Fixed bugs with pagination in a subdirectory.
This commit is contained in:
parent
a71b755e9e
commit
bd0e45c1b9
|
@ -10,9 +10,7 @@ module Jekyll
|
||||||
#
|
#
|
||||||
# Returns nothing.
|
# Returns nothing.
|
||||||
def generate(site)
|
def generate(site)
|
||||||
site.pages.dup.each do |page|
|
paginate(site, template_page(site)) if Pager.pagination_enabled?(site)
|
||||||
paginate(site, page) if Pager.pagination_enabled?(site.config, page)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# Paginates the blog's posts. Renders the index.html file into paginated
|
# Paginates the blog's posts. Renders the index.html file into paginated
|
||||||
|
@ -33,11 +31,11 @@ module Jekyll
|
||||||
all_posts = site.site_payload['site']['posts']
|
all_posts = site.site_payload['site']['posts']
|
||||||
pages = Pager.calculate_pages(all_posts, site.config['paginate'].to_i)
|
pages = Pager.calculate_pages(all_posts, site.config['paginate'].to_i)
|
||||||
(1..pages).each do |num_page|
|
(1..pages).each do |num_page|
|
||||||
pager = Pager.new(site.config, num_page, all_posts, pages)
|
pager = Pager.new(site, num_page, all_posts, pages)
|
||||||
if num_page > 1
|
if num_page > 1
|
||||||
newpage = Page.new(site, site.source, page.dir, page.name)
|
newpage = Page.new(site, site.source, page.dir, page.name)
|
||||||
newpage.pager = pager
|
newpage.pager = pager
|
||||||
newpage.dir = File.join(page.dir, Pager.paginate_path(site.config, num_page))
|
newpage.dir = Pager.paginate_path(site, num_page)
|
||||||
site.pages << newpage
|
site.pages << newpage
|
||||||
else
|
else
|
||||||
page.pager = pager
|
page.pager = pager
|
||||||
|
@ -45,6 +43,28 @@ module Jekyll
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Static: Fetch the URL of the template page. Used to determine the
|
||||||
|
# path to the first pager in the series.
|
||||||
|
#
|
||||||
|
# site - the Jekyll::Site object
|
||||||
|
#
|
||||||
|
# Returns the url of the template page
|
||||||
|
def self.first_page_url(site)
|
||||||
|
Pagination.new.template_page(site).url
|
||||||
|
end
|
||||||
|
|
||||||
|
# Public: Find the Jekyll::Page which will act as the pager template
|
||||||
|
#
|
||||||
|
# site - the Jekyll::Site object
|
||||||
|
#
|
||||||
|
# Returns the Jekyll::Page which will act as the pager template
|
||||||
|
def template_page(site)
|
||||||
|
site.pages.dup.select do |page|
|
||||||
|
Pager.pagination_candidate?(site.config, page)
|
||||||
|
end.sort do |one, two|
|
||||||
|
two.path.size <=> one.path.size
|
||||||
|
end.first
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -62,39 +82,74 @@ module Jekyll
|
||||||
(all_posts.size.to_f / per_page.to_i).ceil
|
(all_posts.size.to_f / per_page.to_i).ceil
|
||||||
end
|
end
|
||||||
|
|
||||||
# Determine if pagination is enabled for a given file.
|
# Determine if pagination is enabled the site.
|
||||||
#
|
#
|
||||||
# config - The configuration Hash.
|
# site - the Jekyll::Site object
|
||||||
# page - The Jekyll::Page with which to paginate
|
|
||||||
#
|
#
|
||||||
# Returns true if pagination is enabled, false otherwise.
|
# Returns true if pagination is enabled, false otherwise.
|
||||||
def self.pagination_enabled?(config, page)
|
def self.pagination_enabled?(site)
|
||||||
!config['paginate'].nil? &&
|
!site.config['paginate'].nil? &&
|
||||||
|
site.pages.size > 0
|
||||||
|
end
|
||||||
|
|
||||||
|
# Static: Determine if a page is a possible candidate to be a template page.
|
||||||
|
# Page's name must be `index.html` and exist in any of the directories
|
||||||
|
# between the site source and `paginate_path`.
|
||||||
|
#
|
||||||
|
# Returns true if the
|
||||||
|
def self.pagination_candidate?(config, page)
|
||||||
|
page_dir = File.dirname(File.expand_path(remove_leading_slash(page.path), config['source']))
|
||||||
page.name == 'index.html' &&
|
page.name == 'index.html' &&
|
||||||
subdirectories_identical(config['paginate_path'], page.dir)
|
in_hierarchy(config, page_dir)
|
||||||
end
|
end
|
||||||
|
|
||||||
# Determine if the subdirectories of the two paths are the same relative to source
|
# Determine if the subdirectories of the two paths are the same relative to source
|
||||||
#
|
#
|
||||||
# paginate_path - the paginate_path configuration setting
|
# config - the site configuration hash
|
||||||
# page_dir - the directory of the Jekyll::Page
|
# page_dir - the directory of the Jekyll::Page
|
||||||
#
|
#
|
||||||
# Returns whether the subdirectories are the same relative to source
|
# Returns whether the subdirectories are the same relative to source
|
||||||
def self.subdirectories_identical(paginate_path, page_dir)
|
def self.in_hierarchy(config, page_dir)
|
||||||
File.dirname(paginate_path).gsub(/\A\./, '') == page_dir.gsub(/\/\z/, '')
|
paginate_path = remove_leading_slash(config['paginate_path'])
|
||||||
|
paginate_path = File.expand_path(paginate_path, config['source'])
|
||||||
|
return false if page_dir == File.dirname(page_dir)
|
||||||
|
page_dir == config['source'] ||
|
||||||
|
page_dir == paginate_path ||
|
||||||
|
in_hierarchy(config, File.dirname(page_dir))
|
||||||
end
|
end
|
||||||
|
|
||||||
# Static: Return the pagination path of the page
|
# Static: Return the pagination path of the page
|
||||||
#
|
#
|
||||||
# site_config - the site config
|
# site - the Jekyll::Site object
|
||||||
# num_page - the pagination page number
|
# num_page - the pagination page number
|
||||||
#
|
#
|
||||||
# Returns the pagination path as a string
|
# Returns the pagination path as a string
|
||||||
def self.paginate_path(site_config, num_page)
|
def self.paginate_path(site, num_page)
|
||||||
return nil if num_page.nil? || num_page <= 1
|
return nil if num_page.nil?
|
||||||
format = site_config['paginate_path']
|
return Generators::Pagination.first_page_url(site) if num_page <= 1
|
||||||
|
format = site.config['paginate_path']
|
||||||
format = format.sub(':num', num_page.to_s)
|
format = format.sub(':num', num_page.to_s)
|
||||||
File.basename(format)
|
ensure_leading_slash(format)
|
||||||
|
end
|
||||||
|
|
||||||
|
# Static: Return a String version of the input which has a leading slash.
|
||||||
|
# If the input already has a forward slash in position zero, it will be
|
||||||
|
# returned unchanged.
|
||||||
|
#
|
||||||
|
# path - a String path
|
||||||
|
#
|
||||||
|
# Returns the path with a leading slash
|
||||||
|
def self.ensure_leading_slash(path)
|
||||||
|
path[0..0] == "/" ? path : "/#{path}"
|
||||||
|
end
|
||||||
|
|
||||||
|
# Static: Return a String version of the input without a leading slash.
|
||||||
|
#
|
||||||
|
# path - a String path
|
||||||
|
#
|
||||||
|
# Returns the input without the leading slash
|
||||||
|
def self.remove_leading_slash(path)
|
||||||
|
ensure_leading_slash(path)[1..-1]
|
||||||
end
|
end
|
||||||
|
|
||||||
# Initialize a new Pager.
|
# Initialize a new Pager.
|
||||||
|
@ -104,9 +159,9 @@ module Jekyll
|
||||||
# all_posts - The Array of all the site's Posts.
|
# all_posts - The Array of all the site's Posts.
|
||||||
# num_pages - The Integer number of pages or nil if you'd like the number
|
# num_pages - The Integer number of pages or nil if you'd like the number
|
||||||
# of pages calculated.
|
# of pages calculated.
|
||||||
def initialize(config, page, all_posts, num_pages = nil)
|
def initialize(site, page, all_posts, num_pages = nil)
|
||||||
@page = page
|
@page = page
|
||||||
@per_page = config['paginate'].to_i
|
@per_page = site.config['paginate'].to_i
|
||||||
@total_pages = num_pages || Pager.calculate_pages(all_posts, @per_page)
|
@total_pages = num_pages || Pager.calculate_pages(all_posts, @per_page)
|
||||||
|
|
||||||
if @page > @total_pages
|
if @page > @total_pages
|
||||||
|
@ -119,9 +174,9 @@ module Jekyll
|
||||||
@total_posts = all_posts.size
|
@total_posts = all_posts.size
|
||||||
@posts = all_posts[init..offset]
|
@posts = all_posts[init..offset]
|
||||||
@previous_page = @page != 1 ? @page - 1 : nil
|
@previous_page = @page != 1 ? @page - 1 : nil
|
||||||
@previous_page_path = Pager.paginate_path(config, @previous_page)
|
@previous_page_path = Pager.paginate_path(site, @previous_page)
|
||||||
@next_page = @page != @total_pages ? @page + 1 : nil
|
@next_page = @page != @total_pages ? @page + 1 : nil
|
||||||
@next_page_path = Pager.paginate_path(config, @next_page)
|
@next_page_path = Pager.paginate_path(site, @next_page)
|
||||||
end
|
end
|
||||||
|
|
||||||
# Convert this Pager's data to a Hash suitable for use by Liquid.
|
# Convert this Pager's data to a Hash suitable for use by Liquid.
|
||||||
|
|
Loading…
Reference in New Issue