2023-04-27 01:21:32 +09:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module ReactComponentHelper
|
|
|
|
def react_component(name, props = {}, &block)
|
|
|
|
data = { component: name.to_s.camelcase, props: Oj.dump(props) }
|
|
|
|
if block.nil?
|
|
|
|
div_tag_with_data(data)
|
|
|
|
else
|
|
|
|
content_tag(:div, data: data, &block)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def react_admin_component(name, props = {})
|
2023-06-02 22:00:27 +09:00
|
|
|
data = { 'admin-component': name.to_s.camelcase, props: Oj.dump(props) }
|
2023-04-27 01:21:32 +09:00
|
|
|
div_tag_with_data(data)
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def div_tag_with_data(data)
|
|
|
|
content_tag(:div, nil, data: data)
|
|
|
|
end
|
|
|
|
end
|