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.
- data/.gitignore +1 -0
- data/.travis.yml +2 -2
- data/Gemfile +15 -2
- data/Gemfile.lock +34 -14
- data/README.md +37 -124
- data/app/assets/javascripts/application.js.erb +1 -1
- data/app/assets/javascripts/crm.js +22 -1
- data/app/assets/javascripts/crm_fields.js +2 -3
- data/app/assets/javascripts/jquery-noconflict.js +17 -0
- data/app/assets/stylesheets/application.css.erb +1 -0
- data/app/assets/stylesheets/common.scss +26 -0
- data/app/assets/stylesheets/ffcrm_chosen.scss +1 -1
- data/app/controllers/admin/application_controller.rb +1 -1
- data/app/controllers/application_controller.rb +0 -8
- data/app/controllers/{accounts_controller.rb → entities/accounts_controller.rb} +1 -13
- data/app/controllers/{campaigns_controller.rb → entities/campaigns_controller.rb} +1 -13
- data/app/controllers/{contacts_controller.rb → entities/contacts_controller.rb} +1 -7
- data/app/controllers/{leads_controller.rb → entities/leads_controller.rb} +1 -1
- data/app/controllers/{opportunities_controller.rb → entities/opportunities_controller.rb} +1 -7
- data/app/controllers/{tasks_controller.rb → entities/tasks_controller.rb} +1 -1
- data/app/controllers/{base_controller.rb → entities_controller.rb} +32 -1
- data/app/controllers/home_controller.rb +9 -9
- data/app/controllers/lists_controller.rb +17 -0
- data/app/helpers/admin/tags_helper.rb +1 -1
- data/app/helpers/application_helper.rb +14 -14
- data/app/helpers/crm_tags_helper.rb +1 -1
- data/app/helpers/home_helper.rb +13 -15
- data/app/helpers/lists_helper.rb +17 -0
- data/app/inputs/date_time_input.rb +17 -0
- data/app/inputs/text_input.rb +17 -1
- data/app/models/{base → entities}/account.rb +0 -1
- data/app/models/{base → entities}/account_contact.rb +0 -0
- data/app/models/{base → entities}/account_opportunity.rb +0 -0
- data/app/models/{base → entities}/campaign.rb +0 -1
- data/app/models/{base → entities}/contact.rb +0 -1
- data/app/models/{base → entities}/contact_opportunity.rb +0 -0
- data/app/models/{base → entities}/lead.rb +0 -1
- data/app/models/{base → entities}/opportunity.rb +0 -1
- data/app/models/{base → entities}/task.rb +5 -6
- data/app/models/list.rb +17 -0
- data/app/models/observers/lead_observer.rb +39 -0
- data/app/models/observers/opportunity_observer.rb +54 -0
- data/app/models/observers/task_observer.rb +41 -0
- data/app/models/polymorphic/address.rb +1 -3
- data/app/models/polymorphic/avatar.rb +0 -5
- data/app/models/polymorphic/comment.rb +2 -11
- data/app/models/polymorphic/email.rb +2 -9
- data/app/models/polymorphic/tag.rb +17 -0
- data/app/models/polymorphic/tagging.rb +17 -0
- data/app/models/users/ability.rb +13 -0
- data/app/models/users/user.rb +1 -4
- data/app/views/accounts/_account.html.haml +10 -6
- data/app/views/accounts/index.html.haml +1 -1
- data/app/views/accounts/show.html.haml +6 -24
- data/app/views/admin/fields/_field.html.haml +6 -6
- data/app/views/admin/tags/_tag.html.haml +2 -2
- data/app/views/admin/tags/index.html.haml +1 -1
- data/app/views/admin/users/_user.html.haml +3 -3
- data/app/views/admin/users/index.html.haml +1 -1
- data/app/views/campaigns/_campaign.html.haml +9 -5
- data/app/views/campaigns/index.html.haml +1 -1
- data/app/views/campaigns/show.html.haml +4 -24
- data/app/views/comments/_comment.html.haml +17 -14
- data/app/views/comments/_edit.html.haml +1 -1
- data/app/views/comments/_new.html.haml +3 -3
- data/app/views/contacts/_contact.html.haml +33 -15
- data/app/views/contacts/_contacts.html.haml +6 -0
- data/app/views/contacts/_sidebar_show.html.haml +1 -1
- data/app/views/contacts/index.html.haml +1 -1
- data/app/views/contacts/show.html.haml +3 -19
- data/app/views/emails/_email.html.haml +24 -21
- data/app/views/{base → entities}/_advanced_search.html.haml +0 -0
- data/app/views/{base → entities}/_condition_fields.html.haml +0 -0
- data/app/views/{base → entities}/_grouping_fields.html.haml +0 -0
- data/app/views/{base → entities}/_sort_fields.html.haml +0 -0
- data/app/views/{base → entities}/advanced_search.js.rjs +0 -0
- data/app/views/entities/contacts.js.rjs +3 -0
- data/app/views/entities/leads.js.rjs +3 -0
- data/app/views/entities/opportunities.js.rjs +3 -0
- data/app/views/entities/versions.js.rjs +3 -0
- data/app/views/home/_activity.html.haml +19 -18
- data/app/views/home/_events_menu.html.haml +8 -0
- data/app/views/home/_options.html.haml +2 -3
- data/app/views/home/index.html.haml +1 -1
- data/app/views/leads/_lead.html.haml +42 -23
- data/app/views/leads/_leads.html.haml +6 -0
- data/app/views/leads/_sidebar_show.html.haml +1 -1
- data/app/views/leads/index.html.haml +1 -1
- data/app/views/leads/show.html.haml +3 -13
- data/app/views/opportunities/_opportunities.html.haml +6 -0
- data/app/views/opportunities/_opportunity.html.haml +23 -11
- data/app/views/opportunities/index.html.haml +1 -1
- data/app/views/opportunities/show.html.haml +4 -18
- data/app/views/shared/_comment.html.haml +3 -3
- data/app/views/shared/_edit_comment.html.haml +1 -1
- data/app/views/shared/_recent.html.haml +4 -4
- data/app/views/shared/_recently.html.haml +3 -3
- data/app/views/shared/_timeline.html.haml +2 -3
- data/app/views/tasks/_assigned.html.haml +4 -4
- data/app/views/tasks/_completed.html.haml +2 -2
- data/app/views/tasks/_pending.html.haml +2 -2
- data/app/views/tasks/_related.html.haml +4 -5
- data/app/views/tasks/_tasks.html.haml +3 -0
- data/app/views/tasks/_title.html.haml +1 -1
- data/app/views/tasks/index.html.haml +1 -1
- data/app/views/users/_avatar.html.haml +2 -2
- data/app/views/versions/_version.html.haml +9 -12
- data/app/views/versions/_versions.html.haml +11 -0
- data/config/application.rb +3 -2
- data/config/environments/development.rb +2 -2
- data/config/environments/production.rb +0 -4
- data/config/environments/staging.rb +1 -1
- data/config/initializers/action_mailer.rb +9 -0
- data/config/initializers/paper_trail.rb +80 -0
- data/config/initializers/relative_url_root.rb +23 -0
- data/config/locales/cz_fat_free_crm.yml +1 -1
- data/config/locales/en-US_fat_free_crm.yml +22 -17
- data/config/locales/fr_fat_free_crm.yml +349 -134
- data/config/routes.rb +144 -140
- data/config/settings.default.yml +14 -2
- data/db/demo/addresses.yml +2 -2
- data/db/demo/emails.yml +2 -2
- data/db/migrate/20120216042541_is_paranoid_to_paper_trail.rb +1 -2
- data/db/migrate/20120309070209_add_versions_related.rb +6 -0
- data/db/migrate/20120316045804_activities_to_versions.rb +35 -0
- data/db/schema.rb +79 -53
- data/fat_free_crm.gemspec +8 -4
- data/lib/development_tasks/gem.rake +18 -1
- data/lib/development_tasks/license.rake +2 -4
- data/lib/development_tasks/rdoc.rake +17 -0
- data/lib/development_tasks/rspec.rake +17 -0
- data/lib/fat_free_crm.rb +20 -14
- data/lib/fat_free_crm/core_ext/array.rb +0 -27
- data/lib/fat_free_crm/dropbox.rb +11 -1
- data/lib/fat_free_crm/engine.rb +21 -3
- data/lib/fat_free_crm/gem_dependencies.rb +26 -0
- data/lib/fat_free_crm/gem_ext.rb +18 -1
- data/lib/fat_free_crm/gem_ext/active_record/schema_dumper.rb +18 -1
- data/lib/fat_free_crm/gem_ext/authlogic/session/cookies.rb +17 -0
- data/lib/fat_free_crm/gem_ext/rails/engine.rb +17 -0
- data/lib/fat_free_crm/gem_ext/rails/text_helper.rb +17 -0
- data/lib/fat_free_crm/gem_ext/rake/task.rb +17 -0
- data/lib/fat_free_crm/gem_ext/simple_form/action_view_extensions/form_helper.rb +18 -1
- data/lib/fat_free_crm/plugin_dependencies.rb +23 -5
- data/lib/fat_free_crm/renderers.rb +17 -0
- data/lib/fat_free_crm/syck_yaml.rb +17 -0
- data/lib/fat_free_crm/version.rb +1 -1
- data/lib/{country_select → plugins/country_select}/MIT-LICENSE +0 -0
- data/lib/{country_select → plugins/country_select}/README +0 -0
- data/lib/{country_select → plugins/country_select}/init.rb +0 -0
- data/lib/{country_select → plugins/country_select}/install.rb +0 -0
- data/lib/{country_select → plugins/country_select}/lib/country_select.rb +0 -0
- data/lib/{country_select → plugins/country_select}/uninstall.rb +0 -0
- data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/Gemfile +0 -0
- data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/README.textile +0 -0
- data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/ROADMAP.textile +0 -0
- data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/Rakefile +0 -0
- data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/VERSION +0 -0
- data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/gravatar_image_tag.gemspec +0 -0
- data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/init.rb +0 -0
- data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/lib/gravatar_image_tag.rb +0 -0
- data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/spec/gravatar_image_tag_spec.rb +0 -0
- data/lib/{gravatar_image_tag → plugins/gravatar_image_tag}/spec/test_helper.rb +0 -0
- data/lib/tasks/demo.rake +32 -29
- data/lib/tasks/dropbox.rake +1 -1
- data/lib/tasks/fat_free_crm.rake +3 -2
- data/lib/tasks/plugins.rake +1 -0
- data/spec/controllers/accounts_controller_spec.rb +7 -5
- data/spec/controllers/campaigns_controller_spec.rb +11 -9
- data/spec/controllers/contacts_controller_spec.rb +7 -5
- data/spec/controllers/home_controller_spec.rb +2 -2
- data/spec/controllers/leads_controller_spec.rb +7 -5
- data/spec/controllers/opportunities_controller_spec.rb +7 -5
- data/spec/factories/shared_factories.rb +8 -11
- data/spec/lib/dropbox_spec.rb +1 -0
- data/spec/models/polymorphic/version_spec.rb +247 -0
- data/spec/models/users/user_spec.rb +0 -9
- data/spec/spec_helper.rb +4 -0
- data/spec/views/home/index.haml_spec.rb +1 -1
- data/spec/views/home/index.rjs_spec.rb +4 -4
- data/spec/views/tasks/new.rjs_spec.rb +2 -2
- data/vendor/assets/javascripts/calendar_date_select/format_french.js +24 -0
- metadata +167 -126
- data/app/models/observers/activity_observer.rb +0 -84
- data/app/models/polymorphic/activity.rb +0 -106
- data/app/views/accounts/contacts.js.rjs +0 -3
- data/app/views/accounts/opportunities.js.rjs +0 -3
- data/app/views/campaigns/leads.js.rjs +0 -3
- data/app/views/campaigns/opportunities.js.rjs +0 -3
- data/app/views/contacts/opportunities.js.rjs +0 -3
- data/app/views/home/_actions_menu.html.haml +0 -8
- data/lib/dynamic_form/MIT-LICENSE +0 -20
- data/lib/dynamic_form/README +0 -13
- data/lib/dynamic_form/Rakefile +0 -10
- data/lib/dynamic_form/dynamic_form.gemspec +0 -12
- data/lib/dynamic_form/init.rb +0 -2
- data/lib/dynamic_form/lib/action_view/helpers/dynamic_form.rb +0 -301
- data/lib/dynamic_form/lib/action_view/locale/en-US.yml +0 -8
- data/lib/dynamic_form/lib/dynamic_form.rb +0 -6
- data/lib/dynamic_form/test/dynamic_form_i18n_test.rb +0 -42
- data/lib/dynamic_form/test/dynamic_form_test.rb +0 -370
- data/lib/dynamic_form/test/test_helper.rb +0 -10
- data/lib/responds_to_parent/MIT-LICENSE +0 -20
- data/lib/responds_to_parent/README +0 -47
- data/lib/responds_to_parent/Rakefile +0 -22
- data/lib/responds_to_parent/init.rb +0 -2
- data/lib/responds_to_parent/install.rb +0 -2
- data/lib/responds_to_parent/lib/responds_to_parent.rb +0 -70
- data/lib/responds_to_parent/test/responds_to_parent_test.rb +0 -11
- data/lib/responds_to_parent/test/test_helper.rb +0 -7
- data/lib/responds_to_parent/uninstall.rb +0 -2
- 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 =>
|
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
|
-
=
|
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
|
-
=
|
18
|
+
= render :partial => "contacts/contacts", :locals => {:object => @account}
|
19
|
+
|
20
|
+
= render :partial => "opportunities/opportunities", :locals => {:object => @account}
|
33
21
|
|
34
|
-
|
22
|
+
= render :partial => "versions/versions", :locals => {:object => @account}
|
35
23
|
|
36
|
-
|
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]
|
1
|
+
%li.highlight.position[field]
|
2
2
|
%span.handle
|
3
3
|
%img( src="/assets/sortable.gif" )
|
4
|
-
|
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
|
-
|
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]
|
5
|
-
.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 =>
|
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]
|
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 =>
|
12
|
+
= avatar_for(user, :size => :medium, :width => 30, :height => 30 )
|
13
13
|
|
14
14
|
.indentfull
|
15
|
-
.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 =>
|
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]
|
1
|
+
%li.highlight[campaign]
|
2
2
|
.strip{:class => campaign.status}= t(campaign.status)
|
3
3
|
|
4
|
-
.tools
|
5
|
-
|
6
|
-
|
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(
|
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 =>
|
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
|
-
=
|
17
|
-
.log#tasks
|
18
|
-
= render "shared/tasks"
|
16
|
+
= render :partial => "tasks/tasks", :locals => {:object => @campaign}
|
19
17
|
|
20
|
-
=
|
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
|
-
|
20
|
+
= render :partial => "opportunities/opportunities", :locals => {:object => @campaign}
|
27
21
|
|
28
|
-
=
|
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]
|
6
|
+
%li.comment.highlight[comment]
|
6
7
|
.body
|
7
|
-
= link_to avatar_for(comment.user, :size =>
|
8
|
-
.tools
|
9
|
-
|
10
|
-
|
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
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
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 =>
|
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{
|
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 =>
|
11
|
-
.tools
|
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]
|
3
|
+
%li.highlight[contact]
|
4
4
|
= gravatar_for(contact, :size => gravatar_size)
|
5
5
|
|
6
|
-
.tools
|
6
|
+
%ul.tools
|
7
7
|
= hook(:contact_tools_before, self, :contact => contact)
|
8
|
-
|
9
|
-
|
10
|
-
|
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
|
-
=
|
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
|
-
|
22
|
+
== #{contact.title}, #{contact.department}
|
17
23
|
- else
|
18
|
-
=
|
19
|
-
|
20
|
-
|
21
|
-
|
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
|
–
|
23
|
-
|
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
|
-
|
27
|
-
|
28
|
-
|
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}
|
@@ -8,7 +8,7 @@
|
|
8
8
|
|
9
9
|
.title
|
10
10
|
%span#create_contact_title #{t :contacts}
|
11
|
-
= image_tag("loading.gif", :size =>
|
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
|
-
=
|
17
|
-
.log#tasks
|
18
|
-
= render "shared/tasks"
|
16
|
+
= render :partial => "tasks/tasks", :locals => {:object => @contact}
|
19
17
|
|
20
|
-
|
18
|
+
= render :partial => "opportunities/opportunities", :locals => {:object => @contact}
|
21
19
|
|
22
|
-
=
|
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 =
|
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
|
5
|
+
%li.mail.highlight[email]
|
5
6
|
.body
|
6
|
-
= link_to avatar_for(email.user, :size =>
|
7
|
-
.tools
|
8
|
-
|
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
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
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
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
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)
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|