diff options
| author | Christine Dodrill <me@christine.website> | 2019-05-21 21:47:09 -0400 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2019-05-21 21:47:09 -0400 |
| commit | d64c666255665c5e03812c47e70d6edb46432510 (patch) | |
| tree | 1dd44e77f7d57a5a52ccfa0fe96fc073cb3da2fe /templates | |
| parent | a275fc754b4c82a81ba06f0f3cbddb39946db1ac (diff) | |
| download | xesite-d64c666255665c5e03812c47e70d6edb46432510.tar.xz xesite-d64c666255665c5e03812c47e70d6edb46432510.zip | |
add talks support (#40)
* add talks support
* gosimplify
Diffstat (limited to 'templates')
| -rw-r--r-- | templates/base.html | 2 | ||||
| -rw-r--r-- | templates/talkindex.html | 20 | ||||
| -rw-r--r-- | templates/talkpost.html | 103 |
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 }} |
