publify_core 9.0.0.pre5 → 9.2.0

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of publify_core might be problematic. Click here for more details.

Files changed (395) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGELOG.md +102 -6
  3. data/README.md +9 -0
  4. data/app/assets/javascripts/bootstrap-sprockets.js +8 -0
  5. data/app/assets/javascripts/bootstrap/affix.js +164 -0
  6. data/app/assets/javascripts/bootstrap/alert.js +95 -0
  7. data/app/assets/javascripts/bootstrap/button.js +125 -0
  8. data/app/assets/javascripts/bootstrap/collapse.js +212 -0
  9. data/app/assets/javascripts/bootstrap/dropdown.js +165 -0
  10. data/app/assets/javascripts/bootstrap/modal.js +358 -0
  11. data/app/assets/javascripts/bootstrap/tab.js +155 -0
  12. data/app/assets/javascripts/bootstrap/transition.js +59 -0
  13. data/app/assets/javascripts/lightbox.js +4 -4
  14. data/app/assets/javascripts/publify_admin.js +1 -35
  15. data/app/assets/stylesheets/_bootstrap-compass.scss +9 -0
  16. data/app/assets/stylesheets/_bootstrap-mincer.scss +19 -0
  17. data/app/assets/stylesheets/_bootstrap-sprockets.scss +9 -0
  18. data/app/assets/stylesheets/_bootstrap.scss +42 -0
  19. data/app/assets/stylesheets/administration_structure.css.scss +1 -45
  20. data/app/assets/stylesheets/bootstrap/_alerts.scss +73 -0
  21. data/app/assets/stylesheets/bootstrap/_button-groups.scss +242 -0
  22. data/app/assets/stylesheets/bootstrap/_buttons.scss +168 -0
  23. data/app/assets/stylesheets/bootstrap/_close.scss +37 -0
  24. data/app/assets/stylesheets/bootstrap/_code.scss +69 -0
  25. data/app/assets/stylesheets/bootstrap/_component-animations.scss +38 -0
  26. data/app/assets/stylesheets/bootstrap/_dropdowns.scss +213 -0
  27. data/app/assets/stylesheets/bootstrap/_forms.scss +586 -0
  28. data/app/assets/stylesheets/bootstrap/_grid.scss +94 -0
  29. data/app/assets/stylesheets/bootstrap/_labels.scss +66 -0
  30. data/app/assets/stylesheets/bootstrap/_media.scss +66 -0
  31. data/app/assets/stylesheets/bootstrap/_mixins.scss +37 -0
  32. data/app/assets/stylesheets/bootstrap/_modals.scss +150 -0
  33. data/app/assets/stylesheets/bootstrap/_navbar.scss +479 -0
  34. data/app/assets/stylesheets/bootstrap/_navs.scss +242 -0
  35. data/app/assets/stylesheets/bootstrap/_normalize.scss +427 -0
  36. data/app/assets/stylesheets/bootstrap/_pagination.scss +86 -0
  37. data/app/assets/stylesheets/bootstrap/_panels.scss +222 -0
  38. data/app/assets/stylesheets/bootstrap/_print.scss +99 -0
  39. data/app/assets/stylesheets/bootstrap/_scaffolding.scss +160 -0
  40. data/app/assets/stylesheets/bootstrap/_tables.scss +234 -0
  41. data/app/assets/stylesheets/bootstrap/_theme.scss +224 -0
  42. data/app/assets/stylesheets/bootstrap/_type.scss +296 -0
  43. data/app/assets/stylesheets/bootstrap/_utilities.scss +55 -0
  44. data/app/assets/stylesheets/bootstrap/_variables.scss +638 -0
  45. data/app/assets/stylesheets/bootstrap/_wells.scss +29 -0
  46. data/app/assets/stylesheets/bootstrap/mixins/_alerts.scss +15 -0
  47. data/app/assets/stylesheets/bootstrap/mixins/_background-variant.scss +12 -0
  48. data/app/assets/stylesheets/bootstrap/mixins/_border-radius.scss +18 -0
  49. data/app/assets/stylesheets/bootstrap/mixins/_buttons.scss +56 -0
  50. data/app/assets/stylesheets/bootstrap/mixins/_center-block.scss +7 -0
  51. data/app/assets/stylesheets/bootstrap/mixins/_clearfix.scss +22 -0
  52. data/app/assets/stylesheets/bootstrap/mixins/_forms.scss +82 -0
  53. data/app/assets/stylesheets/bootstrap/mixins/_gradients.scss +56 -0
  54. data/app/assets/stylesheets/bootstrap/mixins/_grid-framework.scss +81 -0
  55. data/app/assets/stylesheets/bootstrap/mixins/_grid.scss +122 -0
  56. data/app/assets/stylesheets/bootstrap/mixins/_hide-text.scss +21 -0
  57. data/app/assets/stylesheets/bootstrap/mixins/_image.scss +28 -0
  58. data/app/assets/stylesheets/bootstrap/mixins/_labels.scss +12 -0
  59. data/app/assets/stylesheets/bootstrap/mixins/_nav-divider.scss +10 -0
  60. data/app/assets/stylesheets/bootstrap/mixins/_nav-vertical-align.scss +9 -0
  61. data/app/assets/stylesheets/bootstrap/mixins/_opacity.scss +7 -0
  62. data/app/assets/stylesheets/bootstrap/mixins/_pagination.scss +24 -0
  63. data/app/assets/stylesheets/bootstrap/mixins/_panels.scss +20 -0
  64. data/app/assets/stylesheets/bootstrap/mixins/_reset-filter.scss +8 -0
  65. data/app/assets/stylesheets/bootstrap/mixins/_resize.scss +6 -0
  66. data/app/assets/stylesheets/bootstrap/mixins/_responsive-visibility.scss +17 -0
  67. data/app/assets/stylesheets/bootstrap/mixins/_size.scss +10 -0
  68. data/app/assets/stylesheets/bootstrap/mixins/_tab-focus.scss +9 -0
  69. data/app/assets/stylesheets/bootstrap/mixins/_table-row.scss +28 -0
  70. data/app/assets/stylesheets/bootstrap/mixins/_text-emphasis.scss +12 -0
  71. data/app/assets/stylesheets/bootstrap/mixins/_text-overflow.scss +8 -0
  72. data/app/assets/stylesheets/bootstrap/mixins/_vendor-prefixes.scss +222 -0
  73. data/app/assets/stylesheets/lightbox.css +3 -3
  74. data/app/assets/stylesheets/publify_admin.css.scss +0 -1
  75. data/app/controllers/accounts_controller.rb +2 -0
  76. data/app/controllers/admin/base_controller.rb +8 -22
  77. data/app/controllers/admin/content_controller.rb +69 -48
  78. data/app/controllers/admin/dashboard_controller.rb +20 -74
  79. data/app/controllers/admin/feedback_controller.rb +45 -36
  80. data/app/controllers/admin/notes_controller.rb +16 -10
  81. data/app/controllers/admin/pages_controller.rb +20 -34
  82. data/app/controllers/admin/post_types_controller.rb +7 -5
  83. data/app/controllers/admin/profiles_controller.rb +15 -5
  84. data/app/controllers/admin/redirects_controller.rb +9 -5
  85. data/app/controllers/admin/resources_controller.rb +7 -4
  86. data/app/controllers/admin/seo_controller.rb +12 -10
  87. data/app/controllers/admin/settings_controller.rb +7 -5
  88. data/app/controllers/admin/sidebar_controller.rb +7 -5
  89. data/app/controllers/admin/tags_controller.rb +7 -3
  90. data/app/controllers/admin/themes_controller.rb +10 -7
  91. data/app/controllers/admin/users_controller.rb +10 -7
  92. data/app/controllers/articles_controller.rb +92 -81
  93. data/app/controllers/authors_controller.rb +6 -3
  94. data/app/controllers/base_controller.rb +9 -11
  95. data/app/controllers/comments_controller.rb +15 -16
  96. data/app/controllers/content_controller.rb +12 -19
  97. data/app/controllers/feedback_controller.rb +7 -39
  98. data/app/controllers/notes_controller.rb +6 -6
  99. data/app/controllers/setup_controller.rb +25 -26
  100. data/app/controllers/tags_controller.rb +16 -16
  101. data/app/controllers/text_controller.rb +2 -4
  102. data/app/controllers/textfilter_controller.rb +2 -0
  103. data/app/controllers/theme_controller.rb +22 -17
  104. data/app/controllers/xml_controller.rb +13 -59
  105. data/app/helpers/admin/base_helper.rb +28 -29
  106. data/app/helpers/admin/feedback_helper.rb +34 -24
  107. data/app/helpers/articles_helper.rb +4 -2
  108. data/app/helpers/authors_helper.rb +9 -18
  109. data/app/helpers/base_helper.rb +66 -55
  110. data/app/helpers/blog_helper.rb +4 -2
  111. data/app/helpers/xml_helper.rb +5 -3
  112. data/app/jobs/application_job.rb +4 -0
  113. data/app/mailers/notification_mailer.rb +5 -3
  114. data/app/models/ability.rb +25 -24
  115. data/app/models/archives_sidebar.rb +18 -18
  116. data/app/models/article.rb +84 -99
  117. data/app/models/article/factory.rb +14 -6
  118. data/app/models/blog.rb +98 -110
  119. data/app/models/comment.rb +14 -10
  120. data/app/models/config_manager.rb +4 -2
  121. data/app/models/content.rb +45 -65
  122. data/app/models/content_base.rb +7 -14
  123. data/app/models/feedback.rb +91 -66
  124. data/app/models/meta_sidebar.rb +5 -3
  125. data/app/models/note.rb +31 -23
  126. data/app/models/page.rb +16 -10
  127. data/app/models/page_sidebar.rb +4 -2
  128. data/app/models/ping.rb +2 -113
  129. data/app/models/post_type.rb +4 -3
  130. data/app/models/redirect.rb +13 -7
  131. data/app/models/redirection.rb +3 -1
  132. data/app/models/resource.rb +6 -22
  133. data/app/models/search_sidebar.rb +4 -2
  134. data/app/models/sidebar.rb +12 -7
  135. data/app/models/static_sidebar.rb +15 -13
  136. data/app/models/tag.rb +23 -15
  137. data/app/models/tag_sidebar.rb +10 -7
  138. data/app/models/text_filter.rb +85 -11
  139. data/app/models/trackback.rb +7 -18
  140. data/app/models/trigger.rb +8 -19
  141. data/app/models/user.rb +46 -52
  142. data/app/services/title_builder.rb +52 -45
  143. data/app/uploaders/resource_uploader.rb +35 -2
  144. data/app/views/accounts/confirm.html.erb +3 -4
  145. data/app/views/admin/content/_article_list.html.erb +24 -9
  146. data/app/views/admin/content/_form.html.erb +71 -51
  147. data/app/views/admin/content/autosave.js.erb +2 -2
  148. data/app/views/admin/content/edit.html.erb +1 -1
  149. data/app/views/admin/content/index.html.erb +25 -15
  150. data/app/views/admin/content/new.html.erb +2 -2
  151. data/app/views/admin/dashboard/_comment.html.erb +5 -5
  152. data/app/views/admin/dashboard/_comments.html.erb +2 -2
  153. data/app/views/admin/dashboard/_drafts.html.erb +5 -5
  154. data/app/views/admin/dashboard/_overview.html.erb +7 -9
  155. data/app/views/admin/dashboard/_welcome.html.erb +11 -11
  156. data/app/views/admin/dashboard/index.html.erb +12 -7
  157. data/app/views/admin/feedback/_button.html.erb +6 -6
  158. data/app/views/admin/feedback/_feedback.html.erb +3 -3
  159. data/app/views/admin/feedback/_ham.html.erb +27 -9
  160. data/app/views/admin/feedback/_spam.html.erb +26 -16
  161. data/app/views/admin/feedback/article.html.erb +20 -21
  162. data/app/views/admin/feedback/edit.html.erb +14 -15
  163. data/app/views/admin/feedback/{ham.js → ham.js.erb} +0 -0
  164. data/app/views/admin/feedback/index.html.erb +25 -23
  165. data/app/views/admin/feedback/{spam.js → spam.js.erb} +0 -0
  166. data/app/views/admin/migrations/show.html.erb +10 -11
  167. data/app/views/admin/notes/_form.html.erb +13 -13
  168. data/app/views/admin/notes/_list.html.erb +19 -8
  169. data/app/views/admin/notes/_note.html.erb +12 -7
  170. data/app/views/admin/notes/edit.html.erb +6 -1
  171. data/app/views/admin/notes/index.html.erb +5 -1
  172. data/app/views/admin/notes/show.html.erb +2 -2
  173. data/app/views/admin/pages/_form.html.erb +86 -77
  174. data/app/views/admin/pages/_pages.html.erb +11 -4
  175. data/app/views/admin/pages/edit.html.erb +3 -1
  176. data/app/views/admin/pages/index.html.erb +10 -6
  177. data/app/views/admin/pages/new.html.erb +3 -1
  178. data/app/views/admin/post_types/_index_and_form.html.erb +15 -16
  179. data/app/views/admin/post_types/edit.html.erb +1 -1
  180. data/app/views/admin/post_types/index.html.erb +1 -1
  181. data/app/views/admin/profiles/index.html.erb +2 -3
  182. data/app/views/admin/redirects/_index_and_form.html.erb +10 -11
  183. data/app/views/admin/redirects/edit.html.erb +1 -1
  184. data/app/views/admin/redirects/index.html.erb +1 -1
  185. data/app/views/admin/resources/index.html.erb +19 -16
  186. data/app/views/admin/seo/_general.html.erb +40 -59
  187. data/app/views/admin/seo/_permalinks.html.erb +17 -17
  188. data/app/views/admin/seo/_titles.html.erb +81 -82
  189. data/app/views/admin/seo/show.html.erb +14 -19
  190. data/app/views/admin/settings/display.html.erb +42 -52
  191. data/app/views/admin/settings/feedback.html.erb +59 -67
  192. data/app/views/admin/settings/index.html.erb +30 -31
  193. data/app/views/admin/settings/write.html.erb +27 -46
  194. data/app/views/admin/shared/_edit.html.erb +3 -3
  195. data/app/views/admin/shared/_menu.html.erb +26 -26
  196. data/app/views/admin/shared/_twitter_alert.html.erb +1 -1
  197. data/app/views/admin/sidebar/_config.html.erb +5 -5
  198. data/app/views/admin/sidebar/_target_sidebar.html.erb +4 -4
  199. data/app/views/admin/sidebar/index.html.erb +7 -7
  200. data/app/views/admin/tags/_index_and_form.html.erb +11 -12
  201. data/app/views/admin/tags/edit.html.erb +1 -1
  202. data/app/views/admin/tags/index.html.erb +1 -1
  203. data/app/views/admin/themes/index.html.erb +5 -6
  204. data/app/views/admin/users/_form.html.erb +34 -34
  205. data/app/views/admin/users/edit.html.erb +2 -2
  206. data/app/views/admin/users/index.html.erb +10 -12
  207. data/app/views/admin/users/new.html.erb +2 -2
  208. data/app/views/archives_sidebar/_content.html.erb +2 -2
  209. data/app/views/articles/_archives_article.html.erb +9 -0
  210. data/app/views/articles/_article.html.erb +9 -9
  211. data/app/views/articles/_article_author.html.erb +4 -0
  212. data/app/views/articles/_article_collection.html.erb +1 -1
  213. data/app/views/articles/_article_content.html.erb +2 -2
  214. data/app/views/articles/_article_excerpt.html.erb +11 -9
  215. data/app/views/articles/_article_links.html.erb +5 -3
  216. data/app/views/articles/_comment_errors.html.erb +1 -1
  217. data/app/views/articles/_comment_form.html.erb +12 -12
  218. data/app/views/articles/_comment_list.html.erb +5 -5
  219. data/app/views/articles/_comment_preview.html.erb +3 -3
  220. data/app/views/articles/_full_article_content.html.erb +4 -2
  221. data/app/views/articles/_password_form.html.erb +4 -4
  222. data/app/views/articles/_trackback.html.erb +2 -2
  223. data/app/views/articles/archives.html.erb +11 -21
  224. data/app/views/articles/feedback_atom_feed.atom.builder +7 -5
  225. data/app/views/articles/feedback_rss_feed.rss.builder +11 -11
  226. data/app/views/articles/index_atom_feed.atom.builder +5 -4
  227. data/app/views/articles/index_rss_feed.rss.builder +8 -8
  228. data/app/views/articles/live_search.html.erb +3 -3
  229. data/app/views/articles/read.html.erb +19 -37
  230. data/app/views/articles/search.html.erb +3 -3
  231. data/app/views/articles/trackback.xml.builder +3 -1
  232. data/app/views/articles/view_page.html.erb +2 -2
  233. data/app/views/authors/show.html.erb +18 -28
  234. data/app/views/authors/show_atom_feed.atom.builder +5 -4
  235. data/app/views/authors/show_rss_feed.rss.builder +8 -8
  236. data/app/views/comments/_comment.html.erb +17 -16
  237. data/app/views/devise/mailer/reset_password_instructions.html.erb +7 -9
  238. data/app/views/devise/passwords/edit.html.erb +4 -4
  239. data/app/views/devise/passwords/new.html.erb +1 -1
  240. data/app/views/devise/registrations/new.html.erb +5 -5
  241. data/app/views/devise/sessions/new.html.erb +3 -3
  242. data/app/views/errors/404.html.erb +2 -2
  243. data/app/views/feedback/index.atom.builder +9 -0
  244. data/app/views/feedback/index.rss.builder +20 -0
  245. data/app/views/layouts/accounts.html.erb +26 -26
  246. data/app/views/layouts/administration.html.erb +31 -31
  247. data/app/views/layouts/default.html.erb +4 -3
  248. data/app/views/layouts/editor.html.erb +5 -19
  249. data/app/views/meta_sidebar/_content.html.erb +2 -2
  250. data/app/views/notes/_note.html.erb +16 -15
  251. data/app/views/notes/index.html.erb +2 -2
  252. data/app/views/notes/show_in_reply.html.erb +1 -1
  253. data/app/views/notification_mailer/_mail_footer.html.erb +3 -5
  254. data/app/views/notification_mailer/_mail_header.html.erb +2 -0
  255. data/app/views/notification_mailer/article.html.erb +5 -4
  256. data/app/views/notification_mailer/comment.html.erb +9 -8
  257. data/app/views/notification_mailer/notif_user.html.erb +4 -9
  258. data/app/views/page_sidebar/_content.html.erb +1 -1
  259. data/app/views/search_sidebar/_content.html.erb +2 -2
  260. data/app/views/settings/install.html.erb +2 -2
  261. data/app/views/setup/index.html.erb +9 -5
  262. data/app/views/shared/_atom_header.atom.builder +4 -4
  263. data/app/views/shared/_atom_item_article.atom.builder +19 -22
  264. data/app/views/shared/_atom_item_comment.atom.builder +5 -5
  265. data/app/views/shared/_atom_item_trackback.atom.builder +5 -4
  266. data/app/views/shared/_google_analytics.html.erb +8 -0
  267. data/app/views/shared/_page_header.html.erb +10 -13
  268. data/app/views/shared/_rss_item_article.rss.builder +12 -15
  269. data/app/views/shared/_rss_item_comment.rss.builder +2 -1
  270. data/app/views/shared/_rss_item_trackback.rss.builder +2 -0
  271. data/app/views/sidebar/display_plugins.html.erb +1 -1
  272. data/app/views/tag_sidebar/_content.html.erb +1 -1
  273. data/app/views/tags/index.html.erb +2 -2
  274. data/app/views/xml/_googlesitemap_item_article.googlesitemap.builder +2 -0
  275. data/app/views/xml/_googlesitemap_item_category.googlesitemap.builder +2 -0
  276. data/app/views/xml/_googlesitemap_item_page.googlesitemap.builder +2 -0
  277. data/app/views/xml/_googlesitemap_item_tag.googlesitemap.builder +2 -0
  278. data/app/views/xml/sitemap.googlesitemap.builder +9 -0
  279. data/config/i18n-tasks.yml +0 -5
  280. data/config/initializers/devise.rb +10 -4
  281. data/config/initializers/mime_types.rb +3 -2
  282. data/config/locales/da.yml +140 -108
  283. data/config/locales/de.yml +147 -111
  284. data/config/locales/en.yml +133 -102
  285. data/config/locales/es-MX.yml +141 -106
  286. data/config/locales/fr.yml +172 -122
  287. data/config/locales/he.yml +132 -105
  288. data/config/locales/it.yml +141 -108
  289. data/config/locales/ja.yml +115 -100
  290. data/config/locales/lt.yml +158 -110
  291. data/config/locales/nb-NO.yml +128 -101
  292. data/config/locales/nl.yml +147 -113
  293. data/config/locales/pl.yml +335 -275
  294. data/config/locales/pt-BR.yml +143 -107
  295. data/config/locales/ro.yml +155 -108
  296. data/config/locales/ru.yml +166 -105
  297. data/config/locales/zh-CN.yml +112 -96
  298. data/config/locales/zh-TW.yml +116 -99
  299. data/config/routes.rb +70 -87
  300. data/db/migrate/113_initial_schema.rb +6 -6
  301. data/db/migrate/114_fixes_buggy_articles_and_notes.rb +8 -6
  302. data/db/migrate/115_drops_categories_for_tags.rb +7 -6
  303. data/db/migrate/20150207131657_add_missing_indexes.rb +3 -1
  304. data/db/migrate/20150807134129_simplify_redirect_relations.rb +6 -1
  305. data/db/migrate/20150808052637_add_blog_ids.rb +11 -7
  306. data/db/migrate/20150808191127_add_blog_id_to_redirects.rb +3 -1
  307. data/db/migrate/20150810094754_add_blog_id_to_tags.rb +3 -1
  308. data/db/migrate/20160108111120_add_devise_to_users.rb +3 -1
  309. data/db/migrate/20160108184201_move_last_connection_to_last_sign_in_at.rb +3 -1
  310. data/db/migrate/20160110094906_remove_profiles_rights.rb +3 -1
  311. data/db/migrate/20160605103918_replace_profile_id_with_string.rb +3 -3
  312. data/db/migrate/20160605154632_remove_profiles.rb +12 -7
  313. data/db/migrate/20160701061851_demand_blog_id_on_contents.rb +3 -1
  314. data/db/migrate/20160701062604_add_blog_id_to_resources.rb +3 -1
  315. data/db/migrate/20170528093024_move_resources_to_content.rb +7 -0
  316. data/db/migrate/20170528094923_move_tags_to_content.rb +8 -0
  317. data/db/migrate/20170528201606_remove_separate_published_flag.rb +7 -0
  318. data/db/migrate/20170605071626_remove_extra_state_columns_from_feedback.rb +8 -0
  319. data/db/migrate/20170702105201_remove_published_at_from_feedback.rb +7 -0
  320. data/db/migrate/20190208151235_add_text_filter_name_fields.rb +9 -0
  321. data/db/migrate/20190208152646_move_text_filter_to_name.rb +97 -0
  322. data/db/migrate/20190209155717_remove_text_filter_ids.rb +19 -0
  323. data/db/migrate/20190209160610_remove_text_filters.rb +17 -0
  324. data/db/migrate/20200413140440_add_unique_indexes.rb +10 -0
  325. data/db/seeds.rb +8 -20
  326. data/lib/email_notify.rb +3 -1
  327. data/lib/format.rb +4 -12
  328. data/lib/publify_core.rb +36 -36
  329. data/lib/publify_core/engine.rb +11 -4
  330. data/lib/publify_core/lang.rb +5 -1
  331. data/lib/publify_core/testing_support/dns_mock.rb +15 -0
  332. data/lib/publify_core/testing_support/factories.rb +240 -0
  333. data/lib/publify_core/testing_support/feed_assertions.rb +48 -0
  334. data/lib/publify_core/testing_support/fixtures/exploit.svg +4 -0
  335. data/lib/publify_core/testing_support/fixtures/fakepng.png +1 -0
  336. data/lib/publify_core/testing_support/fixtures/otherfile.txt +1 -0
  337. data/lib/publify_core/testing_support/fixtures/testfile.png +0 -0
  338. data/lib/publify_core/testing_support/fixtures/testfile.txt +1 -0
  339. data/lib/publify_core/testing_support/upload_fixtures.rb +15 -0
  340. data/lib/publify_core/version.rb +3 -1
  341. data/lib/publify_guid.rb +4 -2
  342. data/lib/publify_plugins.rb +10 -5
  343. data/lib/publify_textfilter_markdown.rb +38 -25
  344. data/lib/publify_textfilter_none.rb +5 -3
  345. data/lib/publify_textfilter_smartypants.rb +5 -3
  346. data/lib/publify_textfilter_textile.rb +7 -4
  347. data/lib/publify_textfilter_twitterfilter.rb +13 -7
  348. data/lib/publify_time.rb +6 -2
  349. data/lib/sidebar_field.rb +29 -20
  350. data/lib/sidebar_registry.rb +5 -3
  351. data/lib/spam_protection.rb +19 -17
  352. data/lib/tasks/i18n.rake +9 -0
  353. data/lib/tasks/manifest.rake +30 -0
  354. data/lib/tasks/publify_core_tasks.rake +2 -0
  355. data/lib/text_filter_plugin.rb +30 -29
  356. data/lib/theme.rb +5 -5
  357. data/lib/transforms.rb +22 -20
  358. data/{app/assets/stylesheets/publify_core/.keep → themes/plain/javascripts/theme.js} +0 -0
  359. metadata +304 -130
  360. data/.gitignore +0 -13
  361. data/.rspec +0 -2
  362. data/.rubocop.yml +0 -84
  363. data/.rubocop_todo.yml +0 -148
  364. data/.travis.yml +0 -27
  365. data/Gemfile +0 -17
  366. data/README.rdoc +0 -3
  367. data/Rakefile +0 -35
  368. data/app/assets/javascripts/widearea.js +0 -486
  369. data/app/assets/stylesheets/widearea.css +0 -133
  370. data/app/controllers/.keep +0 -0
  371. data/app/controllers/admin/migrations_controller.rb +0 -19
  372. data/app/controllers/admin/textfilters_controller.rb +0 -6
  373. data/app/controllers/concerns/.keep +0 -0
  374. data/app/controllers/trackbacks_controller.rb +0 -36
  375. data/app/helpers/.keep +0 -0
  376. data/app/mailers/.keep +0 -0
  377. data/app/models/.keep +0 -0
  378. data/app/models/article/states.rb +0 -179
  379. data/app/models/concerns/.keep +0 -0
  380. data/app/models/feedback/states.rb +0 -256
  381. data/app/services/migrator.rb +0 -25
  382. data/app/views/.keep +0 -0
  383. data/app/views/admin/dashboard/_inbound.html.erb +0 -31
  384. data/app/views/admin/notes/_header.html.erb +0 -6
  385. data/app/views/articles/_protected_article_content.html.erb +0 -6
  386. data/app/views/comments/index.html.erb +0 -1
  387. data/app/views/comments/index_atom_feed.atom.builder +0 -8
  388. data/app/views/comments/index_rss_feed.rss.builder +0 -20
  389. data/app/views/trackbacks/index_atom_feed.atom.builder +0 -7
  390. data/app/views/trackbacks/index_rss_feed.rss.builder +0 -20
  391. data/app/views/trackbacks/trackback.xml.builder +0 -4
  392. data/app/views/xml/feed.googlesitemap.builder +0 -7
  393. data/app/views/xml/rsd.rsd.builder +0 -8
  394. data/lib/stateful.rb +0 -106
  395. data/publify_core.gemspec +0 -54
@@ -0,0 +1,4 @@
1
+ <p class="auth">
2
+ <%= t('.posted_by') %> <%= author_link(article) %>
3
+ <%= display_date_and_time article.published_at %>
4
+ </p>
@@ -5,4 +5,4 @@
5
5
  </div>
6
6
  <% end %>
7
7
 
8
- <%= paginate articles, next_label: "#{t("pagination.next_page")} &raquo;", previous_label: "&laquo; #{t('pagination.previous_page')}" %>
8
+ <%= paginate articles %>
@@ -1,5 +1,5 @@
1
1
  <% if controller.action_name == 'redirect' %>
2
- <%= render 'articles/full_article_content', { :article => article } %>
2
+ <%= render 'articles/full_article_content', article: article %>
3
3
  <% else %>
4
- <%= render 'articles/article_excerpt', { :article => article } %>
4
+ <%= render 'articles/article_excerpt', article: article %>
5
5
  <% end %>
@@ -1,13 +1,15 @@
1
- <% if article.excerpt? %>
2
- <%= article.excerpt %>
3
- <div class="extended">
4
- <p><%= link_to_permalink article, t(".continue_reading") %></p>
5
- </div>
6
- <% else %>
7
- <%= raw article.html(:body) %>
8
- <% if article.extended? %>
1
+ <% cache article do %>
2
+ <% if article.excerpt? %>
3
+ <%= article.excerpt %>
9
4
  <div class="extended">
10
- <p><%= link_to_permalink article, t(".continue_reading") %></p>
5
+ <p><%= link_to_permalink article, t('.continue_reading') %></p>
11
6
  </div>
7
+ <% else %>
8
+ <%= raw article.html(:body) %>
9
+ <% if article.extended? %>
10
+ <div class="extended">
11
+ <p><%= link_to_permalink article, t('.continue_reading') %></p>
12
+ </div>
13
+ <% end %>
12
14
  <% end %>
13
15
  <% end %>
@@ -1,10 +1,12 @@
1
- <p class="meta">
1
+ <% cache article do %>
2
+ <p class="meta">
2
3
  <% if article.tags.any? %>
3
- <%= t(".tags") %>
4
+ <%= t('.tags') %>
4
5
  <%= tag_links article %>
5
6
  <% end %>
6
7
 
7
8
  <%= link_to(t('.comments', count: article.published_comments.size), article.permalink_url('comments', true)) if article.allow_comments? %>
8
9
 
9
10
  <%= link_to(t('.trackbacks', count: article.published_trackbacks.size), article.permalink_url('trackbacks', true)) if article.allow_pings? %>
10
- </p>
11
+ </p>
12
+ <% end %>
@@ -1,2 +1,2 @@
1
1
  <p><%= t('.message') %></p>
2
- <%= error_messages_for("comment") %>
2
+ <%= error_messages_for('comment') %>
@@ -6,28 +6,28 @@
6
6
  <a name="respond"></a>
7
7
  <table cellpadding="4" cellspacing="0" class="frm-tbl">
8
8
  <tr>
9
- <td><p><label for="comment_author"><%= t(".your_name")%></label></p></td>
9
+ <td><p><label for="comment_author"><%= t('.your_name') %></label></p></td>
10
10
  <td>
11
- <%= text_field "comment", "author", size: 20 %>
11
+ <%= text_field 'comment', 'author', size: 20 %>
12
12
  <small>
13
13
  <%= link_to '#', onclick: "$('.optional_field').fadeToggle();return false" do %>
14
- (<%= t(".leave_url_email") %> &#187;)
14
+ (<%= t('.leave_url_email') %> &#187;)
15
15
  <% end %>
16
16
  </small>
17
17
  </td>
18
18
  </tr>
19
19
  <tr class="optional_field" style="display: none">
20
- <td><p><label for="comment_url"><%= t(".your_blog")%></label></p></td>
21
- <td> <%= text_field "comment", "url" %></td>
20
+ <td><p><label for="comment_url"><%= t('.your_blog') %></label></p></td>
21
+ <td> <%= text_field 'comment', 'url' %></td>
22
22
  </tr>
23
23
  <tr class="optional_field" style="display: none">
24
- <td><p><label for="comment_email"><%= t(".your_email")%></label></p></td>
25
- <td> <%= text_field "comment", "email" %></td>
24
+ <td><p><label for="comment_email"><%= t('.your_email') %></label></p></td>
25
+ <td> <%= text_field 'comment', 'email' %></td>
26
26
  </tr>
27
27
  <tr>
28
- <td><p><label for="comment_body"><%= t(".your_message")%></label></p></td>
28
+ <td><p><label for="comment_body"><%= t('.your_message') %></label></p></td>
29
29
  <td valign="top" colspan="2">
30
- <%= text_area "comment", "body" %>
30
+ <%= text_area 'comment', 'body' %>
31
31
  </td>
32
32
  </tr>
33
33
  <% if this_blog.use_recaptcha %>
@@ -38,9 +38,9 @@
38
38
  <% end %>
39
39
  <tr>
40
40
  <td colspan="2" id="frm-btns">
41
- <%= markup_help_popup TextFilter.find_by_name(this_blog.comment_text_filter), t(".comment_markup_help") %>
42
- <a href="#" onclick="$.post('<%= @article.preview_comment_url %>', $('#comment_form').serialize());return false"><%= t(".preview_comment")%></a>
43
- <input type="submit" name="submit" id="form-submit-button" value="submit" class="button">
41
+ <%= markup_help_popup TextFilter.make_filter(this_blog.comment_text_filter), t('.comment_markup_help') %>
42
+ <a href="#" onclick="$.post('<%= @article.preview_comment_url %>', $('#comment_form').serialize());return false"><%= t('.preview_comment') %></a>
43
+ <input type="submit" name="submit" id="form-submit-button" value="submit" class="button" />
44
44
  </td>
45
45
  </tr>
46
46
  </table>
@@ -1,5 +1,5 @@
1
- <ol id="commentList" class="comments">
2
- <% if @article.published_comments.any? %>
3
- <%= render @article.published_comments %>
4
- <% end %>
5
- </ol>
1
+ <% cache @article do %>
2
+ <ol id="commentList" class="comments">
3
+ <%= render @article.published_comments, partial: 'articles/comment' %>
4
+ </ol>
5
+ <% end %>
@@ -1,4 +1,4 @@
1
1
  <%= avatar_tag(email: comment.email, url: comment.url) %>
2
- <cite><strong><%=h @comment[:author] %></strong></cite>
3
- <%= t(".is_about_to_say")%>:<br>
4
- <%= @comment.html %>
2
+ <cite><strong><%= h comment[:author] %></strong></cite>
3
+ <%= t('.is_about_to_say') %>:<br />
4
+ <%= comment.html %>
@@ -1,2 +1,4 @@
1
- <%= raw article.html(:body) %>
2
- <%= raw article.html(:extended) %>
1
+ <% cache article do %>
2
+ <%= raw article.html(:body) %>
3
+ <%= raw article.html(:extended) %>
4
+ <% end %>
@@ -1,10 +1,10 @@
1
1
  <div id='content-<%= article.id %>'>
2
2
  <p>This post is password protected. Please fill in your password or login to view the content</p>
3
- <%= form_for(article, {:remote => true,
4
- :url => { :controller => 'articles', :action => 'check_password'},
5
- :update => "content-#{article.id}"}) do |f| %>
3
+ <%= form_for(article, remote: true,
4
+ url: { controller: 'articles', action: 'check_password' },
5
+ update: "content-#{article.id}") do |f| %>
6
6
  <%= password_field(:article, :password) %>
7
- <input type='hidden' name='article[id]' value='<%= article.id %>'>
7
+ <input type='hidden' name='article[id]' value='<%= article.id %>' />
8
8
  <%= submit_tag(t('.submit') + '!', name: 'check_password') %>
9
9
  <% end %>
10
10
  </div>
@@ -1,6 +1,6 @@
1
1
  <li id="trackback-<%= trackback.id %>"<%= onhover_show_admin_tools(:trackback, trackback.id) %>>
2
2
  <a name="trackback-<%= trackback.id %>"></a>
3
- <%= t(".from")%> <strong><%= trackback.blog_name %></strong><br>
4
- <a href="<%= trackback.url %>" rel="nofollow"><%=h trackback.title %></a><br>
3
+ <%= t('.from') %> <strong><%= trackback.blog_name %></strong><br />
4
+ <a href="<%= trackback.url %>" rel="nofollow"><%= h trackback.title %></a><br />
5
5
  <%= trackback.excerpt %>
6
6
  </li>
@@ -1,25 +1,15 @@
1
1
  <% if @articles.empty? %>
2
- <div class="post">
3
- <p><%= t(".no_articles_found")%></p>
2
+ <div class="post">
3
+ <p><%= t('.no_articles_found') %></p>
4
4
  </div>
5
- <% else
6
- currentmonth = 0
7
- currentyear = 0
8
- for article in @articles
9
- if (article.published_at.month != currentmonth || article.published_at.year != currentyear)
10
- currentmonth = article.published_at.month
11
- currentyear = article.published_at.year %>
12
- <h3 class="archivemonth">
13
- <%= l(article.published_at, format: :letters_month_with_year) %>
14
- </h3>
15
- <% end %>
16
- <div class="archivepost">
17
- <%= article.published_at.mday %> -
18
- <%= link_to_permalink(article,h(article.title)) %>
19
- <% if !article.tags.empty? %> <%= t(".posted_in") %>
20
- <%= safe_join(article.tags.collect {|t| link_to_permalink t,t.display_name }, ", ") %>
5
+ <% else %>
6
+ <%= cache [@articles, params[:page]] do %>
7
+ <% @articles.group_by(&:publication_month).each do |_month, articles| %>
8
+ <h3 class="archivemonth">
9
+ <%= l(articles.first.published_at, format: :letters_month_with_year) %>
10
+ </h3>
11
+ <%= render partial: 'archives_article', collection: articles, as: :article %>
21
12
  <% end %>
22
- </div>
23
- <% end %>
24
13
  <% end %>
25
- +<%= paginate @articles, next_label: "#{t("pagination.next_page")} &raquo;", previous_label: "&laquo; #{t('pagination.previous_page')}" %>
14
+ <% end %>
15
+ <%= paginate @articles %>
@@ -1,8 +1,10 @@
1
- atom_feed do |feed|
2
- render "shared/atom_header", {:feed => feed, :items => @feedback}
1
+ # frozen_string_literal: true
3
2
 
4
- @feedback.each do |item|
5
- render "shared/atom_item_#{item.type.downcase}", {:feed => feed, :item => item}
3
+ atom_feed root_url: @article.permalink_url do |feed|
4
+ feedback = @article.published_feedback
5
+ render "shared/atom_header", feed: feed, items: feedback
6
+
7
+ feedback.each do |item|
8
+ render "shared/atom_item_#{item.type.downcase}", feed: feed, item: item
6
9
  end
7
10
  end
8
-
@@ -1,21 +1,21 @@
1
- xml.instruct! :xml, :version=>"1.0", :encoding=>"UTF-8"
2
- xml.instruct! 'xml-stylesheet', :type=>"text/css", :href => url_for("/stylesheets/rss.css")
1
+ # frozen_string_literal: true
2
+
3
+ xml.instruct! :xml, version: "1.0", encoding: "UTF-8"
4
+ xml.instruct! "xml-stylesheet", type: "text/css", href: url_for("/stylesheets/rss.css")
3
5
 
4
6
  xml.rss "version" => "2.0", "xmlns:dc" => "http://purl.org/dc/elements/1.1/",
5
- "xmlns:atom" => "http://www.w3.org/2005/Atom",
6
- "xmlns:trackback" => "http://madskills.com/public/xml/rss/module/trackback/" do
7
+ "xmlns:atom" => "http://www.w3.org/2005/Atom" do
7
8
  xml.channel do
8
9
  xml.title feed_title
9
- xml.link this_blog.base_url
10
- xml.atom :link, :href => request.url, :rel => 'self', :type => 'application/rss+xml'
11
- xml.language this_blog.lang.gsub("_", "-").downcase
10
+ xml.link @article.permalink_url
11
+ xml.atom :link, href: request.url, rel: "self", type: "application/rss+xml"
12
+ xml.language this_blog.lang.tr("_", "-").downcase
12
13
  xml.ttl "40"
13
14
  xml.description this_blog.blog_subtitle
14
15
 
15
- @feedback.each do |item|
16
- render "shared/rss_item_#{item.type.downcase}", {:feed => xml, :item => item}
16
+ feedback = @article.published_feedback
17
+ feedback.each do |item|
18
+ render "shared/rss_item_#{item.type.downcase}", feed: xml, item: item
17
19
  end
18
20
  end
19
21
  end
20
-
21
-
@@ -1,8 +1,9 @@
1
- atom_feed(:language => this_blog.lang.split("_").first) do |feed|
2
- render "shared/atom_header", {:feed => feed, :items => @articles}
1
+ # frozen_string_literal: true
2
+
3
+ atom_feed(language: this_blog.lang.split("_").first, root_url: this_blog.base_url) do |feed|
4
+ render "shared/atom_header", feed: feed, items: @articles
3
5
 
4
6
  @articles.each do |item|
5
- render "shared/atom_item_article", {:feed => feed, :item => item}
7
+ render "shared/atom_item_article", feed: feed, item: item
6
8
  end
7
9
  end
8
-
@@ -1,20 +1,20 @@
1
- xml.instruct! :xml, :version=>"1.0", :encoding=>"UTF-8"
2
- xml.instruct! 'xml-stylesheet', :type=>"text/css", :href => url_for("/stylesheets/rss.css")
1
+ # frozen_string_literal: true
2
+
3
+ xml.instruct! :xml, version: "1.0", encoding: "UTF-8"
4
+ xml.instruct! "xml-stylesheet", type: "text/css", href: url_for("/stylesheets/rss.css")
3
5
 
4
6
  xml.rss "version" => "2.0", "xmlns:dc" => "http://purl.org/dc/elements/1.1/",
5
- "xmlns:atom" => "http://www.w3.org/2005/Atom",
6
- "xmlns:trackback" => "http://madskills.com/public/xml/rss/module/trackback/" do
7
+ "xmlns:atom" => "http://www.w3.org/2005/Atom" do
7
8
  xml.channel do
8
9
  xml.title feed_title
9
10
  xml.link this_blog.base_url
10
- xml.atom :link, :href => request.url, :rel => 'self', :type => 'application/rss+xml'
11
- xml.language this_blog.lang.gsub("_", "-").downcase
11
+ xml.atom :link, href: request.url, rel: "self", type: "application/rss+xml"
12
+ xml.language this_blog.lang.tr("_", "-").downcase
12
13
  xml.ttl "40"
13
14
  xml.description this_blog.blog_subtitle
14
15
 
15
16
  @articles.each do |item|
16
- render "shared/rss_item_article", {:xm => xml, :item => item}
17
+ render "shared/rss_item_article", xm: xml, item: item
17
18
  end
18
19
  end
19
20
  end
20
-
@@ -1,10 +1,10 @@
1
1
  <% if !@search.to_s.blank? %>
2
- <h3>Searched for <em>"<%=h @search %>"</em></h3>
2
+ <h3>Searched for <em>"<%= h @search %>"</em></h3>
3
3
  <ul>
4
4
  <% for article in @articles.to_a %>
5
- <li><%= link_to_permalink article,h(article.title) %></li>
5
+ <li><%= link_to_permalink article, h(article.title) %></li>
6
6
  <% end %>
7
- </ul>
7
+ </ul>
8
8
  <% else %>
9
9
  &nbsp;
10
10
  <% end %>
@@ -1,23 +1,14 @@
1
- <!--
2
- <rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
3
- xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/"
4
- xmlns:dc="http://purl.org/dc/elements/1.1/">
5
- <rdf:Description
6
- rdf:about=""
7
- <% if @article.allow_pings? %>
8
- trackback:ping="<%= @article.trackback_url %>"
9
- <% end %>
10
- dc:title="<%=h @article.title.gsub(/-+/, '-') %>"
11
- dc:identifier="<%= @article.permalink_url %>"
12
- dc:description="<%=h (html(@article).strip_html[0..255]).gsub(/-+/, '-') %>"
13
- dc:creator="<%= h @article.author %>"
14
- dc:date="<%= @article.updated_at.xmlschema %>">
15
- </rdf:RDF>
16
- -->
17
-
18
1
  <div class="post"<%= onhover_show_admin_tools(:article) %>>
19
- <%= link_to(t(".edit"), { controller: "admin/content", action: "edit", id: @article.id }, class: "admintools", style: "display: none", id: "admin_article") %>
20
- <%= render @article %>
2
+ <%= link_to(t('.edit'), { controller: 'admin/content', action: 'edit', id: @article.id }, { class: 'admintools', style: 'display: none', id: 'admin_article' }) %>
3
+ <% cache @article do %>
4
+ <h2><%= link_to_permalink @article, @article.title %></h2>
5
+ <%= render 'articles/article_author', article: @article %>
6
+ <% if @article.password.blank? %>
7
+ <%= render 'articles/full_article_content', article: @article %>
8
+ <% else %>
9
+ <%= render 'articles/password_form', article: @article %>
10
+ <% end %>
11
+ <% end %>
21
12
  </div>
22
13
 
23
14
  <%= render 'article_links', article: @article %>
@@ -26,36 +17,27 @@
26
17
  <a name="comments"></a><h4 class="blueblk"><%= t('.comments') %></h4>
27
18
  <% unless @article.comments_closed? %>
28
19
  <p class="postmetadata alt">
29
- <small><a href="#respond"><%= t(".leave_a_response")%></a></small>
20
+ <small><a href="#respond"><%= t('.leave_a_response') %></a></small>
30
21
  </p>
31
22
  <% end %>
32
- <%= render "articles/comment_list" %>
23
+ <%= render 'articles/comment_list' %>
33
24
  <% end %>
34
25
 
35
- <% if @article.allow_pings? %>
36
- <a name="trackbacks"></a><h4 class="blueblk"><%= t(".trackbacks")%></h4>
37
- <p>
38
- <%= t(".use_the_following_link_to_trackback")%>:<br>
39
- <span class="light-bg"><%= @article.trackback_url %></span>
40
- </p>
41
- <% unless @article.published_trackbacks.blank? %>
42
- <ol id="trackbackList" class="trackback-list">
43
- <%= render(partial: "trackback", collection: @article.published_trackbacks) %>
44
- </ol>
45
- <% end %>
26
+ <% if @article.published_trackbacks.any? %>
27
+ <a name="trackbacks"></a><h4 class="blueblk"><%= t('.trackbacks') %></h4>
28
+ <ol id="trackbackList" class="trackback-list">
29
+ <%= render(partial: 'trackback', collection: @article.published_trackbacks) %>
30
+ </ol>
46
31
  <% end %>
47
32
 
48
33
  <p class="postmetadata alt">
49
34
  <small>
50
- <a href="<%= @article.feed_url('rss') %>" title="RSS Feed"><%= t(".rss_feed")%></a>
51
- <% if @article.allow_pings? %>
52
- <a href="<%= @article.trackback_url %>" ><%= t(".trackback_uri")%></a>
53
- <% end %>
35
+ <a href="<%= @article.feed_url('rss') %>" title="RSS Feed"><%= t('.rss_feed') %></a>
54
36
  </small>
55
37
  </p>
56
38
 
57
39
  <% unless @article.comments_closed? %>
58
40
  <%= render 'comment_form' %>
59
41
  <% else %>
60
- <p><%= t(".comments_are_disabled")%></p>
42
+ <p><%= t('.comments_are_disabled') %></p>
61
43
  <% end %>
@@ -1,8 +1,8 @@
1
1
  <% for article in @articles %>
2
2
  <div class="post">
3
- <h2><%= link_to_permalink article,article.title %></h2>
4
- <%= article.html(:body).gsub(/<\/?[^>]*>/, "").slice(0..300) %>...
3
+ <h2><%= link_to_permalink article, article.title %></h2>
4
+ <%= article.html(:body).gsub(%r{</?[^>]*>}, '').slice(0..300) %>...
5
5
  </div>
6
6
  <% end %>
7
7
 
8
- <%= paginate @articles, :next_label => "#{t(".next_page")} &raquo;", :previous_label => "&laquo; #{t('.previous_page')}" %>
8
+ <%= paginate @articles %>
@@ -1,4 +1,6 @@
1
- xml.instruct! :xml, :version=>"1.0", :encoding=>"iso-8859-1"
1
+ # frozen_string_literal: true
2
+
3
+ xml.instruct! :xml, version: "1.0", encoding: "iso-8859-1"
2
4
  xml.response do
3
5
  xml.error(@error_message.blank? ? 0 : 1)
4
6
  xml.message(@error_message) if @error_message
@@ -1,3 +1,3 @@
1
- <div id="viewpage" >
2
- <%= html @page %>
1
+ <div id="viewpage">
2
+ <%= raw html @page %>
3
3
  </div>
@@ -1,40 +1,30 @@
1
1
  <div class="post">
2
2
  <h2><%= @author.nickname %></h2>
3
3
  <%= display_user_avatar(@author, 'thumb', 'alignright') %>
4
-
5
4
  <%= author_description @author %>
6
-
7
- <h2><%= t(".contact_information") %></h2>
5
+ <h2><%= t('.contact_information') %></h2>
8
6
  <ul>
9
- <%= display_profile_item @author.url, t(".web_site") %>
10
- <%= display_profile_item @author.msn, t(".msn") %>
11
- <%= display_profile_item @author.yahoo, t(".yahoo") %>
12
- <%= display_profile_item @author.jabber, t(".jabber") %>
13
- <%= display_profile_item @author.aim, t(".aim") %>
14
- <%= display_profile_item @author.twitter, t(".twitter") %>
7
+ <%= display_profile_item @author.url, t('.web_site') %>
8
+ <%= display_profile_item @author.msn, t('.msn') %>
9
+ <%= display_profile_item @author.yahoo, t('.yahoo') %>
10
+ <%= display_profile_item @author.jabber, t('.jabber') %>
11
+ <%= display_profile_item @author.aim, t('.aim') %>
12
+ <%= display_profile_item @author.twitter, t('.twitter') %>
15
13
  </ul>
16
14
  </div>
17
15
 
18
16
  <% if @articles.empty? %>
19
17
  <div class="post">
20
- <p><%= t(".this_author_has_not_published_any_article_yet")%></p>
21
- </div>
22
- <% else
23
- currentmonth = 0
24
- currentyear = 0
25
- for article in @articles
26
- if (article.published_at.month != currentmonth || article.published_at.year != currentyear)
27
- currentmonth = article.published_at.month
28
- currentyear = article.published_at.year %>
29
- <h3 class="archivemonth"><%= l(article.published_at, format: :letters_month_with_year) %></h3>
30
- <% end %>
31
- <div class="archivepost">
32
- <%= article.published_at.mday %> -
33
- <%= link_to_permalink(article,h(article.title)) %>
34
- <% if !article.tags.empty? %> <%= t(".posted_in") %>
35
- <%= article.tags.collect {|c| link_to_permalink c,c.name }.join(", ") %>
18
+ <p><%= t('.this_author_has_not_published_any_article_yet') %></p>
19
+ </div>
20
+ <% else %>
21
+ <%= cache [@articles, params[:page]] do %>
22
+ <% @articles.group_by(&:publication_month).each do |_month, articles| %>
23
+ <h3 class="archivemonth">
24
+ <%= l(articles.first.published_at, format: :letters_month_with_year) %>
25
+ </h3>
26
+ <%= render partial: 'articles/archives_article', collection: articles, as: :article %>
36
27
  <% end %>
37
- </div>
38
28
  <% end %>
39
- <%= paginate @articles, :next_label => "#{t(".next_page")} &raquo;", :previous_label => "&laquo; #{t('.previous_page')}" %>
40
- <% end %>
29
+ <%= paginate @articles %>
30
+ <% end %>