fat_free_crm 0.11.0 → 0.11.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 (212) hide show
  1. data/.gitignore +1 -0
  2. data/.travis.yml +2 -2
  3. data/Gemfile +15 -2
  4. data/Gemfile.lock +34 -14
  5. data/README.md +37 -124
  6. data/app/assets/javascripts/application.js.erb +1 -1
  7. data/app/assets/javascripts/crm.js +22 -1
  8. data/app/assets/javascripts/crm_fields.js +2 -3
  9. data/app/assets/javascripts/jquery-noconflict.js +17 -0
  10. data/app/assets/stylesheets/application.css.erb +1 -0
  11. data/app/assets/stylesheets/common.scss +26 -0
  12. data/app/assets/stylesheets/ffcrm_chosen.scss +1 -1
  13. data/app/controllers/admin/application_controller.rb +1 -1
  14. data/app/controllers/application_controller.rb +0 -8
  15. data/app/controllers/{accounts_controller.rb → entities/accounts_controller.rb} +1 -13
  16. data/app/controllers/{campaigns_controller.rb → entities/campaigns_controller.rb} +1 -13
  17. data/app/controllers/{contacts_controller.rb → entities/contacts_controller.rb} +1 -7
  18. data/app/controllers/{leads_controller.rb → entities/leads_controller.rb} +1 -1
  19. data/app/controllers/{opportunities_controller.rb → entities/opportunities_controller.rb} +1 -7
  20. data/app/controllers/{tasks_controller.rb → entities/tasks_controller.rb} +1 -1
  21. data/app/controllers/{base_controller.rb → entities_controller.rb} +32 -1
  22. data/app/controllers/home_controller.rb +9 -9
  23. data/app/controllers/lists_controller.rb +17 -0
  24. data/app/helpers/admin/tags_helper.rb +1 -1
  25. data/app/helpers/application_helper.rb +14 -14
  26. data/app/helpers/crm_tags_helper.rb +1 -1
  27. data/app/helpers/home_helper.rb +13 -15
  28. data/app/helpers/lists_helper.rb +17 -0
  29. data/app/inputs/date_time_input.rb +17 -0
  30. data/app/inputs/text_input.rb +17 -1
  31. data/app/models/{base → entities}/account.rb +0 -1
  32. data/app/models/{base → entities}/account_contact.rb +0 -0
  33. data/app/models/{base → entities}/account_opportunity.rb +0 -0
  34. data/app/models/{base → entities}/campaign.rb +0 -1
  35. data/app/models/{base → entities}/contact.rb +0 -1
  36. data/app/models/{base → entities}/contact_opportunity.rb +0 -0
  37. data/app/models/{base → entities}/lead.rb +0 -1
  38. data/app/models/{base → entities}/opportunity.rb +0 -1
  39. data/app/models/{base → entities}/task.rb +5 -6
  40. data/app/models/list.rb +17 -0
  41. data/app/models/observers/lead_observer.rb +39 -0
  42. data/app/models/observers/opportunity_observer.rb +54 -0
  43. data/app/models/observers/task_observer.rb +41 -0
  44. data/app/models/polymorphic/address.rb +1 -3
  45. data/app/models/polymorphic/avatar.rb +0 -5
  46. data/app/models/polymorphic/comment.rb +2 -11
  47. data/app/models/polymorphic/email.rb +2 -9
  48. data/app/models/polymorphic/tag.rb +17 -0
  49. data/app/models/polymorphic/tagging.rb +17 -0
  50. data/app/models/users/ability.rb +13 -0
  51. data/app/models/users/user.rb +1 -4
  52. data/app/views/accounts/_account.html.haml +10 -6
  53. data/app/views/accounts/index.html.haml +1 -1
  54. data/app/views/accounts/show.html.haml +6 -24
  55. data/app/views/admin/fields/_field.html.haml +6 -6
  56. data/app/views/admin/tags/_tag.html.haml +2 -2
  57. data/app/views/admin/tags/index.html.haml +1 -1
  58. data/app/views/admin/users/_user.html.haml +3 -3
  59. data/app/views/admin/users/index.html.haml +1 -1
  60. data/app/views/campaigns/_campaign.html.haml +9 -5
  61. data/app/views/campaigns/index.html.haml +1 -1
  62. data/app/views/campaigns/show.html.haml +4 -24
  63. data/app/views/comments/_comment.html.haml +17 -14
  64. data/app/views/comments/_edit.html.haml +1 -1
  65. data/app/views/comments/_new.html.haml +3 -3
  66. data/app/views/contacts/_contact.html.haml +33 -15
  67. data/app/views/contacts/_contacts.html.haml +6 -0
  68. data/app/views/contacts/_sidebar_show.html.haml +1 -1
  69. data/app/views/contacts/index.html.haml +1 -1
  70. data/app/views/contacts/show.html.haml +3 -19
  71. data/app/views/emails/_email.html.haml +24 -21
  72. data/app/views/{base → entities}/_advanced_search.html.haml +0 -0
  73. data/app/views/{base → entities}/_condition_fields.html.haml +0 -0
  74. data/app/views/{base → entities}/_grouping_fields.html.haml +0 -0
  75. data/app/views/{base → entities}/_sort_fields.html.haml +0 -0
  76. data/app/views/{base → entities}/advanced_search.js.rjs +0 -0
  77. data/app/views/entities/contacts.js.rjs +3 -0
  78. data/app/views/entities/leads.js.rjs +3 -0
  79. data/app/views/entities/opportunities.js.rjs +3 -0
  80. data/app/views/entities/versions.js.rjs +3 -0
  81. data/app/views/home/_activity.html.haml +19 -18
  82. data/app/views/home/_events_menu.html.haml +8 -0
  83. data/app/views/home/_options.html.haml +2 -3
  84. data/app/views/home/index.html.haml +1 -1
  85. data/app/views/leads/_lead.html.haml +42 -23
  86. data/app/views/leads/_leads.html.haml +6 -0
  87. data/app/views/leads/_sidebar_show.html.haml +1 -1
  88. data/app/views/leads/index.html.haml +1 -1
  89. data/app/views/leads/show.html.haml +3 -13
  90. data/app/views/opportunities/_opportunities.html.haml +6 -0
  91. data/app/views/opportunities/_opportunity.html.haml +23 -11
  92. data/app/views/opportunities/index.html.haml +1 -1
  93. data/app/views/opportunities/show.html.haml +4 -18
  94. data/app/views/shared/_comment.html.haml +3 -3
  95. data/app/views/shared/_edit_comment.html.haml +1 -1
  96. data/app/views/shared/_recent.html.haml +4 -4
  97. data/app/views/shared/_recently.html.haml +3 -3
  98. data/app/views/shared/_timeline.html.haml +2 -3
  99. data/app/views/tasks/_assigned.html.haml +4 -4
  100. data/app/views/tasks/_completed.html.haml +2 -2
  101. data/app/views/tasks/_pending.html.haml +2 -2
  102. data/app/views/tasks/_related.html.haml +4 -5
  103. data/app/views/tasks/_tasks.html.haml +3 -0
  104. data/app/views/tasks/_title.html.haml +1 -1
  105. data/app/views/tasks/index.html.haml +1 -1
  106. data/app/views/users/_avatar.html.haml +2 -2
  107. data/app/views/versions/_version.html.haml +9 -12
  108. data/app/views/versions/_versions.html.haml +11 -0
  109. data/config/application.rb +3 -2
  110. data/config/environments/development.rb +2 -2
  111. data/config/environments/production.rb +0 -4
  112. data/config/environments/staging.rb +1 -1
  113. data/config/initializers/action_mailer.rb +9 -0
  114. data/config/initializers/paper_trail.rb +80 -0
  115. data/config/initializers/relative_url_root.rb +23 -0
  116. data/config/locales/cz_fat_free_crm.yml +1 -1
  117. data/config/locales/en-US_fat_free_crm.yml +22 -17
  118. data/config/locales/fr_fat_free_crm.yml +349 -134
  119. data/config/routes.rb +144 -140
  120. data/config/settings.default.yml +14 -2
  121. data/db/demo/addresses.yml +2 -2
  122. data/db/demo/emails.yml +2 -2
  123. data/db/migrate/20120216042541_is_paranoid_to_paper_trail.rb +1 -2
  124. data/db/migrate/20120309070209_add_versions_related.rb +6 -0
  125. data/db/migrate/20120316045804_activities_to_versions.rb +35 -0
  126. data/db/schema.rb +79 -53
  127. data/fat_free_crm.gemspec +8 -4
  128. data/lib/development_tasks/gem.rake +18 -1
  129. data/lib/development_tasks/license.rake +2 -4
  130. data/lib/development_tasks/rdoc.rake +17 -0
  131. data/lib/development_tasks/rspec.rake +17 -0
  132. data/lib/fat_free_crm.rb +20 -14
  133. data/lib/fat_free_crm/core_ext/array.rb +0 -27
  134. data/lib/fat_free_crm/dropbox.rb +11 -1
  135. data/lib/fat_free_crm/engine.rb +21 -3
  136. data/lib/fat_free_crm/gem_dependencies.rb +26 -0
  137. data/lib/fat_free_crm/gem_ext.rb +18 -1
  138. data/lib/fat_free_crm/gem_ext/active_record/schema_dumper.rb +18 -1
  139. data/lib/fat_free_crm/gem_ext/authlogic/session/cookies.rb +17 -0
  140. data/lib/fat_free_crm/gem_ext/rails/engine.rb +17 -0
  141. data/lib/fat_free_crm/gem_ext/rails/text_helper.rb +17 -0
  142. data/lib/fat_free_crm/gem_ext/rake/task.rb +17 -0
  143. data/lib/fat_free_crm/gem_ext/simple_form/action_view_extensions/form_helper.rb +18 -1
  144. data/lib/fat_free_crm/plugin_dependencies.rb +23 -5
  145. data/lib/fat_free_crm/renderers.rb +17 -0
  146. data/lib/fat_free_crm/syck_yaml.rb +17 -0
  147. data/lib/fat_free_crm/version.rb +1 -1
  148. data/lib/{country_select → plugins/country_select}/MIT-LICENSE +0 -0
  149. data/lib/{country_select → plugins/country_select}/README +0 -0
  150. data/lib/{country_select → plugins/country_select}/init.rb +0 -0
  151. data/lib/{country_select → plugins/country_select}/install.rb +0 -0
  152. data/lib/{country_select → plugins/country_select}/lib/country_select.rb +0 -0
  153. data/lib/{country_select → plugins/country_select}/uninstall.rb +0 -0
  154. data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/Gemfile +0 -0
  155. data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/README.textile +0 -0
  156. data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/ROADMAP.textile +0 -0
  157. data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/Rakefile +0 -0
  158. data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/VERSION +0 -0
  159. data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/gravatar_image_tag.gemspec +0 -0
  160. data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/init.rb +0 -0
  161. data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/lib/gravatar_image_tag.rb +0 -0
  162. data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/spec/gravatar_image_tag_spec.rb +0 -0
  163. data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/spec/test_helper.rb +0 -0
  164. data/lib/tasks/demo.rake +32 -29
  165. data/lib/tasks/dropbox.rake +1 -1
  166. data/lib/tasks/fat_free_crm.rake +3 -2
  167. data/lib/tasks/plugins.rake +1 -0
  168. data/spec/controllers/accounts_controller_spec.rb +7 -5
  169. data/spec/controllers/campaigns_controller_spec.rb +11 -9
  170. data/spec/controllers/contacts_controller_spec.rb +7 -5
  171. data/spec/controllers/home_controller_spec.rb +2 -2
  172. data/spec/controllers/leads_controller_spec.rb +7 -5
  173. data/spec/controllers/opportunities_controller_spec.rb +7 -5
  174. data/spec/factories/shared_factories.rb +8 -11
  175. data/spec/lib/dropbox_spec.rb +1 -0
  176. data/spec/models/polymorphic/version_spec.rb +247 -0
  177. data/spec/models/users/user_spec.rb +0 -9
  178. data/spec/spec_helper.rb +4 -0
  179. data/spec/views/home/index.haml_spec.rb +1 -1
  180. data/spec/views/home/index.rjs_spec.rb +4 -4
  181. data/spec/views/tasks/new.rjs_spec.rb +2 -2
  182. data/vendor/assets/javascripts/calendar_date_select/format_french.js +24 -0
  183. metadata +167 -126
  184. data/app/models/observers/activity_observer.rb +0 -84
  185. data/app/models/polymorphic/activity.rb +0 -106
  186. data/app/views/accounts/contacts.js.rjs +0 -3
  187. data/app/views/accounts/opportunities.js.rjs +0 -3
  188. data/app/views/campaigns/leads.js.rjs +0 -3
  189. data/app/views/campaigns/opportunities.js.rjs +0 -3
  190. data/app/views/contacts/opportunities.js.rjs +0 -3
  191. data/app/views/home/_actions_menu.html.haml +0 -8
  192. data/lib/dynamic_form/MIT-LICENSE +0 -20
  193. data/lib/dynamic_form/README +0 -13
  194. data/lib/dynamic_form/Rakefile +0 -10
  195. data/lib/dynamic_form/dynamic_form.gemspec +0 -12
  196. data/lib/dynamic_form/init.rb +0 -2
  197. data/lib/dynamic_form/lib/action_view/helpers/dynamic_form.rb +0 -301
  198. data/lib/dynamic_form/lib/action_view/locale/en-US.yml +0 -8
  199. data/lib/dynamic_form/lib/dynamic_form.rb +0 -6
  200. data/lib/dynamic_form/test/dynamic_form_i18n_test.rb +0 -42
  201. data/lib/dynamic_form/test/dynamic_form_test.rb +0 -370
  202. data/lib/dynamic_form/test/test_helper.rb +0 -10
  203. data/lib/responds_to_parent/MIT-LICENSE +0 -20
  204. data/lib/responds_to_parent/README +0 -47
  205. data/lib/responds_to_parent/Rakefile +0 -22
  206. data/lib/responds_to_parent/init.rb +0 -2
  207. data/lib/responds_to_parent/install.rb +0 -2
  208. data/lib/responds_to_parent/lib/responds_to_parent.rb +0 -70
  209. data/lib/responds_to_parent/test/responds_to_parent_test.rb +0 -11
  210. data/lib/responds_to_parent/test/test_helper.rb +0 -7
  211. data/lib/responds_to_parent/uninstall.rb +0 -2
  212. data/spec/models/polymorphic/activity_spec.rb +0 -303
@@ -8,7 +8,7 @@
8
8
 
9
9
  .title
10
10
  %span#create_account_title #{t :accounts}
11
- = image_tag("loading.gif", :size => "16x16", :id => "loading", :style => "display: none;")
11
+ = image_tag("loading.gif", :size => :thumb, :id => "loading", :style => "display: none;")
12
12
  .remote#options{ hidden }
13
13
  .remote#advanced_search{ hidden_if(!params[:q]) }
14
14
  - if @search
@@ -13,30 +13,12 @@
13
13
 
14
14
  = hook(:show_account_bottom, self) do
15
15
 
16
- = section(@account, :tasks)
17
- .log#tasks
18
- = render "shared/tasks"
19
-
20
- = section(@account, :contacts)
21
- .list#contacts
22
- - @contacts = @account.contacts.paginate(:page => 1, :per_page => 20)
23
- = render :partial => "contacts/contact", :collection => @contacts
24
- = will_paginate @contacts, :id => true, :params => {:action => :contacts}
25
-
26
- = section(@account, :opportunities)
27
- .list#opportunities
28
- - @opportunities = @account.opportunities.paginate(:page => 1, :per_page => 20)
29
- = render :partial => "opportunities/opportunity", :collection => @opportunities
30
- = will_paginate @opportunities, :id => true, :params => {:action => :opportunities}
16
+ = render :partial => "tasks/tasks", :locals => {:object => @account}
31
17
 
32
- = load_select_popups_for(@account, :tasks, :contacts, :opportunities)
18
+ = render :partial => "contacts/contacts", :locals => {:object => @account}
19
+
20
+ = render :partial => "opportunities/opportunities", :locals => {:object => @account}
33
21
 
34
- %br( style="clear:both" )
22
+ = render :partial => "versions/versions", :locals => {:object => @account}
35
23
 
36
- - if Setting.paper_trail_ui_enabled
37
- %br
38
- = content_tag(:div, t(:versions), :class => :subtitle)
39
- .list#versions
40
- - @versions = @account.versions.except(:order).order('created_at DESC').paginate(:page => 1, :per_page => 20)
41
- = render :partial => "versions/version", :collection => @versions
42
- = will_paginate @versions, :id => true, :params => {:action => :versions}
24
+ = load_select_popups_for(@account, :tasks, :contacts, :opportunities)
@@ -1,15 +1,15 @@
1
- %li.position[field]{ highlightable(dom_id(field, :tools)) }
1
+ %li.highlight.position[field]
2
2
  %span.handle
3
3
  %img( src="/assets/sortable.gif" )
4
- .tools{ invisible, :id => dom_id(field, :tools) }
4
+
5
+ .tools
5
6
  %small
6
7
  = link_to_edit(field, :url => edit_admin_field_path(field), :klass_name => 'Field') + " | "
7
8
  = link_to_delete(field, :url => admin_field_path(field), :klass_name => 'Field')
9
+
8
10
  %tt
9
- %b
10
- = field.label
11
- = "(#{t('field_types.' + field.as)})"
11
+ %b= field.label
12
+ == (#{t('field_types.' + field.as)})
12
13
 
13
14
  == added #{time_ago_in_words(field.created_at)} ago
14
15
  = hook(:field_bottom, self, :field => field)
15
-
@@ -1,8 +1,8 @@
1
1
  - tag_field_groups = FieldGroup.find_all_by_tag_id(tag)
2
2
  - model_tagging_counts = tag.model_tagging_counts
3
3
 
4
- %li[tag]{ highlightable(dom_id(tag, :tools)) }
5
- .tools{ invisible, :id => dom_id(tag, :tools) }
4
+ %li.highlight[tag]
5
+ .tools
6
6
  = link_to_edit(tag, :url => edit_admin_tag_path(tag)) << " |"
7
7
  - if tag_field_groups.any?
8
8
  %span{:style => "color: #777"} Delete
@@ -5,7 +5,7 @@
5
5
 
6
6
  .title
7
7
  %span#create_tag_title #{t :tags}
8
- = image_tag("loading.gif", :size => "16x16", :id => "loading", :style => "display: none;")
8
+ = image_tag("loading.gif", :size => :thumb, :id => "loading", :style => "display: none;")
9
9
  .remote#create_tag{ hidden }
10
10
 
11
11
  .list#tags
@@ -1,4 +1,4 @@
1
- %li[user]{ highlightable(dom_id(user, :tools)) }
1
+ %li.highlight[user]
2
2
 
3
3
  - if user.awaits_approval?
4
4
  .strip.signed_up #{t :user_signed_up}
@@ -9,10 +9,10 @@
9
9
  - else
10
10
  .strip.active #{t :user_active}
11
11
 
12
- = avatar_for(user, :size => "30x30")
12
+ = avatar_for(user, :size => :medium, :width => 30, :height => 30 )
13
13
 
14
14
  .indentfull
15
- .tools{ invisible, :id => dom_id(user, :tools) }
15
+ .tools
16
16
  = link_to_edit(user, :url => edit_admin_user_path(user)) << " | "
17
17
 
18
18
  - if user.suspended?
@@ -5,7 +5,7 @@
5
5
 
6
6
  .title
7
7
  %span#create_user_title #{t :users}
8
- = image_tag("loading.gif", :size => "16x16", :id => "loading", :style => "display: none;")
8
+ = image_tag("loading.gif", :size => :thumb, :id => "loading", :style => "display: none;")
9
9
  .remote#create_user{ hidden }
10
10
 
11
11
  .list#users= render :partial => "admin/users/user", :collection => @users
@@ -1,13 +1,17 @@
1
- %li[campaign]{ highlightable(dom_id(campaign, :tools)) }
1
+ %li.highlight[campaign]
2
2
  .strip{:class => campaign.status}= t(campaign.status)
3
3
 
4
- .tools{ invisible, :id => dom_id(campaign, :tools) }
5
- = link_to_edit(campaign) + " | "
6
- = link_to_delete(campaign)
4
+ %ul.tools
5
+ - if can?(:update, campaign)
6
+ %li= link_to_edit(campaign)
7
+
8
+ - if can?(:destroy, campaign)
9
+ %li= link_to_delete(campaign)
7
10
 
8
11
  .indent
9
- = link_to(h(campaign.name), campaign)
12
+ = link_to(campaign.name, campaign)
10
13
  = render "campaigns/status", :campaign => campaign
14
+
11
15
  - unless @current_user.preference[:campaigns_outline] == "brief"
12
16
  = render "campaigns/metrics", :campaign => campaign
13
17
  - if campaign.tag_list.present?
@@ -8,7 +8,7 @@
8
8
 
9
9
  .title
10
10
  %span#create_campaign_title #{t :campaigns}
11
- = image_tag("loading.gif", :size => "16x16", :id => "loading", :style => "display: none;")
11
+ = image_tag("loading.gif", :size => :thumb, :id => "loading", :style => "display: none;")
12
12
  .remote#options{ hidden }
13
13
  .remote#advanced_search{ hidden_if(!params[:q]) }
14
14
  - if @search
@@ -13,32 +13,12 @@
13
13
 
14
14
  = hook(:show_campaign_bottom, self) do
15
15
 
16
- = section(@campaign, :tasks)
17
- .log#tasks
18
- = render "shared/tasks"
16
+ = render :partial => "tasks/tasks", :locals => {:object => @campaign}
19
17
 
20
- = section(@campaign, :leads)
21
- .list#leads
22
- - @leads = @campaign.leads.paginate(:page => 1, :per_page => 20)
23
- = render :partial => "leads/lead", :collection => @campaign.leads.paginate(:page => 1, :per_page => 20)
24
- = will_paginate @leads, :id => true, :params => {:action => :leads}
18
+ = render :partial => "leads/leads", :locals => {:object => @campaign}
25
19
 
26
- %br( style="clear:both" )
20
+ = render :partial => "opportunities/opportunities", :locals => {:object => @campaign}
27
21
 
28
- = section(@campaign, :opportunities)
29
- .list#opportunities
30
- - @opportunities = @campaign.opportunities.paginate(:page => 1, :per_page => 20)
31
- = render :partial => "opportunities/opportunity", :collection => @campaign.opportunities.paginate(:page => 1, :per_page => 20)
32
- = will_paginate @opportunities, :id => true, :params => {:action => :opportunities}
22
+ = render :partial => "versions/versions", :locals => {:object => @campaign}
33
23
 
34
24
  = load_select_popups_for(@campaign, :tasks, :leads, :opportunities)
35
-
36
- %br( style="clear:both" )
37
-
38
- - if Setting.paper_trail_ui_enabled
39
- %br
40
- = content_tag(:div, t(:versions), :class => :subtitle)
41
- .list#versions
42
- - @versions = @campaign.versions.except(:order).order('created_at DESC').paginate(:page => 1, :per_page => 20)
43
- = render :partial => "versions/version", :collection => @versions
44
- = will_paginate @versions, :id => true, :params => {:action => :versions}
@@ -1,25 +1,28 @@
1
1
  - truncated = simple_format h(truncate(comment.comment.gsub("\n", " "), :length => 125))
2
2
  - formatted = defined?(RedCloth) ? RedCloth.new(h(comment.comment)).to_html.html_safe : simple_format(h(comment.comment)).html_safe
3
3
  - collapsable = formatted.size > 150
4
+ - commentable = comment.commentable
4
5
 
5
- %li[comment]{ highlightable(dom_id(comment, :tools), :off => "#f2f2f2") }
6
+ %li.comment.highlight[comment]
6
7
  .body
7
- = link_to avatar_for(comment.user, :size => "25x25"), user_path(comment.user)
8
- .tools{ invisible, :id => dom_id(comment, :tools) }
9
- = link_to_edit(comment) + " | "
10
- = link_to_delete(comment)
8
+ = link_to avatar_for(comment.user, :size => :small), user_path(comment.user)
9
+ %ul.tools
10
+ - if can?(:update, commentable)
11
+ %li= link_to_edit(comment)
12
+ - if can?(:destroy, commentable)
13
+ %li= link_to_delete(comment)
11
14
 
12
15
  = link_to(comment.user.full_name, user_path(comment.user)) + ","
13
16
  %tt
14
17
  added note #{t(:time_ago, distance_of_time_in_words(Time.now, comment.created_at))}
15
- - if collapsable
18
+ - if collapsable && can?(:read, commentable)
16
19
  = " | ".html_safe + link_to_function(comment.collapsed? ? t(:more) : t(:less), "crm.flip_note_or_email(this, '#{t(:more)}', '#{t(:less)}')", :class => "toggle")
17
20
 
18
- - if collapsable
19
- %dt{ hidden_if(comment.expanded?), :id => dom_id(comment, :truncated) }
20
- = truncated
21
- %dt.textile{ hidden_if(comment.collapsed?), :id => dom_id(comment, :formatted) }
22
- = auto_link(formatted).html_safe
23
- - else
24
- %dt.textile= auto_link(formatted).html_safe
25
-
21
+ - if can?(:read, commentable)
22
+ - if collapsable
23
+ %dt{ hidden_if(comment.expanded?), :id => dom_id(comment, :truncated) }
24
+ = truncated
25
+ %dt.textile{ hidden_if(comment.collapsed?), :id => dom_id(comment, :formatted) }
26
+ = auto_link(formatted).html_safe
27
+ - else
28
+ %dt.textile= auto_link(formatted).html_safe
@@ -1,6 +1,6 @@
1
1
  - class_name = commentable.class.name.downcase
2
2
  .comment{:style => "margin: 5px 0px 0px 0px"}
3
- = link_to avatar_for(@current_user, :size => "25x25"), user_path(@current_user)
3
+ = link_to avatar_for(@current_user, :size => :small), user_path(@current_user)
4
4
  = form_for(@comment, :remote => true) do |f|
5
5
  = hidden_field_tag "comment[user_id]", @comment.user_id || @current_user.id
6
6
  = hidden_field_tag "comment[commentable_id]", commentable.id
@@ -1,14 +1,14 @@
1
1
  - class_name = commentable.class.name.downcase
2
2
  - id_prefix = "#{class_name}_#{commentable.id}"
3
- .comment.new_comment{ {:id => "#{class_name}_#{commentable.id}_comment_new"}.merge(highlightable("#{class_name}_#{commentable.id}_comment_new_tools", :off => "#f2f2f2")) }
3
+ .comment.highlight.new_comment{ :id => "#{id_prefix}_comment_new" }
4
4
 
5
5
  -# Two hidden fields store the IDs of notes and emails shown for the asset. These IDs are used
6
6
  -# by [Expand/Collapse All]. The contents gets updated by actions such as [Add] or [Delete].
7
7
  = hidden_field_tag :shown_notes, "#{commentable.comment_ids.join(',')}", :id => "#{id_prefix}_shown_notes"
8
8
  = hidden_field_tag :shown_emails, "#{commentable.email_ids.join(',')}", :id => "#{id_prefix}_shown_emails"
9
9
 
10
- = link_to avatar_for(@current_user, :size => "25x25"), user_path(@current_user)
11
- .tools{ {:id => "#{id_prefix}_comment_new_tools"}.merge(invisible) }
10
+ = link_to avatar_for(@current_user, :size => :small), user_path(@current_user)
11
+ .tools
12
12
  = link_to_function(t(:expand_all), "crm.flip_notes_and_emails('#{t(:expanded)}', '#{t(:more)}', '#{t(:less)}', '#{id_prefix}')") << " | "
13
13
  = link_to_function(t(:collapse_all), "crm.flip_notes_and_emails('#{t(:collapsed)}', '#{t(:more)}', '#{t(:less)}', '#{id_prefix}')")
14
14
 
@@ -1,31 +1,49 @@
1
1
  - gravatar_size = @current_user.preference[:contacts_outline] == "brief" ? "16x16" : "30x30"
2
2
 
3
- %li[contact]{ highlightable(dom_id(contact, :tools)) }
3
+ %li.highlight[contact]
4
4
  = gravatar_for(contact, :size => gravatar_size)
5
5
 
6
- .tools{ invisible, :id => dom_id(contact, :tools) }
6
+ %ul.tools
7
7
  = hook(:contact_tools_before, self, :contact => contact)
8
- = link_to_edit(contact) + " | "
9
- = link_to_discard(contact) + " | " if shown_on_landing_page?
10
- = link_to_delete(contact)
8
+
9
+ - if can?(:update, contact)
10
+ %li= link_to_edit(contact)
11
+
12
+ - if shown_on_landing_page?
13
+ %li= link_to_discard(contact)
14
+
15
+ - if can?(:destroy, contact)
16
+ %li= link_to_delete(contact)
11
17
 
12
18
  .indentslim
13
- = link_to(h(contact.full_name(@current_user.preference[:contacts_naming])), contact)
19
+ = link_to_if can?(:read, contact), contact.full_name(@current_user.preference[:contacts_naming]), contact
14
20
  %tt
15
21
  - if contact.title? && contact.department?
16
- = h(contact.title) << ", " << h(contact.department)
22
+ == #{contact.title}, #{contact.department}
17
23
  - else
18
- = h(contact.title) if contact.title?
19
- - if contact.account && contact.account.name?
20
- == #{t :at} #{link_to h(contact.account.name), account_path(contact.account)}
21
- - if contact.lead and contact.lead.referred_by?
24
+ = contact.title if contact.title?
25
+
26
+ - if (account = contact.account) and account.name?
27
+ == #{t :at} #{link_to_if can?(:read, account), account.name, account_path(account)}
28
+
29
+ - if (lead = contact.lead) and lead.referred_by?
22
30
  &ndash;
23
- = #{t :referred_by_small} #{contact.lead.referred_by}"
31
+ == #{t :referred_by_small} #{lead.referred_by}
32
+
24
33
  - unless @current_user.preference[:contacts_outline] == "brief"
25
34
  %dt{ :style => "padding: 2px 0px 0px 0px" }
26
- = link_to_email(contact.email) << " | " if contact.email.present?
27
- = "#{t :phone_small}: <b>".html_safe + h(contact.phone) << "</b> | ".html_safe if contact.phone.present?
28
- = "#{t :mobile_small}: <b>".html_safe + h(contact.mobile) << "</b> | ".html_safe if contact.mobile.present?
35
+ - if can?(:read, contact)
36
+ - if contact.email.present?
37
+ = link_to_email(contact.email)
38
+ |
39
+ - if contact.phone.present?
40
+ == #{t :phone_small}:
41
+ %b= contact.phone
42
+ |
43
+ - if contact.mobile.present?
44
+ == #{t :mobile_small}:
45
+ %b= contact.mobile
46
+ |
29
47
  = t(:added_ago, time_ago_in_words(contact.created_at))
30
48
  - if contact.tag_list.present?
31
49
  %dt
@@ -0,0 +1,6 @@
1
+ = section(object, :contacts)
2
+ .list#contacts
3
+ - contacts = object.contacts.paginate(:page => 1, :per_page => 20)
4
+ = render :partial => "contacts/contact", :collection => contacts
5
+
6
+ = will_paginate contacts, :id => 'contacts_pagination', :params => {:action => :contacts}
@@ -36,6 +36,6 @@
36
36
 
37
37
  - if @contact.tag_list.present?
38
38
  %dt
39
- .tags= tags_for_index(@contact)
39
+ .tags= tags_for_index(@contact)
40
40
 
41
41
  = hook(:show_contact_sidebar_bottom, self, :contact => @contact)
@@ -8,7 +8,7 @@
8
8
 
9
9
  .title
10
10
  %span#create_contact_title #{t :contacts}
11
- = image_tag("loading.gif", :size => "16x16", :id => "loading", :style => "display: none;")
11
+ = image_tag("loading.gif", :size => :thumb, :id => "loading", :style => "display: none;")
12
12
  .remote#options{ hidden }
13
13
  .remote#advanced_search{ hidden_if(!params[:q]) }
14
14
  - if @search
@@ -13,26 +13,10 @@
13
13
 
14
14
  = hook(:show_contact_bottom, self) do
15
15
 
16
- = section(@contact, :tasks)
17
- .log#tasks
18
- = render "shared/tasks"
16
+ = render :partial => "tasks/tasks", :locals => {:object => @contact}
19
17
 
20
- %br( style="clear:both" )
18
+ = render :partial => "opportunities/opportunities", :locals => {:object => @contact}
21
19
 
22
- = section(@contact, :opportunities)
23
- .list#opportunities
24
- - @opportunities = @contact.opportunities.paginate(:page => 1, :per_page => 20)
25
- = render :partial => "opportunities/opportunity", :collection => @contact.opportunities.paginate(:page => 1, :per_page => 20)
26
- = will_paginate @opportunities, :id => true, :params => {:action => :opportunities}
20
+ = render :partial => "versions/versions", :locals => {:object => @contact}
27
21
 
28
22
  = load_select_popups_for(@contact, :tasks, :opportunities)
29
-
30
- %br( style="clear:both" )
31
-
32
- - if Setting.paper_trail_ui_enabled
33
- %br
34
- = content_tag(:div, t(:versions), :class => :subtitle)
35
- .list#versions
36
- - @versions = @contact.versions.except(:order).order('created_at DESC').paginate(:page => 1, :per_page => 20)
37
- = render :partial => "versions/version", :collection => @versions
38
- = will_paginate @versions, :id => true, :params => {:action => :versions}
@@ -1,27 +1,30 @@
1
- - truncated = h(truncate(email.body_without_textile.to_s.gsub("\n", " "), :length => 125 - email.subject.to_s.size))
1
+ - truncated = truncate(email.body_without_textile.to_s.gsub("\n", " "), :length => 125 - email.subject.to_s.size)
2
2
  - formatted = email.body
3
+ - mediator = email.mediator
3
4
 
4
- %li.mail{ highlightable(dom_id(email, :tools), :off => "#f2f2f2"), :id => dom_id(email) }
5
+ %li.mail.highlight[email]
5
6
  .body
6
- = link_to avatar_for(email.user, :size => "25x25"), user_path(email.user)
7
- .tools{ invisible, :id => dom_id(email, :tools) }
8
- = link_to_delete(email)
7
+ = link_to avatar_for(email.user, :size => :small), user_path(email.user)
8
+ %ul.tools
9
+ - if can?(:destroy, mediator)
10
+ %li= link_to_delete(email)
9
11
 
10
- %tt
11
- - if email.sent_to.to_s.include?(", ")
12
- = "To: ".html_safe << email.sent_to
13
- - else
14
- = "To ".html_safe << link_to_email(email.sent_to)
15
- = "from ".html_safe << link_to_email(email.sent_from) << ", sent on ".html_safe
16
- = l(email.sent_at, :format => :mmddhhss)
17
- = " | ".html_safe + link_to_function(email.collapsed? ? t(:more) : t(:less), "crm.flip_note_or_email(this, '#{t(:more)}', '#{t(:less)}')", :class => "toggle")
12
+ - if can?(:read, mediator)
13
+ %tt
14
+ - if email.sent_to.to_s.include?(", ")
15
+ = "To: ".html_safe << email.sent_to
16
+ - else
17
+ = "To ".html_safe << link_to_email(email.sent_to)
18
+ = "from ".html_safe << link_to_email(email.sent_from) << ", sent on ".html_safe
19
+ = l(email.sent_at, :format => :mmddhhss)
20
+ = " | ".html_safe + link_to_function(email.collapsed? ? t(:more) : t(:less), "crm.flip_note_or_email(this, '#{t(:more)}', '#{t(:less)}')", :class => "toggle")
18
21
 
19
- %dt{ hidden_if(email.expanded?), :id => dom_id(email, :truncated) }
20
- %p
21
- = h(email.subject)
22
- %tt= " - ".html_safe << truncated
23
- %dt.textile{ hidden_if(email.collapsed?), :id => dom_id(email, :formatted) }
24
- .email_content
25
- %p= h(email.subject)
26
- = auto_link(formatted)
22
+ %dt{ hidden_if(email.expanded?), :id => dom_id(email, :truncated) }
23
+ %p
24
+ = h(email.subject)
25
+ %tt= (" - " << truncated).html_safe
27
26
 
27
+ %dt.textile{ hidden_if(email.collapsed?), :id => dom_id(email, :formatted) }
28
+ .email_content
29
+ %p= h(email.subject)
30
+ = auto_link(formatted)