Diary entries pretty much i18n'd. Additional test that checks there are no missing translation strings, need more like it.
This commit is contained in:
parent
ae70ea2858
commit
b377927a64
7 changed files with 45 additions and 13 deletions
|
@ -115,7 +115,11 @@ class DiaryEntryController < ApplicationController
|
||||||
|
|
||||||
if user
|
if user
|
||||||
@entry = DiaryEntry.find(:first, :conditions => ['user_id = ? AND id = ?', user.id, params[:id]])
|
@entry = DiaryEntry.find(:first, :conditions => ['user_id = ? AND id = ?', user.id, params[:id]])
|
||||||
@title = "Users' diaries | #{params[:display_name]}"
|
if @entry
|
||||||
|
@title = "Users' diaries | #{params[:display_name]}"
|
||||||
|
else
|
||||||
|
render :action => 'no_such_entry', :status => :not_found
|
||||||
|
end
|
||||||
else
|
else
|
||||||
@not_found_user = params[:display_name]
|
@not_found_user = params[:display_name]
|
||||||
|
|
||||||
|
|
|
@ -1,3 +1,3 @@
|
||||||
<h4 id="comment<%= diary_comment.id %>">Comment from <%= link_to h(diary_comment.user.display_name), :controller => 'user', :action => 'view', :display_name => diary_comment.user.display_name %> at <%= diary_comment.created_at %></h4>
|
<h4 id="comment<%= diary_comment.id %>"><%= t('diary_entry.comment_from', :link_user => (link_to h(diary_comment.user.display_name), :controller => 'user', :action => 'view', :display_name => diary_comment.user.display_name), :comment_created_at => l(diary_comment.created_at)) %></h4>
|
||||||
<%= htmlize(diary_comment.body) %>
|
<%= htmlize(diary_comment.body) %>
|
||||||
<hr />
|
<hr />
|
||||||
|
|
|
@ -5,30 +5,30 @@
|
||||||
<% form_for :diary_entry do |f| %>
|
<% form_for :diary_entry do |f| %>
|
||||||
<table>
|
<table>
|
||||||
<tr valign="top">
|
<tr valign="top">
|
||||||
<td class="fieldName">Subject:</td>
|
<td class="fieldName"><%= t 'diary_entry.edit.subject' -%></td>
|
||||||
<td><%= f.text_field :title, :size => 60 %></td>
|
<td><%= f.text_field :title, :size => 60 %></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr valign="top">
|
<tr valign="top">
|
||||||
<td class="fieldName">Body:</td>
|
<td class="fieldName"><%= t 'diary_entry.edit.body' -%></td>
|
||||||
<td><%= f.text_area :body, :cols => 80 %></td>
|
<td><%= f.text_area :body, :cols => 80 %></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr valign="top">
|
<tr valign="top">
|
||||||
<td class="fieldName">Language:</td>
|
<td class="fieldName"><%= t 'diary_entry.edit.language' -%></td>
|
||||||
<td><%= f.collection_select :language, Language.find(:all), :code, :name %></td>
|
<td><%= f.collection_select :language, Language.find(:all), :code, :name %></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr valign="top">
|
<tr valign="top">
|
||||||
<td class="fieldName">Location:</td>
|
<td class="fieldName"><%= t 'diary_entry.edit.location' -%></td>
|
||||||
<td>
|
<td>
|
||||||
<div id="map" style="border: 1px solid black; position: relative; width : 90%; height : 400px; display: none;"></div>
|
<div id="map" style="border: 1px solid black; position: relative; width : 90%; height : 400px; display: none;"></div>
|
||||||
<span class="location">Latitude: <%= f.text_field :latitude, :size => 20, :id => "latitude" %> Longitude: <%= f.text_field :longitude, :size => 20, :id => "longitude" %></span>
|
<span class="location"><%= t 'diary_entry.edit.latitude' -%> <%= f.text_field :latitude, :size => 20, :id => "latitude" %> <%= t 'diary_entry.edit.longitude' -%> <%= f.text_field :longitude, :size => 20, :id => "longitude" %></span>
|
||||||
<a href="javascript:openMap()" id="usemap">use map</a>
|
<a href="javascript:openMap()" id="usemap"><%= t 'diary_entry.edit.use_map_link' -%></a>
|
||||||
<br/><br/>
|
<br/><br/>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td></td>
|
<td></td>
|
||||||
<td>
|
<td>
|
||||||
<%= submit_tag 'Save' %>
|
<%= submit_tag t 'diary_entry.edit.save_button' %>
|
||||||
<%# TODO: button should say 'publish' or 'save changes' depending on new/edit state %>
|
<%# TODO: button should say 'publish' or 'save changes' depending on new/edit state %>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
@ -76,7 +76,7 @@
|
||||||
removeMarkerFromMap(marker);
|
removeMarkerFromMap(marker);
|
||||||
}
|
}
|
||||||
|
|
||||||
marker = addMarkerToMap(lonlat, null, "Diary entry location");
|
marker = addMarkerToMap(lonlat, null, "<%= t 'diary_entry.edit.marker_text' -%>");
|
||||||
}
|
}
|
||||||
|
|
||||||
function openMap() {
|
function openMap() {
|
||||||
|
|
|
@ -1,2 +1,2 @@
|
||||||
<h2>No entry with the id: <%= h(params[:id]) %></h2>
|
<h2><%= t 'diary_entry.no_such_entry.heading', :id => h(params[:id]) %></h2>
|
||||||
<p>Sorry, there is no diary entry or comment with the id <%=h params[:id] -%>, or no id was given. Please check your spelling, or maybe the link you clicked is wrong.</p>
|
<p><%= t 'diary_entry.no_such_entry.body', :id => h(params[:id]) %></p>
|
||||||
|
|
|
@ -1,2 +1,2 @@
|
||||||
<h2><%= h(@not_found_user) %></h2>
|
<h2><%= h(@not_found_user) %></h2>
|
||||||
<p>Sorry, there is no user with the name <%= @not_found_user -%>. Please check your spelling, or maybe the link you clicked is wrong.</p>
|
<p><%= t 'diary_entry.no_such_user.body', :user => @not_found_user %></p>
|
||||||
|
|
|
@ -11,6 +11,21 @@ en:
|
||||||
recent_entries: "Recent diary entries: "
|
recent_entries: "Recent diary entries: "
|
||||||
older_entries: Older Entries
|
older_entries: Older Entries
|
||||||
newer_entries: Newer Entries
|
newer_entries: Newer Entries
|
||||||
|
edit:
|
||||||
|
subject: "Subject:"
|
||||||
|
body: "Body:"
|
||||||
|
language: "Language:"
|
||||||
|
location: "Location:"
|
||||||
|
latitude: "Latitude:"
|
||||||
|
longitude: "Longitude:"
|
||||||
|
use_map_link: "use map"
|
||||||
|
save_button: "Save"
|
||||||
|
marker_text: Diary entry location
|
||||||
|
no_such_entry:
|
||||||
|
heading: "No entry with the id: {{id}}"
|
||||||
|
body: "Sorry, there is no diary entry or comment with the id {{id}}. Please check your spelling, or maybe the link you clicked is wrong."
|
||||||
|
no_such_user:
|
||||||
|
body: "Sorry, there is no user with the name {{user}}. Please check your spelling, or maybe the link you clicked is wrong."
|
||||||
posted_by: "Posted by {{link_user}} at {{created}} in {{language}}"
|
posted_by: "Posted by {{link_user}} at {{created}} in {{language}}"
|
||||||
comment_link: Comment on this entry
|
comment_link: Comment on this entry
|
||||||
reply_link: Reply to this entry
|
reply_link: Reply to this entry
|
||||||
|
@ -18,3 +33,4 @@ en:
|
||||||
one: 1 comment
|
one: 1 comment
|
||||||
other: "{{count}} comments"
|
other: "{{count}} comments"
|
||||||
edit_link: Edit this entry
|
edit_link: Edit this entry
|
||||||
|
comment_from: "Comment from {{link_user}} at {{comment_created_at}}"
|
||||||
|
|
|
@ -145,6 +145,16 @@ class DiaryEntryControllerTest < ActionController::TestCase
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_edit_diary_entry_i18n
|
||||||
|
I18n.available_locales.each do |locale|
|
||||||
|
set_locale locale
|
||||||
|
|
||||||
|
get(:edit, {:id => diary_entries(:normal_user_entry_1).id}, {'user' => users(:normal_user).id})
|
||||||
|
assert_response :success
|
||||||
|
assert_select "span[class=translation_missing]", false, "Missing translation in edit diary entry"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def test_create_diary_entry
|
def test_create_diary_entry
|
||||||
#post :new
|
#post :new
|
||||||
end
|
end
|
||||||
|
@ -162,11 +172,13 @@ class DiaryEntryControllerTest < ActionController::TestCase
|
||||||
get :list
|
get :list
|
||||||
assert_response :success, "Should be able to list the diary entries in #{locale}"
|
assert_response :success, "Should be able to list the diary entries in #{locale}"
|
||||||
assert_template 'list', "Should use the list template in #{locale}"
|
assert_template 'list', "Should use the list template in #{locale}"
|
||||||
|
assert_select "span[class=translation_missing]", false, "Missing translation in list of diary entries"
|
||||||
|
|
||||||
# Now try to find a specific user's diary entry
|
# Now try to find a specific user's diary entry
|
||||||
get :list, {:display_name => users(:normal_user).display_name}
|
get :list, {:display_name => users(:normal_user).display_name}
|
||||||
assert_response :success, "Should be able to list the diary entries for a user in #{locale}"
|
assert_response :success, "Should be able to list the diary entries for a user in #{locale}"
|
||||||
assert_template 'list', "Should use the list template for a user in #{locale}"
|
assert_template 'list', "Should use the list template for a user in #{locale}"
|
||||||
|
assert_select "span[class=translation_missing]", false, "Missing translation in list of diary entries for user"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue