aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorpolo <ordipolo@gmx.fr>2025-10-29 21:42:39 +0100
committerpolo <ordipolo@gmx.fr>2025-10-29 21:42:39 +0100
commitbce9fda51d334a547ec5a48f0b7699ed3b5d7944 (patch)
treef4b3b57414a22c2b9542195bfd76eaf6e2853293 /src
parent822f526fd7f4e89043e64b435961720b622bdb6e (diff)
downloadcms-bce9fda51d334a547ec5a48f0b7699ed3b5d7944.tar.gz
cms-bce9fda51d334a547ec5a48f0b7699ed3b5d7944.tar.bz2
cms-bce9fda51d334a547ec5a48f0b7699ed3b5d7944.zip
classe Fetcher, gestion réseaux sociaux présents/absents, partie 2
Diffstat (limited to 'src')
-rw-r--r--src/controller/HeadFootController.php30
-rw-r--r--src/router.php3
-rw-r--r--src/view/HeadBuilder.php3
-rw-r--r--src/view/HeaderBuilder.php13
4 files changed, 42 insertions, 7 deletions
diff --git a/src/controller/HeadFootController.php b/src/controller/HeadFootController.php
index 7597683..a4727e2 100644
--- a/src/controller/HeadFootController.php
+++ b/src/controller/HeadFootController.php
@@ -22,15 +22,17 @@ class HeadFootController
22 if($model->findWhateverNode('name_node', $params_array[0])){ 22 if($model->findWhateverNode('name_node', $params_array[0])){
23 $node_data = $model->getNode()->getNodeData(); 23 $node_data = $model->getNode()->getNodeData();
24 24
25 // liens réseaux sociaux
25 if(in_array($params_array[1], NodeData::$social_networks)){ 26 if(in_array($params_array[1], NodeData::$social_networks)){
26 $social = $node_data->getData()['social']; 27 $social = $node_data->getData()['social'] ?? [];
27 $social[$params_array[1]] = $json['new_text']; 28 $social[$params_array[1]] = $json['new_text'];
28 $node_data->updateData('social', $social); 29 $node_data->updateData('social', $social);
29 } 30 }
31 // autres textes
30 else{ 32 else{
31 $node_data->updateData($params_array[1], $json['new_text']); // $params_array[1] n'est pas contrôlé 33 $node_data->updateData($params_array[1], $json['new_text']); // $params_array[1] n'est pas contrôlé
32 } 34 }
33 35
34 $entityManager->flush(); 36 $entityManager->flush();
35 echo json_encode(['success' => true]); 37 echo json_encode(['success' => true]);
36 } 38 }
@@ -120,5 +122,29 @@ class HeadFootController
120 die; 122 die;
121 } 123 }
122 124
125 static public function displaySocialNetwork(EntityManager $entityManager, string $request_params, array $json): void
126 {
127 $params_array = explode('_', $request_params);
128 if(count($params_array) !== 2){
129 echo json_encode(['success' => false]);
130 die;
131 }
132
133 $model = new Model($entityManager);
134 if(in_array($params_array[1], NodeData::$social_networks) && $model->findWhateverNode('name_node', $params_array[0])){
135 $node_data = $model->getNode()->getNodeData();
136 $social_show = $node_data->getData()['social_show'] ?? [];
137 $social_show[$params_array[1]] = $json['checked'];
138 $node_data->updateData('social_show', $social_show);
139
140 $entityManager->flush();
141 echo json_encode(['success' => true, 'checked' => $json['checked']]);
142 }
143 else{
144 echo json_encode(['success' => false]);
145 }
146 die;
147 }
148
123 //static public function uploadImage(EntityManager $entityManager, array $request_params): void 149 //static public function uploadImage(EntityManager $entityManager, array $request_params): void
124} \ No newline at end of file 150} \ No newline at end of file
diff --git a/src/router.php b/src/router.php
index ebe645f..2ba3b88 100644
--- a/src/router.php
+++ b/src/router.php
@@ -145,6 +145,9 @@ elseif($request->getMethod() === 'POST'){
145 elseif($request->query->has('head_foot_text')){ 145 elseif($request->query->has('head_foot_text')){
146 HeadFootController::setTextData($entityManager, $request->query->get('head_foot_text'), $json); 146 HeadFootController::setTextData($entityManager, $request->query->get('head_foot_text'), $json);
147 } 147 }
148 elseif($request->query->has('head_foot_social_check')){
149 HeadFootController::displaySocialNetwork($entityManager, $request->query->get('head_foot_social_check'), $json);
150 }
148 151
149 /* -- page Menu et chemins -- */ 152 /* -- page Menu et chemins -- */
150 elseif(isset($_GET['menu_edit'])) 153 elseif(isset($_GET['menu_edit']))
diff --git a/src/view/HeadBuilder.php b/src/view/HeadBuilder.php
index 88e69fb..e3d620c 100644
--- a/src/view/HeadBuilder.php
+++ b/src/view/HeadBuilder.php
@@ -38,6 +38,9 @@ class HeadBuilder extends AbstractBuilder
38 // édition éléments sur toutes les pages (header, footer et favicon) 38 // édition éléments sur toutes les pages (header, footer et favicon)
39 $js .= '<script src="' . self::versionedFileURL('js', 'Input') . '"></script>' . "\n"; 39 $js .= '<script src="' . self::versionedFileURL('js', 'Input') . '"></script>' . "\n";
40 40
41 // sert partout?
42 $js .= '<script src="' . self::versionedFileURL('js', 'Fetcher') . '"></script>' . "\n";
43
41 // tinymce, nécéssite un script de copie dans composer.json 44 // tinymce, nécéssite un script de copie dans composer.json
42 $css .= '<link rel="stylesheet" href="' . self::versionedFileURL('css', 'tinymce') . '">' . "\n"; 45 $css .= '<link rel="stylesheet" href="' . self::versionedFileURL('css', 'tinymce') . '">' . "\n";
43 $js .= '<script src="' . self::versionedFileURL('js', 'tinymce/tinymce.min') . '"></script>' . "\n"; // pour js/tinymce/tinymce.min.js 46 $js .= '<script src="' . self::versionedFileURL('js', 'tinymce/tinymce.min') . '"></script>' . "\n"; // pour js/tinymce/tinymce.min.js
diff --git a/src/view/HeaderBuilder.php b/src/view/HeaderBuilder.php
index 1cc4fc3..f988156 100644
--- a/src/view/HeaderBuilder.php
+++ b/src/view/HeaderBuilder.php
@@ -84,10 +84,10 @@ class HeaderBuilder extends AbstractBuilder
84 // boucle sur la liste complète de réseaux sociaux 84 // boucle sur la liste complète de réseaux sociaux
85 foreach(NodeData::$social_networks as $network){ 85 foreach(NodeData::$social_networks as $network){
86 $checked = (isset($social_show[$network]) && $social_show[$network]) ? 'checked' : ''; 86 $checked = (isset($social_show[$network]) && $social_show[$network]) ? 'checked' : '';
87 $href = isset($social[$network]) ? 'href="' . $social[$network] . '"' : ''; 87 $href = (isset($social[$network]) && $social[$network] !== '') ? 'href="' . $social[$network] . '"' : '';
88 88
89 $social_networks .= '<div id="header_' . $network . '"> 89 $social_networks .= '<div id="header_' . $network . '">
90 <input type="checkbox" onclick="" ' . $checked . '> 90 <input type="checkbox" onclick="checkSocialNetwork(\'header_' . $network . '\')" ' . $checked . '>
91 <a ' . $href . ' target="_blank" rel="noopener noreferrer"> 91 <a ' . $href . ' target="_blank" rel="noopener noreferrer">
92 <img id="header_' . $network . '_content" src="assets/' . $network . '.svg" alt="'. $network . '_alt"> 92 <img id="header_' . $network . '_content" src="assets/' . $network . '.svg" alt="'. $network . '_alt">
93 </a> 93 </a>
@@ -110,9 +110,12 @@ class HeaderBuilder extends AbstractBuilder
110 if(isset($social_show)){ 110 if(isset($social_show)){
111 // boucle sur les réseaux sociaux "activés" 111 // boucle sur les réseaux sociaux "activés"
112 foreach(array_keys($social_show) as $network){ 112 foreach(array_keys($social_show) as $network){
113 $social_networks .= '<div id="header_' . $network . '"> 113 if($social_show[$network]){
114 <a href="' . $social[$network] . '" target="_blank" rel="noopener noreferrer"><img id="header_' . $network . '_content" src="assets/' . $network . '.svg" alt="'. $network . '_alt"></a> 114 $href = (isset($social[$network]) && $social[$network] !== '') ? 'href="' . $social[$network] . '"' : '';
115 </div>'; 115 $social_networks .= '<div id="header_' . $network . '">
116 <a ' . $href . ' target="_blank" rel="noopener noreferrer"><img id="header_' . $network . '_content" src="assets/' . $network . '.svg" alt="'. $network . '_alt"></a>
117 </div>';
118 }
116 } 119 }
117 } 120 }
118 } 121 }