effective_committees 0.7.5 → 0.9.0
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 +4 -4
- data/app/controllers/effective/committees_controller.rb +2 -2
- data/app/datatables/admin/effective_committee_members_datatable.rb +2 -0
- data/app/datatables/admin/effective_committees_datatable.rb +3 -2
- data/app/models/effective/committee.rb +8 -1
- data/app/models/effective/committee_member.rb +12 -3
- data/app/views/effective/committees/_committee.html.haml +1 -1
- data/app/views/effective/committees/volunteers_and_committees.html.haml +1 -0
- data/db/migrate/101_create_effective_committees.rb +3 -0
- data/lib/effective_committees/version.rb +1 -1
- metadata +46 -4
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: '028cb7fc1b4194a805ffc494fc6d2c7e8429b87f3a6ea559481e467c33dc0ac6'
|
|
4
|
+
data.tar.gz: 07f3eca18fb18cd17e2cdea403b84d21fbcf1a2196a6d22d233cec4c48308224
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: caac2747b32561bc4dfb1e2c93e5a46b5be7c932d064ab30d4588de8a2d9530d0c2ef49cd3cac6ba78bdee9f67cecb15fa440016d9e8e914165fde0f7af93843
|
|
7
|
+
data.tar.gz: 74df738c96c21cbd8617e4b04ff5f1c9d3b29e90f799b035f1c07c5ea5b4b7fab6d21c515973f2fc15c0f796755d71f293c7950edbd7d5eee5bc9ed876fb17e0
|
|
@@ -9,7 +9,7 @@ module Effective
|
|
|
9
9
|
page_title "More Activity", only: [:activity]
|
|
10
10
|
|
|
11
11
|
def index
|
|
12
|
-
@committees = resource_scope.for_dashboard
|
|
12
|
+
@committees = resource_scope.for_dashboard.sorted
|
|
13
13
|
@page_title = "My #{EffectiveResources.et('effective_committees.name')}"
|
|
14
14
|
|
|
15
15
|
EffectiveResources.authorize!(self, :index, Effective::Committee)
|
|
@@ -18,7 +18,7 @@ module Effective
|
|
|
18
18
|
end
|
|
19
19
|
|
|
20
20
|
def volunteers_and_committees
|
|
21
|
-
@committees = resource_scope.for_index
|
|
21
|
+
@committees = resource_scope.for_index.sorted
|
|
22
22
|
@page_title = "Volunteers and Committees"
|
|
23
23
|
|
|
24
24
|
EffectiveResources.authorize!(self, :index, Effective::Committee)
|
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
module Admin
|
|
2
2
|
class EffectiveCommitteeMembersDatatable < Effective::Datatable
|
|
3
3
|
datatable do
|
|
4
|
+
reorder :position if attributes[:committee]
|
|
4
5
|
length 100
|
|
5
6
|
|
|
6
7
|
col :id, visible: false
|
|
7
8
|
col :user_id, visible: false
|
|
9
|
+
col :position, visible: false
|
|
8
10
|
|
|
9
11
|
col :committee
|
|
10
12
|
col :user
|
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
module Admin
|
|
2
2
|
class EffectiveCommitteesDatatable < Effective::Datatable
|
|
3
3
|
datatable do
|
|
4
|
+
reorder :position
|
|
4
5
|
length 100
|
|
5
|
-
order :title
|
|
6
6
|
|
|
7
7
|
col :updated_at, visible: false
|
|
8
8
|
col :created_at, visible: false
|
|
9
9
|
|
|
10
10
|
col :id, visible: false
|
|
11
|
+
col :position, visible: false
|
|
11
12
|
|
|
12
13
|
col :title, label: committee_label
|
|
13
14
|
col :slug, visible: false
|
|
@@ -17,7 +18,7 @@ module Admin
|
|
|
17
18
|
col :display_on_dashboard
|
|
18
19
|
|
|
19
20
|
col(:committee_members, label: committee_members_label, visible: false) do |committee|
|
|
20
|
-
committee.committee_members.select(&:active?).
|
|
21
|
+
committee.committee_members.select(&:active?).map do |member|
|
|
21
22
|
content_tag(:div, class: 'col-resource_item') do
|
|
22
23
|
label = link_to(member.to_s, "/admin/users/#{member.user_id}/edit")
|
|
23
24
|
badge = badge(member.category) if member.category.present?
|
|
@@ -22,6 +22,8 @@ module Effective
|
|
|
22
22
|
title :string
|
|
23
23
|
slug :string
|
|
24
24
|
|
|
25
|
+
position :integer
|
|
26
|
+
|
|
25
27
|
committee_members_count :integer # Counter Cache
|
|
26
28
|
committee_folders_count :integer # Counter Cache
|
|
27
29
|
committee_files_count :integer # Counter Cache
|
|
@@ -29,13 +31,18 @@ module Effective
|
|
|
29
31
|
timestamps
|
|
30
32
|
end
|
|
31
33
|
|
|
32
|
-
scope :sorted, -> { order(:
|
|
34
|
+
scope :sorted, -> { order(:position) }
|
|
33
35
|
scope :deep, -> { with_rich_text_body.includes(committee_members: [:user], committee_folders: [:committee_files, :rich_text_body]) }
|
|
34
36
|
|
|
35
37
|
scope :for_dashboard, -> { where(display_on_dashboard: true) }
|
|
36
38
|
scope :for_index, -> { where(display_on_index: true) }
|
|
37
39
|
|
|
40
|
+
before_validation do
|
|
41
|
+
self.position ||= (self.class.maximum(:position) || -1) + 1
|
|
42
|
+
end
|
|
43
|
+
|
|
38
44
|
validates :title, presence: true, uniqueness: true, length: { maximum: 255 }
|
|
45
|
+
validates :position, presence: true
|
|
39
46
|
|
|
40
47
|
def to_s
|
|
41
48
|
title.presence || 'New Committee'
|
|
@@ -23,10 +23,12 @@ module Effective
|
|
|
23
23
|
start_on :date
|
|
24
24
|
end_on :date
|
|
25
25
|
|
|
26
|
+
position :integer
|
|
27
|
+
|
|
26
28
|
timestamps
|
|
27
29
|
end
|
|
28
30
|
|
|
29
|
-
scope :sorted, -> { order(:
|
|
31
|
+
scope :sorted, -> { order(:position) }
|
|
30
32
|
scope :deep, -> { includes(:user, :committee) }
|
|
31
33
|
|
|
32
34
|
before_validation(if: -> { user_ids.present? }) do
|
|
@@ -39,18 +41,25 @@ module Effective
|
|
|
39
41
|
|
|
40
42
|
after_commit(if: -> { user_ids.present? }) do
|
|
41
43
|
additional = (user_ids - CommitteeMember.where(committee_id: committee_id, user_id: user_ids).pluck(:user_id))
|
|
42
|
-
|
|
44
|
+
max_position = CommitteeMember.where(committee_id: committee_id, committee_type: committee_type).maximum(:position) || -1
|
|
45
|
+
additional = additional.each_with_index.map { |user_id, index| {committee_id: committee_id, committee_type: committee_type, user_id: user_id, user_type: user_type, roles_mask: roles_mask, start_on: start_on, end_on: end_on, position: max_position + index + 1} }
|
|
43
46
|
CommitteeMember.insert_all(additional)
|
|
44
47
|
end
|
|
45
48
|
|
|
46
49
|
after_commit(if: -> { committee_ids.present? }) do
|
|
47
50
|
additional = (committee_ids - CommitteeMember.where(user_id: user_id, committee_id: committee_ids).pluck(:committee_id))
|
|
48
|
-
|
|
51
|
+
max_positions = CommitteeMember.where(committee_id: additional, committee_type: committee_type).group(:committee_id).maximum(:position)
|
|
52
|
+
additional = additional.map { |committee_id| {committee_id: committee_id, committee_type: committee_type, user_id: user_id, user_type: user_type, roles_mask: roles_mask, start_on: start_on, end_on: end_on, position: (max_positions[committee_id] || -1) + 1} }
|
|
49
53
|
CommitteeMember.insert_all(additional)
|
|
50
54
|
end
|
|
51
55
|
|
|
56
|
+
before_validation do
|
|
57
|
+
self.position ||= (self.class.where(committee_id: committee_id, committee_type: committee_type).maximum(:position) || -1) + 1
|
|
58
|
+
end
|
|
59
|
+
|
|
52
60
|
validates :committee, presence: true
|
|
53
61
|
validates :user, presence: true
|
|
62
|
+
validates :position, presence: true
|
|
54
63
|
|
|
55
64
|
validates :user_id, if: -> { user_id && user_type && committee_id && committee_type },
|
|
56
65
|
uniqueness: { scope: [:committee_id, :committee_type], message: 'already belongs to this committee' }
|
|
@@ -4,6 +4,7 @@ class CreateEffectiveCommittees < ActiveRecord::Migration[6.0]
|
|
|
4
4
|
create_table :committees do |t|
|
|
5
5
|
t.string :title
|
|
6
6
|
t.string :slug
|
|
7
|
+
t.integer :position, default: 0
|
|
7
8
|
|
|
8
9
|
t.integer :committee_members_count, default: 0
|
|
9
10
|
t.integer :committee_folders_count, default: 0
|
|
@@ -33,6 +34,8 @@ class CreateEffectiveCommittees < ActiveRecord::Migration[6.0]
|
|
|
33
34
|
t.date :start_on
|
|
34
35
|
t.date :end_on
|
|
35
36
|
|
|
37
|
+
t.integer :position
|
|
38
|
+
|
|
36
39
|
t.datetime :updated_at
|
|
37
40
|
t.datetime :created_at
|
|
38
41
|
end
|
metadata
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
|
2
2
|
name: effective_committees
|
|
3
3
|
version: !ruby/object:Gem::Version
|
|
4
|
-
version: 0.
|
|
4
|
+
version: 0.9.0
|
|
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: 2026-
|
|
11
|
+
date: 2026-03-13 00:00:00.000000000 Z
|
|
12
12
|
dependencies:
|
|
13
13
|
- !ruby/object:Gem::Dependency
|
|
14
14
|
name: rails
|
|
@@ -109,7 +109,7 @@ dependencies:
|
|
|
109
109
|
- !ruby/object:Gem::Version
|
|
110
110
|
version: '0'
|
|
111
111
|
- !ruby/object:Gem::Dependency
|
|
112
|
-
name: haml
|
|
112
|
+
name: haml-rails
|
|
113
113
|
requirement: !ruby/object:Gem::Requirement
|
|
114
114
|
requirements:
|
|
115
115
|
- - ">="
|
|
@@ -136,6 +136,48 @@ dependencies:
|
|
|
136
136
|
- - ">="
|
|
137
137
|
- !ruby/object:Gem::Version
|
|
138
138
|
version: '0'
|
|
139
|
+
- !ruby/object:Gem::Dependency
|
|
140
|
+
name: psych
|
|
141
|
+
requirement: !ruby/object:Gem::Requirement
|
|
142
|
+
requirements:
|
|
143
|
+
- - ">="
|
|
144
|
+
- !ruby/object:Gem::Version
|
|
145
|
+
version: '0'
|
|
146
|
+
type: :development
|
|
147
|
+
prerelease: false
|
|
148
|
+
version_requirements: !ruby/object:Gem::Requirement
|
|
149
|
+
requirements:
|
|
150
|
+
- - ">="
|
|
151
|
+
- !ruby/object:Gem::Version
|
|
152
|
+
version: '0'
|
|
153
|
+
- !ruby/object:Gem::Dependency
|
|
154
|
+
name: wicked
|
|
155
|
+
requirement: !ruby/object:Gem::Requirement
|
|
156
|
+
requirements:
|
|
157
|
+
- - ">="
|
|
158
|
+
- !ruby/object:Gem::Version
|
|
159
|
+
version: '0'
|
|
160
|
+
type: :development
|
|
161
|
+
prerelease: false
|
|
162
|
+
version_requirements: !ruby/object:Gem::Requirement
|
|
163
|
+
requirements:
|
|
164
|
+
- - ">="
|
|
165
|
+
- !ruby/object:Gem::Version
|
|
166
|
+
version: '0'
|
|
167
|
+
- !ruby/object:Gem::Dependency
|
|
168
|
+
name: effective_logging
|
|
169
|
+
requirement: !ruby/object:Gem::Requirement
|
|
170
|
+
requirements:
|
|
171
|
+
- - ">="
|
|
172
|
+
- !ruby/object:Gem::Version
|
|
173
|
+
version: '0'
|
|
174
|
+
type: :development
|
|
175
|
+
prerelease: false
|
|
176
|
+
version_requirements: !ruby/object:Gem::Requirement
|
|
177
|
+
requirements:
|
|
178
|
+
- - ">="
|
|
179
|
+
- !ruby/object:Gem::Version
|
|
180
|
+
version: '0'
|
|
139
181
|
- !ruby/object:Gem::Dependency
|
|
140
182
|
name: effective_test_bot
|
|
141
183
|
requirement: !ruby/object:Gem::Requirement
|
|
@@ -257,7 +299,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
|
257
299
|
- !ruby/object:Gem::Version
|
|
258
300
|
version: '0'
|
|
259
301
|
requirements: []
|
|
260
|
-
rubygems_version: 3.
|
|
302
|
+
rubygems_version: 3.5.9
|
|
261
303
|
signing_key:
|
|
262
304
|
specification_version: 4
|
|
263
305
|
summary: Committees are groups of users that can all share files.
|