Ao implementar hook_field_extra_fields () , posso ocultar o campo extra por padrão?
Às vezes, é mais amigável oferecer os campos extras como opção, em vez de exibi-lo imediatamente após a ativação de um módulo.
Ao implementar hook_field_extra_fields () , posso ocultar o campo extra por padrão?
Às vezes, é mais amigável oferecer os campos extras como opção, em vez de exibi-lo imediatamente após a ativação de um módulo.
Respostas:
Nos _field_info_prepare_extra_fields()
campos extras, são definidos como visíveis por padrão, mas as configurações extras são armazenadas na variável field_bundle_settings, que você pode alterar nos módulos, hook_install()
como:
$entity_type = 'node';
$bundle = 'article';
$field_name = 'my_extra_field';
$view_mode = 'teaser';
$field_bundle_setting = variable_get('field_bundle_settings', array());
$field_bundle_setting[$entity_type][$bundle]['extra_fields']['display'][$field_name][$view_mode]['visible'] = FALSE;
variable_set('field_bundle_settings', $field_bundle_setting);
_field_extra_fields_pre_render () , o retorno de chamada de pré-renderização usado por field_attach_form () e field_attach_view () , contém o seguinte código:
elseif (isset($elements['#view_mode'])) {
$view_mode = $elements['#view_mode'];
$extra_fields = field_extra_fields_get_display($entity_type, $bundle, $view_mode);
foreach ($extra_fields as $name => $settings) {
if (isset($elements[$name])) {
$elements[$name]['#weight'] = $settings['weight'];
// Visibility: make sure we do not accidentally show a hidden element.
$elements[$name]['#access'] = isset($elements[$name]['#access']) ? ($elements[$name]['#access'] && $settings['visible']) : $settings['visible'];
}
}
}
Ao implementar hook_field_extra_fields_display_alter () , você pode alterar a configuração de visibilidade, mas isso tornaria o campo invisível o tempo todo em que o formulário é exibido. Se você não deseja mostrar o campo quando o formulário é carregado pela primeira vez e quando, por exemplo, outro campo de formulário é selecionado ou seu valor é alterado, é necessário usar algum código JavaScript.
function mymodule_field_extra_fields_display_alter(&$displays, $context) {
if ($context['entity_type'] == 'taxonomy_term' && $context['view_mode'] == 'full') {
$displays['description']['visible'] = FALSE;
}
}
<hidden>
a primeira.
hook_field_extra_fields()
. Você pode alterar o campo do formulário ou o formatador usado pelo campo.
Existe um patch para adicionar essa capacidade ao núcleo drupal.
Se você quiser ver isso entrar, revise-o e envie-o.
No gancho de instalação do seu módulo, você pode fazer uma chamada para uma função semelhante a esta e ela ocultará em massa seus campos extras por padrão.
/**
* Sets default visibility of extra fields in all active view modes on entity bundles.
*
* This will not overwrite visibility that already exists in the variable.
*
* @param array $extra_field_names An array of extra fields
* @param string $entity_type The name of the entity type. Defaults to 'node'.
* @param array $bundles An array of bundle objects or names.
*/
function my_module_hide_extra_fields($extra_field_names, $entity_type = 'node', $bundles = NULL) {
$entity_info = entity_get_info($entity_type);
if ($bundles === NULL) {
$bundles = array_keys($entity_info['bundles']);
}
foreach ($bundles as $bundle) {
if (!is_string($bundle)) {
$bundle = $bundle->type;
}
$settings = field_bundle_settings($entity_type, $bundle);
$active_modes = array('default');
foreach ($settings['view_modes'] as $mode => $mode_settings) {
if ($mode_settings['custom_settings']) {
$active_modes[] = $mode;
}
}
foreach ($extra_field_names as $field_name) {
foreach ($active_modes as $mode) {
if (empty($settings['extra_fields']['display'][$field_name][$mode])
|| !array_key_exists('visible', $settings['extra_fields']['display'][$field_name][$mode])) {
$settings['extra_fields']['display'][$field_name][$mode]['visible'] = FALSE;
$settings['extra_fields']['display'][$field_name][$mode] += array(
'weight' => 0,
);
}
}
}
field_bundle_settings($entity_type, $bundle, $settings);
}
}
Exemplo muito mais simples. Para o Drupal 7, crie example_module.install no diretório example_module
/**
* hook_install
*/
function example_module_install() {
$field_machine_name = 'new_extra_field';
$entity_types = array('node', 'taxonomy_term', 'user');
foreach ($entity_types as $type) {
$info = entity_get_info($type);
$settings = field_bundle_settings($type, $bundle);
$view_modes = array_merge(array('default'), array_keys($info['view modes']));
foreach($view_modes as $view_mode) {
$settings['extra_fields']['display'][$field_machine_name][$view_mode] = array(
'visible' => FALSE,
'weight' => 0,
);
}
field_bundle_settings($type, $bundle, $settings);
}
}
Documentação para hook_install https://api.drupal.org/api/drupal/modules%21system%21system.api.php/function/hook_install/7
No seu arquivo example_module.module, inclua
/**
* Implementation of hook_field_extra_fields
*
*/
function example_module_field_extra_fields() {
$extra = array();
$field_machine_name = 'new_extra_field';
$entity_types = array('node', 'taxonomy_term', 'user');
foreach ($entity_types as $type) {
$info = entity_get_info($type);
foreach(array_keys($info["bundles"]) as $bundle) {
$extra[$type][$bundle]['display'][$field_machine_name] = array(
'label' => t('New extra field that will show up in manage display'),
'description' => 'A description for the extra field',
'weight' => 5,
);
}
}
return $extra;
}
Documentação para hook_field_extra_fields https://api.drupal.org/api/drupal/modules%21field%21field.api.php/function/hook_field_extra_fields/7