diff --git a/core/modules/content_translation/src/ContentTranslationHandler.php b/core/modules/content_translation/src/ContentTranslationHandler.php index fe837505ded8f3d904cb7235c0f2333ae9d992e2..d3dad8ee8044882f7667383ec728404af0946652 100644 --- a/core/modules/content_translation/src/ContentTranslationHandler.php +++ b/core/modules/content_translation/src/ContentTranslationHandler.php @@ -629,9 +629,21 @@ public function entityFormSharedElements($element, FormStateInterface $form_stat } } - if ($display_warning && !$form_state->isSubmitted() && !$form_state->isRebuilding()) { + if ($display_warning) { $url = $entity->getUntranslated()->toUrl('edit-form')->toString(); - $this->messenger->addWarning($this->t('Fields that apply to all languages are hidden to avoid conflicting changes. <a href=":url">Edit them on the original language form</a>.', [':url' => $url])); + $message['warning'][] = $this->t('Fields that apply to all languages are hidden to avoid conflicting changes. <a href=":url">Edit them on the original language form</a>.', [':url' => $url]); + // Explicitly renders this warning message. This prevents repetition on + // AJAX operations or form submission. Other messages will be rendered in + // the default location. + // @see \Drupal\Core\Render\Element\StatusMessages. + $element['hidden_fields_warning_message'] = [ + '#theme' => 'status_messages', + '#message_list' => $message, + '#weight' => -100, + '#status_headings' => [ + 'warning' => $this->t('Warning message'), + ], + ]; } return $element; diff --git a/core/modules/content_translation/tests/src/Functional/ContentTranslationUntranslatableFieldsTest.php b/core/modules/content_translation/tests/src/Functional/ContentTranslationUntranslatableFieldsTest.php index 07470bc7e9a0930077fe178673628d8e623d6412..f436ed27922d51a35dc566e761ebf6859b83991b 100644 --- a/core/modules/content_translation/tests/src/Functional/ContentTranslationUntranslatableFieldsTest.php +++ b/core/modules/content_translation/tests/src/Functional/ContentTranslationUntranslatableFieldsTest.php @@ -176,6 +176,13 @@ public function testHiddenWidgets() { $this->submitForm([$settings_key => 0], 'Save configuration'); $this->assertSession()->fieldValueEquals($field_name, 1); $this->assertSession()->fieldDisabled($field_name); + + // Verify that the untranslatable fields warning message is not displayed + // when submitting. + $this->drupalGet($it_edit_url); + $this->assertSession()->pageTextContains('Fields that apply to all languages are hidden to avoid conflicting changes.'); + $this->submitForm([], 'Save (this translation)'); + $this->assertSession()->pageTextNotContains('Fields that apply to all languages are hidden to avoid conflicting changes.'); } } diff --git a/core/modules/content_translation/tests/src/Kernel/ContentTranslationHandlerTest.php b/core/modules/content_translation/tests/src/Kernel/ContentTranslationHandlerTest.php index 55428a40ee4e7e4df498f1e226e56062bb32f367..7d27abd9585cb8400b385ced4414d80818ac1576 100644 --- a/core/modules/content_translation/tests/src/Kernel/ContentTranslationHandlerTest.php +++ b/core/modules/content_translation/tests/src/Kernel/ContentTranslationHandlerTest.php @@ -93,21 +93,15 @@ protected function setUp(): void { * Whether or not the entity is the default translation. * @param bool $translation_form * Whether or not the form is a translation form. - * @param bool $is_submitted - * Whether or not the form should be marked as submitted. - * @param bool $is_rebuilding - * Whether or not the form should be flagged for rebuild. * @param array $expected * The expected altered element. - * @param bool $display_warning - * Whether or not the warning message should be displayed. * * @dataProvider providerTestEntityFormSharedElements * * @covers ::entityFormSharedElements * @covers ::addTranslatabilityClue */ - public function testEntityFormSharedElements(array $element, $default_translation_affected, $default_translation, $translation_form, $is_submitted, $is_rebuilding, array $expected, $display_warning) { + public function testEntityFormSharedElements(array $element, $default_translation_affected, $default_translation, $translation_form, array $expected) { $this->state->set('entity_test.translation', TRUE); $this->state->set('entity_test.untranslatable_fields.default_translation_affected', $default_translation_affected); $this->entityTypeBundleInfo->clearCachedBundles(); @@ -126,21 +120,11 @@ public function testEntityFormSharedElements(array $element, $default_translatio $form_state ->addBuildInfo('callback_object', $form_object) ->set(['content_translation', 'translation_form'], $translation_form); - if ($is_submitted) { - $form_state->setSubmitted(); - } - $form_state->setRebuild($is_rebuilding); $handler = $this->entityTypeManager->getHandler($this->entityTypeId, 'translation'); $actual = $handler->entityFormSharedElements($element, $form_state, $element); $this->assertEquals($expected, $actual); - if ($display_warning) { - $messages = $this->messenger->messagesByType('warning'); - $this->assertCount(1, $messages); - $expected_message = sprintf('Fields that apply to all languages are hidden to avoid conflicting changes. <a href="%s">Edit them on the original language form</a>.', $entity->toUrl('edit-form')->toString()); - $this->assertSame($expected_message, (string) reset($messages)); - } } /** @@ -159,10 +143,7 @@ public function providerTestEntityFormSharedElements() { 'default_translation_affected' => TRUE, 'default_translation' => TRUE, 'translation_form' => FALSE, - 'is_submitted' => TRUE, - 'is_rebuilding' => TRUE, 'expected' => $element, - 'display_warning' => FALSE, ]; $element = [ @@ -226,6 +207,16 @@ public function providerTestEntityFormSharedElements() { 'name' => [ '#type' => 'textfield', ], + 'hidden_fields_warning_message' => [ + '#theme' => 'status_messages', + '#message_list' => [ + 'warning' => [t('Fields that apply to all languages are hidden to avoid conflicting changes. <a href=":url">Edit them on the original language form</a>.')], + ], + '#weight' => -100, + '#status_headings' => [ + 'warning' => t('Warning message'), + ], + ], ]; $expected = $element; $expected['name']['#access'] = FALSE; @@ -233,13 +224,6 @@ public function providerTestEntityFormSharedElements() { $tests['hide-untranslatable']['element'] = $element; $tests['hide-untranslatable']['expected'] = $expected; - $tests['is-rebuilding'] = $tests['hide-untranslatable']; - $tests['is-rebuilding']['is_submitted'] = FALSE; - - $tests['display-warning'] = $tests['is-rebuilding']; - $tests['display-warning']['is_rebuilding'] = FALSE; - $tests['display-warning']['display_warning'] = TRUE; - $tests['no-translation-form'] = $tests['no-translatability-clue']; $tests['no-translation-form']['translation_form'] = FALSE;