jekyll-author-page 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (3) hide show
  1. checksums.yaml +7 -0
  2. data/lib/jekyll-author-page.rb +76 -0
  3. metadata +44 -0
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: ed4d505a4f1b5ba3ae2c27860f0be4634f24e921
4
+ data.tar.gz: 1bcba1e3d48379736e5f22e888be475314b705c2
5
+ SHA512:
6
+ metadata.gz: c14a15154b1f0cf9252029959a73f1ede904e09d4e4d73c5afaf775d1535098efad154463089b4d0dcce55fb342ab877d3387a02e389ec2fd24efa803d51a776
7
+ data.tar.gz: 955e61ea3d47a9db444af79c77fae692176ab986a29d66761272e878592f350ede4eb16267c515c308cce8e2bb92e9e95d95922414a46871e2852cc393704075
@@ -0,0 +1,76 @@
1
+ module Jekyll
2
+
3
+ class AuthorsGenerator < Generator
4
+
5
+ safe true
6
+
7
+ def generate(site)
8
+ site.data['authors'].each do |author, data|
9
+ posts = [author, posts_by_author(site, author)]
10
+ build_subpages(site, 'author', posts)
11
+ end
12
+ end
13
+
14
+ def build_subpages(site, type, posts)
15
+ posts[1] = posts[1].sort_by { |p| -p.date.to_f }
16
+ atomize(site, type, posts)
17
+ paginate(site, type, posts)
18
+ end
19
+
20
+ def atomize(site, type, posts)
21
+ path = "/author/#{posts[0]}"
22
+ atom = AtomPageAuthor.new(site, site.source, path, type, posts[0], posts[1])
23
+ site.pages << atom
24
+ end
25
+
26
+ def paginate(site, type, posts)
27
+ pages = Jekyll::Paginate::Pager.calculate_pages(posts[1], site.config['paginate'].to_i)
28
+ (1..pages).each do |num_page|
29
+ pager = Jekyll::Paginate::Pager.new(site, num_page, posts[1], pages)
30
+ path = "/author/#{posts[0]}"
31
+ if num_page > 1
32
+ path = path + "/page#{num_page}"
33
+ end
34
+ newpage = GroupSubPageAuthor.new(site, site.source, path, type, posts[0])
35
+ newpage.pager = pager
36
+ site.pages << newpage
37
+
38
+ end
39
+ end
40
+
41
+ private
42
+
43
+ def posts_by_author(site, author)
44
+ site.posts.docs.select { |post| post.data['author'] == author }
45
+ end
46
+ end
47
+
48
+ class GroupSubPageAuthor < Page
49
+ def initialize(site, base, dir, type, val)
50
+ @site = site
51
+ @base = base
52
+ @dir = dir
53
+ @name = 'index.html'
54
+
55
+ self.process(@name)
56
+ self.read_yaml(File.join(base, '_layouts'), "author.html")
57
+ self.data["grouptype"] = type
58
+ self.data[type] = val
59
+ end
60
+ end
61
+
62
+ class AtomPageAuthor < Page
63
+ def initialize(site, base, dir, type, val, posts)
64
+ @site = site
65
+ @base = base
66
+ @dir = dir
67
+ @name = 'feed.xml'
68
+
69
+ self.process(@name)
70
+ self.read_yaml(File.join(base, '_layouts'), "feed.xml")
71
+ self.data[type] = val
72
+ self.data["grouptype"] = type
73
+ self.data["posts"] = posts[0..9]
74
+ end
75
+ end
76
+ end
metadata ADDED
@@ -0,0 +1,44 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: jekyll-author-page
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - Tomas
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2019-01-22 00:00:00.000000000 Z
12
+ dependencies: []
13
+ description: Author page generator for Jekyll
14
+ email: tbdizainas@gmail.com
15
+ executables: []
16
+ extensions: []
17
+ extra_rdoc_files: []
18
+ files:
19
+ - lib/jekyll-author-page.rb
20
+ homepage: http://rubygems.org/gems/jekyll-author-page
21
+ licenses:
22
+ - MIT
23
+ metadata: {}
24
+ post_install_message:
25
+ rdoc_options: []
26
+ require_paths:
27
+ - lib
28
+ required_ruby_version: !ruby/object:Gem::Requirement
29
+ requirements:
30
+ - - ">="
31
+ - !ruby/object:Gem::Version
32
+ version: '0'
33
+ required_rubygems_version: !ruby/object:Gem::Requirement
34
+ requirements:
35
+ - - ">="
36
+ - !ruby/object:Gem::Version
37
+ version: '0'
38
+ requirements: []
39
+ rubyforge_project:
40
+ rubygems_version: 2.6.14
41
+ signing_key:
42
+ specification_version: 4
43
+ summary: Author page generator
44
+ test_files: []