Skip to content

desrosj/respect-art-direction

Repository files navigation

Respect Art Direction

Build Status Test Coverage Code Climate Issue Count

In version 4.4, WordPress merged responsive image support in core. This meant sites would automatically benefit from responsive images through the srcset attribute.

However, this feature does not account for art direction, a common problem in responsive design.

This plugin is a proof of concept for a way to solve this.

Approach

WordPress core defines several image sizes (large, medium, thumbnail, and medium_large). Other image sizes need to be defined within a plugin or theme as needed using the after_setup_theme action hook.

In themes, defined image sizes usually have specific purposes. A banner image, or related post image, for example.

function mytheme_add_image_sizes() {
    add_image_size( 'header_banner', 1200, 200, true );
    add_image_size( 'related_post', 400, 300, true );
}
add_action( 'after_setup_theme', 'mytheme_add_image_sizes' );

What if we took a similar approach to defining breakpoints and image sources?

Defining Breakpoints

function mytheme_add_breakpoints() {
    rad_add_breakpoint( 'mytheme_large', '(min-width: 1000px)' );
    rad_add_breakpoint( 'mytheme_medium', '(min-width: 480px)' );
    rad_add_breakpoint( 'mytheme_small', '(max-width: 479px)' );
}
add_action( 'after_setup_theme', 'mytheme_add_breakpoints' );

A breakpoint consists of a name, and a media query that attribute.

Defining Image Sources

function mytheme_add_image_sources() {
    rad_add_source_list( 'source_size1', array(
        'mytheme_large' => array(
            'custom1_large_size',
        ),
        'mytheme_medium' => array(
            'custom1_medium_size',
        ),
        'mytheme_small' => array(
            'custom1_small_size',
        ),
        'default' => array(
            'custom1_default_size',
        ),
    ) );
}
add_action( 'after_setup_theme', 'mytheme_add_image_sources' );

An image source is a name and a multidimensional array. The key of each array index represents the breakpoint it belongs to, and the values in each array represent the registered image sizes that belong to that breakpoint.

The image source name is a sort of pseudo image name. If you request markup using a source set as the image size, it will replace the markup with a <picture> tag properly populated with <source> tags. based on the registered breakpoints and image sizes.

About

An attempt to solve the art direction problem with responsive images in WordPress core.

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published