5aec5d5ee9f78cb73e53aea3d0d7f100c8155c9e
2 // Copyright 2008 Grégory Burri
4 // This file is part of Euphorik.
6 // Euphorik is free software: you can redistribute it and/or modify
7 // it under the terms of the GNU General Public License as published by
8 // the Free Software Foundation, either version 3 of the License, or
9 // (at your option) any later version.
11 // Euphorik is distributed in the hope that it will be useful,
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 // but WITHOUT ANY WARRANTY; without even the implied warranty of
14 // GNU General Public License for more details.
16 // You should have received a copy of the GNU General Public License
17 // along with Euphorik. If not, see <http://www.gnu.org/licenses/>.
19 /*jslint laxbreak:true */
22 * Permet d'executer des commandes tapées par l'utilisateur.
23 * les commandes sont entrées directement dans la ligne de saisie du message sous la forme :
24 * /<commande> <paramètres>
26 * Voici les commandes supportées :
27 * /nick <nouveau nick>
28 * Modifie le nick courant
30 euphorik
.Commandes = function(client
, pageMinichat
, util
, formater
) {
31 var thisCommandes
= this;
34 this.pageMinichat
= pageMinichat
;
36 this.formater
= formater
;
38 // construction du texte d'aide (liste des commandes) de manière statique
39 this.texteAide
= "<div id=\"aideCommandes\"><h1>Commandes</h1><ul>";
41 euphorik
.Commandes
.liste
,
42 function(name
, commande
) {
43 thisCommandes
.texteAide
+= "<li><span class=\"usage\">" + thisCommandes
.formater
.traitementComplet(commande
.usage
) + "</span> : " + thisCommandes
.formater
.traitementComplet(commande
.description
) + "</li>";
46 this.texteAide
+= "</ul></div>";
49 euphorik
.Commandes
.statut
= {ok : 0, pas_une_commande : 1, erreur_commande : 2};
51 euphorik
.Commandes
.liste
= {
53 description : "Change le nick courant",
54 usage : "/nick <nouveau nick>",
55 exec : function(args
, client
) {
57 if (args
.length
=== 0) {
58 return [euphorik
.Commandes
.statut
.erreur_commande
, 'Utilisation de la commande : ' + this.usage
];
61 client
.nick
= args
[0];
62 $("form#posterMessage input.nick").val(client
.nick
);
64 return [euphorik
.Commandes
.statut
.ok
, ''];
68 description : "Envoie le message \"C'est pas faux\"",
70 exec : function(args
, client
, pageMinichat
) {
71 pageMinichat
.envoyerMessage("C'est pas faux");
72 return [euphorik
.Commandes
.statut
.ok
, ''];
76 description : "Envoie le message \"On s'en fout !\"",
78 exec : function(args
, client
, pageMinichat
) {
79 pageMinichat
.envoyerMessage("On s'en fout !");
80 return [euphorik
.Commandes
.statut
.ok
, ''];
86 * Execute une commande.
87 * @return [statut, message], 'message' n'est utilisé que pour le statut 'erreur_commande'.
89 euphorik
.Commandes
.prototype.exec = function(chaine
) {
90 chaine
= chaine
.trim();
92 var fragments
= chaine
.split(/\s+/);
93 if (fragments
.length
=== 0 || fragments
[0].charAt(0) != '/') {
94 return [euphorik
.Commandes
.statut
.pas_une_commande
, ''];
97 var commandName
= fragments
[0].slice(1);
98 var args
= fragments
.slice(1);
100 if (commandName
=== "") {
101 return [euphorik
.Commandes
.statut
.erreur_commande
, 'La commande est vide'];
103 // commandes spéciales pour afficher l'aide : "?", "h", "help", "aide"
104 if (commandName
=== "?" || commandName
=== "h" || commandName
=== "help" || commandName
=== "aide") {
105 this.util
.messageDialog(
107 euphorik
.Util
.messageType
.informatif
,
108 {"close" : function(){}},
112 return [euphorik
.Commandes
.statut
.ok
, ''];
115 if (euphorik
.Commandes
.liste
.hasOwnProperty(commandName
)) {
116 return euphorik
.Commandes
.liste
[commandName
].exec(args
, this.client
, this.pageMinichat
);
119 return [euphorik
.Commandes
.statut
.erreur_commande
, 'La commande /' + commandName
+ ' est inconnue'];