Make preferences page editable without clicking 'Edit Preferences'
This commit is contained in:
parent
99af52b478
commit
967e6d4d86
8 changed files with 35 additions and 83 deletions
|
@ -11,8 +11,6 @@ class PreferencesController < ApplicationController
|
||||||
|
|
||||||
def show; end
|
def show; end
|
||||||
|
|
||||||
def edit; end
|
|
||||||
|
|
||||||
def update
|
def update
|
||||||
current_user.languages = params[:user][:languages].split(",")
|
current_user.languages = params[:user][:languages].split(",")
|
||||||
|
|
||||||
|
@ -40,7 +38,7 @@ class PreferencesController < ApplicationController
|
||||||
redirect_to preferences_path
|
redirect_to preferences_path
|
||||||
else
|
else
|
||||||
flash.now[:error] = t ".failure"
|
flash.now[:error] = t ".failure"
|
||||||
render :edit
|
render :show
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,28 +0,0 @@
|
||||||
<% content_for :heading do %>
|
|
||||||
<h1><%= t ".title" %></h1>
|
|
||||||
<% end %>
|
|
||||||
|
|
||||||
<%= bootstrap_form_for current_user, :url => { :action => :update } do |f| %>
|
|
||||||
<%= f.select :preferred_editor, [[t("editor.default", :name => t("editor.#{Settings.default_editor}.name")), "default"]] + Editors::AVAILABLE_EDITORS.collect { |e| [t("editor.#{e}.description"), e] } %>
|
|
||||||
|
|
||||||
<%= f.text_field :languages %>
|
|
||||||
|
|
||||||
<div class="mb-3">
|
|
||||||
<%= label_tag "site_color_scheme", t("preferences.show.preferred_site_color_scheme"), :class => "form-label" %>
|
|
||||||
<%= select_tag "site_color_scheme",
|
|
||||||
options_for_select(%w[auto light dark].map { |scheme| [t("preferences.show.site_color_schemes.#{scheme}"), scheme] },
|
|
||||||
preferred_color_scheme(:site)),
|
|
||||||
:class => "form-select" %>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="mb-3">
|
|
||||||
<%= label_tag "map_color_scheme", t("preferences.show.preferred_map_color_scheme"), :class => "form-label" %>
|
|
||||||
<%= select_tag "map_color_scheme",
|
|
||||||
options_for_select(%w[auto light dark].map { |scheme| [t("preferences.show.map_color_schemes.#{scheme}"), scheme] },
|
|
||||||
preferred_color_scheme(:map)),
|
|
||||||
:class => "form-select" %>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<%= f.primary t(".save") %>
|
|
||||||
<%= link_to t(".cancel"), preferences_path, :class => "btn btn-link" %>
|
|
||||||
<% end %>
|
|
|
@ -2,36 +2,26 @@
|
||||||
<h1><%= t ".title" %></h1>
|
<h1><%= t ".title" %></h1>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
||||||
<dl class="row">
|
<%= bootstrap_form_for current_user, :url => { :action => :update } do |f| %>
|
||||||
<dt class="col-sm-4"><%= t ".preferred_editor" %></dt>
|
<%= f.select :preferred_editor, [[t("editor.default", :name => t("editor.#{Settings.default_editor}.name")), "default"]] + Editors::AVAILABLE_EDITORS.collect { |e| [t("editor.#{e}.description"), e] } %>
|
||||||
|
|
||||||
<% if current_user.preferred_editor? %>
|
<%= f.text_field :languages %>
|
||||||
<dd class="col-sm-8"><%= t("editor.#{current_user.preferred_editor}.description") %></dd>
|
|
||||||
<% else %>
|
|
||||||
<dd class="col-sm-8"><%= t("editor.default", :name => t("editor.#{Settings.default_editor}.name")) %></dd>
|
|
||||||
<% end %>
|
|
||||||
|
|
||||||
<dt class="col-sm-4"><%= t ".preferred_languages" %></dt>
|
<div class="mb-3">
|
||||||
|
<%= label_tag "site_color_scheme", t(".preferred_site_color_scheme"), :class => "form-label" %>
|
||||||
<dd class="col-sm-8">
|
<%= select_tag "site_color_scheme",
|
||||||
<ul class="list-unstyled">
|
options_for_select(%w[auto light dark].map { |scheme| [t(".site_color_schemes.#{scheme}"), scheme] },
|
||||||
<% current_user.preferred_languages.each do |locale| %>
|
preferred_color_scheme(:site)),
|
||||||
<li><%= locale %></li>
|
:class => "form-select" %>
|
||||||
<% end %>
|
|
||||||
</ul>
|
|
||||||
</dd>
|
|
||||||
|
|
||||||
<dt class="col-sm-4"><%= t ".preferred_site_color_scheme" %></dt>
|
|
||||||
<dd class="col-sm-8">
|
|
||||||
<%= t ".site_color_schemes.#{preferred_color_scheme(:site)}" %>
|
|
||||||
</dd>
|
|
||||||
|
|
||||||
<dt class="col-sm-4"><%= t ".preferred_map_color_scheme" %></dt>
|
|
||||||
<dd class="col-sm-8">
|
|
||||||
<%= t ".map_color_schemes.#{preferred_color_scheme(:map)}" %>
|
|
||||||
</dd>
|
|
||||||
</dl>
|
|
||||||
|
|
||||||
<div>
|
|
||||||
<%= link_to t(".edit_preferences"), edit_preferences_path, :class => "btn btn-outline-primary" %>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
<%= label_tag "map_color_scheme", t(".preferred_map_color_scheme"), :class => "form-label" %>
|
||||||
|
<%= select_tag "map_color_scheme",
|
||||||
|
options_for_select(%w[auto light dark].map { |scheme| [t(".map_color_schemes.#{scheme}"), scheme] },
|
||||||
|
preferred_color_scheme(:map)),
|
||||||
|
:class => "form-select" %>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<%= f.primary t(".save") %>
|
||||||
|
<% end %>
|
||||||
|
|
|
@ -1841,11 +1841,7 @@ en:
|
||||||
auto: Auto
|
auto: Auto
|
||||||
light: Light
|
light: Light
|
||||||
dark: Dark
|
dark: Dark
|
||||||
edit_preferences: Edit Preferences
|
|
||||||
edit:
|
|
||||||
title: Edit Preferences
|
|
||||||
save: Update Preferences
|
save: Update Preferences
|
||||||
cancel: Cancel
|
|
||||||
update:
|
update:
|
||||||
failure: Couldn't update preferences.
|
failure: Couldn't update preferences.
|
||||||
update_success_flash:
|
update_success_flash:
|
||||||
|
|
|
@ -281,7 +281,8 @@ OpenStreetMap::Application.routes.draw do
|
||||||
resource :deletion, :only => [:show]
|
resource :deletion, :only => [:show]
|
||||||
end
|
end
|
||||||
resource :dashboard, :only => [:show]
|
resource :dashboard, :only => [:show]
|
||||||
resource :preferences, :only => [:show, :edit, :update]
|
resource :preferences, :only => [:show, :update]
|
||||||
|
get "/preferences/edit", :to => redirect(:path => "/preferences")
|
||||||
resource :profile, :only => [:edit, :update]
|
resource :profile, :only => [:edit, :update]
|
||||||
|
|
||||||
# friendships
|
# friendships
|
||||||
|
|
|
@ -9,11 +9,6 @@ class PreferencesControllerTest < ActionDispatch::IntegrationTest
|
||||||
{ :controller => "preferences", :action => "show" }
|
{ :controller => "preferences", :action => "show" }
|
||||||
)
|
)
|
||||||
|
|
||||||
assert_routing(
|
|
||||||
{ :path => "/preferences/edit", :method => :get },
|
|
||||||
{ :controller => "preferences", :action => "edit" }
|
|
||||||
)
|
|
||||||
|
|
||||||
assert_routing(
|
assert_routing(
|
||||||
{ :path => "/preferences", :method => :put },
|
{ :path => "/preferences", :method => :put },
|
||||||
{ :controller => "preferences", :action => "update" }
|
{ :controller => "preferences", :action => "update" }
|
||||||
|
@ -27,35 +22,35 @@ class PreferencesControllerTest < ActionDispatch::IntegrationTest
|
||||||
session_for(user)
|
session_for(user)
|
||||||
|
|
||||||
# Changing to a invalid editor should fail
|
# Changing to a invalid editor should fail
|
||||||
user.preferred_editor = "unknown"
|
put preferences_path, :params => { :user => { :preferred_editor => "unknown", :languages => [] } }
|
||||||
put preferences_path, :params => { :user => user.attributes }
|
|
||||||
assert_response :success
|
assert_response :success
|
||||||
assert_template :edit
|
assert_template :show
|
||||||
assert_select ".alert-success", false
|
assert_select ".alert-success", false
|
||||||
assert_select ".alert-danger", true
|
assert_select ".alert-danger", true
|
||||||
assert_select "form > div > select#user_preferred_editor > option[selected]", false
|
user.reload
|
||||||
|
assert_nil user.preferred_editor
|
||||||
assert_equal "light", user.preferences.find_by(:k => "site.color_scheme")&.v
|
assert_equal "light", user.preferences.find_by(:k => "site.color_scheme")&.v
|
||||||
assert_equal "light", user.preferences.find_by(:k => "map.color_scheme")&.v
|
assert_equal "light", user.preferences.find_by(:k => "map.color_scheme")&.v
|
||||||
|
|
||||||
# Changing to a valid editor should work
|
# Changing to a valid editor should work
|
||||||
user.preferred_editor = "id"
|
put preferences_path, :params => { :user => { :preferred_editor => "id", :languages => [] } }
|
||||||
put preferences_path, :params => { :user => user.attributes }
|
|
||||||
assert_redirected_to preferences_path
|
assert_redirected_to preferences_path
|
||||||
follow_redirect!
|
follow_redirect!
|
||||||
assert_template :show
|
assert_template :show
|
||||||
assert_select ".alert-success", /^Preferences updated/
|
assert_select ".alert-success", /^Preferences updated/
|
||||||
assert_select "dd", "iD (in-browser editor)"
|
user.reload
|
||||||
|
assert_equal "id", user.preferred_editor
|
||||||
assert_equal "light", user.preferences.find_by(:k => "site.color_scheme")&.v
|
assert_equal "light", user.preferences.find_by(:k => "site.color_scheme")&.v
|
||||||
assert_equal "light", user.preferences.find_by(:k => "map.color_scheme")&.v
|
assert_equal "light", user.preferences.find_by(:k => "map.color_scheme")&.v
|
||||||
|
|
||||||
# Changing to the default editor should work
|
# Changing to the default editor should work
|
||||||
user.preferred_editor = "default"
|
put preferences_path, :params => { :user => { :preferred_editor => "default", :languages => [] } }
|
||||||
put preferences_path, :params => { :user => user.attributes }
|
|
||||||
assert_redirected_to preferences_path
|
assert_redirected_to preferences_path
|
||||||
follow_redirect!
|
follow_redirect!
|
||||||
assert_template :show
|
assert_template :show
|
||||||
assert_select ".alert-success", /^Preferences updated/
|
assert_select ".alert-success", /^Preferences updated/
|
||||||
assert_select "dd", "Default (currently iD)"
|
user.reload
|
||||||
|
assert_nil user.preferred_editor
|
||||||
assert_equal "light", user.preferences.find_by(:k => "site.color_scheme")&.v
|
assert_equal "light", user.preferences.find_by(:k => "site.color_scheme")&.v
|
||||||
assert_equal "light", user.preferences.find_by(:k => "map.color_scheme")&.v
|
assert_equal "light", user.preferences.find_by(:k => "map.color_scheme")&.v
|
||||||
end
|
end
|
||||||
|
|
|
@ -4,7 +4,7 @@ class PreferencesTest < ApplicationSystemTestCase
|
||||||
def test_flash_message_shows_in_original_language
|
def test_flash_message_shows_in_original_language
|
||||||
sign_in_as(create(:user))
|
sign_in_as(create(:user))
|
||||||
|
|
||||||
visit edit_preferences_path
|
visit preferences_path
|
||||||
click_on "Update Preferences"
|
click_on "Update Preferences"
|
||||||
|
|
||||||
assert_content "Preferences updated"
|
assert_content "Preferences updated"
|
||||||
|
@ -13,7 +13,7 @@ class PreferencesTest < ApplicationSystemTestCase
|
||||||
def test_flash_message_shows_in_new_language
|
def test_flash_message_shows_in_new_language
|
||||||
sign_in_as(create(:user))
|
sign_in_as(create(:user))
|
||||||
|
|
||||||
visit edit_preferences_path
|
visit preferences_path
|
||||||
fill_in "Preferred Languages", :with => "fr"
|
fill_in "Preferred Languages", :with => "fr"
|
||||||
click_on "Update Preferences"
|
click_on "Update Preferences"
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,7 @@ class ViewCommunitiesTest < ApplicationSystemTestCase
|
||||||
def test_translated_links
|
def test_translated_links
|
||||||
sign_in_as(create(:user))
|
sign_in_as(create(:user))
|
||||||
|
|
||||||
visit edit_preferences_path
|
visit preferences_path
|
||||||
fill_in "Preferred Languages", :with => "fr"
|
fill_in "Preferred Languages", :with => "fr"
|
||||||
click_on "Update Preferences"
|
click_on "Update Preferences"
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue