study.fdf28530.chunk.js.map 40.6 KB
Newer Older
zhanghaozhe committed
1
{"version":3,"sources":["components/study/myCourses/index.js","components/study/freeCourses/index.js","components/study/index.js","common/v-list-base/index.js","../node_modules/react-infinite-scroller/index.js","../node_modules/react-infinite-scroller/dist/InfiniteScroll.js"],"names":["AddCourse","React","memo","_ref","addCourseClick","react_default","a","createElement","className","onClick","Record","_ref2","_ref2$record","record","seconds","lesson_name","result","matchResult","exec","studyTime","hour","Math","floor","min","sec","getStudyTime","String","padStart","length","concat","Bottom","_ref3","item","ago","date","Date","time","isToday","format","MyCourses","state","isLoading","handleClick","id","history","_this","props","mode","course_id","push","loadFunc","debounce","courseList","fetchCoursesListIfNeeded","this","switchTab","_this2","_this$props","user","common","Fragment","hasError","data","uid","react_infinite_scroller_default","pageStart","hasMore","loadMore","useWindow","ref","el","list","map","index","Info","course_title","is_restricted","is_aist","assist_weixin","contact_type","course_qq","aist_schedule","style","width","parseFloat","myCourses_Bottom","status","course_expire","v_list_base","Object","assign","img","image_name","key","info","react_router_dom","to","Component","connect","myCourses","text","audience","FreeCourse","page","num","courses","live","getFreeCourses","http","get","API","home","getFreeLive","toLive","room_id","live_status","window","location","toast_default","setState","then","res","code","Array","isArray","msg","isEmpty","_this3","element","threshold","fill","classnames","LiveStatus","course_base","title","top","bottom","bind","logo","freeCourses_Bottom","category","PureComponent","Study","position","match","url","replace","activeClassName","react_router","exact","from","path","component","FreeCourses","compose","WithFullSize","WithTab","VList","react__WEBPACK_IMPORTED_MODULE_0___default","src","alt","tab","module","exports","__webpack_require__","defineProperty","value","_createClass","defineProperties","target","i","descriptor","enumerable","configurable","writable","Constructor","protoProps","staticProps","prototype","_react","_react2","_interopRequireDefault","_propTypes2","obj","__esModule","default","InfiniteScroll","_Component","instance","TypeError","_classCallCheck","self","call","ReferenceError","_possibleConstructorReturn","__proto__","getPrototypeOf","scrollListener","eventListenerOptions","mousewheelListener","subClass","superClass","create","constructor","setPrototypeOf","_inherits","pageLoaded","options","attachScrollListener","isReverse","parentElement","getParentElement","scrollComponent","scrollTop","scrollHeight","beforeScrollHeight","beforeScrollTop","detachScrollListener","detachMousewheelListener","passive","testOptions","document","addEventListener","removeEventListener","e","useCapture","isPassiveSupported","loader","defaultLoader","scrollEl","parentNode","scrollParent","getScrollParent","initialLoad","deltaY","preventDefault","offset","doc","documentElement","body","undefined","pageYOffset","calculateOffset","clientHeight","Number","offsetParent","calculateTopPosition","offsetHeight","innerHeight","offsetTop","renderProps","filterProps","children","keys","indexOf","hasOwnProperty","_objectWithoutProperties","node","childrenArray","unshift","propTypes","isRequired","bool","func","number","defaultProps"],"mappings":"+PAoBA,IAAMA,EAAYC,IAAMC,KAAK,SAAAC,GAAA,IAAEC,EAAFD,EAAEC,eAAF,OAC3BC,EAAAC,EAAAC,cAAA,OAAKC,UAAU,cACbH,EAAAC,EAAAC,cAAA,UAAQC,UAAU,MAAMC,QAASL,GAAjC,gCAIJ,SAASM,EAATC,GAAkD,IAAAC,EAAAD,EAAjCE,OAASC,EAAwBF,EAAxBE,QAASC,EAAeH,EAAfG,YAE/BC,EAAS,GAEX,GAAID,EAAa,CACf,IAAIE,EAJG,uBAIcC,KAAKH,GAC1BC,GAAWC,GAAeA,EAAY,GAAMA,EAAY,GAAK,GAG/D,GAAIH,EAAS,CACX,IAAIK,EAxBR,SAAsBL,GACpB,MAAO,CACLM,KAAMC,KAAKC,MAAMR,EAAO,MACxBS,IAAKF,KAAKC,MAAMR,EAAU,IAAM,GAChCU,IAAKV,EAAU,IAoBCW,CAAaX,GAK7BE,IAJWG,EAAUC,KAAOM,OAAOP,EAAUC,MAAMO,SAAS,EAAG,KAAO,IAAM,KACpER,EAAUI,IAAMG,OAAOP,EAAUI,KAAKI,SAAS,EAAG,KAAO,IAAM,KAC/DR,EAAUK,IAAME,OAAOP,EAAUK,KAAKG,SAAS,EAAG,KAAO,IAKnE,OACEtB,EAAAC,EAAAC,cAAA,QAAMC,UAAW,UAEPQ,EAAOY,OAAP,qBAAAC,OAAsBb,GAAW,MAO/C,IAAMc,EAAS7B,IAAMC,KAAK,SAAA6B,GAAY,IAAVC,EAAUD,EAAVC,KAC1B,GAAIA,EAAKC,KAAOD,EAAKlB,QAAS,CAC5B,IAAIoB,EAAO,IAAIC,KAAgB,IAAXH,EAAKC,KACrBG,EAAOC,kBAAQH,GAAQI,iBAAOJ,EAAM,oBAAYI,iBAAOJ,EAAM,oBACjE,OACE7B,EAAAC,EAAAC,cAAA,OAAKC,UAAU,OACbH,EAAAC,EAAAC,cAAA,QAAMC,UAAU,QAAQ4B,GACxB/B,EAAAC,EAAAC,cAACG,EAAD,CAAQG,OAAQmB,KAItB,OACE3B,EAAAC,EAAAC,cAAA,UAAQC,UAAU,eAAlB,8BAIE+B,6MAIJC,MAAQ,CACNC,WAAW,KAGbC,YAAc,SAACC,EAAIX,GAAS,IACnBY,EAAWC,EAAKC,MAAhBF,QACAG,EAAmBf,EAAnBe,KAAMC,EAAahB,EAAbgB,UACTD,GAAgB,GAARA,EACVH,EAAQK,KAAR,cAAApB,OAA2BmB,IAG7BJ,EAAQK,KAAR,kBAAApB,OAA+Bc,OAEjCvC,eAAiB,WACfyC,EAAKC,MAAMF,QAAQK,KAAK,gBAY1BC,SAAWC,mBAAS,WACdN,EAAKC,MAAMM,WAAWxB,OAAS,KAAO,GACxCiB,EAAKC,MAAMO,4BAEZ,wFAZDC,KAAKR,MAAMS,WAAU,GACrBD,KAAKR,MAAMO,0EAIXC,KAAKR,MAAMS,WAAU,oCASd,IAAAC,EAAAF,KAAAG,EACkBH,KAAKR,MAAzBM,EADEK,EACFL,WAAYM,EADVD,EACUC,KAEjB,OAAOrD,EAAAC,EAAAC,cAACoD,EAAA,EAAD,CAASlB,UAAWa,KAAKR,MAAML,WAElCW,GAAoC,IAAtBA,EAAWxB,OAEvBvB,EAAAC,EAAAC,cAAAF,EAAAC,EAAAsD,SAAA,KACEvD,EAAAC,EAAAC,cAAA,OAAKC,UAAU,iBAAf,+DAAAqB,QACiB6B,EAAKG,UAAYP,KAAKR,MAAMY,KAAKI,KAAKC,MAEvD1D,EAAAC,EAAAC,cAACyD,EAAA1D,EAAD,CACE2D,UAAW,EACXC,SAAS,EACTC,SAAUb,KAAKJ,SACfkB,WAAW,GAEX/D,EAAAC,EAAAC,cAAA,MAAI8D,IAAK,SAAAC,GAAE,OAAId,EAAKe,KAAOD,IAEvBlB,EAAWoB,IAAI,SAACxC,EAAMyC,GAEpB,IAAMC,EACJrE,EAAAC,EAAAC,cAAA,OAAKC,UAAU,QACbH,EAAAC,EAAAC,cAAA,OAAKC,UAAU,SAASwB,EAAK2C,eAE1B3C,EAAK4C,eAAiB5C,EAAK6C,SAC5BxE,EAAAC,EAAAC,cAAA,OAAKC,UAAU,WAAf,iCAA+BwB,EAAK8C,gBAGnC9C,EAAK4C,gBAAkB5C,EAAK6C,SAAgC,GAArB7C,EAAK+C,cAAqB/C,EAAKgD,WACvE3E,EAAAC,EAAAC,cAAA,OAAKC,UAAU,WAAf,iBAA8BwB,EAAKgD,YAGlChD,EAAK4C,gBAAkB5C,EAAK6C,SAAgC,GAArB7C,EAAK+C,cAAqB/C,EAAKgD,WACvE3E,EAAAC,EAAAC,cAAA,OAAKC,UAAU,WAAf,uCAAgCwB,EAAKgD,WAIrChD,EAAK6C,SAAW7C,EAAKiD,eACrB5E,EAAAC,EAAAC,cAAA,OAAKC,UAAU,kBACbH,EAAAC,EAAAC,cAAA,OAAKC,UAAU,mBACbH,EAAAC,EAAAC,cAAA,OAAKC,UAAU,cACV0E,MAAO,CAACC,MAAK,GAAAtD,OAAKuD,WAAWpD,EAAKiD,eAArB,SAEpB5E,EAAAC,EAAAC,cAAA,OAAKC,UAAU,gBAAgBwB,EAAKiD,gBAGxC5E,EAAAC,EAAAC,cAAC8E,EAAD,CAAQrD,KAAMA,KAIZsD,EACJtD,EAAK6C,QACDxE,EAAAC,EAAAC,cAAA,QAAMC,UAAU,UAAhB,gBACAwB,EAAKuD,cACLlF,EAAAC,EAAAC,cAAA,QAAMC,UAAU,iBAAiBwB,EAAKuD,eACtC,KAEN,OACElF,EAAAC,EAAAC,cAACiF,EAAA,EAADC,OAAAC,OAAA,CAAOC,IAAK3D,EAAK4D,WACVlD,YAAac,EAAKd,aACdV,EAFX,CAGO6D,IAAKpB,EACLqB,KAAMpB,EACNY,OAAQA,EACRtD,KAAMA,EACNW,GAAIX,EAAI,mBAQvBoB,EAAWxB,OAAS,KAAO,EACzBvB,EAAAC,EAAAC,cAACP,EAAD,CAAWI,eAAgBkD,KAAKlD,iBAC9B,MAIRC,EAAAC,EAAAC,cAAA,OAAKC,UAAU,SACbH,EAAAC,EAAAC,cAAA,SAAGF,EAAAC,EAAAC,cAAA,KAAGC,UAAU,uBAChBH,EAAAC,EAAAC,cAAA,KAAGC,UAAU,gBAAb,yFACAH,EAAAC,EAAAC,cAAA,SACEF,EAAAC,EAAAC,cAACwF,EAAA,EAAD,CAAMvF,UAAU,gBAAgBwF,GAAG,aAAnC,gCAxHUC,aAiITC,cACb,SAAA1D,GAAK,MAAK,CACRY,WAAYZ,EAAM2D,UAAU/C,WAC5BM,KAAMlB,EAAMkB,KACZjB,UAAWD,EAAM2D,UAAU1D,YAE7B,CACEY,6BACAE,eARW2C,CASV3D,6DCnMCT,iBAAS,SAACgB,GAAD,OACXzC,EAAAC,EAAAC,cAAA,OAAKC,UAAU,UACXH,EAAAC,EAAAC,cAACoD,EAAA,EAAD,CAAKnD,UAAWsC,EAAMtC,WAAYsC,EAAMsD,MACxC/F,EAAAC,EAAAC,cAAA,YAAOuC,EAAMuD,SAAb,yBAkJOC,6MA5IXC,KAAO,IACPC,IAAM,KACNhE,MAAQ,CACJiE,QAAS,GACTC,KAAM,GACNH,KAAM,EACNrC,SAAS,KA6BbxB,YAAc,SAAAC,GACVE,EAAKC,MAAMF,QAAQK,KAAnB,kBAAApB,OAA0Cc,OAG9CgE,eAAiB,WACb,OAAOC,IAAKC,IAAL,GAAAhF,OAAYiF,IAAIC,KAAhB,mBAAAlF,OAAsCgB,EAAK0D,OAA3C,KAAA1E,OAAqDgB,EAAK2D,SAGrEQ,YAAc,WACV,OAAOJ,IAAKC,IAAL,GAAAhF,OAAYiF,IAAIC,KAAhB,yBAGXE,OAAS,SAAAP,GAAQ,IACNQ,EAAwBR,EAAxBQ,QAAwBR,EAAfS,YAEZC,OAAOC,SAAS3B,OAAhB,sCAAA7D,OAA6DqF,IAE7DI,EAAAhH,EAAMwF,KAAK,qEAAe,EAAG,MAAM,MAI3C5C,SAAW,WACHL,EAAKL,MAAM0B,SACXrB,EAAK0E,SAAS,CACVrD,QAASrB,EAAKL,MAAMiE,QAAQ7E,OAAS,KAAO,GAC7C,WACCiB,EAAK8D,iBACAa,KAAK,SAAAC,GACF,IAAI3D,EAAO2D,EAAI3D,KACE,KAAbA,EAAK4D,KACLC,MAAMC,QAAQ9D,EAAKA,OAASjB,EAAK0E,SAAS,CACtCd,QAAS5D,EAAKL,MAAMiE,QAAQ5E,OAAOiC,EAAKA,MACxCI,QAASJ,EAAKA,KAAKlC,OAAS,KAAO,IAGvC0F,EAAAhH,EAAMwF,KAAKhC,EAAK+D,6FA7DpB,IAAArE,EAAAF,KAChBA,KAAKqD,iBACAa,KAAK,SAAAC,GACF,IAAI3D,EAAO2D,EAAI3D,KACE,KAAbA,EAAK4D,KACLlE,EAAK+D,SAAS,CACVd,QAAS3C,EAAKA,KACdI,SAAS,IAGboD,EAAAhH,EAAMwF,KAAKhC,EAAK+D,OAG5BvE,KAAK0D,cACAQ,KAAK,SAAAC,GACF,IAAI3D,EAAO2D,EAAI3D,KACE,KAAbA,EAAK4D,KACLlE,EAAK+D,SAAS,CACVb,KAAMoB,kBAAQhE,EAAKA,MAAQ,GAAKA,EAAKA,OAGzCwD,EAAAhH,EAAMwF,KAAKhC,EAAK+D,IAAK,EAAG,MAAM,sCA+CrC,IAAAE,EAAAzE,KACL,OACIjD,EAAAC,EAAAC,cAACyD,EAAA1D,EAAD,CACI2D,UAAW,EACXE,SAAUb,KAAKJ,SACfkB,WAAW,EACX5D,UAAW,eACXwH,QAAS,KACT9D,QAASZ,KAAKd,MAAM0B,QACpB+D,UAAW,KAGP3E,KAAKd,MAAMkE,KAAKlC,IAAI,SAACxC,EAAMyC,GACvB,IAAM3C,EACFzB,EAAAC,EAAAC,cAAA,OAAKC,UAAU,UACXH,EAAAC,EAAAC,cAAA,OAAKC,UAAU,iBACV,IAAImH,MAAM,GAAGO,KAAK,KAAK1D,IAAI,SAACxC,EAAMyC,GAC/B,OAAOpE,EAAAC,EAAAC,cAAA,KAAGsF,IAAKpB,EAAOjE,UAAW2H,IAAW,SAAD,UAAAtG,OAAqB4C,EAAQ,SAGhFpE,EAAAC,EAAAC,cAAA,OAAKC,UAAU,QAAf,GAAAqB,OAA0BG,EAAI,mBAIhCoG,EACqB,GAAvBpG,EAAI,YAAuB3B,EAAAC,EAAAC,cAACoD,EAAA,EAAD,CAAKnD,UAAW,gBAAhB,4BACvBH,EAAAC,EAAAC,cAACoD,EAAA,EAAD,CAAKnD,UAAW,mBAAhB,4BAER,OACIH,EAAAC,EAAAC,cAAC8H,EAAA,EAAD,CACI1C,IAAK3D,EAAI,WACTsG,MAAOtG,EAAI,WACXuG,IAAKH,EACLI,OAAQ1G,EACR+D,IAAK7D,EAAI,QACTxB,UAAW,OACXkC,YAAaqF,EAAKd,OAAOwB,KAAKV,EAAM/F,GACpCW,GAAI8B,MAMhBnB,KAAKd,MAAMiE,QAAQjC,IAAI,SAACxC,EAAMyC,GAAP,OACnBpE,EAAAC,EAAAC,cAAC8H,EAAA,EAAD,CACI1C,IAAK3D,EAAK0G,KACVJ,MAAOtG,EAAI,kBACXU,YAAaqF,EAAKrF,YAClB8F,OACInI,EAAAC,EAAAC,cAACoI,EAAD,CAAQtC,SAAUrE,EAAI,WAAgBxB,UAAW,eAAgB4F,KAAMpE,EAAK4G,WAEhFjG,GAAIX,EAAI,YACR6D,IAAKpB,EACLjE,UAAW,0BApIdqI,2CCTnBC,6MAEFtG,MAAQ,CACJuG,SAAU,4EAGL,IACEC,EAAS1F,KAAKR,MAAdkG,MACP,OACI3I,EAAAC,EAAAC,cAAA,WAASoC,GAAG,SACRtC,EAAAC,EAAAC,cAAA,OAAKC,UAAU,OACXH,EAAAC,EAAAC,cAAA,WACIF,EAAAC,EAAAC,cAACwF,EAAA,EAAD,CAASC,GAAE,GAAAnE,OAAKmH,EAAMC,IAAX,cACFC,SAAO,EACPC,gBAAgB,UAFzB,6BAKJ9I,EAAAC,EAAAC,cAAA,WACIF,EAAAC,EAAAC,cAACwF,EAAA,EAAD,CAASC,GAAE,GAAAnE,OAAKmH,EAAMC,IAAX,gBACFC,SAAO,EACPC,gBAAgB,UAFzB,8BAMR9I,EAAAC,EAAAC,cAAA,OAAKC,UAAU,mBACXH,EAAAC,EAAAC,cAAC6I,EAAA,EAAD,KACI/I,EAAAC,EAAAC,cAAC6I,EAAA,EAAD,CAAUC,OAAK,EAACC,KAAK,SAAStD,GAAG,oBACjC3F,EAAAC,EAAAC,cAAC6I,EAAA,EAAD,CAAOG,KAAI,GAAA1H,OAAKyB,KAAKR,MAAMkG,MAAMO,KAAtB,cAAwCC,UAAWjH,IAC9DlC,EAAAC,EAAAC,cAAC6I,EAAA,EAAD,CAAOG,KAAI,GAAA1H,OAAKyB,KAAKR,MAAMkG,MAAMO,KAAtB,gBAA0CC,UAAWC,cA5BpExD,aAqCLyD,sBACXC,IACAC,IAFWF,CAGbZ,gECjCae,IAfD,SAAC/G,GACX,OACIgH,EAAAxJ,EAAAC,cAAA,MAAIC,UAAU,mBAAmBC,QAASqC,EAAMJ,YAAY+F,YAAW3F,EAAMH,GAAIG,EAAMd,OACnF8H,EAAAxJ,EAAAC,cAAA,OAAKC,UAAU,WACXsJ,EAAAxJ,EAAAC,cAAA,OAAKC,UAAU,SACVsC,EAAMwC,OACPwE,EAAAxJ,EAAAC,cAAA,OAAKwJ,IAAKjH,EAAM6C,IAAKqE,IAAI,MAE5BlH,EAAMgD,MAEVhD,EAAMmH,iDCbnBC,EAAAC,QAAiBC,EAAQ,uCCEzB3E,OAAA4E,eAAAF,EAAA,cACAG,OAAA,IAGA,IAAAC,EAAA,WACA,SAAAC,EAAAC,EAAA3H,GACA,QAAA4H,EAAA,EAAmBA,EAAA5H,EAAAlB,OAAkB8I,IAAA,CACrC,IAAAC,EAAA7H,EAAA4H,GACAC,EAAAC,WAAAD,EAAAC,aAAA,EACAD,EAAAE,cAAA,EACA,UAAAF,MAAAG,UAAA,GACArF,OAAA4E,eAAAI,EAAAE,EAAA9E,IAAA8E,IAIA,gBAAAI,EAAAC,EAAAC,GAGA,OAFAD,GAAAR,EAAAO,EAAAG,UAAAF,GACAC,GAAAT,EAAAO,EAAAE,GACAF,GAdA,GAkBAI,EAAaf,EAAQ,GAErBgB,EAAAC,EAAAF,GAIAG,EAAAD,EAFiBjB,EAAQ,IAIzB,SAAAiB,EAAAE,GACA,OAAAA,KAAAC,WAAAD,EAAA,CACAE,QAAAF,GA8CA,IAAAG,EAAA,SAAAC,GAGA,SAAAD,EAAA5I,IAjCA,SAAA8I,EAAAb,GACA,KAAAa,aAAAb,GACA,UAAAc,UAAA,qCAgCAC,CAAAxI,KAAAoI,GAEA,IAAA7I,EA9BA,SAAAkJ,EAAAC,GACA,IAAAD,EACA,UAAAE,eAAA,6DAGA,OAAAD,GAAA,kBAAAA,GAAA,oBAAAA,EAAAD,EAAAC,EAyBAE,CAAA5I,MAAAoI,EAAAS,WAAA1G,OAAA2G,eAAAV,IAAAM,KAAA1I,KAAAR,IAKA,OAHAD,EAAAwJ,eAAAxJ,EAAAwJ,eAAA5D,KAAA5F,GACAA,EAAAyJ,qBAAAzJ,EAAAyJ,qBAAA7D,KAAA5F,GACAA,EAAA0J,mBAAA1J,EAAA0J,mBAAA9D,KAAA5F,GACAA,EA0OA,OArQA,SAAA2J,EAAAC,GACA,uBAAAA,GAAA,OAAAA,EACA,UAAAZ,UAAA,kEAAAY,GAGAD,EAAAtB,UAAAzF,OAAAiH,OAAAD,KAAAvB,UAAA,CACAyB,YAAA,CACArC,MAAAkC,EACA5B,YAAA,EACAE,UAAA,EACAD,cAAA,KAGA4B,IAAAhH,OAAAmH,eAAAnH,OAAAmH,eAAAJ,EAAAC,GAAAD,EAAAL,UAAAM,GAIAI,CAAAnB,EAqPCP,EAAAlF,WAxODsE,EAAAmB,EAAA,EACA7F,IAAA,oBACAyE,MAAA,WACAhH,KAAAwJ,WAAAxJ,KAAAR,MAAAmB,UACAX,KAAAyJ,QAAAzJ,KAAAgJ,uBACAhJ,KAAA0J,yBAEG,CACHnH,IAAA,qBACAyE,MAAA,WACA,GAAAhH,KAAAR,MAAAmK,WAAA3J,KAAAa,SAAA,CACA,IAAA+I,EAAA5J,KAAA6J,iBAAA7J,KAAA8J,iBACAF,EAAAG,UAAAH,EAAAI,aAAAhK,KAAAiK,mBAAAjK,KAAAkK,gBACAlK,KAAAa,UAAA,EAGAb,KAAA0J,yBAEG,CACHnH,IAAA,uBACAyE,MAAA,WACAhH,KAAAmK,uBACAnK,KAAAoK,6BAEG,CACH7H,IAAA,qBACAyE,MAAA,WACA,IAAAqD,GAAA,EACAC,EAAA,CACAD,cACAA,GAAA,IAKA,IACAE,SAAAC,iBAAA,YAAAF,GACAC,SAAAE,oBAAA,YAAAH,GACO,MAAAI,IAGP,OAAAL,IAEG,CACH9H,IAAA,uBACAyE,MAAA,WACA,IAAAyC,EAAAzJ,KAAAR,MAAAmL,WASA,OAPA3K,KAAA4K,uBACAnB,EAAA,CACAkB,WAAA3K,KAAAR,MAAAmL,WACAN,SAAA,IAIAZ,IAGG,CACHlH,IAAA,mBACAyE,MAAA,SAAA6D,GACA7K,KAAA8K,cAAAD,IAEG,CACHtI,IAAA,2BACAyE,MAAA,WACA,IAAA+D,EAAAjH,QAEA,IAAA9D,KAAAR,MAAAsB,YACAiK,EAAA/K,KAAA8J,gBAAAkB,YAGAD,EAAAN,oBAAA,aAAAzK,KAAAiJ,mBAAAjJ,KAAAyJ,QAAAzJ,KAAAyJ,QAAAzJ,KAAAR,MAAAmL,cAEG,CACHpI,IAAA,uBACAyE,MAAA,WACA,IAAA+D,EAAAjH,QAEA,IAAA9D,KAAAR,MAAAsB,YACAiK,EAAA/K,KAAA6J,iBAAA7J,KAAA8J,kBAGAiB,EAAAN,oBAAA,SAAAzK,KAAA+I,eAAA/I,KAAAyJ,QAAAzJ,KAAAyJ,QAAAzJ,KAAAR,MAAAmL,YACAI,EAAAN,oBAAA,SAAAzK,KAAA+I,eAAA/I,KAAAyJ,QAAAzJ,KAAAyJ,QAAAzJ,KAAAR,MAAAmL,cAEG,CACHpI,IAAA,mBACAyE,MAAA,SAAAhG,GACA,IAAAiK,EAAAjL,KAAAR,MAAA0L,iBAAAlL,KAAAR,MAAA0L,kBAEA,aAAAD,EACAA,EAGAjK,KAAAgK,aAEG,CACHzI,IAAA,cACAyE,MAAA,SAAAxH,GACA,OAAAA,IAEG,CACH+C,IAAA,uBACAyE,MAAA,WACA,IAAA4C,EAAA5J,KAAA6J,iBAAA7J,KAAA8J,iBAEA,GAAA9J,KAAAR,MAAAoB,SAAAgJ,EAAA,CAIA,IAAAmB,EAAAjH,QAEA,IAAA9D,KAAAR,MAAAsB,YACAiK,EAAAnB,GAGAmB,EAAAP,iBAAA,aAAAxK,KAAAiJ,mBAAAjJ,KAAAyJ,QAAAzJ,KAAAyJ,QAAAzJ,KAAAR,MAAAmL,YACAI,EAAAP,iBAAA,SAAAxK,KAAA+I,eAAA/I,KAAAyJ,QAAAzJ,KAAAyJ,QAAAzJ,KAAAR,MAAAmL,YACAI,EAAAP,iBAAA,SAAAxK,KAAA+I,eAAA/I,KAAAyJ,QAAAzJ,KAAAyJ,QAAAzJ,KAAAR,MAAAmL,YAEA3K,KAAAR,MAAA2L,aACAnL,KAAA+I,oBAGG,CACHxG,IAAA,qBACAyE,MAAA,SAAA0D,GAGA,IAAAA,EAAAU,QAAApL,KAAA4K,sBACAF,EAAAW,mBAGG,CACH9I,IAAA,iBACAyE,MAAA,WACA,IAAAhG,EAAAhB,KAAA8J,gBACAiB,EAAAjH,OACAkH,EAAAhL,KAAA6J,iBAAA7I,GACAsK,OAAA,EAEA,GAAAtL,KAAAR,MAAAsB,UAAA,CACA,IAAAyK,EAAAhB,SAAAiB,iBAAAjB,SAAAkB,KAAAT,YAAAT,SAAAkB,KACA1B,OAAA2B,IAAAX,EAAAY,YAAAZ,EAAAY,YAAAJ,EAAAxB,UAGAuB,EADAtL,KAAAR,MAAAmK,UACAI,EAEA/J,KAAA4L,gBAAA5K,EAAA+I,QAGAuB,EADOtL,KAAAR,MAAAmK,UACPqB,EAAAjB,UAEA/I,EAAAgJ,aAAAgB,EAAAjB,UAAAiB,EAAAa,aAIAP,EAAAQ,OAAA9L,KAAAR,MAAAmF,YAAA3D,GAAA,OAAAA,EAAA+K,eACA/L,KAAAmK,uBACAnK,KAAAiK,mBAAAe,EAAAhB,aACAhK,KAAAkK,gBAAAc,EAAAjB,UAEA,oBAAA/J,KAAAR,MAAAqB,WACAb,KAAAR,MAAAqB,SAAAb,KAAAwJ,YAAA,GACAxJ,KAAAa,UAAA,MAIG,CACH0B,IAAA,kBACAyE,MAAA,SAAAhG,EAAA+I,GACA,OAAA/I,EAIAhB,KAAAgM,qBAAAhL,MAAAiL,aAAAlC,EAAAjG,OAAAoI,aAHA,IAKG,CACH3J,IAAA,uBACAyE,MAAA,SAAAhG,GACA,OAAAA,EAIAA,EAAAmL,UAAAnM,KAAAgM,qBAAAhL,EAAA+K,cAHA,IAKG,CACHxJ,IAAA,SACAyE,MAAA,WACA,IAAA9G,EAAAF,KAEAoM,EAAApM,KAAAqM,YAAArM,KAAAR,OAEA8M,EAAAF,EAAAE,SACA5H,EAAA0H,EAAA1H,QACA9D,EAAAwL,EAAAxL,QAEA+I,GADAyC,EAAAjB,YACAiB,EAAAzC,WACAkB,EAAAuB,EAAAvB,OAGA9J,GAFAqL,EAAAvL,SACAuL,EAAAzL,UACAyL,EAAArL,KAKAvB,GAJA4M,EAAAzH,UACAyH,EAAAzB,WACAyB,EAAAtL,UACAsL,EAAAlB,gBAtQA,SAAAjD,EAAAsE,GACA,IAAApF,EAAA,GAEA,QAAAC,KAAAa,EACAsE,EAAAC,QAAApF,IAAA,GACAjF,OAAAyF,UAAA6E,eAAA/D,KAAAT,EAAAb,KACAD,EAAAC,GAAAa,EAAAb,IAGA,OAAAD,EA8PAuF,CAAAN,EAAA,0JAEA5M,EAAAuB,IAAA,SAAA4L,GACAzM,EAAA4J,gBAAA6C,EAEA5L,GACAA,EAAA4L,IAIA,IAAAC,EAAA,CAAAN,GAUA,OARA1L,IACAiK,EACAlB,EAAAiD,EAAAC,QAAAhC,GAAA+B,EAAAjN,KAAAkL,GACS7K,KAAA8K,gBACTnB,EAAAiD,EAAAC,QAAA7M,KAAA8K,eAAA8B,EAAAjN,KAAAK,KAAA8K,iBAIAhD,EAAAK,QAAAlL,cAAAyH,EAAAlF,EAAAoN,OAIAxE,EArPA,GAwPAA,EAAA0E,UAAA,CACAR,SAAAtE,EAAAG,QAAAwE,KAAAI,WACArI,QAAAsD,EAAAG,QAAAwE,KACA/L,QAAAoH,EAAAG,QAAA6E,KACA7B,YAAAnD,EAAAG,QAAA6E,KACArD,UAAA3B,EAAAG,QAAA6E,KACAnC,OAAA7C,EAAAG,QAAAwE,KACA9L,SAAAmH,EAAAG,QAAA8E,KAAAF,WACApM,UAAAqH,EAAAG,QAAA+E,OACAnM,IAAAiH,EAAAG,QAAA8E,KACA/B,gBAAAlD,EAAAG,QAAA8E,KACAtI,UAAAqD,EAAAG,QAAA+E,OACAvC,WAAA3C,EAAAG,QAAA6E,KACAlM,UAAAkH,EAAAG,QAAA6E,MAEA5E,EAAA+E,aAAA,CACAzI,QAAA,MACA9D,SAAA,EACAuK,aAAA,EACAxK,UAAA,EACAI,IAAA,KACA4D,UAAA,IACA7D,WAAA,EACA6I,WAAA,EACAgB,YAAA,EACAE,OAAA,KACAK,gBAAA,MAEArE,EAAAsB,QAAAC,EACAxB,EAAAC,UAAA","file":"mrstatic/js/study.fdf28530.chunk.js","sourcesContent":["import React, { Component } from \"react\"\nimport VList from '@/common/v-list-base'\nimport './my-courses.scss'\nimport { isToday, format } from \"date-fns\"\nimport { connect } from \"react-redux\"\nimport { fetchCoursesListIfNeeded, switchTab } from \"./actions\"\nimport InfiniteScroll from 'react-infinite-scroller'\nimport { debounce } from 'lodash'\nimport { Link } from 'react-router-dom'\nimport { Loading } from \"@/common\";\n\n\nfunction getStudyTime(seconds) {\n  return {\n    hour: Math.floor(seconds / (60 * 60)),\n    min: Math.floor(seconds / 60) % 60,\n    sec: seconds % 60\n  }\n}\n\nconst AddCourse = React.memo(({addCourseClick}) => (\n  <div className='add-course'>\n    <button className='add' onClick={addCourseClick}>添加课程+</button>\n  </div>\n))\n\nfunction Record({record: {seconds, lesson_name}}) {\n  let re = /第[\\s\\S]+?课/,\n    result = ''\n\n  if (lesson_name) {\n    let matchResult = re.exec(lesson_name)\n    result += (matchResult && matchResult[0]) ? matchResult[0] : ''\n  }\n\n  if (seconds) {\n    let studyTime = getStudyTime(seconds)\n    let hour = studyTime.hour ? String(studyTime.hour).padStart(2, '0') + ':' : '',\n      min = studyTime.min ? String(studyTime.min).padStart(2, '0') + ':' : '',\n      sec = studyTime.sec ? String(studyTime.sec).padStart(2, '0') : ''\n\n    result += hour + min + sec\n  }\n\n  return (\n    <span className={'record'}>\n            {\n              result.length ? `学习到${result}` : null\n            }\n        </span>\n  )\n}\n\n\nconst Bottom = React.memo(({item}) => {\n  if (item.ago || item.seconds) {\n    let date = new Date(item.ago * 1000)\n    let time = isToday(date) ? format(date, 'HH时mm分') : format(date, 'MM月DD日')\n    return (\n      <div className=\"des\">\n        <span className='time'>{time}</span>\n        <Record record={item}/>\n      </div>\n    )\n  }\n  return (\n    <button className='start-learn'>开始学习</button>\n  )\n})\n\nclass MyCourses extends Component {\n\n  list\n\n  state = {\n    isLoading: true\n  }\n\n  handleClick = (id, item) => {\n    const {history} = this.props\n    const {mode, course_id} = item\n    if (mode && mode == 6) {\n      history.push(`/python?id=${course_id}`)\n      return\n    }\n    history.push(`/play/video?id=${id}`)\n  }\n  addCourseClick = () => {\n    this.props.history.push('/classify')\n  }\n\n  componentDidMount() {\n    this.props.switchTab(false)\n    this.props.fetchCoursesListIfNeeded()\n  }\n\n  componentWillUnmount() {\n    this.props.switchTab(true);\n  }\n\n  loadFunc = debounce(() => {\n    if (this.props.courseList.length % 10 === 0) {\n      this.props.fetchCoursesListIfNeeded()\n    }\n  }, 200)\n\n  render() {\n    let {courseList, user} = this.props\n\n    return <Loading isLoading={this.props.isLoading}>\n      {\n        courseList && courseList.length !== 0\n          ?\n          <>\n            <div className=\"my-course-uid\">\n              {`加群请备注您的学号:${!user.hasError && this.props.user.data.uid}`}\n            </div>\n            <InfiniteScroll\n              pageStart={0}\n              hasMore={true}\n              loadMore={this.loadFunc}\n              useWindow={false}\n            >\n              <ul ref={el => this.list = el}>\n                {\n                  courseList.map((item, index) => {\n\n                    const Info = (\n                      <div className=\"info\">\n                        <div className='title'>{item.course_title}</div>\n                        {\n                          !item.is_restricted && item.is_aist &&\n                          <div className='contact'>助教微信:{item.assist_weixin}</div>\n                        }\n                        {\n                          !item.is_restricted && !item.is_aist && item.contact_type == 1 && item.course_qq &&\n                          <div className='contact'>QQ群:{item.course_qq}</div>\n                        }\n                        {\n                          !item.is_restricted && !item.is_aist && item.contact_type == 2 && item.course_qq &&\n                          <div className='contact'>班主任微信:{item.course_qq}</div>\n                        }\n\n                        {\n                          item.is_aist && item.aist_schedule &&\n                          <div className=\"process-status\">\n                            <div className=\"process-wrapper\">\n                              <div className=\"process-bar\"\n                                   style={{width: `${parseFloat(item.aist_schedule)}%`}}/>\n                            </div>\n                            <div className=\"process-text\">{item.aist_schedule}</div>\n                          </div>\n                        }\n                        <Bottom item={item}/>\n                      </div>\n                    )\n\n                    const status = (\n                      item.is_aist\n                        ? <span className='status'>返现</span>\n                        : item.course_expire\n                        ? <span className='course-expire'>{item.course_expire}</span>\n                        : null\n                    )\n                    return (\n                      <VList img={item.image_name}\n                             handleClick={this.handleClick}\n                             {...item}\n                             key={index}\n                             info={Info}\n                             status={status}\n                             item={item}\n                             id={item['v_course_id']}\n                      />\n                    )\n                  })\n                }\n              </ul>\n            </InfiniteScroll>\n            {\n              courseList.length % 10 !== 0 ?\n                <AddCourse addCourseClick={this.addCourseClick}/>\n                : null\n            }\n          </>\n          :\n          <div className=\"empty\">\n            <p><i className='iconfont iconfish'/></p>\n            <p className='empty-prompt'>您还没有课程哦,赶快去选课吧~</p>\n            <p>\n              <Link className='select-course' to='/classify'>去选课</Link>\n            </p>\n          </div>\n      }\n    </Loading>\n\n  }\n}\n\nexport default connect(\n  state => ({\n    courseList: state.myCourses.courseList,\n    user: state.user,\n    isLoading: state.myCourses.isLoading\n  }),\n  {\n    fetchCoursesListIfNeeded,\n    switchTab\n  })(MyCourses)\n","import React, { PureComponent } from 'react'\nimport { Tag } from '../../../common'\nimport Course from '@/common/course-base'\nimport { http } from '@/utils'\nimport { Toast } from \"antd-mobile\";\nimport classnames from 'classnames'\nimport { isEmpty } from 'lodash'\nimport InfiniteScroll from \"react-infinite-scroller\";\nimport {HashLoader} from 'react-spinners'\n\n\nimport './free-courses.scss'\n\nconst Bottom = (props) => (\n    <div className='bottom'>\n        <Tag className={props.className}>{props.text}</Tag>\n        <span>{props.audience}人观看</span>\n    </div>\n)\n\nclass FreeCourse extends PureComponent {\n\n    page = 1\n    num = 10\n    state = {\n        courses: [],\n        live: [],\n        page: 1,\n        hasMore: false\n    }\n\n    componentDidMount() {\n        this.getFreeCourses()\n            .then(res => {\n                let data = res.data\n                if (data.code == 200) {\n                    this.setState({\n                        courses: data.data,\n                        hasMore: true\n                    })\n                } else {\n                    Toast.info(data.msg)\n                }\n            })\n        this.getFreeLive()\n            .then(res => {\n                let data = res.data\n                if (data.code == 200) {\n                    this.setState({\n                        live: isEmpty(data.data) ? [] : data.data\n                    })\n                } else {\n                    Toast.info(data.msg, 2, null, false)\n                }\n            })\n    }\n\n    handleClick = id => {\n        this.props.history.push(`/play/video?id=${id}`)\n    }\n\n    getFreeCourses = () => {\n        return http.get(`${API.home}/m/free_course/${this.page++}/${this.num}`)\n    }\n\n    getFreeLive = () => {\n        return http.get(`${API.home}/m/live/free_list`)\n    }\n\n    toLive = live => {\n        const {room_id, live_status} = live\n        if (live_status) {\n            window.location.assign(`http://www.julyedu.com/live/m_room/${room_id}`)\n        } else {\n            Toast.info('直播即将开始,敬请期待', 2, null, false)\n        }\n    }\n\n    loadFunc = () => {\n        if (this.state.hasMore) {\n            this.setState({\n                hasMore: this.state.courses.length % 10 === 0\n            }, () => {\n                this.getFreeCourses()\n                    .then(res => {\n                        let data = res.data\n                        if (data.code == 200) {\n                            Array.isArray(data.data) && this.setState({\n                                courses: this.state.courses.concat(data.data),\n                                hasMore: data.data.length % 10 === 0\n                            })\n                        } else {\n                            Toast.info(data.msg)\n                        }\n                    })\n            })\n        }\n    }\n\n    render() {\n        return (\n            <InfiniteScroll\n                pageStart={0}\n                loadMore={this.loadFunc}\n                useWindow={false}\n                className={'free-courses'}\n                element={'ul'}\n                hasMore={this.state.hasMore}\n                threshold={250}\n            >\n                {\n                    this.state.live.map((item, index) => {\n                        const Bottom = (\n                            <div className=\"bottom\">\n                                <div className=\"animation-box\">\n                                    {new Array(4).fill('a').map((item, index) => {\n                                        return <i key={index} className={classnames('column', `column-${index + 1}`)}/>\n                                    })}\n                                </div>\n                                <div className=\"time\">{`${item['live_start_time']}`}</div>\n                            </div>\n                        )\n\n                        const LiveStatus = (\n                            item['live_status'] == 0 ? <Tag className={'tag-soon top'}>即将开始</Tag> :\n                                <Tag className={'tag-playing top'}>正在直播</Tag>\n                        )\n                        return (\n                            <Course\n                                img={item['live_cover']}\n                                title={item['live_title']}\n                                top={LiveStatus}\n                                bottom={Bottom}\n                                key={item['live_id']}\n                                className={'live'}\n                                handleClick={this.toLive.bind(this, item)}\n                                id={index}\n                            />\n                        )\n                    })\n                }\n                {\n                    this.state.courses.map((item, index) => (\n                        <Course\n                            img={item.logo}\n                            title={item['video_course_name']}\n                            handleClick={this.handleClick}\n                            bottom={\n                                <Bottom audience={item['play_times']} className={'tag-category'} text={item.category}/>\n                            }\n                            id={item['v_course_id']}\n                            key={index}\n                            className={'course-item'}\n                        />\n                    ))\n                }\n            </InfiniteScroll>\n        )\n    }\n}\n\n\nexport default FreeCourse","import React, { Component } from 'react'\nimport './study.scss'\n\nimport { NavLink, Route, Switch, Redirect } from \"react-router-dom\"\nimport MyCourses from \"./myCourses\"\nimport FreeCourses from './freeCourses'\nimport WithTab from '@/HOCs/WithTab'\nimport WithFullSize from '@/HOCs/WithFullSize'\nimport { compose } from 'redux'\n\n\nclass Study extends Component {\n\n    state = {\n        position: {}\n    }\n\n    render() {\n        const {match} = this.props;\n        return (\n            <section id='study'>\n                <div className='tab'>\n                    <div>\n                        <NavLink to={`${match.url}/my-course`}\n                                 replace\n                                 activeClassName='active'\n                        >我的课程</NavLink>\n                    </div>\n                    <div>\n                        <NavLink to={`${match.url}/free-course`}\n                                 replace\n                                 activeClassName='active'\n                        >免费课程</NavLink>\n                    </div>\n                </div>\n                <div className=\"study-container\">\n                    <Switch>\n                        <Redirect exact from='/study' to='study/my-course'/>\n                        <Route path={`${this.props.match.path}/my-course`} component={MyCourses}/>\n                        <Route path={`${this.props.match.path}/free-course`} component={FreeCourses}/>\n                    </Switch>\n                </div>\n            </section>\n        )\n    }\n\n}\n\nexport default compose(\n    WithFullSize,\n    WithTab\n)(Study)","import React from 'react';\nimport './index.scss'\n\nconst VList = (props) => {\n    return (\n        <li className='v-list-base-item' onClick={props.handleClick.bind(this, props.id, props.item)}>\n            <div className=\"content\">\n                <div className=\"cover\">\n                    {props.status}\n                    <img src={props.img} alt=\"\"/>\n                </div>\n                {props.info}\n            </div>\n            {props.tab}\n        </li>\n    );\n};\n\nexport default VList;\n","module.exports = require('./dist/InfiniteScroll');","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () {\n  function defineProperties(target, props) {\n    for (var i = 0; i < props.length; i++) {\n      var descriptor = props[i];\n      descriptor.enumerable = descriptor.enumerable || false;\n      descriptor.configurable = true;\n      if (\"value\" in descriptor) descriptor.writable = true;\n      Object.defineProperty(target, descriptor.key, descriptor);\n    }\n  }\n\n  return function (Constructor, protoProps, staticProps) {\n    if (protoProps) defineProperties(Constructor.prototype, protoProps);\n    if (staticProps) defineProperties(Constructor, staticProps);\n    return Constructor;\n  };\n}();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = require('prop-types');\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nfunction _interopRequireDefault(obj) {\n  return obj && obj.__esModule ? obj : {\n    default: obj\n  };\n}\n\nfunction _objectWithoutProperties(obj, keys) {\n  var target = {};\n\n  for (var i in obj) {\n    if (keys.indexOf(i) >= 0) continue;\n    if (!Object.prototype.hasOwnProperty.call(obj, i)) continue;\n    target[i] = obj[i];\n  }\n\n  return target;\n}\n\nfunction _classCallCheck(instance, Constructor) {\n  if (!(instance instanceof Constructor)) {\n    throw new TypeError(\"Cannot call a class as a function\");\n  }\n}\n\nfunction _possibleConstructorReturn(self, call) {\n  if (!self) {\n    throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n  }\n\n  return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self;\n}\n\nfunction _inherits(subClass, superClass) {\n  if (typeof superClass !== \"function\" && superClass !== null) {\n    throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass);\n  }\n\n  subClass.prototype = Object.create(superClass && superClass.prototype, {\n    constructor: {\n      value: subClass,\n      enumerable: false,\n      writable: true,\n      configurable: true\n    }\n  });\n  if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;\n}\n\nvar InfiniteScroll = function (_Component) {\n  _inherits(InfiniteScroll, _Component);\n\n  function InfiniteScroll(props) {\n    _classCallCheck(this, InfiniteScroll);\n\n    var _this = _possibleConstructorReturn(this, (InfiniteScroll.__proto__ || Object.getPrototypeOf(InfiniteScroll)).call(this, props));\n\n    _this.scrollListener = _this.scrollListener.bind(_this);\n    _this.eventListenerOptions = _this.eventListenerOptions.bind(_this);\n    _this.mousewheelListener = _this.mousewheelListener.bind(_this);\n    return _this;\n  }\n\n  _createClass(InfiniteScroll, [{\n    key: 'componentDidMount',\n    value: function componentDidMount() {\n      this.pageLoaded = this.props.pageStart;\n      this.options = this.eventListenerOptions();\n      this.attachScrollListener();\n    }\n  }, {\n    key: 'componentDidUpdate',\n    value: function componentDidUpdate() {\n      if (this.props.isReverse && this.loadMore) {\n        var parentElement = this.getParentElement(this.scrollComponent);\n        parentElement.scrollTop = parentElement.scrollHeight - this.beforeScrollHeight + this.beforeScrollTop;\n        this.loadMore = false;\n      }\n\n      this.attachScrollListener();\n    }\n  }, {\n    key: 'componentWillUnmount',\n    value: function componentWillUnmount() {\n      this.detachScrollListener();\n      this.detachMousewheelListener();\n    }\n  }, {\n    key: 'isPassiveSupported',\n    value: function isPassiveSupported() {\n      var passive = false;\n      var testOptions = {\n        get passive() {\n          passive = true;\n        }\n\n      };\n\n      try {\n        document.addEventListener('test', null, testOptions);\n        document.removeEventListener('test', null, testOptions);\n      } catch (e) {// ignore\n      }\n\n      return passive;\n    }\n  }, {\n    key: 'eventListenerOptions',\n    value: function eventListenerOptions() {\n      var options = this.props.useCapture;\n\n      if (this.isPassiveSupported()) {\n        options = {\n          useCapture: this.props.useCapture,\n          passive: true\n        };\n      }\n\n      return options;\n    } // Set a defaut loader for all your `InfiniteScroll` components\n\n  }, {\n    key: 'setDefaultLoader',\n    value: function setDefaultLoader(loader) {\n      this.defaultLoader = loader;\n    }\n  }, {\n    key: 'detachMousewheelListener',\n    value: function detachMousewheelListener() {\n      var scrollEl = window;\n\n      if (this.props.useWindow === false) {\n        scrollEl = this.scrollComponent.parentNode;\n      }\n\n      scrollEl.removeEventListener('mousewheel', this.mousewheelListener, this.options ? this.options : this.props.useCapture);\n    }\n  }, {\n    key: 'detachScrollListener',\n    value: function detachScrollListener() {\n      var scrollEl = window;\n\n      if (this.props.useWindow === false) {\n        scrollEl = this.getParentElement(this.scrollComponent);\n      }\n\n      scrollEl.removeEventListener('scroll', this.scrollListener, this.options ? this.options : this.props.useCapture);\n      scrollEl.removeEventListener('resize', this.scrollListener, this.options ? this.options : this.props.useCapture);\n    }\n  }, {\n    key: 'getParentElement',\n    value: function getParentElement(el) {\n      var scrollParent = this.props.getScrollParent && this.props.getScrollParent();\n\n      if (scrollParent != null) {\n        return scrollParent;\n      }\n\n      return el && el.parentNode;\n    }\n  }, {\n    key: 'filterProps',\n    value: function filterProps(props) {\n      return props;\n    }\n  }, {\n    key: 'attachScrollListener',\n    value: function attachScrollListener() {\n      var parentElement = this.getParentElement(this.scrollComponent);\n\n      if (!this.props.hasMore || !parentElement) {\n        return;\n      }\n\n      var scrollEl = window;\n\n      if (this.props.useWindow === false) {\n        scrollEl = parentElement;\n      }\n\n      scrollEl.addEventListener('mousewheel', this.mousewheelListener, this.options ? this.options : this.props.useCapture);\n      scrollEl.addEventListener('scroll', this.scrollListener, this.options ? this.options : this.props.useCapture);\n      scrollEl.addEventListener('resize', this.scrollListener, this.options ? this.options : this.props.useCapture);\n\n      if (this.props.initialLoad) {\n        this.scrollListener();\n      }\n    }\n  }, {\n    key: 'mousewheelListener',\n    value: function mousewheelListener(e) {\n      // Prevents Chrome hangups\n      // See: https://stackoverflow.com/questions/47524205/random-high-content-download-time-in-chrome/47684257#47684257\n      if (e.deltaY === 1 && !this.isPassiveSupported()) {\n        e.preventDefault();\n      }\n    }\n  }, {\n    key: 'scrollListener',\n    value: function scrollListener() {\n      var el = this.scrollComponent;\n      var scrollEl = window;\n      var parentNode = this.getParentElement(el);\n      var offset = void 0;\n\n      if (this.props.useWindow) {\n        var doc = document.documentElement || document.body.parentNode || document.body;\n        var scrollTop = scrollEl.pageYOffset !== undefined ? scrollEl.pageYOffset : doc.scrollTop;\n\n        if (this.props.isReverse) {\n          offset = scrollTop;\n        } else {\n          offset = this.calculateOffset(el, scrollTop);\n        }\n      } else if (this.props.isReverse) {\n        offset = parentNode.scrollTop;\n      } else {\n        offset = el.scrollHeight - parentNode.scrollTop - parentNode.clientHeight;\n      } // Here we make sure the element is visible as well as checking the offset\n\n\n      if (offset < Number(this.props.threshold) && el && el.offsetParent !== null) {\n        this.detachScrollListener();\n        this.beforeScrollHeight = parentNode.scrollHeight;\n        this.beforeScrollTop = parentNode.scrollTop; // Call loadMore after detachScrollListener to allow for non-async loadMore functions\n\n        if (typeof this.props.loadMore === 'function') {\n          this.props.loadMore(this.pageLoaded += 1);\n          this.loadMore = true;\n        }\n      }\n    }\n  }, {\n    key: 'calculateOffset',\n    value: function calculateOffset(el, scrollTop) {\n      if (!el) {\n        return 0;\n      }\n\n      return this.calculateTopPosition(el) + (el.offsetHeight - scrollTop - window.innerHeight);\n    }\n  }, {\n    key: 'calculateTopPosition',\n    value: function calculateTopPosition(el) {\n      if (!el) {\n        return 0;\n      }\n\n      return el.offsetTop + this.calculateTopPosition(el.offsetParent);\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var _this2 = this;\n\n      var renderProps = this.filterProps(this.props);\n\n      var children = renderProps.children,\n          element = renderProps.element,\n          hasMore = renderProps.hasMore,\n          initialLoad = renderProps.initialLoad,\n          isReverse = renderProps.isReverse,\n          loader = renderProps.loader,\n          loadMore = renderProps.loadMore,\n          pageStart = renderProps.pageStart,\n          ref = renderProps.ref,\n          threshold = renderProps.threshold,\n          useCapture = renderProps.useCapture,\n          useWindow = renderProps.useWindow,\n          getScrollParent = renderProps.getScrollParent,\n          props = _objectWithoutProperties(renderProps, ['children', 'element', 'hasMore', 'initialLoad', 'isReverse', 'loader', 'loadMore', 'pageStart', 'ref', 'threshold', 'useCapture', 'useWindow', 'getScrollParent']);\n\n      props.ref = function (node) {\n        _this2.scrollComponent = node;\n\n        if (ref) {\n          ref(node);\n        }\n      };\n\n      var childrenArray = [children];\n\n      if (hasMore) {\n        if (loader) {\n          isReverse ? childrenArray.unshift(loader) : childrenArray.push(loader);\n        } else if (this.defaultLoader) {\n          isReverse ? childrenArray.unshift(this.defaultLoader) : childrenArray.push(this.defaultLoader);\n        }\n      }\n\n      return _react2.default.createElement(element, props, childrenArray);\n    }\n  }]);\n\n  return InfiniteScroll;\n}(_react.Component);\n\nInfiniteScroll.propTypes = {\n  children: _propTypes2.default.node.isRequired,\n  element: _propTypes2.default.node,\n  hasMore: _propTypes2.default.bool,\n  initialLoad: _propTypes2.default.bool,\n  isReverse: _propTypes2.default.bool,\n  loader: _propTypes2.default.node,\n  loadMore: _propTypes2.default.func.isRequired,\n  pageStart: _propTypes2.default.number,\n  ref: _propTypes2.default.func,\n  getScrollParent: _propTypes2.default.func,\n  threshold: _propTypes2.default.number,\n  useCapture: _propTypes2.default.bool,\n  useWindow: _propTypes2.default.bool\n};\nInfiniteScroll.defaultProps = {\n  element: 'div',\n  hasMore: false,\n  initialLoad: true,\n  pageStart: 0,\n  ref: null,\n  threshold: 250,\n  useWindow: true,\n  isReverse: false,\n  useCapture: false,\n  loader: null,\n  getScrollParent: null\n};\nexports.default = InfiniteScroll;\nmodule.exports = exports['default'];"],"sourceRoot":""}