function FieldSettings::getSettings

Same name and namespace in other branches
  1. 8.9.x core/modules/field/src/Plugin/migrate/process/d6/FieldSettings.php \Drupal\field\Plugin\migrate\process\d6\FieldSettings::getSettings()
  2. 10 core/modules/field/src/Plugin/migrate/process/d6/FieldSettings.php \Drupal\field\Plugin\migrate\process\d6\FieldSettings::getSettings()
  3. 11.x core/modules/field/src/Plugin/migrate/process/d6/FieldSettings.php \Drupal\field\Plugin\migrate\process\d6\FieldSettings::getSettings()

Merge the default D8 and specified D6 settings.

Parameters

string $field_type: The destination field type.

array $global_settings: The field settings.

string $original_field_type: (optional) The original field type before migration.

Return value

array A valid array of settings.

1 call to FieldSettings::getSettings()
FieldSettings::transform in core/modules/field/src/Plugin/migrate/process/d6/FieldSettings.php
Get the field default/mapped settings.

File

core/modules/field/src/Plugin/migrate/process/d6/FieldSettings.php, line 46

Class

FieldSettings
Get the field settings.

Namespace

Drupal\field\Plugin\migrate\process\d6

Code

public function getSettings($field_type, $global_settings, $original_field_type = NULL) {
    $max_length = $global_settings['max_length'] ?? '';
    $max_length = empty($max_length) ? 255 : $max_length;
    $allowed_values = [];
    if (isset($global_settings['allowed_values'])) {
        $list = explode("\n", $global_settings['allowed_values']);
        $list = array_map('trim', $list);
        $list = array_filter($list, 'strlen');
        switch ($field_type) {
            case 'list_string':
            case 'list_integer':
            case 'list_float':
                foreach ($list as $value) {
                    $value = explode("|", $value);
                    $allowed_values[$value[0]] = $value[1] ?? $value[0];
                }
                break;
            default:
                $allowed_values = $list;
        }
    }
    $settings = [
        'text' => [
            'max_length' => $max_length,
        ],
        'datetime' => [
            'datetime_type' => 'datetime',
        ],
        'list_string' => [
            'allowed_values' => $allowed_values,
        ],
        'list_integer' => [
            'allowed_values' => $allowed_values,
        ],
        'list_float' => [
            'allowed_values' => $allowed_values,
        ],
        'boolean' => [
            'allowed_values' => $allowed_values,
        ],
    ];
    if ($original_field_type == 'userreference') {
        return [
            'target_type' => 'user',
        ];
    }
    else {
        return $settings[$field_type] ?? [];
    }
}

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.