forked from fixin.me/fixin.me
Run #create action
This commit is contained in:
parent
ba3c2a99b9
commit
ce4770a25c
@ -20,7 +20,7 @@ class UnitsController < ApplicationController
|
|||||||
@unit = current_user.units.new(unit_params)
|
@unit = current_user.units.new(unit_params)
|
||||||
if @unit.save
|
if @unit.save
|
||||||
flash[:notice] = t(".success")
|
flash[:notice] = t(".success")
|
||||||
redirect_to units_url
|
@units = current_user.units
|
||||||
else
|
else
|
||||||
render :new
|
render :new
|
||||||
end
|
end
|
||||||
|
@ -1,21 +1,22 @@
|
|||||||
<%= fields_for unit do |form| %>
|
<%= fields_for @unit do |form| %>
|
||||||
<td>
|
<td>
|
||||||
<%= form.text_field :symbol, form: :unit_form, required: true, autofocus: true, size: 10,
|
<%= form.text_field :symbol, form: :unit_form, required: true, autofocus: true, size: 10,
|
||||||
maxlength: unit.class.columns_hash['symbol'].limit, autocomplete: "off" %>
|
maxlength: @unit.class.columns_hash['symbol'].limit, autocomplete: "off" %>
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<%= form.text_field :name, form: :unit_form, size: 25,
|
<%= form.text_field :name, form: :unit_form, size: 25,
|
||||||
maxlength: unit.class.columns_hash['name'].limit, autocomplete: "off" %>
|
maxlength: @unit.class.columns_hash['name'].limit, autocomplete: "off" %>
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<% unless unit.base.nil? %>
|
<% unless @unit.base.nil? %>
|
||||||
<%= form.number_field :multiplier, form: :unit_form, step: "any", size: 10,
|
<%= form.number_field :multiplier, form: :unit_form, step: "any", size: 10,
|
||||||
autocomplete: "off" %>
|
autocomplete: "off" %>
|
||||||
<% end %>
|
<% end %>
|
||||||
</td>
|
</td>
|
||||||
|
|
||||||
<td class="actions">
|
<td class="actions">
|
||||||
<%= form.submit unit.persisted? ? t(:update) : t(:add), form: :unit_form %>
|
<%= form.submit @unit.persisted? ? t(:update) : t(:add), form: :unit_form,
|
||||||
|
onclick: 'focusAddLink(event);' %>
|
||||||
<%= image_link_to t(:cancel), "close-circle-outline", units_path, class: 'dangerous',
|
<%= image_link_to t(:cancel), "close-circle-outline", units_path, class: 'dangerous',
|
||||||
onclick: 'closeForm(event); return false;' %>
|
onclick: 'closeForm(event); return false;' %>
|
||||||
</td>
|
</td>
|
||||||
@ -25,6 +26,10 @@
|
|||||||
<%= javascript_tag do %>
|
<%= javascript_tag do %>
|
||||||
function closeForm(event) {
|
function closeForm(event) {
|
||||||
event.target.closest("tr").replaceChildren();
|
event.target.closest("tr").replaceChildren();
|
||||||
|
focusAddLink(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
function focusAddLink(event) {
|
||||||
var add_unit_link = document.querySelector("a#add_unit");
|
var add_unit_link = document.querySelector("a#add_unit");
|
||||||
add_unit_link.style.visibility = "visible";
|
add_unit_link.style.visibility = "visible";
|
||||||
add_unit_link.focus({ focusVisible: true });
|
add_unit_link.focus({ focusVisible: true });
|
||||||
|
17
app/views/units/_index.html.erb
Normal file
17
app/views/units/_index.html.erb
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
<tr id="<%= dom_id(Unit.new) %>" is="turbo-frame"></tr>
|
||||||
|
|
||||||
|
<% Unit.each_with_level(@units) do |unit, level| %>
|
||||||
|
<tr>
|
||||||
|
<td class="link">
|
||||||
|
<%= link_to unit.symbol, edit_unit_path(unit), class: level > 0 ? 'subunit' : '' %>
|
||||||
|
</td>
|
||||||
|
<td><%= unit.name %></td>
|
||||||
|
<td class="number"><%= scientifize(unit.multiplier) unless unit.multiplier == 1 %></td>
|
||||||
|
<% if current_user.at_least(:active) %>
|
||||||
|
<td class="actions">
|
||||||
|
<%= image_button_to t(".delete_unit"), "delete-outline", unit_path(unit),
|
||||||
|
method: :delete %>
|
||||||
|
</td>
|
||||||
|
<% end %>
|
||||||
|
</tr>
|
||||||
|
<% end %>
|
3
app/views/units/create.turbo_stream.erb
Normal file
3
app/views/units/create.turbo_stream.erb
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
<%= turbo_stream.update :units do %>
|
||||||
|
<%= render partial: 'index' %>
|
||||||
|
<% end %>
|
@ -9,7 +9,7 @@
|
|||||||
|
|
||||||
<%= turbo_frame_tag 'unit_form_frame' %>
|
<%= turbo_frame_tag 'unit_form_frame' %>
|
||||||
|
|
||||||
<table class="main items" id="units">
|
<table class="main items">
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th><%= User.human_attribute_name(:symbol).capitalize %></th>
|
<th><%= User.human_attribute_name(:symbol).capitalize %></th>
|
||||||
@ -20,23 +20,7 @@
|
|||||||
<% end %>
|
<% end %>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody id="units" is="turbo-frame">
|
||||||
<tr id="<%= dom_id(Unit.new) %>" is="turbo-frame"></tr>
|
<%= render partial: 'index' %>
|
||||||
|
|
||||||
<% Unit.each_with_level(@units) do |unit, level| %>
|
|
||||||
<tr>
|
|
||||||
<td class="link">
|
|
||||||
<%= link_to unit.symbol, edit_unit_path(unit), class: level > 0 ? 'subunit' : '' %>
|
|
||||||
</td>
|
|
||||||
<td><%= unit.name %></td>
|
|
||||||
<td class="number"><%= scientifize(unit.multiplier) unless unit.multiplier == 1 %></td>
|
|
||||||
<% if current_user.at_least(:active) %>
|
|
||||||
<td class="actions">
|
|
||||||
<%= image_button_to t(".delete_unit"), "delete-outline", unit_path(unit),
|
|
||||||
method: :delete %>
|
|
||||||
</td>
|
|
||||||
<% end %>
|
|
||||||
</tr>
|
|
||||||
<% end %>
|
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
<%= turbo_stream.update @unit do %>
|
<%= turbo_stream.update @unit do %>
|
||||||
<%= render partial: 'form', locals: {unit: @unit} %>
|
<%= render partial: 'form' %>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
||||||
<%= turbo_stream.update :unit_form_frame do %>
|
<%= turbo_stream.update :unit_form_frame do %>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user