Paulund http://www.paulund.co.uk Paulund | WordPress, PHP, CSS, HTML5 Wed, 23 Jul 2014 12:44:16 +0000 en-US hourly 1 http://wordpress.org/?v=3.9.1 Install Doctrine With Zend Framework 2 http://www.paulund.co.uk/install-doctrine-zend-framework-2 http://www.paulund.co.uk/install-doctrine-zend-framework-2#comments Wed, 23 Jul 2014 07:30:08 +0000 http://www.paulund.co.uk/?p=10853 In this tutorial we are going to learn how you can install doctrine into your Zend Framework 2 application. What Is Zend Framework 2? Zend framework is one of the most popular PHP frameworks created for high performing PHP applications. It is an open source project supported by Zend Technologies. Zend Framework uses 100% object-oriented approach to PHP development and uses most of the new features available to PHP including

The post Install Doctrine With Zend Framework 2 appeared first on Paulund.

]]>
In this tutorial we are going to learn how you can install doctrine into your Zend Framework 2 application.

What Is Zend Framework 2?

zend-framework
Zend framework is one of the most popular PHP frameworks created for high performing PHP applications. It is an open source project supported by Zend Technologies. Zend Framework uses 100% object-oriented approach to PHP development and uses most of the new features available to PHP including PHP namespaces, late static binding classes and closures.

It recently had a huge overhaul of code changes with the new Framework 2, now based of having code modules that you can include in your application. A module is like a plugin, you can drop this module into your application, enable the module and have access to all the features that this module allows you to have. The advantages of using modular code like this is that you can easily reuse this in other applications.

Therefore you could create a standard module to login to the application, for all your future applications you can simply reuse this module and you now take this functionality with you.

Zend Framework 2 is very extendable and flexible you will be able to create any type of website that you want. Using the MVC implementation Zend allows you to apply database abstraction in your application, decoupling the database and your presentation.

With most open source projects there is a strong community of developers that help with support questions, Zend Framework is no different there is a very active support community available for anyone stuck on both simple or difficult questions.

A big improvement in Zend Framework 2 is the use of PHPunit to test all the core code, this comes packaged with the framework making it very easy for you to test your own applications using PHPunit, giving you a test driven development approach to creating your application.

To try out the framework on your next project you can download it here.

Zend Framework 2

This tutorial assumes that you have an already installed version of Zend Framework, ready to start developing. If you need information about how to get started with Zend, follow this tutorial.

Getting Started With Zend Framework 2

What Is The Doctrine Project?

Doctrine is a set of PHP class libraries that are focused on database storage and database management. The main projects with Doctrine are the ORM (Object Relational Manager) and DBAL (Database Abstraction Layer). Using these two projects Doctrine allows you to build up database entities in PHP code that will represent your application's database structure.

Having PHP classes to construct your database structure means that you can use fully object oriented code to construct the Database queries, this provides developers with a powerful alternative to SQL that maintains flexibility without requiring unnecessary code duplication.

Doctrine

Installing With Composer

The easiest way to install Doctrine into your Zend Framework application is to use the PHP project composer.

Composer is a dependency manager for PHP allowing you to state what third party projects your application will depend on to work correctly. This will be populated into a composer config JSON file. Using this JSON file composer will automatically get the any version of the repository and install the code into your application.

As our Zend application will have a Database dependency of Doctrine we need to ensure that this is included in our application.

To install the doctrine project in your application use the following command.

php composer.phar require doctrine/doctrine-orm-module:0.8.*

This has now downloaded all the files needed for doctrine and placed it inside the /vendor folder in your Zend Application.

To monitor the queries that the database is making the Zend Framework Developer Tools can be very useful, use the following composer command to install the repository.

php composer.phar require zendframework/zend-developer-tools:dev-master

When the Zend Developer Tools have installed you need to move the configuration file into your application config.

cp vendor/zendframework/zend-developer-tools/config/zenddevelopertools.local.php.dist config/autoload/zdt.local.php

With Doctrine code installed in your application you need to enable the Doctrine modules with Zend.

Open you application config file and add the new modules to the module array config/application.config.php

return array(
    'modules' => array(
        'ZendDeveloperTools',
        'DoctrineModule',
        'DoctrineORMModule',
        'Application',
    ),
    // [...]
);

Doctrine is now installed in your Zend application and you can start adding the entities you need to create the doctrine database.

Create Your First Entity

Create a folder where you want to store your application entities, can be in an existing module or in a new module for your entities.

Inside the entity folder create a new PHP file called User.php, this class will be used to define the structure of the User entity and database structure for the user table.

<?php
namespace Application\Entity;
use Doctrine\ORM\Mapping as ORM;

/** @ORM\Entity */
class User
{
    /**
    * @ORM\Id
    * @ORM\GeneratedValue(strategy="AUTO")
    * @ORM\Column(type="integer")
    */
    protected $id;

    /** @ORM\Column(type="string") */
    protected $Name;
}

Next you will need to tell Doctrine where to find your entities in your file structure, open the Zend module config file /config/module.config.php and paste the following code.

<?php
namespace Application;

return array(
    'doctrine' => array(
        'driver' => array(
            __NAMESPACE__ . '_driver' => array(
                'class' => 'Doctrine\ORM\Mapping\Driver\AnnotationDriver',
                'cache' => 'array',
                'paths' => array(__DIR__ . '/../src/' . __NAMESPACE__ . '/Entity',  // Define path of entities
                )
            ),
            'orm_default' => array(
                'drivers' => array(
                    __NAMESPACE__ . '\Entity' => __NAMESPACE__ . '_driver'  // Define namespace of entities
                )
            )
        )
    ),
);

If the entity has been successfully mapped to Doctrine then you will see this defined on the Zend Developer Toolbar.

user-mapping

Connecting To The Database

With an entity created we can now connect to the database and get Doctrine to use the entity defined to create the database structure.

In your Zend application config/autoload folder create a new file named doctrine.local.php and paste in the following code, changes the settings with your database login.

<?php
return array(
    'doctrine' => array(
        'connection' => array(
            'orm_default' => array(
                'driverClass' =>'Doctrine\DBAL\Driver\PDOMySql\Driver',
                'params' => array(
                    'host'     => 'localhost',
                    'port'     => '',
                    'user'     => 'user',
                    'password' => 'pass',
                    'dbname'   => 'data',
                )))));

To check that the PHP entities and database structures are mapped correctly you can validation the schema by running the following command.

vendor/bin/doctrine-module orm:validate-schema

This will show you that the entity files are setup correctly but the database schema does not match up with the entities.

validate-doctrine-schema

Now we can create the database by running the following command.

vendor/bin/doctrine-module orm:schema-tool:create

After running this command you can now switch to your database and you should see the user table with the columns we defined in the entity.

user-database

With the table and Doctrine entity created we can now use this in our application to add data to the table. For this you need to use the Zend service locator to get the entity manager, then you can create a new instance of the user entity, populate the entity and use the entity manager to add the data to the database.

Below is the example code of how you can use the entity manager to populate new rows into your database.

<?php
namespace Application\Controller;

use Zend\Mvc\Controller\AbstractActionController;
use Zend\View\Model\ViewModel;

class IndexController extends AbstractActionController
{
    public function indexAction() {
        $entityManager = $this
            ->getServiceLocator()
            ->get('Doctrine\ORM\EntityManager');

        $user = new \Application\Entity\User();
        $user->setName('Paul Underwood');

        $entityManager->persist($user);
        $entityManager->flush();

        echo $user->getId();

        return new ViewModel();
    }
}

If the query was successful then this code should output a number 1 on the view and the database will have the new user of Paul Underwood in the first row.

This is a simple example of getting Doctrine setup in your application you can now take this info your next project and develop a website in Zend with Doctrine powering the database.

The post Install Doctrine With Zend Framework 2 appeared first on Paulund.

]]>
http://www.paulund.co.uk/install-doctrine-zend-framework-2/feed 0
How To Use WordPress Thickbox To Create A Gallery http://www.paulund.co.uk/use-wordpress-thickbox-create-gallery http://www.paulund.co.uk/use-wordpress-thickbox-create-gallery#comments Mon, 21 Jul 2014 08:30:14 +0000 http://www.paulund.co.uk/?p=10784 WordPress comes with an inbuilt Javascript library which allows you to easily show pop-up dialog boxes on your WordPress site. This Javascript library is called Thickbox, which is a lightweight library used to create dialog widgets built on top of the jQuery library. The Thickbox library can be used to display an image, multiple images, inline content, iframed content and even content from an iframe. Thickbox Using the Thickbox library

The post How To Use WordPress Thickbox To Create A Gallery appeared first on Paulund.

]]>
WordPress comes with an inbuilt Javascript library which allows you to easily show pop-up dialog boxes on your WordPress site. This Javascript library is called Thickbox, which is a lightweight library used to create dialog widgets built on top of the jQuery library.

thickbox

The Thickbox library can be used to display an image, multiple images, inline content, iframed content and even content from an iframe.

Thickbox

Using the Thickbox library you can turn your images on a WordPress post into a pop-up gallery.

How To Use Thickbox

To use Thickbox on your WordPress site you need to include the Javascript and the CSS files into the page. As this is one of the default scripts that is included with WordPress you just simply need to call the handle for Thickbox and it will include the Javascript files on to the page.

On the wp_enqueue_scripts action you will need to call the functions wp_enqueue_script with a handle of thickbox and a dependency of jQuery, as this is already registered by WordPress we don't need to provide a source for the script.

The next function will need to add the Thickbox styles to the page by using wp_enqueue_style, the Thickbox library is located in the wp-includes folder inside the js folder /wp-includes/js/thickbox.

function include_thickbox_scripts()
{
    // include the javascript
    wp_enqueue_script('thickbox', null, array('jquery'));

    // include the thickbox styles
    wp_enqueue_style('thickbox.css', '/'.WPINC.'/js/thickbox/thickbox.css', null, '1.0');
}
add_action('wp_enqueue_scripts', 'include_thickbox_scripts');

Enable Images To Use Thickbox

With the Thickbox styles and Javascript files included on the page we can add images to the post and add the required HTML class to enable Thickbox on the images.

To use Thickbox you will need to add a link around the image with a HTML class of Thickbox.

<a href="images/image1.jpg" title="Image 1" class="thickbox"><img src="images/image1_thumbnail.jpg" alt="Image 1" /></a>

This enabled Thickbox on the image, where on the click event of the image the Thickbox dialog box will pop-up with the image in the href displayed in the Thickbox.

Create A Thickbox Gallery

You can use Thickbox to create a gallery of images allowing you to navigate between multiple images, to create a gallery you simply need to add a rel="" attribute to the link around the image.

<a href="images/image1.jpg" title="Image 1" class="thickbox" rel="gallery"><img src="images/image1_thumbnail.jpg" alt="Image 1" /></a>
<a href="images/image2.jpg" title="Image 2" class="thickbox" rel="gallery"><img src="images/image2_thumbnail.jpg" alt="Image 2" /></a>
<a href="images/image3.jpg" title="Image 3" class="thickbox" rel="gallery"><img src="images/image3_thumbnail.jpg" alt="Image 3" /></a>

Automatically Add Thickbox Class To All Images

If you would like to use Thickbox on every image on your WordPress site that has a link around it then you can use the_content filter to search for images with a link around them and add the class="thickbox" to the image links.

This uses a regular expression to find all images with links and replaces the HTML with a link and a HTML class of thickbox.

function auto_add_thickbox($content)
{
    $content = preg_replace('/<a(.*?)href="(.*?).(jpg|jpeg|png|gif|bmp|ico)"(.*?)><img/U', '<a$1href="$2.$3" $4 class="thickbox"><img', $content);

    return $content;
}
add_filter('the_content', 'auto_add_thickbox', 2)

Add Class With jQuery

An alternative to adding the thickbox HTML around all links with the WordPress filter is to use jQuery to find all images on the page, step up to it's parent element which has to be an anchor tag, then we add a class of thickbox.

jQuery(document).ready(function() {
    jQuery("img").parent("a").addClass("thickbox");
});

The post How To Use WordPress Thickbox To Create A Gallery appeared first on Paulund.

]]>
http://www.paulund.co.uk/use-wordpress-thickbox-create-gallery/feed 0
Using IF Statements In Sass http://www.paulund.co.uk/using-statements-sass http://www.paulund.co.uk/using-statements-sass#comments Wed, 09 Jul 2014 07:54:27 +0000 http://www.paulund.co.uk/?p=10727 In previous tutorials we were investigating some of the features and benefits you get with using Sass to generate your CSS files. If you haven't tried Sass then I advise you look into using it in your next project, to get information on what's involved with Sass view my article on Getting Started with Sass. We also learnt that you can use loops just like in other programming languages to

The post Using IF Statements In Sass appeared first on Paulund.

]]>
In previous tutorials we were investigating some of the features and benefits you get with using Sass to generate your CSS files.

If you haven't tried Sass then I advise you look into using it in your next project, to get information on what's involved with Sass view my article on Getting Started with Sass.

We also learnt that you can use loops just like in other programming languages to dynamically create classes for your CSS.

In this article we are going to look at using IF statements in Sass.

To use IF statements you do this by defining them prefixed with a @.

p
{
    @if 1 + 1 == 2 { border: 1px solid;  }
}

Sass IF Statements

This will allow you to create a mixin where you pass in a number of different parameters which can change the outcome of the values for element. The below mixin is something you can apply to any element which you want to make absolute positioned, then you just pass in the values for top, right, bottom and left. We then use the IF statements to see if the parameter has a value, if it hasn't then we just ignore that property. This will allow you to exactly position the element anywhere you want using only the properties that you need to.

@mixin absolute-position($top, $right, $bottom, $left)
{
  position: absolute;

  @if $top != '' {
    top: $top;
  }

  @if $right != '' {
    right: $right;
  }

  @if $bottom != '' {
    bottom: $bottom;
  }

  @if $left != '' {
    left: $left;
  }
}

The post Using IF Statements In Sass appeared first on Paulund.

]]>
http://www.paulund.co.uk/using-statements-sass/feed 0
Convert Image To Data URI With PHP http://www.paulund.co.uk/convert-image-base64-php http://www.paulund.co.uk/convert-image-base64-php#comments Tue, 08 Jul 2014 07:44:07 +0000 http://www.paulund.co.uk/?p=10730 One of the easiest ways to speed up your page loading times is to reduce the amount of HTTP requests that your website makes, each time your webpage needs to fetch an external resource such as a CSS stylesheet, a Javascript files or images it will make a HTTP request to the server. The server will then return this resource back to your web page and use this on the

The post Convert Image To Data URI With PHP appeared first on Paulund.

]]>
One of the easiest ways to speed up your page loading times is to reduce the amount of HTTP requests that your website makes, each time your webpage needs to fetch an external resource such as a CSS stylesheet, a Javascript files or images it will make a HTTP request to the server. The server will then return this resource back to your web page and use this on the requested page.

The more HTTP requests that your website has will lead to slowing down your site, there are a few things you can do with stylesheets and Javascript files to reduce requests, such as combining the files together and minimising the contents of the files. If you have multiple CSS files you should combine the content of these into one file, this will cut down the HTTP requests as the web page will only need to load one CSS file.

The way you can reduce HTTP requests in images is to make sure that the page doesn't need to request the image by embedding it directing into the web page itself, therefore it can simply load the image and doesn't need to request it from a server.

Using data URIs it allows you to convert resources such as images into data strings that you can embedded directly into the browser.

This allows you to take the following image.
google

And convert it into a data URI string.



You can then take this string and add it to either your image tag src="" attribute or to your CSS files as the background: url('').

<img src="" />
.image-1
{
   background: url('') no-repeat;
}

Convert Image To Data URI With PHP

Using PHP you can create your own data URIs to use in your webpages, to create the data URI you need to know the mime type of the image and then use the PHP function base64_encode() to convert the contents of the image into a data URI string, which can be done with the following code snippet.

$image = 'myimage.png';
$type = pathinfo($image, PATHINFO_EXTENSION);
$data = file_get_contents($image);
$dataUri = 'data:image/' . $type . ';base64,' . base64_encode($data);

Image To Data URI Converter

If you want to use a tool to convert your images to data URI string so you can copy and paste the string instead of using PHP to do this on your applications, then you can use the Image to Base64 Converter tool at Coveloping.com.

All you have to do is upload the image you want to convert and click the convert button, the textarea will then be populated with the content of the image as a data URI string.

Image To Data URI Converter

The post Convert Image To Data URI With PHP appeared first on Paulund.

]]>
http://www.paulund.co.uk/convert-image-base64-php/feed 0
Dynamically Create Classes With SASS http://www.paulund.co.uk/dynamically-create-css-classes-sass http://www.paulund.co.uk/dynamically-create-css-classes-sass#comments Thu, 03 Jul 2014 18:02:00 +0000 http://www.paulund.co.uk/?p=10796 There are many advantages to using CSS pre-processors like SASS, some of the features allow you to end up writing less CSS code by using inheritance and functions in SASS to reuse the same code on your different CSS classes and IDs. To learn more about getting started with SASS you can refer to a previous articles. Getting started with SASS One of my favourite features of SASS is the

The post Dynamically Create Classes With SASS appeared first on Paulund.

]]>
There are many advantages to using CSS pre-processors like SASS, some of the features allow you to end up writing less CSS code by using inheritance and functions in SASS to reuse the same code on your different CSS classes and IDs.

To learn more about getting started with SASS you can refer to a previous articles.

Getting started with SASS

One of my favourite features of SASS is the ability to use loops to dynamically create your CSS classes. A good example of this is when you want to make a set of classes to use for changing the text colours and background colours of elements you would normally have to write CSS like this.

.red-background {
  background: #FF0000;
}

.red-color {
  color: #FF0000;
}

.blue-background {
  background: #001EFF;
}

.blue-color {
  color: #001EFF;
}

.green-background {
  background: #00FF00;
}

.green-color {
  color: #00FF00;
}

.yellow-background {
  background: #F6FF00;
}

.yellow-color {
  color: #F6FF00;
}

If you want to add additional colours to this later you will have to remember to write both background and colour classes. With SASS we can create a list of our colours and then loop through these to create the CSS classes.

To create a list in SASS all you have to do is create a comma separated list of key value pairs like the following.

$colours:
  "red" #FF0000,
  "blue" #001EFF,
  "green" #00FF00,
  "yellow" #F6FF00;

Using the @each keyword in SASS we can loop through each of the colours and then use the nth() function to get the name of the class and the value of the class to dynamically create the classes in our CSS. The following each loop will generate exactly the same colour classes as above with only a few lines of code.

@each $i in $colours{
  .#{nth($i, 1)}-background {
    background: nth($i, 2);
  }
  .#{nth($i, 1)}-color {
    color:nth($i, 2);
  }
}

The post Dynamically Create Classes With SASS appeared first on Paulund.

]]>
http://www.paulund.co.uk/dynamically-create-css-classes-sass/feed 0
Free Files For July 2014 http://www.paulund.co.uk/free-files-july-2014 http://www.paulund.co.uk/free-files-july-2014#comments Tue, 01 Jul 2014 15:47:06 +0000 http://www.paulund.co.uk/?p=10798 Each month the Envato marketplace brings you free premium files. Envato is a web marketplace where you can get premium files for different areas of your website. My favourite marketplaces are the script marketplace CodeCanyon and the theme marketplace ThemeForest. Here are the files which you can get for free in July 2014. Simple QR Codes - WordPress Shortcode 9 purchases at the price of $10. Simple QR Codes is

The post Free Files For July 2014 appeared first on Paulund.

]]>
Each month the Envato marketplace brings you free premium files.

Envato is a web marketplace where you can get premium files for different areas of your website. My favourite marketplaces are the script marketplace CodeCanyon and the theme marketplace ThemeForest.

Here are the files which you can get for free in July 2014.

Simple QR Codes - WordPress Shortcode

Simple QR Codes - WordPress Shortcode

9 purchases at the price of $10.

Simple QR Codes is a beautiful QR codes plugin that displays 9 types of qr codes via shortcodes. Add a simple but very useful feature to your website with this stylish plugin. You can use them anywhere in the website, to display nice short information about things that your visitors can save easily on their mobile devices. You can set 9 types of QR codes with any size and any alignment.

Download For Free

Plasma - One-Page Multi-Purpose HTML Template

Plasma - One-Page Multi-Purpose HTML Template

93 purchases at the price of $15.

Plasma is a fully responsive one-page HTML template or Creative Page html template is easily usable with any device (Desktop, tablet, mobile phone…), without removing any content!.
Plasma is a responsive html template that modest for your Business , Portfolio and your website agency that you can be Special with this theme .
The theme has a gallery for featured work special, paginated blog, awsome hover effect, and contact work. The template offers a quick and easy setup.

Download For Free

Camera Recording Screen 01

Camera Recording Screen 01

63 purchases at the price of $3.

1920×1080 30p HD Video
Two Videos – Normal and Low Battery
30 seconds of footage
Music is not included, you can get it here – Flying Colors
Footage from preview not included, you can get it here:

Download For Free

Absolutely Uplifting

AudioJungle

97 purchases at the price of $17.

This corporate track has an uplifting and positive feel. It’s written in modern pop-rock style with the mood of hope, prompting, and optimism. This track could be useful for commercial advertising projects, as the background music on business presentation, sports or commercial video.

Download For Free

Corporate Letterhead Vol.2 with MS Word Doc

Corporate Letterhead Vol.2 with MS Word Doc

72 purchases at the price of $6.

Corporate Letterhead designed in 4 different color schemes with stylish design elements. You can easily change the logo, contact information and color of the element itself in just 1 click. Corporate Letterhead can be used absolutely any company or for personal use.

Download For Free

Mesa Arch

Mesa Arch

0 purchases at the price of $5.

Mesa Arch in morning’s sunlight

Download For Free

3D Car Rim Granturismo

3D Car Rim Granturismo

0 purchases at the price of $5.

3D model of Granturismo Aluminium Car Rim created in Cinema 4D. This 3D rim model has 15387 polygons.

Download For Free

IntroOne - XML Driven Dynamic Flash Intro

IntroOne - XML Driven Dynamic Flash Intro

32 purchases at the price of $8.

IntroOne is XML driven, dynamic Flash intro with particle blast effect. It can display any number of text/slogans synchronized with background sound. You can also include single image/logo using img tag. Sound, images and swf font libraries are externally loaded, and there are over 30 available XML settings, what allows you customize this intro with no need to open Flash

Download For Free

The post Free Files For July 2014 appeared first on Paulund.

]]>
http://www.paulund.co.uk/free-files-july-2014/feed 0
Speech Bubble SASS Mixin http://www.paulund.co.uk/speech-bubble-sass-mixin http://www.paulund.co.uk/speech-bubble-sass-mixin#comments Mon, 30 Jun 2014 08:56:15 +0000 http://www.paulund.co.uk/?p=10777 The following code will allow you easily create speech bubble banners in CSS using SASS mixins. Since pseudo-classes such as :before or :after was introduced into CSS we have been able to do so much more using just CSS. For example with CSS we can now create a number of different shapes as you can see in this tutorial. How To Create Shapes In CSS From this tutorial we can

The post Speech Bubble SASS Mixin appeared first on Paulund.

]]>
The following code will allow you easily create speech bubble banners in CSS using SASS mixins.

Since pseudo-classes such as :before or :after was introduced into CSS we have been able to do so much more using just CSS. For example with CSS we can now create a number of different shapes as you can see in this tutorial.

How To Create Shapes In CSS

From this tutorial we can see how to create a speech bubble shape by combining two shapes together, the rectangle and the triangle shape, allowing us to style elements like this.

This is done with the following CSS.

.speech-bubble
{
  background: #ddd;
  display: inline-block;
  padding: 15px;
  position: relative;
  margin-left: 15px;
  height:100px;
  width:400px;
}
.speech-bubble:before
{
  content: '';
  position: absolute;
  left: -15px;
  top: 50%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  border-top: 7px solid transparent;
  border-right: 15px solid #ddd;
  border-bottom: 7px solid transparent;
}

Because there are a few calculations and duplicate colours in this CSS code it is perfect to use as a SASS mixin and then we can reuse this code in another area of the website with different size speech bubbles if we need to.

If you are not familiar with SASS and the benefits it can provide you with your CSS then you should have a look at this article about getting started with SASS.

To create a SASS mixin you need to use the keyword @mixin and then rest of the syntax is similar to a function you will see in other languages. The text inside the mixin will be output on the CSS property this is applied to.

To start off we are going to pass in two parameters the size of the speech bubble and the background colour, these are important to pass through as parameters as these are really the only properties that are going to need to change. From the $size parameter we need to set the margin-left of the box, this makes room for the triangle at the start of the bubble. We will also use this $size to calculate the size of the triangle.

@mixin speech-bubble($size, $background)
{
  background: $background;
  display: inline-block;
  padding: $size;
  position: relative;
  margin-left: $size;

  &:before
  {
    content: '';
    position: absolute;
    left: -$size;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    border-top: ($size / 2) solid transparent;
    border-right: $size solid $background;
    border-bottom: ($size / 2) solid transparent;
  }
}

To use this mixin we need to use the @include keyword and pass in the two parameters. When SASS is compiled it will output the CSS needed to create the speech bubble.

.speech-bubble
{
   @include speech-bubble(15px, #1e252b);
}

The post Speech Bubble SASS Mixin appeared first on Paulund.

]]>
http://www.paulund.co.uk/speech-bubble-sass-mixin/feed 0
Display Content For Registered Only Users In WordPress http://www.paulund.co.uk/registered-content-shortcodes http://www.paulund.co.uk/registered-content-shortcodes#comments Wed, 11 Jun 2014 08:39:29 +0000 http://www.paulund.co.uk/?p=10755 The registered users of your website are the most valuable visitors you can get on your website, these people are loyal visitors and you should reward them for that. One of the best ways of rewarding your registered users is with new premium content, which can be reserved just for the visitors who are logged in. The following code snippet will allow you to place content which is only available

The post Display Content For Registered Only Users In WordPress appeared first on Paulund.

]]>
The registered users of your website are the most valuable visitors you can get on your website, these people are loyal visitors and you should reward them for that. One of the best ways of rewarding your registered users is with new premium content, which can be reserved just for the visitors who are logged in.

The following code snippet will allow you to place content which is only available for the users that have logged into your website, we will then use a shortcode to show the difference between normal content and premium content just for logged in users.

The following code snippet will first check to see if the user is logged in, this check is done by a WordPress function is_user_logged_in(). Then we need to check that the content is not empty, we also need to check that the content is not currently being displayed on the RSS feed.

Simply add the following code in your plugin or functions.php file to register a new shortcode called members_only.

add_shortcode( 'members_only', 'members_only_shortcode' );
function members_only_shortcode( $atts, $content = null ) 
{
    if ( is_user_logged_in() && !empty( $content ) && !is_feed() )
    {
        return $content;
    }
    
    return 'To view this content please login.';
}

Now that a shortcode has been registered you can use this in the content area just like the code below.

[members_only]
Display this content only for users which are logged in.
[/members_only]

Please note that this solution will only be acceptable if admin user of the site does not remove the theme or plugin where this shortcode function exists. If they remove the plugin or theme then all the content inside this shortcode will be available for everyone to see.

The post Display Content For Registered Only Users In WordPress appeared first on Paulund.

]]>
http://www.paulund.co.uk/registered-content-shortcodes/feed 0
Sort Multi-Dimensional Array By Value In PHP http://www.paulund.co.uk/sort-multi-dimensional-array-value http://www.paulund.co.uk/sort-multi-dimensional-array-value#comments Mon, 09 Jun 2014 08:09:01 +0000 http://www.paulund.co.uk/?p=10709 The following code snippet will help to sort multi-dimensional arrays by a value of one of the elements. If you look at the code below we have an array populated with 3 other arrays, each of them has an ID element, a title element and an order element. At the moment these are simply in order of how they were added to the array but because there is an order

The post Sort Multi-Dimensional Array By Value In PHP appeared first on Paulund.

]]>
The following code snippet will help to sort multi-dimensional arrays by a value of one of the elements.

If you look at the code below we have an array populated with 3 other arrays, each of them has an ID element, a title element and an order element. At the moment these are simply in order of how they were added to the array but because there is an order element identifying what position they should be in we need to re-sort these in the correct order.

Array
(
    [item-1] => Array
        (
            [id] => 1
            [title] => Item 1
            [order] => 3
        )

    [item-2] => Array
        (
            [id] => 2
            [title] => Item 2
            [order] => 2
        )

    [item-3] => Array
        (
            [id] => 3
            [title] => Item 3
            [order] => 1
        )
)

We do have a couple of options when it comes to sorting arrays, PHP comes with loads of functions that are designed to make sorting arrays easier.

Array Sorting

Some of the functions you can use are:

  • array_multisort()
  • asort()
  • arsort()
  • krsort()
  • ksort()
  • natcasesort()
  • natsort()
  • rsort()
  • shuffle()
  • sort()
  • uasort()
  • uksort()
  • usort()

The difference between these functions is that some will sort by value, sort by keys, maintain the keys, replace the keys, user defined ordering, alphabetically order, there are lots of different ways you would want to sort an array so you need to make sure you are going to use the correct one.

For the above example we are going to use the function usort() as it allows the user to define what values you want to use to sort on, as we need to sort on the order element this is exactly what we want.

usort($array, 'sort_by_order ');
function sort_by_order ($a, $b)
{
    return $a['order'] - $b['order'];
}

The usort() function is used by passing in the array and callback function that you want to use to compare the array element, PHP will then pass into this function the fields of the array as two parameters which you can then compare and values you define and will know which way to sort these by how you return the values from the function.

Below is how the above usort function will be returned.

Array
(
    [0] => Array
        (
            [id] => 3
            [title] => Item 3
            [order] => 1
        )

    [1] => Array
        (
            [id] => 2
            [title] => Item 2
            [order] => 2
        )

    [2] => Array
        (
            [id] => 1
            [title] => Item 1
            [order] => 3
        )
)

As you can see the array elements are now in the correct order by using the value inside the order element. But the problem with using usort is that it will remove the existing keys from your array and use the standard index keys. The solution to this problem is to use a different sorting function called uasort() which will maintain your defined array keys.

uasort($array, 'sort_by_order ');
function sort_by_order ($a, $b)
{
    return $a['order'] - $b['order'];
}

Used exactly the same way as usort(), but looking at the output below you will see that the keys are now maintained to how they were defined.

Array
(
    [item-3] => Array
        (
            [id] => 3
            [title] => Item 3
            [order] => 1
        )

    [item-2] => Array
        (
            [id] => 2
            [title] => Item 2
            [order] => 2
        )

    [item-1] => Array
        (
            [id] => 1
            [title] => Item 1
            [order] => 3
        )
)

The post Sort Multi-Dimensional Array By Value In PHP appeared first on Paulund.

]]>
http://www.paulund.co.uk/sort-multi-dimensional-array-value/feed 0
Checking Media Queries With Javascript http://www.paulund.co.uk/checking-media-queries-javascript http://www.paulund.co.uk/checking-media-queries-javascript#comments Fri, 06 Jun 2014 07:15:25 +0000 http://www.paulund.co.uk/?p=10675 With the web being used on so many different devices now it's very important that you can change your design to fit on different screen sizes. The best way of changing your display depending on screen size is to use media queries to find out the size viewport of the screen and allowing you to change the design depending on what screen size is on. You will mainly make these

The post Checking Media Queries With Javascript appeared first on Paulund.

]]>
With the web being used on so many different devices now it's very important that you can change your design to fit on different screen sizes. The best way of changing your display depending on screen size is to use media queries to find out the size viewport of the screen and allowing you to change the design depending on what screen size is on.

You will mainly make these changes in the CSS file as you can define the media query break points to change the design on different devices like this.

/* Smartphones (portrait) ----------- */
@media only screen
and (max-width : 320px) {

}

/* Desktops and laptops ----------- */
@media only screen
and (min-width : 1224px) {

}

/* Large screens ----------- */
@media only screen
and (min-width : 1824px) {

}

The above code will allow you to make styling completely different on different devices, but what if you wanted to change the functionality of the site depending on the screen size? What if you needed to use some Javascript code on different screen sizes, for example to create a slide down navigation button.

How Do You Use Media Queries With jQuery

Media queries will be checking the width of the window to see what the size of the device is so you would think that you can use a method like .width() on the window object like this.

if($(window).width() < 767)
{
   // change functionality for smaller screens
} else {
   // change functionality for larger screens
}

But this will not return the true value of the window as it takes into effect things like body padding and scroll bars on the window. The other option you have when checking the media size is to use a Javascript method of .matchMedia() on the window object.

var window_size = window.matchMedia('(max-width: 768px)'));

This works the same way as media queries and is supported on many browsers apart from IE9 and lower.

Can I Use window.matchMedia

To use matchMedia you need to pass in the min or max values you want to check (like media queries) and see if the viewport matches this.

if (window.matchMedia('(max-width: 768px)').matches)
{
    // do functionality on screens smaller than 768px
}

Now you can use this to add a click event on to a sub-menu for screens smaller than 768px. The below code is an example of how you can add some Javascript code which will only be run on screens smaller than 768px.

if (window.matchMedia('(max-width: 768px)').matches)
{
    $('.sub-menu-button').on('click', function(e)
    {
        var subMenu = $(this).next('.sub-navigation');
        if(subMenu.is(':visible'))
        {
            subMenu.slideUp();
        } else {
            subMenu.slideDown();
        }

        return false;
    });
}

The post Checking Media Queries With Javascript appeared first on Paulund.

]]>
http://www.paulund.co.uk/checking-media-queries-javascript/feed 0