mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-10-04 10:54:30 +08:00
Add uniqueness to sample_type & sample_group name
Closes SCI-720.
This commit is contained in:
parent
5b917768a7
commit
7658ae264a
3 changed files with 50 additions and 2 deletions
|
@ -2,7 +2,8 @@ class SampleGroup < ActiveRecord::Base
|
||||||
auto_strip_attributes :name, :color, nullify: false
|
auto_strip_attributes :name, :color, nullify: false
|
||||||
validates :name,
|
validates :name,
|
||||||
presence: true,
|
presence: true,
|
||||||
length: { maximum: Constants::NAME_MAX_LENGTH }
|
length: { maximum: Constants::NAME_MAX_LENGTH },
|
||||||
|
uniqueness: { scope: :organization, case_sensitive: false }
|
||||||
validates :color,
|
validates :color,
|
||||||
presence: true,
|
presence: true,
|
||||||
length: { maximum: Constants::COLOR_MAX_LENGTH }
|
length: { maximum: Constants::COLOR_MAX_LENGTH }
|
||||||
|
|
|
@ -2,7 +2,8 @@ class SampleType < ActiveRecord::Base
|
||||||
auto_strip_attributes :name, nullify: false
|
auto_strip_attributes :name, nullify: false
|
||||||
validates :name,
|
validates :name,
|
||||||
presence: true,
|
presence: true,
|
||||||
length: { maximum: Constants::NAME_MAX_LENGTH }
|
length: { maximum: Constants::NAME_MAX_LENGTH },
|
||||||
|
uniqueness: { scope: :organization, case_sensitive: false }
|
||||||
validates :organization, presence: true
|
validates :organization, presence: true
|
||||||
|
|
||||||
belongs_to :created_by, foreign_key: 'created_by_id', class_name: 'User'
|
belongs_to :created_by, foreign_key: 'created_by_id', class_name: 'User'
|
||||||
|
|
|
@ -0,0 +1,46 @@
|
||||||
|
class RenameNonUniqueSampleTypesGroups < ActiveRecord::Migration
|
||||||
|
def up
|
||||||
|
Organization.find_each do |org|
|
||||||
|
st_ids = []
|
||||||
|
org.sample_types.find_each do |st|
|
||||||
|
if SampleType.where(organization_id: org.id)
|
||||||
|
.where(name: st.name).count > 1
|
||||||
|
st_ids << st.id
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
next if st_ids.count == 0
|
||||||
|
|
||||||
|
cntr = -1
|
||||||
|
SampleType.where(id: st_ids).find_each do |st|
|
||||||
|
cntr += 1
|
||||||
|
next if cntr == 0
|
||||||
|
new_name = "#{st.name} (#{cntr})"
|
||||||
|
st.update(name: new_name)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
Organization.find_each do |org|
|
||||||
|
sg_ids = []
|
||||||
|
org.sample_groups.find_each do |sg|
|
||||||
|
if SampleGroup.where(organization_id: org.id)
|
||||||
|
.where(name: sg.name).count > 1
|
||||||
|
sg_ids << sg.id
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
next if sg_ids.count == 0
|
||||||
|
|
||||||
|
cntr = -1
|
||||||
|
SampleGroup.where(id: sg_ids).find_each do |sg|
|
||||||
|
cntr += 1
|
||||||
|
next if cntr == 0
|
||||||
|
new_name = "#{sg.name} (#{cntr})"
|
||||||
|
sg.update(name: new_name)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def down
|
||||||
|
end
|
||||||
|
end
|
Loading…
Add table
Reference in a new issue