159 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			159 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!DOCTYPE html>
 | ||
| <html class="no-js">
 | ||
|     <head>
 | ||
|         <meta charset="utf-8">
 | ||
|         <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
 | ||
|         <title>Basic ePubJS Example</title>
 | ||
|         <meta name="description" content="">
 | ||
|         <meta name="viewport" content="width=device-width">
 | ||
|         <meta name="apple-mobile-web-app-capable" content="yes">
 | ||
| 
 | ||
| 
 | ||
|         <!-- EPUBJS Renderer -->
 | ||
|         <script src="{{ url_for('static', filename='js/zip.min.js') }}"></script>
 | ||
|         <script src="{{ url_for('static', filename='js/inflate.js') }}"></script>
 | ||
|         <script src="{{ url_for('static', filename='js/epub.min.js') }}"></script>
 | ||
|         <script src="{{ url_for('static', filename='css/style.css') }}"></script>
 | ||
| 
 | ||
|         <style type="text/css">
 | ||
| 
 | ||
|           body {
 | ||
|             overflow: hidden;
 | ||
|           }
 | ||
|           body{background:#f2f2f2}
 | ||
|           h1, h1 span{font-weight:normal;color:#444 !important}
 | ||
| 
 | ||
|           .t{
 | ||
|             color: #444 !important;
 | ||
|           }
 | ||
| 
 | ||
| 
 | ||
|           #main {
 | ||
|             position: absolute;
 | ||
|             width: 100%;
 | ||
|             height: 100%;
 | ||
|           }
 | ||
| 
 | ||
|           #area {
 | ||
|             width: 80%;
 | ||
|             height: 80%;
 | ||
|             margin: 5% auto;
 | ||
|             max-width: 1250px;
 | ||
|           }
 | ||
| 
 | ||
|           #area iframe {
 | ||
|             border: none;
 | ||
|           }
 | ||
| 
 | ||
|           #prev {
 | ||
|             left: 40px;
 | ||
|           }
 | ||
| 
 | ||
|           #next {
 | ||
|             right: 40px;
 | ||
|           }
 | ||
| 
 | ||
|           .arrow {
 | ||
|             position: absolute;
 | ||
|             top: 50%;
 | ||
|             margin-top: -32px;
 | ||
|             font-size: 64px;
 | ||
|             color: #E2E2E2;
 | ||
|             font-family: arial, sans-serif;
 | ||
|             font-weight: bold;
 | ||
|             cursor: pointer;
 | ||
|             -webkit-user-select: none;
 | ||
|             -moz-user-select: none;
 | ||
|             user-select: none;
 | ||
|           }
 | ||
| 
 | ||
|           .arrow:hover {
 | ||
|             color: #777;
 | ||
|           }
 | ||
| 
 | ||
|           .arrow:active {
 | ||
|             color: #000;
 | ||
|           }
 | ||
|         </style>
 | ||
| 
 | ||
|          <script>
 | ||
|             "use strict";
 | ||
|             EPUBJS.filePath = "{{ url_for('static', filename='js/') }}";
 | ||
|             EPUBJS.Hooks.register("beforeChapterDisplay").newStyle = function(callback, chapter){
 | ||
|               EPUBJS.core.addCss("{{ url_for('static', filename='css/colors.css') }}", false, chapter.doc.head);
 | ||
|                if(callback) callback();
 | ||
|             }
 | ||
| 
 | ||
|             EPUBJS.Hooks.register("beforeChapterDisplay").highlight = function(callback, renderer){
 | ||
| 
 | ||
|     // EPUBJS.core.addScript("js/libs/jquery.highlight.js", null, renderer.doc.head);
 | ||
| 
 | ||
|     var s = document.createElement("style");
 | ||
|     s.innerHTML =".highlight { background: yellow; font-weight: normal; }";
 | ||
| 
 | ||
|     renderer.doc.head.appendChild(s);
 | ||
| 
 | ||
|     if(callback) callback();
 | ||
| 
 | ||
| }
 | ||
|             var Book = ePub("{{ url_for('static', filename=bookid) }}/", { restore: false });
 | ||
| 
 | ||
|         </script>
 | ||
|     </head>
 | ||
|     <body>
 | ||
|         <div id="main">
 | ||
|           <select id="toc"></select>
 | ||
|           <div id="prev" onclick="Book.prevPage();" class="arrow">‹</div>
 | ||
|           <div id="area"></div>
 | ||
|           <div id="next" onclick="Book.nextPage();"class="arrow">›</div>
 | ||
|         </div>
 | ||
| 
 | ||
| 
 | ||
| <!-- <script src="{{ url_for('static', filename='js/zip.min.js') }}"></script>
 | ||
| <script src="{{ url_for('static', filename='js/inflate.js') }}"></script>
 | ||
| <script src="{{ url_for('static', filename='js/hooks.min.js') }}"></script>
 | ||
| <script src="{{ url_for('static', filename='js/epub.min.js') }}"></script> -->
 | ||
| <script>
 | ||
| 
 | ||
| 
 | ||
|      Book.getMetadata().then(function(meta){
 | ||
| 
 | ||
|                 document.title = meta.bookTitle+" – "+meta.creator;
 | ||
| 
 | ||
|             });
 | ||
| 
 | ||
|     Book.getToc().then(function(toc){
 | ||
| 
 | ||
|               var $select = document.getElementById("toc"),
 | ||
|                   docfrag = document.createDocumentFragment();
 | ||
| 
 | ||
|               toc.forEach(function(chapter) {
 | ||
|                 var option = document.createElement("option");
 | ||
|                 option.textContent = chapter.label;
 | ||
|                 option.ref = chapter.href;
 | ||
| 
 | ||
|                 docfrag.appendChild(option);
 | ||
|               });
 | ||
| 
 | ||
|               $select.appendChild(docfrag);
 | ||
| 
 | ||
|               $select.onchange = function(){
 | ||
|                   var index = $select.selectedIndex,
 | ||
|                       url = $select.options[index].ref;
 | ||
| 
 | ||
|                   Book.goto(url);
 | ||
|                   return false;
 | ||
|               }
 | ||
| 
 | ||
|             });
 | ||
|       Book.renderTo("area");
 | ||
|       Book.setStyle("padding", "0 40px");
 | ||
|     // EPUBJS.filePath = "{{ url_for('static', filename='js/') }}";
 | ||
|     // var Book = ePub("{{ url_for('get_download_link', book_id=bookid, format='epub') }}.epub", { restore: true });
 | ||
|     // Book.renderTo("area").then(function(){
 | ||
|     //   Book.setStyle("padding", "0 40px");
 | ||
|     // });
 | ||
| </script>
 | ||
| </body>
 | ||
| </html>
 |