Browse Source

Adds a /tags/ to list all valid tags

upstream
Zach Leatherman 4 years ago
parent
commit
ef7783222d
6 changed files with 45 additions and 2 deletions
  1. +2
    -0
      .eleventy.js
  2. +1
    -0
      .eleventyignore
  3. +29
    -0
      _11ty/getTagList.js
  4. +1
    -1
      package.json
  5. +10
    -0
      tags-list.njk
  6. +2
    -1
      tags.njk

+ 2
- 0
.eleventy.js View File

@ -19,6 +19,8 @@ module.exports = function(eleventyConfig) {
});
});
eleventyConfig.addCollection("tagList", require("./_11ty/getTagList"));
eleventyConfig.addPassthroughCopy("img");
eleventyConfig.addPassthroughCopy("css");


+ 1
- 0
.eleventyignore View File

@ -1 +1,2 @@
README.md
_11ty/

+ 29
- 0
_11ty/getTagList.js View File

@ -0,0 +1,29 @@
module.exports = function(collection) {
let tagList = {};
collection.getAllSorted().forEach(function(item) {
if( "tags" in item.data ) {
let tags = item.data.tags;
if( typeof tags === "string" ) {
tags = [tags];
}
tags.filter(function(item) {
switch(item) {
// this list should match the `filter` list in tags.njk
case "all":
case "nav":
case "post":
case "posts":
return false;
}
return true;
}).forEach(function(tag) {
tagList[tag] = true;
});
}
});
// returning an array in addCollection works in Eleventy 0.5.3
return Object.keys(tagList);
};

+ 1
- 1
package.json View File

@ -22,7 +22,7 @@
},
"homepage": "https://github.com/11ty/eleventy-base-blog#readme",
"devDependencies": {
"@11ty/eleventy": "^0.4.0",
"@11ty/eleventy": "^0.5.3",
"@11ty/eleventy-plugin-rss": "^1.0.2",
"@11ty/eleventy-plugin-syntaxhighlight": "^1.0.5",
"luxon": "^1.0.0",


+ 10
- 0
tags-list.njk View File

@ -0,0 +1,10 @@
---
permalink: /tags/
layout: layouts/home.njk
---
<h1>Tags</h1>
{% for tag in collections.tagList %}
{% set tagUrl %}/tags/{{ tag }}/{% endset %}
<a href="{{ tagUrl | url }}" class="tag">{{ tag }}</a>
{% endfor %}

+ 2
- 1
tags.njk View File

@ -11,8 +11,9 @@ pagination:
permalink: /tags/{{ tag }}/
layout: layouts/home.njk
---
<h1>Tagged “{{ tag }}”</h1>
{% set postslist = collections[ tag ] %}
{% include "postslist.njk" %}
<p>See <a href="/tags/">all tags</a>.</p>

Loading…
Cancel
Save