artfully_ose 1.2.0.beta.1 → 1.2.0.pre
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +9 -9
- data/app/assets/fonts/FontAwesome.otf +0 -0
- data/app/assets/fonts/fontawesome-webfont.eot +0 -0
- data/app/assets/fonts/fontawesome-webfont.svg +252 -472
- data/app/assets/fonts/fontawesome-webfont.ttf +0 -0
- data/app/assets/fonts/fontawesome-webfont.woff +0 -0
- data/app/assets/images/person-default-avatar.psd +0 -0
- data/app/assets/javascripts/application.js +10 -163
- data/app/assets/javascripts/box-office.js +262 -0
- data/app/assets/javascripts/custom/inline-people-search.js +40 -40
- data/app/assets/javascripts/custom/people.js +5 -68
- data/app/assets/javascripts/custom/prices.js +0 -1
- data/app/assets/javascripts/custom/show.js +8 -18
- data/app/assets/javascripts/jquery-lib/jquery.mask-money.js +0 -1
- data/app/assets/javascripts/locationselector.js +1 -1
- data/app/assets/javascripts/store/jquery.validate.additional-methods.js +159 -476
- data/app/assets/javascripts/store/jquery.validate.js +406 -449
- data/app/assets/javascripts/store/store.js +5 -29
- data/app/assets/stylesheets/application.sass +60 -223
- data/app/assets/stylesheets/bootstrap-overrides.css +3 -13
- data/app/assets/stylesheets/bootstrap.css +0 -1
- data/app/assets/stylesheets/font-awesome.sass +759 -0
- data/app/assets/stylesheets/sass/_event_list.sass +1 -12
- data/app/assets/stylesheets/sass/_tags.sass +2 -13
- data/app/assets/stylesheets/sass/box-office.sass +1 -2
- data/app/assets/stylesheets/sass/cart.sass +6 -0
- data/app/assets/stylesheets/sass/store.sass +68 -123
- data/app/assets/stylesheets/storefront.css +1 -2
- data/app/concerns/itemable.rb +1 -1
- data/app/controllers/artfully_ose_controller.rb +7 -29
- data/app/controllers/discounts_controller.rb +1 -8
- data/app/controllers/events_controller.rb +33 -41
- data/app/controllers/exchanges_controller.rb +2 -8
- data/app/controllers/export_controller.rb +0 -6
- data/app/controllers/imports_controller.rb +0 -19
- data/app/controllers/members/index_controller.rb +1 -1
- data/app/controllers/members/members_controller.rb +1 -6
- data/app/controllers/membership_awards_controller.rb +58 -0
- data/app/controllers/membership_types_controller.rb +3 -40
- data/app/controllers/memberships_controller.rb +4 -6
- data/app/controllers/orders_controller.rb +2 -86
- data/app/controllers/organizations_controller.rb +3 -4
- data/app/controllers/people_controller.rb +23 -54
- data/app/controllers/refunds_controller.rb +7 -7
- data/app/controllers/sales_controller.rb +28 -67
- data/app/controllers/searches_controller.rb +9 -15
- data/app/controllers/sections_controller.rb +2 -2
- data/app/controllers/segments_controller.rb +4 -4
- data/app/controllers/shows_controller.rb +49 -79
- data/app/controllers/slices_controller.rb +2 -3
- data/app/controllers/statements_controller.rb +1 -1
- data/app/controllers/store/checkouts_controller.rb +3 -8
- data/app/controllers/store/donations_controller.rb +1 -19
- data/app/controllers/store/events_controller.rb +1 -14
- data/app/controllers/store/memberships_controller.rb +1 -12
- data/app/controllers/store/orders_controller.rb +17 -36
- data/app/controllers/store/passes_controller.rb +0 -9
- data/app/controllers/store/store_controller.rb +2 -7
- data/app/controllers/tickets_controller.rb +2 -2
- data/app/helpers/artfully_ose_helper.rb +21 -79
- data/app/helpers/link_helper.rb +2 -12
- data/app/mailers/order_mailer.rb +1 -28
- data/app/mailers/reports_mailer.rb +4 -5
- data/app/models/ability.rb +0 -1
- data/app/models/action.rb +1 -1
- data/app/models/actions/go_action.rb +2 -3
- data/app/{concerns → models/actions}/immutable_action.rb +0 -0
- data/app/models/address.rb +11 -32
- data/app/models/{cart.rb → carts/cart.rb} +37 -46
- data/app/models/carts/cart_finder.rb +33 -0
- data/app/models/checkout.rb +41 -85
- data/app/models/comp.rb +17 -24
- data/app/models/company.rb +1 -1
- data/app/models/contribution.rb +0 -1
- data/app/models/database_views/item_view.rb +28 -169
- data/app/models/database_views/order_view.rb +34 -0
- data/app/models/donation.rb +0 -4
- data/app/models/door_list.rb +3 -6
- data/app/models/event.rb +10 -60
- data/app/models/exchange.rb +5 -7
- data/app/models/{ext.rb → ext/ext.rb} +1 -14
- data/app/models/ext/integrations.rb +21 -39
- data/app/models/fee_strategy.rb +1 -47
- data/app/models/import.rb +2 -22
- data/app/models/imports/donations_import.rb +19 -1
- data/app/models/imports/events_import.rb +51 -43
- data/app/models/individual.rb +1 -3
- data/app/models/item.rb +11 -28
- data/app/models/job/daily_email_report_job.rb +6 -20
- data/app/models/job/mailchimp_sync_job.rb +3 -1
- data/app/models/job/order_processor.rb +12 -78
- data/app/models/job/show_creator.rb +3 -8
- data/app/models/kit.rb +4 -2
- data/app/models/kits/mailchimp_kit.rb +10 -18
- data/app/models/kits/regular_donation_kit.rb +8 -38
- data/app/models/member.rb +17 -152
- data/app/models/membership.rb +23 -59
- data/app/models/membership_award.rb +23 -0
- data/app/models/membership_type.rb +2 -44
- data/app/models/note.rb +1 -1
- data/app/models/order_handler.rb +39 -100
- data/app/models/orders/comp_order.rb +0 -4
- data/app/models/orders/imported_order.rb +0 -4
- data/app/models/{order.rb → orders/order.rb} +18 -113
- data/app/models/orders/refund_order.rb +0 -4
- data/app/{concerns → models/orders}/unrefundable.rb +0 -0
- data/app/models/organization.rb +15 -55
- data/app/models/organization_ability.rb +0 -1
- data/app/models/parsed_row.rb +3 -58
- data/app/models/payments/cash_payment.rb +1 -3
- data/app/models/payments/comp_payment.rb +1 -3
- data/app/models/payments/credit_card_payment.rb +23 -44
- data/app/models/{payment.rb → payments/payment.rb} +1 -29
- data/app/models/person.rb +36 -140
- data/app/models/phone.rb +8 -0
- data/app/models/refund.rb +2 -5
- data/app/models/sale.rb +10 -14
- data/app/models/sale_search.rb +21 -3
- data/app/models/search.rb +67 -320
- data/app/models/section.rb +2 -18
- data/app/models/show.rb +20 -67
- data/app/models/slices.rb +8 -25
- data/app/models/statement.rb +5 -32
- data/app/models/ticket.rb +15 -50
- data/app/models/ticket/locker.rb +1 -2
- data/app/models/ticket/pricing.rb +1 -11
- data/app/models/ticket/reports.rb +0 -16
- data/app/models/ticket/sale_transitions.rb +0 -4
- data/app/models/ticket/template.rb +0 -1
- data/app/models/ticket/transfers.rb +2 -12
- data/app/models/ticket_summary.rb +1 -7
- data/app/models/ticket_type.rb +7 -59
- data/app/models/user.rb +5 -18
- data/app/models/user_membership.rb +3 -21
- data/app/models/valuation/lifetime_ticket_value.rb +1 -1
- data/app/models/venue.rb +7 -21
- data/app/presenters/event_presenter.rb +1 -1
- data/app/views/actions/_form.html.haml +6 -6
- data/app/views/actions/get/_show.html.haml +13 -2
- data/app/views/actions/give/_show.html.haml +1 -1
- data/app/views/actions/shared/_show.html.haml +1 -1
- data/app/views/addresses/_address.html.haml +6 -7
- data/app/views/contributions/_form.html.haml +1 -1
- data/app/views/contributions/index.html.haml +2 -2
- data/app/views/discounts/_discount_section_fields.html.haml +1 -1
- data/app/views/discounts/_form.html.haml +1 -1
- data/app/views/discounts/index.html.haml +1 -1
- data/app/views/events/_day_date_show.html.haml +2 -2
- data/app/views/events/_discount_section_fields.html.haml +1 -1
- data/app/views/events/_header.html.haml +0 -1
- data/app/views/events/_list.html.haml +5 -10
- data/app/views/events/_menu.html.haml +15 -6
- data/app/views/events/_section_fields.html.haml +1 -1
- data/app/views/events/_share_and_sell.haml +2 -3
- data/app/views/events/_ticket_type_fields.html.haml +4 -43
- data/app/views/events/edit.html.haml +1 -6
- data/app/views/events/image.html.haml +1 -2
- data/app/views/events/index.html.haml +3 -20
- data/app/views/events/show.html.haml +1 -3
- data/app/views/events/temp_discount_form.html.haml +1 -1
- data/app/views/events/temp_discounts_index.html.haml +1 -1
- data/app/views/exchanges/new.html.haml +28 -51
- data/app/views/imports/donations/_pending.html.haml +1 -1
- data/app/views/imports/events/_pending.html.haml +1 -1
- data/app/views/imports/index.html.haml +3 -6
- data/app/views/imports/people/_imported.html.haml +2 -2
- data/app/views/imports/people/_new.html.haml +8 -20
- data/app/views/imports/people/_pending.html.haml +2 -2
- data/app/views/imports/people/_recalled.html.haml +1 -1
- data/app/views/imports/shared/_sidebar.html.haml +1 -1
- data/app/views/index/dashboard.html.haml +4 -4
- data/app/views/layouts/_flash.html.haml +3 -3
- data/app/views/layouts/_google_analytics.html.haml +2 -5
- data/app/views/layouts/_menu.html.haml +5 -9
- data/app/views/layouts/application.html.haml +2 -2
- data/app/views/layouts/devise_layout.html.haml +2 -2
- data/app/views/layouts/members.html.haml +1 -1
- data/app/views/layouts/storefront.html.haml +15 -27
- data/app/views/members/index/index.html.haml +13 -7
- data/app/views/membership_awards/confirm.html.haml +59 -0
- data/app/views/membership_awards/create.html.haml +1 -0
- data/app/views/membership_awards/new.html.haml +74 -0
- data/app/views/membership_types/_form.html.haml +19 -67
- data/app/views/membership_types/index.html.haml +14 -15
- data/app/views/memberships/index.html.haml +50 -116
- data/app/views/merges/find_person.html.haml +1 -1
- data/app/views/notes/_note.html.haml +4 -4
- data/app/views/order_mailer/confirmation_for.html.haml +21 -33
- data/app/views/order_mailer/confirmation_for.text.haml +3 -6
- data/app/views/orders/_item_table.haml +8 -25
- data/app/views/orders/_order_sidebar.html.haml +4 -2
- data/app/views/orders/sales.html.haml +3 -3
- data/app/views/organizations/_connection_form.html.haml +1 -1
- data/app/views/organizations/_form.html.haml +20 -25
- data/app/views/organizations/edit.html.haml +2 -2
- data/app/views/organizations/show.html.haml +16 -22
- data/app/views/people/_edit_modal.html.haml +28 -48
- data/app/views/people/_header.html.haml +9 -18
- data/app/views/people/_phone_fields.html.haml +1 -1
- data/app/views/people/index.html.haml +6 -18
- data/app/views/people/new.html.haml +1 -1
- data/app/views/people/show.html.haml +24 -71
- data/app/views/refunds/new.html.haml +27 -45
- data/app/views/reports_mailer/daily.html.haml +21 -86
- data/app/views/sales/new.html.haml +125 -33
- data/app/views/searches/_form.html.haml +50 -115
- data/app/views/searches/_person.html.haml +2 -5
- data/app/views/searches/new.html.haml +1 -1
- data/app/views/searches/show.html.haml +6 -17
- data/app/views/segments/show.html.haml +4 -7
- data/app/views/shared/_error_messages.html.haml +1 -1
- data/app/views/shared/_tags.html.haml +2 -2
- data/app/views/shows/_controls.html.haml +20 -4
- data/app/views/shows/_glance.html.haml +5 -1
- data/app/views/shows/_sections_table.html.haml +6 -8
- data/app/views/shows/_ticket_table.html.haml +3 -3
- data/app/views/shows/_work_with.html.haml +5 -5
- data/app/views/shows/door_list.html.haml +2 -2
- data/app/views/shows/index.html.haml +19 -88
- data/app/views/shows/new.html.haml +11 -10
- data/app/views/shows/show.html.haml +2 -2
- data/app/views/slices/index.html.haml +1 -2
- data/app/views/statements/_discounts_table.html.haml +1 -1
- data/app/views/statements/_order_location_table.html.haml +1 -1
- data/app/views/statements/_payment_method_table.haml +1 -1
- data/app/views/statements/_ticket_type_table.haml +2 -5
- data/app/views/statements/show.html.haml +2 -5
- data/app/views/store/checkouts/thanks.html.haml +16 -38
- data/app/views/store/donations/index.html.haml +2 -19
- data/app/views/store/events/_calendar.html.haml +4 -1
- data/app/views/store/events/index.html.haml +4 -11
- data/app/views/store/events/show.html.haml +19 -10
- data/app/views/store/memberships/index.html.haml +17 -17
- data/app/views/store/orders/show.html.haml +22 -33
- data/app/views/store/shared/_donate_form.html.haml +12 -31
- data/app/views/store/shows/_show.html.haml +29 -37
- data/app/views/user_memberships/_list.html.haml +29 -28
- data/app/views/users/invitations/edit.html.haml +9 -19
- data/app/views/users/mailer/invitation_instructions.html.erb +8 -0
- data/app/views/users/passwords/edit.html.haml +2 -2
- data/app/views/users/registrations/edit.html.erb +3 -3
- data/app/views/users/sessions/new.html.haml +2 -2
- data/app/views/venues/edit.html.haml +1 -3
- data/config/initializers/devise.rb +5 -2
- data/config/locales/devise.en.yml +1 -1
- data/config/locales/devise_invitable.en.yml +1 -1
- data/config/locales/en.yml +3 -18
- data/config/routes.rb +12 -101
- data/lib/artfully_ose.rb +4 -6
- data/lib/artfully_ose/common_abilities.rb +2 -8
- data/lib/artfully_ose/engine.rb +10 -34
- data/lib/artfully_ose/version.rb +1 -1
- metadata +45 -349
- data/README.md +0 -28
- data/app/assets/images/household-default-avatar.png +0 -0
- data/app/assets/javascripts/angular-resource.js +0 -546
- data/app/assets/javascripts/angular.js +0 -20311
- data/app/assets/javascripts/bootstrap-wysihtml5.js +0 -511
- data/app/assets/javascripts/boxoffice.js +0 -558
- data/app/assets/javascripts/change-membership.js +0 -152
- data/app/assets/javascripts/custom/kits-config.js +0 -33
- data/app/assets/javascripts/households.js +0 -59
- data/app/assets/javascripts/jquery-migrate-1.2.1.min.js +0 -2
- data/app/assets/javascripts/relationships.js +0 -63
- data/app/assets/javascripts/sales-console.js +0 -158
- data/app/assets/javascripts/wysihtml5-0.3.0.min.js +0 -261
- data/app/assets/stylesheets/bootstrap-wysihtml5.css +0 -102
- data/app/assets/stylesheets/boxoffice.css.scss +0 -258
- data/app/assets/stylesheets/font-awesome.css.scss +0 -1566
- data/app/assets/stylesheets/pages/bootstrap-responsive.css +0 -1109
- data/app/assets/stylesheets/wysiwyg-color.css +0 -67
- data/app/concerns/cart_finder.rb +0 -50
- data/app/concerns/pdf_generation.rb +0 -64
- data/app/concerns/search_by_dates.rb +0 -20
- data/app/controllers/console_sales_controller.rb +0 -182
- data/app/controllers/events_pass_types_controller.rb +0 -87
- data/app/controllers/households_controller.rb +0 -71
- data/app/controllers/member_cards_controller.rb +0 -44
- data/app/controllers/members/invitations_controller.rb +0 -7
- data/app/controllers/members/passwords_controller.rb +0 -10
- data/app/controllers/members/people_controller.rb +0 -17
- data/app/controllers/members/sessions_controller.rb +0 -14
- data/app/controllers/membership_cancellations_controller.rb +0 -46
- data/app/controllers/membership_changes_controller.rb +0 -39
- data/app/controllers/membership_comps_controller.rb +0 -102
- data/app/controllers/membership_kits_controller.rb +0 -25
- data/app/controllers/mobile/dashboard_controller.rb +0 -17
- data/app/controllers/mobile/events_controller.rb +0 -16
- data/app/controllers/mobile/orders_controller.rb +0 -61
- data/app/controllers/mobile/shows_controller.rb +0 -39
- data/app/controllers/mobile/tickets_controller.rb +0 -114
- data/app/controllers/mobile/users_controller.rb +0 -30
- data/app/controllers/pass_types_controller.rb +0 -53
- data/app/controllers/passes_controller.rb +0 -52
- data/app/controllers/passes_kits_controller.rb +0 -25
- data/app/controllers/passes_reports_controller.rb +0 -25
- data/app/controllers/regular_donation_kits_controller.rb +0 -32
- data/app/controllers/relationships_controller.rb +0 -15
- data/app/controllers/store/retrievals_controller.rb +0 -29
- data/app/controllers/users/sessions_controller.rb +0 -3
- data/app/helpers/households_helper.rb +0 -7
- data/app/helpers/membership_types_helper.rb +0 -22
- data/app/helpers/relationships_helper.rb +0 -26
- data/app/helpers/sales_helper.rb +0 -29
- data/app/helpers/searches_helper.rb +0 -13
- data/app/helpers/suggested_households_helper.rb +0 -5
- data/app/mailers/pass_mailer.rb +0 -17
- data/app/models/actions/change_action.rb +0 -13
- data/app/models/actions/comp_action.rb +0 -15
- data/app/models/console_sale.rb +0 -30
- data/app/models/daily_membership_report.rb +0 -50
- data/app/models/daily_pass_report.rb +0 -48
- data/app/models/events_pass_type.rb +0 -18
- data/app/models/ext/preprocessor.rb +0 -7
- data/app/models/extendable.rb +0 -6
- data/app/models/household.rb +0 -61
- data/app/models/household_suggester.rb +0 -58
- data/app/models/imports/memberships_import.rb +0 -43
- data/app/models/job/checkout_processor.rb +0 -46
- data/app/models/job/cleanup_suggested_households_job.rb +0 -17
- data/app/models/job/destroy_show_job.rb +0 -10
- data/app/models/job/geocode_address_job.rb +0 -11
- data/app/models/job/order_mailer_job.rb +0 -8
- data/app/models/job/refund_order_processor.rb +0 -16
- data/app/models/kits/membership_kit.rb +0 -62
- data/app/models/kits/passes_kit.rb +0 -62
- data/app/models/kits/scannable_tickets_kit.rb +0 -23
- data/app/models/member_card_generator.rb +0 -63
- data/app/models/member_walkup.rb +0 -150
- data/app/models/membership_cancellation.rb +0 -80
- data/app/models/membership_change.rb +0 -187
- data/app/models/membership_comp.rb +0 -105
- data/app/models/membership_comp_job.rb +0 -32
- data/app/models/membership_sale_search.rb +0 -18
- data/app/models/pass.rb +0 -197
- data/app/models/pass_sale_search.rb +0 -18
- data/app/models/pass_summary.rb +0 -18
- data/app/models/pass_type.rb +0 -46
- data/app/models/passes_report.rb +0 -117
- data/app/models/payments/check_payment.rb +0 -33
- data/app/models/relation.rb +0 -27
- data/app/models/relation_builder.rb +0 -32
- data/app/models/relationship.rb +0 -55
- data/app/models/relationship_builder.rb +0 -12
- data/app/models/relationship_validator.rb +0 -46
- data/app/models/relationships_kit.rb +0 -31
- data/app/models/rolling_membership_type.rb +0 -11
- data/app/models/seasonal_membership_type.rb +0 -3
- data/app/models/suggested_household.rb +0 -24
- data/app/models/ticket/qr_code.rb +0 -21
- data/app/models/valuation/lifetime_memberships.rb +0 -24
- data/app/serializers/show_serializer.rb +0 -15
- data/app/views/console_sales/_aloha.html.haml +0 -26
- data/app/views/console_sales/_cart.html.haml +0 -60
- data/app/views/console_sales/_payment.html.haml +0 -111
- data/app/views/console_sales/_shows.html.haml +0 -24
- data/app/views/console_sales/new.html.haml +0 -143
- data/app/views/events_pass_types/_form.html.haml +0 -42
- data/app/views/events_pass_types/edit.html.haml +0 -22
- data/app/views/events_pass_types/index.html.haml +0 -47
- data/app/views/events_pass_types/new.html.haml +0 -22
- data/app/views/households/_action.html.haml +0 -24
- data/app/views/households/_edit_modal.html.haml +0 -143
- data/app/views/households/_form.html.haml +0 -26
- data/app/views/households/_header.html.haml +0 -25
- data/app/views/households/_individual_fields.html.haml +0 -8
- data/app/views/households/_list.html.haml +0 -10
- data/app/views/households/_note.html.haml +0 -33
- data/app/views/households/edit.html.haml +0 -1
- data/app/views/households/index.html.haml +0 -13
- data/app/views/households/new.html.haml +0 -14
- data/app/views/households/show.html.haml +0 -72
- data/app/views/households/suggested.html.haml +0 -38
- data/app/views/imports/_export_links.html.haml +0 -3
- data/app/views/kits/_list.html.haml +0 -9
- data/app/views/members/invitations/edit.html.haml +0 -17
- data/app/views/members/invitations/new.html.erb +0 -14
- data/app/views/members/mailer/_invitation_body.html.haml +0 -18
- data/app/views/members/mailer/invitation_instructions.html.haml +0 -6
- data/app/views/members/mailer/reset_password_instructions.html.erb +0 -8
- data/app/views/members/passwords/edit.html.haml +0 -18
- data/app/views/members/sessions/new.html.haml +0 -19
- data/app/views/membership_cancellations/_form.html.haml +0 -39
- data/app/views/membership_cancellations/_modal.html.haml +0 -2
- data/app/views/membership_cancellations/_processing.html.haml +0 -12
- data/app/views/membership_cancellations/create.js.erb +0 -3
- data/app/views/membership_cancellations/new.js.erb +0 -3
- data/app/views/membership_comps/confirm.html.haml +0 -86
- data/app/views/membership_comps/create.html.haml +0 -20
- data/app/views/membership_comps/new.html.haml +0 -95
- data/app/views/membership_kits/edit.html.haml +0 -52
- data/app/views/membership_mailer/cancellation_confirmation.html.haml +0 -9
- data/app/views/membership_mailer/cancellation_confirmation.text.haml +0 -6
- data/app/views/membership_mailer/refund_problem.html.haml +0 -18
- data/app/views/membership_mailer/refund_problem.text.haml +0 -14
- data/app/views/membership_types/_membership_type_fees.html.haml +0 -0
- data/app/views/membership_types/_rolling_membership_type_form.html.haml +0 -5
- data/app/views/membership_types/_seasonal_membership_type_form.html.haml +0 -8
- data/app/views/membership_types/type.html.haml +0 -19
- data/app/views/memberships/_membership_scripts.js.erb +0 -15
- data/app/views/order_mailer/confirmation_for_exchange.html.haml +0 -34
- data/app/views/order_mailer/confirmation_for_exchange.text.haml +0 -26
- data/app/views/order_mailer/confirmation_for_refund.html.haml +0 -36
- data/app/views/order_mailer/confirmation_for_refund.text.haml +0 -22
- data/app/views/orders/membership.html.haml +0 -100
- data/app/views/orders/passes.html.haml +0 -97
- data/app/views/pass_mailer/pass_info_for.html.haml +0 -21
- data/app/views/pass_types/_form.html.haml +0 -76
- data/app/views/pass_types/_pass_type_fees.html.haml +0 -0
- data/app/views/pass_types/edit.html.haml +0 -4
- data/app/views/pass_types/index.html.haml +0 -34
- data/app/views/pass_types/new.html.haml +0 -4
- data/app/views/passes/index.html.haml +0 -108
- data/app/views/passes_kits/edit.html.haml +0 -30
- data/app/views/passes_reports/index.html.haml +0 -80
- data/app/views/pdfs/member.html.haml +0 -66
- data/app/views/pdfs/member_card_generator/blanks_usa_idc6.html.haml +0 -109
- data/app/views/pdfs/order.html.haml +0 -84
- data/app/views/people/_household_fields.html.haml +0 -5
- data/app/views/people/_relationship_fields.html.haml +0 -14
- data/app/views/people/_work_with_menu.html.haml +0 -39
- data/app/views/producer_mailer/donation_kit_notification.html.haml +0 -8
- data/app/views/producer_mailer/donation_kit_notification.text.erb +0 -8
- data/app/views/producer_mailer/mailchimp_kit_initial_sync_notification.html.haml +0 -21
- data/app/views/producer_mailer/ticket_offer_accepted.html.haml +0 -7
- data/app/views/producer_mailer/ticket_offer_accepted.text.erb +0 -7
- data/app/views/producer_mailer/ticket_offer_rejected.html.haml +0 -11
- data/app/views/producer_mailer/ticket_offer_rejected.text.erb +0 -13
- data/app/views/regular_donation_kits/edit.html.haml +0 -140
- data/app/views/relationships/index.html.haml +0 -32
- data/app/views/sales/_boxoffice.html.haml +0 -141
- data/app/views/sales/_doorlist.html.haml +0 -79
- data/app/views/searches/_household.html.haml +0 -7
- data/app/views/shared/_show_time_and_calendar.html.haml +0 -21
- data/app/views/shows/door_list.pdf.haml +0 -29
- data/app/views/statements/_passes_table.html.haml +0 -22
- data/app/views/store/checkouts/_membership_info.html.haml +0 -12
- data/app/views/store/events/_venue.html.haml +0 -9
- data/app/views/store/events/calendar.html.haml +0 -50
- data/app/views/store/events/single_show.html.haml +0 -45
- data/app/views/store/passes/index.html.haml +0 -33
- data/app/views/store/retrievals/index.html.haml +0 -11
- data/app/views/store/shared/_small_donate_form.html.haml +0 -21
- data/app/views/users/mailer/invitation_instructions.html.haml +0 -14
- data/config/initializers/paperclip.rb +0 -69
- data/db/migrate/20130411162346_add_country_zip_state_phone_number_discipline_to_organizations.rb +0 -9
- data/db/migrate/20130412184415_add_first_name_and_last_name_to_users.rb +0 -6
- data/db/migrate/20130722153731_add_autentication_token_to_users.rb +0 -5
- data/db/migrate/20130723212712_add_qr_code_to_tickets.rb +0 -9
- data/db/migrate/20130820011240_add_uuid_to_tickets.rb +0 -13
- data/db/migrate/20130820025134_make_ticket_uuid_not_null.rb +0 -11
- data/db/migrate/20130823191625_add_pdf_to_orders.rb +0 -5
- data/db/migrate/20130916194547_add_relationships.rb +0 -21
- data/db/migrate/20131002191646_create_show_stats_view.rb +0 -16
- data/db/migrate/20131003134821_add_relationships_to_search.rb +0 -7
- data/db/migrate/20131003200508_add_starred_to_relationships.rb +0 -5
- data/db/migrate/20131007141421_add_counters_to_member.rb +0 -7
- data/db/migrate/20131007144456_remove_expires_at_from_membership.rb +0 -6
- data/db/migrate/20131011154027_add_purchased_to_searches.rb +0 -5
- data/db/migrate/20131013144010_add_type_to_membership_type.rb +0 -5
- data/db/migrate/20131013150230_add_duration_to_membership_type.rb +0 -6
- data/db/migrate/20131013192807_change_number_of_shows_to_tickets.rb +0 -5
- data/db/migrate/20131015151550_add_households.rb +0 -18
- data/db/migrate/20131022183913_add_search_output_options.rb +0 -24
- data/db/migrate/20131023200559_add_admin_to_user_memberships.rb +0 -14
- data/db/migrate/20131025162155_default_search_filter_values.rb +0 -10
- data/db/migrate/20131025180139_unique_household_names.rb +0 -8
- data/db/migrate/20131029173612_add_sales_start_to_membership_typ.rb +0 -6
- data/db/migrate/20131106191847_add_suggested_households.rb +0 -13
- data/db/migrate/20131127162818_add_buyer_id_index_to_tickets.rb +0 -5
- data/db/migrate/20131127164000_member_tickets.rb +0 -9
- data/db/migrate/20131204162642_add_shared_address.rb +0 -9
- data/db/migrate/20131206153323_add_membership_kit.rb +0 -5
- data/db/migrate/20131206175325_add_marketing_to_membership_type.rb +0 -6
- data/db/migrate/20131210212342_add_show_fee_to_memberhsip_type.rb +0 -5
- data/db/migrate/20131210222814_add_renewal_price_to_membership_type.rb +0 -6
- data/db/migrate/20131212164553_add_copy_to_individuals_option.rb +0 -5
- data/db/migrate/20131223215615_goodbye_order_view.rb +0 -6
- data/db/migrate/20140114011856_add_welcome_message_to_memberships.rb +0 -5
- data/db/migrate/20140114212127_add_send_email_to_memberships.rb +0 -5
- data/db/migrate/20140125183606_index_memberships_and_types.rb +0 -6
- data/db/migrate/20140128213101_add_pdf_to_members.rb +0 -5
- data/db/migrate/20140128223140_add_uuid_to_member.rb +0 -6
- data/db/migrate/20140128223948_add_qr_code_to_member.rb +0 -9
- data/db/migrate/20140207135731_update_items_view.rb +0 -38
- data/db/migrate/20140210154723_add_cached_stats.rb +0 -5
- data/db/migrate/20140218202726_cache_stats.rb +0 -7
- data/db/migrate/20140304171625_passes_ahoy.rb +0 -52
- data/db/migrate/20140304174807_add_passes_kit.rb +0 -5
- data/db/migrate/20140307144454_add_events_pass_types.rb +0 -9
- data/db/migrate/20140307193350_add_pass_id_to_cart.rb +0 -7
- data/db/migrate/20140314162422_add_total_paid_to_membership.rb +0 -13
- data/db/migrate/20140319191237_add_show_dates_to_advanced_search.rb +0 -6
- data/db/migrate/20140328172333_add_cols_to_events_pass_types.rb +0 -6
- data/db/migrate/20140328174217_add_deleted_at_to_ept.rb +0 -9
- data/db/migrate/20140328185432_add_active_to_ept.rb +0 -5
- data/db/migrate/20140328192612_add_pass_type_id_to_search.rb +0 -5
- data/db/migrate/20140415212841_add_min_max_start_dates_to_searches.artfully_ose_engine.rb +0 -6
- data/db/migrate/20140422193345_add_email_copy_to_pass_type.rb +0 -5
- data/db/migrate/20140423181639_add_min_max_end_dates_to_searches.artfully_ose_engine.rb +0 -6
- data/db/migrate/20140423185921_add_cached_stats_to_event.rb +0 -9
- data/db/migrate/20140424174423_add_lifetime_memberships_to_people.artfully_ose_engine.rb +0 -5
- data/db/migrate/20140506155241_add_lpt_to_membership_type.rb +0 -5
- data/db/migrate/20140507184646_add_bday_attributes_to_person.rb +0 -7
- data/db/migrate/20140507201048_add_check_number_to_orders.rb +0 -5
- data/db/migrate/20140515143651_remove_show_stats_view.rb +0 -6
- data/db/migrate/20140521195853_add_deleted_at_to_pass_type.rb +0 -5
- data/db/migrate/20140522205554_add_limit_to_events_pass_types.rb +0 -5
- data/db/migrate/20140523180444_remove_tickets_purchased_from_passes.rb +0 -5
- data/db/migrate/20140603200735_add_subtitle_to_events.rb +0 -5
- data/db/migrate/20140619194127_add_do_not_call_to_people.artfully_ose_engine.rb +0 -5
- data/db/migrate/20140623160543_add_index_to_items.rb +0 -7
- data/spec/factories/action_factories.rb +0 -19
- data/spec/factories/address_factories.rb +0 -11
- data/spec/factories/cart_factories.rb +0 -26
- data/spec/factories/chart_factories.rb +0 -52
- data/spec/factories/discount_factories.rb +0 -11
- data/spec/factories/donation_factories.rb +0 -14
- data/spec/factories/event_factories.rb +0 -29
- data/spec/factories/household_factories.rb +0 -8
- data/spec/factories/import_factories.rb +0 -61
- data/spec/factories/item_factories.rb +0 -51
- data/spec/factories/kit_factories.rb +0 -33
- data/spec/factories/member_factories.rb +0 -19
- data/spec/factories/membership_factories.rb +0 -9
- data/spec/factories/membership_type_factories.rb +0 -18
- data/spec/factories/order_factories.rb +0 -40
- data/spec/factories/organization_factories.rb +0 -48
- data/spec/factories/pass_type_factories.rb +0 -11
- data/spec/factories/payments_factories.rb +0 -97
- data/spec/factories/person_factories.rb +0 -47
- data/spec/factories/phone_factories.rb +0 -6
- data/spec/factories/section_factories.rb +0 -21
- data/spec/factories/segment_factories.rb +0 -6
- data/spec/factories/show_factories.rb +0 -33
- data/spec/factories/ticket_factories.rb +0 -57
- data/spec/factories/ticket_offer_factories.rb +0 -16
- data/spec/factories/ticket_type_factories.rb +0 -8
- data/spec/factories/user_factories.rb +0 -24
data/app/models/phone.rb
CHANGED
@@ -2,6 +2,14 @@ class Phone < ActiveRecord::Base
|
|
2
2
|
attr_accessible :kind, :number
|
3
3
|
belongs_to :person
|
4
4
|
|
5
|
+
#This method is here solely to parse phones in the Athena migration
|
6
|
+
#There were in the form type:number
|
7
|
+
def self.from_athena(unparsed_phone)
|
8
|
+
Phone.new.tap do |phone|
|
9
|
+
phone.kind, phone.number = unparsed_phone.split(":")
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
5
13
|
def self.kinds
|
6
14
|
[ "Work", "Home", "Cell", "Fax", "Other" ]
|
7
15
|
end
|
data/app/models/refund.rb
CHANGED
@@ -1,8 +1,8 @@
|
|
1
1
|
class Refund
|
2
|
-
attr_accessor :order, :refund_order, :items, :message
|
2
|
+
attr_accessor :order, :refund_order, :items, :message
|
3
3
|
|
4
4
|
BRAINTREE_UNSETTLED_MESSAGE = "Cannot refund a transaction unless it is settled. (91506)"
|
5
|
-
FRIENDLY_UNSETTLED_MESSAGE = "
|
5
|
+
FRIENDLY_UNSETTLED_MESSAGE = "The processor cannot refund that transaction yet. Please try again in a few hours."
|
6
6
|
|
7
7
|
def initialize(order, items)
|
8
8
|
self.order = order
|
@@ -11,8 +11,6 @@ class Refund
|
|
11
11
|
|
12
12
|
def submit(options = {})
|
13
13
|
return_items_to_inventory = options[:and_return] || false
|
14
|
-
@send_email_confirmation = options[:send_email_confirmation] || false
|
15
|
-
|
16
14
|
|
17
15
|
ActiveRecord::Base.transaction do
|
18
16
|
items.each do |i|
|
@@ -77,7 +75,6 @@ class Refund
|
|
77
75
|
@refund_order.parent = order
|
78
76
|
@refund_order.for_organization order.organization
|
79
77
|
@refund_order.items = items.collect(&:to_refund)
|
80
|
-
@refund_order.skip_email = !send_email_confirmation
|
81
78
|
@refund_order.save!
|
82
79
|
@refund_order
|
83
80
|
end
|
data/app/models/sale.rb
CHANGED
@@ -1,22 +1,21 @@
|
|
1
1
|
class Sale
|
2
2
|
include ActiveModel::Validations
|
3
3
|
|
4
|
-
attr_accessor :ticket_types, :quantities, :tickets, :cart, :message, :error, :sale_made
|
4
|
+
attr_accessor :ticket_types, :quantities, :tickets, :cart, :message, :error, :sale_made
|
5
5
|
attr_reader :buyer
|
6
6
|
|
7
7
|
validate :has_tickets?
|
8
8
|
|
9
|
-
def initialize(show, ticket_types, cart, quantities = {}
|
9
|
+
def initialize(show, ticket_types, cart, quantities = {})
|
10
10
|
@show = show
|
11
11
|
@ticket_types = ticket_types
|
12
|
-
|
13
|
-
|
12
|
+
|
14
13
|
#When coming from a browser, all keys and values in @quantities are STRINGS
|
15
14
|
@quantities = quantities
|
16
15
|
@cart = cart
|
17
16
|
@tickets = []
|
18
17
|
|
19
|
-
load_tickets
|
18
|
+
load_tickets
|
20
19
|
end
|
21
20
|
|
22
21
|
def sell(payment)
|
@@ -55,7 +54,7 @@ class Sale
|
|
55
54
|
end
|
56
55
|
end
|
57
56
|
end
|
58
|
-
|
57
|
+
|
59
58
|
def has_tickets?
|
60
59
|
unless non_zero_quantities?
|
61
60
|
errors.add(:base, "Please select a number of tickets to purchase") and return false
|
@@ -67,25 +66,22 @@ class Sale
|
|
67
66
|
private
|
68
67
|
|
69
68
|
def comp_tickets(payment)
|
70
|
-
@comp = Comp.new(tickets.first.show, tickets,
|
69
|
+
@comp = Comp.new(tickets.first.show, tickets, payment.customer, payment.benefactor)
|
71
70
|
@comp.submit
|
72
71
|
@buyer = @comp.recipient
|
73
|
-
@order = @comp.order
|
74
|
-
self.cart.approve!
|
75
72
|
true
|
76
73
|
end
|
77
|
-
|
74
|
+
|
78
75
|
def sell_tickets(payment)
|
79
|
-
checkout = BoxOffice::Checkout.new(cart, payment
|
76
|
+
checkout = BoxOffice::Checkout.new(cart, payment)
|
80
77
|
begin
|
81
78
|
success = checkout.finish
|
82
79
|
@buyer = checkout.person
|
83
|
-
@order = checkout.order
|
84
80
|
if !success
|
85
81
|
if checkout.payment.errors.blank?
|
86
82
|
errors.add(:base, "payment was not accepted")
|
87
83
|
else
|
88
|
-
errors.add(:base, checkout.payment.errors.full_messages.to_sentence.downcase)
|
84
|
+
errors.add(:base, checkout.payment.errors.full_messages.to_sentence.downcase)
|
89
85
|
end
|
90
86
|
return success
|
91
87
|
end
|
@@ -98,4 +94,4 @@ class Sale
|
|
98
94
|
end
|
99
95
|
success
|
100
96
|
end
|
101
|
-
end
|
97
|
+
end
|
data/app/models/sale_search.rb
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
class SaleSearch
|
2
|
-
|
3
|
-
|
4
|
-
attr_reader :event, :show
|
2
|
+
|
3
|
+
attr_reader :start, :stop
|
4
|
+
attr_reader :organization, :event, :show
|
5
5
|
|
6
6
|
def initialize(terms)
|
7
7
|
@organization = terms[:organization]
|
@@ -16,4 +16,22 @@ class SaleSearch
|
|
16
16
|
def results
|
17
17
|
@results ||= Order.sale_search(self).select(&:has_ticket?)
|
18
18
|
end
|
19
|
+
|
20
|
+
private
|
21
|
+
|
22
|
+
def start_with(start)
|
23
|
+
start.present? ? DateTime.parse(start) : default_start
|
24
|
+
end
|
25
|
+
|
26
|
+
def stop_with(stop)
|
27
|
+
stop.present? ? Sundial.midnightish(@organization, stop) : default_stop
|
28
|
+
end
|
29
|
+
|
30
|
+
def default_start
|
31
|
+
DateTime.now.in_time_zone(@organization.time_zone).beginning_of_month
|
32
|
+
end
|
33
|
+
|
34
|
+
def default_stop
|
35
|
+
DateTime.now.in_time_zone(@organization.time_zone).end_of_day
|
36
|
+
end
|
19
37
|
end
|
data/app/models/search.rb
CHANGED
@@ -3,25 +3,16 @@ class Search < ActiveRecord::Base
|
|
3
3
|
belongs_to :organization
|
4
4
|
belongs_to :event
|
5
5
|
belongs_to :membership_type
|
6
|
-
belongs_to :pass_type
|
7
|
-
belongs_to :relation
|
8
|
-
|
9
6
|
validates_presence_of :organization_id
|
10
7
|
|
11
|
-
attr_accessible :zip, :state,
|
12
|
-
:
|
13
|
-
:tagging, :person_subtype,
|
8
|
+
attr_accessible :zip, :state, :event_id, :tagging,
|
9
|
+
:person_type, :person_subtype,
|
14
10
|
:min_lifetime_value, :max_lifetime_value,
|
15
11
|
:min_donations_amount, :max_donations_amount,
|
16
12
|
:min_donations_date, :max_donations_date, :discount_code,
|
17
|
-
:membership_status, :
|
18
|
-
:relation_id, :output_individuals, :output_households, :output_companies,
|
19
|
-
:show_date_start, :show_date_end,
|
20
|
-
:min_membership_start_date, :max_membership_start_date,
|
21
|
-
:min_membership_end_date, :max_membership_end_date
|
13
|
+
:membership_status, :passholder, :membership_type_id, :membership_type
|
22
14
|
|
23
|
-
|
24
|
-
ANY_MEMBERSHIP_TYPE = -1
|
15
|
+
attr_accessor :membership_status, :passholder
|
25
16
|
|
26
17
|
def length
|
27
18
|
people.length
|
@@ -39,44 +30,28 @@ class Search < ActiveRecord::Base
|
|
39
30
|
Delayed::Job.enqueue(ActionJob.new(action, people))
|
40
31
|
end
|
41
32
|
|
42
|
-
def event_name
|
43
|
-
event.try(:name) || Event::ANY_EVENT_TEXT
|
44
|
-
end
|
45
|
-
|
46
33
|
def description
|
47
|
-
|
48
|
-
conditions = ""
|
49
|
-
|
50
|
-
conditions << c.call("Are tagged with #{tagging}.") if tagging.present?
|
51
|
-
conditions << c.call("Have #{relation.indefinite_article} '#{relation.description}' relationship") if relation.present?
|
52
|
-
|
53
|
-
if event_id.present?
|
54
|
-
if has_purchased_for
|
55
|
-
conditions << c.call("Purchased tickets for #{event_name}.")
|
56
|
-
else
|
57
|
-
conditions << c.call("Have not purchased tickets for #{event_name}.")
|
58
|
-
end
|
59
|
-
|
60
|
-
conditions << c.call("For show dates after #{show_date_start.strftime('%D')}") if show_date_start.present?
|
61
|
-
conditions << c.call("For show dates through #{show_date_end.strftime('%D')}") if show_date_end.present?
|
62
|
-
end
|
34
|
+
conditions = []
|
63
35
|
|
36
|
+
conditions << "Are tagged with #{tagging}." if tagging.present?
|
37
|
+
conditions << "Bought tickets for #{event.name}." if event_id.present?
|
38
|
+
conditions << "Purchased #{membership_type.name}" if membership_type_id.present?
|
64
39
|
if zip.present? || state.present?
|
65
40
|
locations = []
|
66
41
|
locations << state if state.present?
|
67
42
|
locations << "the zipcode of #{zip}" if zip.present?
|
68
|
-
conditions <<
|
43
|
+
conditions << "Are located within #{locations.to_sentence}."
|
69
44
|
end
|
70
45
|
if min_lifetime_value.present? && max_lifetime_value.present?
|
71
|
-
conditions <<
|
46
|
+
conditions << "Have a lifetime value between $#{min_lifetime_value} and $#{max_lifetime_value}."
|
72
47
|
elsif min_lifetime_value.present?
|
73
|
-
conditions <<
|
48
|
+
conditions << "Have a minimum lifetime value of $#{min_lifetime_value}."
|
74
49
|
elsif max_lifetime_value.present?
|
75
|
-
conditions <<
|
50
|
+
conditions << "Have a maximum lifetime value of $#{max_lifetime_value}."
|
76
51
|
end
|
77
52
|
|
78
53
|
unless discount_code.blank?
|
79
|
-
conditions << ((discount_code == Discount::ALL_DISCOUNTS_STRING) ?
|
54
|
+
conditions << ((discount_code == Discount::ALL_DISCOUNTS_STRING) ? "Used any discount code" : "Used discount code #{discount_code}.")
|
80
55
|
end
|
81
56
|
|
82
57
|
unless [min_donations_amount, max_donations_amount, min_donations_date, max_donations_date].all?(&:blank?)
|
@@ -99,308 +74,80 @@ class Search < ActiveRecord::Base
|
|
99
74
|
else
|
100
75
|
string << " overall."
|
101
76
|
end
|
102
|
-
conditions <<
|
77
|
+
conditions << string
|
103
78
|
end
|
104
79
|
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
80
|
+
String.new.tap do |s|
|
81
|
+
if conditions.blank?
|
82
|
+
if person_type == "Company"
|
83
|
+
if person_subtype.present?
|
84
|
+
return "All #{person_subtype.pluralize(2)}."
|
85
|
+
else
|
86
|
+
return "All companies."
|
87
|
+
end
|
88
|
+
else
|
89
|
+
return "All individuals."
|
90
|
+
end
|
110
91
|
else
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
state_str = (membership_status == "None") ? "not" : membership_status.downcase
|
118
|
-
conditions << c.call("Are #{state_str} members")
|
119
|
-
end
|
120
|
-
|
121
|
-
if membership_type_id.present?
|
122
|
-
if any_membership_type?
|
123
|
-
conditions << c.call("Are members")
|
92
|
+
if person_type == "Company"
|
93
|
+
if person_subtype.present?
|
94
|
+
s = "#{person_subtype.pluralize(2)} that: "
|
95
|
+
else
|
96
|
+
s = "Companies that: "
|
97
|
+
end
|
124
98
|
else
|
125
|
-
|
99
|
+
s = "Individuals that: "
|
126
100
|
end
|
101
|
+
return s + "<ul>" + conditions.collect{|c| "<li>#{c}</li>"}.join + "</ul>"
|
127
102
|
end
|
128
|
-
|
129
|
-
|
130
|
-
# Membership Start
|
131
|
-
if min_membership_start_date.present? && max_membership_start_date.present?
|
132
|
-
conditions << c.call("Have memberships starting from #{min_membership_start_date.strftime('%D')} through #{max_membership_start_date.strftime('%D')}.")
|
133
|
-
elsif min_membership_start_date.present?
|
134
|
-
conditions << c.call("Have memberships starting on or after #{min_membership_start_date.strftime('%D')}.")
|
135
|
-
elsif max_membership_start_date.present?
|
136
|
-
conditions << c.call("Have memberships starting on or before #{max_membership_start_date.strftime('%D')}.")
|
137
|
-
end
|
138
|
-
|
139
|
-
# Membership End
|
140
|
-
if min_membership_end_date.present? && max_membership_end_date.present?
|
141
|
-
conditions << c.call("Have memberships ending from #{min_membership_end_date.strftime('%D')} through #{max_membership_end_date.strftime('%D')}.")
|
142
|
-
elsif min_membership_end_date.present?
|
143
|
-
conditions << c.call("Have memberships ending on or after #{min_membership_end_date.strftime('%D')}.")
|
144
|
-
elsif max_membership_end_date.present?
|
145
|
-
conditions << c.call("Have memberships ending on or before #{max_membership_end_date.strftime('%D')}.")
|
146
|
-
end
|
147
|
-
end
|
148
|
-
|
149
|
-
if searching_passes?
|
150
|
-
conditions << c.call("Have a current #{pass_type.passerize}.")
|
151
|
-
end
|
152
|
-
|
153
|
-
categories << "individuals" if output_individuals
|
154
|
-
|
155
|
-
if self.organization.can? :access,:relationships
|
156
|
-
categories << "households" if output_households
|
157
103
|
end
|
158
|
-
|
159
|
-
categories[-1] = "and #{categories[-1]}" if categories.length > 1
|
160
|
-
|
161
|
-
categories << "Anything " if categories.empty?
|
162
|
-
|
163
|
-
if conditions.blank?
|
164
|
-
result = "All " << categories.join(", ") << "."
|
165
|
-
else
|
166
|
-
result = categories.join(" ") << " that: " << "<ul>" << conditions << "</ul>"
|
167
|
-
result[0] = result[0].upcase
|
168
|
-
end
|
169
|
-
|
170
|
-
result
|
171
|
-
|
172
|
-
end
|
173
|
-
|
174
|
-
def offset_show_date_start
|
175
|
-
return nil if self.show_date_start.blank?
|
176
|
-
@offset_show_date_start ||= self.show_date_start.to_datetime.change(:offset => offset(self.show_date_start))
|
177
|
-
end
|
178
|
-
|
179
|
-
def offset_show_date_end
|
180
|
-
return nil if self.show_date_end.blank?
|
181
|
-
@offset_show_date_end ||= self.show_date_end.to_datetime.end_of_day.change(:offset => offset(self.show_date_end))
|
182
|
-
end
|
183
|
-
|
184
|
-
def offset(datetime)
|
185
|
-
@offset ||= datetime.in_time_zone(ActiveSupport::TimeZone.create(self.organization.time_zone)).formatted_offset
|
186
104
|
end
|
187
105
|
|
188
106
|
private
|
189
107
|
|
190
|
-
|
191
|
-
|
192
|
-
|
193
|
-
people = Person.where(:organization_id => organization_id)
|
194
|
-
people = people.where(:dummy => false)
|
195
|
-
people = people.order('ordered_last_names ASC')
|
196
|
-
|
197
|
-
people = people.tagged_with(tagging) unless tagging.blank?
|
198
|
-
people = people.joins(:address) unless zip.blank? && state.blank?
|
199
|
-
|
200
|
-
people = add_event_query(people, column_names)
|
201
|
-
|
202
|
-
people = people.where("addresses.zip" => zip.to_s) unless zip.blank?
|
203
|
-
people = people.where("addresses.state" => state) unless state.blank?
|
204
|
-
people = people.where("people.lifetime_value >= ?", min_lifetime_value * 100.0) unless min_lifetime_value.blank?
|
205
|
-
people = people.where("people.lifetime_value <= ?", max_lifetime_value * 100.0) unless max_lifetime_value.blank?
|
206
|
-
|
207
|
-
unless discount_code.blank?
|
208
|
-
people = people.joins(:orders => [:items => [:discount]])
|
209
|
-
people = (discount_code == Discount::ALL_DISCOUNTS_STRING) ? people.where("items.discount_id is not null") : people.where("discounts.code = ?", discount_code)
|
210
|
-
end
|
211
|
-
|
212
|
-
unless [min_donations_amount, max_donations_amount, min_donations_date, max_donations_date].all?(&:blank?)
|
213
|
-
people = people.joins(:orders => :items)
|
214
|
-
people = people.where("orders.created_at >= ?", min_donations_date) unless min_donations_date.blank?
|
215
|
-
people = people.where("orders.created_at <= ?", max_donations_date + 1.day) unless max_donations_date.blank?
|
216
|
-
people = people.where("items.product_type = 'Donation'")
|
217
|
-
people = people.group("people.id")
|
218
|
-
if min_donations_amount.blank?
|
219
|
-
people = people.having("SUM(items.price + items.nongift_amount) >= 1")
|
220
|
-
else
|
221
|
-
people = people.having("SUM(items.price + items.nongift_amount) >= ?", min_donations_amount * 100.0)
|
222
|
-
end
|
223
|
-
people = people.having("SUM(items.price + items.nongift_amount) <= ?", max_donations_amount * 100.0) unless max_donations_amount.blank?
|
224
|
-
end
|
225
|
-
|
226
|
-
### MEMBERSHIP ##
|
227
|
-
if searching_membership?
|
228
|
-
people = people.joins('LEFT JOIN members ON members.person_id = people.id')
|
229
|
-
people = people.joins('LEFT JOIN memberships ON memberships.member_id = members.id ')
|
230
|
-
people = people.joins('LEFT JOIN membership_types ON membership_types.id = memberships.membership_type_id')
|
231
|
-
end
|
232
|
-
|
233
|
-
if membership_status.present?
|
234
|
-
people = people.merge(Member.current) if membership_status == 'Current'
|
235
|
-
people = people.merge(Member.lapsed) if membership_status == 'Lapsed'
|
236
|
-
people = people.merge(Member.past) if membership_status == 'Past'
|
237
|
-
people = people.where('members.id IS NULL') if membership_status == 'None'
|
238
|
-
end
|
239
|
-
|
240
|
-
if membership_type_id.present?
|
241
|
-
people = if any_membership_type?
|
242
|
-
people.where('memberships.member_id IS NOT NULL')
|
243
|
-
else
|
244
|
-
people.where('membership_types.id = ?', membership_type_id)
|
245
|
-
end
|
246
|
-
end
|
247
|
-
|
248
|
-
# Membership Start
|
249
|
-
people = people.where('memberships.starts_at >= ?', min_membership_start_date) if min_membership_start_date.present?
|
250
|
-
people = people.where('memberships.starts_at <= ?', max_membership_start_date) if max_membership_start_date.present?
|
251
|
-
|
252
|
-
# Membership End
|
253
|
-
people = people.where('memberships.ends_at >= ?', min_membership_end_date) if min_membership_end_date.present?
|
254
|
-
people = people.where('memberships.ends_at <= ?', max_membership_end_date) if max_membership_end_date.present?
|
255
|
-
|
256
|
-
### PASSES ###
|
257
|
-
if searching_passes?
|
258
|
-
people = add_passes_query(people)
|
259
|
-
end
|
260
|
-
|
261
|
-
people = people.companies if output_companies && !output_individuals
|
262
|
-
people = people.where("people.subtype" => person_subtype) if output_companies && person_subtype.present?
|
263
|
-
|
264
|
-
people = people.individuals if !output_companies && output_individuals
|
265
|
-
|
266
|
-
people = people.joins('left join households on people.household_id = households.id') if output_households
|
267
|
-
|
268
|
-
people = people.in_household if households_only?
|
269
|
-
|
270
|
-
if relation_id.present?
|
271
|
-
people = people.joins('left join relationships on people.id = relationships.person_id')
|
272
|
-
people = people.where(:relationships => {:relation_id => relation_id})
|
273
|
-
end
|
274
|
-
|
275
|
-
column_names << "lower(people.last_name) AS ordered_last_names"
|
276
|
-
people.select(column_names).group("people.id")
|
277
|
-
end
|
278
|
-
|
279
|
-
def households_only?
|
280
|
-
output_households && (!output_companies && !output_individuals)
|
281
|
-
end
|
282
|
-
|
283
|
-
def add_passes_query(people)
|
284
|
-
people = people.joins("LEFT JOIN #{Pass.table_name} ON #{Pass.table_name}.person_id = #{Person.table_name}.id")
|
285
|
-
people = people.merge(Pass.not_expired)
|
286
|
-
people = people.where("#{Pass.table_name}.pass_type_id = ?", pass_type_id)
|
287
|
-
people
|
288
|
-
end
|
289
|
-
|
290
|
-
def add_event_query(people, column_names)
|
291
|
-
if any_event?
|
292
|
-
people = add_any_event_query(people, column_names)
|
293
|
-
elsif specific_event?
|
294
|
-
people = add_specific_event_query(people, column_names)
|
295
|
-
end
|
296
|
-
|
297
|
-
people
|
298
|
-
end
|
299
|
-
|
300
|
-
def add_specific_event_query(people, column_names)
|
301
|
-
if has_purchased_for
|
302
|
-
people = people.joins("LEFT JOIN `tickets` ON `tickets`.`buyer_id` = `people`.`id` ")
|
303
|
-
.joins("LEFT JOIN `shows` ON `shows`.`id` = `tickets`.`show_id` ")
|
304
|
-
.joins("LEFT JOIN `events` ON `events`.`id` = `shows`.`event_id`")
|
305
|
-
|
306
|
-
people = people.where("events.id" => event_id)
|
307
|
-
|
308
|
-
if show_date_search?
|
309
|
-
people = people.where("shows.datetime >= ?", offset_show_date_start) unless show_date_start.blank?
|
310
|
-
people = people.where("shows.datetime <= ?", offset_show_date_end) unless show_date_end.blank?
|
311
|
-
end
|
108
|
+
def find_people
|
109
|
+
column_names = Person.column_names.collect {|cn| "people.#{cn}" }
|
110
|
+
column_names << "lower(people.last_name) AS ordered_last_names"
|
312
111
|
|
313
|
-
|
314
|
-
|
315
|
-
|
316
|
-
.where("shows.event_id = ?", event_id)
|
317
|
-
.where("tickets.buyer_id = people.id")
|
112
|
+
people = Person.where(:organization_id => organization_id)
|
113
|
+
people = people.where(:dummy => false)
|
114
|
+
people = people.order('ordered_last_names ASC')
|
318
115
|
|
319
|
-
|
320
|
-
|
116
|
+
people = people.where("people.type" => person_type) unless person_type.blank?
|
117
|
+
people = people.where("people.subtype" => person_subtype) unless person_type.blank? || person_subtype.blank?
|
321
118
|
|
322
|
-
|
323
|
-
|
324
|
-
|
325
|
-
|
326
|
-
|
327
|
-
|
328
|
-
|
329
|
-
people_subquery = Person.select("people.id")
|
330
|
-
.joins("LEFT JOIN `tickets` ON `tickets`.`buyer_id` = `people`.`id` ")
|
331
|
-
.joins("LEFT JOIN `shows` ON `shows`.`id` = `tickets`.`show_id` ")
|
332
|
-
.joins("LEFT JOIN `events` ON `events`.`id` = `shows`.`event_id`")
|
333
|
-
.where("events.id" => event_id)
|
334
|
-
people = people.where("people.id not in (#{people_subquery.to_sql})")
|
335
|
-
end
|
119
|
+
people = people.tagged_with(tagging) unless tagging.blank?
|
120
|
+
people = people.joins(:address) unless zip.blank? && state.blank?
|
121
|
+
people = people.joins(:tickets => {:show => :event}).where("events.id" => event_id) unless event_id.blank?
|
122
|
+
people = people.where("addresses.zip" => zip.to_s) unless zip.blank?
|
123
|
+
people = people.where("addresses.state" => state) unless state.blank?
|
124
|
+
people = people.where("people.lifetime_value >= ?", min_lifetime_value * 100.0) unless min_lifetime_value.blank?
|
125
|
+
people = people.where("people.lifetime_value <= ?", max_lifetime_value * 100.0) unless max_lifetime_value.blank?
|
336
126
|
|
337
|
-
|
338
|
-
|
339
|
-
|
340
|
-
people
|
127
|
+
unless discount_code.blank?
|
128
|
+
people = people.joins(:orders => [:items => [:discount]])
|
129
|
+
people = (discount_code == Discount::ALL_DISCOUNTS_STRING) ? people.where("items.discount_id is not null") : people.where("discounts.code = ?", discount_code)
|
341
130
|
end
|
342
131
|
|
343
|
-
|
344
|
-
people = people.joins(
|
345
|
-
|
346
|
-
|
347
|
-
|
348
|
-
|
349
|
-
|
350
|
-
|
351
|
-
|
352
|
-
|
353
|
-
people = people.having("ticket_count > 0")
|
354
|
-
elsif !has_purchased_for
|
355
|
-
if show_date_search?
|
356
|
-
people_subquery = Ticket.joins(:show)
|
357
|
-
.where("tickets.buyer_id = people.id")
|
358
|
-
|
359
|
-
people_subquery = people_subquery.where("shows.datetime >= ?", offset_show_date_start) unless show_date_start.blank?
|
360
|
-
people_subquery = people_subquery.where("shows.datetime <= ?", offset_show_date_end) unless show_date_end.blank?
|
361
|
-
|
362
|
-
people = people.where("NOT EXISTS (#{people_subquery.to_sql})")
|
363
|
-
else
|
364
|
-
column_names << "count(tickets.id) as ticket_count"
|
365
|
-
people = people.having("ticket_count = 0")
|
366
|
-
end
|
132
|
+
unless [min_donations_amount, max_donations_amount, min_donations_date, max_donations_date].all?(&:blank?)
|
133
|
+
people = people.joins(:orders => :items)
|
134
|
+
people = people.where("orders.created_at >= ?", min_donations_date) unless min_donations_date.blank?
|
135
|
+
people = people.where("orders.created_at <= ?", max_donations_date + 1.day) unless max_donations_date.blank?
|
136
|
+
people = people.where("items.product_type = 'Donation'")
|
137
|
+
people = people.group("people.id")
|
138
|
+
if min_donations_amount.blank?
|
139
|
+
people = people.having("SUM(items.price + items.nongift_amount) >= 1")
|
140
|
+
else
|
141
|
+
people = people.having("SUM(items.price + items.nongift_amount) >= ?", min_donations_amount * 100.0)
|
367
142
|
end
|
368
|
-
|
369
|
-
people
|
143
|
+
people = people.having("SUM(items.price + items.nongift_amount) <= ?", max_donations_amount * 100.0) unless max_donations_amount.blank?
|
370
144
|
end
|
371
145
|
|
372
|
-
|
373
|
-
|
146
|
+
unless membership_type_id.blank?
|
147
|
+
people = people.joins(:member => [:memberships => [:membership_type]])
|
148
|
+
.where('membership_types.id = ?', membership_type_id)
|
374
149
|
end
|
375
150
|
|
376
|
-
|
377
|
-
|
378
|
-
end
|
379
|
-
|
380
|
-
def any_event?
|
381
|
-
self.event_id == ANY_EVENT
|
382
|
-
end
|
383
|
-
|
384
|
-
def specific_event?
|
385
|
-
self.event_id.present? && self.event_id > ANY_EVENT
|
386
|
-
end
|
387
|
-
|
388
|
-
def any_membership_type?
|
389
|
-
membership_type_id == ANY_MEMBERSHIP_TYPE
|
390
|
-
end
|
391
|
-
|
392
|
-
def searching_passes?
|
393
|
-
pass_type_id.present?
|
394
|
-
end
|
395
|
-
|
396
|
-
def searching_membership?
|
397
|
-
[
|
398
|
-
:membership_status,
|
399
|
-
:membership_type_id,
|
400
|
-
:min_membership_start_date,
|
401
|
-
:max_membership_start_date,
|
402
|
-
:min_membership_end_date,
|
403
|
-
:max_membership_end_date
|
404
|
-
].any? { |s| send(s).present? }
|
405
|
-
end
|
151
|
+
people.select(column_names).uniq
|
152
|
+
end
|
406
153
|
end
|