Retomamos la segunda parte de la conversión de HTML5 a Wordpress, en esta segunda parte configuraremos el archivo single.php que es el archivo que muestra los post completos, sus comentarios y un formulario para que los usuarios puedan enviar comentarios a la entrada.
Descargas y resultados del tutorial
- Demo Online (un demo de la plantilla en wordpress)
- Descargar Theme y PSD (descarga la plantilla hasta este punto del tutorial y sus PSD)
Aspecto final de la página single.php
Tutoriales anteriores
- Tutorial 1: Diseñar template de Wordpress en Photoshop
- Tutorial 2: Template de Wordpress: pasar de PSD a HTML5
- Tutorial 3: Template de Wordpress: pasar HTML5 a Wordpress, parte 1
En esta segunda parte trataremos los siguientes temas:
- Dividir la estructura del archivo index.php en: (Header.php, index.php, footer.php y sidebar.php)
- Configuración del archivo single.php
- Agregar Navegación de los posts desde el archivo single.php
- Configurar los comentarios de cada post
Dividir el archivo index.php
Para iniciar con el tutorial vamos a dividir el archivo index.php en tres partes(header.php, footer.php y sidebar.php). El código que tenemos en el archivo index.php será dividido entre estos tres archivos, como se muestra en la siguiente imagen.Para empezar crearemos los tres archivos antes mencionados y deberíamos de tener una estructura de archivos hasta este punto del tutorial como muestra la siguiente imagen.
Código para el header.php
Empezaremos a trabajar con el header.php, para ello cortaremos del index.php el siguiente trozo de código y lo pegaremos en el header.php, no explicaré todo el código ya que lo explicamos anteriormente en la codificación del index, además lo dejo comentado por si no se acuerdan para qué sirve cada trozo de código.Código :
<!DOCTYPE HTML> <html <?php language_attributes(); ?>> <head> <!-- METAS --> <meta charset="<?php bloginfo( 'charset' ); //cambiamos <meta charset="utf-8"> por su ?>" /> <!-- /METAS --> <title><?php /*Con este código agregamos a wordpress un título que cambia dependiendo * del lugar donde te encuentres en el blog. También puede utilizar <?php bloginfo('name'); ?> * Muestra en la etiqueta <title> el nombre de lo que está viendo, la forma en la que lo estamos creando * es mucho más amigable para los navegadores ya que muestra información de cada lugar que estés. */ global $page, $paged; wp_title( '|', true, 'right' ); // Agrega el nombre del blog. bloginfo( 'name' ); // Agrega la descripción del blog, en la página principal. $site_description = get_bloginfo( 'description', 'display' ); if ( $site_description && ( is_home() || is_front_page() ) ) echo " | $site_description"; // Agrega el número de página si es necesario: if ( $paged >= 2 || $page >= 2 ) echo ' | ' . sprintf( __( 'Page %s', 'twentyten' ), max( $paged, $page ) ); ?> </title> <!-- CSS --> <link href='<?php bloginfo( 'stylesheet_url' ); ?>' rel="stylesheet" /> <!-- /CSS --> <!-- RSS & PINGBACKS --> <link rel="pingback" href="<?php bloginfo( 'pingback_url' ); ?>" /> <link rel="alternate" type="application/rss+xml" title="<?php bloginfo( 'name' ); ?>" href="<?php bloginfo( 'rss2_url' ); ?>" /> <!-- /RSS & PINGBACKS --> <?php /* Para compatibilizar HTML5 con navegadores antiguos */ ?> <!--[if IE]> <script src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script> <![endif]--> <?php /*Siempre agrege wp_head antes del cierre de </ head> de su thema, * si no lo agrega puede que muchos plugins no funcionen ya que * lo utilizan este gancho (hook)para agregar elementos al head. */ wp_head(); ?> <script> $(document).ready(function() { //Slider Show var pager = true;//ESTABLECE A FALSE PARA DESACTIVAR LA PAGINACIÓN. var oSlider = $('#slider-wrapper'); if(oSlider.length > 0) { oSlider.tinycarousel( { pager: true, //paginación interval: true, //Auto Play duration: 300 //retardo de pase de imagen }); } }); </script> </head> <body <?php body_class(); ?>> <!-- WRAPPER --> <div id="wrapper" class="clearfix"> <!-- NAV#TOP-MENU --> <nav id="top-menu" role="navigation" class="clearfix"> <!-- ul Menú --> <?php wp_nav_menu( array('theme_location' => 'MenuPrincipal', 'container' => 'false' )); ?> <!-- final ul Menú--> <!-- .Top-search --> <div class="top-search"> <form method="get" id="searchform" action="#"> <input type="text" value="" name="s" id="s" placeholder="Buscar..." /> <button id="searchsubmit">Go</button> </form> </div> <!-- Final .Top-search --> </nav> <!-- FINAL NAV#TOP-MENU --> <!-- HEADER --> <header id="header" class="clearfix"> <?php $query = new WP_Query(); $query->query('posts_per_page=5&cat=9'); $post_count = $query->post_count; ?> <!-- #slider-wrapper --> <div id="slider-wrapper"> <!-- .viewport --> <div class="viewport clearfix"> <div> <ul class="overview"> <?php if ($query->have_posts()) : while ($query->have_posts()) : $query->the_post(); ?> <li> <a href="<?php the_permalink();?>"><?php the_post_thumbnail('slider-thumbnail') ?></a> </li> <?php endwhile; ?> </ul> </div> </div> <!-- Final .viewport --> <!-- .slider-controls --> <div class="slider-controls"> <!-- .pager --> <ul class="pager"> <?php for($i = 0; $i < $post_count; $i++ ){ echo'<li><a href="#" class="pagenum" rel="'.$i.'">'.$i.'</a></li>';}?> </ul> <!-- Final .pager --> <!-- .button-left , .button-right --> <div class="button-left"> <a class="buttons prev" href="#">left</a> <span></span> </div> <div class="button-right"> <a href="#" class="buttons next">right</a> <span></span> </div> <!-- Final .button-left , .button-right --> </div> <!-- Final .slider-controls --> <?php endif?> </div> <!-- Final #slider-wrapper --> <!-- #logo --> <h1 id="logo"> <a href="<?php echo home_url(); ?>" title="<?php bloginfo('description')?>"> <?php bloginfo('name');?> </a> </h1> <!-- Final #logo --> <!-- .vermasVideos --> <div class="vermasVideos"><a href="#">Ver Más videos</a></div> <!-- Final .vermasVideos --> </header> <!-- FINAL HEADER --> <!-- #MAIN --> <div id="main" class="clearfix"> <!-- .main-content --> <div class="main-content clearfix">En el mismo lugar del index.php donde cortamos ese código incluiremos el archivo header.php mediante la función get_header(), con esto ya tenemos el header incluido en el index.php desde un archivo externo.
Código :
<?php get_header(); ?>
Código para el footer.php
Para el footer.php haremos lo mismo, del index.php cortaremos el siguiente código y lo pegaremos en el archivo footer.php que creamos anteriormente.Código :
</div> <!-- final .main-content --> </div> <!-- FINAL #MAIN --> <!-- #FOOTER --> <footer id="footer" class="clearfix" role="contentinfo"> <!-- .Copy --> <p class="copy">©2010 Music.com. All rights reserved.</p> <!-- Final .Copy --> <!-- Menu Footer --> <?php wp_nav_menu( array('theme_location' => 'MenuFooter', 'container' => 'false' )); ?> <!-- Final Menu Footer --> <!-- .GoTop --> <a href="#" class="goTop">Ir Arriba</a> <!-- Final .GoTop --> </footer> <!-- FINAL #FOOTER --> </div> <!-- FINAL WRAPPER --> <?php wp_footer();?> </body> </html>Para terminar con el footer sólo nos queda llamar el archivo footer, para ello utilizaremos la función get_footer() desde el archivo index.php en el mismo lugar donde cortamos el código en el index.php.
Código :
<?php get_footer(); ?>
Código para el sidebar.php
Para el sidebar lo mismo, cortamos el siguiente código del archivo index.php y lo pegamos en el archivo sidebar.php.Código :
<!-- #sidebar --> <aside id="sidebar" role="complementary"> <!-- Widget Últimas Noticias --> <aside class="widget" id="ultimas-noticias"> <h3>Últimas Noticias</h3> <ul> <li> <a href="#">Alejandro Sanz</a> <p>Miércoles - 8-09-2010</p> <p>Palacio de los Deportes Madrid</p> </li> <li> <a href="#">Alejandro Sanz</a> <p>Miércoles - 8-09-2010</p> <p>Palacio de los Deportes Madrid</p> </li> <li> <a href="#">Alejandro Sanz</a> <p>Miércoles - 8-09-2010</p> <p>Palacio de los Deportes Madrid</p> </li> </ul> </aside> <!-- Final Widget Últimas Noticias --> <!-- Widget Últimos Videos --> <aside class="widget" id="ultimos-videos"> <h3>Últimas Noticias</h3> <ul> <li class="clearfix"> <img src="images/tmp/list-video1.jpg" alt=""> <p><a href="#">Mi princesa</a></p> <p>David Bisbal</p> </li> <li class="clearfix"> <img src="images/tmp/list-video2.jpg" alt=""> <p><a href="#">Desde Cuando</a></p> <p>Alejandro Sanz</p> </li> <li class="clearfix"> <img src="images/tmp/list-video3.jpg" alt=""> <p><a href="#">Mientes</a></p> <p>Camila</p> </li> <li class="clearfix"> <img src="images/tmp/list-video4.jpg" alt=""> <p><a href="#">Bad Romance</a></p> <p>Lady Gaga</p> </li> </ul> </aside> <!-- Final Widget Últimos Videos --> <!-- Widget Contáctenos --> <aside class="widget"> <h3>Contáctenos</h3> <form id="wiget-contact" action="#" method="post" name="Widget-Contact"> <p><input id="form-nombre" type="text" placeholder="Nombre" name="Nombre"></p> <p><input id="form-email" type="email" placeholder="Email" name="Email"></p> <p><textarea id="form-mensage" cols="0" rows="8" placeholder="Su Mensaje..." name="Mensaje"></textarea></p> <p><button id="form-enviar">Enviar</button></p> </form> </aside> <!-- Final Widget Contáctenos --> </aside> <!-- Final #sidebar -->Para llamar el sidebar desde el index.php utilizaremos en el mismo lugar donde cortamos el código anterior la función get_sidebar().
Código :
<?php get_sidebar(); ?>
Las funciones utilizadas para incluir estos archivos nos dan algunas funcionalidades más avanzadas, esta función acepta parámetros que en algún momento pueden ser de mucha ayuda.
Por ejemplo: si queremos tener un sidebar en distintas situaciones podemos crear un archivo para cada situación, si creamos un archivo sidebar-404.php, podemos incluir este archivo cuando la página que se muestra sea la página 404.php utilizando la misma función pasándole como parámetro el nombre del archivo(get_sidebar('404')) y haciendo uso de las funciones condicionales de wordpress para gestionar la visualización de los archivos.
Esto solo es un ejemplo, lo mismo puede hacerlo con los demás archivos, para ampliar la información sobre esto puede visitar la información completa en codex wordpress
Con esto ya tenemos los archivos separados cada uno en su fichero independiente e incluido en el index mediante sus respectivas funciones. Lo siguiente será configurar el archivo single.php que es donde se visualizarán las entradas.
Configurar el archivo single.php
Nuestro single.php es bastante simple, estará formado por el contenido, una imagen representativa del post, el listado de comentarios, el formulario para comentar y el sidebar.Para crear el archivo single.php duplicamos el index.php y cambiamos su nombre a single.php, este archivo prácticamente tiene lo que necesitamos, solo eliminaremos algunas líneas de código y agregaremos otras.
Contenido del post
En el single.php buscamos las líneas correspondientes al loop. Tienen una consulta personalizada que no necesitamos en el single.php, con lo cual eliminaremos las líneas de código del loop y lo cambiaremos por el loop simple de wordpress.Código :
<?php if ( have_posts() ) : while ( have_posts() ) : the_post(); ?>
Para mostrar el contenido completo del post sustituiremos la función the_excerpt(); por la función the_content();. A esta función se le puede pasar algunos parámetros muy interesantes en los cuales no entraré en detalle, pero pueden verlo en el codex de wordpress si quieren ampliar la información sobre esta función.
Código :
<?php the_content();?>
En el index.php teníamos un código de error que se mostraba si no había post en la base de datos, en el single.php no necesitamos este trozo de código, con lo cual lo eliminaremos y editaremos el final del loop, ya que contiene parte del código que no utilizaremos, el código debe quedar como en la imagen siguiente.
Código :
<!-- Eliminamos todo este código --> <?php endwhile; else: ?> <article class="posts"> <p><h2><?php _e('Ha ocurrido un error.'); ?></h2></p> <p><?php _e('Disculpe, no existen post relacionados con su criterio de busqueda'); ?></p> <?php get_search_form();?> </article> <?php endif; ?> <!-- Se sustituye por este --> <?php endwhile; ?>
Por último eliminaremos el número de comentarios y el botón "leer más" que se utilizaban en el index, para ello eliminaremos el siguiente trozo de código.
Navegación de los posts
Debajo del contenido del post agregaremos dos botones de navegación los cuales enlazarán la entrada anterior y la siguiente a la actual, para ello utilizaremos las funciones previous_post_link() y next_post_link() las cuales nos proporcionan dichos enlaces a sus respectivas entradas, solo debemos agregar el siguiente código html después del final de la etiqueta article class="posts".Código :
<section class="newer-older"> <p class="older"><?php previous_post_link('%link', '« Post Anterior') ?> <p class="newer"><?php next_post_link('%link', 'Siguiente Post »') ?></p> </section>
Código Css para la navegación
Código :
/* =ESTILOS PARA LA PÁGINA SINGLE -------------------------------------------------------------- */ /*Parrafos*/ .entry-content P{ line-height: 20px; margin-bottom: 15px; } /* Navegador de post */ .newer-older{ display: block; height: 30px; clear: both; padding: 20px 0; } .older{float: left; text-align:left;} .newer{float: right; text-align:right;} .newer-older p{ display:inline-block; width: 150px; background: #c4c4c4; border-radius: 5px; box-shadow: 1px 1px 0px 0px #e1e1e1; overflow:hidden; } .newer-older p a{ display: inline-block; height: 30px; line-height:30px; padding: 0 20px; color: #777777; text-decoration: none; font-weight: bold; text-shadow: 1px 1px 0 #e1e1e1; width:110px; } .newer-older p:hover{background:#c9c8c8;} .older:hover a{ color: #6d9110; margin-left: -10px; } .newer:hover a{ color: #6d9110; margin-right: -10px; }El resultado sería algo como la imagen siguiente:
Configurar los comentarios de cada post
A mi entender creo que ésta es una de las partes que más puede sufrir un usuario que se inicia en el desarrollo de theme de wordpress, al listar los comentarios no tienen más que utilizar la función correspondiente para realizar esa llamada, hasta aquí todo fácil, pero ¿y si quieres crear una lista personalizada de comentarios? Si quieres utilizar esta opción de crear una función personalizada para listar los comentarios de wordpress podemos utilizar este artículo: (Mostrar de forma personalizada los comentarios en wordpress), que pone a nuestra disposición el codex de wordpress.No me atrevo a meterme a explicarlo ya que sería alargar bastante más el tutorial y creo que ese tema se merece un tutorial ya que es un tema que puede ampliarse bastante, en nuestro caso utilizaremos la salida por defecto de los comentarios y lo adaptaremos a nuestro gusto solo utilizando CSS, vamos a ello.
Para listar los comentarios y el formulario para enviarlos utilizaremos la función comments_template( '', true );, esta función muestra los comentarios tanto en las páginas como en la página single.
Utilizar solo esta función tiene sus ventajas y sus desventajas
Esta función utiliza el archivo comment-template.php ubicado en la carpeta wp-include, para mostrar los comentarios y el formulario.Ventajas:
- Con la llamada de una simple función obtenemos los comentarios y el formulario de envío.
- Más simplicidad en el código de nuestra plantilla.
- No hace falta ser un experto ni saber de programación para hacer esto.
Des Ventajas:
- Con esta función estamos utilizando el código fuente de wordpress con lo cual cualquier actualización puede afectarnos a la visualización de nuestra estructura.
- Tenemos pocas opciones para cambiar la estructura, o salida HTML que nos proporciona esta función.
- Si editamos el código saliente al actualizar tu wordpress perderás todos los cambios que hay realizado en la estructura de estos archivos.
Código :
<?php comments_template( '', true ); ?>
Esta función nos da como resultado la siguiente estructura HTML la cual adaptaremos a la plantilla a continuación con CSS.
Tomando como referencia los selectores (ID y class) que nos proporciona esta función aplicaremos CSS.
Css para el listado de comentarios
Código :
/* ESTILOS PARA LISTA DE COMENTARIOS*/ h3#comments{ font-size: 16px; color: #437201; background:url(images/title-bg.png) no-repeat left top; height: 55px; line-height: 55px; margin: 0 0 15px -22px; padding-left:20px; color: #e1e1e1; } .commentlist{ border: medium none !important; list-style: none outside none; margin-left: 0; } .commentlist li .children > li{ padding-left: 25px; } .comment-awaiting-moderation{color:red;text-align:center;} .commentlist li > .children #respond h3{margin: 0 0 15px -46px;} .commentlist li > .children li > .children #respond h3{margin: 0 0 15px -71px;/*nivel 2 comentarios anidados*/} .commentlist li > .children li > .children li > .children #respond h3{margin: 0 0 15px -96px;/*nivel 3 comentarios anidados*/} .comment-body{ padding-bottom:25px; position:relative; overflow:hidden; } .reply{ bottom: 25px; position: absolute; right: -76px; opacity:0; -webkit-transition: all 0.2s ease-in-out; -moz-transition: all 0.2s ease-in-out; -o-transition: all 0.2s ease-in-out; transition: all 0.2s ease-in-out; } .comment-body:hover > .reply{ right:0px; opacity:1;} .comment-body p{ margin:15px 0; padding-left:15px; } .comment-author{ background: #EEEEEE; border-radius: 5px; border: solid 1px #cbcbcb; height: 50px; } .comment-author img{ background: #f1f1f1; padding:3px; margin: 5px; border: 1px solid #cbcbcb; } .comment-author .fn, .comment-author .says{ position: relative; top: -20px; font-style:italic; } .commentmetadata{ position: absolute; right:10px; top: 15px; }Aplicando el CSS anterior organizamos los comentarios adaptándolos al estilo de nuestra plantilla, obtendremos un resultado como muestro en la siguiente imagen.
He aplicado los estilos de manera que los comentarios anidados se muestren dentro del comentario padre, solo lo he probado con los comentarios anidados hasta nivel 3.
Estilos para el formulario de envío de comentario
Para el formulario de envío de comentarios utilizaremos los siguientes estilos.Código :
/* FORMULARIO DE COMENTARIOS */ #respond{ clear: both; display: block; border-top: solid 1px #ecede9; padding: 15px 0; position:relative; } #respond h3{ font-size: 16px; color: #437201; background:url(images/title-bg-sidebar-right.png) no-repeat left top; height: 55px; line-height: 55px; margin: 0 0 15px -22px; padding-left:20px; color: #e1e1e1; } #respond #cancel-comment-reply { position: absolute; right: 0; top: 35px; } #respond #cancel-comment-reply a{color:red; font-style:italic;} #respond #cancel-comment-reply a:hover{text-decoration:none; border-bottom: 1px dotted red;} div#respond form#commentform p{ margin: 15px 0;} div#respond form#commentform input[type=text]{ width: 230px; height:20px;} #commentform #submit{width: auto !important;} div#respond form#commentform textarea{ width: 400px;} #commentform label{font-size:11px;margin-left:10px;} .nocomments{color:red; text-align:center;}/*Comentarios Cerrados*/ .page .nocomments{display: none;}Para los input, el textarea y el botón del formulario de comentario reutilizaremos el código utilizado para el widget de contacto, y para el botón reutilizaremos el código css utilizado para el botón leer más que creamos en el index, de esta forma nos evitamos crear nuevas reglas css para el formulario.
Para el css del input y el textarea buscamos la línea #546 ó el selector #sidebar #wiget-contact input, en esta parte agregaremos los selectores del input y el textarea para aplicarle el mismo estilo. No es nada del otro mundo, sólo es agregar el selector separado por comas, pero por si alguno no sabe a qué me refiero trataré de ilustrarlo en la siguiente imagen.
Código completo
Código :
#sidebar #wiget-contact input, #sidebar #wiget-contact textarea, form#commentform p input, form#commentform p textarea { width: 100%; padding: 5px; text-transform: uppercase; font-size: 12px; text-shadow: 1px 1px 0px #dedede; color: #9a9b9d; background: #c4c4c4; border:none; -moz-border-radius: 5px; -webkit-border-radius: 5px; border-radius: 5px; -moz-box-shadow: 1px 1px 0px 0px #f4f4f4, 1px 2px 1px 0px #b1b3b5 inset; -webkit-box-shadow: 1px 1px 0px 0px #f4f4f4, 1px 2px 1px 0px #b1b3b5 inset; box-shadow: 1px 1px 0px 0px #f4f4f4, 1px 2px 1px 0px #b1b3b5 inset; } #sidebar #wiget-contact input:focus, #sidebar #wiget-contact textarea:focus, form#commentform p input:focus, form#commentform p textarea:focus{ -moz-box-shadow: 0px 0px 8px 0px #afafaf inset, 0px 0px 5px 0px #efefef, 1px 1px 0px 0px #f4f4f4, 1px 2px 1px 0px #b1b3b5 inset; -webkit-box-shadow: 0px 0px 8px 0px #afafaf inset, 0px 0px 5px 0px #efefef, 1px 1px 0px 0px #f4f4f4, 1px 2px 1px 0px #b1b3b5 inset; box-shadow: 0px 0px 8px 0px #afafaf inset, 0px 0px 5px 0px #efefef, 1px 1px 0px 0px #f4f4f4, 1px 2px 1px 0px #b1b3b5 inset; color: #707070; background: #cdcdcd; }Esto mismo haremos con el botón de enviar el formulario, igualaremos sus estilos con el botón leer más que creamos en el tutorial anterior, exactamente en la línea #659 de nuestra hoja de estilo, de todas forma les dejo el código completo para estos botones.
Código :
.leermas, #wiget-contact #form-enviar, #commentform p input#submit{ display: inline-block; padding: 5px 10px; border-radius: 5px; border: solid 1px #558300; text-shadow: none !important; color: #fff !important; background: #6aa103; box-shadow:none !important; -webkit-transition: all 0.3s ease-in-out; -moz-transition: all 0.3s ease-in-out; transition: all 0.3s ease-in-out; } .leermas:hover, #wiget-contact #form-enviar:hover, #commentform #submit:hover{ text-decoration: none; color: red; -moz-box-shadow: 0px 0px 0px 1px #77b800 inset !important; text-shadow: 0px 0px 3px #FFFFFF !important; cursor:pointer; }
Conclusión
Con esto ya debemos tener tanto la lista de comentarios y el formulario ya con estilos y adaptado al estilo de nuestra plantilla, y con esto pueden darse cuenta de lo sencillo que puede ser si no necesitamos utilizar formulario ni listas de comentarios personalizadas.Como puedes notar en el código CSS3 he utilizado prefijos específicos para los navegadores, si no quieres marearte con los prefijos esta a opción de cada uno utilizar alguna utilidad para eliminar los prefijos o dejarlo tal cual está en el tutorial.
Disculpa por coger la forma fácil para mostrar el listado de comentarios, es que si empiezo a explicar lo de crear una lista personalizada de comentarios el tutorial se me alarga mucho y este es un tema bastante amplio del cual se puede hablar mucho.
En la siguiente y última parte del tutorial trataremos los siguientes temas:
Tercera parte:
- Registrar posición de los widget para el sidebar
- Utilizar campos personalizados de wordpress.
- Crear el widget próximos conciertos utilizando campos personalizados
- Crear widget próximos conciertos
- Crear Widget últimos vídeos
- Crear formulario de contacto con el plugins contactform
¿Sabes SQL? ¿No-SQL? Aprende MySQL, PostgreSQL, MongoDB, Redis y más con el Curso Profesional de Bases de Datos que empieza el martes, en vivo.
Por jordano_p el 04 de Abril de 2012
Por Mariux el 04 de Abril de 2012
gracias por el tuto!!! son cada vez mas geniales!
Por jordano_p el 08 de Abril de 2012
Por jefelon el 08 de Abril de 2012
Por Foxnetorka el 08 de Abril de 2012
http://html5reset.org/
Ya que contiene un tema base para wordpress, que se puede usar como punto de partida para un tema. Espero les funcione.
Por HtrMancera el 08 de Abril de 2012
Por Freddie el 09 de Abril de 2012
Por jordano_p el 09 de Abril de 2012
Foxnetorka-blog :
http://html5reset.org/
Ya que contiene un tema base para wordpress, que se puede usar como punto de partida para un tema. Espero les funcione.
Hay muchos framework que te pueden ayudar con la creación de de una plantilla para wordpress, pero este tutorial trata de crearlo desde cero sin ningún framework, cuando trabajo para clientes y tengo tiempo limitado de entrega claro que uso Framework son muy útiles en estos casos.
Freddie :
No entiendo del todo el comentario
Por Mago Blanco el 01 de Mayo de 2012
Pero vamos lo dicho Genial y Loco por que lo acabes, a ver si soy capaz de acabarlo yo tambien,jeje
Un saludo y 1 millon de gracias.
Por @guiyens12 el 12 de Mayo de 2012
Por xirux-nefer el 24 de Septiembre de 2012
(por cierto, ¿cómo se cita un comentario de otra persona? No veo el botón)
Ya acabé este tuto, =) ...todo claro, mi pregunta esta vez es una chorradita del CSS:
En el input y el textarea del formulario de comentarios, cuando están en focus, utilizas un box-shadow con 4 colores de sombras distintas pero muy similares, representando así el ángulo en que viene la luz y las sombras que habría si fuesen 3D. Mi pregunta es: ¿Como eliges esos colores? Vas probando grises más claros y grises más oscuros hasta que encuentras una combinación que te guste?
Por jordano_p el 07 de Noviembre de 2012
xirux-nefer :
(por cierto, ¿cómo se cita un comentario de otra persona? No veo el botón)
Ya acabé este tuto, =) ...todo claro, mi pregunta esta vez es una chorradita del CSS:
En el input y el textarea del formulario de comentarios, cuando están en focus, utilizas un box-shadow con 4 colores de sombras distintas pero muy similares, representando así el ángulo en que viene la luz y las sombras que habría si fuesen 3D. Mi pregunta es: ¿Como eliges esos colores? Vas probando grises más claros y grises más oscuros hasta que encuentras una combinación que te guste?
Para elegir los colores me guío del diseño utilizando photoshop, seria muy tedioso estar probando tonos de colores directamente en el código, casi siempre antes de meterme en el código de una web tengo el diseño creado en photoshop, y es de hay de donde saco todos los colores necesarios.
Por el 01 de Agosto de 2016
Por shanawarwht el 17 de Noviembre de 2016
Por shanawarwht el 17 de Noviembre de 2016
Por shanawarwht el 17 de Noviembre de 2016
Por shanawarwht el 17 de Noviembre de 2016
Por shanawarwht el 17 de Noviembre de 2016
Por José el 31 de Enero de 2018
classroom rental space
training rrom rental in singapore
training rooms in singapore
seminar room rental in singapore
indoor team building activities
corporate team building games singapore
team bonding in singapore
team building activities singapore
team building games singapore
10 soft skills you need
administrative office procedures
administrative support courses
adult learning mental skills
adult learning physical skills
anger management courses in singapore
appreciative inquiry courses
archiving and records management
assertiveness and self confidence
attention management courses
basic bookkeeping courses
being a likeable boss
body language basics courses
budgets and financial reports
business acumen courses
business ethics courses
business etiquette courses in singapore
business succession planning courses
business writing courses in singapore
call center training courses
change management courses in singapore
coaching and mentoring courses
coaching sales people courses
collaborative business writing
communication strategies courses
conducting annual employee reviews
conflict resolution courses
contact center training courses
contract management courses in singapore
creating a great webinar
creative problem solving courses
crisis management courses
critical thinking courses in singapore
customer service courses in singapore
customer support courses
cyber security courses in singapore
delivering constructive criticism
developing a lunch and learn
developing corporate behavior
developing creativity courses
developing new managers
digital citizenship courses
emotional intelligence courses
employee motivation courses
employee on boarding courses
employee recognition courses
employee recruitment courses
employee termination processes
entrepreneurship courses in singapore
event planning courses in singapore
executive and personal assistants
facilitation skills courses
generation gaps courses
goal setting and getting things done
handling a difficult customer
health and wellness at work courses
high performance teams inside the company
high performance teams remote work force
hiring strategies courses
human resource management courses in singapore
improving mindfulness
improving self awareness
increasing your happiness
internet marketing fundamentals courses
interpersonal skills courses
job search skills courses
knowledge management courses in singapore
leadership and influence courses
lean process and six sigma
life coaching essentials courses
manager management courses
managing personal finances courses
managing work place anxiety
marketing basics courses
measuring results from training
media and public relations courses
meeting management courses
middle manager courses
millennial on boarding courses
m learning essentials
motivating your sales team
multi level marketing courses
negotiation skills courses
networking outside the company
networking within the company
office politics for managers
organizational skills courses
overcoming sales objections
performance management courses
personal branding courses in singapore
personal productivity courses
presentation skills courses in singapore
project management courses in singapore
proposal writing courses
prospecting and lead generation
public speaking courses in singapore
risk assessment and management courses
safety in the work place courses
sales fundamentals courses
sales training courses in singapore
servant leadership courses
it courses in singapore
microsoft training singapore
corporate training in singapore
corporate sgx
social intelligence courses
social learning courses
social media in the work place
social media marketing courses in singapore
soft skills courses in singapore
stress management courses in singapore
supervising others
supply chain management courses
taking initiative courses
talent management courses
team building for managers
team building through chemistry
teamwork and team building
telephone etiquette courses
telework and telecommuting
time management courses in singapore
trade show staff training
train the trainer courses
virtual team building and management
women in leadership courses
work life balance courses in singapore
work place diversity courses
work place harassment courses
work place violence courses
sancy suraj
sancy suraj
sancy suraj
sancy suraj
sancy suraj
sancy suraj
sancy suraj
sancy suraj
[url=https://books.google.com.sg/books?id=1QykBQAAQBAJ&pg=PT362&lpg=PT362&dq=%22sancy+suraj+singh%22&source=bl&ots=E86QDyrLG2&sig=H-6a_YH-kTWaZWTfPSr1xfm4BOs&hl=en&sa=X&ved=0ahUKEwi3_56hhubVAhWJLo8KHcxTBxQ4ChDoAQgjMAA#v=onepage&q =% 22sancy% 20suraj% 20singh% 22 & f = false]sancy suraj[/url]
sancy suraj
longest colour sequence memorised
sancy suraj
longest colour sequence memorised
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
lunch talks
lunch talks
memory training course
memory training course
cabin crew
online memory course
memory training course
memory training course
memory training course
memory training course
memory training course
speed reading
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
geography tuition for secondary school students in singapore
geography tuition for secondary school students singapore
geography tuition for secondary school students singapore
geography tuition for secondary school students singapore
geography tuition for secondary school students singapore
secondary geography tuition in singapore
history tuition for secondary school students in singapore
social studies tuition for secondary school students in singapore
psle english tuition in singapore
psle science tuition in singapore
secondary 1 chemistry tuition in singapore
secondary 1 physics tuition in singapore
school holiday workshops courses for students in singapore
school holidays activitie in singapore
school holidays activitie in singapore
[url=http://umonictuitionadvantage.com/2017-november-school-holidays-activities-programmes-workshop-courses-camps-for- students-kids-in-singapore/]school holidays activitie in singapore[/url]
school holidays activitie in singapore
study skills
study skills
study skills workshops course in singapore
study skills workshops course in singapore
speed reading
speed reading
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition[
tuition[
tuition[
tuition[
tuition[
tuition[
tuition[
tuition[
student courses
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
team building
team building ideas
team building activities
unique team building
team building
corporate training in singapore
corporate training courses
corporate training courses
corporate training courses
corporate training courses
corporate health talk
corporate health talk
corporate health talk
lunch and learn talk
workplace lunch and learn
corporate training companies in singapore
training companies in singapore
emcee
emcee
health talks
soft skills training course
corporate training providers
professional development courses
training and development courses
short courses in singapore
corporate training courses in singapore
corporate training courses
corporate training in singapore
school holiday workshops courses for students in singapore
business students memory course in singapore
business students memory improvement workshop in singapore
memory improvement course for business students
memory improvement course for business students
business students memory improvement course
business students memory course in singapore
corporate health talks singapore
corporate health talks in singapore
corporate health talk singapore
corporate health talk in singapore
corporate health talks singapore
corporate health talks singapore
finance students memory training course in singapore
finance students memory training course in singapore
finance students memory training course in singapore
memory training courses for finance students in singapore
memory training courses for finance students in singapore
memory improvement courses for finance students in singapore
pinnacle minds
memory course
study skills
speed reading
memory training
school holiday
lunch and learn
march school holidays workshops
march school holidays workshops
march school holidays workshops
march school holidays workshops
march school holidays workshops
june school holidays workshops
june school holidays workshops
june school holidays workshops
june school holidays workshops
september 2018 school holidays workshops
september 2018 school holidays workshops
september 2018 school holidays workshops
september 2018 school holidays workshops
november 2018 school holidays workshops
november 2018 school holidays workshops
november 2018 school holidays workshops
november 2018 school holidays workshops
december 2018 school holidays workshops
december 2018 school holidays workshops
december 2018 school holidays workshops
december 2018 school holidays workshops
top 10 soft skills you need training course
administrative office procedures training course
administrative support training course
anger management training course
appreciative inquiry training course
archiving and records management training course
archiving and records management training course
self confidence and assertiveness training course
improving your attention management training course
bacis bookkeeping training course
being a likeable boss training course
body language training course
budgets and-financial reports training course
business acumen training course
business ethics training course
business etiquette training course
business succession planning training course
business writing training course
call centre training course
change management training course
civility in the workplace training course
coaching and mentoring training course
coaching salespeople training course
collaborative business writing training course
communication strategies training course
conducting annual employee reviews training course
conflict resolution training course
contact centre training course
contract management training course
creating a great webinar training course
creative problem solving training course
crisis management training course
critical thinking training course
customer service training course
customer support training course
cyber security training course
delivering constructive criticism training course
developing lunch and learn training course
developing corporate behavior training course
developing creativity training course
developing new managers training course
digital citizenship training course
emotional intelligence training course
employee motivation training course
employee onboarding training course
employee recognition training course
employee recruitment training course
employee termination processes training course
entrepreneurship training course
event planning training course
executive and personal assistants training course
facilitation skills training course
generation gaps training course
goal setting and getting things done training course
handling a difficult customer training course
health and wellness at work training course
high performance teams inside the company training course
high performance teams remote workforce training course
hiring strategies training course
human resource management training course
improving mindfulness training course
improving self awareness training course
internet marketing fundamentals training course
interpersonal skills training course
job search skills training course
knowledge management training course
leadership and influence training course
lean process and six sigma training course
life coaching essentials training course
manager management training course
managing personal finances training course
managing workplace anxiety training course
marketing basics training course
measuring results from training course
media and public relations training course
meeting management training course
middle manager training course
millennial onboarding training course
mlearning essentials training course
motivating your sales team training course
negotiation skills training course
networking outside the company training course
networking within the company training course
office politics for managers training course
organizational skills training course
overcoming sales objections training course
performance management training course
personal branding training course
personal productivity training course
presentation skills training course
project management training course
proposal writing training course
prospecting and lead generation training course
public speaking training course
risk assessment and management training course
safety in the workplace training course
sales fundamentals training course
servant leadership training course
social intelligence training course
social learning training course
social media in the workplace training course
social media marketing training course
stress management training course
supervising others training course
supply chain management training course
taking initiative training course
talent management training course
team building for managers training course
team building through chemistry training course
teamwork and team building training course
telephone etiquette training course
telework and telecommuting training course
time management training course
top 10 sales secrets training course
trade show staff training course
train the trainer training course
virtual team building and management training course
women in leadership training course
work life balance training course
workplace diversity training course
workplace harassment training course
workplace violence training course
half day memory improvement courses workshops
speed reading courses workshops in singapore
10 soft skills you need corporate training course in singapore
administrative office procedures corporate training course in singapore
administrative support corporate training course in singapore
anger management corporate training course in singapore
appreciative inquiry corporate training course in singapore
archiving and records management corporate training course in singapore
self confidence assertiveness corporate training course in singapore
improving your attention management corporate training course in singapore
basic bookkeeping corporate training course in singapore
being a likeable boss corporate training course in singapore
body language basics corporate training course in singapore
budgets and financial reports corporate training course in singapore
business acumen corporate training course in singapore
business ethics corporate training course in singapore
business etiquette corporate training course in singapore
business succession planning corporate training course in singapore
business writing corporate training course in singapore
call center corporate training course in singapore
change management corporate training course in singapore
civility in the workplace corporate training course in singapore
coaching and mentoring corporate training course in singapore
coaching salespeople corporate training course in singapore
collaborative business writing corporate training course in singapore
communication strategies corporate training course in singapore
conducting annual employee reviews corporate training course in singapore
conflict resolution corporate training course in singapore
contact center corporate training course in singapore
contract management corporate training course in singapore
creating a great webinar corporate training course in singapore
creative problem solving corporate training course in singapore
crisis-management corporate training course in singapore
critical thinking corporate training course in singapore
customer service corporate training course in singapore
customer support corporate training course in singapore
cyber security corporate training course in singapore
delivering constructive criticism corporate training course in singapore
developing a lunch and learn corporate training course in singapore
developing corporate behavior corporate training course in singapore
developing creativity corporate training course in singapore
developing new managers corporate training course in singapore
digital citizenship corporate training course in singapore
emotional intelligence corporate training course in singapore
employee motivation corporate training course in singapore
employee onboarding corporate training course in singapore
employee recognition corporate training course in singapore
employee recruitment corporate training course in singapore
employee termination processes corporate training course in singapore
entrepreneurship training course in singapore
event planning corporate training course in singapore
executive and personal assistants corporate training course in singapore
facilitation skills corporate training course in singapore
generation gaps corporate training course in singapore
goal setting and getting things done corporate training course in singapore
handling a difficult customer corporate training course in singapore
health and wellness at work corporate training course in singapore
high performance teams inside the company corporate training course in singapore
high performance teams remote workforce corporate training course in singapore
hiring strategies corporate training course in singapore
human resource management corporate training course in singapore
improving mindfulness corporate training course in singapore
improving self awareness corporate training course in singapore
increasing your happiness corporate training course in singapore
internet marketing fundamentals corporate training course in singapore
interpersonal skills corporate training course in singapore
job search skills corporate training course in singapore
knowledge management corporate training course in singapore
leadership and influence corporate training course in singapore
lean process and six sigma corporate training course in singapore
life coaching essentials corporate training course in singapore
manager management corporate training course in singapore
managing personal finances corporate training course in singapore
marketing basics corporate training course in singapore
measuring results from corporate training course in singapore
media and public relations corporate training course in singapore
meeting management corporate training course in singapore
middle manager corporate training course in singapore
millennial onboarding corporate training course in singapore
mlearning essentials corporate training course in singapore
motivating your sales team corporate training course in singapore
negotiation skills corporate training course in singapore
networking outside the company corporate training course in singapore
networking within the company corporate training course in singapore
office politics for managers corporate training course in singapore
organizational skills corporate training course in singapore
overcoming sales objections corporate training course in singapore
performance management corporate training course in singapore
personal branding corporate training course in singapore
personal productivity corporate training course in singapore
presentation skills corporate training course in singapore
project management corporate training course in singapore
proposal writing corporate training course in singapore
prospecting and lead generation corporate training course in singapore
public speaking corporate training course in singapore
[url