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.
Files changed (539) hide show
  1. checksums.yaml +9 -9
  2. data/app/assets/fonts/FontAwesome.otf +0 -0
  3. data/app/assets/fonts/fontawesome-webfont.eot +0 -0
  4. data/app/assets/fonts/fontawesome-webfont.svg +252 -472
  5. data/app/assets/fonts/fontawesome-webfont.ttf +0 -0
  6. data/app/assets/fonts/fontawesome-webfont.woff +0 -0
  7. data/app/assets/images/person-default-avatar.psd +0 -0
  8. data/app/assets/javascripts/application.js +10 -163
  9. data/app/assets/javascripts/box-office.js +262 -0
  10. data/app/assets/javascripts/custom/inline-people-search.js +40 -40
  11. data/app/assets/javascripts/custom/people.js +5 -68
  12. data/app/assets/javascripts/custom/prices.js +0 -1
  13. data/app/assets/javascripts/custom/show.js +8 -18
  14. data/app/assets/javascripts/jquery-lib/jquery.mask-money.js +0 -1
  15. data/app/assets/javascripts/locationselector.js +1 -1
  16. data/app/assets/javascripts/store/jquery.validate.additional-methods.js +159 -476
  17. data/app/assets/javascripts/store/jquery.validate.js +406 -449
  18. data/app/assets/javascripts/store/store.js +5 -29
  19. data/app/assets/stylesheets/application.sass +60 -223
  20. data/app/assets/stylesheets/bootstrap-overrides.css +3 -13
  21. data/app/assets/stylesheets/bootstrap.css +0 -1
  22. data/app/assets/stylesheets/font-awesome.sass +759 -0
  23. data/app/assets/stylesheets/sass/_event_list.sass +1 -12
  24. data/app/assets/stylesheets/sass/_tags.sass +2 -13
  25. data/app/assets/stylesheets/sass/box-office.sass +1 -2
  26. data/app/assets/stylesheets/sass/cart.sass +6 -0
  27. data/app/assets/stylesheets/sass/store.sass +68 -123
  28. data/app/assets/stylesheets/storefront.css +1 -2
  29. data/app/concerns/itemable.rb +1 -1
  30. data/app/controllers/artfully_ose_controller.rb +7 -29
  31. data/app/controllers/discounts_controller.rb +1 -8
  32. data/app/controllers/events_controller.rb +33 -41
  33. data/app/controllers/exchanges_controller.rb +2 -8
  34. data/app/controllers/export_controller.rb +0 -6
  35. data/app/controllers/imports_controller.rb +0 -19
  36. data/app/controllers/members/index_controller.rb +1 -1
  37. data/app/controllers/members/members_controller.rb +1 -6
  38. data/app/controllers/membership_awards_controller.rb +58 -0
  39. data/app/controllers/membership_types_controller.rb +3 -40
  40. data/app/controllers/memberships_controller.rb +4 -6
  41. data/app/controllers/orders_controller.rb +2 -86
  42. data/app/controllers/organizations_controller.rb +3 -4
  43. data/app/controllers/people_controller.rb +23 -54
  44. data/app/controllers/refunds_controller.rb +7 -7
  45. data/app/controllers/sales_controller.rb +28 -67
  46. data/app/controllers/searches_controller.rb +9 -15
  47. data/app/controllers/sections_controller.rb +2 -2
  48. data/app/controllers/segments_controller.rb +4 -4
  49. data/app/controllers/shows_controller.rb +49 -79
  50. data/app/controllers/slices_controller.rb +2 -3
  51. data/app/controllers/statements_controller.rb +1 -1
  52. data/app/controllers/store/checkouts_controller.rb +3 -8
  53. data/app/controllers/store/donations_controller.rb +1 -19
  54. data/app/controllers/store/events_controller.rb +1 -14
  55. data/app/controllers/store/memberships_controller.rb +1 -12
  56. data/app/controllers/store/orders_controller.rb +17 -36
  57. data/app/controllers/store/passes_controller.rb +0 -9
  58. data/app/controllers/store/store_controller.rb +2 -7
  59. data/app/controllers/tickets_controller.rb +2 -2
  60. data/app/helpers/artfully_ose_helper.rb +21 -79
  61. data/app/helpers/link_helper.rb +2 -12
  62. data/app/mailers/order_mailer.rb +1 -28
  63. data/app/mailers/reports_mailer.rb +4 -5
  64. data/app/models/ability.rb +0 -1
  65. data/app/models/action.rb +1 -1
  66. data/app/models/actions/go_action.rb +2 -3
  67. data/app/{concerns → models/actions}/immutable_action.rb +0 -0
  68. data/app/models/address.rb +11 -32
  69. data/app/models/{cart.rb → carts/cart.rb} +37 -46
  70. data/app/models/carts/cart_finder.rb +33 -0
  71. data/app/models/checkout.rb +41 -85
  72. data/app/models/comp.rb +17 -24
  73. data/app/models/company.rb +1 -1
  74. data/app/models/contribution.rb +0 -1
  75. data/app/models/database_views/item_view.rb +28 -169
  76. data/app/models/database_views/order_view.rb +34 -0
  77. data/app/models/donation.rb +0 -4
  78. data/app/models/door_list.rb +3 -6
  79. data/app/models/event.rb +10 -60
  80. data/app/models/exchange.rb +5 -7
  81. data/app/models/{ext.rb → ext/ext.rb} +1 -14
  82. data/app/models/ext/integrations.rb +21 -39
  83. data/app/models/fee_strategy.rb +1 -47
  84. data/app/models/import.rb +2 -22
  85. data/app/models/imports/donations_import.rb +19 -1
  86. data/app/models/imports/events_import.rb +51 -43
  87. data/app/models/individual.rb +1 -3
  88. data/app/models/item.rb +11 -28
  89. data/app/models/job/daily_email_report_job.rb +6 -20
  90. data/app/models/job/mailchimp_sync_job.rb +3 -1
  91. data/app/models/job/order_processor.rb +12 -78
  92. data/app/models/job/show_creator.rb +3 -8
  93. data/app/models/kit.rb +4 -2
  94. data/app/models/kits/mailchimp_kit.rb +10 -18
  95. data/app/models/kits/regular_donation_kit.rb +8 -38
  96. data/app/models/member.rb +17 -152
  97. data/app/models/membership.rb +23 -59
  98. data/app/models/membership_award.rb +23 -0
  99. data/app/models/membership_type.rb +2 -44
  100. data/app/models/note.rb +1 -1
  101. data/app/models/order_handler.rb +39 -100
  102. data/app/models/orders/comp_order.rb +0 -4
  103. data/app/models/orders/imported_order.rb +0 -4
  104. data/app/models/{order.rb → orders/order.rb} +18 -113
  105. data/app/models/orders/refund_order.rb +0 -4
  106. data/app/{concerns → models/orders}/unrefundable.rb +0 -0
  107. data/app/models/organization.rb +15 -55
  108. data/app/models/organization_ability.rb +0 -1
  109. data/app/models/parsed_row.rb +3 -58
  110. data/app/models/payments/cash_payment.rb +1 -3
  111. data/app/models/payments/comp_payment.rb +1 -3
  112. data/app/models/payments/credit_card_payment.rb +23 -44
  113. data/app/models/{payment.rb → payments/payment.rb} +1 -29
  114. data/app/models/person.rb +36 -140
  115. data/app/models/phone.rb +8 -0
  116. data/app/models/refund.rb +2 -5
  117. data/app/models/sale.rb +10 -14
  118. data/app/models/sale_search.rb +21 -3
  119. data/app/models/search.rb +67 -320
  120. data/app/models/section.rb +2 -18
  121. data/app/models/show.rb +20 -67
  122. data/app/models/slices.rb +8 -25
  123. data/app/models/statement.rb +5 -32
  124. data/app/models/ticket.rb +15 -50
  125. data/app/models/ticket/locker.rb +1 -2
  126. data/app/models/ticket/pricing.rb +1 -11
  127. data/app/models/ticket/reports.rb +0 -16
  128. data/app/models/ticket/sale_transitions.rb +0 -4
  129. data/app/models/ticket/template.rb +0 -1
  130. data/app/models/ticket/transfers.rb +2 -12
  131. data/app/models/ticket_summary.rb +1 -7
  132. data/app/models/ticket_type.rb +7 -59
  133. data/app/models/user.rb +5 -18
  134. data/app/models/user_membership.rb +3 -21
  135. data/app/models/valuation/lifetime_ticket_value.rb +1 -1
  136. data/app/models/venue.rb +7 -21
  137. data/app/presenters/event_presenter.rb +1 -1
  138. data/app/views/actions/_form.html.haml +6 -6
  139. data/app/views/actions/get/_show.html.haml +13 -2
  140. data/app/views/actions/give/_show.html.haml +1 -1
  141. data/app/views/actions/shared/_show.html.haml +1 -1
  142. data/app/views/addresses/_address.html.haml +6 -7
  143. data/app/views/contributions/_form.html.haml +1 -1
  144. data/app/views/contributions/index.html.haml +2 -2
  145. data/app/views/discounts/_discount_section_fields.html.haml +1 -1
  146. data/app/views/discounts/_form.html.haml +1 -1
  147. data/app/views/discounts/index.html.haml +1 -1
  148. data/app/views/events/_day_date_show.html.haml +2 -2
  149. data/app/views/events/_discount_section_fields.html.haml +1 -1
  150. data/app/views/events/_header.html.haml +0 -1
  151. data/app/views/events/_list.html.haml +5 -10
  152. data/app/views/events/_menu.html.haml +15 -6
  153. data/app/views/events/_section_fields.html.haml +1 -1
  154. data/app/views/events/_share_and_sell.haml +2 -3
  155. data/app/views/events/_ticket_type_fields.html.haml +4 -43
  156. data/app/views/events/edit.html.haml +1 -6
  157. data/app/views/events/image.html.haml +1 -2
  158. data/app/views/events/index.html.haml +3 -20
  159. data/app/views/events/show.html.haml +1 -3
  160. data/app/views/events/temp_discount_form.html.haml +1 -1
  161. data/app/views/events/temp_discounts_index.html.haml +1 -1
  162. data/app/views/exchanges/new.html.haml +28 -51
  163. data/app/views/imports/donations/_pending.html.haml +1 -1
  164. data/app/views/imports/events/_pending.html.haml +1 -1
  165. data/app/views/imports/index.html.haml +3 -6
  166. data/app/views/imports/people/_imported.html.haml +2 -2
  167. data/app/views/imports/people/_new.html.haml +8 -20
  168. data/app/views/imports/people/_pending.html.haml +2 -2
  169. data/app/views/imports/people/_recalled.html.haml +1 -1
  170. data/app/views/imports/shared/_sidebar.html.haml +1 -1
  171. data/app/views/index/dashboard.html.haml +4 -4
  172. data/app/views/layouts/_flash.html.haml +3 -3
  173. data/app/views/layouts/_google_analytics.html.haml +2 -5
  174. data/app/views/layouts/_menu.html.haml +5 -9
  175. data/app/views/layouts/application.html.haml +2 -2
  176. data/app/views/layouts/devise_layout.html.haml +2 -2
  177. data/app/views/layouts/members.html.haml +1 -1
  178. data/app/views/layouts/storefront.html.haml +15 -27
  179. data/app/views/members/index/index.html.haml +13 -7
  180. data/app/views/membership_awards/confirm.html.haml +59 -0
  181. data/app/views/membership_awards/create.html.haml +1 -0
  182. data/app/views/membership_awards/new.html.haml +74 -0
  183. data/app/views/membership_types/_form.html.haml +19 -67
  184. data/app/views/membership_types/index.html.haml +14 -15
  185. data/app/views/memberships/index.html.haml +50 -116
  186. data/app/views/merges/find_person.html.haml +1 -1
  187. data/app/views/notes/_note.html.haml +4 -4
  188. data/app/views/order_mailer/confirmation_for.html.haml +21 -33
  189. data/app/views/order_mailer/confirmation_for.text.haml +3 -6
  190. data/app/views/orders/_item_table.haml +8 -25
  191. data/app/views/orders/_order_sidebar.html.haml +4 -2
  192. data/app/views/orders/sales.html.haml +3 -3
  193. data/app/views/organizations/_connection_form.html.haml +1 -1
  194. data/app/views/organizations/_form.html.haml +20 -25
  195. data/app/views/organizations/edit.html.haml +2 -2
  196. data/app/views/organizations/show.html.haml +16 -22
  197. data/app/views/people/_edit_modal.html.haml +28 -48
  198. data/app/views/people/_header.html.haml +9 -18
  199. data/app/views/people/_phone_fields.html.haml +1 -1
  200. data/app/views/people/index.html.haml +6 -18
  201. data/app/views/people/new.html.haml +1 -1
  202. data/app/views/people/show.html.haml +24 -71
  203. data/app/views/refunds/new.html.haml +27 -45
  204. data/app/views/reports_mailer/daily.html.haml +21 -86
  205. data/app/views/sales/new.html.haml +125 -33
  206. data/app/views/searches/_form.html.haml +50 -115
  207. data/app/views/searches/_person.html.haml +2 -5
  208. data/app/views/searches/new.html.haml +1 -1
  209. data/app/views/searches/show.html.haml +6 -17
  210. data/app/views/segments/show.html.haml +4 -7
  211. data/app/views/shared/_error_messages.html.haml +1 -1
  212. data/app/views/shared/_tags.html.haml +2 -2
  213. data/app/views/shows/_controls.html.haml +20 -4
  214. data/app/views/shows/_glance.html.haml +5 -1
  215. data/app/views/shows/_sections_table.html.haml +6 -8
  216. data/app/views/shows/_ticket_table.html.haml +3 -3
  217. data/app/views/shows/_work_with.html.haml +5 -5
  218. data/app/views/shows/door_list.html.haml +2 -2
  219. data/app/views/shows/index.html.haml +19 -88
  220. data/app/views/shows/new.html.haml +11 -10
  221. data/app/views/shows/show.html.haml +2 -2
  222. data/app/views/slices/index.html.haml +1 -2
  223. data/app/views/statements/_discounts_table.html.haml +1 -1
  224. data/app/views/statements/_order_location_table.html.haml +1 -1
  225. data/app/views/statements/_payment_method_table.haml +1 -1
  226. data/app/views/statements/_ticket_type_table.haml +2 -5
  227. data/app/views/statements/show.html.haml +2 -5
  228. data/app/views/store/checkouts/thanks.html.haml +16 -38
  229. data/app/views/store/donations/index.html.haml +2 -19
  230. data/app/views/store/events/_calendar.html.haml +4 -1
  231. data/app/views/store/events/index.html.haml +4 -11
  232. data/app/views/store/events/show.html.haml +19 -10
  233. data/app/views/store/memberships/index.html.haml +17 -17
  234. data/app/views/store/orders/show.html.haml +22 -33
  235. data/app/views/store/shared/_donate_form.html.haml +12 -31
  236. data/app/views/store/shows/_show.html.haml +29 -37
  237. data/app/views/user_memberships/_list.html.haml +29 -28
  238. data/app/views/users/invitations/edit.html.haml +9 -19
  239. data/app/views/users/mailer/invitation_instructions.html.erb +8 -0
  240. data/app/views/users/passwords/edit.html.haml +2 -2
  241. data/app/views/users/registrations/edit.html.erb +3 -3
  242. data/app/views/users/sessions/new.html.haml +2 -2
  243. data/app/views/venues/edit.html.haml +1 -3
  244. data/config/initializers/devise.rb +5 -2
  245. data/config/locales/devise.en.yml +1 -1
  246. data/config/locales/devise_invitable.en.yml +1 -1
  247. data/config/locales/en.yml +3 -18
  248. data/config/routes.rb +12 -101
  249. data/lib/artfully_ose.rb +4 -6
  250. data/lib/artfully_ose/common_abilities.rb +2 -8
  251. data/lib/artfully_ose/engine.rb +10 -34
  252. data/lib/artfully_ose/version.rb +1 -1
  253. metadata +45 -349
  254. data/README.md +0 -28
  255. data/app/assets/images/household-default-avatar.png +0 -0
  256. data/app/assets/javascripts/angular-resource.js +0 -546
  257. data/app/assets/javascripts/angular.js +0 -20311
  258. data/app/assets/javascripts/bootstrap-wysihtml5.js +0 -511
  259. data/app/assets/javascripts/boxoffice.js +0 -558
  260. data/app/assets/javascripts/change-membership.js +0 -152
  261. data/app/assets/javascripts/custom/kits-config.js +0 -33
  262. data/app/assets/javascripts/households.js +0 -59
  263. data/app/assets/javascripts/jquery-migrate-1.2.1.min.js +0 -2
  264. data/app/assets/javascripts/relationships.js +0 -63
  265. data/app/assets/javascripts/sales-console.js +0 -158
  266. data/app/assets/javascripts/wysihtml5-0.3.0.min.js +0 -261
  267. data/app/assets/stylesheets/bootstrap-wysihtml5.css +0 -102
  268. data/app/assets/stylesheets/boxoffice.css.scss +0 -258
  269. data/app/assets/stylesheets/font-awesome.css.scss +0 -1566
  270. data/app/assets/stylesheets/pages/bootstrap-responsive.css +0 -1109
  271. data/app/assets/stylesheets/wysiwyg-color.css +0 -67
  272. data/app/concerns/cart_finder.rb +0 -50
  273. data/app/concerns/pdf_generation.rb +0 -64
  274. data/app/concerns/search_by_dates.rb +0 -20
  275. data/app/controllers/console_sales_controller.rb +0 -182
  276. data/app/controllers/events_pass_types_controller.rb +0 -87
  277. data/app/controllers/households_controller.rb +0 -71
  278. data/app/controllers/member_cards_controller.rb +0 -44
  279. data/app/controllers/members/invitations_controller.rb +0 -7
  280. data/app/controllers/members/passwords_controller.rb +0 -10
  281. data/app/controllers/members/people_controller.rb +0 -17
  282. data/app/controllers/members/sessions_controller.rb +0 -14
  283. data/app/controllers/membership_cancellations_controller.rb +0 -46
  284. data/app/controllers/membership_changes_controller.rb +0 -39
  285. data/app/controllers/membership_comps_controller.rb +0 -102
  286. data/app/controllers/membership_kits_controller.rb +0 -25
  287. data/app/controllers/mobile/dashboard_controller.rb +0 -17
  288. data/app/controllers/mobile/events_controller.rb +0 -16
  289. data/app/controllers/mobile/orders_controller.rb +0 -61
  290. data/app/controllers/mobile/shows_controller.rb +0 -39
  291. data/app/controllers/mobile/tickets_controller.rb +0 -114
  292. data/app/controllers/mobile/users_controller.rb +0 -30
  293. data/app/controllers/pass_types_controller.rb +0 -53
  294. data/app/controllers/passes_controller.rb +0 -52
  295. data/app/controllers/passes_kits_controller.rb +0 -25
  296. data/app/controllers/passes_reports_controller.rb +0 -25
  297. data/app/controllers/regular_donation_kits_controller.rb +0 -32
  298. data/app/controllers/relationships_controller.rb +0 -15
  299. data/app/controllers/store/retrievals_controller.rb +0 -29
  300. data/app/controllers/users/sessions_controller.rb +0 -3
  301. data/app/helpers/households_helper.rb +0 -7
  302. data/app/helpers/membership_types_helper.rb +0 -22
  303. data/app/helpers/relationships_helper.rb +0 -26
  304. data/app/helpers/sales_helper.rb +0 -29
  305. data/app/helpers/searches_helper.rb +0 -13
  306. data/app/helpers/suggested_households_helper.rb +0 -5
  307. data/app/mailers/pass_mailer.rb +0 -17
  308. data/app/models/actions/change_action.rb +0 -13
  309. data/app/models/actions/comp_action.rb +0 -15
  310. data/app/models/console_sale.rb +0 -30
  311. data/app/models/daily_membership_report.rb +0 -50
  312. data/app/models/daily_pass_report.rb +0 -48
  313. data/app/models/events_pass_type.rb +0 -18
  314. data/app/models/ext/preprocessor.rb +0 -7
  315. data/app/models/extendable.rb +0 -6
  316. data/app/models/household.rb +0 -61
  317. data/app/models/household_suggester.rb +0 -58
  318. data/app/models/imports/memberships_import.rb +0 -43
  319. data/app/models/job/checkout_processor.rb +0 -46
  320. data/app/models/job/cleanup_suggested_households_job.rb +0 -17
  321. data/app/models/job/destroy_show_job.rb +0 -10
  322. data/app/models/job/geocode_address_job.rb +0 -11
  323. data/app/models/job/order_mailer_job.rb +0 -8
  324. data/app/models/job/refund_order_processor.rb +0 -16
  325. data/app/models/kits/membership_kit.rb +0 -62
  326. data/app/models/kits/passes_kit.rb +0 -62
  327. data/app/models/kits/scannable_tickets_kit.rb +0 -23
  328. data/app/models/member_card_generator.rb +0 -63
  329. data/app/models/member_walkup.rb +0 -150
  330. data/app/models/membership_cancellation.rb +0 -80
  331. data/app/models/membership_change.rb +0 -187
  332. data/app/models/membership_comp.rb +0 -105
  333. data/app/models/membership_comp_job.rb +0 -32
  334. data/app/models/membership_sale_search.rb +0 -18
  335. data/app/models/pass.rb +0 -197
  336. data/app/models/pass_sale_search.rb +0 -18
  337. data/app/models/pass_summary.rb +0 -18
  338. data/app/models/pass_type.rb +0 -46
  339. data/app/models/passes_report.rb +0 -117
  340. data/app/models/payments/check_payment.rb +0 -33
  341. data/app/models/relation.rb +0 -27
  342. data/app/models/relation_builder.rb +0 -32
  343. data/app/models/relationship.rb +0 -55
  344. data/app/models/relationship_builder.rb +0 -12
  345. data/app/models/relationship_validator.rb +0 -46
  346. data/app/models/relationships_kit.rb +0 -31
  347. data/app/models/rolling_membership_type.rb +0 -11
  348. data/app/models/seasonal_membership_type.rb +0 -3
  349. data/app/models/suggested_household.rb +0 -24
  350. data/app/models/ticket/qr_code.rb +0 -21
  351. data/app/models/valuation/lifetime_memberships.rb +0 -24
  352. data/app/serializers/show_serializer.rb +0 -15
  353. data/app/views/console_sales/_aloha.html.haml +0 -26
  354. data/app/views/console_sales/_cart.html.haml +0 -60
  355. data/app/views/console_sales/_payment.html.haml +0 -111
  356. data/app/views/console_sales/_shows.html.haml +0 -24
  357. data/app/views/console_sales/new.html.haml +0 -143
  358. data/app/views/events_pass_types/_form.html.haml +0 -42
  359. data/app/views/events_pass_types/edit.html.haml +0 -22
  360. data/app/views/events_pass_types/index.html.haml +0 -47
  361. data/app/views/events_pass_types/new.html.haml +0 -22
  362. data/app/views/households/_action.html.haml +0 -24
  363. data/app/views/households/_edit_modal.html.haml +0 -143
  364. data/app/views/households/_form.html.haml +0 -26
  365. data/app/views/households/_header.html.haml +0 -25
  366. data/app/views/households/_individual_fields.html.haml +0 -8
  367. data/app/views/households/_list.html.haml +0 -10
  368. data/app/views/households/_note.html.haml +0 -33
  369. data/app/views/households/edit.html.haml +0 -1
  370. data/app/views/households/index.html.haml +0 -13
  371. data/app/views/households/new.html.haml +0 -14
  372. data/app/views/households/show.html.haml +0 -72
  373. data/app/views/households/suggested.html.haml +0 -38
  374. data/app/views/imports/_export_links.html.haml +0 -3
  375. data/app/views/kits/_list.html.haml +0 -9
  376. data/app/views/members/invitations/edit.html.haml +0 -17
  377. data/app/views/members/invitations/new.html.erb +0 -14
  378. data/app/views/members/mailer/_invitation_body.html.haml +0 -18
  379. data/app/views/members/mailer/invitation_instructions.html.haml +0 -6
  380. data/app/views/members/mailer/reset_password_instructions.html.erb +0 -8
  381. data/app/views/members/passwords/edit.html.haml +0 -18
  382. data/app/views/members/sessions/new.html.haml +0 -19
  383. data/app/views/membership_cancellations/_form.html.haml +0 -39
  384. data/app/views/membership_cancellations/_modal.html.haml +0 -2
  385. data/app/views/membership_cancellations/_processing.html.haml +0 -12
  386. data/app/views/membership_cancellations/create.js.erb +0 -3
  387. data/app/views/membership_cancellations/new.js.erb +0 -3
  388. data/app/views/membership_comps/confirm.html.haml +0 -86
  389. data/app/views/membership_comps/create.html.haml +0 -20
  390. data/app/views/membership_comps/new.html.haml +0 -95
  391. data/app/views/membership_kits/edit.html.haml +0 -52
  392. data/app/views/membership_mailer/cancellation_confirmation.html.haml +0 -9
  393. data/app/views/membership_mailer/cancellation_confirmation.text.haml +0 -6
  394. data/app/views/membership_mailer/refund_problem.html.haml +0 -18
  395. data/app/views/membership_mailer/refund_problem.text.haml +0 -14
  396. data/app/views/membership_types/_membership_type_fees.html.haml +0 -0
  397. data/app/views/membership_types/_rolling_membership_type_form.html.haml +0 -5
  398. data/app/views/membership_types/_seasonal_membership_type_form.html.haml +0 -8
  399. data/app/views/membership_types/type.html.haml +0 -19
  400. data/app/views/memberships/_membership_scripts.js.erb +0 -15
  401. data/app/views/order_mailer/confirmation_for_exchange.html.haml +0 -34
  402. data/app/views/order_mailer/confirmation_for_exchange.text.haml +0 -26
  403. data/app/views/order_mailer/confirmation_for_refund.html.haml +0 -36
  404. data/app/views/order_mailer/confirmation_for_refund.text.haml +0 -22
  405. data/app/views/orders/membership.html.haml +0 -100
  406. data/app/views/orders/passes.html.haml +0 -97
  407. data/app/views/pass_mailer/pass_info_for.html.haml +0 -21
  408. data/app/views/pass_types/_form.html.haml +0 -76
  409. data/app/views/pass_types/_pass_type_fees.html.haml +0 -0
  410. data/app/views/pass_types/edit.html.haml +0 -4
  411. data/app/views/pass_types/index.html.haml +0 -34
  412. data/app/views/pass_types/new.html.haml +0 -4
  413. data/app/views/passes/index.html.haml +0 -108
  414. data/app/views/passes_kits/edit.html.haml +0 -30
  415. data/app/views/passes_reports/index.html.haml +0 -80
  416. data/app/views/pdfs/member.html.haml +0 -66
  417. data/app/views/pdfs/member_card_generator/blanks_usa_idc6.html.haml +0 -109
  418. data/app/views/pdfs/order.html.haml +0 -84
  419. data/app/views/people/_household_fields.html.haml +0 -5
  420. data/app/views/people/_relationship_fields.html.haml +0 -14
  421. data/app/views/people/_work_with_menu.html.haml +0 -39
  422. data/app/views/producer_mailer/donation_kit_notification.html.haml +0 -8
  423. data/app/views/producer_mailer/donation_kit_notification.text.erb +0 -8
  424. data/app/views/producer_mailer/mailchimp_kit_initial_sync_notification.html.haml +0 -21
  425. data/app/views/producer_mailer/ticket_offer_accepted.html.haml +0 -7
  426. data/app/views/producer_mailer/ticket_offer_accepted.text.erb +0 -7
  427. data/app/views/producer_mailer/ticket_offer_rejected.html.haml +0 -11
  428. data/app/views/producer_mailer/ticket_offer_rejected.text.erb +0 -13
  429. data/app/views/regular_donation_kits/edit.html.haml +0 -140
  430. data/app/views/relationships/index.html.haml +0 -32
  431. data/app/views/sales/_boxoffice.html.haml +0 -141
  432. data/app/views/sales/_doorlist.html.haml +0 -79
  433. data/app/views/searches/_household.html.haml +0 -7
  434. data/app/views/shared/_show_time_and_calendar.html.haml +0 -21
  435. data/app/views/shows/door_list.pdf.haml +0 -29
  436. data/app/views/statements/_passes_table.html.haml +0 -22
  437. data/app/views/store/checkouts/_membership_info.html.haml +0 -12
  438. data/app/views/store/events/_venue.html.haml +0 -9
  439. data/app/views/store/events/calendar.html.haml +0 -50
  440. data/app/views/store/events/single_show.html.haml +0 -45
  441. data/app/views/store/passes/index.html.haml +0 -33
  442. data/app/views/store/retrievals/index.html.haml +0 -11
  443. data/app/views/store/shared/_small_donate_form.html.haml +0 -21
  444. data/app/views/users/mailer/invitation_instructions.html.haml +0 -14
  445. data/config/initializers/paperclip.rb +0 -69
  446. data/db/migrate/20130411162346_add_country_zip_state_phone_number_discipline_to_organizations.rb +0 -9
  447. data/db/migrate/20130412184415_add_first_name_and_last_name_to_users.rb +0 -6
  448. data/db/migrate/20130722153731_add_autentication_token_to_users.rb +0 -5
  449. data/db/migrate/20130723212712_add_qr_code_to_tickets.rb +0 -9
  450. data/db/migrate/20130820011240_add_uuid_to_tickets.rb +0 -13
  451. data/db/migrate/20130820025134_make_ticket_uuid_not_null.rb +0 -11
  452. data/db/migrate/20130823191625_add_pdf_to_orders.rb +0 -5
  453. data/db/migrate/20130916194547_add_relationships.rb +0 -21
  454. data/db/migrate/20131002191646_create_show_stats_view.rb +0 -16
  455. data/db/migrate/20131003134821_add_relationships_to_search.rb +0 -7
  456. data/db/migrate/20131003200508_add_starred_to_relationships.rb +0 -5
  457. data/db/migrate/20131007141421_add_counters_to_member.rb +0 -7
  458. data/db/migrate/20131007144456_remove_expires_at_from_membership.rb +0 -6
  459. data/db/migrate/20131011154027_add_purchased_to_searches.rb +0 -5
  460. data/db/migrate/20131013144010_add_type_to_membership_type.rb +0 -5
  461. data/db/migrate/20131013150230_add_duration_to_membership_type.rb +0 -6
  462. data/db/migrate/20131013192807_change_number_of_shows_to_tickets.rb +0 -5
  463. data/db/migrate/20131015151550_add_households.rb +0 -18
  464. data/db/migrate/20131022183913_add_search_output_options.rb +0 -24
  465. data/db/migrate/20131023200559_add_admin_to_user_memberships.rb +0 -14
  466. data/db/migrate/20131025162155_default_search_filter_values.rb +0 -10
  467. data/db/migrate/20131025180139_unique_household_names.rb +0 -8
  468. data/db/migrate/20131029173612_add_sales_start_to_membership_typ.rb +0 -6
  469. data/db/migrate/20131106191847_add_suggested_households.rb +0 -13
  470. data/db/migrate/20131127162818_add_buyer_id_index_to_tickets.rb +0 -5
  471. data/db/migrate/20131127164000_member_tickets.rb +0 -9
  472. data/db/migrate/20131204162642_add_shared_address.rb +0 -9
  473. data/db/migrate/20131206153323_add_membership_kit.rb +0 -5
  474. data/db/migrate/20131206175325_add_marketing_to_membership_type.rb +0 -6
  475. data/db/migrate/20131210212342_add_show_fee_to_memberhsip_type.rb +0 -5
  476. data/db/migrate/20131210222814_add_renewal_price_to_membership_type.rb +0 -6
  477. data/db/migrate/20131212164553_add_copy_to_individuals_option.rb +0 -5
  478. data/db/migrate/20131223215615_goodbye_order_view.rb +0 -6
  479. data/db/migrate/20140114011856_add_welcome_message_to_memberships.rb +0 -5
  480. data/db/migrate/20140114212127_add_send_email_to_memberships.rb +0 -5
  481. data/db/migrate/20140125183606_index_memberships_and_types.rb +0 -6
  482. data/db/migrate/20140128213101_add_pdf_to_members.rb +0 -5
  483. data/db/migrate/20140128223140_add_uuid_to_member.rb +0 -6
  484. data/db/migrate/20140128223948_add_qr_code_to_member.rb +0 -9
  485. data/db/migrate/20140207135731_update_items_view.rb +0 -38
  486. data/db/migrate/20140210154723_add_cached_stats.rb +0 -5
  487. data/db/migrate/20140218202726_cache_stats.rb +0 -7
  488. data/db/migrate/20140304171625_passes_ahoy.rb +0 -52
  489. data/db/migrate/20140304174807_add_passes_kit.rb +0 -5
  490. data/db/migrate/20140307144454_add_events_pass_types.rb +0 -9
  491. data/db/migrate/20140307193350_add_pass_id_to_cart.rb +0 -7
  492. data/db/migrate/20140314162422_add_total_paid_to_membership.rb +0 -13
  493. data/db/migrate/20140319191237_add_show_dates_to_advanced_search.rb +0 -6
  494. data/db/migrate/20140328172333_add_cols_to_events_pass_types.rb +0 -6
  495. data/db/migrate/20140328174217_add_deleted_at_to_ept.rb +0 -9
  496. data/db/migrate/20140328185432_add_active_to_ept.rb +0 -5
  497. data/db/migrate/20140328192612_add_pass_type_id_to_search.rb +0 -5
  498. data/db/migrate/20140415212841_add_min_max_start_dates_to_searches.artfully_ose_engine.rb +0 -6
  499. data/db/migrate/20140422193345_add_email_copy_to_pass_type.rb +0 -5
  500. data/db/migrate/20140423181639_add_min_max_end_dates_to_searches.artfully_ose_engine.rb +0 -6
  501. data/db/migrate/20140423185921_add_cached_stats_to_event.rb +0 -9
  502. data/db/migrate/20140424174423_add_lifetime_memberships_to_people.artfully_ose_engine.rb +0 -5
  503. data/db/migrate/20140506155241_add_lpt_to_membership_type.rb +0 -5
  504. data/db/migrate/20140507184646_add_bday_attributes_to_person.rb +0 -7
  505. data/db/migrate/20140507201048_add_check_number_to_orders.rb +0 -5
  506. data/db/migrate/20140515143651_remove_show_stats_view.rb +0 -6
  507. data/db/migrate/20140521195853_add_deleted_at_to_pass_type.rb +0 -5
  508. data/db/migrate/20140522205554_add_limit_to_events_pass_types.rb +0 -5
  509. data/db/migrate/20140523180444_remove_tickets_purchased_from_passes.rb +0 -5
  510. data/db/migrate/20140603200735_add_subtitle_to_events.rb +0 -5
  511. data/db/migrate/20140619194127_add_do_not_call_to_people.artfully_ose_engine.rb +0 -5
  512. data/db/migrate/20140623160543_add_index_to_items.rb +0 -7
  513. data/spec/factories/action_factories.rb +0 -19
  514. data/spec/factories/address_factories.rb +0 -11
  515. data/spec/factories/cart_factories.rb +0 -26
  516. data/spec/factories/chart_factories.rb +0 -52
  517. data/spec/factories/discount_factories.rb +0 -11
  518. data/spec/factories/donation_factories.rb +0 -14
  519. data/spec/factories/event_factories.rb +0 -29
  520. data/spec/factories/household_factories.rb +0 -8
  521. data/spec/factories/import_factories.rb +0 -61
  522. data/spec/factories/item_factories.rb +0 -51
  523. data/spec/factories/kit_factories.rb +0 -33
  524. data/spec/factories/member_factories.rb +0 -19
  525. data/spec/factories/membership_factories.rb +0 -9
  526. data/spec/factories/membership_type_factories.rb +0 -18
  527. data/spec/factories/order_factories.rb +0 -40
  528. data/spec/factories/organization_factories.rb +0 -48
  529. data/spec/factories/pass_type_factories.rb +0 -11
  530. data/spec/factories/payments_factories.rb +0 -97
  531. data/spec/factories/person_factories.rb +0 -47
  532. data/spec/factories/phone_factories.rb +0 -6
  533. data/spec/factories/section_factories.rb +0 -21
  534. data/spec/factories/segment_factories.rb +0 -6
  535. data/spec/factories/show_factories.rb +0 -33
  536. data/spec/factories/ticket_factories.rb +0 -57
  537. data/spec/factories/ticket_offer_factories.rb +0 -16
  538. data/spec/factories/ticket_type_factories.rb +0 -8
  539. data/spec/factories/user_factories.rb +0 -24
@@ -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
@@ -1,8 +1,8 @@
1
1
  class Refund
2
- attr_accessor :order, :refund_order, :items, :message, :send_email_confirmation
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 = "Unfortunately we cannot refund credit card transactions until the day after they were processed. Please re-issue the refund tomorrow."
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
@@ -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, :notes, :order
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 = {}, notes=nil)
9
+ def initialize(show, ticket_types, cart, quantities = {})
10
10
  @show = show
11
11
  @ticket_types = ticket_types
12
- @notes = notes
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, [], payment.customer, payment.benefactor, notes)
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, notes)
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
@@ -1,7 +1,7 @@
1
1
  class SaleSearch
2
- include SearchByDates
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
@@ -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
- :has_purchased_for, :event_id,
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, :pass_type_id, :pass_type, :membership_type_id, :membership_type,
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
- ANY_EVENT = -1
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
- c = ->(s){ "<li>#{s}</li>" }
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 << c.call("Are located within #{locations.to_sentence}.")
43
+ conditions << "Are located within #{locations.to_sentence}."
69
44
  end
70
45
  if min_lifetime_value.present? && max_lifetime_value.present?
71
- conditions << c.call("Have a lifetime value between $#{min_lifetime_value} and $#{max_lifetime_value}.")
46
+ conditions << "Have a lifetime value between $#{min_lifetime_value} and $#{max_lifetime_value}."
72
47
  elsif min_lifetime_value.present?
73
- conditions << c.call("Have a minimum lifetime value of $#{min_lifetime_value}.")
48
+ conditions << "Have a minimum lifetime value of $#{min_lifetime_value}."
74
49
  elsif max_lifetime_value.present?
75
- conditions << c.call("Have a maximum lifetime value of $#{max_lifetime_value}.")
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) ? c.call("Used any discount code") : ("Used discount code #{discount_code}."))
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 << c.call(string)
77
+ conditions << string
103
78
  end
104
79
 
105
- categories = []
106
-
107
- if output_companies
108
- if person_subtype.present?
109
- categories << person_subtype.downcase.pluralize
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
- categories << "companies" if output_companies
112
- end
113
- end
114
-
115
- if searching_membership?
116
- if membership_status.present?
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
- conditions << c.call("Are #{membership_type.name} members")
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
- def find_people
191
- column_names = Person.column_names.collect {|cn| "people.#{cn}" }
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
- elsif !has_purchased_for
314
- if show_date_search?
315
- people_subquery = Ticket.joins(:show)
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
- people_subquery = people_subquery.where("shows.datetime >= ?", offset_show_date_start) unless show_date_start.blank?
320
- people_subquery = people_subquery.where("shows.datetime <= ?", offset_show_date_end) unless show_date_end.blank?
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
- people = people.where("NOT EXISTS (#{people_subquery.to_sql})")
323
- else
324
- #
325
- # Had to use a correlated subquery here. Sorry.
326
- # ActiveRecord 3.2 does not support NOT IN, so we have to do some manual work here.
327
- # AR 4.0 has NOT IN
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
- people
338
- end
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
- def add_any_event_query(people, column_names)
344
- people = people.joins("LEFT JOIN `tickets` ON `tickets`.`buyer_id` = `people`.`id` ")
345
-
346
- if has_purchased_for
347
- column_names << "count(tickets.id) as ticket_count"
348
- if show_date_search?
349
- people = people.joins("LEFT JOIN `shows` ON `shows`.`id` = `tickets`.`show_id` ")
350
- people = people.where("shows.datetime >= ?", offset_show_date_start) unless show_date_start.blank?
351
- people = people.where("shows.datetime <= ?", offset_show_date_end) unless show_date_end.blank?
352
- end
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
- def searching_for_event?
373
- event_id.present?
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
- def show_date_search?
377
- show_date_start.present? || show_date_end.present?
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