fat_free_crm 0.11.3 → 0.11.4
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/CHANGELOG +6 -1
- data/CONTRIBUTORS +40 -1
- data/Capfile +5 -0
- data/Gemfile +25 -6
- data/Gemfile.lock +128 -86
- data/README.md +23 -16
- data/{vendor → app}/assets/images/delete.png +0 -0
- data/app/assets/javascripts/admin/fields.js.coffee +62 -0
- data/app/assets/javascripts/application.js.erb +8 -1
- data/app/assets/javascripts/crm.js +44 -46
- data/app/assets/javascripts/crm_chosen.js.coffee +10 -7
- data/app/assets/javascripts/datepicker.js.coffee +15 -0
- data/app/assets/javascripts/format_buttons.js.coffee +48 -0
- data/app/assets/javascripts/{admin/field_groups.js.coffee → groups.js.coffee} +0 -0
- data/app/assets/javascripts/lists.js.coffee +1 -1
- data/app/assets/javascripts/search.js.coffee +56 -38
- data/app/assets/stylesheets/admin/{field_groups.css.scss → fields.css.scss} +4 -0
- data/app/assets/stylesheets/advanced_search.css.scss +79 -0
- data/app/assets/stylesheets/application.css.erb +4 -0
- data/app/assets/stylesheets/base.scss +3 -3
- data/app/assets/stylesheets/common.scss +72 -25
- data/app/assets/stylesheets/fields.scss +14 -0
- data/app/assets/stylesheets/format_buttons.css.scss +30 -0
- data/app/assets/stylesheets/groups.css.scss +3 -0
- data/app/assets/stylesheets/header.scss +7 -6
- data/{vendor/plugins/.gitkeep → app/assets/stylesheets/index_headers.css.scss} +0 -0
- data/app/assets/stylesheets/print.css.scss +12 -3
- data/app/assets/stylesheets/rails.scss +12 -3
- data/app/controllers/admin/application_controller.rb +1 -1
- data/app/controllers/admin/field_groups_controller.rb +2 -0
- data/app/controllers/admin/fields_controller.rb +41 -17
- data/app/controllers/admin/groups_controller.rb +70 -0
- data/app/controllers/admin/tags_controller.rb +1 -0
- data/app/controllers/admin/users_controller.rb +8 -7
- data/app/controllers/application_controller.rb +34 -5
- data/app/controllers/comments_controller.rb +2 -3
- data/app/controllers/entities/accounts_controller.rb +30 -37
- data/app/controllers/entities/campaigns_controller.rb +56 -29
- data/app/controllers/entities/contacts_controller.rb +24 -26
- data/app/controllers/entities/leads_controller.rb +38 -37
- data/app/controllers/entities/opportunities_controller.rb +28 -34
- data/app/controllers/entities_controller.rb +71 -43
- data/app/controllers/home_controller.rb +29 -27
- data/app/controllers/tasks_controller.rb +18 -17
- data/app/controllers/users_controller.rb +12 -8
- data/app/helpers/accounts_helper.rb +58 -16
- data/app/helpers/addresses_helper.rb +4 -1
- data/app/helpers/admin/fields_helper.rb +3 -4
- data/app/helpers/application_helper.rb +147 -100
- data/app/helpers/campaigns_helper.rb +2 -9
- data/app/helpers/fields_helper.rb +0 -1
- data/app/helpers/groups_helper.rb +2 -0
- data/app/helpers/home_helper.rb +11 -0
- data/app/helpers/leads_helper.rb +2 -9
- data/app/helpers/opportunities_helper.rb +2 -9
- data/app/helpers/{crm_tags_helper.rb → tags_helper.rb} +9 -8
- data/app/helpers/tasks_helper.rb +5 -21
- data/app/helpers/users_helper.rb +14 -7
- data/app/helpers/versions_helper.rb +46 -0
- data/app/inputs/date_time_input.rb +8 -25
- data/app/inputs/datepair_input.rb +77 -0
- data/app/inputs/datetimepair_input.rb +37 -0
- data/app/mailers/user_mailer.rb +10 -0
- data/app/models/entities/account.rb +18 -11
- data/app/models/entities/account_contact.rb +4 -3
- data/app/models/entities/account_opportunity.rb +0 -1
- data/app/models/entities/campaign.rb +6 -7
- data/app/models/entities/contact.rb +53 -25
- data/app/models/entities/contact_opportunity.rb +0 -1
- data/app/models/entities/lead.rb +24 -13
- data/app/models/entities/opportunity.rb +34 -16
- data/app/models/fields/custom_field.rb +29 -13
- data/app/models/fields/custom_field_date_pair.rb +58 -0
- data/app/models/fields/custom_field_datetime_pair.rb +28 -0
- data/app/models/fields/custom_field_pair.rb +54 -0
- data/app/models/fields/field.rb +60 -43
- data/app/models/fields/field_group.rb +0 -9
- data/app/models/observers/entity_observer.rb +29 -0
- data/app/models/observers/opportunity_observer.rb +3 -0
- data/app/models/polymorphic/address.rb +14 -0
- data/app/models/polymorphic/avatar.rb +13 -1
- data/app/models/polymorphic/email.rb +1 -1
- data/app/models/polymorphic/task.rb +14 -13
- data/app/models/setting.rb +14 -21
- data/app/models/users/ability.rb +25 -4
- data/app/models/users/group.rb +13 -0
- data/app/models/users/permission.rb +3 -1
- data/app/models/users/preference.rb +1 -2
- data/app/models/users/user.rb +25 -3
- data/app/views/accounts/_account.html.haml +5 -39
- data/app/views/accounts/_edit.html.haml +3 -2
- data/app/views/accounts/_index_brief.html.haml +32 -0
- data/app/views/accounts/_index_long.html.haml +42 -0
- data/app/views/accounts/_new.html.haml +3 -2
- data/app/views/accounts/_sidebar_index.html.haml +3 -4
- data/app/views/accounts/_sidebar_show.html.haml +2 -2
- data/app/views/accounts/_title_bar.html.haml +11 -0
- data/app/views/accounts/_top_section.html.haml +1 -1
- data/app/views/accounts/create.js.rjs +1 -2
- data/app/views/accounts/destroy.js.rjs +1 -1
- data/app/views/accounts/edit.js.rjs +0 -2
- data/app/views/accounts/index.html.haml +6 -13
- data/app/views/accounts/index.js.rjs +3 -1
- data/app/views/accounts/index.xls.builder +82 -0
- data/app/views/accounts/new.js.rjs +0 -2
- data/app/views/accounts/show.html.haml +17 -15
- data/app/views/accounts/show.js.erb +2 -0
- data/app/views/admin/custom_fields/_base_field.html.haml +21 -0
- data/app/views/admin/custom_fields/_check_boxes_field.html.haml +6 -0
- data/app/views/admin/custom_fields/_date_field.html.haml +14 -0
- data/app/views/admin/custom_fields/_date_pair_field.html.haml +21 -0
- data/app/views/admin/custom_fields/_datetime_field.html.haml +14 -0
- data/app/views/admin/custom_fields/_datetime_pair_field.html.haml +21 -0
- data/app/views/admin/custom_fields/_radio_field.html.haml +6 -0
- data/app/views/admin/custom_fields/_select_field.html.haml +25 -0
- data/app/views/admin/custom_fields/_string_field.html.haml +2 -0
- data/app/views/admin/field_groups/_field_group.html.haml +7 -5
- data/app/views/admin/field_groups/_top_section.html.haml +4 -3
- data/app/views/admin/field_groups/create.js.rjs +1 -2
- data/app/views/admin/fields/_field.html.haml +5 -3
- data/app/views/admin/fields/_form.html.haml +35 -0
- data/app/views/admin/fields/_subform.html.haml +6 -0
- data/app/views/admin/fields/create.js.erb +19 -0
- data/app/views/admin/fields/destroy.js.erb +9 -0
- data/app/views/admin/fields/edit.js.erb +1 -0
- data/app/views/admin/fields/index.html.haml +11 -8
- data/app/views/admin/fields/update.js.erb +13 -0
- data/app/views/admin/groups/_edit.html.haml +12 -0
- data/app/views/admin/groups/_form.html.haml +13 -0
- data/app/views/admin/groups/_group.html.haml +15 -0
- data/app/views/admin/groups/_new.html.haml +12 -0
- data/app/views/admin/groups/create.js.rjs +11 -0
- data/app/views/admin/{fields → groups}/destroy.js.rjs +3 -3
- data/app/views/admin/groups/edit.js.rjs +21 -0
- data/app/views/admin/groups/index.html.haml +18 -0
- data/app/views/admin/groups/index.js.rjs +2 -0
- data/app/views/admin/groups/new.js.rjs +9 -0
- data/app/views/admin/groups/show.html.haml +11 -0
- data/app/views/admin/groups/update.js.rjs +10 -0
- data/app/views/admin/users/_profile.html.haml +13 -1
- data/app/views/admin/users/_user.html.haml +7 -2
- data/app/views/admin/users/index.js.rjs +1 -0
- data/app/views/application/index.atom.builder +1 -1
- data/app/views/application/index.rss.builder +1 -1
- data/app/views/application/show.atom.builder +32 -0
- data/app/views/application/show.rss.builder +29 -0
- data/app/views/campaigns/_campaign.html.haml +5 -21
- data/app/views/campaigns/_edit.html.haml +3 -2
- data/app/views/campaigns/_index_brief.html.haml +15 -0
- data/app/views/campaigns/_index_long.html.haml +20 -0
- data/app/views/campaigns/_new.html.haml +4 -2
- data/app/views/campaigns/_sidebar_index.html.haml +3 -3
- data/app/views/campaigns/_title_bar.html.haml +11 -0
- data/app/views/campaigns/_top_section.html.haml +2 -2
- data/app/views/campaigns/create.js.rjs +1 -4
- data/app/views/campaigns/destroy.js.rjs +1 -1
- data/app/views/campaigns/edit.js.rjs +0 -4
- data/app/views/campaigns/index.html.haml +6 -13
- data/app/views/campaigns/index.js.rjs +3 -1
- data/app/views/campaigns/index.xls.builder +75 -0
- data/app/views/campaigns/new.js.rjs +0 -4
- data/app/views/campaigns/show.html.haml +17 -15
- data/app/views/campaigns/show.js.erb +2 -0
- data/app/views/campaigns/update.js.rjs +0 -2
- data/app/views/comments/_comment.html.haml +6 -5
- data/app/views/comments/_edit.html.haml +5 -5
- data/app/views/comments/_new.html.haml +6 -5
- data/app/views/comments/create.js.rjs +1 -1
- data/app/views/contacts/_contact.html.haml +5 -52
- data/app/views/contacts/_contacts.html.haml +1 -0
- data/app/views/contacts/_edit.html.haml +3 -2
- data/app/views/contacts/_index_brief.html.haml +25 -0
- data/app/views/contacts/_index_full.html.haml +57 -0
- data/app/views/contacts/_index_long.html.haml +43 -0
- data/app/views/contacts/_new.html.haml +4 -2
- data/app/views/contacts/_section_extra.html.haml +26 -0
- data/app/views/contacts/_section_general.html.haml +22 -0
- data/app/views/contacts/_sidebar_index.html.haml +0 -3
- data/app/views/contacts/_sidebar_show.html.haml +2 -10
- data/app/views/contacts/_title_bar.html.haml +11 -0
- data/app/views/contacts/_top_section.html.haml +1 -1
- data/app/views/contacts/create.js.rjs +1 -2
- data/app/views/contacts/destroy.js.rjs +1 -1
- data/app/views/contacts/edit.js.rjs +0 -2
- data/app/views/contacts/index.html.haml +6 -14
- data/app/views/contacts/index.js.rjs +3 -1
- data/app/views/contacts/index.xls.builder +102 -0
- data/app/views/contacts/new.js.rjs +0 -2
- data/app/views/contacts/show.html.haml +15 -15
- data/app/views/contacts/show.js.erb +2 -0
- data/app/views/entities/_basic_search.html.haml +22 -0
- data/app/views/entities/_permissions.html.haml +41 -0
- data/app/views/entities/_search.html.haml +15 -0
- data/app/views/entities/_section_custom_fields.html.haml +11 -0
- data/app/views/entities/_title_bar.html.haml +12 -0
- data/app/views/entities/attach.js.rjs +1 -1
- data/app/views/entities/opportunities.js.rjs +1 -1
- data/app/views/entities/versions.js.erb +3 -0
- data/app/views/fields/_edit_custom_field_group.html.haml +8 -0
- data/app/views/fields/_group.html.haml +11 -20
- data/app/views/fields/_group_table.html.haml +13 -0
- data/app/views/fields/_group_view.html.haml +7 -0
- data/app/views/fields/_groups.html.haml +1 -4
- data/app/views/fields/_sidebar_show.html.haml +5 -4
- data/app/views/home/_account.html.haml +29 -0
- data/app/views/home/_activity.html.haml +16 -6
- data/app/views/home/_opportunity.html.haml +41 -0
- data/app/views/home/_options.html.haml +1 -1
- data/app/views/home/_task.html.haml +46 -0
- data/app/views/home/index.html.haml +32 -1
- data/app/views/home/index.js.rjs +1 -0
- data/app/views/layouts/_header.html.haml +3 -3
- data/app/views/layouts/_sidebar.html.haml +1 -3
- data/app/views/layouts/_tabbed.html.haml +2 -3
- data/app/views/layouts/_tabless.html.haml +1 -1
- data/app/views/layouts/admin/_header.html.haml +1 -1
- data/app/views/layouts/application.html.haml +7 -8
- data/app/views/layouts/header.xls.builder +8 -0
- data/app/views/leads/_contact.html.haml +1 -2
- data/app/views/leads/_convert.html.haml +1 -2
- data/app/views/leads/_convert_permissions.html.haml +21 -11
- data/app/views/leads/_edit.html.haml +3 -2
- data/app/views/leads/_index_brief.html.haml +41 -0
- data/app/views/leads/_index_long.html.haml +62 -0
- data/app/views/leads/_lead.html.haml +5 -62
- data/app/views/leads/_new.html.haml +4 -2
- data/app/views/leads/_opportunity.html.haml +1 -1
- data/app/views/leads/_sidebar_index.html.haml +3 -3
- data/app/views/leads/_sidebar_show.html.haml +3 -3
- data/app/views/leads/_status.html.haml +1 -1
- data/app/views/leads/_title_bar.html.haml +16 -0
- data/app/views/leads/convert.js.rjs +0 -1
- data/app/views/leads/create.js.rjs +1 -2
- data/app/views/leads/destroy.js.rjs +1 -1
- data/app/views/leads/edit.js.rjs +0 -2
- data/app/views/leads/index.html.haml +6 -13
- data/app/views/leads/index.js.rjs +3 -1
- data/app/views/leads/index.xls.builder +100 -0
- data/app/views/leads/new.js.rjs +0 -2
- data/app/views/leads/promote.js.rjs +0 -1
- data/app/views/leads/show.html.haml +13 -18
- data/app/views/leads/show.js.erb +2 -0
- data/app/views/{shared/_lists.html.haml → lists/_sidebar.html.haml} +0 -0
- data/app/views/lists/create.js.rjs +1 -1
- data/app/views/opportunities/_edit.html.haml +3 -2
- data/app/views/opportunities/_index_brief.html.haml +29 -0
- data/app/views/opportunities/_index_long.html.haml +59 -0
- data/app/views/opportunities/_new.html.haml +4 -2
- data/app/views/opportunities/_opportunity.html.haml +5 -57
- data/app/views/opportunities/_sidebar_index.html.haml +3 -3
- data/app/views/opportunities/_sidebar_show.html.haml +2 -2
- data/app/views/opportunities/_title_bar.html.haml +11 -0
- data/app/views/opportunities/_top_section.html.haml +2 -2
- data/app/views/opportunities/create.js.rjs +4 -6
- data/app/views/opportunities/destroy.js.rjs +1 -1
- data/app/views/opportunities/edit.js.rjs +0 -3
- data/app/views/opportunities/index.html.haml +6 -14
- data/app/views/opportunities/index.js.rjs +3 -1
- data/app/views/opportunities/index.xls.builder +69 -0
- data/app/views/opportunities/new.js.rjs +1 -5
- data/app/views/opportunities/show.html.haml +14 -14
- data/app/views/opportunities/show.js.erb +2 -0
- data/app/views/opportunities/update.js.rjs +0 -1
- data/app/views/passwords/new.html.haml +1 -1
- data/app/views/shared/_add_comment.html.haml +8 -0
- data/app/views/shared/_address.html.haml +1 -1
- data/app/views/shared/_address_show.html.haml +1 -1
- data/app/views/shared/_edit_comment.html.haml +2 -2
- data/app/views/shared/_export.html.haml +2 -1
- data/app/views/shared/_paginate_with_per_page.html.haml +14 -0
- data/app/views/shared/_recently.html.haml +1 -1
- data/app/views/shared/_search.html.haml +1 -1
- data/app/views/shared/_tags.html.haml +1 -2
- data/app/views/shared/_tasks.html.haml +2 -2
- data/app/views/tasks/_completed.html.haml +3 -3
- data/app/views/tasks/_new.html.haml +1 -1
- data/app/views/tasks/_pending.html.haml +2 -3
- data/app/views/tasks/_sidebar_index.html.haml +2 -2
- data/app/views/tasks/_top_section.html.haml +5 -3
- data/app/views/tasks/create.js.rjs +3 -4
- data/app/views/tasks/edit.js.rjs +2 -4
- data/app/views/tasks/index.html.haml +1 -1
- data/app/views/tasks/index.xls.builder +47 -0
- data/app/views/tasks/new.js.rjs +0 -2
- data/app/views/tasks/update.js.rjs +0 -1
- data/app/views/user_mailer/assigned_entity_notification.html.haml +3 -0
- data/app/views/users/_user.html.haml +2 -2
- data/app/views/users/_user_report.html.haml +6 -0
- data/app/views/users/opportunities_overview.html.haml +16 -0
- data/app/views/users/show.html.haml +2 -3
- data/app/views/users/update.js.rjs +1 -1
- data/app/views/versions/_version.html.haml +4 -19
- data/app/views/versions/_version_item.html.haml +8 -0
- data/app/views/versions/_versions.html.haml +9 -9
- data/config/application.rb +10 -2
- data/config/deploy.example.rb +47 -0
- data/config/environments/development.rb +1 -0
- data/config/environments/production.rb +1 -3
- data/config/environments/staging.rb +1 -1
- data/config/initializers/action_mailer.rb +10 -8
- data/config/initializers/custom_fields.rb +21 -0
- data/config/initializers/gravatar.rb +7 -0
- data/config/initializers/paper_trail.rb +1 -0
- data/config/initializers/ransack.rb +15 -0
- data/config/initializers/simple_form.rb +1 -2
- data/config/initializers/views.rb +42 -0
- data/config/locales/cz_fat_free_crm.yml +0 -10
- data/config/locales/de_fat_free_crm.yml +23 -21
- data/config/locales/en-GB_fat_free_crm.yml +241 -25
- data/config/locales/en-US_fat_free_crm.yml +139 -57
- data/config/locales/en-US_ransack.yml +92 -0
- data/config/locales/es_fat_free_crm.yml +0 -6
- data/config/locales/fr-CA_fat_free_crm.yml +0 -6
- data/config/locales/fr_fat_free_crm.yml +3 -14
- data/config/locales/it_fat_free_crm.yml +0 -11
- data/config/locales/ja_fat_free_crm.yml +0 -10
- data/config/locales/pl_fat_free_crm.yml +0 -6
- data/config/locales/pt-BR_fat_free_crm.yml +0 -6
- data/config/locales/ru_fat_free_crm.yml +0 -9
- data/config/locales/sv-SE_fat_free_crm.yml +0 -10
- data/config/locales/th_fat_free_crm.yml +0 -6
- data/config/locales/zh-CN.yml +4 -0
- data/config/locales/zh-CN_fat_free_crm.yml +78 -47
- data/config/routes.rb +13 -0
- data/config/settings.default.yml +20 -20
- data/db/demo/addresses.yml +2 -2
- data/db/migrate/20100928030598_create_sessions.rb +5 -0
- data/db/migrate/20100928030627_acts_as_taggable_on_migration.rb +6 -6
- data/db/migrate/20111201030535_add_field_groups_klass_name.rb +2 -1
- data/db/migrate/20120406082136_create_groups.rb +19 -0
- data/db/migrate/20120510025219_add_not_null_constraints_for_timestamp_columns.rb +21 -0
- data/db/migrate/20120528102124_increase_length_of_version_events.rb +9 -0
- data/db/migrate/20120801032706_add_pair_id_to_fields.rb +5 -0
- data/db/migrate/20121003063155_add_settings_to_custom_fields.rb +5 -0
- data/db/migrate/20121221033947_fix_country_mapping.rb +32 -0
- data/db/schema.rb +25 -6
- data/fat_free_crm.gemspec +16 -13
- data/lib/fat_free_crm.rb +2 -0
- data/lib/fat_free_crm/comment_extensions.rb +23 -0
- data/lib/fat_free_crm/core_ext/array.rb +8 -2
- data/lib/fat_free_crm/fields.rb +24 -2
- data/lib/fat_free_crm/gem_dependencies.rb +7 -1
- data/lib/fat_free_crm/permissions.rb +47 -26
- data/lib/fat_free_crm/version.rb +1 -1
- data/lib/fat_free_crm/view_factory.rb +95 -0
- data/lib/plugins/country_select/lib/country_select.rb +393 -374
- data/lib/tasks/{plugins.rake → db/migrate.rake} +1 -1
- data/lib/tasks/{schema_upgrade.rake → db/schema.rake} +2 -1
- data/lib/tasks/{mail_processing.rake → ffcrm/comment_replies.rake} +2 -21
- data/lib/tasks/ffcrm/config.rake +33 -0
- data/lib/tasks/{demo.rake → ffcrm/demo.rake} +3 -2
- data/lib/tasks/ffcrm/dropbox.rake +42 -0
- data/lib/tasks/ffcrm/settings.rake +46 -0
- data/lib/tasks/{fat_free_crm.rake → ffcrm/setup.rake} +1 -39
- data/lib/tasks/ffcrm/update_data.rake +256 -0
- data/{acceptance → spec/acceptance}/acceptance_helper.rb +5 -4
- data/{acceptance → spec/acceptance}/accounts_spec.rb +36 -10
- data/spec/acceptance/admin/groups_spec.rb +26 -0
- data/spec/acceptance/admin/users_spec.rb +34 -0
- data/spec/acceptance/campaigns_spec.rb +101 -0
- data/spec/acceptance/contacts_spec.rb +101 -0
- data/spec/acceptance/dashboard_spec.rb +62 -0
- data/spec/acceptance/leads_spec.rb +109 -0
- data/spec/acceptance/opportunities_overview_spec.rb +82 -0
- data/spec/acceptance/opportunities_spec.rb +103 -0
- data/{acceptance → spec/acceptance}/support/browser.rb +0 -0
- data/{acceptance → spec/acceptance}/support/headless.rb +0 -0
- data/{acceptance → spec/acceptance}/support/helpers.rb +8 -1
- data/{acceptance → spec/acceptance}/support/maintain_sessions.rb +0 -0
- data/spec/acceptance/support/paths.rb +42 -0
- data/spec/acceptance/support/selector_helpers.rb +31 -0
- data/spec/acceptance/tasks_spec.rb +85 -0
- data/spec/controllers/admin/groups_controller_spec.rb +5 -0
- data/spec/controllers/admin/users_controller_spec.rb +2 -3
- data/spec/controllers/applications_controller_spec.rb +40 -0
- data/spec/controllers/comments_controller_spec.rb +5 -6
- data/spec/controllers/emails_controller_spec.rb +1 -2
- data/spec/controllers/entities/accounts_controller_spec.rb +65 -81
- data/spec/controllers/entities/campaigns_controller_spec.rb +69 -85
- data/spec/controllers/entities/contacts_controller_spec.rb +78 -95
- data/spec/controllers/entities/leads_controller_spec.rb +105 -127
- data/spec/controllers/entities/opportunities_controller_spec.rb +88 -103
- data/spec/controllers/entities_controller_spec.rb +39 -0
- data/spec/controllers/home_controller_spec.rb +101 -11
- data/spec/controllers/tasks_controller_spec.rb +27 -32
- data/spec/controllers/users_controller_spec.rb +95 -28
- data/spec/factories/account_factories.rb +2 -2
- data/spec/factories/opportunity_factories.rb +12 -4
- data/spec/factories/task_factories.rb +4 -0
- data/spec/factories/user_factories.rb +9 -2
- data/spec/helpers/application_helper_spec.rb +15 -1
- data/spec/helpers/groups_helper_spec.rb +15 -0
- data/spec/helpers/users_helper_spec.rb +26 -4
- data/spec/lib/comment_extensions_spec.rb +29 -0
- data/spec/lib/core_ext/{string.rb → string_spec.rb} +0 -1
- data/spec/lib/fields_spec.rb +104 -0
- data/spec/lib/permissions_spec.rb +144 -0
- data/spec/lib/view_factory_spec.rb +68 -0
- data/spec/mailers/subscription_mailer_spec.rb +18 -4
- data/spec/mailers/user_mailer_spec.rb +134 -0
- data/spec/models/entities/account_spec.rb +44 -4
- data/spec/models/entities/campaign_spec.rb +3 -4
- data/spec/models/entities/contact_spec.rb +45 -5
- data/spec/models/entities/lead_spec.rb +3 -4
- data/spec/models/entities/opportunity_spec.rb +105 -9
- data/spec/models/fields/custom_field_date_pair_spec.rb +106 -0
- data/spec/models/fields/custom_field_pair_spec.rb +94 -0
- data/spec/models/fields/custom_field_spec.rb +43 -23
- data/spec/models/fields/field_spec.rb +3 -5
- data/spec/models/observers/entity_observer_spec.rb +65 -0
- data/spec/models/polymorphic/task_spec.rb +74 -118
- data/spec/models/polymorphic/version_spec.rb +18 -18
- data/spec/models/users/group_spec.rb +5 -0
- data/spec/models/users/permission_spec.rb +18 -1
- data/spec/models/users/preference_spec.rb +5 -1
- data/spec/models/users/user_spec.rb +55 -8
- data/spec/shared/models.rb +54 -0
- data/spec/spec_helper.rb +82 -87
- data/spec/support/auth_macros.rb +2 -3
- data/spec/views/accounts/_edit.haml_spec.rb +1 -2
- data/spec/views/accounts/_new.haml_spec.rb +1 -2
- data/spec/views/accounts/create.rjs_spec.rb +1 -3
- data/spec/views/accounts/edit.rjs_spec.rb +3 -4
- data/spec/views/accounts/index.haml_spec.rb +9 -6
- data/spec/views/accounts/new.rjs_spec.rb +2 -9
- data/spec/views/accounts/show.haml_spec.rb +1 -2
- data/spec/views/accounts/update.rjs_spec.rb +2 -3
- data/spec/views/admin/users/_create.haml_spec.rb +1 -2
- data/spec/views/admin/users/create.rjs_spec.rb +1 -2
- data/spec/views/campaigns/_edit.haml_spec.rb +2 -3
- data/spec/views/campaigns/_new.haml_spec.rb +2 -3
- data/spec/views/campaigns/create.rjs_spec.rb +0 -3
- data/spec/views/campaigns/destroy.rjs_spec.rb +1 -2
- data/spec/views/campaigns/edit.rjs_spec.rb +3 -6
- data/spec/views/campaigns/index.haml_spec.rb +6 -3
- data/spec/views/campaigns/new.rjs_spec.rb +2 -13
- data/spec/views/campaigns/show.haml_spec.rb +4 -6
- data/spec/views/campaigns/update.rjs_spec.rb +2 -7
- data/spec/views/contacts/_edit.haml_spec.rb +6 -7
- data/spec/views/contacts/_new.haml_spec.rb +2 -3
- data/spec/views/contacts/create.rjs_spec.rb +1 -3
- data/spec/views/contacts/edit.rjs_spec.rb +3 -4
- data/spec/views/contacts/index.haml_spec.rb +6 -3
- data/spec/views/contacts/new.rjs_spec.rb +2 -11
- data/spec/views/contacts/show.haml_spec.rb +1 -2
- data/spec/views/contacts/update.rjs_spec.rb +2 -3
- data/spec/views/home/index.haml_spec.rb +6 -2
- data/spec/views/home/index.rjs_spec.rb +1 -2
- data/spec/views/home/options.rjs_spec.rb +1 -2
- data/spec/views/leads/_convert.haml_spec.rb +1 -2
- data/spec/views/leads/_edit.haml_spec.rb +2 -3
- data/spec/views/leads/_new.haml_spec.rb +2 -3
- data/spec/views/leads/_sidebar_show.haml_spec.rb +1 -2
- data/spec/views/leads/convert.rjs_spec.rb +3 -5
- data/spec/views/leads/edit.rjs_spec.rb +4 -5
- data/spec/views/leads/index.haml_spec.rb +6 -3
- data/spec/views/leads/new.rjs_spec.rb +2 -11
- data/spec/views/leads/promote.rjs_spec.rb +3 -5
- data/spec/views/leads/show.haml_spec.rb +1 -2
- data/spec/views/leads/update.rjs_spec.rb +2 -3
- data/spec/views/opportunities/_edit.haml_spec.rb +5 -6
- data/spec/views/opportunities/_new.haml_spec.rb +2 -4
- data/spec/views/opportunities/create.rjs_spec.rb +0 -2
- data/spec/views/opportunities/edit.rjs_spec.rb +3 -4
- data/spec/views/opportunities/index.haml_spec.rb +7 -4
- data/spec/views/opportunities/new.rjs_spec.rb +2 -12
- data/spec/views/opportunities/show.haml_spec.rb +1 -2
- data/spec/views/opportunities/update.rjs_spec.rb +2 -3
- data/spec/views/tasks/_edit.haml_spec.rb +1 -3
- data/spec/views/tasks/complete.rjs_spec.rb +2 -3
- data/spec/views/tasks/create.rjs_spec.rb +2 -2
- data/spec/views/tasks/edit.rjs_spec.rb +1 -2
- data/spec/views/tasks/new.rjs_spec.rb +1 -18
- data/spec/views/users/avatar.rjs_spec.rb +1 -2
- data/spec/views/users/change_password.rjs_spec.rb +1 -2
- data/spec/views/users/edit.rjs_spec.rb +1 -2
- data/spec/views/users/password.rjs_spec.rb +1 -1
- data/spec/views/users/update.rjs_spec.rb +1 -2
- data/spec/views/users/upload_avatar.rjs_spec.rb +6 -7
- data/vendor/assets/images/brief.png +0 -0
- data/vendor/assets/images/chosen-sprite.png +0 -0
- data/vendor/assets/images/full.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_flat_0_aaaaaa_40x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_flat_0_eeeeee_40x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_flat_100_ffffff_40x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_flat_25_3875d7_40x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_flat_55_ffffff_40x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_flat_65_3875d7_40x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_flat_75_ffffff_40x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_highlight-soft_50_dddddd_1x100.png +0 -0
- data/vendor/assets/images/jquery-ui/{ui-icons_ef8c08_256x240.png → ui-icons_0073ea_256x240.png} +0 -0
- data/vendor/assets/images/jquery-ui/ui-icons_466bb1_256x240.png +0 -0
- data/vendor/assets/images/jquery-ui/{ui-icons_ffd27a_256x240.png → ui-icons_ff0084_256x240.png} +0 -0
- data/vendor/assets/images/long.png +0 -0
- data/vendor/assets/javascripts/chosen-jquery.js +3 -0
- data/vendor/assets/javascripts/chosen-prototype.js +3 -0
- data/vendor/assets/javascripts/chosen.jquery.coffee +574 -0
- data/vendor/assets/javascripts/chosen.proto.coffee +580 -0
- data/vendor/assets/javascripts/jquery.disable.js +23 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-addon.js +1882 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-af.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-ca.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-cz.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-de.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-el.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-es.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-et.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-fi.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-fr-CA.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-fr.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-gl.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-he.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-hu.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-id.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-it.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-ja.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-ko.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-lt.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-nl.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-no.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-pl.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-pt.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-ro.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-ru.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-sk.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-sv.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-tr.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-vi.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-zh-CN.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery-ui-timepicker-zh-TW.js +20 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery.ui.datepicker-cz.js +23 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery.ui.datepicker-de.js +23 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery.ui.datepicker-en-GB.js +23 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery.ui.datepicker-es.js +23 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery.ui.datepicker-fr.js +23 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery.ui.datepicker-it.js +23 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery.ui.datepicker-ja.js +23 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery.ui.datepicker-pl.js +23 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery.ui.datepicker-pt-BR.js +23 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery.ui.datepicker-ru.js +23 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery.ui.datepicker-sv-SE.js +23 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery.ui.datepicker-th.js +23 -0
- data/vendor/assets/javascripts/jquery_ui_datepicker/jquery.ui.datepicker-zh-CN.js +23 -0
- data/vendor/assets/javascripts/lib/abstract-chosen.coffee +110 -0
- data/vendor/assets/javascripts/lib/select-parser.coffee +51 -0
- data/vendor/assets/stylesheets/chosen.css.sass +361 -0
- data/vendor/assets/stylesheets/{jquery-ui.custom.css.erb → jquery-ui.custom.css} +70 -70
- data/zeus.json +21 -0
- metadata +304 -140
- data/acceptance/support/database_cleaner.rb +0 -16
- data/acceptance/support/paths.rb +0 -9
- data/app/views/accounts/_options.html.haml +0 -20
- data/app/views/accounts/_permissions.html.haml +0 -24
- data/app/views/accounts/options.js.rjs +0 -10
- data/app/views/admin/fields/_edit.html.haml +0 -9
- data/app/views/admin/fields/_new.html.haml +0 -10
- data/app/views/admin/fields/_options.html.haml +0 -12
- data/app/views/admin/fields/_top_section.html.haml +0 -54
- data/app/views/admin/fields/create.js.rjs +0 -16
- data/app/views/admin/fields/edit.js.rjs +0 -35
- data/app/views/admin/fields/index.js.rjs +0 -6
- data/app/views/admin/fields/new.js.rjs +0 -8
- data/app/views/admin/fields/options.js.rjs +0 -10
- data/app/views/admin/fields/update.js.rjs +0 -17
- data/app/views/campaigns/_options.html.haml +0 -20
- data/app/views/campaigns/_permissions.html.haml +0 -24
- data/app/views/campaigns/options.js.rjs +0 -10
- data/app/views/contacts/_options.html.haml +0 -21
- data/app/views/contacts/_permissions.html.haml +0 -24
- data/app/views/contacts/options.js.rjs +0 -10
- data/app/views/entities/_advanced_search.html.haml +0 -12
- data/app/views/entities/_condition_fields.html.haml +0 -14
- data/app/views/entities/_grouping_fields.html.haml +0 -12
- data/app/views/entities/advanced_search.js.rjs +0 -9
- data/app/views/entities/versions.js.rjs +0 -3
- data/app/views/leads/_options.html.haml +0 -21
- data/app/views/leads/_permissions.html.haml +0 -28
- data/app/views/leads/options.js.rjs +0 -10
- data/app/views/opportunities/_options.html.haml +0 -20
- data/app/views/opportunities/_permissions.html.haml +0 -24
- data/app/views/opportunities/options.js.rjs +0 -10
- data/app/views/shared/_outline.html.haml +0 -9
- data/app/views/shared/_per_page.html.haml +0 -10
- data/app/views/shared/_sort_by.html.haml +0 -10
- data/config/initializers/cancan.rb +0 -151
- data/config/initializers/squeel.rb +0 -5
- data/public/blank_iframe.html +0 -2
- data/spec/views/accounts/options.rjs_spec.rb +0 -59
- data/spec/views/campaigns/options.rjs_spec.rb +0 -60
- data/spec/views/contacts/options.rjs_spec.rb +0 -61
- data/spec/views/leads/options.rjs_spec.rb +0 -61
- data/spec/views/opportunities/options.rjs_spec.rb +0 -60
- data/vendor/assets/images/jquery-ui/ui-bg_diagonals-thick_18_b81900_40x40.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_diagonals-thick_20_666666_40x40.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_flat_10_000000_40x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_glass_100_f6f6f6_1x400.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_glass_100_fdf5ce_1x400.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_glass_65_ffffff_1x400.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_gloss-wave_35_f6a828_500x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_highlight-soft_100_eeeeee_1x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-bg_highlight-soft_75_ffe45c_1x100.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-icons_222222_256x240.png +0 -0
- data/vendor/assets/images/jquery-ui/ui-icons_228ef1_256x240.png +0 -0
- data/vendor/assets/javascripts/calendar_date_select/calendar_date_select.js +0 -446
- data/vendor/assets/javascripts/calendar_date_select/format_american.js +0 -35
- data/vendor/assets/javascripts/calendar_date_select/format_danish.js +0 -31
- data/vendor/assets/javascripts/calendar_date_select/format_db.js +0 -27
- data/vendor/assets/javascripts/calendar_date_select/format_euro_24hr.js +0 -7
- data/vendor/assets/javascripts/calendar_date_select/format_euro_24hr_ymd.js +0 -7
- data/vendor/assets/javascripts/calendar_date_select/format_finnish.js +0 -32
- data/vendor/assets/javascripts/calendar_date_select/format_french.js +0 -24
- data/vendor/assets/javascripts/calendar_date_select/format_hyphen_ampm.js +0 -37
- data/vendor/assets/javascripts/calendar_date_select/format_iso_date.js +0 -29
- data/vendor/assets/javascripts/calendar_date_select/format_italian.js +0 -24
- data/vendor/assets/javascripts/calendar_date_select/locale/ar.js +0 -10
- data/vendor/assets/javascripts/calendar_date_select/locale/da.js +0 -11
- data/vendor/assets/javascripts/calendar_date_select/locale/de.js +0 -11
- data/vendor/assets/javascripts/calendar_date_select/locale/es.js +0 -11
- data/vendor/assets/javascripts/calendar_date_select/locale/fi.js +0 -10
- data/vendor/assets/javascripts/calendar_date_select/locale/fr.js +0 -11
- data/vendor/assets/javascripts/calendar_date_select/locale/it.js +0 -9
- data/vendor/assets/javascripts/calendar_date_select/locale/ja.js +0 -11
- data/vendor/assets/javascripts/calendar_date_select/locale/nl.js +0 -11
- data/vendor/assets/javascripts/calendar_date_select/locale/pl.js +0 -11
- data/vendor/assets/javascripts/calendar_date_select/locale/pt.js +0 -11
- data/vendor/assets/javascripts/calendar_date_select/locale/ru.js +0 -10
- data/vendor/assets/javascripts/calendar_date_select/locale/sl.js +0 -11
- data/vendor/assets/javascripts/calendar_date_select/locale/sv.js +0 -9
- data/vendor/assets/stylesheets/calendar_date_select/blue.css +0 -130
- data/vendor/assets/stylesheets/calendar_date_select/default.css +0 -135
- data/vendor/assets/stylesheets/calendar_date_select/green.css +0 -142
- data/vendor/assets/stylesheets/calendar_date_select/plain.css +0 -128
- data/vendor/assets/stylesheets/calendar_date_select/red.css +0 -135
- data/vendor/assets/stylesheets/calendar_date_select/silver.css +0 -133
- data/vendor/plugins/.gitkeep~master +0 -0
@@ -35,7 +35,7 @@ describe Field do
|
|
35
35
|
|
36
36
|
|
37
37
|
it "should return a list of field types" do
|
38
|
-
Field.field_types['string'].should == {
|
38
|
+
Field.field_types['string'].should == {'klass' => 'CustomField', 'type' => 'string'}
|
39
39
|
end
|
40
40
|
|
41
41
|
it "should return a hash of input options" do
|
@@ -50,15 +50,13 @@ describe Field do
|
|
50
50
|
object = mock('Object')
|
51
51
|
|
52
52
|
# as | value | expected
|
53
|
-
[["check_boxes", [1, 2, 3]
|
54
|
-
["check_boxes", [1, 2, 3], "1, 2<br />3"],
|
53
|
+
[["check_boxes", [1, 2, 3], "1, 2<br />3"],
|
55
54
|
["checkbox", "0", "no"],
|
56
55
|
["checkbox", 1, "yes"],
|
57
|
-
["date", DateTime.new(2011,4,19),
|
56
|
+
["date", DateTime.new(2011,4,19), DateTime.new(2011,4,19).strftime(I18n.t("date.formats.mmddyy")) ]].each do |as, value, expected|
|
58
57
|
field.as = as
|
59
58
|
object.stub!(field.name).and_return(value)
|
60
59
|
field.render_value(object).should == expected
|
61
60
|
end
|
62
61
|
end
|
63
62
|
end
|
64
|
-
|
@@ -0,0 +1,65 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe EntityObserver do
|
4
|
+
[:account, :contact, :lead, :opportunity].each do |entity_type|
|
5
|
+
describe "on creation of #{entity_type}" do
|
6
|
+
let(:assignee) { FactoryGirl.create(:user) }
|
7
|
+
let(:assigner) { FactoryGirl.create(:user) }
|
8
|
+
let!(:entity) { FactoryGirl.build(entity_type, :user => assigner, :assignee => assignee) }
|
9
|
+
let(:mail) { mock('mail', :deliver => true) }
|
10
|
+
|
11
|
+
before :each do
|
12
|
+
PaperTrail.stub(:whodunnit).and_return(assigner)
|
13
|
+
end
|
14
|
+
|
15
|
+
after :each do
|
16
|
+
entity.save
|
17
|
+
end
|
18
|
+
|
19
|
+
it "sends notification to the assigned user for entity" do
|
20
|
+
UserMailer.should_receive(:assigned_entity_notification).with(entity, assigner).and_return(mail)
|
21
|
+
end
|
22
|
+
|
23
|
+
it "does not notify anyone if the entity is created and assigned to no-one" do
|
24
|
+
entity.assignee = nil
|
25
|
+
UserMailer.should_not_receive(:assigned_entity_notification)
|
26
|
+
end
|
27
|
+
|
28
|
+
it "does not notify me if I have created an entity for myself" do
|
29
|
+
entity.assignee = entity.user = assigner
|
30
|
+
UserMailer.should_not_receive(:assigned_entity_notification)
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
describe "on update of #{entity_type}" do
|
35
|
+
let(:assignee) { FactoryGirl.create(:user) }
|
36
|
+
let(:assigner) { FactoryGirl.create(:user) }
|
37
|
+
let!(:entity) { FactoryGirl.create(entity_type, :user => FactoryGirl.create(:user)) }
|
38
|
+
let(:mail) { mock('mail', :deliver => true) }
|
39
|
+
|
40
|
+
before :each do
|
41
|
+
PaperTrail.stub(:whodunnit).and_return(assigner)
|
42
|
+
end
|
43
|
+
|
44
|
+
it "notifies the new owner if the entity is re-assigned" do
|
45
|
+
UserMailer.should_receive(:assigned_entity_notification).with(entity, assigner).and_return(mail)
|
46
|
+
entity.update_attributes(:assignee => assignee)
|
47
|
+
end
|
48
|
+
|
49
|
+
it "does not notify the owner if the entity is not re-assigned" do
|
50
|
+
UserMailer.should_not_receive(:assigned_entity_notification)
|
51
|
+
entity.touch
|
52
|
+
end
|
53
|
+
|
54
|
+
it "does not notify anyone if the entity becomes unassigned" do
|
55
|
+
UserMailer.should_not_receive(:assigned_entity_notification)
|
56
|
+
entity.update_attributes(:assignee => nil)
|
57
|
+
end
|
58
|
+
|
59
|
+
it "does not notify me if I re-assign an entity to myself" do
|
60
|
+
UserMailer.should_not_receive(:assigned_entity_notification)
|
61
|
+
entity.update_attributes(:assignee => assigner)
|
62
|
+
end
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
@@ -47,10 +47,10 @@ describe Task do
|
|
47
47
|
end
|
48
48
|
|
49
49
|
it "should create a task with due date selected from the calendar within #{offset ? 'different' : 'current'} timezone" do
|
50
|
-
task = FactoryGirl.create(:task, :bucket => "specific_time", :calendar => "
|
50
|
+
task = FactoryGirl.create(:task, :bucket => "specific_time", :calendar => "2020-03-20")
|
51
51
|
task.errors.should be_empty
|
52
52
|
task.bucket.should == "specific_time"
|
53
|
-
task.due_at.should ==
|
53
|
+
task.due_at.to_i.should == Time.parse("2020-03-20").to_i
|
54
54
|
end
|
55
55
|
end
|
56
56
|
end
|
@@ -104,10 +104,10 @@ describe Task do
|
|
104
104
|
|
105
105
|
it "should update due date if specific calendar date selected within #{offset ? 'different' : 'current'} timezone" do
|
106
106
|
task = FactoryGirl.create(:task, :due_at => Time.now.midnight.tomorrow, :bucket => "due_tomorrow")
|
107
|
-
task.update_attributes( { :bucket => "specific_time", :calendar => "
|
107
|
+
task.update_attributes( { :bucket => "specific_time", :calendar => "2020-03-20" } )
|
108
108
|
task.errors.should be_empty
|
109
109
|
task.bucket.should == "specific_time"
|
110
|
-
task.due_at.should ==
|
110
|
+
task.due_at.to_i.should == Time.parse("2020-03-20").to_i
|
111
111
|
end
|
112
112
|
end
|
113
113
|
|
@@ -116,113 +116,109 @@ describe Task do
|
|
116
116
|
describe "Task/Complete" do
|
117
117
|
it "should comlete a task that is overdue" do
|
118
118
|
task = FactoryGirl.create(:task, :due_at => 2.days.ago, :bucket => "overdue")
|
119
|
-
task.update_attributes(:completed_at => Time.now, :completed_by =>
|
119
|
+
task.update_attributes(:completed_at => Time.now, :completed_by => current_user.id)
|
120
120
|
task.errors.should be_empty
|
121
121
|
task.completed_at.should_not == nil
|
122
|
-
task.completor.should ==
|
122
|
+
task.completor.should == current_user
|
123
123
|
end
|
124
124
|
|
125
125
|
it "should complete a task due sometime in the future" do
|
126
126
|
task = FactoryGirl.create(:task, :due_at => Time.now.midnight.tomorrow, :bucket => "due_tomorrow")
|
127
|
-
task.update_attributes(:completed_at => Time.now, :completed_by =>
|
127
|
+
task.update_attributes(:completed_at => Time.now, :completed_by => current_user.id)
|
128
128
|
task.errors.should be_empty
|
129
129
|
task.completed_at.should_not == nil
|
130
|
-
task.completor.should ==
|
130
|
+
task.completor.should == current_user
|
131
131
|
end
|
132
132
|
|
133
133
|
it "should complete a task that is due on specific date in the future" do
|
134
134
|
task = FactoryGirl.create(:task, :calendar => "10/10/2022 12:00 AM", :bucket => "specific_time")
|
135
135
|
task.calendar = nil # Calendar is not saved in the database; we need it only to set the :due_at.
|
136
|
-
task.update_attributes(:completed_at => Time.now, :completed_by =>
|
136
|
+
task.update_attributes(:completed_at => Time.now, :completed_by => current_user.id)
|
137
137
|
task.errors.should be_empty
|
138
138
|
task.completed_at.should_not == nil
|
139
|
-
task.completor.should ==
|
139
|
+
task.completor.should == current_user
|
140
140
|
end
|
141
141
|
|
142
142
|
it "should complete a task that is due on specific date in the past" do
|
143
143
|
task = FactoryGirl.create(:task, :calendar => "10/10/1992 12:00 AM", :bucket => "specific_time")
|
144
144
|
task.calendar = nil # Calendar is not saved in the database; we need it only to set the :due_at.
|
145
|
-
task.update_attributes(:completed_at => Time.now, :completed_by =>
|
145
|
+
task.update_attributes(:completed_at => Time.now, :completed_by => current_user.id)
|
146
146
|
task.errors.should be_empty
|
147
147
|
task.completed_at.should_not == nil
|
148
|
-
task.completor.should ==
|
148
|
+
task.completor.should == current_user
|
149
149
|
end
|
150
150
|
|
151
151
|
it "completion should preserve original due date" do
|
152
|
-
due_at = 42.days
|
153
|
-
time_format = I18n.t(Setting.task_calendar_with_time ?
|
154
|
-
'time.formats.mmddyyyy_hhmm' :
|
155
|
-
'date.formats.mmddyyyy')
|
152
|
+
due_at = Time.now - 42.days
|
156
153
|
task = FactoryGirl.create(:task, :due_at => due_at, :bucket => "specific_time",
|
157
|
-
:calendar => due_at.strftime(
|
158
|
-
task.update_attributes(:completed_at => Time.now, :completed_by =>
|
154
|
+
:calendar => due_at.strftime('%Y-%m-%d %H:%M'))
|
155
|
+
task.update_attributes(:completed_at => Time.now, :completed_by => current_user.id, :calendar => '')
|
159
156
|
task.completed?.should == true
|
160
|
-
|
161
|
-
task.due_at.to_i.should == parsed_time.to_i
|
157
|
+
task.due_at.should == due_at.utc.strftime('%Y-%m-%d %H:%M')
|
162
158
|
end
|
163
159
|
end
|
164
160
|
|
165
161
|
# named_scope :my, lambda { |user| { :conditions => [ "(user_id = ? AND assigned_to IS NULL) OR assigned_to = ?", user.id, user.id ], :include => :assignee } }
|
166
162
|
describe "task.my?" do
|
167
163
|
it "should match a task created by the user" do
|
168
|
-
task = FactoryGirl.create(:task, :user =>
|
169
|
-
task.my?(
|
164
|
+
task = FactoryGirl.create(:task, :user => current_user, :assignee => nil)
|
165
|
+
task.my?(current_user).should == true
|
170
166
|
end
|
171
167
|
|
172
168
|
it "should match a task assigned to the user" do
|
173
|
-
task = FactoryGirl.create(:task, :user => FactoryGirl.create(:user), :assignee =>
|
174
|
-
task.my?(
|
169
|
+
task = FactoryGirl.create(:task, :user => FactoryGirl.create(:user), :assignee => current_user)
|
170
|
+
task.my?(current_user).should == true
|
175
171
|
end
|
176
172
|
|
177
173
|
it "should Not match a task not created by the user" do
|
178
174
|
task = FactoryGirl.create(:task, :user => FactoryGirl.create(:user))
|
179
|
-
task.my?(
|
175
|
+
task.my?(current_user).should == false
|
180
176
|
end
|
181
177
|
|
182
178
|
it "should Not match a task created by the user but assigned to somebody else" do
|
183
|
-
task = FactoryGirl.create(:task, :user =>
|
184
|
-
task.my?(
|
179
|
+
task = FactoryGirl.create(:task, :user => current_user, :assignee => FactoryGirl.create(:user))
|
180
|
+
task.my?(current_user).should == false
|
185
181
|
end
|
186
182
|
end
|
187
183
|
|
188
184
|
# named_scope :assigned_by, lambda { |user| { :conditions => [ "user_id = ? AND assigned_to IS NOT NULL AND assigned_to != ?", user.id, user.id ], :include => :assignee } }
|
189
185
|
describe "task.assigned_by?" do
|
190
186
|
it "should match a task assigned by the user to somebody else" do
|
191
|
-
task = FactoryGirl.create(:task, :user =>
|
192
|
-
task.assigned_by?(
|
187
|
+
task = FactoryGirl.create(:task, :user => current_user, :assignee => FactoryGirl.create(:user))
|
188
|
+
task.assigned_by?(current_user).should == true
|
193
189
|
end
|
194
190
|
|
195
191
|
it "should Not match a task not created by the user" do
|
196
192
|
task = FactoryGirl.create(:task, :user => FactoryGirl.create(:user))
|
197
|
-
task.assigned_by?(
|
193
|
+
task.assigned_by?(current_user).should == false
|
198
194
|
end
|
199
195
|
|
200
196
|
it "should Not match a task not assigned to anybody" do
|
201
197
|
task = FactoryGirl.create(:task, :assignee => nil)
|
202
|
-
task.assigned_by?(
|
198
|
+
task.assigned_by?(current_user).should == false
|
203
199
|
end
|
204
200
|
|
205
201
|
it "should Not match a task assigned to the user" do
|
206
|
-
task = FactoryGirl.create(:task, :assignee =>
|
207
|
-
task.assigned_by?(
|
202
|
+
task = FactoryGirl.create(:task, :assignee => current_user)
|
203
|
+
task.assigned_by?(current_user).should == false
|
208
204
|
end
|
209
205
|
end
|
210
206
|
|
211
207
|
# named_scope :tracked_by, lambda { |user| { :conditions => [ "user_id = ? OR assigned_to = ?", user.id, user.id ], :include => :assignee } }
|
212
208
|
describe "task.tracked_by?" do
|
213
209
|
it "should match a task created by the user" do
|
214
|
-
task = FactoryGirl.create(:task, :user =>
|
215
|
-
task.tracked_by?(
|
210
|
+
task = FactoryGirl.create(:task, :user => current_user)
|
211
|
+
task.tracked_by?(current_user).should == true
|
216
212
|
end
|
217
213
|
|
218
214
|
it "should match a task assigned to the user" do
|
219
|
-
task = FactoryGirl.create(:task, :assignee =>
|
220
|
-
task.tracked_by?(
|
215
|
+
task = FactoryGirl.create(:task, :assignee => current_user)
|
216
|
+
task.tracked_by?(current_user).should == true
|
221
217
|
end
|
222
218
|
|
223
219
|
it "should Not match a task that is neither created nor assigned to the user" do
|
224
220
|
task = FactoryGirl.create(:task, :user => FactoryGirl.create(:user), :assignee => FactoryGirl.create(:user))
|
225
|
-
task.tracked_by?(
|
221
|
+
task.tracked_by?(current_user).should == false
|
226
222
|
end
|
227
223
|
end
|
228
224
|
|
@@ -262,96 +258,56 @@ describe Task do
|
|
262
258
|
end
|
263
259
|
|
264
260
|
describe "#parse_calendar_date" do
|
265
|
-
before :each do
|
266
|
-
I18n.locale = "de"
|
267
|
-
@task = Task.new
|
268
|
-
@task.bucket = "specific_time"
|
269
|
-
@backup_with_time = Setting.task_calendar_with_time
|
270
|
-
end
|
271
|
-
|
272
|
-
after :each do
|
273
|
-
I18n.locale = "en-Us"
|
274
|
-
Setting.task_calendar_with_time = @backup_with_time
|
275
|
-
end
|
276
|
-
|
277
|
-
context "german" do
|
278
|
-
context "date" do
|
279
|
-
before :each do
|
280
|
-
Setting.task_calendar_with_time = false
|
281
|
-
end
|
282
|
-
|
283
|
-
it "should translate: \"20 Jänner 2012\" to \"20 January 2012\"" do
|
284
|
-
@task.calendar = "20 Jänner 2012"
|
285
|
-
@task.send(:parse_calendar_date).should == "20 January 2012"
|
286
|
-
end
|
287
|
-
|
288
|
-
it "should translate: \"20 Februar 2012\" to \"20 February 2012\"" do
|
289
|
-
@task.calendar = "20 Februar 2012"
|
290
|
-
@task.send(:parse_calendar_date).should == "20 February 2012"
|
291
|
-
end
|
292
|
-
|
293
|
-
it "should translate: \"20 März 2012\" to \"20 March 2012\"" do
|
294
|
-
@task.calendar = "20 März 2012"
|
295
|
-
@task.send(:parse_calendar_date).should == "20 March 2012"
|
296
|
-
end
|
297
261
|
|
298
|
-
|
299
|
-
|
300
|
-
|
301
|
-
|
302
|
-
|
303
|
-
it "should translate: \"20 Mai 2012\" to \"20 May 2012\"" do
|
304
|
-
@task.calendar = "20 Mai 2012"
|
305
|
-
@task.send(:parse_calendar_date).should == "20 May 2012"
|
306
|
-
end
|
262
|
+
it "should parse the date" do
|
263
|
+
@task = Task.new(:calendar => '2020-12-23')
|
264
|
+
Time.should_receive(:parse).with('2020-12-23')
|
265
|
+
@task.send(:parse_calendar_date)
|
266
|
+
end
|
307
267
|
|
308
|
-
|
309
|
-
@task.calendar = "20 Juni 2012"
|
310
|
-
@task.send(:parse_calendar_date).should == "20 June 2012"
|
311
|
-
end
|
268
|
+
end
|
312
269
|
|
313
|
-
|
314
|
-
|
315
|
-
|
316
|
-
|
270
|
+
describe "scopes" do
|
271
|
+
context "visible_on_dashboard" do
|
272
|
+
before :each do
|
273
|
+
@user = FactoryGirl.create(:user)
|
274
|
+
@t1 = FactoryGirl.create(:task, :user => @user)
|
275
|
+
@t2 = FactoryGirl.create(:task, :user => @user, :assignee => FactoryGirl.create(:user))
|
276
|
+
@t3 = FactoryGirl.create(:task, :user => FactoryGirl.create(:user), :assignee => @user)
|
277
|
+
@t4 = FactoryGirl.create(:task, :user => FactoryGirl.create(:user), :assignee => FactoryGirl.create(:user))
|
278
|
+
@t5 = FactoryGirl.create(:task, :user => FactoryGirl.create(:user), :assignee => @user)
|
279
|
+
@t6 = FactoryGirl.create(:completed_task, :assignee => @user)
|
280
|
+
end
|
317
281
|
|
318
|
-
|
319
|
-
|
320
|
-
|
321
|
-
end
|
282
|
+
it "should show tasks which have been created by the user and are unassigned" do
|
283
|
+
Task.visible_on_dashboard(@user).should include(@t1)
|
284
|
+
end
|
322
285
|
|
323
|
-
|
324
|
-
|
325
|
-
|
326
|
-
end
|
286
|
+
it "should show tasks which are assigned to the user" do
|
287
|
+
Task.visible_on_dashboard(@user).should include(@t3, @t5)
|
288
|
+
end
|
327
289
|
|
328
|
-
|
329
|
-
|
330
|
-
|
331
|
-
end
|
290
|
+
it "should not show tasks which are not assigned to the user" do
|
291
|
+
Task.visible_on_dashboard(@user).should_not include(@t4)
|
292
|
+
end
|
332
293
|
|
333
|
-
|
334
|
-
|
335
|
-
|
336
|
-
end
|
294
|
+
it "should not show tasks which are created by the user but assigned" do
|
295
|
+
Task.visible_on_dashboard(@user).should_not include(@t2)
|
296
|
+
end
|
337
297
|
|
338
|
-
|
339
|
-
|
340
|
-
@task.send(:parse_calendar_date).should == "20 December 2012"
|
341
|
-
end
|
298
|
+
it "should not include completed tasks" do
|
299
|
+
Task.visible_on_dashboard(@user).should_not include(@t6)
|
342
300
|
end
|
343
|
-
|
344
|
-
|
345
|
-
|
346
|
-
|
347
|
-
|
348
|
-
|
349
|
-
|
350
|
-
|
351
|
-
|
352
|
-
end
|
301
|
+
end
|
302
|
+
|
303
|
+
context "by_due_at" do
|
304
|
+
it "should show tasks ordered by due_at" do
|
305
|
+
t1 = FactoryGirl.create(:task, :name => 't1', :bucket => "due_asap")
|
306
|
+
t2 = FactoryGirl.create(:task, :calendar => 5.days.from_now.strftime("%Y-%m-%d %H:%M"), :bucket => "specific_time")
|
307
|
+
t3 = FactoryGirl.create(:task, :name => 't3', :bucket => "due_next_week")
|
308
|
+
t4 = FactoryGirl.create(:task, :calendar => 20.days.from_now.strftime("%Y-%m-%d %H:%M"), :bucket => "specific_time")
|
309
|
+
Task.by_due_at.should == [t1, t2, t3, t4]
|
353
310
|
end
|
354
311
|
end
|
355
312
|
end
|
356
313
|
end
|
357
|
-
|
@@ -19,7 +19,7 @@ describe Version do
|
|
19
19
|
|
20
20
|
before do
|
21
21
|
login
|
22
|
-
PaperTrail.whodunnit =
|
22
|
+
PaperTrail.whodunnit = current_user.id.to_s
|
23
23
|
end
|
24
24
|
|
25
25
|
it "should create a new instance given valid attributes" do
|
@@ -37,27 +37,27 @@ describe Version do
|
|
37
37
|
end
|
38
38
|
|
39
39
|
it "should select all versions except one" do
|
40
|
-
@versions = Version.for(
|
40
|
+
@versions = Version.for(current_user).exclude_events(:view)
|
41
41
|
@versions.map(&:event).sort.should == %w(create destroy update)
|
42
42
|
end
|
43
43
|
|
44
44
|
it "should select all versions except many" do
|
45
|
-
@versions = Version.for(
|
45
|
+
@versions = Version.for(current_user).exclude_events(:create, :update, :destroy)
|
46
46
|
@versions.map(&:event).should == %w(view)
|
47
47
|
end
|
48
48
|
|
49
49
|
it "should select one requested version" do
|
50
|
-
@versions = Version.for(
|
50
|
+
@versions = Version.for(current_user).include_events(:destroy)
|
51
51
|
@versions.map(&:event).should == %w(destroy)
|
52
52
|
end
|
53
53
|
|
54
54
|
it "should select many requested versions" do
|
55
|
-
@versions = Version.for(
|
55
|
+
@versions = Version.for(current_user).include_events(:create, :update)
|
56
56
|
@versions.map(&:event).sort.should == %w(create update)
|
57
57
|
end
|
58
58
|
|
59
59
|
it "should select versions for given user" do
|
60
|
-
@versions = Version.for(
|
60
|
+
@versions = Version.for(current_user)
|
61
61
|
@versions.map(&:event).sort.should == %w(create destroy update view)
|
62
62
|
end
|
63
63
|
end
|
@@ -66,7 +66,7 @@ describe Version do
|
|
66
66
|
describe "Create, update, and delete (#{item})" do
|
67
67
|
before :each do
|
68
68
|
PaperTrail.enabled = true
|
69
|
-
@item = FactoryGirl.create(item.to_sym, :user =>
|
69
|
+
@item = FactoryGirl.create(item.to_sym, :user => current_user)
|
70
70
|
@conditions = {:item_id => @item.id, :item_type => @item.class.name, :whodunnit => PaperTrail.whodunnit}
|
71
71
|
end
|
72
72
|
|
@@ -94,7 +94,7 @@ describe Version do
|
|
94
94
|
end
|
95
95
|
|
96
96
|
it "should add a version when commenting on a #{item}" do
|
97
|
-
@comment = FactoryGirl.create(:comment, :commentable => @item, :user =>
|
97
|
+
@comment = FactoryGirl.create(:comment, :commentable => @item, :user => current_user)
|
98
98
|
|
99
99
|
@version = Version.where({:related_id => @item.id, :related_type => @item.class.name, :whodunnit => PaperTrail.whodunnit, :event => 'create'}).first
|
100
100
|
@version.should_not == nil
|
@@ -125,7 +125,7 @@ describe Version do
|
|
125
125
|
|
126
126
|
describe "Action refinements for task updates" do
|
127
127
|
before do
|
128
|
-
@task = FactoryGirl.create(:task, :user =>
|
128
|
+
@task = FactoryGirl.create(:task, :user => current_user)
|
129
129
|
@conditions = {:item_id => @task.id, :item_type => @task.class.name, :whodunnit => PaperTrail.whodunnit}
|
130
130
|
end
|
131
131
|
|
@@ -137,7 +137,7 @@ describe Version do
|
|
137
137
|
end
|
138
138
|
|
139
139
|
it "should create 'reassigned' task event" do
|
140
|
-
@task.update_attribute(:assigned_to,
|
140
|
+
@task.update_attribute(:assigned_to, current_user.id + 1)
|
141
141
|
@versions = Version.where(@conditions)
|
142
142
|
|
143
143
|
@versions.map(&:event).sort.should == %w(reassign)
|
@@ -153,7 +153,7 @@ describe Version do
|
|
153
153
|
|
154
154
|
describe "Rejecting a lead" do
|
155
155
|
before do
|
156
|
-
@lead = FactoryGirl.create(:lead, :user =>
|
156
|
+
@lead = FactoryGirl.create(:lead, :user => current_user, :status => "new")
|
157
157
|
@conditions = {:item_id => @lead.id, :item_type => @lead.class.name, :whodunnit => PaperTrail.whodunnit}
|
158
158
|
end
|
159
159
|
|
@@ -173,7 +173,7 @@ describe Version do
|
|
173
173
|
end
|
174
174
|
|
175
175
|
it "should not show the create/update versions if the item is private" do
|
176
|
-
@item = FactoryGirl.create(:account, :user =>
|
176
|
+
@item = FactoryGirl.create(:account, :user => current_user, :access => "Private")
|
177
177
|
@item.update_attribute(:updated_at, 1.second.ago)
|
178
178
|
|
179
179
|
@versions = Version.where({:item_id => @item.id, :item_type => @item.class.name})
|
@@ -183,7 +183,7 @@ describe Version do
|
|
183
183
|
end
|
184
184
|
|
185
185
|
it "should not show the destroy version if the item is private" do
|
186
|
-
@item = FactoryGirl.create(:account, :user =>
|
186
|
+
@item = FactoryGirl.create(:account, :user => current_user, :access => "Private")
|
187
187
|
@item.destroy
|
188
188
|
|
189
189
|
@versions = Version.where({:item_id => @item.id, :item_type => @item.class.name})
|
@@ -194,9 +194,9 @@ describe Version do
|
|
194
194
|
|
195
195
|
it "should not show create/update versions if the item was not shared with the user" do
|
196
196
|
@item = FactoryGirl.create(:account,
|
197
|
-
:user =>
|
197
|
+
:user => current_user,
|
198
198
|
:access => "Shared",
|
199
|
-
:permissions => [ FactoryGirl.build(:permission, :user =>
|
199
|
+
:permissions => [ FactoryGirl.build(:permission, :user => current_user, :asset => @item) ]
|
200
200
|
)
|
201
201
|
@item.update_attribute(:updated_at, 1.second.ago)
|
202
202
|
|
@@ -208,9 +208,9 @@ describe Version do
|
|
208
208
|
|
209
209
|
it "should not show the destroy version if the item was not shared with the user" do
|
210
210
|
@item = FactoryGirl.create(:account,
|
211
|
-
:user =>
|
211
|
+
:user => current_user,
|
212
212
|
:access => "Shared",
|
213
|
-
:permissions => [ FactoryGirl.build(:permission, :user =>
|
213
|
+
:permissions => [ FactoryGirl.build(:permission, :user => current_user, :asset => @item) ]
|
214
214
|
)
|
215
215
|
@item.destroy
|
216
216
|
|
@@ -222,7 +222,7 @@ describe Version do
|
|
222
222
|
|
223
223
|
it "should show create/update versions if the item was shared with the user" do
|
224
224
|
@item = FactoryGirl.create(:account,
|
225
|
-
:user =>
|
225
|
+
:user => current_user,
|
226
226
|
:access => "Shared",
|
227
227
|
:permissions => [ FactoryGirl.build(:permission, :user => @user, :asset => @item) ]
|
228
228
|
)
|