Skip to content
New issue

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

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

Already on GitHub? # to your account

Use streaming responses #67

Open
varyonic opened this issue Nov 16, 2017 · 3 comments
Open

Use streaming responses #67

varyonic opened this issue Nov 16, 2017 · 3 comments

Comments

@varyonic
Copy link
Contributor

See activeadmin/activeadmin#2689

The unused in-memory DOM representation more than doubles the memory usage required to service a request and complicates the implementation to having a seperate buffer per element. I think a lot can be gained my dropping the in memory DOM representation: a single ActionView buffer can be passed from parent to child, lowering memory usage and allow us to use streaming responses.

@joeldrapper
Copy link

joeldrapper commented Jul 2, 2024

This is essentially how Phlex works and it’s really fast because you don’t need to allocate an object for each element. The generated HTML tag methods are essentially:

def h1(**)
  @buffer << "<h1" << build_attributes(**) << ">"
  yield
  @buffer << "</h1>"
end

@varyonic
Copy link
Contributor Author

varyonic commented Jul 2, 2024

Yes, see varyonic@312ee73?diff=split&w=1 for my less elegant but working replacement of Element#to_s. I think it would be interesting to replace Arbre or Arbo with Phlex in ActiveAdmin but I am not familiar with how Phlex interoperates with ActionView and Rails helpers (especially form builders, though replacing Formtastic would also be good). Could it be done in a way that is (mostly) backward compatible or has a simple migration path?

@joeldrapper
Copy link

Could it be done in a way that is (mostly) backward compatible or has a simple migration path?

I expect so. Phlex Rails defines wrappers for each ActionView helper because it needs to behave in different ways depending on the kind of helper.

There are essentially two kinds of helpers:

  1. Value helpers return values that you typically output as text or attribute values. These helpers should work as normal in a Phlex context.
  2. Output helpers return HTML that should be pushed to the output buffer immediately.

For example, here the link_to helper is an output helper, and the dashboard_path helper is a value helper.

link_to(dashboard_path) { "Dashboard" }

We don’t need to do anything like

unsafe_raw(
  link_to(dashboard_path) { "Dashboard" }
)

All the helpers are defined here. https://github.com/phlex-ruby/phlex-rails/tree/main/lib/phlex/rails/helpers

Some helpers such as form builder helpers need some extra managing to maintain compatibility. Helpers like form_with yield a FormBuilder, which has output helpers and value helpers on it, so Phlex decorates the form builder.

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants