Server IP : 184.154.167.98 / Your IP : 18.226.186.153 Web Server : Apache System : Linux pink.dnsnetservice.com 4.18.0-553.22.1.lve.1.el8.x86_64 #1 SMP Tue Oct 8 15:52:54 UTC 2024 x86_64 User : puertode ( 1767) PHP Version : 8.2.27 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /home/puertode/public_html/nextcloud/apps/files_videoplayer/js/ |
Upload File : |
{"version":3,"sources":["webpack:///./node_modules/video.js/dist/video-js.css?02fd","webpack:///./node_modules/m3u8-parser/dist/m3u8-parser.es.js","webpack:///./node_modules/pkcs7/dist/pkcs7.es.js","webpack:///./node_modules/aes-decrypter/dist/aes-decrypter.es.js","webpack:///./node_modules/video.js/dist/video.es.js","webpack:///./node_modules/mux.js/lib/utils/stream.js","webpack:///./node_modules/mux.js/lib/m2ts/stream-types.js","webpack:///./node_modules/global/window.js","webpack:///./node_modules/mux.js/lib/mp4/probe.js","webpack:///(webpack)/buildin/global.js","webpack:///./node_modules/mux.js/lib/mp4/transmuxer.js","webpack:///./node_modules/mux.js/lib/aac/utils.js","webpack:///./node_modules/mux.js/lib/mp4/mp4-generator.js","webpack:///./node_modules/mux.js/lib/m2ts/caption-stream.js","webpack:///./node_modules/mux.js/lib/tools/caption-packet-parser.js","webpack:///./node_modules/mux.js/lib/m2ts/timestamp-rollover-stream.js","webpack:///./node_modules/css-loader/dist/runtime/api.js","webpack:///./node_modules/style-loader/lib/addStyles.js","webpack:///./node_modules/safe-json-parse/tuple.js","webpack:///./node_modules/videojs-vtt.js/lib/browser-index.js","webpack:///./node_modules/videojs-vtt.js/lib/vtt.js","webpack:///./node_modules/videojs-vtt.js/lib/vttcue.js","webpack:///./node_modules/videojs-vtt.js/lib/vttregion.js","webpack:///./node_modules/tsml/tsml.js","webpack:///./node_modules/xhr/index.js","webpack:///./node_modules/is-function/index.js","webpack:///./node_modules/parse-headers/parse-headers.js","webpack:///./node_modules/trim/index.js","webpack:///./node_modules/for-each/index.js","webpack:///./node_modules/is-callable/index.js","webpack:///./node_modules/xtend/immutable.js","webpack:///./node_modules/url-toolkit/src/url-toolkit.js","webpack:///./node_modules/global/document.js","webpack:///./node_modules/mpd-parser/dist/mpd-parser.es.js","webpack:///./node_modules/mux.js/lib/utils/bin.js","webpack:///./node_modules/mux.js/lib/mp4/index.js","webpack:///./node_modules/mux.js/lib/mp4/frame-utils.js","webpack:///./node_modules/mux.js/lib/mp4/audio-frame-utils.js","webpack:///./node_modules/mux.js/lib/data/silence.js","webpack:///./node_modules/mux.js/lib/utils/clock.js","webpack:///./node_modules/mux.js/lib/mp4/track-decode-info.js","webpack:///./node_modules/mux.js/lib/m2ts/m2ts.js","webpack:///./node_modules/mux.js/lib/m2ts/metadata-stream.js","webpack:///./node_modules/mux.js/lib/codecs/adts.js","webpack:///./node_modules/mux.js/lib/codecs/h264.js","webpack:///./node_modules/mux.js/lib/utils/exp-golomb.js","webpack:///./node_modules/mux.js/lib/aac/index.js","webpack:///./node_modules/mux.js/lib/mp4/caption-parser.js","webpack:///./node_modules/mux.js/lib/tools/mp4-inspector.js","webpack:///./node_modules/mux.js/lib/tools/ts-inspector.js","webpack:///./node_modules/mux.js/lib/m2ts/probe.js","webpack:///./node_modules/style-loader/lib/urls.js","webpack:///./node_modules/video.js/dist/video-js.css"],"names":["content","__webpack_require__","module","i","options","hmr","transform","insertInto","undefined","locals","exports","classCallCheck","instance","Constructor","TypeError","_extends","Object","assign","target","arguments","length","source","key","prototype","hasOwnProperty","call","inherits","subClass","superClass","create","constructor","value","enumerable","writable","configurable","setPrototypeOf","__proto__","possibleConstructorReturn","self","ReferenceError","Stream","this","listeners","on","type","listener","push","off","index","indexOf","splice","trigger","callbacks","args","Array","slice","apply","dispose","pipe","destination","data","LineStream","_Stream","_this","buffer","nextNewline","substring","parseAttributes","attributes","attrs","split","RegExp","result","attr","exec","replace","ParseStream","customParsers","line","match","event","tagType","duration","parseFloat","title","parseInt","version","number","playlistType","offset","allowed","test","URI","uri","BYTERANGE","_attributes$BYTERANGE","byterange","RESOLUTION","resolution","width","height","BANDWIDTH","dateTimeString","dateTimeObject","Date","IV","toLowerCase","Uint32Array","PRECISE","text","addParser","_ref","_this2","expression","customType","dataParser","segment","Parser","lineStream","parseStream","uris","currentUri","currentMap","_key","defaultMediaGroups","AUDIO","VIDEO","CLOSED-CAPTIONS","SUBTITLES","currentTimeline","manifest","allowCache","discontinuityStarts","segments","entry","mediaGroup","rendition","tag","allow-cache","message","endlist","endList","inf","mediaSequence","discontinuitySequence","METHOD","method","iv","media-sequence","isFinite","discontinuity-sequence","playlist-type","playlist","map","stream-inf","playlists","mediaGroups","media","TYPE","NAME","mediaGroupType","default","DEFAULT","autoselect","AUTOSELECT","LANGUAGE","language","instreamId","CHARACTERISTICS","characteristics","FORCED","forced","discontinuity","program-date-time","targetduration","targetDuration","totalduration","totalDuration","start","isNaN","timeOffset","precise","cue-out","cueOut","cue-out-cont","cueOutCont","cue-in","cueIn","timeline","comment","custom","chunk","end","aes_decrypter_es_classCallCheck","createClass","defineProperties","props","descriptor","defineProperty","protoProps","staticProps","aes_decrypter_es_possibleConstructorReturn","precompute","tables","encTable","decTable","sbox","sboxInv","x","xInv","d","th","x2","x4","s","tEnc","tDec","aesTables","AES","_tables","j","tmp","encKey","decKey","keyLen","rcon","Error","decrypt","encrypted0","encrypted1","encrypted2","encrypted3","out","a","b","c","a2","b2","c2","nInnerRounds","kIndex","table","table0","table1","table2","table3","aes_decrypter_es_Stream","_length","_i","AsyncStream","jobs","delay","timeout_","aes_decrypter_es_inherits","processJob_","shift","setTimeout","bind","job","ntoh","word","encrypted","initVector","encrypted32","Int32Array","byteOffset","byteLength","decipher","decrypted","Uint8Array","decrypted32","init0","init1","init2","init3","wordIx","aes_decrypter_es_Decrypter","Decrypter","done","step","STEP","asyncStream_","decryptChunk_","subarray","padded","bytes","set","get","video_es_version","_inheritsLoose","_setPrototypeOf","o","p","_construct","Parent","Class","Reflect","construct","sham","Proxy","toString","e","isNativeReflectConstruct","Function","_assertThisInitialized","_taggedTemplateLiteralLoose","strings","raw","video_es_history","video_es_LogByTypeFactory","name","log","level","lvl","levels","lvlRegExp","unshift","toUpperCase","concat","window_default","console","fn","info","isArray","video_es_log","createLogger","logByType","_len","subname","all","debug","warn","error","history","filter","fname","historyItem","clear","disable","enable","_len2","_key2","_len3","_key3","_len4","_key4","createLogger$1","video_es_toString","keys","object","isObject","each","forEach","video_es_assign","sources","isPlain","video_es_computedStyle","el","prop","getComputedStyle","cs","_templateObject","isNonBlankString","str","throwIfWhitespace","isReal","document_default","document","isEl","nodeType","isInFrame","parent","createQuerier","selector","context","querySelector","ctx","createEl","tagName","properties","createElement","getOwnPropertyNames","propName","val","tsml_default","setAttribute","textContent","attrName","appendContent","innerText","prependTo","child","firstChild","insertBefore","appendChild","hasClass","element","classToCheck","classList","contains","className","addClass","classToAdd","add","trim","removeClass","classToRemove","remove","join","toggleClass","classToToggle","predicate","has","setAttributes","attrValue","removeAttribute","getAttributes","obj","knownBooleans","attrVal","getAttribute","attribute","blockTextSelection","body","focus","onselectstart","unblockTextSelection","getBoundingClientRect","parentNode","rect","k","findPosition","box","left","top","docEl","documentElement","clientLeft","scrollLeft","pageXOffset","clientTop","scrollTop","pageYOffset","Math","round","getPointerPosition","position","boxW","offsetWidth","boxH","offsetHeight","boxY","boxX","pageY","pageX","changedTouches","y","max","min","isTextNode","emptyEl","removeChild","normalizeContent","createTextNode","node","insertContent","isSingleLeftClick","button","buttons","$","$$","Dom","freeze","_guid","newGUID","elData","elIdAttr","getTime","getData","id","hasData","removeData","_cleanUpEvents","elem","handlers","removeEventListener","dispatcher","detachEvent","disabled","_handleMultipleEvents","types","callback","fixEvent","returnTrue","returnFalse","isPropagationStopped","old","preventDefault","srcElement","relatedTarget","fromElement","toElement","returnValue","defaultPrevented","stopPropagation","cancelBubble","stopImmediatePropagation","isImmediatePropagationStopped","clientX","doc","clientY","which","charCode","keyCode","_supportsPassive","opts","addEventListener","passiveEvents","guid","hash","handlersCopy","m","n","passive","attachEvent","removeType","t","elemData","ownerDocument","bubbles","targetData","one","func","videojs","Events","_windowLoaded","video_es_autoSetup","autoSetup","vids","getElementsByTagName","audios","divs","mediaEls","mediaEl","autoSetupTimeout","player","wait","vjs","readyState","EVENT_MAP","video_es_createStyleElement","style","setTextContent","styleSheet","cssText","uid","bound","throttle","last","now","video_es_debounce","immediate","timeout","debounced","_later","clearTimeout","cancel","EventTarget","allowedEvents_","ael","dispatchEvent","queueTrigger","Map","oldTimeout","delete","size","isEvented","eventBusEl_","every","isValidEventType","validateTarget","nodeName","validateEventType","validateListener","normalizeListenArgs","isTargetingSelf","listen","EventedMixin","_normalizeListenArgs","removeListenerOnDispose","removeRemoverOnTargetDispose","_normalizeListenArgs2","wrapper","largs","targetOrType","typeOrListener","evented","eventBusKey","eventedCallbacks","StatefulMixin","state","setState","stateUpdates","changes","from","to","stateful","defaultState","handleStateChanged","toTitleCase","string","charAt","mergeOptions","video_es_Component","Component","ready","play","player_","options_","id_","name_","el_","children_","childIndex_","childNameIndex_","initChildren","reportTouchActivity","enableTouchActivity","_proto","localize","tokens","defaultValue","code","languages","primaryCode","primaryLang","localizedString","ret","contentEl","contentEl_","children","getChildById","getChild","addChild","component","componentName","componentClassName","componentClass","ComponentClass","getComponent","refNode","childFound","compEl","workingChildren","parentOptions","Tech","some","wchild","isTech","playerOptions","newChild","buildCSSClass","sync","isReady_","readyQueue_","triggerReady","readyQueue","show","hide","lockShowing","unlockShowing","num","skipListeners","dimension","dimensions","widthOrHeight","pxIndex","currentDimension","computedWidthOrHeight","computedStyle","getPropertyValue","rule","currentDimensions","currentWidth","currentHeight","blur","emitTapEvents","couldBeTap","touchStart","firstTouch","touches","xdiff","ydiff","sqrt","noTap","reportUserActivity","touchHolding","report","clearInterval","setInterval","touchEnd","timeoutId","disposeFn","interval","_this3","intervalId","requestAnimationFrame","_this4","supportsRaf_","cancelAnimationFrame","registerComponent","ComponentToRegister","reason","isComp","isPrototypeOf","components_","Player","players","playerNames","pname","Boolean","USER_AGENT","navigator","userAgent","webkitVersionMap","appleWebkitVersion","pop","IS_IPAD","IS_IPHONE","IS_IPOD","IS_IOS","IOS_VERSION","IS_ANDROID","ANDROID_VERSION","major","minor","IS_NATIVE_ANDROID","IS_FIREFOX","IS_EDGE","IS_CHROME","CHROME_VERSION","IE_VERSION","IS_SAFARI","IS_ANY_SAFARI","TOUCH_ENABLED","maxTouchPoints","DocumentTouch","browser","getRange","fnName","valueIndex","ranges","rangeIndex","maxIndex","rangeCheck","createTimeRangesObj","createTimeRanges","bufferedPercent","buffered","bufferedDuration","browserApi","FullscreenApi","apiMap","specApi","video_es_i","dist_video_es_i","MediaError","defaultMessages","status","errorTypes","1","2","3","4","5","errNum","isPromise","then","silencePromise","trackToJson_","track","reduce","acc","cues","cue","startTime","endTime","textTrackConverter","tech","trackEls","trackObjs","trackEl","json","src","textTracks","addedTrack","addRemoteTextTrack","addCue","MODAL_CLASS_NAME","video_es_ModalDialog","_Component","ModalDialog","opened_","hasBeenOpened_","hasBeenFilled_","closeable","uncloseable","role","descEl_","description","tabIndex","aria-describedby","aria-hidden","aria-label","label","previouslyActiveEl_","handleKeyPress","close","desc","open","fillAlways","fill","wasPlaying_","paused","pauseOnOpen","pause","hadControls_","controls","conditionalFocus_","opened","conditionalBlur_","temporary","closeable_","temp","controlText","fillWith","parentEl","nextSiblingEl","nextSibling","empty","closeButton","content_","activeEl","activeElement","playerEl","handleKeyDown","focusIndex","focusableEls","focusableEls_","shiftKey","allChildren","querySelectorAll","HTMLAnchorElement","HTMLAreaElement","hasAttribute","HTMLInputElement","HTMLSelectElement","HTMLTextAreaElement","HTMLButtonElement","HTMLIFrameElement","HTMLObjectElement","HTMLEmbedElement","TrackList","_EventTarget","tracks","tracks_","addTrack","removeTrack","rtrack","l","getTrackById","video_es_event","change","addtrack","removetrack","disableOthers","list","enabled","AudioTrackList","_TrackList","changing_","disableOthers$1","selected","VideoTrackList","TextTrackList","kind","HtmlTrackElementList","trackElements","trackElements_","addTrackElement_","trackElement","getTrackElementByTrack_","trackElement_","removeTrackElement_","TextTrackCueList","setCues_","length_","oldLength","cues_","defineProp","getCueById","VideoTrackKind","alternative","captions","main","sign","subtitles","commentary","AudioTrackKind","descriptions","main-desc","translation","TextTrackKind","chapters","metadata","TextTrackMode","hidden","showing","Track","trackProps","_loop","video_es_parseUrl","url","href","div","addToBody","host","protocol","innerHTML","details","location","video_es_getAbsoluteURL","getFileExtension","path","pathParts","video_es_isCrossOrigin","winLoc","urlInfo","Url","parseUrl","getAbsoluteURL","isCrossOrigin","video_es_parseCues","srcContent","parser","WebVTT","vttjs","StringDecoder","errors","oncue","onparsingerror","onflush","parse","groupCollapsed","groupEnd","flush","video_es_loadTrack","crossOrigin","cors","xhr_default","err","response","responseBody","loaded_","tech_","loadHandler","video_es_TextTrack","_Track","TextTrack","settings","srclang","mode","default_","activeCues_","activeCues","changed","timeupdateHandler","newMode","ct","currentTime","active","originalCue","VTTCue","originalCue_","removeCue","_removeCue","cuechange","AudioTrack","newEnabled","VideoTrack","newSelected","NONE","LOADED","HTMLTrackElement","load","LOADING","ERROR","NORMAL","audio","ListClass","TrackClass","capitalName","video","getterName","privateName","REMOTE","remoteText","remoteTextEl","ALL","names","video_es_Tech","hasStarted_","featuresProgressEvents","manualProgressOn","featuresTimeupdateEvents","manualTimeUpdatesOn","nativeCaptions","nativeTextTracks","featuresNativeTextTracks","emulateTextTracks","autoRemoteTextTracks_","initTrackListeners","nativeControlsForTouch","triggerSourceset","onDurationChange","manualProgress","trackProgress","manualProgressOff","stopTrackingProgress","progressInterval","numBufferedPercent","bufferedPercent_","duration_","manualTimeUpdates","trackCurrentTime","stopTrackingCurrentTime","manualTimeUpdatesOff","currentTimeInterval","manuallyTriggered","clearTracks","removeRemoteTextTrack","cleanupAutoTextTracks","reset","error_","played","setCurrentTime","trackListChanges","addWebVttScript_","_this5","browser_index_default","script","onload","onerror","_this6","remoteTracks","remoteTextTracks","handleAddTrack","handleRemoveTrack","updateDisplay","textTracksChanges","addTextTrack","createTrackHelper","createRemoteTextTrack","manualCleanup","_this7","htmlTrackElement","remoteTextTrackEls","getVideoPlaybackQuality","setPoster","playsinline","setPlaysinline","overrideNativeAudioTracks","overrideNativeVideoTracks","canPlayType","canPlaySource","srcObj","registerTech","techs_","defaultTechOrder_","getTech","featuresVolumeControl","featuresMuteControl","featuresFullscreenResize","featuresPlaybackRate","featuresSourceset","withSourceHandlers","_Tech","registerSourceHandler","handler","sourceHandlers","can","selectSourceHandler","canHandleSource","sh","originalFn","sourceHandler_","setSource","nativeSourceHandler","disposeSourceHandler","currentSource_","handleSource","middlewares","middlewareInstances","TERMINATOR","next","setSourceHelper","middleware","lastRun","_middleware","mwFactory","mwrest","mw","mws","_mws$i","mwf","mwi","getOrCreateFactory","_src","mediate","arg","callMethod","middlewareValue","middlewareIterator","terminated","executeRight","allowedGetters","seekable","allowedSetters","allowedMediators","MimetypesKind","opus","ogv","mp4","mov","m4v","mkv","mp3","aac","oga","m3u8","getMimetype","ext","fixSource","mimetype","MediaLoader","techOrder","techName","isSupported","loadTech_","video_es_ClickableComponent","ClickableComponent","tabIndex_","createControlTextEl","controlTextEl_","aria-live","controlText_","localizedText","nonIconControl","enabled_","handleClick","handleFocus","handleBlur","PosterImage","_ClickableComponent","update","poster","setSrc","backgroundImage","fontMap","monospace","sansSerif","serif","monospaceSansSerif","monospaceSerif","proportionalSansSerif","proportionalSerif","casual","smallcaps","constructColor","color","opacity","hex","tryUpdateStyle","video_es_TextTrackDisplay","TextTrackDisplay","updateDisplayHandler","toggleDisplay","preselectTrack","firstDesc","firstCaptions","preferredTrack","modes","trackList","userPref","cache_","selectedLanguage","aria-atomic","clearDisplay","processCues","descriptionsTrack","captionsSubtitlesTrack","updateForTrack","textTrackSettings","overrides","getValues","cueDiv","displayState","textOpacity","backgroundColor","backgroundOpacity","windowColor","windowOpacity","edgeStyle","textShadow","fontPercent","fontSize","bottom","fontFamily","fontVariant","LoadingSpinner","isAudio","playerType","dir","Button","BigPlayButton","_Button","mouseused_","handleMouseDown","playPromise","cb","playToggle","playFocus","CloseButton","PlayToggle","replay","handlePlay","handlePause","handleEnded","handleSeeked","defaultImplementation","seconds","guide","floor","h","gm","gh","Infinity","implementation","formatTime","video_es_TimeDisplay","TimeDisplay","throttledUpdateContent","updateContent","plainName","labelText_","updateTextNode_","textNode_","formattedTime_","formatTime_","time","updateFormattedTime_","formattedTime","CurrentTimeDisplay","_TimeDisplay","scrubbing","getCache","DurationDisplay","TimeDivider","RemainingTimeDisplay","remainingTimeDisplay","remainingTime","LiveDisplay","updateShowing","SeekToLive","updateLiveEdgeStatus","liveTracker","textEl_","atLiveEdge","seekToLiveEdge","Slider","bar","barName","vertical","playerEvent","handleMouseMove","handleMouseUp","aria-valuenow","aria-valuemin","aria-valuemax","progress","getPercent","percentage","toFixed","calculateDistance","stepBack","stepForward","bool","vertical_","LoadProgressBar","partEls_","isLive","seekableEnd","bufferedEnd","controlTextPercentage","percentify","rounded","percent","part","TimeTooltip","seekBarRect","seekBarPoint","tooltipRect","playerRect","seekBarPointPx","spaceLeftOfPoint","spaceRightOfPoint","right","pullTooltipBy","updateTime","rafId_","liveWindow","secondsBehind","PlayProgressBar","timeTooltip","MouseTimeDisplay","SeekBar","_Slider","setEventHandlers_","updateInterval","update_","liveCurrentTime","getCurrentTime_","seekableStart","videoWasPlaying","newTime","distance","mouseTimeDisplay","handleAction","ProgressControl","throttledHandleMouseSeek","handleMouseSeek","seekBar","seekBarEl","video_es_FullscreenToggle","FullscreenToggle","handleFullscreenChange","fullscreenEnabled","isFullscreen","exitFullscreen","requestFullscreen","checkVolumeSupport","VolumeLevel","VolumeBar","updateLastVolume_","updateARIAAttributes","checkMuted","volume","muted","ariaValue","volumeAsPercentage_","volumeBeforeDrag","lastVolume_","VolumeControl","volumeBar","throttledHandleMouseMove","orientationClass","checkMuteSupport","MuteToggle","vol","lastVolume","volumeToSet","updateIcon_","updateControlText_","VolumePanel","inline","volumeControl","volumePanelState_","sliderActive_","sliderInactive_","muteToggle","video_es_Menu","Menu","menuButton_","menuButton","focusedChild_","addItem","unpressButton","contentElType","append","btn","buttonPressed_","stepChild","item","video_es_MenuButton","MenuButton","buttonClass","menu","handleSubmenuKeyPress","createMenu","items","hideThreshold_","createItems","buildWrapperCSSClass","menuButtonClass","pressButton","TrackButton","_MenuButton","updateHandler","MenuItem","selectable","isSelected_","multiSelectable","_selected","video_es_TextTrackMenuItem","_MenuItem","TextTrackMenuItem","changeHandler","handleTracksChange","selectedLanguageChangeHandler","handleSelectedLanguageChange","onchange","Event","createEvent","initEvent","kinds","shouldBeSelected","OffTextTrackMenuItem","_TextTrackMenuItem","allHidden","TextTrackButton","_TrackButton","TrackMenuItem","label_","kinds_","kind_","ChaptersTrackMenuItem","ChaptersButton","_TextTrackButton","track_","setTrack","findChaptersTrack","updateHandler_","remoteTextTrackEl","_remoteTextTrackEl","getMenuCaption","mi","DescriptionsButton","SubtitlesButton","CaptionSettingsMenuItem","CaptionsButton","SubsCapsMenuItem","SubsCapsButton","language_","AudioTrackMenuItem","audioTracks","AudioTrackButton","PlaybackRateMenuItem","rate","playbackRate","PlaybackRateMenuButton","updateVisibility","updateLabel","labelEl_","rates","playbackRates","currentRate","newRate","playbackRateSupported","Spacer","CustomControlSpacer","_Spacer","ControlBar","ErrorDisplay","_ModalDialog","COLOR_BLACK","COLOR_BLUE","COLOR_CYAN","COLOR_GREEN","COLOR_MAGENTA","COLOR_RED","COLOR_WHITE","COLOR_YELLOW","OPACITY_OPAQUE","OPACITY_SEMI","OPACITY_TRANS","selectConfigs","v","Number","parseOptionValue","video_es_TextTrackSettings","TextTrackSettings","endDialog","setDefaults","persistTextTrackSettings","saveSettings","config","restoreSettings","createElSelect_","legendId","selectLabelledbyIds","optionId","createElFgColor_","createElBgColor_","createElWinColor_","createElColors_","createElFont_","createElControls_","defaultsDescription","initial","accum","selectedIndex","setValues","values","setSelectedOption","JSON","localStorage","getItem","setItem","stringify","removeItem","ttDisplay","controlBar","subsCapsBtn","subsCapsButton","ccBtn","captionsButton","video_es_ResizeManager","ResizeManager","RESIZE_OBSERVER_AVAILABLE","ResizeObserver","loadListener_","resizeObserver_","debouncedHandler_","resizeHandler","observe","contentWindow","unobserve","disconnect","resizeObserver","LiveTracker","reset_","handleDurationchange","isBehind_","timeupdateSeen_","seekableIncrement","seekableIncrement_","trackLive_","pastSeekEnd_","newSeekEnd","lastSeekEnd_","abs","pastSeekEnd","behindLiveEdge","behindLiveEdge_","startTracking","stopTracking","isTracking","trackingInterval_","handleTimeupdate","seekableEnds","sort","seekableStarts","sourcesetLoad","srcUrls","innerHTMLDescriptorPolyfill","cloneNode","dummy","docFrag","createDocumentFragment","childNodes","Element","getDescriptor","priority","getOwnPropertyDescriptor","firstSourceWatch","resetSourceWatch_","innerDescriptor","HTMLMediaElement","video_es_getInnerHTMLDescriptor","appendWrapper","appendFn","retval","srcDescriptorPolyfill","setupSourceset","resetSourceset_","srcDescriptor","video_es_getSrcDescriptor","oldSetAttribute","oldLoad","currentSrc","_templateObject$1","video_es_Html5","Html5","crossoriginTracks","initNetworkState_","handleLateInit_","enableSourceset","setupSourcesetHandling_","hasChildNodes","nodes","nodesLength","removeNodes","proxyNativeTracks_","restoreMetadataTracksInIOSNativePlayer_","setControls","proxyWebkitFullscreen_","disposeMediaElement","metadataTracksPreFullscreenState","takeMetadataTrackSnapshot","storedMode","restoreTrackMode","storedTrack","overrideNative_","override","lowerCaseType","eventName","proxyNativeTracksForType_","elTracks","techTracks","currentTarget","removeOldTracks","removeTracks","found","playerElIngest","movingMediaElementInDOM","clone","techId","class","playerId","preload","settingsAttrs","networkState","loadstartFired","setLoadstartFired","triggerLoadstart","eventsToTrigger","checkProgress","NaN","endFn","beginFn","webkitPresentationMode","supportsFullScreen","webkitEnterFullScreen","enterFullScreen","HAVE_METADATA","exitFullScreen","webkitExitFullScreen","resetMediaElement","videoPlaybackQuality","webkitDroppedFrameCount","webkitDecodedFrameCount","droppedVideoFrames","totalVideoFrames","performance","creationTime","timing","navigationStart","TEST_VID","video_es_track","canControlVolume","canMuteVolume","canControlPlaybackRate","canOverrideAttributes","noop","supportsNativeTextTracks","supportsNativeVideoTracks","videoTracks","supportsNativeAudioTracks","featuresNativeVideoTracks","featuresNativeAudioTracks","mpegurlRE","_templateObject$2","patchCanPlayType","unpatchCanPlayType","r","TECH_EVENTS_RETRIGGER","TECH_EVENTS_QUEUE","canplay","canplaythrough","playing","seeked","BREAKPOINT_ORDER","BREAKPOINT_CLASSES","DEFAULT_BREAKPOINTS","tiny","xsmall","small","medium","large","xlarge","huge","video_es_Player","getTagSettings","closest","isPosterFromTech_","queuedCallbacks_","userActive_","tagAttributes","languagesToLower","name$$1","languages_","poster_","controls_","autoplay","scrubbing_","lastPlaybackRate","defaultPlaybackRate","fluid_","updateStyleEl_","playerOptionsCopy","plugins","middleware_","flexNotSupported_","majorVersion","userActive","listenForUserActivity_","handleFullscreenChange_","handleStageClick_","breakpoints","responsive","changingSrc_","playWaitingForReady_","playOnLoadstart_","styleEl_","playerElIngest_","divEmbed","tabindex","VIDEOJS_NO_DYNAMIC_STYLE","defaultsStyleEl","head","fill_","fluid","aspectRatio","links","linkEl","_dimension","privDimension","parsedVal","ratio","aspectRatio_","idClass","ratioParts","videoWidth","videoHeight","ratioMultiplier","width_","height_","_width","_height","techEl","unloadTech_","titleTechName","camelTechName","techName_","techOptions","loop","vtt.js","canOverridePoster","techCanOverridePoster","TechClass","handleTechReady_","textTracksJson_","eventObj","seeking","handleTechLoadStart_","handleTechSourceset_","handleTechWaiting_","handleTechEnded_","handleTechSeeking_","handleTechPlay_","handleTechFirstPlay_","handleTechPause_","handleTechDurationChange_","handleTechFullscreenChange_","handleTechError_","handleTechPosterChange_","handleTechTextData_","handleTechRateChange_","usingNativeControls","techGet_","addTechControlsListeners_","safety","removeTechControlsListeners_","handleTechClick_","handleTechDoubleClick_","handleTechTouchStart_","handleTechTouchMove_","handleTechTouchEnd_","handleTechTap_","techCall_","hasStarted","manualAutoplay_","promise","previouslyMuted","catch","updateSourceCaches_","matchingSources","findMimetype","sourceElSources","sourceEls","matchingSourceEls","sourceObj","updateSourceCaches","playerSrc","currentSource","eventSrc","lastSource_","updateCache","techSrc","techGet","request","queued","timeWhenWaiting","timeUpdateListener","handleTechCanPlay_","handleTechCanPlayThrough_","handleTechPlaying_","handleTechSeeked_","starttime","userWasActive","set$1","reduceRight","video_es_get","PromiseClass","Promise","resolve","play_","_this8","isScrubbing","liveui","percentAsDecimal","_muted","defaultMuted","_defaultMuted","isFS","isFullscreen_","fsApi","fullscreenchange","documentFullscreenChange","fullscreenElement","enterFullWindow","exitFullWindow","isFullWindow","docOrigOverflow","overflow","fullWindowOnEscKey","selectSource","_this9","techs","findFirstPassingTechSourcePair","outerArray","innerArray","tester","outerChoice","innerChoice","finder","_ref2","sourceOrder","_this10","filterSource","newsrc","srcobj","middlewareSource","src_","notSupportedMessage","setTech","str1","str2","_this11","sourceTech","currentSources","currentType","techAutoplay","newPoster","usingNativeControls_","errorDisplay","userActivity_","mouseInProgress","lastMoveX","lastMoveY","inactivityTimeout","handleActivity","screenX","screenY","isAudio_","String","toJSON","createModal","_this12","modal","updateCurrentBreakpoint_","currentBreakpoint","candidateBreakpoint","breakpoints_","breakpoint_","removeCurrentBreakpoint_","currentBreakpointClass","_breakpoints","responsive_","baseOptions","tagOptions","dataSetup","_safeParseTuple","tuple_default","childName","video_es_navigator","html5","flash","userLanguage","pluginStorage","pluginExists","getPlugin","markPluginAsActive","triggerSetupEvent","before","createPluginFactory","PluginSubClass","plugin","getEventHash","Plugin","VERSION","isBasic","registerPlugin","basicPluginWrapper","createBasicPlugin","deregisterPlugin","getPlugins","getPluginVersion","BASE_PLUGIN_NAME","usingPlugin","hasPlugin","normalizeId","videojs$1","getPlayer","hooks","hookFunction","PlayerComponent","hooks_","hook","hookOnce","original","removeHook","style$1","video_es_head","getPlayers","nId","_tag","_player","getAllPlayers","comp","use","writeable","extend","subClassMethods","methods","super_","_inherits$1","addLanguage","_mergeOptions","createTimeRange","setFormatTime","customImplementation","resetFormatTime","xhr","dom","video_es_resolveUrl","baseURL","relativeURL","url_toolkit_default","buildAbsoluteURL","video_es_classCallCheck","video_es_createClass","video_es_inherits","video_es_possibleConstructorReturn","slicedToArray","arr","Symbol","iterator","_arr","_n","_d","_e","_s","sliceIterator","mergeOptions$1","EventTarget$1","log$1","forEachMediaGroup","master","mediaType","groupKey","labelKey","mediaProperties","updateMaster","mergedPlaylist","updateSegments","baseUri","resolvedUri","resolveSegmentUris","setupMediaPlaylists","resolveMediaGroupUris","refreshDelay","lastSegment","video_es_PlaylistLoader","PlaylistLoader","srcUrl","hls","withCredentials","getPrototypeOf","hls_","req","playlistRequestError","haveMetadata","xhr$$1","startingState","responseText","media_","mediaUpdateTimeout","stopRequest","oldRequest","onreadystatechange","abort","mediaChange","started","isFinalRendition","intervalDuration","endSequence","expired","backward","forward","backwardDuration","forwardDuration","video_es_duration","sumDurations","startIndex","endIndex","durations","safeLiveIndex","distanceFromEnd","safeDistance","playlistEnd","useSafeLiveEnd","isWholeNumber","roundSignificantDigit","increment","numDecimalDigits","scale","pow","ceilLeastSignificantDigit","floorLeastSignificantDigit","isBlacklisted","excludeUntil","isIncompatible","isEnabled","blacklisted","isLowestEnabledRendition","currentBandwidth","MAX_VALUE","Playlist","getMediaInfoForTime","numSegments","mediaIndex","isDisabled","isAes","isFmp4","estimateSegmentRequestTime","segmentDuration","bandwidth","bytesReceived","videojsXHR","mergeOptions$1$1","xhrFactory","XhrFunction","beforeRequest","Hls","newOptions","reqResponse","responseTime","roundTripTime","requestTime","headers","responseHeaders","timedout","aborted","statusCode","originalAbort","textRange","range","formatHexString","formatAsciiString","fromCharCode","createTransferableMessage","transferable","ArrayBuffer","isView","initSegmentId","initSegment","hexDump","utils","tagDump","textRanges","timeWithinSegment","requestedTime","segmentStart","requestedTimeString","toISOString","segmentTimeString","endTimeString","findSegmentForTime","manifestTime","estimatedEnd","estimatedStart","timeWithinSegmentEnd","timeWithinSegmentDuration","getStreamTime","_ref$time","matchedSegment","findSegmentForPlayerTime","seekTime","streamTime","mediaSeconds","programDateTime","seekToStreamTime","_ref2$retryCount","retryCount","seekTo","_ref2$pauseAfterSeek","pauseAfterSeek","verifyProgramDateTimeTags","findSegmentForStreamTime","mediaOffset","comparisonTimeStamp","segmentDateTime","streamDateTime","segmentTimeEpoch","getOffsetFromTimestamp","seekToTime","filterRanges","timeRanges","results","findRange","findNextRange","printableRange","strArr","timeRangesToArray","timeRangesList","removeCuesFromTrack","durationOfVideo","video_es_addTextTrackData","sourceHandler","captionArray","metadataArray","Cue","WebKitDataCue","caption","stream","inbandTextTracks_","timestampOffset","videoDuration","mediaSource_","cueTime","frames","frame","privateData","deprecateOldCue","metadataTrack_","cuesArray","cuesGroupedByStartTime","timeSlot","sortedStartTimes","idx","cueGroup","nextTime","win","window","TARGET","SCRIPT_TYPE","BlobBuilder","WebKitBlobBuilder","MozBlobBuilder","MSBlobBuilder","URL","webkitURL","msURL","Worker","shimWorker","filename","forceFallback","objURL","createSourceObject","worker","term","terminate","revokeObjectURL","wrapTerminate","selfShim","postMessage","onmessage","isThisThread","testWorker","testArray","createObjectURL","Blob","blob","getBlob","TransmuxWorker","document$$1","dinf","esds","ftyp","mfhd","minf","moof","moov","mvex","mvhd","trak","tkhd","mdia","mdhd","hdlr","sdtp","stbl","stsd","traf","trex","trun","MAJOR_BRAND","MINOR_VERSION","AVC1_BRAND","VIDEO_HDLR","AUDIO_HDLR","HDLR_TYPES","VMHD","SMHD","DREF","STCO","STSC","STSZ","STTS","videoSample","audioSample","audioTrun","videoTrun","trunHeader","UINT32_MAX","avc1","avcC","btrt","dref","mdat","mp4a","smhd","stco","stsc","stsz","stts","styp","tfdt","tfhd","vmhd","charCodeAt","payload","DataView","setUint32","audioobjecttype","samplingfrequencyindex","channelcount","samplerate","sequenceNumber","trackFragments","boxes","flags","samples","dependsOn","isDependedOn","hasRedundancy","sps","pps","sequenceParameterSets","pictureParameterSets","profileIdc","profileCompatibility","levelIdc","samplesize","trackFragmentHeader","trackFragmentDecodeTime","trackFragmentRun","sampleDependencyTable","upperWordBaseMediaDecodeTime","lowerWordBaseMediaDecodeTime","baseMediaDecodeTime","durationPresent","sizePresent","flagsPresent","compositionTimeOffset","sample","isLeading","paddingValue","isNonSyncSample","degradationPriority","_findBox","parseType","timescale","getVideoTrackIds","mp4Generator","fileType","movie","toUnsigned$1","init","fragment","trafs","baseTimes","traks","videoTrackIds","hdlrs","tkhds","view","trackId","handlerType","getUint8","getUint32","probe","findBox","subresults","flushSource","metaTable","secondsToVideoTs","secondsToAudioTs","videoTsToSeconds","audioTsToSeconds","audioTsToVideoTs","videoTsToAudioTs","sampleForFrame","dataOffset","pts","dts","keyFrame","frameUtils","nalUnits","currentNal","currentFrame","nalUnitType","currentGop","gops","nalCount","baseDataOffset","nalsByteLength","numberOfNals","highPrefix","lowPrefix","zeroFill","count","coneOfSilence","96000","88200","64000","48000","44100","32000","24000","16000","12000","11025","8000","silence","timestamp","sampleRate","clock","audioFrameUtils","audioAppendStartTs","videoBaseMediaDecodeTime","baseMediaDecodeTimeTs","frameDuration","silentFrame","audioGapDuration","audioFillFrameCount","audioFillDuration","ceil","ONE_SECOND_IN_TS$1","adtsFrames","earliestAllowedDts","minSegmentDts","minSegmentPts","array","sum","sumFrameByteLengths","trackDecodeInfo","maxSegmentDts","maxSegmentPts","keepOriginalTimestamps","timelineStartInfo","captionPacketParser","payloadType","payloadSize","sei","userData","ccData","newLength","newData","emulationPreventionBytesPositions","sourceIndex","CaptionStream","captionPackets_","ccStreams_","Cea608Stream","cc","newCaptionPackets","escapedRBSP","latestDts_","ignoreNextEqualDts_","numSameDts_","presortIndex","packet","dispatchCea608Packet","activeCea608Channel_","ccStream","setsChannel1Active","setsChannel2Active","CHARACTER_TRANSLATION","42","92","94","95","96","123","124","125","126","127","304","305","306","307","308","309","310","311","312","313","314","315","316","317","318","319","544","545","546","547","548","549","550","551","552","553","554","555","556","557","558","559","560","561","562","563","564","565","566","567","568","569","570","571","572","573","574","575","800","801","802","803","804","805","806","807","808","809","810","811","812","813","814","815","816","817","818","819","820","821","822","823","824","825","826","827","828","829","830","831","getCharFromCode","ROWS","createDisplayBuffer","BOTTOM_ROW","field","dataChannel","field_","dataChannel_","setConstants","swap","char0","char1","lastControlCode_","PADDING_","RESUME_CAPTION_LOADING_","mode_","END_OF_CAPTION_","clearFormatting","flushDisplayed","displayed_","nonDisplayed_","startPts_","ROLL_UP_2_ROWS_","rollUpRows_","setRollUp","ROLL_UP_3_ROWS_","ROLL_UP_4_ROWS_","CARRIAGE_RETURN_","shiftRowsUp_","BACKSPACE_","row_","ERASE_DISPLAYED_MEMORY_","ERASE_NON_DISPLAYED_MEMORY_","RESUME_DIRECT_CAPTIONING_","isSpecialCharacter","column_","isExtCharacter","isMidRowCode","addFormatting","isOffsetControlCode","isPAC","row","formatting_","isColorPAC","isNormalChar","startPts","endPts","topRow_","BASE_","EXT_","CONTROL_","OFFSET_","char","newBaseRow","format","reverse","popOn","baseRow","rollUp","paintOn","captionStream","streamTypes","H264_STREAM_TYPE","ADTS_STREAM_TYPE","METADATA_STREAM_TYPE","handleRollover","reference","direction","TimestampRolloverStream","lastDTS","referenceDTS","type_","_MetadataStream","timestampRolloverStream","percentEncode","parseUtf8","decodeURIComponent","parseSyncSafeInteger","tagParsers","TXXX","WXXX","PRIV","owner","unescape","tagSize","bufferSize","dispatchType","frameStart","frameSize","dataAlignmentIndicator","timeStamp","_TransportPacketStream","_TransportParseStream","_ElementaryStream","metadataStream","TimestampRolloverStream$1","bytesInBuffer","everything","parsePsi","parsePat","parsePmt","packetsWaitingForPmt","programMapTable","psi","payloadUnitStartIndicator","pat","section_number","last_section_number","pmtPid","pmt","tableEnd","timed-metadata","streamType","pid","processPes_","STREAM_TYPES","h264","adts","timedMetadata","flushStream","stream$$1","forceFlush","packetFlushable","packetData","pes","ptsDtsFlags","packetLength","codec","m2ts","PAT_PID","MP2T_PACKET_LENGTH","TransportPacketStream","TransportParseStream","ElementaryStream","MetadataStream","_AdtsStream","m2ts_1","ADTS_SAMPLING_FREQUENCIES","frameLength","protectionSkipBytes","frameEnd","oldBuffer","sampleCount","adtsFrameDuration","frameNum","_H264Stream","_NalByteStream","PROFILES_WITH_OPTIONAL_SPS_DATA","expGolomb","workingData","workingBytesAvailable","workingWord","workingBitsAvailable","bitsAvailable","loadWord","workingBytes","availableBytes","skipBits","skipBytes","readBits","bits","valu","skipLeadingZeros","leadingZeroCount","skipUnsignedExpGolomb","skipExpGolomb","readUnsignedExpGolomb","clz","readExpGolomb","readBoolean","readUnsignedByte","syncPoint","swapBuffer","100","110","122","244","44","83","86","118","128","138","139","134","currentPts","currentDts","discardEmulationPreventionBytes","readSequenceParameterSet","skipScalingList","nalByteStream","expGolombDecoder","lastScale","nextScale","chromaFormatIdc","picOrderCntType","numRefFramesInPicOrderCntCycle","picWidthInMbsMinus1","picHeightInMapUnitsMinus1","frameMbsOnlyFlag","scalingListCount","sarRatio","frameCropLeftOffset","frameCropRightOffset","frameCropTopOffset","frameCropBottomOffset","sarScale","_AacStream","H264Stream","NalByteStream","header","byteIndex","returnSize","lowThree","middle","setTimestamp","bytesLeft","tempLength","_VideoSegmentStream","_AudioSegmentStream","_Transmuxer","_CoalesceStream","isLikelyAacData$1","AUDIO_PROPERTIES","VIDEO_PROPERTIES","arrayEquals","setEarliestDts","earliestDts","setVideoBaseMediaDecodeTime","setAudioAppendStart","gopsToAlignWith","minPTS","gopCache_","nalUnit","gopForFusion","resetStream_","getGopForFusion_","alignedGops","alignGopsAtEnd","alignGopsAtEnd_","alignGopsAtStart_","gop","dtsDistance","nearestGopObj","currentGopObj","nearestDistance","alignIndex","gopIndex","align","alignEndIndex","matchFound","trimIndex","total","alignGopsWith","newGopsToAlignWith","numberOfTracks","remux","remuxTracks","pendingTracks","videoTrack","pendingBoxes","pendingCaptions","pendingMetadata","pendingBytes","emittedTracks","output","audioTrack","id3","captionStreams","timelineStartPts","hasFlushed","transmuxPipeline_","setupAacPipeline","pipeline","aacStream","audioTimestampRolloverStream","timedMetadataTimestampRolloverStream","adtsStream","coalesceStream","headOfPipeline","audioSegmentStream","setupTsPipeline","packetStream","elementaryStream","videoTimestampRolloverStream","h264Stream","videoSegmentStream","setBaseMediaDecodeTime","isAac","resetCaptions","inspectMp4","_textifyMp","transmuxer","Transmuxer","VideoSegmentStream","AudioSegmentStream","parseType$2","parseMp4Date","parseSampleFlags","nalParse","avcStream","avcView","parse$$1","dataReferenceIndex","getUint16","horizresolution","vertresolution","frameCount","depth","numOfPictureParameterSets","nalSize","configurationVersion","avcProfileIndication","avcLevelIndication","lengthSizeMinusOne","numOfSequenceParameterSets","bufferSizeDB","maxBitrate","avgBitrate","esId","streamPriority","decoderConfig","objectProfileIndication","decoderConfigDescriptor","audioObjectType","samplingFrequencyIndex","channelConfiguration","majorBrand","minorVersion","compatibleBrands","dataReferences","escape","nals","modificationTime","streamDescriptor","matrix","nextTrackId","pdin","initialDelay","sidx","references","referenceId","earliestPresentationTime","firstOffset","referenceCount","referenceType","referencedSize","subsegmentDuration","startsWithSap","sapType","sapDeltaTime","balance","chunkOffsets","entryCount","sampleToChunks","firstChunk","samplesPerChunk","sampleDescriptionIndex","sampleDescriptions","sampleSize","entries","timeToSamples","sampleDelta","baseDataOffsetPresent","sampleDescriptionIndexPresent","defaultSampleDurationPresent","defaultSampleSizePresent","defaultSampleFlagsPresent","durationIsEmpty","defaultBaseIsMoof","defaultSampleDuration","defaultSampleSize","defaultSampleFlags","baseDataOffsetIsMoof","layer","alternateGroup","defaultSampleDescriptionIndex","sampleDependsOn","sampleIsDependedOn","sampleHasRedundancy","samplePaddingValue","sampleIsDifferenceSample","sampleDegradationPriority","dataOffsetPresent","firstSampleFlagsPresent","sampleDurationPresent","sampleSizePresent","sampleFlagsPresent","sampleCompositionTimeOffsetPresent","getInt32","url ","graphicsmode","opcolor","Uint16Array","mp4Inspector","inspect","ab","z","textify","inspectedMp4","indent","prefix","byte","parseTfdt","parseHdlr","parseTfhd","parseTrun","discardEmulationPreventionBytes$1","CaptionStream$1","mapToSample","approximateOffset","parseCaptionNals","videoTrackId","mdats","captionNals","mdatTrafPairs","matchingTraf","pair","seiNals","headerInfo","truns","seiNal","lastMatchedSample","matchingSample","findSeiNals","allSamples","parseSamples","generator","CaptionParser","captionStream$$1","segmentCache","parsedCaptions","isInitialized","isNewInit","timescales","parsedData","cachedSegment","parseEmbeddedCaptions","pushNals","nal","clearParsedCaptions","resetCaptionStream","clearAllCaptions","MessageHandlers","initArray","typedArray","action","gopInfo","appendStart","messageHandlers","defaultCodecs","videoCodec","videoObjectTypeIndicator","audioProfile","translateLegacyCodecs","codecs","orig","profile","avcLevel","parseCodecs","parsed","codecCount","makeMimeTypeString","container","mimeTypesForPlaylist","containerType","getContainerType","codecInfo","mediaAttributes","CODECS","getCodecs","isMuxed","isMaat","audioGroup","groupId","audioGroupId","audioType","audioProfileFromDefault","codecStrings","justAudio","justVideo","bothVideoAudio","isAudioCodec","isVideoCodec","gopsSafeToAlignWith","mapping","currentTimePts","videoBuffer","audioBuffer","audioDisabled","arity","extents","videoBuffered","audioBuffered","VirtualSourceBuffer","_videojs$EventTarget","mediaSource","timestampOffset_","pendingBuffers_","bufferUpdating_","codecs_","audioCodec_","videoCodec_","audioDisabled_","appendAudioInitSegment_","gopBuffer_","timeMapping_","safeAppend_","transmuxer_","data_","done_","appendGopInfo_","videoBuffer_","audioBuffer_","appendWindowStart","updating","sourceBuffer","inBandMetadataTrackDispatchType","createTextTracksIfNecessary","processPendingSegments_","mimeType","addSourceBuffer","realBuffer_","makeWrappedSourceBuffer","nativeMediaSource_","updateGopBuffer","updatedBuffer","removeGopBuffer","sortedSegments","segmentObj","createRealSourceBuffers_","triggerUpdateend","concatAndAppendSegments_","destinationBuffer","tempBuffer","appendBuffer","originalError","video_es_HtmlMediaSource","HtmlMediaSource","property","MediaSource","activeSourceBuffers_","sourceBuffers","updateActiveSourceBuffers_","disableCombined","disableAudioOnly","onPlayerMediachange_","onHlsReset_","onHlsSegmentTimeMapping_","url_","sourcebuffer","parsedType","parameters","parameter","parseContentType","urlCount","mediaSources","video_es_open","msObjectURL","swfId","video_es_supportsNativeMediaSources","isTypeSupported","supportsNativeMediaSources","URL$1","EventTarget$1$1","mergeOptions$2","updateMaster$1","oldMaster","newMaster","minimumUpdatePeriod","playlistUpdate","group","_playlistUpdate","video_es_DashPlaylistLoader","DashPlaylistLoader","srcUrlOrPlaylist","masterPlaylistLoader","refreshXml_","refreshMedia_","masterPlaylistLoader_","mpd_parser_es","masterXml_","manifestUri","clientOffset","clientOffset_","phonyUri","_phonyUri","date","masterLoaded_","syncClientServerClock_","onClientServerClockSync_","utcTiming","serverTime","parseMasterXml","updatedMaster","logger","video_es_noop","SourceUpdater","sourceBufferEmitter","callbacks_","pendingCallback_","processedAppend_","mimeType_","logger_","createSourceBuffer_","sourceBuffer_","start_","started_","onUpdateendCallback_","pendingCallback","runCallback_","queueCallback_","Config","GOAL_BUFFER_LENGTH","MAX_GOAL_BUFFER_LENGTH","GOAL_BUFFER_LENGTH_RATE","INITIAL_BANDWIDTH","BANDWIDTH_VARIANCE","BUFFER_LOW_WATER_LINE","MAX_BUFFER_LOW_WATER_LINE","BUFFER_LOW_WATER_LINE_RATE","REQUEST_ERRORS","segmentXhrHeaders","byterangeEnd","Range","abortAll","activeXhrs","handleErrors","waitForCompletion","decrypter","doneFn","didError","endOfAllRequests","encryptedBytes","decryptionHandler","requestId","decryptSegment","handleProgress","progressFn","progressEvent","stats","loaded","firstBytesReceivedAt","mediaSegmentRequest","xhrOptions","decryptionWorker","captionParser","finishProcessingFn","keyXhr","responseType","errorObj","handleKeyResponse","initSegmentXhr","probe_default","video_es_handleInitSegmentResponse","segmentXhr","getRequestStats","fmp4Captions","handleSegmentResponse","video_es_safeGetComputedStyle","stableSort","sortFn","newArray","cmp","video_es_comparePlaylistBandwidth","leftBandwidth","rightBandwidth","detectEndOfStream","segmentIndex","appendedLastSegment","finite","video_es_SegmentLoader","SegmentLoader","throughput","roundTrip","resetStats_","hasPlayed_","hasPlayed","currentTime_","seekable_","seeking_","loaderType_","loaderType","startingMedia_","segmentMetadataTrack_","segmentMetadataTrack","goalBufferLength_","goalBufferLength","sourceType_","sourceType","inbandTextTracks","state_","checkBufferTimeout_","currentTimeline_","pendingSegment_","sourceUpdater_","xhrOptions_","activeInitSegmentId_","initSegments_","captionParser_","decrypter_","syncController_","syncController","syncPoint_","ended_","fetchAtBuffer_","newState","mediaBytesTransferred","mediaRequests","mediaRequestsAborted","mediaRequestsTimedout","mediaRequestsErrored","mediaTransferDuration","mediaSecondsLoaded","abort_","monitorBuffer_","abortRequests","_error","set$$1","storedMap","playlist_","setDateTimeMapping","couldBeginLoading_","init_","sourceBufferEmitter_","resetEverything","newPlaylist","oldPlaylist","segmentInfo","syncInfo","oldId","mediaSequenceDiff","saveExpiredSegmentInfo","resyncLoader","_mimeType","resetLoader","monitorBufferTick_","fillBuffer_","getSyncPoint","checkBuffer_","buffered_","endOfStream","startOfSegment","loadSegment_","lastBufferedEnd","bufferedTime","getSyncSegmentCandidate_","generateSegmentInfo_","mediaSourceInfo","_mediaSourceInfo","segmentIndexArray","isSyncRequest","random","measuredBandwidth","requestTimeRemaining","timeUntilRebuffer$$1","timeUntilRebuffer","switchCandidate","duration$$1","compatiblePlaylists","enabledPlaylists","rebufferingEstimates","numRequests","rebufferingImpact","noRebufferingPlaylists","estimate","minRebufferMaxBandwidthSelector","timeSavedBySwitching","minimumTimeSaving","simpleSegment","abortRequestEarly_","trimBackBuffer_","createSimplifiedSegmentObj_","handleProgress_","segmentRequestFinished_","removeToTime","seekable$$1","safeBackBufferTrimTime","processSegmentResponse_","createCaptionsTrackIfNotExists","addCaptionData","handleSegment_","timingInfo","probeSegmentInfo","containsAudio","containsVideo","startingMedia","newSegmentMedia","illegalMediaSwitchError","blacklistDuration","timelineMapping","mappingForTimeline","initId","_segmentInfo$segment","_segmentInfo$playlist","seq","_segmentInfo$playlist2","segmentInfoString","handleUpdateEnd_","isWalkingForward","recordThroughput_","addSegmentMetadataCue_","segmentProcessingTime","segmentProcessingThroughput","uint8ToUtf8","uintArray","VTT_LINE_TERMINATORS","video_es_VTTSegmentLoader","_SegmentLoader","VTTSegmentLoader","subtitlesTrack_","combinedByteLength","combinedSegment","_track","skipEmptySegments_","timestampOffsetForTimeline","requested","parseVTTCues_","updateTimeMapping_","timelines","decoder","decodeBytesToString","TextDecoder","timestampmap","MPEGTS","LOCAL","ontimestampmap","mapData","segmentData","mappingObj","diff","firstStart","lastStart","findAdCue","mediaTime","adStartTime","adEndTime","tsprobe","ts_inspector_default","syncPointStrategies","run","datetimeToDisplayTime","lastDistance","discontinuitySync","discontinuities","video_es_SyncController","SyncController","inspectCache_","syncPoints","runStrategies_","selectSyncPoint_","strategy","bestSyncPoint","bestDistance","bestStrategy","newDistance","lastRemovedSegment","playlistTimestamp","probeMp4Segment_","probeTsSegment_","calculateSegmentTimeMapping_","saveDiscontinuitySyncInfo_","timeInfo","segmentStartTime","segmentEndTime","dtsTime","accuracy","mediaIndexDiff","Decrypter$1","AsyncStream$$1","Decrypter$$1","decrypt$$1","audioTrackKind_","stopLoaders","segmentLoader","activePlaylistLoader","startLoaders","playlistLoader","onError","segmentLoaders","mediaTypes","blacklistCurrentPlaylist","activeTrack","activeGroup","defaultTrack","onTrackChanged","setupListeners","requestOptions","byGroupId","byResolvedUri","initialize","_settings$master","_settings$mediaTypes$","groups","groupPlaylists","variantLabel","_settings$mediaTypes$2","_settings$mediaTypes$3","setupMediaGroups","variants","onGroupChanged","_settings$segmentLoad","mainSegmentLoader","previousActiveLoader","_settings$segmentLoad2","onAudioTrackChanged","createMediaTypes","loaderStats","sumLoaderStat","stat","audioSegmentLoader_","mainSegmentLoader_","video_es_MasterPlaylistController","MasterPlaylistController","externHls","useCueTags","enableLowInitialPlaylist","seekTo_","useCueTags_","cueTagsTrack_","requestOptions_","mediaTypes_","handleSourceOpen_","segmentLoaderSettings","setupMasterPlaylistLoaderListeners_","subtitleSegmentLoader_","setupSegmentLoaderListeners_","requestTimeout","triggerPresenceUsage_","setupSourceBuffers_","setupFirstPlay","updatedPlaylist","excludeUnsupportedVariants_","selectedMedia","selectInitialPlaylist","selectPlaylist","initialMedia_","updateAdCues_","updateDuration","addSeekableRange","addSeekableRange_","onDurationchange","stuckAtPlaylistEnd_","defaultDemuxed","audioGroupKeys","nextPlaylist","currentPlaylist","forwardBuffer","bufferLowWaterLine","onSyncInfoUpdate_","onEndOfStream","ended","isEndOfStream","getExpiredTime","absolutePlaylistEnd","TIME_FUDGE_FACTOR","mainSeekable","audioSeekable","oldDuration","newDuration","setDuration","mimeTypes","configureLoaderMimeTypes_","excludeIncompatibleVariants_","variant","codecString","variantCodecs","adOffset","adTotal","_segment$cueOutCont$s","_segment$cueOutCont$s2","video_es_updateAdCues","Representation","hlsHandler","loader","playlistUri","changePlaylistFn","mpc","masterPlaylistController_","qualityChangeFunction","smoothQualityChange","incompatible","currentlyEnabled","timerCancelEvents","video_es_PlaybackWatcher","PlaybackWatcher","consecutiveUpdates","lastRecordedTime","timer_","checkCurrentTimeTimeout_","canPlayHandler","monitorCurrentTime_","waitingHandler","techWaiting_","cancelTimerHandler","cancelTimer_","fixesBadSeeksHandler","fixesBadSeeks_","checkCurrentTime_","waiting_","afterSeekableWindow_","beforeSeekableWindow_","currentRange","livePoint","nextRange","videoUnderflow_","difference","skipTheGap_","gap","gapFromVideoUnderflow_","scheduledCurrentTime","gaps","findGaps","defaultOptions","errorInterval","getSource","IWillNotUseThisInPlugins","reloadSourceOnError","initPlugin","lastCalled","localOptions","loadedMetadataHandler","errorHandler","cleanupEvents","vhs","source_","Hls$1","STANDARD_PLAYLIST_SELECTOR","playerBandwidth","playerWidth","playerHeight","limitRenditionByPlayerDimensions","sortedPlaylistReps","enabledPlaylistReps","rep","bandwidthPlaylistReps","highestRemainingBandwidthRep","bandwidthBestRep","_chosenRep","haveResolution","resolutionBestRepList","resolutionBestRep","resolutionPlusOneList","resolutionPlusOneSmallest","resolutionPlusOneRep","chosenRep","video_es_simpleSelector","systemBandwidth","INITIAL_PLAYLIST_SELECTOR","comparePlaylistBandwidth","comparePlaylistResolution","leftWidth","rightWidth","simpleTypeFromSourceType","handleHlsMediaChange","qualityLevels","selectedIndex_","setupEmeOptions","eme","sourceOptions","keySystemOptions","videoPlaylist","audioPlaylist","keySystemContentTypes","keySystem","audioContentType","videoContentType","contentProtection","pssh","emeKeySystems","keySystems","initializeMediaKeys","getVhsLocalStorage","storedObject","supportsNativeHls","canItPlay","supportsNativeDash","supportsTypeNatively","Component$1","video_es_HlsHandler","HlsHandler","dash","setOptions_","overrideNative","webkitFullscreenElement","mozFullScreenElement","msFullscreenElement","smoothQualityChange_","pauseLoading","useBandwidthFromLocalStorage","option","playbackWatcher_","invBandwidth","invThroughput","mediaRequests_","mediaRequestsAborted_","mediaRequestsTimedout_","mediaRequestsErrored_","mediaTransferDuration_","mediaBytesTransferred_","mediaSecondsLoaded_","currentTech","playerDimensions","objectToStore","updateVhsLocalStorage","representations","setupQualityLevels_","qualityLevels_","addQualityLevel","receiver","getter","get$1","HlsSourceHandler","supportedType","__webpack_exports__","global","toUnsigned","g","CoalesceStream","AdtsStream","AacStream","isLikelyAacData","collectDtsInfo","trimAdtsFramesByEarliestDts","calculateTrackBaseMediaDecodeTime","prefixWithSilence","generateSampleTable","concatenateFrameData","clearDtsInfo","groupNalsIntoFrames","groupFramesIntoGops","extendFirstKeyFrame","concatenateNalData","parseId3TagSize","parseAdtsSize","parseSampleRate","parseAacTimestamp","cea708Parser","parseSei","USER_DATA_REGISTERED_ITU_T_T35","parseUserData","parseCaptionPackets","useSourceMap","cssMapping","btoa","sourceMapping","sourceMap","encodeURIComponent","sourceURLs","sourceRoot","cssWithMappingToString","modules","mediaQuery","alreadyImportedModules","memo","stylesInDom","isOldIE","atob","getElement","styleTarget","contentDocument","singleton","singletonCounter","stylesInsertedAtTop","fixUrls","addStylesToDom","styles","domStyle","refs","parts","addStyle","listToStyles","newStyles","base","css","insertStyleElement","lastStyleElementInsertedAtTop","insertAt","removeStyleElement","createStyleElement","nonce","nc","getNonce","addAttrs","styleIndex","applyToSingletonTag","link","rel","createLinkElement","autoFixUrls","convertToAbsoluteUrls","oldSrc","newObj","DEBUG","newList","mayRemove","textStore","replaceText","replacement","cssNode","reviver","VTTRegion","cueShim","regionShim","nativeVTTCue","nativeVTTRegion","shim","restore","_objCreate","F","ParsingError","errorData","parseTimeStamp","input","computeSeconds","f","Settings","parseOptions","keyValueDelim","groupDelim","kv","parseCue","regionList","oInput","consumeTimeStamp","ts","Errors","BadTimeStamp","skipWhitespace","substr","region","alt","vals","vals0","integer","lineAlign","snapToLines","positionAlign","consumeCueSettings","BadSignature","dflt","defaultKey","ESCAPE","&","<",">","‎","‏"," ","TAG_NAME","u","ruby","rt","lang","TAG_ANNOTATION","NEEDS_PARENT","parseContent","nextToken","unescape1","shouldAdd","current","localName","annotation","rootDiv","tagStack","createProcessingInstruction","strongRTLRanges","isStrongRTLChar","determineBidi","nodeStack","pushNodes","nextTextNode","StyleBox","CueStyleBox","styleOptions","display","writingMode","unicodeBidi","applyStyles","textAlign","font","whiteSpace","textPos","formatStyle","move","BoxPosition","lh","offsetTop","rects","getClientRects","lineHeight","moveBoxToLinePosition","styleBox","containerBox","boxPositions","boxPosition","linePos","textTrackList","mediaElement","computeLinePos","axis","maxPosition","initialAxis","calculatedPercentage","bestPosition","specifiedPosition","overlapsOppositeAxis","within","overlapsAny","intersectPercentage","findBestPosition","toCSSCompatValues","unit","toMove","overlaps","getSimpleBoxPosition","decode","convertCueToDOMTree","cuetext","overlay","paddedOverlay","margin","hasBeenReset","shouldCompute","reportOrThrowError","collectNextLine","pos","parseHeader","xy","anchor","lines","regionAnchorX","regionAnchorY","viewportAnchorX","viewportAnchorY","scroll","onregion","parseRegion","alreadyCollectedLine","hasSubstring","autoKeyword","directionSetting","","lr","rl","alignSetting","findAlignSetting","_id","_pauseOnExit","_startTime","_endTime","_text","_region","_vertical","_snapToLines","_line","_lineAlign","_position","_positionAlign","_size","_align","pauseOnExit","setting","findDirectionSetting","SyntaxError","getCueAsHTML","scrollSetting","up","isValidPercentValue","_lines","_regionAnchorX","_regionAnchorY","_viewportAnchorX","_viewportAnchorY","_scroll","findScrollSetting","clean","sa","isFunction","parseHeaders","xtend","initParams","params","createXHR","_createXHR","called","getBody","responseXML","firefoxBugTakenEffect","getXml","isJson","errorFunc","evt","timeoutTimer","failureResponse","loadFunc","useXDR","rawRequest","getAllResponseHeaders","XDomainRequest","XMLHttpRequest","onprogress","onabort","ontimeout","username","password","setRequestHeader","isEmpty","beforeSend","send","forEachArray","alert","confirm","prompt","isCallable","toStr","thisArg","len","forEachString","forEachObject","fnToStr","constructorRegex","isES6ClassFn","fnStr","hasToStringTag","toStringTag","tryFunctionObject","strClass","URL_REGEX","FIRST_SEGMENT_REGEX","SLASH_DOT_REGEX","SLASH_DOT_DOT_REGEX","URLToolkit","alwaysNormalize","basePartsForNormalise","parseURL","normalizePath","buildURLFromParts","relativeParts","scheme","baseParts","netLoc","builtParts","query","baseURLPath","newPath","lastIndexOf","doccy","topLevel","minDoc","parseUTCTiming","global_window__WEBPACK_IMPORTED_MODULE_0__","global_window__WEBPACK_IMPORTED_MODULE_0___default","merge","objects","flatten","lists","mergeDiscontiguousPlaylists","_acc$name$segments","formatAudioPlaylist","_attributes","periodIndex","formatVideoPlaylist","_ref3","_attributes3","toM3u8","dashPlaylists","_mediaGroups","_dashPlaylists$0$attr","sourceDuration","_dashPlaylists$0$attr2","videoPlaylists","_ref4","contentType","audioPlaylists","_ref5","vttPlaylists","_ref6","subs","_attributes2","baseUrl","organizeVttPlaylists","urlToolkit","resolveUrl","relativeUrl","urlTypeToSegment","_ref$baseUrl","_ref$source","_ref$range","startRange","endRange","getLiveRValue","NOW","availabilityStartTime","_attributes$timescale","_attributes$start","_attributes$minimumUp","periodDuration","parseByTimeline","segmentTimeline","_attributes$type","_attributes$minimumUp2","_attributes$media","_attributes$timescale2","_attributes$startNumb","startNumber","sIndex","S","repeat","segmentTime","nextS","segmentRange","static","dynamic","_attributes$timeShift","timeShiftBufferDepth","periodStartWC","segmentCount","availableStart","availableEnd","parseByDuration","_attributes$timescale4","_segmentRange$type","_attributes$timescale3","toSegments","identifierPattern","constructTemplateUrl","identifier","identifierReplacement","segmentsFromTemplate","templateValues","RepresentationID","Bandwidth","_attributes$initializ","initialization","sourceURL","mapSegment","parseTemplateInfo","Time","segmentsFromList","_attributes$segmentUr","segmentUrls","segmentTimeInfo","segmentUrlMap","segmentUrlObject","segmentUrl","mediaRange","SegmentURLToSegmentObject","segmentsFromBase","_attributes$indexRang","indexRange","generateSegments","segmentAttributes","segmentsFn","template","_segmentAttributes","_segmentAttributes$ti","findChildren","getContent","parseDuration","_match$slice","year","month","day","hour","minute","second","parsers","mediaPresentationDuration","parsedValue","parseFn","keySystemsMap","urn:uuid:1077efec-c0b2-4d02-ace3-3c1e52e2fb4b","urn:uuid:edef8ba9-79d6-4ace-a3c8-27dcd51d21ed","urn:uuid:9a04f079-9840-4286-ab92-e65be0885f95","urn:uuid:f239e769-efa3-4850-9c16-a903c6932efb","buildBaseUrls","referenceUrls","baseUrlElements","baseUrlElement","getSegmentInformation","adaptationSet","segmentTemplate","segmentList","segmentBase","segmentTimelineParentNode","segmentInitializationParentNode","segmentInitialization","generateKeySystemInformation","contentProtectionNodes","schemeIdUri","psshNode","psshBuffer","b64Text","decodedString","decodeB64ToUint8Array","toRepresentations","periodAttributes","periodBaseUrls","periodSegmentInfo","adaptationSetAttributes","adaptationSetBaseUrls","roleAttributes","adaptationSetSegmentInfo","representation","repBaseUrlElements","repBaseUrls","representationSegmentInfo","inheritBaseUrls","inheritAttributes","mpd","_options","_options$manifestUri","_options$NOW","_options$clientOffset","periods","mpdAttributes","mpdBaseUrls","period","periodAtt","parsedPeriodId","adaptationSets","toAdaptationSets","stringToMpdXml","manifestString","xml","DOMParser","parseFromString","UTCTimingNode","parseUTCTimingScheme","ONE_SECOND_IN_TS","StreamTypes","m2tsStreamTypes","ExpGolomb","aacUtils","textifyMp4","parseAudioPes_","pesType","pusi","endLoop","parsePesType","parsePayloadUnitStartIndicator","parsePesTime","parseVideoPes_","firstKeyFrame","videoPacketContainsKeyFrame","inspectTs_","parsePsi_","baseTimestamp","audioCount","audioTimescale","inspectAac_","audioBaseTimestamp","ptsTime","videoBaseTimestamp","adjustTimestamp_","parsePid","parseAdaptionField","parseNalUnitType","payloadOffset","frameBuffer","frameI","frameSyncPoint","foundKeyFrame","currentDir","pathname","fullMatch","origUrl","newUrl","unquotedOrigUrl","$1"],"mappings":"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","file":"vendors~videojs.js","sourcesContent":["\nvar content = require(\"!!../../css-loader/dist/cjs.js!./video-js.css\");\n\nif(typeof content === 'string') content = [[module.id, content, '']];\n\nvar transform;\nvar insertInto;\n\n\n\nvar options = {\"hmr\":true}\n\noptions.transform = transform\noptions.insertInto = undefined;\n\nvar update = require(\"!../../style-loader/lib/addStyles.js\")(content, options);\n\nif(content.locals) module.exports = content.locals;\n\nif(module.hot) {\n\tmodule.hot.accept(\"!!../../css-loader/dist/cjs.js!./video-js.css\", function() {\n\t\tvar newContent = require(\"!!../../css-loader/dist/cjs.js!./video-js.css\");\n\n\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\n\t\tvar locals = (function(a, b) {\n\t\t\tvar key, idx = 0;\n\n\t\t\tfor(key in a) {\n\t\t\t\tif(!b || a[key] !== b[key]) return false;\n\t\t\t\tidx++;\n\t\t\t}\n\n\t\t\tfor(key in b) idx--;\n\n\t\t\treturn idx === 0;\n\t\t}(content.locals, newContent.locals));\n\n\t\tif(!locals) throw new Error('Aborting CSS HMR due to changed css-modules locals.');\n\n\t\tupdate(newContent);\n\t});\n\n\tmodule.hot.dispose(function() { update(); });\n}","var classCallCheck = function (instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n};\n\n\n\n\n\n\n\n\n\nvar _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n};\n\n\n\nvar inherits = function (subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass);\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;\n};\n\n\n\n\n\n\n\n\n\n\n\nvar possibleConstructorReturn = function (self, call) {\n if (!self) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self;\n};\n\n/**\n * @file stream.js\n */\n/**\n * A lightweight readable stream implemention that handles event dispatching.\n *\n * @class Stream\n */\nvar Stream = function () {\n function Stream() {\n classCallCheck(this, Stream);\n\n this.listeners = {};\n }\n\n /**\n * Add a listener for a specified event type.\n *\n * @param {String} type the event name\n * @param {Function} listener the callback to be invoked when an event of\n * the specified type occurs\n */\n\n\n Stream.prototype.on = function on(type, listener) {\n if (!this.listeners[type]) {\n this.listeners[type] = [];\n }\n this.listeners[type].push(listener);\n };\n\n /**\n * Remove a listener for a specified event type.\n *\n * @param {String} type the event name\n * @param {Function} listener a function previously registered for this\n * type of event through `on`\n * @return {Boolean} if we could turn it off or not\n */\n\n\n Stream.prototype.off = function off(type, listener) {\n if (!this.listeners[type]) {\n return false;\n }\n\n var index = this.listeners[type].indexOf(listener);\n\n this.listeners[type].splice(index, 1);\n return index > -1;\n };\n\n /**\n * Trigger an event of the specified type on this stream. Any additional\n * arguments to this function are passed as parameters to event listeners.\n *\n * @param {String} type the event name\n */\n\n\n Stream.prototype.trigger = function trigger(type) {\n var callbacks = this.listeners[type];\n var i = void 0;\n var length = void 0;\n var args = void 0;\n\n if (!callbacks) {\n return;\n }\n // Slicing the arguments on every invocation of this method\n // can add a significant amount of overhead. Avoid the\n // intermediate object creation for the common case of a\n // single callback argument\n if (arguments.length === 2) {\n length = callbacks.length;\n for (i = 0; i < length; ++i) {\n callbacks[i].call(this, arguments[1]);\n }\n } else {\n args = Array.prototype.slice.call(arguments, 1);\n length = callbacks.length;\n for (i = 0; i < length; ++i) {\n callbacks[i].apply(this, args);\n }\n }\n };\n\n /**\n * Destroys the stream and cleans up.\n */\n\n\n Stream.prototype.dispose = function dispose() {\n this.listeners = {};\n };\n /**\n * Forwards all `data` events on this stream to the destination stream. The\n * destination stream should provide a method `push` to receive the data\n * events as they arrive.\n *\n * @param {Stream} destination the stream that will receive all `data` events\n * @see http://nodejs.org/api/stream.html#stream_readable_pipe_destination_options\n */\n\n\n Stream.prototype.pipe = function pipe(destination) {\n this.on('data', function (data) {\n destination.push(data);\n });\n };\n\n return Stream;\n}();\n\n/**\n * @file m3u8/line-stream.js\n */\n/**\n * A stream that buffers string input and generates a `data` event for each\n * line.\n *\n * @class LineStream\n * @extends Stream\n */\n\nvar LineStream = function (_Stream) {\n inherits(LineStream, _Stream);\n\n function LineStream() {\n classCallCheck(this, LineStream);\n\n var _this = possibleConstructorReturn(this, _Stream.call(this));\n\n _this.buffer = '';\n return _this;\n }\n\n /**\n * Add new data to be parsed.\n *\n * @param {String} data the text to process\n */\n\n\n LineStream.prototype.push = function push(data) {\n var nextNewline = void 0;\n\n this.buffer += data;\n nextNewline = this.buffer.indexOf('\\n');\n\n for (; nextNewline > -1; nextNewline = this.buffer.indexOf('\\n')) {\n this.trigger('data', this.buffer.substring(0, nextNewline));\n this.buffer = this.buffer.substring(nextNewline + 1);\n }\n };\n\n return LineStream;\n}(Stream);\n\n/**\n * @file m3u8/parse-stream.js\n */\n/**\n * \"forgiving\" attribute list psuedo-grammar:\n * attributes -> keyvalue (',' keyvalue)*\n * keyvalue -> key '=' value\n * key -> [^=]*\n * value -> '\"' [^\"]* '\"' | [^,]*\n */\nvar attributeSeparator = function attributeSeparator() {\n var key = '[^=]*';\n var value = '\"[^\"]*\"|[^,]*';\n var keyvalue = '(?:' + key + ')=(?:' + value + ')';\n\n return new RegExp('(?:^|,)(' + keyvalue + ')');\n};\n\n/**\n * Parse attributes from a line given the seperator\n *\n * @param {String} attributes the attibute line to parse\n */\nvar parseAttributes = function parseAttributes(attributes) {\n // split the string using attributes as the separator\n var attrs = attributes.split(attributeSeparator());\n var result = {};\n var i = attrs.length;\n var attr = void 0;\n\n while (i--) {\n // filter out unmatched portions of the string\n if (attrs[i] === '') {\n continue;\n }\n\n // split the key and value\n attr = /([^=]*)=(.*)/.exec(attrs[i]).slice(1);\n // trim whitespace and remove optional quotes around the value\n attr[0] = attr[0].replace(/^\\s+|\\s+$/g, '');\n attr[1] = attr[1].replace(/^\\s+|\\s+$/g, '');\n attr[1] = attr[1].replace(/^['\"](.*)['\"]$/g, '$1');\n result[attr[0]] = attr[1];\n }\n return result;\n};\n\n/**\n * A line-level M3U8 parser event stream. It expects to receive input one\n * line at a time and performs a context-free parse of its contents. A stream\n * interpretation of a manifest can be useful if the manifest is expected to\n * be too large to fit comfortably into memory or the entirety of the input\n * is not immediately available. Otherwise, it's probably much easier to work\n * with a regular `Parser` object.\n *\n * Produces `data` events with an object that captures the parser's\n * interpretation of the input. That object has a property `tag` that is one\n * of `uri`, `comment`, or `tag`. URIs only have a single additional\n * property, `line`, which captures the entirety of the input without\n * interpretation. Comments similarly have a single additional property\n * `text` which is the input without the leading `#`.\n *\n * Tags always have a property `tagType` which is the lower-cased version of\n * the M3U8 directive without the `#EXT` or `#EXT-X-` prefix. For instance,\n * `#EXT-X-MEDIA-SEQUENCE` becomes `media-sequence` when parsed. Unrecognized\n * tags are given the tag type `unknown` and a single additional property\n * `data` with the remainder of the input.\n *\n * @class ParseStream\n * @extends Stream\n */\n\nvar ParseStream = function (_Stream) {\n inherits(ParseStream, _Stream);\n\n function ParseStream() {\n classCallCheck(this, ParseStream);\n\n var _this = possibleConstructorReturn(this, _Stream.call(this));\n\n _this.customParsers = [];\n return _this;\n }\n\n /**\n * Parses an additional line of input.\n *\n * @param {String} line a single line of an M3U8 file to parse\n */\n\n\n ParseStream.prototype.push = function push(line) {\n var match = void 0;\n var event = void 0;\n\n // strip whitespace\n line = line.replace(/^[\\u0000\\s]+|[\\u0000\\s]+$/g, '');\n if (line.length === 0) {\n // ignore empty lines\n return;\n }\n\n // URIs\n if (line[0] !== '#') {\n this.trigger('data', {\n type: 'uri',\n uri: line\n });\n return;\n }\n\n for (var i = 0; i < this.customParsers.length; i++) {\n if (this.customParsers[i].call(this, line)) {\n return;\n }\n }\n\n // Comments\n if (line.indexOf('#EXT') !== 0) {\n this.trigger('data', {\n type: 'comment',\n text: line.slice(1)\n });\n return;\n }\n\n // strip off any carriage returns here so the regex matching\n // doesn't have to account for them.\n line = line.replace('\\r', '');\n\n // Tags\n match = /^#EXTM3U/.exec(line);\n if (match) {\n this.trigger('data', {\n type: 'tag',\n tagType: 'm3u'\n });\n return;\n }\n match = /^#EXTINF:?([0-9\\.]*)?,?(.*)?$/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'inf'\n };\n if (match[1]) {\n event.duration = parseFloat(match[1]);\n }\n if (match[2]) {\n event.title = match[2];\n }\n this.trigger('data', event);\n return;\n }\n match = /^#EXT-X-TARGETDURATION:?([0-9.]*)?/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'targetduration'\n };\n if (match[1]) {\n event.duration = parseInt(match[1], 10);\n }\n this.trigger('data', event);\n return;\n }\n match = /^#ZEN-TOTAL-DURATION:?([0-9.]*)?/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'totalduration'\n };\n if (match[1]) {\n event.duration = parseInt(match[1], 10);\n }\n this.trigger('data', event);\n return;\n }\n match = /^#EXT-X-VERSION:?([0-9.]*)?/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'version'\n };\n if (match[1]) {\n event.version = parseInt(match[1], 10);\n }\n this.trigger('data', event);\n return;\n }\n match = /^#EXT-X-MEDIA-SEQUENCE:?(\\-?[0-9.]*)?/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'media-sequence'\n };\n if (match[1]) {\n event.number = parseInt(match[1], 10);\n }\n this.trigger('data', event);\n return;\n }\n match = /^#EXT-X-DISCONTINUITY-SEQUENCE:?(\\-?[0-9.]*)?/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'discontinuity-sequence'\n };\n if (match[1]) {\n event.number = parseInt(match[1], 10);\n }\n this.trigger('data', event);\n return;\n }\n match = /^#EXT-X-PLAYLIST-TYPE:?(.*)?$/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'playlist-type'\n };\n if (match[1]) {\n event.playlistType = match[1];\n }\n this.trigger('data', event);\n return;\n }\n match = /^#EXT-X-BYTERANGE:?([0-9.]*)?@?([0-9.]*)?/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'byterange'\n };\n if (match[1]) {\n event.length = parseInt(match[1], 10);\n }\n if (match[2]) {\n event.offset = parseInt(match[2], 10);\n }\n this.trigger('data', event);\n return;\n }\n match = /^#EXT-X-ALLOW-CACHE:?(YES|NO)?/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'allow-cache'\n };\n if (match[1]) {\n event.allowed = !/NO/.test(match[1]);\n }\n this.trigger('data', event);\n return;\n }\n match = /^#EXT-X-MAP:?(.*)$/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'map'\n };\n\n if (match[1]) {\n var attributes = parseAttributes(match[1]);\n\n if (attributes.URI) {\n event.uri = attributes.URI;\n }\n if (attributes.BYTERANGE) {\n var _attributes$BYTERANGE = attributes.BYTERANGE.split('@'),\n length = _attributes$BYTERANGE[0],\n offset = _attributes$BYTERANGE[1];\n\n event.byterange = {};\n if (length) {\n event.byterange.length = parseInt(length, 10);\n }\n if (offset) {\n event.byterange.offset = parseInt(offset, 10);\n }\n }\n }\n\n this.trigger('data', event);\n return;\n }\n match = /^#EXT-X-STREAM-INF:?(.*)$/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'stream-inf'\n };\n if (match[1]) {\n event.attributes = parseAttributes(match[1]);\n\n if (event.attributes.RESOLUTION) {\n var split = event.attributes.RESOLUTION.split('x');\n var resolution = {};\n\n if (split[0]) {\n resolution.width = parseInt(split[0], 10);\n }\n if (split[1]) {\n resolution.height = parseInt(split[1], 10);\n }\n event.attributes.RESOLUTION = resolution;\n }\n if (event.attributes.BANDWIDTH) {\n event.attributes.BANDWIDTH = parseInt(event.attributes.BANDWIDTH, 10);\n }\n if (event.attributes['PROGRAM-ID']) {\n event.attributes['PROGRAM-ID'] = parseInt(event.attributes['PROGRAM-ID'], 10);\n }\n }\n this.trigger('data', event);\n return;\n }\n match = /^#EXT-X-MEDIA:?(.*)$/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'media'\n };\n if (match[1]) {\n event.attributes = parseAttributes(match[1]);\n }\n this.trigger('data', event);\n return;\n }\n match = /^#EXT-X-ENDLIST/.exec(line);\n if (match) {\n this.trigger('data', {\n type: 'tag',\n tagType: 'endlist'\n });\n return;\n }\n match = /^#EXT-X-DISCONTINUITY/.exec(line);\n if (match) {\n this.trigger('data', {\n type: 'tag',\n tagType: 'discontinuity'\n });\n return;\n }\n match = /^#EXT-X-PROGRAM-DATE-TIME:?(.*)$/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'program-date-time'\n };\n if (match[1]) {\n event.dateTimeString = match[1];\n event.dateTimeObject = new Date(match[1]);\n }\n this.trigger('data', event);\n return;\n }\n match = /^#EXT-X-KEY:?(.*)$/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'key'\n };\n if (match[1]) {\n event.attributes = parseAttributes(match[1]);\n // parse the IV string into a Uint32Array\n if (event.attributes.IV) {\n if (event.attributes.IV.substring(0, 2).toLowerCase() === '0x') {\n event.attributes.IV = event.attributes.IV.substring(2);\n }\n\n event.attributes.IV = event.attributes.IV.match(/.{8}/g);\n event.attributes.IV[0] = parseInt(event.attributes.IV[0], 16);\n event.attributes.IV[1] = parseInt(event.attributes.IV[1], 16);\n event.attributes.IV[2] = parseInt(event.attributes.IV[2], 16);\n event.attributes.IV[3] = parseInt(event.attributes.IV[3], 16);\n event.attributes.IV = new Uint32Array(event.attributes.IV);\n }\n }\n this.trigger('data', event);\n return;\n }\n match = /^#EXT-X-START:?(.*)$/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'start'\n };\n if (match[1]) {\n event.attributes = parseAttributes(match[1]);\n\n event.attributes['TIME-OFFSET'] = parseFloat(event.attributes['TIME-OFFSET']);\n event.attributes.PRECISE = /YES/.test(event.attributes.PRECISE);\n }\n this.trigger('data', event);\n return;\n }\n match = /^#EXT-X-CUE-OUT-CONT:?(.*)?$/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'cue-out-cont'\n };\n if (match[1]) {\n event.data = match[1];\n } else {\n event.data = '';\n }\n this.trigger('data', event);\n return;\n }\n match = /^#EXT-X-CUE-OUT:?(.*)?$/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'cue-out'\n };\n if (match[1]) {\n event.data = match[1];\n } else {\n event.data = '';\n }\n this.trigger('data', event);\n return;\n }\n match = /^#EXT-X-CUE-IN:?(.*)?$/.exec(line);\n if (match) {\n event = {\n type: 'tag',\n tagType: 'cue-in'\n };\n if (match[1]) {\n event.data = match[1];\n } else {\n event.data = '';\n }\n this.trigger('data', event);\n return;\n }\n\n // unknown tag type\n this.trigger('data', {\n type: 'tag',\n data: line.slice(4)\n });\n };\n\n /**\n * Add a parser for custom headers\n *\n * @param {Object} options a map of options for the added parser\n * @param {RegExp} options.expression a regular expression to match the custom header\n * @param {string} options.customType the custom type to register to the output\n * @param {Function} [options.dataParser] function to parse the line into an object\n * @param {boolean} [options.segment] should tag data be attached to the segment object\n */\n\n\n ParseStream.prototype.addParser = function addParser(_ref) {\n var _this2 = this;\n\n var expression = _ref.expression,\n customType = _ref.customType,\n dataParser = _ref.dataParser,\n segment = _ref.segment;\n\n if (typeof dataParser !== 'function') {\n dataParser = function dataParser(line) {\n return line;\n };\n }\n this.customParsers.push(function (line) {\n var match = expression.exec(line);\n\n if (match) {\n _this2.trigger('data', {\n type: 'custom',\n data: dataParser(line),\n customType: customType,\n segment: segment\n });\n return true;\n }\n });\n };\n\n return ParseStream;\n}(Stream);\n\n/**\n * @file m3u8/parser.js\n */\n/**\n * A parser for M3U8 files. The current interpretation of the input is\n * exposed as a property `manifest` on parser objects. It's just two lines to\n * create and parse a manifest once you have the contents available as a string:\n *\n * ```js\n * var parser = new m3u8.Parser();\n * parser.push(xhr.responseText);\n * ```\n *\n * New input can later be applied to update the manifest object by calling\n * `push` again.\n *\n * The parser attempts to create a usable manifest object even if the\n * underlying input is somewhat nonsensical. It emits `info` and `warning`\n * events during the parse if it encounters input that seems invalid or\n * requires some property of the manifest object to be defaulted.\n *\n * @class Parser\n * @extends Stream\n */\n\nvar Parser = function (_Stream) {\n inherits(Parser, _Stream);\n\n function Parser() {\n classCallCheck(this, Parser);\n\n var _this = possibleConstructorReturn(this, _Stream.call(this));\n\n _this.lineStream = new LineStream();\n _this.parseStream = new ParseStream();\n _this.lineStream.pipe(_this.parseStream);\n\n /* eslint-disable consistent-this */\n var self = _this;\n /* eslint-enable consistent-this */\n var uris = [];\n var currentUri = {};\n // if specified, the active EXT-X-MAP definition\n var currentMap = void 0;\n // if specified, the active decryption key\n var _key = void 0;\n var noop = function noop() {};\n var defaultMediaGroups = {\n 'AUDIO': {},\n 'VIDEO': {},\n 'CLOSED-CAPTIONS': {},\n 'SUBTITLES': {}\n };\n // group segments into numbered timelines delineated by discontinuities\n var currentTimeline = 0;\n\n // the manifest is empty until the parse stream begins delivering data\n _this.manifest = {\n allowCache: true,\n discontinuityStarts: [],\n segments: []\n };\n\n // update the manifest with the m3u8 entry from the parse stream\n _this.parseStream.on('data', function (entry) {\n var mediaGroup = void 0;\n var rendition = void 0;\n\n ({\n tag: function tag() {\n // switch based on the tag type\n (({\n 'allow-cache': function allowCache() {\n this.manifest.allowCache = entry.allowed;\n if (!('allowed' in entry)) {\n this.trigger('info', {\n message: 'defaulting allowCache to YES'\n });\n this.manifest.allowCache = true;\n }\n },\n byterange: function byterange() {\n var byterange = {};\n\n if ('length' in entry) {\n currentUri.byterange = byterange;\n byterange.length = entry.length;\n\n if (!('offset' in entry)) {\n this.trigger('info', {\n message: 'defaulting offset to zero'\n });\n entry.offset = 0;\n }\n }\n if ('offset' in entry) {\n currentUri.byterange = byterange;\n byterange.offset = entry.offset;\n }\n },\n endlist: function endlist() {\n this.manifest.endList = true;\n },\n inf: function inf() {\n if (!('mediaSequence' in this.manifest)) {\n this.manifest.mediaSequence = 0;\n this.trigger('info', {\n message: 'defaulting media sequence to zero'\n });\n }\n if (!('discontinuitySequence' in this.manifest)) {\n this.manifest.discontinuitySequence = 0;\n this.trigger('info', {\n message: 'defaulting discontinuity sequence to zero'\n });\n }\n if (entry.duration > 0) {\n currentUri.duration = entry.duration;\n }\n\n if (entry.duration === 0) {\n currentUri.duration = 0.01;\n this.trigger('info', {\n message: 'updating zero segment duration to a small value'\n });\n }\n\n this.manifest.segments = uris;\n },\n key: function key() {\n if (!entry.attributes) {\n this.trigger('warn', {\n message: 'ignoring key declaration without attribute list'\n });\n return;\n }\n // clear the active encryption key\n if (entry.attributes.METHOD === 'NONE') {\n _key = null;\n return;\n }\n if (!entry.attributes.URI) {\n this.trigger('warn', {\n message: 'ignoring key declaration without URI'\n });\n return;\n }\n if (!entry.attributes.METHOD) {\n this.trigger('warn', {\n message: 'defaulting key method to AES-128'\n });\n }\n\n // setup an encryption key for upcoming segments\n _key = {\n method: entry.attributes.METHOD || 'AES-128',\n uri: entry.attributes.URI\n };\n\n if (typeof entry.attributes.IV !== 'undefined') {\n _key.iv = entry.attributes.IV;\n }\n },\n 'media-sequence': function mediaSequence() {\n if (!isFinite(entry.number)) {\n this.trigger('warn', {\n message: 'ignoring invalid media sequence: ' + entry.number\n });\n return;\n }\n this.manifest.mediaSequence = entry.number;\n },\n 'discontinuity-sequence': function discontinuitySequence() {\n if (!isFinite(entry.number)) {\n this.trigger('warn', {\n message: 'ignoring invalid discontinuity sequence: ' + entry.number\n });\n return;\n }\n this.manifest.discontinuitySequence = entry.number;\n currentTimeline = entry.number;\n },\n 'playlist-type': function playlistType() {\n if (!/VOD|EVENT/.test(entry.playlistType)) {\n this.trigger('warn', {\n message: 'ignoring unknown playlist type: ' + entry.playlist\n });\n return;\n }\n this.manifest.playlistType = entry.playlistType;\n },\n map: function map() {\n currentMap = {};\n if (entry.uri) {\n currentMap.uri = entry.uri;\n }\n if (entry.byterange) {\n currentMap.byterange = entry.byterange;\n }\n },\n 'stream-inf': function streamInf() {\n this.manifest.playlists = uris;\n this.manifest.mediaGroups = this.manifest.mediaGroups || defaultMediaGroups;\n\n if (!entry.attributes) {\n this.trigger('warn', {\n message: 'ignoring empty stream-inf attributes'\n });\n return;\n }\n\n if (!currentUri.attributes) {\n currentUri.attributes = {};\n }\n _extends(currentUri.attributes, entry.attributes);\n },\n media: function media() {\n this.manifest.mediaGroups = this.manifest.mediaGroups || defaultMediaGroups;\n\n if (!(entry.attributes && entry.attributes.TYPE && entry.attributes['GROUP-ID'] && entry.attributes.NAME)) {\n this.trigger('warn', {\n message: 'ignoring incomplete or missing media group'\n });\n return;\n }\n\n // find the media group, creating defaults as necessary\n var mediaGroupType = this.manifest.mediaGroups[entry.attributes.TYPE];\n\n mediaGroupType[entry.attributes['GROUP-ID']] = mediaGroupType[entry.attributes['GROUP-ID']] || {};\n mediaGroup = mediaGroupType[entry.attributes['GROUP-ID']];\n\n // collect the rendition metadata\n rendition = {\n 'default': /yes/i.test(entry.attributes.DEFAULT)\n };\n if (rendition['default']) {\n rendition.autoselect = true;\n } else {\n rendition.autoselect = /yes/i.test(entry.attributes.AUTOSELECT);\n }\n if (entry.attributes.LANGUAGE) {\n rendition.language = entry.attributes.LANGUAGE;\n }\n if (entry.attributes.URI) {\n rendition.uri = entry.attributes.URI;\n }\n if (entry.attributes['INSTREAM-ID']) {\n rendition.instreamId = entry.attributes['INSTREAM-ID'];\n }\n if (entry.attributes.CHARACTERISTICS) {\n rendition.characteristics = entry.attributes.CHARACTERISTICS;\n }\n if (entry.attributes.FORCED) {\n rendition.forced = /yes/i.test(entry.attributes.FORCED);\n }\n\n // insert the new rendition\n mediaGroup[entry.attributes.NAME] = rendition;\n },\n discontinuity: function discontinuity() {\n currentTimeline += 1;\n currentUri.discontinuity = true;\n this.manifest.discontinuityStarts.push(uris.length);\n },\n 'program-date-time': function programDateTime() {\n if (typeof this.manifest.dateTimeString === 'undefined') {\n // PROGRAM-DATE-TIME is a media-segment tag, but for backwards\n // compatibility, we add the first occurence of the PROGRAM-DATE-TIME tag\n // to the manifest object\n // TODO: Consider removing this in future major version\n this.manifest.dateTimeString = entry.dateTimeString;\n this.manifest.dateTimeObject = entry.dateTimeObject;\n }\n\n currentUri.dateTimeString = entry.dateTimeString;\n currentUri.dateTimeObject = entry.dateTimeObject;\n },\n targetduration: function targetduration() {\n if (!isFinite(entry.duration) || entry.duration < 0) {\n this.trigger('warn', {\n message: 'ignoring invalid target duration: ' + entry.duration\n });\n return;\n }\n this.manifest.targetDuration = entry.duration;\n },\n totalduration: function totalduration() {\n if (!isFinite(entry.duration) || entry.duration < 0) {\n this.trigger('warn', {\n message: 'ignoring invalid total duration: ' + entry.duration\n });\n return;\n }\n this.manifest.totalDuration = entry.duration;\n },\n start: function start() {\n if (!entry.attributes || isNaN(entry.attributes['TIME-OFFSET'])) {\n this.trigger('warn', {\n message: 'ignoring start declaration without appropriate attribute list'\n });\n return;\n }\n this.manifest.start = {\n timeOffset: entry.attributes['TIME-OFFSET'],\n precise: entry.attributes.PRECISE\n };\n },\n 'cue-out': function cueOut() {\n currentUri.cueOut = entry.data;\n },\n 'cue-out-cont': function cueOutCont() {\n currentUri.cueOutCont = entry.data;\n },\n 'cue-in': function cueIn() {\n currentUri.cueIn = entry.data;\n }\n })[entry.tagType] || noop).call(self);\n },\n uri: function uri() {\n currentUri.uri = entry.uri;\n uris.push(currentUri);\n\n // if no explicit duration was declared, use the target duration\n if (this.manifest.targetDuration && !('duration' in currentUri)) {\n this.trigger('warn', {\n message: 'defaulting segment duration to the target duration'\n });\n currentUri.duration = this.manifest.targetDuration;\n }\n // annotate with encryption information, if necessary\n if (_key) {\n currentUri.key = _key;\n }\n currentUri.timeline = currentTimeline;\n // annotate with initialization segment information, if necessary\n if (currentMap) {\n currentUri.map = currentMap;\n }\n\n // prepare for the next URI\n currentUri = {};\n },\n comment: function comment() {\n // comments are not important for playback\n },\n custom: function custom() {\n // if this is segment-level data attach the output to the segment\n if (entry.segment) {\n currentUri.custom = currentUri.custom || {};\n currentUri.custom[entry.customType] = entry.data;\n // if this is manifest-level data attach to the top level manifest object\n } else {\n this.manifest.custom = this.manifest.custom || {};\n this.manifest.custom[entry.customType] = entry.data;\n }\n }\n })[entry.type].call(self);\n });\n return _this;\n }\n\n /**\n * Parse the input string and update the manifest object.\n *\n * @param {String} chunk a potentially incomplete portion of the manifest\n */\n\n\n Parser.prototype.push = function push(chunk) {\n this.lineStream.push(chunk);\n };\n\n /**\n * Flush any remaining input. This can be handy if the last line of an M3U8\n * manifest did not contain a trailing newline but the file has been\n * completely received.\n */\n\n\n Parser.prototype.end = function end() {\n // flush any buffered input\n this.lineStream.push('\\n');\n };\n /**\n * Add an additional parser for non-standard tags\n *\n * @param {Object} options a map of options for the added parser\n * @param {RegExp} options.expression a regular expression to match the custom header\n * @param {string} options.type the type to register to the output\n * @param {Function} [options.dataParser] function to parse the line into an object\n * @param {boolean} [options.segment] should tag data be attached to the segment object\n */\n\n\n Parser.prototype.addParser = function addParser(options) {\n this.parseStream.addParser(options);\n };\n\n return Parser;\n}(Stream);\n\n/**\n * @file m3u8/index.js\n *\n * Utilities for parsing M3U8 files. If the entire manifest is available,\n * `Parser` will create an object representation with enough detail for managing\n * playback. `ParseStream` and `LineStream` are lower-level parsing primitives\n * that do not assume the entirety of the manifest is ready and expose a\n * ReadableStream-like interface.\n */\n\nexport { LineStream, ParseStream, Parser };\n","/*\n * pkcs7.pad\n * https://github.com/brightcove/pkcs7\n *\n * Copyright (c) 2014 Brightcove\n * Licensed under the apache2 license.\n */\n\nvar PADDING = void 0;\n\n/**\n * Returns a new Uint8Array that is padded with PKCS#7 padding.\n * @param plaintext {Uint8Array} the input bytes before encryption\n * @return {Uint8Array} the padded bytes\n * @see http://tools.ietf.org/html/rfc5652\n */\nfunction pad(plaintext) {\n var padding = PADDING[plaintext.byteLength % 16 || 0];\n var result = new Uint8Array(plaintext.byteLength + padding.length);\n\n result.set(plaintext);\n result.set(padding, plaintext.byteLength);\n\n return result;\n}\n\n// pre-define the padding values\nPADDING = [[16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16], [15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15], [14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14], [13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13], [12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12], [11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11], [10, 10, 10, 10, 10, 10, 10, 10, 10, 10], [9, 9, 9, 9, 9, 9, 9, 9, 9], [8, 8, 8, 8, 8, 8, 8, 8], [7, 7, 7, 7, 7, 7, 7], [6, 6, 6, 6, 6, 6], [5, 5, 5, 5, 5], [4, 4, 4, 4], [3, 3, 3], [2, 2], [1]];\n\n/**\n * Returns the subarray of a Uint8Array without PKCS#7 padding.\n * @param padded {Uint8Array} unencrypted bytes that have been padded\n * @return {Uint8Array} the unpadded bytes\n * @see http://tools.ietf.org/html/rfc5652\n */\nfunction unpad(padded) {\n return padded.subarray(0, padded.byteLength - padded[padded.byteLength - 1]);\n}\n\nvar version = \"1.0.2\";\n\nexport { pad, unpad, version as VERSION };\n","import { unpad } from 'pkcs7';\n\nvar classCallCheck = function (instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n};\n\nvar createClass = function () {\n function defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n }\n\n return function (Constructor, protoProps, staticProps) {\n if (protoProps) defineProperties(Constructor.prototype, protoProps);\n if (staticProps) defineProperties(Constructor, staticProps);\n return Constructor;\n };\n}();\n\n\n\n\n\n\n\n\n\nvar inherits = function (subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass);\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;\n};\n\n\n\n\n\n\n\n\n\n\n\nvar possibleConstructorReturn = function (self, call) {\n if (!self) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self;\n};\n\n/**\n * @file aes.js\n *\n * This file contains an adaptation of the AES decryption algorithm\n * from the Standford Javascript Cryptography Library. That work is\n * covered by the following copyright and permissions notice:\n *\n * Copyright 2009-2010 Emily Stark, Mike Hamburg, Dan Boneh.\n * All rights reserved.\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are\n * met:\n *\n * 1. Redistributions of source code must retain the above copyright\n * notice, this list of conditions and the following disclaimer.\n *\n * 2. Redistributions in binary form must reproduce the above\n * copyright notice, this list of conditions and the following\n * disclaimer in the documentation and/or other materials provided\n * with the distribution.\n *\n * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR\n * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> OR CONTRIBUTORS BE\n * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR\n * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF\n * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR\n * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,\n * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE\n * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN\n * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n *\n * The views and conclusions contained in the software and documentation\n * are those of the authors and should not be interpreted as representing\n * official policies, either expressed or implied, of the authors.\n */\n\n/**\n * Expand the S-box tables.\n *\n * @private\n */\nvar precompute = function precompute() {\n var tables = [[[], [], [], [], []], [[], [], [], [], []]];\n var encTable = tables[0];\n var decTable = tables[1];\n var sbox = encTable[4];\n var sboxInv = decTable[4];\n var i = void 0;\n var x = void 0;\n var xInv = void 0;\n var d = [];\n var th = [];\n var x2 = void 0;\n var x4 = void 0;\n var x8 = void 0;\n var s = void 0;\n var tEnc = void 0;\n var tDec = void 0;\n\n // Compute double and third tables\n for (i = 0; i < 256; i++) {\n th[(d[i] = i << 1 ^ (i >> 7) * 283) ^ i] = i;\n }\n\n for (x = xInv = 0; !sbox[x]; x ^= x2 || 1, xInv = th[xInv] || 1) {\n // Compute sbox\n s = xInv ^ xInv << 1 ^ xInv << 2 ^ xInv << 3 ^ xInv << 4;\n s = s >> 8 ^ s & 255 ^ 99;\n sbox[x] = s;\n sboxInv[s] = x;\n\n // Compute MixColumns\n x8 = d[x4 = d[x2 = d[x]]];\n tDec = x8 * 0x1010101 ^ x4 * 0x10001 ^ x2 * 0x101 ^ x * 0x1010100;\n tEnc = d[s] * 0x101 ^ s * 0x1010100;\n\n for (i = 0; i < 4; i++) {\n encTable[i][x] = tEnc = tEnc << 24 ^ tEnc >>> 8;\n decTable[i][s] = tDec = tDec << 24 ^ tDec >>> 8;\n }\n }\n\n // Compactify. Considerable speedup on Firefox.\n for (i = 0; i < 5; i++) {\n encTable[i] = encTable[i].slice(0);\n decTable[i] = decTable[i].slice(0);\n }\n return tables;\n};\nvar aesTables = null;\n\n/**\n * Schedule out an AES key for both encryption and decryption. This\n * is a low-level class. Use a cipher mode to do bulk encryption.\n *\n * @class AES\n * @param key {Array} The key as an array of 4, 6 or 8 words.\n */\n\nvar AES = function () {\n function AES(key) {\n classCallCheck(this, AES);\n\n /**\n * The expanded S-box and inverse S-box tables. These will be computed\n * on the client so that we don't have to send them down the wire.\n *\n * There are two tables, _tables[0] is for encryption and\n * _tables[1] is for decryption.\n *\n * The first 4 sub-tables are the expanded S-box with MixColumns. The\n * last (_tables[01][4]) is the S-box itself.\n *\n * @private\n */\n // if we have yet to precompute the S-box tables\n // do so now\n if (!aesTables) {\n aesTables = precompute();\n }\n // then make a copy of that object for use\n this._tables = [[aesTables[0][0].slice(), aesTables[0][1].slice(), aesTables[0][2].slice(), aesTables[0][3].slice(), aesTables[0][4].slice()], [aesTables[1][0].slice(), aesTables[1][1].slice(), aesTables[1][2].slice(), aesTables[1][3].slice(), aesTables[1][4].slice()]];\n var i = void 0;\n var j = void 0;\n var tmp = void 0;\n var encKey = void 0;\n var decKey = void 0;\n var sbox = this._tables[0][4];\n var decTable = this._tables[1];\n var keyLen = key.length;\n var rcon = 1;\n\n if (keyLen !== 4 && keyLen !== 6 && keyLen !== 8) {\n throw new Error('Invalid aes key size');\n }\n\n encKey = key.slice(0);\n decKey = [];\n this._key = [encKey, decKey];\n\n // schedule encryption keys\n for (i = keyLen; i < 4 * keyLen + 28; i++) {\n tmp = encKey[i - 1];\n\n // apply sbox\n if (i % keyLen === 0 || keyLen === 8 && i % keyLen === 4) {\n tmp = sbox[tmp >>> 24] << 24 ^ sbox[tmp >> 16 & 255] << 16 ^ sbox[tmp >> 8 & 255] << 8 ^ sbox[tmp & 255];\n\n // shift rows and add rcon\n if (i % keyLen === 0) {\n tmp = tmp << 8 ^ tmp >>> 24 ^ rcon << 24;\n rcon = rcon << 1 ^ (rcon >> 7) * 283;\n }\n }\n\n encKey[i] = encKey[i - keyLen] ^ tmp;\n }\n\n // schedule decryption keys\n for (j = 0; i; j++, i--) {\n tmp = encKey[j & 3 ? i : i - 4];\n if (i <= 4 || j < 4) {\n decKey[j] = tmp;\n } else {\n decKey[j] = decTable[0][sbox[tmp >>> 24]] ^ decTable[1][sbox[tmp >> 16 & 255]] ^ decTable[2][sbox[tmp >> 8 & 255]] ^ decTable[3][sbox[tmp & 255]];\n }\n }\n }\n\n /**\n * Decrypt 16 bytes, specified as four 32-bit words.\n *\n * @param {Number} encrypted0 the first word to decrypt\n * @param {Number} encrypted1 the second word to decrypt\n * @param {Number} encrypted2 the third word to decrypt\n * @param {Number} encrypted3 the fourth word to decrypt\n * @param {Int32Array} out the array to write the decrypted words\n * into\n * @param {Number} offset the offset into the output array to start\n * writing results\n * @return {Array} The plaintext.\n */\n\n\n AES.prototype.decrypt = function decrypt(encrypted0, encrypted1, encrypted2, encrypted3, out, offset) {\n var key = this._key[1];\n // state variables a,b,c,d are loaded with pre-whitened data\n var a = encrypted0 ^ key[0];\n var b = encrypted3 ^ key[1];\n var c = encrypted2 ^ key[2];\n var d = encrypted1 ^ key[3];\n var a2 = void 0;\n var b2 = void 0;\n var c2 = void 0;\n\n // key.length === 2 ?\n var nInnerRounds = key.length / 4 - 2;\n var i = void 0;\n var kIndex = 4;\n var table = this._tables[1];\n\n // load up the tables\n var table0 = table[0];\n var table1 = table[1];\n var table2 = table[2];\n var table3 = table[3];\n var sbox = table[4];\n\n // Inner rounds. Cribbed from OpenSSL.\n for (i = 0; i < nInnerRounds; i++) {\n a2 = table0[a >>> 24] ^ table1[b >> 16 & 255] ^ table2[c >> 8 & 255] ^ table3[d & 255] ^ key[kIndex];\n b2 = table0[b >>> 24] ^ table1[c >> 16 & 255] ^ table2[d >> 8 & 255] ^ table3[a & 255] ^ key[kIndex + 1];\n c2 = table0[c >>> 24] ^ table1[d >> 16 & 255] ^ table2[a >> 8 & 255] ^ table3[b & 255] ^ key[kIndex + 2];\n d = table0[d >>> 24] ^ table1[a >> 16 & 255] ^ table2[b >> 8 & 255] ^ table3[c & 255] ^ key[kIndex + 3];\n kIndex += 4;\n a = a2;b = b2;c = c2;\n }\n\n // Last round.\n for (i = 0; i < 4; i++) {\n out[(3 & -i) + offset] = sbox[a >>> 24] << 24 ^ sbox[b >> 16 & 255] << 16 ^ sbox[c >> 8 & 255] << 8 ^ sbox[d & 255] ^ key[kIndex++];\n a2 = a;a = b;b = c;c = d;d = a2;\n }\n };\n\n return AES;\n}();\n\n/**\n * @file stream.js\n */\n/**\n * A lightweight readable stream implemention that handles event dispatching.\n *\n * @class Stream\n */\nvar Stream = function () {\n function Stream() {\n classCallCheck(this, Stream);\n\n this.listeners = {};\n }\n\n /**\n * Add a listener for a specified event type.\n *\n * @param {String} type the event name\n * @param {Function} listener the callback to be invoked when an event of\n * the specified type occurs\n */\n\n\n Stream.prototype.on = function on(type, listener) {\n if (!this.listeners[type]) {\n this.listeners[type] = [];\n }\n this.listeners[type].push(listener);\n };\n\n /**\n * Remove a listener for a specified event type.\n *\n * @param {String} type the event name\n * @param {Function} listener a function previously registered for this\n * type of event through `on`\n * @return {Boolean} if we could turn it off or not\n */\n\n\n Stream.prototype.off = function off(type, listener) {\n if (!this.listeners[type]) {\n return false;\n }\n\n var index = this.listeners[type].indexOf(listener);\n\n this.listeners[type].splice(index, 1);\n return index > -1;\n };\n\n /**\n * Trigger an event of the specified type on this stream. Any additional\n * arguments to this function are passed as parameters to event listeners.\n *\n * @param {String} type the event name\n */\n\n\n Stream.prototype.trigger = function trigger(type) {\n var callbacks = this.listeners[type];\n\n if (!callbacks) {\n return;\n }\n\n // Slicing the arguments on every invocation of this method\n // can add a significant amount of overhead. Avoid the\n // intermediate object creation for the common case of a\n // single callback argument\n if (arguments.length === 2) {\n var length = callbacks.length;\n\n for (var i = 0; i < length; ++i) {\n callbacks[i].call(this, arguments[1]);\n }\n } else {\n var args = Array.prototype.slice.call(arguments, 1);\n var _length = callbacks.length;\n\n for (var _i = 0; _i < _length; ++_i) {\n callbacks[_i].apply(this, args);\n }\n }\n };\n\n /**\n * Destroys the stream and cleans up.\n */\n\n\n Stream.prototype.dispose = function dispose() {\n this.listeners = {};\n };\n /**\n * Forwards all `data` events on this stream to the destination stream. The\n * destination stream should provide a method `push` to receive the data\n * events as they arrive.\n *\n * @param {Stream} destination the stream that will receive all `data` events\n * @see http://nodejs.org/api/stream.html#stream_readable_pipe_destination_options\n */\n\n\n Stream.prototype.pipe = function pipe(destination) {\n this.on('data', function (data) {\n destination.push(data);\n });\n };\n\n return Stream;\n}();\n\n/**\n * @file async-stream.js\n */\n/**\n * A wrapper around the Stream class to use setTiemout\n * and run stream \"jobs\" Asynchronously\n *\n * @class AsyncStream\n * @extends Stream\n */\n\nvar AsyncStream = function (_Stream) {\n inherits(AsyncStream, _Stream);\n\n function AsyncStream() {\n classCallCheck(this, AsyncStream);\n\n var _this = possibleConstructorReturn(this, _Stream.call(this, Stream));\n\n _this.jobs = [];\n _this.delay = 1;\n _this.timeout_ = null;\n return _this;\n }\n\n /**\n * process an async job\n *\n * @private\n */\n\n\n AsyncStream.prototype.processJob_ = function processJob_() {\n this.jobs.shift()();\n if (this.jobs.length) {\n this.timeout_ = setTimeout(this.processJob_.bind(this), this.delay);\n } else {\n this.timeout_ = null;\n }\n };\n\n /**\n * push a job into the stream\n *\n * @param {Function} job the job to push into the stream\n */\n\n\n AsyncStream.prototype.push = function push(job) {\n this.jobs.push(job);\n if (!this.timeout_) {\n this.timeout_ = setTimeout(this.processJob_.bind(this), this.delay);\n }\n };\n\n return AsyncStream;\n}(Stream);\n\n/**\n * @file decrypter.js\n *\n * An asynchronous implementation of AES-128 CBC decryption with\n * PKCS#7 padding.\n */\n\n/**\n * Convert network-order (big-endian) bytes into their little-endian\n * representation.\n */\nvar ntoh = function ntoh(word) {\n return word << 24 | (word & 0xff00) << 8 | (word & 0xff0000) >> 8 | word >>> 24;\n};\n\n/**\n * Decrypt bytes using AES-128 with CBC and PKCS#7 padding.\n *\n * @param {Uint8Array} encrypted the encrypted bytes\n * @param {Uint32Array} key the bytes of the decryption key\n * @param {Uint32Array} initVector the initialization vector (IV) to\n * use for the first round of CBC.\n * @return {Uint8Array} the decrypted bytes\n *\n * @see http://en.wikipedia.org/wiki/Advanced_Encryption_Standard\n * @see http://en.wikipedia.org/wiki/Block_cipher_mode_of_operation#Cipher_Block_Chaining_.28CBC.29\n * @see https://tools.ietf.org/html/rfc2315\n */\nvar decrypt = function decrypt(encrypted, key, initVector) {\n // word-level access to the encrypted bytes\n var encrypted32 = new Int32Array(encrypted.buffer, encrypted.byteOffset, encrypted.byteLength >> 2);\n\n var decipher = new AES(Array.prototype.slice.call(key));\n\n // byte and word-level access for the decrypted output\n var decrypted = new Uint8Array(encrypted.byteLength);\n var decrypted32 = new Int32Array(decrypted.buffer);\n\n // temporary variables for working with the IV, encrypted, and\n // decrypted data\n var init0 = void 0;\n var init1 = void 0;\n var init2 = void 0;\n var init3 = void 0;\n var encrypted0 = void 0;\n var encrypted1 = void 0;\n var encrypted2 = void 0;\n var encrypted3 = void 0;\n\n // iteration variable\n var wordIx = void 0;\n\n // pull out the words of the IV to ensure we don't modify the\n // passed-in reference and easier access\n init0 = initVector[0];\n init1 = initVector[1];\n init2 = initVector[2];\n init3 = initVector[3];\n\n // decrypt four word sequences, applying cipher-block chaining (CBC)\n // to each decrypted block\n for (wordIx = 0; wordIx < encrypted32.length; wordIx += 4) {\n // convert big-endian (network order) words into little-endian\n // (javascript order)\n encrypted0 = ntoh(encrypted32[wordIx]);\n encrypted1 = ntoh(encrypted32[wordIx + 1]);\n encrypted2 = ntoh(encrypted32[wordIx + 2]);\n encrypted3 = ntoh(encrypted32[wordIx + 3]);\n\n // decrypt the block\n decipher.decrypt(encrypted0, encrypted1, encrypted2, encrypted3, decrypted32, wordIx);\n\n // XOR with the IV, and restore network byte-order to obtain the\n // plaintext\n decrypted32[wordIx] = ntoh(decrypted32[wordIx] ^ init0);\n decrypted32[wordIx + 1] = ntoh(decrypted32[wordIx + 1] ^ init1);\n decrypted32[wordIx + 2] = ntoh(decrypted32[wordIx + 2] ^ init2);\n decrypted32[wordIx + 3] = ntoh(decrypted32[wordIx + 3] ^ init3);\n\n // setup the IV for the next round\n init0 = encrypted0;\n init1 = encrypted1;\n init2 = encrypted2;\n init3 = encrypted3;\n }\n\n return decrypted;\n};\n\n/**\n * The `Decrypter` class that manages decryption of AES\n * data through `AsyncStream` objects and the `decrypt`\n * function\n *\n * @param {Uint8Array} encrypted the encrypted bytes\n * @param {Uint32Array} key the bytes of the decryption key\n * @param {Uint32Array} initVector the initialization vector (IV) to\n * @param {Function} done the function to run when done\n * @class Decrypter\n */\n\nvar Decrypter = function () {\n function Decrypter(encrypted, key, initVector, done) {\n classCallCheck(this, Decrypter);\n\n var step = Decrypter.STEP;\n var encrypted32 = new Int32Array(encrypted.buffer);\n var decrypted = new Uint8Array(encrypted.byteLength);\n var i = 0;\n\n this.asyncStream_ = new AsyncStream();\n\n // split up the encryption job and do the individual chunks asynchronously\n this.asyncStream_.push(this.decryptChunk_(encrypted32.subarray(i, i + step), key, initVector, decrypted));\n for (i = step; i < encrypted32.length; i += step) {\n initVector = new Uint32Array([ntoh(encrypted32[i - 4]), ntoh(encrypted32[i - 3]), ntoh(encrypted32[i - 2]), ntoh(encrypted32[i - 1])]);\n this.asyncStream_.push(this.decryptChunk_(encrypted32.subarray(i, i + step), key, initVector, decrypted));\n }\n // invoke the done() callback when everything is finished\n this.asyncStream_.push(function () {\n // remove pkcs#7 padding from the decrypted bytes\n done(null, unpad(decrypted));\n });\n }\n\n /**\n * a getter for step the maximum number of bytes to process at one time\n *\n * @return {Number} the value of step 32000\n */\n\n\n /**\n * @private\n */\n Decrypter.prototype.decryptChunk_ = function decryptChunk_(encrypted, key, initVector, decrypted) {\n return function () {\n var bytes = decrypt(encrypted, key, initVector);\n\n decrypted.set(bytes, encrypted.byteOffset);\n };\n };\n\n createClass(Decrypter, null, [{\n key: 'STEP',\n get: function get$$1() {\n // 4 * 8000;\n return 32000;\n }\n }]);\n return Decrypter;\n}();\n\n/**\n * @file index.js\n *\n * Index module to easily import the primary components of AES-128\n * decryption. Like this:\n *\n * ```js\n * import {Decrypter, decrypt, AsyncStream} from 'aes-decrypter';\n * ```\n */\n\nexport { decrypt, Decrypter, AsyncStream };\n","/**\n * @license\n * Video.js 7.4.1 <http://videojs.com/>\n * Copyright Brightcove, Inc. <https://www.brightcove.com/>\n * Available under Apache License Version 2.0\n * <https://github.com/videojs/video.js/blob/master/LICENSE>\n *\n * Includes vtt.js <https://github.com/mozilla/vtt.js>\n * Available under Apache License Version 2.0\n * <https://github.com/mozilla/vtt.js/blob/master/LICENSE>\n */\n\nimport safeParseTuple from 'safe-json-parse/tuple';\nimport vtt from 'videojs-vtt.js';\nimport tsml from 'tsml';\nimport xhr from 'xhr';\nimport URLToolkit from 'url-toolkit';\nimport window$1 from 'global/window';\nimport { Parser } from 'm3u8-parser';\nimport document from 'global/document';\nimport { parse, parseUTCTiming } from 'mpd-parser';\nimport mp4probe from 'mux.js/lib/mp4/probe';\nimport { CaptionParser } from 'mux.js/lib/mp4';\nimport tsInspector from 'mux.js/lib/tools/ts-inspector.js';\nimport { Decrypter, AsyncStream, decrypt } from 'aes-decrypter';\n\nvar version = \"7.4.1\";\n\nfunction _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n subClass.__proto__ = superClass;\n}\n\nfunction _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n\n return _setPrototypeOf(o, p);\n}\n\nfunction isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n\n try {\n Date.prototype.toString.call(Reflect.construct(Date, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}\n\nfunction _construct(Parent, args, Class) {\n if (isNativeReflectConstruct()) {\n _construct = Reflect.construct;\n } else {\n _construct = function _construct(Parent, args, Class) {\n var a = [null];\n a.push.apply(a, args);\n var Constructor = Function.bind.apply(Parent, a);\n var instance = new Constructor();\n if (Class) _setPrototypeOf(instance, Class.prototype);\n return instance;\n };\n }\n\n return _construct.apply(null, arguments);\n}\n\nfunction _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}\n\nfunction _taggedTemplateLiteralLoose(strings, raw) {\n if (!raw) {\n raw = strings.slice(0);\n }\n\n strings.raw = raw;\n return strings;\n}\n\n/**\n * @file create-logger.js\n * @module create-logger\n */\n\nvar history = [];\n/**\n * Log messages to the console and history based on the type of message\n *\n * @private\n * @param {string} type\n * The name of the console method to use.\n *\n * @param {Array} args\n * The arguments to be passed to the matching console method.\n */\n\nvar LogByTypeFactory = function LogByTypeFactory(name, log) {\n return function (type, level, args) {\n var lvl = log.levels[level];\n var lvlRegExp = new RegExp(\"^(\" + lvl + \")$\");\n\n if (type !== 'log') {\n // Add the type to the front of the message when it's not \"log\".\n args.unshift(type.toUpperCase() + ':');\n } // Add console prefix after adding to history.\n\n\n args.unshift(name + ':'); // Add a clone of the args at this point to history.\n\n if (history) {\n history.push([].concat(args));\n } // If there's no console then don't try to output messages, but they will\n // still be stored in history.\n\n\n if (!window$1.console) {\n return;\n } // Was setting these once outside of this function, but containing them\n // in the function makes it easier to test cases where console doesn't exist\n // when the module is executed.\n\n\n var fn = window$1.console[type];\n\n if (!fn && type === 'debug') {\n // Certain browsers don't have support for console.debug. For those, we\n // should default to the closest comparable log.\n fn = window$1.console.info || window$1.console.log;\n } // Bail out if there's no console or if this type is not allowed by the\n // current logging level.\n\n\n if (!fn || !lvl || !lvlRegExp.test(type)) {\n return;\n }\n\n fn[Array.isArray(args) ? 'apply' : 'call'](window$1.console, args);\n };\n};\n\nfunction createLogger(name) {\n // This is the private tracking variable for logging level.\n var level = 'info'; // the curried logByType bound to the specific log and history\n\n var logByType;\n /**\n * Logs plain debug messages. Similar to `console.log`.\n *\n * Due to [limitations](https://github.com/jsdoc3/jsdoc/issues/955#issuecomment-313829149)\n * of our JSDoc template, we cannot properly document this as both a function\n * and a namespace, so its function signature is documented here.\n *\n * #### Arguments\n * ##### *args\n * Mixed[]\n *\n * Any combination of values that could be passed to `console.log()`.\n *\n * #### Return Value\n *\n * `undefined`\n *\n * @namespace\n * @param {Mixed[]} args\n * One or more messages or objects that should be logged.\n */\n\n var log = function log() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n logByType('log', level, args);\n }; // This is the logByType helper that the logging methods below use\n\n\n logByType = LogByTypeFactory(name, log);\n /**\n * Create a new sublogger which chains the old name to the new name.\n *\n * For example, doing `videojs.log.createLogger('player')` and then using that logger will log the following:\n * ```js\n * mylogger('foo');\n * // > VIDEOJS: player: foo\n * ```\n *\n * @param {string} name\n * The name to add call the new logger\n * @return {Object}\n */\n\n log.createLogger = function (subname) {\n return createLogger(name + ': ' + subname);\n };\n /**\n * Enumeration of available logging levels, where the keys are the level names\n * and the values are `|`-separated strings containing logging methods allowed\n * in that logging level. These strings are used to create a regular expression\n * matching the function name being called.\n *\n * Levels provided by Video.js are:\n *\n * - `off`: Matches no calls. Any value that can be cast to `false` will have\n * this effect. The most restrictive.\n * - `all`: Matches only Video.js-provided functions (`debug`, `log`,\n * `log.warn`, and `log.error`).\n * - `debug`: Matches `log.debug`, `log`, `log.warn`, and `log.error` calls.\n * - `info` (default): Matches `log`, `log.warn`, and `log.error` calls.\n * - `warn`: Matches `log.warn` and `log.error` calls.\n * - `error`: Matches only `log.error` calls.\n *\n * @type {Object}\n */\n\n\n log.levels = {\n all: 'debug|log|warn|error',\n off: '',\n debug: 'debug|log|warn|error',\n info: 'log|warn|error',\n warn: 'warn|error',\n error: 'error',\n DEFAULT: level\n };\n /**\n * Get or set the current logging level.\n *\n * If a string matching a key from {@link module:log.levels} is provided, acts\n * as a setter.\n *\n * @param {string} [lvl]\n * Pass a valid level to set a new logging level.\n *\n * @return {string}\n * The current logging level.\n */\n\n log.level = function (lvl) {\n if (typeof lvl === 'string') {\n if (!log.levels.hasOwnProperty(lvl)) {\n throw new Error(\"\\\"\" + lvl + \"\\\" in not a valid log level\");\n }\n\n level = lvl;\n }\n\n return level;\n };\n /**\n * Returns an array containing everything that has been logged to the history.\n *\n * This array is a shallow clone of the internal history record. However, its\n * contents are _not_ cloned; so, mutating objects inside this array will\n * mutate them in history.\n *\n * @return {Array}\n */\n\n\n log.history = function () {\n return history ? [].concat(history) : [];\n };\n /**\n * Allows you to filter the history by the given logger name\n *\n * @param {string} fname\n * The name to filter by\n *\n * @return {Array}\n * The filtered list to return\n */\n\n\n log.history.filter = function (fname) {\n return (history || []).filter(function (historyItem) {\n // if the first item in each historyItem includes `fname`, then it's a match\n return new RegExp(\".*\" + fname + \".*\").test(historyItem[0]);\n });\n };\n /**\n * Clears the internal history tracking, but does not prevent further history\n * tracking.\n */\n\n\n log.history.clear = function () {\n if (history) {\n history.length = 0;\n }\n };\n /**\n * Disable history tracking if it is currently enabled.\n */\n\n\n log.history.disable = function () {\n if (history !== null) {\n history.length = 0;\n history = null;\n }\n };\n /**\n * Enable history tracking if it is currently disabled.\n */\n\n\n log.history.enable = function () {\n if (history === null) {\n history = [];\n }\n };\n /**\n * Logs error messages. Similar to `console.error`.\n *\n * @param {Mixed[]} args\n * One or more messages or objects that should be logged as an error\n */\n\n\n log.error = function () {\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n\n return logByType('error', level, args);\n };\n /**\n * Logs warning messages. Similar to `console.warn`.\n *\n * @param {Mixed[]} args\n * One or more messages or objects that should be logged as a warning.\n */\n\n\n log.warn = function () {\n for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {\n args[_key3] = arguments[_key3];\n }\n\n return logByType('warn', level, args);\n };\n /**\n * Logs debug messages. Similar to `console.debug`, but may also act as a comparable\n * log if `console.debug` is not available\n *\n * @param {Mixed[]} args\n * One or more messages or objects that should be logged as debug.\n */\n\n\n log.debug = function () {\n for (var _len4 = arguments.length, args = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {\n args[_key4] = arguments[_key4];\n }\n\n return logByType('debug', level, args);\n };\n\n return log;\n}\n\n/**\n * @file log.js\n * @module log\n */\nvar log = createLogger('VIDEOJS');\nvar createLogger$1 = log.createLogger;\n\n/**\n * @file obj.js\n * @module obj\n */\n\n/**\n * @callback obj:EachCallback\n *\n * @param {Mixed} value\n * The current key for the object that is being iterated over.\n *\n * @param {string} key\n * The current key-value for object that is being iterated over\n */\n\n/**\n * @callback obj:ReduceCallback\n *\n * @param {Mixed} accum\n * The value that is accumulating over the reduce loop.\n *\n * @param {Mixed} value\n * The current key for the object that is being iterated over.\n *\n * @param {string} key\n * The current key-value for object that is being iterated over\n *\n * @return {Mixed}\n * The new accumulated value.\n */\nvar toString = Object.prototype.toString;\n/**\n * Get the keys of an Object\n *\n * @param {Object}\n * The Object to get the keys from\n *\n * @return {string[]}\n * An array of the keys from the object. Returns an empty array if the\n * object passed in was invalid or had no keys.\n *\n * @private\n */\n\nvar keys = function keys(object) {\n return isObject(object) ? Object.keys(object) : [];\n};\n/**\n * Array-like iteration for objects.\n *\n * @param {Object} object\n * The object to iterate over\n *\n * @param {obj:EachCallback} fn\n * The callback function which is called for each key in the object.\n */\n\n\nfunction each(object, fn) {\n keys(object).forEach(function (key) {\n return fn(object[key], key);\n });\n}\n/**\n * Array-like reduce for objects.\n *\n * @param {Object} object\n * The Object that you want to reduce.\n *\n * @param {Function} fn\n * A callback function which is called for each key in the object. It\n * receives the accumulated value and the per-iteration value and key\n * as arguments.\n *\n * @param {Mixed} [initial = 0]\n * Starting value\n *\n * @return {Mixed}\n * The final accumulated value.\n */\n\nfunction reduce(object, fn, initial) {\n if (initial === void 0) {\n initial = 0;\n }\n\n return keys(object).reduce(function (accum, key) {\n return fn(accum, object[key], key);\n }, initial);\n}\n/**\n * Object.assign-style object shallow merge/extend.\n *\n * @param {Object} target\n * @param {Object} ...sources\n * @return {Object}\n */\n\nfunction assign(target) {\n for (var _len = arguments.length, sources = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n sources[_key - 1] = arguments[_key];\n }\n\n if (Object.assign) {\n return Object.assign.apply(Object, [target].concat(sources));\n }\n\n sources.forEach(function (source) {\n if (!source) {\n return;\n }\n\n each(source, function (value, key) {\n target[key] = value;\n });\n });\n return target;\n}\n/**\n * Returns whether a value is an object of any kind - including DOM nodes,\n * arrays, regular expressions, etc. Not functions, though.\n *\n * This avoids the gotcha where using `typeof` on a `null` value\n * results in `'object'`.\n *\n * @param {Object} value\n * @return {boolean}\n */\n\nfunction isObject(value) {\n return !!value && typeof value === 'object';\n}\n/**\n * Returns whether an object appears to be a \"plain\" object - that is, a\n * direct instance of `Object`.\n *\n * @param {Object} value\n * @return {boolean}\n */\n\nfunction isPlain(value) {\n return isObject(value) && toString.call(value) === '[object Object]' && value.constructor === Object;\n}\n\n/**\n * @file computed-style.js\n * @module computed-style\n */\n/**\n * A safe getComputedStyle.\n *\n * This is needed because in Firefox, if the player is loaded in an iframe with\n * `display:none`, then `getComputedStyle` returns `null`, so, we do a\n * null-check to make sure that the player doesn't break in these cases.\n *\n * @function\n * @param {Element} el\n * The element you want the computed style of\n *\n * @param {string} prop\n * The property name you want\n *\n * @see https://bugzilla.mozilla.org/show_bug.cgi?id=548397\n */\n\nfunction computedStyle(el, prop) {\n if (!el || !prop) {\n return '';\n }\n\n if (typeof window$1.getComputedStyle === 'function') {\n var cs = window$1.getComputedStyle(el);\n return cs ? cs[prop] : '';\n }\n\n return '';\n}\n\nfunction _templateObject() {\n var data = _taggedTemplateLiteralLoose([\"Setting attributes in the second argument of createEl()\\n has been deprecated. Use the third argument instead.\\n createEl(type, properties, attributes). Attempting to set \", \" to \", \".\"]);\n\n _templateObject = function _templateObject() {\n return data;\n };\n\n return data;\n}\n/**\n * Detect if a value is a string with any non-whitespace characters.\n *\n * @private\n * @param {string} str\n * The string to check\n *\n * @return {boolean}\n * Will be `true` if the string is non-blank, `false` otherwise.\n *\n */\n\nfunction isNonBlankString(str) {\n return typeof str === 'string' && /\\S/.test(str);\n}\n/**\n * Throws an error if the passed string has whitespace. This is used by\n * class methods to be relatively consistent with the classList API.\n *\n * @private\n * @param {string} str\n * The string to check for whitespace.\n *\n * @throws {Error}\n * Throws an error if there is whitespace in the string.\n */\n\n\nfunction throwIfWhitespace(str) {\n if (/\\s/.test(str)) {\n throw new Error('class has illegal whitespace characters');\n }\n}\n/**\n * Produce a regular expression for matching a className within an elements className.\n *\n * @private\n * @param {string} className\n * The className to generate the RegExp for.\n *\n * @return {RegExp}\n * The RegExp that will check for a specific `className` in an elements\n * className.\n */\n\n\nfunction classRegExp(className) {\n return new RegExp('(^|\\\\s)' + className + '($|\\\\s)');\n}\n/**\n * Whether the current DOM interface appears to be real (i.e. not simulated).\n *\n * @return {boolean}\n * Will be `true` if the DOM appears to be real, `false` otherwise.\n */\n\n\nfunction isReal() {\n // Both document and window will never be undefined thanks to `global`.\n return document === window$1.document;\n}\n/**\n * Determines, via duck typing, whether or not a value is a DOM element.\n *\n * @param {Mixed} value\n * The value to check.\n *\n * @return {boolean}\n * Will be `true` if the value is a DOM element, `false` otherwise.\n */\n\nfunction isEl(value) {\n return isObject(value) && value.nodeType === 1;\n}\n/**\n * Determines if the current DOM is embedded in an iframe.\n *\n * @return {boolean}\n * Will be `true` if the DOM is embedded in an iframe, `false`\n * otherwise.\n */\n\nfunction isInFrame() {\n // We need a try/catch here because Safari will throw errors when attempting\n // to get either `parent` or `self`\n try {\n return window$1.parent !== window$1.self;\n } catch (x) {\n return true;\n }\n}\n/**\n * Creates functions to query the DOM using a given method.\n *\n * @private\n * @param {string} method\n * The method to create the query with.\n *\n * @return {Function}\n * The query method\n */\n\nfunction createQuerier(method) {\n return function (selector, context) {\n if (!isNonBlankString(selector)) {\n return document[method](null);\n }\n\n if (isNonBlankString(context)) {\n context = document.querySelector(context);\n }\n\n var ctx = isEl(context) ? context : document;\n return ctx[method] && ctx[method](selector);\n };\n}\n/**\n * Creates an element and applies properties, attributes, and inserts content.\n *\n * @param {string} [tagName='div']\n * Name of tag to be created.\n *\n * @param {Object} [properties={}]\n * Element properties to be applied.\n *\n * @param {Object} [attributes={}]\n * Element attributes to be applied.\n *\n * @param {module:dom~ContentDescriptor} content\n * A content descriptor object.\n *\n * @return {Element}\n * The element that was created.\n */\n\n\nfunction createEl(tagName, properties, attributes, content) {\n if (tagName === void 0) {\n tagName = 'div';\n }\n\n if (properties === void 0) {\n properties = {};\n }\n\n if (attributes === void 0) {\n attributes = {};\n }\n\n var el = document.createElement(tagName);\n Object.getOwnPropertyNames(properties).forEach(function (propName) {\n var val = properties[propName]; // See #2176\n // We originally were accepting both properties and attributes in the\n // same object, but that doesn't work so well.\n\n if (propName.indexOf('aria-') !== -1 || propName === 'role' || propName === 'type') {\n log.warn(tsml(_templateObject(), propName, val));\n el.setAttribute(propName, val); // Handle textContent since it's not supported everywhere and we have a\n // method for it.\n } else if (propName === 'textContent') {\n textContent(el, val);\n } else {\n el[propName] = val;\n }\n });\n Object.getOwnPropertyNames(attributes).forEach(function (attrName) {\n el.setAttribute(attrName, attributes[attrName]);\n });\n\n if (content) {\n appendContent(el, content);\n }\n\n return el;\n}\n/**\n * Injects text into an element, replacing any existing contents entirely.\n *\n * @param {Element} el\n * The element to add text content into\n *\n * @param {string} text\n * The text content to add.\n *\n * @return {Element}\n * The element with added text content.\n */\n\nfunction textContent(el, text) {\n if (typeof el.textContent === 'undefined') {\n el.innerText = text;\n } else {\n el.textContent = text;\n }\n\n return el;\n}\n/**\n * Insert an element as the first child node of another\n *\n * @param {Element} child\n * Element to insert\n *\n * @param {Element} parent\n * Element to insert child into\n */\n\nfunction prependTo(child, parent) {\n if (parent.firstChild) {\n parent.insertBefore(child, parent.firstChild);\n } else {\n parent.appendChild(child);\n }\n}\n/**\n * Check if an element has a class name.\n *\n * @param {Element} element\n * Element to check\n *\n * @param {string} classToCheck\n * Class name to check for\n *\n * @return {boolean}\n * Will be `true` if the element has a class, `false` otherwise.\n *\n * @throws {Error}\n * Throws an error if `classToCheck` has white space.\n */\n\nfunction hasClass(element, classToCheck) {\n throwIfWhitespace(classToCheck);\n\n if (element.classList) {\n return element.classList.contains(classToCheck);\n }\n\n return classRegExp(classToCheck).test(element.className);\n}\n/**\n * Add a class name to an element.\n *\n * @param {Element} element\n * Element to add class name to.\n *\n * @param {string} classToAdd\n * Class name to add.\n *\n * @return {Element}\n * The DOM element with the added class name.\n */\n\nfunction addClass(element, classToAdd) {\n if (element.classList) {\n element.classList.add(classToAdd); // Don't need to `throwIfWhitespace` here because `hasElClass` will do it\n // in the case of classList not being supported.\n } else if (!hasClass(element, classToAdd)) {\n element.className = (element.className + ' ' + classToAdd).trim();\n }\n\n return element;\n}\n/**\n * Remove a class name from an element.\n *\n * @param {Element} element\n * Element to remove a class name from.\n *\n * @param {string} classToRemove\n * Class name to remove\n *\n * @return {Element}\n * The DOM element with class name removed.\n */\n\nfunction removeClass(element, classToRemove) {\n if (element.classList) {\n element.classList.remove(classToRemove);\n } else {\n throwIfWhitespace(classToRemove);\n element.className = element.className.split(/\\s+/).filter(function (c) {\n return c !== classToRemove;\n }).join(' ');\n }\n\n return element;\n}\n/**\n * The callback definition for toggleClass.\n *\n * @callback module:dom~PredicateCallback\n * @param {Element} element\n * The DOM element of the Component.\n *\n * @param {string} classToToggle\n * The `className` that wants to be toggled\n *\n * @return {boolean|undefined}\n * If `true` is returned, the `classToToggle` will be added to the\n * `element`. If `false`, the `classToToggle` will be removed from\n * the `element`. If `undefined`, the callback will be ignored.\n */\n\n/**\n * Adds or removes a class name to/from an element depending on an optional\n * condition or the presence/absence of the class name.\n *\n * @param {Element} element\n * The element to toggle a class name on.\n *\n * @param {string} classToToggle\n * The class that should be toggled.\n *\n * @param {boolean|module:dom~PredicateCallback} [predicate]\n * See the return value for {@link module:dom~PredicateCallback}\n *\n * @return {Element}\n * The element with a class that has been toggled.\n */\n\nfunction toggleClass(element, classToToggle, predicate) {\n // This CANNOT use `classList` internally because IE11 does not support the\n // second parameter to the `classList.toggle()` method! Which is fine because\n // `classList` will be used by the add/remove functions.\n var has = hasClass(element, classToToggle);\n\n if (typeof predicate === 'function') {\n predicate = predicate(element, classToToggle);\n }\n\n if (typeof predicate !== 'boolean') {\n predicate = !has;\n } // If the necessary class operation matches the current state of the\n // element, no action is required.\n\n\n if (predicate === has) {\n return;\n }\n\n if (predicate) {\n addClass(element, classToToggle);\n } else {\n removeClass(element, classToToggle);\n }\n\n return element;\n}\n/**\n * Apply attributes to an HTML element.\n *\n * @param {Element} el\n * Element to add attributes to.\n *\n * @param {Object} [attributes]\n * Attributes to be applied.\n */\n\nfunction setAttributes(el, attributes) {\n Object.getOwnPropertyNames(attributes).forEach(function (attrName) {\n var attrValue = attributes[attrName];\n\n if (attrValue === null || typeof attrValue === 'undefined' || attrValue === false) {\n el.removeAttribute(attrName);\n } else {\n el.setAttribute(attrName, attrValue === true ? '' : attrValue);\n }\n });\n}\n/**\n * Get an element's attribute values, as defined on the HTML tag.\n *\n * Attributes are not the same as properties. They're defined on the tag\n * or with setAttribute.\n *\n * @param {Element} tag\n * Element from which to get tag attributes.\n *\n * @return {Object}\n * All attributes of the element. Boolean attributes will be `true` or\n * `false`, others will be strings.\n */\n\nfunction getAttributes(tag) {\n var obj = {}; // known boolean attributes\n // we can check for matching boolean properties, but not all browsers\n // and not all tags know about these attributes, so, we still want to check them manually\n\n var knownBooleans = ',' + 'autoplay,controls,playsinline,loop,muted,default,defaultMuted' + ',';\n\n if (tag && tag.attributes && tag.attributes.length > 0) {\n var attrs = tag.attributes;\n\n for (var i = attrs.length - 1; i >= 0; i--) {\n var attrName = attrs[i].name;\n var attrVal = attrs[i].value; // check for known booleans\n // the matching element property will return a value for typeof\n\n if (typeof tag[attrName] === 'boolean' || knownBooleans.indexOf(',' + attrName + ',') !== -1) {\n // the value of an included boolean attribute is typically an empty\n // string ('') which would equal false if we just check for a false value.\n // we also don't want support bad code like autoplay='false'\n attrVal = attrVal !== null ? true : false;\n }\n\n obj[attrName] = attrVal;\n }\n }\n\n return obj;\n}\n/**\n * Get the value of an element's attribute.\n *\n * @param {Element} el\n * A DOM element.\n *\n * @param {string} attribute\n * Attribute to get the value of.\n *\n * @return {string}\n * The value of the attribute.\n */\n\nfunction getAttribute(el, attribute) {\n return el.getAttribute(attribute);\n}\n/**\n * Set the value of an element's attribute.\n *\n * @param {Element} el\n * A DOM element.\n *\n * @param {string} attribute\n * Attribute to set.\n *\n * @param {string} value\n * Value to set the attribute to.\n */\n\nfunction setAttribute(el, attribute, value) {\n el.setAttribute(attribute, value);\n}\n/**\n * Remove an element's attribute.\n *\n * @param {Element} el\n * A DOM element.\n *\n * @param {string} attribute\n * Attribute to remove.\n */\n\nfunction removeAttribute(el, attribute) {\n el.removeAttribute(attribute);\n}\n/**\n * Attempt to block the ability to select text.\n */\n\nfunction blockTextSelection() {\n document.body.focus();\n\n document.onselectstart = function () {\n return false;\n };\n}\n/**\n * Turn off text selection blocking.\n */\n\nfunction unblockTextSelection() {\n document.onselectstart = function () {\n return true;\n };\n}\n/**\n * Identical to the native `getBoundingClientRect` function, but ensures that\n * the method is supported at all (it is in all browsers we claim to support)\n * and that the element is in the DOM before continuing.\n *\n * This wrapper function also shims properties which are not provided by some\n * older browsers (namely, IE8).\n *\n * Additionally, some browsers do not support adding properties to a\n * `ClientRect`/`DOMRect` object; so, we shallow-copy it with the standard\n * properties (except `x` and `y` which are not widely supported). This helps\n * avoid implementations where keys are non-enumerable.\n *\n * @param {Element} el\n * Element whose `ClientRect` we want to calculate.\n *\n * @return {Object|undefined}\n * Always returns a plain object - or `undefined` if it cannot.\n */\n\nfunction getBoundingClientRect(el) {\n if (el && el.getBoundingClientRect && el.parentNode) {\n var rect = el.getBoundingClientRect();\n var result = {};\n ['bottom', 'height', 'left', 'right', 'top', 'width'].forEach(function (k) {\n if (rect[k] !== undefined) {\n result[k] = rect[k];\n }\n });\n\n if (!result.height) {\n result.height = parseFloat(computedStyle(el, 'height'));\n }\n\n if (!result.width) {\n result.width = parseFloat(computedStyle(el, 'width'));\n }\n\n return result;\n }\n}\n/**\n * Represents the position of a DOM element on the page.\n *\n * @typedef {Object} module:dom~Position\n *\n * @property {number} left\n * Pixels to the left.\n *\n * @property {number} top\n * Pixels from the top.\n */\n\n/**\n * Get the position of an element in the DOM.\n *\n * Uses `getBoundingClientRect` technique from John Resig.\n *\n * @see http://ejohn.org/blog/getboundingclientrect-is-awesome/\n *\n * @param {Element} el\n * Element from which to get offset.\n *\n * @return {module:dom~Position}\n * The position of the element that was passed in.\n */\n\nfunction findPosition(el) {\n var box;\n\n if (el.getBoundingClientRect && el.parentNode) {\n box = el.getBoundingClientRect();\n }\n\n if (!box) {\n return {\n left: 0,\n top: 0\n };\n }\n\n var docEl = document.documentElement;\n var body = document.body;\n var clientLeft = docEl.clientLeft || body.clientLeft || 0;\n var scrollLeft = window$1.pageXOffset || body.scrollLeft;\n var left = box.left + scrollLeft - clientLeft;\n var clientTop = docEl.clientTop || body.clientTop || 0;\n var scrollTop = window$1.pageYOffset || body.scrollTop;\n var top = box.top + scrollTop - clientTop; // Android sometimes returns slightly off decimal values, so need to round\n\n return {\n left: Math.round(left),\n top: Math.round(top)\n };\n}\n/**\n * Represents x and y coordinates for a DOM element or mouse pointer.\n *\n * @typedef {Object} module:dom~Coordinates\n *\n * @property {number} x\n * x coordinate in pixels\n *\n * @property {number} y\n * y coordinate in pixels\n */\n\n/**\n * Get the pointer position within an element.\n *\n * The base on the coordinates are the bottom left of the element.\n *\n * @param {Element} el\n * Element on which to get the pointer position on.\n *\n * @param {EventTarget~Event} event\n * Event object.\n *\n * @return {module:dom~Coordinates}\n * A coordinates object corresponding to the mouse position.\n *\n */\n\nfunction getPointerPosition(el, event) {\n var position = {};\n var box = findPosition(el);\n var boxW = el.offsetWidth;\n var boxH = el.offsetHeight;\n var boxY = box.top;\n var boxX = box.left;\n var pageY = event.pageY;\n var pageX = event.pageX;\n\n if (event.changedTouches) {\n pageX = event.changedTouches[0].pageX;\n pageY = event.changedTouches[0].pageY;\n }\n\n position.y = Math.max(0, Math.min(1, (boxY - pageY + boxH) / boxH));\n position.x = Math.max(0, Math.min(1, (pageX - boxX) / boxW));\n return position;\n}\n/**\n * Determines, via duck typing, whether or not a value is a text node.\n *\n * @param {Mixed} value\n * Check if this value is a text node.\n *\n * @return {boolean}\n * Will be `true` if the value is a text node, `false` otherwise.\n */\n\nfunction isTextNode(value) {\n return isObject(value) && value.nodeType === 3;\n}\n/**\n * Empties the contents of an element.\n *\n * @param {Element} el\n * The element to empty children from\n *\n * @return {Element}\n * The element with no children\n */\n\nfunction emptyEl(el) {\n while (el.firstChild) {\n el.removeChild(el.firstChild);\n }\n\n return el;\n}\n/**\n * This is a mixed value that describes content to be injected into the DOM\n * via some method. It can be of the following types:\n *\n * Type | Description\n * -----------|-------------\n * `string` | The value will be normalized into a text node.\n * `Element` | The value will be accepted as-is.\n * `TextNode` | The value will be accepted as-is.\n * `Array` | A one-dimensional array of strings, elements, text nodes, or functions. These functions should return a string, element, or text node (any other return value, like an array, will be ignored).\n * `Function` | A function, which is expected to return a string, element, text node, or array - any of the other possible values described above. This means that a content descriptor could be a function that returns an array of functions, but those second-level functions must return strings, elements, or text nodes.\n *\n * @typedef {string|Element|TextNode|Array|Function} module:dom~ContentDescriptor\n */\n\n/**\n * Normalizes content for eventual insertion into the DOM.\n *\n * This allows a wide range of content definition methods, but helps protect\n * from falling into the trap of simply writing to `innerHTML`, which could\n * be an XSS concern.\n *\n * The content for an element can be passed in multiple types and\n * combinations, whose behavior is as follows:\n *\n * @param {module:dom~ContentDescriptor} content\n * A content descriptor value.\n *\n * @return {Array}\n * All of the content that was passed in, normalized to an array of\n * elements or text nodes.\n */\n\nfunction normalizeContent(content) {\n // First, invoke content if it is a function. If it produces an array,\n // that needs to happen before normalization.\n if (typeof content === 'function') {\n content = content();\n } // Next up, normalize to an array, so one or many items can be normalized,\n // filtered, and returned.\n\n\n return (Array.isArray(content) ? content : [content]).map(function (value) {\n // First, invoke value if it is a function to produce a new value,\n // which will be subsequently normalized to a Node of some kind.\n if (typeof value === 'function') {\n value = value();\n }\n\n if (isEl(value) || isTextNode(value)) {\n return value;\n }\n\n if (typeof value === 'string' && /\\S/.test(value)) {\n return document.createTextNode(value);\n }\n }).filter(function (value) {\n return value;\n });\n}\n/**\n * Normalizes and appends content to an element.\n *\n * @param {Element} el\n * Element to append normalized content to.\n *\n * @param {module:dom~ContentDescriptor} content\n * A content descriptor value.\n *\n * @return {Element}\n * The element with appended normalized content.\n */\n\nfunction appendContent(el, content) {\n normalizeContent(content).forEach(function (node) {\n return el.appendChild(node);\n });\n return el;\n}\n/**\n * Normalizes and inserts content into an element; this is identical to\n * `appendContent()`, except it empties the element first.\n *\n * @param {Element} el\n * Element to insert normalized content into.\n *\n * @param {module:dom~ContentDescriptor} content\n * A content descriptor value.\n *\n * @return {Element}\n * The element with inserted normalized content.\n */\n\nfunction insertContent(el, content) {\n return appendContent(emptyEl(el), content);\n}\n/**\n * Check if an event was a single left click.\n *\n * @param {EventTarget~Event} event\n * Event object.\n *\n * @return {boolean}\n * Will be `true` if a single left click, `false` otherwise.\n */\n\nfunction isSingleLeftClick(event) {\n // Note: if you create something draggable, be sure to\n // call it on both `mousedown` and `mousemove` event,\n // otherwise `mousedown` should be enough for a button\n if (event.button === undefined && event.buttons === undefined) {\n // Why do we need `buttons` ?\n // Because, middle mouse sometimes have this:\n // e.button === 0 and e.buttons === 4\n // Furthermore, we want to prevent combination click, something like\n // HOLD middlemouse then left click, that would be\n // e.button === 0, e.buttons === 5\n // just `button` is not gonna work\n // Alright, then what this block does ?\n // this is for chrome `simulate mobile devices`\n // I want to support this as well\n return true;\n }\n\n if (event.button === 0 && event.buttons === undefined) {\n // Touch screen, sometimes on some specific device, `buttons`\n // doesn't have anything (safari on ios, blackberry...)\n return true;\n }\n\n if (event.button !== 0 || event.buttons !== 1) {\n // This is the reason we have those if else block above\n // if any special case we can catch and let it slide\n // we do it above, when get to here, this definitely\n // is-not-left-click\n return false;\n }\n\n return true;\n}\n/**\n * Finds a single DOM element matching `selector` within the optional\n * `context` of another DOM element (defaulting to `document`).\n *\n * @param {string} selector\n * A valid CSS selector, which will be passed to `querySelector`.\n *\n * @param {Element|String} [context=document]\n * A DOM element within which to query. Can also be a selector\n * string in which case the first matching element will be used\n * as context. If missing (or no element matches selector), falls\n * back to `document`.\n *\n * @return {Element|null}\n * The element that was found or null.\n */\n\nvar $ = createQuerier('querySelector');\n/**\n * Finds a all DOM elements matching `selector` within the optional\n * `context` of another DOM element (defaulting to `document`).\n *\n * @param {string} selector\n * A valid CSS selector, which will be passed to `querySelectorAll`.\n *\n * @param {Element|String} [context=document]\n * A DOM element within which to query. Can also be a selector\n * string in which case the first matching element will be used\n * as context. If missing (or no element matches selector), falls\n * back to `document`.\n *\n * @return {NodeList}\n * A element list of elements that were found. Will be empty if none\n * were found.\n *\n */\n\nvar $$ = createQuerier('querySelectorAll');\n\nvar Dom = /*#__PURE__*/Object.freeze({\n isReal: isReal,\n isEl: isEl,\n isInFrame: isInFrame,\n createEl: createEl,\n textContent: textContent,\n prependTo: prependTo,\n hasClass: hasClass,\n addClass: addClass,\n removeClass: removeClass,\n toggleClass: toggleClass,\n setAttributes: setAttributes,\n getAttributes: getAttributes,\n getAttribute: getAttribute,\n setAttribute: setAttribute,\n removeAttribute: removeAttribute,\n blockTextSelection: blockTextSelection,\n unblockTextSelection: unblockTextSelection,\n getBoundingClientRect: getBoundingClientRect,\n findPosition: findPosition,\n getPointerPosition: getPointerPosition,\n isTextNode: isTextNode,\n emptyEl: emptyEl,\n normalizeContent: normalizeContent,\n appendContent: appendContent,\n insertContent: insertContent,\n isSingleLeftClick: isSingleLeftClick,\n $: $,\n $$: $$\n});\n\n/**\n * @file guid.js\n * @module guid\n */\n\n/**\n * Unique ID for an element or function\n * @type {Number}\n */\nvar _guid = 1;\n/**\n * Get a unique auto-incrementing ID by number that has not been returned before.\n *\n * @return {number}\n * A new unique ID.\n */\n\nfunction newGUID() {\n return _guid++;\n}\n\n/**\n * @file dom-data.js\n * @module dom-data\n */\n/**\n * Element Data Store.\n *\n * Allows for binding data to an element without putting it directly on the\n * element. Ex. Event listeners are stored here.\n * (also from jsninja.com, slightly modified and updated for closure compiler)\n *\n * @type {Object}\n * @private\n */\n\nvar elData = {};\n/*\n * Unique attribute name to store an element's guid in\n *\n * @type {String}\n * @constant\n * @private\n */\n\nvar elIdAttr = 'vdata' + new Date().getTime();\n/**\n * Returns the cache object where data for an element is stored\n *\n * @param {Element} el\n * Element to store data for.\n *\n * @return {Object}\n * The cache object for that el that was passed in.\n */\n\nfunction getData(el) {\n var id = el[elIdAttr];\n\n if (!id) {\n id = el[elIdAttr] = newGUID();\n }\n\n if (!elData[id]) {\n elData[id] = {};\n }\n\n return elData[id];\n}\n/**\n * Returns whether or not an element has cached data\n *\n * @param {Element} el\n * Check if this element has cached data.\n *\n * @return {boolean}\n * - True if the DOM element has cached data.\n * - False otherwise.\n */\n\nfunction hasData(el) {\n var id = el[elIdAttr];\n\n if (!id) {\n return false;\n }\n\n return !!Object.getOwnPropertyNames(elData[id]).length;\n}\n/**\n * Delete data for the element from the cache and the guid attr from getElementById\n *\n * @param {Element} el\n * Remove cached data for this element.\n */\n\nfunction removeData(el) {\n var id = el[elIdAttr];\n\n if (!id) {\n return;\n } // Remove all stored data\n\n\n delete elData[id]; // Remove the elIdAttr property from the DOM node\n\n try {\n delete el[elIdAttr];\n } catch (e) {\n if (el.removeAttribute) {\n el.removeAttribute(elIdAttr);\n } else {\n // IE doesn't appear to support removeAttribute on the document element\n el[elIdAttr] = null;\n }\n }\n}\n\n/**\n * @file events.js. An Event System (John Resig - Secrets of a JS Ninja http://jsninja.com/)\n * (Original book version wasn't completely usable, so fixed some things and made Closure Compiler compatible)\n * This should work very similarly to jQuery's events, however it's based off the book version which isn't as\n * robust as jquery's, so there's probably some differences.\n *\n * @file events.js\n * @module events\n */\n/**\n * Clean up the listener cache and dispatchers\n *\n * @param {Element|Object} elem\n * Element to clean up\n *\n * @param {string} type\n * Type of event to clean up\n */\n\nfunction _cleanUpEvents(elem, type) {\n var data = getData(elem); // Remove the events of a particular type if there are none left\n\n if (data.handlers[type].length === 0) {\n delete data.handlers[type]; // data.handlers[type] = null;\n // Setting to null was causing an error with data.handlers\n // Remove the meta-handler from the element\n\n if (elem.removeEventListener) {\n elem.removeEventListener(type, data.dispatcher, false);\n } else if (elem.detachEvent) {\n elem.detachEvent('on' + type, data.dispatcher);\n }\n } // Remove the events object if there are no types left\n\n\n if (Object.getOwnPropertyNames(data.handlers).length <= 0) {\n delete data.handlers;\n delete data.dispatcher;\n delete data.disabled;\n } // Finally remove the element data if there is no data left\n\n\n if (Object.getOwnPropertyNames(data).length === 0) {\n removeData(elem);\n }\n}\n/**\n * Loops through an array of event types and calls the requested method for each type.\n *\n * @param {Function} fn\n * The event method we want to use.\n *\n * @param {Element|Object} elem\n * Element or object to bind listeners to\n *\n * @param {string} type\n * Type of event to bind to.\n *\n * @param {EventTarget~EventListener} callback\n * Event listener.\n */\n\n\nfunction _handleMultipleEvents(fn, elem, types, callback) {\n types.forEach(function (type) {\n // Call the event method for each one of the types\n fn(elem, type, callback);\n });\n}\n/**\n * Fix a native event to have standard property values\n *\n * @param {Object} event\n * Event object to fix.\n *\n * @return {Object}\n * Fixed event object.\n */\n\n\nfunction fixEvent(event) {\n function returnTrue() {\n return true;\n }\n\n function returnFalse() {\n return false;\n } // Test if fixing up is needed\n // Used to check if !event.stopPropagation instead of isPropagationStopped\n // But native events return true for stopPropagation, but don't have\n // other expected methods like isPropagationStopped. Seems to be a problem\n // with the Javascript Ninja code. So we're just overriding all events now.\n\n\n if (!event || !event.isPropagationStopped) {\n var old = event || window$1.event;\n event = {}; // Clone the old object so that we can modify the values event = {};\n // IE8 Doesn't like when you mess with native event properties\n // Firefox returns false for event.hasOwnProperty('type') and other props\n // which makes copying more difficult.\n // TODO: Probably best to create a whitelist of event props\n\n for (var key in old) {\n // Safari 6.0.3 warns you if you try to copy deprecated layerX/Y\n // Chrome warns you if you try to copy deprecated keyboardEvent.keyLocation\n // and webkitMovementX/Y\n if (key !== 'layerX' && key !== 'layerY' && key !== 'keyLocation' && key !== 'webkitMovementX' && key !== 'webkitMovementY') {\n // Chrome 32+ warns if you try to copy deprecated returnValue, but\n // we still want to if preventDefault isn't supported (IE8).\n if (!(key === 'returnValue' && old.preventDefault)) {\n event[key] = old[key];\n }\n }\n } // The event occurred on this element\n\n\n if (!event.target) {\n event.target = event.srcElement || document;\n } // Handle which other element the event is related to\n\n\n if (!event.relatedTarget) {\n event.relatedTarget = event.fromElement === event.target ? event.toElement : event.fromElement;\n } // Stop the default browser action\n\n\n event.preventDefault = function () {\n if (old.preventDefault) {\n old.preventDefault();\n }\n\n event.returnValue = false;\n old.returnValue = false;\n event.defaultPrevented = true;\n };\n\n event.defaultPrevented = false; // Stop the event from bubbling\n\n event.stopPropagation = function () {\n if (old.stopPropagation) {\n old.stopPropagation();\n }\n\n event.cancelBubble = true;\n old.cancelBubble = true;\n event.isPropagationStopped = returnTrue;\n };\n\n event.isPropagationStopped = returnFalse; // Stop the event from bubbling and executing other handlers\n\n event.stopImmediatePropagation = function () {\n if (old.stopImmediatePropagation) {\n old.stopImmediatePropagation();\n }\n\n event.isImmediatePropagationStopped = returnTrue;\n event.stopPropagation();\n };\n\n event.isImmediatePropagationStopped = returnFalse; // Handle mouse position\n\n if (event.clientX !== null && event.clientX !== undefined) {\n var doc = document.documentElement;\n var body = document.body;\n event.pageX = event.clientX + (doc && doc.scrollLeft || body && body.scrollLeft || 0) - (doc && doc.clientLeft || body && body.clientLeft || 0);\n event.pageY = event.clientY + (doc && doc.scrollTop || body && body.scrollTop || 0) - (doc && doc.clientTop || body && body.clientTop || 0);\n } // Handle key presses\n\n\n event.which = event.charCode || event.keyCode; // Fix button for mouse clicks:\n // 0 == left; 1 == middle; 2 == right\n\n if (event.button !== null && event.button !== undefined) {\n // The following is disabled because it does not pass videojs-standard\n // and... yikes.\n\n /* eslint-disable */\n event.button = event.button & 1 ? 0 : event.button & 4 ? 1 : event.button & 2 ? 2 : 0;\n /* eslint-enable */\n }\n } // Returns fixed-up instance\n\n\n return event;\n}\n/**\n * Whether passive event listeners are supported\n */\n\nvar _supportsPassive = false;\n\n(function () {\n try {\n var opts = Object.defineProperty({}, 'passive', {\n get: function get() {\n _supportsPassive = true;\n }\n });\n window$1.addEventListener('test', null, opts);\n window$1.removeEventListener('test', null, opts);\n } catch (e) {// disregard\n }\n})();\n/**\n * Touch events Chrome expects to be passive\n */\n\n\nvar passiveEvents = ['touchstart', 'touchmove'];\n/**\n * Add an event listener to element\n * It stores the handler function in a separate cache object\n * and adds a generic handler to the element's event,\n * along with a unique id (guid) to the element.\n *\n * @param {Element|Object} elem\n * Element or object to bind listeners to\n *\n * @param {string|string[]} type\n * Type of event to bind to.\n *\n * @param {EventTarget~EventListener} fn\n * Event listener.\n */\n\nfunction on(elem, type, fn) {\n if (Array.isArray(type)) {\n return _handleMultipleEvents(on, elem, type, fn);\n }\n\n var data = getData(elem); // We need a place to store all our handler data\n\n if (!data.handlers) {\n data.handlers = {};\n }\n\n if (!data.handlers[type]) {\n data.handlers[type] = [];\n }\n\n if (!fn.guid) {\n fn.guid = newGUID();\n }\n\n data.handlers[type].push(fn);\n\n if (!data.dispatcher) {\n data.disabled = false;\n\n data.dispatcher = function (event, hash) {\n if (data.disabled) {\n return;\n }\n\n event = fixEvent(event);\n var handlers = data.handlers[event.type];\n\n if (handlers) {\n // Copy handlers so if handlers are added/removed during the process it doesn't throw everything off.\n var handlersCopy = handlers.slice(0);\n\n for (var m = 0, n = handlersCopy.length; m < n; m++) {\n if (event.isImmediatePropagationStopped()) {\n break;\n } else {\n try {\n handlersCopy[m].call(elem, event, hash);\n } catch (e) {\n log.error(e);\n }\n }\n }\n }\n };\n }\n\n if (data.handlers[type].length === 1) {\n if (elem.addEventListener) {\n var options = false;\n\n if (_supportsPassive && passiveEvents.indexOf(type) > -1) {\n options = {\n passive: true\n };\n }\n\n elem.addEventListener(type, data.dispatcher, options);\n } else if (elem.attachEvent) {\n elem.attachEvent('on' + type, data.dispatcher);\n }\n }\n}\n/**\n * Removes event listeners from an element\n *\n * @param {Element|Object} elem\n * Object to remove listeners from.\n *\n * @param {string|string[]} [type]\n * Type of listener to remove. Don't include to remove all events from element.\n *\n * @param {EventTarget~EventListener} [fn]\n * Specific listener to remove. Don't include to remove listeners for an event\n * type.\n */\n\nfunction off(elem, type, fn) {\n // Don't want to add a cache object through getElData if not needed\n if (!hasData(elem)) {\n return;\n }\n\n var data = getData(elem); // If no events exist, nothing to unbind\n\n if (!data.handlers) {\n return;\n }\n\n if (Array.isArray(type)) {\n return _handleMultipleEvents(off, elem, type, fn);\n } // Utility function\n\n\n var removeType = function removeType(el, t) {\n data.handlers[t] = [];\n\n _cleanUpEvents(el, t);\n }; // Are we removing all bound events?\n\n\n if (type === undefined) {\n for (var t in data.handlers) {\n if (Object.prototype.hasOwnProperty.call(data.handlers || {}, t)) {\n removeType(elem, t);\n }\n }\n\n return;\n }\n\n var handlers = data.handlers[type]; // If no handlers exist, nothing to unbind\n\n if (!handlers) {\n return;\n } // If no listener was provided, remove all listeners for type\n\n\n if (!fn) {\n removeType(elem, type);\n return;\n } // We're only removing a single handler\n\n\n if (fn.guid) {\n for (var n = 0; n < handlers.length; n++) {\n if (handlers[n].guid === fn.guid) {\n handlers.splice(n--, 1);\n }\n }\n }\n\n _cleanUpEvents(elem, type);\n}\n/**\n * Trigger an event for an element\n *\n * @param {Element|Object} elem\n * Element to trigger an event on\n *\n * @param {EventTarget~Event|string} event\n * A string (the type) or an event object with a type attribute\n *\n * @param {Object} [hash]\n * data hash to pass along with the event\n *\n * @return {boolean|undefined}\n * Returns the opposite of `defaultPrevented` if default was\n * prevented. Otherwise, returns `undefined`\n */\n\nfunction trigger(elem, event, hash) {\n // Fetches element data and a reference to the parent (for bubbling).\n // Don't want to add a data object to cache for every parent,\n // so checking hasElData first.\n var elemData = hasData(elem) ? getData(elem) : {};\n var parent = elem.parentNode || elem.ownerDocument; // type = event.type || event,\n // handler;\n // If an event name was passed as a string, creates an event out of it\n\n if (typeof event === 'string') {\n event = {\n type: event,\n target: elem\n };\n } else if (!event.target) {\n event.target = elem;\n } // Normalizes the event properties.\n\n\n event = fixEvent(event); // If the passed element has a dispatcher, executes the established handlers.\n\n if (elemData.dispatcher) {\n elemData.dispatcher.call(elem, event, hash);\n } // Unless explicitly stopped or the event does not bubble (e.g. media events)\n // recursively calls this function to bubble the event up the DOM.\n\n\n if (parent && !event.isPropagationStopped() && event.bubbles === true) {\n trigger.call(null, parent, event, hash); // If at the top of the DOM, triggers the default action unless disabled.\n } else if (!parent && !event.defaultPrevented) {\n var targetData = getData(event.target); // Checks if the target has a default action for this event.\n\n if (event.target[event.type]) {\n // Temporarily disables event dispatching on the target as we have already executed the handler.\n targetData.disabled = true; // Executes the default action.\n\n if (typeof event.target[event.type] === 'function') {\n event.target[event.type]();\n } // Re-enables event dispatching.\n\n\n targetData.disabled = false;\n }\n } // Inform the triggerer if the default was prevented by returning false\n\n\n return !event.defaultPrevented;\n}\n/**\n * Trigger a listener only once for an event.\n *\n * @param {Element|Object} elem\n * Element or object to bind to.\n *\n * @param {string|string[]} type\n * Name/type of event\n *\n * @param {Event~EventListener} fn\n * Event listener function\n */\n\nfunction one(elem, type, fn) {\n if (Array.isArray(type)) {\n return _handleMultipleEvents(one, elem, type, fn);\n }\n\n var func = function func() {\n off(elem, type, func);\n fn.apply(this, arguments);\n }; // copy the guid to the new function so it can removed using the original function's ID\n\n\n func.guid = fn.guid = fn.guid || newGUID();\n on(elem, type, func);\n}\n\nvar Events = /*#__PURE__*/Object.freeze({\n fixEvent: fixEvent,\n on: on,\n off: off,\n trigger: trigger,\n one: one\n});\n\n/**\n * @file setup.js - Functions for setting up a player without\n * user interaction based on the data-setup `attribute` of the video tag.\n *\n * @module setup\n */\nvar _windowLoaded = false;\nvar videojs;\n/**\n * Set up any tags that have a data-setup `attribute` when the player is started.\n */\n\nvar autoSetup = function autoSetup() {\n // Protect against breakage in non-browser environments and check global autoSetup option.\n if (!isReal() || videojs.options.autoSetup === false) {\n return;\n }\n\n var vids = Array.prototype.slice.call(document.getElementsByTagName('video'));\n var audios = Array.prototype.slice.call(document.getElementsByTagName('audio'));\n var divs = Array.prototype.slice.call(document.getElementsByTagName('video-js'));\n var mediaEls = vids.concat(audios, divs); // Check if any media elements exist\n\n if (mediaEls && mediaEls.length > 0) {\n for (var i = 0, e = mediaEls.length; i < e; i++) {\n var mediaEl = mediaEls[i]; // Check if element exists, has getAttribute func.\n\n if (mediaEl && mediaEl.getAttribute) {\n // Make sure this player hasn't already been set up.\n if (mediaEl.player === undefined) {\n var options = mediaEl.getAttribute('data-setup'); // Check if data-setup attr exists.\n // We only auto-setup if they've added the data-setup attr.\n\n if (options !== null) {\n // Create new video.js instance.\n videojs(mediaEl);\n }\n } // If getAttribute isn't defined, we need to wait for the DOM.\n\n } else {\n autoSetupTimeout(1);\n break;\n }\n } // No videos were found, so keep looping unless page is finished loading.\n\n } else if (!_windowLoaded) {\n autoSetupTimeout(1);\n }\n};\n/**\n * Wait until the page is loaded before running autoSetup. This will be called in\n * autoSetup if `hasLoaded` returns false.\n *\n * @param {number} wait\n * How long to wait in ms\n *\n * @param {module:videojs} [vjs]\n * The videojs library function\n */\n\n\nfunction autoSetupTimeout(wait, vjs) {\n if (vjs) {\n videojs = vjs;\n }\n\n window$1.setTimeout(autoSetup, wait);\n}\n\nif (isReal() && document.readyState === 'complete') {\n _windowLoaded = true;\n} else {\n /**\n * Listen for the load event on window, and set _windowLoaded to true.\n *\n * @listens load\n */\n one(window$1, 'load', function () {\n _windowLoaded = true;\n });\n}\n\n/**\n * @file stylesheet.js\n * @module stylesheet\n */\n/**\n * Create a DOM syle element given a className for it.\n *\n * @param {string} className\n * The className to add to the created style element.\n *\n * @return {Element}\n * The element that was created.\n */\n\nvar createStyleElement = function createStyleElement(className) {\n var style = document.createElement('style');\n style.className = className;\n return style;\n};\n/**\n * Add text to a DOM element.\n *\n * @param {Element} el\n * The Element to add text content to.\n *\n * @param {string} content\n * The text to add to the element.\n */\n\nvar setTextContent = function setTextContent(el, content) {\n if (el.styleSheet) {\n el.styleSheet.cssText = content;\n } else {\n el.textContent = content;\n }\n};\n\n/**\n * @file fn.js\n * @module fn\n */\n/**\n * Bind (a.k.a proxy or context). A simple method for changing the context of\n * a function.\n *\n * It also stores a unique id on the function so it can be easily removed from\n * events.\n *\n * @function\n * @param {Mixed} context\n * The object to bind as scope.\n *\n * @param {Function} fn\n * The function to be bound to a scope.\n *\n * @param {number} [uid]\n * An optional unique ID for the function to be set\n *\n * @return {Function}\n * The new function that will be bound into the context given\n */\n\nvar bind = function bind(context, fn, uid) {\n // Make sure the function has a unique ID\n if (!fn.guid) {\n fn.guid = newGUID();\n } // Create the new function that changes the context\n\n\n var bound = function bound() {\n return fn.apply(context, arguments);\n }; // Allow for the ability to individualize this function\n // Needed in the case where multiple objects might share the same prototype\n // IF both items add an event listener with the same function, then you try to remove just one\n // it will remove both because they both have the same guid.\n // when using this, you need to use the bind method when you remove the listener as well.\n // currently used in text tracks\n\n\n bound.guid = uid ? uid + '_' + fn.guid : fn.guid;\n return bound;\n};\n/**\n * Wraps the given function, `fn`, with a new function that only invokes `fn`\n * at most once per every `wait` milliseconds.\n *\n * @function\n * @param {Function} fn\n * The function to be throttled.\n *\n * @param {Number} wait\n * The number of milliseconds by which to throttle.\n *\n * @return {Function}\n */\n\nvar throttle = function throttle(fn, wait) {\n var last = Date.now();\n\n var throttled = function throttled() {\n var now = Date.now();\n\n if (now - last >= wait) {\n fn.apply(void 0, arguments);\n last = now;\n }\n };\n\n return throttled;\n};\n/**\n * Creates a debounced function that delays invoking `func` until after `wait`\n * milliseconds have elapsed since the last time the debounced function was\n * invoked.\n *\n * Inspired by lodash and underscore implementations.\n *\n * @function\n * @param {Function} func\n * The function to wrap with debounce behavior.\n *\n * @param {number} wait\n * The number of milliseconds to wait after the last invocation.\n *\n * @param {boolean} [immediate]\n * Whether or not to invoke the function immediately upon creation.\n *\n * @param {Object} [context=window]\n * The \"context\" in which the debounced function should debounce. For\n * example, if this function should be tied to a Video.js player,\n * the player can be passed here. Alternatively, defaults to the\n * global `window` object.\n *\n * @return {Function}\n * A debounced function.\n */\n\nvar debounce = function debounce(func, wait, immediate, context) {\n if (context === void 0) {\n context = window$1;\n }\n\n var timeout;\n\n var cancel = function cancel() {\n context.clearTimeout(timeout);\n timeout = null;\n };\n /* eslint-disable consistent-this */\n\n\n var debounced = function debounced() {\n var self = this;\n var args = arguments;\n\n var _later = function later() {\n timeout = null;\n _later = null;\n\n if (!immediate) {\n func.apply(self, args);\n }\n };\n\n if (!timeout && immediate) {\n func.apply(self, args);\n }\n\n context.clearTimeout(timeout);\n timeout = context.setTimeout(_later, wait);\n };\n /* eslint-enable consistent-this */\n\n\n debounced.cancel = cancel;\n return debounced;\n};\n\n/**\n * @file src/js/event-target.js\n */\n/**\n * `EventTarget` is a class that can have the same API as the DOM `EventTarget`. It\n * adds shorthand functions that wrap around lengthy functions. For example:\n * the `on` function is a wrapper around `addEventListener`.\n *\n * @see [EventTarget Spec]{@link https://www.w3.org/TR/DOM-Level-2-Events/events.html#Events-EventTarget}\n * @class EventTarget\n */\n\nvar EventTarget = function EventTarget() {};\n/**\n * A Custom DOM event.\n *\n * @typedef {Object} EventTarget~Event\n * @see [Properties]{@link https://developer.mozilla.org/en-US/docs/Web/API/CustomEvent}\n */\n\n/**\n * All event listeners should follow the following format.\n *\n * @callback EventTarget~EventListener\n * @this {EventTarget}\n *\n * @param {EventTarget~Event} event\n * the event that triggered this function\n *\n * @param {Object} [hash]\n * hash of data sent during the event\n */\n\n/**\n * An object containing event names as keys and booleans as values.\n *\n * > NOTE: If an event name is set to a true value here {@link EventTarget#trigger}\n * will have extra functionality. See that function for more information.\n *\n * @property EventTarget.prototype.allowedEvents_\n * @private\n */\n\n\nEventTarget.prototype.allowedEvents_ = {};\n/**\n * Adds an `event listener` to an instance of an `EventTarget`. An `event listener` is a\n * function that will get called when an event with a certain name gets triggered.\n *\n * @param {string|string[]} type\n * An event name or an array of event names.\n *\n * @param {EventTarget~EventListener} fn\n * The function to call with `EventTarget`s\n */\n\nEventTarget.prototype.on = function (type, fn) {\n // Remove the addEventListener alias before calling Events.on\n // so we don't get into an infinite type loop\n var ael = this.addEventListener;\n\n this.addEventListener = function () {};\n\n on(this, type, fn);\n this.addEventListener = ael;\n};\n/**\n * An alias of {@link EventTarget#on}. Allows `EventTarget` to mimic\n * the standard DOM API.\n *\n * @function\n * @see {@link EventTarget#on}\n */\n\n\nEventTarget.prototype.addEventListener = EventTarget.prototype.on;\n/**\n * Removes an `event listener` for a specific event from an instance of `EventTarget`.\n * This makes it so that the `event listener` will no longer get called when the\n * named event happens.\n *\n * @param {string|string[]} type\n * An event name or an array of event names.\n *\n * @param {EventTarget~EventListener} fn\n * The function to remove.\n */\n\nEventTarget.prototype.off = function (type, fn) {\n off(this, type, fn);\n};\n/**\n * An alias of {@link EventTarget#off}. Allows `EventTarget` to mimic\n * the standard DOM API.\n *\n * @function\n * @see {@link EventTarget#off}\n */\n\n\nEventTarget.prototype.removeEventListener = EventTarget.prototype.off;\n/**\n * This function will add an `event listener` that gets triggered only once. After the\n * first trigger it will get removed. This is like adding an `event listener`\n * with {@link EventTarget#on} that calls {@link EventTarget#off} on itself.\n *\n * @param {string|string[]} type\n * An event name or an array of event names.\n *\n * @param {EventTarget~EventListener} fn\n * The function to be called once for each event name.\n */\n\nEventTarget.prototype.one = function (type, fn) {\n // Remove the addEventListener alialing Events.on\n // so we don't get into an infinite type loop\n var ael = this.addEventListener;\n\n this.addEventListener = function () {};\n\n one(this, type, fn);\n this.addEventListener = ael;\n};\n/**\n * This function causes an event to happen. This will then cause any `event listeners`\n * that are waiting for that event, to get called. If there are no `event listeners`\n * for an event then nothing will happen.\n *\n * If the name of the `Event` that is being triggered is in `EventTarget.allowedEvents_`.\n * Trigger will also call the `on` + `uppercaseEventName` function.\n *\n * Example:\n * 'click' is in `EventTarget.allowedEvents_`, so, trigger will attempt to call\n * `onClick` if it exists.\n *\n * @param {string|EventTarget~Event|Object} event\n * The name of the event, an `Event`, or an object with a key of type set to\n * an event name.\n */\n\n\nEventTarget.prototype.trigger = function (event) {\n var type = event.type || event;\n\n if (typeof event === 'string') {\n event = {\n type: type\n };\n }\n\n event = fixEvent(event);\n\n if (this.allowedEvents_[type] && this['on' + type]) {\n this['on' + type](event);\n }\n\n trigger(this, event);\n};\n/**\n * An alias of {@link EventTarget#trigger}. Allows `EventTarget` to mimic\n * the standard DOM API.\n *\n * @function\n * @see {@link EventTarget#trigger}\n */\n\n\nEventTarget.prototype.dispatchEvent = EventTarget.prototype.trigger;\nvar EVENT_MAP;\n\nEventTarget.prototype.queueTrigger = function (event) {\n var _this = this;\n\n // only set up EVENT_MAP if it'll be used\n if (!EVENT_MAP) {\n EVENT_MAP = new Map();\n }\n\n var type = event.type || event;\n var map = EVENT_MAP.get(this);\n\n if (!map) {\n map = new Map();\n EVENT_MAP.set(this, map);\n }\n\n var oldTimeout = map.get(type);\n map.delete(type);\n window$1.clearTimeout(oldTimeout);\n var timeout = window$1.setTimeout(function () {\n // if we cleared out all timeouts for the current target, delete its map\n if (map.size === 0) {\n map = null;\n EVENT_MAP.delete(_this);\n }\n\n _this.trigger(event);\n }, 0);\n map.set(type, timeout);\n};\n\n/**\n * @file mixins/evented.js\n * @module evented\n */\n/**\n * Returns whether or not an object has had the evented mixin applied.\n *\n * @param {Object} object\n * An object to test.\n *\n * @return {boolean}\n * Whether or not the object appears to be evented.\n */\n\nvar isEvented = function isEvented(object) {\n return object instanceof EventTarget || !!object.eventBusEl_ && ['on', 'one', 'off', 'trigger'].every(function (k) {\n return typeof object[k] === 'function';\n });\n};\n/**\n * Adds a callback to run after the evented mixin applied.\n *\n * @param {Object} object\n * An object to Add\n * @param {Function} callback\n * The callback to run.\n */\n\n\nvar addEventedCallback = function addEventedCallback(target, callback) {\n if (isEvented(target)) {\n callback();\n } else {\n if (!target.eventedCallbacks) {\n target.eventedCallbacks = [];\n }\n\n target.eventedCallbacks.push(callback);\n }\n};\n/**\n * Whether a value is a valid event type - non-empty string or array.\n *\n * @private\n * @param {string|Array} type\n * The type value to test.\n *\n * @return {boolean}\n * Whether or not the type is a valid event type.\n */\n\n\nvar isValidEventType = function isValidEventType(type) {\n return (// The regex here verifies that the `type` contains at least one non-\n // whitespace character.\n typeof type === 'string' && /\\S/.test(type) || Array.isArray(type) && !!type.length\n );\n};\n/**\n * Validates a value to determine if it is a valid event target. Throws if not.\n *\n * @private\n * @throws {Error}\n * If the target does not appear to be a valid event target.\n *\n * @param {Object} target\n * The object to test.\n */\n\n\nvar validateTarget = function validateTarget(target) {\n if (!target.nodeName && !isEvented(target)) {\n throw new Error('Invalid target; must be a DOM node or evented object.');\n }\n};\n/**\n * Validates a value to determine if it is a valid event target. Throws if not.\n *\n * @private\n * @throws {Error}\n * If the type does not appear to be a valid event type.\n *\n * @param {string|Array} type\n * The type to test.\n */\n\n\nvar validateEventType = function validateEventType(type) {\n if (!isValidEventType(type)) {\n throw new Error('Invalid event type; must be a non-empty string or array.');\n }\n};\n/**\n * Validates a value to determine if it is a valid listener. Throws if not.\n *\n * @private\n * @throws {Error}\n * If the listener is not a function.\n *\n * @param {Function} listener\n * The listener to test.\n */\n\n\nvar validateListener = function validateListener(listener) {\n if (typeof listener !== 'function') {\n throw new Error('Invalid listener; must be a function.');\n }\n};\n/**\n * Takes an array of arguments given to `on()` or `one()`, validates them, and\n * normalizes them into an object.\n *\n * @private\n * @param {Object} self\n * The evented object on which `on()` or `one()` was called. This\n * object will be bound as the `this` value for the listener.\n *\n * @param {Array} args\n * An array of arguments passed to `on()` or `one()`.\n *\n * @return {Object}\n * An object containing useful values for `on()` or `one()` calls.\n */\n\n\nvar normalizeListenArgs = function normalizeListenArgs(self, args) {\n // If the number of arguments is less than 3, the target is always the\n // evented object itself.\n var isTargetingSelf = args.length < 3 || args[0] === self || args[0] === self.eventBusEl_;\n var target;\n var type;\n var listener;\n\n if (isTargetingSelf) {\n target = self.eventBusEl_; // Deal with cases where we got 3 arguments, but we are still listening to\n // the evented object itself.\n\n if (args.length >= 3) {\n args.shift();\n }\n\n type = args[0];\n listener = args[1];\n } else {\n target = args[0];\n type = args[1];\n listener = args[2];\n }\n\n validateTarget(target);\n validateEventType(type);\n validateListener(listener);\n listener = bind(self, listener);\n return {\n isTargetingSelf: isTargetingSelf,\n target: target,\n type: type,\n listener: listener\n };\n};\n/**\n * Adds the listener to the event type(s) on the target, normalizing for\n * the type of target.\n *\n * @private\n * @param {Element|Object} target\n * A DOM node or evented object.\n *\n * @param {string} method\n * The event binding method to use (\"on\" or \"one\").\n *\n * @param {string|Array} type\n * One or more event type(s).\n *\n * @param {Function} listener\n * A listener function.\n */\n\n\nvar listen = function listen(target, method, type, listener) {\n validateTarget(target);\n\n if (target.nodeName) {\n Events[method](target, type, listener);\n } else {\n target[method](type, listener);\n }\n};\n/**\n * Contains methods that provide event capabilities to an object which is passed\n * to {@link module:evented|evented}.\n *\n * @mixin EventedMixin\n */\n\n\nvar EventedMixin = {\n /**\n * Add a listener to an event (or events) on this object or another evented\n * object.\n *\n * @param {string|Array|Element|Object} targetOrType\n * If this is a string or array, it represents the event type(s)\n * that will trigger the listener.\n *\n * Another evented object can be passed here instead, which will\n * cause the listener to listen for events on _that_ object.\n *\n * In either case, the listener's `this` value will be bound to\n * this object.\n *\n * @param {string|Array|Function} typeOrListener\n * If the first argument was a string or array, this should be the\n * listener function. Otherwise, this is a string or array of event\n * type(s).\n *\n * @param {Function} [listener]\n * If the first argument was another evented object, this will be\n * the listener function.\n */\n on: function on$$1() {\n var _this = this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var _normalizeListenArgs = normalizeListenArgs(this, args),\n isTargetingSelf = _normalizeListenArgs.isTargetingSelf,\n target = _normalizeListenArgs.target,\n type = _normalizeListenArgs.type,\n listener = _normalizeListenArgs.listener;\n\n listen(target, 'on', type, listener); // If this object is listening to another evented object.\n\n if (!isTargetingSelf) {\n // If this object is disposed, remove the listener.\n var removeListenerOnDispose = function removeListenerOnDispose() {\n return _this.off(target, type, listener);\n }; // Use the same function ID as the listener so we can remove it later it\n // using the ID of the original listener.\n\n\n removeListenerOnDispose.guid = listener.guid; // Add a listener to the target's dispose event as well. This ensures\n // that if the target is disposed BEFORE this object, we remove the\n // removal listener that was just added. Otherwise, we create a memory leak.\n\n var removeRemoverOnTargetDispose = function removeRemoverOnTargetDispose() {\n return _this.off('dispose', removeListenerOnDispose);\n }; // Use the same function ID as the listener so we can remove it later\n // it using the ID of the original listener.\n\n\n removeRemoverOnTargetDispose.guid = listener.guid;\n listen(this, 'on', 'dispose', removeListenerOnDispose);\n listen(target, 'on', 'dispose', removeRemoverOnTargetDispose);\n }\n },\n\n /**\n * Add a listener to an event (or events) on this object or another evented\n * object. The listener will only be called once and then removed.\n *\n * @param {string|Array|Element|Object} targetOrType\n * If this is a string or array, it represents the event type(s)\n * that will trigger the listener.\n *\n * Another evented object can be passed here instead, which will\n * cause the listener to listen for events on _that_ object.\n *\n * In either case, the listener's `this` value will be bound to\n * this object.\n *\n * @param {string|Array|Function} typeOrListener\n * If the first argument was a string or array, this should be the\n * listener function. Otherwise, this is a string or array of event\n * type(s).\n *\n * @param {Function} [listener]\n * If the first argument was another evented object, this will be\n * the listener function.\n */\n one: function one$$1() {\n var _this2 = this;\n\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n\n var _normalizeListenArgs2 = normalizeListenArgs(this, args),\n isTargetingSelf = _normalizeListenArgs2.isTargetingSelf,\n target = _normalizeListenArgs2.target,\n type = _normalizeListenArgs2.type,\n listener = _normalizeListenArgs2.listener; // Targeting this evented object.\n\n\n if (isTargetingSelf) {\n listen(target, 'one', type, listener); // Targeting another evented object.\n } else {\n var wrapper = function wrapper() {\n _this2.off(target, type, wrapper);\n\n for (var _len3 = arguments.length, largs = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {\n largs[_key3] = arguments[_key3];\n }\n\n listener.apply(null, largs);\n }; // Use the same function ID as the listener so we can remove it later\n // it using the ID of the original listener.\n\n\n wrapper.guid = listener.guid;\n listen(target, 'one', type, wrapper);\n }\n },\n\n /**\n * Removes listener(s) from event(s) on an evented object.\n *\n * @param {string|Array|Element|Object} [targetOrType]\n * If this is a string or array, it represents the event type(s).\n *\n * Another evented object can be passed here instead, in which case\n * ALL 3 arguments are _required_.\n *\n * @param {string|Array|Function} [typeOrListener]\n * If the first argument was a string or array, this may be the\n * listener function. Otherwise, this is a string or array of event\n * type(s).\n *\n * @param {Function} [listener]\n * If the first argument was another evented object, this will be\n * the listener function; otherwise, _all_ listeners bound to the\n * event type(s) will be removed.\n */\n off: function off$$1(targetOrType, typeOrListener, listener) {\n // Targeting this evented object.\n if (!targetOrType || isValidEventType(targetOrType)) {\n off(this.eventBusEl_, targetOrType, typeOrListener); // Targeting another evented object.\n } else {\n var target = targetOrType;\n var type = typeOrListener; // Fail fast and in a meaningful way!\n\n validateTarget(target);\n validateEventType(type);\n validateListener(listener); // Ensure there's at least a guid, even if the function hasn't been used\n\n listener = bind(this, listener); // Remove the dispose listener on this evented object, which was given\n // the same guid as the event listener in on().\n\n this.off('dispose', listener);\n\n if (target.nodeName) {\n off(target, type, listener);\n off(target, 'dispose', listener);\n } else if (isEvented(target)) {\n target.off(type, listener);\n target.off('dispose', listener);\n }\n }\n },\n\n /**\n * Fire an event on this evented object, causing its listeners to be called.\n *\n * @param {string|Object} event\n * An event type or an object with a type property.\n *\n * @param {Object} [hash]\n * An additional object to pass along to listeners.\n *\n * @return {boolean}\n * Whether or not the default behavior was prevented.\n */\n trigger: function trigger$$1(event, hash) {\n return trigger(this.eventBusEl_, event, hash);\n }\n};\n/**\n * Applies {@link module:evented~EventedMixin|EventedMixin} to a target object.\n *\n * @param {Object} target\n * The object to which to add event methods.\n *\n * @param {Object} [options={}]\n * Options for customizing the mixin behavior.\n *\n * @param {string} [options.eventBusKey]\n * By default, adds a `eventBusEl_` DOM element to the target object,\n * which is used as an event bus. If the target object already has a\n * DOM element that should be used, pass its key here.\n *\n * @return {Object}\n * The target object.\n */\n\nfunction evented(target, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n eventBusKey = _options.eventBusKey; // Set or create the eventBusEl_.\n\n if (eventBusKey) {\n if (!target[eventBusKey].nodeName) {\n throw new Error(\"The eventBusKey \\\"\" + eventBusKey + \"\\\" does not refer to an element.\");\n }\n\n target.eventBusEl_ = target[eventBusKey];\n } else {\n target.eventBusEl_ = createEl('span', {\n className: 'vjs-event-bus'\n });\n }\n\n assign(target, EventedMixin);\n\n if (target.eventedCallbacks) {\n target.eventedCallbacks.forEach(function (callback) {\n callback();\n });\n } // When any evented object is disposed, it removes all its listeners.\n\n\n target.on('dispose', function () {\n target.off();\n window$1.setTimeout(function () {\n target.eventBusEl_ = null;\n }, 0);\n });\n return target;\n}\n\n/**\n * @file mixins/stateful.js\n * @module stateful\n */\n/**\n * Contains methods that provide statefulness to an object which is passed\n * to {@link module:stateful}.\n *\n * @mixin StatefulMixin\n */\n\nvar StatefulMixin = {\n /**\n * A hash containing arbitrary keys and values representing the state of\n * the object.\n *\n * @type {Object}\n */\n state: {},\n\n /**\n * Set the state of an object by mutating its\n * {@link module:stateful~StatefulMixin.state|state} object in place.\n *\n * @fires module:stateful~StatefulMixin#statechanged\n * @param {Object|Function} stateUpdates\n * A new set of properties to shallow-merge into the plugin state.\n * Can be a plain object or a function returning a plain object.\n *\n * @return {Object|undefined}\n * An object containing changes that occurred. If no changes\n * occurred, returns `undefined`.\n */\n setState: function setState(stateUpdates) {\n var _this = this;\n\n // Support providing the `stateUpdates` state as a function.\n if (typeof stateUpdates === 'function') {\n stateUpdates = stateUpdates();\n }\n\n var changes;\n each(stateUpdates, function (value, key) {\n // Record the change if the value is different from what's in the\n // current state.\n if (_this.state[key] !== value) {\n changes = changes || {};\n changes[key] = {\n from: _this.state[key],\n to: value\n };\n }\n\n _this.state[key] = value;\n }); // Only trigger \"statechange\" if there were changes AND we have a trigger\n // function. This allows us to not require that the target object be an\n // evented object.\n\n if (changes && isEvented(this)) {\n /**\n * An event triggered on an object that is both\n * {@link module:stateful|stateful} and {@link module:evented|evented}\n * indicating that its state has changed.\n *\n * @event module:stateful~StatefulMixin#statechanged\n * @type {Object}\n * @property {Object} changes\n * A hash containing the properties that were changed and\n * the values they were changed `from` and `to`.\n */\n this.trigger({\n changes: changes,\n type: 'statechanged'\n });\n }\n\n return changes;\n }\n};\n/**\n * Applies {@link module:stateful~StatefulMixin|StatefulMixin} to a target\n * object.\n *\n * If the target object is {@link module:evented|evented} and has a\n * `handleStateChanged` method, that method will be automatically bound to the\n * `statechanged` event on itself.\n *\n * @param {Object} target\n * The object to be made stateful.\n *\n * @param {Object} [defaultState]\n * A default set of properties to populate the newly-stateful object's\n * `state` property.\n *\n * @return {Object}\n * Returns the `target`.\n */\n\nfunction stateful(target, defaultState) {\n assign(target, StatefulMixin); // This happens after the mixing-in because we need to replace the `state`\n // added in that step.\n\n target.state = assign({}, target.state, defaultState); // Auto-bind the `handleStateChanged` method of the target object if it exists.\n\n if (typeof target.handleStateChanged === 'function' && isEvented(target)) {\n target.on('statechanged', target.handleStateChanged);\n }\n\n return target;\n}\n\n/**\n * @file to-title-case.js\n * @module to-title-case\n */\n\n/**\n * Uppercase the first letter of a string.\n *\n * @param {string} string\n * String to be uppercased\n *\n * @return {string}\n * The string with an uppercased first letter\n */\nfunction toTitleCase(string) {\n if (typeof string !== 'string') {\n return string;\n }\n\n return string.charAt(0).toUpperCase() + string.slice(1);\n}\n/**\n * Compares the TitleCase versions of the two strings for equality.\n *\n * @param {string} str1\n * The first string to compare\n *\n * @param {string} str2\n * The second string to compare\n *\n * @return {boolean}\n * Whether the TitleCase versions of the strings are equal\n */\n\nfunction titleCaseEquals(str1, str2) {\n return toTitleCase(str1) === toTitleCase(str2);\n}\n\n/**\n * @file merge-options.js\n * @module merge-options\n */\n/**\n * Merge two objects recursively.\n *\n * Performs a deep merge like\n * {@link https://lodash.com/docs/4.17.10#merge|lodash.merge}, but only merges\n * plain objects (not arrays, elements, or anything else).\n *\n * Non-plain object values will be copied directly from the right-most\n * argument.\n *\n * @static\n * @param {Object[]} sources\n * One or more objects to merge into a new object.\n *\n * @return {Object}\n * A new object that is the merged result of all sources.\n */\n\nfunction mergeOptions() {\n var result = {};\n\n for (var _len = arguments.length, sources = new Array(_len), _key = 0; _key < _len; _key++) {\n sources[_key] = arguments[_key];\n }\n\n sources.forEach(function (source) {\n if (!source) {\n return;\n }\n\n each(source, function (value, key) {\n if (!isPlain(value)) {\n result[key] = value;\n return;\n }\n\n if (!isPlain(result[key])) {\n result[key] = {};\n }\n\n result[key] = mergeOptions(result[key], value);\n });\n });\n return result;\n}\n\n/**\n * Player Component - Base class for all UI objects\n *\n * @file component.js\n */\n/**\n * Base class for all UI Components.\n * Components are UI objects which represent both a javascript object and an element\n * in the DOM. They can be children of other components, and can have\n * children themselves.\n *\n * Components can also use methods from {@link EventTarget}\n */\n\nvar Component =\n/*#__PURE__*/\nfunction () {\n /**\n * A callback that is called when a component is ready. Does not have any\n * paramters and any callback value will be ignored.\n *\n * @callback Component~ReadyCallback\n * @this Component\n */\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n *\n * @param {Object[]} [options.children]\n * An array of children objects to intialize this component with. Children objects have\n * a name property that will be used if more than one component of the same type needs to be\n * added.\n *\n * @param {Component~ReadyCallback} [ready]\n * Function that gets called when the `Component` is ready.\n */\n function Component(player, options, ready) {\n // The component might be the player itself and we can't pass `this` to super\n if (!player && this.play) {\n this.player_ = player = this; // eslint-disable-line\n } else {\n this.player_ = player;\n } // Make a copy of prototype.options_ to protect against overriding defaults\n\n\n this.options_ = mergeOptions({}, this.options_); // Updated options with supplied options\n\n options = this.options_ = mergeOptions(this.options_, options); // Get ID from options or options element if one is supplied\n\n this.id_ = options.id || options.el && options.el.id; // If there was no ID from the options, generate one\n\n if (!this.id_) {\n // Don't require the player ID function in the case of mock players\n var id = player && player.id && player.id() || 'no_player';\n this.id_ = id + \"_component_\" + newGUID();\n }\n\n this.name_ = options.name || null; // Create element if one wasn't provided in options\n\n if (options.el) {\n this.el_ = options.el;\n } else if (options.createEl !== false) {\n this.el_ = this.createEl();\n } // if evented is anything except false, we want to mixin in evented\n\n\n if (options.evented !== false) {\n // Make this an evented object and use `el_`, if available, as its event bus\n evented(this, {\n eventBusKey: this.el_ ? 'el_' : null\n });\n }\n\n stateful(this, this.constructor.defaultState);\n this.children_ = [];\n this.childIndex_ = {};\n this.childNameIndex_ = {}; // Add any child components in options\n\n if (options.initChildren !== false) {\n this.initChildren();\n }\n\n this.ready(ready); // Don't want to trigger ready here or it will before init is actually\n // finished for all children that run this constructor\n\n if (options.reportTouchActivity !== false) {\n this.enableTouchActivity();\n }\n }\n /**\n * Dispose of the `Component` and all child components.\n *\n * @fires Component#dispose\n */\n\n\n var _proto = Component.prototype;\n\n _proto.dispose = function dispose() {\n /**\n * Triggered when a `Component` is disposed.\n *\n * @event Component#dispose\n * @type {EventTarget~Event}\n *\n * @property {boolean} [bubbles=false]\n * set to false so that the close event does not\n * bubble up\n */\n this.trigger({\n type: 'dispose',\n bubbles: false\n }); // Dispose all children.\n\n if (this.children_) {\n for (var i = this.children_.length - 1; i >= 0; i--) {\n if (this.children_[i].dispose) {\n this.children_[i].dispose();\n }\n }\n } // Delete child references\n\n\n this.children_ = null;\n this.childIndex_ = null;\n this.childNameIndex_ = null;\n\n if (this.el_) {\n // Remove element from DOM\n if (this.el_.parentNode) {\n this.el_.parentNode.removeChild(this.el_);\n }\n\n removeData(this.el_);\n this.el_ = null;\n } // remove reference to the player after disposing of the element\n\n\n this.player_ = null;\n };\n /**\n * Return the {@link Player} that the `Component` has attached to.\n *\n * @return {Player}\n * The player that this `Component` has attached to.\n */\n\n\n _proto.player = function player() {\n return this.player_;\n };\n /**\n * Deep merge of options objects with new options.\n * > Note: When both `obj` and `options` contain properties whose values are objects.\n * The two properties get merged using {@link module:mergeOptions}\n *\n * @param {Object} obj\n * The object that contains new options.\n *\n * @return {Object}\n * A new object of `this.options_` and `obj` merged together.\n *\n * @deprecated since version 5\n */\n\n\n _proto.options = function options(obj) {\n log.warn('this.options() has been deprecated and will be moved to the constructor in 6.0');\n\n if (!obj) {\n return this.options_;\n }\n\n this.options_ = mergeOptions(this.options_, obj);\n return this.options_;\n };\n /**\n * Get the `Component`s DOM element\n *\n * @return {Element}\n * The DOM element for this `Component`.\n */\n\n\n _proto.el = function el() {\n return this.el_;\n };\n /**\n * Create the `Component`s DOM element.\n *\n * @param {string} [tagName]\n * Element's DOM node type. e.g. 'div'\n *\n * @param {Object} [properties]\n * An object of properties that should be set.\n *\n * @param {Object} [attributes]\n * An object of attributes that should be set.\n *\n * @return {Element}\n * The element that gets created.\n */\n\n\n _proto.createEl = function createEl$$1(tagName, properties, attributes) {\n return createEl(tagName, properties, attributes);\n };\n /**\n * Localize a string given the string in english.\n *\n * If tokens are provided, it'll try and run a simple token replacement on the provided string.\n * The tokens it looks for look like `{1}` with the index being 1-indexed into the tokens array.\n *\n * If a `defaultValue` is provided, it'll use that over `string`,\n * if a value isn't found in provided language files.\n * This is useful if you want to have a descriptive key for token replacement\n * but have a succinct localized string and not require `en.json` to be included.\n *\n * Currently, it is used for the progress bar timing.\n * ```js\n * {\n * \"progress bar timing: currentTime={1} duration={2}\": \"{1} of {2}\"\n * }\n * ```\n * It is then used like so:\n * ```js\n * this.localize('progress bar timing: currentTime={1} duration{2}',\n * [this.player_.currentTime(), this.player_.duration()],\n * '{1} of {2}');\n * ```\n *\n * Which outputs something like: `01:23 of 24:56`.\n *\n *\n * @param {string} string\n * The string to localize and the key to lookup in the language files.\n * @param {string[]} [tokens]\n * If the current item has token replacements, provide the tokens here.\n * @param {string} [defaultValue]\n * Defaults to `string`. Can be a default value to use for token replacement\n * if the lookup key is needed to be separate.\n *\n * @return {string}\n * The localized string or if no localization exists the english string.\n */\n\n\n _proto.localize = function localize(string, tokens, defaultValue) {\n if (defaultValue === void 0) {\n defaultValue = string;\n }\n\n var code = this.player_.language && this.player_.language();\n var languages = this.player_.languages && this.player_.languages();\n var language = languages && languages[code];\n var primaryCode = code && code.split('-')[0];\n var primaryLang = languages && languages[primaryCode];\n var localizedString = defaultValue;\n\n if (language && language[string]) {\n localizedString = language[string];\n } else if (primaryLang && primaryLang[string]) {\n localizedString = primaryLang[string];\n }\n\n if (tokens) {\n localizedString = localizedString.replace(/\\{(\\d+)\\}/g, function (match, index) {\n var value = tokens[index - 1];\n var ret = value;\n\n if (typeof value === 'undefined') {\n ret = match;\n }\n\n return ret;\n });\n }\n\n return localizedString;\n };\n /**\n * Return the `Component`s DOM element. This is where children get inserted.\n * This will usually be the the same as the element returned in {@link Component#el}.\n *\n * @return {Element}\n * The content element for this `Component`.\n */\n\n\n _proto.contentEl = function contentEl() {\n return this.contentEl_ || this.el_;\n };\n /**\n * Get this `Component`s ID\n *\n * @return {string}\n * The id of this `Component`\n */\n\n\n _proto.id = function id() {\n return this.id_;\n };\n /**\n * Get the `Component`s name. The name gets used to reference the `Component`\n * and is set during registration.\n *\n * @return {string}\n * The name of this `Component`.\n */\n\n\n _proto.name = function name() {\n return this.name_;\n };\n /**\n * Get an array of all child components\n *\n * @return {Array}\n * The children\n */\n\n\n _proto.children = function children() {\n return this.children_;\n };\n /**\n * Returns the child `Component` with the given `id`.\n *\n * @param {string} id\n * The id of the child `Component` to get.\n *\n * @return {Component|undefined}\n * The child `Component` with the given `id` or undefined.\n */\n\n\n _proto.getChildById = function getChildById(id) {\n return this.childIndex_[id];\n };\n /**\n * Returns the child `Component` with the given `name`.\n *\n * @param {string} name\n * The name of the child `Component` to get.\n *\n * @return {Component|undefined}\n * The child `Component` with the given `name` or undefined.\n */\n\n\n _proto.getChild = function getChild(name) {\n if (!name) {\n return;\n }\n\n name = toTitleCase(name);\n return this.childNameIndex_[name];\n };\n /**\n * Add a child `Component` inside the current `Component`.\n *\n *\n * @param {string|Component} child\n * The name or instance of a child to add.\n *\n * @param {Object} [options={}]\n * The key/value store of options that will get passed to children of\n * the child.\n *\n * @param {number} [index=this.children_.length]\n * The index to attempt to add a child into.\n *\n * @return {Component}\n * The `Component` that gets added as a child. When using a string the\n * `Component` will get created by this process.\n */\n\n\n _proto.addChild = function addChild(child, options, index) {\n if (options === void 0) {\n options = {};\n }\n\n if (index === void 0) {\n index = this.children_.length;\n }\n\n var component;\n var componentName; // If child is a string, create component with options\n\n if (typeof child === 'string') {\n componentName = toTitleCase(child);\n var componentClassName = options.componentClass || componentName; // Set name through options\n\n options.name = componentName; // Create a new object & element for this controls set\n // If there's no .player_, this is a player\n\n var ComponentClass = Component.getComponent(componentClassName);\n\n if (!ComponentClass) {\n throw new Error(\"Component \" + componentClassName + \" does not exist\");\n } // data stored directly on the videojs object may be\n // misidentified as a component to retain\n // backwards-compatibility with 4.x. check to make sure the\n // component class can be instantiated.\n\n\n if (typeof ComponentClass !== 'function') {\n return null;\n }\n\n component = new ComponentClass(this.player_ || this, options); // child is a component instance\n } else {\n component = child;\n }\n\n this.children_.splice(index, 0, component);\n\n if (typeof component.id === 'function') {\n this.childIndex_[component.id()] = component;\n } // If a name wasn't used to create the component, check if we can use the\n // name function of the component\n\n\n componentName = componentName || component.name && toTitleCase(component.name());\n\n if (componentName) {\n this.childNameIndex_[componentName] = component;\n } // Add the UI object's element to the container div (box)\n // Having an element is not required\n\n\n if (typeof component.el === 'function' && component.el()) {\n var childNodes = this.contentEl().children;\n var refNode = childNodes[index] || null;\n this.contentEl().insertBefore(component.el(), refNode);\n } // Return so it can stored on parent object if desired.\n\n\n return component;\n };\n /**\n * Remove a child `Component` from this `Component`s list of children. Also removes\n * the child `Component`s element from this `Component`s element.\n *\n * @param {Component} component\n * The child `Component` to remove.\n */\n\n\n _proto.removeChild = function removeChild(component) {\n if (typeof component === 'string') {\n component = this.getChild(component);\n }\n\n if (!component || !this.children_) {\n return;\n }\n\n var childFound = false;\n\n for (var i = this.children_.length - 1; i >= 0; i--) {\n if (this.children_[i] === component) {\n childFound = true;\n this.children_.splice(i, 1);\n break;\n }\n }\n\n if (!childFound) {\n return;\n }\n\n this.childIndex_[component.id()] = null;\n this.childNameIndex_[component.name()] = null;\n var compEl = component.el();\n\n if (compEl && compEl.parentNode === this.contentEl()) {\n this.contentEl().removeChild(component.el());\n }\n };\n /**\n * Add and initialize default child `Component`s based upon options.\n */\n\n\n _proto.initChildren = function initChildren() {\n var _this = this;\n\n var children = this.options_.children;\n\n if (children) {\n // `this` is `parent`\n var parentOptions = this.options_;\n\n var handleAdd = function handleAdd(child) {\n var name = child.name;\n var opts = child.opts; // Allow options for children to be set at the parent options\n // e.g. videojs(id, { controlBar: false });\n // instead of videojs(id, { children: { controlBar: false });\n\n if (parentOptions[name] !== undefined) {\n opts = parentOptions[name];\n } // Allow for disabling default components\n // e.g. options['children']['posterImage'] = false\n\n\n if (opts === false) {\n return;\n } // Allow options to be passed as a simple boolean if no configuration\n // is necessary.\n\n\n if (opts === true) {\n opts = {};\n } // We also want to pass the original player options\n // to each component as well so they don't need to\n // reach back into the player for options later.\n\n\n opts.playerOptions = _this.options_.playerOptions; // Create and add the child component.\n // Add a direct reference to the child by name on the parent instance.\n // If two of the same component are used, different names should be supplied\n // for each\n\n var newChild = _this.addChild(name, opts);\n\n if (newChild) {\n _this[name] = newChild;\n }\n }; // Allow for an array of children details to passed in the options\n\n\n var workingChildren;\n var Tech = Component.getComponent('Tech');\n\n if (Array.isArray(children)) {\n workingChildren = children;\n } else {\n workingChildren = Object.keys(children);\n }\n\n workingChildren // children that are in this.options_ but also in workingChildren would\n // give us extra children we do not want. So, we want to filter them out.\n .concat(Object.keys(this.options_).filter(function (child) {\n return !workingChildren.some(function (wchild) {\n if (typeof wchild === 'string') {\n return child === wchild;\n }\n\n return child === wchild.name;\n });\n })).map(function (child) {\n var name;\n var opts;\n\n if (typeof child === 'string') {\n name = child;\n opts = children[name] || _this.options_[name] || {};\n } else {\n name = child.name;\n opts = child;\n }\n\n return {\n name: name,\n opts: opts\n };\n }).filter(function (child) {\n // we have to make sure that child.name isn't in the techOrder since\n // techs are registerd as Components but can't aren't compatible\n // See https://github.com/videojs/video.js/issues/2772\n var c = Component.getComponent(child.opts.componentClass || toTitleCase(child.name));\n return c && !Tech.isTech(c);\n }).forEach(handleAdd);\n }\n };\n /**\n * Builds the default DOM class name. Should be overriden by sub-components.\n *\n * @return {string}\n * The DOM class name for this object.\n *\n * @abstract\n */\n\n\n _proto.buildCSSClass = function buildCSSClass() {\n // Child classes can include a function that does:\n // return 'CLASS NAME' + this._super();\n return '';\n };\n /**\n * Bind a listener to the component's ready state.\n * Different from event listeners in that if the ready event has already happened\n * it will trigger the function immediately.\n *\n * @return {Component}\n * Returns itself; method can be chained.\n */\n\n\n _proto.ready = function ready(fn, sync) {\n if (sync === void 0) {\n sync = false;\n }\n\n if (!fn) {\n return;\n }\n\n if (!this.isReady_) {\n this.readyQueue_ = this.readyQueue_ || [];\n this.readyQueue_.push(fn);\n return;\n }\n\n if (sync) {\n fn.call(this);\n } else {\n // Call the function asynchronously by default for consistency\n this.setTimeout(fn, 1);\n }\n };\n /**\n * Trigger all the ready listeners for this `Component`.\n *\n * @fires Component#ready\n */\n\n\n _proto.triggerReady = function triggerReady() {\n this.isReady_ = true; // Ensure ready is triggered asynchronously\n\n this.setTimeout(function () {\n var readyQueue = this.readyQueue_; // Reset Ready Queue\n\n this.readyQueue_ = [];\n\n if (readyQueue && readyQueue.length > 0) {\n readyQueue.forEach(function (fn) {\n fn.call(this);\n }, this);\n } // Allow for using event listeners also\n\n /**\n * Triggered when a `Component` is ready.\n *\n * @event Component#ready\n * @type {EventTarget~Event}\n */\n\n\n this.trigger('ready');\n }, 1);\n };\n /**\n * Find a single DOM element matching a `selector`. This can be within the `Component`s\n * `contentEl()` or another custom context.\n *\n * @param {string} selector\n * A valid CSS selector, which will be passed to `querySelector`.\n *\n * @param {Element|string} [context=this.contentEl()]\n * A DOM element within which to query. Can also be a selector string in\n * which case the first matching element will get used as context. If\n * missing `this.contentEl()` gets used. If `this.contentEl()` returns\n * nothing it falls back to `document`.\n *\n * @return {Element|null}\n * the dom element that was found, or null\n *\n * @see [Information on CSS Selectors](https://developer.mozilla.org/en-US/docs/Web/Guide/CSS/Getting_Started/Selectors)\n */\n\n\n _proto.$ = function $$$1(selector, context) {\n return $(selector, context || this.contentEl());\n };\n /**\n * Finds all DOM element matching a `selector`. This can be within the `Component`s\n * `contentEl()` or another custom context.\n *\n * @param {string} selector\n * A valid CSS selector, which will be passed to `querySelectorAll`.\n *\n * @param {Element|string} [context=this.contentEl()]\n * A DOM element within which to query. Can also be a selector string in\n * which case the first matching element will get used as context. If\n * missing `this.contentEl()` gets used. If `this.contentEl()` returns\n * nothing it falls back to `document`.\n *\n * @return {NodeList}\n * a list of dom elements that were found\n *\n * @see [Information on CSS Selectors](https://developer.mozilla.org/en-US/docs/Web/Guide/CSS/Getting_Started/Selectors)\n */\n\n\n _proto.$$ = function $$$$1(selector, context) {\n return $$(selector, context || this.contentEl());\n };\n /**\n * Check if a component's element has a CSS class name.\n *\n * @param {string} classToCheck\n * CSS class name to check.\n *\n * @return {boolean}\n * - True if the `Component` has the class.\n * - False if the `Component` does not have the class`\n */\n\n\n _proto.hasClass = function hasClass$$1(classToCheck) {\n return hasClass(this.el_, classToCheck);\n };\n /**\n * Add a CSS class name to the `Component`s element.\n *\n * @param {string} classToAdd\n * CSS class name to add\n */\n\n\n _proto.addClass = function addClass$$1(classToAdd) {\n addClass(this.el_, classToAdd);\n };\n /**\n * Remove a CSS class name from the `Component`s element.\n *\n * @param {string} classToRemove\n * CSS class name to remove\n */\n\n\n _proto.removeClass = function removeClass$$1(classToRemove) {\n removeClass(this.el_, classToRemove);\n };\n /**\n * Add or remove a CSS class name from the component's element.\n * - `classToToggle` gets added when {@link Component#hasClass} would return false.\n * - `classToToggle` gets removed when {@link Component#hasClass} would return true.\n *\n * @param {string} classToToggle\n * The class to add or remove based on (@link Component#hasClass}\n *\n * @param {boolean|Dom~predicate} [predicate]\n * An {@link Dom~predicate} function or a boolean\n */\n\n\n _proto.toggleClass = function toggleClass$$1(classToToggle, predicate) {\n toggleClass(this.el_, classToToggle, predicate);\n };\n /**\n * Show the `Component`s element if it is hidden by removing the\n * 'vjs-hidden' class name from it.\n */\n\n\n _proto.show = function show() {\n this.removeClass('vjs-hidden');\n };\n /**\n * Hide the `Component`s element if it is currently showing by adding the\n * 'vjs-hidden` class name to it.\n */\n\n\n _proto.hide = function hide() {\n this.addClass('vjs-hidden');\n };\n /**\n * Lock a `Component`s element in its visible state by adding the 'vjs-lock-showing'\n * class name to it. Used during fadeIn/fadeOut.\n *\n * @private\n */\n\n\n _proto.lockShowing = function lockShowing() {\n this.addClass('vjs-lock-showing');\n };\n /**\n * Unlock a `Component`s element from its visible state by removing the 'vjs-lock-showing'\n * class name from it. Used during fadeIn/fadeOut.\n *\n * @private\n */\n\n\n _proto.unlockShowing = function unlockShowing() {\n this.removeClass('vjs-lock-showing');\n };\n /**\n * Get the value of an attribute on the `Component`s element.\n *\n * @param {string} attribute\n * Name of the attribute to get the value from.\n *\n * @return {string|null}\n * - The value of the attribute that was asked for.\n * - Can be an empty string on some browsers if the attribute does not exist\n * or has no value\n * - Most browsers will return null if the attibute does not exist or has\n * no value.\n *\n * @see [DOM API]{@link https://developer.mozilla.org/en-US/docs/Web/API/Element/getAttribute}\n */\n\n\n _proto.getAttribute = function getAttribute$$1(attribute) {\n return getAttribute(this.el_, attribute);\n };\n /**\n * Set the value of an attribute on the `Component`'s element\n *\n * @param {string} attribute\n * Name of the attribute to set.\n *\n * @param {string} value\n * Value to set the attribute to.\n *\n * @see [DOM API]{@link https://developer.mozilla.org/en-US/docs/Web/API/Element/setAttribute}\n */\n\n\n _proto.setAttribute = function setAttribute$$1(attribute, value) {\n setAttribute(this.el_, attribute, value);\n };\n /**\n * Remove an attribute from the `Component`s element.\n *\n * @param {string} attribute\n * Name of the attribute to remove.\n *\n * @see [DOM API]{@link https://developer.mozilla.org/en-US/docs/Web/API/Element/removeAttribute}\n */\n\n\n _proto.removeAttribute = function removeAttribute$$1(attribute) {\n removeAttribute(this.el_, attribute);\n };\n /**\n * Get or set the width of the component based upon the CSS styles.\n * See {@link Component#dimension} for more detailed information.\n *\n * @param {number|string} [num]\n * The width that you want to set postfixed with '%', 'px' or nothing.\n *\n * @param {boolean} [skipListeners]\n * Skip the componentresize event trigger\n *\n * @return {number|string}\n * The width when getting, zero if there is no width. Can be a string\n * postpixed with '%' or 'px'.\n */\n\n\n _proto.width = function width(num, skipListeners) {\n return this.dimension('width', num, skipListeners);\n };\n /**\n * Get or set the height of the component based upon the CSS styles.\n * See {@link Component#dimension} for more detailed information.\n *\n * @param {number|string} [num]\n * The height that you want to set postfixed with '%', 'px' or nothing.\n *\n * @param {boolean} [skipListeners]\n * Skip the componentresize event trigger\n *\n * @return {number|string}\n * The width when getting, zero if there is no width. Can be a string\n * postpixed with '%' or 'px'.\n */\n\n\n _proto.height = function height(num, skipListeners) {\n return this.dimension('height', num, skipListeners);\n };\n /**\n * Set both the width and height of the `Component` element at the same time.\n *\n * @param {number|string} width\n * Width to set the `Component`s element to.\n *\n * @param {number|string} height\n * Height to set the `Component`s element to.\n */\n\n\n _proto.dimensions = function dimensions(width, height) {\n // Skip componentresize listeners on width for optimization\n this.width(width, true);\n this.height(height);\n };\n /**\n * Get or set width or height of the `Component` element. This is the shared code\n * for the {@link Component#width} and {@link Component#height}.\n *\n * Things to know:\n * - If the width or height in an number this will return the number postfixed with 'px'.\n * - If the width/height is a percent this will return the percent postfixed with '%'\n * - Hidden elements have a width of 0 with `window.getComputedStyle`. This function\n * defaults to the `Component`s `style.width` and falls back to `window.getComputedStyle`.\n * See [this]{@link http://www.foliotek.com/devblog/getting-the-width-of-a-hidden-element-with-jquery-using-width/}\n * for more information\n * - If you want the computed style of the component, use {@link Component#currentWidth}\n * and {@link {Component#currentHeight}\n *\n * @fires Component#componentresize\n *\n * @param {string} widthOrHeight\n 8 'width' or 'height'\n *\n * @param {number|string} [num]\n 8 New dimension\n *\n * @param {boolean} [skipListeners]\n * Skip componentresize event trigger\n *\n * @return {number}\n * The dimension when getting or 0 if unset\n */\n\n\n _proto.dimension = function dimension(widthOrHeight, num, skipListeners) {\n if (num !== undefined) {\n // Set to zero if null or literally NaN (NaN !== NaN)\n if (num === null || num !== num) {\n num = 0;\n } // Check if using css width/height (% or px) and adjust\n\n\n if (('' + num).indexOf('%') !== -1 || ('' + num).indexOf('px') !== -1) {\n this.el_.style[widthOrHeight] = num;\n } else if (num === 'auto') {\n this.el_.style[widthOrHeight] = '';\n } else {\n this.el_.style[widthOrHeight] = num + 'px';\n } // skipListeners allows us to avoid triggering the resize event when setting both width and height\n\n\n if (!skipListeners) {\n /**\n * Triggered when a component is resized.\n *\n * @event Component#componentresize\n * @type {EventTarget~Event}\n */\n this.trigger('componentresize');\n }\n\n return;\n } // Not setting a value, so getting it\n // Make sure element exists\n\n\n if (!this.el_) {\n return 0;\n } // Get dimension value from style\n\n\n var val = this.el_.style[widthOrHeight];\n var pxIndex = val.indexOf('px');\n\n if (pxIndex !== -1) {\n // Return the pixel value with no 'px'\n return parseInt(val.slice(0, pxIndex), 10);\n } // No px so using % or no style was set, so falling back to offsetWidth/height\n // If component has display:none, offset will return 0\n // TODO: handle display:none and no dimension style using px\n\n\n return parseInt(this.el_['offset' + toTitleCase(widthOrHeight)], 10);\n };\n /**\n * Get the computed width or the height of the component's element.\n *\n * Uses `window.getComputedStyle`.\n *\n * @param {string} widthOrHeight\n * A string containing 'width' or 'height'. Whichever one you want to get.\n *\n * @return {number}\n * The dimension that gets asked for or 0 if nothing was set\n * for that dimension.\n */\n\n\n _proto.currentDimension = function currentDimension(widthOrHeight) {\n var computedWidthOrHeight = 0;\n\n if (widthOrHeight !== 'width' && widthOrHeight !== 'height') {\n throw new Error('currentDimension only accepts width or height value');\n }\n\n if (typeof window$1.getComputedStyle === 'function') {\n var computedStyle = window$1.getComputedStyle(this.el_);\n computedWidthOrHeight = computedStyle.getPropertyValue(widthOrHeight) || computedStyle[widthOrHeight];\n } // remove 'px' from variable and parse as integer\n\n\n computedWidthOrHeight = parseFloat(computedWidthOrHeight); // if the computed value is still 0, it's possible that the browser is lying\n // and we want to check the offset values.\n // This code also runs wherever getComputedStyle doesn't exist.\n\n if (computedWidthOrHeight === 0) {\n var rule = \"offset\" + toTitleCase(widthOrHeight);\n computedWidthOrHeight = this.el_[rule];\n }\n\n return computedWidthOrHeight;\n };\n /**\n * An object that contains width and height values of the `Component`s\n * computed style. Uses `window.getComputedStyle`.\n *\n * @typedef {Object} Component~DimensionObject\n *\n * @property {number} width\n * The width of the `Component`s computed style.\n *\n * @property {number} height\n * The height of the `Component`s computed style.\n */\n\n /**\n * Get an object that contains computed width and height values of the\n * component's element.\n *\n * Uses `window.getComputedStyle`.\n *\n * @return {Component~DimensionObject}\n * The computed dimensions of the component's element.\n */\n\n\n _proto.currentDimensions = function currentDimensions() {\n return {\n width: this.currentDimension('width'),\n height: this.currentDimension('height')\n };\n };\n /**\n * Get the computed width of the component's element.\n *\n * Uses `window.getComputedStyle`.\n *\n * @return {number}\n * The computed width of the component's element.\n */\n\n\n _proto.currentWidth = function currentWidth() {\n return this.currentDimension('width');\n };\n /**\n * Get the computed height of the component's element.\n *\n * Uses `window.getComputedStyle`.\n *\n * @return {number}\n * The computed height of the component's element.\n */\n\n\n _proto.currentHeight = function currentHeight() {\n return this.currentDimension('height');\n };\n /**\n * Set the focus to this component\n */\n\n\n _proto.focus = function focus() {\n this.el_.focus();\n };\n /**\n * Remove the focus from this component\n */\n\n\n _proto.blur = function blur() {\n this.el_.blur();\n };\n /**\n * Emit a 'tap' events when touch event support gets detected. This gets used to\n * support toggling the controls through a tap on the video. They get enabled\n * because every sub-component would have extra overhead otherwise.\n *\n * @private\n * @fires Component#tap\n * @listens Component#touchstart\n * @listens Component#touchmove\n * @listens Component#touchleave\n * @listens Component#touchcancel\n * @listens Component#touchend\n */\n\n\n _proto.emitTapEvents = function emitTapEvents() {\n // Track the start time so we can determine how long the touch lasted\n var touchStart = 0;\n var firstTouch = null; // Maximum movement allowed during a touch event to still be considered a tap\n // Other popular libs use anywhere from 2 (hammer.js) to 15,\n // so 10 seems like a nice, round number.\n\n var tapMovementThreshold = 10; // The maximum length a touch can be while still being considered a tap\n\n var touchTimeThreshold = 200;\n var couldBeTap;\n this.on('touchstart', function (event) {\n // If more than one finger, don't consider treating this as a click\n if (event.touches.length === 1) {\n // Copy pageX/pageY from the object\n firstTouch = {\n pageX: event.touches[0].pageX,\n pageY: event.touches[0].pageY\n }; // Record start time so we can detect a tap vs. \"touch and hold\"\n\n touchStart = new Date().getTime(); // Reset couldBeTap tracking\n\n couldBeTap = true;\n }\n });\n this.on('touchmove', function (event) {\n // If more than one finger, don't consider treating this as a click\n if (event.touches.length > 1) {\n couldBeTap = false;\n } else if (firstTouch) {\n // Some devices will throw touchmoves for all but the slightest of taps.\n // So, if we moved only a small distance, this could still be a tap\n var xdiff = event.touches[0].pageX - firstTouch.pageX;\n var ydiff = event.touches[0].pageY - firstTouch.pageY;\n var touchDistance = Math.sqrt(xdiff * xdiff + ydiff * ydiff);\n\n if (touchDistance > tapMovementThreshold) {\n couldBeTap = false;\n }\n }\n });\n\n var noTap = function noTap() {\n couldBeTap = false;\n }; // TODO: Listen to the original target. http://youtu.be/DujfpXOKUp8?t=13m8s\n\n\n this.on('touchleave', noTap);\n this.on('touchcancel', noTap); // When the touch ends, measure how long it took and trigger the appropriate\n // event\n\n this.on('touchend', function (event) {\n firstTouch = null; // Proceed only if the touchmove/leave/cancel event didn't happen\n\n if (couldBeTap === true) {\n // Measure how long the touch lasted\n var touchTime = new Date().getTime() - touchStart; // Make sure the touch was less than the threshold to be considered a tap\n\n if (touchTime < touchTimeThreshold) {\n // Don't let browser turn this into a click\n event.preventDefault();\n /**\n * Triggered when a `Component` is tapped.\n *\n * @event Component#tap\n * @type {EventTarget~Event}\n */\n\n this.trigger('tap'); // It may be good to copy the touchend event object and change the\n // type to tap, if the other event properties aren't exact after\n // Events.fixEvent runs (e.g. event.target)\n }\n }\n });\n };\n /**\n * This function reports user activity whenever touch events happen. This can get\n * turned off by any sub-components that wants touch events to act another way.\n *\n * Report user touch activity when touch events occur. User activity gets used to\n * determine when controls should show/hide. It is simple when it comes to mouse\n * events, because any mouse event should show the controls. So we capture mouse\n * events that bubble up to the player and report activity when that happens.\n * With touch events it isn't as easy as `touchstart` and `touchend` toggle player\n * controls. So touch events can't help us at the player level either.\n *\n * User activity gets checked asynchronously. So what could happen is a tap event\n * on the video turns the controls off. Then the `touchend` event bubbles up to\n * the player. Which, if it reported user activity, would turn the controls right\n * back on. We also don't want to completely block touch events from bubbling up.\n * Furthermore a `touchmove` event and anything other than a tap, should not turn\n * controls back on.\n *\n * @listens Component#touchstart\n * @listens Component#touchmove\n * @listens Component#touchend\n * @listens Component#touchcancel\n */\n\n\n _proto.enableTouchActivity = function enableTouchActivity() {\n // Don't continue if the root player doesn't support reporting user activity\n if (!this.player() || !this.player().reportUserActivity) {\n return;\n } // listener for reporting that the user is active\n\n\n var report = bind(this.player(), this.player().reportUserActivity);\n var touchHolding;\n this.on('touchstart', function () {\n report(); // For as long as the they are touching the device or have their mouse down,\n // we consider them active even if they're not moving their finger or mouse.\n // So we want to continue to update that they are active\n\n this.clearInterval(touchHolding); // report at the same interval as activityCheck\n\n touchHolding = this.setInterval(report, 250);\n });\n\n var touchEnd = function touchEnd(event) {\n report(); // stop the interval that maintains activity if the touch is holding\n\n this.clearInterval(touchHolding);\n };\n\n this.on('touchmove', report);\n this.on('touchend', touchEnd);\n this.on('touchcancel', touchEnd);\n };\n /**\n * A callback that has no parameters and is bound into `Component`s context.\n *\n * @callback Component~GenericCallback\n * @this Component\n */\n\n /**\n * Creates a function that runs after an `x` millisecond timeout. This function is a\n * wrapper around `window.setTimeout`. There are a few reasons to use this one\n * instead though:\n * 1. It gets cleared via {@link Component#clearTimeout} when\n * {@link Component#dispose} gets called.\n * 2. The function callback will gets turned into a {@link Component~GenericCallback}\n *\n * > Note: You can't use `window.clearTimeout` on the id returned by this function. This\n * will cause its dispose listener not to get cleaned up! Please use\n * {@link Component#clearTimeout} or {@link Component#dispose} instead.\n *\n * @param {Component~GenericCallback} fn\n * The function that will be run after `timeout`.\n *\n * @param {number} timeout\n * Timeout in milliseconds to delay before executing the specified function.\n *\n * @return {number}\n * Returns a timeout ID that gets used to identify the timeout. It can also\n * get used in {@link Component#clearTimeout} to clear the timeout that\n * was set.\n *\n * @listens Component#dispose\n * @see [Similar to]{@link https://developer.mozilla.org/en-US/docs/Web/API/WindowTimers/setTimeout}\n */\n\n\n _proto.setTimeout = function setTimeout(fn, timeout) {\n var _this2 = this;\n\n // declare as variables so they are properly available in timeout function\n // eslint-disable-next-line\n var timeoutId, disposeFn;\n fn = bind(this, fn);\n timeoutId = window$1.setTimeout(function () {\n _this2.off('dispose', disposeFn);\n\n fn();\n }, timeout);\n\n disposeFn = function disposeFn() {\n return _this2.clearTimeout(timeoutId);\n };\n\n disposeFn.guid = \"vjs-timeout-\" + timeoutId;\n this.on('dispose', disposeFn);\n return timeoutId;\n };\n /**\n * Clears a timeout that gets created via `window.setTimeout` or\n * {@link Component#setTimeout}. If you set a timeout via {@link Component#setTimeout}\n * use this function instead of `window.clearTimout`. If you don't your dispose\n * listener will not get cleaned up until {@link Component#dispose}!\n *\n * @param {number} timeoutId\n * The id of the timeout to clear. The return value of\n * {@link Component#setTimeout} or `window.setTimeout`.\n *\n * @return {number}\n * Returns the timeout id that was cleared.\n *\n * @see [Similar to]{@link https://developer.mozilla.org/en-US/docs/Web/API/WindowTimers/clearTimeout}\n */\n\n\n _proto.clearTimeout = function clearTimeout(timeoutId) {\n window$1.clearTimeout(timeoutId);\n\n var disposeFn = function disposeFn() {};\n\n disposeFn.guid = \"vjs-timeout-\" + timeoutId;\n this.off('dispose', disposeFn);\n return timeoutId;\n };\n /**\n * Creates a function that gets run every `x` milliseconds. This function is a wrapper\n * around `window.setInterval`. There are a few reasons to use this one instead though.\n * 1. It gets cleared via {@link Component#clearInterval} when\n * {@link Component#dispose} gets called.\n * 2. The function callback will be a {@link Component~GenericCallback}\n *\n * @param {Component~GenericCallback} fn\n * The function to run every `x` seconds.\n *\n * @param {number} interval\n * Execute the specified function every `x` milliseconds.\n *\n * @return {number}\n * Returns an id that can be used to identify the interval. It can also be be used in\n * {@link Component#clearInterval} to clear the interval.\n *\n * @listens Component#dispose\n * @see [Similar to]{@link https://developer.mozilla.org/en-US/docs/Web/API/WindowTimers/setInterval}\n */\n\n\n _proto.setInterval = function setInterval(fn, interval) {\n var _this3 = this;\n\n fn = bind(this, fn);\n var intervalId = window$1.setInterval(fn, interval);\n\n var disposeFn = function disposeFn() {\n return _this3.clearInterval(intervalId);\n };\n\n disposeFn.guid = \"vjs-interval-\" + intervalId;\n this.on('dispose', disposeFn);\n return intervalId;\n };\n /**\n * Clears an interval that gets created via `window.setInterval` or\n * {@link Component#setInterval}. If you set an inteval via {@link Component#setInterval}\n * use this function instead of `window.clearInterval`. If you don't your dispose\n * listener will not get cleaned up until {@link Component#dispose}!\n *\n * @param {number} intervalId\n * The id of the interval to clear. The return value of\n * {@link Component#setInterval} or `window.setInterval`.\n *\n * @return {number}\n * Returns the interval id that was cleared.\n *\n * @see [Similar to]{@link https://developer.mozilla.org/en-US/docs/Web/API/WindowTimers/clearInterval}\n */\n\n\n _proto.clearInterval = function clearInterval(intervalId) {\n window$1.clearInterval(intervalId);\n\n var disposeFn = function disposeFn() {};\n\n disposeFn.guid = \"vjs-interval-\" + intervalId;\n this.off('dispose', disposeFn);\n return intervalId;\n };\n /**\n * Queues up a callback to be passed to requestAnimationFrame (rAF), but\n * with a few extra bonuses:\n *\n * - Supports browsers that do not support rAF by falling back to\n * {@link Component#setTimeout}.\n *\n * - The callback is turned into a {@link Component~GenericCallback} (i.e.\n * bound to the component).\n *\n * - Automatic cancellation of the rAF callback is handled if the component\n * is disposed before it is called.\n *\n * @param {Component~GenericCallback} fn\n * A function that will be bound to this component and executed just\n * before the browser's next repaint.\n *\n * @return {number}\n * Returns an rAF ID that gets used to identify the timeout. It can\n * also be used in {@link Component#cancelAnimationFrame} to cancel\n * the animation frame callback.\n *\n * @listens Component#dispose\n * @see [Similar to]{@link https://developer.mozilla.org/en-US/docs/Web/API/window/requestAnimationFrame}\n */\n\n\n _proto.requestAnimationFrame = function requestAnimationFrame(fn) {\n var _this4 = this;\n\n // declare as variables so they are properly available in rAF function\n // eslint-disable-next-line\n var id, disposeFn;\n\n if (this.supportsRaf_) {\n fn = bind(this, fn);\n id = window$1.requestAnimationFrame(function () {\n _this4.off('dispose', disposeFn);\n\n fn();\n });\n\n disposeFn = function disposeFn() {\n return _this4.cancelAnimationFrame(id);\n };\n\n disposeFn.guid = \"vjs-raf-\" + id;\n this.on('dispose', disposeFn);\n return id;\n } // Fall back to using a timer.\n\n\n return this.setTimeout(fn, 1000 / 60);\n };\n /**\n * Cancels a queued callback passed to {@link Component#requestAnimationFrame}\n * (rAF).\n *\n * If you queue an rAF callback via {@link Component#requestAnimationFrame},\n * use this function instead of `window.cancelAnimationFrame`. If you don't,\n * your dispose listener will not get cleaned up until {@link Component#dispose}!\n *\n * @param {number} id\n * The rAF ID to clear. The return value of {@link Component#requestAnimationFrame}.\n *\n * @return {number}\n * Returns the rAF ID that was cleared.\n *\n * @see [Similar to]{@link https://developer.mozilla.org/en-US/docs/Web/API/window/cancelAnimationFrame}\n */\n\n\n _proto.cancelAnimationFrame = function cancelAnimationFrame(id) {\n if (this.supportsRaf_) {\n window$1.cancelAnimationFrame(id);\n\n var disposeFn = function disposeFn() {};\n\n disposeFn.guid = \"vjs-raf-\" + id;\n this.off('dispose', disposeFn);\n return id;\n } // Fall back to using a timer.\n\n\n return this.clearTimeout(id);\n };\n /**\n * Register a `Component` with `videojs` given the name and the component.\n *\n * > NOTE: {@link Tech}s should not be registered as a `Component`. {@link Tech}s\n * should be registered using {@link Tech.registerTech} or\n * {@link videojs:videojs.registerTech}.\n *\n * > NOTE: This function can also be seen on videojs as\n * {@link videojs:videojs.registerComponent}.\n *\n * @param {string} name\n * The name of the `Component` to register.\n *\n * @param {Component} ComponentToRegister\n * The `Component` class to register.\n *\n * @return {Component}\n * The `Component` that was registered.\n */\n\n\n Component.registerComponent = function registerComponent(name, ComponentToRegister) {\n if (typeof name !== 'string' || !name) {\n throw new Error(\"Illegal component name, \\\"\" + name + \"\\\"; must be a non-empty string.\");\n }\n\n var Tech = Component.getComponent('Tech'); // We need to make sure this check is only done if Tech has been registered.\n\n var isTech = Tech && Tech.isTech(ComponentToRegister);\n var isComp = Component === ComponentToRegister || Component.prototype.isPrototypeOf(ComponentToRegister.prototype);\n\n if (isTech || !isComp) {\n var reason;\n\n if (isTech) {\n reason = 'techs must be registered using Tech.registerTech()';\n } else {\n reason = 'must be a Component subclass';\n }\n\n throw new Error(\"Illegal component, \\\"\" + name + \"\\\"; \" + reason + \".\");\n }\n\n name = toTitleCase(name);\n\n if (!Component.components_) {\n Component.components_ = {};\n }\n\n var Player = Component.getComponent('Player');\n\n if (name === 'Player' && Player && Player.players) {\n var players = Player.players;\n var playerNames = Object.keys(players); // If we have players that were disposed, then their name will still be\n // in Players.players. So, we must loop through and verify that the value\n // for each item is not null. This allows registration of the Player component\n // after all players have been disposed or before any were created.\n\n if (players && playerNames.length > 0 && playerNames.map(function (pname) {\n return players[pname];\n }).every(Boolean)) {\n throw new Error('Can not register Player component after player has been created.');\n }\n }\n\n Component.components_[name] = ComponentToRegister;\n return ComponentToRegister;\n };\n /**\n * Get a `Component` based on the name it was registered with.\n *\n * @param {string} name\n * The Name of the component to get.\n *\n * @return {Component}\n * The `Component` that got registered under the given name.\n *\n * @deprecated In `videojs` 6 this will not return `Component`s that were not\n * registered using {@link Component.registerComponent}. Currently we\n * check the global `videojs` object for a `Component` name and\n * return that if it exists.\n */\n\n\n Component.getComponent = function getComponent(name) {\n if (!name) {\n return;\n }\n\n name = toTitleCase(name);\n\n if (Component.components_ && Component.components_[name]) {\n return Component.components_[name];\n }\n };\n\n return Component;\n}();\n/**\n * Whether or not this component supports `requestAnimationFrame`.\n *\n * This is exposed primarily for testing purposes.\n *\n * @private\n * @type {Boolean}\n */\n\n\nComponent.prototype.supportsRaf_ = typeof window$1.requestAnimationFrame === 'function' && typeof window$1.cancelAnimationFrame === 'function';\nComponent.registerComponent('Component', Component);\n\n/**\n * @file browser.js\n * @module browser\n */\nvar USER_AGENT = window$1.navigator && window$1.navigator.userAgent || '';\nvar webkitVersionMap = /AppleWebKit\\/([\\d.]+)/i.exec(USER_AGENT);\nvar appleWebkitVersion = webkitVersionMap ? parseFloat(webkitVersionMap.pop()) : null;\n/**\n * Whether or not this device is an iPad.\n *\n * @static\n * @const\n * @type {Boolean}\n */\n\nvar IS_IPAD = /iPad/i.test(USER_AGENT);\n/**\n * Whether or not this device is an iPhone.\n *\n * @static\n * @const\n * @type {Boolean}\n */\n// The Facebook app's UIWebView identifies as both an iPhone and iPad, so\n// to identify iPhones, we need to exclude iPads.\n// http://artsy.github.io/blog/2012/10/18/the-perils-of-ios-user-agent-sniffing/\n\nvar IS_IPHONE = /iPhone/i.test(USER_AGENT) && !IS_IPAD;\n/**\n * Whether or not this device is an iPod.\n *\n * @static\n * @const\n * @type {Boolean}\n */\n\nvar IS_IPOD = /iPod/i.test(USER_AGENT);\n/**\n * Whether or not this is an iOS device.\n *\n * @static\n * @const\n * @type {Boolean}\n */\n\nvar IS_IOS = IS_IPHONE || IS_IPAD || IS_IPOD;\n/**\n * The detected iOS version - or `null`.\n *\n * @static\n * @const\n * @type {string|null}\n */\n\nvar IOS_VERSION = function () {\n var match = USER_AGENT.match(/OS (\\d+)_/i);\n\n if (match && match[1]) {\n return match[1];\n }\n\n return null;\n}();\n/**\n * Whether or not this is an Android device.\n *\n * @static\n * @const\n * @type {Boolean}\n */\n\nvar IS_ANDROID = /Android/i.test(USER_AGENT);\n/**\n * The detected Android version - or `null`.\n *\n * @static\n * @const\n * @type {number|string|null}\n */\n\nvar ANDROID_VERSION = function () {\n // This matches Android Major.Minor.Patch versions\n // ANDROID_VERSION is Major.Minor as a Number, if Minor isn't available, then only Major is returned\n var match = USER_AGENT.match(/Android (\\d+)(?:\\.(\\d+))?(?:\\.(\\d+))*/i);\n\n if (!match) {\n return null;\n }\n\n var major = match[1] && parseFloat(match[1]);\n var minor = match[2] && parseFloat(match[2]);\n\n if (major && minor) {\n return parseFloat(match[1] + '.' + match[2]);\n } else if (major) {\n return major;\n }\n\n return null;\n}();\n/**\n * Whether or not this is a native Android browser.\n *\n * @static\n * @const\n * @type {Boolean}\n */\n\nvar IS_NATIVE_ANDROID = IS_ANDROID && ANDROID_VERSION < 5 && appleWebkitVersion < 537;\n/**\n * Whether or not this is Mozilla Firefox.\n *\n * @static\n * @const\n * @type {Boolean}\n */\n\nvar IS_FIREFOX = /Firefox/i.test(USER_AGENT);\n/**\n * Whether or not this is Microsoft Edge.\n *\n * @static\n * @const\n * @type {Boolean}\n */\n\nvar IS_EDGE = /Edge/i.test(USER_AGENT);\n/**\n * Whether or not this is Google Chrome.\n *\n * This will also be `true` for Chrome on iOS, which will have different support\n * as it is actually Safari under the hood.\n *\n * @static\n * @const\n * @type {Boolean}\n */\n\nvar IS_CHROME = !IS_EDGE && (/Chrome/i.test(USER_AGENT) || /CriOS/i.test(USER_AGENT));\n/**\n * The detected Google Chrome version - or `null`.\n *\n * @static\n * @const\n * @type {number|null}\n */\n\nvar CHROME_VERSION = function () {\n var match = USER_AGENT.match(/(Chrome|CriOS)\\/(\\d+)/);\n\n if (match && match[2]) {\n return parseFloat(match[2]);\n }\n\n return null;\n}();\n/**\n * The detected Internet Explorer version - or `null`.\n *\n * @static\n * @const\n * @type {number|null}\n */\n\nvar IE_VERSION = function () {\n var result = /MSIE\\s(\\d+)\\.\\d/.exec(USER_AGENT);\n var version = result && parseFloat(result[1]);\n\n if (!version && /Trident\\/7.0/i.test(USER_AGENT) && /rv:11.0/.test(USER_AGENT)) {\n // IE 11 has a different user agent string than other IE versions\n version = 11.0;\n }\n\n return version;\n}();\n/**\n * Whether or not this is desktop Safari.\n *\n * @static\n * @const\n * @type {Boolean}\n */\n\nvar IS_SAFARI = /Safari/i.test(USER_AGENT) && !IS_CHROME && !IS_ANDROID && !IS_EDGE;\n/**\n * Whether or not this is any flavor of Safari - including iOS.\n *\n * @static\n * @const\n * @type {Boolean}\n */\n\nvar IS_ANY_SAFARI = (IS_SAFARI || IS_IOS) && !IS_CHROME;\n/**\n * Whether or not this device is touch-enabled.\n *\n * @static\n * @const\n * @type {Boolean}\n */\n\nvar TOUCH_ENABLED = isReal() && ('ontouchstart' in window$1 || window$1.navigator.maxTouchPoints || window$1.DocumentTouch && window$1.document instanceof window$1.DocumentTouch);\n\nvar browser = /*#__PURE__*/Object.freeze({\n IS_IPAD: IS_IPAD,\n IS_IPHONE: IS_IPHONE,\n IS_IPOD: IS_IPOD,\n IS_IOS: IS_IOS,\n IOS_VERSION: IOS_VERSION,\n IS_ANDROID: IS_ANDROID,\n ANDROID_VERSION: ANDROID_VERSION,\n IS_NATIVE_ANDROID: IS_NATIVE_ANDROID,\n IS_FIREFOX: IS_FIREFOX,\n IS_EDGE: IS_EDGE,\n IS_CHROME: IS_CHROME,\n CHROME_VERSION: CHROME_VERSION,\n IE_VERSION: IE_VERSION,\n IS_SAFARI: IS_SAFARI,\n IS_ANY_SAFARI: IS_ANY_SAFARI,\n TOUCH_ENABLED: TOUCH_ENABLED\n});\n\n/**\n * @file time-ranges.js\n * @module time-ranges\n */\n\n/**\n * Returns the time for the specified index at the start or end\n * of a TimeRange object.\n *\n * @typedef {Function} TimeRangeIndex\n *\n * @param {number} [index=0]\n * The range number to return the time for.\n *\n * @return {number}\n * The time offset at the specified index.\n *\n * @deprecated The index argument must be provided.\n * In the future, leaving it out will throw an error.\n */\n\n/**\n * An object that contains ranges of time.\n *\n * @typedef {Object} TimeRange\n *\n * @property {number} length\n * The number of time ranges represented by this object.\n *\n * @property {module:time-ranges~TimeRangeIndex} start\n * Returns the time offset at which a specified time range begins.\n *\n * @property {module:time-ranges~TimeRangeIndex} end\n * Returns the time offset at which a specified time range ends.\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/TimeRanges\n */\n\n/**\n * Check if any of the time ranges are over the maximum index.\n *\n * @private\n * @param {string} fnName\n * The function name to use for logging\n *\n * @param {number} index\n * The index to check\n *\n * @param {number} maxIndex\n * The maximum possible index\n *\n * @throws {Error} if the timeRanges provided are over the maxIndex\n */\nfunction rangeCheck(fnName, index, maxIndex) {\n if (typeof index !== 'number' || index < 0 || index > maxIndex) {\n throw new Error(\"Failed to execute '\" + fnName + \"' on 'TimeRanges': The index provided (\" + index + \") is non-numeric or out of bounds (0-\" + maxIndex + \").\");\n }\n}\n/**\n * Get the time for the specified index at the start or end\n * of a TimeRange object.\n *\n * @private\n * @param {string} fnName\n * The function name to use for logging\n *\n * @param {string} valueIndex\n * The property that should be used to get the time. should be\n * 'start' or 'end'\n *\n * @param {Array} ranges\n * An array of time ranges\n *\n * @param {Array} [rangeIndex=0]\n * The index to start the search at\n *\n * @return {number}\n * The time that offset at the specified index.\n *\n * @deprecated rangeIndex must be set to a value, in the future this will throw an error.\n * @throws {Error} if rangeIndex is more than the length of ranges\n */\n\n\nfunction getRange(fnName, valueIndex, ranges, rangeIndex) {\n rangeCheck(fnName, rangeIndex, ranges.length - 1);\n return ranges[rangeIndex][valueIndex];\n}\n/**\n * Create a time range object given ranges of time.\n *\n * @private\n * @param {Array} [ranges]\n * An array of time ranges.\n */\n\n\nfunction createTimeRangesObj(ranges) {\n if (ranges === undefined || ranges.length === 0) {\n return {\n length: 0,\n start: function start() {\n throw new Error('This TimeRanges object is empty');\n },\n end: function end() {\n throw new Error('This TimeRanges object is empty');\n }\n };\n }\n\n return {\n length: ranges.length,\n start: getRange.bind(null, 'start', 0, ranges),\n end: getRange.bind(null, 'end', 1, ranges)\n };\n}\n/**\n * Create a `TimeRange` object which mimics an\n * {@link https://developer.mozilla.org/en-US/docs/Web/API/TimeRanges|HTML5 TimeRanges instance}.\n *\n * @param {number|Array[]} start\n * The start of a single range (a number) or an array of ranges (an\n * array of arrays of two numbers each).\n *\n * @param {number} end\n * The end of a single range. Cannot be used with the array form of\n * the `start` argument.\n */\n\n\nfunction createTimeRanges(start, end) {\n if (Array.isArray(start)) {\n return createTimeRangesObj(start);\n } else if (start === undefined || end === undefined) {\n return createTimeRangesObj();\n }\n\n return createTimeRangesObj([[start, end]]);\n}\n\n/**\n * @file buffer.js\n * @module buffer\n */\n/**\n * Compute the percentage of the media that has been buffered.\n *\n * @param {TimeRange} buffered\n * The current `TimeRange` object representing buffered time ranges\n *\n * @param {number} duration\n * Total duration of the media\n *\n * @return {number}\n * Percent buffered of the total duration in decimal form.\n */\n\nfunction bufferedPercent(buffered, duration) {\n var bufferedDuration = 0;\n var start;\n var end;\n\n if (!duration) {\n return 0;\n }\n\n if (!buffered || !buffered.length) {\n buffered = createTimeRanges(0, 0);\n }\n\n for (var i = 0; i < buffered.length; i++) {\n start = buffered.start(i);\n end = buffered.end(i); // buffered end can be bigger than duration by a very small fraction\n\n if (end > duration) {\n end = duration;\n }\n\n bufferedDuration += end - start;\n }\n\n return bufferedDuration / duration;\n}\n\n/**\n * @file fullscreen-api.js\n * @module fullscreen-api\n * @private\n */\n/**\n * Store the browser-specific methods for the fullscreen API.\n *\n * @type {Object}\n * @see [Specification]{@link https://fullscreen.spec.whatwg.org}\n * @see [Map Approach From Screenfull.js]{@link https://github.com/sindresorhus/screenfull.js}\n */\n\nvar FullscreenApi = {}; // browser API methods\n\nvar apiMap = [['requestFullscreen', 'exitFullscreen', 'fullscreenElement', 'fullscreenEnabled', 'fullscreenchange', 'fullscreenerror'], // WebKit\n['webkitRequestFullscreen', 'webkitExitFullscreen', 'webkitFullscreenElement', 'webkitFullscreenEnabled', 'webkitfullscreenchange', 'webkitfullscreenerror'], // Old WebKit (Safari 5.1)\n['webkitRequestFullScreen', 'webkitCancelFullScreen', 'webkitCurrentFullScreenElement', 'webkitCancelFullScreen', 'webkitfullscreenchange', 'webkitfullscreenerror'], // Mozilla\n['mozRequestFullScreen', 'mozCancelFullScreen', 'mozFullScreenElement', 'mozFullScreenEnabled', 'mozfullscreenchange', 'mozfullscreenerror'], // Microsoft\n['msRequestFullscreen', 'msExitFullscreen', 'msFullscreenElement', 'msFullscreenEnabled', 'MSFullscreenChange', 'MSFullscreenError']];\nvar specApi = apiMap[0];\nvar browserApi; // determine the supported set of functions\n\nfor (var i = 0; i < apiMap.length; i++) {\n // check for exitFullscreen function\n if (apiMap[i][1] in document) {\n browserApi = apiMap[i];\n break;\n }\n} // map the browser API names to the spec API names\n\n\nif (browserApi) {\n for (var _i = 0; _i < browserApi.length; _i++) {\n FullscreenApi[specApi[_i]] = browserApi[_i];\n }\n}\n\n/**\n * @file media-error.js\n */\n/**\n * A Custom `MediaError` class which mimics the standard HTML5 `MediaError` class.\n *\n * @param {number|string|Object|MediaError} value\n * This can be of multiple types:\n * - number: should be a standard error code\n * - string: an error message (the code will be 0)\n * - Object: arbitrary properties\n * - `MediaError` (native): used to populate a video.js `MediaError` object\n * - `MediaError` (video.js): will return itself if it's already a\n * video.js `MediaError` object.\n *\n * @see [MediaError Spec]{@link https://dev.w3.org/html5/spec-author-view/video.html#mediaerror}\n * @see [Encrypted MediaError Spec]{@link https://www.w3.org/TR/2013/WD-encrypted-media-20130510/#error-codes}\n *\n * @class MediaError\n */\n\nfunction MediaError(value) {\n // Allow redundant calls to this constructor to avoid having `instanceof`\n // checks peppered around the code.\n if (value instanceof MediaError) {\n return value;\n }\n\n if (typeof value === 'number') {\n this.code = value;\n } else if (typeof value === 'string') {\n // default code is zero, so this is a custom error\n this.message = value;\n } else if (isObject(value)) {\n // We assign the `code` property manually because native `MediaError` objects\n // do not expose it as an own/enumerable property of the object.\n if (typeof value.code === 'number') {\n this.code = value.code;\n }\n\n assign(this, value);\n }\n\n if (!this.message) {\n this.message = MediaError.defaultMessages[this.code] || '';\n }\n}\n/**\n * The error code that refers two one of the defined `MediaError` types\n *\n * @type {Number}\n */\n\n\nMediaError.prototype.code = 0;\n/**\n * An optional message that to show with the error. Message is not part of the HTML5\n * video spec but allows for more informative custom errors.\n *\n * @type {String}\n */\n\nMediaError.prototype.message = '';\n/**\n * An optional status code that can be set by plugins to allow even more detail about\n * the error. For example a plugin might provide a specific HTTP status code and an\n * error message for that code. Then when the plugin gets that error this class will\n * know how to display an error message for it. This allows a custom message to show\n * up on the `Player` error overlay.\n *\n * @type {Array}\n */\n\nMediaError.prototype.status = null;\n/**\n * Errors indexed by the W3C standard. The order **CANNOT CHANGE**! See the\n * specification listed under {@link MediaError} for more information.\n *\n * @enum {array}\n * @readonly\n * @property {string} 0 - MEDIA_ERR_CUSTOM\n * @property {string} 1 - MEDIA_ERR_ABORTED\n * @property {string} 2 - MEDIA_ERR_NETWORK\n * @property {string} 3 - MEDIA_ERR_DECODE\n * @property {string} 4 - MEDIA_ERR_SRC_NOT_SUPPORTED\n * @property {string} 5 - MEDIA_ERR_ENCRYPTED\n */\n\nMediaError.errorTypes = ['MEDIA_ERR_CUSTOM', 'MEDIA_ERR_ABORTED', 'MEDIA_ERR_NETWORK', 'MEDIA_ERR_DECODE', 'MEDIA_ERR_SRC_NOT_SUPPORTED', 'MEDIA_ERR_ENCRYPTED'];\n/**\n * The default `MediaError` messages based on the {@link MediaError.errorTypes}.\n *\n * @type {Array}\n * @constant\n */\n\nMediaError.defaultMessages = {\n 1: 'You aborted the media playback',\n 2: 'A network error caused the media download to fail part-way.',\n 3: 'The media playback was aborted due to a corruption problem or because the media used features your browser did not support.',\n 4: 'The media could not be loaded, either because the server or network failed or because the format is not supported.',\n 5: 'The media is encrypted and we do not have the keys to decrypt it.'\n}; // Add types as properties on MediaError\n// e.g. MediaError.MEDIA_ERR_SRC_NOT_SUPPORTED = 4;\n\nfor (var errNum = 0; errNum < MediaError.errorTypes.length; errNum++) {\n MediaError[MediaError.errorTypes[errNum]] = errNum; // values should be accessible on both the class and instance\n\n MediaError.prototype[MediaError.errorTypes[errNum]] = errNum;\n} // jsdocs for instance/static members added above\n\n/**\n * Returns whether an object is `Promise`-like (i.e. has a `then` method).\n *\n * @param {Object} value\n * An object that may or may not be `Promise`-like.\n *\n * @return {boolean}\n * Whether or not the object is `Promise`-like.\n */\nfunction isPromise(value) {\n return value !== undefined && value !== null && typeof value.then === 'function';\n}\n/**\n * Silence a Promise-like object.\n *\n * This is useful for avoiding non-harmful, but potentially confusing \"uncaught\n * play promise\" rejection error messages.\n *\n * @param {Object} value\n * An object that may or may not be `Promise`-like.\n */\n\nfunction silencePromise(value) {\n if (isPromise(value)) {\n value.then(null, function (e) {});\n }\n}\n\n/**\n * @file text-track-list-converter.js Utilities for capturing text track state and\n * re-creating tracks based on a capture.\n *\n * @module text-track-list-converter\n */\n\n/**\n * Examine a single {@link TextTrack} and return a JSON-compatible javascript object that\n * represents the {@link TextTrack}'s state.\n *\n * @param {TextTrack} track\n * The text track to query.\n *\n * @return {Object}\n * A serializable javascript representation of the TextTrack.\n * @private\n */\nvar trackToJson_ = function trackToJson_(track) {\n var ret = ['kind', 'label', 'language', 'id', 'inBandMetadataTrackDispatchType', 'mode', 'src'].reduce(function (acc, prop, i) {\n if (track[prop]) {\n acc[prop] = track[prop];\n }\n\n return acc;\n }, {\n cues: track.cues && Array.prototype.map.call(track.cues, function (cue) {\n return {\n startTime: cue.startTime,\n endTime: cue.endTime,\n text: cue.text,\n id: cue.id\n };\n })\n });\n return ret;\n};\n/**\n * Examine a {@link Tech} and return a JSON-compatible javascript array that represents the\n * state of all {@link TextTrack}s currently configured. The return array is compatible with\n * {@link text-track-list-converter:jsonToTextTracks}.\n *\n * @param {Tech} tech\n * The tech object to query\n *\n * @return {Array}\n * A serializable javascript representation of the {@link Tech}s\n * {@link TextTrackList}.\n */\n\n\nvar textTracksToJson = function textTracksToJson(tech) {\n var trackEls = tech.$$('track');\n var trackObjs = Array.prototype.map.call(trackEls, function (t) {\n return t.track;\n });\n var tracks = Array.prototype.map.call(trackEls, function (trackEl) {\n var json = trackToJson_(trackEl.track);\n\n if (trackEl.src) {\n json.src = trackEl.src;\n }\n\n return json;\n });\n return tracks.concat(Array.prototype.filter.call(tech.textTracks(), function (track) {\n return trackObjs.indexOf(track) === -1;\n }).map(trackToJson_));\n};\n/**\n * Create a set of remote {@link TextTrack}s on a {@link Tech} based on an array of javascript\n * object {@link TextTrack} representations.\n *\n * @param {Array} json\n * An array of `TextTrack` representation objects, like those that would be\n * produced by `textTracksToJson`.\n *\n * @param {Tech} tech\n * The `Tech` to create the `TextTrack`s on.\n */\n\n\nvar jsonToTextTracks = function jsonToTextTracks(json, tech) {\n json.forEach(function (track) {\n var addedTrack = tech.addRemoteTextTrack(track).track;\n\n if (!track.src && track.cues) {\n track.cues.forEach(function (cue) {\n return addedTrack.addCue(cue);\n });\n }\n });\n return tech.textTracks();\n};\n\nvar textTrackConverter = {\n textTracksToJson: textTracksToJson,\n jsonToTextTracks: jsonToTextTracks,\n trackToJson_: trackToJson_\n};\n\nvar MODAL_CLASS_NAME = 'vjs-modal-dialog';\nvar ESC = 27;\n/**\n * The `ModalDialog` displays over the video and its controls, which blocks\n * interaction with the player until it is closed.\n *\n * Modal dialogs include a \"Close\" button and will close when that button\n * is activated - or when ESC is pressed anywhere.\n *\n * @extends Component\n */\n\nvar ModalDialog =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(ModalDialog, _Component);\n\n /**\n * Create an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n *\n * @param {Mixed} [options.content=undefined]\n * Provide customized content for this modal.\n *\n * @param {string} [options.description]\n * A text description for the modal, primarily for accessibility.\n *\n * @param {boolean} [options.fillAlways=false]\n * Normally, modals are automatically filled only the first time\n * they open. This tells the modal to refresh its content\n * every time it opens.\n *\n * @param {string} [options.label]\n * A text label for the modal, primarily for accessibility.\n *\n * @param {boolean} [options.temporary=true]\n * If `true`, the modal can only be opened once; it will be\n * disposed as soon as it's closed.\n *\n * @param {boolean} [options.uncloseable=false]\n * If `true`, the user will not be able to close the modal\n * through the UI in the normal ways. Programmatic closing is\n * still possible.\n */\n function ModalDialog(player, options) {\n var _this;\n\n _this = _Component.call(this, player, options) || this;\n _this.opened_ = _this.hasBeenOpened_ = _this.hasBeenFilled_ = false;\n\n _this.closeable(!_this.options_.uncloseable);\n\n _this.content(_this.options_.content); // Make sure the contentEl is defined AFTER any children are initialized\n // because we only want the contents of the modal in the contentEl\n // (not the UI elements like the close button).\n\n\n _this.contentEl_ = createEl('div', {\n className: MODAL_CLASS_NAME + \"-content\"\n }, {\n role: 'document'\n });\n _this.descEl_ = createEl('p', {\n className: MODAL_CLASS_NAME + \"-description vjs-control-text\",\n id: _this.el().getAttribute('aria-describedby')\n });\n textContent(_this.descEl_, _this.description());\n\n _this.el_.appendChild(_this.descEl_);\n\n _this.el_.appendChild(_this.contentEl_);\n\n return _this;\n }\n /**\n * Create the `ModalDialog`'s DOM element\n *\n * @return {Element}\n * The DOM element that gets created.\n */\n\n\n var _proto = ModalDialog.prototype;\n\n _proto.createEl = function createEl$$1() {\n return _Component.prototype.createEl.call(this, 'div', {\n className: this.buildCSSClass(),\n tabIndex: -1\n }, {\n 'aria-describedby': this.id() + \"_description\",\n 'aria-hidden': 'true',\n 'aria-label': this.label(),\n 'role': 'dialog'\n });\n };\n\n _proto.dispose = function dispose() {\n this.contentEl_ = null;\n this.descEl_ = null;\n this.previouslyActiveEl_ = null;\n\n _Component.prototype.dispose.call(this);\n };\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n\n\n _proto.buildCSSClass = function buildCSSClass() {\n return MODAL_CLASS_NAME + \" vjs-hidden \" + _Component.prototype.buildCSSClass.call(this);\n };\n /**\n * Handles `keydown` events on the document, looking for ESC, which closes\n * the modal.\n *\n * @param {EventTarget~Event} e\n * The keypress that triggered this event.\n *\n * @listens keydown\n */\n\n\n _proto.handleKeyPress = function handleKeyPress(e) {\n if (e.which === ESC && this.closeable()) {\n this.close();\n }\n };\n /**\n * Returns the label string for this modal. Primarily used for accessibility.\n *\n * @return {string}\n * the localized or raw label of this modal.\n */\n\n\n _proto.label = function label() {\n return this.localize(this.options_.label || 'Modal Window');\n };\n /**\n * Returns the description string for this modal. Primarily used for\n * accessibility.\n *\n * @return {string}\n * The localized or raw description of this modal.\n */\n\n\n _proto.description = function description() {\n var desc = this.options_.description || this.localize('This is a modal window.'); // Append a universal closeability message if the modal is closeable.\n\n if (this.closeable()) {\n desc += ' ' + this.localize('This modal can be closed by pressing the Escape key or activating the close button.');\n }\n\n return desc;\n };\n /**\n * Opens the modal.\n *\n * @fires ModalDialog#beforemodalopen\n * @fires ModalDialog#modalopen\n */\n\n\n _proto.open = function open() {\n if (!this.opened_) {\n var player = this.player();\n /**\n * Fired just before a `ModalDialog` is opened.\n *\n * @event ModalDialog#beforemodalopen\n * @type {EventTarget~Event}\n */\n\n this.trigger('beforemodalopen');\n this.opened_ = true; // Fill content if the modal has never opened before and\n // never been filled.\n\n if (this.options_.fillAlways || !this.hasBeenOpened_ && !this.hasBeenFilled_) {\n this.fill();\n } // If the player was playing, pause it and take note of its previously\n // playing state.\n\n\n this.wasPlaying_ = !player.paused();\n\n if (this.options_.pauseOnOpen && this.wasPlaying_) {\n player.pause();\n }\n\n if (this.closeable()) {\n this.on(this.el_.ownerDocument, 'keydown', bind(this, this.handleKeyPress));\n } // Hide controls and note if they were enabled.\n\n\n this.hadControls_ = player.controls();\n player.controls(false);\n this.show();\n this.conditionalFocus_();\n this.el().setAttribute('aria-hidden', 'false');\n /**\n * Fired just after a `ModalDialog` is opened.\n *\n * @event ModalDialog#modalopen\n * @type {EventTarget~Event}\n */\n\n this.trigger('modalopen');\n this.hasBeenOpened_ = true;\n }\n };\n /**\n * If the `ModalDialog` is currently open or closed.\n *\n * @param {boolean} [value]\n * If given, it will open (`true`) or close (`false`) the modal.\n *\n * @return {boolean}\n * the current open state of the modaldialog\n */\n\n\n _proto.opened = function opened(value) {\n if (typeof value === 'boolean') {\n this[value ? 'open' : 'close']();\n }\n\n return this.opened_;\n };\n /**\n * Closes the modal, does nothing if the `ModalDialog` is\n * not open.\n *\n * @fires ModalDialog#beforemodalclose\n * @fires ModalDialog#modalclose\n */\n\n\n _proto.close = function close() {\n if (!this.opened_) {\n return;\n }\n\n var player = this.player();\n /**\n * Fired just before a `ModalDialog` is closed.\n *\n * @event ModalDialog#beforemodalclose\n * @type {EventTarget~Event}\n */\n\n this.trigger('beforemodalclose');\n this.opened_ = false;\n\n if (this.wasPlaying_ && this.options_.pauseOnOpen) {\n player.play();\n }\n\n if (this.closeable()) {\n this.off(this.el_.ownerDocument, 'keydown', bind(this, this.handleKeyPress));\n }\n\n if (this.hadControls_) {\n player.controls(true);\n }\n\n this.hide();\n this.el().setAttribute('aria-hidden', 'true');\n /**\n * Fired just after a `ModalDialog` is closed.\n *\n * @event ModalDialog#modalclose\n * @type {EventTarget~Event}\n */\n\n this.trigger('modalclose');\n this.conditionalBlur_();\n\n if (this.options_.temporary) {\n this.dispose();\n }\n };\n /**\n * Check to see if the `ModalDialog` is closeable via the UI.\n *\n * @param {boolean} [value]\n * If given as a boolean, it will set the `closeable` option.\n *\n * @return {boolean}\n * Returns the final value of the closable option.\n */\n\n\n _proto.closeable = function closeable(value) {\n if (typeof value === 'boolean') {\n var closeable = this.closeable_ = !!value;\n var close = this.getChild('closeButton'); // If this is being made closeable and has no close button, add one.\n\n if (closeable && !close) {\n // The close button should be a child of the modal - not its\n // content element, so temporarily change the content element.\n var temp = this.contentEl_;\n this.contentEl_ = this.el_;\n close = this.addChild('closeButton', {\n controlText: 'Close Modal Dialog'\n });\n this.contentEl_ = temp;\n this.on(close, 'close', this.close);\n } // If this is being made uncloseable and has a close button, remove it.\n\n\n if (!closeable && close) {\n this.off(close, 'close', this.close);\n this.removeChild(close);\n close.dispose();\n }\n }\n\n return this.closeable_;\n };\n /**\n * Fill the modal's content element with the modal's \"content\" option.\n * The content element will be emptied before this change takes place.\n */\n\n\n _proto.fill = function fill() {\n this.fillWith(this.content());\n };\n /**\n * Fill the modal's content element with arbitrary content.\n * The content element will be emptied before this change takes place.\n *\n * @fires ModalDialog#beforemodalfill\n * @fires ModalDialog#modalfill\n *\n * @param {Mixed} [content]\n * The same rules apply to this as apply to the `content` option.\n */\n\n\n _proto.fillWith = function fillWith(content) {\n var contentEl = this.contentEl();\n var parentEl = contentEl.parentNode;\n var nextSiblingEl = contentEl.nextSibling;\n /**\n * Fired just before a `ModalDialog` is filled with content.\n *\n * @event ModalDialog#beforemodalfill\n * @type {EventTarget~Event}\n */\n\n this.trigger('beforemodalfill');\n this.hasBeenFilled_ = true; // Detach the content element from the DOM before performing\n // manipulation to avoid modifying the live DOM multiple times.\n\n parentEl.removeChild(contentEl);\n this.empty();\n insertContent(contentEl, content);\n /**\n * Fired just after a `ModalDialog` is filled with content.\n *\n * @event ModalDialog#modalfill\n * @type {EventTarget~Event}\n */\n\n this.trigger('modalfill'); // Re-inject the re-filled content element.\n\n if (nextSiblingEl) {\n parentEl.insertBefore(contentEl, nextSiblingEl);\n } else {\n parentEl.appendChild(contentEl);\n } // make sure that the close button is last in the dialog DOM\n\n\n var closeButton = this.getChild('closeButton');\n\n if (closeButton) {\n parentEl.appendChild(closeButton.el_);\n }\n };\n /**\n * Empties the content element. This happens anytime the modal is filled.\n *\n * @fires ModalDialog#beforemodalempty\n * @fires ModalDialog#modalempty\n */\n\n\n _proto.empty = function empty() {\n /**\n * Fired just before a `ModalDialog` is emptied.\n *\n * @event ModalDialog#beforemodalempty\n * @type {EventTarget~Event}\n */\n this.trigger('beforemodalempty');\n emptyEl(this.contentEl());\n /**\n * Fired just after a `ModalDialog` is emptied.\n *\n * @event ModalDialog#modalempty\n * @type {EventTarget~Event}\n */\n\n this.trigger('modalempty');\n };\n /**\n * Gets or sets the modal content, which gets normalized before being\n * rendered into the DOM.\n *\n * This does not update the DOM or fill the modal, but it is called during\n * that process.\n *\n * @param {Mixed} [value]\n * If defined, sets the internal content value to be used on the\n * next call(s) to `fill`. This value is normalized before being\n * inserted. To \"clear\" the internal content value, pass `null`.\n *\n * @return {Mixed}\n * The current content of the modal dialog\n */\n\n\n _proto.content = function content(value) {\n if (typeof value !== 'undefined') {\n this.content_ = value;\n }\n\n return this.content_;\n };\n /**\n * conditionally focus the modal dialog if focus was previously on the player.\n *\n * @private\n */\n\n\n _proto.conditionalFocus_ = function conditionalFocus_() {\n var activeEl = document.activeElement;\n var playerEl = this.player_.el_;\n this.previouslyActiveEl_ = null;\n\n if (playerEl.contains(activeEl) || playerEl === activeEl) {\n this.previouslyActiveEl_ = activeEl;\n this.focus();\n this.on(document, 'keydown', this.handleKeyDown);\n }\n };\n /**\n * conditionally blur the element and refocus the last focused element\n *\n * @private\n */\n\n\n _proto.conditionalBlur_ = function conditionalBlur_() {\n if (this.previouslyActiveEl_) {\n this.previouslyActiveEl_.focus();\n this.previouslyActiveEl_ = null;\n }\n\n this.off(document, 'keydown', this.handleKeyDown);\n };\n /**\n * Keydown handler. Attached when modal is focused.\n *\n * @listens keydown\n */\n\n\n _proto.handleKeyDown = function handleKeyDown(event) {\n // exit early if it isn't a tab key\n if (event.which !== 9) {\n return;\n }\n\n var focusableEls = this.focusableEls_();\n var activeEl = this.el_.querySelector(':focus');\n var focusIndex;\n\n for (var i = 0; i < focusableEls.length; i++) {\n if (activeEl === focusableEls[i]) {\n focusIndex = i;\n break;\n }\n }\n\n if (document.activeElement === this.el_) {\n focusIndex = 0;\n }\n\n if (event.shiftKey && focusIndex === 0) {\n focusableEls[focusableEls.length - 1].focus();\n event.preventDefault();\n } else if (!event.shiftKey && focusIndex === focusableEls.length - 1) {\n focusableEls[0].focus();\n event.preventDefault();\n }\n };\n /**\n * get all focusable elements\n *\n * @private\n */\n\n\n _proto.focusableEls_ = function focusableEls_() {\n var allChildren = this.el_.querySelectorAll('*');\n return Array.prototype.filter.call(allChildren, function (child) {\n return (child instanceof window$1.HTMLAnchorElement || child instanceof window$1.HTMLAreaElement) && child.hasAttribute('href') || (child instanceof window$1.HTMLInputElement || child instanceof window$1.HTMLSelectElement || child instanceof window$1.HTMLTextAreaElement || child instanceof window$1.HTMLButtonElement) && !child.hasAttribute('disabled') || child instanceof window$1.HTMLIFrameElement || child instanceof window$1.HTMLObjectElement || child instanceof window$1.HTMLEmbedElement || child.hasAttribute('tabindex') && child.getAttribute('tabindex') !== -1 || child.hasAttribute('contenteditable');\n });\n };\n\n return ModalDialog;\n}(Component);\n/**\n * Default options for `ModalDialog` default options.\n *\n * @type {Object}\n * @private\n */\n\n\nModalDialog.prototype.options_ = {\n pauseOnOpen: true,\n temporary: true\n};\nComponent.registerComponent('ModalDialog', ModalDialog);\n\n/**\n * Common functionaliy between {@link TextTrackList}, {@link AudioTrackList}, and\n * {@link VideoTrackList}\n *\n * @extends EventTarget\n */\n\nvar TrackList =\n/*#__PURE__*/\nfunction (_EventTarget) {\n _inheritsLoose(TrackList, _EventTarget);\n\n /**\n * Create an instance of this class\n *\n * @param {Track[]} tracks\n * A list of tracks to initialize the list with.\n *\n * @abstract\n */\n function TrackList(tracks) {\n var _this;\n\n if (tracks === void 0) {\n tracks = [];\n }\n\n _this = _EventTarget.call(this) || this;\n _this.tracks_ = [];\n /**\n * @memberof TrackList\n * @member {number} length\n * The current number of `Track`s in the this Trackist.\n * @instance\n */\n\n Object.defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), 'length', {\n get: function get() {\n return this.tracks_.length;\n }\n });\n\n for (var i = 0; i < tracks.length; i++) {\n _this.addTrack(tracks[i]);\n }\n\n return _this;\n }\n /**\n * Add a {@link Track} to the `TrackList`\n *\n * @param {Track} track\n * The audio, video, or text track to add to the list.\n *\n * @fires TrackList#addtrack\n */\n\n\n var _proto = TrackList.prototype;\n\n _proto.addTrack = function addTrack(track) {\n var index = this.tracks_.length;\n\n if (!('' + index in this)) {\n Object.defineProperty(this, index, {\n get: function get() {\n return this.tracks_[index];\n }\n });\n } // Do not add duplicate tracks\n\n\n if (this.tracks_.indexOf(track) === -1) {\n this.tracks_.push(track);\n /**\n * Triggered when a track is added to a track list.\n *\n * @event TrackList#addtrack\n * @type {EventTarget~Event}\n * @property {Track} track\n * A reference to track that was added.\n */\n\n this.trigger({\n track: track,\n type: 'addtrack'\n });\n }\n };\n /**\n * Remove a {@link Track} from the `TrackList`\n *\n * @param {Track} rtrack\n * The audio, video, or text track to remove from the list.\n *\n * @fires TrackList#removetrack\n */\n\n\n _proto.removeTrack = function removeTrack(rtrack) {\n var track;\n\n for (var i = 0, l = this.length; i < l; i++) {\n if (this[i] === rtrack) {\n track = this[i];\n\n if (track.off) {\n track.off();\n }\n\n this.tracks_.splice(i, 1);\n break;\n }\n }\n\n if (!track) {\n return;\n }\n /**\n * Triggered when a track is removed from track list.\n *\n * @event TrackList#removetrack\n * @type {EventTarget~Event}\n * @property {Track} track\n * A reference to track that was removed.\n */\n\n\n this.trigger({\n track: track,\n type: 'removetrack'\n });\n };\n /**\n * Get a Track from the TrackList by a tracks id\n *\n * @param {string} id - the id of the track to get\n * @method getTrackById\n * @return {Track}\n * @private\n */\n\n\n _proto.getTrackById = function getTrackById(id) {\n var result = null;\n\n for (var i = 0, l = this.length; i < l; i++) {\n var track = this[i];\n\n if (track.id === id) {\n result = track;\n break;\n }\n }\n\n return result;\n };\n\n return TrackList;\n}(EventTarget);\n/**\n * Triggered when a different track is selected/enabled.\n *\n * @event TrackList#change\n * @type {EventTarget~Event}\n */\n\n/**\n * Events that can be called with on + eventName. See {@link EventHandler}.\n *\n * @property {Object} TrackList#allowedEvents_\n * @private\n */\n\n\nTrackList.prototype.allowedEvents_ = {\n change: 'change',\n addtrack: 'addtrack',\n removetrack: 'removetrack'\n}; // emulate attribute EventHandler support to allow for feature detection\n\nfor (var event in TrackList.prototype.allowedEvents_) {\n TrackList.prototype['on' + event] = null;\n}\n\n/**\n * Anywhere we call this function we diverge from the spec\n * as we only support one enabled audiotrack at a time\n *\n * @param {AudioTrackList} list\n * list to work on\n *\n * @param {AudioTrack} track\n * The track to skip\n *\n * @private\n */\n\nvar disableOthers = function disableOthers(list, track) {\n for (var i = 0; i < list.length; i++) {\n if (!Object.keys(list[i]).length || track.id === list[i].id) {\n continue;\n } // another audio track is enabled, disable it\n\n\n list[i].enabled = false;\n }\n};\n/**\n * The current list of {@link AudioTrack} for a media file.\n *\n * @see [Spec]{@link https://html.spec.whatwg.org/multipage/embedded-content.html#audiotracklist}\n * @extends TrackList\n */\n\n\nvar AudioTrackList =\n/*#__PURE__*/\nfunction (_TrackList) {\n _inheritsLoose(AudioTrackList, _TrackList);\n\n /**\n * Create an instance of this class.\n *\n * @param {AudioTrack[]} [tracks=[]]\n * A list of `AudioTrack` to instantiate the list with.\n */\n function AudioTrackList(tracks) {\n var _this;\n\n if (tracks === void 0) {\n tracks = [];\n }\n\n // make sure only 1 track is enabled\n // sorted from last index to first index\n for (var i = tracks.length - 1; i >= 0; i--) {\n if (tracks[i].enabled) {\n disableOthers(tracks, tracks[i]);\n break;\n }\n }\n\n _this = _TrackList.call(this, tracks) || this;\n _this.changing_ = false;\n return _this;\n }\n /**\n * Add an {@link AudioTrack} to the `AudioTrackList`.\n *\n * @param {AudioTrack} track\n * The AudioTrack to add to the list\n *\n * @fires TrackList#addtrack\n */\n\n\n var _proto = AudioTrackList.prototype;\n\n _proto.addTrack = function addTrack(track) {\n var _this2 = this;\n\n if (track.enabled) {\n disableOthers(this, track);\n }\n\n _TrackList.prototype.addTrack.call(this, track); // native tracks don't have this\n\n\n if (!track.addEventListener) {\n return;\n }\n /**\n * @listens AudioTrack#enabledchange\n * @fires TrackList#change\n */\n\n\n track.addEventListener('enabledchange', function () {\n // when we are disabling other tracks (since we don't support\n // more than one track at a time) we will set changing_\n // to true so that we don't trigger additional change events\n if (_this2.changing_) {\n return;\n }\n\n _this2.changing_ = true;\n disableOthers(_this2, track);\n _this2.changing_ = false;\n\n _this2.trigger('change');\n });\n };\n\n return AudioTrackList;\n}(TrackList);\n\n/**\n * Un-select all other {@link VideoTrack}s that are selected.\n *\n * @param {VideoTrackList} list\n * list to work on\n *\n * @param {VideoTrack} track\n * The track to skip\n *\n * @private\n */\n\nvar disableOthers$1 = function disableOthers(list, track) {\n for (var i = 0; i < list.length; i++) {\n if (!Object.keys(list[i]).length || track.id === list[i].id) {\n continue;\n } // another video track is enabled, disable it\n\n\n list[i].selected = false;\n }\n};\n/**\n * The current list of {@link VideoTrack} for a video.\n *\n * @see [Spec]{@link https://html.spec.whatwg.org/multipage/embedded-content.html#videotracklist}\n * @extends TrackList\n */\n\n\nvar VideoTrackList =\n/*#__PURE__*/\nfunction (_TrackList) {\n _inheritsLoose(VideoTrackList, _TrackList);\n\n /**\n * Create an instance of this class.\n *\n * @param {VideoTrack[]} [tracks=[]]\n * A list of `VideoTrack` to instantiate the list with.\n */\n function VideoTrackList(tracks) {\n var _this;\n\n if (tracks === void 0) {\n tracks = [];\n }\n\n // make sure only 1 track is enabled\n // sorted from last index to first index\n for (var i = tracks.length - 1; i >= 0; i--) {\n if (tracks[i].selected) {\n disableOthers$1(tracks, tracks[i]);\n break;\n }\n }\n\n _this = _TrackList.call(this, tracks) || this;\n _this.changing_ = false;\n /**\n * @member {number} VideoTrackList#selectedIndex\n * The current index of the selected {@link VideoTrack`}.\n */\n\n Object.defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), 'selectedIndex', {\n get: function get() {\n for (var _i = 0; _i < this.length; _i++) {\n if (this[_i].selected) {\n return _i;\n }\n }\n\n return -1;\n },\n set: function set() {}\n });\n return _this;\n }\n /**\n * Add a {@link VideoTrack} to the `VideoTrackList`.\n *\n * @param {VideoTrack} track\n * The VideoTrack to add to the list\n *\n * @fires TrackList#addtrack\n */\n\n\n var _proto = VideoTrackList.prototype;\n\n _proto.addTrack = function addTrack(track) {\n var _this2 = this;\n\n if (track.selected) {\n disableOthers$1(this, track);\n }\n\n _TrackList.prototype.addTrack.call(this, track); // native tracks don't have this\n\n\n if (!track.addEventListener) {\n return;\n }\n /**\n * @listens VideoTrack#selectedchange\n * @fires TrackList#change\n */\n\n\n track.addEventListener('selectedchange', function () {\n if (_this2.changing_) {\n return;\n }\n\n _this2.changing_ = true;\n disableOthers$1(_this2, track);\n _this2.changing_ = false;\n\n _this2.trigger('change');\n });\n };\n\n return VideoTrackList;\n}(TrackList);\n\n/**\n * The current list of {@link TextTrack} for a media file.\n *\n * @see [Spec]{@link https://html.spec.whatwg.org/multipage/embedded-content.html#texttracklist}\n * @extends TrackList\n */\n\nvar TextTrackList =\n/*#__PURE__*/\nfunction (_TrackList) {\n _inheritsLoose(TextTrackList, _TrackList);\n\n function TextTrackList() {\n return _TrackList.apply(this, arguments) || this;\n }\n\n var _proto = TextTrackList.prototype;\n\n /**\n * Add a {@link TextTrack} to the `TextTrackList`\n *\n * @param {TextTrack} track\n * The text track to add to the list.\n *\n * @fires TrackList#addtrack\n */\n _proto.addTrack = function addTrack(track) {\n _TrackList.prototype.addTrack.call(this, track);\n /**\n * @listens TextTrack#modechange\n * @fires TrackList#change\n */\n\n\n track.addEventListener('modechange', bind(this, function () {\n this.queueTrigger('change');\n }));\n var nonLanguageTextTrackKind = ['metadata', 'chapters'];\n\n if (nonLanguageTextTrackKind.indexOf(track.kind) === -1) {\n track.addEventListener('modechange', bind(this, function () {\n this.trigger('selectedlanguagechange');\n }));\n }\n };\n\n return TextTrackList;\n}(TrackList);\n\n/**\n * @file html-track-element-list.js\n */\n\n/**\n * The current list of {@link HtmlTrackElement}s.\n */\nvar HtmlTrackElementList =\n/*#__PURE__*/\nfunction () {\n /**\n * Create an instance of this class.\n *\n * @param {HtmlTrackElement[]} [tracks=[]]\n * A list of `HtmlTrackElement` to instantiate the list with.\n */\n function HtmlTrackElementList(trackElements) {\n if (trackElements === void 0) {\n trackElements = [];\n }\n\n this.trackElements_ = [];\n /**\n * @memberof HtmlTrackElementList\n * @member {number} length\n * The current number of `Track`s in the this Trackist.\n * @instance\n */\n\n Object.defineProperty(this, 'length', {\n get: function get() {\n return this.trackElements_.length;\n }\n });\n\n for (var i = 0, length = trackElements.length; i < length; i++) {\n this.addTrackElement_(trackElements[i]);\n }\n }\n /**\n * Add an {@link HtmlTrackElement} to the `HtmlTrackElementList`\n *\n * @param {HtmlTrackElement} trackElement\n * The track element to add to the list.\n *\n * @private\n */\n\n\n var _proto = HtmlTrackElementList.prototype;\n\n _proto.addTrackElement_ = function addTrackElement_(trackElement) {\n var index = this.trackElements_.length;\n\n if (!('' + index in this)) {\n Object.defineProperty(this, index, {\n get: function get() {\n return this.trackElements_[index];\n }\n });\n } // Do not add duplicate elements\n\n\n if (this.trackElements_.indexOf(trackElement) === -1) {\n this.trackElements_.push(trackElement);\n }\n };\n /**\n * Get an {@link HtmlTrackElement} from the `HtmlTrackElementList` given an\n * {@link TextTrack}.\n *\n * @param {TextTrack} track\n * The track associated with a track element.\n *\n * @return {HtmlTrackElement|undefined}\n * The track element that was found or undefined.\n *\n * @private\n */\n\n\n _proto.getTrackElementByTrack_ = function getTrackElementByTrack_(track) {\n var trackElement_;\n\n for (var i = 0, length = this.trackElements_.length; i < length; i++) {\n if (track === this.trackElements_[i].track) {\n trackElement_ = this.trackElements_[i];\n break;\n }\n }\n\n return trackElement_;\n };\n /**\n * Remove a {@link HtmlTrackElement} from the `HtmlTrackElementList`\n *\n * @param {HtmlTrackElement} trackElement\n * The track element to remove from the list.\n *\n * @private\n */\n\n\n _proto.removeTrackElement_ = function removeTrackElement_(trackElement) {\n for (var i = 0, length = this.trackElements_.length; i < length; i++) {\n if (trackElement === this.trackElements_[i]) {\n this.trackElements_.splice(i, 1);\n break;\n }\n }\n };\n\n return HtmlTrackElementList;\n}();\n\n/**\n * @file text-track-cue-list.js\n */\n\n/**\n * @typedef {Object} TextTrackCueList~TextTrackCue\n *\n * @property {string} id\n * The unique id for this text track cue\n *\n * @property {number} startTime\n * The start time for this text track cue\n *\n * @property {number} endTime\n * The end time for this text track cue\n *\n * @property {boolean} pauseOnExit\n * Pause when the end time is reached if true.\n *\n * @see [Spec]{@link https://html.spec.whatwg.org/multipage/embedded-content.html#texttrackcue}\n */\n\n/**\n * A List of TextTrackCues.\n *\n * @see [Spec]{@link https://html.spec.whatwg.org/multipage/embedded-content.html#texttrackcuelist}\n */\nvar TextTrackCueList =\n/*#__PURE__*/\nfunction () {\n /**\n * Create an instance of this class..\n *\n * @param {Array} cues\n * A list of cues to be initialized with\n */\n function TextTrackCueList(cues) {\n TextTrackCueList.prototype.setCues_.call(this, cues);\n /**\n * @memberof TextTrackCueList\n * @member {number} length\n * The current number of `TextTrackCue`s in the TextTrackCueList.\n * @instance\n */\n\n Object.defineProperty(this, 'length', {\n get: function get() {\n return this.length_;\n }\n });\n }\n /**\n * A setter for cues in this list. Creates getters\n * an an index for the cues.\n *\n * @param {Array} cues\n * An array of cues to set\n *\n * @private\n */\n\n\n var _proto = TextTrackCueList.prototype;\n\n _proto.setCues_ = function setCues_(cues) {\n var oldLength = this.length || 0;\n var i = 0;\n var l = cues.length;\n this.cues_ = cues;\n this.length_ = cues.length;\n\n var defineProp = function defineProp(index) {\n if (!('' + index in this)) {\n Object.defineProperty(this, '' + index, {\n get: function get() {\n return this.cues_[index];\n }\n });\n }\n };\n\n if (oldLength < l) {\n i = oldLength;\n\n for (; i < l; i++) {\n defineProp.call(this, i);\n }\n }\n };\n /**\n * Get a `TextTrackCue` that is currently in the `TextTrackCueList` by id.\n *\n * @param {string} id\n * The id of the cue that should be searched for.\n *\n * @return {TextTrackCueList~TextTrackCue|null}\n * A single cue or null if none was found.\n */\n\n\n _proto.getCueById = function getCueById(id) {\n var result = null;\n\n for (var i = 0, l = this.length; i < l; i++) {\n var cue = this[i];\n\n if (cue.id === id) {\n result = cue;\n break;\n }\n }\n\n return result;\n };\n\n return TextTrackCueList;\n}();\n\n/**\n * @file track-kinds.js\n */\n\n/**\n * All possible `VideoTrackKind`s\n *\n * @see https://html.spec.whatwg.org/multipage/embedded-content.html#dom-videotrack-kind\n * @typedef VideoTrack~Kind\n * @enum\n */\nvar VideoTrackKind = {\n alternative: 'alternative',\n captions: 'captions',\n main: 'main',\n sign: 'sign',\n subtitles: 'subtitles',\n commentary: 'commentary'\n};\n/**\n * All possible `AudioTrackKind`s\n *\n * @see https://html.spec.whatwg.org/multipage/embedded-content.html#dom-audiotrack-kind\n * @typedef AudioTrack~Kind\n * @enum\n */\n\nvar AudioTrackKind = {\n 'alternative': 'alternative',\n 'descriptions': 'descriptions',\n 'main': 'main',\n 'main-desc': 'main-desc',\n 'translation': 'translation',\n 'commentary': 'commentary'\n};\n/**\n * All possible `TextTrackKind`s\n *\n * @see https://html.spec.whatwg.org/multipage/embedded-content.html#dom-texttrack-kind\n * @typedef TextTrack~Kind\n * @enum\n */\n\nvar TextTrackKind = {\n subtitles: 'subtitles',\n captions: 'captions',\n descriptions: 'descriptions',\n chapters: 'chapters',\n metadata: 'metadata'\n};\n/**\n * All possible `TextTrackMode`s\n *\n * @see https://html.spec.whatwg.org/multipage/embedded-content.html#texttrackmode\n * @typedef TextTrack~Mode\n * @enum\n */\n\nvar TextTrackMode = {\n disabled: 'disabled',\n hidden: 'hidden',\n showing: 'showing'\n};\n\n/**\n * A Track class that contains all of the common functionality for {@link AudioTrack},\n * {@link VideoTrack}, and {@link TextTrack}.\n *\n * > Note: This class should not be used directly\n *\n * @see {@link https://html.spec.whatwg.org/multipage/embedded-content.html}\n * @extends EventTarget\n * @abstract\n */\n\nvar Track =\n/*#__PURE__*/\nfunction (_EventTarget) {\n _inheritsLoose(Track, _EventTarget);\n\n /**\n * Create an instance of this class.\n *\n * @param {Object} [options={}]\n * Object of option names and values\n *\n * @param {string} [options.kind='']\n * A valid kind for the track type you are creating.\n *\n * @param {string} [options.id='vjs_track_' + Guid.newGUID()]\n * A unique id for this AudioTrack.\n *\n * @param {string} [options.label='']\n * The menu label for this track.\n *\n * @param {string} [options.language='']\n * A valid two character language code.\n *\n * @abstract\n */\n function Track(options) {\n var _this;\n\n if (options === void 0) {\n options = {};\n }\n\n _this = _EventTarget.call(this) || this;\n var trackProps = {\n id: options.id || 'vjs_track_' + newGUID(),\n kind: options.kind || '',\n label: options.label || '',\n language: options.language || ''\n };\n /**\n * @memberof Track\n * @member {string} id\n * The id of this track. Cannot be changed after creation.\n * @instance\n *\n * @readonly\n */\n\n /**\n * @memberof Track\n * @member {string} kind\n * The kind of track that this is. Cannot be changed after creation.\n * @instance\n *\n * @readonly\n */\n\n /**\n * @memberof Track\n * @member {string} label\n * The label of this track. Cannot be changed after creation.\n * @instance\n *\n * @readonly\n */\n\n /**\n * @memberof Track\n * @member {string} language\n * The two letter language code for this track. Cannot be changed after\n * creation.\n * @instance\n *\n * @readonly\n */\n\n var _loop = function _loop(key) {\n Object.defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), key, {\n get: function get() {\n return trackProps[key];\n },\n set: function set() {}\n });\n };\n\n for (var key in trackProps) {\n _loop(key);\n }\n\n return _this;\n }\n\n return Track;\n}(EventTarget);\n\n/**\n * @file url.js\n * @module url\n */\n/**\n * @typedef {Object} url:URLObject\n *\n * @property {string} protocol\n * The protocol of the url that was parsed.\n *\n * @property {string} hostname\n * The hostname of the url that was parsed.\n *\n * @property {string} port\n * The port of the url that was parsed.\n *\n * @property {string} pathname\n * The pathname of the url that was parsed.\n *\n * @property {string} search\n * The search query of the url that was parsed.\n *\n * @property {string} hash\n * The hash of the url that was parsed.\n *\n * @property {string} host\n * The host of the url that was parsed.\n */\n\n/**\n * Resolve and parse the elements of a URL.\n *\n * @function\n * @param {String} url\n * The url to parse\n *\n * @return {url:URLObject}\n * An object of url details\n */\n\nvar parseUrl = function parseUrl(url) {\n var props = ['protocol', 'hostname', 'port', 'pathname', 'search', 'hash', 'host']; // add the url to an anchor and let the browser parse the URL\n\n var a = document.createElement('a');\n a.href = url; // IE8 (and 9?) Fix\n // ie8 doesn't parse the URL correctly until the anchor is actually\n // added to the body, and an innerHTML is needed to trigger the parsing\n\n var addToBody = a.host === '' && a.protocol !== 'file:';\n var div;\n\n if (addToBody) {\n div = document.createElement('div');\n div.innerHTML = \"<a href=\\\"\" + url + \"\\\"></a>\";\n a = div.firstChild; // prevent the div from affecting layout\n\n div.setAttribute('style', 'display:none; position:absolute;');\n document.body.appendChild(div);\n } // Copy the specific URL properties to a new object\n // This is also needed for IE8 because the anchor loses its\n // properties when it's removed from the dom\n\n\n var details = {};\n\n for (var i = 0; i < props.length; i++) {\n details[props[i]] = a[props[i]];\n } // IE9 adds the port to the host property unlike everyone else. If\n // a port identifier is added for standard ports, strip it.\n\n\n if (details.protocol === 'http:') {\n details.host = details.host.replace(/:80$/, '');\n }\n\n if (details.protocol === 'https:') {\n details.host = details.host.replace(/:443$/, '');\n }\n\n if (!details.protocol) {\n details.protocol = window$1.location.protocol;\n }\n\n if (addToBody) {\n document.body.removeChild(div);\n }\n\n return details;\n};\n/**\n * Get absolute version of relative URL. Used to tell Flash the correct URL.\n *\n * @function\n * @param {string} url\n * URL to make absolute\n *\n * @return {string}\n * Absolute URL\n *\n * @see http://stackoverflow.com/questions/470832/getting-an-absolute-url-from-a-relative-one-ie6-issue\n */\n\nvar getAbsoluteURL = function getAbsoluteURL(url) {\n // Check if absolute URL\n if (!url.match(/^https?:\\/\\//)) {\n // Convert to absolute URL. Flash hosted off-site needs an absolute URL.\n var div = document.createElement('div');\n div.innerHTML = \"<a href=\\\"\" + url + \"\\\">x</a>\";\n url = div.firstChild.href;\n }\n\n return url;\n};\n/**\n * Returns the extension of the passed file name. It will return an empty string\n * if passed an invalid path.\n *\n * @function\n * @param {string} path\n * The fileName path like '/path/to/file.mp4'\n *\n * @returns {string}\n * The extension in lower case or an empty string if no\n * extension could be found.\n */\n\nvar getFileExtension = function getFileExtension(path) {\n if (typeof path === 'string') {\n var splitPathRe = /^(\\/?)([\\s\\S]*?)((?:\\.{1,2}|[^\\/]+?)(\\.([^\\.\\/\\?]+)))(?:[\\/]*|[\\?].*)$/i;\n var pathParts = splitPathRe.exec(path);\n\n if (pathParts) {\n return pathParts.pop().toLowerCase();\n }\n }\n\n return '';\n};\n/**\n * Returns whether the url passed is a cross domain request or not.\n *\n * @function\n * @param {string} url\n * The url to check.\n *\n * @return {boolean}\n * Whether it is a cross domain request or not.\n */\n\nvar isCrossOrigin = function isCrossOrigin(url) {\n var winLoc = window$1.location;\n var urlInfo = parseUrl(url); // IE8 protocol relative urls will return ':' for protocol\n\n var srcProtocol = urlInfo.protocol === ':' ? winLoc.protocol : urlInfo.protocol; // Check if url is for another domain/origin\n // IE8 doesn't know location.origin, so we won't rely on it here\n\n var crossOrigin = srcProtocol + urlInfo.host !== winLoc.protocol + winLoc.host;\n return crossOrigin;\n};\n\nvar Url = /*#__PURE__*/Object.freeze({\n parseUrl: parseUrl,\n getAbsoluteURL: getAbsoluteURL,\n getFileExtension: getFileExtension,\n isCrossOrigin: isCrossOrigin\n});\n\n/**\n * Takes a webvtt file contents and parses it into cues\n *\n * @param {string} srcContent\n * webVTT file contents\n *\n * @param {TextTrack} track\n * TextTrack to add cues to. Cues come from the srcContent.\n *\n * @private\n */\n\nvar parseCues = function parseCues(srcContent, track) {\n var parser = new window$1.WebVTT.Parser(window$1, window$1.vttjs, window$1.WebVTT.StringDecoder());\n var errors = [];\n\n parser.oncue = function (cue) {\n track.addCue(cue);\n };\n\n parser.onparsingerror = function (error) {\n errors.push(error);\n };\n\n parser.onflush = function () {\n track.trigger({\n type: 'loadeddata',\n target: track\n });\n };\n\n parser.parse(srcContent);\n\n if (errors.length > 0) {\n if (window$1.console && window$1.console.groupCollapsed) {\n window$1.console.groupCollapsed(\"Text Track parsing errors for \" + track.src);\n }\n\n errors.forEach(function (error) {\n return log.error(error);\n });\n\n if (window$1.console && window$1.console.groupEnd) {\n window$1.console.groupEnd();\n }\n }\n\n parser.flush();\n};\n/**\n * Load a `TextTrack` from a specified url.\n *\n * @param {string} src\n * Url to load track from.\n *\n * @param {TextTrack} track\n * Track to add cues to. Comes from the content at the end of `url`.\n *\n * @private\n */\n\n\nvar loadTrack = function loadTrack(src, track) {\n var opts = {\n uri: src\n };\n var crossOrigin = isCrossOrigin(src);\n\n if (crossOrigin) {\n opts.cors = crossOrigin;\n }\n\n xhr(opts, bind(this, function (err, response, responseBody) {\n if (err) {\n return log.error(err, response);\n }\n\n track.loaded_ = true; // Make sure that vttjs has loaded, otherwise, wait till it finished loading\n // NOTE: this is only used for the alt/video.novtt.js build\n\n if (typeof window$1.WebVTT !== 'function') {\n if (track.tech_) {\n var loadHandler = function loadHandler() {\n return parseCues(responseBody, track);\n };\n\n track.tech_.on('vttjsloaded', loadHandler);\n track.tech_.on('vttjserror', function () {\n log.error(\"vttjs failed to load, stopping trying to process \" + track.src);\n track.tech_.off('vttjsloaded', loadHandler);\n });\n }\n } else {\n parseCues(responseBody, track);\n }\n }));\n};\n/**\n * A representation of a single `TextTrack`.\n *\n * @see [Spec]{@link https://html.spec.whatwg.org/multipage/embedded-content.html#texttrack}\n * @extends Track\n */\n\n\nvar TextTrack =\n/*#__PURE__*/\nfunction (_Track) {\n _inheritsLoose(TextTrack, _Track);\n\n /**\n * Create an instance of this class.\n *\n * @param {Object} options={}\n * Object of option names and values\n *\n * @param {Tech} options.tech\n * A reference to the tech that owns this TextTrack.\n *\n * @param {TextTrack~Kind} [options.kind='subtitles']\n * A valid text track kind.\n *\n * @param {TextTrack~Mode} [options.mode='disabled']\n * A valid text track mode.\n *\n * @param {string} [options.id='vjs_track_' + Guid.newGUID()]\n * A unique id for this TextTrack.\n *\n * @param {string} [options.label='']\n * The menu label for this track.\n *\n * @param {string} [options.language='']\n * A valid two character language code.\n *\n * @param {string} [options.srclang='']\n * A valid two character language code. An alternative, but deprioritized\n * version of `options.language`\n *\n * @param {string} [options.src]\n * A url to TextTrack cues.\n *\n * @param {boolean} [options.default]\n * If this track should default to on or off.\n */\n function TextTrack(options) {\n var _this;\n\n if (options === void 0) {\n options = {};\n }\n\n if (!options.tech) {\n throw new Error('A tech was not provided.');\n }\n\n var settings = mergeOptions(options, {\n kind: TextTrackKind[options.kind] || 'subtitles',\n language: options.language || options.srclang || ''\n });\n var mode = TextTrackMode[settings.mode] || 'disabled';\n var default_ = settings.default;\n\n if (settings.kind === 'metadata' || settings.kind === 'chapters') {\n mode = 'hidden';\n }\n\n _this = _Track.call(this, settings) || this;\n _this.tech_ = settings.tech;\n _this.cues_ = [];\n _this.activeCues_ = [];\n var cues = new TextTrackCueList(_this.cues_);\n var activeCues = new TextTrackCueList(_this.activeCues_);\n var changed = false;\n var timeupdateHandler = bind(_assertThisInitialized(_assertThisInitialized(_this)), function () {\n // Accessing this.activeCues for the side-effects of updating itself\n // due to it's nature as a getter function. Do not remove or cues will\n // stop updating!\n // Use the setter to prevent deletion from uglify (pure_getters rule)\n this.activeCues = this.activeCues;\n\n if (changed) {\n this.trigger('cuechange');\n changed = false;\n }\n });\n\n if (mode !== 'disabled') {\n _this.tech_.ready(function () {\n _this.tech_.on('timeupdate', timeupdateHandler);\n }, true);\n }\n\n Object.defineProperties(_assertThisInitialized(_assertThisInitialized(_this)), {\n /**\n * @memberof TextTrack\n * @member {boolean} default\n * If this track was set to be on or off by default. Cannot be changed after\n * creation.\n * @instance\n *\n * @readonly\n */\n default: {\n get: function get() {\n return default_;\n },\n set: function set() {}\n },\n\n /**\n * @memberof TextTrack\n * @member {string} mode\n * Set the mode of this TextTrack to a valid {@link TextTrack~Mode}. Will\n * not be set if setting to an invalid mode.\n * @instance\n *\n * @fires TextTrack#modechange\n */\n mode: {\n get: function get() {\n return mode;\n },\n set: function set(newMode) {\n var _this2 = this;\n\n if (!TextTrackMode[newMode]) {\n return;\n }\n\n mode = newMode;\n\n if (mode !== 'disabled') {\n this.tech_.ready(function () {\n _this2.tech_.on('timeupdate', timeupdateHandler);\n }, true);\n } else {\n this.tech_.off('timeupdate', timeupdateHandler);\n }\n /**\n * An event that fires when mode changes on this track. This allows\n * the TextTrackList that holds this track to act accordingly.\n *\n * > Note: This is not part of the spec!\n *\n * @event TextTrack#modechange\n * @type {EventTarget~Event}\n */\n\n\n this.trigger('modechange');\n }\n },\n\n /**\n * @memberof TextTrack\n * @member {TextTrackCueList} cues\n * The text track cue list for this TextTrack.\n * @instance\n */\n cues: {\n get: function get() {\n if (!this.loaded_) {\n return null;\n }\n\n return cues;\n },\n set: function set() {}\n },\n\n /**\n * @memberof TextTrack\n * @member {TextTrackCueList} activeCues\n * The list text track cues that are currently active for this TextTrack.\n * @instance\n */\n activeCues: {\n get: function get() {\n if (!this.loaded_) {\n return null;\n } // nothing to do\n\n\n if (this.cues.length === 0) {\n return activeCues;\n }\n\n var ct = this.tech_.currentTime();\n var active = [];\n\n for (var i = 0, l = this.cues.length; i < l; i++) {\n var cue = this.cues[i];\n\n if (cue.startTime <= ct && cue.endTime >= ct) {\n active.push(cue);\n } else if (cue.startTime === cue.endTime && cue.startTime <= ct && cue.startTime + 0.5 >= ct) {\n active.push(cue);\n }\n }\n\n changed = false;\n\n if (active.length !== this.activeCues_.length) {\n changed = true;\n } else {\n for (var _i = 0; _i < active.length; _i++) {\n if (this.activeCues_.indexOf(active[_i]) === -1) {\n changed = true;\n }\n }\n }\n\n this.activeCues_ = active;\n activeCues.setCues_(this.activeCues_);\n return activeCues;\n },\n // /!\\ Keep this setter empty (see the timeupdate handler above)\n set: function set() {}\n }\n });\n\n if (settings.src) {\n _this.src = settings.src;\n loadTrack(settings.src, _assertThisInitialized(_assertThisInitialized(_this)));\n } else {\n _this.loaded_ = true;\n }\n\n return _this;\n }\n /**\n * Add a cue to the internal list of cues.\n *\n * @param {TextTrack~Cue} cue\n * The cue to add to our internal list\n */\n\n\n var _proto = TextTrack.prototype;\n\n _proto.addCue = function addCue(originalCue) {\n var cue = originalCue;\n\n if (window$1.vttjs && !(originalCue instanceof window$1.vttjs.VTTCue)) {\n cue = new window$1.vttjs.VTTCue(originalCue.startTime, originalCue.endTime, originalCue.text);\n\n for (var prop in originalCue) {\n if (!(prop in cue)) {\n cue[prop] = originalCue[prop];\n }\n } // make sure that `id` is copied over\n\n\n cue.id = originalCue.id;\n cue.originalCue_ = originalCue;\n }\n\n var tracks = this.tech_.textTracks();\n\n for (var i = 0; i < tracks.length; i++) {\n if (tracks[i] !== this) {\n tracks[i].removeCue(cue);\n }\n }\n\n this.cues_.push(cue);\n this.cues.setCues_(this.cues_);\n };\n /**\n * Remove a cue from our internal list\n *\n * @param {TextTrack~Cue} removeCue\n * The cue to remove from our internal list\n */\n\n\n _proto.removeCue = function removeCue(_removeCue) {\n var i = this.cues_.length;\n\n while (i--) {\n var cue = this.cues_[i];\n\n if (cue === _removeCue || cue.originalCue_ && cue.originalCue_ === _removeCue) {\n this.cues_.splice(i, 1);\n this.cues.setCues_(this.cues_);\n break;\n }\n }\n };\n\n return TextTrack;\n}(Track);\n/**\n * cuechange - One or more cues in the track have become active or stopped being active.\n */\n\n\nTextTrack.prototype.allowedEvents_ = {\n cuechange: 'cuechange'\n};\n\n/**\n * A representation of a single `AudioTrack`. If it is part of an {@link AudioTrackList}\n * only one `AudioTrack` in the list will be enabled at a time.\n *\n * @see [Spec]{@link https://html.spec.whatwg.org/multipage/embedded-content.html#audiotrack}\n * @extends Track\n */\n\nvar AudioTrack =\n/*#__PURE__*/\nfunction (_Track) {\n _inheritsLoose(AudioTrack, _Track);\n\n /**\n * Create an instance of this class.\n *\n * @param {Object} [options={}]\n * Object of option names and values\n *\n * @param {AudioTrack~Kind} [options.kind='']\n * A valid audio track kind\n *\n * @param {string} [options.id='vjs_track_' + Guid.newGUID()]\n * A unique id for this AudioTrack.\n *\n * @param {string} [options.label='']\n * The menu label for this track.\n *\n * @param {string} [options.language='']\n * A valid two character language code.\n *\n * @param {boolean} [options.enabled]\n * If this track is the one that is currently playing. If this track is part of\n * an {@link AudioTrackList}, only one {@link AudioTrack} will be enabled.\n */\n function AudioTrack(options) {\n var _this;\n\n if (options === void 0) {\n options = {};\n }\n\n var settings = mergeOptions(options, {\n kind: AudioTrackKind[options.kind] || ''\n });\n _this = _Track.call(this, settings) || this;\n var enabled = false;\n /**\n * @memberof AudioTrack\n * @member {boolean} enabled\n * If this `AudioTrack` is enabled or not. When setting this will\n * fire {@link AudioTrack#enabledchange} if the state of enabled is changed.\n * @instance\n *\n * @fires VideoTrack#selectedchange\n */\n\n Object.defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), 'enabled', {\n get: function get() {\n return enabled;\n },\n set: function set(newEnabled) {\n // an invalid or unchanged value\n if (typeof newEnabled !== 'boolean' || newEnabled === enabled) {\n return;\n }\n\n enabled = newEnabled;\n /**\n * An event that fires when enabled changes on this track. This allows\n * the AudioTrackList that holds this track to act accordingly.\n *\n * > Note: This is not part of the spec! Native tracks will do\n * this internally without an event.\n *\n * @event AudioTrack#enabledchange\n * @type {EventTarget~Event}\n */\n\n this.trigger('enabledchange');\n }\n }); // if the user sets this track to selected then\n // set selected to that true value otherwise\n // we keep it false\n\n if (settings.enabled) {\n _this.enabled = settings.enabled;\n }\n\n _this.loaded_ = true;\n return _this;\n }\n\n return AudioTrack;\n}(Track);\n\n/**\n * A representation of a single `VideoTrack`.\n *\n * @see [Spec]{@link https://html.spec.whatwg.org/multipage/embedded-content.html#videotrack}\n * @extends Track\n */\n\nvar VideoTrack =\n/*#__PURE__*/\nfunction (_Track) {\n _inheritsLoose(VideoTrack, _Track);\n\n /**\n * Create an instance of this class.\n *\n * @param {Object} [options={}]\n * Object of option names and values\n *\n * @param {string} [options.kind='']\n * A valid {@link VideoTrack~Kind}\n *\n * @param {string} [options.id='vjs_track_' + Guid.newGUID()]\n * A unique id for this AudioTrack.\n *\n * @param {string} [options.label='']\n * The menu label for this track.\n *\n * @param {string} [options.language='']\n * A valid two character language code.\n *\n * @param {boolean} [options.selected]\n * If this track is the one that is currently playing.\n */\n function VideoTrack(options) {\n var _this;\n\n if (options === void 0) {\n options = {};\n }\n\n var settings = mergeOptions(options, {\n kind: VideoTrackKind[options.kind] || ''\n });\n _this = _Track.call(this, settings) || this;\n var selected = false;\n /**\n * @memberof VideoTrack\n * @member {boolean} selected\n * If this `VideoTrack` is selected or not. When setting this will\n * fire {@link VideoTrack#selectedchange} if the state of selected changed.\n * @instance\n *\n * @fires VideoTrack#selectedchange\n */\n\n Object.defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), 'selected', {\n get: function get() {\n return selected;\n },\n set: function set(newSelected) {\n // an invalid or unchanged value\n if (typeof newSelected !== 'boolean' || newSelected === selected) {\n return;\n }\n\n selected = newSelected;\n /**\n * An event that fires when selected changes on this track. This allows\n * the VideoTrackList that holds this track to act accordingly.\n *\n * > Note: This is not part of the spec! Native tracks will do\n * this internally without an event.\n *\n * @event VideoTrack#selectedchange\n * @type {EventTarget~Event}\n */\n\n this.trigger('selectedchange');\n }\n }); // if the user sets this track to selected then\n // set selected to that true value otherwise\n // we keep it false\n\n if (settings.selected) {\n _this.selected = settings.selected;\n }\n\n return _this;\n }\n\n return VideoTrack;\n}(Track);\n\n/**\n * @memberof HTMLTrackElement\n * @typedef {HTMLTrackElement~ReadyState}\n * @enum {number}\n */\n\nvar NONE = 0;\nvar LOADING = 1;\nvar LOADED = 2;\nvar ERROR = 3;\n/**\n * A single track represented in the DOM.\n *\n * @see [Spec]{@link https://html.spec.whatwg.org/multipage/embedded-content.html#htmltrackelement}\n * @extends EventTarget\n */\n\nvar HTMLTrackElement =\n/*#__PURE__*/\nfunction (_EventTarget) {\n _inheritsLoose(HTMLTrackElement, _EventTarget);\n\n /**\n * Create an instance of this class.\n *\n * @param {Object} options={}\n * Object of option names and values\n *\n * @param {Tech} options.tech\n * A reference to the tech that owns this HTMLTrackElement.\n *\n * @param {TextTrack~Kind} [options.kind='subtitles']\n * A valid text track kind.\n *\n * @param {TextTrack~Mode} [options.mode='disabled']\n * A valid text track mode.\n *\n * @param {string} [options.id='vjs_track_' + Guid.newGUID()]\n * A unique id for this TextTrack.\n *\n * @param {string} [options.label='']\n * The menu label for this track.\n *\n * @param {string} [options.language='']\n * A valid two character language code.\n *\n * @param {string} [options.srclang='']\n * A valid two character language code. An alternative, but deprioritized\n * vesion of `options.language`\n *\n * @param {string} [options.src]\n * A url to TextTrack cues.\n *\n * @param {boolean} [options.default]\n * If this track should default to on or off.\n */\n function HTMLTrackElement(options) {\n var _this;\n\n if (options === void 0) {\n options = {};\n }\n\n _this = _EventTarget.call(this) || this;\n var readyState;\n var track = new TextTrack(options);\n _this.kind = track.kind;\n _this.src = track.src;\n _this.srclang = track.language;\n _this.label = track.label;\n _this.default = track.default;\n Object.defineProperties(_assertThisInitialized(_assertThisInitialized(_this)), {\n /**\n * @memberof HTMLTrackElement\n * @member {HTMLTrackElement~ReadyState} readyState\n * The current ready state of the track element.\n * @instance\n */\n readyState: {\n get: function get() {\n return readyState;\n }\n },\n\n /**\n * @memberof HTMLTrackElement\n * @member {TextTrack} track\n * The underlying TextTrack object.\n * @instance\n *\n */\n track: {\n get: function get() {\n return track;\n }\n }\n });\n readyState = NONE;\n /**\n * @listens TextTrack#loadeddata\n * @fires HTMLTrackElement#load\n */\n\n track.addEventListener('loadeddata', function () {\n readyState = LOADED;\n\n _this.trigger({\n type: 'load',\n target: _assertThisInitialized(_assertThisInitialized(_this))\n });\n });\n return _this;\n }\n\n return HTMLTrackElement;\n}(EventTarget);\n\nHTMLTrackElement.prototype.allowedEvents_ = {\n load: 'load'\n};\nHTMLTrackElement.NONE = NONE;\nHTMLTrackElement.LOADING = LOADING;\nHTMLTrackElement.LOADED = LOADED;\nHTMLTrackElement.ERROR = ERROR;\n\n/*\n * This file contains all track properties that are used in\n * player.js, tech.js, html5.js and possibly other techs in the future.\n */\n\nvar NORMAL = {\n audio: {\n ListClass: AudioTrackList,\n TrackClass: AudioTrack,\n capitalName: 'Audio'\n },\n video: {\n ListClass: VideoTrackList,\n TrackClass: VideoTrack,\n capitalName: 'Video'\n },\n text: {\n ListClass: TextTrackList,\n TrackClass: TextTrack,\n capitalName: 'Text'\n }\n};\nObject.keys(NORMAL).forEach(function (type) {\n NORMAL[type].getterName = type + \"Tracks\";\n NORMAL[type].privateName = type + \"Tracks_\";\n});\nvar REMOTE = {\n remoteText: {\n ListClass: TextTrackList,\n TrackClass: TextTrack,\n capitalName: 'RemoteText',\n getterName: 'remoteTextTracks',\n privateName: 'remoteTextTracks_'\n },\n remoteTextEl: {\n ListClass: HtmlTrackElementList,\n TrackClass: HTMLTrackElement,\n capitalName: 'RemoteTextTrackEls',\n getterName: 'remoteTextTrackEls',\n privateName: 'remoteTextTrackEls_'\n }\n};\nvar ALL = mergeOptions(NORMAL, REMOTE);\nREMOTE.names = Object.keys(REMOTE);\nNORMAL.names = Object.keys(NORMAL);\nALL.names = [].concat(REMOTE.names).concat(NORMAL.names);\n\n/**\n * An Object containing a structure like: `{src: 'url', type: 'mimetype'}` or string\n * that just contains the src url alone.\n * * `var SourceObject = {src: 'http://ex.com/video.mp4', type: 'video/mp4'};`\n * `var SourceString = 'http://example.com/some-video.mp4';`\n *\n * @typedef {Object|string} Tech~SourceObject\n *\n * @property {string} src\n * The url to the source\n *\n * @property {string} type\n * The mime type of the source\n */\n\n/**\n * A function used by {@link Tech} to create a new {@link TextTrack}.\n *\n * @private\n *\n * @param {Tech} self\n * An instance of the Tech class.\n *\n * @param {string} kind\n * `TextTrack` kind (subtitles, captions, descriptions, chapters, or metadata)\n *\n * @param {string} [label]\n * Label to identify the text track\n *\n * @param {string} [language]\n * Two letter language abbreviation\n *\n * @param {Object} [options={}]\n * An object with additional text track options\n *\n * @return {TextTrack}\n * The text track that was created.\n */\n\nfunction createTrackHelper(self, kind, label, language, options) {\n if (options === void 0) {\n options = {};\n }\n\n var tracks = self.textTracks();\n options.kind = kind;\n\n if (label) {\n options.label = label;\n }\n\n if (language) {\n options.language = language;\n }\n\n options.tech = self;\n var track = new ALL.text.TrackClass(options);\n tracks.addTrack(track);\n return track;\n}\n/**\n * This is the base class for media playback technology controllers, such as\n * {@link Flash} and {@link HTML5}\n *\n * @extends Component\n */\n\n\nvar Tech =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(Tech, _Component);\n\n /**\n * Create an instance of this Tech.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n *\n * @param {Component~ReadyCallback} ready\n * Callback function to call when the `HTML5` Tech is ready.\n */\n function Tech(options, ready) {\n var _this;\n\n if (options === void 0) {\n options = {};\n }\n\n if (ready === void 0) {\n ready = function ready() {};\n }\n\n // we don't want the tech to report user activity automatically.\n // This is done manually in addControlsListeners\n options.reportTouchActivity = false;\n _this = _Component.call(this, null, options, ready) || this; // keep track of whether the current source has played at all to\n // implement a very limited played()\n\n _this.hasStarted_ = false;\n\n _this.on('playing', function () {\n this.hasStarted_ = true;\n });\n\n _this.on('loadstart', function () {\n this.hasStarted_ = false;\n });\n\n ALL.names.forEach(function (name) {\n var props = ALL[name];\n\n if (options && options[props.getterName]) {\n _this[props.privateName] = options[props.getterName];\n }\n }); // Manually track progress in cases where the browser/flash player doesn't report it.\n\n if (!_this.featuresProgressEvents) {\n _this.manualProgressOn();\n } // Manually track timeupdates in cases where the browser/flash player doesn't report it.\n\n\n if (!_this.featuresTimeupdateEvents) {\n _this.manualTimeUpdatesOn();\n }\n\n ['Text', 'Audio', 'Video'].forEach(function (track) {\n if (options[\"native\" + track + \"Tracks\"] === false) {\n _this[\"featuresNative\" + track + \"Tracks\"] = false;\n }\n });\n\n if (options.nativeCaptions === false || options.nativeTextTracks === false) {\n _this.featuresNativeTextTracks = false;\n } else if (options.nativeCaptions === true || options.nativeTextTracks === true) {\n _this.featuresNativeTextTracks = true;\n }\n\n if (!_this.featuresNativeTextTracks) {\n _this.emulateTextTracks();\n }\n\n _this.autoRemoteTextTracks_ = new ALL.text.ListClass();\n\n _this.initTrackListeners(); // Turn on component tap events only if not using native controls\n\n\n if (!options.nativeControlsForTouch) {\n _this.emitTapEvents();\n }\n\n if (_this.constructor) {\n _this.name_ = _this.constructor.name || 'Unknown Tech';\n }\n\n return _this;\n }\n /**\n * A special function to trigger source set in a way that will allow player\n * to re-trigger if the player or tech are not ready yet.\n *\n * @fires Tech#sourceset\n * @param {string} src The source string at the time of the source changing.\n */\n\n\n var _proto = Tech.prototype;\n\n _proto.triggerSourceset = function triggerSourceset(src) {\n var _this2 = this;\n\n if (!this.isReady_) {\n // on initial ready we have to trigger source set\n // 1ms after ready so that player can watch for it.\n this.one('ready', function () {\n return _this2.setTimeout(function () {\n return _this2.triggerSourceset(src);\n }, 1);\n });\n }\n /**\n * Fired when the source is set on the tech causing the media element\n * to reload.\n *\n * @see {@link Player#event:sourceset}\n * @event Tech#sourceset\n * @type {EventTarget~Event}\n */\n\n\n this.trigger({\n src: src,\n type: 'sourceset'\n });\n };\n /* Fallbacks for unsupported event types\n ================================================================================ */\n\n /**\n * Polyfill the `progress` event for browsers that don't support it natively.\n *\n * @see {@link Tech#trackProgress}\n */\n\n\n _proto.manualProgressOn = function manualProgressOn() {\n this.on('durationchange', this.onDurationChange);\n this.manualProgress = true; // Trigger progress watching when a source begins loading\n\n this.one('ready', this.trackProgress);\n };\n /**\n * Turn off the polyfill for `progress` events that was created in\n * {@link Tech#manualProgressOn}\n */\n\n\n _proto.manualProgressOff = function manualProgressOff() {\n this.manualProgress = false;\n this.stopTrackingProgress();\n this.off('durationchange', this.onDurationChange);\n };\n /**\n * This is used to trigger a `progress` event when the buffered percent changes. It\n * sets an interval function that will be called every 500 milliseconds to check if the\n * buffer end percent has changed.\n *\n * > This function is called by {@link Tech#manualProgressOn}\n *\n * @param {EventTarget~Event} event\n * The `ready` event that caused this to run.\n *\n * @listens Tech#ready\n * @fires Tech#progress\n */\n\n\n _proto.trackProgress = function trackProgress(event) {\n this.stopTrackingProgress();\n this.progressInterval = this.setInterval(bind(this, function () {\n // Don't trigger unless buffered amount is greater than last time\n var numBufferedPercent = this.bufferedPercent();\n\n if (this.bufferedPercent_ !== numBufferedPercent) {\n /**\n * See {@link Player#progress}\n *\n * @event Tech#progress\n * @type {EventTarget~Event}\n */\n this.trigger('progress');\n }\n\n this.bufferedPercent_ = numBufferedPercent;\n\n if (numBufferedPercent === 1) {\n this.stopTrackingProgress();\n }\n }), 500);\n };\n /**\n * Update our internal duration on a `durationchange` event by calling\n * {@link Tech#duration}.\n *\n * @param {EventTarget~Event} event\n * The `durationchange` event that caused this to run.\n *\n * @listens Tech#durationchange\n */\n\n\n _proto.onDurationChange = function onDurationChange(event) {\n this.duration_ = this.duration();\n };\n /**\n * Get and create a `TimeRange` object for buffering.\n *\n * @return {TimeRange}\n * The time range object that was created.\n */\n\n\n _proto.buffered = function buffered() {\n return createTimeRanges(0, 0);\n };\n /**\n * Get the percentage of the current video that is currently buffered.\n *\n * @return {number}\n * A number from 0 to 1 that represents the decimal percentage of the\n * video that is buffered.\n *\n */\n\n\n _proto.bufferedPercent = function bufferedPercent$$1() {\n return bufferedPercent(this.buffered(), this.duration_);\n };\n /**\n * Turn off the polyfill for `progress` events that was created in\n * {@link Tech#manualProgressOn}\n * Stop manually tracking progress events by clearing the interval that was set in\n * {@link Tech#trackProgress}.\n */\n\n\n _proto.stopTrackingProgress = function stopTrackingProgress() {\n this.clearInterval(this.progressInterval);\n };\n /**\n * Polyfill the `timeupdate` event for browsers that don't support it.\n *\n * @see {@link Tech#trackCurrentTime}\n */\n\n\n _proto.manualTimeUpdatesOn = function manualTimeUpdatesOn() {\n this.manualTimeUpdates = true;\n this.on('play', this.trackCurrentTime);\n this.on('pause', this.stopTrackingCurrentTime);\n };\n /**\n * Turn off the polyfill for `timeupdate` events that was created in\n * {@link Tech#manualTimeUpdatesOn}\n */\n\n\n _proto.manualTimeUpdatesOff = function manualTimeUpdatesOff() {\n this.manualTimeUpdates = false;\n this.stopTrackingCurrentTime();\n this.off('play', this.trackCurrentTime);\n this.off('pause', this.stopTrackingCurrentTime);\n };\n /**\n * Sets up an interval function to track current time and trigger `timeupdate` every\n * 250 milliseconds.\n *\n * @listens Tech#play\n * @triggers Tech#timeupdate\n */\n\n\n _proto.trackCurrentTime = function trackCurrentTime() {\n if (this.currentTimeInterval) {\n this.stopTrackingCurrentTime();\n }\n\n this.currentTimeInterval = this.setInterval(function () {\n /**\n * Triggered at an interval of 250ms to indicated that time is passing in the video.\n *\n * @event Tech#timeupdate\n * @type {EventTarget~Event}\n */\n this.trigger({\n type: 'timeupdate',\n target: this,\n manuallyTriggered: true\n }); // 42 = 24 fps // 250 is what Webkit uses // FF uses 15\n }, 250);\n };\n /**\n * Stop the interval function created in {@link Tech#trackCurrentTime} so that the\n * `timeupdate` event is no longer triggered.\n *\n * @listens {Tech#pause}\n */\n\n\n _proto.stopTrackingCurrentTime = function stopTrackingCurrentTime() {\n this.clearInterval(this.currentTimeInterval); // #1002 - if the video ends right before the next timeupdate would happen,\n // the progress bar won't make it all the way to the end\n\n this.trigger({\n type: 'timeupdate',\n target: this,\n manuallyTriggered: true\n });\n };\n /**\n * Turn off all event polyfills, clear the `Tech`s {@link AudioTrackList},\n * {@link VideoTrackList}, and {@link TextTrackList}, and dispose of this Tech.\n *\n * @fires Component#dispose\n */\n\n\n _proto.dispose = function dispose() {\n // clear out all tracks because we can't reuse them between techs\n this.clearTracks(NORMAL.names); // Turn off any manual progress or timeupdate tracking\n\n if (this.manualProgress) {\n this.manualProgressOff();\n }\n\n if (this.manualTimeUpdates) {\n this.manualTimeUpdatesOff();\n }\n\n _Component.prototype.dispose.call(this);\n };\n /**\n * Clear out a single `TrackList` or an array of `TrackLists` given their names.\n *\n * > Note: Techs without source handlers should call this between sources for `video`\n * & `audio` tracks. You don't want to use them between tracks!\n *\n * @param {string[]|string} types\n * TrackList names to clear, valid names are `video`, `audio`, and\n * `text`.\n */\n\n\n _proto.clearTracks = function clearTracks(types) {\n var _this3 = this;\n\n types = [].concat(types); // clear out all tracks because we can't reuse them between techs\n\n types.forEach(function (type) {\n var list = _this3[type + \"Tracks\"]() || [];\n var i = list.length;\n\n while (i--) {\n var track = list[i];\n\n if (type === 'text') {\n _this3.removeRemoteTextTrack(track);\n }\n\n list.removeTrack(track);\n }\n });\n };\n /**\n * Remove any TextTracks added via addRemoteTextTrack that are\n * flagged for automatic garbage collection\n */\n\n\n _proto.cleanupAutoTextTracks = function cleanupAutoTextTracks() {\n var list = this.autoRemoteTextTracks_ || [];\n var i = list.length;\n\n while (i--) {\n var track = list[i];\n this.removeRemoteTextTrack(track);\n }\n };\n /**\n * Reset the tech, which will removes all sources and reset the internal readyState.\n *\n * @abstract\n */\n\n\n _proto.reset = function reset() {};\n /**\n * Get or set an error on the Tech.\n *\n * @param {MediaError} [err]\n * Error to set on the Tech\n *\n * @return {MediaError|null}\n * The current error object on the tech, or null if there isn't one.\n */\n\n\n _proto.error = function error(err) {\n if (err !== undefined) {\n this.error_ = new MediaError(err);\n this.trigger('error');\n }\n\n return this.error_;\n };\n /**\n * Returns the `TimeRange`s that have been played through for the current source.\n *\n * > NOTE: This implementation is incomplete. It does not track the played `TimeRange`.\n * It only checks whether the source has played at all or not.\n *\n * @return {TimeRange}\n * - A single time range if this video has played\n * - An empty set of ranges if not.\n */\n\n\n _proto.played = function played() {\n if (this.hasStarted_) {\n return createTimeRanges(0, 0);\n }\n\n return createTimeRanges();\n };\n /**\n * Causes a manual time update to occur if {@link Tech#manualTimeUpdatesOn} was\n * previously called.\n *\n * @fires Tech#timeupdate\n */\n\n\n _proto.setCurrentTime = function setCurrentTime() {\n // improve the accuracy of manual timeupdates\n if (this.manualTimeUpdates) {\n /**\n * A manual `timeupdate` event.\n *\n * @event Tech#timeupdate\n * @type {EventTarget~Event}\n */\n this.trigger({\n type: 'timeupdate',\n target: this,\n manuallyTriggered: true\n });\n }\n };\n /**\n * Turn on listeners for {@link VideoTrackList}, {@link {AudioTrackList}, and\n * {@link TextTrackList} events.\n *\n * This adds {@link EventTarget~EventListeners} for `addtrack`, and `removetrack`.\n *\n * @fires Tech#audiotrackchange\n * @fires Tech#videotrackchange\n * @fires Tech#texttrackchange\n */\n\n\n _proto.initTrackListeners = function initTrackListeners() {\n var _this4 = this;\n\n /**\n * Triggered when tracks are added or removed on the Tech {@link AudioTrackList}\n *\n * @event Tech#audiotrackchange\n * @type {EventTarget~Event}\n */\n\n /**\n * Triggered when tracks are added or removed on the Tech {@link VideoTrackList}\n *\n * @event Tech#videotrackchange\n * @type {EventTarget~Event}\n */\n\n /**\n * Triggered when tracks are added or removed on the Tech {@link TextTrackList}\n *\n * @event Tech#texttrackchange\n * @type {EventTarget~Event}\n */\n NORMAL.names.forEach(function (name) {\n var props = NORMAL[name];\n\n var trackListChanges = function trackListChanges() {\n _this4.trigger(name + \"trackchange\");\n };\n\n var tracks = _this4[props.getterName]();\n\n tracks.addEventListener('removetrack', trackListChanges);\n tracks.addEventListener('addtrack', trackListChanges);\n\n _this4.on('dispose', function () {\n tracks.removeEventListener('removetrack', trackListChanges);\n tracks.removeEventListener('addtrack', trackListChanges);\n });\n });\n };\n /**\n * Emulate TextTracks using vtt.js if necessary\n *\n * @fires Tech#vttjsloaded\n * @fires Tech#vttjserror\n */\n\n\n _proto.addWebVttScript_ = function addWebVttScript_() {\n var _this5 = this;\n\n if (window$1.WebVTT) {\n return;\n } // Initially, Tech.el_ is a child of a dummy-div wait until the Component system\n // signals that the Tech is ready at which point Tech.el_ is part of the DOM\n // before inserting the WebVTT script\n\n\n if (document.body.contains(this.el())) {\n // load via require if available and vtt.js script location was not passed in\n // as an option. novtt builds will turn the above require call into an empty object\n // which will cause this if check to always fail.\n if (!this.options_['vtt.js'] && isPlain(vtt) && Object.keys(vtt).length > 0) {\n this.trigger('vttjsloaded');\n return;\n } // load vtt.js via the script location option or the cdn of no location was\n // passed in\n\n\n var script = document.createElement('script');\n script.src = this.options_['vtt.js'] || 'https://vjs.zencdn.net/vttjs/0.14.1/vtt.min.js';\n\n script.onload = function () {\n /**\n * Fired when vtt.js is loaded.\n *\n * @event Tech#vttjsloaded\n * @type {EventTarget~Event}\n */\n _this5.trigger('vttjsloaded');\n };\n\n script.onerror = function () {\n /**\n * Fired when vtt.js was not loaded due to an error\n *\n * @event Tech#vttjsloaded\n * @type {EventTarget~Event}\n */\n _this5.trigger('vttjserror');\n };\n\n this.on('dispose', function () {\n script.onload = null;\n script.onerror = null;\n }); // but have not loaded yet and we set it to true before the inject so that\n // we don't overwrite the injected window.WebVTT if it loads right away\n\n window$1.WebVTT = true;\n this.el().parentNode.appendChild(script);\n } else {\n this.ready(this.addWebVttScript_);\n }\n };\n /**\n * Emulate texttracks\n *\n */\n\n\n _proto.emulateTextTracks = function emulateTextTracks() {\n var _this6 = this;\n\n var tracks = this.textTracks();\n var remoteTracks = this.remoteTextTracks();\n\n var handleAddTrack = function handleAddTrack(e) {\n return tracks.addTrack(e.track);\n };\n\n var handleRemoveTrack = function handleRemoveTrack(e) {\n return tracks.removeTrack(e.track);\n };\n\n remoteTracks.on('addtrack', handleAddTrack);\n remoteTracks.on('removetrack', handleRemoveTrack);\n this.addWebVttScript_();\n\n var updateDisplay = function updateDisplay() {\n return _this6.trigger('texttrackchange');\n };\n\n var textTracksChanges = function textTracksChanges() {\n updateDisplay();\n\n for (var i = 0; i < tracks.length; i++) {\n var track = tracks[i];\n track.removeEventListener('cuechange', updateDisplay);\n\n if (track.mode === 'showing') {\n track.addEventListener('cuechange', updateDisplay);\n }\n }\n };\n\n textTracksChanges();\n tracks.addEventListener('change', textTracksChanges);\n tracks.addEventListener('addtrack', textTracksChanges);\n tracks.addEventListener('removetrack', textTracksChanges);\n this.on('dispose', function () {\n remoteTracks.off('addtrack', handleAddTrack);\n remoteTracks.off('removetrack', handleRemoveTrack);\n tracks.removeEventListener('change', textTracksChanges);\n tracks.removeEventListener('addtrack', textTracksChanges);\n tracks.removeEventListener('removetrack', textTracksChanges);\n\n for (var i = 0; i < tracks.length; i++) {\n var track = tracks[i];\n track.removeEventListener('cuechange', updateDisplay);\n }\n });\n };\n /**\n * Create and returns a remote {@link TextTrack} object.\n *\n * @param {string} kind\n * `TextTrack` kind (subtitles, captions, descriptions, chapters, or metadata)\n *\n * @param {string} [label]\n * Label to identify the text track\n *\n * @param {string} [language]\n * Two letter language abbreviation\n *\n * @return {TextTrack}\n * The TextTrack that gets created.\n */\n\n\n _proto.addTextTrack = function addTextTrack(kind, label, language) {\n if (!kind) {\n throw new Error('TextTrack kind is required but was not provided');\n }\n\n return createTrackHelper(this, kind, label, language);\n };\n /**\n * Create an emulated TextTrack for use by addRemoteTextTrack\n *\n * This is intended to be overridden by classes that inherit from\n * Tech in order to create native or custom TextTracks.\n *\n * @param {Object} options\n * The object should contain the options to initialize the TextTrack with.\n *\n * @param {string} [options.kind]\n * `TextTrack` kind (subtitles, captions, descriptions, chapters, or metadata).\n *\n * @param {string} [options.label].\n * Label to identify the text track\n *\n * @param {string} [options.language]\n * Two letter language abbreviation.\n *\n * @return {HTMLTrackElement}\n * The track element that gets created.\n */\n\n\n _proto.createRemoteTextTrack = function createRemoteTextTrack(options) {\n var track = mergeOptions(options, {\n tech: this\n });\n return new REMOTE.remoteTextEl.TrackClass(track);\n };\n /**\n * Creates a remote text track object and returns an html track element.\n *\n * > Note: This can be an emulated {@link HTMLTrackElement} or a native one.\n *\n * @param {Object} options\n * See {@link Tech#createRemoteTextTrack} for more detailed properties.\n *\n * @param {boolean} [manualCleanup=true]\n * - When false: the TextTrack will be automatically removed from the video\n * element whenever the source changes\n * - When True: The TextTrack will have to be cleaned up manually\n *\n * @return {HTMLTrackElement}\n * An Html Track Element.\n *\n * @deprecated The default functionality for this function will be equivalent\n * to \"manualCleanup=false\" in the future. The manualCleanup parameter will\n * also be removed.\n */\n\n\n _proto.addRemoteTextTrack = function addRemoteTextTrack(options, manualCleanup) {\n var _this7 = this;\n\n if (options === void 0) {\n options = {};\n }\n\n var htmlTrackElement = this.createRemoteTextTrack(options);\n\n if (manualCleanup !== true && manualCleanup !== false) {\n // deprecation warning\n log.warn('Calling addRemoteTextTrack without explicitly setting the \"manualCleanup\" parameter to `true` is deprecated and default to `false` in future version of video.js');\n manualCleanup = true;\n } // store HTMLTrackElement and TextTrack to remote list\n\n\n this.remoteTextTrackEls().addTrackElement_(htmlTrackElement);\n this.remoteTextTracks().addTrack(htmlTrackElement.track);\n\n if (manualCleanup !== true) {\n // create the TextTrackList if it doesn't exist\n this.ready(function () {\n return _this7.autoRemoteTextTracks_.addTrack(htmlTrackElement.track);\n });\n }\n\n return htmlTrackElement;\n };\n /**\n * Remove a remote text track from the remote `TextTrackList`.\n *\n * @param {TextTrack} track\n * `TextTrack` to remove from the `TextTrackList`\n */\n\n\n _proto.removeRemoteTextTrack = function removeRemoteTextTrack(track) {\n var trackElement = this.remoteTextTrackEls().getTrackElementByTrack_(track); // remove HTMLTrackElement and TextTrack from remote list\n\n this.remoteTextTrackEls().removeTrackElement_(trackElement);\n this.remoteTextTracks().removeTrack(track);\n this.autoRemoteTextTracks_.removeTrack(track);\n };\n /**\n * Gets available media playback quality metrics as specified by the W3C's Media\n * Playback Quality API.\n *\n * @see [Spec]{@link https://wicg.github.io/media-playback-quality}\n *\n * @return {Object}\n * An object with supported media playback quality metrics\n *\n * @abstract\n */\n\n\n _proto.getVideoPlaybackQuality = function getVideoPlaybackQuality() {\n return {};\n };\n /**\n * A method to set a poster from a `Tech`.\n *\n * @abstract\n */\n\n\n _proto.setPoster = function setPoster() {};\n /**\n * A method to check for the presence of the 'playsinline' <video> attribute.\n *\n * @abstract\n */\n\n\n _proto.playsinline = function playsinline() {};\n /**\n * A method to set or unset the 'playsinline' <video> attribute.\n *\n * @abstract\n */\n\n\n _proto.setPlaysinline = function setPlaysinline() {};\n /**\n * Attempt to force override of native audio tracks.\n *\n * @param {boolean} override - If set to true native audio will be overridden,\n * otherwise native audio will potentially be used.\n *\n * @abstract\n */\n\n\n _proto.overrideNativeAudioTracks = function overrideNativeAudioTracks() {};\n /**\n * Attempt to force override of native video tracks.\n *\n * @param {boolean} override - If set to true native video will be overridden,\n * otherwise native video will potentially be used.\n *\n * @abstract\n */\n\n\n _proto.overrideNativeVideoTracks = function overrideNativeVideoTracks() {};\n /*\n * Check if the tech can support the given mime-type.\n *\n * The base tech does not support any type, but source handlers might\n * overwrite this.\n *\n * @param {string} type\n * The mimetype to check for support\n *\n * @return {string}\n * 'probably', 'maybe', or empty string\n *\n * @see [Spec]{@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/canPlayType}\n *\n * @abstract\n */\n\n\n _proto.canPlayType = function canPlayType() {\n return '';\n };\n /**\n * Check if the type is supported by this tech.\n *\n * The base tech does not support any type, but source handlers might\n * overwrite this.\n *\n * @param {string} type\n * The media type to check\n * @return {string} Returns the native video element's response\n */\n\n\n Tech.canPlayType = function canPlayType() {\n return '';\n };\n /**\n * Check if the tech can support the given source\n *\n * @param {Object} srcObj\n * The source object\n * @param {Object} options\n * The options passed to the tech\n * @return {string} 'probably', 'maybe', or '' (empty string)\n */\n\n\n Tech.canPlaySource = function canPlaySource(srcObj, options) {\n return Tech.canPlayType(srcObj.type);\n };\n /*\n * Return whether the argument is a Tech or not.\n * Can be passed either a Class like `Html5` or a instance like `player.tech_`\n *\n * @param {Object} component\n * The item to check\n *\n * @return {boolean}\n * Whether it is a tech or not\n * - True if it is a tech\n * - False if it is not\n */\n\n\n Tech.isTech = function isTech(component) {\n return component.prototype instanceof Tech || component instanceof Tech || component === Tech;\n };\n /**\n * Registers a `Tech` into a shared list for videojs.\n *\n * @param {string} name\n * Name of the `Tech` to register.\n *\n * @param {Object} tech\n * The `Tech` class to register.\n */\n\n\n Tech.registerTech = function registerTech(name, tech) {\n if (!Tech.techs_) {\n Tech.techs_ = {};\n }\n\n if (!Tech.isTech(tech)) {\n throw new Error(\"Tech \" + name + \" must be a Tech\");\n }\n\n if (!Tech.canPlayType) {\n throw new Error('Techs must have a static canPlayType method on them');\n }\n\n if (!Tech.canPlaySource) {\n throw new Error('Techs must have a static canPlaySource method on them');\n }\n\n name = toTitleCase(name);\n Tech.techs_[name] = tech;\n\n if (name !== 'Tech') {\n // camel case the techName for use in techOrder\n Tech.defaultTechOrder_.push(name);\n }\n\n return tech;\n };\n /**\n * Get a `Tech` from the shared list by name.\n *\n * @param {string} name\n * `camelCase` or `TitleCase` name of the Tech to get\n *\n * @return {Tech|undefined}\n * The `Tech` or undefined if there was no tech with the name requested.\n */\n\n\n Tech.getTech = function getTech(name) {\n if (!name) {\n return;\n }\n\n name = toTitleCase(name);\n\n if (Tech.techs_ && Tech.techs_[name]) {\n return Tech.techs_[name];\n }\n\n if (window$1 && window$1.videojs && window$1.videojs[name]) {\n log.warn(\"The \" + name + \" tech was added to the videojs object when it should be registered using videojs.registerTech(name, tech)\");\n return window$1.videojs[name];\n }\n };\n\n return Tech;\n}(Component);\n/**\n * Get the {@link VideoTrackList}\n *\n * @returns {VideoTrackList}\n * @method Tech.prototype.videoTracks\n */\n\n/**\n * Get the {@link AudioTrackList}\n *\n * @returns {AudioTrackList}\n * @method Tech.prototype.audioTracks\n */\n\n/**\n * Get the {@link TextTrackList}\n *\n * @returns {TextTrackList}\n * @method Tech.prototype.textTracks\n */\n\n/**\n * Get the remote element {@link TextTrackList}\n *\n * @returns {TextTrackList}\n * @method Tech.prototype.remoteTextTracks\n */\n\n/**\n * Get the remote element {@link HtmlTrackElementList}\n *\n * @returns {HtmlTrackElementList}\n * @method Tech.prototype.remoteTextTrackEls\n */\n\n\nALL.names.forEach(function (name) {\n var props = ALL[name];\n\n Tech.prototype[props.getterName] = function () {\n this[props.privateName] = this[props.privateName] || new props.ListClass();\n return this[props.privateName];\n };\n});\n/**\n * List of associated text tracks\n *\n * @type {TextTrackList}\n * @private\n * @property Tech#textTracks_\n */\n\n/**\n * List of associated audio tracks.\n *\n * @type {AudioTrackList}\n * @private\n * @property Tech#audioTracks_\n */\n\n/**\n * List of associated video tracks.\n *\n * @type {VideoTrackList}\n * @private\n * @property Tech#videoTracks_\n */\n\n/**\n * Boolean indicating whether the `Tech` supports volume control.\n *\n * @type {boolean}\n * @default\n */\n\nTech.prototype.featuresVolumeControl = true;\n/**\n * Boolean indicating whether the `Tech` supports muting volume.\n *\n * @type {bolean}\n * @default\n */\n\nTech.prototype.featuresMuteControl = true;\n/**\n * Boolean indicating whether the `Tech` supports fullscreen resize control.\n * Resizing plugins using request fullscreen reloads the plugin\n *\n * @type {boolean}\n * @default\n */\n\nTech.prototype.featuresFullscreenResize = false;\n/**\n * Boolean indicating whether the `Tech` supports changing the speed at which the video\n * plays. Examples:\n * - Set player to play 2x (twice) as fast\n * - Set player to play 0.5x (half) as fast\n *\n * @type {boolean}\n * @default\n */\n\nTech.prototype.featuresPlaybackRate = false;\n/**\n * Boolean indicating whether the `Tech` supports the `progress` event. This is currently\n * not triggered by video-js-swf. This will be used to determine if\n * {@link Tech#manualProgressOn} should be called.\n *\n * @type {boolean}\n * @default\n */\n\nTech.prototype.featuresProgressEvents = false;\n/**\n * Boolean indicating whether the `Tech` supports the `sourceset` event.\n *\n * A tech should set this to `true` and then use {@link Tech#triggerSourceset}\n * to trigger a {@link Tech#event:sourceset} at the earliest time after getting\n * a new source.\n *\n * @type {boolean}\n * @default\n */\n\nTech.prototype.featuresSourceset = false;\n/**\n * Boolean indicating whether the `Tech` supports the `timeupdate` event. This is currently\n * not triggered by video-js-swf. This will be used to determine if\n * {@link Tech#manualTimeUpdates} should be called.\n *\n * @type {boolean}\n * @default\n */\n\nTech.prototype.featuresTimeupdateEvents = false;\n/**\n * Boolean indicating whether the `Tech` supports the native `TextTrack`s.\n * This will help us integrate with native `TextTrack`s if the browser supports them.\n *\n * @type {boolean}\n * @default\n */\n\nTech.prototype.featuresNativeTextTracks = false;\n/**\n * A functional mixin for techs that want to use the Source Handler pattern.\n * Source handlers are scripts for handling specific formats.\n * The source handler pattern is used for adaptive formats (HLS, DASH) that\n * manually load video data and feed it into a Source Buffer (Media Source Extensions)\n * Example: `Tech.withSourceHandlers.call(MyTech);`\n *\n * @param {Tech} _Tech\n * The tech to add source handler functions to.\n *\n * @mixes Tech~SourceHandlerAdditions\n */\n\nTech.withSourceHandlers = function (_Tech) {\n /**\n * Register a source handler\n *\n * @param {Function} handler\n * The source handler class\n *\n * @param {number} [index]\n * Register it at the following index\n */\n _Tech.registerSourceHandler = function (handler, index) {\n var handlers = _Tech.sourceHandlers;\n\n if (!handlers) {\n handlers = _Tech.sourceHandlers = [];\n }\n\n if (index === undefined) {\n // add to the end of the list\n index = handlers.length;\n }\n\n handlers.splice(index, 0, handler);\n };\n /**\n * Check if the tech can support the given type. Also checks the\n * Techs sourceHandlers.\n *\n * @param {string} type\n * The mimetype to check.\n *\n * @return {string}\n * 'probably', 'maybe', or '' (empty string)\n */\n\n\n _Tech.canPlayType = function (type) {\n var handlers = _Tech.sourceHandlers || [];\n var can;\n\n for (var i = 0; i < handlers.length; i++) {\n can = handlers[i].canPlayType(type);\n\n if (can) {\n return can;\n }\n }\n\n return '';\n };\n /**\n * Returns the first source handler that supports the source.\n *\n * TODO: Answer question: should 'probably' be prioritized over 'maybe'\n *\n * @param {Tech~SourceObject} source\n * The source object\n *\n * @param {Object} options\n * The options passed to the tech\n *\n * @return {SourceHandler|null}\n * The first source handler that supports the source or null if\n * no SourceHandler supports the source\n */\n\n\n _Tech.selectSourceHandler = function (source, options) {\n var handlers = _Tech.sourceHandlers || [];\n var can;\n\n for (var i = 0; i < handlers.length; i++) {\n can = handlers[i].canHandleSource(source, options);\n\n if (can) {\n return handlers[i];\n }\n }\n\n return null;\n };\n /**\n * Check if the tech can support the given source.\n *\n * @param {Tech~SourceObject} srcObj\n * The source object\n *\n * @param {Object} options\n * The options passed to the tech\n *\n * @return {string}\n * 'probably', 'maybe', or '' (empty string)\n */\n\n\n _Tech.canPlaySource = function (srcObj, options) {\n var sh = _Tech.selectSourceHandler(srcObj, options);\n\n if (sh) {\n return sh.canHandleSource(srcObj, options);\n }\n\n return '';\n };\n /**\n * When using a source handler, prefer its implementation of\n * any function normally provided by the tech.\n */\n\n\n var deferrable = ['seekable', 'seeking', 'duration'];\n /**\n * A wrapper around {@link Tech#seekable} that will call a `SourceHandler`s seekable\n * function if it exists, with a fallback to the Techs seekable function.\n *\n * @method _Tech.seekable\n */\n\n /**\n * A wrapper around {@link Tech#duration} that will call a `SourceHandler`s duration\n * function if it exists, otherwise it will fallback to the techs duration function.\n *\n * @method _Tech.duration\n */\n\n deferrable.forEach(function (fnName) {\n var originalFn = this[fnName];\n\n if (typeof originalFn !== 'function') {\n return;\n }\n\n this[fnName] = function () {\n if (this.sourceHandler_ && this.sourceHandler_[fnName]) {\n return this.sourceHandler_[fnName].apply(this.sourceHandler_, arguments);\n }\n\n return originalFn.apply(this, arguments);\n };\n }, _Tech.prototype);\n /**\n * Create a function for setting the source using a source object\n * and source handlers.\n * Should never be called unless a source handler was found.\n *\n * @param {Tech~SourceObject} source\n * A source object with src and type keys\n */\n\n _Tech.prototype.setSource = function (source) {\n var sh = _Tech.selectSourceHandler(source, this.options_);\n\n if (!sh) {\n // Fall back to a native source hander when unsupported sources are\n // deliberately set\n if (_Tech.nativeSourceHandler) {\n sh = _Tech.nativeSourceHandler;\n } else {\n log.error('No source handler found for the current source.');\n }\n } // Dispose any existing source handler\n\n\n this.disposeSourceHandler();\n this.off('dispose', this.disposeSourceHandler);\n\n if (sh !== _Tech.nativeSourceHandler) {\n this.currentSource_ = source;\n }\n\n this.sourceHandler_ = sh.handleSource(source, this, this.options_);\n this.on('dispose', this.disposeSourceHandler);\n };\n /**\n * Clean up any existing SourceHandlers and listeners when the Tech is disposed.\n *\n * @listens Tech#dispose\n */\n\n\n _Tech.prototype.disposeSourceHandler = function () {\n // if we have a source and get another one\n // then we are loading something new\n // than clear all of our current tracks\n if (this.currentSource_) {\n this.clearTracks(['audio', 'video']);\n this.currentSource_ = null;\n } // always clean up auto-text tracks\n\n\n this.cleanupAutoTextTracks();\n\n if (this.sourceHandler_) {\n if (this.sourceHandler_.dispose) {\n this.sourceHandler_.dispose();\n }\n\n this.sourceHandler_ = null;\n }\n };\n}; // The base Tech class needs to be registered as a Component. It is the only\n// Tech that can be registered as a Component.\n\n\nComponent.registerComponent('Tech', Tech);\nTech.registerTech('Tech', Tech);\n/**\n * A list of techs that should be added to techOrder on Players\n *\n * @private\n */\n\nTech.defaultTechOrder_ = [];\n\n/**\n * @file middleware.js\n * @module middleware\n */\nvar middlewares = {};\nvar middlewareInstances = {};\nvar TERMINATOR = {};\n/**\n * A middleware object is a plain JavaScript object that has methods that\n * match the {@link Tech} methods found in the lists of allowed\n * {@link module:middleware.allowedGetters|getters},\n * {@link module:middleware.allowedSetters|setters}, and\n * {@link module:middleware.allowedMediators|mediators}.\n *\n * @typedef {Object} MiddlewareObject\n */\n\n/**\n * A middleware factory function that should return a\n * {@link module:middleware~MiddlewareObject|MiddlewareObject}.\n *\n * This factory will be called for each player when needed, with the player\n * passed in as an argument.\n *\n * @callback MiddlewareFactory\n * @param {Player} player\n * A Video.js player.\n */\n\n/**\n * Define a middleware that the player should use by way of a factory function\n * that returns a middleware object.\n *\n * @param {string} type\n * The MIME type to match or `\"*\"` for all MIME types.\n *\n * @param {MiddlewareFactory} middleware\n * A middleware factory function that will be executed for\n * matching types.\n */\n\nfunction use(type, middleware) {\n middlewares[type] = middlewares[type] || [];\n middlewares[type].push(middleware);\n}\n/**\n * Asynchronously sets a source using middleware by recursing through any\n * matching middlewares and calling `setSource` on each, passing along the\n * previous returned value each time.\n *\n * @param {Player} player\n * A {@link Player} instance.\n *\n * @param {Tech~SourceObject} src\n * A source object.\n *\n * @param {Function}\n * The next middleware to run.\n */\n\nfunction setSource(player, src, next) {\n player.setTimeout(function () {\n return setSourceHelper(src, middlewares[src.type], next, player);\n }, 1);\n}\n/**\n * When the tech is set, passes the tech to each middleware's `setTech` method.\n *\n * @param {Object[]} middleware\n * An array of middleware instances.\n *\n * @param {Tech} tech\n * A Video.js tech.\n */\n\nfunction setTech(middleware, tech) {\n middleware.forEach(function (mw) {\n return mw.setTech && mw.setTech(tech);\n });\n}\n/**\n * Calls a getter on the tech first, through each middleware\n * from right to left to the player.\n *\n * @param {Object[]} middleware\n * An array of middleware instances.\n *\n * @param {Tech} tech\n * The current tech.\n *\n * @param {string} method\n * A method name.\n *\n * @return {Mixed}\n * The final value from the tech after middleware has intercepted it.\n */\n\nfunction get(middleware, tech, method) {\n return middleware.reduceRight(middlewareIterator(method), tech[method]());\n}\n/**\n * Takes the argument given to the player and calls the setter method on each\n * middleware from left to right to the tech.\n *\n * @param {Object[]} middleware\n * An array of middleware instances.\n *\n * @param {Tech} tech\n * The current tech.\n *\n * @param {string} method\n * A method name.\n *\n * @param {Mixed} arg\n * The value to set on the tech.\n *\n * @return {Mixed}\n * The return value of the `method` of the `tech`.\n */\n\nfunction set$1(middleware, tech, method, arg) {\n return tech[method](middleware.reduce(middlewareIterator(method), arg));\n}\n/**\n * Takes the argument given to the player and calls the `call` version of the\n * method on each middleware from left to right.\n *\n * Then, call the passed in method on the tech and return the result unchanged\n * back to the player, through middleware, this time from right to left.\n *\n * @param {Object[]} middleware\n * An array of middleware instances.\n *\n * @param {Tech} tech\n * The current tech.\n *\n * @param {string} method\n * A method name.\n *\n * @param {Mixed} arg\n * The value to set on the tech.\n *\n * @return {Mixed}\n * The return value of the `method` of the `tech`, regardless of the\n * return values of middlewares.\n */\n\nfunction mediate(middleware, tech, method, arg) {\n if (arg === void 0) {\n arg = null;\n }\n\n var callMethod = 'call' + toTitleCase(method);\n var middlewareValue = middleware.reduce(middlewareIterator(callMethod), arg);\n var terminated = middlewareValue === TERMINATOR;\n var returnValue = terminated ? null : tech[method](middlewareValue);\n executeRight(middleware, method, returnValue, terminated);\n return returnValue;\n}\n/**\n * Enumeration of allowed getters where the keys are method names.\n *\n * @type {Object}\n */\n\nvar allowedGetters = {\n buffered: 1,\n currentTime: 1,\n duration: 1,\n seekable: 1,\n played: 1,\n paused: 1\n};\n/**\n * Enumeration of allowed setters where the keys are method names.\n *\n * @type {Object}\n */\n\nvar allowedSetters = {\n setCurrentTime: 1\n};\n/**\n * Enumeration of allowed mediators where the keys are method names.\n *\n * @type {Object}\n */\n\nvar allowedMediators = {\n play: 1,\n pause: 1\n};\n\nfunction middlewareIterator(method) {\n return function (value, mw) {\n // if the previous middleware terminated, pass along the termination\n if (value === TERMINATOR) {\n return TERMINATOR;\n }\n\n if (mw[method]) {\n return mw[method](value);\n }\n\n return value;\n };\n}\n\nfunction executeRight(mws, method, value, terminated) {\n for (var i = mws.length - 1; i >= 0; i--) {\n var mw = mws[i];\n\n if (mw[method]) {\n mw[method](terminated, value);\n }\n }\n}\n/**\n * Clear the middleware cache for a player.\n *\n * @param {Player} player\n * A {@link Player} instance.\n */\n\n\nfunction clearCacheForPlayer(player) {\n middlewareInstances[player.id()] = null;\n}\n/**\n * {\n * [playerId]: [[mwFactory, mwInstance], ...]\n * }\n *\n * @private\n */\n\nfunction getOrCreateFactory(player, mwFactory) {\n var mws = middlewareInstances[player.id()];\n var mw = null;\n\n if (mws === undefined || mws === null) {\n mw = mwFactory(player);\n middlewareInstances[player.id()] = [[mwFactory, mw]];\n return mw;\n }\n\n for (var i = 0; i < mws.length; i++) {\n var _mws$i = mws[i],\n mwf = _mws$i[0],\n mwi = _mws$i[1];\n\n if (mwf !== mwFactory) {\n continue;\n }\n\n mw = mwi;\n }\n\n if (mw === null) {\n mw = mwFactory(player);\n mws.push([mwFactory, mw]);\n }\n\n return mw;\n}\n\nfunction setSourceHelper(src, middleware, next, player, acc, lastRun) {\n if (src === void 0) {\n src = {};\n }\n\n if (middleware === void 0) {\n middleware = [];\n }\n\n if (acc === void 0) {\n acc = [];\n }\n\n if (lastRun === void 0) {\n lastRun = false;\n }\n\n var _middleware = middleware,\n mwFactory = _middleware[0],\n mwrest = _middleware.slice(1); // if mwFactory is a string, then we're at a fork in the road\n\n\n if (typeof mwFactory === 'string') {\n setSourceHelper(src, middlewares[mwFactory], next, player, acc, lastRun); // if we have an mwFactory, call it with the player to get the mw,\n // then call the mw's setSource method\n } else if (mwFactory) {\n var mw = getOrCreateFactory(player, mwFactory); // if setSource isn't present, implicitly select this middleware\n\n if (!mw.setSource) {\n acc.push(mw);\n return setSourceHelper(src, mwrest, next, player, acc, lastRun);\n }\n\n mw.setSource(assign({}, src), function (err, _src) {\n // something happened, try the next middleware on the current level\n // make sure to use the old src\n if (err) {\n return setSourceHelper(src, mwrest, next, player, acc, lastRun);\n } // we've succeeded, now we need to go deeper\n\n\n acc.push(mw); // if it's the same type, continue down the current chain\n // otherwise, we want to go down the new chain\n\n setSourceHelper(_src, src.type === _src.type ? mwrest : middlewares[_src.type], next, player, acc, lastRun);\n });\n } else if (mwrest.length) {\n setSourceHelper(src, mwrest, next, player, acc, lastRun);\n } else if (lastRun) {\n next(src, acc);\n } else {\n setSourceHelper(src, middlewares['*'], next, player, acc, true);\n }\n}\n\n/**\n * Mimetypes\n *\n * @see http://hul.harvard.edu/ois/////systems/wax/wax-public-help/mimetypes.htm\n * @typedef Mimetypes~Kind\n * @enum\n */\n\nvar MimetypesKind = {\n opus: 'video/ogg',\n ogv: 'video/ogg',\n mp4: 'video/mp4',\n mov: 'video/mp4',\n m4v: 'video/mp4',\n mkv: 'video/x-matroska',\n mp3: 'audio/mpeg',\n aac: 'audio/aac',\n oga: 'audio/ogg',\n m3u8: 'application/x-mpegURL'\n};\n/**\n * Get the mimetype of a given src url if possible\n *\n * @param {string} src\n * The url to the src\n *\n * @return {string}\n * return the mimetype if it was known or empty string otherwise\n */\n\nvar getMimetype = function getMimetype(src) {\n if (src === void 0) {\n src = '';\n }\n\n var ext = getFileExtension(src);\n var mimetype = MimetypesKind[ext.toLowerCase()];\n return mimetype || '';\n};\n/**\n * Find the mime type of a given source string if possible. Uses the player\n * source cache.\n *\n * @param {Player} player\n * The player object\n *\n * @param {string} src\n * The source string\n *\n * @return {string}\n * The type that was found\n */\n\nvar findMimetype = function findMimetype(player, src) {\n if (!src) {\n return '';\n } // 1. check for the type in the `source` cache\n\n\n if (player.cache_.source.src === src && player.cache_.source.type) {\n return player.cache_.source.type;\n } // 2. see if we have this source in our `currentSources` cache\n\n\n var matchingSources = player.cache_.sources.filter(function (s) {\n return s.src === src;\n });\n\n if (matchingSources.length) {\n return matchingSources[0].type;\n } // 3. look for the src url in source elements and use the type there\n\n\n var sources = player.$$('source');\n\n for (var i = 0; i < sources.length; i++) {\n var s = sources[i];\n\n if (s.type && s.src && s.src === src) {\n return s.type;\n }\n } // 4. finally fallback to our list of mime types based on src url extension\n\n\n return getMimetype(src);\n};\n\n/**\n * @module filter-source\n */\n/**\n * Filter out single bad source objects or multiple source objects in an\n * array. Also flattens nested source object arrays into a 1 dimensional\n * array of source objects.\n *\n * @param {Tech~SourceObject|Tech~SourceObject[]} src\n * The src object to filter\n *\n * @return {Tech~SourceObject[]}\n * An array of sourceobjects containing only valid sources\n *\n * @private\n */\n\nvar filterSource = function filterSource(src) {\n // traverse array\n if (Array.isArray(src)) {\n var newsrc = [];\n src.forEach(function (srcobj) {\n srcobj = filterSource(srcobj);\n\n if (Array.isArray(srcobj)) {\n newsrc = newsrc.concat(srcobj);\n } else if (isObject(srcobj)) {\n newsrc.push(srcobj);\n }\n });\n src = newsrc;\n } else if (typeof src === 'string' && src.trim()) {\n // convert string into object\n src = [fixSource({\n src: src\n })];\n } else if (isObject(src) && typeof src.src === 'string' && src.src && src.src.trim()) {\n // src is already valid\n src = [fixSource(src)];\n } else {\n // invalid source, turn it into an empty array\n src = [];\n }\n\n return src;\n};\n/**\n * Checks src mimetype, adding it when possible\n *\n * @param {Tech~SourceObject} src\n * The src object to check\n * @return {Tech~SourceObject}\n * src Object with known type\n */\n\n\nfunction fixSource(src) {\n var mimetype = getMimetype(src.src);\n\n if (!src.type && mimetype) {\n src.type = mimetype;\n }\n\n return src;\n}\n\n/**\n * The `MediaLoader` is the `Component` that decides which playback technology to load\n * when a player is initialized.\n *\n * @extends Component\n */\n\nvar MediaLoader =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(MediaLoader, _Component);\n\n /**\n * Create an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should attach to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n *\n * @param {Component~ReadyCallback} [ready]\n * The function that is run when this component is ready.\n */\n function MediaLoader(player, options, ready) {\n var _this;\n\n // MediaLoader has no element\n var options_ = mergeOptions({\n createEl: false\n }, options);\n _this = _Component.call(this, player, options_, ready) || this; // If there are no sources when the player is initialized,\n // load the first supported playback technology.\n\n if (!options.playerOptions.sources || options.playerOptions.sources.length === 0) {\n for (var i = 0, j = options.playerOptions.techOrder; i < j.length; i++) {\n var techName = toTitleCase(j[i]);\n var tech = Tech.getTech(techName); // Support old behavior of techs being registered as components.\n // Remove once that deprecated behavior is removed.\n\n if (!techName) {\n tech = Component.getComponent(techName);\n } // Check if the browser supports this technology\n\n\n if (tech && tech.isSupported()) {\n player.loadTech_(techName);\n break;\n }\n }\n } else {\n // Loop through playback technologies (HTML5, Flash) and check for support.\n // Then load the best source.\n // A few assumptions here:\n // All playback technologies respect preload false.\n player.src(options.playerOptions.sources);\n }\n\n return _this;\n }\n\n return MediaLoader;\n}(Component);\n\nComponent.registerComponent('MediaLoader', MediaLoader);\n\n/**\n * Clickable Component which is clickable or keyboard actionable,\n * but is not a native HTML button.\n *\n * @extends Component\n */\n\nvar ClickableComponent =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(ClickableComponent, _Component);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function ClickableComponent(player, options) {\n var _this;\n\n _this = _Component.call(this, player, options) || this;\n\n _this.emitTapEvents();\n\n _this.enable();\n\n return _this;\n }\n /**\n * Create the `Component`s DOM element.\n *\n * @param {string} [tag=div]\n * The element's node type.\n *\n * @param {Object} [props={}]\n * An object of properties that should be set on the element.\n *\n * @param {Object} [attributes={}]\n * An object of attributes that should be set on the element.\n *\n * @return {Element}\n * The element that gets created.\n */\n\n\n var _proto = ClickableComponent.prototype;\n\n _proto.createEl = function createEl$$1(tag, props, attributes) {\n if (tag === void 0) {\n tag = 'div';\n }\n\n if (props === void 0) {\n props = {};\n }\n\n if (attributes === void 0) {\n attributes = {};\n }\n\n props = assign({\n innerHTML: '<span aria-hidden=\"true\" class=\"vjs-icon-placeholder\"></span>',\n className: this.buildCSSClass(),\n tabIndex: 0\n }, props);\n\n if (tag === 'button') {\n log.error(\"Creating a ClickableComponent with an HTML element of \" + tag + \" is not supported; use a Button instead.\");\n } // Add ARIA attributes for clickable element which is not a native HTML button\n\n\n attributes = assign({\n role: 'button'\n }, attributes);\n this.tabIndex_ = props.tabIndex;\n\n var el = _Component.prototype.createEl.call(this, tag, props, attributes);\n\n this.createControlTextEl(el);\n return el;\n };\n\n _proto.dispose = function dispose() {\n // remove controlTextEl_ on dispose\n this.controlTextEl_ = null;\n\n _Component.prototype.dispose.call(this);\n };\n /**\n * Create a control text element on this `Component`\n *\n * @param {Element} [el]\n * Parent element for the control text.\n *\n * @return {Element}\n * The control text element that gets created.\n */\n\n\n _proto.createControlTextEl = function createControlTextEl(el) {\n this.controlTextEl_ = createEl('span', {\n className: 'vjs-control-text'\n }, {\n // let the screen reader user know that the text of the element may change\n 'aria-live': 'polite'\n });\n\n if (el) {\n el.appendChild(this.controlTextEl_);\n }\n\n this.controlText(this.controlText_, el);\n return this.controlTextEl_;\n };\n /**\n * Get or set the localize text to use for the controls on the `Component`.\n *\n * @param {string} [text]\n * Control text for element.\n *\n * @param {Element} [el=this.el()]\n * Element to set the title on.\n *\n * @return {string}\n * - The control text when getting\n */\n\n\n _proto.controlText = function controlText(text, el) {\n if (el === void 0) {\n el = this.el();\n }\n\n if (text === undefined) {\n return this.controlText_ || 'Need Text';\n }\n\n var localizedText = this.localize(text);\n this.controlText_ = text;\n textContent(this.controlTextEl_, localizedText);\n\n if (!this.nonIconControl) {\n // Set title attribute if only an icon is shown\n el.setAttribute('title', localizedText);\n }\n };\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n\n\n _proto.buildCSSClass = function buildCSSClass() {\n return \"vjs-control vjs-button \" + _Component.prototype.buildCSSClass.call(this);\n };\n /**\n * Enable this `Component`s element.\n */\n\n\n _proto.enable = function enable() {\n if (!this.enabled_) {\n this.enabled_ = true;\n this.removeClass('vjs-disabled');\n this.el_.setAttribute('aria-disabled', 'false');\n\n if (typeof this.tabIndex_ !== 'undefined') {\n this.el_.setAttribute('tabIndex', this.tabIndex_);\n }\n\n this.on(['tap', 'click'], this.handleClick);\n this.on('focus', this.handleFocus);\n this.on('blur', this.handleBlur);\n }\n };\n /**\n * Disable this `Component`s element.\n */\n\n\n _proto.disable = function disable() {\n this.enabled_ = false;\n this.addClass('vjs-disabled');\n this.el_.setAttribute('aria-disabled', 'true');\n\n if (typeof this.tabIndex_ !== 'undefined') {\n this.el_.removeAttribute('tabIndex');\n }\n\n this.off(['tap', 'click'], this.handleClick);\n this.off('focus', this.handleFocus);\n this.off('blur', this.handleBlur);\n };\n /**\n * This gets called when a `ClickableComponent` gets:\n * - Clicked (via the `click` event, listening starts in the constructor)\n * - Tapped (via the `tap` event, listening starts in the constructor)\n * - The following things happen in order:\n * 1. {@link ClickableComponent#handleFocus} is called via a `focus` event on the\n * `ClickableComponent`.\n * 2. {@link ClickableComponent#handleFocus} adds a listener for `keydown` on using\n * {@link ClickableComponent#handleKeyPress}.\n * 3. `ClickableComponent` has not had a `blur` event (`blur` means that focus was lost). The user presses\n * the space or enter key.\n * 4. {@link ClickableComponent#handleKeyPress} calls this function with the `keydown`\n * event as a parameter.\n *\n * @param {EventTarget~Event} event\n * The `keydown`, `tap`, or `click` event that caused this function to be\n * called.\n *\n * @listens tap\n * @listens click\n * @abstract\n */\n\n\n _proto.handleClick = function handleClick(event) {};\n /**\n * This gets called when a `ClickableComponent` gains focus via a `focus` event.\n * Turns on listening for `keydown` events. When they happen it\n * calls `this.handleKeyPress`.\n *\n * @param {EventTarget~Event} event\n * The `focus` event that caused this function to be called.\n *\n * @listens focus\n */\n\n\n _proto.handleFocus = function handleFocus(event) {\n on(document, 'keydown', bind(this, this.handleKeyPress));\n };\n /**\n * Called when this ClickableComponent has focus and a key gets pressed down. By\n * default it will call `this.handleClick` when the key is space or enter.\n *\n * @param {EventTarget~Event} event\n * The `keydown` event that caused this function to be called.\n *\n * @listens keydown\n */\n\n\n _proto.handleKeyPress = function handleKeyPress(event) {\n // Support Space (32) or Enter (13) key operation to fire a click event\n if (event.which === 32 || event.which === 13) {\n event.preventDefault();\n this.trigger('click');\n } else if (_Component.prototype.handleKeyPress) {\n // Pass keypress handling up for unsupported keys\n _Component.prototype.handleKeyPress.call(this, event);\n }\n };\n /**\n * Called when a `ClickableComponent` loses focus. Turns off the listener for\n * `keydown` events. Which Stops `this.handleKeyPress` from getting called.\n *\n * @param {EventTarget~Event} event\n * The `blur` event that caused this function to be called.\n *\n * @listens blur\n */\n\n\n _proto.handleBlur = function handleBlur(event) {\n off(document, 'keydown', bind(this, this.handleKeyPress));\n };\n\n return ClickableComponent;\n}(Component);\n\nComponent.registerComponent('ClickableComponent', ClickableComponent);\n\n/**\n * A `ClickableComponent` that handles showing the poster image for the player.\n *\n * @extends ClickableComponent\n */\n\nvar PosterImage =\n/*#__PURE__*/\nfunction (_ClickableComponent) {\n _inheritsLoose(PosterImage, _ClickableComponent);\n\n /**\n * Create an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should attach to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function PosterImage(player, options) {\n var _this;\n\n _this = _ClickableComponent.call(this, player, options) || this;\n\n _this.update();\n\n player.on('posterchange', bind(_assertThisInitialized(_assertThisInitialized(_this)), _this.update));\n return _this;\n }\n /**\n * Clean up and dispose of the `PosterImage`.\n */\n\n\n var _proto = PosterImage.prototype;\n\n _proto.dispose = function dispose() {\n this.player().off('posterchange', this.update);\n\n _ClickableComponent.prototype.dispose.call(this);\n };\n /**\n * Create the `PosterImage`s DOM element.\n *\n * @return {Element}\n * The element that gets created.\n */\n\n\n _proto.createEl = function createEl$$1() {\n var el = createEl('div', {\n className: 'vjs-poster',\n // Don't want poster to be tabbable.\n tabIndex: -1\n });\n return el;\n };\n /**\n * An {@link EventTarget~EventListener} for {@link Player#posterchange} events.\n *\n * @listens Player#posterchange\n *\n * @param {EventTarget~Event} [event]\n * The `Player#posterchange` event that triggered this function.\n */\n\n\n _proto.update = function update(event) {\n var url = this.player().poster();\n this.setSrc(url); // If there's no poster source we should display:none on this component\n // so it's not still clickable or right-clickable\n\n if (url) {\n this.show();\n } else {\n this.hide();\n }\n };\n /**\n * Set the source of the `PosterImage` depending on the display method.\n *\n * @param {string} url\n * The URL to the source for the `PosterImage`.\n */\n\n\n _proto.setSrc = function setSrc(url) {\n var backgroundImage = ''; // Any falsy value should stay as an empty string, otherwise\n // this will throw an extra error\n\n if (url) {\n backgroundImage = \"url(\\\"\" + url + \"\\\")\";\n }\n\n this.el_.style.backgroundImage = backgroundImage;\n };\n /**\n * An {@link EventTarget~EventListener} for clicks on the `PosterImage`. See\n * {@link ClickableComponent#handleClick} for instances where this will be triggered.\n *\n * @listens tap\n * @listens click\n * @listens keydown\n *\n * @param {EventTarget~Event} event\n + The `click`, `tap` or `keydown` event that caused this function to be called.\n */\n\n\n _proto.handleClick = function handleClick(event) {\n // We don't want a click to trigger playback when controls are disabled\n if (!this.player_.controls()) {\n return;\n }\n\n if (this.player_.paused()) {\n silencePromise(this.player_.play());\n } else {\n this.player_.pause();\n }\n };\n\n return PosterImage;\n}(ClickableComponent);\n\nComponent.registerComponent('PosterImage', PosterImage);\n\nvar darkGray = '#222';\nvar lightGray = '#ccc';\nvar fontMap = {\n monospace: 'monospace',\n sansSerif: 'sans-serif',\n serif: 'serif',\n monospaceSansSerif: '\"Andale Mono\", \"Lucida Console\", monospace',\n monospaceSerif: '\"Courier New\", monospace',\n proportionalSansSerif: 'sans-serif',\n proportionalSerif: 'serif',\n casual: '\"Comic Sans MS\", Impact, fantasy',\n script: '\"Monotype Corsiva\", cursive',\n smallcaps: '\"Andale Mono\", \"Lucida Console\", monospace, sans-serif'\n};\n/**\n * Construct an rgba color from a given hex color code.\n *\n * @param {number} color\n * Hex number for color, like #f0e or #f604e2.\n *\n * @param {number} opacity\n * Value for opacity, 0.0 - 1.0.\n *\n * @return {string}\n * The rgba color that was created, like 'rgba(255, 0, 0, 0.3)'.\n */\n\nfunction constructColor(color, opacity) {\n var hex;\n\n if (color.length === 4) {\n // color looks like \"#f0e\"\n hex = color[1] + color[1] + color[2] + color[2] + color[3] + color[3];\n } else if (color.length === 7) {\n // color looks like \"#f604e2\"\n hex = color.slice(1);\n } else {\n throw new Error('Invalid color code provided, ' + color + '; must be formatted as e.g. #f0e or #f604e2.');\n }\n\n return 'rgba(' + parseInt(hex.slice(0, 2), 16) + ',' + parseInt(hex.slice(2, 4), 16) + ',' + parseInt(hex.slice(4, 6), 16) + ',' + opacity + ')';\n}\n/**\n * Try to update the style of a DOM element. Some style changes will throw an error,\n * particularly in IE8. Those should be noops.\n *\n * @param {Element} el\n * The DOM element to be styled.\n *\n * @param {string} style\n * The CSS property on the element that should be styled.\n *\n * @param {string} rule\n * The style rule that should be applied to the property.\n *\n * @private\n */\n\nfunction tryUpdateStyle(el, style, rule) {\n try {\n el.style[style] = rule;\n } catch (e) {\n // Satisfies linter.\n return;\n }\n}\n/**\n * The component for displaying text track cues.\n *\n * @extends Component\n */\n\n\nvar TextTrackDisplay =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(TextTrackDisplay, _Component);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n *\n * @param {Component~ReadyCallback} [ready]\n * The function to call when `TextTrackDisplay` is ready.\n */\n function TextTrackDisplay(player, options, ready) {\n var _this;\n\n _this = _Component.call(this, player, options, ready) || this;\n var updateDisplayHandler = bind(_assertThisInitialized(_assertThisInitialized(_this)), _this.updateDisplay);\n player.on('loadstart', bind(_assertThisInitialized(_assertThisInitialized(_this)), _this.toggleDisplay));\n player.on('texttrackchange', updateDisplayHandler);\n player.on('loadedmetadata', bind(_assertThisInitialized(_assertThisInitialized(_this)), _this.preselectTrack)); // This used to be called during player init, but was causing an error\n // if a track should show by default and the display hadn't loaded yet.\n // Should probably be moved to an external track loader when we support\n // tracks that don't need a display.\n\n player.ready(bind(_assertThisInitialized(_assertThisInitialized(_this)), function () {\n if (player.tech_ && player.tech_.featuresNativeTextTracks) {\n this.hide();\n return;\n }\n\n player.on('fullscreenchange', updateDisplayHandler);\n player.on('playerresize', updateDisplayHandler);\n window$1.addEventListener('orientationchange', updateDisplayHandler);\n player.on('dispose', function () {\n return window$1.removeEventListener('orientationchange', updateDisplayHandler);\n });\n var tracks = this.options_.playerOptions.tracks || [];\n\n for (var i = 0; i < tracks.length; i++) {\n this.player_.addRemoteTextTrack(tracks[i], true);\n }\n\n this.preselectTrack();\n }));\n return _this;\n }\n /**\n * Preselect a track following this precedence:\n * - matches the previously selected {@link TextTrack}'s language and kind\n * - matches the previously selected {@link TextTrack}'s language only\n * - is the first default captions track\n * - is the first default descriptions track\n *\n * @listens Player#loadstart\n */\n\n\n var _proto = TextTrackDisplay.prototype;\n\n _proto.preselectTrack = function preselectTrack() {\n var modes = {\n captions: 1,\n subtitles: 1\n };\n var trackList = this.player_.textTracks();\n var userPref = this.player_.cache_.selectedLanguage;\n var firstDesc;\n var firstCaptions;\n var preferredTrack;\n\n for (var i = 0; i < trackList.length; i++) {\n var track = trackList[i];\n\n if (userPref && userPref.enabled && userPref.language && userPref.language === track.language && track.kind in modes) {\n // Always choose the track that matches both language and kind\n if (track.kind === userPref.kind) {\n preferredTrack = track; // or choose the first track that matches language\n } else if (!preferredTrack) {\n preferredTrack = track;\n } // clear everything if offTextTrackMenuItem was clicked\n\n } else if (userPref && !userPref.enabled) {\n preferredTrack = null;\n firstDesc = null;\n firstCaptions = null;\n } else if (track.default) {\n if (track.kind === 'descriptions' && !firstDesc) {\n firstDesc = track;\n } else if (track.kind in modes && !firstCaptions) {\n firstCaptions = track;\n }\n }\n } // The preferredTrack matches the user preference and takes\n // precedence over all the other tracks.\n // So, display the preferredTrack before the first default track\n // and the subtitles/captions track before the descriptions track\n\n\n if (preferredTrack) {\n preferredTrack.mode = 'showing';\n } else if (firstCaptions) {\n firstCaptions.mode = 'showing';\n } else if (firstDesc) {\n firstDesc.mode = 'showing';\n }\n };\n /**\n * Turn display of {@link TextTrack}'s from the current state into the other state.\n * There are only two states:\n * - 'shown'\n * - 'hidden'\n *\n * @listens Player#loadstart\n */\n\n\n _proto.toggleDisplay = function toggleDisplay() {\n if (this.player_.tech_ && this.player_.tech_.featuresNativeTextTracks) {\n this.hide();\n } else {\n this.show();\n }\n };\n /**\n * Create the {@link Component}'s DOM element.\n *\n * @return {Element}\n * The element that was created.\n */\n\n\n _proto.createEl = function createEl() {\n return _Component.prototype.createEl.call(this, 'div', {\n className: 'vjs-text-track-display'\n }, {\n 'aria-live': 'off',\n 'aria-atomic': 'true'\n });\n };\n /**\n * Clear all displayed {@link TextTrack}s.\n */\n\n\n _proto.clearDisplay = function clearDisplay() {\n if (typeof window$1.WebVTT === 'function') {\n window$1.WebVTT.processCues(window$1, [], this.el_);\n }\n };\n /**\n * Update the displayed TextTrack when a either a {@link Player#texttrackchange} or\n * a {@link Player#fullscreenchange} is fired.\n *\n * @listens Player#texttrackchange\n * @listens Player#fullscreenchange\n */\n\n\n _proto.updateDisplay = function updateDisplay() {\n var tracks = this.player_.textTracks();\n this.clearDisplay(); // Track display prioritization model: if multiple tracks are 'showing',\n // display the first 'subtitles' or 'captions' track which is 'showing',\n // otherwise display the first 'descriptions' track which is 'showing'\n\n var descriptionsTrack = null;\n var captionsSubtitlesTrack = null;\n var i = tracks.length;\n\n while (i--) {\n var track = tracks[i];\n\n if (track.mode === 'showing') {\n if (track.kind === 'descriptions') {\n descriptionsTrack = track;\n } else {\n captionsSubtitlesTrack = track;\n }\n }\n }\n\n if (captionsSubtitlesTrack) {\n if (this.getAttribute('aria-live') !== 'off') {\n this.setAttribute('aria-live', 'off');\n }\n\n this.updateForTrack(captionsSubtitlesTrack);\n } else if (descriptionsTrack) {\n if (this.getAttribute('aria-live') !== 'assertive') {\n this.setAttribute('aria-live', 'assertive');\n }\n\n this.updateForTrack(descriptionsTrack);\n }\n };\n /**\n * Add an {@link TextTrack} to to the {@link Tech}s {@link TextTrackList}.\n *\n * @param {TextTrack} track\n * Text track object to be added to the list.\n */\n\n\n _proto.updateForTrack = function updateForTrack(track) {\n if (typeof window$1.WebVTT !== 'function' || !track.activeCues) {\n return;\n }\n\n var cues = [];\n\n for (var _i = 0; _i < track.activeCues.length; _i++) {\n cues.push(track.activeCues[_i]);\n }\n\n window$1.WebVTT.processCues(window$1, cues, this.el_);\n\n if (!this.player_.textTrackSettings) {\n return;\n }\n\n var overrides = this.player_.textTrackSettings.getValues();\n var i = cues.length;\n\n while (i--) {\n var cue = cues[i];\n\n if (!cue) {\n continue;\n }\n\n var cueDiv = cue.displayState;\n\n if (overrides.color) {\n cueDiv.firstChild.style.color = overrides.color;\n }\n\n if (overrides.textOpacity) {\n tryUpdateStyle(cueDiv.firstChild, 'color', constructColor(overrides.color || '#fff', overrides.textOpacity));\n }\n\n if (overrides.backgroundColor) {\n cueDiv.firstChild.style.backgroundColor = overrides.backgroundColor;\n }\n\n if (overrides.backgroundOpacity) {\n tryUpdateStyle(cueDiv.firstChild, 'backgroundColor', constructColor(overrides.backgroundColor || '#000', overrides.backgroundOpacity));\n }\n\n if (overrides.windowColor) {\n if (overrides.windowOpacity) {\n tryUpdateStyle(cueDiv, 'backgroundColor', constructColor(overrides.windowColor, overrides.windowOpacity));\n } else {\n cueDiv.style.backgroundColor = overrides.windowColor;\n }\n }\n\n if (overrides.edgeStyle) {\n if (overrides.edgeStyle === 'dropshadow') {\n cueDiv.firstChild.style.textShadow = \"2px 2px 3px \" + darkGray + \", 2px 2px 4px \" + darkGray + \", 2px 2px 5px \" + darkGray;\n } else if (overrides.edgeStyle === 'raised') {\n cueDiv.firstChild.style.textShadow = \"1px 1px \" + darkGray + \", 2px 2px \" + darkGray + \", 3px 3px \" + darkGray;\n } else if (overrides.edgeStyle === 'depressed') {\n cueDiv.firstChild.style.textShadow = \"1px 1px \" + lightGray + \", 0 1px \" + lightGray + \", -1px -1px \" + darkGray + \", 0 -1px \" + darkGray;\n } else if (overrides.edgeStyle === 'uniform') {\n cueDiv.firstChild.style.textShadow = \"0 0 4px \" + darkGray + \", 0 0 4px \" + darkGray + \", 0 0 4px \" + darkGray + \", 0 0 4px \" + darkGray;\n }\n }\n\n if (overrides.fontPercent && overrides.fontPercent !== 1) {\n var fontSize = window$1.parseFloat(cueDiv.style.fontSize);\n cueDiv.style.fontSize = fontSize * overrides.fontPercent + 'px';\n cueDiv.style.height = 'auto';\n cueDiv.style.top = 'auto';\n cueDiv.style.bottom = '2px';\n }\n\n if (overrides.fontFamily && overrides.fontFamily !== 'default') {\n if (overrides.fontFamily === 'small-caps') {\n cueDiv.firstChild.style.fontVariant = 'small-caps';\n } else {\n cueDiv.firstChild.style.fontFamily = fontMap[overrides.fontFamily];\n }\n }\n }\n };\n\n return TextTrackDisplay;\n}(Component);\n\nComponent.registerComponent('TextTrackDisplay', TextTrackDisplay);\n\n/**\n * A loading spinner for use during waiting/loading events.\n *\n * @extends Component\n */\n\nvar LoadingSpinner =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(LoadingSpinner, _Component);\n\n function LoadingSpinner() {\n return _Component.apply(this, arguments) || this;\n }\n\n var _proto = LoadingSpinner.prototype;\n\n /**\n * Create the `LoadingSpinner`s DOM element.\n *\n * @return {Element}\n * The dom element that gets created.\n */\n _proto.createEl = function createEl$$1() {\n var isAudio = this.player_.isAudio();\n var playerType = this.localize(isAudio ? 'Audio Player' : 'Video Player');\n var controlText = createEl('span', {\n className: 'vjs-control-text',\n innerHTML: this.localize('{1} is loading.', [playerType])\n });\n\n var el = _Component.prototype.createEl.call(this, 'div', {\n className: 'vjs-loading-spinner',\n dir: 'ltr'\n });\n\n el.appendChild(controlText);\n return el;\n };\n\n return LoadingSpinner;\n}(Component);\n\nComponent.registerComponent('LoadingSpinner', LoadingSpinner);\n\n/**\n * Base class for all buttons.\n *\n * @extends ClickableComponent\n */\n\nvar Button =\n/*#__PURE__*/\nfunction (_ClickableComponent) {\n _inheritsLoose(Button, _ClickableComponent);\n\n function Button() {\n return _ClickableComponent.apply(this, arguments) || this;\n }\n\n var _proto = Button.prototype;\n\n /**\n * Create the `Button`s DOM element.\n *\n * @param {string} [tag=\"button\"]\n * The element's node type. This argument is IGNORED: no matter what\n * is passed, it will always create a `button` element.\n *\n * @param {Object} [props={}]\n * An object of properties that should be set on the element.\n *\n * @param {Object} [attributes={}]\n * An object of attributes that should be set on the element.\n *\n * @return {Element}\n * The element that gets created.\n */\n _proto.createEl = function createEl(tag, props, attributes) {\n if (props === void 0) {\n props = {};\n }\n\n if (attributes === void 0) {\n attributes = {};\n }\n\n tag = 'button';\n props = assign({\n innerHTML: '<span aria-hidden=\"true\" class=\"vjs-icon-placeholder\"></span>',\n className: this.buildCSSClass()\n }, props); // Add attributes for button element\n\n attributes = assign({\n // Necessary since the default button type is \"submit\"\n type: 'button'\n }, attributes);\n var el = Component.prototype.createEl.call(this, tag, props, attributes);\n this.createControlTextEl(el);\n return el;\n };\n /**\n * Add a child `Component` inside of this `Button`.\n *\n * @param {string|Component} child\n * The name or instance of a child to add.\n *\n * @param {Object} [options={}]\n * The key/value store of options that will get passed to children of\n * the child.\n *\n * @return {Component}\n * The `Component` that gets added as a child. When using a string the\n * `Component` will get created by this process.\n *\n * @deprecated since version 5\n */\n\n\n _proto.addChild = function addChild(child, options) {\n if (options === void 0) {\n options = {};\n }\n\n var className = this.constructor.name;\n log.warn(\"Adding an actionable (user controllable) child to a Button (\" + className + \") is not supported; use a ClickableComponent instead.\"); // Avoid the error message generated by ClickableComponent's addChild method\n\n return Component.prototype.addChild.call(this, child, options);\n };\n /**\n * Enable the `Button` element so that it can be activated or clicked. Use this with\n * {@link Button#disable}.\n */\n\n\n _proto.enable = function enable() {\n _ClickableComponent.prototype.enable.call(this);\n\n this.el_.removeAttribute('disabled');\n };\n /**\n * Disable the `Button` element so that it cannot be activated or clicked. Use this with\n * {@link Button#enable}.\n */\n\n\n _proto.disable = function disable() {\n _ClickableComponent.prototype.disable.call(this);\n\n this.el_.setAttribute('disabled', 'disabled');\n };\n /**\n * This gets called when a `Button` has focus and `keydown` is triggered via a key\n * press.\n *\n * @param {EventTarget~Event} event\n * The event that caused this function to get called.\n *\n * @listens keydown\n */\n\n\n _proto.handleKeyPress = function handleKeyPress(event) {\n // Ignore Space (32) or Enter (13) key operation, which is handled by the browser for a button.\n if (event.which === 32 || event.which === 13) {\n return;\n } // Pass keypress handling up for unsupported keys\n\n\n _ClickableComponent.prototype.handleKeyPress.call(this, event);\n };\n\n return Button;\n}(ClickableComponent);\n\nComponent.registerComponent('Button', Button);\n\n/**\n * The initial play button that shows before the video has played. The hiding of the\n * `BigPlayButton` get done via CSS and `Player` states.\n *\n * @extends Button\n */\n\nvar BigPlayButton =\n/*#__PURE__*/\nfunction (_Button) {\n _inheritsLoose(BigPlayButton, _Button);\n\n function BigPlayButton(player, options) {\n var _this;\n\n _this = _Button.call(this, player, options) || this;\n _this.mouseused_ = false;\n\n _this.on('mousedown', _this.handleMouseDown);\n\n return _this;\n }\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object. Always returns 'vjs-big-play-button'.\n */\n\n\n var _proto = BigPlayButton.prototype;\n\n _proto.buildCSSClass = function buildCSSClass() {\n return 'vjs-big-play-button';\n };\n /**\n * This gets called when a `BigPlayButton` \"clicked\". See {@link ClickableComponent}\n * for more detailed information on what a click can be.\n *\n * @param {EventTarget~Event} event\n * The `keydown`, `tap`, or `click` event that caused this function to be\n * called.\n *\n * @listens tap\n * @listens click\n */\n\n\n _proto.handleClick = function handleClick(event) {\n var playPromise = this.player_.play(); // exit early if clicked via the mouse\n\n if (this.mouseused_ && event.clientX && event.clientY) {\n silencePromise(playPromise);\n return;\n }\n\n var cb = this.player_.getChild('controlBar');\n var playToggle = cb && cb.getChild('playToggle');\n\n if (!playToggle) {\n this.player_.focus();\n return;\n }\n\n var playFocus = function playFocus() {\n return playToggle.focus();\n };\n\n if (isPromise(playPromise)) {\n playPromise.then(playFocus, function () {});\n } else {\n this.setTimeout(playFocus, 1);\n }\n };\n\n _proto.handleKeyPress = function handleKeyPress(event) {\n this.mouseused_ = false;\n\n _Button.prototype.handleKeyPress.call(this, event);\n };\n\n _proto.handleMouseDown = function handleMouseDown(event) {\n this.mouseused_ = true;\n };\n\n return BigPlayButton;\n}(Button);\n/**\n * The text that should display over the `BigPlayButton`s controls. Added to for localization.\n *\n * @type {string}\n * @private\n */\n\n\nBigPlayButton.prototype.controlText_ = 'Play Video';\nComponent.registerComponent('BigPlayButton', BigPlayButton);\n\n/**\n * The `CloseButton` is a `{@link Button}` that fires a `close` event when\n * it gets clicked.\n *\n * @extends Button\n */\n\nvar CloseButton =\n/*#__PURE__*/\nfunction (_Button) {\n _inheritsLoose(CloseButton, _Button);\n\n /**\n * Creates an instance of the this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function CloseButton(player, options) {\n var _this;\n\n _this = _Button.call(this, player, options) || this;\n\n _this.controlText(options && options.controlText || _this.localize('Close'));\n\n return _this;\n }\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n\n\n var _proto = CloseButton.prototype;\n\n _proto.buildCSSClass = function buildCSSClass() {\n return \"vjs-close-button \" + _Button.prototype.buildCSSClass.call(this);\n };\n /**\n * This gets called when a `CloseButton` gets clicked. See\n * {@link ClickableComponent#handleClick} for more information on when this will be\n * triggered\n *\n * @param {EventTarget~Event} event\n * The `keydown`, `tap`, or `click` event that caused this function to be\n * called.\n *\n * @listens tap\n * @listens click\n * @fires CloseButton#close\n */\n\n\n _proto.handleClick = function handleClick(event) {\n /**\n * Triggered when the a `CloseButton` is clicked.\n *\n * @event CloseButton#close\n * @type {EventTarget~Event}\n *\n * @property {boolean} [bubbles=false]\n * set to false so that the close event does not\n * bubble up to parents if there is no listener\n */\n this.trigger({\n type: 'close',\n bubbles: false\n });\n };\n\n return CloseButton;\n}(Button);\n\nComponent.registerComponent('CloseButton', CloseButton);\n\n/**\n * Button to toggle between play and pause.\n *\n * @extends Button\n */\n\nvar PlayToggle =\n/*#__PURE__*/\nfunction (_Button) {\n _inheritsLoose(PlayToggle, _Button);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options={}]\n * The key/value store of player options.\n */\n function PlayToggle(player, options) {\n var _this;\n\n if (options === void 0) {\n options = {};\n }\n\n _this = _Button.call(this, player, options) || this; // show or hide replay icon\n\n options.replay = options.replay === undefined || options.replay;\n\n _this.on(player, 'play', _this.handlePlay);\n\n _this.on(player, 'pause', _this.handlePause);\n\n if (options.replay) {\n _this.on(player, 'ended', _this.handleEnded);\n }\n\n return _this;\n }\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n\n\n var _proto = PlayToggle.prototype;\n\n _proto.buildCSSClass = function buildCSSClass() {\n return \"vjs-play-control \" + _Button.prototype.buildCSSClass.call(this);\n };\n /**\n * This gets called when an `PlayToggle` is \"clicked\". See\n * {@link ClickableComponent} for more detailed information on what a click can be.\n *\n * @param {EventTarget~Event} [event]\n * The `keydown`, `tap`, or `click` event that caused this function to be\n * called.\n *\n * @listens tap\n * @listens click\n */\n\n\n _proto.handleClick = function handleClick(event) {\n if (this.player_.paused()) {\n this.player_.play();\n } else {\n this.player_.pause();\n }\n };\n /**\n * This gets called once after the video has ended and the user seeks so that\n * we can change the replay button back to a play button.\n *\n * @param {EventTarget~Event} [event]\n * The event that caused this function to run.\n *\n * @listens Player#seeked\n */\n\n\n _proto.handleSeeked = function handleSeeked(event) {\n this.removeClass('vjs-ended');\n\n if (this.player_.paused()) {\n this.handlePause(event);\n } else {\n this.handlePlay(event);\n }\n };\n /**\n * Add the vjs-playing class to the element so it can change appearance.\n *\n * @param {EventTarget~Event} [event]\n * The event that caused this function to run.\n *\n * @listens Player#play\n */\n\n\n _proto.handlePlay = function handlePlay(event) {\n this.removeClass('vjs-ended');\n this.removeClass('vjs-paused');\n this.addClass('vjs-playing'); // change the button text to \"Pause\"\n\n this.controlText('Pause');\n };\n /**\n * Add the vjs-paused class to the element so it can change appearance.\n *\n * @param {EventTarget~Event} [event]\n * The event that caused this function to run.\n *\n * @listens Player#pause\n */\n\n\n _proto.handlePause = function handlePause(event) {\n this.removeClass('vjs-playing');\n this.addClass('vjs-paused'); // change the button text to \"Play\"\n\n this.controlText('Play');\n };\n /**\n * Add the vjs-ended class to the element so it can change appearance\n *\n * @param {EventTarget~Event} [event]\n * The event that caused this function to run.\n *\n * @listens Player#ended\n */\n\n\n _proto.handleEnded = function handleEnded(event) {\n this.removeClass('vjs-playing');\n this.addClass('vjs-ended'); // change the button text to \"Replay\"\n\n this.controlText('Replay'); // on the next seek remove the replay button\n\n this.one(this.player_, 'seeked', this.handleSeeked);\n };\n\n return PlayToggle;\n}(Button);\n/**\n * The text that should display over the `PlayToggle`s controls. Added for localization.\n *\n * @type {string}\n * @private\n */\n\n\nPlayToggle.prototype.controlText_ = 'Play';\nComponent.registerComponent('PlayToggle', PlayToggle);\n\n/**\n * @file format-time.js\n * @module format-time\n */\n\n/**\n * Format seconds as a time string, H:MM:SS or M:SS. Supplying a guide (in\n * seconds) will force a number of leading zeros to cover the length of the\n * guide.\n *\n * @private\n * @param {number} seconds\n * Number of seconds to be turned into a string\n *\n * @param {number} guide\n * Number (in seconds) to model the string after\n *\n * @return {string}\n * Time formatted as H:MM:SS or M:SS\n */\nvar defaultImplementation = function defaultImplementation(seconds, guide) {\n seconds = seconds < 0 ? 0 : seconds;\n var s = Math.floor(seconds % 60);\n var m = Math.floor(seconds / 60 % 60);\n var h = Math.floor(seconds / 3600);\n var gm = Math.floor(guide / 60 % 60);\n var gh = Math.floor(guide / 3600); // handle invalid times\n\n if (isNaN(seconds) || seconds === Infinity) {\n // '-' is false for all relational operators (e.g. <, >=) so this setting\n // will add the minimum number of fields specified by the guide\n h = m = s = '-';\n } // Check if we need to show hours\n\n\n h = h > 0 || gh > 0 ? h + ':' : ''; // If hours are showing, we may need to add a leading zero.\n // Always show at least one digit of minutes.\n\n m = ((h || gm >= 10) && m < 10 ? '0' + m : m) + ':'; // Check if leading zero is need for seconds\n\n s = s < 10 ? '0' + s : s;\n return h + m + s;\n}; // Internal pointer to the current implementation.\n\n\nvar implementation = defaultImplementation;\n/**\n * Replaces the default formatTime implementation with a custom implementation.\n *\n * @param {Function} customImplementation\n * A function which will be used in place of the default formatTime\n * implementation. Will receive the current time in seconds and the\n * guide (in seconds) as arguments.\n */\n\nfunction setFormatTime(customImplementation) {\n implementation = customImplementation;\n}\n/**\n * Resets formatTime to the default implementation.\n */\n\nfunction resetFormatTime() {\n implementation = defaultImplementation;\n}\n/**\n * Delegates to either the default time formatting function or a custom\n * function supplied via `setFormatTime`.\n *\n * Formats seconds as a time string (H:MM:SS or M:SS). Supplying a\n * guide (in seconds) will force a number of leading zeros to cover the\n * length of the guide.\n *\n * @static\n * @example formatTime(125, 600) === \"02:05\"\n * @param {number} seconds\n * Number of seconds to be turned into a string\n *\n * @param {number} guide\n * Number (in seconds) to model the string after\n *\n * @return {string}\n * Time formatted as H:MM:SS or M:SS\n */\n\nfunction formatTime(seconds, guide) {\n if (guide === void 0) {\n guide = seconds;\n }\n\n return implementation(seconds, guide);\n}\n\n/**\n * Displays time information about the video\n *\n * @extends Component\n */\n\nvar TimeDisplay =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(TimeDisplay, _Component);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function TimeDisplay(player, options) {\n var _this;\n\n _this = _Component.call(this, player, options) || this;\n _this.throttledUpdateContent = throttle(bind(_assertThisInitialized(_assertThisInitialized(_this)), _this.updateContent), 25);\n\n _this.on(player, 'timeupdate', _this.throttledUpdateContent);\n\n return _this;\n }\n /**\n * Create the `Component`'s DOM element\n *\n * @return {Element}\n * The element that was created.\n */\n\n\n var _proto = TimeDisplay.prototype;\n\n _proto.createEl = function createEl$$1(plainName) {\n var className = this.buildCSSClass();\n\n var el = _Component.prototype.createEl.call(this, 'div', {\n className: className + \" vjs-time-control vjs-control\",\n innerHTML: \"<span class=\\\"vjs-control-text\\\" role=\\\"presentation\\\">\" + this.localize(this.labelText_) + \"\\xA0</span>\"\n });\n\n this.contentEl_ = createEl('span', {\n className: className + \"-display\"\n }, {\n // tell screen readers not to automatically read the time as it changes\n 'aria-live': 'off',\n // span elements have no implicit role, but some screen readers (notably VoiceOver)\n // treat them as a break between items in the DOM when using arrow keys\n // (or left-to-right swipes on iOS) to read contents of a page. Using\n // role='presentation' causes VoiceOver to NOT treat this span as a break.\n 'role': 'presentation'\n });\n this.updateTextNode_();\n el.appendChild(this.contentEl_);\n return el;\n };\n\n _proto.dispose = function dispose() {\n this.contentEl_ = null;\n this.textNode_ = null;\n\n _Component.prototype.dispose.call(this);\n };\n /**\n * Updates the \"remaining time\" text node with new content using the\n * contents of the `formattedTime_` property.\n *\n * @private\n */\n\n\n _proto.updateTextNode_ = function updateTextNode_() {\n if (!this.contentEl_) {\n return;\n }\n\n while (this.contentEl_.firstChild) {\n this.contentEl_.removeChild(this.contentEl_.firstChild);\n }\n\n this.textNode_ = document.createTextNode(this.formattedTime_ || this.formatTime_(0));\n this.contentEl_.appendChild(this.textNode_);\n };\n /**\n * Generates a formatted time for this component to use in display.\n *\n * @param {number} time\n * A numeric time, in seconds.\n *\n * @return {string}\n * A formatted time\n *\n * @private\n */\n\n\n _proto.formatTime_ = function formatTime_(time) {\n return formatTime(time);\n };\n /**\n * Updates the time display text node if it has what was passed in changed\n * the formatted time.\n *\n * @param {number} time\n * The time to update to\n *\n * @private\n */\n\n\n _proto.updateFormattedTime_ = function updateFormattedTime_(time) {\n var formattedTime = this.formatTime_(time);\n\n if (formattedTime === this.formattedTime_) {\n return;\n }\n\n this.formattedTime_ = formattedTime;\n this.requestAnimationFrame(this.updateTextNode_);\n };\n /**\n * To be filled out in the child class, should update the displayed time\n * in accordance with the fact that the current time has changed.\n *\n * @param {EventTarget~Event} [event]\n * The `timeupdate` event that caused this to run.\n *\n * @listens Player#timeupdate\n */\n\n\n _proto.updateContent = function updateContent(event) {};\n\n return TimeDisplay;\n}(Component);\n/**\n * The text that is added to the `TimeDisplay` for screen reader users.\n *\n * @type {string}\n * @private\n */\n\n\nTimeDisplay.prototype.labelText_ = 'Time';\n/**\n * The text that should display over the `TimeDisplay`s controls. Added to for localization.\n *\n * @type {string}\n * @private\n *\n * @deprecated in v7; controlText_ is not used in non-active display Components\n */\n\nTimeDisplay.prototype.controlText_ = 'Time';\nComponent.registerComponent('TimeDisplay', TimeDisplay);\n\n/**\n * Displays the current time\n *\n * @extends Component\n */\n\nvar CurrentTimeDisplay =\n/*#__PURE__*/\nfunction (_TimeDisplay) {\n _inheritsLoose(CurrentTimeDisplay, _TimeDisplay);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function CurrentTimeDisplay(player, options) {\n var _this;\n\n _this = _TimeDisplay.call(this, player, options) || this;\n\n _this.on(player, 'ended', _this.handleEnded);\n\n return _this;\n }\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n\n\n var _proto = CurrentTimeDisplay.prototype;\n\n _proto.buildCSSClass = function buildCSSClass() {\n return 'vjs-current-time';\n };\n /**\n * Update current time display\n *\n * @param {EventTarget~Event} [event]\n * The `timeupdate` event that caused this function to run.\n *\n * @listens Player#timeupdate\n */\n\n\n _proto.updateContent = function updateContent(event) {\n // Allows for smooth scrubbing, when player can't keep up.\n var time = this.player_.scrubbing() ? this.player_.getCache().currentTime : this.player_.currentTime();\n this.updateFormattedTime_(time);\n };\n /**\n * When the player fires ended there should be no time left. Sadly\n * this is not always the case, lets make it seem like that is the case\n * for users.\n *\n * @param {EventTarget~Event} [event]\n * The `ended` event that caused this to run.\n *\n * @listens Player#ended\n */\n\n\n _proto.handleEnded = function handleEnded(event) {\n if (!this.player_.duration()) {\n return;\n }\n\n this.updateFormattedTime_(this.player_.duration());\n };\n\n return CurrentTimeDisplay;\n}(TimeDisplay);\n/**\n * The text that is added to the `CurrentTimeDisplay` for screen reader users.\n *\n * @type {string}\n * @private\n */\n\n\nCurrentTimeDisplay.prototype.labelText_ = 'Current Time';\n/**\n * The text that should display over the `CurrentTimeDisplay`s controls. Added to for localization.\n *\n * @type {string}\n * @private\n *\n * @deprecated in v7; controlText_ is not used in non-active display Components\n */\n\nCurrentTimeDisplay.prototype.controlText_ = 'Current Time';\nComponent.registerComponent('CurrentTimeDisplay', CurrentTimeDisplay);\n\n/**\n * Displays the duration\n *\n * @extends Component\n */\n\nvar DurationDisplay =\n/*#__PURE__*/\nfunction (_TimeDisplay) {\n _inheritsLoose(DurationDisplay, _TimeDisplay);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function DurationDisplay(player, options) {\n var _this;\n\n _this = _TimeDisplay.call(this, player, options) || this; // we do not want to/need to throttle duration changes,\n // as they should always display the changed duration as\n // it has changed\n\n _this.on(player, 'durationchange', _this.updateContent); // Listen to loadstart because the player duration is reset when a new media element is loaded,\n // but the durationchange on the user agent will not fire.\n // @see [Spec]{@link https://www.w3.org/TR/2011/WD-html5-20110113/video.html#media-element-load-algorithm}\n\n\n _this.on(player, 'loadstart', _this.updateContent); // Also listen for timeupdate (in the parent) and loadedmetadata because removing those\n // listeners could have broken dependent applications/libraries. These\n // can likely be removed for 7.0.\n\n\n _this.on(player, 'loadedmetadata', _this.throttledUpdateContent);\n\n return _this;\n }\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n\n\n var _proto = DurationDisplay.prototype;\n\n _proto.buildCSSClass = function buildCSSClass() {\n return 'vjs-duration';\n };\n /**\n * Update duration time display.\n *\n * @param {EventTarget~Event} [event]\n * The `durationchange`, `timeupdate`, or `loadedmetadata` event that caused\n * this function to be called.\n *\n * @listens Player#durationchange\n * @listens Player#timeupdate\n * @listens Player#loadedmetadata\n */\n\n\n _proto.updateContent = function updateContent(event) {\n var duration = this.player_.duration();\n\n if (this.duration_ !== duration) {\n this.duration_ = duration;\n this.updateFormattedTime_(duration);\n }\n };\n\n return DurationDisplay;\n}(TimeDisplay);\n/**\n * The text that is added to the `DurationDisplay` for screen reader users.\n *\n * @type {string}\n * @private\n */\n\n\nDurationDisplay.prototype.labelText_ = 'Duration';\n/**\n * The text that should display over the `DurationDisplay`s controls. Added to for localization.\n *\n * @type {string}\n * @private\n *\n * @deprecated in v7; controlText_ is not used in non-active display Components\n */\n\nDurationDisplay.prototype.controlText_ = 'Duration';\nComponent.registerComponent('DurationDisplay', DurationDisplay);\n\n/**\n * The separator between the current time and duration.\n * Can be hidden if it's not needed in the design.\n *\n * @extends Component\n */\n\nvar TimeDivider =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(TimeDivider, _Component);\n\n function TimeDivider() {\n return _Component.apply(this, arguments) || this;\n }\n\n var _proto = TimeDivider.prototype;\n\n /**\n * Create the component's DOM element\n *\n * @return {Element}\n * The element that was created.\n */\n _proto.createEl = function createEl() {\n return _Component.prototype.createEl.call(this, 'div', {\n className: 'vjs-time-control vjs-time-divider',\n innerHTML: '<div><span>/</span></div>'\n }, {\n // this element and its contents can be hidden from assistive techs since\n // it is made extraneous by the announcement of the control text\n // for the current time and duration displays\n 'aria-hidden': true\n });\n };\n\n return TimeDivider;\n}(Component);\n\nComponent.registerComponent('TimeDivider', TimeDivider);\n\n/**\n * Displays the time left in the video\n *\n * @extends Component\n */\n\nvar RemainingTimeDisplay =\n/*#__PURE__*/\nfunction (_TimeDisplay) {\n _inheritsLoose(RemainingTimeDisplay, _TimeDisplay);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function RemainingTimeDisplay(player, options) {\n var _this;\n\n _this = _TimeDisplay.call(this, player, options) || this;\n\n _this.on(player, 'durationchange', _this.throttledUpdateContent);\n\n _this.on(player, 'ended', _this.handleEnded);\n\n return _this;\n }\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n\n\n var _proto = RemainingTimeDisplay.prototype;\n\n _proto.buildCSSClass = function buildCSSClass() {\n return 'vjs-remaining-time';\n };\n /**\n * The remaining time display prefixes numbers with a \"minus\" character.\n *\n * @param {number} time\n * A numeric time, in seconds.\n *\n * @return {string}\n * A formatted time\n *\n * @private\n */\n\n\n _proto.formatTime_ = function formatTime_(time) {\n // TODO: The \"-\" should be decorative, and not announced by a screen reader\n return '-' + _TimeDisplay.prototype.formatTime_.call(this, time);\n };\n /**\n * Update remaining time display.\n *\n * @param {EventTarget~Event} [event]\n * The `timeupdate` or `durationchange` event that caused this to run.\n *\n * @listens Player#timeupdate\n * @listens Player#durationchange\n */\n\n\n _proto.updateContent = function updateContent(event) {\n if (!this.player_.duration()) {\n return;\n } // @deprecated We should only use remainingTimeDisplay\n // as of video.js 7\n\n\n if (this.player_.remainingTimeDisplay) {\n this.updateFormattedTime_(this.player_.remainingTimeDisplay());\n } else {\n this.updateFormattedTime_(this.player_.remainingTime());\n }\n };\n /**\n * When the player fires ended there should be no time left. Sadly\n * this is not always the case, lets make it seem like that is the case\n * for users.\n *\n * @param {EventTarget~Event} [event]\n * The `ended` event that caused this to run.\n *\n * @listens Player#ended\n */\n\n\n _proto.handleEnded = function handleEnded(event) {\n if (!this.player_.duration()) {\n return;\n }\n\n this.updateFormattedTime_(0);\n };\n\n return RemainingTimeDisplay;\n}(TimeDisplay);\n/**\n * The text that is added to the `RemainingTimeDisplay` for screen reader users.\n *\n * @type {string}\n * @private\n */\n\n\nRemainingTimeDisplay.prototype.labelText_ = 'Remaining Time';\n/**\n * The text that should display over the `RemainingTimeDisplay`s controls. Added to for localization.\n *\n * @type {string}\n * @private\n *\n * @deprecated in v7; controlText_ is not used in non-active display Components\n */\n\nRemainingTimeDisplay.prototype.controlText_ = 'Remaining Time';\nComponent.registerComponent('RemainingTimeDisplay', RemainingTimeDisplay);\n\n/**\n * Displays the live indicator when duration is Infinity.\n *\n * @extends Component\n */\n\nvar LiveDisplay =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(LiveDisplay, _Component);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function LiveDisplay(player, options) {\n var _this;\n\n _this = _Component.call(this, player, options) || this;\n\n _this.updateShowing();\n\n _this.on(_this.player(), 'durationchange', _this.updateShowing);\n\n return _this;\n }\n /**\n * Create the `Component`'s DOM element\n *\n * @return {Element}\n * The element that was created.\n */\n\n\n var _proto = LiveDisplay.prototype;\n\n _proto.createEl = function createEl$$1() {\n var el = _Component.prototype.createEl.call(this, 'div', {\n className: 'vjs-live-control vjs-control'\n });\n\n this.contentEl_ = createEl('div', {\n className: 'vjs-live-display',\n innerHTML: \"<span class=\\\"vjs-control-text\\\">\" + this.localize('Stream Type') + \"\\xA0</span>\" + this.localize('LIVE')\n }, {\n 'aria-live': 'off'\n });\n el.appendChild(this.contentEl_);\n return el;\n };\n\n _proto.dispose = function dispose() {\n this.contentEl_ = null;\n\n _Component.prototype.dispose.call(this);\n };\n /**\n * Check the duration to see if the LiveDisplay should be showing or not. Then show/hide\n * it accordingly\n *\n * @param {EventTarget~Event} [event]\n * The {@link Player#durationchange} event that caused this function to run.\n *\n * @listens Player#durationchange\n */\n\n\n _proto.updateShowing = function updateShowing(event) {\n if (this.player().duration() === Infinity) {\n this.show();\n } else {\n this.hide();\n }\n };\n\n return LiveDisplay;\n}(Component);\n\nComponent.registerComponent('LiveDisplay', LiveDisplay);\n\n/**\n * Displays the live indicator when duration is Infinity.\n *\n * @extends Component\n */\n\nvar SeekToLive =\n/*#__PURE__*/\nfunction (_Button) {\n _inheritsLoose(SeekToLive, _Button);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function SeekToLive(player, options) {\n var _this;\n\n _this = _Button.call(this, player, options) || this;\n\n _this.updateLiveEdgeStatus();\n\n if (_this.player_.liveTracker) {\n _this.on(_this.player_.liveTracker, 'liveedgechange', _this.updateLiveEdgeStatus);\n }\n\n return _this;\n }\n /**\n * Create the `Component`'s DOM element\n *\n * @return {Element}\n * The element that was created.\n */\n\n\n var _proto = SeekToLive.prototype;\n\n _proto.createEl = function createEl$$1() {\n var el = _Button.prototype.createEl.call(this, 'button', {\n className: 'vjs-seek-to-live-control vjs-control'\n });\n\n this.textEl_ = createEl('span', {\n className: 'vjs-seek-to-live-text',\n innerHTML: this.localize('LIVE')\n }, {\n 'aria-hidden': 'true'\n });\n el.appendChild(this.textEl_);\n return el;\n };\n /**\n * Update the state of this button if we are at the live edge\n * or not\n */\n\n\n _proto.updateLiveEdgeStatus = function updateLiveEdgeStatus(e) {\n // default to live edge\n if (!this.player_.liveTracker || this.player_.liveTracker.atLiveEdge()) {\n this.setAttribute('aria-disabled', true);\n this.addClass('vjs-at-live-edge');\n this.controlText('Seek to live, currently playing live');\n } else {\n this.setAttribute('aria-disabled', false);\n this.removeClass('vjs-at-live-edge');\n this.controlText('Seek to live, currently behind live');\n }\n };\n /**\n * On click bring us as near to the live point as possible.\n * This requires that we wait for the next `live-seekable-change`\n * event which will happen every segment length seconds.\n */\n\n\n _proto.handleClick = function handleClick() {\n this.player_.liveTracker.seekToLiveEdge();\n };\n /**\n * Dispose of the element and stop tracking\n */\n\n\n _proto.dispose = function dispose() {\n if (this.player_.liveTracker) {\n this.off(this.player_.liveTracker, 'liveedgechange', this.updateLiveEdgeStatus);\n }\n\n this.textEl_ = null;\n\n _Button.prototype.dispose.call(this);\n };\n\n return SeekToLive;\n}(Button);\n\nSeekToLive.prototype.controlText_ = 'Seek to live, currently playing live';\nComponent.registerComponent('SeekToLive', SeekToLive);\n\n/**\n * The base functionality for a slider. Can be vertical or horizontal.\n * For instance the volume bar or the seek bar on a video is a slider.\n *\n * @extends Component\n */\n\nvar Slider =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(Slider, _Component);\n\n /**\n * Create an instance of this class\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function Slider(player, options) {\n var _this;\n\n _this = _Component.call(this, player, options) || this; // Set property names to bar to match with the child Slider class is looking for\n\n _this.bar = _this.getChild(_this.options_.barName); // Set a horizontal or vertical class on the slider depending on the slider type\n\n _this.vertical(!!_this.options_.vertical);\n\n _this.enable();\n\n return _this;\n }\n /**\n * Are controls are currently enabled for this slider or not.\n *\n * @return {boolean}\n * true if controls are enabled, false otherwise\n */\n\n\n var _proto = Slider.prototype;\n\n _proto.enabled = function enabled() {\n return this.enabled_;\n };\n /**\n * Enable controls for this slider if they are disabled\n */\n\n\n _proto.enable = function enable() {\n if (this.enabled()) {\n return;\n }\n\n this.on('mousedown', this.handleMouseDown);\n this.on('touchstart', this.handleMouseDown);\n this.on('focus', this.handleFocus);\n this.on('blur', this.handleBlur);\n this.on('click', this.handleClick);\n this.on(this.player_, 'controlsvisible', this.update);\n\n if (this.playerEvent) {\n this.on(this.player_, this.playerEvent, this.update);\n }\n\n this.removeClass('disabled');\n this.setAttribute('tabindex', 0);\n this.enabled_ = true;\n };\n /**\n * Disable controls for this slider if they are enabled\n */\n\n\n _proto.disable = function disable() {\n if (!this.enabled()) {\n return;\n }\n\n var doc = this.bar.el_.ownerDocument;\n this.off('mousedown', this.handleMouseDown);\n this.off('touchstart', this.handleMouseDown);\n this.off('focus', this.handleFocus);\n this.off('blur', this.handleBlur);\n this.off('click', this.handleClick);\n this.off(this.player_, 'controlsvisible', this.update);\n this.off(doc, 'mousemove', this.handleMouseMove);\n this.off(doc, 'mouseup', this.handleMouseUp);\n this.off(doc, 'touchmove', this.handleMouseMove);\n this.off(doc, 'touchend', this.handleMouseUp);\n this.removeAttribute('tabindex');\n this.addClass('disabled');\n\n if (this.playerEvent) {\n this.off(this.player_, this.playerEvent, this.update);\n }\n\n this.enabled_ = false;\n };\n /**\n * Create the `Slider`s DOM element.\n *\n * @param {string} type\n * Type of element to create.\n *\n * @param {Object} [props={}]\n * List of properties in Object form.\n *\n * @param {Object} [attributes={}]\n * list of attributes in Object form.\n *\n * @return {Element}\n * The element that gets created.\n */\n\n\n _proto.createEl = function createEl$$1(type, props, attributes) {\n if (props === void 0) {\n props = {};\n }\n\n if (attributes === void 0) {\n attributes = {};\n }\n\n // Add the slider element class to all sub classes\n props.className = props.className + ' vjs-slider';\n props = assign({\n tabIndex: 0\n }, props);\n attributes = assign({\n 'role': 'slider',\n 'aria-valuenow': 0,\n 'aria-valuemin': 0,\n 'aria-valuemax': 100,\n 'tabIndex': 0\n }, attributes);\n return _Component.prototype.createEl.call(this, type, props, attributes);\n };\n /**\n * Handle `mousedown` or `touchstart` events on the `Slider`.\n *\n * @param {EventTarget~Event} event\n * `mousedown` or `touchstart` event that triggered this function\n *\n * @listens mousedown\n * @listens touchstart\n * @fires Slider#slideractive\n */\n\n\n _proto.handleMouseDown = function handleMouseDown(event) {\n var doc = this.bar.el_.ownerDocument;\n\n if (event.type === 'mousedown') {\n event.preventDefault();\n } // Do not call preventDefault() on touchstart in Chrome\n // to avoid console warnings. Use a 'touch-action: none' style\n // instead to prevent unintented scrolling.\n // https://developers.google.com/web/updates/2017/01/scrolling-intervention\n\n\n if (event.type === 'touchstart' && !IS_CHROME) {\n event.preventDefault();\n }\n\n blockTextSelection();\n this.addClass('vjs-sliding');\n /**\n * Triggered when the slider is in an active state\n *\n * @event Slider#slideractive\n * @type {EventTarget~Event}\n */\n\n this.trigger('slideractive');\n this.on(doc, 'mousemove', this.handleMouseMove);\n this.on(doc, 'mouseup', this.handleMouseUp);\n this.on(doc, 'touchmove', this.handleMouseMove);\n this.on(doc, 'touchend', this.handleMouseUp);\n this.handleMouseMove(event);\n };\n /**\n * Handle the `mousemove`, `touchmove`, and `mousedown` events on this `Slider`.\n * The `mousemove` and `touchmove` events will only only trigger this function during\n * `mousedown` and `touchstart`. This is due to {@link Slider#handleMouseDown} and\n * {@link Slider#handleMouseUp}.\n *\n * @param {EventTarget~Event} event\n * `mousedown`, `mousemove`, `touchstart`, or `touchmove` event that triggered\n * this function\n *\n * @listens mousemove\n * @listens touchmove\n */\n\n\n _proto.handleMouseMove = function handleMouseMove(event) {};\n /**\n * Handle `mouseup` or `touchend` events on the `Slider`.\n *\n * @param {EventTarget~Event} event\n * `mouseup` or `touchend` event that triggered this function.\n *\n * @listens touchend\n * @listens mouseup\n * @fires Slider#sliderinactive\n */\n\n\n _proto.handleMouseUp = function handleMouseUp() {\n var doc = this.bar.el_.ownerDocument;\n unblockTextSelection();\n this.removeClass('vjs-sliding');\n /**\n * Triggered when the slider is no longer in an active state.\n *\n * @event Slider#sliderinactive\n * @type {EventTarget~Event}\n */\n\n this.trigger('sliderinactive');\n this.off(doc, 'mousemove', this.handleMouseMove);\n this.off(doc, 'mouseup', this.handleMouseUp);\n this.off(doc, 'touchmove', this.handleMouseMove);\n this.off(doc, 'touchend', this.handleMouseUp);\n this.update();\n };\n /**\n * Update the progress bar of the `Slider`.\n *\n * @return {number}\n * The percentage of progress the progress bar represents as a\n * number from 0 to 1.\n */\n\n\n _proto.update = function update() {\n // In VolumeBar init we have a setTimeout for update that pops and update\n // to the end of the execution stack. The player is destroyed before then\n // update will cause an error\n if (!this.el_) {\n return;\n } // If scrubbing, we could use a cached value to make the handle keep up\n // with the user's mouse. On HTML5 browsers scrubbing is really smooth, but\n // some flash players are slow, so we might want to utilize this later.\n // var progress = (this.player_.scrubbing()) ? this.player_.getCache().currentTime / this.player_.duration() : this.player_.currentTime() / this.player_.duration();\n\n\n var progress = this.getPercent();\n var bar = this.bar; // If there's no bar...\n\n if (!bar) {\n return;\n } // Protect against no duration and other division issues\n\n\n if (typeof progress !== 'number' || progress !== progress || progress < 0 || progress === Infinity) {\n progress = 0;\n } // Convert to a percentage for setting\n\n\n var percentage = (progress * 100).toFixed(2) + '%';\n var style = bar.el().style; // Set the new bar width or height\n\n if (this.vertical()) {\n style.height = percentage;\n } else {\n style.width = percentage;\n }\n\n return progress;\n };\n /**\n * Calculate distance for slider\n *\n * @param {EventTarget~Event} event\n * The event that caused this function to run.\n *\n * @return {number}\n * The current position of the Slider.\n * - position.x for vertical `Slider`s\n * - position.y for horizontal `Slider`s\n */\n\n\n _proto.calculateDistance = function calculateDistance(event) {\n var position = getPointerPosition(this.el_, event);\n\n if (this.vertical()) {\n return position.y;\n }\n\n return position.x;\n };\n /**\n * Handle a `focus` event on this `Slider`.\n *\n * @param {EventTarget~Event} event\n * The `focus` event that caused this function to run.\n *\n * @listens focus\n */\n\n\n _proto.handleFocus = function handleFocus() {\n this.on(this.bar.el_.ownerDocument, 'keydown', this.handleKeyPress);\n };\n /**\n * Handle a `keydown` event on the `Slider`. Watches for left, rigth, up, and down\n * arrow keys. This function will only be called when the slider has focus. See\n * {@link Slider#handleFocus} and {@link Slider#handleBlur}.\n *\n * @param {EventTarget~Event} event\n * the `keydown` event that caused this function to run.\n *\n * @listens keydown\n */\n\n\n _proto.handleKeyPress = function handleKeyPress(event) {\n // Left and Down Arrows\n if (event.which === 37 || event.which === 40) {\n event.preventDefault();\n this.stepBack(); // Up and Right Arrows\n } else if (event.which === 38 || event.which === 39) {\n event.preventDefault();\n this.stepForward();\n }\n };\n /**\n * Handle a `blur` event on this `Slider`.\n *\n * @param {EventTarget~Event} event\n * The `blur` event that caused this function to run.\n *\n * @listens blur\n */\n\n\n _proto.handleBlur = function handleBlur() {\n this.off(this.bar.el_.ownerDocument, 'keydown', this.handleKeyPress);\n };\n /**\n * Listener for click events on slider, used to prevent clicks\n * from bubbling up to parent elements like button menus.\n *\n * @param {Object} event\n * Event that caused this object to run\n */\n\n\n _proto.handleClick = function handleClick(event) {\n event.stopImmediatePropagation();\n event.preventDefault();\n };\n /**\n * Get/set if slider is horizontal for vertical\n *\n * @param {boolean} [bool]\n * - true if slider is vertical,\n * - false is horizontal\n *\n * @return {boolean}\n * - true if slider is vertical, and getting\n * - false if the slider is horizontal, and getting\n */\n\n\n _proto.vertical = function vertical(bool) {\n if (bool === undefined) {\n return this.vertical_ || false;\n }\n\n this.vertical_ = !!bool;\n\n if (this.vertical_) {\n this.addClass('vjs-slider-vertical');\n } else {\n this.addClass('vjs-slider-horizontal');\n }\n };\n\n return Slider;\n}(Component);\n\nComponent.registerComponent('Slider', Slider);\n\n/**\n * Shows loading progress\n *\n * @extends Component\n */\n\nvar LoadProgressBar =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(LoadProgressBar, _Component);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function LoadProgressBar(player, options) {\n var _this;\n\n _this = _Component.call(this, player, options) || this;\n _this.partEls_ = [];\n\n _this.on(player, 'progress', _this.update);\n\n return _this;\n }\n /**\n * Create the `Component`'s DOM element\n *\n * @return {Element}\n * The element that was created.\n */\n\n\n var _proto = LoadProgressBar.prototype;\n\n _proto.createEl = function createEl$$1() {\n return _Component.prototype.createEl.call(this, 'div', {\n className: 'vjs-load-progress',\n innerHTML: \"<span class=\\\"vjs-control-text\\\"><span>\" + this.localize('Loaded') + \"</span>: <span class=\\\"vjs-control-text-loaded-percentage\\\">0%</span></span>\"\n });\n };\n\n _proto.dispose = function dispose() {\n this.partEls_ = null;\n\n _Component.prototype.dispose.call(this);\n };\n /**\n * Update progress bar\n *\n * @param {EventTarget~Event} [event]\n * The `progress` event that caused this function to run.\n *\n * @listens Player#progress\n */\n\n\n _proto.update = function update(event) {\n var liveTracker = this.player_.liveTracker;\n var buffered = this.player_.buffered();\n var duration = liveTracker && liveTracker.isLive() ? liveTracker.seekableEnd() : this.player_.duration();\n var bufferedEnd = this.player_.bufferedEnd();\n var children = this.partEls_;\n var controlTextPercentage = this.$('.vjs-control-text-loaded-percentage'); // get the percent width of a time compared to the total end\n\n var percentify = function percentify(time, end, rounded) {\n // no NaN\n var percent = time / end || 0;\n percent = (percent >= 1 ? 1 : percent) * 100;\n\n if (rounded) {\n percent = percent.toFixed(2);\n }\n\n return percent + '%';\n }; // update the width of the progress bar\n\n\n this.el_.style.width = percentify(bufferedEnd, duration); // update the control-text\n\n textContent(controlTextPercentage, percentify(bufferedEnd, duration, true)); // add child elements to represent the individual buffered time ranges\n\n for (var i = 0; i < buffered.length; i++) {\n var start = buffered.start(i);\n var end = buffered.end(i);\n var part = children[i];\n\n if (!part) {\n part = this.el_.appendChild(createEl());\n children[i] = part;\n } // set the percent based on the width of the progress bar (bufferedEnd)\n\n\n part.style.left = percentify(start, bufferedEnd);\n part.style.width = percentify(end - start, bufferedEnd);\n } // remove unused buffered range elements\n\n\n for (var _i = children.length; _i > buffered.length; _i--) {\n this.el_.removeChild(children[_i - 1]);\n }\n\n children.length = buffered.length;\n };\n\n return LoadProgressBar;\n}(Component);\n\nComponent.registerComponent('LoadProgressBar', LoadProgressBar);\n\n/**\n * Time tooltips display a time above the progress bar.\n *\n * @extends Component\n */\n\nvar TimeTooltip =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(TimeTooltip, _Component);\n\n function TimeTooltip() {\n return _Component.apply(this, arguments) || this;\n }\n\n var _proto = TimeTooltip.prototype;\n\n /**\n * Create the time tooltip DOM element\n *\n * @return {Element}\n * The element that was created.\n */\n _proto.createEl = function createEl$$1() {\n return _Component.prototype.createEl.call(this, 'div', {\n className: 'vjs-time-tooltip'\n }, {\n 'aria-hidden': 'true'\n });\n };\n /**\n * Updates the position of the time tooltip relative to the `SeekBar`.\n *\n * @param {Object} seekBarRect\n * The `ClientRect` for the {@link SeekBar} element.\n *\n * @param {number} seekBarPoint\n * A number from 0 to 1, representing a horizontal reference point\n * from the left edge of the {@link SeekBar}\n */\n\n\n _proto.update = function update(seekBarRect, seekBarPoint, content) {\n var tooltipRect = getBoundingClientRect(this.el_);\n var playerRect = getBoundingClientRect(this.player_.el());\n var seekBarPointPx = seekBarRect.width * seekBarPoint; // do nothing if either rect isn't available\n // for example, if the player isn't in the DOM for testing\n\n if (!playerRect || !tooltipRect) {\n return;\n } // This is the space left of the `seekBarPoint` available within the bounds\n // of the player. We calculate any gap between the left edge of the player\n // and the left edge of the `SeekBar` and add the number of pixels in the\n // `SeekBar` before hitting the `seekBarPoint`\n\n\n var spaceLeftOfPoint = seekBarRect.left - playerRect.left + seekBarPointPx; // This is the space right of the `seekBarPoint` available within the bounds\n // of the player. We calculate the number of pixels from the `seekBarPoint`\n // to the right edge of the `SeekBar` and add to that any gap between the\n // right edge of the `SeekBar` and the player.\n\n var spaceRightOfPoint = seekBarRect.width - seekBarPointPx + (playerRect.right - seekBarRect.right); // This is the number of pixels by which the tooltip will need to be pulled\n // further to the right to center it over the `seekBarPoint`.\n\n var pullTooltipBy = tooltipRect.width / 2; // Adjust the `pullTooltipBy` distance to the left or right depending on\n // the results of the space calculations above.\n\n if (spaceLeftOfPoint < pullTooltipBy) {\n pullTooltipBy += pullTooltipBy - spaceLeftOfPoint;\n } else if (spaceRightOfPoint < pullTooltipBy) {\n pullTooltipBy = spaceRightOfPoint;\n } // Due to the imprecision of decimal/ratio based calculations and varying\n // rounding behaviors, there are cases where the spacing adjustment is off\n // by a pixel or two. This adds insurance to these calculations.\n\n\n if (pullTooltipBy < 0) {\n pullTooltipBy = 0;\n } else if (pullTooltipBy > tooltipRect.width) {\n pullTooltipBy = tooltipRect.width;\n }\n\n this.el_.style.right = \"-\" + pullTooltipBy + \"px\";\n textContent(this.el_, content);\n };\n /**\n * Updates the position of the time tooltip relative to the `SeekBar`.\n *\n * @param {Object} seekBarRect\n * The `ClientRect` for the {@link SeekBar} element.\n *\n * @param {number} seekBarPoint\n * A number from 0 to 1, representing a horizontal reference point\n * from the left edge of the {@link SeekBar}\n *\n * @param {number} time\n * The time to update the tooltip to, not used during live playback\n *\n * @param {Function} cb\n * A function that will be called during the request animation frame\n * for tooltips that need to do additional animations from the default\n */\n\n\n _proto.updateTime = function updateTime(seekBarRect, seekBarPoint, time, cb) {\n var _this = this;\n\n // If there is an existing rAF ID, cancel it so we don't over-queue.\n if (this.rafId_) {\n this.cancelAnimationFrame(this.rafId_);\n }\n\n this.rafId_ = this.requestAnimationFrame(function () {\n var content;\n\n var duration = _this.player_.duration();\n\n if (_this.player_.liveTracker && _this.player_.liveTracker.isLive()) {\n var liveWindow = _this.player_.liveTracker.liveWindow();\n\n var secondsBehind = liveWindow - seekBarPoint * liveWindow;\n content = (secondsBehind < 1 ? '' : '-') + formatTime(secondsBehind, liveWindow);\n } else {\n content = formatTime(time, duration);\n }\n\n _this.update(seekBarRect, seekBarPoint, content);\n\n if (cb) {\n cb();\n }\n });\n };\n\n return TimeTooltip;\n}(Component);\n\nComponent.registerComponent('TimeTooltip', TimeTooltip);\n\n/**\n * Used by {@link SeekBar} to display media playback progress as part of the\n * {@link ProgressControl}.\n *\n * @extends Component\n */\n\nvar PlayProgressBar =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(PlayProgressBar, _Component);\n\n function PlayProgressBar() {\n return _Component.apply(this, arguments) || this;\n }\n\n var _proto = PlayProgressBar.prototype;\n\n /**\n * Create the the DOM element for this class.\n *\n * @return {Element}\n * The element that was created.\n */\n _proto.createEl = function createEl() {\n return _Component.prototype.createEl.call(this, 'div', {\n className: 'vjs-play-progress vjs-slider-bar'\n }, {\n 'aria-hidden': 'true'\n });\n };\n /**\n * Enqueues updates to its own DOM as well as the DOM of its\n * {@link TimeTooltip} child.\n *\n * @param {Object} seekBarRect\n * The `ClientRect` for the {@link SeekBar} element.\n *\n * @param {number} seekBarPoint\n * A number from 0 to 1, representing a horizontal reference point\n * from the left edge of the {@link SeekBar}\n */\n\n\n _proto.update = function update(seekBarRect, seekBarPoint) {\n var timeTooltip = this.getChild('timeTooltip');\n\n if (!timeTooltip) {\n return;\n }\n\n var time = this.player_.scrubbing() ? this.player_.getCache().currentTime : this.player_.currentTime();\n timeTooltip.updateTime(seekBarRect, seekBarPoint, time);\n };\n\n return PlayProgressBar;\n}(Component);\n/**\n * Default options for {@link PlayProgressBar}.\n *\n * @type {Object}\n * @private\n */\n\n\nPlayProgressBar.prototype.options_ = {\n children: []\n}; // Time tooltips should not be added to a player on mobile devices\n\nif (!IS_IOS && !IS_ANDROID) {\n PlayProgressBar.prototype.options_.children.push('timeTooltip');\n}\n\nComponent.registerComponent('PlayProgressBar', PlayProgressBar);\n\n/**\n * The {@link MouseTimeDisplay} component tracks mouse movement over the\n * {@link ProgressControl}. It displays an indicator and a {@link TimeTooltip}\n * indicating the time which is represented by a given point in the\n * {@link ProgressControl}.\n *\n * @extends Component\n */\n\nvar MouseTimeDisplay =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(MouseTimeDisplay, _Component);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The {@link Player} that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function MouseTimeDisplay(player, options) {\n var _this;\n\n _this = _Component.call(this, player, options) || this;\n _this.update = throttle(bind(_assertThisInitialized(_assertThisInitialized(_this)), _this.update), 25);\n return _this;\n }\n /**\n * Create the DOM element for this class.\n *\n * @return {Element}\n * The element that was created.\n */\n\n\n var _proto = MouseTimeDisplay.prototype;\n\n _proto.createEl = function createEl() {\n return _Component.prototype.createEl.call(this, 'div', {\n className: 'vjs-mouse-display'\n });\n };\n /**\n * Enqueues updates to its own DOM as well as the DOM of its\n * {@link TimeTooltip} child.\n *\n * @param {Object} seekBarRect\n * The `ClientRect` for the {@link SeekBar} element.\n *\n * @param {number} seekBarPoint\n * A number from 0 to 1, representing a horizontal reference point\n * from the left edge of the {@link SeekBar}\n */\n\n\n _proto.update = function update(seekBarRect, seekBarPoint) {\n var _this2 = this;\n\n var time = seekBarPoint * this.player_.duration();\n this.getChild('timeTooltip').updateTime(seekBarRect, seekBarPoint, time, function () {\n _this2.el_.style.left = seekBarRect.width * seekBarPoint + \"px\";\n });\n };\n\n return MouseTimeDisplay;\n}(Component);\n/**\n * Default options for `MouseTimeDisplay`\n *\n * @type {Object}\n * @private\n */\n\n\nMouseTimeDisplay.prototype.options_ = {\n children: ['timeTooltip']\n};\nComponent.registerComponent('MouseTimeDisplay', MouseTimeDisplay);\n\nvar STEP_SECONDS = 5; // The interval at which the bar should update as it progresses.\n\nvar UPDATE_REFRESH_INTERVAL = 30;\n/**\n * Seek bar and container for the progress bars. Uses {@link PlayProgressBar}\n * as its `bar`.\n *\n * @extends Slider\n */\n\nvar SeekBar =\n/*#__PURE__*/\nfunction (_Slider) {\n _inheritsLoose(SeekBar, _Slider);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function SeekBar(player, options) {\n var _this;\n\n _this = _Slider.call(this, player, options) || this;\n\n _this.setEventHandlers_();\n\n return _this;\n }\n /**\n * Sets the event handlers\n *\n * @private\n */\n\n\n var _proto = SeekBar.prototype;\n\n _proto.setEventHandlers_ = function setEventHandlers_() {\n var _this2 = this;\n\n this.update = throttle(bind(this, this.update), UPDATE_REFRESH_INTERVAL);\n this.on(this.player_, 'timeupdate', this.update);\n this.on(this.player_, 'ended', this.handleEnded);\n this.on(this.player_, 'durationchange', this.update);\n\n if (this.player_.liveTracker) {\n this.on(this.player_.liveTracker, 'liveedgechange', this.update);\n } // when playing, let's ensure we smoothly update the play progress bar\n // via an interval\n\n\n this.updateInterval = null;\n this.on(this.player_, ['playing'], function () {\n _this2.clearInterval(_this2.updateInterval);\n\n _this2.updateInterval = _this2.setInterval(function () {\n _this2.requestAnimationFrame(function () {\n _this2.update();\n });\n }, UPDATE_REFRESH_INTERVAL);\n });\n this.on(this.player_, ['ended', 'pause', 'waiting'], function (e) {\n if (_this2.player_.liveTracker && _this2.player_.liveTracker.isLive() && e.type !== 'ended') {\n return;\n }\n\n _this2.clearInterval(_this2.updateInterval);\n });\n this.on(this.player_, ['timeupdate', 'ended'], this.update);\n };\n /**\n * Create the `Component`'s DOM element\n *\n * @return {Element}\n * The element that was created.\n */\n\n\n _proto.createEl = function createEl$$1() {\n return _Slider.prototype.createEl.call(this, 'div', {\n className: 'vjs-progress-holder'\n }, {\n 'aria-label': this.localize('Progress Bar')\n });\n };\n /**\n * This function updates the play progress bar and accessibility\n * attributes to whatever is passed in.\n *\n * @param {number} currentTime\n * The currentTime value that should be used for accessibility\n *\n * @param {number} percent\n * The percentage as a decimal that the bar should be filled from 0-1.\n *\n * @private\n */\n\n\n _proto.update_ = function update_(currentTime, percent) {\n var liveTracker = this.player_.liveTracker;\n var duration = this.player_.duration();\n\n if (liveTracker && liveTracker.isLive()) {\n duration = this.player_.liveTracker.liveCurrentTime();\n }\n\n if (liveTracker && liveTracker.seekableEnd() === Infinity) {\n this.disable();\n } else {\n this.enable();\n } // machine readable value of progress bar (percentage complete)\n\n\n this.el_.setAttribute('aria-valuenow', (percent * 100).toFixed(2)); // human readable value of progress bar (time complete)\n\n this.el_.setAttribute('aria-valuetext', this.localize('progress bar timing: currentTime={1} duration={2}', [formatTime(currentTime, duration), formatTime(duration, duration)], '{1} of {2}')); // Update the `PlayProgressBar`.\n\n this.bar.update(getBoundingClientRect(this.el_), percent);\n };\n /**\n * Update the seek bar's UI.\n *\n * @param {EventTarget~Event} [event]\n * The `timeupdate` or `ended` event that caused this to run.\n *\n * @listens Player#timeupdate\n *\n * @return {number}\n * The current percent at a number from 0-1\n */\n\n\n _proto.update = function update(event) {\n var percent = _Slider.prototype.update.call(this);\n\n this.update_(this.getCurrentTime_(), percent);\n return percent;\n };\n /**\n * Get the value of current time but allows for smooth scrubbing,\n * when player can't keep up.\n *\n * @return {number}\n * The current time value to display\n *\n * @private\n */\n\n\n _proto.getCurrentTime_ = function getCurrentTime_() {\n return this.player_.scrubbing() ? this.player_.getCache().currentTime : this.player_.currentTime();\n };\n /**\n * We want the seek bar to be full on ended\n * no matter what the actual internal values are. so we force it.\n *\n * @param {EventTarget~Event} [event]\n * The `timeupdate` or `ended` event that caused this to run.\n *\n * @listens Player#ended\n */\n\n\n _proto.handleEnded = function handleEnded(event) {\n this.update_(this.player_.duration(), 1);\n };\n /**\n * Get the percentage of media played so far.\n *\n * @return {number}\n * The percentage of media played so far (0 to 1).\n */\n\n\n _proto.getPercent = function getPercent() {\n var currentTime = this.getCurrentTime_();\n var percent;\n var liveTracker = this.player_.liveTracker;\n\n if (liveTracker && liveTracker.isLive()) {\n percent = (currentTime - liveTracker.seekableStart()) / liveTracker.liveWindow(); // prevent the percent from changing at the live edge\n\n if (liveTracker.atLiveEdge()) {\n percent = 1;\n }\n } else {\n percent = currentTime / this.player_.duration();\n }\n\n return percent >= 1 ? 1 : percent || 0;\n };\n /**\n * Handle mouse down on seek bar\n *\n * @param {EventTarget~Event} event\n * The `mousedown` event that caused this to run.\n *\n * @listens mousedown\n */\n\n\n _proto.handleMouseDown = function handleMouseDown(event) {\n if (!isSingleLeftClick(event)) {\n return;\n } // Stop event propagation to prevent double fire in progress-control.js\n\n\n event.stopPropagation();\n this.player_.scrubbing(true);\n this.videoWasPlaying = !this.player_.paused();\n this.player_.pause();\n\n _Slider.prototype.handleMouseDown.call(this, event);\n };\n /**\n * Handle mouse move on seek bar\n *\n * @param {EventTarget~Event} event\n * The `mousemove` event that caused this to run.\n *\n * @listens mousemove\n */\n\n\n _proto.handleMouseMove = function handleMouseMove(event) {\n if (!isSingleLeftClick(event)) {\n return;\n }\n\n var newTime;\n var distance = this.calculateDistance(event);\n var liveTracker = this.player_.liveTracker;\n\n if (!liveTracker || !liveTracker.isLive()) {\n newTime = distance * this.player_.duration(); // Don't let video end while scrubbing.\n\n if (newTime === this.player_.duration()) {\n newTime = newTime - 0.1;\n }\n } else {\n var seekableStart = liveTracker.seekableStart();\n var seekableEnd = liveTracker.liveCurrentTime();\n newTime = seekableStart + distance * liveTracker.liveWindow(); // Don't let video end while scrubbing.\n\n if (newTime >= seekableEnd) {\n newTime = seekableEnd;\n } // Compensate for precision differences so that currentTime is not less\n // than seekable start\n\n\n if (newTime <= seekableStart) {\n newTime = seekableStart + 0.1;\n } // On android seekableEnd can be Infinity sometimes,\n // this will cause newTime to be Infinity, which is\n // not a valid currentTime.\n\n\n if (newTime === Infinity) {\n return;\n }\n } // Set new time (tell player to seek to new time)\n\n\n this.player_.currentTime(newTime);\n };\n\n _proto.enable = function enable() {\n _Slider.prototype.enable.call(this);\n\n var mouseTimeDisplay = this.getChild('mouseTimeDisplay');\n\n if (!mouseTimeDisplay) {\n return;\n }\n\n mouseTimeDisplay.show();\n };\n\n _proto.disable = function disable() {\n _Slider.prototype.disable.call(this);\n\n var mouseTimeDisplay = this.getChild('mouseTimeDisplay');\n\n if (!mouseTimeDisplay) {\n return;\n }\n\n mouseTimeDisplay.hide();\n };\n /**\n * Handle mouse up on seek bar\n *\n * @param {EventTarget~Event} event\n * The `mouseup` event that caused this to run.\n *\n * @listens mouseup\n */\n\n\n _proto.handleMouseUp = function handleMouseUp(event) {\n _Slider.prototype.handleMouseUp.call(this, event); // Stop event propagation to prevent double fire in progress-control.js\n\n\n if (event) {\n event.stopPropagation();\n }\n\n this.player_.scrubbing(false);\n /**\n * Trigger timeupdate because we're done seeking and the time has changed.\n * This is particularly useful for if the player is paused to time the time displays.\n *\n * @event Tech#timeupdate\n * @type {EventTarget~Event}\n */\n\n this.player_.trigger({\n type: 'timeupdate',\n target: this,\n manuallyTriggered: true\n });\n\n if (this.videoWasPlaying) {\n silencePromise(this.player_.play());\n }\n };\n /**\n * Move more quickly fast forward for keyboard-only users\n */\n\n\n _proto.stepForward = function stepForward() {\n this.player_.currentTime(this.player_.currentTime() + STEP_SECONDS);\n };\n /**\n * Move more quickly rewind for keyboard-only users\n */\n\n\n _proto.stepBack = function stepBack() {\n this.player_.currentTime(this.player_.currentTime() - STEP_SECONDS);\n };\n /**\n * Toggles the playback state of the player\n * This gets called when enter or space is used on the seekbar\n *\n * @param {EventTarget~Event} event\n * The `keydown` event that caused this function to be called\n *\n */\n\n\n _proto.handleAction = function handleAction(event) {\n if (this.player_.paused()) {\n this.player_.play();\n } else {\n this.player_.pause();\n }\n };\n /**\n * Called when this SeekBar has focus and a key gets pressed down. By\n * default it will call `this.handleAction` when the key is space or enter.\n *\n * @param {EventTarget~Event} event\n * The `keydown` event that caused this function to be called.\n *\n * @listens keydown\n */\n\n\n _proto.handleKeyPress = function handleKeyPress(event) {\n // Support Space (32) or Enter (13) key operation to fire a click event\n if (event.which === 32 || event.which === 13) {\n event.preventDefault();\n this.handleAction(event);\n } else if (_Slider.prototype.handleKeyPress) {\n // Pass keypress handling up for unsupported keys\n _Slider.prototype.handleKeyPress.call(this, event);\n }\n };\n\n return SeekBar;\n}(Slider);\n/**\n * Default options for the `SeekBar`\n *\n * @type {Object}\n * @private\n */\n\n\nSeekBar.prototype.options_ = {\n children: ['loadProgressBar', 'playProgressBar'],\n barName: 'playProgressBar'\n}; // MouseTimeDisplay tooltips should not be added to a player on mobile devices\n\nif (!IS_IOS && !IS_ANDROID) {\n SeekBar.prototype.options_.children.splice(1, 0, 'mouseTimeDisplay');\n}\n/**\n * Call the update event for this Slider when this event happens on the player.\n *\n * @type {string}\n */\n\n\nSeekBar.prototype.playerEvent = 'timeupdate';\nComponent.registerComponent('SeekBar', SeekBar);\n\n/**\n * The Progress Control component contains the seek bar, load progress,\n * and play progress.\n *\n * @extends Component\n */\n\nvar ProgressControl =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(ProgressControl, _Component);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function ProgressControl(player, options) {\n var _this;\n\n _this = _Component.call(this, player, options) || this;\n _this.handleMouseMove = throttle(bind(_assertThisInitialized(_assertThisInitialized(_this)), _this.handleMouseMove), 25);\n _this.throttledHandleMouseSeek = throttle(bind(_assertThisInitialized(_assertThisInitialized(_this)), _this.handleMouseSeek), 25);\n\n _this.enable();\n\n return _this;\n }\n /**\n * Create the `Component`'s DOM element\n *\n * @return {Element}\n * The element that was created.\n */\n\n\n var _proto = ProgressControl.prototype;\n\n _proto.createEl = function createEl$$1() {\n return _Component.prototype.createEl.call(this, 'div', {\n className: 'vjs-progress-control vjs-control'\n });\n };\n /**\n * When the mouse moves over the `ProgressControl`, the pointer position\n * gets passed down to the `MouseTimeDisplay` component.\n *\n * @param {EventTarget~Event} event\n * The `mousemove` event that caused this function to run.\n *\n * @listen mousemove\n */\n\n\n _proto.handleMouseMove = function handleMouseMove(event) {\n var seekBar = this.getChild('seekBar');\n\n if (seekBar) {\n var mouseTimeDisplay = seekBar.getChild('mouseTimeDisplay');\n var seekBarEl = seekBar.el();\n var seekBarRect = getBoundingClientRect(seekBarEl);\n var seekBarPoint = getPointerPosition(seekBarEl, event).x; // The default skin has a gap on either side of the `SeekBar`. This means\n // that it's possible to trigger this behavior outside the boundaries of\n // the `SeekBar`. This ensures we stay within it at all times.\n\n if (seekBarPoint > 1) {\n seekBarPoint = 1;\n } else if (seekBarPoint < 0) {\n seekBarPoint = 0;\n }\n\n if (mouseTimeDisplay) {\n mouseTimeDisplay.update(seekBarRect, seekBarPoint);\n }\n }\n };\n /**\n * A throttled version of the {@link ProgressControl#handleMouseSeek} listener.\n *\n * @method ProgressControl#throttledHandleMouseSeek\n * @param {EventTarget~Event} event\n * The `mousemove` event that caused this function to run.\n *\n * @listen mousemove\n * @listen touchmove\n */\n\n /**\n * Handle `mousemove` or `touchmove` events on the `ProgressControl`.\n *\n * @param {EventTarget~Event} event\n * `mousedown` or `touchstart` event that triggered this function\n *\n * @listens mousemove\n * @listens touchmove\n */\n\n\n _proto.handleMouseSeek = function handleMouseSeek(event) {\n var seekBar = this.getChild('seekBar');\n\n if (seekBar) {\n seekBar.handleMouseMove(event);\n }\n };\n /**\n * Are controls are currently enabled for this progress control.\n *\n * @return {boolean}\n * true if controls are enabled, false otherwise\n */\n\n\n _proto.enabled = function enabled() {\n return this.enabled_;\n };\n /**\n * Disable all controls on the progress control and its children\n */\n\n\n _proto.disable = function disable() {\n this.children().forEach(function (child) {\n return child.disable && child.disable();\n });\n\n if (!this.enabled()) {\n return;\n }\n\n this.off(['mousedown', 'touchstart'], this.handleMouseDown);\n this.off(this.el_, 'mousemove', this.handleMouseMove);\n this.handleMouseUp();\n this.addClass('disabled');\n this.enabled_ = false;\n };\n /**\n * Enable all controls on the progress control and its children\n */\n\n\n _proto.enable = function enable() {\n this.children().forEach(function (child) {\n return child.enable && child.enable();\n });\n\n if (this.enabled()) {\n return;\n }\n\n this.on(['mousedown', 'touchstart'], this.handleMouseDown);\n this.on(this.el_, 'mousemove', this.handleMouseMove);\n this.removeClass('disabled');\n this.enabled_ = true;\n };\n /**\n * Handle `mousedown` or `touchstart` events on the `ProgressControl`.\n *\n * @param {EventTarget~Event} event\n * `mousedown` or `touchstart` event that triggered this function\n *\n * @listens mousedown\n * @listens touchstart\n */\n\n\n _proto.handleMouseDown = function handleMouseDown(event) {\n var doc = this.el_.ownerDocument;\n var seekBar = this.getChild('seekBar');\n\n if (seekBar) {\n seekBar.handleMouseDown(event);\n }\n\n this.on(doc, 'mousemove', this.throttledHandleMouseSeek);\n this.on(doc, 'touchmove', this.throttledHandleMouseSeek);\n this.on(doc, 'mouseup', this.handleMouseUp);\n this.on(doc, 'touchend', this.handleMouseUp);\n };\n /**\n * Handle `mouseup` or `touchend` events on the `ProgressControl`.\n *\n * @param {EventTarget~Event} event\n * `mouseup` or `touchend` event that triggered this function.\n *\n * @listens touchend\n * @listens mouseup\n */\n\n\n _proto.handleMouseUp = function handleMouseUp(event) {\n var doc = this.el_.ownerDocument;\n var seekBar = this.getChild('seekBar');\n\n if (seekBar) {\n seekBar.handleMouseUp(event);\n }\n\n this.off(doc, 'mousemove', this.throttledHandleMouseSeek);\n this.off(doc, 'touchmove', this.throttledHandleMouseSeek);\n this.off(doc, 'mouseup', this.handleMouseUp);\n this.off(doc, 'touchend', this.handleMouseUp);\n };\n\n return ProgressControl;\n}(Component);\n/**\n * Default options for `ProgressControl`\n *\n * @type {Object}\n * @private\n */\n\n\nProgressControl.prototype.options_ = {\n children: ['seekBar']\n};\nComponent.registerComponent('ProgressControl', ProgressControl);\n\n/**\n * Toggle fullscreen video\n *\n * @extends Button\n */\n\nvar FullscreenToggle =\n/*#__PURE__*/\nfunction (_Button) {\n _inheritsLoose(FullscreenToggle, _Button);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function FullscreenToggle(player, options) {\n var _this;\n\n _this = _Button.call(this, player, options) || this;\n\n _this.on(player, 'fullscreenchange', _this.handleFullscreenChange);\n\n if (document[FullscreenApi.fullscreenEnabled] === false) {\n _this.disable();\n }\n\n return _this;\n }\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n\n\n var _proto = FullscreenToggle.prototype;\n\n _proto.buildCSSClass = function buildCSSClass() {\n return \"vjs-fullscreen-control \" + _Button.prototype.buildCSSClass.call(this);\n };\n /**\n * Handles fullscreenchange on the player and change control text accordingly.\n *\n * @param {EventTarget~Event} [event]\n * The {@link Player#fullscreenchange} event that caused this function to be\n * called.\n *\n * @listens Player#fullscreenchange\n */\n\n\n _proto.handleFullscreenChange = function handleFullscreenChange(event) {\n if (this.player_.isFullscreen()) {\n this.controlText('Non-Fullscreen');\n } else {\n this.controlText('Fullscreen');\n }\n };\n /**\n * This gets called when an `FullscreenToggle` is \"clicked\". See\n * {@link ClickableComponent} for more detailed information on what a click can be.\n *\n * @param {EventTarget~Event} [event]\n * The `keydown`, `tap`, or `click` event that caused this function to be\n * called.\n *\n * @listens tap\n * @listens click\n */\n\n\n _proto.handleClick = function handleClick(event) {\n if (!this.player_.isFullscreen()) {\n this.player_.requestFullscreen();\n } else {\n this.player_.exitFullscreen();\n }\n };\n\n return FullscreenToggle;\n}(Button);\n/**\n * The text that should display over the `FullscreenToggle`s controls. Added for localization.\n *\n * @type {string}\n * @private\n */\n\n\nFullscreenToggle.prototype.controlText_ = 'Fullscreen';\nComponent.registerComponent('FullscreenToggle', FullscreenToggle);\n\n/**\n * Check if volume control is supported and if it isn't hide the\n * `Component` that was passed using the `vjs-hidden` class.\n *\n * @param {Component} self\n * The component that should be hidden if volume is unsupported\n *\n * @param {Player} player\n * A reference to the player\n *\n * @private\n */\nvar checkVolumeSupport = function checkVolumeSupport(self, player) {\n // hide volume controls when they're not supported by the current tech\n if (player.tech_ && !player.tech_.featuresVolumeControl) {\n self.addClass('vjs-hidden');\n }\n\n self.on(player, 'loadstart', function () {\n if (!player.tech_.featuresVolumeControl) {\n self.addClass('vjs-hidden');\n } else {\n self.removeClass('vjs-hidden');\n }\n });\n};\n\n/**\n * Shows volume level\n *\n * @extends Component\n */\n\nvar VolumeLevel =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(VolumeLevel, _Component);\n\n function VolumeLevel() {\n return _Component.apply(this, arguments) || this;\n }\n\n var _proto = VolumeLevel.prototype;\n\n /**\n * Create the `Component`'s DOM element\n *\n * @return {Element}\n * The element that was created.\n */\n _proto.createEl = function createEl() {\n return _Component.prototype.createEl.call(this, 'div', {\n className: 'vjs-volume-level',\n innerHTML: '<span class=\"vjs-control-text\"></span>'\n });\n };\n\n return VolumeLevel;\n}(Component);\n\nComponent.registerComponent('VolumeLevel', VolumeLevel);\n\n/**\n * The bar that contains the volume level and can be clicked on to adjust the level\n *\n * @extends Slider\n */\n\nvar VolumeBar =\n/*#__PURE__*/\nfunction (_Slider) {\n _inheritsLoose(VolumeBar, _Slider);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function VolumeBar(player, options) {\n var _this;\n\n _this = _Slider.call(this, player, options) || this;\n\n _this.on('slideractive', _this.updateLastVolume_);\n\n _this.on(player, 'volumechange', _this.updateARIAAttributes);\n\n player.ready(function () {\n return _this.updateARIAAttributes();\n });\n return _this;\n }\n /**\n * Create the `Component`'s DOM element\n *\n * @return {Element}\n * The element that was created.\n */\n\n\n var _proto = VolumeBar.prototype;\n\n _proto.createEl = function createEl$$1() {\n return _Slider.prototype.createEl.call(this, 'div', {\n className: 'vjs-volume-bar vjs-slider-bar'\n }, {\n 'aria-label': this.localize('Volume Level'),\n 'aria-live': 'polite'\n });\n };\n /**\n * Handle mouse down on volume bar\n *\n * @param {EventTarget~Event} event\n * The `mousedown` event that caused this to run.\n *\n * @listens mousedown\n */\n\n\n _proto.handleMouseDown = function handleMouseDown(event) {\n if (!isSingleLeftClick(event)) {\n return;\n }\n\n _Slider.prototype.handleMouseDown.call(this, event);\n };\n /**\n * Handle movement events on the {@link VolumeMenuButton}.\n *\n * @param {EventTarget~Event} event\n * The event that caused this function to run.\n *\n * @listens mousemove\n */\n\n\n _proto.handleMouseMove = function handleMouseMove(event) {\n if (!isSingleLeftClick(event)) {\n return;\n }\n\n this.checkMuted();\n this.player_.volume(this.calculateDistance(event));\n };\n /**\n * If the player is muted unmute it.\n */\n\n\n _proto.checkMuted = function checkMuted() {\n if (this.player_.muted()) {\n this.player_.muted(false);\n }\n };\n /**\n * Get percent of volume level\n *\n * @return {number}\n * Volume level percent as a decimal number.\n */\n\n\n _proto.getPercent = function getPercent() {\n if (this.player_.muted()) {\n return 0;\n }\n\n return this.player_.volume();\n };\n /**\n * Increase volume level for keyboard users\n */\n\n\n _proto.stepForward = function stepForward() {\n this.checkMuted();\n this.player_.volume(this.player_.volume() + 0.1);\n };\n /**\n * Decrease volume level for keyboard users\n */\n\n\n _proto.stepBack = function stepBack() {\n this.checkMuted();\n this.player_.volume(this.player_.volume() - 0.1);\n };\n /**\n * Update ARIA accessibility attributes\n *\n * @param {EventTarget~Event} [event]\n * The `volumechange` event that caused this function to run.\n *\n * @listens Player#volumechange\n */\n\n\n _proto.updateARIAAttributes = function updateARIAAttributes(event) {\n var ariaValue = this.player_.muted() ? 0 : this.volumeAsPercentage_();\n this.el_.setAttribute('aria-valuenow', ariaValue);\n this.el_.setAttribute('aria-valuetext', ariaValue + '%');\n };\n /**\n * Returns the current value of the player volume as a percentage\n *\n * @private\n */\n\n\n _proto.volumeAsPercentage_ = function volumeAsPercentage_() {\n return Math.round(this.player_.volume() * 100);\n };\n /**\n * When user starts dragging the VolumeBar, store the volume and listen for\n * the end of the drag. When the drag ends, if the volume was set to zero,\n * set lastVolume to the stored volume.\n *\n * @listens slideractive\n * @private\n */\n\n\n _proto.updateLastVolume_ = function updateLastVolume_() {\n var _this2 = this;\n\n var volumeBeforeDrag = this.player_.volume();\n this.one('sliderinactive', function () {\n if (_this2.player_.volume() === 0) {\n _this2.player_.lastVolume_(volumeBeforeDrag);\n }\n });\n };\n\n return VolumeBar;\n}(Slider);\n/**\n * Default options for the `VolumeBar`\n *\n * @type {Object}\n * @private\n */\n\n\nVolumeBar.prototype.options_ = {\n children: ['volumeLevel'],\n barName: 'volumeLevel'\n};\n/**\n * Call the update event for this Slider when this event happens on the player.\n *\n * @type {string}\n */\n\nVolumeBar.prototype.playerEvent = 'volumechange';\nComponent.registerComponent('VolumeBar', VolumeBar);\n\n/**\n * The component for controlling the volume level\n *\n * @extends Component\n */\n\nvar VolumeControl =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(VolumeControl, _Component);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options={}]\n * The key/value store of player options.\n */\n function VolumeControl(player, options) {\n var _this;\n\n if (options === void 0) {\n options = {};\n }\n\n options.vertical = options.vertical || false; // Pass the vertical option down to the VolumeBar if\n // the VolumeBar is turned on.\n\n if (typeof options.volumeBar === 'undefined' || isPlain(options.volumeBar)) {\n options.volumeBar = options.volumeBar || {};\n options.volumeBar.vertical = options.vertical;\n }\n\n _this = _Component.call(this, player, options) || this; // hide this control if volume support is missing\n\n checkVolumeSupport(_assertThisInitialized(_assertThisInitialized(_this)), player);\n _this.throttledHandleMouseMove = throttle(bind(_assertThisInitialized(_assertThisInitialized(_this)), _this.handleMouseMove), 25);\n\n _this.on('mousedown', _this.handleMouseDown);\n\n _this.on('touchstart', _this.handleMouseDown); // while the slider is active (the mouse has been pressed down and\n // is dragging) or in focus we do not want to hide the VolumeBar\n\n\n _this.on(_this.volumeBar, ['focus', 'slideractive'], function () {\n _this.volumeBar.addClass('vjs-slider-active');\n\n _this.addClass('vjs-slider-active');\n\n _this.trigger('slideractive');\n });\n\n _this.on(_this.volumeBar, ['blur', 'sliderinactive'], function () {\n _this.volumeBar.removeClass('vjs-slider-active');\n\n _this.removeClass('vjs-slider-active');\n\n _this.trigger('sliderinactive');\n });\n\n return _this;\n }\n /**\n * Create the `Component`'s DOM element\n *\n * @return {Element}\n * The element that was created.\n */\n\n\n var _proto = VolumeControl.prototype;\n\n _proto.createEl = function createEl() {\n var orientationClass = 'vjs-volume-horizontal';\n\n if (this.options_.vertical) {\n orientationClass = 'vjs-volume-vertical';\n }\n\n return _Component.prototype.createEl.call(this, 'div', {\n className: \"vjs-volume-control vjs-control \" + orientationClass\n });\n };\n /**\n * Handle `mousedown` or `touchstart` events on the `VolumeControl`.\n *\n * @param {EventTarget~Event} event\n * `mousedown` or `touchstart` event that triggered this function\n *\n * @listens mousedown\n * @listens touchstart\n */\n\n\n _proto.handleMouseDown = function handleMouseDown(event) {\n var doc = this.el_.ownerDocument;\n this.on(doc, 'mousemove', this.throttledHandleMouseMove);\n this.on(doc, 'touchmove', this.throttledHandleMouseMove);\n this.on(doc, 'mouseup', this.handleMouseUp);\n this.on(doc, 'touchend', this.handleMouseUp);\n };\n /**\n * Handle `mouseup` or `touchend` events on the `VolumeControl`.\n *\n * @param {EventTarget~Event} event\n * `mouseup` or `touchend` event that triggered this function.\n *\n * @listens touchend\n * @listens mouseup\n */\n\n\n _proto.handleMouseUp = function handleMouseUp(event) {\n var doc = this.el_.ownerDocument;\n this.off(doc, 'mousemove', this.throttledHandleMouseMove);\n this.off(doc, 'touchmove', this.throttledHandleMouseMove);\n this.off(doc, 'mouseup', this.handleMouseUp);\n this.off(doc, 'touchend', this.handleMouseUp);\n };\n /**\n * Handle `mousedown` or `touchstart` events on the `VolumeControl`.\n *\n * @param {EventTarget~Event} event\n * `mousedown` or `touchstart` event that triggered this function\n *\n * @listens mousedown\n * @listens touchstart\n */\n\n\n _proto.handleMouseMove = function handleMouseMove(event) {\n this.volumeBar.handleMouseMove(event);\n };\n\n return VolumeControl;\n}(Component);\n/**\n * Default options for the `VolumeControl`\n *\n * @type {Object}\n * @private\n */\n\n\nVolumeControl.prototype.options_ = {\n children: ['volumeBar']\n};\nComponent.registerComponent('VolumeControl', VolumeControl);\n\n/**\n * Check if muting volume is supported and if it isn't hide the mute toggle\n * button.\n *\n * @param {Component} self\n * A reference to the mute toggle button\n *\n * @param {Player} player\n * A reference to the player\n *\n * @private\n */\nvar checkMuteSupport = function checkMuteSupport(self, player) {\n // hide mute toggle button if it's not supported by the current tech\n if (player.tech_ && !player.tech_.featuresMuteControl) {\n self.addClass('vjs-hidden');\n }\n\n self.on(player, 'loadstart', function () {\n if (!player.tech_.featuresMuteControl) {\n self.addClass('vjs-hidden');\n } else {\n self.removeClass('vjs-hidden');\n }\n });\n};\n\n/**\n * A button component for muting the audio.\n *\n * @extends Button\n */\n\nvar MuteToggle =\n/*#__PURE__*/\nfunction (_Button) {\n _inheritsLoose(MuteToggle, _Button);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function MuteToggle(player, options) {\n var _this;\n\n _this = _Button.call(this, player, options) || this; // hide this control if volume support is missing\n\n checkMuteSupport(_assertThisInitialized(_assertThisInitialized(_this)), player);\n\n _this.on(player, ['loadstart', 'volumechange'], _this.update);\n\n return _this;\n }\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n\n\n var _proto = MuteToggle.prototype;\n\n _proto.buildCSSClass = function buildCSSClass() {\n return \"vjs-mute-control \" + _Button.prototype.buildCSSClass.call(this);\n };\n /**\n * This gets called when an `MuteToggle` is \"clicked\". See\n * {@link ClickableComponent} for more detailed information on what a click can be.\n *\n * @param {EventTarget~Event} [event]\n * The `keydown`, `tap`, or `click` event that caused this function to be\n * called.\n *\n * @listens tap\n * @listens click\n */\n\n\n _proto.handleClick = function handleClick(event) {\n var vol = this.player_.volume();\n var lastVolume = this.player_.lastVolume_();\n\n if (vol === 0) {\n var volumeToSet = lastVolume < 0.1 ? 0.1 : lastVolume;\n this.player_.volume(volumeToSet);\n this.player_.muted(false);\n } else {\n this.player_.muted(this.player_.muted() ? false : true);\n }\n };\n /**\n * Update the `MuteToggle` button based on the state of `volume` and `muted`\n * on the player.\n *\n * @param {EventTarget~Event} [event]\n * The {@link Player#loadstart} event if this function was called\n * through an event.\n *\n * @listens Player#loadstart\n * @listens Player#volumechange\n */\n\n\n _proto.update = function update(event) {\n this.updateIcon_();\n this.updateControlText_();\n };\n /**\n * Update the appearance of the `MuteToggle` icon.\n *\n * Possible states (given `level` variable below):\n * - 0: crossed out\n * - 1: zero bars of volume\n * - 2: one bar of volume\n * - 3: two bars of volume\n *\n * @private\n */\n\n\n _proto.updateIcon_ = function updateIcon_() {\n var vol = this.player_.volume();\n var level = 3; // in iOS when a player is loaded with muted attribute\n // and volume is changed with a native mute button\n // we want to make sure muted state is updated\n\n if (IS_IOS) {\n this.player_.muted(this.player_.tech_.el_.muted);\n }\n\n if (vol === 0 || this.player_.muted()) {\n level = 0;\n } else if (vol < 0.33) {\n level = 1;\n } else if (vol < 0.67) {\n level = 2;\n } // TODO improve muted icon classes\n\n\n for (var i = 0; i < 4; i++) {\n removeClass(this.el_, \"vjs-vol-\" + i);\n }\n\n addClass(this.el_, \"vjs-vol-\" + level);\n };\n /**\n * If `muted` has changed on the player, update the control text\n * (`title` attribute on `vjs-mute-control` element and content of\n * `vjs-control-text` element).\n *\n * @private\n */\n\n\n _proto.updateControlText_ = function updateControlText_() {\n var soundOff = this.player_.muted() || this.player_.volume() === 0;\n var text = soundOff ? 'Unmute' : 'Mute';\n\n if (this.controlText() !== text) {\n this.controlText(text);\n }\n };\n\n return MuteToggle;\n}(Button);\n/**\n * The text that should display over the `MuteToggle`s controls. Added for localization.\n *\n * @type {string}\n * @private\n */\n\n\nMuteToggle.prototype.controlText_ = 'Mute';\nComponent.registerComponent('MuteToggle', MuteToggle);\n\n/**\n * A Component to contain the MuteToggle and VolumeControl so that\n * they can work together.\n *\n * @extends Component\n */\n\nvar VolumePanel =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(VolumePanel, _Component);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options={}]\n * The key/value store of player options.\n */\n function VolumePanel(player, options) {\n var _this;\n\n if (options === void 0) {\n options = {};\n }\n\n if (typeof options.inline !== 'undefined') {\n options.inline = options.inline;\n } else {\n options.inline = true;\n } // pass the inline option down to the VolumeControl as vertical if\n // the VolumeControl is on.\n\n\n if (typeof options.volumeControl === 'undefined' || isPlain(options.volumeControl)) {\n options.volumeControl = options.volumeControl || {};\n options.volumeControl.vertical = !options.inline;\n }\n\n _this = _Component.call(this, player, options) || this;\n\n _this.on(player, ['loadstart'], _this.volumePanelState_); // while the slider is active (the mouse has been pressed down and\n // is dragging) we do not want to hide the VolumeBar\n\n\n _this.on(_this.volumeControl, ['slideractive'], _this.sliderActive_);\n\n _this.on(_this.volumeControl, ['sliderinactive'], _this.sliderInactive_);\n\n return _this;\n }\n /**\n * Add vjs-slider-active class to the VolumePanel\n *\n * @listens VolumeControl#slideractive\n * @private\n */\n\n\n var _proto = VolumePanel.prototype;\n\n _proto.sliderActive_ = function sliderActive_() {\n this.addClass('vjs-slider-active');\n };\n /**\n * Removes vjs-slider-active class to the VolumePanel\n *\n * @listens VolumeControl#sliderinactive\n * @private\n */\n\n\n _proto.sliderInactive_ = function sliderInactive_() {\n this.removeClass('vjs-slider-active');\n };\n /**\n * Adds vjs-hidden or vjs-mute-toggle-only to the VolumePanel\n * depending on MuteToggle and VolumeControl state\n *\n * @listens Player#loadstart\n * @private\n */\n\n\n _proto.volumePanelState_ = function volumePanelState_() {\n // hide volume panel if neither volume control or mute toggle\n // are displayed\n if (this.volumeControl.hasClass('vjs-hidden') && this.muteToggle.hasClass('vjs-hidden')) {\n this.addClass('vjs-hidden');\n } // if only mute toggle is visible we don't want\n // volume panel expanding when hovered or active\n\n\n if (this.volumeControl.hasClass('vjs-hidden') && !this.muteToggle.hasClass('vjs-hidden')) {\n this.addClass('vjs-mute-toggle-only');\n }\n };\n /**\n * Create the `Component`'s DOM element\n *\n * @return {Element}\n * The element that was created.\n */\n\n\n _proto.createEl = function createEl() {\n var orientationClass = 'vjs-volume-panel-horizontal';\n\n if (!this.options_.inline) {\n orientationClass = 'vjs-volume-panel-vertical';\n }\n\n return _Component.prototype.createEl.call(this, 'div', {\n className: \"vjs-volume-panel vjs-control \" + orientationClass\n });\n };\n\n return VolumePanel;\n}(Component);\n/**\n * Default options for the `VolumeControl`\n *\n * @type {Object}\n * @private\n */\n\n\nVolumePanel.prototype.options_ = {\n children: ['muteToggle', 'volumeControl']\n};\nComponent.registerComponent('VolumePanel', VolumePanel);\n\n/**\n * The Menu component is used to build popup menus, including subtitle and\n * captions selection menus.\n *\n * @extends Component\n */\n\nvar Menu =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(Menu, _Component);\n\n /**\n * Create an instance of this class.\n *\n * @param {Player} player\n * the player that this component should attach to\n *\n * @param {Object} [options]\n * Object of option names and values\n *\n */\n function Menu(player, options) {\n var _this;\n\n _this = _Component.call(this, player, options) || this;\n\n if (options) {\n _this.menuButton_ = options.menuButton;\n }\n\n _this.focusedChild_ = -1;\n\n _this.on('keydown', _this.handleKeyPress);\n\n return _this;\n }\n /**\n * Add a {@link MenuItem} to the menu.\n *\n * @param {Object|string} component\n * The name or instance of the `MenuItem` to add.\n *\n */\n\n\n var _proto = Menu.prototype;\n\n _proto.addItem = function addItem(component) {\n this.addChild(component);\n component.on('blur', bind(this, this.handleBlur));\n component.on(['tap', 'click'], bind(this, function (event) {\n // Unpress the associated MenuButton, and move focus back to it\n if (this.menuButton_) {\n this.menuButton_.unpressButton(); // don't focus menu button if item is a caption settings item\n // because focus will move elsewhere\n\n if (component.name() !== 'CaptionSettingsMenuItem') {\n this.menuButton_.focus();\n }\n }\n }));\n };\n /**\n * Create the `Menu`s DOM element.\n *\n * @return {Element}\n * the element that was created\n */\n\n\n _proto.createEl = function createEl$$1() {\n var contentElType = this.options_.contentElType || 'ul';\n this.contentEl_ = createEl(contentElType, {\n className: 'vjs-menu-content'\n });\n this.contentEl_.setAttribute('role', 'menu');\n\n var el = _Component.prototype.createEl.call(this, 'div', {\n append: this.contentEl_,\n className: 'vjs-menu'\n });\n\n el.appendChild(this.contentEl_); // Prevent clicks from bubbling up. Needed for Menu Buttons,\n // where a click on the parent is significant\n\n on(el, 'click', function (event) {\n event.preventDefault();\n event.stopImmediatePropagation();\n });\n return el;\n };\n\n _proto.dispose = function dispose() {\n this.contentEl_ = null;\n\n _Component.prototype.dispose.call(this);\n };\n /**\n * Called when a `MenuItem` loses focus.\n *\n * @param {EventTarget~Event} event\n * The `blur` event that caused this function to be called.\n *\n * @listens blur\n */\n\n\n _proto.handleBlur = function handleBlur(event) {\n var relatedTarget = event.relatedTarget || document.activeElement; // Close menu popup when a user clicks outside the menu\n\n if (!this.children().some(function (element) {\n return element.el() === relatedTarget;\n })) {\n var btn = this.menuButton_;\n\n if (btn && btn.buttonPressed_ && relatedTarget !== btn.el().firstChild) {\n btn.unpressButton();\n }\n }\n };\n /**\n * Handle a `keydown` event on this menu. This listener is added in the constructor.\n *\n * @param {EventTarget~Event} event\n * A `keydown` event that happened on the menu.\n *\n * @listens keydown\n */\n\n\n _proto.handleKeyPress = function handleKeyPress(event) {\n // Left and Down Arrows\n if (event.which === 37 || event.which === 40) {\n event.preventDefault();\n this.stepForward(); // Up and Right Arrows\n } else if (event.which === 38 || event.which === 39) {\n event.preventDefault();\n this.stepBack();\n }\n };\n /**\n * Move to next (lower) menu item for keyboard users.\n */\n\n\n _proto.stepForward = function stepForward() {\n var stepChild = 0;\n\n if (this.focusedChild_ !== undefined) {\n stepChild = this.focusedChild_ + 1;\n }\n\n this.focus(stepChild);\n };\n /**\n * Move to previous (higher) menu item for keyboard users.\n */\n\n\n _proto.stepBack = function stepBack() {\n var stepChild = 0;\n\n if (this.focusedChild_ !== undefined) {\n stepChild = this.focusedChild_ - 1;\n }\n\n this.focus(stepChild);\n };\n /**\n * Set focus on a {@link MenuItem} in the `Menu`.\n *\n * @param {Object|string} [item=0]\n * Index of child item set focus on.\n */\n\n\n _proto.focus = function focus(item) {\n if (item === void 0) {\n item = 0;\n }\n\n var children = this.children().slice();\n var haveTitle = children.length && children[0].className && /vjs-menu-title/.test(children[0].className);\n\n if (haveTitle) {\n children.shift();\n }\n\n if (children.length > 0) {\n if (item < 0) {\n item = 0;\n } else if (item >= children.length) {\n item = children.length - 1;\n }\n\n this.focusedChild_ = item;\n children[item].el_.focus();\n }\n };\n\n return Menu;\n}(Component);\n\nComponent.registerComponent('Menu', Menu);\n\n/**\n * A `MenuButton` class for any popup {@link Menu}.\n *\n * @extends Component\n */\n\nvar MenuButton =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(MenuButton, _Component);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options={}]\n * The key/value store of player options.\n */\n function MenuButton(player, options) {\n var _this;\n\n if (options === void 0) {\n options = {};\n }\n\n _this = _Component.call(this, player, options) || this;\n _this.menuButton_ = new Button(player, options);\n\n _this.menuButton_.controlText(_this.controlText_);\n\n _this.menuButton_.el_.setAttribute('aria-haspopup', 'true'); // Add buildCSSClass values to the button, not the wrapper\n\n\n var buttonClass = Button.prototype.buildCSSClass();\n _this.menuButton_.el_.className = _this.buildCSSClass() + ' ' + buttonClass;\n\n _this.menuButton_.removeClass('vjs-control');\n\n _this.addChild(_this.menuButton_);\n\n _this.update();\n\n _this.enabled_ = true;\n\n _this.on(_this.menuButton_, 'tap', _this.handleClick);\n\n _this.on(_this.menuButton_, 'click', _this.handleClick);\n\n _this.on(_this.menuButton_, 'focus', _this.handleFocus);\n\n _this.on(_this.menuButton_, 'blur', _this.handleBlur);\n\n _this.on(_this.menuButton_, 'mouseenter', function () {\n _this.menu.show();\n });\n\n _this.on('keydown', _this.handleSubmenuKeyPress);\n\n return _this;\n }\n /**\n * Update the menu based on the current state of its items.\n */\n\n\n var _proto = MenuButton.prototype;\n\n _proto.update = function update() {\n var menu = this.createMenu();\n\n if (this.menu) {\n this.menu.dispose();\n this.removeChild(this.menu);\n }\n\n this.menu = menu;\n this.addChild(menu);\n /**\n * Track the state of the menu button\n *\n * @type {Boolean}\n * @private\n */\n\n this.buttonPressed_ = false;\n this.menuButton_.el_.setAttribute('aria-expanded', 'false');\n\n if (this.items && this.items.length <= this.hideThreshold_) {\n this.hide();\n } else {\n this.show();\n }\n };\n /**\n * Create the menu and add all items to it.\n *\n * @return {Menu}\n * The constructed menu\n */\n\n\n _proto.createMenu = function createMenu() {\n var menu = new Menu(this.player_, {\n menuButton: this\n });\n /**\n * Hide the menu if the number of items is less than or equal to this threshold. This defaults\n * to 0 and whenever we add items which can be hidden to the menu we'll increment it. We list\n * it here because every time we run `createMenu` we need to reset the value.\n *\n * @protected\n * @type {Number}\n */\n\n this.hideThreshold_ = 0; // Add a title list item to the top\n\n if (this.options_.title) {\n var title = createEl('li', {\n className: 'vjs-menu-title',\n innerHTML: toTitleCase(this.options_.title),\n tabIndex: -1\n });\n this.hideThreshold_ += 1;\n menu.children_.unshift(title);\n prependTo(title, menu.contentEl());\n }\n\n this.items = this.createItems();\n\n if (this.items) {\n // Add menu items to the menu\n for (var i = 0; i < this.items.length; i++) {\n menu.addItem(this.items[i]);\n }\n }\n\n return menu;\n };\n /**\n * Create the list of menu items. Specific to each subclass.\n *\n * @abstract\n */\n\n\n _proto.createItems = function createItems() {};\n /**\n * Create the `MenuButtons`s DOM element.\n *\n * @return {Element}\n * The element that gets created.\n */\n\n\n _proto.createEl = function createEl$$1() {\n return _Component.prototype.createEl.call(this, 'div', {\n className: this.buildWrapperCSSClass()\n }, {});\n };\n /**\n * Allow sub components to stack CSS class names for the wrapper element\n *\n * @return {string}\n * The constructed wrapper DOM `className`\n */\n\n\n _proto.buildWrapperCSSClass = function buildWrapperCSSClass() {\n var menuButtonClass = 'vjs-menu-button'; // If the inline option is passed, we want to use different styles altogether.\n\n if (this.options_.inline === true) {\n menuButtonClass += '-inline';\n } else {\n menuButtonClass += '-popup';\n } // TODO: Fix the CSS so that this isn't necessary\n\n\n var buttonClass = Button.prototype.buildCSSClass();\n return \"vjs-menu-button \" + menuButtonClass + \" \" + buttonClass + \" \" + _Component.prototype.buildCSSClass.call(this);\n };\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n\n\n _proto.buildCSSClass = function buildCSSClass() {\n var menuButtonClass = 'vjs-menu-button'; // If the inline option is passed, we want to use different styles altogether.\n\n if (this.options_.inline === true) {\n menuButtonClass += '-inline';\n } else {\n menuButtonClass += '-popup';\n }\n\n return \"vjs-menu-button \" + menuButtonClass + \" \" + _Component.prototype.buildCSSClass.call(this);\n };\n /**\n * Get or set the localized control text that will be used for accessibility.\n *\n * > NOTE: This will come from the internal `menuButton_` element.\n *\n * @param {string} [text]\n * Control text for element.\n *\n * @param {Element} [el=this.menuButton_.el()]\n * Element to set the title on.\n *\n * @return {string}\n * - The control text when getting\n */\n\n\n _proto.controlText = function controlText(text, el) {\n if (el === void 0) {\n el = this.menuButton_.el();\n }\n\n return this.menuButton_.controlText(text, el);\n };\n /**\n * Handle a click on a `MenuButton`.\n * See {@link ClickableComponent#handleClick} for instances where this is called.\n *\n * @param {EventTarget~Event} event\n * The `keydown`, `tap`, or `click` event that caused this function to be\n * called.\n *\n * @listens tap\n * @listens click\n */\n\n\n _proto.handleClick = function handleClick(event) {\n if (this.buttonPressed_) {\n this.unpressButton();\n } else {\n this.pressButton();\n }\n };\n /**\n * Set the focus to the actual button, not to this element\n */\n\n\n _proto.focus = function focus() {\n this.menuButton_.focus();\n };\n /**\n * Remove the focus from the actual button, not this element\n */\n\n\n _proto.blur = function blur() {\n this.menuButton_.blur();\n };\n /**\n * This gets called when a `MenuButton` gains focus via a `focus` event.\n * Turns on listening for `keydown` events. When they happen it\n * calls `this.handleKeyPress`.\n *\n * @param {EventTarget~Event} event\n * The `focus` event that caused this function to be called.\n *\n * @listens focus\n */\n\n\n _proto.handleFocus = function handleFocus() {\n on(document, 'keydown', bind(this, this.handleKeyPress));\n };\n /**\n * Called when a `MenuButton` loses focus. Turns off the listener for\n * `keydown` events. Which Stops `this.handleKeyPress` from getting called.\n *\n * @param {EventTarget~Event} event\n * The `blur` event that caused this function to be called.\n *\n * @listens blur\n */\n\n\n _proto.handleBlur = function handleBlur() {\n off(document, 'keydown', bind(this, this.handleKeyPress));\n };\n /**\n * Handle tab, escape, down arrow, and up arrow keys for `MenuButton`. See\n * {@link ClickableComponent#handleKeyPress} for instances where this is called.\n *\n * @param {EventTarget~Event} event\n * The `keydown` event that caused this function to be called.\n *\n * @listens keydown\n */\n\n\n _proto.handleKeyPress = function handleKeyPress(event) {\n // Escape (27) key or Tab (9) key unpress the 'button'\n if (event.which === 27 || event.which === 9) {\n if (this.buttonPressed_) {\n this.unpressButton();\n } // Don't preventDefault for Tab key - we still want to lose focus\n\n\n if (event.which !== 9) {\n event.preventDefault(); // Set focus back to the menu button's button\n\n this.menuButton_.el_.focus();\n } // Enter (13) or Up (38) key or Down (40) key press the 'button'\n\n } else if (event.which === 13 || event.which === 38 || event.which === 40) {\n if (!this.buttonPressed_) {\n this.pressButton();\n event.preventDefault();\n }\n }\n };\n /**\n * Handle a `keydown` event on a sub-menu. The listener for this is added in\n * the constructor.\n *\n * @param {EventTarget~Event} event\n * Key press event\n *\n * @listens keydown\n */\n\n\n _proto.handleSubmenuKeyPress = function handleSubmenuKeyPress(event) {\n // Escape (27) key or Tab (9) key unpress the 'button'\n if (event.which === 27 || event.which === 9) {\n if (this.buttonPressed_) {\n this.unpressButton();\n } // Don't preventDefault for Tab key - we still want to lose focus\n\n\n if (event.which !== 9) {\n event.preventDefault(); // Set focus back to the menu button's button\n\n this.menuButton_.el_.focus();\n }\n }\n };\n /**\n * Put the current `MenuButton` into a pressed state.\n */\n\n\n _proto.pressButton = function pressButton() {\n if (this.enabled_) {\n this.buttonPressed_ = true;\n this.menu.show();\n this.menu.lockShowing();\n this.menuButton_.el_.setAttribute('aria-expanded', 'true'); // set the focus into the submenu, except on iOS where it is resulting in\n // undesired scrolling behavior when the player is in an iframe\n\n if (IS_IOS && isInFrame()) {\n // Return early so that the menu isn't focused\n return;\n }\n\n this.menu.focus();\n }\n };\n /**\n * Take the current `MenuButton` out of a pressed state.\n */\n\n\n _proto.unpressButton = function unpressButton() {\n if (this.enabled_) {\n this.buttonPressed_ = false;\n this.menu.unlockShowing();\n this.menu.hide();\n this.menuButton_.el_.setAttribute('aria-expanded', 'false');\n }\n };\n /**\n * Disable the `MenuButton`. Don't allow it to be clicked.\n */\n\n\n _proto.disable = function disable() {\n this.unpressButton();\n this.enabled_ = false;\n this.addClass('vjs-disabled');\n this.menuButton_.disable();\n };\n /**\n * Enable the `MenuButton`. Allow it to be clicked.\n */\n\n\n _proto.enable = function enable() {\n this.enabled_ = true;\n this.removeClass('vjs-disabled');\n this.menuButton_.enable();\n };\n\n return MenuButton;\n}(Component);\n\nComponent.registerComponent('MenuButton', MenuButton);\n\n/**\n * The base class for buttons that toggle specific track types (e.g. subtitles).\n *\n * @extends MenuButton\n */\n\nvar TrackButton =\n/*#__PURE__*/\nfunction (_MenuButton) {\n _inheritsLoose(TrackButton, _MenuButton);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function TrackButton(player, options) {\n var _this;\n\n var tracks = options.tracks;\n _this = _MenuButton.call(this, player, options) || this;\n\n if (_this.items.length <= 1) {\n _this.hide();\n }\n\n if (!tracks) {\n return _assertThisInitialized(_this);\n }\n\n var updateHandler = bind(_assertThisInitialized(_assertThisInitialized(_this)), _this.update);\n tracks.addEventListener('removetrack', updateHandler);\n tracks.addEventListener('addtrack', updateHandler);\n\n _this.player_.on('ready', updateHandler);\n\n _this.player_.on('dispose', function () {\n tracks.removeEventListener('removetrack', updateHandler);\n tracks.removeEventListener('addtrack', updateHandler);\n });\n\n return _this;\n }\n\n return TrackButton;\n}(MenuButton);\n\nComponent.registerComponent('TrackButton', TrackButton);\n\n/**\n * The component for a menu item. `<li>`\n *\n * @extends ClickableComponent\n */\n\nvar MenuItem =\n/*#__PURE__*/\nfunction (_ClickableComponent) {\n _inheritsLoose(MenuItem, _ClickableComponent);\n\n /**\n * Creates an instance of the this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options={}]\n * The key/value store of player options.\n *\n */\n function MenuItem(player, options) {\n var _this;\n\n _this = _ClickableComponent.call(this, player, options) || this;\n _this.selectable = options.selectable;\n _this.isSelected_ = options.selected || false;\n _this.multiSelectable = options.multiSelectable;\n\n _this.selected(_this.isSelected_);\n\n if (_this.selectable) {\n if (_this.multiSelectable) {\n _this.el_.setAttribute('role', 'menuitemcheckbox');\n } else {\n _this.el_.setAttribute('role', 'menuitemradio');\n }\n } else {\n _this.el_.setAttribute('role', 'menuitem');\n }\n\n return _this;\n }\n /**\n * Create the `MenuItem's DOM element\n *\n * @param {string} [type=li]\n * Element's node type, not actually used, always set to `li`.\n *\n * @param {Object} [props={}]\n * An object of properties that should be set on the element\n *\n * @param {Object} [attrs={}]\n * An object of attributes that should be set on the element\n *\n * @return {Element}\n * The element that gets created.\n */\n\n\n var _proto = MenuItem.prototype;\n\n _proto.createEl = function createEl(type, props, attrs) {\n // The control is textual, not just an icon\n this.nonIconControl = true;\n return _ClickableComponent.prototype.createEl.call(this, 'li', assign({\n className: 'vjs-menu-item',\n innerHTML: \"<span class=\\\"vjs-menu-item-text\\\">\" + this.localize(this.options_.label) + \"</span>\",\n tabIndex: -1\n }, props), attrs);\n };\n /**\n * Any click on a `MenuItem` puts it into the selected state.\n * See {@link ClickableComponent#handleClick} for instances where this is called.\n *\n * @param {EventTarget~Event} event\n * The `keydown`, `tap`, or `click` event that caused this function to be\n * called.\n *\n * @listens tap\n * @listens click\n */\n\n\n _proto.handleClick = function handleClick(event) {\n this.selected(true);\n };\n /**\n * Set the state for this menu item as selected or not.\n *\n * @param {boolean} selected\n * if the menu item is selected or not\n */\n\n\n _proto.selected = function selected(_selected) {\n if (this.selectable) {\n if (_selected) {\n this.addClass('vjs-selected');\n this.el_.setAttribute('aria-checked', 'true'); // aria-checked isn't fully supported by browsers/screen readers,\n // so indicate selected state to screen reader in the control text.\n\n this.controlText(', selected');\n this.isSelected_ = true;\n } else {\n this.removeClass('vjs-selected');\n this.el_.setAttribute('aria-checked', 'false'); // Indicate un-selected state to screen reader\n\n this.controlText('');\n this.isSelected_ = false;\n }\n }\n };\n\n return MenuItem;\n}(ClickableComponent);\n\nComponent.registerComponent('MenuItem', MenuItem);\n\n/**\n * The specific menu item type for selecting a language within a text track kind\n *\n * @extends MenuItem\n */\n\nvar TextTrackMenuItem =\n/*#__PURE__*/\nfunction (_MenuItem) {\n _inheritsLoose(TextTrackMenuItem, _MenuItem);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function TextTrackMenuItem(player, options) {\n var _this;\n\n var track = options.track;\n var tracks = player.textTracks(); // Modify options for parent MenuItem class's init.\n\n options.label = track.label || track.language || 'Unknown';\n options.selected = track.mode === 'showing';\n _this = _MenuItem.call(this, player, options) || this;\n _this.track = track;\n\n var changeHandler = function changeHandler() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this.handleTracksChange.apply(_assertThisInitialized(_assertThisInitialized(_this)), args);\n };\n\n var selectedLanguageChangeHandler = function selectedLanguageChangeHandler() {\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n\n _this.handleSelectedLanguageChange.apply(_assertThisInitialized(_assertThisInitialized(_this)), args);\n };\n\n player.on(['loadstart', 'texttrackchange'], changeHandler);\n tracks.addEventListener('change', changeHandler);\n tracks.addEventListener('selectedlanguagechange', selectedLanguageChangeHandler);\n\n _this.on('dispose', function () {\n player.off(['loadstart', 'texttrackchange'], changeHandler);\n tracks.removeEventListener('change', changeHandler);\n tracks.removeEventListener('selectedlanguagechange', selectedLanguageChangeHandler);\n }); // iOS7 doesn't dispatch change events to TextTrackLists when an\n // associated track's mode changes. Without something like\n // Object.observe() (also not present on iOS7), it's not\n // possible to detect changes to the mode attribute and polyfill\n // the change event. As a poor substitute, we manually dispatch\n // change events whenever the controls modify the mode.\n\n\n if (tracks.onchange === undefined) {\n var event;\n\n _this.on(['tap', 'click'], function () {\n if (typeof window$1.Event !== 'object') {\n // Android 2.3 throws an Illegal Constructor error for window.Event\n try {\n event = new window$1.Event('change');\n } catch (err) {// continue regardless of error\n }\n }\n\n if (!event) {\n event = document.createEvent('Event');\n event.initEvent('change', true, true);\n }\n\n tracks.dispatchEvent(event);\n });\n } // set the default state based on current tracks\n\n\n _this.handleTracksChange();\n\n return _this;\n }\n /**\n * This gets called when an `TextTrackMenuItem` is \"clicked\". See\n * {@link ClickableComponent} for more detailed information on what a click can be.\n *\n * @param {EventTarget~Event} event\n * The `keydown`, `tap`, or `click` event that caused this function to be\n * called.\n *\n * @listens tap\n * @listens click\n */\n\n\n var _proto = TextTrackMenuItem.prototype;\n\n _proto.handleClick = function handleClick(event) {\n var kind = this.track.kind;\n var kinds = this.track.kinds;\n var tracks = this.player_.textTracks();\n\n if (!kinds) {\n kinds = [kind];\n }\n\n _MenuItem.prototype.handleClick.call(this, event);\n\n if (!tracks) {\n return;\n }\n\n for (var i = 0; i < tracks.length; i++) {\n var track = tracks[i];\n\n if (track === this.track && kinds.indexOf(track.kind) > -1) {\n if (track.mode !== 'showing') {\n track.mode = 'showing';\n }\n } else if (track.mode !== 'disabled') {\n track.mode = 'disabled';\n }\n }\n };\n /**\n * Handle text track list change\n *\n * @param {EventTarget~Event} event\n * The `change` event that caused this function to be called.\n *\n * @listens TextTrackList#change\n */\n\n\n _proto.handleTracksChange = function handleTracksChange(event) {\n var shouldBeSelected = this.track.mode === 'showing'; // Prevent redundant selected() calls because they may cause\n // screen readers to read the appended control text unnecessarily\n\n if (shouldBeSelected !== this.isSelected_) {\n this.selected(shouldBeSelected);\n }\n };\n\n _proto.handleSelectedLanguageChange = function handleSelectedLanguageChange(event) {\n if (this.track.mode === 'showing') {\n var selectedLanguage = this.player_.cache_.selectedLanguage; // Don't replace the kind of track across the same language\n\n if (selectedLanguage && selectedLanguage.enabled && selectedLanguage.language === this.track.language && selectedLanguage.kind !== this.track.kind) {\n return;\n }\n\n this.player_.cache_.selectedLanguage = {\n enabled: true,\n language: this.track.language,\n kind: this.track.kind\n };\n }\n };\n\n _proto.dispose = function dispose() {\n // remove reference to track object on dispose\n this.track = null;\n\n _MenuItem.prototype.dispose.call(this);\n };\n\n return TextTrackMenuItem;\n}(MenuItem);\n\nComponent.registerComponent('TextTrackMenuItem', TextTrackMenuItem);\n\n/**\n * A special menu item for turning of a specific type of text track\n *\n * @extends TextTrackMenuItem\n */\n\nvar OffTextTrackMenuItem =\n/*#__PURE__*/\nfunction (_TextTrackMenuItem) {\n _inheritsLoose(OffTextTrackMenuItem, _TextTrackMenuItem);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function OffTextTrackMenuItem(player, options) {\n // Create pseudo track info\n // Requires options['kind']\n options.track = {\n player: player,\n kind: options.kind,\n kinds: options.kinds,\n default: false,\n mode: 'disabled'\n };\n\n if (!options.kinds) {\n options.kinds = [options.kind];\n }\n\n if (options.label) {\n options.track.label = options.label;\n } else {\n options.track.label = options.kinds.join(' and ') + ' off';\n } // MenuItem is selectable\n\n\n options.selectable = true; // MenuItem is NOT multiSelectable (i.e. only one can be marked \"selected\" at a time)\n\n options.multiSelectable = false;\n return _TextTrackMenuItem.call(this, player, options) || this;\n }\n /**\n * Handle text track change\n *\n * @param {EventTarget~Event} event\n * The event that caused this function to run\n */\n\n\n var _proto = OffTextTrackMenuItem.prototype;\n\n _proto.handleTracksChange = function handleTracksChange(event) {\n var tracks = this.player().textTracks();\n var shouldBeSelected = true;\n\n for (var i = 0, l = tracks.length; i < l; i++) {\n var track = tracks[i];\n\n if (this.options_.kinds.indexOf(track.kind) > -1 && track.mode === 'showing') {\n shouldBeSelected = false;\n break;\n }\n } // Prevent redundant selected() calls because they may cause\n // screen readers to read the appended control text unnecessarily\n\n\n if (shouldBeSelected !== this.isSelected_) {\n this.selected(shouldBeSelected);\n }\n };\n\n _proto.handleSelectedLanguageChange = function handleSelectedLanguageChange(event) {\n var tracks = this.player().textTracks();\n var allHidden = true;\n\n for (var i = 0, l = tracks.length; i < l; i++) {\n var track = tracks[i];\n\n if (['captions', 'descriptions', 'subtitles'].indexOf(track.kind) > -1 && track.mode === 'showing') {\n allHidden = false;\n break;\n }\n }\n\n if (allHidden) {\n this.player_.cache_.selectedLanguage = {\n enabled: false\n };\n }\n };\n\n return OffTextTrackMenuItem;\n}(TextTrackMenuItem);\n\nComponent.registerComponent('OffTextTrackMenuItem', OffTextTrackMenuItem);\n\n/**\n * The base class for buttons that toggle specific text track types (e.g. subtitles)\n *\n * @extends MenuButton\n */\n\nvar TextTrackButton =\n/*#__PURE__*/\nfunction (_TrackButton) {\n _inheritsLoose(TextTrackButton, _TrackButton);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options={}]\n * The key/value store of player options.\n */\n function TextTrackButton(player, options) {\n if (options === void 0) {\n options = {};\n }\n\n options.tracks = player.textTracks();\n return _TrackButton.call(this, player, options) || this;\n }\n /**\n * Create a menu item for each text track\n *\n * @param {TextTrackMenuItem[]} [items=[]]\n * Existing array of items to use during creation\n *\n * @return {TextTrackMenuItem[]}\n * Array of menu items that were created\n */\n\n\n var _proto = TextTrackButton.prototype;\n\n _proto.createItems = function createItems(items, TrackMenuItem) {\n if (items === void 0) {\n items = [];\n }\n\n if (TrackMenuItem === void 0) {\n TrackMenuItem = TextTrackMenuItem;\n }\n\n // Label is an override for the [track] off label\n // USed to localise captions/subtitles\n var label;\n\n if (this.label_) {\n label = this.label_ + \" off\";\n } // Add an OFF menu item to turn all tracks off\n\n\n items.push(new OffTextTrackMenuItem(this.player_, {\n kinds: this.kinds_,\n kind: this.kind_,\n label: label\n }));\n this.hideThreshold_ += 1;\n var tracks = this.player_.textTracks();\n\n if (!Array.isArray(this.kinds_)) {\n this.kinds_ = [this.kind_];\n }\n\n for (var i = 0; i < tracks.length; i++) {\n var track = tracks[i]; // only add tracks that are of an appropriate kind and have a label\n\n if (this.kinds_.indexOf(track.kind) > -1) {\n var item = new TrackMenuItem(this.player_, {\n track: track,\n // MenuItem is selectable\n selectable: true,\n // MenuItem is NOT multiSelectable (i.e. only one can be marked \"selected\" at a time)\n multiSelectable: false\n });\n item.addClass(\"vjs-\" + track.kind + \"-menu-item\");\n items.push(item);\n }\n }\n\n return items;\n };\n\n return TextTrackButton;\n}(TrackButton);\n\nComponent.registerComponent('TextTrackButton', TextTrackButton);\n\n/**\n * The chapter track menu item\n *\n * @extends MenuItem\n */\n\nvar ChaptersTrackMenuItem =\n/*#__PURE__*/\nfunction (_MenuItem) {\n _inheritsLoose(ChaptersTrackMenuItem, _MenuItem);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function ChaptersTrackMenuItem(player, options) {\n var _this;\n\n var track = options.track;\n var cue = options.cue;\n var currentTime = player.currentTime(); // Modify options for parent MenuItem class's init.\n\n options.selectable = true;\n options.multiSelectable = false;\n options.label = cue.text;\n options.selected = cue.startTime <= currentTime && currentTime < cue.endTime;\n _this = _MenuItem.call(this, player, options) || this;\n _this.track = track;\n _this.cue = cue;\n track.addEventListener('cuechange', bind(_assertThisInitialized(_assertThisInitialized(_this)), _this.update));\n return _this;\n }\n /**\n * This gets called when an `ChaptersTrackMenuItem` is \"clicked\". See\n * {@link ClickableComponent} for more detailed information on what a click can be.\n *\n * @param {EventTarget~Event} [event]\n * The `keydown`, `tap`, or `click` event that caused this function to be\n * called.\n *\n * @listens tap\n * @listens click\n */\n\n\n var _proto = ChaptersTrackMenuItem.prototype;\n\n _proto.handleClick = function handleClick(event) {\n _MenuItem.prototype.handleClick.call(this);\n\n this.player_.currentTime(this.cue.startTime);\n this.update(this.cue.startTime);\n };\n /**\n * Update chapter menu item\n *\n * @param {EventTarget~Event} [event]\n * The `cuechange` event that caused this function to run.\n *\n * @listens TextTrack#cuechange\n */\n\n\n _proto.update = function update(event) {\n var cue = this.cue;\n var currentTime = this.player_.currentTime(); // vjs.log(currentTime, cue.startTime);\n\n this.selected(cue.startTime <= currentTime && currentTime < cue.endTime);\n };\n\n return ChaptersTrackMenuItem;\n}(MenuItem);\n\nComponent.registerComponent('ChaptersTrackMenuItem', ChaptersTrackMenuItem);\n\n/**\n * The button component for toggling and selecting chapters\n * Chapters act much differently than other text tracks\n * Cues are navigation vs. other tracks of alternative languages\n *\n * @extends TextTrackButton\n */\n\nvar ChaptersButton =\n/*#__PURE__*/\nfunction (_TextTrackButton) {\n _inheritsLoose(ChaptersButton, _TextTrackButton);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n *\n * @param {Component~ReadyCallback} [ready]\n * The function to call when this function is ready.\n */\n function ChaptersButton(player, options, ready) {\n return _TextTrackButton.call(this, player, options, ready) || this;\n }\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n\n\n var _proto = ChaptersButton.prototype;\n\n _proto.buildCSSClass = function buildCSSClass() {\n return \"vjs-chapters-button \" + _TextTrackButton.prototype.buildCSSClass.call(this);\n };\n\n _proto.buildWrapperCSSClass = function buildWrapperCSSClass() {\n return \"vjs-chapters-button \" + _TextTrackButton.prototype.buildWrapperCSSClass.call(this);\n };\n /**\n * Update the menu based on the current state of its items.\n *\n * @param {EventTarget~Event} [event]\n * An event that triggered this function to run.\n *\n * @listens TextTrackList#addtrack\n * @listens TextTrackList#removetrack\n * @listens TextTrackList#change\n */\n\n\n _proto.update = function update(event) {\n if (!this.track_ || event && (event.type === 'addtrack' || event.type === 'removetrack')) {\n this.setTrack(this.findChaptersTrack());\n }\n\n _TextTrackButton.prototype.update.call(this);\n };\n /**\n * Set the currently selected track for the chapters button.\n *\n * @param {TextTrack} track\n * The new track to select. Nothing will change if this is the currently selected\n * track.\n */\n\n\n _proto.setTrack = function setTrack(track) {\n if (this.track_ === track) {\n return;\n }\n\n if (!this.updateHandler_) {\n this.updateHandler_ = this.update.bind(this);\n } // here this.track_ refers to the old track instance\n\n\n if (this.track_) {\n var remoteTextTrackEl = this.player_.remoteTextTrackEls().getTrackElementByTrack_(this.track_);\n\n if (remoteTextTrackEl) {\n remoteTextTrackEl.removeEventListener('load', this.updateHandler_);\n }\n\n this.track_ = null;\n }\n\n this.track_ = track; // here this.track_ refers to the new track instance\n\n if (this.track_) {\n this.track_.mode = 'hidden';\n\n var _remoteTextTrackEl = this.player_.remoteTextTrackEls().getTrackElementByTrack_(this.track_);\n\n if (_remoteTextTrackEl) {\n _remoteTextTrackEl.addEventListener('load', this.updateHandler_);\n }\n }\n };\n /**\n * Find the track object that is currently in use by this ChaptersButton\n *\n * @return {TextTrack|undefined}\n * The current track or undefined if none was found.\n */\n\n\n _proto.findChaptersTrack = function findChaptersTrack() {\n var tracks = this.player_.textTracks() || [];\n\n for (var i = tracks.length - 1; i >= 0; i--) {\n // We will always choose the last track as our chaptersTrack\n var track = tracks[i];\n\n if (track.kind === this.kind_) {\n return track;\n }\n }\n };\n /**\n * Get the caption for the ChaptersButton based on the track label. This will also\n * use the current tracks localized kind as a fallback if a label does not exist.\n *\n * @return {string}\n * The tracks current label or the localized track kind.\n */\n\n\n _proto.getMenuCaption = function getMenuCaption() {\n if (this.track_ && this.track_.label) {\n return this.track_.label;\n }\n\n return this.localize(toTitleCase(this.kind_));\n };\n /**\n * Create menu from chapter track\n *\n * @return {Menu}\n * New menu for the chapter buttons\n */\n\n\n _proto.createMenu = function createMenu() {\n this.options_.title = this.getMenuCaption();\n return _TextTrackButton.prototype.createMenu.call(this);\n };\n /**\n * Create a menu item for each text track\n *\n * @return {TextTrackMenuItem[]}\n * Array of menu items\n */\n\n\n _proto.createItems = function createItems() {\n var items = [];\n\n if (!this.track_) {\n return items;\n }\n\n var cues = this.track_.cues;\n\n if (!cues) {\n return items;\n }\n\n for (var i = 0, l = cues.length; i < l; i++) {\n var cue = cues[i];\n var mi = new ChaptersTrackMenuItem(this.player_, {\n track: this.track_,\n cue: cue\n });\n items.push(mi);\n }\n\n return items;\n };\n\n return ChaptersButton;\n}(TextTrackButton);\n/**\n * `kind` of TextTrack to look for to associate it with this menu.\n *\n * @type {string}\n * @private\n */\n\n\nChaptersButton.prototype.kind_ = 'chapters';\n/**\n * The text that should display over the `ChaptersButton`s controls. Added for localization.\n *\n * @type {string}\n * @private\n */\n\nChaptersButton.prototype.controlText_ = 'Chapters';\nComponent.registerComponent('ChaptersButton', ChaptersButton);\n\n/**\n * The button component for toggling and selecting descriptions\n *\n * @extends TextTrackButton\n */\n\nvar DescriptionsButton =\n/*#__PURE__*/\nfunction (_TextTrackButton) {\n _inheritsLoose(DescriptionsButton, _TextTrackButton);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n *\n * @param {Component~ReadyCallback} [ready]\n * The function to call when this component is ready.\n */\n function DescriptionsButton(player, options, ready) {\n var _this;\n\n _this = _TextTrackButton.call(this, player, options, ready) || this;\n var tracks = player.textTracks();\n var changeHandler = bind(_assertThisInitialized(_assertThisInitialized(_this)), _this.handleTracksChange);\n tracks.addEventListener('change', changeHandler);\n\n _this.on('dispose', function () {\n tracks.removeEventListener('change', changeHandler);\n });\n\n return _this;\n }\n /**\n * Handle text track change\n *\n * @param {EventTarget~Event} event\n * The event that caused this function to run\n *\n * @listens TextTrackList#change\n */\n\n\n var _proto = DescriptionsButton.prototype;\n\n _proto.handleTracksChange = function handleTracksChange(event) {\n var tracks = this.player().textTracks();\n var disabled = false; // Check whether a track of a different kind is showing\n\n for (var i = 0, l = tracks.length; i < l; i++) {\n var track = tracks[i];\n\n if (track.kind !== this.kind_ && track.mode === 'showing') {\n disabled = true;\n break;\n }\n } // If another track is showing, disable this menu button\n\n\n if (disabled) {\n this.disable();\n } else {\n this.enable();\n }\n };\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n\n\n _proto.buildCSSClass = function buildCSSClass() {\n return \"vjs-descriptions-button \" + _TextTrackButton.prototype.buildCSSClass.call(this);\n };\n\n _proto.buildWrapperCSSClass = function buildWrapperCSSClass() {\n return \"vjs-descriptions-button \" + _TextTrackButton.prototype.buildWrapperCSSClass.call(this);\n };\n\n return DescriptionsButton;\n}(TextTrackButton);\n/**\n * `kind` of TextTrack to look for to associate it with this menu.\n *\n * @type {string}\n * @private\n */\n\n\nDescriptionsButton.prototype.kind_ = 'descriptions';\n/**\n * The text that should display over the `DescriptionsButton`s controls. Added for localization.\n *\n * @type {string}\n * @private\n */\n\nDescriptionsButton.prototype.controlText_ = 'Descriptions';\nComponent.registerComponent('DescriptionsButton', DescriptionsButton);\n\n/**\n * The button component for toggling and selecting subtitles\n *\n * @extends TextTrackButton\n */\n\nvar SubtitlesButton =\n/*#__PURE__*/\nfunction (_TextTrackButton) {\n _inheritsLoose(SubtitlesButton, _TextTrackButton);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n *\n * @param {Component~ReadyCallback} [ready]\n * The function to call when this component is ready.\n */\n function SubtitlesButton(player, options, ready) {\n return _TextTrackButton.call(this, player, options, ready) || this;\n }\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n\n\n var _proto = SubtitlesButton.prototype;\n\n _proto.buildCSSClass = function buildCSSClass() {\n return \"vjs-subtitles-button \" + _TextTrackButton.prototype.buildCSSClass.call(this);\n };\n\n _proto.buildWrapperCSSClass = function buildWrapperCSSClass() {\n return \"vjs-subtitles-button \" + _TextTrackButton.prototype.buildWrapperCSSClass.call(this);\n };\n\n return SubtitlesButton;\n}(TextTrackButton);\n/**\n * `kind` of TextTrack to look for to associate it with this menu.\n *\n * @type {string}\n * @private\n */\n\n\nSubtitlesButton.prototype.kind_ = 'subtitles';\n/**\n * The text that should display over the `SubtitlesButton`s controls. Added for localization.\n *\n * @type {string}\n * @private\n */\n\nSubtitlesButton.prototype.controlText_ = 'Subtitles';\nComponent.registerComponent('SubtitlesButton', SubtitlesButton);\n\n/**\n * The menu item for caption track settings menu\n *\n * @extends TextTrackMenuItem\n */\n\nvar CaptionSettingsMenuItem =\n/*#__PURE__*/\nfunction (_TextTrackMenuItem) {\n _inheritsLoose(CaptionSettingsMenuItem, _TextTrackMenuItem);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function CaptionSettingsMenuItem(player, options) {\n var _this;\n\n options.track = {\n player: player,\n kind: options.kind,\n label: options.kind + ' settings',\n selectable: false,\n default: false,\n mode: 'disabled'\n }; // CaptionSettingsMenuItem has no concept of 'selected'\n\n options.selectable = false;\n options.name = 'CaptionSettingsMenuItem';\n _this = _TextTrackMenuItem.call(this, player, options) || this;\n\n _this.addClass('vjs-texttrack-settings');\n\n _this.controlText(', opens ' + options.kind + ' settings dialog');\n\n return _this;\n }\n /**\n * This gets called when an `CaptionSettingsMenuItem` is \"clicked\". See\n * {@link ClickableComponent} for more detailed information on what a click can be.\n *\n * @param {EventTarget~Event} [event]\n * The `keydown`, `tap`, or `click` event that caused this function to be\n * called.\n *\n * @listens tap\n * @listens click\n */\n\n\n var _proto = CaptionSettingsMenuItem.prototype;\n\n _proto.handleClick = function handleClick(event) {\n this.player().getChild('textTrackSettings').open();\n };\n\n return CaptionSettingsMenuItem;\n}(TextTrackMenuItem);\n\nComponent.registerComponent('CaptionSettingsMenuItem', CaptionSettingsMenuItem);\n\n/**\n * The button component for toggling and selecting captions\n *\n * @extends TextTrackButton\n */\n\nvar CaptionsButton =\n/*#__PURE__*/\nfunction (_TextTrackButton) {\n _inheritsLoose(CaptionsButton, _TextTrackButton);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n *\n * @param {Component~ReadyCallback} [ready]\n * The function to call when this component is ready.\n */\n function CaptionsButton(player, options, ready) {\n return _TextTrackButton.call(this, player, options, ready) || this;\n }\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n\n\n var _proto = CaptionsButton.prototype;\n\n _proto.buildCSSClass = function buildCSSClass() {\n return \"vjs-captions-button \" + _TextTrackButton.prototype.buildCSSClass.call(this);\n };\n\n _proto.buildWrapperCSSClass = function buildWrapperCSSClass() {\n return \"vjs-captions-button \" + _TextTrackButton.prototype.buildWrapperCSSClass.call(this);\n };\n /**\n * Create caption menu items\n *\n * @return {CaptionSettingsMenuItem[]}\n * The array of current menu items.\n */\n\n\n _proto.createItems = function createItems() {\n var items = [];\n\n if (!(this.player().tech_ && this.player().tech_.featuresNativeTextTracks) && this.player().getChild('textTrackSettings')) {\n items.push(new CaptionSettingsMenuItem(this.player_, {\n kind: this.kind_\n }));\n this.hideThreshold_ += 1;\n }\n\n return _TextTrackButton.prototype.createItems.call(this, items);\n };\n\n return CaptionsButton;\n}(TextTrackButton);\n/**\n * `kind` of TextTrack to look for to associate it with this menu.\n *\n * @type {string}\n * @private\n */\n\n\nCaptionsButton.prototype.kind_ = 'captions';\n/**\n * The text that should display over the `CaptionsButton`s controls. Added for localization.\n *\n * @type {string}\n * @private\n */\n\nCaptionsButton.prototype.controlText_ = 'Captions';\nComponent.registerComponent('CaptionsButton', CaptionsButton);\n\n/**\n * SubsCapsMenuItem has an [cc] icon to distinguish captions from subtitles\n * in the SubsCapsMenu.\n *\n * @extends TextTrackMenuItem\n */\n\nvar SubsCapsMenuItem =\n/*#__PURE__*/\nfunction (_TextTrackMenuItem) {\n _inheritsLoose(SubsCapsMenuItem, _TextTrackMenuItem);\n\n function SubsCapsMenuItem() {\n return _TextTrackMenuItem.apply(this, arguments) || this;\n }\n\n var _proto = SubsCapsMenuItem.prototype;\n\n _proto.createEl = function createEl(type, props, attrs) {\n var innerHTML = \"<span class=\\\"vjs-menu-item-text\\\">\" + this.localize(this.options_.label);\n\n if (this.options_.track.kind === 'captions') {\n innerHTML += \"\\n <span aria-hidden=\\\"true\\\" class=\\\"vjs-icon-placeholder\\\"></span>\\n <span class=\\\"vjs-control-text\\\"> \" + this.localize('Captions') + \"</span>\\n \";\n }\n\n innerHTML += '</span>';\n\n var el = _TextTrackMenuItem.prototype.createEl.call(this, type, assign({\n innerHTML: innerHTML\n }, props), attrs);\n\n return el;\n };\n\n return SubsCapsMenuItem;\n}(TextTrackMenuItem);\n\nComponent.registerComponent('SubsCapsMenuItem', SubsCapsMenuItem);\n\n/**\n * The button component for toggling and selecting captions and/or subtitles\n *\n * @extends TextTrackButton\n */\n\nvar SubsCapsButton =\n/*#__PURE__*/\nfunction (_TextTrackButton) {\n _inheritsLoose(SubsCapsButton, _TextTrackButton);\n\n function SubsCapsButton(player, options) {\n var _this;\n\n if (options === void 0) {\n options = {};\n }\n\n _this = _TextTrackButton.call(this, player, options) || this; // Although North America uses \"captions\" in most cases for\n // \"captions and subtitles\" other locales use \"subtitles\"\n\n _this.label_ = 'subtitles';\n\n if (['en', 'en-us', 'en-ca', 'fr-ca'].indexOf(_this.player_.language_) > -1) {\n _this.label_ = 'captions';\n }\n\n _this.menuButton_.controlText(toTitleCase(_this.label_));\n\n return _this;\n }\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n\n\n var _proto = SubsCapsButton.prototype;\n\n _proto.buildCSSClass = function buildCSSClass() {\n return \"vjs-subs-caps-button \" + _TextTrackButton.prototype.buildCSSClass.call(this);\n };\n\n _proto.buildWrapperCSSClass = function buildWrapperCSSClass() {\n return \"vjs-subs-caps-button \" + _TextTrackButton.prototype.buildWrapperCSSClass.call(this);\n };\n /**\n * Create caption/subtitles menu items\n *\n * @return {CaptionSettingsMenuItem[]}\n * The array of current menu items.\n */\n\n\n _proto.createItems = function createItems() {\n var items = [];\n\n if (!(this.player().tech_ && this.player().tech_.featuresNativeTextTracks) && this.player().getChild('textTrackSettings')) {\n items.push(new CaptionSettingsMenuItem(this.player_, {\n kind: this.label_\n }));\n this.hideThreshold_ += 1;\n }\n\n items = _TextTrackButton.prototype.createItems.call(this, items, SubsCapsMenuItem);\n return items;\n };\n\n return SubsCapsButton;\n}(TextTrackButton);\n/**\n * `kind`s of TextTrack to look for to associate it with this menu.\n *\n * @type {array}\n * @private\n */\n\n\nSubsCapsButton.prototype.kinds_ = ['captions', 'subtitles'];\n/**\n * The text that should display over the `SubsCapsButton`s controls.\n *\n *\n * @type {string}\n * @private\n */\n\nSubsCapsButton.prototype.controlText_ = 'Subtitles';\nComponent.registerComponent('SubsCapsButton', SubsCapsButton);\n\n/**\n * An {@link AudioTrack} {@link MenuItem}\n *\n * @extends MenuItem\n */\n\nvar AudioTrackMenuItem =\n/*#__PURE__*/\nfunction (_MenuItem) {\n _inheritsLoose(AudioTrackMenuItem, _MenuItem);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function AudioTrackMenuItem(player, options) {\n var _this;\n\n var track = options.track;\n var tracks = player.audioTracks(); // Modify options for parent MenuItem class's init.\n\n options.label = track.label || track.language || 'Unknown';\n options.selected = track.enabled;\n _this = _MenuItem.call(this, player, options) || this;\n _this.track = track;\n\n _this.addClass(\"vjs-\" + track.kind + \"-menu-item\");\n\n var changeHandler = function changeHandler() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this.handleTracksChange.apply(_assertThisInitialized(_assertThisInitialized(_this)), args);\n };\n\n tracks.addEventListener('change', changeHandler);\n\n _this.on('dispose', function () {\n tracks.removeEventListener('change', changeHandler);\n });\n\n return _this;\n }\n\n var _proto = AudioTrackMenuItem.prototype;\n\n _proto.createEl = function createEl(type, props, attrs) {\n var innerHTML = \"<span class=\\\"vjs-menu-item-text\\\">\" + this.localize(this.options_.label);\n\n if (this.options_.track.kind === 'main-desc') {\n innerHTML += \"\\n <span aria-hidden=\\\"true\\\" class=\\\"vjs-icon-placeholder\\\"></span>\\n <span class=\\\"vjs-control-text\\\"> \" + this.localize('Descriptions') + \"</span>\\n \";\n }\n\n innerHTML += '</span>';\n\n var el = _MenuItem.prototype.createEl.call(this, type, assign({\n innerHTML: innerHTML\n }, props), attrs);\n\n return el;\n };\n /**\n * This gets called when an `AudioTrackMenuItem is \"clicked\". See {@link ClickableComponent}\n * for more detailed information on what a click can be.\n *\n * @param {EventTarget~Event} [event]\n * The `keydown`, `tap`, or `click` event that caused this function to be\n * called.\n *\n * @listens tap\n * @listens click\n */\n\n\n _proto.handleClick = function handleClick(event) {\n var tracks = this.player_.audioTracks();\n\n _MenuItem.prototype.handleClick.call(this, event);\n\n for (var i = 0; i < tracks.length; i++) {\n var track = tracks[i];\n track.enabled = track === this.track;\n }\n };\n /**\n * Handle any {@link AudioTrack} change.\n *\n * @param {EventTarget~Event} [event]\n * The {@link AudioTrackList#change} event that caused this to run.\n *\n * @listens AudioTrackList#change\n */\n\n\n _proto.handleTracksChange = function handleTracksChange(event) {\n this.selected(this.track.enabled);\n };\n\n return AudioTrackMenuItem;\n}(MenuItem);\n\nComponent.registerComponent('AudioTrackMenuItem', AudioTrackMenuItem);\n\n/**\n * The base class for buttons that toggle specific {@link AudioTrack} types.\n *\n * @extends TrackButton\n */\n\nvar AudioTrackButton =\n/*#__PURE__*/\nfunction (_TrackButton) {\n _inheritsLoose(AudioTrackButton, _TrackButton);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options={}]\n * The key/value store of player options.\n */\n function AudioTrackButton(player, options) {\n if (options === void 0) {\n options = {};\n }\n\n options.tracks = player.audioTracks();\n return _TrackButton.call(this, player, options) || this;\n }\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n\n\n var _proto = AudioTrackButton.prototype;\n\n _proto.buildCSSClass = function buildCSSClass() {\n return \"vjs-audio-button \" + _TrackButton.prototype.buildCSSClass.call(this);\n };\n\n _proto.buildWrapperCSSClass = function buildWrapperCSSClass() {\n return \"vjs-audio-button \" + _TrackButton.prototype.buildWrapperCSSClass.call(this);\n };\n /**\n * Create a menu item for each audio track\n *\n * @param {AudioTrackMenuItem[]} [items=[]]\n * An array of existing menu items to use.\n *\n * @return {AudioTrackMenuItem[]}\n * An array of menu items\n */\n\n\n _proto.createItems = function createItems(items) {\n if (items === void 0) {\n items = [];\n }\n\n // if there's only one audio track, there no point in showing it\n this.hideThreshold_ = 1;\n var tracks = this.player_.audioTracks();\n\n for (var i = 0; i < tracks.length; i++) {\n var track = tracks[i];\n items.push(new AudioTrackMenuItem(this.player_, {\n track: track,\n // MenuItem is selectable\n selectable: true,\n // MenuItem is NOT multiSelectable (i.e. only one can be marked \"selected\" at a time)\n multiSelectable: false\n }));\n }\n\n return items;\n };\n\n return AudioTrackButton;\n}(TrackButton);\n/**\n * The text that should display over the `AudioTrackButton`s controls. Added for localization.\n *\n * @type {string}\n * @private\n */\n\n\nAudioTrackButton.prototype.controlText_ = 'Audio Track';\nComponent.registerComponent('AudioTrackButton', AudioTrackButton);\n\n/**\n * The specific menu item type for selecting a playback rate.\n *\n * @extends MenuItem\n */\n\nvar PlaybackRateMenuItem =\n/*#__PURE__*/\nfunction (_MenuItem) {\n _inheritsLoose(PlaybackRateMenuItem, _MenuItem);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function PlaybackRateMenuItem(player, options) {\n var _this;\n\n var label = options.rate;\n var rate = parseFloat(label, 10); // Modify options for parent MenuItem class's init.\n\n options.label = label;\n options.selected = rate === 1;\n options.selectable = true;\n options.multiSelectable = false;\n _this = _MenuItem.call(this, player, options) || this;\n _this.label = label;\n _this.rate = rate;\n\n _this.on(player, 'ratechange', _this.update);\n\n return _this;\n }\n /**\n * This gets called when an `PlaybackRateMenuItem` is \"clicked\". See\n * {@link ClickableComponent} for more detailed information on what a click can be.\n *\n * @param {EventTarget~Event} [event]\n * The `keydown`, `tap`, or `click` event that caused this function to be\n * called.\n *\n * @listens tap\n * @listens click\n */\n\n\n var _proto = PlaybackRateMenuItem.prototype;\n\n _proto.handleClick = function handleClick(event) {\n _MenuItem.prototype.handleClick.call(this);\n\n this.player().playbackRate(this.rate);\n };\n /**\n * Update the PlaybackRateMenuItem when the playbackrate changes.\n *\n * @param {EventTarget~Event} [event]\n * The `ratechange` event that caused this function to run.\n *\n * @listens Player#ratechange\n */\n\n\n _proto.update = function update(event) {\n this.selected(this.player().playbackRate() === this.rate);\n };\n\n return PlaybackRateMenuItem;\n}(MenuItem);\n/**\n * The text that should display over the `PlaybackRateMenuItem`s controls. Added for localization.\n *\n * @type {string}\n * @private\n */\n\n\nPlaybackRateMenuItem.prototype.contentElType = 'button';\nComponent.registerComponent('PlaybackRateMenuItem', PlaybackRateMenuItem);\n\n/**\n * The component for controlling the playback rate.\n *\n * @extends MenuButton\n */\n\nvar PlaybackRateMenuButton =\n/*#__PURE__*/\nfunction (_MenuButton) {\n _inheritsLoose(PlaybackRateMenuButton, _MenuButton);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function PlaybackRateMenuButton(player, options) {\n var _this;\n\n _this = _MenuButton.call(this, player, options) || this;\n\n _this.updateVisibility();\n\n _this.updateLabel();\n\n _this.on(player, 'loadstart', _this.updateVisibility);\n\n _this.on(player, 'ratechange', _this.updateLabel);\n\n return _this;\n }\n /**\n * Create the `Component`'s DOM element\n *\n * @return {Element}\n * The element that was created.\n */\n\n\n var _proto = PlaybackRateMenuButton.prototype;\n\n _proto.createEl = function createEl$$1() {\n var el = _MenuButton.prototype.createEl.call(this);\n\n this.labelEl_ = createEl('div', {\n className: 'vjs-playback-rate-value',\n innerHTML: '1x'\n });\n el.appendChild(this.labelEl_);\n return el;\n };\n\n _proto.dispose = function dispose() {\n this.labelEl_ = null;\n\n _MenuButton.prototype.dispose.call(this);\n };\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n\n\n _proto.buildCSSClass = function buildCSSClass() {\n return \"vjs-playback-rate \" + _MenuButton.prototype.buildCSSClass.call(this);\n };\n\n _proto.buildWrapperCSSClass = function buildWrapperCSSClass() {\n return \"vjs-playback-rate \" + _MenuButton.prototype.buildWrapperCSSClass.call(this);\n };\n /**\n * Create the playback rate menu\n *\n * @return {Menu}\n * Menu object populated with {@link PlaybackRateMenuItem}s\n */\n\n\n _proto.createMenu = function createMenu() {\n var menu = new Menu(this.player());\n var rates = this.playbackRates();\n\n if (rates) {\n for (var i = rates.length - 1; i >= 0; i--) {\n menu.addChild(new PlaybackRateMenuItem(this.player(), {\n rate: rates[i] + 'x'\n }));\n }\n }\n\n return menu;\n };\n /**\n * Updates ARIA accessibility attributes\n */\n\n\n _proto.updateARIAAttributes = function updateARIAAttributes() {\n // Current playback rate\n this.el().setAttribute('aria-valuenow', this.player().playbackRate());\n };\n /**\n * This gets called when an `PlaybackRateMenuButton` is \"clicked\". See\n * {@link ClickableComponent} for more detailed information on what a click can be.\n *\n * @param {EventTarget~Event} [event]\n * The `keydown`, `tap`, or `click` event that caused this function to be\n * called.\n *\n * @listens tap\n * @listens click\n */\n\n\n _proto.handleClick = function handleClick(event) {\n // select next rate option\n var currentRate = this.player().playbackRate();\n var rates = this.playbackRates(); // this will select first one if the last one currently selected\n\n var newRate = rates[0];\n\n for (var i = 0; i < rates.length; i++) {\n if (rates[i] > currentRate) {\n newRate = rates[i];\n break;\n }\n }\n\n this.player().playbackRate(newRate);\n };\n /**\n * Get possible playback rates\n *\n * @return {Array}\n * All possible playback rates\n */\n\n\n _proto.playbackRates = function playbackRates() {\n return this.options_.playbackRates || this.options_.playerOptions && this.options_.playerOptions.playbackRates;\n };\n /**\n * Get whether playback rates is supported by the tech\n * and an array of playback rates exists\n *\n * @return {boolean}\n * Whether changing playback rate is supported\n */\n\n\n _proto.playbackRateSupported = function playbackRateSupported() {\n return this.player().tech_ && this.player().tech_.featuresPlaybackRate && this.playbackRates() && this.playbackRates().length > 0;\n };\n /**\n * Hide playback rate controls when they're no playback rate options to select\n *\n * @param {EventTarget~Event} [event]\n * The event that caused this function to run.\n *\n * @listens Player#loadstart\n */\n\n\n _proto.updateVisibility = function updateVisibility(event) {\n if (this.playbackRateSupported()) {\n this.removeClass('vjs-hidden');\n } else {\n this.addClass('vjs-hidden');\n }\n };\n /**\n * Update button label when rate changed\n *\n * @param {EventTarget~Event} [event]\n * The event that caused this function to run.\n *\n * @listens Player#ratechange\n */\n\n\n _proto.updateLabel = function updateLabel(event) {\n if (this.playbackRateSupported()) {\n this.labelEl_.innerHTML = this.player().playbackRate() + 'x';\n }\n };\n\n return PlaybackRateMenuButton;\n}(MenuButton);\n/**\n * The text that should display over the `FullscreenToggle`s controls. Added for localization.\n *\n * @type {string}\n * @private\n */\n\n\nPlaybackRateMenuButton.prototype.controlText_ = 'Playback Rate';\nComponent.registerComponent('PlaybackRateMenuButton', PlaybackRateMenuButton);\n\n/**\n * Just an empty spacer element that can be used as an append point for plugins, etc.\n * Also can be used to create space between elements when necessary.\n *\n * @extends Component\n */\n\nvar Spacer =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(Spacer, _Component);\n\n function Spacer() {\n return _Component.apply(this, arguments) || this;\n }\n\n var _proto = Spacer.prototype;\n\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n _proto.buildCSSClass = function buildCSSClass() {\n return \"vjs-spacer \" + _Component.prototype.buildCSSClass.call(this);\n };\n /**\n * Create the `Component`'s DOM element\n *\n * @return {Element}\n * The element that was created.\n */\n\n\n _proto.createEl = function createEl() {\n return _Component.prototype.createEl.call(this, 'div', {\n className: this.buildCSSClass()\n });\n };\n\n return Spacer;\n}(Component);\n\nComponent.registerComponent('Spacer', Spacer);\n\n/**\n * Spacer specifically meant to be used as an insertion point for new plugins, etc.\n *\n * @extends Spacer\n */\n\nvar CustomControlSpacer =\n/*#__PURE__*/\nfunction (_Spacer) {\n _inheritsLoose(CustomControlSpacer, _Spacer);\n\n function CustomControlSpacer() {\n return _Spacer.apply(this, arguments) || this;\n }\n\n var _proto = CustomControlSpacer.prototype;\n\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n */\n _proto.buildCSSClass = function buildCSSClass() {\n return \"vjs-custom-control-spacer \" + _Spacer.prototype.buildCSSClass.call(this);\n };\n /**\n * Create the `Component`'s DOM element\n *\n * @return {Element}\n * The element that was created.\n */\n\n\n _proto.createEl = function createEl() {\n var el = _Spacer.prototype.createEl.call(this, {\n className: this.buildCSSClass()\n }); // No-flex/table-cell mode requires there be some content\n // in the cell to fill the remaining space of the table.\n\n\n el.innerHTML = \"\\xA0\";\n return el;\n };\n\n return CustomControlSpacer;\n}(Spacer);\n\nComponent.registerComponent('CustomControlSpacer', CustomControlSpacer);\n\n/**\n * Container of main controls.\n *\n * @extends Component\n */\n\nvar ControlBar =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(ControlBar, _Component);\n\n function ControlBar() {\n return _Component.apply(this, arguments) || this;\n }\n\n var _proto = ControlBar.prototype;\n\n /**\n * Create the `Component`'s DOM element\n *\n * @return {Element}\n * The element that was created.\n */\n _proto.createEl = function createEl() {\n return _Component.prototype.createEl.call(this, 'div', {\n className: 'vjs-control-bar',\n dir: 'ltr'\n });\n };\n\n return ControlBar;\n}(Component);\n/**\n * Default options for `ControlBar`\n *\n * @type {Object}\n * @private\n */\n\n\nControlBar.prototype.options_ = {\n children: ['playToggle', 'volumePanel', 'currentTimeDisplay', 'timeDivider', 'durationDisplay', 'progressControl', 'liveDisplay', 'seekToLive', 'remainingTimeDisplay', 'customControlSpacer', 'playbackRateMenuButton', 'chaptersButton', 'descriptionsButton', 'subsCapsButton', 'audioTrackButton', 'fullscreenToggle']\n};\nComponent.registerComponent('ControlBar', ControlBar);\n\n/**\n * A display that indicates an error has occurred. This means that the video\n * is unplayable.\n *\n * @extends ModalDialog\n */\n\nvar ErrorDisplay =\n/*#__PURE__*/\nfunction (_ModalDialog) {\n _inheritsLoose(ErrorDisplay, _ModalDialog);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function ErrorDisplay(player, options) {\n var _this;\n\n _this = _ModalDialog.call(this, player, options) || this;\n\n _this.on(player, 'error', _this.open);\n\n return _this;\n }\n /**\n * Builds the default DOM `className`.\n *\n * @return {string}\n * The DOM `className` for this object.\n *\n * @deprecated Since version 5.\n */\n\n\n var _proto = ErrorDisplay.prototype;\n\n _proto.buildCSSClass = function buildCSSClass() {\n return \"vjs-error-display \" + _ModalDialog.prototype.buildCSSClass.call(this);\n };\n /**\n * Gets the localized error message based on the `Player`s error.\n *\n * @return {string}\n * The `Player`s error message localized or an empty string.\n */\n\n\n _proto.content = function content() {\n var error = this.player().error();\n return error ? this.localize(error.message) : '';\n };\n\n return ErrorDisplay;\n}(ModalDialog);\n/**\n * The default options for an `ErrorDisplay`.\n *\n * @private\n */\n\n\nErrorDisplay.prototype.options_ = mergeOptions(ModalDialog.prototype.options_, {\n pauseOnOpen: false,\n fillAlways: true,\n temporary: false,\n uncloseable: true\n});\nComponent.registerComponent('ErrorDisplay', ErrorDisplay);\n\nvar LOCAL_STORAGE_KEY = 'vjs-text-track-settings';\nvar COLOR_BLACK = ['#000', 'Black'];\nvar COLOR_BLUE = ['#00F', 'Blue'];\nvar COLOR_CYAN = ['#0FF', 'Cyan'];\nvar COLOR_GREEN = ['#0F0', 'Green'];\nvar COLOR_MAGENTA = ['#F0F', 'Magenta'];\nvar COLOR_RED = ['#F00', 'Red'];\nvar COLOR_WHITE = ['#FFF', 'White'];\nvar COLOR_YELLOW = ['#FF0', 'Yellow'];\nvar OPACITY_OPAQUE = ['1', 'Opaque'];\nvar OPACITY_SEMI = ['0.5', 'Semi-Transparent'];\nvar OPACITY_TRANS = ['0', 'Transparent']; // Configuration for the various <select> elements in the DOM of this component.\n//\n// Possible keys include:\n//\n// `default`:\n// The default option index. Only needs to be provided if not zero.\n// `parser`:\n// A function which is used to parse the value from the selected option in\n// a customized way.\n// `selector`:\n// The selector used to find the associated <select> element.\n\nvar selectConfigs = {\n backgroundColor: {\n selector: '.vjs-bg-color > select',\n id: 'captions-background-color-%s',\n label: 'Color',\n options: [COLOR_BLACK, COLOR_WHITE, COLOR_RED, COLOR_GREEN, COLOR_BLUE, COLOR_YELLOW, COLOR_MAGENTA, COLOR_CYAN]\n },\n backgroundOpacity: {\n selector: '.vjs-bg-opacity > select',\n id: 'captions-background-opacity-%s',\n label: 'Transparency',\n options: [OPACITY_OPAQUE, OPACITY_SEMI, OPACITY_TRANS]\n },\n color: {\n selector: '.vjs-fg-color > select',\n id: 'captions-foreground-color-%s',\n label: 'Color',\n options: [COLOR_WHITE, COLOR_BLACK, COLOR_RED, COLOR_GREEN, COLOR_BLUE, COLOR_YELLOW, COLOR_MAGENTA, COLOR_CYAN]\n },\n edgeStyle: {\n selector: '.vjs-edge-style > select',\n id: '%s',\n label: 'Text Edge Style',\n options: [['none', 'None'], ['raised', 'Raised'], ['depressed', 'Depressed'], ['uniform', 'Uniform'], ['dropshadow', 'Dropshadow']]\n },\n fontFamily: {\n selector: '.vjs-font-family > select',\n id: 'captions-font-family-%s',\n label: 'Font Family',\n options: [['proportionalSansSerif', 'Proportional Sans-Serif'], ['monospaceSansSerif', 'Monospace Sans-Serif'], ['proportionalSerif', 'Proportional Serif'], ['monospaceSerif', 'Monospace Serif'], ['casual', 'Casual'], ['script', 'Script'], ['small-caps', 'Small Caps']]\n },\n fontPercent: {\n selector: '.vjs-font-percent > select',\n id: 'captions-font-size-%s',\n label: 'Font Size',\n options: [['0.50', '50%'], ['0.75', '75%'], ['1.00', '100%'], ['1.25', '125%'], ['1.50', '150%'], ['1.75', '175%'], ['2.00', '200%'], ['3.00', '300%'], ['4.00', '400%']],\n default: 2,\n parser: function parser(v) {\n return v === '1.00' ? null : Number(v);\n }\n },\n textOpacity: {\n selector: '.vjs-text-opacity > select',\n id: 'captions-foreground-opacity-%s',\n label: 'Transparency',\n options: [OPACITY_OPAQUE, OPACITY_SEMI]\n },\n // Options for this object are defined below.\n windowColor: {\n selector: '.vjs-window-color > select',\n id: 'captions-window-color-%s',\n label: 'Color'\n },\n // Options for this object are defined below.\n windowOpacity: {\n selector: '.vjs-window-opacity > select',\n id: 'captions-window-opacity-%s',\n label: 'Transparency',\n options: [OPACITY_TRANS, OPACITY_SEMI, OPACITY_OPAQUE]\n }\n};\nselectConfigs.windowColor.options = selectConfigs.backgroundColor.options;\n/**\n * Get the actual value of an option.\n *\n * @param {string} value\n * The value to get\n *\n * @param {Function} [parser]\n * Optional function to adjust the value.\n *\n * @return {Mixed}\n * - Will be `undefined` if no value exists\n * - Will be `undefined` if the given value is \"none\".\n * - Will be the actual value otherwise.\n *\n * @private\n */\n\nfunction parseOptionValue(value, parser) {\n if (parser) {\n value = parser(value);\n }\n\n if (value && value !== 'none') {\n return value;\n }\n}\n/**\n * Gets the value of the selected <option> element within a <select> element.\n *\n * @param {Element} el\n * the element to look in\n *\n * @param {Function} [parser]\n * Optional function to adjust the value.\n *\n * @return {Mixed}\n * - Will be `undefined` if no value exists\n * - Will be `undefined` if the given value is \"none\".\n * - Will be the actual value otherwise.\n *\n * @private\n */\n\n\nfunction getSelectedOptionValue(el, parser) {\n var value = el.options[el.options.selectedIndex].value;\n return parseOptionValue(value, parser);\n}\n/**\n * Sets the selected <option> element within a <select> element based on a\n * given value.\n *\n * @param {Element} el\n * The element to look in.\n *\n * @param {string} value\n * the property to look on.\n *\n * @param {Function} [parser]\n * Optional function to adjust the value before comparing.\n *\n * @private\n */\n\n\nfunction setSelectedOption(el, value, parser) {\n if (!value) {\n return;\n }\n\n for (var i = 0; i < el.options.length; i++) {\n if (parseOptionValue(el.options[i].value, parser) === value) {\n el.selectedIndex = i;\n break;\n }\n }\n}\n/**\n * Manipulate Text Tracks settings.\n *\n * @extends ModalDialog\n */\n\n\nvar TextTrackSettings =\n/*#__PURE__*/\nfunction (_ModalDialog) {\n _inheritsLoose(TextTrackSettings, _ModalDialog);\n\n /**\n * Creates an instance of this class.\n *\n * @param {Player} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n */\n function TextTrackSettings(player, options) {\n var _this;\n\n options.temporary = false;\n _this = _ModalDialog.call(this, player, options) || this;\n _this.updateDisplay = bind(_assertThisInitialized(_assertThisInitialized(_this)), _this.updateDisplay); // fill the modal and pretend we have opened it\n\n _this.fill();\n\n _this.hasBeenOpened_ = _this.hasBeenFilled_ = true;\n _this.endDialog = createEl('p', {\n className: 'vjs-control-text',\n textContent: _this.localize('End of dialog window.')\n });\n\n _this.el().appendChild(_this.endDialog);\n\n _this.setDefaults(); // Grab `persistTextTrackSettings` from the player options if not passed in child options\n\n\n if (options.persistTextTrackSettings === undefined) {\n _this.options_.persistTextTrackSettings = _this.options_.playerOptions.persistTextTrackSettings;\n }\n\n _this.on(_this.$('.vjs-done-button'), 'click', function () {\n _this.saveSettings();\n\n _this.close();\n });\n\n _this.on(_this.$('.vjs-default-button'), 'click', function () {\n _this.setDefaults();\n\n _this.updateDisplay();\n });\n\n each(selectConfigs, function (config) {\n _this.on(_this.$(config.selector), 'change', _this.updateDisplay);\n });\n\n if (_this.options_.persistTextTrackSettings) {\n _this.restoreSettings();\n }\n\n return _this;\n }\n\n var _proto = TextTrackSettings.prototype;\n\n _proto.dispose = function dispose() {\n this.endDialog = null;\n\n _ModalDialog.prototype.dispose.call(this);\n };\n /**\n * Create a <select> element with configured options.\n *\n * @param {string} key\n * Configuration key to use during creation.\n *\n * @return {string}\n * An HTML string.\n *\n * @private\n */\n\n\n _proto.createElSelect_ = function createElSelect_(key, legendId, type) {\n var _this2 = this;\n\n if (legendId === void 0) {\n legendId = '';\n }\n\n if (type === void 0) {\n type = 'label';\n }\n\n var config = selectConfigs[key];\n var id = config.id.replace('%s', this.id_);\n var selectLabelledbyIds = [legendId, id].join(' ').trim();\n return [\"<\" + type + \" id=\\\"\" + id + \"\\\" class=\\\"\" + (type === 'label' ? 'vjs-label' : '') + \"\\\">\", this.localize(config.label), \"</\" + type + \">\", \"<select aria-labelledby=\\\"\" + selectLabelledbyIds + \"\\\">\"].concat(config.options.map(function (o) {\n var optionId = id + '-' + o[1].replace(/\\W+/g, '');\n return [\"<option id=\\\"\" + optionId + \"\\\" value=\\\"\" + o[0] + \"\\\" \", \"aria-labelledby=\\\"\" + selectLabelledbyIds + \" \" + optionId + \"\\\">\", _this2.localize(o[1]), '</option>'].join('');\n })).concat('</select>').join('');\n };\n /**\n * Create foreground color element for the component\n *\n * @return {string}\n * An HTML string.\n *\n * @private\n */\n\n\n _proto.createElFgColor_ = function createElFgColor_() {\n var legendId = \"captions-text-legend-\" + this.id_;\n return ['<fieldset class=\"vjs-fg-color vjs-track-setting\">', \"<legend id=\\\"\" + legendId + \"\\\">\", this.localize('Text'), '</legend>', this.createElSelect_('color', legendId), '<span class=\"vjs-text-opacity vjs-opacity\">', this.createElSelect_('textOpacity', legendId), '</span>', '</fieldset>'].join('');\n };\n /**\n * Create background color element for the component\n *\n * @return {string}\n * An HTML string.\n *\n * @private\n */\n\n\n _proto.createElBgColor_ = function createElBgColor_() {\n var legendId = \"captions-background-\" + this.id_;\n return ['<fieldset class=\"vjs-bg-color vjs-track-setting\">', \"<legend id=\\\"\" + legendId + \"\\\">\", this.localize('Background'), '</legend>', this.createElSelect_('backgroundColor', legendId), '<span class=\"vjs-bg-opacity vjs-opacity\">', this.createElSelect_('backgroundOpacity', legendId), '</span>', '</fieldset>'].join('');\n };\n /**\n * Create window color element for the component\n *\n * @return {string}\n * An HTML string.\n *\n * @private\n */\n\n\n _proto.createElWinColor_ = function createElWinColor_() {\n var legendId = \"captions-window-\" + this.id_;\n return ['<fieldset class=\"vjs-window-color vjs-track-setting\">', \"<legend id=\\\"\" + legendId + \"\\\">\", this.localize('Window'), '</legend>', this.createElSelect_('windowColor', legendId), '<span class=\"vjs-window-opacity vjs-opacity\">', this.createElSelect_('windowOpacity', legendId), '</span>', '</fieldset>'].join('');\n };\n /**\n * Create color elements for the component\n *\n * @return {Element}\n * The element that was created\n *\n * @private\n */\n\n\n _proto.createElColors_ = function createElColors_() {\n return createEl('div', {\n className: 'vjs-track-settings-colors',\n innerHTML: [this.createElFgColor_(), this.createElBgColor_(), this.createElWinColor_()].join('')\n });\n };\n /**\n * Create font elements for the component\n *\n * @return {Element}\n * The element that was created.\n *\n * @private\n */\n\n\n _proto.createElFont_ = function createElFont_() {\n return createEl('div', {\n className: 'vjs-track-settings-font',\n innerHTML: ['<fieldset class=\"vjs-font-percent vjs-track-setting\">', this.createElSelect_('fontPercent', '', 'legend'), '</fieldset>', '<fieldset class=\"vjs-edge-style vjs-track-setting\">', this.createElSelect_('edgeStyle', '', 'legend'), '</fieldset>', '<fieldset class=\"vjs-font-family vjs-track-setting\">', this.createElSelect_('fontFamily', '', 'legend'), '</fieldset>'].join('')\n });\n };\n /**\n * Create controls for the component\n *\n * @return {Element}\n * The element that was created.\n *\n * @private\n */\n\n\n _proto.createElControls_ = function createElControls_() {\n var defaultsDescription = this.localize('restore all settings to the default values');\n return createEl('div', {\n className: 'vjs-track-settings-controls',\n innerHTML: [\"<button type=\\\"button\\\" class=\\\"vjs-default-button\\\" title=\\\"\" + defaultsDescription + \"\\\">\", this.localize('Reset'), \"<span class=\\\"vjs-control-text\\\"> \" + defaultsDescription + \"</span>\", '</button>', \"<button type=\\\"button\\\" class=\\\"vjs-done-button\\\">\" + this.localize('Done') + \"</button>\"].join('')\n });\n };\n\n _proto.content = function content() {\n return [this.createElColors_(), this.createElFont_(), this.createElControls_()];\n };\n\n _proto.label = function label() {\n return this.localize('Caption Settings Dialog');\n };\n\n _proto.description = function description() {\n return this.localize('Beginning of dialog window. Escape will cancel and close the window.');\n };\n\n _proto.buildCSSClass = function buildCSSClass() {\n return _ModalDialog.prototype.buildCSSClass.call(this) + ' vjs-text-track-settings';\n };\n /**\n * Gets an object of text track settings (or null).\n *\n * @return {Object}\n * An object with config values parsed from the DOM or localStorage.\n */\n\n\n _proto.getValues = function getValues() {\n var _this3 = this;\n\n return reduce(selectConfigs, function (accum, config, key) {\n var value = getSelectedOptionValue(_this3.$(config.selector), config.parser);\n\n if (value !== undefined) {\n accum[key] = value;\n }\n\n return accum;\n }, {});\n };\n /**\n * Sets text track settings from an object of values.\n *\n * @param {Object} values\n * An object with config values parsed from the DOM or localStorage.\n */\n\n\n _proto.setValues = function setValues(values) {\n var _this4 = this;\n\n each(selectConfigs, function (config, key) {\n setSelectedOption(_this4.$(config.selector), values[key], config.parser);\n });\n };\n /**\n * Sets all `<select>` elements to their default values.\n */\n\n\n _proto.setDefaults = function setDefaults() {\n var _this5 = this;\n\n each(selectConfigs, function (config) {\n var index = config.hasOwnProperty('default') ? config.default : 0;\n _this5.$(config.selector).selectedIndex = index;\n });\n };\n /**\n * Restore texttrack settings from localStorage\n */\n\n\n _proto.restoreSettings = function restoreSettings() {\n var values;\n\n try {\n values = JSON.parse(window$1.localStorage.getItem(LOCAL_STORAGE_KEY));\n } catch (err) {\n log.warn(err);\n }\n\n if (values) {\n this.setValues(values);\n }\n };\n /**\n * Save text track settings to localStorage\n */\n\n\n _proto.saveSettings = function saveSettings() {\n if (!this.options_.persistTextTrackSettings) {\n return;\n }\n\n var values = this.getValues();\n\n try {\n if (Object.keys(values).length) {\n window$1.localStorage.setItem(LOCAL_STORAGE_KEY, JSON.stringify(values));\n } else {\n window$1.localStorage.removeItem(LOCAL_STORAGE_KEY);\n }\n } catch (err) {\n log.warn(err);\n }\n };\n /**\n * Update display of text track settings\n */\n\n\n _proto.updateDisplay = function updateDisplay() {\n var ttDisplay = this.player_.getChild('textTrackDisplay');\n\n if (ttDisplay) {\n ttDisplay.updateDisplay();\n }\n };\n /**\n * conditionally blur the element and refocus the captions button\n *\n * @private\n */\n\n\n _proto.conditionalBlur_ = function conditionalBlur_() {\n this.previouslyActiveEl_ = null;\n this.off(document, 'keydown', this.handleKeyDown);\n var cb = this.player_.controlBar;\n var subsCapsBtn = cb && cb.subsCapsButton;\n var ccBtn = cb && cb.captionsButton;\n\n if (subsCapsBtn) {\n subsCapsBtn.focus();\n } else if (ccBtn) {\n ccBtn.focus();\n }\n };\n\n return TextTrackSettings;\n}(ModalDialog);\n\nComponent.registerComponent('TextTrackSettings', TextTrackSettings);\n\n/**\n * A Resize Manager. It is in charge of triggering `playerresize` on the player in the right conditions.\n *\n * It'll either create an iframe and use a debounced resize handler on it or use the new {@link https://wicg.github.io/ResizeObserver/|ResizeObserver}.\n *\n * If the ResizeObserver is available natively, it will be used. A polyfill can be passed in as an option.\n * If a `playerresize` event is not needed, the ResizeManager component can be removed from the player, see the example below.\n * @example <caption>How to disable the resize manager</caption>\n * const player = videojs('#vid', {\n * resizeManager: false\n * });\n *\n * @see {@link https://wicg.github.io/ResizeObserver/|ResizeObserver specification}\n *\n * @extends Component\n */\n\nvar ResizeManager =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(ResizeManager, _Component);\n\n /**\n * Create the ResizeManager.\n *\n * @param {Object} player\n * The `Player` that this class should be attached to.\n *\n * @param {Object} [options]\n * The key/value store of ResizeManager options.\n *\n * @param {Object} [options.ResizeObserver]\n * A polyfill for ResizeObserver can be passed in here.\n * If this is set to null it will ignore the native ResizeObserver and fall back to the iframe fallback.\n */\n function ResizeManager(player, options) {\n var _this;\n\n var RESIZE_OBSERVER_AVAILABLE = options.ResizeObserver || window$1.ResizeObserver; // if `null` was passed, we want to disable the ResizeObserver\n\n if (options.ResizeObserver === null) {\n RESIZE_OBSERVER_AVAILABLE = false;\n } // Only create an element when ResizeObserver isn't available\n\n\n var options_ = mergeOptions({\n createEl: !RESIZE_OBSERVER_AVAILABLE,\n reportTouchActivity: false\n }, options);\n _this = _Component.call(this, player, options_) || this;\n _this.ResizeObserver = options.ResizeObserver || window$1.ResizeObserver;\n _this.loadListener_ = null;\n _this.resizeObserver_ = null;\n _this.debouncedHandler_ = debounce(function () {\n _this.resizeHandler();\n }, 100, false, _assertThisInitialized(_assertThisInitialized(_this)));\n\n if (RESIZE_OBSERVER_AVAILABLE) {\n _this.resizeObserver_ = new _this.ResizeObserver(_this.debouncedHandler_);\n\n _this.resizeObserver_.observe(player.el());\n } else {\n _this.loadListener_ = function () {\n if (!_this.el_ || !_this.el_.contentWindow) {\n return;\n }\n\n on(_this.el_.contentWindow, 'resize', _this.debouncedHandler_);\n };\n\n _this.one('load', _this.loadListener_);\n }\n\n return _this;\n }\n\n var _proto = ResizeManager.prototype;\n\n _proto.createEl = function createEl() {\n return _Component.prototype.createEl.call(this, 'iframe', {\n className: 'vjs-resize-manager'\n });\n };\n /**\n * Called when a resize is triggered on the iframe or a resize is observed via the ResizeObserver\n *\n * @fires Player#playerresize\n */\n\n\n _proto.resizeHandler = function resizeHandler() {\n /**\n * Called when the player size has changed\n *\n * @event Player#playerresize\n * @type {EventTarget~Event}\n */\n // make sure player is still around to trigger\n // prevents this from causing an error after dispose\n if (!this.player_ || !this.player_.trigger) {\n return;\n }\n\n this.player_.trigger('playerresize');\n };\n\n _proto.dispose = function dispose() {\n if (this.debouncedHandler_) {\n this.debouncedHandler_.cancel();\n }\n\n if (this.resizeObserver_) {\n if (this.player_.el()) {\n this.resizeObserver_.unobserve(this.player_.el());\n }\n\n this.resizeObserver_.disconnect();\n }\n\n if (this.el_ && this.el_.contentWindow) {\n off(this.el_.contentWindow, 'resize', this.debouncedHandler_);\n }\n\n if (this.loadListener_) {\n this.off('load', this.loadListener_);\n }\n\n this.ResizeObserver = null;\n this.resizeObserver = null;\n this.debouncedHandler_ = null;\n this.loadListener_ = null;\n };\n\n return ResizeManager;\n}(Component);\n\nComponent.registerComponent('ResizeManager', ResizeManager);\n\n/* track when we are at the live edge, and other helpers for live playback */\n\nvar LiveTracker =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(LiveTracker, _Component);\n\n function LiveTracker(player, options) {\n var _this;\n\n // LiveTracker does not need an element\n var options_ = mergeOptions({\n createEl: false\n }, options);\n _this = _Component.call(this, player, options_) || this;\n\n _this.reset_();\n\n _this.on(_this.player_, 'durationchange', _this.handleDurationchange);\n\n return _this;\n }\n\n var _proto = LiveTracker.prototype;\n\n _proto.isBehind_ = function isBehind_() {\n // don't report that we are behind until a timeupdate has been seen\n if (!this.timeupdateSeen_) {\n return false;\n }\n\n var liveCurrentTime = this.liveCurrentTime();\n var currentTime = this.player_.currentTime();\n var seekableIncrement = this.seekableIncrement_; // the live edge window is the amount of seconds away from live\n // that a player can be, but still be considered live.\n // we add 0.07 because the live tracking happens every 30ms\n // and we want some wiggle room for short segment live playback\n\n var liveEdgeWindow = seekableIncrement * 2 + 0.07; // on Android liveCurrentTime can bee Infinity, because seekableEnd\n // can be Infinity, so we handle that case.\n\n return liveCurrentTime !== Infinity && liveCurrentTime - liveEdgeWindow >= currentTime;\n }; // all the functionality for tracking when seek end changes\n // and for tracking how far past seek end we should be\n\n\n _proto.trackLive_ = function trackLive_() {\n this.pastSeekEnd_ = this.pastSeekEnd_;\n var seekable = this.player_.seekable(); // skip undefined seekable\n\n if (!seekable || !seekable.length) {\n return;\n }\n\n var newSeekEnd = this.seekableEnd(); // we can only tell if we are behind live, when seekable changes\n // once we detect that seekable has changed we check the new seek\n // end against current time, with a fudge value of half a second.\n\n if (newSeekEnd !== this.lastSeekEnd_) {\n if (this.lastSeekEnd_) {\n this.seekableIncrement_ = Math.abs(newSeekEnd - this.lastSeekEnd_);\n }\n\n this.pastSeekEnd_ = 0;\n this.lastSeekEnd_ = newSeekEnd;\n this.trigger('seekableendchange');\n }\n\n this.pastSeekEnd_ = this.pastSeekEnd() + 0.03;\n\n if (this.isBehind_() !== this.behindLiveEdge()) {\n this.behindLiveEdge_ = this.isBehind_();\n this.trigger('liveedgechange');\n }\n };\n /**\n * handle a durationchange event on the player\n * and start/stop tracking accordingly.\n */\n\n\n _proto.handleDurationchange = function handleDurationchange() {\n if (this.player_.duration() === Infinity) {\n this.startTracking();\n } else {\n this.stopTracking();\n }\n };\n /**\n * start tracking live playback\n */\n\n\n _proto.startTracking = function startTracking() {\n var _this2 = this;\n\n if (this.isTracking()) {\n return;\n }\n\n this.trackingInterval_ = this.setInterval(this.trackLive_, 30);\n this.trackLive_();\n this.on(this.player_, 'play', this.trackLive_);\n this.on(this.player_, 'pause', this.trackLive_);\n this.one(this.player_, 'play', this.handlePlay); // this is to prevent showing that we are not live\n // before a video starts to play\n\n if (!this.timeupdateSeen_) {\n this.handleTimeupdate = function () {\n _this2.timeupdateSeen_ = true;\n _this2.handleTimeupdate = null;\n };\n\n this.one(this.player_, 'timeupdate', this.handleTimeupdate);\n }\n };\n\n _proto.handlePlay = function handlePlay() {\n this.one(this.player_, 'timeupdate', this.seekToLiveEdge);\n };\n /**\n * Stop tracking, and set all internal variables to\n * their initial value.\n */\n\n\n _proto.reset_ = function reset_() {\n this.pastSeekEnd_ = 0;\n this.lastSeekEnd_ = null;\n this.behindLiveEdge_ = null;\n this.timeupdateSeen_ = false;\n this.clearInterval(this.trackingInterval_);\n this.trackingInterval_ = null;\n this.seekableIncrement_ = 12;\n this.off(this.player_, 'play', this.trackLive_);\n this.off(this.player_, 'pause', this.trackLive_);\n this.off(this.player_, 'play', this.handlePlay);\n this.off(this.player_, 'timeupdate', this.seekToLiveEdge);\n\n if (this.handleTimeupdate) {\n this.off(this.player_, 'timeupdate', this.handleTimeupdate);\n this.handleTimeupdate = null;\n }\n };\n /**\n * stop tracking live playback\n */\n\n\n _proto.stopTracking = function stopTracking() {\n if (!this.isTracking()) {\n return;\n }\n\n this.reset_();\n };\n /**\n * A helper to get the player seekable end\n * so that we don't have to null check everywhere\n */\n\n\n _proto.seekableEnd = function seekableEnd() {\n var seekable = this.player_.seekable();\n var seekableEnds = [];\n var i = seekable ? seekable.length : 0;\n\n while (i--) {\n seekableEnds.push(seekable.end(i));\n } // grab the furthest seekable end after sorting, or if there are none\n // default to Infinity\n\n\n return seekableEnds.length ? seekableEnds.sort()[seekableEnds.length - 1] : Infinity;\n };\n /**\n * A helper to get the player seekable start\n * so that we don't have to null check everywhere\n */\n\n\n _proto.seekableStart = function seekableStart() {\n var seekable = this.player_.seekable();\n var seekableStarts = [];\n var i = seekable ? seekable.length : 0;\n\n while (i--) {\n seekableStarts.push(seekable.start(i));\n } // grab the first seekable start after sorting, or if there are none\n // default to 0\n\n\n return seekableStarts.length ? seekableStarts.sort()[0] : 0;\n };\n /**\n * Get the live time window\n */\n\n\n _proto.liveWindow = function liveWindow() {\n var liveCurrentTime = this.liveCurrentTime();\n\n if (liveCurrentTime === Infinity) {\n return Infinity;\n }\n\n return liveCurrentTime - this.seekableStart();\n };\n /**\n * Determines if the player is live, only checks if this component\n * is tracking live playback or not\n */\n\n\n _proto.isLive = function isLive() {\n return this.isTracking();\n };\n /**\n * Determines if currentTime is at the live edge and won't fall behind\n * on each seekableendchange\n */\n\n\n _proto.atLiveEdge = function atLiveEdge() {\n return !this.behindLiveEdge();\n };\n /**\n * get what we expect the live current time to be\n */\n\n\n _proto.liveCurrentTime = function liveCurrentTime() {\n return this.pastSeekEnd() + this.seekableEnd();\n };\n /**\n * Returns how far past seek end we expect current time to be\n */\n\n\n _proto.pastSeekEnd = function pastSeekEnd() {\n return this.pastSeekEnd_;\n };\n /**\n * If we are currently behind the live edge, aka currentTime will be\n * behind on a seekableendchange\n */\n\n\n _proto.behindLiveEdge = function behindLiveEdge() {\n return this.behindLiveEdge_;\n };\n\n _proto.isTracking = function isTracking() {\n return typeof this.trackingInterval_ === 'number';\n };\n /**\n * Seek to the live edge if we are behind the live edge\n */\n\n\n _proto.seekToLiveEdge = function seekToLiveEdge() {\n if (this.atLiveEdge()) {\n return;\n }\n\n this.player_.currentTime(this.liveCurrentTime());\n\n if (this.player_.paused()) {\n this.player_.play();\n }\n };\n\n _proto.dispose = function dispose() {\n this.stopTracking();\n\n _Component.prototype.dispose.call(this);\n };\n\n return LiveTracker;\n}(Component);\n\nComponent.registerComponent('LiveTracker', LiveTracker);\n\n/**\n * This function is used to fire a sourceset when there is something\n * similar to `mediaEl.load()` being called. It will try to find the source via\n * the `src` attribute and then the `<source>` elements. It will then fire `sourceset`\n * with the source that was found or empty string if we cannot know. If it cannot\n * find a source then `sourceset` will not be fired.\n *\n * @param {Html5} tech\n * The tech object that sourceset was setup on\n *\n * @return {boolean}\n * returns false if the sourceset was not fired and true otherwise.\n */\n\nvar sourcesetLoad = function sourcesetLoad(tech) {\n var el = tech.el(); // if `el.src` is set, that source will be loaded.\n\n if (el.hasAttribute('src')) {\n tech.triggerSourceset(el.src);\n return true;\n }\n /**\n * Since there isn't a src property on the media element, source elements will be used for\n * implementing the source selection algorithm. This happens asynchronously and\n * for most cases were there is more than one source we cannot tell what source will\n * be loaded, without re-implementing the source selection algorithm. At this time we are not\n * going to do that. There are three special cases that we do handle here though:\n *\n * 1. If there are no sources, do not fire `sourceset`.\n * 2. If there is only one `<source>` with a `src` property/attribute that is our `src`\n * 3. If there is more than one `<source>` but all of them have the same `src` url.\n * That will be our src.\n */\n\n\n var sources = tech.$$('source');\n var srcUrls = [];\n var src = ''; // if there are no sources, do not fire sourceset\n\n if (!sources.length) {\n return false;\n } // only count valid/non-duplicate source elements\n\n\n for (var i = 0; i < sources.length; i++) {\n var url = sources[i].src;\n\n if (url && srcUrls.indexOf(url) === -1) {\n srcUrls.push(url);\n }\n } // there were no valid sources\n\n\n if (!srcUrls.length) {\n return false;\n } // there is only one valid source element url\n // use that\n\n\n if (srcUrls.length === 1) {\n src = srcUrls[0];\n }\n\n tech.triggerSourceset(src);\n return true;\n};\n/**\n * our implementation of an `innerHTML` descriptor for browsers\n * that do not have one.\n */\n\n\nvar innerHTMLDescriptorPolyfill = Object.defineProperty({}, 'innerHTML', {\n get: function get() {\n return this.cloneNode(true).innerHTML;\n },\n set: function set(v) {\n // make a dummy node to use innerHTML on\n var dummy = document.createElement(this.nodeName.toLowerCase()); // set innerHTML to the value provided\n\n dummy.innerHTML = v; // make a document fragment to hold the nodes from dummy\n\n var docFrag = document.createDocumentFragment(); // copy all of the nodes created by the innerHTML on dummy\n // to the document fragment\n\n while (dummy.childNodes.length) {\n docFrag.appendChild(dummy.childNodes[0]);\n } // remove content\n\n\n this.innerText = ''; // now we add all of that html in one by appending the\n // document fragment. This is how innerHTML does it.\n\n window$1.Element.prototype.appendChild.call(this, docFrag); // then return the result that innerHTML's setter would\n\n return this.innerHTML;\n }\n});\n/**\n * Get a property descriptor given a list of priorities and the\n * property to get.\n */\n\nvar getDescriptor = function getDescriptor(priority, prop) {\n var descriptor = {};\n\n for (var i = 0; i < priority.length; i++) {\n descriptor = Object.getOwnPropertyDescriptor(priority[i], prop);\n\n if (descriptor && descriptor.set && descriptor.get) {\n break;\n }\n }\n\n descriptor.enumerable = true;\n descriptor.configurable = true;\n return descriptor;\n};\n\nvar getInnerHTMLDescriptor = function getInnerHTMLDescriptor(tech) {\n return getDescriptor([tech.el(), window$1.HTMLMediaElement.prototype, window$1.Element.prototype, innerHTMLDescriptorPolyfill], 'innerHTML');\n};\n/**\n * Patches browser internal functions so that we can tell synchronously\n * if a `<source>` was appended to the media element. For some reason this\n * causes a `sourceset` if the the media element is ready and has no source.\n * This happens when:\n * - The page has just loaded and the media element does not have a source.\n * - The media element was emptied of all sources, then `load()` was called.\n *\n * It does this by patching the following functions/properties when they are supported:\n *\n * - `append()` - can be used to add a `<source>` element to the media element\n * - `appendChild()` - can be used to add a `<source>` element to the media element\n * - `insertAdjacentHTML()` - can be used to add a `<source>` element to the media element\n * - `innerHTML` - can be used to add a `<source>` element to the media element\n *\n * @param {Html5} tech\n * The tech object that sourceset is being setup on.\n */\n\n\nvar firstSourceWatch = function firstSourceWatch(tech) {\n var el = tech.el(); // make sure firstSourceWatch isn't setup twice.\n\n if (el.resetSourceWatch_) {\n return;\n }\n\n var old = {};\n var innerDescriptor = getInnerHTMLDescriptor(tech);\n\n var appendWrapper = function appendWrapper(appendFn) {\n return function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var retval = appendFn.apply(el, args);\n sourcesetLoad(tech);\n return retval;\n };\n };\n\n ['append', 'appendChild', 'insertAdjacentHTML'].forEach(function (k) {\n if (!el[k]) {\n return;\n } // store the old function\n\n\n old[k] = el[k]; // call the old function with a sourceset if a source\n // was loaded\n\n el[k] = appendWrapper(old[k]);\n });\n Object.defineProperty(el, 'innerHTML', mergeOptions(innerDescriptor, {\n set: appendWrapper(innerDescriptor.set)\n }));\n\n el.resetSourceWatch_ = function () {\n el.resetSourceWatch_ = null;\n Object.keys(old).forEach(function (k) {\n el[k] = old[k];\n });\n Object.defineProperty(el, 'innerHTML', innerDescriptor);\n }; // on the first sourceset, we need to revert our changes\n\n\n tech.one('sourceset', el.resetSourceWatch_);\n};\n/**\n * our implementation of a `src` descriptor for browsers\n * that do not have one.\n */\n\n\nvar srcDescriptorPolyfill = Object.defineProperty({}, 'src', {\n get: function get() {\n if (this.hasAttribute('src')) {\n return getAbsoluteURL(window$1.Element.prototype.getAttribute.call(this, 'src'));\n }\n\n return '';\n },\n set: function set(v) {\n window$1.Element.prototype.setAttribute.call(this, 'src', v);\n return v;\n }\n});\n\nvar getSrcDescriptor = function getSrcDescriptor(tech) {\n return getDescriptor([tech.el(), window$1.HTMLMediaElement.prototype, srcDescriptorPolyfill], 'src');\n};\n/**\n * setup `sourceset` handling on the `Html5` tech. This function\n * patches the following element properties/functions:\n *\n * - `src` - to determine when `src` is set\n * - `setAttribute()` - to determine when `src` is set\n * - `load()` - this re-triggers the source selection algorithm, and can\n * cause a sourceset.\n *\n * If there is no source when we are adding `sourceset` support or during a `load()`\n * we also patch the functions listed in `firstSourceWatch`.\n *\n * @param {Html5} tech\n * The tech to patch\n */\n\n\nvar setupSourceset = function setupSourceset(tech) {\n if (!tech.featuresSourceset) {\n return;\n }\n\n var el = tech.el(); // make sure sourceset isn't setup twice.\n\n if (el.resetSourceset_) {\n return;\n }\n\n var srcDescriptor = getSrcDescriptor(tech);\n var oldSetAttribute = el.setAttribute;\n var oldLoad = el.load;\n Object.defineProperty(el, 'src', mergeOptions(srcDescriptor, {\n set: function set(v) {\n var retval = srcDescriptor.set.call(el, v); // we use the getter here to get the actual value set on src\n\n tech.triggerSourceset(el.src);\n return retval;\n }\n }));\n\n el.setAttribute = function (n, v) {\n var retval = oldSetAttribute.call(el, n, v);\n\n if (/src/i.test(n)) {\n tech.triggerSourceset(el.src);\n }\n\n return retval;\n };\n\n el.load = function () {\n var retval = oldLoad.call(el); // if load was called, but there was no source to fire\n // sourceset on. We have to watch for a source append\n // as that can trigger a `sourceset` when the media element\n // has no source\n\n if (!sourcesetLoad(tech)) {\n tech.triggerSourceset('');\n firstSourceWatch(tech);\n }\n\n return retval;\n };\n\n if (el.currentSrc) {\n tech.triggerSourceset(el.currentSrc);\n } else if (!sourcesetLoad(tech)) {\n firstSourceWatch(tech);\n }\n\n el.resetSourceset_ = function () {\n el.resetSourceset_ = null;\n el.load = oldLoad;\n el.setAttribute = oldSetAttribute;\n Object.defineProperty(el, 'src', srcDescriptor);\n\n if (el.resetSourceWatch_) {\n el.resetSourceWatch_();\n }\n };\n};\n\nfunction _templateObject$1() {\n var data = _taggedTemplateLiteralLoose([\"Text Tracks are being loaded from another origin but the crossorigin attribute isn't used.\\n This may prevent text tracks from loading.\"]);\n\n _templateObject$1 = function _templateObject() {\n return data;\n };\n\n return data;\n}\n/**\n * HTML5 Media Controller - Wrapper for HTML5 Media API\n *\n * @mixes Tech~SourceHandlerAdditions\n * @extends Tech\n */\n\nvar Html5 =\n/*#__PURE__*/\nfunction (_Tech) {\n _inheritsLoose(Html5, _Tech);\n\n /**\n * Create an instance of this Tech.\n *\n * @param {Object} [options]\n * The key/value store of player options.\n *\n * @param {Component~ReadyCallback} ready\n * Callback function to call when the `HTML5` Tech is ready.\n */\n function Html5(options, ready) {\n var _this;\n\n _this = _Tech.call(this, options, ready) || this;\n var source = options.source;\n var crossoriginTracks = false; // Set the source if one is provided\n // 1) Check if the source is new (if not, we want to keep the original so playback isn't interrupted)\n // 2) Check to see if the network state of the tag was failed at init, and if so, reset the source\n // anyway so the error gets fired.\n\n if (source && (_this.el_.currentSrc !== source.src || options.tag && options.tag.initNetworkState_ === 3)) {\n _this.setSource(source);\n } else {\n _this.handleLateInit_(_this.el_);\n } // setup sourceset after late sourceset/init\n\n\n if (options.enableSourceset) {\n _this.setupSourcesetHandling_();\n }\n\n if (_this.el_.hasChildNodes()) {\n var nodes = _this.el_.childNodes;\n var nodesLength = nodes.length;\n var removeNodes = [];\n\n while (nodesLength--) {\n var node = nodes[nodesLength];\n var nodeName = node.nodeName.toLowerCase();\n\n if (nodeName === 'track') {\n if (!_this.featuresNativeTextTracks) {\n // Empty video tag tracks so the built-in player doesn't use them also.\n // This may not be fast enough to stop HTML5 browsers from reading the tags\n // so we'll need to turn off any default tracks if we're manually doing\n // captions and subtitles. videoElement.textTracks\n removeNodes.push(node);\n } else {\n // store HTMLTrackElement and TextTrack to remote list\n _this.remoteTextTrackEls().addTrackElement_(node);\n\n _this.remoteTextTracks().addTrack(node.track);\n\n _this.textTracks().addTrack(node.track);\n\n if (!crossoriginTracks && !_this.el_.hasAttribute('crossorigin') && isCrossOrigin(node.src)) {\n crossoriginTracks = true;\n }\n }\n }\n }\n\n for (var i = 0; i < removeNodes.length; i++) {\n _this.el_.removeChild(removeNodes[i]);\n }\n }\n\n _this.proxyNativeTracks_();\n\n if (_this.featuresNativeTextTracks && crossoriginTracks) {\n log.warn(tsml(_templateObject$1()));\n } // prevent iOS Safari from disabling metadata text tracks during native playback\n\n\n _this.restoreMetadataTracksInIOSNativePlayer_(); // Determine if native controls should be used\n // Our goal should be to get the custom controls on mobile solid everywhere\n // so we can remove this all together. Right now this will block custom\n // controls on touch enabled laptops like the Chrome Pixel\n\n\n if ((TOUCH_ENABLED || IS_IPHONE || IS_NATIVE_ANDROID) && options.nativeControlsForTouch === true) {\n _this.setControls(true);\n } // on iOS, we want to proxy `webkitbeginfullscreen` and `webkitendfullscreen`\n // into a `fullscreenchange` event\n\n\n _this.proxyWebkitFullscreen_();\n\n _this.triggerReady();\n\n return _this;\n }\n /**\n * Dispose of `HTML5` media element and remove all tracks.\n */\n\n\n var _proto = Html5.prototype;\n\n _proto.dispose = function dispose() {\n if (this.el_ && this.el_.resetSourceset_) {\n this.el_.resetSourceset_();\n }\n\n Html5.disposeMediaElement(this.el_);\n this.options_ = null; // tech will handle clearing of the emulated track list\n\n _Tech.prototype.dispose.call(this);\n };\n /**\n * Modify the media element so that we can detect when\n * the source is changed. Fires `sourceset` just after the source has changed\n */\n\n\n _proto.setupSourcesetHandling_ = function setupSourcesetHandling_() {\n setupSourceset(this);\n };\n /**\n * When a captions track is enabled in the iOS Safari native player, all other\n * tracks are disabled (including metadata tracks), which nulls all of their\n * associated cue points. This will restore metadata tracks to their pre-fullscreen\n * state in those cases so that cue points are not needlessly lost.\n *\n * @private\n */\n\n\n _proto.restoreMetadataTracksInIOSNativePlayer_ = function restoreMetadataTracksInIOSNativePlayer_() {\n var textTracks = this.textTracks();\n var metadataTracksPreFullscreenState; // captures a snapshot of every metadata track's current state\n\n var takeMetadataTrackSnapshot = function takeMetadataTrackSnapshot() {\n metadataTracksPreFullscreenState = [];\n\n for (var i = 0; i < textTracks.length; i++) {\n var track = textTracks[i];\n\n if (track.kind === 'metadata') {\n metadataTracksPreFullscreenState.push({\n track: track,\n storedMode: track.mode\n });\n }\n }\n }; // snapshot each metadata track's initial state, and update the snapshot\n // each time there is a track 'change' event\n\n\n takeMetadataTrackSnapshot();\n textTracks.addEventListener('change', takeMetadataTrackSnapshot);\n this.on('dispose', function () {\n return textTracks.removeEventListener('change', takeMetadataTrackSnapshot);\n });\n\n var restoreTrackMode = function restoreTrackMode() {\n for (var i = 0; i < metadataTracksPreFullscreenState.length; i++) {\n var storedTrack = metadataTracksPreFullscreenState[i];\n\n if (storedTrack.track.mode === 'disabled' && storedTrack.track.mode !== storedTrack.storedMode) {\n storedTrack.track.mode = storedTrack.storedMode;\n }\n } // we only want this handler to be executed on the first 'change' event\n\n\n textTracks.removeEventListener('change', restoreTrackMode);\n }; // when we enter fullscreen playback, stop updating the snapshot and\n // restore all track modes to their pre-fullscreen state\n\n\n this.on('webkitbeginfullscreen', function () {\n textTracks.removeEventListener('change', takeMetadataTrackSnapshot); // remove the listener before adding it just in case it wasn't previously removed\n\n textTracks.removeEventListener('change', restoreTrackMode);\n textTracks.addEventListener('change', restoreTrackMode);\n }); // start updating the snapshot again after leaving fullscreen\n\n this.on('webkitendfullscreen', function () {\n // remove the listener before adding it just in case it wasn't previously removed\n textTracks.removeEventListener('change', takeMetadataTrackSnapshot);\n textTracks.addEventListener('change', takeMetadataTrackSnapshot); // remove the restoreTrackMode handler in case it wasn't triggered during fullscreen playback\n\n textTracks.removeEventListener('change', restoreTrackMode);\n });\n };\n /**\n * Attempt to force override of tracks for the given type\n *\n * @param {string} type - Track type to override, possible values include 'Audio',\n * 'Video', and 'Text'.\n * @param {boolean} override - If set to true native audio/video will be overridden,\n * otherwise native audio/video will potentially be used.\n * @private\n */\n\n\n _proto.overrideNative_ = function overrideNative_(type, override) {\n var _this2 = this;\n\n // If there is no behavioral change don't add/remove listeners\n if (override !== this[\"featuresNative\" + type + \"Tracks\"]) {\n return;\n }\n\n var lowerCaseType = type.toLowerCase();\n\n if (this[lowerCaseType + \"TracksListeners_\"]) {\n Object.keys(this[lowerCaseType + \"TracksListeners_\"]).forEach(function (eventName) {\n var elTracks = _this2.el()[lowerCaseType + \"Tracks\"];\n\n elTracks.removeEventListener(eventName, _this2[lowerCaseType + \"TracksListeners_\"][eventName]);\n });\n }\n\n this[\"featuresNative\" + type + \"Tracks\"] = !override;\n this[lowerCaseType + \"TracksListeners_\"] = null;\n this.proxyNativeTracksForType_(lowerCaseType);\n };\n /**\n * Attempt to force override of native audio tracks.\n *\n * @param {boolean} override - If set to true native audio will be overridden,\n * otherwise native audio will potentially be used.\n */\n\n\n _proto.overrideNativeAudioTracks = function overrideNativeAudioTracks(override) {\n this.overrideNative_('Audio', override);\n };\n /**\n * Attempt to force override of native video tracks.\n *\n * @param {boolean} override - If set to true native video will be overridden,\n * otherwise native video will potentially be used.\n */\n\n\n _proto.overrideNativeVideoTracks = function overrideNativeVideoTracks(override) {\n this.overrideNative_('Video', override);\n };\n /**\n * Proxy native track list events for the given type to our track\n * lists if the browser we are playing in supports that type of track list.\n *\n * @param {string} name - Track type; values include 'audio', 'video', and 'text'\n * @private\n */\n\n\n _proto.proxyNativeTracksForType_ = function proxyNativeTracksForType_(name) {\n var _this3 = this;\n\n var props = NORMAL[name];\n var elTracks = this.el()[props.getterName];\n var techTracks = this[props.getterName]();\n\n if (!this[\"featuresNative\" + props.capitalName + \"Tracks\"] || !elTracks || !elTracks.addEventListener) {\n return;\n }\n\n var listeners = {\n change: function change(e) {\n techTracks.trigger({\n type: 'change',\n target: techTracks,\n currentTarget: techTracks,\n srcElement: techTracks\n });\n },\n addtrack: function addtrack(e) {\n techTracks.addTrack(e.track);\n },\n removetrack: function removetrack(e) {\n techTracks.removeTrack(e.track);\n }\n };\n\n var removeOldTracks = function removeOldTracks() {\n var removeTracks = [];\n\n for (var i = 0; i < techTracks.length; i++) {\n var found = false;\n\n for (var j = 0; j < elTracks.length; j++) {\n if (elTracks[j] === techTracks[i]) {\n found = true;\n break;\n }\n }\n\n if (!found) {\n removeTracks.push(techTracks[i]);\n }\n }\n\n while (removeTracks.length) {\n techTracks.removeTrack(removeTracks.shift());\n }\n };\n\n this[props.getterName + 'Listeners_'] = listeners;\n Object.keys(listeners).forEach(function (eventName) {\n var listener = listeners[eventName];\n elTracks.addEventListener(eventName, listener);\n\n _this3.on('dispose', function (e) {\n return elTracks.removeEventListener(eventName, listener);\n });\n }); // Remove (native) tracks that are not used anymore\n\n this.on('loadstart', removeOldTracks);\n this.on('dispose', function (e) {\n return _this3.off('loadstart', removeOldTracks);\n });\n };\n /**\n * Proxy all native track list events to our track lists if the browser we are playing\n * in supports that type of track list.\n *\n * @private\n */\n\n\n _proto.proxyNativeTracks_ = function proxyNativeTracks_() {\n var _this4 = this;\n\n NORMAL.names.forEach(function (name) {\n _this4.proxyNativeTracksForType_(name);\n });\n };\n /**\n * Create the `Html5` Tech's DOM element.\n *\n * @return {Element}\n * The element that gets created.\n */\n\n\n _proto.createEl = function createEl$$1() {\n var el = this.options_.tag; // Check if this browser supports moving the element into the box.\n // On the iPhone video will break if you move the element,\n // So we have to create a brand new element.\n // If we ingested the player div, we do not need to move the media element.\n\n if (!el || !(this.options_.playerElIngest || this.movingMediaElementInDOM)) {\n // If the original tag is still there, clone and remove it.\n if (el) {\n var clone = el.cloneNode(true);\n\n if (el.parentNode) {\n el.parentNode.insertBefore(clone, el);\n }\n\n Html5.disposeMediaElement(el);\n el = clone;\n } else {\n el = document.createElement('video'); // determine if native controls should be used\n\n var tagAttributes = this.options_.tag && getAttributes(this.options_.tag);\n var attributes = mergeOptions({}, tagAttributes);\n\n if (!TOUCH_ENABLED || this.options_.nativeControlsForTouch !== true) {\n delete attributes.controls;\n }\n\n setAttributes(el, assign(attributes, {\n id: this.options_.techId,\n class: 'vjs-tech'\n }));\n }\n\n el.playerId = this.options_.playerId;\n }\n\n if (typeof this.options_.preload !== 'undefined') {\n setAttribute(el, 'preload', this.options_.preload);\n } // Update specific tag settings, in case they were overridden\n // `autoplay` has to be *last* so that `muted` and `playsinline` are present\n // when iOS/Safari or other browsers attempt to autoplay.\n\n\n var settingsAttrs = ['loop', 'muted', 'playsinline', 'autoplay'];\n\n for (var i = 0; i < settingsAttrs.length; i++) {\n var attr = settingsAttrs[i];\n var value = this.options_[attr];\n\n if (typeof value !== 'undefined') {\n if (value) {\n setAttribute(el, attr, attr);\n } else {\n removeAttribute(el, attr);\n }\n\n el[attr] = value;\n }\n }\n\n return el;\n };\n /**\n * This will be triggered if the loadstart event has already fired, before videojs was\n * ready. Two known examples of when this can happen are:\n * 1. If we're loading the playback object after it has started loading\n * 2. The media is already playing the (often with autoplay on) then\n *\n * This function will fire another loadstart so that videojs can catchup.\n *\n * @fires Tech#loadstart\n *\n * @return {undefined}\n * returns nothing.\n */\n\n\n _proto.handleLateInit_ = function handleLateInit_(el) {\n if (el.networkState === 0 || el.networkState === 3) {\n // The video element hasn't started loading the source yet\n // or didn't find a source\n return;\n }\n\n if (el.readyState === 0) {\n // NetworkState is set synchronously BUT loadstart is fired at the\n // end of the current stack, usually before setInterval(fn, 0).\n // So at this point we know loadstart may have already fired or is\n // about to fire, and either way the player hasn't seen it yet.\n // We don't want to fire loadstart prematurely here and cause a\n // double loadstart so we'll wait and see if it happens between now\n // and the next loop, and fire it if not.\n // HOWEVER, we also want to make sure it fires before loadedmetadata\n // which could also happen between now and the next loop, so we'll\n // watch for that also.\n var loadstartFired = false;\n\n var setLoadstartFired = function setLoadstartFired() {\n loadstartFired = true;\n };\n\n this.on('loadstart', setLoadstartFired);\n\n var triggerLoadstart = function triggerLoadstart() {\n // We did miss the original loadstart. Make sure the player\n // sees loadstart before loadedmetadata\n if (!loadstartFired) {\n this.trigger('loadstart');\n }\n };\n\n this.on('loadedmetadata', triggerLoadstart);\n this.ready(function () {\n this.off('loadstart', setLoadstartFired);\n this.off('loadedmetadata', triggerLoadstart);\n\n if (!loadstartFired) {\n // We did miss the original native loadstart. Fire it now.\n this.trigger('loadstart');\n }\n });\n return;\n } // From here on we know that loadstart already fired and we missed it.\n // The other readyState events aren't as much of a problem if we double\n // them, so not going to go to as much trouble as loadstart to prevent\n // that unless we find reason to.\n\n\n var eventsToTrigger = ['loadstart']; // loadedmetadata: newly equal to HAVE_METADATA (1) or greater\n\n eventsToTrigger.push('loadedmetadata'); // loadeddata: newly increased to HAVE_CURRENT_DATA (2) or greater\n\n if (el.readyState >= 2) {\n eventsToTrigger.push('loadeddata');\n } // canplay: newly increased to HAVE_FUTURE_DATA (3) or greater\n\n\n if (el.readyState >= 3) {\n eventsToTrigger.push('canplay');\n } // canplaythrough: newly equal to HAVE_ENOUGH_DATA (4)\n\n\n if (el.readyState >= 4) {\n eventsToTrigger.push('canplaythrough');\n } // We still need to give the player time to add event listeners\n\n\n this.ready(function () {\n eventsToTrigger.forEach(function (type) {\n this.trigger(type);\n }, this);\n });\n };\n /**\n * Set current time for the `HTML5` tech.\n *\n * @param {number} seconds\n * Set the current time of the media to this.\n */\n\n\n _proto.setCurrentTime = function setCurrentTime(seconds) {\n try {\n this.el_.currentTime = seconds;\n } catch (e) {\n log(e, 'Video is not ready. (Video.js)'); // this.warning(VideoJS.warnings.videoNotReady);\n }\n };\n /**\n * Get the current duration of the HTML5 media element.\n *\n * @return {number}\n * The duration of the media or 0 if there is no duration.\n */\n\n\n _proto.duration = function duration() {\n var _this5 = this;\n\n // Android Chrome will report duration as Infinity for VOD HLS until after\n // playback has started, which triggers the live display erroneously.\n // Return NaN if playback has not started and trigger a durationupdate once\n // the duration can be reliably known.\n if (this.el_.duration === Infinity && IS_ANDROID && IS_CHROME && this.el_.currentTime === 0) {\n // Wait for the first `timeupdate` with currentTime > 0 - there may be\n // several with 0\n var checkProgress = function checkProgress() {\n if (_this5.el_.currentTime > 0) {\n // Trigger durationchange for genuinely live video\n if (_this5.el_.duration === Infinity) {\n _this5.trigger('durationchange');\n }\n\n _this5.off('timeupdate', checkProgress);\n }\n };\n\n this.on('timeupdate', checkProgress);\n return NaN;\n }\n\n return this.el_.duration || NaN;\n };\n /**\n * Get the current width of the HTML5 media element.\n *\n * @return {number}\n * The width of the HTML5 media element.\n */\n\n\n _proto.width = function width() {\n return this.el_.offsetWidth;\n };\n /**\n * Get the current height of the HTML5 media element.\n *\n * @return {number}\n * The height of the HTML5 media element.\n */\n\n\n _proto.height = function height() {\n return this.el_.offsetHeight;\n };\n /**\n * Proxy iOS `webkitbeginfullscreen` and `webkitendfullscreen` into\n * `fullscreenchange` event.\n *\n * @private\n * @fires fullscreenchange\n * @listens webkitendfullscreen\n * @listens webkitbeginfullscreen\n * @listens webkitbeginfullscreen\n */\n\n\n _proto.proxyWebkitFullscreen_ = function proxyWebkitFullscreen_() {\n var _this6 = this;\n\n if (!('webkitDisplayingFullscreen' in this.el_)) {\n return;\n }\n\n var endFn = function endFn() {\n this.trigger('fullscreenchange', {\n isFullscreen: false\n });\n };\n\n var beginFn = function beginFn() {\n if ('webkitPresentationMode' in this.el_ && this.el_.webkitPresentationMode !== 'picture-in-picture') {\n this.one('webkitendfullscreen', endFn);\n this.trigger('fullscreenchange', {\n isFullscreen: true\n });\n }\n };\n\n this.on('webkitbeginfullscreen', beginFn);\n this.on('dispose', function () {\n _this6.off('webkitbeginfullscreen', beginFn);\n\n _this6.off('webkitendfullscreen', endFn);\n });\n };\n /**\n * Check if fullscreen is supported on the current playback device.\n *\n * @return {boolean}\n * - True if fullscreen is supported.\n * - False if fullscreen is not supported.\n */\n\n\n _proto.supportsFullScreen = function supportsFullScreen() {\n if (typeof this.el_.webkitEnterFullScreen === 'function') {\n var userAgent = window$1.navigator && window$1.navigator.userAgent || ''; // Seems to be broken in Chromium/Chrome && Safari in Leopard\n\n if (/Android/.test(userAgent) || !/Chrome|Mac OS X 10.5/.test(userAgent)) {\n return true;\n }\n }\n\n return false;\n };\n /**\n * Request that the `HTML5` Tech enter fullscreen.\n */\n\n\n _proto.enterFullScreen = function enterFullScreen() {\n var video = this.el_;\n\n if (video.paused && video.networkState <= video.HAVE_METADATA) {\n // attempt to prime the video element for programmatic access\n // this isn't necessary on the desktop but shouldn't hurt\n this.el_.play(); // playing and pausing synchronously during the transition to fullscreen\n // can get iOS ~6.1 devices into a play/pause loop\n\n this.setTimeout(function () {\n video.pause();\n video.webkitEnterFullScreen();\n }, 0);\n } else {\n video.webkitEnterFullScreen();\n }\n };\n /**\n * Request that the `HTML5` Tech exit fullscreen.\n */\n\n\n _proto.exitFullScreen = function exitFullScreen() {\n this.el_.webkitExitFullScreen();\n };\n /**\n * A getter/setter for the `Html5` Tech's source object.\n * > Note: Please use {@link Html5#setSource}\n *\n * @param {Tech~SourceObject} [src]\n * The source object you want to set on the `HTML5` techs element.\n *\n * @return {Tech~SourceObject|undefined}\n * - The current source object when a source is not passed in.\n * - undefined when setting\n *\n * @deprecated Since version 5.\n */\n\n\n _proto.src = function src(_src) {\n if (_src === undefined) {\n return this.el_.src;\n } // Setting src through `src` instead of `setSrc` will be deprecated\n\n\n this.setSrc(_src);\n };\n /**\n * Reset the tech by removing all sources and then calling\n * {@link Html5.resetMediaElement}.\n */\n\n\n _proto.reset = function reset() {\n Html5.resetMediaElement(this.el_);\n };\n /**\n * Get the current source on the `HTML5` Tech. Falls back to returning the source from\n * the HTML5 media element.\n *\n * @return {Tech~SourceObject}\n * The current source object from the HTML5 tech. With a fallback to the\n * elements source.\n */\n\n\n _proto.currentSrc = function currentSrc() {\n if (this.currentSource_) {\n return this.currentSource_.src;\n }\n\n return this.el_.currentSrc;\n };\n /**\n * Set controls attribute for the HTML5 media Element.\n *\n * @param {string} val\n * Value to set the controls attribute to\n */\n\n\n _proto.setControls = function setControls(val) {\n this.el_.controls = !!val;\n };\n /**\n * Create and returns a remote {@link TextTrack} object.\n *\n * @param {string} kind\n * `TextTrack` kind (subtitles, captions, descriptions, chapters, or metadata)\n *\n * @param {string} [label]\n * Label to identify the text track\n *\n * @param {string} [language]\n * Two letter language abbreviation\n *\n * @return {TextTrack}\n * The TextTrack that gets created.\n */\n\n\n _proto.addTextTrack = function addTextTrack(kind, label, language) {\n if (!this.featuresNativeTextTracks) {\n return _Tech.prototype.addTextTrack.call(this, kind, label, language);\n }\n\n return this.el_.addTextTrack(kind, label, language);\n };\n /**\n * Creates either native TextTrack or an emulated TextTrack depending\n * on the value of `featuresNativeTextTracks`\n *\n * @param {Object} options\n * The object should contain the options to initialize the TextTrack with.\n *\n * @param {string} [options.kind]\n * `TextTrack` kind (subtitles, captions, descriptions, chapters, or metadata).\n *\n * @param {string} [options.label]\n * Label to identify the text track\n *\n * @param {string} [options.language]\n * Two letter language abbreviation.\n *\n * @param {boolean} [options.default]\n * Default this track to on.\n *\n * @param {string} [options.id]\n * The internal id to assign this track.\n *\n * @param {string} [options.src]\n * A source url for the track.\n *\n * @return {HTMLTrackElement}\n * The track element that gets created.\n */\n\n\n _proto.createRemoteTextTrack = function createRemoteTextTrack(options) {\n if (!this.featuresNativeTextTracks) {\n return _Tech.prototype.createRemoteTextTrack.call(this, options);\n }\n\n var htmlTrackElement = document.createElement('track');\n\n if (options.kind) {\n htmlTrackElement.kind = options.kind;\n }\n\n if (options.label) {\n htmlTrackElement.label = options.label;\n }\n\n if (options.language || options.srclang) {\n htmlTrackElement.srclang = options.language || options.srclang;\n }\n\n if (options.default) {\n htmlTrackElement.default = options.default;\n }\n\n if (options.id) {\n htmlTrackElement.id = options.id;\n }\n\n if (options.src) {\n htmlTrackElement.src = options.src;\n }\n\n return htmlTrackElement;\n };\n /**\n * Creates a remote text track object and returns an html track element.\n *\n * @param {Object} options The object should contain values for\n * kind, language, label, and src (location of the WebVTT file)\n * @param {boolean} [manualCleanup=true] if set to false, the TextTrack will be\n * automatically removed from the video element whenever the source changes\n * @return {HTMLTrackElement} An Html Track Element.\n * This can be an emulated {@link HTMLTrackElement} or a native one.\n * @deprecated The default value of the \"manualCleanup\" parameter will default\n * to \"false\" in upcoming versions of Video.js\n */\n\n\n _proto.addRemoteTextTrack = function addRemoteTextTrack(options, manualCleanup) {\n var htmlTrackElement = _Tech.prototype.addRemoteTextTrack.call(this, options, manualCleanup);\n\n if (this.featuresNativeTextTracks) {\n this.el().appendChild(htmlTrackElement);\n }\n\n return htmlTrackElement;\n };\n /**\n * Remove remote `TextTrack` from `TextTrackList` object\n *\n * @param {TextTrack} track\n * `TextTrack` object to remove\n */\n\n\n _proto.removeRemoteTextTrack = function removeRemoteTextTrack(track) {\n _Tech.prototype.removeRemoteTextTrack.call(this, track);\n\n if (this.featuresNativeTextTracks) {\n var tracks = this.$$('track');\n var i = tracks.length;\n\n while (i--) {\n if (track === tracks[i] || track === tracks[i].track) {\n this.el().removeChild(tracks[i]);\n }\n }\n }\n };\n /**\n * Gets available media playback quality metrics as specified by the W3C's Media\n * Playback Quality API.\n *\n * @see [Spec]{@link https://wicg.github.io/media-playback-quality}\n *\n * @return {Object}\n * An object with supported media playback quality metrics\n */\n\n\n _proto.getVideoPlaybackQuality = function getVideoPlaybackQuality() {\n if (typeof this.el().getVideoPlaybackQuality === 'function') {\n return this.el().getVideoPlaybackQuality();\n }\n\n var videoPlaybackQuality = {};\n\n if (typeof this.el().webkitDroppedFrameCount !== 'undefined' && typeof this.el().webkitDecodedFrameCount !== 'undefined') {\n videoPlaybackQuality.droppedVideoFrames = this.el().webkitDroppedFrameCount;\n videoPlaybackQuality.totalVideoFrames = this.el().webkitDecodedFrameCount;\n }\n\n if (window$1.performance && typeof window$1.performance.now === 'function') {\n videoPlaybackQuality.creationTime = window$1.performance.now();\n } else if (window$1.performance && window$1.performance.timing && typeof window$1.performance.timing.navigationStart === 'number') {\n videoPlaybackQuality.creationTime = window$1.Date.now() - window$1.performance.timing.navigationStart;\n }\n\n return videoPlaybackQuality;\n };\n\n return Html5;\n}(Tech);\n/* HTML5 Support Testing ---------------------------------------------------- */\n\n\nif (isReal()) {\n /**\n * Element for testing browser HTML5 media capabilities\n *\n * @type {Element}\n * @constant\n * @private\n */\n Html5.TEST_VID = document.createElement('video');\n var track = document.createElement('track');\n track.kind = 'captions';\n track.srclang = 'en';\n track.label = 'English';\n Html5.TEST_VID.appendChild(track);\n}\n/**\n * Check if HTML5 media is supported by this browser/device.\n *\n * @return {boolean}\n * - True if HTML5 media is supported.\n * - False if HTML5 media is not supported.\n */\n\n\nHtml5.isSupported = function () {\n // IE with no Media Player is a LIAR! (#984)\n try {\n Html5.TEST_VID.volume = 0.5;\n } catch (e) {\n return false;\n }\n\n return !!(Html5.TEST_VID && Html5.TEST_VID.canPlayType);\n};\n/**\n * Check if the tech can support the given type\n *\n * @param {string} type\n * The mimetype to check\n * @return {string} 'probably', 'maybe', or '' (empty string)\n */\n\n\nHtml5.canPlayType = function (type) {\n return Html5.TEST_VID.canPlayType(type);\n};\n/**\n * Check if the tech can support the given source\n *\n * @param {Object} srcObj\n * The source object\n * @param {Object} options\n * The options passed to the tech\n * @return {string} 'probably', 'maybe', or '' (empty string)\n */\n\n\nHtml5.canPlaySource = function (srcObj, options) {\n return Html5.canPlayType(srcObj.type);\n};\n/**\n * Check if the volume can be changed in this browser/device.\n * Volume cannot be changed in a lot of mobile devices.\n * Specifically, it can't be changed from 1 on iOS.\n *\n * @return {boolean}\n * - True if volume can be controlled\n * - False otherwise\n */\n\n\nHtml5.canControlVolume = function () {\n // IE will error if Windows Media Player not installed #3315\n try {\n var volume = Html5.TEST_VID.volume;\n Html5.TEST_VID.volume = volume / 2 + 0.1;\n return volume !== Html5.TEST_VID.volume;\n } catch (e) {\n return false;\n }\n};\n/**\n * Check if the volume can be muted in this browser/device.\n * Some devices, e.g. iOS, don't allow changing volume\n * but permits muting/unmuting.\n *\n * @return {bolean}\n * - True if volume can be muted\n * - False otherwise\n */\n\n\nHtml5.canMuteVolume = function () {\n try {\n var muted = Html5.TEST_VID.muted; // in some versions of iOS muted property doesn't always\n // work, so we want to set both property and attribute\n\n Html5.TEST_VID.muted = !muted;\n\n if (Html5.TEST_VID.muted) {\n setAttribute(Html5.TEST_VID, 'muted', 'muted');\n } else {\n removeAttribute(Html5.TEST_VID, 'muted', 'muted');\n }\n\n return muted !== Html5.TEST_VID.muted;\n } catch (e) {\n return false;\n }\n};\n/**\n * Check if the playback rate can be changed in this browser/device.\n *\n * @return {boolean}\n * - True if playback rate can be controlled\n * - False otherwise\n */\n\n\nHtml5.canControlPlaybackRate = function () {\n // Playback rate API is implemented in Android Chrome, but doesn't do anything\n // https://github.com/videojs/video.js/issues/3180\n if (IS_ANDROID && IS_CHROME && CHROME_VERSION < 58) {\n return false;\n } // IE will error if Windows Media Player not installed #3315\n\n\n try {\n var playbackRate = Html5.TEST_VID.playbackRate;\n Html5.TEST_VID.playbackRate = playbackRate / 2 + 0.1;\n return playbackRate !== Html5.TEST_VID.playbackRate;\n } catch (e) {\n return false;\n }\n};\n/**\n * Check if we can override a video/audio elements attributes, with\n * Object.defineProperty.\n *\n * @return {boolean}\n * - True if builtin attributes can be overridden\n * - False otherwise\n */\n\n\nHtml5.canOverrideAttributes = function () {\n // if we cannot overwrite the src/innerHTML property, there is no support\n // iOS 7 safari for instance cannot do this.\n try {\n var noop = function noop() {};\n\n Object.defineProperty(document.createElement('video'), 'src', {\n get: noop,\n set: noop\n });\n Object.defineProperty(document.createElement('audio'), 'src', {\n get: noop,\n set: noop\n });\n Object.defineProperty(document.createElement('video'), 'innerHTML', {\n get: noop,\n set: noop\n });\n Object.defineProperty(document.createElement('audio'), 'innerHTML', {\n get: noop,\n set: noop\n });\n } catch (e) {\n return false;\n }\n\n return true;\n};\n/**\n * Check to see if native `TextTrack`s are supported by this browser/device.\n *\n * @return {boolean}\n * - True if native `TextTrack`s are supported.\n * - False otherwise\n */\n\n\nHtml5.supportsNativeTextTracks = function () {\n return IS_ANY_SAFARI || IS_IOS && IS_CHROME;\n};\n/**\n * Check to see if native `VideoTrack`s are supported by this browser/device\n *\n * @return {boolean}\n * - True if native `VideoTrack`s are supported.\n * - False otherwise\n */\n\n\nHtml5.supportsNativeVideoTracks = function () {\n return !!(Html5.TEST_VID && Html5.TEST_VID.videoTracks);\n};\n/**\n * Check to see if native `AudioTrack`s are supported by this browser/device\n *\n * @return {boolean}\n * - True if native `AudioTrack`s are supported.\n * - False otherwise\n */\n\n\nHtml5.supportsNativeAudioTracks = function () {\n return !!(Html5.TEST_VID && Html5.TEST_VID.audioTracks);\n};\n/**\n * An array of events available on the Html5 tech.\n *\n * @private\n * @type {Array}\n */\n\n\nHtml5.Events = ['loadstart', 'suspend', 'abort', 'error', 'emptied', 'stalled', 'loadedmetadata', 'loadeddata', 'canplay', 'canplaythrough', 'playing', 'waiting', 'seeking', 'seeked', 'ended', 'durationchange', 'timeupdate', 'progress', 'play', 'pause', 'ratechange', 'resize', 'volumechange'];\n/**\n * Boolean indicating whether the `Tech` supports volume control.\n *\n * @type {boolean}\n * @default {@link Html5.canControlVolume}\n */\n\nHtml5.prototype.featuresVolumeControl = Html5.canControlVolume();\n/**\n * Boolean indicating whether the `Tech` supports muting volume.\n *\n * @type {bolean}\n * @default {@link Html5.canMuteVolume}\n */\n\nHtml5.prototype.featuresMuteControl = Html5.canMuteVolume();\n/**\n * Boolean indicating whether the `Tech` supports changing the speed at which the media\n * plays. Examples:\n * - Set player to play 2x (twice) as fast\n * - Set player to play 0.5x (half) as fast\n *\n * @type {boolean}\n * @default {@link Html5.canControlPlaybackRate}\n */\n\nHtml5.prototype.featuresPlaybackRate = Html5.canControlPlaybackRate();\n/**\n * Boolean indicating whether the `Tech` supports the `sourceset` event.\n *\n * @type {boolean}\n * @default\n */\n\nHtml5.prototype.featuresSourceset = Html5.canOverrideAttributes();\n/**\n * Boolean indicating whether the `HTML5` tech currently supports the media element\n * moving in the DOM. iOS breaks if you move the media element, so this is set this to\n * false there. Everywhere else this should be true.\n *\n * @type {boolean}\n * @default\n */\n\nHtml5.prototype.movingMediaElementInDOM = !IS_IOS; // TODO: Previous comment: No longer appears to be used. Can probably be removed.\n// Is this true?\n\n/**\n * Boolean indicating whether the `HTML5` tech currently supports automatic media resize\n * when going into fullscreen.\n *\n * @type {boolean}\n * @default\n */\n\nHtml5.prototype.featuresFullscreenResize = true;\n/**\n * Boolean indicating whether the `HTML5` tech currently supports the progress event.\n * If this is false, manual `progress` events will be triggered instead.\n *\n * @type {boolean}\n * @default\n */\n\nHtml5.prototype.featuresProgressEvents = true;\n/**\n * Boolean indicating whether the `HTML5` tech currently supports the timeupdate event.\n * If this is false, manual `timeupdate` events will be triggered instead.\n *\n * @default\n */\n\nHtml5.prototype.featuresTimeupdateEvents = true;\n/**\n * Boolean indicating whether the `HTML5` tech currently supports native `TextTrack`s.\n *\n * @type {boolean}\n * @default {@link Html5.supportsNativeTextTracks}\n */\n\nHtml5.prototype.featuresNativeTextTracks = Html5.supportsNativeTextTracks();\n/**\n * Boolean indicating whether the `HTML5` tech currently supports native `VideoTrack`s.\n *\n * @type {boolean}\n * @default {@link Html5.supportsNativeVideoTracks}\n */\n\nHtml5.prototype.featuresNativeVideoTracks = Html5.supportsNativeVideoTracks();\n/**\n * Boolean indicating whether the `HTML5` tech currently supports native `AudioTrack`s.\n *\n * @type {boolean}\n * @default {@link Html5.supportsNativeAudioTracks}\n */\n\nHtml5.prototype.featuresNativeAudioTracks = Html5.supportsNativeAudioTracks(); // HTML5 Feature detection and Device Fixes --------------------------------- //\n\nvar canPlayType = Html5.TEST_VID && Html5.TEST_VID.constructor.prototype.canPlayType;\nvar mpegurlRE = /^application\\/(?:x-|vnd\\.apple\\.)mpegurl/i;\n\nHtml5.patchCanPlayType = function () {\n // Android 4.0 and above can play HLS to some extent but it reports being unable to do so\n // Firefox and Chrome report correctly\n if (ANDROID_VERSION >= 4.0 && !IS_FIREFOX && !IS_CHROME) {\n Html5.TEST_VID.constructor.prototype.canPlayType = function (type) {\n if (type && mpegurlRE.test(type)) {\n return 'maybe';\n }\n\n return canPlayType.call(this, type);\n };\n }\n};\n\nHtml5.unpatchCanPlayType = function () {\n var r = Html5.TEST_VID.constructor.prototype.canPlayType;\n Html5.TEST_VID.constructor.prototype.canPlayType = canPlayType;\n return r;\n}; // by default, patch the media element\n\n\nHtml5.patchCanPlayType();\n\nHtml5.disposeMediaElement = function (el) {\n if (!el) {\n return;\n }\n\n if (el.parentNode) {\n el.parentNode.removeChild(el);\n } // remove any child track or source nodes to prevent their loading\n\n\n while (el.hasChildNodes()) {\n el.removeChild(el.firstChild);\n } // remove any src reference. not setting `src=''` because that causes a warning\n // in firefox\n\n\n el.removeAttribute('src'); // force the media element to update its loading state by calling load()\n // however IE on Windows 7N has a bug that throws an error so need a try/catch (#793)\n\n if (typeof el.load === 'function') {\n // wrapping in an iife so it's not deoptimized (#1060#discussion_r10324473)\n (function () {\n try {\n el.load();\n } catch (e) {// not supported\n }\n })();\n }\n};\n\nHtml5.resetMediaElement = function (el) {\n if (!el) {\n return;\n }\n\n var sources = el.querySelectorAll('source');\n var i = sources.length;\n\n while (i--) {\n el.removeChild(sources[i]);\n } // remove any src reference.\n // not setting `src=''` because that throws an error\n\n\n el.removeAttribute('src');\n\n if (typeof el.load === 'function') {\n // wrapping in an iife so it's not deoptimized (#1060#discussion_r10324473)\n (function () {\n try {\n el.load();\n } catch (e) {// satisfy linter\n }\n })();\n }\n};\n/* Native HTML5 element property wrapping ----------------------------------- */\n// Wrap native boolean attributes with getters that check both property and attribute\n// The list is as followed:\n// muted, defaultMuted, autoplay, controls, loop, playsinline\n\n\n[\n/**\n * Get the value of `muted` from the media element. `muted` indicates\n * that the volume for the media should be set to silent. This does not actually change\n * the `volume` attribute.\n *\n * @method Html5#muted\n * @return {boolean}\n * - True if the value of `volume` should be ignored and the audio set to silent.\n * - False if the value of `volume` should be used.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-muted}\n */\n'muted',\n/**\n * Get the value of `defaultMuted` from the media element. `defaultMuted` indicates\n * whether the media should start muted or not. Only changes the default state of the\n * media. `muted` and `defaultMuted` can have different values. {@link Html5#muted} indicates the\n * current state.\n *\n * @method Html5#defaultMuted\n * @return {boolean}\n * - The value of `defaultMuted` from the media element.\n * - True indicates that the media should start muted.\n * - False indicates that the media should not start muted\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-defaultmuted}\n */\n'defaultMuted',\n/**\n * Get the value of `autoplay` from the media element. `autoplay` indicates\n * that the media should start to play as soon as the page is ready.\n *\n * @method Html5#autoplay\n * @return {boolean}\n * - The value of `autoplay` from the media element.\n * - True indicates that the media should start as soon as the page loads.\n * - False indicates that the media should not start as soon as the page loads.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#attr-media-autoplay}\n */\n'autoplay',\n/**\n * Get the value of `controls` from the media element. `controls` indicates\n * whether the native media controls should be shown or hidden.\n *\n * @method Html5#controls\n * @return {boolean}\n * - The value of `controls` from the media element.\n * - True indicates that native controls should be showing.\n * - False indicates that native controls should be hidden.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#attr-media-controls}\n */\n'controls',\n/**\n * Get the value of `loop` from the media element. `loop` indicates\n * that the media should return to the start of the media and continue playing once\n * it reaches the end.\n *\n * @method Html5#loop\n * @return {boolean}\n * - The value of `loop` from the media element.\n * - True indicates that playback should seek back to start once\n * the end of a media is reached.\n * - False indicates that playback should not loop back to the start when the\n * end of the media is reached.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#attr-media-loop}\n */\n'loop',\n/**\n * Get the value of `playsinline` from the media element. `playsinline` indicates\n * to the browser that non-fullscreen playback is preferred when fullscreen\n * playback is the native default, such as in iOS Safari.\n *\n * @method Html5#playsinline\n * @return {boolean}\n * - The value of `playsinline` from the media element.\n * - True indicates that the media should play inline.\n * - False indicates that the media should not play inline.\n *\n * @see [Spec]{@link https://html.spec.whatwg.org/#attr-video-playsinline}\n */\n'playsinline'].forEach(function (prop) {\n Html5.prototype[prop] = function () {\n return this.el_[prop] || this.el_.hasAttribute(prop);\n };\n}); // Wrap native boolean attributes with setters that set both property and attribute\n// The list is as followed:\n// setMuted, setDefaultMuted, setAutoplay, setLoop, setPlaysinline\n// setControls is special-cased above\n\n[\n/**\n * Set the value of `muted` on the media element. `muted` indicates that the current\n * audio level should be silent.\n *\n * @method Html5#setMuted\n * @param {boolean} muted\n * - True if the audio should be set to silent\n * - False otherwise\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-muted}\n */\n'muted',\n/**\n * Set the value of `defaultMuted` on the media element. `defaultMuted` indicates that the current\n * audio level should be silent, but will only effect the muted level on intial playback..\n *\n * @method Html5.prototype.setDefaultMuted\n * @param {boolean} defaultMuted\n * - True if the audio should be set to silent\n * - False otherwise\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-defaultmuted}\n */\n'defaultMuted',\n/**\n * Set the value of `autoplay` on the media element. `autoplay` indicates\n * that the media should start to play as soon as the page is ready.\n *\n * @method Html5#setAutoplay\n * @param {boolean} autoplay\n * - True indicates that the media should start as soon as the page loads.\n * - False indicates that the media should not start as soon as the page loads.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#attr-media-autoplay}\n */\n'autoplay',\n/**\n * Set the value of `loop` on the media element. `loop` indicates\n * that the media should return to the start of the media and continue playing once\n * it reaches the end.\n *\n * @method Html5#setLoop\n * @param {boolean} loop\n * - True indicates that playback should seek back to start once\n * the end of a media is reached.\n * - False indicates that playback should not loop back to the start when the\n * end of the media is reached.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#attr-media-loop}\n */\n'loop',\n/**\n * Set the value of `playsinline` from the media element. `playsinline` indicates\n * to the browser that non-fullscreen playback is preferred when fullscreen\n * playback is the native default, such as in iOS Safari.\n *\n * @method Html5#setPlaysinline\n * @param {boolean} playsinline\n * - True indicates that the media should play inline.\n * - False indicates that the media should not play inline.\n *\n * @see [Spec]{@link https://html.spec.whatwg.org/#attr-video-playsinline}\n */\n'playsinline'].forEach(function (prop) {\n Html5.prototype['set' + toTitleCase(prop)] = function (v) {\n this.el_[prop] = v;\n\n if (v) {\n this.el_.setAttribute(prop, prop);\n } else {\n this.el_.removeAttribute(prop);\n }\n };\n}); // Wrap native properties with a getter\n// The list is as followed\n// paused, currentTime, buffered, volume, poster, preload, error, seeking\n// seekable, ended, playbackRate, defaultPlaybackRate, played, networkState\n// readyState, videoWidth, videoHeight\n\n[\n/**\n * Get the value of `paused` from the media element. `paused` indicates whether the media element\n * is currently paused or not.\n *\n * @method Html5#paused\n * @return {boolean}\n * The value of `paused` from the media element.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-paused}\n */\n'paused',\n/**\n * Get the value of `currentTime` from the media element. `currentTime` indicates\n * the current second that the media is at in playback.\n *\n * @method Html5#currentTime\n * @return {number}\n * The value of `currentTime` from the media element.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-currenttime}\n */\n'currentTime',\n/**\n * Get the value of `buffered` from the media element. `buffered` is a `TimeRange`\n * object that represents the parts of the media that are already downloaded and\n * available for playback.\n *\n * @method Html5#buffered\n * @return {TimeRange}\n * The value of `buffered` from the media element.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-buffered}\n */\n'buffered',\n/**\n * Get the value of `volume` from the media element. `volume` indicates\n * the current playback volume of audio for a media. `volume` will be a value from 0\n * (silent) to 1 (loudest and default).\n *\n * @method Html5#volume\n * @return {number}\n * The value of `volume` from the media element. Value will be between 0-1.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-a-volume}\n */\n'volume',\n/**\n * Get the value of `poster` from the media element. `poster` indicates\n * that the url of an image file that can/will be shown when no media data is available.\n *\n * @method Html5#poster\n * @return {string}\n * The value of `poster` from the media element. Value will be a url to an\n * image.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#attr-video-poster}\n */\n'poster',\n/**\n * Get the value of `preload` from the media element. `preload` indicates\n * what should download before the media is interacted with. It can have the following\n * values:\n * - none: nothing should be downloaded\n * - metadata: poster and the first few frames of the media may be downloaded to get\n * media dimensions and other metadata\n * - auto: allow the media and metadata for the media to be downloaded before\n * interaction\n *\n * @method Html5#preload\n * @return {string}\n * The value of `preload` from the media element. Will be 'none', 'metadata',\n * or 'auto'.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#attr-media-preload}\n */\n'preload',\n/**\n * Get the value of the `error` from the media element. `error` indicates any\n * MediaError that may have occurred during playback. If error returns null there is no\n * current error.\n *\n * @method Html5#error\n * @return {MediaError|null}\n * The value of `error` from the media element. Will be `MediaError` if there\n * is a current error and null otherwise.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-error}\n */\n'error',\n/**\n * Get the value of `seeking` from the media element. `seeking` indicates whether the\n * media is currently seeking to a new position or not.\n *\n * @method Html5#seeking\n * @return {boolean}\n * - The value of `seeking` from the media element.\n * - True indicates that the media is currently seeking to a new position.\n * - False indicates that the media is not seeking to a new position at this time.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-seeking}\n */\n'seeking',\n/**\n * Get the value of `seekable` from the media element. `seekable` returns a\n * `TimeRange` object indicating ranges of time that can currently be `seeked` to.\n *\n * @method Html5#seekable\n * @return {TimeRange}\n * The value of `seekable` from the media element. A `TimeRange` object\n * indicating the current ranges of time that can be seeked to.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-seekable}\n */\n'seekable',\n/**\n * Get the value of `ended` from the media element. `ended` indicates whether\n * the media has reached the end or not.\n *\n * @method Html5#ended\n * @return {boolean}\n * - The value of `ended` from the media element.\n * - True indicates that the media has ended.\n * - False indicates that the media has not ended.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-ended}\n */\n'ended',\n/**\n * Get the value of `playbackRate` from the media element. `playbackRate` indicates\n * the rate at which the media is currently playing back. Examples:\n * - if playbackRate is set to 2, media will play twice as fast.\n * - if playbackRate is set to 0.5, media will play half as fast.\n *\n * @method Html5#playbackRate\n * @return {number}\n * The value of `playbackRate` from the media element. A number indicating\n * the current playback speed of the media, where 1 is normal speed.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-playbackrate}\n */\n'playbackRate',\n/**\n * Get the value of `defaultPlaybackRate` from the media element. `defaultPlaybackRate` indicates\n * the rate at which the media is currently playing back. This value will not indicate the current\n * `playbackRate` after playback has started, use {@link Html5#playbackRate} for that.\n *\n * Examples:\n * - if defaultPlaybackRate is set to 2, media will play twice as fast.\n * - if defaultPlaybackRate is set to 0.5, media will play half as fast.\n *\n * @method Html5.prototype.defaultPlaybackRate\n * @return {number}\n * The value of `defaultPlaybackRate` from the media element. A number indicating\n * the current playback speed of the media, where 1 is normal speed.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-playbackrate}\n */\n'defaultPlaybackRate',\n/**\n * Get the value of `played` from the media element. `played` returns a `TimeRange`\n * object representing points in the media timeline that have been played.\n *\n * @method Html5#played\n * @return {TimeRange}\n * The value of `played` from the media element. A `TimeRange` object indicating\n * the ranges of time that have been played.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-played}\n */\n'played',\n/**\n * Get the value of `networkState` from the media element. `networkState` indicates\n * the current network state. It returns an enumeration from the following list:\n * - 0: NETWORK_EMPTY\n * - 1: NETWORK_IDLE\n * - 2: NETWORK_LOADING\n * - 3: NETWORK_NO_SOURCE\n *\n * @method Html5#networkState\n * @return {number}\n * The value of `networkState` from the media element. This will be a number\n * from the list in the description.\n *\n * @see [Spec] {@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-networkstate}\n */\n'networkState',\n/**\n * Get the value of `readyState` from the media element. `readyState` indicates\n * the current state of the media element. It returns an enumeration from the\n * following list:\n * - 0: HAVE_NOTHING\n * - 1: HAVE_METADATA\n * - 2: HAVE_CURRENT_DATA\n * - 3: HAVE_FUTURE_DATA\n * - 4: HAVE_ENOUGH_DATA\n *\n * @method Html5#readyState\n * @return {number}\n * The value of `readyState` from the media element. This will be a number\n * from the list in the description.\n *\n * @see [Spec] {@link https://www.w3.org/TR/html5/embedded-content-0.html#ready-states}\n */\n'readyState',\n/**\n * Get the value of `videoWidth` from the video element. `videoWidth` indicates\n * the current width of the video in css pixels.\n *\n * @method Html5#videoWidth\n * @return {number}\n * The value of `videoWidth` from the video element. This will be a number\n * in css pixels.\n *\n * @see [Spec] {@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-video-videowidth}\n */\n'videoWidth',\n/**\n * Get the value of `videoHeight` from the video element. `videoHeight` indicates\n * the current height of the video in css pixels.\n *\n * @method Html5#videoHeight\n * @return {number}\n * The value of `videoHeight` from the video element. This will be a number\n * in css pixels.\n *\n * @see [Spec] {@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-video-videowidth}\n */\n'videoHeight'].forEach(function (prop) {\n Html5.prototype[prop] = function () {\n return this.el_[prop];\n };\n}); // Wrap native properties with a setter in this format:\n// set + toTitleCase(name)\n// The list is as follows:\n// setVolume, setSrc, setPoster, setPreload, setPlaybackRate, setDefaultPlaybackRate\n\n[\n/**\n * Set the value of `volume` on the media element. `volume` indicates the current\n * audio level as a percentage in decimal form. This means that 1 is 100%, 0.5 is 50%, and\n * so on.\n *\n * @method Html5#setVolume\n * @param {number} percentAsDecimal\n * The volume percent as a decimal. Valid range is from 0-1.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-a-volume}\n */\n'volume',\n/**\n * Set the value of `src` on the media element. `src` indicates the current\n * {@link Tech~SourceObject} for the media.\n *\n * @method Html5#setSrc\n * @param {Tech~SourceObject} src\n * The source object to set as the current source.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-src}\n */\n'src',\n/**\n * Set the value of `poster` on the media element. `poster` is the url to\n * an image file that can/will be shown when no media data is available.\n *\n * @method Html5#setPoster\n * @param {string} poster\n * The url to an image that should be used as the `poster` for the media\n * element.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#attr-media-poster}\n */\n'poster',\n/**\n * Set the value of `preload` on the media element. `preload` indicates\n * what should download before the media is interacted with. It can have the following\n * values:\n * - none: nothing should be downloaded\n * - metadata: poster and the first few frames of the media may be downloaded to get\n * media dimensions and other metadata\n * - auto: allow the media and metadata for the media to be downloaded before\n * interaction\n *\n * @method Html5#setPreload\n * @param {string} preload\n * The value of `preload` to set on the media element. Must be 'none', 'metadata',\n * or 'auto'.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#attr-media-preload}\n */\n'preload',\n/**\n * Set the value of `playbackRate` on the media element. `playbackRate` indicates\n * the rate at which the media should play back. Examples:\n * - if playbackRate is set to 2, media will play twice as fast.\n * - if playbackRate is set to 0.5, media will play half as fast.\n *\n * @method Html5#setPlaybackRate\n * @return {number}\n * The value of `playbackRate` from the media element. A number indicating\n * the current playback speed of the media, where 1 is normal speed.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-playbackrate}\n */\n'playbackRate',\n/**\n * Set the value of `defaultPlaybackRate` on the media element. `defaultPlaybackRate` indicates\n * the rate at which the media should play back upon initial startup. Changing this value\n * after a video has started will do nothing. Instead you should used {@link Html5#setPlaybackRate}.\n *\n * Example Values:\n * - if playbackRate is set to 2, media will play twice as fast.\n * - if playbackRate is set to 0.5, media will play half as fast.\n *\n * @method Html5.prototype.setDefaultPlaybackRate\n * @return {number}\n * The value of `defaultPlaybackRate` from the media element. A number indicating\n * the current playback speed of the media, where 1 is normal speed.\n *\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-defaultplaybackrate}\n */\n'defaultPlaybackRate'].forEach(function (prop) {\n Html5.prototype['set' + toTitleCase(prop)] = function (v) {\n this.el_[prop] = v;\n };\n}); // wrap native functions with a function\n// The list is as follows:\n// pause, load, play\n\n[\n/**\n * A wrapper around the media elements `pause` function. This will call the `HTML5`\n * media elements `pause` function.\n *\n * @method Html5#pause\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-pause}\n */\n'pause',\n/**\n * A wrapper around the media elements `load` function. This will call the `HTML5`s\n * media element `load` function.\n *\n * @method Html5#load\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-load}\n */\n'load',\n/**\n * A wrapper around the media elements `play` function. This will call the `HTML5`s\n * media element `play` function.\n *\n * @method Html5#play\n * @see [Spec]{@link https://www.w3.org/TR/html5/embedded-content-0.html#dom-media-play}\n */\n'play'].forEach(function (prop) {\n Html5.prototype[prop] = function () {\n return this.el_[prop]();\n };\n});\nTech.withSourceHandlers(Html5);\n/**\n * Native source handler for Html5, simply passes the source to the media element.\n *\n * @property {Tech~SourceObject} source\n * The source object\n *\n * @property {Html5} tech\n * The instance of the HTML5 tech.\n */\n\nHtml5.nativeSourceHandler = {};\n/**\n * Check if the media element can play the given mime type.\n *\n * @param {string} type\n * The mimetype to check\n *\n * @return {string}\n * 'probably', 'maybe', or '' (empty string)\n */\n\nHtml5.nativeSourceHandler.canPlayType = function (type) {\n // IE without MediaPlayer throws an error (#519)\n try {\n return Html5.TEST_VID.canPlayType(type);\n } catch (e) {\n return '';\n }\n};\n/**\n * Check if the media element can handle a source natively.\n *\n * @param {Tech~SourceObject} source\n * The source object\n *\n * @param {Object} [options]\n * Options to be passed to the tech.\n *\n * @return {string}\n * 'probably', 'maybe', or '' (empty string).\n */\n\n\nHtml5.nativeSourceHandler.canHandleSource = function (source, options) {\n // If a type was provided we should rely on that\n if (source.type) {\n return Html5.nativeSourceHandler.canPlayType(source.type); // If no type, fall back to checking 'video/[EXTENSION]'\n } else if (source.src) {\n var ext = getFileExtension(source.src);\n return Html5.nativeSourceHandler.canPlayType(\"video/\" + ext);\n }\n\n return '';\n};\n/**\n * Pass the source to the native media element.\n *\n * @param {Tech~SourceObject} source\n * The source object\n *\n * @param {Html5} tech\n * The instance of the Html5 tech\n *\n * @param {Object} [options]\n * The options to pass to the source\n */\n\n\nHtml5.nativeSourceHandler.handleSource = function (source, tech, options) {\n tech.setSrc(source.src);\n};\n/**\n * A noop for the native dispose function, as cleanup is not needed.\n */\n\n\nHtml5.nativeSourceHandler.dispose = function () {}; // Register the native source handler\n\n\nHtml5.registerSourceHandler(Html5.nativeSourceHandler);\nTech.registerTech('Html5', Html5);\n\nfunction _templateObject$2() {\n var data = _taggedTemplateLiteralLoose([\"\\n Using the tech directly can be dangerous. I hope you know what you're doing.\\n See https://github.com/videojs/video.js/issues/2617 for more info.\\n \"]);\n\n _templateObject$2 = function _templateObject() {\n return data;\n };\n\n return data;\n}\n// on the player when they happen\n\nvar TECH_EVENTS_RETRIGGER = [\n/**\n * Fired while the user agent is downloading media data.\n *\n * @event Player#progress\n * @type {EventTarget~Event}\n */\n\n/**\n * Retrigger the `progress` event that was triggered by the {@link Tech}.\n *\n * @private\n * @method Player#handleTechProgress_\n * @fires Player#progress\n * @listens Tech#progress\n */\n'progress',\n/**\n * Fires when the loading of an audio/video is aborted.\n *\n * @event Player#abort\n * @type {EventTarget~Event}\n */\n\n/**\n * Retrigger the `abort` event that was triggered by the {@link Tech}.\n *\n * @private\n * @method Player#handleTechAbort_\n * @fires Player#abort\n * @listens Tech#abort\n */\n'abort',\n/**\n * Fires when the browser is intentionally not getting media data.\n *\n * @event Player#suspend\n * @type {EventTarget~Event}\n */\n\n/**\n * Retrigger the `suspend` event that was triggered by the {@link Tech}.\n *\n * @private\n * @method Player#handleTechSuspend_\n * @fires Player#suspend\n * @listens Tech#suspend\n */\n'suspend',\n/**\n * Fires when the current playlist is empty.\n *\n * @event Player#emptied\n * @type {EventTarget~Event}\n */\n\n/**\n * Retrigger the `emptied` event that was triggered by the {@link Tech}.\n *\n * @private\n * @method Player#handleTechEmptied_\n * @fires Player#emptied\n * @listens Tech#emptied\n */\n'emptied',\n/**\n * Fires when the browser is trying to get media data, but data is not available.\n *\n * @event Player#stalled\n * @type {EventTarget~Event}\n */\n\n/**\n * Retrigger the `stalled` event that was triggered by the {@link Tech}.\n *\n * @private\n * @method Player#handleTechStalled_\n * @fires Player#stalled\n * @listens Tech#stalled\n */\n'stalled',\n/**\n * Fires when the browser has loaded meta data for the audio/video.\n *\n * @event Player#loadedmetadata\n * @type {EventTarget~Event}\n */\n\n/**\n * Retrigger the `stalled` event that was triggered by the {@link Tech}.\n *\n * @private\n * @method Player#handleTechLoadedmetadata_\n * @fires Player#loadedmetadata\n * @listens Tech#loadedmetadata\n */\n'loadedmetadata',\n/**\n * Fires when the browser has loaded the current frame of the audio/video.\n *\n * @event Player#loadeddata\n * @type {event}\n */\n\n/**\n * Retrigger the `loadeddata` event that was triggered by the {@link Tech}.\n *\n * @private\n * @method Player#handleTechLoaddeddata_\n * @fires Player#loadeddata\n * @listens Tech#loadeddata\n */\n'loadeddata',\n/**\n * Fires when the current playback position has changed.\n *\n * @event Player#timeupdate\n * @type {event}\n */\n\n/**\n * Retrigger the `timeupdate` event that was triggered by the {@link Tech}.\n *\n * @private\n * @method Player#handleTechTimeUpdate_\n * @fires Player#timeupdate\n * @listens Tech#timeupdate\n */\n'timeupdate',\n/**\n * Fires when the video's intrinsic dimensions change\n *\n * @event Player#resize\n * @type {event}\n */\n\n/**\n * Retrigger the `resize` event that was triggered by the {@link Tech}.\n *\n * @private\n * @method Player#handleTechResize_\n * @fires Player#resize\n * @listens Tech#resize\n */\n'resize',\n/**\n * Fires when the volume has been changed\n *\n * @event Player#volumechange\n * @type {event}\n */\n\n/**\n * Retrigger the `volumechange` event that was triggered by the {@link Tech}.\n *\n * @private\n * @method Player#handleTechVolumechange_\n * @fires Player#volumechange\n * @listens Tech#volumechange\n */\n'volumechange',\n/**\n * Fires when the text track has been changed\n *\n * @event Player#texttrackchange\n * @type {event}\n */\n\n/**\n * Retrigger the `texttrackchange` event that was triggered by the {@link Tech}.\n *\n * @private\n * @method Player#handleTechTexttrackchange_\n * @fires Player#texttrackchange\n * @listens Tech#texttrackchange\n */\n'texttrackchange']; // events to queue when playback rate is zero\n// this is a hash for the sole purpose of mapping non-camel-cased event names\n// to camel-cased function names\n\nvar TECH_EVENTS_QUEUE = {\n canplay: 'CanPlay',\n canplaythrough: 'CanPlayThrough',\n playing: 'Playing',\n seeked: 'Seeked'\n};\nvar BREAKPOINT_ORDER = ['tiny', 'xsmall', 'small', 'medium', 'large', 'xlarge', 'huge'];\nvar BREAKPOINT_CLASSES = {}; // grep: vjs-layout-tiny\n// grep: vjs-layout-x-small\n// grep: vjs-layout-small\n// grep: vjs-layout-medium\n// grep: vjs-layout-large\n// grep: vjs-layout-x-large\n// grep: vjs-layout-huge\n\nBREAKPOINT_ORDER.forEach(function (k) {\n var v = k.charAt(0) === 'x' ? \"x-\" + k.substring(1) : k;\n BREAKPOINT_CLASSES[k] = \"vjs-layout-\" + v;\n});\nvar DEFAULT_BREAKPOINTS = {\n tiny: 210,\n xsmall: 320,\n small: 425,\n medium: 768,\n large: 1440,\n xlarge: 2560,\n huge: Infinity\n};\n/**\n * An instance of the `Player` class is created when any of the Video.js setup methods\n * are used to initialize a video.\n *\n * After an instance has been created it can be accessed globally in two ways:\n * 1. By calling `videojs('example_video_1');`\n * 2. By using it directly via `videojs.players.example_video_1;`\n *\n * @extends Component\n */\n\nvar Player =\n/*#__PURE__*/\nfunction (_Component) {\n _inheritsLoose(Player, _Component);\n\n /**\n * Create an instance of this class.\n *\n * @param {Element} tag\n * The original video DOM element used for configuring options.\n *\n * @param {Object} [options]\n * Object of option names and values.\n *\n * @param {Component~ReadyCallback} [ready]\n * Ready callback function.\n */\n function Player(tag, options, ready) {\n var _this;\n\n // Make sure tag ID exists\n tag.id = tag.id || options.id || \"vjs_video_\" + newGUID(); // Set Options\n // The options argument overrides options set in the video tag\n // which overrides globally set options.\n // This latter part coincides with the load order\n // (tag must exist before Player)\n\n options = assign(Player.getTagSettings(tag), options); // Delay the initialization of children because we need to set up\n // player properties first, and can't use `this` before `super()`\n\n options.initChildren = false; // Same with creating the element\n\n options.createEl = false; // don't auto mixin the evented mixin\n\n options.evented = false; // we don't want the player to report touch activity on itself\n // see enableTouchActivity in Component\n\n options.reportTouchActivity = false; // If language is not set, get the closest lang attribute\n\n if (!options.language) {\n if (typeof tag.closest === 'function') {\n var closest = tag.closest('[lang]');\n\n if (closest && closest.getAttribute) {\n options.language = closest.getAttribute('lang');\n }\n } else {\n var element = tag;\n\n while (element && element.nodeType === 1) {\n if (getAttributes(element).hasOwnProperty('lang')) {\n options.language = element.getAttribute('lang');\n break;\n }\n\n element = element.parentNode;\n }\n }\n } // Run base component initializing with new options\n\n\n _this = _Component.call(this, null, options, ready) || this; // create logger\n\n _this.log = createLogger$1(_this.id_); // Tracks when a tech changes the poster\n\n _this.isPosterFromTech_ = false; // Holds callback info that gets queued when playback rate is zero\n // and a seek is happening\n\n _this.queuedCallbacks_ = []; // Turn off API access because we're loading a new tech that might load asynchronously\n\n _this.isReady_ = false; // Init state hasStarted_\n\n _this.hasStarted_ = false; // Init state userActive_\n\n _this.userActive_ = false; // if the global option object was accidentally blown away by\n // someone, bail early with an informative error\n\n if (!_this.options_ || !_this.options_.techOrder || !_this.options_.techOrder.length) {\n throw new Error('No techOrder specified. Did you overwrite ' + 'videojs.options instead of just changing the ' + 'properties you want to override?');\n } // Store the original tag used to set options\n\n\n _this.tag = tag; // Store the tag attributes used to restore html5 element\n\n _this.tagAttributes = tag && getAttributes(tag); // Update current language\n\n _this.language(_this.options_.language); // Update Supported Languages\n\n\n if (options.languages) {\n // Normalise player option languages to lowercase\n var languagesToLower = {};\n Object.getOwnPropertyNames(options.languages).forEach(function (name$$1) {\n languagesToLower[name$$1.toLowerCase()] = options.languages[name$$1];\n });\n _this.languages_ = languagesToLower;\n } else {\n _this.languages_ = Player.prototype.options_.languages;\n } // Cache for video property values.\n\n\n _this.cache_ = {}; // Set poster\n\n _this.poster_ = options.poster || ''; // Set controls\n\n _this.controls_ = !!options.controls; // Set default values for lastVolume\n\n _this.cache_.lastVolume = 1; // Original tag settings stored in options\n // now remove immediately so native controls don't flash.\n // May be turned back on by HTML5 tech if nativeControlsForTouch is true\n\n tag.controls = false;\n tag.removeAttribute('controls'); // the attribute overrides the option\n\n if (tag.hasAttribute('autoplay')) {\n _this.options_.autoplay = true;\n } else {\n // otherwise use the setter to validate and\n // set the correct value.\n _this.autoplay(_this.options_.autoplay);\n }\n /*\n * Store the internal state of scrubbing\n *\n * @private\n * @return {Boolean} True if the user is scrubbing\n */\n\n\n _this.scrubbing_ = false;\n _this.el_ = _this.createEl(); // Set default value for lastPlaybackRate\n\n _this.cache_.lastPlaybackRate = _this.defaultPlaybackRate(); // Make this an evented object and use `el_` as its event bus.\n\n evented(_assertThisInitialized(_assertThisInitialized(_this)), {\n eventBusKey: 'el_'\n });\n\n if (_this.fluid_) {\n _this.on('playerreset', _this.updateStyleEl_);\n } // We also want to pass the original player options to each component and plugin\n // as well so they don't need to reach back into the player for options later.\n // We also need to do another copy of this.options_ so we don't end up with\n // an infinite loop.\n\n\n var playerOptionsCopy = mergeOptions(_this.options_); // Load plugins\n\n if (options.plugins) {\n var plugins = options.plugins;\n Object.keys(plugins).forEach(function (name$$1) {\n if (typeof this[name$$1] === 'function') {\n this[name$$1](plugins[name$$1]);\n } else {\n throw new Error(\"plugin \\\"\" + name$$1 + \"\\\" does not exist\");\n }\n }, _assertThisInitialized(_assertThisInitialized(_this)));\n }\n\n _this.options_.playerOptions = playerOptionsCopy;\n _this.middleware_ = [];\n\n _this.initChildren(); // Set isAudio based on whether or not an audio tag was used\n\n\n _this.isAudio(tag.nodeName.toLowerCase() === 'audio'); // Update controls className. Can't do this when the controls are initially\n // set because the element doesn't exist yet.\n\n\n if (_this.controls()) {\n _this.addClass('vjs-controls-enabled');\n } else {\n _this.addClass('vjs-controls-disabled');\n } // Set ARIA label and region role depending on player type\n\n\n _this.el_.setAttribute('role', 'region');\n\n if (_this.isAudio()) {\n _this.el_.setAttribute('aria-label', _this.localize('Audio Player'));\n } else {\n _this.el_.setAttribute('aria-label', _this.localize('Video Player'));\n }\n\n if (_this.isAudio()) {\n _this.addClass('vjs-audio');\n }\n\n if (_this.flexNotSupported_()) {\n _this.addClass('vjs-no-flex');\n } // TODO: Make this smarter. Toggle user state between touching/mousing\n // using events, since devices can have both touch and mouse events.\n // if (browser.TOUCH_ENABLED) {\n // this.addClass('vjs-touch-enabled');\n // }\n // iOS Safari has broken hover handling\n\n\n if (!IS_IOS) {\n _this.addClass('vjs-workinghover');\n } // Make player easily findable by ID\n\n\n Player.players[_this.id_] = _assertThisInitialized(_assertThisInitialized(_this)); // Add a major version class to aid css in plugins\n\n var majorVersion = version.split('.')[0];\n\n _this.addClass(\"vjs-v\" + majorVersion); // When the player is first initialized, trigger activity so components\n // like the control bar show themselves if needed\n\n\n _this.userActive(true);\n\n _this.reportUserActivity();\n\n _this.one('play', _this.listenForUserActivity_);\n\n _this.on('fullscreenchange', _this.handleFullscreenChange_);\n\n _this.on('stageclick', _this.handleStageClick_);\n\n _this.breakpoints(_this.options_.breakpoints);\n\n _this.responsive(_this.options_.responsive);\n\n _this.changingSrc_ = false;\n _this.playWaitingForReady_ = false;\n _this.playOnLoadstart_ = null;\n return _this;\n }\n /**\n * Destroys the video player and does any necessary cleanup.\n *\n * This is especially helpful if you are dynamically adding and removing videos\n * to/from the DOM.\n *\n * @fires Player#dispose\n */\n\n\n var _proto = Player.prototype;\n\n _proto.dispose = function dispose() {\n /**\n * Called when the player is being disposed of.\n *\n * @event Player#dispose\n * @type {EventTarget~Event}\n */\n this.trigger('dispose'); // prevent dispose from being called twice\n\n this.off('dispose');\n\n if (this.styleEl_ && this.styleEl_.parentNode) {\n this.styleEl_.parentNode.removeChild(this.styleEl_);\n this.styleEl_ = null;\n } // Kill reference to this player\n\n\n Player.players[this.id_] = null;\n\n if (this.tag && this.tag.player) {\n this.tag.player = null;\n }\n\n if (this.el_ && this.el_.player) {\n this.el_.player = null;\n }\n\n if (this.tech_) {\n this.tech_.dispose();\n this.isPosterFromTech_ = false;\n this.poster_ = '';\n }\n\n if (this.playerElIngest_) {\n this.playerElIngest_ = null;\n }\n\n if (this.tag) {\n this.tag = null;\n }\n\n clearCacheForPlayer(this); // the actual .el_ is removed here\n\n _Component.prototype.dispose.call(this);\n };\n /**\n * Create the `Player`'s DOM element.\n *\n * @return {Element}\n * The DOM element that gets created.\n */\n\n\n _proto.createEl = function createEl$$1() {\n var tag = this.tag;\n var el;\n var playerElIngest = this.playerElIngest_ = tag.parentNode && tag.parentNode.hasAttribute && tag.parentNode.hasAttribute('data-vjs-player');\n var divEmbed = this.tag.tagName.toLowerCase() === 'video-js';\n\n if (playerElIngest) {\n el = this.el_ = tag.parentNode;\n } else if (!divEmbed) {\n el = this.el_ = _Component.prototype.createEl.call(this, 'div');\n } // Copy over all the attributes from the tag, including ID and class\n // ID will now reference player box, not the video tag\n\n\n var attrs = getAttributes(tag);\n\n if (divEmbed) {\n el = this.el_ = tag;\n tag = this.tag = document.createElement('video');\n\n while (el.children.length) {\n tag.appendChild(el.firstChild);\n }\n\n if (!hasClass(el, 'video-js')) {\n addClass(el, 'video-js');\n }\n\n el.appendChild(tag);\n playerElIngest = this.playerElIngest_ = el; // move properties over from our custom `video-js` element\n // to our new `video` element. This will move things like\n // `src` or `controls` that were set via js before the player\n // was initialized.\n\n Object.keys(el).forEach(function (k) {\n tag[k] = el[k];\n });\n } // set tabindex to -1 to remove the video element from the focus order\n\n\n tag.setAttribute('tabindex', '-1');\n attrs.tabindex = '-1'; // Workaround for #4583 (JAWS+IE doesn't announce BPB or play button)\n // See https://github.com/FreedomScientific/VFO-standards-support/issues/78\n // Note that we can't detect if JAWS is being used, but this ARIA attribute\n // doesn't change behavior of IE11 if JAWS is not being used\n\n if (IE_VERSION) {\n tag.setAttribute('role', 'application');\n attrs.role = 'application';\n } // Remove width/height attrs from tag so CSS can make it 100% width/height\n\n\n tag.removeAttribute('width');\n tag.removeAttribute('height');\n\n if ('width' in attrs) {\n delete attrs.width;\n }\n\n if ('height' in attrs) {\n delete attrs.height;\n }\n\n Object.getOwnPropertyNames(attrs).forEach(function (attr) {\n // don't copy over the class attribute to the player element when we're in a div embed\n // the class is already set up properly in the divEmbed case\n // and we want to make sure that the `video-js` class doesn't get lost\n if (!(divEmbed && attr === 'class')) {\n el.setAttribute(attr, attrs[attr]);\n }\n\n if (divEmbed) {\n tag.setAttribute(attr, attrs[attr]);\n }\n }); // Update tag id/class for use as HTML5 playback tech\n // Might think we should do this after embedding in container so .vjs-tech class\n // doesn't flash 100% width/height, but class only applies with .video-js parent\n\n tag.playerId = tag.id;\n tag.id += '_html5_api';\n tag.className = 'vjs-tech'; // Make player findable on elements\n\n tag.player = el.player = this; // Default state of video is paused\n\n this.addClass('vjs-paused'); // Add a style element in the player that we'll use to set the width/height\n // of the player in a way that's still overrideable by CSS, just like the\n // video element\n\n if (window$1.VIDEOJS_NO_DYNAMIC_STYLE !== true) {\n this.styleEl_ = createStyleElement('vjs-styles-dimensions');\n var defaultsStyleEl = $('.vjs-styles-defaults');\n var head = $('head');\n head.insertBefore(this.styleEl_, defaultsStyleEl ? defaultsStyleEl.nextSibling : head.firstChild);\n }\n\n this.fill_ = false;\n this.fluid_ = false; // Pass in the width/height/aspectRatio options which will update the style el\n\n this.width(this.options_.width);\n this.height(this.options_.height);\n this.fill(this.options_.fill);\n this.fluid(this.options_.fluid);\n this.aspectRatio(this.options_.aspectRatio); // Hide any links within the video/audio tag,\n // because IE doesn't hide them completely from screen readers.\n\n var links = tag.getElementsByTagName('a');\n\n for (var i = 0; i < links.length; i++) {\n var linkEl = links.item(i);\n addClass(linkEl, 'vjs-hidden');\n linkEl.setAttribute('hidden', 'hidden');\n } // insertElFirst seems to cause the networkState to flicker from 3 to 2, so\n // keep track of the original for later so we can know if the source originally failed\n\n\n tag.initNetworkState_ = tag.networkState; // Wrap video tag in div (el/box) container\n\n if (tag.parentNode && !playerElIngest) {\n tag.parentNode.insertBefore(el, tag);\n } // insert the tag as the first child of the player element\n // then manually add it to the children array so that this.addChild\n // will work properly for other components\n //\n // Breaks iPhone, fixed in HTML5 setup.\n\n\n prependTo(tag, el);\n this.children_.unshift(tag); // Set lang attr on player to ensure CSS :lang() in consistent with player\n // if it's been set to something different to the doc\n\n this.el_.setAttribute('lang', this.language_);\n this.el_ = el;\n return el;\n };\n /**\n * A getter/setter for the `Player`'s width. Returns the player's configured value.\n * To get the current width use `currentWidth()`.\n *\n * @param {number} [value]\n * The value to set the `Player`'s width to.\n *\n * @return {number}\n * The current width of the `Player` when getting.\n */\n\n\n _proto.width = function width(value) {\n return this.dimension('width', value);\n };\n /**\n * A getter/setter for the `Player`'s height. Returns the player's configured value.\n * To get the current height use `currentheight()`.\n *\n * @param {number} [value]\n * The value to set the `Player`'s heigth to.\n *\n * @return {number}\n * The current height of the `Player` when getting.\n */\n\n\n _proto.height = function height(value) {\n return this.dimension('height', value);\n };\n /**\n * A getter/setter for the `Player`'s width & height.\n *\n * @param {string} dimension\n * This string can be:\n * - 'width'\n * - 'height'\n *\n * @param {number} [value]\n * Value for dimension specified in the first argument.\n *\n * @return {number}\n * The dimension arguments value when getting (width/height).\n */\n\n\n _proto.dimension = function dimension(_dimension, value) {\n var privDimension = _dimension + '_';\n\n if (value === undefined) {\n return this[privDimension] || 0;\n }\n\n if (value === '') {\n // If an empty string is given, reset the dimension to be automatic\n this[privDimension] = undefined;\n this.updateStyleEl_();\n return;\n }\n\n var parsedVal = parseFloat(value);\n\n if (isNaN(parsedVal)) {\n log.error(\"Improper value \\\"\" + value + \"\\\" supplied for for \" + _dimension);\n return;\n }\n\n this[privDimension] = parsedVal;\n this.updateStyleEl_();\n };\n /**\n * A getter/setter/toggler for the vjs-fluid `className` on the `Player`.\n *\n * Turning this on will turn off fill mode.\n *\n * @param {boolean} [bool]\n * - A value of true adds the class.\n * - A value of false removes the class.\n * - No value will be a getter.\n *\n * @return {boolean|undefined}\n * - The value of fluid when getting.\n * - `undefined` when setting.\n */\n\n\n _proto.fluid = function fluid(bool) {\n if (bool === undefined) {\n return !!this.fluid_;\n }\n\n this.fluid_ = !!bool;\n\n if (isEvented(this)) {\n this.off('playerreset', this.updateStyleEl_);\n }\n\n if (bool) {\n this.addClass('vjs-fluid');\n this.fill(false);\n addEventedCallback(function () {\n this.on('playerreset', this.updateStyleEl_);\n });\n } else {\n this.removeClass('vjs-fluid');\n }\n\n this.updateStyleEl_();\n };\n /**\n * A getter/setter/toggler for the vjs-fill `className` on the `Player`.\n *\n * Turning this on will turn off fluid mode.\n *\n * @param {boolean} [bool]\n * - A value of true adds the class.\n * - A value of false removes the class.\n * - No value will be a getter.\n *\n * @return {boolean|undefined}\n * - The value of fluid when getting.\n * - `undefined` when setting.\n */\n\n\n _proto.fill = function fill(bool) {\n if (bool === undefined) {\n return !!this.fill_;\n }\n\n this.fill_ = !!bool;\n\n if (bool) {\n this.addClass('vjs-fill');\n this.fluid(false);\n } else {\n this.removeClass('vjs-fill');\n }\n };\n /**\n * Get/Set the aspect ratio\n *\n * @param {string} [ratio]\n * Aspect ratio for player\n *\n * @return {string|undefined}\n * returns the current aspect ratio when getting\n */\n\n /**\n * A getter/setter for the `Player`'s aspect ratio.\n *\n * @param {string} [ratio]\n * The value to set the `Player's aspect ratio to.\n *\n * @return {string|undefined}\n * - The current aspect ratio of the `Player` when getting.\n * - undefined when setting\n */\n\n\n _proto.aspectRatio = function aspectRatio(ratio) {\n if (ratio === undefined) {\n return this.aspectRatio_;\n } // Check for width:height format\n\n\n if (!/^\\d+\\:\\d+$/.test(ratio)) {\n throw new Error('Improper value supplied for aspect ratio. The format should be width:height, for example 16:9.');\n }\n\n this.aspectRatio_ = ratio; // We're assuming if you set an aspect ratio you want fluid mode,\n // because in fixed mode you could calculate width and height yourself.\n\n this.fluid(true);\n this.updateStyleEl_();\n };\n /**\n * Update styles of the `Player` element (height, width and aspect ratio).\n *\n * @private\n * @listens Tech#loadedmetadata\n */\n\n\n _proto.updateStyleEl_ = function updateStyleEl_() {\n if (window$1.VIDEOJS_NO_DYNAMIC_STYLE === true) {\n var _width = typeof this.width_ === 'number' ? this.width_ : this.options_.width;\n\n var _height = typeof this.height_ === 'number' ? this.height_ : this.options_.height;\n\n var techEl = this.tech_ && this.tech_.el();\n\n if (techEl) {\n if (_width >= 0) {\n techEl.width = _width;\n }\n\n if (_height >= 0) {\n techEl.height = _height;\n }\n }\n\n return;\n }\n\n var width;\n var height;\n var aspectRatio;\n var idClass; // The aspect ratio is either used directly or to calculate width and height.\n\n if (this.aspectRatio_ !== undefined && this.aspectRatio_ !== 'auto') {\n // Use any aspectRatio that's been specifically set\n aspectRatio = this.aspectRatio_;\n } else if (this.videoWidth() > 0) {\n // Otherwise try to get the aspect ratio from the video metadata\n aspectRatio = this.videoWidth() + ':' + this.videoHeight();\n } else {\n // Or use a default. The video element's is 2:1, but 16:9 is more common.\n aspectRatio = '16:9';\n } // Get the ratio as a decimal we can use to calculate dimensions\n\n\n var ratioParts = aspectRatio.split(':');\n var ratioMultiplier = ratioParts[1] / ratioParts[0];\n\n if (this.width_ !== undefined) {\n // Use any width that's been specifically set\n width = this.width_;\n } else if (this.height_ !== undefined) {\n // Or calulate the width from the aspect ratio if a height has been set\n width = this.height_ / ratioMultiplier;\n } else {\n // Or use the video's metadata, or use the video el's default of 300\n width = this.videoWidth() || 300;\n }\n\n if (this.height_ !== undefined) {\n // Use any height that's been specifically set\n height = this.height_;\n } else {\n // Otherwise calculate the height from the ratio and the width\n height = width * ratioMultiplier;\n } // Ensure the CSS class is valid by starting with an alpha character\n\n\n if (/^[^a-zA-Z]/.test(this.id())) {\n idClass = 'dimensions-' + this.id();\n } else {\n idClass = this.id() + '-dimensions';\n } // Ensure the right class is still on the player for the style element\n\n\n this.addClass(idClass);\n setTextContent(this.styleEl_, \"\\n .\" + idClass + \" {\\n width: \" + width + \"px;\\n height: \" + height + \"px;\\n }\\n\\n .\" + idClass + \".vjs-fluid {\\n padding-top: \" + ratioMultiplier * 100 + \"%;\\n }\\n \");\n };\n /**\n * Load/Create an instance of playback {@link Tech} including element\n * and API methods. Then append the `Tech` element in `Player` as a child.\n *\n * @param {string} techName\n * name of the playback technology\n *\n * @param {string} source\n * video source\n *\n * @private\n */\n\n\n _proto.loadTech_ = function loadTech_(techName, source) {\n var _this2 = this;\n\n // Pause and remove current playback technology\n if (this.tech_) {\n this.unloadTech_();\n }\n\n var titleTechName = toTitleCase(techName);\n var camelTechName = techName.charAt(0).toLowerCase() + techName.slice(1); // get rid of the HTML5 video tag as soon as we are using another tech\n\n if (titleTechName !== 'Html5' && this.tag) {\n Tech.getTech('Html5').disposeMediaElement(this.tag);\n this.tag.player = null;\n this.tag = null;\n }\n\n this.techName_ = titleTechName; // Turn off API access because we're loading a new tech that might load asynchronously\n\n this.isReady_ = false; // if autoplay is a string we pass false to the tech\n // because the player is going to handle autoplay on `loadstart`\n\n var autoplay = typeof this.autoplay() === 'string' ? false : this.autoplay(); // Grab tech-specific options from player options and add source and parent element to use.\n\n var techOptions = {\n source: source,\n autoplay: autoplay,\n 'nativeControlsForTouch': this.options_.nativeControlsForTouch,\n 'playerId': this.id(),\n 'techId': this.id() + \"_\" + camelTechName + \"_api\",\n 'playsinline': this.options_.playsinline,\n 'preload': this.options_.preload,\n 'loop': this.options_.loop,\n 'muted': this.options_.muted,\n 'poster': this.poster(),\n 'language': this.language(),\n 'playerElIngest': this.playerElIngest_ || false,\n 'vtt.js': this.options_['vtt.js'],\n 'canOverridePoster': !!this.options_.techCanOverridePoster,\n 'enableSourceset': this.options_.enableSourceset\n };\n ALL.names.forEach(function (name$$1) {\n var props = ALL[name$$1];\n techOptions[props.getterName] = _this2[props.privateName];\n });\n assign(techOptions, this.options_[titleTechName]);\n assign(techOptions, this.options_[camelTechName]);\n assign(techOptions, this.options_[techName.toLowerCase()]);\n\n if (this.tag) {\n techOptions.tag = this.tag;\n }\n\n if (source && source.src === this.cache_.src && this.cache_.currentTime > 0) {\n techOptions.startTime = this.cache_.currentTime;\n } // Initialize tech instance\n\n\n var TechClass = Tech.getTech(techName);\n\n if (!TechClass) {\n throw new Error(\"No Tech named '\" + titleTechName + \"' exists! '\" + titleTechName + \"' should be registered using videojs.registerTech()'\");\n }\n\n this.tech_ = new TechClass(techOptions); // player.triggerReady is always async, so don't need this to be async\n\n this.tech_.ready(bind(this, this.handleTechReady_), true);\n textTrackConverter.jsonToTextTracks(this.textTracksJson_ || [], this.tech_); // Listen to all HTML5-defined events and trigger them on the player\n\n TECH_EVENTS_RETRIGGER.forEach(function (event) {\n _this2.on(_this2.tech_, event, _this2[\"handleTech\" + toTitleCase(event) + \"_\"]);\n });\n Object.keys(TECH_EVENTS_QUEUE).forEach(function (event) {\n _this2.on(_this2.tech_, event, function (eventObj) {\n if (_this2.tech_.playbackRate() === 0 && _this2.tech_.seeking()) {\n _this2.queuedCallbacks_.push({\n callback: _this2[\"handleTech\" + TECH_EVENTS_QUEUE[event] + \"_\"].bind(_this2),\n event: eventObj\n });\n\n return;\n }\n\n _this2[\"handleTech\" + TECH_EVENTS_QUEUE[event] + \"_\"](eventObj);\n });\n });\n this.on(this.tech_, 'loadstart', this.handleTechLoadStart_);\n this.on(this.tech_, 'sourceset', this.handleTechSourceset_);\n this.on(this.tech_, 'waiting', this.handleTechWaiting_);\n this.on(this.tech_, 'ended', this.handleTechEnded_);\n this.on(this.tech_, 'seeking', this.handleTechSeeking_);\n this.on(this.tech_, 'play', this.handleTechPlay_);\n this.on(this.tech_, 'firstplay', this.handleTechFirstPlay_);\n this.on(this.tech_, 'pause', this.handleTechPause_);\n this.on(this.tech_, 'durationchange', this.handleTechDurationChange_);\n this.on(this.tech_, 'fullscreenchange', this.handleTechFullscreenChange_);\n this.on(this.tech_, 'error', this.handleTechError_);\n this.on(this.tech_, 'loadedmetadata', this.updateStyleEl_);\n this.on(this.tech_, 'posterchange', this.handleTechPosterChange_);\n this.on(this.tech_, 'textdata', this.handleTechTextData_);\n this.on(this.tech_, 'ratechange', this.handleTechRateChange_);\n this.usingNativeControls(this.techGet_('controls'));\n\n if (this.controls() && !this.usingNativeControls()) {\n this.addTechControlsListeners_();\n } // Add the tech element in the DOM if it was not already there\n // Make sure to not insert the original video element if using Html5\n\n\n if (this.tech_.el().parentNode !== this.el() && (titleTechName !== 'Html5' || !this.tag)) {\n prependTo(this.tech_.el(), this.el());\n } // Get rid of the original video tag reference after the first tech is loaded\n\n\n if (this.tag) {\n this.tag.player = null;\n this.tag = null;\n }\n };\n /**\n * Unload and dispose of the current playback {@link Tech}.\n *\n * @private\n */\n\n\n _proto.unloadTech_ = function unloadTech_() {\n var _this3 = this;\n\n // Save the current text tracks so that we can reuse the same text tracks with the next tech\n ALL.names.forEach(function (name$$1) {\n var props = ALL[name$$1];\n _this3[props.privateName] = _this3[props.getterName]();\n });\n this.textTracksJson_ = textTrackConverter.textTracksToJson(this.tech_);\n this.isReady_ = false;\n this.tech_.dispose();\n this.tech_ = false;\n\n if (this.isPosterFromTech_) {\n this.poster_ = '';\n this.trigger('posterchange');\n }\n\n this.isPosterFromTech_ = false;\n };\n /**\n * Return a reference to the current {@link Tech}.\n * It will print a warning by default about the danger of using the tech directly\n * but any argument that is passed in will silence the warning.\n *\n * @param {*} [safety]\n * Anything passed in to silence the warning\n *\n * @return {Tech}\n * The Tech\n */\n\n\n _proto.tech = function tech(safety) {\n if (safety === undefined) {\n log.warn(tsml(_templateObject$2()));\n }\n\n return this.tech_;\n };\n /**\n * Set up click and touch listeners for the playback element\n *\n * - On desktops: a click on the video itself will toggle playback\n * - On mobile devices: a click on the video toggles controls\n * which is done by toggling the user state between active and\n * inactive\n * - A tap can signal that a user has become active or has become inactive\n * e.g. a quick tap on an iPhone movie should reveal the controls. Another\n * quick tap should hide them again (signaling the user is in an inactive\n * viewing state)\n * - In addition to this, we still want the user to be considered inactive after\n * a few seconds of inactivity.\n *\n * > Note: the only part of iOS interaction we can't mimic with this setup\n * is a touch and hold on the video element counting as activity in order to\n * keep the controls showing, but that shouldn't be an issue. A touch and hold\n * on any controls will still keep the user active\n *\n * @private\n */\n\n\n _proto.addTechControlsListeners_ = function addTechControlsListeners_() {\n // Make sure to remove all the previous listeners in case we are called multiple times.\n this.removeTechControlsListeners_(); // Some browsers (Chrome & IE) don't trigger a click on a flash swf, but do\n // trigger mousedown/up.\n // http://stackoverflow.com/questions/1444562/javascript-onclick-event-over-flash-object\n // Any touch events are set to block the mousedown event from happening\n\n this.on(this.tech_, 'mousedown', this.handleTechClick_);\n this.on(this.tech_, 'dblclick', this.handleTechDoubleClick_); // If the controls were hidden we don't want that to change without a tap event\n // so we'll check if the controls were already showing before reporting user\n // activity\n\n this.on(this.tech_, 'touchstart', this.handleTechTouchStart_);\n this.on(this.tech_, 'touchmove', this.handleTechTouchMove_);\n this.on(this.tech_, 'touchend', this.handleTechTouchEnd_); // The tap listener needs to come after the touchend listener because the tap\n // listener cancels out any reportedUserActivity when setting userActive(false)\n\n this.on(this.tech_, 'tap', this.handleTechTap_);\n };\n /**\n * Remove the listeners used for click and tap controls. This is needed for\n * toggling to controls disabled, where a tap/touch should do nothing.\n *\n * @private\n */\n\n\n _proto.removeTechControlsListeners_ = function removeTechControlsListeners_() {\n // We don't want to just use `this.off()` because there might be other needed\n // listeners added by techs that extend this.\n this.off(this.tech_, 'tap', this.handleTechTap_);\n this.off(this.tech_, 'touchstart', this.handleTechTouchStart_);\n this.off(this.tech_, 'touchmove', this.handleTechTouchMove_);\n this.off(this.tech_, 'touchend', this.handleTechTouchEnd_);\n this.off(this.tech_, 'mousedown', this.handleTechClick_);\n this.off(this.tech_, 'dblclick', this.handleTechDoubleClick_);\n };\n /**\n * Player waits for the tech to be ready\n *\n * @private\n */\n\n\n _proto.handleTechReady_ = function handleTechReady_() {\n this.triggerReady(); // Keep the same volume as before\n\n if (this.cache_.volume) {\n this.techCall_('setVolume', this.cache_.volume);\n } // Look if the tech found a higher resolution poster while loading\n\n\n this.handleTechPosterChange_(); // Update the duration if available\n\n this.handleTechDurationChange_();\n };\n /**\n * Retrigger the `loadstart` event that was triggered by the {@link Tech}. This\n * function will also trigger {@link Player#firstplay} if it is the first loadstart\n * for a video.\n *\n * @fires Player#loadstart\n * @fires Player#firstplay\n * @listens Tech#loadstart\n * @private\n */\n\n\n _proto.handleTechLoadStart_ = function handleTechLoadStart_() {\n // TODO: Update to use `emptied` event instead. See #1277.\n this.removeClass('vjs-ended');\n this.removeClass('vjs-seeking'); // reset the error state\n\n this.error(null); // Update the duration\n\n this.handleTechDurationChange_(); // If it's already playing we want to trigger a firstplay event now.\n // The firstplay event relies on both the play and loadstart events\n // which can happen in any order for a new source\n\n if (!this.paused()) {\n /**\n * Fired when the user agent begins looking for media data\n *\n * @event Player#loadstart\n * @type {EventTarget~Event}\n */\n this.trigger('loadstart');\n this.trigger('firstplay');\n } else {\n // reset the hasStarted state\n this.hasStarted(false);\n this.trigger('loadstart');\n } // autoplay happens after loadstart for the browser,\n // so we mimic that behavior\n\n\n this.manualAutoplay_(this.autoplay());\n };\n /**\n * Handle autoplay string values, rather than the typical boolean\n * values that should be handled by the tech. Note that this is not\n * part of any specification. Valid values and what they do can be\n * found on the autoplay getter at Player#autoplay()\n */\n\n\n _proto.manualAutoplay_ = function manualAutoplay_(type) {\n var _this4 = this;\n\n if (!this.tech_ || typeof type !== 'string') {\n return;\n }\n\n var muted = function muted() {\n var previouslyMuted = _this4.muted();\n\n _this4.muted(true);\n\n var playPromise = _this4.play();\n\n if (!playPromise || !playPromise.then || !playPromise.catch) {\n return;\n }\n\n return playPromise.catch(function (e) {\n // restore old value of muted on failure\n _this4.muted(previouslyMuted);\n });\n };\n\n var promise;\n\n if (type === 'any') {\n promise = this.play();\n\n if (promise && promise.then && promise.catch) {\n promise.catch(function () {\n return muted();\n });\n }\n } else if (type === 'muted') {\n promise = muted();\n } else {\n promise = this.play();\n }\n\n if (!promise || !promise.then || !promise.catch) {\n return;\n }\n\n return promise.then(function () {\n _this4.trigger({\n type: 'autoplay-success',\n autoplay: type\n });\n }).catch(function (e) {\n _this4.trigger({\n type: 'autoplay-failure',\n autoplay: type\n });\n });\n };\n /**\n * Update the internal source caches so that we return the correct source from\n * `src()`, `currentSource()`, and `currentSources()`.\n *\n * > Note: `currentSources` will not be updated if the source that is passed in exists\n * in the current `currentSources` cache.\n *\n *\n * @param {Tech~SourceObject} srcObj\n * A string or object source to update our caches to.\n */\n\n\n _proto.updateSourceCaches_ = function updateSourceCaches_(srcObj) {\n if (srcObj === void 0) {\n srcObj = '';\n }\n\n var src = srcObj;\n var type = '';\n\n if (typeof src !== 'string') {\n src = srcObj.src;\n type = srcObj.type;\n } // make sure all the caches are set to default values\n // to prevent null checking\n\n\n this.cache_.source = this.cache_.source || {};\n this.cache_.sources = this.cache_.sources || []; // try to get the type of the src that was passed in\n\n if (src && !type) {\n type = findMimetype(this, src);\n } // update `currentSource` cache always\n\n\n this.cache_.source = mergeOptions({}, srcObj, {\n src: src,\n type: type\n });\n var matchingSources = this.cache_.sources.filter(function (s) {\n return s.src && s.src === src;\n });\n var sourceElSources = [];\n var sourceEls = this.$$('source');\n var matchingSourceEls = [];\n\n for (var i = 0; i < sourceEls.length; i++) {\n var sourceObj = getAttributes(sourceEls[i]);\n sourceElSources.push(sourceObj);\n\n if (sourceObj.src && sourceObj.src === src) {\n matchingSourceEls.push(sourceObj.src);\n }\n } // if we have matching source els but not matching sources\n // the current source cache is not up to date\n\n\n if (matchingSourceEls.length && !matchingSources.length) {\n this.cache_.sources = sourceElSources; // if we don't have matching source or source els set the\n // sources cache to the `currentSource` cache\n } else if (!matchingSources.length) {\n this.cache_.sources = [this.cache_.source];\n } // update the tech `src` cache\n\n\n this.cache_.src = src;\n };\n /**\n * *EXPERIMENTAL* Fired when the source is set or changed on the {@link Tech}\n * causing the media element to reload.\n *\n * It will fire for the initial source and each subsequent source.\n * This event is a custom event from Video.js and is triggered by the {@link Tech}.\n *\n * The event object for this event contains a `src` property that will contain the source\n * that was available when the event was triggered. This is generally only necessary if Video.js\n * is switching techs while the source was being changed.\n *\n * It is also fired when `load` is called on the player (or media element)\n * because the {@link https://html.spec.whatwg.org/multipage/media.html#dom-media-load|specification for `load`}\n * says that the resource selection algorithm needs to be aborted and restarted.\n * In this case, it is very likely that the `src` property will be set to the\n * empty string `\"\"` to indicate we do not know what the source will be but\n * that it is changing.\n *\n * *This event is currently still experimental and may change in minor releases.*\n * __To use this, pass `enableSourceset` option to the player.__\n *\n * @event Player#sourceset\n * @type {EventTarget~Event}\n * @prop {string} src\n * The source url available when the `sourceset` was triggered.\n * It will be an empty string if we cannot know what the source is\n * but know that the source will change.\n */\n\n /**\n * Retrigger the `sourceset` event that was triggered by the {@link Tech}.\n *\n * @fires Player#sourceset\n * @listens Tech#sourceset\n * @private\n */\n\n\n _proto.handleTechSourceset_ = function handleTechSourceset_(event) {\n var _this5 = this;\n\n // only update the source cache when the source\n // was not updated using the player api\n if (!this.changingSrc_) {\n var updateSourceCaches = function updateSourceCaches(src) {\n return _this5.updateSourceCaches_(src);\n };\n\n var playerSrc = this.currentSource().src;\n var eventSrc = event.src; // if we have a playerSrc that is not a blob, and a tech src that is a blob\n\n if (playerSrc && !/^blob:/.test(playerSrc) && /^blob:/.test(eventSrc)) {\n // if both the tech source and the player source were updated we assume\n // something like @videojs/http-streaming did the sourceset and skip updating the source cache.\n if (!this.lastSource_ || this.lastSource_.tech !== eventSrc && this.lastSource_.player !== playerSrc) {\n updateSourceCaches = function updateSourceCaches() {};\n }\n } // update the source to the intial source right away\n // in some cases this will be empty string\n\n\n updateSourceCaches(eventSrc); // if the `sourceset` `src` was an empty string\n // wait for a `loadstart` to update the cache to `currentSrc`.\n // If a sourceset happens before a `loadstart`, we reset the state\n // as this function will be called again.\n\n if (!event.src) {\n var updateCache = function updateCache(e) {\n if (e.type !== 'sourceset') {\n var techSrc = _this5.techGet('currentSrc');\n\n _this5.lastSource_.tech = techSrc;\n\n _this5.updateSourceCaches_(techSrc);\n }\n\n _this5.tech_.off(['sourceset', 'loadstart'], updateCache);\n };\n\n this.tech_.one(['sourceset', 'loadstart'], updateCache);\n }\n }\n\n this.lastSource_ = {\n player: this.currentSource().src,\n tech: event.src\n };\n this.trigger({\n src: event.src,\n type: 'sourceset'\n });\n };\n /**\n * Add/remove the vjs-has-started class\n *\n * @fires Player#firstplay\n *\n * @param {boolean} request\n * - true: adds the class\n * - false: remove the class\n *\n * @return {boolean}\n * the boolean value of hasStarted_\n */\n\n\n _proto.hasStarted = function hasStarted(request) {\n if (request === undefined) {\n // act as getter, if we have no request to change\n return this.hasStarted_;\n }\n\n if (request === this.hasStarted_) {\n return;\n }\n\n this.hasStarted_ = request;\n\n if (this.hasStarted_) {\n this.addClass('vjs-has-started');\n this.trigger('firstplay');\n } else {\n this.removeClass('vjs-has-started');\n }\n };\n /**\n * Fired whenever the media begins or resumes playback\n *\n * @see [Spec]{@link https://html.spec.whatwg.org/multipage/embedded-content.html#dom-media-play}\n * @fires Player#play\n * @listens Tech#play\n * @private\n */\n\n\n _proto.handleTechPlay_ = function handleTechPlay_() {\n this.removeClass('vjs-ended');\n this.removeClass('vjs-paused');\n this.addClass('vjs-playing'); // hide the poster when the user hits play\n\n this.hasStarted(true);\n /**\n * Triggered whenever an {@link Tech#play} event happens. Indicates that\n * playback has started or resumed.\n *\n * @event Player#play\n * @type {EventTarget~Event}\n */\n\n this.trigger('play');\n };\n /**\n * Retrigger the `ratechange` event that was triggered by the {@link Tech}.\n *\n * If there were any events queued while the playback rate was zero, fire\n * those events now.\n *\n * @private\n * @method Player#handleTechRateChange_\n * @fires Player#ratechange\n * @listens Tech#ratechange\n */\n\n\n _proto.handleTechRateChange_ = function handleTechRateChange_() {\n if (this.tech_.playbackRate() > 0 && this.cache_.lastPlaybackRate === 0) {\n this.queuedCallbacks_.forEach(function (queued) {\n return queued.callback(queued.event);\n });\n this.queuedCallbacks_ = [];\n }\n\n this.cache_.lastPlaybackRate = this.tech_.playbackRate();\n /**\n * Fires when the playing speed of the audio/video is changed\n *\n * @event Player#ratechange\n * @type {event}\n */\n\n this.trigger('ratechange');\n };\n /**\n * Retrigger the `waiting` event that was triggered by the {@link Tech}.\n *\n * @fires Player#waiting\n * @listens Tech#waiting\n * @private\n */\n\n\n _proto.handleTechWaiting_ = function handleTechWaiting_() {\n var _this6 = this;\n\n this.addClass('vjs-waiting');\n /**\n * A readyState change on the DOM element has caused playback to stop.\n *\n * @event Player#waiting\n * @type {EventTarget~Event}\n */\n\n this.trigger('waiting'); // Browsers may emit a timeupdate event after a waiting event. In order to prevent\n // premature removal of the waiting class, wait for the time to change.\n\n var timeWhenWaiting = this.currentTime();\n\n var timeUpdateListener = function timeUpdateListener() {\n if (timeWhenWaiting !== _this6.currentTime()) {\n _this6.removeClass('vjs-waiting');\n\n _this6.off('timeupdate', timeUpdateListener);\n }\n };\n\n this.on('timeupdate', timeUpdateListener);\n };\n /**\n * Retrigger the `canplay` event that was triggered by the {@link Tech}.\n * > Note: This is not consistent between browsers. See #1351\n *\n * @fires Player#canplay\n * @listens Tech#canplay\n * @private\n */\n\n\n _proto.handleTechCanPlay_ = function handleTechCanPlay_() {\n this.removeClass('vjs-waiting');\n /**\n * The media has a readyState of HAVE_FUTURE_DATA or greater.\n *\n * @event Player#canplay\n * @type {EventTarget~Event}\n */\n\n this.trigger('canplay');\n };\n /**\n * Retrigger the `canplaythrough` event that was triggered by the {@link Tech}.\n *\n * @fires Player#canplaythrough\n * @listens Tech#canplaythrough\n * @private\n */\n\n\n _proto.handleTechCanPlayThrough_ = function handleTechCanPlayThrough_() {\n this.removeClass('vjs-waiting');\n /**\n * The media has a readyState of HAVE_ENOUGH_DATA or greater. This means that the\n * entire media file can be played without buffering.\n *\n * @event Player#canplaythrough\n * @type {EventTarget~Event}\n */\n\n this.trigger('canplaythrough');\n };\n /**\n * Retrigger the `playing` event that was triggered by the {@link Tech}.\n *\n * @fires Player#playing\n * @listens Tech#playing\n * @private\n */\n\n\n _proto.handleTechPlaying_ = function handleTechPlaying_() {\n this.removeClass('vjs-waiting');\n /**\n * The media is no longer blocked from playback, and has started playing.\n *\n * @event Player#playing\n * @type {EventTarget~Event}\n */\n\n this.trigger('playing');\n };\n /**\n * Retrigger the `seeking` event that was triggered by the {@link Tech}.\n *\n * @fires Player#seeking\n * @listens Tech#seeking\n * @private\n */\n\n\n _proto.handleTechSeeking_ = function handleTechSeeking_() {\n this.addClass('vjs-seeking');\n /**\n * Fired whenever the player is jumping to a new time\n *\n * @event Player#seeking\n * @type {EventTarget~Event}\n */\n\n this.trigger('seeking');\n };\n /**\n * Retrigger the `seeked` event that was triggered by the {@link Tech}.\n *\n * @fires Player#seeked\n * @listens Tech#seeked\n * @private\n */\n\n\n _proto.handleTechSeeked_ = function handleTechSeeked_() {\n this.removeClass('vjs-seeking');\n /**\n * Fired when the player has finished jumping to a new time\n *\n * @event Player#seeked\n * @type {EventTarget~Event}\n */\n\n this.trigger('seeked');\n };\n /**\n * Retrigger the `firstplay` event that was triggered by the {@link Tech}.\n *\n * @fires Player#firstplay\n * @listens Tech#firstplay\n * @deprecated As of 6.0 firstplay event is deprecated.\n * As of 6.0 passing the `starttime` option to the player and the firstplay event are deprecated.\n * @private\n */\n\n\n _proto.handleTechFirstPlay_ = function handleTechFirstPlay_() {\n // If the first starttime attribute is specified\n // then we will start at the given offset in seconds\n if (this.options_.starttime) {\n log.warn('Passing the `starttime` option to the player will be deprecated in 6.0');\n this.currentTime(this.options_.starttime);\n }\n\n this.addClass('vjs-has-started');\n /**\n * Fired the first time a video is played. Not part of the HLS spec, and this is\n * probably not the best implementation yet, so use sparingly. If you don't have a\n * reason to prevent playback, use `myPlayer.one('play');` instead.\n *\n * @event Player#firstplay\n * @deprecated As of 6.0 firstplay event is deprecated.\n * @type {EventTarget~Event}\n */\n\n this.trigger('firstplay');\n };\n /**\n * Retrigger the `pause` event that was triggered by the {@link Tech}.\n *\n * @fires Player#pause\n * @listens Tech#pause\n * @private\n */\n\n\n _proto.handleTechPause_ = function handleTechPause_() {\n this.removeClass('vjs-playing');\n this.addClass('vjs-paused');\n /**\n * Fired whenever the media has been paused\n *\n * @event Player#pause\n * @type {EventTarget~Event}\n */\n\n this.trigger('pause');\n };\n /**\n * Retrigger the `ended` event that was triggered by the {@link Tech}.\n *\n * @fires Player#ended\n * @listens Tech#ended\n * @private\n */\n\n\n _proto.handleTechEnded_ = function handleTechEnded_() {\n this.addClass('vjs-ended');\n\n if (this.options_.loop) {\n this.currentTime(0);\n this.play();\n } else if (!this.paused()) {\n this.pause();\n }\n /**\n * Fired when the end of the media resource is reached (currentTime == duration)\n *\n * @event Player#ended\n * @type {EventTarget~Event}\n */\n\n\n this.trigger('ended');\n };\n /**\n * Fired when the duration of the media resource is first known or changed\n *\n * @listens Tech#durationchange\n * @private\n */\n\n\n _proto.handleTechDurationChange_ = function handleTechDurationChange_() {\n this.duration(this.techGet_('duration'));\n };\n /**\n * Handle a click on the media element to play/pause\n *\n * @param {EventTarget~Event} event\n * the event that caused this function to trigger\n *\n * @listens Tech#mousedown\n * @private\n */\n\n\n _proto.handleTechClick_ = function handleTechClick_(event) {\n if (!isSingleLeftClick(event)) {\n return;\n } // When controls are disabled a click should not toggle playback because\n // the click is considered a control\n\n\n if (!this.controls_) {\n return;\n }\n\n if (this.paused()) {\n silencePromise(this.play());\n } else {\n this.pause();\n }\n };\n /**\n * Handle a double-click on the media element to enter/exit fullscreen\n *\n * @param {EventTarget~Event} event\n * the event that caused this function to trigger\n *\n * @listens Tech#dblclick\n * @private\n */\n\n\n _proto.handleTechDoubleClick_ = function handleTechDoubleClick_(event) {\n if (!this.controls_) {\n return;\n } // we do not want to toggle fullscreen state\n // when double-clicking inside a control bar or a modal\n\n\n var inAllowedEls = Array.prototype.some.call(this.$$('.vjs-control-bar, .vjs-modal-dialog'), function (el) {\n return el.contains(event.target);\n });\n\n if (!inAllowedEls) {\n if (this.isFullscreen()) {\n this.exitFullscreen();\n } else {\n this.requestFullscreen();\n }\n }\n };\n /**\n * Handle a tap on the media element. It will toggle the user\n * activity state, which hides and shows the controls.\n *\n * @listens Tech#tap\n * @private\n */\n\n\n _proto.handleTechTap_ = function handleTechTap_() {\n this.userActive(!this.userActive());\n };\n /**\n * Handle touch to start\n *\n * @listens Tech#touchstart\n * @private\n */\n\n\n _proto.handleTechTouchStart_ = function handleTechTouchStart_() {\n this.userWasActive = this.userActive();\n };\n /**\n * Handle touch to move\n *\n * @listens Tech#touchmove\n * @private\n */\n\n\n _proto.handleTechTouchMove_ = function handleTechTouchMove_() {\n if (this.userWasActive) {\n this.reportUserActivity();\n }\n };\n /**\n * Handle touch to end\n *\n * @param {EventTarget~Event} event\n * the touchend event that triggered\n * this function\n *\n * @listens Tech#touchend\n * @private\n */\n\n\n _proto.handleTechTouchEnd_ = function handleTechTouchEnd_(event) {\n // Stop the mouse events from also happening\n event.preventDefault();\n };\n /**\n * Fired when the player switches in or out of fullscreen mode\n *\n * @private\n * @listens Player#fullscreenchange\n */\n\n\n _proto.handleFullscreenChange_ = function handleFullscreenChange_() {\n if (this.isFullscreen()) {\n this.addClass('vjs-fullscreen');\n } else {\n this.removeClass('vjs-fullscreen');\n }\n };\n /**\n * native click events on the SWF aren't triggered on IE11, Win8.1RT\n * use stageclick events triggered from inside the SWF instead\n *\n * @private\n * @listens stageclick\n */\n\n\n _proto.handleStageClick_ = function handleStageClick_() {\n this.reportUserActivity();\n };\n /**\n * Handle Tech Fullscreen Change\n *\n * @param {EventTarget~Event} event\n * the fullscreenchange event that triggered this function\n *\n * @param {Object} data\n * the data that was sent with the event\n *\n * @private\n * @listens Tech#fullscreenchange\n * @fires Player#fullscreenchange\n */\n\n\n _proto.handleTechFullscreenChange_ = function handleTechFullscreenChange_(event, data) {\n if (data) {\n this.isFullscreen(data.isFullscreen);\n }\n /**\n * Fired when going in and out of fullscreen.\n *\n * @event Player#fullscreenchange\n * @type {EventTarget~Event}\n */\n\n\n this.trigger('fullscreenchange');\n };\n /**\n * Fires when an error occurred during the loading of an audio/video.\n *\n * @private\n * @listens Tech#error\n */\n\n\n _proto.handleTechError_ = function handleTechError_() {\n var error = this.tech_.error();\n this.error(error);\n };\n /**\n * Retrigger the `textdata` event that was triggered by the {@link Tech}.\n *\n * @fires Player#textdata\n * @listens Tech#textdata\n * @private\n */\n\n\n _proto.handleTechTextData_ = function handleTechTextData_() {\n var data = null;\n\n if (arguments.length > 1) {\n data = arguments[1];\n }\n /**\n * Fires when we get a textdata event from tech\n *\n * @event Player#textdata\n * @type {EventTarget~Event}\n */\n\n\n this.trigger('textdata', data);\n };\n /**\n * Get object for cached values.\n *\n * @return {Object}\n * get the current object cache\n */\n\n\n _proto.getCache = function getCache() {\n return this.cache_;\n };\n /**\n * Pass values to the playback tech\n *\n * @param {string} [method]\n * the method to call\n *\n * @param {Object} arg\n * the argument to pass\n *\n * @private\n */\n\n\n _proto.techCall_ = function techCall_(method, arg) {\n // If it's not ready yet, call method when it is\n this.ready(function () {\n if (method in allowedSetters) {\n return set$1(this.middleware_, this.tech_, method, arg);\n } else if (method in allowedMediators) {\n return mediate(this.middleware_, this.tech_, method, arg);\n }\n\n try {\n if (this.tech_) {\n this.tech_[method](arg);\n }\n } catch (e) {\n log(e);\n throw e;\n }\n }, true);\n };\n /**\n * Get calls can't wait for the tech, and sometimes don't need to.\n *\n * @param {string} method\n * Tech method\n *\n * @return {Function|undefined}\n * the method or undefined\n *\n * @private\n */\n\n\n _proto.techGet_ = function techGet_(method) {\n if (!this.tech_ || !this.tech_.isReady_) {\n return;\n }\n\n if (method in allowedGetters) {\n return get(this.middleware_, this.tech_, method);\n } else if (method in allowedMediators) {\n return mediate(this.middleware_, this.tech_, method);\n } // Flash likes to die and reload when you hide or reposition it.\n // In these cases the object methods go away and we get errors.\n // When that happens we'll catch the errors and inform tech that it's not ready any more.\n\n\n try {\n return this.tech_[method]();\n } catch (e) {\n // When building additional tech libs, an expected method may not be defined yet\n if (this.tech_[method] === undefined) {\n log(\"Video.js: \" + method + \" method not defined for \" + this.techName_ + \" playback technology.\", e);\n throw e;\n } // When a method isn't available on the object it throws a TypeError\n\n\n if (e.name === 'TypeError') {\n log(\"Video.js: \" + method + \" unavailable on \" + this.techName_ + \" playback technology element.\", e);\n this.tech_.isReady_ = false;\n throw e;\n } // If error unknown, just log and throw\n\n\n log(e);\n throw e;\n }\n };\n /**\n * Attempt to begin playback at the first opportunity.\n *\n * @return {Promise|undefined}\n * Returns a promise if the browser supports Promises (or one\n * was passed in as an option). This promise will be resolved on\n * the return value of play. If this is undefined it will fulfill the\n * promise chain otherwise the promise chain will be fulfilled when\n * the promise from play is fulfilled.\n */\n\n\n _proto.play = function play() {\n var _this7 = this;\n\n var PromiseClass = this.options_.Promise || window$1.Promise;\n\n if (PromiseClass) {\n return new PromiseClass(function (resolve) {\n _this7.play_(resolve);\n });\n }\n\n return this.play_();\n };\n /**\n * The actual logic for play, takes a callback that will be resolved on the\n * return value of play. This allows us to resolve to the play promise if there\n * is one on modern browsers.\n *\n * @private\n * @param {Function} [callback]\n * The callback that should be called when the techs play is actually called\n */\n\n\n _proto.play_ = function play_(callback) {\n var _this8 = this;\n\n if (callback === void 0) {\n callback = silencePromise;\n }\n\n // If this is called while we have a play queued up on a loadstart, remove\n // that listener to avoid getting in a potentially bad state.\n if (this.playOnLoadstart_) {\n this.off('loadstart', this.playOnLoadstart_);\n } // If the player/tech is not ready, queue up another call to `play()` for\n // when it is. This will loop back into this method for another attempt at\n // playback when the tech is ready.\n\n\n if (!this.isReady_) {\n // Bail out if we're already waiting for `ready`!\n if (this.playWaitingForReady_) {\n return;\n }\n\n this.playWaitingForReady_ = true;\n this.ready(function () {\n _this8.playWaitingForReady_ = false;\n callback(_this8.play());\n }); // If the player/tech is ready and we have a source, we can attempt playback.\n } else if (!this.changingSrc_ && (this.src() || this.currentSrc())) {\n callback(this.techGet_('play'));\n return; // If the tech is ready, but we do not have a source, we'll need to wait\n // for both the `ready` and a `loadstart` when the source is finally\n // resolved by middleware and set on the player.\n //\n // This can happen if `play()` is called while changing sources or before\n // one has been set on the player.\n } else {\n this.playOnLoadstart_ = function () {\n _this8.playOnLoadstart_ = null;\n callback(_this8.play());\n };\n\n this.one('loadstart', this.playOnLoadstart_);\n }\n };\n /**\n * Pause the video playback\n *\n * @return {Player}\n * A reference to the player object this function was called on\n */\n\n\n _proto.pause = function pause() {\n this.techCall_('pause');\n };\n /**\n * Check if the player is paused or has yet to play\n *\n * @return {boolean}\n * - false: if the media is currently playing\n * - true: if media is not currently playing\n */\n\n\n _proto.paused = function paused() {\n // The initial state of paused should be true (in Safari it's actually false)\n return this.techGet_('paused') === false ? false : true;\n };\n /**\n * Get a TimeRange object representing the current ranges of time that the user\n * has played.\n *\n * @return {TimeRange}\n * A time range object that represents all the increments of time that have\n * been played.\n */\n\n\n _proto.played = function played() {\n return this.techGet_('played') || createTimeRanges(0, 0);\n };\n /**\n * Returns whether or not the user is \"scrubbing\". Scrubbing is\n * when the user has clicked the progress bar handle and is\n * dragging it along the progress bar.\n *\n * @param {boolean} [isScrubbing]\n * whether the user is or is not scrubbing\n *\n * @return {boolean}\n * The value of scrubbing when getting\n */\n\n\n _proto.scrubbing = function scrubbing(isScrubbing) {\n if (typeof isScrubbing === 'undefined') {\n return this.scrubbing_;\n }\n\n this.scrubbing_ = !!isScrubbing;\n\n if (isScrubbing) {\n this.addClass('vjs-scrubbing');\n } else {\n this.removeClass('vjs-scrubbing');\n }\n };\n /**\n * Get or set the current time (in seconds)\n *\n * @param {number|string} [seconds]\n * The time to seek to in seconds\n *\n * @return {number}\n * - the current time in seconds when getting\n */\n\n\n _proto.currentTime = function currentTime(seconds) {\n if (typeof seconds !== 'undefined') {\n if (seconds < 0) {\n seconds = 0;\n }\n\n this.techCall_('setCurrentTime', seconds);\n return;\n } // cache last currentTime and return. default to 0 seconds\n //\n // Caching the currentTime is meant to prevent a massive amount of reads on the tech's\n // currentTime when scrubbing, but may not provide much performance benefit afterall.\n // Should be tested. Also something has to read the actual current time or the cache will\n // never get updated.\n\n\n this.cache_.currentTime = this.techGet_('currentTime') || 0;\n return this.cache_.currentTime;\n };\n /**\n * Normally gets the length in time of the video in seconds;\n * in all but the rarest use cases an argument will NOT be passed to the method\n *\n * > **NOTE**: The video must have started loading before the duration can be\n * known, and in the case of Flash, may not be known until the video starts\n * playing.\n *\n * @fires Player#durationchange\n *\n * @param {number} [seconds]\n * The duration of the video to set in seconds\n *\n * @return {number}\n * - The duration of the video in seconds when getting\n */\n\n\n _proto.duration = function duration(seconds) {\n if (seconds === undefined) {\n // return NaN if the duration is not known\n return this.cache_.duration !== undefined ? this.cache_.duration : NaN;\n }\n\n seconds = parseFloat(seconds); // Standardize on Infinity for signaling video is live\n\n if (seconds < 0) {\n seconds = Infinity;\n }\n\n if (seconds !== this.cache_.duration) {\n // Cache the last set value for optimized scrubbing (esp. Flash)\n this.cache_.duration = seconds;\n\n if (seconds === Infinity) {\n this.addClass('vjs-live');\n\n if (this.options_.liveui && this.player_.liveTracker) {\n this.addClass('vjs-liveui');\n }\n } else {\n this.removeClass('vjs-live');\n this.removeClass('vjs-liveui');\n }\n\n if (!isNaN(seconds)) {\n // Do not fire durationchange unless the duration value is known.\n // @see [Spec]{@link https://www.w3.org/TR/2011/WD-html5-20110113/video.html#media-element-load-algorithm}\n\n /**\n * @event Player#durationchange\n * @type {EventTarget~Event}\n */\n this.trigger('durationchange');\n }\n }\n };\n /**\n * Calculates how much time is left in the video. Not part\n * of the native video API.\n *\n * @return {number}\n * The time remaining in seconds\n */\n\n\n _proto.remainingTime = function remainingTime() {\n return this.duration() - this.currentTime();\n };\n /**\n * A remaining time function that is intented to be used when\n * the time is to be displayed directly to the user.\n *\n * @return {number}\n * The rounded time remaining in seconds\n */\n\n\n _proto.remainingTimeDisplay = function remainingTimeDisplay() {\n return Math.floor(this.duration()) - Math.floor(this.currentTime());\n }; //\n // Kind of like an array of portions of the video that have been downloaded.\n\n /**\n * Get a TimeRange object with an array of the times of the video\n * that have been downloaded. If you just want the percent of the\n * video that's been downloaded, use bufferedPercent.\n *\n * @see [Buffered Spec]{@link http://dev.w3.org/html5/spec/video.html#dom-media-buffered}\n *\n * @return {TimeRange}\n * A mock TimeRange object (following HTML spec)\n */\n\n\n _proto.buffered = function buffered() {\n var buffered = this.techGet_('buffered');\n\n if (!buffered || !buffered.length) {\n buffered = createTimeRanges(0, 0);\n }\n\n return buffered;\n };\n /**\n * Get the percent (as a decimal) of the video that's been downloaded.\n * This method is not a part of the native HTML video API.\n *\n * @return {number}\n * A decimal between 0 and 1 representing the percent\n * that is buffered 0 being 0% and 1 being 100%\n */\n\n\n _proto.bufferedPercent = function bufferedPercent$$1() {\n return bufferedPercent(this.buffered(), this.duration());\n };\n /**\n * Get the ending time of the last buffered time range\n * This is used in the progress bar to encapsulate all time ranges.\n *\n * @return {number}\n * The end of the last buffered time range\n */\n\n\n _proto.bufferedEnd = function bufferedEnd() {\n var buffered = this.buffered();\n var duration = this.duration();\n var end = buffered.end(buffered.length - 1);\n\n if (end > duration) {\n end = duration;\n }\n\n return end;\n };\n /**\n * Get or set the current volume of the media\n *\n * @param {number} [percentAsDecimal]\n * The new volume as a decimal percent:\n * - 0 is muted/0%/off\n * - 1.0 is 100%/full\n * - 0.5 is half volume or 50%\n *\n * @return {number}\n * The current volume as a percent when getting\n */\n\n\n _proto.volume = function volume(percentAsDecimal) {\n var vol;\n\n if (percentAsDecimal !== undefined) {\n // Force value to between 0 and 1\n vol = Math.max(0, Math.min(1, parseFloat(percentAsDecimal)));\n this.cache_.volume = vol;\n this.techCall_('setVolume', vol);\n\n if (vol > 0) {\n this.lastVolume_(vol);\n }\n\n return;\n } // Default to 1 when returning current volume.\n\n\n vol = parseFloat(this.techGet_('volume'));\n return isNaN(vol) ? 1 : vol;\n };\n /**\n * Get the current muted state, or turn mute on or off\n *\n * @param {boolean} [muted]\n * - true to mute\n * - false to unmute\n *\n * @return {boolean}\n * - true if mute is on and getting\n * - false if mute is off and getting\n */\n\n\n _proto.muted = function muted(_muted) {\n if (_muted !== undefined) {\n this.techCall_('setMuted', _muted);\n return;\n }\n\n return this.techGet_('muted') || false;\n };\n /**\n * Get the current defaultMuted state, or turn defaultMuted on or off. defaultMuted\n * indicates the state of muted on initial playback.\n *\n * ```js\n * var myPlayer = videojs('some-player-id');\n *\n * myPlayer.src(\"http://www.example.com/path/to/video.mp4\");\n *\n * // get, should be false\n * console.log(myPlayer.defaultMuted());\n * // set to true\n * myPlayer.defaultMuted(true);\n * // get should be true\n * console.log(myPlayer.defaultMuted());\n * ```\n *\n * @param {boolean} [defaultMuted]\n * - true to mute\n * - false to unmute\n *\n * @return {boolean|Player}\n * - true if defaultMuted is on and getting\n * - false if defaultMuted is off and getting\n * - A reference to the current player when setting\n */\n\n\n _proto.defaultMuted = function defaultMuted(_defaultMuted) {\n if (_defaultMuted !== undefined) {\n return this.techCall_('setDefaultMuted', _defaultMuted);\n }\n\n return this.techGet_('defaultMuted') || false;\n };\n /**\n * Get the last volume, or set it\n *\n * @param {number} [percentAsDecimal]\n * The new last volume as a decimal percent:\n * - 0 is muted/0%/off\n * - 1.0 is 100%/full\n * - 0.5 is half volume or 50%\n *\n * @return {number}\n * the current value of lastVolume as a percent when getting\n *\n * @private\n */\n\n\n _proto.lastVolume_ = function lastVolume_(percentAsDecimal) {\n if (percentAsDecimal !== undefined && percentAsDecimal !== 0) {\n this.cache_.lastVolume = percentAsDecimal;\n return;\n }\n\n return this.cache_.lastVolume;\n };\n /**\n * Check if current tech can support native fullscreen\n * (e.g. with built in controls like iOS, so not our flash swf)\n *\n * @return {boolean}\n * if native fullscreen is supported\n */\n\n\n _proto.supportsFullScreen = function supportsFullScreen() {\n return this.techGet_('supportsFullScreen') || false;\n };\n /**\n * Check if the player is in fullscreen mode or tell the player that it\n * is or is not in fullscreen mode.\n *\n * > NOTE: As of the latest HTML5 spec, isFullscreen is no longer an official\n * property and instead document.fullscreenElement is used. But isFullscreen is\n * still a valuable property for internal player workings.\n *\n * @param {boolean} [isFS]\n * Set the players current fullscreen state\n *\n * @return {boolean}\n * - true if fullscreen is on and getting\n * - false if fullscreen is off and getting\n */\n\n\n _proto.isFullscreen = function isFullscreen(isFS) {\n if (isFS !== undefined) {\n this.isFullscreen_ = !!isFS;\n return;\n }\n\n return !!this.isFullscreen_;\n };\n /**\n * Increase the size of the video to full screen\n * In some browsers, full screen is not supported natively, so it enters\n * \"full window mode\", where the video fills the browser window.\n * In browsers and devices that support native full screen, sometimes the\n * browser's default controls will be shown, and not the Video.js custom skin.\n * This includes most mobile devices (iOS, Android) and older versions of\n * Safari.\n *\n * @fires Player#fullscreenchange\n */\n\n\n _proto.requestFullscreen = function requestFullscreen() {\n var fsApi = FullscreenApi;\n this.isFullscreen(true);\n\n if (fsApi.requestFullscreen) {\n // the browser supports going fullscreen at the element level so we can\n // take the controls fullscreen as well as the video\n // Trigger fullscreenchange event after change\n // We have to specifically add this each time, and remove\n // when canceling fullscreen. Otherwise if there's multiple\n // players on a page, they would all be reacting to the same fullscreen\n // events\n on(document, fsApi.fullscreenchange, bind(this, function documentFullscreenChange(e) {\n this.isFullscreen(document[fsApi.fullscreenElement]); // If cancelling fullscreen, remove event listener.\n\n if (this.isFullscreen() === false) {\n off(document, fsApi.fullscreenchange, documentFullscreenChange);\n }\n /**\n * @event Player#fullscreenchange\n * @type {EventTarget~Event}\n */\n\n\n this.trigger('fullscreenchange');\n }));\n this.el_[fsApi.requestFullscreen]();\n } else if (this.tech_.supportsFullScreen()) {\n // we can't take the video.js controls fullscreen but we can go fullscreen\n // with native controls\n this.techCall_('enterFullScreen');\n } else {\n // fullscreen isn't supported so we'll just stretch the video element to\n // fill the viewport\n this.enterFullWindow();\n /**\n * @event Player#fullscreenchange\n * @type {EventTarget~Event}\n */\n\n this.trigger('fullscreenchange');\n }\n };\n /**\n * Return the video to its normal size after having been in full screen mode\n *\n * @fires Player#fullscreenchange\n */\n\n\n _proto.exitFullscreen = function exitFullscreen() {\n var fsApi = FullscreenApi;\n this.isFullscreen(false); // Check for browser element fullscreen support\n\n if (fsApi.requestFullscreen) {\n document[fsApi.exitFullscreen]();\n } else if (this.tech_.supportsFullScreen()) {\n this.techCall_('exitFullScreen');\n } else {\n this.exitFullWindow();\n /**\n * @event Player#fullscreenchange\n * @type {EventTarget~Event}\n */\n\n this.trigger('fullscreenchange');\n }\n };\n /**\n * When fullscreen isn't supported we can stretch the\n * video container to as wide as the browser will let us.\n *\n * @fires Player#enterFullWindow\n */\n\n\n _proto.enterFullWindow = function enterFullWindow() {\n this.isFullWindow = true; // Storing original doc overflow value to return to when fullscreen is off\n\n this.docOrigOverflow = document.documentElement.style.overflow; // Add listener for esc key to exit fullscreen\n\n on(document, 'keydown', bind(this, this.fullWindowOnEscKey)); // Hide any scroll bars\n\n document.documentElement.style.overflow = 'hidden'; // Apply fullscreen styles\n\n addClass(document.body, 'vjs-full-window');\n /**\n * @event Player#enterFullWindow\n * @type {EventTarget~Event}\n */\n\n this.trigger('enterFullWindow');\n };\n /**\n * Check for call to either exit full window or\n * full screen on ESC key\n *\n * @param {string} event\n * Event to check for key press\n */\n\n\n _proto.fullWindowOnEscKey = function fullWindowOnEscKey(event) {\n if (event.keyCode === 27) {\n if (this.isFullscreen() === true) {\n this.exitFullscreen();\n } else {\n this.exitFullWindow();\n }\n }\n };\n /**\n * Exit full window\n *\n * @fires Player#exitFullWindow\n */\n\n\n _proto.exitFullWindow = function exitFullWindow() {\n this.isFullWindow = false;\n off(document, 'keydown', this.fullWindowOnEscKey); // Unhide scroll bars.\n\n document.documentElement.style.overflow = this.docOrigOverflow; // Remove fullscreen styles\n\n removeClass(document.body, 'vjs-full-window'); // Resize the box, controller, and poster to original sizes\n // this.positionAll();\n\n /**\n * @event Player#exitFullWindow\n * @type {EventTarget~Event}\n */\n\n this.trigger('exitFullWindow');\n };\n /**\n * Check whether the player can play a given mimetype\n *\n * @see https://www.w3.org/TR/2011/WD-html5-20110113/video.html#dom-navigator-canplaytype\n *\n * @param {string} type\n * The mimetype to check\n *\n * @return {string}\n * 'probably', 'maybe', or '' (empty string)\n */\n\n\n _proto.canPlayType = function canPlayType(type) {\n var can; // Loop through each playback technology in the options order\n\n for (var i = 0, j = this.options_.techOrder; i < j.length; i++) {\n var techName = j[i];\n var tech = Tech.getTech(techName); // Support old behavior of techs being registered as components.\n // Remove once that deprecated behavior is removed.\n\n if (!tech) {\n tech = Component.getComponent(techName);\n } // Check if the current tech is defined before continuing\n\n\n if (!tech) {\n log.error(\"The \\\"\" + techName + \"\\\" tech is undefined. Skipped browser support check for that tech.\");\n continue;\n } // Check if the browser supports this technology\n\n\n if (tech.isSupported()) {\n can = tech.canPlayType(type);\n\n if (can) {\n return can;\n }\n }\n }\n\n return '';\n };\n /**\n * Select source based on tech-order or source-order\n * Uses source-order selection if `options.sourceOrder` is truthy. Otherwise,\n * defaults to tech-order selection\n *\n * @param {Array} sources\n * The sources for a media asset\n *\n * @return {Object|boolean}\n * Object of source and tech order or false\n */\n\n\n _proto.selectSource = function selectSource(sources) {\n var _this9 = this;\n\n // Get only the techs specified in `techOrder` that exist and are supported by the\n // current platform\n var techs = this.options_.techOrder.map(function (techName) {\n return [techName, Tech.getTech(techName)];\n }).filter(function (_ref) {\n var techName = _ref[0],\n tech = _ref[1];\n\n // Check if the current tech is defined before continuing\n if (tech) {\n // Check if the browser supports this technology\n return tech.isSupported();\n }\n\n log.error(\"The \\\"\" + techName + \"\\\" tech is undefined. Skipped browser support check for that tech.\");\n return false;\n }); // Iterate over each `innerArray` element once per `outerArray` element and execute\n // `tester` with both. If `tester` returns a non-falsy value, exit early and return\n // that value.\n\n var findFirstPassingTechSourcePair = function findFirstPassingTechSourcePair(outerArray, innerArray, tester) {\n var found;\n outerArray.some(function (outerChoice) {\n return innerArray.some(function (innerChoice) {\n found = tester(outerChoice, innerChoice);\n\n if (found) {\n return true;\n }\n });\n });\n return found;\n };\n\n var foundSourceAndTech;\n\n var flip = function flip(fn) {\n return function (a, b) {\n return fn(b, a);\n };\n };\n\n var finder = function finder(_ref2, source) {\n var techName = _ref2[0],\n tech = _ref2[1];\n\n if (tech.canPlaySource(source, _this9.options_[techName.toLowerCase()])) {\n return {\n source: source,\n tech: techName\n };\n }\n }; // Depending on the truthiness of `options.sourceOrder`, we swap the order of techs and sources\n // to select from them based on their priority.\n\n\n if (this.options_.sourceOrder) {\n // Source-first ordering\n foundSourceAndTech = findFirstPassingTechSourcePair(sources, techs, flip(finder));\n } else {\n // Tech-first ordering\n foundSourceAndTech = findFirstPassingTechSourcePair(techs, sources, finder);\n }\n\n return foundSourceAndTech || false;\n };\n /**\n * Get or set the video source.\n *\n * @param {Tech~SourceObject|Tech~SourceObject[]|string} [source]\n * A SourceObject, an array of SourceObjects, or a string referencing\n * a URL to a media source. It is _highly recommended_ that an object\n * or array of objects is used here, so that source selection\n * algorithms can take the `type` into account.\n *\n * If not provided, this method acts as a getter.\n *\n * @return {string|undefined}\n * If the `source` argument is missing, returns the current source\n * URL. Otherwise, returns nothing/undefined.\n */\n\n\n _proto.src = function src(source) {\n var _this10 = this;\n\n // getter usage\n if (typeof source === 'undefined') {\n return this.cache_.src || '';\n } // filter out invalid sources and turn our source into\n // an array of source objects\n\n\n var sources = filterSource(source); // if a source was passed in then it is invalid because\n // it was filtered to a zero length Array. So we have to\n // show an error\n\n if (!sources.length) {\n this.setTimeout(function () {\n this.error({\n code: 4,\n message: this.localize(this.options_.notSupportedMessage)\n });\n }, 0);\n return;\n } // intial sources\n\n\n this.changingSrc_ = true;\n this.cache_.sources = sources;\n this.updateSourceCaches_(sources[0]); // middlewareSource is the source after it has been changed by middleware\n\n setSource(this, sources[0], function (middlewareSource, mws) {\n _this10.middleware_ = mws; // since sourceSet is async we have to update the cache again after we select a source since\n // the source that is selected could be out of order from the cache update above this callback.\n\n _this10.cache_.sources = sources;\n\n _this10.updateSourceCaches_(middlewareSource);\n\n var err = _this10.src_(middlewareSource);\n\n if (err) {\n if (sources.length > 1) {\n return _this10.src(sources.slice(1));\n }\n\n _this10.changingSrc_ = false; // We need to wrap this in a timeout to give folks a chance to add error event handlers\n\n _this10.setTimeout(function () {\n this.error({\n code: 4,\n message: this.localize(this.options_.notSupportedMessage)\n });\n }, 0); // we could not find an appropriate tech, but let's still notify the delegate that this is it\n // this needs a better comment about why this is needed\n\n\n _this10.triggerReady();\n\n return;\n }\n\n setTech(mws, _this10.tech_);\n });\n };\n /**\n * Set the source object on the tech, returns a boolean that indicates whether\n * there is a tech that can play the source or not\n *\n * @param {Tech~SourceObject} source\n * The source object to set on the Tech\n *\n * @return {boolean}\n * - True if there is no Tech to playback this source\n * - False otherwise\n *\n * @private\n */\n\n\n _proto.src_ = function src_(source) {\n var _this11 = this;\n\n var sourceTech = this.selectSource([source]);\n\n if (!sourceTech) {\n return true;\n }\n\n if (!titleCaseEquals(sourceTech.tech, this.techName_)) {\n this.changingSrc_ = true; // load this technology with the chosen source\n\n this.loadTech_(sourceTech.tech, sourceTech.source);\n this.tech_.ready(function () {\n _this11.changingSrc_ = false;\n });\n return false;\n } // wait until the tech is ready to set the source\n // and set it synchronously if possible (#2326)\n\n\n this.ready(function () {\n // The setSource tech method was added with source handlers\n // so older techs won't support it\n // We need to check the direct prototype for the case where subclasses\n // of the tech do not support source handlers\n if (this.tech_.constructor.prototype.hasOwnProperty('setSource')) {\n this.techCall_('setSource', source);\n } else {\n this.techCall_('src', source.src);\n }\n\n this.changingSrc_ = false;\n }, true);\n return false;\n };\n /**\n * Begin loading the src data.\n */\n\n\n _proto.load = function load() {\n this.techCall_('load');\n };\n /**\n * Reset the player. Loads the first tech in the techOrder,\n * removes all the text tracks in the existing `tech`,\n * and calls `reset` on the `tech`.\n */\n\n\n _proto.reset = function reset() {\n if (this.tech_) {\n this.tech_.clearTracks('text');\n }\n\n this.loadTech_(this.options_.techOrder[0], null);\n this.techCall_('reset');\n\n if (isEvented(this)) {\n this.trigger('playerreset');\n }\n };\n /**\n * Returns all of the current source objects.\n *\n * @return {Tech~SourceObject[]}\n * The current source objects\n */\n\n\n _proto.currentSources = function currentSources() {\n var source = this.currentSource();\n var sources = []; // assume `{}` or `{ src }`\n\n if (Object.keys(source).length !== 0) {\n sources.push(source);\n }\n\n return this.cache_.sources || sources;\n };\n /**\n * Returns the current source object.\n *\n * @return {Tech~SourceObject}\n * The current source object\n */\n\n\n _proto.currentSource = function currentSource() {\n return this.cache_.source || {};\n };\n /**\n * Returns the fully qualified URL of the current source value e.g. http://mysite.com/video.mp4\n * Can be used in conjunction with `currentType` to assist in rebuilding the current source object.\n *\n * @return {string}\n * The current source\n */\n\n\n _proto.currentSrc = function currentSrc() {\n return this.currentSource() && this.currentSource().src || '';\n };\n /**\n * Get the current source type e.g. video/mp4\n * This can allow you rebuild the current source object so that you could load the same\n * source and tech later\n *\n * @return {string}\n * The source MIME type\n */\n\n\n _proto.currentType = function currentType() {\n return this.currentSource() && this.currentSource().type || '';\n };\n /**\n * Get or set the preload attribute\n *\n * @param {boolean} [value]\n * - true means that we should preload\n * - false means that we should not preload\n *\n * @return {string}\n * The preload attribute value when getting\n */\n\n\n _proto.preload = function preload(value) {\n if (value !== undefined) {\n this.techCall_('setPreload', value);\n this.options_.preload = value;\n return;\n }\n\n return this.techGet_('preload');\n };\n /**\n * Get or set the autoplay option. When this is a boolean it will\n * modify the attribute on the tech. When this is a string the attribute on\n * the tech will be removed and `Player` will handle autoplay on loadstarts.\n *\n * @param {boolean|string} [value]\n * - true: autoplay using the browser behavior\n * - false: do not autoplay\n * - 'play': call play() on every loadstart\n * - 'muted': call muted() then play() on every loadstart\n * - 'any': call play() on every loadstart. if that fails call muted() then play().\n * - *: values other than those listed here will be set `autoplay` to true\n *\n * @return {boolean|string}\n * The current value of autoplay when getting\n */\n\n\n _proto.autoplay = function autoplay(value) {\n // getter usage\n if (value === undefined) {\n return this.options_.autoplay || false;\n }\n\n var techAutoplay; // if the value is a valid string set it to that\n\n if (typeof value === 'string' && /(any|play|muted)/.test(value)) {\n this.options_.autoplay = value;\n this.manualAutoplay_(value);\n techAutoplay = false; // any falsy value sets autoplay to false in the browser,\n // lets do the same\n } else if (!value) {\n this.options_.autoplay = false; // any other value (ie truthy) sets autoplay to true\n } else {\n this.options_.autoplay = true;\n }\n\n techAutoplay = techAutoplay || this.options_.autoplay; // if we don't have a tech then we do not queue up\n // a setAutoplay call on tech ready. We do this because the\n // autoplay option will be passed in the constructor and we\n // do not need to set it twice\n\n if (this.tech_) {\n this.techCall_('setAutoplay', techAutoplay);\n }\n };\n /**\n * Set or unset the playsinline attribute.\n * Playsinline tells the browser that non-fullscreen playback is preferred.\n *\n * @param {boolean} [value]\n * - true means that we should try to play inline by default\n * - false means that we should use the browser's default playback mode,\n * which in most cases is inline. iOS Safari is a notable exception\n * and plays fullscreen by default.\n *\n * @return {string|Player}\n * - the current value of playsinline\n * - the player when setting\n *\n * @see [Spec]{@link https://html.spec.whatwg.org/#attr-video-playsinline}\n */\n\n\n _proto.playsinline = function playsinline(value) {\n if (value !== undefined) {\n this.techCall_('setPlaysinline', value);\n this.options_.playsinline = value;\n return this;\n }\n\n return this.techGet_('playsinline');\n };\n /**\n * Get or set the loop attribute on the video element.\n *\n * @param {boolean} [value]\n * - true means that we should loop the video\n * - false means that we should not loop the video\n *\n * @return {string}\n * The current value of loop when getting\n */\n\n\n _proto.loop = function loop(value) {\n if (value !== undefined) {\n this.techCall_('setLoop', value);\n this.options_.loop = value;\n return;\n }\n\n return this.techGet_('loop');\n };\n /**\n * Get or set the poster image source url\n *\n * @fires Player#posterchange\n *\n * @param {string} [src]\n * Poster image source URL\n *\n * @return {string}\n * The current value of poster when getting\n */\n\n\n _proto.poster = function poster(src) {\n if (src === undefined) {\n return this.poster_;\n } // The correct way to remove a poster is to set as an empty string\n // other falsey values will throw errors\n\n\n if (!src) {\n src = '';\n }\n\n if (src === this.poster_) {\n return;\n } // update the internal poster variable\n\n\n this.poster_ = src; // update the tech's poster\n\n this.techCall_('setPoster', src);\n this.isPosterFromTech_ = false; // alert components that the poster has been set\n\n /**\n * This event fires when the poster image is changed on the player.\n *\n * @event Player#posterchange\n * @type {EventTarget~Event}\n */\n\n this.trigger('posterchange');\n };\n /**\n * Some techs (e.g. YouTube) can provide a poster source in an\n * asynchronous way. We want the poster component to use this\n * poster source so that it covers up the tech's controls.\n * (YouTube's play button). However we only want to use this\n * source if the player user hasn't set a poster through\n * the normal APIs.\n *\n * @fires Player#posterchange\n * @listens Tech#posterchange\n * @private\n */\n\n\n _proto.handleTechPosterChange_ = function handleTechPosterChange_() {\n if ((!this.poster_ || this.options_.techCanOverridePoster) && this.tech_ && this.tech_.poster) {\n var newPoster = this.tech_.poster() || '';\n\n if (newPoster !== this.poster_) {\n this.poster_ = newPoster;\n this.isPosterFromTech_ = true; // Let components know the poster has changed\n\n this.trigger('posterchange');\n }\n }\n };\n /**\n * Get or set whether or not the controls are showing.\n *\n * @fires Player#controlsenabled\n *\n * @param {boolean} [bool]\n * - true to turn controls on\n * - false to turn controls off\n *\n * @return {boolean}\n * The current value of controls when getting\n */\n\n\n _proto.controls = function controls(bool) {\n if (bool === undefined) {\n return !!this.controls_;\n }\n\n bool = !!bool; // Don't trigger a change event unless it actually changed\n\n if (this.controls_ === bool) {\n return;\n }\n\n this.controls_ = bool;\n\n if (this.usingNativeControls()) {\n this.techCall_('setControls', bool);\n }\n\n if (this.controls_) {\n this.removeClass('vjs-controls-disabled');\n this.addClass('vjs-controls-enabled');\n /**\n * @event Player#controlsenabled\n * @type {EventTarget~Event}\n */\n\n this.trigger('controlsenabled');\n\n if (!this.usingNativeControls()) {\n this.addTechControlsListeners_();\n }\n } else {\n this.removeClass('vjs-controls-enabled');\n this.addClass('vjs-controls-disabled');\n /**\n * @event Player#controlsdisabled\n * @type {EventTarget~Event}\n */\n\n this.trigger('controlsdisabled');\n\n if (!this.usingNativeControls()) {\n this.removeTechControlsListeners_();\n }\n }\n };\n /**\n * Toggle native controls on/off. Native controls are the controls built into\n * devices (e.g. default iPhone controls), Flash, or other techs\n * (e.g. Vimeo Controls)\n * **This should only be set by the current tech, because only the tech knows\n * if it can support native controls**\n *\n * @fires Player#usingnativecontrols\n * @fires Player#usingcustomcontrols\n *\n * @param {boolean} [bool]\n * - true to turn native controls on\n * - false to turn native controls off\n *\n * @return {boolean}\n * The current value of native controls when getting\n */\n\n\n _proto.usingNativeControls = function usingNativeControls(bool) {\n if (bool === undefined) {\n return !!this.usingNativeControls_;\n }\n\n bool = !!bool; // Don't trigger a change event unless it actually changed\n\n if (this.usingNativeControls_ === bool) {\n return;\n }\n\n this.usingNativeControls_ = bool;\n\n if (this.usingNativeControls_) {\n this.addClass('vjs-using-native-controls');\n /**\n * player is using the native device controls\n *\n * @event Player#usingnativecontrols\n * @type {EventTarget~Event}\n */\n\n this.trigger('usingnativecontrols');\n } else {\n this.removeClass('vjs-using-native-controls');\n /**\n * player is using the custom HTML controls\n *\n * @event Player#usingcustomcontrols\n * @type {EventTarget~Event}\n */\n\n this.trigger('usingcustomcontrols');\n }\n };\n /**\n * Set or get the current MediaError\n *\n * @fires Player#error\n *\n * @param {MediaError|string|number} [err]\n * A MediaError or a string/number to be turned\n * into a MediaError\n *\n * @return {MediaError|null}\n * The current MediaError when getting (or null)\n */\n\n\n _proto.error = function error(err) {\n if (err === undefined) {\n return this.error_ || null;\n } // restoring to default\n\n\n if (err === null) {\n this.error_ = err;\n this.removeClass('vjs-error');\n\n if (this.errorDisplay) {\n this.errorDisplay.close();\n }\n\n return;\n }\n\n this.error_ = new MediaError(err); // add the vjs-error classname to the player\n\n this.addClass('vjs-error'); // log the name of the error type and any message\n // IE11 logs \"[object object]\" and required you to expand message to see error object\n\n log.error(\"(CODE:\" + this.error_.code + \" \" + MediaError.errorTypes[this.error_.code] + \")\", this.error_.message, this.error_);\n /**\n * @event Player#error\n * @type {EventTarget~Event}\n */\n\n this.trigger('error');\n return;\n };\n /**\n * Report user activity\n *\n * @param {Object} event\n * Event object\n */\n\n\n _proto.reportUserActivity = function reportUserActivity(event) {\n this.userActivity_ = true;\n };\n /**\n * Get/set if user is active\n *\n * @fires Player#useractive\n * @fires Player#userinactive\n *\n * @param {boolean} [bool]\n * - true if the user is active\n * - false if the user is inactive\n *\n * @return {boolean}\n * The current value of userActive when getting\n */\n\n\n _proto.userActive = function userActive(bool) {\n if (bool === undefined) {\n return this.userActive_;\n }\n\n bool = !!bool;\n\n if (bool === this.userActive_) {\n return;\n }\n\n this.userActive_ = bool;\n\n if (this.userActive_) {\n this.userActivity_ = true;\n this.removeClass('vjs-user-inactive');\n this.addClass('vjs-user-active');\n /**\n * @event Player#useractive\n * @type {EventTarget~Event}\n */\n\n this.trigger('useractive');\n return;\n } // Chrome/Safari/IE have bugs where when you change the cursor it can\n // trigger a mousemove event. This causes an issue when you're hiding\n // the cursor when the user is inactive, and a mousemove signals user\n // activity. Making it impossible to go into inactive mode. Specifically\n // this happens in fullscreen when we really need to hide the cursor.\n //\n // When this gets resolved in ALL browsers it can be removed\n // https://code.google.com/p/chromium/issues/detail?id=103041\n\n\n if (this.tech_) {\n this.tech_.one('mousemove', function (e) {\n e.stopPropagation();\n e.preventDefault();\n });\n }\n\n this.userActivity_ = false;\n this.removeClass('vjs-user-active');\n this.addClass('vjs-user-inactive');\n /**\n * @event Player#userinactive\n * @type {EventTarget~Event}\n */\n\n this.trigger('userinactive');\n };\n /**\n * Listen for user activity based on timeout value\n *\n * @private\n */\n\n\n _proto.listenForUserActivity_ = function listenForUserActivity_() {\n var mouseInProgress;\n var lastMoveX;\n var lastMoveY;\n var handleActivity = bind(this, this.reportUserActivity);\n\n var handleMouseMove = function handleMouseMove(e) {\n // #1068 - Prevent mousemove spamming\n // Chrome Bug: https://code.google.com/p/chromium/issues/detail?id=366970\n if (e.screenX !== lastMoveX || e.screenY !== lastMoveY) {\n lastMoveX = e.screenX;\n lastMoveY = e.screenY;\n handleActivity();\n }\n };\n\n var handleMouseDown = function handleMouseDown() {\n handleActivity(); // For as long as the they are touching the device or have their mouse down,\n // we consider them active even if they're not moving their finger or mouse.\n // So we want to continue to update that they are active\n\n this.clearInterval(mouseInProgress); // Setting userActivity=true now and setting the interval to the same time\n // as the activityCheck interval (250) should ensure we never miss the\n // next activityCheck\n\n mouseInProgress = this.setInterval(handleActivity, 250);\n };\n\n var handleMouseUp = function handleMouseUp(event) {\n handleActivity(); // Stop the interval that maintains activity if the mouse/touch is down\n\n this.clearInterval(mouseInProgress);\n }; // Any mouse movement will be considered user activity\n\n\n this.on('mousedown', handleMouseDown);\n this.on('mousemove', handleMouseMove);\n this.on('mouseup', handleMouseUp); // Listen for keyboard navigation\n // Shouldn't need to use inProgress interval because of key repeat\n\n this.on('keydown', handleActivity);\n this.on('keyup', handleActivity); // Run an interval every 250 milliseconds instead of stuffing everything into\n // the mousemove/touchmove function itself, to prevent performance degradation.\n // `this.reportUserActivity` simply sets this.userActivity_ to true, which\n // then gets picked up by this loop\n // http://ejohn.org/blog/learning-from-twitter/\n\n var inactivityTimeout;\n this.setInterval(function () {\n // Check to see if mouse/touch activity has happened\n if (!this.userActivity_) {\n return;\n } // Reset the activity tracker\n\n\n this.userActivity_ = false; // If the user state was inactive, set the state to active\n\n this.userActive(true); // Clear any existing inactivity timeout to start the timer over\n\n this.clearTimeout(inactivityTimeout);\n var timeout = this.options_.inactivityTimeout;\n\n if (timeout <= 0) {\n return;\n } // In <timeout> milliseconds, if no more activity has occurred the\n // user will be considered inactive\n\n\n inactivityTimeout = this.setTimeout(function () {\n // Protect against the case where the inactivityTimeout can trigger just\n // before the next user activity is picked up by the activity check loop\n // causing a flicker\n if (!this.userActivity_) {\n this.userActive(false);\n }\n }, timeout);\n }, 250);\n };\n /**\n * Gets or sets the current playback rate. A playback rate of\n * 1.0 represents normal speed and 0.5 would indicate half-speed\n * playback, for instance.\n *\n * @see https://html.spec.whatwg.org/multipage/embedded-content.html#dom-media-playbackrate\n *\n * @param {number} [rate]\n * New playback rate to set.\n *\n * @return {number}\n * The current playback rate when getting or 1.0\n */\n\n\n _proto.playbackRate = function playbackRate(rate) {\n if (rate !== undefined) {\n // NOTE: this.cache_.lastPlaybackRate is set from the tech handler\n // that is registered above\n this.techCall_('setPlaybackRate', rate);\n return;\n }\n\n if (this.tech_ && this.tech_.featuresPlaybackRate) {\n return this.cache_.lastPlaybackRate || this.techGet_('playbackRate');\n }\n\n return 1.0;\n };\n /**\n * Gets or sets the current default playback rate. A default playback rate of\n * 1.0 represents normal speed and 0.5 would indicate half-speed playback, for instance.\n * defaultPlaybackRate will only represent what the initial playbackRate of a video was, not\n * not the current playbackRate.\n *\n * @see https://html.spec.whatwg.org/multipage/embedded-content.html#dom-media-defaultplaybackrate\n *\n * @param {number} [rate]\n * New default playback rate to set.\n *\n * @return {number|Player}\n * - The default playback rate when getting or 1.0\n * - the player when setting\n */\n\n\n _proto.defaultPlaybackRate = function defaultPlaybackRate(rate) {\n if (rate !== undefined) {\n return this.techCall_('setDefaultPlaybackRate', rate);\n }\n\n if (this.tech_ && this.tech_.featuresPlaybackRate) {\n return this.techGet_('defaultPlaybackRate');\n }\n\n return 1.0;\n };\n /**\n * Gets or sets the audio flag\n *\n * @param {boolean} bool\n * - true signals that this is an audio player\n * - false signals that this is not an audio player\n *\n * @return {boolean}\n * The current value of isAudio when getting\n */\n\n\n _proto.isAudio = function isAudio(bool) {\n if (bool !== undefined) {\n this.isAudio_ = !!bool;\n return;\n }\n\n return !!this.isAudio_;\n };\n /**\n * A helper method for adding a {@link TextTrack} to our\n * {@link TextTrackList}.\n *\n * In addition to the W3C settings we allow adding additional info through options.\n *\n * @see http://www.w3.org/html/wg/drafts/html/master/embedded-content-0.html#dom-media-addtexttrack\n *\n * @param {string} [kind]\n * the kind of TextTrack you are adding\n *\n * @param {string} [label]\n * the label to give the TextTrack label\n *\n * @param {string} [language]\n * the language to set on the TextTrack\n *\n * @return {TextTrack|undefined}\n * the TextTrack that was added or undefined\n * if there is no tech\n */\n\n\n _proto.addTextTrack = function addTextTrack(kind, label, language) {\n if (this.tech_) {\n return this.tech_.addTextTrack(kind, label, language);\n }\n };\n /**\n * Create a remote {@link TextTrack} and an {@link HTMLTrackElement}. It will\n * automatically removed from the video element whenever the source changes, unless\n * manualCleanup is set to false.\n *\n * @param {Object} options\n * Options to pass to {@link HTMLTrackElement} during creation. See\n * {@link HTMLTrackElement} for object properties that you should use.\n *\n * @param {boolean} [manualCleanup=true] if set to false, the TextTrack will be\n *\n * @return {HtmlTrackElement}\n * the HTMLTrackElement that was created and added\n * to the HtmlTrackElementList and the remote\n * TextTrackList\n *\n * @deprecated The default value of the \"manualCleanup\" parameter will default\n * to \"false\" in upcoming versions of Video.js\n */\n\n\n _proto.addRemoteTextTrack = function addRemoteTextTrack(options, manualCleanup) {\n if (this.tech_) {\n return this.tech_.addRemoteTextTrack(options, manualCleanup);\n }\n };\n /**\n * Remove a remote {@link TextTrack} from the respective\n * {@link TextTrackList} and {@link HtmlTrackElementList}.\n *\n * @param {Object} track\n * Remote {@link TextTrack} to remove\n *\n * @return {undefined}\n * does not return anything\n */\n\n\n _proto.removeRemoteTextTrack = function removeRemoteTextTrack(obj) {\n if (obj === void 0) {\n obj = {};\n }\n\n var _obj = obj,\n track = _obj.track;\n\n if (!track) {\n track = obj;\n } // destructure the input into an object with a track argument, defaulting to arguments[0]\n // default the whole argument to an empty object if nothing was passed in\n\n\n if (this.tech_) {\n return this.tech_.removeRemoteTextTrack(track);\n }\n };\n /**\n * Gets available media playback quality metrics as specified by the W3C's Media\n * Playback Quality API.\n *\n * @see [Spec]{@link https://wicg.github.io/media-playback-quality}\n *\n * @return {Object|undefined}\n * An object with supported media playback quality metrics or undefined if there\n * is no tech or the tech does not support it.\n */\n\n\n _proto.getVideoPlaybackQuality = function getVideoPlaybackQuality() {\n return this.techGet_('getVideoPlaybackQuality');\n };\n /**\n * Get video width\n *\n * @return {number}\n * current video width\n */\n\n\n _proto.videoWidth = function videoWidth() {\n return this.tech_ && this.tech_.videoWidth && this.tech_.videoWidth() || 0;\n };\n /**\n * Get video height\n *\n * @return {number}\n * current video height\n */\n\n\n _proto.videoHeight = function videoHeight() {\n return this.tech_ && this.tech_.videoHeight && this.tech_.videoHeight() || 0;\n };\n /**\n * The player's language code\n * NOTE: The language should be set in the player options if you want the\n * the controls to be built with a specific language. Changing the language\n * later will not update controls text.\n *\n * @param {string} [code]\n * the language code to set the player to\n *\n * @return {string}\n * The current language code when getting\n */\n\n\n _proto.language = function language(code) {\n if (code === undefined) {\n return this.language_;\n }\n\n this.language_ = String(code).toLowerCase();\n };\n /**\n * Get the player's language dictionary\n * Merge every time, because a newly added plugin might call videojs.addLanguage() at any time\n * Languages specified directly in the player options have precedence\n *\n * @return {Array}\n * An array of of supported languages\n */\n\n\n _proto.languages = function languages() {\n return mergeOptions(Player.prototype.options_.languages, this.languages_);\n };\n /**\n * returns a JavaScript object reperesenting the current track\n * information. **DOES not return it as JSON**\n *\n * @return {Object}\n * Object representing the current of track info\n */\n\n\n _proto.toJSON = function toJSON() {\n var options = mergeOptions(this.options_);\n var tracks = options.tracks;\n options.tracks = [];\n\n for (var i = 0; i < tracks.length; i++) {\n var track = tracks[i]; // deep merge tracks and null out player so no circular references\n\n track = mergeOptions(track);\n track.player = undefined;\n options.tracks[i] = track;\n }\n\n return options;\n };\n /**\n * Creates a simple modal dialog (an instance of the {@link ModalDialog}\n * component) that immediately overlays the player with arbitrary\n * content and removes itself when closed.\n *\n * @param {string|Function|Element|Array|null} content\n * Same as {@link ModalDialog#content}'s param of the same name.\n * The most straight-forward usage is to provide a string or DOM\n * element.\n *\n * @param {Object} [options]\n * Extra options which will be passed on to the {@link ModalDialog}.\n *\n * @return {ModalDialog}\n * the {@link ModalDialog} that was created\n */\n\n\n _proto.createModal = function createModal(content, options) {\n var _this12 = this;\n\n options = options || {};\n options.content = content || '';\n var modal = new ModalDialog(this, options);\n this.addChild(modal);\n modal.on('dispose', function () {\n _this12.removeChild(modal);\n });\n modal.open();\n return modal;\n };\n /**\n * Change breakpoint classes when the player resizes.\n *\n * @private\n */\n\n\n _proto.updateCurrentBreakpoint_ = function updateCurrentBreakpoint_() {\n if (!this.responsive()) {\n return;\n }\n\n var currentBreakpoint = this.currentBreakpoint();\n var currentWidth = this.currentWidth();\n\n for (var i = 0; i < BREAKPOINT_ORDER.length; i++) {\n var candidateBreakpoint = BREAKPOINT_ORDER[i];\n var maxWidth = this.breakpoints_[candidateBreakpoint];\n\n if (currentWidth <= maxWidth) {\n // The current breakpoint did not change, nothing to do.\n if (currentBreakpoint === candidateBreakpoint) {\n return;\n } // Only remove a class if there is a current breakpoint.\n\n\n if (currentBreakpoint) {\n this.removeClass(BREAKPOINT_CLASSES[currentBreakpoint]);\n }\n\n this.addClass(BREAKPOINT_CLASSES[candidateBreakpoint]);\n this.breakpoint_ = candidateBreakpoint;\n break;\n }\n }\n };\n /**\n * Removes the current breakpoint.\n *\n * @private\n */\n\n\n _proto.removeCurrentBreakpoint_ = function removeCurrentBreakpoint_() {\n var className = this.currentBreakpointClass();\n this.breakpoint_ = '';\n\n if (className) {\n this.removeClass(className);\n }\n };\n /**\n * Get or set breakpoints on the player.\n *\n * Calling this method with an object or `true` will remove any previous\n * custom breakpoints and start from the defaults again.\n *\n * @param {Object|boolean} [breakpoints]\n * If an object is given, it can be used to provide custom\n * breakpoints. If `true` is given, will set default breakpoints.\n * If this argument is not given, will simply return the current\n * breakpoints.\n *\n * @param {number} [breakpoints.tiny]\n * The maximum width for the \"vjs-layout-tiny\" class.\n *\n * @param {number} [breakpoints.xsmall]\n * The maximum width for the \"vjs-layout-x-small\" class.\n *\n * @param {number} [breakpoints.small]\n * The maximum width for the \"vjs-layout-small\" class.\n *\n * @param {number} [breakpoints.medium]\n * The maximum width for the \"vjs-layout-medium\" class.\n *\n * @param {number} [breakpoints.large]\n * The maximum width for the \"vjs-layout-large\" class.\n *\n * @param {number} [breakpoints.xlarge]\n * The maximum width for the \"vjs-layout-x-large\" class.\n *\n * @param {number} [breakpoints.huge]\n * The maximum width for the \"vjs-layout-huge\" class.\n *\n * @return {Object}\n * An object mapping breakpoint names to maximum width values.\n */\n\n\n _proto.breakpoints = function breakpoints(_breakpoints) {\n // Used as a getter.\n if (_breakpoints === undefined) {\n return assign(this.breakpoints_);\n }\n\n this.breakpoint_ = '';\n this.breakpoints_ = assign({}, DEFAULT_BREAKPOINTS, _breakpoints); // When breakpoint definitions change, we need to update the currently\n // selected breakpoint.\n\n this.updateCurrentBreakpoint_(); // Clone the breakpoints before returning.\n\n return assign(this.breakpoints_);\n };\n /**\n * Get or set a flag indicating whether or not this player should adjust\n * its UI based on its dimensions.\n *\n * @param {boolean} value\n * Should be `true` if the player should adjust its UI based on its\n * dimensions; otherwise, should be `false`.\n *\n * @return {boolean}\n * Will be `true` if this player should adjust its UI based on its\n * dimensions; otherwise, will be `false`.\n */\n\n\n _proto.responsive = function responsive(value) {\n // Used as a getter.\n if (value === undefined) {\n return this.responsive_;\n }\n\n value = Boolean(value);\n var current = this.responsive_; // Nothing changed.\n\n if (value === current) {\n return;\n } // The value actually changed, set it.\n\n\n this.responsive_ = value; // Start listening for breakpoints and set the initial breakpoint if the\n // player is now responsive.\n\n if (value) {\n this.on('playerresize', this.updateCurrentBreakpoint_);\n this.updateCurrentBreakpoint_(); // Stop listening for breakpoints if the player is no longer responsive.\n } else {\n this.off('playerresize', this.updateCurrentBreakpoint_);\n this.removeCurrentBreakpoint_();\n }\n\n return value;\n };\n /**\n * Get current breakpoint name, if any.\n *\n * @return {string}\n * If there is currently a breakpoint set, returns a the key from the\n * breakpoints object matching it. Otherwise, returns an empty string.\n */\n\n\n _proto.currentBreakpoint = function currentBreakpoint() {\n return this.breakpoint_;\n };\n /**\n * Get the current breakpoint class name.\n *\n * @return {string}\n * The matching class name (e.g. `\"vjs-layout-tiny\"` or\n * `\"vjs-layout-large\"`) for the current breakpoint. Empty string if\n * there is no current breakpoint.\n */\n\n\n _proto.currentBreakpointClass = function currentBreakpointClass() {\n return BREAKPOINT_CLASSES[this.breakpoint_] || '';\n };\n /**\n * Gets tag settings\n *\n * @param {Element} tag\n * The player tag\n *\n * @return {Object}\n * An object containing all of the settings\n * for a player tag\n */\n\n\n Player.getTagSettings = function getTagSettings(tag) {\n var baseOptions = {\n sources: [],\n tracks: []\n };\n var tagOptions = getAttributes(tag);\n var dataSetup = tagOptions['data-setup'];\n\n if (hasClass(tag, 'vjs-fill')) {\n tagOptions.fill = true;\n }\n\n if (hasClass(tag, 'vjs-fluid')) {\n tagOptions.fluid = true;\n } // Check if data-setup attr exists.\n\n\n if (dataSetup !== null) {\n // Parse options JSON\n // If empty string, make it a parsable json object.\n var _safeParseTuple = safeParseTuple(dataSetup || '{}'),\n err = _safeParseTuple[0],\n data = _safeParseTuple[1];\n\n if (err) {\n log.error(err);\n }\n\n assign(tagOptions, data);\n }\n\n assign(baseOptions, tagOptions); // Get tag children settings\n\n if (tag.hasChildNodes()) {\n var children = tag.childNodes;\n\n for (var i = 0, j = children.length; i < j; i++) {\n var child = children[i]; // Change case needed: http://ejohn.org/blog/nodename-case-sensitivity/\n\n var childName = child.nodeName.toLowerCase();\n\n if (childName === 'source') {\n baseOptions.sources.push(getAttributes(child));\n } else if (childName === 'track') {\n baseOptions.tracks.push(getAttributes(child));\n }\n }\n }\n\n return baseOptions;\n };\n /**\n * Determine whether or not flexbox is supported\n *\n * @return {boolean}\n * - true if flexbox is supported\n * - false if flexbox is not supported\n */\n\n\n _proto.flexNotSupported_ = function flexNotSupported_() {\n var elem = document.createElement('i'); // Note: We don't actually use flexBasis (or flexOrder), but it's one of the more\n // common flex features that we can rely on when checking for flex support.\n\n return !('flexBasis' in elem.style || 'webkitFlexBasis' in elem.style || 'mozFlexBasis' in elem.style || 'msFlexBasis' in elem.style || // IE10-specific (2012 flex spec), available for completeness\n 'msFlexOrder' in elem.style);\n };\n\n return Player;\n}(Component);\n/**\n * Get the {@link VideoTrackList}\n * @link https://html.spec.whatwg.org/multipage/embedded-content.html#videotracklist\n *\n * @return {VideoTrackList}\n * the current video track list\n *\n * @method Player.prototype.videoTracks\n */\n\n/**\n * Get the {@link AudioTrackList}\n * @link https://html.spec.whatwg.org/multipage/embedded-content.html#audiotracklist\n *\n * @return {AudioTrackList}\n * the current audio track list\n *\n * @method Player.prototype.audioTracks\n */\n\n/**\n * Get the {@link TextTrackList}\n *\n * @link http://www.w3.org/html/wg/drafts/html/master/embedded-content-0.html#dom-media-texttracks\n *\n * @return {TextTrackList}\n * the current text track list\n *\n * @method Player.prototype.textTracks\n */\n\n/**\n * Get the remote {@link TextTrackList}\n *\n * @return {TextTrackList}\n * The current remote text track list\n *\n * @method Player.prototype.remoteTextTracks\n */\n\n/**\n * Get the remote {@link HtmlTrackElementList} tracks.\n *\n * @return {HtmlTrackElementList}\n * The current remote text track element list\n *\n * @method Player.prototype.remoteTextTrackEls\n */\n\n\nALL.names.forEach(function (name$$1) {\n var props = ALL[name$$1];\n\n Player.prototype[props.getterName] = function () {\n if (this.tech_) {\n return this.tech_[props.getterName]();\n } // if we have not yet loadTech_, we create {video,audio,text}Tracks_\n // these will be passed to the tech during loading\n\n\n this[props.privateName] = this[props.privateName] || new props.ListClass();\n return this[props.privateName];\n };\n});\n/**\n * Global enumeration of players.\n *\n * The keys are the player IDs and the values are either the {@link Player}\n * instance or `null` for disposed players.\n *\n * @type {Object}\n */\n\nPlayer.players = {};\nvar navigator = window$1.navigator;\n/*\n * Player instance options, surfaced using options\n * options = Player.prototype.options_\n * Make changes in options, not here.\n *\n * @type {Object}\n * @private\n */\n\nPlayer.prototype.options_ = {\n // Default order of fallback technology\n techOrder: Tech.defaultTechOrder_,\n html5: {},\n flash: {},\n // default inactivity timeout\n inactivityTimeout: 2000,\n // default playback rates\n playbackRates: [],\n // Add playback rate selection by adding rates\n // 'playbackRates': [0.5, 1, 1.5, 2],\n liveui: false,\n // Included control sets\n children: ['mediaLoader', 'posterImage', 'textTrackDisplay', 'loadingSpinner', 'bigPlayButton', 'liveTracker', 'controlBar', 'errorDisplay', 'textTrackSettings', 'resizeManager'],\n language: navigator && (navigator.languages && navigator.languages[0] || navigator.userLanguage || navigator.language) || 'en',\n // locales and their language translations\n languages: {},\n // Default message to show when a video cannot be played.\n notSupportedMessage: 'No compatible source was found for this media.',\n breakpoints: {},\n responsive: false\n};\n[\n/**\n * Returns whether or not the player is in the \"ended\" state.\n *\n * @return {Boolean} True if the player is in the ended state, false if not.\n * @method Player#ended\n */\n'ended',\n/**\n * Returns whether or not the player is in the \"seeking\" state.\n *\n * @return {Boolean} True if the player is in the seeking state, false if not.\n * @method Player#seeking\n */\n'seeking',\n/**\n * Returns the TimeRanges of the media that are currently available\n * for seeking to.\n *\n * @return {TimeRanges} the seekable intervals of the media timeline\n * @method Player#seekable\n */\n'seekable',\n/**\n * Returns the current state of network activity for the element, from\n * the codes in the list below.\n * - NETWORK_EMPTY (numeric value 0)\n * The element has not yet been initialised. All attributes are in\n * their initial states.\n * - NETWORK_IDLE (numeric value 1)\n * The element's resource selection algorithm is active and has\n * selected a resource, but it is not actually using the network at\n * this time.\n * - NETWORK_LOADING (numeric value 2)\n * The user agent is actively trying to download data.\n * - NETWORK_NO_SOURCE (numeric value 3)\n * The element's resource selection algorithm is active, but it has\n * not yet found a resource to use.\n *\n * @see https://html.spec.whatwg.org/multipage/embedded-content.html#network-states\n * @return {number} the current network activity state\n * @method Player#networkState\n */\n'networkState',\n/**\n * Returns a value that expresses the current state of the element\n * with respect to rendering the current playback position, from the\n * codes in the list below.\n * - HAVE_NOTHING (numeric value 0)\n * No information regarding the media resource is available.\n * - HAVE_METADATA (numeric value 1)\n * Enough of the resource has been obtained that the duration of the\n * resource is available.\n * - HAVE_CURRENT_DATA (numeric value 2)\n * Data for the immediate current playback position is available.\n * - HAVE_FUTURE_DATA (numeric value 3)\n * Data for the immediate current playback position is available, as\n * well as enough data for the user agent to advance the current\n * playback position in the direction of playback.\n * - HAVE_ENOUGH_DATA (numeric value 4)\n * The user agent estimates that enough data is available for\n * playback to proceed uninterrupted.\n *\n * @see https://html.spec.whatwg.org/multipage/embedded-content.html#dom-media-readystate\n * @return {number} the current playback rendering state\n * @method Player#readyState\n */\n'readyState'].forEach(function (fn) {\n Player.prototype[fn] = function () {\n return this.techGet_(fn);\n };\n});\nTECH_EVENTS_RETRIGGER.forEach(function (event) {\n Player.prototype[\"handleTech\" + toTitleCase(event) + \"_\"] = function () {\n return this.trigger(event);\n };\n});\n/**\n * Fired when the player has initial duration and dimension information\n *\n * @event Player#loadedmetadata\n * @type {EventTarget~Event}\n */\n\n/**\n * Fired when the player has downloaded data at the current playback position\n *\n * @event Player#loadeddata\n * @type {EventTarget~Event}\n */\n\n/**\n * Fired when the current playback position has changed *\n * During playback this is fired every 15-250 milliseconds, depending on the\n * playback technology in use.\n *\n * @event Player#timeupdate\n * @type {EventTarget~Event}\n */\n\n/**\n * Fired when the volume changes\n *\n * @event Player#volumechange\n * @type {EventTarget~Event}\n */\n\n/**\n * Reports whether or not a player has a plugin available.\n *\n * This does not report whether or not the plugin has ever been initialized\n * on this player. For that, [usingPlugin]{@link Player#usingPlugin}.\n *\n * @method Player#hasPlugin\n * @param {string} name\n * The name of a plugin.\n *\n * @return {boolean}\n * Whether or not this player has the requested plugin available.\n */\n\n/**\n * Reports whether or not a player is using a plugin by name.\n *\n * For basic plugins, this only reports whether the plugin has _ever_ been\n * initialized on this player.\n *\n * @method Player#usingPlugin\n * @param {string} name\n * The name of a plugin.\n *\n * @return {boolean}\n * Whether or not this player is using the requested plugin.\n */\n\nComponent.registerComponent('Player', Player);\n\n/**\n * The base plugin name.\n *\n * @private\n * @constant\n * @type {string}\n */\n\nvar BASE_PLUGIN_NAME = 'plugin';\n/**\n * The key on which a player's active plugins cache is stored.\n *\n * @private\n * @constant\n * @type {string}\n */\n\nvar PLUGIN_CACHE_KEY = 'activePlugins_';\n/**\n * Stores registered plugins in a private space.\n *\n * @private\n * @type {Object}\n */\n\nvar pluginStorage = {};\n/**\n * Reports whether or not a plugin has been registered.\n *\n * @private\n * @param {string} name\n * The name of a plugin.\n *\n * @return {boolean}\n * Whether or not the plugin has been registered.\n */\n\nvar pluginExists = function pluginExists(name) {\n return pluginStorage.hasOwnProperty(name);\n};\n/**\n * Get a single registered plugin by name.\n *\n * @private\n * @param {string} name\n * The name of a plugin.\n *\n * @return {Function|undefined}\n * The plugin (or undefined).\n */\n\n\nvar getPlugin = function getPlugin(name) {\n return pluginExists(name) ? pluginStorage[name] : undefined;\n};\n/**\n * Marks a plugin as \"active\" on a player.\n *\n * Also, ensures that the player has an object for tracking active plugins.\n *\n * @private\n * @param {Player} player\n * A Video.js player instance.\n *\n * @param {string} name\n * The name of a plugin.\n */\n\n\nvar markPluginAsActive = function markPluginAsActive(player, name) {\n player[PLUGIN_CACHE_KEY] = player[PLUGIN_CACHE_KEY] || {};\n player[PLUGIN_CACHE_KEY][name] = true;\n};\n/**\n * Triggers a pair of plugin setup events.\n *\n * @private\n * @param {Player} player\n * A Video.js player instance.\n *\n * @param {Plugin~PluginEventHash} hash\n * A plugin event hash.\n *\n * @param {boolean} [before]\n * If true, prefixes the event name with \"before\". In other words,\n * use this to trigger \"beforepluginsetup\" instead of \"pluginsetup\".\n */\n\n\nvar triggerSetupEvent = function triggerSetupEvent(player, hash, before) {\n var eventName = (before ? 'before' : '') + 'pluginsetup';\n player.trigger(eventName, hash);\n player.trigger(eventName + ':' + hash.name, hash);\n};\n/**\n * Takes a basic plugin function and returns a wrapper function which marks\n * on the player that the plugin has been activated.\n *\n * @private\n * @param {string} name\n * The name of the plugin.\n *\n * @param {Function} plugin\n * The basic plugin.\n *\n * @return {Function}\n * A wrapper function for the given plugin.\n */\n\n\nvar createBasicPlugin = function createBasicPlugin(name, plugin) {\n var basicPluginWrapper = function basicPluginWrapper() {\n // We trigger the \"beforepluginsetup\" and \"pluginsetup\" events on the player\n // regardless, but we want the hash to be consistent with the hash provided\n // for advanced plugins.\n //\n // The only potentially counter-intuitive thing here is the `instance` in\n // the \"pluginsetup\" event is the value returned by the `plugin` function.\n triggerSetupEvent(this, {\n name: name,\n plugin: plugin,\n instance: null\n }, true);\n var instance = plugin.apply(this, arguments);\n markPluginAsActive(this, name);\n triggerSetupEvent(this, {\n name: name,\n plugin: plugin,\n instance: instance\n });\n return instance;\n };\n\n Object.keys(plugin).forEach(function (prop) {\n basicPluginWrapper[prop] = plugin[prop];\n });\n return basicPluginWrapper;\n};\n/**\n * Takes a plugin sub-class and returns a factory function for generating\n * instances of it.\n *\n * This factory function will replace itself with an instance of the requested\n * sub-class of Plugin.\n *\n * @private\n * @param {string} name\n * The name of the plugin.\n *\n * @param {Plugin} PluginSubClass\n * The advanced plugin.\n *\n * @return {Function}\n */\n\n\nvar createPluginFactory = function createPluginFactory(name, PluginSubClass) {\n // Add a `name` property to the plugin prototype so that each plugin can\n // refer to itself by name.\n PluginSubClass.prototype.name = name;\n return function () {\n triggerSetupEvent(this, {\n name: name,\n plugin: PluginSubClass,\n instance: null\n }, true);\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var instance = _construct(PluginSubClass, [this].concat(args)); // The plugin is replaced by a function that returns the current instance.\n\n\n this[name] = function () {\n return instance;\n };\n\n triggerSetupEvent(this, instance.getEventHash());\n return instance;\n };\n};\n/**\n * Parent class for all advanced plugins.\n *\n * @mixes module:evented~EventedMixin\n * @mixes module:stateful~StatefulMixin\n * @fires Player#beforepluginsetup\n * @fires Player#beforepluginsetup:$name\n * @fires Player#pluginsetup\n * @fires Player#pluginsetup:$name\n * @listens Player#dispose\n * @throws {Error}\n * If attempting to instantiate the base {@link Plugin} class\n * directly instead of via a sub-class.\n */\n\n\nvar Plugin =\n/*#__PURE__*/\nfunction () {\n /**\n * Creates an instance of this class.\n *\n * Sub-classes should call `super` to ensure plugins are properly initialized.\n *\n * @param {Player} player\n * A Video.js player instance.\n */\n function Plugin(player) {\n if (this.constructor === Plugin) {\n throw new Error('Plugin must be sub-classed; not directly instantiated.');\n }\n\n this.player = player; // Make this object evented, but remove the added `trigger` method so we\n // use the prototype version instead.\n\n evented(this);\n delete this.trigger;\n stateful(this, this.constructor.defaultState);\n markPluginAsActive(player, this.name); // Auto-bind the dispose method so we can use it as a listener and unbind\n // it later easily.\n\n this.dispose = bind(this, this.dispose); // If the player is disposed, dispose the plugin.\n\n player.on('dispose', this.dispose);\n }\n /**\n * Get the version of the plugin that was set on <pluginName>.VERSION\n */\n\n\n var _proto = Plugin.prototype;\n\n _proto.version = function version() {\n return this.constructor.VERSION;\n };\n /**\n * Each event triggered by plugins includes a hash of additional data with\n * conventional properties.\n *\n * This returns that object or mutates an existing hash.\n *\n * @param {Object} [hash={}]\n * An object to be used as event an event hash.\n *\n * @return {Plugin~PluginEventHash}\n * An event hash object with provided properties mixed-in.\n */\n\n\n _proto.getEventHash = function getEventHash(hash) {\n if (hash === void 0) {\n hash = {};\n }\n\n hash.name = this.name;\n hash.plugin = this.constructor;\n hash.instance = this;\n return hash;\n };\n /**\n * Triggers an event on the plugin object and overrides\n * {@link module:evented~EventedMixin.trigger|EventedMixin.trigger}.\n *\n * @param {string|Object} event\n * An event type or an object with a type property.\n *\n * @param {Object} [hash={}]\n * Additional data hash to merge with a\n * {@link Plugin~PluginEventHash|PluginEventHash}.\n *\n * @return {boolean}\n * Whether or not default was prevented.\n */\n\n\n _proto.trigger = function trigger$$1(event, hash) {\n if (hash === void 0) {\n hash = {};\n }\n\n return trigger(this.eventBusEl_, event, this.getEventHash(hash));\n };\n /**\n * Handles \"statechanged\" events on the plugin. No-op by default, override by\n * subclassing.\n *\n * @abstract\n * @param {Event} e\n * An event object provided by a \"statechanged\" event.\n *\n * @param {Object} e.changes\n * An object describing changes that occurred with the \"statechanged\"\n * event.\n */\n\n\n _proto.handleStateChanged = function handleStateChanged(e) {};\n /**\n * Disposes a plugin.\n *\n * Subclasses can override this if they want, but for the sake of safety,\n * it's probably best to subscribe the \"dispose\" event.\n *\n * @fires Plugin#dispose\n */\n\n\n _proto.dispose = function dispose() {\n var name = this.name,\n player = this.player;\n /**\n * Signals that a advanced plugin is about to be disposed.\n *\n * @event Plugin#dispose\n * @type {EventTarget~Event}\n */\n\n this.trigger('dispose');\n this.off();\n player.off('dispose', this.dispose); // Eliminate any possible sources of leaking memory by clearing up\n // references between the player and the plugin instance and nulling out\n // the plugin's state and replacing methods with a function that throws.\n\n player[PLUGIN_CACHE_KEY][name] = false;\n this.player = this.state = null; // Finally, replace the plugin name on the player with a new factory\n // function, so that the plugin is ready to be set up again.\n\n player[name] = createPluginFactory(name, pluginStorage[name]);\n };\n /**\n * Determines if a plugin is a basic plugin (i.e. not a sub-class of `Plugin`).\n *\n * @param {string|Function} plugin\n * If a string, matches the name of a plugin. If a function, will be\n * tested directly.\n *\n * @return {boolean}\n * Whether or not a plugin is a basic plugin.\n */\n\n\n Plugin.isBasic = function isBasic(plugin) {\n var p = typeof plugin === 'string' ? getPlugin(plugin) : plugin;\n return typeof p === 'function' && !Plugin.prototype.isPrototypeOf(p.prototype);\n };\n /**\n * Register a Video.js plugin.\n *\n * @param {string} name\n * The name of the plugin to be registered. Must be a string and\n * must not match an existing plugin or a method on the `Player`\n * prototype.\n *\n * @param {Function} plugin\n * A sub-class of `Plugin` or a function for basic plugins.\n *\n * @return {Function}\n * For advanced plugins, a factory function for that plugin. For\n * basic plugins, a wrapper function that initializes the plugin.\n */\n\n\n Plugin.registerPlugin = function registerPlugin(name, plugin) {\n if (typeof name !== 'string') {\n throw new Error(\"Illegal plugin name, \\\"\" + name + \"\\\", must be a string, was \" + typeof name + \".\");\n }\n\n if (pluginExists(name)) {\n log.warn(\"A plugin named \\\"\" + name + \"\\\" already exists. You may want to avoid re-registering plugins!\");\n } else if (Player.prototype.hasOwnProperty(name)) {\n throw new Error(\"Illegal plugin name, \\\"\" + name + \"\\\", cannot share a name with an existing player method!\");\n }\n\n if (typeof plugin !== 'function') {\n throw new Error(\"Illegal plugin for \\\"\" + name + \"\\\", must be a function, was \" + typeof plugin + \".\");\n }\n\n pluginStorage[name] = plugin; // Add a player prototype method for all sub-classed plugins (but not for\n // the base Plugin class).\n\n if (name !== BASE_PLUGIN_NAME) {\n if (Plugin.isBasic(plugin)) {\n Player.prototype[name] = createBasicPlugin(name, plugin);\n } else {\n Player.prototype[name] = createPluginFactory(name, plugin);\n }\n }\n\n return plugin;\n };\n /**\n * De-register a Video.js plugin.\n *\n * @param {string} name\n * The name of the plugin to be de-registered. Must be a string that\n * matches an existing plugin.\n *\n * @throws {Error}\n * If an attempt is made to de-register the base plugin.\n */\n\n\n Plugin.deregisterPlugin = function deregisterPlugin(name) {\n if (name === BASE_PLUGIN_NAME) {\n throw new Error('Cannot de-register base plugin.');\n }\n\n if (pluginExists(name)) {\n delete pluginStorage[name];\n delete Player.prototype[name];\n }\n };\n /**\n * Gets an object containing multiple Video.js plugins.\n *\n * @param {Array} [names]\n * If provided, should be an array of plugin names. Defaults to _all_\n * plugin names.\n *\n * @return {Object|undefined}\n * An object containing plugin(s) associated with their name(s) or\n * `undefined` if no matching plugins exist).\n */\n\n\n Plugin.getPlugins = function getPlugins(names) {\n if (names === void 0) {\n names = Object.keys(pluginStorage);\n }\n\n var result;\n names.forEach(function (name) {\n var plugin = getPlugin(name);\n\n if (plugin) {\n result = result || {};\n result[name] = plugin;\n }\n });\n return result;\n };\n /**\n * Gets a plugin's version, if available\n *\n * @param {string} name\n * The name of a plugin.\n *\n * @return {string}\n * The plugin's version or an empty string.\n */\n\n\n Plugin.getPluginVersion = function getPluginVersion(name) {\n var plugin = getPlugin(name);\n return plugin && plugin.VERSION || '';\n };\n\n return Plugin;\n}();\n/**\n * Gets a plugin by name if it exists.\n *\n * @static\n * @method getPlugin\n * @memberOf Plugin\n * @param {string} name\n * The name of a plugin.\n *\n * @returns {Function|undefined}\n * The plugin (or `undefined`).\n */\n\n\nPlugin.getPlugin = getPlugin;\n/**\n * The name of the base plugin class as it is registered.\n *\n * @type {string}\n */\n\nPlugin.BASE_PLUGIN_NAME = BASE_PLUGIN_NAME;\nPlugin.registerPlugin(BASE_PLUGIN_NAME, Plugin);\n/**\n * Documented in player.js\n *\n * @ignore\n */\n\nPlayer.prototype.usingPlugin = function (name) {\n return !!this[PLUGIN_CACHE_KEY] && this[PLUGIN_CACHE_KEY][name] === true;\n};\n/**\n * Documented in player.js\n *\n * @ignore\n */\n\n\nPlayer.prototype.hasPlugin = function (name) {\n return !!pluginExists(name);\n};\n/**\n * Signals that a plugin is about to be set up on a player.\n *\n * @event Player#beforepluginsetup\n * @type {Plugin~PluginEventHash}\n */\n\n/**\n * Signals that a plugin is about to be set up on a player - by name. The name\n * is the name of the plugin.\n *\n * @event Player#beforepluginsetup:$name\n * @type {Plugin~PluginEventHash}\n */\n\n/**\n * Signals that a plugin has just been set up on a player.\n *\n * @event Player#pluginsetup\n * @type {Plugin~PluginEventHash}\n */\n\n/**\n * Signals that a plugin has just been set up on a player - by name. The name\n * is the name of the plugin.\n *\n * @event Player#pluginsetup:$name\n * @type {Plugin~PluginEventHash}\n */\n\n/**\n * @typedef {Object} Plugin~PluginEventHash\n *\n * @property {string} instance\n * For basic plugins, the return value of the plugin function. For\n * advanced plugins, the plugin instance on which the event is fired.\n *\n * @property {string} name\n * The name of the plugin.\n *\n * @property {string} plugin\n * For basic plugins, the plugin function. For advanced plugins, the\n * plugin class/constructor.\n */\n\n/**\n * @file extend.js\n * @module extend\n */\n\n/**\n * A combination of node inherits and babel's inherits (after transpile).\n * Both work the same but node adds `super_` to the subClass\n * and Bable adds the superClass as __proto__. Both seem useful.\n *\n * @param {Object} subClass\n * The class to inherit to\n *\n * @param {Object} superClass\n * The class to inherit from\n *\n * @private\n */\nvar _inherits$1 = function _inherits(subClass, superClass) {\n if (typeof superClass !== 'function' && superClass !== null) {\n throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass);\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n\n if (superClass) {\n // node\n subClass.super_ = superClass;\n }\n};\n/**\n * Used to subclass an existing class by emulating ES subclassing using the\n * `extends` keyword.\n *\n * @function\n * @example\n * var MyComponent = videojs.extend(videojs.getComponent('Component'), {\n * myCustomMethod: function() {\n * // Do things in my method.\n * }\n * });\n *\n * @param {Function} superClass\n * The class to inherit from\n *\n * @param {Object} [subClassMethods={}]\n * Methods of the new class\n *\n * @return {Function}\n * The new class with subClassMethods that inherited superClass.\n */\n\n\nvar extend = function extend(superClass, subClassMethods) {\n if (subClassMethods === void 0) {\n subClassMethods = {};\n }\n\n var subClass = function subClass() {\n superClass.apply(this, arguments);\n };\n\n var methods = {};\n\n if (typeof subClassMethods === 'object') {\n if (subClassMethods.constructor !== Object.prototype.constructor) {\n subClass = subClassMethods.constructor;\n }\n\n methods = subClassMethods;\n } else if (typeof subClassMethods === 'function') {\n subClass = subClassMethods;\n }\n\n _inherits$1(subClass, superClass); // Extend subObj's prototype with functions and other properties from props\n\n\n for (var name in methods) {\n if (methods.hasOwnProperty(name)) {\n subClass.prototype[name] = methods[name];\n }\n }\n\n return subClass;\n};\n\n/**\n * @file video.js\n * @module videojs\n */\n/**\n * Normalize an `id` value by trimming off a leading `#`\n *\n * @private\n * @param {string} id\n * A string, maybe with a leading `#`.\n *\n * @return {string}\n * The string, without any leading `#`.\n */\n\nvar normalizeId = function normalizeId(id) {\n return id.indexOf('#') === 0 ? id.slice(1) : id;\n};\n/**\n * The `videojs()` function doubles as the main function for users to create a\n * {@link Player} instance as well as the main library namespace.\n *\n * It can also be used as a getter for a pre-existing {@link Player} instance.\n * However, we _strongly_ recommend using `videojs.getPlayer()` for this\n * purpose because it avoids any potential for unintended initialization.\n *\n * Due to [limitations](https://github.com/jsdoc3/jsdoc/issues/955#issuecomment-313829149)\n * of our JSDoc template, we cannot properly document this as both a function\n * and a namespace, so its function signature is documented here.\n *\n * #### Arguments\n * ##### id\n * string|Element, **required**\n *\n * Video element or video element ID.\n *\n * ##### options\n * Object, optional\n *\n * Options object for providing settings.\n * See: [Options Guide](https://docs.videojs.com/tutorial-options.html).\n *\n * ##### ready\n * {@link Component~ReadyCallback}, optional\n *\n * A function to be called when the {@link Player} and {@link Tech} are ready.\n *\n * #### Return Value\n *\n * The `videojs()` function returns a {@link Player} instance.\n *\n * @namespace\n *\n * @borrows AudioTrack as AudioTrack\n * @borrows Component.getComponent as getComponent\n * @borrows module:computed-style~computedStyle as computedStyle\n * @borrows module:events.on as on\n * @borrows module:events.one as one\n * @borrows module:events.off as off\n * @borrows module:events.trigger as trigger\n * @borrows EventTarget as EventTarget\n * @borrows module:extend~extend as extend\n * @borrows module:fn.bind as bind\n * @borrows module:format-time.formatTime as formatTime\n * @borrows module:format-time.resetFormatTime as resetFormatTime\n * @borrows module:format-time.setFormatTime as setFormatTime\n * @borrows module:merge-options.mergeOptions as mergeOptions\n * @borrows module:middleware.use as use\n * @borrows Player.players as players\n * @borrows Plugin.registerPlugin as registerPlugin\n * @borrows Plugin.deregisterPlugin as deregisterPlugin\n * @borrows Plugin.getPlugins as getPlugins\n * @borrows Plugin.getPlugin as getPlugin\n * @borrows Plugin.getPluginVersion as getPluginVersion\n * @borrows Tech.getTech as getTech\n * @borrows Tech.registerTech as registerTech\n * @borrows TextTrack as TextTrack\n * @borrows module:time-ranges.createTimeRanges as createTimeRange\n * @borrows module:time-ranges.createTimeRanges as createTimeRanges\n * @borrows module:url.isCrossOrigin as isCrossOrigin\n * @borrows module:url.parseUrl as parseUrl\n * @borrows VideoTrack as VideoTrack\n *\n * @param {string|Element} id\n * Video element or video element ID.\n *\n * @param {Object} [options]\n * Options object for providing settings.\n * See: [Options Guide](https://docs.videojs.com/tutorial-options.html).\n *\n * @param {Component~ReadyCallback} [ready]\n * A function to be called when the {@link Player} and {@link Tech} are\n * ready.\n *\n * @return {Player}\n * The `videojs()` function returns a {@link Player|Player} instance.\n */\n\n\nfunction videojs$1(id, options, ready) {\n var player = videojs$1.getPlayer(id);\n\n if (player) {\n if (options) {\n log.warn(\"Player \\\"\" + id + \"\\\" is already initialised. Options will not be applied.\");\n }\n\n if (ready) {\n player.ready(ready);\n }\n\n return player;\n }\n\n var el = typeof id === 'string' ? $('#' + normalizeId(id)) : id;\n\n if (!isEl(el)) {\n throw new TypeError('The element or ID supplied is not valid. (videojs)');\n }\n\n if (!document.body.contains(el)) {\n log.warn('The element supplied is not included in the DOM');\n }\n\n options = options || {};\n videojs$1.hooks('beforesetup').forEach(function (hookFunction) {\n var opts = hookFunction(el, mergeOptions(options));\n\n if (!isObject(opts) || Array.isArray(opts)) {\n log.error('please return an object in beforesetup hooks');\n return;\n }\n\n options = mergeOptions(options, opts);\n }); // We get the current \"Player\" component here in case an integration has\n // replaced it with a custom player.\n\n var PlayerComponent = Component.getComponent('Player');\n player = new PlayerComponent(el, options, ready);\n videojs$1.hooks('setup').forEach(function (hookFunction) {\n return hookFunction(player);\n });\n return player;\n}\n/**\n * An Object that contains lifecycle hooks as keys which point to an array\n * of functions that are run when a lifecycle is triggered\n *\n * @private\n */\n\n\nvideojs$1.hooks_ = {};\n/**\n * Get a list of hooks for a specific lifecycle\n *\n * @param {string} type\n * the lifecyle to get hooks from\n *\n * @param {Function|Function[]} [fn]\n * Optionally add a hook (or hooks) to the lifecycle that your are getting.\n *\n * @return {Array}\n * an array of hooks, or an empty array if there are none.\n */\n\nvideojs$1.hooks = function (type, fn) {\n videojs$1.hooks_[type] = videojs$1.hooks_[type] || [];\n\n if (fn) {\n videojs$1.hooks_[type] = videojs$1.hooks_[type].concat(fn);\n }\n\n return videojs$1.hooks_[type];\n};\n/**\n * Add a function hook to a specific videojs lifecycle.\n *\n * @param {string} type\n * the lifecycle to hook the function to.\n *\n * @param {Function|Function[]}\n * The function or array of functions to attach.\n */\n\n\nvideojs$1.hook = function (type, fn) {\n videojs$1.hooks(type, fn);\n};\n/**\n * Add a function hook that will only run once to a specific videojs lifecycle.\n *\n * @param {string} type\n * the lifecycle to hook the function to.\n *\n * @param {Function|Function[]}\n * The function or array of functions to attach.\n */\n\n\nvideojs$1.hookOnce = function (type, fn) {\n videojs$1.hooks(type, [].concat(fn).map(function (original) {\n var wrapper = function wrapper() {\n videojs$1.removeHook(type, wrapper);\n return original.apply(void 0, arguments);\n };\n\n return wrapper;\n }));\n};\n/**\n * Remove a hook from a specific videojs lifecycle.\n *\n * @param {string} type\n * the lifecycle that the function hooked to\n *\n * @param {Function} fn\n * The hooked function to remove\n *\n * @return {boolean}\n * The function that was removed or undef\n */\n\n\nvideojs$1.removeHook = function (type, fn) {\n var index = videojs$1.hooks(type).indexOf(fn);\n\n if (index <= -1) {\n return false;\n }\n\n videojs$1.hooks_[type] = videojs$1.hooks_[type].slice();\n videojs$1.hooks_[type].splice(index, 1);\n return true;\n}; // Add default styles\n\n\nif (window$1.VIDEOJS_NO_DYNAMIC_STYLE !== true && isReal()) {\n var style$1 = $('.vjs-styles-defaults');\n\n if (!style$1) {\n style$1 = createStyleElement('vjs-styles-defaults');\n var head = $('head');\n\n if (head) {\n head.insertBefore(style$1, head.firstChild);\n }\n\n setTextContent(style$1, \"\\n .video-js {\\n width: 300px;\\n height: 150px;\\n }\\n\\n .vjs-fluid {\\n padding-top: 56.25%\\n }\\n \");\n }\n} // Run Auto-load players\n// You have to wait at least once in case this script is loaded after your\n// video in the DOM (weird behavior only with minified version)\n\n\nautoSetupTimeout(1, videojs$1);\n/**\n * Current Video.js version. Follows [semantic versioning](https://semver.org/).\n *\n * @type {string}\n */\n\nvideojs$1.VERSION = version;\n/**\n * The global options object. These are the settings that take effect\n * if no overrides are specified when the player is created.\n *\n * @type {Object}\n */\n\nvideojs$1.options = Player.prototype.options_;\n/**\n * Get an object with the currently created players, keyed by player ID\n *\n * @return {Object}\n * The created players\n */\n\nvideojs$1.getPlayers = function () {\n return Player.players;\n};\n/**\n * Get a single player based on an ID or DOM element.\n *\n * This is useful if you want to check if an element or ID has an associated\n * Video.js player, but not create one if it doesn't.\n *\n * @param {string|Element} id\n * An HTML element - `<video>`, `<audio>`, or `<video-js>` -\n * or a string matching the `id` of such an element.\n *\n * @return {Player|undefined}\n * A player instance or `undefined` if there is no player instance\n * matching the argument.\n */\n\n\nvideojs$1.getPlayer = function (id) {\n var players = Player.players;\n var tag;\n\n if (typeof id === 'string') {\n var nId = normalizeId(id);\n var player = players[nId];\n\n if (player) {\n return player;\n }\n\n tag = $('#' + nId);\n } else {\n tag = id;\n }\n\n if (isEl(tag)) {\n var _tag = tag,\n _player = _tag.player,\n playerId = _tag.playerId; // Element may have a `player` property referring to an already created\n // player instance. If so, return that.\n\n if (_player || players[playerId]) {\n return _player || players[playerId];\n }\n }\n};\n/**\n * Returns an array of all current players.\n *\n * @return {Array}\n * An array of all players. The array will be in the order that\n * `Object.keys` provides, which could potentially vary between\n * JavaScript engines.\n *\n */\n\n\nvideojs$1.getAllPlayers = function () {\n return (// Disposed players leave a key with a `null` value, so we need to make sure\n // we filter those out.\n Object.keys(Player.players).map(function (k) {\n return Player.players[k];\n }).filter(Boolean)\n );\n};\n\nvideojs$1.players = Player.players;\nvideojs$1.getComponent = Component.getComponent;\n/**\n * Register a component so it can referred to by name. Used when adding to other\n * components, either through addChild `component.addChild('myComponent')` or through\n * default children options `{ children: ['myComponent'] }`.\n *\n * > NOTE: You could also just initialize the component before adding.\n * `component.addChild(new MyComponent());`\n *\n * @param {string} name\n * The class name of the component\n *\n * @param {Component} comp\n * The component class\n *\n * @return {Component}\n * The newly registered component\n */\n\nvideojs$1.registerComponent = function (name$$1, comp) {\n if (Tech.isTech(comp)) {\n log.warn(\"The \" + name$$1 + \" tech was registered as a component. It should instead be registered using videojs.registerTech(name, tech)\");\n }\n\n Component.registerComponent.call(Component, name$$1, comp);\n};\n\nvideojs$1.getTech = Tech.getTech;\nvideojs$1.registerTech = Tech.registerTech;\nvideojs$1.use = use;\n/**\n * An object that can be returned by a middleware to signify\n * that the middleware is being terminated.\n *\n * @type {object}\n * @property {object} middleware.TERMINATOR\n */\n\nObject.defineProperty(videojs$1, 'middleware', {\n value: {},\n writeable: false,\n enumerable: true\n});\nObject.defineProperty(videojs$1.middleware, 'TERMINATOR', {\n value: TERMINATOR,\n writeable: false,\n enumerable: true\n});\n/**\n * A reference to the {@link module:browser|browser utility module} as an object.\n *\n * @type {Object}\n * @see {@link module:browser|browser}\n */\n\nvideojs$1.browser = browser;\n/**\n * Use {@link module:browser.TOUCH_ENABLED|browser.TOUCH_ENABLED} instead; only\n * included for backward-compatibility with 4.x.\n *\n * @deprecated Since version 5.0, use {@link module:browser.TOUCH_ENABLED|browser.TOUCH_ENABLED instead.\n * @type {boolean}\n */\n\nvideojs$1.TOUCH_ENABLED = TOUCH_ENABLED;\nvideojs$1.extend = extend;\nvideojs$1.mergeOptions = mergeOptions;\nvideojs$1.bind = bind;\nvideojs$1.registerPlugin = Plugin.registerPlugin;\nvideojs$1.deregisterPlugin = Plugin.deregisterPlugin;\n/**\n * Deprecated method to register a plugin with Video.js\n *\n * @deprecated videojs.plugin() is deprecated; use videojs.registerPlugin() instead\n *\n * @param {string} name\n * The plugin name\n *\n * @param {Plugin|Function} plugin\n * The plugin sub-class or function\n */\n\nvideojs$1.plugin = function (name$$1, plugin) {\n log.warn('videojs.plugin() is deprecated; use videojs.registerPlugin() instead');\n return Plugin.registerPlugin(name$$1, plugin);\n};\n\nvideojs$1.getPlugins = Plugin.getPlugins;\nvideojs$1.getPlugin = Plugin.getPlugin;\nvideojs$1.getPluginVersion = Plugin.getPluginVersion;\n/**\n * Adding languages so that they're available to all players.\n * Example: `videojs.addLanguage('es', { 'Hello': 'Hola' });`\n *\n * @param {string} code\n * The language code or dictionary property\n *\n * @param {Object} data\n * The data values to be translated\n *\n * @return {Object}\n * The resulting language dictionary object\n */\n\nvideojs$1.addLanguage = function (code, data) {\n var _mergeOptions;\n\n code = ('' + code).toLowerCase();\n videojs$1.options.languages = mergeOptions(videojs$1.options.languages, (_mergeOptions = {}, _mergeOptions[code] = data, _mergeOptions));\n return videojs$1.options.languages[code];\n};\n/**\n * A reference to the {@link module:log|log utility module} as an object.\n *\n * @type {Function}\n * @see {@link module:log|log}\n */\n\n\nvideojs$1.log = log;\nvideojs$1.createLogger = createLogger$1;\nvideojs$1.createTimeRange = videojs$1.createTimeRanges = createTimeRanges;\nvideojs$1.formatTime = formatTime;\nvideojs$1.setFormatTime = setFormatTime;\nvideojs$1.resetFormatTime = resetFormatTime;\nvideojs$1.parseUrl = parseUrl;\nvideojs$1.isCrossOrigin = isCrossOrigin;\nvideojs$1.EventTarget = EventTarget;\nvideojs$1.on = on;\nvideojs$1.one = one;\nvideojs$1.off = off;\nvideojs$1.trigger = trigger;\n/**\n * A cross-browser XMLHttpRequest wrapper.\n *\n * @function\n * @param {Object} options\n * Settings for the request.\n *\n * @return {XMLHttpRequest|XDomainRequest}\n * The request object.\n *\n * @see https://github.com/Raynos/xhr\n */\n\nvideojs$1.xhr = xhr;\nvideojs$1.TextTrack = TextTrack;\nvideojs$1.AudioTrack = AudioTrack;\nvideojs$1.VideoTrack = VideoTrack;\n['isEl', 'isTextNode', 'createEl', 'hasClass', 'addClass', 'removeClass', 'toggleClass', 'setAttributes', 'getAttributes', 'emptyEl', 'appendContent', 'insertContent'].forEach(function (k) {\n videojs$1[k] = function () {\n log.warn(\"videojs.\" + k + \"() is deprecated; use videojs.dom.\" + k + \"() instead\");\n return Dom[k].apply(null, arguments);\n };\n});\nvideojs$1.computedStyle = computedStyle;\n/**\n * A reference to the {@link module:dom|DOM utility module} as an object.\n *\n * @type {Object}\n * @see {@link module:dom|dom}\n */\n\nvideojs$1.dom = Dom;\n/**\n * A reference to the {@link module:url|URL utility module} as an object.\n *\n * @type {Object}\n * @see {@link module:url|url}\n */\n\nvideojs$1.url = Url;\n\n/**\n * @videojs/http-streaming\n * @version 1.5.1\n * @copyright 2018 Brightcove, Inc\n * @license Apache-2.0\n */\n/**\n * @file resolve-url.js\n */\n\nvar resolveUrl = function resolveUrl(baseURL, relativeURL) {\n // return early if we don't need to resolve\n if (/^[a-z]+:/i.test(relativeURL)) {\n return relativeURL;\n } // if the base URL is relative then combine with the current location\n\n\n if (!/\\/\\//i.test(baseURL)) {\n baseURL = URLToolkit.buildAbsoluteURL(window$1.location.href, baseURL);\n }\n\n return URLToolkit.buildAbsoluteURL(baseURL, relativeURL);\n};\n\nvar classCallCheck = function classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n};\n\nvar createClass = function () {\n function defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n }\n\n return function (Constructor, protoProps, staticProps) {\n if (protoProps) defineProperties(Constructor.prototype, protoProps);\n if (staticProps) defineProperties(Constructor, staticProps);\n return Constructor;\n };\n}();\n\nvar get$1 = function get(object, property, receiver) {\n if (object === null) object = Function.prototype;\n var desc = Object.getOwnPropertyDescriptor(object, property);\n\n if (desc === undefined) {\n var parent = Object.getPrototypeOf(object);\n\n if (parent === null) {\n return undefined;\n } else {\n return get(parent, property, receiver);\n }\n } else if (\"value\" in desc) {\n return desc.value;\n } else {\n var getter = desc.get;\n\n if (getter === undefined) {\n return undefined;\n }\n\n return getter.call(receiver);\n }\n};\n\nvar inherits = function inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass);\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;\n};\n\nvar possibleConstructorReturn = function possibleConstructorReturn(self, call) {\n if (!self) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self;\n};\n\nvar slicedToArray = function () {\n function sliceIterator(arr, i) {\n var _arr = [];\n var _n = true;\n var _d = false;\n var _e = undefined;\n\n try {\n for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"]) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n }\n\n return function (arr, i) {\n if (Array.isArray(arr)) {\n return arr;\n } else if (Symbol.iterator in Object(arr)) {\n return sliceIterator(arr, i);\n } else {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n }\n };\n}();\n/**\n * @file playlist-loader.js\n *\n * A state machine that manages the loading, caching, and updating of\n * M3U8 playlists.\n *\n */\n\n\nvar mergeOptions$1 = videojs$1.mergeOptions,\n EventTarget$1 = videojs$1.EventTarget,\n log$1 = videojs$1.log;\n/**\n * Loops through all supported media groups in master and calls the provided\n * callback for each group\n *\n * @param {Object} master\n * The parsed master manifest object\n * @param {Function} callback\n * Callback to call for each media group\n */\n\nvar forEachMediaGroup = function forEachMediaGroup(master, callback) {\n ['AUDIO', 'SUBTITLES'].forEach(function (mediaType) {\n for (var groupKey in master.mediaGroups[mediaType]) {\n for (var labelKey in master.mediaGroups[mediaType][groupKey]) {\n var mediaProperties = master.mediaGroups[mediaType][groupKey][labelKey];\n callback(mediaProperties, mediaType, groupKey, labelKey);\n }\n }\n });\n};\n/**\n * Returns a new array of segments that is the result of merging\n * properties from an older list of segments onto an updated\n * list. No properties on the updated playlist will be overridden.\n *\n * @param {Array} original the outdated list of segments\n * @param {Array} update the updated list of segments\n * @param {Number=} offset the index of the first update\n * segment in the original segment list. For non-live playlists,\n * this should always be zero and does not need to be\n * specified. For live playlists, it should be the difference\n * between the media sequence numbers in the original and updated\n * playlists.\n * @return a list of merged segment objects\n */\n\n\nvar updateSegments = function updateSegments(original, update, offset) {\n var result = update.slice();\n offset = offset || 0;\n var length = Math.min(original.length, update.length + offset);\n\n for (var i = offset; i < length; i++) {\n result[i - offset] = mergeOptions$1(original[i], result[i - offset]);\n }\n\n return result;\n};\n\nvar resolveSegmentUris = function resolveSegmentUris(segment, baseUri) {\n if (!segment.resolvedUri) {\n segment.resolvedUri = resolveUrl(baseUri, segment.uri);\n }\n\n if (segment.key && !segment.key.resolvedUri) {\n segment.key.resolvedUri = resolveUrl(baseUri, segment.key.uri);\n }\n\n if (segment.map && !segment.map.resolvedUri) {\n segment.map.resolvedUri = resolveUrl(baseUri, segment.map.uri);\n }\n};\n/**\n * Returns a new master playlist that is the result of merging an\n * updated media playlist into the original version. If the\n * updated media playlist does not match any of the playlist\n * entries in the original master playlist, null is returned.\n *\n * @param {Object} master a parsed master M3U8 object\n * @param {Object} media a parsed media M3U8 object\n * @return {Object} a new object that represents the original\n * master playlist with the updated media playlist merged in, or\n * null if the merge produced no change.\n */\n\n\nvar updateMaster = function updateMaster(master, media) {\n var result = mergeOptions$1(master, {});\n var playlist = result.playlists[media.uri];\n\n if (!playlist) {\n return null;\n } // consider the playlist unchanged if the number of segments is equal and the media\n // sequence number is unchanged\n\n\n if (playlist.segments && media.segments && playlist.segments.length === media.segments.length && playlist.mediaSequence === media.mediaSequence) {\n return null;\n }\n\n var mergedPlaylist = mergeOptions$1(playlist, media); // if the update could overlap existing segment information, merge the two segment lists\n\n if (playlist.segments) {\n mergedPlaylist.segments = updateSegments(playlist.segments, media.segments, media.mediaSequence - playlist.mediaSequence);\n } // resolve any segment URIs to prevent us from having to do it later\n\n\n mergedPlaylist.segments.forEach(function (segment) {\n resolveSegmentUris(segment, mergedPlaylist.resolvedUri);\n }); // TODO Right now in the playlists array there are two references to each playlist, one\n // that is referenced by index, and one by URI. The index reference may no longer be\n // necessary.\n\n for (var i = 0; i < result.playlists.length; i++) {\n if (result.playlists[i].uri === media.uri) {\n result.playlists[i] = mergedPlaylist;\n }\n }\n\n result.playlists[media.uri] = mergedPlaylist;\n return result;\n};\n\nvar setupMediaPlaylists = function setupMediaPlaylists(master) {\n // setup by-URI lookups and resolve media playlist URIs\n var i = master.playlists.length;\n\n while (i--) {\n var playlist = master.playlists[i];\n master.playlists[playlist.uri] = playlist;\n playlist.resolvedUri = resolveUrl(master.uri, playlist.uri);\n playlist.id = i;\n\n if (!playlist.attributes) {\n // Although the spec states an #EXT-X-STREAM-INF tag MUST have a\n // BANDWIDTH attribute, we can play the stream without it. This means a poorly\n // formatted master playlist may not have an attribute list. An attributes\n // property is added here to prevent undefined references when we encounter\n // this scenario.\n playlist.attributes = {};\n log$1.warn('Invalid playlist STREAM-INF detected. Missing BANDWIDTH attribute.');\n }\n }\n};\n\nvar resolveMediaGroupUris = function resolveMediaGroupUris(master) {\n forEachMediaGroup(master, function (properties) {\n if (properties.uri) {\n properties.resolvedUri = resolveUrl(master.uri, properties.uri);\n }\n });\n};\n/**\n * Calculates the time to wait before refreshing a live playlist\n *\n * @param {Object} media\n * The current media\n * @param {Boolean} update\n * True if there were any updates from the last refresh, false otherwise\n * @return {Number}\n * The time in ms to wait before refreshing the live playlist\n */\n\n\nvar refreshDelay = function refreshDelay(media, update) {\n var lastSegment = media.segments[media.segments.length - 1];\n var delay = void 0;\n\n if (update && lastSegment && lastSegment.duration) {\n delay = lastSegment.duration * 1000;\n } else {\n // if the playlist is unchanged since the last reload or last segment duration\n // cannot be determined, try again after half the target duration\n delay = (media.targetDuration || 10) * 500;\n }\n\n return delay;\n};\n/**\n * Load a playlist from a remote location\n *\n * @class PlaylistLoader\n * @extends Stream\n * @param {String} srcUrl the url to start with\n * @param {Boolean} withCredentials the withCredentials xhr option\n * @constructor\n */\n\n\nvar PlaylistLoader = function (_EventTarget) {\n inherits(PlaylistLoader, _EventTarget);\n\n function PlaylistLoader(srcUrl, hls, withCredentials) {\n classCallCheck(this, PlaylistLoader);\n\n var _this = possibleConstructorReturn(this, (PlaylistLoader.__proto__ || Object.getPrototypeOf(PlaylistLoader)).call(this));\n\n _this.srcUrl = srcUrl;\n _this.hls_ = hls;\n _this.withCredentials = withCredentials;\n\n if (!_this.srcUrl) {\n throw new Error('A non-empty playlist URL is required');\n } // initialize the loader state\n\n\n _this.state = 'HAVE_NOTHING'; // live playlist staleness timeout\n\n _this.on('mediaupdatetimeout', function () {\n if (_this.state !== 'HAVE_METADATA') {\n // only refresh the media playlist if no other activity is going on\n return;\n }\n\n _this.state = 'HAVE_CURRENT_METADATA';\n _this.request = _this.hls_.xhr({\n uri: resolveUrl(_this.master.uri, _this.media().uri),\n withCredentials: _this.withCredentials\n }, function (error, req) {\n // disposed\n if (!_this.request) {\n return;\n }\n\n if (error) {\n return _this.playlistRequestError(_this.request, _this.media().uri, 'HAVE_METADATA');\n }\n\n _this.haveMetadata(_this.request, _this.media().uri);\n });\n });\n\n return _this;\n }\n\n createClass(PlaylistLoader, [{\n key: 'playlistRequestError',\n value: function playlistRequestError(xhr$$1, url, startingState) {\n // any in-flight request is now finished\n this.request = null;\n\n if (startingState) {\n this.state = startingState;\n }\n\n this.error = {\n playlist: this.master.playlists[url],\n status: xhr$$1.status,\n message: 'HLS playlist request error at URL: ' + url,\n responseText: xhr$$1.responseText,\n code: xhr$$1.status >= 500 ? 4 : 2\n };\n this.trigger('error');\n } // update the playlist loader's state in response to a new or\n // updated playlist.\n\n }, {\n key: 'haveMetadata',\n value: function haveMetadata(xhr$$1, url) {\n var _this2 = this; // any in-flight request is now finished\n\n\n this.request = null;\n this.state = 'HAVE_METADATA';\n var parser = new Parser();\n parser.push(xhr$$1.responseText);\n parser.end();\n parser.manifest.uri = url; // m3u8-parser does not attach an attributes property to media playlists so make\n // sure that the property is attached to avoid undefined reference errors\n\n parser.manifest.attributes = parser.manifest.attributes || {}; // merge this playlist into the master\n\n var update = updateMaster(this.master, parser.manifest);\n this.targetDuration = parser.manifest.targetDuration;\n\n if (update) {\n this.master = update;\n this.media_ = this.master.playlists[parser.manifest.uri];\n } else {\n this.trigger('playlistunchanged');\n } // refresh live playlists after a target duration passes\n\n\n if (!this.media().endList) {\n window$1.clearTimeout(this.mediaUpdateTimeout);\n this.mediaUpdateTimeout = window$1.setTimeout(function () {\n _this2.trigger('mediaupdatetimeout');\n }, refreshDelay(this.media(), !!update));\n }\n\n this.trigger('loadedplaylist');\n }\n /**\n * Abort any outstanding work and clean up.\n */\n\n }, {\n key: 'dispose',\n value: function dispose() {\n this.stopRequest();\n window$1.clearTimeout(this.mediaUpdateTimeout);\n }\n }, {\n key: 'stopRequest',\n value: function stopRequest() {\n if (this.request) {\n var oldRequest = this.request;\n this.request = null;\n oldRequest.onreadystatechange = null;\n oldRequest.abort();\n }\n }\n /**\n * When called without any arguments, returns the currently\n * active media playlist. When called with a single argument,\n * triggers the playlist loader to asynchronously switch to the\n * specified media playlist. Calling this method while the\n * loader is in the HAVE_NOTHING causes an error to be emitted\n * but otherwise has no effect.\n *\n * @param {Object=} playlist the parsed media playlist\n * object to switch to\n * @return {Playlist} the current loaded media\n */\n\n }, {\n key: 'media',\n value: function media(playlist) {\n var _this3 = this; // getter\n\n\n if (!playlist) {\n return this.media_;\n } // setter\n\n\n if (this.state === 'HAVE_NOTHING') {\n throw new Error('Cannot switch media playlist from ' + this.state);\n }\n\n var startingState = this.state; // find the playlist object if the target playlist has been\n // specified by URI\n\n if (typeof playlist === 'string') {\n if (!this.master.playlists[playlist]) {\n throw new Error('Unknown playlist URI: ' + playlist);\n }\n\n playlist = this.master.playlists[playlist];\n }\n\n var mediaChange = !this.media_ || playlist.uri !== this.media_.uri; // switch to fully loaded playlists immediately\n\n if (this.master.playlists[playlist.uri].endList) {\n // abort outstanding playlist requests\n if (this.request) {\n this.request.onreadystatechange = null;\n this.request.abort();\n this.request = null;\n }\n\n this.state = 'HAVE_METADATA';\n this.media_ = playlist; // trigger media change if the active media has been updated\n\n if (mediaChange) {\n this.trigger('mediachanging');\n this.trigger('mediachange');\n }\n\n return;\n } // switching to the active playlist is a no-op\n\n\n if (!mediaChange) {\n return;\n }\n\n this.state = 'SWITCHING_MEDIA'; // there is already an outstanding playlist request\n\n if (this.request) {\n if (resolveUrl(this.master.uri, playlist.uri) === this.request.url) {\n // requesting to switch to the same playlist multiple times\n // has no effect after the first\n return;\n }\n\n this.request.onreadystatechange = null;\n this.request.abort();\n this.request = null;\n } // request the new playlist\n\n\n if (this.media_) {\n this.trigger('mediachanging');\n }\n\n this.request = this.hls_.xhr({\n uri: resolveUrl(this.master.uri, playlist.uri),\n withCredentials: this.withCredentials\n }, function (error, req) {\n // disposed\n if (!_this3.request) {\n return;\n }\n\n if (error) {\n return _this3.playlistRequestError(_this3.request, playlist.uri, startingState);\n }\n\n _this3.haveMetadata(req, playlist.uri); // fire loadedmetadata the first time a media playlist is loaded\n\n\n if (startingState === 'HAVE_MASTER') {\n _this3.trigger('loadedmetadata');\n } else {\n _this3.trigger('mediachange');\n }\n });\n }\n /**\n * pause loading of the playlist\n */\n\n }, {\n key: 'pause',\n value: function pause() {\n this.stopRequest();\n window$1.clearTimeout(this.mediaUpdateTimeout);\n\n if (this.state === 'HAVE_NOTHING') {\n // If we pause the loader before any data has been retrieved, its as if we never\n // started, so reset to an unstarted state.\n this.started = false;\n } // Need to restore state now that no activity is happening\n\n\n if (this.state === 'SWITCHING_MEDIA') {\n // if the loader was in the process of switching media, it should either return to\n // HAVE_MASTER or HAVE_METADATA depending on if the loader has loaded a media\n // playlist yet. This is determined by the existence of loader.media_\n if (this.media_) {\n this.state = 'HAVE_METADATA';\n } else {\n this.state = 'HAVE_MASTER';\n }\n } else if (this.state === 'HAVE_CURRENT_METADATA') {\n this.state = 'HAVE_METADATA';\n }\n }\n /**\n * start loading of the playlist\n */\n\n }, {\n key: 'load',\n value: function load(isFinalRendition) {\n var _this4 = this;\n\n window$1.clearTimeout(this.mediaUpdateTimeout);\n var media = this.media();\n\n if (isFinalRendition) {\n var delay = media ? media.targetDuration / 2 * 1000 : 5 * 1000;\n this.mediaUpdateTimeout = window$1.setTimeout(function () {\n return _this4.load();\n }, delay);\n return;\n }\n\n if (!this.started) {\n this.start();\n return;\n }\n\n if (media && !media.endList) {\n this.trigger('mediaupdatetimeout');\n } else {\n this.trigger('loadedplaylist');\n }\n }\n /**\n * start loading of the playlist\n */\n\n }, {\n key: 'start',\n value: function start() {\n var _this5 = this;\n\n this.started = true; // request the specified URL\n\n this.request = this.hls_.xhr({\n uri: this.srcUrl,\n withCredentials: this.withCredentials\n }, function (error, req) {\n // disposed\n if (!_this5.request) {\n return;\n } // clear the loader's request reference\n\n\n _this5.request = null;\n\n if (error) {\n _this5.error = {\n status: req.status,\n message: 'HLS playlist request error at URL: ' + _this5.srcUrl,\n responseText: req.responseText,\n // MEDIA_ERR_NETWORK\n code: 2\n };\n\n if (_this5.state === 'HAVE_NOTHING') {\n _this5.started = false;\n }\n\n return _this5.trigger('error');\n }\n\n var parser = new Parser();\n parser.push(req.responseText);\n parser.end();\n _this5.state = 'HAVE_MASTER';\n parser.manifest.uri = _this5.srcUrl; // loaded a master playlist\n\n if (parser.manifest.playlists) {\n _this5.master = parser.manifest;\n setupMediaPlaylists(_this5.master);\n resolveMediaGroupUris(_this5.master);\n\n _this5.trigger('loadedplaylist');\n\n if (!_this5.request) {\n // no media playlist was specifically selected so start\n // from the first listed one\n _this5.media(parser.manifest.playlists[0]);\n }\n\n return;\n } // loaded a media playlist\n // infer a master playlist if none was previously requested\n\n\n _this5.master = {\n mediaGroups: {\n 'AUDIO': {},\n 'VIDEO': {},\n 'CLOSED-CAPTIONS': {},\n 'SUBTITLES': {}\n },\n uri: window$1.location.href,\n playlists: [{\n uri: _this5.srcUrl,\n id: 0\n }]\n };\n _this5.master.playlists[_this5.srcUrl] = _this5.master.playlists[0];\n _this5.master.playlists[0].resolvedUri = _this5.srcUrl; // m3u8-parser does not attach an attributes property to media playlists so make\n // sure that the property is attached to avoid undefined reference errors\n\n _this5.master.playlists[0].attributes = _this5.master.playlists[0].attributes || {};\n\n _this5.haveMetadata(req, _this5.srcUrl);\n\n return _this5.trigger('loadedmetadata');\n });\n }\n }]);\n return PlaylistLoader;\n}(EventTarget$1);\n/**\n * @file playlist.js\n *\n * Playlist related utilities.\n */\n\n\nvar createTimeRange = videojs$1.createTimeRange;\n/**\n * walk backward until we find a duration we can use\n * or return a failure\n *\n * @param {Playlist} playlist the playlist to walk through\n * @param {Number} endSequence the mediaSequence to stop walking on\n */\n\nvar backwardDuration = function backwardDuration(playlist, endSequence) {\n var result = 0;\n var i = endSequence - playlist.mediaSequence; // if a start time is available for segment immediately following\n // the interval, use it\n\n var segment = playlist.segments[i]; // Walk backward until we find the latest segment with timeline\n // information that is earlier than endSequence\n\n if (segment) {\n if (typeof segment.start !== 'undefined') {\n return {\n result: segment.start,\n precise: true\n };\n }\n\n if (typeof segment.end !== 'undefined') {\n return {\n result: segment.end - segment.duration,\n precise: true\n };\n }\n }\n\n while (i--) {\n segment = playlist.segments[i];\n\n if (typeof segment.end !== 'undefined') {\n return {\n result: result + segment.end,\n precise: true\n };\n }\n\n result += segment.duration;\n\n if (typeof segment.start !== 'undefined') {\n return {\n result: result + segment.start,\n precise: true\n };\n }\n }\n\n return {\n result: result,\n precise: false\n };\n};\n/**\n * walk forward until we find a duration we can use\n * or return a failure\n *\n * @param {Playlist} playlist the playlist to walk through\n * @param {Number} endSequence the mediaSequence to stop walking on\n */\n\n\nvar forwardDuration = function forwardDuration(playlist, endSequence) {\n var result = 0;\n var segment = void 0;\n var i = endSequence - playlist.mediaSequence; // Walk forward until we find the earliest segment with timeline\n // information\n\n for (; i < playlist.segments.length; i++) {\n segment = playlist.segments[i];\n\n if (typeof segment.start !== 'undefined') {\n return {\n result: segment.start - result,\n precise: true\n };\n }\n\n result += segment.duration;\n\n if (typeof segment.end !== 'undefined') {\n return {\n result: segment.end - result,\n precise: true\n };\n }\n } // indicate we didn't find a useful duration estimate\n\n\n return {\n result: -1,\n precise: false\n };\n};\n/**\n * Calculate the media duration from the segments associated with a\n * playlist. The duration of a subinterval of the available segments\n * may be calculated by specifying an end index.\n *\n * @param {Object} playlist a media playlist object\n * @param {Number=} endSequence an exclusive upper boundary\n * for the playlist. Defaults to playlist length.\n * @param {Number} expired the amount of time that has dropped\n * off the front of the playlist in a live scenario\n * @return {Number} the duration between the first available segment\n * and end index.\n */\n\n\nvar intervalDuration = function intervalDuration(playlist, endSequence, expired) {\n var backward = void 0;\n var forward = void 0;\n\n if (typeof endSequence === 'undefined') {\n endSequence = playlist.mediaSequence + playlist.segments.length;\n }\n\n if (endSequence < playlist.mediaSequence) {\n return 0;\n } // do a backward walk to estimate the duration\n\n\n backward = backwardDuration(playlist, endSequence);\n\n if (backward.precise) {\n // if we were able to base our duration estimate on timing\n // information provided directly from the Media Source, return\n // it\n return backward.result;\n } // walk forward to see if a precise duration estimate can be made\n // that way\n\n\n forward = forwardDuration(playlist, endSequence);\n\n if (forward.precise) {\n // we found a segment that has been buffered and so it's\n // position is known precisely\n return forward.result;\n } // return the less-precise, playlist-based duration estimate\n\n\n return backward.result + expired;\n};\n/**\n * Calculates the duration of a playlist. If a start and end index\n * are specified, the duration will be for the subset of the media\n * timeline between those two indices. The total duration for live\n * playlists is always Infinity.\n *\n * @param {Object} playlist a media playlist object\n * @param {Number=} endSequence an exclusive upper\n * boundary for the playlist. Defaults to the playlist media\n * sequence number plus its length.\n * @param {Number=} expired the amount of time that has\n * dropped off the front of the playlist in a live scenario\n * @return {Number} the duration between the start index and end\n * index.\n */\n\n\nvar duration = function duration(playlist, endSequence, expired) {\n if (!playlist) {\n return 0;\n }\n\n if (typeof expired !== 'number') {\n expired = 0;\n } // if a slice of the total duration is not requested, use\n // playlist-level duration indicators when they're present\n\n\n if (typeof endSequence === 'undefined') {\n // if present, use the duration specified in the playlist\n if (playlist.totalDuration) {\n return playlist.totalDuration;\n } // duration should be Infinity for live playlists\n\n\n if (!playlist.endList) {\n return window$1.Infinity;\n }\n } // calculate the total duration based on the segment durations\n\n\n return intervalDuration(playlist, endSequence, expired);\n};\n/**\n * Calculate the time between two indexes in the current playlist\n * neight the start- nor the end-index need to be within the current\n * playlist in which case, the targetDuration of the playlist is used\n * to approximate the durations of the segments\n *\n * @param {Object} playlist a media playlist object\n * @param {Number} startIndex\n * @param {Number} endIndex\n * @return {Number} the number of seconds between startIndex and endIndex\n */\n\n\nvar sumDurations = function sumDurations(playlist, startIndex, endIndex) {\n var durations = 0;\n\n if (startIndex > endIndex) {\n var _ref = [endIndex, startIndex];\n startIndex = _ref[0];\n endIndex = _ref[1];\n }\n\n if (startIndex < 0) {\n for (var i = startIndex; i < Math.min(0, endIndex); i++) {\n durations += playlist.targetDuration;\n }\n\n startIndex = 0;\n }\n\n for (var _i = startIndex; _i < endIndex; _i++) {\n durations += playlist.segments[_i].duration;\n }\n\n return durations;\n};\n/**\n * Determines the media index of the segment corresponding to the safe edge of the live\n * window which is the duration of the last segment plus 2 target durations from the end\n * of the playlist.\n *\n * @param {Object} playlist\n * a media playlist object\n * @return {Number}\n * The media index of the segment at the safe live point. 0 if there is no \"safe\"\n * point.\n * @function safeLiveIndex\n */\n\n\nvar safeLiveIndex = function safeLiveIndex(playlist) {\n if (!playlist.segments.length) {\n return 0;\n }\n\n var i = playlist.segments.length - 1;\n var distanceFromEnd = playlist.segments[i].duration || playlist.targetDuration;\n var safeDistance = distanceFromEnd + playlist.targetDuration * 2;\n\n while (i--) {\n distanceFromEnd += playlist.segments[i].duration;\n\n if (distanceFromEnd >= safeDistance) {\n break;\n }\n }\n\n return Math.max(0, i);\n};\n/**\n * Calculates the playlist end time\n *\n * @param {Object} playlist a media playlist object\n * @param {Number=} expired the amount of time that has\n * dropped off the front of the playlist in a live scenario\n * @param {Boolean|false} useSafeLiveEnd a boolean value indicating whether or not the\n * playlist end calculation should consider the safe live end\n * (truncate the playlist end by three segments). This is normally\n * used for calculating the end of the playlist's seekable range.\n * @returns {Number} the end time of playlist\n * @function playlistEnd\n */\n\n\nvar playlistEnd = function playlistEnd(playlist, expired, useSafeLiveEnd) {\n if (!playlist || !playlist.segments) {\n return null;\n }\n\n if (playlist.endList) {\n return duration(playlist);\n }\n\n if (expired === null) {\n return null;\n }\n\n expired = expired || 0;\n var endSequence = useSafeLiveEnd ? safeLiveIndex(playlist) : playlist.segments.length;\n return intervalDuration(playlist, playlist.mediaSequence + endSequence, expired);\n};\n/**\n * Calculates the interval of time that is currently seekable in a\n * playlist. The returned time ranges are relative to the earliest\n * moment in the specified playlist that is still available. A full\n * seekable implementation for live streams would need to offset\n * these values by the duration of content that has expired from the\n * stream.\n *\n * @param {Object} playlist a media playlist object\n * dropped off the front of the playlist in a live scenario\n * @param {Number=} expired the amount of time that has\n * dropped off the front of the playlist in a live scenario\n * @return {TimeRanges} the periods of time that are valid targets\n * for seeking\n */\n\n\nvar seekable = function seekable(playlist, expired) {\n var useSafeLiveEnd = true;\n var seekableStart = expired || 0;\n var seekableEnd = playlistEnd(playlist, expired, useSafeLiveEnd);\n\n if (seekableEnd === null) {\n return createTimeRange();\n }\n\n return createTimeRange(seekableStart, seekableEnd);\n};\n\nvar isWholeNumber = function isWholeNumber(num) {\n return num - Math.floor(num) === 0;\n};\n\nvar roundSignificantDigit = function roundSignificantDigit(increment, num) {\n // If we have a whole number, just add 1 to it\n if (isWholeNumber(num)) {\n return num + increment * 0.1;\n }\n\n var numDecimalDigits = num.toString().split('.')[1].length;\n\n for (var i = 1; i <= numDecimalDigits; i++) {\n var scale = Math.pow(10, i);\n var temp = num * scale;\n\n if (isWholeNumber(temp) || i === numDecimalDigits) {\n return (temp + increment) / scale;\n }\n }\n};\n\nvar ceilLeastSignificantDigit = roundSignificantDigit.bind(null, 1);\nvar floorLeastSignificantDigit = roundSignificantDigit.bind(null, -1);\n/**\n * Determine the index and estimated starting time of the segment that\n * contains a specified playback position in a media playlist.\n *\n * @param {Object} playlist the media playlist to query\n * @param {Number} currentTime The number of seconds since the earliest\n * possible position to determine the containing segment for\n * @param {Number} startIndex\n * @param {Number} startTime\n * @return {Object}\n */\n\nvar getMediaInfoForTime = function getMediaInfoForTime(playlist, currentTime, startIndex, startTime) {\n var i = void 0;\n var segment = void 0;\n var numSegments = playlist.segments.length;\n var time = currentTime - startTime;\n\n if (time < 0) {\n // Walk backward from startIndex in the playlist, adding durations\n // until we find a segment that contains `time` and return it\n if (startIndex > 0) {\n for (i = startIndex - 1; i >= 0; i--) {\n segment = playlist.segments[i];\n time += floorLeastSignificantDigit(segment.duration);\n\n if (time > 0) {\n return {\n mediaIndex: i,\n startTime: startTime - sumDurations(playlist, startIndex, i)\n };\n }\n }\n } // We were unable to find a good segment within the playlist\n // so select the first segment\n\n\n return {\n mediaIndex: 0,\n startTime: currentTime\n };\n } // When startIndex is negative, we first walk forward to first segment\n // adding target durations. If we \"run out of time\" before getting to\n // the first segment, return the first segment\n\n\n if (startIndex < 0) {\n for (i = startIndex; i < 0; i++) {\n time -= playlist.targetDuration;\n\n if (time < 0) {\n return {\n mediaIndex: 0,\n startTime: currentTime\n };\n }\n }\n\n startIndex = 0;\n } // Walk forward from startIndex in the playlist, subtracting durations\n // until we find a segment that contains `time` and return it\n\n\n for (i = startIndex; i < numSegments; i++) {\n segment = playlist.segments[i];\n time -= ceilLeastSignificantDigit(segment.duration);\n\n if (time < 0) {\n return {\n mediaIndex: i,\n startTime: startTime + sumDurations(playlist, startIndex, i)\n };\n }\n } // We are out of possible candidates so load the last one...\n\n\n return {\n mediaIndex: numSegments - 1,\n startTime: currentTime\n };\n};\n/**\n * Check whether the playlist is blacklisted or not.\n *\n * @param {Object} playlist the media playlist object\n * @return {boolean} whether the playlist is blacklisted or not\n * @function isBlacklisted\n */\n\n\nvar isBlacklisted = function isBlacklisted(playlist) {\n return playlist.excludeUntil && playlist.excludeUntil > Date.now();\n};\n/**\n * Check whether the playlist is compatible with current playback configuration or has\n * been blacklisted permanently for being incompatible.\n *\n * @param {Object} playlist the media playlist object\n * @return {boolean} whether the playlist is incompatible or not\n * @function isIncompatible\n */\n\n\nvar isIncompatible = function isIncompatible(playlist) {\n return playlist.excludeUntil && playlist.excludeUntil === Infinity;\n};\n/**\n * Check whether the playlist is enabled or not.\n *\n * @param {Object} playlist the media playlist object\n * @return {boolean} whether the playlist is enabled or not\n * @function isEnabled\n */\n\n\nvar isEnabled = function isEnabled(playlist) {\n var blacklisted = isBlacklisted(playlist);\n return !playlist.disabled && !blacklisted;\n};\n/**\n * Check whether the playlist has been manually disabled through the representations api.\n *\n * @param {Object} playlist the media playlist object\n * @return {boolean} whether the playlist is disabled manually or not\n * @function isDisabled\n */\n\n\nvar isDisabled = function isDisabled(playlist) {\n return playlist.disabled;\n};\n/**\n * Returns whether the current playlist is an AES encrypted HLS stream\n *\n * @return {Boolean} true if it's an AES encrypted HLS stream\n */\n\n\nvar isAes = function isAes(media) {\n for (var i = 0; i < media.segments.length; i++) {\n if (media.segments[i].key) {\n return true;\n }\n }\n\n return false;\n};\n/**\n * Returns whether the current playlist contains fMP4\n *\n * @return {Boolean} true if the playlist contains fMP4\n */\n\n\nvar isFmp4 = function isFmp4(media) {\n for (var i = 0; i < media.segments.length; i++) {\n if (media.segments[i].map) {\n return true;\n }\n }\n\n return false;\n};\n/**\n * Checks if the playlist has a value for the specified attribute\n *\n * @param {String} attr\n * Attribute to check for\n * @param {Object} playlist\n * The media playlist object\n * @return {Boolean}\n * Whether the playlist contains a value for the attribute or not\n * @function hasAttribute\n */\n\n\nvar hasAttribute = function hasAttribute(attr, playlist) {\n return playlist.attributes && playlist.attributes[attr];\n};\n/**\n * Estimates the time required to complete a segment download from the specified playlist\n *\n * @param {Number} segmentDuration\n * Duration of requested segment\n * @param {Number} bandwidth\n * Current measured bandwidth of the player\n * @param {Object} playlist\n * The media playlist object\n * @param {Number=} bytesReceived\n * Number of bytes already received for the request. Defaults to 0\n * @return {Number|NaN}\n * The estimated time to request the segment. NaN if bandwidth information for\n * the given playlist is unavailable\n * @function estimateSegmentRequestTime\n */\n\n\nvar estimateSegmentRequestTime = function estimateSegmentRequestTime(segmentDuration, bandwidth, playlist) {\n var bytesReceived = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0;\n\n if (!hasAttribute('BANDWIDTH', playlist)) {\n return NaN;\n }\n\n var size = segmentDuration * playlist.attributes.BANDWIDTH;\n return (size - bytesReceived * 8) / bandwidth;\n};\n/*\n * Returns whether the current playlist is the lowest rendition\n *\n * @return {Boolean} true if on lowest rendition\n */\n\n\nvar isLowestEnabledRendition = function isLowestEnabledRendition(master, media) {\n if (master.playlists.length === 1) {\n return true;\n }\n\n var currentBandwidth = media.attributes.BANDWIDTH || Number.MAX_VALUE;\n return master.playlists.filter(function (playlist) {\n if (!isEnabled(playlist)) {\n return false;\n }\n\n return (playlist.attributes.BANDWIDTH || 0) < currentBandwidth;\n }).length === 0;\n}; // exports\n\n\nvar Playlist = {\n duration: duration,\n seekable: seekable,\n safeLiveIndex: safeLiveIndex,\n getMediaInfoForTime: getMediaInfoForTime,\n isEnabled: isEnabled,\n isDisabled: isDisabled,\n isBlacklisted: isBlacklisted,\n isIncompatible: isIncompatible,\n playlistEnd: playlistEnd,\n isAes: isAes,\n isFmp4: isFmp4,\n hasAttribute: hasAttribute,\n estimateSegmentRequestTime: estimateSegmentRequestTime,\n isLowestEnabledRendition: isLowestEnabledRendition\n};\n/**\n * @file xhr.js\n */\n\nvar videojsXHR = videojs$1.xhr,\n mergeOptions$1$1 = videojs$1.mergeOptions;\n\nvar xhrFactory = function xhrFactory() {\n var xhr$$1 = function XhrFunction(options, callback) {\n // Add a default timeout for all hls requests\n options = mergeOptions$1$1({\n timeout: 45e3\n }, options); // Allow an optional user-specified function to modify the option\n // object before we construct the xhr request\n\n var beforeRequest = XhrFunction.beforeRequest || videojs$1.Hls.xhr.beforeRequest;\n\n if (beforeRequest && typeof beforeRequest === 'function') {\n var newOptions = beforeRequest(options);\n\n if (newOptions) {\n options = newOptions;\n }\n }\n\n var request = videojsXHR(options, function (error, response) {\n var reqResponse = request.response;\n\n if (!error && reqResponse) {\n request.responseTime = Date.now();\n request.roundTripTime = request.responseTime - request.requestTime;\n request.bytesReceived = reqResponse.byteLength || reqResponse.length;\n\n if (!request.bandwidth) {\n request.bandwidth = Math.floor(request.bytesReceived / request.roundTripTime * 8 * 1000);\n }\n }\n\n if (response.headers) {\n request.responseHeaders = response.headers;\n } // videojs.xhr now uses a specific code on the error\n // object to signal that a request has timed out instead\n // of setting a boolean on the request object\n\n\n if (error && error.code === 'ETIMEDOUT') {\n request.timedout = true;\n } // videojs.xhr no longer considers status codes outside of 200 and 0\n // (for file uris) to be errors, but the old XHR did, so emulate that\n // behavior. Status 206 may be used in response to byterange requests.\n\n\n if (!error && !request.aborted && response.statusCode !== 200 && response.statusCode !== 206 && response.statusCode !== 0) {\n error = new Error('XHR Failed with a response of: ' + (request && (reqResponse || request.responseText)));\n }\n\n callback(error, request);\n });\n var originalAbort = request.abort;\n\n request.abort = function () {\n request.aborted = true;\n return originalAbort.apply(request, arguments);\n };\n\n request.uri = options.uri;\n request.requestTime = Date.now();\n return request;\n };\n\n return xhr$$1;\n};\n/**\n * @file bin-utils.js\n */\n\n/**\n * convert a TimeRange to text\n *\n * @param {TimeRange} range the timerange to use for conversion\n * @param {Number} i the iterator on the range to convert\n */\n\n\nvar textRange = function textRange(range, i) {\n return range.start(i) + '-' + range.end(i);\n};\n/**\n * format a number as hex string\n *\n * @param {Number} e The number\n * @param {Number} i the iterator\n */\n\n\nvar formatHexString = function formatHexString(e, i) {\n var value = e.toString(16);\n return '00'.substring(0, 2 - value.length) + value + (i % 2 ? ' ' : '');\n};\n\nvar formatAsciiString = function formatAsciiString(e) {\n if (e >= 0x20 && e < 0x7e) {\n return String.fromCharCode(e);\n }\n\n return '.';\n};\n/**\n * Creates an object for sending to a web worker modifying properties that are TypedArrays\n * into a new object with seperated properties for the buffer, byteOffset, and byteLength.\n *\n * @param {Object} message\n * Object of properties and values to send to the web worker\n * @return {Object}\n * Modified message with TypedArray values expanded\n * @function createTransferableMessage\n */\n\n\nvar createTransferableMessage = function createTransferableMessage(message) {\n var transferable = {};\n Object.keys(message).forEach(function (key) {\n var value = message[key];\n\n if (ArrayBuffer.isView(value)) {\n transferable[key] = {\n bytes: value.buffer,\n byteOffset: value.byteOffset,\n byteLength: value.byteLength\n };\n } else {\n transferable[key] = value;\n }\n });\n return transferable;\n};\n/**\n * Returns a unique string identifier for a media initialization\n * segment.\n */\n\n\nvar initSegmentId = function initSegmentId(initSegment) {\n var byterange = initSegment.byterange || {\n length: Infinity,\n offset: 0\n };\n return [byterange.length, byterange.offset, initSegment.resolvedUri].join(',');\n};\n/**\n * utils to help dump binary data to the console\n */\n\n\nvar hexDump = function hexDump(data) {\n var bytes = Array.prototype.slice.call(data);\n var step = 16;\n var result = '';\n var hex = void 0;\n var ascii = void 0;\n\n for (var j = 0; j < bytes.length / step; j++) {\n hex = bytes.slice(j * step, j * step + step).map(formatHexString).join('');\n ascii = bytes.slice(j * step, j * step + step).map(formatAsciiString).join('');\n result += hex + ' ' + ascii + '\\n';\n }\n\n return result;\n};\n\nvar tagDump = function tagDump(_ref) {\n var bytes = _ref.bytes;\n return hexDump(bytes);\n};\n\nvar textRanges = function textRanges(ranges) {\n var result = '';\n var i = void 0;\n\n for (i = 0; i < ranges.length; i++) {\n result += textRange(ranges, i) + ' ';\n }\n\n return result;\n};\n\nvar utils =\n/*#__PURE__*/\nObject.freeze({\n createTransferableMessage: createTransferableMessage,\n initSegmentId: initSegmentId,\n hexDump: hexDump,\n tagDump: tagDump,\n textRanges: textRanges\n});\n/**\n * @file time.js\n */\n\n/**\n * Checks whether a given time is within a segment based on its start time\n * and duration. For playerTime, the requested time is in seconds, for\n * streamTime, the time is a Date object.\n *\n * @param {Date|Number} requestedTime Time to check is within a segment\n * @param {\"stream\" | \"player\"} type Whether passing in a playerTime or streamTime\n * @param {Date|Number} segmentStart The start time of the segment\n * @param {Number} duration Segment duration in seconds\n */\n\nvar timeWithinSegment = function timeWithinSegment(requestedTime, type, segmentStart, duration) {\n var endTime = void 0;\n\n if (type === 'stream') {\n endTime = new Date(duration * 1000 + segmentStart.getTime());\n var requestedTimeString = requestedTime.toISOString();\n var segmentTimeString = segmentStart.toISOString();\n var endTimeString = endTime.toISOString();\n return segmentTimeString <= requestedTimeString && requestedTimeString <= endTimeString;\n } else if (type === 'player') {\n endTime = duration + segmentStart;\n return segmentStart <= requestedTime && requestedTime <= endTime;\n }\n};\n/**\n * Finds a segment that contains the time requested. This might be an estimate or\n * an accurate match.\n *\n * @param {Date|Number} time The streamTime or playerTime to find a matching segment for\n * @param {\"stream\" | \"player\"} type Either the playerTime or streamTime\n * @param {Object} playlist A playlist object\n * @return {Object} match\n * @return {Object} match.segment The matched segment from the playlist\n * @return {Date|Number} match.estimatedStart The estimated start time of the segment\n * @return {\"accurate\" | \"estimate\"} match.type Whether the match is estimated or accurate\n */\n\n\nvar findSegmentForTime = function findSegmentForTime(time, type, playlist) {\n if (!playlist.segments || playlist.segments.length === 0) {\n return null;\n }\n\n if (type !== 'player' && type !== 'stream') {\n return null;\n }\n\n var manifestTime = 0;\n\n for (var i = 0; i < playlist.segments.length; i++) {\n var segment = playlist.segments[i];\n var estimatedEnd = manifestTime + segment.duration;\n var segmentStart = void 0;\n var estimatedStart = void 0;\n\n if (type === 'player') {\n segmentStart = segment.start;\n estimatedStart = manifestTime;\n } else {\n // we can rely on the program date time being accurate\n segmentStart = segment.dateTimeObject;\n estimatedStart = segment.dateTimeObject;\n }\n\n var timeWithinSegmentEnd = typeof segment.start !== 'undefined' && typeof segment.end !== 'undefined' && timeWithinSegment(time, type, segmentStart, segment.end - segment.start);\n var timeWithinSegmentDuration = timeWithinSegment(time, type, estimatedStart, segment.duration);\n\n if (timeWithinSegmentEnd) {\n return {\n segment: segment,\n estimatedStart: estimatedStart,\n type: 'accurate'\n };\n } else if (timeWithinSegmentDuration) {\n return {\n segment: segment,\n estimatedStart: estimatedStart,\n type: 'estimate'\n };\n }\n\n manifestTime = estimatedEnd;\n }\n\n return null;\n};\n/**\n * Finds a segment that contains the given player time(in seconds).\n *\n * @param {Number} time The player time to find a match for\n * @param {Object} playlist A playlist object to search within\n */\n\n\nvar findSegmentForPlayerTime = function findSegmentForPlayerTime(time, playlist) {\n // Assumptions:\n // - there will always be a segment.duration\n // - we can start from zero\n // - segments are in time order\n // - segment.start and segment.end only come\n // from syncController\n return findSegmentForTime(time, 'player', playlist);\n};\n/**\n * Finds a segment that contains the stream time give as an ISO-8601 string.\n *\n * @param {String} streamTime The ISO-8601 streamTime to find a match for\n * @param {Object} playlist A playlist object to search within\n */\n\n\nvar findSegmentForStreamTime = function findSegmentForStreamTime(streamTime, playlist) {\n var dateTimeObject = void 0;\n\n try {\n dateTimeObject = new Date(streamTime);\n } catch (e) {\n // TODO something here?\n return null;\n } // Assumptions:\n // - verifyProgramDateTimeTags has already been run\n // - live streams have been started\n\n\n return findSegmentForTime(dateTimeObject, 'stream', playlist);\n};\n/**\n * Gives the offset of the comparisonTimestamp from the streamTime timestamp in seconds.\n * If the offset returned is positive, the streamTime occurs before the comparisonTimestamp.\n * If the offset is negative, the streamTime occurs before the comparisonTimestamp.\n *\n * @param {String} comparisonTimeStamp An ISO-8601 timestamp to compare against\n * @param {String} streamTime The streamTime as an ISO-8601 string\n * @return {Number} offset\n */\n\n\nvar getOffsetFromTimestamp = function getOffsetFromTimestamp(comparisonTimeStamp, streamTime) {\n var segmentDateTime = void 0;\n var streamDateTime = void 0;\n\n try {\n segmentDateTime = new Date(comparisonTimeStamp);\n streamDateTime = new Date(streamTime);\n } catch (e) {// TODO handle error\n }\n\n var segmentTimeEpoch = segmentDateTime.getTime();\n var streamTimeEpoch = streamDateTime.getTime();\n return (streamTimeEpoch - segmentTimeEpoch) / 1000;\n};\n/**\n * Checks that all segments in this playlist have programDateTime tags.\n *\n * @param {Object} playlist A playlist object\n */\n\n\nvar verifyProgramDateTimeTags = function verifyProgramDateTimeTags(playlist) {\n if (!playlist.segments || playlist.segments.length === 0) {\n return false;\n }\n\n for (var i = 0; i < playlist.segments.length; i++) {\n var segment = playlist.segments[i];\n\n if (!segment.dateTimeObject) {\n return false;\n }\n }\n\n return true;\n};\n/**\n * Returns the streamTime of the media given a playlist and a playerTime.\n * The playlist must have programDateTime tags for a programDateTime tag to be returned.\n * If the segments containing the time requested have not been buffered yet, an estimate\n * may be returned to the callback.\n *\n * @param {Object} args\n * @param {Object} args.playlist A playlist object to search within\n * @param {Number} time A playerTime in seconds\n * @param {Function} callback(err, streamTime)\n * @returns {String} err.message A detailed error message\n * @returns {Object} streamTime\n * @returns {Number} streamTime.mediaSeconds The streamTime in seconds\n * @returns {String} streamTime.programDateTime The streamTime as an ISO-8601 String\n */\n\n\nvar getStreamTime = function getStreamTime(_ref) {\n var playlist = _ref.playlist,\n _ref$time = _ref.time,\n time = _ref$time === undefined ? undefined : _ref$time,\n callback = _ref.callback;\n\n if (!callback) {\n throw new Error('getStreamTime: callback must be provided');\n }\n\n if (!playlist || time === undefined) {\n return callback({\n message: 'getStreamTime: playlist and time must be provided'\n });\n }\n\n var matchedSegment = findSegmentForPlayerTime(time, playlist);\n\n if (!matchedSegment) {\n return callback({\n message: 'valid streamTime was not found'\n });\n }\n\n if (matchedSegment.type === 'estimate') {\n return callback({\n message: 'Accurate streamTime could not be determined. Please seek to e.seekTime and try again',\n seekTime: matchedSegment.estimatedStart\n });\n }\n\n var streamTime = {\n mediaSeconds: time\n };\n\n if (matchedSegment.segment.dateTimeObject) {\n // TODO this is currently the time of the beginning of the\n // segment. This still needs to be modified to be offset\n // by the time requested.\n streamTime.programDateTime = matchedSegment.segment.dateTimeObject.toISOString();\n }\n\n return callback(null, streamTime);\n};\n/**\n * Seeks in the player to a time that matches the given streamTime ISO-8601 string.\n *\n * @param {Object} args\n * @param {String} args.streamTime A streamTime to seek to as an ISO-8601 String\n * @param {Object} args.playlist A playlist to look within\n * @param {Number} args.retryCount The number of times to try for an accurate seek. Default is 2.\n * @param {Function} args.seekTo A method to perform a seek\n * @param {Boolean} args.pauseAfterSeek Whether to end in a paused state after seeking. Default is true.\n * @param {Object} args.tech The tech to seek on\n * @param {Function} args.callback(err, newTime) A callback to return the new time to\n * @returns {String} err.message A detailed error message\n * @returns {Number} newTime The exact time that was seeked to in seconds\n */\n\n\nvar seekToStreamTime = function seekToStreamTime(_ref2) {\n var streamTime = _ref2.streamTime,\n playlist = _ref2.playlist,\n _ref2$retryCount = _ref2.retryCount,\n retryCount = _ref2$retryCount === undefined ? 2 : _ref2$retryCount,\n seekTo = _ref2.seekTo,\n _ref2$pauseAfterSeek = _ref2.pauseAfterSeek,\n pauseAfterSeek = _ref2$pauseAfterSeek === undefined ? true : _ref2$pauseAfterSeek,\n tech = _ref2.tech,\n callback = _ref2.callback;\n\n if (!callback) {\n throw new Error('seekToStreamTime: callback must be provided');\n }\n\n if (typeof streamTime === 'undefined' || !playlist || !seekTo) {\n return callback({\n message: 'seekToStreamTime: streamTime, seekTo and playlist must be provided'\n });\n }\n\n if (!playlist.endList && !tech.hasStarted_) {\n return callback({\n message: 'player must be playing a live stream to start buffering'\n });\n }\n\n if (!verifyProgramDateTimeTags(playlist)) {\n return callback({\n message: 'programDateTime tags must be provided in the manifest ' + playlist.resolvedUri\n });\n }\n\n var matchedSegment = findSegmentForStreamTime(streamTime, playlist); // no match\n\n if (!matchedSegment) {\n return callback({\n message: streamTime + ' was not found in the stream'\n });\n }\n\n if (matchedSegment.type === 'estimate') {\n // we've run out of retries\n if (retryCount === 0) {\n return callback({\n message: streamTime + ' is not buffered yet. Try again'\n });\n }\n\n return seekToStreamTime({\n streamTime: streamTime,\n playlist: playlist,\n retryCount: retryCount - 1,\n seekTo: seekTo,\n pauseAfterSeek: pauseAfterSeek,\n tech: tech,\n callback: callback\n });\n }\n\n var segment = matchedSegment.segment;\n var mediaOffset = getOffsetFromTimestamp(segment.dateTimeObject, streamTime);\n var seekToTime = segment.start + mediaOffset;\n\n var seekedCallback = function seekedCallback() {\n return callback(null, tech.currentTime());\n }; // listen for seeked event\n\n\n tech.one('seeked', seekedCallback); // pause before seeking as video.js will restore this state\n\n if (pauseAfterSeek) {\n tech.pause();\n }\n\n seekTo(seekToTime);\n};\n/**\n * ranges\n *\n * Utilities for working with TimeRanges.\n *\n */\n// Fudge factor to account for TimeRanges rounding\n\n\nvar TIME_FUDGE_FACTOR = 1 / 30; // Comparisons between time values such as current time and the end of the buffered range\n// can be misleading because of precision differences or when the current media has poorly\n// aligned audio and video, which can cause values to be slightly off from what you would\n// expect. This value is what we consider to be safe to use in such comparisons to account\n// for these scenarios.\n\nvar SAFE_TIME_DELTA = TIME_FUDGE_FACTOR * 3;\n\nvar filterRanges = function filterRanges(timeRanges, predicate) {\n var results = [];\n var i = void 0;\n\n if (timeRanges && timeRanges.length) {\n // Search for ranges that match the predicate\n for (i = 0; i < timeRanges.length; i++) {\n if (predicate(timeRanges.start(i), timeRanges.end(i))) {\n results.push([timeRanges.start(i), timeRanges.end(i)]);\n }\n }\n }\n\n return videojs$1.createTimeRanges(results);\n};\n/**\n * Attempts to find the buffered TimeRange that contains the specified\n * time.\n * @param {TimeRanges} buffered - the TimeRanges object to query\n * @param {number} time - the time to filter on.\n * @returns {TimeRanges} a new TimeRanges object\n */\n\n\nvar findRange = function findRange(buffered, time) {\n return filterRanges(buffered, function (start, end) {\n return start - TIME_FUDGE_FACTOR <= time && end + TIME_FUDGE_FACTOR >= time;\n });\n};\n/**\n * Returns the TimeRanges that begin later than the specified time.\n * @param {TimeRanges} timeRanges - the TimeRanges object to query\n * @param {number} time - the time to filter on.\n * @returns {TimeRanges} a new TimeRanges object.\n */\n\n\nvar findNextRange = function findNextRange(timeRanges, time) {\n return filterRanges(timeRanges, function (start) {\n return start - TIME_FUDGE_FACTOR >= time;\n });\n};\n/**\n * Returns gaps within a list of TimeRanges\n * @param {TimeRanges} buffered - the TimeRanges object\n * @return {TimeRanges} a TimeRanges object of gaps\n */\n\n\nvar findGaps = function findGaps(buffered) {\n if (buffered.length < 2) {\n return videojs$1.createTimeRanges();\n }\n\n var ranges = [];\n\n for (var i = 1; i < buffered.length; i++) {\n var start = buffered.end(i - 1);\n var end = buffered.start(i);\n ranges.push([start, end]);\n }\n\n return videojs$1.createTimeRanges(ranges);\n};\n/**\n * Gets a human readable string for a TimeRange\n *\n * @param {TimeRange} range\n * @returns {String} a human readable string\n */\n\n\nvar printableRange = function printableRange(range) {\n var strArr = [];\n\n if (!range || !range.length) {\n return '';\n }\n\n for (var i = 0; i < range.length; i++) {\n strArr.push(range.start(i) + ' => ' + range.end(i));\n }\n\n return strArr.join(', ');\n};\n/**\n * Calculates the amount of time left in seconds until the player hits the end of the\n * buffer and causes a rebuffer\n *\n * @param {TimeRange} buffered\n * The state of the buffer\n * @param {Numnber} currentTime\n * The current time of the player\n * @param {Number} playbackRate\n * The current playback rate of the player. Defaults to 1.\n * @return {Number}\n * Time until the player has to start rebuffering in seconds.\n * @function timeUntilRebuffer\n */\n\n\nvar timeUntilRebuffer = function timeUntilRebuffer(buffered, currentTime) {\n var playbackRate = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1;\n var bufferedEnd = buffered.length ? buffered.end(buffered.length - 1) : 0;\n return (bufferedEnd - currentTime) / playbackRate;\n};\n/**\n * Converts a TimeRanges object into an array representation\n * @param {TimeRanges} timeRanges\n * @returns {Array}\n */\n\n\nvar timeRangesToArray = function timeRangesToArray(timeRanges) {\n var timeRangesList = [];\n\n for (var i = 0; i < timeRanges.length; i++) {\n timeRangesList.push({\n start: timeRanges.start(i),\n end: timeRanges.end(i)\n });\n }\n\n return timeRangesList;\n};\n/**\n * @file create-text-tracks-if-necessary.js\n */\n\n/**\n * Create text tracks on video.js if they exist on a segment.\n *\n * @param {Object} sourceBuffer the VSB or FSB\n * @param {Object} mediaSource the HTML media source\n * @param {Object} segment the segment that may contain the text track\n * @private\n */\n\n\nvar createTextTracksIfNecessary = function createTextTracksIfNecessary(sourceBuffer, mediaSource, segment) {\n var player = mediaSource.player_; // create an in-band caption track if one is present in the segment\n\n if (segment.captions && segment.captions.length) {\n if (!sourceBuffer.inbandTextTracks_) {\n sourceBuffer.inbandTextTracks_ = {};\n }\n\n for (var trackId in segment.captionStreams) {\n if (!sourceBuffer.inbandTextTracks_[trackId]) {\n player.tech_.trigger({\n type: 'usage',\n name: 'hls-608'\n });\n var track = player.textTracks().getTrackById(trackId);\n\n if (track) {\n // Resuse an existing track with a CC# id because this was\n // very likely created by videojs-contrib-hls from information\n // in the m3u8 for us to use\n sourceBuffer.inbandTextTracks_[trackId] = track;\n } else {\n // Otherwise, create a track with the default `CC#` label and\n // without a language\n sourceBuffer.inbandTextTracks_[trackId] = player.addRemoteTextTrack({\n kind: 'captions',\n id: trackId,\n label: trackId\n }, false).track;\n }\n }\n }\n }\n\n if (segment.metadata && segment.metadata.length && !sourceBuffer.metadataTrack_) {\n sourceBuffer.metadataTrack_ = player.addRemoteTextTrack({\n kind: 'metadata',\n label: 'Timed Metadata'\n }, false).track;\n sourceBuffer.metadataTrack_.inBandMetadataTrackDispatchType = segment.metadata.dispatchType;\n }\n};\n/**\n * @file remove-cues-from-track.js\n */\n\n/**\n * Remove cues from a track on video.js.\n *\n * @param {Double} start start of where we should remove the cue\n * @param {Double} end end of where the we should remove the cue\n * @param {Object} track the text track to remove the cues from\n * @private\n */\n\n\nvar removeCuesFromTrack = function removeCuesFromTrack(start, end, track) {\n var i = void 0;\n var cue = void 0;\n\n if (!track) {\n return;\n }\n\n if (!track.cues) {\n return;\n }\n\n i = track.cues.length;\n\n while (i--) {\n cue = track.cues[i]; // Remove any overlapping cue\n\n if (cue.startTime <= end && cue.endTime >= start) {\n track.removeCue(cue);\n }\n }\n};\n/**\n * @file add-text-track-data.js\n */\n\n/**\n * Define properties on a cue for backwards compatability,\n * but warn the user that the way that they are using it\n * is depricated and will be removed at a later date.\n *\n * @param {Cue} cue the cue to add the properties on\n * @private\n */\n\n\nvar deprecateOldCue = function deprecateOldCue(cue) {\n Object.defineProperties(cue.frame, {\n id: {\n get: function get() {\n videojs$1.log.warn('cue.frame.id is deprecated. Use cue.value.key instead.');\n return cue.value.key;\n }\n },\n value: {\n get: function get() {\n videojs$1.log.warn('cue.frame.value is deprecated. Use cue.value.data instead.');\n return cue.value.data;\n }\n },\n privateData: {\n get: function get() {\n videojs$1.log.warn('cue.frame.privateData is deprecated. Use cue.value.data instead.');\n return cue.value.data;\n }\n }\n });\n};\n\nvar durationOfVideo = function durationOfVideo(duration) {\n var dur = void 0;\n\n if (isNaN(duration) || Math.abs(duration) === Infinity) {\n dur = Number.MAX_VALUE;\n } else {\n dur = duration;\n }\n\n return dur;\n};\n/**\n * Add text track data to a source handler given the captions and\n * metadata from the buffer.\n *\n * @param {Object} sourceHandler the virtual source buffer\n * @param {Array} captionArray an array of caption data\n * @param {Array} metadataArray an array of meta data\n * @private\n */\n\n\nvar addTextTrackData = function addTextTrackData(sourceHandler, captionArray, metadataArray) {\n var Cue = window$1.WebKitDataCue || window$1.VTTCue;\n\n if (captionArray) {\n captionArray.forEach(function (caption) {\n var track = caption.stream;\n this.inbandTextTracks_[track].addCue(new Cue(caption.startTime + this.timestampOffset, caption.endTime + this.timestampOffset, caption.text));\n }, sourceHandler);\n }\n\n if (metadataArray) {\n var videoDuration = durationOfVideo(sourceHandler.mediaSource_.duration);\n metadataArray.forEach(function (metadata) {\n var time = metadata.cueTime + this.timestampOffset;\n metadata.frames.forEach(function (frame) {\n var cue = new Cue(time, time, frame.value || frame.url || frame.data || '');\n cue.frame = frame;\n cue.value = frame;\n deprecateOldCue(cue);\n this.metadataTrack_.addCue(cue);\n }, this);\n }, sourceHandler); // Updating the metadeta cues so that\n // the endTime of each cue is the startTime of the next cue\n // the endTime of last cue is the duration of the video\n\n if (sourceHandler.metadataTrack_ && sourceHandler.metadataTrack_.cues && sourceHandler.metadataTrack_.cues.length) {\n var cues = sourceHandler.metadataTrack_.cues;\n var cuesArray = []; // Create a copy of the TextTrackCueList...\n // ...disregarding cues with a falsey value\n\n for (var i = 0; i < cues.length; i++) {\n if (cues[i]) {\n cuesArray.push(cues[i]);\n }\n } // Group cues by their startTime value\n\n\n var cuesGroupedByStartTime = cuesArray.reduce(function (obj, cue) {\n var timeSlot = obj[cue.startTime] || [];\n timeSlot.push(cue);\n obj[cue.startTime] = timeSlot;\n return obj;\n }, {}); // Sort startTimes by ascending order\n\n var sortedStartTimes = Object.keys(cuesGroupedByStartTime).sort(function (a, b) {\n return Number(a) - Number(b);\n }); // Map each cue group's endTime to the next group's startTime\n\n sortedStartTimes.forEach(function (startTime, idx) {\n var cueGroup = cuesGroupedByStartTime[startTime];\n var nextTime = Number(sortedStartTimes[idx + 1]) || videoDuration; // Map each cue's endTime the next group's startTime\n\n cueGroup.forEach(function (cue) {\n cue.endTime = nextTime;\n });\n });\n }\n }\n};\n\nvar win = typeof window !== 'undefined' ? window : {},\n TARGET = typeof Symbol === 'undefined' ? '__target' : Symbol(),\n SCRIPT_TYPE = 'application/javascript',\n BlobBuilder = win.BlobBuilder || win.WebKitBlobBuilder || win.MozBlobBuilder || win.MSBlobBuilder,\n URL = win.URL || win.webkitURL || URL && URL.msURL,\n Worker = win.Worker;\n/**\n * Returns a wrapper around Web Worker code that is constructible.\n *\n * @function shimWorker\n *\n * @param { String } filename The name of the file\n * @param { Function } fn Function wrapping the code of the worker\n */\n\nfunction shimWorker(filename, fn) {\n return function ShimWorker(forceFallback) {\n var o = this;\n\n if (!fn) {\n return new Worker(filename);\n } else if (Worker && !forceFallback) {\n // Convert the function's inner code to a string to construct the worker\n var source = fn.toString().replace(/^function.+?{/, '').slice(0, -1),\n objURL = createSourceObject(source);\n this[TARGET] = new Worker(objURL);\n wrapTerminate(this[TARGET], objURL);\n return this[TARGET];\n } else {\n var selfShim = {\n postMessage: function postMessage(m) {\n if (o.onmessage) {\n setTimeout(function () {\n o.onmessage({\n data: m,\n target: selfShim\n });\n });\n }\n }\n };\n fn.call(selfShim);\n\n this.postMessage = function (m) {\n setTimeout(function () {\n selfShim.onmessage({\n data: m,\n target: o\n });\n });\n };\n\n this.isThisThread = true;\n }\n };\n} // Test Worker capabilities\n\n\nif (Worker) {\n var testWorker,\n objURL = createSourceObject('self.onmessage = function () {}'),\n testArray = new Uint8Array(1);\n\n try {\n testWorker = new Worker(objURL); // Native browser on some Samsung devices throws for transferables, let's detect it\n\n testWorker.postMessage(testArray, [testArray.buffer]);\n } catch (e) {\n Worker = null;\n } finally {\n URL.revokeObjectURL(objURL);\n\n if (testWorker) {\n testWorker.terminate();\n }\n }\n}\n\nfunction createSourceObject(str) {\n try {\n return URL.createObjectURL(new Blob([str], {\n type: SCRIPT_TYPE\n }));\n } catch (e) {\n var blob = new BlobBuilder();\n blob.append(str);\n return URL.createObjectURL(blob.getBlob(type));\n }\n}\n\nfunction wrapTerminate(worker, objURL) {\n if (!worker || !objURL) return;\n var term = worker.terminate;\n worker.objURL = objURL;\n\n worker.terminate = function () {\n if (worker.objURL) URL.revokeObjectURL(worker.objURL);\n term.call(worker);\n };\n}\n\nvar TransmuxWorker = new shimWorker(\"./transmuxer-worker.worker.js\", function (window, document$$1) {\n var self = this;\n\n var transmuxerWorker = function () {\n /**\n * mux.js\n *\n * Copyright (c) 2015 Brightcove\n * All rights reserved.\n *\n * Functions that generate fragmented MP4s suitable for use with Media\n * Source Extensions.\n */\n var UINT32_MAX = Math.pow(2, 32) - 1;\n var box, dinf, esds, ftyp, mdat, mfhd, minf, moof, moov, mvex, mvhd, trak, tkhd, mdia, mdhd, hdlr, sdtp, stbl, stsd, traf, trex, trun, types, MAJOR_BRAND, MINOR_VERSION, AVC1_BRAND, VIDEO_HDLR, AUDIO_HDLR, HDLR_TYPES, VMHD, SMHD, DREF, STCO, STSC, STSZ, STTS; // pre-calculate constants\n\n (function () {\n var i;\n types = {\n avc1: [],\n // codingname\n avcC: [],\n btrt: [],\n dinf: [],\n dref: [],\n esds: [],\n ftyp: [],\n hdlr: [],\n mdat: [],\n mdhd: [],\n mdia: [],\n mfhd: [],\n minf: [],\n moof: [],\n moov: [],\n mp4a: [],\n // codingname\n mvex: [],\n mvhd: [],\n sdtp: [],\n smhd: [],\n stbl: [],\n stco: [],\n stsc: [],\n stsd: [],\n stsz: [],\n stts: [],\n styp: [],\n tfdt: [],\n tfhd: [],\n traf: [],\n trak: [],\n trun: [],\n trex: [],\n tkhd: [],\n vmhd: []\n }; // In environments where Uint8Array is undefined (e.g., IE8), skip set up so that we\n // don't throw an error\n\n if (typeof Uint8Array === 'undefined') {\n return;\n }\n\n for (i in types) {\n if (types.hasOwnProperty(i)) {\n types[i] = [i.charCodeAt(0), i.charCodeAt(1), i.charCodeAt(2), i.charCodeAt(3)];\n }\n }\n\n MAJOR_BRAND = new Uint8Array(['i'.charCodeAt(0), 's'.charCodeAt(0), 'o'.charCodeAt(0), 'm'.charCodeAt(0)]);\n AVC1_BRAND = new Uint8Array(['a'.charCodeAt(0), 'v'.charCodeAt(0), 'c'.charCodeAt(0), '1'.charCodeAt(0)]);\n MINOR_VERSION = new Uint8Array([0, 0, 0, 1]);\n VIDEO_HDLR = new Uint8Array([0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, // pre_defined\n 0x76, 0x69, 0x64, 0x65, // handler_type: 'vide'\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x56, 0x69, 0x64, 0x65, 0x6f, 0x48, 0x61, 0x6e, 0x64, 0x6c, 0x65, 0x72, 0x00 // name: 'VideoHandler'\n ]);\n AUDIO_HDLR = new Uint8Array([0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, // pre_defined\n 0x73, 0x6f, 0x75, 0x6e, // handler_type: 'soun'\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x53, 0x6f, 0x75, 0x6e, 0x64, 0x48, 0x61, 0x6e, 0x64, 0x6c, 0x65, 0x72, 0x00 // name: 'SoundHandler'\n ]);\n HDLR_TYPES = {\n video: VIDEO_HDLR,\n audio: AUDIO_HDLR\n };\n DREF = new Uint8Array([0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x01, // entry_count\n 0x00, 0x00, 0x00, 0x0c, // entry_size\n 0x75, 0x72, 0x6c, 0x20, // 'url' type\n 0x00, // version 0\n 0x00, 0x00, 0x01 // entry_flags\n ]);\n SMHD = new Uint8Array([0x00, // version\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, // balance, 0 means centered\n 0x00, 0x00 // reserved\n ]);\n STCO = new Uint8Array([0x00, // version\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00 // entry_count\n ]);\n STSC = STCO;\n STSZ = new Uint8Array([0x00, // version\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, // sample_size\n 0x00, 0x00, 0x00, 0x00 // sample_count\n ]);\n STTS = STCO;\n VMHD = new Uint8Array([0x00, // version\n 0x00, 0x00, 0x01, // flags\n 0x00, 0x00, // graphicsmode\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 // opcolor\n ]);\n })();\n\n box = function box(type) {\n var payload = [],\n size = 0,\n i,\n result,\n view;\n\n for (i = 1; i < arguments.length; i++) {\n payload.push(arguments[i]);\n }\n\n i = payload.length; // calculate the total size we need to allocate\n\n while (i--) {\n size += payload[i].byteLength;\n }\n\n result = new Uint8Array(size + 8);\n view = new DataView(result.buffer, result.byteOffset, result.byteLength);\n view.setUint32(0, result.byteLength);\n result.set(type, 4); // copy the payload into the result\n\n for (i = 0, size = 8; i < payload.length; i++) {\n result.set(payload[i], size);\n size += payload[i].byteLength;\n }\n\n return result;\n };\n\n dinf = function dinf() {\n return box(types.dinf, box(types.dref, DREF));\n };\n\n esds = function esds(track) {\n return box(types.esds, new Uint8Array([0x00, // version\n 0x00, 0x00, 0x00, // flags\n // ES_Descriptor\n 0x03, // tag, ES_DescrTag\n 0x19, // length\n 0x00, 0x00, // ES_ID\n 0x00, // streamDependenceFlag, URL_flag, reserved, streamPriority\n // DecoderConfigDescriptor\n 0x04, // tag, DecoderConfigDescrTag\n 0x11, // length\n 0x40, // object type\n 0x15, // streamType\n 0x00, 0x06, 0x00, // bufferSizeDB\n 0x00, 0x00, 0xda, 0xc0, // maxBitrate\n 0x00, 0x00, 0xda, 0xc0, // avgBitrate\n // DecoderSpecificInfo\n 0x05, // tag, DecoderSpecificInfoTag\n 0x02, // length\n // ISO/IEC 14496-3, AudioSpecificConfig\n // for samplingFrequencyIndex see ISO/IEC 13818-7:2006, 8.1.3.2.2, Table 35\n track.audioobjecttype << 3 | track.samplingfrequencyindex >>> 1, track.samplingfrequencyindex << 7 | track.channelcount << 3, 0x06, 0x01, 0x02 // GASpecificConfig\n ]));\n };\n\n ftyp = function ftyp() {\n return box(types.ftyp, MAJOR_BRAND, MINOR_VERSION, MAJOR_BRAND, AVC1_BRAND);\n };\n\n hdlr = function hdlr(type) {\n return box(types.hdlr, HDLR_TYPES[type]);\n };\n\n mdat = function mdat(data) {\n return box(types.mdat, data);\n };\n\n mdhd = function mdhd(track) {\n var result = new Uint8Array([0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x02, // creation_time\n 0x00, 0x00, 0x00, 0x03, // modification_time\n 0x00, 0x01, 0x5f, 0x90, // timescale, 90,000 \"ticks\" per second\n track.duration >>> 24 & 0xFF, track.duration >>> 16 & 0xFF, track.duration >>> 8 & 0xFF, track.duration & 0xFF, // duration\n 0x55, 0xc4, // 'und' language (undetermined)\n 0x00, 0x00]); // Use the sample rate from the track metadata, when it is\n // defined. The sample rate can be parsed out of an ADTS header, for\n // instance.\n\n if (track.samplerate) {\n result[12] = track.samplerate >>> 24 & 0xFF;\n result[13] = track.samplerate >>> 16 & 0xFF;\n result[14] = track.samplerate >>> 8 & 0xFF;\n result[15] = track.samplerate & 0xFF;\n }\n\n return box(types.mdhd, result);\n };\n\n mdia = function mdia(track) {\n return box(types.mdia, mdhd(track), hdlr(track.type), minf(track));\n };\n\n mfhd = function mfhd(sequenceNumber) {\n return box(types.mfhd, new Uint8Array([0x00, 0x00, 0x00, 0x00, // flags\n (sequenceNumber & 0xFF000000) >> 24, (sequenceNumber & 0xFF0000) >> 16, (sequenceNumber & 0xFF00) >> 8, sequenceNumber & 0xFF // sequence_number\n ]));\n };\n\n minf = function minf(track) {\n return box(types.minf, track.type === 'video' ? box(types.vmhd, VMHD) : box(types.smhd, SMHD), dinf(), stbl(track));\n };\n\n moof = function moof(sequenceNumber, tracks) {\n var trackFragments = [],\n i = tracks.length; // build traf boxes for each track fragment\n\n while (i--) {\n trackFragments[i] = traf(tracks[i]);\n }\n\n return box.apply(null, [types.moof, mfhd(sequenceNumber)].concat(trackFragments));\n };\n /**\n * Returns a movie box.\n * @param tracks {array} the tracks associated with this movie\n * @see ISO/IEC 14496-12:2012(E), section 8.2.1\n */\n\n\n moov = function moov(tracks) {\n var i = tracks.length,\n boxes = [];\n\n while (i--) {\n boxes[i] = trak(tracks[i]);\n }\n\n return box.apply(null, [types.moov, mvhd(0xffffffff)].concat(boxes).concat(mvex(tracks)));\n };\n\n mvex = function mvex(tracks) {\n var i = tracks.length,\n boxes = [];\n\n while (i--) {\n boxes[i] = trex(tracks[i]);\n }\n\n return box.apply(null, [types.mvex].concat(boxes));\n };\n\n mvhd = function mvhd(duration) {\n var bytes = new Uint8Array([0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x01, // creation_time\n 0x00, 0x00, 0x00, 0x02, // modification_time\n 0x00, 0x01, 0x5f, 0x90, // timescale, 90,000 \"ticks\" per second\n (duration & 0xFF000000) >> 24, (duration & 0xFF0000) >> 16, (duration & 0xFF00) >> 8, duration & 0xFF, // duration\n 0x00, 0x01, 0x00, 0x00, // 1.0 rate\n 0x01, 0x00, // 1.0 volume\n 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x40, 0x00, 0x00, 0x00, // transformation: unity matrix\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // pre_defined\n 0xff, 0xff, 0xff, 0xff // next_track_ID\n ]);\n return box(types.mvhd, bytes);\n };\n\n sdtp = function sdtp(track) {\n var samples = track.samples || [],\n bytes = new Uint8Array(4 + samples.length),\n flags,\n i; // leave the full box header (4 bytes) all zero\n // write the sample table\n\n for (i = 0; i < samples.length; i++) {\n flags = samples[i].flags;\n bytes[i + 4] = flags.dependsOn << 4 | flags.isDependedOn << 2 | flags.hasRedundancy;\n }\n\n return box(types.sdtp, bytes);\n };\n\n stbl = function stbl(track) {\n return box(types.stbl, stsd(track), box(types.stts, STTS), box(types.stsc, STSC), box(types.stsz, STSZ), box(types.stco, STCO));\n };\n\n (function () {\n var videoSample, audioSample;\n\n stsd = function stsd(track) {\n return box(types.stsd, new Uint8Array([0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x01]), track.type === 'video' ? videoSample(track) : audioSample(track));\n };\n\n videoSample = function videoSample(track) {\n var sps = track.sps || [],\n pps = track.pps || [],\n sequenceParameterSets = [],\n pictureParameterSets = [],\n i; // assemble the SPSs\n\n for (i = 0; i < sps.length; i++) {\n sequenceParameterSets.push((sps[i].byteLength & 0xFF00) >>> 8);\n sequenceParameterSets.push(sps[i].byteLength & 0xFF); // sequenceParameterSetLength\n\n sequenceParameterSets = sequenceParameterSets.concat(Array.prototype.slice.call(sps[i])); // SPS\n } // assemble the PPSs\n\n\n for (i = 0; i < pps.length; i++) {\n pictureParameterSets.push((pps[i].byteLength & 0xFF00) >>> 8);\n pictureParameterSets.push(pps[i].byteLength & 0xFF);\n pictureParameterSets = pictureParameterSets.concat(Array.prototype.slice.call(pps[i]));\n }\n\n return box(types.avc1, new Uint8Array([0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // data_reference_index\n 0x00, 0x00, // pre_defined\n 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // pre_defined\n (track.width & 0xff00) >> 8, track.width & 0xff, // width\n (track.height & 0xff00) >> 8, track.height & 0xff, // height\n 0x00, 0x48, 0x00, 0x00, // horizresolution\n 0x00, 0x48, 0x00, 0x00, // vertresolution\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // frame_count\n 0x13, 0x76, 0x69, 0x64, 0x65, 0x6f, 0x6a, 0x73, 0x2d, 0x63, 0x6f, 0x6e, 0x74, 0x72, 0x69, 0x62, 0x2d, 0x68, 0x6c, 0x73, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // compressorname\n 0x00, 0x18, // depth = 24\n 0x11, 0x11 // pre_defined = -1\n ]), box(types.avcC, new Uint8Array([0x01, // configurationVersion\n track.profileIdc, // AVCProfileIndication\n track.profileCompatibility, // profile_compatibility\n track.levelIdc, // AVCLevelIndication\n 0xff // lengthSizeMinusOne, hard-coded to 4 bytes\n ].concat([sps.length // numOfSequenceParameterSets\n ]).concat(sequenceParameterSets).concat([pps.length // numOfPictureParameterSets\n ]).concat(pictureParameterSets))), // \"PPS\"\n box(types.btrt, new Uint8Array([0x00, 0x1c, 0x9c, 0x80, // bufferSizeDB\n 0x00, 0x2d, 0xc6, 0xc0, // maxBitrate\n 0x00, 0x2d, 0xc6, 0xc0])) // avgBitrate\n );\n };\n\n audioSample = function audioSample(track) {\n return box(types.mp4a, new Uint8Array([// SampleEntry, ISO/IEC 14496-12\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // data_reference_index\n // AudioSampleEntry, ISO/IEC 14496-12\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n (track.channelcount & 0xff00) >> 8, track.channelcount & 0xff, // channelcount\n (track.samplesize & 0xff00) >> 8, track.samplesize & 0xff, // samplesize\n 0x00, 0x00, // pre_defined\n 0x00, 0x00, // reserved\n (track.samplerate & 0xff00) >> 8, track.samplerate & 0xff, 0x00, 0x00 // samplerate, 16.16\n // MP4AudioSampleEntry, ISO/IEC 14496-14\n ]), esds(track));\n };\n })();\n\n tkhd = function tkhd(track) {\n var result = new Uint8Array([0x00, // version 0\n 0x00, 0x00, 0x07, // flags\n 0x00, 0x00, 0x00, 0x00, // creation_time\n 0x00, 0x00, 0x00, 0x00, // modification_time\n (track.id & 0xFF000000) >> 24, (track.id & 0xFF0000) >> 16, (track.id & 0xFF00) >> 8, track.id & 0xFF, // track_ID\n 0x00, 0x00, 0x00, 0x00, // reserved\n (track.duration & 0xFF000000) >> 24, (track.duration & 0xFF0000) >> 16, (track.duration & 0xFF00) >> 8, track.duration & 0xFF, // duration\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, // layer\n 0x00, 0x00, // alternate_group\n 0x01, 0x00, // non-audio track volume\n 0x00, 0x00, // reserved\n 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x40, 0x00, 0x00, 0x00, // transformation: unity matrix\n (track.width & 0xFF00) >> 8, track.width & 0xFF, 0x00, 0x00, // width\n (track.height & 0xFF00) >> 8, track.height & 0xFF, 0x00, 0x00 // height\n ]);\n return box(types.tkhd, result);\n };\n /**\n * Generate a track fragment (traf) box. A traf box collects metadata\n * about tracks in a movie fragment (moof) box.\n */\n\n\n traf = function traf(track) {\n var trackFragmentHeader, trackFragmentDecodeTime, trackFragmentRun, sampleDependencyTable, dataOffset, upperWordBaseMediaDecodeTime, lowerWordBaseMediaDecodeTime;\n trackFragmentHeader = box(types.tfhd, new Uint8Array([0x00, // version 0\n 0x00, 0x00, 0x3a, // flags\n (track.id & 0xFF000000) >> 24, (track.id & 0xFF0000) >> 16, (track.id & 0xFF00) >> 8, track.id & 0xFF, // track_ID\n 0x00, 0x00, 0x00, 0x01, // sample_description_index\n 0x00, 0x00, 0x00, 0x00, // default_sample_duration\n 0x00, 0x00, 0x00, 0x00, // default_sample_size\n 0x00, 0x00, 0x00, 0x00 // default_sample_flags\n ]));\n upperWordBaseMediaDecodeTime = Math.floor(track.baseMediaDecodeTime / (UINT32_MAX + 1));\n lowerWordBaseMediaDecodeTime = Math.floor(track.baseMediaDecodeTime % (UINT32_MAX + 1));\n trackFragmentDecodeTime = box(types.tfdt, new Uint8Array([0x01, // version 1\n 0x00, 0x00, 0x00, // flags\n // baseMediaDecodeTime\n upperWordBaseMediaDecodeTime >>> 24 & 0xFF, upperWordBaseMediaDecodeTime >>> 16 & 0xFF, upperWordBaseMediaDecodeTime >>> 8 & 0xFF, upperWordBaseMediaDecodeTime & 0xFF, lowerWordBaseMediaDecodeTime >>> 24 & 0xFF, lowerWordBaseMediaDecodeTime >>> 16 & 0xFF, lowerWordBaseMediaDecodeTime >>> 8 & 0xFF, lowerWordBaseMediaDecodeTime & 0xFF])); // the data offset specifies the number of bytes from the start of\n // the containing moof to the first payload byte of the associated\n // mdat\n\n dataOffset = 32 + // tfhd\n 20 + // tfdt\n 8 + // traf header\n 16 + // mfhd\n 8 + // moof header\n 8; // mdat header\n // audio tracks require less metadata\n\n if (track.type === 'audio') {\n trackFragmentRun = trun(track, dataOffset);\n return box(types.traf, trackFragmentHeader, trackFragmentDecodeTime, trackFragmentRun);\n } // video tracks should contain an independent and disposable samples\n // box (sdtp)\n // generate one and adjust offsets to match\n\n\n sampleDependencyTable = sdtp(track);\n trackFragmentRun = trun(track, sampleDependencyTable.length + dataOffset);\n return box(types.traf, trackFragmentHeader, trackFragmentDecodeTime, trackFragmentRun, sampleDependencyTable);\n };\n /**\n * Generate a track box.\n * @param track {object} a track definition\n * @return {Uint8Array} the track box\n */\n\n\n trak = function trak(track) {\n track.duration = track.duration || 0xffffffff;\n return box(types.trak, tkhd(track), mdia(track));\n };\n\n trex = function trex(track) {\n var result = new Uint8Array([0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n (track.id & 0xFF000000) >> 24, (track.id & 0xFF0000) >> 16, (track.id & 0xFF00) >> 8, track.id & 0xFF, // track_ID\n 0x00, 0x00, 0x00, 0x01, // default_sample_description_index\n 0x00, 0x00, 0x00, 0x00, // default_sample_duration\n 0x00, 0x00, 0x00, 0x00, // default_sample_size\n 0x00, 0x01, 0x00, 0x01 // default_sample_flags\n ]); // the last two bytes of default_sample_flags is the sample\n // degradation priority, a hint about the importance of this sample\n // relative to others. Lower the degradation priority for all sample\n // types other than video.\n\n if (track.type !== 'video') {\n result[result.length - 1] = 0x00;\n }\n\n return box(types.trex, result);\n };\n\n (function () {\n var audioTrun, videoTrun, trunHeader; // This method assumes all samples are uniform. That is, if a\n // duration is present for the first sample, it will be present for\n // all subsequent samples.\n // see ISO/IEC 14496-12:2012, Section 8.8.8.1\n\n trunHeader = function trunHeader(samples, offset) {\n var durationPresent = 0,\n sizePresent = 0,\n flagsPresent = 0,\n compositionTimeOffset = 0; // trun flag constants\n\n if (samples.length) {\n if (samples[0].duration !== undefined) {\n durationPresent = 0x1;\n }\n\n if (samples[0].size !== undefined) {\n sizePresent = 0x2;\n }\n\n if (samples[0].flags !== undefined) {\n flagsPresent = 0x4;\n }\n\n if (samples[0].compositionTimeOffset !== undefined) {\n compositionTimeOffset = 0x8;\n }\n }\n\n return [0x00, // version 0\n 0x00, durationPresent | sizePresent | flagsPresent | compositionTimeOffset, 0x01, // flags\n (samples.length & 0xFF000000) >>> 24, (samples.length & 0xFF0000) >>> 16, (samples.length & 0xFF00) >>> 8, samples.length & 0xFF, // sample_count\n (offset & 0xFF000000) >>> 24, (offset & 0xFF0000) >>> 16, (offset & 0xFF00) >>> 8, offset & 0xFF // data_offset\n ];\n };\n\n videoTrun = function videoTrun(track, offset) {\n var bytes, samples, sample, i;\n samples = track.samples || [];\n offset += 8 + 12 + 16 * samples.length;\n bytes = trunHeader(samples, offset);\n\n for (i = 0; i < samples.length; i++) {\n sample = samples[i];\n bytes = bytes.concat([(sample.duration & 0xFF000000) >>> 24, (sample.duration & 0xFF0000) >>> 16, (sample.duration & 0xFF00) >>> 8, sample.duration & 0xFF, // sample_duration\n (sample.size & 0xFF000000) >>> 24, (sample.size & 0xFF0000) >>> 16, (sample.size & 0xFF00) >>> 8, sample.size & 0xFF, // sample_size\n sample.flags.isLeading << 2 | sample.flags.dependsOn, sample.flags.isDependedOn << 6 | sample.flags.hasRedundancy << 4 | sample.flags.paddingValue << 1 | sample.flags.isNonSyncSample, sample.flags.degradationPriority & 0xF0 << 8, sample.flags.degradationPriority & 0x0F, // sample_flags\n (sample.compositionTimeOffset & 0xFF000000) >>> 24, (sample.compositionTimeOffset & 0xFF0000) >>> 16, (sample.compositionTimeOffset & 0xFF00) >>> 8, sample.compositionTimeOffset & 0xFF // sample_composition_time_offset\n ]);\n }\n\n return box(types.trun, new Uint8Array(bytes));\n };\n\n audioTrun = function audioTrun(track, offset) {\n var bytes, samples, sample, i;\n samples = track.samples || [];\n offset += 8 + 12 + 8 * samples.length;\n bytes = trunHeader(samples, offset);\n\n for (i = 0; i < samples.length; i++) {\n sample = samples[i];\n bytes = bytes.concat([(sample.duration & 0xFF000000) >>> 24, (sample.duration & 0xFF0000) >>> 16, (sample.duration & 0xFF00) >>> 8, sample.duration & 0xFF, // sample_duration\n (sample.size & 0xFF000000) >>> 24, (sample.size & 0xFF0000) >>> 16, (sample.size & 0xFF00) >>> 8, sample.size & 0xFF]); // sample_size\n }\n\n return box(types.trun, new Uint8Array(bytes));\n };\n\n trun = function trun(track, offset) {\n if (track.type === 'audio') {\n return audioTrun(track, offset);\n }\n\n return videoTrun(track, offset);\n };\n })();\n\n var mp4Generator = {\n ftyp: ftyp,\n mdat: mdat,\n moof: moof,\n moov: moov,\n initSegment: function initSegment(tracks) {\n var fileType = ftyp(),\n movie = moov(tracks),\n result;\n result = new Uint8Array(fileType.byteLength + movie.byteLength);\n result.set(fileType);\n result.set(movie, fileType.byteLength);\n return result;\n }\n };\n\n var toUnsigned = function toUnsigned(value) {\n return value >>> 0;\n };\n\n var bin = {\n toUnsigned: toUnsigned\n };\n var toUnsigned$1 = bin.toUnsigned;\n\n var _findBox, parseType, timescale, startTime, getVideoTrackIds; // Find the data for a box specified by its path\n\n\n _findBox = function findBox(data, path) {\n var results = [],\n i,\n size,\n type,\n end,\n subresults;\n\n if (!path.length) {\n // short-circuit the search for empty paths\n return null;\n }\n\n for (i = 0; i < data.byteLength;) {\n size = toUnsigned$1(data[i] << 24 | data[i + 1] << 16 | data[i + 2] << 8 | data[i + 3]);\n type = parseType(data.subarray(i + 4, i + 8));\n end = size > 1 ? i + size : data.byteLength;\n\n if (type === path[0]) {\n if (path.length === 1) {\n // this is the end of the path and we've found the box we were\n // looking for\n results.push(data.subarray(i + 8, end));\n } else {\n // recursively search for the next box along the path\n subresults = _findBox(data.subarray(i + 8, end), path.slice(1));\n\n if (subresults.length) {\n results = results.concat(subresults);\n }\n }\n }\n\n i = end;\n } // we've finished searching all of data\n\n\n return results;\n };\n /**\n * Returns the string representation of an ASCII encoded four byte buffer.\n * @param buffer {Uint8Array} a four-byte buffer to translate\n * @return {string} the corresponding string\n */\n\n\n parseType = function parseType(buffer) {\n var result = '';\n result += String.fromCharCode(buffer[0]);\n result += String.fromCharCode(buffer[1]);\n result += String.fromCharCode(buffer[2]);\n result += String.fromCharCode(buffer[3]);\n return result;\n };\n /**\n * Parses an MP4 initialization segment and extracts the timescale\n * values for any declared tracks. Timescale values indicate the\n * number of clock ticks per second to assume for time-based values\n * elsewhere in the MP4.\n *\n * To determine the start time of an MP4, you need two pieces of\n * information: the timescale unit and the earliest base media decode\n * time. Multiple timescales can be specified within an MP4 but the\n * base media decode time is always expressed in the timescale from\n * the media header box for the track:\n * ```\n * moov > trak > mdia > mdhd.timescale\n * ```\n * @param init {Uint8Array} the bytes of the init segment\n * @return {object} a hash of track ids to timescale values or null if\n * the init segment is malformed.\n */\n\n\n timescale = function timescale(init) {\n var result = {},\n traks = _findBox(init, ['moov', 'trak']); // mdhd timescale\n\n\n return traks.reduce(function (result, trak) {\n var tkhd, version, index, id, mdhd;\n tkhd = _findBox(trak, ['tkhd'])[0];\n\n if (!tkhd) {\n return null;\n }\n\n version = tkhd[0];\n index = version === 0 ? 12 : 20;\n id = toUnsigned$1(tkhd[index] << 24 | tkhd[index + 1] << 16 | tkhd[index + 2] << 8 | tkhd[index + 3]);\n mdhd = _findBox(trak, ['mdia', 'mdhd'])[0];\n\n if (!mdhd) {\n return null;\n }\n\n version = mdhd[0];\n index = version === 0 ? 12 : 20;\n result[id] = toUnsigned$1(mdhd[index] << 24 | mdhd[index + 1] << 16 | mdhd[index + 2] << 8 | mdhd[index + 3]);\n return result;\n }, result);\n };\n /**\n * Determine the base media decode start time, in seconds, for an MP4\n * fragment. If multiple fragments are specified, the earliest time is\n * returned.\n *\n * The base media decode time can be parsed from track fragment\n * metadata:\n * ```\n * moof > traf > tfdt.baseMediaDecodeTime\n * ```\n * It requires the timescale value from the mdhd to interpret.\n *\n * @param timescale {object} a hash of track ids to timescale values.\n * @return {number} the earliest base media decode start time for the\n * fragment, in seconds\n */\n\n\n startTime = function startTime(timescale, fragment) {\n var trafs, baseTimes, result; // we need info from two childrend of each track fragment box\n\n trafs = _findBox(fragment, ['moof', 'traf']); // determine the start times for each track\n\n baseTimes = [].concat.apply([], trafs.map(function (traf) {\n return _findBox(traf, ['tfhd']).map(function (tfhd) {\n var id, scale, baseTime; // get the track id from the tfhd\n\n id = toUnsigned$1(tfhd[4] << 24 | tfhd[5] << 16 | tfhd[6] << 8 | tfhd[7]); // assume a 90kHz clock if no timescale was specified\n\n scale = timescale[id] || 90e3; // get the base media decode time from the tfdt\n\n baseTime = _findBox(traf, ['tfdt']).map(function (tfdt) {\n var version, result;\n version = tfdt[0];\n result = toUnsigned$1(tfdt[4] << 24 | tfdt[5] << 16 | tfdt[6] << 8 | tfdt[7]);\n\n if (version === 1) {\n result *= Math.pow(2, 32);\n result += toUnsigned$1(tfdt[8] << 24 | tfdt[9] << 16 | tfdt[10] << 8 | tfdt[11]);\n }\n\n return result;\n })[0];\n baseTime = baseTime || Infinity; // convert base time to seconds\n\n return baseTime / scale;\n });\n })); // return the minimum\n\n result = Math.min.apply(null, baseTimes);\n return isFinite(result) ? result : 0;\n };\n /**\n * Find the trackIds of the video tracks in this source.\n * Found by parsing the Handler Reference and Track Header Boxes:\n * moov > trak > mdia > hdlr\n * moov > trak > tkhd\n *\n * @param {Uint8Array} init - The bytes of the init segment for this source\n * @return {Number[]} A list of trackIds\n *\n * @see ISO-BMFF-12/2015, Section 8.4.3\n **/\n\n\n getVideoTrackIds = function getVideoTrackIds(init) {\n var traks = _findBox(init, ['moov', 'trak']);\n\n var videoTrackIds = [];\n traks.forEach(function (trak) {\n var hdlrs = _findBox(trak, ['mdia', 'hdlr']);\n\n var tkhds = _findBox(trak, ['tkhd']);\n\n hdlrs.forEach(function (hdlr, index) {\n var handlerType = parseType(hdlr.subarray(8, 12));\n var tkhd = tkhds[index];\n var view;\n var version;\n var trackId;\n\n if (handlerType === 'vide') {\n view = new DataView(tkhd.buffer, tkhd.byteOffset, tkhd.byteLength);\n version = view.getUint8(0);\n trackId = version === 0 ? view.getUint32(12) : view.getUint32(20);\n videoTrackIds.push(trackId);\n }\n });\n });\n return videoTrackIds;\n };\n\n var probe = {\n findBox: _findBox,\n parseType: parseType,\n timescale: timescale,\n startTime: startTime,\n videoTrackIds: getVideoTrackIds\n };\n /**\n * mux.js\n *\n * Copyright (c) 2014 Brightcove\n * All rights reserved.\n *\n * A lightweight readable stream implemention that handles event dispatching.\n * Objects that inherit from streams should call init in their constructors.\n */\n\n var Stream = function Stream() {\n this.init = function () {\n var listeners = {};\n /**\n * Add a listener for a specified event type.\n * @param type {string} the event name\n * @param listener {function} the callback to be invoked when an event of\n * the specified type occurs\n */\n\n this.on = function (type, listener) {\n if (!listeners[type]) {\n listeners[type] = [];\n }\n\n listeners[type] = listeners[type].concat(listener);\n };\n /**\n * Remove a listener for a specified event type.\n * @param type {string} the event name\n * @param listener {function} a function previously registered for this\n * type of event through `on`\n */\n\n\n this.off = function (type, listener) {\n var index;\n\n if (!listeners[type]) {\n return false;\n }\n\n index = listeners[type].indexOf(listener);\n listeners[type] = listeners[type].slice();\n listeners[type].splice(index, 1);\n return index > -1;\n };\n /**\n * Trigger an event of the specified type on this stream. Any additional\n * arguments to this function are passed as parameters to event listeners.\n * @param type {string} the event name\n */\n\n\n this.trigger = function (type) {\n var callbacks, i, length, args;\n callbacks = listeners[type];\n\n if (!callbacks) {\n return;\n } // Slicing the arguments on every invocation of this method\n // can add a significant amount of overhead. Avoid the\n // intermediate object creation for the common case of a\n // single callback argument\n\n\n if (arguments.length === 2) {\n length = callbacks.length;\n\n for (i = 0; i < length; ++i) {\n callbacks[i].call(this, arguments[1]);\n }\n } else {\n args = [];\n i = arguments.length;\n\n for (i = 1; i < arguments.length; ++i) {\n args.push(arguments[i]);\n }\n\n length = callbacks.length;\n\n for (i = 0; i < length; ++i) {\n callbacks[i].apply(this, args);\n }\n }\n };\n /**\n * Destroys the stream and cleans up.\n */\n\n\n this.dispose = function () {\n listeners = {};\n };\n };\n };\n /**\n * Forwards all `data` events on this stream to the destination stream. The\n * destination stream should provide a method `push` to receive the data\n * events as they arrive.\n * @param destination {stream} the stream that will receive all `data` events\n * @param autoFlush {boolean} if false, we will not call `flush` on the destination\n * when the current stream emits a 'done' event\n * @see http://nodejs.org/api/stream.html#stream_readable_pipe_destination_options\n */\n\n\n Stream.prototype.pipe = function (destination) {\n this.on('data', function (data) {\n destination.push(data);\n });\n this.on('done', function (flushSource) {\n destination.flush(flushSource);\n });\n return destination;\n }; // Default stream functions that are expected to be overridden to perform\n // actual work. These are provided by the prototype as a sort of no-op\n // implementation so that we don't have to check for their existence in the\n // `pipe` function above.\n\n\n Stream.prototype.push = function (data) {\n this.trigger('data', data);\n };\n\n Stream.prototype.flush = function (flushSource) {\n this.trigger('done', flushSource);\n };\n\n var stream = Stream; // Convert an array of nal units into an array of frames with each frame being\n // composed of the nal units that make up that frame\n // Also keep track of cummulative data about the frame from the nal units such\n // as the frame duration, starting pts, etc.\n\n var groupNalsIntoFrames = function groupNalsIntoFrames(nalUnits) {\n var i,\n currentNal,\n currentFrame = [],\n frames = [];\n currentFrame.byteLength = 0;\n\n for (i = 0; i < nalUnits.length; i++) {\n currentNal = nalUnits[i]; // Split on 'aud'-type nal units\n\n if (currentNal.nalUnitType === 'access_unit_delimiter_rbsp') {\n // Since the very first nal unit is expected to be an AUD\n // only push to the frames array when currentFrame is not empty\n if (currentFrame.length) {\n currentFrame.duration = currentNal.dts - currentFrame.dts;\n frames.push(currentFrame);\n }\n\n currentFrame = [currentNal];\n currentFrame.byteLength = currentNal.data.byteLength;\n currentFrame.pts = currentNal.pts;\n currentFrame.dts = currentNal.dts;\n } else {\n // Specifically flag key frames for ease of use later\n if (currentNal.nalUnitType === 'slice_layer_without_partitioning_rbsp_idr') {\n currentFrame.keyFrame = true;\n }\n\n currentFrame.duration = currentNal.dts - currentFrame.dts;\n currentFrame.byteLength += currentNal.data.byteLength;\n currentFrame.push(currentNal);\n }\n } // For the last frame, use the duration of the previous frame if we\n // have nothing better to go on\n\n\n if (frames.length && (!currentFrame.duration || currentFrame.duration <= 0)) {\n currentFrame.duration = frames[frames.length - 1].duration;\n } // Push the final frame\n\n\n frames.push(currentFrame);\n return frames;\n }; // Convert an array of frames into an array of Gop with each Gop being composed\n // of the frames that make up that Gop\n // Also keep track of cummulative data about the Gop from the frames such as the\n // Gop duration, starting pts, etc.\n\n\n var groupFramesIntoGops = function groupFramesIntoGops(frames) {\n var i,\n currentFrame,\n currentGop = [],\n gops = []; // We must pre-set some of the values on the Gop since we\n // keep running totals of these values\n\n currentGop.byteLength = 0;\n currentGop.nalCount = 0;\n currentGop.duration = 0;\n currentGop.pts = frames[0].pts;\n currentGop.dts = frames[0].dts; // store some metadata about all the Gops\n\n gops.byteLength = 0;\n gops.nalCount = 0;\n gops.duration = 0;\n gops.pts = frames[0].pts;\n gops.dts = frames[0].dts;\n\n for (i = 0; i < frames.length; i++) {\n currentFrame = frames[i];\n\n if (currentFrame.keyFrame) {\n // Since the very first frame is expected to be an keyframe\n // only push to the gops array when currentGop is not empty\n if (currentGop.length) {\n gops.push(currentGop);\n gops.byteLength += currentGop.byteLength;\n gops.nalCount += currentGop.nalCount;\n gops.duration += currentGop.duration;\n }\n\n currentGop = [currentFrame];\n currentGop.nalCount = currentFrame.length;\n currentGop.byteLength = currentFrame.byteLength;\n currentGop.pts = currentFrame.pts;\n currentGop.dts = currentFrame.dts;\n currentGop.duration = currentFrame.duration;\n } else {\n currentGop.duration += currentFrame.duration;\n currentGop.nalCount += currentFrame.length;\n currentGop.byteLength += currentFrame.byteLength;\n currentGop.push(currentFrame);\n }\n }\n\n if (gops.length && currentGop.duration <= 0) {\n currentGop.duration = gops[gops.length - 1].duration;\n }\n\n gops.byteLength += currentGop.byteLength;\n gops.nalCount += currentGop.nalCount;\n gops.duration += currentGop.duration; // push the final Gop\n\n gops.push(currentGop);\n return gops;\n };\n /*\n * Search for the first keyframe in the GOPs and throw away all frames\n * until that keyframe. Then extend the duration of the pulled keyframe\n * and pull the PTS and DTS of the keyframe so that it covers the time\n * range of the frames that were disposed.\n *\n * @param {Array} gops video GOPs\n * @returns {Array} modified video GOPs\n */\n\n\n var extendFirstKeyFrame = function extendFirstKeyFrame(gops) {\n var currentGop;\n\n if (!gops[0][0].keyFrame && gops.length > 1) {\n // Remove the first GOP\n currentGop = gops.shift();\n gops.byteLength -= currentGop.byteLength;\n gops.nalCount -= currentGop.nalCount; // Extend the first frame of what is now the\n // first gop to cover the time period of the\n // frames we just removed\n\n gops[0][0].dts = currentGop.dts;\n gops[0][0].pts = currentGop.pts;\n gops[0][0].duration += currentGop.duration;\n }\n\n return gops;\n };\n /**\n * Default sample object\n * see ISO/IEC 14496-12:2012, section 8.6.4.3\n */\n\n\n var createDefaultSample = function createDefaultSample() {\n return {\n size: 0,\n flags: {\n isLeading: 0,\n dependsOn: 1,\n isDependedOn: 0,\n hasRedundancy: 0,\n degradationPriority: 0,\n isNonSyncSample: 1\n }\n };\n };\n /*\n * Collates information from a video frame into an object for eventual\n * entry into an MP4 sample table.\n *\n * @param {Object} frame the video frame\n * @param {Number} dataOffset the byte offset to position the sample\n * @return {Object} object containing sample table info for a frame\n */\n\n\n var sampleForFrame = function sampleForFrame(frame, dataOffset) {\n var sample = createDefaultSample();\n sample.dataOffset = dataOffset;\n sample.compositionTimeOffset = frame.pts - frame.dts;\n sample.duration = frame.duration;\n sample.size = 4 * frame.length; // Space for nal unit size\n\n sample.size += frame.byteLength;\n\n if (frame.keyFrame) {\n sample.flags.dependsOn = 2;\n sample.flags.isNonSyncSample = 0;\n }\n\n return sample;\n }; // generate the track's sample table from an array of gops\n\n\n var generateSampleTable = function generateSampleTable(gops, baseDataOffset) {\n var h,\n i,\n sample,\n currentGop,\n currentFrame,\n dataOffset = baseDataOffset || 0,\n samples = [];\n\n for (h = 0; h < gops.length; h++) {\n currentGop = gops[h];\n\n for (i = 0; i < currentGop.length; i++) {\n currentFrame = currentGop[i];\n sample = sampleForFrame(currentFrame, dataOffset);\n dataOffset += sample.size;\n samples.push(sample);\n }\n }\n\n return samples;\n }; // generate the track's raw mdat data from an array of gops\n\n\n var concatenateNalData = function concatenateNalData(gops) {\n var h,\n i,\n j,\n currentGop,\n currentFrame,\n currentNal,\n dataOffset = 0,\n nalsByteLength = gops.byteLength,\n numberOfNals = gops.nalCount,\n totalByteLength = nalsByteLength + 4 * numberOfNals,\n data = new Uint8Array(totalByteLength),\n view = new DataView(data.buffer); // For each Gop..\n\n for (h = 0; h < gops.length; h++) {\n currentGop = gops[h]; // For each Frame..\n\n for (i = 0; i < currentGop.length; i++) {\n currentFrame = currentGop[i]; // For each NAL..\n\n for (j = 0; j < currentFrame.length; j++) {\n currentNal = currentFrame[j];\n view.setUint32(dataOffset, currentNal.data.byteLength);\n dataOffset += 4;\n data.set(currentNal.data, dataOffset);\n dataOffset += currentNal.data.byteLength;\n }\n }\n }\n\n return data;\n };\n\n var frameUtils = {\n groupNalsIntoFrames: groupNalsIntoFrames,\n groupFramesIntoGops: groupFramesIntoGops,\n extendFirstKeyFrame: extendFirstKeyFrame,\n generateSampleTable: generateSampleTable,\n concatenateNalData: concatenateNalData\n };\n var highPrefix = [33, 16, 5, 32, 164, 27];\n var lowPrefix = [33, 65, 108, 84, 1, 2, 4, 8, 168, 2, 4, 8, 17, 191, 252];\n\n var zeroFill = function zeroFill(count) {\n var a = [];\n\n while (count--) {\n a.push(0);\n }\n\n return a;\n };\n\n var makeTable = function makeTable(metaTable) {\n return Object.keys(metaTable).reduce(function (obj, key) {\n obj[key] = new Uint8Array(metaTable[key].reduce(function (arr, part) {\n return arr.concat(part);\n }, []));\n return obj;\n }, {});\n }; // Frames-of-silence to use for filling in missing AAC frames\n\n\n var coneOfSilence = {\n 96000: [highPrefix, [227, 64], zeroFill(154), [56]],\n 88200: [highPrefix, [231], zeroFill(170), [56]],\n 64000: [highPrefix, [248, 192], zeroFill(240), [56]],\n 48000: [highPrefix, [255, 192], zeroFill(268), [55, 148, 128], zeroFill(54), [112]],\n 44100: [highPrefix, [255, 192], zeroFill(268), [55, 163, 128], zeroFill(84), [112]],\n 32000: [highPrefix, [255, 192], zeroFill(268), [55, 234], zeroFill(226), [112]],\n 24000: [highPrefix, [255, 192], zeroFill(268), [55, 255, 128], zeroFill(268), [111, 112], zeroFill(126), [224]],\n 16000: [highPrefix, [255, 192], zeroFill(268), [55, 255, 128], zeroFill(268), [111, 255], zeroFill(269), [223, 108], zeroFill(195), [1, 192]],\n 12000: [lowPrefix, zeroFill(268), [3, 127, 248], zeroFill(268), [6, 255, 240], zeroFill(268), [13, 255, 224], zeroFill(268), [27, 253, 128], zeroFill(259), [56]],\n 11025: [lowPrefix, zeroFill(268), [3, 127, 248], zeroFill(268), [6, 255, 240], zeroFill(268), [13, 255, 224], zeroFill(268), [27, 255, 192], zeroFill(268), [55, 175, 128], zeroFill(108), [112]],\n 8000: [lowPrefix, zeroFill(268), [3, 121, 16], zeroFill(47), [7]]\n };\n var silence = makeTable(coneOfSilence);\n var ONE_SECOND_IN_TS = 90000,\n // 90kHz clock\n secondsToVideoTs,\n secondsToAudioTs,\n videoTsToSeconds,\n audioTsToSeconds,\n audioTsToVideoTs,\n videoTsToAudioTs;\n\n secondsToVideoTs = function secondsToVideoTs(seconds) {\n return seconds * ONE_SECOND_IN_TS;\n };\n\n secondsToAudioTs = function secondsToAudioTs(seconds, sampleRate) {\n return seconds * sampleRate;\n };\n\n videoTsToSeconds = function videoTsToSeconds(timestamp) {\n return timestamp / ONE_SECOND_IN_TS;\n };\n\n audioTsToSeconds = function audioTsToSeconds(timestamp, sampleRate) {\n return timestamp / sampleRate;\n };\n\n audioTsToVideoTs = function audioTsToVideoTs(timestamp, sampleRate) {\n return secondsToVideoTs(audioTsToSeconds(timestamp, sampleRate));\n };\n\n videoTsToAudioTs = function videoTsToAudioTs(timestamp, sampleRate) {\n return secondsToAudioTs(videoTsToSeconds(timestamp), sampleRate);\n };\n\n var clock = {\n secondsToVideoTs: secondsToVideoTs,\n secondsToAudioTs: secondsToAudioTs,\n videoTsToSeconds: videoTsToSeconds,\n audioTsToSeconds: audioTsToSeconds,\n audioTsToVideoTs: audioTsToVideoTs,\n videoTsToAudioTs: videoTsToAudioTs\n };\n var ONE_SECOND_IN_TS$1 = 90000; // 90kHz clock\n\n /**\n * Sum the `byteLength` properties of the data in each AAC frame\n */\n\n var sumFrameByteLengths = function sumFrameByteLengths(array) {\n var i,\n currentObj,\n sum = 0; // sum the byteLength's all each nal unit in the frame\n\n for (i = 0; i < array.length; i++) {\n currentObj = array[i];\n sum += currentObj.data.byteLength;\n }\n\n return sum;\n }; // Possibly pad (prefix) the audio track with silence if appending this track\n // would lead to the introduction of a gap in the audio buffer\n\n\n var prefixWithSilence = function prefixWithSilence(track, frames, audioAppendStartTs, videoBaseMediaDecodeTime) {\n var baseMediaDecodeTimeTs,\n frameDuration = 0,\n audioGapDuration = 0,\n audioFillFrameCount = 0,\n audioFillDuration = 0,\n silentFrame,\n i;\n\n if (!frames.length) {\n return;\n }\n\n baseMediaDecodeTimeTs = clock.audioTsToVideoTs(track.baseMediaDecodeTime, track.samplerate); // determine frame clock duration based on sample rate, round up to avoid overfills\n\n frameDuration = Math.ceil(ONE_SECOND_IN_TS$1 / (track.samplerate / 1024));\n\n if (audioAppendStartTs && videoBaseMediaDecodeTime) {\n // insert the shortest possible amount (audio gap or audio to video gap)\n audioGapDuration = baseMediaDecodeTimeTs - Math.max(audioAppendStartTs, videoBaseMediaDecodeTime); // number of full frames in the audio gap\n\n audioFillFrameCount = Math.floor(audioGapDuration / frameDuration);\n audioFillDuration = audioFillFrameCount * frameDuration;\n } // don't attempt to fill gaps smaller than a single frame or larger\n // than a half second\n\n\n if (audioFillFrameCount < 1 || audioFillDuration > ONE_SECOND_IN_TS$1 / 2) {\n return;\n }\n\n silentFrame = silence[track.samplerate];\n\n if (!silentFrame) {\n // we don't have a silent frame pregenerated for the sample rate, so use a frame\n // from the content instead\n silentFrame = frames[0].data;\n }\n\n for (i = 0; i < audioFillFrameCount; i++) {\n frames.splice(i, 0, {\n data: silentFrame\n });\n }\n\n track.baseMediaDecodeTime -= Math.floor(clock.videoTsToAudioTs(audioFillDuration, track.samplerate));\n }; // If the audio segment extends before the earliest allowed dts\n // value, remove AAC frames until starts at or after the earliest\n // allowed DTS so that we don't end up with a negative baseMedia-\n // DecodeTime for the audio track\n\n\n var trimAdtsFramesByEarliestDts = function trimAdtsFramesByEarliestDts(adtsFrames, track, earliestAllowedDts) {\n if (track.minSegmentDts >= earliestAllowedDts) {\n return adtsFrames;\n } // We will need to recalculate the earliest segment Dts\n\n\n track.minSegmentDts = Infinity;\n return adtsFrames.filter(function (currentFrame) {\n // If this is an allowed frame, keep it and record it's Dts\n if (currentFrame.dts >= earliestAllowedDts) {\n track.minSegmentDts = Math.min(track.minSegmentDts, currentFrame.dts);\n track.minSegmentPts = track.minSegmentDts;\n return true;\n } // Otherwise, discard it\n\n\n return false;\n });\n }; // generate the track's raw mdat data from an array of frames\n\n\n var generateSampleTable$1 = function generateSampleTable(frames) {\n var i,\n currentFrame,\n samples = [];\n\n for (i = 0; i < frames.length; i++) {\n currentFrame = frames[i];\n samples.push({\n size: currentFrame.data.byteLength,\n duration: 1024 // For AAC audio, all samples contain 1024 samples\n\n });\n }\n\n return samples;\n }; // generate the track's sample table from an array of frames\n\n\n var concatenateFrameData = function concatenateFrameData(frames) {\n var i,\n currentFrame,\n dataOffset = 0,\n data = new Uint8Array(sumFrameByteLengths(frames));\n\n for (i = 0; i < frames.length; i++) {\n currentFrame = frames[i];\n data.set(currentFrame.data, dataOffset);\n dataOffset += currentFrame.data.byteLength;\n }\n\n return data;\n };\n\n var audioFrameUtils = {\n prefixWithSilence: prefixWithSilence,\n trimAdtsFramesByEarliestDts: trimAdtsFramesByEarliestDts,\n generateSampleTable: generateSampleTable$1,\n concatenateFrameData: concatenateFrameData\n };\n var ONE_SECOND_IN_TS$2 = 90000; // 90kHz clock\n\n /**\n * Store information about the start and end of the track and the\n * duration for each frame/sample we process in order to calculate\n * the baseMediaDecodeTime\n */\n\n var collectDtsInfo = function collectDtsInfo(track, data) {\n if (typeof data.pts === 'number') {\n if (track.timelineStartInfo.pts === undefined) {\n track.timelineStartInfo.pts = data.pts;\n }\n\n if (track.minSegmentPts === undefined) {\n track.minSegmentPts = data.pts;\n } else {\n track.minSegmentPts = Math.min(track.minSegmentPts, data.pts);\n }\n\n if (track.maxSegmentPts === undefined) {\n track.maxSegmentPts = data.pts;\n } else {\n track.maxSegmentPts = Math.max(track.maxSegmentPts, data.pts);\n }\n }\n\n if (typeof data.dts === 'number') {\n if (track.timelineStartInfo.dts === undefined) {\n track.timelineStartInfo.dts = data.dts;\n }\n\n if (track.minSegmentDts === undefined) {\n track.minSegmentDts = data.dts;\n } else {\n track.minSegmentDts = Math.min(track.minSegmentDts, data.dts);\n }\n\n if (track.maxSegmentDts === undefined) {\n track.maxSegmentDts = data.dts;\n } else {\n track.maxSegmentDts = Math.max(track.maxSegmentDts, data.dts);\n }\n }\n };\n /**\n * Clear values used to calculate the baseMediaDecodeTime between\n * tracks\n */\n\n\n var clearDtsInfo = function clearDtsInfo(track) {\n delete track.minSegmentDts;\n delete track.maxSegmentDts;\n delete track.minSegmentPts;\n delete track.maxSegmentPts;\n };\n /**\n * Calculate the track's baseMediaDecodeTime based on the earliest\n * DTS the transmuxer has ever seen and the minimum DTS for the\n * current track\n * @param track {object} track metadata configuration\n * @param keepOriginalTimestamps {boolean} If true, keep the timestamps\n * in the source; false to adjust the first segment to start at 0.\n */\n\n\n var calculateTrackBaseMediaDecodeTime = function calculateTrackBaseMediaDecodeTime(track, keepOriginalTimestamps) {\n var baseMediaDecodeTime,\n scale,\n minSegmentDts = track.minSegmentDts; // Optionally adjust the time so the first segment starts at zero.\n\n if (!keepOriginalTimestamps) {\n minSegmentDts -= track.timelineStartInfo.dts;\n } // track.timelineStartInfo.baseMediaDecodeTime is the location, in time, where\n // we want the start of the first segment to be placed\n\n\n baseMediaDecodeTime = track.timelineStartInfo.baseMediaDecodeTime; // Add to that the distance this segment is from the very first\n\n baseMediaDecodeTime += minSegmentDts; // baseMediaDecodeTime must not become negative\n\n baseMediaDecodeTime = Math.max(0, baseMediaDecodeTime);\n\n if (track.type === 'audio') {\n // Audio has a different clock equal to the sampling_rate so we need to\n // scale the PTS values into the clock rate of the track\n scale = track.samplerate / ONE_SECOND_IN_TS$2;\n baseMediaDecodeTime *= scale;\n baseMediaDecodeTime = Math.floor(baseMediaDecodeTime);\n }\n\n return baseMediaDecodeTime;\n };\n\n var trackDecodeInfo = {\n clearDtsInfo: clearDtsInfo,\n calculateTrackBaseMediaDecodeTime: calculateTrackBaseMediaDecodeTime,\n collectDtsInfo: collectDtsInfo\n };\n /**\n * mux.js\n *\n * Copyright (c) 2015 Brightcove\n * All rights reserved.\n *\n * Reads in-band caption information from a video elementary\n * stream. Captions must follow the CEA-708 standard for injection\n * into an MPEG-2 transport streams.\n * @see https://en.wikipedia.org/wiki/CEA-708\n * @see https://www.gpo.gov/fdsys/pkg/CFR-2007-title47-vol1/pdf/CFR-2007-title47-vol1-sec15-119.pdf\n */\n // Supplemental enhancement information (SEI) NAL units have a\n // payload type field to indicate how they are to be\n // interpreted. CEAS-708 caption content is always transmitted with\n // payload type 0x04.\n\n var USER_DATA_REGISTERED_ITU_T_T35 = 4,\n RBSP_TRAILING_BITS = 128;\n /**\n * Parse a supplemental enhancement information (SEI) NAL unit.\n * Stops parsing once a message of type ITU T T35 has been found.\n *\n * @param bytes {Uint8Array} the bytes of a SEI NAL unit\n * @return {object} the parsed SEI payload\n * @see Rec. ITU-T H.264, 7.3.2.3.1\n */\n\n var parseSei = function parseSei(bytes) {\n var i = 0,\n result = {\n payloadType: -1,\n payloadSize: 0\n },\n payloadType = 0,\n payloadSize = 0; // go through the sei_rbsp parsing each each individual sei_message\n\n while (i < bytes.byteLength) {\n // stop once we have hit the end of the sei_rbsp\n if (bytes[i] === RBSP_TRAILING_BITS) {\n break;\n } // Parse payload type\n\n\n while (bytes[i] === 0xFF) {\n payloadType += 255;\n i++;\n }\n\n payloadType += bytes[i++]; // Parse payload size\n\n while (bytes[i] === 0xFF) {\n payloadSize += 255;\n i++;\n }\n\n payloadSize += bytes[i++]; // this sei_message is a 608/708 caption so save it and break\n // there can only ever be one caption message in a frame's sei\n\n if (!result.payload && payloadType === USER_DATA_REGISTERED_ITU_T_T35) {\n result.payloadType = payloadType;\n result.payloadSize = payloadSize;\n result.payload = bytes.subarray(i, i + payloadSize);\n break;\n } // skip the payload and parse the next message\n\n\n i += payloadSize;\n payloadType = 0;\n payloadSize = 0;\n }\n\n return result;\n }; // see ANSI/SCTE 128-1 (2013), section 8.1\n\n\n var parseUserData = function parseUserData(sei) {\n // itu_t_t35_contry_code must be 181 (United States) for\n // captions\n if (sei.payload[0] !== 181) {\n return null;\n } // itu_t_t35_provider_code should be 49 (ATSC) for captions\n\n\n if ((sei.payload[1] << 8 | sei.payload[2]) !== 49) {\n return null;\n } // the user_identifier should be \"GA94\" to indicate ATSC1 data\n\n\n if (String.fromCharCode(sei.payload[3], sei.payload[4], sei.payload[5], sei.payload[6]) !== 'GA94') {\n return null;\n } // finally, user_data_type_code should be 0x03 for caption data\n\n\n if (sei.payload[7] !== 0x03) {\n return null;\n } // return the user_data_type_structure and strip the trailing\n // marker bits\n\n\n return sei.payload.subarray(8, sei.payload.length - 1);\n }; // see CEA-708-D, section 4.4\n\n\n var parseCaptionPackets = function parseCaptionPackets(pts, userData) {\n var results = [],\n i,\n count,\n offset,\n data; // if this is just filler, return immediately\n\n if (!(userData[0] & 0x40)) {\n return results;\n } // parse out the cc_data_1 and cc_data_2 fields\n\n\n count = userData[0] & 0x1f;\n\n for (i = 0; i < count; i++) {\n offset = i * 3;\n data = {\n type: userData[offset + 2] & 0x03,\n pts: pts\n }; // capture cc data when cc_valid is 1\n\n if (userData[offset + 2] & 0x04) {\n data.ccData = userData[offset + 3] << 8 | userData[offset + 4];\n results.push(data);\n }\n }\n\n return results;\n };\n\n var discardEmulationPreventionBytes = function discardEmulationPreventionBytes(data) {\n var length = data.byteLength,\n emulationPreventionBytesPositions = [],\n i = 1,\n newLength,\n newData; // Find all `Emulation Prevention Bytes`\n\n while (i < length - 2) {\n if (data[i] === 0 && data[i + 1] === 0 && data[i + 2] === 0x03) {\n emulationPreventionBytesPositions.push(i + 2);\n i += 2;\n } else {\n i++;\n }\n } // If no Emulation Prevention Bytes were found just return the original\n // array\n\n\n if (emulationPreventionBytesPositions.length === 0) {\n return data;\n } // Create a new array to hold the NAL unit data\n\n\n newLength = length - emulationPreventionBytesPositions.length;\n newData = new Uint8Array(newLength);\n var sourceIndex = 0;\n\n for (i = 0; i < newLength; sourceIndex++, i++) {\n if (sourceIndex === emulationPreventionBytesPositions[0]) {\n // Skip this byte\n sourceIndex++; // Remove this position index\n\n emulationPreventionBytesPositions.shift();\n }\n\n newData[i] = data[sourceIndex];\n }\n\n return newData;\n }; // exports\n\n\n var captionPacketParser = {\n parseSei: parseSei,\n parseUserData: parseUserData,\n parseCaptionPackets: parseCaptionPackets,\n discardEmulationPreventionBytes: discardEmulationPreventionBytes,\n USER_DATA_REGISTERED_ITU_T_T35: USER_DATA_REGISTERED_ITU_T_T35\n }; // -----------------\n // Link To Transport\n // -----------------\n\n var CaptionStream = function CaptionStream() {\n CaptionStream.prototype.init.call(this);\n this.captionPackets_ = [];\n this.ccStreams_ = [new Cea608Stream(0, 0), // eslint-disable-line no-use-before-define\n new Cea608Stream(0, 1), // eslint-disable-line no-use-before-define\n new Cea608Stream(1, 0), // eslint-disable-line no-use-before-define\n new Cea608Stream(1, 1) // eslint-disable-line no-use-before-define\n ];\n this.reset(); // forward data and done events from CCs to this CaptionStream\n\n this.ccStreams_.forEach(function (cc) {\n cc.on('data', this.trigger.bind(this, 'data'));\n cc.on('done', this.trigger.bind(this, 'done'));\n }, this);\n };\n\n CaptionStream.prototype = new stream();\n\n CaptionStream.prototype.push = function (event) {\n var sei, userData, newCaptionPackets; // only examine SEI NALs\n\n if (event.nalUnitType !== 'sei_rbsp') {\n return;\n } // parse the sei\n\n\n sei = captionPacketParser.parseSei(event.escapedRBSP); // ignore everything but user_data_registered_itu_t_t35\n\n if (sei.payloadType !== captionPacketParser.USER_DATA_REGISTERED_ITU_T_T35) {\n return;\n } // parse out the user data payload\n\n\n userData = captionPacketParser.parseUserData(sei); // ignore unrecognized userData\n\n if (!userData) {\n return;\n } // Sometimes, the same segment # will be downloaded twice. To stop the\n // caption data from being processed twice, we track the latest dts we've\n // received and ignore everything with a dts before that. However, since\n // data for a specific dts can be split across packets on either side of\n // a segment boundary, we need to make sure we *don't* ignore the packets\n // from the *next* segment that have dts === this.latestDts_. By constantly\n // tracking the number of packets received with dts === this.latestDts_, we\n // know how many should be ignored once we start receiving duplicates.\n\n\n if (event.dts < this.latestDts_) {\n // We've started getting older data, so set the flag.\n this.ignoreNextEqualDts_ = true;\n return;\n } else if (event.dts === this.latestDts_ && this.ignoreNextEqualDts_) {\n this.numSameDts_--;\n\n if (!this.numSameDts_) {\n // We've received the last duplicate packet, time to start processing again\n this.ignoreNextEqualDts_ = false;\n }\n\n return;\n } // parse out CC data packets and save them for later\n\n\n newCaptionPackets = captionPacketParser.parseCaptionPackets(event.pts, userData);\n this.captionPackets_ = this.captionPackets_.concat(newCaptionPackets);\n\n if (this.latestDts_ !== event.dts) {\n this.numSameDts_ = 0;\n }\n\n this.numSameDts_++;\n this.latestDts_ = event.dts;\n };\n\n CaptionStream.prototype.flush = function () {\n // make sure we actually parsed captions before proceeding\n if (!this.captionPackets_.length) {\n this.ccStreams_.forEach(function (cc) {\n cc.flush();\n }, this);\n return;\n } // In Chrome, the Array#sort function is not stable so add a\n // presortIndex that we can use to ensure we get a stable-sort\n\n\n this.captionPackets_.forEach(function (elem, idx) {\n elem.presortIndex = idx;\n }); // sort caption byte-pairs based on their PTS values\n\n this.captionPackets_.sort(function (a, b) {\n if (a.pts === b.pts) {\n return a.presortIndex - b.presortIndex;\n }\n\n return a.pts - b.pts;\n });\n this.captionPackets_.forEach(function (packet) {\n if (packet.type < 2) {\n // Dispatch packet to the right Cea608Stream\n this.dispatchCea608Packet(packet);\n } // this is where an 'else' would go for a dispatching packets\n // to a theoretical Cea708Stream that handles SERVICEn data\n\n }, this);\n this.captionPackets_.length = 0;\n this.ccStreams_.forEach(function (cc) {\n cc.flush();\n }, this);\n return;\n };\n\n CaptionStream.prototype.reset = function () {\n this.latestDts_ = null;\n this.ignoreNextEqualDts_ = false;\n this.numSameDts_ = 0;\n this.activeCea608Channel_ = [null, null];\n this.ccStreams_.forEach(function (ccStream) {\n ccStream.reset();\n });\n };\n\n CaptionStream.prototype.dispatchCea608Packet = function (packet) {\n // NOTE: packet.type is the CEA608 field\n if (this.setsChannel1Active(packet)) {\n this.activeCea608Channel_[packet.type] = 0;\n } else if (this.setsChannel2Active(packet)) {\n this.activeCea608Channel_[packet.type] = 1;\n }\n\n if (this.activeCea608Channel_[packet.type] === null) {\n // If we haven't received anything to set the active channel, discard the\n // data; we don't want jumbled captions\n return;\n }\n\n this.ccStreams_[(packet.type << 1) + this.activeCea608Channel_[packet.type]].push(packet);\n };\n\n CaptionStream.prototype.setsChannel1Active = function (packet) {\n return (packet.ccData & 0x7800) === 0x1000;\n };\n\n CaptionStream.prototype.setsChannel2Active = function (packet) {\n return (packet.ccData & 0x7800) === 0x1800;\n }; // ----------------------\n // Session to Application\n // ----------------------\n // This hash maps non-ASCII, special, and extended character codes to their\n // proper Unicode equivalent. The first keys that are only a single byte\n // are the non-standard ASCII characters, which simply map the CEA608 byte\n // to the standard ASCII/Unicode. The two-byte keys that follow are the CEA608\n // character codes, but have their MSB bitmasked with 0x03 so that a lookup\n // can be performed regardless of the field and data channel on which the\n // character code was received.\n\n\n var CHARACTER_TRANSLATION = {\n 0x2a: 0xe1,\n // á\n 0x5c: 0xe9,\n // é\n 0x5e: 0xed,\n // í\n 0x5f: 0xf3,\n // ó\n 0x60: 0xfa,\n // ú\n 0x7b: 0xe7,\n // ç\n 0x7c: 0xf7,\n // ÷\n 0x7d: 0xd1,\n // Ñ\n 0x7e: 0xf1,\n // ñ\n 0x7f: 0x2588,\n // █\n 0x0130: 0xae,\n // ®\n 0x0131: 0xb0,\n // °\n 0x0132: 0xbd,\n // ½\n 0x0133: 0xbf,\n // ¿\n 0x0134: 0x2122,\n // ™\n 0x0135: 0xa2,\n // ¢\n 0x0136: 0xa3,\n // £\n 0x0137: 0x266a,\n // ♪\n 0x0138: 0xe0,\n // à\n 0x0139: 0xa0,\n //\n 0x013a: 0xe8,\n // è\n 0x013b: 0xe2,\n // â\n 0x013c: 0xea,\n // ê\n 0x013d: 0xee,\n // î\n 0x013e: 0xf4,\n // ô\n 0x013f: 0xfb,\n // û\n 0x0220: 0xc1,\n // Á\n 0x0221: 0xc9,\n // É\n 0x0222: 0xd3,\n // Ó\n 0x0223: 0xda,\n // Ú\n 0x0224: 0xdc,\n // Ü\n 0x0225: 0xfc,\n // ü\n 0x0226: 0x2018,\n // ‘\n 0x0227: 0xa1,\n // ¡\n 0x0228: 0x2a,\n // *\n 0x0229: 0x27,\n // '\n 0x022a: 0x2014,\n // —\n 0x022b: 0xa9,\n // ©\n 0x022c: 0x2120,\n // ℠\n 0x022d: 0x2022,\n // •\n 0x022e: 0x201c,\n // “\n 0x022f: 0x201d,\n // ”\n 0x0230: 0xc0,\n // À\n 0x0231: 0xc2,\n // Â\n 0x0232: 0xc7,\n // Ç\n 0x0233: 0xc8,\n // È\n 0x0234: 0xca,\n // Ê\n 0x0235: 0xcb,\n // Ë\n 0x0236: 0xeb,\n // ë\n 0x0237: 0xce,\n // Î\n 0x0238: 0xcf,\n // Ï\n 0x0239: 0xef,\n // ï\n 0x023a: 0xd4,\n // Ô\n 0x023b: 0xd9,\n // Ù\n 0x023c: 0xf9,\n // ù\n 0x023d: 0xdb,\n // Û\n 0x023e: 0xab,\n // «\n 0x023f: 0xbb,\n // »\n 0x0320: 0xc3,\n // Ã\n 0x0321: 0xe3,\n // ã\n 0x0322: 0xcd,\n // Í\n 0x0323: 0xcc,\n // Ì\n 0x0324: 0xec,\n // ì\n 0x0325: 0xd2,\n // Ò\n 0x0326: 0xf2,\n // ò\n 0x0327: 0xd5,\n // Õ\n 0x0328: 0xf5,\n // õ\n 0x0329: 0x7b,\n // {\n 0x032a: 0x7d,\n // }\n 0x032b: 0x5c,\n // \\\n 0x032c: 0x5e,\n // ^\n 0x032d: 0x5f,\n // _\n 0x032e: 0x7c,\n // |\n 0x032f: 0x7e,\n // ~\n 0x0330: 0xc4,\n // Ä\n 0x0331: 0xe4,\n // ä\n 0x0332: 0xd6,\n // Ö\n 0x0333: 0xf6,\n // ö\n 0x0334: 0xdf,\n // ß\n 0x0335: 0xa5,\n // ¥\n 0x0336: 0xa4,\n // ¤\n 0x0337: 0x2502,\n // │\n 0x0338: 0xc5,\n // Å\n 0x0339: 0xe5,\n // å\n 0x033a: 0xd8,\n // Ø\n 0x033b: 0xf8,\n // ø\n 0x033c: 0x250c,\n // ┌\n 0x033d: 0x2510,\n // ┐\n 0x033e: 0x2514,\n // └\n 0x033f: 0x2518 // ┘\n\n };\n\n var getCharFromCode = function getCharFromCode(code) {\n if (code === null) {\n return '';\n }\n\n code = CHARACTER_TRANSLATION[code] || code;\n return String.fromCharCode(code);\n }; // the index of the last row in a CEA-608 display buffer\n\n\n var BOTTOM_ROW = 14; // This array is used for mapping PACs -> row #, since there's no way of\n // getting it through bit logic.\n\n var ROWS = [0x1100, 0x1120, 0x1200, 0x1220, 0x1500, 0x1520, 0x1600, 0x1620, 0x1700, 0x1720, 0x1000, 0x1300, 0x1320, 0x1400, 0x1420]; // CEA-608 captions are rendered onto a 34x15 matrix of character\n // cells. The \"bottom\" row is the last element in the outer array.\n\n var createDisplayBuffer = function createDisplayBuffer() {\n var result = [],\n i = BOTTOM_ROW + 1;\n\n while (i--) {\n result.push('');\n }\n\n return result;\n };\n\n var Cea608Stream = function Cea608Stream(field, dataChannel) {\n Cea608Stream.prototype.init.call(this);\n this.field_ = field || 0;\n this.dataChannel_ = dataChannel || 0;\n this.name_ = 'CC' + ((this.field_ << 1 | this.dataChannel_) + 1);\n this.setConstants();\n this.reset();\n\n this.push = function (packet) {\n var data, swap, char0, char1, text; // remove the parity bits\n\n data = packet.ccData & 0x7f7f; // ignore duplicate control codes; the spec demands they're sent twice\n\n if (data === this.lastControlCode_) {\n this.lastControlCode_ = null;\n return;\n } // Store control codes\n\n\n if ((data & 0xf000) === 0x1000) {\n this.lastControlCode_ = data;\n } else if (data !== this.PADDING_) {\n this.lastControlCode_ = null;\n }\n\n char0 = data >>> 8;\n char1 = data & 0xff;\n\n if (data === this.PADDING_) {\n return;\n } else if (data === this.RESUME_CAPTION_LOADING_) {\n this.mode_ = 'popOn';\n } else if (data === this.END_OF_CAPTION_) {\n // If an EOC is received while in paint-on mode, the displayed caption\n // text should be swapped to non-displayed memory as if it was a pop-on\n // caption. Because of that, we should explicitly switch back to pop-on\n // mode\n this.mode_ = 'popOn';\n this.clearFormatting(packet.pts); // if a caption was being displayed, it's gone now\n\n this.flushDisplayed(packet.pts); // flip memory\n\n swap = this.displayed_;\n this.displayed_ = this.nonDisplayed_;\n this.nonDisplayed_ = swap; // start measuring the time to display the caption\n\n this.startPts_ = packet.pts;\n } else if (data === this.ROLL_UP_2_ROWS_) {\n this.rollUpRows_ = 2;\n this.setRollUp(packet.pts);\n } else if (data === this.ROLL_UP_3_ROWS_) {\n this.rollUpRows_ = 3;\n this.setRollUp(packet.pts);\n } else if (data === this.ROLL_UP_4_ROWS_) {\n this.rollUpRows_ = 4;\n this.setRollUp(packet.pts);\n } else if (data === this.CARRIAGE_RETURN_) {\n this.clearFormatting(packet.pts);\n this.flushDisplayed(packet.pts);\n this.shiftRowsUp_();\n this.startPts_ = packet.pts;\n } else if (data === this.BACKSPACE_) {\n if (this.mode_ === 'popOn') {\n this.nonDisplayed_[this.row_] = this.nonDisplayed_[this.row_].slice(0, -1);\n } else {\n this.displayed_[this.row_] = this.displayed_[this.row_].slice(0, -1);\n }\n } else if (data === this.ERASE_DISPLAYED_MEMORY_) {\n this.flushDisplayed(packet.pts);\n this.displayed_ = createDisplayBuffer();\n } else if (data === this.ERASE_NON_DISPLAYED_MEMORY_) {\n this.nonDisplayed_ = createDisplayBuffer();\n } else if (data === this.RESUME_DIRECT_CAPTIONING_) {\n if (this.mode_ !== 'paintOn') {\n // NOTE: This should be removed when proper caption positioning is\n // implemented\n this.flushDisplayed(packet.pts);\n this.displayed_ = createDisplayBuffer();\n }\n\n this.mode_ = 'paintOn';\n this.startPts_ = packet.pts; // Append special characters to caption text\n } else if (this.isSpecialCharacter(char0, char1)) {\n // Bitmask char0 so that we can apply character transformations\n // regardless of field and data channel.\n // Then byte-shift to the left and OR with char1 so we can pass the\n // entire character code to `getCharFromCode`.\n char0 = (char0 & 0x03) << 8;\n text = getCharFromCode(char0 | char1);\n this[this.mode_](packet.pts, text);\n this.column_++; // Append extended characters to caption text\n } else if (this.isExtCharacter(char0, char1)) {\n // Extended characters always follow their \"non-extended\" equivalents.\n // IE if a \"è\" is desired, you'll always receive \"eè\"; non-compliant\n // decoders are supposed to drop the \"è\", while compliant decoders\n // backspace the \"e\" and insert \"è\".\n // Delete the previous character\n if (this.mode_ === 'popOn') {\n this.nonDisplayed_[this.row_] = this.nonDisplayed_[this.row_].slice(0, -1);\n } else {\n this.displayed_[this.row_] = this.displayed_[this.row_].slice(0, -1);\n } // Bitmask char0 so that we can apply character transformations\n // regardless of field and data channel.\n // Then byte-shift to the left and OR with char1 so we can pass the\n // entire character code to `getCharFromCode`.\n\n\n char0 = (char0 & 0x03) << 8;\n text = getCharFromCode(char0 | char1);\n this[this.mode_](packet.pts, text);\n this.column_++; // Process mid-row codes\n } else if (this.isMidRowCode(char0, char1)) {\n // Attributes are not additive, so clear all formatting\n this.clearFormatting(packet.pts); // According to the standard, mid-row codes\n // should be replaced with spaces, so add one now\n\n this[this.mode_](packet.pts, ' ');\n this.column_++;\n\n if ((char1 & 0xe) === 0xe) {\n this.addFormatting(packet.pts, ['i']);\n }\n\n if ((char1 & 0x1) === 0x1) {\n this.addFormatting(packet.pts, ['u']);\n } // Detect offset control codes and adjust cursor\n\n } else if (this.isOffsetControlCode(char0, char1)) {\n // Cursor position is set by indent PAC (see below) in 4-column\n // increments, with an additional offset code of 1-3 to reach any\n // of the 32 columns specified by CEA-608. So all we need to do\n // here is increment the column cursor by the given offset.\n this.column_ += char1 & 0x03; // Detect PACs (Preamble Address Codes)\n } else if (this.isPAC(char0, char1)) {\n // There's no logic for PAC -> row mapping, so we have to just\n // find the row code in an array and use its index :(\n var row = ROWS.indexOf(data & 0x1f20); // Configure the caption window if we're in roll-up mode\n\n if (this.mode_ === 'rollUp') {\n // This implies that the base row is incorrectly set.\n // As per the recommendation in CEA-608(Base Row Implementation), defer to the number\n // of roll-up rows set.\n if (row - this.rollUpRows_ + 1 < 0) {\n row = this.rollUpRows_ - 1;\n }\n\n this.setRollUp(packet.pts, row);\n }\n\n if (row !== this.row_) {\n // formatting is only persistent for current row\n this.clearFormatting(packet.pts);\n this.row_ = row;\n } // All PACs can apply underline, so detect and apply\n // (All odd-numbered second bytes set underline)\n\n\n if (char1 & 0x1 && this.formatting_.indexOf('u') === -1) {\n this.addFormatting(packet.pts, ['u']);\n }\n\n if ((data & 0x10) === 0x10) {\n // We've got an indent level code. Each successive even number\n // increments the column cursor by 4, so we can get the desired\n // column position by bit-shifting to the right (to get n/2)\n // and multiplying by 4.\n this.column_ = ((data & 0xe) >> 1) * 4;\n }\n\n if (this.isColorPAC(char1)) {\n // it's a color code, though we only support white, which\n // can be either normal or italicized. white italics can be\n // either 0x4e or 0x6e depending on the row, so we just\n // bitwise-and with 0xe to see if italics should be turned on\n if ((char1 & 0xe) === 0xe) {\n this.addFormatting(packet.pts, ['i']);\n }\n } // We have a normal character in char0, and possibly one in char1\n\n } else if (this.isNormalChar(char0)) {\n if (char1 === 0x00) {\n char1 = null;\n }\n\n text = getCharFromCode(char0);\n text += getCharFromCode(char1);\n this[this.mode_](packet.pts, text);\n this.column_ += text.length;\n } // finish data processing\n\n };\n };\n\n Cea608Stream.prototype = new stream(); // Trigger a cue point that captures the current state of the\n // display buffer\n\n Cea608Stream.prototype.flushDisplayed = function (pts) {\n var content = this.displayed_ // remove spaces from the start and end of the string\n .map(function (row) {\n try {\n return row.trim();\n } catch (e) {\n // Ordinarily, this shouldn't happen. However, caption\n // parsing errors should not throw exceptions and\n // break playback.\n // eslint-disable-next-line no-console\n console.error('Skipping malformed caption.');\n return '';\n }\n }) // combine all text rows to display in one cue\n .join('\\n') // and remove blank rows from the start and end, but not the middle\n .replace(/^\\n+|\\n+$/g, '');\n\n if (content.length) {\n this.trigger('data', {\n startPts: this.startPts_,\n endPts: pts,\n text: content,\n stream: this.name_\n });\n }\n };\n /**\n * Zero out the data, used for startup and on seek\n */\n\n\n Cea608Stream.prototype.reset = function () {\n this.mode_ = 'popOn'; // When in roll-up mode, the index of the last row that will\n // actually display captions. If a caption is shifted to a row\n // with a lower index than this, it is cleared from the display\n // buffer\n\n this.topRow_ = 0;\n this.startPts_ = 0;\n this.displayed_ = createDisplayBuffer();\n this.nonDisplayed_ = createDisplayBuffer();\n this.lastControlCode_ = null; // Track row and column for proper line-breaking and spacing\n\n this.column_ = 0;\n this.row_ = BOTTOM_ROW;\n this.rollUpRows_ = 2; // This variable holds currently-applied formatting\n\n this.formatting_ = [];\n };\n /**\n * Sets up control code and related constants for this instance\n */\n\n\n Cea608Stream.prototype.setConstants = function () {\n // The following attributes have these uses:\n // ext_ : char0 for mid-row codes, and the base for extended\n // chars (ext_+0, ext_+1, and ext_+2 are char0s for\n // extended codes)\n // control_: char0 for control codes, except byte-shifted to the\n // left so that we can do this.control_ | CONTROL_CODE\n // offset_: char0 for tab offset codes\n //\n // It's also worth noting that control codes, and _only_ control codes,\n // differ between field 1 and field2. Field 2 control codes are always\n // their field 1 value plus 1. That's why there's the \"| field\" on the\n // control value.\n if (this.dataChannel_ === 0) {\n this.BASE_ = 0x10;\n this.EXT_ = 0x11;\n this.CONTROL_ = (0x14 | this.field_) << 8;\n this.OFFSET_ = 0x17;\n } else if (this.dataChannel_ === 1) {\n this.BASE_ = 0x18;\n this.EXT_ = 0x19;\n this.CONTROL_ = (0x1c | this.field_) << 8;\n this.OFFSET_ = 0x1f;\n } // Constants for the LSByte command codes recognized by Cea608Stream. This\n // list is not exhaustive. For a more comprehensive listing and semantics see\n // http://www.gpo.gov/fdsys/pkg/CFR-2010-title47-vol1/pdf/CFR-2010-title47-vol1-sec15-119.pdf\n // Padding\n\n\n this.PADDING_ = 0x0000; // Pop-on Mode\n\n this.RESUME_CAPTION_LOADING_ = this.CONTROL_ | 0x20;\n this.END_OF_CAPTION_ = this.CONTROL_ | 0x2f; // Roll-up Mode\n\n this.ROLL_UP_2_ROWS_ = this.CONTROL_ | 0x25;\n this.ROLL_UP_3_ROWS_ = this.CONTROL_ | 0x26;\n this.ROLL_UP_4_ROWS_ = this.CONTROL_ | 0x27;\n this.CARRIAGE_RETURN_ = this.CONTROL_ | 0x2d; // paint-on mode\n\n this.RESUME_DIRECT_CAPTIONING_ = this.CONTROL_ | 0x29; // Erasure\n\n this.BACKSPACE_ = this.CONTROL_ | 0x21;\n this.ERASE_DISPLAYED_MEMORY_ = this.CONTROL_ | 0x2c;\n this.ERASE_NON_DISPLAYED_MEMORY_ = this.CONTROL_ | 0x2e;\n };\n /**\n * Detects if the 2-byte packet data is a special character\n *\n * Special characters have a second byte in the range 0x30 to 0x3f,\n * with the first byte being 0x11 (for data channel 1) or 0x19 (for\n * data channel 2).\n *\n * @param {Integer} char0 The first byte\n * @param {Integer} char1 The second byte\n * @return {Boolean} Whether the 2 bytes are an special character\n */\n\n\n Cea608Stream.prototype.isSpecialCharacter = function (char0, char1) {\n return char0 === this.EXT_ && char1 >= 0x30 && char1 <= 0x3f;\n };\n /**\n * Detects if the 2-byte packet data is an extended character\n *\n * Extended characters have a second byte in the range 0x20 to 0x3f,\n * with the first byte being 0x12 or 0x13 (for data channel 1) or\n * 0x1a or 0x1b (for data channel 2).\n *\n * @param {Integer} char0 The first byte\n * @param {Integer} char1 The second byte\n * @return {Boolean} Whether the 2 bytes are an extended character\n */\n\n\n Cea608Stream.prototype.isExtCharacter = function (char0, char1) {\n return (char0 === this.EXT_ + 1 || char0 === this.EXT_ + 2) && char1 >= 0x20 && char1 <= 0x3f;\n };\n /**\n * Detects if the 2-byte packet is a mid-row code\n *\n * Mid-row codes have a second byte in the range 0x20 to 0x2f, with\n * the first byte being 0x11 (for data channel 1) or 0x19 (for data\n * channel 2).\n *\n * @param {Integer} char0 The first byte\n * @param {Integer} char1 The second byte\n * @return {Boolean} Whether the 2 bytes are a mid-row code\n */\n\n\n Cea608Stream.prototype.isMidRowCode = function (char0, char1) {\n return char0 === this.EXT_ && char1 >= 0x20 && char1 <= 0x2f;\n };\n /**\n * Detects if the 2-byte packet is an offset control code\n *\n * Offset control codes have a second byte in the range 0x21 to 0x23,\n * with the first byte being 0x17 (for data channel 1) or 0x1f (for\n * data channel 2).\n *\n * @param {Integer} char0 The first byte\n * @param {Integer} char1 The second byte\n * @return {Boolean} Whether the 2 bytes are an offset control code\n */\n\n\n Cea608Stream.prototype.isOffsetControlCode = function (char0, char1) {\n return char0 === this.OFFSET_ && char1 >= 0x21 && char1 <= 0x23;\n };\n /**\n * Detects if the 2-byte packet is a Preamble Address Code\n *\n * PACs have a first byte in the range 0x10 to 0x17 (for data channel 1)\n * or 0x18 to 0x1f (for data channel 2), with the second byte in the\n * range 0x40 to 0x7f.\n *\n * @param {Integer} char0 The first byte\n * @param {Integer} char1 The second byte\n * @return {Boolean} Whether the 2 bytes are a PAC\n */\n\n\n Cea608Stream.prototype.isPAC = function (char0, char1) {\n return char0 >= this.BASE_ && char0 < this.BASE_ + 8 && char1 >= 0x40 && char1 <= 0x7f;\n };\n /**\n * Detects if a packet's second byte is in the range of a PAC color code\n *\n * PAC color codes have the second byte be in the range 0x40 to 0x4f, or\n * 0x60 to 0x6f.\n *\n * @param {Integer} char1 The second byte\n * @return {Boolean} Whether the byte is a color PAC\n */\n\n\n Cea608Stream.prototype.isColorPAC = function (char1) {\n return char1 >= 0x40 && char1 <= 0x4f || char1 >= 0x60 && char1 <= 0x7f;\n };\n /**\n * Detects if a single byte is in the range of a normal character\n *\n * Normal text bytes are in the range 0x20 to 0x7f.\n *\n * @param {Integer} char The byte\n * @return {Boolean} Whether the byte is a normal character\n */\n\n\n Cea608Stream.prototype.isNormalChar = function (char) {\n return char >= 0x20 && char <= 0x7f;\n };\n /**\n * Configures roll-up\n *\n * @param {Integer} pts Current PTS\n * @param {Integer} newBaseRow Used by PACs to slide the current window to\n * a new position\n */\n\n\n Cea608Stream.prototype.setRollUp = function (pts, newBaseRow) {\n // Reset the base row to the bottom row when switching modes\n if (this.mode_ !== 'rollUp') {\n this.row_ = BOTTOM_ROW;\n this.mode_ = 'rollUp'; // Spec says to wipe memories when switching to roll-up\n\n this.flushDisplayed(pts);\n this.nonDisplayed_ = createDisplayBuffer();\n this.displayed_ = createDisplayBuffer();\n }\n\n if (newBaseRow !== undefined && newBaseRow !== this.row_) {\n // move currently displayed captions (up or down) to the new base row\n for (var i = 0; i < this.rollUpRows_; i++) {\n this.displayed_[newBaseRow - i] = this.displayed_[this.row_ - i];\n this.displayed_[this.row_ - i] = '';\n }\n }\n\n if (newBaseRow === undefined) {\n newBaseRow = this.row_;\n }\n\n this.topRow_ = newBaseRow - this.rollUpRows_ + 1;\n }; // Adds the opening HTML tag for the passed character to the caption text,\n // and keeps track of it for later closing\n\n\n Cea608Stream.prototype.addFormatting = function (pts, format) {\n this.formatting_ = this.formatting_.concat(format);\n var text = format.reduce(function (text, format) {\n return text + '<' + format + '>';\n }, '');\n this[this.mode_](pts, text);\n }; // Adds HTML closing tags for current formatting to caption text and\n // clears remembered formatting\n\n\n Cea608Stream.prototype.clearFormatting = function (pts) {\n if (!this.formatting_.length) {\n return;\n }\n\n var text = this.formatting_.reverse().reduce(function (text, format) {\n return text + '</' + format + '>';\n }, '');\n this.formatting_ = [];\n this[this.mode_](pts, text);\n }; // Mode Implementations\n\n\n Cea608Stream.prototype.popOn = function (pts, text) {\n var baseRow = this.nonDisplayed_[this.row_]; // buffer characters\n\n baseRow += text;\n this.nonDisplayed_[this.row_] = baseRow;\n };\n\n Cea608Stream.prototype.rollUp = function (pts, text) {\n var baseRow = this.displayed_[this.row_];\n baseRow += text;\n this.displayed_[this.row_] = baseRow;\n };\n\n Cea608Stream.prototype.shiftRowsUp_ = function () {\n var i; // clear out inactive rows\n\n for (i = 0; i < this.topRow_; i++) {\n this.displayed_[i] = '';\n }\n\n for (i = this.row_ + 1; i < BOTTOM_ROW + 1; i++) {\n this.displayed_[i] = '';\n } // shift displayed rows up\n\n\n for (i = this.topRow_; i < this.row_; i++) {\n this.displayed_[i] = this.displayed_[i + 1];\n } // clear out the bottom row\n\n\n this.displayed_[this.row_] = '';\n };\n\n Cea608Stream.prototype.paintOn = function (pts, text) {\n var baseRow = this.displayed_[this.row_];\n baseRow += text;\n this.displayed_[this.row_] = baseRow;\n }; // exports\n\n\n var captionStream = {\n CaptionStream: CaptionStream,\n Cea608Stream: Cea608Stream\n };\n var streamTypes = {\n H264_STREAM_TYPE: 0x1B,\n ADTS_STREAM_TYPE: 0x0F,\n METADATA_STREAM_TYPE: 0x15\n };\n var MAX_TS = 8589934592;\n var RO_THRESH = 4294967296;\n\n var handleRollover = function handleRollover(value, reference) {\n var direction = 1;\n\n if (value > reference) {\n // If the current timestamp value is greater than our reference timestamp and we detect a\n // timestamp rollover, this means the roll over is happening in the opposite direction.\n // Example scenario: Enter a long stream/video just after a rollover occurred. The reference\n // point will be set to a small number, e.g. 1. The user then seeks backwards over the\n // rollover point. In loading this segment, the timestamp values will be very large,\n // e.g. 2^33 - 1. Since this comes before the data we loaded previously, we want to adjust\n // the time stamp to be `value - 2^33`.\n direction = -1;\n } // Note: A seek forwards or back that is greater than the RO_THRESH (2^32, ~13 hours) will\n // cause an incorrect adjustment.\n\n\n while (Math.abs(reference - value) > RO_THRESH) {\n value += direction * MAX_TS;\n }\n\n return value;\n };\n\n var TimestampRolloverStream = function TimestampRolloverStream(type) {\n var lastDTS, referenceDTS;\n TimestampRolloverStream.prototype.init.call(this);\n this.type_ = type;\n\n this.push = function (data) {\n if (data.type !== this.type_) {\n return;\n }\n\n if (referenceDTS === undefined) {\n referenceDTS = data.dts;\n }\n\n data.dts = handleRollover(data.dts, referenceDTS);\n data.pts = handleRollover(data.pts, referenceDTS);\n lastDTS = data.dts;\n this.trigger('data', data);\n };\n\n this.flush = function () {\n referenceDTS = lastDTS;\n this.trigger('done');\n };\n\n this.discontinuity = function () {\n referenceDTS = void 0;\n lastDTS = void 0;\n };\n };\n\n TimestampRolloverStream.prototype = new stream();\n var timestampRolloverStream = {\n TimestampRolloverStream: TimestampRolloverStream,\n handleRollover: handleRollover\n };\n\n var percentEncode = function percentEncode(bytes, start, end) {\n var i,\n result = '';\n\n for (i = start; i < end; i++) {\n result += '%' + ('00' + bytes[i].toString(16)).slice(-2);\n }\n\n return result;\n },\n // return the string representation of the specified byte range,\n // interpreted as UTf-8.\n parseUtf8 = function parseUtf8(bytes, start, end) {\n return decodeURIComponent(percentEncode(bytes, start, end));\n },\n // return the string representation of the specified byte range,\n // interpreted as ISO-8859-1.\n parseIso88591 = function parseIso88591(bytes, start, end) {\n return unescape(percentEncode(bytes, start, end)); // jshint ignore:line\n },\n parseSyncSafeInteger = function parseSyncSafeInteger(data) {\n return data[0] << 21 | data[1] << 14 | data[2] << 7 | data[3];\n },\n tagParsers = {\n TXXX: function TXXX(tag) {\n var i;\n\n if (tag.data[0] !== 3) {\n // ignore frames with unrecognized character encodings\n return;\n }\n\n for (i = 1; i < tag.data.length; i++) {\n if (tag.data[i] === 0) {\n // parse the text fields\n tag.description = parseUtf8(tag.data, 1, i); // do not include the null terminator in the tag value\n\n tag.value = parseUtf8(tag.data, i + 1, tag.data.length).replace(/\\0*$/, '');\n break;\n }\n }\n\n tag.data = tag.value;\n },\n WXXX: function WXXX(tag) {\n var i;\n\n if (tag.data[0] !== 3) {\n // ignore frames with unrecognized character encodings\n return;\n }\n\n for (i = 1; i < tag.data.length; i++) {\n if (tag.data[i] === 0) {\n // parse the description and URL fields\n tag.description = parseUtf8(tag.data, 1, i);\n tag.url = parseUtf8(tag.data, i + 1, tag.data.length);\n break;\n }\n }\n },\n PRIV: function PRIV(tag) {\n var i;\n\n for (i = 0; i < tag.data.length; i++) {\n if (tag.data[i] === 0) {\n // parse the description and URL fields\n tag.owner = parseIso88591(tag.data, 0, i);\n break;\n }\n }\n\n tag.privateData = tag.data.subarray(i + 1);\n tag.data = tag.privateData;\n }\n },\n _MetadataStream;\n\n _MetadataStream = function MetadataStream(options) {\n var settings = {\n debug: !!(options && options.debug),\n // the bytes of the program-level descriptor field in MP2T\n // see ISO/IEC 13818-1:2013 (E), section 2.6 \"Program and\n // program element descriptors\"\n descriptor: options && options.descriptor\n },\n // the total size in bytes of the ID3 tag being parsed\n tagSize = 0,\n // tag data that is not complete enough to be parsed\n buffer = [],\n // the total number of bytes currently in the buffer\n bufferSize = 0,\n i;\n\n _MetadataStream.prototype.init.call(this); // calculate the text track in-band metadata track dispatch type\n // https://html.spec.whatwg.org/multipage/embedded-content.html#steps-to-expose-a-media-resource-specific-text-track\n\n\n this.dispatchType = streamTypes.METADATA_STREAM_TYPE.toString(16);\n\n if (settings.descriptor) {\n for (i = 0; i < settings.descriptor.length; i++) {\n this.dispatchType += ('00' + settings.descriptor[i].toString(16)).slice(-2);\n }\n }\n\n this.push = function (chunk) {\n var tag, frameStart, frameSize, frame, i, frameHeader;\n\n if (chunk.type !== 'timed-metadata') {\n return;\n } // if data_alignment_indicator is set in the PES header,\n // we must have the start of a new ID3 tag. Assume anything\n // remaining in the buffer was malformed and throw it out\n\n\n if (chunk.dataAlignmentIndicator) {\n bufferSize = 0;\n buffer.length = 0;\n } // ignore events that don't look like ID3 data\n\n\n if (buffer.length === 0 && (chunk.data.length < 10 || chunk.data[0] !== 'I'.charCodeAt(0) || chunk.data[1] !== 'D'.charCodeAt(0) || chunk.data[2] !== '3'.charCodeAt(0))) {\n if (settings.debug) {\n // eslint-disable-next-line no-console\n console.log('Skipping unrecognized metadata packet');\n }\n\n return;\n } // add this chunk to the data we've collected so far\n\n\n buffer.push(chunk);\n bufferSize += chunk.data.byteLength; // grab the size of the entire frame from the ID3 header\n\n if (buffer.length === 1) {\n // the frame size is transmitted as a 28-bit integer in the\n // last four bytes of the ID3 header.\n // The most significant bit of each byte is dropped and the\n // results concatenated to recover the actual value.\n tagSize = parseSyncSafeInteger(chunk.data.subarray(6, 10)); // ID3 reports the tag size excluding the header but it's more\n // convenient for our comparisons to include it\n\n tagSize += 10;\n } // if the entire frame has not arrived, wait for more data\n\n\n if (bufferSize < tagSize) {\n return;\n } // collect the entire frame so it can be parsed\n\n\n tag = {\n data: new Uint8Array(tagSize),\n frames: [],\n pts: buffer[0].pts,\n dts: buffer[0].dts\n };\n\n for (i = 0; i < tagSize;) {\n tag.data.set(buffer[0].data.subarray(0, tagSize - i), i);\n i += buffer[0].data.byteLength;\n bufferSize -= buffer[0].data.byteLength;\n buffer.shift();\n } // find the start of the first frame and the end of the tag\n\n\n frameStart = 10;\n\n if (tag.data[5] & 0x40) {\n // advance the frame start past the extended header\n frameStart += 4; // header size field\n\n frameStart += parseSyncSafeInteger(tag.data.subarray(10, 14)); // clip any padding off the end\n\n tagSize -= parseSyncSafeInteger(tag.data.subarray(16, 20));\n } // parse one or more ID3 frames\n // http://id3.org/id3v2.3.0#ID3v2_frame_overview\n\n\n do {\n // determine the number of bytes in this frame\n frameSize = parseSyncSafeInteger(tag.data.subarray(frameStart + 4, frameStart + 8));\n\n if (frameSize < 1) {\n // eslint-disable-next-line no-console\n return console.log('Malformed ID3 frame encountered. Skipping metadata parsing.');\n }\n\n frameHeader = String.fromCharCode(tag.data[frameStart], tag.data[frameStart + 1], tag.data[frameStart + 2], tag.data[frameStart + 3]);\n frame = {\n id: frameHeader,\n data: tag.data.subarray(frameStart + 10, frameStart + frameSize + 10)\n };\n frame.key = frame.id;\n\n if (tagParsers[frame.id]) {\n tagParsers[frame.id](frame); // handle the special PRIV frame used to indicate the start\n // time for raw AAC data\n\n if (frame.owner === 'com.apple.streaming.transportStreamTimestamp') {\n var d = frame.data,\n size = (d[3] & 0x01) << 30 | d[4] << 22 | d[5] << 14 | d[6] << 6 | d[7] >>> 2;\n size *= 4;\n size += d[7] & 0x03;\n frame.timeStamp = size; // in raw AAC, all subsequent data will be timestamped based\n // on the value of this frame\n // we couldn't have known the appropriate pts and dts before\n // parsing this ID3 tag so set those values now\n\n if (tag.pts === undefined && tag.dts === undefined) {\n tag.pts = frame.timeStamp;\n tag.dts = frame.timeStamp;\n }\n\n this.trigger('timestamp', frame);\n }\n }\n\n tag.frames.push(frame);\n frameStart += 10; // advance past the frame header\n\n frameStart += frameSize; // advance past the frame body\n } while (frameStart < tagSize);\n\n this.trigger('data', tag);\n };\n };\n\n _MetadataStream.prototype = new stream();\n var metadataStream = _MetadataStream;\n var TimestampRolloverStream$1 = timestampRolloverStream.TimestampRolloverStream; // object types\n\n var _TransportPacketStream, _TransportParseStream, _ElementaryStream; // constants\n\n\n var MP2T_PACKET_LENGTH = 188,\n // bytes\n SYNC_BYTE = 0x47;\n /**\n * Splits an incoming stream of binary data into MPEG-2 Transport\n * Stream packets.\n */\n\n _TransportPacketStream = function TransportPacketStream() {\n var buffer = new Uint8Array(MP2T_PACKET_LENGTH),\n bytesInBuffer = 0;\n\n _TransportPacketStream.prototype.init.call(this); // Deliver new bytes to the stream.\n\n /**\n * Split a stream of data into M2TS packets\n **/\n\n\n this.push = function (bytes) {\n var startIndex = 0,\n endIndex = MP2T_PACKET_LENGTH,\n everything; // If there are bytes remaining from the last segment, prepend them to the\n // bytes that were pushed in\n\n if (bytesInBuffer) {\n everything = new Uint8Array(bytes.byteLength + bytesInBuffer);\n everything.set(buffer.subarray(0, bytesInBuffer));\n everything.set(bytes, bytesInBuffer);\n bytesInBuffer = 0;\n } else {\n everything = bytes;\n } // While we have enough data for a packet\n\n\n while (endIndex < everything.byteLength) {\n // Look for a pair of start and end sync bytes in the data..\n if (everything[startIndex] === SYNC_BYTE && everything[endIndex] === SYNC_BYTE) {\n // We found a packet so emit it and jump one whole packet forward in\n // the stream\n this.trigger('data', everything.subarray(startIndex, endIndex));\n startIndex += MP2T_PACKET_LENGTH;\n endIndex += MP2T_PACKET_LENGTH;\n continue;\n } // If we get here, we have somehow become de-synchronized and we need to step\n // forward one byte at a time until we find a pair of sync bytes that denote\n // a packet\n\n\n startIndex++;\n endIndex++;\n } // If there was some data left over at the end of the segment that couldn't\n // possibly be a whole packet, keep it because it might be the start of a packet\n // that continues in the next segment\n\n\n if (startIndex < everything.byteLength) {\n buffer.set(everything.subarray(startIndex), 0);\n bytesInBuffer = everything.byteLength - startIndex;\n }\n };\n /**\n * Passes identified M2TS packets to the TransportParseStream to be parsed\n **/\n\n\n this.flush = function () {\n // If the buffer contains a whole packet when we are being flushed, emit it\n // and empty the buffer. Otherwise hold onto the data because it may be\n // important for decoding the next segment\n if (bytesInBuffer === MP2T_PACKET_LENGTH && buffer[0] === SYNC_BYTE) {\n this.trigger('data', buffer);\n bytesInBuffer = 0;\n }\n\n this.trigger('done');\n };\n };\n\n _TransportPacketStream.prototype = new stream();\n /**\n * Accepts an MP2T TransportPacketStream and emits data events with parsed\n * forms of the individual transport stream packets.\n */\n\n _TransportParseStream = function TransportParseStream() {\n var parsePsi, parsePat, parsePmt, self;\n\n _TransportParseStream.prototype.init.call(this);\n\n self = this;\n this.packetsWaitingForPmt = [];\n this.programMapTable = undefined;\n\n parsePsi = function parsePsi(payload, psi) {\n var offset = 0; // PSI packets may be split into multiple sections and those\n // sections may be split into multiple packets. If a PSI\n // section starts in this packet, the payload_unit_start_indicator\n // will be true and the first byte of the payload will indicate\n // the offset from the current position to the start of the\n // section.\n\n if (psi.payloadUnitStartIndicator) {\n offset += payload[offset] + 1;\n }\n\n if (psi.type === 'pat') {\n parsePat(payload.subarray(offset), psi);\n } else {\n parsePmt(payload.subarray(offset), psi);\n }\n };\n\n parsePat = function parsePat(payload, pat) {\n pat.section_number = payload[7]; // eslint-disable-line camelcase\n\n pat.last_section_number = payload[8]; // eslint-disable-line camelcase\n // skip the PSI header and parse the first PMT entry\n\n self.pmtPid = (payload[10] & 0x1F) << 8 | payload[11];\n pat.pmtPid = self.pmtPid;\n };\n /**\n * Parse out the relevant fields of a Program Map Table (PMT).\n * @param payload {Uint8Array} the PMT-specific portion of an MP2T\n * packet. The first byte in this array should be the table_id\n * field.\n * @param pmt {object} the object that should be decorated with\n * fields parsed from the PMT.\n */\n\n\n parsePmt = function parsePmt(payload, pmt) {\n var sectionLength, tableEnd, programInfoLength, offset; // PMTs can be sent ahead of the time when they should actually\n // take effect. We don't believe this should ever be the case\n // for HLS but we'll ignore \"forward\" PMT declarations if we see\n // them. Future PMT declarations have the current_next_indicator\n // set to zero.\n\n if (!(payload[5] & 0x01)) {\n return;\n } // overwrite any existing program map table\n\n\n self.programMapTable = {\n video: null,\n audio: null,\n 'timed-metadata': {}\n }; // the mapping table ends at the end of the current section\n\n sectionLength = (payload[1] & 0x0f) << 8 | payload[2];\n tableEnd = 3 + sectionLength - 4; // to determine where the table is, we have to figure out how\n // long the program info descriptors are\n\n programInfoLength = (payload[10] & 0x0f) << 8 | payload[11]; // advance the offset to the first entry in the mapping table\n\n offset = 12 + programInfoLength;\n\n while (offset < tableEnd) {\n var streamType = payload[offset];\n var pid = (payload[offset + 1] & 0x1F) << 8 | payload[offset + 2]; // only map a single elementary_pid for audio and video stream types\n // TODO: should this be done for metadata too? for now maintain behavior of\n // multiple metadata streams\n\n if (streamType === streamTypes.H264_STREAM_TYPE && self.programMapTable.video === null) {\n self.programMapTable.video = pid;\n } else if (streamType === streamTypes.ADTS_STREAM_TYPE && self.programMapTable.audio === null) {\n self.programMapTable.audio = pid;\n } else if (streamType === streamTypes.METADATA_STREAM_TYPE) {\n // map pid to stream type for metadata streams\n self.programMapTable['timed-metadata'][pid] = streamType;\n } // move to the next table entry\n // skip past the elementary stream descriptors, if present\n\n\n offset += ((payload[offset + 3] & 0x0F) << 8 | payload[offset + 4]) + 5;\n } // record the map on the packet as well\n\n\n pmt.programMapTable = self.programMapTable;\n };\n /**\n * Deliver a new MP2T packet to the next stream in the pipeline.\n */\n\n\n this.push = function (packet) {\n var result = {},\n offset = 4;\n result.payloadUnitStartIndicator = !!(packet[1] & 0x40); // pid is a 13-bit field starting at the last bit of packet[1]\n\n result.pid = packet[1] & 0x1f;\n result.pid <<= 8;\n result.pid |= packet[2]; // if an adaption field is present, its length is specified by the\n // fifth byte of the TS packet header. The adaptation field is\n // used to add stuffing to PES packets that don't fill a complete\n // TS packet, and to specify some forms of timing and control data\n // that we do not currently use.\n\n if ((packet[3] & 0x30) >>> 4 > 0x01) {\n offset += packet[offset] + 1;\n } // parse the rest of the packet based on the type\n\n\n if (result.pid === 0) {\n result.type = 'pat';\n parsePsi(packet.subarray(offset), result);\n this.trigger('data', result);\n } else if (result.pid === this.pmtPid) {\n result.type = 'pmt';\n parsePsi(packet.subarray(offset), result);\n this.trigger('data', result); // if there are any packets waiting for a PMT to be found, process them now\n\n while (this.packetsWaitingForPmt.length) {\n this.processPes_.apply(this, this.packetsWaitingForPmt.shift());\n }\n } else if (this.programMapTable === undefined) {\n // When we have not seen a PMT yet, defer further processing of\n // PES packets until one has been parsed\n this.packetsWaitingForPmt.push([packet, offset, result]);\n } else {\n this.processPes_(packet, offset, result);\n }\n };\n\n this.processPes_ = function (packet, offset, result) {\n // set the appropriate stream type\n if (result.pid === this.programMapTable.video) {\n result.streamType = streamTypes.H264_STREAM_TYPE;\n } else if (result.pid === this.programMapTable.audio) {\n result.streamType = streamTypes.ADTS_STREAM_TYPE;\n } else {\n // if not video or audio, it is timed-metadata or unknown\n // if unknown, streamType will be undefined\n result.streamType = this.programMapTable['timed-metadata'][result.pid];\n }\n\n result.type = 'pes';\n result.data = packet.subarray(offset);\n this.trigger('data', result);\n };\n };\n\n _TransportParseStream.prototype = new stream();\n _TransportParseStream.STREAM_TYPES = {\n h264: 0x1b,\n adts: 0x0f\n };\n /**\n * Reconsistutes program elementary stream (PES) packets from parsed\n * transport stream packets. That is, if you pipe an\n * mp2t.TransportParseStream into a mp2t.ElementaryStream, the output\n * events will be events which capture the bytes for individual PES\n * packets plus relevant metadata that has been extracted from the\n * container.\n */\n\n _ElementaryStream = function ElementaryStream() {\n var self = this,\n // PES packet fragments\n video = {\n data: [],\n size: 0\n },\n audio = {\n data: [],\n size: 0\n },\n timedMetadata = {\n data: [],\n size: 0\n },\n parsePes = function parsePes(payload, pes) {\n var ptsDtsFlags; // get the packet length, this will be 0 for video\n\n pes.packetLength = 6 + (payload[4] << 8 | payload[5]); // find out if this packets starts a new keyframe\n\n pes.dataAlignmentIndicator = (payload[6] & 0x04) !== 0; // PES packets may be annotated with a PTS value, or a PTS value\n // and a DTS value. Determine what combination of values is\n // available to work with.\n\n ptsDtsFlags = payload[7]; // PTS and DTS are normally stored as a 33-bit number. Javascript\n // performs all bitwise operations on 32-bit integers but javascript\n // supports a much greater range (52-bits) of integer using standard\n // mathematical operations.\n // We construct a 31-bit value using bitwise operators over the 31\n // most significant bits and then multiply by 4 (equal to a left-shift\n // of 2) before we add the final 2 least significant bits of the\n // timestamp (equal to an OR.)\n\n if (ptsDtsFlags & 0xC0) {\n // the PTS and DTS are not written out directly. For information\n // on how they are encoded, see\n // http://dvd.sourceforge.net/dvdinfo/pes-hdr.html\n pes.pts = (payload[9] & 0x0E) << 27 | (payload[10] & 0xFF) << 20 | (payload[11] & 0xFE) << 12 | (payload[12] & 0xFF) << 5 | (payload[13] & 0xFE) >>> 3;\n pes.pts *= 4; // Left shift by 2\n\n pes.pts += (payload[13] & 0x06) >>> 1; // OR by the two LSBs\n\n pes.dts = pes.pts;\n\n if (ptsDtsFlags & 0x40) {\n pes.dts = (payload[14] & 0x0E) << 27 | (payload[15] & 0xFF) << 20 | (payload[16] & 0xFE) << 12 | (payload[17] & 0xFF) << 5 | (payload[18] & 0xFE) >>> 3;\n pes.dts *= 4; // Left shift by 2\n\n pes.dts += (payload[18] & 0x06) >>> 1; // OR by the two LSBs\n }\n } // the data section starts immediately after the PES header.\n // pes_header_data_length specifies the number of header bytes\n // that follow the last byte of the field.\n\n\n pes.data = payload.subarray(9 + payload[8]);\n },\n\n /**\n * Pass completely parsed PES packets to the next stream in the pipeline\n **/\n flushStream = function flushStream(stream$$1, type, forceFlush) {\n var packetData = new Uint8Array(stream$$1.size),\n event = {\n type: type\n },\n i = 0,\n offset = 0,\n packetFlushable = false,\n fragment; // do nothing if there is not enough buffered data for a complete\n // PES header\n\n if (!stream$$1.data.length || stream$$1.size < 9) {\n return;\n }\n\n event.trackId = stream$$1.data[0].pid; // reassemble the packet\n\n for (i = 0; i < stream$$1.data.length; i++) {\n fragment = stream$$1.data[i];\n packetData.set(fragment.data, offset);\n offset += fragment.data.byteLength;\n } // parse assembled packet's PES header\n\n\n parsePes(packetData, event); // non-video PES packets MUST have a non-zero PES_packet_length\n // check that there is enough stream data to fill the packet\n\n packetFlushable = type === 'video' || event.packetLength <= stream$$1.size; // flush pending packets if the conditions are right\n\n if (forceFlush || packetFlushable) {\n stream$$1.size = 0;\n stream$$1.data.length = 0;\n } // only emit packets that are complete. this is to avoid assembling\n // incomplete PES packets due to poor segmentation\n\n\n if (packetFlushable) {\n self.trigger('data', event);\n }\n };\n\n _ElementaryStream.prototype.init.call(this);\n /**\n * Identifies M2TS packet types and parses PES packets using metadata\n * parsed from the PMT\n **/\n\n\n this.push = function (data) {\n ({\n pat: function pat() {// we have to wait for the PMT to arrive as well before we\n // have any meaningful metadata\n },\n pes: function pes() {\n var stream$$1, streamType;\n\n switch (data.streamType) {\n case streamTypes.H264_STREAM_TYPE:\n case streamTypes.H264_STREAM_TYPE:\n stream$$1 = video;\n streamType = 'video';\n break;\n\n case streamTypes.ADTS_STREAM_TYPE:\n stream$$1 = audio;\n streamType = 'audio';\n break;\n\n case streamTypes.METADATA_STREAM_TYPE:\n stream$$1 = timedMetadata;\n streamType = 'timed-metadata';\n break;\n\n default:\n // ignore unknown stream types\n return;\n } // if a new packet is starting, we can flush the completed\n // packet\n\n\n if (data.payloadUnitStartIndicator) {\n flushStream(stream$$1, streamType, true);\n } // buffer this fragment until we are sure we've received the\n // complete payload\n\n\n stream$$1.data.push(data);\n stream$$1.size += data.data.byteLength;\n },\n pmt: function pmt() {\n var event = {\n type: 'metadata',\n tracks: []\n },\n programMapTable = data.programMapTable; // translate audio and video streams to tracks\n\n if (programMapTable.video !== null) {\n event.tracks.push({\n timelineStartInfo: {\n baseMediaDecodeTime: 0\n },\n id: +programMapTable.video,\n codec: 'avc',\n type: 'video'\n });\n }\n\n if (programMapTable.audio !== null) {\n event.tracks.push({\n timelineStartInfo: {\n baseMediaDecodeTime: 0\n },\n id: +programMapTable.audio,\n codec: 'adts',\n type: 'audio'\n });\n }\n\n self.trigger('data', event);\n }\n })[data.type]();\n };\n /**\n * Flush any remaining input. Video PES packets may be of variable\n * length. Normally, the start of a new video packet can trigger the\n * finalization of the previous packet. That is not possible if no\n * more video is forthcoming, however. In that case, some other\n * mechanism (like the end of the file) has to be employed. When it is\n * clear that no additional data is forthcoming, calling this method\n * will flush the buffered packets.\n */\n\n\n this.flush = function () {\n // !!THIS ORDER IS IMPORTANT!!\n // video first then audio\n flushStream(video, 'video');\n flushStream(audio, 'audio');\n flushStream(timedMetadata, 'timed-metadata');\n this.trigger('done');\n };\n };\n\n _ElementaryStream.prototype = new stream();\n var m2ts = {\n PAT_PID: 0x0000,\n MP2T_PACKET_LENGTH: MP2T_PACKET_LENGTH,\n TransportPacketStream: _TransportPacketStream,\n TransportParseStream: _TransportParseStream,\n ElementaryStream: _ElementaryStream,\n TimestampRolloverStream: TimestampRolloverStream$1,\n CaptionStream: captionStream.CaptionStream,\n Cea608Stream: captionStream.Cea608Stream,\n MetadataStream: metadataStream\n };\n\n for (var type in streamTypes) {\n if (streamTypes.hasOwnProperty(type)) {\n m2ts[type] = streamTypes[type];\n }\n }\n\n var m2ts_1 = m2ts;\n\n var _AdtsStream;\n\n var ADTS_SAMPLING_FREQUENCIES = [96000, 88200, 64000, 48000, 44100, 32000, 24000, 22050, 16000, 12000, 11025, 8000, 7350];\n /*\n * Accepts a ElementaryStream and emits data events with parsed\n * AAC Audio Frames of the individual packets. Input audio in ADTS\n * format is unpacked and re-emitted as AAC frames.\n *\n * @see http://wiki.multimedia.cx/index.php?title=ADTS\n * @see http://wiki.multimedia.cx/?title=Understanding_AAC\n */\n\n _AdtsStream = function AdtsStream() {\n var buffer;\n\n _AdtsStream.prototype.init.call(this);\n\n this.push = function (packet) {\n var i = 0,\n frameNum = 0,\n frameLength,\n protectionSkipBytes,\n frameEnd,\n oldBuffer,\n sampleCount,\n adtsFrameDuration;\n\n if (packet.type !== 'audio') {\n // ignore non-audio data\n return;\n } // Prepend any data in the buffer to the input data so that we can parse\n // aac frames the cross a PES packet boundary\n\n\n if (buffer) {\n oldBuffer = buffer;\n buffer = new Uint8Array(oldBuffer.byteLength + packet.data.byteLength);\n buffer.set(oldBuffer);\n buffer.set(packet.data, oldBuffer.byteLength);\n } else {\n buffer = packet.data;\n } // unpack any ADTS frames which have been fully received\n // for details on the ADTS header, see http://wiki.multimedia.cx/index.php?title=ADTS\n\n\n while (i + 5 < buffer.length) {\n // Loook for the start of an ADTS header..\n if (buffer[i] !== 0xFF || (buffer[i + 1] & 0xF6) !== 0xF0) {\n // If a valid header was not found, jump one forward and attempt to\n // find a valid ADTS header starting at the next byte\n i++;\n continue;\n } // The protection skip bit tells us if we have 2 bytes of CRC data at the\n // end of the ADTS header\n\n\n protectionSkipBytes = (~buffer[i + 1] & 0x01) * 2; // Frame length is a 13 bit integer starting 16 bits from the\n // end of the sync sequence\n\n frameLength = (buffer[i + 3] & 0x03) << 11 | buffer[i + 4] << 3 | (buffer[i + 5] & 0xe0) >> 5;\n sampleCount = ((buffer[i + 6] & 0x03) + 1) * 1024;\n adtsFrameDuration = sampleCount * 90000 / ADTS_SAMPLING_FREQUENCIES[(buffer[i + 2] & 0x3c) >>> 2];\n frameEnd = i + frameLength; // If we don't have enough data to actually finish this ADTS frame, return\n // and wait for more data\n\n if (buffer.byteLength < frameEnd) {\n return;\n } // Otherwise, deliver the complete AAC frame\n\n\n this.trigger('data', {\n pts: packet.pts + frameNum * adtsFrameDuration,\n dts: packet.dts + frameNum * adtsFrameDuration,\n sampleCount: sampleCount,\n audioobjecttype: (buffer[i + 2] >>> 6 & 0x03) + 1,\n channelcount: (buffer[i + 2] & 1) << 2 | (buffer[i + 3] & 0xc0) >>> 6,\n samplerate: ADTS_SAMPLING_FREQUENCIES[(buffer[i + 2] & 0x3c) >>> 2],\n samplingfrequencyindex: (buffer[i + 2] & 0x3c) >>> 2,\n // assume ISO/IEC 14496-12 AudioSampleEntry default of 16\n samplesize: 16,\n data: buffer.subarray(i + 7 + protectionSkipBytes, frameEnd)\n }); // If the buffer is empty, clear it and return\n\n if (buffer.byteLength === frameEnd) {\n buffer = undefined;\n return;\n }\n\n frameNum++; // Remove the finished frame from the buffer and start the process again\n\n buffer = buffer.subarray(frameEnd);\n }\n };\n\n this.flush = function () {\n this.trigger('done');\n };\n };\n\n _AdtsStream.prototype = new stream();\n var adts = _AdtsStream;\n var ExpGolomb;\n /**\n * Parser for exponential Golomb codes, a variable-bitwidth number encoding\n * scheme used by h264.\n */\n\n ExpGolomb = function ExpGolomb(workingData) {\n var // the number of bytes left to examine in workingData\n workingBytesAvailable = workingData.byteLength,\n // the current word being examined\n workingWord = 0,\n // :uint\n // the number of bits left to examine in the current word\n workingBitsAvailable = 0; // :uint;\n // ():uint\n\n this.length = function () {\n return 8 * workingBytesAvailable;\n }; // ():uint\n\n\n this.bitsAvailable = function () {\n return 8 * workingBytesAvailable + workingBitsAvailable;\n }; // ():void\n\n\n this.loadWord = function () {\n var position = workingData.byteLength - workingBytesAvailable,\n workingBytes = new Uint8Array(4),\n availableBytes = Math.min(4, workingBytesAvailable);\n\n if (availableBytes === 0) {\n throw new Error('no bytes available');\n }\n\n workingBytes.set(workingData.subarray(position, position + availableBytes));\n workingWord = new DataView(workingBytes.buffer).getUint32(0); // track the amount of workingData that has been processed\n\n workingBitsAvailable = availableBytes * 8;\n workingBytesAvailable -= availableBytes;\n }; // (count:int):void\n\n\n this.skipBits = function (count) {\n var skipBytes; // :int\n\n if (workingBitsAvailable > count) {\n workingWord <<= count;\n workingBitsAvailable -= count;\n } else {\n count -= workingBitsAvailable;\n skipBytes = Math.floor(count / 8);\n count -= skipBytes * 8;\n workingBytesAvailable -= skipBytes;\n this.loadWord();\n workingWord <<= count;\n workingBitsAvailable -= count;\n }\n }; // (size:int):uint\n\n\n this.readBits = function (size) {\n var bits = Math.min(workingBitsAvailable, size),\n // :uint\n valu = workingWord >>> 32 - bits; // :uint\n // if size > 31, handle error\n\n workingBitsAvailable -= bits;\n\n if (workingBitsAvailable > 0) {\n workingWord <<= bits;\n } else if (workingBytesAvailable > 0) {\n this.loadWord();\n }\n\n bits = size - bits;\n\n if (bits > 0) {\n return valu << bits | this.readBits(bits);\n }\n\n return valu;\n }; // ():uint\n\n\n this.skipLeadingZeros = function () {\n var leadingZeroCount; // :uint\n\n for (leadingZeroCount = 0; leadingZeroCount < workingBitsAvailable; ++leadingZeroCount) {\n if ((workingWord & 0x80000000 >>> leadingZeroCount) !== 0) {\n // the first bit of working word is 1\n workingWord <<= leadingZeroCount;\n workingBitsAvailable -= leadingZeroCount;\n return leadingZeroCount;\n }\n } // we exhausted workingWord and still have not found a 1\n\n\n this.loadWord();\n return leadingZeroCount + this.skipLeadingZeros();\n }; // ():void\n\n\n this.skipUnsignedExpGolomb = function () {\n this.skipBits(1 + this.skipLeadingZeros());\n }; // ():void\n\n\n this.skipExpGolomb = function () {\n this.skipBits(1 + this.skipLeadingZeros());\n }; // ():uint\n\n\n this.readUnsignedExpGolomb = function () {\n var clz = this.skipLeadingZeros(); // :uint\n\n return this.readBits(clz + 1) - 1;\n }; // ():int\n\n\n this.readExpGolomb = function () {\n var valu = this.readUnsignedExpGolomb(); // :int\n\n if (0x01 & valu) {\n // the number is odd if the low order bit is set\n return 1 + valu >>> 1; // add 1 to make it even, and divide by 2\n }\n\n return -1 * (valu >>> 1); // divide by two then make it negative\n }; // Some convenience functions\n // :Boolean\n\n\n this.readBoolean = function () {\n return this.readBits(1) === 1;\n }; // ():int\n\n\n this.readUnsignedByte = function () {\n return this.readBits(8);\n };\n\n this.loadWord();\n };\n\n var expGolomb = ExpGolomb;\n\n var _H264Stream, _NalByteStream;\n\n var PROFILES_WITH_OPTIONAL_SPS_DATA;\n /**\n * Accepts a NAL unit byte stream and unpacks the embedded NAL units.\n */\n\n _NalByteStream = function NalByteStream() {\n var syncPoint = 0,\n i,\n buffer;\n\n _NalByteStream.prototype.init.call(this);\n /*\n * Scans a byte stream and triggers a data event with the NAL units found.\n * @param {Object} data Event received from H264Stream\n * @param {Uint8Array} data.data The h264 byte stream to be scanned\n *\n * @see H264Stream.push\n */\n\n\n this.push = function (data) {\n var swapBuffer;\n\n if (!buffer) {\n buffer = data.data;\n } else {\n swapBuffer = new Uint8Array(buffer.byteLength + data.data.byteLength);\n swapBuffer.set(buffer);\n swapBuffer.set(data.data, buffer.byteLength);\n buffer = swapBuffer;\n } // Rec. ITU-T H.264, Annex B\n // scan for NAL unit boundaries\n // a match looks like this:\n // 0 0 1 .. NAL .. 0 0 1\n // ^ sync point ^ i\n // or this:\n // 0 0 1 .. NAL .. 0 0 0\n // ^ sync point ^ i\n // advance the sync point to a NAL start, if necessary\n\n\n for (; syncPoint < buffer.byteLength - 3; syncPoint++) {\n if (buffer[syncPoint + 2] === 1) {\n // the sync point is properly aligned\n i = syncPoint + 5;\n break;\n }\n }\n\n while (i < buffer.byteLength) {\n // look at the current byte to determine if we've hit the end of\n // a NAL unit boundary\n switch (buffer[i]) {\n case 0:\n // skip past non-sync sequences\n if (buffer[i - 1] !== 0) {\n i += 2;\n break;\n } else if (buffer[i - 2] !== 0) {\n i++;\n break;\n } // deliver the NAL unit if it isn't empty\n\n\n if (syncPoint + 3 !== i - 2) {\n this.trigger('data', buffer.subarray(syncPoint + 3, i - 2));\n } // drop trailing zeroes\n\n\n do {\n i++;\n } while (buffer[i] !== 1 && i < buffer.length);\n\n syncPoint = i - 2;\n i += 3;\n break;\n\n case 1:\n // skip past non-sync sequences\n if (buffer[i - 1] !== 0 || buffer[i - 2] !== 0) {\n i += 3;\n break;\n } // deliver the NAL unit\n\n\n this.trigger('data', buffer.subarray(syncPoint + 3, i - 2));\n syncPoint = i - 2;\n i += 3;\n break;\n\n default:\n // the current byte isn't a one or zero, so it cannot be part\n // of a sync sequence\n i += 3;\n break;\n }\n } // filter out the NAL units that were delivered\n\n\n buffer = buffer.subarray(syncPoint);\n i -= syncPoint;\n syncPoint = 0;\n };\n\n this.flush = function () {\n // deliver the last buffered NAL unit\n if (buffer && buffer.byteLength > 3) {\n this.trigger('data', buffer.subarray(syncPoint + 3));\n } // reset the stream state\n\n\n buffer = null;\n syncPoint = 0;\n this.trigger('done');\n };\n };\n\n _NalByteStream.prototype = new stream(); // values of profile_idc that indicate additional fields are included in the SPS\n // see Recommendation ITU-T H.264 (4/2013),\n // 7.3.2.1.1 Sequence parameter set data syntax\n\n PROFILES_WITH_OPTIONAL_SPS_DATA = {\n 100: true,\n 110: true,\n 122: true,\n 244: true,\n 44: true,\n 83: true,\n 86: true,\n 118: true,\n 128: true,\n 138: true,\n 139: true,\n 134: true\n };\n /**\n * Accepts input from a ElementaryStream and produces H.264 NAL unit data\n * events.\n */\n\n _H264Stream = function H264Stream() {\n var nalByteStream = new _NalByteStream(),\n self,\n trackId,\n currentPts,\n currentDts,\n discardEmulationPreventionBytes,\n readSequenceParameterSet,\n skipScalingList;\n\n _H264Stream.prototype.init.call(this);\n\n self = this;\n /*\n * Pushes a packet from a stream onto the NalByteStream\n *\n * @param {Object} packet - A packet received from a stream\n * @param {Uint8Array} packet.data - The raw bytes of the packet\n * @param {Number} packet.dts - Decode timestamp of the packet\n * @param {Number} packet.pts - Presentation timestamp of the packet\n * @param {Number} packet.trackId - The id of the h264 track this packet came from\n * @param {('video'|'audio')} packet.type - The type of packet\n *\n */\n\n this.push = function (packet) {\n if (packet.type !== 'video') {\n return;\n }\n\n trackId = packet.trackId;\n currentPts = packet.pts;\n currentDts = packet.dts;\n nalByteStream.push(packet);\n };\n /*\n * Identify NAL unit types and pass on the NALU, trackId, presentation and decode timestamps\n * for the NALUs to the next stream component.\n * Also, preprocess caption and sequence parameter NALUs.\n *\n * @param {Uint8Array} data - A NAL unit identified by `NalByteStream.push`\n * @see NalByteStream.push\n */\n\n\n nalByteStream.on('data', function (data) {\n var event = {\n trackId: trackId,\n pts: currentPts,\n dts: currentDts,\n data: data\n };\n\n switch (data[0] & 0x1f) {\n case 0x05:\n event.nalUnitType = 'slice_layer_without_partitioning_rbsp_idr';\n break;\n\n case 0x06:\n event.nalUnitType = 'sei_rbsp';\n event.escapedRBSP = discardEmulationPreventionBytes(data.subarray(1));\n break;\n\n case 0x07:\n event.nalUnitType = 'seq_parameter_set_rbsp';\n event.escapedRBSP = discardEmulationPreventionBytes(data.subarray(1));\n event.config = readSequenceParameterSet(event.escapedRBSP);\n break;\n\n case 0x08:\n event.nalUnitType = 'pic_parameter_set_rbsp';\n break;\n\n case 0x09:\n event.nalUnitType = 'access_unit_delimiter_rbsp';\n break;\n\n default:\n break;\n } // This triggers data on the H264Stream\n\n\n self.trigger('data', event);\n });\n nalByteStream.on('done', function () {\n self.trigger('done');\n });\n\n this.flush = function () {\n nalByteStream.flush();\n };\n /**\n * Advance the ExpGolomb decoder past a scaling list. The scaling\n * list is optionally transmitted as part of a sequence parameter\n * set and is not relevant to transmuxing.\n * @param count {number} the number of entries in this scaling list\n * @param expGolombDecoder {object} an ExpGolomb pointed to the\n * start of a scaling list\n * @see Recommendation ITU-T H.264, Section 7.3.2.1.1.1\n */\n\n\n skipScalingList = function skipScalingList(count, expGolombDecoder) {\n var lastScale = 8,\n nextScale = 8,\n j,\n deltaScale;\n\n for (j = 0; j < count; j++) {\n if (nextScale !== 0) {\n deltaScale = expGolombDecoder.readExpGolomb();\n nextScale = (lastScale + deltaScale + 256) % 256;\n }\n\n lastScale = nextScale === 0 ? lastScale : nextScale;\n }\n };\n /**\n * Expunge any \"Emulation Prevention\" bytes from a \"Raw Byte\n * Sequence Payload\"\n * @param data {Uint8Array} the bytes of a RBSP from a NAL\n * unit\n * @return {Uint8Array} the RBSP without any Emulation\n * Prevention Bytes\n */\n\n\n discardEmulationPreventionBytes = function discardEmulationPreventionBytes(data) {\n var length = data.byteLength,\n emulationPreventionBytesPositions = [],\n i = 1,\n newLength,\n newData; // Find all `Emulation Prevention Bytes`\n\n while (i < length - 2) {\n if (data[i] === 0 && data[i + 1] === 0 && data[i + 2] === 0x03) {\n emulationPreventionBytesPositions.push(i + 2);\n i += 2;\n } else {\n i++;\n }\n } // If no Emulation Prevention Bytes were found just return the original\n // array\n\n\n if (emulationPreventionBytesPositions.length === 0) {\n return data;\n } // Create a new array to hold the NAL unit data\n\n\n newLength = length - emulationPreventionBytesPositions.length;\n newData = new Uint8Array(newLength);\n var sourceIndex = 0;\n\n for (i = 0; i < newLength; sourceIndex++, i++) {\n if (sourceIndex === emulationPreventionBytesPositions[0]) {\n // Skip this byte\n sourceIndex++; // Remove this position index\n\n emulationPreventionBytesPositions.shift();\n }\n\n newData[i] = data[sourceIndex];\n }\n\n return newData;\n };\n /**\n * Read a sequence parameter set and return some interesting video\n * properties. A sequence parameter set is the H264 metadata that\n * describes the properties of upcoming video frames.\n * @param data {Uint8Array} the bytes of a sequence parameter set\n * @return {object} an object with configuration parsed from the\n * sequence parameter set, including the dimensions of the\n * associated video frames.\n */\n\n\n readSequenceParameterSet = function readSequenceParameterSet(data) {\n var frameCropLeftOffset = 0,\n frameCropRightOffset = 0,\n frameCropTopOffset = 0,\n frameCropBottomOffset = 0,\n sarScale = 1,\n expGolombDecoder,\n profileIdc,\n levelIdc,\n profileCompatibility,\n chromaFormatIdc,\n picOrderCntType,\n numRefFramesInPicOrderCntCycle,\n picWidthInMbsMinus1,\n picHeightInMapUnitsMinus1,\n frameMbsOnlyFlag,\n scalingListCount,\n sarRatio,\n aspectRatioIdc,\n i;\n expGolombDecoder = new expGolomb(data);\n profileIdc = expGolombDecoder.readUnsignedByte(); // profile_idc\n\n profileCompatibility = expGolombDecoder.readUnsignedByte(); // constraint_set[0-5]_flag\n\n levelIdc = expGolombDecoder.readUnsignedByte(); // level_idc u(8)\n\n expGolombDecoder.skipUnsignedExpGolomb(); // seq_parameter_set_id\n // some profiles have more optional data we don't need\n\n if (PROFILES_WITH_OPTIONAL_SPS_DATA[profileIdc]) {\n chromaFormatIdc = expGolombDecoder.readUnsignedExpGolomb();\n\n if (chromaFormatIdc === 3) {\n expGolombDecoder.skipBits(1); // separate_colour_plane_flag\n }\n\n expGolombDecoder.skipUnsignedExpGolomb(); // bit_depth_luma_minus8\n\n expGolombDecoder.skipUnsignedExpGolomb(); // bit_depth_chroma_minus8\n\n expGolombDecoder.skipBits(1); // qpprime_y_zero_transform_bypass_flag\n\n if (expGolombDecoder.readBoolean()) {\n // seq_scaling_matrix_present_flag\n scalingListCount = chromaFormatIdc !== 3 ? 8 : 12;\n\n for (i = 0; i < scalingListCount; i++) {\n if (expGolombDecoder.readBoolean()) {\n // seq_scaling_list_present_flag[ i ]\n if (i < 6) {\n skipScalingList(16, expGolombDecoder);\n } else {\n skipScalingList(64, expGolombDecoder);\n }\n }\n }\n }\n }\n\n expGolombDecoder.skipUnsignedExpGolomb(); // log2_max_frame_num_minus4\n\n picOrderCntType = expGolombDecoder.readUnsignedExpGolomb();\n\n if (picOrderCntType === 0) {\n expGolombDecoder.readUnsignedExpGolomb(); // log2_max_pic_order_cnt_lsb_minus4\n } else if (picOrderCntType === 1) {\n expGolombDecoder.skipBits(1); // delta_pic_order_always_zero_flag\n\n expGolombDecoder.skipExpGolomb(); // offset_for_non_ref_pic\n\n expGolombDecoder.skipExpGolomb(); // offset_for_top_to_bottom_field\n\n numRefFramesInPicOrderCntCycle = expGolombDecoder.readUnsignedExpGolomb();\n\n for (i = 0; i < numRefFramesInPicOrderCntCycle; i++) {\n expGolombDecoder.skipExpGolomb(); // offset_for_ref_frame[ i ]\n }\n }\n\n expGolombDecoder.skipUnsignedExpGolomb(); // max_num_ref_frames\n\n expGolombDecoder.skipBits(1); // gaps_in_frame_num_value_allowed_flag\n\n picWidthInMbsMinus1 = expGolombDecoder.readUnsignedExpGolomb();\n picHeightInMapUnitsMinus1 = expGolombDecoder.readUnsignedExpGolomb();\n frameMbsOnlyFlag = expGolombDecoder.readBits(1);\n\n if (frameMbsOnlyFlag === 0) {\n expGolombDecoder.skipBits(1); // mb_adaptive_frame_field_flag\n }\n\n expGolombDecoder.skipBits(1); // direct_8x8_inference_flag\n\n if (expGolombDecoder.readBoolean()) {\n // frame_cropping_flag\n frameCropLeftOffset = expGolombDecoder.readUnsignedExpGolomb();\n frameCropRightOffset = expGolombDecoder.readUnsignedExpGolomb();\n frameCropTopOffset = expGolombDecoder.readUnsignedExpGolomb();\n frameCropBottomOffset = expGolombDecoder.readUnsignedExpGolomb();\n }\n\n if (expGolombDecoder.readBoolean()) {\n // vui_parameters_present_flag\n if (expGolombDecoder.readBoolean()) {\n // aspect_ratio_info_present_flag\n aspectRatioIdc = expGolombDecoder.readUnsignedByte();\n\n switch (aspectRatioIdc) {\n case 1:\n sarRatio = [1, 1];\n break;\n\n case 2:\n sarRatio = [12, 11];\n break;\n\n case 3:\n sarRatio = [10, 11];\n break;\n\n case 4:\n sarRatio = [16, 11];\n break;\n\n case 5:\n sarRatio = [40, 33];\n break;\n\n case 6:\n sarRatio = [24, 11];\n break;\n\n case 7:\n sarRatio = [20, 11];\n break;\n\n case 8:\n sarRatio = [32, 11];\n break;\n\n case 9:\n sarRatio = [80, 33];\n break;\n\n case 10:\n sarRatio = [18, 11];\n break;\n\n case 11:\n sarRatio = [15, 11];\n break;\n\n case 12:\n sarRatio = [64, 33];\n break;\n\n case 13:\n sarRatio = [160, 99];\n break;\n\n case 14:\n sarRatio = [4, 3];\n break;\n\n case 15:\n sarRatio = [3, 2];\n break;\n\n case 16:\n sarRatio = [2, 1];\n break;\n\n case 255:\n {\n sarRatio = [expGolombDecoder.readUnsignedByte() << 8 | expGolombDecoder.readUnsignedByte(), expGolombDecoder.readUnsignedByte() << 8 | expGolombDecoder.readUnsignedByte()];\n break;\n }\n }\n\n if (sarRatio) {\n sarScale = sarRatio[0] / sarRatio[1];\n }\n }\n }\n\n return {\n profileIdc: profileIdc,\n levelIdc: levelIdc,\n profileCompatibility: profileCompatibility,\n width: Math.ceil(((picWidthInMbsMinus1 + 1) * 16 - frameCropLeftOffset * 2 - frameCropRightOffset * 2) * sarScale),\n height: (2 - frameMbsOnlyFlag) * (picHeightInMapUnitsMinus1 + 1) * 16 - frameCropTopOffset * 2 - frameCropBottomOffset * 2\n };\n };\n };\n\n _H264Stream.prototype = new stream();\n var h264 = {\n H264Stream: _H264Stream,\n NalByteStream: _NalByteStream\n };\n /**\n * mux.js\n *\n * Copyright (c) 2016 Brightcove\n * All rights reserved.\n *\n * Utilities to detect basic properties and metadata about Aac data.\n */\n\n var ADTS_SAMPLING_FREQUENCIES$1 = [96000, 88200, 64000, 48000, 44100, 32000, 24000, 22050, 16000, 12000, 11025, 8000, 7350];\n\n var isLikelyAacData = function isLikelyAacData(data) {\n if (data[0] === 'I'.charCodeAt(0) && data[1] === 'D'.charCodeAt(0) && data[2] === '3'.charCodeAt(0)) {\n return true;\n }\n\n return false;\n };\n\n var parseSyncSafeInteger$1 = function parseSyncSafeInteger(data) {\n return data[0] << 21 | data[1] << 14 | data[2] << 7 | data[3];\n }; // return a percent-encoded representation of the specified byte range\n // @see http://en.wikipedia.org/wiki/Percent-encoding\n\n\n var percentEncode$1 = function percentEncode(bytes, start, end) {\n var i,\n result = '';\n\n for (i = start; i < end; i++) {\n result += '%' + ('00' + bytes[i].toString(16)).slice(-2);\n }\n\n return result;\n }; // return the string representation of the specified byte range,\n // interpreted as ISO-8859-1.\n\n\n var parseIso88591$1 = function parseIso88591(bytes, start, end) {\n return unescape(percentEncode$1(bytes, start, end)); // jshint ignore:line\n };\n\n var parseId3TagSize = function parseId3TagSize(header, byteIndex) {\n var returnSize = header[byteIndex + 6] << 21 | header[byteIndex + 7] << 14 | header[byteIndex + 8] << 7 | header[byteIndex + 9],\n flags = header[byteIndex + 5],\n footerPresent = (flags & 16) >> 4;\n\n if (footerPresent) {\n return returnSize + 20;\n }\n\n return returnSize + 10;\n };\n\n var parseAdtsSize = function parseAdtsSize(header, byteIndex) {\n var lowThree = (header[byteIndex + 5] & 0xE0) >> 5,\n middle = header[byteIndex + 4] << 3,\n highTwo = header[byteIndex + 3] & 0x3 << 11;\n return highTwo | middle | lowThree;\n };\n\n var parseType$1 = function parseType(header, byteIndex) {\n if (header[byteIndex] === 'I'.charCodeAt(0) && header[byteIndex + 1] === 'D'.charCodeAt(0) && header[byteIndex + 2] === '3'.charCodeAt(0)) {\n return 'timed-metadata';\n } else if (header[byteIndex] & 0xff === 0xff && (header[byteIndex + 1] & 0xf0) === 0xf0) {\n return 'audio';\n }\n\n return null;\n };\n\n var parseSampleRate = function parseSampleRate(packet) {\n var i = 0;\n\n while (i + 5 < packet.length) {\n if (packet[i] !== 0xFF || (packet[i + 1] & 0xF6) !== 0xF0) {\n // If a valid header was not found, jump one forward and attempt to\n // find a valid ADTS header starting at the next byte\n i++;\n continue;\n }\n\n return ADTS_SAMPLING_FREQUENCIES$1[(packet[i + 2] & 0x3c) >>> 2];\n }\n\n return null;\n };\n\n var parseAacTimestamp = function parseAacTimestamp(packet) {\n var frameStart, frameSize, frame, frameHeader; // find the start of the first frame and the end of the tag\n\n frameStart = 10;\n\n if (packet[5] & 0x40) {\n // advance the frame start past the extended header\n frameStart += 4; // header size field\n\n frameStart += parseSyncSafeInteger$1(packet.subarray(10, 14));\n } // parse one or more ID3 frames\n // http://id3.org/id3v2.3.0#ID3v2_frame_overview\n\n\n do {\n // determine the number of bytes in this frame\n frameSize = parseSyncSafeInteger$1(packet.subarray(frameStart + 4, frameStart + 8));\n\n if (frameSize < 1) {\n return null;\n }\n\n frameHeader = String.fromCharCode(packet[frameStart], packet[frameStart + 1], packet[frameStart + 2], packet[frameStart + 3]);\n\n if (frameHeader === 'PRIV') {\n frame = packet.subarray(frameStart + 10, frameStart + frameSize + 10);\n\n for (var i = 0; i < frame.byteLength; i++) {\n if (frame[i] === 0) {\n var owner = parseIso88591$1(frame, 0, i);\n\n if (owner === 'com.apple.streaming.transportStreamTimestamp') {\n var d = frame.subarray(i + 1);\n var size = (d[3] & 0x01) << 30 | d[4] << 22 | d[5] << 14 | d[6] << 6 | d[7] >>> 2;\n size *= 4;\n size += d[7] & 0x03;\n return size;\n }\n\n break;\n }\n }\n }\n\n frameStart += 10; // advance past the frame header\n\n frameStart += frameSize; // advance past the frame body\n } while (frameStart < packet.byteLength);\n\n return null;\n };\n\n var utils = {\n isLikelyAacData: isLikelyAacData,\n parseId3TagSize: parseId3TagSize,\n parseAdtsSize: parseAdtsSize,\n parseType: parseType$1,\n parseSampleRate: parseSampleRate,\n parseAacTimestamp: parseAacTimestamp\n }; // Constants\n\n var _AacStream;\n /**\n * Splits an incoming stream of binary data into ADTS and ID3 Frames.\n */\n\n\n _AacStream = function AacStream() {\n var everything = new Uint8Array(),\n timeStamp = 0;\n\n _AacStream.prototype.init.call(this);\n\n this.setTimestamp = function (timestamp) {\n timeStamp = timestamp;\n };\n\n this.push = function (bytes) {\n var frameSize = 0,\n byteIndex = 0,\n bytesLeft,\n chunk,\n packet,\n tempLength; // If there are bytes remaining from the last segment, prepend them to the\n // bytes that were pushed in\n\n if (everything.length) {\n tempLength = everything.length;\n everything = new Uint8Array(bytes.byteLength + tempLength);\n everything.set(everything.subarray(0, tempLength));\n everything.set(bytes, tempLength);\n } else {\n everything = bytes;\n }\n\n while (everything.length - byteIndex >= 3) {\n if (everything[byteIndex] === 'I'.charCodeAt(0) && everything[byteIndex + 1] === 'D'.charCodeAt(0) && everything[byteIndex + 2] === '3'.charCodeAt(0)) {\n // Exit early because we don't have enough to parse\n // the ID3 tag header\n if (everything.length - byteIndex < 10) {\n break;\n } // check framesize\n\n\n frameSize = utils.parseId3TagSize(everything, byteIndex); // Exit early if we don't have enough in the buffer\n // to emit a full packet\n // Add to byteIndex to support multiple ID3 tags in sequence\n\n if (byteIndex + frameSize > everything.length) {\n break;\n }\n\n chunk = {\n type: 'timed-metadata',\n data: everything.subarray(byteIndex, byteIndex + frameSize)\n };\n this.trigger('data', chunk);\n byteIndex += frameSize;\n continue;\n } else if ((everything[byteIndex] & 0xff) === 0xff && (everything[byteIndex + 1] & 0xf0) === 0xf0) {\n // Exit early because we don't have enough to parse\n // the ADTS frame header\n if (everything.length - byteIndex < 7) {\n break;\n }\n\n frameSize = utils.parseAdtsSize(everything, byteIndex); // Exit early if we don't have enough in the buffer\n // to emit a full packet\n\n if (byteIndex + frameSize > everything.length) {\n break;\n }\n\n packet = {\n type: 'audio',\n data: everything.subarray(byteIndex, byteIndex + frameSize),\n pts: timeStamp,\n dts: timeStamp\n };\n this.trigger('data', packet);\n byteIndex += frameSize;\n continue;\n }\n\n byteIndex++;\n }\n\n bytesLeft = everything.length - byteIndex;\n\n if (bytesLeft > 0) {\n everything = everything.subarray(byteIndex);\n } else {\n everything = new Uint8Array();\n }\n };\n };\n\n _AacStream.prototype = new stream();\n var aac = _AacStream;\n var H264Stream = h264.H264Stream;\n var isLikelyAacData$1 = utils.isLikelyAacData; // constants\n\n var AUDIO_PROPERTIES = ['audioobjecttype', 'channelcount', 'samplerate', 'samplingfrequencyindex', 'samplesize'];\n var VIDEO_PROPERTIES = ['width', 'height', 'profileIdc', 'levelIdc', 'profileCompatibility']; // object types\n\n var _VideoSegmentStream, _AudioSegmentStream, _Transmuxer, _CoalesceStream;\n /**\n * Compare two arrays (even typed) for same-ness\n */\n\n\n var arrayEquals = function arrayEquals(a, b) {\n var i;\n\n if (a.length !== b.length) {\n return false;\n } // compare the value of each element in the array\n\n\n for (i = 0; i < a.length; i++) {\n if (a[i] !== b[i]) {\n return false;\n }\n }\n\n return true;\n };\n /**\n * Constructs a single-track, ISO BMFF media segment from AAC data\n * events. The output of this stream can be fed to a SourceBuffer\n * configured with a suitable initialization segment.\n * @param track {object} track metadata configuration\n * @param options {object} transmuxer options object\n * @param options.keepOriginalTimestamps {boolean} If true, keep the timestamps\n * in the source; false to adjust the first segment to start at 0.\n */\n\n\n _AudioSegmentStream = function AudioSegmentStream(track, options) {\n var adtsFrames = [],\n sequenceNumber = 0,\n earliestAllowedDts = 0,\n audioAppendStartTs = 0,\n videoBaseMediaDecodeTime = Infinity;\n options = options || {};\n\n _AudioSegmentStream.prototype.init.call(this);\n\n this.push = function (data) {\n trackDecodeInfo.collectDtsInfo(track, data);\n\n if (track) {\n AUDIO_PROPERTIES.forEach(function (prop) {\n track[prop] = data[prop];\n });\n } // buffer audio data until end() is called\n\n\n adtsFrames.push(data);\n };\n\n this.setEarliestDts = function (earliestDts) {\n earliestAllowedDts = earliestDts - track.timelineStartInfo.baseMediaDecodeTime;\n };\n\n this.setVideoBaseMediaDecodeTime = function (baseMediaDecodeTime) {\n videoBaseMediaDecodeTime = baseMediaDecodeTime;\n };\n\n this.setAudioAppendStart = function (timestamp) {\n audioAppendStartTs = timestamp;\n };\n\n this.flush = function () {\n var frames, moof, mdat, boxes; // return early if no audio data has been observed\n\n if (adtsFrames.length === 0) {\n this.trigger('done', 'AudioSegmentStream');\n return;\n }\n\n frames = audioFrameUtils.trimAdtsFramesByEarliestDts(adtsFrames, track, earliestAllowedDts);\n track.baseMediaDecodeTime = trackDecodeInfo.calculateTrackBaseMediaDecodeTime(track, options.keepOriginalTimestamps);\n audioFrameUtils.prefixWithSilence(track, frames, audioAppendStartTs, videoBaseMediaDecodeTime); // we have to build the index from byte locations to\n // samples (that is, adts frames) in the audio data\n\n track.samples = audioFrameUtils.generateSampleTable(frames); // concatenate the audio data to constuct the mdat\n\n mdat = mp4Generator.mdat(audioFrameUtils.concatenateFrameData(frames));\n adtsFrames = [];\n moof = mp4Generator.moof(sequenceNumber, [track]);\n boxes = new Uint8Array(moof.byteLength + mdat.byteLength); // bump the sequence number for next time\n\n sequenceNumber++;\n boxes.set(moof);\n boxes.set(mdat, moof.byteLength);\n trackDecodeInfo.clearDtsInfo(track);\n this.trigger('data', {\n track: track,\n boxes: boxes\n });\n this.trigger('done', 'AudioSegmentStream');\n };\n };\n\n _AudioSegmentStream.prototype = new stream();\n /**\n * Constructs a single-track, ISO BMFF media segment from H264 data\n * events. The output of this stream can be fed to a SourceBuffer\n * configured with a suitable initialization segment.\n * @param track {object} track metadata configuration\n * @param options {object} transmuxer options object\n * @param options.alignGopsAtEnd {boolean} If true, start from the end of the\n * gopsToAlignWith list when attempting to align gop pts\n * @param options.keepOriginalTimestamps {boolean} If true, keep the timestamps\n * in the source; false to adjust the first segment to start at 0.\n */\n\n _VideoSegmentStream = function VideoSegmentStream(track, options) {\n var sequenceNumber = 0,\n nalUnits = [],\n gopsToAlignWith = [],\n config,\n pps;\n options = options || {};\n\n _VideoSegmentStream.prototype.init.call(this);\n\n delete track.minPTS;\n this.gopCache_ = [];\n /**\n * Constructs a ISO BMFF segment given H264 nalUnits\n * @param {Object} nalUnit A data event representing a nalUnit\n * @param {String} nalUnit.nalUnitType\n * @param {Object} nalUnit.config Properties for a mp4 track\n * @param {Uint8Array} nalUnit.data The nalUnit bytes\n * @see lib/codecs/h264.js\n **/\n\n this.push = function (nalUnit) {\n trackDecodeInfo.collectDtsInfo(track, nalUnit); // record the track config\n\n if (nalUnit.nalUnitType === 'seq_parameter_set_rbsp' && !config) {\n config = nalUnit.config;\n track.sps = [nalUnit.data];\n VIDEO_PROPERTIES.forEach(function (prop) {\n track[prop] = config[prop];\n }, this);\n }\n\n if (nalUnit.nalUnitType === 'pic_parameter_set_rbsp' && !pps) {\n pps = nalUnit.data;\n track.pps = [nalUnit.data];\n } // buffer video until flush() is called\n\n\n nalUnits.push(nalUnit);\n };\n /**\n * Pass constructed ISO BMFF track and boxes on to the\n * next stream in the pipeline\n **/\n\n\n this.flush = function () {\n var frames, gopForFusion, gops, moof, mdat, boxes; // Throw away nalUnits at the start of the byte stream until\n // we find the first AUD\n\n while (nalUnits.length) {\n if (nalUnits[0].nalUnitType === 'access_unit_delimiter_rbsp') {\n break;\n }\n\n nalUnits.shift();\n } // Return early if no video data has been observed\n\n\n if (nalUnits.length === 0) {\n this.resetStream_();\n this.trigger('done', 'VideoSegmentStream');\n return;\n } // Organize the raw nal-units into arrays that represent\n // higher-level constructs such as frames and gops\n // (group-of-pictures)\n\n\n frames = frameUtils.groupNalsIntoFrames(nalUnits);\n gops = frameUtils.groupFramesIntoGops(frames); // If the first frame of this fragment is not a keyframe we have\n // a problem since MSE (on Chrome) requires a leading keyframe.\n //\n // We have two approaches to repairing this situation:\n // 1) GOP-FUSION:\n // This is where we keep track of the GOPS (group-of-pictures)\n // from previous fragments and attempt to find one that we can\n // prepend to the current fragment in order to create a valid\n // fragment.\n // 2) KEYFRAME-PULLING:\n // Here we search for the first keyframe in the fragment and\n // throw away all the frames between the start of the fragment\n // and that keyframe. We then extend the duration and pull the\n // PTS of the keyframe forward so that it covers the time range\n // of the frames that were disposed of.\n //\n // #1 is far prefereable over #2 which can cause \"stuttering\" but\n // requires more things to be just right.\n\n if (!gops[0][0].keyFrame) {\n // Search for a gop for fusion from our gopCache\n gopForFusion = this.getGopForFusion_(nalUnits[0], track);\n\n if (gopForFusion) {\n gops.unshift(gopForFusion); // Adjust Gops' metadata to account for the inclusion of the\n // new gop at the beginning\n\n gops.byteLength += gopForFusion.byteLength;\n gops.nalCount += gopForFusion.nalCount;\n gops.pts = gopForFusion.pts;\n gops.dts = gopForFusion.dts;\n gops.duration += gopForFusion.duration;\n } else {\n // If we didn't find a candidate gop fall back to keyframe-pulling\n gops = frameUtils.extendFirstKeyFrame(gops);\n }\n } // Trim gops to align with gopsToAlignWith\n\n\n if (gopsToAlignWith.length) {\n var alignedGops;\n\n if (options.alignGopsAtEnd) {\n alignedGops = this.alignGopsAtEnd_(gops);\n } else {\n alignedGops = this.alignGopsAtStart_(gops);\n }\n\n if (!alignedGops) {\n // save all the nals in the last GOP into the gop cache\n this.gopCache_.unshift({\n gop: gops.pop(),\n pps: track.pps,\n sps: track.sps\n }); // Keep a maximum of 6 GOPs in the cache\n\n this.gopCache_.length = Math.min(6, this.gopCache_.length); // Clear nalUnits\n\n nalUnits = []; // return early no gops can be aligned with desired gopsToAlignWith\n\n this.resetStream_();\n this.trigger('done', 'VideoSegmentStream');\n return;\n } // Some gops were trimmed. clear dts info so minSegmentDts and pts are correct\n // when recalculated before sending off to CoalesceStream\n\n\n trackDecodeInfo.clearDtsInfo(track);\n gops = alignedGops;\n }\n\n trackDecodeInfo.collectDtsInfo(track, gops); // First, we have to build the index from byte locations to\n // samples (that is, frames) in the video data\n\n track.samples = frameUtils.generateSampleTable(gops); // Concatenate the video data and construct the mdat\n\n mdat = mp4Generator.mdat(frameUtils.concatenateNalData(gops));\n track.baseMediaDecodeTime = trackDecodeInfo.calculateTrackBaseMediaDecodeTime(track, options.keepOriginalTimestamps);\n this.trigger('processedGopsInfo', gops.map(function (gop) {\n return {\n pts: gop.pts,\n dts: gop.dts,\n byteLength: gop.byteLength\n };\n })); // save all the nals in the last GOP into the gop cache\n\n this.gopCache_.unshift({\n gop: gops.pop(),\n pps: track.pps,\n sps: track.sps\n }); // Keep a maximum of 6 GOPs in the cache\n\n this.gopCache_.length = Math.min(6, this.gopCache_.length); // Clear nalUnits\n\n nalUnits = [];\n this.trigger('baseMediaDecodeTime', track.baseMediaDecodeTime);\n this.trigger('timelineStartInfo', track.timelineStartInfo);\n moof = mp4Generator.moof(sequenceNumber, [track]); // it would be great to allocate this array up front instead of\n // throwing away hundreds of media segment fragments\n\n boxes = new Uint8Array(moof.byteLength + mdat.byteLength); // Bump the sequence number for next time\n\n sequenceNumber++;\n boxes.set(moof);\n boxes.set(mdat, moof.byteLength);\n this.trigger('data', {\n track: track,\n boxes: boxes\n });\n this.resetStream_(); // Continue with the flush process now\n\n this.trigger('done', 'VideoSegmentStream');\n };\n\n this.resetStream_ = function () {\n trackDecodeInfo.clearDtsInfo(track); // reset config and pps because they may differ across segments\n // for instance, when we are rendition switching\n\n config = undefined;\n pps = undefined;\n }; // Search for a candidate Gop for gop-fusion from the gop cache and\n // return it or return null if no good candidate was found\n\n\n this.getGopForFusion_ = function (nalUnit) {\n var halfSecond = 45000,\n // Half-a-second in a 90khz clock\n allowableOverlap = 10000,\n // About 3 frames @ 30fps\n nearestDistance = Infinity,\n dtsDistance,\n nearestGopObj,\n currentGop,\n currentGopObj,\n i; // Search for the GOP nearest to the beginning of this nal unit\n\n for (i = 0; i < this.gopCache_.length; i++) {\n currentGopObj = this.gopCache_[i];\n currentGop = currentGopObj.gop; // Reject Gops with different SPS or PPS\n\n if (!(track.pps && arrayEquals(track.pps[0], currentGopObj.pps[0])) || !(track.sps && arrayEquals(track.sps[0], currentGopObj.sps[0]))) {\n continue;\n } // Reject Gops that would require a negative baseMediaDecodeTime\n\n\n if (currentGop.dts < track.timelineStartInfo.dts) {\n continue;\n } // The distance between the end of the gop and the start of the nalUnit\n\n\n dtsDistance = nalUnit.dts - currentGop.dts - currentGop.duration; // Only consider GOPS that start before the nal unit and end within\n // a half-second of the nal unit\n\n if (dtsDistance >= -allowableOverlap && dtsDistance <= halfSecond) {\n // Always use the closest GOP we found if there is more than\n // one candidate\n if (!nearestGopObj || nearestDistance > dtsDistance) {\n nearestGopObj = currentGopObj;\n nearestDistance = dtsDistance;\n }\n }\n }\n\n if (nearestGopObj) {\n return nearestGopObj.gop;\n }\n\n return null;\n }; // trim gop list to the first gop found that has a matching pts with a gop in the list\n // of gopsToAlignWith starting from the START of the list\n\n\n this.alignGopsAtStart_ = function (gops) {\n var alignIndex, gopIndex, align, gop, byteLength, nalCount, duration, alignedGops;\n byteLength = gops.byteLength;\n nalCount = gops.nalCount;\n duration = gops.duration;\n alignIndex = gopIndex = 0;\n\n while (alignIndex < gopsToAlignWith.length && gopIndex < gops.length) {\n align = gopsToAlignWith[alignIndex];\n gop = gops[gopIndex];\n\n if (align.pts === gop.pts) {\n break;\n }\n\n if (gop.pts > align.pts) {\n // this current gop starts after the current gop we want to align on, so increment\n // align index\n alignIndex++;\n continue;\n } // current gop starts before the current gop we want to align on. so increment gop\n // index\n\n\n gopIndex++;\n byteLength -= gop.byteLength;\n nalCount -= gop.nalCount;\n duration -= gop.duration;\n }\n\n if (gopIndex === 0) {\n // no gops to trim\n return gops;\n }\n\n if (gopIndex === gops.length) {\n // all gops trimmed, skip appending all gops\n return null;\n }\n\n alignedGops = gops.slice(gopIndex);\n alignedGops.byteLength = byteLength;\n alignedGops.duration = duration;\n alignedGops.nalCount = nalCount;\n alignedGops.pts = alignedGops[0].pts;\n alignedGops.dts = alignedGops[0].dts;\n return alignedGops;\n }; // trim gop list to the first gop found that has a matching pts with a gop in the list\n // of gopsToAlignWith starting from the END of the list\n\n\n this.alignGopsAtEnd_ = function (gops) {\n var alignIndex, gopIndex, align, gop, alignEndIndex, matchFound;\n alignIndex = gopsToAlignWith.length - 1;\n gopIndex = gops.length - 1;\n alignEndIndex = null;\n matchFound = false;\n\n while (alignIndex >= 0 && gopIndex >= 0) {\n align = gopsToAlignWith[alignIndex];\n gop = gops[gopIndex];\n\n if (align.pts === gop.pts) {\n matchFound = true;\n break;\n }\n\n if (align.pts > gop.pts) {\n alignIndex--;\n continue;\n }\n\n if (alignIndex === gopsToAlignWith.length - 1) {\n // gop.pts is greater than the last alignment candidate. If no match is found\n // by the end of this loop, we still want to append gops that come after this\n // point\n alignEndIndex = gopIndex;\n }\n\n gopIndex--;\n }\n\n if (!matchFound && alignEndIndex === null) {\n return null;\n }\n\n var trimIndex;\n\n if (matchFound) {\n trimIndex = gopIndex;\n } else {\n trimIndex = alignEndIndex;\n }\n\n if (trimIndex === 0) {\n return gops;\n }\n\n var alignedGops = gops.slice(trimIndex);\n var metadata = alignedGops.reduce(function (total, gop) {\n total.byteLength += gop.byteLength;\n total.duration += gop.duration;\n total.nalCount += gop.nalCount;\n return total;\n }, {\n byteLength: 0,\n duration: 0,\n nalCount: 0\n });\n alignedGops.byteLength = metadata.byteLength;\n alignedGops.duration = metadata.duration;\n alignedGops.nalCount = metadata.nalCount;\n alignedGops.pts = alignedGops[0].pts;\n alignedGops.dts = alignedGops[0].dts;\n return alignedGops;\n };\n\n this.alignGopsWith = function (newGopsToAlignWith) {\n gopsToAlignWith = newGopsToAlignWith;\n };\n };\n\n _VideoSegmentStream.prototype = new stream();\n /**\n * A Stream that can combine multiple streams (ie. audio & video)\n * into a single output segment for MSE. Also supports audio-only\n * and video-only streams.\n * @param options {object} transmuxer options object\n * @param options.keepOriginalTimestamps {boolean} If true, keep the timestamps\n * in the source; false to adjust the first segment to start at media timeline start.\n */\n\n _CoalesceStream = function CoalesceStream(options, metadataStream) {\n // Number of Tracks per output segment\n // If greater than 1, we combine multiple\n // tracks into a single segment\n this.numberOfTracks = 0;\n this.metadataStream = metadataStream;\n options = options || {};\n\n if (typeof options.remux !== 'undefined') {\n this.remuxTracks = !!options.remux;\n } else {\n this.remuxTracks = true;\n }\n\n if (typeof options.keepOriginalTimestamps === 'boolean') {\n this.keepOriginalTimestamps = options.keepOriginalTimestamps;\n }\n\n this.pendingTracks = [];\n this.videoTrack = null;\n this.pendingBoxes = [];\n this.pendingCaptions = [];\n this.pendingMetadata = [];\n this.pendingBytes = 0;\n this.emittedTracks = 0;\n\n _CoalesceStream.prototype.init.call(this); // Take output from multiple\n\n\n this.push = function (output) {\n // buffer incoming captions until the associated video segment\n // finishes\n if (output.text) {\n return this.pendingCaptions.push(output);\n } // buffer incoming id3 tags until the final flush\n\n\n if (output.frames) {\n return this.pendingMetadata.push(output);\n } // Add this track to the list of pending tracks and store\n // important information required for the construction of\n // the final segment\n\n\n this.pendingTracks.push(output.track);\n this.pendingBoxes.push(output.boxes);\n this.pendingBytes += output.boxes.byteLength;\n\n if (output.track.type === 'video') {\n this.videoTrack = output.track;\n }\n\n if (output.track.type === 'audio') {\n this.audioTrack = output.track;\n }\n };\n };\n\n _CoalesceStream.prototype = new stream();\n\n _CoalesceStream.prototype.flush = function (flushSource) {\n var offset = 0,\n event = {\n captions: [],\n captionStreams: {},\n metadata: [],\n info: {}\n },\n caption,\n id3,\n initSegment,\n timelineStartPts = 0,\n i;\n\n if (this.pendingTracks.length < this.numberOfTracks) {\n if (flushSource !== 'VideoSegmentStream' && flushSource !== 'AudioSegmentStream') {\n // Return because we haven't received a flush from a data-generating\n // portion of the segment (meaning that we have only recieved meta-data\n // or captions.)\n return;\n } else if (this.remuxTracks) {\n // Return until we have enough tracks from the pipeline to remux (if we\n // are remuxing audio and video into a single MP4)\n return;\n } else if (this.pendingTracks.length === 0) {\n // In the case where we receive a flush without any data having been\n // received we consider it an emitted track for the purposes of coalescing\n // `done` events.\n // We do this for the case where there is an audio and video track in the\n // segment but no audio data. (seen in several playlists with alternate\n // audio tracks and no audio present in the main TS segments.)\n this.emittedTracks++;\n\n if (this.emittedTracks >= this.numberOfTracks) {\n this.trigger('done');\n this.emittedTracks = 0;\n }\n\n return;\n }\n }\n\n if (this.videoTrack) {\n timelineStartPts = this.videoTrack.timelineStartInfo.pts;\n VIDEO_PROPERTIES.forEach(function (prop) {\n event.info[prop] = this.videoTrack[prop];\n }, this);\n } else if (this.audioTrack) {\n timelineStartPts = this.audioTrack.timelineStartInfo.pts;\n AUDIO_PROPERTIES.forEach(function (prop) {\n event.info[prop] = this.audioTrack[prop];\n }, this);\n }\n\n if (this.pendingTracks.length === 1) {\n event.type = this.pendingTracks[0].type;\n } else {\n event.type = 'combined';\n }\n\n this.emittedTracks += this.pendingTracks.length;\n initSegment = mp4Generator.initSegment(this.pendingTracks); // Create a new typed array to hold the init segment\n\n event.initSegment = new Uint8Array(initSegment.byteLength); // Create an init segment containing a moov\n // and track definitions\n\n event.initSegment.set(initSegment); // Create a new typed array to hold the moof+mdats\n\n event.data = new Uint8Array(this.pendingBytes); // Append each moof+mdat (one per track) together\n\n for (i = 0; i < this.pendingBoxes.length; i++) {\n event.data.set(this.pendingBoxes[i], offset);\n offset += this.pendingBoxes[i].byteLength;\n } // Translate caption PTS times into second offsets to match the\n // video timeline for the segment, and add track info\n\n\n for (i = 0; i < this.pendingCaptions.length; i++) {\n caption = this.pendingCaptions[i];\n caption.startTime = caption.startPts;\n\n if (!this.keepOriginalTimestamps) {\n caption.startTime -= timelineStartPts;\n }\n\n caption.startTime /= 90e3;\n caption.endTime = caption.endPts;\n\n if (!this.keepOriginalTimestamps) {\n caption.endTime -= timelineStartPts;\n }\n\n caption.endTime /= 90e3;\n event.captionStreams[caption.stream] = true;\n event.captions.push(caption);\n } // Translate ID3 frame PTS times into second offsets to match the\n // video timeline for the segment\n\n\n for (i = 0; i < this.pendingMetadata.length; i++) {\n id3 = this.pendingMetadata[i];\n id3.cueTime = id3.pts;\n\n if (!this.keepOriginalTimestamps) {\n id3.cueTime -= timelineStartPts;\n }\n\n id3.cueTime /= 90e3;\n event.metadata.push(id3);\n } // We add this to every single emitted segment even though we only need\n // it for the first\n\n\n event.metadata.dispatchType = this.metadataStream.dispatchType; // Reset stream state\n\n this.pendingTracks.length = 0;\n this.videoTrack = null;\n this.pendingBoxes.length = 0;\n this.pendingCaptions.length = 0;\n this.pendingBytes = 0;\n this.pendingMetadata.length = 0; // Emit the built segment\n\n this.trigger('data', event); // Only emit `done` if all tracks have been flushed and emitted\n\n if (this.emittedTracks >= this.numberOfTracks) {\n this.trigger('done');\n this.emittedTracks = 0;\n }\n };\n /**\n * A Stream that expects MP2T binary data as input and produces\n * corresponding media segments, suitable for use with Media Source\n * Extension (MSE) implementations that support the ISO BMFF byte\n * stream format, like Chrome.\n */\n\n\n _Transmuxer = function Transmuxer(options) {\n var self = this,\n hasFlushed = true,\n videoTrack,\n audioTrack;\n\n _Transmuxer.prototype.init.call(this);\n\n options = options || {};\n this.baseMediaDecodeTime = options.baseMediaDecodeTime || 0;\n this.transmuxPipeline_ = {};\n\n this.setupAacPipeline = function () {\n var pipeline = {};\n this.transmuxPipeline_ = pipeline;\n pipeline.type = 'aac';\n pipeline.metadataStream = new m2ts_1.MetadataStream(); // set up the parsing pipeline\n\n pipeline.aacStream = new aac();\n pipeline.audioTimestampRolloverStream = new m2ts_1.TimestampRolloverStream('audio');\n pipeline.timedMetadataTimestampRolloverStream = new m2ts_1.TimestampRolloverStream('timed-metadata');\n pipeline.adtsStream = new adts();\n pipeline.coalesceStream = new _CoalesceStream(options, pipeline.metadataStream);\n pipeline.headOfPipeline = pipeline.aacStream;\n pipeline.aacStream.pipe(pipeline.audioTimestampRolloverStream).pipe(pipeline.adtsStream);\n pipeline.aacStream.pipe(pipeline.timedMetadataTimestampRolloverStream).pipe(pipeline.metadataStream).pipe(pipeline.coalesceStream);\n pipeline.metadataStream.on('timestamp', function (frame) {\n pipeline.aacStream.setTimestamp(frame.timeStamp);\n });\n pipeline.aacStream.on('data', function (data) {\n if (data.type === 'timed-metadata' && !pipeline.audioSegmentStream) {\n audioTrack = audioTrack || {\n timelineStartInfo: {\n baseMediaDecodeTime: self.baseMediaDecodeTime\n },\n codec: 'adts',\n type: 'audio'\n }; // hook up the audio segment stream to the first track with aac data\n\n pipeline.coalesceStream.numberOfTracks++;\n pipeline.audioSegmentStream = new _AudioSegmentStream(audioTrack, options); // Set up the final part of the audio pipeline\n\n pipeline.adtsStream.pipe(pipeline.audioSegmentStream).pipe(pipeline.coalesceStream);\n }\n }); // Re-emit any data coming from the coalesce stream to the outside world\n\n pipeline.coalesceStream.on('data', this.trigger.bind(this, 'data')); // Let the consumer know we have finished flushing the entire pipeline\n\n pipeline.coalesceStream.on('done', this.trigger.bind(this, 'done'));\n };\n\n this.setupTsPipeline = function () {\n var pipeline = {};\n this.transmuxPipeline_ = pipeline;\n pipeline.type = 'ts';\n pipeline.metadataStream = new m2ts_1.MetadataStream(); // set up the parsing pipeline\n\n pipeline.packetStream = new m2ts_1.TransportPacketStream();\n pipeline.parseStream = new m2ts_1.TransportParseStream();\n pipeline.elementaryStream = new m2ts_1.ElementaryStream();\n pipeline.videoTimestampRolloverStream = new m2ts_1.TimestampRolloverStream('video');\n pipeline.audioTimestampRolloverStream = new m2ts_1.TimestampRolloverStream('audio');\n pipeline.timedMetadataTimestampRolloverStream = new m2ts_1.TimestampRolloverStream('timed-metadata');\n pipeline.adtsStream = new adts();\n pipeline.h264Stream = new H264Stream();\n pipeline.captionStream = new m2ts_1.CaptionStream();\n pipeline.coalesceStream = new _CoalesceStream(options, pipeline.metadataStream);\n pipeline.headOfPipeline = pipeline.packetStream; // disassemble MPEG2-TS packets into elementary streams\n\n pipeline.packetStream.pipe(pipeline.parseStream).pipe(pipeline.elementaryStream); // !!THIS ORDER IS IMPORTANT!!\n // demux the streams\n\n pipeline.elementaryStream.pipe(pipeline.videoTimestampRolloverStream).pipe(pipeline.h264Stream);\n pipeline.elementaryStream.pipe(pipeline.audioTimestampRolloverStream).pipe(pipeline.adtsStream);\n pipeline.elementaryStream.pipe(pipeline.timedMetadataTimestampRolloverStream).pipe(pipeline.metadataStream).pipe(pipeline.coalesceStream); // Hook up CEA-608/708 caption stream\n\n pipeline.h264Stream.pipe(pipeline.captionStream).pipe(pipeline.coalesceStream);\n pipeline.elementaryStream.on('data', function (data) {\n var i;\n\n if (data.type === 'metadata') {\n i = data.tracks.length; // scan the tracks listed in the metadata\n\n while (i--) {\n if (!videoTrack && data.tracks[i].type === 'video') {\n videoTrack = data.tracks[i];\n videoTrack.timelineStartInfo.baseMediaDecodeTime = self.baseMediaDecodeTime;\n } else if (!audioTrack && data.tracks[i].type === 'audio') {\n audioTrack = data.tracks[i];\n audioTrack.timelineStartInfo.baseMediaDecodeTime = self.baseMediaDecodeTime;\n }\n } // hook up the video segment stream to the first track with h264 data\n\n\n if (videoTrack && !pipeline.videoSegmentStream) {\n pipeline.coalesceStream.numberOfTracks++;\n pipeline.videoSegmentStream = new _VideoSegmentStream(videoTrack, options);\n pipeline.videoSegmentStream.on('timelineStartInfo', function (timelineStartInfo) {\n // When video emits timelineStartInfo data after a flush, we forward that\n // info to the AudioSegmentStream, if it exists, because video timeline\n // data takes precedence.\n if (audioTrack) {\n audioTrack.timelineStartInfo = timelineStartInfo; // On the first segment we trim AAC frames that exist before the\n // very earliest DTS we have seen in video because Chrome will\n // interpret any video track with a baseMediaDecodeTime that is\n // non-zero as a gap.\n\n pipeline.audioSegmentStream.setEarliestDts(timelineStartInfo.dts);\n }\n });\n pipeline.videoSegmentStream.on('processedGopsInfo', self.trigger.bind(self, 'gopInfo'));\n pipeline.videoSegmentStream.on('baseMediaDecodeTime', function (baseMediaDecodeTime) {\n if (audioTrack) {\n pipeline.audioSegmentStream.setVideoBaseMediaDecodeTime(baseMediaDecodeTime);\n }\n }); // Set up the final part of the video pipeline\n\n pipeline.h264Stream.pipe(pipeline.videoSegmentStream).pipe(pipeline.coalesceStream);\n }\n\n if (audioTrack && !pipeline.audioSegmentStream) {\n // hook up the audio segment stream to the first track with aac data\n pipeline.coalesceStream.numberOfTracks++;\n pipeline.audioSegmentStream = new _AudioSegmentStream(audioTrack, options); // Set up the final part of the audio pipeline\n\n pipeline.adtsStream.pipe(pipeline.audioSegmentStream).pipe(pipeline.coalesceStream);\n }\n }\n }); // Re-emit any data coming from the coalesce stream to the outside world\n\n pipeline.coalesceStream.on('data', this.trigger.bind(this, 'data')); // Let the consumer know we have finished flushing the entire pipeline\n\n pipeline.coalesceStream.on('done', this.trigger.bind(this, 'done'));\n }; // hook up the segment streams once track metadata is delivered\n\n\n this.setBaseMediaDecodeTime = function (baseMediaDecodeTime) {\n var pipeline = this.transmuxPipeline_;\n\n if (!options.keepOriginalTimestamps) {\n this.baseMediaDecodeTime = baseMediaDecodeTime;\n }\n\n if (audioTrack) {\n audioTrack.timelineStartInfo.dts = undefined;\n audioTrack.timelineStartInfo.pts = undefined;\n trackDecodeInfo.clearDtsInfo(audioTrack);\n\n if (!options.keepOriginalTimestamps) {\n audioTrack.timelineStartInfo.baseMediaDecodeTime = baseMediaDecodeTime;\n }\n\n if (pipeline.audioTimestampRolloverStream) {\n pipeline.audioTimestampRolloverStream.discontinuity();\n }\n }\n\n if (videoTrack) {\n if (pipeline.videoSegmentStream) {\n pipeline.videoSegmentStream.gopCache_ = [];\n pipeline.videoTimestampRolloverStream.discontinuity();\n }\n\n videoTrack.timelineStartInfo.dts = undefined;\n videoTrack.timelineStartInfo.pts = undefined;\n trackDecodeInfo.clearDtsInfo(videoTrack);\n pipeline.captionStream.reset();\n\n if (!options.keepOriginalTimestamps) {\n videoTrack.timelineStartInfo.baseMediaDecodeTime = baseMediaDecodeTime;\n }\n }\n\n if (pipeline.timedMetadataTimestampRolloverStream) {\n pipeline.timedMetadataTimestampRolloverStream.discontinuity();\n }\n };\n\n this.setAudioAppendStart = function (timestamp) {\n if (audioTrack) {\n this.transmuxPipeline_.audioSegmentStream.setAudioAppendStart(timestamp);\n }\n };\n\n this.alignGopsWith = function (gopsToAlignWith) {\n if (videoTrack && this.transmuxPipeline_.videoSegmentStream) {\n this.transmuxPipeline_.videoSegmentStream.alignGopsWith(gopsToAlignWith);\n }\n }; // feed incoming data to the front of the parsing pipeline\n\n\n this.push = function (data) {\n if (hasFlushed) {\n var isAac = isLikelyAacData$1(data);\n\n if (isAac && this.transmuxPipeline_.type !== 'aac') {\n this.setupAacPipeline();\n } else if (!isAac && this.transmuxPipeline_.type !== 'ts') {\n this.setupTsPipeline();\n }\n\n hasFlushed = false;\n }\n\n this.transmuxPipeline_.headOfPipeline.push(data);\n }; // flush any buffered data\n\n\n this.flush = function () {\n hasFlushed = true; // Start at the top of the pipeline and flush all pending work\n\n this.transmuxPipeline_.headOfPipeline.flush();\n }; // Caption data has to be reset when seeking outside buffered range\n\n\n this.resetCaptions = function () {\n if (this.transmuxPipeline_.captionStream) {\n this.transmuxPipeline_.captionStream.reset();\n }\n };\n };\n\n _Transmuxer.prototype = new stream();\n var transmuxer = {\n Transmuxer: _Transmuxer,\n VideoSegmentStream: _VideoSegmentStream,\n AudioSegmentStream: _AudioSegmentStream,\n AUDIO_PROPERTIES: AUDIO_PROPERTIES,\n VIDEO_PROPERTIES: VIDEO_PROPERTIES\n };\n\n var inspectMp4,\n _textifyMp,\n parseType$2 = probe.parseType,\n parseMp4Date = function parseMp4Date(seconds) {\n return new Date(seconds * 1000 - 2082844800000);\n },\n parseSampleFlags = function parseSampleFlags(flags) {\n return {\n isLeading: (flags[0] & 0x0c) >>> 2,\n dependsOn: flags[0] & 0x03,\n isDependedOn: (flags[1] & 0xc0) >>> 6,\n hasRedundancy: (flags[1] & 0x30) >>> 4,\n paddingValue: (flags[1] & 0x0e) >>> 1,\n isNonSyncSample: flags[1] & 0x01,\n degradationPriority: flags[2] << 8 | flags[3]\n };\n },\n nalParse = function nalParse(avcStream) {\n var avcView = new DataView(avcStream.buffer, avcStream.byteOffset, avcStream.byteLength),\n result = [],\n i,\n length;\n\n for (i = 0; i + 4 < avcStream.length; i += length) {\n length = avcView.getUint32(i);\n i += 4; // bail if this doesn't appear to be an H264 stream\n\n if (length <= 0) {\n result.push('<span style=\\'color:red;\\'>MALFORMED DATA</span>');\n continue;\n }\n\n switch (avcStream[i] & 0x1F) {\n case 0x01:\n result.push('slice_layer_without_partitioning_rbsp');\n break;\n\n case 0x05:\n result.push('slice_layer_without_partitioning_rbsp_idr');\n break;\n\n case 0x06:\n result.push('sei_rbsp');\n break;\n\n case 0x07:\n result.push('seq_parameter_set_rbsp');\n break;\n\n case 0x08:\n result.push('pic_parameter_set_rbsp');\n break;\n\n case 0x09:\n result.push('access_unit_delimiter_rbsp');\n break;\n\n default:\n result.push('UNKNOWN NAL - ' + avcStream[i] & 0x1F);\n break;\n }\n }\n\n return result;\n },\n // registry of handlers for individual mp4 box types\n parse$$1 = {\n // codingname, not a first-class box type. stsd entries share the\n // same format as real boxes so the parsing infrastructure can be\n // shared\n avc1: function avc1(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength);\n return {\n dataReferenceIndex: view.getUint16(6),\n width: view.getUint16(24),\n height: view.getUint16(26),\n horizresolution: view.getUint16(28) + view.getUint16(30) / 16,\n vertresolution: view.getUint16(32) + view.getUint16(34) / 16,\n frameCount: view.getUint16(40),\n depth: view.getUint16(74),\n config: inspectMp4(data.subarray(78, data.byteLength))\n };\n },\n avcC: function avcC(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n configurationVersion: data[0],\n avcProfileIndication: data[1],\n profileCompatibility: data[2],\n avcLevelIndication: data[3],\n lengthSizeMinusOne: data[4] & 0x03,\n sps: [],\n pps: []\n },\n numOfSequenceParameterSets = data[5] & 0x1f,\n numOfPictureParameterSets,\n nalSize,\n offset,\n i; // iterate past any SPSs\n\n offset = 6;\n\n for (i = 0; i < numOfSequenceParameterSets; i++) {\n nalSize = view.getUint16(offset);\n offset += 2;\n result.sps.push(new Uint8Array(data.subarray(offset, offset + nalSize)));\n offset += nalSize;\n } // iterate past any PPSs\n\n\n numOfPictureParameterSets = data[offset];\n offset++;\n\n for (i = 0; i < numOfPictureParameterSets; i++) {\n nalSize = view.getUint16(offset);\n offset += 2;\n result.pps.push(new Uint8Array(data.subarray(offset, offset + nalSize)));\n offset += nalSize;\n }\n\n return result;\n },\n btrt: function btrt(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength);\n return {\n bufferSizeDB: view.getUint32(0),\n maxBitrate: view.getUint32(4),\n avgBitrate: view.getUint32(8)\n };\n },\n esds: function esds(data) {\n return {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n esId: data[6] << 8 | data[7],\n streamPriority: data[8] & 0x1f,\n decoderConfig: {\n objectProfileIndication: data[11],\n streamType: data[12] >>> 2 & 0x3f,\n bufferSize: data[13] << 16 | data[14] << 8 | data[15],\n maxBitrate: data[16] << 24 | data[17] << 16 | data[18] << 8 | data[19],\n avgBitrate: data[20] << 24 | data[21] << 16 | data[22] << 8 | data[23],\n decoderConfigDescriptor: {\n tag: data[24],\n length: data[25],\n audioObjectType: data[26] >>> 3 & 0x1f,\n samplingFrequencyIndex: (data[26] & 0x07) << 1 | data[27] >>> 7 & 0x01,\n channelConfiguration: data[27] >>> 3 & 0x0f\n }\n }\n };\n },\n ftyp: function ftyp(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n majorBrand: parseType$2(data.subarray(0, 4)),\n minorVersion: view.getUint32(4),\n compatibleBrands: []\n },\n i = 8;\n\n while (i < data.byteLength) {\n result.compatibleBrands.push(parseType$2(data.subarray(i, i + 4)));\n i += 4;\n }\n\n return result;\n },\n dinf: function dinf(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n dref: function dref(data) {\n return {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n dataReferences: inspectMp4(data.subarray(8))\n };\n },\n hdlr: function hdlr(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n version: view.getUint8(0),\n flags: new Uint8Array(data.subarray(1, 4)),\n handlerType: parseType$2(data.subarray(8, 12)),\n name: ''\n },\n i = 8; // parse out the name field\n\n for (i = 24; i < data.byteLength; i++) {\n if (data[i] === 0x00) {\n // the name field is null-terminated\n i++;\n break;\n }\n\n result.name += String.fromCharCode(data[i]);\n } // decode UTF-8 to javascript's internal representation\n // see http://ecmanaut.blogspot.com/2006/07/encoding-decoding-utf8-in-javascript.html\n\n\n result.name = decodeURIComponent(escape(result.name));\n return result;\n },\n mdat: function mdat(data) {\n return {\n byteLength: data.byteLength,\n nals: nalParse(data)\n };\n },\n mdhd: function mdhd(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n i = 4,\n language,\n result = {\n version: view.getUint8(0),\n flags: new Uint8Array(data.subarray(1, 4)),\n language: ''\n };\n\n if (result.version === 1) {\n i += 4;\n result.creationTime = parseMp4Date(view.getUint32(i)); // truncating top 4 bytes\n\n i += 8;\n result.modificationTime = parseMp4Date(view.getUint32(i)); // truncating top 4 bytes\n\n i += 4;\n result.timescale = view.getUint32(i);\n i += 8;\n result.duration = view.getUint32(i); // truncating top 4 bytes\n } else {\n result.creationTime = parseMp4Date(view.getUint32(i));\n i += 4;\n result.modificationTime = parseMp4Date(view.getUint32(i));\n i += 4;\n result.timescale = view.getUint32(i);\n i += 4;\n result.duration = view.getUint32(i);\n }\n\n i += 4; // language is stored as an ISO-639-2/T code in an array of three 5-bit fields\n // each field is the packed difference between its ASCII value and 0x60\n\n language = view.getUint16(i);\n result.language += String.fromCharCode((language >> 10) + 0x60);\n result.language += String.fromCharCode(((language & 0x03e0) >> 5) + 0x60);\n result.language += String.fromCharCode((language & 0x1f) + 0x60);\n return result;\n },\n mdia: function mdia(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n mfhd: function mfhd(data) {\n return {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n sequenceNumber: data[4] << 24 | data[5] << 16 | data[6] << 8 | data[7]\n };\n },\n minf: function minf(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n // codingname, not a first-class box type. stsd entries share the\n // same format as real boxes so the parsing infrastructure can be\n // shared\n mp4a: function mp4a(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n // 6 bytes reserved\n dataReferenceIndex: view.getUint16(6),\n // 4 + 4 bytes reserved\n channelcount: view.getUint16(16),\n samplesize: view.getUint16(18),\n // 2 bytes pre_defined\n // 2 bytes reserved\n samplerate: view.getUint16(24) + view.getUint16(26) / 65536\n }; // if there are more bytes to process, assume this is an ISO/IEC\n // 14496-14 MP4AudioSampleEntry and parse the ESDBox\n\n if (data.byteLength > 28) {\n result.streamDescriptor = inspectMp4(data.subarray(28))[0];\n }\n\n return result;\n },\n moof: function moof(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n moov: function moov(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n mvex: function mvex(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n mvhd: function mvhd(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n i = 4,\n result = {\n version: view.getUint8(0),\n flags: new Uint8Array(data.subarray(1, 4))\n };\n\n if (result.version === 1) {\n i += 4;\n result.creationTime = parseMp4Date(view.getUint32(i)); // truncating top 4 bytes\n\n i += 8;\n result.modificationTime = parseMp4Date(view.getUint32(i)); // truncating top 4 bytes\n\n i += 4;\n result.timescale = view.getUint32(i);\n i += 8;\n result.duration = view.getUint32(i); // truncating top 4 bytes\n } else {\n result.creationTime = parseMp4Date(view.getUint32(i));\n i += 4;\n result.modificationTime = parseMp4Date(view.getUint32(i));\n i += 4;\n result.timescale = view.getUint32(i);\n i += 4;\n result.duration = view.getUint32(i);\n }\n\n i += 4; // convert fixed-point, base 16 back to a number\n\n result.rate = view.getUint16(i) + view.getUint16(i + 2) / 16;\n i += 4;\n result.volume = view.getUint8(i) + view.getUint8(i + 1) / 8;\n i += 2;\n i += 2;\n i += 2 * 4;\n result.matrix = new Uint32Array(data.subarray(i, i + 9 * 4));\n i += 9 * 4;\n i += 6 * 4;\n result.nextTrackId = view.getUint32(i);\n return result;\n },\n pdin: function pdin(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength);\n return {\n version: view.getUint8(0),\n flags: new Uint8Array(data.subarray(1, 4)),\n rate: view.getUint32(4),\n initialDelay: view.getUint32(8)\n };\n },\n sdtp: function sdtp(data) {\n var result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n samples: []\n },\n i;\n\n for (i = 4; i < data.byteLength; i++) {\n result.samples.push({\n dependsOn: (data[i] & 0x30) >> 4,\n isDependedOn: (data[i] & 0x0c) >> 2,\n hasRedundancy: data[i] & 0x03\n });\n }\n\n return result;\n },\n sidx: function sidx(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n references: [],\n referenceId: view.getUint32(4),\n timescale: view.getUint32(8),\n earliestPresentationTime: view.getUint32(12),\n firstOffset: view.getUint32(16)\n },\n referenceCount = view.getUint16(22),\n i;\n\n for (i = 24; referenceCount; i += 12, referenceCount--) {\n result.references.push({\n referenceType: (data[i] & 0x80) >>> 7,\n referencedSize: view.getUint32(i) & 0x7FFFFFFF,\n subsegmentDuration: view.getUint32(i + 4),\n startsWithSap: !!(data[i + 8] & 0x80),\n sapType: (data[i + 8] & 0x70) >>> 4,\n sapDeltaTime: view.getUint32(i + 8) & 0x0FFFFFFF\n });\n }\n\n return result;\n },\n smhd: function smhd(data) {\n return {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n balance: data[4] + data[5] / 256\n };\n },\n stbl: function stbl(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n stco: function stco(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n chunkOffsets: []\n },\n entryCount = view.getUint32(4),\n i;\n\n for (i = 8; entryCount; i += 4, entryCount--) {\n result.chunkOffsets.push(view.getUint32(i));\n }\n\n return result;\n },\n stsc: function stsc(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n entryCount = view.getUint32(4),\n result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n sampleToChunks: []\n },\n i;\n\n for (i = 8; entryCount; i += 12, entryCount--) {\n result.sampleToChunks.push({\n firstChunk: view.getUint32(i),\n samplesPerChunk: view.getUint32(i + 4),\n sampleDescriptionIndex: view.getUint32(i + 8)\n });\n }\n\n return result;\n },\n stsd: function stsd(data) {\n return {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n sampleDescriptions: inspectMp4(data.subarray(8))\n };\n },\n stsz: function stsz(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n sampleSize: view.getUint32(4),\n entries: []\n },\n i;\n\n for (i = 12; i < data.byteLength; i += 4) {\n result.entries.push(view.getUint32(i));\n }\n\n return result;\n },\n stts: function stts(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n timeToSamples: []\n },\n entryCount = view.getUint32(4),\n i;\n\n for (i = 8; entryCount; i += 8, entryCount--) {\n result.timeToSamples.push({\n sampleCount: view.getUint32(i),\n sampleDelta: view.getUint32(i + 4)\n });\n }\n\n return result;\n },\n styp: function styp(data) {\n return parse$$1.ftyp(data);\n },\n tfdt: function tfdt(data) {\n var result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n baseMediaDecodeTime: data[4] << 24 | data[5] << 16 | data[6] << 8 | data[7]\n };\n\n if (result.version === 1) {\n result.baseMediaDecodeTime *= Math.pow(2, 32);\n result.baseMediaDecodeTime += data[8] << 24 | data[9] << 16 | data[10] << 8 | data[11];\n }\n\n return result;\n },\n tfhd: function tfhd(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n trackId: view.getUint32(4)\n },\n baseDataOffsetPresent = result.flags[2] & 0x01,\n sampleDescriptionIndexPresent = result.flags[2] & 0x02,\n defaultSampleDurationPresent = result.flags[2] & 0x08,\n defaultSampleSizePresent = result.flags[2] & 0x10,\n defaultSampleFlagsPresent = result.flags[2] & 0x20,\n durationIsEmpty = result.flags[0] & 0x010000,\n defaultBaseIsMoof = result.flags[0] & 0x020000,\n i;\n i = 8;\n\n if (baseDataOffsetPresent) {\n i += 4; // truncate top 4 bytes\n // FIXME: should we read the full 64 bits?\n\n result.baseDataOffset = view.getUint32(12);\n i += 4;\n }\n\n if (sampleDescriptionIndexPresent) {\n result.sampleDescriptionIndex = view.getUint32(i);\n i += 4;\n }\n\n if (defaultSampleDurationPresent) {\n result.defaultSampleDuration = view.getUint32(i);\n i += 4;\n }\n\n if (defaultSampleSizePresent) {\n result.defaultSampleSize = view.getUint32(i);\n i += 4;\n }\n\n if (defaultSampleFlagsPresent) {\n result.defaultSampleFlags = view.getUint32(i);\n }\n\n if (durationIsEmpty) {\n result.durationIsEmpty = true;\n }\n\n if (!baseDataOffsetPresent && defaultBaseIsMoof) {\n result.baseDataOffsetIsMoof = true;\n }\n\n return result;\n },\n tkhd: function tkhd(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n i = 4,\n result = {\n version: view.getUint8(0),\n flags: new Uint8Array(data.subarray(1, 4))\n };\n\n if (result.version === 1) {\n i += 4;\n result.creationTime = parseMp4Date(view.getUint32(i)); // truncating top 4 bytes\n\n i += 8;\n result.modificationTime = parseMp4Date(view.getUint32(i)); // truncating top 4 bytes\n\n i += 4;\n result.trackId = view.getUint32(i);\n i += 4;\n i += 8;\n result.duration = view.getUint32(i); // truncating top 4 bytes\n } else {\n result.creationTime = parseMp4Date(view.getUint32(i));\n i += 4;\n result.modificationTime = parseMp4Date(view.getUint32(i));\n i += 4;\n result.trackId = view.getUint32(i);\n i += 4;\n i += 4;\n result.duration = view.getUint32(i);\n }\n\n i += 4;\n i += 2 * 4;\n result.layer = view.getUint16(i);\n i += 2;\n result.alternateGroup = view.getUint16(i);\n i += 2; // convert fixed-point, base 16 back to a number\n\n result.volume = view.getUint8(i) + view.getUint8(i + 1) / 8;\n i += 2;\n i += 2;\n result.matrix = new Uint32Array(data.subarray(i, i + 9 * 4));\n i += 9 * 4;\n result.width = view.getUint16(i) + view.getUint16(i + 2) / 16;\n i += 4;\n result.height = view.getUint16(i) + view.getUint16(i + 2) / 16;\n return result;\n },\n traf: function traf(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n trak: function trak(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n trex: function trex(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength);\n return {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n trackId: view.getUint32(4),\n defaultSampleDescriptionIndex: view.getUint32(8),\n defaultSampleDuration: view.getUint32(12),\n defaultSampleSize: view.getUint32(16),\n sampleDependsOn: data[20] & 0x03,\n sampleIsDependedOn: (data[21] & 0xc0) >> 6,\n sampleHasRedundancy: (data[21] & 0x30) >> 4,\n samplePaddingValue: (data[21] & 0x0e) >> 1,\n sampleIsDifferenceSample: !!(data[21] & 0x01),\n sampleDegradationPriority: view.getUint16(22)\n };\n },\n trun: function trun(data) {\n var result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n samples: []\n },\n view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n // Flag interpretation\n dataOffsetPresent = result.flags[2] & 0x01,\n // compare with 2nd byte of 0x1\n firstSampleFlagsPresent = result.flags[2] & 0x04,\n // compare with 2nd byte of 0x4\n sampleDurationPresent = result.flags[1] & 0x01,\n // compare with 2nd byte of 0x100\n sampleSizePresent = result.flags[1] & 0x02,\n // compare with 2nd byte of 0x200\n sampleFlagsPresent = result.flags[1] & 0x04,\n // compare with 2nd byte of 0x400\n sampleCompositionTimeOffsetPresent = result.flags[1] & 0x08,\n // compare with 2nd byte of 0x800\n sampleCount = view.getUint32(4),\n offset = 8,\n sample;\n\n if (dataOffsetPresent) {\n // 32 bit signed integer\n result.dataOffset = view.getInt32(offset);\n offset += 4;\n } // Overrides the flags for the first sample only. The order of\n // optional values will be: duration, size, compositionTimeOffset\n\n\n if (firstSampleFlagsPresent && sampleCount) {\n sample = {\n flags: parseSampleFlags(data.subarray(offset, offset + 4))\n };\n offset += 4;\n\n if (sampleDurationPresent) {\n sample.duration = view.getUint32(offset);\n offset += 4;\n }\n\n if (sampleSizePresent) {\n sample.size = view.getUint32(offset);\n offset += 4;\n }\n\n if (sampleCompositionTimeOffsetPresent) {\n // Note: this should be a signed int if version is 1\n sample.compositionTimeOffset = view.getUint32(offset);\n offset += 4;\n }\n\n result.samples.push(sample);\n sampleCount--;\n }\n\n while (sampleCount--) {\n sample = {};\n\n if (sampleDurationPresent) {\n sample.duration = view.getUint32(offset);\n offset += 4;\n }\n\n if (sampleSizePresent) {\n sample.size = view.getUint32(offset);\n offset += 4;\n }\n\n if (sampleFlagsPresent) {\n sample.flags = parseSampleFlags(data.subarray(offset, offset + 4));\n offset += 4;\n }\n\n if (sampleCompositionTimeOffsetPresent) {\n // Note: this should be a signed int if version is 1\n sample.compositionTimeOffset = view.getUint32(offset);\n offset += 4;\n }\n\n result.samples.push(sample);\n }\n\n return result;\n },\n 'url ': function url(data) {\n return {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4))\n };\n },\n vmhd: function vmhd(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength);\n return {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n graphicsmode: view.getUint16(4),\n opcolor: new Uint16Array([view.getUint16(6), view.getUint16(8), view.getUint16(10)])\n };\n }\n };\n /**\n * Return a javascript array of box objects parsed from an ISO base\n * media file.\n * @param data {Uint8Array} the binary data of the media to be inspected\n * @return {array} a javascript array of potentially nested box objects\n */\n\n\n inspectMp4 = function inspectMp4(data) {\n var i = 0,\n result = [],\n view,\n size,\n type,\n end,\n box; // Convert data from Uint8Array to ArrayBuffer, to follow Dataview API\n\n var ab = new ArrayBuffer(data.length);\n var v = new Uint8Array(ab);\n\n for (var z = 0; z < data.length; ++z) {\n v[z] = data[z];\n }\n\n view = new DataView(ab);\n\n while (i < data.byteLength) {\n // parse box data\n size = view.getUint32(i);\n type = parseType$2(data.subarray(i + 4, i + 8));\n end = size > 1 ? i + size : data.byteLength; // parse type-specific data\n\n box = (parse$$1[type] || function (data) {\n return {\n data: data\n };\n })(data.subarray(i + 8, end));\n\n box.size = size;\n box.type = type; // store this box and move to the next\n\n result.push(box);\n i = end;\n }\n\n return result;\n };\n /**\n * Returns a textual representation of the javascript represtentation\n * of an MP4 file. You can use it as an alternative to\n * JSON.stringify() to compare inspected MP4s.\n * @param inspectedMp4 {array} the parsed array of boxes in an MP4\n * file\n * @param depth {number} (optional) the number of ancestor boxes of\n * the elements of inspectedMp4. Assumed to be zero if unspecified.\n * @return {string} a text representation of the parsed MP4\n */\n\n\n _textifyMp = function textifyMp4(inspectedMp4, depth) {\n var indent;\n depth = depth || 0;\n indent = new Array(depth * 2 + 1).join(' '); // iterate over all the boxes\n\n return inspectedMp4.map(function (box, index) {\n // list the box type first at the current indentation level\n return indent + box.type + '\\n' + // the type is already included and handle child boxes separately\n Object.keys(box).filter(function (key) {\n return key !== 'type' && key !== 'boxes'; // output all the box properties\n }).map(function (key) {\n var prefix = indent + ' ' + key + ': ',\n value = box[key]; // print out raw bytes as hexademical\n\n if (value instanceof Uint8Array || value instanceof Uint32Array) {\n var bytes = Array.prototype.slice.call(new Uint8Array(value.buffer, value.byteOffset, value.byteLength)).map(function (byte) {\n return ' ' + ('00' + byte.toString(16)).slice(-2);\n }).join('').match(/.{1,24}/g);\n\n if (!bytes) {\n return prefix + '<>';\n }\n\n if (bytes.length === 1) {\n return prefix + '<' + bytes.join('').slice(1) + '>';\n }\n\n return prefix + '<\\n' + bytes.map(function (line) {\n return indent + ' ' + line;\n }).join('\\n') + '\\n' + indent + ' >';\n } // stringify generic objects\n\n\n return prefix + JSON.stringify(value, null, 2).split('\\n').map(function (line, index) {\n if (index === 0) {\n return line;\n }\n\n return indent + ' ' + line;\n }).join('\\n');\n }).join('\\n') + ( // recursively textify the child boxes\n box.boxes ? '\\n' + _textifyMp(box.boxes, depth + 1) : '');\n }).join('\\n');\n };\n\n var mp4Inspector = {\n inspect: inspectMp4,\n textify: _textifyMp,\n parseTfdt: parse$$1.tfdt,\n parseHdlr: parse$$1.hdlr,\n parseTfhd: parse$$1.tfhd,\n parseTrun: parse$$1.trun\n };\n var discardEmulationPreventionBytes$1 = captionPacketParser.discardEmulationPreventionBytes;\n var CaptionStream$1 = captionStream.CaptionStream;\n /**\n * Maps an offset in the mdat to a sample based on the the size of the samples.\n * Assumes that `parseSamples` has been called first.\n *\n * @param {Number} offset - The offset into the mdat\n * @param {Object[]} samples - An array of samples, parsed using `parseSamples`\n * @return {?Object} The matching sample, or null if no match was found.\n *\n * @see ISO-BMFF-12/2015, Section 8.8.8\n **/\n\n var mapToSample = function mapToSample(offset, samples) {\n var approximateOffset = offset;\n\n for (var i = 0; i < samples.length; i++) {\n var sample = samples[i];\n\n if (approximateOffset < sample.size) {\n return sample;\n }\n\n approximateOffset -= sample.size;\n }\n\n return null;\n };\n /**\n * Finds SEI nal units contained in a Media Data Box.\n * Assumes that `parseSamples` has been called first.\n *\n * @param {Uint8Array} avcStream - The bytes of the mdat\n * @param {Object[]} samples - The samples parsed out by `parseSamples`\n * @param {Number} trackId - The trackId of this video track\n * @return {Object[]} seiNals - the parsed SEI NALUs found.\n * The contents of the seiNal should match what is expected by\n * CaptionStream.push (nalUnitType, size, data, escapedRBSP, pts, dts)\n *\n * @see ISO-BMFF-12/2015, Section 8.1.1\n * @see Rec. ITU-T H.264, 7.3.2.3.1\n **/\n\n\n var findSeiNals = function findSeiNals(avcStream, samples, trackId) {\n var avcView = new DataView(avcStream.buffer, avcStream.byteOffset, avcStream.byteLength),\n result = [],\n seiNal,\n i,\n length,\n lastMatchedSample;\n\n for (i = 0; i + 4 < avcStream.length; i += length) {\n length = avcView.getUint32(i);\n i += 4; // Bail if this doesn't appear to be an H264 stream\n\n if (length <= 0) {\n continue;\n }\n\n switch (avcStream[i] & 0x1F) {\n case 0x06:\n var data = avcStream.subarray(i + 1, i + 1 + length);\n var matchingSample = mapToSample(i, samples);\n seiNal = {\n nalUnitType: 'sei_rbsp',\n size: length,\n data: data,\n escapedRBSP: discardEmulationPreventionBytes$1(data),\n trackId: trackId\n };\n\n if (matchingSample) {\n seiNal.pts = matchingSample.pts;\n seiNal.dts = matchingSample.dts;\n lastMatchedSample = matchingSample;\n } else {\n // If a matching sample cannot be found, use the last\n // sample's values as they should be as close as possible\n seiNal.pts = lastMatchedSample.pts;\n seiNal.dts = lastMatchedSample.dts;\n }\n\n result.push(seiNal);\n break;\n\n default:\n break;\n }\n }\n\n return result;\n };\n /**\n * Parses sample information out of Track Run Boxes and calculates\n * the absolute presentation and decode timestamps of each sample.\n *\n * @param {Array<Uint8Array>} truns - The Trun Run boxes to be parsed\n * @param {Number} baseMediaDecodeTime - base media decode time from tfdt\n @see ISO-BMFF-12/2015, Section 8.8.12\n * @param {Object} tfhd - The parsed Track Fragment Header\n * @see inspect.parseTfhd\n * @return {Object[]} the parsed samples\n *\n * @see ISO-BMFF-12/2015, Section 8.8.8\n **/\n\n\n var parseSamples = function parseSamples(truns, baseMediaDecodeTime, tfhd) {\n var currentDts = baseMediaDecodeTime;\n var defaultSampleDuration = tfhd.defaultSampleDuration || 0;\n var defaultSampleSize = tfhd.defaultSampleSize || 0;\n var trackId = tfhd.trackId;\n var allSamples = [];\n truns.forEach(function (trun) {\n // Note: We currently do not parse the sample table as well\n // as the trun. It's possible some sources will require this.\n // moov > trak > mdia > minf > stbl\n var trackRun = mp4Inspector.parseTrun(trun);\n var samples = trackRun.samples;\n samples.forEach(function (sample) {\n if (sample.duration === undefined) {\n sample.duration = defaultSampleDuration;\n }\n\n if (sample.size === undefined) {\n sample.size = defaultSampleSize;\n }\n\n sample.trackId = trackId;\n sample.dts = currentDts;\n\n if (sample.compositionTimeOffset === undefined) {\n sample.compositionTimeOffset = 0;\n }\n\n sample.pts = currentDts + sample.compositionTimeOffset;\n currentDts += sample.duration;\n });\n allSamples = allSamples.concat(samples);\n });\n return allSamples;\n };\n /**\n * Parses out caption nals from an FMP4 segment's video tracks.\n *\n * @param {Uint8Array} segment - The bytes of a single segment\n * @param {Number} videoTrackId - The trackId of a video track in the segment\n * @return {Object.<Number, Object[]>} A mapping of video trackId to\n * a list of seiNals found in that track\n **/\n\n\n var parseCaptionNals = function parseCaptionNals(segment, videoTrackId) {\n // To get the samples\n var trafs = probe.findBox(segment, ['moof', 'traf']); // To get SEI NAL units\n\n var mdats = probe.findBox(segment, ['mdat']);\n var captionNals = {};\n var mdatTrafPairs = []; // Pair up each traf with a mdat as moofs and mdats are in pairs\n\n mdats.forEach(function (mdat, index) {\n var matchingTraf = trafs[index];\n mdatTrafPairs.push({\n mdat: mdat,\n traf: matchingTraf\n });\n });\n mdatTrafPairs.forEach(function (pair) {\n var mdat = pair.mdat;\n var traf = pair.traf;\n var tfhd = probe.findBox(traf, ['tfhd']); // Exactly 1 tfhd per traf\n\n var headerInfo = mp4Inspector.parseTfhd(tfhd[0]);\n var trackId = headerInfo.trackId;\n var tfdt = probe.findBox(traf, ['tfdt']); // Either 0 or 1 tfdt per traf\n\n var baseMediaDecodeTime = tfdt.length > 0 ? mp4Inspector.parseTfdt(tfdt[0]).baseMediaDecodeTime : 0;\n var truns = probe.findBox(traf, ['trun']);\n var samples;\n var seiNals; // Only parse video data for the chosen video track\n\n if (videoTrackId === trackId && truns.length > 0) {\n samples = parseSamples(truns, baseMediaDecodeTime, headerInfo);\n seiNals = findSeiNals(mdat, samples, trackId);\n\n if (!captionNals[trackId]) {\n captionNals[trackId] = [];\n }\n\n captionNals[trackId] = captionNals[trackId].concat(seiNals);\n }\n });\n return captionNals;\n };\n /**\n * Parses out inband captions from an MP4 container and returns\n * caption objects that can be used by WebVTT and the TextTrack API.\n * @see https://developer.mozilla.org/en-US/docs/Web/API/VTTCue\n * @see https://developer.mozilla.org/en-US/docs/Web/API/TextTrack\n * Assumes that `probe.getVideoTrackIds` and `probe.timescale` have been called first\n *\n * @param {Uint8Array} segment - The fmp4 segment containing embedded captions\n * @param {Number} trackId - The id of the video track to parse\n * @param {Number} timescale - The timescale for the video track from the init segment\n *\n * @return {?Object[]} parsedCaptions - A list of captions or null if no video tracks\n * @return {Number} parsedCaptions[].startTime - The time to show the caption in seconds\n * @return {Number} parsedCaptions[].endTime - The time to stop showing the caption in seconds\n * @return {String} parsedCaptions[].text - The visible content of the caption\n **/\n\n\n var parseEmbeddedCaptions = function parseEmbeddedCaptions(segment, trackId, timescale) {\n var seiNals;\n\n if (!trackId) {\n return null;\n }\n\n seiNals = parseCaptionNals(segment, trackId);\n return {\n seiNals: seiNals[trackId],\n timescale: timescale\n };\n };\n /**\n * Converts SEI NALUs into captions that can be used by video.js\n **/\n\n\n var CaptionParser$$1 = function CaptionParser$$1() {\n var isInitialized = false;\n var captionStream$$1; // Stores segments seen before trackId and timescale are set\n\n var segmentCache; // Stores video track ID of the track being parsed\n\n var trackId; // Stores the timescale of the track being parsed\n\n var timescale; // Stores captions parsed so far\n\n var parsedCaptions;\n /**\n * A method to indicate whether a CaptionParser has been initalized\n * @returns {Boolean}\n **/\n\n this.isInitialized = function () {\n return isInitialized;\n };\n /**\n * Initializes the underlying CaptionStream, SEI NAL parsing\n * and management, and caption collection\n **/\n\n\n this.init = function () {\n captionStream$$1 = new CaptionStream$1();\n isInitialized = true; // Collect dispatched captions\n\n captionStream$$1.on('data', function (event) {\n // Convert to seconds in the source's timescale\n event.startTime = event.startPts / timescale;\n event.endTime = event.endPts / timescale;\n parsedCaptions.captions.push(event);\n parsedCaptions.captionStreams[event.stream] = true;\n });\n };\n /**\n * Determines if a new video track will be selected\n * or if the timescale changed\n * @return {Boolean}\n **/\n\n\n this.isNewInit = function (videoTrackIds, timescales) {\n if (videoTrackIds && videoTrackIds.length === 0 || timescales && typeof timescales === 'object' && Object.keys(timescales).length === 0) {\n return false;\n }\n\n return trackId !== videoTrackIds[0] || timescale !== timescales[trackId];\n };\n /**\n * Parses out SEI captions and interacts with underlying\n * CaptionStream to return dispatched captions\n *\n * @param {Uint8Array} segment - The fmp4 segment containing embedded captions\n * @param {Number[]} videoTrackIds - A list of video tracks found in the init segment\n * @param {Object.<Number, Number>} timescales - The timescales found in the init segment\n * @see parseEmbeddedCaptions\n * @see m2ts/caption-stream.js\n **/\n\n\n this.parse = function (segment, videoTrackIds, timescales) {\n var parsedData;\n\n if (!this.isInitialized()) {\n return null; // This is not likely to be a video segment\n } else if (!videoTrackIds || !timescales) {\n return null;\n } else if (this.isNewInit(videoTrackIds, timescales)) {\n // Use the first video track only as there is no\n // mechanism to switch to other video tracks\n trackId = videoTrackIds[0];\n timescale = timescales[trackId]; // If an init segment has not been seen yet, hold onto segment\n // data until we have one\n } else if (!trackId || !timescale) {\n segmentCache.push(segment);\n return null;\n } // Now that a timescale and trackId is set, parse cached segments\n\n\n while (segmentCache.length > 0) {\n var cachedSegment = segmentCache.shift();\n this.parse(cachedSegment, videoTrackIds, timescales);\n }\n\n parsedData = parseEmbeddedCaptions(segment, trackId, timescale);\n\n if (parsedData === null || !parsedData.seiNals) {\n return null;\n }\n\n this.pushNals(parsedData.seiNals); // Force the parsed captions to be dispatched\n\n this.flushStream();\n return parsedCaptions;\n };\n /**\n * Pushes SEI NALUs onto CaptionStream\n * @param {Object[]} nals - A list of SEI nals parsed using `parseCaptionNals`\n * Assumes that `parseCaptionNals` has been called first\n * @see m2ts/caption-stream.js\n **/\n\n\n this.pushNals = function (nals) {\n if (!this.isInitialized() || !nals || nals.length === 0) {\n return null;\n }\n\n nals.forEach(function (nal) {\n captionStream$$1.push(nal);\n });\n };\n /**\n * Flushes underlying CaptionStream to dispatch processed, displayable captions\n * @see m2ts/caption-stream.js\n **/\n\n\n this.flushStream = function () {\n if (!this.isInitialized()) {\n return null;\n }\n\n captionStream$$1.flush();\n };\n /**\n * Reset caption buckets for new data\n **/\n\n\n this.clearParsedCaptions = function () {\n parsedCaptions.captions = [];\n parsedCaptions.captionStreams = {};\n };\n /**\n * Resets underlying CaptionStream\n * @see m2ts/caption-stream.js\n **/\n\n\n this.resetCaptionStream = function () {\n if (!this.isInitialized()) {\n return null;\n }\n\n captionStream$$1.reset();\n };\n /**\n * Convenience method to clear all captions flushed from the\n * CaptionStream and still being parsed\n * @see m2ts/caption-stream.js\n **/\n\n\n this.clearAllCaptions = function () {\n this.clearParsedCaptions();\n this.resetCaptionStream();\n };\n /**\n * Reset caption parser\n **/\n\n\n this.reset = function () {\n segmentCache = [];\n trackId = null;\n timescale = null;\n\n if (!parsedCaptions) {\n parsedCaptions = {\n captions: [],\n // CC1, CC2, CC3, CC4\n captionStreams: {}\n };\n } else {\n this.clearParsedCaptions();\n }\n\n this.resetCaptionStream();\n };\n\n this.reset();\n };\n\n var captionParser = CaptionParser$$1;\n var mp4 = {\n generator: mp4Generator,\n probe: probe,\n Transmuxer: transmuxer.Transmuxer,\n AudioSegmentStream: transmuxer.AudioSegmentStream,\n VideoSegmentStream: transmuxer.VideoSegmentStream,\n CaptionParser: captionParser\n };\n\n var classCallCheck = function classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n };\n\n var createClass = function () {\n function defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n }\n\n return function (Constructor, protoProps, staticProps) {\n if (protoProps) defineProperties(Constructor.prototype, protoProps);\n if (staticProps) defineProperties(Constructor, staticProps);\n return Constructor;\n };\n }();\n /**\n * @file transmuxer-worker.js\n */\n\n /**\n * Re-emits transmuxer events by converting them into messages to the\n * world outside the worker.\n *\n * @param {Object} transmuxer the transmuxer to wire events on\n * @private\n */\n\n\n var wireTransmuxerEvents = function wireTransmuxerEvents(self, transmuxer) {\n transmuxer.on('data', function (segment) {\n // transfer ownership of the underlying ArrayBuffer\n // instead of doing a copy to save memory\n // ArrayBuffers are transferable but generic TypedArrays are not\n // @link https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API/Using_web_workers#Passing_data_by_transferring_ownership_(transferable_objects)\n var initArray = segment.initSegment;\n segment.initSegment = {\n data: initArray.buffer,\n byteOffset: initArray.byteOffset,\n byteLength: initArray.byteLength\n };\n var typedArray = segment.data;\n segment.data = typedArray.buffer;\n self.postMessage({\n action: 'data',\n segment: segment,\n byteOffset: typedArray.byteOffset,\n byteLength: typedArray.byteLength\n }, [segment.data]);\n });\n\n if (transmuxer.captionStream) {\n transmuxer.captionStream.on('data', function (caption) {\n self.postMessage({\n action: 'caption',\n data: caption\n });\n });\n }\n\n transmuxer.on('done', function (data) {\n self.postMessage({\n action: 'done'\n });\n });\n transmuxer.on('gopInfo', function (gopInfo) {\n self.postMessage({\n action: 'gopInfo',\n gopInfo: gopInfo\n });\n });\n };\n /**\n * All incoming messages route through this hash. If no function exists\n * to handle an incoming message, then we ignore the message.\n *\n * @class MessageHandlers\n * @param {Object} options the options to initialize with\n */\n\n\n var MessageHandlers = function () {\n function MessageHandlers(self, options) {\n classCallCheck(this, MessageHandlers);\n this.options = options || {};\n this.self = self;\n this.init();\n }\n /**\n * initialize our web worker and wire all the events.\n */\n\n\n createClass(MessageHandlers, [{\n key: 'init',\n value: function init() {\n if (this.transmuxer) {\n this.transmuxer.dispose();\n }\n\n this.transmuxer = new mp4.Transmuxer(this.options);\n wireTransmuxerEvents(this.self, this.transmuxer);\n }\n /**\n * Adds data (a ts segment) to the start of the transmuxer pipeline for\n * processing.\n *\n * @param {ArrayBuffer} data data to push into the muxer\n */\n\n }, {\n key: 'push',\n value: function push(data) {\n // Cast array buffer to correct type for transmuxer\n var segment = new Uint8Array(data.data, data.byteOffset, data.byteLength);\n this.transmuxer.push(segment);\n }\n /**\n * Recreate the transmuxer so that the next segment added via `push`\n * start with a fresh transmuxer.\n */\n\n }, {\n key: 'reset',\n value: function reset() {\n this.init();\n }\n /**\n * Set the value that will be used as the `baseMediaDecodeTime` time for the\n * next segment pushed in. Subsequent segments will have their `baseMediaDecodeTime`\n * set relative to the first based on the PTS values.\n *\n * @param {Object} data used to set the timestamp offset in the muxer\n */\n\n }, {\n key: 'setTimestampOffset',\n value: function setTimestampOffset(data) {\n var timestampOffset = data.timestampOffset || 0;\n this.transmuxer.setBaseMediaDecodeTime(Math.round(timestampOffset * 90000));\n }\n }, {\n key: 'setAudioAppendStart',\n value: function setAudioAppendStart(data) {\n this.transmuxer.setAudioAppendStart(Math.ceil(data.appendStart * 90000));\n }\n /**\n * Forces the pipeline to finish processing the last segment and emit it's\n * results.\n *\n * @param {Object} data event data, not really used\n */\n\n }, {\n key: 'flush',\n value: function flush(data) {\n this.transmuxer.flush();\n }\n }, {\n key: 'resetCaptions',\n value: function resetCaptions() {\n this.transmuxer.resetCaptions();\n }\n }, {\n key: 'alignGopsWith',\n value: function alignGopsWith(data) {\n this.transmuxer.alignGopsWith(data.gopsToAlignWith.slice());\n }\n }]);\n return MessageHandlers;\n }();\n /**\n * Our web wroker interface so that things can talk to mux.js\n * that will be running in a web worker. the scope is passed to this by\n * webworkify.\n *\n * @param {Object} self the scope for the web worker\n */\n\n\n var TransmuxerWorker = function TransmuxerWorker(self) {\n self.onmessage = function (event) {\n if (event.data.action === 'init' && event.data.options) {\n this.messageHandlers = new MessageHandlers(self, event.data.options);\n return;\n }\n\n if (!this.messageHandlers) {\n this.messageHandlers = new MessageHandlers(self);\n }\n\n if (event.data && event.data.action && event.data.action !== 'init') {\n if (this.messageHandlers[event.data.action]) {\n this.messageHandlers[event.data.action](event.data);\n }\n }\n };\n };\n\n var transmuxerWorker = new TransmuxerWorker(self);\n return transmuxerWorker;\n }();\n});\n/**\n * @file - codecs.js - Handles tasks regarding codec strings such as translating them to\n * codec strings, or translating codec strings into objects that can be examined.\n */\n// Default codec parameters if none were provided for video and/or audio\n\nvar defaultCodecs = {\n videoCodec: 'avc1',\n videoObjectTypeIndicator: '.4d400d',\n // AAC-LC\n audioProfile: '2'\n};\n/**\n * Replace the old apple-style `avc1.<dd>.<dd>` codec string with the standard\n * `avc1.<hhhhhh>`\n *\n * @param {Array} codecs an array of codec strings to fix\n * @return {Array} the translated codec array\n * @private\n */\n\nvar translateLegacyCodecs = function translateLegacyCodecs(codecs) {\n return codecs.map(function (codec) {\n return codec.replace(/avc1\\.(\\d+)\\.(\\d+)/i, function (orig, profile, avcLevel) {\n var profileHex = ('00' + Number(profile).toString(16)).slice(-2);\n var avcLevelHex = ('00' + Number(avcLevel).toString(16)).slice(-2);\n return 'avc1.' + profileHex + '00' + avcLevelHex;\n });\n });\n};\n/**\n * Parses a codec string to retrieve the number of codecs specified,\n * the video codec and object type indicator, and the audio profile.\n */\n\n\nvar parseCodecs = function parseCodecs() {\n var codecs = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';\n var result = {\n codecCount: 0\n };\n var parsed = void 0;\n result.codecCount = codecs.split(',').length;\n result.codecCount = result.codecCount || 2; // parse the video codec\n\n parsed = /(^|\\s|,)+(avc[13])([^ ,]*)/i.exec(codecs);\n\n if (parsed) {\n result.videoCodec = parsed[2];\n result.videoObjectTypeIndicator = parsed[3];\n } // parse the last field of the audio codec\n\n\n result.audioProfile = /(^|\\s|,)+mp4a.[0-9A-Fa-f]+\\.([0-9A-Fa-f]+)/i.exec(codecs);\n result.audioProfile = result.audioProfile && result.audioProfile[2];\n return result;\n};\n/**\n * Replace codecs in the codec string with the old apple-style `avc1.<dd>.<dd>` to the\n * standard `avc1.<hhhhhh>`.\n *\n * @param codecString {String} the codec string\n * @return {String} the codec string with old apple-style codecs replaced\n *\n * @private\n */\n\n\nvar mapLegacyAvcCodecs = function mapLegacyAvcCodecs(codecString) {\n return codecString.replace(/avc1\\.(\\d+)\\.(\\d+)/i, function (match) {\n return translateLegacyCodecs([match])[0];\n });\n};\n/**\n * Build a media mime-type string from a set of parameters\n * @param {String} type either 'audio' or 'video'\n * @param {String} container either 'mp2t' or 'mp4'\n * @param {Array} codecs an array of codec strings to add\n * @return {String} a valid media mime-type\n */\n\n\nvar makeMimeTypeString = function makeMimeTypeString(type, container, codecs) {\n // The codecs array is filtered so that falsey values are\n // dropped and don't cause Array#join to create spurious\n // commas\n return type + '/' + container + '; codecs=\"' + codecs.filter(function (c) {\n return !!c;\n }).join(', ') + '\"';\n};\n/**\n * Returns the type container based on information in the playlist\n * @param {Playlist} media the current media playlist\n * @return {String} a valid media container type\n */\n\n\nvar getContainerType = function getContainerType(media) {\n // An initialization segment means the media playlist is an iframe\n // playlist or is using the mp4 container. We don't currently\n // support iframe playlists, so assume this is signalling mp4\n // fragments.\n if (media.segments && media.segments.length && media.segments[0].map) {\n return 'mp4';\n }\n\n return 'mp2t';\n};\n/**\n * Returns a set of codec strings parsed from the playlist or the default\n * codec strings if no codecs were specified in the playlist\n * @param {Playlist} media the current media playlist\n * @return {Object} an object with the video and audio codecs\n */\n\n\nvar getCodecs = function getCodecs(media) {\n // if the codecs were explicitly specified, use them instead of the\n // defaults\n var mediaAttributes = media.attributes || {};\n\n if (mediaAttributes.CODECS) {\n return parseCodecs(mediaAttributes.CODECS);\n }\n\n return defaultCodecs;\n};\n\nvar audioProfileFromDefault = function audioProfileFromDefault(master, audioGroupId) {\n if (!master.mediaGroups.AUDIO || !audioGroupId) {\n return null;\n }\n\n var audioGroup = master.mediaGroups.AUDIO[audioGroupId];\n\n if (!audioGroup) {\n return null;\n }\n\n for (var name in audioGroup) {\n var audioType = audioGroup[name];\n\n if (audioType.default && audioType.playlists) {\n // codec should be the same for all playlists within the audio type\n return parseCodecs(audioType.playlists[0].attributes.CODECS).audioProfile;\n }\n }\n\n return null;\n};\n/**\n * Calculates the MIME type strings for a working configuration of\n * SourceBuffers to play variant streams in a master playlist. If\n * there is no possible working configuration, an empty array will be\n * returned.\n *\n * @param master {Object} the m3u8 object for the master playlist\n * @param media {Object} the m3u8 object for the variant playlist\n * @return {Array} the MIME type strings. If the array has more than\n * one entry, the first element should be applied to the video\n * SourceBuffer and the second to the audio SourceBuffer.\n *\n * @private\n */\n\n\nvar mimeTypesForPlaylist = function mimeTypesForPlaylist(master, media) {\n var containerType = getContainerType(media);\n var codecInfo = getCodecs(media);\n var mediaAttributes = media.attributes || {}; // Default condition for a traditional HLS (no demuxed audio/video)\n\n var isMuxed = true;\n var isMaat = false;\n\n if (!media) {\n // Not enough information\n return [];\n }\n\n if (master.mediaGroups.AUDIO && mediaAttributes.AUDIO) {\n var audioGroup = master.mediaGroups.AUDIO[mediaAttributes.AUDIO]; // Handle the case where we are in a multiple-audio track scenario\n\n if (audioGroup) {\n isMaat = true; // Start with the everything demuxed then...\n\n isMuxed = false; // ...check to see if any audio group tracks are muxed (ie. lacking a uri)\n\n for (var groupId in audioGroup) {\n // either a uri is present (if the case of HLS and an external playlist), or\n // playlists is present (in the case of DASH where we don't have external audio\n // playlists)\n if (!audioGroup[groupId].uri && !audioGroup[groupId].playlists) {\n isMuxed = true;\n break;\n }\n }\n }\n } // HLS with multiple-audio tracks must always get an audio codec.\n // Put another way, there is no way to have a video-only multiple-audio HLS!\n\n\n if (isMaat && !codecInfo.audioProfile) {\n if (!isMuxed) {\n // It is possible for codecs to be specified on the audio media group playlist but\n // not on the rendition playlist. This is mostly the case for DASH, where audio and\n // video are always separate (and separately specified).\n codecInfo.audioProfile = audioProfileFromDefault(master, mediaAttributes.AUDIO);\n }\n\n if (!codecInfo.audioProfile) {\n videojs$1.log.warn('Multiple audio tracks present but no audio codec string is specified. ' + 'Attempting to use the default audio codec (mp4a.40.2)');\n codecInfo.audioProfile = defaultCodecs.audioProfile;\n }\n } // Generate the final codec strings from the codec object generated above\n\n\n var codecStrings = {};\n\n if (codecInfo.videoCodec) {\n codecStrings.video = '' + codecInfo.videoCodec + codecInfo.videoObjectTypeIndicator;\n }\n\n if (codecInfo.audioProfile) {\n codecStrings.audio = 'mp4a.40.' + codecInfo.audioProfile;\n } // Finally, make and return an array with proper mime-types depending on\n // the configuration\n\n\n var justAudio = makeMimeTypeString('audio', containerType, [codecStrings.audio]);\n var justVideo = makeMimeTypeString('video', containerType, [codecStrings.video]);\n var bothVideoAudio = makeMimeTypeString('video', containerType, [codecStrings.video, codecStrings.audio]);\n\n if (isMaat) {\n if (!isMuxed && codecStrings.video) {\n return [justVideo, justAudio];\n }\n\n if (!isMuxed && !codecStrings.video) {\n // There is no muxed content and no video codec string, so this is an audio only\n // stream with alternate audio.\n return [justAudio, justAudio];\n } // There exists the possiblity that this will return a `video/container`\n // mime-type for the first entry in the array even when there is only audio.\n // This doesn't appear to be a problem and simplifies the code.\n\n\n return [bothVideoAudio, justAudio];\n } // If there is no video codec at all, always just return a single\n // audio/<container> mime-type\n\n\n if (!codecStrings.video) {\n return [justAudio];\n } // When not using separate audio media groups, audio and video is\n // *always* muxed\n\n\n return [bothVideoAudio];\n};\n/**\n * Parse a content type header into a type and parameters\n * object\n *\n * @param {String} type the content type header\n * @return {Object} the parsed content-type\n * @private\n */\n\n\nvar parseContentType = function parseContentType(type) {\n var object = {\n type: '',\n parameters: {}\n };\n var parameters = type.trim().split(';'); // first parameter should always be content-type\n\n object.type = parameters.shift().trim();\n parameters.forEach(function (parameter) {\n var pair = parameter.trim().split('=');\n\n if (pair.length > 1) {\n var name = pair[0].replace(/\"/g, '').trim();\n var value = pair[1].replace(/\"/g, '').trim();\n object.parameters[name] = value;\n }\n });\n return object;\n};\n/**\n * Check if a codec string refers to an audio codec.\n *\n * @param {String} codec codec string to check\n * @return {Boolean} if this is an audio codec\n * @private\n */\n\n\nvar isAudioCodec = function isAudioCodec(codec) {\n return /mp4a\\.\\d+.\\d+/i.test(codec);\n};\n/**\n * Check if a codec string refers to a video codec.\n *\n * @param {String} codec codec string to check\n * @return {Boolean} if this is a video codec\n * @private\n */\n\n\nvar isVideoCodec = function isVideoCodec(codec) {\n return /avc1\\.[\\da-f]+/i.test(codec);\n};\n/**\n * Returns a list of gops in the buffer that have a pts value of 3 seconds or more in\n * front of current time.\n *\n * @param {Array} buffer\n * The current buffer of gop information\n * @param {Number} currentTime\n * The current time\n * @param {Double} mapping\n * Offset to map display time to stream presentation time\n * @return {Array}\n * List of gops considered safe to append over\n */\n\n\nvar gopsSafeToAlignWith = function gopsSafeToAlignWith(buffer, currentTime, mapping) {\n if (typeof currentTime === 'undefined' || currentTime === null || !buffer.length) {\n return [];\n } // pts value for current time + 3 seconds to give a bit more wiggle room\n\n\n var currentTimePts = Math.ceil((currentTime - mapping + 3) * 90000);\n var i = void 0;\n\n for (i = 0; i < buffer.length; i++) {\n if (buffer[i].pts > currentTimePts) {\n break;\n }\n }\n\n return buffer.slice(i);\n};\n/**\n * Appends gop information (timing and byteLength) received by the transmuxer for the\n * gops appended in the last call to appendBuffer\n *\n * @param {Array} buffer\n * The current buffer of gop information\n * @param {Array} gops\n * List of new gop information\n * @param {boolean} replace\n * If true, replace the buffer with the new gop information. If false, append the\n * new gop information to the buffer in the right location of time.\n * @return {Array}\n * Updated list of gop information\n */\n\n\nvar updateGopBuffer = function updateGopBuffer(buffer, gops, replace) {\n if (!gops.length) {\n return buffer;\n }\n\n if (replace) {\n // If we are in safe append mode, then completely overwrite the gop buffer\n // with the most recent appeneded data. This will make sure that when appending\n // future segments, we only try to align with gops that are both ahead of current\n // time and in the last segment appended.\n return gops.slice();\n }\n\n var start = gops[0].pts;\n var i = 0;\n\n for (i; i < buffer.length; i++) {\n if (buffer[i].pts >= start) {\n break;\n }\n }\n\n return buffer.slice(0, i).concat(gops);\n};\n/**\n * Removes gop information in buffer that overlaps with provided start and end\n *\n * @param {Array} buffer\n * The current buffer of gop information\n * @param {Double} start\n * position to start the remove at\n * @param {Double} end\n * position to end the remove at\n * @param {Double} mapping\n * Offset to map display time to stream presentation time\n */\n\n\nvar removeGopBuffer = function removeGopBuffer(buffer, start, end, mapping) {\n var startPts = Math.ceil((start - mapping) * 90000);\n var endPts = Math.ceil((end - mapping) * 90000);\n var updatedBuffer = buffer.slice();\n var i = buffer.length;\n\n while (i--) {\n if (buffer[i].pts <= endPts) {\n break;\n }\n }\n\n if (i === -1) {\n // no removal because end of remove range is before start of buffer\n return updatedBuffer;\n }\n\n var j = i + 1;\n\n while (j--) {\n if (buffer[j].pts <= startPts) {\n break;\n }\n } // clamp remove range start to 0 index\n\n\n j = Math.max(j, 0);\n updatedBuffer.splice(j, i - j + 1);\n return updatedBuffer;\n};\n\nvar buffered = function buffered(videoBuffer, audioBuffer, audioDisabled) {\n var start = null;\n var end = null;\n var arity = 0;\n var extents = [];\n var ranges = []; // neither buffer has been created yet\n\n if (!videoBuffer && !audioBuffer) {\n return videojs$1.createTimeRange();\n } // only one buffer is configured\n\n\n if (!videoBuffer) {\n return audioBuffer.buffered;\n }\n\n if (!audioBuffer) {\n return videoBuffer.buffered;\n } // both buffers are configured\n\n\n if (audioDisabled) {\n return videoBuffer.buffered;\n } // both buffers are empty\n\n\n if (videoBuffer.buffered.length === 0 && audioBuffer.buffered.length === 0) {\n return videojs$1.createTimeRange();\n } // Handle the case where we have both buffers and create an\n // intersection of the two\n\n\n var videoBuffered = videoBuffer.buffered;\n var audioBuffered = audioBuffer.buffered;\n var count = videoBuffered.length; // A) Gather up all start and end times\n\n while (count--) {\n extents.push({\n time: videoBuffered.start(count),\n type: 'start'\n });\n extents.push({\n time: videoBuffered.end(count),\n type: 'end'\n });\n }\n\n count = audioBuffered.length;\n\n while (count--) {\n extents.push({\n time: audioBuffered.start(count),\n type: 'start'\n });\n extents.push({\n time: audioBuffered.end(count),\n type: 'end'\n });\n } // B) Sort them by time\n\n\n extents.sort(function (a, b) {\n return a.time - b.time;\n }); // C) Go along one by one incrementing arity for start and decrementing\n // arity for ends\n\n for (count = 0; count < extents.length; count++) {\n if (extents[count].type === 'start') {\n arity++; // D) If arity is ever incremented to 2 we are entering an\n // overlapping range\n\n if (arity === 2) {\n start = extents[count].time;\n }\n } else if (extents[count].type === 'end') {\n arity--; // E) If arity is ever decremented to 1 we leaving an\n // overlapping range\n\n if (arity === 1) {\n end = extents[count].time;\n }\n } // F) Record overlapping ranges\n\n\n if (start !== null && end !== null) {\n ranges.push([start, end]);\n start = null;\n end = null;\n }\n }\n\n return videojs$1.createTimeRanges(ranges);\n};\n/**\n * @file virtual-source-buffer.js\n */\n// We create a wrapper around the SourceBuffer so that we can manage the\n// state of the `updating` property manually. We have to do this because\n// Firefox changes `updating` to false long before triggering `updateend`\n// events and that was causing strange problems in videojs-contrib-hls\n\n\nvar makeWrappedSourceBuffer = function makeWrappedSourceBuffer(mediaSource, mimeType) {\n var sourceBuffer = mediaSource.addSourceBuffer(mimeType);\n var wrapper = Object.create(null);\n wrapper.updating = false;\n wrapper.realBuffer_ = sourceBuffer;\n\n var _loop = function _loop(key) {\n if (typeof sourceBuffer[key] === 'function') {\n wrapper[key] = function () {\n return sourceBuffer[key].apply(sourceBuffer, arguments);\n };\n } else if (typeof wrapper[key] === 'undefined') {\n Object.defineProperty(wrapper, key, {\n get: function get$$1() {\n return sourceBuffer[key];\n },\n set: function set$$1(v) {\n return sourceBuffer[key] = v;\n }\n });\n }\n };\n\n for (var key in sourceBuffer) {\n _loop(key);\n }\n\n return wrapper;\n};\n/**\n * VirtualSourceBuffers exist so that we can transmux non native formats\n * into a native format, but keep the same api as a native source buffer.\n * It creates a transmuxer, that works in its own thread (a web worker) and\n * that transmuxer muxes the data into a native format. VirtualSourceBuffer will\n * then send all of that data to the naive sourcebuffer so that it is\n * indestinguishable from a natively supported format.\n *\n * @param {HtmlMediaSource} mediaSource the parent mediaSource\n * @param {Array} codecs array of codecs that we will be dealing with\n * @class VirtualSourceBuffer\n * @extends video.js.EventTarget\n */\n\n\nvar VirtualSourceBuffer = function (_videojs$EventTarget) {\n inherits(VirtualSourceBuffer, _videojs$EventTarget);\n\n function VirtualSourceBuffer(mediaSource, codecs) {\n classCallCheck(this, VirtualSourceBuffer);\n\n var _this = possibleConstructorReturn(this, (VirtualSourceBuffer.__proto__ || Object.getPrototypeOf(VirtualSourceBuffer)).call(this, videojs$1.EventTarget));\n\n _this.timestampOffset_ = 0;\n _this.pendingBuffers_ = [];\n _this.bufferUpdating_ = false;\n _this.mediaSource_ = mediaSource;\n _this.codecs_ = codecs;\n _this.audioCodec_ = null;\n _this.videoCodec_ = null;\n _this.audioDisabled_ = false;\n _this.appendAudioInitSegment_ = true;\n _this.gopBuffer_ = [];\n _this.timeMapping_ = 0;\n _this.safeAppend_ = videojs$1.browser.IE_VERSION >= 11;\n var options = {\n remux: false,\n alignGopsAtEnd: _this.safeAppend_\n };\n\n _this.codecs_.forEach(function (codec) {\n if (isAudioCodec(codec)) {\n _this.audioCodec_ = codec;\n } else if (isVideoCodec(codec)) {\n _this.videoCodec_ = codec;\n }\n }); // append muxed segments to their respective native buffers as\n // soon as they are available\n\n\n _this.transmuxer_ = new TransmuxWorker();\n\n _this.transmuxer_.postMessage({\n action: 'init',\n options: options\n });\n\n _this.transmuxer_.onmessage = function (event) {\n if (event.data.action === 'data') {\n return _this.data_(event);\n }\n\n if (event.data.action === 'done') {\n return _this.done_(event);\n }\n\n if (event.data.action === 'gopInfo') {\n return _this.appendGopInfo_(event);\n }\n }; // this timestampOffset is a property with the side-effect of resetting\n // baseMediaDecodeTime in the transmuxer on the setter\n\n\n Object.defineProperty(_this, 'timestampOffset', {\n get: function get$$1() {\n return this.timestampOffset_;\n },\n set: function set$$1(val) {\n if (typeof val === 'number' && val >= 0) {\n this.timestampOffset_ = val;\n this.appendAudioInitSegment_ = true; // reset gop buffer on timestampoffset as this signals a change in timeline\n\n this.gopBuffer_.length = 0;\n this.timeMapping_ = 0; // We have to tell the transmuxer to set the baseMediaDecodeTime to\n // the desired timestampOffset for the next segment\n\n this.transmuxer_.postMessage({\n action: 'setTimestampOffset',\n timestampOffset: val\n });\n }\n }\n }); // setting the append window affects both source buffers\n\n Object.defineProperty(_this, 'appendWindowStart', {\n get: function get$$1() {\n return (this.videoBuffer_ || this.audioBuffer_).appendWindowStart;\n },\n set: function set$$1(start) {\n if (this.videoBuffer_) {\n this.videoBuffer_.appendWindowStart = start;\n }\n\n if (this.audioBuffer_) {\n this.audioBuffer_.appendWindowStart = start;\n }\n }\n }); // this buffer is \"updating\" if either of its native buffers are\n\n Object.defineProperty(_this, 'updating', {\n get: function get$$1() {\n return !!(this.bufferUpdating_ || !this.audioDisabled_ && this.audioBuffer_ && this.audioBuffer_.updating || this.videoBuffer_ && this.videoBuffer_.updating);\n }\n }); // the buffered property is the intersection of the buffered\n // ranges of the native source buffers\n\n Object.defineProperty(_this, 'buffered', {\n get: function get$$1() {\n return buffered(this.videoBuffer_, this.audioBuffer_, this.audioDisabled_);\n }\n });\n return _this;\n }\n /**\n * When we get a data event from the transmuxer\n * we call this function and handle the data that\n * was sent to us\n *\n * @private\n * @param {Event} event the data event from the transmuxer\n */\n\n\n createClass(VirtualSourceBuffer, [{\n key: 'data_',\n value: function data_(event) {\n var segment = event.data.segment; // Cast ArrayBuffer to TypedArray\n\n segment.data = new Uint8Array(segment.data, event.data.byteOffset, event.data.byteLength);\n segment.initSegment = new Uint8Array(segment.initSegment.data, segment.initSegment.byteOffset, segment.initSegment.byteLength);\n createTextTracksIfNecessary(this, this.mediaSource_, segment); // Add the segments to the pendingBuffers array\n\n this.pendingBuffers_.push(segment);\n return;\n }\n /**\n * When we get a done event from the transmuxer\n * we call this function and we process all\n * of the pending data that we have been saving in the\n * data_ function\n *\n * @private\n * @param {Event} event the done event from the transmuxer\n */\n\n }, {\n key: 'done_',\n value: function done_(event) {\n // Don't process and append data if the mediaSource is closed\n if (this.mediaSource_.readyState === 'closed') {\n this.pendingBuffers_.length = 0;\n return;\n } // All buffers should have been flushed from the muxer\n // start processing anything we have received\n\n\n this.processPendingSegments_();\n return;\n }\n /**\n * Create our internal native audio/video source buffers and add\n * event handlers to them with the following conditions:\n * 1. they do not already exist on the mediaSource\n * 2. this VSB has a codec for them\n *\n * @private\n */\n\n }, {\n key: 'createRealSourceBuffers_',\n value: function createRealSourceBuffers_() {\n var _this2 = this;\n\n var types = ['audio', 'video'];\n types.forEach(function (type) {\n // Don't create a SourceBuffer of this type if we don't have a\n // codec for it\n if (!_this2[type + 'Codec_']) {\n return;\n } // Do nothing if a SourceBuffer of this type already exists\n\n\n if (_this2[type + 'Buffer_']) {\n return;\n }\n\n var buffer = null; // If the mediasource already has a SourceBuffer for the codec\n // use that\n\n if (_this2.mediaSource_[type + 'Buffer_']) {\n buffer = _this2.mediaSource_[type + 'Buffer_']; // In multiple audio track cases, the audio source buffer is disabled\n // on the main VirtualSourceBuffer by the HTMLMediaSource much earlier\n // than createRealSourceBuffers_ is called to create the second\n // VirtualSourceBuffer because that happens as a side-effect of\n // videojs-contrib-hls starting the audioSegmentLoader. As a result,\n // the audioBuffer is essentially \"ownerless\" and no one will toggle\n // the `updating` state back to false once the `updateend` event is received\n //\n // Setting `updating` to false manually will work around this\n // situation and allow work to continue\n\n buffer.updating = false;\n } else {\n var codecProperty = type + 'Codec_';\n var mimeType = type + '/mp4;codecs=\"' + _this2[codecProperty] + '\"';\n buffer = makeWrappedSourceBuffer(_this2.mediaSource_.nativeMediaSource_, mimeType);\n _this2.mediaSource_[type + 'Buffer_'] = buffer;\n }\n\n _this2[type + 'Buffer_'] = buffer; // Wire up the events to the SourceBuffer\n\n ['update', 'updatestart', 'updateend'].forEach(function (event) {\n buffer.addEventListener(event, function () {\n // if audio is disabled\n if (type === 'audio' && _this2.audioDisabled_) {\n return;\n }\n\n if (event === 'updateend') {\n _this2[type + 'Buffer_'].updating = false;\n }\n\n var shouldTrigger = types.every(function (t) {\n // skip checking audio's updating status if audio\n // is not enabled\n if (t === 'audio' && _this2.audioDisabled_) {\n return true;\n } // if the other type if updating we don't trigger\n\n\n if (type !== t && _this2[t + 'Buffer_'] && _this2[t + 'Buffer_'].updating) {\n return false;\n }\n\n return true;\n });\n\n if (shouldTrigger) {\n return _this2.trigger(event);\n }\n });\n });\n });\n }\n /**\n * Emulate the native mediasource function, but our function will\n * send all of the proposed segments to the transmuxer so that we\n * can transmux them before we append them to our internal\n * native source buffers in the correct format.\n *\n * @link https://developer.mozilla.org/en-US/docs/Web/API/SourceBuffer/appendBuffer\n * @param {Uint8Array} segment the segment to append to the buffer\n */\n\n }, {\n key: 'appendBuffer',\n value: function appendBuffer(segment) {\n // Start the internal \"updating\" state\n this.bufferUpdating_ = true;\n\n if (this.audioBuffer_ && this.audioBuffer_.buffered.length) {\n var audioBuffered = this.audioBuffer_.buffered;\n this.transmuxer_.postMessage({\n action: 'setAudioAppendStart',\n appendStart: audioBuffered.end(audioBuffered.length - 1)\n });\n }\n\n if (this.videoBuffer_) {\n this.transmuxer_.postMessage({\n action: 'alignGopsWith',\n gopsToAlignWith: gopsSafeToAlignWith(this.gopBuffer_, this.mediaSource_.player_ ? this.mediaSource_.player_.currentTime() : null, this.timeMapping_)\n });\n }\n\n this.transmuxer_.postMessage({\n action: 'push',\n // Send the typed-array of data as an ArrayBuffer so that\n // it can be sent as a \"Transferable\" and avoid the costly\n // memory copy\n data: segment.buffer,\n // To recreate the original typed-array, we need information\n // about what portion of the ArrayBuffer it was a view into\n byteOffset: segment.byteOffset,\n byteLength: segment.byteLength\n }, [segment.buffer]);\n this.transmuxer_.postMessage({\n action: 'flush'\n });\n }\n /**\n * Appends gop information (timing and byteLength) received by the transmuxer for the\n * gops appended in the last call to appendBuffer\n *\n * @param {Event} event\n * The gopInfo event from the transmuxer\n * @param {Array} event.data.gopInfo\n * List of gop info to append\n */\n\n }, {\n key: 'appendGopInfo_',\n value: function appendGopInfo_(event) {\n this.gopBuffer_ = updateGopBuffer(this.gopBuffer_, event.data.gopInfo, this.safeAppend_);\n }\n /**\n * Emulate the native mediasource function and remove parts\n * of the buffer from any of our internal buffers that exist\n *\n * @link https://developer.mozilla.org/en-US/docs/Web/API/SourceBuffer/remove\n * @param {Double} start position to start the remove at\n * @param {Double} end position to end the remove at\n */\n\n }, {\n key: 'remove',\n value: function remove(start, end) {\n if (this.videoBuffer_) {\n this.videoBuffer_.updating = true;\n this.videoBuffer_.remove(start, end);\n this.gopBuffer_ = removeGopBuffer(this.gopBuffer_, start, end, this.timeMapping_);\n }\n\n if (!this.audioDisabled_ && this.audioBuffer_) {\n this.audioBuffer_.updating = true;\n this.audioBuffer_.remove(start, end);\n } // Remove Metadata Cues (id3)\n\n\n removeCuesFromTrack(start, end, this.metadataTrack_); // Remove Any Captions\n\n if (this.inbandTextTracks_) {\n for (var track in this.inbandTextTracks_) {\n removeCuesFromTrack(start, end, this.inbandTextTracks_[track]);\n }\n }\n }\n /**\n * Process any segments that the muxer has output\n * Concatenate segments together based on type and append them into\n * their respective sourceBuffers\n *\n * @private\n */\n\n }, {\n key: 'processPendingSegments_',\n value: function processPendingSegments_() {\n var sortedSegments = {\n video: {\n segments: [],\n bytes: 0\n },\n audio: {\n segments: [],\n bytes: 0\n },\n captions: [],\n metadata: []\n }; // Sort segments into separate video/audio arrays and\n // keep track of their total byte lengths\n\n sortedSegments = this.pendingBuffers_.reduce(function (segmentObj, segment) {\n var type = segment.type;\n var data = segment.data;\n var initSegment = segment.initSegment;\n segmentObj[type].segments.push(data);\n segmentObj[type].bytes += data.byteLength;\n segmentObj[type].initSegment = initSegment; // Gather any captions into a single array\n\n if (segment.captions) {\n segmentObj.captions = segmentObj.captions.concat(segment.captions);\n }\n\n if (segment.info) {\n segmentObj[type].info = segment.info;\n } // Gather any metadata into a single array\n\n\n if (segment.metadata) {\n segmentObj.metadata = segmentObj.metadata.concat(segment.metadata);\n }\n\n return segmentObj;\n }, sortedSegments); // Create the real source buffers if they don't exist by now since we\n // finally are sure what tracks are contained in the source\n\n if (!this.videoBuffer_ && !this.audioBuffer_) {\n // Remove any codecs that may have been specified by default but\n // are no longer applicable now\n if (sortedSegments.video.bytes === 0) {\n this.videoCodec_ = null;\n }\n\n if (sortedSegments.audio.bytes === 0) {\n this.audioCodec_ = null;\n }\n\n this.createRealSourceBuffers_();\n }\n\n if (sortedSegments.audio.info) {\n this.mediaSource_.trigger({\n type: 'audioinfo',\n info: sortedSegments.audio.info\n });\n }\n\n if (sortedSegments.video.info) {\n this.mediaSource_.trigger({\n type: 'videoinfo',\n info: sortedSegments.video.info\n });\n }\n\n if (this.appendAudioInitSegment_) {\n if (!this.audioDisabled_ && this.audioBuffer_) {\n sortedSegments.audio.segments.unshift(sortedSegments.audio.initSegment);\n sortedSegments.audio.bytes += sortedSegments.audio.initSegment.byteLength;\n }\n\n this.appendAudioInitSegment_ = false;\n }\n\n var triggerUpdateend = false; // Merge multiple video and audio segments into one and append\n\n if (this.videoBuffer_ && sortedSegments.video.bytes) {\n sortedSegments.video.segments.unshift(sortedSegments.video.initSegment);\n sortedSegments.video.bytes += sortedSegments.video.initSegment.byteLength;\n this.concatAndAppendSegments_(sortedSegments.video, this.videoBuffer_); // TODO: are video tracks the only ones with text tracks?\n\n addTextTrackData(this, sortedSegments.captions, sortedSegments.metadata);\n } else if (this.videoBuffer_ && (this.audioDisabled_ || !this.audioBuffer_)) {\n // The transmuxer did not return any bytes of video, meaning it was all trimmed\n // for gop alignment. Since we have a video buffer and audio is disabled, updateend\n // will never be triggered by this source buffer, which will cause contrib-hls\n // to be stuck forever waiting for updateend. If audio is not disabled, updateend\n // will be triggered by the audio buffer, which will be sent upwards since the video\n // buffer will not be in an updating state.\n triggerUpdateend = true;\n }\n\n if (!this.audioDisabled_ && this.audioBuffer_) {\n this.concatAndAppendSegments_(sortedSegments.audio, this.audioBuffer_);\n }\n\n this.pendingBuffers_.length = 0;\n\n if (triggerUpdateend) {\n this.trigger('updateend');\n } // We are no longer in the internal \"updating\" state\n\n\n this.bufferUpdating_ = false;\n }\n /**\n * Combine all segments into a single Uint8Array and then append them\n * to the destination buffer\n *\n * @param {Object} segmentObj\n * @param {SourceBuffer} destinationBuffer native source buffer to append data to\n * @private\n */\n\n }, {\n key: 'concatAndAppendSegments_',\n value: function concatAndAppendSegments_(segmentObj, destinationBuffer) {\n var offset = 0;\n var tempBuffer = void 0;\n\n if (segmentObj.bytes) {\n tempBuffer = new Uint8Array(segmentObj.bytes); // Combine the individual segments into one large typed-array\n\n segmentObj.segments.forEach(function (segment) {\n tempBuffer.set(segment, offset);\n offset += segment.byteLength;\n });\n\n try {\n destinationBuffer.updating = true;\n destinationBuffer.appendBuffer(tempBuffer);\n } catch (error) {\n if (this.mediaSource_.player_) {\n this.mediaSource_.player_.error({\n code: -3,\n type: 'APPEND_BUFFER_ERR',\n message: error.message,\n originalError: error\n });\n }\n }\n }\n }\n /**\n * Emulate the native mediasource function. abort any soureBuffer\n * actions and throw out any un-appended data.\n *\n * @link https://developer.mozilla.org/en-US/docs/Web/API/SourceBuffer/abort\n */\n\n }, {\n key: 'abort',\n value: function abort() {\n if (this.videoBuffer_) {\n this.videoBuffer_.abort();\n }\n\n if (!this.audioDisabled_ && this.audioBuffer_) {\n this.audioBuffer_.abort();\n }\n\n if (this.transmuxer_) {\n this.transmuxer_.postMessage({\n action: 'reset'\n });\n }\n\n this.pendingBuffers_.length = 0;\n this.bufferUpdating_ = false;\n }\n }]);\n return VirtualSourceBuffer;\n}(videojs$1.EventTarget);\n/**\n * @file html-media-source.js\n */\n\n/**\n * Our MediaSource implementation in HTML, mimics native\n * MediaSource where/if possible.\n *\n * @link https://developer.mozilla.org/en-US/docs/Web/API/MediaSource\n * @class HtmlMediaSource\n * @extends videojs.EventTarget\n */\n\n\nvar HtmlMediaSource = function (_videojs$EventTarget) {\n inherits(HtmlMediaSource, _videojs$EventTarget);\n\n function HtmlMediaSource() {\n classCallCheck(this, HtmlMediaSource);\n\n var _this = possibleConstructorReturn(this, (HtmlMediaSource.__proto__ || Object.getPrototypeOf(HtmlMediaSource)).call(this));\n\n var property = void 0;\n _this.nativeMediaSource_ = new window$1.MediaSource(); // delegate to the native MediaSource's methods by default\n\n for (property in _this.nativeMediaSource_) {\n if (!(property in HtmlMediaSource.prototype) && typeof _this.nativeMediaSource_[property] === 'function') {\n _this[property] = _this.nativeMediaSource_[property].bind(_this.nativeMediaSource_);\n }\n } // emulate `duration` and `seekable` until seeking can be\n // handled uniformly for live streams\n // see https://github.com/w3c/media-source/issues/5\n\n\n _this.duration_ = NaN;\n Object.defineProperty(_this, 'duration', {\n get: function get$$1() {\n if (this.duration_ === Infinity) {\n return this.duration_;\n }\n\n return this.nativeMediaSource_.duration;\n },\n set: function set$$1(duration) {\n this.duration_ = duration;\n\n if (duration !== Infinity) {\n this.nativeMediaSource_.duration = duration;\n return;\n }\n }\n });\n Object.defineProperty(_this, 'seekable', {\n get: function get$$1() {\n if (this.duration_ === Infinity) {\n return videojs$1.createTimeRanges([[0, this.nativeMediaSource_.duration]]);\n }\n\n return this.nativeMediaSource_.seekable;\n }\n });\n Object.defineProperty(_this, 'readyState', {\n get: function get$$1() {\n return this.nativeMediaSource_.readyState;\n }\n });\n Object.defineProperty(_this, 'activeSourceBuffers', {\n get: function get$$1() {\n return this.activeSourceBuffers_;\n }\n }); // the list of virtual and native SourceBuffers created by this\n // MediaSource\n\n _this.sourceBuffers = [];\n _this.activeSourceBuffers_ = [];\n /**\n * update the list of active source buffers based upon various\n * imformation from HLS and video.js\n *\n * @private\n */\n\n _this.updateActiveSourceBuffers_ = function () {\n // Retain the reference but empty the array\n _this.activeSourceBuffers_.length = 0; // If there is only one source buffer, then it will always be active and audio will\n // be disabled based on the codec of the source buffer\n\n if (_this.sourceBuffers.length === 1) {\n var sourceBuffer = _this.sourceBuffers[0];\n sourceBuffer.appendAudioInitSegment_ = true;\n sourceBuffer.audioDisabled_ = !sourceBuffer.audioCodec_;\n\n _this.activeSourceBuffers_.push(sourceBuffer);\n\n return;\n } // There are 2 source buffers, a combined (possibly video only) source buffer and\n // and an audio only source buffer.\n // By default, the audio in the combined virtual source buffer is enabled\n // and the audio-only source buffer (if it exists) is disabled.\n\n\n var disableCombined = false;\n var disableAudioOnly = true; // TODO: maybe we can store the sourcebuffers on the track objects?\n // safari may do something like this\n\n for (var i = 0; i < _this.player_.audioTracks().length; i++) {\n var track = _this.player_.audioTracks()[i];\n\n if (track.enabled && track.kind !== 'main') {\n // The enabled track is an alternate audio track so disable the audio in\n // the combined source buffer and enable the audio-only source buffer.\n disableCombined = true;\n disableAudioOnly = false;\n break;\n }\n }\n\n _this.sourceBuffers.forEach(function (sourceBuffer, index) {\n /* eslinst-disable */\n // TODO once codecs are required, we can switch to using the codecs to determine\n // what stream is the video stream, rather than relying on videoTracks\n\n /* eslinst-enable */\n sourceBuffer.appendAudioInitSegment_ = true;\n\n if (sourceBuffer.videoCodec_ && sourceBuffer.audioCodec_) {\n // combined\n sourceBuffer.audioDisabled_ = disableCombined;\n } else if (sourceBuffer.videoCodec_ && !sourceBuffer.audioCodec_) {\n // If the \"combined\" source buffer is video only, then we do not want\n // disable the audio-only source buffer (this is mostly for demuxed\n // audio and video hls)\n sourceBuffer.audioDisabled_ = true;\n disableAudioOnly = false;\n } else if (!sourceBuffer.videoCodec_ && sourceBuffer.audioCodec_) {\n // audio only\n // In the case of audio only with alternate audio and disableAudioOnly is true\n // this means we want to disable the audio on the alternate audio sourcebuffer\n // but not the main \"combined\" source buffer. The \"combined\" source buffer is\n // always at index 0, so this ensures audio won't be disabled in both source\n // buffers.\n sourceBuffer.audioDisabled_ = index ? disableAudioOnly : !disableAudioOnly;\n\n if (sourceBuffer.audioDisabled_) {\n return;\n }\n }\n\n _this.activeSourceBuffers_.push(sourceBuffer);\n });\n };\n\n _this.onPlayerMediachange_ = function () {\n _this.sourceBuffers.forEach(function (sourceBuffer) {\n sourceBuffer.appendAudioInitSegment_ = true;\n });\n };\n\n _this.onHlsReset_ = function () {\n _this.sourceBuffers.forEach(function (sourceBuffer) {\n if (sourceBuffer.transmuxer_) {\n sourceBuffer.transmuxer_.postMessage({\n action: 'resetCaptions'\n });\n }\n });\n };\n\n _this.onHlsSegmentTimeMapping_ = function (event) {\n _this.sourceBuffers.forEach(function (buffer) {\n return buffer.timeMapping_ = event.mapping;\n });\n }; // Re-emit MediaSource events on the polyfill\n\n\n ['sourceopen', 'sourceclose', 'sourceended'].forEach(function (eventName) {\n this.nativeMediaSource_.addEventListener(eventName, this.trigger.bind(this));\n }, _this); // capture the associated player when the MediaSource is\n // successfully attached\n\n _this.on('sourceopen', function (event) {\n // Get the player this MediaSource is attached to\n var video = document.querySelector('[src=\"' + _this.url_ + '\"]');\n\n if (!video) {\n return;\n }\n\n _this.player_ = videojs$1(video.parentNode);\n\n if (!_this.player_) {\n return;\n } // hls-reset is fired by videojs.Hls on to the tech after the main SegmentLoader\n // resets its state and flushes the buffer\n\n\n _this.player_.tech_.on('hls-reset', _this.onHlsReset_); // hls-segment-time-mapping is fired by videojs.Hls on to the tech after the main\n // SegmentLoader inspects an MTS segment and has an accurate stream to display\n // time mapping\n\n\n _this.player_.tech_.on('hls-segment-time-mapping', _this.onHlsSegmentTimeMapping_);\n\n if (_this.player_.audioTracks && _this.player_.audioTracks()) {\n _this.player_.audioTracks().on('change', _this.updateActiveSourceBuffers_);\n\n _this.player_.audioTracks().on('addtrack', _this.updateActiveSourceBuffers_);\n\n _this.player_.audioTracks().on('removetrack', _this.updateActiveSourceBuffers_);\n }\n\n _this.player_.on('mediachange', _this.onPlayerMediachange_);\n });\n\n _this.on('sourceended', function (event) {\n var duration = durationOfVideo(_this.duration);\n\n for (var i = 0; i < _this.sourceBuffers.length; i++) {\n var sourcebuffer = _this.sourceBuffers[i];\n var cues = sourcebuffer.metadataTrack_ && sourcebuffer.metadataTrack_.cues;\n\n if (cues && cues.length) {\n cues[cues.length - 1].endTime = duration;\n }\n }\n }); // explicitly terminate any WebWorkers that were created\n // by SourceHandlers\n\n\n _this.on('sourceclose', function (event) {\n this.sourceBuffers.forEach(function (sourceBuffer) {\n if (sourceBuffer.transmuxer_) {\n sourceBuffer.transmuxer_.terminate();\n }\n });\n this.sourceBuffers.length = 0;\n\n if (!this.player_) {\n return;\n }\n\n if (this.player_.audioTracks && this.player_.audioTracks()) {\n this.player_.audioTracks().off('change', this.updateActiveSourceBuffers_);\n this.player_.audioTracks().off('addtrack', this.updateActiveSourceBuffers_);\n this.player_.audioTracks().off('removetrack', this.updateActiveSourceBuffers_);\n } // We can only change this if the player hasn't been disposed of yet\n // because `off` eventually tries to use the el_ property. If it has\n // been disposed of, then don't worry about it because there are no\n // event handlers left to unbind anyway\n\n\n if (this.player_.el_) {\n this.player_.off('mediachange', this.onPlayerMediachange_);\n }\n\n if (this.player_.tech_ && this.player_.tech_.el_) {\n this.player_.tech_.off('hls-reset', this.onHlsReset_);\n this.player_.tech_.off('hls-segment-time-mapping', this.onHlsSegmentTimeMapping_);\n }\n });\n\n return _this;\n }\n /**\n * Add a range that that can now be seeked to.\n *\n * @param {Double} start where to start the addition\n * @param {Double} end where to end the addition\n * @private\n */\n\n\n createClass(HtmlMediaSource, [{\n key: 'addSeekableRange_',\n value: function addSeekableRange_(start, end) {\n var error = void 0;\n\n if (this.duration !== Infinity) {\n error = new Error('MediaSource.addSeekableRange() can only be invoked ' + 'when the duration is Infinity');\n error.name = 'InvalidStateError';\n error.code = 11;\n throw error;\n }\n\n if (end > this.nativeMediaSource_.duration || isNaN(this.nativeMediaSource_.duration)) {\n this.nativeMediaSource_.duration = end;\n }\n }\n /**\n * Add a source buffer to the media source.\n *\n * @link https://developer.mozilla.org/en-US/docs/Web/API/MediaSource/addSourceBuffer\n * @param {String} type the content-type of the content\n * @return {Object} the created source buffer\n */\n\n }, {\n key: 'addSourceBuffer',\n value: function addSourceBuffer(type) {\n var buffer = void 0;\n var parsedType = parseContentType(type); // Create a VirtualSourceBuffer to transmux MPEG-2 transport\n // stream segments into fragmented MP4s\n\n if (/^(video|audio)\\/mp2t$/i.test(parsedType.type)) {\n var codecs = [];\n\n if (parsedType.parameters && parsedType.parameters.codecs) {\n codecs = parsedType.parameters.codecs.split(',');\n codecs = translateLegacyCodecs(codecs);\n codecs = codecs.filter(function (codec) {\n return isAudioCodec(codec) || isVideoCodec(codec);\n });\n }\n\n if (codecs.length === 0) {\n codecs = ['avc1.4d400d', 'mp4a.40.2'];\n }\n\n buffer = new VirtualSourceBuffer(this, codecs);\n\n if (this.sourceBuffers.length !== 0) {\n // If another VirtualSourceBuffer already exists, then we are creating a\n // SourceBuffer for an alternate audio track and therefore we know that\n // the source has both an audio and video track.\n // That means we should trigger the manual creation of the real\n // SourceBuffers instead of waiting for the transmuxer to return data\n this.sourceBuffers[0].createRealSourceBuffers_();\n buffer.createRealSourceBuffers_(); // Automatically disable the audio on the first source buffer if\n // a second source buffer is ever created\n\n this.sourceBuffers[0].audioDisabled_ = true;\n }\n } else {\n // delegate to the native implementation\n buffer = this.nativeMediaSource_.addSourceBuffer(type);\n }\n\n this.sourceBuffers.push(buffer);\n return buffer;\n }\n }]);\n return HtmlMediaSource;\n}(videojs$1.EventTarget);\n/**\n * @file videojs-contrib-media-sources.js\n */\n\n\nvar urlCount = 0; // ------------\n// Media Source\n// ------------\n// store references to the media sources so they can be connected\n// to a video element (a swf object)\n// TODO: can we store this somewhere local to this module?\n\nvideojs$1.mediaSources = {};\n/**\n * Provide a method for a swf object to notify JS that a\n * media source is now open.\n *\n * @param {String} msObjectURL string referencing the MSE Object URL\n * @param {String} swfId the swf id\n */\n\nvar open = function open(msObjectURL, swfId) {\n var mediaSource = videojs$1.mediaSources[msObjectURL];\n\n if (mediaSource) {\n mediaSource.trigger({\n type: 'sourceopen',\n swfId: swfId\n });\n } else {\n throw new Error('Media Source not found (Video.js)');\n }\n};\n/**\n * Check to see if the native MediaSource object exists and supports\n * an MP4 container with both H.264 video and AAC-LC audio.\n *\n * @return {Boolean} if native media sources are supported\n */\n\n\nvar supportsNativeMediaSources = function supportsNativeMediaSources() {\n return !!window$1.MediaSource && !!window$1.MediaSource.isTypeSupported && window$1.MediaSource.isTypeSupported('video/mp4;codecs=\"avc1.4d400d,mp4a.40.2\"');\n};\n/**\n * An emulation of the MediaSource API so that we can support\n * native and non-native functionality. returns an instance of\n * HtmlMediaSource.\n *\n * @link https://developer.mozilla.org/en-US/docs/Web/API/MediaSource/MediaSource\n */\n\n\nvar MediaSource = function MediaSource() {\n this.MediaSource = {\n open: open,\n supportsNativeMediaSources: supportsNativeMediaSources\n };\n\n if (supportsNativeMediaSources()) {\n return new HtmlMediaSource();\n }\n\n throw new Error('Cannot use create a virtual MediaSource for this video');\n};\n\nMediaSource.open = open;\nMediaSource.supportsNativeMediaSources = supportsNativeMediaSources;\n/**\n * A wrapper around the native URL for our MSE object\n * implementation, this object is exposed under videojs.URL\n *\n * @link https://developer.mozilla.org/en-US/docs/Web/API/URL/URL\n */\n\nvar URL$1 = {\n /**\n * A wrapper around the native createObjectURL for our objects.\n * This function maps a native or emulated mediaSource to a blob\n * url so that it can be loaded into video.js\n *\n * @link https://developer.mozilla.org/en-US/docs/Web/API/URL/createObjectURL\n * @param {MediaSource} object the object to create a blob url to\n */\n createObjectURL: function createObjectURL(object) {\n var objectUrlPrefix = 'blob:vjs-media-source/';\n var url = void 0; // use the native MediaSource to generate an object URL\n\n if (object instanceof HtmlMediaSource) {\n url = window$1.URL.createObjectURL(object.nativeMediaSource_);\n object.url_ = url;\n return url;\n } // if the object isn't an emulated MediaSource, delegate to the\n // native implementation\n\n\n if (!(object instanceof HtmlMediaSource)) {\n url = window$1.URL.createObjectURL(object);\n object.url_ = url;\n return url;\n } // build a URL that can be used to map back to the emulated\n // MediaSource\n\n\n url = objectUrlPrefix + urlCount;\n urlCount++; // setup the mapping back to object\n\n videojs$1.mediaSources[url] = object;\n return url;\n }\n};\nvideojs$1.MediaSource = MediaSource;\nvideojs$1.URL = URL$1;\nvar EventTarget$1$1 = videojs$1.EventTarget,\n mergeOptions$2 = videojs$1.mergeOptions;\n/**\n * Returns a new master manifest that is the result of merging an updated master manifest\n * into the original version.\n *\n * @param {Object} oldMaster\n * The old parsed mpd object\n * @param {Object} newMaster\n * The updated parsed mpd object\n * @return {Object}\n * A new object representing the original master manifest with the updated media\n * playlists merged in\n */\n\nvar updateMaster$1 = function updateMaster$$1(oldMaster, newMaster) {\n var update = mergeOptions$2(oldMaster, {\n // These are top level properties that can be updated\n duration: newMaster.duration,\n minimumUpdatePeriod: newMaster.minimumUpdatePeriod\n }); // First update the playlists in playlist list\n\n for (var i = 0; i < newMaster.playlists.length; i++) {\n var playlistUpdate = updateMaster(update, newMaster.playlists[i]);\n\n if (playlistUpdate) {\n update = playlistUpdate;\n }\n } // Then update media group playlists\n\n\n forEachMediaGroup(newMaster, function (properties, type, group, label) {\n if (properties.playlists && properties.playlists.length) {\n var uri = properties.playlists[0].uri;\n\n var _playlistUpdate = updateMaster(update, properties.playlists[0]);\n\n if (_playlistUpdate) {\n update = _playlistUpdate; // update the playlist reference within media groups\n\n update.mediaGroups[type][group][label].playlists[0] = update.playlists[uri];\n }\n }\n });\n return update;\n};\n\nvar DashPlaylistLoader = function (_EventTarget) {\n inherits(DashPlaylistLoader, _EventTarget); // DashPlaylistLoader must accept either a src url or a playlist because subsequent\n // playlist loader setups from media groups will expect to be able to pass a playlist\n // (since there aren't external URLs to media playlists with DASH)\n\n function DashPlaylistLoader(srcUrlOrPlaylist, hls, withCredentials, masterPlaylistLoader) {\n classCallCheck(this, DashPlaylistLoader);\n\n var _this = possibleConstructorReturn(this, (DashPlaylistLoader.__proto__ || Object.getPrototypeOf(DashPlaylistLoader)).call(this));\n\n _this.hls_ = hls;\n _this.withCredentials = withCredentials;\n\n if (!srcUrlOrPlaylist) {\n throw new Error('A non-empty playlist URL or playlist is required');\n } // event naming?\n\n\n _this.on('minimumUpdatePeriod', function () {\n _this.refreshXml_();\n }); // live playlist staleness timeout\n\n\n _this.on('mediaupdatetimeout', function () {\n _this.refreshMedia_();\n }); // initialize the loader state\n\n\n if (typeof srcUrlOrPlaylist === 'string') {\n _this.srcUrl = srcUrlOrPlaylist;\n _this.state = 'HAVE_NOTHING';\n return possibleConstructorReturn(_this);\n }\n\n _this.masterPlaylistLoader_ = masterPlaylistLoader;\n _this.state = 'HAVE_METADATA';\n _this.started = true; // we only should have one playlist so select it\n\n _this.media(srcUrlOrPlaylist); // trigger async to mimic behavior of HLS, where it must request a playlist\n\n\n window$1.setTimeout(function () {\n _this.trigger('loadedmetadata');\n }, 0);\n return _this;\n }\n\n createClass(DashPlaylistLoader, [{\n key: 'dispose',\n value: function dispose() {\n this.stopRequest();\n window$1.clearTimeout(this.mediaUpdateTimeout);\n }\n }, {\n key: 'stopRequest',\n value: function stopRequest() {\n if (this.request) {\n var oldRequest = this.request;\n this.request = null;\n oldRequest.onreadystatechange = null;\n oldRequest.abort();\n }\n }\n }, {\n key: 'media',\n value: function media(playlist) {\n // getter\n if (!playlist) {\n return this.media_;\n } // setter\n\n\n if (this.state === 'HAVE_NOTHING') {\n throw new Error('Cannot switch media playlist from ' + this.state);\n }\n\n var startingState = this.state; // find the playlist object if the target playlist has been specified by URI\n\n if (typeof playlist === 'string') {\n if (!this.master.playlists[playlist]) {\n throw new Error('Unknown playlist URI: ' + playlist);\n }\n\n playlist = this.master.playlists[playlist];\n }\n\n var mediaChange = !this.media_ || playlist.uri !== this.media_.uri;\n this.state = 'HAVE_METADATA'; // switching to the active playlist is a no-op\n\n if (!mediaChange) {\n return;\n } // switching from an already loaded playlist\n\n\n if (this.media_) {\n this.trigger('mediachanging');\n }\n\n this.media_ = playlist;\n this.refreshMedia_(); // trigger media change if the active media has been updated\n\n if (startingState !== 'HAVE_MASTER') {\n this.trigger('mediachange');\n }\n }\n }, {\n key: 'pause',\n value: function pause() {\n this.stopRequest();\n window$1.clearTimeout(this.mediaUpdateTimeout);\n\n if (this.state === 'HAVE_NOTHING') {\n // If we pause the loader before any data has been retrieved, its as if we never\n // started, so reset to an unstarted state.\n this.started = false;\n }\n }\n }, {\n key: 'load',\n value: function load(isFinalRendition) {\n var _this2 = this;\n\n window$1.clearTimeout(this.mediaUpdateTimeout);\n var media = this.media();\n\n if (isFinalRendition) {\n var delay = media ? media.targetDuration / 2 * 1000 : 5 * 1000;\n this.mediaUpdateTimeout = window$1.setTimeout(function () {\n return _this2.load();\n }, delay);\n return;\n } // because the playlists are internal to the manifest, load should either load the\n // main manifest, or do nothing but trigger an event\n\n\n if (!this.started) {\n this.start();\n return;\n }\n\n this.trigger('loadedplaylist');\n }\n /**\n * Parses the master xml string and updates playlist uri references\n *\n * @return {Object}\n * The parsed mpd manifest object\n */\n\n }, {\n key: 'parseMasterXml',\n value: function parseMasterXml() {\n var master = parse(this.masterXml_, {\n manifestUri: this.srcUrl,\n clientOffset: this.clientOffset_\n });\n master.uri = this.srcUrl; // Set up phony URIs for the playlists since we won't have external URIs for DASH\n // but reference playlists by their URI throughout the project\n // TODO: Should we create the dummy uris in mpd-parser as well (leaning towards yes).\n\n for (var i = 0; i < master.playlists.length; i++) {\n var phonyUri = 'placeholder-uri-' + i;\n master.playlists[i].uri = phonyUri; // set up by URI references\n\n master.playlists[phonyUri] = master.playlists[i];\n } // set up phony URIs for the media group playlists since we won't have external\n // URIs for DASH but reference playlists by their URI throughout the project\n\n\n forEachMediaGroup(master, function (properties, mediaType, groupKey, labelKey) {\n if (properties.playlists && properties.playlists.length) {\n var _phonyUri = 'placeholder-uri-' + mediaType + '-' + groupKey + '-' + labelKey;\n\n properties.playlists[0].uri = _phonyUri; // setup URI references\n\n master.playlists[_phonyUri] = properties.playlists[0];\n }\n });\n setupMediaPlaylists(master);\n resolveMediaGroupUris(master);\n return master;\n }\n }, {\n key: 'start',\n value: function start() {\n var _this3 = this;\n\n this.started = true; // request the specified URL\n\n this.request = this.hls_.xhr({\n uri: this.srcUrl,\n withCredentials: this.withCredentials\n }, function (error, req) {\n // disposed\n if (!_this3.request) {\n return;\n } // clear the loader's request reference\n\n\n _this3.request = null;\n\n if (error) {\n _this3.error = {\n status: req.status,\n message: 'DASH playlist request error at URL: ' + _this3.srcUrl,\n responseText: req.responseText,\n // MEDIA_ERR_NETWORK\n code: 2\n };\n\n if (_this3.state === 'HAVE_NOTHING') {\n _this3.started = false;\n }\n\n return _this3.trigger('error');\n }\n\n _this3.masterXml_ = req.responseText;\n\n if (req.responseHeaders && req.responseHeaders.date) {\n _this3.masterLoaded_ = Date.parse(req.responseHeaders.date);\n } else {\n _this3.masterLoaded_ = Date.now();\n }\n\n _this3.syncClientServerClock_(_this3.onClientServerClockSync_.bind(_this3));\n });\n }\n /**\n * Parses the master xml for UTCTiming node to sync the client clock to the server\n * clock. If the UTCTiming node requires a HEAD or GET request, that request is made.\n *\n * @param {Function} done\n * Function to call when clock sync has completed\n */\n\n }, {\n key: 'syncClientServerClock_',\n value: function syncClientServerClock_(done) {\n var _this4 = this;\n\n var utcTiming = parseUTCTiming(this.masterXml_); // No UTCTiming element found in the mpd. Use Date header from mpd request as the\n // server clock\n\n if (utcTiming === null) {\n this.clientOffset_ = this.masterLoaded_ - Date.now();\n return done();\n }\n\n if (utcTiming.method === 'DIRECT') {\n this.clientOffset_ = utcTiming.value - Date.now();\n return done();\n }\n\n this.request = this.hls_.xhr({\n uri: resolveUrl(this.srcUrl, utcTiming.value),\n method: utcTiming.method,\n withCredentials: this.withCredentials\n }, function (error, req) {\n // disposed\n if (!_this4.request) {\n return;\n }\n\n if (error) {\n // sync request failed, fall back to using date header from mpd\n // TODO: log warning\n _this4.clientOffset_ = _this4.masterLoaded_ - Date.now();\n return done();\n }\n\n var serverTime = void 0;\n\n if (utcTiming.method === 'HEAD') {\n if (!req.responseHeaders || !req.responseHeaders.date) {\n // expected date header not preset, fall back to using date header from mpd\n // TODO: log warning\n serverTime = _this4.masterLoaded_;\n } else {\n serverTime = Date.parse(req.responseHeaders.date);\n }\n } else {\n serverTime = Date.parse(req.responseText);\n }\n\n _this4.clientOffset_ = serverTime - Date.now();\n done();\n });\n }\n /**\n * Handler for after client/server clock synchronization has happened. Sets up\n * xml refresh timer if specificed by the manifest.\n */\n\n }, {\n key: 'onClientServerClockSync_',\n value: function onClientServerClockSync_() {\n var _this5 = this;\n\n this.master = this.parseMasterXml();\n this.state = 'HAVE_MASTER';\n this.trigger('loadedplaylist');\n\n if (!this.media_) {\n // no media playlist was specifically selected so start\n // from the first listed one\n this.media(this.master.playlists[0]);\n } // trigger loadedmetadata to resolve setup of media groups\n // trigger async to mimic behavior of HLS, where it must request a playlist\n\n\n window$1.setTimeout(function () {\n _this5.trigger('loadedmetadata');\n }, 0); // TODO: minimumUpdatePeriod can have a value of 0. Currently the manifest will not\n // be refreshed when this is the case. The inter-op guide says that when the\n // minimumUpdatePeriod is 0, the manifest should outline all currently available\n // segments, but future segments may require an update. I think a good solution\n // would be to update the manifest at the same rate that the media playlists\n // are \"refreshed\", i.e. every targetDuration.\n\n if (this.master.minimumUpdatePeriod) {\n window$1.setTimeout(function () {\n _this5.trigger('minimumUpdatePeriod');\n }, this.master.minimumUpdatePeriod);\n }\n }\n /**\n * Sends request to refresh the master xml and updates the parsed master manifest\n * TODO: Does the client offset need to be recalculated when the xml is refreshed?\n */\n\n }, {\n key: 'refreshXml_',\n value: function refreshXml_() {\n var _this6 = this;\n\n this.request = this.hls_.xhr({\n uri: this.srcUrl,\n withCredentials: this.withCredentials\n }, function (error, req) {\n // disposed\n if (!_this6.request) {\n return;\n } // clear the loader's request reference\n\n\n _this6.request = null;\n\n if (error) {\n _this6.error = {\n status: req.status,\n message: 'DASH playlist request error at URL: ' + _this6.srcUrl,\n responseText: req.responseText,\n // MEDIA_ERR_NETWORK\n code: 2\n };\n\n if (_this6.state === 'HAVE_NOTHING') {\n _this6.started = false;\n }\n\n return _this6.trigger('error');\n }\n\n _this6.masterXml_ = req.responseText;\n\n var newMaster = _this6.parseMasterXml();\n\n _this6.master = updateMaster$1(_this6.master, newMaster);\n window$1.setTimeout(function () {\n _this6.trigger('minimumUpdatePeriod');\n }, _this6.master.minimumUpdatePeriod);\n });\n }\n /**\n * Refreshes the media playlist by re-parsing the master xml and updating playlist\n * references. If this is an alternate loader, the updated parsed manifest is retrieved\n * from the master loader.\n */\n\n }, {\n key: 'refreshMedia_',\n value: function refreshMedia_() {\n var _this7 = this;\n\n var oldMaster = void 0;\n var newMaster = void 0;\n\n if (this.masterPlaylistLoader_) {\n oldMaster = this.masterPlaylistLoader_.master;\n newMaster = this.masterPlaylistLoader_.parseMasterXml();\n } else {\n oldMaster = this.master;\n newMaster = this.parseMasterXml();\n }\n\n var updatedMaster = updateMaster$1(oldMaster, newMaster);\n\n if (updatedMaster) {\n if (this.masterPlaylistLoader_) {\n this.masterPlaylistLoader_.master = updatedMaster;\n } else {\n this.master = updatedMaster;\n }\n\n this.media_ = updatedMaster.playlists[this.media_.uri];\n } else {\n this.trigger('playlistunchanged');\n }\n\n if (!this.media().endList) {\n this.mediaUpdateTimeout = window$1.setTimeout(function () {\n _this7.trigger('mediaupdatetimeout');\n }, refreshDelay(this.media(), !!updatedMaster));\n }\n\n this.trigger('loadedplaylist');\n }\n }]);\n return DashPlaylistLoader;\n}(EventTarget$1$1);\n\nvar logger = function logger(source) {\n if (videojs$1.log.debug) {\n return videojs$1.log.debug.bind(videojs$1, 'VHS:', source + ' >');\n }\n\n return function () {};\n};\n\nfunction noop() {}\n/**\n * @file source-updater.js\n */\n\n/**\n * A queue of callbacks to be serialized and applied when a\n * MediaSource and its associated SourceBuffers are not in the\n * updating state. It is used by the segment loader to update the\n * underlying SourceBuffers when new data is loaded, for instance.\n *\n * @class SourceUpdater\n * @param {MediaSource} mediaSource the MediaSource to create the\n * SourceBuffer from\n * @param {String} mimeType the desired MIME type of the underlying\n * SourceBuffer\n * @param {Object} sourceBufferEmitter an event emitter that fires when a source buffer is\n * added to the media source\n */\n\n\nvar SourceUpdater = function () {\n function SourceUpdater(mediaSource, mimeType, type, sourceBufferEmitter) {\n classCallCheck(this, SourceUpdater);\n this.callbacks_ = [];\n this.pendingCallback_ = null;\n this.timestampOffset_ = 0;\n this.mediaSource = mediaSource;\n this.processedAppend_ = false;\n this.type_ = type;\n this.mimeType_ = mimeType;\n this.logger_ = logger('SourceUpdater[' + type + '][' + mimeType + ']');\n\n if (mediaSource.readyState === 'closed') {\n mediaSource.addEventListener('sourceopen', this.createSourceBuffer_.bind(this, mimeType, sourceBufferEmitter));\n } else {\n this.createSourceBuffer_(mimeType, sourceBufferEmitter);\n }\n }\n\n createClass(SourceUpdater, [{\n key: 'createSourceBuffer_',\n value: function createSourceBuffer_(mimeType, sourceBufferEmitter) {\n var _this = this;\n\n this.sourceBuffer_ = this.mediaSource.addSourceBuffer(mimeType);\n this.logger_('created SourceBuffer');\n\n if (sourceBufferEmitter) {\n sourceBufferEmitter.trigger('sourcebufferadded');\n\n if (this.mediaSource.sourceBuffers.length < 2) {\n // There's another source buffer we must wait for before we can start updating\n // our own (or else we can get into a bad state, i.e., appending video/audio data\n // before the other video/audio source buffer is available and leading to a video\n // or audio only buffer).\n sourceBufferEmitter.on('sourcebufferadded', function () {\n _this.start_();\n });\n return;\n }\n }\n\n this.start_();\n }\n }, {\n key: 'start_',\n value: function start_() {\n var _this2 = this;\n\n this.started_ = true; // run completion handlers and process callbacks as updateend\n // events fire\n\n this.onUpdateendCallback_ = function () {\n var pendingCallback = _this2.pendingCallback_;\n _this2.pendingCallback_ = null;\n\n _this2.logger_('buffered [' + printableRange(_this2.buffered()) + ']');\n\n if (pendingCallback) {\n pendingCallback();\n }\n\n _this2.runCallback_();\n };\n\n this.sourceBuffer_.addEventListener('updateend', this.onUpdateendCallback_);\n this.runCallback_();\n }\n /**\n * Aborts the current segment and resets the segment parser.\n *\n * @param {Function} done function to call when done\n * @see http://w3c.github.io/media-source/#widl-SourceBuffer-abort-void\n */\n\n }, {\n key: 'abort',\n value: function abort(done) {\n var _this3 = this;\n\n if (this.processedAppend_) {\n this.queueCallback_(function () {\n _this3.sourceBuffer_.abort();\n }, done);\n }\n }\n /**\n * Queue an update to append an ArrayBuffer.\n *\n * @param {ArrayBuffer} bytes\n * @param {Function} done the function to call when done\n * @see http://www.w3.org/TR/media-source/#widl-SourceBuffer-appendBuffer-void-ArrayBuffer-data\n */\n\n }, {\n key: 'appendBuffer',\n value: function appendBuffer(bytes, done) {\n var _this4 = this;\n\n this.processedAppend_ = true;\n this.queueCallback_(function () {\n _this4.sourceBuffer_.appendBuffer(bytes);\n }, done);\n }\n /**\n * Indicates what TimeRanges are buffered in the managed SourceBuffer.\n *\n * @see http://www.w3.org/TR/media-source/#widl-SourceBuffer-buffered\n */\n\n }, {\n key: 'buffered',\n value: function buffered() {\n if (!this.sourceBuffer_) {\n return videojs$1.createTimeRanges();\n }\n\n return this.sourceBuffer_.buffered;\n }\n /**\n * Queue an update to remove a time range from the buffer.\n *\n * @param {Number} start where to start the removal\n * @param {Number} end where to end the removal\n * @param {Function} [done=noop] optional callback to be executed when the remove\n * operation is complete\n * @see http://www.w3.org/TR/media-source/#widl-SourceBuffer-remove-void-double-start-unrestricted-double-end\n */\n\n }, {\n key: 'remove',\n value: function remove(start, end) {\n var _this5 = this;\n\n var done = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : noop;\n\n if (this.processedAppend_) {\n this.queueCallback_(function () {\n _this5.logger_('remove [' + start + ' => ' + end + ']');\n\n _this5.sourceBuffer_.remove(start, end);\n }, done);\n }\n }\n /**\n * Whether the underlying sourceBuffer is updating or not\n *\n * @return {Boolean} the updating status of the SourceBuffer\n */\n\n }, {\n key: 'updating',\n value: function updating() {\n return !this.sourceBuffer_ || this.sourceBuffer_.updating || this.pendingCallback_;\n }\n /**\n * Set/get the timestampoffset on the SourceBuffer\n *\n * @return {Number} the timestamp offset\n */\n\n }, {\n key: 'timestampOffset',\n value: function timestampOffset(offset) {\n var _this6 = this;\n\n if (typeof offset !== 'undefined') {\n this.queueCallback_(function () {\n _this6.sourceBuffer_.timestampOffset = offset;\n });\n this.timestampOffset_ = offset;\n }\n\n return this.timestampOffset_;\n }\n /**\n * Queue a callback to run\n */\n\n }, {\n key: 'queueCallback_',\n value: function queueCallback_(callback, done) {\n this.callbacks_.push([callback.bind(this), done]);\n this.runCallback_();\n }\n /**\n * Run a queued callback\n */\n\n }, {\n key: 'runCallback_',\n value: function runCallback_() {\n var callbacks = void 0;\n\n if (!this.updating() && this.callbacks_.length && this.started_) {\n callbacks = this.callbacks_.shift();\n this.pendingCallback_ = callbacks[1];\n callbacks[0]();\n }\n }\n /**\n * dispose of the source updater and the underlying sourceBuffer\n */\n\n }, {\n key: 'dispose',\n value: function dispose() {\n this.sourceBuffer_.removeEventListener('updateend', this.onUpdateendCallback_);\n\n if (this.sourceBuffer_ && this.mediaSource.readyState === 'open') {\n this.sourceBuffer_.abort();\n }\n }\n }]);\n return SourceUpdater;\n}();\n\nvar Config = {\n GOAL_BUFFER_LENGTH: 30,\n MAX_GOAL_BUFFER_LENGTH: 60,\n GOAL_BUFFER_LENGTH_RATE: 1,\n // 0.5 MB/s\n INITIAL_BANDWIDTH: 4194304,\n // A fudge factor to apply to advertised playlist bitrates to account for\n // temporary flucations in client bandwidth\n BANDWIDTH_VARIANCE: 1.2,\n // How much of the buffer must be filled before we consider upswitching\n BUFFER_LOW_WATER_LINE: 0,\n MAX_BUFFER_LOW_WATER_LINE: 30,\n BUFFER_LOW_WATER_LINE_RATE: 1\n};\nvar REQUEST_ERRORS = {\n FAILURE: 2,\n TIMEOUT: -101,\n ABORTED: -102\n};\n/**\n * Turns segment byterange into a string suitable for use in\n * HTTP Range requests\n *\n * @param {Object} byterange - an object with two values defining the start and end\n * of a byte-range\n */\n\nvar byterangeStr = function byterangeStr(byterange) {\n var byterangeStart = void 0;\n var byterangeEnd = void 0; // `byterangeEnd` is one less than `offset + length` because the HTTP range\n // header uses inclusive ranges\n\n byterangeEnd = byterange.offset + byterange.length - 1;\n byterangeStart = byterange.offset;\n return 'bytes=' + byterangeStart + '-' + byterangeEnd;\n};\n/**\n * Defines headers for use in the xhr request for a particular segment.\n *\n * @param {Object} segment - a simplified copy of the segmentInfo object\n * from SegmentLoader\n */\n\n\nvar segmentXhrHeaders = function segmentXhrHeaders(segment) {\n var headers = {};\n\n if (segment.byterange) {\n headers.Range = byterangeStr(segment.byterange);\n }\n\n return headers;\n};\n/**\n * Abort all requests\n *\n * @param {Object} activeXhrs - an object that tracks all XHR requests\n */\n\n\nvar abortAll = function abortAll(activeXhrs) {\n activeXhrs.forEach(function (xhr$$1) {\n xhr$$1.abort();\n });\n};\n/**\n * Gather important bandwidth stats once a request has completed\n *\n * @param {Object} request - the XHR request from which to gather stats\n */\n\n\nvar getRequestStats = function getRequestStats(request) {\n return {\n bandwidth: request.bandwidth,\n bytesReceived: request.bytesReceived || 0,\n roundTripTime: request.roundTripTime || 0\n };\n};\n/**\n * If possible gather bandwidth stats as a request is in\n * progress\n *\n * @param {Event} progressEvent - an event object from an XHR's progress event\n */\n\n\nvar getProgressStats = function getProgressStats(progressEvent) {\n var request = progressEvent.target;\n var roundTripTime = Date.now() - request.requestTime;\n var stats = {\n bandwidth: Infinity,\n bytesReceived: 0,\n roundTripTime: roundTripTime || 0\n };\n stats.bytesReceived = progressEvent.loaded; // This can result in Infinity if stats.roundTripTime is 0 but that is ok\n // because we should only use bandwidth stats on progress to determine when\n // abort a request early due to insufficient bandwidth\n\n stats.bandwidth = Math.floor(stats.bytesReceived / stats.roundTripTime * 8 * 1000);\n return stats;\n};\n/**\n * Handle all error conditions in one place and return an object\n * with all the information\n *\n * @param {Error|null} error - if non-null signals an error occured with the XHR\n * @param {Object} request - the XHR request that possibly generated the error\n */\n\n\nvar handleErrors = function handleErrors(error, request) {\n if (request.timedout) {\n return {\n status: request.status,\n message: 'HLS request timed-out at URL: ' + request.uri,\n code: REQUEST_ERRORS.TIMEOUT,\n xhr: request\n };\n }\n\n if (request.aborted) {\n return {\n status: request.status,\n message: 'HLS request aborted at URL: ' + request.uri,\n code: REQUEST_ERRORS.ABORTED,\n xhr: request\n };\n }\n\n if (error) {\n return {\n status: request.status,\n message: 'HLS request errored at URL: ' + request.uri,\n code: REQUEST_ERRORS.FAILURE,\n xhr: request\n };\n }\n\n return null;\n};\n/**\n * Handle responses for key data and convert the key data to the correct format\n * for the decryption step later\n *\n * @param {Object} segment - a simplified copy of the segmentInfo object\n * from SegmentLoader\n * @param {Function} finishProcessingFn - a callback to execute to continue processing\n * this request\n */\n\n\nvar handleKeyResponse = function handleKeyResponse(segment, finishProcessingFn) {\n return function (error, request) {\n var response = request.response;\n var errorObj = handleErrors(error, request);\n\n if (errorObj) {\n return finishProcessingFn(errorObj, segment);\n }\n\n if (response.byteLength !== 16) {\n return finishProcessingFn({\n status: request.status,\n message: 'Invalid HLS key at URL: ' + request.uri,\n code: REQUEST_ERRORS.FAILURE,\n xhr: request\n }, segment);\n }\n\n var view = new DataView(response);\n segment.key.bytes = new Uint32Array([view.getUint32(0), view.getUint32(4), view.getUint32(8), view.getUint32(12)]);\n return finishProcessingFn(null, segment);\n };\n};\n/**\n * Handle init-segment responses\n *\n * @param {Object} segment - a simplified copy of the segmentInfo object\n * from SegmentLoader\n * @param {Function} finishProcessingFn - a callback to execute to continue processing\n * this request\n */\n\n\nvar handleInitSegmentResponse = function handleInitSegmentResponse(segment, captionParser, finishProcessingFn) {\n return function (error, request) {\n var response = request.response;\n var errorObj = handleErrors(error, request);\n\n if (errorObj) {\n return finishProcessingFn(errorObj, segment);\n } // stop processing if received empty content\n\n\n if (response.byteLength === 0) {\n return finishProcessingFn({\n status: request.status,\n message: 'Empty HLS segment content at URL: ' + request.uri,\n code: REQUEST_ERRORS.FAILURE,\n xhr: request\n }, segment);\n }\n\n segment.map.bytes = new Uint8Array(request.response); // Initialize CaptionParser if it hasn't been yet\n\n if (!captionParser.isInitialized()) {\n captionParser.init();\n }\n\n segment.map.timescales = mp4probe.timescale(segment.map.bytes);\n segment.map.videoTrackIds = mp4probe.videoTrackIds(segment.map.bytes);\n return finishProcessingFn(null, segment);\n };\n};\n/**\n * Response handler for segment-requests being sure to set the correct\n * property depending on whether the segment is encryped or not\n * Also records and keeps track of stats that are used for ABR purposes\n *\n * @param {Object} segment - a simplified copy of the segmentInfo object\n * from SegmentLoader\n * @param {Function} finishProcessingFn - a callback to execute to continue processing\n * this request\n */\n\n\nvar handleSegmentResponse = function handleSegmentResponse(segment, captionParser, finishProcessingFn) {\n return function (error, request) {\n var response = request.response;\n var errorObj = handleErrors(error, request);\n var parsed = void 0;\n\n if (errorObj) {\n return finishProcessingFn(errorObj, segment);\n } // stop processing if received empty content\n\n\n if (response.byteLength === 0) {\n return finishProcessingFn({\n status: request.status,\n message: 'Empty HLS segment content at URL: ' + request.uri,\n code: REQUEST_ERRORS.FAILURE,\n xhr: request\n }, segment);\n }\n\n segment.stats = getRequestStats(request);\n\n if (segment.key) {\n segment.encryptedBytes = new Uint8Array(request.response);\n } else {\n segment.bytes = new Uint8Array(request.response);\n } // This is likely an FMP4 and has the init segment.\n // Run through the CaptionParser in case there are captions.\n\n\n if (segment.map && segment.map.bytes) {\n // Initialize CaptionParser if it hasn't been yet\n if (!captionParser.isInitialized()) {\n captionParser.init();\n }\n\n parsed = captionParser.parse(segment.bytes, segment.map.videoTrackIds, segment.map.timescales);\n\n if (parsed && parsed.captions) {\n segment.captionStreams = parsed.captionStreams;\n segment.fmp4Captions = parsed.captions;\n }\n }\n\n return finishProcessingFn(null, segment);\n };\n};\n/**\n * Decrypt the segment via the decryption web worker\n *\n * @param {WebWorker} decrypter - a WebWorker interface to AES-128 decryption routines\n * @param {Object} segment - a simplified copy of the segmentInfo object\n * from SegmentLoader\n * @param {Function} doneFn - a callback that is executed after decryption has completed\n */\n\n\nvar decryptSegment = function decryptSegment(decrypter, segment, doneFn) {\n var decryptionHandler = function decryptionHandler(event) {\n if (event.data.source === segment.requestId) {\n decrypter.removeEventListener('message', decryptionHandler);\n var decrypted = event.data.decrypted;\n segment.bytes = new Uint8Array(decrypted.bytes, decrypted.byteOffset, decrypted.byteLength);\n return doneFn(null, segment);\n }\n };\n\n decrypter.addEventListener('message', decryptionHandler); // this is an encrypted segment\n // incrementally decrypt the segment\n\n decrypter.postMessage(createTransferableMessage({\n source: segment.requestId,\n encrypted: segment.encryptedBytes,\n key: segment.key.bytes,\n iv: segment.key.iv\n }), [segment.encryptedBytes.buffer, segment.key.bytes.buffer]);\n};\n/**\n * This function waits for all XHRs to finish (with either success or failure)\n * before continueing processing via it's callback. The function gathers errors\n * from each request into a single errors array so that the error status for\n * each request can be examined later.\n *\n * @param {Object} activeXhrs - an object that tracks all XHR requests\n * @param {WebWorker} decrypter - a WebWorker interface to AES-128 decryption routines\n * @param {Function} doneFn - a callback that is executed after all resources have been\n * downloaded and any decryption completed\n */\n\n\nvar waitForCompletion = function waitForCompletion(activeXhrs, decrypter, doneFn) {\n var count = 0;\n var didError = false;\n return function (error, segment) {\n if (didError) {\n return;\n }\n\n if (error) {\n didError = true; // If there are errors, we have to abort any outstanding requests\n\n abortAll(activeXhrs); // Even though the requests above are aborted, and in theory we could wait until we\n // handle the aborted events from those requests, there are some cases where we may\n // never get an aborted event. For instance, if the network connection is lost and\n // there were two requests, the first may have triggered an error immediately, while\n // the second request remains unsent. In that case, the aborted algorithm will not\n // trigger an abort: see https://xhr.spec.whatwg.org/#the-abort()-method\n //\n // We also can't rely on the ready state of the XHR, since the request that\n // triggered the connection error may also show as a ready state of 0 (unsent).\n // Therefore, we have to finish this group of requests immediately after the first\n // seen error.\n\n return doneFn(error, segment);\n }\n\n count += 1;\n\n if (count === activeXhrs.length) {\n // Keep track of when *all* of the requests have completed\n segment.endOfAllRequests = Date.now();\n\n if (segment.encryptedBytes) {\n return decryptSegment(decrypter, segment, doneFn);\n } // Otherwise, everything is ready just continue\n\n\n return doneFn(null, segment);\n }\n };\n};\n/**\n * Simple progress event callback handler that gathers some stats before\n * executing a provided callback with the `segment` object\n *\n * @param {Object} segment - a simplified copy of the segmentInfo object\n * from SegmentLoader\n * @param {Function} progressFn - a callback that is executed each time a progress event\n * is received\n * @param {Event} event - the progress event object from XMLHttpRequest\n */\n\n\nvar handleProgress = function handleProgress(segment, progressFn) {\n return function (event) {\n segment.stats = videojs$1.mergeOptions(segment.stats, getProgressStats(event)); // record the time that we receive the first byte of data\n\n if (!segment.stats.firstBytesReceivedAt && segment.stats.bytesReceived) {\n segment.stats.firstBytesReceivedAt = Date.now();\n }\n\n return progressFn(event, segment);\n };\n};\n/**\n * Load all resources and does any processing necessary for a media-segment\n *\n * Features:\n * decrypts the media-segment if it has a key uri and an iv\n * aborts *all* requests if *any* one request fails\n *\n * The segment object, at minimum, has the following format:\n * {\n * resolvedUri: String,\n * [byterange]: {\n * offset: Number,\n * length: Number\n * },\n * [key]: {\n * resolvedUri: String\n * [byterange]: {\n * offset: Number,\n * length: Number\n * },\n * iv: {\n * bytes: Uint32Array\n * }\n * },\n * [map]: {\n * resolvedUri: String,\n * [byterange]: {\n * offset: Number,\n * length: Number\n * },\n * [bytes]: Uint8Array\n * }\n * }\n * ...where [name] denotes optional properties\n *\n * @param {Function} xhr - an instance of the xhr wrapper in xhr.js\n * @param {Object} xhrOptions - the base options to provide to all xhr requests\n * @param {WebWorker} decryptionWorker - a WebWorker interface to AES-128\n * decryption routines\n * @param {Object} segment - a simplified copy of the segmentInfo object\n * from SegmentLoader\n * @param {Function} progressFn - a callback that receives progress events from the main\n * segment's xhr request\n * @param {Function} doneFn - a callback that is executed only once all requests have\n * succeeded or failed\n * @returns {Function} a function that, when invoked, immediately aborts all\n * outstanding requests\n */\n\n\nvar mediaSegmentRequest = function mediaSegmentRequest(xhr$$1, xhrOptions, decryptionWorker, captionParser, segment, progressFn, doneFn) {\n var activeXhrs = [];\n var finishProcessingFn = waitForCompletion(activeXhrs, decryptionWorker, doneFn); // optionally, request the decryption key\n\n if (segment.key) {\n var keyRequestOptions = videojs$1.mergeOptions(xhrOptions, {\n uri: segment.key.resolvedUri,\n responseType: 'arraybuffer'\n });\n var keyRequestCallback = handleKeyResponse(segment, finishProcessingFn);\n var keyXhr = xhr$$1(keyRequestOptions, keyRequestCallback);\n activeXhrs.push(keyXhr);\n } // optionally, request the associated media init segment\n\n\n if (segment.map && !segment.map.bytes) {\n var initSegmentOptions = videojs$1.mergeOptions(xhrOptions, {\n uri: segment.map.resolvedUri,\n responseType: 'arraybuffer',\n headers: segmentXhrHeaders(segment.map)\n });\n var initSegmentRequestCallback = handleInitSegmentResponse(segment, captionParser, finishProcessingFn);\n var initSegmentXhr = xhr$$1(initSegmentOptions, initSegmentRequestCallback);\n activeXhrs.push(initSegmentXhr);\n }\n\n var segmentRequestOptions = videojs$1.mergeOptions(xhrOptions, {\n uri: segment.resolvedUri,\n responseType: 'arraybuffer',\n headers: segmentXhrHeaders(segment)\n });\n var segmentRequestCallback = handleSegmentResponse(segment, captionParser, finishProcessingFn);\n var segmentXhr = xhr$$1(segmentRequestOptions, segmentRequestCallback);\n segmentXhr.addEventListener('progress', handleProgress(segment, progressFn));\n activeXhrs.push(segmentXhr);\n return function () {\n return abortAll(activeXhrs);\n };\n}; // Utilities\n\n/**\n * Returns the CSS value for the specified property on an element\n * using `getComputedStyle`. Firefox has a long-standing issue where\n * getComputedStyle() may return null when running in an iframe with\n * `display: none`.\n *\n * @see https://bugzilla.mozilla.org/show_bug.cgi?id=548397\n * @param {HTMLElement} el the htmlelement to work on\n * @param {string} the proprety to get the style for\n */\n\n\nvar safeGetComputedStyle = function safeGetComputedStyle(el, property) {\n var result = void 0;\n\n if (!el) {\n return '';\n }\n\n result = window$1.getComputedStyle(el);\n\n if (!result) {\n return '';\n }\n\n return result[property];\n};\n/**\n * Resuable stable sort function\n *\n * @param {Playlists} array\n * @param {Function} sortFn Different comparators\n * @function stableSort\n */\n\n\nvar stableSort = function stableSort(array, sortFn) {\n var newArray = array.slice();\n array.sort(function (left, right) {\n var cmp = sortFn(left, right);\n\n if (cmp === 0) {\n return newArray.indexOf(left) - newArray.indexOf(right);\n }\n\n return cmp;\n });\n};\n/**\n * A comparator function to sort two playlist object by bandwidth.\n *\n * @param {Object} left a media playlist object\n * @param {Object} right a media playlist object\n * @return {Number} Greater than zero if the bandwidth attribute of\n * left is greater than the corresponding attribute of right. Less\n * than zero if the bandwidth of right is greater than left and\n * exactly zero if the two are equal.\n */\n\n\nvar comparePlaylistBandwidth = function comparePlaylistBandwidth(left, right) {\n var leftBandwidth = void 0;\n var rightBandwidth = void 0;\n\n if (left.attributes.BANDWIDTH) {\n leftBandwidth = left.attributes.BANDWIDTH;\n }\n\n leftBandwidth = leftBandwidth || window$1.Number.MAX_VALUE;\n\n if (right.attributes.BANDWIDTH) {\n rightBandwidth = right.attributes.BANDWIDTH;\n }\n\n rightBandwidth = rightBandwidth || window$1.Number.MAX_VALUE;\n return leftBandwidth - rightBandwidth;\n};\n/**\n * A comparator function to sort two playlist object by resolution (width).\n * @param {Object} left a media playlist object\n * @param {Object} right a media playlist object\n * @return {Number} Greater than zero if the resolution.width attribute of\n * left is greater than the corresponding attribute of right. Less\n * than zero if the resolution.width of right is greater than left and\n * exactly zero if the two are equal.\n */\n\n\nvar comparePlaylistResolution = function comparePlaylistResolution(left, right) {\n var leftWidth = void 0;\n var rightWidth = void 0;\n\n if (left.attributes.RESOLUTION && left.attributes.RESOLUTION.width) {\n leftWidth = left.attributes.RESOLUTION.width;\n }\n\n leftWidth = leftWidth || window$1.Number.MAX_VALUE;\n\n if (right.attributes.RESOLUTION && right.attributes.RESOLUTION.width) {\n rightWidth = right.attributes.RESOLUTION.width;\n }\n\n rightWidth = rightWidth || window$1.Number.MAX_VALUE; // NOTE - Fallback to bandwidth sort as appropriate in cases where multiple renditions\n // have the same media dimensions/ resolution\n\n if (leftWidth === rightWidth && left.attributes.BANDWIDTH && right.attributes.BANDWIDTH) {\n return left.attributes.BANDWIDTH - right.attributes.BANDWIDTH;\n }\n\n return leftWidth - rightWidth;\n};\n/**\n * Chooses the appropriate media playlist based on bandwidth and player size\n *\n * @param {Object} master\n * Object representation of the master manifest\n * @param {Number} playerBandwidth\n * Current calculated bandwidth of the player\n * @param {Number} playerWidth\n * Current width of the player element\n * @param {Number} playerHeight\n * Current height of the player element\n * @param {Boolean} limitRenditionByPlayerDimensions\n * True if the player width and height should be used during the selection, false otherwise\n * @return {Playlist} the highest bitrate playlist less than the\n * currently detected bandwidth, accounting for some amount of\n * bandwidth variance\n */\n\n\nvar simpleSelector = function simpleSelector(master, playerBandwidth, playerWidth, playerHeight, limitRenditionByPlayerDimensions) {\n // convert the playlists to an intermediary representation to make comparisons easier\n var sortedPlaylistReps = master.playlists.map(function (playlist) {\n var width = void 0;\n var height = void 0;\n var bandwidth = void 0;\n width = playlist.attributes.RESOLUTION && playlist.attributes.RESOLUTION.width;\n height = playlist.attributes.RESOLUTION && playlist.attributes.RESOLUTION.height;\n bandwidth = playlist.attributes.BANDWIDTH;\n bandwidth = bandwidth || window$1.Number.MAX_VALUE;\n return {\n bandwidth: bandwidth,\n width: width,\n height: height,\n playlist: playlist\n };\n });\n stableSort(sortedPlaylistReps, function (left, right) {\n return left.bandwidth - right.bandwidth;\n }); // filter out any playlists that have been excluded due to\n // incompatible configurations\n\n sortedPlaylistReps = sortedPlaylistReps.filter(function (rep) {\n return !Playlist.isIncompatible(rep.playlist);\n }); // filter out any playlists that have been disabled manually through the representations\n // api or blacklisted temporarily due to playback errors.\n\n var enabledPlaylistReps = sortedPlaylistReps.filter(function (rep) {\n return Playlist.isEnabled(rep.playlist);\n });\n\n if (!enabledPlaylistReps.length) {\n // if there are no enabled playlists, then they have all been blacklisted or disabled\n // by the user through the representations api. In this case, ignore blacklisting and\n // fallback to what the user wants by using playlists the user has not disabled.\n enabledPlaylistReps = sortedPlaylistReps.filter(function (rep) {\n return !Playlist.isDisabled(rep.playlist);\n });\n } // filter out any variant that has greater effective bitrate\n // than the current estimated bandwidth\n\n\n var bandwidthPlaylistReps = enabledPlaylistReps.filter(function (rep) {\n return rep.bandwidth * Config.BANDWIDTH_VARIANCE < playerBandwidth;\n });\n var highestRemainingBandwidthRep = bandwidthPlaylistReps[bandwidthPlaylistReps.length - 1]; // get all of the renditions with the same (highest) bandwidth\n // and then taking the very first element\n\n var bandwidthBestRep = bandwidthPlaylistReps.filter(function (rep) {\n return rep.bandwidth === highestRemainingBandwidthRep.bandwidth;\n })[0]; // if we're not going to limit renditions by player size, make an early decision.\n\n if (limitRenditionByPlayerDimensions === false) {\n var _chosenRep = bandwidthBestRep || enabledPlaylistReps[0] || sortedPlaylistReps[0];\n\n return _chosenRep ? _chosenRep.playlist : null;\n } // filter out playlists without resolution information\n\n\n var haveResolution = bandwidthPlaylistReps.filter(function (rep) {\n return rep.width && rep.height;\n }); // sort variants by resolution\n\n stableSort(haveResolution, function (left, right) {\n return left.width - right.width;\n }); // if we have the exact resolution as the player use it\n\n var resolutionBestRepList = haveResolution.filter(function (rep) {\n return rep.width === playerWidth && rep.height === playerHeight;\n });\n highestRemainingBandwidthRep = resolutionBestRepList[resolutionBestRepList.length - 1]; // ensure that we pick the highest bandwidth variant that have exact resolution\n\n var resolutionBestRep = resolutionBestRepList.filter(function (rep) {\n return rep.bandwidth === highestRemainingBandwidthRep.bandwidth;\n })[0];\n var resolutionPlusOneList = void 0;\n var resolutionPlusOneSmallest = void 0;\n var resolutionPlusOneRep = void 0; // find the smallest variant that is larger than the player\n // if there is no match of exact resolution\n\n if (!resolutionBestRep) {\n resolutionPlusOneList = haveResolution.filter(function (rep) {\n return rep.width > playerWidth || rep.height > playerHeight;\n }); // find all the variants have the same smallest resolution\n\n resolutionPlusOneSmallest = resolutionPlusOneList.filter(function (rep) {\n return rep.width === resolutionPlusOneList[0].width && rep.height === resolutionPlusOneList[0].height;\n }); // ensure that we also pick the highest bandwidth variant that\n // is just-larger-than the video player\n\n highestRemainingBandwidthRep = resolutionPlusOneSmallest[resolutionPlusOneSmallest.length - 1];\n resolutionPlusOneRep = resolutionPlusOneSmallest.filter(function (rep) {\n return rep.bandwidth === highestRemainingBandwidthRep.bandwidth;\n })[0];\n } // fallback chain of variants\n\n\n var chosenRep = resolutionPlusOneRep || resolutionBestRep || bandwidthBestRep || enabledPlaylistReps[0] || sortedPlaylistReps[0];\n return chosenRep ? chosenRep.playlist : null;\n}; // Playlist Selectors\n\n/**\n * Chooses the appropriate media playlist based on the most recent\n * bandwidth estimate and the player size.\n *\n * Expects to be called within the context of an instance of HlsHandler\n *\n * @return {Playlist} the highest bitrate playlist less than the\n * currently detected bandwidth, accounting for some amount of\n * bandwidth variance\n */\n\n\nvar lastBandwidthSelector = function lastBandwidthSelector() {\n return simpleSelector(this.playlists.master, this.systemBandwidth, parseInt(safeGetComputedStyle(this.tech_.el(), 'width'), 10), parseInt(safeGetComputedStyle(this.tech_.el(), 'height'), 10), this.limitRenditionByPlayerDimensions);\n};\n/**\n * Chooses the appropriate media playlist based on the potential to rebuffer\n *\n * @param {Object} settings\n * Object of information required to use this selector\n * @param {Object} settings.master\n * Object representation of the master manifest\n * @param {Number} settings.currentTime\n * The current time of the player\n * @param {Number} settings.bandwidth\n * Current measured bandwidth\n * @param {Number} settings.duration\n * Duration of the media\n * @param {Number} settings.segmentDuration\n * Segment duration to be used in round trip time calculations\n * @param {Number} settings.timeUntilRebuffer\n * Time left in seconds until the player has to rebuffer\n * @param {Number} settings.currentTimeline\n * The current timeline segments are being loaded from\n * @param {SyncController} settings.syncController\n * SyncController for determining if we have a sync point for a given playlist\n * @return {Object|null}\n * {Object} return.playlist\n * The highest bandwidth playlist with the least amount of rebuffering\n * {Number} return.rebufferingImpact\n * The amount of time in seconds switching to this playlist will rebuffer. A\n * negative value means that switching will cause zero rebuffering.\n */\n\n\nvar minRebufferMaxBandwidthSelector = function minRebufferMaxBandwidthSelector(settings) {\n var master = settings.master,\n currentTime = settings.currentTime,\n bandwidth = settings.bandwidth,\n duration$$1 = settings.duration,\n segmentDuration = settings.segmentDuration,\n timeUntilRebuffer = settings.timeUntilRebuffer,\n currentTimeline = settings.currentTimeline,\n syncController = settings.syncController; // filter out any playlists that have been excluded due to\n // incompatible configurations\n\n var compatiblePlaylists = master.playlists.filter(function (playlist) {\n return !Playlist.isIncompatible(playlist);\n }); // filter out any playlists that have been disabled manually through the representations\n // api or blacklisted temporarily due to playback errors.\n\n var enabledPlaylists = compatiblePlaylists.filter(Playlist.isEnabled);\n\n if (!enabledPlaylists.length) {\n // if there are no enabled playlists, then they have all been blacklisted or disabled\n // by the user through the representations api. In this case, ignore blacklisting and\n // fallback to what the user wants by using playlists the user has not disabled.\n enabledPlaylists = compatiblePlaylists.filter(function (playlist) {\n return !Playlist.isDisabled(playlist);\n });\n }\n\n var bandwidthPlaylists = enabledPlaylists.filter(Playlist.hasAttribute.bind(null, 'BANDWIDTH'));\n var rebufferingEstimates = bandwidthPlaylists.map(function (playlist) {\n var syncPoint = syncController.getSyncPoint(playlist, duration$$1, currentTimeline, currentTime); // If there is no sync point for this playlist, switching to it will require a\n // sync request first. This will double the request time\n\n var numRequests = syncPoint ? 1 : 2;\n var requestTimeEstimate = Playlist.estimateSegmentRequestTime(segmentDuration, bandwidth, playlist);\n var rebufferingImpact = requestTimeEstimate * numRequests - timeUntilRebuffer;\n return {\n playlist: playlist,\n rebufferingImpact: rebufferingImpact\n };\n });\n var noRebufferingPlaylists = rebufferingEstimates.filter(function (estimate) {\n return estimate.rebufferingImpact <= 0;\n }); // Sort by bandwidth DESC\n\n stableSort(noRebufferingPlaylists, function (a, b) {\n return comparePlaylistBandwidth(b.playlist, a.playlist);\n });\n\n if (noRebufferingPlaylists.length) {\n return noRebufferingPlaylists[0];\n }\n\n stableSort(rebufferingEstimates, function (a, b) {\n return a.rebufferingImpact - b.rebufferingImpact;\n });\n return rebufferingEstimates[0] || null;\n};\n/**\n * Chooses the appropriate media playlist, which in this case is the lowest bitrate\n * one with video. If no renditions with video exist, return the lowest audio rendition.\n *\n * Expects to be called within the context of an instance of HlsHandler\n *\n * @return {Object|null}\n * {Object} return.playlist\n * The lowest bitrate playlist that contains a video codec. If no such rendition\n * exists pick the lowest audio rendition.\n */\n\n\nvar lowestBitrateCompatibleVariantSelector = function lowestBitrateCompatibleVariantSelector() {\n // filter out any playlists that have been excluded due to\n // incompatible configurations or playback errors\n var playlists = this.playlists.master.playlists.filter(Playlist.isEnabled); // Sort ascending by bitrate\n\n stableSort(playlists, function (a, b) {\n return comparePlaylistBandwidth(a, b);\n }); // Parse and assume that playlists with no video codec have no video\n // (this is not necessarily true, although it is generally true).\n //\n // If an entire manifest has no valid videos everything will get filtered\n // out.\n\n var playlistsWithVideo = playlists.filter(function (playlist) {\n return parseCodecs(playlist.attributes.CODECS).videoCodec;\n });\n return playlistsWithVideo[0] || null;\n};\n/**\n * Create captions text tracks on video.js if they do not exist\n *\n * @param {Object} inbandTextTracks a reference to current inbandTextTracks\n * @param {Object} tech the video.js tech\n * @param {Object} captionStreams the caption streams to create\n * @private\n */\n\n\nvar createCaptionsTrackIfNotExists = function createCaptionsTrackIfNotExists(inbandTextTracks, tech, captionStreams) {\n for (var trackId in captionStreams) {\n if (!inbandTextTracks[trackId]) {\n tech.trigger({\n type: 'usage',\n name: 'hls-608'\n });\n var track = tech.textTracks().getTrackById(trackId);\n\n if (track) {\n // Resuse an existing track with a CC# id because this was\n // very likely created by videojs-contrib-hls from information\n // in the m3u8 for us to use\n inbandTextTracks[trackId] = track;\n } else {\n // Otherwise, create a track with the default `CC#` label and\n // without a language\n inbandTextTracks[trackId] = tech.addRemoteTextTrack({\n kind: 'captions',\n id: trackId,\n label: trackId\n }, false).track;\n }\n }\n }\n};\n\nvar addCaptionData = function addCaptionData(_ref) {\n var inbandTextTracks = _ref.inbandTextTracks,\n captionArray = _ref.captionArray,\n timestampOffset = _ref.timestampOffset;\n\n if (!captionArray) {\n return;\n }\n\n var Cue = window.WebKitDataCue || window.VTTCue;\n captionArray.forEach(function (caption) {\n var track = caption.stream;\n var startTime = caption.startTime;\n var endTime = caption.endTime;\n\n if (!inbandTextTracks[track]) {\n return;\n }\n\n startTime += timestampOffset;\n endTime += timestampOffset;\n inbandTextTracks[track].addCue(new Cue(startTime, endTime, caption.text));\n });\n};\n/**\n * @file segment-loader.js\n */\n// in ms\n\n\nvar CHECK_BUFFER_DELAY = 500;\n/**\n * Determines if we should call endOfStream on the media source based\n * on the state of the buffer or if appened segment was the final\n * segment in the playlist.\n *\n * @param {Object} playlist a media playlist object\n * @param {Object} mediaSource the MediaSource object\n * @param {Number} segmentIndex the index of segment we last appended\n * @returns {Boolean} do we need to call endOfStream on the MediaSource\n */\n\nvar detectEndOfStream = function detectEndOfStream(playlist, mediaSource, segmentIndex) {\n if (!playlist || !mediaSource) {\n return false;\n }\n\n var segments = playlist.segments; // determine a few boolean values to help make the branch below easier\n // to read\n\n var appendedLastSegment = segmentIndex === segments.length; // if we've buffered to the end of the video, we need to call endOfStream\n // so that MediaSources can trigger the `ended` event when it runs out of\n // buffered data instead of waiting for me\n\n return playlist.endList && mediaSource.readyState === 'open' && appendedLastSegment;\n};\n\nvar finite = function finite(num) {\n return typeof num === 'number' && isFinite(num);\n};\n\nvar illegalMediaSwitch = function illegalMediaSwitch(loaderType, startingMedia, newSegmentMedia) {\n // Although these checks should most likely cover non 'main' types, for now it narrows\n // the scope of our checks.\n if (loaderType !== 'main' || !startingMedia || !newSegmentMedia) {\n return null;\n }\n\n if (!newSegmentMedia.containsAudio && !newSegmentMedia.containsVideo) {\n return 'Neither audio nor video found in segment.';\n }\n\n if (startingMedia.containsVideo && !newSegmentMedia.containsVideo) {\n return 'Only audio found in segment when we expected video.' + ' We can\\'t switch to audio only from a stream that had video.' + ' To get rid of this message, please add codec information to the manifest.';\n }\n\n if (!startingMedia.containsVideo && newSegmentMedia.containsVideo) {\n return 'Video found in segment when we expected only audio.' + ' We can\\'t switch to a stream with video from an audio only stream.' + ' To get rid of this message, please add codec information to the manifest.';\n }\n\n return null;\n};\n/**\n * Calculates a time value that is safe to remove from the back buffer without interupting\n * playback.\n *\n * @param {TimeRange} seekable\n * The current seekable range\n * @param {Number} currentTime\n * The current time of the player\n * @param {Number} targetDuration\n * The target duration of the current playlist\n * @return {Number}\n * Time that is safe to remove from the back buffer without interupting playback\n */\n\n\nvar safeBackBufferTrimTime = function safeBackBufferTrimTime(seekable$$1, currentTime, targetDuration) {\n var removeToTime = void 0;\n\n if (seekable$$1.length && seekable$$1.start(0) > 0 && seekable$$1.start(0) < currentTime) {\n // If we have a seekable range use that as the limit for what can be removed safely\n removeToTime = seekable$$1.start(0);\n } else {\n // otherwise remove anything older than 30 seconds before the current play head\n removeToTime = currentTime - 30;\n } // Don't allow removing from the buffer within target duration of current time\n // to avoid the possibility of removing the GOP currently being played which could\n // cause playback stalls.\n\n\n return Math.min(removeToTime, currentTime - targetDuration);\n};\n\nvar segmentInfoString = function segmentInfoString(segmentInfo) {\n var _segmentInfo$segment = segmentInfo.segment,\n start = _segmentInfo$segment.start,\n end = _segmentInfo$segment.end,\n _segmentInfo$playlist = segmentInfo.playlist,\n seq = _segmentInfo$playlist.mediaSequence,\n id = _segmentInfo$playlist.id,\n _segmentInfo$playlist2 = _segmentInfo$playlist.segments,\n segments = _segmentInfo$playlist2 === undefined ? [] : _segmentInfo$playlist2,\n index = segmentInfo.mediaIndex,\n timeline = segmentInfo.timeline;\n return ['appending [' + index + '] of [' + seq + ', ' + (seq + segments.length) + '] from playlist [' + id + ']', '[' + start + ' => ' + end + '] in timeline [' + timeline + ']'].join(' ');\n};\n/**\n * An object that manages segment loading and appending.\n *\n * @class SegmentLoader\n * @param {Object} options required and optional options\n * @extends videojs.EventTarget\n */\n\n\nvar SegmentLoader = function (_videojs$EventTarget) {\n inherits(SegmentLoader, _videojs$EventTarget);\n\n function SegmentLoader(settings) {\n classCallCheck(this, SegmentLoader); // check pre-conditions\n\n var _this = possibleConstructorReturn(this, (SegmentLoader.__proto__ || Object.getPrototypeOf(SegmentLoader)).call(this));\n\n if (!settings) {\n throw new TypeError('Initialization settings are required');\n }\n\n if (typeof settings.currentTime !== 'function') {\n throw new TypeError('No currentTime getter specified');\n }\n\n if (!settings.mediaSource) {\n throw new TypeError('No MediaSource specified');\n } // public properties\n\n\n _this.bandwidth = settings.bandwidth;\n _this.throughput = {\n rate: 0,\n count: 0\n };\n _this.roundTrip = NaN;\n\n _this.resetStats_();\n\n _this.mediaIndex = null; // private settings\n\n _this.hasPlayed_ = settings.hasPlayed;\n _this.currentTime_ = settings.currentTime;\n _this.seekable_ = settings.seekable;\n _this.seeking_ = settings.seeking;\n _this.duration_ = settings.duration;\n _this.mediaSource_ = settings.mediaSource;\n _this.hls_ = settings.hls;\n _this.loaderType_ = settings.loaderType;\n _this.startingMedia_ = void 0;\n _this.segmentMetadataTrack_ = settings.segmentMetadataTrack;\n _this.goalBufferLength_ = settings.goalBufferLength;\n _this.sourceType_ = settings.sourceType;\n _this.inbandTextTracks_ = settings.inbandTextTracks;\n _this.state_ = 'INIT'; // private instance variables\n\n _this.checkBufferTimeout_ = null;\n _this.error_ = void 0;\n _this.currentTimeline_ = -1;\n _this.pendingSegment_ = null;\n _this.mimeType_ = null;\n _this.sourceUpdater_ = null;\n _this.xhrOptions_ = null; // Fragmented mp4 playback\n\n _this.activeInitSegmentId_ = null;\n _this.initSegments_ = {}; // Fmp4 CaptionParser\n\n _this.captionParser_ = new CaptionParser();\n _this.decrypter_ = settings.decrypter; // Manages the tracking and generation of sync-points, mappings\n // between a time in the display time and a segment index within\n // a playlist\n\n _this.syncController_ = settings.syncController;\n _this.syncPoint_ = {\n segmentIndex: 0,\n time: 0\n };\n\n _this.syncController_.on('syncinfoupdate', function () {\n return _this.trigger('syncinfoupdate');\n });\n\n _this.mediaSource_.addEventListener('sourceopen', function () {\n return _this.ended_ = false;\n }); // ...for determining the fetch location\n\n\n _this.fetchAtBuffer_ = false;\n _this.logger_ = logger('SegmentLoader[' + _this.loaderType_ + ']');\n Object.defineProperty(_this, 'state', {\n get: function get$$1() {\n return this.state_;\n },\n set: function set$$1(newState) {\n if (newState !== this.state_) {\n this.logger_(this.state_ + ' -> ' + newState);\n this.state_ = newState;\n }\n }\n });\n return _this;\n }\n /**\n * reset all of our media stats\n *\n * @private\n */\n\n\n createClass(SegmentLoader, [{\n key: 'resetStats_',\n value: function resetStats_() {\n this.mediaBytesTransferred = 0;\n this.mediaRequests = 0;\n this.mediaRequestsAborted = 0;\n this.mediaRequestsTimedout = 0;\n this.mediaRequestsErrored = 0;\n this.mediaTransferDuration = 0;\n this.mediaSecondsLoaded = 0;\n }\n /**\n * dispose of the SegmentLoader and reset to the default state\n */\n\n }, {\n key: 'dispose',\n value: function dispose() {\n this.state = 'DISPOSED';\n this.pause();\n this.abort_();\n\n if (this.sourceUpdater_) {\n this.sourceUpdater_.dispose();\n }\n\n this.resetStats_();\n this.captionParser_.reset();\n }\n /**\n * abort anything that is currently doing on with the SegmentLoader\n * and reset to a default state\n */\n\n }, {\n key: 'abort',\n value: function abort() {\n if (this.state !== 'WAITING') {\n if (this.pendingSegment_) {\n this.pendingSegment_ = null;\n }\n\n return;\n }\n\n this.abort_(); // We aborted the requests we were waiting on, so reset the loader's state to READY\n // since we are no longer \"waiting\" on any requests. XHR callback is not always run\n // when the request is aborted. This will prevent the loader from being stuck in the\n // WAITING state indefinitely.\n\n this.state = 'READY'; // don't wait for buffer check timeouts to begin fetching the\n // next segment\n\n if (!this.paused()) {\n this.monitorBuffer_();\n }\n }\n /**\n * abort all pending xhr requests and null any pending segements\n *\n * @private\n */\n\n }, {\n key: 'abort_',\n value: function abort_() {\n if (this.pendingSegment_) {\n this.pendingSegment_.abortRequests();\n } // clear out the segment being processed\n\n\n this.pendingSegment_ = null;\n }\n /**\n * set an error on the segment loader and null out any pending segements\n *\n * @param {Error} error the error to set on the SegmentLoader\n * @return {Error} the error that was set or that is currently set\n */\n\n }, {\n key: 'error',\n value: function error(_error) {\n if (typeof _error !== 'undefined') {\n this.error_ = _error;\n }\n\n this.pendingSegment_ = null;\n return this.error_;\n }\n }, {\n key: 'endOfStream',\n value: function endOfStream() {\n this.ended_ = true;\n this.pause();\n this.trigger('ended');\n }\n /**\n * Indicates which time ranges are buffered\n *\n * @return {TimeRange}\n * TimeRange object representing the current buffered ranges\n */\n\n }, {\n key: 'buffered_',\n value: function buffered_() {\n if (!this.sourceUpdater_) {\n return videojs$1.createTimeRanges();\n }\n\n return this.sourceUpdater_.buffered();\n }\n /**\n * Gets and sets init segment for the provided map\n *\n * @param {Object} map\n * The map object representing the init segment to get or set\n * @param {Boolean=} set\n * If true, the init segment for the provided map should be saved\n * @return {Object}\n * map object for desired init segment\n */\n\n }, {\n key: 'initSegment',\n value: function initSegment(map) {\n var set$$1 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n\n if (!map) {\n return null;\n }\n\n var id = initSegmentId(map);\n var storedMap = this.initSegments_[id];\n\n if (set$$1 && !storedMap && map.bytes) {\n this.initSegments_[id] = storedMap = {\n resolvedUri: map.resolvedUri,\n byterange: map.byterange,\n bytes: map.bytes,\n timescales: map.timescales,\n videoTrackIds: map.videoTrackIds\n };\n }\n\n return storedMap || map;\n }\n /**\n * Returns true if all configuration required for loading is present, otherwise false.\n *\n * @return {Boolean} True if the all configuration is ready for loading\n * @private\n */\n\n }, {\n key: 'couldBeginLoading_',\n value: function couldBeginLoading_() {\n return this.playlist_ && ( // the source updater is created when init_ is called, so either having a\n // source updater or being in the INIT state with a mimeType is enough\n // to say we have all the needed configuration to start loading.\n this.sourceUpdater_ || this.mimeType_ && this.state === 'INIT') && !this.paused();\n }\n /**\n * load a playlist and start to fill the buffer\n */\n\n }, {\n key: 'load',\n value: function load() {\n // un-pause\n this.monitorBuffer_(); // if we don't have a playlist yet, keep waiting for one to be\n // specified\n\n if (!this.playlist_) {\n return;\n } // not sure if this is the best place for this\n\n\n this.syncController_.setDateTimeMapping(this.playlist_); // if all the configuration is ready, initialize and begin loading\n\n if (this.state === 'INIT' && this.couldBeginLoading_()) {\n return this.init_();\n } // if we're in the middle of processing a segment already, don't\n // kick off an additional segment request\n\n\n if (!this.couldBeginLoading_() || this.state !== 'READY' && this.state !== 'INIT') {\n return;\n }\n\n this.state = 'READY';\n }\n /**\n * Once all the starting parameters have been specified, begin\n * operation. This method should only be invoked from the INIT\n * state.\n *\n * @private\n */\n\n }, {\n key: 'init_',\n value: function init_() {\n this.state = 'READY';\n this.sourceUpdater_ = new SourceUpdater(this.mediaSource_, this.mimeType_, this.loaderType_, this.sourceBufferEmitter_);\n this.resetEverything();\n return this.monitorBuffer_();\n }\n /**\n * set a playlist on the segment loader\n *\n * @param {PlaylistLoader} media the playlist to set on the segment loader\n */\n\n }, {\n key: 'playlist',\n value: function playlist(newPlaylist) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n if (!newPlaylist) {\n return;\n }\n\n var oldPlaylist = this.playlist_;\n var segmentInfo = this.pendingSegment_;\n this.playlist_ = newPlaylist;\n this.xhrOptions_ = options; // when we haven't started playing yet, the start of a live playlist\n // is always our zero-time so force a sync update each time the playlist\n // is refreshed from the server\n\n if (!this.hasPlayed_()) {\n newPlaylist.syncInfo = {\n mediaSequence: newPlaylist.mediaSequence,\n time: 0\n };\n }\n\n var oldId = oldPlaylist ? oldPlaylist.id : null;\n this.logger_('playlist update [' + oldId + ' => ' + newPlaylist.id + ']'); // in VOD, this is always a rendition switch (or we updated our syncInfo above)\n // in LIVE, we always want to update with new playlists (including refreshes)\n\n this.trigger('syncinfoupdate'); // if we were unpaused but waiting for a playlist, start\n // buffering now\n\n if (this.state === 'INIT' && this.couldBeginLoading_()) {\n return this.init_();\n }\n\n if (!oldPlaylist || oldPlaylist.uri !== newPlaylist.uri) {\n if (this.mediaIndex !== null) {\n // we must \"resync\" the segment loader when we switch renditions and\n // the segment loader is already synced to the previous rendition\n this.resyncLoader();\n } // the rest of this function depends on `oldPlaylist` being defined\n\n\n return;\n } // we reloaded the same playlist so we are in a live scenario\n // and we will likely need to adjust the mediaIndex\n\n\n var mediaSequenceDiff = newPlaylist.mediaSequence - oldPlaylist.mediaSequence;\n this.logger_('live window shift [' + mediaSequenceDiff + ']'); // update the mediaIndex on the SegmentLoader\n // this is important because we can abort a request and this value must be\n // equal to the last appended mediaIndex\n\n if (this.mediaIndex !== null) {\n this.mediaIndex -= mediaSequenceDiff;\n } // update the mediaIndex on the SegmentInfo object\n // this is important because we will update this.mediaIndex with this value\n // in `handleUpdateEnd_` after the segment has been successfully appended\n\n\n if (segmentInfo) {\n segmentInfo.mediaIndex -= mediaSequenceDiff; // we need to update the referenced segment so that timing information is\n // saved for the new playlist's segment, however, if the segment fell off the\n // playlist, we can leave the old reference and just lose the timing info\n\n if (segmentInfo.mediaIndex >= 0) {\n segmentInfo.segment = newPlaylist.segments[segmentInfo.mediaIndex];\n }\n }\n\n this.syncController_.saveExpiredSegmentInfo(oldPlaylist, newPlaylist);\n }\n /**\n * Prevent the loader from fetching additional segments. If there\n * is a segment request outstanding, it will finish processing\n * before the loader halts. A segment loader can be unpaused by\n * calling load().\n */\n\n }, {\n key: 'pause',\n value: function pause() {\n if (this.checkBufferTimeout_) {\n window$1.clearTimeout(this.checkBufferTimeout_);\n this.checkBufferTimeout_ = null;\n }\n }\n /**\n * Returns whether the segment loader is fetching additional\n * segments when given the opportunity. This property can be\n * modified through calls to pause() and load().\n */\n\n }, {\n key: 'paused',\n value: function paused() {\n return this.checkBufferTimeout_ === null;\n }\n /**\n * create/set the following mimetype on the SourceBuffer through a\n * SourceUpdater\n *\n * @param {String} mimeType the mime type string to use\n * @param {Object} sourceBufferEmitter an event emitter that fires when a source buffer\n * is added to the media source\n */\n\n }, {\n key: 'mimeType',\n value: function mimeType(_mimeType, sourceBufferEmitter) {\n if (this.mimeType_) {\n return;\n }\n\n this.mimeType_ = _mimeType;\n this.sourceBufferEmitter_ = sourceBufferEmitter; // if we were unpaused but waiting for a sourceUpdater, start\n // buffering now\n\n if (this.state === 'INIT' && this.couldBeginLoading_()) {\n this.init_();\n }\n }\n /**\n * Delete all the buffered data and reset the SegmentLoader\n * @param {Function} [done] an optional callback to be executed when the remove\n * operation is complete\n */\n\n }, {\n key: 'resetEverything',\n value: function resetEverything(done) {\n this.ended_ = false;\n this.resetLoader();\n this.remove(0, this.duration_(), done); // clears fmp4 captions\n\n this.captionParser_.clearAllCaptions();\n this.trigger('reseteverything');\n }\n /**\n * Force the SegmentLoader to resync and start loading around the currentTime instead\n * of starting at the end of the buffer\n *\n * Useful for fast quality changes\n */\n\n }, {\n key: 'resetLoader',\n value: function resetLoader() {\n this.fetchAtBuffer_ = false;\n this.resyncLoader();\n }\n /**\n * Force the SegmentLoader to restart synchronization and make a conservative guess\n * before returning to the simple walk-forward method\n */\n\n }, {\n key: 'resyncLoader',\n value: function resyncLoader() {\n this.mediaIndex = null;\n this.syncPoint_ = null;\n this.abort();\n }\n /**\n * Remove any data in the source buffer between start and end times\n * @param {Number} start - the start time of the region to remove from the buffer\n * @param {Number} end - the end time of the region to remove from the buffer\n * @param {Function} [done] - an optional callback to be executed when the remove\n * operation is complete\n */\n\n }, {\n key: 'remove',\n value: function remove(start, end, done) {\n if (this.sourceUpdater_) {\n this.sourceUpdater_.remove(start, end, done);\n }\n\n removeCuesFromTrack(start, end, this.segmentMetadataTrack_);\n\n if (this.inbandTextTracks_) {\n for (var id in this.inbandTextTracks_) {\n removeCuesFromTrack(start, end, this.inbandTextTracks_[id]);\n }\n }\n }\n /**\n * (re-)schedule monitorBufferTick_ to run as soon as possible\n *\n * @private\n */\n\n }, {\n key: 'monitorBuffer_',\n value: function monitorBuffer_() {\n if (this.checkBufferTimeout_) {\n window$1.clearTimeout(this.checkBufferTimeout_);\n }\n\n this.checkBufferTimeout_ = window$1.setTimeout(this.monitorBufferTick_.bind(this), 1);\n }\n /**\n * As long as the SegmentLoader is in the READY state, periodically\n * invoke fillBuffer_().\n *\n * @private\n */\n\n }, {\n key: 'monitorBufferTick_',\n value: function monitorBufferTick_() {\n if (this.state === 'READY') {\n this.fillBuffer_();\n }\n\n if (this.checkBufferTimeout_) {\n window$1.clearTimeout(this.checkBufferTimeout_);\n }\n\n this.checkBufferTimeout_ = window$1.setTimeout(this.monitorBufferTick_.bind(this), CHECK_BUFFER_DELAY);\n }\n /**\n * fill the buffer with segements unless the sourceBuffers are\n * currently updating\n *\n * Note: this function should only ever be called by monitorBuffer_\n * and never directly\n *\n * @private\n */\n\n }, {\n key: 'fillBuffer_',\n value: function fillBuffer_() {\n if (this.sourceUpdater_.updating()) {\n return;\n }\n\n if (!this.syncPoint_) {\n this.syncPoint_ = this.syncController_.getSyncPoint(this.playlist_, this.duration_(), this.currentTimeline_, this.currentTime_());\n } // see if we need to begin loading immediately\n\n\n var segmentInfo = this.checkBuffer_(this.buffered_(), this.playlist_, this.mediaIndex, this.hasPlayed_(), this.currentTime_(), this.syncPoint_);\n\n if (!segmentInfo) {\n return;\n }\n\n var isEndOfStream = detectEndOfStream(this.playlist_, this.mediaSource_, segmentInfo.mediaIndex);\n\n if (isEndOfStream) {\n this.endOfStream();\n return;\n }\n\n if (segmentInfo.mediaIndex === this.playlist_.segments.length - 1 && this.mediaSource_.readyState === 'ended' && !this.seeking_()) {\n return;\n } // We will need to change timestampOffset of the sourceBuffer if either of\n // the following conditions are true:\n // - The segment.timeline !== this.currentTimeline\n // (we are crossing a discontinuity somehow)\n // - The \"timestampOffset\" for the start of this segment is less than\n // the currently set timestampOffset\n // Also, clear captions if we are crossing a discontinuity boundary\n\n\n if (segmentInfo.timeline !== this.currentTimeline_ || segmentInfo.startOfSegment !== null && segmentInfo.startOfSegment < this.sourceUpdater_.timestampOffset()) {\n this.syncController_.reset();\n segmentInfo.timestampOffset = segmentInfo.startOfSegment;\n this.captionParser_.clearAllCaptions();\n }\n\n this.loadSegment_(segmentInfo);\n }\n /**\n * Determines what segment request should be made, given current playback\n * state.\n *\n * @param {TimeRanges} buffered - the state of the buffer\n * @param {Object} playlist - the playlist object to fetch segments from\n * @param {Number} mediaIndex - the previous mediaIndex fetched or null\n * @param {Boolean} hasPlayed - a flag indicating whether we have played or not\n * @param {Number} currentTime - the playback position in seconds\n * @param {Object} syncPoint - a segment info object that describes the\n * @returns {Object} a segment request object that describes the segment to load\n */\n\n }, {\n key: 'checkBuffer_',\n value: function checkBuffer_(buffered, playlist, mediaIndex, hasPlayed, currentTime, syncPoint) {\n var lastBufferedEnd = 0;\n var startOfSegment = void 0;\n\n if (buffered.length) {\n lastBufferedEnd = buffered.end(buffered.length - 1);\n }\n\n var bufferedTime = Math.max(0, lastBufferedEnd - currentTime);\n\n if (!playlist.segments.length) {\n return null;\n } // if there is plenty of content buffered, and the video has\n // been played before relax for awhile\n\n\n if (bufferedTime >= this.goalBufferLength_()) {\n return null;\n } // if the video has not yet played once, and we already have\n // one segment downloaded do nothing\n\n\n if (!hasPlayed && bufferedTime >= 1) {\n return null;\n } // When the syncPoint is null, there is no way of determining a good\n // conservative segment index to fetch from\n // The best thing to do here is to get the kind of sync-point data by\n // making a request\n\n\n if (syncPoint === null) {\n mediaIndex = this.getSyncSegmentCandidate_(playlist);\n return this.generateSegmentInfo_(playlist, mediaIndex, null, true);\n } // Under normal playback conditions fetching is a simple walk forward\n\n\n if (mediaIndex !== null) {\n var segment = playlist.segments[mediaIndex];\n\n if (segment && segment.end) {\n startOfSegment = segment.end;\n } else {\n startOfSegment = lastBufferedEnd;\n }\n\n return this.generateSegmentInfo_(playlist, mediaIndex + 1, startOfSegment, false);\n } // There is a sync-point but the lack of a mediaIndex indicates that\n // we need to make a good conservative guess about which segment to\n // fetch\n\n\n if (this.fetchAtBuffer_) {\n // Find the segment containing the end of the buffer\n var mediaSourceInfo = Playlist.getMediaInfoForTime(playlist, lastBufferedEnd, syncPoint.segmentIndex, syncPoint.time);\n mediaIndex = mediaSourceInfo.mediaIndex;\n startOfSegment = mediaSourceInfo.startTime;\n } else {\n // Find the segment containing currentTime\n var _mediaSourceInfo = Playlist.getMediaInfoForTime(playlist, currentTime, syncPoint.segmentIndex, syncPoint.time);\n\n mediaIndex = _mediaSourceInfo.mediaIndex;\n startOfSegment = _mediaSourceInfo.startTime;\n }\n\n return this.generateSegmentInfo_(playlist, mediaIndex, startOfSegment, false);\n }\n /**\n * The segment loader has no recourse except to fetch a segment in the\n * current playlist and use the internal timestamps in that segment to\n * generate a syncPoint. This function returns a good candidate index\n * for that process.\n *\n * @param {Object} playlist - the playlist object to look for a\n * @returns {Number} An index of a segment from the playlist to load\n */\n\n }, {\n key: 'getSyncSegmentCandidate_',\n value: function getSyncSegmentCandidate_(playlist) {\n var _this2 = this;\n\n if (this.currentTimeline_ === -1) {\n return 0;\n }\n\n var segmentIndexArray = playlist.segments.map(function (s, i) {\n return {\n timeline: s.timeline,\n segmentIndex: i\n };\n }).filter(function (s) {\n return s.timeline === _this2.currentTimeline_;\n });\n\n if (segmentIndexArray.length) {\n return segmentIndexArray[Math.min(segmentIndexArray.length - 1, 1)].segmentIndex;\n }\n\n return Math.max(playlist.segments.length - 1, 0);\n }\n }, {\n key: 'generateSegmentInfo_',\n value: function generateSegmentInfo_(playlist, mediaIndex, startOfSegment, isSyncRequest) {\n if (mediaIndex < 0 || mediaIndex >= playlist.segments.length) {\n return null;\n }\n\n var segment = playlist.segments[mediaIndex];\n return {\n requestId: 'segment-loader-' + Math.random(),\n // resolve the segment URL relative to the playlist\n uri: segment.resolvedUri,\n // the segment's mediaIndex at the time it was requested\n mediaIndex: mediaIndex,\n // whether or not to update the SegmentLoader's state with this\n // segment's mediaIndex\n isSyncRequest: isSyncRequest,\n startOfSegment: startOfSegment,\n // the segment's playlist\n playlist: playlist,\n // unencrypted bytes of the segment\n bytes: null,\n // when a key is defined for this segment, the encrypted bytes\n encryptedBytes: null,\n // The target timestampOffset for this segment when we append it\n // to the source buffer\n timestampOffset: null,\n // The timeline that the segment is in\n timeline: segment.timeline,\n // The expected duration of the segment in seconds\n duration: segment.duration,\n // retain the segment in case the playlist updates while doing an async process\n segment: segment\n };\n }\n /**\n * Determines if the network has enough bandwidth to complete the current segment\n * request in a timely manner. If not, the request will be aborted early and bandwidth\n * updated to trigger a playlist switch.\n *\n * @param {Object} stats\n * Object containing stats about the request timing and size\n * @return {Boolean} True if the request was aborted, false otherwise\n * @private\n */\n\n }, {\n key: 'abortRequestEarly_',\n value: function abortRequestEarly_(stats) {\n if (this.hls_.tech_.paused() || // Don't abort if the current playlist is on the lowestEnabledRendition\n // TODO: Replace using timeout with a boolean indicating whether this playlist is\n // the lowestEnabledRendition.\n !this.xhrOptions_.timeout || // Don't abort if we have no bandwidth information to estimate segment sizes\n !this.playlist_.attributes.BANDWIDTH) {\n return false;\n } // Wait at least 1 second since the first byte of data has been received before\n // using the calculated bandwidth from the progress event to allow the bitrate\n // to stabilize\n\n\n if (Date.now() - (stats.firstBytesReceivedAt || Date.now()) < 1000) {\n return false;\n }\n\n var currentTime = this.currentTime_();\n var measuredBandwidth = stats.bandwidth;\n var segmentDuration = this.pendingSegment_.duration;\n var requestTimeRemaining = Playlist.estimateSegmentRequestTime(segmentDuration, measuredBandwidth, this.playlist_, stats.bytesReceived); // Subtract 1 from the timeUntilRebuffer so we still consider an early abort\n // if we are only left with less than 1 second when the request completes.\n // A negative timeUntilRebuffering indicates we are already rebuffering\n\n var timeUntilRebuffer$$1 = timeUntilRebuffer(this.buffered_(), currentTime, this.hls_.tech_.playbackRate()) - 1; // Only consider aborting early if the estimated time to finish the download\n // is larger than the estimated time until the player runs out of forward buffer\n\n if (requestTimeRemaining <= timeUntilRebuffer$$1) {\n return false;\n }\n\n var switchCandidate = minRebufferMaxBandwidthSelector({\n master: this.hls_.playlists.master,\n currentTime: currentTime,\n bandwidth: measuredBandwidth,\n duration: this.duration_(),\n segmentDuration: segmentDuration,\n timeUntilRebuffer: timeUntilRebuffer$$1,\n currentTimeline: this.currentTimeline_,\n syncController: this.syncController_\n });\n\n if (!switchCandidate) {\n return;\n }\n\n var rebufferingImpact = requestTimeRemaining - timeUntilRebuffer$$1;\n var timeSavedBySwitching = rebufferingImpact - switchCandidate.rebufferingImpact;\n var minimumTimeSaving = 0.5; // If we are already rebuffering, increase the amount of variance we add to the\n // potential round trip time of the new request so that we are not too aggressive\n // with switching to a playlist that might save us a fraction of a second.\n\n if (timeUntilRebuffer$$1 <= TIME_FUDGE_FACTOR) {\n minimumTimeSaving = 1;\n }\n\n if (!switchCandidate.playlist || switchCandidate.playlist.uri === this.playlist_.uri || timeSavedBySwitching < minimumTimeSaving) {\n return false;\n } // set the bandwidth to that of the desired playlist being sure to scale by\n // BANDWIDTH_VARIANCE and add one so the playlist selector does not exclude it\n // don't trigger a bandwidthupdate as the bandwidth is artifial\n\n\n this.bandwidth = switchCandidate.playlist.attributes.BANDWIDTH * Config.BANDWIDTH_VARIANCE + 1;\n this.abort();\n this.trigger('earlyabort');\n return true;\n }\n /**\n * XHR `progress` event handler\n *\n * @param {Event}\n * The XHR `progress` event\n * @param {Object} simpleSegment\n * A simplified segment object copy\n * @private\n */\n\n }, {\n key: 'handleProgress_',\n value: function handleProgress_(event, simpleSegment) {\n if (!this.pendingSegment_ || simpleSegment.requestId !== this.pendingSegment_.requestId || this.abortRequestEarly_(simpleSegment.stats)) {\n return;\n }\n\n this.trigger('progress');\n }\n /**\n * load a specific segment from a request into the buffer\n *\n * @private\n */\n\n }, {\n key: 'loadSegment_',\n value: function loadSegment_(segmentInfo) {\n this.state = 'WAITING';\n this.pendingSegment_ = segmentInfo;\n this.trimBackBuffer_(segmentInfo);\n segmentInfo.abortRequests = mediaSegmentRequest(this.hls_.xhr, this.xhrOptions_, this.decrypter_, this.captionParser_, this.createSimplifiedSegmentObj_(segmentInfo), // progress callback\n this.handleProgress_.bind(this), this.segmentRequestFinished_.bind(this));\n }\n /**\n * trim the back buffer so that we don't have too much data\n * in the source buffer\n *\n * @private\n *\n * @param {Object} segmentInfo - the current segment\n */\n\n }, {\n key: 'trimBackBuffer_',\n value: function trimBackBuffer_(segmentInfo) {\n var removeToTime = safeBackBufferTrimTime(this.seekable_(), this.currentTime_(), this.playlist_.targetDuration || 10); // Chrome has a hard limit of 150MB of\n // buffer and a very conservative \"garbage collector\"\n // We manually clear out the old buffer to ensure\n // we don't trigger the QuotaExceeded error\n // on the source buffer during subsequent appends\n\n if (removeToTime > 0) {\n this.remove(0, removeToTime);\n }\n }\n /**\n * created a simplified copy of the segment object with just the\n * information necessary to perform the XHR and decryption\n *\n * @private\n *\n * @param {Object} segmentInfo - the current segment\n * @returns {Object} a simplified segment object copy\n */\n\n }, {\n key: 'createSimplifiedSegmentObj_',\n value: function createSimplifiedSegmentObj_(segmentInfo) {\n var segment = segmentInfo.segment;\n var simpleSegment = {\n resolvedUri: segment.resolvedUri,\n byterange: segment.byterange,\n requestId: segmentInfo.requestId\n };\n\n if (segment.key) {\n // if the media sequence is greater than 2^32, the IV will be incorrect\n // assuming 10s segments, that would be about 1300 years\n var iv = segment.key.iv || new Uint32Array([0, 0, 0, segmentInfo.mediaIndex + segmentInfo.playlist.mediaSequence]);\n simpleSegment.key = {\n resolvedUri: segment.key.resolvedUri,\n iv: iv\n };\n }\n\n if (segment.map) {\n simpleSegment.map = this.initSegment(segment.map);\n }\n\n return simpleSegment;\n }\n /**\n * Handle the callback from the segmentRequest function and set the\n * associated SegmentLoader state and errors if necessary\n *\n * @private\n */\n\n }, {\n key: 'segmentRequestFinished_',\n value: function segmentRequestFinished_(error, simpleSegment) {\n // every request counts as a media request even if it has been aborted\n // or canceled due to a timeout\n this.mediaRequests += 1;\n\n if (simpleSegment.stats) {\n this.mediaBytesTransferred += simpleSegment.stats.bytesReceived;\n this.mediaTransferDuration += simpleSegment.stats.roundTripTime;\n } // The request was aborted and the SegmentLoader has already been reset\n\n\n if (!this.pendingSegment_) {\n this.mediaRequestsAborted += 1;\n return;\n } // the request was aborted and the SegmentLoader has already started\n // another request. this can happen when the timeout for an aborted\n // request triggers due to a limitation in the XHR library\n // do not count this as any sort of request or we risk double-counting\n\n\n if (simpleSegment.requestId !== this.pendingSegment_.requestId) {\n return;\n } // an error occurred from the active pendingSegment_ so reset everything\n\n\n if (error) {\n this.pendingSegment_ = null;\n this.state = 'READY'; // the requests were aborted just record the aborted stat and exit\n // this is not a true error condition and nothing corrective needs\n // to be done\n\n if (error.code === REQUEST_ERRORS.ABORTED) {\n this.mediaRequestsAborted += 1;\n return;\n }\n\n this.pause(); // the error is really just that at least one of the requests timed-out\n // set the bandwidth to a very low value and trigger an ABR switch to\n // take emergency action\n\n if (error.code === REQUEST_ERRORS.TIMEOUT) {\n this.mediaRequestsTimedout += 1;\n this.bandwidth = 1;\n this.roundTrip = NaN;\n this.trigger('bandwidthupdate');\n return;\n } // if control-flow has arrived here, then the error is real\n // emit an error event to blacklist the current playlist\n\n\n this.mediaRequestsErrored += 1;\n this.error(error);\n this.trigger('error');\n return;\n } // the response was a success so set any bandwidth stats the request\n // generated for ABR purposes\n\n\n this.bandwidth = simpleSegment.stats.bandwidth;\n this.roundTrip = simpleSegment.stats.roundTripTime; // if this request included an initialization segment, save that data\n // to the initSegment cache\n\n if (simpleSegment.map) {\n simpleSegment.map = this.initSegment(simpleSegment.map, true);\n }\n\n this.processSegmentResponse_(simpleSegment);\n }\n /**\n * Move any important data from the simplified segment object\n * back to the real segment object for future phases\n *\n * @private\n */\n\n }, {\n key: 'processSegmentResponse_',\n value: function processSegmentResponse_(simpleSegment) {\n var segmentInfo = this.pendingSegment_;\n segmentInfo.bytes = simpleSegment.bytes;\n\n if (simpleSegment.map) {\n segmentInfo.segment.map.bytes = simpleSegment.map.bytes;\n }\n\n segmentInfo.endOfAllRequests = simpleSegment.endOfAllRequests; // This has fmp4 captions, add them to text tracks\n\n if (simpleSegment.fmp4Captions) {\n createCaptionsTrackIfNotExists(this.inbandTextTracks_, this.hls_.tech_, simpleSegment.captionStreams);\n addCaptionData({\n inbandTextTracks: this.inbandTextTracks_,\n captionArray: simpleSegment.fmp4Captions,\n // fmp4s will not have a timestamp offset\n timestampOffset: 0\n }); // Reset stored captions since we added parsed\n // captions to a text track at this point\n\n this.captionParser_.clearParsedCaptions();\n }\n\n this.handleSegment_();\n }\n /**\n * append a decrypted segement to the SourceBuffer through a SourceUpdater\n *\n * @private\n */\n\n }, {\n key: 'handleSegment_',\n value: function handleSegment_() {\n var _this3 = this;\n\n if (!this.pendingSegment_) {\n this.state = 'READY';\n return;\n }\n\n var segmentInfo = this.pendingSegment_;\n var segment = segmentInfo.segment;\n var timingInfo = this.syncController_.probeSegmentInfo(segmentInfo); // When we have our first timing info, determine what media types this loader is\n // dealing with. Although we're maintaining extra state, it helps to preserve the\n // separation of segment loader from the actual source buffers.\n\n if (typeof this.startingMedia_ === 'undefined' && timingInfo && ( // Guard against cases where we're not getting timing info at all until we are\n // certain that all streams will provide it.\n timingInfo.containsAudio || timingInfo.containsVideo)) {\n this.startingMedia_ = {\n containsAudio: timingInfo.containsAudio,\n containsVideo: timingInfo.containsVideo\n };\n }\n\n var illegalMediaSwitchError = illegalMediaSwitch(this.loaderType_, this.startingMedia_, timingInfo);\n\n if (illegalMediaSwitchError) {\n this.error({\n message: illegalMediaSwitchError,\n blacklistDuration: Infinity\n });\n this.trigger('error');\n return;\n }\n\n if (segmentInfo.isSyncRequest) {\n this.trigger('syncinfoupdate');\n this.pendingSegment_ = null;\n this.state = 'READY';\n return;\n }\n\n if (segmentInfo.timestampOffset !== null && segmentInfo.timestampOffset !== this.sourceUpdater_.timestampOffset()) {\n this.sourceUpdater_.timestampOffset(segmentInfo.timestampOffset); // fired when a timestamp offset is set in HLS (can also identify discontinuities)\n\n this.trigger('timestampoffset');\n }\n\n var timelineMapping = this.syncController_.mappingForTimeline(segmentInfo.timeline);\n\n if (timelineMapping !== null) {\n this.trigger({\n type: 'segmenttimemapping',\n mapping: timelineMapping\n });\n }\n\n this.state = 'APPENDING'; // if the media initialization segment is changing, append it\n // before the content segment\n\n if (segment.map) {\n var initId = initSegmentId(segment.map);\n\n if (!this.activeInitSegmentId_ || this.activeInitSegmentId_ !== initId) {\n var initSegment = this.initSegment(segment.map);\n this.sourceUpdater_.appendBuffer(initSegment.bytes, function () {\n _this3.activeInitSegmentId_ = initId;\n });\n }\n }\n\n segmentInfo.byteLength = segmentInfo.bytes.byteLength;\n\n if (typeof segment.start === 'number' && typeof segment.end === 'number') {\n this.mediaSecondsLoaded += segment.end - segment.start;\n } else {\n this.mediaSecondsLoaded += segment.duration;\n }\n\n this.logger_(segmentInfoString(segmentInfo));\n this.sourceUpdater_.appendBuffer(segmentInfo.bytes, this.handleUpdateEnd_.bind(this));\n }\n /**\n * callback to run when appendBuffer is finished. detects if we are\n * in a good state to do things with the data we got, or if we need\n * to wait for more\n *\n * @private\n */\n\n }, {\n key: 'handleUpdateEnd_',\n value: function handleUpdateEnd_() {\n if (!this.pendingSegment_) {\n this.state = 'READY';\n\n if (!this.paused()) {\n this.monitorBuffer_();\n }\n\n return;\n }\n\n var segmentInfo = this.pendingSegment_;\n var segment = segmentInfo.segment;\n var isWalkingForward = this.mediaIndex !== null;\n this.pendingSegment_ = null;\n this.recordThroughput_(segmentInfo);\n this.addSegmentMetadataCue_(segmentInfo);\n this.state = 'READY';\n this.mediaIndex = segmentInfo.mediaIndex;\n this.fetchAtBuffer_ = true;\n this.currentTimeline_ = segmentInfo.timeline; // We must update the syncinfo to recalculate the seekable range before\n // the following conditional otherwise it may consider this a bad \"guess\"\n // and attempt to resync when the post-update seekable window and live\n // point would mean that this was the perfect segment to fetch\n\n this.trigger('syncinfoupdate'); // If we previously appended a segment that ends more than 3 targetDurations before\n // the currentTime_ that means that our conservative guess was too conservative.\n // In that case, reset the loader state so that we try to use any information gained\n // from the previous request to create a new, more accurate, sync-point.\n\n if (segment.end && this.currentTime_() - segment.end > segmentInfo.playlist.targetDuration * 3) {\n this.resetEverything();\n return;\n } // Don't do a rendition switch unless we have enough time to get a sync segment\n // and conservatively guess\n\n\n if (isWalkingForward) {\n this.trigger('bandwidthupdate');\n }\n\n this.trigger('progress'); // any time an update finishes and the last segment is in the\n // buffer, end the stream. this ensures the \"ended\" event will\n // fire if playback reaches that point.\n\n var isEndOfStream = detectEndOfStream(segmentInfo.playlist, this.mediaSource_, segmentInfo.mediaIndex + 1);\n\n if (isEndOfStream) {\n this.endOfStream();\n }\n\n if (!this.paused()) {\n this.monitorBuffer_();\n }\n }\n /**\n * Records the current throughput of the decrypt, transmux, and append\n * portion of the semgment pipeline. `throughput.rate` is a the cumulative\n * moving average of the throughput. `throughput.count` is the number of\n * data points in the average.\n *\n * @private\n * @param {Object} segmentInfo the object returned by loadSegment\n */\n\n }, {\n key: 'recordThroughput_',\n value: function recordThroughput_(segmentInfo) {\n var rate = this.throughput.rate; // Add one to the time to ensure that we don't accidentally attempt to divide\n // by zero in the case where the throughput is ridiculously high\n\n var segmentProcessingTime = Date.now() - segmentInfo.endOfAllRequests + 1; // Multiply by 8000 to convert from bytes/millisecond to bits/second\n\n var segmentProcessingThroughput = Math.floor(segmentInfo.byteLength / segmentProcessingTime * 8 * 1000); // This is just a cumulative moving average calculation:\n // newAvg = oldAvg + (sample - oldAvg) / (sampleCount + 1)\n\n this.throughput.rate += (segmentProcessingThroughput - rate) / ++this.throughput.count;\n }\n /**\n * Adds a cue to the segment-metadata track with some metadata information about the\n * segment\n *\n * @private\n * @param {Object} segmentInfo\n * the object returned by loadSegment\n * @method addSegmentMetadataCue_\n */\n\n }, {\n key: 'addSegmentMetadataCue_',\n value: function addSegmentMetadataCue_(segmentInfo) {\n if (!this.segmentMetadataTrack_) {\n return;\n }\n\n var segment = segmentInfo.segment;\n var start = segment.start;\n var end = segment.end; // Do not try adding the cue if the start and end times are invalid.\n\n if (!finite(start) || !finite(end)) {\n return;\n }\n\n removeCuesFromTrack(start, end, this.segmentMetadataTrack_);\n var Cue = window$1.WebKitDataCue || window$1.VTTCue;\n var value = {\n dateTimeObject: segment.dateTimeObject,\n dateTimeString: segment.dateTimeString,\n bandwidth: segmentInfo.playlist.attributes.BANDWIDTH,\n resolution: segmentInfo.playlist.attributes.RESOLUTION,\n codecs: segmentInfo.playlist.attributes.CODECS,\n byteLength: segmentInfo.byteLength,\n uri: segmentInfo.uri,\n timeline: segmentInfo.timeline,\n playlist: segmentInfo.playlist.uri,\n start: start,\n end: end\n };\n var data = JSON.stringify(value);\n var cue = new Cue(start, end, data); // Attach the metadata to the value property of the cue to keep consistency between\n // the differences of WebKitDataCue in safari and VTTCue in other browsers\n\n cue.value = value;\n this.segmentMetadataTrack_.addCue(cue);\n }\n }]);\n return SegmentLoader;\n}(videojs$1.EventTarget);\n\nvar uint8ToUtf8 = function uint8ToUtf8(uintArray) {\n return decodeURIComponent(escape(String.fromCharCode.apply(null, uintArray)));\n};\n/**\n * @file vtt-segment-loader.js\n */\n\n\nvar VTT_LINE_TERMINATORS = new Uint8Array('\\n\\n'.split('').map(function (char) {\n return char.charCodeAt(0);\n}));\n/**\n * An object that manages segment loading and appending.\n *\n * @class VTTSegmentLoader\n * @param {Object} options required and optional options\n * @extends videojs.EventTarget\n */\n\nvar VTTSegmentLoader = function (_SegmentLoader) {\n inherits(VTTSegmentLoader, _SegmentLoader);\n\n function VTTSegmentLoader(settings) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n classCallCheck(this, VTTSegmentLoader); // SegmentLoader requires a MediaSource be specified or it will throw an error;\n // however, VTTSegmentLoader has no need of a media source, so delete the reference\n\n var _this = possibleConstructorReturn(this, (VTTSegmentLoader.__proto__ || Object.getPrototypeOf(VTTSegmentLoader)).call(this, settings, options));\n\n _this.mediaSource_ = null;\n _this.subtitlesTrack_ = null;\n return _this;\n }\n /**\n * Indicates which time ranges are buffered\n *\n * @return {TimeRange}\n * TimeRange object representing the current buffered ranges\n */\n\n\n createClass(VTTSegmentLoader, [{\n key: 'buffered_',\n value: function buffered_() {\n if (!this.subtitlesTrack_ || !this.subtitlesTrack_.cues.length) {\n return videojs$1.createTimeRanges();\n }\n\n var cues = this.subtitlesTrack_.cues;\n var start = cues[0].startTime;\n var end = cues[cues.length - 1].startTime;\n return videojs$1.createTimeRanges([[start, end]]);\n }\n /**\n * Gets and sets init segment for the provided map\n *\n * @param {Object} map\n * The map object representing the init segment to get or set\n * @param {Boolean=} set\n * If true, the init segment for the provided map should be saved\n * @return {Object}\n * map object for desired init segment\n */\n\n }, {\n key: 'initSegment',\n value: function initSegment(map) {\n var set$$1 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n\n if (!map) {\n return null;\n }\n\n var id = initSegmentId(map);\n var storedMap = this.initSegments_[id];\n\n if (set$$1 && !storedMap && map.bytes) {\n // append WebVTT line terminators to the media initialization segment if it exists\n // to follow the WebVTT spec (https://w3c.github.io/webvtt/#file-structure) that\n // requires two or more WebVTT line terminators between the WebVTT header and the\n // rest of the file\n var combinedByteLength = VTT_LINE_TERMINATORS.byteLength + map.bytes.byteLength;\n var combinedSegment = new Uint8Array(combinedByteLength);\n combinedSegment.set(map.bytes);\n combinedSegment.set(VTT_LINE_TERMINATORS, map.bytes.byteLength);\n this.initSegments_[id] = storedMap = {\n resolvedUri: map.resolvedUri,\n byterange: map.byterange,\n bytes: combinedSegment\n };\n }\n\n return storedMap || map;\n }\n /**\n * Returns true if all configuration required for loading is present, otherwise false.\n *\n * @return {Boolean} True if the all configuration is ready for loading\n * @private\n */\n\n }, {\n key: 'couldBeginLoading_',\n value: function couldBeginLoading_() {\n return this.playlist_ && this.subtitlesTrack_ && !this.paused();\n }\n /**\n * Once all the starting parameters have been specified, begin\n * operation. This method should only be invoked from the INIT\n * state.\n *\n * @private\n */\n\n }, {\n key: 'init_',\n value: function init_() {\n this.state = 'READY';\n this.resetEverything();\n return this.monitorBuffer_();\n }\n /**\n * Set a subtitle track on the segment loader to add subtitles to\n *\n * @param {TextTrack=} track\n * The text track to add loaded subtitles to\n * @return {TextTrack}\n * Returns the subtitles track\n */\n\n }, {\n key: 'track',\n value: function track(_track) {\n if (typeof _track === 'undefined') {\n return this.subtitlesTrack_;\n }\n\n this.subtitlesTrack_ = _track; // if we were unpaused but waiting for a sourceUpdater, start\n // buffering now\n\n if (this.state === 'INIT' && this.couldBeginLoading_()) {\n this.init_();\n }\n\n return this.subtitlesTrack_;\n }\n /**\n * Remove any data in the source buffer between start and end times\n * @param {Number} start - the start time of the region to remove from the buffer\n * @param {Number} end - the end time of the region to remove from the buffer\n */\n\n }, {\n key: 'remove',\n value: function remove(start, end) {\n removeCuesFromTrack(start, end, this.subtitlesTrack_);\n }\n /**\n * fill the buffer with segements unless the sourceBuffers are\n * currently updating\n *\n * Note: this function should only ever be called by monitorBuffer_\n * and never directly\n *\n * @private\n */\n\n }, {\n key: 'fillBuffer_',\n value: function fillBuffer_() {\n var _this2 = this;\n\n if (!this.syncPoint_) {\n this.syncPoint_ = this.syncController_.getSyncPoint(this.playlist_, this.duration_(), this.currentTimeline_, this.currentTime_());\n } // see if we need to begin loading immediately\n\n\n var segmentInfo = this.checkBuffer_(this.buffered_(), this.playlist_, this.mediaIndex, this.hasPlayed_(), this.currentTime_(), this.syncPoint_);\n segmentInfo = this.skipEmptySegments_(segmentInfo);\n\n if (!segmentInfo) {\n return;\n }\n\n if (this.syncController_.timestampOffsetForTimeline(segmentInfo.timeline) === null) {\n // We don't have the timestamp offset that we need to sync subtitles.\n // Rerun on a timestamp offset or user interaction.\n var checkTimestampOffset = function checkTimestampOffset() {\n _this2.state = 'READY';\n\n if (!_this2.paused()) {\n // if not paused, queue a buffer check as soon as possible\n _this2.monitorBuffer_();\n }\n };\n\n this.syncController_.one('timestampoffset', checkTimestampOffset);\n this.state = 'WAITING_ON_TIMELINE';\n return;\n }\n\n this.loadSegment_(segmentInfo);\n }\n /**\n * Prevents the segment loader from requesting segments we know contain no subtitles\n * by walking forward until we find the next segment that we don't know whether it is\n * empty or not.\n *\n * @param {Object} segmentInfo\n * a segment info object that describes the current segment\n * @return {Object}\n * a segment info object that describes the current segment\n */\n\n }, {\n key: 'skipEmptySegments_',\n value: function skipEmptySegments_(segmentInfo) {\n while (segmentInfo && segmentInfo.segment.empty) {\n segmentInfo = this.generateSegmentInfo_(segmentInfo.playlist, segmentInfo.mediaIndex + 1, segmentInfo.startOfSegment + segmentInfo.duration, segmentInfo.isSyncRequest);\n }\n\n return segmentInfo;\n }\n /**\n * append a decrypted segement to the SourceBuffer through a SourceUpdater\n *\n * @private\n */\n\n }, {\n key: 'handleSegment_',\n value: function handleSegment_() {\n var _this3 = this;\n\n if (!this.pendingSegment_ || !this.subtitlesTrack_) {\n this.state = 'READY';\n return;\n }\n\n this.state = 'APPENDING';\n var segmentInfo = this.pendingSegment_;\n var segment = segmentInfo.segment; // Make sure that vttjs has loaded, otherwise, wait till it finished loading\n\n if (typeof window$1.WebVTT !== 'function' && this.subtitlesTrack_ && this.subtitlesTrack_.tech_) {\n var loadHandler = function loadHandler() {\n _this3.handleSegment_();\n };\n\n this.state = 'WAITING_ON_VTTJS';\n this.subtitlesTrack_.tech_.one('vttjsloaded', loadHandler);\n this.subtitlesTrack_.tech_.one('vttjserror', function () {\n _this3.subtitlesTrack_.tech_.off('vttjsloaded', loadHandler);\n\n _this3.error({\n message: 'Error loading vtt.js'\n });\n\n _this3.state = 'READY';\n\n _this3.pause();\n\n _this3.trigger('error');\n });\n return;\n }\n\n segment.requested = true;\n\n try {\n this.parseVTTCues_(segmentInfo);\n } catch (e) {\n this.error({\n message: e.message\n });\n this.state = 'READY';\n this.pause();\n return this.trigger('error');\n }\n\n this.updateTimeMapping_(segmentInfo, this.syncController_.timelines[segmentInfo.timeline], this.playlist_);\n\n if (segmentInfo.isSyncRequest) {\n this.trigger('syncinfoupdate');\n this.pendingSegment_ = null;\n this.state = 'READY';\n return;\n }\n\n segmentInfo.byteLength = segmentInfo.bytes.byteLength;\n this.mediaSecondsLoaded += segment.duration;\n\n if (segmentInfo.cues.length) {\n // remove any overlapping cues to prevent doubling\n this.remove(segmentInfo.cues[0].endTime, segmentInfo.cues[segmentInfo.cues.length - 1].endTime);\n }\n\n segmentInfo.cues.forEach(function (cue) {\n _this3.subtitlesTrack_.addCue(cue);\n });\n this.handleUpdateEnd_();\n }\n /**\n * Uses the WebVTT parser to parse the segment response\n *\n * @param {Object} segmentInfo\n * a segment info object that describes the current segment\n * @private\n */\n\n }, {\n key: 'parseVTTCues_',\n value: function parseVTTCues_(segmentInfo) {\n var decoder = void 0;\n var decodeBytesToString = false;\n\n if (typeof window$1.TextDecoder === 'function') {\n decoder = new window$1.TextDecoder('utf8');\n } else {\n decoder = window$1.WebVTT.StringDecoder();\n decodeBytesToString = true;\n }\n\n var parser = new window$1.WebVTT.Parser(window$1, window$1.vttjs, decoder);\n segmentInfo.cues = [];\n segmentInfo.timestampmap = {\n MPEGTS: 0,\n LOCAL: 0\n };\n parser.oncue = segmentInfo.cues.push.bind(segmentInfo.cues);\n\n parser.ontimestampmap = function (map) {\n return segmentInfo.timestampmap = map;\n };\n\n parser.onparsingerror = function (error) {\n videojs$1.log.warn('Error encountered when parsing cues: ' + error.message);\n };\n\n if (segmentInfo.segment.map) {\n var mapData = segmentInfo.segment.map.bytes;\n\n if (decodeBytesToString) {\n mapData = uint8ToUtf8(mapData);\n }\n\n parser.parse(mapData);\n }\n\n var segmentData = segmentInfo.bytes;\n\n if (decodeBytesToString) {\n segmentData = uint8ToUtf8(segmentData);\n }\n\n parser.parse(segmentData);\n parser.flush();\n }\n /**\n * Updates the start and end times of any cues parsed by the WebVTT parser using\n * the information parsed from the X-TIMESTAMP-MAP header and a TS to media time mapping\n * from the SyncController\n *\n * @param {Object} segmentInfo\n * a segment info object that describes the current segment\n * @param {Object} mappingObj\n * object containing a mapping from TS to media time\n * @param {Object} playlist\n * the playlist object containing the segment\n * @private\n */\n\n }, {\n key: 'updateTimeMapping_',\n value: function updateTimeMapping_(segmentInfo, mappingObj, playlist) {\n var segment = segmentInfo.segment;\n\n if (!mappingObj) {\n // If the sync controller does not have a mapping of TS to Media Time for the\n // timeline, then we don't have enough information to update the cue\n // start/end times\n return;\n }\n\n if (!segmentInfo.cues.length) {\n // If there are no cues, we also do not have enough information to figure out\n // segment timing. Mark that the segment contains no cues so we don't re-request\n // an empty segment.\n segment.empty = true;\n return;\n }\n\n var timestampmap = segmentInfo.timestampmap;\n var diff = timestampmap.MPEGTS / 90000 - timestampmap.LOCAL + mappingObj.mapping;\n segmentInfo.cues.forEach(function (cue) {\n // First convert cue time to TS time using the timestamp-map provided within the vtt\n cue.startTime += diff;\n cue.endTime += diff;\n });\n\n if (!playlist.syncInfo) {\n var firstStart = segmentInfo.cues[0].startTime;\n var lastStart = segmentInfo.cues[segmentInfo.cues.length - 1].startTime;\n playlist.syncInfo = {\n mediaSequence: playlist.mediaSequence + segmentInfo.mediaIndex,\n time: Math.min(firstStart, lastStart - segment.duration)\n };\n }\n }\n }]);\n return VTTSegmentLoader;\n}(SegmentLoader);\n/**\n * @file ad-cue-tags.js\n */\n\n/**\n * Searches for an ad cue that overlaps with the given mediaTime\n */\n\n\nvar findAdCue = function findAdCue(track, mediaTime) {\n var cues = track.cues;\n\n for (var i = 0; i < cues.length; i++) {\n var cue = cues[i];\n\n if (mediaTime >= cue.adStartTime && mediaTime <= cue.adEndTime) {\n return cue;\n }\n }\n\n return null;\n};\n\nvar updateAdCues = function updateAdCues(media, track) {\n var offset = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;\n\n if (!media.segments) {\n return;\n }\n\n var mediaTime = offset;\n var cue = void 0;\n\n for (var i = 0; i < media.segments.length; i++) {\n var segment = media.segments[i];\n\n if (!cue) {\n // Since the cues will span for at least the segment duration, adding a fudge\n // factor of half segment duration will prevent duplicate cues from being\n // created when timing info is not exact (e.g. cue start time initialized\n // at 10.006677, but next call mediaTime is 10.003332 )\n cue = findAdCue(track, mediaTime + segment.duration / 2);\n }\n\n if (cue) {\n if ('cueIn' in segment) {\n // Found a CUE-IN so end the cue\n cue.endTime = mediaTime;\n cue.adEndTime = mediaTime;\n mediaTime += segment.duration;\n cue = null;\n continue;\n }\n\n if (mediaTime < cue.endTime) {\n // Already processed this mediaTime for this cue\n mediaTime += segment.duration;\n continue;\n } // otherwise extend cue until a CUE-IN is found\n\n\n cue.endTime += segment.duration;\n } else {\n if ('cueOut' in segment) {\n cue = new window$1.VTTCue(mediaTime, mediaTime + segment.duration, segment.cueOut);\n cue.adStartTime = mediaTime; // Assumes tag format to be\n // #EXT-X-CUE-OUT:30\n\n cue.adEndTime = mediaTime + parseFloat(segment.cueOut);\n track.addCue(cue);\n }\n\n if ('cueOutCont' in segment) {\n // Entered into the middle of an ad cue\n var adOffset = void 0;\n var adTotal = void 0; // Assumes tag formate to be\n // #EXT-X-CUE-OUT-CONT:10/30\n\n var _segment$cueOutCont$s = segment.cueOutCont.split('/').map(parseFloat);\n\n var _segment$cueOutCont$s2 = slicedToArray(_segment$cueOutCont$s, 2);\n\n adOffset = _segment$cueOutCont$s2[0];\n adTotal = _segment$cueOutCont$s2[1];\n cue = new window$1.VTTCue(mediaTime, mediaTime + segment.duration, '');\n cue.adStartTime = mediaTime - adOffset;\n cue.adEndTime = cue.adStartTime + adTotal;\n track.addCue(cue);\n }\n }\n\n mediaTime += segment.duration;\n }\n};\n/**\n * @file sync-controller.js\n */\n\n\nvar tsprobe = tsInspector.inspect;\nvar syncPointStrategies = [// Stategy \"VOD\": Handle the VOD-case where the sync-point is *always*\n// the equivalence display-time 0 === segment-index 0\n{\n name: 'VOD',\n run: function run(syncController, playlist, duration$$1, currentTimeline, currentTime) {\n if (duration$$1 !== Infinity) {\n var syncPoint = {\n time: 0,\n segmentIndex: 0\n };\n return syncPoint;\n }\n\n return null;\n }\n}, // Stategy \"ProgramDateTime\": We have a program-date-time tag in this playlist\n{\n name: 'ProgramDateTime',\n run: function run(syncController, playlist, duration$$1, currentTimeline, currentTime) {\n if (!syncController.datetimeToDisplayTime) {\n return null;\n }\n\n var segments = playlist.segments || [];\n var syncPoint = null;\n var lastDistance = null;\n currentTime = currentTime || 0;\n\n for (var i = 0; i < segments.length; i++) {\n var segment = segments[i];\n\n if (segment.dateTimeObject) {\n var segmentTime = segment.dateTimeObject.getTime() / 1000;\n var segmentStart = segmentTime + syncController.datetimeToDisplayTime;\n var distance = Math.abs(currentTime - segmentStart); // Once the distance begins to increase, we have passed\n // currentTime and can stop looking for better candidates\n\n if (lastDistance !== null && lastDistance < distance) {\n break;\n }\n\n lastDistance = distance;\n syncPoint = {\n time: segmentStart,\n segmentIndex: i\n };\n }\n }\n\n return syncPoint;\n }\n}, // Stategy \"Segment\": We have a known time mapping for a timeline and a\n// segment in the current timeline with timing data\n{\n name: 'Segment',\n run: function run(syncController, playlist, duration$$1, currentTimeline, currentTime) {\n var segments = playlist.segments || [];\n var syncPoint = null;\n var lastDistance = null;\n currentTime = currentTime || 0;\n\n for (var i = 0; i < segments.length; i++) {\n var segment = segments[i];\n\n if (segment.timeline === currentTimeline && typeof segment.start !== 'undefined') {\n var distance = Math.abs(currentTime - segment.start); // Once the distance begins to increase, we have passed\n // currentTime and can stop looking for better candidates\n\n if (lastDistance !== null && lastDistance < distance) {\n break;\n }\n\n if (!syncPoint || lastDistance === null || lastDistance >= distance) {\n lastDistance = distance;\n syncPoint = {\n time: segment.start,\n segmentIndex: i\n };\n }\n }\n }\n\n return syncPoint;\n }\n}, // Stategy \"Discontinuity\": We have a discontinuity with a known\n// display-time\n{\n name: 'Discontinuity',\n run: function run(syncController, playlist, duration$$1, currentTimeline, currentTime) {\n var syncPoint = null;\n currentTime = currentTime || 0;\n\n if (playlist.discontinuityStarts && playlist.discontinuityStarts.length) {\n var lastDistance = null;\n\n for (var i = 0; i < playlist.discontinuityStarts.length; i++) {\n var segmentIndex = playlist.discontinuityStarts[i];\n var discontinuity = playlist.discontinuitySequence + i + 1;\n var discontinuitySync = syncController.discontinuities[discontinuity];\n\n if (discontinuitySync) {\n var distance = Math.abs(currentTime - discontinuitySync.time); // Once the distance begins to increase, we have passed\n // currentTime and can stop looking for better candidates\n\n if (lastDistance !== null && lastDistance < distance) {\n break;\n }\n\n if (!syncPoint || lastDistance === null || lastDistance >= distance) {\n lastDistance = distance;\n syncPoint = {\n time: discontinuitySync.time,\n segmentIndex: segmentIndex\n };\n }\n }\n }\n }\n\n return syncPoint;\n }\n}, // Stategy \"Playlist\": We have a playlist with a known mapping of\n// segment index to display time\n{\n name: 'Playlist',\n run: function run(syncController, playlist, duration$$1, currentTimeline, currentTime) {\n if (playlist.syncInfo) {\n var syncPoint = {\n time: playlist.syncInfo.time,\n segmentIndex: playlist.syncInfo.mediaSequence - playlist.mediaSequence\n };\n return syncPoint;\n }\n\n return null;\n }\n}];\n\nvar SyncController = function (_videojs$EventTarget) {\n inherits(SyncController, _videojs$EventTarget);\n\n function SyncController() {\n classCallCheck(this, SyncController); // Segment Loader state variables...\n // ...for synching across variants\n\n var _this = possibleConstructorReturn(this, (SyncController.__proto__ || Object.getPrototypeOf(SyncController)).call(this));\n\n _this.inspectCache_ = undefined; // ...for synching across variants\n\n _this.timelines = [];\n _this.discontinuities = [];\n _this.datetimeToDisplayTime = null;\n _this.logger_ = logger('SyncController');\n return _this;\n }\n /**\n * Find a sync-point for the playlist specified\n *\n * A sync-point is defined as a known mapping from display-time to\n * a segment-index in the current playlist.\n *\n * @param {Playlist} playlist\n * The playlist that needs a sync-point\n * @param {Number} duration\n * Duration of the MediaSource (Infinite if playing a live source)\n * @param {Number} currentTimeline\n * The last timeline from which a segment was loaded\n * @returns {Object}\n * A sync-point object\n */\n\n\n createClass(SyncController, [{\n key: 'getSyncPoint',\n value: function getSyncPoint(playlist, duration$$1, currentTimeline, currentTime) {\n var syncPoints = this.runStrategies_(playlist, duration$$1, currentTimeline, currentTime);\n\n if (!syncPoints.length) {\n // Signal that we need to attempt to get a sync-point manually\n // by fetching a segment in the playlist and constructing\n // a sync-point from that information\n return null;\n } // Now find the sync-point that is closest to the currentTime because\n // that should result in the most accurate guess about which segment\n // to fetch\n\n\n return this.selectSyncPoint_(syncPoints, {\n key: 'time',\n value: currentTime\n });\n }\n /**\n * Calculate the amount of time that has expired off the playlist during playback\n *\n * @param {Playlist} playlist\n * Playlist object to calculate expired from\n * @param {Number} duration\n * Duration of the MediaSource (Infinity if playling a live source)\n * @returns {Number|null}\n * The amount of time that has expired off the playlist during playback. Null\n * if no sync-points for the playlist can be found.\n */\n\n }, {\n key: 'getExpiredTime',\n value: function getExpiredTime(playlist, duration$$1) {\n if (!playlist || !playlist.segments) {\n return null;\n }\n\n var syncPoints = this.runStrategies_(playlist, duration$$1, playlist.discontinuitySequence, 0); // Without sync-points, there is not enough information to determine the expired time\n\n if (!syncPoints.length) {\n return null;\n }\n\n var syncPoint = this.selectSyncPoint_(syncPoints, {\n key: 'segmentIndex',\n value: 0\n }); // If the sync-point is beyond the start of the playlist, we want to subtract the\n // duration from index 0 to syncPoint.segmentIndex instead of adding.\n\n if (syncPoint.segmentIndex > 0) {\n syncPoint.time *= -1;\n }\n\n return Math.abs(syncPoint.time + sumDurations(playlist, syncPoint.segmentIndex, 0));\n }\n /**\n * Runs each sync-point strategy and returns a list of sync-points returned by the\n * strategies\n *\n * @private\n * @param {Playlist} playlist\n * The playlist that needs a sync-point\n * @param {Number} duration\n * Duration of the MediaSource (Infinity if playing a live source)\n * @param {Number} currentTimeline\n * The last timeline from which a segment was loaded\n * @returns {Array}\n * A list of sync-point objects\n */\n\n }, {\n key: 'runStrategies_',\n value: function runStrategies_(playlist, duration$$1, currentTimeline, currentTime) {\n var syncPoints = []; // Try to find a sync-point in by utilizing various strategies...\n\n for (var i = 0; i < syncPointStrategies.length; i++) {\n var strategy = syncPointStrategies[i];\n var syncPoint = strategy.run(this, playlist, duration$$1, currentTimeline, currentTime);\n\n if (syncPoint) {\n syncPoint.strategy = strategy.name;\n syncPoints.push({\n strategy: strategy.name,\n syncPoint: syncPoint\n });\n }\n }\n\n return syncPoints;\n }\n /**\n * Selects the sync-point nearest the specified target\n *\n * @private\n * @param {Array} syncPoints\n * List of sync-points to select from\n * @param {Object} target\n * Object specifying the property and value we are targeting\n * @param {String} target.key\n * Specifies the property to target. Must be either 'time' or 'segmentIndex'\n * @param {Number} target.value\n * The value to target for the specified key.\n * @returns {Object}\n * The sync-point nearest the target\n */\n\n }, {\n key: 'selectSyncPoint_',\n value: function selectSyncPoint_(syncPoints, target) {\n var bestSyncPoint = syncPoints[0].syncPoint;\n var bestDistance = Math.abs(syncPoints[0].syncPoint[target.key] - target.value);\n var bestStrategy = syncPoints[0].strategy;\n\n for (var i = 1; i < syncPoints.length; i++) {\n var newDistance = Math.abs(syncPoints[i].syncPoint[target.key] - target.value);\n\n if (newDistance < bestDistance) {\n bestDistance = newDistance;\n bestSyncPoint = syncPoints[i].syncPoint;\n bestStrategy = syncPoints[i].strategy;\n }\n }\n\n this.logger_('syncPoint for [' + target.key + ': ' + target.value + '] chosen with strategy' + (' [' + bestStrategy + ']: [time:' + bestSyncPoint.time + ',') + (' segmentIndex:' + bestSyncPoint.segmentIndex + ']'));\n return bestSyncPoint;\n }\n /**\n * Save any meta-data present on the segments when segments leave\n * the live window to the playlist to allow for synchronization at the\n * playlist level later.\n *\n * @param {Playlist} oldPlaylist - The previous active playlist\n * @param {Playlist} newPlaylist - The updated and most current playlist\n */\n\n }, {\n key: 'saveExpiredSegmentInfo',\n value: function saveExpiredSegmentInfo(oldPlaylist, newPlaylist) {\n var mediaSequenceDiff = newPlaylist.mediaSequence - oldPlaylist.mediaSequence; // When a segment expires from the playlist and it has a start time\n // save that information as a possible sync-point reference in future\n\n for (var i = mediaSequenceDiff - 1; i >= 0; i--) {\n var lastRemovedSegment = oldPlaylist.segments[i];\n\n if (lastRemovedSegment && typeof lastRemovedSegment.start !== 'undefined') {\n newPlaylist.syncInfo = {\n mediaSequence: oldPlaylist.mediaSequence + i,\n time: lastRemovedSegment.start\n };\n this.logger_('playlist refresh sync: [time:' + newPlaylist.syncInfo.time + ',' + (' mediaSequence: ' + newPlaylist.syncInfo.mediaSequence + ']'));\n this.trigger('syncinfoupdate');\n break;\n }\n }\n }\n /**\n * Save the mapping from playlist's ProgramDateTime to display. This should\n * only ever happen once at the start of playback.\n *\n * @param {Playlist} playlist - The currently active playlist\n */\n\n }, {\n key: 'setDateTimeMapping',\n value: function setDateTimeMapping(playlist) {\n if (!this.datetimeToDisplayTime && playlist.segments && playlist.segments.length && playlist.segments[0].dateTimeObject) {\n var playlistTimestamp = playlist.segments[0].dateTimeObject.getTime() / 1000;\n this.datetimeToDisplayTime = -playlistTimestamp;\n }\n }\n /**\n * Reset the state of the inspection cache when we do a rendition\n * switch\n */\n\n }, {\n key: 'reset',\n value: function reset() {\n this.inspectCache_ = undefined;\n }\n /**\n * Probe or inspect a fmp4 or an mpeg2-ts segment to determine the start\n * and end of the segment in it's internal \"media time\". Used to generate\n * mappings from that internal \"media time\" to the display time that is\n * shown on the player.\n *\n * @param {SegmentInfo} segmentInfo - The current active request information\n */\n\n }, {\n key: 'probeSegmentInfo',\n value: function probeSegmentInfo(segmentInfo) {\n var segment = segmentInfo.segment;\n var playlist = segmentInfo.playlist;\n var timingInfo = void 0;\n\n if (segment.map) {\n timingInfo = this.probeMp4Segment_(segmentInfo);\n } else {\n timingInfo = this.probeTsSegment_(segmentInfo);\n }\n\n if (timingInfo) {\n if (this.calculateSegmentTimeMapping_(segmentInfo, timingInfo)) {\n this.saveDiscontinuitySyncInfo_(segmentInfo); // If the playlist does not have sync information yet, record that information\n // now with segment timing information\n\n if (!playlist.syncInfo) {\n playlist.syncInfo = {\n mediaSequence: playlist.mediaSequence + segmentInfo.mediaIndex,\n time: segment.start\n };\n }\n }\n }\n\n return timingInfo;\n }\n /**\n * Probe an fmp4 or an mpeg2-ts segment to determine the start of the segment\n * in it's internal \"media time\".\n *\n * @private\n * @param {SegmentInfo} segmentInfo - The current active request information\n * @return {object} The start and end time of the current segment in \"media time\"\n */\n\n }, {\n key: 'probeMp4Segment_',\n value: function probeMp4Segment_(segmentInfo) {\n var segment = segmentInfo.segment;\n var timescales = mp4probe.timescale(segment.map.bytes);\n var startTime = mp4probe.startTime(timescales, segmentInfo.bytes);\n\n if (segmentInfo.timestampOffset !== null) {\n segmentInfo.timestampOffset -= startTime;\n }\n\n return {\n start: startTime,\n end: startTime + segment.duration\n };\n }\n /**\n * Probe an mpeg2-ts segment to determine the start and end of the segment\n * in it's internal \"media time\".\n *\n * @private\n * @param {SegmentInfo} segmentInfo - The current active request information\n * @return {object} The start and end time of the current segment in \"media time\"\n */\n\n }, {\n key: 'probeTsSegment_',\n value: function probeTsSegment_(segmentInfo) {\n var timeInfo = tsprobe(segmentInfo.bytes, this.inspectCache_);\n var segmentStartTime = void 0;\n var segmentEndTime = void 0;\n\n if (!timeInfo) {\n return null;\n }\n\n if (timeInfo.video && timeInfo.video.length === 2) {\n this.inspectCache_ = timeInfo.video[1].dts;\n segmentStartTime = timeInfo.video[0].dtsTime;\n segmentEndTime = timeInfo.video[1].dtsTime;\n } else if (timeInfo.audio && timeInfo.audio.length === 2) {\n this.inspectCache_ = timeInfo.audio[1].dts;\n segmentStartTime = timeInfo.audio[0].dtsTime;\n segmentEndTime = timeInfo.audio[1].dtsTime;\n }\n\n return {\n start: segmentStartTime,\n end: segmentEndTime,\n containsVideo: timeInfo.video && timeInfo.video.length === 2,\n containsAudio: timeInfo.audio && timeInfo.audio.length === 2\n };\n }\n }, {\n key: 'timestampOffsetForTimeline',\n value: function timestampOffsetForTimeline(timeline) {\n if (typeof this.timelines[timeline] === 'undefined') {\n return null;\n }\n\n return this.timelines[timeline].time;\n }\n }, {\n key: 'mappingForTimeline',\n value: function mappingForTimeline(timeline) {\n if (typeof this.timelines[timeline] === 'undefined') {\n return null;\n }\n\n return this.timelines[timeline].mapping;\n }\n /**\n * Use the \"media time\" for a segment to generate a mapping to \"display time\" and\n * save that display time to the segment.\n *\n * @private\n * @param {SegmentInfo} segmentInfo\n * The current active request information\n * @param {object} timingInfo\n * The start and end time of the current segment in \"media time\"\n * @returns {Boolean}\n * Returns false if segment time mapping could not be calculated\n */\n\n }, {\n key: 'calculateSegmentTimeMapping_',\n value: function calculateSegmentTimeMapping_(segmentInfo, timingInfo) {\n var segment = segmentInfo.segment;\n var mappingObj = this.timelines[segmentInfo.timeline];\n\n if (segmentInfo.timestampOffset !== null) {\n mappingObj = {\n time: segmentInfo.startOfSegment,\n mapping: segmentInfo.startOfSegment - timingInfo.start\n };\n this.timelines[segmentInfo.timeline] = mappingObj;\n this.trigger('timestampoffset');\n this.logger_('time mapping for timeline ' + segmentInfo.timeline + ': ' + ('[time: ' + mappingObj.time + '] [mapping: ' + mappingObj.mapping + ']'));\n segment.start = segmentInfo.startOfSegment;\n segment.end = timingInfo.end + mappingObj.mapping;\n } else if (mappingObj) {\n segment.start = timingInfo.start + mappingObj.mapping;\n segment.end = timingInfo.end + mappingObj.mapping;\n } else {\n return false;\n }\n\n return true;\n }\n /**\n * Each time we have discontinuity in the playlist, attempt to calculate the location\n * in display of the start of the discontinuity and save that. We also save an accuracy\n * value so that we save values with the most accuracy (closest to 0.)\n *\n * @private\n * @param {SegmentInfo} segmentInfo - The current active request information\n */\n\n }, {\n key: 'saveDiscontinuitySyncInfo_',\n value: function saveDiscontinuitySyncInfo_(segmentInfo) {\n var playlist = segmentInfo.playlist;\n var segment = segmentInfo.segment; // If the current segment is a discontinuity then we know exactly where\n // the start of the range and it's accuracy is 0 (greater accuracy values\n // mean more approximation)\n\n if (segment.discontinuity) {\n this.discontinuities[segment.timeline] = {\n time: segment.start,\n accuracy: 0\n };\n } else if (playlist.discontinuityStarts && playlist.discontinuityStarts.length) {\n // Search for future discontinuities that we can provide better timing\n // information for and save that information for sync purposes\n for (var i = 0; i < playlist.discontinuityStarts.length; i++) {\n var segmentIndex = playlist.discontinuityStarts[i];\n var discontinuity = playlist.discontinuitySequence + i + 1;\n var mediaIndexDiff = segmentIndex - segmentInfo.mediaIndex;\n var accuracy = Math.abs(mediaIndexDiff);\n\n if (!this.discontinuities[discontinuity] || this.discontinuities[discontinuity].accuracy > accuracy) {\n var time = void 0;\n\n if (mediaIndexDiff < 0) {\n time = segment.start - sumDurations(playlist, segmentInfo.mediaIndex, segmentIndex);\n } else {\n time = segment.end + sumDurations(playlist, segmentInfo.mediaIndex + 1, segmentIndex);\n }\n\n this.discontinuities[discontinuity] = {\n time: time,\n accuracy: accuracy\n };\n }\n }\n }\n }\n }]);\n return SyncController;\n}(videojs$1.EventTarget);\n\nvar Decrypter$1 = new shimWorker(\"./decrypter-worker.worker.js\", function (window, document$$1) {\n var self = this;\n\n var decrypterWorker = function () {\n /*\n * pkcs7.pad\n * https://github.com/brightcove/pkcs7\n *\n * Copyright (c) 2014 Brightcove\n * Licensed under the apache2 license.\n */\n\n /**\n * Returns the subarray of a Uint8Array without PKCS#7 padding.\n * @param padded {Uint8Array} unencrypted bytes that have been padded\n * @return {Uint8Array} the unpadded bytes\n * @see http://tools.ietf.org/html/rfc5652\n */\n function unpad(padded) {\n return padded.subarray(0, padded.byteLength - padded[padded.byteLength - 1]);\n }\n\n var classCallCheck = function classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n };\n\n var createClass = function () {\n function defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n }\n\n return function (Constructor, protoProps, staticProps) {\n if (protoProps) defineProperties(Constructor.prototype, protoProps);\n if (staticProps) defineProperties(Constructor, staticProps);\n return Constructor;\n };\n }();\n\n var inherits = function inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass);\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;\n };\n\n var possibleConstructorReturn = function possibleConstructorReturn(self, call) {\n if (!self) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self;\n };\n /**\n * @file aes.js\n *\n * This file contains an adaptation of the AES decryption algorithm\n * from the Standford Javascript Cryptography Library. That work is\n * covered by the following copyright and permissions notice:\n *\n * Copyright 2009-2010 Emily Stark, Mike Hamburg, Dan Boneh.\n * All rights reserved.\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are\n * met:\n *\n * 1. Redistributions of source code must retain the above copyright\n * notice, this list of conditions and the following disclaimer.\n *\n * 2. Redistributions in binary form must reproduce the above\n * copyright notice, this list of conditions and the following\n * disclaimer in the documentation and/or other materials provided\n * with the distribution.\n *\n * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR\n * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> OR CONTRIBUTORS BE\n * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR\n * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF\n * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR\n * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,\n * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE\n * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN\n * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n *\n * The views and conclusions contained in the software and documentation\n * are those of the authors and should not be interpreted as representing\n * official policies, either expressed or implied, of the authors.\n */\n\n /**\n * Expand the S-box tables.\n *\n * @private\n */\n\n\n var precompute = function precompute() {\n var tables = [[[], [], [], [], []], [[], [], [], [], []]];\n var encTable = tables[0];\n var decTable = tables[1];\n var sbox = encTable[4];\n var sboxInv = decTable[4];\n var i = void 0;\n var x = void 0;\n var xInv = void 0;\n var d = [];\n var th = [];\n var x2 = void 0;\n var x4 = void 0;\n var x8 = void 0;\n var s = void 0;\n var tEnc = void 0;\n var tDec = void 0; // Compute double and third tables\n\n for (i = 0; i < 256; i++) {\n th[(d[i] = i << 1 ^ (i >> 7) * 283) ^ i] = i;\n }\n\n for (x = xInv = 0; !sbox[x]; x ^= x2 || 1, xInv = th[xInv] || 1) {\n // Compute sbox\n s = xInv ^ xInv << 1 ^ xInv << 2 ^ xInv << 3 ^ xInv << 4;\n s = s >> 8 ^ s & 255 ^ 99;\n sbox[x] = s;\n sboxInv[s] = x; // Compute MixColumns\n\n x8 = d[x4 = d[x2 = d[x]]];\n tDec = x8 * 0x1010101 ^ x4 * 0x10001 ^ x2 * 0x101 ^ x * 0x1010100;\n tEnc = d[s] * 0x101 ^ s * 0x1010100;\n\n for (i = 0; i < 4; i++) {\n encTable[i][x] = tEnc = tEnc << 24 ^ tEnc >>> 8;\n decTable[i][s] = tDec = tDec << 24 ^ tDec >>> 8;\n }\n } // Compactify. Considerable speedup on Firefox.\n\n\n for (i = 0; i < 5; i++) {\n encTable[i] = encTable[i].slice(0);\n decTable[i] = decTable[i].slice(0);\n }\n\n return tables;\n };\n\n var aesTables = null;\n /**\n * Schedule out an AES key for both encryption and decryption. This\n * is a low-level class. Use a cipher mode to do bulk encryption.\n *\n * @class AES\n * @param key {Array} The key as an array of 4, 6 or 8 words.\n */\n\n var AES = function () {\n function AES(key) {\n classCallCheck(this, AES);\n /**\n * The expanded S-box and inverse S-box tables. These will be computed\n * on the client so that we don't have to send them down the wire.\n *\n * There are two tables, _tables[0] is for encryption and\n * _tables[1] is for decryption.\n *\n * The first 4 sub-tables are the expanded S-box with MixColumns. The\n * last (_tables[01][4]) is the S-box itself.\n *\n * @private\n */\n // if we have yet to precompute the S-box tables\n // do so now\n\n if (!aesTables) {\n aesTables = precompute();\n } // then make a copy of that object for use\n\n\n this._tables = [[aesTables[0][0].slice(), aesTables[0][1].slice(), aesTables[0][2].slice(), aesTables[0][3].slice(), aesTables[0][4].slice()], [aesTables[1][0].slice(), aesTables[1][1].slice(), aesTables[1][2].slice(), aesTables[1][3].slice(), aesTables[1][4].slice()]];\n var i = void 0;\n var j = void 0;\n var tmp = void 0;\n var encKey = void 0;\n var decKey = void 0;\n var sbox = this._tables[0][4];\n var decTable = this._tables[1];\n var keyLen = key.length;\n var rcon = 1;\n\n if (keyLen !== 4 && keyLen !== 6 && keyLen !== 8) {\n throw new Error('Invalid aes key size');\n }\n\n encKey = key.slice(0);\n decKey = [];\n this._key = [encKey, decKey]; // schedule encryption keys\n\n for (i = keyLen; i < 4 * keyLen + 28; i++) {\n tmp = encKey[i - 1]; // apply sbox\n\n if (i % keyLen === 0 || keyLen === 8 && i % keyLen === 4) {\n tmp = sbox[tmp >>> 24] << 24 ^ sbox[tmp >> 16 & 255] << 16 ^ sbox[tmp >> 8 & 255] << 8 ^ sbox[tmp & 255]; // shift rows and add rcon\n\n if (i % keyLen === 0) {\n tmp = tmp << 8 ^ tmp >>> 24 ^ rcon << 24;\n rcon = rcon << 1 ^ (rcon >> 7) * 283;\n }\n }\n\n encKey[i] = encKey[i - keyLen] ^ tmp;\n } // schedule decryption keys\n\n\n for (j = 0; i; j++, i--) {\n tmp = encKey[j & 3 ? i : i - 4];\n\n if (i <= 4 || j < 4) {\n decKey[j] = tmp;\n } else {\n decKey[j] = decTable[0][sbox[tmp >>> 24]] ^ decTable[1][sbox[tmp >> 16 & 255]] ^ decTable[2][sbox[tmp >> 8 & 255]] ^ decTable[3][sbox[tmp & 255]];\n }\n }\n }\n /**\n * Decrypt 16 bytes, specified as four 32-bit words.\n *\n * @param {Number} encrypted0 the first word to decrypt\n * @param {Number} encrypted1 the second word to decrypt\n * @param {Number} encrypted2 the third word to decrypt\n * @param {Number} encrypted3 the fourth word to decrypt\n * @param {Int32Array} out the array to write the decrypted words\n * into\n * @param {Number} offset the offset into the output array to start\n * writing results\n * @return {Array} The plaintext.\n */\n\n\n AES.prototype.decrypt = function decrypt$$1(encrypted0, encrypted1, encrypted2, encrypted3, out, offset) {\n var key = this._key[1]; // state variables a,b,c,d are loaded with pre-whitened data\n\n var a = encrypted0 ^ key[0];\n var b = encrypted3 ^ key[1];\n var c = encrypted2 ^ key[2];\n var d = encrypted1 ^ key[3];\n var a2 = void 0;\n var b2 = void 0;\n var c2 = void 0; // key.length === 2 ?\n\n var nInnerRounds = key.length / 4 - 2;\n var i = void 0;\n var kIndex = 4;\n var table = this._tables[1]; // load up the tables\n\n var table0 = table[0];\n var table1 = table[1];\n var table2 = table[2];\n var table3 = table[3];\n var sbox = table[4]; // Inner rounds. Cribbed from OpenSSL.\n\n for (i = 0; i < nInnerRounds; i++) {\n a2 = table0[a >>> 24] ^ table1[b >> 16 & 255] ^ table2[c >> 8 & 255] ^ table3[d & 255] ^ key[kIndex];\n b2 = table0[b >>> 24] ^ table1[c >> 16 & 255] ^ table2[d >> 8 & 255] ^ table3[a & 255] ^ key[kIndex + 1];\n c2 = table0[c >>> 24] ^ table1[d >> 16 & 255] ^ table2[a >> 8 & 255] ^ table3[b & 255] ^ key[kIndex + 2];\n d = table0[d >>> 24] ^ table1[a >> 16 & 255] ^ table2[b >> 8 & 255] ^ table3[c & 255] ^ key[kIndex + 3];\n kIndex += 4;\n a = a2;\n b = b2;\n c = c2;\n } // Last round.\n\n\n for (i = 0; i < 4; i++) {\n out[(3 & -i) + offset] = sbox[a >>> 24] << 24 ^ sbox[b >> 16 & 255] << 16 ^ sbox[c >> 8 & 255] << 8 ^ sbox[d & 255] ^ key[kIndex++];\n a2 = a;\n a = b;\n b = c;\n c = d;\n d = a2;\n }\n };\n\n return AES;\n }();\n /**\n * @file stream.js\n */\n\n /**\n * A lightweight readable stream implemention that handles event dispatching.\n *\n * @class Stream\n */\n\n\n var Stream = function () {\n function Stream() {\n classCallCheck(this, Stream);\n this.listeners = {};\n }\n /**\n * Add a listener for a specified event type.\n *\n * @param {String} type the event name\n * @param {Function} listener the callback to be invoked when an event of\n * the specified type occurs\n */\n\n\n Stream.prototype.on = function on(type, listener) {\n if (!this.listeners[type]) {\n this.listeners[type] = [];\n }\n\n this.listeners[type].push(listener);\n };\n /**\n * Remove a listener for a specified event type.\n *\n * @param {String} type the event name\n * @param {Function} listener a function previously registered for this\n * type of event through `on`\n * @return {Boolean} if we could turn it off or not\n */\n\n\n Stream.prototype.off = function off(type, listener) {\n if (!this.listeners[type]) {\n return false;\n }\n\n var index = this.listeners[type].indexOf(listener);\n this.listeners[type].splice(index, 1);\n return index > -1;\n };\n /**\n * Trigger an event of the specified type on this stream. Any additional\n * arguments to this function are passed as parameters to event listeners.\n *\n * @param {String} type the event name\n */\n\n\n Stream.prototype.trigger = function trigger(type) {\n var callbacks = this.listeners[type];\n\n if (!callbacks) {\n return;\n } // Slicing the arguments on every invocation of this method\n // can add a significant amount of overhead. Avoid the\n // intermediate object creation for the common case of a\n // single callback argument\n\n\n if (arguments.length === 2) {\n var length = callbacks.length;\n\n for (var i = 0; i < length; ++i) {\n callbacks[i].call(this, arguments[1]);\n }\n } else {\n var args = Array.prototype.slice.call(arguments, 1);\n var _length = callbacks.length;\n\n for (var _i = 0; _i < _length; ++_i) {\n callbacks[_i].apply(this, args);\n }\n }\n };\n /**\n * Destroys the stream and cleans up.\n */\n\n\n Stream.prototype.dispose = function dispose() {\n this.listeners = {};\n };\n /**\n * Forwards all `data` events on this stream to the destination stream. The\n * destination stream should provide a method `push` to receive the data\n * events as they arrive.\n *\n * @param {Stream} destination the stream that will receive all `data` events\n * @see http://nodejs.org/api/stream.html#stream_readable_pipe_destination_options\n */\n\n\n Stream.prototype.pipe = function pipe(destination) {\n this.on('data', function (data) {\n destination.push(data);\n });\n };\n\n return Stream;\n }();\n /**\n * @file async-stream.js\n */\n\n /**\n * A wrapper around the Stream class to use setTiemout\n * and run stream \"jobs\" Asynchronously\n *\n * @class AsyncStream\n * @extends Stream\n */\n\n\n var AsyncStream$$1 = function (_Stream) {\n inherits(AsyncStream$$1, _Stream);\n\n function AsyncStream$$1() {\n classCallCheck(this, AsyncStream$$1);\n\n var _this = possibleConstructorReturn(this, _Stream.call(this, Stream));\n\n _this.jobs = [];\n _this.delay = 1;\n _this.timeout_ = null;\n return _this;\n }\n /**\n * process an async job\n *\n * @private\n */\n\n\n AsyncStream$$1.prototype.processJob_ = function processJob_() {\n this.jobs.shift()();\n\n if (this.jobs.length) {\n this.timeout_ = setTimeout(this.processJob_.bind(this), this.delay);\n } else {\n this.timeout_ = null;\n }\n };\n /**\n * push a job into the stream\n *\n * @param {Function} job the job to push into the stream\n */\n\n\n AsyncStream$$1.prototype.push = function push(job) {\n this.jobs.push(job);\n\n if (!this.timeout_) {\n this.timeout_ = setTimeout(this.processJob_.bind(this), this.delay);\n }\n };\n\n return AsyncStream$$1;\n }(Stream);\n /**\n * @file decrypter.js\n *\n * An asynchronous implementation of AES-128 CBC decryption with\n * PKCS#7 padding.\n */\n\n /**\n * Convert network-order (big-endian) bytes into their little-endian\n * representation.\n */\n\n\n var ntoh = function ntoh(word) {\n return word << 24 | (word & 0xff00) << 8 | (word & 0xff0000) >> 8 | word >>> 24;\n };\n /**\n * Decrypt bytes using AES-128 with CBC and PKCS#7 padding.\n *\n * @param {Uint8Array} encrypted the encrypted bytes\n * @param {Uint32Array} key the bytes of the decryption key\n * @param {Uint32Array} initVector the initialization vector (IV) to\n * use for the first round of CBC.\n * @return {Uint8Array} the decrypted bytes\n *\n * @see http://en.wikipedia.org/wiki/Advanced_Encryption_Standard\n * @see http://en.wikipedia.org/wiki/Block_cipher_mode_of_operation#Cipher_Block_Chaining_.28CBC.29\n * @see https://tools.ietf.org/html/rfc2315\n */\n\n\n var decrypt$$1 = function decrypt$$1(encrypted, key, initVector) {\n // word-level access to the encrypted bytes\n var encrypted32 = new Int32Array(encrypted.buffer, encrypted.byteOffset, encrypted.byteLength >> 2);\n var decipher = new AES(Array.prototype.slice.call(key)); // byte and word-level access for the decrypted output\n\n var decrypted = new Uint8Array(encrypted.byteLength);\n var decrypted32 = new Int32Array(decrypted.buffer); // temporary variables for working with the IV, encrypted, and\n // decrypted data\n\n var init0 = void 0;\n var init1 = void 0;\n var init2 = void 0;\n var init3 = void 0;\n var encrypted0 = void 0;\n var encrypted1 = void 0;\n var encrypted2 = void 0;\n var encrypted3 = void 0; // iteration variable\n\n var wordIx = void 0; // pull out the words of the IV to ensure we don't modify the\n // passed-in reference and easier access\n\n init0 = initVector[0];\n init1 = initVector[1];\n init2 = initVector[2];\n init3 = initVector[3]; // decrypt four word sequences, applying cipher-block chaining (CBC)\n // to each decrypted block\n\n for (wordIx = 0; wordIx < encrypted32.length; wordIx += 4) {\n // convert big-endian (network order) words into little-endian\n // (javascript order)\n encrypted0 = ntoh(encrypted32[wordIx]);\n encrypted1 = ntoh(encrypted32[wordIx + 1]);\n encrypted2 = ntoh(encrypted32[wordIx + 2]);\n encrypted3 = ntoh(encrypted32[wordIx + 3]); // decrypt the block\n\n decipher.decrypt(encrypted0, encrypted1, encrypted2, encrypted3, decrypted32, wordIx); // XOR with the IV, and restore network byte-order to obtain the\n // plaintext\n\n decrypted32[wordIx] = ntoh(decrypted32[wordIx] ^ init0);\n decrypted32[wordIx + 1] = ntoh(decrypted32[wordIx + 1] ^ init1);\n decrypted32[wordIx + 2] = ntoh(decrypted32[wordIx + 2] ^ init2);\n decrypted32[wordIx + 3] = ntoh(decrypted32[wordIx + 3] ^ init3); // setup the IV for the next round\n\n init0 = encrypted0;\n init1 = encrypted1;\n init2 = encrypted2;\n init3 = encrypted3;\n }\n\n return decrypted;\n };\n /**\n * The `Decrypter` class that manages decryption of AES\n * data through `AsyncStream` objects and the `decrypt`\n * function\n *\n * @param {Uint8Array} encrypted the encrypted bytes\n * @param {Uint32Array} key the bytes of the decryption key\n * @param {Uint32Array} initVector the initialization vector (IV) to\n * @param {Function} done the function to run when done\n * @class Decrypter\n */\n\n\n var Decrypter$$1 = function () {\n function Decrypter$$1(encrypted, key, initVector, done) {\n classCallCheck(this, Decrypter$$1);\n var step = Decrypter$$1.STEP;\n var encrypted32 = new Int32Array(encrypted.buffer);\n var decrypted = new Uint8Array(encrypted.byteLength);\n var i = 0;\n this.asyncStream_ = new AsyncStream$$1(); // split up the encryption job and do the individual chunks asynchronously\n\n this.asyncStream_.push(this.decryptChunk_(encrypted32.subarray(i, i + step), key, initVector, decrypted));\n\n for (i = step; i < encrypted32.length; i += step) {\n initVector = new Uint32Array([ntoh(encrypted32[i - 4]), ntoh(encrypted32[i - 3]), ntoh(encrypted32[i - 2]), ntoh(encrypted32[i - 1])]);\n this.asyncStream_.push(this.decryptChunk_(encrypted32.subarray(i, i + step), key, initVector, decrypted));\n } // invoke the done() callback when everything is finished\n\n\n this.asyncStream_.push(function () {\n // remove pkcs#7 padding from the decrypted bytes\n done(null, unpad(decrypted));\n });\n }\n /**\n * a getter for step the maximum number of bytes to process at one time\n *\n * @return {Number} the value of step 32000\n */\n\n /**\n * @private\n */\n\n\n Decrypter$$1.prototype.decryptChunk_ = function decryptChunk_(encrypted, key, initVector, decrypted) {\n return function () {\n var bytes = decrypt$$1(encrypted, key, initVector);\n decrypted.set(bytes, encrypted.byteOffset);\n };\n };\n\n createClass(Decrypter$$1, null, [{\n key: 'STEP',\n get: function get$$1() {\n // 4 * 8000;\n return 32000;\n }\n }]);\n return Decrypter$$1;\n }();\n /**\n * @file bin-utils.js\n */\n\n /**\n * Creates an object for sending to a web worker modifying properties that are TypedArrays\n * into a new object with seperated properties for the buffer, byteOffset, and byteLength.\n *\n * @param {Object} message\n * Object of properties and values to send to the web worker\n * @return {Object}\n * Modified message with TypedArray values expanded\n * @function createTransferableMessage\n */\n\n\n var createTransferableMessage = function createTransferableMessage(message) {\n var transferable = {};\n Object.keys(message).forEach(function (key) {\n var value = message[key];\n\n if (ArrayBuffer.isView(value)) {\n transferable[key] = {\n bytes: value.buffer,\n byteOffset: value.byteOffset,\n byteLength: value.byteLength\n };\n } else {\n transferable[key] = value;\n }\n });\n return transferable;\n };\n /**\n * Our web worker interface so that things can talk to aes-decrypter\n * that will be running in a web worker. the scope is passed to this by\n * webworkify.\n *\n * @param {Object} self\n * the scope for the web worker\n */\n\n\n var DecrypterWorker = function DecrypterWorker(self) {\n self.onmessage = function (event) {\n var data = event.data;\n var encrypted = new Uint8Array(data.encrypted.bytes, data.encrypted.byteOffset, data.encrypted.byteLength);\n var key = new Uint32Array(data.key.bytes, data.key.byteOffset, data.key.byteLength / 4);\n var iv = new Uint32Array(data.iv.bytes, data.iv.byteOffset, data.iv.byteLength / 4);\n /* eslint-disable no-new, handle-callback-err */\n\n new Decrypter$$1(encrypted, key, iv, function (err, bytes) {\n self.postMessage(createTransferableMessage({\n source: data.source,\n decrypted: bytes\n }), [bytes.buffer]);\n });\n /* eslint-enable */\n };\n };\n\n var decrypterWorker = new DecrypterWorker(self);\n return decrypterWorker;\n }();\n});\n/**\n * Convert the properties of an HLS track into an audioTrackKind.\n *\n * @private\n */\n\nvar audioTrackKind_ = function audioTrackKind_(properties) {\n var kind = properties.default ? 'main' : 'alternative';\n\n if (properties.characteristics && properties.characteristics.indexOf('public.accessibility.describes-video') >= 0) {\n kind = 'main-desc';\n }\n\n return kind;\n};\n/**\n * Pause provided segment loader and playlist loader if active\n *\n * @param {SegmentLoader} segmentLoader\n * SegmentLoader to pause\n * @param {Object} mediaType\n * Active media type\n * @function stopLoaders\n */\n\n\nvar stopLoaders = function stopLoaders(segmentLoader, mediaType) {\n segmentLoader.abort();\n segmentLoader.pause();\n\n if (mediaType && mediaType.activePlaylistLoader) {\n mediaType.activePlaylistLoader.pause();\n mediaType.activePlaylistLoader = null;\n }\n};\n/**\n * Start loading provided segment loader and playlist loader\n *\n * @param {PlaylistLoader} playlistLoader\n * PlaylistLoader to start loading\n * @param {Object} mediaType\n * Active media type\n * @function startLoaders\n */\n\n\nvar startLoaders = function startLoaders(playlistLoader, mediaType) {\n // Segment loader will be started after `loadedmetadata` or `loadedplaylist` from the\n // playlist loader\n mediaType.activePlaylistLoader = playlistLoader;\n playlistLoader.load();\n};\n/**\n * Returns a function to be called when the media group changes. It performs a\n * non-destructive (preserve the buffer) resync of the SegmentLoader. This is because a\n * change of group is merely a rendition switch of the same content at another encoding,\n * rather than a change of content, such as switching audio from English to Spanish.\n *\n * @param {String} type\n * MediaGroup type\n * @param {Object} settings\n * Object containing required information for media groups\n * @return {Function}\n * Handler for a non-destructive resync of SegmentLoader when the active media\n * group changes.\n * @function onGroupChanged\n */\n\n\nvar onGroupChanged = function onGroupChanged(type, settings) {\n return function () {\n var _settings$segmentLoad = settings.segmentLoaders,\n segmentLoader = _settings$segmentLoad[type],\n mainSegmentLoader = _settings$segmentLoad.main,\n mediaType = settings.mediaTypes[type];\n var activeTrack = mediaType.activeTrack();\n var activeGroup = mediaType.activeGroup(activeTrack);\n var previousActiveLoader = mediaType.activePlaylistLoader;\n stopLoaders(segmentLoader, mediaType);\n\n if (!activeGroup) {\n // there is no group active\n return;\n }\n\n if (!activeGroup.playlistLoader) {\n if (previousActiveLoader) {\n // The previous group had a playlist loader but the new active group does not\n // this means we are switching from demuxed to muxed audio. In this case we want to\n // do a destructive reset of the main segment loader and not restart the audio\n // loaders.\n mainSegmentLoader.resetEverything();\n }\n\n return;\n } // Non-destructive resync\n\n\n segmentLoader.resyncLoader();\n startLoaders(activeGroup.playlistLoader, mediaType);\n };\n};\n/**\n * Returns a function to be called when the media track changes. It performs a\n * destructive reset of the SegmentLoader to ensure we start loading as close to\n * currentTime as possible.\n *\n * @param {String} type\n * MediaGroup type\n * @param {Object} settings\n * Object containing required information for media groups\n * @return {Function}\n * Handler for a destructive reset of SegmentLoader when the active media\n * track changes.\n * @function onTrackChanged\n */\n\n\nvar onTrackChanged = function onTrackChanged(type, settings) {\n return function () {\n var _settings$segmentLoad2 = settings.segmentLoaders,\n segmentLoader = _settings$segmentLoad2[type],\n mainSegmentLoader = _settings$segmentLoad2.main,\n mediaType = settings.mediaTypes[type];\n var activeTrack = mediaType.activeTrack();\n var activeGroup = mediaType.activeGroup(activeTrack);\n var previousActiveLoader = mediaType.activePlaylistLoader;\n stopLoaders(segmentLoader, mediaType);\n\n if (!activeGroup) {\n // there is no group active so we do not want to restart loaders\n return;\n }\n\n if (!activeGroup.playlistLoader) {\n // when switching from demuxed audio/video to muxed audio/video (noted by no playlist\n // loader for the audio group), we want to do a destructive reset of the main segment\n // loader and not restart the audio loaders\n mainSegmentLoader.resetEverything();\n return;\n }\n\n if (previousActiveLoader === activeGroup.playlistLoader) {\n // Nothing has actually changed. This can happen because track change events can fire\n // multiple times for a \"single\" change. One for enabling the new active track, and\n // one for disabling the track that was active\n startLoaders(activeGroup.playlistLoader, mediaType);\n return;\n }\n\n if (segmentLoader.track) {\n // For WebVTT, set the new text track in the segmentloader\n segmentLoader.track(activeTrack);\n } // destructive reset\n\n\n segmentLoader.resetEverything();\n startLoaders(activeGroup.playlistLoader, mediaType);\n };\n};\n\nvar onError = {\n /**\n * Returns a function to be called when a SegmentLoader or PlaylistLoader encounters\n * an error.\n *\n * @param {String} type\n * MediaGroup type\n * @param {Object} settings\n * Object containing required information for media groups\n * @return {Function}\n * Error handler. Logs warning (or error if the playlist is blacklisted) to\n * console and switches back to default audio track.\n * @function onError.AUDIO\n */\n AUDIO: function AUDIO(type, settings) {\n return function () {\n var segmentLoader = settings.segmentLoaders[type],\n mediaType = settings.mediaTypes[type],\n blacklistCurrentPlaylist = settings.blacklistCurrentPlaylist;\n stopLoaders(segmentLoader, mediaType); // switch back to default audio track\n\n var activeTrack = mediaType.activeTrack();\n var activeGroup = mediaType.activeGroup();\n var id = (activeGroup.filter(function (group) {\n return group.default;\n })[0] || activeGroup[0]).id;\n var defaultTrack = mediaType.tracks[id];\n\n if (activeTrack === defaultTrack) {\n // Default track encountered an error. All we can do now is blacklist the current\n // rendition and hope another will switch audio groups\n blacklistCurrentPlaylist({\n message: 'Problem encountered loading the default audio track.'\n });\n return;\n }\n\n videojs$1.log.warn('Problem encountered loading the alternate audio track.' + 'Switching back to default.');\n\n for (var trackId in mediaType.tracks) {\n mediaType.tracks[trackId].enabled = mediaType.tracks[trackId] === defaultTrack;\n }\n\n mediaType.onTrackChanged();\n };\n },\n\n /**\n * Returns a function to be called when a SegmentLoader or PlaylistLoader encounters\n * an error.\n *\n * @param {String} type\n * MediaGroup type\n * @param {Object} settings\n * Object containing required information for media groups\n * @return {Function}\n * Error handler. Logs warning to console and disables the active subtitle track\n * @function onError.SUBTITLES\n */\n SUBTITLES: function SUBTITLES(type, settings) {\n return function () {\n var segmentLoader = settings.segmentLoaders[type],\n mediaType = settings.mediaTypes[type];\n videojs$1.log.warn('Problem encountered loading the subtitle track.' + 'Disabling subtitle track.');\n stopLoaders(segmentLoader, mediaType);\n var track = mediaType.activeTrack();\n\n if (track) {\n track.mode = 'disabled';\n }\n\n mediaType.onTrackChanged();\n };\n }\n};\nvar setupListeners = {\n /**\n * Setup event listeners for audio playlist loader\n *\n * @param {String} type\n * MediaGroup type\n * @param {PlaylistLoader|null} playlistLoader\n * PlaylistLoader to register listeners on\n * @param {Object} settings\n * Object containing required information for media groups\n * @function setupListeners.AUDIO\n */\n AUDIO: function AUDIO(type, playlistLoader, settings) {\n if (!playlistLoader) {\n // no playlist loader means audio will be muxed with the video\n return;\n }\n\n var tech = settings.tech,\n requestOptions = settings.requestOptions,\n segmentLoader = settings.segmentLoaders[type];\n playlistLoader.on('loadedmetadata', function () {\n var media = playlistLoader.media();\n segmentLoader.playlist(media, requestOptions); // if the video is already playing, or if this isn't a live video and preload\n // permits, start downloading segments\n\n if (!tech.paused() || media.endList && tech.preload() !== 'none') {\n segmentLoader.load();\n }\n });\n playlistLoader.on('loadedplaylist', function () {\n segmentLoader.playlist(playlistLoader.media(), requestOptions); // If the player isn't paused, ensure that the segment loader is running\n\n if (!tech.paused()) {\n segmentLoader.load();\n }\n });\n playlistLoader.on('error', onError[type](type, settings));\n },\n\n /**\n * Setup event listeners for subtitle playlist loader\n *\n * @param {String} type\n * MediaGroup type\n * @param {PlaylistLoader|null} playlistLoader\n * PlaylistLoader to register listeners on\n * @param {Object} settings\n * Object containing required information for media groups\n * @function setupListeners.SUBTITLES\n */\n SUBTITLES: function SUBTITLES(type, playlistLoader, settings) {\n var tech = settings.tech,\n requestOptions = settings.requestOptions,\n segmentLoader = settings.segmentLoaders[type],\n mediaType = settings.mediaTypes[type];\n playlistLoader.on('loadedmetadata', function () {\n var media = playlistLoader.media();\n segmentLoader.playlist(media, requestOptions);\n segmentLoader.track(mediaType.activeTrack()); // if the video is already playing, or if this isn't a live video and preload\n // permits, start downloading segments\n\n if (!tech.paused() || media.endList && tech.preload() !== 'none') {\n segmentLoader.load();\n }\n });\n playlistLoader.on('loadedplaylist', function () {\n segmentLoader.playlist(playlistLoader.media(), requestOptions); // If the player isn't paused, ensure that the segment loader is running\n\n if (!tech.paused()) {\n segmentLoader.load();\n }\n });\n playlistLoader.on('error', onError[type](type, settings));\n }\n};\n\nvar byGroupId = function byGroupId(type, groupId) {\n return function (playlist) {\n return playlist.attributes[type] === groupId;\n };\n};\n\nvar byResolvedUri = function byResolvedUri(resolvedUri) {\n return function (playlist) {\n return playlist.resolvedUri === resolvedUri;\n };\n};\n\nvar initialize = {\n /**\n * Setup PlaylistLoaders and AudioTracks for the audio groups\n *\n * @param {String} type\n * MediaGroup type\n * @param {Object} settings\n * Object containing required information for media groups\n * @function initialize.AUDIO\n */\n 'AUDIO': function AUDIO(type, settings) {\n var hls = settings.hls,\n sourceType = settings.sourceType,\n segmentLoader = settings.segmentLoaders[type],\n withCredentials = settings.requestOptions.withCredentials,\n _settings$master = settings.master,\n mediaGroups = _settings$master.mediaGroups,\n playlists = _settings$master.playlists,\n _settings$mediaTypes$ = settings.mediaTypes[type],\n groups = _settings$mediaTypes$.groups,\n tracks = _settings$mediaTypes$.tracks,\n masterPlaylistLoader = settings.masterPlaylistLoader; // force a default if we have none\n\n if (!mediaGroups[type] || Object.keys(mediaGroups[type]).length === 0) {\n mediaGroups[type] = {\n main: {\n default: {\n default: true\n }\n }\n };\n }\n\n for (var groupId in mediaGroups[type]) {\n if (!groups[groupId]) {\n groups[groupId] = [];\n } // List of playlists that have an AUDIO attribute value matching the current\n // group ID\n\n\n var groupPlaylists = playlists.filter(byGroupId(type, groupId));\n\n for (var variantLabel in mediaGroups[type][groupId]) {\n var properties = mediaGroups[type][groupId][variantLabel]; // List of playlists for the current group ID that have a matching uri with\n // this alternate audio variant\n\n var matchingPlaylists = groupPlaylists.filter(byResolvedUri(properties.resolvedUri));\n\n if (matchingPlaylists.length) {\n // If there is a playlist that has the same uri as this audio variant, assume\n // that the playlist is audio only. We delete the resolvedUri property here\n // to prevent a playlist loader from being created so that we don't have\n // both the main and audio segment loaders loading the same audio segments\n // from the same playlist.\n delete properties.resolvedUri;\n }\n\n var playlistLoader = void 0;\n\n if (properties.resolvedUri) {\n playlistLoader = new PlaylistLoader(properties.resolvedUri, hls, withCredentials);\n } else if (properties.playlists && sourceType === 'dash') {\n playlistLoader = new DashPlaylistLoader(properties.playlists[0], hls, withCredentials, masterPlaylistLoader);\n } else {\n // no resolvedUri means the audio is muxed with the video when using this\n // audio track\n playlistLoader = null;\n }\n\n properties = videojs$1.mergeOptions({\n id: variantLabel,\n playlistLoader: playlistLoader\n }, properties);\n setupListeners[type](type, properties.playlistLoader, settings);\n groups[groupId].push(properties);\n\n if (typeof tracks[variantLabel] === 'undefined') {\n var track = new videojs$1.AudioTrack({\n id: variantLabel,\n kind: audioTrackKind_(properties),\n enabled: false,\n language: properties.language,\n default: properties.default,\n label: variantLabel\n });\n tracks[variantLabel] = track;\n }\n }\n } // setup single error event handler for the segment loader\n\n\n segmentLoader.on('error', onError[type](type, settings));\n },\n\n /**\n * Setup PlaylistLoaders and TextTracks for the subtitle groups\n *\n * @param {String} type\n * MediaGroup type\n * @param {Object} settings\n * Object containing required information for media groups\n * @function initialize.SUBTITLES\n */\n 'SUBTITLES': function SUBTITLES(type, settings) {\n var tech = settings.tech,\n hls = settings.hls,\n sourceType = settings.sourceType,\n segmentLoader = settings.segmentLoaders[type],\n withCredentials = settings.requestOptions.withCredentials,\n mediaGroups = settings.master.mediaGroups,\n _settings$mediaTypes$2 = settings.mediaTypes[type],\n groups = _settings$mediaTypes$2.groups,\n tracks = _settings$mediaTypes$2.tracks,\n masterPlaylistLoader = settings.masterPlaylistLoader;\n\n for (var groupId in mediaGroups[type]) {\n if (!groups[groupId]) {\n groups[groupId] = [];\n }\n\n for (var variantLabel in mediaGroups[type][groupId]) {\n if (mediaGroups[type][groupId][variantLabel].forced) {\n // Subtitle playlists with the forced attribute are not selectable in Safari.\n // According to Apple's HLS Authoring Specification:\n // If content has forced subtitles and regular subtitles in a given language,\n // the regular subtitles track in that language MUST contain both the forced\n // subtitles and the regular subtitles for that language.\n // Because of this requirement and that Safari does not add forced subtitles,\n // forced subtitles are skipped here to maintain consistent experience across\n // all platforms\n continue;\n }\n\n var properties = mediaGroups[type][groupId][variantLabel];\n var playlistLoader = void 0;\n\n if (sourceType === 'hls') {\n playlistLoader = new PlaylistLoader(properties.resolvedUri, hls, withCredentials);\n } else if (sourceType === 'dash') {\n playlistLoader = new DashPlaylistLoader(properties.playlists[0], hls, withCredentials, masterPlaylistLoader);\n }\n\n properties = videojs$1.mergeOptions({\n id: variantLabel,\n playlistLoader: playlistLoader\n }, properties);\n setupListeners[type](type, properties.playlistLoader, settings);\n groups[groupId].push(properties);\n\n if (typeof tracks[variantLabel] === 'undefined') {\n var track = tech.addRemoteTextTrack({\n id: variantLabel,\n kind: 'subtitles',\n default: properties.default && properties.autoselect,\n language: properties.language,\n label: variantLabel\n }, false).track;\n tracks[variantLabel] = track;\n }\n }\n } // setup single error event handler for the segment loader\n\n\n segmentLoader.on('error', onError[type](type, settings));\n },\n\n /**\n * Setup TextTracks for the closed-caption groups\n *\n * @param {String} type\n * MediaGroup type\n * @param {Object} settings\n * Object containing required information for media groups\n * @function initialize['CLOSED-CAPTIONS']\n */\n 'CLOSED-CAPTIONS': function CLOSEDCAPTIONS(type, settings) {\n var tech = settings.tech,\n mediaGroups = settings.master.mediaGroups,\n _settings$mediaTypes$3 = settings.mediaTypes[type],\n groups = _settings$mediaTypes$3.groups,\n tracks = _settings$mediaTypes$3.tracks;\n\n for (var groupId in mediaGroups[type]) {\n if (!groups[groupId]) {\n groups[groupId] = [];\n }\n\n for (var variantLabel in mediaGroups[type][groupId]) {\n var properties = mediaGroups[type][groupId][variantLabel]; // We only support CEA608 captions for now, so ignore anything that\n // doesn't use a CCx INSTREAM-ID\n\n if (!properties.instreamId.match(/CC\\d/)) {\n continue;\n } // No PlaylistLoader is required for Closed-Captions because the captions are\n // embedded within the video stream\n\n\n groups[groupId].push(videojs$1.mergeOptions({\n id: variantLabel\n }, properties));\n\n if (typeof tracks[variantLabel] === 'undefined') {\n var track = tech.addRemoteTextTrack({\n id: properties.instreamId,\n kind: 'captions',\n default: properties.default && properties.autoselect,\n language: properties.language,\n label: variantLabel\n }, false).track;\n tracks[variantLabel] = track;\n }\n }\n }\n }\n};\n/**\n * Returns a function used to get the active group of the provided type\n *\n * @param {String} type\n * MediaGroup type\n * @param {Object} settings\n * Object containing required information for media groups\n * @return {Function}\n * Function that returns the active media group for the provided type. Takes an\n * optional parameter {TextTrack} track. If no track is provided, a list of all\n * variants in the group, otherwise the variant corresponding to the provided\n * track is returned.\n * @function activeGroup\n */\n\nvar activeGroup = function activeGroup(type, settings) {\n return function (track) {\n var masterPlaylistLoader = settings.masterPlaylistLoader,\n groups = settings.mediaTypes[type].groups;\n var media = masterPlaylistLoader.media();\n\n if (!media) {\n return null;\n }\n\n var variants = null;\n\n if (media.attributes[type]) {\n variants = groups[media.attributes[type]];\n }\n\n variants = variants || groups.main;\n\n if (typeof track === 'undefined') {\n return variants;\n }\n\n if (track === null) {\n // An active track was specified so a corresponding group is expected. track === null\n // means no track is currently active so there is no corresponding group\n return null;\n }\n\n return variants.filter(function (props) {\n return props.id === track.id;\n })[0] || null;\n };\n};\n\nvar activeTrack = {\n /**\n * Returns a function used to get the active track of type provided\n *\n * @param {String} type\n * MediaGroup type\n * @param {Object} settings\n * Object containing required information for media groups\n * @return {Function}\n * Function that returns the active media track for the provided type. Returns\n * null if no track is active\n * @function activeTrack.AUDIO\n */\n AUDIO: function AUDIO(type, settings) {\n return function () {\n var tracks = settings.mediaTypes[type].tracks;\n\n for (var id in tracks) {\n if (tracks[id].enabled) {\n return tracks[id];\n }\n }\n\n return null;\n };\n },\n\n /**\n * Returns a function used to get the active track of type provided\n *\n * @param {String} type\n * MediaGroup type\n * @param {Object} settings\n * Object containing required information for media groups\n * @return {Function}\n * Function that returns the active media track for the provided type. Returns\n * null if no track is active\n * @function activeTrack.SUBTITLES\n */\n SUBTITLES: function SUBTITLES(type, settings) {\n return function () {\n var tracks = settings.mediaTypes[type].tracks;\n\n for (var id in tracks) {\n if (tracks[id].mode === 'showing') {\n return tracks[id];\n }\n }\n\n return null;\n };\n }\n};\n/**\n * Setup PlaylistLoaders and Tracks for media groups (Audio, Subtitles,\n * Closed-Captions) specified in the master manifest.\n *\n * @param {Object} settings\n * Object containing required information for setting up the media groups\n * @param {SegmentLoader} settings.segmentLoaders.AUDIO\n * Audio segment loader\n * @param {SegmentLoader} settings.segmentLoaders.SUBTITLES\n * Subtitle segment loader\n * @param {SegmentLoader} settings.segmentLoaders.main\n * Main segment loader\n * @param {Tech} settings.tech\n * The tech of the player\n * @param {Object} settings.requestOptions\n * XHR request options used by the segment loaders\n * @param {PlaylistLoader} settings.masterPlaylistLoader\n * PlaylistLoader for the master source\n * @param {HlsHandler} settings.hls\n * HLS SourceHandler\n * @param {Object} settings.master\n * The parsed master manifest\n * @param {Object} settings.mediaTypes\n * Object to store the loaders, tracks, and utility methods for each media type\n * @param {Function} settings.blacklistCurrentPlaylist\n * Blacklists the current rendition and forces a rendition switch.\n * @function setupMediaGroups\n */\n\nvar setupMediaGroups = function setupMediaGroups(settings) {\n ['AUDIO', 'SUBTITLES', 'CLOSED-CAPTIONS'].forEach(function (type) {\n initialize[type](type, settings);\n });\n var mediaTypes = settings.mediaTypes,\n masterPlaylistLoader = settings.masterPlaylistLoader,\n tech = settings.tech,\n hls = settings.hls; // setup active group and track getters and change event handlers\n\n ['AUDIO', 'SUBTITLES'].forEach(function (type) {\n mediaTypes[type].activeGroup = activeGroup(type, settings);\n mediaTypes[type].activeTrack = activeTrack[type](type, settings);\n mediaTypes[type].onGroupChanged = onGroupChanged(type, settings);\n mediaTypes[type].onTrackChanged = onTrackChanged(type, settings);\n }); // DO NOT enable the default subtitle or caption track.\n // DO enable the default audio track\n\n var audioGroup = mediaTypes.AUDIO.activeGroup();\n var groupId = (audioGroup.filter(function (group) {\n return group.default;\n })[0] || audioGroup[0]).id;\n mediaTypes.AUDIO.tracks[groupId].enabled = true;\n mediaTypes.AUDIO.onTrackChanged();\n masterPlaylistLoader.on('mediachange', function () {\n ['AUDIO', 'SUBTITLES'].forEach(function (type) {\n return mediaTypes[type].onGroupChanged();\n });\n }); // custom audio track change event handler for usage event\n\n var onAudioTrackChanged = function onAudioTrackChanged() {\n mediaTypes.AUDIO.onTrackChanged();\n tech.trigger({\n type: 'usage',\n name: 'hls-audio-change'\n });\n };\n\n tech.audioTracks().addEventListener('change', onAudioTrackChanged);\n tech.remoteTextTracks().addEventListener('change', mediaTypes.SUBTITLES.onTrackChanged);\n hls.on('dispose', function () {\n tech.audioTracks().removeEventListener('change', onAudioTrackChanged);\n tech.remoteTextTracks().removeEventListener('change', mediaTypes.SUBTITLES.onTrackChanged);\n }); // clear existing audio tracks and add the ones we just created\n\n tech.clearTracks('audio');\n\n for (var id in mediaTypes.AUDIO.tracks) {\n tech.audioTracks().addTrack(mediaTypes.AUDIO.tracks[id]);\n }\n};\n/**\n * Creates skeleton object used to store the loaders, tracks, and utility methods for each\n * media type\n *\n * @return {Object}\n * Object to store the loaders, tracks, and utility methods for each media type\n * @function createMediaTypes\n */\n\n\nvar createMediaTypes = function createMediaTypes() {\n var mediaTypes = {};\n ['AUDIO', 'SUBTITLES', 'CLOSED-CAPTIONS'].forEach(function (type) {\n mediaTypes[type] = {\n groups: {},\n tracks: {},\n activePlaylistLoader: null,\n activeGroup: noop,\n activeTrack: noop,\n onGroupChanged: noop,\n onTrackChanged: noop\n };\n });\n return mediaTypes;\n};\n/**\n * @file master-playlist-controller.js\n */\n\n\nvar ABORT_EARLY_BLACKLIST_SECONDS = 60 * 2;\nvar Hls = void 0; // SegmentLoader stats that need to have each loader's\n// values summed to calculate the final value\n\nvar loaderStats = ['mediaRequests', 'mediaRequestsAborted', 'mediaRequestsTimedout', 'mediaRequestsErrored', 'mediaTransferDuration', 'mediaBytesTransferred'];\n\nvar sumLoaderStat = function sumLoaderStat(stat) {\n return this.audioSegmentLoader_[stat] + this.mainSegmentLoader_[stat];\n};\n/**\n * the master playlist controller controller all interactons\n * between playlists and segmentloaders. At this time this mainly\n * involves a master playlist and a series of audio playlists\n * if they are available\n *\n * @class MasterPlaylistController\n * @extends videojs.EventTarget\n */\n\n\nvar MasterPlaylistController = function (_videojs$EventTarget) {\n inherits(MasterPlaylistController, _videojs$EventTarget);\n\n function MasterPlaylistController(options) {\n classCallCheck(this, MasterPlaylistController);\n\n var _this = possibleConstructorReturn(this, (MasterPlaylistController.__proto__ || Object.getPrototypeOf(MasterPlaylistController)).call(this));\n\n var url = options.url,\n withCredentials = options.withCredentials,\n tech = options.tech,\n bandwidth = options.bandwidth,\n externHls = options.externHls,\n useCueTags = options.useCueTags,\n blacklistDuration = options.blacklistDuration,\n enableLowInitialPlaylist = options.enableLowInitialPlaylist,\n sourceType = options.sourceType,\n seekTo = options.seekTo;\n\n if (!url) {\n throw new Error('A non-empty playlist URL is required');\n }\n\n Hls = externHls;\n _this.withCredentials = withCredentials;\n _this.tech_ = tech;\n _this.hls_ = tech.hls;\n _this.seekTo_ = seekTo;\n _this.sourceType_ = sourceType;\n _this.useCueTags_ = useCueTags;\n _this.blacklistDuration = blacklistDuration;\n _this.enableLowInitialPlaylist = enableLowInitialPlaylist;\n\n if (_this.useCueTags_) {\n _this.cueTagsTrack_ = _this.tech_.addTextTrack('metadata', 'ad-cues');\n _this.cueTagsTrack_.inBandMetadataTrackDispatchType = '';\n }\n\n _this.requestOptions_ = {\n withCredentials: _this.withCredentials,\n timeout: null\n };\n _this.mediaTypes_ = createMediaTypes();\n _this.mediaSource = new videojs$1.MediaSource(); // load the media source into the player\n\n _this.mediaSource.addEventListener('sourceopen', _this.handleSourceOpen_.bind(_this));\n\n _this.seekable_ = videojs$1.createTimeRanges();\n\n _this.hasPlayed_ = function () {\n return false;\n };\n\n _this.syncController_ = new SyncController(options);\n _this.segmentMetadataTrack_ = tech.addRemoteTextTrack({\n kind: 'metadata',\n label: 'segment-metadata'\n }, false).track;\n _this.decrypter_ = new Decrypter$1();\n _this.inbandTextTracks_ = {};\n var segmentLoaderSettings = {\n hls: _this.hls_,\n mediaSource: _this.mediaSource,\n currentTime: _this.tech_.currentTime.bind(_this.tech_),\n seekable: function seekable$$1() {\n return _this.seekable();\n },\n seeking: function seeking() {\n return _this.tech_.seeking();\n },\n duration: function duration$$1() {\n return _this.mediaSource.duration;\n },\n hasPlayed: function hasPlayed() {\n return _this.hasPlayed_();\n },\n goalBufferLength: function goalBufferLength() {\n return _this.goalBufferLength();\n },\n bandwidth: bandwidth,\n syncController: _this.syncController_,\n decrypter: _this.decrypter_,\n sourceType: _this.sourceType_,\n inbandTextTracks: _this.inbandTextTracks_\n };\n _this.masterPlaylistLoader_ = _this.sourceType_ === 'dash' ? new DashPlaylistLoader(url, _this.hls_, _this.withCredentials) : new PlaylistLoader(url, _this.hls_, _this.withCredentials);\n\n _this.setupMasterPlaylistLoaderListeners_(); // setup segment loaders\n // combined audio/video or just video when alternate audio track is selected\n\n\n _this.mainSegmentLoader_ = new SegmentLoader(videojs$1.mergeOptions(segmentLoaderSettings, {\n segmentMetadataTrack: _this.segmentMetadataTrack_,\n loaderType: 'main'\n }), options); // alternate audio track\n\n _this.audioSegmentLoader_ = new SegmentLoader(videojs$1.mergeOptions(segmentLoaderSettings, {\n loaderType: 'audio'\n }), options);\n _this.subtitleSegmentLoader_ = new VTTSegmentLoader(videojs$1.mergeOptions(segmentLoaderSettings, {\n loaderType: 'vtt'\n }), options);\n\n _this.setupSegmentLoaderListeners_(); // Create SegmentLoader stat-getters\n\n\n loaderStats.forEach(function (stat) {\n _this[stat + '_'] = sumLoaderStat.bind(_this, stat);\n });\n _this.logger_ = logger('MPC');\n\n _this.masterPlaylistLoader_.load();\n\n return _this;\n }\n /**\n * Register event handlers on the master playlist loader. A helper\n * function for construction time.\n *\n * @private\n */\n\n\n createClass(MasterPlaylistController, [{\n key: 'setupMasterPlaylistLoaderListeners_',\n value: function setupMasterPlaylistLoaderListeners_() {\n var _this2 = this;\n\n this.masterPlaylistLoader_.on('loadedmetadata', function () {\n var media = _this2.masterPlaylistLoader_.media();\n\n var requestTimeout = _this2.masterPlaylistLoader_.targetDuration * 1.5 * 1000; // If we don't have any more available playlists, we don't want to\n // timeout the request.\n\n if (isLowestEnabledRendition(_this2.masterPlaylistLoader_.master, _this2.masterPlaylistLoader_.media())) {\n _this2.requestOptions_.timeout = 0;\n } else {\n _this2.requestOptions_.timeout = requestTimeout;\n } // if this isn't a live video and preload permits, start\n // downloading segments\n\n\n if (media.endList && _this2.tech_.preload() !== 'none') {\n _this2.mainSegmentLoader_.playlist(media, _this2.requestOptions_);\n\n _this2.mainSegmentLoader_.load();\n }\n\n setupMediaGroups({\n sourceType: _this2.sourceType_,\n segmentLoaders: {\n AUDIO: _this2.audioSegmentLoader_,\n SUBTITLES: _this2.subtitleSegmentLoader_,\n main: _this2.mainSegmentLoader_\n },\n tech: _this2.tech_,\n requestOptions: _this2.requestOptions_,\n masterPlaylistLoader: _this2.masterPlaylistLoader_,\n hls: _this2.hls_,\n master: _this2.master(),\n mediaTypes: _this2.mediaTypes_,\n blacklistCurrentPlaylist: _this2.blacklistCurrentPlaylist.bind(_this2)\n });\n\n _this2.triggerPresenceUsage_(_this2.master(), media);\n\n try {\n _this2.setupSourceBuffers_();\n } catch (e) {\n videojs$1.log.warn('Failed to create SourceBuffers', e);\n return _this2.mediaSource.endOfStream('decode');\n }\n\n _this2.setupFirstPlay();\n\n _this2.trigger('selectedinitialmedia');\n });\n this.masterPlaylistLoader_.on('loadedplaylist', function () {\n var updatedPlaylist = _this2.masterPlaylistLoader_.media();\n\n if (!updatedPlaylist) {\n // blacklist any variants that are not supported by the browser before selecting\n // an initial media as the playlist selectors do not consider browser support\n _this2.excludeUnsupportedVariants_();\n\n var selectedMedia = void 0;\n\n if (_this2.enableLowInitialPlaylist) {\n selectedMedia = _this2.selectInitialPlaylist();\n }\n\n if (!selectedMedia) {\n selectedMedia = _this2.selectPlaylist();\n }\n\n _this2.initialMedia_ = selectedMedia;\n\n _this2.masterPlaylistLoader_.media(_this2.initialMedia_);\n\n return;\n }\n\n if (_this2.useCueTags_) {\n _this2.updateAdCues_(updatedPlaylist);\n } // TODO: Create a new event on the PlaylistLoader that signals\n // that the segments have changed in some way and use that to\n // update the SegmentLoader instead of doing it twice here and\n // on `mediachange`\n\n\n _this2.mainSegmentLoader_.playlist(updatedPlaylist, _this2.requestOptions_);\n\n _this2.updateDuration(); // If the player isn't paused, ensure that the segment loader is running,\n // as it is possible that it was temporarily stopped while waiting for\n // a playlist (e.g., in case the playlist errored and we re-requested it).\n\n\n if (!_this2.tech_.paused()) {\n _this2.mainSegmentLoader_.load();\n\n if (_this2.audioSegmentLoader_) {\n _this2.audioSegmentLoader_.load();\n }\n }\n\n if (!updatedPlaylist.endList) {\n var addSeekableRange = function addSeekableRange() {\n var seekable$$1 = _this2.seekable();\n\n if (seekable$$1.length !== 0) {\n _this2.mediaSource.addSeekableRange_(seekable$$1.start(0), seekable$$1.end(0));\n }\n };\n\n if (_this2.duration() !== Infinity) {\n var onDurationchange = function onDurationchange() {\n if (_this2.duration() === Infinity) {\n addSeekableRange();\n } else {\n _this2.tech_.one('durationchange', onDurationchange);\n }\n };\n\n _this2.tech_.one('durationchange', onDurationchange);\n } else {\n addSeekableRange();\n }\n }\n });\n this.masterPlaylistLoader_.on('error', function () {\n _this2.blacklistCurrentPlaylist(_this2.masterPlaylistLoader_.error);\n });\n this.masterPlaylistLoader_.on('mediachanging', function () {\n _this2.mainSegmentLoader_.abort();\n\n _this2.mainSegmentLoader_.pause();\n });\n this.masterPlaylistLoader_.on('mediachange', function () {\n var media = _this2.masterPlaylistLoader_.media();\n\n var requestTimeout = _this2.masterPlaylistLoader_.targetDuration * 1.5 * 1000; // If we don't have any more available playlists, we don't want to\n // timeout the request.\n\n if (isLowestEnabledRendition(_this2.masterPlaylistLoader_.master, _this2.masterPlaylistLoader_.media())) {\n _this2.requestOptions_.timeout = 0;\n } else {\n _this2.requestOptions_.timeout = requestTimeout;\n } // TODO: Create a new event on the PlaylistLoader that signals\n // that the segments have changed in some way and use that to\n // update the SegmentLoader instead of doing it twice here and\n // on `loadedplaylist`\n\n\n _this2.mainSegmentLoader_.playlist(media, _this2.requestOptions_);\n\n _this2.mainSegmentLoader_.load();\n\n _this2.tech_.trigger({\n type: 'mediachange',\n bubbles: true\n });\n });\n this.masterPlaylistLoader_.on('playlistunchanged', function () {\n var updatedPlaylist = _this2.masterPlaylistLoader_.media();\n\n var playlistOutdated = _this2.stuckAtPlaylistEnd_(updatedPlaylist);\n\n if (playlistOutdated) {\n // Playlist has stopped updating and we're stuck at its end. Try to\n // blacklist it and switch to another playlist in the hope that that\n // one is updating (and give the player a chance to re-adjust to the\n // safe live point).\n _this2.blacklistCurrentPlaylist({\n message: 'Playlist no longer updating.'\n }); // useful for monitoring QoS\n\n\n _this2.tech_.trigger('playliststuck');\n }\n });\n this.masterPlaylistLoader_.on('renditiondisabled', function () {\n _this2.tech_.trigger({\n type: 'usage',\n name: 'hls-rendition-disabled'\n });\n });\n this.masterPlaylistLoader_.on('renditionenabled', function () {\n _this2.tech_.trigger({\n type: 'usage',\n name: 'hls-rendition-enabled'\n });\n });\n }\n /**\n * A helper function for triggerring presence usage events once per source\n *\n * @private\n */\n\n }, {\n key: 'triggerPresenceUsage_',\n value: function triggerPresenceUsage_(master, media) {\n var mediaGroups = master.mediaGroups || {};\n var defaultDemuxed = true;\n var audioGroupKeys = Object.keys(mediaGroups.AUDIO);\n\n for (var mediaGroup in mediaGroups.AUDIO) {\n for (var label in mediaGroups.AUDIO[mediaGroup]) {\n var properties = mediaGroups.AUDIO[mediaGroup][label];\n\n if (!properties.uri) {\n defaultDemuxed = false;\n }\n }\n }\n\n if (defaultDemuxed) {\n this.tech_.trigger({\n type: 'usage',\n name: 'hls-demuxed'\n });\n }\n\n if (Object.keys(mediaGroups.SUBTITLES).length) {\n this.tech_.trigger({\n type: 'usage',\n name: 'hls-webvtt'\n });\n }\n\n if (Hls.Playlist.isAes(media)) {\n this.tech_.trigger({\n type: 'usage',\n name: 'hls-aes'\n });\n }\n\n if (Hls.Playlist.isFmp4(media)) {\n this.tech_.trigger({\n type: 'usage',\n name: 'hls-fmp4'\n });\n }\n\n if (audioGroupKeys.length && Object.keys(mediaGroups.AUDIO[audioGroupKeys[0]]).length > 1) {\n this.tech_.trigger({\n type: 'usage',\n name: 'hls-alternate-audio'\n });\n }\n\n if (this.useCueTags_) {\n this.tech_.trigger({\n type: 'usage',\n name: 'hls-playlist-cue-tags'\n });\n }\n }\n /**\n * Register event handlers on the segment loaders. A helper function\n * for construction time.\n *\n * @private\n */\n\n }, {\n key: 'setupSegmentLoaderListeners_',\n value: function setupSegmentLoaderListeners_() {\n var _this3 = this;\n\n this.mainSegmentLoader_.on('bandwidthupdate', function () {\n var nextPlaylist = _this3.selectPlaylist();\n\n var currentPlaylist = _this3.masterPlaylistLoader_.media();\n\n var buffered = _this3.tech_.buffered();\n\n var forwardBuffer = buffered.length ? buffered.end(buffered.length - 1) - _this3.tech_.currentTime() : 0;\n\n var bufferLowWaterLine = _this3.bufferLowWaterLine(); // If the playlist is live, then we want to not take low water line into account.\n // This is because in LIVE, the player plays 3 segments from the end of the\n // playlist, and if `BUFFER_LOW_WATER_LINE` is greater than the duration availble\n // in those segments, a viewer will never experience a rendition upswitch.\n\n\n if (!currentPlaylist.endList || // For the same reason as LIVE, we ignore the low water line when the VOD\n // duration is below the max potential low water line\n _this3.duration() < Config.MAX_BUFFER_LOW_WATER_LINE || // we want to switch down to lower resolutions quickly to continue playback, but\n nextPlaylist.attributes.BANDWIDTH < currentPlaylist.attributes.BANDWIDTH || // ensure we have some buffer before we switch up to prevent us running out of\n // buffer while loading a higher rendition.\n forwardBuffer >= bufferLowWaterLine) {\n _this3.masterPlaylistLoader_.media(nextPlaylist);\n }\n\n _this3.tech_.trigger('bandwidthupdate');\n });\n this.mainSegmentLoader_.on('progress', function () {\n _this3.trigger('progress');\n });\n this.mainSegmentLoader_.on('error', function () {\n _this3.blacklistCurrentPlaylist(_this3.mainSegmentLoader_.error());\n });\n this.mainSegmentLoader_.on('syncinfoupdate', function () {\n _this3.onSyncInfoUpdate_();\n });\n this.mainSegmentLoader_.on('timestampoffset', function () {\n _this3.tech_.trigger({\n type: 'usage',\n name: 'hls-timestamp-offset'\n });\n });\n this.audioSegmentLoader_.on('syncinfoupdate', function () {\n _this3.onSyncInfoUpdate_();\n });\n this.mainSegmentLoader_.on('ended', function () {\n _this3.onEndOfStream();\n });\n this.mainSegmentLoader_.on('earlyabort', function () {\n _this3.blacklistCurrentPlaylist({\n message: 'Aborted early because there isn\\'t enough bandwidth to complete the ' + 'request without rebuffering.'\n }, ABORT_EARLY_BLACKLIST_SECONDS);\n });\n this.mainSegmentLoader_.on('reseteverything', function () {\n // If playing an MTS stream, a videojs.MediaSource is listening for\n // hls-reset to reset caption parsing state in the transmuxer\n _this3.tech_.trigger('hls-reset');\n });\n this.mainSegmentLoader_.on('segmenttimemapping', function (event) {\n // If playing an MTS stream in html, a videojs.MediaSource is listening for\n // hls-segment-time-mapping update its internal mapping of stream to display time\n _this3.tech_.trigger({\n type: 'hls-segment-time-mapping',\n mapping: event.mapping\n });\n });\n this.audioSegmentLoader_.on('ended', function () {\n _this3.onEndOfStream();\n });\n }\n }, {\n key: 'mediaSecondsLoaded_',\n value: function mediaSecondsLoaded_() {\n return Math.max(this.audioSegmentLoader_.mediaSecondsLoaded + this.mainSegmentLoader_.mediaSecondsLoaded);\n }\n /**\n * Call load on our SegmentLoaders\n */\n\n }, {\n key: 'load',\n value: function load() {\n this.mainSegmentLoader_.load();\n\n if (this.mediaTypes_.AUDIO.activePlaylistLoader) {\n this.audioSegmentLoader_.load();\n }\n\n if (this.mediaTypes_.SUBTITLES.activePlaylistLoader) {\n this.subtitleSegmentLoader_.load();\n }\n }\n /**\n * Re-tune playback quality level for the current player\n * conditions without performing destructive actions, like\n * removing already buffered content\n *\n * @private\n */\n\n }, {\n key: 'smoothQualityChange_',\n value: function smoothQualityChange_() {\n var media = this.selectPlaylist();\n\n if (media !== this.masterPlaylistLoader_.media()) {\n this.masterPlaylistLoader_.media(media);\n this.mainSegmentLoader_.resetLoader(); // don't need to reset audio as it is reset when media changes\n }\n }\n /**\n * Re-tune playback quality level for the current player\n * conditions. This method will perform destructive actions like removing\n * already buffered content in order to readjust the currently active\n * playlist quickly. This is good for manual quality changes\n *\n * @private\n */\n\n }, {\n key: 'fastQualityChange_',\n value: function fastQualityChange_() {\n var _this4 = this;\n\n var media = this.selectPlaylist();\n\n if (media === this.masterPlaylistLoader_.media()) {\n return;\n }\n\n this.masterPlaylistLoader_.media(media); // Delete all buffered data to allow an immediate quality switch, then seek to give\n // the browser a kick to remove any cached frames from the previous rendtion (.04 seconds\n // ahead is roughly the minimum that will accomplish this across a variety of content\n // in IE and Edge, but seeking in place is sufficient on all other browsers)\n // Edge/IE bug: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/14600375/\n // Chrome bug: https://bugs.chromium.org/p/chromium/issues/detail?id=651904\n\n this.mainSegmentLoader_.resetEverything(function () {\n // Since this is not a typical seek, we avoid the seekTo method which can cause segments\n // from the previously enabled rendition to load before the new playlist has finished loading\n if (videojs$1.browser.IE_VERSION || videojs$1.browser.IS_EDGE) {\n _this4.tech_.setCurrentTime(_this4.tech_.currentTime() + 0.04);\n } else {\n _this4.tech_.setCurrentTime(_this4.tech_.currentTime());\n }\n }); // don't need to reset audio as it is reset when media changes\n }\n /**\n * Begin playback.\n */\n\n }, {\n key: 'play',\n value: function play() {\n if (this.setupFirstPlay()) {\n return;\n }\n\n if (this.tech_.ended()) {\n this.seekTo_(0);\n }\n\n if (this.hasPlayed_()) {\n this.load();\n }\n\n var seekable$$1 = this.tech_.seekable(); // if the viewer has paused and we fell out of the live window,\n // seek forward to the live point\n\n if (this.tech_.duration() === Infinity) {\n if (this.tech_.currentTime() < seekable$$1.start(0)) {\n return this.seekTo_(seekable$$1.end(seekable$$1.length - 1));\n }\n }\n }\n /**\n * Seek to the latest media position if this is a live video and the\n * player and video are loaded and initialized.\n */\n\n }, {\n key: 'setupFirstPlay',\n value: function setupFirstPlay() {\n var _this5 = this;\n\n var media = this.masterPlaylistLoader_.media(); // Check that everything is ready to begin buffering for the first call to play\n // If 1) there is no active media\n // 2) the player is paused\n // 3) the first play has already been setup\n // then exit early\n\n if (!media || this.tech_.paused() || this.hasPlayed_()) {\n return false;\n } // when the video is a live stream\n\n\n if (!media.endList) {\n var seekable$$1 = this.seekable();\n\n if (!seekable$$1.length) {\n // without a seekable range, the player cannot seek to begin buffering at the live\n // point\n return false;\n }\n\n if (videojs$1.browser.IE_VERSION && this.tech_.readyState() === 0) {\n // IE11 throws an InvalidStateError if you try to set currentTime while the\n // readyState is 0, so it must be delayed until the tech fires loadedmetadata.\n this.tech_.one('loadedmetadata', function () {\n _this5.trigger('firstplay');\n\n _this5.seekTo_(seekable$$1.end(0));\n\n _this5.hasPlayed_ = function () {\n return true;\n };\n });\n return false;\n } // trigger firstplay to inform the source handler to ignore the next seek event\n\n\n this.trigger('firstplay'); // seek to the live point\n\n this.seekTo_(seekable$$1.end(0));\n }\n\n this.hasPlayed_ = function () {\n return true;\n }; // we can begin loading now that everything is ready\n\n\n this.load();\n return true;\n }\n /**\n * handle the sourceopen event on the MediaSource\n *\n * @private\n */\n\n }, {\n key: 'handleSourceOpen_',\n value: function handleSourceOpen_() {\n // Only attempt to create the source buffer if none already exist.\n // handleSourceOpen is also called when we are \"re-opening\" a source buffer\n // after `endOfStream` has been called (in response to a seek for instance)\n try {\n this.setupSourceBuffers_();\n } catch (e) {\n videojs$1.log.warn('Failed to create Source Buffers', e);\n return this.mediaSource.endOfStream('decode');\n } // if autoplay is enabled, begin playback. This is duplicative of\n // code in video.js but is required because play() must be invoked\n // *after* the media source has opened.\n\n\n if (this.tech_.autoplay()) {\n var playPromise = this.tech_.play(); // Catch/silence error when a pause interrupts a play request\n // on browsers which return a promise\n\n if (typeof playPromise !== 'undefined' && typeof playPromise.then === 'function') {\n playPromise.then(null, function (e) {});\n }\n }\n\n this.trigger('sourceopen');\n }\n /**\n * Calls endOfStream on the media source when all active stream types have called\n * endOfStream\n *\n * @param {string} streamType\n * Stream type of the segment loader that called endOfStream\n * @private\n */\n\n }, {\n key: 'onEndOfStream',\n value: function onEndOfStream() {\n var isEndOfStream = this.mainSegmentLoader_.ended_;\n\n if (this.mediaTypes_.AUDIO.activePlaylistLoader) {\n // if the audio playlist loader exists, then alternate audio is active\n if (!this.mainSegmentLoader_.startingMedia_ || this.mainSegmentLoader_.startingMedia_.containsVideo) {\n // if we do not know if the main segment loader contains video yet or if we\n // definitively know the main segment loader contains video, then we need to wait\n // for both main and audio segment loaders to call endOfStream\n isEndOfStream = isEndOfStream && this.audioSegmentLoader_.ended_;\n } else {\n // otherwise just rely on the audio loader\n isEndOfStream = this.audioSegmentLoader_.ended_;\n }\n }\n\n if (isEndOfStream) {\n this.mediaSource.endOfStream();\n }\n }\n /**\n * Check if a playlist has stopped being updated\n * @param {Object} playlist the media playlist object\n * @return {boolean} whether the playlist has stopped being updated or not\n */\n\n }, {\n key: 'stuckAtPlaylistEnd_',\n value: function stuckAtPlaylistEnd_(playlist) {\n var seekable$$1 = this.seekable();\n\n if (!seekable$$1.length) {\n // playlist doesn't have enough information to determine whether we are stuck\n return false;\n }\n\n var expired = this.syncController_.getExpiredTime(playlist, this.mediaSource.duration);\n\n if (expired === null) {\n return false;\n } // does not use the safe live end to calculate playlist end, since we\n // don't want to say we are stuck while there is still content\n\n\n var absolutePlaylistEnd = Hls.Playlist.playlistEnd(playlist, expired);\n var currentTime = this.tech_.currentTime();\n var buffered = this.tech_.buffered();\n\n if (!buffered.length) {\n // return true if the playhead reached the absolute end of the playlist\n return absolutePlaylistEnd - currentTime <= SAFE_TIME_DELTA;\n }\n\n var bufferedEnd = buffered.end(buffered.length - 1); // return true if there is too little buffer left and buffer has reached absolute\n // end of playlist\n\n return bufferedEnd - currentTime <= SAFE_TIME_DELTA && absolutePlaylistEnd - bufferedEnd <= SAFE_TIME_DELTA;\n }\n /**\n * Blacklists a playlist when an error occurs for a set amount of time\n * making it unavailable for selection by the rendition selection algorithm\n * and then forces a new playlist (rendition) selection.\n *\n * @param {Object=} error an optional error that may include the playlist\n * to blacklist\n * @param {Number=} blacklistDuration an optional number of seconds to blacklist the\n * playlist\n */\n\n }, {\n key: 'blacklistCurrentPlaylist',\n value: function blacklistCurrentPlaylist() {\n var error = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var blacklistDuration = arguments[1];\n var currentPlaylist = void 0;\n var nextPlaylist = void 0; // If the `error` was generated by the playlist loader, it will contain\n // the playlist we were trying to load (but failed) and that should be\n // blacklisted instead of the currently selected playlist which is likely\n // out-of-date in this scenario\n\n currentPlaylist = error.playlist || this.masterPlaylistLoader_.media();\n blacklistDuration = blacklistDuration || error.blacklistDuration || this.blacklistDuration; // If there is no current playlist, then an error occurred while we were\n // trying to load the master OR while we were disposing of the tech\n\n if (!currentPlaylist) {\n this.error = error;\n\n try {\n return this.mediaSource.endOfStream('network');\n } catch (e) {\n return this.trigger('error');\n }\n }\n\n var isFinalRendition = this.masterPlaylistLoader_.master.playlists.filter(isEnabled).length === 1;\n\n if (isFinalRendition) {\n // Never blacklisting this playlist because it's final rendition\n videojs$1.log.warn('Problem encountered with the current ' + 'HLS playlist. Trying again since it is the final playlist.');\n this.tech_.trigger('retryplaylist');\n return this.masterPlaylistLoader_.load(isFinalRendition);\n } // Blacklist this playlist\n\n\n currentPlaylist.excludeUntil = Date.now() + blacklistDuration * 1000;\n this.tech_.trigger('blacklistplaylist');\n this.tech_.trigger({\n type: 'usage',\n name: 'hls-rendition-blacklisted'\n }); // Select a new playlist\n\n nextPlaylist = this.selectPlaylist();\n videojs$1.log.warn('Problem encountered with the current HLS playlist.' + (error.message ? ' ' + error.message : '') + ' Switching to another playlist.');\n return this.masterPlaylistLoader_.media(nextPlaylist);\n }\n /**\n * Pause all segment loaders\n */\n\n }, {\n key: 'pauseLoading',\n value: function pauseLoading() {\n this.mainSegmentLoader_.pause();\n\n if (this.mediaTypes_.AUDIO.activePlaylistLoader) {\n this.audioSegmentLoader_.pause();\n }\n\n if (this.mediaTypes_.SUBTITLES.activePlaylistLoader) {\n this.subtitleSegmentLoader_.pause();\n }\n }\n /**\n * set the current time on all segment loaders\n *\n * @param {TimeRange} currentTime the current time to set\n * @return {TimeRange} the current time\n */\n\n }, {\n key: 'setCurrentTime',\n value: function setCurrentTime(currentTime) {\n var buffered = findRange(this.tech_.buffered(), currentTime);\n\n if (!(this.masterPlaylistLoader_ && this.masterPlaylistLoader_.media())) {\n // return immediately if the metadata is not ready yet\n return 0;\n } // it's clearly an edge-case but don't thrown an error if asked to\n // seek within an empty playlist\n\n\n if (!this.masterPlaylistLoader_.media().segments) {\n return 0;\n } // In flash playback, the segment loaders should be reset on every seek, even\n // in buffer seeks. If the seek location is already buffered, continue buffering as\n // usual\n // TODO: redo this comment\n\n\n if (buffered && buffered.length) {\n return currentTime;\n } // cancel outstanding requests so we begin buffering at the new\n // location\n\n\n this.mainSegmentLoader_.resetEverything();\n this.mainSegmentLoader_.abort();\n\n if (this.mediaTypes_.AUDIO.activePlaylistLoader) {\n this.audioSegmentLoader_.resetEverything();\n this.audioSegmentLoader_.abort();\n }\n\n if (this.mediaTypes_.SUBTITLES.activePlaylistLoader) {\n this.subtitleSegmentLoader_.resetEverything();\n this.subtitleSegmentLoader_.abort();\n } // start segment loader loading in case they are paused\n\n\n this.load();\n }\n /**\n * get the current duration\n *\n * @return {TimeRange} the duration\n */\n\n }, {\n key: 'duration',\n value: function duration$$1() {\n if (!this.masterPlaylistLoader_) {\n return 0;\n }\n\n if (this.mediaSource) {\n return this.mediaSource.duration;\n }\n\n return Hls.Playlist.duration(this.masterPlaylistLoader_.media());\n }\n /**\n * check the seekable range\n *\n * @return {TimeRange} the seekable range\n */\n\n }, {\n key: 'seekable',\n value: function seekable$$1() {\n return this.seekable_;\n }\n }, {\n key: 'onSyncInfoUpdate_',\n value: function onSyncInfoUpdate_() {\n var mainSeekable = void 0;\n var audioSeekable = void 0;\n\n if (!this.masterPlaylistLoader_) {\n return;\n }\n\n var media = this.masterPlaylistLoader_.media();\n\n if (!media) {\n return;\n }\n\n var expired = this.syncController_.getExpiredTime(media, this.mediaSource.duration);\n\n if (expired === null) {\n // not enough information to update seekable\n return;\n }\n\n mainSeekable = Hls.Playlist.seekable(media, expired);\n\n if (mainSeekable.length === 0) {\n return;\n }\n\n if (this.mediaTypes_.AUDIO.activePlaylistLoader) {\n media = this.mediaTypes_.AUDIO.activePlaylistLoader.media();\n expired = this.syncController_.getExpiredTime(media, this.mediaSource.duration);\n\n if (expired === null) {\n return;\n }\n\n audioSeekable = Hls.Playlist.seekable(media, expired);\n\n if (audioSeekable.length === 0) {\n return;\n }\n }\n\n if (!audioSeekable) {\n // seekable has been calculated based on buffering video data so it\n // can be returned directly\n this.seekable_ = mainSeekable;\n } else if (audioSeekable.start(0) > mainSeekable.end(0) || mainSeekable.start(0) > audioSeekable.end(0)) {\n // seekables are pretty far off, rely on main\n this.seekable_ = mainSeekable;\n } else {\n this.seekable_ = videojs$1.createTimeRanges([[audioSeekable.start(0) > mainSeekable.start(0) ? audioSeekable.start(0) : mainSeekable.start(0), audioSeekable.end(0) < mainSeekable.end(0) ? audioSeekable.end(0) : mainSeekable.end(0)]]);\n }\n\n this.logger_('seekable updated [' + printableRange(this.seekable_) + ']');\n this.tech_.trigger('seekablechanged');\n }\n /**\n * Update the player duration\n */\n\n }, {\n key: 'updateDuration',\n value: function updateDuration() {\n var _this6 = this;\n\n var oldDuration = this.mediaSource.duration;\n var newDuration = Hls.Playlist.duration(this.masterPlaylistLoader_.media());\n var buffered = this.tech_.buffered();\n\n var setDuration = function setDuration() {\n _this6.mediaSource.duration = newDuration;\n\n _this6.tech_.trigger('durationchange');\n\n _this6.mediaSource.removeEventListener('sourceopen', setDuration);\n };\n\n if (buffered.length > 0) {\n newDuration = Math.max(newDuration, buffered.end(buffered.length - 1));\n } // if the duration has changed, invalidate the cached value\n\n\n if (oldDuration !== newDuration) {\n // update the duration\n if (this.mediaSource.readyState !== 'open') {\n this.mediaSource.addEventListener('sourceopen', setDuration);\n } else {\n setDuration();\n }\n }\n }\n /**\n * dispose of the MasterPlaylistController and everything\n * that it controls\n */\n\n }, {\n key: 'dispose',\n value: function dispose() {\n var _this7 = this;\n\n this.decrypter_.terminate();\n this.masterPlaylistLoader_.dispose();\n this.mainSegmentLoader_.dispose();\n ['AUDIO', 'SUBTITLES'].forEach(function (type) {\n var groups = _this7.mediaTypes_[type].groups;\n\n for (var id in groups) {\n groups[id].forEach(function (group) {\n if (group.playlistLoader) {\n group.playlistLoader.dispose();\n }\n });\n }\n });\n this.audioSegmentLoader_.dispose();\n this.subtitleSegmentLoader_.dispose();\n }\n /**\n * return the master playlist object if we have one\n *\n * @return {Object} the master playlist object that we parsed\n */\n\n }, {\n key: 'master',\n value: function master() {\n return this.masterPlaylistLoader_.master;\n }\n /**\n * return the currently selected playlist\n *\n * @return {Object} the currently selected playlist object that we parsed\n */\n\n }, {\n key: 'media',\n value: function media() {\n // playlist loader will not return media if it has not been fully loaded\n return this.masterPlaylistLoader_.media() || this.initialMedia_;\n }\n /**\n * setup our internal source buffers on our segment Loaders\n *\n * @private\n */\n\n }, {\n key: 'setupSourceBuffers_',\n value: function setupSourceBuffers_() {\n var media = this.masterPlaylistLoader_.media();\n var mimeTypes = void 0; // wait until a media playlist is available and the Media Source is\n // attached\n\n if (!media || this.mediaSource.readyState !== 'open') {\n return;\n }\n\n mimeTypes = mimeTypesForPlaylist(this.masterPlaylistLoader_.master, media);\n\n if (mimeTypes.length < 1) {\n this.error = 'No compatible SourceBuffer configuration for the variant stream:' + media.resolvedUri;\n return this.mediaSource.endOfStream('decode');\n }\n\n this.configureLoaderMimeTypes_(mimeTypes); // exclude any incompatible variant streams from future playlist\n // selection\n\n this.excludeIncompatibleVariants_(media);\n }\n }, {\n key: 'configureLoaderMimeTypes_',\n value: function configureLoaderMimeTypes_(mimeTypes) {\n // If the content is demuxed, we can't start appending segments to a source buffer\n // until both source buffers are set up, or else the browser may not let us add the\n // second source buffer (it will assume we are playing either audio only or video\n // only).\n var sourceBufferEmitter = // If there is more than one mime type\n mimeTypes.length > 1 && // and the first mime type does not have muxed video and audio\n mimeTypes[0].indexOf(',') === -1 && // and the two mime types are different (they can be the same in the case of audio\n // only with alternate audio)\n mimeTypes[0] !== mimeTypes[1] ? // then we want to wait on the second source buffer\n new videojs$1.EventTarget() : // otherwise there is no need to wait as the content is either audio only,\n // video only, or muxed content.\n null;\n this.mainSegmentLoader_.mimeType(mimeTypes[0], sourceBufferEmitter);\n\n if (mimeTypes[1]) {\n this.audioSegmentLoader_.mimeType(mimeTypes[1], sourceBufferEmitter);\n }\n }\n /**\n * Blacklists playlists with codecs that are unsupported by the browser.\n */\n\n }, {\n key: 'excludeUnsupportedVariants_',\n value: function excludeUnsupportedVariants_() {\n this.master().playlists.forEach(function (variant) {\n if (variant.attributes.CODECS && window$1.MediaSource && window$1.MediaSource.isTypeSupported && !window$1.MediaSource.isTypeSupported('video/mp4; codecs=\"' + mapLegacyAvcCodecs(variant.attributes.CODECS) + '\"')) {\n variant.excludeUntil = Infinity;\n }\n });\n }\n /**\n * Blacklist playlists that are known to be codec or\n * stream-incompatible with the SourceBuffer configuration. For\n * instance, Media Source Extensions would cause the video element to\n * stall waiting for video data if you switched from a variant with\n * video and audio to an audio-only one.\n *\n * @param {Object} media a media playlist compatible with the current\n * set of SourceBuffers. Variants in the current master playlist that\n * do not appear to have compatible codec or stream configurations\n * will be excluded from the default playlist selection algorithm\n * indefinitely.\n * @private\n */\n\n }, {\n key: 'excludeIncompatibleVariants_',\n value: function excludeIncompatibleVariants_(media) {\n var codecCount = 2;\n var videoCodec = null;\n var codecs = void 0;\n\n if (media.attributes.CODECS) {\n codecs = parseCodecs(media.attributes.CODECS);\n videoCodec = codecs.videoCodec;\n codecCount = codecs.codecCount;\n }\n\n this.master().playlists.forEach(function (variant) {\n var variantCodecs = {\n codecCount: 2,\n videoCodec: null\n };\n\n if (variant.attributes.CODECS) {\n variantCodecs = parseCodecs(variant.attributes.CODECS);\n } // if the streams differ in the presence or absence of audio or\n // video, they are incompatible\n\n\n if (variantCodecs.codecCount !== codecCount) {\n variant.excludeUntil = Infinity;\n } // if h.264 is specified on the current playlist, some flavor of\n // it must be specified on all compatible variants\n\n\n if (variantCodecs.videoCodec !== videoCodec) {\n variant.excludeUntil = Infinity;\n }\n });\n }\n }, {\n key: 'updateAdCues_',\n value: function updateAdCues_(media) {\n var offset = 0;\n var seekable$$1 = this.seekable();\n\n if (seekable$$1.length) {\n offset = seekable$$1.start(0);\n }\n\n updateAdCues(media, this.cueTagsTrack_, offset);\n }\n /**\n * Calculates the desired forward buffer length based on current time\n *\n * @return {Number} Desired forward buffer length in seconds\n */\n\n }, {\n key: 'goalBufferLength',\n value: function goalBufferLength() {\n var currentTime = this.tech_.currentTime();\n var initial = Config.GOAL_BUFFER_LENGTH;\n var rate = Config.GOAL_BUFFER_LENGTH_RATE;\n var max = Math.max(initial, Config.MAX_GOAL_BUFFER_LENGTH);\n return Math.min(initial + currentTime * rate, max);\n }\n /**\n * Calculates the desired buffer low water line based on current time\n *\n * @return {Number} Desired buffer low water line in seconds\n */\n\n }, {\n key: 'bufferLowWaterLine',\n value: function bufferLowWaterLine() {\n var currentTime = this.tech_.currentTime();\n var initial = Config.BUFFER_LOW_WATER_LINE;\n var rate = Config.BUFFER_LOW_WATER_LINE_RATE;\n var max = Math.max(initial, Config.MAX_BUFFER_LOW_WATER_LINE);\n return Math.min(initial + currentTime * rate, max);\n }\n }]);\n return MasterPlaylistController;\n}(videojs$1.EventTarget);\n/**\n * Returns a function that acts as the Enable/disable playlist function.\n *\n * @param {PlaylistLoader} loader - The master playlist loader\n * @param {String} playlistUri - uri of the playlist\n * @param {Function} changePlaylistFn - A function to be called after a\n * playlist's enabled-state has been changed. Will NOT be called if a\n * playlist's enabled-state is unchanged\n * @param {Boolean=} enable - Value to set the playlist enabled-state to\n * or if undefined returns the current enabled-state for the playlist\n * @return {Function} Function for setting/getting enabled\n */\n\n\nvar enableFunction = function enableFunction(loader, playlistUri, changePlaylistFn) {\n return function (enable) {\n var playlist = loader.master.playlists[playlistUri];\n var incompatible = isIncompatible(playlist);\n var currentlyEnabled = isEnabled(playlist);\n\n if (typeof enable === 'undefined') {\n return currentlyEnabled;\n }\n\n if (enable) {\n delete playlist.disabled;\n } else {\n playlist.disabled = true;\n }\n\n if (enable !== currentlyEnabled && !incompatible) {\n // Ensure the outside world knows about our changes\n changePlaylistFn();\n\n if (enable) {\n loader.trigger('renditionenabled');\n } else {\n loader.trigger('renditiondisabled');\n }\n }\n\n return enable;\n };\n};\n/**\n * The representation object encapsulates the publicly visible information\n * in a media playlist along with a setter/getter-type function (enabled)\n * for changing the enabled-state of a particular playlist entry\n *\n * @class Representation\n */\n\n\nvar Representation = function Representation(hlsHandler, playlist, id) {\n classCallCheck(this, Representation);\n var mpc = hlsHandler.masterPlaylistController_,\n smoothQualityChange = hlsHandler.options_.smoothQualityChange; // Get a reference to a bound version of the quality change function\n\n var changeType = smoothQualityChange ? 'smooth' : 'fast';\n var qualityChangeFunction = mpc[changeType + 'QualityChange_'].bind(mpc); // some playlist attributes are optional\n\n if (playlist.attributes.RESOLUTION) {\n var resolution = playlist.attributes.RESOLUTION;\n this.width = resolution.width;\n this.height = resolution.height;\n }\n\n this.bandwidth = playlist.attributes.BANDWIDTH; // The id is simply the ordinality of the media playlist\n // within the master playlist\n\n this.id = id; // Partially-apply the enableFunction to create a playlist-\n // specific variant\n\n this.enabled = enableFunction(hlsHandler.playlists, playlist.uri, qualityChangeFunction);\n};\n/**\n * A mixin function that adds the `representations` api to an instance\n * of the HlsHandler class\n * @param {HlsHandler} hlsHandler - An instance of HlsHandler to add the\n * representation API into\n */\n\n\nvar renditionSelectionMixin = function renditionSelectionMixin(hlsHandler) {\n var playlists = hlsHandler.playlists; // Add a single API-specific function to the HlsHandler instance\n\n hlsHandler.representations = function () {\n return playlists.master.playlists.filter(function (media) {\n return !isIncompatible(media);\n }).map(function (e, i) {\n return new Representation(hlsHandler, e, e.uri);\n });\n };\n};\n/**\n * @file playback-watcher.js\n *\n * Playback starts, and now my watch begins. It shall not end until my death. I shall\n * take no wait, hold no uncleared timeouts, father no bad seeks. I shall wear no crowns\n * and win no glory. I shall live and die at my post. I am the corrector of the underflow.\n * I am the watcher of gaps. I am the shield that guards the realms of seekable. I pledge\n * my life and honor to the Playback Watch, for this Player and all the Players to come.\n */\n// Set of events that reset the playback-watcher time check logic and clear the timeout\n\n\nvar timerCancelEvents = ['seeking', 'seeked', 'pause', 'playing', 'error'];\n/**\n * @class PlaybackWatcher\n */\n\nvar PlaybackWatcher = function () {\n /**\n * Represents an PlaybackWatcher object.\n * @constructor\n * @param {object} options an object that includes the tech and settings\n */\n function PlaybackWatcher(options) {\n var _this = this;\n\n classCallCheck(this, PlaybackWatcher);\n this.tech_ = options.tech;\n this.seekable = options.seekable;\n this.seekTo = options.seekTo;\n this.consecutiveUpdates = 0;\n this.lastRecordedTime = null;\n this.timer_ = null;\n this.checkCurrentTimeTimeout_ = null;\n this.logger_ = logger('PlaybackWatcher');\n this.logger_('initialize');\n\n var canPlayHandler = function canPlayHandler() {\n return _this.monitorCurrentTime_();\n };\n\n var waitingHandler = function waitingHandler() {\n return _this.techWaiting_();\n };\n\n var cancelTimerHandler = function cancelTimerHandler() {\n return _this.cancelTimer_();\n };\n\n var fixesBadSeeksHandler = function fixesBadSeeksHandler() {\n return _this.fixesBadSeeks_();\n };\n\n this.tech_.on('seekablechanged', fixesBadSeeksHandler);\n this.tech_.on('waiting', waitingHandler);\n this.tech_.on(timerCancelEvents, cancelTimerHandler);\n this.tech_.on('canplay', canPlayHandler); // Define the dispose function to clean up our events\n\n this.dispose = function () {\n _this.logger_('dispose');\n\n _this.tech_.off('seekablechanged', fixesBadSeeksHandler);\n\n _this.tech_.off('waiting', waitingHandler);\n\n _this.tech_.off(timerCancelEvents, cancelTimerHandler);\n\n _this.tech_.off('canplay', canPlayHandler);\n\n if (_this.checkCurrentTimeTimeout_) {\n window$1.clearTimeout(_this.checkCurrentTimeTimeout_);\n }\n\n _this.cancelTimer_();\n };\n }\n /**\n * Periodically check current time to see if playback stopped\n *\n * @private\n */\n\n\n createClass(PlaybackWatcher, [{\n key: 'monitorCurrentTime_',\n value: function monitorCurrentTime_() {\n this.checkCurrentTime_();\n\n if (this.checkCurrentTimeTimeout_) {\n window$1.clearTimeout(this.checkCurrentTimeTimeout_);\n } // 42 = 24 fps // 250 is what Webkit uses // FF uses 15\n\n\n this.checkCurrentTimeTimeout_ = window$1.setTimeout(this.monitorCurrentTime_.bind(this), 250);\n }\n /**\n * The purpose of this function is to emulate the \"waiting\" event on\n * browsers that do not emit it when they are waiting for more\n * data to continue playback\n *\n * @private\n */\n\n }, {\n key: 'checkCurrentTime_',\n value: function checkCurrentTime_() {\n if (this.tech_.seeking() && this.fixesBadSeeks_()) {\n this.consecutiveUpdates = 0;\n this.lastRecordedTime = this.tech_.currentTime();\n return;\n }\n\n if (this.tech_.paused() || this.tech_.seeking()) {\n return;\n }\n\n var currentTime = this.tech_.currentTime();\n var buffered = this.tech_.buffered();\n\n if (this.lastRecordedTime === currentTime && (!buffered.length || currentTime + SAFE_TIME_DELTA >= buffered.end(buffered.length - 1))) {\n // If current time is at the end of the final buffered region, then any playback\n // stall is most likely caused by buffering in a low bandwidth environment. The tech\n // should fire a `waiting` event in this scenario, but due to browser and tech\n // inconsistencies. Calling `techWaiting_` here allows us to simulate\n // responding to a native `waiting` event when the tech fails to emit one.\n return this.techWaiting_();\n }\n\n if (this.consecutiveUpdates >= 5 && currentTime === this.lastRecordedTime) {\n this.consecutiveUpdates++;\n this.waiting_();\n } else if (currentTime === this.lastRecordedTime) {\n this.consecutiveUpdates++;\n } else {\n this.consecutiveUpdates = 0;\n this.lastRecordedTime = currentTime;\n }\n }\n /**\n * Cancels any pending timers and resets the 'timeupdate' mechanism\n * designed to detect that we are stalled\n *\n * @private\n */\n\n }, {\n key: 'cancelTimer_',\n value: function cancelTimer_() {\n this.consecutiveUpdates = 0;\n\n if (this.timer_) {\n this.logger_('cancelTimer_');\n clearTimeout(this.timer_);\n }\n\n this.timer_ = null;\n }\n /**\n * Fixes situations where there's a bad seek\n *\n * @return {Boolean} whether an action was taken to fix the seek\n * @private\n */\n\n }, {\n key: 'fixesBadSeeks_',\n value: function fixesBadSeeks_() {\n var seeking = this.tech_.seeking();\n var seekable = this.seekable();\n var currentTime = this.tech_.currentTime();\n var seekTo = void 0;\n\n if (seeking && this.afterSeekableWindow_(seekable, currentTime)) {\n var seekableEnd = seekable.end(seekable.length - 1); // sync to live point (if VOD, our seekable was updated and we're simply adjusting)\n\n seekTo = seekableEnd;\n }\n\n if (seeking && this.beforeSeekableWindow_(seekable, currentTime)) {\n var seekableStart = seekable.start(0); // sync to the beginning of the live window\n // provide a buffer of .1 seconds to handle rounding/imprecise numbers\n\n seekTo = seekableStart + SAFE_TIME_DELTA;\n }\n\n if (typeof seekTo !== 'undefined') {\n this.logger_('Trying to seek outside of seekable at time ' + currentTime + ' with ' + ('seekable range ' + printableRange(seekable) + '. Seeking to ') + (seekTo + '.'));\n this.seekTo(seekTo);\n return true;\n }\n\n return false;\n }\n /**\n * Handler for situations when we determine the player is waiting.\n *\n * @private\n */\n\n }, {\n key: 'waiting_',\n value: function waiting_() {\n if (this.techWaiting_()) {\n return;\n } // All tech waiting checks failed. Use last resort correction\n\n\n var currentTime = this.tech_.currentTime();\n var buffered = this.tech_.buffered();\n var currentRange = findRange(buffered, currentTime); // Sometimes the player can stall for unknown reasons within a contiguous buffered\n // region with no indication that anything is amiss (seen in Firefox). Seeking to\n // currentTime is usually enough to kickstart the player. This checks that the player\n // is currently within a buffered region before attempting a corrective seek.\n // Chrome does not appear to continue `timeupdate` events after a `waiting` event\n // until there is ~ 3 seconds of forward buffer available. PlaybackWatcher should also\n // make sure there is ~3 seconds of forward buffer before taking any corrective action\n // to avoid triggering an `unknownwaiting` event when the network is slow.\n\n if (currentRange.length && currentTime + 3 <= currentRange.end(0)) {\n this.cancelTimer_();\n this.seekTo(currentTime);\n this.logger_('Stopped at ' + currentTime + ' while inside a buffered region ' + ('[' + currentRange.start(0) + ' -> ' + currentRange.end(0) + ']. Attempting to resume ') + 'playback by seeking to the current time.'); // unknown waiting corrections may be useful for monitoring QoS\n\n this.tech_.trigger({\n type: 'usage',\n name: 'hls-unknown-waiting'\n });\n return;\n }\n }\n /**\n * Handler for situations when the tech fires a `waiting` event\n *\n * @return {Boolean}\n * True if an action (or none) was needed to correct the waiting. False if no\n * checks passed\n * @private\n */\n\n }, {\n key: 'techWaiting_',\n value: function techWaiting_() {\n var seekable = this.seekable();\n var currentTime = this.tech_.currentTime();\n\n if (this.tech_.seeking() && this.fixesBadSeeks_()) {\n // Tech is seeking or bad seek fixed, no action needed\n return true;\n }\n\n if (this.tech_.seeking() || this.timer_ !== null) {\n // Tech is seeking or already waiting on another action, no action needed\n return true;\n }\n\n if (this.beforeSeekableWindow_(seekable, currentTime)) {\n var livePoint = seekable.end(seekable.length - 1);\n this.logger_('Fell out of live window at time ' + currentTime + '. Seeking to ' + ('live point (seekable end) ' + livePoint));\n this.cancelTimer_();\n this.seekTo(livePoint); // live window resyncs may be useful for monitoring QoS\n\n this.tech_.trigger({\n type: 'usage',\n name: 'hls-live-resync'\n });\n return true;\n }\n\n var buffered = this.tech_.buffered();\n var nextRange = findNextRange(buffered, currentTime);\n\n if (this.videoUnderflow_(nextRange, buffered, currentTime)) {\n // Even though the video underflowed and was stuck in a gap, the audio overplayed\n // the gap, leading currentTime into a buffered range. Seeking to currentTime\n // allows the video to catch up to the audio position without losing any audio\n // (only suffering ~3 seconds of frozen video and a pause in audio playback).\n this.cancelTimer_();\n this.seekTo(currentTime); // video underflow may be useful for monitoring QoS\n\n this.tech_.trigger({\n type: 'usage',\n name: 'hls-video-underflow'\n });\n return true;\n } // check for gap\n\n\n if (nextRange.length > 0) {\n var difference = nextRange.start(0) - currentTime;\n this.logger_('Stopped at ' + currentTime + ', setting timer for ' + difference + ', seeking ' + ('to ' + nextRange.start(0)));\n this.timer_ = setTimeout(this.skipTheGap_.bind(this), difference * 1000, currentTime);\n return true;\n } // All checks failed. Returning false to indicate failure to correct waiting\n\n\n return false;\n }\n }, {\n key: 'afterSeekableWindow_',\n value: function afterSeekableWindow_(seekable, currentTime) {\n if (!seekable.length) {\n // we can't make a solid case if there's no seekable, default to false\n return false;\n }\n\n if (currentTime > seekable.end(seekable.length - 1) + SAFE_TIME_DELTA) {\n return true;\n }\n\n return false;\n }\n }, {\n key: 'beforeSeekableWindow_',\n value: function beforeSeekableWindow_(seekable, currentTime) {\n if (seekable.length && // can't fall before 0 and 0 seekable start identifies VOD stream\n seekable.start(0) > 0 && currentTime < seekable.start(0) - SAFE_TIME_DELTA) {\n return true;\n }\n\n return false;\n }\n }, {\n key: 'videoUnderflow_',\n value: function videoUnderflow_(nextRange, buffered, currentTime) {\n if (nextRange.length === 0) {\n // Even if there is no available next range, there is still a possibility we are\n // stuck in a gap due to video underflow.\n var gap = this.gapFromVideoUnderflow_(buffered, currentTime);\n\n if (gap) {\n this.logger_('Encountered a gap in video from ' + gap.start + ' to ' + gap.end + '. ' + ('Seeking to current time ' + currentTime));\n return true;\n }\n }\n\n return false;\n }\n /**\n * Timer callback. If playback still has not proceeded, then we seek\n * to the start of the next buffered region.\n *\n * @private\n */\n\n }, {\n key: 'skipTheGap_',\n value: function skipTheGap_(scheduledCurrentTime) {\n var buffered = this.tech_.buffered();\n var currentTime = this.tech_.currentTime();\n var nextRange = findNextRange(buffered, currentTime);\n this.cancelTimer_();\n\n if (nextRange.length === 0 || currentTime !== scheduledCurrentTime) {\n return;\n }\n\n this.logger_('skipTheGap_:', 'currentTime:', currentTime, 'scheduled currentTime:', scheduledCurrentTime, 'nextRange start:', nextRange.start(0)); // only seek if we still have not played\n\n this.seekTo(nextRange.start(0) + TIME_FUDGE_FACTOR);\n this.tech_.trigger({\n type: 'usage',\n name: 'hls-gap-skip'\n });\n }\n }, {\n key: 'gapFromVideoUnderflow_',\n value: function gapFromVideoUnderflow_(buffered, currentTime) {\n // At least in Chrome, if there is a gap in the video buffer, the audio will continue\n // playing for ~3 seconds after the video gap starts. This is done to account for\n // video buffer underflow/underrun (note that this is not done when there is audio\n // buffer underflow/underrun -- in that case the video will stop as soon as it\n // encounters the gap, as audio stalls are more noticeable/jarring to a user than\n // video stalls). The player's time will reflect the playthrough of audio, so the\n // time will appear as if we are in a buffered region, even if we are stuck in a\n // \"gap.\"\n //\n // Example:\n // video buffer: 0 => 10.1, 10.2 => 20\n // audio buffer: 0 => 20\n // overall buffer: 0 => 10.1, 10.2 => 20\n // current time: 13\n //\n // Chrome's video froze at 10 seconds, where the video buffer encountered the gap,\n // however, the audio continued playing until it reached ~3 seconds past the gap\n // (13 seconds), at which point it stops as well. Since current time is past the\n // gap, findNextRange will return no ranges.\n //\n // To check for this issue, we see if there is a gap that starts somewhere within\n // a 3 second range (3 seconds +/- 1 second) back from our current time.\n var gaps = findGaps(buffered);\n\n for (var i = 0; i < gaps.length; i++) {\n var start = gaps.start(i);\n var end = gaps.end(i); // gap is starts no more than 4 seconds back\n\n if (currentTime - start < 4 && currentTime - start > 2) {\n return {\n start: start,\n end: end\n };\n }\n }\n\n return null;\n }\n }]);\n return PlaybackWatcher;\n}();\n\nvar defaultOptions = {\n errorInterval: 30,\n getSource: function getSource(next) {\n var tech = this.tech({\n IWillNotUseThisInPlugins: true\n });\n var sourceObj = tech.currentSource_;\n return next(sourceObj);\n }\n};\n/**\n * Main entry point for the plugin\n *\n * @param {Player} player a reference to a videojs Player instance\n * @param {Object} [options] an object with plugin options\n * @private\n */\n\nvar initPlugin = function initPlugin(player, options) {\n var lastCalled = 0;\n var seekTo = 0;\n var localOptions = videojs$1.mergeOptions(defaultOptions, options);\n player.ready(function () {\n player.trigger({\n type: 'usage',\n name: 'hls-error-reload-initialized'\n });\n });\n /**\n * Player modifications to perform that must wait until `loadedmetadata`\n * has been triggered\n *\n * @private\n */\n\n var loadedMetadataHandler = function loadedMetadataHandler() {\n if (seekTo) {\n player.currentTime(seekTo);\n }\n };\n /**\n * Set the source on the player element, play, and seek if necessary\n *\n * @param {Object} sourceObj An object specifying the source url and mime-type to play\n * @private\n */\n\n\n var setSource = function setSource(sourceObj) {\n if (sourceObj === null || sourceObj === undefined) {\n return;\n }\n\n seekTo = player.duration() !== Infinity && player.currentTime() || 0;\n player.one('loadedmetadata', loadedMetadataHandler);\n player.src(sourceObj);\n player.trigger({\n type: 'usage',\n name: 'hls-error-reload'\n });\n player.play();\n };\n /**\n * Attempt to get a source from either the built-in getSource function\n * or a custom function provided via the options\n *\n * @private\n */\n\n\n var errorHandler = function errorHandler() {\n // Do not attempt to reload the source if a source-reload occurred before\n // 'errorInterval' time has elapsed since the last source-reload\n if (Date.now() - lastCalled < localOptions.errorInterval * 1000) {\n player.trigger({\n type: 'usage',\n name: 'hls-error-reload-canceled'\n });\n return;\n }\n\n if (!localOptions.getSource || typeof localOptions.getSource !== 'function') {\n videojs$1.log.error('ERROR: reloadSourceOnError - The option getSource must be a function!');\n return;\n }\n\n lastCalled = Date.now();\n return localOptions.getSource.call(player, setSource);\n };\n /**\n * Unbind any event handlers that were bound by the plugin\n *\n * @private\n */\n\n\n var cleanupEvents = function cleanupEvents() {\n player.off('loadedmetadata', loadedMetadataHandler);\n player.off('error', errorHandler);\n player.off('dispose', cleanupEvents);\n };\n /**\n * Cleanup before re-initializing the plugin\n *\n * @param {Object} [newOptions] an object with plugin options\n * @private\n */\n\n\n var reinitPlugin = function reinitPlugin(newOptions) {\n cleanupEvents();\n initPlugin(player, newOptions);\n };\n\n player.on('error', errorHandler);\n player.on('dispose', cleanupEvents); // Overwrite the plugin function so that we can correctly cleanup before\n // initializing the plugin\n\n player.reloadSourceOnError = reinitPlugin;\n};\n/**\n * Reload the source when an error is detected as long as there\n * wasn't an error previously within the last 30 seconds\n *\n * @param {Object} [options] an object with plugin options\n */\n\n\nvar reloadSourceOnError = function reloadSourceOnError(options) {\n initPlugin(this, options);\n};\n\nvar version$1 = \"1.5.1\"; // since VHS handles HLS and DASH (and in the future, more types), use * to capture all\n\nvideojs$1.use('*', function (player) {\n return {\n setSource: function setSource(srcObj, next) {\n // pass null as the first argument to indicate that the source is not rejected\n next(null, srcObj);\n },\n // VHS needs to know when seeks happen. For external seeks (generated at the player\n // level), this middleware will capture the action. For internal seeks (generated at\n // the tech level), we use a wrapped function so that we can handle it on our own\n // (specified elsewhere).\n setCurrentTime: function setCurrentTime(time) {\n if (player.vhs && player.currentSource().src === player.vhs.source_.src) {\n player.vhs.setCurrentTime(time);\n }\n\n return time;\n },\n // Sync VHS after play requests.\n // This specifically handles replay where the order of actions is\n // play, video element will seek to 0 (skipping the setCurrentTime middleware)\n // then triggers a play event.\n play: function play() {\n if (player.vhs && player.currentSource().src === player.vhs.source_.src) {\n player.vhs.setCurrentTime(player.currentTime());\n }\n }\n };\n});\n/**\n * @file videojs-http-streaming.js\n *\n * The main file for the HLS project.\n * License: https://github.com/videojs/videojs-http-streaming/blob/master/LICENSE\n */\n\nvar Hls$1 = {\n PlaylistLoader: PlaylistLoader,\n Playlist: Playlist,\n Decrypter: Decrypter,\n AsyncStream: AsyncStream,\n decrypt: decrypt,\n utils: utils,\n STANDARD_PLAYLIST_SELECTOR: lastBandwidthSelector,\n INITIAL_PLAYLIST_SELECTOR: lowestBitrateCompatibleVariantSelector,\n comparePlaylistBandwidth: comparePlaylistBandwidth,\n comparePlaylistResolution: comparePlaylistResolution,\n xhr: xhrFactory()\n}; // Define getter/setters for config properites\n\n['GOAL_BUFFER_LENGTH', 'MAX_GOAL_BUFFER_LENGTH', 'GOAL_BUFFER_LENGTH_RATE', 'BUFFER_LOW_WATER_LINE', 'MAX_BUFFER_LOW_WATER_LINE', 'BUFFER_LOW_WATER_LINE_RATE', 'BANDWIDTH_VARIANCE'].forEach(function (prop) {\n Object.defineProperty(Hls$1, prop, {\n get: function get$$1() {\n videojs$1.log.warn('using Hls.' + prop + ' is UNSAFE be sure you know what you are doing');\n return Config[prop];\n },\n set: function set$$1(value) {\n videojs$1.log.warn('using Hls.' + prop + ' is UNSAFE be sure you know what you are doing');\n\n if (typeof value !== 'number' || value < 0) {\n videojs$1.log.warn('value of Hls.' + prop + ' must be greater than or equal to 0');\n return;\n }\n\n Config[prop] = value;\n }\n });\n});\nvar LOCAL_STORAGE_KEY$1 = 'videojs-vhs';\n\nvar simpleTypeFromSourceType = function simpleTypeFromSourceType(type) {\n var mpegurlRE = /^(audio|video|application)\\/(x-|vnd\\.apple\\.)?mpegurl/i;\n\n if (mpegurlRE.test(type)) {\n return 'hls';\n }\n\n var dashRE = /^application\\/dash\\+xml/i;\n\n if (dashRE.test(type)) {\n return 'dash';\n }\n\n return null;\n};\n/**\n * Updates the selectedIndex of the QualityLevelList when a mediachange happens in hls.\n *\n * @param {QualityLevelList} qualityLevels The QualityLevelList to update.\n * @param {PlaylistLoader} playlistLoader PlaylistLoader containing the new media info.\n * @function handleHlsMediaChange\n */\n\n\nvar handleHlsMediaChange = function handleHlsMediaChange(qualityLevels, playlistLoader) {\n var newPlaylist = playlistLoader.media();\n var selectedIndex = -1;\n\n for (var i = 0; i < qualityLevels.length; i++) {\n if (qualityLevels[i].id === newPlaylist.uri) {\n selectedIndex = i;\n break;\n }\n }\n\n qualityLevels.selectedIndex_ = selectedIndex;\n qualityLevels.trigger({\n selectedIndex: selectedIndex,\n type: 'change'\n });\n};\n/**\n * Adds quality levels to list once playlist metadata is available\n *\n * @param {QualityLevelList} qualityLevels The QualityLevelList to attach events to.\n * @param {Object} hls Hls object to listen to for media events.\n * @function handleHlsLoadedMetadata\n */\n\n\nvar handleHlsLoadedMetadata = function handleHlsLoadedMetadata(qualityLevels, hls) {\n hls.representations().forEach(function (rep) {\n qualityLevels.addQualityLevel(rep);\n });\n handleHlsMediaChange(qualityLevels, hls.playlists);\n}; // HLS is a source handler, not a tech. Make sure attempts to use it\n// as one do not cause exceptions.\n\n\nHls$1.canPlaySource = function () {\n return videojs$1.log.warn('HLS is no longer a tech. Please remove it from ' + 'your player\\'s techOrder.');\n};\n\nvar emeKeySystems = function emeKeySystems(keySystemOptions, videoPlaylist, audioPlaylist) {\n if (!keySystemOptions) {\n return keySystemOptions;\n } // upsert the content types based on the selected playlist\n\n\n var keySystemContentTypes = {};\n\n for (var keySystem in keySystemOptions) {\n keySystemContentTypes[keySystem] = {\n audioContentType: 'audio/mp4; codecs=\"' + audioPlaylist.attributes.CODECS + '\"',\n videoContentType: 'video/mp4; codecs=\"' + videoPlaylist.attributes.CODECS + '\"'\n };\n\n if (videoPlaylist.contentProtection && videoPlaylist.contentProtection[keySystem] && videoPlaylist.contentProtection[keySystem].pssh) {\n keySystemContentTypes[keySystem].pssh = videoPlaylist.contentProtection[keySystem].pssh;\n } // videojs-contrib-eme accepts the option of specifying: 'com.some.cdm': 'url'\n // so we need to prevent overwriting the URL entirely\n\n\n if (typeof keySystemOptions[keySystem] === 'string') {\n keySystemContentTypes[keySystem].url = keySystemOptions[keySystem];\n }\n }\n\n return videojs$1.mergeOptions(keySystemOptions, keySystemContentTypes);\n};\n\nvar setupEmeOptions = function setupEmeOptions(hlsHandler) {\n if (hlsHandler.options_.sourceType !== 'dash') {\n return;\n }\n\n var player = videojs$1.players[hlsHandler.tech_.options_.playerId];\n\n if (player.eme) {\n var sourceOptions = emeKeySystems(hlsHandler.source_.keySystems, hlsHandler.playlists.media(), hlsHandler.masterPlaylistController_.mediaTypes_.AUDIO.activePlaylistLoader.media());\n\n if (sourceOptions) {\n player.currentSource().keySystems = sourceOptions; // works around https://bugs.chromium.org/p/chromium/issues/detail?id=895449\n\n if (player.eme.initializeMediaKeys) {\n player.eme.initializeMediaKeys();\n }\n }\n }\n};\n\nvar getVhsLocalStorage = function getVhsLocalStorage() {\n if (!window.localStorage) {\n return null;\n }\n\n var storedObject = window.localStorage.getItem(LOCAL_STORAGE_KEY$1);\n\n if (!storedObject) {\n return null;\n }\n\n try {\n return JSON.parse(storedObject);\n } catch (e) {\n // someone may have tampered with the value\n return null;\n }\n};\n\nvar updateVhsLocalStorage = function updateVhsLocalStorage(options) {\n if (!window.localStorage) {\n return false;\n }\n\n var objectToStore = getVhsLocalStorage();\n objectToStore = objectToStore ? videojs$1.mergeOptions(objectToStore, options) : options;\n\n try {\n window.localStorage.setItem(LOCAL_STORAGE_KEY$1, JSON.stringify(objectToStore));\n } catch (e) {\n // Throws if storage is full (e.g., always on iOS 5+ Safari private mode, where\n // storage is set to 0).\n // https://developer.mozilla.org/en-US/docs/Web/API/Storage/setItem#Exceptions\n // No need to perform any operation.\n return false;\n }\n\n return objectToStore;\n};\n/**\n * Whether the browser has built-in HLS support.\n */\n\n\nHls$1.supportsNativeHls = function () {\n var video = document.createElement('video'); // native HLS is definitely not supported if HTML5 video isn't\n\n if (!videojs$1.getTech('Html5').isSupported()) {\n return false;\n } // HLS manifests can go by many mime-types\n\n\n var canPlay = [// Apple santioned\n 'application/vnd.apple.mpegurl', // Apple sanctioned for backwards compatibility\n 'audio/mpegurl', // Very common\n 'audio/x-mpegurl', // Very common\n 'application/x-mpegurl', // Included for completeness\n 'video/x-mpegurl', 'video/mpegurl', 'application/mpegurl'];\n return canPlay.some(function (canItPlay) {\n return /maybe|probably/i.test(video.canPlayType(canItPlay));\n });\n}();\n\nHls$1.supportsNativeDash = function () {\n if (!videojs$1.getTech('Html5').isSupported()) {\n return false;\n }\n\n return /maybe|probably/i.test(document.createElement('video').canPlayType('application/dash+xml'));\n}();\n\nHls$1.supportsTypeNatively = function (type) {\n if (type === 'hls') {\n return Hls$1.supportsNativeHls;\n }\n\n if (type === 'dash') {\n return Hls$1.supportsNativeDash;\n }\n\n return false;\n};\n/**\n * HLS is a source handler, not a tech. Make sure attempts to use it\n * as one do not cause exceptions.\n */\n\n\nHls$1.isSupported = function () {\n return videojs$1.log.warn('HLS is no longer a tech. Please remove it from ' + 'your player\\'s techOrder.');\n};\n\nvar Component$1 = videojs$1.getComponent('Component');\n/**\n * The Hls Handler object, where we orchestrate all of the parts\n * of HLS to interact with video.js\n *\n * @class HlsHandler\n * @extends videojs.Component\n * @param {Object} source the soruce object\n * @param {Tech} tech the parent tech object\n * @param {Object} options optional and required options\n */\n\nvar HlsHandler = function (_Component) {\n inherits(HlsHandler, _Component);\n\n function HlsHandler(source, tech, options) {\n classCallCheck(this, HlsHandler); // tech.player() is deprecated but setup a reference to HLS for\n // backwards-compatibility\n\n var _this = possibleConstructorReturn(this, (HlsHandler.__proto__ || Object.getPrototypeOf(HlsHandler)).call(this, tech, options.hls));\n\n if (tech.options_ && tech.options_.playerId) {\n var _player = videojs$1(tech.options_.playerId);\n\n if (!_player.hasOwnProperty('hls')) {\n Object.defineProperty(_player, 'hls', {\n get: function get$$1() {\n videojs$1.log.warn('player.hls is deprecated. Use player.tech().hls instead.');\n tech.trigger({\n type: 'usage',\n name: 'hls-player-access'\n });\n return _this;\n },\n configurable: true\n });\n } // Set up a reference to the HlsHandler from player.vhs. This allows users to start\n // migrating from player.tech_.hls... to player.vhs... for API access. Although this\n // isn't the most appropriate form of reference for video.js (since all APIs should\n // be provided through core video.js), it is a common pattern for plugins, and vhs\n // will act accordingly.\n\n\n _player.vhs = _this; // deprecated, for backwards compatibility\n\n _player.dash = _this;\n _this.player_ = _player;\n }\n\n _this.tech_ = tech;\n _this.source_ = source;\n _this.stats = {};\n\n _this.setOptions_();\n\n if (_this.options_.overrideNative && tech.overrideNativeAudioTracks && tech.overrideNativeVideoTracks) {\n tech.overrideNativeAudioTracks(true);\n tech.overrideNativeVideoTracks(true);\n } else if (_this.options_.overrideNative && (tech.featuresNativeVideoTracks || tech.featuresNativeAudioTracks)) {\n // overriding native HLS only works if audio tracks have been emulated\n // error early if we're misconfigured\n throw new Error('Overriding native HLS requires emulated tracks. ' + 'See https://git.io/vMpjB');\n } // listen for fullscreenchange events for this player so that we\n // can adjust our quality selection quickly\n\n\n _this.on(document, ['fullscreenchange', 'webkitfullscreenchange', 'mozfullscreenchange', 'MSFullscreenChange'], function (event) {\n var fullscreenElement = document.fullscreenElement || document.webkitFullscreenElement || document.mozFullScreenElement || document.msFullscreenElement;\n\n if (fullscreenElement && fullscreenElement.contains(_this.tech_.el())) {\n _this.masterPlaylistController_.smoothQualityChange_();\n }\n }); // Handle seeking when looping - middleware doesn't handle this seek event from the tech\n\n\n _this.on(_this.tech_, 'seeking', function () {\n if (this.tech_.seeking() && this.tech_.currentTime() === 0 && this.tech_.player_.loop()) {\n this.setCurrentTime(0);\n }\n });\n\n _this.on(_this.tech_, 'error', function () {\n if (this.masterPlaylistController_) {\n this.masterPlaylistController_.pauseLoading();\n }\n });\n\n _this.on(_this.tech_, 'play', _this.play);\n\n return _this;\n }\n\n createClass(HlsHandler, [{\n key: 'setOptions_',\n value: function setOptions_() {\n var _this2 = this; // defaults\n\n\n this.options_.withCredentials = this.options_.withCredentials || false;\n this.options_.limitRenditionByPlayerDimensions = this.options_.limitRenditionByPlayerDimensions === false ? false : true;\n this.options_.smoothQualityChange = this.options_.smoothQualityChange || false;\n this.options_.useBandwidthFromLocalStorage = typeof this.source_.useBandwidthFromLocalStorage !== 'undefined' ? this.source_.useBandwidthFromLocalStorage : this.options_.useBandwidthFromLocalStorage || false;\n\n if (typeof this.options_.blacklistDuration !== 'number') {\n this.options_.blacklistDuration = 5 * 60;\n }\n\n if (typeof this.options_.bandwidth !== 'number') {\n if (this.options_.useBandwidthFromLocalStorage) {\n var storedObject = getVhsLocalStorage();\n\n if (storedObject && storedObject.bandwidth) {\n this.options_.bandwidth = storedObject.bandwidth;\n this.tech_.trigger({\n type: 'usage',\n name: 'hls-bandwidth-from-local-storage'\n });\n }\n\n if (storedObject && storedObject.throughput) {\n this.options_.throughput = storedObject.throughput;\n this.tech_.trigger({\n type: 'usage',\n name: 'hls-throughput-from-local-storage'\n });\n }\n }\n } // if bandwidth was not set by options or pulled from local storage, start playlist\n // selection at a reasonable bandwidth\n\n\n if (typeof this.options_.bandwidth !== 'number') {\n this.options_.bandwidth = Config.INITIAL_BANDWIDTH;\n } // If the bandwidth number is unchanged from the initial setting\n // then this takes precedence over the enableLowInitialPlaylist option\n\n\n this.options_.enableLowInitialPlaylist = this.options_.enableLowInitialPlaylist && this.options_.bandwidth === Config.INITIAL_BANDWIDTH; // grab options passed to player.src\n\n ['withCredentials', 'limitRenditionByPlayerDimensions', 'bandwidth', 'smoothQualityChange'].forEach(function (option) {\n if (typeof _this2.source_[option] !== 'undefined') {\n _this2.options_[option] = _this2.source_[option];\n }\n });\n this.limitRenditionByPlayerDimensions = this.options_.limitRenditionByPlayerDimensions;\n }\n /**\n * called when player.src gets called, handle a new source\n *\n * @param {Object} src the source object to handle\n */\n\n }, {\n key: 'src',\n value: function src(_src, type) {\n var _this3 = this; // do nothing if the src is falsey\n\n\n if (!_src) {\n return;\n }\n\n this.setOptions_(); // add master playlist controller options\n\n this.options_.url = this.source_.src;\n this.options_.tech = this.tech_;\n this.options_.externHls = Hls$1;\n this.options_.sourceType = simpleTypeFromSourceType(type); // Whenever we seek internally, we should update both the tech and call our own\n // setCurrentTime function. This is needed because \"seeking\" events aren't always\n // reliable. External seeks (via the player object) are handled via middleware.\n\n this.options_.seekTo = function (time) {\n _this3.tech_.setCurrentTime(time);\n\n _this3.setCurrentTime(time);\n };\n\n this.masterPlaylistController_ = new MasterPlaylistController(this.options_);\n this.playbackWatcher_ = new PlaybackWatcher(videojs$1.mergeOptions(this.options_, {\n seekable: function seekable$$1() {\n return _this3.seekable();\n }\n }));\n this.masterPlaylistController_.on('error', function () {\n var player = videojs$1.players[_this3.tech_.options_.playerId];\n player.error(_this3.masterPlaylistController_.error);\n }); // `this` in selectPlaylist should be the HlsHandler for backwards\n // compatibility with < v2\n\n this.masterPlaylistController_.selectPlaylist = this.selectPlaylist ? this.selectPlaylist.bind(this) : Hls$1.STANDARD_PLAYLIST_SELECTOR.bind(this);\n this.masterPlaylistController_.selectInitialPlaylist = Hls$1.INITIAL_PLAYLIST_SELECTOR.bind(this); // re-expose some internal objects for backwards compatibility with < v2\n\n this.playlists = this.masterPlaylistController_.masterPlaylistLoader_;\n this.mediaSource = this.masterPlaylistController_.mediaSource; // Proxy assignment of some properties to the master playlist\n // controller. Using a custom property for backwards compatibility\n // with < v2\n\n Object.defineProperties(this, {\n selectPlaylist: {\n get: function get$$1() {\n return this.masterPlaylistController_.selectPlaylist;\n },\n set: function set$$1(selectPlaylist) {\n this.masterPlaylistController_.selectPlaylist = selectPlaylist.bind(this);\n }\n },\n throughput: {\n get: function get$$1() {\n return this.masterPlaylistController_.mainSegmentLoader_.throughput.rate;\n },\n set: function set$$1(throughput) {\n this.masterPlaylistController_.mainSegmentLoader_.throughput.rate = throughput; // By setting `count` to 1 the throughput value becomes the starting value\n // for the cumulative average\n\n this.masterPlaylistController_.mainSegmentLoader_.throughput.count = 1;\n }\n },\n bandwidth: {\n get: function get$$1() {\n return this.masterPlaylistController_.mainSegmentLoader_.bandwidth;\n },\n set: function set$$1(bandwidth) {\n this.masterPlaylistController_.mainSegmentLoader_.bandwidth = bandwidth; // setting the bandwidth manually resets the throughput counter\n // `count` is set to zero that current value of `rate` isn't included\n // in the cumulative average\n\n this.masterPlaylistController_.mainSegmentLoader_.throughput = {\n rate: 0,\n count: 0\n };\n }\n },\n\n /**\n * `systemBandwidth` is a combination of two serial processes bit-rates. The first\n * is the network bitrate provided by `bandwidth` and the second is the bitrate of\n * the entire process after that - decryption, transmuxing, and appending - provided\n * by `throughput`.\n *\n * Since the two process are serial, the overall system bandwidth is given by:\n * sysBandwidth = 1 / (1 / bandwidth + 1 / throughput)\n */\n systemBandwidth: {\n get: function get$$1() {\n var invBandwidth = 1 / (this.bandwidth || 1);\n var invThroughput = void 0;\n\n if (this.throughput > 0) {\n invThroughput = 1 / this.throughput;\n } else {\n invThroughput = 0;\n }\n\n var systemBitrate = Math.floor(1 / (invBandwidth + invThroughput));\n return systemBitrate;\n },\n set: function set$$1() {\n videojs$1.log.error('The \"systemBandwidth\" property is read-only');\n }\n }\n });\n\n if (this.options_.bandwidth) {\n this.bandwidth = this.options_.bandwidth;\n }\n\n if (this.options_.throughput) {\n this.throughput = this.options_.throughput;\n }\n\n Object.defineProperties(this.stats, {\n bandwidth: {\n get: function get$$1() {\n return _this3.bandwidth || 0;\n },\n enumerable: true\n },\n mediaRequests: {\n get: function get$$1() {\n return _this3.masterPlaylistController_.mediaRequests_() || 0;\n },\n enumerable: true\n },\n mediaRequestsAborted: {\n get: function get$$1() {\n return _this3.masterPlaylistController_.mediaRequestsAborted_() || 0;\n },\n enumerable: true\n },\n mediaRequestsTimedout: {\n get: function get$$1() {\n return _this3.masterPlaylistController_.mediaRequestsTimedout_() || 0;\n },\n enumerable: true\n },\n mediaRequestsErrored: {\n get: function get$$1() {\n return _this3.masterPlaylistController_.mediaRequestsErrored_() || 0;\n },\n enumerable: true\n },\n mediaTransferDuration: {\n get: function get$$1() {\n return _this3.masterPlaylistController_.mediaTransferDuration_() || 0;\n },\n enumerable: true\n },\n mediaBytesTransferred: {\n get: function get$$1() {\n return _this3.masterPlaylistController_.mediaBytesTransferred_() || 0;\n },\n enumerable: true\n },\n mediaSecondsLoaded: {\n get: function get$$1() {\n return _this3.masterPlaylistController_.mediaSecondsLoaded_() || 0;\n },\n enumerable: true\n },\n buffered: {\n get: function get$$1() {\n return timeRangesToArray(_this3.tech_.buffered());\n },\n enumerable: true\n },\n currentTime: {\n get: function get$$1() {\n return _this3.tech_.currentTime();\n },\n enumerable: true\n },\n currentSource: {\n get: function get$$1() {\n return _this3.tech_.currentSource_;\n },\n enumerable: true\n },\n currentTech: {\n get: function get$$1() {\n return _this3.tech_.name_;\n },\n enumerable: true\n },\n duration: {\n get: function get$$1() {\n return _this3.tech_.duration();\n },\n enumerable: true\n },\n master: {\n get: function get$$1() {\n return _this3.playlists.master;\n },\n enumerable: true\n },\n playerDimensions: {\n get: function get$$1() {\n return _this3.tech_.currentDimensions();\n },\n enumerable: true\n },\n seekable: {\n get: function get$$1() {\n return timeRangesToArray(_this3.tech_.seekable());\n },\n enumerable: true\n },\n timestamp: {\n get: function get$$1() {\n return Date.now();\n },\n enumerable: true\n },\n videoPlaybackQuality: {\n get: function get$$1() {\n return _this3.tech_.getVideoPlaybackQuality();\n },\n enumerable: true\n }\n });\n this.tech_.one('canplay', this.masterPlaylistController_.setupFirstPlay.bind(this.masterPlaylistController_));\n this.tech_.on('bandwidthupdate', function () {\n if (_this3.options_.useBandwidthFromLocalStorage) {\n updateVhsLocalStorage({\n bandwidth: _this3.bandwidth,\n throughput: Math.round(_this3.throughput)\n });\n }\n });\n this.masterPlaylistController_.on('selectedinitialmedia', function () {\n // Add the manual rendition mix-in to HlsHandler\n renditionSelectionMixin(_this3);\n setupEmeOptions(_this3);\n }); // the bandwidth of the primary segment loader is our best\n // estimate of overall bandwidth\n\n this.on(this.masterPlaylistController_, 'progress', function () {\n this.tech_.trigger('progress');\n });\n this.tech_.ready(function () {\n return _this3.setupQualityLevels_();\n }); // do nothing if the tech has been disposed already\n // this can occur if someone sets the src in player.ready(), for instance\n\n if (!this.tech_.el()) {\n return;\n }\n\n this.tech_.src(videojs$1.URL.createObjectURL(this.masterPlaylistController_.mediaSource));\n }\n /**\n * Initializes the quality levels and sets listeners to update them.\n *\n * @method setupQualityLevels_\n * @private\n */\n\n }, {\n key: 'setupQualityLevels_',\n value: function setupQualityLevels_() {\n var _this4 = this;\n\n var player = videojs$1.players[this.tech_.options_.playerId];\n\n if (player && player.qualityLevels) {\n this.qualityLevels_ = player.qualityLevels();\n this.masterPlaylistController_.on('selectedinitialmedia', function () {\n handleHlsLoadedMetadata(_this4.qualityLevels_, _this4);\n });\n this.playlists.on('mediachange', function () {\n handleHlsMediaChange(_this4.qualityLevels_, _this4.playlists);\n });\n }\n }\n /**\n * Begin playing the video.\n */\n\n }, {\n key: 'play',\n value: function play() {\n this.masterPlaylistController_.play();\n }\n /**\n * a wrapper around the function in MasterPlaylistController\n */\n\n }, {\n key: 'setCurrentTime',\n value: function setCurrentTime(currentTime) {\n this.masterPlaylistController_.setCurrentTime(currentTime);\n }\n /**\n * a wrapper around the function in MasterPlaylistController\n */\n\n }, {\n key: 'duration',\n value: function duration$$1() {\n return this.masterPlaylistController_.duration();\n }\n /**\n * a wrapper around the function in MasterPlaylistController\n */\n\n }, {\n key: 'seekable',\n value: function seekable$$1() {\n return this.masterPlaylistController_.seekable();\n }\n /**\n * Abort all outstanding work and cleanup.\n */\n\n }, {\n key: 'dispose',\n value: function dispose() {\n if (this.playbackWatcher_) {\n this.playbackWatcher_.dispose();\n }\n\n if (this.masterPlaylistController_) {\n this.masterPlaylistController_.dispose();\n }\n\n if (this.qualityLevels_) {\n this.qualityLevels_.dispose();\n }\n\n if (this.player_) {\n delete this.player_.vhs;\n delete this.player_.dash;\n delete this.player_.hls;\n }\n\n if (this.tech_ && this.tech_.hls) {\n delete this.tech_.hls;\n }\n\n get$1(HlsHandler.prototype.__proto__ || Object.getPrototypeOf(HlsHandler.prototype), 'dispose', this).call(this);\n }\n }, {\n key: 'convertToStreamTime',\n value: function convertToStreamTime(time, callback) {\n return getStreamTime({\n playlist: this.masterPlaylistController_.media(),\n time: time,\n callback: callback\n });\n } // the player must be playing before calling this\n\n }, {\n key: 'seekToStreamTime',\n value: function seekToStreamTime$$1(streamTime, callback) {\n var pauseAfterSeek = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;\n var retryCount = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 2;\n return seekToStreamTime({\n streamTime: streamTime,\n playlist: this.masterPlaylistController_.media(),\n retryCount: retryCount,\n pauseAfterSeek: pauseAfterSeek,\n seekTo: this.options_.seekTo,\n tech: this.options_.tech,\n callback: callback\n });\n }\n }]);\n return HlsHandler;\n}(Component$1);\n/**\n * The Source Handler object, which informs video.js what additional\n * MIME types are supported and sets up playback. It is registered\n * automatically to the appropriate tech based on the capabilities of\n * the browser it is running in. It is not necessary to use or modify\n * this object in normal usage.\n */\n\n\nvar HlsSourceHandler = {\n name: 'videojs-http-streaming',\n VERSION: version$1,\n canHandleSource: function canHandleSource(srcObj) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var localOptions = videojs$1.mergeOptions(videojs$1.options, options);\n return HlsSourceHandler.canPlayType(srcObj.type, localOptions);\n },\n handleSource: function handleSource(source, tech) {\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n var localOptions = videojs$1.mergeOptions(videojs$1.options, options);\n tech.hls = new HlsHandler(source, tech, localOptions);\n tech.hls.xhr = xhrFactory();\n tech.hls.src(source.src, source.type);\n return tech.hls;\n },\n canPlayType: function canPlayType(type) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n var _videojs$mergeOptions = videojs$1.mergeOptions(videojs$1.options, options),\n overrideNative = _videojs$mergeOptions.hls.overrideNative;\n\n var supportedType = simpleTypeFromSourceType(type);\n var canUseMsePlayback = supportedType && (!Hls$1.supportsTypeNatively(supportedType) || overrideNative);\n return canUseMsePlayback ? 'maybe' : '';\n }\n};\n\nif (typeof videojs$1.MediaSource === 'undefined' || typeof videojs$1.URL === 'undefined') {\n videojs$1.MediaSource = MediaSource;\n videojs$1.URL = URL$1;\n} // register source handlers with the appropriate techs\n\n\nif (MediaSource.supportsNativeMediaSources()) {\n videojs$1.getTech('Html5').registerSourceHandler(HlsSourceHandler, 0);\n}\n\nvideojs$1.HlsHandler = HlsHandler;\nvideojs$1.HlsSourceHandler = HlsSourceHandler;\nvideojs$1.Hls = Hls$1;\n\nif (!videojs$1.use) {\n videojs$1.registerComponent('Hls', Hls$1);\n}\n\nvideojs$1.options.hls = videojs$1.options.hls || {};\n\nif (videojs$1.registerPlugin) {\n videojs$1.registerPlugin('reloadSourceOnError', reloadSourceOnError);\n} else {\n videojs$1.plugin('reloadSourceOnError', reloadSourceOnError);\n}\n\nexport default videojs$1;\n","/**\n * mux.js\n *\n * Copyright (c) 2014 Brightcove\n * All rights reserved.\n *\n * A lightweight readable stream implemention that handles event dispatching.\n * Objects that inherit from streams should call init in their constructors.\n */\n'use strict';\n\nvar Stream = function() {\n this.init = function() {\n var listeners = {};\n /**\n * Add a listener for a specified event type.\n * @param type {string} the event name\n * @param listener {function} the callback to be invoked when an event of\n * the specified type occurs\n */\n this.on = function(type, listener) {\n if (!listeners[type]) {\n listeners[type] = [];\n }\n listeners[type] = listeners[type].concat(listener);\n };\n /**\n * Remove a listener for a specified event type.\n * @param type {string} the event name\n * @param listener {function} a function previously registered for this\n * type of event through `on`\n */\n this.off = function(type, listener) {\n var index;\n if (!listeners[type]) {\n return false;\n }\n index = listeners[type].indexOf(listener);\n listeners[type] = listeners[type].slice();\n listeners[type].splice(index, 1);\n return index > -1;\n };\n /**\n * Trigger an event of the specified type on this stream. Any additional\n * arguments to this function are passed as parameters to event listeners.\n * @param type {string} the event name\n */\n this.trigger = function(type) {\n var callbacks, i, length, args;\n callbacks = listeners[type];\n if (!callbacks) {\n return;\n }\n // Slicing the arguments on every invocation of this method\n // can add a significant amount of overhead. Avoid the\n // intermediate object creation for the common case of a\n // single callback argument\n if (arguments.length === 2) {\n length = callbacks.length;\n for (i = 0; i < length; ++i) {\n callbacks[i].call(this, arguments[1]);\n }\n } else {\n args = [];\n i = arguments.length;\n for (i = 1; i < arguments.length; ++i) {\n args.push(arguments[i]);\n }\n length = callbacks.length;\n for (i = 0; i < length; ++i) {\n callbacks[i].apply(this, args);\n }\n }\n };\n /**\n * Destroys the stream and cleans up.\n */\n this.dispose = function() {\n listeners = {};\n };\n };\n};\n\n/**\n * Forwards all `data` events on this stream to the destination stream. The\n * destination stream should provide a method `push` to receive the data\n * events as they arrive.\n * @param destination {stream} the stream that will receive all `data` events\n * @param autoFlush {boolean} if false, we will not call `flush` on the destination\n * when the current stream emits a 'done' event\n * @see http://nodejs.org/api/stream.html#stream_readable_pipe_destination_options\n */\nStream.prototype.pipe = function(destination) {\n this.on('data', function(data) {\n destination.push(data);\n });\n\n this.on('done', function(flushSource) {\n destination.flush(flushSource);\n });\n\n return destination;\n};\n\n// Default stream functions that are expected to be overridden to perform\n// actual work. These are provided by the prototype as a sort of no-op\n// implementation so that we don't have to check for their existence in the\n// `pipe` function above.\nStream.prototype.push = function(data) {\n this.trigger('data', data);\n};\n\nStream.prototype.flush = function(flushSource) {\n this.trigger('done', flushSource);\n};\n\nmodule.exports = Stream;\n","'use strict';\n\nmodule.exports = {\n H264_STREAM_TYPE: 0x1B,\n ADTS_STREAM_TYPE: 0x0F,\n METADATA_STREAM_TYPE: 0x15\n};\n","var win;\n\nif (typeof window !== \"undefined\") {\n win = window;\n} else if (typeof global !== \"undefined\") {\n win = global;\n} else if (typeof self !== \"undefined\"){\n win = self;\n} else {\n win = {};\n}\n\nmodule.exports = win;\n","/**\n * mux.js\n *\n * Copyright (c) 2015 Brightcove\n * All rights reserved.\n *\n * Utilities to detect basic properties and metadata about MP4s.\n */\n'use strict';\n\nvar toUnsigned = require('../utils/bin').toUnsigned;\nvar findBox, parseType, timescale, startTime, getVideoTrackIds;\n\n// Find the data for a box specified by its path\nfindBox = function(data, path) {\n var results = [],\n i, size, type, end, subresults;\n\n if (!path.length) {\n // short-circuit the search for empty paths\n return null;\n }\n\n for (i = 0; i < data.byteLength;) {\n size = toUnsigned(data[i] << 24 |\n data[i + 1] << 16 |\n data[i + 2] << 8 |\n data[i + 3]);\n\n type = parseType(data.subarray(i + 4, i + 8));\n\n end = size > 1 ? i + size : data.byteLength;\n\n if (type === path[0]) {\n if (path.length === 1) {\n // this is the end of the path and we've found the box we were\n // looking for\n results.push(data.subarray(i + 8, end));\n } else {\n // recursively search for the next box along the path\n subresults = findBox(data.subarray(i + 8, end), path.slice(1));\n if (subresults.length) {\n results = results.concat(subresults);\n }\n }\n }\n i = end;\n }\n\n // we've finished searching all of data\n return results;\n};\n\n/**\n * Returns the string representation of an ASCII encoded four byte buffer.\n * @param buffer {Uint8Array} a four-byte buffer to translate\n * @return {string} the corresponding string\n */\nparseType = function(buffer) {\n var result = '';\n result += String.fromCharCode(buffer[0]);\n result += String.fromCharCode(buffer[1]);\n result += String.fromCharCode(buffer[2]);\n result += String.fromCharCode(buffer[3]);\n return result;\n};\n\n/**\n * Parses an MP4 initialization segment and extracts the timescale\n * values for any declared tracks. Timescale values indicate the\n * number of clock ticks per second to assume for time-based values\n * elsewhere in the MP4.\n *\n * To determine the start time of an MP4, you need two pieces of\n * information: the timescale unit and the earliest base media decode\n * time. Multiple timescales can be specified within an MP4 but the\n * base media decode time is always expressed in the timescale from\n * the media header box for the track:\n * ```\n * moov > trak > mdia > mdhd.timescale\n * ```\n * @param init {Uint8Array} the bytes of the init segment\n * @return {object} a hash of track ids to timescale values or null if\n * the init segment is malformed.\n */\ntimescale = function(init) {\n var\n result = {},\n traks = findBox(init, ['moov', 'trak']);\n\n // mdhd timescale\n return traks.reduce(function(result, trak) {\n var tkhd, version, index, id, mdhd;\n\n tkhd = findBox(trak, ['tkhd'])[0];\n if (!tkhd) {\n return null;\n }\n version = tkhd[0];\n index = version === 0 ? 12 : 20;\n id = toUnsigned(tkhd[index] << 24 |\n tkhd[index + 1] << 16 |\n tkhd[index + 2] << 8 |\n tkhd[index + 3]);\n\n mdhd = findBox(trak, ['mdia', 'mdhd'])[0];\n if (!mdhd) {\n return null;\n }\n version = mdhd[0];\n index = version === 0 ? 12 : 20;\n result[id] = toUnsigned(mdhd[index] << 24 |\n mdhd[index + 1] << 16 |\n mdhd[index + 2] << 8 |\n mdhd[index + 3]);\n return result;\n }, result);\n};\n\n/**\n * Determine the base media decode start time, in seconds, for an MP4\n * fragment. If multiple fragments are specified, the earliest time is\n * returned.\n *\n * The base media decode time can be parsed from track fragment\n * metadata:\n * ```\n * moof > traf > tfdt.baseMediaDecodeTime\n * ```\n * It requires the timescale value from the mdhd to interpret.\n *\n * @param timescale {object} a hash of track ids to timescale values.\n * @return {number} the earliest base media decode start time for the\n * fragment, in seconds\n */\nstartTime = function(timescale, fragment) {\n var trafs, baseTimes, result;\n\n // we need info from two childrend of each track fragment box\n trafs = findBox(fragment, ['moof', 'traf']);\n\n // determine the start times for each track\n baseTimes = [].concat.apply([], trafs.map(function(traf) {\n return findBox(traf, ['tfhd']).map(function(tfhd) {\n var id, scale, baseTime;\n\n // get the track id from the tfhd\n id = toUnsigned(tfhd[4] << 24 |\n tfhd[5] << 16 |\n tfhd[6] << 8 |\n tfhd[7]);\n // assume a 90kHz clock if no timescale was specified\n scale = timescale[id] || 90e3;\n\n // get the base media decode time from the tfdt\n baseTime = findBox(traf, ['tfdt']).map(function(tfdt) {\n var version, result;\n\n version = tfdt[0];\n result = toUnsigned(tfdt[4] << 24 |\n tfdt[5] << 16 |\n tfdt[6] << 8 |\n tfdt[7]);\n if (version === 1) {\n result *= Math.pow(2, 32);\n result += toUnsigned(tfdt[8] << 24 |\n tfdt[9] << 16 |\n tfdt[10] << 8 |\n tfdt[11]);\n }\n return result;\n })[0];\n baseTime = baseTime || Infinity;\n\n // convert base time to seconds\n return baseTime / scale;\n });\n }));\n\n // return the minimum\n result = Math.min.apply(null, baseTimes);\n return isFinite(result) ? result : 0;\n};\n\n/**\n * Find the trackIds of the video tracks in this source.\n * Found by parsing the Handler Reference and Track Header Boxes:\n * moov > trak > mdia > hdlr\n * moov > trak > tkhd\n *\n * @param {Uint8Array} init - The bytes of the init segment for this source\n * @return {Number[]} A list of trackIds\n *\n * @see ISO-BMFF-12/2015, Section 8.4.3\n **/\ngetVideoTrackIds = function(init) {\n var traks = findBox(init, ['moov', 'trak']);\n var videoTrackIds = [];\n\n traks.forEach(function(trak) {\n var hdlrs = findBox(trak, ['mdia', 'hdlr']);\n var tkhds = findBox(trak, ['tkhd']);\n\n hdlrs.forEach(function(hdlr, index) {\n var handlerType = parseType(hdlr.subarray(8, 12));\n var tkhd = tkhds[index];\n var view;\n var version;\n var trackId;\n\n if (handlerType === 'vide') {\n view = new DataView(tkhd.buffer, tkhd.byteOffset, tkhd.byteLength);\n version = view.getUint8(0);\n trackId = (version === 0) ? view.getUint32(12) : view.getUint32(20);\n\n videoTrackIds.push(trackId);\n }\n });\n });\n\n return videoTrackIds;\n};\n\nmodule.exports = {\n findBox: findBox,\n parseType: parseType,\n timescale: timescale,\n startTime: startTime,\n videoTrackIds: getVideoTrackIds\n};\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","/**\n * mux.js\n *\n * Copyright (c) 2015 Brightcove\n * All rights reserved.\n *\n * A stream-based mp2t to mp4 converter. This utility can be used to\n * deliver mp4s to a SourceBuffer on platforms that support native\n * Media Source Extensions.\n */\n'use strict';\n\nvar Stream = require('../utils/stream.js');\nvar mp4 = require('./mp4-generator.js');\nvar frameUtils = require('./frame-utils');\nvar audioFrameUtils = require('./audio-frame-utils');\nvar trackDecodeInfo = require('./track-decode-info');\nvar m2ts = require('../m2ts/m2ts.js');\nvar AdtsStream = require('../codecs/adts.js');\nvar H264Stream = require('../codecs/h264').H264Stream;\nvar AacStream = require('../aac');\nvar isLikelyAacData = require('../aac/utils').isLikelyAacData;\n\n// constants\nvar AUDIO_PROPERTIES = [\n 'audioobjecttype',\n 'channelcount',\n 'samplerate',\n 'samplingfrequencyindex',\n 'samplesize'\n];\n\nvar VIDEO_PROPERTIES = [\n 'width',\n 'height',\n 'profileIdc',\n 'levelIdc',\n 'profileCompatibility'\n];\n\n// object types\nvar VideoSegmentStream, AudioSegmentStream, Transmuxer, CoalesceStream;\n\n/**\n * Compare two arrays (even typed) for same-ness\n */\nvar arrayEquals = function(a, b) {\n var\n i;\n\n if (a.length !== b.length) {\n return false;\n }\n\n // compare the value of each element in the array\n for (i = 0; i < a.length; i++) {\n if (a[i] !== b[i]) {\n return false;\n }\n }\n\n return true;\n};\n\n/**\n * Constructs a single-track, ISO BMFF media segment from AAC data\n * events. The output of this stream can be fed to a SourceBuffer\n * configured with a suitable initialization segment.\n * @param track {object} track metadata configuration\n * @param options {object} transmuxer options object\n * @param options.keepOriginalTimestamps {boolean} If true, keep the timestamps\n * in the source; false to adjust the first segment to start at 0.\n */\nAudioSegmentStream = function(track, options) {\n var\n adtsFrames = [],\n sequenceNumber = 0,\n earliestAllowedDts = 0,\n audioAppendStartTs = 0,\n videoBaseMediaDecodeTime = Infinity;\n\n options = options || {};\n\n AudioSegmentStream.prototype.init.call(this);\n\n this.push = function(data) {\n trackDecodeInfo.collectDtsInfo(track, data);\n\n if (track) {\n AUDIO_PROPERTIES.forEach(function(prop) {\n track[prop] = data[prop];\n });\n }\n\n // buffer audio data until end() is called\n adtsFrames.push(data);\n };\n\n this.setEarliestDts = function(earliestDts) {\n earliestAllowedDts = earliestDts - track.timelineStartInfo.baseMediaDecodeTime;\n };\n\n this.setVideoBaseMediaDecodeTime = function(baseMediaDecodeTime) {\n videoBaseMediaDecodeTime = baseMediaDecodeTime;\n };\n\n this.setAudioAppendStart = function(timestamp) {\n audioAppendStartTs = timestamp;\n };\n\n this.flush = function() {\n var\n frames,\n moof,\n mdat,\n boxes;\n\n // return early if no audio data has been observed\n if (adtsFrames.length === 0) {\n this.trigger('done', 'AudioSegmentStream');\n return;\n }\n\n frames = audioFrameUtils.trimAdtsFramesByEarliestDts(\n adtsFrames, track, earliestAllowedDts);\n track.baseMediaDecodeTime = trackDecodeInfo.calculateTrackBaseMediaDecodeTime(\n track, options.keepOriginalTimestamps);\n\n audioFrameUtils.prefixWithSilence(\n track, frames, audioAppendStartTs, videoBaseMediaDecodeTime);\n\n // we have to build the index from byte locations to\n // samples (that is, adts frames) in the audio data\n track.samples = audioFrameUtils.generateSampleTable(frames);\n\n // concatenate the audio data to constuct the mdat\n mdat = mp4.mdat(audioFrameUtils.concatenateFrameData(frames));\n\n adtsFrames = [];\n\n moof = mp4.moof(sequenceNumber, [track]);\n boxes = new Uint8Array(moof.byteLength + mdat.byteLength);\n\n // bump the sequence number for next time\n sequenceNumber++;\n\n boxes.set(moof);\n boxes.set(mdat, moof.byteLength);\n\n trackDecodeInfo.clearDtsInfo(track);\n\n this.trigger('data', {track: track, boxes: boxes});\n this.trigger('done', 'AudioSegmentStream');\n };\n};\n\nAudioSegmentStream.prototype = new Stream();\n\n/**\n * Constructs a single-track, ISO BMFF media segment from H264 data\n * events. The output of this stream can be fed to a SourceBuffer\n * configured with a suitable initialization segment.\n * @param track {object} track metadata configuration\n * @param options {object} transmuxer options object\n * @param options.alignGopsAtEnd {boolean} If true, start from the end of the\n * gopsToAlignWith list when attempting to align gop pts\n * @param options.keepOriginalTimestamps {boolean} If true, keep the timestamps\n * in the source; false to adjust the first segment to start at 0.\n */\nVideoSegmentStream = function(track, options) {\n var\n sequenceNumber = 0,\n nalUnits = [],\n gopsToAlignWith = [],\n config,\n pps;\n\n options = options || {};\n\n VideoSegmentStream.prototype.init.call(this);\n\n delete track.minPTS;\n\n this.gopCache_ = [];\n\n /**\n * Constructs a ISO BMFF segment given H264 nalUnits\n * @param {Object} nalUnit A data event representing a nalUnit\n * @param {String} nalUnit.nalUnitType\n * @param {Object} nalUnit.config Properties for a mp4 track\n * @param {Uint8Array} nalUnit.data The nalUnit bytes\n * @see lib/codecs/h264.js\n **/\n this.push = function(nalUnit) {\n trackDecodeInfo.collectDtsInfo(track, nalUnit);\n\n // record the track config\n if (nalUnit.nalUnitType === 'seq_parameter_set_rbsp' && !config) {\n config = nalUnit.config;\n track.sps = [nalUnit.data];\n\n VIDEO_PROPERTIES.forEach(function(prop) {\n track[prop] = config[prop];\n }, this);\n }\n\n if (nalUnit.nalUnitType === 'pic_parameter_set_rbsp' &&\n !pps) {\n pps = nalUnit.data;\n track.pps = [nalUnit.data];\n }\n\n // buffer video until flush() is called\n nalUnits.push(nalUnit);\n };\n\n /**\n * Pass constructed ISO BMFF track and boxes on to the\n * next stream in the pipeline\n **/\n this.flush = function() {\n var\n frames,\n gopForFusion,\n gops,\n moof,\n mdat,\n boxes;\n\n // Throw away nalUnits at the start of the byte stream until\n // we find the first AUD\n while (nalUnits.length) {\n if (nalUnits[0].nalUnitType === 'access_unit_delimiter_rbsp') {\n break;\n }\n nalUnits.shift();\n }\n\n // Return early if no video data has been observed\n if (nalUnits.length === 0) {\n this.resetStream_();\n this.trigger('done', 'VideoSegmentStream');\n return;\n }\n\n // Organize the raw nal-units into arrays that represent\n // higher-level constructs such as frames and gops\n // (group-of-pictures)\n frames = frameUtils.groupNalsIntoFrames(nalUnits);\n gops = frameUtils.groupFramesIntoGops(frames);\n\n // If the first frame of this fragment is not a keyframe we have\n // a problem since MSE (on Chrome) requires a leading keyframe.\n //\n // We have two approaches to repairing this situation:\n // 1) GOP-FUSION:\n // This is where we keep track of the GOPS (group-of-pictures)\n // from previous fragments and attempt to find one that we can\n // prepend to the current fragment in order to create a valid\n // fragment.\n // 2) KEYFRAME-PULLING:\n // Here we search for the first keyframe in the fragment and\n // throw away all the frames between the start of the fragment\n // and that keyframe. We then extend the duration and pull the\n // PTS of the keyframe forward so that it covers the time range\n // of the frames that were disposed of.\n //\n // #1 is far prefereable over #2 which can cause \"stuttering\" but\n // requires more things to be just right.\n if (!gops[0][0].keyFrame) {\n // Search for a gop for fusion from our gopCache\n gopForFusion = this.getGopForFusion_(nalUnits[0], track);\n\n if (gopForFusion) {\n gops.unshift(gopForFusion);\n // Adjust Gops' metadata to account for the inclusion of the\n // new gop at the beginning\n gops.byteLength += gopForFusion.byteLength;\n gops.nalCount += gopForFusion.nalCount;\n gops.pts = gopForFusion.pts;\n gops.dts = gopForFusion.dts;\n gops.duration += gopForFusion.duration;\n } else {\n // If we didn't find a candidate gop fall back to keyframe-pulling\n gops = frameUtils.extendFirstKeyFrame(gops);\n }\n }\n\n // Trim gops to align with gopsToAlignWith\n if (gopsToAlignWith.length) {\n var alignedGops;\n\n if (options.alignGopsAtEnd) {\n alignedGops = this.alignGopsAtEnd_(gops);\n } else {\n alignedGops = this.alignGopsAtStart_(gops);\n }\n\n if (!alignedGops) {\n // save all the nals in the last GOP into the gop cache\n this.gopCache_.unshift({\n gop: gops.pop(),\n pps: track.pps,\n sps: track.sps\n });\n\n // Keep a maximum of 6 GOPs in the cache\n this.gopCache_.length = Math.min(6, this.gopCache_.length);\n\n // Clear nalUnits\n nalUnits = [];\n\n // return early no gops can be aligned with desired gopsToAlignWith\n this.resetStream_();\n this.trigger('done', 'VideoSegmentStream');\n return;\n }\n\n // Some gops were trimmed. clear dts info so minSegmentDts and pts are correct\n // when recalculated before sending off to CoalesceStream\n trackDecodeInfo.clearDtsInfo(track);\n\n gops = alignedGops;\n }\n\n trackDecodeInfo.collectDtsInfo(track, gops);\n\n // First, we have to build the index from byte locations to\n // samples (that is, frames) in the video data\n track.samples = frameUtils.generateSampleTable(gops);\n\n // Concatenate the video data and construct the mdat\n mdat = mp4.mdat(frameUtils.concatenateNalData(gops));\n\n track.baseMediaDecodeTime = trackDecodeInfo.calculateTrackBaseMediaDecodeTime(\n track, options.keepOriginalTimestamps);\n\n this.trigger('processedGopsInfo', gops.map(function(gop) {\n return {\n pts: gop.pts,\n dts: gop.dts,\n byteLength: gop.byteLength\n };\n }));\n\n // save all the nals in the last GOP into the gop cache\n this.gopCache_.unshift({\n gop: gops.pop(),\n pps: track.pps,\n sps: track.sps\n });\n\n // Keep a maximum of 6 GOPs in the cache\n this.gopCache_.length = Math.min(6, this.gopCache_.length);\n\n // Clear nalUnits\n nalUnits = [];\n\n this.trigger('baseMediaDecodeTime', track.baseMediaDecodeTime);\n this.trigger('timelineStartInfo', track.timelineStartInfo);\n\n moof = mp4.moof(sequenceNumber, [track]);\n\n // it would be great to allocate this array up front instead of\n // throwing away hundreds of media segment fragments\n boxes = new Uint8Array(moof.byteLength + mdat.byteLength);\n\n // Bump the sequence number for next time\n sequenceNumber++;\n\n boxes.set(moof);\n boxes.set(mdat, moof.byteLength);\n\n this.trigger('data', {track: track, boxes: boxes});\n\n this.resetStream_();\n\n // Continue with the flush process now\n this.trigger('done', 'VideoSegmentStream');\n };\n\n this.resetStream_ = function() {\n trackDecodeInfo.clearDtsInfo(track);\n\n // reset config and pps because they may differ across segments\n // for instance, when we are rendition switching\n config = undefined;\n pps = undefined;\n };\n\n // Search for a candidate Gop for gop-fusion from the gop cache and\n // return it or return null if no good candidate was found\n this.getGopForFusion_ = function(nalUnit) {\n var\n halfSecond = 45000, // Half-a-second in a 90khz clock\n allowableOverlap = 10000, // About 3 frames @ 30fps\n nearestDistance = Infinity,\n dtsDistance,\n nearestGopObj,\n currentGop,\n currentGopObj,\n i;\n\n // Search for the GOP nearest to the beginning of this nal unit\n for (i = 0; i < this.gopCache_.length; i++) {\n currentGopObj = this.gopCache_[i];\n currentGop = currentGopObj.gop;\n\n // Reject Gops with different SPS or PPS\n if (!(track.pps && arrayEquals(track.pps[0], currentGopObj.pps[0])) ||\n !(track.sps && arrayEquals(track.sps[0], currentGopObj.sps[0]))) {\n continue;\n }\n\n // Reject Gops that would require a negative baseMediaDecodeTime\n if (currentGop.dts < track.timelineStartInfo.dts) {\n continue;\n }\n\n // The distance between the end of the gop and the start of the nalUnit\n dtsDistance = (nalUnit.dts - currentGop.dts) - currentGop.duration;\n\n // Only consider GOPS that start before the nal unit and end within\n // a half-second of the nal unit\n if (dtsDistance >= -allowableOverlap &&\n dtsDistance <= halfSecond) {\n\n // Always use the closest GOP we found if there is more than\n // one candidate\n if (!nearestGopObj ||\n nearestDistance > dtsDistance) {\n nearestGopObj = currentGopObj;\n nearestDistance = dtsDistance;\n }\n }\n }\n\n if (nearestGopObj) {\n return nearestGopObj.gop;\n }\n return null;\n };\n\n // trim gop list to the first gop found that has a matching pts with a gop in the list\n // of gopsToAlignWith starting from the START of the list\n this.alignGopsAtStart_ = function(gops) {\n var alignIndex, gopIndex, align, gop, byteLength, nalCount, duration, alignedGops;\n\n byteLength = gops.byteLength;\n nalCount = gops.nalCount;\n duration = gops.duration;\n alignIndex = gopIndex = 0;\n\n while (alignIndex < gopsToAlignWith.length && gopIndex < gops.length) {\n align = gopsToAlignWith[alignIndex];\n gop = gops[gopIndex];\n\n if (align.pts === gop.pts) {\n break;\n }\n\n if (gop.pts > align.pts) {\n // this current gop starts after the current gop we want to align on, so increment\n // align index\n alignIndex++;\n continue;\n }\n\n // current gop starts before the current gop we want to align on. so increment gop\n // index\n gopIndex++;\n byteLength -= gop.byteLength;\n nalCount -= gop.nalCount;\n duration -= gop.duration;\n }\n\n if (gopIndex === 0) {\n // no gops to trim\n return gops;\n }\n\n if (gopIndex === gops.length) {\n // all gops trimmed, skip appending all gops\n return null;\n }\n\n alignedGops = gops.slice(gopIndex);\n alignedGops.byteLength = byteLength;\n alignedGops.duration = duration;\n alignedGops.nalCount = nalCount;\n alignedGops.pts = alignedGops[0].pts;\n alignedGops.dts = alignedGops[0].dts;\n\n return alignedGops;\n };\n\n // trim gop list to the first gop found that has a matching pts with a gop in the list\n // of gopsToAlignWith starting from the END of the list\n this.alignGopsAtEnd_ = function(gops) {\n var alignIndex, gopIndex, align, gop, alignEndIndex, matchFound;\n\n alignIndex = gopsToAlignWith.length - 1;\n gopIndex = gops.length - 1;\n alignEndIndex = null;\n matchFound = false;\n\n while (alignIndex >= 0 && gopIndex >= 0) {\n align = gopsToAlignWith[alignIndex];\n gop = gops[gopIndex];\n\n if (align.pts === gop.pts) {\n matchFound = true;\n break;\n }\n\n if (align.pts > gop.pts) {\n alignIndex--;\n continue;\n }\n\n if (alignIndex === gopsToAlignWith.length - 1) {\n // gop.pts is greater than the last alignment candidate. If no match is found\n // by the end of this loop, we still want to append gops that come after this\n // point\n alignEndIndex = gopIndex;\n }\n\n gopIndex--;\n }\n\n if (!matchFound && alignEndIndex === null) {\n return null;\n }\n\n var trimIndex;\n\n if (matchFound) {\n trimIndex = gopIndex;\n } else {\n trimIndex = alignEndIndex;\n }\n\n if (trimIndex === 0) {\n return gops;\n }\n\n var alignedGops = gops.slice(trimIndex);\n var metadata = alignedGops.reduce(function(total, gop) {\n total.byteLength += gop.byteLength;\n total.duration += gop.duration;\n total.nalCount += gop.nalCount;\n return total;\n }, { byteLength: 0, duration: 0, nalCount: 0 });\n\n alignedGops.byteLength = metadata.byteLength;\n alignedGops.duration = metadata.duration;\n alignedGops.nalCount = metadata.nalCount;\n alignedGops.pts = alignedGops[0].pts;\n alignedGops.dts = alignedGops[0].dts;\n\n return alignedGops;\n };\n\n this.alignGopsWith = function(newGopsToAlignWith) {\n gopsToAlignWith = newGopsToAlignWith;\n };\n};\n\nVideoSegmentStream.prototype = new Stream();\n\n/**\n * A Stream that can combine multiple streams (ie. audio & video)\n * into a single output segment for MSE. Also supports audio-only\n * and video-only streams.\n * @param options {object} transmuxer options object\n * @param options.keepOriginalTimestamps {boolean} If true, keep the timestamps\n * in the source; false to adjust the first segment to start at media timeline start.\n */\nCoalesceStream = function(options, metadataStream) {\n // Number of Tracks per output segment\n // If greater than 1, we combine multiple\n // tracks into a single segment\n this.numberOfTracks = 0;\n this.metadataStream = metadataStream;\n\n options = options || {};\n\n if (typeof options.remux !== 'undefined') {\n this.remuxTracks = !!options.remux;\n } else {\n this.remuxTracks = true;\n }\n\n if (typeof options.keepOriginalTimestamps === 'boolean') {\n this.keepOriginalTimestamps = options.keepOriginalTimestamps;\n }\n\n this.pendingTracks = [];\n this.videoTrack = null;\n this.pendingBoxes = [];\n this.pendingCaptions = [];\n this.pendingMetadata = [];\n this.pendingBytes = 0;\n this.emittedTracks = 0;\n\n CoalesceStream.prototype.init.call(this);\n\n // Take output from multiple\n this.push = function(output) {\n // buffer incoming captions until the associated video segment\n // finishes\n if (output.text) {\n return this.pendingCaptions.push(output);\n }\n // buffer incoming id3 tags until the final flush\n if (output.frames) {\n return this.pendingMetadata.push(output);\n }\n\n // Add this track to the list of pending tracks and store\n // important information required for the construction of\n // the final segment\n this.pendingTracks.push(output.track);\n this.pendingBoxes.push(output.boxes);\n this.pendingBytes += output.boxes.byteLength;\n\n if (output.track.type === 'video') {\n this.videoTrack = output.track;\n }\n if (output.track.type === 'audio') {\n this.audioTrack = output.track;\n }\n };\n};\n\nCoalesceStream.prototype = new Stream();\nCoalesceStream.prototype.flush = function(flushSource) {\n var\n offset = 0,\n event = {\n captions: [],\n captionStreams: {},\n metadata: [],\n info: {}\n },\n caption,\n id3,\n initSegment,\n timelineStartPts = 0,\n i;\n\n if (this.pendingTracks.length < this.numberOfTracks) {\n if (flushSource !== 'VideoSegmentStream' &&\n flushSource !== 'AudioSegmentStream') {\n // Return because we haven't received a flush from a data-generating\n // portion of the segment (meaning that we have only recieved meta-data\n // or captions.)\n return;\n } else if (this.remuxTracks) {\n // Return until we have enough tracks from the pipeline to remux (if we\n // are remuxing audio and video into a single MP4)\n return;\n } else if (this.pendingTracks.length === 0) {\n // In the case where we receive a flush without any data having been\n // received we consider it an emitted track for the purposes of coalescing\n // `done` events.\n // We do this for the case where there is an audio and video track in the\n // segment but no audio data. (seen in several playlists with alternate\n // audio tracks and no audio present in the main TS segments.)\n this.emittedTracks++;\n\n if (this.emittedTracks >= this.numberOfTracks) {\n this.trigger('done');\n this.emittedTracks = 0;\n }\n return;\n }\n }\n\n if (this.videoTrack) {\n timelineStartPts = this.videoTrack.timelineStartInfo.pts;\n VIDEO_PROPERTIES.forEach(function(prop) {\n event.info[prop] = this.videoTrack[prop];\n }, this);\n } else if (this.audioTrack) {\n timelineStartPts = this.audioTrack.timelineStartInfo.pts;\n AUDIO_PROPERTIES.forEach(function(prop) {\n event.info[prop] = this.audioTrack[prop];\n }, this);\n }\n\n if (this.pendingTracks.length === 1) {\n event.type = this.pendingTracks[0].type;\n } else {\n event.type = 'combined';\n }\n\n this.emittedTracks += this.pendingTracks.length;\n\n initSegment = mp4.initSegment(this.pendingTracks);\n\n // Create a new typed array to hold the init segment\n event.initSegment = new Uint8Array(initSegment.byteLength);\n\n // Create an init segment containing a moov\n // and track definitions\n event.initSegment.set(initSegment);\n\n // Create a new typed array to hold the moof+mdats\n event.data = new Uint8Array(this.pendingBytes);\n\n // Append each moof+mdat (one per track) together\n for (i = 0; i < this.pendingBoxes.length; i++) {\n event.data.set(this.pendingBoxes[i], offset);\n offset += this.pendingBoxes[i].byteLength;\n }\n\n // Translate caption PTS times into second offsets to match the\n // video timeline for the segment, and add track info\n for (i = 0; i < this.pendingCaptions.length; i++) {\n caption = this.pendingCaptions[i];\n\n caption.startTime = caption.startPts;\n if (!this.keepOriginalTimestamps) {\n caption.startTime -= timelineStartPts;\n }\n caption.startTime /= 90e3;\n\n caption.endTime = caption.endPts;\n if (!this.keepOriginalTimestamps) {\n caption.endTime -= timelineStartPts;\n }\n caption.endTime /= 90e3;\n\n event.captionStreams[caption.stream] = true;\n event.captions.push(caption);\n }\n\n // Translate ID3 frame PTS times into second offsets to match the\n // video timeline for the segment\n for (i = 0; i < this.pendingMetadata.length; i++) {\n id3 = this.pendingMetadata[i];\n\n id3.cueTime = id3.pts;\n if (!this.keepOriginalTimestamps) {\n id3.cueTime -= timelineStartPts;\n }\n id3.cueTime /= 90e3;\n\n event.metadata.push(id3);\n }\n\n // We add this to every single emitted segment even though we only need\n // it for the first\n event.metadata.dispatchType = this.metadataStream.dispatchType;\n\n // Reset stream state\n this.pendingTracks.length = 0;\n this.videoTrack = null;\n this.pendingBoxes.length = 0;\n this.pendingCaptions.length = 0;\n this.pendingBytes = 0;\n this.pendingMetadata.length = 0;\n\n // Emit the built segment\n this.trigger('data', event);\n\n // Only emit `done` if all tracks have been flushed and emitted\n if (this.emittedTracks >= this.numberOfTracks) {\n this.trigger('done');\n this.emittedTracks = 0;\n }\n};\n/**\n * A Stream that expects MP2T binary data as input and produces\n * corresponding media segments, suitable for use with Media Source\n * Extension (MSE) implementations that support the ISO BMFF byte\n * stream format, like Chrome.\n */\nTransmuxer = function(options) {\n var\n self = this,\n hasFlushed = true,\n videoTrack,\n audioTrack;\n\n Transmuxer.prototype.init.call(this);\n\n options = options || {};\n this.baseMediaDecodeTime = options.baseMediaDecodeTime || 0;\n this.transmuxPipeline_ = {};\n\n this.setupAacPipeline = function() {\n var pipeline = {};\n this.transmuxPipeline_ = pipeline;\n\n pipeline.type = 'aac';\n pipeline.metadataStream = new m2ts.MetadataStream();\n\n // set up the parsing pipeline\n pipeline.aacStream = new AacStream();\n pipeline.audioTimestampRolloverStream = new m2ts.TimestampRolloverStream('audio');\n pipeline.timedMetadataTimestampRolloverStream = new m2ts.TimestampRolloverStream('timed-metadata');\n pipeline.adtsStream = new AdtsStream();\n pipeline.coalesceStream = new CoalesceStream(options, pipeline.metadataStream);\n pipeline.headOfPipeline = pipeline.aacStream;\n\n pipeline.aacStream\n .pipe(pipeline.audioTimestampRolloverStream)\n .pipe(pipeline.adtsStream);\n pipeline.aacStream\n .pipe(pipeline.timedMetadataTimestampRolloverStream)\n .pipe(pipeline.metadataStream)\n .pipe(pipeline.coalesceStream);\n\n pipeline.metadataStream.on('timestamp', function(frame) {\n pipeline.aacStream.setTimestamp(frame.timeStamp);\n });\n\n pipeline.aacStream.on('data', function(data) {\n if (data.type === 'timed-metadata' && !pipeline.audioSegmentStream) {\n audioTrack = audioTrack || {\n timelineStartInfo: {\n baseMediaDecodeTime: self.baseMediaDecodeTime\n },\n codec: 'adts',\n type: 'audio'\n };\n // hook up the audio segment stream to the first track with aac data\n pipeline.coalesceStream.numberOfTracks++;\n pipeline.audioSegmentStream = new AudioSegmentStream(audioTrack, options);\n // Set up the final part of the audio pipeline\n pipeline.adtsStream\n .pipe(pipeline.audioSegmentStream)\n .pipe(pipeline.coalesceStream);\n }\n });\n\n // Re-emit any data coming from the coalesce stream to the outside world\n pipeline.coalesceStream.on('data', this.trigger.bind(this, 'data'));\n // Let the consumer know we have finished flushing the entire pipeline\n pipeline.coalesceStream.on('done', this.trigger.bind(this, 'done'));\n };\n\n this.setupTsPipeline = function() {\n var pipeline = {};\n this.transmuxPipeline_ = pipeline;\n\n pipeline.type = 'ts';\n pipeline.metadataStream = new m2ts.MetadataStream();\n\n // set up the parsing pipeline\n pipeline.packetStream = new m2ts.TransportPacketStream();\n pipeline.parseStream = new m2ts.TransportParseStream();\n pipeline.elementaryStream = new m2ts.ElementaryStream();\n pipeline.videoTimestampRolloverStream = new m2ts.TimestampRolloverStream('video');\n pipeline.audioTimestampRolloverStream = new m2ts.TimestampRolloverStream('audio');\n pipeline.timedMetadataTimestampRolloverStream = new m2ts.TimestampRolloverStream('timed-metadata');\n pipeline.adtsStream = new AdtsStream();\n pipeline.h264Stream = new H264Stream();\n pipeline.captionStream = new m2ts.CaptionStream();\n pipeline.coalesceStream = new CoalesceStream(options, pipeline.metadataStream);\n pipeline.headOfPipeline = pipeline.packetStream;\n\n // disassemble MPEG2-TS packets into elementary streams\n pipeline.packetStream\n .pipe(pipeline.parseStream)\n .pipe(pipeline.elementaryStream);\n\n // !!THIS ORDER IS IMPORTANT!!\n // demux the streams\n pipeline.elementaryStream\n .pipe(pipeline.videoTimestampRolloverStream)\n .pipe(pipeline.h264Stream);\n pipeline.elementaryStream\n .pipe(pipeline.audioTimestampRolloverStream)\n .pipe(pipeline.adtsStream);\n\n pipeline.elementaryStream\n .pipe(pipeline.timedMetadataTimestampRolloverStream)\n .pipe(pipeline.metadataStream)\n .pipe(pipeline.coalesceStream);\n\n // Hook up CEA-608/708 caption stream\n pipeline.h264Stream.pipe(pipeline.captionStream)\n .pipe(pipeline.coalesceStream);\n\n pipeline.elementaryStream.on('data', function(data) {\n var i;\n\n if (data.type === 'metadata') {\n i = data.tracks.length;\n\n // scan the tracks listed in the metadata\n while (i--) {\n if (!videoTrack && data.tracks[i].type === 'video') {\n videoTrack = data.tracks[i];\n videoTrack.timelineStartInfo.baseMediaDecodeTime = self.baseMediaDecodeTime;\n } else if (!audioTrack && data.tracks[i].type === 'audio') {\n audioTrack = data.tracks[i];\n audioTrack.timelineStartInfo.baseMediaDecodeTime = self.baseMediaDecodeTime;\n }\n }\n\n // hook up the video segment stream to the first track with h264 data\n if (videoTrack && !pipeline.videoSegmentStream) {\n pipeline.coalesceStream.numberOfTracks++;\n pipeline.videoSegmentStream = new VideoSegmentStream(videoTrack, options);\n\n pipeline.videoSegmentStream.on('timelineStartInfo', function(timelineStartInfo) {\n // When video emits timelineStartInfo data after a flush, we forward that\n // info to the AudioSegmentStream, if it exists, because video timeline\n // data takes precedence.\n if (audioTrack) {\n audioTrack.timelineStartInfo = timelineStartInfo;\n // On the first segment we trim AAC frames that exist before the\n // very earliest DTS we have seen in video because Chrome will\n // interpret any video track with a baseMediaDecodeTime that is\n // non-zero as a gap.\n pipeline.audioSegmentStream.setEarliestDts(timelineStartInfo.dts);\n }\n });\n\n pipeline.videoSegmentStream.on('processedGopsInfo',\n self.trigger.bind(self, 'gopInfo'));\n\n pipeline.videoSegmentStream.on('baseMediaDecodeTime', function(baseMediaDecodeTime) {\n if (audioTrack) {\n pipeline.audioSegmentStream.setVideoBaseMediaDecodeTime(baseMediaDecodeTime);\n }\n });\n\n // Set up the final part of the video pipeline\n pipeline.h264Stream\n .pipe(pipeline.videoSegmentStream)\n .pipe(pipeline.coalesceStream);\n }\n\n if (audioTrack && !pipeline.audioSegmentStream) {\n // hook up the audio segment stream to the first track with aac data\n pipeline.coalesceStream.numberOfTracks++;\n pipeline.audioSegmentStream = new AudioSegmentStream(audioTrack, options);\n\n // Set up the final part of the audio pipeline\n pipeline.adtsStream\n .pipe(pipeline.audioSegmentStream)\n .pipe(pipeline.coalesceStream);\n }\n }\n });\n\n // Re-emit any data coming from the coalesce stream to the outside world\n pipeline.coalesceStream.on('data', this.trigger.bind(this, 'data'));\n // Let the consumer know we have finished flushing the entire pipeline\n pipeline.coalesceStream.on('done', this.trigger.bind(this, 'done'));\n };\n\n // hook up the segment streams once track metadata is delivered\n this.setBaseMediaDecodeTime = function(baseMediaDecodeTime) {\n var pipeline = this.transmuxPipeline_;\n\n if (!options.keepOriginalTimestamps) {\n this.baseMediaDecodeTime = baseMediaDecodeTime;\n }\n\n if (audioTrack) {\n audioTrack.timelineStartInfo.dts = undefined;\n audioTrack.timelineStartInfo.pts = undefined;\n trackDecodeInfo.clearDtsInfo(audioTrack);\n if (!options.keepOriginalTimestamps) {\n audioTrack.timelineStartInfo.baseMediaDecodeTime = baseMediaDecodeTime;\n }\n if (pipeline.audioTimestampRolloverStream) {\n pipeline.audioTimestampRolloverStream.discontinuity();\n }\n }\n if (videoTrack) {\n if (pipeline.videoSegmentStream) {\n pipeline.videoSegmentStream.gopCache_ = [];\n pipeline.videoTimestampRolloverStream.discontinuity();\n }\n videoTrack.timelineStartInfo.dts = undefined;\n videoTrack.timelineStartInfo.pts = undefined;\n trackDecodeInfo.clearDtsInfo(videoTrack);\n pipeline.captionStream.reset();\n if (!options.keepOriginalTimestamps) {\n videoTrack.timelineStartInfo.baseMediaDecodeTime = baseMediaDecodeTime;\n }\n }\n\n if (pipeline.timedMetadataTimestampRolloverStream) {\n pipeline.timedMetadataTimestampRolloverStream.discontinuity();\n }\n };\n\n this.setAudioAppendStart = function(timestamp) {\n if (audioTrack) {\n this.transmuxPipeline_.audioSegmentStream.setAudioAppendStart(timestamp);\n }\n };\n\n this.alignGopsWith = function(gopsToAlignWith) {\n if (videoTrack && this.transmuxPipeline_.videoSegmentStream) {\n this.transmuxPipeline_.videoSegmentStream.alignGopsWith(gopsToAlignWith);\n }\n };\n\n // feed incoming data to the front of the parsing pipeline\n this.push = function(data) {\n if (hasFlushed) {\n var isAac = isLikelyAacData(data);\n\n if (isAac && this.transmuxPipeline_.type !== 'aac') {\n this.setupAacPipeline();\n } else if (!isAac && this.transmuxPipeline_.type !== 'ts') {\n this.setupTsPipeline();\n }\n hasFlushed = false;\n }\n this.transmuxPipeline_.headOfPipeline.push(data);\n };\n\n // flush any buffered data\n this.flush = function() {\n hasFlushed = true;\n // Start at the top of the pipeline and flush all pending work\n this.transmuxPipeline_.headOfPipeline.flush();\n };\n\n // Caption data has to be reset when seeking outside buffered range\n this.resetCaptions = function() {\n if (this.transmuxPipeline_.captionStream) {\n this.transmuxPipeline_.captionStream.reset();\n }\n };\n\n};\nTransmuxer.prototype = new Stream();\n\nmodule.exports = {\n Transmuxer: Transmuxer,\n VideoSegmentStream: VideoSegmentStream,\n AudioSegmentStream: AudioSegmentStream,\n AUDIO_PROPERTIES: AUDIO_PROPERTIES,\n VIDEO_PROPERTIES: VIDEO_PROPERTIES\n};\n","/**\n * mux.js\n *\n * Copyright (c) 2016 Brightcove\n * All rights reserved.\n *\n * Utilities to detect basic properties and metadata about Aac data.\n */\n'use strict';\n\nvar ADTS_SAMPLING_FREQUENCIES = [\n 96000,\n 88200,\n 64000,\n 48000,\n 44100,\n 32000,\n 24000,\n 22050,\n 16000,\n 12000,\n 11025,\n 8000,\n 7350\n];\n\nvar isLikelyAacData = function(data) {\n if ((data[0] === 'I'.charCodeAt(0)) &&\n (data[1] === 'D'.charCodeAt(0)) &&\n (data[2] === '3'.charCodeAt(0))) {\n return true;\n }\n return false;\n};\n\nvar parseSyncSafeInteger = function(data) {\n return (data[0] << 21) |\n (data[1] << 14) |\n (data[2] << 7) |\n (data[3]);\n};\n\n// return a percent-encoded representation of the specified byte range\n// @see http://en.wikipedia.org/wiki/Percent-encoding\nvar percentEncode = function(bytes, start, end) {\n var i, result = '';\n for (i = start; i < end; i++) {\n result += '%' + ('00' + bytes[i].toString(16)).slice(-2);\n }\n return result;\n};\n\n// return the string representation of the specified byte range,\n// interpreted as ISO-8859-1.\nvar parseIso88591 = function(bytes, start, end) {\n return unescape(percentEncode(bytes, start, end)); // jshint ignore:line\n};\n\nvar parseId3TagSize = function(header, byteIndex) {\n var\n returnSize = (header[byteIndex + 6] << 21) |\n (header[byteIndex + 7] << 14) |\n (header[byteIndex + 8] << 7) |\n (header[byteIndex + 9]),\n flags = header[byteIndex + 5],\n footerPresent = (flags & 16) >> 4;\n\n if (footerPresent) {\n return returnSize + 20;\n }\n return returnSize + 10;\n};\n\nvar parseAdtsSize = function(header, byteIndex) {\n var\n lowThree = (header[byteIndex + 5] & 0xE0) >> 5,\n middle = header[byteIndex + 4] << 3,\n highTwo = header[byteIndex + 3] & 0x3 << 11;\n\n return (highTwo | middle) | lowThree;\n};\n\nvar parseType = function(header, byteIndex) {\n if ((header[byteIndex] === 'I'.charCodeAt(0)) &&\n (header[byteIndex + 1] === 'D'.charCodeAt(0)) &&\n (header[byteIndex + 2] === '3'.charCodeAt(0))) {\n return 'timed-metadata';\n } else if ((header[byteIndex] & 0xff === 0xff) &&\n ((header[byteIndex + 1] & 0xf0) === 0xf0)) {\n return 'audio';\n }\n return null;\n};\n\nvar parseSampleRate = function(packet) {\n var i = 0;\n\n while (i + 5 < packet.length) {\n if (packet[i] !== 0xFF || (packet[i + 1] & 0xF6) !== 0xF0) {\n // If a valid header was not found, jump one forward and attempt to\n // find a valid ADTS header starting at the next byte\n i++;\n continue;\n }\n return ADTS_SAMPLING_FREQUENCIES[(packet[i + 2] & 0x3c) >>> 2];\n }\n\n return null;\n};\n\nvar parseAacTimestamp = function(packet) {\n var frameStart, frameSize, frame, frameHeader;\n\n // find the start of the first frame and the end of the tag\n frameStart = 10;\n if (packet[5] & 0x40) {\n // advance the frame start past the extended header\n frameStart += 4; // header size field\n frameStart += parseSyncSafeInteger(packet.subarray(10, 14));\n }\n\n // parse one or more ID3 frames\n // http://id3.org/id3v2.3.0#ID3v2_frame_overview\n do {\n // determine the number of bytes in this frame\n frameSize = parseSyncSafeInteger(packet.subarray(frameStart + 4, frameStart + 8));\n if (frameSize < 1) {\n return null;\n }\n frameHeader = String.fromCharCode(packet[frameStart],\n packet[frameStart + 1],\n packet[frameStart + 2],\n packet[frameStart + 3]);\n\n if (frameHeader === 'PRIV') {\n frame = packet.subarray(frameStart + 10, frameStart + frameSize + 10);\n\n for (var i = 0; i < frame.byteLength; i++) {\n if (frame[i] === 0) {\n var owner = parseIso88591(frame, 0, i);\n if (owner === 'com.apple.streaming.transportStreamTimestamp') {\n var d = frame.subarray(i + 1);\n var size = ((d[3] & 0x01) << 30) |\n (d[4] << 22) |\n (d[5] << 14) |\n (d[6] << 6) |\n (d[7] >>> 2);\n size *= 4;\n size += d[7] & 0x03;\n\n return size;\n }\n break;\n }\n }\n }\n\n frameStart += 10; // advance past the frame header\n frameStart += frameSize; // advance past the frame body\n } while (frameStart < packet.byteLength);\n return null;\n};\n\nmodule.exports = {\n isLikelyAacData: isLikelyAacData,\n parseId3TagSize: parseId3TagSize,\n parseAdtsSize: parseAdtsSize,\n parseType: parseType,\n parseSampleRate: parseSampleRate,\n parseAacTimestamp: parseAacTimestamp\n};\n","/**\n * mux.js\n *\n * Copyright (c) 2015 Brightcove\n * All rights reserved.\n *\n * Functions that generate fragmented MP4s suitable for use with Media\n * Source Extensions.\n */\n'use strict';\n\nvar UINT32_MAX = Math.pow(2, 32) - 1;\n\nvar box, dinf, esds, ftyp, mdat, mfhd, minf, moof, moov, mvex, mvhd,\n trak, tkhd, mdia, mdhd, hdlr, sdtp, stbl, stsd, traf, trex,\n trun, types, MAJOR_BRAND, MINOR_VERSION, AVC1_BRAND, VIDEO_HDLR,\n AUDIO_HDLR, HDLR_TYPES, VMHD, SMHD, DREF, STCO, STSC, STSZ, STTS;\n\n// pre-calculate constants\n(function() {\n var i;\n types = {\n avc1: [], // codingname\n avcC: [],\n btrt: [],\n dinf: [],\n dref: [],\n esds: [],\n ftyp: [],\n hdlr: [],\n mdat: [],\n mdhd: [],\n mdia: [],\n mfhd: [],\n minf: [],\n moof: [],\n moov: [],\n mp4a: [], // codingname\n mvex: [],\n mvhd: [],\n sdtp: [],\n smhd: [],\n stbl: [],\n stco: [],\n stsc: [],\n stsd: [],\n stsz: [],\n stts: [],\n styp: [],\n tfdt: [],\n tfhd: [],\n traf: [],\n trak: [],\n trun: [],\n trex: [],\n tkhd: [],\n vmhd: []\n };\n\n // In environments where Uint8Array is undefined (e.g., IE8), skip set up so that we\n // don't throw an error\n if (typeof Uint8Array === 'undefined') {\n return;\n }\n\n for (i in types) {\n if (types.hasOwnProperty(i)) {\n types[i] = [\n i.charCodeAt(0),\n i.charCodeAt(1),\n i.charCodeAt(2),\n i.charCodeAt(3)\n ];\n }\n }\n\n MAJOR_BRAND = new Uint8Array([\n 'i'.charCodeAt(0),\n 's'.charCodeAt(0),\n 'o'.charCodeAt(0),\n 'm'.charCodeAt(0)\n ]);\n AVC1_BRAND = new Uint8Array([\n 'a'.charCodeAt(0),\n 'v'.charCodeAt(0),\n 'c'.charCodeAt(0),\n '1'.charCodeAt(0)\n ]);\n MINOR_VERSION = new Uint8Array([0, 0, 0, 1]);\n VIDEO_HDLR = new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, // pre_defined\n 0x76, 0x69, 0x64, 0x65, // handler_type: 'vide'\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x56, 0x69, 0x64, 0x65,\n 0x6f, 0x48, 0x61, 0x6e,\n 0x64, 0x6c, 0x65, 0x72, 0x00 // name: 'VideoHandler'\n ]);\n AUDIO_HDLR = new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, // pre_defined\n 0x73, 0x6f, 0x75, 0x6e, // handler_type: 'soun'\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x53, 0x6f, 0x75, 0x6e,\n 0x64, 0x48, 0x61, 0x6e,\n 0x64, 0x6c, 0x65, 0x72, 0x00 // name: 'SoundHandler'\n ]);\n HDLR_TYPES = {\n video: VIDEO_HDLR,\n audio: AUDIO_HDLR\n };\n DREF = new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x01, // entry_count\n 0x00, 0x00, 0x00, 0x0c, // entry_size\n 0x75, 0x72, 0x6c, 0x20, // 'url' type\n 0x00, // version 0\n 0x00, 0x00, 0x01 // entry_flags\n ]);\n SMHD = new Uint8Array([\n 0x00, // version\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, // balance, 0 means centered\n 0x00, 0x00 // reserved\n ]);\n STCO = new Uint8Array([\n 0x00, // version\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00 // entry_count\n ]);\n STSC = STCO;\n STSZ = new Uint8Array([\n 0x00, // version\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, // sample_size\n 0x00, 0x00, 0x00, 0x00 // sample_count\n ]);\n STTS = STCO;\n VMHD = new Uint8Array([\n 0x00, // version\n 0x00, 0x00, 0x01, // flags\n 0x00, 0x00, // graphicsmode\n 0x00, 0x00,\n 0x00, 0x00,\n 0x00, 0x00 // opcolor\n ]);\n}());\n\nbox = function(type) {\n var\n payload = [],\n size = 0,\n i,\n result,\n view;\n\n for (i = 1; i < arguments.length; i++) {\n payload.push(arguments[i]);\n }\n\n i = payload.length;\n\n // calculate the total size we need to allocate\n while (i--) {\n size += payload[i].byteLength;\n }\n result = new Uint8Array(size + 8);\n view = new DataView(result.buffer, result.byteOffset, result.byteLength);\n view.setUint32(0, result.byteLength);\n result.set(type, 4);\n\n // copy the payload into the result\n for (i = 0, size = 8; i < payload.length; i++) {\n result.set(payload[i], size);\n size += payload[i].byteLength;\n }\n return result;\n};\n\ndinf = function() {\n return box(types.dinf, box(types.dref, DREF));\n};\n\nesds = function(track) {\n return box(types.esds, new Uint8Array([\n 0x00, // version\n 0x00, 0x00, 0x00, // flags\n\n // ES_Descriptor\n 0x03, // tag, ES_DescrTag\n 0x19, // length\n 0x00, 0x00, // ES_ID\n 0x00, // streamDependenceFlag, URL_flag, reserved, streamPriority\n\n // DecoderConfigDescriptor\n 0x04, // tag, DecoderConfigDescrTag\n 0x11, // length\n 0x40, // object type\n 0x15, // streamType\n 0x00, 0x06, 0x00, // bufferSizeDB\n 0x00, 0x00, 0xda, 0xc0, // maxBitrate\n 0x00, 0x00, 0xda, 0xc0, // avgBitrate\n\n // DecoderSpecificInfo\n 0x05, // tag, DecoderSpecificInfoTag\n 0x02, // length\n // ISO/IEC 14496-3, AudioSpecificConfig\n // for samplingFrequencyIndex see ISO/IEC 13818-7:2006, 8.1.3.2.2, Table 35\n (track.audioobjecttype << 3) | (track.samplingfrequencyindex >>> 1),\n (track.samplingfrequencyindex << 7) | (track.channelcount << 3),\n 0x06, 0x01, 0x02 // GASpecificConfig\n ]));\n};\n\nftyp = function() {\n return box(types.ftyp, MAJOR_BRAND, MINOR_VERSION, MAJOR_BRAND, AVC1_BRAND);\n};\n\nhdlr = function(type) {\n return box(types.hdlr, HDLR_TYPES[type]);\n};\nmdat = function(data) {\n return box(types.mdat, data);\n};\nmdhd = function(track) {\n var result = new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x02, // creation_time\n 0x00, 0x00, 0x00, 0x03, // modification_time\n 0x00, 0x01, 0x5f, 0x90, // timescale, 90,000 \"ticks\" per second\n\n (track.duration >>> 24) & 0xFF,\n (track.duration >>> 16) & 0xFF,\n (track.duration >>> 8) & 0xFF,\n track.duration & 0xFF, // duration\n 0x55, 0xc4, // 'und' language (undetermined)\n 0x00, 0x00\n ]);\n\n // Use the sample rate from the track metadata, when it is\n // defined. The sample rate can be parsed out of an ADTS header, for\n // instance.\n if (track.samplerate) {\n result[12] = (track.samplerate >>> 24) & 0xFF;\n result[13] = (track.samplerate >>> 16) & 0xFF;\n result[14] = (track.samplerate >>> 8) & 0xFF;\n result[15] = (track.samplerate) & 0xFF;\n }\n\n return box(types.mdhd, result);\n};\nmdia = function(track) {\n return box(types.mdia, mdhd(track), hdlr(track.type), minf(track));\n};\nmfhd = function(sequenceNumber) {\n return box(types.mfhd, new Uint8Array([\n 0x00,\n 0x00, 0x00, 0x00, // flags\n (sequenceNumber & 0xFF000000) >> 24,\n (sequenceNumber & 0xFF0000) >> 16,\n (sequenceNumber & 0xFF00) >> 8,\n sequenceNumber & 0xFF // sequence_number\n ]));\n};\nminf = function(track) {\n return box(types.minf,\n track.type === 'video' ? box(types.vmhd, VMHD) : box(types.smhd, SMHD),\n dinf(),\n stbl(track));\n};\nmoof = function(sequenceNumber, tracks) {\n var\n trackFragments = [],\n i = tracks.length;\n // build traf boxes for each track fragment\n while (i--) {\n trackFragments[i] = traf(tracks[i]);\n }\n return box.apply(null, [\n types.moof,\n mfhd(sequenceNumber)\n ].concat(trackFragments));\n};\n/**\n * Returns a movie box.\n * @param tracks {array} the tracks associated with this movie\n * @see ISO/IEC 14496-12:2012(E), section 8.2.1\n */\nmoov = function(tracks) {\n var\n i = tracks.length,\n boxes = [];\n\n while (i--) {\n boxes[i] = trak(tracks[i]);\n }\n\n return box.apply(null, [types.moov, mvhd(0xffffffff)].concat(boxes).concat(mvex(tracks)));\n};\nmvex = function(tracks) {\n var\n i = tracks.length,\n boxes = [];\n\n while (i--) {\n boxes[i] = trex(tracks[i]);\n }\n return box.apply(null, [types.mvex].concat(boxes));\n};\nmvhd = function(duration) {\n var\n bytes = new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x01, // creation_time\n 0x00, 0x00, 0x00, 0x02, // modification_time\n 0x00, 0x01, 0x5f, 0x90, // timescale, 90,000 \"ticks\" per second\n (duration & 0xFF000000) >> 24,\n (duration & 0xFF0000) >> 16,\n (duration & 0xFF00) >> 8,\n duration & 0xFF, // duration\n 0x00, 0x01, 0x00, 0x00, // 1.0 rate\n 0x01, 0x00, // 1.0 volume\n 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x01, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x40, 0x00, 0x00, 0x00, // transformation: unity matrix\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00, // pre_defined\n 0xff, 0xff, 0xff, 0xff // next_track_ID\n ]);\n return box(types.mvhd, bytes);\n};\n\nsdtp = function(track) {\n var\n samples = track.samples || [],\n bytes = new Uint8Array(4 + samples.length),\n flags,\n i;\n\n // leave the full box header (4 bytes) all zero\n\n // write the sample table\n for (i = 0; i < samples.length; i++) {\n flags = samples[i].flags;\n\n bytes[i + 4] = (flags.dependsOn << 4) |\n (flags.isDependedOn << 2) |\n (flags.hasRedundancy);\n }\n\n return box(types.sdtp,\n bytes);\n};\n\nstbl = function(track) {\n return box(types.stbl,\n stsd(track),\n box(types.stts, STTS),\n box(types.stsc, STSC),\n box(types.stsz, STSZ),\n box(types.stco, STCO));\n};\n\n(function() {\n var videoSample, audioSample;\n\n stsd = function(track) {\n\n return box(types.stsd, new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x01\n ]), track.type === 'video' ? videoSample(track) : audioSample(track));\n };\n\n videoSample = function(track) {\n var\n sps = track.sps || [],\n pps = track.pps || [],\n sequenceParameterSets = [],\n pictureParameterSets = [],\n i;\n\n // assemble the SPSs\n for (i = 0; i < sps.length; i++) {\n sequenceParameterSets.push((sps[i].byteLength & 0xFF00) >>> 8);\n sequenceParameterSets.push((sps[i].byteLength & 0xFF)); // sequenceParameterSetLength\n sequenceParameterSets = sequenceParameterSets.concat(Array.prototype.slice.call(sps[i])); // SPS\n }\n\n // assemble the PPSs\n for (i = 0; i < pps.length; i++) {\n pictureParameterSets.push((pps[i].byteLength & 0xFF00) >>> 8);\n pictureParameterSets.push((pps[i].byteLength & 0xFF));\n pictureParameterSets = pictureParameterSets.concat(Array.prototype.slice.call(pps[i]));\n }\n\n return box(types.avc1, new Uint8Array([\n 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // data_reference_index\n 0x00, 0x00, // pre_defined\n 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00, // pre_defined\n (track.width & 0xff00) >> 8,\n track.width & 0xff, // width\n (track.height & 0xff00) >> 8,\n track.height & 0xff, // height\n 0x00, 0x48, 0x00, 0x00, // horizresolution\n 0x00, 0x48, 0x00, 0x00, // vertresolution\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // frame_count\n 0x13,\n 0x76, 0x69, 0x64, 0x65,\n 0x6f, 0x6a, 0x73, 0x2d,\n 0x63, 0x6f, 0x6e, 0x74,\n 0x72, 0x69, 0x62, 0x2d,\n 0x68, 0x6c, 0x73, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, // compressorname\n 0x00, 0x18, // depth = 24\n 0x11, 0x11 // pre_defined = -1\n ]), box(types.avcC, new Uint8Array([\n 0x01, // configurationVersion\n track.profileIdc, // AVCProfileIndication\n track.profileCompatibility, // profile_compatibility\n track.levelIdc, // AVCLevelIndication\n 0xff // lengthSizeMinusOne, hard-coded to 4 bytes\n ].concat([\n sps.length // numOfSequenceParameterSets\n ]).concat(sequenceParameterSets).concat([\n pps.length // numOfPictureParameterSets\n ]).concat(pictureParameterSets))), // \"PPS\"\n box(types.btrt, new Uint8Array([\n 0x00, 0x1c, 0x9c, 0x80, // bufferSizeDB\n 0x00, 0x2d, 0xc6, 0xc0, // maxBitrate\n 0x00, 0x2d, 0xc6, 0xc0\n ])) // avgBitrate\n );\n };\n\n audioSample = function(track) {\n return box(types.mp4a, new Uint8Array([\n\n // SampleEntry, ISO/IEC 14496-12\n 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // data_reference_index\n\n // AudioSampleEntry, ISO/IEC 14496-12\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n (track.channelcount & 0xff00) >> 8,\n (track.channelcount & 0xff), // channelcount\n\n (track.samplesize & 0xff00) >> 8,\n (track.samplesize & 0xff), // samplesize\n 0x00, 0x00, // pre_defined\n 0x00, 0x00, // reserved\n\n (track.samplerate & 0xff00) >> 8,\n (track.samplerate & 0xff),\n 0x00, 0x00 // samplerate, 16.16\n\n // MP4AudioSampleEntry, ISO/IEC 14496-14\n ]), esds(track));\n };\n}());\n\ntkhd = function(track) {\n var result = new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x07, // flags\n 0x00, 0x00, 0x00, 0x00, // creation_time\n 0x00, 0x00, 0x00, 0x00, // modification_time\n (track.id & 0xFF000000) >> 24,\n (track.id & 0xFF0000) >> 16,\n (track.id & 0xFF00) >> 8,\n track.id & 0xFF, // track_ID\n 0x00, 0x00, 0x00, 0x00, // reserved\n (track.duration & 0xFF000000) >> 24,\n (track.duration & 0xFF0000) >> 16,\n (track.duration & 0xFF00) >> 8,\n track.duration & 0xFF, // duration\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, // layer\n 0x00, 0x00, // alternate_group\n 0x01, 0x00, // non-audio track volume\n 0x00, 0x00, // reserved\n 0x00, 0x01, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x01, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x00, 0x00, 0x00,\n 0x40, 0x00, 0x00, 0x00, // transformation: unity matrix\n (track.width & 0xFF00) >> 8,\n track.width & 0xFF,\n 0x00, 0x00, // width\n (track.height & 0xFF00) >> 8,\n track.height & 0xFF,\n 0x00, 0x00 // height\n ]);\n\n return box(types.tkhd, result);\n};\n\n/**\n * Generate a track fragment (traf) box. A traf box collects metadata\n * about tracks in a movie fragment (moof) box.\n */\ntraf = function(track) {\n var trackFragmentHeader, trackFragmentDecodeTime, trackFragmentRun,\n sampleDependencyTable, dataOffset,\n upperWordBaseMediaDecodeTime, lowerWordBaseMediaDecodeTime;\n\n trackFragmentHeader = box(types.tfhd, new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x3a, // flags\n (track.id & 0xFF000000) >> 24,\n (track.id & 0xFF0000) >> 16,\n (track.id & 0xFF00) >> 8,\n (track.id & 0xFF), // track_ID\n 0x00, 0x00, 0x00, 0x01, // sample_description_index\n 0x00, 0x00, 0x00, 0x00, // default_sample_duration\n 0x00, 0x00, 0x00, 0x00, // default_sample_size\n 0x00, 0x00, 0x00, 0x00 // default_sample_flags\n ]));\n\n upperWordBaseMediaDecodeTime = Math.floor(track.baseMediaDecodeTime / (UINT32_MAX + 1));\n lowerWordBaseMediaDecodeTime = Math.floor(track.baseMediaDecodeTime % (UINT32_MAX + 1));\n\n trackFragmentDecodeTime = box(types.tfdt, new Uint8Array([\n 0x01, // version 1\n 0x00, 0x00, 0x00, // flags\n // baseMediaDecodeTime\n (upperWordBaseMediaDecodeTime >>> 24) & 0xFF,\n (upperWordBaseMediaDecodeTime >>> 16) & 0xFF,\n (upperWordBaseMediaDecodeTime >>> 8) & 0xFF,\n upperWordBaseMediaDecodeTime & 0xFF,\n (lowerWordBaseMediaDecodeTime >>> 24) & 0xFF,\n (lowerWordBaseMediaDecodeTime >>> 16) & 0xFF,\n (lowerWordBaseMediaDecodeTime >>> 8) & 0xFF,\n lowerWordBaseMediaDecodeTime & 0xFF\n ]));\n\n // the data offset specifies the number of bytes from the start of\n // the containing moof to the first payload byte of the associated\n // mdat\n dataOffset = (32 + // tfhd\n 20 + // tfdt\n 8 + // traf header\n 16 + // mfhd\n 8 + // moof header\n 8); // mdat header\n\n // audio tracks require less metadata\n if (track.type === 'audio') {\n trackFragmentRun = trun(track, dataOffset);\n return box(types.traf,\n trackFragmentHeader,\n trackFragmentDecodeTime,\n trackFragmentRun);\n }\n\n // video tracks should contain an independent and disposable samples\n // box (sdtp)\n // generate one and adjust offsets to match\n sampleDependencyTable = sdtp(track);\n trackFragmentRun = trun(track,\n sampleDependencyTable.length + dataOffset);\n return box(types.traf,\n trackFragmentHeader,\n trackFragmentDecodeTime,\n trackFragmentRun,\n sampleDependencyTable);\n};\n\n/**\n * Generate a track box.\n * @param track {object} a track definition\n * @return {Uint8Array} the track box\n */\ntrak = function(track) {\n track.duration = track.duration || 0xffffffff;\n return box(types.trak,\n tkhd(track),\n mdia(track));\n};\n\ntrex = function(track) {\n var result = new Uint8Array([\n 0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n (track.id & 0xFF000000) >> 24,\n (track.id & 0xFF0000) >> 16,\n (track.id & 0xFF00) >> 8,\n (track.id & 0xFF), // track_ID\n 0x00, 0x00, 0x00, 0x01, // default_sample_description_index\n 0x00, 0x00, 0x00, 0x00, // default_sample_duration\n 0x00, 0x00, 0x00, 0x00, // default_sample_size\n 0x00, 0x01, 0x00, 0x01 // default_sample_flags\n ]);\n // the last two bytes of default_sample_flags is the sample\n // degradation priority, a hint about the importance of this sample\n // relative to others. Lower the degradation priority for all sample\n // types other than video.\n if (track.type !== 'video') {\n result[result.length - 1] = 0x00;\n }\n\n return box(types.trex, result);\n};\n\n(function() {\n var audioTrun, videoTrun, trunHeader;\n\n // This method assumes all samples are uniform. That is, if a\n // duration is present for the first sample, it will be present for\n // all subsequent samples.\n // see ISO/IEC 14496-12:2012, Section 8.8.8.1\n trunHeader = function(samples, offset) {\n var durationPresent = 0, sizePresent = 0,\n flagsPresent = 0, compositionTimeOffset = 0;\n\n // trun flag constants\n if (samples.length) {\n if (samples[0].duration !== undefined) {\n durationPresent = 0x1;\n }\n if (samples[0].size !== undefined) {\n sizePresent = 0x2;\n }\n if (samples[0].flags !== undefined) {\n flagsPresent = 0x4;\n }\n if (samples[0].compositionTimeOffset !== undefined) {\n compositionTimeOffset = 0x8;\n }\n }\n\n return [\n 0x00, // version 0\n 0x00,\n durationPresent | sizePresent | flagsPresent | compositionTimeOffset,\n 0x01, // flags\n (samples.length & 0xFF000000) >>> 24,\n (samples.length & 0xFF0000) >>> 16,\n (samples.length & 0xFF00) >>> 8,\n samples.length & 0xFF, // sample_count\n (offset & 0xFF000000) >>> 24,\n (offset & 0xFF0000) >>> 16,\n (offset & 0xFF00) >>> 8,\n offset & 0xFF // data_offset\n ];\n };\n\n videoTrun = function(track, offset) {\n var bytes, samples, sample, i;\n\n samples = track.samples || [];\n offset += 8 + 12 + (16 * samples.length);\n\n bytes = trunHeader(samples, offset);\n\n for (i = 0; i < samples.length; i++) {\n sample = samples[i];\n bytes = bytes.concat([\n (sample.duration & 0xFF000000) >>> 24,\n (sample.duration & 0xFF0000) >>> 16,\n (sample.duration & 0xFF00) >>> 8,\n sample.duration & 0xFF, // sample_duration\n (sample.size & 0xFF000000) >>> 24,\n (sample.size & 0xFF0000) >>> 16,\n (sample.size & 0xFF00) >>> 8,\n sample.size & 0xFF, // sample_size\n (sample.flags.isLeading << 2) | sample.flags.dependsOn,\n (sample.flags.isDependedOn << 6) |\n (sample.flags.hasRedundancy << 4) |\n (sample.flags.paddingValue << 1) |\n sample.flags.isNonSyncSample,\n sample.flags.degradationPriority & 0xF0 << 8,\n sample.flags.degradationPriority & 0x0F, // sample_flags\n (sample.compositionTimeOffset & 0xFF000000) >>> 24,\n (sample.compositionTimeOffset & 0xFF0000) >>> 16,\n (sample.compositionTimeOffset & 0xFF00) >>> 8,\n sample.compositionTimeOffset & 0xFF // sample_composition_time_offset\n ]);\n }\n return box(types.trun, new Uint8Array(bytes));\n };\n\n audioTrun = function(track, offset) {\n var bytes, samples, sample, i;\n\n samples = track.samples || [];\n offset += 8 + 12 + (8 * samples.length);\n\n bytes = trunHeader(samples, offset);\n\n for (i = 0; i < samples.length; i++) {\n sample = samples[i];\n bytes = bytes.concat([\n (sample.duration & 0xFF000000) >>> 24,\n (sample.duration & 0xFF0000) >>> 16,\n (sample.duration & 0xFF00) >>> 8,\n sample.duration & 0xFF, // sample_duration\n (sample.size & 0xFF000000) >>> 24,\n (sample.size & 0xFF0000) >>> 16,\n (sample.size & 0xFF00) >>> 8,\n sample.size & 0xFF]); // sample_size\n }\n\n return box(types.trun, new Uint8Array(bytes));\n };\n\n trun = function(track, offset) {\n if (track.type === 'audio') {\n return audioTrun(track, offset);\n }\n\n return videoTrun(track, offset);\n };\n}());\n\nmodule.exports = {\n ftyp: ftyp,\n mdat: mdat,\n moof: moof,\n moov: moov,\n initSegment: function(tracks) {\n var\n fileType = ftyp(),\n movie = moov(tracks),\n result;\n\n result = new Uint8Array(fileType.byteLength + movie.byteLength);\n result.set(fileType);\n result.set(movie, fileType.byteLength);\n return result;\n }\n};\n","/**\n * mux.js\n *\n * Copyright (c) 2015 Brightcove\n * All rights reserved.\n *\n * Reads in-band caption information from a video elementary\n * stream. Captions must follow the CEA-708 standard for injection\n * into an MPEG-2 transport streams.\n * @see https://en.wikipedia.org/wiki/CEA-708\n * @see https://www.gpo.gov/fdsys/pkg/CFR-2007-title47-vol1/pdf/CFR-2007-title47-vol1-sec15-119.pdf\n */\n\n'use strict';\n\n// -----------------\n// Link To Transport\n// -----------------\n\nvar Stream = require('../utils/stream');\nvar cea708Parser = require('../tools/caption-packet-parser');\n\nvar CaptionStream = function() {\n\n CaptionStream.prototype.init.call(this);\n\n this.captionPackets_ = [];\n\n this.ccStreams_ = [\n new Cea608Stream(0, 0), // eslint-disable-line no-use-before-define\n new Cea608Stream(0, 1), // eslint-disable-line no-use-before-define\n new Cea608Stream(1, 0), // eslint-disable-line no-use-before-define\n new Cea608Stream(1, 1) // eslint-disable-line no-use-before-define\n ];\n\n this.reset();\n\n // forward data and done events from CCs to this CaptionStream\n this.ccStreams_.forEach(function(cc) {\n cc.on('data', this.trigger.bind(this, 'data'));\n cc.on('done', this.trigger.bind(this, 'done'));\n }, this);\n\n};\n\nCaptionStream.prototype = new Stream();\nCaptionStream.prototype.push = function(event) {\n var sei, userData, newCaptionPackets;\n\n // only examine SEI NALs\n if (event.nalUnitType !== 'sei_rbsp') {\n return;\n }\n\n // parse the sei\n sei = cea708Parser.parseSei(event.escapedRBSP);\n\n // ignore everything but user_data_registered_itu_t_t35\n if (sei.payloadType !== cea708Parser.USER_DATA_REGISTERED_ITU_T_T35) {\n return;\n }\n\n // parse out the user data payload\n userData = cea708Parser.parseUserData(sei);\n\n // ignore unrecognized userData\n if (!userData) {\n return;\n }\n\n // Sometimes, the same segment # will be downloaded twice. To stop the\n // caption data from being processed twice, we track the latest dts we've\n // received and ignore everything with a dts before that. However, since\n // data for a specific dts can be split across packets on either side of\n // a segment boundary, we need to make sure we *don't* ignore the packets\n // from the *next* segment that have dts === this.latestDts_. By constantly\n // tracking the number of packets received with dts === this.latestDts_, we\n // know how many should be ignored once we start receiving duplicates.\n if (event.dts < this.latestDts_) {\n // We've started getting older data, so set the flag.\n this.ignoreNextEqualDts_ = true;\n return;\n } else if ((event.dts === this.latestDts_) && (this.ignoreNextEqualDts_)) {\n this.numSameDts_--;\n if (!this.numSameDts_) {\n // We've received the last duplicate packet, time to start processing again\n this.ignoreNextEqualDts_ = false;\n }\n return;\n }\n\n // parse out CC data packets and save them for later\n newCaptionPackets = cea708Parser.parseCaptionPackets(event.pts, userData);\n this.captionPackets_ = this.captionPackets_.concat(newCaptionPackets);\n if (this.latestDts_ !== event.dts) {\n this.numSameDts_ = 0;\n }\n this.numSameDts_++;\n this.latestDts_ = event.dts;\n};\n\nCaptionStream.prototype.flush = function() {\n // make sure we actually parsed captions before proceeding\n if (!this.captionPackets_.length) {\n this.ccStreams_.forEach(function(cc) {\n cc.flush();\n }, this);\n return;\n }\n\n // In Chrome, the Array#sort function is not stable so add a\n // presortIndex that we can use to ensure we get a stable-sort\n this.captionPackets_.forEach(function(elem, idx) {\n elem.presortIndex = idx;\n });\n\n // sort caption byte-pairs based on their PTS values\n this.captionPackets_.sort(function(a, b) {\n if (a.pts === b.pts) {\n return a.presortIndex - b.presortIndex;\n }\n return a.pts - b.pts;\n });\n\n this.captionPackets_.forEach(function(packet) {\n if (packet.type < 2) {\n // Dispatch packet to the right Cea608Stream\n this.dispatchCea608Packet(packet);\n }\n // this is where an 'else' would go for a dispatching packets\n // to a theoretical Cea708Stream that handles SERVICEn data\n }, this);\n\n this.captionPackets_.length = 0;\n this.ccStreams_.forEach(function(cc) {\n cc.flush();\n }, this);\n return;\n};\n\nCaptionStream.prototype.reset = function() {\n this.latestDts_ = null;\n this.ignoreNextEqualDts_ = false;\n this.numSameDts_ = 0;\n this.activeCea608Channel_ = [null, null];\n this.ccStreams_.forEach(function(ccStream) {\n ccStream.reset();\n });\n};\n\nCaptionStream.prototype.dispatchCea608Packet = function(packet) {\n // NOTE: packet.type is the CEA608 field\n if (this.setsChannel1Active(packet)) {\n this.activeCea608Channel_[packet.type] = 0;\n } else if (this.setsChannel2Active(packet)) {\n this.activeCea608Channel_[packet.type] = 1;\n }\n if (this.activeCea608Channel_[packet.type] === null) {\n // If we haven't received anything to set the active channel, discard the\n // data; we don't want jumbled captions\n return;\n }\n this.ccStreams_[(packet.type << 1) + this.activeCea608Channel_[packet.type]].push(packet);\n};\n\nCaptionStream.prototype.setsChannel1Active = function(packet) {\n return ((packet.ccData & 0x7800) === 0x1000);\n};\nCaptionStream.prototype.setsChannel2Active = function(packet) {\n return ((packet.ccData & 0x7800) === 0x1800);\n};\n\n// ----------------------\n// Session to Application\n// ----------------------\n\n// This hash maps non-ASCII, special, and extended character codes to their\n// proper Unicode equivalent. The first keys that are only a single byte\n// are the non-standard ASCII characters, which simply map the CEA608 byte\n// to the standard ASCII/Unicode. The two-byte keys that follow are the CEA608\n// character codes, but have their MSB bitmasked with 0x03 so that a lookup\n// can be performed regardless of the field and data channel on which the\n// character code was received.\nvar CHARACTER_TRANSLATION = {\n 0x2a: 0xe1, // á\n 0x5c: 0xe9, // é\n 0x5e: 0xed, // í\n 0x5f: 0xf3, // ó\n 0x60: 0xfa, // ú\n 0x7b: 0xe7, // ç\n 0x7c: 0xf7, // ÷\n 0x7d: 0xd1, // Ñ\n 0x7e: 0xf1, // ñ\n 0x7f: 0x2588, // █\n 0x0130: 0xae, // ®\n 0x0131: 0xb0, // °\n 0x0132: 0xbd, // ½\n 0x0133: 0xbf, // ¿\n 0x0134: 0x2122, // ™\n 0x0135: 0xa2, // ¢\n 0x0136: 0xa3, // £\n 0x0137: 0x266a, // ♪\n 0x0138: 0xe0, // à\n 0x0139: 0xa0, //\n 0x013a: 0xe8, // è\n 0x013b: 0xe2, // â\n 0x013c: 0xea, // ê\n 0x013d: 0xee, // î\n 0x013e: 0xf4, // ô\n 0x013f: 0xfb, // û\n 0x0220: 0xc1, // Á\n 0x0221: 0xc9, // É\n 0x0222: 0xd3, // Ó\n 0x0223: 0xda, // Ú\n 0x0224: 0xdc, // Ü\n 0x0225: 0xfc, // ü\n 0x0226: 0x2018, // ‘\n 0x0227: 0xa1, // ¡\n 0x0228: 0x2a, // *\n 0x0229: 0x27, // '\n 0x022a: 0x2014, // —\n 0x022b: 0xa9, // ©\n 0x022c: 0x2120, // ℠\n 0x022d: 0x2022, // •\n 0x022e: 0x201c, // “\n 0x022f: 0x201d, // ”\n 0x0230: 0xc0, // À\n 0x0231: 0xc2, // Â\n 0x0232: 0xc7, // Ç\n 0x0233: 0xc8, // È\n 0x0234: 0xca, // Ê\n 0x0235: 0xcb, // Ë\n 0x0236: 0xeb, // ë\n 0x0237: 0xce, // Î\n 0x0238: 0xcf, // Ï\n 0x0239: 0xef, // ï\n 0x023a: 0xd4, // Ô\n 0x023b: 0xd9, // Ù\n 0x023c: 0xf9, // ù\n 0x023d: 0xdb, // Û\n 0x023e: 0xab, // «\n 0x023f: 0xbb, // »\n 0x0320: 0xc3, // Ã\n 0x0321: 0xe3, // ã\n 0x0322: 0xcd, // Í\n 0x0323: 0xcc, // Ì\n 0x0324: 0xec, // ì\n 0x0325: 0xd2, // Ò\n 0x0326: 0xf2, // ò\n 0x0327: 0xd5, // Õ\n 0x0328: 0xf5, // õ\n 0x0329: 0x7b, // {\n 0x032a: 0x7d, // }\n 0x032b: 0x5c, // \\\n 0x032c: 0x5e, // ^\n 0x032d: 0x5f, // _\n 0x032e: 0x7c, // |\n 0x032f: 0x7e, // ~\n 0x0330: 0xc4, // Ä\n 0x0331: 0xe4, // ä\n 0x0332: 0xd6, // Ö\n 0x0333: 0xf6, // ö\n 0x0334: 0xdf, // ß\n 0x0335: 0xa5, // ¥\n 0x0336: 0xa4, // ¤\n 0x0337: 0x2502, // │\n 0x0338: 0xc5, // Å\n 0x0339: 0xe5, // å\n 0x033a: 0xd8, // Ø\n 0x033b: 0xf8, // ø\n 0x033c: 0x250c, // ┌\n 0x033d: 0x2510, // ┐\n 0x033e: 0x2514, // └\n 0x033f: 0x2518 // ┘\n};\n\nvar getCharFromCode = function(code) {\n if (code === null) {\n return '';\n }\n code = CHARACTER_TRANSLATION[code] || code;\n return String.fromCharCode(code);\n};\n\n// the index of the last row in a CEA-608 display buffer\nvar BOTTOM_ROW = 14;\n\n// This array is used for mapping PACs -> row #, since there's no way of\n// getting it through bit logic.\nvar ROWS = [0x1100, 0x1120, 0x1200, 0x1220, 0x1500, 0x1520, 0x1600, 0x1620,\n 0x1700, 0x1720, 0x1000, 0x1300, 0x1320, 0x1400, 0x1420];\n\n// CEA-608 captions are rendered onto a 34x15 matrix of character\n// cells. The \"bottom\" row is the last element in the outer array.\nvar createDisplayBuffer = function() {\n var result = [], i = BOTTOM_ROW + 1;\n while (i--) {\n result.push('');\n }\n return result;\n};\n\nvar Cea608Stream = function(field, dataChannel) {\n Cea608Stream.prototype.init.call(this);\n\n this.field_ = field || 0;\n this.dataChannel_ = dataChannel || 0;\n\n this.name_ = 'CC' + (((this.field_ << 1) | this.dataChannel_) + 1);\n\n this.setConstants();\n this.reset();\n\n this.push = function(packet) {\n var data, swap, char0, char1, text;\n // remove the parity bits\n data = packet.ccData & 0x7f7f;\n\n // ignore duplicate control codes; the spec demands they're sent twice\n if (data === this.lastControlCode_) {\n this.lastControlCode_ = null;\n return;\n }\n\n // Store control codes\n if ((data & 0xf000) === 0x1000) {\n this.lastControlCode_ = data;\n } else if (data !== this.PADDING_) {\n this.lastControlCode_ = null;\n }\n\n char0 = data >>> 8;\n char1 = data & 0xff;\n\n if (data === this.PADDING_) {\n return;\n\n } else if (data === this.RESUME_CAPTION_LOADING_) {\n this.mode_ = 'popOn';\n\n } else if (data === this.END_OF_CAPTION_) {\n // If an EOC is received while in paint-on mode, the displayed caption\n // text should be swapped to non-displayed memory as if it was a pop-on\n // caption. Because of that, we should explicitly switch back to pop-on\n // mode\n this.mode_ = 'popOn';\n this.clearFormatting(packet.pts);\n // if a caption was being displayed, it's gone now\n this.flushDisplayed(packet.pts);\n\n // flip memory\n swap = this.displayed_;\n this.displayed_ = this.nonDisplayed_;\n this.nonDisplayed_ = swap;\n\n // start measuring the time to display the caption\n this.startPts_ = packet.pts;\n\n } else if (data === this.ROLL_UP_2_ROWS_) {\n this.rollUpRows_ = 2;\n this.setRollUp(packet.pts);\n } else if (data === this.ROLL_UP_3_ROWS_) {\n this.rollUpRows_ = 3;\n this.setRollUp(packet.pts);\n } else if (data === this.ROLL_UP_4_ROWS_) {\n this.rollUpRows_ = 4;\n this.setRollUp(packet.pts);\n } else if (data === this.CARRIAGE_RETURN_) {\n this.clearFormatting(packet.pts);\n this.flushDisplayed(packet.pts);\n this.shiftRowsUp_();\n this.startPts_ = packet.pts;\n\n } else if (data === this.BACKSPACE_) {\n if (this.mode_ === 'popOn') {\n this.nonDisplayed_[this.row_] = this.nonDisplayed_[this.row_].slice(0, -1);\n } else {\n this.displayed_[this.row_] = this.displayed_[this.row_].slice(0, -1);\n }\n } else if (data === this.ERASE_DISPLAYED_MEMORY_) {\n this.flushDisplayed(packet.pts);\n this.displayed_ = createDisplayBuffer();\n } else if (data === this.ERASE_NON_DISPLAYED_MEMORY_) {\n this.nonDisplayed_ = createDisplayBuffer();\n\n } else if (data === this.RESUME_DIRECT_CAPTIONING_) {\n if (this.mode_ !== 'paintOn') {\n // NOTE: This should be removed when proper caption positioning is\n // implemented\n this.flushDisplayed(packet.pts);\n this.displayed_ = createDisplayBuffer();\n }\n this.mode_ = 'paintOn';\n this.startPts_ = packet.pts;\n\n // Append special characters to caption text\n } else if (this.isSpecialCharacter(char0, char1)) {\n // Bitmask char0 so that we can apply character transformations\n // regardless of field and data channel.\n // Then byte-shift to the left and OR with char1 so we can pass the\n // entire character code to `getCharFromCode`.\n char0 = (char0 & 0x03) << 8;\n text = getCharFromCode(char0 | char1);\n this[this.mode_](packet.pts, text);\n this.column_++;\n\n // Append extended characters to caption text\n } else if (this.isExtCharacter(char0, char1)) {\n // Extended characters always follow their \"non-extended\" equivalents.\n // IE if a \"è\" is desired, you'll always receive \"eè\"; non-compliant\n // decoders are supposed to drop the \"è\", while compliant decoders\n // backspace the \"e\" and insert \"è\".\n\n // Delete the previous character\n if (this.mode_ === 'popOn') {\n this.nonDisplayed_[this.row_] = this.nonDisplayed_[this.row_].slice(0, -1);\n } else {\n this.displayed_[this.row_] = this.displayed_[this.row_].slice(0, -1);\n }\n\n // Bitmask char0 so that we can apply character transformations\n // regardless of field and data channel.\n // Then byte-shift to the left and OR with char1 so we can pass the\n // entire character code to `getCharFromCode`.\n char0 = (char0 & 0x03) << 8;\n text = getCharFromCode(char0 | char1);\n this[this.mode_](packet.pts, text);\n this.column_++;\n\n // Process mid-row codes\n } else if (this.isMidRowCode(char0, char1)) {\n // Attributes are not additive, so clear all formatting\n this.clearFormatting(packet.pts);\n\n // According to the standard, mid-row codes\n // should be replaced with spaces, so add one now\n this[this.mode_](packet.pts, ' ');\n this.column_++;\n\n if ((char1 & 0xe) === 0xe) {\n this.addFormatting(packet.pts, ['i']);\n }\n\n if ((char1 & 0x1) === 0x1) {\n this.addFormatting(packet.pts, ['u']);\n }\n\n // Detect offset control codes and adjust cursor\n } else if (this.isOffsetControlCode(char0, char1)) {\n // Cursor position is set by indent PAC (see below) in 4-column\n // increments, with an additional offset code of 1-3 to reach any\n // of the 32 columns specified by CEA-608. So all we need to do\n // here is increment the column cursor by the given offset.\n this.column_ += (char1 & 0x03);\n\n // Detect PACs (Preamble Address Codes)\n } else if (this.isPAC(char0, char1)) {\n\n // There's no logic for PAC -> row mapping, so we have to just\n // find the row code in an array and use its index :(\n var row = ROWS.indexOf(data & 0x1f20);\n\n // Configure the caption window if we're in roll-up mode\n if (this.mode_ === 'rollUp') {\n // This implies that the base row is incorrectly set.\n // As per the recommendation in CEA-608(Base Row Implementation), defer to the number\n // of roll-up rows set.\n if (row - this.rollUpRows_ + 1 < 0) {\n row = this.rollUpRows_ - 1;\n }\n\n this.setRollUp(packet.pts, row);\n }\n\n if (row !== this.row_) {\n // formatting is only persistent for current row\n this.clearFormatting(packet.pts);\n this.row_ = row;\n }\n // All PACs can apply underline, so detect and apply\n // (All odd-numbered second bytes set underline)\n if ((char1 & 0x1) && (this.formatting_.indexOf('u') === -1)) {\n this.addFormatting(packet.pts, ['u']);\n }\n\n if ((data & 0x10) === 0x10) {\n // We've got an indent level code. Each successive even number\n // increments the column cursor by 4, so we can get the desired\n // column position by bit-shifting to the right (to get n/2)\n // and multiplying by 4.\n this.column_ = ((data & 0xe) >> 1) * 4;\n }\n\n if (this.isColorPAC(char1)) {\n // it's a color code, though we only support white, which\n // can be either normal or italicized. white italics can be\n // either 0x4e or 0x6e depending on the row, so we just\n // bitwise-and with 0xe to see if italics should be turned on\n if ((char1 & 0xe) === 0xe) {\n this.addFormatting(packet.pts, ['i']);\n }\n }\n\n // We have a normal character in char0, and possibly one in char1\n } else if (this.isNormalChar(char0)) {\n if (char1 === 0x00) {\n char1 = null;\n }\n text = getCharFromCode(char0);\n text += getCharFromCode(char1);\n this[this.mode_](packet.pts, text);\n this.column_ += text.length;\n\n } // finish data processing\n\n };\n};\nCea608Stream.prototype = new Stream();\n// Trigger a cue point that captures the current state of the\n// display buffer\nCea608Stream.prototype.flushDisplayed = function(pts) {\n var content = this.displayed_\n // remove spaces from the start and end of the string\n .map(function(row) {\n try {\n return row.trim();\n } catch (e) {\n // Ordinarily, this shouldn't happen. However, caption\n // parsing errors should not throw exceptions and\n // break playback.\n // eslint-disable-next-line no-console\n console.error('Skipping malformed caption.');\n return '';\n }\n })\n // combine all text rows to display in one cue\n .join('\\n')\n // and remove blank rows from the start and end, but not the middle\n .replace(/^\\n+|\\n+$/g, '');\n\n if (content.length) {\n this.trigger('data', {\n startPts: this.startPts_,\n endPts: pts,\n text: content,\n stream: this.name_\n });\n }\n};\n\n/**\n * Zero out the data, used for startup and on seek\n */\nCea608Stream.prototype.reset = function() {\n this.mode_ = 'popOn';\n // When in roll-up mode, the index of the last row that will\n // actually display captions. If a caption is shifted to a row\n // with a lower index than this, it is cleared from the display\n // buffer\n this.topRow_ = 0;\n this.startPts_ = 0;\n this.displayed_ = createDisplayBuffer();\n this.nonDisplayed_ = createDisplayBuffer();\n this.lastControlCode_ = null;\n\n // Track row and column for proper line-breaking and spacing\n this.column_ = 0;\n this.row_ = BOTTOM_ROW;\n this.rollUpRows_ = 2;\n\n // This variable holds currently-applied formatting\n this.formatting_ = [];\n};\n\n/**\n * Sets up control code and related constants for this instance\n */\nCea608Stream.prototype.setConstants = function() {\n // The following attributes have these uses:\n // ext_ : char0 for mid-row codes, and the base for extended\n // chars (ext_+0, ext_+1, and ext_+2 are char0s for\n // extended codes)\n // control_: char0 for control codes, except byte-shifted to the\n // left so that we can do this.control_ | CONTROL_CODE\n // offset_: char0 for tab offset codes\n //\n // It's also worth noting that control codes, and _only_ control codes,\n // differ between field 1 and field2. Field 2 control codes are always\n // their field 1 value plus 1. That's why there's the \"| field\" on the\n // control value.\n if (this.dataChannel_ === 0) {\n this.BASE_ = 0x10;\n this.EXT_ = 0x11;\n this.CONTROL_ = (0x14 | this.field_) << 8;\n this.OFFSET_ = 0x17;\n } else if (this.dataChannel_ === 1) {\n this.BASE_ = 0x18;\n this.EXT_ = 0x19;\n this.CONTROL_ = (0x1c | this.field_) << 8;\n this.OFFSET_ = 0x1f;\n }\n\n // Constants for the LSByte command codes recognized by Cea608Stream. This\n // list is not exhaustive. For a more comprehensive listing and semantics see\n // http://www.gpo.gov/fdsys/pkg/CFR-2010-title47-vol1/pdf/CFR-2010-title47-vol1-sec15-119.pdf\n // Padding\n this.PADDING_ = 0x0000;\n // Pop-on Mode\n this.RESUME_CAPTION_LOADING_ = this.CONTROL_ | 0x20;\n this.END_OF_CAPTION_ = this.CONTROL_ | 0x2f;\n // Roll-up Mode\n this.ROLL_UP_2_ROWS_ = this.CONTROL_ | 0x25;\n this.ROLL_UP_3_ROWS_ = this.CONTROL_ | 0x26;\n this.ROLL_UP_4_ROWS_ = this.CONTROL_ | 0x27;\n this.CARRIAGE_RETURN_ = this.CONTROL_ | 0x2d;\n // paint-on mode\n this.RESUME_DIRECT_CAPTIONING_ = this.CONTROL_ | 0x29;\n // Erasure\n this.BACKSPACE_ = this.CONTROL_ | 0x21;\n this.ERASE_DISPLAYED_MEMORY_ = this.CONTROL_ | 0x2c;\n this.ERASE_NON_DISPLAYED_MEMORY_ = this.CONTROL_ | 0x2e;\n};\n\n/**\n * Detects if the 2-byte packet data is a special character\n *\n * Special characters have a second byte in the range 0x30 to 0x3f,\n * with the first byte being 0x11 (for data channel 1) or 0x19 (for\n * data channel 2).\n *\n * @param {Integer} char0 The first byte\n * @param {Integer} char1 The second byte\n * @return {Boolean} Whether the 2 bytes are an special character\n */\nCea608Stream.prototype.isSpecialCharacter = function(char0, char1) {\n return (char0 === this.EXT_ && char1 >= 0x30 && char1 <= 0x3f);\n};\n\n/**\n * Detects if the 2-byte packet data is an extended character\n *\n * Extended characters have a second byte in the range 0x20 to 0x3f,\n * with the first byte being 0x12 or 0x13 (for data channel 1) or\n * 0x1a or 0x1b (for data channel 2).\n *\n * @param {Integer} char0 The first byte\n * @param {Integer} char1 The second byte\n * @return {Boolean} Whether the 2 bytes are an extended character\n */\nCea608Stream.prototype.isExtCharacter = function(char0, char1) {\n return ((char0 === (this.EXT_ + 1) || char0 === (this.EXT_ + 2)) &&\n (char1 >= 0x20 && char1 <= 0x3f));\n};\n\n/**\n * Detects if the 2-byte packet is a mid-row code\n *\n * Mid-row codes have a second byte in the range 0x20 to 0x2f, with\n * the first byte being 0x11 (for data channel 1) or 0x19 (for data\n * channel 2).\n *\n * @param {Integer} char0 The first byte\n * @param {Integer} char1 The second byte\n * @return {Boolean} Whether the 2 bytes are a mid-row code\n */\nCea608Stream.prototype.isMidRowCode = function(char0, char1) {\n return (char0 === this.EXT_ && (char1 >= 0x20 && char1 <= 0x2f));\n};\n\n/**\n * Detects if the 2-byte packet is an offset control code\n *\n * Offset control codes have a second byte in the range 0x21 to 0x23,\n * with the first byte being 0x17 (for data channel 1) or 0x1f (for\n * data channel 2).\n *\n * @param {Integer} char0 The first byte\n * @param {Integer} char1 The second byte\n * @return {Boolean} Whether the 2 bytes are an offset control code\n */\nCea608Stream.prototype.isOffsetControlCode = function(char0, char1) {\n return (char0 === this.OFFSET_ && (char1 >= 0x21 && char1 <= 0x23));\n};\n\n/**\n * Detects if the 2-byte packet is a Preamble Address Code\n *\n * PACs have a first byte in the range 0x10 to 0x17 (for data channel 1)\n * or 0x18 to 0x1f (for data channel 2), with the second byte in the\n * range 0x40 to 0x7f.\n *\n * @param {Integer} char0 The first byte\n * @param {Integer} char1 The second byte\n * @return {Boolean} Whether the 2 bytes are a PAC\n */\nCea608Stream.prototype.isPAC = function(char0, char1) {\n return (char0 >= this.BASE_ && char0 < (this.BASE_ + 8) &&\n (char1 >= 0x40 && char1 <= 0x7f));\n};\n\n/**\n * Detects if a packet's second byte is in the range of a PAC color code\n *\n * PAC color codes have the second byte be in the range 0x40 to 0x4f, or\n * 0x60 to 0x6f.\n *\n * @param {Integer} char1 The second byte\n * @return {Boolean} Whether the byte is a color PAC\n */\nCea608Stream.prototype.isColorPAC = function(char1) {\n return ((char1 >= 0x40 && char1 <= 0x4f) || (char1 >= 0x60 && char1 <= 0x7f));\n};\n\n/**\n * Detects if a single byte is in the range of a normal character\n *\n * Normal text bytes are in the range 0x20 to 0x7f.\n *\n * @param {Integer} char The byte\n * @return {Boolean} Whether the byte is a normal character\n */\nCea608Stream.prototype.isNormalChar = function(char) {\n return (char >= 0x20 && char <= 0x7f);\n};\n\n/**\n * Configures roll-up\n *\n * @param {Integer} pts Current PTS\n * @param {Integer} newBaseRow Used by PACs to slide the current window to\n * a new position\n */\nCea608Stream.prototype.setRollUp = function(pts, newBaseRow) {\n // Reset the base row to the bottom row when switching modes\n if (this.mode_ !== 'rollUp') {\n this.row_ = BOTTOM_ROW;\n this.mode_ = 'rollUp';\n // Spec says to wipe memories when switching to roll-up\n this.flushDisplayed(pts);\n this.nonDisplayed_ = createDisplayBuffer();\n this.displayed_ = createDisplayBuffer();\n }\n\n if (newBaseRow !== undefined && newBaseRow !== this.row_) {\n // move currently displayed captions (up or down) to the new base row\n for (var i = 0; i < this.rollUpRows_; i++) {\n this.displayed_[newBaseRow - i] = this.displayed_[this.row_ - i];\n this.displayed_[this.row_ - i] = '';\n }\n }\n\n if (newBaseRow === undefined) {\n newBaseRow = this.row_;\n }\n\n this.topRow_ = newBaseRow - this.rollUpRows_ + 1;\n};\n\n// Adds the opening HTML tag for the passed character to the caption text,\n// and keeps track of it for later closing\nCea608Stream.prototype.addFormatting = function(pts, format) {\n this.formatting_ = this.formatting_.concat(format);\n var text = format.reduce(function(text, format) {\n return text + '<' + format + '>';\n }, '');\n this[this.mode_](pts, text);\n};\n\n// Adds HTML closing tags for current formatting to caption text and\n// clears remembered formatting\nCea608Stream.prototype.clearFormatting = function(pts) {\n if (!this.formatting_.length) {\n return;\n }\n var text = this.formatting_.reverse().reduce(function(text, format) {\n return text + '</' + format + '>';\n }, '');\n this.formatting_ = [];\n this[this.mode_](pts, text);\n};\n\n// Mode Implementations\nCea608Stream.prototype.popOn = function(pts, text) {\n var baseRow = this.nonDisplayed_[this.row_];\n\n // buffer characters\n baseRow += text;\n this.nonDisplayed_[this.row_] = baseRow;\n};\n\nCea608Stream.prototype.rollUp = function(pts, text) {\n var baseRow = this.displayed_[this.row_];\n\n baseRow += text;\n this.displayed_[this.row_] = baseRow;\n\n};\n\nCea608Stream.prototype.shiftRowsUp_ = function() {\n var i;\n // clear out inactive rows\n for (i = 0; i < this.topRow_; i++) {\n this.displayed_[i] = '';\n }\n for (i = this.row_ + 1; i < BOTTOM_ROW + 1; i++) {\n this.displayed_[i] = '';\n }\n // shift displayed rows up\n for (i = this.topRow_; i < this.row_; i++) {\n this.displayed_[i] = this.displayed_[i + 1];\n }\n // clear out the bottom row\n this.displayed_[this.row_] = '';\n};\n\nCea608Stream.prototype.paintOn = function(pts, text) {\n var baseRow = this.displayed_[this.row_];\n\n baseRow += text;\n this.displayed_[this.row_] = baseRow;\n};\n\n// exports\nmodule.exports = {\n CaptionStream: CaptionStream,\n Cea608Stream: Cea608Stream\n};\n","/**\n * mux.js\n *\n * Copyright (c) 2015 Brightcove\n * All rights reserved.\n *\n * Reads in-band caption information from a video elementary\n * stream. Captions must follow the CEA-708 standard for injection\n * into an MPEG-2 transport streams.\n * @see https://en.wikipedia.org/wiki/CEA-708\n * @see https://www.gpo.gov/fdsys/pkg/CFR-2007-title47-vol1/pdf/CFR-2007-title47-vol1-sec15-119.pdf\n */\n\n'use strict';\n\n// Supplemental enhancement information (SEI) NAL units have a\n// payload type field to indicate how they are to be\n// interpreted. CEAS-708 caption content is always transmitted with\n// payload type 0x04.\nvar USER_DATA_REGISTERED_ITU_T_T35 = 4,\n RBSP_TRAILING_BITS = 128;\n\n/**\n * Parse a supplemental enhancement information (SEI) NAL unit.\n * Stops parsing once a message of type ITU T T35 has been found.\n *\n * @param bytes {Uint8Array} the bytes of a SEI NAL unit\n * @return {object} the parsed SEI payload\n * @see Rec. ITU-T H.264, 7.3.2.3.1\n */\nvar parseSei = function(bytes) {\n var\n i = 0,\n result = {\n payloadType: -1,\n payloadSize: 0\n },\n payloadType = 0,\n payloadSize = 0;\n\n // go through the sei_rbsp parsing each each individual sei_message\n while (i < bytes.byteLength) {\n // stop once we have hit the end of the sei_rbsp\n if (bytes[i] === RBSP_TRAILING_BITS) {\n break;\n }\n\n // Parse payload type\n while (bytes[i] === 0xFF) {\n payloadType += 255;\n i++;\n }\n payloadType += bytes[i++];\n\n // Parse payload size\n while (bytes[i] === 0xFF) {\n payloadSize += 255;\n i++;\n }\n payloadSize += bytes[i++];\n\n // this sei_message is a 608/708 caption so save it and break\n // there can only ever be one caption message in a frame's sei\n if (!result.payload && payloadType === USER_DATA_REGISTERED_ITU_T_T35) {\n result.payloadType = payloadType;\n result.payloadSize = payloadSize;\n result.payload = bytes.subarray(i, i + payloadSize);\n break;\n }\n\n // skip the payload and parse the next message\n i += payloadSize;\n payloadType = 0;\n payloadSize = 0;\n }\n\n return result;\n};\n\n// see ANSI/SCTE 128-1 (2013), section 8.1\nvar parseUserData = function(sei) {\n // itu_t_t35_contry_code must be 181 (United States) for\n // captions\n if (sei.payload[0] !== 181) {\n return null;\n }\n\n // itu_t_t35_provider_code should be 49 (ATSC) for captions\n if (((sei.payload[1] << 8) | sei.payload[2]) !== 49) {\n return null;\n }\n\n // the user_identifier should be \"GA94\" to indicate ATSC1 data\n if (String.fromCharCode(sei.payload[3],\n sei.payload[4],\n sei.payload[5],\n sei.payload[6]) !== 'GA94') {\n return null;\n }\n\n // finally, user_data_type_code should be 0x03 for caption data\n if (sei.payload[7] !== 0x03) {\n return null;\n }\n\n // return the user_data_type_structure and strip the trailing\n // marker bits\n return sei.payload.subarray(8, sei.payload.length - 1);\n};\n\n// see CEA-708-D, section 4.4\nvar parseCaptionPackets = function(pts, userData) {\n var results = [], i, count, offset, data;\n\n // if this is just filler, return immediately\n if (!(userData[0] & 0x40)) {\n return results;\n }\n\n // parse out the cc_data_1 and cc_data_2 fields\n count = userData[0] & 0x1f;\n for (i = 0; i < count; i++) {\n offset = i * 3;\n data = {\n type: userData[offset + 2] & 0x03,\n pts: pts\n };\n\n // capture cc data when cc_valid is 1\n if (userData[offset + 2] & 0x04) {\n data.ccData = (userData[offset + 3] << 8) | userData[offset + 4];\n results.push(data);\n }\n }\n return results;\n};\n\nvar discardEmulationPreventionBytes = function(data) {\n var\n length = data.byteLength,\n emulationPreventionBytesPositions = [],\n i = 1,\n newLength, newData;\n\n // Find all `Emulation Prevention Bytes`\n while (i < length - 2) {\n if (data[i] === 0 && data[i + 1] === 0 && data[i + 2] === 0x03) {\n emulationPreventionBytesPositions.push(i + 2);\n i += 2;\n } else {\n i++;\n }\n }\n\n // If no Emulation Prevention Bytes were found just return the original\n // array\n if (emulationPreventionBytesPositions.length === 0) {\n return data;\n }\n\n // Create a new array to hold the NAL unit data\n newLength = length - emulationPreventionBytesPositions.length;\n newData = new Uint8Array(newLength);\n var sourceIndex = 0;\n\n for (i = 0; i < newLength; sourceIndex++, i++) {\n if (sourceIndex === emulationPreventionBytesPositions[0]) {\n // Skip this byte\n sourceIndex++;\n // Remove this position index\n emulationPreventionBytesPositions.shift();\n }\n newData[i] = data[sourceIndex];\n }\n\n return newData;\n};\n\n// exports\nmodule.exports = {\n parseSei: parseSei,\n parseUserData: parseUserData,\n parseCaptionPackets: parseCaptionPackets,\n discardEmulationPreventionBytes: discardEmulationPreventionBytes,\n USER_DATA_REGISTERED_ITU_T_T35: USER_DATA_REGISTERED_ITU_T_T35\n};\n","/**\n * mux.js\n *\n * Copyright (c) 2016 Brightcove\n * All rights reserved.\n *\n * Accepts program elementary stream (PES) data events and corrects\n * decode and presentation time stamps to account for a rollover\n * of the 33 bit value.\n */\n\n'use strict';\n\nvar Stream = require('../utils/stream');\n\nvar MAX_TS = 8589934592;\n\nvar RO_THRESH = 4294967296;\n\nvar handleRollover = function(value, reference) {\n var direction = 1;\n\n if (value > reference) {\n // If the current timestamp value is greater than our reference timestamp and we detect a\n // timestamp rollover, this means the roll over is happening in the opposite direction.\n // Example scenario: Enter a long stream/video just after a rollover occurred. The reference\n // point will be set to a small number, e.g. 1. The user then seeks backwards over the\n // rollover point. In loading this segment, the timestamp values will be very large,\n // e.g. 2^33 - 1. Since this comes before the data we loaded previously, we want to adjust\n // the time stamp to be `value - 2^33`.\n direction = -1;\n }\n\n // Note: A seek forwards or back that is greater than the RO_THRESH (2^32, ~13 hours) will\n // cause an incorrect adjustment.\n while (Math.abs(reference - value) > RO_THRESH) {\n value += (direction * MAX_TS);\n }\n\n return value;\n};\n\nvar TimestampRolloverStream = function(type) {\n var lastDTS, referenceDTS;\n\n TimestampRolloverStream.prototype.init.call(this);\n\n this.type_ = type;\n\n this.push = function(data) {\n if (data.type !== this.type_) {\n return;\n }\n\n if (referenceDTS === undefined) {\n referenceDTS = data.dts;\n }\n\n data.dts = handleRollover(data.dts, referenceDTS);\n data.pts = handleRollover(data.pts, referenceDTS);\n\n lastDTS = data.dts;\n\n this.trigger('data', data);\n };\n\n this.flush = function() {\n referenceDTS = lastDTS;\n this.trigger('done');\n };\n\n this.discontinuity = function() {\n referenceDTS = void 0;\n lastDTS = void 0;\n };\n\n};\n\nTimestampRolloverStream.prototype = new Stream();\n\nmodule.exports = {\n TimestampRolloverStream: TimestampRolloverStream,\n handleRollover: handleRollover\n};\n","\"use strict\";\n\n/*\n MIT License http://www.opensource.org/licenses/mit-license.php\n Author Tobias Koppers @sokra\n*/\n// css base code, injected by the css-loader\nmodule.exports = function (useSourceMap) {\n var list = []; // return the list of modules as css string\n\n list.toString = function toString() {\n return this.map(function (item) {\n var content = cssWithMappingToString(item, useSourceMap);\n\n if (item[2]) {\n return '@media ' + item[2] + '{' + content + '}';\n } else {\n return content;\n }\n }).join('');\n }; // import a list of modules into the list\n\n\n list.i = function (modules, mediaQuery) {\n if (typeof modules === 'string') {\n modules = [[null, modules, '']];\n }\n\n var alreadyImportedModules = {};\n\n for (var i = 0; i < this.length; i++) {\n var id = this[i][0];\n\n if (id != null) {\n alreadyImportedModules[id] = true;\n }\n }\n\n for (i = 0; i < modules.length; i++) {\n var item = modules[i]; // skip already imported module\n // this implementation is not 100% perfect for weird media query combinations\n // when a module is imported multiple times with different media queries.\n // I hope this will never occur (Hey this way we have smaller bundles)\n\n if (item[0] == null || !alreadyImportedModules[item[0]]) {\n if (mediaQuery && !item[2]) {\n item[2] = mediaQuery;\n } else if (mediaQuery) {\n item[2] = '(' + item[2] + ') and (' + mediaQuery + ')';\n }\n\n list.push(item);\n }\n }\n };\n\n return list;\n};\n\nfunction cssWithMappingToString(item, useSourceMap) {\n var content = item[1] || '';\n var cssMapping = item[3];\n\n if (!cssMapping) {\n return content;\n }\n\n if (useSourceMap && typeof btoa === 'function') {\n var sourceMapping = toComment(cssMapping);\n var sourceURLs = cssMapping.sources.map(function (source) {\n return '/*# sourceURL=' + cssMapping.sourceRoot + source + ' */';\n });\n return [content].concat(sourceURLs).concat([sourceMapping]).join('\\n');\n }\n\n return [content].join('\\n');\n} // Adapted from convert-source-map (MIT)\n\n\nfunction toComment(sourceMap) {\n // eslint-disable-next-line no-undef\n var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap))));\n var data = 'sourceMappingURL=data:application/json;charset=utf-8;base64,' + base64;\n return '/*# ' + data + ' */';\n}","/*\n\tMIT License http://www.opensource.org/licenses/mit-license.php\n\tAuthor Tobias Koppers @sokra\n*/\n\nvar stylesInDom = {};\n\nvar\tmemoize = function (fn) {\n\tvar memo;\n\n\treturn function () {\n\t\tif (typeof memo === \"undefined\") memo = fn.apply(this, arguments);\n\t\treturn memo;\n\t};\n};\n\nvar isOldIE = memoize(function () {\n\t// Test for IE <= 9 as proposed by Browserhacks\n\t// @see http://browserhacks.com/#hack-e71d8692f65334173fee715c222cb805\n\t// Tests for existence of standard globals is to allow style-loader\n\t// to operate correctly into non-standard environments\n\t// @see https://github.com/webpack-contrib/style-loader/issues/177\n\treturn window && document && document.all && !window.atob;\n});\n\nvar getTarget = function (target, parent) {\n if (parent){\n return parent.querySelector(target);\n }\n return document.querySelector(target);\n};\n\nvar getElement = (function (fn) {\n\tvar memo = {};\n\n\treturn function(target, parent) {\n // If passing function in options, then use it for resolve \"head\" element.\n // Useful for Shadow Root style i.e\n // {\n // insertInto: function () { return document.querySelector(\"#foo\").shadowRoot }\n // }\n if (typeof target === 'function') {\n return target();\n }\n if (typeof memo[target] === \"undefined\") {\n\t\t\tvar styleTarget = getTarget.call(this, target, parent);\n\t\t\t// Special case to return head of iframe instead of iframe itself\n\t\t\tif (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) {\n\t\t\t\ttry {\n\t\t\t\t\t// This will throw an exception if access to iframe is blocked\n\t\t\t\t\t// due to cross-origin restrictions\n\t\t\t\t\tstyleTarget = styleTarget.contentDocument.head;\n\t\t\t\t} catch(e) {\n\t\t\t\t\tstyleTarget = null;\n\t\t\t\t}\n\t\t\t}\n\t\t\tmemo[target] = styleTarget;\n\t\t}\n\t\treturn memo[target]\n\t};\n})();\n\nvar singleton = null;\nvar\tsingletonCounter = 0;\nvar\tstylesInsertedAtTop = [];\n\nvar\tfixUrls = require(\"./urls\");\n\nmodule.exports = function(list, options) {\n\tif (typeof DEBUG !== \"undefined\" && DEBUG) {\n\t\tif (typeof document !== \"object\") throw new Error(\"The style-loader cannot be used in a non-browser environment\");\n\t}\n\n\toptions = options || {};\n\n\toptions.attrs = typeof options.attrs === \"object\" ? options.attrs : {};\n\n\t// Force single-tag solution on IE6-9, which has a hard limit on the # of <style>\n\t// tags it will allow on a page\n\tif (!options.singleton && typeof options.singleton !== \"boolean\") options.singleton = isOldIE();\n\n\t// By default, add <style> tags to the <head> element\n if (!options.insertInto) options.insertInto = \"head\";\n\n\t// By default, add <style> tags to the bottom of the target\n\tif (!options.insertAt) options.insertAt = \"bottom\";\n\n\tvar styles = listToStyles(list, options);\n\n\taddStylesToDom(styles, options);\n\n\treturn function update (newList) {\n\t\tvar mayRemove = [];\n\n\t\tfor (var i = 0; i < styles.length; i++) {\n\t\t\tvar item = styles[i];\n\t\t\tvar domStyle = stylesInDom[item.id];\n\n\t\t\tdomStyle.refs--;\n\t\t\tmayRemove.push(domStyle);\n\t\t}\n\n\t\tif(newList) {\n\t\t\tvar newStyles = listToStyles(newList, options);\n\t\t\taddStylesToDom(newStyles, options);\n\t\t}\n\n\t\tfor (var i = 0; i < mayRemove.length; i++) {\n\t\t\tvar domStyle = mayRemove[i];\n\n\t\t\tif(domStyle.refs === 0) {\n\t\t\t\tfor (var j = 0; j < domStyle.parts.length; j++) domStyle.parts[j]();\n\n\t\t\t\tdelete stylesInDom[domStyle.id];\n\t\t\t}\n\t\t}\n\t};\n};\n\nfunction addStylesToDom (styles, options) {\n\tfor (var i = 0; i < styles.length; i++) {\n\t\tvar item = styles[i];\n\t\tvar domStyle = stylesInDom[item.id];\n\n\t\tif(domStyle) {\n\t\t\tdomStyle.refs++;\n\n\t\t\tfor(var j = 0; j < domStyle.parts.length; j++) {\n\t\t\t\tdomStyle.parts[j](item.parts[j]);\n\t\t\t}\n\n\t\t\tfor(; j < item.parts.length; j++) {\n\t\t\t\tdomStyle.parts.push(addStyle(item.parts[j], options));\n\t\t\t}\n\t\t} else {\n\t\t\tvar parts = [];\n\n\t\t\tfor(var j = 0; j < item.parts.length; j++) {\n\t\t\t\tparts.push(addStyle(item.parts[j], options));\n\t\t\t}\n\n\t\t\tstylesInDom[item.id] = {id: item.id, refs: 1, parts: parts};\n\t\t}\n\t}\n}\n\nfunction listToStyles (list, options) {\n\tvar styles = [];\n\tvar newStyles = {};\n\n\tfor (var i = 0; i < list.length; i++) {\n\t\tvar item = list[i];\n\t\tvar id = options.base ? item[0] + options.base : item[0];\n\t\tvar css = item[1];\n\t\tvar media = item[2];\n\t\tvar sourceMap = item[3];\n\t\tvar part = {css: css, media: media, sourceMap: sourceMap};\n\n\t\tif(!newStyles[id]) styles.push(newStyles[id] = {id: id, parts: [part]});\n\t\telse newStyles[id].parts.push(part);\n\t}\n\n\treturn styles;\n}\n\nfunction insertStyleElement (options, style) {\n\tvar target = getElement(options.insertInto)\n\n\tif (!target) {\n\t\tthrow new Error(\"Couldn't find a style target. This probably means that the value for the 'insertInto' parameter is invalid.\");\n\t}\n\n\tvar lastStyleElementInsertedAtTop = stylesInsertedAtTop[stylesInsertedAtTop.length - 1];\n\n\tif (options.insertAt === \"top\") {\n\t\tif (!lastStyleElementInsertedAtTop) {\n\t\t\ttarget.insertBefore(style, target.firstChild);\n\t\t} else if (lastStyleElementInsertedAtTop.nextSibling) {\n\t\t\ttarget.insertBefore(style, lastStyleElementInsertedAtTop.nextSibling);\n\t\t} else {\n\t\t\ttarget.appendChild(style);\n\t\t}\n\t\tstylesInsertedAtTop.push(style);\n\t} else if (options.insertAt === \"bottom\") {\n\t\ttarget.appendChild(style);\n\t} else if (typeof options.insertAt === \"object\" && options.insertAt.before) {\n\t\tvar nextSibling = getElement(options.insertAt.before, target);\n\t\ttarget.insertBefore(style, nextSibling);\n\t} else {\n\t\tthrow new Error(\"[Style Loader]\\n\\n Invalid value for parameter 'insertAt' ('options.insertAt') found.\\n Must be 'top', 'bottom', or Object.\\n (https://github.com/webpack-contrib/style-loader#insertat)\\n\");\n\t}\n}\n\nfunction removeStyleElement (style) {\n\tif (style.parentNode === null) return false;\n\tstyle.parentNode.removeChild(style);\n\n\tvar idx = stylesInsertedAtTop.indexOf(style);\n\tif(idx >= 0) {\n\t\tstylesInsertedAtTop.splice(idx, 1);\n\t}\n}\n\nfunction createStyleElement (options) {\n\tvar style = document.createElement(\"style\");\n\n\tif(options.attrs.type === undefined) {\n\t\toptions.attrs.type = \"text/css\";\n\t}\n\n\tif(options.attrs.nonce === undefined) {\n\t\tvar nonce = getNonce();\n\t\tif (nonce) {\n\t\t\toptions.attrs.nonce = nonce;\n\t\t}\n\t}\n\n\taddAttrs(style, options.attrs);\n\tinsertStyleElement(options, style);\n\n\treturn style;\n}\n\nfunction createLinkElement (options) {\n\tvar link = document.createElement(\"link\");\n\n\tif(options.attrs.type === undefined) {\n\t\toptions.attrs.type = \"text/css\";\n\t}\n\toptions.attrs.rel = \"stylesheet\";\n\n\taddAttrs(link, options.attrs);\n\tinsertStyleElement(options, link);\n\n\treturn link;\n}\n\nfunction addAttrs (el, attrs) {\n\tObject.keys(attrs).forEach(function (key) {\n\t\tel.setAttribute(key, attrs[key]);\n\t});\n}\n\nfunction getNonce() {\n\tif (typeof __webpack_nonce__ === 'undefined') {\n\t\treturn null;\n\t}\n\n\treturn __webpack_nonce__;\n}\n\nfunction addStyle (obj, options) {\n\tvar style, update, remove, result;\n\n\t// If a transform function was defined, run it on the css\n\tif (options.transform && obj.css) {\n\t result = typeof options.transform === 'function'\n\t\t ? options.transform(obj.css) \n\t\t : options.transform.default(obj.css);\n\n\t if (result) {\n\t \t// If transform returns a value, use that instead of the original css.\n\t \t// This allows running runtime transformations on the css.\n\t \tobj.css = result;\n\t } else {\n\t \t// If the transform function returns a falsy value, don't add this css.\n\t \t// This allows conditional loading of css\n\t \treturn function() {\n\t \t\t// noop\n\t \t};\n\t }\n\t}\n\n\tif (options.singleton) {\n\t\tvar styleIndex = singletonCounter++;\n\n\t\tstyle = singleton || (singleton = createStyleElement(options));\n\n\t\tupdate = applyToSingletonTag.bind(null, style, styleIndex, false);\n\t\tremove = applyToSingletonTag.bind(null, style, styleIndex, true);\n\n\t} else if (\n\t\tobj.sourceMap &&\n\t\ttypeof URL === \"function\" &&\n\t\ttypeof URL.createObjectURL === \"function\" &&\n\t\ttypeof URL.revokeObjectURL === \"function\" &&\n\t\ttypeof Blob === \"function\" &&\n\t\ttypeof btoa === \"function\"\n\t) {\n\t\tstyle = createLinkElement(options);\n\t\tupdate = updateLink.bind(null, style, options);\n\t\tremove = function () {\n\t\t\tremoveStyleElement(style);\n\n\t\t\tif(style.href) URL.revokeObjectURL(style.href);\n\t\t};\n\t} else {\n\t\tstyle = createStyleElement(options);\n\t\tupdate = applyToTag.bind(null, style);\n\t\tremove = function () {\n\t\t\tremoveStyleElement(style);\n\t\t};\n\t}\n\n\tupdate(obj);\n\n\treturn function updateStyle (newObj) {\n\t\tif (newObj) {\n\t\t\tif (\n\t\t\t\tnewObj.css === obj.css &&\n\t\t\t\tnewObj.media === obj.media &&\n\t\t\t\tnewObj.sourceMap === obj.sourceMap\n\t\t\t) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tupdate(obj = newObj);\n\t\t} else {\n\t\t\tremove();\n\t\t}\n\t};\n}\n\nvar replaceText = (function () {\n\tvar textStore = [];\n\n\treturn function (index, replacement) {\n\t\ttextStore[index] = replacement;\n\n\t\treturn textStore.filter(Boolean).join('\\n');\n\t};\n})();\n\nfunction applyToSingletonTag (style, index, remove, obj) {\n\tvar css = remove ? \"\" : obj.css;\n\n\tif (style.styleSheet) {\n\t\tstyle.styleSheet.cssText = replaceText(index, css);\n\t} else {\n\t\tvar cssNode = document.createTextNode(css);\n\t\tvar childNodes = style.childNodes;\n\n\t\tif (childNodes[index]) style.removeChild(childNodes[index]);\n\n\t\tif (childNodes.length) {\n\t\t\tstyle.insertBefore(cssNode, childNodes[index]);\n\t\t} else {\n\t\t\tstyle.appendChild(cssNode);\n\t\t}\n\t}\n}\n\nfunction applyToTag (style, obj) {\n\tvar css = obj.css;\n\tvar media = obj.media;\n\n\tif(media) {\n\t\tstyle.setAttribute(\"media\", media)\n\t}\n\n\tif(style.styleSheet) {\n\t\tstyle.styleSheet.cssText = css;\n\t} else {\n\t\twhile(style.firstChild) {\n\t\t\tstyle.removeChild(style.firstChild);\n\t\t}\n\n\t\tstyle.appendChild(document.createTextNode(css));\n\t}\n}\n\nfunction updateLink (link, options, obj) {\n\tvar css = obj.css;\n\tvar sourceMap = obj.sourceMap;\n\n\t/*\n\t\tIf convertToAbsoluteUrls isn't defined, but sourcemaps are enabled\n\t\tand there is no publicPath defined then lets turn convertToAbsoluteUrls\n\t\ton by default. Otherwise default to the convertToAbsoluteUrls option\n\t\tdirectly\n\t*/\n\tvar autoFixUrls = options.convertToAbsoluteUrls === undefined && sourceMap;\n\n\tif (options.convertToAbsoluteUrls || autoFixUrls) {\n\t\tcss = fixUrls(css);\n\t}\n\n\tif (sourceMap) {\n\t\t// http://stackoverflow.com/a/26603875\n\t\tcss += \"\\n/*# sourceMappingURL=data:application/json;base64,\" + btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))) + \" */\";\n\t}\n\n\tvar blob = new Blob([css], { type: \"text/css\" });\n\n\tvar oldSrc = link.href;\n\n\tlink.href = URL.createObjectURL(blob);\n\n\tif(oldSrc) URL.revokeObjectURL(oldSrc);\n}\n","module.exports = SafeParseTuple\n\nfunction SafeParseTuple(obj, reviver) {\n var json\n var error = null\n\n try {\n json = JSON.parse(obj, reviver)\n } catch (err) {\n error = err\n }\n\n return [error, json]\n}\n","/**\n * Copyright 2013 vtt.js Contributors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n// Default exports for Node. Export the extended versions of VTTCue and\n// VTTRegion in Node since we likely want the capability to convert back and\n// forth between JSON. If we don't then it's not that big of a deal since we're\n// off browser.\n\nvar window = require('global/window');\n\nvar vttjs = module.exports = {\n WebVTT: require(\"./vtt.js\"),\n VTTCue: require(\"./vttcue.js\"),\n VTTRegion: require(\"./vttregion.js\")\n};\n\nwindow.vttjs = vttjs;\nwindow.WebVTT = vttjs.WebVTT;\n\nvar cueShim = vttjs.VTTCue;\nvar regionShim = vttjs.VTTRegion;\nvar nativeVTTCue = window.VTTCue;\nvar nativeVTTRegion = window.VTTRegion;\n\nvttjs.shim = function() {\n window.VTTCue = cueShim;\n window.VTTRegion = regionShim;\n};\n\nvttjs.restore = function() {\n window.VTTCue = nativeVTTCue;\n window.VTTRegion = nativeVTTRegion;\n};\n\nif (!window.VTTCue) {\n vttjs.shim();\n}\n","/**\n * Copyright 2013 vtt.js Contributors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */\n/* vim: set shiftwidth=2 tabstop=2 autoindent cindent expandtab: */\nvar _objCreate = Object.create || (function() {\n function F() {}\n return function(o) {\n if (arguments.length !== 1) {\n throw new Error('Object.create shim only accepts one parameter.');\n }\n F.prototype = o;\n return new F();\n };\n})();\n\n// Creates a new ParserError object from an errorData object. The errorData\n// object should have default code and message properties. The default message\n// property can be overriden by passing in a message parameter.\n// See ParsingError.Errors below for acceptable errors.\nfunction ParsingError(errorData, message) {\n this.name = \"ParsingError\";\n this.code = errorData.code;\n this.message = message || errorData.message;\n}\nParsingError.prototype = _objCreate(Error.prototype);\nParsingError.prototype.constructor = ParsingError;\n\n// ParsingError metadata for acceptable ParsingErrors.\nParsingError.Errors = {\n BadSignature: {\n code: 0,\n message: \"Malformed WebVTT signature.\"\n },\n BadTimeStamp: {\n code: 1,\n message: \"Malformed time stamp.\"\n }\n};\n\n// Try to parse input as a time stamp.\nfunction parseTimeStamp(input) {\n\n function computeSeconds(h, m, s, f) {\n return (h | 0) * 3600 + (m | 0) * 60 + (s | 0) + (f | 0) / 1000;\n }\n\n var m = input.match(/^(\\d+):(\\d{2})(:\\d{2})?\\.(\\d{3})/);\n if (!m) {\n return null;\n }\n\n if (m[3]) {\n // Timestamp takes the form of [hours]:[minutes]:[seconds].[milliseconds]\n return computeSeconds(m[1], m[2], m[3].replace(\":\", \"\"), m[4]);\n } else if (m[1] > 59) {\n // Timestamp takes the form of [hours]:[minutes].[milliseconds]\n // First position is hours as it's over 59.\n return computeSeconds(m[1], m[2], 0, m[4]);\n } else {\n // Timestamp takes the form of [minutes]:[seconds].[milliseconds]\n return computeSeconds(0, m[1], m[2], m[4]);\n }\n}\n\n// A settings object holds key/value pairs and will ignore anything but the first\n// assignment to a specific key.\nfunction Settings() {\n this.values = _objCreate(null);\n}\n\nSettings.prototype = {\n // Only accept the first assignment to any key.\n set: function(k, v) {\n if (!this.get(k) && v !== \"\") {\n this.values[k] = v;\n }\n },\n // Return the value for a key, or a default value.\n // If 'defaultKey' is passed then 'dflt' is assumed to be an object with\n // a number of possible default values as properties where 'defaultKey' is\n // the key of the property that will be chosen; otherwise it's assumed to be\n // a single value.\n get: function(k, dflt, defaultKey) {\n if (defaultKey) {\n return this.has(k) ? this.values[k] : dflt[defaultKey];\n }\n return this.has(k) ? this.values[k] : dflt;\n },\n // Check whether we have a value for a key.\n has: function(k) {\n return k in this.values;\n },\n // Accept a setting if its one of the given alternatives.\n alt: function(k, v, a) {\n for (var n = 0; n < a.length; ++n) {\n if (v === a[n]) {\n this.set(k, v);\n break;\n }\n }\n },\n // Accept a setting if its a valid (signed) integer.\n integer: function(k, v) {\n if (/^-?\\d+$/.test(v)) { // integer\n this.set(k, parseInt(v, 10));\n }\n },\n // Accept a setting if its a valid percentage.\n percent: function(k, v) {\n var m;\n if ((m = v.match(/^([\\d]{1,3})(\\.[\\d]*)?%$/))) {\n v = parseFloat(v);\n if (v >= 0 && v <= 100) {\n this.set(k, v);\n return true;\n }\n }\n return false;\n }\n};\n\n// Helper function to parse input into groups separated by 'groupDelim', and\n// interprete each group as a key/value pair separated by 'keyValueDelim'.\nfunction parseOptions(input, callback, keyValueDelim, groupDelim) {\n var groups = groupDelim ? input.split(groupDelim) : [input];\n for (var i in groups) {\n if (typeof groups[i] !== \"string\") {\n continue;\n }\n var kv = groups[i].split(keyValueDelim);\n if (kv.length !== 2) {\n continue;\n }\n var k = kv[0];\n var v = kv[1];\n callback(k, v);\n }\n}\n\nfunction parseCue(input, cue, regionList) {\n // Remember the original input if we need to throw an error.\n var oInput = input;\n // 4.1 WebVTT timestamp\n function consumeTimeStamp() {\n var ts = parseTimeStamp(input);\n if (ts === null) {\n throw new ParsingError(ParsingError.Errors.BadTimeStamp,\n \"Malformed timestamp: \" + oInput);\n }\n // Remove time stamp from input.\n input = input.replace(/^[^\\sa-zA-Z-]+/, \"\");\n return ts;\n }\n\n // 4.4.2 WebVTT cue settings\n function consumeCueSettings(input, cue) {\n var settings = new Settings();\n\n parseOptions(input, function (k, v) {\n switch (k) {\n case \"region\":\n // Find the last region we parsed with the same region id.\n for (var i = regionList.length - 1; i >= 0; i--) {\n if (regionList[i].id === v) {\n settings.set(k, regionList[i].region);\n break;\n }\n }\n break;\n case \"vertical\":\n settings.alt(k, v, [\"rl\", \"lr\"]);\n break;\n case \"line\":\n var vals = v.split(\",\"),\n vals0 = vals[0];\n settings.integer(k, vals0);\n settings.percent(k, vals0) ? settings.set(\"snapToLines\", false) : null;\n settings.alt(k, vals0, [\"auto\"]);\n if (vals.length === 2) {\n settings.alt(\"lineAlign\", vals[1], [\"start\", \"middle\", \"end\"]);\n }\n break;\n case \"position\":\n vals = v.split(\",\");\n settings.percent(k, vals[0]);\n if (vals.length === 2) {\n settings.alt(\"positionAlign\", vals[1], [\"start\", \"middle\", \"end\"]);\n }\n break;\n case \"size\":\n settings.percent(k, v);\n break;\n case \"align\":\n settings.alt(k, v, [\"start\", \"middle\", \"end\", \"left\", \"right\"]);\n break;\n }\n }, /:/, /\\s/);\n\n // Apply default values for any missing fields.\n cue.region = settings.get(\"region\", null);\n cue.vertical = settings.get(\"vertical\", \"\");\n cue.line = settings.get(\"line\", \"auto\");\n cue.lineAlign = settings.get(\"lineAlign\", \"start\");\n cue.snapToLines = settings.get(\"snapToLines\", true);\n cue.size = settings.get(\"size\", 100);\n cue.align = settings.get(\"align\", \"middle\");\n cue.position = settings.get(\"position\", {\n start: 0,\n left: 0,\n middle: 50,\n end: 100,\n right: 100\n }, cue.align);\n cue.positionAlign = settings.get(\"positionAlign\", {\n start: \"start\",\n left: \"start\",\n middle: \"middle\",\n end: \"end\",\n right: \"end\"\n }, cue.align);\n }\n\n function skipWhitespace() {\n input = input.replace(/^\\s+/, \"\");\n }\n\n // 4.1 WebVTT cue timings.\n skipWhitespace();\n cue.startTime = consumeTimeStamp(); // (1) collect cue start time\n skipWhitespace();\n if (input.substr(0, 3) !== \"-->\") { // (3) next characters must match \"-->\"\n throw new ParsingError(ParsingError.Errors.BadTimeStamp,\n \"Malformed time stamp (time stamps must be separated by '-->'): \" +\n oInput);\n }\n input = input.substr(3);\n skipWhitespace();\n cue.endTime = consumeTimeStamp(); // (5) collect cue end time\n\n // 4.1 WebVTT cue settings list.\n skipWhitespace();\n consumeCueSettings(input, cue);\n}\n\nvar ESCAPE = {\n \"&\": \"&\",\n \"<\": \"<\",\n \">\": \">\",\n \"‎\": \"\\u200e\",\n \"‏\": \"\\u200f\",\n \" \": \"\\u00a0\"\n};\n\nvar TAG_NAME = {\n c: \"span\",\n i: \"i\",\n b: \"b\",\n u: \"u\",\n ruby: \"ruby\",\n rt: \"rt\",\n v: \"span\",\n lang: \"span\"\n};\n\nvar TAG_ANNOTATION = {\n v: \"title\",\n lang: \"lang\"\n};\n\nvar NEEDS_PARENT = {\n rt: \"ruby\"\n};\n\n// Parse content into a document fragment.\nfunction parseContent(window, input) {\n function nextToken() {\n // Check for end-of-string.\n if (!input) {\n return null;\n }\n\n // Consume 'n' characters from the input.\n function consume(result) {\n input = input.substr(result.length);\n return result;\n }\n\n var m = input.match(/^([^<]*)(<[^>]*>?)?/);\n // If there is some text before the next tag, return it, otherwise return\n // the tag.\n return consume(m[1] ? m[1] : m[2]);\n }\n\n // Unescape a string 's'.\n function unescape1(e) {\n return ESCAPE[e];\n }\n function unescape(s) {\n while ((m = s.match(/&(amp|lt|gt|lrm|rlm|nbsp);/))) {\n s = s.replace(m[0], unescape1);\n }\n return s;\n }\n\n function shouldAdd(current, element) {\n return !NEEDS_PARENT[element.localName] ||\n NEEDS_PARENT[element.localName] === current.localName;\n }\n\n // Create an element for this tag.\n function createElement(type, annotation) {\n var tagName = TAG_NAME[type];\n if (!tagName) {\n return null;\n }\n var element = window.document.createElement(tagName);\n element.localName = tagName;\n var name = TAG_ANNOTATION[type];\n if (name && annotation) {\n element[name] = annotation.trim();\n }\n return element;\n }\n\n var rootDiv = window.document.createElement(\"div\"),\n current = rootDiv,\n t,\n tagStack = [];\n\n while ((t = nextToken()) !== null) {\n if (t[0] === '<') {\n if (t[1] === \"/\") {\n // If the closing tag matches, move back up to the parent node.\n if (tagStack.length &&\n tagStack[tagStack.length - 1] === t.substr(2).replace(\">\", \"\")) {\n tagStack.pop();\n current = current.parentNode;\n }\n // Otherwise just ignore the end tag.\n continue;\n }\n var ts = parseTimeStamp(t.substr(1, t.length - 2));\n var node;\n if (ts) {\n // Timestamps are lead nodes as well.\n node = window.document.createProcessingInstruction(\"timestamp\", ts);\n current.appendChild(node);\n continue;\n }\n var m = t.match(/^<([^.\\s/0-9>]+)(\\.[^\\s\\\\>]+)?([^>\\\\]+)?(\\\\?)>?$/);\n // If we can't parse the tag, skip to the next tag.\n if (!m) {\n continue;\n }\n // Try to construct an element, and ignore the tag if we couldn't.\n node = createElement(m[1], m[3]);\n if (!node) {\n continue;\n }\n // Determine if the tag should be added based on the context of where it\n // is placed in the cuetext.\n if (!shouldAdd(current, node)) {\n continue;\n }\n // Set the class list (as a list of classes, separated by space).\n if (m[2]) {\n node.className = m[2].substr(1).replace('.', ' ');\n }\n // Append the node to the current node, and enter the scope of the new\n // node.\n tagStack.push(m[1]);\n current.appendChild(node);\n current = node;\n continue;\n }\n\n // Text nodes are leaf nodes.\n current.appendChild(window.document.createTextNode(unescape(t)));\n }\n\n return rootDiv;\n}\n\n// This is a list of all the Unicode characters that have a strong\n// right-to-left category. What this means is that these characters are\n// written right-to-left for sure. It was generated by pulling all the strong\n// right-to-left characters out of the Unicode data table. That table can\n// found at: http://www.unicode.org/Public/UNIDATA/UnicodeData.txt\nvar strongRTLRanges = [[0x5be, 0x5be], [0x5c0, 0x5c0], [0x5c3, 0x5c3], [0x5c6, 0x5c6],\n [0x5d0, 0x5ea], [0x5f0, 0x5f4], [0x608, 0x608], [0x60b, 0x60b], [0x60d, 0x60d],\n [0x61b, 0x61b], [0x61e, 0x64a], [0x66d, 0x66f], [0x671, 0x6d5], [0x6e5, 0x6e6],\n [0x6ee, 0x6ef], [0x6fa, 0x70d], [0x70f, 0x710], [0x712, 0x72f], [0x74d, 0x7a5],\n [0x7b1, 0x7b1], [0x7c0, 0x7ea], [0x7f4, 0x7f5], [0x7fa, 0x7fa], [0x800, 0x815],\n [0x81a, 0x81a], [0x824, 0x824], [0x828, 0x828], [0x830, 0x83e], [0x840, 0x858],\n [0x85e, 0x85e], [0x8a0, 0x8a0], [0x8a2, 0x8ac], [0x200f, 0x200f],\n [0xfb1d, 0xfb1d], [0xfb1f, 0xfb28], [0xfb2a, 0xfb36], [0xfb38, 0xfb3c],\n [0xfb3e, 0xfb3e], [0xfb40, 0xfb41], [0xfb43, 0xfb44], [0xfb46, 0xfbc1],\n [0xfbd3, 0xfd3d], [0xfd50, 0xfd8f], [0xfd92, 0xfdc7], [0xfdf0, 0xfdfc],\n [0xfe70, 0xfe74], [0xfe76, 0xfefc], [0x10800, 0x10805], [0x10808, 0x10808],\n [0x1080a, 0x10835], [0x10837, 0x10838], [0x1083c, 0x1083c], [0x1083f, 0x10855],\n [0x10857, 0x1085f], [0x10900, 0x1091b], [0x10920, 0x10939], [0x1093f, 0x1093f],\n [0x10980, 0x109b7], [0x109be, 0x109bf], [0x10a00, 0x10a00], [0x10a10, 0x10a13],\n [0x10a15, 0x10a17], [0x10a19, 0x10a33], [0x10a40, 0x10a47], [0x10a50, 0x10a58],\n [0x10a60, 0x10a7f], [0x10b00, 0x10b35], [0x10b40, 0x10b55], [0x10b58, 0x10b72],\n [0x10b78, 0x10b7f], [0x10c00, 0x10c48], [0x1ee00, 0x1ee03], [0x1ee05, 0x1ee1f],\n [0x1ee21, 0x1ee22], [0x1ee24, 0x1ee24], [0x1ee27, 0x1ee27], [0x1ee29, 0x1ee32],\n [0x1ee34, 0x1ee37], [0x1ee39, 0x1ee39], [0x1ee3b, 0x1ee3b], [0x1ee42, 0x1ee42],\n [0x1ee47, 0x1ee47], [0x1ee49, 0x1ee49], [0x1ee4b, 0x1ee4b], [0x1ee4d, 0x1ee4f],\n [0x1ee51, 0x1ee52], [0x1ee54, 0x1ee54], [0x1ee57, 0x1ee57], [0x1ee59, 0x1ee59],\n [0x1ee5b, 0x1ee5b], [0x1ee5d, 0x1ee5d], [0x1ee5f, 0x1ee5f], [0x1ee61, 0x1ee62],\n [0x1ee64, 0x1ee64], [0x1ee67, 0x1ee6a], [0x1ee6c, 0x1ee72], [0x1ee74, 0x1ee77],\n [0x1ee79, 0x1ee7c], [0x1ee7e, 0x1ee7e], [0x1ee80, 0x1ee89], [0x1ee8b, 0x1ee9b],\n [0x1eea1, 0x1eea3], [0x1eea5, 0x1eea9], [0x1eeab, 0x1eebb], [0x10fffd, 0x10fffd]];\n\nfunction isStrongRTLChar(charCode) {\n for (var i = 0; i < strongRTLRanges.length; i++) {\n var currentRange = strongRTLRanges[i];\n if (charCode >= currentRange[0] && charCode <= currentRange[1]) {\n return true;\n }\n }\n\n return false;\n}\n\nfunction determineBidi(cueDiv) {\n var nodeStack = [],\n text = \"\",\n charCode;\n\n if (!cueDiv || !cueDiv.childNodes) {\n return \"ltr\";\n }\n\n function pushNodes(nodeStack, node) {\n for (var i = node.childNodes.length - 1; i >= 0; i--) {\n nodeStack.push(node.childNodes[i]);\n }\n }\n\n function nextTextNode(nodeStack) {\n if (!nodeStack || !nodeStack.length) {\n return null;\n }\n\n var node = nodeStack.pop(),\n text = node.textContent || node.innerText;\n if (text) {\n // TODO: This should match all unicode type B characters (paragraph\n // separator characters). See issue #115.\n var m = text.match(/^.*(\\n|\\r)/);\n if (m) {\n nodeStack.length = 0;\n return m[0];\n }\n return text;\n }\n if (node.tagName === \"ruby\") {\n return nextTextNode(nodeStack);\n }\n if (node.childNodes) {\n pushNodes(nodeStack, node);\n return nextTextNode(nodeStack);\n }\n }\n\n pushNodes(nodeStack, cueDiv);\n while ((text = nextTextNode(nodeStack))) {\n for (var i = 0; i < text.length; i++) {\n charCode = text.charCodeAt(i);\n if (isStrongRTLChar(charCode)) {\n return \"rtl\";\n }\n }\n }\n return \"ltr\";\n}\n\nfunction computeLinePos(cue) {\n if (typeof cue.line === \"number\" &&\n (cue.snapToLines || (cue.line >= 0 && cue.line <= 100))) {\n return cue.line;\n }\n if (!cue.track || !cue.track.textTrackList ||\n !cue.track.textTrackList.mediaElement) {\n return -1;\n }\n var track = cue.track,\n trackList = track.textTrackList,\n count = 0;\n for (var i = 0; i < trackList.length && trackList[i] !== track; i++) {\n if (trackList[i].mode === \"showing\") {\n count++;\n }\n }\n return ++count * -1;\n}\n\nfunction StyleBox() {\n}\n\n// Apply styles to a div. If there is no div passed then it defaults to the\n// div on 'this'.\nStyleBox.prototype.applyStyles = function(styles, div) {\n div = div || this.div;\n for (var prop in styles) {\n if (styles.hasOwnProperty(prop)) {\n div.style[prop] = styles[prop];\n }\n }\n};\n\nStyleBox.prototype.formatStyle = function(val, unit) {\n return val === 0 ? 0 : val + unit;\n};\n\n// Constructs the computed display state of the cue (a div). Places the div\n// into the overlay which should be a block level element (usually a div).\nfunction CueStyleBox(window, cue, styleOptions) {\n StyleBox.call(this);\n this.cue = cue;\n\n // Parse our cue's text into a DOM tree rooted at 'cueDiv'. This div will\n // have inline positioning and will function as the cue background box.\n this.cueDiv = parseContent(window, cue.text);\n var styles = {\n color: \"rgba(255, 255, 255, 1)\",\n backgroundColor: \"rgba(0, 0, 0, 0.8)\",\n position: \"relative\",\n left: 0,\n right: 0,\n top: 0,\n bottom: 0,\n display: \"inline\",\n writingMode: cue.vertical === \"\" ? \"horizontal-tb\"\n : cue.vertical === \"lr\" ? \"vertical-lr\"\n : \"vertical-rl\",\n unicodeBidi: \"plaintext\"\n };\n\n this.applyStyles(styles, this.cueDiv);\n\n // Create an absolutely positioned div that will be used to position the cue\n // div. Note, all WebVTT cue-setting alignments are equivalent to the CSS\n // mirrors of them except \"middle\" which is \"center\" in CSS.\n this.div = window.document.createElement(\"div\");\n styles = {\n direction: determineBidi(this.cueDiv),\n writingMode: cue.vertical === \"\" ? \"horizontal-tb\"\n : cue.vertical === \"lr\" ? \"vertical-lr\"\n : \"vertical-rl\",\n unicodeBidi: \"plaintext\",\n textAlign: cue.align === \"middle\" ? \"center\" : cue.align,\n font: styleOptions.font,\n whiteSpace: \"pre-line\",\n position: \"absolute\"\n };\n\n this.applyStyles(styles);\n this.div.appendChild(this.cueDiv);\n\n // Calculate the distance from the reference edge of the viewport to the text\n // position of the cue box. The reference edge will be resolved later when\n // the box orientation styles are applied.\n var textPos = 0;\n switch (cue.positionAlign) {\n case \"start\":\n textPos = cue.position;\n break;\n case \"middle\":\n textPos = cue.position - (cue.size / 2);\n break;\n case \"end\":\n textPos = cue.position - cue.size;\n break;\n }\n\n // Horizontal box orientation; textPos is the distance from the left edge of the\n // area to the left edge of the box and cue.size is the distance extending to\n // the right from there.\n if (cue.vertical === \"\") {\n this.applyStyles({\n left: this.formatStyle(textPos, \"%\"),\n width: this.formatStyle(cue.size, \"%\")\n });\n // Vertical box orientation; textPos is the distance from the top edge of the\n // area to the top edge of the box and cue.size is the height extending\n // downwards from there.\n } else {\n this.applyStyles({\n top: this.formatStyle(textPos, \"%\"),\n height: this.formatStyle(cue.size, \"%\")\n });\n }\n\n this.move = function(box) {\n this.applyStyles({\n top: this.formatStyle(box.top, \"px\"),\n bottom: this.formatStyle(box.bottom, \"px\"),\n left: this.formatStyle(box.left, \"px\"),\n right: this.formatStyle(box.right, \"px\"),\n height: this.formatStyle(box.height, \"px\"),\n width: this.formatStyle(box.width, \"px\")\n });\n };\n}\nCueStyleBox.prototype = _objCreate(StyleBox.prototype);\nCueStyleBox.prototype.constructor = CueStyleBox;\n\n// Represents the co-ordinates of an Element in a way that we can easily\n// compute things with such as if it overlaps or intersects with another Element.\n// Can initialize it with either a StyleBox or another BoxPosition.\nfunction BoxPosition(obj) {\n // Either a BoxPosition was passed in and we need to copy it, or a StyleBox\n // was passed in and we need to copy the results of 'getBoundingClientRect'\n // as the object returned is readonly. All co-ordinate values are in reference\n // to the viewport origin (top left).\n var lh, height, width, top;\n if (obj.div) {\n height = obj.div.offsetHeight;\n width = obj.div.offsetWidth;\n top = obj.div.offsetTop;\n\n var rects = (rects = obj.div.childNodes) && (rects = rects[0]) &&\n rects.getClientRects && rects.getClientRects();\n obj = obj.div.getBoundingClientRect();\n // In certain cases the outter div will be slightly larger then the sum of\n // the inner div's lines. This could be due to bold text, etc, on some platforms.\n // In this case we should get the average line height and use that. This will\n // result in the desired behaviour.\n lh = rects ? Math.max((rects[0] && rects[0].height) || 0, obj.height / rects.length)\n : 0;\n\n }\n this.left = obj.left;\n this.right = obj.right;\n this.top = obj.top || top;\n this.height = obj.height || height;\n this.bottom = obj.bottom || (top + (obj.height || height));\n this.width = obj.width || width;\n this.lineHeight = lh !== undefined ? lh : obj.lineHeight;\n}\n\n// Move the box along a particular axis. Optionally pass in an amount to move\n// the box. If no amount is passed then the default is the line height of the\n// box.\nBoxPosition.prototype.move = function(axis, toMove) {\n toMove = toMove !== undefined ? toMove : this.lineHeight;\n switch (axis) {\n case \"+x\":\n this.left += toMove;\n this.right += toMove;\n break;\n case \"-x\":\n this.left -= toMove;\n this.right -= toMove;\n break;\n case \"+y\":\n this.top += toMove;\n this.bottom += toMove;\n break;\n case \"-y\":\n this.top -= toMove;\n this.bottom -= toMove;\n break;\n }\n};\n\n// Check if this box overlaps another box, b2.\nBoxPosition.prototype.overlaps = function(b2) {\n return this.left < b2.right &&\n this.right > b2.left &&\n this.top < b2.bottom &&\n this.bottom > b2.top;\n};\n\n// Check if this box overlaps any other boxes in boxes.\nBoxPosition.prototype.overlapsAny = function(boxes) {\n for (var i = 0; i < boxes.length; i++) {\n if (this.overlaps(boxes[i])) {\n return true;\n }\n }\n return false;\n};\n\n// Check if this box is within another box.\nBoxPosition.prototype.within = function(container) {\n return this.top >= container.top &&\n this.bottom <= container.bottom &&\n this.left >= container.left &&\n this.right <= container.right;\n};\n\n// Check if this box is entirely within the container or it is overlapping\n// on the edge opposite of the axis direction passed. For example, if \"+x\" is\n// passed and the box is overlapping on the left edge of the container, then\n// return true.\nBoxPosition.prototype.overlapsOppositeAxis = function(container, axis) {\n switch (axis) {\n case \"+x\":\n return this.left < container.left;\n case \"-x\":\n return this.right > container.right;\n case \"+y\":\n return this.top < container.top;\n case \"-y\":\n return this.bottom > container.bottom;\n }\n};\n\n// Find the percentage of the area that this box is overlapping with another\n// box.\nBoxPosition.prototype.intersectPercentage = function(b2) {\n var x = Math.max(0, Math.min(this.right, b2.right) - Math.max(this.left, b2.left)),\n y = Math.max(0, Math.min(this.bottom, b2.bottom) - Math.max(this.top, b2.top)),\n intersectArea = x * y;\n return intersectArea / (this.height * this.width);\n};\n\n// Convert the positions from this box to CSS compatible positions using\n// the reference container's positions. This has to be done because this\n// box's positions are in reference to the viewport origin, whereas, CSS\n// values are in referecne to their respective edges.\nBoxPosition.prototype.toCSSCompatValues = function(reference) {\n return {\n top: this.top - reference.top,\n bottom: reference.bottom - this.bottom,\n left: this.left - reference.left,\n right: reference.right - this.right,\n height: this.height,\n width: this.width\n };\n};\n\n// Get an object that represents the box's position without anything extra.\n// Can pass a StyleBox, HTMLElement, or another BoxPositon.\nBoxPosition.getSimpleBoxPosition = function(obj) {\n var height = obj.div ? obj.div.offsetHeight : obj.tagName ? obj.offsetHeight : 0;\n var width = obj.div ? obj.div.offsetWidth : obj.tagName ? obj.offsetWidth : 0;\n var top = obj.div ? obj.div.offsetTop : obj.tagName ? obj.offsetTop : 0;\n\n obj = obj.div ? obj.div.getBoundingClientRect() :\n obj.tagName ? obj.getBoundingClientRect() : obj;\n var ret = {\n left: obj.left,\n right: obj.right,\n top: obj.top || top,\n height: obj.height || height,\n bottom: obj.bottom || (top + (obj.height || height)),\n width: obj.width || width\n };\n return ret;\n};\n\n// Move a StyleBox to its specified, or next best, position. The containerBox\n// is the box that contains the StyleBox, such as a div. boxPositions are\n// a list of other boxes that the styleBox can't overlap with.\nfunction moveBoxToLinePosition(window, styleBox, containerBox, boxPositions) {\n\n // Find the best position for a cue box, b, on the video. The axis parameter\n // is a list of axis, the order of which, it will move the box along. For example:\n // Passing [\"+x\", \"-x\"] will move the box first along the x axis in the positive\n // direction. If it doesn't find a good position for it there it will then move\n // it along the x axis in the negative direction.\n function findBestPosition(b, axis) {\n var bestPosition,\n specifiedPosition = new BoxPosition(b),\n percentage = 1; // Highest possible so the first thing we get is better.\n\n for (var i = 0; i < axis.length; i++) {\n while (b.overlapsOppositeAxis(containerBox, axis[i]) ||\n (b.within(containerBox) && b.overlapsAny(boxPositions))) {\n b.move(axis[i]);\n }\n // We found a spot where we aren't overlapping anything. This is our\n // best position.\n if (b.within(containerBox)) {\n return b;\n }\n var p = b.intersectPercentage(containerBox);\n // If we're outside the container box less then we were on our last try\n // then remember this position as the best position.\n if (percentage > p) {\n bestPosition = new BoxPosition(b);\n percentage = p;\n }\n // Reset the box position to the specified position.\n b = new BoxPosition(specifiedPosition);\n }\n return bestPosition || specifiedPosition;\n }\n\n var boxPosition = new BoxPosition(styleBox),\n cue = styleBox.cue,\n linePos = computeLinePos(cue),\n axis = [];\n\n // If we have a line number to align the cue to.\n if (cue.snapToLines) {\n var size;\n switch (cue.vertical) {\n case \"\":\n axis = [ \"+y\", \"-y\" ];\n size = \"height\";\n break;\n case \"rl\":\n axis = [ \"+x\", \"-x\" ];\n size = \"width\";\n break;\n case \"lr\":\n axis = [ \"-x\", \"+x\" ];\n size = \"width\";\n break;\n }\n\n var step = boxPosition.lineHeight,\n position = step * Math.round(linePos),\n maxPosition = containerBox[size] + step,\n initialAxis = axis[0];\n\n // If the specified intial position is greater then the max position then\n // clamp the box to the amount of steps it would take for the box to\n // reach the max position.\n if (Math.abs(position) > maxPosition) {\n position = position < 0 ? -1 : 1;\n position *= Math.ceil(maxPosition / step) * step;\n }\n\n // If computed line position returns negative then line numbers are\n // relative to the bottom of the video instead of the top. Therefore, we\n // need to increase our initial position by the length or width of the\n // video, depending on the writing direction, and reverse our axis directions.\n if (linePos < 0) {\n position += cue.vertical === \"\" ? containerBox.height : containerBox.width;\n axis = axis.reverse();\n }\n\n // Move the box to the specified position. This may not be its best\n // position.\n boxPosition.move(initialAxis, position);\n\n } else {\n // If we have a percentage line value for the cue.\n var calculatedPercentage = (boxPosition.lineHeight / containerBox.height) * 100;\n\n switch (cue.lineAlign) {\n case \"middle\":\n linePos -= (calculatedPercentage / 2);\n break;\n case \"end\":\n linePos -= calculatedPercentage;\n break;\n }\n\n // Apply initial line position to the cue box.\n switch (cue.vertical) {\n case \"\":\n styleBox.applyStyles({\n top: styleBox.formatStyle(linePos, \"%\")\n });\n break;\n case \"rl\":\n styleBox.applyStyles({\n left: styleBox.formatStyle(linePos, \"%\")\n });\n break;\n case \"lr\":\n styleBox.applyStyles({\n right: styleBox.formatStyle(linePos, \"%\")\n });\n break;\n }\n\n axis = [ \"+y\", \"-x\", \"+x\", \"-y\" ];\n\n // Get the box position again after we've applied the specified positioning\n // to it.\n boxPosition = new BoxPosition(styleBox);\n }\n\n var bestPosition = findBestPosition(boxPosition, axis);\n styleBox.move(bestPosition.toCSSCompatValues(containerBox));\n}\n\nfunction WebVTT() {\n // Nothing\n}\n\n// Helper to allow strings to be decoded instead of the default binary utf8 data.\nWebVTT.StringDecoder = function() {\n return {\n decode: function(data) {\n if (!data) {\n return \"\";\n }\n if (typeof data !== \"string\") {\n throw new Error(\"Error - expected string data.\");\n }\n return decodeURIComponent(encodeURIComponent(data));\n }\n };\n};\n\nWebVTT.convertCueToDOMTree = function(window, cuetext) {\n if (!window || !cuetext) {\n return null;\n }\n return parseContent(window, cuetext);\n};\n\nvar FONT_SIZE_PERCENT = 0.05;\nvar FONT_STYLE = \"sans-serif\";\nvar CUE_BACKGROUND_PADDING = \"1.5%\";\n\n// Runs the processing model over the cues and regions passed to it.\n// @param overlay A block level element (usually a div) that the computed cues\n// and regions will be placed into.\nWebVTT.processCues = function(window, cues, overlay) {\n if (!window || !cues || !overlay) {\n return null;\n }\n\n // Remove all previous children.\n while (overlay.firstChild) {\n overlay.removeChild(overlay.firstChild);\n }\n\n var paddedOverlay = window.document.createElement(\"div\");\n paddedOverlay.style.position = \"absolute\";\n paddedOverlay.style.left = \"0\";\n paddedOverlay.style.right = \"0\";\n paddedOverlay.style.top = \"0\";\n paddedOverlay.style.bottom = \"0\";\n paddedOverlay.style.margin = CUE_BACKGROUND_PADDING;\n overlay.appendChild(paddedOverlay);\n\n // Determine if we need to compute the display states of the cues. This could\n // be the case if a cue's state has been changed since the last computation or\n // if it has not been computed yet.\n function shouldCompute(cues) {\n for (var i = 0; i < cues.length; i++) {\n if (cues[i].hasBeenReset || !cues[i].displayState) {\n return true;\n }\n }\n return false;\n }\n\n // We don't need to recompute the cues' display states. Just reuse them.\n if (!shouldCompute(cues)) {\n for (var i = 0; i < cues.length; i++) {\n paddedOverlay.appendChild(cues[i].displayState);\n }\n return;\n }\n\n var boxPositions = [],\n containerBox = BoxPosition.getSimpleBoxPosition(paddedOverlay),\n fontSize = Math.round(containerBox.height * FONT_SIZE_PERCENT * 100) / 100;\n var styleOptions = {\n font: fontSize + \"px \" + FONT_STYLE\n };\n\n (function() {\n var styleBox, cue;\n\n for (var i = 0; i < cues.length; i++) {\n cue = cues[i];\n\n // Compute the intial position and styles of the cue div.\n styleBox = new CueStyleBox(window, cue, styleOptions);\n paddedOverlay.appendChild(styleBox.div);\n\n // Move the cue div to it's correct line position.\n moveBoxToLinePosition(window, styleBox, containerBox, boxPositions);\n\n // Remember the computed div so that we don't have to recompute it later\n // if we don't have too.\n cue.displayState = styleBox.div;\n\n boxPositions.push(BoxPosition.getSimpleBoxPosition(styleBox));\n }\n })();\n};\n\nWebVTT.Parser = function(window, vttjs, decoder) {\n if (!decoder) {\n decoder = vttjs;\n vttjs = {};\n }\n if (!vttjs) {\n vttjs = {};\n }\n\n this.window = window;\n this.vttjs = vttjs;\n this.state = \"INITIAL\";\n this.buffer = \"\";\n this.decoder = decoder || new TextDecoder(\"utf8\");\n this.regionList = [];\n};\n\nWebVTT.Parser.prototype = {\n // If the error is a ParsingError then report it to the consumer if\n // possible. If it's not a ParsingError then throw it like normal.\n reportOrThrowError: function(e) {\n if (e instanceof ParsingError) {\n this.onparsingerror && this.onparsingerror(e);\n } else {\n throw e;\n }\n },\n parse: function (data) {\n var self = this;\n\n // If there is no data then we won't decode it, but will just try to parse\n // whatever is in buffer already. This may occur in circumstances, for\n // example when flush() is called.\n if (data) {\n // Try to decode the data that we received.\n self.buffer += self.decoder.decode(data, {stream: true});\n }\n\n function collectNextLine() {\n var buffer = self.buffer;\n var pos = 0;\n while (pos < buffer.length && buffer[pos] !== '\\r' && buffer[pos] !== '\\n') {\n ++pos;\n }\n var line = buffer.substr(0, pos);\n // Advance the buffer early in case we fail below.\n if (buffer[pos] === '\\r') {\n ++pos;\n }\n if (buffer[pos] === '\\n') {\n ++pos;\n }\n self.buffer = buffer.substr(pos);\n return line;\n }\n\n // 3.4 WebVTT region and WebVTT region settings syntax\n function parseRegion(input) {\n var settings = new Settings();\n\n parseOptions(input, function (k, v) {\n switch (k) {\n case \"id\":\n settings.set(k, v);\n break;\n case \"width\":\n settings.percent(k, v);\n break;\n case \"lines\":\n settings.integer(k, v);\n break;\n case \"regionanchor\":\n case \"viewportanchor\":\n var xy = v.split(',');\n if (xy.length !== 2) {\n break;\n }\n // We have to make sure both x and y parse, so use a temporary\n // settings object here.\n var anchor = new Settings();\n anchor.percent(\"x\", xy[0]);\n anchor.percent(\"y\", xy[1]);\n if (!anchor.has(\"x\") || !anchor.has(\"y\")) {\n break;\n }\n settings.set(k + \"X\", anchor.get(\"x\"));\n settings.set(k + \"Y\", anchor.get(\"y\"));\n break;\n case \"scroll\":\n settings.alt(k, v, [\"up\"]);\n break;\n }\n }, /=/, /\\s/);\n\n // Create the region, using default values for any values that were not\n // specified.\n if (settings.has(\"id\")) {\n var region = new (self.vttjs.VTTRegion || self.window.VTTRegion)();\n region.width = settings.get(\"width\", 100);\n region.lines = settings.get(\"lines\", 3);\n region.regionAnchorX = settings.get(\"regionanchorX\", 0);\n region.regionAnchorY = settings.get(\"regionanchorY\", 100);\n region.viewportAnchorX = settings.get(\"viewportanchorX\", 0);\n region.viewportAnchorY = settings.get(\"viewportanchorY\", 100);\n region.scroll = settings.get(\"scroll\", \"\");\n // Register the region.\n self.onregion && self.onregion(region);\n // Remember the VTTRegion for later in case we parse any VTTCues that\n // reference it.\n self.regionList.push({\n id: settings.get(\"id\"),\n region: region\n });\n }\n }\n\n // draft-pantos-http-live-streaming-20\n // https://tools.ietf.org/html/draft-pantos-http-live-streaming-20#section-3.5\n // 3.5 WebVTT\n function parseTimestampMap(input) {\n var settings = new Settings();\n\n parseOptions(input, function(k, v) {\n switch(k) {\n case \"MPEGT\":\n settings.integer(k + 'S', v);\n break;\n case \"LOCA\":\n settings.set(k + 'L', parseTimeStamp(v));\n break;\n }\n }, /[^\\d]:/, /,/);\n\n self.ontimestampmap && self.ontimestampmap({\n \"MPEGTS\": settings.get(\"MPEGTS\"),\n \"LOCAL\": settings.get(\"LOCAL\")\n });\n }\n\n // 3.2 WebVTT metadata header syntax\n function parseHeader(input) {\n if (input.match(/X-TIMESTAMP-MAP/)) {\n // This line contains HLS X-TIMESTAMP-MAP metadata\n parseOptions(input, function(k, v) {\n switch(k) {\n case \"X-TIMESTAMP-MAP\":\n parseTimestampMap(v);\n break;\n }\n }, /=/);\n } else {\n parseOptions(input, function (k, v) {\n switch (k) {\n case \"Region\":\n // 3.3 WebVTT region metadata header syntax\n parseRegion(v);\n break;\n }\n }, /:/);\n }\n\n }\n\n // 5.1 WebVTT file parsing.\n try {\n var line;\n if (self.state === \"INITIAL\") {\n // We can't start parsing until we have the first line.\n if (!/\\r\\n|\\n/.test(self.buffer)) {\n return this;\n }\n\n line = collectNextLine();\n\n var m = line.match(/^WEBVTT([ \\t].*)?$/);\n if (!m || !m[0]) {\n throw new ParsingError(ParsingError.Errors.BadSignature);\n }\n\n self.state = \"HEADER\";\n }\n\n var alreadyCollectedLine = false;\n while (self.buffer) {\n // We can't parse a line until we have the full line.\n if (!/\\r\\n|\\n/.test(self.buffer)) {\n return this;\n }\n\n if (!alreadyCollectedLine) {\n line = collectNextLine();\n } else {\n alreadyCollectedLine = false;\n }\n\n switch (self.state) {\n case \"HEADER\":\n // 13-18 - Allow a header (metadata) under the WEBVTT line.\n if (/:/.test(line)) {\n parseHeader(line);\n } else if (!line) {\n // An empty line terminates the header and starts the body (cues).\n self.state = \"ID\";\n }\n continue;\n case \"NOTE\":\n // Ignore NOTE blocks.\n if (!line) {\n self.state = \"ID\";\n }\n continue;\n case \"ID\":\n // Check for the start of NOTE blocks.\n if (/^NOTE($|[ \\t])/.test(line)) {\n self.state = \"NOTE\";\n break;\n }\n // 19-29 - Allow any number of line terminators, then initialize new cue values.\n if (!line) {\n continue;\n }\n self.cue = new (self.vttjs.VTTCue || self.window.VTTCue)(0, 0, \"\");\n self.state = \"CUE\";\n // 30-39 - Check if self line contains an optional identifier or timing data.\n if (line.indexOf(\"-->\") === -1) {\n self.cue.id = line;\n continue;\n }\n // Process line as start of a cue.\n /*falls through*/\n case \"CUE\":\n // 40 - Collect cue timings and settings.\n try {\n parseCue(line, self.cue, self.regionList);\n } catch (e) {\n self.reportOrThrowError(e);\n // In case of an error ignore rest of the cue.\n self.cue = null;\n self.state = \"BADCUE\";\n continue;\n }\n self.state = \"CUETEXT\";\n continue;\n case \"CUETEXT\":\n var hasSubstring = line.indexOf(\"-->\") !== -1;\n // 34 - If we have an empty line then report the cue.\n // 35 - If we have the special substring '-->' then report the cue,\n // but do not collect the line as we need to process the current\n // one as a new cue.\n if (!line || hasSubstring && (alreadyCollectedLine = true)) {\n // We are done parsing self cue.\n self.oncue && self.oncue(self.cue);\n self.cue = null;\n self.state = \"ID\";\n continue;\n }\n if (self.cue.text) {\n self.cue.text += \"\\n\";\n }\n self.cue.text += line;\n continue;\n case \"BADCUE\": // BADCUE\n // 54-62 - Collect and discard the remaining cue.\n if (!line) {\n self.state = \"ID\";\n }\n continue;\n }\n }\n } catch (e) {\n self.reportOrThrowError(e);\n\n // If we are currently parsing a cue, report what we have.\n if (self.state === \"CUETEXT\" && self.cue && self.oncue) {\n self.oncue(self.cue);\n }\n self.cue = null;\n // Enter BADWEBVTT state if header was not parsed correctly otherwise\n // another exception occurred so enter BADCUE state.\n self.state = self.state === \"INITIAL\" ? \"BADWEBVTT\" : \"BADCUE\";\n }\n return this;\n },\n flush: function () {\n var self = this;\n try {\n // Finish decoding the stream.\n self.buffer += self.decoder.decode();\n // Synthesize the end of the current cue or region.\n if (self.cue || self.state === \"HEADER\") {\n self.buffer += \"\\n\\n\";\n self.parse();\n }\n // If we've flushed, parsed, and we're still on the INITIAL state then\n // that means we don't have enough of the stream to parse the first\n // line.\n if (self.state === \"INITIAL\") {\n throw new ParsingError(ParsingError.Errors.BadSignature);\n }\n } catch(e) {\n self.reportOrThrowError(e);\n }\n self.onflush && self.onflush();\n return this;\n }\n};\n\nmodule.exports = WebVTT;\n","/**\n * Copyright 2013 vtt.js Contributors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nvar autoKeyword = \"auto\";\nvar directionSetting = {\n \"\": 1,\n \"lr\": 1,\n \"rl\": 1\n};\nvar alignSetting = {\n \"start\": 1,\n \"middle\": 1,\n \"end\": 1,\n \"left\": 1,\n \"right\": 1\n};\n\nfunction findDirectionSetting(value) {\n if (typeof value !== \"string\") {\n return false;\n }\n var dir = directionSetting[value.toLowerCase()];\n return dir ? value.toLowerCase() : false;\n}\n\nfunction findAlignSetting(value) {\n if (typeof value !== \"string\") {\n return false;\n }\n var align = alignSetting[value.toLowerCase()];\n return align ? value.toLowerCase() : false;\n}\n\nfunction VTTCue(startTime, endTime, text) {\n /**\n * Shim implementation specific properties. These properties are not in\n * the spec.\n */\n\n // Lets us know when the VTTCue's data has changed in such a way that we need\n // to recompute its display state. This lets us compute its display state\n // lazily.\n this.hasBeenReset = false;\n\n /**\n * VTTCue and TextTrackCue properties\n * http://dev.w3.org/html5/webvtt/#vttcue-interface\n */\n\n var _id = \"\";\n var _pauseOnExit = false;\n var _startTime = startTime;\n var _endTime = endTime;\n var _text = text;\n var _region = null;\n var _vertical = \"\";\n var _snapToLines = true;\n var _line = \"auto\";\n var _lineAlign = \"start\";\n var _position = 50;\n var _positionAlign = \"middle\";\n var _size = 50;\n var _align = \"middle\";\n\n Object.defineProperties(this, {\n \"id\": {\n enumerable: true,\n get: function() {\n return _id;\n },\n set: function(value) {\n _id = \"\" + value;\n }\n },\n\n \"pauseOnExit\": {\n enumerable: true,\n get: function() {\n return _pauseOnExit;\n },\n set: function(value) {\n _pauseOnExit = !!value;\n }\n },\n\n \"startTime\": {\n enumerable: true,\n get: function() {\n return _startTime;\n },\n set: function(value) {\n if (typeof value !== \"number\") {\n throw new TypeError(\"Start time must be set to a number.\");\n }\n _startTime = value;\n this.hasBeenReset = true;\n }\n },\n\n \"endTime\": {\n enumerable: true,\n get: function() {\n return _endTime;\n },\n set: function(value) {\n if (typeof value !== \"number\") {\n throw new TypeError(\"End time must be set to a number.\");\n }\n _endTime = value;\n this.hasBeenReset = true;\n }\n },\n\n \"text\": {\n enumerable: true,\n get: function() {\n return _text;\n },\n set: function(value) {\n _text = \"\" + value;\n this.hasBeenReset = true;\n }\n },\n\n \"region\": {\n enumerable: true,\n get: function() {\n return _region;\n },\n set: function(value) {\n _region = value;\n this.hasBeenReset = true;\n }\n },\n\n \"vertical\": {\n enumerable: true,\n get: function() {\n return _vertical;\n },\n set: function(value) {\n var setting = findDirectionSetting(value);\n // Have to check for false because the setting an be an empty string.\n if (setting === false) {\n throw new SyntaxError(\"An invalid or illegal string was specified.\");\n }\n _vertical = setting;\n this.hasBeenReset = true;\n }\n },\n\n \"snapToLines\": {\n enumerable: true,\n get: function() {\n return _snapToLines;\n },\n set: function(value) {\n _snapToLines = !!value;\n this.hasBeenReset = true;\n }\n },\n\n \"line\": {\n enumerable: true,\n get: function() {\n return _line;\n },\n set: function(value) {\n if (typeof value !== \"number\" && value !== autoKeyword) {\n throw new SyntaxError(\"An invalid number or illegal string was specified.\");\n }\n _line = value;\n this.hasBeenReset = true;\n }\n },\n\n \"lineAlign\": {\n enumerable: true,\n get: function() {\n return _lineAlign;\n },\n set: function(value) {\n var setting = findAlignSetting(value);\n if (!setting) {\n throw new SyntaxError(\"An invalid or illegal string was specified.\");\n }\n _lineAlign = setting;\n this.hasBeenReset = true;\n }\n },\n\n \"position\": {\n enumerable: true,\n get: function() {\n return _position;\n },\n set: function(value) {\n if (value < 0 || value > 100) {\n throw new Error(\"Position must be between 0 and 100.\");\n }\n _position = value;\n this.hasBeenReset = true;\n }\n },\n\n \"positionAlign\": {\n enumerable: true,\n get: function() {\n return _positionAlign;\n },\n set: function(value) {\n var setting = findAlignSetting(value);\n if (!setting) {\n throw new SyntaxError(\"An invalid or illegal string was specified.\");\n }\n _positionAlign = setting;\n this.hasBeenReset = true;\n }\n },\n\n \"size\": {\n enumerable: true,\n get: function() {\n return _size;\n },\n set: function(value) {\n if (value < 0 || value > 100) {\n throw new Error(\"Size must be between 0 and 100.\");\n }\n _size = value;\n this.hasBeenReset = true;\n }\n },\n\n \"align\": {\n enumerable: true,\n get: function() {\n return _align;\n },\n set: function(value) {\n var setting = findAlignSetting(value);\n if (!setting) {\n throw new SyntaxError(\"An invalid or illegal string was specified.\");\n }\n _align = setting;\n this.hasBeenReset = true;\n }\n }\n });\n\n /**\n * Other <track> spec defined properties\n */\n\n // http://www.whatwg.org/specs/web-apps/current-work/multipage/the-video-element.html#text-track-cue-display-state\n this.displayState = undefined;\n}\n\n/**\n * VTTCue methods\n */\n\nVTTCue.prototype.getCueAsHTML = function() {\n // Assume WebVTT.convertCueToDOMTree is on the global.\n return WebVTT.convertCueToDOMTree(window, this.text);\n};\n\nmodule.exports = VTTCue;\n","/**\n * Copyright 2013 vtt.js Contributors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nvar scrollSetting = {\n \"\": true,\n \"up\": true\n};\n\nfunction findScrollSetting(value) {\n if (typeof value !== \"string\") {\n return false;\n }\n var scroll = scrollSetting[value.toLowerCase()];\n return scroll ? value.toLowerCase() : false;\n}\n\nfunction isValidPercentValue(value) {\n return typeof value === \"number\" && (value >= 0 && value <= 100);\n}\n\n// VTTRegion shim http://dev.w3.org/html5/webvtt/#vttregion-interface\nfunction VTTRegion() {\n var _width = 100;\n var _lines = 3;\n var _regionAnchorX = 0;\n var _regionAnchorY = 100;\n var _viewportAnchorX = 0;\n var _viewportAnchorY = 100;\n var _scroll = \"\";\n\n Object.defineProperties(this, {\n \"width\": {\n enumerable: true,\n get: function() {\n return _width;\n },\n set: function(value) {\n if (!isValidPercentValue(value)) {\n throw new Error(\"Width must be between 0 and 100.\");\n }\n _width = value;\n }\n },\n \"lines\": {\n enumerable: true,\n get: function() {\n return _lines;\n },\n set: function(value) {\n if (typeof value !== \"number\") {\n throw new TypeError(\"Lines must be set to a number.\");\n }\n _lines = value;\n }\n },\n \"regionAnchorY\": {\n enumerable: true,\n get: function() {\n return _regionAnchorY;\n },\n set: function(value) {\n if (!isValidPercentValue(value)) {\n throw new Error(\"RegionAnchorX must be between 0 and 100.\");\n }\n _regionAnchorY = value;\n }\n },\n \"regionAnchorX\": {\n enumerable: true,\n get: function() {\n return _regionAnchorX;\n },\n set: function(value) {\n if(!isValidPercentValue(value)) {\n throw new Error(\"RegionAnchorY must be between 0 and 100.\");\n }\n _regionAnchorX = value;\n }\n },\n \"viewportAnchorY\": {\n enumerable: true,\n get: function() {\n return _viewportAnchorY;\n },\n set: function(value) {\n if (!isValidPercentValue(value)) {\n throw new Error(\"ViewportAnchorY must be between 0 and 100.\");\n }\n _viewportAnchorY = value;\n }\n },\n \"viewportAnchorX\": {\n enumerable: true,\n get: function() {\n return _viewportAnchorX;\n },\n set: function(value) {\n if (!isValidPercentValue(value)) {\n throw new Error(\"ViewportAnchorX must be between 0 and 100.\");\n }\n _viewportAnchorX = value;\n }\n },\n \"scroll\": {\n enumerable: true,\n get: function() {\n return _scroll;\n },\n set: function(value) {\n var setting = findScrollSetting(value);\n // Have to check for false as an empty string is a legal value.\n if (setting === false) {\n throw new SyntaxError(\"An invalid or illegal string was specified.\");\n }\n _scroll = setting;\n }\n }\n });\n}\n\nmodule.exports = VTTRegion;\n","function clean (s) {\n return s.replace(/\\n\\r?\\s*/g, '')\n}\n\n\nmodule.exports = function tsml (sa) {\n var s = ''\n , i = 0\n\n for (; i < arguments.length; i++)\n s += clean(sa[i]) + (arguments[i + 1] || '')\n\n return s\n}","\"use strict\";\nvar window = require(\"global/window\")\nvar isFunction = require(\"is-function\")\nvar parseHeaders = require(\"parse-headers\")\nvar xtend = require(\"xtend\")\n\nmodule.exports = createXHR\ncreateXHR.XMLHttpRequest = window.XMLHttpRequest || noop\ncreateXHR.XDomainRequest = \"withCredentials\" in (new createXHR.XMLHttpRequest()) ? createXHR.XMLHttpRequest : window.XDomainRequest\n\nforEachArray([\"get\", \"put\", \"post\", \"patch\", \"head\", \"delete\"], function(method) {\n createXHR[method === \"delete\" ? \"del\" : method] = function(uri, options, callback) {\n options = initParams(uri, options, callback)\n options.method = method.toUpperCase()\n return _createXHR(options)\n }\n})\n\nfunction forEachArray(array, iterator) {\n for (var i = 0; i < array.length; i++) {\n iterator(array[i])\n }\n}\n\nfunction isEmpty(obj){\n for(var i in obj){\n if(obj.hasOwnProperty(i)) return false\n }\n return true\n}\n\nfunction initParams(uri, options, callback) {\n var params = uri\n\n if (isFunction(options)) {\n callback = options\n if (typeof uri === \"string\") {\n params = {uri:uri}\n }\n } else {\n params = xtend(options, {uri: uri})\n }\n\n params.callback = callback\n return params\n}\n\nfunction createXHR(uri, options, callback) {\n options = initParams(uri, options, callback)\n return _createXHR(options)\n}\n\nfunction _createXHR(options) {\n if(typeof options.callback === \"undefined\"){\n throw new Error(\"callback argument missing\")\n }\n\n var called = false\n var callback = function cbOnce(err, response, body){\n if(!called){\n called = true\n options.callback(err, response, body)\n }\n }\n\n function readystatechange() {\n if (xhr.readyState === 4) {\n setTimeout(loadFunc, 0)\n }\n }\n\n function getBody() {\n // Chrome with requestType=blob throws errors arround when even testing access to responseText\n var body = undefined\n\n if (xhr.response) {\n body = xhr.response\n } else {\n body = xhr.responseText || getXml(xhr)\n }\n\n if (isJson) {\n try {\n body = JSON.parse(body)\n } catch (e) {}\n }\n\n return body\n }\n\n function errorFunc(evt) {\n clearTimeout(timeoutTimer)\n if(!(evt instanceof Error)){\n evt = new Error(\"\" + (evt || \"Unknown XMLHttpRequest Error\") )\n }\n evt.statusCode = 0\n return callback(evt, failureResponse)\n }\n\n // will load the data & process the response in a special response object\n function loadFunc() {\n if (aborted) return\n var status\n clearTimeout(timeoutTimer)\n if(options.useXDR && xhr.status===undefined) {\n //IE8 CORS GET successful response doesn't have a status field, but body is fine\n status = 200\n } else {\n status = (xhr.status === 1223 ? 204 : xhr.status)\n }\n var response = failureResponse\n var err = null\n\n if (status !== 0){\n response = {\n body: getBody(),\n statusCode: status,\n method: method,\n headers: {},\n url: uri,\n rawRequest: xhr\n }\n if(xhr.getAllResponseHeaders){ //remember xhr can in fact be XDR for CORS in IE\n response.headers = parseHeaders(xhr.getAllResponseHeaders())\n }\n } else {\n err = new Error(\"Internal XMLHttpRequest Error\")\n }\n return callback(err, response, response.body)\n }\n\n var xhr = options.xhr || null\n\n if (!xhr) {\n if (options.cors || options.useXDR) {\n xhr = new createXHR.XDomainRequest()\n }else{\n xhr = new createXHR.XMLHttpRequest()\n }\n }\n\n var key\n var aborted\n var uri = xhr.url = options.uri || options.url\n var method = xhr.method = options.method || \"GET\"\n var body = options.body || options.data\n var headers = xhr.headers = options.headers || {}\n var sync = !!options.sync\n var isJson = false\n var timeoutTimer\n var failureResponse = {\n body: undefined,\n headers: {},\n statusCode: 0,\n method: method,\n url: uri,\n rawRequest: xhr\n }\n\n if (\"json\" in options && options.json !== false) {\n isJson = true\n headers[\"accept\"] || headers[\"Accept\"] || (headers[\"Accept\"] = \"application/json\") //Don't override existing accept header declared by user\n if (method !== \"GET\" && method !== \"HEAD\") {\n headers[\"content-type\"] || headers[\"Content-Type\"] || (headers[\"Content-Type\"] = \"application/json\") //Don't override existing accept header declared by user\n body = JSON.stringify(options.json === true ? body : options.json)\n }\n }\n\n xhr.onreadystatechange = readystatechange\n xhr.onload = loadFunc\n xhr.onerror = errorFunc\n // IE9 must have onprogress be set to a unique function.\n xhr.onprogress = function () {\n // IE must die\n }\n xhr.onabort = function(){\n aborted = true;\n }\n xhr.ontimeout = errorFunc\n xhr.open(method, uri, !sync, options.username, options.password)\n //has to be after open\n if(!sync) {\n xhr.withCredentials = !!options.withCredentials\n }\n // Cannot set timeout with sync request\n // not setting timeout on the xhr object, because of old webkits etc. not handling that correctly\n // both npm's request and jquery 1.x use this kind of timeout, so this is being consistent\n if (!sync && options.timeout > 0 ) {\n timeoutTimer = setTimeout(function(){\n if (aborted) return\n aborted = true//IE9 may still call readystatechange\n xhr.abort(\"timeout\")\n var e = new Error(\"XMLHttpRequest timeout\")\n e.code = \"ETIMEDOUT\"\n errorFunc(e)\n }, options.timeout )\n }\n\n if (xhr.setRequestHeader) {\n for(key in headers){\n if(headers.hasOwnProperty(key)){\n xhr.setRequestHeader(key, headers[key])\n }\n }\n } else if (options.headers && !isEmpty(options.headers)) {\n throw new Error(\"Headers cannot be set on an XDomainRequest object\")\n }\n\n if (\"responseType\" in options) {\n xhr.responseType = options.responseType\n }\n\n if (\"beforeSend\" in options &&\n typeof options.beforeSend === \"function\"\n ) {\n options.beforeSend(xhr)\n }\n\n // Microsoft Edge browser sends \"undefined\" when send is called with undefined value.\n // XMLHttpRequest spec says to pass null as body to indicate no body\n // See https://github.com/naugtur/xhr/issues/100.\n xhr.send(body || null)\n\n return xhr\n\n\n}\n\nfunction getXml(xhr) {\n if (xhr.responseType === \"document\") {\n return xhr.responseXML\n }\n var firefoxBugTakenEffect = xhr.responseXML && xhr.responseXML.documentElement.nodeName === \"parsererror\"\n if (xhr.responseType === \"\" && !firefoxBugTakenEffect) {\n return xhr.responseXML\n }\n\n return null\n}\n\nfunction noop() {}\n","module.exports = isFunction\n\nvar toString = Object.prototype.toString\n\nfunction isFunction (fn) {\n var string = toString.call(fn)\n return string === '[object Function]' ||\n (typeof fn === 'function' && string !== '[object RegExp]') ||\n (typeof window !== 'undefined' &&\n // IE8 and below\n (fn === window.setTimeout ||\n fn === window.alert ||\n fn === window.confirm ||\n fn === window.prompt))\n};\n","var trim = require('trim')\n , forEach = require('for-each')\n , isArray = function(arg) {\n return Object.prototype.toString.call(arg) === '[object Array]';\n }\n\nmodule.exports = function (headers) {\n if (!headers)\n return {}\n\n var result = {}\n\n forEach(\n trim(headers).split('\\n')\n , function (row) {\n var index = row.indexOf(':')\n , key = trim(row.slice(0, index)).toLowerCase()\n , value = trim(row.slice(index + 1))\n\n if (typeof(result[key]) === 'undefined') {\n result[key] = value\n } else if (isArray(result[key])) {\n result[key].push(value)\n } else {\n result[key] = [ result[key], value ]\n }\n }\n )\n\n return result\n}","\nexports = module.exports = trim;\n\nfunction trim(str){\n return str.replace(/^\\s*|\\s*$/g, '');\n}\n\nexports.left = function(str){\n return str.replace(/^\\s*/, '');\n};\n\nexports.right = function(str){\n return str.replace(/\\s*$/, '');\n};\n","'use strict';\n\nvar isCallable = require('is-callable');\n\nvar toStr = Object.prototype.toString;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\nvar forEachArray = function forEachArray(array, iterator, receiver) {\n for (var i = 0, len = array.length; i < len; i++) {\n if (hasOwnProperty.call(array, i)) {\n if (receiver == null) {\n iterator(array[i], i, array);\n } else {\n iterator.call(receiver, array[i], i, array);\n }\n }\n }\n};\n\nvar forEachString = function forEachString(string, iterator, receiver) {\n for (var i = 0, len = string.length; i < len; i++) {\n // no such thing as a sparse string.\n if (receiver == null) {\n iterator(string.charAt(i), i, string);\n } else {\n iterator.call(receiver, string.charAt(i), i, string);\n }\n }\n};\n\nvar forEachObject = function forEachObject(object, iterator, receiver) {\n for (var k in object) {\n if (hasOwnProperty.call(object, k)) {\n if (receiver == null) {\n iterator(object[k], k, object);\n } else {\n iterator.call(receiver, object[k], k, object);\n }\n }\n }\n};\n\nvar forEach = function forEach(list, iterator, thisArg) {\n if (!isCallable(iterator)) {\n throw new TypeError('iterator must be a function');\n }\n\n var receiver;\n if (arguments.length >= 3) {\n receiver = thisArg;\n }\n\n if (toStr.call(list) === '[object Array]') {\n forEachArray(list, iterator, receiver);\n } else if (typeof list === 'string') {\n forEachString(list, iterator, receiver);\n } else {\n forEachObject(list, iterator, receiver);\n }\n};\n\nmodule.exports = forEach;\n","'use strict';\n\nvar fnToStr = Function.prototype.toString;\n\nvar constructorRegex = /^\\s*class\\b/;\nvar isES6ClassFn = function isES6ClassFunction(value) {\n\ttry {\n\t\tvar fnStr = fnToStr.call(value);\n\t\treturn constructorRegex.test(fnStr);\n\t} catch (e) {\n\t\treturn false; // not a function\n\t}\n};\n\nvar tryFunctionObject = function tryFunctionToStr(value) {\n\ttry {\n\t\tif (isES6ClassFn(value)) { return false; }\n\t\tfnToStr.call(value);\n\t\treturn true;\n\t} catch (e) {\n\t\treturn false;\n\t}\n};\nvar toStr = Object.prototype.toString;\nvar fnClass = '[object Function]';\nvar genClass = '[object GeneratorFunction]';\nvar hasToStringTag = typeof Symbol === 'function' && typeof Symbol.toStringTag === 'symbol';\n\nmodule.exports = function isCallable(value) {\n\tif (!value) { return false; }\n\tif (typeof value !== 'function' && typeof value !== 'object') { return false; }\n\tif (typeof value === 'function' && !value.prototype) { return true; }\n\tif (hasToStringTag) { return tryFunctionObject(value); }\n\tif (isES6ClassFn(value)) { return false; }\n\tvar strClass = toStr.call(value);\n\treturn strClass === fnClass || strClass === genClass;\n};\n","module.exports = extend\n\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\nfunction extend() {\n var target = {}\n\n for (var i = 0; i < arguments.length; i++) {\n var source = arguments[i]\n\n for (var key in source) {\n if (hasOwnProperty.call(source, key)) {\n target[key] = source[key]\n }\n }\n }\n\n return target\n}\n","// see https://tools.ietf.org/html/rfc1808\n\n/* jshint ignore:start */\n(function(root) { \n/* jshint ignore:end */\n\n var URL_REGEX = /^((?:[a-zA-Z0-9+\\-.]+:)?)(\\/\\/[^\\/?#]*)?((?:[^\\/\\?#]*\\/)*.*?)??(;.*?)?(\\?.*?)?(#.*?)?$/;\n var FIRST_SEGMENT_REGEX = /^([^\\/?#]*)(.*)$/;\n var SLASH_DOT_REGEX = /(?:\\/|^)\\.(?=\\/)/g;\n var SLASH_DOT_DOT_REGEX = /(?:\\/|^)\\.\\.\\/(?!\\.\\.\\/).*?(?=\\/)/g;\n\n var URLToolkit = { // jshint ignore:line\n // If opts.alwaysNormalize is true then the path will always be normalized even when it starts with / or //\n // E.g\n // With opts.alwaysNormalize = false (default, spec compliant)\n // http://a.com/b/cd + /e/f/../g => http://a.com/e/f/../g\n // With opts.alwaysNormalize = true (not spec compliant)\n // http://a.com/b/cd + /e/f/../g => http://a.com/e/g\n buildAbsoluteURL: function(baseURL, relativeURL, opts) {\n opts = opts || {};\n // remove any remaining space and CRLF\n baseURL = baseURL.trim();\n relativeURL = relativeURL.trim();\n if (!relativeURL) {\n // 2a) If the embedded URL is entirely empty, it inherits the\n // entire base URL (i.e., is set equal to the base URL)\n // and we are done.\n if (!opts.alwaysNormalize) {\n return baseURL;\n }\n var basePartsForNormalise = URLToolkit.parseURL(baseURL);\n if (!basePartsForNormalise) {\n throw new Error('Error trying to parse base URL.');\n }\n basePartsForNormalise.path = URLToolkit.normalizePath(basePartsForNormalise.path);\n return URLToolkit.buildURLFromParts(basePartsForNormalise);\n }\n var relativeParts = URLToolkit.parseURL(relativeURL);\n if (!relativeParts) {\n throw new Error('Error trying to parse relative URL.');\n }\n if (relativeParts.scheme) {\n // 2b) If the embedded URL starts with a scheme name, it is\n // interpreted as an absolute URL and we are done.\n if (!opts.alwaysNormalize) {\n return relativeURL;\n }\n relativeParts.path = URLToolkit.normalizePath(relativeParts.path);\n return URLToolkit.buildURLFromParts(relativeParts);\n }\n var baseParts = URLToolkit.parseURL(baseURL);\n if (!baseParts) {\n throw new Error('Error trying to parse base URL.');\n }\n if (!baseParts.netLoc && baseParts.path && baseParts.path[0] !== '/') {\n // If netLoc missing and path doesn't start with '/', assume everthing before the first '/' is the netLoc\n // This causes 'example.com/a' to be handled as '//example.com/a' instead of '/example.com/a'\n var pathParts = FIRST_SEGMENT_REGEX.exec(baseParts.path);\n baseParts.netLoc = pathParts[1];\n baseParts.path = pathParts[2];\n }\n if (baseParts.netLoc && !baseParts.path) {\n baseParts.path = '/';\n }\n var builtParts = {\n // 2c) Otherwise, the embedded URL inherits the scheme of\n // the base URL.\n scheme: baseParts.scheme,\n netLoc: relativeParts.netLoc,\n path: null,\n params: relativeParts.params,\n query: relativeParts.query,\n fragment: relativeParts.fragment\n };\n if (!relativeParts.netLoc) {\n // 3) If the embedded URL's <net_loc> is non-empty, we skip to\n // Step 7. Otherwise, the embedded URL inherits the <net_loc>\n // (if any) of the base URL.\n builtParts.netLoc = baseParts.netLoc;\n // 4) If the embedded URL path is preceded by a slash \"/\", the\n // path is not relative and we skip to Step 7.\n if (relativeParts.path[0] !== '/') {\n if (!relativeParts.path) {\n // 5) If the embedded URL path is empty (and not preceded by a\n // slash), then the embedded URL inherits the base URL path\n builtParts.path = baseParts.path;\n // 5a) if the embedded URL's <params> is non-empty, we skip to\n // step 7; otherwise, it inherits the <params> of the base\n // URL (if any) and\n if (!relativeParts.params) {\n builtParts.params = baseParts.params;\n // 5b) if the embedded URL's <query> is non-empty, we skip to\n // step 7; otherwise, it inherits the <query> of the base\n // URL (if any) and we skip to step 7.\n if (!relativeParts.query) {\n builtParts.query = baseParts.query;\n }\n }\n } else {\n // 6) The last segment of the base URL's path (anything\n // following the rightmost slash \"/\", or the entire path if no\n // slash is present) is removed and the embedded URL's path is\n // appended in its place.\n var baseURLPath = baseParts.path;\n var newPath = baseURLPath.substring(0, baseURLPath.lastIndexOf('/') + 1) + relativeParts.path;\n builtParts.path = URLToolkit.normalizePath(newPath);\n }\n }\n }\n if (builtParts.path === null) {\n builtParts.path = opts.alwaysNormalize ? URLToolkit.normalizePath(relativeParts.path) : relativeParts.path;\n }\n return URLToolkit.buildURLFromParts(builtParts);\n },\n parseURL: function(url) {\n var parts = URL_REGEX.exec(url);\n if (!parts) {\n return null;\n }\n return {\n scheme: parts[1] || '',\n netLoc: parts[2] || '',\n path: parts[3] || '',\n params: parts[4] || '',\n query: parts[5] || '',\n fragment: parts[6] || ''\n };\n },\n normalizePath: function(path) {\n // The following operations are\n // then applied, in order, to the new path:\n // 6a) All occurrences of \"./\", where \".\" is a complete path\n // segment, are removed.\n // 6b) If the path ends with \".\" as a complete path segment,\n // that \".\" is removed.\n path = path.split('').reverse().join('').replace(SLASH_DOT_REGEX, '');\n // 6c) All occurrences of \"<segment>/../\", where <segment> is a\n // complete path segment not equal to \"..\", are removed.\n // Removal of these path segments is performed iteratively,\n // removing the leftmost matching pattern on each iteration,\n // until no matching pattern remains.\n // 6d) If the path ends with \"<segment>/..\", where <segment> is a\n // complete path segment not equal to \"..\", that\n // \"<segment>/..\" is removed.\n while (path.length !== (path = path.replace(SLASH_DOT_DOT_REGEX, '')).length) {} // jshint ignore:line\n return path.split('').reverse().join('');\n },\n buildURLFromParts: function(parts) {\n return parts.scheme + parts.netLoc + parts.path + parts.params + parts.query + parts.fragment;\n }\n };\n\n/* jshint ignore:start */\n if(typeof exports === 'object' && typeof module === 'object')\n module.exports = URLToolkit;\n else if(typeof define === 'function' && define.amd)\n define([], function() { return URLToolkit; });\n else if(typeof exports === 'object')\n exports[\"URLToolkit\"] = URLToolkit;\n else\n root[\"URLToolkit\"] = URLToolkit;\n})(this);\n/* jshint ignore:end */\n","var topLevel = typeof global !== 'undefined' ? global :\n typeof window !== 'undefined' ? window : {}\nvar minDoc = require('min-document');\n\nvar doccy;\n\nif (typeof document !== 'undefined') {\n doccy = document;\n} else {\n doccy = topLevel['__GLOBAL_DOCUMENT_CACHE@4'];\n\n if (!doccy) {\n doccy = topLevel['__GLOBAL_DOCUMENT_CACHE@4'] = minDoc;\n }\n}\n\nmodule.exports = doccy;\n","/*! @name mpd-parser @version 0.7.0 @license Apache-2.0 */\nimport window$1 from 'global/window';\n\nvar version = \"0.7.0\";\n\nvar isObject = function isObject(obj) {\n return !!obj && typeof obj === 'object';\n};\n\nvar merge = function merge() {\n for (var _len = arguments.length, objects = new Array(_len), _key = 0; _key < _len; _key++) {\n objects[_key] = arguments[_key];\n }\n\n return objects.reduce(function (result, source) {\n Object.keys(source).forEach(function (key) {\n if (Array.isArray(result[key]) && Array.isArray(source[key])) {\n result[key] = result[key].concat(source[key]);\n } else if (isObject(result[key]) && isObject(source[key])) {\n result[key] = merge(result[key], source[key]);\n } else {\n result[key] = source[key];\n }\n });\n return result;\n }, {});\n};\nvar values = function values(o) {\n return Object.keys(o).map(function (k) {\n return o[k];\n });\n};\n\nvar range = function range(start, end) {\n var result = [];\n\n for (var i = start; i < end; i++) {\n result.push(i);\n }\n\n return result;\n};\nvar flatten = function flatten(lists) {\n return lists.reduce(function (x, y) {\n return x.concat(y);\n }, []);\n};\nvar from = function from(list) {\n if (!list.length) {\n return [];\n }\n\n var result = [];\n\n for (var i = 0; i < list.length; i++) {\n result.push(list[i]);\n }\n\n return result;\n};\nvar findIndexes = function findIndexes(l, key) {\n return l.reduce(function (a, e, i) {\n if (e[key]) {\n a.push(i);\n }\n\n return a;\n }, []);\n};\n\nvar mergeDiscontiguousPlaylists = function mergeDiscontiguousPlaylists(playlists) {\n var mergedPlaylists = values(playlists.reduce(function (acc, playlist) {\n // assuming playlist IDs are the same across periods\n // TODO: handle multiperiod where representation sets are not the same\n // across periods\n var name = playlist.attributes.id + (playlist.attributes.lang || ''); // Periods after first\n\n if (acc[name]) {\n var _acc$name$segments;\n\n // first segment of subsequent periods signal a discontinuity\n playlist.segments[0].discontinuity = true;\n\n (_acc$name$segments = acc[name].segments).push.apply(_acc$name$segments, playlist.segments); // bubble up contentProtection, this assumes all DRM content\n // has the same contentProtection\n\n\n if (playlist.attributes.contentProtection) {\n acc[name].attributes.contentProtection = playlist.attributes.contentProtection;\n }\n } else {\n // first Period\n acc[name] = playlist;\n }\n\n return acc;\n }, {}));\n return mergedPlaylists.map(function (playlist) {\n playlist.discontinuityStarts = findIndexes(playlist.segments, 'discontinuity');\n return playlist;\n });\n};\n\nvar formatAudioPlaylist = function formatAudioPlaylist(_ref) {\n var _attributes;\n\n var attributes = _ref.attributes,\n segments = _ref.segments;\n var playlist = {\n attributes: (_attributes = {\n NAME: attributes.id,\n BANDWIDTH: attributes.bandwidth,\n CODECS: attributes.codecs\n }, _attributes['PROGRAM-ID'] = 1, _attributes),\n uri: '',\n endList: (attributes.type || 'static') === 'static',\n timeline: attributes.periodIndex,\n resolvedUri: '',\n targetDuration: attributes.duration,\n segments: segments,\n mediaSequence: segments.length ? segments[0].number : 1\n };\n\n if (attributes.contentProtection) {\n playlist.contentProtection = attributes.contentProtection;\n }\n\n return playlist;\n};\nvar formatVttPlaylist = function formatVttPlaylist(_ref2) {\n var _attributes2;\n\n var attributes = _ref2.attributes,\n segments = _ref2.segments;\n\n if (typeof segments === 'undefined') {\n // vtt tracks may use single file in BaseURL\n segments = [{\n uri: attributes.baseUrl,\n timeline: attributes.periodIndex,\n resolvedUri: attributes.baseUrl || '',\n duration: attributes.sourceDuration,\n number: 0\n }]; // targetDuration should be the same duration as the only segment\n\n attributes.duration = attributes.sourceDuration;\n }\n\n return {\n attributes: (_attributes2 = {\n NAME: attributes.id,\n BANDWIDTH: attributes.bandwidth\n }, _attributes2['PROGRAM-ID'] = 1, _attributes2),\n uri: '',\n endList: (attributes.type || 'static') === 'static',\n timeline: attributes.periodIndex,\n resolvedUri: attributes.baseUrl || '',\n targetDuration: attributes.duration,\n segments: segments,\n mediaSequence: segments.length ? segments[0].number : 1\n };\n};\nvar organizeAudioPlaylists = function organizeAudioPlaylists(playlists) {\n return playlists.reduce(function (a, playlist) {\n var role = playlist.attributes.role && playlist.attributes.role.value || 'main';\n var language = playlist.attributes.lang || '';\n var label = 'main';\n\n if (language) {\n label = playlist.attributes.lang + \" (\" + role + \")\";\n } // skip if we already have the highest quality audio for a language\n\n\n if (a[label] && a[label].playlists[0].attributes.BANDWIDTH > playlist.attributes.bandwidth) {\n return a;\n }\n\n a[label] = {\n language: language,\n autoselect: true,\n default: role === 'main',\n playlists: [formatAudioPlaylist(playlist)],\n uri: ''\n };\n return a;\n }, {});\n};\nvar organizeVttPlaylists = function organizeVttPlaylists(playlists) {\n return playlists.reduce(function (a, playlist) {\n var label = playlist.attributes.lang || 'text'; // skip if we already have subtitles\n\n if (a[label]) {\n return a;\n }\n\n a[label] = {\n language: label,\n default: false,\n autoselect: false,\n playlists: [formatVttPlaylist(playlist)],\n uri: ''\n };\n return a;\n }, {});\n};\nvar formatVideoPlaylist = function formatVideoPlaylist(_ref3) {\n var _attributes3;\n\n var attributes = _ref3.attributes,\n segments = _ref3.segments;\n var playlist = {\n attributes: (_attributes3 = {\n NAME: attributes.id,\n AUDIO: 'audio',\n SUBTITLES: 'subs',\n RESOLUTION: {\n width: attributes.width,\n height: attributes.height\n },\n CODECS: attributes.codecs,\n BANDWIDTH: attributes.bandwidth\n }, _attributes3['PROGRAM-ID'] = 1, _attributes3),\n uri: '',\n endList: (attributes.type || 'static') === 'static',\n timeline: attributes.periodIndex,\n resolvedUri: '',\n targetDuration: attributes.duration,\n segments: segments,\n mediaSequence: segments.length ? segments[0].number : 1\n };\n\n if (attributes.contentProtection) {\n playlist.contentProtection = attributes.contentProtection;\n }\n\n return playlist;\n};\nvar toM3u8 = function toM3u8(dashPlaylists) {\n var _mediaGroups;\n\n if (!dashPlaylists.length) {\n return {};\n } // grab all master attributes\n\n\n var _dashPlaylists$0$attr = dashPlaylists[0].attributes,\n duration = _dashPlaylists$0$attr.sourceDuration,\n _dashPlaylists$0$attr2 = _dashPlaylists$0$attr.minimumUpdatePeriod,\n minimumUpdatePeriod = _dashPlaylists$0$attr2 === void 0 ? 0 : _dashPlaylists$0$attr2;\n\n var videoOnly = function videoOnly(_ref4) {\n var attributes = _ref4.attributes;\n return attributes.mimeType === 'video/mp4' || attributes.contentType === 'video';\n };\n\n var audioOnly = function audioOnly(_ref5) {\n var attributes = _ref5.attributes;\n return attributes.mimeType === 'audio/mp4' || attributes.contentType === 'audio';\n };\n\n var vttOnly = function vttOnly(_ref6) {\n var attributes = _ref6.attributes;\n return attributes.mimeType === 'text/vtt' || attributes.contentType === 'text';\n };\n\n var videoPlaylists = mergeDiscontiguousPlaylists(dashPlaylists.filter(videoOnly)).map(formatVideoPlaylist);\n var audioPlaylists = mergeDiscontiguousPlaylists(dashPlaylists.filter(audioOnly));\n var vttPlaylists = dashPlaylists.filter(vttOnly);\n var master = {\n allowCache: true,\n discontinuityStarts: [],\n segments: [],\n endList: true,\n mediaGroups: (_mediaGroups = {\n AUDIO: {},\n VIDEO: {}\n }, _mediaGroups['CLOSED-CAPTIONS'] = {}, _mediaGroups.SUBTITLES = {}, _mediaGroups),\n uri: '',\n duration: duration,\n playlists: videoPlaylists,\n minimumUpdatePeriod: minimumUpdatePeriod * 1000\n };\n\n if (audioPlaylists.length) {\n master.mediaGroups.AUDIO.audio = organizeAudioPlaylists(audioPlaylists);\n }\n\n if (vttPlaylists.length) {\n master.mediaGroups.SUBTITLES.subs = organizeVttPlaylists(vttPlaylists);\n }\n\n return master;\n};\n\nvar commonjsGlobal = typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};\n\nfunction createCommonjsModule(fn, module) {\n\treturn module = { exports: {} }, fn(module, module.exports), module.exports;\n}\n\nvar urlToolkit = createCommonjsModule(function (module, exports) {\n// see https://tools.ietf.org/html/rfc1808\n\n/* jshint ignore:start */\n(function(root) { \n/* jshint ignore:end */\n\n var URL_REGEX = /^((?:[a-zA-Z0-9+\\-.]+:)?)(\\/\\/[^\\/?#]*)?((?:[^\\/\\?#]*\\/)*.*?)??(;.*?)?(\\?.*?)?(#.*?)?$/;\n var FIRST_SEGMENT_REGEX = /^([^\\/?#]*)(.*)$/;\n var SLASH_DOT_REGEX = /(?:\\/|^)\\.(?=\\/)/g;\n var SLASH_DOT_DOT_REGEX = /(?:\\/|^)\\.\\.\\/(?!\\.\\.\\/).*?(?=\\/)/g;\n\n var URLToolkit = { // jshint ignore:line\n // If opts.alwaysNormalize is true then the path will always be normalized even when it starts with / or //\n // E.g\n // With opts.alwaysNormalize = false (default, spec compliant)\n // http://a.com/b/cd + /e/f/../g => http://a.com/e/f/../g\n // With opts.alwaysNormalize = true (not spec compliant)\n // http://a.com/b/cd + /e/f/../g => http://a.com/e/g\n buildAbsoluteURL: function(baseURL, relativeURL, opts) {\n opts = opts || {};\n // remove any remaining space and CRLF\n baseURL = baseURL.trim();\n relativeURL = relativeURL.trim();\n if (!relativeURL) {\n // 2a) If the embedded URL is entirely empty, it inherits the\n // entire base URL (i.e., is set equal to the base URL)\n // and we are done.\n if (!opts.alwaysNormalize) {\n return baseURL;\n }\n var basePartsForNormalise = URLToolkit.parseURL(baseURL);\n if (!basePartsForNormalise) {\n throw new Error('Error trying to parse base URL.');\n }\n basePartsForNormalise.path = URLToolkit.normalizePath(basePartsForNormalise.path);\n return URLToolkit.buildURLFromParts(basePartsForNormalise);\n }\n var relativeParts = URLToolkit.parseURL(relativeURL);\n if (!relativeParts) {\n throw new Error('Error trying to parse relative URL.');\n }\n if (relativeParts.scheme) {\n // 2b) If the embedded URL starts with a scheme name, it is\n // interpreted as an absolute URL and we are done.\n if (!opts.alwaysNormalize) {\n return relativeURL;\n }\n relativeParts.path = URLToolkit.normalizePath(relativeParts.path);\n return URLToolkit.buildURLFromParts(relativeParts);\n }\n var baseParts = URLToolkit.parseURL(baseURL);\n if (!baseParts) {\n throw new Error('Error trying to parse base URL.');\n }\n if (!baseParts.netLoc && baseParts.path && baseParts.path[0] !== '/') {\n // If netLoc missing and path doesn't start with '/', assume everthing before the first '/' is the netLoc\n // This causes 'example.com/a' to be handled as '//example.com/a' instead of '/example.com/a'\n var pathParts = FIRST_SEGMENT_REGEX.exec(baseParts.path);\n baseParts.netLoc = pathParts[1];\n baseParts.path = pathParts[2];\n }\n if (baseParts.netLoc && !baseParts.path) {\n baseParts.path = '/';\n }\n var builtParts = {\n // 2c) Otherwise, the embedded URL inherits the scheme of\n // the base URL.\n scheme: baseParts.scheme,\n netLoc: relativeParts.netLoc,\n path: null,\n params: relativeParts.params,\n query: relativeParts.query,\n fragment: relativeParts.fragment\n };\n if (!relativeParts.netLoc) {\n // 3) If the embedded URL's <net_loc> is non-empty, we skip to\n // Step 7. Otherwise, the embedded URL inherits the <net_loc>\n // (if any) of the base URL.\n builtParts.netLoc = baseParts.netLoc;\n // 4) If the embedded URL path is preceded by a slash \"/\", the\n // path is not relative and we skip to Step 7.\n if (relativeParts.path[0] !== '/') {\n if (!relativeParts.path) {\n // 5) If the embedded URL path is empty (and not preceded by a\n // slash), then the embedded URL inherits the base URL path\n builtParts.path = baseParts.path;\n // 5a) if the embedded URL's <params> is non-empty, we skip to\n // step 7; otherwise, it inherits the <params> of the base\n // URL (if any) and\n if (!relativeParts.params) {\n builtParts.params = baseParts.params;\n // 5b) if the embedded URL's <query> is non-empty, we skip to\n // step 7; otherwise, it inherits the <query> of the base\n // URL (if any) and we skip to step 7.\n if (!relativeParts.query) {\n builtParts.query = baseParts.query;\n }\n }\n } else {\n // 6) The last segment of the base URL's path (anything\n // following the rightmost slash \"/\", or the entire path if no\n // slash is present) is removed and the embedded URL's path is\n // appended in its place.\n var baseURLPath = baseParts.path;\n var newPath = baseURLPath.substring(0, baseURLPath.lastIndexOf('/') + 1) + relativeParts.path;\n builtParts.path = URLToolkit.normalizePath(newPath);\n }\n }\n }\n if (builtParts.path === null) {\n builtParts.path = opts.alwaysNormalize ? URLToolkit.normalizePath(relativeParts.path) : relativeParts.path;\n }\n return URLToolkit.buildURLFromParts(builtParts);\n },\n parseURL: function(url) {\n var parts = URL_REGEX.exec(url);\n if (!parts) {\n return null;\n }\n return {\n scheme: parts[1] || '',\n netLoc: parts[2] || '',\n path: parts[3] || '',\n params: parts[4] || '',\n query: parts[5] || '',\n fragment: parts[6] || ''\n };\n },\n normalizePath: function(path) {\n // The following operations are\n // then applied, in order, to the new path:\n // 6a) All occurrences of \"./\", where \".\" is a complete path\n // segment, are removed.\n // 6b) If the path ends with \".\" as a complete path segment,\n // that \".\" is removed.\n path = path.split('').reverse().join('').replace(SLASH_DOT_REGEX, '');\n // 6c) All occurrences of \"<segment>/../\", where <segment> is a\n // complete path segment not equal to \"..\", are removed.\n // Removal of these path segments is performed iteratively,\n // removing the leftmost matching pattern on each iteration,\n // until no matching pattern remains.\n // 6d) If the path ends with \"<segment>/..\", where <segment> is a\n // complete path segment not equal to \"..\", that\n // \"<segment>/..\" is removed.\n while (path.length !== (path = path.replace(SLASH_DOT_DOT_REGEX, '')).length) {} // jshint ignore:line\n return path.split('').reverse().join('');\n },\n buildURLFromParts: function(parts) {\n return parts.scheme + parts.netLoc + parts.path + parts.params + parts.query + parts.fragment;\n }\n };\n\n/* jshint ignore:start */\n module.exports = URLToolkit;\n})(commonjsGlobal);\n/* jshint ignore:end */\n});\n\nvar resolveUrl = function resolveUrl(baseUrl, relativeUrl) {\n // return early if we don't need to resolve\n if (/^[a-z]+:/i.test(relativeUrl)) {\n return relativeUrl;\n } // if the base URL is relative then combine with the current location\n\n\n if (!/\\/\\//i.test(baseUrl)) {\n baseUrl = urlToolkit.buildAbsoluteURL(window$1.location.href, baseUrl);\n }\n\n return urlToolkit.buildAbsoluteURL(baseUrl, relativeUrl);\n};\n\n/**\n * @typedef {Object} SingleUri\n * @property {string} uri - relative location of segment\n * @property {string} resolvedUri - resolved location of segment\n * @property {Object} byterange - Object containing information on how to make byte range\n * requests following byte-range-spec per RFC2616.\n * @property {String} byterange.length - length of range request\n * @property {String} byterange.offset - byte offset of range request\n *\n * @see https://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.35.1\n */\n\n/**\n * Converts a URLType node (5.3.9.2.3 Table 13) to a segment object\n * that conforms to how m3u8-parser is structured\n *\n * @see https://github.com/videojs/m3u8-parser\n *\n * @param {string} baseUrl - baseUrl provided by <BaseUrl> nodes\n * @param {string} source - source url for segment\n * @param {string} range - optional range used for range calls, follows\n * @return {SingleUri} full segment information transformed into a format similar\n * to m3u8-parser\n */\n\nvar urlTypeToSegment = function urlTypeToSegment(_ref) {\n var _ref$baseUrl = _ref.baseUrl,\n baseUrl = _ref$baseUrl === void 0 ? '' : _ref$baseUrl,\n _ref$source = _ref.source,\n source = _ref$source === void 0 ? '' : _ref$source,\n _ref$range = _ref.range,\n range = _ref$range === void 0 ? '' : _ref$range;\n var init = {\n uri: source,\n resolvedUri: resolveUrl(baseUrl || '', source)\n };\n\n if (range) {\n var ranges = range.split('-');\n var startRange = parseInt(ranges[0], 10);\n var endRange = parseInt(ranges[1], 10);\n init.byterange = {\n length: endRange - startRange,\n offset: startRange\n };\n }\n\n return init;\n};\n\n/**\n * Calculates the R (repetition) value for a live stream (for the final segment\n * in a manifest where the r value is negative 1)\n *\n * @param {Object} attributes\n * Object containing all inherited attributes from parent elements with attribute\n * names as keys\n * @param {number} time\n * current time (typically the total time up until the final segment)\n * @param {number} duration\n * duration property for the given <S />\n *\n * @return {number}\n * R value to reach the end of the given period\n */\nvar getLiveRValue = function getLiveRValue(attributes, time, duration) {\n var NOW = attributes.NOW,\n clientOffset = attributes.clientOffset,\n availabilityStartTime = attributes.availabilityStartTime,\n _attributes$timescale = attributes.timescale,\n timescale = _attributes$timescale === void 0 ? 1 : _attributes$timescale,\n _attributes$start = attributes.start,\n start = _attributes$start === void 0 ? 0 : _attributes$start,\n _attributes$minimumUp = attributes.minimumUpdatePeriod,\n minimumUpdatePeriod = _attributes$minimumUp === void 0 ? 0 : _attributes$minimumUp;\n var now = (NOW + clientOffset) / 1000;\n var periodStartWC = availabilityStartTime + start;\n var periodEndWC = now + minimumUpdatePeriod;\n var periodDuration = periodEndWC - periodStartWC;\n return Math.ceil((periodDuration * timescale - time) / duration);\n};\n/**\n * Uses information provided by SegmentTemplate.SegmentTimeline to determine segment\n * timing and duration\n *\n * @param {Object} attributes\n * Object containing all inherited attributes from parent elements with attribute\n * names as keys\n * @param {Object[]} segmentTimeline\n * List of objects representing the attributes of each S element contained within\n *\n * @return {{number: number, duration: number, time: number, timeline: number}[]}\n * List of Objects with segment timing and duration info\n */\n\n\nvar parseByTimeline = function parseByTimeline(attributes, segmentTimeline) {\n var _attributes$type = attributes.type,\n type = _attributes$type === void 0 ? 'static' : _attributes$type,\n _attributes$minimumUp2 = attributes.minimumUpdatePeriod,\n minimumUpdatePeriod = _attributes$minimumUp2 === void 0 ? 0 : _attributes$minimumUp2,\n _attributes$media = attributes.media,\n media = _attributes$media === void 0 ? '' : _attributes$media,\n sourceDuration = attributes.sourceDuration,\n _attributes$timescale2 = attributes.timescale,\n timescale = _attributes$timescale2 === void 0 ? 1 : _attributes$timescale2,\n _attributes$startNumb = attributes.startNumber,\n startNumber = _attributes$startNumb === void 0 ? 1 : _attributes$startNumb,\n timeline = attributes.periodIndex;\n var segments = [];\n var time = -1;\n\n for (var sIndex = 0; sIndex < segmentTimeline.length; sIndex++) {\n var S = segmentTimeline[sIndex];\n var duration = S.d;\n var repeat = S.r || 0;\n var segmentTime = S.t || 0;\n\n if (time < 0) {\n // first segment\n time = segmentTime;\n }\n\n if (segmentTime && segmentTime > time) {\n // discontinuity\n // TODO: How to handle this type of discontinuity\n // timeline++ here would treat it like HLS discontuity and content would\n // get appended without gap\n // E.G.\n // <S t=\"0\" d=\"1\" />\n // <S d=\"1\" />\n // <S d=\"1\" />\n // <S t=\"5\" d=\"1\" />\n // would have $Time$ values of [0, 1, 2, 5]\n // should this be appened at time positions [0, 1, 2, 3],(#EXT-X-DISCONTINUITY)\n // or [0, 1, 2, gap, gap, 5]? (#EXT-X-GAP)\n // does the value of sourceDuration consider this when calculating arbitrary\n // negative @r repeat value?\n // E.G. Same elements as above with this added at the end\n // <S d=\"1\" r=\"-1\" />\n // with a sourceDuration of 10\n // Would the 2 gaps be included in the time duration calculations resulting in\n // 8 segments with $Time$ values of [0, 1, 2, 5, 6, 7, 8, 9] or 10 segments\n // with $Time$ values of [0, 1, 2, 5, 6, 7, 8, 9, 10, 11] ?\n time = segmentTime;\n }\n\n var count = void 0;\n\n if (repeat < 0) {\n var nextS = sIndex + 1;\n\n if (nextS === segmentTimeline.length) {\n // last segment\n if (type === 'dynamic' && minimumUpdatePeriod > 0 && media.indexOf('$Number$') > 0) {\n count = getLiveRValue(attributes, time, duration);\n } else {\n // TODO: This may be incorrect depending on conclusion of TODO above\n count = (sourceDuration * timescale - time) / duration;\n }\n } else {\n count = (segmentTimeline[nextS].t - time) / duration;\n }\n } else {\n count = repeat + 1;\n }\n\n var end = startNumber + segments.length + count;\n var number = startNumber + segments.length;\n\n while (number < end) {\n segments.push({\n number: number,\n duration: duration / timescale,\n time: time,\n timeline: timeline\n });\n time += duration;\n number++;\n }\n }\n\n return segments;\n};\n\n/**\n * Functions for calculating the range of available segments in static and dynamic\n * manifests.\n */\n\nvar segmentRange = {\n /**\n * Returns the entire range of available segments for a static MPD\n *\n * @param {Object} attributes\n * Inheritied MPD attributes\n * @return {{ start: number, end: number }}\n * The start and end numbers for available segments\n */\n static: function _static(attributes) {\n var duration = attributes.duration,\n _attributes$timescale = attributes.timescale,\n timescale = _attributes$timescale === void 0 ? 1 : _attributes$timescale,\n sourceDuration = attributes.sourceDuration;\n return {\n start: 0,\n end: Math.ceil(sourceDuration / (duration / timescale))\n };\n },\n\n /**\n * Returns the current live window range of available segments for a dynamic MPD\n *\n * @param {Object} attributes\n * Inheritied MPD attributes\n * @return {{ start: number, end: number }}\n * The start and end numbers for available segments\n */\n dynamic: function dynamic(attributes) {\n var NOW = attributes.NOW,\n clientOffset = attributes.clientOffset,\n availabilityStartTime = attributes.availabilityStartTime,\n _attributes$timescale2 = attributes.timescale,\n timescale = _attributes$timescale2 === void 0 ? 1 : _attributes$timescale2,\n duration = attributes.duration,\n _attributes$start = attributes.start,\n start = _attributes$start === void 0 ? 0 : _attributes$start,\n _attributes$minimumUp = attributes.minimumUpdatePeriod,\n minimumUpdatePeriod = _attributes$minimumUp === void 0 ? 0 : _attributes$minimumUp,\n _attributes$timeShift = attributes.timeShiftBufferDepth,\n timeShiftBufferDepth = _attributes$timeShift === void 0 ? Infinity : _attributes$timeShift;\n var now = (NOW + clientOffset) / 1000;\n var periodStartWC = availabilityStartTime + start;\n var periodEndWC = now + minimumUpdatePeriod;\n var periodDuration = periodEndWC - periodStartWC;\n var segmentCount = Math.ceil(periodDuration * timescale / duration);\n var availableStart = Math.floor((now - periodStartWC - timeShiftBufferDepth) * timescale / duration);\n var availableEnd = Math.floor((now - periodStartWC) * timescale / duration);\n return {\n start: Math.max(0, availableStart),\n end: Math.min(segmentCount, availableEnd)\n };\n }\n};\n/**\n * Maps a range of numbers to objects with information needed to build the corresponding\n * segment list\n *\n * @name toSegmentsCallback\n * @function\n * @param {number} number\n * Number of the segment\n * @param {number} index\n * Index of the number in the range list\n * @return {{ number: Number, duration: Number, timeline: Number, time: Number }}\n * Object with segment timing and duration info\n */\n\n/**\n * Returns a callback for Array.prototype.map for mapping a range of numbers to\n * information needed to build the segment list.\n *\n * @param {Object} attributes\n * Inherited MPD attributes\n * @return {toSegmentsCallback}\n * Callback map function\n */\n\nvar toSegments = function toSegments(attributes) {\n return function (number, index) {\n var duration = attributes.duration,\n _attributes$timescale3 = attributes.timescale,\n timescale = _attributes$timescale3 === void 0 ? 1 : _attributes$timescale3,\n periodIndex = attributes.periodIndex,\n _attributes$startNumb = attributes.startNumber,\n startNumber = _attributes$startNumb === void 0 ? 1 : _attributes$startNumb;\n return {\n number: startNumber + number,\n duration: duration / timescale,\n timeline: periodIndex,\n time: index * duration\n };\n };\n};\n/**\n * Returns a list of objects containing segment timing and duration info used for\n * building the list of segments. This uses the @duration attribute specified\n * in the MPD manifest to derive the range of segments.\n *\n * @param {Object} attributes\n * Inherited MPD attributes\n * @return {{number: number, duration: number, time: number, timeline: number}[]}\n * List of Objects with segment timing and duration info\n */\n\nvar parseByDuration = function parseByDuration(attributes) {\n var _attributes$type = attributes.type,\n type = _attributes$type === void 0 ? 'static' : _attributes$type,\n duration = attributes.duration,\n _attributes$timescale4 = attributes.timescale,\n timescale = _attributes$timescale4 === void 0 ? 1 : _attributes$timescale4,\n sourceDuration = attributes.sourceDuration;\n\n var _segmentRange$type = segmentRange[type](attributes),\n start = _segmentRange$type.start,\n end = _segmentRange$type.end;\n\n var segments = range(start, end).map(toSegments(attributes));\n\n if (type === 'static') {\n var index = segments.length - 1; // final segment may be less than full segment duration\n\n segments[index].duration = sourceDuration - duration / timescale * index;\n }\n\n return segments;\n};\n\nvar identifierPattern = /\\$([A-z]*)(?:(%0)([0-9]+)d)?\\$/g;\n/**\n * Replaces template identifiers with corresponding values. To be used as the callback\n * for String.prototype.replace\n *\n * @name replaceCallback\n * @function\n * @param {string} match\n * Entire match of identifier\n * @param {string} identifier\n * Name of matched identifier\n * @param {string} format\n * Format tag string. Its presence indicates that padding is expected\n * @param {string} width\n * Desired length of the replaced value. Values less than this width shall be left\n * zero padded\n * @return {string}\n * Replacement for the matched identifier\n */\n\n/**\n * Returns a function to be used as a callback for String.prototype.replace to replace\n * template identifiers\n *\n * @param {Obect} values\n * Object containing values that shall be used to replace known identifiers\n * @param {number} values.RepresentationID\n * Value of the Representation@id attribute\n * @param {number} values.Number\n * Number of the corresponding segment\n * @param {number} values.Bandwidth\n * Value of the Representation@bandwidth attribute.\n * @param {number} values.Time\n * Timestamp value of the corresponding segment\n * @return {replaceCallback}\n * Callback to be used with String.prototype.replace to replace identifiers\n */\n\nvar identifierReplacement = function identifierReplacement(values) {\n return function (match, identifier, format, width) {\n if (match === '$$') {\n // escape sequence\n return '$';\n }\n\n if (typeof values[identifier] === 'undefined') {\n return match;\n }\n\n var value = '' + values[identifier];\n\n if (identifier === 'RepresentationID') {\n // Format tag shall not be present with RepresentationID\n return value;\n }\n\n if (!format) {\n width = 1;\n } else {\n width = parseInt(width, 10);\n }\n\n if (value.length >= width) {\n return value;\n }\n\n return \"\" + new Array(width - value.length + 1).join('0') + value;\n };\n};\n/**\n * Constructs a segment url from a template string\n *\n * @param {string} url\n * Template string to construct url from\n * @param {Obect} values\n * Object containing values that shall be used to replace known identifiers\n * @param {number} values.RepresentationID\n * Value of the Representation@id attribute\n * @param {number} values.Number\n * Number of the corresponding segment\n * @param {number} values.Bandwidth\n * Value of the Representation@bandwidth attribute.\n * @param {number} values.Time\n * Timestamp value of the corresponding segment\n * @return {string}\n * Segment url with identifiers replaced\n */\n\nvar constructTemplateUrl = function constructTemplateUrl(url, values) {\n return url.replace(identifierPattern, identifierReplacement(values));\n};\n/**\n * Generates a list of objects containing timing and duration information about each\n * segment needed to generate segment uris and the complete segment object\n *\n * @param {Object} attributes\n * Object containing all inherited attributes from parent elements with attribute\n * names as keys\n * @param {Object[]|undefined} segmentTimeline\n * List of objects representing the attributes of each S element contained within\n * the SegmentTimeline element\n * @return {{number: number, duration: number, time: number, timeline: number}[]}\n * List of Objects with segment timing and duration info\n */\n\nvar parseTemplateInfo = function parseTemplateInfo(attributes, segmentTimeline) {\n if (!attributes.duration && !segmentTimeline) {\n // if neither @duration or SegmentTimeline are present, then there shall be exactly\n // one media segment\n return [{\n number: attributes.startNumber || 1,\n duration: attributes.sourceDuration,\n time: 0,\n timeline: attributes.periodIndex\n }];\n }\n\n if (attributes.duration) {\n return parseByDuration(attributes);\n }\n\n return parseByTimeline(attributes, segmentTimeline);\n};\n/**\n * Generates a list of segments using information provided by the SegmentTemplate element\n *\n * @param {Object} attributes\n * Object containing all inherited attributes from parent elements with attribute\n * names as keys\n * @param {Object[]|undefined} segmentTimeline\n * List of objects representing the attributes of each S element contained within\n * the SegmentTimeline element\n * @return {Object[]}\n * List of segment objects\n */\n\nvar segmentsFromTemplate = function segmentsFromTemplate(attributes, segmentTimeline) {\n var templateValues = {\n RepresentationID: attributes.id,\n Bandwidth: attributes.bandwidth || 0\n };\n var _attributes$initializ = attributes.initialization,\n initialization = _attributes$initializ === void 0 ? {\n sourceURL: '',\n range: ''\n } : _attributes$initializ;\n var mapSegment = urlTypeToSegment({\n baseUrl: attributes.baseUrl,\n source: constructTemplateUrl(initialization.sourceURL, templateValues),\n range: initialization.range\n });\n var segments = parseTemplateInfo(attributes, segmentTimeline);\n return segments.map(function (segment) {\n templateValues.Number = segment.number;\n templateValues.Time = segment.time;\n var uri = constructTemplateUrl(attributes.media || '', templateValues);\n return {\n uri: uri,\n timeline: segment.timeline,\n duration: segment.duration,\n resolvedUri: resolveUrl(attributes.baseUrl || '', uri),\n map: mapSegment,\n number: segment.number\n };\n });\n};\n\nvar errors = {\n INVALID_NUMBER_OF_PERIOD: 'INVALID_NUMBER_OF_PERIOD',\n DASH_EMPTY_MANIFEST: 'DASH_EMPTY_MANIFEST',\n DASH_INVALID_XML: 'DASH_INVALID_XML',\n NO_BASE_URL: 'NO_BASE_URL',\n MISSING_SEGMENT_INFORMATION: 'MISSING_SEGMENT_INFORMATION',\n SEGMENT_TIME_UNSPECIFIED: 'SEGMENT_TIME_UNSPECIFIED',\n UNSUPPORTED_UTC_TIMING_SCHEME: 'UNSUPPORTED_UTC_TIMING_SCHEME'\n};\n\n/**\n * Converts a <SegmentUrl> (of type URLType from the DASH spec 5.3.9.2 Table 14)\n * to an object that matches the output of a segment in videojs/mpd-parser\n *\n * @param {Object} attributes\n * Object containing all inherited attributes from parent elements with attribute\n * names as keys\n * @param {Object} segmentUrl\n * <SegmentURL> node to translate into a segment object\n * @return {Object} translated segment object\n */\n\nvar SegmentURLToSegmentObject = function SegmentURLToSegmentObject(attributes, segmentUrl) {\n var baseUrl = attributes.baseUrl,\n _attributes$initializ = attributes.initialization,\n initialization = _attributes$initializ === void 0 ? {} : _attributes$initializ;\n var initSegment = urlTypeToSegment({\n baseUrl: baseUrl,\n source: initialization.sourceURL,\n range: initialization.range\n });\n var segment = urlTypeToSegment({\n baseUrl: baseUrl,\n source: segmentUrl.media,\n range: segmentUrl.mediaRange\n });\n segment.map = initSegment;\n return segment;\n};\n/**\n * Generates a list of segments using information provided by the SegmentList element\n * SegmentList (DASH SPEC Section 5.3.9.3.2) contains a set of <SegmentURL> nodes. Each\n * node should be translated into segment.\n *\n * @param {Object} attributes\n * Object containing all inherited attributes from parent elements with attribute\n * names as keys\n * @param {Object[]|undefined} segmentTimeline\n * List of objects representing the attributes of each S element contained within\n * the SegmentTimeline element\n * @return {Object.<Array>} list of segments\n */\n\n\nvar segmentsFromList = function segmentsFromList(attributes, segmentTimeline) {\n var duration = attributes.duration,\n _attributes$segmentUr = attributes.segmentUrls,\n segmentUrls = _attributes$segmentUr === void 0 ? [] : _attributes$segmentUr; // Per spec (5.3.9.2.1) no way to determine segment duration OR\n // if both SegmentTimeline and @duration are defined, it is outside of spec.\n\n if (!duration && !segmentTimeline || duration && segmentTimeline) {\n throw new Error(errors.SEGMENT_TIME_UNSPECIFIED);\n }\n\n var segmentUrlMap = segmentUrls.map(function (segmentUrlObject) {\n return SegmentURLToSegmentObject(attributes, segmentUrlObject);\n });\n var segmentTimeInfo;\n\n if (duration) {\n segmentTimeInfo = parseByDuration(attributes);\n }\n\n if (segmentTimeline) {\n segmentTimeInfo = parseByTimeline(attributes, segmentTimeline);\n }\n\n var segments = segmentTimeInfo.map(function (segmentTime, index) {\n if (segmentUrlMap[index]) {\n var segment = segmentUrlMap[index];\n segment.timeline = segmentTime.timeline;\n segment.duration = segmentTime.duration;\n segment.number = segmentTime.number;\n return segment;\n } // Since we're mapping we should get rid of any blank segments (in case\n // the given SegmentTimeline is handling for more elements than we have\n // SegmentURLs for).\n\n }).filter(function (segment) {\n return segment;\n });\n return segments;\n};\n\n/**\n * Translates SegmentBase into a set of segments.\n * (DASH SPEC Section 5.3.9.3.2) contains a set of <SegmentURL> nodes. Each\n * node should be translated into segment.\n *\n * @param {Object} attributes\n * Object containing all inherited attributes from parent elements with attribute\n * names as keys\n * @return {Object.<Array>} list of segments\n */\n\nvar segmentsFromBase = function segmentsFromBase(attributes) {\n var baseUrl = attributes.baseUrl,\n _attributes$initializ = attributes.initialization,\n initialization = _attributes$initializ === void 0 ? {} : _attributes$initializ,\n sourceDuration = attributes.sourceDuration,\n _attributes$timescale = attributes.timescale,\n timescale = _attributes$timescale === void 0 ? 1 : _attributes$timescale,\n _attributes$indexRang = attributes.indexRange,\n indexRange = _attributes$indexRang === void 0 ? '' : _attributes$indexRang,\n duration = attributes.duration; // base url is required for SegmentBase to work, per spec (Section 5.3.9.2.1)\n\n if (!baseUrl) {\n throw new Error(errors.NO_BASE_URL);\n }\n\n var initSegment = urlTypeToSegment({\n baseUrl: baseUrl,\n source: initialization.sourceURL,\n range: initialization.range\n });\n var segment = urlTypeToSegment({\n baseUrl: baseUrl,\n source: baseUrl,\n range: indexRange\n });\n segment.map = initSegment; // If there is a duration, use it, otherwise use the given duration of the source\n // (since SegmentBase is only for one total segment)\n\n if (duration) {\n var segmentTimeInfo = parseByDuration(attributes);\n\n if (segmentTimeInfo.length) {\n segment.duration = segmentTimeInfo[0].duration;\n segment.timeline = segmentTimeInfo[0].timeline;\n }\n } else if (sourceDuration) {\n segment.duration = sourceDuration / timescale;\n segment.timeline = 0;\n } // This is used for mediaSequence\n\n\n segment.number = 0;\n return [segment];\n};\n\nvar generateSegments = function generateSegments(_ref) {\n var attributes = _ref.attributes,\n segmentInfo = _ref.segmentInfo;\n var segmentAttributes;\n var segmentsFn;\n\n if (segmentInfo.template) {\n segmentsFn = segmentsFromTemplate;\n segmentAttributes = merge(attributes, segmentInfo.template);\n } else if (segmentInfo.base) {\n segmentsFn = segmentsFromBase;\n segmentAttributes = merge(attributes, segmentInfo.base);\n } else if (segmentInfo.list) {\n segmentsFn = segmentsFromList;\n segmentAttributes = merge(attributes, segmentInfo.list);\n }\n\n if (!segmentsFn) {\n return {\n attributes: attributes\n };\n }\n\n var segments = segmentsFn(segmentAttributes, segmentInfo.timeline); // The @duration attribute will be used to determin the playlist's targetDuration which\n // must be in seconds. Since we've generated the segment list, we no longer need\n // @duration to be in @timescale units, so we can convert it here.\n\n if (segmentAttributes.duration) {\n var _segmentAttributes = segmentAttributes,\n duration = _segmentAttributes.duration,\n _segmentAttributes$ti = _segmentAttributes.timescale,\n timescale = _segmentAttributes$ti === void 0 ? 1 : _segmentAttributes$ti;\n segmentAttributes.duration = duration / timescale;\n } else if (segments.length) {\n // if there is no @duration attribute, use the largest segment duration as\n // as target duration\n segmentAttributes.duration = segments.reduce(function (max, segment) {\n return Math.max(max, Math.ceil(segment.duration));\n }, 0);\n } else {\n segmentAttributes.duration = 0;\n }\n\n return {\n attributes: segmentAttributes,\n segments: segments\n };\n};\nvar toPlaylists = function toPlaylists(representations) {\n return representations.map(generateSegments);\n};\n\nvar findChildren = function findChildren(element, name) {\n return from(element.childNodes).filter(function (_ref) {\n var tagName = _ref.tagName;\n return tagName === name;\n });\n};\nvar getContent = function getContent(element) {\n return element.textContent.trim();\n};\n\nvar parseDuration = function parseDuration(str) {\n var SECONDS_IN_YEAR = 365 * 24 * 60 * 60;\n var SECONDS_IN_MONTH = 30 * 24 * 60 * 60;\n var SECONDS_IN_DAY = 24 * 60 * 60;\n var SECONDS_IN_HOUR = 60 * 60;\n var SECONDS_IN_MIN = 60; // P10Y10M10DT10H10M10.1S\n\n var durationRegex = /P(?:(\\d*)Y)?(?:(\\d*)M)?(?:(\\d*)D)?(?:T(?:(\\d*)H)?(?:(\\d*)M)?(?:([\\d.]*)S)?)?/;\n var match = durationRegex.exec(str);\n\n if (!match) {\n return 0;\n }\n\n var _match$slice = match.slice(1),\n year = _match$slice[0],\n month = _match$slice[1],\n day = _match$slice[2],\n hour = _match$slice[3],\n minute = _match$slice[4],\n second = _match$slice[5];\n\n return parseFloat(year || 0) * SECONDS_IN_YEAR + parseFloat(month || 0) * SECONDS_IN_MONTH + parseFloat(day || 0) * SECONDS_IN_DAY + parseFloat(hour || 0) * SECONDS_IN_HOUR + parseFloat(minute || 0) * SECONDS_IN_MIN + parseFloat(second || 0);\n};\nvar parseDate = function parseDate(str) {\n // Date format without timezone according to ISO 8601\n // YYY-MM-DDThh:mm:ss.ssssss\n var dateRegex = /^\\d+-\\d+-\\d+T\\d+:\\d+:\\d+(\\.\\d+)?$/; // If the date string does not specifiy a timezone, we must specifiy UTC. This is\n // expressed by ending with 'Z'\n\n if (dateRegex.test(str)) {\n str += 'Z';\n }\n\n return Date.parse(str);\n};\n\nvar parsers = {\n /**\n * Specifies the duration of the entire Media Presentation. Format is a duration string\n * as specified in ISO 8601\n *\n * @param {string} value\n * value of attribute as a string\n * @return {number}\n * The duration in seconds\n */\n mediaPresentationDuration: function mediaPresentationDuration(value) {\n return parseDuration(value);\n },\n\n /**\n * Specifies the Segment availability start time for all Segments referred to in this\n * MPD. For a dynamic manifest, it specifies the anchor for the earliest availability\n * time. Format is a date string as specified in ISO 8601\n *\n * @param {string} value\n * value of attribute as a string\n * @return {number}\n * The date as seconds from unix epoch\n */\n availabilityStartTime: function availabilityStartTime(value) {\n return parseDate(value) / 1000;\n },\n\n /**\n * Specifies the smallest period between potential changes to the MPD. Format is a\n * duration string as specified in ISO 8601\n *\n * @param {string} value\n * value of attribute as a string\n * @return {number}\n * The duration in seconds\n */\n minimumUpdatePeriod: function minimumUpdatePeriod(value) {\n return parseDuration(value);\n },\n\n /**\n * Specifies the duration of the smallest time shifting buffer for any Representation\n * in the MPD. Format is a duration string as specified in ISO 8601\n *\n * @param {string} value\n * value of attribute as a string\n * @return {number}\n * The duration in seconds\n */\n timeShiftBufferDepth: function timeShiftBufferDepth(value) {\n return parseDuration(value);\n },\n\n /**\n * Specifies the PeriodStart time of the Period relative to the availabilityStarttime.\n * Format is a duration string as specified in ISO 8601\n *\n * @param {string} value\n * value of attribute as a string\n * @return {number}\n * The duration in seconds\n */\n start: function start(value) {\n return parseDuration(value);\n },\n\n /**\n * Specifies the width of the visual presentation\n *\n * @param {string} value\n * value of attribute as a string\n * @return {number}\n * The parsed width\n */\n width: function width(value) {\n return parseInt(value, 10);\n },\n\n /**\n * Specifies the height of the visual presentation\n *\n * @param {string} value\n * value of attribute as a string\n * @return {number}\n * The parsed height\n */\n height: function height(value) {\n return parseInt(value, 10);\n },\n\n /**\n * Specifies the bitrate of the representation\n *\n * @param {string} value\n * value of attribute as a string\n * @return {number}\n * The parsed bandwidth\n */\n bandwidth: function bandwidth(value) {\n return parseInt(value, 10);\n },\n\n /**\n * Specifies the number of the first Media Segment in this Representation in the Period\n *\n * @param {string} value\n * value of attribute as a string\n * @return {number}\n * The parsed number\n */\n startNumber: function startNumber(value) {\n return parseInt(value, 10);\n },\n\n /**\n * Specifies the timescale in units per seconds\n *\n * @param {string} value\n * value of attribute as a string\n * @return {number}\n * The aprsed timescale\n */\n timescale: function timescale(value) {\n return parseInt(value, 10);\n },\n\n /**\n * Specifies the constant approximate Segment duration\n * NOTE: The <Period> element also contains an @duration attribute. This duration\n * specifies the duration of the Period. This attribute is currently not\n * supported by the rest of the parser, however we still check for it to prevent\n * errors.\n *\n * @param {string} value\n * value of attribute as a string\n * @return {number}\n * The parsed duration\n */\n duration: function duration(value) {\n var parsedValue = parseInt(value, 10);\n\n if (isNaN(parsedValue)) {\n return parseDuration(value);\n }\n\n return parsedValue;\n },\n\n /**\n * Specifies the Segment duration, in units of the value of the @timescale.\n *\n * @param {string} value\n * value of attribute as a string\n * @return {number}\n * The parsed duration\n */\n d: function d(value) {\n return parseInt(value, 10);\n },\n\n /**\n * Specifies the MPD start time, in @timescale units, the first Segment in the series\n * starts relative to the beginning of the Period\n *\n * @param {string} value\n * value of attribute as a string\n * @return {number}\n * The parsed time\n */\n t: function t(value) {\n return parseInt(value, 10);\n },\n\n /**\n * Specifies the repeat count of the number of following contiguous Segments with the\n * same duration expressed by the value of @d\n *\n * @param {string} value\n * value of attribute as a string\n * @return {number}\n * The parsed number\n */\n r: function r(value) {\n return parseInt(value, 10);\n },\n\n /**\n * Default parser for all other attributes. Acts as a no-op and just returns the value\n * as a string\n *\n * @param {string} value\n * value of attribute as a string\n * @return {string}\n * Unparsed value\n */\n DEFAULT: function DEFAULT(value) {\n return value;\n }\n};\n/**\n * Gets all the attributes and values of the provided node, parses attributes with known\n * types, and returns an object with attribute names mapped to values.\n *\n * @param {Node} el\n * The node to parse attributes from\n * @return {Object}\n * Object with all attributes of el parsed\n */\n\nvar parseAttributes = function parseAttributes(el) {\n if (!(el && el.attributes)) {\n return {};\n }\n\n return from(el.attributes).reduce(function (a, e) {\n var parseFn = parsers[e.name] || parsers.DEFAULT;\n a[e.name] = parseFn(e.value);\n return a;\n }, {});\n};\n\nfunction decodeB64ToUint8Array(b64Text) {\n var decodedString = window$1.atob(b64Text);\n var array = new Uint8Array(decodedString.length);\n\n for (var i = 0; i < decodedString.length; i++) {\n array[i] = decodedString.charCodeAt(i);\n }\n\n return array;\n}\n\nvar keySystemsMap = {\n 'urn:uuid:1077efec-c0b2-4d02-ace3-3c1e52e2fb4b': 'org.w3.clearkey',\n 'urn:uuid:edef8ba9-79d6-4ace-a3c8-27dcd51d21ed': 'com.widevine.alpha',\n 'urn:uuid:9a04f079-9840-4286-ab92-e65be0885f95': 'com.microsoft.playready',\n 'urn:uuid:f239e769-efa3-4850-9c16-a903c6932efb': 'com.adobe.primetime'\n};\n/**\n * Builds a list of urls that is the product of the reference urls and BaseURL values\n *\n * @param {string[]} referenceUrls\n * List of reference urls to resolve to\n * @param {Node[]} baseUrlElements\n * List of BaseURL nodes from the mpd\n * @return {string[]}\n * List of resolved urls\n */\n\nvar buildBaseUrls = function buildBaseUrls(referenceUrls, baseUrlElements) {\n if (!baseUrlElements.length) {\n return referenceUrls;\n }\n\n return flatten(referenceUrls.map(function (reference) {\n return baseUrlElements.map(function (baseUrlElement) {\n return resolveUrl(reference, getContent(baseUrlElement));\n });\n }));\n};\n/**\n * Contains all Segment information for its containing AdaptationSet\n *\n * @typedef {Object} SegmentInformation\n * @property {Object|undefined} template\n * Contains the attributes for the SegmentTemplate node\n * @property {Object[]|undefined} timeline\n * Contains a list of atrributes for each S node within the SegmentTimeline node\n * @property {Object|undefined} list\n * Contains the attributes for the SegmentList node\n * @property {Object|undefined} base\n * Contains the attributes for the SegmentBase node\n */\n\n/**\n * Returns all available Segment information contained within the AdaptationSet node\n *\n * @param {Node} adaptationSet\n * The AdaptationSet node to get Segment information from\n * @return {SegmentInformation}\n * The Segment information contained within the provided AdaptationSet\n */\n\nvar getSegmentInformation = function getSegmentInformation(adaptationSet) {\n var segmentTemplate = findChildren(adaptationSet, 'SegmentTemplate')[0];\n var segmentList = findChildren(adaptationSet, 'SegmentList')[0];\n var segmentUrls = segmentList && findChildren(segmentList, 'SegmentURL').map(function (s) {\n return merge({\n tag: 'SegmentURL'\n }, parseAttributes(s));\n });\n var segmentBase = findChildren(adaptationSet, 'SegmentBase')[0];\n var segmentTimelineParentNode = segmentList || segmentTemplate;\n var segmentTimeline = segmentTimelineParentNode && findChildren(segmentTimelineParentNode, 'SegmentTimeline')[0];\n var segmentInitializationParentNode = segmentList || segmentBase || segmentTemplate;\n var segmentInitialization = segmentInitializationParentNode && findChildren(segmentInitializationParentNode, 'Initialization')[0]; // SegmentTemplate is handled slightly differently, since it can have both\n // @initialization and an <Initialization> node. @initialization can be templated,\n // while the node can have a url and range specified. If the <SegmentTemplate> has\n // both @initialization and an <Initialization> subelement we opt to override with\n // the node, as this interaction is not defined in the spec.\n\n var template = segmentTemplate && parseAttributes(segmentTemplate);\n\n if (template && segmentInitialization) {\n template.initialization = segmentInitialization && parseAttributes(segmentInitialization);\n } else if (template && template.initialization) {\n // If it is @initialization we convert it to an object since this is the format that\n // later functions will rely on for the initialization segment. This is only valid\n // for <SegmentTemplate>\n template.initialization = {\n sourceURL: template.initialization\n };\n }\n\n var segmentInfo = {\n template: template,\n timeline: segmentTimeline && findChildren(segmentTimeline, 'S').map(function (s) {\n return parseAttributes(s);\n }),\n list: segmentList && merge(parseAttributes(segmentList), {\n segmentUrls: segmentUrls,\n initialization: parseAttributes(segmentInitialization)\n }),\n base: segmentBase && merge(parseAttributes(segmentBase), {\n initialization: parseAttributes(segmentInitialization)\n })\n };\n Object.keys(segmentInfo).forEach(function (key) {\n if (!segmentInfo[key]) {\n delete segmentInfo[key];\n }\n });\n return segmentInfo;\n};\n/**\n * Contains Segment information and attributes needed to construct a Playlist object\n * from a Representation\n *\n * @typedef {Object} RepresentationInformation\n * @property {SegmentInformation} segmentInfo\n * Segment information for this Representation\n * @property {Object} attributes\n * Inherited attributes for this Representation\n */\n\n/**\n * Maps a Representation node to an object containing Segment information and attributes\n *\n * @name inheritBaseUrlsCallback\n * @function\n * @param {Node} representation\n * Representation node from the mpd\n * @return {RepresentationInformation}\n * Representation information needed to construct a Playlist object\n */\n\n/**\n * Returns a callback for Array.prototype.map for mapping Representation nodes to\n * Segment information and attributes using inherited BaseURL nodes.\n *\n * @param {Object} adaptationSetAttributes\n * Contains attributes inherited by the AdaptationSet\n * @param {string[]} adaptationSetBaseUrls\n * Contains list of resolved base urls inherited by the AdaptationSet\n * @param {SegmentInformation} adaptationSetSegmentInfo\n * Contains Segment information for the AdaptationSet\n * @return {inheritBaseUrlsCallback}\n * Callback map function\n */\n\nvar inheritBaseUrls = function inheritBaseUrls(adaptationSetAttributes, adaptationSetBaseUrls, adaptationSetSegmentInfo) {\n return function (representation) {\n var repBaseUrlElements = findChildren(representation, 'BaseURL');\n var repBaseUrls = buildBaseUrls(adaptationSetBaseUrls, repBaseUrlElements);\n var attributes = merge(adaptationSetAttributes, parseAttributes(representation));\n var representationSegmentInfo = getSegmentInformation(representation);\n return repBaseUrls.map(function (baseUrl) {\n return {\n segmentInfo: merge(adaptationSetSegmentInfo, representationSegmentInfo),\n attributes: merge(attributes, {\n baseUrl: baseUrl\n })\n };\n });\n };\n};\n/**\n * Tranforms a series of content protection nodes to\n * an object containing pssh data by key system\n *\n * @param {Node[]} contentProtectionNodes\n * Content protection nodes\n * @return {Object}\n * Object containing pssh data by key system\n */\n\nvar generateKeySystemInformation = function generateKeySystemInformation(contentProtectionNodes) {\n return contentProtectionNodes.reduce(function (acc, node) {\n var attributes = parseAttributes(node);\n var keySystem = keySystemsMap[attributes.schemeIdUri];\n\n if (keySystem) {\n acc[keySystem] = {\n attributes: attributes\n };\n var psshNode = findChildren(node, 'cenc:pssh')[0];\n\n if (psshNode) {\n var pssh = getContent(psshNode);\n var psshBuffer = pssh && decodeB64ToUint8Array(pssh);\n acc[keySystem].pssh = psshBuffer;\n }\n }\n\n return acc;\n }, {});\n};\n/**\n * Maps an AdaptationSet node to a list of Representation information objects\n *\n * @name toRepresentationsCallback\n * @function\n * @param {Node} adaptationSet\n * AdaptationSet node from the mpd\n * @return {RepresentationInformation[]}\n * List of objects containing Representaion information\n */\n\n/**\n * Returns a callback for Array.prototype.map for mapping AdaptationSet nodes to a list of\n * Representation information objects\n *\n * @param {Object} periodAttributes\n * Contains attributes inherited by the Period\n * @param {string[]} periodBaseUrls\n * Contains list of resolved base urls inherited by the Period\n * @param {string[]} periodSegmentInfo\n * Contains Segment Information at the period level\n * @return {toRepresentationsCallback}\n * Callback map function\n */\n\n\nvar toRepresentations = function toRepresentations(periodAttributes, periodBaseUrls, periodSegmentInfo) {\n return function (adaptationSet) {\n var adaptationSetAttributes = parseAttributes(adaptationSet);\n var adaptationSetBaseUrls = buildBaseUrls(periodBaseUrls, findChildren(adaptationSet, 'BaseURL'));\n var role = findChildren(adaptationSet, 'Role')[0];\n var roleAttributes = {\n role: parseAttributes(role)\n };\n var attrs = merge(periodAttributes, adaptationSetAttributes, roleAttributes);\n var contentProtection = generateKeySystemInformation(findChildren(adaptationSet, 'ContentProtection'));\n\n if (Object.keys(contentProtection).length) {\n attrs = merge(attrs, {\n contentProtection: contentProtection\n });\n }\n\n var segmentInfo = getSegmentInformation(adaptationSet);\n var representations = findChildren(adaptationSet, 'Representation');\n var adaptationSetSegmentInfo = merge(periodSegmentInfo, segmentInfo);\n return flatten(representations.map(inheritBaseUrls(attrs, adaptationSetBaseUrls, adaptationSetSegmentInfo)));\n };\n};\n/**\n * Maps an Period node to a list of Representation inforamtion objects for all\n * AdaptationSet nodes contained within the Period\n *\n * @name toAdaptationSetsCallback\n * @function\n * @param {Node} period\n * Period node from the mpd\n * @param {number} periodIndex\n * Index of the Period within the mpd\n * @return {RepresentationInformation[]}\n * List of objects containing Representaion information\n */\n\n/**\n * Returns a callback for Array.prototype.map for mapping Period nodes to a list of\n * Representation information objects\n *\n * @param {Object} mpdAttributes\n * Contains attributes inherited by the mpd\n * @param {string[]} mpdBaseUrls\n * Contains list of resolved base urls inherited by the mpd\n * @return {toAdaptationSetsCallback}\n * Callback map function\n */\n\nvar toAdaptationSets = function toAdaptationSets(mpdAttributes, mpdBaseUrls) {\n return function (period, index) {\n var periodBaseUrls = buildBaseUrls(mpdBaseUrls, findChildren(period, 'BaseURL'));\n var periodAtt = parseAttributes(period);\n var parsedPeriodId = parseInt(periodAtt.id, 10); // fallback to mapping index if Period@id is not a number\n\n var periodIndex = window$1.isNaN(parsedPeriodId) ? index : parsedPeriodId;\n var periodAttributes = merge(mpdAttributes, {\n periodIndex: periodIndex\n });\n var adaptationSets = findChildren(period, 'AdaptationSet');\n var periodSegmentInfo = getSegmentInformation(period);\n return flatten(adaptationSets.map(toRepresentations(periodAttributes, periodBaseUrls, periodSegmentInfo)));\n };\n};\n/**\n * Traverses the mpd xml tree to generate a list of Representation information objects\n * that have inherited attributes from parent nodes\n *\n * @param {Node} mpd\n * The root node of the mpd\n * @param {Object} options\n * Available options for inheritAttributes\n * @param {string} options.manifestUri\n * The uri source of the mpd\n * @param {number} options.NOW\n * Current time per DASH IOP. Default is current time in ms since epoch\n * @param {number} options.clientOffset\n * Client time difference from NOW (in milliseconds)\n * @return {RepresentationInformation[]}\n * List of objects containing Representation information\n */\n\nvar inheritAttributes = function inheritAttributes(mpd, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n _options$manifestUri = _options.manifestUri,\n manifestUri = _options$manifestUri === void 0 ? '' : _options$manifestUri,\n _options$NOW = _options.NOW,\n NOW = _options$NOW === void 0 ? Date.now() : _options$NOW,\n _options$clientOffset = _options.clientOffset,\n clientOffset = _options$clientOffset === void 0 ? 0 : _options$clientOffset;\n var periods = findChildren(mpd, 'Period');\n\n if (!periods.length) {\n throw new Error(errors.INVALID_NUMBER_OF_PERIOD);\n }\n\n var mpdAttributes = parseAttributes(mpd);\n var mpdBaseUrls = buildBaseUrls([manifestUri], findChildren(mpd, 'BaseURL'));\n mpdAttributes.sourceDuration = mpdAttributes.mediaPresentationDuration || 0;\n mpdAttributes.NOW = NOW;\n mpdAttributes.clientOffset = clientOffset;\n return flatten(periods.map(toAdaptationSets(mpdAttributes, mpdBaseUrls)));\n};\n\nvar stringToMpdXml = function stringToMpdXml(manifestString) {\n if (manifestString === '') {\n throw new Error(errors.DASH_EMPTY_MANIFEST);\n }\n\n var parser = new window$1.DOMParser();\n var xml = parser.parseFromString(manifestString, 'application/xml');\n var mpd = xml && xml.documentElement.tagName === 'MPD' ? xml.documentElement : null;\n\n if (!mpd || mpd && mpd.getElementsByTagName('parsererror').length > 0) {\n throw new Error(errors.DASH_INVALID_XML);\n }\n\n return mpd;\n};\n\n/**\n * Parses the manifest for a UTCTiming node, returning the nodes attributes if found\n *\n * @param {string} mpd\n * XML string of the MPD manifest\n * @return {Object|null}\n * Attributes of UTCTiming node specified in the manifest. Null if none found\n */\n\nvar parseUTCTimingScheme = function parseUTCTimingScheme(mpd) {\n var UTCTimingNode = findChildren(mpd, 'UTCTiming')[0];\n\n if (!UTCTimingNode) {\n return null;\n }\n\n var attributes = parseAttributes(UTCTimingNode);\n\n switch (attributes.schemeIdUri) {\n case 'urn:mpeg:dash:utc:http-head:2014':\n case 'urn:mpeg:dash:utc:http-head:2012':\n attributes.method = 'HEAD';\n break;\n\n case 'urn:mpeg:dash:utc:http-xsdate:2014':\n case 'urn:mpeg:dash:utc:http-iso:2014':\n case 'urn:mpeg:dash:utc:http-xsdate:2012':\n case 'urn:mpeg:dash:utc:http-iso:2012':\n attributes.method = 'GET';\n break;\n\n case 'urn:mpeg:dash:utc:direct:2014':\n case 'urn:mpeg:dash:utc:direct:2012':\n attributes.method = 'DIRECT';\n attributes.value = Date.parse(attributes.value);\n break;\n\n case 'urn:mpeg:dash:utc:http-ntp:2014':\n case 'urn:mpeg:dash:utc:ntp:2014':\n case 'urn:mpeg:dash:utc:sntp:2014':\n default:\n throw new Error(errors.UNSUPPORTED_UTC_TIMING_SCHEME);\n }\n\n return attributes;\n};\n\nvar VERSION = version;\nvar parse = function parse(manifestString, options) {\n return toM3u8(toPlaylists(inheritAttributes(stringToMpdXml(manifestString), options)));\n};\n/**\n * Parses the manifest for a UTCTiming node, returning the nodes attributes if found\n *\n * @param {string} manifestString\n * XML string of the MPD manifest\n * @return {Object|null}\n * Attributes of UTCTiming node specified in the manifest. Null if none found\n */\n\nvar parseUTCTiming = function parseUTCTiming(manifestString) {\n return parseUTCTimingScheme(stringToMpdXml(manifestString));\n};\n\nexport { VERSION, parse, parseUTCTiming };\n","var toUnsigned = function(value) {\n return value >>> 0;\n};\n\nmodule.exports = {\n toUnsigned: toUnsigned\n};\n","module.exports = {\n generator: require('./mp4-generator'),\n probe: require('./probe'),\n Transmuxer: require('./transmuxer').Transmuxer,\n AudioSegmentStream: require('./transmuxer').AudioSegmentStream,\n VideoSegmentStream: require('./transmuxer').VideoSegmentStream,\n CaptionParser: require('./caption-parser')\n};\n","// Convert an array of nal units into an array of frames with each frame being\n// composed of the nal units that make up that frame\n// Also keep track of cummulative data about the frame from the nal units such\n// as the frame duration, starting pts, etc.\nvar groupNalsIntoFrames = function(nalUnits) {\n var\n i,\n currentNal,\n currentFrame = [],\n frames = [];\n\n currentFrame.byteLength = 0;\n\n for (i = 0; i < nalUnits.length; i++) {\n currentNal = nalUnits[i];\n\n // Split on 'aud'-type nal units\n if (currentNal.nalUnitType === 'access_unit_delimiter_rbsp') {\n // Since the very first nal unit is expected to be an AUD\n // only push to the frames array when currentFrame is not empty\n if (currentFrame.length) {\n currentFrame.duration = currentNal.dts - currentFrame.dts;\n frames.push(currentFrame);\n }\n currentFrame = [currentNal];\n currentFrame.byteLength = currentNal.data.byteLength;\n currentFrame.pts = currentNal.pts;\n currentFrame.dts = currentNal.dts;\n } else {\n // Specifically flag key frames for ease of use later\n if (currentNal.nalUnitType === 'slice_layer_without_partitioning_rbsp_idr') {\n currentFrame.keyFrame = true;\n }\n currentFrame.duration = currentNal.dts - currentFrame.dts;\n currentFrame.byteLength += currentNal.data.byteLength;\n currentFrame.push(currentNal);\n }\n }\n\n // For the last frame, use the duration of the previous frame if we\n // have nothing better to go on\n if (frames.length &&\n (!currentFrame.duration ||\n currentFrame.duration <= 0)) {\n currentFrame.duration = frames[frames.length - 1].duration;\n }\n\n // Push the final frame\n frames.push(currentFrame);\n return frames;\n};\n\n// Convert an array of frames into an array of Gop with each Gop being composed\n// of the frames that make up that Gop\n// Also keep track of cummulative data about the Gop from the frames such as the\n// Gop duration, starting pts, etc.\nvar groupFramesIntoGops = function(frames) {\n var\n i,\n currentFrame,\n currentGop = [],\n gops = [];\n\n // We must pre-set some of the values on the Gop since we\n // keep running totals of these values\n currentGop.byteLength = 0;\n currentGop.nalCount = 0;\n currentGop.duration = 0;\n currentGop.pts = frames[0].pts;\n currentGop.dts = frames[0].dts;\n\n // store some metadata about all the Gops\n gops.byteLength = 0;\n gops.nalCount = 0;\n gops.duration = 0;\n gops.pts = frames[0].pts;\n gops.dts = frames[0].dts;\n\n for (i = 0; i < frames.length; i++) {\n currentFrame = frames[i];\n\n if (currentFrame.keyFrame) {\n // Since the very first frame is expected to be an keyframe\n // only push to the gops array when currentGop is not empty\n if (currentGop.length) {\n gops.push(currentGop);\n gops.byteLength += currentGop.byteLength;\n gops.nalCount += currentGop.nalCount;\n gops.duration += currentGop.duration;\n }\n\n currentGop = [currentFrame];\n currentGop.nalCount = currentFrame.length;\n currentGop.byteLength = currentFrame.byteLength;\n currentGop.pts = currentFrame.pts;\n currentGop.dts = currentFrame.dts;\n currentGop.duration = currentFrame.duration;\n } else {\n currentGop.duration += currentFrame.duration;\n currentGop.nalCount += currentFrame.length;\n currentGop.byteLength += currentFrame.byteLength;\n currentGop.push(currentFrame);\n }\n }\n\n if (gops.length && currentGop.duration <= 0) {\n currentGop.duration = gops[gops.length - 1].duration;\n }\n gops.byteLength += currentGop.byteLength;\n gops.nalCount += currentGop.nalCount;\n gops.duration += currentGop.duration;\n\n // push the final Gop\n gops.push(currentGop);\n return gops;\n};\n\n/*\n * Search for the first keyframe in the GOPs and throw away all frames\n * until that keyframe. Then extend the duration of the pulled keyframe\n * and pull the PTS and DTS of the keyframe so that it covers the time\n * range of the frames that were disposed.\n *\n * @param {Array} gops video GOPs\n * @returns {Array} modified video GOPs\n */\nvar extendFirstKeyFrame = function(gops) {\n var currentGop;\n\n if (!gops[0][0].keyFrame && gops.length > 1) {\n // Remove the first GOP\n currentGop = gops.shift();\n\n gops.byteLength -= currentGop.byteLength;\n gops.nalCount -= currentGop.nalCount;\n\n // Extend the first frame of what is now the\n // first gop to cover the time period of the\n // frames we just removed\n gops[0][0].dts = currentGop.dts;\n gops[0][0].pts = currentGop.pts;\n gops[0][0].duration += currentGop.duration;\n }\n\n return gops;\n};\n\n/**\n * Default sample object\n * see ISO/IEC 14496-12:2012, section 8.6.4.3\n */\nvar createDefaultSample = function() {\n return {\n size: 0,\n flags: {\n isLeading: 0,\n dependsOn: 1,\n isDependedOn: 0,\n hasRedundancy: 0,\n degradationPriority: 0,\n isNonSyncSample: 1\n }\n };\n};\n\n/*\n * Collates information from a video frame into an object for eventual\n * entry into an MP4 sample table.\n *\n * @param {Object} frame the video frame\n * @param {Number} dataOffset the byte offset to position the sample\n * @return {Object} object containing sample table info for a frame\n */\nvar sampleForFrame = function(frame, dataOffset) {\n var sample = createDefaultSample();\n\n sample.dataOffset = dataOffset;\n sample.compositionTimeOffset = frame.pts - frame.dts;\n sample.duration = frame.duration;\n sample.size = 4 * frame.length; // Space for nal unit size\n sample.size += frame.byteLength;\n\n if (frame.keyFrame) {\n sample.flags.dependsOn = 2;\n sample.flags.isNonSyncSample = 0;\n }\n\n return sample;\n};\n\n// generate the track's sample table from an array of gops\nvar generateSampleTable = function(gops, baseDataOffset) {\n var\n h, i,\n sample,\n currentGop,\n currentFrame,\n dataOffset = baseDataOffset || 0,\n samples = [];\n\n for (h = 0; h < gops.length; h++) {\n currentGop = gops[h];\n\n for (i = 0; i < currentGop.length; i++) {\n currentFrame = currentGop[i];\n\n sample = sampleForFrame(currentFrame, dataOffset);\n\n dataOffset += sample.size;\n\n samples.push(sample);\n }\n }\n return samples;\n};\n\n// generate the track's raw mdat data from an array of gops\nvar concatenateNalData = function(gops) {\n var\n h, i, j,\n currentGop,\n currentFrame,\n currentNal,\n dataOffset = 0,\n nalsByteLength = gops.byteLength,\n numberOfNals = gops.nalCount,\n totalByteLength = nalsByteLength + 4 * numberOfNals,\n data = new Uint8Array(totalByteLength),\n view = new DataView(data.buffer);\n\n // For each Gop..\n for (h = 0; h < gops.length; h++) {\n currentGop = gops[h];\n\n // For each Frame..\n for (i = 0; i < currentGop.length; i++) {\n currentFrame = currentGop[i];\n\n // For each NAL..\n for (j = 0; j < currentFrame.length; j++) {\n currentNal = currentFrame[j];\n\n view.setUint32(dataOffset, currentNal.data.byteLength);\n dataOffset += 4;\n data.set(currentNal.data, dataOffset);\n dataOffset += currentNal.data.byteLength;\n }\n }\n }\n return data;\n};\n\nmodule.exports = {\n groupNalsIntoFrames: groupNalsIntoFrames,\n groupFramesIntoGops: groupFramesIntoGops,\n extendFirstKeyFrame: extendFirstKeyFrame,\n generateSampleTable: generateSampleTable,\n concatenateNalData: concatenateNalData\n};\n","var coneOfSilence = require('../data/silence');\nvar clock = require('../utils/clock');\n\nvar ONE_SECOND_IN_TS = 90000; // 90kHz clock\n\n/**\n * Sum the `byteLength` properties of the data in each AAC frame\n */\nvar sumFrameByteLengths = function(array) {\n var\n i,\n currentObj,\n sum = 0;\n\n // sum the byteLength's all each nal unit in the frame\n for (i = 0; i < array.length; i++) {\n currentObj = array[i];\n sum += currentObj.data.byteLength;\n }\n\n return sum;\n};\n\n// Possibly pad (prefix) the audio track with silence if appending this track\n// would lead to the introduction of a gap in the audio buffer\nvar prefixWithSilence = function(\n track,\n frames,\n audioAppendStartTs,\n videoBaseMediaDecodeTime\n) {\n var\n baseMediaDecodeTimeTs,\n frameDuration = 0,\n audioGapDuration = 0,\n audioFillFrameCount = 0,\n audioFillDuration = 0,\n silentFrame,\n i;\n\n if (!frames.length) {\n return;\n }\n\n baseMediaDecodeTimeTs =\n clock.audioTsToVideoTs(track.baseMediaDecodeTime, track.samplerate);\n // determine frame clock duration based on sample rate, round up to avoid overfills\n frameDuration = Math.ceil(ONE_SECOND_IN_TS / (track.samplerate / 1024));\n\n if (audioAppendStartTs && videoBaseMediaDecodeTime) {\n // insert the shortest possible amount (audio gap or audio to video gap)\n audioGapDuration =\n baseMediaDecodeTimeTs - Math.max(audioAppendStartTs, videoBaseMediaDecodeTime);\n // number of full frames in the audio gap\n audioFillFrameCount = Math.floor(audioGapDuration / frameDuration);\n audioFillDuration = audioFillFrameCount * frameDuration;\n }\n\n // don't attempt to fill gaps smaller than a single frame or larger\n // than a half second\n if (audioFillFrameCount < 1 || audioFillDuration > ONE_SECOND_IN_TS / 2) {\n return;\n }\n\n silentFrame = coneOfSilence[track.samplerate];\n\n if (!silentFrame) {\n // we don't have a silent frame pregenerated for the sample rate, so use a frame\n // from the content instead\n silentFrame = frames[0].data;\n }\n\n for (i = 0; i < audioFillFrameCount; i++) {\n frames.splice(i, 0, {\n data: silentFrame\n });\n }\n\n track.baseMediaDecodeTime -=\n Math.floor(clock.videoTsToAudioTs(audioFillDuration, track.samplerate));\n};\n\n// If the audio segment extends before the earliest allowed dts\n// value, remove AAC frames until starts at or after the earliest\n// allowed DTS so that we don't end up with a negative baseMedia-\n// DecodeTime for the audio track\nvar trimAdtsFramesByEarliestDts = function(adtsFrames, track, earliestAllowedDts) {\n if (track.minSegmentDts >= earliestAllowedDts) {\n return adtsFrames;\n }\n\n // We will need to recalculate the earliest segment Dts\n track.minSegmentDts = Infinity;\n\n return adtsFrames.filter(function(currentFrame) {\n // If this is an allowed frame, keep it and record it's Dts\n if (currentFrame.dts >= earliestAllowedDts) {\n track.minSegmentDts = Math.min(track.minSegmentDts, currentFrame.dts);\n track.minSegmentPts = track.minSegmentDts;\n return true;\n }\n // Otherwise, discard it\n return false;\n });\n};\n\n// generate the track's raw mdat data from an array of frames\nvar generateSampleTable = function(frames) {\n var\n i,\n currentFrame,\n samples = [];\n\n for (i = 0; i < frames.length; i++) {\n currentFrame = frames[i];\n samples.push({\n size: currentFrame.data.byteLength,\n duration: 1024 // For AAC audio, all samples contain 1024 samples\n });\n }\n return samples;\n};\n\n// generate the track's sample table from an array of frames\nvar concatenateFrameData = function(frames) {\n var\n i,\n currentFrame,\n dataOffset = 0,\n data = new Uint8Array(sumFrameByteLengths(frames));\n\n for (i = 0; i < frames.length; i++) {\n currentFrame = frames[i];\n\n data.set(currentFrame.data, dataOffset);\n dataOffset += currentFrame.data.byteLength;\n }\n return data;\n};\n\nmodule.exports = {\n prefixWithSilence: prefixWithSilence,\n trimAdtsFramesByEarliestDts: trimAdtsFramesByEarliestDts,\n generateSampleTable: generateSampleTable,\n concatenateFrameData: concatenateFrameData\n};\n","var highPrefix = [33, 16, 5, 32, 164, 27];\nvar lowPrefix = [33, 65, 108, 84, 1, 2, 4, 8, 168, 2, 4, 8, 17, 191, 252];\nvar zeroFill = function(count) {\n var a = [];\n while (count--) {\n a.push(0);\n }\n return a;\n};\n\nvar makeTable = function(metaTable) {\n return Object.keys(metaTable).reduce(function(obj, key) {\n obj[key] = new Uint8Array(metaTable[key].reduce(function(arr, part) {\n return arr.concat(part);\n }, []));\n return obj;\n }, {});\n};\n\n// Frames-of-silence to use for filling in missing AAC frames\nvar coneOfSilence = {\n 96000: [highPrefix, [227, 64], zeroFill(154), [56]],\n 88200: [highPrefix, [231], zeroFill(170), [56]],\n 64000: [highPrefix, [248, 192], zeroFill(240), [56]],\n 48000: [highPrefix, [255, 192], zeroFill(268), [55, 148, 128], zeroFill(54), [112]],\n 44100: [highPrefix, [255, 192], zeroFill(268), [55, 163, 128], zeroFill(84), [112]],\n 32000: [highPrefix, [255, 192], zeroFill(268), [55, 234], zeroFill(226), [112]],\n 24000: [highPrefix, [255, 192], zeroFill(268), [55, 255, 128], zeroFill(268), [111, 112], zeroFill(126), [224]],\n 16000: [highPrefix, [255, 192], zeroFill(268), [55, 255, 128], zeroFill(268), [111, 255], zeroFill(269), [223, 108], zeroFill(195), [1, 192]],\n 12000: [lowPrefix, zeroFill(268), [3, 127, 248], zeroFill(268), [6, 255, 240], zeroFill(268), [13, 255, 224], zeroFill(268), [27, 253, 128], zeroFill(259), [56]],\n 11025: [lowPrefix, zeroFill(268), [3, 127, 248], zeroFill(268), [6, 255, 240], zeroFill(268), [13, 255, 224], zeroFill(268), [27, 255, 192], zeroFill(268), [55, 175, 128], zeroFill(108), [112]],\n 8000: [lowPrefix, zeroFill(268), [3, 121, 16], zeroFill(47), [7]]\n};\n\nmodule.exports = makeTable(coneOfSilence);\n","var\n ONE_SECOND_IN_TS = 90000, // 90kHz clock\n secondsToVideoTs,\n secondsToAudioTs,\n videoTsToSeconds,\n audioTsToSeconds,\n audioTsToVideoTs,\n videoTsToAudioTs;\n\nsecondsToVideoTs = function(seconds) {\n return seconds * ONE_SECOND_IN_TS;\n};\n\nsecondsToAudioTs = function(seconds, sampleRate) {\n return seconds * sampleRate;\n};\n\nvideoTsToSeconds = function(timestamp) {\n return timestamp / ONE_SECOND_IN_TS;\n};\n\naudioTsToSeconds = function(timestamp, sampleRate) {\n return timestamp / sampleRate;\n};\n\naudioTsToVideoTs = function(timestamp, sampleRate) {\n return secondsToVideoTs(audioTsToSeconds(timestamp, sampleRate));\n};\n\nvideoTsToAudioTs = function(timestamp, sampleRate) {\n return secondsToAudioTs(videoTsToSeconds(timestamp), sampleRate);\n};\n\nmodule.exports = {\n secondsToVideoTs: secondsToVideoTs,\n secondsToAudioTs: secondsToAudioTs,\n videoTsToSeconds: videoTsToSeconds,\n audioTsToSeconds: audioTsToSeconds,\n audioTsToVideoTs: audioTsToVideoTs,\n videoTsToAudioTs: videoTsToAudioTs\n};\n","var ONE_SECOND_IN_TS = 90000; // 90kHz clock\n\n/**\n * Store information about the start and end of the track and the\n * duration for each frame/sample we process in order to calculate\n * the baseMediaDecodeTime\n */\nvar collectDtsInfo = function(track, data) {\n if (typeof data.pts === 'number') {\n if (track.timelineStartInfo.pts === undefined) {\n track.timelineStartInfo.pts = data.pts;\n }\n\n if (track.minSegmentPts === undefined) {\n track.minSegmentPts = data.pts;\n } else {\n track.minSegmentPts = Math.min(track.minSegmentPts, data.pts);\n }\n\n if (track.maxSegmentPts === undefined) {\n track.maxSegmentPts = data.pts;\n } else {\n track.maxSegmentPts = Math.max(track.maxSegmentPts, data.pts);\n }\n }\n\n if (typeof data.dts === 'number') {\n if (track.timelineStartInfo.dts === undefined) {\n track.timelineStartInfo.dts = data.dts;\n }\n\n if (track.minSegmentDts === undefined) {\n track.minSegmentDts = data.dts;\n } else {\n track.minSegmentDts = Math.min(track.minSegmentDts, data.dts);\n }\n\n if (track.maxSegmentDts === undefined) {\n track.maxSegmentDts = data.dts;\n } else {\n track.maxSegmentDts = Math.max(track.maxSegmentDts, data.dts);\n }\n }\n};\n\n/**\n * Clear values used to calculate the baseMediaDecodeTime between\n * tracks\n */\nvar clearDtsInfo = function(track) {\n delete track.minSegmentDts;\n delete track.maxSegmentDts;\n delete track.minSegmentPts;\n delete track.maxSegmentPts;\n};\n\n/**\n * Calculate the track's baseMediaDecodeTime based on the earliest\n * DTS the transmuxer has ever seen and the minimum DTS for the\n * current track\n * @param track {object} track metadata configuration\n * @param keepOriginalTimestamps {boolean} If true, keep the timestamps\n * in the source; false to adjust the first segment to start at 0.\n */\nvar calculateTrackBaseMediaDecodeTime = function(track, keepOriginalTimestamps) {\n var\n baseMediaDecodeTime,\n scale,\n minSegmentDts = track.minSegmentDts;\n\n // Optionally adjust the time so the first segment starts at zero.\n if (!keepOriginalTimestamps) {\n minSegmentDts -= track.timelineStartInfo.dts;\n }\n\n // track.timelineStartInfo.baseMediaDecodeTime is the location, in time, where\n // we want the start of the first segment to be placed\n baseMediaDecodeTime = track.timelineStartInfo.baseMediaDecodeTime;\n\n // Add to that the distance this segment is from the very first\n baseMediaDecodeTime += minSegmentDts;\n\n // baseMediaDecodeTime must not become negative\n baseMediaDecodeTime = Math.max(0, baseMediaDecodeTime);\n\n if (track.type === 'audio') {\n // Audio has a different clock equal to the sampling_rate so we need to\n // scale the PTS values into the clock rate of the track\n scale = track.samplerate / ONE_SECOND_IN_TS;\n baseMediaDecodeTime *= scale;\n baseMediaDecodeTime = Math.floor(baseMediaDecodeTime);\n }\n\n return baseMediaDecodeTime;\n};\n\nmodule.exports = {\n clearDtsInfo: clearDtsInfo,\n calculateTrackBaseMediaDecodeTime: calculateTrackBaseMediaDecodeTime,\n collectDtsInfo: collectDtsInfo\n};\n","/**\n * mux.js\n *\n * Copyright (c) 2015 Brightcove\n * All rights reserved.\n *\n * A stream-based mp2t to mp4 converter. This utility can be used to\n * deliver mp4s to a SourceBuffer on platforms that support native\n * Media Source Extensions.\n */\n'use strict';\nvar Stream = require('../utils/stream.js'),\n CaptionStream = require('./caption-stream'),\n StreamTypes = require('./stream-types'),\n TimestampRolloverStream = require('./timestamp-rollover-stream').TimestampRolloverStream;\n\nvar m2tsStreamTypes = require('./stream-types.js');\n\n// object types\nvar TransportPacketStream, TransportParseStream, ElementaryStream;\n\n// constants\nvar\n MP2T_PACKET_LENGTH = 188, // bytes\n SYNC_BYTE = 0x47;\n\n/**\n * Splits an incoming stream of binary data into MPEG-2 Transport\n * Stream packets.\n */\nTransportPacketStream = function() {\n var\n buffer = new Uint8Array(MP2T_PACKET_LENGTH),\n bytesInBuffer = 0;\n\n TransportPacketStream.prototype.init.call(this);\n\n // Deliver new bytes to the stream.\n\n /**\n * Split a stream of data into M2TS packets\n **/\n this.push = function(bytes) {\n var\n startIndex = 0,\n endIndex = MP2T_PACKET_LENGTH,\n everything;\n\n // If there are bytes remaining from the last segment, prepend them to the\n // bytes that were pushed in\n if (bytesInBuffer) {\n everything = new Uint8Array(bytes.byteLength + bytesInBuffer);\n everything.set(buffer.subarray(0, bytesInBuffer));\n everything.set(bytes, bytesInBuffer);\n bytesInBuffer = 0;\n } else {\n everything = bytes;\n }\n\n // While we have enough data for a packet\n while (endIndex < everything.byteLength) {\n // Look for a pair of start and end sync bytes in the data..\n if (everything[startIndex] === SYNC_BYTE && everything[endIndex] === SYNC_BYTE) {\n // We found a packet so emit it and jump one whole packet forward in\n // the stream\n this.trigger('data', everything.subarray(startIndex, endIndex));\n startIndex += MP2T_PACKET_LENGTH;\n endIndex += MP2T_PACKET_LENGTH;\n continue;\n }\n // If we get here, we have somehow become de-synchronized and we need to step\n // forward one byte at a time until we find a pair of sync bytes that denote\n // a packet\n startIndex++;\n endIndex++;\n }\n\n // If there was some data left over at the end of the segment that couldn't\n // possibly be a whole packet, keep it because it might be the start of a packet\n // that continues in the next segment\n if (startIndex < everything.byteLength) {\n buffer.set(everything.subarray(startIndex), 0);\n bytesInBuffer = everything.byteLength - startIndex;\n }\n };\n\n /**\n * Passes identified M2TS packets to the TransportParseStream to be parsed\n **/\n this.flush = function() {\n // If the buffer contains a whole packet when we are being flushed, emit it\n // and empty the buffer. Otherwise hold onto the data because it may be\n // important for decoding the next segment\n if (bytesInBuffer === MP2T_PACKET_LENGTH && buffer[0] === SYNC_BYTE) {\n this.trigger('data', buffer);\n bytesInBuffer = 0;\n }\n this.trigger('done');\n };\n};\nTransportPacketStream.prototype = new Stream();\n\n/**\n * Accepts an MP2T TransportPacketStream and emits data events with parsed\n * forms of the individual transport stream packets.\n */\nTransportParseStream = function() {\n var parsePsi, parsePat, parsePmt, self;\n TransportParseStream.prototype.init.call(this);\n self = this;\n\n this.packetsWaitingForPmt = [];\n this.programMapTable = undefined;\n\n parsePsi = function(payload, psi) {\n var offset = 0;\n\n // PSI packets may be split into multiple sections and those\n // sections may be split into multiple packets. If a PSI\n // section starts in this packet, the payload_unit_start_indicator\n // will be true and the first byte of the payload will indicate\n // the offset from the current position to the start of the\n // section.\n if (psi.payloadUnitStartIndicator) {\n offset += payload[offset] + 1;\n }\n\n if (psi.type === 'pat') {\n parsePat(payload.subarray(offset), psi);\n } else {\n parsePmt(payload.subarray(offset), psi);\n }\n };\n\n parsePat = function(payload, pat) {\n pat.section_number = payload[7]; // eslint-disable-line camelcase\n pat.last_section_number = payload[8]; // eslint-disable-line camelcase\n\n // skip the PSI header and parse the first PMT entry\n self.pmtPid = (payload[10] & 0x1F) << 8 | payload[11];\n pat.pmtPid = self.pmtPid;\n };\n\n /**\n * Parse out the relevant fields of a Program Map Table (PMT).\n * @param payload {Uint8Array} the PMT-specific portion of an MP2T\n * packet. The first byte in this array should be the table_id\n * field.\n * @param pmt {object} the object that should be decorated with\n * fields parsed from the PMT.\n */\n parsePmt = function(payload, pmt) {\n var sectionLength, tableEnd, programInfoLength, offset;\n\n // PMTs can be sent ahead of the time when they should actually\n // take effect. We don't believe this should ever be the case\n // for HLS but we'll ignore \"forward\" PMT declarations if we see\n // them. Future PMT declarations have the current_next_indicator\n // set to zero.\n if (!(payload[5] & 0x01)) {\n return;\n }\n\n // overwrite any existing program map table\n self.programMapTable = {\n video: null,\n audio: null,\n 'timed-metadata': {}\n };\n\n // the mapping table ends at the end of the current section\n sectionLength = (payload[1] & 0x0f) << 8 | payload[2];\n tableEnd = 3 + sectionLength - 4;\n\n // to determine where the table is, we have to figure out how\n // long the program info descriptors are\n programInfoLength = (payload[10] & 0x0f) << 8 | payload[11];\n\n // advance the offset to the first entry in the mapping table\n offset = 12 + programInfoLength;\n while (offset < tableEnd) {\n var streamType = payload[offset];\n var pid = (payload[offset + 1] & 0x1F) << 8 | payload[offset + 2];\n\n // only map a single elementary_pid for audio and video stream types\n // TODO: should this be done for metadata too? for now maintain behavior of\n // multiple metadata streams\n if (streamType === StreamTypes.H264_STREAM_TYPE &&\n self.programMapTable.video === null) {\n self.programMapTable.video = pid;\n } else if (streamType === StreamTypes.ADTS_STREAM_TYPE &&\n self.programMapTable.audio === null) {\n self.programMapTable.audio = pid;\n } else if (streamType === StreamTypes.METADATA_STREAM_TYPE) {\n // map pid to stream type for metadata streams\n self.programMapTable['timed-metadata'][pid] = streamType;\n }\n\n // move to the next table entry\n // skip past the elementary stream descriptors, if present\n offset += ((payload[offset + 3] & 0x0F) << 8 | payload[offset + 4]) + 5;\n }\n\n // record the map on the packet as well\n pmt.programMapTable = self.programMapTable;\n };\n\n /**\n * Deliver a new MP2T packet to the next stream in the pipeline.\n */\n this.push = function(packet) {\n var\n result = {},\n offset = 4;\n\n result.payloadUnitStartIndicator = !!(packet[1] & 0x40);\n\n // pid is a 13-bit field starting at the last bit of packet[1]\n result.pid = packet[1] & 0x1f;\n result.pid <<= 8;\n result.pid |= packet[2];\n\n // if an adaption field is present, its length is specified by the\n // fifth byte of the TS packet header. The adaptation field is\n // used to add stuffing to PES packets that don't fill a complete\n // TS packet, and to specify some forms of timing and control data\n // that we do not currently use.\n if (((packet[3] & 0x30) >>> 4) > 0x01) {\n offset += packet[offset] + 1;\n }\n\n // parse the rest of the packet based on the type\n if (result.pid === 0) {\n result.type = 'pat';\n parsePsi(packet.subarray(offset), result);\n this.trigger('data', result);\n } else if (result.pid === this.pmtPid) {\n result.type = 'pmt';\n parsePsi(packet.subarray(offset), result);\n this.trigger('data', result);\n\n // if there are any packets waiting for a PMT to be found, process them now\n while (this.packetsWaitingForPmt.length) {\n this.processPes_.apply(this, this.packetsWaitingForPmt.shift());\n }\n } else if (this.programMapTable === undefined) {\n // When we have not seen a PMT yet, defer further processing of\n // PES packets until one has been parsed\n this.packetsWaitingForPmt.push([packet, offset, result]);\n } else {\n this.processPes_(packet, offset, result);\n }\n };\n\n this.processPes_ = function(packet, offset, result) {\n // set the appropriate stream type\n if (result.pid === this.programMapTable.video) {\n result.streamType = StreamTypes.H264_STREAM_TYPE;\n } else if (result.pid === this.programMapTable.audio) {\n result.streamType = StreamTypes.ADTS_STREAM_TYPE;\n } else {\n // if not video or audio, it is timed-metadata or unknown\n // if unknown, streamType will be undefined\n result.streamType = this.programMapTable['timed-metadata'][result.pid];\n }\n\n result.type = 'pes';\n result.data = packet.subarray(offset);\n\n this.trigger('data', result);\n };\n\n};\nTransportParseStream.prototype = new Stream();\nTransportParseStream.STREAM_TYPES = {\n h264: 0x1b,\n adts: 0x0f\n};\n\n/**\n * Reconsistutes program elementary stream (PES) packets from parsed\n * transport stream packets. That is, if you pipe an\n * mp2t.TransportParseStream into a mp2t.ElementaryStream, the output\n * events will be events which capture the bytes for individual PES\n * packets plus relevant metadata that has been extracted from the\n * container.\n */\nElementaryStream = function() {\n var\n self = this,\n // PES packet fragments\n video = {\n data: [],\n size: 0\n },\n audio = {\n data: [],\n size: 0\n },\n timedMetadata = {\n data: [],\n size: 0\n },\n parsePes = function(payload, pes) {\n var ptsDtsFlags;\n\n // get the packet length, this will be 0 for video\n pes.packetLength = 6 + ((payload[4] << 8) | payload[5]);\n\n // find out if this packets starts a new keyframe\n pes.dataAlignmentIndicator = (payload[6] & 0x04) !== 0;\n // PES packets may be annotated with a PTS value, or a PTS value\n // and a DTS value. Determine what combination of values is\n // available to work with.\n ptsDtsFlags = payload[7];\n\n // PTS and DTS are normally stored as a 33-bit number. Javascript\n // performs all bitwise operations on 32-bit integers but javascript\n // supports a much greater range (52-bits) of integer using standard\n // mathematical operations.\n // We construct a 31-bit value using bitwise operators over the 31\n // most significant bits and then multiply by 4 (equal to a left-shift\n // of 2) before we add the final 2 least significant bits of the\n // timestamp (equal to an OR.)\n if (ptsDtsFlags & 0xC0) {\n // the PTS and DTS are not written out directly. For information\n // on how they are encoded, see\n // http://dvd.sourceforge.net/dvdinfo/pes-hdr.html\n pes.pts = (payload[9] & 0x0E) << 27 |\n (payload[10] & 0xFF) << 20 |\n (payload[11] & 0xFE) << 12 |\n (payload[12] & 0xFF) << 5 |\n (payload[13] & 0xFE) >>> 3;\n pes.pts *= 4; // Left shift by 2\n pes.pts += (payload[13] & 0x06) >>> 1; // OR by the two LSBs\n pes.dts = pes.pts;\n if (ptsDtsFlags & 0x40) {\n pes.dts = (payload[14] & 0x0E) << 27 |\n (payload[15] & 0xFF) << 20 |\n (payload[16] & 0xFE) << 12 |\n (payload[17] & 0xFF) << 5 |\n (payload[18] & 0xFE) >>> 3;\n pes.dts *= 4; // Left shift by 2\n pes.dts += (payload[18] & 0x06) >>> 1; // OR by the two LSBs\n }\n }\n // the data section starts immediately after the PES header.\n // pes_header_data_length specifies the number of header bytes\n // that follow the last byte of the field.\n pes.data = payload.subarray(9 + payload[8]);\n },\n /**\n * Pass completely parsed PES packets to the next stream in the pipeline\n **/\n flushStream = function(stream, type, forceFlush) {\n var\n packetData = new Uint8Array(stream.size),\n event = {\n type: type\n },\n i = 0,\n offset = 0,\n packetFlushable = false,\n fragment;\n\n // do nothing if there is not enough buffered data for a complete\n // PES header\n if (!stream.data.length || stream.size < 9) {\n return;\n }\n event.trackId = stream.data[0].pid;\n\n // reassemble the packet\n for (i = 0; i < stream.data.length; i++) {\n fragment = stream.data[i];\n\n packetData.set(fragment.data, offset);\n offset += fragment.data.byteLength;\n }\n\n // parse assembled packet's PES header\n parsePes(packetData, event);\n\n // non-video PES packets MUST have a non-zero PES_packet_length\n // check that there is enough stream data to fill the packet\n packetFlushable = type === 'video' || event.packetLength <= stream.size;\n\n // flush pending packets if the conditions are right\n if (forceFlush || packetFlushable) {\n stream.size = 0;\n stream.data.length = 0;\n }\n\n // only emit packets that are complete. this is to avoid assembling\n // incomplete PES packets due to poor segmentation\n if (packetFlushable) {\n self.trigger('data', event);\n }\n };\n\n ElementaryStream.prototype.init.call(this);\n\n /**\n * Identifies M2TS packet types and parses PES packets using metadata\n * parsed from the PMT\n **/\n this.push = function(data) {\n ({\n pat: function() {\n // we have to wait for the PMT to arrive as well before we\n // have any meaningful metadata\n },\n pes: function() {\n var stream, streamType;\n\n switch (data.streamType) {\n case StreamTypes.H264_STREAM_TYPE:\n case m2tsStreamTypes.H264_STREAM_TYPE:\n stream = video;\n streamType = 'video';\n break;\n case StreamTypes.ADTS_STREAM_TYPE:\n stream = audio;\n streamType = 'audio';\n break;\n case StreamTypes.METADATA_STREAM_TYPE:\n stream = timedMetadata;\n streamType = 'timed-metadata';\n break;\n default:\n // ignore unknown stream types\n return;\n }\n\n // if a new packet is starting, we can flush the completed\n // packet\n if (data.payloadUnitStartIndicator) {\n flushStream(stream, streamType, true);\n }\n\n // buffer this fragment until we are sure we've received the\n // complete payload\n stream.data.push(data);\n stream.size += data.data.byteLength;\n },\n pmt: function() {\n var\n event = {\n type: 'metadata',\n tracks: []\n },\n programMapTable = data.programMapTable;\n\n // translate audio and video streams to tracks\n if (programMapTable.video !== null) {\n event.tracks.push({\n timelineStartInfo: {\n baseMediaDecodeTime: 0\n },\n id: +programMapTable.video,\n codec: 'avc',\n type: 'video'\n });\n }\n if (programMapTable.audio !== null) {\n event.tracks.push({\n timelineStartInfo: {\n baseMediaDecodeTime: 0\n },\n id: +programMapTable.audio,\n codec: 'adts',\n type: 'audio'\n });\n }\n\n self.trigger('data', event);\n }\n })[data.type]();\n };\n\n /**\n * Flush any remaining input. Video PES packets may be of variable\n * length. Normally, the start of a new video packet can trigger the\n * finalization of the previous packet. That is not possible if no\n * more video is forthcoming, however. In that case, some other\n * mechanism (like the end of the file) has to be employed. When it is\n * clear that no additional data is forthcoming, calling this method\n * will flush the buffered packets.\n */\n this.flush = function() {\n // !!THIS ORDER IS IMPORTANT!!\n // video first then audio\n flushStream(video, 'video');\n flushStream(audio, 'audio');\n flushStream(timedMetadata, 'timed-metadata');\n this.trigger('done');\n };\n};\nElementaryStream.prototype = new Stream();\n\nvar m2ts = {\n PAT_PID: 0x0000,\n MP2T_PACKET_LENGTH: MP2T_PACKET_LENGTH,\n TransportPacketStream: TransportPacketStream,\n TransportParseStream: TransportParseStream,\n ElementaryStream: ElementaryStream,\n TimestampRolloverStream: TimestampRolloverStream,\n CaptionStream: CaptionStream.CaptionStream,\n Cea608Stream: CaptionStream.Cea608Stream,\n MetadataStream: require('./metadata-stream')\n};\n\nfor (var type in StreamTypes) {\n if (StreamTypes.hasOwnProperty(type)) {\n m2ts[type] = StreamTypes[type];\n }\n}\n\nmodule.exports = m2ts;\n","/**\n * Accepts program elementary stream (PES) data events and parses out\n * ID3 metadata from them, if present.\n * @see http://id3.org/id3v2.3.0\n */\n'use strict';\nvar\n Stream = require('../utils/stream'),\n StreamTypes = require('./stream-types'),\n // return a percent-encoded representation of the specified byte range\n // @see http://en.wikipedia.org/wiki/Percent-encoding\n percentEncode = function(bytes, start, end) {\n var i, result = '';\n for (i = start; i < end; i++) {\n result += '%' + ('00' + bytes[i].toString(16)).slice(-2);\n }\n return result;\n },\n // return the string representation of the specified byte range,\n // interpreted as UTf-8.\n parseUtf8 = function(bytes, start, end) {\n return decodeURIComponent(percentEncode(bytes, start, end));\n },\n // return the string representation of the specified byte range,\n // interpreted as ISO-8859-1.\n parseIso88591 = function(bytes, start, end) {\n return unescape(percentEncode(bytes, start, end)); // jshint ignore:line\n },\n parseSyncSafeInteger = function(data) {\n return (data[0] << 21) |\n (data[1] << 14) |\n (data[2] << 7) |\n (data[3]);\n },\n tagParsers = {\n TXXX: function(tag) {\n var i;\n if (tag.data[0] !== 3) {\n // ignore frames with unrecognized character encodings\n return;\n }\n\n for (i = 1; i < tag.data.length; i++) {\n if (tag.data[i] === 0) {\n // parse the text fields\n tag.description = parseUtf8(tag.data, 1, i);\n // do not include the null terminator in the tag value\n tag.value = parseUtf8(tag.data, i + 1, tag.data.length).replace(/\\0*$/, '');\n break;\n }\n }\n tag.data = tag.value;\n },\n WXXX: function(tag) {\n var i;\n if (tag.data[0] !== 3) {\n // ignore frames with unrecognized character encodings\n return;\n }\n\n for (i = 1; i < tag.data.length; i++) {\n if (tag.data[i] === 0) {\n // parse the description and URL fields\n tag.description = parseUtf8(tag.data, 1, i);\n tag.url = parseUtf8(tag.data, i + 1, tag.data.length);\n break;\n }\n }\n },\n PRIV: function(tag) {\n var i;\n\n for (i = 0; i < tag.data.length; i++) {\n if (tag.data[i] === 0) {\n // parse the description and URL fields\n tag.owner = parseIso88591(tag.data, 0, i);\n break;\n }\n }\n tag.privateData = tag.data.subarray(i + 1);\n tag.data = tag.privateData;\n }\n },\n MetadataStream;\n\nMetadataStream = function(options) {\n var\n settings = {\n debug: !!(options && options.debug),\n\n // the bytes of the program-level descriptor field in MP2T\n // see ISO/IEC 13818-1:2013 (E), section 2.6 \"Program and\n // program element descriptors\"\n descriptor: options && options.descriptor\n },\n // the total size in bytes of the ID3 tag being parsed\n tagSize = 0,\n // tag data that is not complete enough to be parsed\n buffer = [],\n // the total number of bytes currently in the buffer\n bufferSize = 0,\n i;\n\n MetadataStream.prototype.init.call(this);\n\n // calculate the text track in-band metadata track dispatch type\n // https://html.spec.whatwg.org/multipage/embedded-content.html#steps-to-expose-a-media-resource-specific-text-track\n this.dispatchType = StreamTypes.METADATA_STREAM_TYPE.toString(16);\n if (settings.descriptor) {\n for (i = 0; i < settings.descriptor.length; i++) {\n this.dispatchType += ('00' + settings.descriptor[i].toString(16)).slice(-2);\n }\n }\n\n this.push = function(chunk) {\n var tag, frameStart, frameSize, frame, i, frameHeader;\n if (chunk.type !== 'timed-metadata') {\n return;\n }\n\n // if data_alignment_indicator is set in the PES header,\n // we must have the start of a new ID3 tag. Assume anything\n // remaining in the buffer was malformed and throw it out\n if (chunk.dataAlignmentIndicator) {\n bufferSize = 0;\n buffer.length = 0;\n }\n\n // ignore events that don't look like ID3 data\n if (buffer.length === 0 &&\n (chunk.data.length < 10 ||\n chunk.data[0] !== 'I'.charCodeAt(0) ||\n chunk.data[1] !== 'D'.charCodeAt(0) ||\n chunk.data[2] !== '3'.charCodeAt(0))) {\n if (settings.debug) {\n // eslint-disable-next-line no-console\n console.log('Skipping unrecognized metadata packet');\n }\n return;\n }\n\n // add this chunk to the data we've collected so far\n\n buffer.push(chunk);\n bufferSize += chunk.data.byteLength;\n\n // grab the size of the entire frame from the ID3 header\n if (buffer.length === 1) {\n // the frame size is transmitted as a 28-bit integer in the\n // last four bytes of the ID3 header.\n // The most significant bit of each byte is dropped and the\n // results concatenated to recover the actual value.\n tagSize = parseSyncSafeInteger(chunk.data.subarray(6, 10));\n\n // ID3 reports the tag size excluding the header but it's more\n // convenient for our comparisons to include it\n tagSize += 10;\n }\n\n // if the entire frame has not arrived, wait for more data\n if (bufferSize < tagSize) {\n return;\n }\n\n // collect the entire frame so it can be parsed\n tag = {\n data: new Uint8Array(tagSize),\n frames: [],\n pts: buffer[0].pts,\n dts: buffer[0].dts\n };\n for (i = 0; i < tagSize;) {\n tag.data.set(buffer[0].data.subarray(0, tagSize - i), i);\n i += buffer[0].data.byteLength;\n bufferSize -= buffer[0].data.byteLength;\n buffer.shift();\n }\n\n // find the start of the first frame and the end of the tag\n frameStart = 10;\n if (tag.data[5] & 0x40) {\n // advance the frame start past the extended header\n frameStart += 4; // header size field\n frameStart += parseSyncSafeInteger(tag.data.subarray(10, 14));\n\n // clip any padding off the end\n tagSize -= parseSyncSafeInteger(tag.data.subarray(16, 20));\n }\n\n // parse one or more ID3 frames\n // http://id3.org/id3v2.3.0#ID3v2_frame_overview\n do {\n // determine the number of bytes in this frame\n frameSize = parseSyncSafeInteger(tag.data.subarray(frameStart + 4, frameStart + 8));\n if (frameSize < 1) {\n // eslint-disable-next-line no-console\n return console.log('Malformed ID3 frame encountered. Skipping metadata parsing.');\n }\n frameHeader = String.fromCharCode(tag.data[frameStart],\n tag.data[frameStart + 1],\n tag.data[frameStart + 2],\n tag.data[frameStart + 3]);\n\n\n frame = {\n id: frameHeader,\n data: tag.data.subarray(frameStart + 10, frameStart + frameSize + 10)\n };\n frame.key = frame.id;\n if (tagParsers[frame.id]) {\n tagParsers[frame.id](frame);\n\n // handle the special PRIV frame used to indicate the start\n // time for raw AAC data\n if (frame.owner === 'com.apple.streaming.transportStreamTimestamp') {\n var\n d = frame.data,\n size = ((d[3] & 0x01) << 30) |\n (d[4] << 22) |\n (d[5] << 14) |\n (d[6] << 6) |\n (d[7] >>> 2);\n\n size *= 4;\n size += d[7] & 0x03;\n frame.timeStamp = size;\n // in raw AAC, all subsequent data will be timestamped based\n // on the value of this frame\n // we couldn't have known the appropriate pts and dts before\n // parsing this ID3 tag so set those values now\n if (tag.pts === undefined && tag.dts === undefined) {\n tag.pts = frame.timeStamp;\n tag.dts = frame.timeStamp;\n }\n this.trigger('timestamp', frame);\n }\n }\n tag.frames.push(frame);\n\n frameStart += 10; // advance past the frame header\n frameStart += frameSize; // advance past the frame body\n } while (frameStart < tagSize);\n this.trigger('data', tag);\n };\n};\nMetadataStream.prototype = new Stream();\n\nmodule.exports = MetadataStream;\n","'use strict';\n\nvar Stream = require('../utils/stream.js');\n\nvar AdtsStream;\n\nvar\n ADTS_SAMPLING_FREQUENCIES = [\n 96000,\n 88200,\n 64000,\n 48000,\n 44100,\n 32000,\n 24000,\n 22050,\n 16000,\n 12000,\n 11025,\n 8000,\n 7350\n ];\n\n/*\n * Accepts a ElementaryStream and emits data events with parsed\n * AAC Audio Frames of the individual packets. Input audio in ADTS\n * format is unpacked and re-emitted as AAC frames.\n *\n * @see http://wiki.multimedia.cx/index.php?title=ADTS\n * @see http://wiki.multimedia.cx/?title=Understanding_AAC\n */\nAdtsStream = function() {\n var buffer;\n\n AdtsStream.prototype.init.call(this);\n\n this.push = function(packet) {\n var\n i = 0,\n frameNum = 0,\n frameLength,\n protectionSkipBytes,\n frameEnd,\n oldBuffer,\n sampleCount,\n adtsFrameDuration;\n\n if (packet.type !== 'audio') {\n // ignore non-audio data\n return;\n }\n\n // Prepend any data in the buffer to the input data so that we can parse\n // aac frames the cross a PES packet boundary\n if (buffer) {\n oldBuffer = buffer;\n buffer = new Uint8Array(oldBuffer.byteLength + packet.data.byteLength);\n buffer.set(oldBuffer);\n buffer.set(packet.data, oldBuffer.byteLength);\n } else {\n buffer = packet.data;\n }\n\n // unpack any ADTS frames which have been fully received\n // for details on the ADTS header, see http://wiki.multimedia.cx/index.php?title=ADTS\n while (i + 5 < buffer.length) {\n\n // Loook for the start of an ADTS header..\n if (buffer[i] !== 0xFF || (buffer[i + 1] & 0xF6) !== 0xF0) {\n // If a valid header was not found, jump one forward and attempt to\n // find a valid ADTS header starting at the next byte\n i++;\n continue;\n }\n\n // The protection skip bit tells us if we have 2 bytes of CRC data at the\n // end of the ADTS header\n protectionSkipBytes = (~buffer[i + 1] & 0x01) * 2;\n\n // Frame length is a 13 bit integer starting 16 bits from the\n // end of the sync sequence\n frameLength = ((buffer[i + 3] & 0x03) << 11) |\n (buffer[i + 4] << 3) |\n ((buffer[i + 5] & 0xe0) >> 5);\n\n sampleCount = ((buffer[i + 6] & 0x03) + 1) * 1024;\n adtsFrameDuration = (sampleCount * 90000) /\n ADTS_SAMPLING_FREQUENCIES[(buffer[i + 2] & 0x3c) >>> 2];\n\n frameEnd = i + frameLength;\n\n // If we don't have enough data to actually finish this ADTS frame, return\n // and wait for more data\n if (buffer.byteLength < frameEnd) {\n return;\n }\n\n // Otherwise, deliver the complete AAC frame\n this.trigger('data', {\n pts: packet.pts + (frameNum * adtsFrameDuration),\n dts: packet.dts + (frameNum * adtsFrameDuration),\n sampleCount: sampleCount,\n audioobjecttype: ((buffer[i + 2] >>> 6) & 0x03) + 1,\n channelcount: ((buffer[i + 2] & 1) << 2) |\n ((buffer[i + 3] & 0xc0) >>> 6),\n samplerate: ADTS_SAMPLING_FREQUENCIES[(buffer[i + 2] & 0x3c) >>> 2],\n samplingfrequencyindex: (buffer[i + 2] & 0x3c) >>> 2,\n // assume ISO/IEC 14496-12 AudioSampleEntry default of 16\n samplesize: 16,\n data: buffer.subarray(i + 7 + protectionSkipBytes, frameEnd)\n });\n\n // If the buffer is empty, clear it and return\n if (buffer.byteLength === frameEnd) {\n buffer = undefined;\n return;\n }\n\n frameNum++;\n\n // Remove the finished frame from the buffer and start the process again\n buffer = buffer.subarray(frameEnd);\n }\n };\n this.flush = function() {\n this.trigger('done');\n };\n};\n\nAdtsStream.prototype = new Stream();\n\nmodule.exports = AdtsStream;\n","'use strict';\n\nvar Stream = require('../utils/stream.js');\nvar ExpGolomb = require('../utils/exp-golomb.js');\n\nvar H264Stream, NalByteStream;\nvar PROFILES_WITH_OPTIONAL_SPS_DATA;\n\n/**\n * Accepts a NAL unit byte stream and unpacks the embedded NAL units.\n */\nNalByteStream = function() {\n var\n syncPoint = 0,\n i,\n buffer;\n NalByteStream.prototype.init.call(this);\n\n /*\n * Scans a byte stream and triggers a data event with the NAL units found.\n * @param {Object} data Event received from H264Stream\n * @param {Uint8Array} data.data The h264 byte stream to be scanned\n *\n * @see H264Stream.push\n */\n this.push = function(data) {\n var swapBuffer;\n\n if (!buffer) {\n buffer = data.data;\n } else {\n swapBuffer = new Uint8Array(buffer.byteLength + data.data.byteLength);\n swapBuffer.set(buffer);\n swapBuffer.set(data.data, buffer.byteLength);\n buffer = swapBuffer;\n }\n\n // Rec. ITU-T H.264, Annex B\n // scan for NAL unit boundaries\n\n // a match looks like this:\n // 0 0 1 .. NAL .. 0 0 1\n // ^ sync point ^ i\n // or this:\n // 0 0 1 .. NAL .. 0 0 0\n // ^ sync point ^ i\n\n // advance the sync point to a NAL start, if necessary\n for (; syncPoint < buffer.byteLength - 3; syncPoint++) {\n if (buffer[syncPoint + 2] === 1) {\n // the sync point is properly aligned\n i = syncPoint + 5;\n break;\n }\n }\n\n while (i < buffer.byteLength) {\n // look at the current byte to determine if we've hit the end of\n // a NAL unit boundary\n switch (buffer[i]) {\n case 0:\n // skip past non-sync sequences\n if (buffer[i - 1] !== 0) {\n i += 2;\n break;\n } else if (buffer[i - 2] !== 0) {\n i++;\n break;\n }\n\n // deliver the NAL unit if it isn't empty\n if (syncPoint + 3 !== i - 2) {\n this.trigger('data', buffer.subarray(syncPoint + 3, i - 2));\n }\n\n // drop trailing zeroes\n do {\n i++;\n } while (buffer[i] !== 1 && i < buffer.length);\n syncPoint = i - 2;\n i += 3;\n break;\n case 1:\n // skip past non-sync sequences\n if (buffer[i - 1] !== 0 ||\n buffer[i - 2] !== 0) {\n i += 3;\n break;\n }\n\n // deliver the NAL unit\n this.trigger('data', buffer.subarray(syncPoint + 3, i - 2));\n syncPoint = i - 2;\n i += 3;\n break;\n default:\n // the current byte isn't a one or zero, so it cannot be part\n // of a sync sequence\n i += 3;\n break;\n }\n }\n // filter out the NAL units that were delivered\n buffer = buffer.subarray(syncPoint);\n i -= syncPoint;\n syncPoint = 0;\n };\n\n this.flush = function() {\n // deliver the last buffered NAL unit\n if (buffer && buffer.byteLength > 3) {\n this.trigger('data', buffer.subarray(syncPoint + 3));\n }\n // reset the stream state\n buffer = null;\n syncPoint = 0;\n this.trigger('done');\n };\n};\nNalByteStream.prototype = new Stream();\n\n// values of profile_idc that indicate additional fields are included in the SPS\n// see Recommendation ITU-T H.264 (4/2013),\n// 7.3.2.1.1 Sequence parameter set data syntax\nPROFILES_WITH_OPTIONAL_SPS_DATA = {\n 100: true,\n 110: true,\n 122: true,\n 244: true,\n 44: true,\n 83: true,\n 86: true,\n 118: true,\n 128: true,\n 138: true,\n 139: true,\n 134: true\n};\n\n/**\n * Accepts input from a ElementaryStream and produces H.264 NAL unit data\n * events.\n */\nH264Stream = function() {\n var\n nalByteStream = new NalByteStream(),\n self,\n trackId,\n currentPts,\n currentDts,\n\n discardEmulationPreventionBytes,\n readSequenceParameterSet,\n skipScalingList;\n\n H264Stream.prototype.init.call(this);\n self = this;\n\n /*\n * Pushes a packet from a stream onto the NalByteStream\n *\n * @param {Object} packet - A packet received from a stream\n * @param {Uint8Array} packet.data - The raw bytes of the packet\n * @param {Number} packet.dts - Decode timestamp of the packet\n * @param {Number} packet.pts - Presentation timestamp of the packet\n * @param {Number} packet.trackId - The id of the h264 track this packet came from\n * @param {('video'|'audio')} packet.type - The type of packet\n *\n */\n this.push = function(packet) {\n if (packet.type !== 'video') {\n return;\n }\n trackId = packet.trackId;\n currentPts = packet.pts;\n currentDts = packet.dts;\n\n nalByteStream.push(packet);\n };\n\n /*\n * Identify NAL unit types and pass on the NALU, trackId, presentation and decode timestamps\n * for the NALUs to the next stream component.\n * Also, preprocess caption and sequence parameter NALUs.\n *\n * @param {Uint8Array} data - A NAL unit identified by `NalByteStream.push`\n * @see NalByteStream.push\n */\n nalByteStream.on('data', function(data) {\n var\n event = {\n trackId: trackId,\n pts: currentPts,\n dts: currentDts,\n data: data\n };\n\n switch (data[0] & 0x1f) {\n case 0x05:\n event.nalUnitType = 'slice_layer_without_partitioning_rbsp_idr';\n break;\n case 0x06:\n event.nalUnitType = 'sei_rbsp';\n event.escapedRBSP = discardEmulationPreventionBytes(data.subarray(1));\n break;\n case 0x07:\n event.nalUnitType = 'seq_parameter_set_rbsp';\n event.escapedRBSP = discardEmulationPreventionBytes(data.subarray(1));\n event.config = readSequenceParameterSet(event.escapedRBSP);\n break;\n case 0x08:\n event.nalUnitType = 'pic_parameter_set_rbsp';\n break;\n case 0x09:\n event.nalUnitType = 'access_unit_delimiter_rbsp';\n break;\n\n default:\n break;\n }\n // This triggers data on the H264Stream\n self.trigger('data', event);\n });\n nalByteStream.on('done', function() {\n self.trigger('done');\n });\n\n this.flush = function() {\n nalByteStream.flush();\n };\n\n /**\n * Advance the ExpGolomb decoder past a scaling list. The scaling\n * list is optionally transmitted as part of a sequence parameter\n * set and is not relevant to transmuxing.\n * @param count {number} the number of entries in this scaling list\n * @param expGolombDecoder {object} an ExpGolomb pointed to the\n * start of a scaling list\n * @see Recommendation ITU-T H.264, Section 7.3.2.1.1.1\n */\n skipScalingList = function(count, expGolombDecoder) {\n var\n lastScale = 8,\n nextScale = 8,\n j,\n deltaScale;\n\n for (j = 0; j < count; j++) {\n if (nextScale !== 0) {\n deltaScale = expGolombDecoder.readExpGolomb();\n nextScale = (lastScale + deltaScale + 256) % 256;\n }\n\n lastScale = (nextScale === 0) ? lastScale : nextScale;\n }\n };\n\n /**\n * Expunge any \"Emulation Prevention\" bytes from a \"Raw Byte\n * Sequence Payload\"\n * @param data {Uint8Array} the bytes of a RBSP from a NAL\n * unit\n * @return {Uint8Array} the RBSP without any Emulation\n * Prevention Bytes\n */\n discardEmulationPreventionBytes = function(data) {\n var\n length = data.byteLength,\n emulationPreventionBytesPositions = [],\n i = 1,\n newLength, newData;\n\n // Find all `Emulation Prevention Bytes`\n while (i < length - 2) {\n if (data[i] === 0 && data[i + 1] === 0 && data[i + 2] === 0x03) {\n emulationPreventionBytesPositions.push(i + 2);\n i += 2;\n } else {\n i++;\n }\n }\n\n // If no Emulation Prevention Bytes were found just return the original\n // array\n if (emulationPreventionBytesPositions.length === 0) {\n return data;\n }\n\n // Create a new array to hold the NAL unit data\n newLength = length - emulationPreventionBytesPositions.length;\n newData = new Uint8Array(newLength);\n var sourceIndex = 0;\n\n for (i = 0; i < newLength; sourceIndex++, i++) {\n if (sourceIndex === emulationPreventionBytesPositions[0]) {\n // Skip this byte\n sourceIndex++;\n // Remove this position index\n emulationPreventionBytesPositions.shift();\n }\n newData[i] = data[sourceIndex];\n }\n\n return newData;\n };\n\n /**\n * Read a sequence parameter set and return some interesting video\n * properties. A sequence parameter set is the H264 metadata that\n * describes the properties of upcoming video frames.\n * @param data {Uint8Array} the bytes of a sequence parameter set\n * @return {object} an object with configuration parsed from the\n * sequence parameter set, including the dimensions of the\n * associated video frames.\n */\n readSequenceParameterSet = function(data) {\n var\n frameCropLeftOffset = 0,\n frameCropRightOffset = 0,\n frameCropTopOffset = 0,\n frameCropBottomOffset = 0,\n sarScale = 1,\n expGolombDecoder, profileIdc, levelIdc, profileCompatibility,\n chromaFormatIdc, picOrderCntType,\n numRefFramesInPicOrderCntCycle, picWidthInMbsMinus1,\n picHeightInMapUnitsMinus1,\n frameMbsOnlyFlag,\n scalingListCount,\n sarRatio,\n aspectRatioIdc,\n i;\n\n expGolombDecoder = new ExpGolomb(data);\n profileIdc = expGolombDecoder.readUnsignedByte(); // profile_idc\n profileCompatibility = expGolombDecoder.readUnsignedByte(); // constraint_set[0-5]_flag\n levelIdc = expGolombDecoder.readUnsignedByte(); // level_idc u(8)\n expGolombDecoder.skipUnsignedExpGolomb(); // seq_parameter_set_id\n\n // some profiles have more optional data we don't need\n if (PROFILES_WITH_OPTIONAL_SPS_DATA[profileIdc]) {\n chromaFormatIdc = expGolombDecoder.readUnsignedExpGolomb();\n if (chromaFormatIdc === 3) {\n expGolombDecoder.skipBits(1); // separate_colour_plane_flag\n }\n expGolombDecoder.skipUnsignedExpGolomb(); // bit_depth_luma_minus8\n expGolombDecoder.skipUnsignedExpGolomb(); // bit_depth_chroma_minus8\n expGolombDecoder.skipBits(1); // qpprime_y_zero_transform_bypass_flag\n if (expGolombDecoder.readBoolean()) { // seq_scaling_matrix_present_flag\n scalingListCount = (chromaFormatIdc !== 3) ? 8 : 12;\n for (i = 0; i < scalingListCount; i++) {\n if (expGolombDecoder.readBoolean()) { // seq_scaling_list_present_flag[ i ]\n if (i < 6) {\n skipScalingList(16, expGolombDecoder);\n } else {\n skipScalingList(64, expGolombDecoder);\n }\n }\n }\n }\n }\n\n expGolombDecoder.skipUnsignedExpGolomb(); // log2_max_frame_num_minus4\n picOrderCntType = expGolombDecoder.readUnsignedExpGolomb();\n\n if (picOrderCntType === 0) {\n expGolombDecoder.readUnsignedExpGolomb(); // log2_max_pic_order_cnt_lsb_minus4\n } else if (picOrderCntType === 1) {\n expGolombDecoder.skipBits(1); // delta_pic_order_always_zero_flag\n expGolombDecoder.skipExpGolomb(); // offset_for_non_ref_pic\n expGolombDecoder.skipExpGolomb(); // offset_for_top_to_bottom_field\n numRefFramesInPicOrderCntCycle = expGolombDecoder.readUnsignedExpGolomb();\n for (i = 0; i < numRefFramesInPicOrderCntCycle; i++) {\n expGolombDecoder.skipExpGolomb(); // offset_for_ref_frame[ i ]\n }\n }\n\n expGolombDecoder.skipUnsignedExpGolomb(); // max_num_ref_frames\n expGolombDecoder.skipBits(1); // gaps_in_frame_num_value_allowed_flag\n\n picWidthInMbsMinus1 = expGolombDecoder.readUnsignedExpGolomb();\n picHeightInMapUnitsMinus1 = expGolombDecoder.readUnsignedExpGolomb();\n\n frameMbsOnlyFlag = expGolombDecoder.readBits(1);\n if (frameMbsOnlyFlag === 0) {\n expGolombDecoder.skipBits(1); // mb_adaptive_frame_field_flag\n }\n\n expGolombDecoder.skipBits(1); // direct_8x8_inference_flag\n if (expGolombDecoder.readBoolean()) { // frame_cropping_flag\n frameCropLeftOffset = expGolombDecoder.readUnsignedExpGolomb();\n frameCropRightOffset = expGolombDecoder.readUnsignedExpGolomb();\n frameCropTopOffset = expGolombDecoder.readUnsignedExpGolomb();\n frameCropBottomOffset = expGolombDecoder.readUnsignedExpGolomb();\n }\n if (expGolombDecoder.readBoolean()) {\n // vui_parameters_present_flag\n if (expGolombDecoder.readBoolean()) {\n // aspect_ratio_info_present_flag\n aspectRatioIdc = expGolombDecoder.readUnsignedByte();\n switch (aspectRatioIdc) {\n case 1: sarRatio = [1, 1]; break;\n case 2: sarRatio = [12, 11]; break;\n case 3: sarRatio = [10, 11]; break;\n case 4: sarRatio = [16, 11]; break;\n case 5: sarRatio = [40, 33]; break;\n case 6: sarRatio = [24, 11]; break;\n case 7: sarRatio = [20, 11]; break;\n case 8: sarRatio = [32, 11]; break;\n case 9: sarRatio = [80, 33]; break;\n case 10: sarRatio = [18, 11]; break;\n case 11: sarRatio = [15, 11]; break;\n case 12: sarRatio = [64, 33]; break;\n case 13: sarRatio = [160, 99]; break;\n case 14: sarRatio = [4, 3]; break;\n case 15: sarRatio = [3, 2]; break;\n case 16: sarRatio = [2, 1]; break;\n case 255: {\n sarRatio = [expGolombDecoder.readUnsignedByte() << 8 |\n expGolombDecoder.readUnsignedByte(),\n expGolombDecoder.readUnsignedByte() << 8 |\n expGolombDecoder.readUnsignedByte() ];\n break;\n }\n }\n if (sarRatio) {\n sarScale = sarRatio[0] / sarRatio[1];\n }\n }\n }\n return {\n profileIdc: profileIdc,\n levelIdc: levelIdc,\n profileCompatibility: profileCompatibility,\n width: Math.ceil((((picWidthInMbsMinus1 + 1) * 16) - frameCropLeftOffset * 2 - frameCropRightOffset * 2) * sarScale),\n height: ((2 - frameMbsOnlyFlag) * (picHeightInMapUnitsMinus1 + 1) * 16) - (frameCropTopOffset * 2) - (frameCropBottomOffset * 2)\n };\n };\n\n};\nH264Stream.prototype = new Stream();\n\nmodule.exports = {\n H264Stream: H264Stream,\n NalByteStream: NalByteStream\n};\n","'use strict';\n\nvar ExpGolomb;\n\n/**\n * Parser for exponential Golomb codes, a variable-bitwidth number encoding\n * scheme used by h264.\n */\nExpGolomb = function(workingData) {\n var\n // the number of bytes left to examine in workingData\n workingBytesAvailable = workingData.byteLength,\n\n // the current word being examined\n workingWord = 0, // :uint\n\n // the number of bits left to examine in the current word\n workingBitsAvailable = 0; // :uint;\n\n // ():uint\n this.length = function() {\n return (8 * workingBytesAvailable);\n };\n\n // ():uint\n this.bitsAvailable = function() {\n return (8 * workingBytesAvailable) + workingBitsAvailable;\n };\n\n // ():void\n this.loadWord = function() {\n var\n position = workingData.byteLength - workingBytesAvailable,\n workingBytes = new Uint8Array(4),\n availableBytes = Math.min(4, workingBytesAvailable);\n\n if (availableBytes === 0) {\n throw new Error('no bytes available');\n }\n\n workingBytes.set(workingData.subarray(position,\n position + availableBytes));\n workingWord = new DataView(workingBytes.buffer).getUint32(0);\n\n // track the amount of workingData that has been processed\n workingBitsAvailable = availableBytes * 8;\n workingBytesAvailable -= availableBytes;\n };\n\n // (count:int):void\n this.skipBits = function(count) {\n var skipBytes; // :int\n if (workingBitsAvailable > count) {\n workingWord <<= count;\n workingBitsAvailable -= count;\n } else {\n count -= workingBitsAvailable;\n skipBytes = Math.floor(count / 8);\n\n count -= (skipBytes * 8);\n workingBytesAvailable -= skipBytes;\n\n this.loadWord();\n\n workingWord <<= count;\n workingBitsAvailable -= count;\n }\n };\n\n // (size:int):uint\n this.readBits = function(size) {\n var\n bits = Math.min(workingBitsAvailable, size), // :uint\n valu = workingWord >>> (32 - bits); // :uint\n // if size > 31, handle error\n workingBitsAvailable -= bits;\n if (workingBitsAvailable > 0) {\n workingWord <<= bits;\n } else if (workingBytesAvailable > 0) {\n this.loadWord();\n }\n\n bits = size - bits;\n if (bits > 0) {\n return valu << bits | this.readBits(bits);\n }\n return valu;\n };\n\n // ():uint\n this.skipLeadingZeros = function() {\n var leadingZeroCount; // :uint\n for (leadingZeroCount = 0; leadingZeroCount < workingBitsAvailable; ++leadingZeroCount) {\n if ((workingWord & (0x80000000 >>> leadingZeroCount)) !== 0) {\n // the first bit of working word is 1\n workingWord <<= leadingZeroCount;\n workingBitsAvailable -= leadingZeroCount;\n return leadingZeroCount;\n }\n }\n\n // we exhausted workingWord and still have not found a 1\n this.loadWord();\n return leadingZeroCount + this.skipLeadingZeros();\n };\n\n // ():void\n this.skipUnsignedExpGolomb = function() {\n this.skipBits(1 + this.skipLeadingZeros());\n };\n\n // ():void\n this.skipExpGolomb = function() {\n this.skipBits(1 + this.skipLeadingZeros());\n };\n\n // ():uint\n this.readUnsignedExpGolomb = function() {\n var clz = this.skipLeadingZeros(); // :uint\n return this.readBits(clz + 1) - 1;\n };\n\n // ():int\n this.readExpGolomb = function() {\n var valu = this.readUnsignedExpGolomb(); // :int\n if (0x01 & valu) {\n // the number is odd if the low order bit is set\n return (1 + valu) >>> 1; // add 1 to make it even, and divide by 2\n }\n return -1 * (valu >>> 1); // divide by two then make it negative\n };\n\n // Some convenience functions\n // :Boolean\n this.readBoolean = function() {\n return this.readBits(1) === 1;\n };\n\n // ():int\n this.readUnsignedByte = function() {\n return this.readBits(8);\n };\n\n this.loadWord();\n};\n\nmodule.exports = ExpGolomb;\n","/**\n * mux.js\n *\n * Copyright (c) 2016 Brightcove\n * All rights reserved.\n *\n * A stream-based aac to mp4 converter. This utility can be used to\n * deliver mp4s to a SourceBuffer on platforms that support native\n * Media Source Extensions.\n */\n'use strict';\nvar Stream = require('../utils/stream.js');\nvar aacUtils = require('./utils');\n\n// Constants\nvar AacStream;\n\n/**\n * Splits an incoming stream of binary data into ADTS and ID3 Frames.\n */\n\nAacStream = function() {\n var\n everything = new Uint8Array(),\n timeStamp = 0;\n\n AacStream.prototype.init.call(this);\n\n this.setTimestamp = function(timestamp) {\n timeStamp = timestamp;\n };\n\n this.push = function(bytes) {\n var\n frameSize = 0,\n byteIndex = 0,\n bytesLeft,\n chunk,\n packet,\n tempLength;\n\n // If there are bytes remaining from the last segment, prepend them to the\n // bytes that were pushed in\n if (everything.length) {\n tempLength = everything.length;\n everything = new Uint8Array(bytes.byteLength + tempLength);\n everything.set(everything.subarray(0, tempLength));\n everything.set(bytes, tempLength);\n } else {\n everything = bytes;\n }\n\n while (everything.length - byteIndex >= 3) {\n if ((everything[byteIndex] === 'I'.charCodeAt(0)) &&\n (everything[byteIndex + 1] === 'D'.charCodeAt(0)) &&\n (everything[byteIndex + 2] === '3'.charCodeAt(0))) {\n\n // Exit early because we don't have enough to parse\n // the ID3 tag header\n if (everything.length - byteIndex < 10) {\n break;\n }\n\n // check framesize\n frameSize = aacUtils.parseId3TagSize(everything, byteIndex);\n\n // Exit early if we don't have enough in the buffer\n // to emit a full packet\n // Add to byteIndex to support multiple ID3 tags in sequence\n if (byteIndex + frameSize > everything.length) {\n break;\n }\n chunk = {\n type: 'timed-metadata',\n data: everything.subarray(byteIndex, byteIndex + frameSize)\n };\n this.trigger('data', chunk);\n byteIndex += frameSize;\n continue;\n } else if (((everything[byteIndex] & 0xff) === 0xff) &&\n ((everything[byteIndex + 1] & 0xf0) === 0xf0)) {\n\n // Exit early because we don't have enough to parse\n // the ADTS frame header\n if (everything.length - byteIndex < 7) {\n break;\n }\n\n frameSize = aacUtils.parseAdtsSize(everything, byteIndex);\n\n // Exit early if we don't have enough in the buffer\n // to emit a full packet\n if (byteIndex + frameSize > everything.length) {\n break;\n }\n\n packet = {\n type: 'audio',\n data: everything.subarray(byteIndex, byteIndex + frameSize),\n pts: timeStamp,\n dts: timeStamp\n };\n this.trigger('data', packet);\n byteIndex += frameSize;\n continue;\n }\n byteIndex++;\n }\n bytesLeft = everything.length - byteIndex;\n\n if (bytesLeft > 0) {\n everything = everything.subarray(byteIndex);\n } else {\n everything = new Uint8Array();\n }\n };\n};\n\nAacStream.prototype = new Stream();\n\nmodule.exports = AacStream;\n","/**\n * mux.js\n *\n * Copyright (c) 2015 Brightcove\n * All rights reserved.\n *\n * Reads in-band CEA-708 captions out of FMP4 segments.\n * @see https://en.wikipedia.org/wiki/CEA-708\n */\n'use strict';\n\nvar discardEmulationPreventionBytes = require('../tools/caption-packet-parser').discardEmulationPreventionBytes;\nvar CaptionStream = require('../m2ts/caption-stream').CaptionStream;\nvar probe = require('./probe');\nvar inspect = require('../tools/mp4-inspector');\n\n/**\n * Maps an offset in the mdat to a sample based on the the size of the samples.\n * Assumes that `parseSamples` has been called first.\n *\n * @param {Number} offset - The offset into the mdat\n * @param {Object[]} samples - An array of samples, parsed using `parseSamples`\n * @return {?Object} The matching sample, or null if no match was found.\n *\n * @see ISO-BMFF-12/2015, Section 8.8.8\n **/\nvar mapToSample = function(offset, samples) {\n var approximateOffset = offset;\n\n for (var i = 0; i < samples.length; i++) {\n var sample = samples[i];\n\n if (approximateOffset < sample.size) {\n return sample;\n }\n\n approximateOffset -= sample.size;\n }\n\n return null;\n};\n\n/**\n * Finds SEI nal units contained in a Media Data Box.\n * Assumes that `parseSamples` has been called first.\n *\n * @param {Uint8Array} avcStream - The bytes of the mdat\n * @param {Object[]} samples - The samples parsed out by `parseSamples`\n * @param {Number} trackId - The trackId of this video track\n * @return {Object[]} seiNals - the parsed SEI NALUs found.\n * The contents of the seiNal should match what is expected by\n * CaptionStream.push (nalUnitType, size, data, escapedRBSP, pts, dts)\n *\n * @see ISO-BMFF-12/2015, Section 8.1.1\n * @see Rec. ITU-T H.264, 7.3.2.3.1\n **/\nvar findSeiNals = function(avcStream, samples, trackId) {\n var\n avcView = new DataView(avcStream.buffer, avcStream.byteOffset, avcStream.byteLength),\n result = [],\n seiNal,\n i,\n length,\n lastMatchedSample;\n\n for (i = 0; i + 4 < avcStream.length; i += length) {\n length = avcView.getUint32(i);\n i += 4;\n\n // Bail if this doesn't appear to be an H264 stream\n if (length <= 0) {\n continue;\n }\n\n switch (avcStream[i] & 0x1F) {\n case 0x06:\n var data = avcStream.subarray(i + 1, i + 1 + length);\n var matchingSample = mapToSample(i, samples);\n\n seiNal = {\n nalUnitType: 'sei_rbsp',\n size: length,\n data: data,\n escapedRBSP: discardEmulationPreventionBytes(data),\n trackId: trackId\n };\n\n if (matchingSample) {\n seiNal.pts = matchingSample.pts;\n seiNal.dts = matchingSample.dts;\n lastMatchedSample = matchingSample;\n } else {\n // If a matching sample cannot be found, use the last\n // sample's values as they should be as close as possible\n seiNal.pts = lastMatchedSample.pts;\n seiNal.dts = lastMatchedSample.dts;\n }\n\n result.push(seiNal);\n break;\n default:\n break;\n }\n }\n\n return result;\n};\n\n/**\n * Parses sample information out of Track Run Boxes and calculates\n * the absolute presentation and decode timestamps of each sample.\n *\n * @param {Array<Uint8Array>} truns - The Trun Run boxes to be parsed\n * @param {Number} baseMediaDecodeTime - base media decode time from tfdt\n @see ISO-BMFF-12/2015, Section 8.8.12\n * @param {Object} tfhd - The parsed Track Fragment Header\n * @see inspect.parseTfhd\n * @return {Object[]} the parsed samples\n *\n * @see ISO-BMFF-12/2015, Section 8.8.8\n **/\nvar parseSamples = function(truns, baseMediaDecodeTime, tfhd) {\n var currentDts = baseMediaDecodeTime;\n var defaultSampleDuration = tfhd.defaultSampleDuration || 0;\n var defaultSampleSize = tfhd.defaultSampleSize || 0;\n var trackId = tfhd.trackId;\n var allSamples = [];\n\n truns.forEach(function(trun) {\n // Note: We currently do not parse the sample table as well\n // as the trun. It's possible some sources will require this.\n // moov > trak > mdia > minf > stbl\n var trackRun = inspect.parseTrun(trun);\n var samples = trackRun.samples;\n\n samples.forEach(function(sample) {\n if (sample.duration === undefined) {\n sample.duration = defaultSampleDuration;\n }\n if (sample.size === undefined) {\n sample.size = defaultSampleSize;\n }\n sample.trackId = trackId;\n sample.dts = currentDts;\n if (sample.compositionTimeOffset === undefined) {\n sample.compositionTimeOffset = 0;\n }\n sample.pts = currentDts + sample.compositionTimeOffset;\n\n currentDts += sample.duration;\n });\n\n allSamples = allSamples.concat(samples);\n });\n\n return allSamples;\n};\n\n/**\n * Parses out caption nals from an FMP4 segment's video tracks.\n *\n * @param {Uint8Array} segment - The bytes of a single segment\n * @param {Number} videoTrackId - The trackId of a video track in the segment\n * @return {Object.<Number, Object[]>} A mapping of video trackId to\n * a list of seiNals found in that track\n **/\nvar parseCaptionNals = function(segment, videoTrackId) {\n // To get the samples\n var trafs = probe.findBox(segment, ['moof', 'traf']);\n // To get SEI NAL units\n var mdats = probe.findBox(segment, ['mdat']);\n var captionNals = {};\n var mdatTrafPairs = [];\n\n // Pair up each traf with a mdat as moofs and mdats are in pairs\n mdats.forEach(function(mdat, index) {\n var matchingTraf = trafs[index];\n mdatTrafPairs.push({\n mdat: mdat,\n traf: matchingTraf\n });\n });\n\n mdatTrafPairs.forEach(function(pair) {\n var mdat = pair.mdat;\n var traf = pair.traf;\n var tfhd = probe.findBox(traf, ['tfhd']);\n // Exactly 1 tfhd per traf\n var headerInfo = inspect.parseTfhd(tfhd[0]);\n var trackId = headerInfo.trackId;\n var tfdt = probe.findBox(traf, ['tfdt']);\n // Either 0 or 1 tfdt per traf\n var baseMediaDecodeTime = (tfdt.length > 0) ? inspect.parseTfdt(tfdt[0]).baseMediaDecodeTime : 0;\n var truns = probe.findBox(traf, ['trun']);\n var samples;\n var seiNals;\n\n // Only parse video data for the chosen video track\n if (videoTrackId === trackId && truns.length > 0) {\n samples = parseSamples(truns, baseMediaDecodeTime, headerInfo);\n\n seiNals = findSeiNals(mdat, samples, trackId);\n\n if (!captionNals[trackId]) {\n captionNals[trackId] = [];\n }\n\n captionNals[trackId] = captionNals[trackId].concat(seiNals);\n }\n });\n\n return captionNals;\n};\n\n/**\n * Parses out inband captions from an MP4 container and returns\n * caption objects that can be used by WebVTT and the TextTrack API.\n * @see https://developer.mozilla.org/en-US/docs/Web/API/VTTCue\n * @see https://developer.mozilla.org/en-US/docs/Web/API/TextTrack\n * Assumes that `probe.getVideoTrackIds` and `probe.timescale` have been called first\n *\n * @param {Uint8Array} segment - The fmp4 segment containing embedded captions\n * @param {Number} trackId - The id of the video track to parse\n * @param {Number} timescale - The timescale for the video track from the init segment\n *\n * @return {?Object[]} parsedCaptions - A list of captions or null if no video tracks\n * @return {Number} parsedCaptions[].startTime - The time to show the caption in seconds\n * @return {Number} parsedCaptions[].endTime - The time to stop showing the caption in seconds\n * @return {String} parsedCaptions[].text - The visible content of the caption\n **/\nvar parseEmbeddedCaptions = function(segment, trackId, timescale) {\n var seiNals;\n\n if (!trackId) {\n return null;\n }\n\n seiNals = parseCaptionNals(segment, trackId);\n\n return {\n seiNals: seiNals[trackId],\n timescale: timescale\n };\n};\n\n/**\n * Converts SEI NALUs into captions that can be used by video.js\n **/\nvar CaptionParser = function() {\n var isInitialized = false;\n var captionStream;\n\n // Stores segments seen before trackId and timescale are set\n var segmentCache;\n // Stores video track ID of the track being parsed\n var trackId;\n // Stores the timescale of the track being parsed\n var timescale;\n // Stores captions parsed so far\n var parsedCaptions;\n\n /**\n * A method to indicate whether a CaptionParser has been initalized\n * @returns {Boolean}\n **/\n this.isInitialized = function() {\n return isInitialized;\n };\n\n /**\n * Initializes the underlying CaptionStream, SEI NAL parsing\n * and management, and caption collection\n **/\n this.init = function() {\n captionStream = new CaptionStream();\n isInitialized = true;\n\n // Collect dispatched captions\n captionStream.on('data', function(event) {\n // Convert to seconds in the source's timescale\n event.startTime = event.startPts / timescale;\n event.endTime = event.endPts / timescale;\n\n parsedCaptions.captions.push(event);\n parsedCaptions.captionStreams[event.stream] = true;\n });\n };\n\n /**\n * Determines if a new video track will be selected\n * or if the timescale changed\n * @return {Boolean}\n **/\n this.isNewInit = function(videoTrackIds, timescales) {\n if ((videoTrackIds && videoTrackIds.length === 0) ||\n (timescales && typeof timescales === 'object' &&\n Object.keys(timescales).length === 0)) {\n return false;\n }\n\n return trackId !== videoTrackIds[0] ||\n timescale !== timescales[trackId];\n };\n\n /**\n * Parses out SEI captions and interacts with underlying\n * CaptionStream to return dispatched captions\n *\n * @param {Uint8Array} segment - The fmp4 segment containing embedded captions\n * @param {Number[]} videoTrackIds - A list of video tracks found in the init segment\n * @param {Object.<Number, Number>} timescales - The timescales found in the init segment\n * @see parseEmbeddedCaptions\n * @see m2ts/caption-stream.js\n **/\n this.parse = function(segment, videoTrackIds, timescales) {\n var parsedData;\n\n if (!this.isInitialized()) {\n return null;\n\n // This is not likely to be a video segment\n } else if (!videoTrackIds || !timescales) {\n return null;\n\n } else if (this.isNewInit(videoTrackIds, timescales)) {\n // Use the first video track only as there is no\n // mechanism to switch to other video tracks\n trackId = videoTrackIds[0];\n timescale = timescales[trackId];\n\n // If an init segment has not been seen yet, hold onto segment\n // data until we have one\n } else if (!trackId || !timescale) {\n segmentCache.push(segment);\n return null;\n }\n\n // Now that a timescale and trackId is set, parse cached segments\n while (segmentCache.length > 0) {\n var cachedSegment = segmentCache.shift();\n\n this.parse(cachedSegment, videoTrackIds, timescales);\n }\n\n parsedData = parseEmbeddedCaptions(segment, trackId, timescale);\n\n if (parsedData === null || !parsedData.seiNals) {\n return null;\n }\n\n this.pushNals(parsedData.seiNals);\n // Force the parsed captions to be dispatched\n this.flushStream();\n\n return parsedCaptions;\n };\n\n /**\n * Pushes SEI NALUs onto CaptionStream\n * @param {Object[]} nals - A list of SEI nals parsed using `parseCaptionNals`\n * Assumes that `parseCaptionNals` has been called first\n * @see m2ts/caption-stream.js\n **/\n this.pushNals = function(nals) {\n if (!this.isInitialized() || !nals || nals.length === 0) {\n return null;\n }\n\n nals.forEach(function(nal) {\n captionStream.push(nal);\n });\n };\n\n /**\n * Flushes underlying CaptionStream to dispatch processed, displayable captions\n * @see m2ts/caption-stream.js\n **/\n this.flushStream = function() {\n if (!this.isInitialized()) {\n return null;\n }\n\n captionStream.flush();\n };\n\n /**\n * Reset caption buckets for new data\n **/\n this.clearParsedCaptions = function() {\n parsedCaptions.captions = [];\n parsedCaptions.captionStreams = {};\n };\n\n /**\n * Resets underlying CaptionStream\n * @see m2ts/caption-stream.js\n **/\n this.resetCaptionStream = function() {\n if (!this.isInitialized()) {\n return null;\n }\n\n captionStream.reset();\n };\n\n /**\n * Convenience method to clear all captions flushed from the\n * CaptionStream and still being parsed\n * @see m2ts/caption-stream.js\n **/\n this.clearAllCaptions = function() {\n this.clearParsedCaptions();\n this.resetCaptionStream();\n };\n\n /**\n * Reset caption parser\n **/\n this.reset = function() {\n segmentCache = [];\n trackId = null;\n timescale = null;\n\n if (!parsedCaptions) {\n parsedCaptions = {\n captions: [],\n // CC1, CC2, CC3, CC4\n captionStreams: {}\n };\n } else {\n this.clearParsedCaptions();\n }\n\n this.resetCaptionStream();\n };\n\n this.reset();\n};\n\nmodule.exports = CaptionParser;\n","/**\n * mux.js\n *\n * Copyright (c) 2015 Brightcove\n * All rights reserved.\n *\n * Parse the internal MP4 structure into an equivalent javascript\n * object.\n */\n'use strict';\n\nvar\n inspectMp4,\n textifyMp4,\n\n parseType = require('../mp4/probe').parseType,\n parseMp4Date = function(seconds) {\n return new Date(seconds * 1000 - 2082844800000);\n },\n parseSampleFlags = function(flags) {\n return {\n isLeading: (flags[0] & 0x0c) >>> 2,\n dependsOn: flags[0] & 0x03,\n isDependedOn: (flags[1] & 0xc0) >>> 6,\n hasRedundancy: (flags[1] & 0x30) >>> 4,\n paddingValue: (flags[1] & 0x0e) >>> 1,\n isNonSyncSample: flags[1] & 0x01,\n degradationPriority: (flags[2] << 8) | flags[3]\n };\n },\n nalParse = function(avcStream) {\n var\n avcView = new DataView(avcStream.buffer, avcStream.byteOffset, avcStream.byteLength),\n result = [],\n i,\n length;\n for (i = 0; i + 4 < avcStream.length; i += length) {\n length = avcView.getUint32(i);\n i += 4;\n\n // bail if this doesn't appear to be an H264 stream\n if (length <= 0) {\n result.push('<span style=\\'color:red;\\'>MALFORMED DATA</span>');\n continue;\n }\n\n switch (avcStream[i] & 0x1F) {\n case 0x01:\n result.push('slice_layer_without_partitioning_rbsp');\n break;\n case 0x05:\n result.push('slice_layer_without_partitioning_rbsp_idr');\n break;\n case 0x06:\n result.push('sei_rbsp');\n break;\n case 0x07:\n result.push('seq_parameter_set_rbsp');\n break;\n case 0x08:\n result.push('pic_parameter_set_rbsp');\n break;\n case 0x09:\n result.push('access_unit_delimiter_rbsp');\n break;\n default:\n result.push('UNKNOWN NAL - ' + avcStream[i] & 0x1F);\n break;\n }\n }\n return result;\n },\n\n // registry of handlers for individual mp4 box types\n parse = {\n // codingname, not a first-class box type. stsd entries share the\n // same format as real boxes so the parsing infrastructure can be\n // shared\n avc1: function(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength);\n return {\n dataReferenceIndex: view.getUint16(6),\n width: view.getUint16(24),\n height: view.getUint16(26),\n horizresolution: view.getUint16(28) + (view.getUint16(30) / 16),\n vertresolution: view.getUint16(32) + (view.getUint16(34) / 16),\n frameCount: view.getUint16(40),\n depth: view.getUint16(74),\n config: inspectMp4(data.subarray(78, data.byteLength))\n };\n },\n avcC: function(data) {\n var\n view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n configurationVersion: data[0],\n avcProfileIndication: data[1],\n profileCompatibility: data[2],\n avcLevelIndication: data[3],\n lengthSizeMinusOne: data[4] & 0x03,\n sps: [],\n pps: []\n },\n numOfSequenceParameterSets = data[5] & 0x1f,\n numOfPictureParameterSets,\n nalSize,\n offset,\n i;\n\n // iterate past any SPSs\n offset = 6;\n for (i = 0; i < numOfSequenceParameterSets; i++) {\n nalSize = view.getUint16(offset);\n offset += 2;\n result.sps.push(new Uint8Array(data.subarray(offset, offset + nalSize)));\n offset += nalSize;\n }\n // iterate past any PPSs\n numOfPictureParameterSets = data[offset];\n offset++;\n for (i = 0; i < numOfPictureParameterSets; i++) {\n nalSize = view.getUint16(offset);\n offset += 2;\n result.pps.push(new Uint8Array(data.subarray(offset, offset + nalSize)));\n offset += nalSize;\n }\n return result;\n },\n btrt: function(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength);\n return {\n bufferSizeDB: view.getUint32(0),\n maxBitrate: view.getUint32(4),\n avgBitrate: view.getUint32(8)\n };\n },\n esds: function(data) {\n return {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n esId: (data[6] << 8) | data[7],\n streamPriority: data[8] & 0x1f,\n decoderConfig: {\n objectProfileIndication: data[11],\n streamType: (data[12] >>> 2) & 0x3f,\n bufferSize: (data[13] << 16) | (data[14] << 8) | data[15],\n maxBitrate: (data[16] << 24) |\n (data[17] << 16) |\n (data[18] << 8) |\n data[19],\n avgBitrate: (data[20] << 24) |\n (data[21] << 16) |\n (data[22] << 8) |\n data[23],\n decoderConfigDescriptor: {\n tag: data[24],\n length: data[25],\n audioObjectType: (data[26] >>> 3) & 0x1f,\n samplingFrequencyIndex: ((data[26] & 0x07) << 1) |\n ((data[27] >>> 7) & 0x01),\n channelConfiguration: (data[27] >>> 3) & 0x0f\n }\n }\n };\n },\n ftyp: function(data) {\n var\n view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n majorBrand: parseType(data.subarray(0, 4)),\n minorVersion: view.getUint32(4),\n compatibleBrands: []\n },\n i = 8;\n while (i < data.byteLength) {\n result.compatibleBrands.push(parseType(data.subarray(i, i + 4)));\n i += 4;\n }\n return result;\n },\n dinf: function(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n dref: function(data) {\n return {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n dataReferences: inspectMp4(data.subarray(8))\n };\n },\n hdlr: function(data) {\n var\n view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n version: view.getUint8(0),\n flags: new Uint8Array(data.subarray(1, 4)),\n handlerType: parseType(data.subarray(8, 12)),\n name: ''\n },\n i = 8;\n\n // parse out the name field\n for (i = 24; i < data.byteLength; i++) {\n if (data[i] === 0x00) {\n // the name field is null-terminated\n i++;\n break;\n }\n result.name += String.fromCharCode(data[i]);\n }\n // decode UTF-8 to javascript's internal representation\n // see http://ecmanaut.blogspot.com/2006/07/encoding-decoding-utf8-in-javascript.html\n result.name = decodeURIComponent(escape(result.name));\n\n return result;\n },\n mdat: function(data) {\n return {\n byteLength: data.byteLength,\n nals: nalParse(data)\n };\n },\n mdhd: function(data) {\n var\n view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n i = 4,\n language,\n result = {\n version: view.getUint8(0),\n flags: new Uint8Array(data.subarray(1, 4)),\n language: ''\n };\n if (result.version === 1) {\n i += 4;\n result.creationTime = parseMp4Date(view.getUint32(i)); // truncating top 4 bytes\n i += 8;\n result.modificationTime = parseMp4Date(view.getUint32(i)); // truncating top 4 bytes\n i += 4;\n result.timescale = view.getUint32(i);\n i += 8;\n result.duration = view.getUint32(i); // truncating top 4 bytes\n } else {\n result.creationTime = parseMp4Date(view.getUint32(i));\n i += 4;\n result.modificationTime = parseMp4Date(view.getUint32(i));\n i += 4;\n result.timescale = view.getUint32(i);\n i += 4;\n result.duration = view.getUint32(i);\n }\n i += 4;\n // language is stored as an ISO-639-2/T code in an array of three 5-bit fields\n // each field is the packed difference between its ASCII value and 0x60\n language = view.getUint16(i);\n result.language += String.fromCharCode((language >> 10) + 0x60);\n result.language += String.fromCharCode(((language & 0x03e0) >> 5) + 0x60);\n result.language += String.fromCharCode((language & 0x1f) + 0x60);\n\n return result;\n },\n mdia: function(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n mfhd: function(data) {\n return {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n sequenceNumber: (data[4] << 24) |\n (data[5] << 16) |\n (data[6] << 8) |\n (data[7])\n };\n },\n minf: function(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n // codingname, not a first-class box type. stsd entries share the\n // same format as real boxes so the parsing infrastructure can be\n // shared\n mp4a: function(data) {\n var\n view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n // 6 bytes reserved\n dataReferenceIndex: view.getUint16(6),\n // 4 + 4 bytes reserved\n channelcount: view.getUint16(16),\n samplesize: view.getUint16(18),\n // 2 bytes pre_defined\n // 2 bytes reserved\n samplerate: view.getUint16(24) + (view.getUint16(26) / 65536)\n };\n\n // if there are more bytes to process, assume this is an ISO/IEC\n // 14496-14 MP4AudioSampleEntry and parse the ESDBox\n if (data.byteLength > 28) {\n result.streamDescriptor = inspectMp4(data.subarray(28))[0];\n }\n return result;\n },\n moof: function(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n moov: function(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n mvex: function(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n mvhd: function(data) {\n var\n view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n i = 4,\n result = {\n version: view.getUint8(0),\n flags: new Uint8Array(data.subarray(1, 4))\n };\n\n if (result.version === 1) {\n i += 4;\n result.creationTime = parseMp4Date(view.getUint32(i)); // truncating top 4 bytes\n i += 8;\n result.modificationTime = parseMp4Date(view.getUint32(i)); // truncating top 4 bytes\n i += 4;\n result.timescale = view.getUint32(i);\n i += 8;\n result.duration = view.getUint32(i); // truncating top 4 bytes\n } else {\n result.creationTime = parseMp4Date(view.getUint32(i));\n i += 4;\n result.modificationTime = parseMp4Date(view.getUint32(i));\n i += 4;\n result.timescale = view.getUint32(i);\n i += 4;\n result.duration = view.getUint32(i);\n }\n i += 4;\n\n // convert fixed-point, base 16 back to a number\n result.rate = view.getUint16(i) + (view.getUint16(i + 2) / 16);\n i += 4;\n result.volume = view.getUint8(i) + (view.getUint8(i + 1) / 8);\n i += 2;\n i += 2;\n i += 2 * 4;\n result.matrix = new Uint32Array(data.subarray(i, i + (9 * 4)));\n i += 9 * 4;\n i += 6 * 4;\n result.nextTrackId = view.getUint32(i);\n return result;\n },\n pdin: function(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength);\n return {\n version: view.getUint8(0),\n flags: new Uint8Array(data.subarray(1, 4)),\n rate: view.getUint32(4),\n initialDelay: view.getUint32(8)\n };\n },\n sdtp: function(data) {\n var\n result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n samples: []\n }, i;\n\n for (i = 4; i < data.byteLength; i++) {\n result.samples.push({\n dependsOn: (data[i] & 0x30) >> 4,\n isDependedOn: (data[i] & 0x0c) >> 2,\n hasRedundancy: data[i] & 0x03\n });\n }\n return result;\n },\n sidx: function(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n references: [],\n referenceId: view.getUint32(4),\n timescale: view.getUint32(8),\n earliestPresentationTime: view.getUint32(12),\n firstOffset: view.getUint32(16)\n },\n referenceCount = view.getUint16(22),\n i;\n\n for (i = 24; referenceCount; i += 12, referenceCount--) {\n result.references.push({\n referenceType: (data[i] & 0x80) >>> 7,\n referencedSize: view.getUint32(i) & 0x7FFFFFFF,\n subsegmentDuration: view.getUint32(i + 4),\n startsWithSap: !!(data[i + 8] & 0x80),\n sapType: (data[i + 8] & 0x70) >>> 4,\n sapDeltaTime: view.getUint32(i + 8) & 0x0FFFFFFF\n });\n }\n\n return result;\n },\n smhd: function(data) {\n return {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n balance: data[4] + (data[5] / 256)\n };\n },\n stbl: function(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n stco: function(data) {\n var\n view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n chunkOffsets: []\n },\n entryCount = view.getUint32(4),\n i;\n for (i = 8; entryCount; i += 4, entryCount--) {\n result.chunkOffsets.push(view.getUint32(i));\n }\n return result;\n },\n stsc: function(data) {\n var\n view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n entryCount = view.getUint32(4),\n result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n sampleToChunks: []\n },\n i;\n for (i = 8; entryCount; i += 12, entryCount--) {\n result.sampleToChunks.push({\n firstChunk: view.getUint32(i),\n samplesPerChunk: view.getUint32(i + 4),\n sampleDescriptionIndex: view.getUint32(i + 8)\n });\n }\n return result;\n },\n stsd: function(data) {\n return {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n sampleDescriptions: inspectMp4(data.subarray(8))\n };\n },\n stsz: function(data) {\n var\n view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n sampleSize: view.getUint32(4),\n entries: []\n },\n i;\n for (i = 12; i < data.byteLength; i += 4) {\n result.entries.push(view.getUint32(i));\n }\n return result;\n },\n stts: function(data) {\n var\n view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n timeToSamples: []\n },\n entryCount = view.getUint32(4),\n i;\n\n for (i = 8; entryCount; i += 8, entryCount--) {\n result.timeToSamples.push({\n sampleCount: view.getUint32(i),\n sampleDelta: view.getUint32(i + 4)\n });\n }\n return result;\n },\n styp: function(data) {\n return parse.ftyp(data);\n },\n tfdt: function(data) {\n var result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n baseMediaDecodeTime: data[4] << 24 | data[5] << 16 | data[6] << 8 | data[7]\n };\n if (result.version === 1) {\n result.baseMediaDecodeTime *= Math.pow(2, 32);\n result.baseMediaDecodeTime += data[8] << 24 | data[9] << 16 | data[10] << 8 | data[11];\n }\n return result;\n },\n tfhd: function(data) {\n var\n view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n trackId: view.getUint32(4)\n },\n baseDataOffsetPresent = result.flags[2] & 0x01,\n sampleDescriptionIndexPresent = result.flags[2] & 0x02,\n defaultSampleDurationPresent = result.flags[2] & 0x08,\n defaultSampleSizePresent = result.flags[2] & 0x10,\n defaultSampleFlagsPresent = result.flags[2] & 0x20,\n durationIsEmpty = result.flags[0] & 0x010000,\n defaultBaseIsMoof = result.flags[0] & 0x020000,\n i;\n\n i = 8;\n if (baseDataOffsetPresent) {\n i += 4; // truncate top 4 bytes\n // FIXME: should we read the full 64 bits?\n result.baseDataOffset = view.getUint32(12);\n i += 4;\n }\n if (sampleDescriptionIndexPresent) {\n result.sampleDescriptionIndex = view.getUint32(i);\n i += 4;\n }\n if (defaultSampleDurationPresent) {\n result.defaultSampleDuration = view.getUint32(i);\n i += 4;\n }\n if (defaultSampleSizePresent) {\n result.defaultSampleSize = view.getUint32(i);\n i += 4;\n }\n if (defaultSampleFlagsPresent) {\n result.defaultSampleFlags = view.getUint32(i);\n }\n if (durationIsEmpty) {\n result.durationIsEmpty = true;\n }\n if (!baseDataOffsetPresent && defaultBaseIsMoof) {\n result.baseDataOffsetIsMoof = true;\n }\n return result;\n },\n tkhd: function(data) {\n var\n view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n i = 4,\n result = {\n version: view.getUint8(0),\n flags: new Uint8Array(data.subarray(1, 4))\n };\n if (result.version === 1) {\n i += 4;\n result.creationTime = parseMp4Date(view.getUint32(i)); // truncating top 4 bytes\n i += 8;\n result.modificationTime = parseMp4Date(view.getUint32(i)); // truncating top 4 bytes\n i += 4;\n result.trackId = view.getUint32(i);\n i += 4;\n i += 8;\n result.duration = view.getUint32(i); // truncating top 4 bytes\n } else {\n result.creationTime = parseMp4Date(view.getUint32(i));\n i += 4;\n result.modificationTime = parseMp4Date(view.getUint32(i));\n i += 4;\n result.trackId = view.getUint32(i);\n i += 4;\n i += 4;\n result.duration = view.getUint32(i);\n }\n i += 4;\n i += 2 * 4;\n result.layer = view.getUint16(i);\n i += 2;\n result.alternateGroup = view.getUint16(i);\n i += 2;\n // convert fixed-point, base 16 back to a number\n result.volume = view.getUint8(i) + (view.getUint8(i + 1) / 8);\n i += 2;\n i += 2;\n result.matrix = new Uint32Array(data.subarray(i, i + (9 * 4)));\n i += 9 * 4;\n result.width = view.getUint16(i) + (view.getUint16(i + 2) / 16);\n i += 4;\n result.height = view.getUint16(i) + (view.getUint16(i + 2) / 16);\n return result;\n },\n traf: function(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n trak: function(data) {\n return {\n boxes: inspectMp4(data)\n };\n },\n trex: function(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength);\n return {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n trackId: view.getUint32(4),\n defaultSampleDescriptionIndex: view.getUint32(8),\n defaultSampleDuration: view.getUint32(12),\n defaultSampleSize: view.getUint32(16),\n sampleDependsOn: data[20] & 0x03,\n sampleIsDependedOn: (data[21] & 0xc0) >> 6,\n sampleHasRedundancy: (data[21] & 0x30) >> 4,\n samplePaddingValue: (data[21] & 0x0e) >> 1,\n sampleIsDifferenceSample: !!(data[21] & 0x01),\n sampleDegradationPriority: view.getUint16(22)\n };\n },\n trun: function(data) {\n var\n result = {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n samples: []\n },\n view = new DataView(data.buffer, data.byteOffset, data.byteLength),\n // Flag interpretation\n dataOffsetPresent = result.flags[2] & 0x01, // compare with 2nd byte of 0x1\n firstSampleFlagsPresent = result.flags[2] & 0x04, // compare with 2nd byte of 0x4\n sampleDurationPresent = result.flags[1] & 0x01, // compare with 2nd byte of 0x100\n sampleSizePresent = result.flags[1] & 0x02, // compare with 2nd byte of 0x200\n sampleFlagsPresent = result.flags[1] & 0x04, // compare with 2nd byte of 0x400\n sampleCompositionTimeOffsetPresent = result.flags[1] & 0x08, // compare with 2nd byte of 0x800\n sampleCount = view.getUint32(4),\n offset = 8,\n sample;\n\n if (dataOffsetPresent) {\n // 32 bit signed integer\n result.dataOffset = view.getInt32(offset);\n offset += 4;\n }\n\n // Overrides the flags for the first sample only. The order of\n // optional values will be: duration, size, compositionTimeOffset\n if (firstSampleFlagsPresent && sampleCount) {\n sample = {\n flags: parseSampleFlags(data.subarray(offset, offset + 4))\n };\n offset += 4;\n if (sampleDurationPresent) {\n sample.duration = view.getUint32(offset);\n offset += 4;\n }\n if (sampleSizePresent) {\n sample.size = view.getUint32(offset);\n offset += 4;\n }\n if (sampleCompositionTimeOffsetPresent) {\n // Note: this should be a signed int if version is 1\n sample.compositionTimeOffset = view.getUint32(offset);\n offset += 4;\n }\n result.samples.push(sample);\n sampleCount--;\n }\n\n while (sampleCount--) {\n sample = {};\n if (sampleDurationPresent) {\n sample.duration = view.getUint32(offset);\n offset += 4;\n }\n if (sampleSizePresent) {\n sample.size = view.getUint32(offset);\n offset += 4;\n }\n if (sampleFlagsPresent) {\n sample.flags = parseSampleFlags(data.subarray(offset, offset + 4));\n offset += 4;\n }\n if (sampleCompositionTimeOffsetPresent) {\n // Note: this should be a signed int if version is 1\n sample.compositionTimeOffset = view.getUint32(offset);\n offset += 4;\n }\n result.samples.push(sample);\n }\n return result;\n },\n 'url ': function(data) {\n return {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4))\n };\n },\n vmhd: function(data) {\n var view = new DataView(data.buffer, data.byteOffset, data.byteLength);\n return {\n version: data[0],\n flags: new Uint8Array(data.subarray(1, 4)),\n graphicsmode: view.getUint16(4),\n opcolor: new Uint16Array([view.getUint16(6),\n view.getUint16(8),\n view.getUint16(10)])\n };\n }\n };\n\n\n/**\n * Return a javascript array of box objects parsed from an ISO base\n * media file.\n * @param data {Uint8Array} the binary data of the media to be inspected\n * @return {array} a javascript array of potentially nested box objects\n */\ninspectMp4 = function(data) {\n var\n i = 0,\n result = [],\n view,\n size,\n type,\n end,\n box;\n\n // Convert data from Uint8Array to ArrayBuffer, to follow Dataview API\n var ab = new ArrayBuffer(data.length);\n var v = new Uint8Array(ab);\n for (var z = 0; z < data.length; ++z) {\n v[z] = data[z];\n }\n view = new DataView(ab);\n\n while (i < data.byteLength) {\n // parse box data\n size = view.getUint32(i);\n type = parseType(data.subarray(i + 4, i + 8));\n end = size > 1 ? i + size : data.byteLength;\n\n // parse type-specific data\n box = (parse[type] || function(data) {\n return {\n data: data\n };\n })(data.subarray(i + 8, end));\n box.size = size;\n box.type = type;\n\n // store this box and move to the next\n result.push(box);\n i = end;\n }\n return result;\n};\n\n/**\n * Returns a textual representation of the javascript represtentation\n * of an MP4 file. You can use it as an alternative to\n * JSON.stringify() to compare inspected MP4s.\n * @param inspectedMp4 {array} the parsed array of boxes in an MP4\n * file\n * @param depth {number} (optional) the number of ancestor boxes of\n * the elements of inspectedMp4. Assumed to be zero if unspecified.\n * @return {string} a text representation of the parsed MP4\n */\ntextifyMp4 = function(inspectedMp4, depth) {\n var indent;\n depth = depth || 0;\n indent = new Array(depth * 2 + 1).join(' ');\n\n // iterate over all the boxes\n return inspectedMp4.map(function(box, index) {\n\n // list the box type first at the current indentation level\n return indent + box.type + '\\n' +\n\n // the type is already included and handle child boxes separately\n Object.keys(box).filter(function(key) {\n return key !== 'type' && key !== 'boxes';\n\n // output all the box properties\n }).map(function(key) {\n var prefix = indent + ' ' + key + ': ',\n value = box[key];\n\n // print out raw bytes as hexademical\n if (value instanceof Uint8Array || value instanceof Uint32Array) {\n var bytes = Array.prototype.slice.call(new Uint8Array(value.buffer, value.byteOffset, value.byteLength))\n .map(function(byte) {\n return ' ' + ('00' + byte.toString(16)).slice(-2);\n }).join('').match(/.{1,24}/g);\n if (!bytes) {\n return prefix + '<>';\n }\n if (bytes.length === 1) {\n return prefix + '<' + bytes.join('').slice(1) + '>';\n }\n return prefix + '<\\n' + bytes.map(function(line) {\n return indent + ' ' + line;\n }).join('\\n') + '\\n' + indent + ' >';\n }\n\n // stringify generic objects\n return prefix +\n JSON.stringify(value, null, 2)\n .split('\\n').map(function(line, index) {\n if (index === 0) {\n return line;\n }\n return indent + ' ' + line;\n }).join('\\n');\n }).join('\\n') +\n\n // recursively textify the child boxes\n (box.boxes ? '\\n' + textifyMp4(box.boxes, depth + 1) : '');\n }).join('\\n');\n};\n\nmodule.exports = {\n inspect: inspectMp4,\n textify: textifyMp4,\n parseTfdt: parse.tfdt,\n parseHdlr: parse.hdlr,\n parseTfhd: parse.tfhd,\n parseTrun: parse.trun\n};\n","/**\n * mux.js\n *\n * Copyright (c) 2016 Brightcove\n * All rights reserved.\n *\n * Parse mpeg2 transport stream packets to extract basic timing information\n */\n'use strict';\n\nvar StreamTypes = require('../m2ts/stream-types.js');\nvar handleRollover = require('../m2ts/timestamp-rollover-stream.js').handleRollover;\nvar probe = {};\nprobe.ts = require('../m2ts/probe.js');\nprobe.aac = require('../aac/utils.js');\n\n\nvar\n PES_TIMESCALE = 90000,\n MP2T_PACKET_LENGTH = 188, // bytes\n SYNC_BYTE = 0x47;\n\n/**\n * walks through segment data looking for pat and pmt packets to parse out\n * program map table information\n */\nvar parsePsi_ = function(bytes, pmt) {\n var\n startIndex = 0,\n endIndex = MP2T_PACKET_LENGTH,\n packet, type;\n\n while (endIndex < bytes.byteLength) {\n // Look for a pair of start and end sync bytes in the data..\n if (bytes[startIndex] === SYNC_BYTE && bytes[endIndex] === SYNC_BYTE) {\n // We found a packet\n packet = bytes.subarray(startIndex, endIndex);\n type = probe.ts.parseType(packet, pmt.pid);\n\n switch (type) {\n case 'pat':\n if (!pmt.pid) {\n pmt.pid = probe.ts.parsePat(packet);\n }\n break;\n case 'pmt':\n if (!pmt.table) {\n pmt.table = probe.ts.parsePmt(packet);\n }\n break;\n default:\n break;\n }\n\n // Found the pat and pmt, we can stop walking the segment\n if (pmt.pid && pmt.table) {\n return;\n }\n\n startIndex += MP2T_PACKET_LENGTH;\n endIndex += MP2T_PACKET_LENGTH;\n continue;\n }\n\n // If we get here, we have somehow become de-synchronized and we need to step\n // forward one byte at a time until we find a pair of sync bytes that denote\n // a packet\n startIndex++;\n endIndex++;\n }\n};\n\n/**\n * walks through the segment data from the start and end to get timing information\n * for the first and last audio pes packets\n */\nvar parseAudioPes_ = function(bytes, pmt, result) {\n var\n startIndex = 0,\n endIndex = MP2T_PACKET_LENGTH,\n packet, type, pesType, pusi, parsed;\n\n var endLoop = false;\n\n // Start walking from start of segment to get first audio packet\n while (endIndex <= bytes.byteLength) {\n // Look for a pair of start and end sync bytes in the data..\n if (bytes[startIndex] === SYNC_BYTE &&\n (bytes[endIndex] === SYNC_BYTE || endIndex === bytes.byteLength)) {\n // We found a packet\n packet = bytes.subarray(startIndex, endIndex);\n type = probe.ts.parseType(packet, pmt.pid);\n\n switch (type) {\n case 'pes':\n pesType = probe.ts.parsePesType(packet, pmt.table);\n pusi = probe.ts.parsePayloadUnitStartIndicator(packet);\n if (pesType === 'audio' && pusi) {\n parsed = probe.ts.parsePesTime(packet);\n if (parsed) {\n parsed.type = 'audio';\n result.audio.push(parsed);\n endLoop = true;\n }\n }\n break;\n default:\n break;\n }\n\n if (endLoop) {\n break;\n }\n\n startIndex += MP2T_PACKET_LENGTH;\n endIndex += MP2T_PACKET_LENGTH;\n continue;\n }\n\n // If we get here, we have somehow become de-synchronized and we need to step\n // forward one byte at a time until we find a pair of sync bytes that denote\n // a packet\n startIndex++;\n endIndex++;\n }\n\n // Start walking from end of segment to get last audio packet\n endIndex = bytes.byteLength;\n startIndex = endIndex - MP2T_PACKET_LENGTH;\n endLoop = false;\n while (startIndex >= 0) {\n // Look for a pair of start and end sync bytes in the data..\n if (bytes[startIndex] === SYNC_BYTE &&\n (bytes[endIndex] === SYNC_BYTE || endIndex === bytes.byteLength)) {\n // We found a packet\n packet = bytes.subarray(startIndex, endIndex);\n type = probe.ts.parseType(packet, pmt.pid);\n\n switch (type) {\n case 'pes':\n pesType = probe.ts.parsePesType(packet, pmt.table);\n pusi = probe.ts.parsePayloadUnitStartIndicator(packet);\n if (pesType === 'audio' && pusi) {\n parsed = probe.ts.parsePesTime(packet);\n if (parsed) {\n parsed.type = 'audio';\n result.audio.push(parsed);\n endLoop = true;\n }\n }\n break;\n default:\n break;\n }\n\n if (endLoop) {\n break;\n }\n\n startIndex -= MP2T_PACKET_LENGTH;\n endIndex -= MP2T_PACKET_LENGTH;\n continue;\n }\n\n // If we get here, we have somehow become de-synchronized and we need to step\n // forward one byte at a time until we find a pair of sync bytes that denote\n // a packet\n startIndex--;\n endIndex--;\n }\n};\n\n/**\n * walks through the segment data from the start and end to get timing information\n * for the first and last video pes packets as well as timing information for the first\n * key frame.\n */\nvar parseVideoPes_ = function(bytes, pmt, result) {\n var\n startIndex = 0,\n endIndex = MP2T_PACKET_LENGTH,\n packet, type, pesType, pusi, parsed, frame, i, pes;\n\n var endLoop = false;\n\n var currentFrame = {\n data: [],\n size: 0\n };\n\n // Start walking from start of segment to get first video packet\n while (endIndex < bytes.byteLength) {\n // Look for a pair of start and end sync bytes in the data..\n if (bytes[startIndex] === SYNC_BYTE && bytes[endIndex] === SYNC_BYTE) {\n // We found a packet\n packet = bytes.subarray(startIndex, endIndex);\n type = probe.ts.parseType(packet, pmt.pid);\n\n switch (type) {\n case 'pes':\n pesType = probe.ts.parsePesType(packet, pmt.table);\n pusi = probe.ts.parsePayloadUnitStartIndicator(packet);\n if (pesType === 'video') {\n if (pusi && !endLoop) {\n parsed = probe.ts.parsePesTime(packet);\n if (parsed) {\n parsed.type = 'video';\n result.video.push(parsed);\n endLoop = true;\n }\n }\n if (!result.firstKeyFrame) {\n if (pusi) {\n if (currentFrame.size !== 0) {\n frame = new Uint8Array(currentFrame.size);\n i = 0;\n while (currentFrame.data.length) {\n pes = currentFrame.data.shift();\n frame.set(pes, i);\n i += pes.byteLength;\n }\n if (probe.ts.videoPacketContainsKeyFrame(frame)) {\n result.firstKeyFrame = probe.ts.parsePesTime(frame);\n result.firstKeyFrame.type = 'video';\n }\n currentFrame.size = 0;\n }\n }\n currentFrame.data.push(packet);\n currentFrame.size += packet.byteLength;\n }\n }\n break;\n default:\n break;\n }\n\n if (endLoop && result.firstKeyFrame) {\n break;\n }\n\n startIndex += MP2T_PACKET_LENGTH;\n endIndex += MP2T_PACKET_LENGTH;\n continue;\n }\n\n // If we get here, we have somehow become de-synchronized and we need to step\n // forward one byte at a time until we find a pair of sync bytes that denote\n // a packet\n startIndex++;\n endIndex++;\n }\n\n // Start walking from end of segment to get last video packet\n endIndex = bytes.byteLength;\n startIndex = endIndex - MP2T_PACKET_LENGTH;\n endLoop = false;\n while (startIndex >= 0) {\n // Look for a pair of start and end sync bytes in the data..\n if (bytes[startIndex] === SYNC_BYTE && bytes[endIndex] === SYNC_BYTE) {\n // We found a packet\n packet = bytes.subarray(startIndex, endIndex);\n type = probe.ts.parseType(packet, pmt.pid);\n\n switch (type) {\n case 'pes':\n pesType = probe.ts.parsePesType(packet, pmt.table);\n pusi = probe.ts.parsePayloadUnitStartIndicator(packet);\n if (pesType === 'video' && pusi) {\n parsed = probe.ts.parsePesTime(packet);\n if (parsed) {\n parsed.type = 'video';\n result.video.push(parsed);\n endLoop = true;\n }\n }\n break;\n default:\n break;\n }\n\n if (endLoop) {\n break;\n }\n\n startIndex -= MP2T_PACKET_LENGTH;\n endIndex -= MP2T_PACKET_LENGTH;\n continue;\n }\n\n // If we get here, we have somehow become de-synchronized and we need to step\n // forward one byte at a time until we find a pair of sync bytes that denote\n // a packet\n startIndex--;\n endIndex--;\n }\n};\n\n/**\n * Adjusts the timestamp information for the segment to account for\n * rollover and convert to seconds based on pes packet timescale (90khz clock)\n */\nvar adjustTimestamp_ = function(segmentInfo, baseTimestamp) {\n if (segmentInfo.audio && segmentInfo.audio.length) {\n var audioBaseTimestamp = baseTimestamp;\n if (typeof audioBaseTimestamp === 'undefined') {\n audioBaseTimestamp = segmentInfo.audio[0].dts;\n }\n segmentInfo.audio.forEach(function(info) {\n info.dts = handleRollover(info.dts, audioBaseTimestamp);\n info.pts = handleRollover(info.pts, audioBaseTimestamp);\n // time in seconds\n info.dtsTime = info.dts / PES_TIMESCALE;\n info.ptsTime = info.pts / PES_TIMESCALE;\n });\n }\n\n if (segmentInfo.video && segmentInfo.video.length) {\n var videoBaseTimestamp = baseTimestamp;\n if (typeof videoBaseTimestamp === 'undefined') {\n videoBaseTimestamp = segmentInfo.video[0].dts;\n }\n segmentInfo.video.forEach(function(info) {\n info.dts = handleRollover(info.dts, videoBaseTimestamp);\n info.pts = handleRollover(info.pts, videoBaseTimestamp);\n // time in seconds\n info.dtsTime = info.dts / PES_TIMESCALE;\n info.ptsTime = info.pts / PES_TIMESCALE;\n });\n if (segmentInfo.firstKeyFrame) {\n var frame = segmentInfo.firstKeyFrame;\n frame.dts = handleRollover(frame.dts, videoBaseTimestamp);\n frame.pts = handleRollover(frame.pts, videoBaseTimestamp);\n // time in seconds\n frame.dtsTime = frame.dts / PES_TIMESCALE;\n frame.ptsTime = frame.dts / PES_TIMESCALE;\n }\n }\n};\n\n/**\n * inspects the aac data stream for start and end time information\n */\nvar inspectAac_ = function(bytes) {\n var\n endLoop = false,\n audioCount = 0,\n sampleRate = null,\n timestamp = null,\n frameSize = 0,\n byteIndex = 0,\n packet;\n\n while (bytes.length - byteIndex >= 3) {\n var type = probe.aac.parseType(bytes, byteIndex);\n switch (type) {\n case 'timed-metadata':\n // Exit early because we don't have enough to parse\n // the ID3 tag header\n if (bytes.length - byteIndex < 10) {\n endLoop = true;\n break;\n }\n\n frameSize = probe.aac.parseId3TagSize(bytes, byteIndex);\n\n // Exit early if we don't have enough in the buffer\n // to emit a full packet\n if (frameSize > bytes.length) {\n endLoop = true;\n break;\n }\n if (timestamp === null) {\n packet = bytes.subarray(byteIndex, byteIndex + frameSize);\n timestamp = probe.aac.parseAacTimestamp(packet);\n }\n byteIndex += frameSize;\n break;\n case 'audio':\n // Exit early because we don't have enough to parse\n // the ADTS frame header\n if (bytes.length - byteIndex < 7) {\n endLoop = true;\n break;\n }\n\n frameSize = probe.aac.parseAdtsSize(bytes, byteIndex);\n\n // Exit early if we don't have enough in the buffer\n // to emit a full packet\n if (frameSize > bytes.length) {\n endLoop = true;\n break;\n }\n if (sampleRate === null) {\n packet = bytes.subarray(byteIndex, byteIndex + frameSize);\n sampleRate = probe.aac.parseSampleRate(packet);\n }\n audioCount++;\n byteIndex += frameSize;\n break;\n default:\n byteIndex++;\n break;\n }\n if (endLoop) {\n return null;\n }\n }\n if (sampleRate === null || timestamp === null) {\n return null;\n }\n\n var audioTimescale = PES_TIMESCALE / sampleRate;\n\n var result = {\n audio: [\n {\n type: 'audio',\n dts: timestamp,\n pts: timestamp\n },\n {\n type: 'audio',\n dts: timestamp + (audioCount * 1024 * audioTimescale),\n pts: timestamp + (audioCount * 1024 * audioTimescale)\n }\n ]\n };\n\n return result;\n};\n\n/**\n * inspects the transport stream segment data for start and end time information\n * of the audio and video tracks (when present) as well as the first key frame's\n * start time.\n */\nvar inspectTs_ = function(bytes) {\n var pmt = {\n pid: null,\n table: null\n };\n\n var result = {};\n\n parsePsi_(bytes, pmt);\n\n for (var pid in pmt.table) {\n if (pmt.table.hasOwnProperty(pid)) {\n var type = pmt.table[pid];\n switch (type) {\n case StreamTypes.H264_STREAM_TYPE:\n result.video = [];\n parseVideoPes_(bytes, pmt, result);\n if (result.video.length === 0) {\n delete result.video;\n }\n break;\n case StreamTypes.ADTS_STREAM_TYPE:\n result.audio = [];\n parseAudioPes_(bytes, pmt, result);\n if (result.audio.length === 0) {\n delete result.audio;\n }\n break;\n default:\n break;\n }\n }\n }\n return result;\n};\n\n/**\n * Inspects segment byte data and returns an object with start and end timing information\n *\n * @param {Uint8Array} bytes The segment byte data\n * @param {Number} baseTimestamp Relative reference timestamp used when adjusting frame\n * timestamps for rollover. This value must be in 90khz clock.\n * @return {Object} Object containing start and end frame timing info of segment.\n */\nvar inspect = function(bytes, baseTimestamp) {\n var isAacData = probe.aac.isLikelyAacData(bytes);\n\n var result;\n\n if (isAacData) {\n result = inspectAac_(bytes);\n } else {\n result = inspectTs_(bytes);\n }\n\n if (!result || (!result.audio && !result.video)) {\n return null;\n }\n\n adjustTimestamp_(result, baseTimestamp);\n\n return result;\n};\n\nmodule.exports = {\n inspect: inspect,\n parseAudioPes_: parseAudioPes_\n};\n","/**\n * mux.js\n *\n * Copyright (c) 2016 Brightcove\n * All rights reserved.\n *\n * Utilities to detect basic properties and metadata about TS Segments.\n */\n'use strict';\n\nvar StreamTypes = require('./stream-types.js');\n\nvar parsePid = function(packet) {\n var pid = packet[1] & 0x1f;\n pid <<= 8;\n pid |= packet[2];\n return pid;\n};\n\nvar parsePayloadUnitStartIndicator = function(packet) {\n return !!(packet[1] & 0x40);\n};\n\nvar parseAdaptionField = function(packet) {\n var offset = 0;\n // if an adaption field is present, its length is specified by the\n // fifth byte of the TS packet header. The adaptation field is\n // used to add stuffing to PES packets that don't fill a complete\n // TS packet, and to specify some forms of timing and control data\n // that we do not currently use.\n if (((packet[3] & 0x30) >>> 4) > 0x01) {\n offset += packet[4] + 1;\n }\n return offset;\n};\n\nvar parseType = function(packet, pmtPid) {\n var pid = parsePid(packet);\n if (pid === 0) {\n return 'pat';\n } else if (pid === pmtPid) {\n return 'pmt';\n } else if (pmtPid) {\n return 'pes';\n }\n return null;\n};\n\nvar parsePat = function(packet) {\n var pusi = parsePayloadUnitStartIndicator(packet);\n var offset = 4 + parseAdaptionField(packet);\n\n if (pusi) {\n offset += packet[offset] + 1;\n }\n\n return (packet[offset + 10] & 0x1f) << 8 | packet[offset + 11];\n};\n\nvar parsePmt = function(packet) {\n var programMapTable = {};\n var pusi = parsePayloadUnitStartIndicator(packet);\n var payloadOffset = 4 + parseAdaptionField(packet);\n\n if (pusi) {\n payloadOffset += packet[payloadOffset] + 1;\n }\n\n // PMTs can be sent ahead of the time when they should actually\n // take effect. We don't believe this should ever be the case\n // for HLS but we'll ignore \"forward\" PMT declarations if we see\n // them. Future PMT declarations have the current_next_indicator\n // set to zero.\n if (!(packet[payloadOffset + 5] & 0x01)) {\n return;\n }\n\n var sectionLength, tableEnd, programInfoLength;\n // the mapping table ends at the end of the current section\n sectionLength = (packet[payloadOffset + 1] & 0x0f) << 8 | packet[payloadOffset + 2];\n tableEnd = 3 + sectionLength - 4;\n\n // to determine where the table is, we have to figure out how\n // long the program info descriptors are\n programInfoLength = (packet[payloadOffset + 10] & 0x0f) << 8 | packet[payloadOffset + 11];\n\n // advance the offset to the first entry in the mapping table\n var offset = 12 + programInfoLength;\n while (offset < tableEnd) {\n var i = payloadOffset + offset;\n // add an entry that maps the elementary_pid to the stream_type\n programMapTable[(packet[i + 1] & 0x1F) << 8 | packet[i + 2]] = packet[i];\n\n // move to the next table entry\n // skip past the elementary stream descriptors, if present\n offset += ((packet[i + 3] & 0x0F) << 8 | packet[i + 4]) + 5;\n }\n return programMapTable;\n};\n\nvar parsePesType = function(packet, programMapTable) {\n var pid = parsePid(packet);\n var type = programMapTable[pid];\n switch (type) {\n case StreamTypes.H264_STREAM_TYPE:\n return 'video';\n case StreamTypes.ADTS_STREAM_TYPE:\n return 'audio';\n case StreamTypes.METADATA_STREAM_TYPE:\n return 'timed-metadata';\n default:\n return null;\n }\n};\n\nvar parsePesTime = function(packet) {\n var pusi = parsePayloadUnitStartIndicator(packet);\n if (!pusi) {\n return null;\n }\n\n var offset = 4 + parseAdaptionField(packet);\n\n if (offset >= packet.byteLength) {\n // From the H 222.0 MPEG-TS spec\n // \"For transport stream packets carrying PES packets, stuffing is needed when there\n // is insufficient PES packet data to completely fill the transport stream packet\n // payload bytes. Stuffing is accomplished by defining an adaptation field longer than\n // the sum of the lengths of the data elements in it, so that the payload bytes\n // remaining after the adaptation field exactly accommodates the available PES packet\n // data.\"\n //\n // If the offset is >= the length of the packet, then the packet contains no data\n // and instead is just adaption field stuffing bytes\n return null;\n }\n\n var pes = null;\n var ptsDtsFlags;\n\n // PES packets may be annotated with a PTS value, or a PTS value\n // and a DTS value. Determine what combination of values is\n // available to work with.\n ptsDtsFlags = packet[offset + 7];\n\n // PTS and DTS are normally stored as a 33-bit number. Javascript\n // performs all bitwise operations on 32-bit integers but javascript\n // supports a much greater range (52-bits) of integer using standard\n // mathematical operations.\n // We construct a 31-bit value using bitwise operators over the 31\n // most significant bits and then multiply by 4 (equal to a left-shift\n // of 2) before we add the final 2 least significant bits of the\n // timestamp (equal to an OR.)\n if (ptsDtsFlags & 0xC0) {\n pes = {};\n // the PTS and DTS are not written out directly. For information\n // on how they are encoded, see\n // http://dvd.sourceforge.net/dvdinfo/pes-hdr.html\n pes.pts = (packet[offset + 9] & 0x0E) << 27 |\n (packet[offset + 10] & 0xFF) << 20 |\n (packet[offset + 11] & 0xFE) << 12 |\n (packet[offset + 12] & 0xFF) << 5 |\n (packet[offset + 13] & 0xFE) >>> 3;\n pes.pts *= 4; // Left shift by 2\n pes.pts += (packet[offset + 13] & 0x06) >>> 1; // OR by the two LSBs\n pes.dts = pes.pts;\n if (ptsDtsFlags & 0x40) {\n pes.dts = (packet[offset + 14] & 0x0E) << 27 |\n (packet[offset + 15] & 0xFF) << 20 |\n (packet[offset + 16] & 0xFE) << 12 |\n (packet[offset + 17] & 0xFF) << 5 |\n (packet[offset + 18] & 0xFE) >>> 3;\n pes.dts *= 4; // Left shift by 2\n pes.dts += (packet[offset + 18] & 0x06) >>> 1; // OR by the two LSBs\n }\n }\n return pes;\n};\n\nvar parseNalUnitType = function(type) {\n switch (type) {\n case 0x05:\n return 'slice_layer_without_partitioning_rbsp_idr';\n case 0x06:\n return 'sei_rbsp';\n case 0x07:\n return 'seq_parameter_set_rbsp';\n case 0x08:\n return 'pic_parameter_set_rbsp';\n case 0x09:\n return 'access_unit_delimiter_rbsp';\n default:\n return null;\n }\n};\n\nvar videoPacketContainsKeyFrame = function(packet) {\n var offset = 4 + parseAdaptionField(packet);\n var frameBuffer = packet.subarray(offset);\n var frameI = 0;\n var frameSyncPoint = 0;\n var foundKeyFrame = false;\n var nalType;\n\n // advance the sync point to a NAL start, if necessary\n for (; frameSyncPoint < frameBuffer.byteLength - 3; frameSyncPoint++) {\n if (frameBuffer[frameSyncPoint + 2] === 1) {\n // the sync point is properly aligned\n frameI = frameSyncPoint + 5;\n break;\n }\n }\n\n while (frameI < frameBuffer.byteLength) {\n // look at the current byte to determine if we've hit the end of\n // a NAL unit boundary\n switch (frameBuffer[frameI]) {\n case 0:\n // skip past non-sync sequences\n if (frameBuffer[frameI - 1] !== 0) {\n frameI += 2;\n break;\n } else if (frameBuffer[frameI - 2] !== 0) {\n frameI++;\n break;\n }\n\n if (frameSyncPoint + 3 !== frameI - 2) {\n nalType = parseNalUnitType(frameBuffer[frameSyncPoint + 3] & 0x1f);\n if (nalType === 'slice_layer_without_partitioning_rbsp_idr') {\n foundKeyFrame = true;\n }\n }\n\n // drop trailing zeroes\n do {\n frameI++;\n } while (frameBuffer[frameI] !== 1 && frameI < frameBuffer.length);\n frameSyncPoint = frameI - 2;\n frameI += 3;\n break;\n case 1:\n // skip past non-sync sequences\n if (frameBuffer[frameI - 1] !== 0 ||\n frameBuffer[frameI - 2] !== 0) {\n frameI += 3;\n break;\n }\n\n nalType = parseNalUnitType(frameBuffer[frameSyncPoint + 3] & 0x1f);\n if (nalType === 'slice_layer_without_partitioning_rbsp_idr') {\n foundKeyFrame = true;\n }\n frameSyncPoint = frameI - 2;\n frameI += 3;\n break;\n default:\n // the current byte isn't a one or zero, so it cannot be part\n // of a sync sequence\n frameI += 3;\n break;\n }\n }\n frameBuffer = frameBuffer.subarray(frameSyncPoint);\n frameI -= frameSyncPoint;\n frameSyncPoint = 0;\n // parse the final nal\n if (frameBuffer && frameBuffer.byteLength > 3) {\n nalType = parseNalUnitType(frameBuffer[frameSyncPoint + 3] & 0x1f);\n if (nalType === 'slice_layer_without_partitioning_rbsp_idr') {\n foundKeyFrame = true;\n }\n }\n\n return foundKeyFrame;\n};\n\n\nmodule.exports = {\n parseType: parseType,\n parsePat: parsePat,\n parsePmt: parsePmt,\n parsePayloadUnitStartIndicator: parsePayloadUnitStartIndicator,\n parsePesType: parsePesType,\n parsePesTime: parsePesTime,\n videoPacketContainsKeyFrame: videoPacketContainsKeyFrame\n};\n","\n/**\n * When source maps are enabled, `style-loader` uses a link element with a data-uri to\n * embed the css on the page. This breaks all relative urls because now they are relative to a\n * bundle instead of the current page.\n *\n * One solution is to only use full urls, but that may be impossible.\n *\n * Instead, this function \"fixes\" the relative urls to be absolute according to the current page location.\n *\n * A rudimentary test suite is located at `test/fixUrls.js` and can be run via the `npm test` command.\n *\n */\n\nmodule.exports = function (css) {\n // get current location\n var location = typeof window !== \"undefined\" && window.location;\n\n if (!location) {\n throw new Error(\"fixUrls requires window.location\");\n }\n\n\t// blank or null?\n\tif (!css || typeof css !== \"string\") {\n\t return css;\n }\n\n var baseUrl = location.protocol + \"//\" + location.host;\n var currentDir = baseUrl + location.pathname.replace(/\\/[^\\/]*$/, \"/\");\n\n\t// convert each url(...)\n\t/*\n\tThis regular expression is just a way to recursively match brackets within\n\ta string.\n\n\t /url\\s*\\( = Match on the word \"url\" with any whitespace after it and then a parens\n\t ( = Start a capturing group\n\t (?: = Start a non-capturing group\n\t [^)(] = Match anything that isn't a parentheses\n\t | = OR\n\t \\( = Match a start parentheses\n\t (?: = Start another non-capturing groups\n\t [^)(]+ = Match anything that isn't a parentheses\n\t | = OR\n\t \\( = Match a start parentheses\n\t [^)(]* = Match anything that isn't a parentheses\n\t \\) = Match a end parentheses\n\t ) = End Group\n *\\) = Match anything and then a close parens\n ) = Close non-capturing group\n * = Match anything\n ) = Close capturing group\n\t \\) = Match a close parens\n\n\t /gi = Get all matches, not the first. Be case insensitive.\n\t */\n\tvar fixedCss = css.replace(/url\\s*\\(((?:[^)(]|\\((?:[^)(]+|\\([^)(]*\\))*\\))*)\\)/gi, function(fullMatch, origUrl) {\n\t\t// strip quotes (if they exist)\n\t\tvar unquotedOrigUrl = origUrl\n\t\t\t.trim()\n\t\t\t.replace(/^\"(.*)\"$/, function(o, $1){ return $1; })\n\t\t\t.replace(/^'(.*)'$/, function(o, $1){ return $1; });\n\n\t\t// already a full url? no change\n\t\tif (/^(#|data:|http:\\/\\/|https:\\/\\/|file:\\/\\/\\/|\\s*$)/i.test(unquotedOrigUrl)) {\n\t\t return fullMatch;\n\t\t}\n\n\t\t// convert the url to a full url\n\t\tvar newUrl;\n\n\t\tif (unquotedOrigUrl.indexOf(\"//\") === 0) {\n\t\t \t//TODO: should we add protocol?\n\t\t\tnewUrl = unquotedOrigUrl;\n\t\t} else if (unquotedOrigUrl.indexOf(\"/\") === 0) {\n\t\t\t// path should be relative to the base url\n\t\t\tnewUrl = baseUrl + unquotedOrigUrl; // already starts with '/'\n\t\t} else {\n\t\t\t// path should be relative to current directory\n\t\t\tnewUrl = currentDir + unquotedOrigUrl.replace(/^\\.\\//, \"\"); // Strip leading './'\n\t\t}\n\n\t\t// send back the fixed url(...)\n\t\treturn \"url(\" + JSON.stringify(newUrl) + \")\";\n\t});\n\n\t// send back the fixed css\n\treturn fixedCss;\n};\n","exports = module.exports = require(\"../../css-loader/dist/runtime/api.js\")(false);\n// Module\nexports.push([module.id, \".video-js .vjs-big-play-button .vjs-icon-placeholder:before, .vjs-button > .vjs-icon-placeholder:before, .video-js .vjs-modal-dialog, .vjs-modal-dialog .vjs-modal-dialog-content {\\n position: absolute;\\n top: 0;\\n left: 0;\\n width: 100%;\\n height: 100%; }\\n\\n.video-js .vjs-big-play-button .vjs-icon-placeholder:before, .vjs-button > .vjs-icon-placeholder:before {\\n text-align: center; }\\n\\n@font-face {\\n font-family: VideoJS;\\n src: url(data:application/font-woff;charset=utf-8;base64,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) format(\\\"woff\\\");\\n font-weight: normal;\\n font-style: normal; }\\n\\n.vjs-icon-play, .video-js .vjs-big-play-button .vjs-icon-placeholder:before, .video-js .vjs-play-control .vjs-icon-placeholder {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-play:before, .video-js .vjs-big-play-button .vjs-icon-placeholder:before, .video-js .vjs-play-control .vjs-icon-placeholder:before {\\n content: \\\"\\\\f101\\\"; }\\n\\n.vjs-icon-play-circle {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-play-circle:before {\\n content: \\\"\\\\f102\\\"; }\\n\\n.vjs-icon-pause, .video-js .vjs-play-control.vjs-playing .vjs-icon-placeholder {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-pause:before, .video-js .vjs-play-control.vjs-playing .vjs-icon-placeholder:before {\\n content: \\\"\\\\f103\\\"; }\\n\\n.vjs-icon-volume-mute, .video-js .vjs-mute-control.vjs-vol-0 .vjs-icon-placeholder {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-volume-mute:before, .video-js .vjs-mute-control.vjs-vol-0 .vjs-icon-placeholder:before {\\n content: \\\"\\\\f104\\\"; }\\n\\n.vjs-icon-volume-low, .video-js .vjs-mute-control.vjs-vol-1 .vjs-icon-placeholder {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-volume-low:before, .video-js .vjs-mute-control.vjs-vol-1 .vjs-icon-placeholder:before {\\n content: \\\"\\\\f105\\\"; }\\n\\n.vjs-icon-volume-mid, .video-js .vjs-mute-control.vjs-vol-2 .vjs-icon-placeholder {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-volume-mid:before, .video-js .vjs-mute-control.vjs-vol-2 .vjs-icon-placeholder:before {\\n content: \\\"\\\\f106\\\"; }\\n\\n.vjs-icon-volume-high, .video-js .vjs-mute-control .vjs-icon-placeholder {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-volume-high:before, .video-js .vjs-mute-control .vjs-icon-placeholder:before {\\n content: \\\"\\\\f107\\\"; }\\n\\n.vjs-icon-fullscreen-enter, .video-js .vjs-fullscreen-control .vjs-icon-placeholder {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-fullscreen-enter:before, .video-js .vjs-fullscreen-control .vjs-icon-placeholder:before {\\n content: \\\"\\\\f108\\\"; }\\n\\n.vjs-icon-fullscreen-exit, .video-js.vjs-fullscreen .vjs-fullscreen-control .vjs-icon-placeholder {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-fullscreen-exit:before, .video-js.vjs-fullscreen .vjs-fullscreen-control .vjs-icon-placeholder:before {\\n content: \\\"\\\\f109\\\"; }\\n\\n.vjs-icon-square {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-square:before {\\n content: \\\"\\\\f10a\\\"; }\\n\\n.vjs-icon-spinner {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-spinner:before {\\n content: \\\"\\\\f10b\\\"; }\\n\\n.vjs-icon-subtitles, .video-js .vjs-subtitles-button .vjs-icon-placeholder, .video-js .vjs-subs-caps-button .vjs-icon-placeholder,\\n.video-js.video-js:lang(en-GB) .vjs-subs-caps-button .vjs-icon-placeholder,\\n.video-js.video-js:lang(en-IE) .vjs-subs-caps-button .vjs-icon-placeholder,\\n.video-js.video-js:lang(en-AU) .vjs-subs-caps-button .vjs-icon-placeholder,\\n.video-js.video-js:lang(en-NZ) .vjs-subs-caps-button .vjs-icon-placeholder {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-subtitles:before, .video-js .vjs-subtitles-button .vjs-icon-placeholder:before, .video-js .vjs-subs-caps-button .vjs-icon-placeholder:before,\\n .video-js.video-js:lang(en-GB) .vjs-subs-caps-button .vjs-icon-placeholder:before,\\n .video-js.video-js:lang(en-IE) .vjs-subs-caps-button .vjs-icon-placeholder:before,\\n .video-js.video-js:lang(en-AU) .vjs-subs-caps-button .vjs-icon-placeholder:before,\\n .video-js.video-js:lang(en-NZ) .vjs-subs-caps-button .vjs-icon-placeholder:before {\\n content: \\\"\\\\f10c\\\"; }\\n\\n.vjs-icon-captions, .video-js .vjs-captions-button .vjs-icon-placeholder, .video-js:lang(en) .vjs-subs-caps-button .vjs-icon-placeholder,\\n.video-js:lang(fr-CA) .vjs-subs-caps-button .vjs-icon-placeholder {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-captions:before, .video-js .vjs-captions-button .vjs-icon-placeholder:before, .video-js:lang(en) .vjs-subs-caps-button .vjs-icon-placeholder:before,\\n .video-js:lang(fr-CA) .vjs-subs-caps-button .vjs-icon-placeholder:before {\\n content: \\\"\\\\f10d\\\"; }\\n\\n.vjs-icon-chapters, .video-js .vjs-chapters-button .vjs-icon-placeholder {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-chapters:before, .video-js .vjs-chapters-button .vjs-icon-placeholder:before {\\n content: \\\"\\\\f10e\\\"; }\\n\\n.vjs-icon-share {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-share:before {\\n content: \\\"\\\\f10f\\\"; }\\n\\n.vjs-icon-cog {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-cog:before {\\n content: \\\"\\\\f110\\\"; }\\n\\n.vjs-icon-circle, .video-js .vjs-play-progress, .video-js .vjs-volume-level, .vjs-seek-to-live-control .vjs-icon-placeholder {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-circle:before, .video-js .vjs-play-progress:before, .video-js .vjs-volume-level:before, .vjs-seek-to-live-control .vjs-icon-placeholder:before {\\n content: \\\"\\\\f111\\\"; }\\n\\n.vjs-icon-circle-outline {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-circle-outline:before {\\n content: \\\"\\\\f112\\\"; }\\n\\n.vjs-icon-circle-inner-circle {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-circle-inner-circle:before {\\n content: \\\"\\\\f113\\\"; }\\n\\n.vjs-icon-hd {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-hd:before {\\n content: \\\"\\\\f114\\\"; }\\n\\n.vjs-icon-cancel, .video-js .vjs-control.vjs-close-button .vjs-icon-placeholder {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-cancel:before, .video-js .vjs-control.vjs-close-button .vjs-icon-placeholder:before {\\n content: \\\"\\\\f115\\\"; }\\n\\n.vjs-icon-replay, .video-js .vjs-play-control.vjs-ended .vjs-icon-placeholder {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-replay:before, .video-js .vjs-play-control.vjs-ended .vjs-icon-placeholder:before {\\n content: \\\"\\\\f116\\\"; }\\n\\n.vjs-icon-facebook {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-facebook:before {\\n content: \\\"\\\\f117\\\"; }\\n\\n.vjs-icon-gplus {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-gplus:before {\\n content: \\\"\\\\f118\\\"; }\\n\\n.vjs-icon-linkedin {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-linkedin:before {\\n content: \\\"\\\\f119\\\"; }\\n\\n.vjs-icon-twitter {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-twitter:before {\\n content: \\\"\\\\f11a\\\"; }\\n\\n.vjs-icon-tumblr {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-tumblr:before {\\n content: \\\"\\\\f11b\\\"; }\\n\\n.vjs-icon-pinterest {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-pinterest:before {\\n content: \\\"\\\\f11c\\\"; }\\n\\n.vjs-icon-audio-description, .video-js .vjs-descriptions-button .vjs-icon-placeholder {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-audio-description:before, .video-js .vjs-descriptions-button .vjs-icon-placeholder:before {\\n content: \\\"\\\\f11d\\\"; }\\n\\n.vjs-icon-audio, .video-js .vjs-audio-button .vjs-icon-placeholder {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-audio:before, .video-js .vjs-audio-button .vjs-icon-placeholder:before {\\n content: \\\"\\\\f11e\\\"; }\\n\\n.vjs-icon-next-item {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-next-item:before {\\n content: \\\"\\\\f11f\\\"; }\\n\\n.vjs-icon-previous-item {\\n font-family: VideoJS;\\n font-weight: normal;\\n font-style: normal; }\\n .vjs-icon-previous-item:before {\\n content: \\\"\\\\f120\\\"; }\\n\\n.video-js {\\n display: block;\\n vertical-align: top;\\n box-sizing: border-box;\\n color: #fff;\\n background-color: #000;\\n position: relative;\\n padding: 0;\\n font-size: 10px;\\n line-height: 1;\\n font-weight: normal;\\n font-style: normal;\\n font-family: Arial, Helvetica, sans-serif;\\n word-break: initial; }\\n .video-js:-moz-full-screen {\\n position: absolute; }\\n .video-js:-webkit-full-screen {\\n width: 100% !important;\\n height: 100% !important; }\\n\\n.video-js[tabindex=\\\"-1\\\"] {\\n outline: none; }\\n\\n.video-js *,\\n.video-js *:before,\\n.video-js *:after {\\n box-sizing: inherit; }\\n\\n.video-js ul {\\n font-family: inherit;\\n font-size: inherit;\\n line-height: inherit;\\n list-style-position: outside;\\n margin-left: 0;\\n margin-right: 0;\\n margin-top: 0;\\n margin-bottom: 0; }\\n\\n.video-js.vjs-fluid,\\n.video-js.vjs-16-9,\\n.video-js.vjs-4-3 {\\n width: 100%;\\n max-width: 100%;\\n height: 0; }\\n\\n.video-js.vjs-16-9 {\\n padding-top: 56.25%; }\\n\\n.video-js.vjs-4-3 {\\n padding-top: 75%; }\\n\\n.video-js.vjs-fill {\\n width: 100%;\\n height: 100%; }\\n\\n.video-js .vjs-tech {\\n position: absolute;\\n top: 0;\\n left: 0;\\n width: 100%;\\n height: 100%; }\\n\\nbody.vjs-full-window {\\n padding: 0;\\n margin: 0;\\n height: 100%; }\\n\\n.vjs-full-window .video-js.vjs-fullscreen {\\n position: fixed;\\n overflow: hidden;\\n z-index: 1000;\\n left: 0;\\n top: 0;\\n bottom: 0;\\n right: 0; }\\n\\n.video-js.vjs-fullscreen {\\n width: 100% !important;\\n height: 100% !important;\\n padding-top: 0 !important; }\\n\\n.video-js.vjs-fullscreen.vjs-user-inactive {\\n cursor: none; }\\n\\n.vjs-hidden {\\n display: none !important; }\\n\\n.vjs-disabled {\\n opacity: 0.5;\\n cursor: default; }\\n\\n.video-js .vjs-offscreen {\\n height: 1px;\\n left: -9999px;\\n position: absolute;\\n top: 0;\\n width: 1px; }\\n\\n.vjs-lock-showing {\\n display: block !important;\\n opacity: 1;\\n visibility: visible; }\\n\\n.vjs-no-js {\\n padding: 20px;\\n color: #fff;\\n background-color: #000;\\n font-size: 18px;\\n font-family: Arial, Helvetica, sans-serif;\\n text-align: center;\\n width: 300px;\\n height: 150px;\\n margin: 0px auto; }\\n\\n.vjs-no-js a,\\n.vjs-no-js a:visited {\\n color: #66A8CC; }\\n\\n.video-js .vjs-big-play-button {\\n font-size: 3em;\\n line-height: 1.5em;\\n height: 1.5em;\\n width: 3em;\\n display: block;\\n position: absolute;\\n top: 10px;\\n left: 10px;\\n padding: 0;\\n cursor: pointer;\\n opacity: 1;\\n border: 0.06666em solid #fff;\\n background-color: #2B333F;\\n background-color: rgba(43, 51, 63, 0.7);\\n border-radius: 0.3em;\\n transition: all 0.4s; }\\n\\n.vjs-big-play-centered .vjs-big-play-button {\\n top: 50%;\\n left: 50%;\\n margin-top: -0.75em;\\n margin-left: -1.5em; }\\n\\n.video-js:hover .vjs-big-play-button,\\n.video-js .vjs-big-play-button:focus {\\n border-color: #fff;\\n background-color: #73859f;\\n background-color: rgba(115, 133, 159, 0.5);\\n transition: all 0s; }\\n\\n.vjs-controls-disabled .vjs-big-play-button,\\n.vjs-has-started .vjs-big-play-button,\\n.vjs-using-native-controls .vjs-big-play-button,\\n.vjs-error .vjs-big-play-button {\\n display: none; }\\n\\n.vjs-has-started.vjs-paused.vjs-show-big-play-button-on-pause .vjs-big-play-button {\\n display: block; }\\n\\n.video-js button {\\n background: none;\\n border: none;\\n color: inherit;\\n display: inline-block;\\n font-size: inherit;\\n line-height: inherit;\\n text-transform: none;\\n text-decoration: none;\\n transition: none;\\n -webkit-appearance: none;\\n -moz-appearance: none;\\n appearance: none; }\\n\\n.vjs-control .vjs-button {\\n width: 100%;\\n height: 100%; }\\n\\n.video-js .vjs-control.vjs-close-button {\\n cursor: pointer;\\n height: 3em;\\n position: absolute;\\n right: 0;\\n top: 0.5em;\\n z-index: 2; }\\n\\n.video-js .vjs-modal-dialog {\\n background: rgba(0, 0, 0, 0.8);\\n background: linear-gradient(180deg, rgba(0, 0, 0, 0.8), rgba(255, 255, 255, 0));\\n overflow: auto; }\\n\\n.video-js .vjs-modal-dialog > * {\\n box-sizing: border-box; }\\n\\n.vjs-modal-dialog .vjs-modal-dialog-content {\\n font-size: 1.2em;\\n line-height: 1.5;\\n padding: 20px 24px;\\n z-index: 1; }\\n\\n.vjs-menu-button {\\n cursor: pointer; }\\n\\n.vjs-menu-button.vjs-disabled {\\n cursor: default; }\\n\\n.vjs-workinghover .vjs-menu-button.vjs-disabled:hover .vjs-menu {\\n display: none; }\\n\\n.vjs-menu .vjs-menu-content {\\n display: block;\\n padding: 0;\\n margin: 0;\\n font-family: Arial, Helvetica, sans-serif;\\n overflow: auto; }\\n\\n.vjs-menu .vjs-menu-content > * {\\n box-sizing: border-box; }\\n\\n.vjs-scrubbing .vjs-control.vjs-menu-button:hover .vjs-menu {\\n display: none; }\\n\\n.vjs-menu li {\\n list-style: none;\\n margin: 0;\\n padding: 0.2em 0;\\n line-height: 1.4em;\\n font-size: 1.2em;\\n text-align: center;\\n text-transform: lowercase; }\\n\\n.vjs-menu li.vjs-menu-item:focus,\\n.vjs-menu li.vjs-menu-item:hover,\\n.js-focus-visible .vjs-menu li.vjs-menu-item:hover {\\n background-color: #73859f;\\n background-color: rgba(115, 133, 159, 0.5); }\\n\\n.vjs-menu li.vjs-selected,\\n.vjs-menu li.vjs-selected:focus,\\n.vjs-menu li.vjs-selected:hover,\\n.js-focus-visible .vjs-menu li.vjs-selected:hover {\\n background-color: #fff;\\n color: #2B333F; }\\n\\n.vjs-menu li.vjs-menu-title {\\n text-align: center;\\n text-transform: uppercase;\\n font-size: 1em;\\n line-height: 2em;\\n padding: 0;\\n margin: 0 0 0.3em 0;\\n font-weight: bold;\\n cursor: default; }\\n\\n.vjs-menu-button-popup .vjs-menu {\\n display: none;\\n position: absolute;\\n bottom: 0;\\n width: 10em;\\n left: -3em;\\n height: 0em;\\n margin-bottom: 1.5em;\\n border-top-color: rgba(43, 51, 63, 0.7); }\\n\\n.vjs-menu-button-popup .vjs-menu .vjs-menu-content {\\n background-color: #2B333F;\\n background-color: rgba(43, 51, 63, 0.7);\\n position: absolute;\\n width: 100%;\\n bottom: 1.5em;\\n max-height: 15em; }\\n\\n.vjs-workinghover .vjs-menu-button-popup:hover .vjs-menu,\\n.vjs-menu-button-popup .vjs-menu.vjs-lock-showing {\\n display: block; }\\n\\n.video-js .vjs-menu-button-inline {\\n transition: all 0.4s;\\n overflow: hidden; }\\n\\n.video-js .vjs-menu-button-inline:before {\\n width: 2.222222222em; }\\n\\n.video-js .vjs-menu-button-inline:hover,\\n.video-js .vjs-menu-button-inline:focus,\\n.video-js .vjs-menu-button-inline.vjs-slider-active,\\n.video-js.vjs-no-flex .vjs-menu-button-inline {\\n width: 12em; }\\n\\n.vjs-menu-button-inline .vjs-menu {\\n opacity: 0;\\n height: 100%;\\n width: auto;\\n position: absolute;\\n left: 4em;\\n top: 0;\\n padding: 0;\\n margin: 0;\\n transition: all 0.4s; }\\n\\n.vjs-menu-button-inline:hover .vjs-menu,\\n.vjs-menu-button-inline:focus .vjs-menu,\\n.vjs-menu-button-inline.vjs-slider-active .vjs-menu {\\n display: block;\\n opacity: 1; }\\n\\n.vjs-no-flex .vjs-menu-button-inline .vjs-menu {\\n display: block;\\n opacity: 1;\\n position: relative;\\n width: auto; }\\n\\n.vjs-no-flex .vjs-menu-button-inline:hover .vjs-menu,\\n.vjs-no-flex .vjs-menu-button-inline:focus .vjs-menu,\\n.vjs-no-flex .vjs-menu-button-inline.vjs-slider-active .vjs-menu {\\n width: auto; }\\n\\n.vjs-menu-button-inline .vjs-menu-content {\\n width: auto;\\n height: 100%;\\n margin: 0;\\n overflow: hidden; }\\n\\n.video-js .vjs-control-bar {\\n display: none;\\n width: 100%;\\n position: absolute;\\n bottom: 0;\\n left: 0;\\n right: 0;\\n height: 3.0em;\\n background-color: #2B333F;\\n background-color: rgba(43, 51, 63, 0.7); }\\n\\n.vjs-has-started .vjs-control-bar {\\n display: flex;\\n visibility: visible;\\n opacity: 1;\\n transition: visibility 0.1s, opacity 0.1s; }\\n\\n.vjs-has-started.vjs-user-inactive.vjs-playing .vjs-control-bar {\\n visibility: visible;\\n opacity: 0;\\n transition: visibility 1s, opacity 1s; }\\n\\n.vjs-controls-disabled .vjs-control-bar,\\n.vjs-using-native-controls .vjs-control-bar,\\n.vjs-error .vjs-control-bar {\\n display: none !important; }\\n\\n.vjs-audio.vjs-has-started.vjs-user-inactive.vjs-playing .vjs-control-bar {\\n opacity: 1;\\n visibility: visible; }\\n\\n.vjs-has-started.vjs-no-flex .vjs-control-bar {\\n display: table; }\\n\\n.video-js .vjs-control {\\n position: relative;\\n text-align: center;\\n margin: 0;\\n padding: 0;\\n height: 100%;\\n width: 4em;\\n flex: none; }\\n\\n.vjs-button > .vjs-icon-placeholder:before {\\n font-size: 1.8em;\\n line-height: 1.67; }\\n\\n.video-js .vjs-control:focus:before,\\n.video-js .vjs-control:hover:before,\\n.video-js .vjs-control:focus {\\n text-shadow: 0em 0em 1em white; }\\n\\n.video-js .vjs-control-text {\\n border: 0;\\n clip: rect(0 0 0 0);\\n height: 1px;\\n overflow: hidden;\\n padding: 0;\\n position: absolute;\\n width: 1px; }\\n\\n.vjs-no-flex .vjs-control {\\n display: table-cell;\\n vertical-align: middle; }\\n\\n.video-js .vjs-custom-control-spacer {\\n display: none; }\\n\\n.video-js .vjs-progress-control {\\n cursor: pointer;\\n flex: auto;\\n display: flex;\\n align-items: center;\\n min-width: 4em;\\n touch-action: none; }\\n\\n.video-js .vjs-progress-control.disabled {\\n cursor: default; }\\n\\n.vjs-live .vjs-progress-control {\\n display: none; }\\n\\n.vjs-liveui .vjs-progress-control {\\n display: flex;\\n align-items: center; }\\n\\n.vjs-no-flex .vjs-progress-control {\\n width: auto; }\\n\\n.video-js .vjs-progress-holder {\\n flex: auto;\\n transition: all 0.2s;\\n height: 0.3em; }\\n\\n.video-js .vjs-progress-control .vjs-progress-holder {\\n margin: 0 10px; }\\n\\n.video-js .vjs-progress-control:hover .vjs-progress-holder {\\n font-size: 1.666666666666666666em; }\\n\\n.video-js .vjs-progress-control:hover .vjs-progress-holder.disabled {\\n font-size: 1em; }\\n\\n.video-js .vjs-progress-holder .vjs-play-progress,\\n.video-js .vjs-progress-holder .vjs-load-progress,\\n.video-js .vjs-progress-holder .vjs-load-progress div {\\n position: absolute;\\n display: block;\\n height: 100%;\\n margin: 0;\\n padding: 0;\\n width: 0; }\\n\\n.video-js .vjs-play-progress {\\n background-color: #fff; }\\n .video-js .vjs-play-progress:before {\\n font-size: 0.9em;\\n position: absolute;\\n right: -0.5em;\\n top: -0.333333333333333em;\\n z-index: 1; }\\n\\n.video-js .vjs-load-progress {\\n background: rgba(115, 133, 159, 0.5); }\\n\\n.video-js .vjs-load-progress div {\\n background: rgba(115, 133, 159, 0.75); }\\n\\n.video-js .vjs-time-tooltip {\\n background-color: #fff;\\n background-color: rgba(255, 255, 255, 0.8);\\n border-radius: 0.3em;\\n color: #000;\\n float: right;\\n font-family: Arial, Helvetica, sans-serif;\\n font-size: 1em;\\n padding: 6px 8px 8px 8px;\\n pointer-events: none;\\n position: absolute;\\n top: -3.4em;\\n visibility: hidden;\\n z-index: 1; }\\n\\n.video-js .vjs-progress-holder:focus .vjs-time-tooltip {\\n display: none; }\\n\\n.video-js .vjs-progress-control:hover .vjs-time-tooltip,\\n.video-js .vjs-progress-control:hover .vjs-progress-holder:focus .vjs-time-tooltip {\\n display: block;\\n font-size: 0.6em;\\n visibility: visible; }\\n\\n.video-js .vjs-progress-control.disabled:hover .vjs-time-tooltip {\\n font-size: 1em; }\\n\\n.video-js .vjs-progress-control .vjs-mouse-display {\\n display: none;\\n position: absolute;\\n width: 1px;\\n height: 100%;\\n background-color: #000;\\n z-index: 1; }\\n\\n.vjs-no-flex .vjs-progress-control .vjs-mouse-display {\\n z-index: 0; }\\n\\n.video-js .vjs-progress-control:hover .vjs-mouse-display {\\n display: block; }\\n\\n.video-js.vjs-user-inactive .vjs-progress-control .vjs-mouse-display {\\n visibility: hidden;\\n opacity: 0;\\n transition: visibility 1s, opacity 1s; }\\n\\n.video-js.vjs-user-inactive.vjs-no-flex .vjs-progress-control .vjs-mouse-display {\\n display: none; }\\n\\n.vjs-mouse-display .vjs-time-tooltip {\\n color: #fff;\\n background-color: #000;\\n background-color: rgba(0, 0, 0, 0.8); }\\n\\n.video-js .vjs-slider {\\n position: relative;\\n cursor: pointer;\\n padding: 0;\\n margin: 0 0.45em 0 0.45em;\\n /* iOS Safari */\\n -webkit-touch-callout: none;\\n /* Safari */\\n -webkit-user-select: none;\\n /* Konqueror HTML */\\n /* Firefox */\\n -moz-user-select: none;\\n /* Internet Explorer/Edge */\\n -ms-user-select: none;\\n /* Non-prefixed version, currently supported by Chrome and Opera */\\n user-select: none;\\n background-color: #73859f;\\n background-color: rgba(115, 133, 159, 0.5); }\\n\\n.video-js .vjs-slider.disabled {\\n cursor: default; }\\n\\n.video-js .vjs-slider:focus {\\n text-shadow: 0em 0em 1em white;\\n box-shadow: 0 0 1em #fff; }\\n\\n.video-js .vjs-mute-control {\\n cursor: pointer;\\n flex: none; }\\n\\n.video-js .vjs-volume-control {\\n cursor: pointer;\\n margin-right: 1em;\\n display: flex; }\\n\\n.video-js .vjs-volume-control.vjs-volume-horizontal {\\n width: 5em; }\\n\\n.video-js .vjs-volume-panel .vjs-volume-control {\\n visibility: visible;\\n opacity: 0;\\n width: 1px;\\n height: 1px;\\n margin-left: -1px; }\\n\\n.video-js .vjs-volume-panel {\\n transition: width 1s; }\\n .video-js .vjs-volume-panel:hover .vjs-volume-control,\\n .video-js .vjs-volume-panel:active .vjs-volume-control,\\n .video-js .vjs-volume-panel:focus .vjs-volume-control,\\n .video-js .vjs-volume-panel .vjs-volume-control:hover,\\n .video-js .vjs-volume-panel .vjs-volume-control:active,\\n .video-js .vjs-volume-panel .vjs-mute-control:hover ~ .vjs-volume-control,\\n .video-js .vjs-volume-panel .vjs-volume-control.vjs-slider-active {\\n visibility: visible;\\n opacity: 1;\\n position: relative;\\n transition: visibility 0.1s, opacity 0.1s, height 0.1s, width 0.1s, left 0s, top 0s; }\\n .video-js .vjs-volume-panel:hover .vjs-volume-control.vjs-volume-horizontal,\\n .video-js .vjs-volume-panel:active .vjs-volume-control.vjs-volume-horizontal,\\n .video-js .vjs-volume-panel:focus .vjs-volume-control.vjs-volume-horizontal,\\n .video-js .vjs-volume-panel .vjs-volume-control:hover.vjs-volume-horizontal,\\n .video-js .vjs-volume-panel .vjs-volume-control:active.vjs-volume-horizontal,\\n .video-js .vjs-volume-panel .vjs-mute-control:hover ~ .vjs-volume-control.vjs-volume-horizontal,\\n .video-js .vjs-volume-panel .vjs-volume-control.vjs-slider-active.vjs-volume-horizontal {\\n width: 5em;\\n height: 3em; }\\n .video-js .vjs-volume-panel:hover .vjs-volume-control.vjs-volume-vertical,\\n .video-js .vjs-volume-panel:active .vjs-volume-control.vjs-volume-vertical,\\n .video-js .vjs-volume-panel:focus .vjs-volume-control.vjs-volume-vertical,\\n .video-js .vjs-volume-panel .vjs-volume-control:hover.vjs-volume-vertical,\\n .video-js .vjs-volume-panel .vjs-volume-control:active.vjs-volume-vertical,\\n .video-js .vjs-volume-panel .vjs-mute-control:hover ~ .vjs-volume-control.vjs-volume-vertical,\\n .video-js .vjs-volume-panel .vjs-volume-control.vjs-slider-active.vjs-volume-vertical {\\n left: -3.5em; }\\n .video-js .vjs-volume-panel.vjs-volume-panel-horizontal:hover, .video-js .vjs-volume-panel.vjs-volume-panel-horizontal:active, .video-js .vjs-volume-panel.vjs-volume-panel-horizontal.vjs-slider-active {\\n width: 9em;\\n transition: width 0.1s; }\\n .video-js .vjs-volume-panel.vjs-volume-panel-horizontal.vjs-mute-toggle-only {\\n width: 4em; }\\n\\n.video-js .vjs-volume-panel .vjs-volume-control.vjs-volume-vertical {\\n height: 8em;\\n width: 3em;\\n left: -3000em;\\n transition: visibility 1s, opacity 1s, height 1s 1s, width 1s 1s, left 1s 1s, top 1s 1s; }\\n\\n.video-js .vjs-volume-panel .vjs-volume-control.vjs-volume-horizontal {\\n transition: visibility 1s, opacity 1s, height 1s 1s, width 1s, left 1s 1s, top 1s 1s; }\\n\\n.video-js.vjs-no-flex .vjs-volume-panel .vjs-volume-control.vjs-volume-horizontal {\\n width: 5em;\\n height: 3em;\\n visibility: visible;\\n opacity: 1;\\n position: relative;\\n transition: none; }\\n\\n.video-js.vjs-no-flex .vjs-volume-control.vjs-volume-vertical,\\n.video-js.vjs-no-flex .vjs-volume-panel .vjs-volume-control.vjs-volume-vertical {\\n position: absolute;\\n bottom: 3em;\\n left: 0.5em; }\\n\\n.video-js .vjs-volume-panel {\\n display: flex; }\\n\\n.video-js .vjs-volume-bar {\\n margin: 1.35em 0.45em; }\\n\\n.vjs-volume-bar.vjs-slider-horizontal {\\n width: 5em;\\n height: 0.3em; }\\n\\n.vjs-volume-bar.vjs-slider-vertical {\\n width: 0.3em;\\n height: 5em;\\n margin: 1.35em auto; }\\n\\n.video-js .vjs-volume-level {\\n position: absolute;\\n bottom: 0;\\n left: 0;\\n background-color: #fff; }\\n .video-js .vjs-volume-level:before {\\n position: absolute;\\n font-size: 0.9em; }\\n\\n.vjs-slider-vertical .vjs-volume-level {\\n width: 0.3em; }\\n .vjs-slider-vertical .vjs-volume-level:before {\\n top: -0.5em;\\n left: -0.3em; }\\n\\n.vjs-slider-horizontal .vjs-volume-level {\\n height: 0.3em; }\\n .vjs-slider-horizontal .vjs-volume-level:before {\\n top: -0.3em;\\n right: -0.5em; }\\n\\n.video-js .vjs-volume-panel.vjs-volume-panel-vertical {\\n width: 4em; }\\n\\n.vjs-volume-bar.vjs-slider-vertical .vjs-volume-level {\\n height: 100%; }\\n\\n.vjs-volume-bar.vjs-slider-horizontal .vjs-volume-level {\\n width: 100%; }\\n\\n.video-js .vjs-volume-vertical {\\n width: 3em;\\n height: 8em;\\n bottom: 8em;\\n background-color: #2B333F;\\n background-color: rgba(43, 51, 63, 0.7); }\\n\\n.video-js .vjs-volume-horizontal .vjs-menu {\\n left: -2em; }\\n\\n.vjs-poster {\\n display: inline-block;\\n vertical-align: middle;\\n background-repeat: no-repeat;\\n background-position: 50% 50%;\\n background-size: contain;\\n background-color: #000000;\\n cursor: pointer;\\n margin: 0;\\n padding: 0;\\n position: absolute;\\n top: 0;\\n right: 0;\\n bottom: 0;\\n left: 0;\\n height: 100%; }\\n\\n.vjs-has-started .vjs-poster {\\n display: none; }\\n\\n.vjs-audio.vjs-has-started .vjs-poster {\\n display: block; }\\n\\n.vjs-using-native-controls .vjs-poster {\\n display: none; }\\n\\n.video-js .vjs-live-control {\\n display: flex;\\n align-items: flex-start;\\n flex: auto;\\n font-size: 1em;\\n line-height: 3em; }\\n\\n.vjs-no-flex .vjs-live-control {\\n display: table-cell;\\n width: auto;\\n text-align: left; }\\n\\n.video-js:not(.vjs-live) .vjs-live-control,\\n.video-js.vjs-liveui .vjs-live-control {\\n display: none; }\\n\\n.video-js .vjs-seek-to-live-control {\\n cursor: pointer;\\n flex: none;\\n display: inline-flex;\\n height: 100%;\\n padding-left: 0.5em;\\n padding-right: 0.5em;\\n font-size: 1em;\\n line-height: 3em;\\n width: auto;\\n min-width: 4em; }\\n\\n.vjs-no-flex .vjs-seek-to-live-control {\\n display: table-cell;\\n width: auto;\\n text-align: left; }\\n\\n.video-js.vjs-live:not(.vjs-liveui) .vjs-seek-to-live-control,\\n.video-js:not(.vjs-live) .vjs-seek-to-live-control {\\n display: none; }\\n\\n.vjs-seek-to-live-control.vjs-control.vjs-at-live-edge {\\n cursor: auto; }\\n\\n.vjs-seek-to-live-control .vjs-icon-placeholder {\\n margin-right: 0.5em;\\n color: #888; }\\n\\n.vjs-seek-to-live-control.vjs-control.vjs-at-live-edge .vjs-icon-placeholder {\\n color: red; }\\n\\n.video-js .vjs-time-control {\\n flex: none;\\n font-size: 1em;\\n line-height: 3em;\\n min-width: 2em;\\n width: auto;\\n padding-left: 1em;\\n padding-right: 1em; }\\n\\n.vjs-live .vjs-time-control {\\n display: none; }\\n\\n.video-js .vjs-current-time,\\n.vjs-no-flex .vjs-current-time {\\n display: none; }\\n\\n.video-js .vjs-duration,\\n.vjs-no-flex .vjs-duration {\\n display: none; }\\n\\n.vjs-time-divider {\\n display: none;\\n line-height: 3em; }\\n\\n.vjs-live .vjs-time-divider {\\n display: none; }\\n\\n.video-js .vjs-play-control {\\n cursor: pointer; }\\n\\n.video-js .vjs-play-control .vjs-icon-placeholder {\\n flex: none; }\\n\\n.vjs-text-track-display {\\n position: absolute;\\n bottom: 3em;\\n left: 0;\\n right: 0;\\n top: 0;\\n pointer-events: none; }\\n\\n.video-js.vjs-user-inactive.vjs-playing .vjs-text-track-display {\\n bottom: 1em; }\\n\\n.video-js .vjs-text-track {\\n font-size: 1.4em;\\n text-align: center;\\n margin-bottom: 0.1em; }\\n\\n.vjs-subtitles {\\n color: #fff; }\\n\\n.vjs-captions {\\n color: #fc6; }\\n\\n.vjs-tt-cue {\\n display: block; }\\n\\nvideo::-webkit-media-text-track-display {\\n -webkit-transform: translateY(-3em);\\n transform: translateY(-3em); }\\n\\n.video-js.vjs-user-inactive.vjs-playing video::-webkit-media-text-track-display {\\n -webkit-transform: translateY(-1.5em);\\n transform: translateY(-1.5em); }\\n\\n.video-js .vjs-fullscreen-control {\\n cursor: pointer;\\n flex: none; }\\n\\n.vjs-playback-rate > .vjs-menu-button,\\n.vjs-playback-rate .vjs-playback-rate-value {\\n position: absolute;\\n top: 0;\\n left: 0;\\n width: 100%;\\n height: 100%; }\\n\\n.vjs-playback-rate .vjs-playback-rate-value {\\n pointer-events: none;\\n font-size: 1.5em;\\n line-height: 2;\\n text-align: center; }\\n\\n.vjs-playback-rate .vjs-menu {\\n width: 4em;\\n left: 0em; }\\n\\n.vjs-error .vjs-error-display .vjs-modal-dialog-content {\\n font-size: 1.4em;\\n text-align: center; }\\n\\n.vjs-error .vjs-error-display:before {\\n color: #fff;\\n content: 'X';\\n font-family: Arial, Helvetica, sans-serif;\\n font-size: 4em;\\n left: 0;\\n line-height: 1;\\n margin-top: -0.5em;\\n position: absolute;\\n text-shadow: 0.05em 0.05em 0.1em #000;\\n text-align: center;\\n top: 50%;\\n vertical-align: middle;\\n width: 100%; }\\n\\n.vjs-loading-spinner {\\n display: none;\\n position: absolute;\\n top: 50%;\\n left: 50%;\\n margin: -25px 0 0 -25px;\\n opacity: 0.85;\\n text-align: left;\\n border: 6px solid rgba(43, 51, 63, 0.7);\\n box-sizing: border-box;\\n background-clip: padding-box;\\n width: 50px;\\n height: 50px;\\n border-radius: 25px;\\n visibility: hidden; }\\n\\n.vjs-seeking .vjs-loading-spinner,\\n.vjs-waiting .vjs-loading-spinner {\\n display: block;\\n -webkit-animation: 0s linear 0.3s forwards vjs-spinner-show;\\n animation: 0s linear 0.3s forwards vjs-spinner-show; }\\n\\n.vjs-loading-spinner:before,\\n.vjs-loading-spinner:after {\\n content: \\\"\\\";\\n position: absolute;\\n margin: -6px;\\n box-sizing: inherit;\\n width: inherit;\\n height: inherit;\\n border-radius: inherit;\\n opacity: 1;\\n border: inherit;\\n border-color: transparent;\\n border-top-color: white; }\\n\\n.vjs-seeking .vjs-loading-spinner:before,\\n.vjs-seeking .vjs-loading-spinner:after,\\n.vjs-waiting .vjs-loading-spinner:before,\\n.vjs-waiting .vjs-loading-spinner:after {\\n -webkit-animation: vjs-spinner-spin 1.1s cubic-bezier(0.6, 0.2, 0, 0.8) infinite, vjs-spinner-fade 1.1s linear infinite;\\n animation: vjs-spinner-spin 1.1s cubic-bezier(0.6, 0.2, 0, 0.8) infinite, vjs-spinner-fade 1.1s linear infinite; }\\n\\n.vjs-seeking .vjs-loading-spinner:before,\\n.vjs-waiting .vjs-loading-spinner:before {\\n border-top-color: white; }\\n\\n.vjs-seeking .vjs-loading-spinner:after,\\n.vjs-waiting .vjs-loading-spinner:after {\\n border-top-color: white;\\n -webkit-animation-delay: 0.44s;\\n animation-delay: 0.44s; }\\n\\n@keyframes vjs-spinner-show {\\n to {\\n visibility: visible; } }\\n\\n@-webkit-keyframes vjs-spinner-show {\\n to {\\n visibility: visible; } }\\n\\n@keyframes vjs-spinner-spin {\\n 100% {\\n -webkit-transform: rotate(360deg);\\n transform: rotate(360deg); } }\\n\\n@-webkit-keyframes vjs-spinner-spin {\\n 100% {\\n -webkit-transform: rotate(360deg); } }\\n\\n@keyframes vjs-spinner-fade {\\n 0% {\\n border-top-color: #73859f; }\\n 20% {\\n border-top-color: #73859f; }\\n 35% {\\n border-top-color: white; }\\n 60% {\\n border-top-color: #73859f; }\\n 100% {\\n border-top-color: #73859f; } }\\n\\n@-webkit-keyframes vjs-spinner-fade {\\n 0% {\\n border-top-color: #73859f; }\\n 20% {\\n border-top-color: #73859f; }\\n 35% {\\n border-top-color: white; }\\n 60% {\\n border-top-color: #73859f; }\\n 100% {\\n border-top-color: #73859f; } }\\n\\n.vjs-chapters-button .vjs-menu ul {\\n width: 24em; }\\n\\n.video-js .vjs-subs-caps-button + .vjs-menu .vjs-captions-menu-item .vjs-menu-item-text .vjs-icon-placeholder {\\n vertical-align: middle;\\n display: inline-block;\\n margin-bottom: -0.1em; }\\n\\n.video-js .vjs-subs-caps-button + .vjs-menu .vjs-captions-menu-item .vjs-menu-item-text .vjs-icon-placeholder:before {\\n font-family: VideoJS;\\n content: \\\"\\\\f10d\\\";\\n font-size: 1.5em;\\n line-height: inherit; }\\n\\n.video-js .vjs-audio-button + .vjs-menu .vjs-main-desc-menu-item .vjs-menu-item-text .vjs-icon-placeholder {\\n vertical-align: middle;\\n display: inline-block;\\n margin-bottom: -0.1em; }\\n\\n.video-js .vjs-audio-button + .vjs-menu .vjs-main-desc-menu-item .vjs-menu-item-text .vjs-icon-placeholder:before {\\n font-family: VideoJS;\\n content: \\\" \\\\f11d\\\";\\n font-size: 1.5em;\\n line-height: inherit; }\\n\\n.video-js.vjs-layout-tiny:not(.vjs-fullscreen) .vjs-custom-control-spacer {\\n flex: auto;\\n display: block; }\\n\\n.video-js.vjs-layout-tiny:not(.vjs-fullscreen).vjs-no-flex .vjs-custom-control-spacer {\\n width: auto; }\\n\\n.video-js.vjs-layout-tiny:not(.vjs-fullscreen) .vjs-current-time, .video-js.vjs-layout-tiny:not(.vjs-fullscreen) .vjs-time-divider, .video-js.vjs-layout-tiny:not(.vjs-fullscreen) .vjs-duration, .video-js.vjs-layout-tiny:not(.vjs-fullscreen) .vjs-remaining-time,\\n.video-js.vjs-layout-tiny:not(.vjs-fullscreen) .vjs-playback-rate, .video-js.vjs-layout-tiny:not(.vjs-fullscreen) .vjs-progress-control,\\n.video-js.vjs-layout-tiny:not(.vjs-fullscreen) .vjs-mute-control, .video-js.vjs-layout-tiny:not(.vjs-fullscreen) .vjs-volume-control, .video-js.vjs-layout-tiny:not(.vjs-fullscreen) .vjs-volume-panel,\\n.video-js.vjs-layout-tiny:not(.vjs-fullscreen) .vjs-chapters-button, .video-js.vjs-layout-tiny:not(.vjs-fullscreen) .vjs-descriptions-button, .video-js.vjs-layout-tiny:not(.vjs-fullscreen) .vjs-captions-button,\\n.video-js.vjs-layout-tiny:not(.vjs-fullscreen) .vjs-subtitles-button, .video-js.vjs-layout-tiny:not(.vjs-fullscreen) .vjs-subs-caps-button, .video-js.vjs-layout-tiny:not(.vjs-fullscreen) .vjs-audio-button {\\n display: none; }\\n\\n.video-js.vjs-layout-x-small:not(.vjs-fullscreen) .vjs-current-time, .video-js.vjs-layout-x-small:not(.vjs-fullscreen) .vjs-time-divider, .video-js.vjs-layout-x-small:not(.vjs-fullscreen) .vjs-duration, .video-js.vjs-layout-x-small:not(.vjs-fullscreen) .vjs-remaining-time,\\n.video-js.vjs-layout-x-small:not(.vjs-fullscreen) .vjs-playback-rate,\\n.video-js.vjs-layout-x-small:not(.vjs-fullscreen) .vjs-mute-control, .video-js.vjs-layout-x-small:not(.vjs-fullscreen) .vjs-volume-control, .video-js.vjs-layout-x-small:not(.vjs-fullscreen) .vjs-volume-panel,\\n.video-js.vjs-layout-x-small:not(.vjs-fullscreen) .vjs-chapters-button, .video-js.vjs-layout-x-small:not(.vjs-fullscreen) .vjs-descriptions-button, .video-js.vjs-layout-x-small:not(.vjs-fullscreen) .vjs-captions-button,\\n.video-js.vjs-layout-x-small:not(.vjs-fullscreen) .vjs-subtitles-button, .video-js.vjs-layout-x-small:not(.vjs-fullscreen) .vjs-subs-caps-button, .video-js.vjs-layout-x-small:not(.vjs-fullscreen) .vjs-audio-button {\\n display: none; }\\n\\n.video-js.vjs-layout-small:not(.vjs-fullscreen) .vjs-current-time, .video-js.vjs-layout-small:not(.vjs-fullscreen) .vjs-time-divider, .video-js.vjs-layout-small:not(.vjs-fullscreen) .vjs-duration, .video-js.vjs-layout-small:not(.vjs-fullscreen) .vjs-remaining-time,\\n.video-js.vjs-layout-small:not(.vjs-fullscreen) .vjs-playback-rate,\\n.video-js.vjs-layout-small:not(.vjs-fullscreen) .vjs-mute-control, .video-js.vjs-layout-small:not(.vjs-fullscreen) .vjs-volume-control, .video-js.vjs-layout-small:not(.vjs-fullscreen) .vjs-volume-panel,\\n.video-js.vjs-layout-small:not(.vjs-fullscreen) .vjs-chapters-button, .video-js.vjs-layout-small:not(.vjs-fullscreen) .vjs-descriptions-button, .video-js.vjs-layout-small:not(.vjs-fullscreen) .vjs-captions-button,\\n.video-js.vjs-layout-small:not(.vjs-fullscreen) .vjs-subtitles-button, .video-js.vjs-layout-small:not(.vjs-fullscreen) .vjs-audio-button {\\n display: none; }\\n\\n.vjs-modal-dialog.vjs-text-track-settings {\\n background-color: #2B333F;\\n background-color: rgba(43, 51, 63, 0.75);\\n color: #fff;\\n height: 70%; }\\n\\n.vjs-text-track-settings .vjs-modal-dialog-content {\\n display: table; }\\n\\n.vjs-text-track-settings .vjs-track-settings-colors,\\n.vjs-text-track-settings .vjs-track-settings-font,\\n.vjs-text-track-settings .vjs-track-settings-controls {\\n display: table-cell; }\\n\\n.vjs-text-track-settings .vjs-track-settings-controls {\\n text-align: right;\\n vertical-align: bottom; }\\n\\n@supports (display: grid) {\\n .vjs-text-track-settings .vjs-modal-dialog-content {\\n display: grid;\\n grid-template-columns: 1fr 1fr;\\n grid-template-rows: 1fr;\\n padding: 20px 24px 0px 24px; }\\n .vjs-track-settings-controls .vjs-default-button {\\n margin-bottom: 20px; }\\n .vjs-text-track-settings .vjs-track-settings-controls {\\n grid-column: 1 / -1; }\\n .vjs-layout-small .vjs-text-track-settings .vjs-modal-dialog-content,\\n .vjs-layout-x-small .vjs-text-track-settings .vjs-modal-dialog-content,\\n .vjs-layout-tiny .vjs-text-track-settings .vjs-modal-dialog-content {\\n grid-template-columns: 1fr; } }\\n\\n.vjs-track-setting > select {\\n margin-right: 1em;\\n margin-bottom: 0.5em; }\\n\\n.vjs-text-track-settings fieldset {\\n margin: 5px;\\n padding: 3px;\\n border: none; }\\n\\n.vjs-text-track-settings fieldset span {\\n display: inline-block; }\\n\\n.vjs-text-track-settings fieldset span > select {\\n max-width: 7.3em; }\\n\\n.vjs-text-track-settings legend {\\n color: #fff;\\n margin: 0 0 5px 0; }\\n\\n.vjs-text-track-settings .vjs-label {\\n position: absolute;\\n clip: rect(1px 1px 1px 1px);\\n clip: rect(1px, 1px, 1px, 1px);\\n display: block;\\n margin: 0 0 5px 0;\\n padding: 0;\\n border: 0;\\n height: 1px;\\n width: 1px;\\n overflow: hidden; }\\n\\n.vjs-track-settings-controls button:focus,\\n.vjs-track-settings-controls button:active {\\n outline-style: solid;\\n outline-width: medium;\\n background-image: linear-gradient(0deg, #fff 88%, #73859f 100%); }\\n\\n.vjs-track-settings-controls button:hover {\\n color: rgba(43, 51, 63, 0.75); }\\n\\n.vjs-track-settings-controls button {\\n background-color: #fff;\\n background-image: linear-gradient(-180deg, #fff 88%, #73859f 100%);\\n color: #2B333F;\\n cursor: pointer;\\n border-radius: 2px; }\\n\\n.vjs-track-settings-controls .vjs-default-button {\\n margin-right: 1em; }\\n\\n@media print {\\n .video-js > *:not(.vjs-tech):not(.vjs-poster) {\\n visibility: hidden; } }\\n\\n.vjs-resize-manager {\\n position: absolute;\\n top: 0;\\n left: 0;\\n width: 100%;\\n height: 100%;\\n border: none;\\n z-index: -1000; }\\n\\n.js-focus-visible .video-js *:focus:not(.focus-visible) {\\n outline: none;\\n background: none; }\\n\\n.video-js *:focus:not(:focus-visible),\\n.video-js .vjs-menu *:focus:not(:focus-visible) {\\n outline: none;\\n background: none; }\\n\", \"\"]);\n\n"],"sourceRoot":""}