diff --git a/cms2/code/TODO b/cms2/code/TODO index 1bc364b..2365bb2 100644 --- a/cms2/code/TODO +++ b/cms2/code/TODO @@ -4,6 +4,4 @@ ElementDocument, et GalerieIndex::res_c_style() renvoie du texte (CSS) pour inclusion dans le CSS principal... alors que res_c_style_supplémentaire() fait je-sais-pas-quoi... - Comment gérer tout ça ? Tout le monde envoie directement et on intercepte avec un ob_start() / ob_end() ? Selon le type d'image on envoie - direct ou on récupère (html,css => récup, img => envoi) ? Une option à chaque fois (bêrk) ? Selon la valeur de retour (Direct => envoyé - directement, autre => récupéré), mais ça pose des pbs (la fonction X appelle un envoi direct alors qu'elle voulait une récup) ? + Comment gérer tout ça ? Selon le type de ressource on envoie direct ou on récupère (html,css => récup, img => envoi). \ No newline at end of file diff --git a/cms2/code/document.php b/cms2/code/document.php index cafa66e..138cc3b 100644 --- a/cms2/code/document.php +++ b/cms2/code/document.php @@ -14,7 +14,7 @@ class ElementDocument { private $type = null; private $enfants = array(); private $attr = array(); - + public static function ajouter_type_élément($type, $typesEnfants, $attributs = "") { self::$enfantsÉléments[$type] = qw($typesEnfants); self::$attributsÉléments[$type] = qw($attributs); @@ -24,10 +24,15 @@ class ElementDocument { self::$widgets["w_" . $nom] = $callback; } - public function inclure($elem) { - // Tente de fusionner $elem avec $this - niy("inclure"); + public function type() { + return $this->type; } + + /* public function inclure($elem) { + // Tente de fusionner $elem avec $this + // Très mauvaise fonction car l'inclusion peut planter bien après la définition des deux parties. + niy("inclure"); + }*/ public function attr($nom, $valeur) { $this->attr[$nom] = $valeur; @@ -107,10 +112,15 @@ ElementDocument::ajouter_type_élément("header", "title"); ElementDocument::ajouter_type_élément("title", "text"); ElementDocument::ajouter_type_élément("footer", ""); ElementDocument::ajouter_type_élément("nav", "ul"); -ElementDocument::ajouter_type_élément("article", "ul p form span"); // span ? +ElementDocument::ajouter_type_élément("article", "ul table p form span"); // span ? ElementDocument::ajouter_type_élément("script", "", "src"); ElementDocument::ajouter_type_élément("style", "", "src"); ElementDocument::ajouter_type_élément("ul", "li"); +ElementDocument::ajouter_type_élément("table", "thead tbody tfoot"); +ElementDocument::ajouter_type_élément("tbody", "tr"); +ElementDocument::ajouter_type_élément("tr", "td th"); +ElementDocument::ajouter_type_élément("td", $inline_elems); +ElementDocument::ajouter_type_élément("th", $inline_elems); ElementDocument::ajouter_type_élément("li", $inline_elems); ElementDocument::ajouter_type_élément("form", "input_text_line input_text_multi input_text_rich input_file"); ElementDocument::ajouter_type_élément("a", $inline_elems, "href"); @@ -160,6 +170,13 @@ ElementDocument::ajouter_widget("liste", function($d, $select, $function_formatt return $l; }); +ElementDocument::ajouter_widget("tableau", function($d, $select, $function_formattage_elements) { + $t = $d->table(); + $tr = $t->tbody()->tr(); + $tr->td()->text("Not Implemented Yet"); + return $t; + }); + /* Widgets : function liste($elts, $format) { $d = new Document(); diff --git a/cms2/code/main.php b/cms2/code/main.php index 3025d9a..6716b19 100644 --- a/cms2/code/main.php +++ b/cms2/code/main.php @@ -1,7 +1,7 @@ rendu(); echo "
";
diff --git a/cms2/code/page.php b/cms2/code/page.php
index ec83c25..e2402c3 100644
--- a/cms2/code/page.php
+++ b/cms2/code/page.php
@@ -87,33 +87,31 @@ class Page {
 	public function __get($nom) {
 		// s'il y a un getter (trigger), on l'appelle, sinon on appelle get_prop_direct();
 		// le getter fait ce qu'il veut, puis appelle set_prop_direct();
-		// if (is_callable(array($this,"get_".$nom)) {
-		// 	return call_user_func(array($this,"get_".$nom));
-		// } else {
-		// 	return $this->get_prop_direct($nom);
-		// }
-		niy("get $nom");
+		if (is_callable(array($this,"get_".$nom))) {
+			return call_user_func(array($this,"get_".$nom));
+		} else {
+			return $this->get_prop_direct($nom);
+		}
 	}
 
 	private function get_prop_direct($nom) {
 		// Récupère l'attribut "$nom" depuis la BDD.
-		niy("get direct $name");
+		niy("get direct $nom");
 	}
 	
 	public function __set($nom, $val) {
 		// s'il y a un setter (trigger), on l'appelle, sinon on appelle set_prop_direct();
 		// le setter fait ce qu'il veut, puis appelle set_prop_direct();
-		// if (is_callable(array($this,"get_".$nom)) {
-		// 	return call_user_func(array($this,"get_".$nom), $val);
-		// } else {
-		// 	return $this->set_prop_direct($nom, $val);
-		// }
-		niy("set $name = $val");
+		if (is_callable(array($this,"get_".$nom))) {
+			return call_user_func(array($this,"get_".$nom), $val);
+		} else {
+			return $this->set_prop_direct($nom, $val);
+		}
 	}
 	
 	public function set_prop_direct($nom, $val) {
 		// Modifie l'attribut "$nom" dans la BDD.
-		niy("set direct $name = $val");
+		niy("set direct $nom = $val");
 	}
   }
 
diff --git a/cms2/modules/admin/admin-utilisateurs.php b/cms2/modules/admin/admin-utilisateurs.php
index 25850ae..0724265 100644
--- a/cms2/modules/admin/admin-utilisateurs.php
+++ b/cms2/modules/admin/admin-utilisateurs.php
@@ -25,10 +25,10 @@ class AdminListeUtilisateurs extends Page {
 	public function res_h_page($d) {
 		$d->w_titre("Utilisateurs");
 		
-		$l = $d->article()->w_liste($this->enfants(true, "nom asc prenom asc"), function($e, $li) {
-				$e->rendu("h_admin", $li);
+		$l = $d->article()->w_tableau($this->enfants(true, "nom asc prenom asc"), function($e, $tr) {
+				$e->rendu("h_admin", $tr);
 			});
-		$nouveau = $l->li();
+		$nouveau = $l->tbody(0)->tr()->td(); // TODO : colspan
 		$nouveau->text("Nouvel utilisateur");
 		return $d;
 	}
@@ -71,6 +71,7 @@ class AdminUtilisateur extends Page {
 	
 	public function res_h_admin($d) {
 		// Vue de l'utilisateur pour inclusion dans admin/utilisateurs.
+		assert('$d->type() == "tr"');
 		$a = $d->article();
 		//$d->w_titre("" . $this->nom . $this->prenom);