Skip to content

Commit

Permalink
added embed-pdf shortcode
Browse files Browse the repository at this point in the history
added download-pdf partial

Keep HTML element on a single line, and other minor spacing

Signed-off-by: Justin W. Flory (he/him) [UNICEF Innovation] <jflory@unicef.org>

added embed-pdf shortcode

added demo in installation/configuration file
  • Loading branch information
Neha9849 committed Feb 24, 2022
1 parent aafa040 commit a4daf39
Show file tree
Hide file tree
Showing 3 changed files with 114 additions and 1 deletion.
4 changes: 3 additions & 1 deletion exampleSite/content/installation/configuration/_index.en.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,4 +24,6 @@ Note that some of these parameters are explained in details in other sections of
# Call to action is default enabled, if you want to disable it. just change the
enable = false
# You can change banner title and other text from the config file.
```
```

{{< embed-pdf pdfName="sample.pdf">}}
Binary file added exampleSite/static/pdfs/sample.pdf
Binary file not shown.
111 changes: 111 additions & 0 deletions layouts/shortcodes/embed-pdf.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,111 @@
<style>
.pdfContainer {
width: 100%;
height: auto;

}

#the-canvas {
border: 1px solid black;
}

.pdfNav {
display: flex;
justify-content: space-between;
margin-bottom: 0 !important;
align-items: center;
}

.pdfBtn {
border-radius: 50%;
width: 40px;
height: 40px;
border: none;
margin: 2px;
}
</style>

<div class="pdfContainer">
<hr>
<div class="pdfNav">
<div class="paginations">
<button class="pdfBtn" id="prev">
<b>&lt</b>
</button>
<b id="currentPageNo"></b>/<b id="totalPages"></b>
<button class="pdfBtn" id="next">
<b> &gt</b>
</button>
</div>

<a href="{{.Site.BaseURL}}pdfs/{{ .Get "pdfName" }}" target="_blank">View PDF</a>
</div>
<canvas id="the-canvas"></canvas>
</div>
<script>
var pdf = "{{.Site.BaseURL}}" + "pdfs/" + "{{ .Get "pdfName" }}";
const prevBtn = document.getElementById("prev");
const nextBtn = document.getElementById("next");
const currentPageNoElement = document.getElementById("currentPageNo");
const loadingTask = pdfjsLib.getDocument(pdf);

loadingTask.promise.then((pdf) => {
var currentPage = 1;

//set toal pages
const totalPages = pdf._pdfInfo.numPages;
const totalPagesElement = document.getElementById("totalPages");
totalPagesElement.innerHTML = totalPages;
console.log(totalPages)
// function to set current page number
setCurrentPageNo();
function setCurrentPageNo() {
currentPageNoElement.innerHTML = currentPage;
}
//on clicking prev btn
prevBtn.addEventListener("click", () => {
if (currentPage > 1) {
currentPage--;
setCurrentPageNo();
renderPage(currentPage);

}
});
//on clicking next btn
nextBtn.addEventListener("click", () => {
if (currentPage < totalPages) {
currentPage++;
setCurrentPageNo();
renderPage(currentPage);

}
});
renderPage(currentPage);

//function to render given page number
function renderPage(no) {
pdf.getPage(no).then((page) => {
console.log(page);
var scale = 1.5;
var viewport = page.getViewport({ scale: scale });
var outputScale = window.devicePixelRatio || 1;
var canvas = document.getElementById("the-canvas");
var context = canvas.getContext("2d");
canvas.width = viewport.width;
canvas.height = viewport.height;
canvas.style.width = "100%";
canvas.style.height = "100%";
var transform =
outputScale !== 1 ? [outputScale, 0, 0, outputScale, 0, 0] : null;
// Render PDF page into canvas context
var renderContext = {
canvasContext: context,
viewport: viewport,
transform: transform,
};
var renderTask = page.render(renderContext);
});
}

});
</script>

0 comments on commit a4daf39

Please sign in to comment.