-Client.prototype.goPremierePage = function(numConv)
-{
- if (numConv < 0)
- {
- if (this.pagePrincipale == 1)
- return false
- this.pagePrincipale = 1
- }
- else
- {
- if (this.conversations[numConv].page == 1)
- return false
- this.conversations[numConv].page = 1
- }
- return true
-}
-
-/**
- * Ajoute une conversation à la vue de l'utilisateur.
- * Le profile de l'utilisateur est directement sauvegardé sur le serveur.
- * @param racines la racine de la conversation (integer)
- * @return true si la conversation a été créée sinon false (par exemple si la conv existe déjà)
- */
-Client.prototype.ajouterConversation = function(racine)
-{
- // vérification s'il elle n'existe pas déjà
- for (var i = 0; i < this.conversations.length; i++)
- if (this.conversations[i].root == racine)
- return false
-
- this.conversations.push({root : racine, page : 1, reduit : false})
- if (this.autoflush) this.flush(true)
-
- return true
-}
-
-Client.prototype.supprimerConversation = function(num)
-{
- if (num < 0 || num >= this.conversations.length) return
-
- // décalage TODO : supprimer le dernier élément
- for (var i = num; i < this.conversations.length - 1; i++)
- this.conversations[i] = this.conversations[i+1]
- this.conversations.pop()
-
- if (this.autoflush) this.flush(true)
-}
-
-Client.prototype.getJSONLogin = function(login, password)
-{
- return {
- "header" : { "action" : "authentification", "version" : euphorik.conf.versionProtocole },
- "login" : login,
- "password" : password
- }
-}
-
-Client.prototype.getJSONLoginCookie = function()
-{
- return {
- "header" : { "action" : "authentification", "version" : euphorik.conf.versionProtocole },
- "cookie" : this.cookie
- }
-}
-
-/**
- * le couple (login, password) est facultatif. S'il n'est pas fournit alors il ne sera pas possible
- * de s'autentifier avec (login, password).
- */
-Client.prototype.getJSONEnregistrement = function(login, password)
-{
- var mess = { "header" : { "action" : "register", "version" : euphorik.conf.versionProtocole }}
-
- if (login != undefined && password != undefined)
- {
- mess["login"] = login
- mess["password"] = password
- }
-
- return mess;
-}
-
-Client.prototype.getJSONConversations = function()
-{
- var conversations = new Array()
- for (var i = 0; i < this.conversations.length; i++)
- conversations.push({root : this.conversations[i].root, minimized : this.conversations[i].reduit})
- return conversations
-}
-
-Client.prototype.getJSONProfile = function()
-{
- return {
- "header" : { "action" : "set_profile", "version" : euphorik.conf.versionProtocole },
- "cookie" : this.cookie,
- "login" : this.login,
- "password" : this.password,
- "nick" : this.pseudo,
- "email" : this.email,
- "css" : this.css,
- "chat_order" : this.chatOrder,
- "nick_format" : this.nickFormat,
- "view_times" : this.viewTimes,
- "view_tooltips" : this.viewTooltips,
- "conversations" : this.getJSONConversations(),
- "ostentatious_master" : this.ostentatiousMaster
- }
-}
-
-/**
- * Renvoie null si pas définit.
- */
-Client.prototype.getCookie = function()
-{
- var cookie = this.regexCookie.exec(document.cookie)
- if (cookie == null) this.cookie = null
- else this.cookie = cookie[1]
-}
-
-Client.prototype.delCookie = function()
-{
- document.cookie = "cookie=; max-age=0"
-}
-
-Client.prototype.setCookie = function()
-{
- if (this.cookie == null || this.cookie == undefined)
- return
-
- // ne fonctionne pas sous IE....
- /*document.cookie = "cookie=" + this.cookie + "; max-age=" + (60 * 60 * 24 * 365) */
-
- document.cookie =
- "cookie="+this.cookie+"; expires=" + new Date(new Date().getTime() + 1000 * 60 * 60 * 24 * 365).toUTCString()
-}
-
-Client.prototype.authentifie = function()
-{
- return this.statut == statutType.auth_registered || this.statut == statutType.auth_not_registered
-}
-
-Client.prototype.setStatut = function(statut)
-{
- // conversation en "enum" si en "string"
- if (typeof(statut) == "string")
- {
- statut =
- statut == "auth_registered" ?
- statutType.auth_registered :
- (statut == "auth_not_registered" ? statutType.auth_not_registered : statutType.deconnected)
- }
-
- if (statut == this.statut) return
-
- this.statut = statut
- this.majMenu()
- this.majLogo()
-}
-
-/**
- * Effectue la connexion vers le serveur.
- * Cette fonction est bloquante tant que la connexion n'a pas été établie.
- * S'il existe un cookie en local on s'authentifie directement avec lui.
- * Si il n'est pas possible de s'authentifier alors on affiche un captcha anti-bot.
- */
-Client.prototype.connexionCookie = function()
-{
- this.getCookie()
- if (this.cookie == null) return false;
- return this.connexion(this.getJSONLoginCookie())
-}
-
-Client.prototype.connexionLogin = function(login, password)
-{
- return this.connexion(this.getJSONLogin(login, password))
-}
-
-Client.prototype.enregistrement = function(login, password)
-{
- if (this.authentifie())
- {
- this.login = login
- this.password = password
- if(this.flush())
- {
- this.setStatut(statutType.auth_registered)
- return true