Class: Bridgetown::Paginate::PaginationPage
- Inherits:
-
GeneratedPage
- Object
- GeneratedPage
- Bridgetown::Paginate::PaginationPage
- Defined in:
- lib/bridgetown-paginate/pagination_page.rb
Overview
This page handles the creation of the fake pagination pages based on the original page configuration. The code does the same things as the default Bridgetown page.rb code but just forces the code to look into the template instead of the (currently non-existing) pagination page. This page exists purely in memory and is not read from disk
Instance Attribute Summary collapse
-
#page_to_copy ⇒ Object
readonly
Returns the value of attribute page_to_copy.
Instance Method Summary collapse
-
#destination(dest) ⇒ Object
rubocop:enable Naming/AccessorMethodName.
- #fast_refresh! ⇒ Object
-
#initialize(page_to_copy, cur_page_nr, total_pages, index_pageandext, template_ext) ⇒ PaginationPage
constructor
rubocop:disable Lint/MissingSuper.
-
#set_url(url_value) ⇒ Object
rubocop:disable Naming/AccessorMethodName.
- #unmark_for_fast_refresh! ⇒ Object
Constructor Details
#initialize(page_to_copy, cur_page_nr, total_pages, index_pageandext, template_ext) ⇒ PaginationPage
rubocop:disable Lint/MissingSuper
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 |
# File 'lib/bridgetown-paginate/pagination_page.rb', line 16 def initialize(page_to_copy, cur_page_nr, total_pages, index_pageandext, template_ext) # rubocop:disable Lint/MissingSuper self.original_resource = if page_to_copy.is_a?(Bridgetown::Resource::Base) page_to_copy elsif page_to_copy.original_resource page_to_copy.original_resource end @page_to_copy = page_to_copy @site = page_to_copy.site @base = "" @url = "" @name = index_pageandext.nil? ? "index#{template_ext}" : index_pageandext @path = page_to_copy.path @basename = File.basename(@path, ".*") @ext = File.extname(@name) @cur_page_r = cur_page_nr @total_pages = total_pages # Only need to copy the data part of the page as it already contains the # layout information self.data = Bridgetown::Utils.deep_merge_hashes page_to_copy.data, {} self.content = page_to_copy.content # Store the current page and total page numbers in the pagination_info construct data["pagination_info"] = { "curr_page" => cur_page_nr, "total_pages" => total_pages } Bridgetown::Hooks.trigger :generated_pages, :post_init, self end |
Instance Attribute Details
#page_to_copy ⇒ Object (readonly)
Returns the value of attribute page_to_copy.
14 15 16 |
# File 'lib/bridgetown-paginate/pagination_page.rb', line 14 def page_to_copy @page_to_copy end |
Instance Method Details
#destination(dest) ⇒ Object
rubocop:enable Naming/AccessorMethodName
66 67 68 69 70 71 72 73 74 75 |
# File 'lib/bridgetown-paginate/pagination_page.rb', line 66 def destination(dest) path = site.in_dest_dir( dest, Bridgetown::Utils .unencode_uri(url) .delete_prefix(site.base_path(strip_slash_only: true)) ) path = File.join(path, "index") if url.end_with?("/") path << output_ext unless path.end_with? output_ext path end |
#fast_refresh! ⇒ Object
44 45 46 47 48 49 50 51 |
# File 'lib/bridgetown-paginate/pagination_page.rb', line 44 def fast_refresh! page_to_copy.fast_refresh! if page_to_copy.respond_to?(:fast_refresh!) self.data = Bridgetown::Utils.deep_merge_hashes page_to_copy.data, {} self.content = page_to_copy.content # Store the current page and total page numbers in the pagination_info construct data["pagination_info"] = { "curr_page" => @cur_page_nr, "total_pages" => @total_pages } end |
#set_url(url_value) ⇒ Object
rubocop:disable Naming/AccessorMethodName
59 60 61 62 63 |
# File 'lib/bridgetown-paginate/pagination_page.rb', line 59 def set_url(url_value) @path = url_value.delete_prefix "/" @dir = @path.ends_with?("/") ? @path : File.dirname(@path) @url = url_value end |
#unmark_for_fast_refresh! ⇒ Object
53 54 55 56 |
# File 'lib/bridgetown-paginate/pagination_page.rb', line 53 def unmark_for_fast_refresh! super page_to_copy.unmark_for_fast_refresh! if page_to_copy.is_a?(Bridgetown::GeneratedPage) end |