Fix view skeleton include bug and add RouteURL method. #2

Merged
Benjamin merged 1 commits from BenBack into master 2026-03-20 13:33:59 +00:00
6 changed files with 69 additions and 9 deletions

View File

@@ -19,6 +19,7 @@ abstract class Controller {
$defaults = [ $defaults = [
'routeController' => static::class, 'routeController' => static::class,
'routeMethods' => [ 'GET' ], 'routeMethods' => [ 'GET' ],
'pageHeadTitle' => 'Page',
]; ];
$args = array_merge($defaults, $args); $args = array_merge($defaults, $args);

View File

@@ -14,8 +14,8 @@ class PagesController extends Controller {
public static function defineRoutes(): array public static function defineRoutes(): array
{ {
return [ return [
self::Route( routeUrl: '/', routeName: 'Homepage', routeAction: 'index' ), self::Route( routeUrl: '/', routeName: 'home', routeAction: 'index', pageHeadTitle: "Home Page" ),
self::Route( routeUrl: '/test/{string}/baba', routeName: 'test', routeAction: 'test' ), self::Route( routeUrl: '/test/{int}/', routeName: 'test', routeAction: 'test' ),
]; ];
} }

View File

@@ -13,19 +13,30 @@ final class Route {
public private(set) string $routeController; public private(set) string $routeController;
public private(set) string $routeAction; public private(set) string $routeAction;
public private(set) array $routeMethods; public private(set) array $routeMethods;
public private(set) string $pageHeadTitle;
/**
* @param string $routeUrl Le chemin vers la route.
* @param string $routeName Le nom de la route.
* @param string $routeController Le controller qui va interpréter cette route.
* @param string $routeAction L'action du controller qui va interpréter cette route.
* @param array $routeMethods Une liste de methodes GET, POST que la page accepte.
* @param string $pageHeadTitle Le nom de la page qui sera affiché dans <title></title>.
*/
public function __construct( public function __construct(
string $routeUrl, string $routeUrl,
string $routeName, string $routeName,
string $routeController, string $routeController,
string $routeAction, string $routeAction,
array $routeMethods array $routeMethods,
string $pageHeadTitle,
){ ){
$this->routeUrl = $routeUrl; $this->routeUrl = $routeUrl;
$this->routeName = $routeName; $this->routeName = $routeName;
$this->routeController = $routeController; $this->routeController = $routeController;
$this->routeAction = $routeAction; $this->routeAction = $routeAction;
$this->routeMethods = $routeMethods; $this->routeMethods = $routeMethods;
$this->pageHeadTitle = $pageHeadTitle;
} }
} }

View File

@@ -129,10 +129,12 @@ final class Router {
private static function clientRouteExist(): Route|bool { private static function clientRouteExist(): Route|bool {
$clientRouteName = trim( self::$clientRouteString, '/' ); $clientRouteName = trim( self::$clientRouteString, '/' );
foreach( self::$routes as $route ){ foreach( self::$routes as $route ){
$routeName = self::getRegexRoute( $route ); $routeName = self::getRegexRoute( $route );
if( preg_match( $routeName, $clientRouteName, $matches ) ){ if( preg_match( $routeName, $clientRouteName, $matches ) ){
array_shift( $matches ); array_shift( $matches ); // On enlève la chaine complète.
self::$clientRouteArguments = $matches; self::$clientRouteArguments = $matches;
return $route; return $route;
} }
@@ -142,6 +144,12 @@ final class Router {
} }
/**
* Permet de remplacer les expressions définies dans la configuration par leurs équivalents Regex.
*
* @param Route $route
* @return string
*/
private static function getRegexRoute( Route $route ): string { private static function getRegexRoute( Route $route ): string {
$routeUrl = trim( $route->routeUrl, '/' ); $routeUrl = trim( $route->routeUrl, '/' );
foreach ( Kernel::$configs['route_arguments'] as $key => $value ){ foreach ( Kernel::$configs['route_arguments'] as $key => $value ){
@@ -161,4 +169,27 @@ final class Router {
new $controller()->$method( ...self::$clientRouteArguments); new $controller()->$method( ...self::$clientRouteArguments);
} }
/**
* Permet d'obtenir l'adresse du site vers une route spécifique.
*
* @param string $routeName Le nom de la route.
* @param ...$args - Les arguments de la route, si existants.
*
* @return string Renvoie l'URL demandé ou bien la racine du site si la route n'existe pas.
*/
public static function getRouteURL( string $routeName, ...$args ): string {
foreach( self::$routes as $route ){
if( $routeName === $route->routeName ){
$i = 0;
$routeUrl = preg_replace_callback( '/\{([^}]+)}/', function( $match ) use ( $args, &$i ){
return $args[$i++] ?? "";
}, $route->routeUrl);
return rtrim( Kernel::$configs['general']['website_url'] . $routeUrl, '/' );
}
}
return Kernel::$configs['general']['website_url'];
}
} }

View File

@@ -132,10 +132,10 @@ final class View {
} else { } else {
// Si on a un squelette, on charge tout le contenu de la vue enfante. // Si on a un squelette, on charge tout le contenu de la vue enfante.
$content = file_get_contents( self::VIEW_PATH . $this->viewName ); $contentName = $this->viewName;
// On démarre la vue du squelette. // On démarre la vue du squelette.
$base = new View( $this->skeleton, $this->viewArgs, skeleton: null, integratedContent: [ 'content' => $content ] ); $base = new View( $this->skeleton, $this->viewArgs, skeleton: null, integratedContent: [ 'content' => $contentName ] );
} }
@@ -154,7 +154,7 @@ final class View {
*/ */
public static function inject( string $integratedContentName ): void { public static function inject( string $integratedContentName ): void {
if( isset( self::$lastInstance->integratedContent[ $integratedContentName ] ) ) if( isset( self::$lastInstance->integratedContent[ $integratedContentName ] ) )
echo self::$lastInstance->integratedContent[ $integratedContentName ]; require self::VIEW_PATH . self::$lastInstance->integratedContent[ $integratedContentName ];
} }
/** /**
@@ -186,9 +186,25 @@ final class View {
} }
} }
/**
* Permet d'obtenir le titre de la page à mettre dans <title></title>
* @return string
*/
public static function getHeadTitle(): string { public static function getHeadTitle(): string {
$siteUrl = Kernel::$configs['general']['website_name']; $siteUrl = Kernel::$configs['general']['website_name'];
return Router::$clientRoute->routeName . ' - ' . $siteUrl; return Router::$clientRoute->pageHeadTitle . ' - ' . $siteUrl;
}
/**
* Permet d'obtenir une route
*
* @param string $routeName Le nom de la route.
* @param ...$args - Les arguments de la route, si existant.
*
* @return void Affiche uniquement.
*/
public static function routeUrl( string $routeName, ...$args ): void {
echo Router::getRouteURL( $routeName, ...$args );
} }
} }

View File

@@ -1 +1,2 @@
<h1>Coucou</h1> <h1>Coucou</h1>
<?php echo \App\Http\Router::getRouteURL( 'test', 3 ); ?>