public function up()

in database/migrations/2018_08_31_020908_create_life_events_table.php [17:408]


    public function up()
    {
        Schema::create('default_life_event_categories', function (Blueprint $table) {
            $table->increments('id');
            $table->string('translation_key');
            $table->boolean('migrated')->default(0);
            $table->timestamps();
        });

        Schema::create('default_life_event_types', function (Blueprint $table) {
            $table->increments('id');
            $table->unsignedInteger('default_life_event_category_id');
            $table->string('translation_key');
            $table->text('specific_information_structure')->nullable();
            $table->boolean('migrated')->default(0);
            $table->timestamps();
            $table->foreign('default_life_event_category_id')->references('id')->on('default_life_event_categories')->onDelete('cascade');
        });

        // Core monica data means that there are some special actions that we do
        // with the data. For those core data, we will warn the user if he
        // deletes them that we won't be able to do special actions with it.
        // Example: let's say user indicates that the contact expects a baby.
        // The system can see that this is linked to a specific action and we
        // could write a special action for it to be reminded in X months to
        // see if the baby is born, for instance.
        Schema::create('life_event_categories', function (Blueprint $table) {
            $table->increments('id');
            $table->unsignedInteger('account_id');
            $table->string('name');
            $table->string('default_life_event_category_key')->nullable();
            $table->boolean('core_monica_data')->default(0);
            $table->timestamps();
            $table->foreign('account_id')->references('id')->on('accounts')->onDelete('cascade');
        });

        Schema::create('life_event_types', function (Blueprint $table) {
            $table->increments('id');
            $table->unsignedInteger('account_id');
            $table->unsignedInteger('life_event_category_id');
            $table->string('name');
            $table->string('default_life_event_type_key')->nullable();
            $table->boolean('core_monica_data')->default(0);
            $table->text('specific_information_structure')->nullable();
            $table->timestamps();
            $table->foreign('account_id')->references('id')->on('accounts')->onDelete('cascade');
            $table->foreign('life_event_category_id')->references('id')->on('life_event_categories')->onDelete('cascade');
        });

        Schema::create('life_events', function (Blueprint $table) {
            $table->increments('id');
            $table->unsignedInteger('account_id');
            $table->unsignedInteger('contact_id');
            $table->unsignedInteger('life_event_type_id');
            $table->string('name')->nullable();
            $table->mediumText('note')->nullable();
            $table->dateTime('happened_at');
            $table->boolean('happened_at_month_unknown')->default(false);
            $table->boolean('happened_at_day_unknown')->default(false);
            $table->text('specific_information')->nullable();
            $table->timestamps();
            $table->foreign('account_id')->references('id')->on('accounts')->onDelete('cascade');
            $table->foreign('contact_id')->references('id')->on('contacts')->onDelete('cascade');
            $table->foreign('life_event_type_id')->references('id')->on('life_event_types')->onDelete('cascade');
        });

        // POPULATE DEFAULT TABLES
        // WORK AND EDUCATION
        $defaultCategoryId = DB::table('default_life_event_categories')->insertGetId([
            'translation_key' => 'work_education',
            'created_at' => now(),
            'updated_at' => now(),
        ]);

        DB::table('default_life_event_types')->insert([
            'translation_key' => 'new_job',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"employer": {"type": "string", "value": ""}, "job_title": {"type": "string", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'retirement',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"profession": {"type": "string", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'new_school',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"degree": {"type": "string", "value": ""}, "end_date": {"type": "date", "value": ""}, "end_date_reminder_id": {"type": "integer", "value": ""}, "school_name": {"type": "string", "value": ""}, "studying": {"type": "string", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'study_abroad',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"degree": {"type": "string", "value": ""}, "end_date": {"type": "date", "value": ""}, "end_date_reminder_id": {"type": "integer", "value": ""}, "school_name": {"type": "string", "value": ""}, "studying": {"type": "string", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'volunteer_work',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"organization": {"type": "string", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'published_book_or_paper',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"full_citation": {"type": "string", "value": ""}, "url": {"type": "string", "value": ""}, "citation": {"type": "string", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'military_service',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"end_date": {"type": "date", "value": ""}, "end_date_reminder_id": {"type": "integer", "value": ""}, "branch": {"type": "string", "value": ""}, "division": {"type": "string", "value": ""}, "country": {"type": "string", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);

        // HOME LIVING
        $defaultCategoryId = DB::table('default_life_event_categories')->insertGetId([
            'translation_key' => 'family_relationships',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'new_relationship',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'engagement',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"with_contact_id": {"type": "integer", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'marriage',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"with_contact_id": {"type": "integer", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'anniversary',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'expecting_a_baby',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"contact_id": {"type": "integer", "value": ""}, "expected_date": {"type": "date", "value": ""}, "expected_date_reminder_id": {"type": "integer", "value": ""}, "expected_gender": {"type": "string", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'new_child',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'new_family_member',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'new_pet',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'end_of_relationship',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"breakup_reason": {"type": "string", "value": ""}, "who_broke_up_contact_id": {"type": "integer", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'loss_of_a_loved_one',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);

        // HOME & LIVING
        $defaultCategoryId = DB::table('default_life_event_categories')->insertGetId([
            'translation_key' => 'home_living',
            'created_at' => now(),
            'updated_at' => now(),
        ]);

        DB::table('default_life_event_types')->insert([
            'translation_key' => 'moved',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"where_to": {"type": "string", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'bought_a_home',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"address": {"type": "string", "value": ""}, "estimated_value": {"type": "number", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'home_improvement',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'holidays',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"where": {"type": "string", "value": ""}, "duration_in_days": {"type": "integer", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'new_vehicule',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"type": {"type": "string", "value": ""}, "model": {"type": "string", "value": ""}, "model_year": {"type": "string", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'new_roommate',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"contact_id": {"type": "string", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);

        // TRAVEL AND EXPERIENCES
        $defaultCategoryId = DB::table('default_life_event_categories')->insertGetId([
            'translation_key' => 'health_wellness',
            'created_at' => now(),
            'updated_at' => now(),
        ]);

        DB::table('default_life_event_types')->insert([
            'translation_key' => 'overcame_an_illness',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'quit_a_habit',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'new_eating_habits',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'weight_loss',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"amount": {"type": "string", "value": ""}, "unit": {"type": "string", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'wear_glass_or_contact',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'broken_bone',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'removed_braces',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'surgery',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"nature": {"type": "string", "value": ""}, "number_days_in_hospital": {"type": "integer", "value": ""}, "number_days_in_hospital": {"type": "integer", "value": ""}, "expected_date_out_of_hospital_reminder_id": {"type": "integer", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'dentist',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);

        // HEALTH AND WELLNESS
        $defaultCategoryId = DB::table('default_life_event_categories')->insertGetId([
            'translation_key' => 'travel_experiences',
            'created_at' => now(),
            'updated_at' => now(),
        ]);

        DB::table('default_life_event_types')->insert([
            'translation_key' => 'new_sport',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'new_hobby',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'new_instrument',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'new_language',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'tattoo_or_piercing',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'new_license',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'travel',
            'default_life_event_category_id' => $defaultCategoryId,
            'specific_information_structure' => '{"visited_place": {"type": "string", "value": ""}, "duration_in_days": {"type": "integer", "value": ""}}',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'achievement_or_award',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'changed_beliefs',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'first_word',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);
        DB::table('default_life_event_types')->insert([
            'translation_key' => 'first_kiss',
            'default_life_event_category_id' => $defaultCategoryId,
            'created_at' => now(),
            'updated_at' => now(),
        ]);

        Account::chunk(200, function ($accounts) {
            foreach ($accounts as $account) {
                app(PopulateLifeEventsTable::class)->execute([
                    'account_id' => $account->id,
                    'migrate_existing_data' => true,
                ]);
            }
        });
    }