diff options
Diffstat (limited to 'src/controller/post.php')
| -rw-r--r-- | src/controller/post.php | 26 |
1 files changed, 25 insertions, 1 deletions
diff --git a/src/controller/post.php b/src/controller/post.php index 3ba0656..7e6ed53 100644 --- a/src/controller/post.php +++ b/src/controller/post.php | |||
| @@ -132,8 +132,32 @@ if($_SERVER['REQUEST_METHOD'] === 'POST' && $_SESSION['admin'] === true) | |||
| 132 | $main = $director->getNode(); | 132 | $main = $director->getNode(); |
| 133 | $position = count($main->getChildren()) + 1; // position dans la fraterie | 133 | $position = count($main->getChildren()) + 1; // position dans la fraterie |
| 134 | 134 | ||
| 135 | $blocs_true_names = ['blog', 'grid', 'calendar', 'galery', 'form']; // même liste dans FormBuilder.php | ||
| 136 | if(!in_array($_POST["bloc_select"], $blocs_true_names, true)) // 3è param: contrôle du type | ||
| 137 | { | ||
| 138 | header("Location: " . new URL(['page' => $_GET['page'], 'error' => 'bad_bloc_type'])); | ||
| 139 | die; | ||
| 140 | } | ||
| 141 | |||
| 142 | if($_POST["bloc_select"] === 'calendar'){ | ||
| 143 | $dql = 'SELECT n FROM App\Entity\Node n WHERE n.page = :page AND n.name_node = :name'; // noeud 'head' de la page | ||
| 144 | $bulk_data = $entityManager | ||
| 145 | ->createQuery($dql) | ||
| 146 | ->setParameter('page', $page) | ||
| 147 | ->setParameter('name', 'head') | ||
| 148 | ->getResult(); | ||
| 149 | |||
| 150 | if(count($bulk_data) != 1){ // 1 head par page | ||
| 151 | header("Location: " . new URL(['page' => $_GET['page'], 'error' => 'head_node_not_found'])); | ||
| 152 | die; | ||
| 153 | } | ||
| 154 | |||
| 155 | $bulk_data[0]->addAttribute('css_array', 'calendar'); | ||
| 156 | $entityManager->persist($bulk_data[0]); | ||
| 157 | } | ||
| 158 | |||
| 135 | $bloc = new Node( | 159 | $bloc = new Node( |
| 136 | trim(htmlspecialchars($_POST["bloc_select"])), | 160 | $_POST["bloc_select"], |
| 137 | null, [], | 161 | null, [], |
| 138 | $position, | 162 | $position, |
| 139 | $main, | 163 | $main, |
