Passed
Push — master ( b62e9a...a002f8 )
by Daniel
03:04
created
src/PageTypes/BasePage.php 2 patches
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -186,7 +186,7 @@
 block discarded – undo
186 186
 
187 187
     public function getCMSFields()
188 188
     {
189
-        $this->beforeUpdateCMSFields(function (FieldList $fields) {
189
+        $this->beforeUpdateCMSFields(function(FieldList $fields) {
190 190
             // Related Pages
191 191
             $components = GridFieldConfig_RelationEditor::create();
192 192
             $components->removeComponentsByType(GridFieldAddNewButton::class);
Please login to merge, or discard this patch.
Indentation   +143 added lines, -143 removed lines patch added patch discarded remove patch
@@ -27,147 +27,147 @@
 block discarded – undo
27 27
 
28 28
 class BasePage extends SiteTree
29 29
 {
30
-    private static $icon = 'cwp/cwp:images/icons/sitetree_images/page.png';
31
-
32
-    /**
33
-     * Hide this page type from the CMS. hide_ancestor is slightly misnamed, should really be just "hide"
34
-     *
35
-     * {@inheritDoc}
36
-     */
37
-    private static $hide_ancestor = BasePage::class;
38
-
39
-    private static $api_access = [
40
-        'view' => [
41
-            'Locale', 'URLSegment', 'Title', 'MenuTitle', 'Content', 'MetaDescription',
42
-            'ExtraMenu', 'Sort', 'Version', 'ParentID', 'ID'
43
-        ],
44
-        'edit' => [
45
-            'Locale', 'URLSegment', 'Title', 'MenuTitle', 'Content', 'MetaDescription',
46
-            'ExtraMenu', 'Sort', 'Version', 'ParentID', 'ID'
47
-        ],
48
-    ];
49
-
50
-    private static $table_name = 'BasePage';
51
-
52
-    /**
53
-     * @config
54
-     * @var string
55
-     */
56
-    private static $related_pages_title = 'Related pages';
57
-
58
-    private static $many_many = [
59
-        'Terms' => TaxonomyTerm::class,
60
-        'RelatedPages' => BasePage::class,
61
-    ];
62
-
63
-    /**
64
-     * @var array
65
-     * @config
66
-     */
67
-    private static $many_many_extraFields = [
68
-        'RelatedPages' => [
69
-            'SortOrder' => DBInt::class,
70
-        ],
71
-    ];
72
-
73
-    private static $plural_name = 'Base Pages';
74
-
75
-    /**
76
-     * Get the footer holder.
77
-     */
78
-    public function getFooter()
79
-    {
80
-        return FooterHolder::get_one(FooterHolder::class);
81
-    }
82
-
83
-    public function RelatedPages()
84
-    {
85
-        return $this->getManyManyComponents('RelatedPages')->sort('SortOrder');
86
-    }
87
-
88
-    public function RelatedPagesTitle()
89
-    {
90
-        return $this->config()->get('related_pages_title');
91
-    }
92
-
93
-    public function getCMSFields()
94
-    {
95
-        $this->beforeUpdateCMSFields(function (FieldList $fields) {
96
-            // Related Pages
97
-            $components = GridFieldConfig_RelationEditor::create();
98
-            $components->removeComponentsByType(GridFieldAddNewButton::class);
99
-            $components->removeComponentsByType(GridFieldEditButton::class);
100
-            $components->removeComponentsByType(GridFieldFilterHeader::class);
101
-            $components->addComponent(new GridFieldOrderableRows('SortOrder'));
102
-
103
-            /** @var GridFieldDataColumns $dataColumns */
104
-            $dataColumns = $components->getComponentByType(GridFieldDataColumns::class);
105
-            $dataColumns->setDisplayFields([
106
-                'Title' => _t(__CLASS__ . '.ColumnTitle', 'Title'),
107
-                'ClassName' => _t(__CLASS__ . '.ColumnPageType', 'Page Type')
108
-            ]);
109
-
110
-            $fields->findOrMakeTab(
111
-                'Root.RelatedPages',
112
-                _t(__CLASS__ . '.RelatedPages', 'Related pages')
113
-            );
114
-            $fields->addFieldToTab(
115
-                'Root.RelatedPages',
116
-                GridField::create(
117
-                    'RelatedPages',
118
-                    _t(__CLASS__ . '.RelatedPages', 'Related pages'),
119
-                    $this->RelatedPages(),
120
-                    $components
121
-                )
122
-            );
123
-
124
-            // Taxonomies - Unless they have their own 'Tags' field (such as in Blog, etc)
125
-            $hasMany = $this->hasMany();
126
-            $manyMany = $this->manyMany();
127
-            if (!isset($hasMany['Tags']) && !isset($manyMany['Tags'])) {
128
-                $components = GridFieldConfig_RelationEditor::create();
129
-                $components->removeComponentsByType(GridFieldAddNewButton::class);
130
-                $components->removeComponentsByType(GridFieldEditButton::class);
131
-
132
-                /** @var GridFieldAddExistingAutocompleter $autoCompleter */
133
-                $autoCompleter = $components->getComponentByType(GridFieldAddExistingAutocompleter::class);
134
-                $autoCompleter->setResultsFormat('$Name ($TaxonomyName)');
135
-
136
-                /** @var GridFieldDataColumns $dataColumns */
137
-                $dataColumns = $components->getComponentByType(GridFieldDataColumns::class);
138
-                $dataColumns->setDisplayFields([
139
-                    'Name' => _t(__CLASS__ . '.Term', 'Term'),
140
-                    'TaxonomyName' => _t(__CLASS__ . '.Taxonomy', 'Taxonomy')
141
-                ]);
142
-
143
-                $fields->findOrMakeTab('Root.Tags', _t(__CLASS__ . '.TagsTabTitle', 'Tags'));
144
-                $fields->addFieldToTab(
145
-                    'Root.Tags',
146
-                    TreeMultiselectField::create(
147
-                        'Terms',
148
-                        _t(__CLASS__ . '.Terms', 'Terms'),
149
-                        TaxonomyTerm::class
150
-                    )->setDescription(_t(__CLASS__ . '.TermsDescription', 'Click to search for additional terms'))
151
-                );
152
-            }
153
-        });
154
-        return parent::getCMSFields();
155
-    }
156
-
157
-    /**
158
-     * Returns the native language name for the selected locale/language, empty string if Fluent is not available
159
-     *
160
-     * @return string
161
-     */
162
-    public function getSelectedLanguage()
163
-    {
164
-        if (!class_exists(Locale::class) || !$this->hasMethod('Locales')) {
165
-            return '';
166
-        }
167
-
168
-        /** @var ArrayData $information */
169
-        $information = $this->LocaleInformation(FluentState::singleton()->getLocale());
170
-
171
-        return $information->LanguageNative;
172
-    }
30
+	private static $icon = 'cwp/cwp:images/icons/sitetree_images/page.png';
31
+
32
+	/**
33
+	 * Hide this page type from the CMS. hide_ancestor is slightly misnamed, should really be just "hide"
34
+	 *
35
+	 * {@inheritDoc}
36
+	 */
37
+	private static $hide_ancestor = BasePage::class;
38
+
39
+	private static $api_access = [
40
+		'view' => [
41
+			'Locale', 'URLSegment', 'Title', 'MenuTitle', 'Content', 'MetaDescription',
42
+			'ExtraMenu', 'Sort', 'Version', 'ParentID', 'ID'
43
+		],
44
+		'edit' => [
45
+			'Locale', 'URLSegment', 'Title', 'MenuTitle', 'Content', 'MetaDescription',
46
+			'ExtraMenu', 'Sort', 'Version', 'ParentID', 'ID'
47
+		],
48
+	];
49
+
50
+	private static $table_name = 'BasePage';
51
+
52
+	/**
53
+	 * @config
54
+	 * @var string
55
+	 */
56
+	private static $related_pages_title = 'Related pages';
57
+
58
+	private static $many_many = [
59
+		'Terms' => TaxonomyTerm::class,
60
+		'RelatedPages' => BasePage::class,
61
+	];
62
+
63
+	/**
64
+	 * @var array
65
+	 * @config
66
+	 */
67
+	private static $many_many_extraFields = [
68
+		'RelatedPages' => [
69
+			'SortOrder' => DBInt::class,
70
+		],
71
+	];
72
+
73
+	private static $plural_name = 'Base Pages';
74
+
75
+	/**
76
+	 * Get the footer holder.
77
+	 */
78
+	public function getFooter()
79
+	{
80
+		return FooterHolder::get_one(FooterHolder::class);
81
+	}
82
+
83
+	public function RelatedPages()
84
+	{
85
+		return $this->getManyManyComponents('RelatedPages')->sort('SortOrder');
86
+	}
87
+
88
+	public function RelatedPagesTitle()
89
+	{
90
+		return $this->config()->get('related_pages_title');
91
+	}
92
+
93
+	public function getCMSFields()
94
+	{
95
+		$this->beforeUpdateCMSFields(function (FieldList $fields) {
96
+			// Related Pages
97
+			$components = GridFieldConfig_RelationEditor::create();
98
+			$components->removeComponentsByType(GridFieldAddNewButton::class);
99
+			$components->removeComponentsByType(GridFieldEditButton::class);
100
+			$components->removeComponentsByType(GridFieldFilterHeader::class);
101
+			$components->addComponent(new GridFieldOrderableRows('SortOrder'));
102
+
103
+			/** @var GridFieldDataColumns $dataColumns */
104
+			$dataColumns = $components->getComponentByType(GridFieldDataColumns::class);
105
+			$dataColumns->setDisplayFields([
106
+				'Title' => _t(__CLASS__ . '.ColumnTitle', 'Title'),
107
+				'ClassName' => _t(__CLASS__ . '.ColumnPageType', 'Page Type')
108
+			]);
109
+
110
+			$fields->findOrMakeTab(
111
+				'Root.RelatedPages',
112
+				_t(__CLASS__ . '.RelatedPages', 'Related pages')
113
+			);
114
+			$fields->addFieldToTab(
115
+				'Root.RelatedPages',
116
+				GridField::create(
117
+					'RelatedPages',
118
+					_t(__CLASS__ . '.RelatedPages', 'Related pages'),
119
+					$this->RelatedPages(),
120
+					$components
121
+				)
122
+			);
123
+
124
+			// Taxonomies - Unless they have their own 'Tags' field (such as in Blog, etc)
125
+			$hasMany = $this->hasMany();
126
+			$manyMany = $this->manyMany();
127
+			if (!isset($hasMany['Tags']) && !isset($manyMany['Tags'])) {
128
+				$components = GridFieldConfig_RelationEditor::create();
129
+				$components->removeComponentsByType(GridFieldAddNewButton::class);
130
+				$components->removeComponentsByType(GridFieldEditButton::class);
131
+
132
+				/** @var GridFieldAddExistingAutocompleter $autoCompleter */
133
+				$autoCompleter = $components->getComponentByType(GridFieldAddExistingAutocompleter::class);
134
+				$autoCompleter->setResultsFormat('$Name ($TaxonomyName)');
135
+
136
+				/** @var GridFieldDataColumns $dataColumns */
137
+				$dataColumns = $components->getComponentByType(GridFieldDataColumns::class);
138
+				$dataColumns->setDisplayFields([
139
+					'Name' => _t(__CLASS__ . '.Term', 'Term'),
140
+					'TaxonomyName' => _t(__CLASS__ . '.Taxonomy', 'Taxonomy')
141
+				]);
142
+
143
+				$fields->findOrMakeTab('Root.Tags', _t(__CLASS__ . '.TagsTabTitle', 'Tags'));
144
+				$fields->addFieldToTab(
145
+					'Root.Tags',
146
+					TreeMultiselectField::create(
147
+						'Terms',
148
+						_t(__CLASS__ . '.Terms', 'Terms'),
149
+						TaxonomyTerm::class
150
+					)->setDescription(_t(__CLASS__ . '.TermsDescription', 'Click to search for additional terms'))
151
+				);
152
+			}
153
+		});
154
+		return parent::getCMSFields();
155
+	}
156
+
157
+	/**
158
+	 * Returns the native language name for the selected locale/language, empty string if Fluent is not available
159
+	 *
160
+	 * @return string
161
+	 */
162
+	public function getSelectedLanguage()
163
+	{
164
+		if (!class_exists(Locale::class) || !$this->hasMethod('Locales')) {
165
+			return '';
166
+		}
167
+
168
+		/** @var ArrayData $information */
169
+		$information = $this->LocaleInformation(FluentState::singleton()->getLocale());
170
+
171
+		return $information->LanguageNative;
172
+	}
173 173
 }
Please login to merge, or discard this patch.
tests/PageTypes/DatedUpdateHolderControllerTest.php 1 patch
Indentation   +23 added lines, -23 removed lines patch added patch discarded remove patch
@@ -9,36 +9,36 @@
 block discarded – undo
9 9
 
10 10
 class DatedUpdateHolderControllerTest extends FunctionalTest
11 11
 {
12
-    protected static $fixture_file = 'EventHolderTest.yml';
12
+	protected static $fixture_file = 'EventHolderTest.yml';
13 13
 
14
-    protected static $use_draft_site = true;
14
+	protected static $use_draft_site = true;
15 15
 
16
-    protected function setUp()
17
-    {
18
-        parent::setUp();
16
+	protected function setUp()
17
+	{
18
+		parent::setUp();
19 19
 
20
-        // Note: this test requires the starter theme to be installed
21
-        Config::modify()->set(SSViewer::class, 'themes', ['starter', '$default']);
22
-        Config::modify()->set(SSViewer::class, 'theme', 'starter');
23
-    }
20
+		// Note: this test requires the starter theme to be installed
21
+		Config::modify()->set(SSViewer::class, 'themes', ['starter', '$default']);
22
+		Config::modify()->set(SSViewer::class, 'theme', 'starter');
23
+	}
24 24
 
25
-    public function testSettingDateFiltersInReverseOrderShowsMessage()
26
-    {
27
-        /** @var EventHolder $holder */
28
-        $holder = $this->objFromFixture(EventHolder::class, 'EventHolder1');
25
+	public function testSettingDateFiltersInReverseOrderShowsMessage()
26
+	{
27
+		/** @var EventHolder $holder */
28
+		$holder = $this->objFromFixture(EventHolder::class, 'EventHolder1');
29 29
 
30
-        $result = $this->get($holder->Link() . '?from=2018-01-10&to=2018-01-01');
30
+		$result = $this->get($holder->Link() . '?from=2018-01-10&to=2018-01-01');
31 31
 
32
-        $this->assertContains('Filter has been applied with the dates reversed', $result->getBody());
33
-    }
32
+		$this->assertContains('Filter has been applied with the dates reversed', $result->getBody());
33
+	}
34 34
 
35
-    public function testSettingFromButNotToDateShowsMessage()
36
-    {
37
-        /** @var EventHolder $holder */
38
-        $holder = $this->objFromFixture(EventHolder::class, 'EventHolder1');
35
+	public function testSettingFromButNotToDateShowsMessage()
36
+	{
37
+		/** @var EventHolder $holder */
38
+		$holder = $this->objFromFixture(EventHolder::class, 'EventHolder1');
39 39
 
40
-        $result = $this->get($holder->Link() . '?from=2018-01-10');
40
+		$result = $this->get($holder->Link() . '?from=2018-01-10');
41 41
 
42
-        $this->assertContains('Filtered by a single date', $result->getBody());
43
-    }
42
+		$this->assertContains('Filtered by a single date', $result->getBody());
43
+	}
44 44
 }
Please login to merge, or discard this patch.
tests/PageTypes/SitemapPageTest.php 1 patch
Indentation   +19 added lines, -19 removed lines patch added patch discarded remove patch
@@ -9,27 +9,27 @@
 block discarded – undo
9 9
 
10 10
 class SitemapPageTest extends FunctionalTest
11 11
 {
12
-    protected static $fixture_file = 'SitemapPageTest.yml';
12
+	protected static $fixture_file = 'SitemapPageTest.yml';
13 13
 
14
-    protected static $use_draft_site = true;
14
+	protected static $use_draft_site = true;
15 15
 
16
-    protected function setUp()
17
-    {
18
-        parent::setUp();
16
+	protected function setUp()
17
+	{
18
+		parent::setUp();
19 19
 
20
-        Config::modify()->set(SSViewer::class, 'themes', ['starter', '$default']);
21
-        Config::modify()->set(SSViewer::class, 'theme', 'starter');
22
-    }
20
+		Config::modify()->set(SSViewer::class, 'themes', ['starter', '$default']);
21
+		Config::modify()->set(SSViewer::class, 'theme', 'starter');
22
+	}
23 23
 
24
-    /**
25
-     * Note: this test depends on the "starter" theme being installed and configured as default
26
-     */
27
-    public function testSitemapShowsNavigationTitleNotNormalTitle()
28
-    {
29
-        $response = $this->get('sitemap');
30
-        $parser = new CSSContentParser($response->getBody());
31
-        $elements = $parser->getBySelector('.sitemap li.first .sitemap-link');
32
-        $this->assertNotEmpty($elements);
33
-        $this->assertEquals('Top page nav 1', (string) $elements[0]);
34
-    }
24
+	/**
25
+	 * Note: this test depends on the "starter" theme being installed and configured as default
26
+	 */
27
+	public function testSitemapShowsNavigationTitleNotNormalTitle()
28
+	{
29
+		$response = $this->get('sitemap');
30
+		$parser = new CSSContentParser($response->getBody());
31
+		$elements = $parser->getBySelector('.sitemap li.first .sitemap-link');
32
+		$this->assertNotEmpty($elements);
33
+		$this->assertEquals('Top page nav 1', (string) $elements[0]);
34
+	}
35 35
 }
Please login to merge, or discard this patch.
src/PageTypes/BasePageController.php 1 patch
Indentation   +10 added lines, -10 removed lines patch added patch discarded remove patch
@@ -7,15 +7,15 @@
 block discarded – undo
7 7
 
8 8
 class BasePageController extends ContentController
9 9
 {
10
-    /**
11
-     * Provide current year.
12
-     */
13
-    public function CurrentDatetime()
14
-    {
15
-        return DBDatetime::now();
16
-    }
10
+	/**
11
+	 * Provide current year.
12
+	 */
13
+	public function CurrentDatetime()
14
+	{
15
+		return DBDatetime::now();
16
+	}
17 17
 
18
-    public function getRSSLink()
19
-    {
20
-    }
18
+	public function getRSSLink()
19
+	{
20
+	}
21 21
 }
Please login to merge, or discard this patch.
tests/Report/CwpStatsReportTest.php 1 patch
Indentation   +27 added lines, -27 removed lines patch added patch discarded remove patch
@@ -9,35 +9,35 @@
 block discarded – undo
9 9
 
10 10
 class CwpStatsReportTest extends SapphireTest
11 11
 {
12
-    protected static $fixture_file = 'CwpStatsReportTest.yml';
12
+	protected static $fixture_file = 'CwpStatsReportTest.yml';
13 13
 
14
-    public function testCount()
15
-    {
16
-        // Publish all pages apart from page3.
17
-        $this->objFromFixture(Page::class, 'page1')->publishRecursive();
18
-        $this->objFromFixture(Page::class, 'page2')->publishRecursive();
19
-        $this->objFromFixture(Page::class, 'page3')->publishRecursive();
14
+	public function testCount()
15
+	{
16
+		// Publish all pages apart from page3.
17
+		$this->objFromFixture(Page::class, 'page1')->publishRecursive();
18
+		$this->objFromFixture(Page::class, 'page2')->publishRecursive();
19
+		$this->objFromFixture(Page::class, 'page3')->publishRecursive();
20 20
 
21
-        // Add page5s to a subsite, if the module is installed.
22
-        $page5s = $this->objFromFixture(Page::class, 'page5s');
23
-        if (class_exists(Subsite::class)) {
24
-            $subsite = Subsite::create();
25
-            $subsite->Title = 'subsite';
26
-            $subsite->write();
21
+		// Add page5s to a subsite, if the module is installed.
22
+		$page5s = $this->objFromFixture(Page::class, 'page5s');
23
+		if (class_exists(Subsite::class)) {
24
+			$subsite = Subsite::create();
25
+			$subsite->Title = 'subsite';
26
+			$subsite->write();
27 27
 
28
-            $page5s->SubsiteID = $subsite->ID;
29
-            $page5s->write();
30
-        }
31
-        $page5s->publishRecursive();
28
+			$page5s->SubsiteID = $subsite->ID;
29
+			$page5s->write();
30
+		}
31
+		$page5s->publishRecursive();
32 32
 
33
-        $report = CwpStatsReport::create();
34
-        $records = $report->sourceRecords([])->toArray();
35
-        $i = 0;
36
-        $this->assertEquals($records[$i++]['Count'], 4, 'Four pages in total, across locales, subsites, live only.');
37
-        if (class_exists(Subsite::class)) {
38
-            $this->assertEquals($records[$i++]['Count'], 3, 'Three pages in the main site, if subsites installed.');
39
-            $this->assertEquals($records[$i++]['Count'], 1, 'One page in the subsite, if subsites installed');
40
-        }
41
-        $this->assertEquals($records[$i++]['Count'], 1, 'One file in total.');
42
-    }
33
+		$report = CwpStatsReport::create();
34
+		$records = $report->sourceRecords([])->toArray();
35
+		$i = 0;
36
+		$this->assertEquals($records[$i++]['Count'], 4, 'Four pages in total, across locales, subsites, live only.');
37
+		if (class_exists(Subsite::class)) {
38
+			$this->assertEquals($records[$i++]['Count'], 3, 'Three pages in the main site, if subsites installed.');
39
+			$this->assertEquals($records[$i++]['Count'], 1, 'One page in the subsite, if subsites installed');
40
+		}
41
+		$this->assertEquals($records[$i++]['Count'], 1, 'One file in total.');
42
+	}
43 43
 }
Please login to merge, or discard this patch.
src/Report/CwpStatsReport.php 2 patches
Indentation   +104 added lines, -104 removed lines patch added patch discarded remove patch
@@ -20,108 +20,108 @@
 block discarded – undo
20 20
  */
21 21
 class CwpStatsReport extends Report
22 22
 {
23
-    public function title()
24
-    {
25
-        return _t(__CLASS__ . '.Title', 'Summary statistics');
26
-    }
27
-
28
-    public function description()
29
-    {
30
-        return _t(
31
-            __CLASS__ . '.Description',
32
-            'This report provides various statistics for this site. The "total live page count" is the number that ' .
33
-                'can be compared against the instance size specifications.'
34
-        );
35
-    }
36
-
37
-    public function columns()
38
-    {
39
-        return [
40
-            'Name' => _t(__CLASS__ . '.Name', 'Name'),
41
-            'Count' => _t(__CLASS__ . '.Count', 'Count'),
42
-        ];
43
-    }
44
-
45
-    /**
46
-     * Manually create source records for the report. Agreggates cannot be provided as a column of a DataQuery result.
47
-     *
48
-     * {@inheritDoc}
49
-     */
50
-    public function sourceRecords($params = [], $sort = null, $limit = null)
51
-    {
52
-        $records = [];
53
-
54
-        // Get the query to apply across all variants: looks at all subsites, translations, live stage only.
55
-        $crossVariant = (function ($dataQuery) {
56
-            $params = [
57
-                'Subsite.filter' => false,
58
-                'Versioned.mode' => 'stage',
59
-                'Versioned.stage' => Versioned::LIVE,
60
-            ];
61
-
62
-            return $dataQuery->setDataQueryParam($params);
63
-        });
64
-
65
-        // Total.
66
-        $records[] = [
67
-            'Name' => _t(
68
-                __CLASS__ . '.TotalPageCount',
69
-                'Total live page count, across all translations and subsites'
70
-            ),
71
-            'Count' => $crossVariant(SiteTree::get())->count(),
72
-        ];
73
-
74
-        if (class_exists(Subsite::class)) {
75
-            // Main site.
76
-            $records[] = [
77
-                'Name' => _t(__CLASS__ . '.PagesForMainSite', '- in the main site'),
78
-                'Count' => $crossVariant(SiteTree::get())
79
-                    ->filter(['SubsiteID' => 0])
80
-                    ->count(),
81
-            ];
82
-
83
-            // Per subsite.
84
-            $subsites = Subsite::get();
85
-            foreach ($subsites as $subsite) {
86
-                $records[] = [
87
-                    'Name' => _t(
88
-                        __CLASS__ . '.PagesForSubsite',
89
-                        "- in the subsite '{SubsiteTitle}'",
90
-                        ['SubsiteTitle' => $subsite->Title]
91
-                    ),
92
-                    'Count' => $crossVariant(SiteTree::get())
93
-                        ->filter(['SubsiteID' => $subsite->ID])
94
-                        ->count(),
95
-                ];
96
-            }
97
-        }
98
-
99
-        // Files.
100
-        $records[] = [
101
-            'Name' => _t(__CLASS__ . '.FileCount', 'File count'),
102
-            'Count' => File::get()
103
-                ->setDataQueryParam('Subsite.filter', false)
104
-                ->filter(['ClassName:not' => Folder::class])
105
-                ->count(),
106
-        ];
107
-
108
-        return ArrayList::create($records);
109
-    }
110
-
111
-    /**
112
-     * @return GridField
113
-     */
114
-    public function getReportField()
115
-    {
116
-        /** @var GridField $gridField */
117
-        $gridField = parent::getReportField();
118
-
119
-        /** @var GridFieldConfig $gridConfig */
120
-        $gridConfig = $gridField->getConfig();
121
-        $gridConfig->removeComponentsByType(GridFieldPrintButton::class);
122
-        $gridConfig->removeComponentsByType(GridFieldExportButton::class);
123
-        $gridConfig->removeComponentsByType(GridFieldSortableHeader::class);
124
-
125
-        return $gridField;
126
-    }
23
+	public function title()
24
+	{
25
+		return _t(__CLASS__ . '.Title', 'Summary statistics');
26
+	}
27
+
28
+	public function description()
29
+	{
30
+		return _t(
31
+			__CLASS__ . '.Description',
32
+			'This report provides various statistics for this site. The "total live page count" is the number that ' .
33
+				'can be compared against the instance size specifications.'
34
+		);
35
+	}
36
+
37
+	public function columns()
38
+	{
39
+		return [
40
+			'Name' => _t(__CLASS__ . '.Name', 'Name'),
41
+			'Count' => _t(__CLASS__ . '.Count', 'Count'),
42
+		];
43
+	}
44
+
45
+	/**
46
+	 * Manually create source records for the report. Agreggates cannot be provided as a column of a DataQuery result.
47
+	 *
48
+	 * {@inheritDoc}
49
+	 */
50
+	public function sourceRecords($params = [], $sort = null, $limit = null)
51
+	{
52
+		$records = [];
53
+
54
+		// Get the query to apply across all variants: looks at all subsites, translations, live stage only.
55
+		$crossVariant = (function ($dataQuery) {
56
+			$params = [
57
+				'Subsite.filter' => false,
58
+				'Versioned.mode' => 'stage',
59
+				'Versioned.stage' => Versioned::LIVE,
60
+			];
61
+
62
+			return $dataQuery->setDataQueryParam($params);
63
+		});
64
+
65
+		// Total.
66
+		$records[] = [
67
+			'Name' => _t(
68
+				__CLASS__ . '.TotalPageCount',
69
+				'Total live page count, across all translations and subsites'
70
+			),
71
+			'Count' => $crossVariant(SiteTree::get())->count(),
72
+		];
73
+
74
+		if (class_exists(Subsite::class)) {
75
+			// Main site.
76
+			$records[] = [
77
+				'Name' => _t(__CLASS__ . '.PagesForMainSite', '- in the main site'),
78
+				'Count' => $crossVariant(SiteTree::get())
79
+					->filter(['SubsiteID' => 0])
80
+					->count(),
81
+			];
82
+
83
+			// Per subsite.
84
+			$subsites = Subsite::get();
85
+			foreach ($subsites as $subsite) {
86
+				$records[] = [
87
+					'Name' => _t(
88
+						__CLASS__ . '.PagesForSubsite',
89
+						"- in the subsite '{SubsiteTitle}'",
90
+						['SubsiteTitle' => $subsite->Title]
91
+					),
92
+					'Count' => $crossVariant(SiteTree::get())
93
+						->filter(['SubsiteID' => $subsite->ID])
94
+						->count(),
95
+				];
96
+			}
97
+		}
98
+
99
+		// Files.
100
+		$records[] = [
101
+			'Name' => _t(__CLASS__ . '.FileCount', 'File count'),
102
+			'Count' => File::get()
103
+				->setDataQueryParam('Subsite.filter', false)
104
+				->filter(['ClassName:not' => Folder::class])
105
+				->count(),
106
+		];
107
+
108
+		return ArrayList::create($records);
109
+	}
110
+
111
+	/**
112
+	 * @return GridField
113
+	 */
114
+	public function getReportField()
115
+	{
116
+		/** @var GridField $gridField */
117
+		$gridField = parent::getReportField();
118
+
119
+		/** @var GridFieldConfig $gridConfig */
120
+		$gridConfig = $gridField->getConfig();
121
+		$gridConfig->removeComponentsByType(GridFieldPrintButton::class);
122
+		$gridConfig->removeComponentsByType(GridFieldExportButton::class);
123
+		$gridConfig->removeComponentsByType(GridFieldSortableHeader::class);
124
+
125
+		return $gridField;
126
+	}
127 127
 }
Please login to merge, or discard this patch.
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -52,7 +52,7 @@
 block discarded – undo
52 52
         $records = [];
53 53
 
54 54
         // Get the query to apply across all variants: looks at all subsites, translations, live stage only.
55
-        $crossVariant = (function ($dataQuery) {
55
+        $crossVariant = (function($dataQuery) {
56 56
             $params = [
57 57
                 'Subsite.filter' => false,
58 58
                 'Versioned.mode' => 'stage',
Please login to merge, or discard this patch.
src/Extensions/CustomSiteConfig.php 1 patch
Indentation   +49 added lines, -49 removed lines patch added patch discarded remove patch
@@ -12,58 +12,58 @@
 block discarded – undo
12 12
  */
13 13
 class CustomSiteConfig extends DataExtension
14 14
 {
15
-    private static $db = array(
16
-        'GACode' => 'Varchar(16)',
17
-        'FacebookURL' => 'Varchar(256)', // multitude of ways to link to Facebook accounts, best to leave it open.
18
-        'TwitterUsername' => 'Varchar(16)', // max length of Twitter username 15
19
-    );
15
+	private static $db = array(
16
+		'GACode' => 'Varchar(16)',
17
+		'FacebookURL' => 'Varchar(256)', // multitude of ways to link to Facebook accounts, best to leave it open.
18
+		'TwitterUsername' => 'Varchar(16)', // max length of Twitter username 15
19
+	);
20 20
 
21
-    public function updateCMSFields(FieldList $fields)
22
-    {
23
-        $fields->addFieldToTab(
24
-            'Root.Main',
25
-            $gaCode = TextField::create(
26
-                'GACode',
27
-                _t(__CLASS__ . '.GaField', 'Google Analytics account')
28
-            )
29
-        );
21
+	public function updateCMSFields(FieldList $fields)
22
+	{
23
+		$fields->addFieldToTab(
24
+			'Root.Main',
25
+			$gaCode = TextField::create(
26
+				'GACode',
27
+				_t(__CLASS__ . '.GaField', 'Google Analytics account')
28
+			)
29
+		);
30 30
 
31
-        $gaCode->setRightTitle(
32
-            DBField::create_field('HTMLFragment', _t(
33
-                __CLASS__ . '.GaFieldDesc',
34
-                'Account number to be used all across the site (in the format <strong>UA-XXXXX-X</strong>)'
35
-            ))
36
-        );
31
+		$gaCode->setRightTitle(
32
+			DBField::create_field('HTMLFragment', _t(
33
+				__CLASS__ . '.GaFieldDesc',
34
+				'Account number to be used all across the site (in the format <strong>UA-XXXXX-X</strong>)'
35
+			))
36
+		);
37 37
 
38
-        $fields->findOrMakeTab('Root.SocialMedia', _t(__CLASS__ . '.SocialMediaTab', 'Social Media'));
38
+		$fields->findOrMakeTab('Root.SocialMedia', _t(__CLASS__ . '.SocialMediaTab', 'Social Media'));
39 39
 
40
-        $fields->addFieldToTab(
41
-            'Root.SocialMedia',
42
-            $facebookURL = TextField::create(
43
-                'FacebookURL',
44
-                _t(__CLASS__ . '.FbField', 'Facebook UID or username')
45
-            )
46
-        );
47
-        $facebookURL->setRightTitle(
48
-            DBField::create_field('HTMLFragment', _t(
49
-                __CLASS__ . '.FbFieldDesc',
50
-                'Facebook link (everything after the "http://facebook.com/", eg http://facebook.com/'
51
-                . '<strong>username</strong> or http://facebook.com/<strong>pages/108510539573</strong>)'
52
-            ))
53
-        );
40
+		$fields->addFieldToTab(
41
+			'Root.SocialMedia',
42
+			$facebookURL = TextField::create(
43
+				'FacebookURL',
44
+				_t(__CLASS__ . '.FbField', 'Facebook UID or username')
45
+			)
46
+		);
47
+		$facebookURL->setRightTitle(
48
+			DBField::create_field('HTMLFragment', _t(
49
+				__CLASS__ . '.FbFieldDesc',
50
+				'Facebook link (everything after the "http://facebook.com/", eg http://facebook.com/'
51
+				. '<strong>username</strong> or http://facebook.com/<strong>pages/108510539573</strong>)'
52
+			))
53
+		);
54 54
 
55
-        $fields->addFieldToTab(
56
-            'Root.SocialMedia',
57
-            $twitterUsername = TextField::create(
58
-                'TwitterUsername',
59
-                _t(__CLASS__ . '.TwitterField', 'Twitter username')
60
-            )
61
-        );
62
-        $twitterUsername->setRightTitle(
63
-            DBField::create_field('HTMLFragment', _t(
64
-                __CLASS__ . '.TwitterFieldDesc',
65
-                'Twitter username (eg, http://twitter.com/<strong>username</strong>)'
66
-            ))
67
-        );
68
-    }
55
+		$fields->addFieldToTab(
56
+			'Root.SocialMedia',
57
+			$twitterUsername = TextField::create(
58
+				'TwitterUsername',
59
+				_t(__CLASS__ . '.TwitterField', 'Twitter username')
60
+			)
61
+		);
62
+		$twitterUsername->setRightTitle(
63
+			DBField::create_field('HTMLFragment', _t(
64
+				__CLASS__ . '.TwitterFieldDesc',
65
+				'Twitter username (eg, http://twitter.com/<strong>username</strong>)'
66
+			))
67
+		);
68
+	}
69 69
 }
Please login to merge, or discard this patch.
tests/Extensions/WorkflowDefinitionExtensionTest.php 1 patch
Indentation   +34 added lines, -34 removed lines patch added patch discarded remove patch
@@ -15,38 +15,38 @@
 block discarded – undo
15 15
 class WorkflowDefinitionExtensionTest extends FunctionalTest
16 16
 {
17 17
 
18
-    /**
19
-     * @var Boolean If set to TRUE, this will force a test database to be generated
20
-     * in {@link setUp()}. Note that this flag is overruled by the presence of a
21
-     * {@link $fixture_file}, which always forces a database build.
22
-     */
23
-    protected $usesDatabase = true;
24
-
25
-    /**
26
-     * Tests the config option that controls the creation of a default workflow definition
27
-     *
28
-     * @return void
29
-     */
30
-    public function testCreateDefaultWorkflowTest()
31
-    {
32
-        if (!class_exists(WorkflowDefinition::class)) {
33
-            $this->markTestSkipped('This test requires the advancedworkflow module to be installed');
34
-        }
35
-
36
-        DB::quiet();
37
-
38
-        // test disabling the default workflow definition
39
-        Config::modify()->set(CwpWorkflowDefinitionExtension::class, 'create_default_workflow', false);
40
-        $workflowExtn = Injector::inst()->create(CwpWorkflowDefinitionExtension::class);
41
-        $workflowExtn->requireDefaultRecords();
42
-        $definition = WorkflowDefinition::get()->first();
43
-        $this->assertNull($definition);
44
-
45
-        // test enabling the default workflow definition
46
-        Config::modify()->set(CwpWorkflowDefinitionExtension::class, 'create_default_workflow', true);
47
-        $workflowExtn = Injector::inst()->create(CwpWorkflowDefinitionExtension::class);
48
-        $workflowExtn->requireDefaultRecords();
49
-        $definition = WorkflowDefinition::get()->first();
50
-        $this->assertNotNull($definition);
51
-    }
18
+	/**
19
+	 * @var Boolean If set to TRUE, this will force a test database to be generated
20
+	 * in {@link setUp()}. Note that this flag is overruled by the presence of a
21
+	 * {@link $fixture_file}, which always forces a database build.
22
+	 */
23
+	protected $usesDatabase = true;
24
+
25
+	/**
26
+	 * Tests the config option that controls the creation of a default workflow definition
27
+	 *
28
+	 * @return void
29
+	 */
30
+	public function testCreateDefaultWorkflowTest()
31
+	{
32
+		if (!class_exists(WorkflowDefinition::class)) {
33
+			$this->markTestSkipped('This test requires the advancedworkflow module to be installed');
34
+		}
35
+
36
+		DB::quiet();
37
+
38
+		// test disabling the default workflow definition
39
+		Config::modify()->set(CwpWorkflowDefinitionExtension::class, 'create_default_workflow', false);
40
+		$workflowExtn = Injector::inst()->create(CwpWorkflowDefinitionExtension::class);
41
+		$workflowExtn->requireDefaultRecords();
42
+		$definition = WorkflowDefinition::get()->first();
43
+		$this->assertNull($definition);
44
+
45
+		// test enabling the default workflow definition
46
+		Config::modify()->set(CwpWorkflowDefinitionExtension::class, 'create_default_workflow', true);
47
+		$workflowExtn = Injector::inst()->create(CwpWorkflowDefinitionExtension::class);
48
+		$workflowExtn->requireDefaultRecords();
49
+		$definition = WorkflowDefinition::get()->first();
50
+		$this->assertNotNull($definition);
51
+	}
52 52
 }
Please login to merge, or discard this patch.
tests/Tasks/PopulateThemeSampleDataTaskTest.php 1 patch
Indentation   +46 added lines, -46 removed lines patch added patch discarded remove patch
@@ -10,50 +10,50 @@
 block discarded – undo
10 10
 
11 11
 class PopulateThemeSampleDataTaskTest extends SapphireTest
12 12
 {
13
-    protected $usesDatabase = true;
14
-
15
-    /**
16
-     * Ensure that the "contact" user form is only created once
17
-     */
18
-    public function testOnlyCreateContactFormOnce()
19
-    {
20
-        if (!class_exists(UserDefinedForm::class)) {
21
-            $this->markTestSkipped('This test requires the userforms module to be installed');
22
-        }
23
-
24
-        $createdMessage = 'Created "contact" UserDefinedForm';
25
-
26
-        $task = new PopulateThemeSampleDataTask;
27
-
28
-        // Run the task
29
-        $this->assertContains($createdMessage, $this->bufferedTask($task));
30
-
31
-        // Run a second time
32
-        $this->assertNotContains($createdMessage, $this->bufferedTask($task));
33
-
34
-        // Change the page name
35
-        $form = UserDefinedForm::get()->filter('URLSegment', 'contact')->first();
36
-        $form->URLSegment = 'testing';
37
-        $form->write();
38
-
39
-        // Ensure the old version is still detected in draft, so not recreated
40
-        $this->assertNotContains($createdMessage, $this->bufferedTask($task));
41
-
42
-        // Delete the page, then ensure it's recreated again (DataObject::delete will remove staged versions)
43
-        $form->delete();
44
-        $this->assertContains($createdMessage, $this->bufferedTask($task));
45
-    }
46
-
47
-    /**
48
-     * Run a BuildTask while buffering its output, and return the result
49
-     *
50
-     * @param  BuildTask $task
51
-     * @return string
52
-     */
53
-    protected function bufferedTask(BuildTask $task)
54
-    {
55
-        ob_start();
56
-        $task->run(new HTTPRequest('GET', '/'));
57
-        return ob_get_clean();
58
-    }
13
+	protected $usesDatabase = true;
14
+
15
+	/**
16
+	 * Ensure that the "contact" user form is only created once
17
+	 */
18
+	public function testOnlyCreateContactFormOnce()
19
+	{
20
+		if (!class_exists(UserDefinedForm::class)) {
21
+			$this->markTestSkipped('This test requires the userforms module to be installed');
22
+		}
23
+
24
+		$createdMessage = 'Created "contact" UserDefinedForm';
25
+
26
+		$task = new PopulateThemeSampleDataTask;
27
+
28
+		// Run the task
29
+		$this->assertContains($createdMessage, $this->bufferedTask($task));
30
+
31
+		// Run a second time
32
+		$this->assertNotContains($createdMessage, $this->bufferedTask($task));
33
+
34
+		// Change the page name
35
+		$form = UserDefinedForm::get()->filter('URLSegment', 'contact')->first();
36
+		$form->URLSegment = 'testing';
37
+		$form->write();
38
+
39
+		// Ensure the old version is still detected in draft, so not recreated
40
+		$this->assertNotContains($createdMessage, $this->bufferedTask($task));
41
+
42
+		// Delete the page, then ensure it's recreated again (DataObject::delete will remove staged versions)
43
+		$form->delete();
44
+		$this->assertContains($createdMessage, $this->bufferedTask($task));
45
+	}
46
+
47
+	/**
48
+	 * Run a BuildTask while buffering its output, and return the result
49
+	 *
50
+	 * @param  BuildTask $task
51
+	 * @return string
52
+	 */
53
+	protected function bufferedTask(BuildTask $task)
54
+	{
55
+		ob_start();
56
+		$task->run(new HTTPRequest('GET', '/'));
57
+		return ob_get_clean();
58
+	}
59 59
 }
Please login to merge, or discard this patch.