Respostas:
Usando o serviço entity_field.manager , você pode obter uma matriz de classes BaseFieldDefinition. Este serviço também é injetável, mas para copiar e colar código de trabalho, você pode fazer o seguinte:
$bundle_fields = \Drupal::getContainer()->get('entity_field.manager')->getFieldDefinitions($entity_type, $bundle);
$field_definition = $bundle_fields[$field_name];
$catalog_id = $field_definition->getSetting($setting_name);
Usando uma instância de campo:
$settings = $field->getFieldDefinition()->getSettings();
Por exemplo, em um widget de campo:
public function formElement(FieldItemListInterface $items, $delta, array $element, array &$form, FormStateInterface $form_state) {
$element = [];
// Get the settings.
$settings = $items[$delta]->getFieldDefinition()->getSettings();
// ... build render array
return $element;
}
A maneira mais simples de obter a configuração do campo é usar o EntityTypeManager .
$entity_type = 'node';// node, taxonomy_term, taxonomy_vocabulary, ...
$bundle = 'article';// the content type machine name
$field = 'field_article_tags';// the field machine name
$fieldConfig = \Drupal::entityTypeManager()
->getStorage('field_config')
->load($entity_type . '.' . $bundle . '.' . $field);