effective_memberships 0.9.15 → 0.9.16

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: e299db8cf3241529169d0f61a9524263dce1b1752fb04cbec395951ae7d1d029
4
- data.tar.gz: e04637274efa4c3bffae73bbd27b62588ec3f6c74379050f51c58609f513bbc0
3
+ metadata.gz: 90078c67d46aca1f293b49ffacac17288bb24592a4007079e6843847845a4e48
4
+ data.tar.gz: 0063d4f68e0c2ff073c06eb62812006d13f050b50eecbc10163aa80f0a862a04
5
5
  SHA512:
6
- metadata.gz: 9d01059e8b8e98c6c5ed0838a15a4b126a6d031cbaea7f76adb19146985f687514f5d518ca05bebbf6b9b3735739efd26c63a5d3a970097572d836cadb478c01
7
- data.tar.gz: 00da75ee33edb063d76280cfb6bd1c771903ff24bdab9db0bf5c0ca06cc76e0998bd72313705ae0bf2ef90acf0c37dc4703b9fc5b3d15b34808f13606ccf38bc
6
+ metadata.gz: 01b87e4c9a1aa5664e5bb0fb14ca95a3fac57ea8f2ca0542e379e7e11a1d0450c7aef6fcd4b8d29ab3312e6db33e4a3729b60301b54870e0d7abe20f144df93b
7
+ data.tar.gz: e71ea11d0e5d126f4e37474726a234440f6e2105131a57fd1a6427c9c2ab897884f3502df0f2150a89318748b494d156a1e11d3fd81334aab8d9c19d9c2ef533
@@ -42,6 +42,9 @@ module Admin
42
42
 
43
43
  col :checkout_type, search: Effective::Fee::CHECKOUT_TYPES, visible: false
44
44
 
45
+ col :late_on, visible: false
46
+ col :not_in_good_standing_on, visible: false
47
+
45
48
  unless attributes[:total] == false
46
49
  aggregate :total
47
50
  end
@@ -333,6 +333,25 @@ module EffectiveMembershipsOwner
333
333
  save!
334
334
  end
335
335
 
336
+ # Delete the last membership history
337
+ def rollback_membership_history!
338
+ raise('expected membership to be present') unless membership.present?
339
+
340
+ (history, last) = membership_histories.last(2)
341
+ raise('expected 2 or more membership histories') unless history.present? && last.present?
342
+
343
+ last.mark_for_destruction
344
+ history.assign_attributes(end_on: nil)
345
+
346
+ membership.assign_attributes(
347
+ number: history.number,
348
+ categories: history.membership_categories,
349
+ statuses: history.membership_statuses
350
+ )
351
+
352
+ save!
353
+ end
354
+
336
355
  def build_membership_history(start_on: nil, notes: nil)
337
356
  raise('expected membership to be present') unless membership.present?
338
357
 
@@ -76,27 +76,8 @@ module EffectiveMembershipsRegistrar
76
76
  membership.number ||= number
77
77
  membership.number_as_integer ||= (Integer(number) rescue nil)
78
78
 
79
- # Delete any removed statuses
80
- membership.membership_statuses.each do |membership_status|
81
- next if statuses.include?(membership_status.status)
82
- membership_status.mark_for_destruction
83
- end
84
-
85
- # Build any additional statuses
86
- statuses.each do |status|
87
- membership.build_membership_status(status: status)
88
- end
89
-
90
- # Delete any removed categories
91
- membership.membership_categories.each do |membership_category|
92
- next if categories.include?(membership_category.category)
93
- membership_category.mark_for_destruction
94
- end
95
-
96
- # Build any additional categories
97
- categories.each do |category|
98
- membership.build_membership_category(category: category)
99
- end
79
+ # Builds the membership_categories and membership_statuses. Marks for destruction ones that don't exist.
80
+ membership.assign_attributes(statuses: statuses, categories: categories)
100
81
 
101
82
  changed = membership.membership_categories.any? { |mc| mc.new_record? || mc.marked_for_destruction? }
102
83
  changed ||= membership.membership_statuses.any? { |ms| ms.new_record? || ms.marked_for_destruction? }
@@ -156,6 +156,21 @@ module Effective
156
156
  membership_categories.reject(&:marked_for_destruction?).map(&:category_id)
157
157
  end
158
158
 
159
+ def categories=(categories)
160
+ categories = Array(categories)
161
+ raise('expecting a membership category') if categories.any? { |cat| !cat.class.respond_to?(:effective_memberships_category?) }
162
+
163
+ # Delete any removed categories
164
+ membership_categories.each do |membership_category|
165
+ membership_category.mark_for_destruction unless categories.include?(membership_category.category)
166
+ end
167
+
168
+ # Build any additional categories
169
+ categories.each { |category| build_membership_category(category: category) }
170
+
171
+ nil
172
+ end
173
+
159
174
  # We might want to use singular memberships.
160
175
  def category
161
176
  raise('expected singular usage but there are more than one membership category') if categories.length > 1
@@ -192,6 +207,21 @@ module Effective
192
207
  membership_statuses.reject(&:marked_for_destruction?).map(&:status_id)
193
208
  end
194
209
 
210
+ def statuses=(statuses)
211
+ statuses = Array(statuses)
212
+ raise('expecting a membership category') if statuses.any? { |status| !status.class.respond_to?(:effective_memberships_status?) }
213
+
214
+ # Delete any removed statuses
215
+ membership_statuses.each do |membership_status|
216
+ membership_status.mark_for_destruction unless statuses.include?(membership_status.status)
217
+ end
218
+
219
+ # Build any additional statuses
220
+ statuses.each { |status| build_membership_status(status: status) }
221
+
222
+ nil
223
+ end
224
+
195
225
  def statuses_sentence
196
226
  statuses.map(&:to_s).to_sentence.presence || 'None'
197
227
  end
@@ -1,3 +1,3 @@
1
1
  module EffectiveMemberships
2
- VERSION = '0.9.15'
2
+ VERSION = '0.9.16'
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: effective_memberships
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.9.15
4
+ version: 0.9.16
5
5
  platform: ruby
6
6
  authors:
7
7
  - Code and Effect
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2023-01-13 00:00:00.000000000 Z
11
+ date: 2023-01-20 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rails