aboutsummaryrefslogtreecommitdiff
path: root/templates
diff options
context:
space:
mode:
authorChristine Dodrill <me@christine.website>2019-05-21 21:47:09 -0400
committerGitHub <noreply@github.com>2019-05-21 21:47:09 -0400
commitd64c666255665c5e03812c47e70d6edb46432510 (patch)
tree1dd44e77f7d57a5a52ccfa0fe96fc073cb3da2fe /templates
parenta275fc754b4c82a81ba06f0f3cbddb39946db1ac (diff)
downloadxesite-d64c666255665c5e03812c47e70d6edb46432510.tar.xz
xesite-d64c666255665c5e03812c47e70d6edb46432510.zip
add talks support (#40)
* add talks support * gosimplify
Diffstat (limited to 'templates')
-rw-r--r--templates/base.html2
-rw-r--r--templates/talkindex.html20
-rw-r--r--templates/talkpost.html103
3 files changed, 124 insertions, 1 deletions
diff --git a/templates/base.html b/templates/base.html
index 1cbaff3..3fdc591 100644
--- a/templates/base.html
+++ b/templates/base.html
@@ -59,7 +59,7 @@
{{ template "scripts" . }}
<div class="container">
<header>
- <p><a href="/">Christine Dodrill</a> - <a href="/blog">Blog</a> - <a href="/contact">Contact</a> - <a href="/resume">Resume</a> | <a target="_blank" rel="noopener noreferrer" href="https://graphviz.christine.website">GraphViz</a> - <a target="_blank" rel="noopener noreferrer" href="https://when-then-zen.christine.website/">When Then Zen</a></p>
+ <p><a href="/">Christine Dodrill</a> - <a href="/blog">Blog</a> - <a href="/contact">Contact</a> - <a href="/resume">Resume</a> - <a href="/talks">Talks</a> | <a target="_blank" rel="noopener noreferrer" href="https://graphviz.christine.website">GraphViz</a> - <a target="_blank" rel="noopener noreferrer" href="https://when-then-zen.christine.website/">When Then Zen</a></p>
</header>
<div class="snowframe">
diff --git a/templates/talkindex.html b/templates/talkindex.html
new file mode 100644
index 0000000..9fad850
--- /dev/null
+++ b/templates/talkindex.html
@@ -0,0 +1,20 @@
+{{ define "title" }}
+<title>Blog - Christine Dodrill</title>
+{{ end }}
+
+{{ define "content" }}
+<h1>Talks</h1>
+
+<p>Here is a link to all of the talks I have done at conferences. Each of these will have links to the slides (PDF) as well as some brief information about them.</p>
+
+<p>If you have a compatible reader, be sure to check out my <a href="/blog.rss">RSS Feed</a> for automatic updates. Also check out the <a href="/blog.json">JSONFeed</a>.</p>
+
+<p>
+ <ul>
+ {{ range . }}
+ <li>{{ .DateString }} - <a href="{{ .Link }}">{{ .Title }}</a></li>
+ {{ end }}
+ </ul>
+</p>
+
+{{ end }}
diff --git a/templates/talkpost.html b/templates/talkpost.html
new file mode 100644
index 0000000..94ddc0f
--- /dev/null
+++ b/templates/talkpost.html
@@ -0,0 +1,103 @@
+{{ define "title" }}
+<title>{{ .Title }} - Christine Dodrill</title>
+
+<!-- Twitter -->
+<meta name="twitter:card" content="summary" />
+<meta name="twitter:site" content="@theprincessxena" />
+<meta name="twitter:title" content="{{ .Title }}" />
+<meta name="twitter:description" content="Posted on {{ .Date }}" />
+
+<!-- Facebook -->
+<meta property="og:type" content="website" />
+<meta property="og:title" content="{{ .Title }}" />
+<meta property="og:site_name" content="Talk by Christine Dodrill" />
+
+<!-- Description -->
+<meta name="description" content="{{ .Title }} - Talk by Christine Dodrill" />
+<meta name="author" content="Christine Dodrill">
+
+<link rel="canonical" href="https://christine.website/{{ .Link }}">
+
+<script type="application/ld+json">
+ {
+ "@context": "http://schema.org",
+ "@type": "Article",
+ "headline": "{{ .Title }}",
+ "image": "https://christine.website/static/img/avatar.png",
+ "url": "https://christine.website/{{ .Link }}",
+ "datePublished": "{{ .Date }}",
+ "mainEntityOfPage": {
+ "@type": "WebPage",
+ "@id": "https://christine.website/{{ .Link }}"
+ },
+ "author": {
+ "@type": "Person",
+ "name": "Christine Dodrill"
+ },
+ "publisher": {
+ "@type": "Person",
+ "name": "Christine Dodrill"
+ }
+ }
+</script>
+{{ end }}
+
+{{ define "content" }}
+{{ .BodyHTML }}
+
+<a href="{{ .SlidesLink }}">Link to the slides</a>
+
+<hr />
+
+<!-- The button that should be clicked. -->
+<button onclick="share_on_mastodon()">Share on Mastodon</button>
+<script>
+
+// The actual function. Set this as an onclick function for your "Share on Mastodon" button
+function share_on_mastodon() {
+ // Prefill the form with the user's previously-specified Mastodon instance, if applicable
+ var default_url = localStorage['mastodon_instance'];
+
+ // If there is no cached instance/domain, then insert a "https://" with no domain at the start of the prompt.
+ if (!default_url)
+ default_url = "https://";
+
+ var instance = prompt("Enter your instance's address: (ex: https://linuxrocks.online)", default_url);
+ if (instance) {
+ // Handle URL formats
+ if ( !instance.startsWith("https://") && !instance.startsWith("http://") )
+ instance = "https://" + instance;
+
+ // Get the current page's URL
+ var url = window.location.href;
+
+ // Get the page title from the og:title meta tag, if it exists.
+ var title = document.querySelectorAll('meta[property="og:title"]')[0].getAttribute("content");
+
+ // Otherwise, use the <title> tag as the title
+ if (!title) var title = document.getElementsByTagName("title")[0].innerHTML;
+
+ // Handle slash
+ if ( !instance.endsWith("/") )
+ instance = instance + "/";
+
+ // Cache the instance/domain for future requests
+ localStorage['mastodon_instance'] = instance;
+
+ // Hashtags
+ var hashtags = "#blogpost";
+
+ // Tagging users, such as offical accounts or the author of the post
+ var author = "@cadey@mst3k.interlinked.me";
+
+ // Create the Share URL
+ // https://someinstance.tld/share?text=URL%20encoded%20text
+ mastodon_url = instance + "share?text=" + encodeURIComponent(title + "\n\n" + url + "\n\n" + hashtags + " " + author);
+
+ // Open a new window at the share location
+ window.open(mastodon_url, '_blank');
+ }
+}
+</script>
+
+{{ end }}