public ModalRenderer::renderResponse(array $main_content, Request $request, RouteMatchInterface $route_match)
Renders the main content render array into a response.
Parameters
array $main_content: The render array representing the main content.
\Symfony\Component\HttpFoundation\Request $request: The request object, for context.
\Drupal\Core\Routing\RouteMatchInterface $route_match: The route match, for context.
Return value
\Symfony\Component\HttpFoundation\Response The Response in the format that this implementation supports.
Overrides DialogRenderer::renderResponse
File
- core/lib/Drupal/Core/Render/MainContent/ModalRenderer.php, line 18
Class
- ModalRenderer
- Default main content renderer for modal dialog requests.
Namespace
Drupal\Core\Render\MainContent
Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | public function renderResponse( array $main_content , Request $request , RouteMatchInterface $route_match ) { $response = new AjaxResponse(); // First render the main content, because it might provide a title. $content = drupal_render_root( $main_content ); // Attach the library necessary for using the OpenModalDialogCommand and set // the attachments for this Ajax response. $main_content [ '#attached' ][ 'library' ][] = 'core/drupal.dialog.ajax' ; $response ->setAttachments( $main_content [ '#attached' ]); // If the main content doesn't provide a title, use the title resolver. $title = isset( $main_content [ '#title' ]) ? $main_content [ '#title' ] : $this ->titleResolver->getTitle( $request , $route_match ->getRouteObject()); // Determine the title: use the title provided by the main content if any, // otherwise get it from the routing information. $options = $request ->request->get( 'dialogOptions' , array ()); $response ->addCommand( new OpenModalDialogCommand( $title , $content , $options )); return $response ; } |
Please login to continue.