Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Improve internal page model structure #122

Merged
merged 58 commits into from
Jul 1, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
58 commits
Select commit Hold shift + click to select a range
f2059f4
Add AbstractPage::$outputDirectory property
caendesilva Jul 1, 2022
c9c78ea
Add PHPDocs
caendesilva Jul 1, 2022
1043f28
Add explicit property getters to contract for page models
caendesilva Jul 1, 2022
80dfc88
Implement the property getters
caendesilva Jul 1, 2022
968f324
Try marking the getters as final
caendesilva Jul 1, 2022
aef1023
Move PHPDocs to contract
caendesilva Jul 1, 2022
49e23b0
Format the file extension return value to ensure it is prefixed with …
caendesilva Jul 1, 2022
3ce9957
Replace type annotated return value PageContract to static
caendesilva Jul 1, 2022
0d47ffc
Replace type annotated return value AbstractPage to static
caendesilva Jul 1, 2022
e8549be
Refactor to use the new source directory getter methods
caendesilva Jul 1, 2022
2b6e4db
Refactor to use the new file extension getter methods
caendesilva Jul 1, 2022
3035048
Refactor to use the new parser class getter method
caendesilva Jul 1, 2022
0a2ea44
Add new method to get an instantiated parser class
caendesilva Jul 1, 2022
707195c
Fix recursion whoopsie
caendesilva Jul 1, 2022
33ee9e3
Remove redundant basename function call
caendesilva Jul 1, 2022
ed465f1
Refactor to use the new page parser getter
caendesilva Jul 1, 2022
d0a83f2
Update BladePage to implement the PageParserContract
caendesilva Jul 1, 2022
99e016b
Reorder helper methods
caendesilva Jul 1, 2022
2191345
Refactor to use sibling helpers to reduce duplicate code
caendesilva Jul 1, 2022
8f3c318
Trim trailing path separators to ensure consistent and predictable state
caendesilva Jul 1, 2022
926d6dd
Create helper to qualify a page basename into a referenceable path
caendesilva Jul 1, 2022
0fc6e1e
Replace string concatenation with model qualifier helper
caendesilva Jul 1, 2022
0570c84
Add getOutputLocation helper to qualify the output path
caendesilva Jul 1, 2022
f422101
Specify default output directories
caendesilva Jul 1, 2022
e82b378
Fix bug, output path should obviously not include source file extension
caendesilva Jul 1, 2022
d89f250
Deprecate DocumentationPage::getDocumentationOutputPath()
caendesilva Jul 1, 2022
ac87d8b
A temporary compat helper until the service provider bootstraps the o…
caendesilva Jul 1, 2022
9db020d
Use the new output location helper to get the output path
caendesilva Jul 1, 2022
b99598e
Dynamically create the needed directories
caendesilva Jul 1, 2022
911c289
Remove unused location parameter
caendesilva Jul 1, 2022
363195f
Rename registerDefaultDirectories to registerSourceDirectories
caendesilva Jul 1, 2022
b02f7d7
Deprecate RegistersDefaultDirectories.php pending rename
caendesilva Jul 1, 2022
d8fcc86
Improve documentation
caendesilva Jul 1, 2022
a3413b7
Create registerOutputDirectories helper
caendesilva Jul 1, 2022
46e5627
Trim the registered location path
caendesilva Jul 1, 2022
e76a1f0
Bind the documentation site output path in the service provider
caendesilva Jul 1, 2022
7d72668
Remove unneeded temporary compatibility helpers
caendesilva Jul 1, 2022
6a015ef
Reregister the service provider to pick up the new config during testing
caendesilva Jul 1, 2022
2fa7ee0
Add getCurrentPagePath to contract
caendesilva Jul 1, 2022
e9b80f2
Update getCurrentPagePath implementation to be dynamic
caendesilva Jul 1, 2022
b8946f8
Add the output directory property to test classes
caendesilva Jul 1, 2022
578bf7b
Move shared test code into helper
caendesilva Jul 1, 2022
9e4d4ed
Reregister the service provider to pick up the new config during testing
caendesilva Jul 1, 2022
99a99d6
Remove now redundant method overrides
caendesilva Jul 1, 2022
65792e2
Deprecate Hyde::getDocumentationOutputDirectory()
caendesilva Jul 1, 2022
b76d8c7
Deprecate Hyde::docsIndexPath()
caendesilva Jul 1, 2022
aebadc4
Replace configuration call with canonical model property value
caendesilva Jul 1, 2022
a2a2e27
Update PHPDoc formatting, add return value
caendesilva Jul 1, 2022
7515387
Format and add inheritDoc annotations
caendesilva Jul 1, 2022
51d2b8d
Add AbstractPage::getOutputPath() helper
caendesilva Jul 1, 2022
d646d61
Use the getOutputPath helper when saving the file
caendesilva Jul 1, 2022
6e44a83
Apply fixes from StyleCI
StyleCIBot Jul 1, 2022
7aa064e
Replace trim with ltrim
caendesilva Jul 1, 2022
c8f6dfe
Collapse PHPDoc
caendesilva Jul 1, 2022
9e2cb26
Create AbstractPageTest.php
caendesilva Jul 1, 2022
d205175
Add the test stubs
caendesilva Jul 1, 2022
f00dcfc
Write tests to cover the AbstractPage class
caendesilva Jul 1, 2022
7ea44d3
Apply fixes from StyleCI
StyleCIBot Jul 1, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Rename registerDefaultDirectories to registerSourceDirectories
  • Loading branch information
caendesilva committed Jul 1, 2022
commit 363195f408ff20ff9fe82589b8cbe37a04b46abc
2 changes: 1 addition & 1 deletion docs/advanced-customization.md
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ use Hyde\Framework\Concerns\RegistersDefaultDirectories;

public function register(): void
{
$this->registerDefaultDirectories([
$this->registerSourceDirectories([
BladePage::class => '_pages',
MarkdownPage::class => '_pages',
MarkdownPost::class => '_posts',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ trait RegistersDefaultDirectories
* @param array $directoryMapping
* @return void
*/
protected function registerDefaultDirectories(array $directoryMapping): void
protected function registerSourceDirectories(array $directoryMapping): void
{
foreach ($directoryMapping as $class => $location) {
/** @var AbstractPage $class */
Expand Down
2 changes: 1 addition & 1 deletion packages/framework/src/HydeServiceProvider.php
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ function () {

$this->app->singleton(AssetServiceContract::class, AssetService::class);

$this->registerDefaultDirectories([
$this->registerSourceDirectories([
BladePage::class => '_pages',
MarkdownPage::class => '_pages',
MarkdownPost::class => '_posts',
Expand Down