refinerycms-blog 1.6.2 → 1.7.0
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.
- data/Gemfile +7 -0
- data/Gemfile.lock +293 -0
- data/app/controllers/admin/blog/categories_controller.rb +8 -4
- data/app/controllers/admin/blog/comments_controller.rb +34 -30
- data/app/controllers/admin/blog/posts_controller.rb +81 -70
- data/app/controllers/admin/blog/settings_controller.rb +46 -32
- data/app/controllers/blog/categories_controller.rb +11 -9
- data/app/controllers/blog/posts_controller.rb +84 -76
- data/app/helpers/blog_posts_helper.rb +8 -4
- data/app/mailers/blog/comment_mailer.rb +11 -9
- data/app/models/blog_category.rb +1 -1
- data/app/models/blog_post.rb +15 -4
- data/app/views/admin/blog/_submenu.html.erb +4 -0
- data/app/views/admin/blog/categories/_category.html.erb +1 -1
- data/app/views/admin/blog/categories/_form.html.erb +1 -1
- data/app/views/admin/blog/categories/index.html.erb +3 -3
- data/app/views/admin/blog/comments/index.html.erb +3 -3
- data/app/views/admin/blog/posts/_form.css.erb +7 -2
- data/app/views/admin/blog/posts/_form.html.erb +5 -5
- data/app/views/admin/blog/posts/_post.html.erb +5 -2
- data/app/views/admin/blog/posts/_teaser_part.html.erb +2 -2
- data/app/views/admin/blog/posts/index.html.erb +3 -3
- data/app/views/admin/blog/posts/uncategorized.html.erb +3 -3
- data/app/views/blog/comment_mailer/notification.html.erb +11 -11
- data/app/views/blog/posts/_comment.html.erb +2 -2
- data/app/views/blog/posts/_nav.html.erb +1 -1
- data/app/views/blog/posts/_post.html.erb +4 -3
- data/app/views/blog/posts/show.html.erb +1 -1
- data/app/views/blog/shared/_post.html.erb +11 -6
- data/changelog.md +17 -4
- data/config/locales/bg.yml +158 -0
- data/config/locales/en.yml +3 -1
- data/config/locales/es.yml +31 -0
- data/config/locales/it.yml +68 -17
- data/config/locales/ja.yml +159 -0
- data/config/locales/nl.yml +1 -0
- data/config/locales/sk.yml +8 -8
- data/config/routes.rb +3 -2
- data/db/migrate/8_add_primary_key_to_categorizations.rb +12 -0
- data/lib/refinery/blog/version.rb +3 -3
- data/lib/refinerycms-blog.rb +6 -16
- data/public/stylesheets/ui-lightness/jquery-ui-1.8.13.custom.css +1 -8
- data/readme.md +3 -2
- data/refinerycms-blog.gemspec +8 -2
- data/spec/models/blog_post_spec.rb +25 -1
- data/todo.md +5 -0
- metadata +62 -96
@@ -1,7 +1,7 @@
|
|
1
1
|
<%= render :partial => '/admin/blog/submenu' %>
|
2
2
|
<div id='records'>
|
3
3
|
<% if searching? %>
|
4
|
-
<h2><%= t('shared.admin.search
|
4
|
+
<h2><%= t('results_for', :scope => 'shared.admin.search', :query => params[:search]) %></h2>
|
5
5
|
<% if @blog_comments.any? %>
|
6
6
|
<%=# will_paginate @blog_comments
|
7
7
|
%>
|
@@ -14,7 +14,7 @@
|
|
14
14
|
<%=# will_paginate @blog_comments
|
15
15
|
%>
|
16
16
|
<% else %>
|
17
|
-
<p><%= t('
|
17
|
+
<p><%= t('search_no_results', :scope => 'admin') %></p>
|
18
18
|
<% end %>
|
19
19
|
<% else %>
|
20
20
|
<% if @blog_comments.any? %>
|
@@ -28,7 +28,7 @@
|
|
28
28
|
<% else %>
|
29
29
|
<h3>
|
30
30
|
<%= t('.no_items_yet',
|
31
|
-
:type => t(
|
31
|
+
:type => t(action_name.gsub('index', 'new'), :scope => 'admin.blog.submenu.comments').downcase) %>
|
32
32
|
</h3>
|
33
33
|
<% end %>
|
34
34
|
<% end %>
|
@@ -1,8 +1,13 @@
|
|
1
1
|
<style type='text/css'>
|
2
|
+
ul.blog_categories{
|
3
|
+
height:200px;
|
4
|
+
overflow:auto;
|
5
|
+
border:1px solid #ccc;
|
6
|
+
padding:5px;
|
7
|
+
}
|
2
8
|
ul.blog_categories, ul.blog_categories li {
|
3
9
|
list-style: none;
|
4
|
-
margin:
|
5
|
-
padding: 0px;
|
10
|
+
margin:5px 0;
|
6
11
|
}
|
7
12
|
a#copy_body_link {
|
8
13
|
background: url("/images/refinery/icons/add.png") no-repeat scroll 0 6px transparent;
|
@@ -14,10 +14,10 @@
|
|
14
14
|
<div id='page-tabs' class='clearfix ui-tabs ui-widget ui-widget-content ui-corner-all'>
|
15
15
|
<ul id='page_parts'>
|
16
16
|
<li class='ui-state-default ui-state-active'>
|
17
|
-
<%= link_to
|
17
|
+
<%= link_to t('body', :scope => 'activerecord.attributes.blog_post'), "#page_part_body" %>
|
18
18
|
</li>
|
19
19
|
<li class='ui-state-default'>
|
20
|
-
<%= link_to
|
20
|
+
<%= link_to t('teaser', :scope => 'activerecord.attributes.blog_post'), "#page_part_teaser" %>
|
21
21
|
</li>
|
22
22
|
<% Refinery::Blog.tabs.each_with_index do |tab, tab_index| %>
|
23
23
|
<li class='ui-state-default' id="custom_<%= tab.name %>_tab">
|
@@ -49,7 +49,7 @@
|
|
49
49
|
</div>
|
50
50
|
|
51
51
|
<div class='field'>
|
52
|
-
<%= f.label :tag_list,
|
52
|
+
<%= f.label :tag_list, t('blog.shared.tags.title') -%>
|
53
53
|
<%= f.text_field :tag_list, :class => 'larger' -%>
|
54
54
|
</div>
|
55
55
|
|
@@ -66,7 +66,7 @@
|
|
66
66
|
</div>
|
67
67
|
<div id='more_options' style="display:none;">
|
68
68
|
<div class="hemisquare">
|
69
|
-
<h3><%= t('admin.blog.submenu.categories
|
69
|
+
<h3><%= t('title', :scope => 'admin.blog.submenu.categories') %></h3>
|
70
70
|
<ul class='blog_categories'>
|
71
71
|
<% @blog_categories.each do |category| %>
|
72
72
|
<li>
|
@@ -99,7 +99,7 @@
|
|
99
99
|
:locals => {
|
100
100
|
:f => f,
|
101
101
|
:continue_editing => true,
|
102
|
-
:delete_title => t('admin.blog.posts.post
|
102
|
+
:delete_title => t('delete', :scope => 'admin.blog.posts.post')
|
103
103
|
} %>
|
104
104
|
<% end -%>
|
105
105
|
|
@@ -1,7 +1,10 @@
|
|
1
1
|
<li class='clearfix record <%= cycle("on", "on-hover") %>' id="<%= dom_id(post) -%>">
|
2
2
|
<span class='title'>
|
3
3
|
<%= post.title %>
|
4
|
-
<span class="preview"
|
4
|
+
<span class="preview">
|
5
|
+
<%= post.published_at.try(:strftime, '%b %d, %Y') || 'draft' %>
|
6
|
+
<%= " by #{post.author.username}" if post.author.present? %>
|
7
|
+
</span>
|
5
8
|
</span>
|
6
9
|
<span class='actions'>
|
7
10
|
<%= link_to refinery_icon_tag("application_go.png"), blog_post_url(post),
|
@@ -13,6 +16,6 @@
|
|
13
16
|
:class => "cancel confirm-delete",
|
14
17
|
:title => t('.delete'),
|
15
18
|
:method => :delete,
|
16
|
-
:confirm => t('shared.admin.delete
|
19
|
+
:confirm => t('message', :scope => 'shared.admin.delete', :title => post.title) %>
|
17
20
|
</span>
|
18
21
|
</li>
|
@@ -2,9 +2,9 @@
|
|
2
2
|
<%= f.text_area :custom_teaser, :rows => 20, :class => 'wymeditor widest' -%>
|
3
3
|
<p>
|
4
4
|
<span class='clearfix label_inline_with_link'>
|
5
|
-
<%= link_to t('admin.blog.posts.form
|
5
|
+
<%= link_to t('copy_body', :scope => 'admin.blog.posts.form'), "#",
|
6
6
|
:id => 'copy_body_link',
|
7
|
-
:title => t('admin.blog.posts.form
|
7
|
+
:title => t('copy_body_help', :scope => 'admin.blog.posts.form') %>
|
8
8
|
</span>
|
9
9
|
</p>
|
10
10
|
</div>
|
@@ -1,14 +1,14 @@
|
|
1
1
|
<%= render :partial => '/admin/blog/submenu' %>
|
2
2
|
<div id='records'>
|
3
3
|
<% if searching? %>
|
4
|
-
<h2><%= t('shared.admin.search
|
4
|
+
<h2><%= t('results_for', :scope => 'shared.admin.search', :query => params[:search]) %></h2>
|
5
5
|
<% if @blog_posts.any? %>
|
6
6
|
<ul>
|
7
7
|
<%= render :partial => "post",
|
8
8
|
:collection => @blog_posts %>
|
9
9
|
</ul>
|
10
10
|
<% else %>
|
11
|
-
<p><%= t('shared.admin.search
|
11
|
+
<p><%= t('no_results', :scope => 'shared.admin.search') %></p>
|
12
12
|
<% end %>
|
13
13
|
<% else %>
|
14
14
|
<% if @blog_posts.any? %>
|
@@ -20,7 +20,7 @@
|
|
20
20
|
<% else %>
|
21
21
|
<p>
|
22
22
|
<strong>
|
23
|
-
<%= t('.no_items_yet', :create => t('admin.blog.submenu.posts
|
23
|
+
<%= t('.no_items_yet', :create => t('new', :scope => 'admin.blog.submenu.posts')) %>
|
24
24
|
</strong>
|
25
25
|
</p>
|
26
26
|
<% end %>
|
@@ -1,12 +1,12 @@
|
|
1
1
|
<%= render :partial => '/admin/blog/submenu' %>
|
2
2
|
<div id='records'>
|
3
3
|
<% if searching? %>
|
4
|
-
<h2><%= t('shared.admin.search
|
4
|
+
<h2><%= t('results_for', :scope => 'shared.admin.search', :query => params[:search]) %></h2>
|
5
5
|
<% if @blog_posts.any? %>
|
6
6
|
<%= render :partial => "blog_posts",
|
7
7
|
:collection => @blog_posts %>
|
8
8
|
<% else %>
|
9
|
-
<p><%= t('
|
9
|
+
<p><%= t('search_no_results', :scope => 'admin') %></p>
|
10
10
|
<% end %>
|
11
11
|
<% else %>
|
12
12
|
<% if @blog_posts.any? %>
|
@@ -18,7 +18,7 @@
|
|
18
18
|
<% else %>
|
19
19
|
<p>
|
20
20
|
<strong>
|
21
|
-
<%= t('.no_items_yet', :create => t('admin.blog.submenu.posts
|
21
|
+
<%= t('.no_items_yet', :create => t('new', :scope => 'admin.blog.submenu.posts')) %>
|
22
22
|
</strong>
|
23
23
|
</p>
|
24
24
|
<% end %>
|
@@ -1,17 +1,17 @@
|
|
1
|
-
<%= t('.greeting') %>,
|
1
|
+
<%=raw t('.greeting') %>,
|
2
2
|
|
3
|
-
<%= t('.you_recieved_new_comment') %>
|
3
|
+
<%=raw t('.you_recieved_new_comment') %>
|
4
4
|
|
5
|
-
<%= t('.comment_starts') %>
|
5
|
+
<%=raw t('.comment_starts') %>
|
6
6
|
|
7
|
-
<%= t('.from') %>: <%= @comment.name %>
|
8
|
-
<%= t('.email') %>: <%= @comment.email %>
|
9
|
-
<%= t('.message') %>:
|
10
|
-
<%= @comment.body %>
|
7
|
+
<%=raw t('.from') %>: <%= @comment.name %>
|
8
|
+
<%=raw t('.email') %>: <%= @comment.email %>
|
9
|
+
<%=raw t('.message') %>:
|
10
|
+
<%=simple_format strip_tags(@comment.body) %>
|
11
11
|
|
12
|
-
<%= t('.comment_ends') %>
|
12
|
+
<%=raw t('.comment_ends') %>
|
13
13
|
|
14
|
-
<%= t('.closing_line') %>,
|
15
|
-
<%= RefinerySetting[:site_name] %>
|
14
|
+
<%=raw t('.closing_line') %>,
|
15
|
+
<%=raw RefinerySetting[:site_name] %>
|
16
16
|
|
17
|
-
<%= t('.ps') %>
|
17
|
+
<%=raw t('.ps') %>
|
@@ -3,8 +3,8 @@
|
|
3
3
|
<%= simple_format auto_link(comment.message.to_s) %>
|
4
4
|
<footer class='blog_comment_author'>
|
5
5
|
<p>
|
6
|
-
<%= t('blog.posts.comments
|
7
|
-
<%= t('blog.posts.comments
|
6
|
+
<%= t('by', :scope => 'blog.posts.comments', :who => comment.name) %>,
|
7
|
+
<%= t('time_ago', :scope => 'blog.posts.comments', :time => time_ago_in_words(comment.created_at)) %>
|
8
8
|
</p>
|
9
9
|
</footer>
|
10
10
|
</article>
|
@@ -3,7 +3,7 @@
|
|
3
3
|
<%= link_to (truncate(@blog_post.next.title) + " »").html_safe, @blog_post.next, :class => 'next' %>
|
4
4
|
<% end -%>
|
5
5
|
|
6
|
-
<%= link_to t('blog.posts.show
|
6
|
+
<%= link_to t('blog_home', :scope => 'blog.posts.show'), blog_root_path, :class => 'home' %>
|
7
7
|
|
8
8
|
<% if @blog_post.prev.present? -%>
|
9
9
|
<%= link_to ("« " + truncate(@blog_post.prev.title)).html_safe, @blog_post.prev, :class => 'prev' %>
|
@@ -8,11 +8,12 @@
|
|
8
8
|
<h1><%= @blog_post.title %></h1>
|
9
9
|
<section class='details'>
|
10
10
|
<time datetime="<%=l @blog_post.published_at.to_date, :format => :default %>" class='posted_at'>
|
11
|
-
<%= t('blog.shared.posts
|
12
|
-
</time
|
11
|
+
<%= t('created_at', :scope => 'blog.shared.posts', :when => l(@blog_post.published_at.to_date, :format => :short)) %>
|
12
|
+
</time>
|
13
|
+
<%= "#{t('by', :scope => 'blog.posts.show')} #{@blog_post.author.username}" if @blog_post.author.present? %>.
|
13
14
|
<% if (categories = @blog_post.categories).any? %>
|
14
15
|
<aside class='filed_in'>
|
15
|
-
<%= t('blog.posts.show
|
16
|
+
<%= t('filed_in', :scope => 'blog.posts.show') %>
|
16
17
|
<% categories.each_with_index do |category, index| %>
|
17
18
|
<%= link_to category.title, blog_category_url(category) -%><%= ',' if index < ((categories.length) - 1) %>
|
18
19
|
<% end %>
|
@@ -4,8 +4,9 @@
|
|
4
4
|
<h1><%= link_to post.title, blog_post_url(post) %></h1>
|
5
5
|
<section class='details'>
|
6
6
|
<time datetime="<%=l post.published_at.to_date, :format => :default %>" class='posted_at'>
|
7
|
-
<%= t('blog.shared.posts
|
8
|
-
</time
|
7
|
+
<%= t('created_at', :scope => 'blog.shared.posts', :when => l(post.published_at.to_date, :format => :short)) %>
|
8
|
+
</time>
|
9
|
+
<%= "#{t('by', :scope => 'blog.posts.show')} #{post.author.username}" if post.author.present? %>.
|
9
10
|
<% if (categories = post.categories).any? %>
|
10
11
|
<aside class='filed_in'>
|
11
12
|
<%= t('filed_in', :scope => 'blog.posts.show') %>
|
@@ -21,18 +22,22 @@
|
|
21
22
|
</section>
|
22
23
|
</header>
|
23
24
|
<section class='clearfix'>
|
24
|
-
|
25
|
+
<% if blog_post_teaser_enabled? %>
|
26
|
+
<%= blog_post_teaser(post) %>
|
27
|
+
<% else %>
|
28
|
+
<%= post.body.html_safe %>
|
29
|
+
<% end %>
|
25
30
|
</section>
|
26
31
|
<footer>
|
27
32
|
<p>
|
28
|
-
<%= link_to t('blog.shared.posts
|
33
|
+
<%= link_to t('read_more', :scope => 'blog.shared.posts'), blog_post_url(post) if blog_post_teaser_enabled? %>
|
29
34
|
</p>
|
30
35
|
<aside class='comment_count'>
|
31
36
|
<% if BlogPost.comments_allowed? %>
|
32
37
|
<% if post.comments.any? %>
|
33
|
-
(<%= pluralize(post.comments.approved.count, t('blog.shared.comments
|
38
|
+
(<%= pluralize(post.comments.approved.count, t('singular', :scope => 'blog.shared.comments')) %>)
|
34
39
|
<% else %>
|
35
|
-
(<%= t('blog.shared.comments
|
40
|
+
(<%= t('none', :scope => 'blog.shared.comments') %>)
|
36
41
|
<% end %>
|
37
42
|
<% end %>
|
38
43
|
</aside>
|
data/changelog.md
CHANGED
@@ -1,13 +1,23 @@
|
|
1
|
-
## 1.7 [UNRELEASED]
|
1
|
+
## 1.7.0 [UNRELEASED]
|
2
|
+
* Bulgarian translations [mirosr](https://github.com/mirosr)
|
3
|
+
* posts/tagged... params[:tag_name] is optional [joemsak](https://github.com/joemsak)
|
4
|
+
* Bug Fix on Categorization relationship: destroying a post produced error because no primary key existed on join table [joemsak](https://github.com/joemsak)
|
5
|
+
* Bug fix on archive listing, don't include draft posts [jgrevich](https://github.com/jgrevich)
|
6
|
+
* [See full list](https://github.com/resolve/refinerycms-blog/compare/1.6.2...1.7.0)
|
7
|
+
|
8
|
+
## 1.6.2 [29 June 2011]
|
2
9
|
* Custom teaser field to overwrite the automatic truncation of the body [wikyd](https://github.com/wikyd)
|
3
10
|
* Tagging URL strategy updated again [joemsak](https://github.com/joemsak)
|
4
|
-
|
5
|
-
## 1.6.2 [UNRELEASED]
|
6
11
|
* Tagging bug fixed [ruprict](https://github.com/ruprict)
|
12
|
+
* Refactored specs [parndt](https://github.com/parndt)
|
13
|
+
* * [See full list](https://github.com/resolve/refinerycms-blog/compare/1.6.1...1.6.2)
|
14
|
+
|
7
15
|
|
8
16
|
## 1.6.1 [21 June 2011]
|
9
17
|
* Tagging URL strategy updated for reliability /blog/posts/tagged/ID-name-parameterized [joemsak](https://github.com/joemsak)
|
10
18
|
* Heroku/PostgreSQL support for autocomplete tags [joemsak](https://github.com/joemsak)
|
19
|
+
* [See full list](https://github.com/resolve/refinerycms-blog/compare/1.6...1.6.1)
|
20
|
+
|
11
21
|
|
12
22
|
## 1.6 [20 June 2011]
|
13
23
|
* Category bug fixes and cleanup [wikyd](https://github.com/wikyd)
|
@@ -17,11 +27,14 @@
|
|
17
27
|
* More testing [wakeless](https://github.com/wakeless)
|
18
28
|
* Tag list autocomplete baked in [joemsak](https://github.com/joemsak)
|
19
29
|
* Customize the URL of your blog post [wikyd](https://github.com/wikyd)
|
30
|
+
* [See full list](https://github.com/resolve/refinerycms-blog/compare/1.5...1.6)
|
31
|
+
|
20
32
|
|
21
33
|
## 1.5 [28 May 2011]
|
22
34
|
|
23
35
|
* Added Gravatar support. [parndt](https://github.com/parndt)
|
24
36
|
* Added support for Refinery CMS 1.0.0 and above. [parndt](https://github.com/parndt)
|
37
|
+
* [See full list](https://github.com/resolve/refinerycms-blog/compare/1.4...1.5)
|
25
38
|
|
26
39
|
## 1.4 [26 May 2011]
|
27
40
|
|
@@ -63,4 +76,4 @@
|
|
63
76
|
* Rails 3 Support
|
64
77
|
* Archives
|
65
78
|
* Categories
|
66
|
-
* [See full list](https://github.com/resolve/refinerycms-blog/compare/1.0...1.1)
|
79
|
+
* [See full list](https://github.com/resolve/refinerycms-blog/compare/1.0...1.1)
|
@@ -0,0 +1,158 @@
|
|
1
|
+
bg:
|
2
|
+
plugins:
|
3
|
+
refinerycms_blog:
|
4
|
+
title: Блог
|
5
|
+
admin:
|
6
|
+
blog:
|
7
|
+
categories:
|
8
|
+
category:
|
9
|
+
edit: Редактиране на тази категория
|
10
|
+
delete: Изтриване на тази категория завинаги
|
11
|
+
index:
|
12
|
+
no_items_yet: 'Все още няма категории. Натиснете "%{create}", за да въведете нова.'
|
13
|
+
comments:
|
14
|
+
approved: 'Коментара от "%{author}" бе одобрен.'
|
15
|
+
comment:
|
16
|
+
view_live_html: 'Преглед на този коментар <br/><em>(ще се отвори се в нов прозорец)</em>'
|
17
|
+
read: Прочитане на този коментар
|
18
|
+
reject: Отхвърляне на този коментар
|
19
|
+
approve: Одобряване на този коментар
|
20
|
+
rejected: 'Коментара от "%{author}" бе отхвърлен.'
|
21
|
+
index:
|
22
|
+
no_items_yet: '%{type} коментари не бяха намерени.'
|
23
|
+
show:
|
24
|
+
comment: Коментар
|
25
|
+
blog_post: Публикация
|
26
|
+
from: Публикувано от
|
27
|
+
date: Публикувано на
|
28
|
+
message: Коментар
|
29
|
+
details: Детайли
|
30
|
+
age: Възраст
|
31
|
+
actions: Действия
|
32
|
+
back: Обратно към всички коментари
|
33
|
+
reject: Отхвърляне на този коментар
|
34
|
+
approve: Одобряване на този коментар
|
35
|
+
posts:
|
36
|
+
form:
|
37
|
+
advanced_options: Разширени настройки
|
38
|
+
toggle_advanced_options: Натиснете, за да достъпите настройките за етикета "meta" и менюто
|
39
|
+
save_as_draft: Запис като чернова
|
40
|
+
published_at: Дата на публикуване
|
41
|
+
custom_url: Уеб адрес по избор
|
42
|
+
custom_url_help: Вместо от заглавието, генерирайте уеб адреса за тази публикация чрез този текст.
|
43
|
+
copy_body: Копиране на съдържанието на публикацията като извадка
|
44
|
+
copy_body_help: Съдържанието на публикацията ще се копира като извадка. Оставете извадката празна и Refinery автоматично ще я сглоби.
|
45
|
+
index:
|
46
|
+
no_items_yet: 'Все още няма публикации. Натиснете "%{create}", за да въведете нова.'
|
47
|
+
uncategorized:
|
48
|
+
no_items_yet: 'Не съществуват некатегоризирани публикации.'
|
49
|
+
post:
|
50
|
+
view_live_html: 'Преглед на този публикация <br/><em>(ще се отвори се в нов прозорец)</em>'
|
51
|
+
edit: Редактиране на тази публикация
|
52
|
+
delete: Изтриване на тази публикация завинаги
|
53
|
+
settings:
|
54
|
+
notification_recipients:
|
55
|
+
value: Изпращане на уведомления до
|
56
|
+
explanation: 'Всеки път, когато някой коментира публикация, Refinery ще изпраща е-писмо, за да уведоми, че съществува нов коментар.'
|
57
|
+
hint: 'При добавяне на коментар, Refinery ще Ви уведоми по е-пощата.'
|
58
|
+
example: "Въведете адреса(ите) на Вашата е-поща. Например: jack@work.com, jill@office.com"
|
59
|
+
updated: 'Уведомления бяха изпратени до "%{recipients}"'
|
60
|
+
submenu:
|
61
|
+
categories:
|
62
|
+
title: Категории
|
63
|
+
manage: Управление
|
64
|
+
new: Добавяне на нова категория
|
65
|
+
comments:
|
66
|
+
title: Коментари
|
67
|
+
title_with_count: 'Коментари (%{new_count} нови)'
|
68
|
+
new: Нови
|
69
|
+
unmoderated: Нови
|
70
|
+
approved: Одобрени
|
71
|
+
rejected: Отхвърлени
|
72
|
+
posts:
|
73
|
+
title: Публикации
|
74
|
+
manage: Управление на публикации
|
75
|
+
new: Добавяне на нова публикация
|
76
|
+
uncategorized: Некатегоризирани публикации
|
77
|
+
settings:
|
78
|
+
title: Настройки
|
79
|
+
moderation: Модерация
|
80
|
+
update_notified: Получатели на уведомления
|
81
|
+
comments: Коментари
|
82
|
+
blog:
|
83
|
+
comment_mailer:
|
84
|
+
notification:
|
85
|
+
greeting: Здравейте
|
86
|
+
you_recieved_new_comment: Току що получихте нов коментар на Вашия уебсайт.
|
87
|
+
comment_starts: --- Начало на коментара ---
|
88
|
+
comment_ends: --- Край на коментара ---
|
89
|
+
from: От
|
90
|
+
email: Е-поща
|
91
|
+
message: Съобщение
|
92
|
+
closing_line: Поздрави
|
93
|
+
ps: 'П.П. Всички Ваши коментари се съхраняват от Refinery в секция "Блог" в подменю "Коментари" и могат да бъдат прегледани по-късно.'
|
94
|
+
shared:
|
95
|
+
categories:
|
96
|
+
title: Категории
|
97
|
+
rss_feed:
|
98
|
+
title: RSS хранилка
|
99
|
+
subscribe: Абониране
|
100
|
+
posts:
|
101
|
+
other: Други публикации
|
102
|
+
created_at: 'Публикувано на %{when}'
|
103
|
+
read_more: Цялата публикация
|
104
|
+
comments:
|
105
|
+
singular: коментар
|
106
|
+
none: няма коментари
|
107
|
+
archives: Архиви
|
108
|
+
tags:
|
109
|
+
title: "Етикети"
|
110
|
+
categories:
|
111
|
+
show:
|
112
|
+
no_posts: Тук все още няма публикации.
|
113
|
+
posts:
|
114
|
+
post:
|
115
|
+
filed_in: Категория
|
116
|
+
comment: коментар
|
117
|
+
comments:
|
118
|
+
by: 'Публикувано от %{who}'
|
119
|
+
time_ago: 'преди %{time}'
|
120
|
+
thank_you: 'Благодаря за Вашия коментар.'
|
121
|
+
thank_you_moderated: 'Благодаря за Вашия коментар. Съобщението Ви е в опашката за модерация и скоро ще бъде показано.'
|
122
|
+
index:
|
123
|
+
no_blog_articles_yet: Все още няма публикувани статии. Очаквайте скоро.
|
124
|
+
show:
|
125
|
+
blog_home: Обратно към началото на блога
|
126
|
+
comments:
|
127
|
+
title: Коментари
|
128
|
+
add: Вашият коментар
|
129
|
+
other: Други публикации
|
130
|
+
filed_in: Категория
|
131
|
+
tagged: Отбелязано с
|
132
|
+
submit: Изпращане на коментар
|
133
|
+
name: Име
|
134
|
+
email: Е-поща
|
135
|
+
message: Съобщение
|
136
|
+
by: от
|
137
|
+
tagged:
|
138
|
+
no_blog_articles_yet: Все още няма публикувани статии. Очаквайте скоро.
|
139
|
+
posts_tagged: Публикации отбелязани с
|
140
|
+
archive:
|
141
|
+
blog_archive_for: 'Архив на блога за %{date}'
|
142
|
+
no_blog_articles_posted: 'Все още няма публикувани статии за %{date}. Очаквайте скоро.'
|
143
|
+
activerecord:
|
144
|
+
models:
|
145
|
+
blog_category: Категория
|
146
|
+
blog_comment: Коментар
|
147
|
+
blog_post: Публикация
|
148
|
+
attributes:
|
149
|
+
blog_category:
|
150
|
+
title: Заглавие
|
151
|
+
blog_comment:
|
152
|
+
name: Име
|
153
|
+
email: Е-поща
|
154
|
+
message: Съобщение
|
155
|
+
blog_post:
|
156
|
+
title: Заглавие
|
157
|
+
body: Съдържание
|
158
|
+
teaser: Извадка
|