This commit is contained in:
2026-04-26 23:47:49 +02:00
parent 1b95f03d1e
commit b073e009d8
5288 changed files with 1112699 additions and 55536 deletions

View File

@@ -43,6 +43,7 @@ class Facebook extends Settings implements Pixel {
add_action( 'pys_register_pixels', function( $core ) {
/** @var PYS $core */
$core->registerPixel( $this );
} );
add_action( 'wp_head', array( $this, 'output_meta_tag' ) );
@@ -76,7 +77,8 @@ class Facebook extends Settings implements Pixel {
if(count($ids) == 0|| empty($ids[0])) {
return apply_filters("pys_facebook_ids",[]);
} else {
return apply_filters("pys_facebook_ids",(array) reset( $ids )); // return first id only
$id = array_shift($ids);
return apply_filters("pys_facebook_ids", array($id)); // return first id only
}
}
@@ -85,16 +87,17 @@ class Facebook extends Settings implements Pixel {
return array(
'pixelIds' => $this->getPixelIDs(),
'advancedMatching' => $this->getOption( 'advanced_matching_enabled' ) ? Helpers\getAdvancedMatchingParams() : array(),
'removeMetadata' => $this->getOption( 'remove_metadata' ),
'advancedMatchingEnabled' => $this->getOption( 'advanced_matching_enabled' ),
'removeMetadata' => $this->getOption( 'remove_metadata' ),
'contentParams' => getTheContentParams(),
'commentEventEnabled' => $this->getOption( 'comment_event_enabled' ),
'wooVariableAsSimple' => $this->getOption( 'woo_variable_as_simple' ),
'downloadEnabled' => $this->getOption( 'download_event_enabled' ),
'formEventEnabled' => $this->getOption( 'form_event_enabled' ),
"ajaxForServerEvent" => $this->getOption( "server_event_use_ajax" ),
'serverApiEnabled' => $this->isServerApiEnabled() && count($this->getApiToken()) > 0,
'wooCRSendFromServer' => $this->getOption("woo_complete_registration_send_from_server") && $this->getOption("woo_complete_registration_fire_every_time")
);
'wooCRSendFromServer' => $this->getOption("woo_complete_registration_send_from_server") && $this->getOption("woo_complete_registration_fire_every_time"),
'send_external_id' => $this->getOption('send_external_id')
);
}
@@ -805,8 +808,21 @@ class Facebook extends Settings implements Pixel {
if ( ! $this->getOption( 'woo_purchase_enabled' ) ) {
return false;
}
$key = sanitize_key($_REQUEST['key']);
$order_id = (int) wc_get_order_id_by_order_key( $key );
$order_key = sanitize_key($_REQUEST['key']);
$cache_key = 'order_id_' . $order_key;
$order_id = get_transient( $cache_key );
global $wp;
if (is_order_received_page() && empty($order_id) && $wp->query_vars['order-received']) {
$order_id = absint( $wp->query_vars['order-received'] );
if ($order_id) {
set_transient( $cache_key, $order_id, HOUR_IN_SECONDS );
}
}
if ( empty($order_id) ) {
$order_id = (int) wc_get_order_id_by_order_key( $order_key );
set_transient( $cache_key, $order_id, HOUR_IN_SECONDS );
}
$order = new \WC_Order( $order_id );
$content_ids = array();
@@ -874,6 +890,10 @@ class Facebook extends Settings implements Pixel {
$params['currency'] = get_woocommerce_currency();
$params['order_id'] = $order_id;
$params['fees'] = get_fees($order);
return array(
'name' => 'Purchase',
'data' => $params,
@@ -982,17 +1002,17 @@ class Facebook extends Settings implements Pixel {
$params = array(
'content_type' => 'product',
'content_ids' => Helpers\getFacebookEddDownloadContentId( $post->ID ),
'content_ids' => Helpers\getFacebookEddDownloadContentId( $download_id ),
);
// content_name, category_name
$params['tags'] = implode( ', ', getObjectTerms( 'download_tag', $post->ID ) );
$params = array_merge( $params, Helpers\getEddCustomAudiencesOptimizationParams( $post->ID ) );
$params['tags'] = implode( ', ', getObjectTerms( 'download_tag', $download_id ) );
$params = array_merge( $params, Helpers\getEddCustomAudiencesOptimizationParams( $download_id ) );
// currency, value
if ( PYS()->getOption( 'edd_add_to_cart_value_enabled' ) ) {
$amount = getEddDownloadPriceToDisplay( $post->ID, $price_index );
$amount = getEddDownloadPriceToDisplay( $download_id, $price_index );
$value_option = PYS()->getOption( 'edd_add_to_cart_value_option' );
$global_value = PYS()->getOption( 'edd_add_to_cart_value_global', 0 );