Mercurial > defr > DualBlog
view admin_xml.php @ 75:49b0a2f3a118
Fix IE: Rend l'administration utilisable avec Internet Explorer 6
En réalité, seulement trois réels changements sont introduits ici:
- il existait quelques problèmes dans le code supposé être executés lorsque
le navigateur ne connait pas les treewalkers, le code fait désormais ce
qu'il faut (la mauvaise fonction était associé à l'édition des brouillons,
la fonction de test ne renvoyait pas true / false)
- Internet Explorer 6 ne connait pas textContent. Une fonction essayant
diverses possibilités de remplacement, et faisant un parcours récursif de
tous les noeuds fils dans le pire des cas a été mise en place
- le code cherchant un remplacement à DOMParser supposait que l'objet ActiveX
XMLDOM fournissait exactement la même API, ce qui aurait été trop beau. Un
wrapper a été développé autour de XMLDOM qui fournit la seule fonction de
DOMParser utilisé dans le script. Evidemment ce n'est pas une solution
totalement générique...
Avec ces modifications, il est possible de poster depuis Internet Explorer
(testé sur la version 6), Safari (testé avec la version 3.1) et Firefox (testé
avec les versions 2 et 3)
author | Franck Deroche <webmaster@defr.org> |
---|---|
date | Mon, 31 Mar 2008 15:07:21 +0200 |
parents | 629389204276 |
children |
line wrap: on
line source
<?php require("classes.php"); $Req = new Requete(); $Data = new DataAccess; header("Content-Type: application/xml; charset=utf-8"); $doc = new DOMDocument('1.0', 'utf-8'); $root = $doc->createElementNS('http://defr.org/2005/blog-post', 'post'); $doc->appendChild($root); $mode = $Req->get('mode', 'GET', 'get'); $type = $Req->get('type', 'GET', 'post'); $id = $Req->get('id'); $root->appendChild($doc->createElement('id', $id)); $root->appendChild(DOMUtils::createCDATAWrapper($doc, 'debug', var_export($Req, true))); switch($mode . '-' . $type) { case 'edit-post': $nvTitre = $Req->get('title'); $nvContenu = $Req->get('content'); $nvMood = $Req->get('mood'); $Data->Query (" UPDATE Mess SET Titre='{$nvTitre}', Message='{$nvContenu}', Emot='{$nvMood}' WHERE num_mess={$id} "); // Récuperation des nouveaux tags à appliquer $arTags = TextUtils::splitTags($Req->get('tags')); // Récuperation des anciens tags $Data->Query (" SELECT T.idTag, T.Tag FROM Lien_Tags_Posts L LEFT JOIN Tags T ON L.idTag = T.idTag WHERE L.idMess = {$id} "); $oldTags = array(); while(0 !== ($row = $Data->GetRow())) { $oldTags[] = $row['Tag']; $mapOld[$row['Tag']] = $row['idTag']; } // Calcul des différences $tagsSupprimes = array_diff($oldTags, $arTags); $tagsAjoutes = array_diff($arTags, $oldTags); // Suppression des tags non affectés if(is_array($tagsSupprimes)) { foreach($tagsSupprimes as $tagSuppr) { $supprIDs .= $mapOld[$tagSuppr] . ','; } $Data->Query (" DELETE FROM Lien_Tags_Posts WHERE idMess={$id} AND idTag IN ({$supprIDs}0) "); } // Ajout des tags ajoutés if(is_array($tagsAjoutes)) { foreach($tagsAjoutes as $tagAj) { $n = $Data->Query("SELECT idTag FROM Tags WHERE Tag='{$tagAj}'"); if($n == 0) { // Si le tag n'existe pas, on le crée $Data->Query("INSERT INTO Tags SET Tag='{$tagAj}'"); $Data->Query("SELECT idTag FROM Tags WHERE Tag='{$tagAj}'"); } $row = $Data->GetRow(); $Data->Query (" INSERT INTO Lien_Tags_Posts SET idMess={$id}, idTag={$row['idTag']} "); } } case 'get-post': $Data->Query (" SELECT Titre, Message, Emot FROM Mess WHERE num_mess={$id} "); $row = $Data->GetRow(); $titre_CDATA = $doc->createCDATASection($row['Titre']); $root->appendChild(DOMUtils::createCDATAWrapper($doc, 'titre', $row['Titre'])); $root->appendChild(DOMUtils::createCDATAWrapper($doc, 'contenu', $row['Message'])); $root->appendChild($doc->createElement('mood', $row['Emot'])); // Obtention des tags $Data->Query (" SELECT T.idTag, T.Tag FROM Lien_Tags_Posts L LEFT JOIN Tags T ON L.idTag = T.idTag WHERE L.idMess = {$id} "); while(0 !== ($row = $Data->GetRow())) $root->appendChild($doc->createElement('tag', $row['Tag'])); break; case 'edit-brouillon': $nvTitre = $Req->get('title'); $nvContenu = $Req->get('content'); $Data->Query (" UPDATE Brouillons SET Titre='{$nvTitre}', Contenu='{$nvContenu}' WHERE id_brouillon={$id} "); case 'get-brouillon': $Data->Query (" SELECT Titre, Contenu FROM Brouillons WHERE id_brouillon={$id} "); $row = $Data->GetRow(); $root->appendChild(DOMUtils::createCDATAWrapper($doc, 'titre', $row['Titre'])); $root->appendChild(DOMUtils::createCDATAWrapper($doc, 'contenu', $row['Contenu'])); break; } echo $doc->saveXML(); ?>