Manage client-side js with turbo_stream actions

This commit is contained in:
2024-01-22 02:14:01 +01:00
parent 0e8bc18620
commit a7f80a575c
6 changed files with 30 additions and 17 deletions

View File

@@ -2,7 +2,7 @@
<% if current_user.at_least(:active) %>
<%= turbo_frame_tag do %>
<%= image_link_to t('.add_unit'), 'plus-outline', new_unit_path, id: :add_unit,
onclick: 'this.blur(); this.style.visibility = "hidden";', data: {turbo_stream: true} %>
onclick: 'this.blur();', data: {turbo_stream: true} %>
<% end %>
<% end %>
</div>
@@ -26,20 +26,9 @@
</table>
<%= javascript_tag do %>
function closeForm(event) {
event.target.closest("tr").remove();
focusAddLink(event);
}
function focusAddLink(event) {
var add_unit_link = document.querySelector("a#add_unit");
add_unit_link.style.visibility = "visible";
add_unit_link.focus({ focusVisible: true });
}
function processKey(event) {
if (event.key == "Escape") {
closeForm(event);
event.target.closest("tr").querySelector("a[name=cancel]").click();
}
}
<% end %>