bloom-player 2.19.6 → 2.19.7-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -8044,7 +8044,7 @@ Add a <Suspense fallback=...> component higher in the tree to provide a loading
8044
8044
  display:none !important;
8045
8045
  }
8046
8046
  `.replace(`
8047
- `,"").replace("\r","")}const uc=[];function OB(){return uc.length>0}function KB(t){const e=uc.pop();if(e)return{bookUrl:t===e.bookId?void 0:hh(e.bookId),pageId:e.pageId}}function $B(t,e,n){const a=t.target.closest("[href], [data-href]");if(!a)return;t.preventDefault(),t.stopPropagation();const i=(a.getAttribute("href")||a.getAttribute("data-href"))??void 0;if(!i)return;if(i.startsWith("http://")||i.startsWith("https://")){window.open(i,"_blank","noreferrer");return}let r,s;if(i==="back"){const c=uc.pop();return c?{bookUrl:e===c.bookId?void 0:hh(c.bookId),pageId:c.pageId}:void 0}else if(i.startsWith("/book/")){const c=qB(i);r=c.bookId,s=c.pageId,c.bookId===e&&(r=void 0)}else i.startsWith("#")&&(s=i.substring(1));const l=n();if(r)return fy(e,l),{bookUrl:hh(r),pageId:s};if(s)return fy(e,l),{pageId:s}}function fy(t,e,n){uc.push({bookId:t,pageId:e})}function hh(t){return`/book/${t}/index.htm`}function qB(t){try{const e=new URL(t,window.location.origin);if(!e.pathname.startsWith("/book/"))throw new Error("Invalid book URL format");const n=e.pathname.replace("/book/",""),a=e.hash.replace("#","");return{bookId:n,pageId:a}}catch(e){return console.error("Error parsing book URL:",e),{bookId:void 0,pageId:void 0}}}const HB="bloom-player",FB="A library for displaying Bloom books in iframes or WebViews",WB="SIL Global",_B="MIT",VB="2.19.6",GB=!1,UB={type:"git",url:"git+https://github.com/BloomBooks/bloom-player.git"},YB="module",XB="lib/shared.es.js",ZB="lib/index.d.ts",JB={".":{types:"./lib/index.d.ts",import:"./lib/shared.es.js",default:"./lib/shared.es.js"}},QB={"// COMMENTS: make the action a space rather than empty string so `yarn run` can list the scripts":" ","//":" ","// 'yarn dev' will build, watch, start a server, and open the player in a brower":" ","// You can edit index-for-developing.html to point to different books":" ","// Or just use 'yarn storybook' and skip this dev approach entirely":" ",dev:"vite","build:standalone":"vite build","build:sharedlib":"vite build --mode lib",test:"vitest","// blame.ignoreRevsFile - This allows blame to see through commits that are only there to format code.":" ",prepare:"husky install && git config blame.ignoreRevsFile .git-blame-ignore-revs",storybook:"storybook dev -p 6006","// run this when working with stories that use an iframe and bloomplayer.htm instead of the raw react components":" ",watchForStorybook:"yarn vite build --watch --mode development","strings:download":"crowdin download --config src/l10n/crowdin.yml && yarn strings:compile","strings:upload":"crowdin upload --config src/l10n/crowdin.yml","strings:compile":"yarn tsx ./src/l10n/compileL10Strings.ts","strings:sync":"yarn strings:upload && yarn strings:download"},tI={"@material-ui/core":"^4.12.3","@material-ui/icons":"^4.11.2",axios:"^0.18.0","compare-versions":"^6.1.1","dynamic-import-polyfill":"^0.1.1","jquery.nicescroll":"^3.7.6",react:"^17.0.2","react-dom":"^17.0.2","react-id-swiper":"2.3.2","style-scoped":"^0.2.1",swiper:"^4.5.0"},eI={"@crowdin/cli":"^4.13.0","@storybook/addon-essentials":"8.4.6","@storybook/addon-interactions":"^8.4.6","@storybook/addon-links":"8.4.6","@storybook/blocks":"8.4.6","@storybook/react":"8.4.6","@storybook/react-vite":"8.4.6","@storybook/test":"8.4.6","@types/jquery":"^3.5.5","@types/jquery.nicescroll":"^3.7.1","@types/node":"^22.7.6","@types/react":"^17.0.2","@types/react-dom":"^17.0.2",editorconfig:"^2.0.0",eslint:"^9.12.0","eslint-plugin-storybook":"^0.11.1",glob:"^10",husky:"8.0.3",jsdom:"^25.0.1",less:"^4.2.0",prettier:"^3.3.3",storybook:"8.4.6",tsx:"^4.19.1",typescript:"*",vite:"^5.4.9","vite-plugin-dts":"^4.5.3","vite-plugin-html":"^3.2.2","vite-plugin-static-copy":"^2.0.0",vitest:"^2.1.3"},nI=["dist/*.js","dist/bloomplayer.htm","dist/*.mp3","lib/*.js","lib/*.d.ts","lib/*.js.map","src/shared/event.ts","src/shared/narration.ts","src/shared/dragActivityRuntime.ts","src/shared/scrolling.ts","src/shared/index.ts","dist/*.css","dist/*.tsv"],aI={node:"24.13.0",yarn:"1.22.19"},iI={name:HB,description:FB,author:WB,license:_B,version:VB,private:!1,"// sideeffects might need to be ['*.css'] to avoid 'shaking' our CSS, if we ever get tree shaking working":"",sideEffects:GB,repository:UB,type:YB,module:XB,types:ZB,exports:JB,scripts:QB,dependencies:tI,devDependencies:eI,"// The four src/ files are directly exported so BloomDesktop can consume them as shared code.":"",files:nI,volta:aI},vi="#d65649",rI="#2e2e2e",oI="#febf00",e0=vs({palette:{primary:{main:rI,contrastText:vi},secondary:{main:vi}}});function n0(){var t=iI.version;return t}const sI=({getBookInstanceId:t})=>{const[e,n]=B.useState(!1),a=n0(),i=new Date("2026-04-20T16:11:48.798Z").toLocaleDateString();if(B.useEffect(()=>{const s=c=>{c.key==="Control"&&n(!0)},l=c=>{c.key==="Control"&&n(!1)};return window.addEventListener("keydown",s),window.addEventListener("keyup",l),()=>{window.removeEventListener("keydown",s),window.removeEventListener("keyup",l)}},[]),!e)return null;const r=t==null?void 0:t();return wt.createElement("div",{className:"diagnostic-info-control",style:{color:vi,fontFamily:"sans-serif",padding:"5px",zIndex:1e3,lineHeight:"1.5"}},wt.createElement("div",null,"Bloom Player v",a," (built ",i,")"),wt.createElement("div",null,"Book ID: ",r??""))},lI=/^[v^~<>=]*?(\d+)(?:\.([x*]|\d+)(?:\.([x*]|\d+)(?:\.([x*]|\d+))?(?:-([\da-z\-]+(?:\.[\da-z\-]+)*))?(?:\+[\da-z\-]+(?:\.[\da-z\-]+)*)?)?)?$/i,hy=t=>{if(typeof t!="string")throw new TypeError("Invalid argument expected string");const e=t.match(lI);if(!e)throw new Error(`Invalid argument not valid semver ('${t}' received)`);return e.shift(),e},py=t=>t==="*"||t==="x"||t==="X",gy=t=>{const e=parseInt(t,10);return isNaN(e)?t:e},uI=(t,e)=>typeof t!=typeof e?[String(t),String(e)]:[t,e],cI=(t,e)=>{if(py(t)||py(e))return 0;const[n,a]=uI(gy(t),gy(e));return n>a?1:n<a?-1:0},my=(t,e)=>{for(let n=0;n<Math.max(t.length,e.length);n++){const a=cI(t[n]||"0",e[n]||"0");if(a!==0)return a}return 0},vy=(t,e)=>{const n=hy(t),a=hy(e),i=n.pop(),r=a.pop(),s=my(n,a);return s!==0?s:i&&r?my(i.split("."),r.split(".")):i||r?i?-1:1:0},ph=new ur;class Te extends B.Component{constructor(e,n){super(e,n),this.activityManager=new oz,this.initialPages=["loading..."],this.initialStyleRules="",this.originalPageClass="Device16x9Portrait",this.bookInfo=new fh,this.bookInteraction=new IB,this.mustUseOriginalPageSize=!1,this.indicesOfPagesWhereWeShouldPreserveDOMState={},this.startingUpSwiper=!0,this.state={pages:this.initialPages,pageIdToIndexMap:{},styleRules:this.initialStyleRules,importedBodyAttributes:{},currentSwiperIndex:0,isLoading:!0,loadFailed:!1,loadErrorHtml:"",ignorePhonyClick:!1,isFinishUpForNewBookComplete:!1,inPauseForced:!1,bookUrl:""},this.isPagesLocalized=!1,this.currentPageHidesNavigationButtons=!1,this.handleDocumentLevelKeyDown=i=>{i.key==="Home"&&(this.goToFirstPage(),i.preventDefault()),i.key==="End"&&(this.goToLastPage(),i.preventDefault())},this.distributionSource="",this.finishUpCalled=!1,this.hasImageDescriptions=!1,this.handlePageVideoComplete=i=>{i.page===Te.currentPage&&this.playAudioAndAnimation(i.page)},this.handlePlayFailed=()=>{this.setState({inPauseForced:!0}),this.props.setForcedPausedCallback&&this.props.setForcedPausedCallback(!0)},this.handlePlayCompleted=()=>{Tn(Ge.MediaFinished),this.props.imageDescriptionCallback(!1)},this.handleToggleImageDescription=i=>{this.props.imageDescriptionCallback(i)},this.handlePageNarrationComplete=i=>{if(i&&(Tn(Ge.MediaFinished),this.shouldAutoPlay())){const r=this.props.autoplayCount??0,s=this.state.startPageIndex??0,l=this.swiperInstance.slides.length-1;let c=this.props.autoplayCount?Math.min(s+r-1,l):l;this.swiperInstance.activeIndex>=c?(this.music.pause(),this.props.shouldReportSoundLog&&QC(),ZC(),KT({})):this.swiperInstance.slideNext()}},this.skipAutoPlay=!1,this.sentBloomNotification=!1;const a=e.url.startsWith("http")?new URL(e.url):new URL(e.url,window.location.origin);a.hash?(this.state.startPageId=a.hash.substring(1),a.hash=""):this.state.startPageIndex=e.startPageIndex,this.state.bookUrl=a.href,Te.currentPagePlayer=this,this.legacyQuestionHandler=new lz(e.locationOfDistFolder)}componentDidMount(){He.setUp(),window.addEventListener("focus",()=>this.handleWindowFocus()),window.addEventListener("blur",()=>this.handleWindowBlur()),document.addEventListener("keydown",e=>this.handleDocumentLevelKeyDown(e)),document.addEventListener("pointerdown",e=>{(e.target.closest("[href], [data-href]")||e.target.closest(".bloom-videoContainer")&&!e.target.closest("[data-draggable-id]"))&&(e.stopPropagation(),e.preventDefault())},{capture:!0}),document.addEventListener("dragstart",e=>{this.activityManager.getActivityAbsorbsDragging()||e.preventDefault()},{capture:!0}),this.componentDidUpdate(this.props,this.state)}CanGoBack(){return OB()}HandleBackButtonClickedIfHavePlayerHistory(){const e=this.getBookIdFromBookUrlForHistory(this.state.bookUrl)||this.bookInfo.bookInstanceId,n=KB(e);return n?(this.navigate(n.bookUrl,n.pageId),!0):!1}navigate(e,n){if(e){const a=new URL(e,this.state.bookUrl);this.setState({bookUrl:a.href,startPageId:n,startPageIndex:void 0})}else if(n!==void 0){const a=this.state.pageIdToIndexMap[n];this.swiperInstance.slideTo(a)}}getBookIdFromBookUrlForHistory(e){if(e)try{const a=new URL(e,window.location.href).pathname.match(/^\/book\/([^/]+)\/index\.htm$/i);return a?a[1]:void 0}catch{return}}handleWindowFocus(){const e=localStorage.getItem(_l),n=localStorage.getItem(om);e&&n==this.sourceUrl&&(this.bookInteraction.beginReadTime=Date.now()-parseInt(e,10))}handleWindowBlur(){const e=Date.now()-this.bookInteraction.beginReadTime;localStorage.setItem(_l,e.toString()),localStorage.setItem(om,this.sourceUrl)}getRequiredVersionMessage(e){var c;const n=(c=e.querySelector('meta[name="FeatureRequirement"]'))==null?void 0:c.getAttribute("content");if(!n)return"";const a=/BloomPlayerMinVersion":"(.*?)".*?"FeatureId":"(.*?)"/g;let i,r=null,s=null;for(;(i=a.exec(n))!==null;){const h=i[1];(!r||vy(h,r)>0)&&(r=h,s=i[2])}if(!r||!s)return"";const l=n0();if(vy(l,r)>=0)return"";if(window.location.hostname.toLowerCase().indexOf("bloomlibrary.org")>=0)return He.getTranslation("Version.Problem.Web",this.props.preferredUiLanguages,"This book uses the feature {feature}. Unfortunately, {hostname} is not ready to display this book yet. Please check back again later or write to issues@bloomlibrary.org if you think this is unexpected.").replace("{feature}",s).replace("{hostname}",window.location.hostname);{let h=ma("host","");switch(h){case"bloomreader":h="Bloom Reader";break;case"bloompubviewer":h="BloomPUB Viewer";break;case"readerapp":h="";break}return h?He.getTranslation("Version.Problem.Host",this.props.preferredUiLanguages,"This book uses the feature {feature} and requires a newer version of {host} to read it. Please upgrade to the latest version.").replace("{feature}",s).replace("{host}",h):He.getTranslation("Version.Problem.NoHost",this.props.preferredUiLanguages,"This book uses the feature {feature} and requires a newer version of the program you are using to read it. Please upgrade to the latest version.").replace("{feature}",s)}}componentDidUpdate(e,n){var a;try{if(!this.props.url||this.state.loadFailed&&n.bookUrl===this.state.bookUrl)return;this.initializeMedia();const i=this.preprocessUrl();if(i&&i!=="/working"&&i!==this.sourceUrl){this.finishUpCalled=!1,this.setState({isLoading:!0,loadFailed:!1}),this.metaDataObject=void 0,this.htmlElement=void 0,this.sourceUrl=i;const r=this.sourceUrl.lastIndexOf("/"),s=this.sourceUrl.lastIndexOf("%2f");let l;r>s?l=this.sourceUrl.substring(r+1,this.sourceUrl.length):l=this.sourceUrl.substring(s+3,this.sourceUrl.length);const c=l.endsWith(".htm"),h=c?this.sourceUrl:this.sourceUrl+"/"+l+".htm";this.urlPrefix=c?this.sourceUrl.substring(0,Math.max(r,s)):this.sourceUrl,this.music.urlPrefix=this.urlPrefix,yC(this.music.urlPrefix);const m=ni.get(this.fullUrl(".distribution")).then(P=>P,P=>({data:""})),k=ni.get(h),w=ni.get(this.fullUrl("meta.json"));Promise.all([k,w,m]).then(P=>{const[E,z,A]=P;this.metaDataObject=z==null?void 0:z.data,this.distributionSource=A.data;const S=new DOMParser().parseFromString(E==null?void 0:E.data,"text/html"),N=S.documentElement,L=this.getRequiredVersionMessage(S);this.setState({requiredVersion:L});const j=N.getElementsByTagName("body")[0];this.mustUseOriginalPageSize=this.computeMustUseOriginalPageSize(j),this.bookInfo.setSomeBookInfoFromBody(j),this.localizeOnce(),this.props.shouldReportSoundLog&&(this.videoList=this.getVideoList(S)),this.animation.PlayAnimations=this.bookInfo.playAnimations,this.collectBodyAttributes(j),this.makeNonEditable(j),this.htmlElement=N;const f=N.getElementsByClassName("bloom-page")[0];this.originalPageClass="Device16x9Portrait",f&&(this.originalPageClass=Te.getPageSizeClass(f)),this.legacyQuestionHandler.generateQuizPagesFromLegacyJSON(this.urlPrefix,j,this.originalPageClass,()=>{this.finishUp()})}).catch(P=>this.HandleLoadingError(P))}else if(e.landscape!==this.props.landscape||e.useOriginalPageSize!==this.props.useOriginalPageSize||e.autoplay!==this.props.autoplay){const r=document.getElementsByClassName("bloom-page");for(let s=0;s<r.length;s++){const l=r[s];this.setPageSizeClass(l)}}!this.state.isLoading&&(n.isLoading||e.activeLanguageCode!==this.props.activeLanguageCode)&&(this.updateDivVisibilityByLangCode(n.isLoading),this.updateOverlayPositionsByLangCode(),this.finishUpCalled&&this.finishUp(!1)),this.state.currentSwiperIndex!=n.currentSwiperIndex&&((a=this.rootDiv)==null||a.querySelectorAll(Xp).forEach(r=>{const s=Is(r).getNiceScroll();s&&s.length>0&&s.remove()})),!this.state.isLoading&&(n.isLoading||e.shouldReadImageDescriptions!==this.props.shouldReadImageDescriptions)&&this.finishUpCalled&&(this.setIndex(this.state.currentSwiperIndex),this.showingPage(this.state.currentSwiperIndex)),this.state.isFinishUpForNewBookComplete&&e.landscape!==this.props.landscape&&(this.setIndex(this.state.currentSwiperIndex),this.showingPage(this.state.currentSwiperIndex)),e.paused!==this.props.paused&&this.handlePausePlay(),this.swiperInstance&&this.swiperInstance.lazy.load()}catch(i){this.setState({isLoading:!1,loadFailed:!0,loadErrorHtml:i.message})}}collectBodyAttributes(e){for(var n={},a=0;a<e.attributes.length;a++)n[e.attributes.item(a).nodeName]=e.attributes.item(a).nodeValue;this.setState({importedBodyAttributes:n})}HandleLoadingError(e){var r;let a=`<p>There was a problem displaying this book: ${e.message}<p>`;const i=!!((r=e.config)!=null&&r.url)&&new URL(e.config.url,window.location.href).pathname.startsWith("/book/");i?a="<p>We could not find that book.</p>":(e.config&&e.config.url&&e.config.url.startsWith("file://")||e.message.indexOf("404")>=0)&&(a="<p>This book (or some part of it) was not found.<p>",e.config&&e.config.url&&(a+=`<p class='errorDetails'>${dI(e.config.url)}</p>`)),this.setState({isLoading:!1,loadFailed:!0,loadErrorHtml:a}),i&&ph.raise()}async finishUp(e=!0){if(this.finishUpCalled=!0,!this.htmlElement)return;Xo.setAllVideoPostersTo1x1TransparentPNG(this.htmlElement);const n=this.htmlElement.getElementsByClassName("bloom-page"),a=[];e&&(this.bookInfo.totalNumberedPages=0,this.bookInfo.questionCount=0,this.activityManager.collectActivityContextForBook(n),this.bookInteraction.clearPagesShown(),this.music.processAllMusicForBook(n));const i=this.bookInfo.getPreferredTranslationLanguages(),r=i[0]===this.props.activeLanguageCode||!this.props.activeLanguageCode,s={},l=h=>h.classList.contains("bloom-interactive-page")||h.classList.contains("simple-comprehension-quiz")||h.getAttribute("data-activity")=="iframe"||h.getElementsByClassName("questions").length>0;s.length=0,s.cover=0;for(let h=0;h<n.length;h++){const m=n[h],k=m.getAttribute("id");k&&(s[k]=h);const w=this.setPageSizeClass(m);m.setAttribute("data-index",h.toString(10)),h===0&&this.props.reportBookProperties&&this.props.reportBookProperties({landscape:w,canRotate:this.bookInfo.canRotate,preferredLanguages:i,pageNumbers:Array.from(n).map(E=>E.getAttribute("data-page-number")??""),isRtl:this.metaDataObject.isRtl,internalUrl:this.state.bookUrl}),e&&(this.fixRelativeUrls(m),m.classList.contains("numberedPage")&&(this.indexOflastNumberedPage=h,this.bookInfo.totalNumberedPages++),(m.getAttribute("data-analyticscategories")||m.getAttribute("data-analyticsCategories"))==="comprehension"&&this.bookInfo.questionCount++),this.showOrHideL1OnlyText(m,r);const P=l(m);P&&this.activityManager.initializePageHtml(this.urlPrefix,m,a.length),(!this.props.skipActivities||!P)&&a.push(m.outerHTML)}if(e){const h=this.htmlElement.getElementsByTagName("head")[0];this.bookInfo.setSomeBookInfoFromHead(h);const m=this.htmlElement.getElementsByTagName("body")[0];if(this.metaDataObject&&(this.bookInfo.setSomeBookInfoFromMetadata(this.metaDataObject,m),this.reportBookOpened(m)),this.props.controlsCallback){const k=gs.createLangDataArrayFromDomAndMetadata(m,this.metaDataObject);this.hasImageDescriptions=fI(m),this.props.controlsCallback(k,this.hasImageDescriptions,w=>{var P;(P=this.swiperInstance)==null||P.slideTo(w)})}}if(e){var c;try{c=await DB(this.htmlElement,this.urlPrefix,this.bookInfo,()=>this.legacyQuestionHandler.getPromiseForAnyQuizCss())}catch(h){this.HandleLoadingError(h),c=""}if(this.startingUpSwiper=!0,this.state.startPageId){if(s[this.state.startPageId]===void 0)throw new Error(`Page ID ${this.state.startPageId} not found in the current pageIdToIndexMap`);this.setState({startPageIndex:s[this.state.startPageId]})}this.setState({pages:a,pageIdToIndexMap:s,styleRules:c,isLoading:!1,currentSwiperIndex:this.state.startPageIndex??0})}else this.setState({pages:a,isLoading:!1});this.props.pageStylesAreNowInstalled(),e?window.setTimeout(()=>{this.setState({isFinishUpForNewBookComplete:!0});const h=this.startingUpSwiper;this.startingUpSwiper=!1;var m=this.state.startPageIndex??0;this.setIndex(m),this.showingPage(m),h&&this.addScrollbarsToPageWhenReady(this.swiperInstance.activeIndex);const k=document.getElementsByClassName("swiper-button-next")[0],w=document.getElementsByClassName("swiper-button-prev")[0];w==null||w.setAttribute("tabindex","4"),k==null||k.setAttribute("tabindex","5"),this.shouldFocusNextButtonForNewBook()&&(k==null||k.focus())},500):Te.currentPage&&window.setTimeout(()=>{this.setIndex(Te.currentPageIndex),this.showingPage(Te.currentPageIndex)},200)}shouldFocusNextButtonForNewBook(){return window.self===window.top||document.referrer.startsWith("http://localhost:")?!0:document.referrer.includes("bloomlibrary.org/player/")}showOrHideL1OnlyText(e,n){e.querySelectorAll(".coverBottomBookTopic, .coverBottomLangName").forEach(a=>{n||a.classList.contains("bloom-content1")?a.classList.remove("do-not-display"):a.classList.add("do-not-display")})}localizeOnce(){!this.isPagesLocalized&&this.state.pages!==this.initialPages&&this.state.styleRules!==this.initialStyleRules&&(He.localizePages(document.body,this.bookInfo.getPreferredTranslationLanguages()),this.isPagesLocalized=!0)}initializeMedia(){this.video||(this.video=new Xo,this.video.PageVideoComplete=new ur,this.video.PageVideoComplete.subscribe(this.handlePageVideoComplete)),this.animation||(this.animation=new Kl),na.subscribe(this.handlePageNarrationComplete),Ar.subscribe(this.handlePlayFailed),Qa.subscribe(this.handlePlayCompleted),gC(this.storeAudioAnalytics.bind(this)),za.subscribe(this.handleToggleImageDescription.bind(this)),mC(()=>{var e;return(e=this.swiperInstance)==null?void 0:e.animating}),vC(e=>eb(e,1)),this.music||(this.music=new tT,this.music.PlayFailed=new ur,this.music.PlayFailed.subscribe(()=>{this.setState({inPauseForced:!0}),this.props.setForcedPausedCallback&&this.props.setForcedPausedCallback(!0)}))}preprocessUrl(){let e=this.state.bookUrl;if(e===void 0||e.trim()==="")throw new Error("The url parameter was empty. It should point to the url of a book.");return e.endsWith("/")&&(e=e.substring(0,e.length-1)),e.endsWith("%2f")&&(e=e.substring(0,e.length-3)),e}handlePausePlay(){this.props.paused?this.pauseAllMultimedia():Te.currentPage!==$y()||mn===Ge.MediaFinished?this.resetForNewPageAndPlay(Te.currentPage):mn===Ge.VideoPaused?this.video.play():(WC(),this.animation.resumeAnimation(),this.music.play())}getAllBloomCanvasElementsOnPage(){var a,i;const e=(a=this.htmlElement)==null?void 0:a.ownerDocument.getElementsByClassName("bloom-canvas");if(e&&e.length>0)return Array.from(e);const n=(i=this.htmlElement)==null?void 0:i.ownerDocument.getElementsByClassName("bloom-imageContainer");return n?Array.from(n).filter(r=>r.parentElement.closest(".bloom-imageContainer")===null):[]}computeMustUseOriginalPageSize(e){return this.props.useOriginalPageSize||e.querySelector(".bloom-canvas-element")?!0:!!e.querySelector(".bloom-textOverPicture")}updateOverlayPositionsByLangCode(){if(!(!this.props.activeLanguageCode||!this.htmlElement))try{const e=this.props.activeLanguageCode;this.getAllBloomCanvasElementsOnPage().forEach(n=>{Array.from(n.querySelectorAll(Bs)).forEach(i=>{const r=Array.from(i.getElementsByClassName("bloom-editable")).find(s=>s.getAttribute("lang")===e);if(r){const s=r.getAttribute("data-bubble-alternate");if(s){const l=JSON.parse(s.replace(/`/g,'"'));i.setAttribute("style",l.style)}}});const a=Array.from(n.getElementsByClassName("comical-alternate")).find(i=>i.getAttribute("data-lang")===e);if(a){const i=n.getElementsByClassName("comical-generated")[0];i&&(i.classList.remove("comical-generated"),i.classList.add("comical-alternate"),i.style.display="none"),a.classList.remove("comical-alternate"),a.classList.add("comical-generated"),a.style.removeProperty("display")}})}catch(e){console.error(e)}}updateDivVisibilityByLangCode(e){if(!this.props.activeLanguageCode||!this.htmlElement)return;const a=this.bookInfo.getPreferredTranslationLanguages()[0]===this.props.activeLanguageCode||!this.props.activeLanguageCode,i=this.props.activeLanguageCode,r=this.htmlElement.ownerDocument.evaluate(".//div[contains(@class, 'bloom-translationGroup')]",this.htmlElement,null,XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE,null),s="bloom-visibility-code-on";for(let l=0;l<r.snapshotLength;l++){const c=r.snapshotItem(l),h=c.getAttribute("data-default-languages"),m=h?h.split(/,| /):[],k=m==null||m.length===0||!m[0]||m.includes("V")||m.includes("L1")||Te.areStringsEqualInvariantCultureIgnoreCase(m[0],"auto"),w=c.childNodes;for(let P=0;P<w.length;P++){const E=w.item(P);!E||!E.classList||!E.classList.contains("bloom-editable")||(e&&E.setAttribute("data-original-class",E.getAttribute("class")||""),a?E.setAttribute("class",E.getAttribute("data-original-class")||""):k&&(E.getAttribute("lang")===i?(E.classList.add(s),Array.from(E.classList).forEach(A=>{A.startsWith("bloom-content")&&E.classList.remove(A)}),E.classList.add("bloom-content1"),E.classList.add("bloom-contentFirst")):E.classList.remove(s)))}}}static areStringsEqualInvariantCultureIgnoreCase(e,n){return e.localeCompare(n,"en-US",{sensitivity:"accent"})===0}static isDivInL2(e){return e.classList.contains("bloom-contentNational1")}static isDivInL3(e){return e.classList.contains("bloom-contentNational2")}componentWillUnmount(){this.pauseAllMultimedia(),document.removeEventListener("keydown",e=>this.handleDocumentLevelKeyDown(e)),this.unsubscribeAllEvents()}unsubscribeAllEvents(){this.video.PageVideoComplete.unsubscribe(this.handlePageVideoComplete),na.unsubscribe(this.handlePageNarrationComplete),Ar.unsubscribe(this.handlePlayFailed),Qa.unsubscribe(this.handlePlayCompleted),za.unsubscribe(this.handleToggleImageDescription)}pauseAllMultimedia(){mn===Ge.VideoPlaying?this.video.pause():mn===Ge.AudioPlaying&&(_C(),this.animation.PauseAnimation()),this.music.pause()}reportBookOpened(e){const n=this.bookInfo.getAmbientAnalyticsProps();this.distributionSource&&(n.distributionSource=this.distributionSource),RT(n),ab("BookOrShelf opened",{})}sendUpdateOfBookProgressReportToExternalContext(){const e=this.bookInteraction.getProgressReportPropertiesForAnalytics();$T("Pages Read",e)}makeNonEditable(e){const n=e.ownerDocument.evaluate(".//*[@contenteditable]",e,null,XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE,null);for(let a=0;a<n.snapshotLength;a++)n.snapshotItem(a).removeAttribute("contenteditable")}setPageSizeClass(e){return Te.setPageSizeClass(e,this.bookInfo.canRotate,this.props.landscape,this.mustUseOriginalPageSize,this.originalPageClass)}static getPageSizeClass(e){const a=(e.getAttribute("class")||"").match(/\b\S*?(Portrait|Landscape)\b/);return a&&a.length?a[0]:""}static setPageSizeClass(e,n,a,i,r){let s=!1;const l=this.getPageSizeClass(e);if(l){s=n?a:l.endsWith("Landscape");let c="";i?c=s?r.replace("Portrait","Landscape"):r.replace("Landscape","Portrait"):c=s?"Device16x9Landscape":"Device16x9Portrait",l!==c&&(e.classList.remove(l),e.classList.add(c))}return s}goToFirstPage(){this.swiperInstance.slideTo(0)}goToLastPage(){this.swiperInstance.slideTo(99999)}fixRelativeUrls(e){const n=e.ownerDocument.evaluate(".//*[@src]",e,null,XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE,null);for(let r=0;r<n.snapshotLength;r++){const s=n.snapshotItem(r);if(!s)continue;const l=s.getAttribute("src"),c=this.fullUrl(l);s.setAttribute("src",c)}const a=e.ownerDocument.evaluate(".//*[@style]",e,null,XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE,null),i=new RegExp(/background-image:url\(['"](.*)['"]\)/);for(let r=0;r<a.snapshotLength;r++){const s=a.snapshotItem(r);if(!s)continue;const l=s.getAttribute("style")||"",c=i.exec(l);if(!c)continue;const h=this.fullUrl(c[1]),m=l.replace(i,"");s.setAttribute("style",m),s.setAttribute("data-background",h),s.classList.add("swiper-lazy")}}fullUrl(e){return this.urlPrefix+"/"+e}getRootDiv(){return this.rootDiv}slideNext(){this.swiperInstance&&this.swiperInstance.slideNext()}slidePrevious(){this.swiperInstance&&this.swiperInstance.slidePrev()}getBookInstanceId(){return this.bookInfo.bookInstanceId}getPlayerOptionsForPage(e){if(!e)return;let n=e.getAttribute("data-player-options");if(n)try{return n=n.replace(/'/g,'"'),JSON.parse(n)}catch(a){console.log("getPlayerOptionsForPage failed to parse json: "+n+" with error "+a.message);return}}render(){var i;const e=this.activityManager.getActivityAbsorbsDragging();if(this.state.isLoading)return B.createElement(Nz,{className:"loadingSpinner",color:"secondary"});if(this.state.loadFailed)return B.createElement(B.Fragment,null,B.createElement(bk,{className:"loadFailedIcon",color:"secondary"}),B.createElement("div",{className:"loadErrorMessage",dangerouslySetInnerHTML:{__html:this.state.loadErrorHtml}}));if(this.state.requiredVersion)return B.createElement("div",{className:"requiredVersionMessage"},this.state.requiredVersion);CC(this.props.shouldReadImageDescriptions&&this.hasImageDescriptions);const n={getSwiper:r=>{var s,l;this.swiperInstance=r,(s=this.metaDataObject)!=null&&s.isRtl&&this.swiperInstance&&((l=this.swiperInstance.el)==null||l.setAttribute("dir","rtl"),this.swiperInstance.rtl=!0,this.swiperInstance.rtlTranslate=!0)},simulateTouch:!0,touchStartPreventDefault:!1,on:{slideChange:()=>{this.state.inPauseForced&&this.props.setForcedPausedCallback&&this.props.setForcedPausedCallback(!1),this.setState({inPauseForced:!1}),this.startingUpSwiper||this.showingPage(this.swiperInstance.activeIndex)},slideChangeTransitionStart:()=>{this.startingUpSwiper||this.setIndex(this.swiperInstance.activeIndex)},slideChangeTransitionEnd:()=>{this.addScrollbarsToPageWhenReady(this.swiperInstance.activeIndex)}},keyboard:{enabled:!0,onlyInViewport:!1},preloadImages:!1,lazy:{loadPrevNext:!0,loadOnTransitionStart:!0,loadPrevNextAmount:2},shouldSwiperUpdate:!0};this.startingUpSwiper&&(n.activeSlideKey=(i=this.state.startPageIndex)==null?void 0:i.toString());let a="bloomPlayer";return this.currentPageHidesNavigationButtons?a+=" hideNextPrevButtons extraScalingForChrome85Bug":(this.props.outsideButtonPageClass&&(a+=" "+this.props.outsideButtonPageClass),e&&(a+=" showNavigationButtonsEvenOnTouchDevices")),B.createElement("div",{"aria-label":"Player Content",className:a+(this.props.extraClassNames?" "+this.props.extraClassNames:""),ref:r=>this.rootDiv=r},B.createElement(fC,{key:this.shouldAutoPlay()?"fade":"slide",...n,effect:this.shouldAutoPlay()?"fade":"slide"},this.state.pages.map((r,s)=>{const c=Math.abs(s-this.state.currentSwiperIndex)<2||this.indicesOfPagesWhereWeShouldPreserveDOMState[s];return B.createElement("div",{key:s,className:"page-preview-slide",onClick:h=>this.handlePageClick(h)},c?B.createElement(B.Fragment,null,B.createElement("style",{scoped:!0},this.state.styleRules),B.createElement("div",{...this.state.importedBodyAttributes,className:`bloomPlayer-page ${this.bookInfo.hasAppearanceSystem?"appearance-system":""} ${this.state.importedBodyAttributes.class??""}`,dangerouslySetInnerHTML:{__html:r}})):"")})),B.createElement("div",{className:"swiper-button-prev "+(this.metaDataObject.isRtl?"swiper-button-right":"swiper-button-left")+(this.props.hideSwiperButtons||this.state.currentSwiperIndex===0?" swiper-button-disabled":""),onClick:()=>this.slidePrevious(),onTouchStart:r=>{this.setState({ignorePhonyClick:!0})}},B.createElement(Aa,{className:"nav-button",disableRipple:!0},this.metaDataObject.isRtl?B.createElement(sh,{titleAccess:He.getTranslation("Button.Prev",this.props.preferredUiLanguages,"Previous Page")}):B.createElement(oh,{titleAccess:He.getTranslation("Button.Prev",this.props.preferredUiLanguages,"Previous Page")}))),B.createElement("div",{className:"swiper-button-next "+(this.metaDataObject.isRtl?"swiper-button-left":"swiper-button-right")+(this.props.hideSwiperButtons||this.state.currentSwiperIndex>=this.state.pages.length-1?" swiper-button-disabled":""),onClick:()=>this.slideNext(),onTouchStart:r=>{this.setState({ignorePhonyClick:!0})}},B.createElement(Aa,{className:"nav-button",disableRipple:!0},this.metaDataObject.isRtl?B.createElement(oh,{titleAccess:He.getTranslation("Button.Next",this.props.preferredUiLanguages,"Next Page")}):B.createElement(sh,{titleAccess:He.getTranslation("Button.Next",this.props.preferredUiLanguages,"Next Page")}))))}shouldAutoPlay(){var e=this.bookInfo.autoAdvance&&this.props.landscape;return this.props.autoplay==="yes"?e=!0:this.props.autoplay==="no"&&(e=!1),e&&!this.skipAutoPlay}setIndex(e){if(this.state.isLoading||this.startingUpSwiper)return;this.setState({currentSwiperIndex:e});const n=this.getPageAtSwiperIndex(e);n&&(this.setPageSizeClass(n),this.animation.HandlePageBeforeVisible(n),this.video.hidingPage(),this.video.HandlePageBeforeVisible(n),GC(),this.music.hidingPage(),mn===Ge.AudioPaused||mn===Ge.VideoPaused?Tn(Ge.NewPageMediaPaused):(this.skipAutoPlay=!0,jC(),this.skipAutoPlay=!1,Tn(Ge.NewPage)))}getPageAtSwiperIndex(e){if(this.swiperInstance==null)return null;const n=this.swiperInstance.slides[e];return n?n.getElementsByClassName("bloom-page")[0]:null}getPageIdFromIndex(e){const n=this.getPageAtSwiperIndex(e);if(!n)throw new Error("No bloomPage at index "+e);return n.getAttribute("id")}static getCurrentPage(){return Te.currentPage}isXmatterPage(){const e=Te.currentPage;if(!e)return!0;const n=e.getAttribute("class");return!n||n.indexOf("bloom-page")<0||n.indexOf("bloom-backMatter")>=0||n.indexOf("bloom-frontMatter")>=0?!0:e.hasAttribute("data-xmatter-page")}showingPage(e){if(this.state.isLoading||this.startingUpSwiper)return;this.props.pageChanged&&this.props.pageChanged(e);const n=this.getPageAtSwiperIndex(e);if(!n){window.setTimeout(()=>this.showingPage(e),50);return}const a=this.getPlayerOptionsForPage(n);this.currentPageHidesNavigationButtons=!!(a&&a.hideNavigation),this.props.hidingNavigationButtonsCallback&&this.props.hidingNavigationButtonsCallback(this.currentPageHidesNavigationButtons),this.activityManager.showingPage(e,n)&&(this.indicesOfPagesWhereWeShouldPreserveDOMState[e]=!0),window.setTimeout(()=>{Te.currentPage=n,Te.currentPageIndex=e,Te.currentPageHasVideo=Xo.pageHasVideo(n),this.setPageSizeClass(n),this.resetForNewPageAndPlay(n),this.props.paused&&this.animation.shouldAnimate(n)&&(this.animation.HandlePageBeforeVisible(n),this.animation.HandlePageVisible(n,this.props.paused),this.animation.HandlePageDurationAvailable(n,am(n),this.props.paused)),this.isXmatterPage()||(this.bookInteraction.pageShown(e),e===this.indexOflastNumberedPage&&(this.bookInteraction.lastNumberedPageWasRead=!0)),this.props.reportPageProperties&&this.props.reportPageProperties({hasAudio:FC(n),hasMusic:this.music.pageHasMusic(n),hasVideo:Te.currentPageHasVideo}),this.bookInteraction.reportedAudioOnCurrentPage=!1,this.bookInteraction.reportedVideoOnCurrentPage=!1,this.sendUpdateOfBookProgressReportToExternalContext(),this.swiperInstance.params.noSwiping=this.activityManager.getActivityAbsorbsDragging(),this.swiperInstance.params.touchRatio=this.activityManager.getActivityAbsorbsDragging()?0:1,this.activityManager.getActivityAbsorbsTyping()?this.swiperInstance.keyboard.disable():this.swiperInstance.keyboard.enable(),Array.from(n.querySelectorAll("[data-sound]")).forEach(r=>{r.addEventListener("click",Gp)})},0)}addScrollbarsToPageWhenReady(e){if(this.state.isLoading||this.startingUpSwiper)return;const n=this.getPageAtSwiperIndex(e);if(!n){window.setTimeout(()=>this.addScrollbarsToPageWhenReady(e),50);return}FL(n,Te.handlePointerMoveEvent)}static handlePointerMoveEvent(e){var n;e.pointerType==="mouse"&&((n=e.target)!=null&&n.closest(".nicescroll-cursors"))&&e.stopPropagation()}storeAudioAnalytics(e){e<.001||Number.isNaN(e)||(this.bookInteraction.totalAudioDuration+=e,!this.isXmatterPage()&&(this.bookInteraction.reportedAudioOnCurrentPage||(this.bookInteraction.reportedAudioOnCurrentPage=!0,this.bookInteraction.audioPageShown(Te.currentPageIndex)),this.sendUpdateOfBookProgressReportToExternalContext()))}static storeVideoAnalytics(e){if(e<.001)return;const n=Te.currentPagePlayer;n.bookInteraction.totalVideoDuration+=e,!n.bookInteraction.reportedVideoOnCurrentPage&&!n.isXmatterPage()&&(n.bookInteraction.reportedVideoOnCurrentPage=!0,n.bookInteraction.videoPageShown(Te.currentPageIndex)),n.sendUpdateOfBookProgressReportToExternalContext()}resetForNewPageAndPlay(e){if(this.props.paused){this.video.HandlePageVisible(e,()=>this.props.paused);return}if(Ky(e),Te.currentPageHasVideo){const n=()=>{this.video.HandlePageVisible(e,()=>this.props.paused),this.music.pause()};if(Tn(Ge.VideoPlaying),!this.sentBloomNotification&&(this.sentBloomNotification=!0,this.props.shouldReportSoundLog)){nf("/publish/av/startRecording",this.videoList).then(n);return}n()}else this.playAudioAndAnimation(e)}playAudioAndAnimation(e){if(this.activityManager.getActivityManagesSound()){this.activityManager.doInitialSoundAndAnimation();return}if(Tn(Ge.AudioPlaying),!e)return;const n=am(e);this.animation.HandlePageDurationAvailable(e,n,this.props.paused);const a=()=>{Kl.pageHasAnimation(e)&&this.animation.HandlePageBeforeVisible(e),this.animation.HandlePageVisible(e,this.props.paused),Hy(e,this.animation.animatableCanvas),this.music.HandlePageVisible(e)};if(!this.sentBloomNotification&&(this.sentBloomNotification=!0,this.props.shouldReportSoundLog)){nf("/publish/av/startRecording",this.videoList).then(a);return}a()}getVideoList(e){let n="";for(const r of Array.from(e.getElementsByTagName("video"))){var a=r,i=a.getElementsByTagName("source")[0].getAttribute("src");n&&(n+="|"),n+=i}return n}handlePageClick(e){if(!this.state.ignorePhonyClick&&(!this.activityManager.getActivityAbsorbsClicking()||e.target.closest("[data-href]")&&e.target.closest(".bloom-canvas"))&&!e.target.closest(".bloom-videoContainer")){const n=$B(e.nativeEvent,this.bookInfo.bookInstanceId,()=>this.getPageIdFromIndex(this.state.currentSwiperIndex));n?(this.navigate(n.bookUrl,n.pageId),e.stopPropagation(),e.preventDefault()):this.props.onContentClick&&this.props.onContentClick(e)}this.setState({ignorePhonyClick:!1})}}function dI(t){return t.replace("%23","#").replace(/[\u00A0-\u9999<>\&]/gim,e=>"&#"+e.charCodeAt(0)+";")}function fI(t){return t.ownerDocument.evaluate("//div[contains(@class, 'bloom-imageDescription')]/div[contains(@class, 'bloom-editable') and contains(@class, 'bloom-visibility-code-on')]//*[contains(@class, 'audio-sentence') or contains(@class, 'bloom-highlightSegment')]",t,null,XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE,null).snapshotLength>0?!0:t.ownerDocument.evaluate("//div[contains(@class, 'bloom-imageDescription')]/div[contains(@class, 'bloom-editable') and contains(@class, 'bloom-visibility-code-on') and @data-audiorecordingmode='TextBox']/p[text()]",t,null,XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE,null).snapshotLength>0}var Zp={},hI=wa,pI=ka;Object.defineProperty(Zp,"__esModule",{value:!0});var a0=Zp.default=void 0,gI=pI(Mn()),mI=hI(xa()),vI=(0,mI.default)(gI.createElement("path",{d:"M20 11H7.83l5.59-5.59L12 4l-8 8 8 8 1.41-1.41L7.83 13H20v-2z"}),"ArrowBack");a0=Zp.default=vI;var Jp={},yI=wa,bI=ka;Object.defineProperty(Jp,"__esModule",{value:!0});var i0=Jp.default=void 0,wI=bI(Mn()),kI=yI(xa()),xI=(0,kI.default)(wI.createElement("path",{d:"M6 10c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm12 0c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm-6 0c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z"}),"MoreHoriz");i0=Jp.default=xI;var Qp={},SI=wa,CI=ka;Object.defineProperty(Qp,"__esModule",{value:!0});var tg=Qp.default=void 0,TI=CI(Mn()),EI=SI(xa()),PI=(0,EI.default)(TI.createElement("path",{d:"M10 16.5l6-4.5-6-4.5v9zM12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z"}),"PlayCircleOutline");tg=Qp.default=PI;var eg={},MI=wa,AI=ka;Object.defineProperty(eg,"__esModule",{value:!0});var r0=eg.default=void 0,NI=AI(Mn()),LI=MI(xa()),zI=(0,LI.default)(NI.createElement("path",{d:"M9 16h2V8H9v8zm3-14C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8zm1-4h2V8h-2v8z"}),"PauseCircleOutline");r0=eg.default=zI;var ng={},BI=wa,II=ka;Object.defineProperty(ng,"__esModule",{value:!0});var o0=ng.default=void 0,DI=II(Mn()),jI=BI(xa()),RI=(0,jI.default)(DI.createElement("path",{d:"M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zm6.93 6h-2.95c-.32-1.25-.78-2.45-1.38-3.56 1.84.63 3.37 1.91 4.33 3.56zM12 4.04c.83 1.2 1.48 2.53 1.91 3.96h-3.82c.43-1.43 1.08-2.76 1.91-3.96zM4.26 14C4.1 13.36 4 12.69 4 12s.1-1.36.26-2h3.38c-.08.66-.14 1.32-.14 2 0 .68.06 1.34.14 2H4.26zm.82 2h2.95c.32 1.25.78 2.45 1.38 3.56-1.84-.63-3.37-1.9-4.33-3.56zm2.95-8H5.08c.96-1.66 2.49-2.93 4.33-3.56C8.81 5.55 8.35 6.75 8.03 8zM12 19.96c-.83-1.2-1.48-2.53-1.91-3.96h3.82c-.43 1.43-1.08 2.76-1.91 3.96zM14.34 14H9.66c-.09-.66-.16-1.32-.16-2 0-.68.07-1.35.16-2h4.68c.09.65.16 1.32.16 2 0 .68-.07 1.34-.16 2zm.25 5.56c.6-1.11 1.06-2.31 1.38-3.56h2.95c-.96 1.65-2.49 2.93-4.33 3.56zM16.36 14c.08-.66.14-1.32.14-2 0-.68-.06-1.34-.14-2h3.38c.16.64.26 1.31.26 2s-.1 1.36-.26 2h-3.38z"}),"Language");o0=ng.default=RI;var ag={},OI=wa,KI=ka;Object.defineProperty(ag,"__esModule",{value:!0});var s0=ag.default=void 0,$I=KI(Mn()),qI=OI(xa()),HI=(0,qI.default)($I.createElement("path",{d:"M7 14H5v5h5v-2H7v-3zm-2-4h2V7h3V5H5v5zm12 7h-3v2h5v-5h-2v3zM14 5v2h3v3h2V5h-5z"}),"Fullscreen");s0=ag.default=HI;var ig={},FI=wa,WI=ka;Object.defineProperty(ig,"__esModule",{value:!0});var l0=ig.default=void 0,_I=WI(Mn()),VI=FI(xa()),GI=(0,VI.default)(_I.createElement("path",{d:"M5 16h3v3h2v-5H5v2zm3-8H5v2h5V5H8v3zm6 11h2v-3h3v-2h-5v5zm2-11V5h-2v5h5V8h-3z"}),"FullscreenExit");l0=ig.default=GI;function UI(t){return wt.createElement(rh,{...t,width:"21",height:"20",viewBox:"0 0 21 20"},wt.createElement("path",{d:"M20.6181 9.909C20.6181 9.909 17.3581 3.70568 10.2454 3.70568C10.1127 3.70568 9.9821 3.70851 9.8522 3.71275L9.23133 0.590958L8.27889 0.807585L8.87136 3.78574C2.72807 4.50344 0 9.86355 0 9.86355C0 9.86355 0.566707 11.0581 1.77366 12.4165L1.27674 9.91983C1.26639 9.90052 1.26089 9.89016 1.26089 9.89016C1.26089 9.89016 1.45882 9.53343 1.86833 9.01188L2.73952 13.3918C3.09729 13.7179 3.49205 14.0383 3.92423 14.3419L2.68074 8.09074C2.92754 7.84068 3.20826 7.58049 3.52199 7.32171L5.05787 15.0424C5.40441 15.2277 5.77033 15.3993 6.15474 15.5514L4.38901 6.67725C4.6772 6.48487 4.98565 6.29932 5.31568 6.12485L7.26481 15.9206C7.59924 16.0118 7.94578 16.0871 8.30509 16.146L7.56314 12.4167C7.89823 12.8518 8.32205 13.2046 8.80465 13.4464L9.36563 16.2656C9.59813 16.2802 9.83459 16.2891 10.0765 16.2891C10.1734 16.2891 10.2694 16.2873 10.3654 16.2844L9.86541 13.773C10.0112 13.7923 10.1591 13.8033 10.3099 13.8033C10.4957 13.8033 10.6783 13.7883 10.8559 13.7588L11.9801 19.4091L12.9321 19.1924L12.3108 16.0683C17.848 14.9378 20.6181 9.909 20.6181 9.909ZM6.88084 8.9881L6.22651 5.69889C6.53386 5.57339 6.8575 5.45942 7.19546 5.35982L7.6228 7.50844C7.28066 7.93015 7.02351 8.43381 6.88084 8.9881ZM8.46692 6.74577L8.14503 5.12836C8.45547 5.06785 8.77691 5.01958 9.11002 4.9859L9.3773 6.32923C9.05322 6.42294 8.74741 6.56375 8.46692 6.74577ZM10.3467 6.19713L10.0944 4.93033C10.1472 4.92963 10.1998 4.92845 10.2533 4.92845C10.4858 4.92845 10.713 4.93599 10.9365 4.94941C13.2188 5.33628 14.964 7.44981 14.964 9.99965C14.964 12.1188 13.7579 13.9352 12.0406 14.7106L11.7914 13.4565C13.0153 12.8558 13.8654 11.5342 13.8654 9.99942C13.8652 7.91226 12.2936 6.21856 10.3467 6.19713ZM14.5336 14.0984C15.4349 13.0056 15.9823 11.5718 15.9823 9.99942C15.9823 8.35399 15.3821 6.8595 14.405 5.74928C17.7771 7.16772 19.3574 9.92642 19.3574 9.92642C19.3574 9.92642 17.7491 12.6074 14.5336 14.0984Z"}))}var rg={},YI=wa,XI=ka;Object.defineProperty(rg,"__esModule",{value:!0});var u0=rg.default=void 0,ZI=XI(Mn()),JI=YI(xa()),QI=(0,JI.default)(ZI.createElement("path",{d:"M3 9v6h4l5 5V4L7 9H3zm13.5 3c0-1.77-1.02-3.29-2.5-4.03v8.05c1.48-.73 2.5-2.25 2.5-4.02zM14 3.23v2.06c2.89.86 5 3.54 5 6.71s-2.11 5.85-5 6.71v2.06c4.01-.91 7-4.49 7-8.77s-2.99-7.86-7-8.77z"}),"VolumeUp");u0=rg.default=QI;const tD=t=>{const[e,n]=B.useState((t.languages.filter(s=>s.IsSelected)[0]||t.languages[0]).Code),a=s=>{const l=s.target.value;n(l),t.onClose(l)},i=()=>{t.onClose("")},r=()=>{const s=t.languages.map(l=>wt.createElement("div",{className:"chooserItem",key:l.Code},wt.createElement(lB,{value:l.Code,control:wt.createElement(kB,null),label:l.Name,checked:l.Code===e}),wt.createElement("span",{className:"spacer"}),wt.createElement(u0,{className:"icon",visibility:l.HasAudio?"inherit":"hidden"})));return wt.createElement("div",{className:"radioGroupDiv"},s)};return wt.createElement(Uz,{className:"languageMenu",onClose:i,"aria-labelledby":"language-menu-title",open:!0,scroll:"paper"},wt.createElement(tB,{id:"language-menu-title"},"Languages in this book:"),wt.createElement(rB,{component:"fieldset"},wt.createElement(xB,{className:"radioGroup","aria-label":"languages",name:"languages",value:e,onChange:a},r())),wt.createElement(Zz,null,wt.createElement(Cz,{onClick:i,color:"secondary"},"Close")))};var Go=(t=>(t[t.showArrow=0]="showArrow",t[t.showEllipsis=1]="showEllipsis",t[t.showNothing=2]="showNothing",t))(Go||{});const eD=t=>{const[e,n]=B.useState(!1),a="button"+(t.bookLanguages.length<2?" disabled":""),i=E=>{n(!1),E!==""&&(t.onLanguageChanged(E),s({lang:E}))},r=()=>{try{document.fullscreenElement!=null||document.webkitFullscreenElement!=null?document.exitFullscreen?document.exitFullscreen():document.webkitExitFullScreen&&document.webkitExitFullScreen():document.documentElement.requestFullscreen?document.documentElement.requestFullscreen():document.documentElement.webkitRequestFullscreen&&document.documentElement.webkitRequestFullscreen()}catch(E){console.error("RequestFullScreen failed: ",E)}},s=E=>{if(!t.videoPreviewMode)return;const z={lang:t.activeLanguageCode,imageDescriptions:t.readImageDescriptions,...E};nf("publish/av/videoSettings",encodeURIComponent(JSON.stringify(z)))},l=He.getTranslation("Audio.Pause",t.preferredLanguages,"Pause"),c=t.paused?wt.createElement(tg,{titleAccess:t.playLabel}):wt.createElement(r0,{titleAccess:l}),h=He.getTranslation("Button.ReadImageDescriptions",t.preferredLanguages,"Read Image Descriptions"),m=He.getTranslation("Button.IgnoreImageDescriptions",t.preferredLanguages,"Ignore Image Descriptions"),k=vs({palette:{primary:{main:oI},secondary:{main:e0.palette.secondary.main}}}),w=wt.createElement(Yl,{theme:k},wt.createElement(UI,{"aria-label":t.readImageDescriptions?"Read image descriptions":"Ignore image descriptions",titleAccess:t.readImageDescriptions?m:h,opacity:t.readImageDescriptions?1:.38,color:t.nowReadingImageDescription?"primary":"secondary"})),P=t.extraButtons?t.extraButtons.map(E=>wt.createElement(Aa,{key:E.id,color:"secondary",title:E.description,onClick:()=>qa({messageType:E.id})},wt.createElement("img",{style:{maxHeight:"24px",maxWidth:"24px"},src:E.iconUrl}))):void 0;return wt.createElement(pz,{color:"primary",className:`control-bar ${t.visible?", visible":""}`,id:"control-bar",elevation:0,position:"relative"},wt.createElement(BB,null,!t.videoPreviewMode&&wt.createElement(Aa,{color:"secondary",onClick:()=>{t.backClicked&&t.backClicked()},"data-testid":"history-back-button",disabled:t.getBackButtonState()===2},t.getBackButtonState()===0?wt.createElement(a0,{"aria-label":"Go Back",titleAccess:He.getTranslation("Button.Back",t.preferredLanguages,"Back")}):t.getBackButtonState()===1&&wt.createElement(i0,{"aria-label":"More Menu",titleAccess:He.getTranslation("Button.More",t.preferredLanguages,"More")})),wt.createElement("div",{className:"filler"}),t.bookHasImageDescriptions&&wt.createElement(Aa,{onClick:()=>{t.onReadImageDescriptionToggled(),s({imageDescriptions:!t.readImageDescriptions})}},w),t.bookLanguages.length>1&&wt.createElement(Aa,{className:a,"aria-label":"Choose Language",color:"secondary",onClick:()=>{n(!0)}},wt.createElement(o0,{titleAccess:He.getTranslation("Button.ChooseLanguage",t.preferredLanguages,"Choose Language")})),e&&wt.createElement(tD,{languages:t.bookLanguages,onClose:i}),!t.videoPreviewMode&&wt.createElement(Aa,{color:"secondary","aria-label":"PlayPause",onClick:()=>{t.pausedChanged&&t.pausedChanged(!t.paused)}},t.showPlayPause?c:null),P,document.fullscreenEnabled&&t.canShowFullScreen&&!t.videoPreviewMode&&wt.createElement(Aa,{color:"secondary",onClick:()=>r()},document.fullscreenElement==null?wt.createElement(s0,{"aria-label":"Full Screen",titleAccess:He.getTranslation("Button.FullScreen",t.preferredLanguages,"Full Screen")}):wt.createElement(l0,{"aria-label":"Exit Full Screen",titleAccess:He.getTranslation("Button.ExitFullScreen",t.preferredLanguages,"Exit Full Screen")}))))};function Gd(t,e){return Math.round(t/e)*e}function nD(t){if(!(!t||t==="cover")){if(/^\d+$/.test(t))return t;try{return t.replace(new RegExp("(?![0-9])\\p{Nd}","gu"),e=>{const n=e.charCodeAt(0);return(n&15)-6*(new RegExp("\\p{Nd}","u").test(String.fromCodePoint(n|15))?1:0)})}catch{return}}}let Ud=!1,gh=t=>{};function aD(t){gh&&gh(t)}let yy=0,by=0;function wy(){const t=/iPad|iPhone|iPod/.test(navigator.platform);let e,n,a;t&&(e=document.getElementsByClassName("bloomPlayer")[0],n=e.parentElement,a=e.nextSibling,n.removeChild(e));const i=document.documentElement.clientWidth,r=document.documentElement.clientHeight;return t&&n.insertBefore(e,a),{width:i,height:r}}const iD=t=>{const[e,n]=B.useState(t.autoplay),a=t.centerVertically===void 0?!0:t.centerVertically;_T(ut=>{ut.pause?(Ud=!j,f(!0)):ut.resume&&Ud?f(!1):ut.play?(f(!1),ut.autoplay&&n(ut.autoplay)):ut.reset?(m(t.startPage??0),Qe.current&&Qe.current(t.startPage??0)):ut.controlAction&&mt(ut.controlAction)});const[i,r]=B.useState(!1),[s,l]=B.useState(t.initiallyShowAppBar),[,c]=B.useState(0);B.useEffect(()=>{const ut=()=>{l(!0),c(Ut=>Ut+1)};return ph.subscribe(ut),()=>{ph.unsubscribe(ut)}},[]);const[h,m]=B.useState(t.startPage??0),[k,w]=B.useState([""]),[P,E]=B.useState(!1),[z,A]=B.useState(!1),[x,S]=B.useState(""),[N,L]=B.useState("Device16x9Portrait");B.useEffect(()=>{l(t.initiallyShowAppBar)},[t.initiallyShowAppBar]),B.useEffect(()=>{s?HT():FT()},[s]),B.useEffect(()=>{f(t.paused)},[t.paused]);const[j,f]=B.useState(t.paused),[U,_]=B.useState(!1),F=He.getBloomUiLanguage(),gt=F==="en"?[F]:[F,"en"],[dt,ot]=B.useState(gt);B.useEffect(()=>{j||(Ud=!1)},[j]);const[X,$]=B.useState(!1),[o,tt]=B.useState(!1),[v,Q]=B.useState(!1),[st,ft]=B.useState(!1),[D,lt]=B.useState(!1),[pt,Ct]=B.useState(0),[St,Dt]=B.useState(9/16),Ht=[],[Vt,Gt]=B.useState(Ht),[Se,dn]=B.useState(""),Qe=B.useRef(),[be,me]=B.useState(!0),[Ue,Tt]=B.useState(!1),[Ce,$n]=B.useState(!1),[We,T]=B.useState(0),I=()=>{T(ut=>ut+1)},[W,Z]=B.useState("");B.useEffect(()=>{Ft()},[D,We,X,t.useOriginalPageSize]),B.useEffect(()=>()=>{const ut=document.getElementById("scale-style-sheet");ut&&ut.parentNode.removeChild(ut)},[]);const nt=B.useRef(),mt=ut=>{switch(ut){case"navigate-to-next-page":nt&&nt.current&&nt.current.slideNext();break;case"navigate-to-previous-page":nt&&nt.current&&nt.current.slidePrevious();break;default:console.log("'handleControlMessage' received an unknown message.");return}},Ft=()=>{const ut=document.getElementsByClassName("swiper-slide-active")[0];let Ut=null;if(ut&&(Ut=ut.getElementsByClassName("bloom-page")[0]),!Ut||!D){window.setTimeout(I,100);return}let qe=document.getElementById("scale-style-sheet");qe||(qe=document.createElement("style"),qe.setAttribute("type","text/css"),qe.setAttribute("id","scale-style-sheet"),document.head.appendChild(qe));let Jt=pt,te=St;const Et=Te.getPageSizeClass(Ut);(t.url!==x||Et!==N)&&(S(t.url),L(Et),window.onresize=()=>{const{width:da,height:Pa}=wy();(Pa!==by||da!==yy)&&I()},Jt=Math.max(Ut.offsetHeight,Ut.offsetWidth),te=Math.min(Ut.offsetHeight,Ut.offsetWidth)/Jt,Dt(te),Ct(Jt));const{width:Lt,height:Qt}=wy();yy=Lt,by=Qt;const we=Lt>Qt;if(we!==X){$(we);return}let fe=0,xn=0;const re=window.getComputedStyle(document.body);re&&re.marginTop&&(fe=parseInt(re.marginTop,10)),re&&re.marginBottom&&(xn=parseInt(re.marginBottom,10));const Fa=Ut.getAttribute("class").indexOf("Landscape")>=0,fn=Fa?Jt*te:Jt,ca=Fa?Jt:Jt*te;let Yn=fe+xn;if(s){const da=document.getElementById("control-bar");da&&(Yn+=da.offsetHeight);const Pa=document.getElementById("pageNumberControl");Pa&&(Yn+=Pa.offsetHeight)}const li=Qt-Yn,yr=se({pageWidth:ca,pageHeight:fn,desiredPageHeight:li}),Wa=le(ca);let de=Math.min(yr,Wa);const Ta=fn*de;let ui=Ta*te/de;Fa&&(ui=Ta/te/de);const Xn=Lt/de-ui;let Ea="",_a=Math.max((Lt-ca*de)/2,0);t.roundMarginToNearestK&&(_a=Gd(_a,t.roundMarginToNearestK));const ho=_a,cc=de,Fs=30;if(Xn>100*2)Ea="largeOutsideButtons";else if(Xn>Fs*2)Ea="smallOutsideButtons";else if(Lt>407&&navigator.userAgent.includes("Chrome")&&!t.hideSwiperButtons){const Pa=new RegExp(" Chrome/([0-9]+).").exec(navigator.userAgent),po=parseInt(Pa[1]);po&&po<90&&(de*=.9,_a=Math.max((Lt-ca*de)/2,0),Ea="smallOutsideButtons extraScalingForChrome85Bug")}Ea!==W&&Z(Ea);let br="";if(a){const da=(Qt-Ta-Yn)/2;da>0&&(br=`translate(0, ${da.toFixed(0)}px) `)}qe.innerText=`.bloomPlayer {
8047
+ `,"").replace("\r","")}const uc=[];function OB(){return uc.length>0}function KB(t){const e=uc.pop();if(e)return{bookUrl:t===e.bookId?void 0:hh(e.bookId),pageId:e.pageId}}function $B(t,e,n){const a=t.target.closest("[href], [data-href]");if(!a)return;t.preventDefault(),t.stopPropagation();const i=(a.getAttribute("href")||a.getAttribute("data-href"))??void 0;if(!i)return;if(i.startsWith("http://")||i.startsWith("https://")){window.open(i,"_blank","noreferrer");return}let r,s;if(i==="back"){const c=uc.pop();return c?{bookUrl:e===c.bookId?void 0:hh(c.bookId),pageId:c.pageId}:void 0}else if(i.startsWith("/book/")){const c=qB(i);r=c.bookId,s=c.pageId,c.bookId===e&&(r=void 0)}else i.startsWith("#")&&(s=i.substring(1));const l=n();if(r)return fy(e,l),{bookUrl:hh(r),pageId:s};if(s)return fy(e,l),{pageId:s}}function fy(t,e,n){uc.push({bookId:t,pageId:e})}function hh(t){return`/book/${t}/index.htm`}function qB(t){try{const e=new URL(t,window.location.origin);if(!e.pathname.startsWith("/book/"))throw new Error("Invalid book URL format");const n=e.pathname.replace("/book/",""),a=e.hash.replace("#","");return{bookId:n,pageId:a}}catch(e){return console.error("Error parsing book URL:",e),{bookId:void 0,pageId:void 0}}}const HB="bloom-player",FB="A library for displaying Bloom books in iframes or WebViews",WB="SIL Global",_B="MIT",VB="2.19.7-alpha.1",GB=!1,UB={type:"git",url:"git+https://github.com/BloomBooks/bloom-player.git"},YB="module",XB="lib/shared.es.js",ZB="lib/index.d.ts",JB={".":{types:"./lib/index.d.ts",import:"./lib/shared.es.js",default:"./lib/shared.es.js"}},QB={"// COMMENTS: make the action a space rather than empty string so `yarn run` can list the scripts":" ","//":" ","// 'yarn dev' will build, watch, start a server, and open the player in a brower":" ","// You can edit index-for-developing.html to point to different books":" ","// Or just use 'yarn storybook' and skip this dev approach entirely":" ",dev:"vite","build:standalone":"vite build","build:sharedlib":"vite build --mode lib",test:"vitest","// blame.ignoreRevsFile - This allows blame to see through commits that are only there to format code.":" ",prepare:"husky install && git config blame.ignoreRevsFile .git-blame-ignore-revs",storybook:"storybook dev -p 6006","// run this when working with stories that use an iframe and bloomplayer.htm instead of the raw react components":" ",watchForStorybook:"yarn vite build --watch --mode development","strings:download":"crowdin download --config src/l10n/crowdin.yml && yarn strings:compile","strings:upload":"crowdin upload --config src/l10n/crowdin.yml","strings:compile":"yarn tsx ./src/l10n/compileL10Strings.ts","strings:sync":"yarn strings:upload && yarn strings:download"},tI={"@material-ui/core":"^4.12.3","@material-ui/icons":"^4.11.2",axios:"^0.18.0","compare-versions":"^6.1.1","dynamic-import-polyfill":"^0.1.1","jquery.nicescroll":"^3.7.6",react:"^17.0.2","react-dom":"^17.0.2","react-id-swiper":"2.3.2","style-scoped":"^0.2.1",swiper:"^4.5.0"},eI={"@crowdin/cli":"^4.13.0","@storybook/addon-essentials":"8.4.6","@storybook/addon-interactions":"^8.4.6","@storybook/addon-links":"8.4.6","@storybook/blocks":"8.4.6","@storybook/react":"8.4.6","@storybook/react-vite":"8.4.6","@storybook/test":"8.4.6","@types/jquery":"^3.5.5","@types/jquery.nicescroll":"^3.7.1","@types/node":"^22.7.6","@types/react":"^17.0.2","@types/react-dom":"^17.0.2",editorconfig:"^2.0.0",eslint:"^9.12.0","eslint-plugin-storybook":"^0.11.1",glob:"^10",husky:"8.0.3",jsdom:"^25.0.1",less:"^4.2.0",prettier:"^3.3.3",storybook:"8.4.6",tsx:"^4.19.1",typescript:"*",vite:"^5.4.9","vite-plugin-dts":"^4.5.3","vite-plugin-html":"^3.2.2","vite-plugin-static-copy":"^2.0.0",vitest:"^2.1.3"},nI=["dist/*.js","dist/bloomplayer.htm","dist/*.mp3","lib/*.js","lib/*.d.ts","lib/*.js.map","src/shared/event.ts","src/shared/narration.ts","src/shared/dragActivityRuntime.ts","src/shared/scrolling.ts","src/shared/index.ts","dist/*.css","dist/*.tsv"],aI={node:"24.13.0",yarn:"1.22.19"},iI={name:HB,description:FB,author:WB,license:_B,version:VB,private:!1,"// sideeffects might need to be ['*.css'] to avoid 'shaking' our CSS, if we ever get tree shaking working":"",sideEffects:GB,repository:UB,type:YB,module:XB,types:ZB,exports:JB,scripts:QB,dependencies:tI,devDependencies:eI,"// The four src/ files are directly exported so BloomDesktop can consume them as shared code.":"",files:nI,volta:aI},vi="#d65649",rI="#2e2e2e",oI="#febf00",e0=vs({palette:{primary:{main:rI,contrastText:vi},secondary:{main:vi}}});function n0(){var t=iI.version;return t}const sI=({getBookInstanceId:t})=>{const[e,n]=B.useState(!1),a=n0(),i=new Date("2026-04-20T16:13:45.557Z").toLocaleDateString();if(B.useEffect(()=>{const s=c=>{c.key==="Control"&&n(!0)},l=c=>{c.key==="Control"&&n(!1)};return window.addEventListener("keydown",s),window.addEventListener("keyup",l),()=>{window.removeEventListener("keydown",s),window.removeEventListener("keyup",l)}},[]),!e)return null;const r=t==null?void 0:t();return wt.createElement("div",{className:"diagnostic-info-control",style:{color:vi,fontFamily:"sans-serif",padding:"5px",zIndex:1e3,lineHeight:"1.5"}},wt.createElement("div",null,"Bloom Player v",a," (built ",i,")"),wt.createElement("div",null,"Book ID: ",r??""))},lI=/^[v^~<>=]*?(\d+)(?:\.([x*]|\d+)(?:\.([x*]|\d+)(?:\.([x*]|\d+))?(?:-([\da-z\-]+(?:\.[\da-z\-]+)*))?(?:\+[\da-z\-]+(?:\.[\da-z\-]+)*)?)?)?$/i,hy=t=>{if(typeof t!="string")throw new TypeError("Invalid argument expected string");const e=t.match(lI);if(!e)throw new Error(`Invalid argument not valid semver ('${t}' received)`);return e.shift(),e},py=t=>t==="*"||t==="x"||t==="X",gy=t=>{const e=parseInt(t,10);return isNaN(e)?t:e},uI=(t,e)=>typeof t!=typeof e?[String(t),String(e)]:[t,e],cI=(t,e)=>{if(py(t)||py(e))return 0;const[n,a]=uI(gy(t),gy(e));return n>a?1:n<a?-1:0},my=(t,e)=>{for(let n=0;n<Math.max(t.length,e.length);n++){const a=cI(t[n]||"0",e[n]||"0");if(a!==0)return a}return 0},vy=(t,e)=>{const n=hy(t),a=hy(e),i=n.pop(),r=a.pop(),s=my(n,a);return s!==0?s:i&&r?my(i.split("."),r.split(".")):i||r?i?-1:1:0},ph=new ur;class Te extends B.Component{constructor(e,n){super(e,n),this.activityManager=new oz,this.initialPages=["loading..."],this.initialStyleRules="",this.originalPageClass="Device16x9Portrait",this.bookInfo=new fh,this.bookInteraction=new IB,this.mustUseOriginalPageSize=!1,this.indicesOfPagesWhereWeShouldPreserveDOMState={},this.startingUpSwiper=!0,this.state={pages:this.initialPages,pageIdToIndexMap:{},styleRules:this.initialStyleRules,importedBodyAttributes:{},currentSwiperIndex:0,isLoading:!0,loadFailed:!1,loadErrorHtml:"",ignorePhonyClick:!1,isFinishUpForNewBookComplete:!1,inPauseForced:!1,bookUrl:""},this.isPagesLocalized=!1,this.currentPageHidesNavigationButtons=!1,this.handleDocumentLevelKeyDown=i=>{i.key==="Home"&&(this.goToFirstPage(),i.preventDefault()),i.key==="End"&&(this.goToLastPage(),i.preventDefault())},this.distributionSource="",this.finishUpCalled=!1,this.hasImageDescriptions=!1,this.handlePageVideoComplete=i=>{i.page===Te.currentPage&&this.playAudioAndAnimation(i.page)},this.handlePlayFailed=()=>{this.setState({inPauseForced:!0}),this.props.setForcedPausedCallback&&this.props.setForcedPausedCallback(!0)},this.handlePlayCompleted=()=>{Tn(Ge.MediaFinished),this.props.imageDescriptionCallback(!1)},this.handleToggleImageDescription=i=>{this.props.imageDescriptionCallback(i)},this.handlePageNarrationComplete=i=>{if(i&&(Tn(Ge.MediaFinished),this.shouldAutoPlay())){const r=this.props.autoplayCount??0,s=this.state.startPageIndex??0,l=this.swiperInstance.slides.length-1;let c=this.props.autoplayCount?Math.min(s+r-1,l):l;this.swiperInstance.activeIndex>=c?(this.music.pause(),this.props.shouldReportSoundLog&&QC(),ZC(),KT({})):this.swiperInstance.slideNext()}},this.skipAutoPlay=!1,this.sentBloomNotification=!1;const a=e.url.startsWith("http")?new URL(e.url):new URL(e.url,window.location.origin);a.hash?(this.state.startPageId=a.hash.substring(1),a.hash=""):this.state.startPageIndex=e.startPageIndex,this.state.bookUrl=a.href,Te.currentPagePlayer=this,this.legacyQuestionHandler=new lz(e.locationOfDistFolder)}componentDidMount(){He.setUp(),window.addEventListener("focus",()=>this.handleWindowFocus()),window.addEventListener("blur",()=>this.handleWindowBlur()),document.addEventListener("keydown",e=>this.handleDocumentLevelKeyDown(e)),document.addEventListener("pointerdown",e=>{(e.target.closest("[href], [data-href]")||e.target.closest(".bloom-videoContainer")&&!e.target.closest("[data-draggable-id]"))&&(e.stopPropagation(),e.preventDefault())},{capture:!0}),document.addEventListener("dragstart",e=>{this.activityManager.getActivityAbsorbsDragging()||e.preventDefault()},{capture:!0}),this.componentDidUpdate(this.props,this.state)}CanGoBack(){return OB()}HandleBackButtonClickedIfHavePlayerHistory(){const e=this.getBookIdFromBookUrlForHistory(this.state.bookUrl)||this.bookInfo.bookInstanceId,n=KB(e);return n?(this.navigate(n.bookUrl,n.pageId),!0):!1}navigate(e,n){if(e){const a=new URL(e,this.state.bookUrl);this.setState({bookUrl:a.href,startPageId:n,startPageIndex:void 0})}else if(n!==void 0){const a=this.state.pageIdToIndexMap[n];this.swiperInstance.slideTo(a)}}getBookIdFromBookUrlForHistory(e){if(e)try{const a=new URL(e,window.location.href).pathname.match(/^\/book\/([^/]+)\/index\.htm$/i);return a?a[1]:void 0}catch{return}}handleWindowFocus(){const e=localStorage.getItem(_l),n=localStorage.getItem(om);e&&n==this.sourceUrl&&(this.bookInteraction.beginReadTime=Date.now()-parseInt(e,10))}handleWindowBlur(){const e=Date.now()-this.bookInteraction.beginReadTime;localStorage.setItem(_l,e.toString()),localStorage.setItem(om,this.sourceUrl)}getRequiredVersionMessage(e){var c;const n=(c=e.querySelector('meta[name="FeatureRequirement"]'))==null?void 0:c.getAttribute("content");if(!n)return"";const a=/BloomPlayerMinVersion":"(.*?)".*?"FeatureId":"(.*?)"/g;let i,r=null,s=null;for(;(i=a.exec(n))!==null;){const h=i[1];(!r||vy(h,r)>0)&&(r=h,s=i[2])}if(!r||!s)return"";const l=n0();if(vy(l,r)>=0)return"";if(window.location.hostname.toLowerCase().indexOf("bloomlibrary.org")>=0)return He.getTranslation("Version.Problem.Web",this.props.preferredUiLanguages,"This book uses the feature {feature}. Unfortunately, {hostname} is not ready to display this book yet. Please check back again later or write to issues@bloomlibrary.org if you think this is unexpected.").replace("{feature}",s).replace("{hostname}",window.location.hostname);{let h=ma("host","");switch(h){case"bloomreader":h="Bloom Reader";break;case"bloompubviewer":h="BloomPUB Viewer";break;case"readerapp":h="";break}return h?He.getTranslation("Version.Problem.Host",this.props.preferredUiLanguages,"This book uses the feature {feature} and requires a newer version of {host} to read it. Please upgrade to the latest version.").replace("{feature}",s).replace("{host}",h):He.getTranslation("Version.Problem.NoHost",this.props.preferredUiLanguages,"This book uses the feature {feature} and requires a newer version of the program you are using to read it. Please upgrade to the latest version.").replace("{feature}",s)}}componentDidUpdate(e,n){var a;try{if(!this.props.url||this.state.loadFailed&&n.bookUrl===this.state.bookUrl)return;this.initializeMedia();const i=this.preprocessUrl();if(i&&i!=="/working"&&i!==this.sourceUrl){this.finishUpCalled=!1,this.setState({isLoading:!0,loadFailed:!1}),this.metaDataObject=void 0,this.htmlElement=void 0,this.sourceUrl=i;const r=this.sourceUrl.lastIndexOf("/"),s=this.sourceUrl.lastIndexOf("%2f");let l;r>s?l=this.sourceUrl.substring(r+1,this.sourceUrl.length):l=this.sourceUrl.substring(s+3,this.sourceUrl.length);const c=l.endsWith(".htm"),h=c?this.sourceUrl:this.sourceUrl+"/"+l+".htm";this.urlPrefix=c?this.sourceUrl.substring(0,Math.max(r,s)):this.sourceUrl,this.music.urlPrefix=this.urlPrefix,yC(this.music.urlPrefix);const m=ni.get(this.fullUrl(".distribution")).then(P=>P,P=>({data:""})),k=ni.get(h),w=ni.get(this.fullUrl("meta.json"));Promise.all([k,w,m]).then(P=>{const[E,z,A]=P;this.metaDataObject=z==null?void 0:z.data,this.distributionSource=A.data;const S=new DOMParser().parseFromString(E==null?void 0:E.data,"text/html"),N=S.documentElement,L=this.getRequiredVersionMessage(S);this.setState({requiredVersion:L});const j=N.getElementsByTagName("body")[0];this.mustUseOriginalPageSize=this.computeMustUseOriginalPageSize(j),this.bookInfo.setSomeBookInfoFromBody(j),this.localizeOnce(),this.props.shouldReportSoundLog&&(this.videoList=this.getVideoList(S)),this.animation.PlayAnimations=this.bookInfo.playAnimations,this.collectBodyAttributes(j),this.makeNonEditable(j),this.htmlElement=N;const f=N.getElementsByClassName("bloom-page")[0];this.originalPageClass="Device16x9Portrait",f&&(this.originalPageClass=Te.getPageSizeClass(f)),this.legacyQuestionHandler.generateQuizPagesFromLegacyJSON(this.urlPrefix,j,this.originalPageClass,()=>{this.finishUp()})}).catch(P=>this.HandleLoadingError(P))}else if(e.landscape!==this.props.landscape||e.useOriginalPageSize!==this.props.useOriginalPageSize||e.autoplay!==this.props.autoplay){const r=document.getElementsByClassName("bloom-page");for(let s=0;s<r.length;s++){const l=r[s];this.setPageSizeClass(l)}}!this.state.isLoading&&(n.isLoading||e.activeLanguageCode!==this.props.activeLanguageCode)&&(this.updateDivVisibilityByLangCode(n.isLoading),this.updateOverlayPositionsByLangCode(),this.finishUpCalled&&this.finishUp(!1)),this.state.currentSwiperIndex!=n.currentSwiperIndex&&((a=this.rootDiv)==null||a.querySelectorAll(Xp).forEach(r=>{const s=Is(r).getNiceScroll();s&&s.length>0&&s.remove()})),!this.state.isLoading&&(n.isLoading||e.shouldReadImageDescriptions!==this.props.shouldReadImageDescriptions)&&this.finishUpCalled&&(this.setIndex(this.state.currentSwiperIndex),this.showingPage(this.state.currentSwiperIndex)),this.state.isFinishUpForNewBookComplete&&e.landscape!==this.props.landscape&&(this.setIndex(this.state.currentSwiperIndex),this.showingPage(this.state.currentSwiperIndex)),e.paused!==this.props.paused&&this.handlePausePlay(),this.swiperInstance&&this.swiperInstance.lazy.load()}catch(i){this.setState({isLoading:!1,loadFailed:!0,loadErrorHtml:i.message})}}collectBodyAttributes(e){for(var n={},a=0;a<e.attributes.length;a++)n[e.attributes.item(a).nodeName]=e.attributes.item(a).nodeValue;this.setState({importedBodyAttributes:n})}HandleLoadingError(e){var r;let a=`<p>There was a problem displaying this book: ${e.message}<p>`;const i=!!((r=e.config)!=null&&r.url)&&new URL(e.config.url,window.location.href).pathname.startsWith("/book/");i?a="<p>We could not find that book.</p>":(e.config&&e.config.url&&e.config.url.startsWith("file://")||e.message.indexOf("404")>=0)&&(a="<p>This book (or some part of it) was not found.<p>",e.config&&e.config.url&&(a+=`<p class='errorDetails'>${dI(e.config.url)}</p>`)),this.setState({isLoading:!1,loadFailed:!0,loadErrorHtml:a}),i&&ph.raise()}async finishUp(e=!0){if(this.finishUpCalled=!0,!this.htmlElement)return;Xo.setAllVideoPostersTo1x1TransparentPNG(this.htmlElement);const n=this.htmlElement.getElementsByClassName("bloom-page"),a=[];e&&(this.bookInfo.totalNumberedPages=0,this.bookInfo.questionCount=0,this.activityManager.collectActivityContextForBook(n),this.bookInteraction.clearPagesShown(),this.music.processAllMusicForBook(n));const i=this.bookInfo.getPreferredTranslationLanguages(),r=i[0]===this.props.activeLanguageCode||!this.props.activeLanguageCode,s={},l=h=>h.classList.contains("bloom-interactive-page")||h.classList.contains("simple-comprehension-quiz")||h.getAttribute("data-activity")=="iframe"||h.getElementsByClassName("questions").length>0;s.length=0,s.cover=0;for(let h=0;h<n.length;h++){const m=n[h],k=m.getAttribute("id");k&&(s[k]=h);const w=this.setPageSizeClass(m);m.setAttribute("data-index",h.toString(10)),h===0&&this.props.reportBookProperties&&this.props.reportBookProperties({landscape:w,canRotate:this.bookInfo.canRotate,preferredLanguages:i,pageNumbers:Array.from(n).map(E=>E.getAttribute("data-page-number")??""),isRtl:this.metaDataObject.isRtl,internalUrl:this.state.bookUrl}),e&&(this.fixRelativeUrls(m),m.classList.contains("numberedPage")&&(this.indexOflastNumberedPage=h,this.bookInfo.totalNumberedPages++),(m.getAttribute("data-analyticscategories")||m.getAttribute("data-analyticsCategories"))==="comprehension"&&this.bookInfo.questionCount++),this.showOrHideL1OnlyText(m,r);const P=l(m);P&&this.activityManager.initializePageHtml(this.urlPrefix,m,a.length),(!this.props.skipActivities||!P)&&a.push(m.outerHTML)}if(e){const h=this.htmlElement.getElementsByTagName("head")[0];this.bookInfo.setSomeBookInfoFromHead(h);const m=this.htmlElement.getElementsByTagName("body")[0];if(this.metaDataObject&&(this.bookInfo.setSomeBookInfoFromMetadata(this.metaDataObject,m),this.reportBookOpened(m)),this.props.controlsCallback){const k=gs.createLangDataArrayFromDomAndMetadata(m,this.metaDataObject);this.hasImageDescriptions=fI(m),this.props.controlsCallback(k,this.hasImageDescriptions,w=>{var P;(P=this.swiperInstance)==null||P.slideTo(w)})}}if(e){var c;try{c=await DB(this.htmlElement,this.urlPrefix,this.bookInfo,()=>this.legacyQuestionHandler.getPromiseForAnyQuizCss())}catch(h){this.HandleLoadingError(h),c=""}if(this.startingUpSwiper=!0,this.state.startPageId){if(s[this.state.startPageId]===void 0)throw new Error(`Page ID ${this.state.startPageId} not found in the current pageIdToIndexMap`);this.setState({startPageIndex:s[this.state.startPageId]})}this.setState({pages:a,pageIdToIndexMap:s,styleRules:c,isLoading:!1,currentSwiperIndex:this.state.startPageIndex??0})}else this.setState({pages:a,isLoading:!1});this.props.pageStylesAreNowInstalled(),e?window.setTimeout(()=>{this.setState({isFinishUpForNewBookComplete:!0});const h=this.startingUpSwiper;this.startingUpSwiper=!1;var m=this.state.startPageIndex??0;this.setIndex(m),this.showingPage(m),h&&this.addScrollbarsToPageWhenReady(this.swiperInstance.activeIndex);const k=document.getElementsByClassName("swiper-button-next")[0],w=document.getElementsByClassName("swiper-button-prev")[0];w==null||w.setAttribute("tabindex","4"),k==null||k.setAttribute("tabindex","5"),this.shouldFocusNextButtonForNewBook()&&(k==null||k.focus())},500):Te.currentPage&&window.setTimeout(()=>{this.setIndex(Te.currentPageIndex),this.showingPage(Te.currentPageIndex)},200)}shouldFocusNextButtonForNewBook(){return window.self===window.top||document.referrer.startsWith("http://localhost:")?!0:document.referrer.includes("bloomlibrary.org/player/")}showOrHideL1OnlyText(e,n){e.querySelectorAll(".coverBottomBookTopic, .coverBottomLangName").forEach(a=>{n||a.classList.contains("bloom-content1")?a.classList.remove("do-not-display"):a.classList.add("do-not-display")})}localizeOnce(){!this.isPagesLocalized&&this.state.pages!==this.initialPages&&this.state.styleRules!==this.initialStyleRules&&(He.localizePages(document.body,this.bookInfo.getPreferredTranslationLanguages()),this.isPagesLocalized=!0)}initializeMedia(){this.video||(this.video=new Xo,this.video.PageVideoComplete=new ur,this.video.PageVideoComplete.subscribe(this.handlePageVideoComplete)),this.animation||(this.animation=new Kl),na.subscribe(this.handlePageNarrationComplete),Ar.subscribe(this.handlePlayFailed),Qa.subscribe(this.handlePlayCompleted),gC(this.storeAudioAnalytics.bind(this)),za.subscribe(this.handleToggleImageDescription.bind(this)),mC(()=>{var e;return(e=this.swiperInstance)==null?void 0:e.animating}),vC(e=>eb(e,1)),this.music||(this.music=new tT,this.music.PlayFailed=new ur,this.music.PlayFailed.subscribe(()=>{this.setState({inPauseForced:!0}),this.props.setForcedPausedCallback&&this.props.setForcedPausedCallback(!0)}))}preprocessUrl(){let e=this.state.bookUrl;if(e===void 0||e.trim()==="")throw new Error("The url parameter was empty. It should point to the url of a book.");return e.endsWith("/")&&(e=e.substring(0,e.length-1)),e.endsWith("%2f")&&(e=e.substring(0,e.length-3)),e}handlePausePlay(){this.props.paused?this.pauseAllMultimedia():Te.currentPage!==$y()||mn===Ge.MediaFinished?this.resetForNewPageAndPlay(Te.currentPage):mn===Ge.VideoPaused?this.video.play():(WC(),this.animation.resumeAnimation(),this.music.play())}getAllBloomCanvasElementsOnPage(){var a,i;const e=(a=this.htmlElement)==null?void 0:a.ownerDocument.getElementsByClassName("bloom-canvas");if(e&&e.length>0)return Array.from(e);const n=(i=this.htmlElement)==null?void 0:i.ownerDocument.getElementsByClassName("bloom-imageContainer");return n?Array.from(n).filter(r=>r.parentElement.closest(".bloom-imageContainer")===null):[]}computeMustUseOriginalPageSize(e){return this.props.useOriginalPageSize||e.querySelector(".bloom-canvas-element")?!0:!!e.querySelector(".bloom-textOverPicture")}updateOverlayPositionsByLangCode(){if(!(!this.props.activeLanguageCode||!this.htmlElement))try{const e=this.props.activeLanguageCode;this.getAllBloomCanvasElementsOnPage().forEach(n=>{Array.from(n.querySelectorAll(Bs)).forEach(i=>{const r=Array.from(i.getElementsByClassName("bloom-editable")).find(s=>s.getAttribute("lang")===e);if(r){const s=r.getAttribute("data-bubble-alternate");if(s){const l=JSON.parse(s.replace(/`/g,'"'));i.setAttribute("style",l.style)}}});const a=Array.from(n.getElementsByClassName("comical-alternate")).find(i=>i.getAttribute("data-lang")===e);if(a){const i=n.getElementsByClassName("comical-generated")[0];i&&(i.classList.remove("comical-generated"),i.classList.add("comical-alternate"),i.style.display="none"),a.classList.remove("comical-alternate"),a.classList.add("comical-generated"),a.style.removeProperty("display")}})}catch(e){console.error(e)}}updateDivVisibilityByLangCode(e){if(!this.props.activeLanguageCode||!this.htmlElement)return;const a=this.bookInfo.getPreferredTranslationLanguages()[0]===this.props.activeLanguageCode||!this.props.activeLanguageCode,i=this.props.activeLanguageCode,r=this.htmlElement.ownerDocument.evaluate(".//div[contains(@class, 'bloom-translationGroup')]",this.htmlElement,null,XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE,null),s="bloom-visibility-code-on";for(let l=0;l<r.snapshotLength;l++){const c=r.snapshotItem(l),h=c.getAttribute("data-default-languages"),m=h?h.split(/,| /):[],k=m==null||m.length===0||!m[0]||m.includes("V")||m.includes("L1")||Te.areStringsEqualInvariantCultureIgnoreCase(m[0],"auto"),w=c.childNodes;for(let P=0;P<w.length;P++){const E=w.item(P);!E||!E.classList||!E.classList.contains("bloom-editable")||(e&&E.setAttribute("data-original-class",E.getAttribute("class")||""),a?E.setAttribute("class",E.getAttribute("data-original-class")||""):k&&(E.getAttribute("lang")===i?(E.classList.add(s),Array.from(E.classList).forEach(A=>{A.startsWith("bloom-content")&&E.classList.remove(A)}),E.classList.add("bloom-content1"),E.classList.add("bloom-contentFirst")):E.classList.remove(s)))}}}static areStringsEqualInvariantCultureIgnoreCase(e,n){return e.localeCompare(n,"en-US",{sensitivity:"accent"})===0}static isDivInL2(e){return e.classList.contains("bloom-contentNational1")}static isDivInL3(e){return e.classList.contains("bloom-contentNational2")}componentWillUnmount(){this.pauseAllMultimedia(),document.removeEventListener("keydown",e=>this.handleDocumentLevelKeyDown(e)),this.unsubscribeAllEvents()}unsubscribeAllEvents(){this.video.PageVideoComplete.unsubscribe(this.handlePageVideoComplete),na.unsubscribe(this.handlePageNarrationComplete),Ar.unsubscribe(this.handlePlayFailed),Qa.unsubscribe(this.handlePlayCompleted),za.unsubscribe(this.handleToggleImageDescription)}pauseAllMultimedia(){mn===Ge.VideoPlaying?this.video.pause():mn===Ge.AudioPlaying&&(_C(),this.animation.PauseAnimation()),this.music.pause()}reportBookOpened(e){const n=this.bookInfo.getAmbientAnalyticsProps();this.distributionSource&&(n.distributionSource=this.distributionSource),RT(n),ab("BookOrShelf opened",{})}sendUpdateOfBookProgressReportToExternalContext(){const e=this.bookInteraction.getProgressReportPropertiesForAnalytics();$T("Pages Read",e)}makeNonEditable(e){const n=e.ownerDocument.evaluate(".//*[@contenteditable]",e,null,XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE,null);for(let a=0;a<n.snapshotLength;a++)n.snapshotItem(a).removeAttribute("contenteditable")}setPageSizeClass(e){return Te.setPageSizeClass(e,this.bookInfo.canRotate,this.props.landscape,this.mustUseOriginalPageSize,this.originalPageClass)}static getPageSizeClass(e){const a=(e.getAttribute("class")||"").match(/\b\S*?(Portrait|Landscape)\b/);return a&&a.length?a[0]:""}static setPageSizeClass(e,n,a,i,r){let s=!1;const l=this.getPageSizeClass(e);if(l){s=n?a:l.endsWith("Landscape");let c="";i?c=s?r.replace("Portrait","Landscape"):r.replace("Landscape","Portrait"):c=s?"Device16x9Landscape":"Device16x9Portrait",l!==c&&(e.classList.remove(l),e.classList.add(c))}return s}goToFirstPage(){this.swiperInstance.slideTo(0)}goToLastPage(){this.swiperInstance.slideTo(99999)}fixRelativeUrls(e){const n=e.ownerDocument.evaluate(".//*[@src]",e,null,XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE,null);for(let r=0;r<n.snapshotLength;r++){const s=n.snapshotItem(r);if(!s)continue;const l=s.getAttribute("src"),c=this.fullUrl(l);s.setAttribute("src",c)}const a=e.ownerDocument.evaluate(".//*[@style]",e,null,XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE,null),i=new RegExp(/background-image:url\(['"](.*)['"]\)/);for(let r=0;r<a.snapshotLength;r++){const s=a.snapshotItem(r);if(!s)continue;const l=s.getAttribute("style")||"",c=i.exec(l);if(!c)continue;const h=this.fullUrl(c[1]),m=l.replace(i,"");s.setAttribute("style",m),s.setAttribute("data-background",h),s.classList.add("swiper-lazy")}}fullUrl(e){return this.urlPrefix+"/"+e}getRootDiv(){return this.rootDiv}slideNext(){this.swiperInstance&&this.swiperInstance.slideNext()}slidePrevious(){this.swiperInstance&&this.swiperInstance.slidePrev()}getBookInstanceId(){return this.bookInfo.bookInstanceId}getPlayerOptionsForPage(e){if(!e)return;let n=e.getAttribute("data-player-options");if(n)try{return n=n.replace(/'/g,'"'),JSON.parse(n)}catch(a){console.log("getPlayerOptionsForPage failed to parse json: "+n+" with error "+a.message);return}}render(){var i;const e=this.activityManager.getActivityAbsorbsDragging();if(this.state.isLoading)return B.createElement(Nz,{className:"loadingSpinner",color:"secondary"});if(this.state.loadFailed)return B.createElement(B.Fragment,null,B.createElement(bk,{className:"loadFailedIcon",color:"secondary"}),B.createElement("div",{className:"loadErrorMessage",dangerouslySetInnerHTML:{__html:this.state.loadErrorHtml}}));if(this.state.requiredVersion)return B.createElement("div",{className:"requiredVersionMessage"},this.state.requiredVersion);CC(this.props.shouldReadImageDescriptions&&this.hasImageDescriptions);const n={getSwiper:r=>{var s,l;this.swiperInstance=r,(s=this.metaDataObject)!=null&&s.isRtl&&this.swiperInstance&&((l=this.swiperInstance.el)==null||l.setAttribute("dir","rtl"),this.swiperInstance.rtl=!0,this.swiperInstance.rtlTranslate=!0)},simulateTouch:!0,touchStartPreventDefault:!1,on:{slideChange:()=>{this.state.inPauseForced&&this.props.setForcedPausedCallback&&this.props.setForcedPausedCallback(!1),this.setState({inPauseForced:!1}),this.startingUpSwiper||this.showingPage(this.swiperInstance.activeIndex)},slideChangeTransitionStart:()=>{this.startingUpSwiper||this.setIndex(this.swiperInstance.activeIndex)},slideChangeTransitionEnd:()=>{this.addScrollbarsToPageWhenReady(this.swiperInstance.activeIndex)}},keyboard:{enabled:!0,onlyInViewport:!1},preloadImages:!1,lazy:{loadPrevNext:!0,loadOnTransitionStart:!0,loadPrevNextAmount:2},shouldSwiperUpdate:!0};this.startingUpSwiper&&(n.activeSlideKey=(i=this.state.startPageIndex)==null?void 0:i.toString());let a="bloomPlayer";return this.currentPageHidesNavigationButtons?a+=" hideNextPrevButtons extraScalingForChrome85Bug":(this.props.outsideButtonPageClass&&(a+=" "+this.props.outsideButtonPageClass),e&&(a+=" showNavigationButtonsEvenOnTouchDevices")),B.createElement("div",{"aria-label":"Player Content",className:a+(this.props.extraClassNames?" "+this.props.extraClassNames:""),ref:r=>this.rootDiv=r},B.createElement(fC,{key:this.shouldAutoPlay()?"fade":"slide",...n,effect:this.shouldAutoPlay()?"fade":"slide"},this.state.pages.map((r,s)=>{const c=Math.abs(s-this.state.currentSwiperIndex)<2||this.indicesOfPagesWhereWeShouldPreserveDOMState[s];return B.createElement("div",{key:s,className:"page-preview-slide",onClick:h=>this.handlePageClick(h)},c?B.createElement(B.Fragment,null,B.createElement("style",{scoped:!0},this.state.styleRules),B.createElement("div",{...this.state.importedBodyAttributes,className:`bloomPlayer-page ${this.bookInfo.hasAppearanceSystem?"appearance-system":""} ${this.state.importedBodyAttributes.class??""}`,dangerouslySetInnerHTML:{__html:r}})):"")})),B.createElement("div",{className:"swiper-button-prev "+(this.metaDataObject.isRtl?"swiper-button-right":"swiper-button-left")+(this.props.hideSwiperButtons||this.state.currentSwiperIndex===0?" swiper-button-disabled":""),onClick:()=>this.slidePrevious(),onTouchStart:r=>{this.setState({ignorePhonyClick:!0})}},B.createElement(Aa,{className:"nav-button",disableRipple:!0},this.metaDataObject.isRtl?B.createElement(sh,{titleAccess:He.getTranslation("Button.Prev",this.props.preferredUiLanguages,"Previous Page")}):B.createElement(oh,{titleAccess:He.getTranslation("Button.Prev",this.props.preferredUiLanguages,"Previous Page")}))),B.createElement("div",{className:"swiper-button-next "+(this.metaDataObject.isRtl?"swiper-button-left":"swiper-button-right")+(this.props.hideSwiperButtons||this.state.currentSwiperIndex>=this.state.pages.length-1?" swiper-button-disabled":""),onClick:()=>this.slideNext(),onTouchStart:r=>{this.setState({ignorePhonyClick:!0})}},B.createElement(Aa,{className:"nav-button",disableRipple:!0},this.metaDataObject.isRtl?B.createElement(oh,{titleAccess:He.getTranslation("Button.Next",this.props.preferredUiLanguages,"Next Page")}):B.createElement(sh,{titleAccess:He.getTranslation("Button.Next",this.props.preferredUiLanguages,"Next Page")}))))}shouldAutoPlay(){var e=this.bookInfo.autoAdvance&&this.props.landscape;return this.props.autoplay==="yes"?e=!0:this.props.autoplay==="no"&&(e=!1),e&&!this.skipAutoPlay}setIndex(e){if(this.state.isLoading||this.startingUpSwiper)return;this.setState({currentSwiperIndex:e});const n=this.getPageAtSwiperIndex(e);n&&(this.setPageSizeClass(n),this.animation.HandlePageBeforeVisible(n),this.video.hidingPage(),this.video.HandlePageBeforeVisible(n),GC(),this.music.hidingPage(),mn===Ge.AudioPaused||mn===Ge.VideoPaused?Tn(Ge.NewPageMediaPaused):(this.skipAutoPlay=!0,jC(),this.skipAutoPlay=!1,Tn(Ge.NewPage)))}getPageAtSwiperIndex(e){if(this.swiperInstance==null)return null;const n=this.swiperInstance.slides[e];return n?n.getElementsByClassName("bloom-page")[0]:null}getPageIdFromIndex(e){const n=this.getPageAtSwiperIndex(e);if(!n)throw new Error("No bloomPage at index "+e);return n.getAttribute("id")}static getCurrentPage(){return Te.currentPage}isXmatterPage(){const e=Te.currentPage;if(!e)return!0;const n=e.getAttribute("class");return!n||n.indexOf("bloom-page")<0||n.indexOf("bloom-backMatter")>=0||n.indexOf("bloom-frontMatter")>=0?!0:e.hasAttribute("data-xmatter-page")}showingPage(e){if(this.state.isLoading||this.startingUpSwiper)return;this.props.pageChanged&&this.props.pageChanged(e);const n=this.getPageAtSwiperIndex(e);if(!n){window.setTimeout(()=>this.showingPage(e),50);return}const a=this.getPlayerOptionsForPage(n);this.currentPageHidesNavigationButtons=!!(a&&a.hideNavigation),this.props.hidingNavigationButtonsCallback&&this.props.hidingNavigationButtonsCallback(this.currentPageHidesNavigationButtons),this.activityManager.showingPage(e,n)&&(this.indicesOfPagesWhereWeShouldPreserveDOMState[e]=!0),window.setTimeout(()=>{Te.currentPage=n,Te.currentPageIndex=e,Te.currentPageHasVideo=Xo.pageHasVideo(n),this.setPageSizeClass(n),this.resetForNewPageAndPlay(n),this.props.paused&&this.animation.shouldAnimate(n)&&(this.animation.HandlePageBeforeVisible(n),this.animation.HandlePageVisible(n,this.props.paused),this.animation.HandlePageDurationAvailable(n,am(n),this.props.paused)),this.isXmatterPage()||(this.bookInteraction.pageShown(e),e===this.indexOflastNumberedPage&&(this.bookInteraction.lastNumberedPageWasRead=!0)),this.props.reportPageProperties&&this.props.reportPageProperties({hasAudio:FC(n),hasMusic:this.music.pageHasMusic(n),hasVideo:Te.currentPageHasVideo}),this.bookInteraction.reportedAudioOnCurrentPage=!1,this.bookInteraction.reportedVideoOnCurrentPage=!1,this.sendUpdateOfBookProgressReportToExternalContext(),this.swiperInstance.params.noSwiping=this.activityManager.getActivityAbsorbsDragging(),this.swiperInstance.params.touchRatio=this.activityManager.getActivityAbsorbsDragging()?0:1,this.activityManager.getActivityAbsorbsTyping()?this.swiperInstance.keyboard.disable():this.swiperInstance.keyboard.enable(),Array.from(n.querySelectorAll("[data-sound]")).forEach(r=>{r.addEventListener("click",Gp)})},0)}addScrollbarsToPageWhenReady(e){if(this.state.isLoading||this.startingUpSwiper)return;const n=this.getPageAtSwiperIndex(e);if(!n){window.setTimeout(()=>this.addScrollbarsToPageWhenReady(e),50);return}FL(n,Te.handlePointerMoveEvent)}static handlePointerMoveEvent(e){var n;e.pointerType==="mouse"&&((n=e.target)!=null&&n.closest(".nicescroll-cursors"))&&e.stopPropagation()}storeAudioAnalytics(e){e<.001||Number.isNaN(e)||(this.bookInteraction.totalAudioDuration+=e,!this.isXmatterPage()&&(this.bookInteraction.reportedAudioOnCurrentPage||(this.bookInteraction.reportedAudioOnCurrentPage=!0,this.bookInteraction.audioPageShown(Te.currentPageIndex)),this.sendUpdateOfBookProgressReportToExternalContext()))}static storeVideoAnalytics(e){if(e<.001)return;const n=Te.currentPagePlayer;n.bookInteraction.totalVideoDuration+=e,!n.bookInteraction.reportedVideoOnCurrentPage&&!n.isXmatterPage()&&(n.bookInteraction.reportedVideoOnCurrentPage=!0,n.bookInteraction.videoPageShown(Te.currentPageIndex)),n.sendUpdateOfBookProgressReportToExternalContext()}resetForNewPageAndPlay(e){if(this.props.paused){this.video.HandlePageVisible(e,()=>this.props.paused);return}if(Ky(e),Te.currentPageHasVideo){const n=()=>{this.video.HandlePageVisible(e,()=>this.props.paused),this.music.pause()};if(Tn(Ge.VideoPlaying),!this.sentBloomNotification&&(this.sentBloomNotification=!0,this.props.shouldReportSoundLog)){nf("/publish/av/startRecording",this.videoList).then(n);return}n()}else this.playAudioAndAnimation(e)}playAudioAndAnimation(e){if(this.activityManager.getActivityManagesSound()){this.activityManager.doInitialSoundAndAnimation();return}if(Tn(Ge.AudioPlaying),!e)return;const n=am(e);this.animation.HandlePageDurationAvailable(e,n,this.props.paused);const a=()=>{Kl.pageHasAnimation(e)&&this.animation.HandlePageBeforeVisible(e),this.animation.HandlePageVisible(e,this.props.paused),Hy(e,this.animation.animatableCanvas),this.music.HandlePageVisible(e)};if(!this.sentBloomNotification&&(this.sentBloomNotification=!0,this.props.shouldReportSoundLog)){nf("/publish/av/startRecording",this.videoList).then(a);return}a()}getVideoList(e){let n="";for(const r of Array.from(e.getElementsByTagName("video"))){var a=r,i=a.getElementsByTagName("source")[0].getAttribute("src");n&&(n+="|"),n+=i}return n}handlePageClick(e){if(!this.state.ignorePhonyClick&&(!this.activityManager.getActivityAbsorbsClicking()||e.target.closest("[data-href]")&&e.target.closest(".bloom-canvas"))&&!e.target.closest(".bloom-videoContainer")){const n=$B(e.nativeEvent,this.bookInfo.bookInstanceId,()=>this.getPageIdFromIndex(this.state.currentSwiperIndex));n?(this.navigate(n.bookUrl,n.pageId),e.stopPropagation(),e.preventDefault()):this.props.onContentClick&&this.props.onContentClick(e)}this.setState({ignorePhonyClick:!1})}}function dI(t){return t.replace("%23","#").replace(/[\u00A0-\u9999<>\&]/gim,e=>"&#"+e.charCodeAt(0)+";")}function fI(t){return t.ownerDocument.evaluate("//div[contains(@class, 'bloom-imageDescription')]/div[contains(@class, 'bloom-editable') and contains(@class, 'bloom-visibility-code-on')]//*[contains(@class, 'audio-sentence') or contains(@class, 'bloom-highlightSegment')]",t,null,XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE,null).snapshotLength>0?!0:t.ownerDocument.evaluate("//div[contains(@class, 'bloom-imageDescription')]/div[contains(@class, 'bloom-editable') and contains(@class, 'bloom-visibility-code-on') and @data-audiorecordingmode='TextBox']/p[text()]",t,null,XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE,null).snapshotLength>0}var Zp={},hI=wa,pI=ka;Object.defineProperty(Zp,"__esModule",{value:!0});var a0=Zp.default=void 0,gI=pI(Mn()),mI=hI(xa()),vI=(0,mI.default)(gI.createElement("path",{d:"M20 11H7.83l5.59-5.59L12 4l-8 8 8 8 1.41-1.41L7.83 13H20v-2z"}),"ArrowBack");a0=Zp.default=vI;var Jp={},yI=wa,bI=ka;Object.defineProperty(Jp,"__esModule",{value:!0});var i0=Jp.default=void 0,wI=bI(Mn()),kI=yI(xa()),xI=(0,kI.default)(wI.createElement("path",{d:"M6 10c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm12 0c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm-6 0c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z"}),"MoreHoriz");i0=Jp.default=xI;var Qp={},SI=wa,CI=ka;Object.defineProperty(Qp,"__esModule",{value:!0});var tg=Qp.default=void 0,TI=CI(Mn()),EI=SI(xa()),PI=(0,EI.default)(TI.createElement("path",{d:"M10 16.5l6-4.5-6-4.5v9zM12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z"}),"PlayCircleOutline");tg=Qp.default=PI;var eg={},MI=wa,AI=ka;Object.defineProperty(eg,"__esModule",{value:!0});var r0=eg.default=void 0,NI=AI(Mn()),LI=MI(xa()),zI=(0,LI.default)(NI.createElement("path",{d:"M9 16h2V8H9v8zm3-14C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8zm1-4h2V8h-2v8z"}),"PauseCircleOutline");r0=eg.default=zI;var ng={},BI=wa,II=ka;Object.defineProperty(ng,"__esModule",{value:!0});var o0=ng.default=void 0,DI=II(Mn()),jI=BI(xa()),RI=(0,jI.default)(DI.createElement("path",{d:"M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zm6.93 6h-2.95c-.32-1.25-.78-2.45-1.38-3.56 1.84.63 3.37 1.91 4.33 3.56zM12 4.04c.83 1.2 1.48 2.53 1.91 3.96h-3.82c.43-1.43 1.08-2.76 1.91-3.96zM4.26 14C4.1 13.36 4 12.69 4 12s.1-1.36.26-2h3.38c-.08.66-.14 1.32-.14 2 0 .68.06 1.34.14 2H4.26zm.82 2h2.95c.32 1.25.78 2.45 1.38 3.56-1.84-.63-3.37-1.9-4.33-3.56zm2.95-8H5.08c.96-1.66 2.49-2.93 4.33-3.56C8.81 5.55 8.35 6.75 8.03 8zM12 19.96c-.83-1.2-1.48-2.53-1.91-3.96h3.82c-.43 1.43-1.08 2.76-1.91 3.96zM14.34 14H9.66c-.09-.66-.16-1.32-.16-2 0-.68.07-1.35.16-2h4.68c.09.65.16 1.32.16 2 0 .68-.07 1.34-.16 2zm.25 5.56c.6-1.11 1.06-2.31 1.38-3.56h2.95c-.96 1.65-2.49 2.93-4.33 3.56zM16.36 14c.08-.66.14-1.32.14-2 0-.68-.06-1.34-.14-2h3.38c.16.64.26 1.31.26 2s-.1 1.36-.26 2h-3.38z"}),"Language");o0=ng.default=RI;var ag={},OI=wa,KI=ka;Object.defineProperty(ag,"__esModule",{value:!0});var s0=ag.default=void 0,$I=KI(Mn()),qI=OI(xa()),HI=(0,qI.default)($I.createElement("path",{d:"M7 14H5v5h5v-2H7v-3zm-2-4h2V7h3V5H5v5zm12 7h-3v2h5v-5h-2v3zM14 5v2h3v3h2V5h-5z"}),"Fullscreen");s0=ag.default=HI;var ig={},FI=wa,WI=ka;Object.defineProperty(ig,"__esModule",{value:!0});var l0=ig.default=void 0,_I=WI(Mn()),VI=FI(xa()),GI=(0,VI.default)(_I.createElement("path",{d:"M5 16h3v3h2v-5H5v2zm3-8H5v2h5V5H8v3zm6 11h2v-3h3v-2h-5v5zm2-11V5h-2v5h5V8h-3z"}),"FullscreenExit");l0=ig.default=GI;function UI(t){return wt.createElement(rh,{...t,width:"21",height:"20",viewBox:"0 0 21 20"},wt.createElement("path",{d:"M20.6181 9.909C20.6181 9.909 17.3581 3.70568 10.2454 3.70568C10.1127 3.70568 9.9821 3.70851 9.8522 3.71275L9.23133 0.590958L8.27889 0.807585L8.87136 3.78574C2.72807 4.50344 0 9.86355 0 9.86355C0 9.86355 0.566707 11.0581 1.77366 12.4165L1.27674 9.91983C1.26639 9.90052 1.26089 9.89016 1.26089 9.89016C1.26089 9.89016 1.45882 9.53343 1.86833 9.01188L2.73952 13.3918C3.09729 13.7179 3.49205 14.0383 3.92423 14.3419L2.68074 8.09074C2.92754 7.84068 3.20826 7.58049 3.52199 7.32171L5.05787 15.0424C5.40441 15.2277 5.77033 15.3993 6.15474 15.5514L4.38901 6.67725C4.6772 6.48487 4.98565 6.29932 5.31568 6.12485L7.26481 15.9206C7.59924 16.0118 7.94578 16.0871 8.30509 16.146L7.56314 12.4167C7.89823 12.8518 8.32205 13.2046 8.80465 13.4464L9.36563 16.2656C9.59813 16.2802 9.83459 16.2891 10.0765 16.2891C10.1734 16.2891 10.2694 16.2873 10.3654 16.2844L9.86541 13.773C10.0112 13.7923 10.1591 13.8033 10.3099 13.8033C10.4957 13.8033 10.6783 13.7883 10.8559 13.7588L11.9801 19.4091L12.9321 19.1924L12.3108 16.0683C17.848 14.9378 20.6181 9.909 20.6181 9.909ZM6.88084 8.9881L6.22651 5.69889C6.53386 5.57339 6.8575 5.45942 7.19546 5.35982L7.6228 7.50844C7.28066 7.93015 7.02351 8.43381 6.88084 8.9881ZM8.46692 6.74577L8.14503 5.12836C8.45547 5.06785 8.77691 5.01958 9.11002 4.9859L9.3773 6.32923C9.05322 6.42294 8.74741 6.56375 8.46692 6.74577ZM10.3467 6.19713L10.0944 4.93033C10.1472 4.92963 10.1998 4.92845 10.2533 4.92845C10.4858 4.92845 10.713 4.93599 10.9365 4.94941C13.2188 5.33628 14.964 7.44981 14.964 9.99965C14.964 12.1188 13.7579 13.9352 12.0406 14.7106L11.7914 13.4565C13.0153 12.8558 13.8654 11.5342 13.8654 9.99942C13.8652 7.91226 12.2936 6.21856 10.3467 6.19713ZM14.5336 14.0984C15.4349 13.0056 15.9823 11.5718 15.9823 9.99942C15.9823 8.35399 15.3821 6.8595 14.405 5.74928C17.7771 7.16772 19.3574 9.92642 19.3574 9.92642C19.3574 9.92642 17.7491 12.6074 14.5336 14.0984Z"}))}var rg={},YI=wa,XI=ka;Object.defineProperty(rg,"__esModule",{value:!0});var u0=rg.default=void 0,ZI=XI(Mn()),JI=YI(xa()),QI=(0,JI.default)(ZI.createElement("path",{d:"M3 9v6h4l5 5V4L7 9H3zm13.5 3c0-1.77-1.02-3.29-2.5-4.03v8.05c1.48-.73 2.5-2.25 2.5-4.02zM14 3.23v2.06c2.89.86 5 3.54 5 6.71s-2.11 5.85-5 6.71v2.06c4.01-.91 7-4.49 7-8.77s-2.99-7.86-7-8.77z"}),"VolumeUp");u0=rg.default=QI;const tD=t=>{const[e,n]=B.useState((t.languages.filter(s=>s.IsSelected)[0]||t.languages[0]).Code),a=s=>{const l=s.target.value;n(l),t.onClose(l)},i=()=>{t.onClose("")},r=()=>{const s=t.languages.map(l=>wt.createElement("div",{className:"chooserItem",key:l.Code},wt.createElement(lB,{value:l.Code,control:wt.createElement(kB,null),label:l.Name,checked:l.Code===e}),wt.createElement("span",{className:"spacer"}),wt.createElement(u0,{className:"icon",visibility:l.HasAudio?"inherit":"hidden"})));return wt.createElement("div",{className:"radioGroupDiv"},s)};return wt.createElement(Uz,{className:"languageMenu",onClose:i,"aria-labelledby":"language-menu-title",open:!0,scroll:"paper"},wt.createElement(tB,{id:"language-menu-title"},"Languages in this book:"),wt.createElement(rB,{component:"fieldset"},wt.createElement(xB,{className:"radioGroup","aria-label":"languages",name:"languages",value:e,onChange:a},r())),wt.createElement(Zz,null,wt.createElement(Cz,{onClick:i,color:"secondary"},"Close")))};var Go=(t=>(t[t.showArrow=0]="showArrow",t[t.showEllipsis=1]="showEllipsis",t[t.showNothing=2]="showNothing",t))(Go||{});const eD=t=>{const[e,n]=B.useState(!1),a="button"+(t.bookLanguages.length<2?" disabled":""),i=E=>{n(!1),E!==""&&(t.onLanguageChanged(E),s({lang:E}))},r=()=>{try{document.fullscreenElement!=null||document.webkitFullscreenElement!=null?document.exitFullscreen?document.exitFullscreen():document.webkitExitFullScreen&&document.webkitExitFullScreen():document.documentElement.requestFullscreen?document.documentElement.requestFullscreen():document.documentElement.webkitRequestFullscreen&&document.documentElement.webkitRequestFullscreen()}catch(E){console.error("RequestFullScreen failed: ",E)}},s=E=>{if(!t.videoPreviewMode)return;const z={lang:t.activeLanguageCode,imageDescriptions:t.readImageDescriptions,...E};nf("publish/av/videoSettings",encodeURIComponent(JSON.stringify(z)))},l=He.getTranslation("Audio.Pause",t.preferredLanguages,"Pause"),c=t.paused?wt.createElement(tg,{titleAccess:t.playLabel}):wt.createElement(r0,{titleAccess:l}),h=He.getTranslation("Button.ReadImageDescriptions",t.preferredLanguages,"Read Image Descriptions"),m=He.getTranslation("Button.IgnoreImageDescriptions",t.preferredLanguages,"Ignore Image Descriptions"),k=vs({palette:{primary:{main:oI},secondary:{main:e0.palette.secondary.main}}}),w=wt.createElement(Yl,{theme:k},wt.createElement(UI,{"aria-label":t.readImageDescriptions?"Read image descriptions":"Ignore image descriptions",titleAccess:t.readImageDescriptions?m:h,opacity:t.readImageDescriptions?1:.38,color:t.nowReadingImageDescription?"primary":"secondary"})),P=t.extraButtons?t.extraButtons.map(E=>wt.createElement(Aa,{key:E.id,color:"secondary",title:E.description,onClick:()=>qa({messageType:E.id})},wt.createElement("img",{style:{maxHeight:"24px",maxWidth:"24px"},src:E.iconUrl}))):void 0;return wt.createElement(pz,{color:"primary",className:`control-bar ${t.visible?", visible":""}`,id:"control-bar",elevation:0,position:"relative"},wt.createElement(BB,null,!t.videoPreviewMode&&wt.createElement(Aa,{color:"secondary",onClick:()=>{t.backClicked&&t.backClicked()},"data-testid":"history-back-button",disabled:t.getBackButtonState()===2},t.getBackButtonState()===0?wt.createElement(a0,{"aria-label":"Go Back",titleAccess:He.getTranslation("Button.Back",t.preferredLanguages,"Back")}):t.getBackButtonState()===1&&wt.createElement(i0,{"aria-label":"More Menu",titleAccess:He.getTranslation("Button.More",t.preferredLanguages,"More")})),wt.createElement("div",{className:"filler"}),t.bookHasImageDescriptions&&wt.createElement(Aa,{onClick:()=>{t.onReadImageDescriptionToggled(),s({imageDescriptions:!t.readImageDescriptions})}},w),t.bookLanguages.length>1&&wt.createElement(Aa,{className:a,"aria-label":"Choose Language",color:"secondary",onClick:()=>{n(!0)}},wt.createElement(o0,{titleAccess:He.getTranslation("Button.ChooseLanguage",t.preferredLanguages,"Choose Language")})),e&&wt.createElement(tD,{languages:t.bookLanguages,onClose:i}),!t.videoPreviewMode&&wt.createElement(Aa,{color:"secondary","aria-label":"PlayPause",onClick:()=>{t.pausedChanged&&t.pausedChanged(!t.paused)}},t.showPlayPause?c:null),P,document.fullscreenEnabled&&t.canShowFullScreen&&!t.videoPreviewMode&&wt.createElement(Aa,{color:"secondary",onClick:()=>r()},document.fullscreenElement==null?wt.createElement(s0,{"aria-label":"Full Screen",titleAccess:He.getTranslation("Button.FullScreen",t.preferredLanguages,"Full Screen")}):wt.createElement(l0,{"aria-label":"Exit Full Screen",titleAccess:He.getTranslation("Button.ExitFullScreen",t.preferredLanguages,"Exit Full Screen")}))))};function Gd(t,e){return Math.round(t/e)*e}function nD(t){if(!(!t||t==="cover")){if(/^\d+$/.test(t))return t;try{return t.replace(new RegExp("(?![0-9])\\p{Nd}","gu"),e=>{const n=e.charCodeAt(0);return(n&15)-6*(new RegExp("\\p{Nd}","u").test(String.fromCodePoint(n|15))?1:0)})}catch{return}}}let Ud=!1,gh=t=>{};function aD(t){gh&&gh(t)}let yy=0,by=0;function wy(){const t=/iPad|iPhone|iPod/.test(navigator.platform);let e,n,a;t&&(e=document.getElementsByClassName("bloomPlayer")[0],n=e.parentElement,a=e.nextSibling,n.removeChild(e));const i=document.documentElement.clientWidth,r=document.documentElement.clientHeight;return t&&n.insertBefore(e,a),{width:i,height:r}}const iD=t=>{const[e,n]=B.useState(t.autoplay),a=t.centerVertically===void 0?!0:t.centerVertically;_T(ut=>{ut.pause?(Ud=!j,f(!0)):ut.resume&&Ud?f(!1):ut.play?(f(!1),ut.autoplay&&n(ut.autoplay)):ut.reset?(m(t.startPage??0),Qe.current&&Qe.current(t.startPage??0)):ut.controlAction&&mt(ut.controlAction)});const[i,r]=B.useState(!1),[s,l]=B.useState(t.initiallyShowAppBar),[,c]=B.useState(0);B.useEffect(()=>{const ut=()=>{l(!0),c(Ut=>Ut+1)};return ph.subscribe(ut),()=>{ph.unsubscribe(ut)}},[]);const[h,m]=B.useState(t.startPage??0),[k,w]=B.useState([""]),[P,E]=B.useState(!1),[z,A]=B.useState(!1),[x,S]=B.useState(""),[N,L]=B.useState("Device16x9Portrait");B.useEffect(()=>{l(t.initiallyShowAppBar)},[t.initiallyShowAppBar]),B.useEffect(()=>{s?HT():FT()},[s]),B.useEffect(()=>{f(t.paused)},[t.paused]);const[j,f]=B.useState(t.paused),[U,_]=B.useState(!1),F=He.getBloomUiLanguage(),gt=F==="en"?[F]:[F,"en"],[dt,ot]=B.useState(gt);B.useEffect(()=>{j||(Ud=!1)},[j]);const[X,$]=B.useState(!1),[o,tt]=B.useState(!1),[v,Q]=B.useState(!1),[st,ft]=B.useState(!1),[D,lt]=B.useState(!1),[pt,Ct]=B.useState(0),[St,Dt]=B.useState(9/16),Ht=[],[Vt,Gt]=B.useState(Ht),[Se,dn]=B.useState(""),Qe=B.useRef(),[be,me]=B.useState(!0),[Ue,Tt]=B.useState(!1),[Ce,$n]=B.useState(!1),[We,T]=B.useState(0),I=()=>{T(ut=>ut+1)},[W,Z]=B.useState("");B.useEffect(()=>{Ft()},[D,We,X,t.useOriginalPageSize]),B.useEffect(()=>()=>{const ut=document.getElementById("scale-style-sheet");ut&&ut.parentNode.removeChild(ut)},[]);const nt=B.useRef(),mt=ut=>{switch(ut){case"navigate-to-next-page":nt&&nt.current&&nt.current.slideNext();break;case"navigate-to-previous-page":nt&&nt.current&&nt.current.slidePrevious();break;default:console.log("'handleControlMessage' received an unknown message.");return}},Ft=()=>{const ut=document.getElementsByClassName("swiper-slide-active")[0];let Ut=null;if(ut&&(Ut=ut.getElementsByClassName("bloom-page")[0]),!Ut||!D){window.setTimeout(I,100);return}let qe=document.getElementById("scale-style-sheet");qe||(qe=document.createElement("style"),qe.setAttribute("type","text/css"),qe.setAttribute("id","scale-style-sheet"),document.head.appendChild(qe));let Jt=pt,te=St;const Et=Te.getPageSizeClass(Ut);(t.url!==x||Et!==N)&&(S(t.url),L(Et),window.onresize=()=>{const{width:da,height:Pa}=wy();(Pa!==by||da!==yy)&&I()},Jt=Math.max(Ut.offsetHeight,Ut.offsetWidth),te=Math.min(Ut.offsetHeight,Ut.offsetWidth)/Jt,Dt(te),Ct(Jt));const{width:Lt,height:Qt}=wy();yy=Lt,by=Qt;const we=Lt>Qt;if(we!==X){$(we);return}let fe=0,xn=0;const re=window.getComputedStyle(document.body);re&&re.marginTop&&(fe=parseInt(re.marginTop,10)),re&&re.marginBottom&&(xn=parseInt(re.marginBottom,10));const Fa=Ut.getAttribute("class").indexOf("Landscape")>=0,fn=Fa?Jt*te:Jt,ca=Fa?Jt:Jt*te;let Yn=fe+xn;if(s){const da=document.getElementById("control-bar");da&&(Yn+=da.offsetHeight);const Pa=document.getElementById("pageNumberControl");Pa&&(Yn+=Pa.offsetHeight)}const li=Qt-Yn,yr=se({pageWidth:ca,pageHeight:fn,desiredPageHeight:li}),Wa=le(ca);let de=Math.min(yr,Wa);const Ta=fn*de;let ui=Ta*te/de;Fa&&(ui=Ta/te/de);const Xn=Lt/de-ui;let Ea="",_a=Math.max((Lt-ca*de)/2,0);t.roundMarginToNearestK&&(_a=Gd(_a,t.roundMarginToNearestK));const ho=_a,cc=de,Fs=30;if(Xn>100*2)Ea="largeOutsideButtons";else if(Xn>Fs*2)Ea="smallOutsideButtons";else if(Lt>407&&navigator.userAgent.includes("Chrome")&&!t.hideSwiperButtons){const Pa=new RegExp(" Chrome/([0-9]+).").exec(navigator.userAgent),po=parseInt(Pa[1]);po&&po<90&&(de*=.9,_a=Math.max((Lt-ca*de)/2,0),Ea="smallOutsideButtons extraScalingForChrome85Bug")}Ea!==W&&Z(Ea);let br="";if(a){const da=(Qt-Ta-Yn)/2;da>0&&(br=`translate(0, ${da.toFixed(0)}px) `)}qe.innerText=`.bloomPlayer {
8048
8048
  width: ${ui}px;
8049
8049
  transform-origin: left top 0;
8050
8050
  transform: ${br}scale(${de});
@@ -8057,4 +8057,4 @@ Add a <Suspense fallback=...> component higher in the tree to provide a loading
8057
8057
  }
8058
8058
  }
8059
8059
  .bloomPlayer-page {height: ${Ta/de}px; overflow: hidden;}`,VL(Ut,de),i||r(!0)},se=ut=>{const{pageWidth:Ut,pageHeight:qe,desiredPageHeight:Jt}=ut,te=Jt/qe;if(!t.roundPageWidthToNearestK)return te;const Et=Ut*te;return Gd(Et,t.roundPageWidthToNearestK)/Ut},le=ut=>{let Ut=document.body.offsetWidth;return t.roundPageWidthToNearestK&&(Ut=Gd(Ut,t.roundPageWidthToNearestK)),Ut/ut};B.useEffect(()=>{U&&!j&&_(!1);const ut=document.getElementById("root");ut&&(gh=Ut=>{(Ut.key===" "||Ut.key==="ArrowRight"&&U)&&(Ut.preventDefault(),Ut.stopImmediatePropagation(),f(!j),_(!1))},ut.addEventListener("keydown",aD,{capture:!0}))});const Rt=ut=>{Se!==ut&&(gs.selectNewLanguageCode(Vt,ut),dn(ut))},Ie=(ut,Ut,qe)=>{Qe.current=qe;let Jt;if(t.videoSettings){const te=JSON.parse(t.videoSettings);Jt=te.lang,me(te.imageDescriptions??!1)}t.initialLanguageCode&&(Jt=t.initialLanguageCode),Jt&&ut.map(te=>te.Code).includes(Jt)?gs.selectNewLanguageCode(ut,Jt):Jt=ut.length>0?ut[0].Code:"",dn(Jt),Gt(ut),Tt(Ut),t.videoPreviewMode&&!s&&l(!0)},_e=He.getTranslation("Audio.Play",dt,"Play"),Nn=He.getTranslation("Audio.ReadAloud",dt,"Read Aloud"),tn=o?Nn:_e,{allowToggleAppBar:Sa,showBackButton:Ca,initiallyShowAppBar:Ye,locationOfDistFolder:Pt,hideFullScreenButton:on,...H}=t,zt=vs({palette:{primary:{main:"#000",contrastText:"#FFF"},secondary:{main:"#FFF"}}}),Xt=ut=>{$n(ut)},Oe=Re({root:{color:vi,height:2,padding:"15px 0"},active:{},valueLabel:{left:"calc(50% - 16px)",top:-31,"& *":{background:vi,color:"white"}},track:{height:4,opacity:.5},rail:{height:2,opacity:.5,backgroundColor:vi},mark:{backgroundColor:"transparent"},markActive:{backgroundColor:"transparent"},markLabel:{top:20,fontSize:"0.6rem",color:vi},markLabelActive:{top:20,fontSize:"0.6rem",color:vi}})(NB),De=vs({direction:"rtl"}),ve=wt.createElement(Oe,{valueLabelDisplay:"on",min:1,max:k.length,step:1,disabled:z,defaultValue:h+1,onChangeCommitted:(ut,Ut)=>{Ut-1!=h&&(m(Ut-1),Qe.current&&Qe.current(Ut-1))},valueLabelFormat:(ut,Ut)=>k[ut-1],marks:[{value:k.length,label:k.length.toString()}]});return wt.createElement("div",{className:"reactRoot"},U&&wt.createElement(wt.Fragment,null,wt.createElement("div",{className:"bigButtonOverlay"},wt.createElement(Yl,{theme:zt},wt.createElement(Aa,{color:"secondary",onClick:()=>{_(!1),f(!1)}},wt.createElement(tg,{titleAccess:tn,preserveAspectRatio:"xMidYMid meet"})))),wt.createElement("div",{className:"behindBigButtonOverlay"})),wt.createElement(eD,{getBackButtonState:()=>{var ut;return(ut=nt.current)!=null&&ut.CanGoBack()?Go.showArrow:Ca?window===window.top?Go.showArrow:Go.showEllipsis:Go.showNothing},visible:s,paused:j,pausedChanged:ut=>f(ut),playLabel:tn,preferredLanguages:dt,backClicked:()=>{var ut;(ut=nt.current)!=null&&ut.HandleBackButtonClickedIfHavePlayerHistory()||qT()},showPlayPause:o||v||st,bookLanguages:Vt,activeLanguageCode:Se,onLanguageChanged:Rt,canShowFullScreen:!t.hideFullScreenButton,extraButtons:t.extraButtons,bookHasImageDescriptions:Ue,readImageDescriptions:be,onReadImageDescriptionToggled:()=>me(!be),nowReadingImageDescription:Ce,videoPreviewMode:t.videoPreviewMode}),wt.createElement(sI,{getBookInstanceId:()=>{var ut;return((ut=nt.current)==null?void 0:ut.getBookInstanceId())??""}}),wt.createElement(Te,{ref:nt,url:t.url,landscape:X,paused:j,preferredUiLanguages:dt,pageStylesAreNowInstalled:()=>{lt(!0)},locationOfDistFolder:t.locationOfDistFolder,reportBookProperties:ut=>{const Ut={landscape:ut.landscape,canRotate:ut.canRotate};OT(Ut),ot([F].concat(ut.preferredLanguages)),w(ut.pageNumbers),E(ut.isRtl),ut.internalUrl!=Yd&&(Yd&&I(),Yd=ut.internalUrl)},controlsCallback:Ie,setForcedPausedCallback:ut=>{ut?(f(ut),_(!0)):_(!1)},reportPageProperties:ut=>{tt(ut.hasAudio),Q(ut.hasMusic),ft(ut.hasVideo)},onContentClick:ut=>{t.allowToggleAppBar&&(l(!s),window.setTimeout(I,300+50))},activeLanguageCode:Se,useOriginalPageSize:t.useOriginalPageSize,hideSwiperButtons:t.hideSwiperButtons,autoplay:e,skipActivities:t.skipActivities,outsideButtonPageClass:W,extraClassNames:i?"":"hidePlayer",shouldReadImageDescriptions:be,imageDescriptionCallback:Xt,pageChanged:ut=>{ut!=h&&m(ut)},hidingNavigationButtonsCallback:ut=>{ut!=z&&A(ut)},shouldReportSoundLog:t.shouldReportSoundLog,startPageIndex:t.startPage,autoplayCount:t.autoplayCount}),s&&!t.videoPreviewMode&&wt.createElement("div",{id:"pageNumberControl",className:"MuiToolbar-gutters"},P?wt.createElement(Yl,{theme:De},ve):ve))};function rD(){const t=ma("extraButtons");if(!t)return[];const e=decodeURIComponent(t);try{return JSON.parse(e)}catch(n){return console.error("Failed to parse extra button info "+JSON.stringify(n)),WT("error decoding extraButtons param "+t+": "+n),[]}}function oD(){SC(parseFloat(ma("defaultDuration","3.0")));const t=ma("autoplay","motion"),e=ma("start-page"),n=nD(e),a=n?parseInt(n):void 0,i=ma("autoplay-count"),r=e?parseInt(i):void 0,s=_n("paused",!1);qi.render(wt.createElement(Yl,{theme:e0},wt.createElement(iD,{url:ma("url"),allowToggleAppBar:_n("allowToggleAppBar",!1),showBackButton:_n("showBackButton",!1),initiallyShowAppBar:_n("initiallyShowAppBar",!0),centerVertically:_n("centerVertically",!0),initialLanguageCode:ma("lang"),videoSettings:ma("videoSettings"),paused:s,locationOfDistFolder:"",useOriginalPageSize:_n("useOriginalPageSize",!1),hideFullScreenButton:_n("hideFullScreenButton",!1),autoplay:t,skipActivities:_n("skipActivities",!1),videoPreviewMode:_n("videoPreviewMode",!1),hideSwiperButtons:_n("hideNavButtons",!1),extraButtons:rD(),shouldReportSoundLog:_n("reportSoundLog",!1),startPage:a,autoplayCount:r,roundPageWidthToNearestK:rm("roundPageWidthToNearestK"),roundMarginToNearestK:rm("roundMarginToNearestK")})),document.getElementById("root"))}let Yd="";oD();
8060
- //# sourceMappingURL=bloomPlayer.Ds4dC-C9.js.map
8060
+ //# sourceMappingURL=bloomPlayer.CuoWzBI1.js.map
@@ -18,7 +18,7 @@
18
18
 
19
19
  <!-- At build time, we replace the target of this script tag to point at the
20
20
  the bloom player bundle with the cache-busting hash in its name. -->
21
- <script src="bloomPlayer.Ds4dC-C9.js"></script>
21
+ <script src="bloomPlayer.CuoWzBI1.js"></script>
22
22
  </body>
23
23
 
24
24