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