commontator 5.1.0 → 6.0.0.pre.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (319) hide show
  1. checksums.yaml +5 -5
  2. data/MIT-LICENSE +1 -1
  3. data/README.md +83 -63
  4. data/app/assets/javascripts/commontator/mentions.js +2 -2
  5. data/app/assets/stylesheets/commontator/application.scss +101 -0
  6. data/app/assets/stylesheets/commontator/comments.scss +103 -0
  7. data/app/controllers/commontator/application_controller.rb +21 -21
  8. data/app/controllers/commontator/comments_controller.rb +123 -114
  9. data/app/controllers/commontator/security_transgression.rb +2 -0
  10. data/app/controllers/commontator/subscriptions_controller.rb +20 -22
  11. data/app/controllers/commontator/threads_controller.rb +50 -50
  12. data/app/helpers/commontator/application_helper.rb +3 -5
  13. data/app/helpers/commontator/link_renderer.rb +25 -0
  14. data/app/mailers/commontator/subscriptions_mailer.rb +35 -35
  15. data/app/models/commontator/comment.rb +208 -91
  16. data/app/models/commontator/json_array_coder.rb +10 -0
  17. data/app/models/commontator/subscription.rb +13 -16
  18. data/app/models/commontator/thread.rb +139 -133
  19. data/app/views/commontator/comments/_actions.html.erb +9 -10
  20. data/app/views/commontator/comments/_body.html.erb +11 -6
  21. data/app/views/commontator/comments/_form.html.erb +31 -20
  22. data/app/views/commontator/comments/_list.html.erb +6 -5
  23. data/app/views/commontator/comments/_reply.html.erb +15 -0
  24. data/app/views/commontator/comments/_show.html.erb +31 -25
  25. data/app/views/commontator/comments/_votes.html.erb +12 -11
  26. data/app/views/commontator/comments/cancel.js.erb +6 -14
  27. data/app/views/commontator/comments/create.js.erb +20 -14
  28. data/app/views/commontator/comments/delete.js.erb +14 -14
  29. data/app/views/commontator/comments/edit.js.erb +6 -4
  30. data/app/views/commontator/comments/new.js.erb +11 -7
  31. data/app/views/commontator/comments/update.js.erb +6 -4
  32. data/app/views/commontator/comments/vote.js.erb +3 -4
  33. data/app/views/commontator/shared/_thread.html.erb +23 -11
  34. data/app/views/commontator/subscriptions/_link.html.erb +7 -8
  35. data/app/views/commontator/subscriptions/subscribe.js.erb +3 -4
  36. data/app/views/commontator/subscriptions_mailer/comment_created.html.erb +9 -8
  37. data/app/views/commontator/threads/_hide_show_links.js.erb +10 -9
  38. data/app/views/commontator/threads/_reply.html.erb +17 -16
  39. data/app/views/commontator/threads/_show.html.erb +75 -76
  40. data/app/views/commontator/threads/_show.js.erb +12 -16
  41. data/app/views/commontator/threads/show.js.erb +9 -6
  42. data/config/initializers/commontator.rb +81 -67
  43. data/config/locales/de.yml +28 -48
  44. data/config/locales/en.yml +38 -27
  45. data/config/locales/pt-BR.yml +31 -29
  46. data/config/locales/ru.yml +34 -29
  47. data/config/locales/zh.yml +65 -48
  48. data/db/migrate/0_install_commontator.rb +27 -32
  49. data/db/migrate/1_add_replying_to_comments.rb +9 -0
  50. data/lib/commontator.rb +9 -140
  51. data/lib/commontator/acts_as_commontable.rb +24 -33
  52. data/lib/commontator/acts_as_commontator.rb +28 -25
  53. data/lib/commontator/build_thread.rb +10 -0
  54. data/lib/commontator/commontable_config.rb +10 -10
  55. data/lib/commontator/commontator_config.rb +10 -10
  56. data/lib/{commontator.rb~ → commontator/config.rb} +57 -57
  57. data/lib/commontator/controllers.rb +35 -29
  58. data/lib/commontator/engine.rb +6 -4
  59. data/lib/commontator/shared_helper.rb +58 -21
  60. data/lib/commontator/version.rb +1 -3
  61. data/lib/tasks/commontator_tasks.rake +2 -2
  62. data/vendor/assets/stylesheets/mentionsInput/jquery.mentionsInput.css +0 -1
  63. metadata +50 -496
  64. data/Rakefile +0 -22
  65. data/app/assets/javascripts/commontator/application.js~ +0 -3
  66. data/app/assets/javascripts/commontator/mentions.js~ +0 -31
  67. data/app/assets/stylesheets/commontator/application.css +0 -5
  68. data/app/assets/stylesheets/commontator/application.css~ +0 -14
  69. data/app/assets/stylesheets/commontator/comments.css +0 -121
  70. data/app/assets/stylesheets/commontator/threads.css +0 -71
  71. data/app/assets/stylesheets/commontator/threads.css~ +0 -71
  72. data/app/controllers/commontator/comments_controller.rb~ +0 -160
  73. data/app/controllers/commontator/threads_controller.rb~ +0 -75
  74. data/app/mailers/commontator/subscriptions_mailer.rb~ +0 -65
  75. data/app/models/commontator/comment.rb~ +0 -124
  76. data/app/models/commontator/subscription.rb~ +0 -23
  77. data/app/views/commontator/shared/_thread.html.erb~ +0 -21
  78. data/app/views/commontator/subscriptions_mailer/comment_created.html.erb~ +0 -10
  79. data/app/views/commontator/threads/_hide_show.js.erb~ +0 -21
  80. data/app/views/commontator/threads/_hide_show_links.js.erb~ +0 -17
  81. data/app/views/commontator/threads/_show.html.erb~ +0 -118
  82. data/app/views/commontator/threads/_show.js.erb~ +0 -18
  83. data/config/initializers/commontator.rb~ +0 -290
  84. data/config/locales/en.yml~ +0 -101
  85. data/config/locales/ru.yml~ +0 -79
  86. data/config/locales/zh.yml~ +0 -79
  87. data/config/routes.rb~ +0 -25
  88. data/db/migrate/0_install_commontator.rb~ +0 -52
  89. data/db/migrate/1_add_parent_comment_id_to_commontator_comments.rb~ +0 -9
  90. data/lib/commontator/link_renderer.rb +0 -28
  91. data/lib/commontator/security_transgression.rb +0 -4
  92. data/lib/commontator/shared_helper.rb~ +0 -26
  93. data/lib/commontator/version.rb~ +0 -3
  94. data/spec/controllers/commontator/comments_controller_spec.rb +0 -613
  95. data/spec/controllers/commontator/comments_controller_spec.rb~ +0 -612
  96. data/spec/controllers/commontator/subscriptions_controller_spec.rb +0 -101
  97. data/spec/controllers/commontator/subscriptions_controller_spec.rb~ +0 -101
  98. data/spec/controllers/commontator/threads_controller_spec.rb +0 -219
  99. data/spec/controllers/commontator/threads_controller_spec.rb~ +0 -218
  100. data/spec/dummy/README.md +0 -4
  101. data/spec/dummy/README.md~ +0 -3
  102. data/spec/dummy/Rakefile +0 -7
  103. data/spec/dummy/Rakefile~ +0 -6
  104. data/spec/dummy/app/assets/javascripts/application.js +0 -17
  105. data/spec/dummy/app/assets/javascripts/application.js~ +0 -16
  106. data/spec/dummy/app/assets/stylesheets/application.css +0 -15
  107. data/spec/dummy/app/assets/stylesheets/application.css~ +0 -14
  108. data/spec/dummy/app/controllers/application_controller.rb +0 -6
  109. data/spec/dummy/app/controllers/application_controller.rb~ +0 -4
  110. data/spec/dummy/app/controllers/dummy_models_controller.rb +0 -23
  111. data/spec/dummy/app/controllers/dummy_models_controller.rb~ +0 -23
  112. data/spec/dummy/app/helpers/application_helper.rb +0 -16
  113. data/spec/dummy/app/helpers/application_helper.rb~ +0 -15
  114. data/spec/dummy/app/models/dummy_dependent_model.rb +0 -4
  115. data/spec/dummy/app/models/dummy_model.rb +0 -4
  116. data/spec/dummy/app/models/dummy_model.rb~ +0 -3
  117. data/spec/dummy/app/models/dummy_user.rb +0 -14
  118. data/spec/dummy/app/models/dummy_user.rb~ +0 -13
  119. data/spec/dummy/app/views/dummy_models/index.html.erb~ +0 -6
  120. data/spec/dummy/app/views/dummy_models/show.html.erb +0 -2
  121. data/spec/dummy/app/views/dummy_models/show.html.erb~ +0 -2
  122. data/spec/dummy/app/views/layouts/application.html.erb +0 -14
  123. data/spec/dummy/app/views/layouts/application.html.erb~ +0 -14
  124. data/spec/dummy/config.ru +0 -5
  125. data/spec/dummy/config.ru~ +0 -4
  126. data/spec/dummy/config/application.rb +0 -27
  127. data/spec/dummy/config/application.rb~ +0 -26
  128. data/spec/dummy/config/boot.rb +0 -6
  129. data/spec/dummy/config/boot.rb~ +0 -5
  130. data/spec/dummy/config/database.yml +0 -26
  131. data/spec/dummy/config/database.yml~ +0 -25
  132. data/spec/dummy/config/environment.rb +0 -8
  133. data/spec/dummy/config/environment.rb~ +0 -8
  134. data/spec/dummy/config/environments/development.rb +0 -31
  135. data/spec/dummy/config/environments/development.rb~ +0 -31
  136. data/spec/dummy/config/environments/production.rb +0 -82
  137. data/spec/dummy/config/environments/production.rb~ +0 -82
  138. data/spec/dummy/config/environments/test.rb +0 -40
  139. data/spec/dummy/config/environments/test.rb~ +0 -40
  140. data/spec/dummy/config/initializers/backtrace_silencers.rb +0 -8
  141. data/spec/dummy/config/initializers/backtrace_silencers.rb~ +0 -7
  142. data/spec/dummy/config/initializers/commontator.rb +0 -20
  143. data/spec/dummy/config/initializers/commontator.rb~ +0 -21
  144. data/spec/dummy/config/initializers/filter_parameter_logging.rb +0 -5
  145. data/spec/dummy/config/initializers/filter_parameter_logging.rb~ +0 -4
  146. data/spec/dummy/config/initializers/inflections.rb +0 -17
  147. data/spec/dummy/config/initializers/inflections.rb~ +0 -16
  148. data/spec/dummy/config/initializers/mime_types.rb +0 -6
  149. data/spec/dummy/config/initializers/mime_types.rb~ +0 -5
  150. data/spec/dummy/config/initializers/secret_token.rb +0 -13
  151. data/spec/dummy/config/initializers/secret_token.rb~ +0 -12
  152. data/spec/dummy/config/initializers/session_store.rb +0 -4
  153. data/spec/dummy/config/initializers/session_store.rb~ +0 -3
  154. data/spec/dummy/config/initializers/wrap_parameters.rb +0 -15
  155. data/spec/dummy/config/initializers/wrap_parameters.rb~ +0 -14
  156. data/spec/dummy/config/routes.rb +0 -9
  157. data/spec/dummy/config/routes.rb~ +0 -10
  158. data/spec/dummy/db/development.sqlite3 +0 -0
  159. data/spec/dummy/db/migrate/1_create_dummy_models.rb +0 -7
  160. data/spec/dummy/db/migrate/1_create_dummy_models.rb~ +0 -7
  161. data/spec/dummy/db/migrate/2_create_dummy_users.rb +0 -7
  162. data/spec/dummy/db/migrate/2_create_dummy_users.rb~ +0 -7
  163. data/spec/dummy/db/migrate/3_acts_as_votable_migration.rb +0 -22
  164. data/spec/dummy/db/migrate/3_acts_as_votable_migration.rb~ +0 -27
  165. data/spec/dummy/db/migrate/4_create_dummy_dependent_models.rb +0 -7
  166. data/spec/dummy/db/schema.rb +0 -85
  167. data/spec/dummy/db/test.sqlite3 +0 -0
  168. data/spec/dummy/lib/controllers.rb~ +0 -10
  169. data/spec/dummy/lib/dummy_controllers.rb +0 -10
  170. data/spec/dummy/log/development.log +0 -6693
  171. data/spec/dummy/log/test.log +0 -125970
  172. data/spec/dummy/public/404.html +0 -27
  173. data/spec/dummy/public/404.html~ +0 -26
  174. data/spec/dummy/public/422.html +0 -27
  175. data/spec/dummy/public/422.html~ +0 -26
  176. data/spec/dummy/public/500.html +0 -26
  177. data/spec/dummy/public/500.html~ +0 -25
  178. data/spec/dummy/public/favicon.ico +0 -0
  179. data/spec/dummy/script/rails +0 -7
  180. data/spec/dummy/script/rails~ +0 -6
  181. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/-RolHYhJdGiLoPkoWZXQdI9AIWUjMMCa2yFJezCE_Bo.cache +0 -2
  182. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/-STzK7UuGeY3gSvnmTELWLvtRMKpmSAQCEw4ao3b1r8.cache +0 -1
  183. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/3NH8nN7uktAXgA3NqaqXTXDVic3BxBvqCxoLpGGbib4.cache +0 -0
  184. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/4_iT7KM6P2IT75Rssrk9p4crTBwM8DQWR41gmsxczL0.cache +0 -0
  185. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/58TLCXvf5bFFYY-mIUXrQNOVWlGsq7qPAoSX2OIIB8Y.cache +0 -0
  186. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/6OQdyrATvNatvWu8Mp1qbuvRx-HLmzCZ5XBGYca-rZU.cache +0 -0
  187. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/6UKCUV-ZLaWCoPMfMB6a2W0RCFPQzPJ6Mz-y67sH7zk.cache +0 -2
  188. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/6wKNjFdNd4OHjIpLC0nq1kBWcbYg1aEYrp7ZhWoJlvY.cache +0 -1
  189. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/7Xxb5iYP5elo40JRlhNQB1gLbv3ueELK2rTinYt5xdc.cache +0 -1
  190. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/7twIKlS6VYCyLlwhsQg2vu4wLSUJsT2REHR4DjZf1oE.cache +0 -2
  191. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/87m-4EcbQnkbo2HYkQp4V9I2U3AYQO1mPeReieduolA.cache +0 -1
  192. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/8B331vt8qC4iXTcVzkx3j-ET8i1oaQskj5LyqGq8mPQ.cache +0 -0
  193. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/8KWvIOgvo7BVJYtdTpFuiSQQFFwZhLWYtwacZv52y48.cache +0 -0
  194. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/9yQa5M2ObK2-qDu231zMoarjVbhKUUg-ND3r2iXqB_Q.cache +0 -0
  195. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/A-ffuUI2juZT6qFpTUwUR1P8OPWcyFFN26WSUZe60Ko.cache +0 -1
  196. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/BbO4diS6uacx69Hn_bCabYlXEbWWdjHShRlfzlWSOMI.cache +0 -0
  197. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/CXhqxaQQAQ8b0Y8y0jTQyiqsZ6Oe4fZn0YiacpJ9IoI.cache +0 -1
  198. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/E1zaNOh68xzPxdtdOwRtOaMCoKivN2dxVwCP65WEi5I.cache +0 -2
  199. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/EmPkV3H8p2Snv9WyPjWran_kOMQ0MqQ1a9CVdGDd8l4.cache +0 -1
  200. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/Hc12Nxe7cw2e0u2pzNsAe8D3ncQpcqLuI2NVL7aAXgw.cache +0 -1
  201. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/HdWuQr9W2mZvggsAxVjDgLYUNfg3rbI-T8KhaDIsvQk.cache +0 -0
  202. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/I7lsrHTKpbfLWqIqdDIx2RN_12yFL2PyLRyYsMxg1IU.cache +0 -1
  203. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/JOCzfBjMjX3D5BUUGh5lJ7fjzMuJrHLxAginRA2_hZQ.cache +0 -0
  204. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/JusxTSXt06IqBm9jeCMM2nTmM3Wvbl3i3L1IwEvW5YA.cache +0 -2
  205. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/KAY1_IaTONtGr0KK8ihOdoA-RDXybqBMNSZLIDRHx68.cache +0 -1
  206. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/KBHIDNfa4ryw9LAkYqK8GgPWne7HkX6mNYgrJajGm94.cache +0 -1
  207. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/L_lv02y00MmIFiFhg5c9zhl7CDHLSahehzLyi_mRZeY.cache +0 -0
  208. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/MOT2X4iikR8v89A4N1bxDTeS1-xV8c9036TNFXmwXCM.cache +0 -1
  209. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/MiX2Z4Vbha1riozZWw1U3_PGttRiZ1iQ_o4wSZJnKCs.cache +0 -3
  210. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/MntKfwol0ud4LuvrX3MVPthTlfNlJZRYbQXpQBxhRrs.cache +0 -1
  211. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/MrqmgPGNYJV1capJKIKJOVEQ4NiO-Z_2YhpjNteJ8B8.cache +0 -2
  212. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/NVMnAwylzGp5bjl_o9dwMAQxVAPDzc4ygddNQSD1fiw.cache +0 -0
  213. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/O2sKqGxNuCYhjzuEZVC9hX_FeemOfRn_1-CCuHBQYyg.cache +0 -1
  214. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/Qy3TykLFmAt5jhSluMTaZaefcA5c_vfBRhQ7tin-gsk.cache +0 -0
  215. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/R3DpUgZ_hja1dQTIzumiP9AD_r8mlOaqv0U9QqnGQqo.cache +0 -0
  216. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/RF07mgb06A30OcDWtCaDlM5tEc1yp0uAsk986Gqs5w8.cache +0 -1
  217. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/S-6Iq5YOEpVnd_vQ0RSSfrmyIwB1dk0op35alFgJ9xA.cache +0 -2
  218. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/TKV8dUTo88gdFY-z2I7Xa5vDC1Z3LY6Paa18385MJsI.cache +0 -1
  219. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/UI4zPmWfZA2d_5ZZIXqK9KmkjOKSDg6JoM7qcOIxm0Q.cache +0 -1
  220. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/UP29vrIQbCkfghZGSCFxpW5gjlsgCxlVrncjjopvRqM.cache +0 -2
  221. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/UoU16f4V7haEXM5GY5j4QFuNMP7PJZaAMEvVNNtNLBA.cache +0 -1
  222. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/VqPqYNG07yqcjbd7FA05Mu-jr5hzsZPaHFf8X0FFbXk.cache +0 -2
  223. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/WkN1QFvcuzXSsyNmfaK02ojXPk-8zmdEegzNPfdAEL4.cache +0 -0
  224. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/WkQX7Wiz41OKx2aGF7uffOmS04hIVZeGCondBAvwum8.cache +0 -2
  225. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/XMeYF1vwAg53eVjXVkw_IKQH2W3-9tWvtuCdqUCbPBM.cache +0 -2
  226. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/XX0Z7OM0xZKfQaAvHARpyeQNZCstNyu9MlsnwThSkg8.cache +0 -1
  227. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/Y-pGNFTA6bAKxSvqZvmMVs3b4Els1aByxZVFxtJR71c.cache +0 -1
  228. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/Y3p3m5V5NOm7yq56apKmF5KZUUsTfnhT_SG3fqbEJgo.cache +0 -1
  229. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/YLZuRWklL6q-csC-7A7CiOTTTYEQcA9PCdWEOm9MpNU.cache +0 -1
  230. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/Yo7V5YXukEBm6z37l-TIRCJx3HZExEUBu3MUMhAzkMU.cache +0 -1
  231. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/bK6QttR8pGmMAMJO0avCBLwH0za8_bAC-yWqkU3Yj24.cache +0 -1
  232. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/cLncjrqpQXzsVBp7K0W7iG1STLrnzfGpbJXxNE7aIUk.cache +0 -2
  233. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/dBcAd64EZFdhHZNXKGXPIR7EtPGf03bzqkci2W12T8g.cache +0 -2
  234. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/d_bbPiareJHKkzFZFCl3pcwfQOFzsB1KHn4A2xxhR20.cache +0 -1
  235. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/eaHZBuJRcawVlkGZVyyRr5_4xYKVOXbCqnTcmaNXzL0.cache +0 -0
  236. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/gWnmfJty3jBn53qsJfOXKrWv4e8i3Dp80wVel-f1L1E.cache +0 -1
  237. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/gumo32Bd3W_q7MYEt9JIZEiQdHF93tLSsGfmXIm2MqU.cache +0 -1
  238. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/jKTlG9KP0iaCGHwg8kQ1amz9SHJ1OAWeCRRn9wc5w7c.cache +0 -1
  239. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/kPJfTiWbmX-q6i2rjM9MAMdEf2silSihU0_lxlTGVA8.cache +0 -1
  240. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/lrt1SWPj4qWUZUMH9xg3n9KLYUqJZxRn-XI-NTU6oTI.cache +0 -1
  241. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/mcCP5u08nlCL6TgWdzzrem9uE2rbsbG3KyIXxvWvlJE.cache +0 -3
  242. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/pC4exGjkQLXXPE0O9hjX_2AJ4DASTFeB6RGjXagxEac.cache +0 -0
  243. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/pIRh_Lq-ZhYC_XdRcqIsCtUkTnwVET0Wrrpw1EltHd8.cache +0 -2
  244. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/qfXc71sDbi1cE9f327D6ABPURPU6lLguGiJqH2fqM0w.cache +0 -1
  245. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/rBcrkzXcMaiCjwvWl8tO0eARzKZS69I3i-lfsTAFzcc.cache +0 -1
  246. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/sfl8l1_1AGn-4llkmb91Q0wHJ-A-x5gAGkIUWe1zLqo.cache +0 -1
  247. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/tFQc0MOeWpJ7t7cNP2GOzo7o9Z6YBgLEpdS0tGLvUSw.cache +0 -0
  248. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/tb9v5OemP-ADEwYnETLLi1r088kZm_TMb9ZVeTV5JxI.cache +0 -1
  249. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/uKmWfbgaNZ8FTsVK1VNuUv15rmtTHzSdJ7TQRGr0Rck.cache +0 -2
  250. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/ul0QEoovfr_12YOpyWx8BJs8fvz5Ay3AZG8-lsLr-a4.cache +0 -1
  251. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/vY6eUgBIXKHqfU2ZroS-GugKPg5_fo2QBs-vS5gBN2o.cache +0 -0
  252. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/vrRc4DPAbHIJHJqsXfBYdyKUPFv8f8YYKJUrk-1zdVw.cache +0 -0
  253. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/wTET4PQq7wlxzrgvNivPJad-CACkoQS4BNxAP0FQaR4.cache +0 -0
  254. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/wcvE87iLx7cDjMDs_Yu1jKYvep-VyLEyj1eXL79KLp4.cache +0 -0
  255. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/xQeZ92qbm2t9FaRck5xUakvNP-MJ2cs0RroN-fm0Tf8.cache +0 -1
  256. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/xQz9WPf67Mu5uV4rNuOfU-y6_KWSlWcnTWrTvQPonKM.cache +0 -0
  257. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/xhYTRUOS8cIvyRp2Jn6FKnXlGOSsIM2z3HAGOJoJs7w.cache +0 -1
  258. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/yLxMFI0ARh2OKSOQLF2xEfM7sbst2vUbOBXoOuI6iTE.cache +0 -1
  259. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/ynnYZxuxqerlFUytw54dl_CwP94g0U4HmGjyILWnhfQ.cache +0 -1
  260. data/spec/dummy/tmp/cache/assets/development/sprockets/v3.0/zCivVPbSRpKF_X-P5OJeld32YhymG-bkjQwzqe2o6zg.cache +0 -2
  261. data/spec/dummy/tmp/cache/assets/test/sprockets/02d4b791eb831cf2057bf4703a1218d1 +0 -0
  262. data/spec/dummy/tmp/cache/assets/test/sprockets/0f196a1a50363b0a076ec6e1ee5417f6 +0 -0
  263. data/spec/dummy/tmp/cache/assets/test/sprockets/a3fb9025f90ff05a6fd4afc7ded2692c +0 -0
  264. data/spec/dummy/tmp/cache/assets/test/sprockets/a41c8be5379abec3c0d0d98e2f0d5609 +0 -0
  265. data/spec/dummy/tmp/cache/assets/test/sprockets/c69ee3cc5796188d873574179290a6ef +0 -0
  266. data/spec/dummy/tmp/cache/assets/test/sprockets/e1f674c11941d62aac1764ef3a7134e4 +0 -0
  267. data/spec/dummy/tmp/cache/assets/test/sprockets/e85565206c3e5fdf9dfeb367c85557b1 +0 -0
  268. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/-gXoYfEJ-e9QQUbNRpNa-pwMCnTc7Eqvkq6Bosde6W8.cache +0 -0
  269. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/6iNAIrMKxHltOChiHQQf9VNsLQuj2rVKz6oqWnK7aSM.cache +0 -1
  270. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/E1zaNOh68xzPxdtdOwRtOaMCoKivN2dxVwCP65WEi5I.cache +0 -2
  271. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/HsNbq1o4RbrEWNL4zXVqFfUVnXXLK_y0F0BvddDre6g.cache +0 -0
  272. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/JusxTSXt06IqBm9jeCMM2nTmM3Wvbl3i3L1IwEvW5YA.cache +0 -2
  273. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/L5DjABL_iOtoxSOLn3X7_YlxECU5EhnrVIKxJFAysgc.cache +0 -1
  274. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/PNc9TJUmRdGTSwgZvGlxKaIiJIkyoWtTPiGGWBqpHAE.cache +0 -0
  275. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/QkgTHa6nNs7XP6RPoV3yBbWWV-uo1u2-qxLuvLCFe_0.cache +0 -0
  276. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/S-6Iq5YOEpVnd_vQ0RSSfrmyIwB1dk0op35alFgJ9xA.cache +0 -2
  277. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/Vuc93A9yywiFxc9CAdxrzdsAQw4jxiCa6JRzRjNxOYs.cache +0 -1
  278. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/YAPBll4U0cgs6cz-WyMRKoakK_gVOOcl9n0CvGyxPjY.cache +0 -1
  279. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/bDNeZfPBQaef5z0YajZc4jFE54nNy9gc06mPNKvvPFk.cache +0 -1
  280. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/c5Wa2loowFYFRBaMoTn1IWYXo4BGMbEy7NIi0vbvfRU.cache +0 -1
  281. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/dkn8MYu2ve_AJW6u0jjTlKrj1KBRqorOHQR0Obx2elU.cache +0 -0
  282. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/fZuAzt_-48u9C7ZXmsPgTraGDYtNC9B9zN-9-EnxJG4.cache +0 -1
  283. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/gumo32Bd3W_q7MYEt9JIZEiQdHF93tLSsGfmXIm2MqU.cache +0 -1
  284. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/ige85jXyj8X7XYr7HpA0gSTThqfPUm71HjhSJXtTbUY.cache +0 -1
  285. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/kuYeE5bV6FdXmfB_o-xhflhSDWoQhYYaaupAXODZ9dQ.cache +0 -1
  286. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/qhZbbNIRUaAOtGano94zLHjeBKUhKr4qbh2tTCi0Bnk.cache +0 -2
  287. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/wJJbzdHJHP6tchng3HhfTwmjc5LursgX8yZkAjpO5UA.cache +0 -0
  288. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/xNL1WW-qU3EvV2iTSW6F4hAFRBsCYmFKJhLjgCZkOV8.cache +0 -2
  289. data/spec/dummy/tmp/cache/assets/test/sprockets/v3.0/ytHkF2DwUE6oaiLyrK6tL-0INpeNhjN6ctD7J0LNY6I.cache +0 -2
  290. data/spec/helpers/commontator/application_helper_spec.rb +0 -10
  291. data/spec/helpers/commontator/application_helper_spec.rb~ +0 -9
  292. data/spec/lib/commontator/acts_as_commontable_spec.rb +0 -25
  293. data/spec/lib/commontator/acts_as_commontable_spec.rb~ +0 -25
  294. data/spec/lib/commontator/acts_as_commontator_spec.rb +0 -26
  295. data/spec/lib/commontator/acts_as_commontator_spec.rb~ +0 -52
  296. data/spec/lib/commontator/commontable_config_spec.rb +0 -28
  297. data/spec/lib/commontator/commontable_config_spec.rb~ +0 -29
  298. data/spec/lib/commontator/commontator_config_spec.rb +0 -28
  299. data/spec/lib/commontator/commontator_config_spec.rb~ +0 -29
  300. data/spec/lib/commontator/controller_includes_spec.rb~ +0 -18
  301. data/spec/lib/commontator/controllers_spec.rb +0 -18
  302. data/spec/lib/commontator/controllers_spec.rb~ +0 -18
  303. data/spec/lib/commontator/shared_helper_spec.rb +0 -21
  304. data/spec/lib/commontator/shared_helper_spec.rb~ +0 -22
  305. data/spec/lib/commontator_spec.rb +0 -25
  306. data/spec/lib/commontator_spec.rb~ +0 -26
  307. data/spec/mailers/commontator/subscriptions_mailer_spec.rb +0 -49
  308. data/spec/mailers/commontator/subscriptions_mailer_spec.rb~ +0 -30
  309. data/spec/models/commontator/comment_spec.rb +0 -82
  310. data/spec/models/commontator/comment_spec.rb~ +0 -82
  311. data/spec/models/commontator/subscription_spec.rb +0 -38
  312. data/spec/models/commontator/subscription_spec.rb~ +0 -38
  313. data/spec/models/commontator/thread_spec.rb +0 -159
  314. data/spec/models/commontator/thread_spec.rb~ +0 -122
  315. data/spec/rails_helper.rb +0 -72
  316. data/spec/rails_helper.rb~ +0 -74
  317. data/spec/spec_helper.rb +0 -94
  318. data/spec/spec_helper.rb~ +0 -93
  319. data/vendor/assets/javascripts/mentionsInput/index.js~ +0 -3
@@ -1,22 +1,19 @@
1
- module Commontator
2
- class Subscription < ActiveRecord::Base
3
- belongs_to :subscriber, polymorphic: true
4
- belongs_to :thread
1
+ class Commontator::Subscription < ActiveRecord::Base
2
+ belongs_to :subscriber, polymorphic: true
3
+ belongs_to :thread, inverse_of: :subscriptions
5
4
 
6
- validates_presence_of :subscriber, :thread
7
- validates_uniqueness_of :thread_id, scope: [:subscriber_type, :subscriber_id]
5
+ validates :thread, presence: true, uniqueness: { scope: [ :subscriber_type, :subscriber_id ] }
8
6
 
9
- def self.comment_created(comment)
10
- recipients = comment.thread.subscribers.reject{|s| s == comment.creator}
11
- return if recipients.empty?
7
+ def self.comment_created(comment)
8
+ recipients = comment.thread.subscribers.reject { |sub| sub == comment.creator }
9
+ return if recipients.empty?
12
10
 
13
- mail = SubscriptionsMailer.comment_created(comment, recipients)
14
- mail.respond_to?(:deliver_later) ? mail.deliver_later : mail.deliver
15
- end
11
+ mail = Commontator::SubscriptionsMailer.comment_created(comment, recipients)
12
+ mail.respond_to?(:deliver_later) ? mail.deliver_later : mail.deliver
13
+ end
16
14
 
17
- def unread_comments
18
- created_at = Comment.arel_table[:created_at]
19
- thread.filtered_comments.where(created_at.gt(updated_at))
20
- end
15
+ def unread_comments
16
+ created_at = Commontator::Comment.arel_table[:created_at]
17
+ thread.filtered_comments.where(created_at.gteq(updated_at))
21
18
  end
22
19
  end
@@ -1,159 +1,165 @@
1
- module Commontator
2
- class Thread < ActiveRecord::Base
3
- belongs_to :closer, polymorphic: true, optional: true
4
- belongs_to :commontable, polymorphic: true, optional: true
1
+ class Commontator::Thread < ActiveRecord::Base
2
+ belongs_to :closer, polymorphic: true, optional: true
3
+ belongs_to :commontable, polymorphic: true, optional: true, inverse_of: :commontator_thread
5
4
 
6
- has_many :comments, dependent: :destroy
7
- has_many :subscriptions, dependent: :destroy
5
+ has_many :comments, dependent: :destroy, inverse_of: :thread
6
+ has_many :subscriptions, dependent: :destroy, inverse_of: :thread
8
7
 
9
- validates_presence_of :commontable, unless: :is_closed?
10
- validates_uniqueness_of :commontable_id,
11
- scope: :commontable_type,
12
- allow_nil: true
8
+ validates :commontable, presence: true, unless: :is_closed?
9
+ validates :commontable_id, uniqueness: { scope: :commontable_type, allow_nil: true }
13
10
 
14
- def config
15
- @config ||= commontable.try(:commontable_config) || Commontator
16
- end
11
+ def config
12
+ @config ||= commontable.try(:commontable_config) || Commontator
13
+ end
17
14
 
18
- def will_paginate?
19
- return false if config.comments_per_page.nil? || !comments.respond_to?(:paginate)
20
- require 'commontator/link_renderer'
21
- true
22
- end
15
+ def will_paginate?
16
+ !config.comments_per_page.nil? && Commontator::Comment.will_paginate?
17
+ end
23
18
 
24
- def is_filtered?
25
- will_paginate? || config.comment_filter
26
- end
19
+ def is_filtered?
20
+ !config.comment_filter.nil?
21
+ end
27
22
 
28
- def filtered_comments
29
- cf = config.comment_filter
30
- return comments if cf.nil?
31
- comments.where(cf)
32
- end
23
+ def filtered_comments
24
+ cf = config.comment_filter
25
+ return comments if cf.nil?
33
26
 
34
- def ordered_comments(unfiltered = false)
35
- vc = unfiltered ? comments : filtered_comments
36
- case config.comment_order.to_sym
37
- when :l then vc.order('created_at DESC')
38
- when :e then vc.order('created_at ASC')
39
- when :ve then vc.order('cached_votes_down - cached_votes_up', 'created_at ASC')
40
- when :vl then vc.order('cached_votes_down - cached_votes_up', 'created_at DESC')
41
- else vc
42
- end
43
- end
27
+ comments.where(cf)
28
+ end
44
29
 
45
- def paginated_comments(page = 1, per_page = config.comments_per_page)
46
- oc = ordered_comments
47
- return oc unless will_paginate?
48
- oc.paginate(page: page, per_page: per_page)
30
+ def ordered_comments(show_all = false)
31
+ vc = show_all ? comments : filtered_comments
32
+ cc = Commontator::Comment.arel_table
33
+ case config.comment_order.to_sym
34
+ when :l
35
+ vc.order(cc[:created_at].desc)
36
+ when :e
37
+ vc.order(cc[:created_at].asc)
38
+ when :ve
39
+ vc.order((cc[:cached_votes_down] - cc[:cached_votes_up]).asc, cc[:created_at].asc)
40
+ when :vl
41
+ vc.order((cc[:cached_votes_down] - cc[:cached_votes_up]).asc, cc[:created_at].desc)
42
+ else
43
+ vc
49
44
  end
45
+ end
50
46
 
51
- def new_comment_page(per_page = config.comments_per_page)
52
- return 1 if per_page.nil? || per_page.to_i <= 0
53
- comment_index = \
54
- case config.comment_order.to_sym
55
- when :l
56
- 1 # First comment
57
- when :ve
58
- comment_arel = Comment.arel_table
59
- # Last comment with rating = 0
60
- filtered_comments.where((comment_arel[:cached_votes_up] - comment_arel[:cached_votes_down]).gteq 0).count
61
- when :vl
62
- comment_arel = Comment.arel_table
63
- # First comment with rating = 0
64
- filtered_comments.where((comment_arel[:cached_votes_up] - comment_arel[:cached_votes_down]).gt 0).count + 1
65
- else
66
- filtered_comments.count # Last comment
67
- end
68
- (comment_index.to_f/per_page.to_i).ceil
69
- end
47
+ def paginated_comments(page = 1, per_page = config.comments_per_page, show_all = false)
48
+ oc = ordered_comments(show_all)
49
+ return oc unless will_paginate?
70
50
 
71
- def is_closed?
72
- !closed_at.blank?
73
- end
51
+ oc.paginate(page: page, per_page: per_page)
52
+ end
74
53
 
75
- def close(user = nil)
76
- return false if is_closed?
77
- self.closed_at = Time.now
78
- self.closer = user
79
- save
80
- end
54
+ def new_comment_page(per_page = config.comments_per_page)
55
+ return 1 if per_page.nil? || per_page.to_i <= 0
56
+
57
+ comment_index = case config.comment_order.to_sym
58
+ when :l
59
+ 1 # First comment
60
+ when :ve
61
+ cc = Commontator::Comment.arel_table
62
+ # Last comment with rating == 0
63
+ filtered_comments.where((cc[:cached_votes_up] - cc[:cached_votes_down]).gteq(0)).count
64
+ when :vl
65
+ cc = Commontator::Comment.arel_table
66
+ # First comment with rating == 0
67
+ filtered_comments.where((cc[:cached_votes_up] - cc[:cached_votes_down]).gt(0)).count + 1
68
+ else
69
+ filtered_comments.count # Last comment
70
+ end
71
+
72
+ (comment_index.to_f/per_page.to_i).ceil
73
+ end
81
74
 
82
- def reopen
83
- return false unless is_closed? && !commontable.nil?
84
- self.closed_at = nil
85
- save
86
- end
75
+ def is_closed?
76
+ !closed_at.nil?
77
+ end
87
78
 
88
- def subscribers
89
- subscriptions.collect{|s| s.subscriber}
90
- end
79
+ def close(user = nil)
80
+ return false if is_closed?
91
81
 
92
- def subscription_for(subscriber)
93
- return nil if !subscriber || !subscriber.is_commontator
94
- subscriber.subscriptions.where(thread_id: self.id).first
95
- end
82
+ self.closed_at = Time.now
83
+ self.closer = user
84
+ save
85
+ end
96
86
 
97
- def subscribe(subscriber)
98
- return false unless subscriber.is_commontator && !subscription_for(subscriber)
99
- subscription = Subscription.new
100
- subscription.subscriber = subscriber
101
- subscription.thread = self
102
- subscription.save
103
- end
87
+ def reopen
88
+ return false unless is_closed? && !commontable.nil?
104
89
 
105
- def unsubscribe(subscriber)
106
- subscription = subscription_for(subscriber)
107
- return false unless subscription
108
- subscription.destroy
109
- end
90
+ self.closed_at = nil
91
+ save
92
+ end
110
93
 
111
- def mark_as_read_for(subscriber)
112
- subscription = subscription_for(subscriber)
113
- return false unless subscription
114
- subscription.touch
115
- end
94
+ def subscribers
95
+ subscriptions.map(&:subscriber)
96
+ end
116
97
 
117
- # Creates a new empty thread and assigns it to the commontable
118
- # The old thread is kept in the database for archival purposes
119
- def clear
120
- return if commontable.blank? || !is_closed?
121
- new_thread = Thread.new
122
- new_thread.commontable = commontable
123
-
124
- with_lock do
125
- self.commontable = nil
126
- save!
127
- new_thread.save!
128
- subscriptions.each do |s|
129
- s.thread = new_thread
130
- s.save!
131
- end
132
- end
133
- end
98
+ def subscription_for(subscriber)
99
+ return nil if !subscriber || !subscriber.is_commontator
134
100
 
135
- ##################
136
- # Access Control #
137
- ##################
101
+ subscriber.commontator_subscriptions.find_by(thread_id: self.id)
102
+ end
138
103
 
139
- # Reader capabilities (user can be nil or false)
140
- def can_be_read_by?(user)
141
- return true if can_be_edited_by?(user)
142
- !commontable.nil? &&\
143
- config.thread_read_proc.call(self, user)
144
- end
104
+ def subscribe(subscriber)
105
+ return false unless subscriber.is_commontator && !subscription_for(subscriber)
145
106
 
146
- # Thread moderator capabilities
147
- def can_be_edited_by?(user)
148
- !commontable.nil? && !user.nil? && user.is_commontator &&\
149
- config.thread_moderator_proc.call(self, user)
150
- end
107
+ subscription = Commontator::Subscription.new
108
+ subscription.subscriber = subscriber
109
+ subscription.thread = self
110
+ subscription.save
111
+ end
112
+
113
+ def unsubscribe(subscriber)
114
+ subscription = subscription_for(subscriber)
115
+ return false unless subscription
116
+
117
+ subscription.destroy
118
+ end
119
+
120
+ def mark_as_read_for(subscriber)
121
+ subscription = subscription_for(subscriber)
122
+ return false unless subscription
151
123
 
152
- def can_subscribe?(user)
153
- thread_sub = config.thread_subscription.to_sym
154
- !is_closed? && !user.nil? && user.is_commontator &&\
155
- (thread_sub == :m || thread_sub == :b) &&\
156
- can_be_read_by?(user)
124
+ subscription.touch
125
+ end
126
+
127
+ # Creates a new empty thread and assigns it to the commontable
128
+ # The old thread is kept in the database for archival purposes
129
+ def clear
130
+ return if commontable.nil? || !is_closed?
131
+
132
+ new_thread = Commontator::Thread.new
133
+ new_thread.commontable = commontable
134
+
135
+ with_lock do
136
+ self.commontable = nil
137
+ save!
138
+ new_thread.save!
139
+ Commontator::Subscription.where(thread: self).update_all(thread_id: new_thread.id)
157
140
  end
158
141
  end
142
+
143
+ ##################
144
+ # Access Control #
145
+ ##################
146
+
147
+ # Reader capabilities (user can be nil or false)
148
+ def can_be_read_by?(user)
149
+ return true if can_be_edited_by?(user)
150
+
151
+ !commontable.nil? && config.thread_read_proc.call(self, user)
152
+ end
153
+
154
+ # Thread moderator capabilities
155
+ def can_be_edited_by?(user)
156
+ !commontable.nil? && !user.nil? && user.is_commontator &&
157
+ config.thread_moderator_proc.call(self, user)
158
+ end
159
+
160
+ def can_subscribe?(user)
161
+ thread_sub = config.thread_subscription.to_sym
162
+ !is_closed? && !user.nil? && user.is_commontator &&
163
+ (thread_sub == :m || thread_sub == :b) && can_be_read_by?(user)
164
+ end
159
165
  end
@@ -1,6 +1,7 @@
1
- <% # Clients of this partial must supply the following variables:
2
- # comment
3
- # user
1
+ <%#
2
+ Views that use this partial must supply the following variables:
3
+ comment
4
+ user
4
5
  %>
5
6
 
6
7
  <% can_edit = comment.can_be_edited_by?(user)
@@ -9,21 +10,19 @@
9
10
  <% if can_edit %>
10
11
  <%= link_to t('commontator.comment.actions.edit'),
11
12
  commontator.edit_comment_path(comment),
12
- id: "comment_#{comment.id.to_s}_edit_link",
13
- class: "comment_edit_link",
13
+ id: "commontator-comment-#{comment.id}-edit",
14
+ class: 'edit',
14
15
  remote: true %>
15
16
  <% end %>
16
17
 
17
- &nbsp;
18
-
19
18
  <% if can_delete %>
20
19
  <% is_deleted = comment.is_deleted? %>
21
20
  <% del_string = is_deleted ? 'undelete' : 'delete' %>
22
21
  <%= link_to t("commontator.comment.actions.#{del_string}"),
23
22
  commontator.polymorphic_path([del_string, comment]),
24
- confirm: (!is_deleted ? t('commontator.comment.actions.confirm_delete') : nil),
23
+ data: is_deleted ? {} : { confirm: t('commontator.comment.actions.confirm_delete') },
25
24
  method: :put,
26
- id: "comment_#{comment.id.to_s}_#{del_string}_link",
27
- class: "comment_#{del_string}_link",
25
+ id: "commontator-comment-#{comment.id}-#{del_string}",
26
+ class: del_string,
28
27
  remote: true %>
29
28
  <% end %>
@@ -1,8 +1,13 @@
1
- <% # Clients of this partial must provide the following variable:
2
- # comment
1
+ <%#
2
+ Views that use this partial must provide the following variable:
3
+ comment
3
4
  %>
4
5
 
5
- <%= simple_format comment.is_deleted? ? \
6
- t('commontator.comment.status.deleted_by',
7
- deleter_name: Commontator.commontator_name(comment.editor)) : \
8
- comment.body %>
6
+ <%=
7
+ commontator_simple_format(
8
+ comment.is_deleted? ? t(
9
+ 'commontator.comment.status.deleted_by',
10
+ deleter_name: Commontator.commontator_name(comment.editor)
11
+ ) : comment.body
12
+ )
13
+ %>
@@ -1,16 +1,17 @@
1
- <% # Clients of this partial must provide the following variables:
2
- # comment
3
- #
4
- # Optionally, they can also supply the following variables:
5
- per_page ||= nil
6
- thread ||= nil
7
- no_remote ||= false
1
+ <%
2
+ # Views that use this partial must provide the following variables:
3
+ # comment
4
+ #
5
+ # Optionally, they can also supply the following variables:
6
+ per_page ||= nil
7
+ thread ||= nil
8
+ no_remote ||= false
8
9
  %>
9
10
 
10
11
  <% config = comment.thread.config %>
11
12
 
12
13
  <% if comment.errors.any? %>
13
- <div class="comment_error_explanation">
14
+ <div class="error-explanation">
14
15
  <h3><%= t "commontator.comment.errors.#{comment.id.blank? ? 'create' : 'update'}" %></h3>
15
16
 
16
17
  <ul>
@@ -21,19 +22,29 @@
21
22
  </div>
22
23
  <% end %>
23
24
 
24
- <%= form_for([commontator, thread, comment],
25
- remote: !no_remote) do |f| %>
26
-
25
+ <%= form_for([commontator, thread, comment], remote: !no_remote) do |form| %>
27
26
  <%= hidden_field_tag :per_page, per_page %>
28
-
29
- <div class="comment_form_field">
30
- <%= f.text_area :body, rows: '7' %>
31
- <%= javascript_tag('Commontator.initMentions()') if Commontator.mentions_enabled %>
27
+
28
+ <%= form.hidden_field :parent_id %>
29
+
30
+ <% unless comment.parent.nil? %>
31
+ <div class="replying">
32
+ <%= t('commontator.comment.replying',
33
+ creator_name: Commontator.commontator_name(comment.parent.creator)) %>
34
+ </div>
35
+ <% end %>
36
+
37
+ <div class="field">
38
+ <%=
39
+ form.text_area :body, rows: '7', id: comment.id.blank? ?
40
+ "commontator-thread-#{@commontator_thread.id}-new-comment-body" :
41
+ "commontator-comment-#{comment.id}-edit-body"
42
+ %>
43
+ <%= javascript_tag('Commontator.initMentions();') if config.mentions_enabled %>
32
44
  </div>
33
-
34
- <div class="comment_form_actions">
35
- <%= f.submit t("commontator.comment.actions.#{comment.id.blank? ? 'create' : 'update'}") %>
36
- <%= f.submit t('commontator.comment.actions.cancel'), name: 'cancel' %>
45
+
46
+ <div class="submit">
47
+ <%= form.submit t("commontator.comment.actions.#{comment.id.blank? ? 'create' : 'update'}") %>
48
+ <%= form.submit t('commontator.comment.actions.cancel'), name: 'cancel' %>
37
49
  </div>
38
-
39
50
  <% end %>