django-thumbs ya tiene nuevo sitio web: http://djangothumbnails.com. La versión 0.3 de django-thumbs funciona correctamente con la versión de desarrollo de Django actual y soluciona algunos problemas de las versiones anteriores. django-thumbs permite crear miniaturas de imágenes para los campos ImageField de tus modelos.
Para usar django-thumbs en tus modelos importa ImageWithThumbsField y reemplaza los campos ImageField por campos ImageWithThumbsField. En cada campo de imagen podrás incluir un nuevo argumento sizes que defina los tamaños de imagen de las miniaturas que deseas. Por ejemplo:
from django.db import models
from thumbs import ImageWithThumbsField
class Persona(models.Model):
foto = ImageWithThumbsField(upload_to='images', sizes=((125,125),(200,200)))
otra_foto = ImageWithThumbsField(upload_to='images')
Al subir una imagen se crearán las miniaturas definidas mediante el atributo sizes y al eliminar el objeto se eliminarán las miniaturas asociadas. Por lo demás ImageWithThumbsField funciona igual que un ImageField normal y no introduce ningún cambio en las tablas de la base de datos de tu modelo. Siempre puedes volver a utilizar ImageField en lugar de ImageWithThumbsField cuando quieras.
Para obtener la url de las miniaturas en las plantillas basta con acceder al atributo url_tamaño. En nuestro caso sería imagen.url_125x125 e imagen.url_200x200.
Publicado por Antonio Melé el Domingo 22 de Marzo de 2009 | 4 comentarios | Categorías: aplicaciones, comunidad, imágenes
Slughifi es un código que mejora las características de la función slugify de django.template.defaultfilters. Soporta muchos más caracteres internacionales con todo tipo de acentuación. Mientras que slugify elimina todos estos caracteres al generar el slug, slughifi los reemplaza por caracteres no acentuados haciendo honor a su nombre al proporcionar slugs altamente fieles a la cadena sobre la que se aplica. Fue presentado hace bastante tiempo en este hilo de la lista de correo django-users y dí con él por casualidad. Desde entonces no he dejado de utilizarlo en mis proyectos. Slughifi parece no estar disponible en la página original en la que se encontraba. Sin embargo sí lo está en el trac de django-fr y también lo podéis bajar directamente desde aquí.
Usar slughifi es realmente sencillo. Basta con hacer un import y usar la función:
from slughifi import slughifi
a = slughifi('Esta es la página web de Django en español')
# a tomará el valor 'esta-es-la-pagina-web-de-django-en-espanol'
Publicado por Antonio Melé el Martes 10 de Marzo de 2009 | 3 comentarios | Categorías: aplicaciones, descargas, internacionalización, snippets
django-localeurl es una aplicación que permite el uso de códigos de idiomas en las URLs de nuestro proyecto. Esto trae la ventaja de que cada página en cada idioma tiene una URL propia. Gracias a ello los buscadores indexan cada página en los distintos idiomas disponibles y nuestros usuarios pueden compartir las URLs de una página en el idioma que deseen. Además funciona a la perfección con el LocaleMiddleware que viene con Django y que sirve para hacer la "negociación" para descubrir el idioma del usuario en función de si ya ha seleccionado un idioma previamente, si por el contrario debe utilizar el idioma de su navegador o como último recurso el idioma por defecto de nuestro proyecto.
django-localeurl nos permitirá cambiar nuestras URLs de http://mi-proyecto.com/noticias a URLs del tipo http://mi-proyecto.com/es/noticias, http://mi-proyecto.com/de/noticias, etc. No hará falta cambiar nada en nuestra URLconf para hacerlo funcionar.
Descargamos el paquete localeurl del sitio oficial a nuestro path de Python.
Añadimos 'localeurl.middleware.LocaleURLMiddleware' al setting MIDDLEWARE_CLASSES por encima de 'django.middleware.common.CommonMiddleware'.
Importante: También deberemos situarlo por debajo de 'django.middleware.locale.LocaleMiddleware' en caso de que utilicemos LocaleMiddleware, para que éste pueda realizar la negociación de selección de idioma previamente.
Añadimos 'localeurl' a nuestras aplicaciones instaladas (setting INSTALLED_APPS).
Nos aseguramos de que el valor del setting LANGUAGE_CODE esté en el setting LANGUAGES que contiene la lista de lenguajes disponibles para nuestro proyecto. Podemos visualizar la lista de lenguajes por defecto en el código fuente de django.conf.global_settings.
Existen 3 settings que nos permiten personalizar el funcionamiento de django-localeurl: LOCALE_INDEPENDENT_PATHS, REDIRECT_LOCALE_INDEPENDENT_PATHS y PREFIX_DEFAULT_LANGUAGE.
Nos permite especificar para qué URLs no deseamos que se añada el código de lenguaje. Deberemos añadirlas como expresiones regulares. Un ejemplo:
import re
LOCALE_INDEPENDENT_PATHS = (
re.compile('^/aviso-legal/'),
re.compile('^/privacidad/'),
)
Por defecto es False. Nos permite especificar si al acceder incluyendo un código de lenguaje a alguna de las URLs especificadas en REDIRECT_LOCALE_INDEPENDENT_PATHS se debe redirigir a la misma sin código de lenguaje. Por ejemplo si al acceder a /de/privacidad/ se debe redirigir a /privacidad/.
Por defecto es True. Nos permite especificar si para el lenguaje por defecto se añade el código de idioma a la URL. Por ejemplo, si nuestro idioma por defecto es el español (LANGUAGE_CODE = 'es') y PREFIX_DEFAULT_LANGUAGE es True, la URL /noticias/ cargará directamente la vista apropiada y /noticias/es/ será redirigida a /noticias/.
Cualquier aplicación que utilice etiquetas {% url %} para las URLs en sus plantillas funcionará correctamente con django-localeurl. A parte de esto django-localeurl incluye un template tag y 2 filtros que nos aportan flexibilidad a la hora de utilizar URLs en nuestras plantillas.
Para hacerlos funcionar debemos cargarlos con load en las plantillas en las que queramos trabajar con ellos:
{% load localeurl_tags %}
El tag {% locale_url %} funciona del mismo modo que el concido {% url %} pero permitiéndonos especificar el idioma que debe utilizarse en la URL. Nos sirve para enlaces que por algún motivo queramos mostrar en un idioma concreto. Para ello si tenemos algo como:
<a href="{% url ver-articulo articulo.id %}">Ver artículo</a>
Para que el enlace apunte a un idioma concreto es tan sencillo como utilizar:
<a href="{% locale_url "en" ver-articulo articulo.id %}">Ver artículo en inglés</a>
Los filtros incluídos son chlocale y rmlocale. chlocale nos permite añadir o cambiar el código de lenguaje de una URL y rmlocale eliminar el código de lenguaje de una URL. Un ejemplo de uso:
<p>Haz <a href="{{ mi_url|chlocale:"de" }}">click aquí</a> para cambiar a alemán.</p>
<p>La url {{ otra_url }} sin código de lenguaje es {{ otra_url|rmlocale }}</p>
Publicado por Antonio Melé el Martes 30 de Diciembre de 2008 | 1 comentario | Categorías: aplicaciones, internacionalización, plantillas, urls
Suscríbete a nuestro feed RSS y al feed de la comunidad para estar al tanto de todo lo que ocurre entorno a Django.
Tú también puedes escribir en éste blog. Para hacerlo basta con que nos digas sobre qué quieres escribir un artículo relacionado con Django.
Utilizar un formulario para modificar 2 modelos
Descubriendo objetos similares por sus etiquetas