fat_free_crm 0.16.4 → 0.17.1

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

Potentially problematic release.


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

Files changed (783) hide show
  1. checksums.yaml +5 -5
  2. data/.gitignore +1 -0
  3. data/.rubocop.yml +44 -5
  4. data/.rubocop_todo.yml +23 -359
  5. data/.travis.yml +21 -21
  6. data/CHANGELOG.md +42 -9
  7. data/Capfile +2 -0
  8. data/Gemfile +4 -1
  9. data/Gemfile.lock +27 -25
  10. data/Guardfile +2 -0
  11. data/README.md +5 -5
  12. data/Rakefile +2 -0
  13. data/Vagrantfile +92 -0
  14. data/app/assets/javascripts/application.js.erb +0 -2
  15. data/app/assets/javascripts/crm.js.coffee +16 -20
  16. data/app/assets/stylesheets/application.css.erb +0 -2
  17. data/app/controllers/admin/application_controller.rb +3 -1
  18. data/app/controllers/admin/field_groups_controller.rb +2 -0
  19. data/app/controllers/admin/fields_controller.rb +4 -5
  20. data/app/controllers/admin/groups_controller.rb +2 -0
  21. data/app/controllers/admin/plugins_controller.rb +3 -7
  22. data/app/controllers/admin/settings_controller.rb +3 -5
  23. data/app/controllers/admin/tags_controller.rb +3 -5
  24. data/app/controllers/admin/users_controller.rb +4 -2
  25. data/app/controllers/application_controller.rb +16 -16
  26. data/app/controllers/authentications_controller.rb +4 -2
  27. data/app/controllers/comments_controller.rb +5 -4
  28. data/app/controllers/emails_controller.rb +2 -0
  29. data/app/controllers/entities/accounts_controller.rb +14 -7
  30. data/app/controllers/entities/campaigns_controller.rb +15 -8
  31. data/app/controllers/entities/contacts_controller.rb +28 -21
  32. data/app/controllers/entities/leads_controller.rb +33 -22
  33. data/app/controllers/entities/opportunities_controller.rb +33 -26
  34. data/app/controllers/entities_controller.rb +15 -1
  35. data/app/controllers/home_controller.rb +10 -5
  36. data/app/controllers/lists_controller.rb +3 -5
  37. data/app/controllers/passwords_controller.rb +3 -1
  38. data/app/controllers/tasks_controller.rb +11 -9
  39. data/app/controllers/users_controller.rb +4 -1
  40. data/app/helpers/accounts_helper.rb +14 -19
  41. data/app/helpers/addresses_helper.rb +2 -0
  42. data/app/helpers/admin/application_helper.rb +3 -2
  43. data/app/helpers/admin/field_groups_helper.rb +2 -0
  44. data/app/helpers/admin/fields_helper.rb +2 -0
  45. data/app/helpers/admin/plugins_helper.rb +2 -0
  46. data/app/helpers/admin/settings_helper.rb +2 -0
  47. data/app/helpers/admin/tags_helper.rb +2 -0
  48. data/app/helpers/admin/users_helper.rb +37 -17
  49. data/app/helpers/application_helper.rb +62 -68
  50. data/app/helpers/authentications_helper.rb +2 -0
  51. data/app/helpers/campaigns_helper.rb +3 -1
  52. data/app/helpers/comments_helper.rb +2 -0
  53. data/app/helpers/contacts_helper.rb +5 -3
  54. data/app/helpers/emails_helper.rb +2 -0
  55. data/app/helpers/fields_helper.rb +2 -0
  56. data/app/helpers/groups_helper.rb +2 -0
  57. data/app/helpers/home_helper.rb +2 -0
  58. data/app/helpers/javascript_helper.rb +2 -0
  59. data/app/helpers/leads_helper.rb +4 -3
  60. data/app/helpers/lists_helper.rb +2 -0
  61. data/app/helpers/opportunities_helper.rb +11 -11
  62. data/app/helpers/passwords_helper.rb +2 -0
  63. data/app/helpers/remote_link_pagination_helper.rb +2 -0
  64. data/app/helpers/tags_helper.rb +4 -2
  65. data/app/helpers/tasks_helper.rb +11 -10
  66. data/app/helpers/users_helper.rb +3 -1
  67. data/app/helpers/versions_helper.rb +2 -0
  68. data/app/inputs/date_pair_input.rb +2 -0
  69. data/app/inputs/date_time_input.rb +2 -0
  70. data/app/inputs/datetime_pair_input.rb +2 -0
  71. data/app/inputs/text_input.rb +2 -0
  72. data/app/mailers/dropbox_mailer.rb +2 -0
  73. data/app/mailers/subscription_mailer.rb +14 -8
  74. data/app/mailers/user_mailer.rb +3 -2
  75. data/app/models/entities/account.rb +17 -9
  76. data/app/models/entities/account_contact.rb +3 -1
  77. data/app/models/entities/account_opportunity.rb +3 -1
  78. data/app/models/entities/campaign.rb +3 -1
  79. data/app/models/entities/contact.rb +9 -7
  80. data/app/models/entities/contact_opportunity.rb +2 -0
  81. data/app/models/entities/lead.rb +3 -1
  82. data/app/models/entities/opportunity.rb +3 -1
  83. data/app/models/fields/core_field.rb +3 -0
  84. data/app/models/fields/custom_field.rb +8 -5
  85. data/app/models/fields/custom_field_date_pair.rb +3 -1
  86. data/app/models/fields/custom_field_datetime_pair.rb +3 -1
  87. data/app/models/fields/custom_field_pair.rb +2 -0
  88. data/app/models/fields/field.rb +9 -4
  89. data/app/models/fields/field_group.rb +3 -1
  90. data/app/models/list.rb +2 -0
  91. data/app/models/observers/entity_observer.rb +2 -0
  92. data/app/models/observers/lead_observer.rb +3 -1
  93. data/app/models/observers/opportunity_observer.rb +5 -3
  94. data/app/models/observers/task_observer.rb +2 -0
  95. data/app/models/polymorphic/address.rb +2 -0
  96. data/app/models/polymorphic/avatar.rb +2 -0
  97. data/app/models/polymorphic/comment.rb +2 -0
  98. data/app/models/polymorphic/email.rb +2 -0
  99. data/app/models/polymorphic/tag.rb +2 -0
  100. data/app/models/polymorphic/tagging.rb +2 -0
  101. data/app/models/polymorphic/task.rb +9 -8
  102. data/app/models/polymorphic/version.rb +3 -1
  103. data/app/models/setting.rb +16 -0
  104. data/app/models/users/ability.rb +2 -0
  105. data/app/models/users/authentication.rb +2 -0
  106. data/app/models/users/group.rb +2 -0
  107. data/app/models/users/permission.rb +2 -0
  108. data/app/models/users/preference.rb +2 -0
  109. data/app/models/users/user.rb +15 -15
  110. data/app/views/accounts/_account.html.haml +3 -3
  111. data/app/views/accounts/_contact_info.html.haml +7 -7
  112. data/app/views/accounts/_edit.html.haml +8 -8
  113. data/app/views/accounts/_index_brief.html.haml +11 -11
  114. data/app/views/accounts/_index_long.html.haml +12 -12
  115. data/app/views/accounts/_new.html.haml +9 -9
  116. data/app/views/accounts/_sidebar_index.html.haml +5 -5
  117. data/app/views/accounts/_sidebar_show.html.haml +11 -11
  118. data/app/views/accounts/_title_bar.html.haml +2 -2
  119. data/app/views/accounts/_top_section.html.haml +8 -8
  120. data/app/views/accounts/create.js.haml +3 -3
  121. data/app/views/accounts/destroy.js.haml +1 -1
  122. data/app/views/accounts/edit.js.haml +4 -4
  123. data/app/views/accounts/index.js.haml +4 -4
  124. data/app/views/accounts/index.xls.builder +3 -1
  125. data/app/views/accounts/new.js.haml +1 -1
  126. data/app/views/accounts/show.html.haml +8 -8
  127. data/app/views/accounts/show.js.haml +1 -1
  128. data/app/views/accounts/update.js.haml +2 -2
  129. data/app/views/admin/custom_fields/_base_field.html.haml +4 -2
  130. data/app/views/admin/custom_fields/_check_boxes_field.html.haml +2 -2
  131. data/app/views/admin/custom_fields/_date_field.html.haml +1 -1
  132. data/app/views/admin/custom_fields/_date_pair_field.html.haml +2 -2
  133. data/app/views/admin/custom_fields/_datetime_field.html.haml +1 -1
  134. data/app/views/admin/custom_fields/_datetime_pair_field.html.haml +2 -2
  135. data/app/views/admin/custom_fields/_radio_field.html.haml +2 -2
  136. data/app/views/admin/custom_fields/_select_field.html.haml +1 -1
  137. data/app/views/admin/custom_fields/_string_field.html.haml +1 -1
  138. data/app/views/admin/field_groups/_confirm.html.haml +1 -1
  139. data/app/views/admin/field_groups/_edit.html.haml +3 -3
  140. data/app/views/admin/field_groups/_field_group.html.haml +9 -9
  141. data/app/views/admin/field_groups/_new.html.haml +4 -4
  142. data/app/views/admin/field_groups/_top_section.html.haml +3 -3
  143. data/app/views/admin/field_groups/confirm.js.haml +1 -1
  144. data/app/views/admin/field_groups/create.js.haml +2 -2
  145. data/app/views/admin/field_groups/edit.js.haml +1 -1
  146. data/app/views/admin/field_groups/new.js.haml +1 -1
  147. data/app/views/admin/field_groups/update.js.haml +1 -1
  148. data/app/views/admin/fields/_field.html.haml +4 -4
  149. data/app/views/admin/fields/_form.html.haml +10 -10
  150. data/app/views/admin/fields/_subform.html.haml +2 -2
  151. data/app/views/admin/fields/create.js.haml +2 -2
  152. data/app/views/admin/fields/edit.js.haml +1 -1
  153. data/app/views/admin/fields/index.html.haml +6 -6
  154. data/app/views/admin/fields/show.html.haml +1 -1
  155. data/app/views/admin/fields/update.js.haml +2 -2
  156. data/app/views/admin/groups/_edit.html.haml +3 -3
  157. data/app/views/admin/groups/_form.html.haml +1 -1
  158. data/app/views/admin/groups/_group.html.haml +4 -4
  159. data/app/views/admin/groups/_new.html.haml +3 -3
  160. data/app/views/admin/groups/create.js.haml +2 -2
  161. data/app/views/admin/groups/edit.js.haml +2 -2
  162. data/app/views/admin/groups/index.html.haml +3 -3
  163. data/app/views/admin/groups/index.js.haml +2 -2
  164. data/app/views/admin/groups/new.js.haml +1 -1
  165. data/app/views/admin/groups/update.js.haml +2 -2
  166. data/app/views/admin/plugins/_plugin.html.haml +1 -1
  167. data/app/views/admin/tags/_confirm.html.haml +2 -2
  168. data/app/views/admin/tags/_edit.html.haml +3 -3
  169. data/app/views/admin/tags/_new.html.haml +3 -3
  170. data/app/views/admin/tags/_tag.html.haml +4 -4
  171. data/app/views/admin/tags/confirm.js.haml +1 -1
  172. data/app/views/admin/tags/create.js.haml +2 -2
  173. data/app/views/admin/tags/edit.js.haml +3 -3
  174. data/app/views/admin/tags/index.html.haml +3 -3
  175. data/app/views/admin/tags/new.js.haml +1 -1
  176. data/app/views/admin/tags/update.js.haml +2 -2
  177. data/app/views/admin/users/_confirm.html.haml +1 -1
  178. data/app/views/admin/users/_edit.html.haml +3 -3
  179. data/app/views/admin/users/_new.html.haml +3 -3
  180. data/app/views/admin/users/_profile.html.haml +3 -3
  181. data/app/views/admin/users/_user.html.haml +16 -16
  182. data/app/views/admin/users/confirm.js.haml +1 -1
  183. data/app/views/admin/users/create.js.haml +2 -2
  184. data/app/views/admin/users/edit.js.haml +3 -3
  185. data/app/views/admin/users/index.html.haml +3 -3
  186. data/app/views/admin/users/index.js.haml +2 -2
  187. data/app/views/admin/users/new.js.haml +1 -1
  188. data/app/views/admin/users/reactivate.js.haml +1 -1
  189. data/app/views/admin/users/suspend.js.haml +1 -1
  190. data/app/views/admin/users/update.js.haml +2 -2
  191. data/app/views/application/_auto_complete.html.haml +3 -3
  192. data/app/views/application/index.atom.builder +10 -6
  193. data/app/views/application/index.rss.builder +3 -1
  194. data/app/views/application/show.atom.builder +11 -7
  195. data/app/views/application/show.rss.builder +4 -2
  196. data/app/views/authentications/new.html.haml +1 -1
  197. data/app/views/campaigns/_campaign.html.haml +3 -3
  198. data/app/views/campaigns/_edit.html.haml +7 -7
  199. data/app/views/campaigns/_index_brief.html.haml +3 -3
  200. data/app/views/campaigns/_index_long.html.haml +5 -5
  201. data/app/views/campaigns/_metrics.html.haml +5 -5
  202. data/app/views/campaigns/_new.html.haml +8 -8
  203. data/app/views/campaigns/_objectives.html.haml +6 -6
  204. data/app/views/campaigns/_sidebar_index.html.haml +5 -5
  205. data/app/views/campaigns/_sidebar_show.html.haml +10 -10
  206. data/app/views/campaigns/_status.html.haml +1 -1
  207. data/app/views/campaigns/_title_bar.html.haml +2 -2
  208. data/app/views/campaigns/_top_section.html.haml +9 -9
  209. data/app/views/campaigns/create.js.haml +3 -3
  210. data/app/views/campaigns/destroy.js.haml +1 -1
  211. data/app/views/campaigns/edit.js.haml +4 -4
  212. data/app/views/campaigns/index.js.haml +4 -4
  213. data/app/views/campaigns/index.xls.builder +22 -20
  214. data/app/views/campaigns/new.js.haml +1 -1
  215. data/app/views/campaigns/show.html.haml +9 -9
  216. data/app/views/campaigns/show.js.haml +1 -1
  217. data/app/views/campaigns/update.js.haml +2 -2
  218. data/app/views/comments/_comment.html.haml +5 -5
  219. data/app/views/comments/_edit.html.haml +5 -5
  220. data/app/views/comments/_new.html.haml +15 -15
  221. data/app/views/comments/_subscription_links.html.haml +3 -3
  222. data/app/views/comments/create.js.haml +1 -1
  223. data/app/views/comments/edit.js.haml +2 -2
  224. data/app/views/comments/update.js.haml +2 -2
  225. data/app/views/contacts/_contact.html.haml +3 -3
  226. data/app/views/contacts/_contacts.html.haml +2 -2
  227. data/app/views/contacts/_edit.html.haml +9 -9
  228. data/app/views/contacts/_extra.html.haml +3 -3
  229. data/app/views/contacts/_index_brief.html.haml +3 -3
  230. data/app/views/contacts/_index_full.html.haml +11 -11
  231. data/app/views/contacts/_index_long.html.haml +5 -5
  232. data/app/views/contacts/_new.html.haml +10 -10
  233. data/app/views/contacts/_section_extra.html.haml +1 -1
  234. data/app/views/contacts/_section_general.html.haml +1 -1
  235. data/app/views/contacts/_sidebar_show.html.haml +8 -8
  236. data/app/views/contacts/_title_bar.html.haml +2 -2
  237. data/app/views/contacts/_top_section.html.haml +9 -9
  238. data/app/views/contacts/create.js.haml +4 -4
  239. data/app/views/contacts/destroy.js.haml +2 -2
  240. data/app/views/contacts/edit.js.haml +4 -4
  241. data/app/views/contacts/index.js.haml +4 -4
  242. data/app/views/contacts/index.xls.builder +3 -1
  243. data/app/views/contacts/new.js.haml +1 -1
  244. data/app/views/contacts/show.html.haml +7 -7
  245. data/app/views/contacts/show.js.haml +1 -1
  246. data/app/views/contacts/update.js.haml +3 -3
  247. data/app/views/emails/_email.html.haml +6 -6
  248. data/app/views/entities/_basic_search.html.haml +3 -3
  249. data/app/views/entities/_permissions.html.haml +10 -10
  250. data/app/views/entities/_search.html.haml +6 -6
  251. data/app/views/entities/_section_custom_fields.html.haml +3 -3
  252. data/app/views/entities/_title_bar.html.haml +3 -3
  253. data/app/views/entities/attach.js.haml +2 -2
  254. data/app/views/entities/contacts.js.haml +2 -2
  255. data/app/views/entities/leads.js.haml +2 -2
  256. data/app/views/entities/opportunities.js.haml +2 -2
  257. data/app/views/entities/subscription_update.js.haml +1 -1
  258. data/app/views/entities/versions.js.haml +2 -2
  259. data/app/views/fields/_edit_custom_field_group.html.haml +2 -2
  260. data/app/views/fields/_group.html.haml +5 -5
  261. data/app/views/fields/_group_table.html.haml +2 -2
  262. data/app/views/fields/_groups.html.haml +1 -1
  263. data/app/views/fields/_sidebar_show.html.haml +1 -1
  264. data/app/views/fields/group.js.erb +1 -1
  265. data/app/views/home/_account.html.haml +11 -11
  266. data/app/views/home/_activity.html.haml +7 -7
  267. data/app/views/home/_assets_menu.html.haml +1 -1
  268. data/app/views/home/_opportunity.html.haml +8 -8
  269. data/app/views/home/_options.html.haml +2 -2
  270. data/app/views/home/_task.html.haml +7 -7
  271. data/app/views/home/index.atom.builder +5 -3
  272. data/app/views/home/index.html.haml +6 -6
  273. data/app/views/home/index.js.haml +3 -3
  274. data/app/views/home/index.rss.builder +2 -0
  275. data/app/views/home/options.js.haml +1 -1
  276. data/app/views/layouts/500.html.haml +2 -2
  277. data/app/views/layouts/_footer.html.haml +1 -1
  278. data/app/views/layouts/_header.html.haml +3 -3
  279. data/app/views/layouts/_jumpbox.html.haml +1 -1
  280. data/app/views/layouts/_tabbed.html.haml +4 -4
  281. data/app/views/layouts/_tabless.html.haml +1 -1
  282. data/app/views/layouts/admin/_header.html.haml +3 -3
  283. data/app/views/layouts/admin/application.html.haml +5 -5
  284. data/app/views/layouts/application.html.haml +3 -3
  285. data/app/views/layouts/header.xls.builder +2 -0
  286. data/app/views/leads/_contact.html.haml +2 -2
  287. data/app/views/leads/_convert.html.haml +2 -2
  288. data/app/views/leads/_convert_permissions.html.haml +10 -10
  289. data/app/views/leads/_edit.html.haml +10 -10
  290. data/app/views/leads/_index_brief.html.haml +6 -6
  291. data/app/views/leads/_index_long.html.haml +7 -7
  292. data/app/views/leads/_lead.html.haml +3 -3
  293. data/app/views/leads/_leads.html.haml +2 -2
  294. data/app/views/leads/_new.html.haml +11 -11
  295. data/app/views/leads/_opportunity.html.haml +6 -6
  296. data/app/views/leads/_sidebar_index.html.haml +5 -5
  297. data/app/views/leads/_sidebar_show.html.haml +13 -13
  298. data/app/views/leads/_status.html.haml +7 -7
  299. data/app/views/leads/_title_bar.html.haml +3 -3
  300. data/app/views/leads/_top_section.html.haml +8 -8
  301. data/app/views/leads/convert.js.haml +4 -4
  302. data/app/views/leads/create.js.haml +3 -3
  303. data/app/views/leads/destroy.js.haml +1 -1
  304. data/app/views/leads/edit.js.haml +4 -4
  305. data/app/views/leads/index.js.haml +4 -4
  306. data/app/views/leads/index.xls.builder +3 -1
  307. data/app/views/leads/new.js.haml +1 -1
  308. data/app/views/leads/promote.js.haml +4 -4
  309. data/app/views/leads/reject.js.haml +1 -1
  310. data/app/views/leads/show.html.haml +6 -6
  311. data/app/views/leads/show.js.haml +1 -1
  312. data/app/views/leads/update.js.haml +3 -3
  313. data/app/views/lists/_lists.html.haml +2 -2
  314. data/app/views/lists/_sidebar.html.haml +8 -8
  315. data/app/views/opportunities/_edit.html.haml +7 -7
  316. data/app/views/opportunities/_index_brief.html.haml +4 -4
  317. data/app/views/opportunities/_index_long.html.haml +11 -11
  318. data/app/views/opportunities/_new.html.haml +8 -8
  319. data/app/views/opportunities/_opportunities.html.haml +2 -2
  320. data/app/views/opportunities/_opportunity.html.haml +3 -3
  321. data/app/views/opportunities/_sidebar_index.html.haml +5 -5
  322. data/app/views/opportunities/_sidebar_show.html.haml +12 -12
  323. data/app/views/opportunities/_title_bar.html.haml +2 -2
  324. data/app/views/opportunities/_top_section.html.haml +14 -14
  325. data/app/views/opportunities/contacts.js.haml +2 -2
  326. data/app/views/opportunities/create.js.haml +4 -4
  327. data/app/views/opportunities/destroy.js.haml +2 -2
  328. data/app/views/opportunities/edit.js.haml +4 -4
  329. data/app/views/opportunities/index.js.haml +4 -4
  330. data/app/views/opportunities/index.xls.builder +3 -1
  331. data/app/views/opportunities/new.js.haml +1 -1
  332. data/app/views/opportunities/show.html.haml +7 -7
  333. data/app/views/opportunities/show.js.haml +1 -1
  334. data/app/views/opportunities/update.js.haml +3 -3
  335. data/app/views/passwords/edit.html.haml +2 -2
  336. data/app/views/passwords/new.html.haml +1 -1
  337. data/app/views/shared/_address.html.haml +3 -3
  338. data/app/views/shared/_comment.html.haml +1 -1
  339. data/app/views/shared/_edit_comment.html.haml +5 -5
  340. data/app/views/shared/_empty.html.haml +1 -1
  341. data/app/views/shared/_paginate_with_per_page.html.haml +1 -1
  342. data/app/views/shared/_recent.html.haml +2 -2
  343. data/app/views/shared/_recently.html.haml +1 -1
  344. data/app/views/shared/_search.html.haml +2 -2
  345. data/app/views/shared/_tags.html.haml +2 -2
  346. data/app/views/shared/_tasks.html.haml +5 -5
  347. data/app/views/subscription_mailer/comment_notification.text.erb +2 -2
  348. data/app/views/tasks/_assigned.html.haml +4 -4
  349. data/app/views/tasks/_completed.html.haml +2 -2
  350. data/app/views/tasks/_edit.html.haml +4 -4
  351. data/app/views/tasks/_empty.html.haml +1 -1
  352. data/app/views/tasks/_new.html.haml +3 -3
  353. data/app/views/tasks/_pending.html.haml +7 -7
  354. data/app/views/tasks/_related.html.haml +2 -2
  355. data/app/views/tasks/_selector.html.haml +4 -4
  356. data/app/views/tasks/_sidebar_index.html.haml +7 -7
  357. data/app/views/tasks/_title.html.haml +2 -2
  358. data/app/views/tasks/_top_section.html.haml +9 -9
  359. data/app/views/tasks/complete.js.haml +2 -2
  360. data/app/views/tasks/create.js.haml +6 -6
  361. data/app/views/tasks/edit.js.haml +3 -3
  362. data/app/views/tasks/index.html.haml +4 -4
  363. data/app/views/tasks/index.xls.builder +5 -3
  364. data/app/views/tasks/new.js.haml +1 -1
  365. data/app/views/tasks/update.js.haml +1 -1
  366. data/app/views/users/_avatar.html.haml +5 -5
  367. data/app/views/users/_password.html.haml +3 -3
  368. data/app/views/users/_profile.html.haml +10 -10
  369. data/app/views/users/_user.html.haml +3 -3
  370. data/app/views/users/_user_report.html.haml +2 -2
  371. data/app/views/users/avatar.js.haml +1 -1
  372. data/app/views/users/change_password.js.haml +1 -1
  373. data/app/views/users/edit.js.haml +1 -1
  374. data/app/views/users/new.html.haml +2 -2
  375. data/app/views/users/opportunities_overview.html.haml +2 -2
  376. data/app/views/users/password.js.haml +1 -1
  377. data/app/views/users/show.html.haml +4 -4
  378. data/app/views/users/update.js.haml +4 -2
  379. data/app/views/users/upload_avatar.js.haml +2 -2
  380. data/app/views/versions/_version.html.haml +3 -3
  381. data/app/views/versions/_version_item.html.haml +3 -3
  382. data/app/views/versions/_versions.html.haml +2 -2
  383. data/bin/bundle +2 -0
  384. data/bin/rails +3 -1
  385. data/bin/rake +2 -0
  386. data/config.ru +3 -1
  387. data/config/application.rb +2 -0
  388. data/config/boot.rb +2 -0
  389. data/config/brakeman.ignore +139 -0
  390. data/config/deploy.example.rb +2 -0
  391. data/config/environment.rb +2 -0
  392. data/config/environments/development.rb +2 -0
  393. data/config/environments/production.rb +2 -0
  394. data/config/environments/staging.rb +2 -0
  395. data/config/environments/test.rb +2 -0
  396. data/config/initializers/action_mailer.rb +2 -0
  397. data/config/initializers/assets.rb +3 -1
  398. data/config/initializers/authlogic.rb +2 -0
  399. data/config/initializers/backtrace_silencers.rb +2 -0
  400. data/config/initializers/constants.rb +2 -0
  401. data/config/initializers/cookies_serializer.rb +2 -0
  402. data/config/initializers/custom_field_ransack_translations.rb +2 -0
  403. data/config/initializers/filter_parameter_logging.rb +2 -0
  404. data/config/initializers/gravatar.rb +2 -0
  405. data/config/initializers/inflections.rb +2 -0
  406. data/config/initializers/locale.rb +2 -0
  407. data/config/initializers/mime_types.rb +2 -0
  408. data/config/initializers/paginate_arrays.rb +2 -0
  409. data/config/initializers/paper_trail.rb +2 -0
  410. data/config/initializers/ransack.rb +2 -0
  411. data/config/initializers/relative_url_root.rb +2 -0
  412. data/config/initializers/secret_token.rb +2 -0
  413. data/config/initializers/session_store.rb +2 -0
  414. data/config/initializers/simple_form.rb +2 -0
  415. data/config/initializers/views.rb +3 -2
  416. data/config/initializers/wrap_parameters.rb +2 -0
  417. data/config/locales/fat_free_crm.de.yml +1 -0
  418. data/config/locales/fat_free_crm.en-GB.yml +7 -5
  419. data/config/locales/fat_free_crm.en-US.yml +7 -5
  420. data/config/locales/fat_free_crm.es-CL.yml +2 -1
  421. data/config/locales/fat_free_crm.es.yml +17 -16
  422. data/config/locales/fat_free_crm.fr.yml +1 -0
  423. data/config/locales/fat_free_crm.ja.yml +555 -184
  424. data/config/locales/fat_free_crm.nl.yml +2 -1
  425. data/config/locales/fat_free_crm.pt-BR.yml +1 -0
  426. data/config/locales/fat_free_crm.ru.yml +1 -0
  427. data/config/puma.rb +2 -0
  428. data/config/routes.rb +3 -1
  429. data/custom_plan.rb +2 -0
  430. data/db/demo/accounts.yml +1 -1
  431. data/db/demo/emails.yml +1 -1
  432. data/db/migrate/20100928030598_create_sessions.rb +2 -0
  433. data/db/migrate/20100928030599_create_users.rb +3 -1
  434. data/db/migrate/20100928030600_create_openid_tables.rb +3 -1
  435. data/db/migrate/20100928030601_create_accounts.rb +2 -0
  436. data/db/migrate/20100928030602_create_permissions.rb +4 -2
  437. data/db/migrate/20100928030603_create_settings.rb +2 -0
  438. data/db/migrate/20100928030604_create_preferences.rb +2 -0
  439. data/db/migrate/20100928030605_create_campaigns.rb +3 -1
  440. data/db/migrate/20100928030606_create_leads.rb +3 -1
  441. data/db/migrate/20100928030607_create_contacts.rb +3 -1
  442. data/db/migrate/20100928030608_create_opportunities.rb +3 -1
  443. data/db/migrate/20100928030609_create_account_contacts.rb +2 -0
  444. data/db/migrate/20100928030610_create_account_opportunities.rb +2 -0
  445. data/db/migrate/20100928030611_create_contact_opportunities.rb +2 -0
  446. data/db/migrate/20100928030612_create_tasks.rb +2 -0
  447. data/db/migrate/20100928030613_create_comments.rb +4 -2
  448. data/db/migrate/20100928030614_create_activities.rb +7 -5
  449. data/db/migrate/20100928030615_create_avatars.rb +5 -3
  450. data/db/migrate/20100928030616_rename_remember_token.rb +2 -0
  451. data/db/migrate/20100928030617_drop_openid_tables.rb +3 -1
  452. data/db/migrate/20100928030618_add_admin_to_users.rb +3 -1
  453. data/db/migrate/20100928030619_add_suspended_to_users.rb +2 -0
  454. data/db/migrate/20100928030620_remove_uuid.rb +2 -0
  455. data/db/migrate/20100928030621_add_email_to_accounts.rb +2 -0
  456. data/db/migrate/20100928030622_add_background_info_to_models.rb +2 -0
  457. data/db/migrate/20100928030623_create_addresses.rb +2 -0
  458. data/db/migrate/20100928030624_add_index_on_permissions.rb +2 -0
  459. data/db/migrate/20100928030625_create_emails.rb +11 -9
  460. data/db/migrate/20100928030626_add_state_to_timeline_objects.rb +2 -0
  461. data/db/migrate/20100928030627_acts_as_taggable_on_migration.rb +2 -0
  462. data/db/migrate/20101221123456_add_single_access_token_to_users.rb +2 -0
  463. data/db/migrate/20101221345678_add_rating_and_category_to_accounts.rb +2 -0
  464. data/db/migrate/20110719082054_add_skype_to_contacts_and_leads.rb +2 -0
  465. data/db/migrate/20111101083437_create_fields.rb +2 -0
  466. data/db/migrate/20111101090312_create_field_groups.rb +2 -0
  467. data/db/migrate/20111116091952_add_field_groups_tag_id.rb +2 -0
  468. data/db/migrate/20111117041311_change_fields_collection_to_text.rb +2 -0
  469. data/db/migrate/20111201030535_add_field_groups_klass_name.rb +2 -0
  470. data/db/migrate/20120121054235_create_lists.rb +2 -0
  471. data/db/migrate/20120216031616_create_versions.rb +4 -2
  472. data/db/migrate/20120216042541_is_paranoid_to_paper_trail.rb +2 -0
  473. data/db/migrate/20120220233724_add_versions_object_changes.rb +2 -0
  474. data/db/migrate/20120224073107_remove_default_value_and_clear_settings.rb +2 -0
  475. data/db/migrate/20120309070209_add_versions_related.rb +2 -0
  476. data/db/migrate/20120314080441_add_subscribed_users_to_entities.rb +2 -0
  477. data/db/migrate/20120316045804_activities_to_versions.rb +13 -12
  478. data/db/migrate/20120405080727_change_subscribed_users_to_set.rb +2 -0
  479. data/db/migrate/20120405080742_change_further_subscribed_users_to_set.rb +2 -0
  480. data/db/migrate/20120406082136_create_groups.rb +2 -0
  481. data/db/migrate/20120413034923_add_index_on_versions_item_type.rb +2 -0
  482. data/db/migrate/20120510025219_add_not_null_constraints_for_timestamp_columns.rb +5 -4
  483. data/db/migrate/20120528102124_increase_length_of_version_events.rb +2 -0
  484. data/db/migrate/20120801032706_add_pair_id_to_fields.rb +2 -0
  485. data/db/migrate/20121003063155_add_settings_to_custom_fields.rb +2 -0
  486. data/db/migrate/20121221033947_fix_country_mapping.rb +2 -0
  487. data/db/migrate/20131207033244_add_user_id_to_lists.rb +2 -0
  488. data/db/migrate/20140916011927_add_created_at_index_on_versions.rb +2 -0
  489. data/db/migrate/20140916012922_add_indexes_to_model_associations.rb +2 -0
  490. data/db/migrate/20141126031837_increase_email_to254_chars.rb +2 -0
  491. data/db/migrate/20141230021159_add_transaction_id_column_to_versions.rb +2 -0
  492. data/db/migrate/20141230205453_add_missing_unique_indices.acts_as_taggable_on_engine.rb +2 -0
  493. data/db/migrate/20141230205454_add_taggings_counter_cache_to_tags.acts_as_taggable_on_engine.rb +2 -0
  494. data/db/migrate/20141230205455_add_missing_taggable_index.acts_as_taggable_on_engine.rb +2 -0
  495. data/db/migrate/20150123060900_convert_radio_to_radio_buttons.rb +2 -0
  496. data/db/migrate/20150227123054_remove_last_request_at_from_users.rb +2 -0
  497. data/db/migrate/20150427131956_create_index_related_type.rb +2 -0
  498. data/db/migrate/20160511053730_add_account_contacts_index.rb +2 -0
  499. data/db/migrate/20180102075234_add_account_counter_caches.rb +24 -0
  500. data/db/migrate/20180103223438_add_minlength_to_field.rb +7 -0
  501. data/db/schema.rb +300 -316
  502. data/db/seeds.rb +1 -0
  503. data/db/seeds/fields.rb +2 -0
  504. data/fat_free_crm.gemspec +4 -4
  505. data/lib/development_tasks/gem.rake +2 -0
  506. data/lib/development_tasks/license.rake +2 -0
  507. data/lib/development_tasks/rdoc.rake +2 -0
  508. data/lib/development_tasks/rspec.rake +2 -0
  509. data/lib/fat_free_crm.rb +2 -0
  510. data/lib/fat_free_crm/callback.rb +2 -0
  511. data/lib/fat_free_crm/comment_extensions.rb +2 -0
  512. data/lib/fat_free_crm/core_ext.rb +2 -0
  513. data/lib/fat_free_crm/core_ext/alias_method_chain.rb +7 -6
  514. data/lib/fat_free_crm/core_ext/nil.rb +2 -0
  515. data/lib/fat_free_crm/core_ext/string.rb +4 -2
  516. data/lib/fat_free_crm/custom_fields.rb +2 -0
  517. data/lib/fat_free_crm/engine.rb +2 -0
  518. data/lib/fat_free_crm/errors.rb +2 -0
  519. data/lib/fat_free_crm/exceptions.rb +2 -0
  520. data/lib/fat_free_crm/export_csv.rb +3 -1
  521. data/lib/fat_free_crm/exportable.rb +2 -0
  522. data/lib/fat_free_crm/fields.rb +2 -0
  523. data/lib/fat_free_crm/gem_dependencies.rb +2 -0
  524. data/lib/fat_free_crm/gem_ext.rb +2 -0
  525. data/lib/fat_free_crm/gem_ext/action_controller/base.rb +2 -0
  526. data/lib/fat_free_crm/gem_ext/active_support/buffered_logger.rb +4 -2
  527. data/lib/fat_free_crm/gem_ext/rails/engine.rb +9 -8
  528. data/lib/fat_free_crm/gem_ext/rake/task.rb +2 -0
  529. data/lib/fat_free_crm/gem_ext/simple_form/action_view_extensions/form_helper.rb +2 -0
  530. data/lib/fat_free_crm/i18n.rb +2 -0
  531. data/lib/fat_free_crm/load_settings.rb +2 -0
  532. data/lib/fat_free_crm/mail_processor/base.rb +11 -8
  533. data/lib/fat_free_crm/mail_processor/comment_replies.rb +2 -0
  534. data/lib/fat_free_crm/mail_processor/dropbox.rb +5 -3
  535. data/lib/fat_free_crm/permissions.rb +8 -9
  536. data/lib/fat_free_crm/renderers.rb +2 -0
  537. data/lib/fat_free_crm/secret_token_generator.rb +2 -0
  538. data/lib/fat_free_crm/sortable.rb +2 -0
  539. data/lib/fat_free_crm/tabs.rb +2 -0
  540. data/lib/fat_free_crm/version.rb +4 -2
  541. data/lib/fat_free_crm/view_factory.rb +3 -1
  542. data/lib/gravatar_image_tag.rb +2 -0
  543. data/lib/missing_translation_detector.rb +2 -0
  544. data/lib/tasks/ffcrm/comment_replies.rake +2 -0
  545. data/lib/tasks/ffcrm/config.rake +2 -0
  546. data/lib/tasks/ffcrm/demo.rake +3 -1
  547. data/lib/tasks/ffcrm/dropbox.rake +2 -0
  548. data/lib/tasks/ffcrm/missing_translations.rake +8 -7
  549. data/lib/tasks/ffcrm/secret.rake +2 -0
  550. data/lib/tasks/ffcrm/settings.rake +2 -0
  551. data/lib/tasks/ffcrm/setup.rake +2 -0
  552. data/lib/tasks/ffcrm/update_data.rake +98 -96
  553. data/script/rails +4 -2
  554. data/spec/controllers/admin/groups_controller_spec.rb +2 -0
  555. data/spec/controllers/admin/users_controller_spec.rb +3 -1
  556. data/spec/controllers/applications_controller_spec.rb +2 -0
  557. data/spec/controllers/authentications_controller_spec.rb +2 -0
  558. data/spec/controllers/comments_controller_spec.rb +3 -1
  559. data/spec/controllers/emails_controller_spec.rb +3 -1
  560. data/spec/controllers/entities/accounts_controller_spec.rb +4 -2
  561. data/spec/controllers/entities/campaigns_controller_spec.rb +4 -2
  562. data/spec/controllers/entities/contacts_controller_spec.rb +4 -2
  563. data/spec/controllers/entities/leads_controller_spec.rb +4 -2
  564. data/spec/controllers/entities/opportunities_controller_spec.rb +4 -2
  565. data/spec/controllers/entities_controller_spec.rb +2 -0
  566. data/spec/controllers/home_controller_spec.rb +14 -10
  567. data/spec/controllers/lists_controller_spec.rb +2 -0
  568. data/spec/controllers/passwords_controller_spec.rb +2 -0
  569. data/spec/controllers/tasks_controller_spec.rb +3 -1
  570. data/spec/controllers/users_controller_spec.rb +20 -18
  571. data/spec/factories/account_factories.rb +2 -0
  572. data/spec/factories/campaign_factories.rb +2 -0
  573. data/spec/factories/contact_factories.rb +2 -0
  574. data/spec/factories/field_factories.rb +2 -0
  575. data/spec/factories/lead_factories.rb +2 -0
  576. data/spec/factories/list_factories.rb +2 -0
  577. data/spec/factories/opportunity_factories.rb +2 -0
  578. data/spec/factories/sequences.rb +4 -2
  579. data/spec/factories/setting_factories.rb +2 -0
  580. data/spec/factories/shared_factories.rb +3 -1
  581. data/spec/factories/subscription_factories.rb +2 -0
  582. data/spec/factories/tag_factories.rb +2 -0
  583. data/spec/factories/task_factories.rb +2 -0
  584. data/spec/factories/user_factories.rb +3 -1
  585. data/spec/features/acceptance_helper.rb +2 -0
  586. data/spec/features/accounts_spec.rb +5 -1
  587. data/spec/features/admin/groups_spec.rb +4 -3
  588. data/spec/features/admin/users_spec.rb +4 -3
  589. data/spec/features/campaigns_spec.rb +2 -1
  590. data/spec/features/contacts_spec.rb +3 -1
  591. data/spec/features/dashboard_spec.rb +2 -1
  592. data/spec/features/leads_spec.rb +7 -2
  593. data/spec/features/opportunities_overview_spec.rb +2 -1
  594. data/spec/features/opportunities_spec.rb +3 -2
  595. data/spec/features/support/browser.rb +2 -0
  596. data/spec/features/support/headless.rb +2 -0
  597. data/spec/features/support/helpers.rb +2 -0
  598. data/spec/features/support/maintain_sessions.rb +2 -0
  599. data/spec/features/support/paths.rb +2 -0
  600. data/spec/features/support/selector_helpers.rb +2 -6
  601. data/spec/features/tasks_spec.rb +8 -7
  602. data/spec/helpers/accounts_helper_spec.rb +2 -0
  603. data/spec/helpers/admin/field_groups_helper_spec.rb +2 -0
  604. data/spec/helpers/admin/plugins_helper_spec.rb +2 -0
  605. data/spec/helpers/admin/settings_helper_spec.rb +2 -0
  606. data/spec/helpers/admin/users_helper_spec.rb +2 -0
  607. data/spec/helpers/application_helper_spec.rb +6 -3
  608. data/spec/helpers/authentications_helper_spec.rb +2 -0
  609. data/spec/helpers/campaigns_helper_spec.rb +2 -0
  610. data/spec/helpers/comments_helper_spec.rb +2 -0
  611. data/spec/helpers/contacts_helper_spec.rb +2 -0
  612. data/spec/helpers/emails_helper_spec.rb +2 -0
  613. data/spec/helpers/fields_helper_spec.rb +2 -0
  614. data/spec/helpers/groups_helper_spec.rb +2 -0
  615. data/spec/helpers/home_helper_spec.rb +2 -0
  616. data/spec/helpers/leads_helper_spec.rb +2 -0
  617. data/spec/helpers/lists_helper_spec.rb +2 -0
  618. data/spec/helpers/opportunities_helper_spec.rb +2 -0
  619. data/spec/helpers/passwords_helper_spec.rb +2 -0
  620. data/spec/helpers/tasks_helper_spec.rb +2 -0
  621. data/spec/helpers/users_helper_spec.rb +2 -0
  622. data/spec/lib/comment_extensions_spec.rb +2 -0
  623. data/spec/lib/core_ext/string_spec.rb +2 -0
  624. data/spec/lib/errors_spec.rb +2 -0
  625. data/spec/lib/fields_spec.rb +2 -0
  626. data/spec/lib/mail_processor/base_spec.rb +2 -0
  627. data/spec/lib/mail_processor/comment_replies_spec.rb +2 -0
  628. data/spec/lib/mail_processor/dropbox_spec.rb +2 -0
  629. data/spec/lib/mail_processor/sample_emails/dropbox.rb +166 -164
  630. data/spec/lib/permissions_spec.rb +2 -0
  631. data/spec/lib/secret_token_generator_spec.rb +2 -0
  632. data/spec/lib/view_factory_spec.rb +2 -0
  633. data/spec/mailers/subscription_mailer_spec.rb +15 -16
  634. data/spec/mailers/user_mailer_spec.rb +2 -0
  635. data/spec/models/entities/account_contact_spec.rb +3 -0
  636. data/spec/models/entities/account_opportunity_spec.rb +3 -0
  637. data/spec/models/entities/account_spec.rb +3 -1
  638. data/spec/models/entities/campaign_spec.rb +3 -1
  639. data/spec/models/entities/contact_opportunity_spec.rb +2 -0
  640. data/spec/models/entities/contact_spec.rb +35 -21
  641. data/spec/models/entities/lead_spec.rb +3 -1
  642. data/spec/models/entities/opportunity_spec.rb +39 -27
  643. data/spec/models/fields/custom_field_date_pair_spec.rb +2 -0
  644. data/spec/models/fields/custom_field_pair_spec.rb +2 -0
  645. data/spec/models/fields/custom_field_spec.rb +2 -0
  646. data/spec/models/fields/field_group_spec.rb +2 -0
  647. data/spec/models/fields/field_spec.rb +8 -4
  648. data/spec/models/list_spec.rb +2 -0
  649. data/spec/models/observers/entity_observer_spec.rb +2 -0
  650. data/spec/models/polymorphic/address_spec.rb +2 -4
  651. data/spec/models/polymorphic/avatar_spec.rb +2 -0
  652. data/spec/models/polymorphic/comment_spec.rb +2 -4
  653. data/spec/models/polymorphic/email_spec.rb +2 -0
  654. data/spec/models/polymorphic/task_spec.rb +6 -4
  655. data/spec/models/polymorphic/version_spec.rb +7 -10
  656. data/spec/models/setting_spec.rb +23 -0
  657. data/spec/models/users/abilities/user_ability_spec.rb +2 -0
  658. data/spec/models/users/authentication_spec.rb +2 -0
  659. data/spec/models/users/group_spec.rb +2 -0
  660. data/spec/models/users/permission_spec.rb +2 -0
  661. data/spec/models/users/preference_spec.rb +2 -0
  662. data/spec/models/users/user_spec.rb +11 -17
  663. data/spec/routing/accounts_routing_spec.rb +2 -0
  664. data/spec/routing/admin/users_routing_spec.rb +2 -0
  665. data/spec/routing/campaigns_routing_spec.rb +2 -0
  666. data/spec/routing/comments_routing_spec.rb +2 -0
  667. data/spec/routing/contacts_routing_spec.rb +2 -0
  668. data/spec/routing/emails_routing_spec.rb +2 -0
  669. data/spec/routing/leads_routing_spec.rb +2 -0
  670. data/spec/routing/opportunities_routing_spec.rb +2 -0
  671. data/spec/routing/tasks_routing_spec.rb +2 -0
  672. data/spec/routing/users_routing_spec.rb +2 -0
  673. data/spec/shared/controllers.rb +2 -0
  674. data/spec/shared/models.rb +2 -0
  675. data/spec/spec_helper.rb +7 -5
  676. data/spec/support/assert_select.rb +2 -0
  677. data/spec/support/auth_macros.rb +5 -12
  678. data/spec/support/macros.rb +9 -7
  679. data/spec/support/mail_processor_mocks.rb +2 -0
  680. data/spec/support/uploaded_file.rb +2 -0
  681. data/spec/views/accounts/_edit.haml_spec.rb +4 -3
  682. data/spec/views/accounts/_new.haml_spec.rb +3 -1
  683. data/spec/views/accounts/create.js.haml_spec.rb +3 -1
  684. data/spec/views/accounts/destroy.js.haml_spec.rb +3 -1
  685. data/spec/views/accounts/edit.js.haml_spec.rb +3 -1
  686. data/spec/views/accounts/index.haml_spec.rb +3 -1
  687. data/spec/views/accounts/index.js.haml_spec.rb +3 -1
  688. data/spec/views/accounts/new.js.haml_spec.rb +3 -1
  689. data/spec/views/accounts/show.haml_spec.rb +6 -1
  690. data/spec/views/accounts/update.js.haml_spec.rb +3 -1
  691. data/spec/views/admin/field_groups/create.js.haml_spec.rb +3 -1
  692. data/spec/views/admin/field_groups/destroy.js.haml_spec.rb +3 -1
  693. data/spec/views/admin/field_groups/edit.js.haml_spec.rb +3 -1
  694. data/spec/views/admin/field_groups/new.js.haml_spec.rb +3 -1
  695. data/spec/views/admin/field_groups/update.js.haml_spec.rb +3 -1
  696. data/spec/views/admin/users/_create.haml_spec.rb +3 -1
  697. data/spec/views/admin/users/create.js.haml_spec.rb +3 -1
  698. data/spec/views/admin/users/destroy.js.haml_spec.rb +3 -1
  699. data/spec/views/admin/users/edit.js.haml_spec.rb +3 -1
  700. data/spec/views/admin/users/index.haml_spec.rb +3 -1
  701. data/spec/views/admin/users/index.js.haml_spec.rb +3 -1
  702. data/spec/views/admin/users/new.js.haml_spec.rb +3 -1
  703. data/spec/views/admin/users/reactivate.js.haml_spec.rb +3 -1
  704. data/spec/views/admin/users/show.haml_spec.rb +2 -0
  705. data/spec/views/admin/users/suspend.js.haml_spec.rb +3 -1
  706. data/spec/views/admin/users/update.js.haml_spec.rb +3 -1
  707. data/spec/views/application/auto_complete.haml_spec.rb +3 -1
  708. data/spec/views/authentications/new.haml_spec.rb +2 -0
  709. data/spec/views/campaigns/_edit.haml_spec.rb +3 -1
  710. data/spec/views/campaigns/_new.haml_spec.rb +3 -1
  711. data/spec/views/campaigns/create.js.haml_spec.rb +3 -1
  712. data/spec/views/campaigns/destroy.js.haml_spec.rb +3 -1
  713. data/spec/views/campaigns/edit.js.haml_spec.rb +3 -1
  714. data/spec/views/campaigns/index.haml_spec.rb +3 -1
  715. data/spec/views/campaigns/index.js.haml_spec.rb +3 -1
  716. data/spec/views/campaigns/new.js.haml_spec.rb +3 -1
  717. data/spec/views/campaigns/show.haml_spec.rb +6 -1
  718. data/spec/views/campaigns/update.js.haml_spec.rb +3 -1
  719. data/spec/views/comments/edit.js.haml_spec.rb +5 -4
  720. data/spec/views/contacts/_edit.haml_spec.rb +3 -1
  721. data/spec/views/contacts/_new.haml_spec.rb +3 -1
  722. data/spec/views/contacts/create.js.haml_spec.rb +3 -1
  723. data/spec/views/contacts/destroy.js.haml_spec.rb +3 -1
  724. data/spec/views/contacts/edit.js.haml_spec.rb +3 -1
  725. data/spec/views/contacts/index.haml_spec.rb +3 -1
  726. data/spec/views/contacts/index.js.html_spec.rb +3 -1
  727. data/spec/views/contacts/new.js.haml_spec.rb +3 -1
  728. data/spec/views/contacts/show.haml_spec.rb +6 -1
  729. data/spec/views/contacts/update.js.haml_spec.rb +3 -1
  730. data/spec/views/home/index.haml_spec.rb +3 -1
  731. data/spec/views/home/index.js.haml_spec.rb +3 -1
  732. data/spec/views/home/options.js.haml_spec.rb +4 -2
  733. data/spec/views/leads/_convert.haml_spec.rb +3 -1
  734. data/spec/views/leads/_edit.haml_spec.rb +3 -1
  735. data/spec/views/leads/_new.haml_spec.rb +3 -1
  736. data/spec/views/leads/_sidebar_show.haml_spec.rb +3 -1
  737. data/spec/views/leads/convert.js.haml_spec.rb +3 -1
  738. data/spec/views/leads/create.js.haml_spec.rb +3 -1
  739. data/spec/views/leads/destroy.js.haml_spec.rb +3 -1
  740. data/spec/views/leads/edit.js.haml_spec.rb +3 -1
  741. data/spec/views/leads/index.haml_spec.rb +3 -1
  742. data/spec/views/leads/index.js.haml_spec.rb +3 -1
  743. data/spec/views/leads/new.js.haml_spec.rb +3 -1
  744. data/spec/views/leads/promote.js.haml_spec.rb +3 -1
  745. data/spec/views/leads/reject.js.haml_spec.rb +3 -1
  746. data/spec/views/leads/show.haml_spec.rb +6 -1
  747. data/spec/views/leads/update.js.haml_spec.rb +3 -1
  748. data/spec/views/opportunities/_edit.haml_spec.rb +3 -1
  749. data/spec/views/opportunities/_new.haml_spec.rb +3 -1
  750. data/spec/views/opportunities/create.js.haml_spec.rb +3 -1
  751. data/spec/views/opportunities/destroy.js.haml_spec.rb +3 -1
  752. data/spec/views/opportunities/edit.js.haml_spec.rb +3 -1
  753. data/spec/views/opportunities/index.haml_spec.rb +3 -1
  754. data/spec/views/opportunities/index.js.haml_spec.rb +3 -1
  755. data/spec/views/opportunities/new.js.haml_spec.rb +3 -1
  756. data/spec/views/opportunities/show.haml_spec.rb +6 -1
  757. data/spec/views/opportunities/update.js.haml_spec.rb +3 -1
  758. data/spec/views/tasks/_edit.haml_spec.rb +3 -1
  759. data/spec/views/tasks/complete.js.haml_spec.rb +3 -1
  760. data/spec/views/tasks/create.js.haml_spec.rb +3 -1
  761. data/spec/views/tasks/destroy.js.haml_spec.rb +3 -1
  762. data/spec/views/tasks/edit.js.haml_spec.rb +3 -1
  763. data/spec/views/tasks/index.haml_spec.rb +6 -4
  764. data/spec/views/tasks/new.js.haml_spec.rb +3 -1
  765. data/spec/views/tasks/uncomplete.js.haml_spec.rb +3 -1
  766. data/spec/views/tasks/update.js.haml_spec.rb +3 -1
  767. data/spec/views/users/avatar.js.haml_spec.rb +3 -1
  768. data/spec/views/users/change_password.js.haml_spec.rb +3 -1
  769. data/spec/views/users/edit.js.haml_spec.rb +3 -1
  770. data/spec/views/users/password.js.haml_spec.rb +3 -1
  771. data/spec/views/users/update.js.haml_spec.rb +3 -1
  772. data/spec/views/users/upload_avatar.js.haml_spec.rb +4 -2
  773. data/vendor/assets/javascripts/textarea_autocomplete.js +1 -1
  774. data/vendor/gems/globby-0.1.2/lib/globby/glob.rb +1 -1
  775. metadata +8 -12
  776. data/app/assets/javascripts/crm_chosen.js.coffee +0 -29
  777. data/app/assets/stylesheets/ffcrm_chosen.scss +0 -69
  778. data/vendor/assets/javascripts/ajax-chosen-jquery.js +0 -2
  779. data/vendor/assets/javascripts/ajax-chosen.jquery.coffee +0 -171
  780. data/vendor/assets/javascripts/chosen-jquery.js +0 -3
  781. data/vendor/assets/javascripts/chosen.jquery.coffee +0 -574
  782. data/vendor/assets/javascripts/lib/abstract-chosen.coffee +0 -110
  783. data/vendor/assets/stylesheets/chosen.css.sass +0 -361
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class ChangeFieldsCollectionToText < ActiveRecord::Migration[4.2]
2
4
  def self.up
3
5
  change_column :fields, :collection, :text
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class AddFieldGroupsKlassName < ActiveRecord::Migration[4.2]
2
4
  def up
3
5
  add_column :field_groups, :klass_name, :string, limit: 32
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class CreateLists < ActiveRecord::Migration[4.2]
2
4
  def change
3
5
  create_table :lists do |t|
@@ -1,9 +1,11 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class CreateVersions < ActiveRecord::Migration[4.2]
2
4
  def self.up
3
5
  create_table :versions do |t|
4
6
  t.string :item_type, null: false
5
- t.integer :item_id, null: false
6
- t.string :event, null: false
7
+ t.integer :item_id, null: false
8
+ t.string :event, null: false
7
9
  t.string :whodunnit
8
10
  t.text :object
9
11
  t.datetime :created_at
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class IsParanoidToPaperTrail < ActiveRecord::Migration[4.2]
2
4
  def up
3
5
  [Account, Campaign, Contact, Lead, Opportunity, Task].each do |klass|
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class AddVersionsObjectChanges < ActiveRecord::Migration[4.2]
2
4
  def up
3
5
  add_column :versions, :object_changes, :text
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class RemoveDefaultValueAndClearSettings < ActiveRecord::Migration[4.2]
2
4
  def up
3
5
  remove_column :settings, :default_value
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class AddVersionsRelated < ActiveRecord::Migration[4.2]
2
4
  def change
3
5
  add_column :versions, :related_id, :integer
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class AddSubscribedUsersToEntities < ActiveRecord::Migration[4.2]
2
4
  def change
3
5
  %w[accounts campaigns contacts leads opportunities tasks].each do |table|
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class ActivitiesToVersions < ActiveRecord::Migration[4.2]
2
4
  def up
3
5
  events = {
@@ -15,18 +17,17 @@ class ActivitiesToVersions < ActiveRecord::Migration[4.2]
15
17
  activities = connection.select_all 'SELECT * FROM activities'
16
18
  activities.each do |activity|
17
19
  # commented and email activities don't translate well so ignore them
18
- if event = events[activity['action']]
19
- attributes = {
20
- item_id: activity['subject_id'],
21
- item_type: activity['subject_type'],
22
- whodunnit: activity['user_id'],
23
- event: event,
24
- created_at: activity['created_at']
25
- }
26
- version = Version.new
27
- attributes.each { |k, v| version.send("#{k}=", v) }
28
- version.save!
29
- end
20
+ next unless event = events[activity['action']]
21
+ attributes = {
22
+ item_id: activity['subject_id'],
23
+ item_type: activity['subject_type'],
24
+ whodunnit: activity['user_id'],
25
+ event: event,
26
+ created_at: activity['created_at']
27
+ }
28
+ version = Version.new
29
+ attributes.each { |k, v| version.send("#{k}=", v) }
30
+ version.save!
30
31
  end
31
32
  end
32
33
 
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class ChangeSubscribedUsersToSet < ActiveRecord::Migration[4.2]
2
4
  def up
3
5
  contacts = connection.select_all %(
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class ChangeFurtherSubscribedUsersToSet < ActiveRecord::Migration[4.2]
2
4
  def up
3
5
  # Change the other tables that were missing from the previous migration
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class CreateGroups < ActiveRecord::Migration[4.2]
2
4
  def change
3
5
  create_table :groups do |t|
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class AddIndexOnVersionsItemType < ActiveRecord::Migration[4.2]
2
4
  def change
3
5
  add_index :versions, :whodunnit
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class AddNotNullConstraintsForTimestampColumns < ActiveRecord::Migration[4.2]
2
4
  def up
3
5
  set_timestamp_constraints null: false unless $FFCRM_NEW_DATABASE
@@ -12,10 +14,9 @@ class AddNotNullConstraintsForTimestampColumns < ActiveRecord::Migration[4.2]
12
14
  def set_timestamp_constraints(constraints)
13
15
  ActiveRecord::Base.connection.tables.each do |table|
14
16
  # If table has both timestamp columns, set not null constraints on both columns.
15
- if %i[created_at updated_at].all? { |column| column_exists?(table, column) }
16
- %i[created_at updated_at].each do |column|
17
- change_column table, column, :datetime, constraints
18
- end
17
+ next unless %i[created_at updated_at].all? { |column| column_exists?(table, column) }
18
+ %i[created_at updated_at].each do |column|
19
+ change_column table, column, :datetime, constraints
19
20
  end
20
21
  end
21
22
  end
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class IncreaseLengthOfVersionEvents < ActiveRecord::Migration[4.2]
2
4
  def up
3
5
  change_column :versions, :event, :string, limit: 512
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class AddPairIdToFields < ActiveRecord::Migration[4.2]
2
4
  def change
3
5
  add_column :fields, :pair_id, :integer
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class AddSettingsToCustomFields < ActiveRecord::Migration[4.2]
2
4
  def change
3
5
  add_column :fields, :settings, :text, default: nil
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class FixCountryMapping < ActiveRecord::Migration[4.2]
2
4
  def up
3
5
  message = """ Important note about countries. Please read carefully!
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class AddUserIdToLists < ActiveRecord::Migration[4.2]
2
4
  def change
3
5
  add_column :lists, :user_id, :integer, default: nil
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class AddCreatedAtIndexOnVersions < ActiveRecord::Migration[4.2]
2
4
  def change
3
5
  add_index :versions, :created_at
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class AddIndexesToModelAssociations < ActiveRecord::Migration[4.2]
2
4
  def change
3
5
  add_index :contact_opportunities, %i[contact_id opportunity_id]
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class IncreaseEmailTo254Chars < ActiveRecord::Migration[4.2]
2
4
  def up
3
5
  change_column :accounts, :email, :string, limit: 254
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class AddTransactionIdColumnToVersions < ActiveRecord::Migration[4.2]
2
4
  def self.up
3
5
  add_column :versions, :transaction_id, :integer
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  # This migration comes from acts_as_taggable_on_engine (originally 2)
2
4
  class AddMissingUniqueIndices < ActiveRecord::Migration[4.2]
3
5
  def self.up
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  # This migration comes from acts_as_taggable_on_engine (originally 3)
2
4
  class AddTaggingsCounterCacheToTags < ActiveRecord::Migration[4.2]
3
5
  def self.up
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  # This migration comes from acts_as_taggable_on_engine (originally 4)
2
4
  class AddMissingTaggableIndex < ActiveRecord::Migration[4.2]
3
5
  def self.up
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class ConvertRadioToRadioButtons < ActiveRecord::Migration[4.2]
2
4
  def up
3
5
  # UPDATE "fields" SET "as" = 'radio_buttons' WHERE "fields"."as" = $1 [["as", "radio"]]
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class RemoveLastRequestAtFromUsers < ActiveRecord::Migration[4.2]
2
4
  def change
3
5
  remove_column :users, :last_request_at
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class CreateIndexRelatedType < ActiveRecord::Migration[4.2]
2
4
  def up
3
5
  add_index :versions, %i[related_id related_type]
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  class AddAccountContactsIndex < ActiveRecord::Migration[4.2]
2
4
  def change
3
5
  add_index :account_contacts, %i[account_id contact_id]
@@ -0,0 +1,24 @@
1
+ # frozen_string_literal: true
2
+
3
+ class AddAccountCounterCaches < ActiveRecord::Migration[5.1]
4
+ def change
5
+ change_table :accounts do |t|
6
+ t.integer :contacts_count, default: 0
7
+ t.integer :opportunities_count, default: 0
8
+ end
9
+
10
+ reversible do |dir|
11
+ dir.up { data }
12
+ end
13
+ end
14
+
15
+ def data
16
+ Account.all.each do |account|
17
+ Account.update_counters(
18
+ account.id,
19
+ contacts_count: account.contacts.count,
20
+ opportunities_count: account.opportunities.count
21
+ )
22
+ end
23
+ end
24
+ end
@@ -0,0 +1,7 @@
1
+ # frozen_string_literal: true
2
+
3
+ class AddMinlengthToField < ActiveRecord::Migration[5.1]
4
+ def change
5
+ add_column :fields, :minlength, :integer, limit: 4, default: 0
6
+ end
7
+ end
@@ -1,4 +1,4 @@
1
- # encoding: UTF-8
1
+ # frozen_string_literal: true
2
2
 
3
3
  # This file is auto-generated from the current state of the database. Instead
4
4
  # of editing this file, please use the migrations feature of Active Record to
@@ -12,234 +12,229 @@
12
12
  #
13
13
  # It's strongly recommended that you check this file into your version control system.
14
14
 
15
- ActiveRecord::Schema.define(version: 20160511053730) do
15
+ ActiveRecord::Schema.define(version: 20180103223438) do
16
+
16
17
  # These are extensions that must be enabled in order to support this database
17
18
  enable_extension "plpgsql"
18
19
 
19
- create_table "account_contacts", force: :cascade do |t|
20
- t.integer "account_id"
21
- t.integer "contact_id"
20
+ create_table "account_contacts", id: :serial, force: :cascade do |t|
21
+ t.integer "account_id"
22
+ t.integer "contact_id"
22
23
  t.datetime "deleted_at"
23
24
  t.datetime "created_at"
24
25
  t.datetime "updated_at"
26
+ t.index ["account_id", "contact_id"], name: "index_account_contacts_on_account_id_and_contact_id"
25
27
  end
26
28
 
27
- add_index "account_contacts", ["account_id", "contact_id"], name: "index_account_contacts_on_account_id_and_contact_id", using: :btree
28
-
29
- create_table "account_opportunities", force: :cascade do |t|
30
- t.integer "account_id"
31
- t.integer "opportunity_id"
29
+ create_table "account_opportunities", id: :serial, force: :cascade do |t|
30
+ t.integer "account_id"
31
+ t.integer "opportunity_id"
32
32
  t.datetime "deleted_at"
33
33
  t.datetime "created_at"
34
34
  t.datetime "updated_at"
35
+ t.index ["account_id", "opportunity_id"], name: "index_account_opportunities_on_account_id_and_opportunity_id"
35
36
  end
36
37
 
37
- add_index "account_opportunities", ["account_id", "opportunity_id"], name: "index_account_opportunities_on_account_id_and_opportunity_id", using: :btree
38
-
39
- create_table "accounts", force: :cascade do |t|
40
- t.integer "user_id"
41
- t.integer "assigned_to"
42
- t.string "name", limit: 64, default: "", null: false
43
- t.string "access", limit: 8, default: "Public"
44
- t.string "website", limit: 64
45
- t.string "toll_free_phone", limit: 32
46
- t.string "phone", limit: 32
47
- t.string "fax", limit: 32
38
+ create_table "accounts", id: :serial, force: :cascade do |t|
39
+ t.integer "user_id"
40
+ t.integer "assigned_to"
41
+ t.string "name", limit: 64, default: "", null: false
42
+ t.string "access", limit: 8, default: "Public"
43
+ t.string "website", limit: 64
44
+ t.string "toll_free_phone", limit: 32
45
+ t.string "phone", limit: 32
46
+ t.string "fax", limit: 32
48
47
  t.datetime "deleted_at"
49
48
  t.datetime "created_at"
50
49
  t.datetime "updated_at"
51
- t.string "email", limit: 254
52
- t.string "background_info"
53
- t.integer "rating", default: 0, null: false
54
- t.string "category", limit: 32
55
- t.text "subscribed_users"
50
+ t.string "email", limit: 254
51
+ t.string "background_info"
52
+ t.integer "rating", default: 0, null: false
53
+ t.string "category", limit: 32
54
+ t.text "subscribed_users"
55
+ t.integer "contacts_count", default: 0
56
+ t.integer "opportunities_count", default: 0
57
+ t.integer "pipeline_opportunities_count", default: 0
58
+ t.index ["assigned_to"], name: "index_accounts_on_assigned_to"
59
+ t.index ["user_id", "name", "deleted_at"], name: "index_accounts_on_user_id_and_name_and_deleted_at", unique: true
56
60
  end
57
61
 
58
- add_index "accounts", ["assigned_to"], name: "index_accounts_on_assigned_to", using: :btree
59
- add_index "accounts", ["user_id", "name", "deleted_at"], name: "index_accounts_on_user_id_and_name_and_deleted_at", unique: true, using: :btree
60
-
61
- create_table "activities", force: :cascade do |t|
62
- t.integer "user_id"
63
- t.integer "subject_id"
64
- t.string "subject_type"
65
- t.string "action", limit: 32, default: "created"
66
- t.string "info", default: ""
67
- t.boolean "private", default: false
62
+ create_table "activities", id: :serial, force: :cascade do |t|
63
+ t.integer "user_id"
64
+ t.string "subject_type"
65
+ t.integer "subject_id"
66
+ t.string "action", limit: 32, default: "created"
67
+ t.string "info", default: ""
68
+ t.boolean "private", default: false
68
69
  t.datetime "created_at"
69
70
  t.datetime "updated_at"
71
+ t.index ["created_at"], name: "index_activities_on_created_at"
72
+ t.index ["user_id"], name: "index_activities_on_user_id"
70
73
  end
71
74
 
72
- add_index "activities", ["created_at"], name: "index_activities_on_created_at", using: :btree
73
- add_index "activities", ["user_id"], name: "index_activities_on_user_id", using: :btree
74
-
75
- create_table "addresses", force: :cascade do |t|
76
- t.string "street1"
77
- t.string "street2"
78
- t.string "city", limit: 64
79
- t.string "state", limit: 64
80
- t.string "zipcode", limit: 16
81
- t.string "country", limit: 64
82
- t.string "full_address"
83
- t.string "address_type", limit: 16
84
- t.integer "addressable_id"
85
- t.string "addressable_type"
75
+ create_table "addresses", id: :serial, force: :cascade do |t|
76
+ t.string "street1"
77
+ t.string "street2"
78
+ t.string "city", limit: 64
79
+ t.string "state", limit: 64
80
+ t.string "zipcode", limit: 16
81
+ t.string "country", limit: 64
82
+ t.string "full_address"
83
+ t.string "address_type", limit: 16
84
+ t.string "addressable_type"
85
+ t.integer "addressable_id"
86
86
  t.datetime "created_at"
87
87
  t.datetime "updated_at"
88
88
  t.datetime "deleted_at"
89
+ t.index ["addressable_id", "addressable_type"], name: "index_addresses_on_addressable_id_and_addressable_type"
89
90
  end
90
91
 
91
- add_index "addresses", ["addressable_id", "addressable_type"], name: "index_addresses_on_addressable_id_and_addressable_type", using: :btree
92
-
93
- create_table "avatars", force: :cascade do |t|
94
- t.integer "user_id"
95
- t.integer "entity_id"
96
- t.string "entity_type"
97
- t.integer "image_file_size"
98
- t.string "image_file_name"
99
- t.string "image_content_type"
92
+ create_table "avatars", id: :serial, force: :cascade do |t|
93
+ t.integer "user_id"
94
+ t.string "entity_type"
95
+ t.integer "entity_id"
96
+ t.integer "image_file_size"
97
+ t.string "image_file_name"
98
+ t.string "image_content_type"
100
99
  t.datetime "created_at"
101
100
  t.datetime "updated_at"
102
101
  end
103
102
 
104
- create_table "campaigns", force: :cascade do |t|
105
- t.integer "user_id"
106
- t.integer "assigned_to"
107
- t.string "name", limit: 64, default: "", null: false
108
- t.string "access", limit: 8, default: "Public"
109
- t.string "status", limit: 64
110
- t.decimal "budget", precision: 12, scale: 2
111
- t.integer "target_leads"
112
- t.float "target_conversion"
113
- t.decimal "target_revenue", precision: 12, scale: 2
114
- t.integer "leads_count"
115
- t.integer "opportunities_count"
116
- t.decimal "revenue", precision: 12, scale: 2
117
- t.date "starts_on"
118
- t.date "ends_on"
119
- t.text "objectives"
103
+ create_table "campaigns", id: :serial, force: :cascade do |t|
104
+ t.integer "user_id"
105
+ t.integer "assigned_to"
106
+ t.string "name", limit: 64, default: "", null: false
107
+ t.string "access", limit: 8, default: "Public"
108
+ t.string "status", limit: 64
109
+ t.decimal "budget", precision: 12, scale: 2
110
+ t.integer "target_leads"
111
+ t.float "target_conversion"
112
+ t.decimal "target_revenue", precision: 12, scale: 2
113
+ t.integer "leads_count"
114
+ t.integer "opportunities_count"
115
+ t.decimal "revenue", precision: 12, scale: 2
116
+ t.date "starts_on"
117
+ t.date "ends_on"
118
+ t.text "objectives"
120
119
  t.datetime "deleted_at"
121
120
  t.datetime "created_at"
122
121
  t.datetime "updated_at"
123
- t.string "background_info"
124
- t.text "subscribed_users"
122
+ t.string "background_info"
123
+ t.text "subscribed_users"
124
+ t.index ["assigned_to"], name: "index_campaigns_on_assigned_to"
125
+ t.index ["user_id", "name", "deleted_at"], name: "index_campaigns_on_user_id_and_name_and_deleted_at", unique: true
125
126
  end
126
127
 
127
- add_index "campaigns", ["assigned_to"], name: "index_campaigns_on_assigned_to", using: :btree
128
- add_index "campaigns", ["user_id", "name", "deleted_at"], name: "index_campaigns_on_user_id_and_name_and_deleted_at", unique: true, using: :btree
129
-
130
- create_table "comments", force: :cascade do |t|
131
- t.integer "user_id"
132
- t.integer "commentable_id"
133
- t.string "commentable_type"
134
- t.boolean "private"
135
- t.string "title", default: ""
136
- t.text "comment"
128
+ create_table "comments", id: :serial, force: :cascade do |t|
129
+ t.integer "user_id"
130
+ t.string "commentable_type"
131
+ t.integer "commentable_id"
132
+ t.boolean "private"
133
+ t.string "title", default: ""
134
+ t.text "comment"
137
135
  t.datetime "created_at"
138
136
  t.datetime "updated_at"
139
- t.string "state", limit: 16, default: "Expanded", null: false
137
+ t.string "state", limit: 16, default: "Expanded", null: false
140
138
  end
141
139
 
142
- create_table "contact_opportunities", force: :cascade do |t|
143
- t.integer "contact_id"
144
- t.integer "opportunity_id"
145
- t.string "role", limit: 32
140
+ create_table "contact_opportunities", id: :serial, force: :cascade do |t|
141
+ t.integer "contact_id"
142
+ t.integer "opportunity_id"
143
+ t.string "role", limit: 32
146
144
  t.datetime "deleted_at"
147
145
  t.datetime "created_at"
148
146
  t.datetime "updated_at"
147
+ t.index ["contact_id", "opportunity_id"], name: "index_contact_opportunities_on_contact_id_and_opportunity_id"
149
148
  end
150
149
 
151
- add_index "contact_opportunities", ["contact_id", "opportunity_id"], name: "index_contact_opportunities_on_contact_id_and_opportunity_id", using: :btree
152
-
153
- create_table "contacts", force: :cascade do |t|
154
- t.integer "user_id"
155
- t.integer "lead_id"
156
- t.integer "assigned_to"
157
- t.integer "reports_to"
158
- t.string "first_name", limit: 64, default: "", null: false
159
- t.string "last_name", limit: 64, default: "", null: false
160
- t.string "access", limit: 8, default: "Public"
161
- t.string "title", limit: 64
162
- t.string "department", limit: 64
163
- t.string "source", limit: 32
164
- t.string "email", limit: 254
165
- t.string "alt_email", limit: 254
166
- t.string "phone", limit: 32
167
- t.string "mobile", limit: 32
168
- t.string "fax", limit: 32
169
- t.string "blog", limit: 128
170
- t.string "linkedin", limit: 128
171
- t.string "facebook", limit: 128
172
- t.string "twitter", limit: 128
173
- t.date "born_on"
174
- t.boolean "do_not_call", default: false, null: false
150
+ create_table "contacts", id: :serial, force: :cascade do |t|
151
+ t.integer "user_id"
152
+ t.integer "lead_id"
153
+ t.integer "assigned_to"
154
+ t.integer "reports_to"
155
+ t.string "first_name", limit: 64, default: "", null: false
156
+ t.string "last_name", limit: 64, default: "", null: false
157
+ t.string "access", limit: 8, default: "Public"
158
+ t.string "title", limit: 64
159
+ t.string "department", limit: 64
160
+ t.string "source", limit: 32
161
+ t.string "email", limit: 254
162
+ t.string "alt_email", limit: 254
163
+ t.string "phone", limit: 32
164
+ t.string "mobile", limit: 32
165
+ t.string "fax", limit: 32
166
+ t.string "blog", limit: 128
167
+ t.string "linkedin", limit: 128
168
+ t.string "facebook", limit: 128
169
+ t.string "twitter", limit: 128
170
+ t.date "born_on"
171
+ t.boolean "do_not_call", default: false, null: false
175
172
  t.datetime "deleted_at"
176
173
  t.datetime "created_at"
177
174
  t.datetime "updated_at"
178
- t.string "background_info"
179
- t.string "skype", limit: 128
180
- t.text "subscribed_users"
175
+ t.string "background_info"
176
+ t.string "skype", limit: 128
177
+ t.text "subscribed_users"
178
+ t.index ["assigned_to"], name: "index_contacts_on_assigned_to"
179
+ t.index ["user_id", "last_name", "deleted_at"], name: "id_last_name_deleted", unique: true
181
180
  end
182
181
 
183
- add_index "contacts", ["assigned_to"], name: "index_contacts_on_assigned_to", using: :btree
184
- add_index "contacts", ["user_id", "last_name", "deleted_at"], name: "id_last_name_deleted", unique: true, using: :btree
185
-
186
- create_table "emails", force: :cascade do |t|
187
- t.string "imap_message_id", null: false
188
- t.integer "user_id"
189
- t.integer "mediator_id"
190
- t.string "mediator_type"
191
- t.string "sent_from", null: false
192
- t.string "sent_to", null: false
193
- t.string "cc"
194
- t.string "bcc"
195
- t.string "subject"
196
- t.text "body"
197
- t.text "header"
182
+ create_table "emails", id: :serial, force: :cascade do |t|
183
+ t.string "imap_message_id", null: false
184
+ t.integer "user_id"
185
+ t.string "mediator_type"
186
+ t.integer "mediator_id"
187
+ t.string "sent_from", null: false
188
+ t.string "sent_to", null: false
189
+ t.string "cc"
190
+ t.string "bcc"
191
+ t.string "subject"
192
+ t.text "body"
193
+ t.text "header"
198
194
  t.datetime "sent_at"
199
195
  t.datetime "received_at"
200
196
  t.datetime "deleted_at"
201
197
  t.datetime "created_at"
202
198
  t.datetime "updated_at"
203
- t.string "state", limit: 16, default: "Expanded", null: false
199
+ t.string "state", limit: 16, default: "Expanded", null: false
200
+ t.index ["mediator_id", "mediator_type"], name: "index_emails_on_mediator_id_and_mediator_type"
204
201
  end
205
202
 
206
- add_index "emails", ["mediator_id", "mediator_type"], name: "index_emails_on_mediator_id_and_mediator_type", using: :btree
207
-
208
- create_table "field_groups", force: :cascade do |t|
209
- t.string "name", limit: 64
210
- t.string "label", limit: 128
211
- t.integer "position"
212
- t.string "hint"
203
+ create_table "field_groups", id: :serial, force: :cascade do |t|
204
+ t.string "name", limit: 64
205
+ t.string "label", limit: 128
206
+ t.integer "position"
207
+ t.string "hint"
213
208
  t.datetime "created_at"
214
209
  t.datetime "updated_at"
215
- t.integer "tag_id"
216
- t.string "klass_name", limit: 32
210
+ t.integer "tag_id"
211
+ t.string "klass_name", limit: 32
217
212
  end
218
213
 
219
- create_table "fields", force: :cascade do |t|
220
- t.string "type"
221
- t.integer "field_group_id"
222
- t.integer "position"
223
- t.string "name", limit: 64
224
- t.string "label", limit: 128
225
- t.string "hint"
226
- t.string "placeholder"
227
- t.string "as", limit: 32
228
- t.text "collection"
229
- t.boolean "disabled"
230
- t.boolean "required"
231
- t.integer "maxlength"
214
+ create_table "fields", id: :serial, force: :cascade do |t|
215
+ t.string "type"
216
+ t.integer "field_group_id"
217
+ t.integer "position"
218
+ t.string "name", limit: 64
219
+ t.string "label", limit: 128
220
+ t.string "hint"
221
+ t.string "placeholder"
222
+ t.string "as", limit: 32
223
+ t.text "collection"
224
+ t.boolean "disabled"
225
+ t.boolean "required"
226
+ t.integer "maxlength"
232
227
  t.datetime "created_at"
233
228
  t.datetime "updated_at"
234
- t.integer "pair_id"
235
- t.text "settings"
229
+ t.integer "pair_id"
230
+ t.text "settings"
231
+ t.integer "minlength", default: 0
232
+ t.index ["field_group_id"], name: "index_fields_on_field_group_id"
233
+ t.index ["name"], name: "index_fields_on_name"
236
234
  end
237
235
 
238
- add_index "fields", ["field_group_id"], name: "index_fields_on_field_group_id", using: :btree
239
- add_index "fields", ["name"], name: "index_fields_on_name", using: :btree
240
-
241
- create_table "groups", force: :cascade do |t|
242
- t.string "name"
236
+ create_table "groups", id: :serial, force: :cascade do |t|
237
+ t.string "name"
243
238
  t.datetime "created_at"
244
239
  t.datetime "updated_at"
245
240
  end
@@ -247,212 +242,201 @@ ActiveRecord::Schema.define(version: 20160511053730) do
247
242
  create_table "groups_users", id: false, force: :cascade do |t|
248
243
  t.integer "group_id"
249
244
  t.integer "user_id"
245
+ t.index ["group_id", "user_id"], name: "index_groups_users_on_group_id_and_user_id"
246
+ t.index ["group_id"], name: "index_groups_users_on_group_id"
247
+ t.index ["user_id"], name: "index_groups_users_on_user_id"
250
248
  end
251
249
 
252
- add_index "groups_users", ["group_id", "user_id"], name: "index_groups_users_on_group_id_and_user_id", using: :btree
253
- add_index "groups_users", ["group_id"], name: "index_groups_users_on_group_id", using: :btree
254
- add_index "groups_users", ["user_id"], name: "index_groups_users_on_user_id", using: :btree
255
-
256
- create_table "leads", force: :cascade do |t|
257
- t.integer "user_id"
258
- t.integer "campaign_id"
259
- t.integer "assigned_to"
260
- t.string "first_name", limit: 64, default: "", null: false
261
- t.string "last_name", limit: 64, default: "", null: false
262
- t.string "access", limit: 8, default: "Public"
263
- t.string "title", limit: 64
264
- t.string "company", limit: 64
265
- t.string "source", limit: 32
266
- t.string "status", limit: 32
267
- t.string "referred_by", limit: 64
268
- t.string "email", limit: 254
269
- t.string "alt_email", limit: 254
270
- t.string "phone", limit: 32
271
- t.string "mobile", limit: 32
272
- t.string "blog", limit: 128
273
- t.string "linkedin", limit: 128
274
- t.string "facebook", limit: 128
275
- t.string "twitter", limit: 128
276
- t.integer "rating", default: 0, null: false
277
- t.boolean "do_not_call", default: false, null: false
250
+ create_table "leads", id: :serial, force: :cascade do |t|
251
+ t.integer "user_id"
252
+ t.integer "campaign_id"
253
+ t.integer "assigned_to"
254
+ t.string "first_name", limit: 64, default: "", null: false
255
+ t.string "last_name", limit: 64, default: "", null: false
256
+ t.string "access", limit: 8, default: "Public"
257
+ t.string "title", limit: 64
258
+ t.string "company", limit: 64
259
+ t.string "source", limit: 32
260
+ t.string "status", limit: 32
261
+ t.string "referred_by", limit: 64
262
+ t.string "email", limit: 254
263
+ t.string "alt_email", limit: 254
264
+ t.string "phone", limit: 32
265
+ t.string "mobile", limit: 32
266
+ t.string "blog", limit: 128
267
+ t.string "linkedin", limit: 128
268
+ t.string "facebook", limit: 128
269
+ t.string "twitter", limit: 128
270
+ t.integer "rating", default: 0, null: false
271
+ t.boolean "do_not_call", default: false, null: false
278
272
  t.datetime "deleted_at"
279
273
  t.datetime "created_at"
280
274
  t.datetime "updated_at"
281
- t.string "background_info"
282
- t.string "skype", limit: 128
283
- t.text "subscribed_users"
275
+ t.string "background_info"
276
+ t.string "skype", limit: 128
277
+ t.text "subscribed_users"
278
+ t.index ["assigned_to"], name: "index_leads_on_assigned_to"
279
+ t.index ["user_id", "last_name", "deleted_at"], name: "index_leads_on_user_id_and_last_name_and_deleted_at", unique: true
284
280
  end
285
281
 
286
- add_index "leads", ["assigned_to"], name: "index_leads_on_assigned_to", using: :btree
287
- add_index "leads", ["user_id", "last_name", "deleted_at"], name: "index_leads_on_user_id_and_last_name_and_deleted_at", unique: true, using: :btree
288
-
289
- create_table "lists", force: :cascade do |t|
290
- t.string "name"
291
- t.text "url"
282
+ create_table "lists", id: :serial, force: :cascade do |t|
283
+ t.string "name"
284
+ t.text "url"
292
285
  t.datetime "created_at"
293
286
  t.datetime "updated_at"
294
- t.integer "user_id"
287
+ t.integer "user_id"
288
+ t.index ["user_id"], name: "index_lists_on_user_id"
295
289
  end
296
290
 
297
- add_index "lists", ["user_id"], name: "index_lists_on_user_id", using: :btree
298
-
299
- create_table "opportunities", force: :cascade do |t|
300
- t.integer "user_id"
301
- t.integer "campaign_id"
302
- t.integer "assigned_to"
303
- t.string "name", limit: 64, default: "", null: false
304
- t.string "access", limit: 8, default: "Public"
305
- t.string "source", limit: 32
306
- t.string "stage", limit: 32
307
- t.integer "probability"
308
- t.decimal "amount", precision: 12, scale: 2
309
- t.decimal "discount", precision: 12, scale: 2
310
- t.date "closes_on"
291
+ create_table "opportunities", id: :serial, force: :cascade do |t|
292
+ t.integer "user_id"
293
+ t.integer "campaign_id"
294
+ t.integer "assigned_to"
295
+ t.string "name", limit: 64, default: "", null: false
296
+ t.string "access", limit: 8, default: "Public"
297
+ t.string "source", limit: 32
298
+ t.string "stage", limit: 32
299
+ t.integer "probability"
300
+ t.decimal "amount", precision: 12, scale: 2
301
+ t.decimal "discount", precision: 12, scale: 2
302
+ t.date "closes_on"
311
303
  t.datetime "deleted_at"
312
304
  t.datetime "created_at"
313
305
  t.datetime "updated_at"
314
- t.string "background_info"
315
- t.text "subscribed_users"
306
+ t.string "background_info"
307
+ t.text "subscribed_users"
308
+ t.index ["assigned_to"], name: "index_opportunities_on_assigned_to"
309
+ t.index ["user_id", "name", "deleted_at"], name: "id_name_deleted", unique: true
316
310
  end
317
311
 
318
- add_index "opportunities", ["assigned_to"], name: "index_opportunities_on_assigned_to", using: :btree
319
- add_index "opportunities", ["user_id", "name", "deleted_at"], name: "id_name_deleted", unique: true, using: :btree
320
-
321
- create_table "permissions", force: :cascade do |t|
322
- t.integer "user_id"
323
- t.integer "asset_id"
324
- t.string "asset_type"
312
+ create_table "permissions", id: :serial, force: :cascade do |t|
313
+ t.integer "user_id"
314
+ t.string "asset_type"
315
+ t.integer "asset_id"
325
316
  t.datetime "created_at"
326
317
  t.datetime "updated_at"
327
- t.integer "group_id"
318
+ t.integer "group_id"
319
+ t.index ["asset_id", "asset_type"], name: "index_permissions_on_asset_id_and_asset_type"
320
+ t.index ["group_id"], name: "index_permissions_on_group_id"
321
+ t.index ["user_id"], name: "index_permissions_on_user_id"
328
322
  end
329
323
 
330
- add_index "permissions", ["asset_id", "asset_type"], name: "index_permissions_on_asset_id_and_asset_type", using: :btree
331
- add_index "permissions", ["group_id"], name: "index_permissions_on_group_id", using: :btree
332
- add_index "permissions", ["user_id"], name: "index_permissions_on_user_id", using: :btree
333
-
334
- create_table "preferences", force: :cascade do |t|
335
- t.integer "user_id"
336
- t.string "name", limit: 32, default: "", null: false
337
- t.text "value"
324
+ create_table "preferences", id: :serial, force: :cascade do |t|
325
+ t.integer "user_id"
326
+ t.string "name", limit: 32, default: "", null: false
327
+ t.text "value"
338
328
  t.datetime "created_at"
339
329
  t.datetime "updated_at"
330
+ t.index ["user_id", "name"], name: "index_preferences_on_user_id_and_name"
340
331
  end
341
332
 
342
- add_index "preferences", ["user_id", "name"], name: "index_preferences_on_user_id_and_name", using: :btree
343
-
344
- create_table "sessions", force: :cascade do |t|
345
- t.string "session_id", null: false
346
- t.text "data"
333
+ create_table "sessions", id: :serial, force: :cascade do |t|
334
+ t.string "session_id", null: false
335
+ t.text "data"
347
336
  t.datetime "created_at"
348
337
  t.datetime "updated_at"
338
+ t.index ["session_id"], name: "index_sessions_on_session_id"
339
+ t.index ["updated_at"], name: "index_sessions_on_updated_at"
349
340
  end
350
341
 
351
- add_index "sessions", ["session_id"], name: "index_sessions_on_session_id", using: :btree
352
- add_index "sessions", ["updated_at"], name: "index_sessions_on_updated_at", using: :btree
353
-
354
- create_table "settings", force: :cascade do |t|
355
- t.string "name", limit: 32, default: "", null: false
356
- t.text "value"
342
+ create_table "settings", id: :serial, force: :cascade do |t|
343
+ t.string "name", limit: 32, default: "", null: false
344
+ t.text "value"
357
345
  t.datetime "created_at"
358
346
  t.datetime "updated_at"
347
+ t.index ["name"], name: "index_settings_on_name"
359
348
  end
360
349
 
361
- add_index "settings", ["name"], name: "index_settings_on_name", using: :btree
362
-
363
- create_table "taggings", force: :cascade do |t|
364
- t.integer "tag_id"
365
- t.integer "taggable_id"
366
- t.integer "tagger_id"
367
- t.string "tagger_type"
368
- t.string "taggable_type", limit: 50
369
- t.string "context", limit: 50
350
+ create_table "taggings", id: :serial, force: :cascade do |t|
351
+ t.integer "tag_id"
352
+ t.integer "taggable_id"
353
+ t.integer "tagger_id"
354
+ t.string "tagger_type"
355
+ t.string "taggable_type", limit: 50
356
+ t.string "context", limit: 50
370
357
  t.datetime "created_at"
358
+ t.index ["tag_id", "taggable_id", "taggable_type", "context"], name: "taggings_idx", unique: true
359
+ t.index ["taggable_id", "taggable_type", "context"], name: "index_taggings_on_taggable_id_and_taggable_type_and_context"
371
360
  end
372
361
 
373
- add_index "taggings", ["tag_id", "taggable_id", "taggable_type", "context"], name: "taggings_idx", unique: true, using: :btree
374
- add_index "taggings", ["taggable_id", "taggable_type", "context"], name: "index_taggings_on_taggable_id_and_taggable_type_and_context", using: :btree
375
-
376
- create_table "tags", force: :cascade do |t|
377
- t.string "name"
362
+ create_table "tags", id: :serial, force: :cascade do |t|
363
+ t.string "name"
378
364
  t.integer "taggings_count", default: 0
365
+ t.index ["name"], name: "index_tags_on_name", unique: true
379
366
  end
380
367
 
381
- add_index "tags", ["name"], name: "index_tags_on_name", unique: true, using: :btree
382
-
383
- create_table "tasks", force: :cascade do |t|
384
- t.integer "user_id"
385
- t.integer "assigned_to"
386
- t.integer "completed_by"
387
- t.string "name", default: "", null: false
388
- t.integer "asset_id"
389
- t.string "asset_type"
390
- t.string "priority", limit: 32
391
- t.string "category", limit: 32
392
- t.string "bucket", limit: 32
368
+ create_table "tasks", id: :serial, force: :cascade do |t|
369
+ t.integer "user_id"
370
+ t.integer "assigned_to"
371
+ t.integer "completed_by"
372
+ t.string "name", default: "", null: false
373
+ t.string "asset_type"
374
+ t.integer "asset_id"
375
+ t.string "priority", limit: 32
376
+ t.string "category", limit: 32
377
+ t.string "bucket", limit: 32
393
378
  t.datetime "due_at"
394
379
  t.datetime "completed_at"
395
380
  t.datetime "deleted_at"
396
381
  t.datetime "created_at"
397
382
  t.datetime "updated_at"
398
- t.string "background_info"
399
- t.text "subscribed_users"
383
+ t.string "background_info"
384
+ t.text "subscribed_users"
385
+ t.index ["assigned_to"], name: "index_tasks_on_assigned_to"
386
+ t.index ["user_id", "name", "deleted_at"], name: "index_tasks_on_user_id_and_name_and_deleted_at", unique: true
400
387
  end
401
388
 
402
- add_index "tasks", ["assigned_to"], name: "index_tasks_on_assigned_to", using: :btree
403
- add_index "tasks", ["user_id", "name", "deleted_at"], name: "index_tasks_on_user_id_and_name_and_deleted_at", unique: true, using: :btree
404
-
405
- create_table "users", force: :cascade do |t|
406
- t.string "username", limit: 32, default: "", null: false
407
- t.string "email", limit: 254, default: "", null: false
408
- t.string "first_name", limit: 32
409
- t.string "last_name", limit: 32
410
- t.string "title", limit: 64
411
- t.string "company", limit: 64
412
- t.string "alt_email", limit: 254
413
- t.string "phone", limit: 32
414
- t.string "mobile", limit: 32
415
- t.string "aim", limit: 32
416
- t.string "yahoo", limit: 32
417
- t.string "google", limit: 32
418
- t.string "skype", limit: 32
419
- t.string "password_hash", default: "", null: false
420
- t.string "password_salt", default: "", null: false
421
- t.string "persistence_token", default: "", null: false
422
- t.string "perishable_token", default: "", null: false
389
+ create_table "users", id: :serial, force: :cascade do |t|
390
+ t.string "username", limit: 32, default: "", null: false
391
+ t.string "email", limit: 254, default: "", null: false
392
+ t.string "first_name", limit: 32
393
+ t.string "last_name", limit: 32
394
+ t.string "title", limit: 64
395
+ t.string "company", limit: 64
396
+ t.string "alt_email", limit: 254
397
+ t.string "phone", limit: 32
398
+ t.string "mobile", limit: 32
399
+ t.string "aim", limit: 32
400
+ t.string "yahoo", limit: 32
401
+ t.string "google", limit: 32
402
+ t.string "skype", limit: 32
403
+ t.string "password_hash", default: "", null: false
404
+ t.string "password_salt", default: "", null: false
405
+ t.string "persistence_token", default: "", null: false
406
+ t.string "perishable_token", default: "", null: false
423
407
  t.datetime "last_login_at"
424
408
  t.datetime "current_login_at"
425
- t.string "last_login_ip"
426
- t.string "current_login_ip"
427
- t.integer "login_count", default: 0, null: false
409
+ t.string "last_login_ip"
410
+ t.string "current_login_ip"
411
+ t.integer "login_count", default: 0, null: false
428
412
  t.datetime "deleted_at"
429
413
  t.datetime "created_at"
430
414
  t.datetime "updated_at"
431
- t.boolean "admin", default: false, null: false
415
+ t.boolean "admin", default: false, null: false
432
416
  t.datetime "suspended_at"
433
- t.string "single_access_token"
417
+ t.string "single_access_token"
418
+ t.index ["email"], name: "index_users_on_email"
419
+ t.index ["perishable_token"], name: "index_users_on_perishable_token"
420
+ t.index ["persistence_token"], name: "index_users_on_persistence_token"
421
+ t.index ["username", "deleted_at"], name: "index_users_on_username_and_deleted_at", unique: true
434
422
  end
435
423
 
436
- add_index "users", ["email"], name: "index_users_on_email", using: :btree
437
- add_index "users", ["perishable_token"], name: "index_users_on_perishable_token", using: :btree
438
- add_index "users", ["persistence_token"], name: "index_users_on_persistence_token", using: :btree
439
- add_index "users", ["username", "deleted_at"], name: "index_users_on_username_and_deleted_at", unique: true, using: :btree
440
-
441
- create_table "versions", force: :cascade do |t|
442
- t.string "item_type", null: false
443
- t.integer "item_id", null: false
444
- t.string "event", limit: 512, null: false
445
- t.string "whodunnit"
446
- t.text "object"
424
+ create_table "versions", id: :serial, force: :cascade do |t|
425
+ t.string "item_type", null: false
426
+ t.integer "item_id", null: false
427
+ t.string "event", limit: 512, null: false
428
+ t.string "whodunnit"
429
+ t.text "object"
447
430
  t.datetime "created_at"
448
- t.text "object_changes"
449
- t.integer "related_id"
450
- t.string "related_type"
451
- t.integer "transaction_id"
431
+ t.text "object_changes"
432
+ t.integer "related_id"
433
+ t.string "related_type"
434
+ t.integer "transaction_id"
435
+ t.index ["created_at"], name: "index_versions_on_created_at"
436
+ t.index ["item_type", "item_id"], name: "index_versions_on_item_type_and_item_id"
437
+ t.index ["related_id", "related_type"], name: "index_versions_on_related_id_and_related_type"
438
+ t.index ["transaction_id"], name: "index_versions_on_transaction_id"
439
+ t.index ["whodunnit"], name: "index_versions_on_whodunnit"
452
440
  end
453
441
 
454
- add_index "versions", ["created_at"], name: "index_versions_on_created_at", using: :btree
455
- add_index "versions", ["item_type", "item_id"], name: "index_versions_on_item_type_and_item_id", using: :btree
456
- add_index "versions", ["transaction_id"], name: "index_versions_on_transaction_id", using: :btree
457
- add_index "versions", ["whodunnit"], name: "index_versions_on_whodunnit", using: :btree
458
442
  end