tml-rails 4.3.6 → 4.3.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/README.md +49 -12
- data/app/views/tml_rails/tags/_language_selector_bootstrap.html.erb +46 -0
- data/app/views/tml_rails/tags/_language_selector_default.html.erb +17 -0
- data/app/views/tml_rails/tags/_language_selector_inline.html.erb +15 -0
- data/app/views/tml_rails/tags/_language_selector_js.html.erb +32 -0
- data/app/views/tml_rails/tags/_language_selector_select.html.erb +15 -0
- data/lib/tasks/tml.rake +3 -3
- data/lib/tml/cache_adapters/rails.rb +1 -2
- data/lib/tml_rails/extensions/action_controller_extension.rb +8 -7
- data/lib/tml_rails/extensions/action_view_extension.rb +18 -12
- data/lib/tml_rails/version.rb +1 -1
- metadata +7 -3
- data/app/views/tml_rails/tags/_language_selector.html.erb +0 -82
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 9326f9cd017dbc9d697e2c7dab50c0ff2d70c41b
|
4
|
+
data.tar.gz: 1898fcb898316d57b4de91356a66524dd18c5a4c
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 598ce0a929c08a22c956d35857bb63f5e52959b3e2381e5a3a1ec79bd0c5df1223b56efdee91bf72edd1f5c3bda03659a271639a7a61921b704724d7be442b6e
|
7
|
+
data.tar.gz: 2470d1f1ac1f5024299fadaf636e7408e5cc38c50a251493d00c1ae7263bf7fc65904b69385d218a6f28f16a1fcda1c5bfe73932156797403ffbd6c6b91eebd8
|
data/README.md
CHANGED
@@ -53,11 +53,44 @@ Tml must be used with caching enabled.
|
|
53
53
|
|
54
54
|
If you are already using Rails caching, you probably already specify it in your production file, like the following:
|
55
55
|
|
56
|
+
Memcache
|
57
|
+
|
56
58
|
config/environments/production.rb
|
57
59
|
|
58
60
|
```ruby
|
59
|
-
config.cache_store = :mem_cache_store,
|
60
|
-
|
61
|
+
config.cache_store = :mem_cache_store, { :namespace => 'my_cache' }
|
62
|
+
```
|
63
|
+
|
64
|
+
Memcache for multiple servers
|
65
|
+
|
66
|
+
```ruby
|
67
|
+
config.cache_store = :mem_cache_store, '123.456.78.9:1001', '123.456.78.9:1002'
|
68
|
+
```
|
69
|
+
|
70
|
+
Memcache with Dalli
|
71
|
+
|
72
|
+
```ruby
|
73
|
+
config.cache_store = :mem_cache_store, Dalli::Client.new('localhost:11211', {
|
74
|
+
:namespace => 'my_cache'
|
75
|
+
})
|
76
|
+
```
|
77
|
+
|
78
|
+
Redis
|
79
|
+
|
80
|
+
```ruby
|
81
|
+
config.cache_store = :redis_store, {
|
82
|
+
:host => 'localhost',
|
83
|
+
:port => 6379,
|
84
|
+
:db => 0,
|
85
|
+
:namespace => 'my_cache',
|
86
|
+
:expires_in => 90.minutes
|
87
|
+
}
|
88
|
+
```
|
89
|
+
|
90
|
+
Tip: to clear up Redis cache
|
91
|
+
|
92
|
+
```sh
|
93
|
+
$ redis-cli FLUSHALL
|
61
94
|
```
|
62
95
|
|
63
96
|
Then all you need to do is specify that you want to use the Rails cache adapter:
|
@@ -76,11 +109,12 @@ Alternatively, you can provide a separate memcache server to store your translat
|
|
76
109
|
|
77
110
|
```ruby
|
78
111
|
config.cache = {
|
79
|
-
:enabled
|
80
|
-
:adapter
|
81
|
-
:host
|
82
|
-
:
|
83
|
-
:
|
112
|
+
:enabled => true,
|
113
|
+
:adapter => 'memcache',
|
114
|
+
:host => 'localhost:11211',
|
115
|
+
:namespace => 'translations',
|
116
|
+
:version => 1,
|
117
|
+
:timeout => 3600
|
84
118
|
}
|
85
119
|
```
|
86
120
|
|
@@ -88,11 +122,14 @@ You can also use Redis to persist your translations cache:
|
|
88
122
|
|
89
123
|
```ruby
|
90
124
|
config.cache = {
|
91
|
-
:enabled
|
92
|
-
:adapter
|
93
|
-
:host
|
94
|
-
:
|
95
|
-
:
|
125
|
+
:enabled => true,
|
126
|
+
:adapter => 'redis',
|
127
|
+
:host => 'localhost',
|
128
|
+
:port => 6379,
|
129
|
+
:password => 'password',
|
130
|
+
:namespace => 'translations',
|
131
|
+
:version => 1,
|
132
|
+
:timeout => 3600
|
96
133
|
}
|
97
134
|
```
|
98
135
|
|
@@ -0,0 +1,46 @@
|
|
1
|
+
<%
|
2
|
+
opts[:element] ||= 'div'
|
3
|
+
opts[:class] ||= 'dropdown'
|
4
|
+
%>
|
5
|
+
|
6
|
+
<<%= opts[:element] %> class="<%= opts[:class] %>" style="<%= opts[:style] %>">
|
7
|
+
<a href="#" role="button" class="<%= opts[:class] || 'dropdown' %>-toggle" data-toggle="dropdown">
|
8
|
+
<%= tml_language_name_tag(tml_current_language, opts) %>
|
9
|
+
</a>
|
10
|
+
|
11
|
+
<ul class="dropdown-menu" role="menu">
|
12
|
+
|
13
|
+
<% tml_application.languages.each do |lang| %>
|
14
|
+
|
15
|
+
<li role="presentation">
|
16
|
+
<%=link_to({:locale => lang.locale}) do %>
|
17
|
+
|
18
|
+
<%= tml_language_name_tag(lang, opts) %>
|
19
|
+
|
20
|
+
<% end %>
|
21
|
+
</li>
|
22
|
+
|
23
|
+
<% end %>
|
24
|
+
|
25
|
+
<% if opts[:toggle] %>
|
26
|
+
<li role='presentation' class='divider'></li>
|
27
|
+
<li role='presentation'>
|
28
|
+
<a href='javascript:void(0);' onclick='Tml.Utils.toggleInlineTranslations()'>
|
29
|
+
<%= tr(opts[:toggle_label] || 'Help Us Translate') %>
|
30
|
+
</a>
|
31
|
+
</li>
|
32
|
+
<% end %>
|
33
|
+
|
34
|
+
<li role='presentation' class='divider'></li>
|
35
|
+
|
36
|
+
<div style="font-size:8px;color:#ccc;text-align: center">
|
37
|
+
<a href="http://translationexchange.com">
|
38
|
+
<img style="padding: 10px;border: 0px;background-repeat: no-repeat;background-size: 14px 17px;
|
39
|
+
background-image:url();"/>
|
40
|
+
<br>
|
41
|
+
Powered By Translation Exchange
|
42
|
+
</a>
|
43
|
+
</div>
|
44
|
+
</ul>
|
45
|
+
</<%= opts[:element] %>>
|
46
|
+
|
@@ -0,0 +1,17 @@
|
|
1
|
+
<%= link_to('#',
|
2
|
+
:onclick => opts[:method] || 'Tml.UI.LanguageSelector.show(); return false;',
|
3
|
+
:style => (opts[:style] || 'padding-right:5px;text-decoration:none'),
|
4
|
+
:class => opts[:class]
|
5
|
+
) do %>
|
6
|
+
<% unless opts[:hide_flag] %>
|
7
|
+
<%= image_tag(tml_current_language.flag_url, :style => "align:middle") %>
|
8
|
+
|
9
|
+
<% end %>
|
10
|
+
<% if opts[:language] == :native %>
|
11
|
+
<%= tml_current_language.native_name %>
|
12
|
+
<% elsif opts[:language] == :english %>
|
13
|
+
<%= tml_current_language.english_name %>
|
14
|
+
<% else %>
|
15
|
+
<%= tml_current_language.english_name %>
|
16
|
+
<% end %>
|
17
|
+
<% end %>
|
@@ -0,0 +1,15 @@
|
|
1
|
+
<div style="<%=opts[:style]%>" class="<%=opts[:class]%>">
|
2
|
+
<% tml_application.languages.each_with_index do |lang, index| %>
|
3
|
+
<% next if opts[:limit] and index >= opts[:limit] %>
|
4
|
+
|
5
|
+
|
6
|
+
<%= link_to(params.merge(:locale => lang.locale), :style => (opts[:style] || 'padding-right:5px;text-decoration:none'), :class => opts[:class]) do %>
|
7
|
+
<% if opts[:flags_only] or opts[:flags] %>
|
8
|
+
<%= image_tag(lang.flag_url) %>
|
9
|
+
<% else %>
|
10
|
+
<%= tml_language_name_tag(lang, opts) %>
|
11
|
+
<% end %>
|
12
|
+
<% end %>
|
13
|
+
|
14
|
+
<% end %>
|
15
|
+
</div>
|
@@ -0,0 +1,32 @@
|
|
1
|
+
<script>
|
2
|
+
function tml_change_locale(locale) {
|
3
|
+
var query_parts = window.location.href.split('#');
|
4
|
+
var anchor = query_parts.length > 1 ? query_parts[1] : null;
|
5
|
+
query_parts = query_parts[0].split('?');
|
6
|
+
var query = query_parts.length > 1 ? query_parts[1] : null;
|
7
|
+
|
8
|
+
var params = {};
|
9
|
+
if (query) {
|
10
|
+
var vars = query.split('&');
|
11
|
+
for (var i = 0; i < vars.length; i++) {
|
12
|
+
var pair = vars[i].split('=');
|
13
|
+
params[pair[0]] = pair[1];
|
14
|
+
}
|
15
|
+
}
|
16
|
+
params['locale'] = locale;
|
17
|
+
|
18
|
+
query = [];
|
19
|
+
var keys = Object.keys(params);
|
20
|
+
for (i = 0; i < keys.length; i++) {
|
21
|
+
query.push(keys[i] + "=" + params[keys[i]]);
|
22
|
+
}
|
23
|
+
|
24
|
+
var destination = query_parts[0];
|
25
|
+
if (query.length > 0)
|
26
|
+
destination = destination + '?' + query.join("&");
|
27
|
+
if (anchor)
|
28
|
+
destination = destination + '#' + anchor;
|
29
|
+
|
30
|
+
window.location = destination;
|
31
|
+
}
|
32
|
+
</script>
|
@@ -0,0 +1,15 @@
|
|
1
|
+
<%= render(:partial => '/tml_rails/tags/language_selector_js') %>
|
2
|
+
|
3
|
+
<select id="tml_language_selector" onchange="tml_change_locale(this.options[this.selectedIndex].value)" style="<%=opts[:style]%>" class="<%=opts[:class]%>">
|
4
|
+
<% tml_application.languages.each do |lang| %>
|
5
|
+
<option dir='ltr' value="<%=lang.locale%>" <%="selected" if lang.locale == tml_current_locale %>>
|
6
|
+
<% if opts[:language] == :native %>
|
7
|
+
<%= lang.native_name %>
|
8
|
+
<% elsif opts[:language] == :english %>
|
9
|
+
<%= lang.english_name %>
|
10
|
+
<% else %>
|
11
|
+
<%= lang.english_name %>
|
12
|
+
<% end %>
|
13
|
+
</option>
|
14
|
+
<% end %>
|
15
|
+
</select>
|
data/lib/tasks/tml.rake
CHANGED
@@ -42,17 +42,17 @@ namespace :tml do
|
|
42
42
|
|
43
43
|
desc 'generates local file cache'
|
44
44
|
task :generate => :environment do
|
45
|
-
Tml::Generators::
|
45
|
+
Tml::Generators::File.new.run
|
46
46
|
end
|
47
47
|
|
48
48
|
desc 'rolls back to the previous version'
|
49
49
|
task :rollback => :environment do
|
50
|
-
Tml::Generators::
|
50
|
+
Tml::Generators::File.new.rollback
|
51
51
|
end
|
52
52
|
|
53
53
|
desc 'rolls up to the next version'
|
54
54
|
task :rollup => :environment do
|
55
|
-
Tml::Generators::
|
55
|
+
Tml::Generators::File.new.rollup
|
56
56
|
end
|
57
57
|
|
58
58
|
end
|
@@ -33,7 +33,6 @@
|
|
33
33
|
class Tml::CacheAdapters::Rails < Tml::Cache
|
34
34
|
|
35
35
|
def initialize
|
36
|
-
Tml.logger.info('Initializing Rails cache...')
|
37
36
|
@cache = Rails.cache
|
38
37
|
end
|
39
38
|
|
@@ -91,7 +90,7 @@ class Tml::CacheAdapters::Rails < Tml::Cache
|
|
91
90
|
end
|
92
91
|
|
93
92
|
def clear(opts = {})
|
94
|
-
info(
|
93
|
+
info('Cache clear')
|
95
94
|
rescue Exception => ex
|
96
95
|
warn("Failed to clear cache: #{ex.message}")
|
97
96
|
end
|
@@ -113,17 +113,18 @@ module TmlRails
|
|
113
113
|
end
|
114
114
|
|
115
115
|
unless tml_session_params[:locale]
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
session[:locale] = tml_user_preferred_locale unless session[:locale]
|
120
|
-
session[:locale] = params[:locale] if params[:locale]
|
121
|
-
tml_session_params.merge!(:locale => session[:locale] || Tml.config.default_locale)
|
122
|
-
end
|
116
|
+
tml_session_params.merge!(:cookies => cookies)
|
117
|
+
tml_session_params.merge!(:change_locale => true) if params[:locale]
|
118
|
+
tml_session_params.merge!(:locale => params[:locale] || tml_user_preferred_locale)
|
123
119
|
end
|
124
120
|
|
125
121
|
Tml.session.init(tml_session_params)
|
126
122
|
|
123
|
+
# if user sets locale manually, update the cookie for future use
|
124
|
+
if tml_session_params[:change_locale]
|
125
|
+
cookies[Tml.session.cookie_name] = Tml::Utils.encode(Tml.session.cookie_params)
|
126
|
+
end
|
127
|
+
|
127
128
|
if defined? I18n.enforce_available_locales
|
128
129
|
I18n.enforce_available_locales = false
|
129
130
|
end
|
@@ -56,36 +56,42 @@ module TmlRails
|
|
56
56
|
end
|
57
57
|
|
58
58
|
def tml_language_flag_tag(lang = tml_current_language, opts = {})
|
59
|
-
return
|
60
|
-
html = image_tag(lang.flag_url, :style =>
|
61
|
-
html <<
|
59
|
+
return '' unless tml_application.feature_enabled?(:language_flags)
|
60
|
+
html = image_tag(lang.flag_url, :style => (opts[:style] || 'vertical-align:middle;'), :title => lang.native_name)
|
61
|
+
html << ' '.html_safe
|
62
62
|
html.html_safe
|
63
63
|
end
|
64
64
|
|
65
65
|
def tml_language_name_tag(lang = tml_current_language, opts = {})
|
66
66
|
show_flag = opts[:flag].nil? ? true : opts[:flag]
|
67
|
-
name_type = opts[:
|
68
|
-
linked = opts[:linked].nil? ? true : opts[:linked]
|
67
|
+
name_type = opts[:language].nil? ? :english : opts[:language] # :full, :native, :english, :locale
|
69
68
|
|
70
|
-
html =
|
69
|
+
html = []
|
70
|
+
html << "<span style='white-space: nowrap'>"
|
71
71
|
html << tml_language_flag_tag(lang, opts) if show_flag
|
72
72
|
html << "<span dir='ltr'>"
|
73
73
|
|
74
74
|
name = case name_type
|
75
75
|
when :native then lang.native_name
|
76
|
-
when :
|
76
|
+
when :full then lang.full_name
|
77
77
|
when :locale then lang.locale
|
78
|
-
else lang.
|
78
|
+
else lang.english_name
|
79
79
|
end
|
80
80
|
|
81
|
-
html << name
|
82
|
-
html <<
|
83
|
-
html.html_safe
|
81
|
+
html << name.to_s
|
82
|
+
html << '</span></span>'
|
83
|
+
html.join().html_safe
|
84
84
|
end
|
85
85
|
|
86
86
|
def tml_language_selector_tag(type = nil, opts = {})
|
87
87
|
return unless Tml.config.enabled?
|
88
|
-
|
88
|
+
|
89
|
+
type ||= :default
|
90
|
+
unless [:bootstrap, :default, :inline, :select].include?(type.to_sym)
|
91
|
+
return "Unsupported language selector #{type}"
|
92
|
+
end
|
93
|
+
|
94
|
+
render(:partial => "/tml_rails/tags/language_selector_#{type}", :locals => {:opts => opts})
|
89
95
|
end
|
90
96
|
|
91
97
|
def tml_language_strip_tag(opts = {})
|
data/lib/tml_rails/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: tml-rails
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 4.3.
|
4
|
+
version: 4.3.7
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Michael Berkovich
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2015-
|
11
|
+
date: 2015-02-08 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rails
|
@@ -49,7 +49,11 @@ files:
|
|
49
49
|
- README.md
|
50
50
|
- Rakefile
|
51
51
|
- app/controllers/tml_rails/tools_controller.rb
|
52
|
-
- app/views/tml_rails/tags/
|
52
|
+
- app/views/tml_rails/tags/_language_selector_bootstrap.html.erb
|
53
|
+
- app/views/tml_rails/tags/_language_selector_default.html.erb
|
54
|
+
- app/views/tml_rails/tags/_language_selector_inline.html.erb
|
55
|
+
- app/views/tml_rails/tags/_language_selector_js.html.erb
|
56
|
+
- app/views/tml_rails/tags/_language_selector_select.html.erb
|
53
57
|
- app/views/tml_rails/tags/_language_strip.html.erb
|
54
58
|
- app/views/tml_rails/tags/_powered_by_trex.html.erb
|
55
59
|
- app/views/tml_rails/tags/_scripts.html.erb
|
@@ -1,82 +0,0 @@
|
|
1
|
-
<% if tml_session.tools_enabled? or type.blank? %>
|
2
|
-
<%
|
3
|
-
if tml_session.tools_enabled?
|
4
|
-
opts[:method] = 'Tml.UI.LanguageSelector.show(); return false;'
|
5
|
-
end
|
6
|
-
%>
|
7
|
-
|
8
|
-
<%= link_to('#',
|
9
|
-
:onclick => (opts[:method] || "alert('Custom language selector can be specified by passing it in the method attribute of the language selector tag.');"),
|
10
|
-
:style => (opts[:style] || 'padding-right:5px;text-decoration:none'),
|
11
|
-
:class => opts[:class]
|
12
|
-
) do %>
|
13
|
-
<% unless opts[:hide_flag] %>
|
14
|
-
<%= image_tag(tml_current_language.flag_url, :style => "align:middle") %>
|
15
|
-
|
16
|
-
<% end %>
|
17
|
-
<% if opts[:language] == :native %>
|
18
|
-
<%= tml_current_language.native_name %>
|
19
|
-
<% elsif opts[:language] == :english %>
|
20
|
-
<%= tml_current_language.english_name %>
|
21
|
-
<% else %>
|
22
|
-
<%= tml_current_language.english_name %>
|
23
|
-
<% end %>
|
24
|
-
<% end %>
|
25
|
-
|
26
|
-
<% elsif type == :list %>
|
27
|
-
<div style="padding-top:10px;">
|
28
|
-
<% tml_application.languages.each_with_index do |lang, index| %>
|
29
|
-
<% next if opts[:limit] and index >= opts[:limit] %>
|
30
|
-
<%= link_to(params.merge(:locale => lang.locale), :style => (opts[:style] || 'padding-right:5px;text-decoration:none'), :class => opts[:class]) do %>
|
31
|
-
<% if opts[:flags_only] or opts[:flags] %>
|
32
|
-
<%= image_tag(lang.flag_url) %>
|
33
|
-
<% end %>
|
34
|
-
<% unless opts[:flags_only] %>
|
35
|
-
<%= lang.english_name %>
|
36
|
-
<% end %>
|
37
|
-
<% end %>
|
38
|
-
<% end %>
|
39
|
-
</div>
|
40
|
-
|
41
|
-
<% elsif type == :dropdown %>
|
42
|
-
|
43
|
-
<script>
|
44
|
-
function tml_change_locale(selector) {
|
45
|
-
var query_parts = window.location.href.split('?');
|
46
|
-
var query = query_parts.length > 1 ? query_parts[1] : null;
|
47
|
-
var params = {};
|
48
|
-
if (query) {
|
49
|
-
var vars = query.split('&');
|
50
|
-
for (var i = 0; i < vars.length; i++) {
|
51
|
-
var pair = vars[i].split('=');
|
52
|
-
params[pair[0]] = pair[1];
|
53
|
-
}
|
54
|
-
}
|
55
|
-
params['locale'] = selector.options[selector.selectedIndex].value;
|
56
|
-
|
57
|
-
query = [];
|
58
|
-
var keys = Object.keys(params);
|
59
|
-
for (var i = 0; i < keys.length; i++) {
|
60
|
-
query.push(encodeURIComponent(keys[i]) + "=" + encodeURIComponent(params[keys[i]]));
|
61
|
-
}
|
62
|
-
|
63
|
-
var destination = query_parts[0] + '?' + query.join("&");
|
64
|
-
window.location = destination;
|
65
|
-
}
|
66
|
-
</script>
|
67
|
-
|
68
|
-
<select id="tml_language_selector" onchange="tml_change_locale(this)" style="<%=opts[:style]%>" class="<%=opts[:class]%>">
|
69
|
-
<% tml_application.languages.each do |lang| %>
|
70
|
-
<option dir='ltr' value="<%=lang.locale%>" <%="selected" if lang.locale == tml_current_locale %>>
|
71
|
-
<% if opts[:language] == :native %>
|
72
|
-
<%= lang.native_name %>
|
73
|
-
<% elsif opts[:language] == :english %>
|
74
|
-
<%= lang.english_name %>
|
75
|
-
<% else %>
|
76
|
-
<%= lang.english_name %>
|
77
|
-
<% end %>
|
78
|
-
</option>
|
79
|
-
<% end %>
|
80
|
-
</select>
|
81
|
-
|
82
|
-
<% end %>
|