forked from fixin.me/fixin.me
Close form on Esc key. Localize submit button.
This commit is contained in:
parent
ce4770a25c
commit
0801e8059c
@ -1,37 +1,26 @@
|
|||||||
<%= fields_for @unit do |form| %>
|
<%= fields_for @unit do |form| %>
|
||||||
<td>
|
<tr id="<%= dom_id(@unit) %>" onkeydown="processKey(event)">
|
||||||
<%= form.text_field :symbol, form: :unit_form, required: true, autofocus: true, size: 10,
|
<td>
|
||||||
maxlength: @unit.class.columns_hash['symbol'].limit, autocomplete: "off" %>
|
<%= form.text_field :symbol, form: :unit_form, required: true, autofocus: true, size: 12,
|
||||||
</td>
|
maxlength: @unit.class.columns_hash['symbol'].limit, autocomplete: "off" %>
|
||||||
<td>
|
</td>
|
||||||
<%= form.text_field :name, form: :unit_form, size: 25,
|
<td>
|
||||||
maxlength: @unit.class.columns_hash['name'].limit, autocomplete: "off" %>
|
<%= form.text_field :name, form: :unit_form, size: 30,
|
||||||
</td>
|
maxlength: @unit.class.columns_hash['name'].limit, autocomplete: "off" %>
|
||||||
<td>
|
</td>
|
||||||
<% unless @unit.base.nil? %>
|
<td>
|
||||||
<%= form.number_field :multiplier, form: :unit_form, step: "any", size: 10,
|
<% unless @unit.base.nil? %>
|
||||||
autocomplete: "off" %>
|
<%= form.number_field :multiplier, form: :unit_form, step: "any", size: 10,
|
||||||
<% end %>
|
autocomplete: "off" %>
|
||||||
</td>
|
<% end %>
|
||||||
|
</td>
|
||||||
|
|
||||||
<td class="actions">
|
<td class="actions">
|
||||||
<%= form.submit @unit.persisted? ? t(:update) : t(:add), form: :unit_form,
|
<%= form.submit form: :unit_form, onclick: 'focusAddLink(event)' %>
|
||||||
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>
|
</tr>
|
||||||
<!-- TODO: display error_messages_for unit -->
|
<!-- TODO: display error_messages_for unit -->
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
||||||
<%= javascript_tag do %>
|
|
||||||
function closeForm(event) {
|
|
||||||
event.target.closest("tr").replaceChildren();
|
|
||||||
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 });
|
|
||||||
}
|
|
||||||
<% end %>
|
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
<tr id="<%= dom_id(Unit.new) %>" is="turbo-frame"></tr>
|
|
||||||
|
|
||||||
<% Unit.each_with_level(@units) do |unit, level| %>
|
<% Unit.each_with_level(@units) do |unit, level| %>
|
||||||
<tr>
|
<tr>
|
||||||
<td class="link">
|
<td class="link">
|
||||||
|
@ -24,3 +24,22 @@
|
|||||||
<%= render partial: 'index' %>
|
<%= render partial: 'index' %>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
<% end %>
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<%= turbo_stream.update @unit do %>
|
<%= turbo_stream.prepend :units do %>
|
||||||
<%= render partial: 'form' %>
|
<%= render partial: 'form' %>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
||||||
|
@ -13,6 +13,10 @@ en:
|
|||||||
created_at: registered
|
created_at: registered
|
||||||
confirmed_at: confirmed
|
confirmed_at: confirmed
|
||||||
unconfirmed_email: Awaiting confirmation for
|
unconfirmed_email: Awaiting confirmation for
|
||||||
|
helpers:
|
||||||
|
submit:
|
||||||
|
create: Create
|
||||||
|
update: Update
|
||||||
units:
|
units:
|
||||||
index:
|
index:
|
||||||
add_unit: Add unit
|
add_unit: Add unit
|
||||||
|
@ -36,4 +36,10 @@ class UnitsTest < ApplicationSystemTestCase
|
|||||||
|
|
||||||
# assert_selector flash
|
# assert_selector flash
|
||||||
end
|
end
|
||||||
|
|
||||||
|
test "close new unit form with escape" do
|
||||||
|
click_on t('units.index.add_unit')
|
||||||
|
first('tbody > tr').all(:field).sample.send_keys :escape
|
||||||
|
within('tbody') { assert_no_selector :fillable_field }
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
x
Reference in New Issue
Block a user