Merge branch 'master' of gburri.org:euphorik
authorUmmon <greg.burri@gmail.com>
Thu, 23 Apr 2020 16:43:19 +0000 (18:43 +0200)
committerUmmon <greg.burri@gmail.com>
Thu, 23 Apr 2020 16:43:19 +0000 (18:43 +0200)
25 files changed:
.gitignore
doc/server_architecture.svg
index.yaws
js/chat/commandes.js
js/chat/conversation.js
js/chat/conversations.js
js/chat/message.js
js/euphorik.js
js/formater.js [deleted file]
js/formatter.js [new file with mode: 0644]
js/pageAbout.js
js/pageAdmin.js
js/pageMinichat.js
js/pageProfile.js
js/pageRegister.js
js/util.js
modules/erl/euphorik_bd.erl
modules/erl/euphorik_bd_admin.erl
modules/erl/euphorik_common.erl
modules/erl/euphorik_daemon.erl
modules/erl/euphorik_minichat_conversation.erl
modules/erl/euphorik_protocole.erl
modules/erl/euphorik_requests.erl
modules/erl/euphorik_test.erl
tools/yaws.conf

index 5b3f348..7c8641d 100644 (file)
@@ -1,3 +1,5 @@
 *.iws
 *.beam
-var/
\ No newline at end of file
+var/
+/BD
+/data
\ No newline at end of file
index 8a00377..c6002b4 100644 (file)
            y="359.74429"
            x="77.082535"
            id="tspan2541"
-           sodipodi:role="line">formater</tspan></text>
+           sodipodi:role="line">formatter</tspan></text>
     </g>
     <g
        style="display:inline"
index 99ce454..9b80ee1 100755 (executable)
@@ -46,7 +46,7 @@
    <script type="text/javascript" src="js/communication.js" prod="delete"></script>\r
    <script type="text/javascript" src="js/conf.js" prod="delete"></script>\r
    <script type="text/javascript" src="js/util.js" prod="delete"></script>\r
-   <script type="text/javascript" src="js/formater.js" prod="delete"></script>\r
+   <script type="text/javascript" src="js/formatter.js" prod="delete"></script>\r
    <script type="text/javascript" src="js/pages.js" prod="delete"></script>\r
    <script type="text/javascript" src="js/client.js" prod="delete"></script>\r
 \r
index 871e22b..cbf522d 100644 (file)
   *  /nick <nouveau nick>
   *  Modifie le nick courant
   */
-euphorik.Commandes = function(client, pageMinichat, util, formater) {
+euphorik.Commandes = function(client, pageMinichat, util, formatter) {
    var thisCommandes = this;
 
    this.client = client;
    this.pageMinichat = pageMinichat;
    this.util = util;
-   this.formater = formater;
+   this.formatter = formatter;
 
    // construction du texte d'aide (liste des commandes) de manière statique
    this.texteAide = "<div id=\"aideCommandes\"><h1>Commandes</h1><ul>";
    objectEach(
       euphorik.Commandes.liste,
       function(name, commande) {
-         thisCommandes.texteAide += "<li><span class=\"usage\">" + thisCommandes.formater.completeProcessing(commande.usage) + "</span> : " + thisCommandes.formater.completeProcessing(commande.description) + "</li>";
+         thisCommandes.texteAide += "<li><span class=\"usage\">" + thisCommandes.formatter.completeProcessing(commande.usage) + "</span> : " + thisCommandes.formatter.completeProcessing(commande.description) + "</li>";
       }
    );
    this.texteAide += "</ul></div>";
index 8c11752..4deb11c 100644 (file)
@@ -35,7 +35,7 @@ euphorik.Conversation = function(conversations, num) {
    this.id = Math.floor(Math.random() * 1000000).toString(36);\r
 \r
    this.util = this.conversations.util;\r
-   this.formater = this.conversations.formater;\r
+   this.formatter = this.conversations.formatter;\r
    this.client = this.conversations.client;\r
 \r
    this.idDernierMessageAffiche = 0;\r
@@ -107,7 +107,7 @@ euphorik.Conversation.prototype.getMessageReduit = function() {
   * @racine un message représentant la racine de la conversation, vaut undefined pour la conversation générale\r
   */\r
 euphorik.Conversation.prototype.setRacine = function(racineElement) {\r
-   this.racine = new euphorik.Message(this.client, this.formater, racineElement);\r
+   this.racine = new euphorik.Message(this.client, this.formatter, racineElement);\r
 };\r
 \r
 /**\r
index ea7e742..05da80e 100644 (file)
@@ -21,9 +21,9 @@
 /**\r
   * Représente l'ensemble des conversations affichés.\r
   */\r
-euphorik.Conversations = function(client, formater, util, communication, fragment) {\r
+euphorik.Conversations = function(client, formatter, util, communication, fragment) {\r
    this.client = client;\r
-   this.formater = formater;\r
+   this.formatter = formatter;\r
    this.util = util;\r
    this.fragment = fragment;\r
 \r
@@ -247,7 +247,7 @@ euphorik.Conversations.prototype.ajouterMessage = function(element, numConversat
    var message =\r
       new euphorik.Message(\r
          this.client,\r
-         this.formater,\r
+         this.formatter,\r
          element\r
       );\r
 \r
index b3e5f12..e7439c9 100644 (file)
@@ -25,9 +25,9 @@ euphorik.Reponse = function(id, nick, login) {
 /**\r
   * Représente un message.\r
   */\r
-euphorik.Message = function(client, formater, element) {\r
+euphorik.Message = function(client, formatter, element) {\r
    this.client = client;\r
-   this.formater = formater;\r
+   this.formatter = formatter;\r
 \r
    this.id = element.id;\r
    this.auteurId = element.user_id;\r
@@ -118,9 +118,9 @@ euphorik.Message.prototype.XHTML = function(messagePair, pre) {
 \r
    // construit l'identifiant de la personne\r
    var identifiant =\r
-      this.client.nickFormat === "nick" || this.login === "" ? this.formater.completeProcessing(this.nick) :\r
-      (this.client.nickFormat === "login" ? this.formater.completeProcessing(this.login) :\r
-      this.formater.completeProcessing(this.nick) + "<span class=\"login\">(" + this.formater.completeProcessing(this.login) +")</span>" );\r
+      this.client.nickFormat === "nick" || this.login === "" ? this.formatter.completeProcessing(this.nick) :\r
+      (this.client.nickFormat === "login" ? this.formatter.completeProcessing(this.login) :\r
+      this.formatter.completeProcessing(this.nick) + "<span class=\"login\">(" + this.formatter.completeProcessing(this.login) +")</span>" );\r
 \r
    var XHTMLrepondA = "";\r
    var debut = true;\r
@@ -128,7 +128,7 @@ euphorik.Message.prototype.XHTML = function(messagePair, pre) {
       if (!debut) {\r
          XHTMLrepondA += ", ";\r
       }\r
-      XHTMLrepondA += thisMessage.formater.completeProcessing(rep.nick);\r
+      XHTMLrepondA += thisMessage.formatter.completeProcessing(rep.nick);\r
       debut = false;\r
    });\r
    if (XHTMLrepondA) {\r
@@ -148,6 +148,6 @@ euphorik.Message.prototype.XHTML = function(messagePair, pre) {
          "</span>" +\r
          "<span class=\"delimitationEntete\"></span>" +\r
          XHTMLrepondA +\r
-         "<span class=\"contenu\">" + this.formater.completeProcessing(this.contenu, this.nick) + "</span>" +\r
+         "<span class=\"contenu\">" + this.formatter.completeProcessing(this.contenu, this.nick) + "</span>" +\r
       "</div>";\r
 };\r
index 3f45e2d..893a32a 100755 (executable)
@@ -25,8 +25,8 @@ var euphorik = {};
 $(document).ready(
    function() {
       var fragment = new Fragment();
-      var formater = new euphorik.Formater();
-      var util = new euphorik.Util(formater);
+      var formatter = new euphorik.Formatter();
+      var util = new euphorik.Util(formatter);
       var communication = new euphorik.Communication(
          function(data) { util.messageDialog(data.error_message); },
          function() { util.showWaitBar(); },
@@ -59,16 +59,16 @@ $(document).ready(
       $("#menu .register").click(function(){ pages.displayPage("register"); });
       $("#menu .about").click(function(){ pages.displayPage("about"); });
 
-      // TODO: simplification : such link[1] should be created and automatically open the right page without
+      // TODO : simplification : such link[1] should be created and automatically open the right page without
       //  explicitly add a page.
       // [1] : <a class="pageLink" href="termes_of_use">Terms of use</a>
       $("#footer .termsOfUse").click(function(){ pages.displayPage("terms_of_use"); });
 
-      pages.addPage(new euphorik.PageMinichat(client, formater, util, communication), true);
-      pages.addPage(new euphorik.PageAdmin(client, formater, util, communication));
-      pages.addPage(new euphorik.PageProfile(client, formater, util));
-      pages.addPage(new euphorik.PageRegister(client, formater, util));
-      pages.addPage(new euphorik.PageAbout(client, formater, util, communication));
+      pages.addPage(new euphorik.PageMinichat(client, formatter, util, communication), true);
+      pages.addPage(new euphorik.PageAdmin(client, formatter, util, communication));
+      pages.addPage(new euphorik.PageProfile(client, formatter, util));
+      pages.addPage(new euphorik.PageRegister(client, formatter, util));
+      pages.addPage(new euphorik.PageAbout(client, formatter, util, communication));
       pages.addPage("terms_of_use");
 
       pages.displayPage(); // display the default page
diff --git a/js/formater.js b/js/formater.js
deleted file mode 100644 (file)
index a4fbc23..0000000
+++ /dev/null
@@ -1,183 +0,0 @@
-// coding: utf-8\r
-// Copyright 2008 Grégory Burri\r
-//\r
-// This file is part of Euphorik.\r
-//\r
-// Euphorik is free software: you can redistribute it and/or modify\r
-// it under the terms of the GNU General Public License as published by\r
-// the Free Software Foundation, either version 3 of the License, or\r
-// (at your option) any later version.\r
-//\r
-// Euphorik is distributed in the hope that it will be useful,\r
-// but WITHOUT ANY WARRANTY; without even the implied warranty of\r
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
-// GNU General Public License for more details.\r
-//\r
-// You should have received a copy of the GNU General Public License\r
-// along with Euphorik.  If not, see <http://www.gnu.org/licenses/>.\r
-\r
-/*jslint laxbreak:true */\r
-\r
-/**\r
-  * An object for text formatting like Wiki syntax or smiles substitution.\r
-  * TODO : improve the performance of the smiles substitution\r
-  */\r
-euphorik.Formater = function() {\r
-   this.smiles = euphorik.conf.smiles;\r
-   this.protocols = "http|https|ed2k";\r
-   \r
-   this.regexUrl = new RegExp("(?:(?:" + this.protocols + ")://|www\\.)[^ ]*", "gi");\r
-   this.regexImg = new RegExp("^.*?\\.(gif|jpg|png|jpeg|bmp|tiff)$", "i");\r
-   this.regexDomain = new RegExp("^(?:(?:" + this.protocols + ")://)(.*?)(?:$|/).*$", "i");\r
-   this.regexTestIfProtocolExists = new RegExp("^(?:" + this.protocols + ")://.*$", "i");\r
-   this.regexProtocolName = new RegExp("^(.*?)://");\r
-};\r
-\r
-/**\r
-  * Formats a nick given by the user.\r
-  * Trim and remove "{..}".\r
-  * @param nick the given nick\r
-  * @return the cleaned nick\r
-  */\r
-euphorik.Formater.prototype.formatNick = function(nick) {\r
-   return nick.replace(/\{|\}/g, "").trim();\r
-};\r
-\r
-euphorik.Formater.prototype.getSmilesHTML = function() {\r
-   var XHTML = "";\r
-   objectEach(this.smiles, function(name) {\r
-      XHTML += "<img class=\"" + name + "\" src=\"img/smileys/" + name + ".gif\" alt =\"" + name + "\" />";\r
-   });\r
-   return XHTML;\r
-};\r
-\r
-/**\r
-  * Complete fomratting process applied to a text.\r
-  *  - Remove HTML markups\r
-  *  - Substitutes wiki syntax with HTML\r
-  *  - Replaces URL with 'a' tag\r
-  *  - Replaces smiles with HTML\r
-  *  - Replaces the link to a conversation with HTML\r
-  * @m the raw message\r
-  * @nick optional, attaches the nick and the message to each images like "<pseudo> : <message>"\r
-  */\r
-euphorik.Formater.prototype.completeProcessing = function(m, nick) {\r
-   return this.processConversationLinks(this.processSmiles(this.traiterURL(this.traiterWikiSyntaxe(this.remplacerBalisesHTML(m)), nick)));\r
-};\r
-\r
-/**\r
-  * Processes all conversation links.\r
-  * The user can click on a conversation link to open it.\r
-  * A link is a number in between brackets like that : "{5F}" where '5F' is the id of the root message.\r
-  * This link will be turn in '<span class="conversationLink">{5F}</span>' which can be clicked to open the '5F' conversation.\r
-  */\r
-euphorik.Formater.prototype.processConversationLinks = function(m) {\r
-   return m.replace(\r
-      /\{\w+\}/g,\r
-      function(lien) {\r
-         return "<span class=\"conversationLink\">" + lien + "</span>";\r
-      }\r
-   );\r
-};\r
-\r
-/**\r
-  * Substitute the smiles (':)', ':P', etc.) with HTML.\r
-  * FIXME : This function is very heavy, to optimize !\r
-  * Average : 234ms\r
-  */\r
-euphorik.Formater.prototype.processSmiles = function(m) {  \r
-   objectEach(this.smiles, function(name, smiles) {\r
-      for (var i = 0; i < smiles.length; i++) {\r
-         m = m.replace(smiles[i], "<img src=\"img/smileys/" + name + ".gif\" alt =\"" + name + "\"  />");\r
-      }\r
-   });\r
-   return m;\r
-};\r
-\r
-euphorik.Formater.prototype.remplacerBalisesHTML = function(m) {\r
-   return m.replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/"/g, "&quot;");\r
-};\r
-\r
-euphorik.Formater.prototype.traiterURL = function(m, nick) {\r
-   var thisFormater = this;\r
-   var traitementUrl = function(url) {    \r
-      // si ya pas de protocole on rajoute "http://"\r
-      if (!thisFormater.regexTestIfProtocolExists.test(url)) {\r
-         url = "http://" + url;\r
-      }\r
-      var extension = thisFormater.getShort(url);\r
-      return "<a " + (extension[1] ? "title=\"" + (nick ? thisFormater.traiterPourFenetreLightBox(nick, url) + ": " : "") +  thisFormateur.traiterPourFenetreLightBox(m, url) + "\"" + " rel=\"lightbox\"" : "") + " href=\"" + url + "\" >[" + extension[0] + "]</a>";\r
-   };\r
-   return m.replace(this.regexUrl, traitementUrl);\r
-};\r
-\r
-/**\r
-  * Formatage en utilisant un sous-ensemble des règles de Textile : http://en.wikipedia.org/wiki/Textile_(markup_language).\r
-  * par exemple _italic_ devient <i>italic</i>.\r
-  */\r
-euphorik.Formater.prototype.traiterWikiSyntaxe = function(m) {\r
-   return m.replace(\r
-      /(?:^| )_(.*?)_(?:$| )/g,\r
-      function(texte, c1, c2, c3) {\r
-         return '<em>' + c1 + c2 + c3 + '</em>';\r
-      }\r
-   ).replace(\r
-      /(?:^| )\*(.*?)\*(?:$| )/g,\r
-      function(texte, c1, c2, c3) {\r
-         return '<strong>' + c1 + c2 + c3 + '</strong>';\r
-      }\r
-   );\r
-};\r
-\r
-/**\r
-  * Renvoie une version courte de l'url.\r
-  * par exemple : http://en.wikipedia.org/wiki/Yakov_Smirnoff devient en.wikipedia.org\r
-  */\r
-euphorik.Formater.prototype.getShort = function(url) {\r
-   var estUneImage = false;\r
-   var versionShort = null;\r
-   var rechercheImg = this.regexImg.exec(url);\r
-   \r
-   if (rechercheImg) {\r
-      versionShort = rechercheImg[1].toLowerCase();\r
-      if (versionShort === "jpeg") {\r
-         versionShort = "jpg"; // jpeg -> jpg\r
-      }\r
-      estUneImage = true;\r
-   } else {\r
-      var rechercheDomaine = this.regexDomain.exec(url);\r
-      if (rechercheDomaine && rechercheDomaine.length >= 2) {\r
-         versionShort = rechercheDomaine[1];\r
-      } else {\r
-         var protocolName = this.regexProtocolName.exec(url);\r
-         if (protocolName && protocolName.length >= 2) {\r
-            versionShort = protocolName[1];\r
-         }\r
-      }\r
-   }\r
-   \r
-   return [versionShort ? versionShort : "url", estUneImage];\r
- };\r
\r
-euphorik.Formater.prototype.supprimerSmiles = function(m) {\r
-   objectEach(this.smiles, function(name, smiles) {\r
-      for (var i = 0; i < smiles.length; i++) {\r
-         m = m.replace(smiles[i], "");\r
-      }\r
-   });\r
-   return m;\r
-};\r
-\r
-/**\r
-  * Traite les nick et messages à être affiché dans le titre d'une image visualisé avec lightbox.\r
-  * Supprime les smiles pour pas qu'ils puissent être remplacés par la fonction 'processSmiles'.\r
-  * TODO : trouver un moyen pour que les smiles puissent être conservés\r
-  */\r
-euphorik.Formater.prototype.traiterPourFenetreLightBox = function(M, urlCourante) {\r
-   var thisFormater = this;\r
-   var traitementUrl = function(url) {\r
-      return "[" + thisFormater.getShort(url)[0] + (urlCourante === url ? "*" : "") + "]";\r
-   };\r
-   \r
-   return this.remplacerBalisesHTML(this.supprimerSmiles(M)).replace(this.regexUrl, traitementUrl);\r
-};\r
diff --git a/js/formatter.js b/js/formatter.js
new file mode 100644 (file)
index 0000000..b1227f0
--- /dev/null
@@ -0,0 +1,183 @@
+// coding: utf-8\r
+// Copyright 2008 Grégory Burri\r
+//\r
+// This file is part of Euphorik.\r
+//\r
+// Euphorik is free software: you can redistribute it and/or modify\r
+// it under the terms of the GNU General Public License as published by\r
+// the Free Software Foundation, either version 3 of the License, or\r
+// (at your option) any later version.\r
+//\r
+// Euphorik is distributed in the hope that it will be useful,\r
+// but WITHOUT ANY WARRANTY; without even the implied warranty of\r
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
+// GNU General Public License for more details.\r
+//\r
+// You should have received a copy of the GNU General Public License\r
+// along with Euphorik.  If not, see <http://www.gnu.org/licenses/>.\r
+\r
+/*jslint laxbreak:true */\r
+\r
+/**\r
+  * An object for text formatting like Wiki syntax or smiles substitution.\r
+  * TODO : improve the performance of the smiles substitution\r
+  */\r
+euphorik.Formatter = function() {\r
+   this.smiles = euphorik.conf.smiles;\r
+   this.protocols = "http|https|ed2k";\r
+   \r
+   this.regexUrl = new RegExp("(?:(?:" + this.protocols + ")://|www\\.)[^ ]*", "gi");\r
+   this.regexImg = new RegExp("^.*?\\.(gif|jpg|png|jpeg|bmp|tiff)$", "i");\r
+   this.regexDomain = new RegExp("^(?:(?:" + this.protocols + ")://)(.*?)(?:$|/).*$", "i");\r
+   this.regexTestIfProtocolExists = new RegExp("^(?:" + this.protocols + ")://.*$", "i");\r
+   this.regexProtocolName = new RegExp("^(.*?)://");\r
+};\r
+\r
+/**\r
+  * Formats a nick given by the user.\r
+  * Trim and remove "{..}".\r
+  * @param nick the given nick\r
+  * @return the cleaned nick\r
+  */\r
+euphorik.Formatter.prototype.formatNick = function(nick) {\r
+   return nick.replace(/\{|\}/g, "").trim();\r
+};\r
+\r
+euphorik.Formatter.prototype.getSmilesHTML = function() {\r
+   var XHTML = "";\r
+   objectEach(this.smiles, function(name) {\r
+      XHTML += "<img class=\"" + name + "\" src=\"img/smileys/" + name + ".gif\" alt =\"" + name + "\" />";\r
+   });\r
+   return XHTML;\r
+};\r
+\r
+/**\r
+  * Complete formatting process applied to a text.\r
+  *  - Remove HTML markups\r
+  *  - Substitutes wiki syntax with HTML\r
+  *  - Replaces URL with 'a' tag\r
+  *  - Replaces smiles with HTML\r
+  *  - Replaces the link to a conversation with HTML\r
+  * @m the raw message\r
+  * @nick optional, attaches the nick and the message to each images like "<pseudo> : <message>"\r
+  */\r
+euphorik.Formatter.prototype.completeProcessing = function(m, nick) {\r
+   return this.processConversationLinks(this.processSmiles(this.traiterURL(this.traiterWikiSyntaxe(this.remplacerBalisesHTML(m)), nick)));\r
+};\r
+\r
+/**\r
+  * Processes all conversation links.\r
+  * The user can click on a conversation link to open it.\r
+  * A link is a number in between brackets like that : "{5F}" where '5F' is the id of the root message.\r
+  * This link will be turn in '<span class="conversationLink">{5F}</span>' which can be clicked to open the '5F' conversation.\r
+  */\r
+euphorik.Formatter.prototype.processConversationLinks = function(m) {\r
+   return m.replace(\r
+      /\{\w+\}/g,\r
+      function(lien) {\r
+         return "<span class=\"conversationLink\">" + lien + "</span>";\r
+      }\r
+   );\r
+};\r
+\r
+/**\r
+  * Substitute the smiles (':)', ':P', etc.) with HTML.\r
+  * FIXME : This function is very heavy, to optimize !\r
+  * Average : 234ms\r
+  */\r
+euphorik.Formatter.prototype.processSmiles = function(m) {\r
+   objectEach(this.smiles, function(name, smiles) {\r
+      for (var i = 0; i < smiles.length; i++) {\r
+         m = m.replace(smiles[i], "<img src=\"img/smileys/" + name + ".gif\" alt =\"" + name + "\"  />");\r
+      }\r
+   });\r
+   return m;\r
+};\r
+\r
+euphorik.Formatter.prototype.remplacerBalisesHTML = function(m) {\r
+   return m.replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/"/g, "&quot;");\r
+};\r
+\r
+euphorik.Formatter.prototype.traiterURL = function(m, nick) {\r
+   var thisFormatter = this;\r
+   var traitementUrl = function(url) {    \r
+      // si ya pas de protocole on rajoute "http://"\r
+      if (!thisFormatter.regexTestIfProtocolExists.test(url)) {\r
+         url = "http://" + url;\r
+      }\r
+      var extension = thisFormatter.getShort(url);\r
+      return "<a " + (extension[1] ? "title=\"" + (nick ? thisFormatter.traiterPourFenetreLightBox(nick, url) + ": " : "") +  thisFormateur.traiterPourFenetreLightBox(m, url) + "\"" + " rel=\"lightbox\"" : "") + " href=\"" + url + "\" >[" + extension[0] + "]</a>";\r
+   };\r
+   return m.replace(this.regexUrl, traitementUrl);\r
+};\r
+\r
+/**\r
+  * Formatage en utilisant un sous-ensemble des règles de Textile : http://en.wikipedia.org/wiki/Textile_(markup_language).\r
+  * par exemple _italic_ devient <i>italic</i>.\r
+  */\r
+euphorik.Formatter.prototype.traiterWikiSyntaxe = function(m) {\r
+   return m.replace(\r
+      /(?:^| )_(.*?)_(?:$| )/g,\r
+      function(texte, c1, c2, c3) {\r
+         return '<em>' + c1 + c2 + c3 + '</em>';\r
+      }\r
+   ).replace(\r
+      /(?:^| )\*(.*?)\*(?:$| )/g,\r
+      function(texte, c1, c2, c3) {\r
+         return '<strong>' + c1 + c2 + c3 + '</strong>';\r
+      }\r
+   );\r
+};\r
+\r
+/**\r
+  * Renvoie une version courte de l'url.\r
+  * par exemple : http://en.wikipedia.org/wiki/Yakov_Smirnoff devient en.wikipedia.org\r
+  */\r
+euphorik.Formatter.prototype.getShort = function(url) {\r
+   var estUneImage = false;\r
+   var versionShort = null;\r
+   var rechercheImg = this.regexImg.exec(url);\r
+   \r
+   if (rechercheImg) {\r
+      versionShort = rechercheImg[1].toLowerCase();\r
+      if (versionShort === "jpeg") {\r
+         versionShort = "jpg"; // jpeg -> jpg\r
+      }\r
+      estUneImage = true;\r
+   } else {\r
+      var rechercheDomaine = this.regexDomain.exec(url);\r
+      if (rechercheDomaine && rechercheDomaine.length >= 2) {\r
+         versionShort = rechercheDomaine[1];\r
+      } else {\r
+         var protocolName = this.regexProtocolName.exec(url);\r
+         if (protocolName && protocolName.length >= 2) {\r
+            versionShort = protocolName[1];\r
+         }\r
+      }\r
+   }\r
+   \r
+   return [versionShort ? versionShort : "url", estUneImage];\r
+ };\r
\r
+euphorik.Formatter.prototype.supprimerSmiles = function(m) {\r
+   objectEach(this.smiles, function(name, smiles) {\r
+      for (var i = 0; i < smiles.length; i++) {\r
+         m = m.replace(smiles[i], "");\r
+      }\r
+   });\r
+   return m;\r
+};\r
+\r
+/**\r
+  * Traite les nick et messages à être affiché dans le titre d'une image visualisé avec lightbox.\r
+  * Supprime les smiles pour pas qu'ils puissent être remplacés par la fonction 'processSmiles'.\r
+  * TODO : trouver un moyen pour que les smiles puissent être conservés\r
+  */\r
+euphorik.Formatter.prototype.traiterPourFenetreLightBox = function(M, urlCourante) {\r
+   var thisFormatter = this;\r
+   var traitementUrl = function(url) {\r
+      return "[" + thisFormatter.getShort(url)[0] + (urlCourante === url ? "*" : "") + "]";\r
+   };\r
+   \r
+   return this.remplacerBalisesHTML(this.supprimerSmiles(M)).replace(this.regexUrl, traitementUrl);\r
+};\r
index 9a72139..e5da1cb 100644 (file)
 // You should have received a copy of the GNU General Public License\r
 // along with Euphorik.  If not, see <http://www.gnu.org/licenses/>.\r
 \r
-euphorik.PageAbout = function(client, formater, util, communication) {\r
+euphorik.PageAbout = function(client, formatter, util, communication) {\r
    this.name = "about";\r
    \r
    this.client = client;\r
-   this.formater = formater;\r
-   this.util = util;
+   this.formatter = formatter;\r
+   this.util = util;\r
    this.communication = communication;\r
 };\r
 \r
index fe464b8..6b1819d 100644 (file)
 /*jslint laxbreak:true */
 
 
-euphorik.PageAdmin = function(client, formater, util, communication) {
+euphorik.PageAdmin = function(client, formatter, util, communication) {
    this.name = "admin";
 
    this.client = client;
-   this.formater = formater;
+   this.formatter = formatter;
    this.util = util;
    this.communication = communication;
 
@@ -87,8 +87,8 @@ euphorik.PageAdmin.prototype.majIPs = function() {
                '</span>|';
             ip.users.each(function(j, user) {
                XHTML += (j > 0 ? ", " : "") +
-                  '<span class="nick">' + thisPageAdmin.formater.completeProcessing(user.nick) + '</span>' +
-                  (user.login === "" ? "" : '<span class="login">(' + thisPageAdmin.formater.completeProcessing(user.login) + ')</span>');
+                  '<span class="nick">' + thisPageAdmin.formatter.completeProcessing(user.nick) + '</span>' +
+                  (user.login === "" ? "" : '<span class="login">(' + thisPageAdmin.formatter.completeProcessing(user.login) + ')</span>');
             });
             XHTML += '<span class="deban">débannir</span></div>';
          });
index 13f3375..4068222 100755 (executable)
 
 /*jslint laxbreak:true */
 
-euphorik.PageMinichat = function(client, formater, util, communication) {
+euphorik.PageMinichat = function(client, formatter, util, communication) {
    this.name = "minichat";
 
    this.client = client;
-   this.formater = formater;
+   this.formatter = formatter;
    this.util = util;
    this.communication = communication;
-   this.commandes = new euphorik.Commandes(this.client, this, this.util, this.formater);
+   this.commandes = new euphorik.Commandes(this.client, this, this.util, this.formatter);
 
    // permet d'éviter d'envoyer plusieurs messages simultanément en pressant
    // rapidement sur "enter" par exemple
@@ -65,7 +65,7 @@ euphorik.PageMinichat.prototype.charger = function() {
    $("#posterMessage input.nick").val(this.client.nick);
 
    // cet appel ne doit pas être fait avant l'appel à 'charger'
-   this.conversations = new euphorik.Conversations(this.client, this.formater, this.util, this.communication, this.fragment);
+   this.conversations = new euphorik.Conversations(this.client, this.formatter, this.util, this.communication, this.fragment);
 
    this.chargerConversationsFragment();
 
@@ -118,12 +118,12 @@ euphorik.PageMinichat.prototype.charger = function() {
    // <smiles>
    $("body").append('<div id="smiles"></div>');
    // affichage des smiles
-   $("#smiles").append(this.formater.getSmilesHTML()).children().each(
+   $("#smiles").append(this.formatter.getSmilesHTML()).children().each(
       function(i) {
          var opacityBase = $(this).css("opacity");
          $(this).click(
             function() {
-               thisPage.util.replaceSelection($("form#posterMessage input.message")[0], thisPage.formater.smiles[$(this).attr("class")][0].source.replace(/\\/g, ""));
+               thisPage.util.replaceSelection($("form#posterMessage input.message")[0], thisPage.formatter.smiles[$(this).attr("class")][0].source.replace(/\\/g, ""));
             }
          ).hover(
             function() { $(this).animate({opacity: 1}, 200); },
@@ -227,7 +227,7 @@ euphorik.PageMinichat.prototype.envoyerMessage = function(message) {
    var nick = $("form#posterMessage input.nick").val();
 
    // (un nick vide est autorisé)
-   nick = this.formater.formatNick(nick);
+   nick = this.formatter.formatNick(nick);
 
    if (nick === euphorik.conf.defaultNick) {
       this.util.messageDialog("Choose a nickname");
index c5ea5df..1a474d7 100755 (executable)
 // You should have received a copy of the GNU General Public License\r
 // along with Euphorik.  If not, see <http://www.gnu.org/licenses/>.\r
 \r
-euphorik.PageProfile = function(client, formater, util) {\r
+euphorik.PageProfile = function(client, formatter, util) {\r
    this.name = "profile";\r
 \r
    this.client = client;\r
-   this.formater = formater;\r
+   this.formatter = formatter;\r
    this.util = util;\r
 };\r
 \r
@@ -64,7 +64,7 @@ euphorik.PageProfile.prototype.chargerProfile = function() {
 \r
    $("form#profile button").click(\r
       function() {\r
-         thisPage.client.nick = thisPage.formater.formatNick($("form#profile input.nick").val());\r
+         thisPage.client.nick = thisPage.formatter.formatNick($("form#profile input.nick").val());\r
          thisPage.client.email = $("form#profile input.email").val();\r
          thisPage.client.chatOrder = $("form#profile select#chatOrder option:selected").attr("value");\r
          thisPage.client.nickFormat = $("form#profile select#affichagePseudo option:selected").attr("value");\r
index 09d3631..56be885 100755 (executable)
 // You should have received a copy of the GNU General Public License\r
 // along with Euphorik.  If not, see <http://www.gnu.org/licenses/>.\r
 \r
-euphorik.PageRegister = function(client, formater, util) {\r
+euphorik.PageRegister = function(client, formatter, util) {\r
    this.name = "register";\r
    \r
    this.client = client;\r
-   this.formater = formater;\r
+   this.formatter = formatter;\r
    this.util = util;\r
 };\r
 \r
index 5feacb5..39f89b0 100644 (file)
   *  - Print a message box to display some information for the user.\r
   *  - Set a tooltip for a HTML element.\r
   *  - Some text manipulation for input area.\r
-  * @formater An object for string format\r
+  * @formatter An object for string format\r
   */\r
-euphorik.Util = function (formater) {\r
+euphorik.Util = function (formatter) {\r
    $("#info .close").click(function() {\r
       $("#info").slideUp(50);\r
    });\r
 \r
    $("body").append('<div id="tooltipArrow"></div>').append('<div id="tooltipMessage"><p></p></div>');\r
 \r
-   this.formater = formater;\r
+   this.formatter = formatter;\r
    this.bulleActive = true;\r
 };\r
 \r
@@ -43,7 +43,7 @@ euphorik.Util.messageType = {informatif: 0, question: 1, erreur: 2};
   * @message [String] The message.\r
   * @type [euphorik.Util.messageType] The message type like 'information' or 'error'. Default is messageType.informatif.\r
   * @buttons An object where the properties are the labels and the values are functions which will be executed when a button is clicked.\r
-  * @format [bool] The message should be formated. (see 'formater.js')\r
+  * @format [bool] The message should be formated. (see 'formatter.js')\r
   * @time The time while the message is displayed. -1 for infinity.\r
   */\r
 euphorik.Util.prototype.messageDialog = function(message, type, buttons, format, time) {\r
@@ -59,7 +59,7 @@ euphorik.Util.prototype.messageDialog = function(message, type, buttons, format,
    var close = function() { $("#info").slideUp(100); };\r
    close();\r
 \r
-   $("#info .message").html(!thisUtil.formater || !format ? message : thisUtil.formater.completeProcessing(message));\r
+   $("#info .message").html(!thisUtil.formatter || !format ? message : thisUtil.formatter.completeProcessing(message));\r
 \r
    switch(type) {\r
       case euphorik.Util.messageType.informatif : $("#info #icone").attr("class", "information"); break;\r
index aabf365..6b10f4b 100755 (executable)
 % Ce module permet de gérer les données persistantes lié au site d'euphorik.ch.\r
 % Il permet d'ajouter des message, de demande les messages sur une page donnée, etc..\r
 % Ce module utilise une base mnesia.\r
-% @author G.Burri\r
 \r
 \r
 -module(euphorik_bd).\r
+-author("Greg Burri <greg.burri@gmail.com>").\r
 -export([\r
    % texte :\r
    get_texte/1,\r
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
diff --cc tools/yaws.conf
Simple merge