355 lines
5.2 KiB
PHP
355 lines
5.2 KiB
PHP
|
<?php
|
||
|
|
||
|
if ( ! defined( 'ABSPATH' ) ) {
|
||
|
exit; // Exit if accessed directly
|
||
|
}
|
||
|
|
||
|
if ( ! class_exists( 'acf_loop' ) ) :
|
||
|
|
||
|
class acf_loop {
|
||
|
|
||
|
|
||
|
/*
|
||
|
* __construct
|
||
|
*
|
||
|
* This function will setup the class functionality
|
||
|
*
|
||
|
* @type function
|
||
|
* @date 5/03/2014
|
||
|
* @since 5.0.0
|
||
|
*
|
||
|
* @param n/a
|
||
|
* @return n/a
|
||
|
*/
|
||
|
|
||
|
function __construct() {
|
||
|
|
||
|
// vars
|
||
|
$this->loops = array();
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
/*
|
||
|
* is_empty
|
||
|
*
|
||
|
* This function will return true if no loops exist
|
||
|
*
|
||
|
* @type function
|
||
|
* @date 3/03/2016
|
||
|
* @since 5.3.2
|
||
|
*
|
||
|
* @param n/a
|
||
|
* @return (boolean)
|
||
|
*/
|
||
|
|
||
|
function is_empty() {
|
||
|
|
||
|
return empty( $this->loops );
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
/*
|
||
|
* is_loop
|
||
|
*
|
||
|
* This function will return true if a loop exists for the given array index
|
||
|
*
|
||
|
* @type function
|
||
|
* @date 3/03/2016
|
||
|
* @since 5.3.2
|
||
|
*
|
||
|
* @param $i (int)
|
||
|
* @return (boolean)
|
||
|
*/
|
||
|
|
||
|
function is_loop( $i = 0 ) {
|
||
|
|
||
|
return isset( $this->loops[ $i ] );
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
/*
|
||
|
* get_i
|
||
|
*
|
||
|
* This function will return a valid array index for the given $i
|
||
|
*
|
||
|
* @type function
|
||
|
* @date 3/03/2016
|
||
|
* @since 5.3.2
|
||
|
*
|
||
|
* @param $i (mixed)
|
||
|
* @return (int)
|
||
|
*/
|
||
|
|
||
|
function get_i( $i = 0 ) {
|
||
|
|
||
|
// 'active'
|
||
|
if ( $i === 'active' ) {
|
||
|
$i = -1;
|
||
|
}
|
||
|
|
||
|
// 'previous'
|
||
|
if ( $i === 'previous' ) {
|
||
|
$i = -2;
|
||
|
}
|
||
|
|
||
|
// allow negative to look at end of loops
|
||
|
if ( $i < 0 ) {
|
||
|
|
||
|
$i = count( $this->loops ) + $i;
|
||
|
|
||
|
}
|
||
|
|
||
|
// return
|
||
|
return $i;
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
/*
|
||
|
* add_loop
|
||
|
*
|
||
|
* This function will add a new loop
|
||
|
*
|
||
|
* @type function
|
||
|
* @date 3/03/2016
|
||
|
* @since 5.3.2
|
||
|
*
|
||
|
* @param $loop (array)
|
||
|
* @return n/a
|
||
|
*/
|
||
|
|
||
|
function add_loop( $loop = array() ) {
|
||
|
|
||
|
// defaults
|
||
|
$loop = wp_parse_args(
|
||
|
$loop,
|
||
|
array(
|
||
|
'selector' => '',
|
||
|
'name' => '',
|
||
|
'value' => false,
|
||
|
'field' => false,
|
||
|
'i' => -1,
|
||
|
'post_id' => 0,
|
||
|
'key' => '',
|
||
|
)
|
||
|
);
|
||
|
|
||
|
// ensure array
|
||
|
$loop['value'] = acf_get_array( $loop['value'] );
|
||
|
|
||
|
// Re-index values if this loop starts from index 0.
|
||
|
// This allows ajax previews to work ($_POST data contains random unique array keys)
|
||
|
if ( $loop['i'] == -1 ) {
|
||
|
|
||
|
$loop['value'] = array_values( $loop['value'] );
|
||
|
|
||
|
}
|
||
|
|
||
|
// append
|
||
|
$this->loops[] = $loop;
|
||
|
|
||
|
// return
|
||
|
return $loop;
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
/*
|
||
|
* update_loop
|
||
|
*
|
||
|
* This function will update a loop's setting
|
||
|
*
|
||
|
* @type function
|
||
|
* @date 3/03/2016
|
||
|
* @since 5.3.2
|
||
|
*
|
||
|
* @param $i (mixed)
|
||
|
* @param $key (string) the loop setting name
|
||
|
* @param $value (mixed) the loop setting value
|
||
|
* @return (boolean) true on success
|
||
|
*/
|
||
|
|
||
|
function update_loop( $i = 'active', $key = null, $value = null ) {
|
||
|
|
||
|
// i
|
||
|
$i = $this->get_i( $i );
|
||
|
|
||
|
// bail early if no set
|
||
|
if ( ! $this->is_loop( $i ) ) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
// set
|
||
|
$this->loops[ $i ][ $key ] = $value;
|
||
|
|
||
|
// return
|
||
|
return true;
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
/*
|
||
|
* get_loop
|
||
|
*
|
||
|
* This function will return a loop, or loop's setting for a given index & key
|
||
|
*
|
||
|
* @type function
|
||
|
* @date 3/03/2016
|
||
|
* @since 5.3.2
|
||
|
*
|
||
|
* @param $i (mixed)
|
||
|
* @param $key (string) the loop setting name
|
||
|
* @return (mixed) false on failure
|
||
|
*/
|
||
|
|
||
|
function get_loop( $i = 'active', $key = null ) {
|
||
|
|
||
|
// i
|
||
|
$i = $this->get_i( $i );
|
||
|
|
||
|
// bail early if no set
|
||
|
if ( ! $this->is_loop( $i ) ) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
// check for key
|
||
|
if ( $key !== null ) {
|
||
|
|
||
|
return $this->loops[ $i ][ $key ];
|
||
|
|
||
|
}
|
||
|
|
||
|
// return
|
||
|
return $this->loops[ $i ];
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
/*
|
||
|
* remove_loop
|
||
|
*
|
||
|
* This function will remove a loop
|
||
|
*
|
||
|
* @type function
|
||
|
* @date 3/03/2016
|
||
|
* @since 5.3.2
|
||
|
*
|
||
|
* @param $i (mixed)
|
||
|
* @return (boolean) true on success
|
||
|
*/
|
||
|
|
||
|
function remove_loop( $i = 'active' ) {
|
||
|
|
||
|
// i
|
||
|
$i = $this->get_i( $i );
|
||
|
|
||
|
// bail early if no set
|
||
|
if ( ! $this->is_loop( $i ) ) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
// remove
|
||
|
unset( $this->loops[ $i ] );
|
||
|
|
||
|
// reset keys
|
||
|
$this->loops = array_values( $this->loops );
|
||
|
|
||
|
// PHP 7.2 no longer resets array keys for empty value
|
||
|
if ( $this->is_empty() ) {
|
||
|
$this->loops = array();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
// initialize
|
||
|
acf()->loop = new acf_loop();
|
||
|
|
||
|
endif; // class_exists check
|
||
|
|
||
|
|
||
|
|
||
|
/*
|
||
|
* acf_add_loop
|
||
|
*
|
||
|
* alias of acf()->loop->add_loop()
|
||
|
*
|
||
|
* @type function
|
||
|
* @date 6/10/13
|
||
|
* @since 5.0.0
|
||
|
*
|
||
|
* @param n/a
|
||
|
* @return n/a
|
||
|
*/
|
||
|
|
||
|
function acf_add_loop( $loop = array() ) {
|
||
|
|
||
|
return acf()->loop->add_loop( $loop );
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
/*
|
||
|
* acf_update_loop
|
||
|
*
|
||
|
* alias of acf()->loop->update_loop()
|
||
|
*
|
||
|
* @type function
|
||
|
* @date 6/10/13
|
||
|
* @since 5.0.0
|
||
|
*
|
||
|
* @param n/a
|
||
|
* @return n/a
|
||
|
*/
|
||
|
|
||
|
function acf_update_loop( $i = 'active', $key = null, $value = null ) {
|
||
|
|
||
|
return acf()->loop->update_loop( $i, $key, $value );
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
/*
|
||
|
* acf_get_loop
|
||
|
*
|
||
|
* alias of acf()->loop->get_loop()
|
||
|
*
|
||
|
* @type function
|
||
|
* @date 6/10/13
|
||
|
* @since 5.0.0
|
||
|
*
|
||
|
* @param n/a
|
||
|
* @return n/a
|
||
|
*/
|
||
|
|
||
|
function acf_get_loop( $i = 'active', $key = null ) {
|
||
|
|
||
|
return acf()->loop->get_loop( $i, $key );
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
/*
|
||
|
* acf_remove_loop
|
||
|
*
|
||
|
* alias of acf()->loop->remove_loop()
|
||
|
*
|
||
|
* @type function
|
||
|
* @date 6/10/13
|
||
|
* @since 5.0.0
|
||
|
*
|
||
|
* @param n/a
|
||
|
* @return n/a
|
||
|
*/
|
||
|
|
||
|
function acf_remove_loop( $i = 'active' ) {
|
||
|
|
||
|
return acf()->loop->remove_loop( $i );
|
||
|
|
||
|
}
|
||
|
|
||
|
|