{"version":3,"sources":["api/gen/index.eotc.ts","store/Events.ts","store/Blogs.ts","store/Page.ts","store/Sermons.ts","store/Config.ts","store/Footer.ts","store/index.ts","components/NavMenu.tsx","Styles.ts","components/contents/list/List.tsx","components/contents/GenericContent.tsx","components/contents/event/Event.tsx","components/contents/blog/Blog.tsx","components/contents/sermon/Sermon.tsx","components/contents/gallery/Gallery.tsx","components/contents/footer/Footer.tsx","components/Layout.tsx","components/EventList.tsx","components/BlogList.tsx","components/SermonList.tsx","components/Page.tsx","registerServiceWorker.ts","index.tsx","store/configureStore.ts","App.tsx"],"names":["BaseClient","options","credentials","idToken","sessionStorage","getItem","headers","Promise","resolve","url","response","processor","status","getErrorCodeFromResponse","errorResponse","clone","json","ErrorCode","ConfigClient","baseUrl","http","jsonParseReviver","undefined","window","url_","this","replace","transformOptions","method","then","transformedOptions_","fetch","_response","transformResult","processGetAuthConfig","_headers","forEach","v","k","text","_responseText","JSON","parse","throwException","ContentClient","startIndex","Error","encodeURIComponent","processGetEvents","processGetSermons","processGetBlogs","path","processGetPage","SwaggerException","message","result","isSwaggerException","obj","actionCreators","requestEvents","dispatch","getState","appState","events","getEvents","data","type","unloadedState","isLoading","requestBlogs","blogs","getBlogs","requestPage","page","pages","find","p","getPage","requestSermons","sermons","getSermons","requestConfig","authConfig","getAuthConfig","requestFooter","footer","contents","reducers","state","incomingAction","action","push","NavMenu","props","isOpen","isLoggedIn","msalConfig","auth","clientId","authority","validateAuthority","redirectUri","cache","cacheLocation","storeAuthStateInCookie","appConfig","b2cScopes","webApi","msal","UserAgentApplication","loginRequest","scopes","tokenRequest","updateUI","user","getAccount","setState","name","accessToken","getToken","acquireTokenSilent","catch","error","console","log","acquireTokenPopup","tokenResponse","signIn","loginRedirect","logout","toggle","handleRedirectCallback","Navbar","className","light","sticky","Container","NavbarBrand","tag","Link","to","style","padding","minWidth","src","height","NavbarToggler","onClick","position","top","Collapse","navbar","NavItem","NavLink","React","connect","ConfigStore","styles","theme","wrapper","margin","backgroundColor","backgroundImage","banner","bg","color","fg","textAlign","fontSize","title","fontWeifht","subTitle","marginTop","linkContainer","link","marginLeft","border","textDecoration","borderRadius","withTemplates","img","maxWidth","row","icon","container","ContentGroupStyles","c","minHeight","backgroundRepeat","backgroundSize","StyledComponent","injectSheet","video","float","items","classes","colSpan","map","item","index","indexOf","subItems","substring","split","dangerouslySetInnerHTML","__html","si","List","html","image","titleStyle","class","source","id","allow","t","h","atob","href","GenericContent","days","hours","minutes","seconds","location","startTime","endTime","start_date","Date","toString","setTime","current_date","getTime","seconds_left","Math","ceil","setInterval","media","info","moment","date","format","alt","imageAlign","Event","createdBy","commentCount","aria-hidden","Blog","preacher","categories","scrolling","category","key","Sermon","images","Gallery","content","isNullOrUndefined","FooterComponent","ensureDataFetched","renderPage","cg","FooterStore","children","Footer","EventList","renderEvents","renderPagination","parseInt","match","params","aria-labelledby","event","prevStartIndex","nextStartIndex","EventsStore","BlogList","renderBlogs","blog","BlogsStore","SermonList","renderSermons","sermon","SermonsStore","shareUrl","hostname","showShare","length","show","copy","setTimeout","cursor","right","contentLabel","PageComponent","PageStore","isLocalhost","Boolean","registerValidSW","swUrl","navigator","serviceWorker","register","registration","onupdatefound","installingWorker","installing","onstatechange","controller","document","getElementsByTagName","getAttribute","history","createBrowserHistory","basename","store","initialState","middleware","thunk","routerMiddleware","rootReducer","combineReducers","router","connectRouter","enhancers","windowIfDefined","__REDUX_DEVTOOLS_EXTENSION__","createStore","compose","applyMiddleware","configureStore","ReactDOM","Layout","exact","component","Page","getElementById","URL","process","origin","addEventListener","contentType","get","ready","unregister","reload","checkValidServiceWorker","registerServiceWorker"],"mappings":"wQASaA,EAAb,yGACqCC,GADrC,+EAGQA,EAAQC,YAAc,eAChBC,EAAUC,eAAeC,QAAQ,mBAElCJ,EAAQK,QAAT,cAA4C,UAAYH,GANpE,kBASeI,QAAQC,QAAQP,IAT/B,6EAYoCQ,EAAaC,EAAoBC,GAZrE,2EAkBuB,OALTC,EAASF,EAAWA,EAASE,OAAS,IAKX,MAAXA,EAlB9B,0CAmBoCZ,EAAWa,yBAAyBH,IAnBxE,8CA0BeC,EAAUD,IA1BzB,wFA6BkDI,GA7BlD,kGA8B2BA,EAAcC,QAAQC,QA9BjD,cA8BcA,EA9Bd,yBA+BeA,EAAKC,WA/BpB,8CAmCaC,EAAb,YAKI,WAAYC,EAAkBC,GAA4E,IAAD,8BACrG,+CALIA,UAIiG,IAHjGD,aAGiG,IAF/FE,sBAAmEC,EAIzE,EAAKF,KAAOA,GAAmBG,OAC/B,EAAKJ,QAAUA,GAAoB,GAHkE,EAL7G,6EAW2D,IAAD,OAC9CK,EAAOC,KAAKN,QAAU,mBAC1BK,EAAOA,EAAKE,QAAQ,QAAS,IAS7B,OAAOD,KAAKE,iBAPgB,CACxBC,OAAQ,MACRtB,QAAS,CACL,OAAU,sBAIqBuB,MAAK,SAAAC,GACxC,OAAO,EAAKV,KAAKW,MAAMP,EAAMM,MAC9BD,MAAK,SAACG,GACL,OAAO,EAAKC,gBAAgBT,EAAMQ,GAAW,SAACA,GAAD,OAAyB,EAAKE,qBAAqBF,WAzB5G,2CA6BmCtB,GAA2D,IAAD,OAC/EE,EAASF,EAASE,OACpBuB,EAAgB,GACpB,OAD4BzB,EAASJ,SAAWI,EAASJ,QAAQ8B,SAAW1B,EAASJ,QAAQ8B,SAAQ,SAACC,EAAQC,GAAT,OAAoBH,EAASG,GAAKD,KACxH,MAAXzB,EACOF,EAAS6B,OAAOV,MAAK,SAACW,GAG7B,MAD8B,KAAlBA,EAAuB,KAAoCC,KAAKC,MAAMF,EAAe,EAAKnB,qBAGpF,MAAXT,GAA6B,MAAXA,EAClBF,EAAS6B,OAAOV,MAAK,SAACW,GAC7B,OAAOG,EAAe,uCAAwC/B,EAAQ4B,EAAeL,MAGlF5B,QAAQC,QAA0C,UA3CjE,GAAkCR,GA+CrB4C,EAAb,YAKI,WAAYzB,EAAkBC,GAA4E,IAAD,8BACrG,+CALIA,UAIiG,IAHjGD,aAGiG,IAF/FE,sBAAmEC,EAIzE,EAAKF,KAAOA,GAAmBG,OAC/B,EAAKJ,QAAUA,GAAoB,GAHkE,EAL7G,uEAWc0B,GAA8C,IAAD,OAC/CrB,EAAOC,KAAKN,QAAU,4BAC1B,QAAmBG,IAAfuB,EACA,MAAM,IAAIC,MAAM,+CAGpBtB,GADIA,GAAQ,cAAgBuB,mBAAmB,GAAKF,GAAc,KACtDnB,QAAQ,QAAS,IAS7B,OAAOD,KAAKE,iBAPgB,CACxBC,OAAQ,MACRtB,QAAS,CACL,OAAU,sBAIqBuB,MAAK,SAAAC,GACxC,OAAO,EAAKV,KAAKW,MAAMP,EAAMM,MAC9BD,MAAK,SAACG,GACL,OAAO,EAAKC,gBAAgBT,EAAMQ,GAAW,SAACA,GAAD,OAAyB,EAAKgB,iBAAiBhB,WA7BxG,uCAiC+BtB,GAAuC,IAAD,OACvDE,EAASF,EAASE,OACpBuB,EAAgB,GACpB,OAD4BzB,EAASJ,SAAWI,EAASJ,QAAQ8B,SAAW1B,EAASJ,QAAQ8B,SAAQ,SAACC,EAAQC,GAAT,OAAoBH,EAASG,GAAKD,KACxH,MAAXzB,EACOF,EAAS6B,OAAOV,MAAK,SAACW,GAG7B,MAD8B,KAAlBA,EAAuB,KAAgBC,KAAKC,MAAMF,EAAe,EAAKnB,qBAGhE,MAAXT,GAA6B,MAAXA,EAClBF,EAAS6B,OAAOV,MAAK,SAACW,GAC7B,OAAOG,EAAe,uCAAwC/B,EAAQ4B,EAAeL,MAGlF5B,QAAQC,QAAsB,QA/C7C,iCAkDeqC,GAA+C,IAAD,OACjDrB,EAAOC,KAAKN,QAAU,6BAC1B,QAAmBG,IAAfuB,EACA,MAAM,IAAIC,MAAM,+CAGpBtB,GADIA,GAAQ,cAAgBuB,mBAAmB,GAAKF,GAAc,KACtDnB,QAAQ,QAAS,IAS7B,OAAOD,KAAKE,iBAPgB,CACxBC,OAAQ,MACRtB,QAAS,CACL,OAAU,sBAIqBuB,MAAK,SAAAC,GACxC,OAAO,EAAKV,KAAKW,MAAMP,EAAMM,MAC9BD,MAAK,SAACG,GACL,OAAO,EAAKC,gBAAgBT,EAAMQ,GAAW,SAACA,GAAD,OAAyB,EAAKiB,kBAAkBjB,WApEzG,wCAwEgCtB,GAAwC,IAAD,OACzDE,EAASF,EAASE,OACpBuB,EAAgB,GACpB,OAD4BzB,EAASJ,SAAWI,EAASJ,QAAQ8B,SAAW1B,EAASJ,QAAQ8B,SAAQ,SAACC,EAAQC,GAAT,OAAoBH,EAASG,GAAKD,KACxH,MAAXzB,EACOF,EAAS6B,OAAOV,MAAK,SAACW,GAG7B,MAD8B,KAAlBA,EAAuB,KAAiBC,KAAKC,MAAMF,EAAe,EAAKnB,qBAGjE,MAAXT,GAA6B,MAAXA,EAClBF,EAAS6B,OAAOV,MAAK,SAACW,GAC7B,OAAOG,EAAe,uCAAwC/B,EAAQ4B,EAAeL,MAGlF5B,QAAQC,QAAuB,QAtF9C,+BAyFaqC,GAA6C,IAAD,OAC7CrB,EAAOC,KAAKN,QAAU,2BAC1B,QAAmBG,IAAfuB,EACA,MAAM,IAAIC,MAAM,+CAGpBtB,GADIA,GAAQ,cAAgBuB,mBAAmB,GAAKF,GAAc,KACtDnB,QAAQ,QAAS,IAS7B,OAAOD,KAAKE,iBAPgB,CACxBC,OAAQ,MACRtB,QAAS,CACL,OAAU,sBAIqBuB,MAAK,SAAAC,GACxC,OAAO,EAAKV,KAAKW,MAAMP,EAAMM,MAC9BD,MAAK,SAACG,GACL,OAAO,EAAKC,gBAAgBT,EAAMQ,GAAW,SAACA,GAAD,OAAyB,EAAKkB,gBAAgBlB,WA3GvG,sCA+G8BtB,GAAsC,IAAD,OACrDE,EAASF,EAASE,OACpBuB,EAAgB,GACpB,OAD4BzB,EAASJ,SAAWI,EAASJ,QAAQ8B,SAAW1B,EAASJ,QAAQ8B,SAAQ,SAACC,EAAQC,GAAT,OAAoBH,EAASG,GAAKD,KACxH,MAAXzB,EACOF,EAAS6B,OAAOV,MAAK,SAACW,GAG7B,MAD8B,KAAlBA,EAAuB,KAAeC,KAAKC,MAAMF,EAAe,EAAKnB,qBAG/D,MAAXT,GAA6B,MAAXA,EAClBF,EAAS6B,OAAOV,MAAK,SAACW,GAC7B,OAAOG,EAAe,uCAAwC/B,EAAQ4B,EAAeL,MAGlF5B,QAAQC,QAAqB,QA7H5C,8BAgIY2C,GAA8B,IAAD,OAC7B3B,EAAOC,KAAKN,QAAU,sBAC1B,QAAaG,IAAT6B,GAA+B,OAATA,EACtB,MAAM,IAAIL,MAAM,yCAEpBtB,GADAA,EAAOA,EAAKE,QAAQ,SAAUqB,mBAAmB,GAAKI,KAC1CzB,QAAQ,QAAS,IAS7B,OAAOD,KAAKE,iBAPgB,CACxBC,OAAQ,MACRtB,QAAS,CACL,OAAU,sBAIqBuB,MAAK,SAAAC,GACxC,OAAO,EAAKV,KAAKW,MAAMP,EAAMM,MAC9BD,MAAK,SAACG,GACL,OAAO,EAAKC,gBAAgBT,EAAMQ,GAAW,SAACA,GAAD,OAAyB,EAAKoB,eAAepB,WAjJtG,qCAqJ6BtB,GAAoC,IAAD,OAClDE,EAASF,EAASE,OACpBuB,EAAgB,GACpB,OAD4BzB,EAASJ,SAAWI,EAASJ,QAAQ8B,SAAW1B,EAASJ,QAAQ8B,SAAQ,SAACC,EAAQC,GAAT,OAAoBH,EAASG,GAAKD,KACxH,MAAXzB,EACOF,EAAS6B,OAAOV,MAAK,SAACW,GAG7B,MAD8B,KAAlBA,EAAuB,KAAaC,KAAKC,MAAMF,EAAe,EAAKnB,qBAG7D,MAAXT,GAA6B,MAAXA,EAClBF,EAAS6B,OAAOV,MAAK,SAACW,GAC7B,OAAOG,EAAe,uCAAwC/B,EAAQ4B,EAAeL,MAGlF5B,QAAQC,QAAmB,UAnK1C,GAAmCR,GAsStBqD,EAAb,YAOI,WAAYC,EAAiB1C,EAAgBF,EAAkBJ,EAAkCiD,GAAc,IAAD,8BAC1G,+CAPJD,aAM8G,IAL9G1C,YAK8G,IAJ9GF,cAI8G,IAH9GJ,aAG8G,IAF9GiD,YAE8G,IAUpGC,oBAAqB,EAP3B,EAAKF,QAAUA,EACf,EAAK1C,OAASA,EACd,EAAKF,SAAWA,EAChB,EAAKJ,QAAUA,EACf,EAAKiD,OAASA,EAP4F,EAPlH,qFAmB8BE,GACtB,OAAkC,IAA3BA,EAAID,uBApBnB,eAAsCV,QAwBtC,SAASH,EAAeW,EAAiB1C,EAAgBF,EAAkBJ,EAAkCiD,GACzG,MAAe,OAAXA,QAA8BjC,IAAXiC,EACbA,EAEA,IAAIF,EAAiBC,EAAS1C,EAAQF,EAAUJ,EAAS,MCzXhE,IAAMoD,EAAiB,CAC1BC,cAAe,SAACd,GAAD,OAAqD,SAACe,EAAUC,GAE3E,IAAMC,EAAWD,IACbC,GAAYA,EAASC,QAAUlB,IAAeiB,EAASC,OAAOlB,cAC9D,IAAID,GAAgBoB,UAAUnB,GACzBhB,MAAK,SAAAoC,GACFL,EAAS,CAAEM,KAAM,iBAAkBrB,WAAYA,EAAYkB,OAAQE,OAG3EL,EAAS,CAAEM,KAAM,iBAAkBrB,WAAYA,QAQrDsB,EAA6B,CAAEJ,YAAQzC,EAAW8C,WAAW,GClBtDV,EAAiB,CAC1BW,aAAc,SAACxB,GAAD,OAAqD,SAACe,EAAUC,GAE1E,IAAMC,EAAWD,IACbC,GAAYA,EAASQ,OAASzB,IAAeiB,EAASQ,MAAMzB,cAC5D,IAAID,GAAgB2B,SAAS1B,GACxBhB,MAAK,SAAAoC,GACFL,EAAS,CAAEM,KAAM,gBAAiBrB,WAAYA,EAAYyB,MAAOL,OAGzEL,EAAS,CAAEM,KAAM,gBAAiBrB,WAAYA,QAQpDsB,EAA4B,CAAEG,WAAOhD,EAAW8C,WAAW,GClBpDV,EAAiB,CAC1Bc,YAAa,SAACrB,GAAD,OAA+C,SAACS,EAAUC,GAEnE,IAAMC,EAAWD,IACbC,GAAYA,EAASW,MAAQtB,IAASW,EAASW,KAAKtB,OAC/CW,EAASW,KAAKC,OAAUZ,EAASW,KAAKC,MAAMC,MAAK,SAAAC,GAAC,OAAIA,EAAEzB,OAASA,MAQlES,EAAS,CAAEM,KAAM,eAAgBf,KAAMA,IACvCS,EAAS,CAAEM,KAAM,eAAgBf,KAAMA,MARvCS,EAAS,CAAEM,KAAM,eAAgBf,KAAMA,KACvC,IAAIP,GAAgBiC,QAAQ1B,GAC3BtB,MAAK,SAAAoC,GACFL,EAAS,CAAEM,KAAM,eAAgBf,KAAMA,EAAMsB,KAAMR,YAcjEE,EAA4B,CAAEO,WAAOpD,EAAW8C,WAAW,GCvBpDV,EAAiB,CAC1BoB,eAAgB,SAACjC,GAAD,OAAqD,SAACe,EAAUC,GAE5E,IAAMC,EAAWD,IACbC,GAAYA,EAASiB,SAAWlC,IAAeiB,EAASiB,QAAQlC,cAChE,IAAID,GAAgBoC,WAAWnC,GAC1BhB,MAAK,SAAAoC,GACFL,EAAS,CAAEM,KAAM,kBAAmBrB,WAAYA,EAAYkC,QAASd,OAG7EL,EAAS,CAAEM,KAAM,kBAAmBrB,WAAYA,QAQtDsB,EAA8B,CAAEY,aAASzD,EAAW8C,WAAW,GCtBxDV,EAAiB,CAC1BuB,cAAe,kBAAmC,SAACrB,EAAUC,GAEzD,IAAMC,EAAWD,IACbC,GAAYA,EAASoB,cACrB,IAAIhE,GAAeiE,gBACdtD,MAAK,SAAAoC,GACFL,EAAS,CAAEM,KAAM,iBAAkBgB,WAAYjB,OAGvDL,EAAS,CAAEM,KAAM,uBAQvBC,EAA6B,CAAEe,gBAAY5D,GCjBpCoC,EAAiB,CAC1B0B,cAAe,kBAAmC,SAACxB,EAAUC,GAEzD,IAAMC,EAAWD,IACbC,GAAYA,EAASuB,UACrB,IAAIzC,GAAgBiC,QAAQ,UACvBhD,MAAK,SAAAoC,GACFL,EAAS,CAAEM,KAAM,iBAAkBmB,OAAQpB,EAAKqB,cAGxD1B,EAAS,CAAEM,KAAM,uBAQvBC,EAA6B,CAAEkB,YAAQ/D,EAAW8C,WAAW,GC/BtDmB,EAAW,CACpBxB,ONmCyC,SAACyB,EAAgCC,GAC1E,QAAcnE,IAAVkE,EACA,OAAOrB,EAGX,IAAMuB,EAASD,EACf,OAAQC,EAAOxB,MACX,IAAK,iBACD,MAAO,CACHrB,WAAY6C,EAAO7C,WACnBkB,OAAQyB,EAAMzB,OACdK,WAAW,GAEnB,IAAK,iBAGD,GAAIsB,EAAO7C,aAAe2C,EAAM3C,WAC5B,MAAO,CACHA,WAAY6C,EAAO7C,WACnBkB,OAAQ2B,EAAO3B,OACfK,WAAW,GAM3B,OAAOoB,GM5DPlB,MLkCwC,SAACkB,EAA+BC,GACxE,QAAcnE,IAAVkE,EACA,OAAOrB,EAGX,IAAMuB,EAASD,EACf,OAAQC,EAAOxB,MACX,IAAK,gBACD,MAAO,CACHrB,WAAY6C,EAAO7C,WACnByB,MAAOkB,EAAMlB,MACbF,WAAW,GAEnB,IAAK,gBAGD,GAAIsB,EAAO7C,aAAe2C,EAAM3C,WAC5B,MAAO,CACHA,WAAY6C,EAAO7C,WACnByB,MAAOoB,EAAOpB,MACdF,WAAW,GAM3B,OAAOoB,GK3DPT,QHiC0C,SAACS,EAAiCC,GAC5E,QAAcnE,IAAVkE,EACA,OAAOrB,EAGX,IAAMuB,EAASD,EACf,OAAQC,EAAOxB,MACX,IAAK,kBACD,MAAO,CACHrB,WAAY6C,EAAO7C,WACnBkC,QAASS,EAAMT,QACfX,WAAW,GAEnB,IAAK,kBAGD,GAAIsB,EAAO7C,aAAe2C,EAAM3C,WAC5B,MAAO,CACHA,WAAY6C,EAAO7C,WACnBkC,QAASW,EAAOX,QAChBX,WAAW,GAM3B,OAAOoB,GG1DPf,KJqCwC,SAACe,EAA+BC,GACxE,QAAcnE,IAAVkE,EACA,OAAOrB,EAGX,IAAMuB,EAASD,EACf,OAAQC,EAAOxB,MACX,IAAK,eACL,MAAO,CACHf,KAAMuC,EAAOvC,KACbuB,MAAOc,EAAMd,MACbN,WAAW,GAEf,IAAK,eAGD,GAAIsB,EAAOvC,OAASqC,EAAMrC,KAAM,CAC5B,IAAMuB,EAAQc,EAAMd,MACpB,GAAIA,EAMG,CACH,IAAME,EAAIF,EAAMC,MAAK,SAAAC,GAAC,OAAIA,EAAEzB,OAASuC,EAAOvC,QAC5C,OAAGyB,GACCA,EAAEU,SAAWI,EAAOjB,KAAOiB,EAAOjB,KAAKa,SAAWV,EAAEU,SAC7C,CACHnC,KAAMuC,EAAOvC,KACbuB,MAAOc,EAAMd,MACbN,WAAW,KAGfsB,EAAOjB,MAAQC,EAAMiB,KAAKD,EAAOjB,MAC1B,CACHtB,KAAMuC,EAAOvC,KACbuB,MAAOc,EAAMd,MACbN,WAAW,IAnBnB,MAAO,CACHjB,KAAMuC,EAAOvC,KACbuB,MAAOgB,EAAOjB,KAAO,CAAEiB,EAAOjB,MAAS,GACvCL,WAAW,IAuB/B,OAAOoB,GIjFPN,WF2ByC,SAACM,EAAgCC,GAC1E,QAAcnE,IAAVkE,EACA,OAAOrB,EAGX,IAAMuB,EAASD,EACf,OAAQC,EAAOxB,MACX,IAAK,iBACD,MAAO,CACHgB,WAAYM,EAAMN,YAE1B,IAAK,iBAGD,MAAO,CACHA,WAAYQ,EAAOR,YAI/B,OAAOM,GE7CPH,OD2ByC,SAACG,EAAgCC,GAC1E,QAAcnE,IAAVkE,EACA,OAAOrB,EAGX,IAAMuB,EAASD,EACf,OAAQC,EAAOxB,MACX,IAAK,iBACD,MAAO,CACHmB,OAAQG,EAAMH,OACdjB,WAAW,GAEnB,IAAK,iBAGD,MAAO,CACHiB,OAAQK,EAAOL,OACfjB,WAAW,GAKvB,OAAOoB,I,mGEjDLI,E,YAuCF,WAAYC,GAAY,IAAD,uBACnB,4CAAMA,KAvCHL,MAAoB,CACvBM,QAAQ,EACRC,YAAY,GAoCO,EAhCfC,WAA4B,CAChCC,KAAM,CACFC,SAAU,uCACVC,UAAW,4EACXC,mBAAmB,EACnBC,YAAa,4BAGjBC,MAAO,CACHC,cAAe,iBACfC,wBAAwB,IAsBT,EAlBfC,UAAY,CAChBC,UAAW,CAAC,kDACZC,OAAQ,0CAgBW,EAZfC,KAAO,IAAIC,IAAqB,EAAKb,YAYtB,EATfc,aAAe,CACnBC,OAAQ,EAAKN,UAAUC,WAQJ,EAJfM,aAAe,CACnBD,OAAQ,EAAKN,UAAUC,WAGJ,EAiBfO,SAAW,WACf,IAAMC,EAAO,EAAKN,KAAKO,aACvB,EAAKC,SAAU,CAAErB,YAAY,EAAMsB,KAAMH,EAAKG,OAC9C9F,OAAO+F,YAAcJ,EAAK/G,SApBP,EAwBfoH,SAAW,SAACP,GAChB,OAAO,EAAKJ,KAAKY,mBAAmBR,GAAcS,OAAM,SAACC,GAGrD,OAFAC,QAAQC,IAAI,sBAEL,EAAKhB,KAAKiB,kBAAkBb,GAAcnF,MAAM,SAAAiG,GACnDH,QAAQC,IAAIE,MACbL,OAAM,SAASC,GAClBC,QAAQC,IAAI,2BAA4BF,UA/BzB,EAqCfK,OAAS,WAEb,IAAMb,EAAO,EAAKN,KAAKO,aACnBD,GAUA,EAAKE,SAAU,CAAErB,YAAY,EAAMsB,KAAMH,EAAKG,OAC9C,EAAKE,SAAS,EAAKP,cAAcnF,KAAK,EAAKoF,WAV3C,EAAKL,KAAKoB,cAAc,EAAKlB,eAzCd,EAwDfmB,OAAS,WAEb,EAAKrB,KAAKqB,UA1DS,EA+GfC,OAAS,WACb,EAAKd,SAAS,CACVtB,QAAS,EAAKN,MAAMM,UA/GxB,EAAKc,KAAKuB,wBAAuB,SAACT,EAAOhH,GACrC,EAAK6G,SAAS,EAAKP,cAAcnF,KAAK,EAAKoF,aAE/C,IAAMC,EAAY,EAAKN,KAAKO,aALT,OAMhBD,IACC,EAAK1B,MAAQ,CAAEO,YAAY,EAAMsB,KAAMH,EAAKG,MAC5C9F,OAAO+F,YAAcJ,EAAK/G,SARX,E,iFAanBsB,KAAKoE,MAAMZ,kB,+BAgDE,IAAD,EACiBxD,KAAK+D,MADtB,EACJO,WADI,EACQsB,KACpB,OACI,8BACI,gBAACe,EAAA,EAAD,CAAQC,UAAU,sEAAsEC,OAAK,EAACC,OAAO,IACjG,gBAACC,EAAA,EAAD,KACI,gBAACC,EAAA,EAAD,CAAaC,IAAKC,IAAMC,GAAG,IAAIC,MAAO,CAACC,QAAS,SAAUC,SAAU,MACpE,uBAAKC,IAAI,0BAA0BC,OAAO,SAD1C,SAEA,gBAACC,EAAA,EAAD,CAAeC,QAAS1H,KAAKyG,OAAQG,UAAU,OAAOQ,MAAO,CAACO,SAAU,WAAYC,IAAK,MACzF,gBAACC,EAAA,EAAD,CAAUjB,UAAU,mBAAmBvC,OAAQrE,KAAK+D,MAAMM,OAAQyD,QAAM,EAACV,MAAO,CAACO,SAAU,aACvF,sBAAIf,UAAU,wBACV,gBAACmB,EAAA,EAAD,KACI,gBAACC,EAAA,EAAD,CAASf,IAAKC,IAAMQ,QAAS1H,KAAKyG,OAAQU,GAAG,KAA7C,SAEJ,gBAACY,EAAA,EAAD,KACI,gBAACC,EAAA,EAAD,CAASf,IAAKC,IAAMQ,QAAS1H,KAAKyG,OAAQU,GAAG,WAA7C,WAKJ,gBAACY,EAAA,EAAD,KACI,gBAACC,EAAA,EAAD,CAASf,IAAKC,IAAMQ,QAAS1H,KAAKyG,OAAQU,GAAG,YAA7C,YAEJ,gBAACY,EAAA,EAAD,KACI,gBAACC,EAAA,EAAD,CAASf,IAAKC,IAAMQ,QAAS1H,KAAKyG,OAAQU,GAAG,WAA7C,WAEJ,gBAACY,EAAA,EAAD,KACI,gBAACC,EAAA,EAAD,CAASf,IAAKC,IAAMQ,QAAS1H,KAAKyG,OAAQU,GAAG,YAA7C,YAEJ,gBAACY,EAAA,EAAD,KACI,gBAACC,EAAA,EAAD,CAASf,IAAKC,IAAMQ,QAAS1H,KAAKyG,OAAQU,GAAG,UAA7C,eAIZ,uBAAKP,UAAU,iB,GAtIjBqB,aA6JPC,eACX,SAACnE,GAAD,OAA6BA,EAAMN,aACnC0E,EAFWD,CAGX/D,G,QCtLSiE,EAAS,SAACC,GAAD,MAAmB,CACrCC,QAAS,CACLjB,QAAS,SAACjD,GAAD,OAA0BA,EAAMgD,OAAShD,EAAMgD,MAAMC,SAAYgB,EAAMhB,SAChFkB,OAAQ,SAACnE,GAAD,MAA0B,UAClCoE,gBAAiB,SAACpE,GACd,OAAGA,EAAMgD,OAAShD,EAAMgD,MAAMqB,gBACnB,cAEHrE,EAAMgD,OAAShD,EAAMgD,MAAMoB,kBAAqC,WAAfpE,EAAM3B,KAAoB4F,EAAMK,OAAOC,GAAKN,EAAMvH,KAAK6H,KAEpHC,MAAO,SAACxE,GAAD,OAA0BA,EAAMgD,OAAShD,EAAMgD,MAAMwB,QAA0B,WAAfxE,EAAM3B,KAAoB4F,EAAMK,OAAOG,GAAIR,EAAMvH,KAAK8H,QAC7HE,UAAY,SAAC1E,GAAD,OAA0BA,EAAMgD,OAAShD,EAAMgD,MAAM0B,WAAc,UAC/EC,SAAU,SAAC3E,GAAD,OAA0BA,EAAMgD,OAAShD,EAAMgD,MAAM2B,UAAa,KAEhFC,MAAO,CACLD,SAAU,GACVE,WAAY,KAEdC,SAAU,CACNH,SAAU,GACVE,WAAY,IACZ5B,QAAS,OACT8B,UAAW,SAEfC,cAAe,CACX/B,QAAS,SAACjD,GAAD,OAA0BA,EAAMiF,MAAQjF,EAAMiF,KAAKjC,OAAShD,EAAMiF,KAAKjC,MAAMC,SAAY,QAClGkB,OAAQ,SAACnE,GAAD,OAA0BA,EAAMiF,MAAQjF,EAAMiF,KAAKjC,OAAShD,EAAMiF,KAAKjC,MAAMmB,QAAW,iBAChGe,YAAa,IAEjBD,KAAM,CACFhC,QAAS,SAACjD,GAAD,OAA0BA,EAAMiF,MAAQjF,EAAMiF,KAAKjC,OAAShD,EAAMiF,KAAKjC,MAAMC,SAAYgB,EAAMgB,KAAKhC,SAC7GmB,gBAAiB,SAACpE,GAAD,OAA0BA,EAAMiF,MAAQjF,EAAMiF,KAAKjC,OAAShD,EAAMiF,KAAKjC,MAAMoB,iBAAoBH,EAAMgB,KAAKV,IAC7HC,MAAO,SAACxE,GAAD,OAA0BA,EAAMiF,MAAQjF,EAAMiF,KAAKjC,OAAShD,EAAMiF,KAAKjC,MAAMwB,OAAUP,EAAMgB,KAAKR,IACzGU,OAAQ,YACR,UAAW,CACPC,eAAgB,OAChBZ,MAAO,SAACxE,GAAD,OAA0BA,EAAMiF,MAAQjF,EAAMiF,KAAKjC,OAAShD,EAAMiF,KAAKjC,MAAMoB,iBAAoBH,EAAMgB,KAAKV,IACnHH,gBAAiB,SAACpE,GAAD,OAA0BA,EAAMiF,MAAQjF,EAAMiF,KAAKjC,OAAShD,EAAMiF,KAAKjC,MAAMwB,OAAUP,EAAMgB,KAAKR,KAEvHY,aAAc,EACdC,cAAc,IAElBC,IAAK,CACDC,SAAU,QAEdC,IAAK,CACDxC,QAAS,IAEbyC,KAAM,CACFlB,MAAOP,EAAMO,MACbG,SAAU,IAEdgB,UAAW,CACP1C,QAAS,KAIF2C,EAAsB,SAAC3B,GAAD,sBAC9BD,EAAOC,GADuB,CAEjCC,QAAS,CACPjB,QAAS,SAACjD,GAAD,OAA+BA,EAAMgD,OAAShD,EAAMgD,MAAMC,SAAY,IAC/EkB,OAAQ,SAACnE,GAAD,MAA+B,QACvCqE,gBAAiB,SAACrE,GAChB,IAAMsE,EAAStE,EAAMP,UAAYO,EAAMP,SAASX,MAAK,SAAA+G,GAAC,MAAe,WAAXA,EAAExH,QAC5D,GAAGiG,GAAUA,EAAOtB,OAASsB,EAAOtB,MAAMqB,gBACtC,OAAOC,EAAOtB,MAAMqB,gBAAgBzJ,KAG1CwJ,gBAAiB,SAACpE,GAChB,IAAMsE,EAAStE,EAAMP,UAAYO,EAAMP,SAASX,MAAK,SAAA+G,GAAC,MAAe,WAAXA,EAAExH,QAC5D,OAAGiG,GAAUA,EAAOtB,OAASsB,EAAOtB,MAAMqB,gBAC/B,cAEJC,EAAUA,GAAUA,EAAOtB,OAASsB,EAAOtB,MAAMoB,iBAAmBH,EAAMK,OAAOC,GAAMN,EAAMvH,KAAK6H,IAE3GC,MAAO,SAACxE,GAAD,OAA+BA,EAAMP,UAAYO,EAAMP,SAASX,MAAK,SAAA+G,GAAC,MAAe,WAAXA,EAAExH,QAAqB4F,EAAMK,OAAOG,GAAIR,EAAMvH,KAAK8H,OACpIE,UAAY,SAAC1E,GAAD,OAA+BA,EAAMgD,OAAShD,EAAMgD,MAAM0B,WAAc,UACpFoB,UAAW,SAAC9F,GACV,IAAMsE,EAAStE,EAAMP,UAAYO,EAAMP,SAASX,MAAK,SAAA+G,GAAC,MAAe,WAAXA,EAAExH,QAC5D,GAAGiG,GAAUA,EAAOtB,OAASsB,EAAOtB,MAAMqB,gBACtC,OAAOC,EAAOtB,MAAMqB,gBAAgBjB,QAG1C2C,iBAAkB,YAClBC,eAAgB,SAElBP,IAAK,CACHxC,QAAS,eCxCTgD,G,YAAkBC,aA3CP,SAACjC,GAAD,sBACRD,EAAOC,GADC,CAEXhB,QAAS,CACLA,QAAS,IAEbkD,MAAO,CACLlD,QAAS,GACTmD,MAAO,YAoCSF,EA5BX,SAAClG,GAAyB,IAC3BqG,EAA2BrG,EAA3BqG,MAAOrD,EAAoBhD,EAApBgD,MAAoBhD,EAAbsG,QAClB,OACI,gBAAC,WAAD,KACI,uBAAK9D,WAAYQ,GAAK,iBAAcA,EAAMuD,SAAW,IAArC,SACXF,GAAS,0BAENA,EAAMG,KAAI,SAAAC,GACN,IAAMC,EAAQD,EAAKE,QAAQ,MACvBC,EAAW,KAMf,OALGF,EAAQ,IACPE,EAAWH,EAAKI,UAAUH,EAAQ,GAAGI,MAAM,KAC3CL,EAAOA,EAAKI,UAAU,EAAGH,IAGtB,0BACD,wBAAMK,wBAAyB,CAACC,OAAQP,KACxCG,GAAY,8BAAOA,EAASJ,KAAI,SAAAS,GAAE,OAAI,8BAAQ,wBAAMF,wBAAyB,CAACC,OAAQC,SAA1E,gBAajCC,GAAb,iLAEQ,OACI,gBAACjB,EAAoBrK,KAAKoE,WAHtC,GAA0B6D,aCKpBoC,GAAkBC,aAjDP,SAACjC,GAAD,sBACRD,EAAOC,GADC,CAEXhB,QAAS,CACLA,QAAS,QA8CKiD,EAtCX,SAAClG,GAAyB,IAC3B4E,EAAoG5E,EAApG4E,MAAOE,EAA6F9E,EAA7F8E,SAAUpI,EAAmFsD,EAAnFtD,KAAMyK,EAA6EnH,EAA7EmH,KAAMd,EAAuErG,EAAvEqG,MAAOe,EAAgEpH,EAAhEoH,MAAOjB,EAAyDnG,EAAzDmG,MAAOlB,EAAkDjF,EAAlDiF,KAAMjC,EAA4ChD,EAA5CgD,MAAOqE,EAAqCrH,EAArCqH,WAAkB3B,GAAmB1F,EAAzB3B,KAAyB2B,EAAnB0F,MAAMY,EAAatG,EAAbsG,QAC3F,OACI,gBAAC,WAAD,KACI,uBAAK9D,UAAWQ,GAAK,iBAAcA,EAAMuD,SAAW,GAA/B,YAAqCD,EAAQpC,UAC5DwB,GAAQA,EAAK1C,OAAkC,WAAzB0C,EAAK1C,MAAM0B,WAA0B,qBAAGlC,UAAS,UAAKkD,EAAK4B,MAAV,YAAmBhB,EAAQZ,KAA3B,YAAmCY,EAAQrD,SAAWD,MAAO,CAAC0B,UAAWgB,EAAK1C,MAAM0B,aAC3JE,GAAS,sBAAIpC,UAAW8D,EAAQ1B,MAAO5B,MAAO,CAACwB,MAAO6C,GAAcA,EAAW7C,MAAOG,SAAU0C,GAAcA,EAAW1C,WACrHe,GAAQA,EAAK1C,OAAkC,SAAzB0C,EAAK1C,MAAM0B,WAAwB,qBAAGlC,UAAS,UAAKkD,EAAK4B,MAAV,YAAmBhB,EAAQZ,KAA3B,YAAmCY,EAAQrD,SAAWD,MAAO,CAAC0B,UAAWgB,EAAK1C,MAAM0B,aACnJ,wBAAMqC,wBAAyB,CAACC,OAAQpC,MAGlDE,GAAY,uBAAKtC,UAAW8D,EAAQxB,UAAWA,GAE7CqB,EAA2B,aAAjBA,EAAMoB,OAChC,0BAAQ/E,UAAU,YAChBW,IAAG,kIAA6HgD,EAAMqB,GAAnI,6BAEM,0BAAShF,UAAS,oBAAgBQ,GAASA,EAAMuD,SAAY,GAAKpD,IAAG,wCAAmCgD,EAAMqB,IAAMC,MAAM,4EAEjHL,GAAS,2BAAK,uBAAK5E,UAAW8D,EAAQf,IAAKpC,IAAKiE,KAErE1K,GAAQA,EAAK8J,KAAI,SAAAkB,GAAC,OAAI,qBAAGX,wBAAyB,CAACC,OAAQU,QAC5CP,GAAQA,EAAKX,KAAI,SAAAmB,GAAC,OAAI,qBAAGZ,wBAAyB,CAAEC,OAAQY,KAAKD,SAEhEtB,GAAS,gBAAC,GAAD,CAAMA,MAAOA,IAEvBpB,GACE,uBAAKzC,UAAS,UAAK8D,EAAQtB,cAAb,UACV,qBAAGxC,UAAW8D,EAAQrB,KAAM4C,KAAM5C,EAAK4C,MACnC,4BAAQ5C,EAAKvI,aAWhCoL,GAAb,iLAEQ,OACI,gBAAC,GAAoBlM,KAAKoE,WAHtC,GAAoC6D,a,kCC8D9BoC,GAAkBC,aA9GP,SAACjC,GAAD,sBACRD,EAAOC,MA6GQiC,EAtGZ,SAAClG,GAAuB,IAG5B+H,EAAMC,EAAOC,EAASC,EAFlBtD,EAAuE5E,EAAvE4E,MAAiBlI,GAAsDsD,EAAhE8E,SAAgE9E,EAAtDtD,MAAY0K,GAA0CpH,EAAhDiF,KAAgDjF,EAA1CoH,OAAOpE,EAAmChD,EAAnCgD,MAAOmD,EAA4BnG,EAA5BmG,MAAOgC,EAAqBnI,EAArBmI,SAAU7B,EAAWtG,EAAXsG,QAC9D8B,EAAuBpI,EAAvBoI,UAAWC,EAAYrI,EAAZqI,QAEXC,EAAaC,KAAK1L,OAAOuL,GAAa,IAAIG,MAAQC,YAClDC,EAAU,WAGZ,IAAIC,GAAe,IAAIH,MAAOI,UAC1BC,GAAgBN,EAAaI,GAAgB,IAGjDX,EAAOc,KAAKC,KAAKF,EAAe,OAChCA,GAA8B,MAE9BZ,EAAQa,KAAKC,KAAKF,EAAe,MACjCA,GAA8B,KAE9BX,EAAUY,KAAKC,KAAKF,EAAe,IACnCV,EAAUW,KAAKC,KAAKF,EAAe,KAGvCH,IACAM,YAAYN,EAAS,KAErB,IAAMO,EAAQ,kBAAM,uBAAKxG,UAAU,kBAE/B2D,EAA2B,aAAjBA,EAAMoB,OACZ,0BAAQ/E,UAAU,YACNW,IAAG,kIAA6HgD,EAAMqB,GAAnI,6BAEH,0BAAShF,UAAS,oBAAgBQ,GAASA,EAAMuD,SAAY,GAAKpD,IAAG,wCAAmCgD,EAAMqB,IAAMC,MAAM,4EAE1IL,GAAS,2BAAK,uBAAK5E,UAAW8D,EAAQf,IAAKpC,IAAKiE,OAI9C6B,EAAO,SAAClB,EAAWC,EAAYC,EAAcC,GAAtC,OAAuD,gBAAC,WAAD,KAChE,uBAAK1F,UAAU,0FACX,uBAAKA,UAAU,cACX,uBAAKA,UAAU,gEACX,uBAAKA,UAAU,aAAa0G,KAAOd,GAAWe,QAC9C,uBAAK3G,UAAU,eAAe0G,KAAOd,GAAWgB,OAAO,UAG/D,uBAAK5G,UAAU,iBACX,uBAAKA,UAAU,eAAc,qBAAGqF,KAAK,KAAMjD,IAC3C,sBAAIpC,UAAU,aACV,0BACI,uBAAKA,UAAU,cAAa,uBAAKW,IAAI,6BAA6BkG,IAAI,MACtE,4BAAQH,KAAOd,GAAWgB,OAAO,MAAjC,MAA4CF,KAAOb,GAASe,OAAO,QAEvE,0BACI,uBAAK5G,UAAU,cAAa,uBAAKW,IAAI,6BAA6BkG,IAAI,MACtE,4BAAQlB,OAKxB,uBAAK3F,UAAU,cACb9F,GAAQA,EAAK8J,KAAI,SAAAkB,GAAC,OAAI,6BAAMA,EAAN,SAEtBK,GAAQA,EAAO,GAAKC,GAASA,EAAQ,GAAKC,GAAWA,EAAU,GAAKC,GAAWA,EAAU,GAAK,uBAAK1F,UAAU,oCAC3G,sBAAIA,UAAU,eACV,0BAAI,uBAAKgF,GAAG,MAAMhF,UAAU,aAAauF,GAAW,uBAAKvF,UAAU,YAAf,QACpD,0BAAI,uBAAKgF,GAAG,OAAOhF,UAAU,aAAawF,GAAY,uBAAKxF,UAAU,YAAf,QACtD,0BAAI,uBAAKgF,GAAG,SAAShF,UAAU,aAAayF,GAAc,uBAAKzF,UAAU,YAAf,QAC1D,0BAAI,uBAAKgF,GAAG,SAAShF,UAAU,aAAa0F,GAAc,uBAAK1F,UAAU,YAAf,YAMlE,OACI,gBAAC,WAAD,KACI,2BACI,2BACA,uBAAKA,UAAS,cAAS8D,EAAQb,MAEvBzC,GAA8B,UAArBA,EAAMsG,WAAyB,gBAAC,WAAD,KACpC,uBAAK9G,UAAU,YACTyG,EAAMlB,EAAMC,EAAOC,EAASC,IAElC,uBAAK1F,UAAU,WAAWQ,MAAO,CAAC0B,UAAW,SACvCsE,MAEU,gBAAC,WAAD,KAChB,uBAAKxG,UAAU,WAAWQ,MAAO,CAAC0B,UAAW,SACvCsE,KAEN,uBAAKxG,UAAU,YACTyG,EAAMlB,EAAMC,EAAOC,EAASC,YAarDqB,GAAb,iLAEQ,OACI,gBAAC,GAAoB3N,KAAKoE,WAHtC,GAA2B6D,a,SC9DrBoC,I,YAAkBC,aAlDP,SAACjC,GAAD,sBACRD,EAAOC,MAiDQiC,EA1CT,SAAClG,GAAsB,IAC1B4E,EAAqF5E,EAArF4E,MAAiBlI,GAAoEsD,EAA9E8E,SAA8E9E,EAApEtD,MAAYsG,GAAwDhD,EAA9DiF,KAA8DjF,EAAxDgD,OAAOoE,EAAiDpH,EAAjDoH,MAAMjB,EAA2CnG,EAA3CmG,MAAOqD,EAAoCxJ,EAApCwJ,UAAWC,EAAyBzJ,EAAzByJ,aAAcnD,EAAWtG,EAAXsG,QAC5E8B,EAAcpI,EAAdoI,UAEF,OACI,gBAAC,WAAD,KACI,uBAAK5F,UAAS,0BAAsBQ,GAASA,EAAMuD,SAAY,EAAjD,mBACV,uBAAK/D,UAAU,aACX,uBAAKA,UAAU,cAEX2D,EAA2B,aAAjBA,EAAMoB,OACZ,0BAAQ/E,UAAU,YACNW,IAAG,kIAA6HgD,EAAMqB,GAAnI,6BAEH,0BAAShF,UAAS,oBAAgBQ,GAASA,EAAMuD,SAAY,GAAKpD,IAAG,wCAAmCgD,EAAMqB,IAAMC,MAAM,4EAE1IL,GAAS,2BAAK,uBAAK5E,UAAW8D,EAAQf,IAAKpC,IAAKiE,MAGpD,uBAAK5E,UAAU,qBACX,uBAAKA,UAAU,mBACX,qBAAGqF,KAAK,oBAAoBjD,IAEhC,uBAAKpC,UAAU,kBACX,0BACI,0BAAI,qBAAGA,UAAU,aAAakH,cAAY,SAAW,qBAAG7B,KAAK,KAAK2B,IAClE,0BAAI,qBAAGhH,UAAU,mBAAmBkH,cAAY,SAAW,qBAAG7B,KAAK,KAAKqB,KAAOd,GAAWgB,OAAO,kBACjG,0BAAI,qBAAG5G,UAAU,gBAAgBkH,cAAY,SAAW,qBAAG7B,KAAK,KAAK4B,MAG7E,uBAAKjH,UAAU,kBAEX9F,GAAQA,EAAK8J,KAAI,SAAAkB,GAAC,OAAI,6BAAMA,EAAN,iBAYzCiC,GAAb,iLAEQ,OACI,gBAAC,GAAoB/N,KAAKoE,WAHtC,GAA0B6D,aCMpBoC,I,YAAkBC,aA1DP,SAACjC,GAAD,sBACRD,EAAOC,MAyDQiC,EAlDT,SAAClG,GAAwB,IAC5B4E,EAA8F5E,EAA9F4E,MAA6B5B,GAAiEhD,EAAvF8E,SAAuF9E,EAA7EtD,KAA6EsD,EAAvEiF,KAAuEjF,EAAjEgD,OAAOoE,EAA0DpH,EAA1DoH,MAAOjB,EAAmDnG,EAAnDmG,MAAkByD,GAAiC5J,EAA5CwJ,UAA4CxJ,EAAjC4J,UAAUC,EAAuB7J,EAAvB6J,WACzEV,GADgGnJ,EAAXsG,QAC5EtG,EAATmJ,MAEF,OACI,gBAAC,WAAD,KACI,uBAAK3G,UAAS,iBAAaQ,GAASA,EAAMuD,SAAY,EAAxC,gBACzB,uBAAK/D,UAAU,QACd,uBAAKA,UAAU,kFACd,uBAAKA,UAAU,oBAAoB0G,KAAOC,GAAMA,QAChD,uBAAK3G,UAAU,sBAAsB0G,KAAOC,GAAMC,OAAO,SAExDjD,EAA2B,aAAjBA,EAAMoB,OAChB,0BAAQ/E,UAAU,YAChBW,IAAG,kIAA6HgD,EAAMqB,GAAnI,2BACHsC,UAAU,OAED,0BAAQtH,UAAS,oBAAgBQ,GAASA,EAAMuD,SAAY,GAAKpD,IAAG,wCAAmCgD,EAAMqB,IAAMC,MAAM,4EAErI,uBAAKjF,UAAU,eAAeW,IAAKiE,EAAOiC,IAAI,MAE5CzE,GAASgF,GAAYC,IACxB,uBAAKrH,UAAU,yBACd,uBAAKA,UAAU,2BAA0B,qBAAGqF,KAAK,eAAejD,IAChE,uBAAKpC,UAAU,mCACZoH,GAAY,uBAAKpH,UAAU,eAE5B,sBAAIA,UAAU,oBACb,0BAAKoH,KAILC,GAAc,uBAAKrH,UAAU,eAC9B,uBAAKA,UAAU,qBAAf,gBACA,sBAAIA,UAAU,oBAEbqH,EAAW/C,MAAM,KAAKN,KAAI,SAACuD,EAAkBrD,GAAnB,OAAqC,sBAAIsD,IAAK,KAAOtD,GAAO,qBAAGmB,KAAK,KAAKkC,EAAb,qBAgBnFE,GAAb,iLAEQ,OACI,gBAAC,GAAoBrO,KAAKoE,WAHtC,GAA4B6D,a,oBCtCtBoC,I,MAAkBC,aA1BP,SAACjC,GAAD,sBACRD,EAAOC,GADC,CAEXhB,QAAS,CACLA,QAAS,IAEbkD,MAAO,CACLlD,QAAS,GACTmD,MAAO,YAmBSF,EAXX,SAAClG,GAAyB,IAC3BkK,EAAqBlK,EAArBkK,OAAQ5D,EAAatG,EAAbsG,QACZ,OACI,gBAAC,WAAD,KACI,uBAAK9D,UAAS,oBAAe8D,EAAQpC,UACjC,gBAAC,KAAD,CAAmBmC,MAAO6D,UAQjCC,GAAb,iLAEQ,OACI,gBAAC,GAAoBvO,KAAKoE,WAHtC,GAA6B6D,aC8CvBoC,I,MAAkBC,aAzDT,SAACjC,GAAD,sBACR2B,EAAmB3B,MAwDFiC,EAhDb,SAAClG,GAA8B,IAChCsG,EAAsBtG,EAAtBsG,QAAS7G,EAAaO,EAAbP,SACb,OACI,gBAAC,WAAD,KACI,uBAAK+C,UAAoC8D,EAAQpC,SAC7C,gBAACvB,EAAA,EAAD,CAAWH,UAAW8D,EAAQX,WAC5B,uBAAKnD,UAAS,cAAS8D,EAAQb,IAAjB,YAEVhG,GAAaA,EAAS+G,KAAI,SAAC4D,EAAkB1D,GAC3C,OAAG2D,6BAAkBD,EAAQ/L,OAA0B,WAAjB+L,EAAQ/L,KAE1C,gBAAC,GAAD,eAAgB2L,IAAK,KAAOtD,GAAY0D,IAGnB,UAAjBA,EAAQ/L,KAEZ,gBAAC,GAAD,eAAO2L,IAAK,QAAUtD,GAAY0D,IAGb,SAAjBA,EAAQ/L,KAEZ,gBAAC,GAAD,eAAM2L,IAAK,OAAStD,GAAY0D,IAGX,WAAjBA,EAAQ/L,KAEZ,gBAAC,GAAD,eAAQ2L,IAAK,SAAWtD,GAAY0D,IAGf,YAAjBA,EAAQ/L,KAEZ,gBAAC,GAAD,eAAS2L,IAAK,UAAYtD,GAAY0D,IAGjB,SAAjBA,EAAQ/L,KAEZ,gBAAC,GAAD,eAAM2L,IAAK,OAAStD,GAAY0D,SAF/B,aAgBzBE,G,4LAGF1O,KAAK2O,sB,+BAIL,OACE,gBAAC,WAAD,KACG3O,KAAK4O,gB,0CAMV5O,KAAKoE,MAAMT,kB,mCAGS,IACZC,EAAW5D,KAAKoE,MAAhBR,OAER,OACI,gBAAC,WAAD,KAEEA,GAAUA,EAAOgH,KAAI,SAACiE,EAAkB/D,GAAnB,OAAqC,gBAAC,GAAD,iBAAqB+D,EAArB,CAAyBT,IAAK,KAAOtD,a,GAxB3E7C,iBA+BfC,gBACb,SAACnE,GAAD,OAA6BA,EAAMH,SACnCkL,EAFa5G,CAGbwG,IClHa,YAACtK,GAAD,OACX,gBAAC,WAAD,KACI,gBAAC,EAAD,MACCA,EAAM2K,SACP,gBAACC,GAAD,QCOFC,I,kMAGFjP,KAAK2O,sB,2CAKL3O,KAAK2O,sB,+BAIL,OACE,gBAAC,WAAD,KACE,sBAAI/C,GAAG,cAAP,UACA,uHACC5L,KAAKkP,eACLlP,KAAKmP,sB,0CAMV,IAAM/N,EAAagO,SAASpP,KAAKoE,MAAMiL,MAAMC,OAAOlO,WAAY,KAAO,EACvEpB,KAAKoE,MAAMlC,cAAcd,K,qCAGH,IACdkB,EAAWtC,KAAKoE,MAAhB9B,OACR,OACE,yBAAOsE,UAAU,sBAAsB2I,kBAAgB,cACrD,6BACE,0BACE,wCACA,sCACA,mCACA,wCAGJ,6BACGjN,GAAUA,EAAOsI,KAAI,SAAC4E,EAAc1E,GAAf,OACpB,sBAAIsD,IAAK,MAAQtD,GACf,0BAAK0E,EAAMhD,WACX,0BAAKgD,EAAM/C,SACX,0BAAK+C,EAAMxG,OACX,0BAAKwG,EAAMjD,kB,yCAQK,IAClBnL,EAAepB,KAAKoE,MAApBhD,WACFqO,GAAkBrO,GAAc,GAAK,EACrCsO,GAAkBtO,GAAc,GAAK,EAE3C,OACE,uBAAKwF,UAAU,kCACb,gBAAC,IAAD,CAAMA,UAAU,mCAAmCO,GAAE,kBAAasI,IAAlE,YACCzP,KAAKoE,MAAMzB,WAAa,0CACzB,gBAAC,IAAD,CAAMiE,UAAU,mCAAmCO,GAAE,kBAAauI,IAAlE,a,GA9DgBzH,kBAoETC,gBACb,SAACnE,GAAD,OAA6BA,EAAMzB,SACnCqN,EAFazH,CAGb+G,ICvEIW,G,4LAGF5P,KAAK2O,sB,2CAKL3O,KAAK2O,sB,+BAIL,OACE,gBAAC,WAAD,KACE,sBAAI/C,GAAG,cAAP,SACA,uHACC5L,KAAK6P,cACL7P,KAAKmP,sB,0CAMV,IAAM/N,EAAagO,SAASpP,KAAKoE,MAAMiL,MAAMC,OAAOlO,WAAY,KAAO,EACvEpB,KAAKoE,MAAMxB,aAAaxB,K,oCAGH,IACbyB,EAAU7C,KAAKoE,MAAfvB,MACR,OACE,yBAAO+D,UAAU,sBAAsB2I,kBAAgB,cACrD,6BACE,0BACE,kCACA,wCACA,mCACA,qCAGJ,6BACG1M,GAASA,GAASA,EAAM+H,KAAI,SAACkF,EAAYhF,GAAb,OAC3B,sBAAIsD,IAAK,MAAQtD,GACf,0BAAKgF,EAAKvC,MACV,0BAAKuC,EAAKlC,WACV,0BAAKkC,EAAK9G,OACV,0BAAK8G,EAAKtE,e,yCAQM,IAClBpK,EAAepB,KAAKoE,MAApBhD,WACFqO,GAAkBrO,GAAc,GAAK,EACrCsO,GAAkBtO,GAAc,GAAK,EAE3C,OACE,uBAAKwF,UAAU,kCACb,gBAAC,IAAD,CAAMA,UAAU,mCAAmCO,GAAE,iBAAYsI,IAAjE,YACCzP,KAAKoE,MAAMzB,WAAa,0CACzB,gBAAC,IAAD,CAAMiE,UAAU,mCAAmCO,GAAE,iBAAYuI,IAAjE,a,GA9DezH,iBAoERC,gBACb,SAACnE,GAAD,OAA6BA,EAAMlB,QACnCkN,EAFa7H,CAGb0H,ICvEII,G,4LAGFhQ,KAAK2O,sB,2CAKL3O,KAAK2O,sB,+BAIL,OACE,gBAAC,WAAD,KACE,sBAAI/C,GAAG,cAAP,WACA,uHACC5L,KAAKiQ,gBACLjQ,KAAKmP,sB,0CAMV,IAAM/N,EAAagO,SAASpP,KAAKoE,MAAMiL,MAAMC,OAAOlO,WAAY,KAAO,EACvEpB,KAAKoE,MAAMf,eAAejC,K,sCAGH,IACfkC,EAAYtD,KAAKoE,MAAjBd,QACR,OACE,yBAAOsD,UAAU,sBAAsB2I,kBAAgB,cACrD,6BACE,0BACE,kCACA,mCACA,kCACA,wCAGJ,6BACGjM,GAAWA,GAAWA,EAAQsH,KAAI,SAACsF,EAAgBpF,GAAjB,OACjC,sBAAIsD,IAAK,MAAQtD,GACf,0BAAKoF,EAAO3C,MACZ,0BAAK2C,EAAOlH,OACZ,0BAAKkH,EAAOpP,MACZ,0BAAKoP,EAAOlC,kB,yCAQI,IAClB5M,EAAepB,KAAKoE,MAApBhD,WACFqO,GAAkBrO,GAAc,GAAK,EACrCsO,GAAkBtO,GAAc,GAAK,EAE3C,OACE,uBAAKwF,UAAU,kCACb,gBAAC,IAAD,CAAMA,UAAU,mCAAmCO,GAAE,mBAAcsI,IAAnE,YACCzP,KAAKoE,MAAMzB,WAAa,0CACzB,gBAAC,IAAD,CAAMiE,UAAU,mCAAmCO,GAAE,mBAAcuI,IAAnE,a,GA9DiBzH,iBAoEVC,gBACb,SAACnE,GAAD,OAA6BA,EAAMT,UACnC6M,EAFajI,CAGb8H,I,wCCQI3F,I,OAAkBC,aAlET,SAACjC,GAAD,sBACR2B,EAAmB3B,MAiEFiC,EAzDb,SAAClG,GAA8B,IAChCsG,EAA4BtG,EAA5BsG,QAAS7G,EAAmBO,EAAnBP,SAAUnC,EAAS0C,EAAT1C,KACrB0O,EAAY1O,GAAQ5B,OAAOyM,SAAS8D,SAAW,IAAM3O,EAAKzB,QAAQ,MAAO,KAAKA,QAAQ,QAAS,IAAIgL,UAAU,GAC7GqF,EAAYzM,GAAYA,EAAS0M,OAAS,IAAM1M,EAASX,MAAK,SAAA+G,GAAC,OAAe,OAAXA,EAAEnJ,SAAkB+C,EAASX,MAAK,SAAA+G,GAAC,OAAgB,OAAZA,EAAEQ,UAAmB5G,EAASX,MAAK,SAAA+G,GAAC,OAAgB,OAAZA,EAAEuB,UAC1JtF,QAAQC,IAAImK,GACZ,IAAIE,GAAO,EAEP,OACI,gBAAC,WAAD,KACI,uBAAK5J,UAAoC8D,EAAQpC,SAC7C,gBAACvB,EAAA,EAAD,CAAWH,UAAW8D,EAAQX,WAC5B,uBAAKnD,UAAS,cAAS8D,EAAQb,KAAO+B,GAAIlK,GAAQA,EAAKzB,QAAQ,MAAO,KAAKA,QAAQ,QAAQ,IAAIgL,UAAU,GAAI7D,MAAO,CAACO,SAAU,aAC3HyI,GAAYE,GAAa,wBAAM5I,QAAS,WAAQ+I,KAAKL,GAAWI,GAAO,EAAME,YAAW,WACxFF,GAAO,IACN,MAAWpJ,MAAO,CAACuJ,OAAQ,UAAWhJ,SAAU,WAAYiJ,MAAO,GAAIhJ,KAAM,GAAImB,SAAU,IAAKnC,UAAU,oBAC3G4J,GAAQ,gBAAC,KAAD,CAAOnM,OAAQmM,EAAMK,aAAa,wBAE1ChN,GAAaA,EAAS+G,KAAI,SAAC4D,EAAkB1D,GAC3C,OAAG2D,6BAAkBD,EAAQ/L,OAA0B,WAAjB+L,EAAQ/L,KAE1C,gBAAC,GAAD,eAAgB2L,IAAK,KAAOtD,GAAY0D,IAGnB,UAAjBA,EAAQ/L,KAEZ,gBAAC,GAAD,eAAO2L,IAAK,QAAUtD,GAAY0D,IAGb,SAAjBA,EAAQ/L,KAEZ,gBAAC,GAAD,eAAM2L,IAAK,OAAStD,GAAY0D,IAGX,WAAjBA,EAAQ/L,KAEZ,gBAAC,GAAD,eAAQ2L,IAAK,SAAWtD,GAAY0D,IAGf,YAAjBA,EAAQ/L,KAEZ,gBAAC,GAAD,eAAS2L,IAAK,UAAYtD,GAAY0D,IAGjB,SAAjBA,EAAQ/L,KAEZ,gBAAC,GAAD,eAAM2L,IAAK,OAAStD,GAAY0D,SAF/B,aAgBzBsC,G,4LAGF9Q,KAAK2O,sB,2CAKL3O,KAAK2O,sB,+BAIL,OACE,gBAAC,WAAD,KACG3O,KAAK4O,gB,0CAMV,IAAMlN,EAAO1B,KAAKoE,MAAMiL,MAAMC,OAAO5N,MAAQ,OAC7C1B,KAAKoE,MAAMrB,YAAYrB,K,mCAGH,IACZA,EAAS1B,KAAKoE,MAAd1C,KACFsB,EAAOhD,KAAKoE,MAAMnB,OAASjD,KAAKoE,MAAMnB,MAAMC,MAAK,SAAAC,GAAC,OAAIA,EAAEzB,OAASA,KAEvE,OACI,gBAAC,WAAD,KAEEsB,GAAQA,EAAKa,UAAYb,EAAKa,SAAS+G,KAAI,SAACiE,EAAkB/D,GAAnB,OAAqC,gBAAC,GAAD,iBAAqB+D,EAArB,CAAyBT,IAAK,KAAOtD,a,GA/BnG7C,iBAsCbC,gBACb,SAACnE,GAAD,OAA6BA,EAAMf,OACnC+N,EAFa7I,CAGb4I,IC/HIE,GAAcC,QACa,cAA7BnR,OAAOyM,SAAS8D,UAEa,UAA7BvQ,OAAOyM,SAAS8D,UAEhBvQ,OAAOyM,SAAS8D,SAAShB,MACrB,2DA8BR,SAAS6B,GAAgBC,GACrBC,UAAUC,cACLC,SAASH,GACT/Q,MAAK,SAAAmR,GACFA,EAAaC,cAAgB,WACzB,IAAMC,EAAmBF,EAAaG,WACtCD,EAAiBE,cAAgB,WACE,cAA3BF,EAAiB1N,QACbqN,UAAUC,cAAcO,WAKxB1L,QAAQC,IAAI,6CAKZD,QAAQC,IAAI,4CAM/BH,OAAM,SAAAC,GACHC,QAAQD,MAAM,4CAA6CA,M,aCvEvE,uCAcA,IAAMvG,GAAUmS,SAASC,qBAAqB,QAAQ,GAAGC,aAAa,QAChEC,GAAUC,YAAqB,CAAEC,SAAUxS,KAG3CyS,GCZS,SAAwBH,EAAkBI,GACrD,IAAMC,EAAa,CACfC,IACAC,YAAiBP,IAGfQ,EAAcC,YAAgB,eAC7B3O,EAD4B,CAE/B4O,OAAQC,YAAcX,MAGpBY,EAAY,GACZC,EAAoC,qBAAX/S,OAAyB,KAAOA,OAK/D,OAJI+S,GAAmBA,EAAgBC,8BACnCF,EAAU1O,KAAK2O,EAAgBC,gCAG5BC,YACHP,EACAJ,EACAY,IAAO,WAAP,GAAQC,IAAe,WAAf,EAAmBZ,IAA3B,OAA2CO,KDRrCM,CAAelB,IAahB3J,GAAe,CACxBO,MAAO,UACPS,KAAM,CACFR,GAAI,UACJF,GAAI,kBACJtB,QAAS,YACTkC,OAAQ,SAEZzI,KAAM,CACF8H,MAAO,UACPD,GAAI,WAERD,OAAQ,CACJG,GAAI,UACJF,GAAI,UACJtB,QAAS,aAEbA,QAAS,QAGb8L,SACI,gBAAC,IAAD,CAAUhB,MAAOA,IACb,gBAAC,IAAD,CAAiBH,QAASA,IAC1B,gBAAC,KAAD,CAAe3J,MAAOA,IAClB,iBE5CG,kBACX,gBAAC+K,GAAD,KACI,gBAAC,IAAD,CAAOC,OAAK,EAAC3R,KAAK,IAAI4R,UAAWC,KACjC,gBAAC,IAAD,CAAO7R,KAAK,4BAA4B4R,UAAWrE,KACnD,gBAAC,IAAD,CAAOvN,KAAK,2BAA2B4R,UAAW1D,KAClD,gBAAC,IAAD,CAAOlO,KAAK,6BAA6B4R,UAAWtD,KACpD,gBAAC,IAAD,CAAOtO,KAAK,SAAS4R,UAAWC,QFsC5B,SAIR1B,SAAS2B,eAAe,SDvCb,WACX,GAA6C,kBAAmBpC,UAAW,CAIvE,GADkB,IAAIqC,IADVC,GACmB5T,OAAOyM,SAASK,YACjC+G,SAAW7T,OAAOyM,SAASoH,OAIrC,OAGJ7T,OAAO8T,iBAAiB,QAAQ,WAC5B,IAAMzC,EAAK,UAAMuC,GAAN,sBAEP1C,GAwChB,SAAiCG,GAE7B7Q,MAAM6Q,GACD/Q,MAAK,SAAAnB,GAEF,IAAM4U,EAAc5U,EAASJ,QAAQiV,IAAI,gBACjB,MAApB7U,EAASE,QAAmB0U,IAAsD,IAAvCA,EAAY9I,QAAQ,cAE/DqG,UAAUC,cAAc0C,MAAM3T,MAAK,SAAAmR,GAC/BA,EAAayC,aAAa5T,MAAK,WAC3BN,OAAOyM,SAAS0H,eAKxB/C,GAAgBC,MAGvBnL,OAAM,WACHE,QAAQC,IAAI,oEAzDR+N,CAAwB/C,GAGxBD,GAAgBC,OCqBhCgD,I","file":"static/js/main.c2179d82.chunk.js","sourcesContent":["/* tslint:disable */\n/* eslint-disable */\n//----------------------\n// \n// Generated using the NSwag toolchain v13.2.1.0 (NJsonSchema v10.1.3.0 (Newtonsoft.Json v10.0.0.0)) (http://NSwag.org)\n// \n//----------------------\n// ReSharper disable InconsistentNaming\n\nexport class BaseClient {\n protected async transformOptions(options: RequestInit): Promise {\n // enable cookie\n options.credentials = \"same-origin\";\n const idToken = sessionStorage.getItem(\"msal.idtoken\");\n if (idToken) {\n (options.headers as any)[\"Authorization\"] = \"Bearer \" + idToken;\n }\n \n return Promise.resolve(options);\n }\n\n protected async transformResult(url: string, response: Response, processor: (response: Response) => any): Promise { // tslint:disable-line:no-any\n const status = response ? response.status : 0;\n\n if (status >= 400) {\n }\n\n if (status === 400 || status === 430) {\n const errorCode = await BaseClient.getErrorCodeFromResponse(response);\n }\n\n if (status === 403) {\n \n }\n\n return processor(response);\n }\n\n private static async getErrorCodeFromResponse(errorResponse: Response): Promise {\n const json = await errorResponse.clone().json();\n return json.ErrorCode;\n }\n}\n\nexport class ConfigClient extends BaseClient {\n private http: { fetch(url: RequestInfo, init?: RequestInit): Promise };\n private baseUrl: string;\n protected jsonParseReviver: ((key: string, value: any) => any) | undefined = undefined;\n\n constructor(baseUrl?: string, http?: { fetch(url: RequestInfo, init?: RequestInit): Promise }) {\n super();\n this.http = http ? http : window;\n this.baseUrl = baseUrl ? baseUrl : \"\";\n }\n\n getAuthConfig(): Promise {\n let url_ = this.baseUrl + \"/api/config/auth\";\n url_ = url_.replace(/[?&]$/, \"\");\n\n let options_ = {\n method: \"GET\",\n headers: {\n \"Accept\": \"application/json\"\n }\n };\n\n return this.transformOptions(options_).then(transformedOptions_ => {\n return this.http.fetch(url_, transformedOptions_);\n }).then((_response: Response) => {\n return this.transformResult(url_, _response, (_response: Response) => this.processGetAuthConfig(_response));\n });\n }\n\n protected processGetAuthConfig(response: Response): Promise {\n const status = response.status;\n let _headers: any = {}; if (response.headers && response.headers.forEach) { response.headers.forEach((v: any, k: any) => _headers[k] = v); };\n if (status === 200) {\n return response.text().then((_responseText) => {\n let result200: any = null;\n result200 = _responseText === \"\" ? null : JSON.parse(_responseText, this.jsonParseReviver);\n return result200;\n });\n } else if (status !== 200 && status !== 204) {\n return response.text().then((_responseText) => {\n return throwException(\"An unexpected server error occurred.\", status, _responseText, _headers);\n });\n }\n return Promise.resolve(null);\n }\n}\n\nexport class ContentClient extends BaseClient {\n private http: { fetch(url: RequestInfo, init?: RequestInit): Promise };\n private baseUrl: string;\n protected jsonParseReviver: ((key: string, value: any) => any) | undefined = undefined;\n\n constructor(baseUrl?: string, http?: { fetch(url: RequestInfo, init?: RequestInit): Promise }) {\n super();\n this.http = http ? http : window;\n this.baseUrl = baseUrl ? baseUrl : \"\";\n }\n\n getEvents(startIndex: number | null): Promise {\n let url_ = this.baseUrl + \"/api/content/events/list?\";\n if (startIndex === undefined)\n throw new Error(\"The parameter 'startIndex' must be defined.\");\n else\n url_ += \"startIndex=\" + encodeURIComponent(\"\" + startIndex) + \"&\"; \n url_ = url_.replace(/[?&]$/, \"\");\n\n let options_ = {\n method: \"GET\",\n headers: {\n \"Accept\": \"application/json\"\n }\n };\n\n return this.transformOptions(options_).then(transformedOptions_ => {\n return this.http.fetch(url_, transformedOptions_);\n }).then((_response: Response) => {\n return this.transformResult(url_, _response, (_response: Response) => this.processGetEvents(_response));\n });\n }\n\n protected processGetEvents(response: Response): Promise {\n const status = response.status;\n let _headers: any = {}; if (response.headers && response.headers.forEach) { response.headers.forEach((v: any, k: any) => _headers[k] = v); };\n if (status === 200) {\n return response.text().then((_responseText) => {\n let result200: any = null;\n result200 = _responseText === \"\" ? null : JSON.parse(_responseText, this.jsonParseReviver);\n return result200;\n });\n } else if (status !== 200 && status !== 204) {\n return response.text().then((_responseText) => {\n return throwException(\"An unexpected server error occurred.\", status, _responseText, _headers);\n });\n }\n return Promise.resolve(null);\n }\n\n getSermons(startIndex: number | null): Promise {\n let url_ = this.baseUrl + \"/api/content/sermons/list?\";\n if (startIndex === undefined)\n throw new Error(\"The parameter 'startIndex' must be defined.\");\n else\n url_ += \"startIndex=\" + encodeURIComponent(\"\" + startIndex) + \"&\"; \n url_ = url_.replace(/[?&]$/, \"\");\n\n let options_ = {\n method: \"GET\",\n headers: {\n \"Accept\": \"application/json\"\n }\n };\n\n return this.transformOptions(options_).then(transformedOptions_ => {\n return this.http.fetch(url_, transformedOptions_);\n }).then((_response: Response) => {\n return this.transformResult(url_, _response, (_response: Response) => this.processGetSermons(_response));\n });\n }\n\n protected processGetSermons(response: Response): Promise {\n const status = response.status;\n let _headers: any = {}; if (response.headers && response.headers.forEach) { response.headers.forEach((v: any, k: any) => _headers[k] = v); };\n if (status === 200) {\n return response.text().then((_responseText) => {\n let result200: any = null;\n result200 = _responseText === \"\" ? null : JSON.parse(_responseText, this.jsonParseReviver);\n return result200;\n });\n } else if (status !== 200 && status !== 204) {\n return response.text().then((_responseText) => {\n return throwException(\"An unexpected server error occurred.\", status, _responseText, _headers);\n });\n }\n return Promise.resolve(null);\n }\n\n getBlogs(startIndex: number | null): Promise {\n let url_ = this.baseUrl + \"/api/content/blogs/list?\";\n if (startIndex === undefined)\n throw new Error(\"The parameter 'startIndex' must be defined.\");\n else\n url_ += \"startIndex=\" + encodeURIComponent(\"\" + startIndex) + \"&\"; \n url_ = url_.replace(/[?&]$/, \"\");\n\n let options_ = {\n method: \"GET\",\n headers: {\n \"Accept\": \"application/json\"\n }\n };\n\n return this.transformOptions(options_).then(transformedOptions_ => {\n return this.http.fetch(url_, transformedOptions_);\n }).then((_response: Response) => {\n return this.transformResult(url_, _response, (_response: Response) => this.processGetBlogs(_response));\n });\n }\n\n protected processGetBlogs(response: Response): Promise {\n const status = response.status;\n let _headers: any = {}; if (response.headers && response.headers.forEach) { response.headers.forEach((v: any, k: any) => _headers[k] = v); };\n if (status === 200) {\n return response.text().then((_responseText) => {\n let result200: any = null;\n result200 = _responseText === \"\" ? null : JSON.parse(_responseText, this.jsonParseReviver);\n return result200;\n });\n } else if (status !== 200 && status !== 204) {\n return response.text().then((_responseText) => {\n return throwException(\"An unexpected server error occurred.\", status, _responseText, _headers);\n });\n }\n return Promise.resolve(null);\n }\n\n getPage(path: string): Promise {\n let url_ = this.baseUrl + \"/api/content/{path}\";\n if (path === undefined || path === null)\n throw new Error(\"The parameter 'path' must be defined.\");\n url_ = url_.replace(\"{path}\", encodeURIComponent(\"\" + path)); \n url_ = url_.replace(/[?&]$/, \"\");\n\n let options_ = {\n method: \"GET\",\n headers: {\n \"Accept\": \"application/json\"\n }\n };\n\n return this.transformOptions(options_).then(transformedOptions_ => {\n return this.http.fetch(url_, transformedOptions_);\n }).then((_response: Response) => {\n return this.transformResult(url_, _response, (_response: Response) => this.processGetPage(_response));\n });\n }\n\n protected processGetPage(response: Response): Promise {\n const status = response.status;\n let _headers: any = {}; if (response.headers && response.headers.forEach) { response.headers.forEach((v: any, k: any) => _headers[k] = v); };\n if (status === 200) {\n return response.text().then((_responseText) => {\n let result200: any = null;\n result200 = _responseText === \"\" ? null : JSON.parse(_responseText, this.jsonParseReviver);\n return result200;\n });\n } else if (status !== 200 && status !== 204) {\n return response.text().then((_responseText) => {\n return throwException(\"An unexpected server error occurred.\", status, _responseText, _headers);\n });\n }\n return Promise.resolve(null);\n }\n}\n\nexport interface AuthenticationConfigSection {\n applicationId?: string | undefined;\n applicationSecret?: string | undefined;\n aadAudience?: string | undefined;\n aadInstance?: string | undefined;\n tenant?: string | undefined;\n authority?: string | undefined;\n policy?: string | undefined;\n scopeRead?: string | undefined;\n scopeWrite?: string | undefined;\n audiences?: string[] | undefined;\n authorizationUrl?: string | undefined;\n redirectUrl?: string | undefined;\n swaggerAppId?: string | undefined;\n sectionName?: string | undefined;\n}\n\nexport interface ContentBase {\n type?: string | undefined;\n style?: Style | undefined;\n}\n\nexport interface Event extends ContentBase {\n image?: string | undefined;\n title?: string | undefined;\n subTitle?: string | undefined;\n text?: string | undefined;\n startTime?: Date | undefined;\n endTime?: Date | undefined;\n location?: string | undefined;\n categories?: string | undefined;\n createdBy?: string | undefined;\n commentCount?: number | undefined;\n}\n\nexport interface Style {\n color?: string | undefined;\n backgroundColor?: string | undefined;\n backgroundImage?: BackgroundImage | undefined;\n backgroundRepeat?: string | undefined;\n backgroundSize?: string | undefined;\n margin?: string | undefined;\n padding?: string | undefined;\n colSpan?: number | undefined;\n textAlign?: string | undefined;\n fontSize?: number | undefined;\n imageAlign?: string | undefined;\n}\n\nexport interface BackgroundImage {\n url?: string | undefined;\n height?: string | undefined;\n}\n\nexport interface Sermon extends ContentBase {\n title?: string | undefined;\n text?: string | undefined;\n date?: Date | undefined;\n categories?: string | undefined;\n preacher?: string | undefined;\n}\n\nexport interface Blog extends ContentBase {\n image?: string | undefined;\n title?: string | undefined;\n subTitle?: string | undefined;\n text?: string[] | undefined;\n date?: Date | undefined;\n categories?: string | undefined;\n createdBy?: string | undefined;\n commentCount?: number | undefined;\n}\n\nexport interface Page {\n path?: string | undefined;\n contents?: ContentGroup[] | undefined;\n}\n\nexport interface ContentGroup {\n path?: string | undefined;\n contents?: Content[] | undefined;\n}\n\nexport interface Content {\n type?: string | undefined;\n style?: Style | undefined;\n titleStyle?: Style | undefined;\n image?: string | undefined;\n title?: string | undefined;\n subTitle?: string | undefined;\n text?: string[] | undefined;\n html?: string[] | undefined;\n date?: Date | undefined;\n categories?: string | undefined;\n createdBy?: string | undefined;\n commentCount?: number | undefined;\n startTime?: Date | undefined;\n endTime?: Date | undefined;\n location?: string | undefined;\n preacher?: string | undefined;\n icon?: Icon | undefined;\n video?: Video | undefined;\n link?: Link | undefined;\n images?: Image[] | undefined;\n items?: string[] | undefined;\n}\n\nexport interface Icon extends ContentBase {\n class?: string | undefined;\n}\n\nexport interface Video {\n id?: string | undefined;\n url?: string | undefined;\n source?: string | undefined;\n}\n\nexport interface Link extends ContentBase {\n href?: string | undefined;\n text?: string | undefined;\n}\n\nexport interface Image {\n original?: string | undefined;\n thumbnail?: string | undefined;\n}\n\nexport class SwaggerException extends Error {\n message: string;\n status: number; \n response: string; \n headers: { [key: string]: any; };\n result: any; \n\n constructor(message: string, status: number, response: string, headers: { [key: string]: any; }, result: any) {\n super();\n\n this.message = message;\n this.status = status;\n this.response = response;\n this.headers = headers;\n this.result = result;\n }\n\n protected isSwaggerException = true;\n\n static isSwaggerException(obj: any): obj is SwaggerException {\n return obj.isSwaggerException === true;\n }\n}\n\nfunction throwException(message: string, status: number, response: string, headers: { [key: string]: any; }, result?: any): any {\n if (result !== null && result !== undefined)\n throw result;\n else\n throw new SwaggerException(message, status, response, headers, null);\n}","import { Action, Reducer } from 'redux';\r\nimport { AppThunkAction } from '.';\r\nimport { Event, ContentClient } from '../api/gen/index.eotc';\r\n\r\n// -----------------\r\n// STATE - This defines the type of data maintained in the Redux store.\r\n\r\nexport interface EventsState {\r\n isLoading: boolean;\r\n startIndex?: number;\r\n events: Event[] | undefined;\r\n}\r\n\r\n// -----------------\r\n// ACTIONS - These are serializable (hence replayable) descriptions of state transitions.\r\n// They do not themselves have any side-effects; they just describe something that is going to happen.\r\n\r\ninterface RequestEventsAction {\r\n type: 'REQUEST_EVENTS';\r\n startIndex: number;\r\n}\r\n\r\ninterface ReceiveEventsAction {\r\n type: 'RECEIVE_EVENTS';\r\n startIndex: number;\r\n events: Event[];\r\n}\r\n\r\n// Declare a 'discriminated union' type. This guarantees that all references to 'type' properties contain one of the\r\n// declared type strings (and not any other arbitrary string).\r\ntype KnownAction = RequestEventsAction | ReceiveEventsAction;\r\n\r\n// ----------------\r\n// ACTION CREATORS - These are functions exposed to UI components that will trigger a state transition.\r\n// They don't directly mutate state, but they can have external side-effects (such as loading data).\r\n\r\nexport const actionCreators = {\r\n requestEvents: (startIndex: number): AppThunkAction => (dispatch, getState) => {\r\n // Only load data if it's something we don't already have (and are not already loading)\r\n const appState = getState();\r\n if (appState && appState.events && startIndex !== appState.events.startIndex) {\r\n new ContentClient().getEvents(startIndex)\r\n .then(data => {\r\n dispatch({ type: 'RECEIVE_EVENTS', startIndex: startIndex, events: data });\r\n });\r\n\r\n dispatch({ type: 'REQUEST_EVENTS', startIndex: startIndex });\r\n }\r\n }\r\n};\r\n\r\n// ----------------\r\n// REDUCER - For a given state and action, returns the new state. To support time travel, this must not mutate the old state.\r\n\r\nconst unloadedState: EventsState = { events: undefined, isLoading: false };\r\n\r\nexport const reducer: Reducer = (state: EventsState | undefined, incomingAction: Action): EventsState => {\r\n if (state === undefined) {\r\n return unloadedState;\r\n }\r\n\r\n const action = incomingAction as KnownAction;\r\n switch (action.type) {\r\n case 'REQUEST_EVENTS':\r\n return {\r\n startIndex: action.startIndex,\r\n events: state.events,\r\n isLoading: true\r\n };\r\n case 'RECEIVE_EVENTS':\r\n // Only accept the incoming data if it matches the most recent request. This ensures we correctly\r\n // handle out-of-order responses.\r\n if (action.startIndex === state.startIndex) {\r\n return {\r\n startIndex: action.startIndex,\r\n events: action.events,\r\n isLoading: false\r\n };\r\n }\r\n break;\r\n }\r\n\r\n return state;\r\n};\r\n","import { Action, Reducer } from 'redux';\r\nimport { AppThunkAction } from '.';\r\nimport { ContentClient, Blog } from '../api/gen/index.eotc';\r\n\r\n// -----------------\r\n// STATE - This defines the type of data maintained in the Redux store.\r\n\r\nexport interface BlogsState {\r\n isLoading: boolean;\r\n startIndex?: number;\r\n blogs: Blog[] | undefined;\r\n}\r\n\r\n// -----------------\r\n// ACTIONS - These are serializable (hence replayable) descriptions of state transitions.\r\n// They do not themselves have any side-effects; they just describe something that is going to happen.\r\n\r\ninterface RequestBlogsAction {\r\n type: 'REQUEST_BLOGS';\r\n startIndex: number;\r\n}\r\n\r\ninterface ReceiveBlogsAction {\r\n type: 'RECEIVE_BLOGS';\r\n startIndex: number;\r\n blogs: Blog[] | undefined;\r\n}\r\n\r\n// Declare a 'discriminated union' type. This guarantees that all references to 'type' properties contain one of the\r\n// declared type strings (and not any other arbitrary string).\r\ntype KnownAction = RequestBlogsAction | ReceiveBlogsAction;\r\n\r\n// ----------------\r\n// ACTION CREATORS - These are functions exposed to UI components that will trigger a state transition.\r\n// They don't directly mutate state, but they can have external side-effects (such as loading data).\r\n\r\nexport const actionCreators = {\r\n requestBlogs: (startIndex: number): AppThunkAction => (dispatch, getState) => {\r\n // Only load data if it's something we don't already have (and are not already loading)\r\n const appState = getState();\r\n if (appState && appState.blogs && startIndex !== appState.blogs.startIndex) {\r\n new ContentClient().getBlogs(startIndex)\r\n .then(data => {\r\n dispatch({ type: 'RECEIVE_BLOGS', startIndex: startIndex, blogs: data });\r\n });\r\n\r\n dispatch({ type: 'REQUEST_BLOGS', startIndex: startIndex });\r\n }\r\n }\r\n};\r\n\r\n// ----------------\r\n// REDUCER - For a given state and action, returns the new state. To support time travel, this must not mutate the old state.\r\n\r\nconst unloadedState: BlogsState = { blogs: undefined, isLoading: false };\r\n\r\nexport const reducer: Reducer = (state: BlogsState | undefined, incomingAction: Action): BlogsState => {\r\n if (state === undefined) {\r\n return unloadedState;\r\n }\r\n\r\n const action = incomingAction as KnownAction;\r\n switch (action.type) {\r\n case 'REQUEST_BLOGS':\r\n return {\r\n startIndex: action.startIndex,\r\n blogs: state.blogs,\r\n isLoading: true\r\n };\r\n case 'RECEIVE_BLOGS':\r\n // Only accept the incoming data if it matches the most recent request. This ensures we correctly\r\n // handle out-of-order responses.\r\n if (action.startIndex === state.startIndex) {\r\n return {\r\n startIndex: action.startIndex,\r\n blogs: action.blogs,\r\n isLoading: false\r\n };\r\n }\r\n break;\r\n }\r\n\r\n return state;\r\n};\r\n","import { Action, Reducer } from 'redux';\r\nimport { AppThunkAction } from '.';\r\nimport { ContentClient, Page } from '../api/gen/index.eotc';\r\n\r\n// -----------------\r\n// STATE - This defines the type of data maintained in the Redux store.\r\n\r\nexport interface PagesState {\r\n isLoading: boolean;\r\n path?: string;\r\n pages: Page[] | undefined;\r\n}\r\n\r\n// -----------------\r\n// ACTIONS - These are serializable (hence replayable) descriptions of state transitions.\r\n// They do not themselves have any side-effects; they just describe something that is going to happen.\r\n\r\ninterface RequestPageAction {\r\n type: 'REQUEST_PAGE';\r\n path: string;\r\n}\r\n\r\ninterface ReceivePageAction {\r\n type: 'RECEIVE_PAGE';\r\n path: string;\r\n page?: Page | undefined;\r\n}\r\n\r\n// Declare a 'discriminated union' type. This guarantees that all references to 'type' properties contain one of the\r\n// declared type strings (and not any other arbitrary string).\r\ntype KnownAction = RequestPageAction | ReceivePageAction;\r\n\r\n// ----------------\r\n// ACTION CREATORS - These are functions exposed to UI components that will trigger a state transition.\r\n// They don't directly mutate state, but they can have external side-effects (such as loading data).\r\n\r\nexport const actionCreators = {\r\n requestPage: (path: string): AppThunkAction => (dispatch, getState) => {\r\n // Only load data if it's something we don't already have (and are not already loading)\r\n const appState = getState();\r\n if (appState && appState.page && path !== appState.page.path) {\r\n if((!appState.page.pages || !appState.page.pages.find(p => p.path === path))) {\r\n dispatch({ type: 'REQUEST_PAGE', path: path });\r\n new ContentClient().getPage(path)\r\n .then(data => {\r\n dispatch({ type: 'RECEIVE_PAGE', path: path, page: data });\r\n });\r\n }\r\n else{\r\n dispatch({ type: 'REQUEST_PAGE', path: path });\r\n dispatch({ type: 'RECEIVE_PAGE', path: path });\r\n }\r\n } \r\n }\r\n};\r\n\r\n// ----------------\r\n// REDUCER - For a given state and action, returns the new state. To support time travel, this must not mutate the old state.\r\n\r\nconst unloadedState: PagesState = { pages: undefined, isLoading: false };\r\n\r\nexport const reducer: Reducer = (state: PagesState | undefined, incomingAction: Action): PagesState => {\r\n if (state === undefined) {\r\n return unloadedState;\r\n }\r\n\r\n const action = incomingAction as KnownAction;\r\n switch (action.type) {\r\n case 'REQUEST_PAGE':\r\n return {\r\n path: action.path,\r\n pages: state.pages,\r\n isLoading: true\r\n };\r\n case 'RECEIVE_PAGE':\r\n // Only accept the incoming data if it matches the most recent request. This ensures we correctly\r\n // handle out-of-order responses.\r\n if (action.path === state.path) {\r\n const pages = state.pages;\r\n if(!pages) {\r\n return {\r\n path: action.path,\r\n pages: action.page ? [ action.page ] : [],\r\n isLoading: false\r\n }; \r\n } else {\r\n const p = pages.find(p => p.path === action.path);\r\n if(p) {\r\n p.contents = action.page ? action.page.contents : p.contents;\r\n return {\r\n path: action.path,\r\n pages: state.pages,\r\n isLoading: false\r\n };\r\n } else {\r\n action.page && pages.push(action.page);\r\n return {\r\n path: action.path,\r\n pages: state.pages,\r\n isLoading: false\r\n };\r\n }\r\n }\r\n }\r\n break;\r\n }\r\n return state;\r\n};\r\n","import { Action, Reducer } from 'redux';\r\nimport { AppThunkAction } from '.';\r\nimport { Page, ContentClient, Sermon } from '../api/gen/index.eotc';\r\n\r\n// -----------------\r\n// STATE - This defines the type of data maintained in the Redux store.\r\n\r\nexport interface SermonsState {\r\n isLoading: boolean;\r\n startIndex?: number;\r\n sermons: Sermon[] | undefined;\r\n}\r\n\r\n// -----------------\r\n// ACTIONS - These are serializable (hence replayable) descriptions of state transitions.\r\n// They do not themselves have any side-effects; they just describe something that is going to happen.\r\n\r\ninterface RequestSermonsAction {\r\n type: 'REQUEST_SERMONS';\r\n startIndex: number;\r\n}\r\n\r\ninterface ReceiveSermonsAction {\r\n type: 'RECEIVE_SERMONS';\r\n startIndex: number;\r\n sermons: Sermon[] | undefined;\r\n}\r\n\r\n// Declare a 'discriminated union' type. This guarantees that all references to 'type' properties contain one of the\r\n// declared type strings (and not any other arbitrary string).\r\ntype KnownAction = RequestSermonsAction | ReceiveSermonsAction;\r\n\r\n// ----------------\r\n// ACTION CREATORS - These are functions exposed to UI components that will trigger a state transition.\r\n// They don't directly mutate state, but they can have external side-effects (such as loading data).\r\n\r\nexport const actionCreators = {\r\n requestSermons: (startIndex: number): AppThunkAction => (dispatch, getState) => {\r\n // Only load data if it's something we don't already have (and are not already loading)\r\n const appState = getState();\r\n if (appState && appState.sermons && startIndex !== appState.sermons.startIndex) {\r\n new ContentClient().getSermons(startIndex)\r\n .then(data => {\r\n dispatch({ type: 'RECEIVE_SERMONS', startIndex: startIndex, sermons: data });\r\n });\r\n\r\n dispatch({ type: 'REQUEST_SERMONS', startIndex: startIndex });\r\n }\r\n }\r\n};\r\n\r\n// ----------------\r\n// REDUCER - For a given state and action, returns the new state. To support time travel, this must not mutate the old state.\r\n\r\nconst unloadedState: SermonsState = { sermons: undefined, isLoading: false };\r\n\r\nexport const reducer: Reducer = (state: SermonsState | undefined, incomingAction: Action): SermonsState => {\r\n if (state === undefined) {\r\n return unloadedState;\r\n }\r\n\r\n const action = incomingAction as KnownAction;\r\n switch (action.type) {\r\n case 'REQUEST_SERMONS':\r\n return {\r\n startIndex: action.startIndex,\r\n sermons: state.sermons,\r\n isLoading: true\r\n };\r\n case 'RECEIVE_SERMONS':\r\n // Only accept the incoming data if it matches the most recent request. This ensures we correctly\r\n // handle out-of-order responses.\r\n if (action.startIndex === state.startIndex) {\r\n return {\r\n startIndex: action.startIndex,\r\n sermons: action.sermons,\r\n isLoading: false\r\n };\r\n }\r\n break;\r\n }\r\n\r\n return state;\r\n};\r\n","import { Action, Reducer } from 'redux';\r\nimport { AppThunkAction } from '.';\r\nimport { AuthenticationConfigSection, ConfigClient } from '../api/gen/index.eotc';\r\n\r\n// -----------------\r\n// STATE - This defines the type of data maintained in the Redux store.\r\n\r\nexport interface ConfigState {\r\n authConfig: AuthenticationConfigSection | undefined;\r\n}\r\n\r\n// -----------------\r\n// ACTIONS - These are serializable (hence replayable) descriptions of state transitions.\r\n// They do not themselves have any side-effects; they just describe something that is going to happen.\r\n\r\ninterface RequestConfigAction {\r\n type: 'REQUEST_CONFIG';\r\n}\r\n\r\ninterface ReceiveConfigAction {\r\n type: 'RECEIVE_CONFIG';\r\n authConfig: AuthenticationConfigSection | undefined;\r\n}\r\n\r\n// Declare a 'discriminated union' type. This guarantees that all references to 'type' properties contain one of the\r\n// declared type strings (and not any other arbitrary string).\r\ntype KnownAction = RequestConfigAction | ReceiveConfigAction;\r\n\r\n// ----------------\r\n// ACTION CREATORS - These are functions exposed to UI components that will trigger a state transition.\r\n// They don't directly mutate state, but they can have external side-effects (such as loading data).\r\n\r\nexport const actionCreators = {\r\n requestConfig: (): AppThunkAction => (dispatch, getState) => {\r\n // Only load data if it's something we don't already have (and are not already loading)\r\n const appState = getState();\r\n if (appState && appState.authConfig) {\r\n new ConfigClient().getAuthConfig()\r\n .then(data => {\r\n dispatch({ type: 'RECEIVE_CONFIG', authConfig: data });\r\n });\r\n\r\n dispatch({ type: 'REQUEST_CONFIG' });\r\n }\r\n }\r\n};\r\n\r\n// ----------------\r\n// REDUCER - For a given state and action, returns the new state. To support time travel, this must not mutate the old state.\r\n\r\nconst unloadedState: ConfigState = { authConfig: undefined };\r\n\r\nexport const reducer: Reducer = (state: ConfigState | undefined, incomingAction: Action): ConfigState => {\r\n if (state === undefined) {\r\n return unloadedState;\r\n }\r\n\r\n const action = incomingAction as KnownAction;\r\n switch (action.type) {\r\n case 'REQUEST_CONFIG':\r\n return {\r\n authConfig: state.authConfig\r\n };\r\n case 'RECEIVE_CONFIG':\r\n // Only accept the incoming data if it matches the most recent request. This ensures we correctly\r\n // handle out-of-order responses.\r\n return {\r\n authConfig: action.authConfig\r\n };\r\n }\r\n\r\n return state;\r\n};\r\n","import { Action, Reducer } from 'redux';\r\nimport { AppThunkAction } from '.';\r\nimport { ContentClient, ContentGroup } from '../api/gen/index.eotc';\r\n\r\n// -----------------\r\n// STATE - This defines the type of data maintained in the Redux store.\r\n\r\nexport interface FooterState {\r\n isLoading: boolean;\r\n footer: ContentGroup[] | undefined;\r\n}\r\n\r\n// -----------------\r\n// ACTIONS - These are serializable (hence replayable) descriptions of state transitions.\r\n// They do not themselves have any side-effects; they just describe something that is going to happen.\r\n\r\ninterface RequestFooterAction {\r\n type: 'REQUEST_FOOTER';\r\n}\r\n\r\ninterface ReceiveFooterAction {\r\n type: 'RECEIVE_FOOTER';\r\n footer: ContentGroup[] | undefined;\r\n}\r\n\r\n// Declare a 'discriminated union' type. This guarantees that all references to 'type' properties contain one of the\r\n// declared type strings (and not any other arbitrary string).\r\ntype KnownAction = RequestFooterAction | ReceiveFooterAction;\r\n\r\n// ----------------\r\n// ACTION CREATORS - These are functions exposed to UI components that will trigger a state transition.\r\n// They don't directly mutate state, but they can have external side-effects (such as loading data).\r\n\r\nexport const actionCreators = {\r\n requestFooter: (): AppThunkAction => (dispatch, getState) => {\r\n // Only load data if it's something we don't already have (and are not already loading)\r\n const appState = getState();\r\n if (appState && appState.footer) {\r\n new ContentClient().getPage(\"footer\")\r\n .then(data => {\r\n dispatch({ type: 'RECEIVE_FOOTER', footer: data.contents });\r\n });\r\n\r\n dispatch({ type: 'REQUEST_FOOTER' });\r\n }\r\n }\r\n};\r\n\r\n// ----------------\r\n// REDUCER - For a given state and action, returns the new state. To support time travel, this must not mutate the old state.\r\n\r\nconst unloadedState: FooterState = { footer: undefined, isLoading: false };\r\n\r\nexport const reducer: Reducer = (state: FooterState | undefined, incomingAction: Action): FooterState => {\r\n if (state === undefined) {\r\n return unloadedState;\r\n }\r\n\r\n const action = incomingAction as KnownAction;\r\n switch (action.type) {\r\n case 'REQUEST_FOOTER':\r\n return {\r\n footer: state.footer,\r\n isLoading: true\r\n };\r\n case 'RECEIVE_FOOTER':\r\n // Only accept the incoming data if it matches the most recent request. This ensures we correctly\r\n // handle out-of-order responses.\r\n return {\r\n footer: action.footer,\r\n isLoading: false\r\n };\r\n break;\r\n }\r\n\r\n return state;\r\n};\r\n","import * as Events from './Events';\r\nimport * as Blogs from './Blogs';\r\nimport * as Page from './Page';\r\nimport * as Sermons from './Sermons';\r\nimport * as Config from './Config'\r\nimport * as Footer from './Footer'\r\n\r\n// The top-level state object\r\nexport interface ApplicationState {\r\n events: Events.EventsState | undefined;\r\n blogs: Blogs.BlogsState | undefined;\r\n sermons: Sermons.SermonsState | undefined;\r\n page: Page.PagesState | undefined;\r\n authConfig: Config.ConfigState | undefined;\r\n footer: Footer.FooterState | undefined;\r\n}\r\n\r\n// Whenever an action is dispatched, Redux will update each top-level application state property using\r\n// the reducer with the matching name. It's important that the names match exactly, and that the reducer\r\n// acts on the corresponding ApplicationState property type.\r\nexport const reducers = {\r\n events: Events.reducer,\r\n blogs: Blogs.reducer,\r\n sermons: Sermons.reducer,\r\n page: Page.reducer,\r\n authConfig: Config.reducer,\r\n footer: Footer.reducer,\r\n};\r\n\r\n// This type can be used as a hint on action creators so that its 'dispatch' and 'getState' params are\r\n// correctly typed to match your store.\r\nexport interface AppThunkAction {\r\n (dispatch: (action: TAction) => void, getState: () => ApplicationState): void;\r\n}\r\n","import * as React from 'react';\r\nimport { connect } from 'react-redux';\r\nimport * as ConfigStore from '../store/Config';\r\nimport { Collapse, Container, Navbar, NavbarBrand, NavbarToggler, NavItem, NavLink } from 'reactstrap';\r\nimport { Link } from 'react-router-dom';\r\nimport './NavMenu.css';\r\nimport { Configuration, UserAgentApplication, AuthenticationParameters } from 'msal';\r\nimport { ApplicationState } from '../store';\r\n\r\ntype ConfigProps =\r\n ConfigStore.ConfigState // ... state we've requested from the Redux store\r\n & typeof ConfigStore.actionCreators; // ... plus incoming routing parameters\r\n\r\ntype LoginState = {\r\n isOpen?: boolean;\r\n name?: string | undefined;\r\n isLoggedIn: boolean;\r\n}\r\n\r\ndeclare global {\r\n interface Window { \r\n accessToken: any; \r\n access_token: any;\r\n }\r\n}\r\n\r\nclass NavMenu extends React.Component {\r\n public state: LoginState = {\r\n isOpen: false,\r\n isLoggedIn: false\r\n };\r\n\r\n // configuration to initialize msal\r\n private msalConfig: Configuration = {\r\n auth: {\r\n clientId: \"937a8b9c-8df3-4f4c-8709-876371c9ec73\", //This is your client ID\r\n authority: \"https://dskmeotc.b2clogin.com/dskmeotc.onmicrosoft.com/B2C_1_signupsignin\", //This is your tenant info\r\n validateAuthority: false,\r\n redirectUri: 'https://localhost:44363/',\r\n \r\n },\r\n cache: {\r\n cacheLocation: \"sessionStorage\",\r\n storeAuthStateInCookie: true\r\n }\r\n };\r\n \r\n private appConfig = {\r\n b2cScopes: [\"https://dskmeotc.onmicrosoft.com/api/dskm.read\"],\r\n webApi: \"https://dskmeotc.azurewebsites.net/api\"\r\n };\r\n \r\n // instantiate MSAL\r\n private msal = new UserAgentApplication(this.msalConfig);\r\n\r\n // request to signin - returns an idToken\r\n private loginRequest = {\r\n scopes: this.appConfig.b2cScopes\r\n };\r\n\r\n // request to acquire a token for resource access\r\n private tokenRequest = {\r\n scopes: this.appConfig.b2cScopes\r\n };\r\n\r\n constructor(props: any){\r\n super(props);\r\n this.msal.handleRedirectCallback((error, response) => {\r\n this.getToken(this.tokenRequest).then(this.updateUI);\r\n });\r\n const user: any = this.msal.getAccount();\r\n if(user) {\r\n this.state = { isLoggedIn: true, name: user.name};\r\n window.accessToken = user.idToken;\r\n }\r\n }\r\n\r\n public componentDidMount() {\r\n this.props.requestConfig();\r\n }\r\n \r\n // updates the UI post login/token acqusition\r\n private updateUI = () => {\r\n const user = this.msal.getAccount();\r\n this.setState( { isLoggedIn: true, name: user.name});\r\n window.accessToken = user.idToken;\r\n }\r\n \r\n //acquire a token silently\r\n private getToken = (tokenRequest: AuthenticationParameters): Promise => {\r\n return this.msal.acquireTokenSilent(tokenRequest).catch((error) => {\r\n console.log(\"aquire token popup\");\r\n // fallback to interaction when silent call fails\r\n return this.msal.acquireTokenPopup(tokenRequest).then( tokenResponse=> {\r\n console.log(tokenResponse);\r\n }).catch(function(error){\r\n console.log(\"Failed token acquisition\", error);\r\n });\r\n });\r\n }\r\n \r\n // signin and acquire a token silently with POPUP flow. Fall back in case of failure with silent acquisition to popup\r\n private signIn = () => {\r\n \r\n const user = this.msal.getAccount();\r\n if(!user) {\r\n this.msal.loginRedirect(this.loginRequest);\r\n /*this.myMSALObj.loginPopup(this.loginRequest)\r\n .then((loginResponse) => {\r\n this.getToken(this.tokenRequest).then(this.updateUI);\r\n }).catch(function (error) {\r\n console.log(error);\r\n });*/\r\n }\r\n else {\r\n this.setState( { isLoggedIn: true, name: user.name});\r\n this.getToken(this.tokenRequest).then(this.updateUI);\r\n }\r\n }\r\n\r\n // signout the user\r\n private logout = () => {\r\n // Removes all sessions, need to call AAD endpoint to do full logout\r\n this.msal.logout();\r\n }\r\n\r\n public render() {\r\n const { isLoggedIn, name } = this.state;\r\n return (\r\n
\r\n \r\n \r\n \r\n DSKM\r\n \r\n \r\n
    \r\n \r\n Home\r\n \r\n \r\n Events\r\n \r\n {/*\r\n Blogs\r\n */}\r\n \r\n Sermons\r\n \r\n \r\n Mezmur\r\n \r\n \r\n Gallery\r\n \r\n \r\n About us\r\n \r\n
\r\n
\r\n
\r\n {/* isLoggedIn ? \r\n
\r\n Hello, {name} Signout\r\n
: \r\n
\r\n Sign in { or Sign up }\r\n
\r\n */}\r\n
\r\n
\r\n
\r\n
\r\n );\r\n }\r\n\r\n private toggle = () => {\r\n this.setState({\r\n isOpen: !this.state.isOpen\r\n });\r\n }\r\n}\r\n\r\nexport default connect(\r\n (state: ApplicationState) => state.authConfig, // Selects which state properties are merged into the component's props\r\n ConfigStore.actionCreators // Selects which action creators are merged into the component's props\r\n )(NavMenu as any);","import { Theme } from \"./Theme\";\r\nimport { ContentProps } from \"./components/contents/GenericContent\";\r\nimport { ContentGroupProps } from \"./components/Page\";\r\n\r\nexport const styles = (theme: Theme) => ({\r\n wrapper: {\r\n padding: (props: ContentProps) => (props.style && props.style.padding) || theme.padding,\r\n margin: (props: ContentProps) => '0 auto',\r\n backgroundColor: (props: ContentProps) => {\r\n if(props.style && props.style.backgroundImage) {\r\n return 'transparent';\r\n }\r\n return (props.style && props.style.backgroundColor) || ( props.type === 'banner' ? theme.banner.bg : theme.text.bg)\r\n },\r\n color: (props: ContentProps) => (props.style && props.style.color) || (props.type === 'banner' ? theme.banner.fg: theme.text.color),\r\n textAlign: (props: ContentProps) => (props.style && props.style.textAlign) || \"center\",\r\n fontSize: (props: ContentProps) => (props.style && props.style.fontSize) || 16\r\n },\r\n title: {\r\n fontSize: 30,\r\n fontWeifht: 900,\r\n },\r\n subTitle: {\r\n fontSize: 15,\r\n fontWeifht: 100,\r\n padding: \"10px\",\r\n marginTop: \"-10px\",\r\n },\r\n linkContainer: {\r\n padding: (props: ContentProps) => (props.link && props.link.style && props.link.style.padding) || \"15px\",\r\n margin: (props: ContentProps) => (props.link && props.link.style && props.link.style.margin) || \"20px 0 20px 0\",\r\n marginLeft: -10\r\n },\r\n link: {\r\n padding: (props: ContentProps) => (props.link && props.link.style && props.link.style.padding) || theme.link.padding,\r\n backgroundColor: (props: ContentProps) => (props.link && props.link.style && props.link.style.backgroundColor) || theme.link.bg,\r\n color: (props: ContentProps) => (props.link && props.link.style && props.link.style.color) || theme.link.fg,\r\n border: 'solid 1px',\r\n \"&:hover\": {\r\n textDecoration: \"none\",\r\n color: (props: ContentProps) => (props.link && props.link.style && props.link.style.backgroundColor) || theme.link.bg,\r\n backgroundColor: (props: ContentProps) => (props.link && props.link.style && props.link.style.color) || theme.link.fg,\r\n },\r\n borderRadius: 3,\r\n withTemplates: ``\r\n },\r\n img: {\r\n maxWidth: \"100%\",\r\n },\r\n row: {\r\n padding: 20\r\n },\r\n icon: {\r\n color: theme.color,\r\n fontSize: 36,\r\n },\r\n container: {\r\n padding: 0,\r\n }\r\n } as unknown as any);\r\n\r\n export const ContentGroupStyles = (theme: Theme) => ({\r\n ...styles(theme),\r\n wrapper: {\r\n padding: (props: ContentGroupProps) => (props.style && props.style.padding) || 20,\r\n margin: (props: ContentGroupProps) => 'auto',\r\n backgroundImage: (props: ContentGroupProps) => {\r\n const banner = props.contents && props.contents.find(c => c.type === 'banner');\r\n if(banner && banner.style && banner.style.backgroundImage) {\r\n return banner.style.backgroundImage.url;\r\n }\r\n },\r\n backgroundColor: (props: ContentGroupProps) => {\r\n const banner = props.contents && props.contents.find(c => c.type === 'banner');\r\n if(banner && banner.style && banner.style.backgroundImage) {\r\n return 'transparent';\r\n }\r\n return banner ? (banner && banner.style && banner.style.backgroundColor || theme.banner.bg) : theme.text.bg;\r\n },\r\n color: (props: ContentGroupProps) => (props.contents && props.contents.find(c => c.type === 'banner') ? theme.banner.fg: theme.text.color),\r\n textAlign: (props: ContentGroupProps) => (props.style && props.style.textAlign) || \"center\",\r\n minHeight: (props: ContentGroupProps) => {\r\n const banner = props.contents && props.contents.find(c => c.type === 'banner');\r\n if(banner && banner.style && banner.style.backgroundImage) {\r\n return banner.style.backgroundImage.height;\r\n }\r\n }, \r\n backgroundRepeat: 'no-repeat',\r\n backgroundSize: '100vw',\r\n },\r\n row: {\r\n padding: \"20px 0px\",\r\n }\r\n });\r\n\r\n\r\n","import * as React from 'react';\r\nimport injectSheet from 'react-jss';\r\nimport { styles } from '../../../Styles';\r\nimport { Theme } from '../../../Theme';\r\nimport { Content } from '../../../api/gen/index.eotc';\r\n\r\nimport \"./list.css\";\r\n\r\n const style = (theme: Theme) => ({\r\n ...styles(theme),\r\n padding: {\r\n padding: 10,\r\n },\r\n video: {\r\n padding: 10,\r\n float: 'left',\r\n }\r\n });\r\n\r\n export type ContentProps = Content & {\r\n classes: any,\r\n };\r\n\r\n const gc = (props: ContentProps) => {\r\n const { items, style, classes } = props;\r\n return (\r\n \r\n
\r\n { items &&
    \r\n {\r\n items.map(item => {\r\n const index = item.indexOf('>>');\r\n let subItems = null;\r\n if(index > 0 ) {\r\n subItems = item.substring(index + 2).split(',');\r\n item = item.substring(0, index );\r\n } \r\n\r\n return
  • \r\n { }\r\n { subItems &&
      { subItems.map(si =>
    • { }
    • )}
    }\r\n
  • \r\n })\r\n }\r\n
\r\n }\r\n
\r\n
\r\n );\r\n };\r\n\r\nconst StyledComponent = injectSheet(style)(gc);\r\n\r\nexport class List extends React.Component {\r\n public render() {\r\n return (\r\n \r\n );\r\n }\r\n};","import * as React from 'react';\r\nimport injectSheet from 'react-jss';\r\nimport { styles } from '../../Styles';\r\nimport { Theme } from '../../Theme';\r\nimport { Content } from '../../api/gen/index.eotc';\r\n\r\nimport \"./GenericContent.css\"\r\nimport { List } from './list/List';\r\n\r\n const style = (theme: Theme) => ({\r\n ...styles(theme),\r\n padding: {\r\n padding: 10,\r\n }\r\n });\r\n\r\n export type ContentProps = Content & {\r\n classes: any,\r\n };\r\n\r\n const gc = (props: ContentProps) => {\r\n const { title, subTitle, text, html, items, image, video, link, style, titleStyle, type, icon, classes } = props;\r\n return (\r\n \r\n
\r\n { icon && icon.style && icon.style.textAlign === 'center' && }\r\n { title &&

\r\n { icon && icon.style && icon.style.textAlign === 'left' && }\r\n \r\n

\r\n }\r\n { subTitle &&
{subTitle}
}\r\n { \r\n video ? ( video.source === \"Facebook\" ?\r\n\t\t\t\t\t\t\t : \r\n\t\t\t\t\t\t\t) :\r\n image &&
\r\n }\r\n\t\t\t\t\t{ text && text.map(t =>

) }\r\n { html && html.map(h =>

) }\r\n {\r\n items && \r\n }\r\n { link &&\r\n

\r\n } \r\n
\r\n
\r\n );\r\n };\r\n\r\nconst StyledComponent = injectSheet(style)(gc);\r\n\r\nexport class GenericContent extends React.Component {\r\n public render() {\r\n return (\r\n \r\n );\r\n }\r\n};","import * as React from 'react';\r\nimport injectSheet from 'react-jss';\r\nimport { Container } from 'reactstrap';\r\nimport { styles } from '../../../Styles';\r\nimport { Theme } from '../../../Theme';\r\nimport { Content } from '../../../api/gen/index.eotc';\r\n\r\nimport './events.css';\r\nimport './events_responsive.css';\r\n\r\nimport moment from 'moment';\r\n\r\n const style = (theme: Theme) => ({\r\n ...styles(theme),\r\n });\r\n\r\n type EventProps = Content & {\r\n classes: any,\r\n };\r\n\r\n const e = (props: EventProps) => {\r\n const { title, subTitle, text, link, image, style, video, location, classes} = props;\r\n let { startTime, endTime } = props;\r\n let days, hours, minutes, seconds;\r\n const start_date = Date.parse((startTime || new Date()).toString());\r\n const setTime = () =>\r\n {\r\n // find the amount of \"seconds\" between now and target\r\n var current_date = new Date().getTime();\r\n var seconds_left = (start_date - current_date) / 1000;\r\n \r\n // do some time calculations\r\n days = Math.ceil(seconds_left / 86400);\r\n seconds_left = seconds_left % 86400;\r\n \r\n hours = Math.ceil(seconds_left / 3600);\r\n seconds_left = seconds_left % 3600;\r\n \r\n minutes = Math.ceil(seconds_left / 60);\r\n seconds = Math.ceil(seconds_left % 60);\r\n };\r\n \r\n setTime();\r\n setInterval(setTime, 1000);\r\n\r\n const media = () =>
\r\n { \r\n video ? ( video.source === \"Facebook\" ?\r\n : \r\n ) :\r\n image &&
\r\n }\r\n
;\r\n\r\n const info = (days: any, hours: any, minutes: any, seconds: any) => \r\n
\r\n
\r\n
\r\n
{moment(startTime).date()}
\r\n
{moment(startTime).format('MMM')}
\r\n
\r\n
\r\n
\r\n \r\n
    \r\n
  • \r\n
    \"\"
    \r\n { moment(startTime).format('LT') } - {moment(endTime).format('LT') }\r\n
  • \r\n
  • \r\n
    \"\"
    \r\n { location }\r\n
  • \r\n
\r\n
\r\n
\r\n
\r\n { text && text.map(t =>

{ t }

) }\r\n
\r\n { days && days > 0 && hours && hours > 0 && minutes && minutes > 0 && seconds && seconds > 0 &&
\r\n
    \r\n
  • {days}
    day
  • \r\n
  • {hours}
    hrs
  • \r\n
  • {minutes}
    min
  • \r\n
  • {seconds}
    sec
  • \r\n
\r\n
\r\n }\r\n
;\r\n\r\n return (\r\n \r\n
\r\n
\r\n
\r\n { \r\n style && style.imageAlign === 'right' ? \r\n
\r\n { info (days, hours, minutes, seconds) }\r\n
\r\n
\r\n { media() }\r\n
\r\n
: \r\n
\r\n { media() }\r\n
\r\n
\r\n { info (days, hours, minutes, seconds)}\r\n
\r\n
\r\n }\r\n
\r\n
\r\n
\r\n
\r\n );\r\n };\r\n\r\nconst StyledComponent = injectSheet(style)(e);\r\n\r\nexport class Event extends React.Component {\r\n public render() {\r\n return (\r\n \r\n );\r\n }\r\n};","import * as React from 'react';\r\nimport injectSheet from 'react-jss';\r\nimport { Container } from 'reactstrap';\r\nimport { styles } from '../../../Styles';\r\nimport { Theme } from '../../../Theme';\r\nimport { Content } from '../../../api/gen/index.eotc';\r\n\r\nimport './blog.css';\r\nimport './blog_responsive.css';\r\n\r\nimport moment from 'moment';\r\n\r\n const style = (theme: Theme) => ({\r\n ...styles(theme),\r\n });\r\n\r\n type BlogProps = Content & {\r\n classes: any,\r\n };\r\n\r\n const blog = (props: BlogProps) => {\r\n const { title, subTitle, text, link, style, image,video, createdBy, commentCount, classes} = props;\r\n let { startTime } = props;\r\n \r\n return (\r\n \r\n
\r\n
\r\n
\r\n { \r\n video ? ( video.source === \"Facebook\" ?\r\n : \r\n ) :\r\n image &&
\r\n }\r\n
\r\n
\r\n
\r\n {title}\r\n
\r\n \r\n
\r\n {\r\n text && text.map(t =>

{ t }

)\r\n }\r\n
\r\n
\r\n
\r\n
\r\n
\r\n );\r\n };\r\n\r\nconst StyledComponent = injectSheet(style)(blog);\r\n\r\nexport class Blog extends React.Component {\r\n public render() {\r\n return (\r\n \r\n );\r\n }\r\n};","import * as React from 'react';\r\nimport injectSheet from 'react-jss';\r\nimport { Container } from 'reactstrap';\r\nimport { styles } from '../../../Styles';\r\nimport { Theme } from '../../../Theme';\r\nimport { Content } from '../../../api/gen/index.eotc';\r\n\r\nimport './sermon.css';\r\nimport './sermon_responsive.css';\r\n\r\nimport moment from 'moment';\r\n\r\n const style = (theme: Theme) => ({\r\n ...styles(theme),\r\n });\r\n\r\n type SermonProps = Content & {\r\n classes: any,\r\n };\r\n\r\n const blog = (props: SermonProps) => {\r\n const { title, subTitle, text, link, style, image, video, createdBy, preacher, categories, classes} = props;\r\n let { date } = props;\r\n \r\n return (\r\n \r\n
\r\n\t\t\t\t\t
\r\n\t\t\t\t\t\t
\r\n\t\t\t\t\t\t\t
{moment(date).date()}
\r\n\t\t\t\t\t\t\t
{moment(date).format('MMM')}
\r\n
\r\n\t\t\t\t\t\t{ video ? ( video.source === \"Facebook\" ?\r\n\t\t\t\t\t\t\t : \r\n\t\t\t\t\t\t\t) :\r\n\t\t\t\t\t\t\t\"\"\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\t{ (title || preacher || categories) &&\t\t\t\r\n\t\t\t\t\t\t
\r\n\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\t
\r\n\t\t\t\t\t\t\t\t{ preacher &&
\r\n\t\t\t\t\t\t\t\t\t{/*
Pastor:
*/}\r\n\t\t\t\t\t\t\t\t\t
    \r\n\t\t\t\t\t\t\t\t\t\t
  • {preacher}
  • \r\n\t\t\t\t\t\t\t\t\t
\r\n\t\t\t\t\t\t\t\t
\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t{ categories &&
\r\n\t\t\t\t\t\t\t\t\t
Categories:
\r\n\t\t\t\t\t\t\t\t\t
    \r\n\t\t\t\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t\t\tcategories.split(',').map((category: string, index: number) =>
  • {category},
  • )\r\n\t\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t\t
\r\n\t\t\t\t\t\t\t\t
\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t
\r\n\t\t\t\t\t\t
\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t
\r\n\t\t\t\t
\r\n
\r\n );\r\n };\r\n\r\nconst StyledComponent = injectSheet(style)(blog);\r\n\r\nexport class Sermon extends React.Component {\r\n public render() {\r\n return (\r\n \r\n );\r\n }\r\n};","import * as React from 'react';\r\nimport injectSheet from 'react-jss';\r\nimport { styles } from '../../../Styles';\r\nimport { Theme } from '../../../Theme';\r\nimport { Content } from '../../../api/gen/index.eotc';\r\nimport ReactImageGallery, { ReactImageGalleryItem } from 'react-image-gallery';\r\nimport \"../../../../node_modules/react-image-gallery/styles/css/image-gallery.css\";\r\n\r\n const style = (theme: Theme) => ({\r\n ...styles(theme),\r\n padding: {\r\n padding: 10,\r\n },\r\n video: {\r\n padding: 10,\r\n float: 'left',\r\n }\r\n });\r\n\r\n export type ContentProps = Content & {\r\n classes: any,\r\n };\r\n\r\n const gc = (props: ContentProps) => {\r\n const { images, classes } = props;\r\n return (\r\n \r\n
\r\n \r\n
\r\n
\r\n );\r\n };\r\n\r\nconst StyledComponent = injectSheet(style)(gc);\r\n\r\nexport class Gallery extends React.Component {\r\n public render() {\r\n return (\r\n \r\n );\r\n }\r\n};","import * as React from 'react';\r\nimport injectSheet from 'react-jss';\r\nimport { connect } from 'react-redux';\r\nimport { RouteComponentProps } from 'react-router';\r\nimport { ApplicationState } from '../../../store';\r\nimport * as FooterStore from '../../../store/Footer';\r\nimport { Content, ContentGroup } from '../../../api/gen/index.eotc';\r\nimport { GenericContent } from './../../contents/GenericContent';\r\nimport { Event } from './../../contents/event/Event';\r\nimport { isNullOrUndefined } from 'util';\r\nimport { Theme } from '../../../Theme';\r\nimport { ContentGroupStyles } from '../../../Styles';\r\nimport { Container } from 'reactstrap';\r\nimport { Blog } from './../../contents/blog/Blog';\r\nimport { Sermon } from './../../contents/sermon/Sermon';\r\nimport { Gallery } from './../../contents/gallery/Gallery';\r\nimport { List } from './../../contents/list/List';\r\n\r\nimport './footer.css';\r\n\r\n// At runtime, Redux will merge together...\r\ntype FooterProps =\r\n FooterStore.FooterState // ... state we've requested from the Redux store\r\n & typeof FooterStore.actionCreators // ... plus action creators we've requested\r\n\r\nconst style = (theme: Theme) => ({\r\n ...ContentGroupStyles(theme),\r\n});\r\n\r\nexport type ContentGroupProps = ContentGroup & {\r\n style?: any;\r\n classes: any,\r\n};\r\n\r\nconst gc = (props: ContentGroupProps) => {\r\n const { classes, contents } = props;\r\n return (\r\n \r\n
\r\n \r\n
\r\n {\r\n contents && contents.map((content: Content, index: number) => {\r\n if(isNullOrUndefined(content.type) || content.type === 'banner') {\r\n return (\r\n \r\n );\r\n }\r\n else if(content.type === 'event') {\r\n return (\r\n \r\n );\r\n }\r\n else if(content.type === 'blog') {\r\n return (\r\n \r\n );\r\n }\r\n else if(content.type === 'sermon') {\r\n return (\r\n \r\n );\r\n }\r\n else if(content.type === 'gallery') {\r\n return (\r\n \r\n );\r\n }\r\n else if(content.type === 'list') {\r\n return (\r\n \r\n );\r\n }\r\n })\r\n }\r\n
\r\n
\r\n
\r\n
\r\n );\r\n};\r\n\r\nconst StyledComponent = injectSheet(style)(gc);\r\n\r\nclass FooterComponent extends React.PureComponent {\r\n // This method is called when the component is first added to the document\r\n public componentDidMount() {\r\n this.ensureDataFetched();\r\n }\r\n\r\n public render() {\r\n return (\r\n \r\n {this.renderPage()}\r\n \r\n );\r\n }\r\n\r\n private ensureDataFetched() {\r\n this.props.requestFooter();\r\n }\r\n\r\n private renderPage() {\r\n const { footer } = this.props;\r\n \r\n return (\r\n \r\n {\r\n footer && footer.map((cg: ContentGroup, index: number) => )\r\n }\r\n \r\n );\r\n }\r\n}\r\n\r\nexport default connect(\r\n (state: ApplicationState) => state.footer, // Selects which state properties are merged into the component's props\r\n FooterStore.actionCreators // Selects which action creators are merged into the component's props\r\n)(FooterComponent as any);\r\n","import * as React from 'react';\r\nimport NavMenu from './NavMenu';\r\nimport Footer from './../components/contents/footer/Footer';\r\n\r\nexport default (props: { children?: React.ReactNode }) => (\r\n \r\n \r\n {props.children}\r\n