Używając hook_form_alter, musisz zrobić dwie rzeczy
1) upewnij się, że jest to formularz węzła 2) dodaj niestandardową procedurę obsługi przesyłania do każdego przycisku przesyłania.
function mymodule_form_alter(&$form, FormStateInterface $form_state, $form_id) {
if (isset($form['#entity_type']) && $form['#entity_type'] == 'node') {
foreach (array_keys($form['actions']) as $action) {
if ($action != 'preview' && isset($form['actions'][$action]['#type']) && $form['actions'][$action]['#type'] === 'submit') {
$form['actions'][$action]['#submit'][] = 'mymodule_node_form_submit';
}
}
}
}
Następnie dla funkcji wysyłania możesz użyć dowolnej logiki. Możesz porównać z NodeForm :: save, gdzie wysyła cię do strony węzła kanonicznego lub do strony głównej w oparciu o uprawnienia dostępu bieżącego użytkownika.
Jeśli chcesz zmienić to zachowanie, aby pozostało w bieżącej formie węzła, możesz to zrobić:
function mymodule_node_form_submit($form, FormStateInterface $form_state) {
$node = $form_state->getFormObject()->getEntity();
if ($node->id()) {
if ($node->access('edit')) {
$form_state->setRedirect(
'entity.node.edit_form',
['node' => $node->id()]
);
}
else {
$form_state->setRedirect('<front>');
}
}
}
Jeśli chcesz użyć niestandardowej strony docelowej, po prostu zastąp przekierowanie kodem, którego już używasz:
$form_state->setRedirect('custom.landing.page');
Pamiętaj, że nie zastąpi to parametru „docelowego” $ _GET, na przykład na stronie / admin / content.
Aby usunąć parametr docelowy ze strony / admin / content, usuń zaznaczenie pola wyboru „miejsce docelowe” w obszarze „Treść: Linki operacji (operacje)” w tych polach widoków.
If saving is an option, privileged users get dedicated form submit buttons to adjust the publishing status while saving in one go. @todo This adjustment makes it close to impossible for contributed modules to integrate with "the Save operation" of this form. Modules need a way to plug themselves into 1) the ::submit() step, and 2) the ::save() step, both decoupled from the pressed form button.