MOON
Server: Apache
System: Linux res.emeff.ca 3.10.0-962.3.2.lve1.5.24.10.el7.x86_64 #1 SMP Wed Mar 20 07:36:02 EDT 2019 x86_64
User: accemeff (1004)
PHP: 7.0.33
Disabled: NONE
Upload Files
File: /home/accemeff/vendor/craftcms/cms/src/migrations/m171016_092553_drop_position_select.php
<?php

namespace craft\migrations;

use craft\db\Migration;
use craft\db\Query;
use craft\db\Table;
use craft\fields\Dropdown;
use craft\helpers\Json;

/**
 * m171016_092553_drop_position_select migration.
 */
class m171016_092553_drop_position_select extends Migration
{
    /**
     * @inheritdoc
     */
    public function safeUp()
    {
        $fields = (new Query())
            ->select(['id', 'settings'])
            ->from([Table::FIELDS])
            ->where(['type' => 'craft\\fields\\PositionSelect'])
            ->all();

        if (empty($fields)) {
            return;
        }

        $labels = [
            'left' => 'Left',
            'center' => 'Center',
            'right' => 'Right',
            'full' => 'Full',
            'drop-left' => 'Drop-left',
            'drop-right' => 'Drop-right',
        ];

        foreach ($fields as $field) {
            $settings = Json::decode($field['settings']);
            $oldOptions = $settings['options'] ?? [];
            $newOptions = [];

            foreach ($oldOptions as $option) {
                $newOptions[] = [
                    'label' => $labels[$option] ?? $option,
                    'value' => $option,
                    'default' => '',
                ];
            }

            $this->update(Table::FIELDS, [
                'type' => Dropdown::class,
                'settings' => Json::encode(['options' => $newOptions]),
            ], [
                'id' => $field['id']
            ]);
        }
    }

    /**
     * @inheritdoc
     */
    public function safeDown()
    {
        echo "m171016_092553_drop_position_select cannot be reverted.\n";
        return false;
    }
}