From 122f33b985224a1f94b6400190df8d2efb0739fd Mon Sep 17 00:00:00 2001 From: Alfred Xing Date: Wed, 8 Oct 2014 21:12:20 -0700 Subject: [PATCH 1/3] Move Date object from `page.title` to `page.date` --- lib/jekyll-archives/archive.rb | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/lib/jekyll-archives/archive.rb b/lib/jekyll-archives/archive.rb index 0a5800a..ca3592d 100644 --- a/lib/jekyll-archives/archive.rb +++ b/lib/jekyll-archives/archive.rb @@ -13,6 +13,7 @@ class Archive posts type title + date name path url @@ -116,14 +117,21 @@ def to_liquid(attrs = nil) # Produce a title object suitable for Liquid based on type of archive. # - # Returns the title as a Date (for date-based archives) or a - # String (for tag and category archives) + # Returns a String (for tag and category archives) and nil for + # date-based archives. def title + if @title.is_a? String + @title + end + end + + # Produce a date object if a date-based archive + # + # Returns a Date. + def date if @title.is_a? Hash args = @title.values.map { |s| s.to_i } Date.new(*args) - else - @title end end From 8e506482a928d428ade3feeb72953263b4140526 Mon Sep 17 00:00:00 2001 From: Alfred Xing Date: Sat, 11 Oct 2014 14:11:15 -0700 Subject: [PATCH 2/3] Add tests for `page.title` and `page.date` --- test/test_jekyll_archives.rb | 39 ++++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) diff --git a/test/test_jekyll_archives.rb b/test/test_jekyll_archives.rb index e3621a6..01eabda 100644 --- a/test/test_jekyll_archives.rb +++ b/test/test_jekyll_archives.rb @@ -158,4 +158,43 @@ class TestJekyllArchives < Minitest::Test assert !archive_exists?(@site, "category/plugins/index.html") end end + + context "the jekyll-archives plugin" do + setup do + @site = fixture_site({ + "jekyll-archives" => { + "enabled" => true + } + }) + @site.process + @archives = @site.config["archives"] + @tag_archive = @archives.detect {|a| a.type == "tag"} + @category_archive = @archives.detect {|a| a.type == "category"} + @year_archive = @archives.detect {|a| a.type == "year"} + @month_archive = @archives.detect {|a| a.type == "month"} + @day_archive = @archives.detect {|a| a.type == "day"} + end + + should "populate the title field in case of category or tag" do + assert @tag_archive.title.is_a? String + assert @category_archive.title.is_a? String + end + + should "use nil for the title field in case of dates" do + assert @year_archive.title.nil? + assert @month_archive.title.nil? + assert @day_archive.title.nil? + end + + should "use nil for the date field in case of category or tag" do + assert @tag_archive.date.nil? + assert @category_archive.date.nil? + end + + should "populate the date field with a Date in case of dates" do + assert @year_archive.date.is_a? Date + assert @month_archive.date.is_a? Date + assert @day_archive.date.is_a? Date + end + end end From e35d6dde782e1583d6f524e98e28e91f894a3864 Mon Sep 17 00:00:00 2001 From: Alfred Xing Date: Sat, 11 Oct 2014 14:15:09 -0700 Subject: [PATCH 3/3] Update documentation --- docs/layouts.md | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/docs/layouts.md b/docs/layouts.md index 2ffd2f0..6165a7f 100644 --- a/docs/layouts.md +++ b/docs/layouts.md @@ -1,10 +1,13 @@ # Layouts -Archives layouts are special layouts that specify how an archive page is displayed. Special attributes are available to these layouts to represent information about the specific layout being generated. These layouts are otherwise identical to regular Jekyll layouts. +Archives layouts are special layouts that specify how an archive page is displayed. Special attributes are available to these layouts to represent information about the specific layout being generated. These layouts are otherwise identical to regular Jekyll layouts. To handle the variety of cases presented through the attributes, we recommend that you use [type-specific layouts](./configuration.md#type-specific-layouts). ### Layout attributes #### Title (`page.title`) -The `page.title` attribute contains information regarding the name or header of the archive. For tag and category archives, this is simply the name of the tag/category. For date-based archives (year, month, and day), this attribute contains a Date object that can be used to present the date header of the archive in a suitable format. For year archives, the month and day components of the Date object passed to Liquid should be neglected; similarly, for month archives, the day component should be neglected. To handle the variety of cases presented, we recommend that you use [type-specific layouts](./configuration.md#type-specific-layouts). We recommend using the [`date` filter](http://docs.shopify.com/themes/liquid-documentation/filters/additional-filters#date) in Liquid to process the Date objects. +The `page.title` attribute contains information regarding the name of the archive *if and only if* the archive is a tag or category archive. In this case, the attribute simply contains the name of the tag/category. For date-based archives (year, month, and day), this attribute is `nil`. + +#### Date (`page.date`) +In the case of a date archive, this attribute contains a Date object that can be used to present the date header of the archive in a suitable format. For year archives, the month and day components of the Date object passed to Liquid should be neglected; similarly, for month archives, the day component should be neglected. We recommend using the [`date` filter](http://docs.shopify.com/themes/liquid-documentation/filters/additional-filters#date) in Liquid to process the Date objects. For tag and category archives, this field is `nil`. #### Posts (`page.posts`) The `page.posts` attribute contains an array of Post objects matching the archive criteria. You can iterate over this array just like any other Post array in Jekyll.