This uses the new part plugin to simplify and optimize render calls with locals. ```ruby render(:template, locals: {foo: 'bar'}) part(:template, foo: 'bar') ``` This simplifies a large number of calls in Clover, since rendering with locals is one of the most common method calls in the templates. The main advantage of this is simplicity, but the part method is also more optimized, and will be even more optimized when we upgrade to Ruby 3.4. Diff best reviewed with: ``` git diff -b --color-words --word-diff-regex='\\w+|[^[:space:]]' ```
35 lines
1.6 KiB
Plaintext
35 lines
1.6 KiB
Plaintext
<aside class="py-6 lg:col-span-4 xl:col-span-3 2xl:col-span-2">
|
|
<nav class="space-y-1">
|
|
<% [
|
|
["Multifactor Auth", "/account/multifactor-manage", "hero-lock-closed", request.path.start_with?("/account/multifactor")],
|
|
["Login Methods", "/account/login-method", "hero-finger-print"],
|
|
["#{rodauth.has_password? ? "Change" : "Create"} Password", "/account/change-password", "hero-key"],
|
|
["Change Email", "/account/change-login", "hero-envelope"],
|
|
["Close Account", "/account/close-account", "hero-x-circle"]
|
|
].each do |label, url, icon, is_active| %>
|
|
<% if is_active || request.path == url %>
|
|
<a
|
|
href="<%= url %>"
|
|
class="border-orange-600 bg-orange-50 text-orange-600 hover:bg-orange-50 hover:text-orange-700 group flex items-center border-l-4 px-3 py-2 text-sm font-medium"
|
|
aria-current="page"
|
|
>
|
|
<%== part(
|
|
"components/icon",
|
|
name: icon,
|
|
classes: "text-orange-600 group-hover:text-orange-600 -ml-1 mr-3 h-6 w-6 flex-shrink-0"
|
|
) %>
|
|
<span class="truncate"><%= label %></span>
|
|
</a>
|
|
<% else %>
|
|
<a
|
|
href="<%= url %>"
|
|
class="border-transparent text-gray-900 hover:bg-gray-50 hover:text-gray-900 group flex items-center border-l-4 px-3 py-2 text-sm font-medium"
|
|
>
|
|
<%== part("components/icon", name: icon, classes: "text-gray-400 group-hover:text-gray-500 -ml-1 mr-3 h-6 w-6 flex-shrink-0") %>
|
|
<span class="truncate"><%= label %></span>
|
|
</a>
|
|
<% end %>
|
|
<% end %>
|
|
</nav>
|
|
</aside>
|