# frozen_string_literal: true class CreateDirectoryColumns < ActiveRecord::Migration[6.1] def up create_table :directory_columns do |t| t.string :name, null: true t.integer :automatic_position, null: true t.string :icon, null: true t.integer :user_field_id, null: true t.boolean :automatic, null: false t.boolean :enabled, null: false t.integer :position, null: false t.datetime :created_at, default: -> { "CURRENT_TIMESTAMP" } end add_index :directory_columns, %i[enabled position user_field_id], name: "directory_column_index" create_automatic_columns end def down drop_table :directory_columns end def create_automatic_columns DB.exec(<<~SQL) INSERT INTO directory_columns ( name, automatic, enabled, automatic_position, position, icon ) VALUES ( 'likes_received', true, true, 1, 1, 'heart' ), ( 'likes_given', true, true, 2, 2, 'heart' ), ( 'topic_count', true, true, 3, 3, NULL ), ( 'post_count', true, true, 4, 4, NULL ), ( 'topics_entered', true, true, 5, 5, NULL ), ( 'posts_read', true, true, 6, 6, NULL ), ( 'days_visited', true, true, 7, 7, NULL ); SQL end end