Skip to content

Commit

Permalink
Remove turbo_meta_tags and add missing documentation (#548)
Browse files Browse the repository at this point in the history
  • Loading branch information
jorgemanrubia authored Jan 1, 2024
1 parent 3f769d6 commit 0f00575
Show file tree
Hide file tree
Showing 4 changed files with 37 additions and 10 deletions.
39 changes: 33 additions & 6 deletions app/helpers/turbo/drive_helper.rb
Original file line number Diff line number Diff line change
@@ -1,21 +1,29 @@
module Turbo::DriveHelper
# Note: These helpers require a +turbo_meta_tags+ provision in the layout.
# Helpers to configure Turbo Drive via meta directives. They come in two
# variants:
#
# The recommended option is to include +yield :head+ in the +<head>+ section
# of the layout. Then you can use the helpers in any view.
#
# ==== Example
#
# # app/views/application.html.erb
# <html><head><%= turbo_meta_tags %></head><body><%= yield %></html>
# <html><head><%= yield :head %></head><body><%= yield %></html>
#
# # app/views/trays/index.html.erb
# <% turbo_exempts_page_from_cache %>
# <p>Page that shouldn't be cached by Turbo</p>
#
# Alternatively, you can use the +_tag+ variant of the helpers to only get the
# HTML for the meta directive.

# Pages that are more likely than not to be a cache miss can skip turbo cache to avoid visual jitter.
# Cannot be used along with +turbo_exempts_page_from_preview+.
def turbo_exempts_page_from_cache
provide :head, turbo_exempts_page_from_cache_tag
end

# See +turbo_exempts_page_from_cache+.
def turbo_exempts_page_from_cache_tag
tag.meta(name: "turbo-cache-control", content: "no-cache")
end
Expand All @@ -26,6 +34,7 @@ def turbo_exempts_page_from_preview
provide :head, turbo_exempts_page_from_preview_tag
end

# See +turbo_exempts_page_from_preview+.
def turbo_exempts_page_from_preview_tag
tag.meta(name: "turbo-cache-control", content: "no-preview")
end
Expand All @@ -35,27 +44,45 @@ def turbo_page_requires_reload
provide :head, turbo_page_requires_reload_tag
end

# See +turbo_page_requires_reload+.
def turbo_page_requires_reload_tag
tag.meta(name: "turbo-visit-control", content: "reload")
end

# Configure how to handle page refreshes. A page refresh happens when
# Turbo loads the current page again with a *replace* visit:
#
# === Parameters:
#
# * <tt>method</tt> - Method to update the +<body>+ of the page
# during a page refresh. It can be one of:
# * +replace:+: Replaces the existing +<body>+ with the new one. This is the
# default behavior.
# * +morph:+: Morphs the existing +<body>+ into the new one.
#
# * <tt>scroll</tt> - Controls the scroll behavior when a page refresh happens. It
# can be one of:
# * +reset:+: Resets scroll to the top, left corner. This is the default.
# * +preserve:+: Keeps the scroll.
#
# === Example Usage:
#
# turbo_refreshes_with(method: :morph, scroll: :preserve)
def turbo_refreshes_with(method: :replace, scroll: :reset)
provide :head, turbo_refresh_method_tag(method)
provide :head, turbo_refresh_scroll_tag(scroll)
end

# Configure method to perform page refreshes. See +turbo_refreshes_with+.
def turbo_refresh_method_tag(method = :replace)
raise ArgumentError, "Invalid refresh option '#{method}'" unless method.in?(%i[ replace morph ])
tag.meta(name: "turbo-refresh-method", content: method)
end

# Configure scroll strategy for page refreshes. See +turbo_refreshes_with+.
def turbo_refresh_scroll_tag(scroll = :reset)
raise ArgumentError, "Invalid scroll option '#{scroll}'" unless scroll.in?(%i[ reset preserve ])
tag.meta(name: "turbo-refresh-scroll", content: scroll)
end

def turbo_meta_tags
content_for :head
end
end

2 changes: 1 addition & 1 deletion app/views/layouts/turbo_rails/frame.html.erb
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
<html>
<head>
<%= turbo_meta_tags %>
<%= yield :head %>
</head>
<body>
<%= yield %>
Expand Down
2 changes: 1 addition & 1 deletion test/dummy/app/views/layouts/application.html.erb
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
<%= csrf_meta_tags %>

<%= stylesheet_link_tag 'application', media: 'all' %>
<%= turbo_meta_tags %>
<%= yield :head %>
<%= javascript_importmap_tags %>
</head>

Expand Down
4 changes: 2 additions & 2 deletions test/frames/views/layouts/turbo_rails/frame.html.erb
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
<html>
<head>
<meta name="alternative" content="present" />
<%= turbo_meta_tags %>
<%= yield :head %>
</head>
<body>
<%= yield %>
</body>
</html>
</html>

0 comments on commit 0f00575

Please sign in to comment.