html .= "\n";
// page article: cas particulier où l'article est greffé sur main
if(Model::$page_path->getLast()->getEndOfPath() === 'article'){
// pas censé arriver
if(!isset($_GET['id'])){
header('Location: ' . new URL);
die;
}
// nouvel article
if($node->getAdoptedChild() == null){
$date = new \DateTime;
$article = new Article('', $date);
$new = new Node('new', [], 0, null, null, $article);
}
// modification
else{
$new = $node->getAdoptedChild();
}
//$builder_name = $this->snakeToPascalCase($new->getName()) . 'Builder';
$builder_name = 'NewBuilder';
$builder = new $builder_name($new);
$this->html .= $builder->render();
}
else{
// si action = "modif_page", affiche des commandes supplémentaires
if($_SESSION['admin'] && self::$modif_mode){
// ajouter un contrôle du champ in_menu
$this->viewEditBlocks($node);
}
// dans tous les cas
$this->useChildrenBuilder($node);
}
$this->html .= "\n";
}
// mode modification de page uniquement
private function viewEditBlocks($node): void
{
$options = '';
foreach(Blocks::$blocks as $key => $value){
$options .= '\n";
}
// ceci pourrait être déplacé au début des blocs
$bloc_edit = '';
foreach($node->getChildren() as $child_node){
// ordre des articles 'news'
if($child_node->getName() === 'news_block'){
$order = $child_node->getNodeData()->getChronoOrder() ? 'chrono' : 'antichrono';
}
// présentation par défaut
if(Blocks::hasPresentation($child_node->getName()) && $child_node->getNodeData()->getPresentation() === null){
$child_node->getNodeData()->setPresentation('full_width'); // pas de persistence ici
}
ob_start();
require self::VIEWS_PATH . 'modify_block.php';
$bloc_edit .= ob_get_clean();
}
ob_start();
require self::VIEWS_PATH . 'modify_page.php';
$this->html .= ob_get_clean();
}
// utilisée dans modify_block.php
private function makePresentationOptions(string $presentation): string
{
$options = '';
foreach(Blocks::$presentations as $key => $value){
$options .= '';
}
return $options;
}
}