BerryReview |
La mala es que Twitter -siguiendo el calendario previsto por cierto- ha dejado de dar soporte a la API 1 que hasta ahora sustentaba una gran parte de los gadgets que permitían mostrar un timeline determinado de una manera personalizada (1) (2).
La siguiente, sólo regular, es que ahora hay que pasar por taquilla -es un decir- y para construir un gadget de Twitter hay que hacerlo por narices desde su página oficial previa autentificación.
Otra de igual enjundia es que desde allí sólo se pueden generar gadgets oficiales, todos grandísimos y casi nada configurables en cuanto a estética por tratarse de iframe's.
Y por fin la buena: Alguien ha tenido una idea feliz para poder solventar todo esto y ha creado un código bastante bueno que da mucho juego.
Ese alguien es Jason Mayes y fue ayer mismo cuando tropecé con su página y con este JSFiddle dónde se puede ver que todo funciona correctamente.
Esta vez no voy a explicaros con detalle que hace todo eso porque hay bastantes cosas más que comentar, pero básicamente hace uso de los widgets oficiales recortando todo lo que "sobra" y dejando sólo lo que interesa: avatar, nick, usuario, mensaje y fecha. Veamos cómo ponerlo en nuestro sitio.
1. Incluir el código principal
Este es ese código y sólo es necesario conservar los créditos del principio para poder usarlo. Atentos a las últimas líneas (// Ejemplos) que será lo único que habrá que modificar como después veremos. En Blogger lo podéis añadir como gadget tipo HTML/JavaScript.
<script type="text/javascript">
// #### Twitter Post Fetcher v7.0 ####
// Coded by Jason Mayes 2013 www.jasonmayes.com
var twitterFetcher=function(){function t(d){return d.replace(/<b[^>]*>(.*?)<\/b>/gi,function(c,d){return d}).replace(/class=".*?"|data-query-source=".*?"|dir=".*?"|rel=".*?"/gi,"")}function m(d,c){for(var f=[],e=RegExp("(^| )"+c+"( |$)"),g=d.getElementsByTagName("*"),b=0,a=g.length;b<a;b++)e.test(g[b].className)&&f.push(g[b]);return f}var u="",j=20,n=!0,h=[],p=!1,k=!0,l=!0,q=null,r=!0;return{fetch:function(d,c,f,e,g,b,a){void 0===f&&(f=20);void 0===e&&(n=!0);void 0===g&&(g=!0);void 0===b&&(b=!0); void 0===a&&(a="default");p?h.push({id:d,domId:c,maxTweets:f,enableLinks:e,showUser:g,showTime:b,dateFunction:a}):(p=!0,u=c,j=f,n=e,l=g,k=b,q=a,c=document.createElement("script"),c.type="text/javascript",c.src="//cdn.syndication.twimg.com/widgets/timelines/"+d+"?&lang=en&callback=twitterFetcher.callback&suppress_response_codes=true&rnd="+Math.random(),document.getElementsByTagName("head")[0].appendChild(c))},callback:function(d){var c=document.createElement("div");c.innerHTML=d.body;"undefined"===typeof c.getElementsByClassName&&(r=!1);var f=d=null,e=null;r?(d=c.getElementsByClassName("e-entry-title"),f=c.getElementsByClassName("p-author"),e=c.getElementsByClassName("dt-updated")):(d=m(c,"e-entry-title"),f=m(c,"p-author"),e=m(c,"dt-updated"));for(var c=[],g=d.length,b=0;b<g;){if("string"!==typeof q){var a=new Date(e[b].getAttribute("datetime").replace(/-/g,"/").replace("T"," ").split("+")[0]),a=q(a);e[b].setAttribute("aria-label",a);if(d[b].innerText)if(r)e[b].innerText=a;else{var s=document.createElement("p"), v=document.createTextNode(a);s.appendChild(v);s.setAttribute("aria-label",a);e[b]=s}else e[b].textContent=a}n?(a="",l&&(a+='<div class="user">'+t(f[b].innerHTML)+"</div>"),a+='<p class="tweet">'+t(d[b].innerHTML)+"</p>",k&&(a+='<p class="timePosted">'+e[b].getAttribute("aria-label")+"</p>")):d[b].innerText?(a="",l&&(a+='<p class="user">'+f[b].innerText+"</p>"),a+='<p class="tweet">'+d[b].innerText+"</p>",k&&(a+='<p class="timePosted">'+e[b].innerText+"</p>")):(a="",l&&(a+='<p class="user">'+f[b].textContent+ "</p>"),a+='<p class="tweet">'+d[b].textContent+"</p>",k&&(a+='<p class="timePosted">'+e[b].textContent+"</p>"));c.push(a);b++}c.length>j&&c.splice(j,c.length-j);d=c.length;f=0;e=document.getElementById(u);for(g="<ul>";f<d;)g+="<li>"+c[f]+"</li>",f++;e.innerHTML=g+"</ul>";p=!1;0<h.length&&(twitterFetcher.fetch(h[0].id,h[0].domId,h[0].maxTweets,h[0].enableLinks,h[0].showUser,h[0].showTime,h[0].dateFunction),h.splice(0,1))}}}();
function dateFormatter(date) {return date.toTimeString();}
// Ejemplo con 3 tuits a insertar en un elemento con id='tweets' con enlaces activos
twitterFetcher.fetch('347121215158222848', 'tweets', 3, true);
// Ejemplo con 5 tuits a insertar en eun elemento con id='tweets2' con enlaces activos, sin detalles de usuario, con fecha y usando un formato personalizado para la fecha
twitterFetcher.fetch('347118235830870017', 'tweets2', 5, true, false, true, dateFormatter);
// Ejemplo con 1 tuit a insertar en un elemento con id='tweets3' con enlaces activos, sin detalles de usuario ni fecha
twitterFetcher.fetch('347086380704342017', 'tweets3', 1, true, false, false);
</script>
// #### Twitter Post Fetcher v7.0 ####
// Coded by Jason Mayes 2013 www.jasonmayes.com
var twitterFetcher=function(){function t(d){return d.replace(/<b[^>]*>(.*?)<\/b>/gi,function(c,d){return d}).replace(/class=".*?"|data-query-source=".*?"|dir=".*?"|rel=".*?"/gi,"")}function m(d,c){for(var f=[],e=RegExp("(^| )"+c+"( |$)"),g=d.getElementsByTagName("*"),b=0,a=g.length;b<a;b++)e.test(g[b].className)&&f.push(g[b]);return f}var u="",j=20,n=!0,h=[],p=!1,k=!0,l=!0,q=null,r=!0;return{fetch:function(d,c,f,e,g,b,a){void 0===f&&(f=20);void 0===e&&(n=!0);void 0===g&&(g=!0);void 0===b&&(b=!0); void 0===a&&(a="default");p?h.push({id:d,domId:c,maxTweets:f,enableLinks:e,showUser:g,showTime:b,dateFunction:a}):(p=!0,u=c,j=f,n=e,l=g,k=b,q=a,c=document.createElement("script"),c.type="text/javascript",c.src="//cdn.syndication.twimg.com/widgets/timelines/"+d+"?&lang=en&callback=twitterFetcher.callback&suppress_response_codes=true&rnd="+Math.random(),document.getElementsByTagName("head")[0].appendChild(c))},callback:function(d){var c=document.createElement("div");c.innerHTML=d.body;"undefined"===typeof c.getElementsByClassName&&(r=!1);var f=d=null,e=null;r?(d=c.getElementsByClassName("e-entry-title"),f=c.getElementsByClassName("p-author"),e=c.getElementsByClassName("dt-updated")):(d=m(c,"e-entry-title"),f=m(c,"p-author"),e=m(c,"dt-updated"));for(var c=[],g=d.length,b=0;b<g;){if("string"!==typeof q){var a=new Date(e[b].getAttribute("datetime").replace(/-/g,"/").replace("T"," ").split("+")[0]),a=q(a);e[b].setAttribute("aria-label",a);if(d[b].innerText)if(r)e[b].innerText=a;else{var s=document.createElement("p"), v=document.createTextNode(a);s.appendChild(v);s.setAttribute("aria-label",a);e[b]=s}else e[b].textContent=a}n?(a="",l&&(a+='<div class="user">'+t(f[b].innerHTML)+"</div>"),a+='<p class="tweet">'+t(d[b].innerHTML)+"</p>",k&&(a+='<p class="timePosted">'+e[b].getAttribute("aria-label")+"</p>")):d[b].innerText?(a="",l&&(a+='<p class="user">'+f[b].innerText+"</p>"),a+='<p class="tweet">'+d[b].innerText+"</p>",k&&(a+='<p class="timePosted">'+e[b].innerText+"</p>")):(a="",l&&(a+='<p class="user">'+f[b].textContent+ "</p>"),a+='<p class="tweet">'+d[b].textContent+"</p>",k&&(a+='<p class="timePosted">'+e[b].textContent+"</p>"));c.push(a);b++}c.length>j&&c.splice(j,c.length-j);d=c.length;f=0;e=document.getElementById(u);for(g="<ul>";f<d;)g+="<li>"+c[f]+"</li>",f++;e.innerHTML=g+"</ul>";p=!1;0<h.length&&(twitterFetcher.fetch(h[0].id,h[0].domId,h[0].maxTweets,h[0].enableLinks,h[0].showUser,h[0].showTime,h[0].dateFunction),h.splice(0,1))}}}();
function dateFormatter(date) {return date.toTimeString();}
// Ejemplo con 3 tuits a insertar en un elemento con id='tweets' con enlaces activos
twitterFetcher.fetch('347121215158222848', 'tweets', 3, true);
// Ejemplo con 5 tuits a insertar en eun elemento con id='tweets2' con enlaces activos, sin detalles de usuario, con fecha y usando un formato personalizado para la fecha
twitterFetcher.fetch('347118235830870017', 'tweets2', 5, true, false, true, dateFormatter);
// Ejemplo con 1 tuit a insertar en un elemento con id='tweets3' con enlaces activos, sin detalles de usuario ni fecha
twitterFetcher.fetch('347086380704342017', 'tweets3', 1, true, false, false);
</script>
2. Relacionar con el gadget oficial
Ahora los datos no se pueden generar de manera independiente y hay que obtenerlos desde un widget oficial. Para vincularlo con este script utilizamos ese número largo al principio de cada función twitterFetcher. Aparecen al final del código principal y los he marcado en verde, al igual que el resto de parámetros configurables. Se trata de un identificador que os asigna Twitter cuando creáis un widget con su sistema. Para generarlo y localizarlo sigue estos pasos:
- validado en Twitter, crea un widget desde https://twitter.com/settings/widgets
- crea un nuevo widget con lo que necesites, cronología, favoritos, etc.
- si no quieres incluir las respuestas asegúrate de marcar su exclusión
- pincha en el botón "Volver a la configuración del widget" y en la nueva pantalla pincha en "Editar"
- ahora fíjate en la dirección de tu navegador, ahí tienes la id del gadget, entre /widgets/ y /edit
- tal que aquí: https://twitter.com/settings/widgets/XXXXXXXXXXXXXXXXXX/edit
Una vez lo tengáis, no olvidéis cambiarlo en el código principal. Se pueden poner tantos distintos como se quiera y ya habéis visto que yo incluí tres, aunque lo normal será dejar una sola de esas tres funciones con la configuración exacta que necesitamos.
3. Añadir una caja vacía para que sea visible
Una vez el código esté en vuestro sitio sólo hay que poner una caja vacía con la id que hayamos elegido (en los ejemplos tweets, tweets2 y tweets3) y el script se encargará de insertar en ella lo que hayamos programado en las últimas líneas.
Así, siguiendo los tres ejemplos que puse, dónde añadamos <div id="tweets"></div> nos saldrá algo así:
Con <div id="tweets2"></div> obtendremos otro tipo de datos.
Y finalmente con <div id="tweets3"></div> esto otro, un tuit simple:
Parámetros de la función twitterFetcher
Ejemplo 2: twitterFetcher.fetch('347118235830870017', 'tweets2', 5, true, false, true, dateFormatter);
Así tal cual lo puse, el código os mostrará uno de los formatos de datos que yo utilicé según uséis una id u otra, pero también eso lo podéis personalizar. De la serie de parámetros separados por comas sólo los dos primeros son obligatorios, el identificador del widget y la id de la caja dónde meteremos el resultado. Los demás son opcionales y en este orden serían:
- el número máximo de tuits a mostrar, desde 1 a 20 (por defecto 20)
- true/false según queramos que nicks, URL's y hashtags tengan enlaces o no (por defecto false)
- true/false para que se muestre el avatar, nick y el usuario (por defecto true)
- true/false para mostrar fecha/hora del tuit (por defecto true)
- nombre de la función que convertirá la fecha al formato que quieras (por defecto saldrá el formato Twitter)
Para personalizar la hora y fecha puedes definir una función que tome una fecha JavaScript como parámetro y devuelva una cadena. En el ejemplo se incluyó una llamada dateFormatter.
Estilo CSS
Pero como además de querer personalizar los datos de salida, posiblemente también os interese personalizar la estética, aquí tenéis la lista de selectores que vais a necesitar. He supuesto que utilizaréis la id tweets. Para otra id habría que sustituir ese nombre.
/* Reset */
#tweets * {}
/* Bloque del gadget */
#tweets {}
/* Lista de tuits */
#tweets ul {}
/* Cada uno de los tuits */
#tweets li {}
/* Bloque datos usuario */
#tweets .user a {}
/* Avatar */
#tweets .user img {}
/* Nick */
#tweets .user a > span {}
/* Usuario Twitter */
#tweets .user span + span {}
/* Cuerpo texto del tuit */
#tweets p {}
/* Enlaces en el tuit */
#tweets p a {}
/* Fecha */
#tweets p.timePosted {}
#tweets * {}
/* Bloque del gadget */
#tweets {}
/* Lista de tuits */
#tweets ul {}
/* Cada uno de los tuits */
#tweets li {}
/* Bloque datos usuario */
#tweets .user a {}
/* Avatar */
#tweets .user img {}
/* Nick */
#tweets .user a > span {}
/* Usuario Twitter */
#tweets .user span + span {}
/* Cuerpo texto del tuit */
#tweets p {}
/* Enlaces en el tuit */
#tweets p a {}
/* Fecha */
#tweets p.timePosted {}
Las reglas que he utilizado para las salidas que visteis en el post fueron estas:
#tweets * {margin: 0; padding: 0; border: 0;}
#tweets {margin: 20px 0; text-align:center;}
#tweets ul {display: inline-block; width: 80%; list-style:none; clear:both;}
#tweets li {margin-bottom: 5px; text-align: left; clear:both;}
#tweets .user a {float:left; width:120px;}
#tweets .user img {float: left; width: 80px;}
#tweets .user a > span {display:none;}
#tweets .user span + span { display:block; margin-top:10px;font-size: 9px;}
#tweets p.timePosted {font-size: 80%;}
#tweets {margin: 20px 0; text-align:center;}
#tweets ul {display: inline-block; width: 80%; list-style:none; clear:both;}
#tweets li {margin-bottom: 5px; text-align: left; clear:both;}
#tweets .user a {float:left; width:120px;}
#tweets .user img {float: left; width: 80px;}
#tweets .user a > span {display:none;}
#tweets .user span + span { display:block; margin-top:10px;font-size: 9px;}
#tweets p.timePosted {font-size: 80%;}
#tweets2 * {margin: 0; padding: 0; border: 0;}
#tweets2 {margin: 20px 0;}
#tweets2 ul {list-style:none; clear:both;}
#tweets2 li {display: block; margin-bottom: 5px; padding:5px; border: 1px solid #ccc; clear:both;}
#tweets2 p {font-size: 14px;}
#tweets2 p.timePosted {font-size: 80%;}
#tweets2 {margin: 20px 0;}
#tweets2 ul {list-style:none; clear:both;}
#tweets2 li {display: block; margin-bottom: 5px; padding:5px; border: 1px solid #ccc; clear:both;}
#tweets2 p {font-size: 14px;}
#tweets2 p.timePosted {font-size: 80%;}
Al tuit simple no le asigné ningún estilo así que por defecto tomó las reglas generales de la página.
Y bien, a ver si saco otro rato para daros hecho el código con el que montar aquel cacharrito para mostrar tu último tweet que a muchos os ha dejado de funcionar por este motivo.
¿Vemos otro post al azar por si le encuentras utilidad o quizás prefieres ser más metódico y suscribirte a nuestras entradas por correo? También puedes imprimir este artículo y por supuesto compartirlo en redes sociales si fue de tu agrado.
Gracias por darnos una solución!
ResponderEliminarNo hay de qué, pero yo sólo traduje y expliqué un poco ;)
EliminarYa me parecía a mí,... cuando hace unos días me desapareció el followbox de Twitter y no se solventaba de ninguna manera, supuse que algo pasaba. Espero poder reincorporarlo también; le daba vidilla a la barra lateral del blog.
ResponderEliminarDe todas formas ahora mismo de poco me serviría: estoy sin twitter por suspensión de la cuenta. ¿El motivo? Ni idea. No he infringido ni una sola de las reglas de Twitter: ni spams masivos, ni retwiteos continuados, ni contenido ilícito, ni desproporción de seguimientos, nada de nada. Sólo me queda apelar con un tiquet y esperar ¡varios días! a que se dignen darme respuesta y reabrirme la cuenta, si ellos quieren. Cuenta que me han suspendido sin darme la menor explicación: twitter no da explicaciones. Estoy empezando a hartarme de esta forma de funcionar de algunas redes sociales, la verdad. Sobre todo cuando hacen la puñeta a quienes las empleamos del modo más honesto posible y luego ves campando a sus anchas a trolls y spammers.
Perdón por la retahíla... es fruto de la indignación.
Te entiendo porque me imagino el problema que debe ser eso, pero es lo que hay. Ponte en su lugar y a ver cómo compruebas manualmente todas las reclamaciones.
EliminarPosible es, pero probable no. Al menos de momento.
ResponderEliminarJolan, a mi me paso lo mismo hace un mes, les reclame varias veces y a la semana me volvieron a poner operativa la cuenta.
ResponderEliminarUn saludo
Hola, tengo un problemilla haber si me podrias ayudar:
ResponderEliminarCuando elimino un widget desde la plantilla de blogger (de forma normal y corriente) el widget desaparece pero en la plantilla sigue apareciendo y cuando le doy a editar me sale lo sig:
Invalid widget: HTML1
Error 400
Nose como eliminarlo, he probado ha buscar en la plantilla desde los ID de los widgets pero no estan.
La plantilla que uso es la sig:
http://www.soratemplates.com/2013/01/webdesign-blogger-template.html
Para ser más gráfico me he currado una imagen jeje:
Eliminarhttp://i41.tinypic.com/2na625z.png
GRACIAS, UN SALUDO ESPERO TU RESPUESTA
SE SOLUCIONO SOLO perdon por las molestias.
EliminarPues como puedes imaginar, en este caso no ha sido ninguna molestia :)
EliminarNo me funciona, no se si estoy poniendo mal el script, pero no aparece nada cuando pongo la llamada la función :(
ResponderEliminarNo hay llamada en este caso. El script lo puedes poner en un gadget o en la plantilla y con conseguir tu propia ID de artilugio en Twitter y luego meter un DIV vacío como se explica, debería salir.
EliminarSigue sin funcionar, se ve fácil de implementar pero pongo el script en un gadget, por que en la plantilla me da un error, y pongo el DIV vació pero no aparece nada
EliminarSi no me especificas un poco más lo que haces, me resultará imposible encontrar el problema.
EliminarEl script lo debes copiar tal cual en un gadget y debajo (para comprobar que funciona) pones un div vacío con la ID tweets3 y así no tienes que añadir de momento estilo. Pero antes de guardarlo tienes que conseguir tu propia identificación de gadget en Twitter y sustituirlo en el código. No hay más.
Pues no es un gadget que yo utilice, así que lo mejor es visitar de vez en cuando la página de widgets de Twitter.
ResponderEliminarQue opina de que el 30 de este mes blogger elimina todos los blog porno
ResponderEliminarNo tengo una opinión al respecto. Ni me parece bien ni mal. Pero de todas formas la eliminación parece que es selectiva, ya que sólo es para los que obtengan un beneficio de la página, como por ejemplo los que enlazan a sitios de pago.
EliminarHola amigo habra alguna forma de hacerlos in un aplicativo utilizando http://www.twitter-rss.com/ que viene a ser el remplazo de lo que eliminaron en estos dias mira http://www.twitter-rss.com/user_timeline.php?screen_name='tamarindodn'
ResponderEliminarel unico problema es que esta en xml y no se como traerlo con ajax :( me puedes ayudar
Andaba estos días buscando una manera de obtener el RSS de Twitter, pero he probado eso y no funciona bien con un lector de feeds que hace tiempo expliqué. Lo sigo teniendo en mente, así que si descubro algo no te preocupes que lo publicaré.
EliminarEstimado buenas noches.. estoy intentando tal cual tenés las instrucciones, pero no me anda el código.
ResponderEliminarMe tengo que repetir y mandarte al comentario 6.3. Ese código funciona y la prueba está en que en esta entrada lo hace.
ResponderEliminarEstimado, ingreso al link que dejas en JSFiddle y obtengo el siguiente código, que en efecto en Internet funciona, sin embargo al bajarlo y copiarlo en un archivo .HTML, no funciona.
ResponderEliminarDesafortunadamente no me deja copiar el código.
ResponderEliminarIgual te comento que baje el .zip de la página oficial e igual no funciona, lo único que presenta son los títulos, no se que tal vez haga falta para que me funcione.
Agradezco tu ayuda. Saludos.
Este es el resultado que arroja la página
ResponderEliminarQuery 1: My latest tweet
Query 2: What people are saying about this component!
Query 3: Last 3 Twitter posts using hastag #API
Query 4: Last 3 Twitter posts using hastag #API with custom callback
Pero no muestra nada.
En el siguiente link, permite descargar un .zip de ejemplo que no me funciona, el cual se obtiene del site oficial del autor:
ResponderEliminarhttp://codepen.io/jasonmayes/pen/Ioype
No sé qué puede ocurrir, pero ¿por qué no usas el que puse aquí que sí funciona?
EliminarHola
ResponderEliminarMe gustaría saber como puedo cambiar el texto de la fecha de publicación del tweet. Ahora me lo pone en inglés y me gustaría ponerlo en castellano.
Muchas gracias por este blog!
Pues no lo sé, sinceramente, pero en el ejemplo dos tienes una forma para añadir una función que saque la fecha como tú quieras. El problema es que sale con eso del "horario romance" y para cambiarlo habría que reconstruir la función, cosa que hoy por hoy no puedo hacer porque tengo una conexión muy mala para ponerme a hacer pruebas. Si tu fueras capaz te agradecería que lo pusieras por aquí ;)
EliminarBuf, soy bastante nuevo en esto y voy un poco perdido.
EliminarSe me ocurre otra cosa que he estado buscando pero no consigo dar con ello. Es poner una línea negra de separación entre cada tweet.
Gracias de nuevo!
Usa entonces el modelo #tweets2 para que no tengas que improvisar nada y luego cambia en el estilo este...
Eliminarborder: 1px solid #ccc; clear:both;
...por un:
border-bottom: 1px solid #ccc; clear:both;
Súper útil, felicidades por estar tan actualizado! :D Gracias!!
ResponderEliminarHola Oloman, tengo puesto en una web el widget de twitter, pero me muestra 20 tweets. Quiero decir, el tweet numero 20 fue el viernes, y ya no me muestra más, pensé que se iría actualizando...
ResponderEliminarSabes que puede pasar?
Gracias por tu tiempo !!
Lo desconozco totalmente. Lo siento.
EliminarHola
ResponderEliminarSabes como hacerlo para mostrar mas de 20 tweets?
Gracias
Pues no, pero con tu pregunta me has hecho descubrir que ese es el tope de los widgets de Twitter ;)
EliminarSólo puedo decirte que reinicies que para eso es la solución informática universal. No sé explicarlo de otra manera que no sea la de la entrada, ni tampoco con la brevedad que requiere un simple comentario si no me das un problema concreto que solucionar. Prueba de nuevo con cuidado y siguiendo escrupulosamente las instrucciones.
ResponderEliminarFuncionando, esta perfecto! Solo una duda, si quisiera guardar cuada uno de los tweets en una base de mysql, como lo podria implementar???
ResponderEliminarNi idea. No he usado SQL en mi vida. Bueno, muy poco, casi nada.
EliminarBuenas tardes,
ResponderEliminarHe colocado el script en mi blog, con la tercera opción, pero nose porqué cuando publico tweets con direcciones de facebook, éstas se salen del gadget, te dejo una imagen como ejemplo:
http://img545.imageshack.us/img545/2826/pysg.png
Gracias.
Eso debe ser porque los enlaces de Facebook son demasiado largos. No sabría cómo acortarlos, así que lo más fácil es añadir en el CSS a #tweets (o al selector que uses) un overflow: hidden; para que no desborden.
EliminarHola Oloman!
ResponderEliminarEsta es una pregunta un poco fuera del gadget que nos muestras pero quería preguntarte si sabes cómo publicar un tweet con imagen, usando el update_with_media desde C# y sin librerías externas.
Gracias!
Hola
EliminarLa respuesta es no, pues no conozco la API de Twitter a ese nivel, pero para hacer eso mismo puedes utilizar las Twitter Cards.
Este comentario ha sido eliminado por el autor.
ResponderEliminarSí, pero puedes crear una función para que te muestre esa fecha como quieras. Si te fijas en el segundo ejemplo, esta sale en español gracias al contenido de la función dateFormatter(date).
EliminarEste comentario ha sido eliminado por el autor.
EliminarIncluido yo... por eso no pude extender el post explicando con detalle cómo hacer esa parte XD
EliminarEste comentario ha sido eliminado por el autor.
ResponderEliminarSin duda el widget oficial es más versátil, pues este toma sólo algunos de datos de aquel y listo. La utilidad del código de esta entrada es obtener una lista manejable desde el punto de vista del estilo de salida, pues el de Twitter no lo puedes controlar.
ResponderEliminarHola, genial aporte!!!
ResponderEliminarPero me falta una cosilla que no consigo cambiar. Sabes como puedo transformar en enlace de la foto (pic.twitter.com/OcavHs39BC) en al propia ruta de la imagen? es decir el src.
Gracias de todas formas!
No, lo siento. Eso no sé cómo conseguirlo.
EliminarHola Oloblogger me e dado cuenta que la imagen de perfil no se ve ya que este truco lo utilizo en mi pagina web hay alguna solución ?
ResponderEliminarHola ¿a qué imagen te refieres y en qué blog tienes exactamente este cacharro?
EliminarEste comentario ha sido eliminado por el autor.
ResponderEliminar