545 lines
278 KiB
HTML
545 lines
278 KiB
HTML
|
<!DOCTYPE html>
|
||
|
<html lang="en">
|
||
|
<head>
|
||
|
<meta charset="utf-8"/>
|
||
|
<title></title>
|
||
|
<meta name="author" content=""/>
|
||
|
<meta name="description" content=""/>
|
||
|
<meta name="keywords" content=""/>
|
||
|
<style type="text/css">
|
||
|
.underline { text-decoration: underline; }
|
||
|
</style>
|
||
|
<style type="text/css">
|
||
|
/*!
|
||
|
* reveal.js 5.1.0
|
||
|
* https://revealjs.com
|
||
|
* MIT licensed
|
||
|
*
|
||
|
* Copyright (C) 2011-2024 Hakim El Hattab, https://hakim.se
|
||
|
*/
|
||
|
.reveal .r-stretch,.reveal .stretch{max-width:none;max-height:none}.reveal pre.r-stretch code,.reveal pre.stretch code{height:100%;max-height:100%;box-sizing:border-box}.reveal .r-fit-text{display:inline-block;white-space:nowrap}.reveal .r-stack{display:grid;grid-template-rows:100%}.reveal .r-stack>*{grid-area:1/1;margin:auto}.reveal .r-hstack,.reveal .r-vstack{display:flex}.reveal .r-hstack img,.reveal .r-hstack video,.reveal .r-vstack img,.reveal .r-vstack video{min-width:0;min-height:0;object-fit:contain}.reveal .r-vstack{flex-direction:column;align-items:center;justify-content:center}.reveal .r-hstack{flex-direction:row;align-items:center;justify-content:center}.reveal .items-stretch{align-items:stretch}.reveal .items-start{align-items:flex-start}.reveal .items-center{align-items:center}.reveal .items-end{align-items:flex-end}.reveal .justify-between{justify-content:space-between}.reveal .justify-around{justify-content:space-around}.reveal .justify-start{justify-content:flex-start}.reveal .justify-center{justify-content:center}.reveal .justify-end{justify-content:flex-end}html.reveal-full-page{width:100%;height:100%;height:100vh;height:calc(var(--vh,1vh) * 100);height:100svh;overflow:hidden}.reveal-viewport{height:100%;overflow:hidden;position:relative;line-height:1;margin:0;background-color:#fff;color:#000;--r-controls-spacing:12px}.reveal-viewport:fullscreen{top:0!important;left:0!important;width:100%!important;height:100%!important;transform:none!important}.reveal .fragment{transition:all .2s ease}.reveal .fragment:not(.custom){opacity:0;visibility:hidden;will-change:opacity}.reveal .fragment.visible{opacity:1;visibility:inherit}.reveal .fragment.disabled{transition:none}.reveal .fragment.grow{opacity:1;visibility:inherit}.reveal .fragment.grow.visible{transform:scale(1.3)}.reveal .fragment.shrink{opacity:1;visibility:inherit}.reveal .fragment.shrink.visible{transform:scale(.7)}.reveal .fragment.zoom-in{transform:scale(.1)}.reveal .fragment.zoom-in.visible{transform:none}.reveal .fragment.fade-out{opacity:1;visibility:inherit}.reveal .fragment.fade-out.visible{opacity:0;visibility:hidden}.reveal .fragment.semi-fade-out{opacity:1;visibility:inherit}.reveal .fragment.semi-fade-out.visible{opacity:.5;visibility:inherit}.reveal .fragment.strike{opacity:1;visibility:inherit}.reveal .fragment.strike.visible{text-decoration:line-through}.reveal .fragment.fade-up{transform:translate(0,40px)}.reveal .fragment.fade-up.visible{transform:translate(0,0)}.reveal .fragment.fade-down{transform:translate(0,-40px)}.reveal .fragment.fade-down.visible{transform:translate(0,0)}.reveal .fragment.fade-right{transform:translate(-40px,0)}.reveal .fragment.fade-right.visible{transform:translate(0,0)}.reveal .fragment.fade-left{transform:translate(40px,0)}.reveal .fragment.fade-left.visible{transform:translate(0,0)}.reveal .fragment.current-visible,.reveal .fragment.fade-in-then-out{opacity:0;visibility:hidden}.reveal .fragment.current-visible.current-fragment,.reveal .fragment.fade-in-then-out.current-fragment{opacity:1;visibility:inherit}.reveal .fragment.fade-in-then-semi-out{opacity:0;visibility:hidden}.reveal .fragment.fade-in-then-semi-out.visible{opacity:.5;visibility:inherit}.reveal .fragment.fade-in-then-semi-out.current-fragment{opacity:1;visibility:inherit}.reveal .fragment.highlight-blue,.reveal .fragment.highlight-current-blue,.reveal .fragment.highlight-current-green,.reveal .fragment.highlight-current-red,.reveal .fragment.highlight-green,.reveal .fragment.highlight-red{opacity:1;visibility:inherit}.reveal .fragment.highlight-red.visible{color:#ff2c2d}.reveal .fragment.highlight-green.visible{color:#17ff2e}.reveal .fragment.highlight-blue.visible{color:#1b91ff}.reveal .fragment.highlight-current-red.current-fragment{color:#ff2c2d}.reveal .fragment.highlight-current-green.current-fragment{color:#17ff2e}.reveal .fragment.highlight-current-blue.current-fragment{color:#1b91ff}.reveal:after{content:"";font-style:italic}.reveal iframe{z-index:1}.reveal a{position:relative}@keyframes bounce-right{0%,10%,25%,40%,50%{transform:transl
|
||
|
</style>
|
||
|
|
||
|
<style type="text/css">
|
||
|
/**
|
||
|
* Solarized Dark theme for reveal.js.
|
||
|
* Author: Achim Staebler
|
||
|
*/
|
||
|
@import url(./fonts/league-gothic/league-gothic.css);
|
||
|
@import url(https://fonts.googleapis.com/css?family=Lato:400,700,400italic,700italic);
|
||
|
/**
|
||
|
* Solarized colors by Ethan Schoonover
|
||
|
*/
|
||
|
section.has-light-background, section.has-light-background h1, section.has-light-background h2, section.has-light-background h3, section.has-light-background h4, section.has-light-background h5, section.has-light-background h6 {
|
||
|
color: #222;
|
||
|
}
|
||
|
|
||
|
/*********************************************
|
||
|
* GLOBAL STYLES
|
||
|
*********************************************/
|
||
|
:root {
|
||
|
--r-background-color: #002b36;
|
||
|
--r-main-font: Lato, sans-serif;
|
||
|
--r-main-font-size: 40px;
|
||
|
--r-main-color: #93a1a1;
|
||
|
--r-block-margin: 20px;
|
||
|
--r-heading-margin: 0 0 20px 0;
|
||
|
--r-heading-font: League Gothic, Impact, sans-serif;
|
||
|
--r-heading-color: #eee8d5;
|
||
|
--r-heading-line-height: 1.2;
|
||
|
--r-heading-letter-spacing: normal;
|
||
|
--r-heading-text-transform: uppercase;
|
||
|
--r-heading-text-shadow: none;
|
||
|
--r-heading-font-weight: normal;
|
||
|
--r-heading1-text-shadow: none;
|
||
|
--r-heading1-size: 3.77em;
|
||
|
--r-heading2-size: 2.11em;
|
||
|
--r-heading3-size: 1.55em;
|
||
|
--r-heading4-size: 1em;
|
||
|
--r-code-font: monospace;
|
||
|
--r-link-color: #268bd2;
|
||
|
--r-link-color-dark: #1a6091;
|
||
|
--r-link-color-hover: #78b9e6;
|
||
|
--r-selection-background-color: #d33682;
|
||
|
--r-selection-color: #fff;
|
||
|
--r-overlay-element-bg-color: 240, 240, 240;
|
||
|
--r-overlay-element-fg-color: 0, 0, 0;
|
||
|
}
|
||
|
|
||
|
.reveal-viewport {
|
||
|
background: #002b36;
|
||
|
background-color: var(--r-background-color);
|
||
|
}
|
||
|
|
||
|
.reveal {
|
||
|
font-family: var(--r-main-font);
|
||
|
font-size: var(--r-main-font-size);
|
||
|
font-weight: normal;
|
||
|
color: var(--r-main-color);
|
||
|
}
|
||
|
|
||
|
.reveal ::selection {
|
||
|
color: var(--r-selection-color);
|
||
|
background: var(--r-selection-background-color);
|
||
|
text-shadow: none;
|
||
|
}
|
||
|
|
||
|
.reveal ::-moz-selection {
|
||
|
color: var(--r-selection-color);
|
||
|
background: var(--r-selection-background-color);
|
||
|
text-shadow: none;
|
||
|
}
|
||
|
|
||
|
.reveal .slides section,
|
||
|
.reveal .slides section > section {
|
||
|
line-height: 1.3;
|
||
|
font-weight: inherit;
|
||
|
}
|
||
|
|
||
|
/*********************************************
|
||
|
* HEADERS
|
||
|
*********************************************/
|
||
|
.reveal h1,
|
||
|
.reveal h2,
|
||
|
.reveal h3,
|
||
|
.reveal h4,
|
||
|
.reveal h5,
|
||
|
.reveal h6 {
|
||
|
margin: var(--r-heading-margin);
|
||
|
color: var(--r-heading-color);
|
||
|
font-family: var(--r-heading-font);
|
||
|
font-weight: var(--r-heading-font-weight);
|
||
|
line-height: var(--r-heading-line-height);
|
||
|
letter-spacing: var(--r-heading-letter-spacing);
|
||
|
text-transform: var(--r-heading-text-transform);
|
||
|
text-shadow: var(--r-heading-text-shadow);
|
||
|
word-wrap: break-word;
|
||
|
}
|
||
|
|
||
|
.reveal h1 {
|
||
|
font-size: var(--r-heading1-size);
|
||
|
}
|
||
|
|
||
|
.reveal h2 {
|
||
|
font-size: var(--r-heading2-size);
|
||
|
}
|
||
|
|
||
|
.reveal h3 {
|
||
|
font-size: var(--r-heading3-size);
|
||
|
}
|
||
|
|
||
|
.reveal h4 {
|
||
|
font-size: var(--r-heading4-size);
|
||
|
}
|
||
|
|
||
|
.reveal h1 {
|
||
|
text-shadow: var(--r-heading1-text-shadow);
|
||
|
}
|
||
|
|
||
|
/*********************************************
|
||
|
* OTHER
|
||
|
*********************************************/
|
||
|
.reveal p {
|
||
|
margin: var(--r-block-margin) 0;
|
||
|
line-height: 1.3;
|
||
|
}
|
||
|
|
||
|
/* Remove trailing margins after titles */
|
||
|
.reveal h1:last-child,
|
||
|
.reveal h2:last-child,
|
||
|
.reveal h3:last-child,
|
||
|
.reveal h4:last-child,
|
||
|
.reveal h5:last-child,
|
||
|
.reveal h6:last-child {
|
||
|
margin-bottom: 0;
|
||
|
}
|
||
|
|
||
|
/* Ensure certain elements are never larger than the slide itself */
|
||
|
.reveal img,
|
||
|
.reveal video,
|
||
|
.reveal iframe {
|
||
|
max-width: 95%;
|
||
|
max-height: 95%;
|
||
|
}
|
||
|
|
||
|
.reveal strong,
|
||
|
.reveal b {
|
||
|
font-weight: bold;
|
||
|
}
|
||
|
|
||
|
.reveal em {
|
||
|
font-style: italic;
|
||
|
}
|
||
|
|
||
|
.reveal ol,
|
||
|
.reveal dl,
|
||
|
.reveal ul {
|
||
|
display: inline-block;
|
||
|
text-align: left;
|
||
|
margin: 0 0 0 1em;
|
||
|
}
|
||
|
|
||
|
.reveal ol {
|
||
|
list-style-type: decimal;
|
||
|
}
|
||
|
|
||
|
.reveal ul {
|
||
|
list-style-type: disc;
|
||
|
}
|
||
|
|
||
|
.reveal ul ul {
|
||
|
list-style-type: square;
|
||
|
}
|
||
|
|
||
|
.reveal ul ul ul {
|
||
|
list-style-type: circle;
|
||
|
}
|
||
|
|
||
|
.reveal ul ul,
|
||
|
.reveal ul ol,
|
||
|
.reveal ol ol,
|
||
|
.reveal ol ul {
|
||
|
display: block;
|
||
|
margin-left: 40px;
|
||
|
}
|
||
|
|
||
|
.reveal dt {
|
||
|
font-weight: bold;
|
||
|
}
|
||
|
|
||
|
.reveal dd {
|
||
|
margin-left: 40px;
|
||
|
}
|
||
|
|
||
|
.reveal blockquote {
|
||
|
display: block;
|
||
|
position: relative;
|
||
|
width: 70%;
|
||
|
margin: var(--r-block-margin) auto;
|
||
|
padding: 5px;
|
||
|
font-style: italic;
|
||
|
background: rgba(255, 255, 255, 0.05);
|
||
|
box-shadow: 0px 0px 2px rgba(0, 0, 0, 0.2);
|
||
|
}
|
||
|
|
||
|
.reveal blockquote p:first-child,
|
||
|
.reveal blockquote p:last-child {
|
||
|
display: inline-block;
|
||
|
}
|
||
|
|
||
|
.reveal q {
|
||
|
font-style: italic;
|
||
|
}
|
||
|
|
||
|
.reveal pre {
|
||
|
display: block;
|
||
|
position: relative;
|
||
|
width: 90%;
|
||
|
margin: var(--r-block-margin) auto;
|
||
|
text-align: left;
|
||
|
font-size: 0.55em;
|
||
|
font-family: var(--r-code-font);
|
||
|
line-height: 1.2em;
|
||
|
word-wrap: break-word;
|
||
|
box-shadow: 0px 5px 15px rgba(0, 0, 0, 0.15);
|
||
|
}
|
||
|
|
||
|
.reveal code {
|
||
|
font-family: var(--r-code-font);
|
||
|
text-transform: none;
|
||
|
tab-size: 2;
|
||
|
}
|
||
|
|
||
|
.reveal pre code {
|
||
|
display: block;
|
||
|
padding: 5px;
|
||
|
overflow: auto;
|
||
|
max-height: 400px;
|
||
|
word-wrap: normal;
|
||
|
}
|
||
|
|
||
|
.reveal .code-wrapper {
|
||
|
white-space: normal;
|
||
|
}
|
||
|
|
||
|
.reveal .code-wrapper code {
|
||
|
white-space: pre;
|
||
|
}
|
||
|
|
||
|
.reveal table {
|
||
|
margin: auto;
|
||
|
border-collapse: collapse;
|
||
|
border-spacing: 0;
|
||
|
}
|
||
|
|
||
|
.reveal table th {
|
||
|
font-weight: bold;
|
||
|
}
|
||
|
|
||
|
.reveal table th,
|
||
|
.reveal table td {
|
||
|
text-align: left;
|
||
|
padding: 0.2em 0.5em 0.2em 0.5em;
|
||
|
border-bottom: 1px solid;
|
||
|
}
|
||
|
|
||
|
.reveal table th[align=center],
|
||
|
.reveal table td[align=center] {
|
||
|
text-align: center;
|
||
|
}
|
||
|
|
||
|
.reveal table th[align=right],
|
||
|
.reveal table td[align=right] {
|
||
|
text-align: right;
|
||
|
}
|
||
|
|
||
|
.reveal table tbody tr:last-child th,
|
||
|
.reveal table tbody tr:last-child td {
|
||
|
border-bottom: none;
|
||
|
}
|
||
|
|
||
|
.reveal sup {
|
||
|
vertical-align: super;
|
||
|
font-size: smaller;
|
||
|
}
|
||
|
|
||
|
.reveal sub {
|
||
|
vertical-align: sub;
|
||
|
font-size: smaller;
|
||
|
}
|
||
|
|
||
|
.reveal small {
|
||
|
display: inline-block;
|
||
|
font-size: 0.6em;
|
||
|
line-height: 1.2em;
|
||
|
vertical-align: top;
|
||
|
}
|
||
|
|
||
|
.reveal small * {
|
||
|
vertical-align: top;
|
||
|
}
|
||
|
|
||
|
.reveal img {
|
||
|
margin: var(--r-block-margin) 0;
|
||
|
}
|
||
|
|
||
|
/*********************************************
|
||
|
* LINKS
|
||
|
*********************************************/
|
||
|
.reveal a {
|
||
|
color: var(--r-link-color);
|
||
|
text-decoration: none;
|
||
|
transition: color 0.15s ease;
|
||
|
}
|
||
|
|
||
|
.reveal a:hover {
|
||
|
color: var(--r-link-color-hover);
|
||
|
text-shadow: none;
|
||
|
border: none;
|
||
|
}
|
||
|
|
||
|
.reveal .roll span:after {
|
||
|
color: #fff;
|
||
|
background: var(--r-link-color-dark);
|
||
|
}
|
||
|
|
||
|
/*********************************************
|
||
|
* Frame helper
|
||
|
*********************************************/
|
||
|
.reveal .r-frame {
|
||
|
border: 4px solid var(--r-main-color);
|
||
|
box-shadow: 0 0 10px rgba(0, 0, 0, 0.15);
|
||
|
}
|
||
|
|
||
|
.reveal a .r-frame {
|
||
|
transition: all 0.15s linear;
|
||
|
}
|
||
|
|
||
|
.reveal a:hover .r-frame {
|
||
|
border-color: var(--r-link-color);
|
||
|
box-shadow: 0 0 20px rgba(0, 0, 0, 0.55);
|
||
|
}
|
||
|
|
||
|
/*********************************************
|
||
|
* NAVIGATION CONTROLS
|
||
|
*********************************************/
|
||
|
.reveal .controls {
|
||
|
color: var(--r-link-color);
|
||
|
}
|
||
|
|
||
|
/*********************************************
|
||
|
* PROGRESS BAR
|
||
|
*********************************************/
|
||
|
.reveal .progress {
|
||
|
background: rgba(0, 0, 0, 0.2);
|
||
|
color: var(--r-link-color);
|
||
|
}
|
||
|
|
||
|
/*********************************************
|
||
|
* PRINT BACKGROUND
|
||
|
*********************************************/
|
||
|
@media print {
|
||
|
.backgrounds {
|
||
|
background-color: var(--r-background-color);
|
||
|
}
|
||
|
}
|
||
|
</style>
|
||
|
|
||
|
<style type="text/css">
|
||
|
.section-number-2 {
|
||
|
display: none;
|
||
|
}
|
||
|
|
||
|
.section-number-3 {
|
||
|
display: none;
|
||
|
}
|
||
|
.section-number-4 {
|
||
|
display: none;
|
||
|
}
|
||
|
.section-number-5 {
|
||
|
display: none;
|
||
|
}
|
||
|
b {
|
||
|
color: lightgreen;
|
||
|
}
|
||
|
table {
|
||
|
table-layout:fixed;
|
||
|
}
|
||
|
|
||
|
|
||
|
td {
|
||
|
overflow: hidden;
|
||
|
text-overflow: ellipsis;
|
||
|
word-wrap: break-word;
|
||
|
}
|
||
|
|
||
|
.date {
|
||
|
display: none;
|
||
|
}
|
||
|
|
||
|
</style>
|
||
|
</head>
|
||
|
<body>
|
||
|
<div class="reveal">
|
||
|
<div class="slides">
|
||
|
<section id="sec-title-slide" data-background="./1.jpg" data-background-size="1200px"><p class="date">Created: 2024-09-08 Sun 20:16</p>
|
||
|
</section>
|
||
|
|
||
|
<section>
|
||
|
<section id="slide-org6dae41c">
|
||
|
<h2 id="org6dae41c"><span class="section-number-2">1.</span> Proxy Cafe: the backup edition</h2>
|
||
|
</section>
|
||
|
</section>
|
||
|
<section>
|
||
|
<section id="slide-orgcf18d07">
|
||
|
<h2 id="orgcf18d07"><span class="section-number-2">2.</span> </h2>
|
||
|
<p>
|
||
|
#+BEGIN<sub>NOTES</sub>
|
||
|
</p>
|
||
|
</section>
|
||
|
</section>
|
||
|
<section>
|
||
|
<section id="slide-org10eea17">
|
||
|
<h2 id="org10eea17"><span class="section-number-2">3.</span> Scaletta</h2>
|
||
|
<ul>
|
||
|
<li>my 9/11 moment</li>
|
||
|
<li>the guy made fun of me</li>
|
||
|
<li>spiega il problema</li>
|
||
|
<li>elenca i dispositivi</li>
|
||
|
<li>elenca i possibili files</li>
|
||
|
<li>categorizza i files</li>
|
||
|
<li>frequenza</li>
|
||
|
<li>possibilità:
|
||
|
<ul>
|
||
|
<li>rolling windows</li>
|
||
|
<li>incrementale</li>
|
||
|
<li>deduplicazione</li>
|
||
|
<li>sincronizzazione (no backup)</li>
|
||
|
<li>encryption</li>
|
||
|
|
||
|
</ul></li>
|
||
|
<li>soluzioni software
|
||
|
<ul>
|
||
|
<li>vedi soluzioni software</li>
|
||
|
<li>categorizza soluzioni software?</li>
|
||
|
<li>3 2 1 rule</li>
|
||
|
<li>try to restore</li>
|
||
|
|
||
|
</ul></li>
|
||
|
<li>soluzioni hardware
|
||
|
<ul>
|
||
|
<li>cloud, sì o no?</li>
|
||
|
<li>backblaze, sì o no?</li>
|
||
|
<li>nas, sì o no?</li>
|
||
|
<li>elettricità</li>
|
||
|
<li>come risparmiare</li>
|
||
|
<li>come scegliere hdd</li>
|
||
|
<li>raid? (lol)</li>
|
||
|
|
||
|
</ul></li>
|
||
|
|
||
|
<li>parte tecnica sui file systems</li>
|
||
|
<li>bonus, what should we backup but we think it's always available?</li>
|
||
|
|
||
|
</ul>
|
||
|
<p>
|
||
|
#+END<sub>NOTES</sub>
|
||
|
</p>
|
||
|
</section>
|
||
|
</section>
|
||
|
</div>
|
||
|
</div>
|
||
|
<script>
|
||
|
/*!
|
||
|
* reveal.js 5.1.0
|
||
|
* https://revealjs.com
|
||
|
* MIT licensed
|
||
|
*
|
||
|
* Copyright (C) 2011-2024 Hakim El Hattab, https://hakim.se
|
||
|
*/
|
||
|
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):(e="undefined"!=typeof globalThis?globalThis:e||self).Reveal=t()}(this,(function(){"use strict";const e=(e,t)=>{for(let i in t)e[i]=t[i];return e},t=(e,t)=>Array.from(e.querySelectorAll(t)),i=(e,t,i)=>{i?e.classList.add(t):e.classList.remove(t)},s=e=>{if("string"==typeof e){if("null"===e)return null;if("true"===e)return!0;if("false"===e)return!1;if(e.match(/^-?[\d\.]+$/))return parseFloat(e)}return e},a=(e,t)=>{e.style.transform=t},n=(e,t)=>{let i=e.matches||e.matchesSelector||e.msMatchesSelector;return!(!i||!i.call(e,t))},r=(e,t)=>{if("function"==typeof e.closest)return e.closest(t);for(;e;){if(n(e,t))return e;e=e.parentNode}return null},o=e=>{let t=(e=e||document.documentElement).requestFullscreen||e.webkitRequestFullscreen||e.webkitRequestFullScreen||e.mozRequestFullScreen||e.msRequestFullscreen;t&&t.apply(e)},l=e=>{let t=document.createElement("style");return t.type="text/css",e&&e.length>0&&(t.styleSheet?t.styleSheet.cssText=e:t.appendChild(document.createTextNode(e))),document.head.appendChild(t),t},d=()=>{let e={};location.search.replace(/[A-Z0-9]+?=([\w\.%-]*)/gi,(t=>{e[t.split("=").shift()]=t.split("=").pop()}));for(let t in e){let i=e[t];e[t]=s(unescape(i))}return void 0!==e.dependencies&&delete e.dependencies,e},c={mp4:"video/mp4",m4a:"video/mp4",ogv:"video/ogg",mpeg:"video/mpeg",webm:"video/webm"},h=navigator.userAgent,u=/(iphone|ipod|ipad|android)/gi.test(h)||"MacIntel"===navigator.platform&&navigator.maxTouchPoints>1,g=/android/gi.test(h);var p=function(e){if(e){var t=function(e){return[].slice.call(e)},i=3,s=[],a=null,n="requestAnimationFrame"in e?function(){e.cancelAnimationFrame(a),a=e.requestAnimationFrame((function(){return o(s.filter((function(e){return e.dirty&&e.active})))}))}:function(){},r=function(e){return function(){s.forEach((function(t){return t.dirty=e})),n()}},o=function(e){e.filter((function(e){return!e.styleComputed})).forEach((function(e){e.styleComputed=h(e)})),e.filter(u).forEach(g);var t=e.filter(c);t.forEach(d),t.forEach((function(e){g(e),l(e)})),t.forEach(p)},l=function(e){return e.dirty=0},d=function(e){e.availableWidth=e.element.parentNode.clientWidth,e.currentWidth=e.element.scrollWidth,e.previousFontSize=e.currentFontSize,e.currentFontSize=Math.min(Math.max(e.minSize,e.availableWidth/e.currentWidth*e.previousFontSize),e.maxSize),e.whiteSpace=e.multiLine&&e.currentFontSize===e.minSize?"normal":"nowrap"},c=function(e){return 2!==e.dirty||2===e.dirty&&e.element.parentNode.clientWidth!==e.availableWidth},h=function(t){var i=e.getComputedStyle(t.element,null);return t.currentFontSize=parseFloat(i.getPropertyValue("font-size")),t.display=i.getPropertyValue("display"),t.whiteSpace=i.getPropertyValue("white-space"),!0},u=function(e){var t=!1;return!e.preStyleTestCompleted&&(/inline-/.test(e.display)||(t=!0,e.display="inline-block"),"nowrap"!==e.whiteSpace&&(t=!0,e.whiteSpace="nowrap"),e.preStyleTestCompleted=!0,t)},g=function(e){e.element.style.whiteSpace=e.whiteSpace,e.element.style.display=e.display,e.element.style.fontSize=e.currentFontSize+"px"},p=function(e){e.element.dispatchEvent(new CustomEvent("fit",{detail:{oldValue:e.previousFontSize,newValue:e.currentFontSize,scaleFactor:e.currentFontSize/e.previousFontSize}}))},v=function(e,t){return function(){e.dirty=t,e.active&&n()}},m=function(e){return function(){s=s.filter((function(t){return t.element!==e.element})),e.observeMutations&&e.observer.disconnect(),e.element.style.whiteSpace=e.originalStyle.whiteSpace,e.element.style.display=e.originalStyle.display,e.element.style.fontSize=e.originalStyle.fontSize}},f=function(e){return function(){e.active||(e.active=!0,n())}},y=function(e){return function(){return e.active=!1}},b=function(e){e.observeMutations&&(e.observer=new MutationObserver(v(e,1)),e.observer.observe(e.element,e.observeMutations))},w={minSize:16,maxSize:512,multiLine:!0,observeMutations:"MutationObserver"in e&&{subtree:!0,childList:!0,characterData:!0}},E=null,S=function(){e.clearTimeo
|
||
|
//# sourceMappingURL=reveal.js.map
|
||
|
|
||
|
</script>
|
||
|
<script>
|
||
|
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):(e="undefined"!=typeof globalThis?globalThis:e||self).RevealMarkdown=t()}(this,(function(){"use strict";function e(){return{async:!1,baseUrl:null,breaks:!1,extensions:null,gfm:!0,headerIds:!0,headerPrefix:"",highlight:null,hooks:null,langPrefix:"language-",mangle:!0,pedantic:!1,renderer:null,sanitize:!1,sanitizer:null,silent:!1,smartypants:!1,tokenizer:null,walkTokens:null,xhtml:!1}}let t={async:!1,baseUrl:null,breaks:!1,extensions:null,gfm:!0,headerIds:!0,headerPrefix:"",highlight:null,hooks:null,langPrefix:"language-",mangle:!0,pedantic:!1,renderer:null,sanitize:!1,sanitizer:null,silent:!1,smartypants:!1,tokenizer:null,walkTokens:null,xhtml:!1};const n=/[&<>"']/,s=new RegExp(n.source,"g"),r=/[<>"']|&(?!(#\d{1,7}|#[Xx][a-fA-F0-9]{1,6}|\w+);)/,i=new RegExp(r.source,"g"),l={"&":"&","<":"<",">":">",'"':""","'":"'"},o=e=>l[e];function a(e,t){if(t){if(n.test(e))return e.replace(s,o)}else if(r.test(e))return e.replace(i,o);return e}const c=/&(#(?:\d+)|(?:#x[0-9A-Fa-f]+)|(?:\w+));?/gi;function h(e){return e.replace(c,((e,t)=>"colon"===(t=t.toLowerCase())?":":"#"===t.charAt(0)?"x"===t.charAt(1)?String.fromCharCode(parseInt(t.substring(2),16)):String.fromCharCode(+t.substring(1)):""))}const p=/(^|[^\[])\^/g;function u(e,t){e="string"==typeof e?e:e.source,t=t||"";const n={replace:(t,s)=>(s=(s=s.source||s).replace(p,"$1"),e=e.replace(t,s),n),getRegex:()=>new RegExp(e,t)};return n}const g=/[^\w:]/g,d=/^$|^[a-z][a-z0-9+.-]*:|^[?#]/i;function f(e,t,n){if(e){let e;try{e=decodeURIComponent(h(n)).replace(g,"").toLowerCase()}catch(e){return null}if(0===e.indexOf("javascript:")||0===e.indexOf("vbscript:")||0===e.indexOf("data:"))return null}t&&!d.test(n)&&(n=function(e,t){k[" "+e]||(x.test(e)?k[" "+e]=e+"/":k[" "+e]=_(e,"/",!0));e=k[" "+e];const n=-1===e.indexOf(":");return"//"===t.substring(0,2)?n?t:e.replace(m,"$1")+t:"/"===t.charAt(0)?n?t:e.replace(b,"$1")+t:e+t}(t,n));try{n=encodeURI(n).replace(/%25/g,"%")}catch(e){return null}return n}const k={},x=/^[^:]+:\/*[^/]*$/,m=/^([^:]+:)[\s\S]*$/,b=/^([^:]+:\/*[^/]*)[\s\S]*$/;const w={exec:function(){}};function y(e,t){const n=e.replace(/\|/g,((e,t,n)=>{let s=!1,r=t;for(;--r>=0&&"\\"===n[r];)s=!s;return s?"|":" |"})).split(/ \|/);let s=0;if(n[0].trim()||n.shift(),n.length>0&&!n[n.length-1].trim()&&n.pop(),n.length>t)n.splice(t);else for(;n.length<t;)n.push("");for(;s<n.length;s++)n[s]=n[s].trim().replace(/\\\|/g,"|");return n}function _(e,t,n){const s=e.length;if(0===s)return"";let r=0;for(;r<s;){const i=e.charAt(s-r-1);if(i!==t||n){if(i===t||!n)break;r++}else r++}return e.slice(0,s-r)}function $(e,t){if(t<1)return"";let n="";for(;t>1;)1&t&&(n+=e),t>>=1,e+=e;return n+e}function z(e,t,n,s){const r=t.href,i=t.title?a(t.title):null,l=e[1].replace(/\\([\[\]])/g,"$1");if("!"!==e[0].charAt(0)){s.state.inLink=!0;const e={type:"link",raw:n,href:r,title:i,text:l,tokens:s.inlineTokens(l)};return s.state.inLink=!1,e}return{type:"image",raw:n,href:r,title:i,text:a(l)}}class S{constructor(e){this.options=e||t}space(e){const t=this.rules.block.newline.exec(e);if(t&&t[0].length>0)return{type:"space",raw:t[0]}}code(e){const t=this.rules.block.code.exec(e);if(t){const e=t[0].replace(/^ {1,4}/gm,"");return{type:"code",raw:t[0],codeBlockStyle:"indented",text:this.options.pedantic?e:_(e,"\n")}}}fences(e){const t=this.rules.block.fences.exec(e);if(t){const e=t[0],n=function(e,t){const n=e.match(/^(\s+)(?:```)/);if(null===n)return t;const s=n[1];return t.split("\n").map((e=>{const t=e.match(/^\s+/);if(null===t)return e;const[n]=t;return n.length>=s.length?e.slice(s.length):e})).join("\n")}(e,t[3]||"");return{type:"code",raw:e,lang:t[2]?t[2].trim().replace(this.rules.inline._escapes,"$1"):t[2],text:n}}}heading(e){const t=this.rules.block.heading.exec(e);if(t){let e=t[2].trim();if(/#$/.test(e)){const t=_(e,"#");this.options.pedantic?e=t.trim():t&&!/ $/.test(t)||(e=t.trim())}return{type:"heading",raw:t[0],depth:t[1].length,text:e,tokens:this.lexer.inline(e)}}}hr(e)
|
||
|
/*!
|
||
|
* The reveal.js markdown plugin. Handles parsing of
|
||
|
* markdown inside of presentations as well as loading
|
||
|
* of external markdown documents.
|
||
|
*/
|
||
|
const N="__SCRIPT_END__",O=/\[\s*((\d*):)?\s*([\s\d,|-]*)\]/,D={"&":"&","<":"<",">":">",'"':""","'":"'"};return()=>{let e;function t(e){let t=(e.querySelector("[data-template]")||e.querySelector("script")||e).textContent;t=t.replace(new RegExp(N,"g"),"<\/script>");const n=t.match(/^\n?(\s*)/)[1].length,s=t.match(/^\n?(\t*)/)[1].length;return s>0?t=t.replace(new RegExp("\\n?\\t{"+s+"}(.*)","g"),(function(e,t){return"\n"+t})):n>1&&(t=t.replace(new RegExp("\\n? {"+n+"}(.*)","g"),(function(e,t){return"\n"+t}))),t}function n(e){const t=e.attributes,n=[];for(let e=0,s=t.length;e<s;e++){const s=t[e].name,r=t[e].value;/data\-(markdown|separator|vertical|notes)/gi.test(s)||(r?n.push(s+'="'+r+'"'):n.push(s))}return n.join(" ")}function s(t){const n=e?.getConfig?.().markdown;return(t=t||{}).separator=t.separator||n?.separator||"\r?\n---\r?\n",t.verticalSeparator=t.verticalSeparator||n?.verticalSeparator||null,t.notesSeparator=t.notesSeparator||n?.notesSeparator||"^s*notes?:",t.attributes=t.attributes||"",t}function r(e,t){t=s(t);const n=e.split(new RegExp(t.notesSeparator,"mgi"));return 2===n.length&&(e=n[0]+'<aside class="notes">'+P(n[1].trim())+"</aside>"),'<script type="text/template">'+(e=e.replace(/<\/script>/g,N))+"<\/script>"}function i(e,t){t=s(t);const n=new RegExp(t.separator+(t.verticalSeparator?"|"+t.verticalSeparator:""),"mg"),i=new RegExp(t.separator);let l,o,a,c=0,h=!0,p=[];for(;l=n.exec(e);)o=i.test(l[0]),!o&&h&&p.push([]),a=e.substring(c,l.index),o&&h?p.push(a):p[p.length-1].push(a),c=n.lastIndex,h=o;(h?p:p[p.length-1]).push(e.substring(c));let u="";for(let e=0,n=p.length;e<n;e++)p[e]instanceof Array?(u+="<section "+t.attributes+">",p[e].forEach((function(e){u+="<section data-markdown>"+r(e,t)+"</section>"})),u+="</section>"):u+="<section "+t.attributes+" data-markdown>"+r(p[e],t)+"</section>";return u}function l(e){return new Promise((function(s){const r=[];[].slice.call(e.querySelectorAll("section[data-markdown]:not([data-markdown-parsed])")).forEach((function(e,s){e.getAttribute("data-markdown").length?r.push(function(e){return new Promise((function(t,n){const s=new XMLHttpRequest,r=e.getAttribute("data-markdown"),i=e.getAttribute("data-charset");null!==i&&""!==i&&s.overrideMimeType("text/html; charset="+i),s.onreadystatechange=function(e,s){4===s.readyState&&(s.status>=200&&s.status<300||0===s.status?t(s,r):n(s,r))}.bind(this,e,s),s.open("GET",r,!0);try{s.send()}catch(e){console.warn("Failed to get the Markdown file "+r+". Make sure that the presentation and the file are served by a HTTP server and the file can be found there. "+e),t(s,r)}}))}(e).then((function(t,s){e.outerHTML=i(t.responseText,{separator:e.getAttribute("data-separator"),verticalSeparator:e.getAttribute("data-separator-vertical"),notesSeparator:e.getAttribute("data-separator-notes"),attributes:n(e)})}),(function(t,n){e.outerHTML='<section data-state="alert">ERROR: The attempt to fetch '+n+" failed with HTTP status "+t.status+".Check your browser's JavaScript console for more details.<p>Remember that you need to serve the presentation HTML from a HTTP server.</p></section>"}))):e.outerHTML=i(t(e),{separator:e.getAttribute("data-separator"),verticalSeparator:e.getAttribute("data-separator-vertical"),notesSeparator:e.getAttribute("data-separator-notes"),attributes:n(e)})})),Promise.all(r).then(s)}))}function o(e,t,n){const s=new RegExp(n,"mg"),r=new RegExp('([^"= ]+?)="([^"]+?)"|(data-[^"= ]+?)(?=[" ])',"mg");let i,l,o=e.nodeValue;if(i=s.exec(o)){const n=i[1];for(o=o.substring(0,i.index)+o.substring(s.lastIndex),e.nodeValue=o;l=r.exec(n);)l[2]?t.setAttribute(l[1],l[2]):t.setAttribute(l[3],"");return!0}return!1}function a(e,t,n,s,r){if(null!==t&&void 0!==t.childNodes&&t.childNodes.length>0){let n=t;for(let i=0;i<t.childNodes.length;i++){const l=t.childNodes[i];if(i>0){let e=i-1;for(;e>=0;){const s=t.childNodes[e];if("function"==typeof s.setAttribute&&"BR"!==s.tagName){n=s;break}e-=1}}let o=e;"section"===l.nodeName&&(o=l,n=l),"function"!=typeof l.setAttribute&&l.nodeType!==Node.COMMENT_NODE||a(o,l,n,s,r)}}t.nodeType===Node.COMMEN
|
||
|
|
||
|
</script>
|
||
|
<script>
|
||
|
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):(e="undefined"!=typeof globalThis?globalThis:e||self).RevealZoom=t()}(this,(function(){"use strict";
|
||
|
/*!
|
||
|
* reveal.js Zoom plugin
|
||
|
*/const e={id:"zoom",init:function(e){e.getRevealElement().addEventListener("mousedown",(function(o){var n=/Linux/.test(window.navigator.platform)?"ctrl":"alt",i=(e.getConfig().zoomKey?e.getConfig().zoomKey:n)+"Key",d=e.getConfig().zoomLevel?e.getConfig().zoomLevel:2;o[i]&&!e.isOverview()&&(o.preventDefault(),t.to({x:o.clientX,y:o.clientY,scale:d,pan:!1}))}))},destroy:()=>{t.reset()}};var t=function(){var e=1,o=0,n=0,i=-1,d=-1,l="transform"in document.body.style;function s(t,o){var n=r();if(t.width=t.width||1,t.height=t.height||1,t.x-=(window.innerWidth-t.width*o)/2,t.y-=(window.innerHeight-t.height*o)/2,l)if(1===o)document.body.style.transform="";else{var i=n.x+"px "+n.y+"px",d="translate("+-t.x+"px,"+-t.y+"px) scale("+o+")";document.body.style.transformOrigin=i,document.body.style.transform=d}else 1===o?(document.body.style.position="",document.body.style.left="",document.body.style.top="",document.body.style.width="",document.body.style.height="",document.body.style.zoom=""):(document.body.style.position="relative",document.body.style.left=-(n.x+t.x)/o+"px",document.body.style.top=-(n.y+t.y)/o+"px",document.body.style.width=100*o+"%",document.body.style.height=100*o+"%",document.body.style.zoom=o);e=o,document.documentElement.classList&&(1!==e?document.documentElement.classList.add("zoomed"):document.documentElement.classList.remove("zoomed"))}function c(){var t=.12*window.innerWidth,i=.12*window.innerHeight,d=r();n<i?window.scroll(d.x,d.y-14/e*(1-n/i)):n>window.innerHeight-i&&window.scroll(d.x,d.y+(1-(window.innerHeight-n)/i)*(14/e)),o<t?window.scroll(d.x-14/e*(1-o/t),d.y):o>window.innerWidth-t&&window.scroll(d.x+(1-(window.innerWidth-o)/t)*(14/e),d.y)}function r(){return{x:void 0!==window.scrollX?window.scrollX:window.pageXOffset,y:void 0!==window.scrollY?window.scrollY:window.pageYOffset}}return l&&(document.body.style.transition="transform 0.8s ease"),document.addEventListener("keyup",(function(o){1!==e&&27===o.keyCode&&t.out()})),document.addEventListener("mousemove",(function(t){1!==e&&(o=t.clientX,n=t.clientY)})),{to:function(o){if(1!==e)t.out();else{if(o.x=o.x||0,o.y=o.y||0,o.element){var n=o.element.getBoundingClientRect();o.x=n.left-20,o.y=n.top-20,o.width=n.width+40,o.height=n.height+40}void 0!==o.width&&void 0!==o.height&&(o.scale=Math.max(Math.min(window.innerWidth/o.width,window.innerHeight/o.height),1)),o.scale>1&&(o.x*=o.scale,o.y*=o.scale,s(o,o.scale),!1!==o.pan&&(i=setTimeout((function(){d=setInterval(c,1e3/60)}),800)))}},out:function(){clearTimeout(i),clearInterval(d),s({x:0,y:0},1),e=1},magnify:function(e){this.to(e)},reset:function(){this.out()},zoomLevel:function(){return e}}}();
|
||
|
/*!
|
||
|
* zoom.js 0.3 (modified for use with reveal.js)
|
||
|
* http://lab.hakim.se/zoom-js
|
||
|
* MIT licensed
|
||
|
*
|
||
|
* Copyright (C) 2011-2014 Hakim El Hattab, http://hakim.se
|
||
|
*/return()=>e}));
|
||
|
|
||
|
</script>
|
||
|
<script>
|
||
|
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(t="undefined"!=typeof globalThis?globalThis:t||self).RevealNotes=e()}(this,(function(){"use strict";function t(){return{async:!1,baseUrl:null,breaks:!1,extensions:null,gfm:!0,headerIds:!0,headerPrefix:"",highlight:null,hooks:null,langPrefix:"language-",mangle:!0,pedantic:!1,renderer:null,sanitize:!1,sanitizer:null,silent:!1,smartypants:!1,tokenizer:null,walkTokens:null,xhtml:!1}}let e={async:!1,baseUrl:null,breaks:!1,extensions:null,gfm:!0,headerIds:!0,headerPrefix:"",highlight:null,hooks:null,langPrefix:"language-",mangle:!0,pedantic:!1,renderer:null,sanitize:!1,sanitizer:null,silent:!1,smartypants:!1,tokenizer:null,walkTokens:null,xhtml:!1};const n=/[&<>"']/,i=new RegExp(n.source,"g"),s=/[<>"']|&(?!(#\d{1,7}|#[Xx][a-fA-F0-9]{1,6}|\w+);)/,r=new RegExp(s.source,"g"),a={"&":"&","<":"<",">":">",'"':""","'":"'"},o=t=>a[t];function l(t,e){if(e){if(n.test(t))return t.replace(i,o)}else if(s.test(t))return t.replace(r,o);return t}const c=/&(#(?:\d+)|(?:#x[0-9A-Fa-f]+)|(?:\w+));?/gi;function p(t){return t.replace(c,((t,e)=>"colon"===(e=e.toLowerCase())?":":"#"===e.charAt(0)?"x"===e.charAt(1)?String.fromCharCode(parseInt(e.substring(2),16)):String.fromCharCode(+e.substring(1)):""))}const u=/(^|[^\[])\^/g;function d(t,e){t="string"==typeof t?t:t.source,e=e||"";const n={replace:(e,i)=>(i=(i=i.source||i).replace(u,"$1"),t=t.replace(e,i),n),getRegex:()=>new RegExp(t,e)};return n}const h=/[^\w:]/g,g=/^$|^[a-z][a-z0-9+.-]*:|^[?#]/i;function m(t,e,n){if(t){let t;try{t=decodeURIComponent(p(n)).replace(h,"").toLowerCase()}catch(t){return null}if(0===t.indexOf("javascript:")||0===t.indexOf("vbscript:")||0===t.indexOf("data:"))return null}e&&!g.test(n)&&(n=function(t,e){f[" "+t]||(k.test(t)?f[" "+t]=t+"/":f[" "+t]=v(t,"/",!0));t=f[" "+t];const n=-1===t.indexOf(":");return"//"===e.substring(0,2)?n?e:t.replace(w,"$1")+e:"/"===e.charAt(0)?n?e:t.replace(x,"$1")+e:t+e}(e,n));try{n=encodeURI(n).replace(/%25/g,"%")}catch(t){return null}return n}const f={},k=/^[^:]+:\/*[^/]*$/,w=/^([^:]+:)[\s\S]*$/,x=/^([^:]+:\/*[^/]*)[\s\S]*$/;const b={exec:function(){}};function y(t,e){const n=t.replace(/\|/g,((t,e,n)=>{let i=!1,s=e;for(;--s>=0&&"\\"===n[s];)i=!i;return i?"|":" |"})).split(/ \|/);let i=0;if(n[0].trim()||n.shift(),n.length>0&&!n[n.length-1].trim()&&n.pop(),n.length>e)n.splice(e);else for(;n.length<e;)n.push("");for(;i<n.length;i++)n[i]=n[i].trim().replace(/\\\|/g,"|");return n}function v(t,e,n){const i=t.length;if(0===i)return"";let s=0;for(;s<i;){const r=t.charAt(i-s-1);if(r!==e||n){if(r===e||!n)break;s++}else s++}return t.slice(0,i-s)}function S(t,e){if(e<1)return"";let n="";for(;e>1;)1&e&&(n+=t),e>>=1,t+=t;return n+t}function T(t,e,n,i){const s=e.href,r=e.title?l(e.title):null,a=t[1].replace(/\\([\[\]])/g,"$1");if("!"!==t[0].charAt(0)){i.state.inLink=!0;const t={type:"link",raw:n,href:s,title:r,text:a,tokens:i.inlineTokens(a)};return i.state.inLink=!1,t}return{type:"image",raw:n,href:s,title:r,text:l(a)}}class _{constructor(t){this.options=t||e}space(t){const e=this.rules.block.newline.exec(t);if(e&&e[0].length>0)return{type:"space",raw:e[0]}}code(t){const e=this.rules.block.code.exec(t);if(e){const t=e[0].replace(/^ {1,4}/gm,"");return{type:"code",raw:e[0],codeBlockStyle:"indented",text:this.options.pedantic?t:v(t,"\n")}}}fences(t){const e=this.rules.block.fences.exec(t);if(e){const t=e[0],n=function(t,e){const n=t.match(/^(\s+)(?:```)/);if(null===n)return e;const i=n[1];return e.split("\n").map((t=>{const e=t.match(/^\s+/);if(null===e)return t;const[n]=e;return n.length>=i.length?t.slice(i.length):t})).join("\n")}(t,e[3]||"");return{type:"code",raw:t,lang:e[2]?e[2].trim().replace(this.rules.inline._escapes,"$1"):e[2],text:n}}}heading(t){const e=this.rules.block.heading.exec(t);if(e){let t=e[2].trim();if(/#$/.test(t)){const e=v(t,"#");this.options.pedantic?t=e.trim():e&&!/ $/.test(e)||(t=e.trim())}return{type:"heading",raw:e[0],depth:e[1].length,text:t,tokens:this.lexer.inline(t)}}}hr(t){co
|
||
|
|
||
|
</script>
|
||
|
|
||
|
|
||
|
<script>
|
||
|
// Full list of configuration options available here:
|
||
|
// https://github.com/hakimel/reveal.js#configuration
|
||
|
Reveal.initialize({
|
||
|
plugins: [RevealMarkdown, RevealZoom, RevealNotes],
|
||
|
slideNumber:"c/t"
|
||
|
});
|
||
|
|
||
|
</script>
|
||
|
</body>
|
||
|
</html>
|