mirror of
				https://github.com/scinote-eln/scinote-web.git
				synced 2025-10-26 14:06:23 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			35 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			35 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| class CreateSamplesTables < ActiveRecord::Migration[4.2]
 | |
|   def change
 | |
|     create_table :samples_tables do |t|
 | |
|       t.jsonb :status, null: false,
 | |
|               default: SampleDatatable::SAMPLES_TABLE_DEFAULT_STATE
 | |
|       # Foreign keys
 | |
|       t.references :user, null: false
 | |
|       t.references :team, null: false
 | |
| 
 | |
|       t.timestamps null: false
 | |
|     end
 | |
|     add_index :samples_tables, :user_id
 | |
|     add_index :samples_tables, :team_id
 | |
| 
 | |
|     User.find_each do |user|
 | |
|       next unless user.teams
 | |
|       user.teams.find_each do |team|
 | |
|         team_status = SampleDatatable::SAMPLES_TABLE_DEFAULT_STATE.deep_dup
 | |
|         next unless team.custom_fields
 | |
|         team.custom_fields.each_with_index do |_, index|
 | |
|           team_status['columns'] << { 'visible' => true,
 | |
|                                       'search' => {
 | |
|                                         'search' => '',
 | |
|                                         'smart' => true,
 | |
|                                         'regex' => false,
 | |
|                                         'caseInsensitive' => true
 | |
|                                       } }
 | |
|           team_status['ColReorder'] << (7 + index)
 | |
|         end
 | |
| 
 | |
|         SamplesTable.create(user: user, team: team, status: team_status)
 | |
|       end
 | |
|     end
 | |
|   end
 | |
| end
 |