1
0
mirror of https://github.com/kremalicious/blog.git synced 2025-01-06 19:55:40 +01:00

port over mixins, base post styling

This commit is contained in:
Matthias Kretschmann 2018-07-18 23:04:31 +02:00
parent 7a51a4478d
commit 9246bf7ea8
Signed by: m
GPG Key ID: 606EEEF3C479A91F
18 changed files with 454 additions and 124 deletions

View File

@ -20,14 +20,14 @@ But more problems appeared. The display of the newest and latest posts and the n
Now it's clear something with my code must be wrong, I thought. For displaying the latest posts in Wordpress I use a pretty standard way which is [described in the Wordpress Codex](http://codex.wordpress.org/Template_Tags/get_posts): Now it's clear something with my code must be wrong, I thought. For displaying the latest posts in Wordpress I use a pretty standard way which is [described in the Wordpress Codex](http://codex.wordpress.org/Template_Tags/get_posts):
{% highlight php %} ```php
<?php $postslist = get_posts('numberposts=5&order=DESC&orderby;=post_date'); <?php $postslist = get_posts('numberposts=5&order=DESC&orderby;=post_date');
foreach ($postslist as $post) : setup_postdata($post); ?> foreach ($postslist as $post) : setup_postdata($post); ?>
<ul> <ul>
<li><a href="<?php the_permalink(); ?>"><?php the_title(); ?></a><span><?php the_date(); ?></span></li> <li><a href="<?php the_permalink(); ?>"><?php the_title(); ?></a><span><?php the_date(); ?></span></li>
</ul> </ul>
<?php endforeach; ?> <?php endforeach; ?>
{% endhighlight %} ```
This would get all recent posts sorted by their post_date entry in the (wp_posts) database table and style it as an unordered list with my preferred format. This code worked since the launch of kremalicious.com and I first used it to display the recent blog entries on my start page. But since i didn't change anything in the code this couldn't be caused by wrong code or something. This would get all recent posts sorted by their post_date entry in the (wp_posts) database table and style it as an unordered list with my preferred format. This code worked since the launch of kremalicious.com and I first used it to display the recent blog entries on my start page. But since i didn't change anything in the code this couldn't be caused by wrong code or something.
@ -39,7 +39,9 @@ This bug affects all versions of MySQL since 5.0.50 and it seems there is no sta
Thankfully [a commenter](http://wordpress.org/support/topic/185896#post-793417) in the Wordpress forums reminded me of a nice temporary solution to this mess until my host updates MySQL: using wp_get_archives for displaying the recent posts. But this won't let me display the dates anymore: Thankfully [a commenter](http://wordpress.org/support/topic/185896#post-793417) in the Wordpress forums reminded me of a nice temporary solution to this mess until my host updates MySQL: using wp_get_archives for displaying the recent posts. But this won't let me display the dates anymore:
{% highlight php %}<?php wp_get_archives('type=postbypost&limit;=5'); ?>{% endhighlight %} ```php
<?php wp_get_archives('type=postbypost&limit;=5'); ?>
```
Problem temporary solved! Problem temporary solved!

View File

@ -26,9 +26,9 @@ While Safari on iPhone will display all websites just fine it can happen that th
The viewport can be larger or smaller than the visible area but I wanted my content to exactly fit the width of the iPhone and the goal was to make the text legible on first load. So here's what I use for kremalicious{iPhone}: The viewport can be larger or smaller than the visible area but I wanted my content to exactly fit the width of the iPhone and the goal was to make the text legible on first load. So here's what I use for kremalicious{iPhone}:
{% highlight html %} ```html
<meta name="Viewport" content="maximum-scale=1.6,width=device-width" > <meta name="Viewport" content="maximum-scale=1.6,width=device-width" >
{% endhighlight %} ```
This code will let the user scale the content up to 1.6 times to the default view and the default width of the content is set to the width of the (iPhone) device. This code will let the user scale the content up to 1.6 times to the default view and the default width of the content is set to the width of the (iPhone) device.
@ -37,17 +37,17 @@ This code will let the user scale the content up to 1.6 times to the default vie
There's neither an active nor a hover state for links on the iPhone which makes sense on a touch interface although it would be much easier to just use a:active for the tap highlighting. Safari on the iPhone uses a special webkit property for that: There's neither an active nor a hover state for links on the iPhone which makes sense on a touch interface although it would be much easier to just use a:active for the tap highlighting. Safari on the iPhone uses a special webkit property for that:
{% highlight css %} ```css
-webkit-tap-highlight-color: rgba(234,234,234,0.5); -webkit-tap-highlight-color: rgba(234,234,234, .5);
{% endhighlight %} ```
# Home Screen Icon # Home Screen Icon
![image](../media/kremalicious-iconiphone.png)I've used a 147x147px icon so the icon looks crisp and sharp on the iPhone screen (because it's a 160dpi screen). You really should use a bigger size than [Apple's recommendation in their iPhone HIG](https://developer.apple.com/iphone/library/documentation/UserExperience/Conceptual/MobileHIG/IconsImages/chapter_14_section_2.html). You have to provide a png icon without rounded corners and without the highlight shine since the iPhone will render that automatically on the icon. The icon has to be named apple-touch-icon.png and gets automatically detected when put in the root of your website. Additionally you can tell the iPhone the place where the icon is with this link tag in your head section: ![image](../media/kremalicious-iconiphone.png)I've used a 147x147px icon so the icon looks crisp and sharp on the iPhone screen (because it's a 160dpi screen). You really should use a bigger size than [Apple's recommendation in their iPhone HIG](https://developer.apple.com/iphone/library/documentation/UserExperience/Conceptual/MobileHIG/IconsImages/chapter_14_section_2.html). You have to provide a png icon without rounded corners and without the highlight shine since the iPhone will render that automatically on the icon. The icon has to be named apple-touch-icon.png and gets automatically detected when put in the root of your website. Additionally you can tell the iPhone the place where the icon is with this link tag in your head section:
{% highlight html %} ```html
<link rel="apple-touch-icon" href="/i/apple-touch-icon.png" /> <link rel="apple-touch-icon" href="/i/apple-touch-icon.png" />
{% endhighlight %} ```
And finally many thanks to [cschock](http://www.cschock.de) for continuously testing my code voodoo soup even at late hours. And finally many thanks to [cschock](http://www.cschock.de) for continuously testing my code voodoo soup even at late hours.

View File

@ -20,7 +20,7 @@ I've searched for a simple way of disabling those feeds, plugins etc. stuff the
So open your `/wp-admin/index-extra.php` file. It should look like this: So open your `/wp-admin/index-extra.php` file. It should look like this:
{% highlight php %} ```php
<?php <?php
require_once('admin.php'); require_once('admin.php');
require( 'includes/dashboard.php' ); require( 'includes/dashboard.php' );
@ -41,12 +41,12 @@ So open your `/wp-admin/index-extra.php` file. It should look like this:
break; break;
} }
?> ?>
{% endhighlight %} ```
Now just uncomment the lines so it looks like this (every line with two leading // is uncommented and therefore inactive): Now just uncomment the lines so it looks like this (every line with two leading // is uncommented and therefore inactive):
{% highlight php %} ```php
<?php <?php
require_once('admin.php'); require_once('admin.php');
require( 'includes/dashboard.php' ); require( 'includes/dashboard.php' );
@ -72,7 +72,7 @@ Now just uncomment the lines so it looks like this (every line with two leading
// //
// } // }
?> ?>
{% endhighlight %} ```
And that's it. Save the file on your server, log in to your Wordpress backend and you should see your Dashboard with everything intact. It just won't search for incoming links and all those other RSS sources anymore. And that's it. Save the file on your server, log in to your Wordpress backend and you should see your Dashboard with everything intact. It just won't search for incoming links and all those other RSS sources anymore.

View File

@ -23,7 +23,7 @@ In MarsEdit main window right-click (or ctrl + click) in the sidebar on the blog
Just copy and paste the following HTML and CSS into your Preview Template editor. If something goes wrong with the source formatting, I've also provided [a txt file with the code](../media/marsedit_kremalicious.txt): Just copy and paste the following HTML and CSS into your Preview Template editor. If something goes wrong with the source formatting, I've also provided [a txt file with the code](../media/marsedit_kremalicious.txt):
{% highlight html %} ```html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"> <html xmlns="http://www.w3.org/1999/xhtml">
<head> <head>
@ -70,7 +70,7 @@ Just copy and paste the following HTML and CSS into your Preview Template editor
</body> </body>
</html> </html>
{% endhighlight %} ```
Now click on Save Changes in the lower right corner of the window and there you have it. Now click on Save Changes in the lower right corner of the window and there you have it.

View File

@ -24,7 +24,7 @@ Sure enough I've upgraded immediately when [Wordpress 2.7 was released](http://w
Before Wordpress 2.7 I achieved a custom gravatar image on kremalicious.com with this code placed in the comments.php template file: Before Wordpress 2.7 I achieved a custom gravatar image on kremalicious.com with this code placed in the comments.php template file:
{% highlight php %} ```php
<?php <?php
if(function_exists('get_avatar')) { if(function_exists('get_avatar')) {
echo get_avatar( echo get_avatar(
@ -34,13 +34,13 @@ Before Wordpress 2.7 I achieved a custom gravatar image on kremalicious.com with
); );
} }
?> ?>
{% endhighlight %} ```
So we were able to set a path to our image we wanted to use as the default gravatar image. But with Wordpress 2.7 we have the new function [`<?php wp_list_comments(); ?>`](http://codex.wordpress.org/Template_Tags/wp_list_comments) which pretty much simplifies writing comment template code. Although it has a parameter for the avatar size it doesn't have one for setting a custom image like before. So we were able to set a path to our image we wanted to use as the default gravatar image. But with Wordpress 2.7 we have the new function [`<?php wp_list_comments(); ?>`](http://codex.wordpress.org/Template_Tags/wp_list_comments) which pretty much simplifies writing comment template code. Although it has a parameter for the avatar size it doesn't have one for setting a custom image like before.
But we can use the functions.php file in your template directory and add some lines to it: (If you don't have a functions.php file just create one.) But we can use the functions.php file in your template directory and add some lines to it: (If you don't have a functions.php file just create one.)
{% highlight php %} ```php
<?php <?php
function my_own_gravatar( $avatar_defaults ) { function my_own_gravatar( $avatar_defaults ) {
$myavatar = get_bloginfo('template_directory') . '/images/gravatar.png'; $myavatar = get_bloginfo('template_directory') . '/images/gravatar.png';
@ -49,7 +49,7 @@ But we can use the functions.php file in your template directory and add some li
} }
add_filter( 'avatar_defaults', 'my_own_gravatar' ); add_filter( 'avatar_defaults', 'my_own_gravatar' );
?> ?>
{% endhighlight %} ```
@ -60,9 +60,9 @@ Just set a name for your custom Gravatar image to show up beside the image in th
And you can adjust the displayed size of the gravatar image by adding a parameter to `<?php wp_list_comments(); ?>` function in your comments.php file: And you can adjust the displayed size of the gravatar image by adding a parameter to `<?php wp_list_comments(); ?>` function in your comments.php file:
{% highlight php %} ```php
<?php wp_list_comments(array('avatar_size'=>70, )); ?> <?php wp_list_comments(array('avatar_size'=>70, )); ?>
{% endhighlight %} ```

View File

@ -21,7 +21,7 @@ Since my update to Wordpress 2.7 I'm pretty much into all the new comments stuff
Let's start by looking at the code to achieve styling of author comments prior to Wordpress 2.7. On kremalicious.com I've used this code: Let's start by looking at the code to achieve styling of author comments prior to Wordpress 2.7. On kremalicious.com I've used this code:
{% highlight php %} ```php
<li class=" <li class="
<?php <?php
if ($comment->comment_author_url == "http://www.kremalicious.com") if ($comment->comment_author_url == "http://www.kremalicious.com")
@ -31,17 +31,21 @@ Let's start by looking at the code to achieve styling of author comments prior t
item" id="comment-<?php comment_ID() ?>"> item" id="comment-<?php comment_ID() ?>">
<em>other comments code</em> <em>other comments code</em>
</li> </li>
{% endhighlight %} ```
So with some php stuff we were able to check for the author name or, as I did it, for the URL of the comment author. If one of these were detected Wordpress added a new class 'author' to the `<li>` tag which we were able to style by adding a li.author to our css file: So with some php stuff we were able to check for the author name or, as I did it, for the URL of the comment author. If one of these were detected Wordpress added a new class 'author' to the `<li>` tag which we were able to style by adding a li.author to our css file:
{% highlight css %}li.author { css comes in here }{% endhighlight %} ```css
li.author { /* css comes in here */ }
```
But with Wordpress 2.7 these steps are needless because of the [new function `<?php wp_list_comments(); ?>`](http://codex.wordpress.org/Template_Tags/wp_list_comments) which adds a class on author comments for itself! But with Wordpress 2.7 these steps are needless because of the [new function `<?php wp_list_comments(); ?>`](http://codex.wordpress.org/Template_Tags/wp_list_comments) which adds a class on author comments for itself!
If a comment from the author of an article is posted under this article, **Wordpress automatically adds the class 'bypostauthor' to the surrounding `<li>` tag.** So all you have to do is adding a css style of `li.bypostauthor` to your css file or just renaming your old `li.author` class or whatever you used for this: If a comment from the author of an article is posted under this article, **Wordpress automatically adds the class 'bypostauthor' to the surrounding `<li>` tag.** So all you have to do is adding a css style of `li.bypostauthor` to your css file or just renaming your old `li.author` class or whatever you used for this:
{% highlight css %}li.bypostauthor { css comes in here }{% endhighlight %} ```css
li.bypostauthor { /* css comes in here */ }
```
And that's it for adding a different style to comments from the article author. Just add some css and there you go. Wonderful! And that's it for adding a different style to comments from the article author. Just add some css and there you go. Wonderful!
@ -49,6 +53,8 @@ And that's it for adding a different style to comments from the article author.
Wordpress also has a special class for registered users of your site so you're able to style their comments as well. For this just use the class 'byuser': Wordpress also has a special class for registered users of your site so you're able to style their comments as well. For this just use the class 'byuser':
{% highlight css %}li.byuser { css comes in here }{% endhighlight %} ```css
li.byuser { /* css comes in here */ }
```
All the various classes Wordpress adds to comments are listed [in the Codex page for enhanced comments display](http://codex.wordpress.org/Migrating_Plugins_and_Themes_to_2.7/Enhanced_Comment_Display#CSS_Styling). And [here's a very nice grahical overview about everything Wordpress 2.7 adds to comments](http://www.wp-fun.co.uk/2008/12/10/27-comment-classes/). All the various classes Wordpress adds to comments are listed [in the Codex page for enhanced comments display](http://codex.wordpress.org/Migrating_Plugins_and_Themes_to_2.7/Enhanced_Comment_Display#CSS_Styling). And [here's a very nice grahical overview about everything Wordpress 2.7 adds to comments](http://www.wp-fun.co.uk/2008/12/10/27-comment-classes/).

View File

@ -54,7 +54,9 @@ If you download the above Coda Clip files this icon is already applied on the cl
That's because both collections have their placeholder selection (the ![Coda Clips Placeholder](../media/codaclips-placeholder.png)) located where the link text would be: That's because both collections have their placeholder selection (the ![Coda Clips Placeholder](../media/codaclips-placeholder.png)) located where the link text would be:
{% highlight html %}<a href="" title="">![Coda Clips Placeholder](../media/codaclips-placeholder.png)</a>{% endhighlight %} ```html
<a href="" title="">![Coda Clips Placeholder](../media/codaclips-placeholder.png)</a>
```
As you can see I've also included the link title value usually with the name of the specific social site. Also I've already encoded all the entities so there shouldn't be any (X)HTML validation errors when using these links in your projects. As you can see I've also included the link title value usually with the name of the specific social site. Also I've already encoded all the entities so there shouldn't be any (X)HTML validation errors when using these links in your projects.
@ -91,11 +93,15 @@ Anyway, as I've said above some sites allow more to submit here and you'll find
Just include an img element wrapped inside the link tag, like so: Just include an img element wrapped inside the link tag, like so:
{% highlight html %}<a href="http://del.icio.us/post?url=http://YOUR URL&amp;title=YOUR TITLE&amp;notes=YOUR NOTES" title="Save To Delicious"><img src="delicious.png" /> Delicious</a>{% endhighlight %} ```html
<a href="http://del.icio.us/post?url=http://YOUR URL&amp;title=YOUR TITLE&amp;notes=YOUR NOTES" title="Save To Delicious"><img src="delicious.png" /> Delicious</a>
```
And if you want to just use an icon with no text use just an img element without providing any link text: And if you want to just use an icon with no text use just an img element without providing any link text:
{% highlight html %}<a href="http://del.icio.us/post?url=http://YOUR URL&amp;title=YOUR TITLE&amp;notes=YOUR NOTES" title="Save To Delicious"><img src="delicious.png" /></a>{% endhighlight %} ```html
<a href="http://del.icio.us/post?url=http://YOUR URL&amp;title=YOUR TITLE&amp;notes=YOUR NOTES" title="Save To Delicious"><img src="delicious.png" /></a>
```
@ -105,29 +111,31 @@ And if you want to just use an icon with no text use just an img element without
To me a more cleaner solution is to use the css background-image property to include the icon images. Just add a class or an id to every share link like so: To me a more cleaner solution is to use the css background-image property to include the icon images. Just add a class or an id to every share link like so:
{% highlight html %}<a class="delicious" href="http://del.icio.us/post?url=http://YOUR URL&amp;title=YOUR TITLE&amp;notes=YOUR NOTES" title="Save To Delicious">Delicious</a>{% endhighlight %} ```html
<a class="delicious" href="http://del.icio.us/post?url=http://YOUR URL&amp;title=YOUR TITLE&amp;notes=YOUR NOTES" title="Save To Delicious">Delicious</a>
```
And in your CSS select this class and style it with a background image. Assuming you want the site icon to appear left beside the link text you would also have to add some padding so the text won't overlap the icons: And in your CSS select this class and style it with a background image. Assuming you want the site icon to appear left beside the link text you would also have to add some padding so the text won't overlap the icons:
{% highlight css %} ```css
.delicious { .delicious {
background: url(delicious.png) no-repeat center center; background: url(delicious.png) no-repeat center center;
padding-left: 20px; padding-left: 20px;
} }
{% endhighlight %} ```
If you want to use just icons and no text you should provide a link text anyway but hide it with css. This is a good practice for accessibility and search engine optimization. Also you would have to provide the dimensions of the icon: If you want to use just icons and no text you should provide a link text anyway but hide it with css. This is a good practice for accessibility and search engine optimization. Also you would have to provide the dimensions of the icon:
{% highlight css %} ```css
.delicious { .delicious {
width: 16px; width: 16px;
height: 16px; height: 16px;
background: url(delicious.png) no-repeat center center; background: url(delicious.png) no-repeat center center;
text-indent: -999999px; text-indent: -999999px;
} }
{% endhighlight %} ```
## 4. HTML File Download And All The Links Separated ## 4. HTML File Download And All The Links Separated

View File

@ -27,20 +27,20 @@ redirect_from:
So just open up your theme's _functions.php_ file in your favorite editor or create it if there's no such file in your theme folder. Add this little code snippet to this file: So just open up your theme's _functions.php_ file in your favorite editor or create it if there's no such file in your theme folder. Add this little code snippet to this file:
{% highlight php %} ```php
<?php <?php
add_theme_support('post-thumbnails'); add_theme_support('post-thumbnails');
?> ?>
{% endhighlight %} ```
For backwards compatibility you should wrap this inside a function check for the new `add_theme_support`: For backwards compatibility you should wrap this inside a function check for the new `add_theme_support`:
{% highlight php %} ```php
<?php <?php
if ( function_exists( 'add_theme_support' ) ) if ( function_exists( 'add_theme_support' ) )
add_theme_support( 'post-thumbnails' ); add_theme_support( 'post-thumbnails' );
?> ?>
{% endhighlight %} ```
This makes sure WordPress installation prior to 2.9 won't get screwed up when using a theme with this new feature. This makes sure WordPress installation prior to 2.9 won't get screwed up when using a theme with this new feature.
@ -62,17 +62,26 @@ You can close the media dialogue now and you will see the image in the Post Thum
![Add to theme](../media/wordpress-thumbnail-5.png)Basically all you have to do is to add this new template tag in your theme files where you want to display the post thumbnail, most certainly in your _index.php_ file: ![Add to theme](../media/wordpress-thumbnail-5.png)Basically all you have to do is to add this new template tag in your theme files where you want to display the post thumbnail, most certainly in your _index.php_ file:
{% highlight php %}<?php the_post_thumbnail(); ?>{% endhighlight %}
```php
<?php the_post_thumbnail(); ?>
```
This template tag will display the thumbnail sized post thumbnail by default and is essentially the same as: This template tag will display the thumbnail sized post thumbnail by default and is essentially the same as:
{% highlight php %}<?php the_post_thumbnail('thumbnail'); ?>{% endhighlight %} ```php
<?php the_post_thumbnail('thumbnail'); ?>
```
But of course you can grab the other sizes WordPress automatically creates when you upload an image: But of course you can grab the other sizes WordPress automatically creates when you upload an image:
{% highlight php %}<?php ```php
<?php
the_post_thumbnail('medium'); the_post_thumbnail('medium');
the_post_thumbnail('large'); the_post_thumbnail('large');
?>{% endhighlight %} ?>
```
_(Note: Matt [left a comment on WP Engineer](http://wpengineer.com/the-ultimative-guide-for-the_post_thumbnail-in-wordpress-2-9/#comment-3053) stating he wouldn't recommend using these named arguments but provided no explanation for it yet.)_ _(Note: Matt [left a comment on WP Engineer](http://wpengineer.com/the-ultimative-guide-for-the_post_thumbnail-in-wordpress-2-9/#comment-3053) stating he wouldn't recommend using these named arguments but provided no explanation for it yet.)_
The code will output a generic `<img />` tag with a class of wp-post-image. Needless to say this is what you can select with css to style just the post thumbnails further: The code will output a generic `<img />` tag with a class of wp-post-image. Needless to say this is what you can select with css to style just the post thumbnails further:
@ -84,21 +93,27 @@ The code will output a generic `<img />` tag with a class of wp-post-image. Need
If you want to adjust the generated output of the <img /> tag you can do this by using some array stuff. So let's say you want to have the post thumbnails to be 200x200px big and another class assigned to it, you can extend the template tag like so: If you want to adjust the generated output of the <img /> tag you can do this by using some array stuff. So let's say you want to have the post thumbnails to be 200x200px big and another class assigned to it, you can extend the template tag like so:
{% highlight php %}<?php the_post_thumbnail(array( 200,200 ), array( 'class' => 'alignleft' )); ?>{% endhighlight %} ```php
<?php the_post_thumbnail(array( 200,200 ), array( 'class' => 'alignleft' )); ?>
```
If you want to add more than one class you can do this like so: If you want to add more than one class you can do this like so:
{% highlight php %}<?php the_post_thumbnail('medium', array('class' => 'alignleft another_class')); ?>{% endhighlight %} ```php
<?php the_post_thumbnail('medium', array('class' => 'alignleft another_class')); ?>
```
And you can add any attributes to the `<img />` tag like a `title`, `rel` or an `alt` attribute. For accessibility reasons you should always add at least the alt-attribute: And you can add any attributes to the `<img />` tag like a `title`, `rel` or an `alt` attribute. For accessibility reasons you should always add at least the alt-attribute:
{% highlight php %}<?php the_post_thumbnail('medium', array('class' => 'alignleft', 'alt' => 'alttext')); ?>{% endhighlight %} ```php
<?php the_post_thumbnail('medium', array('class' => 'alignleft', 'alt' => 'alttext')); ?>
```
As for the title attribute this will be grabbed automatically from the entry you've made in your Media Library during the upload process but you even could override this too: As for the title attribute this will be grabbed automatically from the entry you've made in your Media Library during the upload process but you even could override this too:
{% highlight php %} ```php
<?php the_post_thumbnail('medium', array('class' => 'alignleft', 'alt' => 'alttext', 'title' => 'titletext')); ?> <?php the_post_thumbnail('medium', array('class' => 'alignleft', 'alt' => 'alttext', 'title' => 'titletext')); ?>
{% endhighlight %} ```
@ -107,22 +122,26 @@ As for the title attribute this will be grabbed automatically from the entry you
Finally if you want to respect the custom sizes you or your users have set under Settings > Media you can first grab those sizes with [get_option function](http://codex.wordpress.org/Function_Reference/get_option) and then put it in the array: Finally if you want to respect the custom sizes you or your users have set under Settings > Media you can first grab those sizes with [get_option function](http://codex.wordpress.org/Function_Reference/get_option) and then put it in the array:
{% highlight php %}<?php ```php
<?php
$width = get_option('thumbnail_size_w'); // get the width of the thumbnail setting $width = get_option('thumbnail_size_w'); // get the width of the thumbnail setting
$height = get_option('thumbnail_size_h'); // get the height of the thumbnail setting $height = get_option('thumbnail_size_h'); // get the height of the thumbnail setting
the_post_thumbnail(array($width, $height), array('class' => 'alignleft')); the_post_thumbnail(array($width, $height), array('class' => 'alignleft'));
?>{% endhighlight %} ?>
```
You can also detect the Media settings for the other sizes and whether the crop setting is active or not: You can also detect the Media settings for the other sizes and whether the crop setting is active or not:
{% highlight php %}<?php ```php
<?php
get_option('medium_size_w'); // Width of the medium size get_option('medium_size_w'); // Width of the medium size
get_option('medium_size_h'); // Height of the medium size get_option('medium_size_h'); // Height of the medium size
get_option('large_size_w'); // Width of the large size get_option('large_size_w'); // Width of the large size
get_option('large_size_h'); // Height of the large size get_option('large_size_h'); // Height of the large size
get_option('thumbnail_crop'); // Check for crop, On=1, Off=0 get_option('thumbnail_crop'); // Check for crop, On=1, Off=0
?>{% endhighlight %} ?>
```
@ -133,41 +152,38 @@ With the check in your functions.php at the beginning there's already ensured ol
So it's a pretty good idea to make this backwards compatible with some quick if else voodoo, code shamelessly [adapted from WP-Recipes](http://www.wprecipes.com/wordpress-2-9-display-post-image-with-backward-compatibility): So it's a pretty good idea to make this backwards compatible with some quick if else voodoo, code shamelessly [adapted from WP-Recipes](http://www.wprecipes.com/wordpress-2-9-display-post-image-with-backward-compatibility):
{% highlight php %}if ( (function_exists('has_post_thumbnail')) && (has_post_thumbnail()) ) { ```php
if ( (function_exists('has_post_thumbnail')) && (has_post_thumbnail()) ) {
the_post_thumbnail(); the_post_thumbnail();
} else { } else {
$postimage = get_post_meta($post->ID, 'post-image', true); $postimage = get_post_meta($post->ID, 'post-image', true);
if ($postimage) { if ($postimage) {
echo '<img src="'.$postimage.'" alt="" />'; echo '<img src="'.$postimage.'" alt="" />';
} }
}{% endhighlight %} }
```
This first checks if the feature exists and if a post thumbnail was addd with this new feature. If it was, it simply returns the post thumbnail. If not, it falls back to whatever you've used in your theme before, the usual way is to check for and get the value of a special custom field named e.g. post-image and output it. You can add whatever you've used before inside the else statement. Et voilà, it's nicely backwards compatible now, yay! This first checks if the feature exists and if a post thumbnail was addd with this new feature. If it was, it simply returns the post thumbnail. If not, it falls back to whatever you've used in your theme before, the usual way is to check for and get the value of a special custom field named e.g. post-image and output it. You can add whatever you've used before inside the else statement. Et voilà, it's nicely backwards compatible now, yay!
## 5. Resources And More Information ## 5. Resources And More Information
* WP Engineer: [About WordPress Post Thumbnail](http://wpengineer.com/about-wordpress-post-thumbnail/)
* WP Engineer: [The Ultimative Guide For the_post_thumbnail In WordPress 2.9](http://wpengineer.com/the-ultimative-guide-for-the_post_thumbnail-in-wordpress-2-9/)
* WP Recipes: [WordPress 2.9 : Display post image with backward compatibility](http://www.wprecipes.com/wordpress-2-9-display-post-image-with-backward-compatibility)
* WP Engineer: [About WordPress Post Thumbnail](http://wpengineer.com/about-wordpress-post-thumbnail/)
* WP Engineer: [The Ultimative Guide For the_post_thumbnail In WordPress 2.9](http://wpengineer.com/the-ultimative-guide-for-the_post_thumbnail-in-wordpress-2-9/) * Justin Tadlock: [Everything you need to know about WordPress 2.9s post image feature](http://justintadlock.com/archives/2009/11/16/everything-you-need-to-know-about-wordpress-2-9s-post-image-feature)
* WP Recipes: [WordPress 2.9 : Display post image with backward compatibility](http://www.wprecipes.com/wordpress-2-9-display-post-image-with-backward-compatibility) * Chris Harrison: [Post Thumbnails in RSS Feeds](http://cdharrison.com/2009/12/the_post_thumbnail-for-rss-feeds/)
* Justin Tadlock: [Everything you need to know about WordPress 2.9s post image feature](http://justintadlock.com/archives/2009/11/16/everything-you-need-to-know-about-wordpress-2-9s-post-image-feature) * Technosailor: [10 Things You Need to Know About WordPress 2.9](http://technosailor.com/2009/11/11/10-things-you-need-to-know-about-wordpress-2-9/)
* Chris Harrison: [Post Thumbnails in RSS Feeds](http://cdharrison.com/2009/12/the_post_thumbnail-for-rss-feeds/)
* Technosailor: [10 Things You Need to Know About WordPress 2.9](http://technosailor.com/2009/11/11/10-things-you-need-to-know-about-wordpress-2-9/)
Well and that's it. I would love to link to some smart WordPress Codex pages for these new template tags but at the time of this writing there simply isn't anything in the Codex about this. Well and that's it. I would love to link to some smart WordPress Codex pages for these new template tags but at the time of this writing there simply isn't anything in the Codex about this.
@ -178,13 +194,8 @@ Well and that's it. I would love to link to some smart WordPress Codex pages for
As always: before making your next coffee you should share this article on your favorite social website. Your vote is highly appreciated! After you've finished voting and making your next coffee or tea you could subscribe to my [RSS-Feed](http://www.kremalicious.com/feed/), discuss this article or buy me my next coffee. As always: before making your next coffee you should share this article on your favorite social website. Your vote is highly appreciated! After you've finished voting and making your next coffee or tea you could subscribe to my [RSS-Feed](http://www.kremalicious.com/feed/), discuss this article or buy me my next coffee.
## Article Updates ## Article Updates
12/20/2009 Added some resources and a note about the named arguments 12/20/2009 Added some resources and a note about the named arguments
12/20/2009 function check for add_theme_support at the beginning 12/20/2009 function check for add_theme_support at the beginning
12/20/2009 corrected the size array code under Custom Output 12/20/2009 corrected the size array code under Custom Output

View File

@ -70,8 +70,8 @@ You can always refer to the inline commented versions of these snippets in the [
WordPress automatically puts an ID around your new menu item which contains the name of your custom post type (the $post_type parameter in `register_post_type()`). Just change this to your own post type name: WordPress automatically puts an ID around your new menu item which contains the name of your custom post type (the $post_type parameter in `register_post_type()`). Just change this to your own post type name:
{% highlight php %}
```php
<?php <?php
/** /**
* Custom Post Type Icon for Admin Menu & Post Screen * Custom Post Type Icon for Admin Menu & Post Screen
@ -118,15 +118,16 @@ function custom_post_type_icon() {
<?php } <?php }
?> ?>
```
{% endhighlight %}
### Plugin And Theme Options Icons ### Plugin And Theme Options Icons
The easiest way is to just use this markup on your option page before the page heading which is the default on all admin pages: The easiest way is to just use this markup on your option page before the page heading which is the default on all admin pages:
{% highlight html %}<div id="PLUGINNAME" class="icon32"></div> ```html
<h2>My cool option page</h2>{% endhighlight %} <div id="PLUGINNAME" class="icon32"></div>
<h2>My cool option page</h2>
```
This is the markup being addressed in the snippet block for option page icons. The `icon32` class will make sure everything is aligned consistent to all other pages without redefining everything in css. This is the markup being addressed in the snippet block for option page icons. The `icon32` class will make sure everything is aligned consistent to all other pages without redefining everything in css.
@ -136,8 +137,7 @@ Putting your plugin or option page in the top level of the admin menu via `add_m
So all this combined leads to this snippet: So all this combined leads to this snippet:
{% highlight php %} ```php
<?php <?php
/** /**
@ -196,8 +196,7 @@ function option_page_icon() {
<?php } <?php }
?> ?>
```
{% endhighlight %}
Just replace the bits in the ID selectors with your stuff. If you have problems finding the correct ID selector just inspect element in the admin area. Just replace the bits in the ID selectors with your stuff. If you have problems finding the correct ID selector just inspect element in the admin area.

View File

@ -28,10 +28,10 @@ While the size is the same as for the iPad 3 homescreen icon, I strongly suggest
As an example, I just [pushed](https://github.com/kremalicious/kremalicious2/commit/4c7e215f4abecde4385028767b633be1278f277e) the Metro [tile image](/metro-tile.png) for kremalicious.com with those `meta` tags: As an example, I just [pushed](https://github.com/kremalicious/kremalicious2/commit/4c7e215f4abecde4385028767b633be1278f277e) the Metro [tile image](/metro-tile.png) for kremalicious.com with those `meta` tags:
{% highlight html %} ```html
<meta name="msapplication-TileImage" content="/metro-tile.png"/> <meta name="msapplication-TileImage" content="/metro-tile.png"/>
<meta name="msapplication-TileColor" content="#015565"/> <meta name="msapplication-TileColor" content="#015565"/>
{% endhighlight %} ```
When browsing the site in Windows 8/Internet Explorer 10, users have the choice of pinning it to the start screen: When browsing the site in Windows 8/Internet Explorer 10, users have the choice of pinning it to the start screen:

View File

@ -1,7 +1,7 @@
--- ---
layout: post layout: post
title: Using &lt;kbd&gt; for fun and profit title: Using <kbd> for fun and profit
image: ../media/kremalicious-kbdfun-teaser.png image: ../media/kremalicious-kbdfun-teaser.png
style: post-kbd.min.css style: post-kbd.min.css
author: Matthias Kretschmann author: Matthias Kretschmann
@ -43,8 +43,10 @@ Just drop in the `kbdftw.css` in your `head`:
If you want to use the Android key style, include roboto.css before: If you want to use the Android key style, include roboto.css before:
{% highlight html %}<link rel="stylesheet" href="roboto.css"> ```html
<link rel="stylesheet" href="kbdfun.css">{% endhighlight %} <link rel="stylesheet" href="roboto.css">
<link rel="stylesheet" href="kbdfun.css">
```
You also need to add all the Roboto font files from assets/fonts to your project. You also need to add all the Roboto font files from assets/fonts to your project.
@ -58,21 +60,39 @@ For the Android style, there's `roboto.less` as include at the end. But the font
The default styling are light keys with Lucida Grande as font: The default styling are light keys with Lucida Grande as font:
{% highlight html %}<kbd>Q</kbd>{% endhighlight %} becomes <kbd>Q</kbd> ```html
<kbd>Q</kbd>
```
becomes <kbd>Q</kbd>
Add a dark class to get the dark keys: Add a dark class to get the dark keys:
{% highlight html %}<kbd class="dark">Q</kbd>{% endhighlight %} becomes <kbd class="dark">Q</kbd> ```html
<kbd class="dark">Q</kbd>
```
becomes <kbd class="dark">Q</kbd>
Adding an ios or android class gives a replica of those system keys. Android uses three different colors on the default keyboard. Adding an ios or android class gives a replica of those system keys. Android uses three different colors on the default keyboard.
{% highlight html %}<kbd class="ios">Q</kbd>{% endhighlight %} becomes <kbd class="ios">Q</kbd> ```html
<kbd class="ios">Q</kbd>
```
becomes <kbd class="ios">Q</kbd>
{% highlight html %}<kbd class="android">Q</kbd>{% endhighlight %} becomes <kbd class="android">Q</kbd> ```html
<kbd class="android">Q</kbd>
```
becomes <kbd class="android">Q</kbd>
{% highlight html %}<kbd class="android dark">Q</kbd>{% endhighlight %} becomes <kbd class="android dark">Q</kbd> ```html
<kbd class="android dark">Q</kbd>
```
becomes <kbd class="android dark">Q</kbd>
{% highlight html %}<kbd class="android color">Q</kbd>{% endhighlight %} becomes <kbd class="android color">Q</kbd> ```html
<kbd class="android color">Q</kbd>
```
becomes <kbd class="android color">Q</kbd>
I've let the default `display: inline` intact so all padding on the `kbd` elements won't affect the line-height of the surrounding text. This leads to problems when you want to use them over multiple lines so just make them `display: inline-block` in this scenario. I've let the default `display: inline` intact so all padding on the `kbd` elements won't affect the line-height of the surrounding text. This leads to problems when you want to use them over multiple lines so just make them `display: inline-block` in this scenario.

View File

@ -40,7 +40,7 @@ exports.createPages = ({ graphql, actions }) => {
const { createPage } = actions const { createPage } = actions
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
const postTemplate = path.resolve('src/templates/post.jsx') const postTemplate = path.resolve('src/templates/Post.jsx')
// const indexTemplate = path.resolve('src/templates/index.jsx') // const indexTemplate = path.resolve('src/templates/index.jsx')
// const tagPage = path.resolve('src/templates/tag.jsx') // const tagPage = path.resolve('src/templates/tag.jsx')
// const categoryPage = path.resolve('src/templates/category.jsx') // const categoryPage = path.resolve('src/templates/category.jsx')

View File

@ -1,6 +1,7 @@
@import 'variables'; @import 'variables';
.screen { .screen {
width: 100%;
max-width: 38rem; max-width: 38rem;
margin-left: auto; margin-left: auto;
margin-right: auto; margin-right: auto;

207
src/styles/_mixins.scss Normal file
View File

@ -0,0 +1,207 @@
@import 'variables';
// Centering Blocks
/////////////////////////////////////
@mixin aligncenter() {
display: block;
margin-left: auto;
margin-right: auto;
}
// Toggling content
/////////////////////////////////////
// Hide from both screenreaders and browsers: h5bp.com/u
@mixin hide() {
display: none !important;
visibility: hidden;
}
@mixin show() {
display: block;
visibility: visible;
}
// Hide only visually, but have it available for screenreaders: h5bp.com/v
@mixin visuallyhidden() {
border: 0;
clip: rect(0 0 0 0);
height: 1px;
margin: -1px;
overflow: hidden;
padding: 0;
position: absolute;
width: 1px;
// Extends the .visuallyhidden class to allow the
// element to be focusable when navigated to via the keyboard: h5bp.com/p
&.focusable:active,
&.focusable:focus {
clip: auto;
height: auto;
margin: 0;
overflow: visible;
position: static;
width: auto;
}
}
// Hide visually and from screenreaders, but maintain layout
@mixin invisible() {
visibility: hidden;
}
// CSS image replacement
/////////////////////////////////////
@mixin hide-text() {
font: 0/0 a; // stylelint-disable font-family-no-missing-generic-family-keyword
color: transparent;
text-shadow: none;
background-color: transparent;
border: 0;
}
// Text overflow
/////////////////////////////////////
@mixin ellipsis($width) {
width: $width;
text-overflow: ellipsis;
overflow: hidden;
white-space: nowrap;
}
// Default transition
/////////////////////////////////////
@mixin transition() {
transition: all ease-in-out .15s;
}
// Dashed Dividers
/////////////////////////////////////
@mixin divider() {
position: relative;
border-bottom: 1px dashed #afc3cb;
margin-top: $spacer;
margin-bottom: $spacer;
&::before {
content: '';
position: absolute;
left: 0;
height: 1px;
bottom: -2px;
width: 100%;
border-bottom: 1px dashed #fff;
}
}
// Heading band
/////////////////////////////////////
@mixin heading-band() {
display: inline-block;
clear: both;
background: rgba(255, 255, 255, .5);
padding: ($spacer/2) $spacer ($spacer/2) 100%;
margin-left: -100%;
}
// Lead paragraph
/////////////////////////////////////
@mixin lead() {
font-size: $font-size-large;
line-height: $spacer * 1.15;
}
// Layout breakout
/////////////////////////////////////
@mixin breakoutviewport() {
margin-left: calc(-50vw + 50%);
margin-right: calc(-50vw + 50%);
@media (min-width: $screen-md) {
@include breakoutviewport--base();
}
}
@mixin breakoutviewport--base() {
margin-left: -($spacer * 4);
margin-right: -($spacer * 4);
}
@mixin breakoutviewport--full() {
margin-left: calc(-50vw + 50%);
margin-right: calc(-50vw + 50%);
}
// Button sizing
/////////////////////////////////////
@mixin button-size(
$padding-vertical,
$padding-horizontal,
$font-size,
$line-height,
$border-radius
) {
padding: $padding-vertical $padding-horizontal;
font-size: $font-size;
line-height: $line-height;
border-radius: $border-radius;
}
// Form control sizing
/////////////////////////////////////
@mixin input-size(
$padding-vertical,
$padding-horizontal,
$font-size,
$line-height,
$border-radius
) {
padding: $padding-vertical $padding-horizontal;
font-size: $font-size;
line-height: $line-height;
border-radius: $border-radius;
&input[type='search'] {
background-size: $font-size;
background-position: $padding-vertical center;
padding-left: ($padding-vertical * 4);
}
&select {
line-height: $input-height;
}
&textarea,
&select[multiple] {
height: auto;
}
}
// Placeholder text
/////////////////////////////////////
@mixin placeholder($color: $input-color-placeholder) {
&::-moz-placeholder {
color: $color;
opacity: 1; // Override Firefox's unusual default opacity; See https//github.com/twbs/bootstrap/pull/11526
}
&::-webkit-input-placeholder {
color: $color;
}
&:-ms-input-placeholder {
color: $color;
}
}

View File

@ -68,6 +68,13 @@ $line-height-headings: 1.1;
$color-headings: $brand-main; $color-headings: $brand-main;
$color-headings--dark: $brand-main-light; $color-headings--dark: $brand-main-light;
// Spacing
/////////////////////////////////////
$spacer: ($font-size-base * $line-height);
$border-radius: 3px;
// Code // Code
///////////////////////////////////// /////////////////////////////////////
@ -76,13 +83,6 @@ $code-color: $brand-light;
$kbd-bg: $code-bg; $kbd-bg: $code-bg;
$kbd-color: $code-color; $kbd-color: $code-color;
// Components spacing
/////////////////////////////////////
$spacer: ($font-size-base * $line-height);
$border-radius: 3px;
// Responsive breakpoints // Responsive breakpoints
///////////////////////////////////// /////////////////////////////////////

View File

@ -172,7 +172,8 @@ a {
img, img,
video, video,
svg { svg,
figure {
max-width: 100%; max-width: 100%;
height: auto; height: auto;
margin: 0; margin: 0;
@ -340,13 +341,13 @@ blockquote {
color: #fff; color: #fff;
} }
// More basic elements
/////////////////////////////////////
#___gatsby { #___gatsby {
display: flex; display: flex;
min-height: 100vh; min-height: 100vh;
flex-direction: column; flex-direction: column;
} }
// More basic elements
/////////////////////////////////////
@import 'code'; @import 'code';

View File

@ -0,0 +1,70 @@
@import 'variables';
@import 'mixins';
.hentry {
padding-top: $spacer * 2;
padding-bottom: $spacer * 2;
width: 100%;
@media (min-width: $screen-sm) {
padding-top: $spacer * 3;
padding-bottom: $spacer * 3;
}
}
// Post Title
/////////////////////////////////////
.hentry__title {
font-size: $font-size-h1;
text-align: center;
color: $color-headings;
margin-top: 0;
margin-bottom: $spacer;
}
// Post/photo teaser
/////////////////////////////////////
.hentry__teaser {
@include breakoutviewport();
max-width: none;
display: block;
margin-top: $spacer * 1.5;
margin-bottom: $spacer * 1.5;
img {
border-radius: 0;
@media (min-width: $screen-sm) {
border-radius: $border-radius;
}
}
}
// Post Content
/////////////////////////////////////
.hentry__content {
h1,
h2 {
@include heading-band();
}
h1 {
font-size: $font-size-h2;
}
h2 {
font-size: $font-size-h3;
}
h3 {
font-size: $font-size-h4;
}
p:last-child {
margin-bottom: 0;
}
}

View File

@ -4,6 +4,7 @@ import Helmet from 'react-helmet'
import { graphql } from 'gatsby' import { graphql } from 'gatsby'
import Layout from '../components/Layout' import Layout from '../components/Layout'
import Image from '../components/atoms/Image' import Image from '../components/atoms/Image'
import styles from './Post.module.scss'
const Post = ({ data }) => { const Post = ({ data }) => {
const { markdownRemark: post } = data const { markdownRemark: post } = data
@ -13,11 +14,15 @@ const Post = ({ data }) => {
<Layout location={location}> <Layout location={location}>
<Helmet title={title} /> <Helmet title={title} />
<article className="blog-post"> <article className={styles.hentry}>
<h1 className="title">{title}</h1> <h1 className={styles.hentry__title}>{title}</h1>
{image && <Image fluid={image.childImageSharp.fluid} alt={title} />} {image && (
<figure className={styles.hentry__teaser}>
<Image fluid={image.childImageSharp.fluid} alt={title} />
</figure>
)}
<div <div
className="blog-post-content" className={styles.hentry__content}
dangerouslySetInnerHTML={{ __html: post.html }} dangerouslySetInnerHTML={{ __html: post.html }}
/> />
</article> </article>