From 7ade6a3495cd5c74c964df5ed794e110e770ed9d Mon Sep 17 00:00:00 2001 From: Greg Burri Date: Sat, 28 Jun 2008 23:09:58 +0000 Subject: [PATCH] =?utf8?q?ADD=20avancement=20sur=20la=20possibilit=C3=A9?= =?utf8?q?=20de=20r=C3=A9duire=20une=20conversation=20(pas=20fini)=20ADD?= =?utf8?q?=20possibitlit=C3=A9=20de=20montrer=20de=20mani=C3=A8re=20ostent?= =?utf8?q?atoire=20que=20l'on=20est=20un=20ekMaster=20(pour=20Bernie)?= MIME-Version: 1.0 Content-Type: text/plain; charset=utf8 Content-Transfer-Encoding: 8bit --- css/1/euphorik.css | 3 + css/1/pageMinichat.css | 9 +- doc/TODO.txt | 7 + doc/graphiques/maquette_1.svg | 1037 ++++++++++++++++------------ doc/protocole3.txt | 13 +- img/css1/logo_ek_master.png | Bin 0 -> 16975 bytes img/css1/marque_ek.png | Bin 0 -> 657 bytes index.yaws | 13 +- js/euphorik.js | 23 +- js/pageMinichat.js | 11 +- js/pageProfile.js | 243 ++++--- modules/erl/euphorik_bd.erl | 20 +- modules/erl/euphorik_bd_update.erl | 2 +- modules/erl/euphorik_daemon.erl | 85 +-- modules/erl/euphorik_protocole.erl | 58 +- modules/include/euphorik_bd.hrl | 3 +- nbproject/private/private.xml | 4 +- 17 files changed, 889 insertions(+), 642 deletions(-) create mode 100644 img/css1/logo_ek_master.png create mode 100644 img/css1/marque_ek.png diff --git a/css/1/euphorik.css b/css/1/euphorik.css index 5964a11..fa02cc0 100755 --- a/css/1/euphorik.css +++ b/css/1/euphorik.css @@ -107,6 +107,9 @@ ul#menu { height: 129px; position: absolute; } +#logo.ekMaster { + background-image: url(../../img/css1/logo_ek_master.png); +} /***** Le pied de page *****/ #footer { diff --git a/css/1/pageMinichat.css b/css/1/pageMinichat.css index faea35d..a352ff9 100755 --- a/css/1/pageMinichat.css +++ b/css/1/pageMinichat.css @@ -285,9 +285,16 @@ margin-right: 2px; font-weight: bold; } -#page.minichat div.message.ekMaster .pseudo { +#page.minichat div.message.ekMasterlight .pseudo { color: #f0df95 } + +#page.minichat div.message.ekMasterheavy .pseudo { + color: #fcd82f; + padding-left: 14px; + background: transparent url(../../img/css1/marque_ek.png) no-repeat scroll left center +} + #page.minichat div.message .pseudo .login { margin-left: 2px; font-size: 8px; diff --git a/doc/TODO.txt b/doc/TODO.txt index e54439d..c619c39 100755 --- a/doc/TODO.txt +++ b/doc/TODO.txt @@ -1,6 +1,9 @@ == TODO == === v1.1 === +* adapter au protocole pour envoyer les infos concernant les réductions des conversations +* étudier la solution SVG et le calcul de pourcentage pour la largeur des fenêtres +* un clic sur le nombre de message auquel le user répond enlève tous les mess * Gestion de l'historique au niveau du navigateur (pouvoir revenir aux pages précédentes). Utiliser un plugin jQuery si possible. Voir du coté des ancres (fragment d'url) : #ancre. * http://www.euphorik.ch/#page=chat * Revoir le système de conversation : @@ -13,10 +16,12 @@ * un bouton "créer lien" * un bouton "fermer" * Possibilité de fermer temporairement une conversation (la réduire sous la forme d'un onglet) + * etre averti lorsqu'un nouveau message arrive dans une conversation réduite * lien vers une conversation : http://www.euphorik.ch/#conv=45 * Mettre un icon (genre sablier ou truc qui tourne à la apple) lorsque le chat se charge (également lors d'un changement de page par exemple) * L'icon apparait tout en haut (absolute) * Simuler un réseau lent +* supprimer le cookie si le client n'arrive pas à s'authentifier avec (réponse négative du serveur) * Avoir une option dans le profile pour montrer son rang (ekMaster) de manière ostantatoire, discret ou caché * Mise à jour automatique de la version dans le about en fonction du tag/branche courant (lors de la mise en production) ? * Tests de monter en charge coté serveur, analyse de la complexité (regarder du coté des TODO dans le code). Utiliser eventuellement Tsung @@ -25,6 +30,8 @@ * Pouvoir récupérer son mdp (ou en générer unhttp://www.euphorik.ch/ autre) via son email. Marquer dans le profile que l'email sert à cela et n'est pas visible pas les autres personnes * (Pouvoir inverser le chat) tester la faisabilité === v1.2 === +* option dans le profile pour ouvrir les liens dans un nouveau tab +* Pouvoir auto répondre à une conversation * Possibilité d'ajouter des messages dans son profil * Les messages sont soient publics soient privées (Par défaut privées) * Un bouton "+" se trouve à coté de chaque message afin de pouvoir l'ajouter dans son profil diff --git a/doc/graphiques/maquette_1.svg b/doc/graphiques/maquette_1.svg index 3f930d9..f1ba88e 100644 --- a/doc/graphiques/maquette_1.svg +++ b/doc/graphiques/maquette_1.svg @@ -6,6 +6,7 @@ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:svg="http://www.w3.org/2000/svg" xmlns="http://www.w3.org/2000/svg" + xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" width="744.09448819" @@ -15,93 +16,147 @@ inkscape:version="0.46" sodipodi:docname="maquette_1.svg" inkscape:output_extension="org.inkscape.output.svg.inkscape" - inkscape:export-filename="/home/gburri/projets/euphorik/doc/graphiques/logo_brut2.png" + inkscape:export-filename="/tmp/plop.png" inkscape:export-xdpi="138.63565" inkscape:export-ydpi="138.63565"> + + + + + + + + + + + style="stop-color:#e36a6a;stop-opacity:1;" /> + style="stop-color:#7e1818;stop-opacity:1;" /> + style="stop-color:#767676;stop-opacity:1;" /> + style="stop-color:#801f1f;stop-opacity:1;" /> + style="stop-color:#e19671;stop-opacity:1;" /> + style="stop-color:#e19671;stop-opacity:0;" /> + style="stop-color:#00009d;stop-opacity:1;" /> + style="stop-color:#00009d;stop-opacity:0;" /> + inkscape:vp_x="192.22094 : 1229.9859 : 1" + sodipodi:type="inkscape:persp3d" /> + id="filter5374" + inkscape:collect="always"> + inkscape:collect="always" /> + + + - @@ -114,520 +169,618 @@ + inkscape:groupmode="layer" + inkscape:label="Layer 1"> + inkscape:export-filename="/home/gburri/projets/euphorik/doc/graphiques/logo_brut2.png" + ry="0" + y="32.944107" + x="46.644756" + height="287.99356" + width="453.62442" + id="rect3458" + style="fill:#f6dfc2;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" /> - + transform="scale(1,-1)" + y="-132.54002" + x="138.54781" + height="13.069962" + width="357.56439" + id="rect3474" + style="fill:#f0df95;fill-opacity:1;fill-rule:evenodd;stroke:#841919;stroke-width:0.93;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" /> - + - + [16:57:11] Pifou + inkscape:export-filename="/home/gburri/projets/euphorik/doc/graphiques/logo_brut2.png" + sodipodi:nodetypes="cccccc" + id="rect2413" + d="M 46.294131,144.76665 L 138.52377,144.76665 L 143.38513,151.20817 L 138.52377,157.38453 L 46.294131,157.38453 L 46.294131,144.76665 z" + style="fill:#841919;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1" /> [16:57:11] + What is your favourite colour ? + id="tspan3195" + sodipodi:role="line">What is your favourite colour ? - + - + [16:57:11] Pifou + id="tspan3213" + sodipodi:role="line">[16:57:11] Pifou What is your favourite colour ? + id="tspan3217" + sodipodi:role="line">What is your favourite colour ? - + [16:57:11] Pifou + id="tspan3248" + sodipodi:role="line">[16:57:11] Pifou What is your favourite colour ? + id="tspan3252" + sodipodi:role="line">What is your favourite colour ? - - - + d="M 531.65729,145.35293 C 529.36216,145.35293 527.50104,147.21405 527.50104,149.50918 C 527.50104,151.80431 529.36216,153.66543 531.65729,153.66543 C 533.95242,153.66543 535.81354,151.80431 535.81354,149.50918 C 535.81354,147.21405 533.95242,145.35293 531.65729,145.35293 z M 530.04764,146.86648 L 534.5789,149.44579 L 530.16777,152.15985 L 530.04764,146.86648 z" + style="opacity:1;fill:#841919;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:0.2;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;display:inline" /> + inkscape:export-xdpi="138.63892" + inkscape:export-filename="/home/gburri/projets/euphorik/img/css1/extraction_hover.png" + id="path3235" + d="M 531.65729,158.13031 C 529.36216,158.13031 527.50104,159.99143 527.50104,162.28656 C 527.50104,164.58169 529.36216,166.44281 531.65729,166.44281 C 533.95242,166.44281 535.81354,164.58169 535.81354,162.28656 C 535.81354,159.99143 533.95242,158.13031 531.65729,158.13031 z M 530.04764,159.64386 L 534.5789,162.22317 L 530.16777,164.93723 L 530.04764,159.64386 z" + style="opacity:1;fill:#cb2626;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:0.2;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;display:inline" /> + inkscape:export-filename="/home/gburri/projets/euphorik/img/css1/fermer_conv.png" + id="path3237" + d="M 545.24466,145.35293 C 542.94951,145.35294 541.08841,147.21405 541.08841,149.50918 C 541.08839,151.80432 542.94953,153.66543 545.24466,153.66543 C 547.53977,153.66544 549.40091,151.80431 549.40091,149.50918 C 549.40089,147.21406 547.53979,145.35293 545.24466,145.35293 z M 543.83841,146.88418 L 545.24466,148.25918 L 546.65091,146.88418 L 547.90091,148.13418 L 546.49466,149.50918 L 547.90091,150.91543 L 546.65091,152.16543 L 545.24466,150.79043 L 543.83841,152.16543 L 542.58841,150.91543 L 543.99466,149.50918 L 542.58841,148.13418 L 543.83841,146.88418 z" + style="opacity:1;fill:#841919;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:0.2;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;display:inline" /> + inkscape:export-filename="/home/gburri/projets/euphorik/img/css1/fermer_conv_hover.png" + id="path3251" + d="M 545.24466,158.13031 C 542.94951,158.13032 541.08841,159.99143 541.08841,162.28656 C 541.08839,164.5817 542.94953,166.44281 545.24466,166.44281 C 547.53977,166.44282 549.40091,164.58169 549.40091,162.28656 C 549.40089,159.99144 547.53979,158.13031 545.24466,158.13031 z M 543.83841,159.66156 L 545.24466,161.03656 L 546.65091,159.66156 L 547.90091,160.91156 L 546.49466,162.28656 L 547.90091,163.69281 L 546.65091,164.94281 L 545.24466,163.56781 L 543.83841,164.94281 L 542.58841,163.69281 L 543.99466,162.28656 L 542.58841,160.91156 L 543.83841,159.66156 z" + style="opacity:1;fill:#cb2626;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:0.2;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;display:inline" /> - + + inkscape:export-filename="/home/gburri/projets/euphorik/img/css1/fleche_reponda.png" + sodipodi:nodetypes="cccc" + id="path3254" + d="M 586.75494,158.78182 L 591.6163,165.22334 L 586.75494,171.3997 L 586.75494,158.78182 z" + style="fill:#cb2626;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;display:inline" /> dpi : 138.64 + sodipodi:role="line">dpi : 138.64 + inkscape:export-filename="/home/gburri/projets/euphorik/doc/graphiques/copier_conv.png" + id="path3260" + d="M 557.34084,145.5037 C 555.04571,145.50371 553.18459,147.36482 553.18459,149.65995 C 553.18459,151.95509 555.04571,153.8162 557.34084,153.8162 C 559.63597,153.81621 561.49709,151.95508 561.49709,149.65995 C 561.49709,147.36483 559.63597,145.5037 557.34084,145.5037 z M 557.37209,145.84745 L 558.34084,148.3162 L 560.99709,148.5037 L 558.93459,150.1912 L 559.59084,152.7537 L 557.37209,151.34745 L 555.12209,152.7537 L 555.77834,150.1912 L 553.71584,148.5037 L 556.37209,148.3162 L 557.37209,145.84745 z" + style="opacity:1;fill:#841919;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:0.2;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;display:inline" /> + inkscape:export-filename="/home/gburri/projets/euphorik/doc/graphiques/copier_conv_hover.png" + id="path3274" + d="M 556.97921,158.13031 C 554.68408,158.13032 552.82296,159.99143 552.82296,162.28656 C 552.82296,164.5817 554.68408,166.44281 556.97921,166.44281 C 559.27434,166.44282 561.13546,164.58169 561.13546,162.28656 C 561.13546,159.99144 559.27434,158.13031 556.97921,158.13031 z M 557.01046,158.47406 L 557.97921,160.94281 L 560.63546,161.13031 L 558.57296,162.81781 L 559.22921,165.38031 L 557.01046,163.97406 L 554.76046,165.38031 L 555.41671,162.81781 L 553.35421,161.13031 L 556.01046,160.94281 L 557.01046,158.47406 z" + style="opacity:1;fill:#cb2626;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:0.2;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;display:inline" /> - + id="path3464" + d="M 595.4055,142.72403 L 600.26686,149.16555 L 595.4055,155.34191 L 595.4055,142.72403 z" + style="fill:#31732f;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;display:inline" /> + + inkscape:export-filename="/home/gburri/projets/euphorik/img/css1/fleche_repondu.png" + sodipodi:nodetypes="cccc" + id="path3468" + d="M 612.29483,142.72403 L 617.15619,149.16555 L 612.29483,155.34191 L 612.29483,142.72403 z" + style="fill:#84196c;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:1;stroke-miterlimit:4;stroke-opacity:1;display:inline" /> + inkscape:export-filename="/home/gburri/projets/euphorik/trunk/img/css1/extraction_complete.png" + id="path2721" + d="M 519.27037,145.35293 C 516.97525,145.35292 515.11412,147.21405 515.11412,149.50918 C 515.11413,151.8043 516.97524,153.66543 519.27037,153.66543 C 521.56551,153.66542 523.42662,151.80431 523.42662,149.50918 C 523.42659,147.21404 521.5655,145.35293 519.27037,145.35293 z M 519.27037,146.57168 L 522.23912,149.50918 L 519.27037,152.47793 L 516.33287,149.50918 L 519.27037,146.57168 z" + style="opacity:1;fill:#841919;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:0.2;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;display:inline" /> + inkscape:export-filename="/home/gburri/projets/euphorik/trunk/img/css1/extraction_complete_hover.png" + id="path3502" + d="M 519.27037,158.13031 C 516.97525,158.1303 515.11412,159.99143 515.11412,162.28656 C 515.11413,164.58168 516.97524,166.44281 519.27037,166.44281 C 521.56551,166.4428 523.42662,164.58169 523.42662,162.28656 C 523.42659,159.99142 521.5655,158.13031 519.27037,158.13031 z M 519.27037,159.34906 L 522.23912,162.28656 L 519.27037,165.25531 L 516.33287,162.28656 L 519.27037,159.34906 z" + style="opacity:1;fill:#cb2626;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:0.2;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;display:inline" /> + inkscape:export-filename="/home/gburri/projets/euphorik/trunk/img/css1/reduire_conv.png" + id="path2467" + d="M 569.31564,145.5037 C 567.02051,145.5037 565.15939,147.36482 565.15939,149.65995 C 565.15939,151.95508 567.02051,153.8162 569.31564,153.8162 C 571.61077,153.8162 573.47189,151.95508 573.47189,149.65995 C 573.47189,147.36482 571.61077,145.5037 569.31564,145.5037 z M 569.31564,146.0662 C 569.32581,146.06628 569.33669,146.066 569.34689,146.0662 C 570.25117,146.08396 571.28545,146.57492 571.81564,147.3162 C 571.11486,147.71347 570.50225,148.35045 570.40939,149.5662 C 570.41064,149.65901 570.40276,149.76061 570.40939,149.84745 C 570.50225,151.0632 571.11486,151.70018 571.81564,152.09745 C 571.28545,152.83873 570.25117,153.32969 569.34689,153.34745 C 569.33669,153.34765 569.32581,153.34737 569.31564,153.34745 C 568.41136,153.32969 567.37707,152.83873 566.84689,152.09745 C 567.54767,151.70018 568.16028,151.0632 568.25314,149.84745 C 568.25977,149.76061 568.25189,149.65901 568.25314,149.5662 C 568.16028,148.35045 567.54767,147.71347 566.84689,147.3162 C 567.37707,146.57492 568.41136,146.08396 569.31564,146.0662 z" + style="opacity:1;fill:#841919;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:0.2;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;display:inline" /> + + inkscape:export-filename="/home/gburri/projets/euphorik/doc/graphiques/logo_brut2.png" + sodipodi:linespacing="125%" + id="text3249" + y="154.29619" + x="104.03905" + style="font-size:9px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:125%;writing-mode:lr-tb;text-anchor:start;fill:#d0df27;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;display:inline;font-family:Sans;-inkscape-font-specification:Sans" + xml:space="preserve">Pifou + + [12:47:29] Paul + Blabla blablablabla bla blabla .. + + + + id="layer2" + inkscape:groupmode="layer"> + inkscape:export-filename="/home/gburri/projets/euphorik/doc/graphiques/logo_brut2.png" + y="82.616722" + x="46.525745" + height="20.843534" + width="453.71909" + id="rect3224" + style="fill:#841919;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:1;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;display:inline" /> + inkscape:export-filename="/home/gburri/projets/euphorik/doc/graphiques/logo_brut.png" + id="path5267" + d="M 87.929756,36.448593 C 70.696656,36.448593 56.136941,47.968757 51.554756,63.729843 L 46.617256,63.729843 L 46.617256,82.823589 L 51.023506,82.823589 C 54.891953,99.630647 69.953686,112.16733 87.929756,112.16733 C 105.90583,112.16733 120.93631,99.630647 124.80476,82.823589 L 500.71101,82.823589 L 500.71101,63.729843 L 124.27351,63.729843 C 119.69133,47.968757 105.16286,36.448592 87.929756,36.448593 z" + style="opacity:0.75;fill:#000000;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;display:inline;filter:url(#filter5374)" /> + sodipodi:ry="131.82491" + sodipodi:rx="131.82491" + sodipodi:cy="399.29855" + sodipodi:cx="332.84528" + id="path2407" + style="fill:#f6dfc2;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;display:inline" + sodipodi:type="arc" /> + inkscape:export-filename="/home/gburri/projets/euphorik/doc/graphiques/logo_brut.png" + y="63.504051" + x="46.615898" + height="19.081215" + width="454.09647" + id="rect3462" + style="fill:#f6dfc2;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:2;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;display:inline" /> + id="path2383" + d="M 88.431816,40.254007 C 69.803625,40.166276 54.045002,54.16218 54.129835,75.22051 C 54.068954,91.274344 68.315564,108.10722 88.431816,107.91672 C 89.549813,107.91672 90.095216,107.88452 91.602061,107.7065 C 91.569653,103.93148 91.348366,91.115934 91.413181,87.162485 C 97.635009,91.828858 101.04085,94.097739 109.07738,100.44919 C 112.18829,97.868223 115.29373,94.591662 117.34476,90.7302 C 112.15991,87.360044 105.10581,81.72326 94.21761,73.68674 C 101.21717,66.557554 108.27196,59.995273 114.88264,53.643826 C 112.57171,50.906043 109.37619,47.542256 106.31623,45.699518 C 101.64986,50.106655 98.437833,52.770497 91.413181,59.441256 C 91.44732,54.651308 91.626799,44.013425 91.602061,40.511312 C 90.556557,40.322656 89.622719,40.270207 88.431816,40.254007 z M 79.801333,51.351275 C 79.779096,59.441488 79.924702,62.872417 79.801333,68.719324 C 74.553306,68.625903 71.396213,68.731631 64.915137,68.602009 C 65.721614,58.462795 72.73505,52.397459 79.801333,51.351275 z M 79.801333,80.324934 C 79.833045,85.530259 79.870744,89.328594 79.984647,96.135618 C 73.101686,95.143127 65.177362,88.021089 64.838379,80.002996 C 68.889043,79.921982 74.6941,80.096459 79.801333,80.324934 z" + style="fill:#841919;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:0.51327449;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;display:inline" /> euphorikeuphorik + sodipodi:role="line" /> + inkscape:export-filename="/tmp/euphorik.png" + y="79.890785" + x="524.58624" + height="36.5" + width="36.5" + id="rect3280" + style="opacity:1;fill:#e19671;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:0.93000001;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" /> + - + + + + + + + + + + id="path3648" + d="M 88.433689,40.139507 C 69.742342,40.051409 53.930364,54.094829 54.015447,75.224405 C 53.954448,91.332605 68.249193,108.22245 88.433689,108.03137 C 89.55531,108.03137 90.10262,107.99905 91.614572,107.82039 C 91.581954,104.03258 91.360034,91.173654 91.425073,87.20679 C 97.667896,91.888882 101.08528,94.16553 109.14899,100.53843 C 112.27055,97.94871 115.38639,94.661105 117.44437,90.786576 C 112.24197,87.404961 105.16399,81.749161 94.23898,73.685453 C 101.26227,66.532188 108.34084,59.947617 114.97399,53.574618 C 112.65526,50.827622 109.44896,47.452314 106.37864,45.603442 C 101.69625,50.025479 98.473488,52.69837 91.425073,59.391733 C 91.459366,54.585378 91.639306,43.911649 91.614572,40.397592 C 90.565479,40.208389 89.628528,40.155766 88.433689,40.139507 z M 79.773893,51.274418 C 79.751523,59.39193 79.897565,62.834445 79.773893,68.701128 C 74.508029,68.607413 71.340332,68.713545 64.837364,68.583467 C 65.646435,58.409945 72.683597,52.324004 79.773893,51.274418 z M 79.773893,80.3461 C 79.805722,85.568999 79.843563,89.380263 79.957676,96.210306 C 73.051558,95.214426 65.100465,88.068256 64.760264,80.023173 C 68.824617,79.941776 74.649439,80.116888 79.773893,80.3461 z" + style="fill:#000000;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:0.51327449;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1;display:inline" /> + + id="layer3" + inkscape:groupmode="layer"> - + chat + id="tspan3199" + sodipodi:role="line">chat profile + id="tspan3203" + sodipodi:role="line">profile about + id="tspan3207" + sodipodi:role="line">about - + troll de la semaine : - - + id="tspan3468" + sodipodi:role="line">troll de la semaine : diff --git a/doc/protocole3.txt b/doc/protocole3.txt index eb661a3..dc3ff4b 100644 --- a/doc/protocole3.txt +++ b/doc/protocole3.txt @@ -93,9 +93,9 @@ ou "nick_format" : "nick" | "login" | "nick_login", "view_times" : true | false, "view_tooltips" : true | false, - // "main_page" : 1, - "conversations" : [3, 8], - "ek_master" : true | false + "conversations" : [{"root" : 3, "minimized" : true}, + "ek_master" : true | false, + "ostentatious_master" : "invisible" | "light" | "heavy" } @@ -120,8 +120,8 @@ c -> s "nick_format" : "nick" | "login" | "nick_login", "view_times" : true | false, "view_tooltips" : true | false, - "main_page" : 1, - "conversations" : [3, 8] + "conversations" : [{"root" : 3, "minimized" : true}, + "ostentatious_master" : "invisible" | "light" | "heavy" } s -> c @@ -151,7 +151,8 @@ Si "main_page" est absent alors est vaut 1. "answer_to" : [ { "id" : 123, "nick" : "Pierre", "login" : "pierre_45" } ] - "ek_master" : true | false + "ek_master" : true | false, + "ostentatious_master" : "invisible" | "light" | "heavy" } c -> s diff --git a/img/css1/logo_ek_master.png b/img/css1/logo_ek_master.png new file mode 100644 index 0000000000000000000000000000000000000000..8e03c9340ac5cc3bbb18fbf0726f9fa179566bbb GIT binary patch literal 16975 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 - euphorik.ch + % prédéfinit la feuille de style out(A) -> CSS = case euphorik_bd:css_from_user_cookie(yaws_api:find_cookie_val("cookie", A)) of undefined -> "css/1/euphorik.css"; @@ -35,10 +36,16 @@
- + + % permet de prédéfinir la "class" du logo pour un ekMaster.. + out(A) -> + Est_ek_master = euphorik_bd:is_ek_master_from_cookie(yaws_api:find_cookie_val("cookie", A)), + {ehtml, {'div', [{id, "logo"}] ++ if Est_ek_master -> [{class, "ekMaster"}]; true -> [] end}}. + +

diff --git a/js/euphorik.js b/js/euphorik.js index 596ded4..7e611db 100755 --- a/js/euphorik.js +++ b/js/euphorik.js @@ -597,6 +597,7 @@ Client.prototype.resetDonneesPersonnelles = function() this.pagePrincipale = 1 this.ekMaster = false + this.ostentatiousMaster = "light" // les conversations, une conversation est un objet possédant les attributs suivants : // - root (entier) @@ -720,7 +721,7 @@ Client.prototype.getJSONConversations = function() { var conversations = new Array() for (var i = 0; i < this.conversations.length; i++) - conversations.push(this.conversations[i].root) + conversations.push({root : this.conversations[i].root, minimized : this.conversations[i].reduit}) return conversations } @@ -737,7 +738,8 @@ Client.prototype.getJSONProfile = function() "nick_format" : this.nickFormat, "view_times" : this.viewTimes, "view_tooltips" : this.viewTooltips, - "conversations" : this.getJSONConversations() + "conversations" : this.getJSONConversations(), + "ostentatious_master" : this.ostentatiousMaster } } @@ -788,6 +790,7 @@ Client.prototype.setStatut = function(statut) this.statut = statut this.majMenu() + this.majLogo() } /** @@ -879,6 +882,7 @@ Client.prototype.chargerDonnees = function(data) this.nickFormat = data["nick_format"] this.viewTimes = data["view_times"] this.viewTooltips = data["view_tooltips"] + this.ostentatiousMaster = data["ostentatious_master"] // la page de la conversation principale this.pagePrincipale = 1 @@ -886,10 +890,11 @@ Client.prototype.chargerDonnees = function(data) // les conversations this.conversations = data["conversations"] for (var i = 0; i < this.conversations.length; i++) - this.conversations[i] = {root : this.conversations[i], page : 1} + this.conversations[i] = {root : this.conversations[i].root, page : 1, reduit : this.conversations[i].minimized} this.majBulle() this.majCssSelectionee() + //this.majLogo() } } @@ -984,6 +989,18 @@ Client.prototype.majCssSelectionee = function() } } +/** + * Change la "class" du logo en fonction du statut de ekMaster. + */ +Client.prototype.majLogo = function() +{ + if (this.ekMaster) + $("#logo").addClass("ekMaster") + else + $("#logo").removeClass("ekMaster") +} + + Client.prototype.slap = function(userId, raison) { var thisClient = this diff --git a/js/pageMinichat.js b/js/pageMinichat.js index 4068f35..574dedd 100755 --- a/js/pageMinichat.js +++ b/js/pageMinichat.js @@ -302,6 +302,7 @@ function Message(client, formateur, element) this.systeme = element["system"] // est-ce un message 'système' ? this.setRepondA(element["answer_to"]) // un ensemble de reponse (voir Reponse) indexé par l'id du message de la reponses this.ekMaster = element["ek_master"] + this.degreeOstentatoire = element["ostentatious_master"] } /** @@ -387,8 +388,8 @@ Message.prototype.XHTML = function(messagePair, pre) // construit l'identifiant de la personne var identifiant = this.client.nickFormat == "nick" || this.login == "" ? this.formateur.traitementComplet(this.pseudo) : - (this.client.nickFormat == "login" ? this.formateur.traitementComplet(message.login) : - this.formateur.traitementComplet(this.pseudo) + "(" + this.formateur.traitementComplet(message.login) +")" ) + (this.client.nickFormat == "login" ? this.formateur.traitementComplet(this.login) : + this.formateur.traitementComplet(this.pseudo) + "(" + this.formateur.traitementComplet(this.login) +")" ) var XHTMLrepondA = "" var debut = true @@ -406,7 +407,7 @@ Message.prototype.XHTML = function(messagePair, pre) (this.clientARepondu ? " repondu" : "") + (this.estUneReponse ? " reponse" : "") + (this.systeme ? " systeme" : "") + - (this.ekMaster ? " ekMaster" : "") + + (this.ekMaster ? " ekMaster" + this.degreeOstentatoire : "") + "\">" + "

" + "[" + this.date + "]" + @@ -662,8 +663,8 @@ Conversation.prototype.attacherEventsSurMessage = function(element) // l'id du message var idMess = this.idMessageFromString($(element).attr("id")) - this.util.infoBulle("Extraction de la conversation à partir de ce message", $(".extraire", this)) - this.util.infoBulle("Extraction de la conversation complète", $(".extraireCompletement", this)) + this.util.infoBulle("Extraction de la conversation à partir de ce message", $(".extraire", element)) + this.util.infoBulle("Extraction de la conversation complète", $(".extraireCompletement", element)) var thisConversation = this $(".lienConv", element).click( diff --git a/js/pageProfile.js b/js/pageProfile.js index 14ca09c..cb29198 100755 --- a/js/pageProfile.js +++ b/js/pageProfile.js @@ -14,58 +14,61 @@ // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License -// along with Euphorik. If not, see . - -function PageProfile(client, formateur, util) -{ - this.nom = "profile" - - this.client = client - this.formateur = formateur - this.util = util -} - -PageProfile.prototype.contenu = function() -{ - // pourquoi ? - return "" -} - -PageProfile.prototype.charger = function() -{ - $("#page").html(this.getHTML()) - - // en fonction du statut - if (this.client.authentifie()) - this.chargerProfile() - else - this.chargerLogin() - - $("#page form#profile").submit(function(){return false}) -} - -PageProfile.prototype.chargerProfile = function() +// along with Euphorik. If not, see . + +function PageProfile(client, formateur, util) +{ + this.nom = "profile" + + this.client = client + this.formateur = formateur + this.util = util +} + +PageProfile.prototype.contenu = function() +{ + // pourquoi ? + return "" +} + +PageProfile.prototype.charger = function() +{ + $("#page").html(this.getHTML()) + + // en fonction du statut + if (this.client.authentifie()) + this.chargerProfile() + else + this.chargerLogin() + + $("#page form#profile").submit(function(){return false}) +} + +PageProfile.prototype.chargerProfile = function() { var thisPage = this $("form#profile input.login").val(this.client.login) $("form#profile input.pseudo").val(this.client.pseudo) - $("form#profile input.email").val(this.client.email) - $("form#profile input#viewTooltips").attr("checked", this.client.viewTooltips) - $("form#profile input#viewTimes").attr("checked", this.client.viewTimes) - - $("form#profile select#affichagePseudo option").removeAttr("selected") - $("form#profile select#affichagePseudo option[value=" + this.client.nickFormat + "]").attr("selected", "selected") + $("form#profile input.email").val(this.client.email) + $("form#profile input#viewTooltips").attr("checked", this.client.viewTooltips) + $("form#profile input#viewTimes").attr("checked", this.client.viewTimes) + + $("form#profile select#degreeOstentatoire option").removeAttr("selected") + $("form#profile select#degreeOstentatoire option[value=" + this.client.ostentatiousMaster + "]").attr("selected", "selected") + $("form#profile select#affichagePseudo option").removeAttr("selected") + $("form#profile select#affichagePseudo option[value=" + this.client.nickFormat + "]").attr("selected", "selected") $("form#profile button").click( function() { thisPage.client.pseudo = thisPage.formateur.filtrerInputPseudo($("form#profile input.pseudo").val()) - thisPage.client.email = $("form#profile input.email").val() - thisPage.client.nickFormat = $("form#profile select#affichagePseudo option:selected").attr("value") - thisPage.client.viewTooltips = $("form#profile input#viewTooltips").attr("checked") - thisPage.client.viewTimes = $("form#profile input#viewTimes").attr("checked") + thisPage.client.email = $("form#profile input.email").val() + thisPage.client.nickFormat = $("form#profile select#affichagePseudo option:selected").attr("value") + thisPage.client.ostentatiousMaster = $("form#profile select#degreeOstentatoire option:selected").attr("value") + thisPage.client.viewTooltips = $("form#profile input#viewTooltips").attr("checked") + thisPage.client.viewTimes = $("form#profile input#viewTimes").attr("checked") var password = $("form#profile input.password").val() var passwordRe = $("form#profile input.passwordRe").val() @@ -81,80 +84,90 @@ PageProfile.prototype.chargerProfile = function() if(!thisPage.client.flush()) thisPage.util.messageDialogue("Impossible de mettre à jour votre profile, causes inconnues", messageType.erreur) - else - { - thisPage.util.messageDialogue("Votre profile a été mis à jour") - thisPage.pages.afficherPage("minichat") + else + { + thisPage.util.messageDialogue("Votre profile a été mis à jour") + thisPage.pages.afficherPage("minichat") } } - ) -} - -PageProfile.prototype.chargerLogin = function() -{ - var thisPage = this - - $("#page form#profile button").click( - function() - { - if(thisPage.client.connexionLogin($("form#profile input.login").val(), thisPage.util.md5($("form#profile input.password").val()))) + ) +} + +PageProfile.prototype.chargerLogin = function() +{ + var thisPage = this + + $("#page form#profile button").click( + function() + { + if(thisPage.client.connexionLogin($("form#profile input.login").val(), thisPage.util.md5($("form#profile input.password").val()))) { - // TODO afficher un message "ok" - thisPage.pages.afficherPage("minichat") - } - } - ) -} - -PageProfile.prototype.getHTML = function() -{ -return '\ -\ - \ - \ - \ - \ - \ - \ - \ - \ - ' + - (this.client.authentifie() ? '\ - \ - \ - \ - \ - \ - \ - \ - \ - \ - \ - \ - \ - \ - \ - \ - \ - \ - \ - \ - \ - \ - \ - \ - ' : '') + '\ - \ - \ - \ -
login
password
password re
pseudo
e-mail
Affichage des identifiants\ - \ -
Afficher les infos bulles
Afficher les dates
\ -
\ -' -} - + // TODO afficher un message "ok" + thisPage.pages.afficherPage("minichat") + } + } + ) +} + +PageProfile.prototype.getHTML = function() +{ +return '\ +
\ + \ + \ + \ + \ + \ + \ + \ + \ + ' + + (this.client.authentifie() ? '\ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + ' + + (this.client.ekMaster ? '\ + ' : '') + + '\ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + ' : '') + '\ + \ + \ + \ +
login
password
password re
pseudo
e-mail
Degrée d\'ostentation\ + \ +
Affichage des identifiants\ + \ +
Afficher les infos bulles
Afficher les dates
\ +
\ +
' +} + diff --git a/modules/erl/euphorik_bd.erl b/modules/erl/euphorik_bd.erl index be46ab2..d84b0fb 100755 --- a/modules/erl/euphorik_bd.erl +++ b/modules/erl/euphorik_bd.erl @@ -33,7 +33,7 @@ % users : nouveau_user/2, nouveau_user/3, - set_profile/10, + set_profile/11, update_date_derniere_connexion/1, update_ip/2, update_pseudo_user/2, @@ -47,6 +47,7 @@ user_by_mess/1, toggle_ek_master/1, css_from_user_cookie/1, + is_ek_master_from_cookie/1, % messages :e nouveau_message/3, @@ -192,8 +193,11 @@ nouveau_user(Login, Password, Cookie) -> % Mise à par Cookie les autres peuvent être undefined ce qui veut dire qu'ils ne seront pas modifié. -set_profile(Cookie, Login, Password, Pseudo, Email, Css, Nick_format, View_times, View_tooltips, Conversations) -> - if Nick_format =:= nick; Nick_format =:= login; Nick_format =:= nick_login -> +% Conversation est de type [{int(), bool()}] où l'entier est la racine, le booléen indique si la conversation est réduite ou non +% Ostentatious_master peut valoir invisible, light ou heavy +set_profile(Cookie, Login, Password, Pseudo, Email, Css, Nick_format, View_times, View_tooltips, Conversations, Ostentatious_master) -> + if Nick_format =:= nick; Nick_format =:= login; Nick_format =:= nick_login, + Ostentatious_master =:= invisible; Ostentatious_master =:= light; Ostentatious_master =:= heavy -> resultat_transaction(mnesia:transaction( fun() -> case user_by_cookie(Cookie) of @@ -213,7 +217,8 @@ set_profile(Cookie, Login, Password, Pseudo, Email, Css, Nick_format, View_times nick_format = Nick_format, view_times = View_times, view_tooltips = View_tooltips, - conversations = if is_list(Conversations) -> Conversations; true -> User#user.conversations end + conversations = if is_list(Conversations) -> Conversations; true -> User#user.conversations end, + ostentatious_master = Ostentatious_master }, mnesia:write(User_modifie), ok @@ -396,6 +401,13 @@ css_from_user_cookie(Cookie) -> undefined end. + +is_ek_master_from_cookie(Cookie) -> + case user_by_cookie(Cookie) of + {ok, #user{ek_master = true}} -> true; + _ -> false + end. + user_by_login_password(Login, Password) -> resultat_transaction(mnesia:transaction( diff --git a/modules/erl/euphorik_bd_update.erl b/modules/erl/euphorik_bd_update.erl index 14a85c9..1f04ab0 100644 --- a/modules/erl/euphorik_bd_update.erl +++ b/modules/erl/euphorik_bd_update.erl @@ -78,7 +78,7 @@ patch(1) -> mnesia:transform_table( user, fun({user, Id, Cookie, Pseudo, Login, Password, Email, Date_creation, Date_derniere_connexion, Css, Nick_format, View_times, View_tooltips, Indice_flood, _Page_principale, Conversations, Ek_master, Last_ip}) -> - {user, Id, Cookie, Pseudo, Login, Password, Email, Date_creation, Date_derniere_connexion, Css, Nick_format, View_times, View_tooltips, reverse, Indice_flood, lists:map(fun({C, _}) -> C end, Conversations), Ek_master, Last_ip} + {user, Id, Cookie, Pseudo, Login, Password, Email, Date_creation, Date_derniere_connexion, Css, Nick_format, View_times, View_tooltips, light, reverse, Indice_flood, lists:map(fun({R, _}) -> {R, false} end, Conversations), Ek_master, Last_ip} end, record_info(fields, user), user diff --git a/modules/erl/euphorik_daemon.erl b/modules/erl/euphorik_daemon.erl index 274a2c2..548eab1 100755 --- a/modules/erl/euphorik_daemon.erl +++ b/modules/erl/euphorik_daemon.erl @@ -16,25 +16,25 @@ % You should have received a copy of the GNU General Public License % along with Euphorik. If not, see . % -% Module tournant en background s'occupant periodiquement de certaines tâches : +% Module tournant en background s'occupant periodiquement de certaines tâches : % - sélection du prochain troll chaque semaine % - rechargement des modules lors d'une mise en production -% Date : 05.11.2007 +% Date : 05.11.2007 % @author G.Burri --module(euphorik_daemon). --export([start/1, reload_euphorik/0, loop/0]). --include("../include/euphorik_defines.hrl"). +-module(euphorik_daemon). +-export([start/1, reload_euphorik/0, loop/0]). +-include("../include/euphorik_defines.hrl"). - -% Démarre le démon + +% Démarre le démon start(_A) -> register(euphorik_daemon, self()), - loop(). + loop(). + - -loop() -> +loop() -> % on attend une minute de plus pour prevenir une dérive négative (ce qui pourrait engendrer une double élection) receive switch -> % permet de substituer le code du process par un nouveau code, voir reload_euphorik @@ -42,38 +42,39 @@ loop() -> after 1000 * (trunc(temps_prochaine_election() + 60)) -> euphorik_bd:elire_troll(), euphorik_daemon:loop() - end. - - -% Renvoie le nombre de seconde qu'il reste jusque au prochain lundi à l'heure donnée (l'heure est sur 24heures) -% 86400 est le nombre de seconde dans un jour -temps_prochaine_election() -> - {Date, {H,M,S}} = calendar:local_time(), - Delta = (?JOUR_ELECTION_TROLL - 1) * 86400 + ?HEURE_ELECTION_TROLL * 60 * 60 - -((calendar:day_of_the_week(Date) - 1) * 86400 + H * 60 * 60 + M * 60 + S), - % attention au cas où deux dates (maintenant et la date d'élection) ne se trouvent pas dans la même semaine. - if Delta =< 0 -> Delta + 7 * 86400; true -> Delta end. - - -% Recharge tous les modules euphorik. -% Appelé lors d'une mise en prod. -% TODO : récupérer les noms à partir des .beam dans /modules/ebin -reload_euphorik() -> - lists:foreach( - fun(M) -> - code:purge(M), - code:load_file(M) - end, - [ - euphorik_common, - euphorik_minichat_conversation, - euphorik_protocole, - euphorik_requests, - euphorik_bd, - euphorik_bd_update, - euphorik_daemon - ] + end. + + +% Renvoie le nombre de seconde qu'il reste jusque au prochain lundi à l'heure donnée (l'heure est sur 24heures) +% 86400 est le nombre de seconde dans un jour +temps_prochaine_election() -> + {Date, {H,M,S}} = calendar:local_time(), + Delta = (?JOUR_ELECTION_TROLL - 1) * 86400 + ?HEURE_ELECTION_TROLL * 60 * 60 + -((calendar:day_of_the_week(Date) - 1) * 86400 + H * 60 * 60 + M * 60 + S), + % attention au cas où deux dates (maintenant et la date d'élection) ne se trouvent pas dans la même semaine. + if Delta =< 0 -> Delta + 7 * 86400; true -> Delta end. + + +% Recharge tous les modules euphorik. +% Appelé lors d'une mise en prod. +% TODO : récupérer les noms à partir des .beam dans /modules/ebin +reload_euphorik() -> + lists:foreach( + fun(M) -> + code:purge(M), + code:load_file(M) + end, + [ + euphorik_common, + euphorik_minichat_conversation, + euphorik_protocole, + euphorik_requests, + euphorik_bd, + euphorik_bd_update, + euphorik_daemon + ] ), % changement du code du daemon - euphorik_daemon ! switch. + euphorik_daemon ! switch, + ok. \ No newline at end of file diff --git a/modules/erl/euphorik_protocole.erl b/modules/erl/euphorik_protocole.erl index dac7d03..3f9d7a1 100755 --- a/modules/erl/euphorik_protocole.erl +++ b/modules/erl/euphorik_protocole.erl @@ -74,19 +74,27 @@ erreur_register_flood() -> % Un utilisateur se logge (avec un couple {login, mot de passe}) login([{login, Login}, {password, Password}], IP) -> - loginUser(euphorik_bd:user_by_login_password(Login, Password), IP); + case euphorik_bd:user_by_login_password(Login, Password) of + {ok, User} -> + loginUser(User, IP); + _ -> + timer:sleep(?TEMPS_ATTENTE_ERREUR_LOGIN), + erreur("Couple login/pass introuvable") + end; % Un utilisateur se logge (avec un cookie) login([{cookie, Cookie}], IP) -> - loginUser(euphorik_bd:user_by_cookie(Cookie), IP). + case euphorik_bd:user_by_cookie(Cookie) of + {ok, User} -> + loginUser(User, IP); + _ -> + timer:sleep(?TEMPS_ATTENTE_ERREUR_LOGIN), + erreur("Authentification impossible par cookie") + end. -loginUser({ok, User}, IP) -> +loginUser(User, IP) -> euphorik_bd:update_ip(User#user.id, IP), euphorik_bd:update_date_derniere_connexion(User#user.id), - json_reponse_login_ok(User); -loginUser(_, _) -> - % ajoute un délais d'attente - timer:sleep(?TEMPS_ATTENTE_ERREUR_LOGIN), - erreur("Couple login/pass introuvable"). + json_reponse_login_ok(User). % Renvoie un string() représentant un cookie en base 36. Il y a 10^32 possibillités. @@ -113,14 +121,22 @@ profile( {nick_format, Nick_format_str}, {view_times, View_times}, {view_tooltips, View_tooltips}, - {conversations, {array, Conversations_json}} + {conversations, {array, Conversations_json}}, + {ostentatious_master, Ostentatious_master} ] ) -> - % virage des messages qui n'existent pas - Conversations = lists:dropwhile( - fun(Message_id) -> - not euphorik_bd:message_existe(Message_id) + % décomposition de la strucure JSON + Conversations = lists:foldr( + fun({struc, [{root, Racine}, {minimized, Reduit}]}, A) -> + % virage des messages qui n'existent pas + Message_exite = euphorik_bd:message_existe(Racine), + if Message_exite -> + [ {Racine, Reduit} | A]; + true -> + A + end end, + [], Conversations_json ), % TODO : pas très beau, mieux vaut construire un #user @@ -134,7 +150,8 @@ profile( list_to_atom(Nick_format_str), View_times, View_tooltips, - Conversations) of + Conversations, + list_to_atom(Ostentatious_master)) of ok -> json_reponse_ok(); login_deja_pris -> @@ -658,8 +675,14 @@ json_reponse_login_ok(User) -> {nick_format, atom_to_list(User#user.nick_format)}, {view_times, User#user.view_times}, {view_tooltips, User#user.view_tooltips}, - {conversations, {array, User#user.conversations } }, - {ek_master, User#user.ek_master} + {conversations, {array, lists:map( + fun({Racine, Reduit}) -> + {struct, [{root, Racine}, {minimized, Reduit}]} + end, + User#user.conversations + )}}, + {ek_master, User#user.ek_master}, + {ostentatious_master, atom_to_list(User#user.ostentatious_master)} ] }. @@ -692,5 +715,6 @@ json_message(Mess, Repond_a, User) -> end, Repond_a )}}, - {ek_master, User_mess#user.ek_master} + {ek_master, User_mess#user.ek_master}, + {ostentatious_master, atom_to_list(User_mess#user.ostentatious_master)} ]}. diff --git a/modules/include/euphorik_bd.hrl b/modules/include/euphorik_bd.hrl index b779583..1a12872 100755 --- a/modules/include/euphorik_bd.hrl +++ b/modules/include/euphorik_bd.hrl @@ -74,9 +74,10 @@ nick_format = nick, %atom(), peut valoir 'nick', 'login' ou 'nick_login' view_times = true, view_tooltips = true, + ostentatious_master = light, % peut valoir invisible, light ou heavy. seulement pour ek_master message_order = reverse, % can be normal or reverse indice_flood = 0, % integer() est incrémenté lorsque l'utilisateur envoie trop rapidement des messages. - conversations = [], % [integer()], la liste des messages correspondant au conversation + conversations = [], % [{integer(), bool}], la liste des messages correspondant au conversation {racine, reduite?} ek_master = false, last_ip = undefined % integer(), undefined si inconnu }). diff --git a/nbproject/private/private.xml b/nbproject/private/private.xml index 3212e36..da5c656 100644 --- a/nbproject/private/private.xml +++ b/nbproject/private/private.xml @@ -4,8 +4,8 @@ js/pageMinichat.js 237 - 901 - 1150 + 906 + 1155 -- 2.45.2