Skip to content

Instantly share code, notes, and snippets.

@veganstraightedge
Last active May 30, 2017 00:29
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save veganstraightedge/6a5825de9fbfb69fbd714b961f094cd9 to your computer and use it in GitHub Desktop.
Save veganstraightedge/6a5825de9fbfb69fbd714b961f094cd9 to your computer and use it in GitHub Desktop.
Before and after Microformats on GitHub

Hi.

(In case your email software doesn’t render Markdown, I pasted this into a Gist.)

https://gist.github.com/veganstraightedge/6a5825de9fbfb69fbd714b961f094cd9


On a user profile, there used to be Microformats. They’re all gone now. Please return them. :)

h-card

Here’s an example of how to add Microformats 2 (h-card) back to the profile sidebar.

https://gist.github.com/veganstraightedge/6a5825de9fbfb69fbd714b961f094cd9

(I’ll leave adding classical microformats (hCard) back as an exercise for the reader. Its root class is vCard.))


h-feed

You could also add h-feed Microformats to commits pages (and anywhere else where there is time streamed entries).

For example, this page:

https://github.com/veganstraightedge/microformats.io/commits/master

could have a structure like this:

.h-feed (around the whole list of commits)

.h-entry (around each commit)
.p-author (on the committer’s username link)
.p-name (on the commit message link)
.u-url (on the commit message link too)
.dt-published (on the commit time tag)

If avatar and username were in the same parent HTML, you could wrap them in a combination .p-author.h-card and give the avatar a class of u-photo and the username a class of p-name. Thus specifying that this is the author of the post and this is their name and photo. If not, simply .p-author on username is sufficient.


h-entry (commits)

On a single commit page, you could add all the same classes as above from the h-feed section. And additionally, you could wrap the commit payload in an e-content.

Comments should be treated as separate entries too. Additionally, each comment should have a u-in-reply-to class on a link to the previous post (either the original commit or the comment above it) to allowing conversation threading to be inferred.


h-feed (issues)

Same as commits pages.


h-entry (issues)

Same as commit pages.


Testing

You can read more about Microformats at:

https://microformats.io http://microformats.org/wiki http://microformats.org/wiki/h-card http://microformats.org/wiki/h-feed http://microformats.org/wiki/h-entry

You can use the in-brower parser for testing while developing.

https://ruby.microformats.io

And you can use the Microformats parser gem to write automated tests to ensure that this regression doesn’t happen again.

https://github.com/indieweb/microformats-ruby

Thank you so much. — Shane

<div class="col-3 float-left pr-3" itemscope="" itemtype="http://schema.org/Person">
<div class="user-profile-sticky-bar js-user-profile-sticky-bar">
<div class="user-profile-mini-vcard d-table">
<span class="user-profile-mini-avatar d-table-cell v-align-middle lh-condensed-ultra pr-2">
<img alt="@veganstraightedge" class="rounded-1" height="32" src="https://avatars3.githubusercontent.com/u/4361?v=3&amp;s=64" width="32">
</span>
<span class="d-table-cell v-align-middle lh-condensed js-user-profile-following-mini-toggle">
<strong>veganstraightedge</strong>
</span>
</div>
</div>
<a href="/account" aria-label="Change your avatar" class="vcard-avatar d-block tooltipped tooltipped-s"><img alt="" class="avatar width-full rounded-2" height="230" src="https://avatars0.githubusercontent.com/u/4361?v=3&amp;s=460" width="230"></a>
<div class="vcard-names-container py-3 js-user-profile-sticky-fields is-placeholder" style="visibility: hidden; display: none; height: 85.5999984741211px;"></div><div class="vcard-names-container py-3 js-sticky js-user-profile-sticky-fields " style="position: static;">
<h1 class="vcard-names">
<span class="vcard-fullname d-block" itemprop="name">Shane Becker</span>
<span class="vcard-username d-block" itemprop="additionalName">veganstraightedge</span>
</h1>
</div>
<div class="user-profile-bio">
<div>
Formerly: The <a href="https://github.com/farmhouse" class="user-mention">@Farmhouse</a> in Hollywood, CA and #LittleMisadventureTime.
Currently: Lead Engineer at <a href="https://github.com/teamhappily" class="user-mention">@teamhappily</a>.
</div>
</div>
<ul class="vcard-details border-top border-gray-light py-3">
<li aria-label="Organization" class="vcard-detail pt-1 css-truncate css-truncate-target" itemprop="worksFor" show_title="false"><svg aria-hidden="true" class="octicon octicon-organization" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M16 12.999c0 .439-.45 1-1 1H7.995c-.539 0-.994-.447-.995-.999H1c-.54 0-1-.561-1-1 0-2.634 3-4 3-4s.229-.409 0-1c-.841-.621-1.058-.59-1-3 .058-2.419 1.367-3 2.5-3s2.442.58 2.5 3c.058 2.41-.159 2.379-1 3-.229.59 0 1 0 1s1.549.711 2.42 2.088C9.196 9.369 10 8.999 10 8.999s.229-.409 0-1c-.841-.62-1.058-.59-1-3 .058-2.419 1.367-3 2.5-3s2.437.581 2.495 3c.059 2.41-.158 2.38-1 3-.229.59 0 1 0 1s3.005 1.366 3.005 4"></path></svg><div><a href="https://github.com/teamhappily" class="user-mention">@teamhappily</a></div></li>
<li aria-label="Home location" class="vcard-detail pt-1 css-truncate css-truncate-target" itemprop="homeLocation" title=" Portland, Oregon ">
<svg aria-hidden="true" class="octicon octicon-location" height="16" version="1.1" viewBox="0 0 12 16" width="12"><path fill-rule="evenodd" d="M6 0C2.69 0 0 2.5 0 5.5 0 10.02 6 16 6 16s6-5.98 6-10.5C12 2.5 9.31 0 6 0zm0 14.55C4.14 12.52 1 8.44 1 5.5 1 3.02 3.25 1 6 1c1.34 0 2.61.48 3.56 1.36.92.86 1.44 1.97 1.44 3.14 0 2.94-3.14 7.02-5 9.05zM8 5.5c0 1.11-.89 2-2 2-1.11 0-2-.89-2-2 0-1.11.89-2 2-2 1.11 0 2 .89 2 2z"></path></svg>
Portland, Oregon
</li>
<li aria-label="Email" class="vcard-detail pt-1 css-truncate css-truncate-target" itemprop="email"><svg aria-hidden="true" class="octicon octicon-mail" height="16" version="1.1" viewBox="0 0 14 16" width="14"><path fill-rule="evenodd" d="M0 4v8c0 .55.45 1 1 1h12c.55 0 1-.45 1-1V4c0-.55-.45-1-1-1H1c-.55 0-1 .45-1 1zm13 0L7 9 1 4h12zM1 5.5l4 3-4 3v-6zM2 12l3.5-3L7 10.5 8.5 9l3.5 3H2zm11-.5l-4-3 4-3v6z"></path></svg>
<a href="mailto:veganstraightedge@gmail.com">veganstraightedge@gmail.com</a>
</li>
<li aria-label="Blog or website" class="vcard-detail pt-1 css-truncate css-truncate-target" itemprop="url"><svg aria-hidden="true" class="octicon octicon-link" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg>
<a href="https://veganstraightedge.com" class="url" rel="nofollow me">https://veganstraightedge.com</a>
</li>
</ul>
<div class="border-top py-3 clearfix">
<h2 class="mb-1 h4">Organizations</h2>
<a href="/microformats" aria-label="microformats" class="tooltipped tooltipped-n avatar-group-item" itemprop="follows"><img alt="@microformats" class="avatar" height="35" src="https://avatars3.githubusercontent.com/u/42430?v=3&amp;s=70" width="35"></a>
<a href="/larb" aria-label="larb" class="tooltipped tooltipped-n avatar-group-item" itemprop="follows"><img alt="@larb" class="avatar" height="35" src="https://avatars1.githubusercontent.com/u/687712?v=3&amp;s=70" width="35"></a>
<a href="/darkmatterapp" aria-label="darkmatterapp" class="tooltipped tooltipped-n avatar-group-item" itemprop="follows"><img alt="@darkmatterapp" class="avatar" height="35" src="https://avatars2.githubusercontent.com/u/792213?v=3&amp;s=70" width="35"></a>
<a href="/Farmhouse" aria-label="Farmhouse" class="tooltipped tooltipped-n avatar-group-item" itemprop="follows"><img alt="@Farmhouse" class="avatar" height="35" src="https://avatars1.githubusercontent.com/u/1372501?v=3&amp;s=70" width="35"></a>
<a href="/indieweb" aria-label="indieweb" class="tooltipped tooltipped-n avatar-group-item" itemprop="follows"><img alt="@indieweb" class="avatar" height="35" src="https://avatars3.githubusercontent.com/u/1911753?v=3&amp;s=70" width="35"></a>
<a href="/DateEdge" aria-label="DateEdge" class="tooltipped tooltipped-n avatar-group-item" itemprop="follows"><img alt="@DateEdge" class="avatar" height="35" src="https://avatars2.githubusercontent.com/u/6226773?v=3&amp;s=70" width="35"></a>
<a href="/teamhappily" aria-label="teamhappily" class="tooltipped tooltipped-n avatar-group-item" itemprop="follows"><img alt="@teamhappily" class="avatar" height="35" src="https://avatars1.githubusercontent.com/u/9488400?v=3&amp;s=70" width="35"></a>
<a href="/freeterritory" aria-label="freeterritory" class="tooltipped tooltipped-n avatar-group-item" itemprop="follows"><img alt="@freeterritory" class="avatar" height="35" src="https://avatars0.githubusercontent.com/u/15861697?v=3&amp;s=70" width="35"></a>
<a href="/crimethinc" aria-label="crimethinc" class="tooltipped tooltipped-n avatar-group-item" itemprop="follows"><img alt="@crimethinc" class="avatar" height="35" src="https://avatars0.githubusercontent.com/u/21285375?v=3&amp;s=70" width="35"></a>
<a href="/kypsy" aria-label="kypsy" class="tooltipped tooltipped-n avatar-group-item" itemprop="follows"><img alt="@kypsy" class="avatar" height="35" src="https://avatars1.githubusercontent.com/u/25023355?v=3&amp;s=70" width="35"></a>
</div>
</div>
<div class="col-3 float-left pr-3 h-card" itemscope="" itemtype="http://schema.org/Person">
<div class="user-profile-sticky-bar js-user-profile-sticky-bar">
<div class="user-profile-mini-vcard d-table">
<span class="user-profile-mini-avatar d-table-cell v-align-middle lh-condensed-ultra pr-2">
<img alt="@veganstraightedge" class="rounded-1 u-photo" height="32" src="https://avatars3.githubusercontent.com/u/4361?v=3&amp;s=64" width="32">
</span>
<span class="d-table-cell v-align-middle lh-condensed js-user-profile-following-mini-toggle">
<strong>veganstraightedge</strong>
</span>
</div>
</div>
<a href="/account" aria-label="Change your avatar" class="vcard-avatar d-block tooltipped tooltipped-s"><img alt="" class="avatar width-full rounded-2" height="230" src="https://avatars0.githubusercontent.com/u/4361?v=3&amp;s=460" width="230"></a>
<div class="vcard-names-container py-3 js-user-profile-sticky-fields is-placeholder" style="visibility: hidden; display: none; height: 85.5999984741211px;"></div><div class="vcard-names-container py-3 js-sticky js-user-profile-sticky-fields " style="position: static;">
<h1 class="vcard-names">
<span class="vcard-fullname d-block p-name" itemprop="name">Shane Becker</span>
<span class="vcard-username d-block p-nickname" itemprop="additionalName">veganstraightedge</span>
</h1>
</div>
<div class="user-profile-bio e-note">
<div>
Formerly: The <a href="https://github.com/farmhouse" class="user-mention">@Farmhouse</a> in Hollywood, CA and #LittleMisadventureTime.
Currently: Lead Engineer at <a href="https://github.com/teamhappily" class="user-mention">@teamhappily</a>.
</div>
</div>
<ul class="vcard-details border-top border-gray-light py-3">
<li aria-label="Organization" class="vcard-detail pt-1 css-truncate css-truncate-target p-org" itemprop="worksFor" show_title="false"><svg aria-hidden="true" class="octicon octicon-organization" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M16 12.999c0 .439-.45 1-1 1H7.995c-.539 0-.994-.447-.995-.999H1c-.54 0-1-.561-1-1 0-2.634 3-4 3-4s.229-.409 0-1c-.841-.621-1.058-.59-1-3 .058-2.419 1.367-3 2.5-3s2.442.58 2.5 3c.058 2.41-.159 2.379-1 3-.229.59 0 1 0 1s1.549.711 2.42 2.088C9.196 9.369 10 8.999 10 8.999s.229-.409 0-1c-.841-.62-1.058-.59-1-3 .058-2.419 1.367-3 2.5-3s2.437.581 2.495 3c.059 2.41-.158 2.38-1 3-.229.59 0 1 0 1s3.005 1.366 3.005 4"></path></svg><div><a href="https://github.com/teamhappily" class="user-mention">@teamhappily</a></div></li>
<li aria-label="Home location" class="vcard-detail pt-1 css-truncate css-truncate-target p-location" itemprop="homeLocation" title=" Portland, Oregon ">
<svg aria-hidden="true" class="octicon octicon-location" height="16" version="1.1" viewBox="0 0 12 16" width="12"><path fill-rule="evenodd" d="M6 0C2.69 0 0 2.5 0 5.5 0 10.02 6 16 6 16s6-5.98 6-10.5C12 2.5 9.31 0 6 0zm0 14.55C4.14 12.52 1 8.44 1 5.5 1 3.02 3.25 1 6 1c1.34 0 2.61.48 3.56 1.36.92.86 1.44 1.97 1.44 3.14 0 2.94-3.14 7.02-5 9.05zM8 5.5c0 1.11-.89 2-2 2-1.11 0-2-.89-2-2 0-1.11.89-2 2-2 1.11 0 2 .89 2 2z"></path></svg>
Portland, Oregon
</li>
<li aria-label="Email" class="vcard-detail pt-1 css-truncate css-truncate-target" itemprop="email"><svg aria-hidden="true" class="octicon octicon-mail" height="16" version="1.1" viewBox="0 0 14 16" width="14"><path fill-rule="evenodd" d="M0 4v8c0 .55.45 1 1 1h12c.55 0 1-.45 1-1V4c0-.55-.45-1-1-1H1c-.55 0-1 .45-1 1zm13 0L7 9 1 4h12zM1 5.5l4 3-4 3v-6zM2 12l3.5-3L7 10.5 8.5 9l3.5 3H2zm11-.5l-4-3 4-3v6z"></path></svg>
<a href="mailto:veganstraightedge@gmail.com" class="u-email">veganstraightedge@gmail.com</a>
</li>
<li aria-label="Blog or website" class="vcard-detail pt-1 css-truncate css-truncate-target" itemprop="url"><svg aria-hidden="true" class="octicon octicon-link" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg>
<a href="https://veganstraightedge.com" class="url u-url" rel="nofollow me">https://veganstraightedge.com</a>
</li>
</ul>
<div class="border-top py-3 clearfix">
<h2 class="mb-1 h4">Organizations</h2>
<a href="/microformats" aria-label="microformats" class="tooltipped tooltipped-n avatar-group-item p-org" itemprop="follows"><img alt="@microformats" class="avatar" height="35" src="https://avatars3.githubusercontent.com/u/42430?v=3&amp;s=70" width="35"></a>
<a href="/larb" aria-label="larb" class="tooltipped tooltipped-n avatar-group-item p-org" itemprop="follows"><img alt="@larb" class="avatar" height="35" src="https://avatars1.githubusercontent.com/u/687712?v=3&amp;s=70" width="35"></a>
<a href="/darkmatterapp" aria-label="darkmatterapp" class="tooltipped tooltipped-n avatar-group-item p-org" itemprop="follows"><img alt="@darkmatterapp" class="avatar" height="35" src="https://avatars2.githubusercontent.com/u/792213?v=3&amp;s=70" width="35"></a>
<a href="/Farmhouse" aria-label="Farmhouse" class="tooltipped tooltipped-n avatar-group-item p-org" itemprop="follows"><img alt="@Farmhouse" class="avatar" height="35" src="https://avatars1.githubusercontent.com/u/1372501?v=3&amp;s=70" width="35"></a>
<a href="/indieweb" aria-label="indieweb" class="tooltipped tooltipped-n avatar-group-item p-org" itemprop="follows"><img alt="@indieweb" class="avatar" height="35" src="https://avatars3.githubusercontent.com/u/1911753?v=3&amp;s=70" width="35"></a>
<a href="/DateEdge" aria-label="DateEdge" class="tooltipped tooltipped-n avatar-group-item p-org" itemprop="follows"><img alt="@DateEdge" class="avatar" height="35" src="https://avatars2.githubusercontent.com/u/6226773?v=3&amp;s=70" width="35"></a>
<a href="/teamhappily" aria-label="teamhappily" class="tooltipped tooltipped-n avatar-group-item p-org" itemprop="follows"><img alt="@teamhappily" class="avatar" height="35" src="https://avatars1.githubusercontent.com/u/9488400?v=3&amp;s=70" width="35"></a>
<a href="/freeterritory" aria-label="freeterritory" class="tooltipped tooltipped-n avatar-group-item p-org" itemprop="follows"><img alt="@freeterritory" class="avatar" height="35" src="https://avatars0.githubusercontent.com/u/15861697?v=3&amp;s=70" width="35"></a>
<a href="/crimethinc" aria-label="crimethinc" class="tooltipped tooltipped-n avatar-group-item p-org" itemprop="follows"><img alt="@crimethinc" class="avatar" height="35" src="https://avatars0.githubusercontent.com/u/21285375?v=3&amp;s=70" width="35"></a>
<a href="/kypsy" aria-label="kypsy" class="tooltipped tooltipped-n avatar-group-item p-org" itemprop="follows"><img alt="@kypsy" class="avatar" height="35" src="https://avatars1.githubusercontent.com/u/25023355?v=3&amp;s=70" width="35"></a>
</div>
</div>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment