1
0
mirror of https://github.com/BookStackApp/BookStack.git synced 2024-10-30 07:32:39 +01:00

Updated page nav header shift logic to be accurate

Added tests to cover.
Fixes #542
This commit is contained in:
Dan Brown 2019-06-16 11:32:38 +01:00
parent 56e31a5df7
commit fbb2b7ac6a
No known key found for this signature in database
GPG Key ID: 46D9F943C24A2EF9
3 changed files with 51 additions and 5 deletions

View File

@ -438,10 +438,10 @@ class PageRepo extends EntityRepo
return mb_strlen($header['text']) > 0; return mb_strlen($header['text']) > 0;
}); });
// Normalise headers if only smaller headers have been used // Shift headers if only smaller headers have been used
$minLevel = $tree->pluck('level')->min(); $levelChange = ($tree->pluck('level')->min() - 1);
$tree = $tree->map(function ($header) use ($minLevel) { $tree = $tree->map(function ($header) use ($levelChange) {
$header['level'] -= ($minLevel - 2); $header['level'] -= ($levelChange);
return $header; return $header;
}); });

View File

@ -108,7 +108,7 @@
padding-left: $nav-indent; padding-left: $nav-indent;
} }
.h2 { .h2 {
padding-left: $nav-indent; padding-left: $nav-indent * 1.5;
} }
.h3 { .h3 {
padding-left: $nav-indent * 2; padding-left: $nav-indent * 2;

View File

@ -16,6 +16,32 @@ class PageRepoTest extends TestCase
$this->pageRepo = app()->make(PageRepo::class); $this->pageRepo = app()->make(PageRepo::class);
} }
public function test_get_page_nav_sets_correct_properties()
{
$content = '<h1 id="testa">Hello</h1><h2 id="testb">There</h2><h3 id="testc">Donkey</h3>';
$navMap = $this->pageRepo->getPageNav($content);
$this->assertCount(3, $navMap);
$this->assertArraySubset([
'nodeName' => 'h1',
'link' => '#testa',
'text' => 'Hello',
'level' => 1,
], $navMap[0]);
$this->assertArraySubset([
'nodeName' => 'h2',
'link' => '#testb',
'text' => 'There',
'level' => 2,
], $navMap[1]);
$this->assertArraySubset([
'nodeName' => 'h3',
'link' => '#testc',
'text' => 'Donkey',
'level' => 3,
], $navMap[2]);
}
public function test_get_page_nav_does_not_show_empty_titles() public function test_get_page_nav_does_not_show_empty_titles()
{ {
$content = '<h1 id="testa">Hello</h1><h2 id="testb">&nbsp;</h2><h3 id="testc"></h3>'; $content = '<h1 id="testa">Hello</h1><h2 id="testb">&nbsp;</h2><h3 id="testc"></h3>';
@ -29,4 +55,24 @@ class PageRepoTest extends TestCase
], $navMap[0]); ], $navMap[0]);
} }
public function test_get_page_nav_shifts_headers_if_only_smaller_ones_are_used()
{
$content = '<h4 id="testa">Hello</h4><h5 id="testb">There</h5><h6 id="testc">Donkey</h6>';
$navMap = $this->pageRepo->getPageNav($content);
$this->assertCount(3, $navMap);
$this->assertArraySubset([
'nodeName' => 'h4',
'level' => 1,
], $navMap[0]);
$this->assertArraySubset([
'nodeName' => 'h5',
'level' => 2,
], $navMap[1]);
$this->assertArraySubset([
'nodeName' => 'h6',
'level' => 3,
], $navMap[2]);
}
} }