1: <?php
2: /**
3: * CakePHP(tm) : Rapid Development Framework (https://cakephp.org)
4: * Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
5: *
6: * Licensed under The MIT License
7: * For full copyright and license information, please see the LICENSE.txt
8: * Redistributions of files must retain the above copyright notice.
9: *
10: * @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
11: * @link https://cakephp.org CakePHP(tm) Project
12: * @since 3.0
13: * @license https://opensource.org/licenses/mit-license.php MIT License
14: */
15: namespace Cake\View;
16:
17: use Cake\Event\EventManager;
18: use Cake\Http\Response;
19: use Cake\Http\ServerRequest;
20:
21: /**
22: * A view class that is used for AJAX responses.
23: * Currently only switches the default layout and sets the response type - which just maps to
24: * text/html by default.
25: */
26: class AjaxView extends View
27: {
28:
29: /**
30: * {@inheritDoc}
31: */
32: protected $layout = 'ajax';
33:
34: /**
35: * Constructor
36: *
37: * @param \Cake\Http\ServerRequest|null $request The request object.
38: * @param \Cake\Http\Response|null $response The response object.
39: * @param \Cake\Event\EventManager|null $eventManager Event manager object.
40: * @param array $viewOptions View options.
41: */
42: public function __construct(
43: ServerRequest $request = null,
44: Response $response = null,
45: EventManager $eventManager = null,
46: array $viewOptions = []
47: ) {
48: if ($response && $response instanceof Response) {
49: $response = $response->withType('ajax');
50: }
51:
52: parent::__construct($request, $response, $eventManager, $viewOptions);
53: }
54: }
55: