You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
133 lines
3.8 KiB
PHTML
133 lines
3.8 KiB
PHTML
8 months ago
|
<?php
|
||
|
/**
|
||
|
* Generalized dynamic content implementation to make it usable for WooCommerce Modules.
|
||
|
*
|
||
|
* @package Divi
|
||
|
* @subpackage Builder
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* Handle ajax requests to resolve post content.
|
||
|
*
|
||
|
* @since 3.17.2
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
function et_builder_ajax_resolve_post_content() {
|
||
|
if ( ! isset( $_POST['nonce'] ) || ! wp_verify_nonce( sanitize_text_field( $_POST['nonce'] ), 'et_fb_resolve_post_content' ) ) { // phpcs:ignore ET.Sniffs.ValidatedSanitizedInput -- The nonce value is used only for comparision in the `wp_verify_nonce`.
|
||
|
et_core_die();
|
||
|
}
|
||
|
|
||
|
$_ = ET_Core_Data_Utils::instance();
|
||
|
$post_id = isset( $_POST['post_id'] ) ? (int) $_POST['post_id'] : 0;
|
||
|
// phpcs:disable ET.Sniffs.ValidatedSanitizedInput -- All values from `$_POST['groups']` and `$_POST['overrides']` arrays value are being sanitized before use in following foreach loop.
|
||
|
$groups = isset( $_POST['groups'] ) && is_array( $_POST['groups'] ) ? $_POST['groups'] : array();
|
||
|
$overrides = isset( $_POST['overrides'] ) && is_array( $_POST['overrides'] ) ? $_POST['overrides'] : array();
|
||
|
// phpcs:enable
|
||
|
$overrides = array_map( 'wp_kses_post', $overrides );
|
||
|
$post = get_post( $post_id );
|
||
|
|
||
|
$invalid_permissions = ! current_user_can( 'edit_post', $post_id );
|
||
|
$invalid_post = null === $post;
|
||
|
|
||
|
if ( $invalid_permissions || $invalid_post ) {
|
||
|
et_core_die();
|
||
|
}
|
||
|
|
||
|
$response = array();
|
||
|
|
||
|
foreach ( $groups as $hash => $field_group ) {
|
||
|
$group = sanitize_text_field( isset( $field_group['group'] ) ? (string) $field_group['group'] : '' );
|
||
|
$field = isset( $field_group['field'] ) ? sanitize_text_field( (string) $field_group['field'] ) : '';
|
||
|
$settings = isset( $field_group['settings'] ) && is_array( $field_group['settings'] ) ? wp_unslash( $field_group['settings'] ) : array();
|
||
|
$settings = array_map( 'wp_kses_post', $settings );
|
||
|
$is_content = $_->array_get( $field_group, 'attribute' ) === 'content';
|
||
|
$response[ $hash ] = apply_filters( "et_builder_resolve_{$group}_post_content_field", $field, $settings, $post_id, $overrides, $is_content );
|
||
|
}
|
||
|
|
||
|
wp_send_json_success( $response );
|
||
|
}
|
||
|
add_action( 'wp_ajax_et_builder_resolve_post_content', 'et_builder_ajax_resolve_post_content' );
|
||
|
|
||
|
/**
|
||
|
* List terms for a given post.
|
||
|
*
|
||
|
* @since 3.17.2
|
||
|
*
|
||
|
* @param array $terms List of terms.
|
||
|
* @param boolean $link Whether return link or label.
|
||
|
* @param string $separator Terms separators.
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
function et_builder_list_terms( $terms, $link = true, $separator = ' | ' ) {
|
||
|
$output = array();
|
||
|
|
||
|
foreach ( $terms as $term ) {
|
||
|
$label = esc_html( $term->name );
|
||
|
|
||
|
if ( $link ) {
|
||
|
$label = sprintf(
|
||
|
'<a href="%1$s">%2$s</a>',
|
||
|
esc_url( get_term_link( $term ) ),
|
||
|
et_core_esc_previously( $label )
|
||
|
);
|
||
|
}
|
||
|
|
||
|
$output[] = $label;
|
||
|
}
|
||
|
|
||
|
return implode( esc_html( $separator ), $output );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get the title for the current page be it a post, a tax archive, search etc.
|
||
|
*
|
||
|
* @since 4.0
|
||
|
*
|
||
|
* @param integer $post_id Post id.
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
function et_builder_get_current_title( $post_id = 0 ) {
|
||
|
if ( 0 === $post_id ) {
|
||
|
$post_id = get_the_ID();
|
||
|
}
|
||
|
|
||
|
$post_id = (int) $post_id;
|
||
|
|
||
|
if ( ! ET_Builder_Element::is_theme_builder_layout() || is_singular() ) {
|
||
|
return get_the_title( $post_id );
|
||
|
}
|
||
|
|
||
|
if ( is_front_page() ) {
|
||
|
return __( 'Home', 'et_builder' );
|
||
|
}
|
||
|
|
||
|
if ( is_home() ) {
|
||
|
return __( 'Blog', 'et_builder' );
|
||
|
}
|
||
|
|
||
|
if ( is_404() ) {
|
||
|
return __( 'No Results Found', 'et_builder' );
|
||
|
}
|
||
|
|
||
|
if ( is_search() ) {
|
||
|
return sprintf( __( 'Results for "%1$s"', 'et_builder' ), get_search_query() );
|
||
|
}
|
||
|
|
||
|
if ( is_author() ) {
|
||
|
return get_the_author();
|
||
|
}
|
||
|
|
||
|
if ( is_post_type_archive() ) {
|
||
|
return post_type_archive_title( '', false );
|
||
|
}
|
||
|
|
||
|
if ( is_category() || is_tag() || is_tax() ) {
|
||
|
return single_term_title( '', false );
|
||
|
}
|
||
|
|
||
|
return get_the_archive_title();
|
||
|
}
|