MOD passage à la version 1.2.3 de jquery
[euphorik.git] / doc / TODO.txt
1 == TODO ==
2 [ok] Réaliser la structure suivante :
3    * Table minichat : {id, auteur_id, date, pseudo, contenu, reponses_minichat_id} reponses_minichat_id peut être null
4    * Table reponse_minichat : {id, minichat_id} la clef est (id, minichat_id)
5    * Table user : {id, cookie, pseudo, date_creation, date_derniere_connexion, css}
6 [ok] Implémenter le protocole dans 'fonctionnement_minichat.txt'
7 [ok] Trier la requête et limiter à N le nombre de messages affichés
8 [ok] réaliser un controller sous la forme d'une application pour receptionner tout ce qui vient des formulaires
9 [ok] Ajouter un lien minichat.iduser -> user.id
10 [ok] Ajouter un id pour les messages qui est un entier auto incrémenté
11 [ok] Afficher un captcha le md5 de la valeur est l'envoyer avec
12 [ok] Formater les dates
13 [ok] Trouver et remplacer les url http://www.youpla.com par <a href="http://www.youpla.com">[url]</a>
14 [ok] Traitement des smiles, remplacer :) par "<img src="img/smiles/content.gif" />"
15    * Pour ne pas entrer en conflit avec totoz.eu la notation est la suivante : [=slurp]
16    * La notation totoz.eu est : [:slurp]
17 [ok] Afficher les smiles disponibles, on peut clicker dessus pour en ajouter un dans le text
18 [ok] Mettre en évidence les posts auquels l'utilisateur courant à répondu ainsi que ses propres posts
19    * Vérifier le captcha
20    * Mettre un cookie
21 [ok] Mémoriser le pseudo et le remettre à chaque fois (si cookie)
22 [ok] Afficher un <pseudo> et <message> pour renseigner l'utilisateur sur les différents zones de texte. Lorsque l'utilisateur click sur une zone le message disparait. (javascript).
23 [ok] Pouvoir répondre à un ou plusieurs messages en cliquant dessus (javascript)
24    * L'utilisateur peut cliquer sur un message, cela appond le nom et l'id du message à son message, exe : "kiki:G3E> " "G3E" et l'id du message en base 36, si l'id est omis alors le dernier message dont le pseudo est kiki est pris en compte
25    * le(s) pseudo(s) de l'auteur du message auquel on répond préfixe notre message
26    * Lorsque l'on passe le curseur sur un message on voit la conversation avec une mise en évidence des réponses (les messages ne faisant pas partie de la conversation sont grisés ou masqués)
27 [ok] Maintenir le focus sur la ligne de saisie après l'envoie d'un message
28 [ok] Ajouter plusieurs messages d'un coup pour eviter des lenteurs au chargement
29 [pas besoin] Catcher les exceptions de parsage de l'xml dans euphorik_request
30 [ok] Ne pas virer les balises html mais remplacer les <> par &lt; &gt;
31 [ok mais limité] Avoir accès aux archives (par page, par exemple)
32 [ok] Interdir les {} dans les pseudo
33 [plus besoin] Finir le deamon
34 [plus besoin] tester si le captcha_crypt existe (en regardant les fichiers images temporaires)
35 [ok] Virer les balises html des messages et pseudo lors du stockage du message (et trimer).
36 [ok] afficher les pseudo des messages auquels un message répond (modification du protocole, il faut ajouter une liste de pseudo pour chaque message)
37 [ok] Possibilité de logout
38 [ok] Filtrer les { et } dans les pseudo sur la page profile
39 [ok] différentier [url] [gif] [png] et le reste des url. utiliser lightbox pour les images
40 [ok] Déplacer le formatage des messages du coté du client -> permet de demander à lightbox de reparser lors de l'ajout d'une image
41 [ok] Demander une confirmation lors d'un logout (are you sure jane ?) (vie la système de messagebox)
42 [ok] Possibilité d'enregistrement avec une page dédiée au profil.
43   * Pour se logger il suffit de donner un tuple login + password (le pseudo courant de chat est une données supplémentaire).
44   * La css choisie est une donnée personnelle.
45   * Les personnes enregistrées on un pseudo d'une couleur différente.
46   * (Ajout de smiles personnels)?
47 [ok] Ajouter des messages d'erreur ("login impossible", "captcha incorrect")
48 [ok] Ajouter des messages systèmes
49 [ok] Gérer le flood : si un utilisateur envoie plus de 2 messages par seconde pendant 5 secondes alors il ne peut plus poster pendant 5 secondes
50    * S'il récidive alors il est suspendu pendant 5^2 puis 5^3
51    * Utiliser les messages systèmes pour annonce le flood
52 [ok] Pouvoir modifier la css (dark/light)
53  * Créer le style lite
54  * Créer le style old (avec le style de l'ancien site)   
55 [ok] Ne pas afficher la css dans le profile
56 [ok] Ne pas effacer le message (dans le <input>) si l'on recoit un "pas ok" lors de l'envoie
57
58 * Conversations : 
59    a) implémenter coté serveur et client la sauvegarde et la restauration des conversations
60    b) Supprimer l'envoie de la description des conversations lors du refresh ainsi que modifié la manière de créer les conversations (maj des diagrammes de séquence)
61    c) Navigation vers les pages précédentes
62    c) Mettre à jour l'HTML/CSS de chaque skin en fonction
63 * Utiliser une listbox pour la liste des css
64 * Ralentir volontairement le connexion lors d'un mauvais login (ou après n mauvais login)
65 * Pouvoir switcher entre un affichage "pseudo" ou "pseudo (login)"
66 * réduire les pseudo trop long en mettant un ".." à la fin et permettre de le voir en entier lorsque le curseur le survol.
67 * Problème d'utf-8 avec opera, firefox et konqueror, le prologue (<?xml charset="utf8"...) n'est pas supporté par certains navigateur
68 * Transfert des messages XML (AJAX) en https et le noter dans la faq (même la mafia chinoise ne peut pas sniffer les messages)
69 * Tester avec des caractères exotiques (jap, coréen, etc..)
70 * Shift-enter pour ajouter une ligne dans la ligne de saisie (retour à la ligne)
71    * Crée un <br /> XHTML
72    * A chaque Shift-enter la textbox s'agrandit d'une ligne
73 * Rendre compatible IE 7
74 * Faire une page faq et raconter n'importe quoi (entre autre la limitation avec firefox) "pourquoi ce site à des couleurs qui ne veulent rien dire ?"
75 * Créer un favicon (joli)
76 * Système de commande /<commande>
77    * /nick : changer de pseudo
78    * /me : "*<pseudo> <message>"
79    * /blam <login> : permet d'envoyer un blame à qqun (uniquement depuis un modo vers un non-modo)   
80    * /+ blabla Pourvoir ajouter du texte (correctif en général) à son dernier message par une commande. Le texte ajouté est mise en évidence. Ceci peut être fait plusieurs fois.
81 * Ajouter de nouveaux smiles :
82    * "slurp" : http://forum-images.hardware.fr/images/perso/huit.gif
83    * "agreed" : http://forum-images.hardware.fr/icones/smilies/jap.gif
84    * "dodo" (tete avec un bonnet de nuit et des ZZZZ)
85    * "hum?" : http://forum-images.hardware.fr/icones/smilies/heink.gif
86    * "pas reveillé" avec une tasse de café et des cernes : http://forum-images.hardware.fr/images/perso/elmoricq.gif
87    * "interrogation" genre http://forum-images.hardware.fr/icones/confused.gif
88    * http://forum-images.hardware.fr/images/perso/dao.gif ou http://forum-images.hardware.fr/icones/redface.gif
89    * http://forum-images.hardware.fr/icones/ohwell.gif
90 * Ajouter un skin "simple" sans images ni fioritures (éventuellement le proposer par défaut)
91 * Cleaner le code (erl, js, xhtml, css) et eventuellement profiler un peu (le refresh est lent sous opera)
92 * Gestion de l'historique au niveau du navigateur (pouvoir revenir aux pages précédentes)
93 * Intégrer les totoz : http://www.totoz.eu/ (avec une limite de 3 par messages par exemple) 
94    * avoir une option pour les cacher ou les voir
95    * Masquer systématiquement ceux qui dépassent d'une certaine taille (en pixel?)
96    * modifier la syntaxe des smiles actuels (pour pas qu'ils entre en conflit avec totoz)
97 * Mettre un icone (genre sablier) lorsque le chat se charge (également lors d'un changement de page par exemple)
98 * gestion des timezone (fuseaux horaire) :
99    * L'utilisateur peut simplement définit une timezone dans son profil, les dates sont alors affichées en fonction de sa zone (en option)
100 * Créer un style "super old school" (couleur 8 bit, pas de smiles/images, font fixe)
101 * Un statut "EK" avec plein de privilège à la con. (avoir une petite étoile à coté de son nick ou le nick d'une certaine couleur)
102 * Tests de monter en charge coté serveur, analyse de la complexité (regarder du coté des TODO dans le code). Utiliser eventuellement Tsung
103 * Profiling pour améliorer les performances (client et serveur)
104    * traitementComplet() de euphorik.js est très très lent à executer
105 * Traiter les tags TODO dans le code
106 * Compatage des js lors de la mise en production (afin d'optimiser la bande passante lors de l'accès au site)
107 * Elaborer une stratégie de mise à jour de la structure de la BD quand celle ci est modifié (voir euphorik_bd:vers_version())
108
109
110 == Bugs ==
111 1 : Critique
112 2 : Urgent
113 3 : Peu grave
114
115 [ok] Au bout d'un moment opera n'écoute plus rien... et donc n'affiche plus les nouveaux messages..
116 [ok] La méthod traiterSmiles est très lourde ! (4 secondes pour 80 appels (une page normale))
117 [ok] Utiliser Alpha truc à la place d'opacity sous explorer
118 [ok] les heures sont formatées par le serveur avec un espace devant : " 12.30:10", zarb
119 [ok] un undefined est mis lorsque l'on répond à qqun qui n'a pas de pseudo (traiter ces pseudo par le formateur)
120 [ok] On ne peut pas réponde aux messages du système
121 [ok] Apparement les process liés aux connexions ne sont jamais terminé même quand l'utilisateur coupe la connexion à cause de minichat:attends_nouveau_messages()
122
123 [1] Lors de l'extraction d'une conv il arrive que la conv extracté soit bien créée mais vide, le bouton ne ferme pas la conv (très étrange, bug de firefox?)
124 [3] Amélioration des requêtes MNESIA, voir : http://mail.google.com/mail/#label/Erlang+mailing-list/117f688280569a58
125 [2] Quand on revient en arrière dans firefox le message en rédaction est perdu
126 [2] En changeant de page puis en revenant sur la page principale les smiles ne sont plus highlightés lorsque le curseur les survol\r
127 [2] Dans certains cas (à déterminer) les message-box (message d'information affiché tout en haut de la page) ne s'affiche plus (on ne voit que un petit bout dépassé)
128 [2] Après un register le pseudo est effacé - le pseudo n'est pas mémorisé dans le profil lors d'un envoie de mess en l'ayant changé
129 [3] "Return" ne marche pas sous safari
130 [2] cliquer sur les smiles ne marche pas sous IE
131 [2] le return ne marche pas sous IE
132 [3] la page est completement rechargé après avoir submité le profile dans opera
133 [3] après le login un '?' s'ajoute à l'adresse (opera, firefox)
134
135
136 == Idées ==
137 1 : A implémenter tout de suite !
138 2 : A implémenter dans un futur proche
139 3 : Ca peut attendre
140 4 : Faut en discuter, est-ce réellement utile ?
141 A : Abandonné
142 ok : Implémenté
143
144 [A] smiles personnalisés, on peut en ajouter dans la préférence utilisateur.
145
146 [60%] Possibilité d'extraire une conversation, on click (par l'intermediaire d'un petit bouton par exemple) sur un message et l'arbre de réponses correspondant s'affiche dans une colonne sur la gauche.
147    * Il est possible d'ouvrir plusieurs conversations
148    * Les messages faisant partie des conversations ne sont plus visibles dans le flux général
149    * (une colonne peut avoir le focus, dans ce cas on répond automatiquement à la dernière personne qui nous a répondu)
150    * Chaque colonne possède une entête avec le message d'origine et trois boutons :
151       * un pour copier l'id de la conversation dans la textbox (voir point suivant) 
152       * un pour fermer la conversation
153       * un pour créer une url vers cette conversation (un peu à la manière de google maps)
154 \r
155 [1] Avoir un thème de discussion affiché en haut des messages genre appellé "troll de la semaine : linux sera-t-il desktop ready en 2008?"
156 [2] Pouvoir insérer des tags qui sont des liens vers des conversations, par exemple : {R4S} =~ /\{\w+\}/
157 [2] Raccourcis pour répondre à des messages (genre CTRL+2 pour répondre au deuxième)
158 [2] Pouvoir récupérer son mdp (ou en générer un autre) via son email\r
159 [2] Syntaxe avancée des messagees :\r
160    * Possibilité d'utiliser les balises <i>, <b>, <code>, <q> (quoted text)
161    * La balise <hide> pour mettre des spoilers
162 [2] Pouvoir cacher les dates\r
163 [3] Gestion de l'historique (calendrier)
164 [4] Pouvoir choisir une couleur pour son pseudo
165 [4] Créer un gamebot pour lancer des jeux. Par exemple un jeu d'énigmes
166 [4] Utiliser XMLRPC ou SOAP ou JSON pour la communication client -> serveur (boah, faut pas déconner :))
167 [4] Image animée à la http://www.google.co.kr/ cf http://www.google.co.kr//ig/f/AaEyQnOaAr4/intl/ALL_kr/svc_sprite_all.gif
168 [4] Bot de traduction
169 [4] Bot de jeu (jeu du pendu par exemple)
170 [4] RSS
171 [4] Système de vote sur les messages, + ou - qui donne des points aux messages...
172 [4] Voir les personnes connectées
173 [4] Avoir une liste d'amis
174 [4] Restreindre la consultation d'un message posté à un ou plusieurs utilisateurs définis. Les messages de la conversation ne sont alors vus que par cet ensemble d'utilisateurs.
175 [4] Plusieurs canaux
176
177
178 == Concurrents ==
179 http://www.phpfreechat.net/demo.fr.html
180 http://moules.org/board
181 http://hadoken.free.fr/board/index#b
182 http://bouchot.org/tribune#missive