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,52 +1,47 @@
1
- class InstallCommontator < ActiveRecord::Migration[5.0]
1
+ class InstallCommontator < ActiveRecord::Migration[5.2]
2
2
  def change
3
- create_table :commontator_comments do |t|
4
- t.string :creator_type
5
- t.integer :creator_id
6
- t.string :editor_type
7
- t.integer :editor_id
8
- t.integer :thread_id, null: false
9
- t.text :body, null: false
10
- t.datetime :deleted_at
3
+ create_table :commontator_threads do |t|
4
+ t.references :commontable,
5
+ polymorphic: true,
6
+ index: { unique: true, name: 'index_commontator_threads_on_c_id_and_c_type' }
7
+ t.references :closer, polymorphic: true
11
8
 
12
- t.integer :cached_votes_up, default: 0
13
- t.integer :cached_votes_down, default: 0
9
+ t.datetime :closed_at
14
10
 
15
11
  t.timestamps null: false
16
12
  end
17
13
 
18
- add_index :commontator_comments, [:creator_id, :creator_type, :thread_id],
19
- name: 'index_commontator_comments_on_c_id_and_c_type_and_t_id'
20
- add_index :commontator_comments, [:thread_id, :created_at]
14
+ create_table :commontator_comments do |t|
15
+ t.references :thread, null: false, index: false, foreign_key: {
16
+ to_table: :commontator_threads, on_update: :cascade, on_delete: :cascade
17
+ }
18
+ t.references :creator, polymorphic: true, null: false, index: false
19
+ t.references :editor, polymorphic: true
21
20
 
22
- add_index :commontator_comments, :cached_votes_up
23
- add_index :commontator_comments, :cached_votes_down
21
+ t.text :body, null: false
22
+ t.datetime :deleted_at
24
23
 
25
- create_table :commontator_subscriptions do |t|
26
- t.string :subscriber_type, null: false
27
- t.integer :subscriber_id, null: false
28
- t.integer :thread_id, null: false
24
+ t.integer :cached_votes_up, default: 0, index: true
25
+ t.integer :cached_votes_down, default: 0, index: true
29
26
 
30
27
  t.timestamps null: false
31
28
  end
32
29
 
33
- add_index :commontator_subscriptions, [:subscriber_id, :subscriber_type, :thread_id],
34
- unique: true,
35
- name: 'index_commontator_subscriptions_on_s_id_and_s_type_and_t_id'
36
- add_index :commontator_subscriptions, :thread_id
30
+ add_index :commontator_comments, [ :creator_id, :creator_type, :thread_id ],
31
+ name: 'index_commontator_comments_on_c_id_and_c_type_and_t_id'
32
+ add_index :commontator_comments, [ :thread_id, :created_at ]
37
33
 
38
- create_table :commontator_threads do |t|
39
- t.string :commontable_type
40
- t.integer :commontable_id
41
- t.datetime :closed_at
42
- t.string :closer_type
43
- t.integer :closer_id
34
+ create_table :commontator_subscriptions do |t|
35
+ t.references :thread, null: false, foreign_key: {
36
+ to_table: :commontator_threads, on_update: :cascade, on_delete: :cascade
37
+ }
38
+ t.references :subscriber, polymorphic: true, null: false, index: false
44
39
 
45
40
  t.timestamps null: false
46
41
  end
47
42
 
48
- add_index :commontator_threads, [:commontable_id, :commontable_type],
43
+ add_index :commontator_subscriptions, [ :subscriber_id, :subscriber_type, :thread_id ],
49
44
  unique: true,
50
- name: 'index_commontator_threads_on_c_id_and_c_type'
45
+ name: 'index_commontator_subscriptions_on_s_id_and_s_type_and_t_id'
51
46
  end
52
47
  end
@@ -0,0 +1,9 @@
1
+ class AddReplyingToComments < ActiveRecord::Migration[5.2]
2
+ def change
3
+ add_reference :commontator_comments, :parent, foreign_key: {
4
+ to_table: :commontator_comments, on_update: :restrict, on_delete: :cascade
5
+ }
6
+ add_column :commontator_comments, :ancestor_ids, :text
7
+ add_column :commontator_comments, :descendant_ids, :text
8
+ end
9
+ end
@@ -1,145 +1,14 @@
1
- require 'commontator/engine'
2
- require 'commontator/controllers'
1
+ require 'commontator/version'
3
2
 
4
3
  module Commontator
5
- # Attributes
4
+ # These requires need the Commontator module to function properly
5
+ require 'commontator/engine'
6
+ require 'commontator/config'
7
+ require 'commontator/controllers'
8
+ require 'commontator/acts_as_commontator'
9
+ require 'commontator/acts_as_commontable'
6
10
 
7
- # Can be set in initializer only
8
- ENGINE_ATTRIBUTES = [
9
- :current_user_proc,
10
- :javascript_proc,
11
- :mentions_enabled
12
- ]
11
+ VERSION = COMMONTATOR_VERSION
13
12
 
14
- # Can be set in initializer or passed as an option to acts_as_commontator
15
- COMMONTATOR_ATTRIBUTES = [
16
- :user_name_proc,
17
- :user_link_proc,
18
- :user_avatar_proc,
19
- :user_email_proc,
20
- :user_mentions_proc
21
- ]
22
-
23
- # Can be set in initializer or passed as an option to acts_as_commontable
24
- COMMONTABLE_ATTRIBUTES = [
25
- :comment_filter,
26
- :thread_read_proc,
27
- :thread_moderator_proc,
28
- :comment_editing,
29
- :comment_deletion,
30
- :moderator_permissions,
31
- :comment_voting,
32
- :vote_count_proc,
33
- :comment_order,
34
- :new_comment_style,
35
- :comments_per_page,
36
- :thread_subscription,
37
- :email_from_proc,
38
- :commontable_name_proc,
39
- :comment_url_proc
40
- ]
41
-
42
- DEPRECATED_ATTRIBUTES = [
43
- [:moderators_can_edit_comments, :moderator_permissions],
44
- [:hide_deleted_comments, :comment_filter],
45
- [:hide_closed_threads, :thread_read_proc],
46
- [:wp_link_renderer_proc],
47
- [:voting_text_proc, :vote_count_proc],
48
- [:user_name_clickable, :user_link_proc],
49
- [:user_admin_proc, :thread_moderator_proc],
50
- [:auto_subscribe_on_comment, :thread_subscription],
51
- [:can_edit_own_comments, :comment_editing],
52
- [:can_edit_old_comments, :comment_editing],
53
- [:can_delete_own_comments, :comment_deletion],
54
- [:can_delete_old_comments, :comment_deletion],
55
- [:can_subscribe_to_thread, :thread_subscription],
56
- [:can_vote_on_comments, :comment_voting],
57
- [:combine_upvotes_and_downvotes, :vote_count_proc],
58
- [:comments_order, :comment_order],
59
- [:closed_threads_are_readable, :thread_read_proc],
60
- [:deleted_comments_are_visible, :comment_filter],
61
- [:can_read_thread_proc, :thread_read_proc],
62
- [:can_edit_thread_proc, :thread_moderator_proc],
63
- [:admin_can_edit_comments, :moderator_permissions],
64
- [:subscription_email_enable_proc, :user_email_proc],
65
- [:comment_name, 'config/locales'],
66
- [:comment_create_verb_present, 'config/locales'],
67
- [:comment_create_verb_past, 'config/locales'],
68
- [:comment_edit_verb_present, 'config/locales'],
69
- [:comment_edit_verb_past, 'config/locales'],
70
- [:timestamp_format, 'config/locales'],
71
- [:subscription_email_to_proc, 'config/locales'],
72
- [:subscription_email_from_proc, :email_from_proc],
73
- [:subscription_email_subject_proc, 'config/locales'],
74
- [:comments_ordered_by_votes, :comment_order],
75
- [:current_user_method, :current_user_proc],
76
- [:user_missing_name, 'config/locales'],
77
- [:user_email_method, :user_email_proc],
78
- [:user_name_method, :user_name_proc],
79
- [:commontable_name, :commontable_name_proc],
80
- [:commontable_id_method],
81
- [:commontable_url_proc, :comment_url_proc]
82
- ]
83
-
84
- (ENGINE_ATTRIBUTES + COMMONTATOR_ATTRIBUTES + \
85
- COMMONTABLE_ATTRIBUTES).each do |attribute|
86
- mattr_accessor attribute
87
- end
88
-
89
- DEPRECATED_ATTRIBUTES.each do |deprecated, replacement|
90
- define_singleton_method(deprecated) do
91
- @deprecated_method_called = true
92
- replacement_string = (replacement.nil? ? 'No replacement is available. You can safely remove it from your configuration file.' : "Use `#{replacement.to_s}` instead.")
93
- warn "\n[COMMONTATOR] Deprecation: `config.#{deprecated.to_s}` is deprecated and has been disabled. #{replacement_string}\n"
94
- end
95
-
96
- define_singleton_method("#{deprecated.to_s}=") do |obj|
97
- send(deprecated)
98
- end
99
- end
100
-
101
- def self.configure
102
- @deprecated_method_called = false
103
- yield self
104
- warn "\n[COMMONTATOR] We recommend that you backup the config/initializers/commontator.rb file, rename or remove it, run rake commontator:install:initializers to copy the new default one, then configure it to your liking.\n" if @deprecated_method_called
105
- end
106
-
107
- def self.commontator_config(user)
108
- (user && user.is_commontator) ? user.commontator_config : self
109
- end
110
-
111
- def self.commontable_config(obj)
112
- (obj && obj.is_commontable) ? obj.commontable_config : self
113
- end
114
-
115
- def self.commontator_name(user)
116
- commontator_config(user).user_name_proc.call(user)
117
- end
118
-
119
- def self.commontator_link(user, routing_proxy)
120
- commontator_config(user).user_link_proc.call(user, routing_proxy)
121
- end
122
-
123
- def self.commontator_email(user, mailer = nil)
124
- commontator_config(user).user_email_proc.call(user, mailer)
125
- end
126
-
127
- def self.commontator_avatar(user, view)
128
- commontator_config(user).user_avatar_proc.call(user, view)
129
- end
130
-
131
- def self.commontator_mentions(user, thread, search_phrase)
132
- commontator_config(user).user_mentions_proc.call(user, thread, search_phrase)
133
- end
134
-
135
- def self.commontable_name(commontable)
136
- commontable_config(commontable).commontable_name_proc.call(commontable)
137
- end
138
-
139
- def self.comment_url(comment, routing_proxy)
140
- commontable_config(comment.thread.commontable).comment_url_proc.call(comment, routing_proxy)
141
- end
13
+ include Commontator::Config
142
14
  end
143
-
144
- require 'commontator/acts_as_commontator'
145
- require 'commontator/acts_as_commontable'
@@ -1,44 +1,35 @@
1
- require 'commontator/commontable_config'
2
-
3
- module Commontator
4
- module ActsAsCommontable
5
- def self.included(base)
6
- base.class_attribute :is_commontable
7
- base.is_commontable = false
8
- base.extend(ClassMethods)
9
- end
1
+ require_relative 'commontable_config'
2
+ require_relative 'build_thread'
3
+
4
+ module Commontator::ActsAsCommontable
5
+ def self.included(base)
6
+ base.class_attribute :is_commontable
7
+ base.is_commontable = false
8
+ base.extend(ClassMethods)
9
+ end
10
10
 
11
- module ClassMethods
12
- def acts_as_commontable(options = {})
13
- class_eval do
14
- cattr_accessor :commontable_config
15
- association_options = options.extract!(:dependent)
16
- self.commontable_config = Commontator::CommontableConfig.new(options)
17
- self.is_commontable = true
11
+ module ClassMethods
12
+ def acts_as_commontable(options = {})
13
+ class_exec do
14
+ association_options = options.extract!(:dependent)
15
+ association_options[:dependent] ||= :nullify
18
16
 
19
- has_one :thread, as: :commontable,
20
- class_name: 'Commontator::Thread',
21
- dependent: association_options[:dependent]
17
+ cattr_accessor :commontable_config
18
+ self.commontable_config = Commontator::CommontableConfig.new(options)
22
19
 
23
- validates_presence_of :thread
20
+ has_one :commontator_thread, association_options.merge(
21
+ as: :commontable, class_name: 'Commontator::Thread'
22
+ )
24
23
 
25
- prepend ThreadWithCommontator
26
- end
27
- end
24
+ validates :commontator_thread, presence: true
28
25
 
29
- module ThreadWithCommontator
30
- def thread
31
- @thread ||= super
32
- return @thread unless @thread.nil?
26
+ prepend Commontator::BuildThread
33
27
 
34
- @thread = build_thread
35
- @thread.save if persisted?
36
- @thread
37
- end
28
+ self.is_commontable = true
38
29
  end
39
-
40
- alias_method :acts_as_commentable, :acts_as_commontable
41
30
  end
31
+
32
+ alias_method :acts_as_commentable, :acts_as_commontable
42
33
  end
43
34
  end
44
35
 
@@ -1,32 +1,35 @@
1
- require 'commontator/commontator_config'
1
+ require_relative 'commontator_config'
2
2
 
3
- module Commontator
4
- module ActsAsCommontator
5
- def self.included(base)
6
- base.class_attribute :is_commontator
7
- base.is_commontator = false
8
- base.extend(ClassMethods)
9
- end
10
-
11
- module ClassMethods
12
- def acts_as_commontator(options = {})
13
- class_eval do
14
- cattr_accessor :commontator_config
15
- self.commontator_config = Commontator::CommontatorConfig.new(options)
16
- self.is_commontator = true
3
+ module Commontator::ActsAsCommontator
4
+ def self.included(base)
5
+ base.class_attribute :is_commontator
6
+ base.is_commontator = false
7
+ base.extend(ClassMethods)
8
+ end
9
+
10
+ module ClassMethods
11
+ def acts_as_commontator(options = {})
12
+ class_exec do
13
+ association_options = options.extract!(:dependent)
14
+ association_options[:dependent] ||= :destroy
17
15
 
18
- has_many :comments, as: :creator,
19
- class_name: 'Commontator::Comment'
20
- has_many :subscriptions, as: :subscriber,
21
- class_name: 'Commontator::Subscription',
22
- dependent: :destroy
23
- end
16
+ cattr_accessor :commontator_config
17
+ self.commontator_config = Commontator::CommontatorConfig.new(options)
18
+
19
+ has_many :commontator_comments, association_options.merge(
20
+ as: :creator, class_name: 'Commontator::Comment'
21
+ )
22
+ has_many :commontator_subscriptions, association_options.merge(
23
+ as: :subscriber, class_name: 'Commontator::Subscription'
24
+ )
25
+
26
+ self.is_commontator = true
24
27
  end
25
-
26
- alias_method :acts_as_commonter, :acts_as_commontator
27
- alias_method :acts_as_commentator, :acts_as_commontator
28
- alias_method :acts_as_commenter, :acts_as_commontator
29
28
  end
29
+
30
+ alias_method :acts_as_commonter, :acts_as_commontator
31
+ alias_method :acts_as_commentator, :acts_as_commontator
32
+ alias_method :acts_as_commenter, :acts_as_commontator
30
33
  end
31
34
  end
32
35
 
@@ -0,0 +1,10 @@
1
+ module Commontator::BuildThread
2
+ def commontator_thread
3
+ @commontator_thread ||= super
4
+ return @commontator_thread unless @commontator_thread.nil?
5
+
6
+ @commontator_thread = build_commontator_thread.tap do |thread|
7
+ thread.save if persisted?
8
+ end
9
+ end
10
+ end
@@ -1,13 +1,13 @@
1
- module Commontator
2
- class CommontableConfig
3
- Commontator::COMMONTABLE_ATTRIBUTES.each do |attribute|
4
- attr_accessor attribute
5
- end
6
-
7
- def initialize(options = {})
8
- Commontator::COMMONTABLE_ATTRIBUTES.each do |attribute|
9
- self.send attribute.to_s + '=', options[attribute] || Commontator.send(attribute)
10
- end
1
+ require_relative 'config'
2
+
3
+ class Commontator::CommontableConfig
4
+ Commontator::Config::COMMONTABLE_ATTRIBUTES.each do |attribute|
5
+ attr_accessor attribute
6
+ end
7
+
8
+ def initialize(options = {})
9
+ Commontator::Config::COMMONTABLE_ATTRIBUTES.each do |attribute|
10
+ self.send attribute.to_s + '=', options[attribute] || Commontator.send(attribute)
11
11
  end
12
12
  end
13
13
  end
@@ -1,13 +1,13 @@
1
- module Commontator
2
- class CommontatorConfig
3
- Commontator::COMMONTATOR_ATTRIBUTES.each do |attribute|
4
- attr_accessor attribute
5
- end
6
-
7
- def initialize(options = {})
8
- Commontator::COMMONTATOR_ATTRIBUTES.each do |attribute|
9
- self.send attribute.to_s + '=', options[attribute] || Commontator.send(attribute)
10
- end
1
+ require_relative 'config'
2
+
3
+ class Commontator::CommontatorConfig
4
+ Commontator::Config::COMMONTATOR_ATTRIBUTES.each do |attribute|
5
+ attr_accessor attribute
6
+ end
7
+
8
+ def initialize(options = {})
9
+ Commontator::Config::COMMONTATOR_ATTRIBUTES.each do |attribute|
10
+ self.send attribute.to_s + '=', options[attribute] || Commontator.send(attribute)
11
11
  end
12
12
  end
13
13
  end
@@ -1,14 +1,10 @@
1
- require 'commontator/engine'
2
- require 'commontator/controller_includes'
3
-
4
- module Commontator
1
+ module Commontator::Config
5
2
  # Attributes
6
3
 
7
4
  # Can be set in initializer only
8
5
  ENGINE_ATTRIBUTES = [
9
6
  :current_user_proc,
10
- :javascript_proc,
11
- :mentions_enabled
7
+ :javascript_proc
12
8
  ]
13
9
 
14
10
  # Can be set in initializer or passed as an option to acts_as_commontator
@@ -19,7 +15,7 @@ module Commontator
19
15
  :user_email_proc,
20
16
  :user_mentions_proc
21
17
  ]
22
-
18
+
23
19
  # Can be set in initializer or passed as an option to acts_as_commontable
24
20
  COMMONTABLE_ATTRIBUTES = [
25
21
  :comment_filter,
@@ -36,9 +32,11 @@ module Commontator
36
32
  :thread_subscription,
37
33
  :email_from_proc,
38
34
  :commontable_name_proc,
39
- :comment_url_proc
35
+ :comment_url_proc,
36
+ :comment_reply_style,
37
+ :mentions_enabled
40
38
  ]
41
-
39
+
42
40
  DEPRECATED_ATTRIBUTES = [
43
41
  [:moderators_can_edit_comments, :moderator_permissions],
44
42
  [:hide_deleted_comments, :comment_filter],
@@ -76,70 +74,72 @@ module Commontator
76
74
  [:user_missing_name, 'config/locales'],
77
75
  [:user_email_method, :user_email_proc],
78
76
  [:user_name_method, :user_name_proc],
79
- [:commontable_name, :commontable_name_proc],
80
77
  [:commontable_id_method],
81
78
  [:commontable_url_proc, :comment_url_proc]
82
79
  ]
83
-
84
- (ENGINE_ATTRIBUTES + COMMONTATOR_ATTRIBUTES + \
85
- COMMONTABLE_ATTRIBUTES).each do |attribute|
86
- mattr_accessor attribute
87
- end
88
80
 
89
- DEPRECATED_ATTRIBUTES.each do |deprecated, replacement|
90
- define_singleton_method(deprecated) do
91
- @deprecated_method_called = true
92
- replacement_string = (replacement.nil? ? 'No replacement is available. You can safely remove it from your configuration file.' : "Use `#{replacement.to_s}` instead.")
93
- warn "\n[COMMONTATOR] Deprecation: `config.#{deprecated.to_s}` is deprecated and has been disabled. #{replacement_string}\n"
81
+ def self.included(base)
82
+ (ENGINE_ATTRIBUTES + COMMONTATOR_ATTRIBUTES + COMMONTABLE_ATTRIBUTES).each do |attribute|
83
+ base.mattr_accessor attribute
94
84
  end
95
85
 
96
- define_singleton_method("#{deprecated.to_s}=") do |obj|
97
- send(deprecated)
86
+ base.mattr_accessor :show_deprecation_warning
87
+ DEPRECATED_ATTRIBUTES.each do |deprecated, replacement|
88
+ base.define_singleton_method(deprecated) do
89
+ base.show_deprecation_warning = true
90
+ replacement_string = (replacement.nil? ? 'No replacement is available. You can safely remove it from your configuration file.' : "Use `#{replacement.to_s}` instead.")
91
+ warn "\n[COMMONTATOR] Deprecation: `config.#{deprecated.to_s}` is deprecated and has been disabled. #{replacement_string}\n"
92
+ end
93
+
94
+ base.define_singleton_method("#{deprecated.to_s}=") { |obj| base.send(deprecated) }
98
95
  end
99
- end
100
-
101
- def self.configure
102
- @deprecated_method_called = false
103
- yield self
104
- warn "\n[COMMONTATOR] We recommend that you backup the config/initializers/commontator.rb file, rename or remove it, run rake commontator:install:initializers to copy the new default one, then configure it to your liking.\n" if @deprecated_method_called
105
- end
106
96
 
107
- def self.commontator_config(user)
108
- (user && user.is_commontator) ? user.commontator_config : self
97
+ base.extend ClassMethods
109
98
  end
110
99
 
111
- def self.commontable_config(obj)
112
- (obj && obj.is_commontable) ? obj.commontable_config : self
113
- end
100
+ module ClassMethods
101
+ def configure
102
+ self.show_deprecation_warning = false
114
103
 
115
- def self.commontator_name(user)
116
- commontator_config(user).user_name_proc.call(user)
117
- end
104
+ yield self
118
105
 
119
- def self.commontator_link(user, routing_proxy)
120
- commontator_config(user).user_link_proc.call(user, routing_proxy)
121
- end
106
+ warn("\n[COMMONTATOR] We recommend that you backup the config/initializers/commontator.rb file, rename or remove it, run rake commontator:install:initializers to copy the new default one, then configure it to your liking.\n") if show_deprecation_warning
107
+ end
122
108
 
123
- def self.commontator_email(user, mailer = nil)
124
- commontator_config(user).user_email_proc.call(user, mailer)
125
- end
109
+ def commontator_config(user)
110
+ (user && user.is_commontator) ? user.commontator_config : self
111
+ end
126
112
 
127
- def self.commontator_avatar(user, view)
128
- commontator_config(user).user_avatar_proc.call(user, view)
129
- end
113
+ def commontable_config(obj)
114
+ (obj && obj.is_commontable) ? obj.commontable_config : self
115
+ end
130
116
 
131
- def self.commontator_mentions(user, search_phrase)
132
- commontator_config(user).user_mentions_proc.call(user, search_phrase)
133
- end
117
+ def commontator_name(user)
118
+ commontator_config(user).user_name_proc.call(user)
119
+ end
134
120
 
135
- def self.commontable_name(commontable)
136
- commontable_config(commontable).commontable_name_proc.call(commontable)
137
- end
121
+ def commontator_link(user, routing_proxy)
122
+ commontator_config(user).user_link_proc.call(user, routing_proxy)
123
+ end
124
+
125
+ def commontator_email(user, mailer = nil)
126
+ commontator_config(user).user_email_proc.call(user, mailer)
127
+ end
138
128
 
139
- def self.comment_url(comment, routing_proxy)
140
- commontable_config(comment.thread.commontable).comment_url_proc.call(comment, routing_proxy)
129
+ def commontator_avatar(user, view)
130
+ commontator_config(user).user_avatar_proc.call(user, view)
131
+ end
132
+
133
+ def commontator_mentions(user, thread, search_phrase)
134
+ commontator_config(user).user_mentions_proc.call(user, thread, search_phrase)
135
+ end
136
+
137
+ def commontable_name(commontable)
138
+ commontable_config(commontable).commontable_name_proc.call(commontable)
139
+ end
140
+
141
+ def comment_url(comment, routing_proxy)
142
+ commontable_config(comment.thread.commontable).comment_url_proc.call(comment, routing_proxy)
143
+ end
141
144
  end
142
145
  end
143
-
144
- require 'commontator/acts_as_commontator'
145
- require 'commontator/acts_as_commontable'