-
Notifications
You must be signed in to change notification settings - Fork 638
/
SubModuleFixture.php
90 lines (80 loc) · 2.39 KB
/
SubModuleFixture.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
<?php
declare(strict_types=1);
/*
* This file is part of the TYPO3 CMS project.
*
* It is free software; you can redistribute it and/or modify it under
* the terms of the GNU General Public License, either version 2
* of the License, or any later version.
*
* For the full copyright and license information, please read the
* LICENSE.txt file that was distributed with this source code.
*
* The TYPO3 project - inspiring people to share!
*/
namespace TYPO3\CMS\Adminpanel\Tests\Unit\Fixtures;
use Psr\Http\Message\ServerRequestInterface;
use TYPO3\CMS\Adminpanel\ModuleApi\ContentProviderInterface;
use TYPO3\CMS\Adminpanel\ModuleApi\DataProviderInterface;
use TYPO3\CMS\Adminpanel\ModuleApi\ModuleData;
use TYPO3\CMS\Adminpanel\ModuleApi\ModuleInterface;
use TYPO3\CMS\Adminpanel\ModuleApi\ModuleSettingsProviderInterface;
use TYPO3\CMS\Adminpanel\ModuleApi\OnSubmitActorInterface;
class SubModuleFixture implements ModuleInterface, ContentProviderInterface, ModuleSettingsProviderInterface, OnSubmitActorInterface, DataProviderInterface
{
/**
* Identifier for this Sub-module,
* for example "preview" or "cache"
*
* @return string
*/
public function getIdentifier(): string
{
return 'example-submodule';
}
/**
* Sub-Module label
*
* @return string
*/
public function getLabel(): string
{
return 'Example SubModule';
}
/**
* Sub-Module content as rendered HTML
*
* @param ModuleData $data
* @return string
*/
public function getContent(ModuleData $data): string
{
return 'content';
}
/**
* Settings as HTML form elements (without wrapping form tag or save button)
*
* @return string
*/
public function getSettings(): string
{
return 'settings';
}
/**
* Executed on saving / submit of the configuration form
* Can be used to react to changed settings
* (for example: clearing a specific cache)
*
* @param array $configurationToSave
* @param ServerRequestInterface $request
*/
public function onSubmit(array $configurationToSave, ServerRequestInterface $request): void {}
/**
* @param ServerRequestInterface $request
* @return ModuleData
*/
public function getDataToStore(ServerRequestInterface $request): ModuleData
{
return new ModuleData(['foo' => 'bar']);
}
}