Si usamos el Helper Form para construir nuestro formularios, cuando tenemos un campo fecha, los meses no salen en inglés. ¿Como traducir esto?
Primero fijarnos en el Helper Form, como están construidos los textos traducibles
__d('cake', 'January');
Viendo en el código vemos que el archivo que va a buscar las traducciones no es el default.po ( como en otras versiones de cakePhp, sino uno llamado cake.po, habría que crear este archivo con las traducciones de todos los meses o descargar el que tengo hecho.
El último paso para que esto funcione, es configurar el cakePhp para que el idioma definido sea castellano.
Para probar ponemos el siguiente código en el controlador que necesitemos esa traducción.
A veces en cakePhp nos encontramos con que queremos usar varios modelos en un mismo controlador, y paginar los modelos.
y como es algo que me ha surgido varias veces, y siempre me tengo que para a pensar, lo dejo colgado en el blog, como una pequeña píldora.
Decimos que queremos usar dos modelos.
public $uses = array( 'User', 'Profile');
En lo que siempre fallo es que pongo $this->paginate(); pero si hay varios modelos tengo que decir que modelo quiero paginar, sino por defecto siempre será el primero en la array $uses.
un ejemplo:
public function Profile() {
$this->Profile->recursive = -1;
$this->set('profile', $this->paginate('Profile'));
}
Me he leido el libro Diseño ágil con TDD. Me ha gustado mucho la primera parte del libro algo más teórica, hablando más sobre porqué usar tests, la segunda parte del libro más práctica para mi fue algo más aburrida ya que tenía experiencia en la creación de tests.
Es un libro recomendado para todos los programadores con un nivel medio /alto, Y que quieran mejorar en sus prácticas de programación.
Voy a empezar a crear de vez en cuando posts muy cortos con un apunte una píldora, ya que ha veces me veo buscando como se hacía algo muy sencillo, que ya he hecho con anterioridad, y me pregunto porque no lo subí a mi blog.
Aquí va la primera. A veces en Cakephp nos vemos con la necesidad de pasar código html en un link o en un paginador .. usando los helpers de cake, necesitamos hacer escape, un ejemplo:
Una de las mejoras en el nuevo Estandar HTML5 aún en desarrollo, está en los Formularios, es cierto que no todos los navegadores tiene la posibilidad de ejecutar correctamente todas las funciones de HTML5, pero es bueno empezar a usar muchas de sus funciones para los navegadores más modernos, nos ahorran mucho trabajo, y siempre hay herramientas como modernizr que nos ayudarán con los navegadores que no soportan HTML5.
Placeholder
Un nuevo atributo que sirve para poner texto dentro de un input cuando está vacío, y que al tabular o pulsar dentro del input desaparezca ese mismo texto, antes para hacer esto había que usar javascript.
<input type="text" placeholder="texto ejemplo">
Autofocus
Nos ayuda a definir que input va a quedar marcado, enfocado, cuando se cargue la página.
<input id="buscar" type="text" autofocus>
Required
Un nuevo atributo que apunta que campos tiene que estar rellenos antes de enviar el formulario, para hacer esto había que crear javascript algo largo dependiendo tipos de campos y las comprobaciones que hacíamos.
En las últimas versiones de los diferentes navegadores hay la opción de geolocalización gracias a la ip donde estás conectado.
Sabiendo está opción me animé a implementarlo en un mapa de google maps. Dejó la parte del código referente a usar la geolocalización del navegador.
if (navigator.geolocation) { //Compruebo si el navegador tiene la opción de geolocalizar
navigator.geolocation.getCurrentPosition(function (position) {
// accedo a geolocalización
map.setCenter(new GLatLng(position.coords.latitude,position.coords.longitude),12);
//añado las coordenadas en la función de google maps
});
}else{
map.setCenter(new GLatLng(40,-4),5);
// si el navegador no tiene la opción de geolocalizar añadimos las coordenadas manualmente
}
Es un protocolo adoptado por muchos generadores de contenidos ( Facebook, WordPress, Youtube, Vimeo, etc..), para poder compartir su contenido de una forma social.
Esto surge por la necesidad de solucionar el problema que tenían los programadores para integrar contenido de webs externas, tenían que programar tantas llamadas soap o rest como plataformas de contenidos quisiesen integrar, cada una con sus peculiaridades, cuando al fin y al cabo solo necesitabas siempre las misma información básica.
Ventajas para programadores
La gran ventaja, es programar una sola llamada para todo tipo de contendido que se quiera integrar en la web, o si quieres que tu web sea generadora de contenido y que los demás puedan integrar tu contenido, es muy sencillo y poco costoso.
Para un programador, el css y html a veces no guarda mucha lógica, a veces es así y punto.
Así que aunque esto parezca un tontería, es algo que se olvida y es bueno tenerlo apuntado.
html, body { height: 100%; }
Importante que el height a 100% se aplique tanto en html con en body.