2008-05-21 01:56:04 -04:00
|
|
|
<?php
|
2008-09-27 06:06:18 -04:00
|
|
|
/**
|
|
|
|
* BackPress styles procedural API.
|
|
|
|
*
|
|
|
|
* @package BackPress
|
|
|
|
* @since r79
|
|
|
|
*/
|
2008-05-21 01:56:04 -04:00
|
|
|
|
2008-09-27 06:06:18 -04:00
|
|
|
/**
|
2008-10-18 16:46:30 -04:00
|
|
|
* Display styles that are in the queue or part of $handles.
|
2008-09-27 06:06:18 -04:00
|
|
|
*
|
|
|
|
* @since r79
|
2008-10-18 16:46:30 -04:00
|
|
|
* @uses do_action() Calls 'wp_print_styles' hook.
|
|
|
|
* @global object $wp_styles The WP_Styles object for printing styles.
|
2008-09-27 06:06:18 -04:00
|
|
|
*
|
2009-12-24 03:21:16 -05:00
|
|
|
* @param array|bool $handles Styles to be printed. An empty array prints the queue,
|
|
|
|
* an array with one string prints that style, and an array of strings prints those styles.
|
2008-10-18 16:46:30 -04:00
|
|
|
* @return bool True on success, false on failure.
|
2008-09-27 06:06:18 -04:00
|
|
|
*/
|
2008-05-21 01:56:04 -04:00
|
|
|
function wp_print_styles( $handles = false ) {
|
|
|
|
do_action( 'wp_print_styles' );
|
|
|
|
if ( '' === $handles ) // for wp_head
|
|
|
|
$handles = false;
|
|
|
|
|
|
|
|
global $wp_styles;
|
|
|
|
if ( !is_a($wp_styles, 'WP_Styles') ) {
|
|
|
|
if ( !$handles )
|
2011-07-24 20:36:06 -04:00
|
|
|
return array(); // No need to instantiate if nothing is there.
|
2008-05-21 01:56:04 -04:00
|
|
|
else
|
2008-06-04 16:21:02 -04:00
|
|
|
$wp_styles = new WP_Styles();
|
2008-05-21 01:56:04 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
return $wp_styles->do_items( $handles );
|
|
|
|
}
|
|
|
|
|
2011-07-24 20:36:06 -04:00
|
|
|
/**
|
|
|
|
* Adds extra CSS.
|
|
|
|
*
|
|
|
|
* Works only if the stylesheet has already been added.
|
2011-07-28 14:24:00 -04:00
|
|
|
* Accepts a string $data containing the CSS. If two or more CSS code blocks are
|
|
|
|
* added to the same stylesheet $handle, they will be printed in the order
|
|
|
|
* they were added, i.e. the latter added styles can redeclare the previous.
|
2011-07-24 20:36:06 -04:00
|
|
|
*
|
|
|
|
* @since 3.3
|
|
|
|
* @see WP_Scripts::add_inline_style()
|
|
|
|
*/
|
|
|
|
function wp_add_inline_style( $handle, $data ) {
|
|
|
|
global $wp_styles;
|
|
|
|
if ( !is_a($wp_styles, 'WP_Styles') )
|
|
|
|
return false;
|
|
|
|
|
|
|
|
return $wp_styles->add_inline_style( $handle, $data );
|
|
|
|
}
|
|
|
|
|
2008-10-18 16:46:30 -04:00
|
|
|
/**
|
|
|
|
* Register CSS style file.
|
|
|
|
*
|
|
|
|
* @since r79
|
2009-12-24 03:21:16 -05:00
|
|
|
* @see WP_Styles::add() For additional information.
|
|
|
|
* @global object $wp_styles The WP_Styles object for printing styles.
|
|
|
|
* @link http://www.w3.org/TR/CSS2/media.html#media-types List of CSS media types.
|
|
|
|
*
|
|
|
|
* @param string $handle Name of the stylesheet.
|
|
|
|
* @param string|bool $src Path to the stylesheet from the root directory of WordPress. Example: '/css/mystyle.css'.
|
|
|
|
* @param array $deps Array of handles of any stylesheet that this stylesheet depends on.
|
|
|
|
* (Stylesheets that must be loaded before this stylesheet.) Pass an empty array if there are no dependencies.
|
2009-12-27 19:48:20 -05:00
|
|
|
* @param string|bool $ver String specifying the stylesheet version number. Set to NULL to disable.
|
|
|
|
* Used to ensure that the correct version is sent to the client regardless of caching.
|
2009-12-24 03:21:16 -05:00
|
|
|
* @param string $media The media for which this stylesheet has been defined.
|
2008-10-18 16:46:30 -04:00
|
|
|
*/
|
2008-10-29 18:17:54 -04:00
|
|
|
function wp_register_style( $handle, $src, $deps = array(), $ver = false, $media = 'all' ) {
|
2008-05-21 01:56:04 -04:00
|
|
|
global $wp_styles;
|
2011-08-17 01:48:13 -04:00
|
|
|
|
|
|
|
wp_styles_init();
|
2008-05-21 01:56:04 -04:00
|
|
|
|
|
|
|
$wp_styles->add( $handle, $src, $deps, $ver, $media );
|
|
|
|
}
|
|
|
|
|
2008-10-18 16:46:30 -04:00
|
|
|
/**
|
|
|
|
* Remove a registered CSS file.
|
|
|
|
*
|
|
|
|
* @since r79
|
2009-12-24 03:21:16 -05:00
|
|
|
* @see WP_Styles::remove() For additional information.
|
|
|
|
* @global object $wp_styles The WP_Styles object for printing styles.
|
|
|
|
*
|
|
|
|
* @param string $handle Name of the stylesheet.
|
2008-10-18 16:46:30 -04:00
|
|
|
*/
|
2008-05-21 01:56:04 -04:00
|
|
|
function wp_deregister_style( $handle ) {
|
|
|
|
global $wp_styles;
|
2011-08-17 01:48:13 -04:00
|
|
|
|
|
|
|
wp_styles_init();
|
2008-05-21 01:56:04 -04:00
|
|
|
|
|
|
|
$wp_styles->remove( $handle );
|
|
|
|
}
|
|
|
|
|
2008-10-18 16:46:30 -04:00
|
|
|
/**
|
|
|
|
* Enqueue a CSS style file.
|
|
|
|
*
|
2009-12-27 19:48:20 -05:00
|
|
|
* Registers the style if src provided (does NOT overwrite) and enqueues.
|
|
|
|
*
|
2008-10-18 16:46:30 -04:00
|
|
|
* @since r79
|
|
|
|
* @see WP_Styles::add(), WP_Styles::enqueue()
|
2009-12-24 03:21:16 -05:00
|
|
|
* @global object $wp_styles The WP_Styles object for printing styles.
|
|
|
|
* @link http://www.w3.org/TR/CSS2/media.html#media-types List of CSS media types.
|
|
|
|
*
|
|
|
|
* @param string $handle Name of the stylesheet.
|
|
|
|
* @param string|bool $src Path to the stylesheet from the root directory of WordPress. Example: '/css/mystyle.css'.
|
|
|
|
* @param array $deps Array of handles (names) of any stylesheet that this stylesheet depends on.
|
|
|
|
* (Stylesheets that must be loaded before this stylesheet.) Pass an empty array if there are no dependencies.
|
|
|
|
* @param string|bool $ver String specifying the stylesheet version number, if it has one. This parameter
|
|
|
|
* is used to ensure that the correct version is sent to the client regardless of caching, and so should be included
|
|
|
|
* if a version number is available and makes sense for the stylesheet.
|
|
|
|
* @param string $media The media for which this stylesheet has been defined.
|
2008-10-18 16:46:30 -04:00
|
|
|
*/
|
2010-04-27 16:04:23 -04:00
|
|
|
function wp_enqueue_style( $handle, $src = false, $deps = array(), $ver = false, $media = 'all' ) {
|
2008-05-21 01:56:04 -04:00
|
|
|
global $wp_styles;
|
2011-08-17 01:48:13 -04:00
|
|
|
|
|
|
|
wp_styles_init();
|
2008-05-21 01:56:04 -04:00
|
|
|
|
|
|
|
if ( $src ) {
|
|
|
|
$_handle = explode('?', $handle);
|
|
|
|
$wp_styles->add( $_handle[0], $src, $deps, $ver, $media );
|
|
|
|
}
|
|
|
|
$wp_styles->enqueue( $handle );
|
|
|
|
}
|
2009-02-15 06:04:42 -05:00
|
|
|
|
2010-09-09 00:42:47 -04:00
|
|
|
/**
|
|
|
|
* Remove an enqueued style.
|
|
|
|
*
|
|
|
|
* @since WP 3.1
|
|
|
|
* @see WP_Styles::dequeue() For parameter information.
|
|
|
|
*/
|
|
|
|
function wp_dequeue_style( $handle ) {
|
|
|
|
global $wp_styles;
|
2011-08-17 01:48:13 -04:00
|
|
|
|
|
|
|
wp_styles_init();
|
2010-09-09 00:42:47 -04:00
|
|
|
|
|
|
|
$wp_styles->dequeue( $handle );
|
|
|
|
}
|
|
|
|
|
2009-02-15 06:04:42 -05:00
|
|
|
/**
|
|
|
|
* Check whether style has been added to WordPress Styles.
|
|
|
|
*
|
2009-12-24 03:21:16 -05:00
|
|
|
* The values for list defaults to 'queue', which is the same as wp_enqueue_style().
|
2009-02-15 06:04:42 -05:00
|
|
|
*
|
|
|
|
* @since WP unknown; BP unknown
|
2009-12-24 03:21:16 -05:00
|
|
|
* @global object $wp_styles The WP_Styles object for printing styles.
|
2009-02-15 06:04:42 -05:00
|
|
|
*
|
2009-12-24 03:21:16 -05:00
|
|
|
* @param string $handle Name of the stylesheet.
|
|
|
|
* @param string $list Values are 'registered', 'done', 'queue' and 'to_do'.
|
|
|
|
* @return bool True on success, false on failure.
|
2009-02-15 06:04:42 -05:00
|
|
|
*/
|
|
|
|
function wp_style_is( $handle, $list = 'queue' ) {
|
|
|
|
global $wp_styles;
|
2011-08-17 01:48:13 -04:00
|
|
|
|
|
|
|
wp_styles_init();
|
2009-02-15 06:04:42 -05:00
|
|
|
|
|
|
|
$query = $wp_styles->query( $handle, $list );
|
|
|
|
|
|
|
|
if ( is_object( $query ) )
|
|
|
|
return true;
|
|
|
|
|
|
|
|
return $query;
|
|
|
|
}
|
2011-08-17 01:48:13 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Initializes $wp_styles global (if it hasn't already been initialized by a faulty plugin or theme).
|
|
|
|
*
|
|
|
|
* @since 3.3
|
|
|
|
*/
|
|
|
|
function wp_styles_init() {
|
|
|
|
global $wp_styles;
|
|
|
|
static $done = false;
|
|
|
|
|
|
|
|
if ( !$done && !is_a($wp_styles, 'WP_Styles') ) {
|
|
|
|
if ( !did_action('after_setup_theme') ) {
|
|
|
|
$func = debug_backtrace();
|
|
|
|
$trace = !empty($func[1]['function']) ? $func[1]['function'] : __FUNCTION__;
|
|
|
|
|
|
|
|
_doing_it_wrong( $trace, __( '$wp_styles should not be accessed before the "init" hook.' ), '3.3' );
|
|
|
|
}
|
|
|
|
|
|
|
|
$wp_styles = new WP_Styles();
|
|
|
|
$done = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|