Contenido

iMeneame, la versión de Meneame para el iPhone/iTouch

15 Oct

+ 15

Hace un tiempo vimos como se veía Digg desde el iPhone, una versión lite de Digg adaptada para dedazos. Pues ahora le toca a Meneame.

Este fin de semana he estado trasteando un poco, leyendo la documentación de Apple para optimar el contenido y los sitios web para el iPhone/iTouch y he pensado, “¿que mejor que Meneame para probar esto?”. Y me puse manos a la obra.

imeneame.JPGinoticia.JPG

Desarrollo

Está desarrollado en PHP y se basa sobre el Feed de Meneame.net, usando transformaciones XSLT para convertilo en HTML, he desarrollado una mini caché de 60 segundos de los ficheros HTML, que aliviará la transformación y lectura del feed.

Resultado 

El resultado es una versión, ligera y optimizada que los usuarios de iPhone/iTouch podrán utilizar perfectamente. Aún se haya en estado Beta, pero es bastante estable y desde el iTouch se ve perfectamente.

[Descargar][Demo][iTouch Appz]

Actualización
Se han añadido los comentarios de cada entrada, mediante la lectura del RSS correspondiente y cacheandolo transformado con el resto de la noticia.

Firefox 3.0 integrará EXSLT

6 Jun

+ 3

Esta tarde Enzo me preguntaba si sabía algo acerca de la implantación de XSLT 2 en el nuevo Firefox 3.0 y la verdad es que me ha hecho mucha curiosidad el tema y he estado indagando un poco sobre el tema.

Al parecer Firefox 3.0 no integrará, o no hay planes al respecto,  XSLT 2 aunque tampoco se limitará a mantener la versión actual (XSLT 1.0)  y añadirá EXSLT, una iniciativa de la cominidad para proveer de extensiones al XSLT, entre ellas podemos ver mejoras:

Hasta el momento estos son los datos que he encontrado, quizas decidan cambiar los planes e implementar el estandar en el último momento, pero hasta entonces, solo podemos esperar.

Freja, aplica XSL a tus XML mediante Javascript

4 May

+ 0

Ayer Ajaxian, me alegraba con un nuevo framework para aplicar templates al javascript. En este caso se trata de un framework capaz de aplicar fichero XSL a nuestros XML’s, Freja es el nombre de este framework.

¿Que es Freja?

Freja es un framework especializado para la creación te templates para aplicaciones web visuales, para que nos entendamos, nos permite transforma nuestras códigos XML, en algo legible por el usuario de forma realmente simple.

Únicamente necesitas conocer el lenguaje XSL para poder distrutar de esta librería.

Ejemplo de uso

//XML
<?xml version="1.0" encoding="utf-8"?>
<items>
	<item id="item1">
		<name>Black Bean and Smoked Tomato</name>
		<description>with Goat Cheese, a touch of Cumin and Cayenne</description>
		<price>$3.80</price>
	</item>
	<item id="item2">
		<name>Baked Brie Wheel</name>
		<description>Oven baked and served with condiments and crackers</description>
		<price>$8.85</price>
	</item>
	<item id="item3">
		<name>Pork Green Chili and Chips</name>
		<description>Homemade pork green chili served with a basket of white corn tortilla chips</description>
		<price>$7.95</price>
	</item>
</items>
//XSL
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="html" indent="yes" encoding="UTF-8"/>
<xsl:template match="/">
	<xsl:apply-templates />
</xsl:template>
<xsl:template match="items">
<div>
	<xsl:apply-templates />
	<p><a href="#" class="addLink">Add a new menu entry</a></p>
</div>
</xsl:template>
<xsl:template match="item">
<div>
	<h4><xsl:value-of select="name" /> &#xA0; <small><a href='#' id='{@id}' class='editLink'>edit</a></small></h4>
	<p><xsl:value-of select="description" /></p>
	<p><em>Price: <xsl:value-of select="price" /></em></p>
</div>
</xsl:template>
<xsl:template match="text()" />
</xsl:stylesheet>
//Javascript
// Freja Tutorial 3 - http://www.csscripting.com/freja

Freja.AssetManager.HTTP_METHOD_TUNNEL = null;
Freja.AssetManager.XSLT_SERVICE_URL = "srvc-xslt.php";	// For safari only

// Load Model and Views
var menu = getModel('models/data.xml');
var display = getView('views/display.xsl');
var edit = getView('views/edit.xsl');

// Handles 'ok' button in edit view
edit.behaviors["editForm"] = {
	onsubmit : function() {
		menu.updateFrom(edit);
		display.render(menu, "content");
		return false;
	}
};
edit.behaviors["cancelButton"] = {
	onclick : function() {
		display.render(menu, "content");
		return false;
	}
};

// Handles 'edit' link next to each menu item
display.behaviors["editLink"] = {
	onclick : function(n) {
		edit.render(menu, "content", {itemid:n.id});
		return false;
	}
};

// Handles 'add new menu item' link at the bottom of the list
display.behaviors["addLink"] = {
	onclick : function() {
		var newitem = Freja._aux.loadXML(Freja._aux.xmlize( {name: '', description:'', price: '' },"item"));
		var root = menu.document.documentElement;
		newitem = root.appendChild(Freja._aux.importNode(menu.document, newitem.documentElement));
		var newid = 'item'+root.childNodes.length;
		newitem.setAttribute('id',newid);
		edit.render(menu, "content", {itemid:newid});
		return false;
	}
};

// Let's go.
window.onload = function() {
	display.render(menu, "content");
}

[ Descargar][Demo][Tutorial]

JSLT, más templates en javascript

11 Abr

+ 5

Que javacript es un lenguaje en auge, y que gracias a este auge se está asegurando un futuro hueco en todos los navegadores, no es una novedad. Por ello cada vez más van saliendo aplicaciones, utilidades y mejoras a este lenguaje.

Cade vez más se está apostando por él y hay muchas herramientas que actualmente vulneran la accesibilidad web, pero que a mi parecer en un futuro pueden ser un buen aliado para trabajar con Javascript.

JSLT, es una muestra de ello, una librería javascript que emula el trato de XSLT en a nuestros XML. En la laboriosa y árdua tarea de parsear XML con Javascript generalmente nos encontramos con códigos infumables, por este motivo herramientas que nos facilitan esta tarea me parecen muy interesantes.

XML

<xml>
 <folder name='F1'>
  <file>A</file>
  <file>B</file>
  <file>C</file>
 </folder>
 <folder name='F2'>
  <file>D</file>
 </folder>
 <folder name='F2'>
  <file>E</file>
  <file>F</file>
 </folder>
</xml>

XSLT

<xsl:foreach select="folder">
   <xsl:variable name="c"><xsl:value-of select="count(files)" /></xsl:variable>
   Folder <xsl:value-of select="@name" /> has <xsl:value-of select="$c" /> file\n
   <xsl:foreach select="file" >\s
      File: <xsl:value-of select="text()" />
      <xsl:if test="position() != last()">,</xsl:if>
   </xsl:foreach>\n
</xsl:foreach>

JSLT

[foreach('folder'){]
   Folder {@name} has [%c] file\n
   [foreach('file'){]\s
      File: [%$'text()'.toLowerCase();]
      [if(!last)%',']
   [}]\n
[}]

Tenemos una url en donde probar nuestro JSLT y trastear un poco con él. No soporta funcionalidades como position(), pero la idea es muy buena y atractiva.

Via

Recomendaciones de la W3C para la XSLT 2.0

24 Nov

+ 1

Llevo más de 1 año programando con XSLT y desde que lo conozco he estado deseando que aparecieran cosas como estas. La nueva revisión promete y estas recomendaciones de la W3C son la prueba.

Tomando contacto con XSLT(I)

7 Ago

+ 10

XSLT o Hojas de estilos aplicadas a XML (eXtensible Stylesheet Language) , son sin duda una herramienta de futuro y importante de conocer aunque sea únicamente la base. He pensado en que podría aprovechar que es principalmente la tecnología que utilizo en el trabajo, y lo llevo bastante por mano, para hacer un pequeño manual en capítulos con lo más importante de este lenguaje.

Continua —>

Release Candidate de XSLT 2.0

14 Jun

+ 0

Presentan la Release Candidate del XLT 2.0 Por favor una variable normal!!!

SkinnerBox, generador de Feeds con estilo

16 Mar

+ 0

Via la Brujula Verde, descubro SkinnerBox, un sistema con el que transformar el código XML generado por nuestros feeds para darle un aspecto… horrible, sinceramente hoy por hoy  el diseño resultante es legible pero feo de narices.

Tambien podemos usar el sistema que usaron los chicos de Mundo Geek

XSL, FEED, RSS, wordpress

Programar en XSLT

16 Mar

+ 3

Desde hace casi 9 meses (un parto) trabajo con esta tecnología que nunca le había visto nada de especial, solo cuando ya trabajas con ella es cuando empiezas a conocer las posibilidades que tiene este lenguaje de programación y el por que se está convirtiendo en uno de los lenguajes web con más futuro.

Todo se debe al XML que trabaja por debajo de él. El XML es más que un lenguaje, es un estandard con el cual el traspaso de información ha llegado a una facilidad increible. Mediante un simple fichero XML podemos generar una estructura sólida sobre la cual podremos atacar con cualquier leguaje de programación, ya que este estandard ha sido diseñado para esta función. No voy a extenderme sobre XML ya que no es la intención que tengo para este post.

XSLT, es un lenguaje de maquetación más que un lenguaje de programación, gracias a que es un lenguaje de servidor podemos transformar nuestros XML con la finalidad de convertirlos en un HTML.

Tutoriales (XSL):

  1. Tutorial XSLT
  2. Tutorial oficial W3C
  3. Referencia XSLT
  4. Recomendación XSLT
  5. aulambra.com - XSLT: XSL Transformations
  6. Mini Como XSLT

Una de las fuerzas de este lenguaje es la gran integración con XPath, que es en sí un lenguaje basado en XML, que emula a la expresiones regulares pero atacando a árboles DOM generados en XML.

Tutoriales (XPath):

  1. Tutorial XPath (W3C)
  2. Ejemplos XPath
  3. Especificación oficial