Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add new helper API #1860

Merged
merged 37 commits into from
Nov 3, 2023
Merged
Show file tree
Hide file tree
Changes from 22 commits
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
1500fdd
add: helper api
reeganviljoen Sep 25, 2023
305a952
remove: redundant self
reeganviljoen Sep 25, 2023
11e3aef
add: args and block passthrough
reeganviljoen Sep 25, 2023
903cd3e
add: changelog entry
reeganviljoen Sep 25, 2023
b8bbde9
Fix: markdown liniting errors
reeganviljoen Sep 25, 2023
39df32a
Update lib/view_component/helpers_api.rb
reeganviljoen Sep 29, 2023
d298203
Update docs/CHANGELOG.md
reeganviljoen Sep 29, 2023
b06db04
Update test/sandbox/app/components/helpers_api_component.rb
reeganviljoen Sep 29, 2023
c467068
Update test/sandbox/test/rendering_test.rb
reeganviljoen Sep 29, 2023
7bcc15f
refactor: use_helpers
reeganviljoen Sep 30, 2023
7052b36
refactor to use safe navigation
reeganviljoen Oct 1, 2023
c568550
wip
reeganviljoen Oct 23, 2023
b50b889
Merge branch 'main' into rv_helpers_api
reeganviljoen Oct 23, 2023
9f0eafe
add: with_helpers hellper
reeganviljoen Oct 23, 2023
da9a8af
edit: cleanup
reeganviljoen Oct 23, 2023
52eb3ba
edit: cleanup
reeganviljoen Oct 23, 2023
25867a6
edit: cleanup
reeganviljoen Oct 23, 2023
7508639
edit: cleanup
reeganviljoen Oct 23, 2023
8f7c2c0
Merge branch 'main' into rv_helpers_api
reeganviljoen Oct 23, 2023
1315a54
edit: cleanup
reeganviljoen Oct 23, 2023
9250082
remove Style/RedundantSelf lint error
reeganviljoen Oct 24, 2023
d5e5797
remove Layout/EmptyLinesAroundAccessModifier lint error
reeganviljoen Oct 24, 2023
9fbf47d
Update lib/view_component/use_helpers.rb
reeganviljoen Oct 31, 2023
927e496
Merge branch 'main' into rv_helpers_api
reeganviljoen Oct 31, 2023
1aa8539
edit: change helper spelling
reeganviljoen Oct 31, 2023
43289df
edit: omptimize helper eval
reeganviljoen Oct 31, 2023
c4fdaaa
remove test_helpers and fix use_helpers
reeganviljoen Oct 31, 2023
b270ef8
add: docs
reeganviljoen Oct 31, 2023
ba7dd22
fix markdown issues
reeganviljoen Oct 31, 2023
d0198a1
fix markdown issues
reeganviljoen Oct 31, 2023
6798415
edit: changelog entry
reeganviljoen Oct 31, 2023
530ab54
Update docs/guide/helpers.md
reeganviljoen Oct 31, 2023
357ba44
make helpers example more clear
reeganviljoen Oct 31, 2023
ea2d7bc
fix markdown issues
reeganviljoen Oct 31, 2023
3012915
edit: changelog entry
reeganviljoen Oct 31, 2023
60b66df
Merge branch 'main' into rv_helpers_api
camertron Nov 3, 2023
c2b5a95
Update helpers.md
camertron Nov 3, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions docs/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,9 @@ nav_order: 5

*Alexandre Ignjatovic*

* Add `use_helper` api
reeganviljoen marked this conversation as resolved.
Show resolved Hide resolved

*Reegan Viljoen*
* Reduce UnboundMethod objects by memoizing initialize_parameters

*Rainer Borene*
Expand Down
1 change: 1 addition & 0 deletions lib/view_component/base.rb
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
require "view_component/slotable"
require "view_component/translatable"
require "view_component/with_content_helper"
require "view_component/use_helpers"

module ViewComponent
class Base < ActionView::Base
Expand Down
23 changes: 23 additions & 0 deletions lib/view_component/test_helpers.rb
Original file line number Diff line number Diff line change
Expand Up @@ -190,6 +190,29 @@ def with_request_url(path, host: nil)
@vc_test_controller = old_controller
end

# Set the controller helpers to be used while executing the given block,
#
# ```ruby
# with_helpers(UsersHelper) do
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I was imagining that this could be used to mock helpers instead of including helpers that should already be present on the view context.

e.g.

test "foo" do
  # delegates to the current_user method
  with_helpers(current_user: :current_user) do
    render_inline MyComponent.new
  end

  current_user = create(:user)
  # stubs the current_user helper to return this value
  with_helpers(current_user: current_user) do
    render_inline MyComponent.new
  end
end

def current_user
  # some logic
end

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@BlakeWilliams moving this to a new pr

# render_inline(MyComponent.new)
# end
# ```
#
# @param *args [Array<Module>] The helpers to be used.
def with_helpers(*args)
args.each do |helper_mthd|
camertron marked this conversation as resolved.
Show resolved Hide resolved
vc_test_controller.class_eval(<<-RUBY, __FILE__, __LINE__ + 1)
def #{helper_mthd}
return #{return send(helper_mthd)}
reeganviljoen marked this conversation as resolved.
Show resolved Hide resolved
end

ruby2_keywords(:'#{helper_mthd}')
RUBY
vc_test_controller.class.helper_method helper_mthd
end
yield
end

# Access the controller used by `render_inline`:
#
# ```ruby
Expand Down
20 changes: 20 additions & 0 deletions lib/view_component/use_helpers.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
# frozen_string_literal: true

module ViewComponent::UseHelpers
extend ActiveSupport::Concern

class_methods do
def use_helpers(*args)
args.each do |helper_mtd|
class_eval(<<-RUBY, __FILE__, __LINE__ + 1)
def #{helper_mtd}(*args, &block)
reeganviljoen marked this conversation as resolved.
Show resolved Hide resolved
raise HelpersCalledBeforeRenderError if view_context.nil?
__vc_original_view_context&.send(#{helper_mtd.inspect}, *args, &block) || view_context.send(#{helper_mtd.inspect}, *args, &block)
reeganviljoen marked this conversation as resolved.
Show resolved Hide resolved
reeganviljoen marked this conversation as resolved.
Show resolved Hide resolved
end
RUBY

ruby2_keywords(helper_mtd) if respond_to?(:ruby2_keywords, true)
end
end
end
end
3 changes: 3 additions & 0 deletions test/sandbox/app/components/use_helpers_component.html.erb
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<div class="helper__message">
<%= test_helper %>
</div>
7 changes: 7 additions & 0 deletions test/sandbox/app/components/use_helpers_component.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
# frozen_string_literal: true

class UseHelpersComponent < ViewComponent::Base
include ViewComponent::UseHelpers

use_helpers :test_helper
end
13 changes: 13 additions & 0 deletions test/sandbox/test/rendering_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -1094,4 +1094,17 @@ def test_content_security_policy_nonce

assert_selector("script", text: "\n//<![CDATA[\n \"alert('hello')\"\n\n//]]>\n", visible: :hidden)
end

def test_use_helper
with_helpers(:test_helper) do
render_inline(UseHelpersComponent.new)
assert_selector ".helper__message", text: "Hello helper method"
end
end

private

def test_helper
"Hello helper method"
end
end