Miniposts

Coming soon :)

Showing posts with label Tutoriales. Show all posts
Showing posts with label Tutoriales. Show all posts

Saturday, May 16, 2009

Blogger Hacking: Comments Incrustrados + Popup

Hoy me comentó mi novia de un mini debate que se armó en lo de Halle respecto de qué es mas útil/cómodo, si tener los comentarios en una ventana emergente (popup), o incrustrados debajo del post en la página del mismo, al estilo Wordpress (también conocido en la jerga de la calle como "con el formulario").

Esto me parecía haberlo visto en otro lado, y efectivamente..., sólo que en esa ocasión el resultado no fue muy bueno. Con buen criterio e intentando hacer la gran Salomón, Halle encontró la forma de darle a sus lectores ambas opciones de manera tal de dejar contentos a todos.

Al poner los comentarios por defecto con el método de formulario, el secreto para al mismo tiempo permitir los comments en popup lo encontró simplemente usando esta URL:

https://www.blogger.com/comment.g?blogID=2751746494143071665&postID=7706357119646989421&isPopup=true

Con un poco de sentido común deducimos:

  • https://www.blogger.com/comment.g: la URL de la página que se carga en el popup con los comentarios del post.

  • ?blogID=2751746494143071665: comienza la lista de argumentos que Blogger le pasa a esa página. El primero de ellos es el BlogID, que identifica el blog del cual se quieren ver los comentarios.

  • &postID=7706357119646989421: el segundo de los argumentos es el postID, que como el nombre indica, identifica el post en particular perteneciente al BlogID anterior, del que quiero ver los comentarios.

  • &isPopup=true: y finalmente, un último argumento que simplemente hace que la página de los comentarios se abra en una nueva ventana.


Halle tuvo dos problemas:
  1. El Javascript que usa para abrir esta página en una nueva ventana, abría varias ventanas consecutivas si el lector hacía click en varios enlaces de comentarios de posts diferentes. Lo deseado es que si hay una ventana de comentarios ya abierta, se use esa misma en lugar de una nueva, para no llenar de ventanas el escritorio del sufrido usuario.

  2. Amén del punto anterior, cada ventana nueva de comentarios que se abría, no "refrescaba" la lista de comentarios, y simplemente traía los mismos una y otra vez, independientemente del post seleccionado.

Los que me conocen saben que está en mi naturaleza no dejar pasar un reto, sobre todo si a tecnología se refiere; y cuando mi novia me explicó la situación, una fuerza extraña me impulsó a resolver el (los) problema(s).

Habiendo peleado unas dos horas contra lo que parecía ser algo muy simple, finalmente encontré la solución; y aquí la comparto con ustedes:
  1. Configurar los comentarios de nuestro blog para que "por defecto" vayan incrustrados. Y digo por defecto porque en realidad el usuario medio no necesita saber cuál es el método original y cual es el hack.

  2. Vamos a editar el HTML de nuestro template. No se asusten que es fácil. Nos dirigimos a Diseño->Edición de HTML y seleccionamos "Expandir plantillas de artilugios". Hcemos click en cualquier parte del código en la caja de texto, y usando la opción Buscar de nuestro navegador (Ctrl+F), escribimos lo siguiente:

    data:post.allowComments

  3. El código debería verse como el que sigue. El suyo puede variar dependiendo de la configuración del blog y los cambios que le hayan hecho al template, pero lo al menos debería darles una idea de dónde comienza y termina el bloque de código que vamos a modificar:

    <b:if cond="data:post.allowComments">

    <a class="comment-link" href="data:post.addCommentUrl" onclick="data:post.addCommentOnclick"><b:if cond="data:post.numComments == 1">1 <data:top.commentlabel><b:else><data:post.numcomments> <data:top.commentlabelplural></data:top.commentlabelplural></data:post.numcomments></b:else></data:top.commentlabel></b:if></a>

    <a class="comment-link">Comentar (estilo Wordpress)</a>
    </b:if>

  4. Inmediatamente debajo de <b:if cond="data:post.allowComments"> agregamos el siguiente script en javascript:

    <script language='javascript'>
    function popupComment(poid)
    {
    var comuri = &quot;https://www.blogger.com/comment.g?blogID=HERE_GOES_THE_BLOG_ID_NUMBER&amp;postID=&quot; + poid + &quot;&amp;isPopup=true&quot;;

    window.open(comuri,&#39;commentpopup&#39;,&#39;titlebars=0, toolbar=0,scrollbars=1,location=0,statusbar=0, menubar=0,resizable=1,width=400,height=450&#39;);
    }
    </script>

    Tenemos que reemplazar el obvio HERE_GOES_THE_BLOG_ID_NUMBER del código de arriba con el BlogID del blog respectivo. ¿Cómo lo encontramos?, pues bien, cargamos el blog del que deseamos conocer el ID, y con un click derecho en la página elegimos "Ver código fuente" (el nombre y la ubicación de la opción puede variar según el navegador. Chicos, no intenten esto en IE).
    Nuevamente Ctrl+F y buscamos "blogID=". El número que sigue al igual es el BlogID.

    En el script usamos el método "window.open", el que crea una nueva ventana (duh). El primer argumento que recibe (comuri) contiene la URL que armamos en la línea inmediatamente superior. El segundo argumento resuelve el problema 2); ya que le da un nombre propio a la ventana para que podamos volver a llamarla nuevamente y cambiar su contenido.

  5. Un enter mas abajo, tenemos que agregar el link que abrirá el popup llamando al script que acabamos de crear:

    <a class='comment-link' expr:href='&quot;javascript:popupComment(&quot; + &quot;\&quot;&quot; + data:post.id + &quot;\&quot;&quot; + &quot;)&quot;'>

    Noten como al llamar a la función popupComment, estamos pasando como argumento el postID actual correspondiente. De esta manera el link cambiará automáticamente para cada post del blog. Esto resuelve el problema 1).

    Ahora bien, este elemento es un link común y corriente -de acuerdo, un poco más complicado de leer-, pero como todo tag HTML, necesita una apertura y un cierre. El tag <a> tiene tres partes:

    1. <a href="" ... : La apertura del tag, y el destino del enlace en el href.

    2. >Texto del Link: El cierre de la primer parte del elemento y el texto (o imagen u objeto) que convertiremos en Link.

    3. </a>: El cierre del tag.

    Hasta ahora sólo hicimos la primer parte.

    Para la segunda parte, es decir el texto descriptivo del link, tendrán que ustedes tomar una decisión. Pueden o bien dejar los comentarios "por defecto" como popups, o como formulario. En mi ejemplo el texto por default de Blogger dirigirá al popup, y el de formulario será un texto fijo escrito diréctamente en el código de la plantilla (no podremos cambiarlo desde las opciones de "Elementos de la página").
    Agregamos luego el tag de cierre. Veamos:

    <b:if cond='data:post.numComments == 1'>1 <data:top.commentLabel/><b:else/><data:post.numComments/> <data:top.commentLabelPlural/></b:if></a>

    <a class='comment-link' expr:href='data:post.addCommentUrl' expr:onclick='data:post.addCommentOnclick'>Comentar sin popup</a>

    En caso de que quieran hacer al reves, simplemente invertimos el contenido del enlace:

    Comentar con popup</a>

    <a class='comment-link' expr:href='data:post.addCommentUrl' expr:onclick='data:post.addCommentOnclick'><b:if cond='data:post.numComments == 1'>1 <data:top.commentLabel/><b:else/><data:post.numComments/> <data:top.commentLabelPlural/></b:if></a>

  6. Finalmente, todo el bloque de código nos quedaría parecido a esto:

    <b:if cond="data:post.allowComments">

    <script language='javascript'>
    function popupComment(poid)
    {
    var comuri = &quot;https://www.blogger.com/comment.g?blogID=HERE_GOES_THE_BLOG_ID_NUMBER&amp;postID=&quot; + poid + &quot;&amp;isPopup=true&quot;;

    window.open(comuri,&#39;commentpopup&#39;,&#39;titlebars=0, toolbar=0,scrollbars=1,location=0,statusbar=0, menubar=0,resizable=1,width=400,height=450&#39;);
    }
    </script>

    <a class='comment-link' expr:href='&quot;javascript:popupComment(&quot; + &quot;\&quot;&quot; + data:post.id + &quot;\&quot;&quot; + &quot;)&quot;'>

    <b:if cond='data:post.numComments == 1'>1 <data:top.commentLabel/><b:else/><data:post.numComments/> <data:top.commentLabelPlural/></b:if></a>

    <a class='comment-link' expr:href='data:post.addCommentUrl' expr:onclick='data:post.addCommentOnclick'>Comentar sin popup</a>
Guardamos la plantilla, y refrescamos la página del blog para ver los cambios.

Saturday, March 22, 2008

Arreglando Mplayer en Ubuntu Gutsy

Mis lectores menos cholulos probablemente quieran saltearse la lectura de este post, pero igualmente lo escribo porque me pareció interesante y es poco fácil de encontrar soluciones a un par de problemas de Ubuntu Gutsy .

Problema:
Las versiones de Mplayer que se pueden instalar en Ubuntu Gutsy presentan dos errores o bugs:
a) cuando abrimos un archivo de video directamente, mplayer devuelve un error de "Failed to open file" y muestra la URI del archivo sin parsear correctamente (ej: file:///home/nevermind/videos/agua%20y%20mar.avi/).
b) cuando pausamos un video o la reproducción se detiene, aparece un cartel de error que dice únicamente "gnome_screensaver_control()".

Estos, si bien son dos problemas diferentes y aislados, son los dos bugs que encontramos en el mismo programa en la misma distribución, por lo que les mostraré como solucionarlos a ambos. Desde luego que cada solución puede aplicarse por separado.

Solución:
a) Cuando nos ponemos a revisar las versiones, encontramos que el paquete mplayer actualmente instalado es la "2:1.0~rc2-0ubuntu1~gutsy1 (gutsy-backports)", en teoría este debería solucionar el problema b) ya que es la versión que vendrá con Ubuntu Hardy Heron, en la cual los bugs del screensaver estarán arreglados.
Vamos entonces a forzar este paquete a una versión anterior: la "2:1.0~rc1-0ubuntu13.1 (gutsy-updates)". Con esta podremos abrir nuestros archivos directamente desde Nautilus.

Para forzar la versión anterior, se puede hacer mediante Synaptic (Menú Paquete-> Forzar Versión...); o desde línea de comandos:

sudo apt-get install mplayer=2:1.0~rc1-0ubuntu13.1


Automáticamente nos aparecerá el Notificador de Actualizaciones indicando que existe una nueva versión de mplayer en los repositorios, lógico, pues acabamos de desactualizarlo. Al final les mostraré como evitar que esta notificación nos siga molestando.

b) Esta versión anterior, en realidad no cambia demasiado a la nueva salvo por el hecho de que anda. Pero, seguimos con el otro problema: cada vez que la reproducción del video se detiene, el molesto cartel de error aparece sin muchas más explicaciones.

Hay dos posibles soluciones; la más fácil es desactivando la opción de control del protector de pantalla en las preferencias (Mplayer -> Preferencias -> Misc -> desmarcar "Stop XScreenSaver"), pero con esto, si nos gusta que nuestro monitor deslumbre a nuestros amigos con las bonitas figuras que se generan en períodos de inactividad; es posible que el protector se active mientras estamos cómodamente en la cama viendo una película. Y no da tampoco para estar activando y desactivando el Screensaver por cada video de más de 10 minutos que queramos ver o estar moviendo frenéticamente el mouse durante toda toda la saga del Señor de los Anillos.
Vamos entonces a evitar que mplayer nos muestre esa ?advertencia?. Sin embargo esto resulta un tanto mas complicado de lo que suena.

Tendremos que toquetear el código fuente de mplayer y luego recompilarlo. Pero no se asusten porque es bastante más simple de lo que parece. Vamos paso por paso:

1) Abrimos una terminal nos hacemos root y empezamos a bajar todo lo necesario:

sudo -i
cd /tmp/
apt-get -d source mplayer
dpkg-source -x mplayer*.dsc
cd mplayer-1.0~rc1/
gedit libvo/gnome_screensaver.c

Esto nos bajará el código fuente de la versión de mplayer que tenemos instalada actualmente, lo descomprimirá y por último abrirá Gedit con el archivo que tendremos que modificar.

2) Vamos a la línea 59 y cambiamos:
cookie, G_TYPE_INVALID);
por
cookie, G_TYPE_INVALID, G_TYPE_INVALID);
Guardamos y cerramos Gedit.

3) Sólo nos queda recompilar nuestro paquete, por desgracia esto requiere de muchísimas dependencias vamos a instalarlas y luego quitarlas pues no nos harán más falta:

apt-get install build-essential sharutils liblzo-dev gawk libsmbclient-dev libxv-dev libcdparanoia0-dev libxvidcore4-dev libdv-dev liblivemedia-dev em8300-headers libdvdread-dev libdts-dev libtheora-dev libxxf86dga-dev libxxf86vm-dev liblame-dev libxvmc-dev libggi2-dev libspeex-dev libfribidi-dev libfaac-dev libaa1-dev libcaca-dev libx264-dev ladspa-sdk libaudio-dev
dpkg-buildpackage -r

Podemos ir a tomar una taza de café, pues el proceso de recompilado demora unos minutos. Vale aclarar que si obtienen un mensaje de error por dependencias luego de ejectuar dpkg-buildpackage, simplemente instalen las que falten con apt-get install.

4) Terminada la compilación, podemos borrar todas las dependencias que instalamos:

apt-get remove sharutils liblzo-dev gawk libsmbclient-dev libxv-dev libcdparanoia0-dev libxvidcore4-dev libdv-dev liblivemedia-dev em8300-headers libdvdread-dev libdts-dev libtheora-dev libxxf86dga-dev libxxf86vm-dev liblame-dev libxvmc-dev libggi2-dev libspeex-dev libfribidi-dev libfaac-dev libaa1-dev libcaca-dev libx264-dev ladspa-sdk libaudio-dev

Notarán que no quité el paquete build-essential, pueden hacerlo si quieren, pero es realmente útil dejarlo y no ocupa demasiado.

Como resultado de todo esto, tendremos en /tmp un bonito grupo de cuatro archivos .deb listos para instalarse. En realidad solo necesitamos el de mplayer ya que los demás son de mencoder y documentación:

cd ..
dpkg -i mplayer_1.0~rc1-0ubuntu13.1_i386.deb

Listo!, ya tenemos nuestro mplayer perfectamente funcional y sin carteles molestos. Un paso adicional ahora sería necesario para decirle a Ubuntu que no actualice nuestro trabajo y no nos moleste a cada rato con que hay una nueva versión. Para ello simplemente tendremos que bloquear el paquete e la versión actual.

Se puede hacer perfectamente desde Synaptic (Menú Paquete -> Bloquear Versión), pero si quieren es más rápido por línea de comandos:

echo mplayer hold | dpkg --set-selections

Y cuando queramos actualizar a una nueva versión (evidentemente posterior a la que tiene errores):

echo mplayer install | dpkg --set-selections

Eso es todo amigos, espero que les sirva.

Fuentes: Ubuntu Forums y Launchpad Patches

Thursday, August 17, 2006

Cambiar la IP de Fibertel

A muchos de ustedes les habrá pasado que tienen Fibertel contratado para Banda Chancha y quieren bajar cosas de -por ejemplo- RapidShare. La sorpresa es que tienen que esperar como una hora (y a veces mas) para bajar varias partes. La solución más simple consiste en cambiar nuestra IP, algo que la mayoría de nosotros hacemos simplemente desconectándonos y conectándonos de nuevo.

Hasta aquí todo bien, salvo que los sufridos usuarios de Fiber... no pueden, simplemente porque por mas desconectados que estén, la IP no cambia.

Con Pancho, un amigazo del laburo que paso a serlo del alma, peleamos un poquito con el tema hasta encontrarle la vuelta (el tiene Fiber, yo Arnet). Cuando finalmente logramos que la IP de Panchito sea otra, decidimos demostrarles al mundo lo grosos que somos y que además, lo sabemos :) (faaaa, cacho de humildad los chicos)

Entonces, sin más preámbulos, y directo de la máquina de Pancho... el TUTORIAL, para cambiar la IP de Fibertel.

Enjoy!