Notepad/enter/.obsidian/plugins/obsidian-advanced-slides/template/reveal.html

264 lines
7.0 KiB
HTML

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
<title>{{{title}}}</title>
<link rel="stylesheet" href="{{{base}}}dist/reveal.css" />
<link rel="stylesheet" href="{{{base}}}{{{themeUrl}}}" id="theme" />
<link rel="stylesheet" href="{{{base}}}{{{highlightThemeUrl}}}" />
<link rel="stylesheet" href="{{{base}}}css/layout.css" />
{{#enableCustomControls}}
<link rel="stylesheet" href="{{{base}}}plugin/customcontrols/style.css">
{{/enableCustomControls}}
{{#enableChalkboard}}
<link rel="stylesheet" href="{{{base}}}plugin/chalkboard/style.css">
{{/enableChalkboard}}
{{#enablePointer}}
<link rel="stylesheet" href="{{{base}}}plugin/reveal-pointer/pointer.css" />
{{/enablePointer}}
{{#cssPaths}}
<link rel="stylesheet" href="{{{base}}}{{{.}}}" />
{{/cssPaths}}
<script defer src="{{{base}}}dist/fontawesome/all.min.js"></script>
<script type="text/javascript">
var forgetPop = true;
function onPopState(event) {
if(forgetPop){
forgetPop = false;
} else {
parent.postMessage(event.target.location.href, "app://obsidian.md");
}
}
window.onpopstate = onPopState;
window.onmessage = event => {
if(event.data == "reload"){
window.document.location.reload();
}
forgetPop = true;
}
function fitElements(){
const itemsToFit = document.getElementsByClassName('fitText');
for (const item in itemsToFit) {
if (Object.hasOwnProperty.call(itemsToFit, item)) {
var element = itemsToFit[item];
fitElement(element,1, 1000);
element.classList.remove('fitText');
}
}
}
function fitElement(element, start, end){
let size = (end + start) / 2;
element.style.fontSize = `${size}px`;
if(Math.abs(start - end) < 1){
while(element.scrollHeight > element.offsetHeight){
size--;
element.style.fontSize = `${size}px`;
}
return;
}
if(element.scrollHeight > element.offsetHeight){
fitElement(element, start, size);
} else {
fitElement(element, size, end);
}
}
document.onreadystatechange = () => {
fitElements();
if (document.readyState === 'complete') {
if (window.location.href.indexOf("?export") != -1){
parent.postMessage(event.target.location.href, "app://obsidian.md");
}
if (window.location.href.indexOf("print-pdf") != -1){
let stateCheck = setInterval(() => {
clearInterval(stateCheck);
window.print();
}, 250);
}
}
};
</script>
</head>
<body>
<div class="reveal">
<div class="slides">{{{slides}}}</div>
</div>
<script src="{{{base}}}dist/reveal.js"></script>
<script src="{{{base}}}plugin/markdown/markdown.js"></script>
<script src="{{{base}}}plugin/highlight/highlight.js"></script>
<script src="{{{base}}}plugin/zoom/zoom.js"></script>
<script src="{{{base}}}plugin/notes/notes.js"></script>
<script src="{{{base}}}plugin/math/math.js"></script>
<script src="{{{base}}}plugin/mermaid/mermaid.js"></script>
<script src="{{{base}}}plugin/chart/chart.min.js"></script>
<script src="{{{base}}}plugin/chart/plugin.js"></script>
{{#enableMenu}}
<script src="{{{base}}}plugin/menu/menu.js"></script>
{{/enableMenu}}
{{#enableCustomControls}}
<script src="{{{base}}}plugin/customcontrols/plugin.js"></script>
{{/enableCustomControls}}
{{#enableChalkboard}}
<script src="{{{base}}}plugin/chalkboard/plugin.js"></script>
{{/enableChalkboard}}
{{#enablePointer}}
<script src="{{{base}}}plugin/reveal-pointer/pointer.js"></script>
{{/enablePointer}}
{{#timeForPresentation}}
{{#enableTimeBar}}
<script src="{{{base}}}plugin/elapsed-time-bar/elapsed-time-bar.js"></script>
{{/enableTimeBar}}
{{/timeForPresentation}}
<script>
function extend() {
var target = {};
for (var i = 0; i < arguments.length; i++) {
var source = arguments[i];
for (var key in source) {
if (source.hasOwnProperty(key)) {
target[key] = source[key];
}
}
}
return target;
}
function isLight(color) {
let hex = color.replace('#', '');
// convert #fff => #ffffff
if(hex.length == 3){
hex = `${hex[0]}${hex[0]}${hex[1]}${hex[1]}${hex[2]}${hex[2]}`;
}
const c_r = parseInt(hex.substr(0, 2), 16);
const c_g = parseInt(hex.substr(2, 2), 16);
const c_b = parseInt(hex.substr(4, 2), 16);
const brightness = ((c_r * 299) + (c_g * 587) + (c_b * 114)) / 1000;
return brightness > 155;
}
var bgColor = getComputedStyle(document.documentElement).getPropertyValue('--r-background-color').trim();
var isLight = isLight(bgColor);
if(isLight){
document.body.classList.add('has-light-background');
} else {
document.body.classList.add('has-dark-background');
}
// default options to init reveal.js
var defaultOptions = {
controls: true,
progress: true,
history: true,
center: true,
transition: 'default', // none/fade/slide/convex/concave/zoom
plugins: [
RevealMarkdown,
RevealHighlight,
RevealZoom,
RevealNotes,
RevealMath.MathJax3,
RevealMermaid,
RevealChart,
{{#enableCustomControls}}
RevealCustomControls,
{{/enableCustomControls}}
{{#enableMenu}}
RevealMenu,
{{/enableMenu}}
{{#enablePointer}}
RevealPointer,
{{/enablePointer}}
{{#enableChalkboard}}
RevealChalkboard,
{{/enableChalkboard}}
{{#timeForPresentation}}
{{#enableTimeBar}}
ElapsedTimeBar
{{/enableTimeBar}}
{{/timeForPresentation}}
],
{{#timeForPresentation}}
allottedTime: {{{.}}} * 1000,
{{/timeForPresentation}}
mathjax3: {
mathjax: '{{{base}}}plugin/math/mathjax/tex-mml-chtml.js',
},
markdown: {
gfm: true,
mangle: true,
pedantic: false,
smartLists: false,
smartypants: false,
},
mermaid: {
theme: isLight ? 'default' : 'dark',
},
{{#enableCustomControls}}
customcontrols: {
controls: [
{{#enableOverview}}
{id: 'toggle-overview',
title: 'Toggle overview (O)',
icon: '<i class="fa fa-th"></i>',
action: 'Reveal.toggleOverview();'
},
{{/enableOverview}}
{{#enableChalkboard}}
{ icon: '<i class="fa fa-pen-square"></i>',
title: 'Toggle chalkboard (B)',
action: 'RevealChalkboard.toggleChalkboard();'
},
{ icon: '<i class="fa fa-pen"></i>',
title: 'Toggle notes canvas (C)',
action: 'RevealChalkboard.toggleNotesCanvas();'
},
{{/enableChalkboard}}
]
},
{{/enableCustomControls}}
{{#enableMenu}}
menu: {
loadIcons: false
}
{{/enableMenu}}
};
// options from URL query string
var queryOptions = Reveal().getQueryHash() || {};
var options = extend(defaultOptions, {{{revealOptionsStr}}}, queryOptions);
</script>
<script>
Reveal.initialize(options);
</script>
</body>
<!-- created with {{! ignore me }}Advanced Slides -->
</html>