/wp-content/plugins/wp-e-commerce/wpsc-admin/ajax-and-init.php
PHP | 1826 lines | 1451 code | 282 blank | 93 comment | 380 complexity | d6a11d68467375166bb31640a6d12350 MD5 | raw file
Possible License(s): AGPL-1.0, GPL-2.0
- <?php
- /**
- * WP eCommerce Admin AJAX functions
- *
- * These are the WPSC Admin AJAX functions
- *
- * @package wp-e-commerce
- * @since 3.7
- */
- function wpsc_ajax_add_tracking() {
- global $wpdb;
- foreach ( $_POST as $key => $value ) {
- $parts = preg_split( '/^wpsc_trackingid/', $key );
- if ( count( $parts ) > '1' ) {
- $id = $parts[1];
- $trackingid = $value;
- $sql = "UPDATE `" . WPSC_TABLE_PURCHASE_LOGS . "` SET `track_id`='" . $trackingid . "' WHERE `id`=" . $id;
- $wpdb->query( $sql );
- }
-
- }
- }
- if ( isset( $_REQUEST['submit'] ) && ($_REQUEST['submit'] == 'Add Tracking ID') ) {
- add_action( 'admin_init', 'wpsc_ajax_add_tracking' );
- }
- function wpsc_purchlog_email_trackid() {
- global $wpdb;
- $id = absint( $_POST['purchlog_id'] );
- $trackingid = $wpdb->get_var( "SELECT `track_id` FROM " . WPSC_TABLE_PURCHASE_LOGS . " WHERE `id`={$id} LIMIT 1" );
- $message = get_option( 'wpsc_trackingid_message' );
- $message = str_replace( '%trackid%', $trackingid, $message );
- $message = str_replace( '%shop_name%', get_option( 'blogname' ), $message );
- $email_form_field = $wpdb->get_var( "SELECT `id` FROM `" . WPSC_TABLE_CHECKOUT_FORMS . "` WHERE `type` IN ('email') AND `active` = '1' ORDER BY `checkout_order` ASC LIMIT 1" );
- $email = $wpdb->get_var( "SELECT `value` FROM `" . WPSC_TABLE_SUBMITED_FORM_DATA . "` WHERE `log_id`=" . $id . " AND `form_id` = '$email_form_field' LIMIT 1" );
- $subject = get_option( 'wpsc_trackingid_subject' );
- $subject = str_replace( '%shop_name%', get_option( 'blogname' ), $subject );
- add_filter( 'wp_mail_from', 'wpsc_replace_reply_address', 0 );
- add_filter( 'wp_mail_from_name', 'wpsc_replace_reply_name', 0 );
- wp_mail( $email, $subject, $message);
- remove_filter( 'wp_mail_from_name', 'wpsc_replace_reply_name' );
- remove_filter( 'wp_mail_from', 'wpsc_replace_reply_address' );
- exit( true );
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'purchlog_email_trackid') ) {
- add_action( 'admin_init', 'wpsc_purchlog_email_trackid' );
- }
- function wpsc_ajax_sales_quarterly() {
- $lastdate = $_POST['add_start'];
- $date = preg_split( '/-/', $lastdate );
- if ( !isset( $date[0] ) )
- $date[0] = 0;
- if ( !isset( $date[1] ) )
- $date[1] = 0;
- if ( !isset( $date[2] ) )
- $date[2] = 0;
- $lastquart = mktime( 0, 0, 0, $date[1], $date[2], $date[0] );
- if ( $lastquart != get_option( 'wpsc_last_quarter' ) ) {
- update_option( 'wpsc_last_date', $lastdate );
- update_option( 'wpsc_fourth_quart', $lastquart );
- $thirdquart = mktime( 0, 0, 0, $date[1] - 3, $date[2], $date[0] );
- update_option( 'wpsc_third_quart', $thirdquart );
- $secondquart = mktime( 0, 0, 0, $date[1] - 6, $date[2], $date[0] );
- update_option( 'wpsc_second_quart', $secondquart );
- $firstquart = mktime( 0, 0, 0, $date[1] - 9, $date[2], $date[0] );
- update_option( 'wpsc_first_quart', $firstquart );
- $finalquart = mktime( 0, 0, 0, $date[1], $date[2], $date[0] - 1 );
- update_option( 'wpsc_final_quart', $finalquart );
- }
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'wpsc_quarterly') ) {
- add_action( 'admin_init', 'wpsc_ajax_sales_quarterly' );
- }
- function wpsc_delete_file() {
- global $wpdb;
- $output = 0;
- $row_number = absint( $_GET['row_number'] );
- $product_id = absint( $_GET['product_id'] );
- $file_name = basename( $_GET['file_name'] );
- check_admin_referer( 'delete_file_' . $file_name );
- $sql = $wpdb->prepare( "SELECT ID FROM $wpdb->posts WHERE post_title = %s AND post_parent = %d AND post_type ='wpsc-product-file'", $file_name, $product_id );
- $product_id_to_delete = $wpdb->get_var( $sql );
- wp_delete_post( $product_id_to_delete, true );
- if ( $_POST['ajax'] !== 'true' ) {
- $sendback = wp_get_referer();
- wp_redirect( $sendback );
- }
- echo "jQuery('#select_product_file_row_$row_number').fadeOut('fast',function() {\n";
- echo " jQuery(this).remove();\n";
- echo " jQuery('div.select_product_file p:even').removeClass('alt');\n";
- echo " jQuery('div.select_product_file p:odd').addClass('alt');\n";
- echo "});\n";
- exit( "" );
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'delete_file') ) {
- add_action( 'admin_init', 'wpsc_delete_file' );
- }
- /**
- Function and action for publishing or unpublishing single products
- */
- function wpsc_ajax_toggle_published() {
- $product_id = absint( $_GET['product'] );
- check_admin_referer( 'toggle_publish_' . $product_id );
- $status = (wpsc_toggle_publish_status( $product_id )) ? ('true') : ('false');
- $sendback = add_query_arg( 'flipped', "1", wp_get_referer() );
- wp_redirect( $sendback );
- exit();
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'toggle_publish') ) {
- add_action( 'admin_init', 'wpsc_ajax_toggle_published' );
- }
- /**
- Function and action for duplicating products,
- Refactored for 3.8
- * Purposely not duplicating stick post status (logically, products are most often duplicated because they share many attributes, where products are generally 'featured' uniquely.)
- */
- function wpsc_duplicate_product() {
- // Get the original post
- $id = absint( $_GET['product'] );
- $post = wpsc_duplicate_this_dangit( $id );
- // Copy the post and insert it
- if ( isset( $post ) && $post != null ) {
- $new_id = wpsc_duplicate_product_process( $post );
- $duplicated = true;
- $sendback = wp_get_referer();
- $sendback = add_query_arg( 'duplicated', (int)$duplicated, $sendback );
- wp_redirect( $sendback );
- exit();
- } else {
- wp_die( __( 'Sorry, for some reason, we couldn\'t duplicate this product because it could not be found in the database, check there for this ID: ' ) . $id );
- }
- }
- function wpsc_duplicate_this_dangit( $id ) {
- $post = get_post($id);
- return $post;
- }
- function wpsc_duplicate_product_process( $post ) {
- $new_post_date = $post->post_date;
- $new_post_date_gmt = get_gmt_from_date( $new_post_date );
- $new_post_type = $post->post_type;
- $post_content = str_replace( "'", "''", $post->post_content );
- $post_content_filtered = str_replace( "'", "''", $post->post_content_filtered );
- $post_excerpt = str_replace( "'", "''", $post->post_excerpt );
- $post_title = str_replace( "'", "''", $post->post_title ) . " (Duplicate)";
- $post_name = str_replace( "'", "''", $post->post_name );
- $comment_status = str_replace( "'", "''", $post->comment_status );
- $ping_status = str_replace( "'", "''", $post->ping_status );
-
- $defaults = array(
- 'post_status' => $post->post_status,
- 'post_type' => $new_post_type,
- 'ping_status' => $ping_status,
- 'post_parent' => $post->post_parent,
- 'menu_order' => $post->menu_order,
- 'to_ping' => $post->to_ping,
- 'pinged' => $post->pinged,
- 'post_excerpt' => $post_excerpt,
- 'post_title' => $post_title,
- 'post_content' => $post_content,
- 'post_content_filtered' => $post_content_filtered,
- 'import_id' => 0
- );
- // Insert the new template in the post table
- $new_post_id = wp_insert_post($defaults);
- // Copy the taxonomies
- wpsc_duplicate_taxonomies( $post->ID, $new_post_id, $post->post_type );
- // Copy the meta information
- wpsc_duplicate_product_meta( $post->ID, $new_post_id );
- // Finds children (Which includes product files AND product images), their meta values, and duplicates them.
- wpsc_duplicate_children( $post->ID, $new_post_id );
- return $new_post_id;
- }
- /**
- * Copy the taxonomies of a post to another post
- */
- function wpsc_duplicate_taxonomies( $id, $new_id, $post_type ) {
- $taxonomies = get_object_taxonomies( $post_type ); //array("category", "post_tag");
- foreach ( $taxonomies as $taxonomy ) {
- $post_terms = wp_get_object_terms( $id, $taxonomy );
- for ( $i = 0; $i < count( $post_terms ); $i++ ) {
- wp_set_object_terms( $new_id, $post_terms[$i]->slug, $taxonomy, true );
- }
- }
- }
- /**
- * Copy the meta information of a post to another post
- */
- function wpsc_duplicate_product_meta( $id, $new_id ) {
- global $wpdb;
- $post_meta_infos = $wpdb->get_results( "SELECT meta_key, meta_value FROM $wpdb->postmeta WHERE post_id=$id" );
- if ( count( $post_meta_infos ) != 0 ) {
- $sql_query = "INSERT INTO $wpdb->postmeta (post_id, meta_key, meta_value) ";
- foreach ( $post_meta_infos as $meta_info ) {
- $meta_key = $meta_info->meta_key;
- $meta_value = addslashes( $meta_info->meta_value );
- $sql_query_sel[] = "SELECT $new_id, '$meta_key', '$meta_value'";
- }
- $sql_query.= implode( " UNION ALL ", $sql_query_sel );
- $wpdb->query( $sql_query );
- }
- }
- /**
- * Duplicates children product and children meta
- */
- function wpsc_duplicate_children( $old_parent_id, $new_parent_id ) {
- global $wpdb;
- //Get children products and duplicate them
- $child_posts = $wpdb->get_results( "SELECT * FROM $wpdb->posts WHERE post_parent = $old_parent_id" );
- foreach ( $child_posts as $child_post ) {
- $new_post_date = $child_post->post_date;
- $new_post_date_gmt = get_gmt_from_date( $new_post_date );
- $new_post_type = $child_post->post_type;
- $post_content = str_replace( "'", "''", $child_post->post_content );
- $post_content_filtered = str_replace( "'", "''", $child_post->post_content_filtered );
- $post_excerpt = str_replace( "'", "''", $child_post->post_excerpt );
- $post_title = str_replace( "'", "''", $child_post->post_title );
- $post_name = str_replace( "'", "''", $child_post->post_name );
- $comment_status = str_replace( "'", "''", $child_post->comment_status );
- $ping_status = str_replace( "'", "''", $child_post->ping_status );
- $wpdb->query(
- "INSERT INTO $wpdb->posts
- (post_author, post_date, post_date_gmt, post_content, post_content_filtered, post_title, post_excerpt, post_status, post_type, comment_status, ping_status, post_password, to_ping, pinged, post_modified, post_modified_gmt, post_parent, menu_order, post_mime_type)
- VALUES
- ('$child_post->post_author', '$new_post_date', '$new_post_date_gmt', '$post_content', '$post_content_filtered', '$post_title', '$post_excerpt', '$child_post->post_status', '$new_post_type', '$comment_status', '$ping_status', '$child_post->post_password', '$child_post->to_ping', '$child_post->pinged', '$new_post_date', '$new_post_date_gmt', '$new_parent_id', '$child_post->menu_order', '$child_post->post_mime_type')" );
- $old_post_id = $child_post->ID;
- $new_post_id = $wpdb->insert_id;
- $child_meta = $wpdb->get_results( "SELECT post_id, meta_key, meta_value FROM $wpdb->postmeta WHERE post_id = $old_post_id" );
- foreach ( $child_meta as $child_meta ) {
- $wpdb->query(
- "INSERT INTO $wpdb->postmeta (post_id, meta_key, meta_value)
- VALUES('$new_post_id', '$child_meta->meta_key', '$child_meta->meta_value')"
- );
- }
- }
- }
- if ( isset( $_GET['wpsc_admin_action'] ) && ($_GET['wpsc_admin_action'] == 'duplicate_product') ) {
- add_action( 'admin_init', 'wpsc_duplicate_product' );
- }
- function wpsc_purchase_log_csv() {
- global $wpdb, $wpsc_gateways;
- get_currentuserinfo();
- $count = 0;
- if ( ($_GET['rss_key'] == 'key') && is_numeric( $_GET['start_timestamp'] ) && is_numeric( $_GET['end_timestamp'] ) && current_user_can( 'manage_options' ) ) {
- $form_sql = "SELECT * FROM `" . WPSC_TABLE_CHECKOUT_FORMS . "` WHERE `active` = '1' AND `type` != 'heading' ORDER BY `checkout_order` DESC;";
- $form_data = $wpdb->get_results( $form_sql, ARRAY_A );
- $start_timestamp = $_GET['start_timestamp'];
- $end_timestamp = $_GET['end_timestamp'];
- $data = $wpdb->get_results( "SELECT * FROM `" . WPSC_TABLE_PURCHASE_LOGS . "` WHERE `date` BETWEEN '$start_timestamp' AND '$end_timestamp' ORDER BY `date` DESC", ARRAY_A );
- $csv = 'Purchase ID, Price, Firstname, Lastname, Email, Order Status, Data, ';
- header( 'Content-Type: text/csv' );
- header( 'Content-Disposition: inline; filename="Purchase Log ' . date( "M-d-Y", $start_timestamp ) . ' to ' . date( "M-d-Y", $end_timestamp ) . '.csv"' );
- $headers = "\"Purchase ID\",\"Purchase Total\","; //capture the headers
-
- $headers2 ="\"Payment Gateway\",";
- $headers2 .="\"Payment Status\",\"Purchase Date\",";
- foreach ( (array)$data as $purchase ) {
- $form_headers = '';
- $output .= "\"" . $purchase['id'] . "\","; //Purchase ID
- $output .= "\"" . $purchase['totalprice'] . "\","; //Purchase Total
- foreach ( (array)$form_data as $form_field ) {
- $form_headers .="\"".$form_field['unique_name']."\",";
- $collected_data_sql = "SELECT * FROM `" . WPSC_TABLE_SUBMITED_FORM_DATA . "` WHERE `log_id` = '" . $purchase['id'] . "' AND `form_id` = '" . $form_field['id'] . "' LIMIT 1";
- $collected_data = $wpdb->get_results( $collected_data_sql, ARRAY_A );
- $collected_data = $collected_data[0];
- $output .= "\"" . $collected_data['value'] . "\","; // get form fields
- }
-
- $output .= "\"" . $wpsc_gateways[$purchase['gateway']]['display_name'] . "\","; //get gateway name
-
- $status_name = wpsc_find_purchlog_status_name( $purchase['processed'] );
-
- $output .= "\"" . $status_name . "\","; //get purchase status
- $output .= "\"" . date( "jS M Y", $purchase['date'] ) . "\","; //date
- $cartsql = "SELECT `prodid`, `quantity`, `name` FROM `" . WPSC_TABLE_CART_CONTENTS . "` WHERE `purchaseid`=" . $purchase['id'] . "";
- $cart = $wpdb->get_results( $cartsql, ARRAY_A );
- if($count < count($cart))
- $count = count($cart);
- // Go through all products in cart and display quantity and sku
- foreach ( (array)$cart as $item ) {
- $skuvalue = get_product_meta($item['prodid'], 'sku', true);
- if(empty($skuvalue)) $skuvalue = __('N/A', 'wpsc');
- $output .= "\"" . $item['quantity'] . " x " . str_replace( '"', '\"', $item['name'] ) . "\"";
- $output .= "," . $skuvalue."," ;
- }
- $output .= "\n"; // terminates the row/line in the CSV file
- }
- // Get the most number of products and create a header for them
- $headers3 = "";
- for($i = 0; $i < $count ;$i++){
- $headers3 .= "\"Quantity - Product Name \", \" SKU \"";
- if($i < ($count-1))
- $headers3 .= ",";
- }
- echo $headers . $form_headers . $headers2 . $headers3 . "\n". $output;
- exit();
- }
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'wpsc_downloadcsv') ) {
- add_action( 'admin_init', 'wpsc_purchase_log_csv' );
- }
- function wpsc_admin_ajax() {
- global $wpdb;
- if ( isset( $_POST['action'] ) && $_POST['action'] == 'product-page-order' ) {
- $current_order = get_option( 'wpsc_product_page_order' );
- $new_order = $_POST['order'];
- if ( isset( $new_order["advanced"] ) ) {
- $current_order["advanced"] = array_unique( explode( ',', $new_order["advanced"] ) );
- }
- if ( isset( $new_order["side"] ) ) {
- $current_order["side"] = array_unique( explode( ',', $new_order["side"] ) );
- }
- update_option( 'wpsc_product_page_order', $current_order );
- exit( print_r( $order, 1 ) );
- }
- if ( isset( $_POST['save_image_upload_state'] ) && $_POST['save_image_upload_state'] == 'true' && is_numeric( $_POST['image_upload_state'] ) ) {
- $upload_state = (int)(bool)$_POST['image_upload_state'];
- update_option( 'wpsc_use_flash_uploader', $upload_state );
- exit( "done" );
- }
- if ( isset( $_POST['remove_variation_value'] ) && $_POST['remove_variation_value'] == "true" && is_numeric( $_POST['variation_value_id'] ) ) {
- $value_id = absint( $_GET['variation_value_id'] );
- echo wp_delete_term( $value_id, 'wpsc-variation' );
- exit();
- }
- if ( isset( $_POST['remove_form_field'] ) && $_POST['remove_form_field'] == "true" && is_numeric( $_POST['form_id'] ) ) {
- if ( current_user_can( 'manage_options' ) ) {
- $wpdb->query( $wpdb->prepare( "UPDATE `" . WPSC_TABLE_CHECKOUT_FORMS . "` SET `active` = '0' WHERE `id` = %d LIMIT 1 ;", $_POST['form_id'] ) );
- exit( ' ' );
- }
- }
- if ( isset( $_POST['hide_ecom_dashboard'] ) && $_POST['hide_ecom_dashboard'] == 'true' ) {
- require_once (ABSPATH . WPINC . '/rss.php');
- $rss = fetch_rss( 'http://www.instinct.co.nz/feed/' );
- $rss->items = array_slice( $rss->items, 0, 5 );
- $rss_hash = sha1( serialize( $rss->items ) );
- update_option( 'wpsc_ecom_news_hash', $rss_hash );
- exit( 1 );
- }
- if ( isset( $_POST['remove_meta'] ) && $_POST['remove_meta'] == 'true' && is_numeric( $_POST['meta_id'] ) ) {
- $meta_id = (int)$_POST['meta_id'];
- if ( delete_meta( $meta_id ) ) {
- echo $meta_id;
- exit();
- }
- echo 0;
- exit();
- }
- if ( isset( $_REQUEST['log_state'] ) && $_REQUEST['log_state'] == "true" && is_numeric( $_POST['id'] ) && is_numeric( $_POST['value'] ) ) {
- $newvalue = $_POST['value'];
- if ( $_REQUEST['suspend'] == 'true' ) {
- if ( $_REQUEST['value'] == 1 && function_exists('wpsc_member_dedeactivate_subscriptions'))
- wpsc_member_dedeactivate_subscriptions( $_POST['id'] );
- elseif( function_exists('wpsc_member_deactivate_subscriptions'))
- wpsc_member_deactivate_subscriptions( $_POST['id'] );
-
- exit();
- } else {
- $log_data = $wpdb->get_row( "SELECT * FROM `" . WPSC_TABLE_PURCHASE_LOGS . "` WHERE `id` = '" . $_POST['id'] . "' LIMIT 1", ARRAY_A );
- if ( ($newvalue == 2) && function_exists( 'wpsc_member_activate_subscriptions' ) ) {
- wpsc_member_activate_subscriptions( $_POST['id'] );
- }
- $update_sql = "UPDATE `" . WPSC_TABLE_PURCHASE_LOGS . "` SET `processed` = '" . $newvalue . "' WHERE `id` = '" . $_POST['id'] . "' LIMIT 1";
- $wpdb->query( $update_sql );
- if ( ($newvalue > $log_data['processed']) && ($log_data['processed'] < 2) ) {
- transaction_results( $log_data['sessionid'], false );
- }
- $status_name = wpsc_find_purchlog_status_name( $purchase['processed'] );
- echo "document.getElementById(\"form_group_" . $_POST['id'] . "_text\").innerHTML = '" . $status_name . "';\n";
- $year = date( "Y" );
- $month = date( "m" );
- $start_timestamp = mktime( 0, 0, 0, $month, 1, $year );
- $end_timestamp = mktime( 0, 0, 0, ($month + 1 ), 0, $year );
- echo "document.getElementById(\"log_total_month\").innerHTML = '" . addslashes( wpsc_currency_display( admin_display_total_price( $start_timestamp, $end_timestamp ) ) ) . "';\n";
- echo "document.getElementById(\"log_total_absolute\").innerHTML = '" . addslashes( wpsc_currency_display( admin_display_total_price() ) ) . "';\n";
- exit();
- }
- }
- }
- function wpsc_admin_sale_rss() {
- global $wpdb;
- if ( ($_GET['rss'] == "true") && ($_GET['rss_key'] == 'key') && ($_GET['action'] == "purchase_log") ) {
- $sql = "SELECT * FROM `" . WPSC_TABLE_PURCHASE_LOGS . "` WHERE `date`!='' ORDER BY `date` DESC";
- $purchase_log = $wpdb->get_results( $sql, ARRAY_A );
- header( "Content-Type: application/xml; charset=UTF-8" );
- header( 'Content-Disposition: inline; filename="WP_E-Commerce_Purchase_Log.rss"' );
- $output = '';
- $output .= "<?xml version='1.0'?>\n\r";
- $output .= "<rss version='2.0'>\n\r";
- $output .= " <channel>\n\r";
- $output .= " <title>WP e-Commerce Product Log</title>\n\r";
- $output .= " <link>" . get_option( 'siteurl' ) . "/wp-admin/admin.php?page=" . WPSC_DIR_NAME . "/display-log.php</link>\n\r";
- $output .= " <description>This is the WP e-Commerce Product Log RSS feed</description>\n\r";
- $output .= " <generator>WP e-Commerce Plugin</generator>\n\r";
- foreach ( (array)$purchase_log as $purchase ) {
- $purchase_link = get_option( 'siteurl' ) . "/wp-admin/admin.php?page=" . WPSC_DIR_NAME . "/display-log.php&purchaseid=" . $purchase['id'];
- $output .= " <item>\n\r";
- $output .= " <title>Purchase # " . $purchase['id'] . "</title>\n\r";
- $output .= " <link>$purchase_link</link>\n\r";
- $output .= " <description>This is an entry in the purchase log.</description>\n\r";
- $output .= " <pubDate>" . date( "r", $purchase['date'] ) . "</pubDate>\n\r";
- $output .= " <guid>$purchase_link</guid>\n\r";
- $output .= " </item>\n\r";
- }
- $output .= " </channel>\n\r";
- $output .= "</rss>";
- echo $output;
- exit();
- }
- }
- function wpsc_display_invoice() {
- $purchase_id = (int)$_GET['purchaselog_id'];
- add_action('wpsc_packing_slip', 'wpsc_packing_slip');
- do_action('wpsc_before_packing_slip', $purchase_id);
- do_action('wpsc_packing_slip', $purchase_id);
- exit();
- }
- //other actions are here
- if ( isset( $_GET['display_invoice'] ) && ( 'true' == $_GET['display_invoice'] ) )
- add_action( 'admin_init', 'wpsc_display_invoice', 0 );
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ( 'wpsc_display_invoice' == $_REQUEST['wpsc_admin_action'] ) )
- add_action( 'admin_init', 'wpsc_display_invoice' );
- /**
- * Purchase log ajax code starts here
- */
- function wpsc_purchlog_resend_email() {
- global $wpdb;
- $log_id = $_GET['email_buyer_id'];
- $wpec_taxes_controller = new wpec_taxes_controller();
- if ( is_numeric( $log_id ) ) {
- $selectsql = "SELECT `sessionid` FROM `" . WPSC_TABLE_PURCHASE_LOGS . "` WHERE `id`= " . $log_id . " LIMIT 1";
- $purchase_log = $wpdb->get_var( $selectsql );
- transaction_results( $purchase_log, false);
- $sent = true;
- }
- $sendback = wp_get_referer();
- if ( isset( $sent ) ) {
- $sendback = add_query_arg( 'sent', $sent, $sendback );
- }
- wp_redirect( $sendback );
- exit();
- }
- if ( isset( $_REQUEST['email_buyer_id'] ) && is_numeric( $_REQUEST['email_buyer_id'] ) ) {
- add_action( 'admin_init', 'wpsc_purchlog_resend_email' );
- }
- function wpsc_purchlog_clear_download_items() {
- global $wpdb;
- if ( is_numeric( $_GET['purchaselog_id'] ) ) {
- $purchase_id = (int)$_GET['purchaselog_id'];
- $downloadable_items = $wpdb->get_results( "SELECT * FROM `" . WPSC_TABLE_DOWNLOAD_STATUS . "` WHERE `purchid` IN ('$purchase_id')", ARRAY_A );
- $clear_locks_sql = "UPDATE`" . WPSC_TABLE_DOWNLOAD_STATUS . "` SET `ip_number` = '' WHERE `purchid` IN ('$purchase_id')";
- $wpdb->query( $clear_locks_sql );
- $cleared = true;
- $email_form_field = $wpdb->get_var( "SELECT `id` FROM `" . WPSC_TABLE_CHECKOUT_FORMS . "` WHERE `type` IN ('email') AND `active` = '1' ORDER BY `checkout_order` ASC LIMIT 1" );
- $email_address = $wpdb->get_var( "SELECT `value` FROM `" . WPSC_TABLE_SUBMITED_FORM_DATA . "` WHERE `log_id`='{$purchase_id}' AND `form_id` = '{$email_form_field}' LIMIT 1" );
- foreach ( (array)$downloadable_items as $downloadable_item ) {
- $download_links .= $siteurl . "?downloadid=" . $downloadable_item['uniqueid'] . "\n";
- }
- wp_mail( $email_address, __( 'The administrator has unlocked your file', 'wpsc' ), str_replace( "[download_links]", $download_links, __( 'Dear CustomerWe are pleased to advise you that your order has been updated and your downloads are now active.Please download your purchase using the links provided below.[download_links]Thank you for your custom.', 'wpsc' ) ), "From: " . get_option( 'return_email' ) . "" );
- $sendback = wp_get_referer();
- if ( isset( $cleared ) ) {
- $sendback = add_query_arg( 'cleared', $cleared, $sendback );
- }
- wp_redirect( $sendback );
- exit();
- }
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'clear_locks') ) {
- add_action( 'admin_init', 'wpsc_purchlog_clear_download_items' );
- }
- //call to change view for purchase log
- function wpsc_purchlog_filter_by() {
- wpsc_change_purchlog_view( $_POST['view_purchlogs_by'], $_POST['view_purchlogs_by_status'] );
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'purchlog_filter_by') ) {
- add_action( 'admin_init', 'wpsc_purchlog_filter_by' );
- }
- //bulk actions for purchase log
- function wpsc_purchlog_bulk_modify() {
- if ( $_POST['purchlog_multiple_status_change'] != -1 ) {
- if ( is_numeric( $_POST['purchlog_multiple_status_change'] ) && $_POST['purchlog_multiple_status_change'] != 'delete' ) {
- foreach ( (array)$_POST['purchlogids'] as $purchlogid ) {
- wpsc_purchlog_edit_status( $purchlogid, $_POST['purchlog_multiple_status_change'] );
- $updated++;
- }
- } elseif ( $_POST['purchlog_multiple_status_change'] == 'delete' ) {
- foreach ( (array)$_POST['purchlogids'] as $purchlogid ) {
- wpsc_delete_purchlog( $purchlogid );
- $deleted++;
- }
- }
- }
- $sendback = wp_get_referer();
- if ( isset( $updated ) ) {
- $sendback = add_query_arg( 'updated', $updated, $sendback );
- }
- if ( isset( $deleted ) ) {
- $sendback = add_query_arg( 'deleted', $deleted, $sendback );
- }
- if ( isset( $_POST['view_purchlogs_by'] ) ) {
- $sendback = add_query_arg( 'view_purchlogs_by', $_POST['view_purchlogs_by'], $sendback );
- }
- if ( isset( $_POST['view_purchlogs_by_status'] ) ) {
- $sendback = add_query_arg( 'view_purchlogs_by_status', $_POST['view_purchlogs_by_status'], $sendback );
- }
- wp_redirect( $sendback );
- exit();
- }
- if ( isset( $_REQUEST['wpsc_admin_action2'] ) && ($_REQUEST['wpsc_admin_action2'] == 'purchlog_bulk_modify') ) {
- add_action( 'admin_init', 'wpsc_purchlog_bulk_modify' );
- }
- //edit purchase log status function
- function wpsc_purchlog_edit_status( $purchlog_id='', $purchlog_status='' ) {
- global $wpdb;
- if ( empty($purchlog_id) && empty($purchlog_status) ) {
- $purchlog_id = absint( $_POST['purchlog_id'] );
- $purchlog_status = absint( $_POST['purchlog_status'] );
- }
- $log_data = $wpdb->get_row( "SELECT * FROM `" . WPSC_TABLE_PURCHASE_LOGS . "` WHERE `id` = '{$purchlog_id}' LIMIT 1", ARRAY_A );
- $is_transaction = wpsc_check_purchase_processed($log_data['processed']);
- if ( $is_transaction && function_exists('wpsc_member_activate_subscriptions')) {
- wpsc_member_activate_subscriptions( $_POST['id'] );
- }
- //in the future when everyone is using the 2.0 merchant api, we should use the merchant class to update the staus,
- // then you can get rid of this hook and have each person overwrite the method that updates the status.
- do_action('wpsc_edit_order_status', array('purchlog_id'=>$purchlog_id, 'purchlog_data'=>$log_data, 'new_status'=>$purchlog_status));
- $wpdb->query( "UPDATE `" . WPSC_TABLE_PURCHASE_LOGS . "` SET processed='{$purchlog_status}' WHERE id='{$purchlog_id}'" );
-
- wpsc_clear_stock_claims();
- wpsc_decrement_claimed_stock($purchlog_id);
-
- if ( $purchlog_status == 3 )
- transaction_results($log_data['sessionid'],false,null);
- }
- add_action( 'wp_ajax_purchlog_edit_status', 'wpsc_purchlog_edit_status' );
- function wpsc_save_product_order() {
- global $wpdb;
- $products = array( );
- foreach ( $_POST['post'] as $product ) {
- $products[] = absint( $product );
- }
- print_r( $products );
- foreach ( $products as $order => $product_id ) {
- $wpdb->query( $wpdb->prepare( "UPDATE `{$wpdb->posts}` SET `menu_order`='%d' WHERE `ID`='%d' LIMIT 1", $order, $product_id ) );
- }
- $success = true;
- exit( (string)$success );
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'save_product_order') ) {
- add_action( 'admin_init', 'wpsc_save_product_order' );
- }
- function wpsc_save_checkout_order() {
- global $wpdb;
- $checkoutfields = $_POST['checkout'];
- $order = 1;
- foreach ( $checkoutfields as $checkoutfield ) {
- $checkoutfield = absint( $checkoutfield );
- $wpdb->query( "UPDATE `" . WPSC_TABLE_CHECKOUT_FORMS . "` SET `checkout_order` = '" . $order . "' WHERE `id`=" . $checkoutfield );
- $order++;
- }
- $success = true;
- exit( (string)$success );
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'save_checkout_order') )
- add_action( 'admin_init', 'wpsc_save_checkout_order' );
- /* Start Order Notes (by Ben) */
- function wpsc_purchlogs_update_notes( $purchlog_id = '', $purchlog_notes = '' ) {
- global $wpdb;
- if ( wp_verify_nonce( $_POST['wpsc_purchlogs_update_notes_nonce'], 'wpsc_purchlogs_update_notes' ) ) {
- if ( ($purchlog_id == '') && ($purchlog_notes == '') ) {
- $purchlog_id = absint( $_POST['purchlog_id'] );
- $purchlog_notes = $wpdb->escape( $_POST['purchlog_notes'] );
- }
- $wpdb->query( "UPDATE `" . WPSC_TABLE_PURCHASE_LOGS . "` SET notes='{$purchlog_notes}' WHERE id='{$purchlog_id}'" );
- }
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'purchlogs_update_notes' ) )
- add_action( 'admin_init', 'wpsc_purchlogs_update_notes' );
- /* End Order Notes (by Ben) */
- //delete a purchase log
- function wpsc_delete_purchlog( $purchlog_id='' ) {
- global $wpdb;
- $deleted = 0;
- if ( $purchlog_id == '' ) {
- $purchlog_id = absint( $_GET['purchlog_id'] );
- check_admin_referer( 'delete_purchlog_' . $purchlog_id );
- }
- if ( is_numeric( $purchlog_id ) ) {
- $delete_log_form_sql = "SELECT * FROM `" . WPSC_TABLE_CART_CONTENTS . "` WHERE `purchaseid`='$purchlog_id'";
- $cart_content = $wpdb->get_results( $delete_log_form_sql, ARRAY_A );
- }
- $purchlog_status = $wpdb->get_var( "SELECT `processed` FROM `" . WPSC_TABLE_PURCHASE_LOGS . "` WHERE `id`=" . $purchlog_id );
- if ( $purchlog_status == 5 || $purchlog_status == 1 ) {
- $wpdb->query( "DELETE FROM `" . WPSC_TABLE_CLAIMED_STOCK . "` WHERE `cart_id` = '{$purchlog_id}' AND `cart_submitted` = '1'" );
- }
- $wpdb->query( "DELETE FROM `" . WPSC_TABLE_CART_CONTENTS . "` WHERE `purchaseid`='$purchlog_id'" );
- $wpdb->query( "DELETE FROM `" . WPSC_TABLE_SUBMITED_FORM_DATA . "` WHERE `log_id` IN ('$purchlog_id')" );
- $wpdb->query( "DELETE FROM `" . WPSC_TABLE_PURCHASE_LOGS . "` WHERE `id`='$purchlog_id' LIMIT 1" );
- $deleted = 1;
- if ( is_numeric( $_GET['purchlog_id'] ) ) {
- $sendback = wp_get_referer();
- $sendback = remove_query_arg( 'purchaselog_id', $sendback );
- if ( isset( $deleted ) ) {
- $sendback = add_query_arg( 'deleted', $deleted, $sendback );
- }
- wp_redirect( $sendback );
- exit();
- }
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'delete_purchlog') ) {
- add_action( 'admin_init', 'wpsc_delete_purchlog' );
- }
- /*
- * Get Shipping Form ajax call
- */
- function wpsc_ajax_get_shipping_form() {
- $shippingname = $_REQUEST['shippingname'];
- $_SESSION['previous_shipping_name'] = $shippingname;
- $shipping_data = wpsc_get_shipping_form( $shippingname );
- $html_shipping_name = str_replace( Array( "\n", "\r" ), Array( "\\n", "\\r" ), addslashes( $shipping_data['name'] ) );
- $shipping_form = str_replace( Array( "\n", "\r" ), Array( "\\n", "\\r" ), addslashes( $shipping_data['form_fields'] ) );
- echo "shipping_name_html = '$html_shipping_name'; \n\r";
- echo "shipping_form_html = '$shipping_form'; \n\r";
- echo "has_submit_button = '{$shipping_data['has_submit_button']}'; \n\r";
- exit();
- }
- function wpsc_ajax_get_payment_form() {
- $paymentname = $_REQUEST['paymentname'];
- $_SESSION['previous_payment_name'] = $paymentname;
- $payment_data = wpsc_get_payment_form( $paymentname );
- $html_payment_name = str_replace( Array( "\n", "\r" ), Array( "\\n", "\\r" ), addslashes( $payment_data['name'] ) );
- $payment_form = str_replace( Array( "\n", "\r" ), Array( "\\n", "\\r" ), addslashes( $payment_data['form_fields'] ) );
- echo "payment_name_html = '$html_payment_name'; \n\r";
- echo "payment_form_html = '$payment_form'; \n\r";
- echo "has_submit_button = '{$payment_data['has_submit_button']}'; \n\r";
- exit();
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'get_shipping_form') )
- add_action( 'admin_init', 'wpsc_ajax_get_shipping_form' );
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'get_payment_form') )
- add_action( 'admin_init', 'wpsc_ajax_get_payment_form' );
- /*
- * Submit Options from Settings Pages,
- * takes an array of options checks to see whether it is empty or the same as the exisiting values
- * and if its not it updates them.
- */
- function wpsc_submit_options( $selected='' ) {
- global $wpdb, $wpsc_gateways;
- $updated = 0;
-
- //This is to change the Overall target market selection
- check_admin_referer( 'update-options', 'wpsc-update-options' );
- if ( isset( $_POST['change-settings'] ) ) {
- if ( isset( $_POST['wpsc_also_bought'] ) && $_POST['wpsc_also_bought'] == 'on' )
- update_option( 'wpsc_also_bought', 1 );
- else
- update_option( 'wpsc_also_bought', 0 );
- if ( isset( $_POST['display_find_us'] ) && $_POST['display_find_us'] == 'on' )
- update_option( 'display_find_us', 1 );
- else
- update_option( 'display_find_us', 0 );
- if ( isset( $_POST['wpsc_share_this'] ) && $_POST['wpsc_share_this'] == 'on' )
- update_option( 'wpsc_share_this', 1 );
- else
- update_option( 'wpsc_share_this', 0 );
- }
- if (empty($_POST['countrylist2']) && !empty($_POST['wpsc_options']['currency_sign_location']))
- $selected = 'none';
-
- if ( !isset( $_POST['countrylist2'] ) )
- $_POST['countrylist2'] = '';
- if ( !isset( $_POST['country_id'] ) )
- $_POST['country_id'] = '';
- if ( !isset( $_POST['country_tax'] ) )
- $_POST['country_tax'] = '';
-
- if ( $_POST['countrylist2'] != null || !empty($selected) ) {
- $AllSelected = false;
- if ( $selected == 'all' ) {
- $wpdb->query( "UPDATE `" . WPSC_TABLE_CURRENCY_LIST . "` SET visible = '1'" );
- $AllSelected = true;
- }
- if ( $selected == 'none' ) {
- $wpdb->query( "UPDATE `" . WPSC_TABLE_CURRENCY_LIST . "` SET visible = '0'" );
- $AllSelected = true;
- }
- if ( $AllSelected != true ) {
- $countrylist = $wpdb->get_col( "SELECT id FROM `" . WPSC_TABLE_CURRENCY_LIST . "` ORDER BY country ASC " );
- //find the countries not selected
- $unselectedCountries = array_diff( $countrylist, $_POST['countrylist2'] );
- foreach ( $unselectedCountries as $unselected ) {
- $wpdb->query( "UPDATE `" . WPSC_TABLE_CURRENCY_LIST . "` SET visible = 0 WHERE id = '" . $unselected . "' LIMIT 1" );
- }
- //find the countries that are selected
- $selectedCountries = array_intersect( $countrylist, $_POST['countrylist2'] );
- foreach ( $selectedCountries as $selected ) {
- $wpdb->query( "UPDATE `" . WPSC_TABLE_CURRENCY_LIST . "` SET visible = 1 WHERE id = '" . $selected . "' LIMIT 1" );
- }
- }
- }
- $previous_currency = get_option( 'currency_type' );
-
- $regenerate = false;
-
- $regenerate_options = array('single_view_image_height', 'single_view_image_width','wpsc_gallery_image_width','wpsc_gallery_image_height', 'wpsc_crop_thumbnails','product_image_width','product_image_height');
-
- //To update options
-
- if ( isset( $_POST['wpsc_options'] ) ) {
- foreach ( $_POST['wpsc_options'] as $key => $value ) {
-
- if ( in_array( $key, $regenerate_options ) && $value != get_option( $key ) ) {
- $regenerate = true;
- }
-
- if ( $value != get_option( $key ) ) {
- update_option( $key, $value );
- $updated++;
-
- }
- }
- }
- if ( $previous_currency != get_option( 'currency_type' ) ) {
- $currency_code = $wpdb->get_var( "SELECT `code` FROM `" . WPSC_TABLE_CURRENCY_LIST . "` WHERE `id` IN ('" . absint( get_option( 'currency_type' ) ) . "')" );
- $selected_gateways = get_option( 'custom_gateway_options' );
- $already_changed = array( );
- foreach ( $selected_gateways as $selected_gateway ) {
- if ( isset( $wpsc_gateways[$selected_gateway]['supported_currencies'] ) ) {
- if ( in_array( $currency_code, $wpsc_gateways[$selected_gateway]['supported_currencies']['currency_list'] ) ) {
- $option_name = $wpsc_gateways[$selected_gateway]['supported_currencies']['option_name'];
- if ( !in_array( $option_name, $already_changed ) ) {
- update_option( $option_name, $currency_code );
- $already_changed[] = $option_name;
- }
- }
- }
- }
- }
- foreach ( $GLOBALS['wpsc_shipping_modules'] as $shipping ) {
- if ( is_object( $shipping ) )
- $shipping->submit_form();
- }
- //This is for submitting shipping details to the shipping module
- if ( !isset( $_POST['update_gateways'] ) )
- $_POST['update_gateways'] = '';
- if ( !isset( $_POST['custom_shipping_options'] ) )
- $_POST['custom_shipping_options'] = null;
- if ( $_POST['update_gateways'] == 'true' ) {
- update_option( 'custom_shipping_options', $_POST['custom_shipping_options'] );
- $shipadd = 0;
- foreach ( $GLOBALS['wpsc_shipping_modules'] as $shipping ) {
- foreach ( (array)$_POST['custom_shipping_options'] as $shippingoption ) {
- if ( $shipping->internal_name == $shippingoption ) {
- $shipadd++;
- }
- }
- }
- }
-
- $sendback = wp_get_referer();
- if ( $regenerate ) {
- $sendback = add_query_arg( array('regenerate' => 'true', 'updated' => $updated), $sendback );
- }
- if ( isset( $updated ) ) {
- $sendback = add_query_arg( 'updated', $updated, $sendback );
- }
- if ( isset( $shipadd ) ) {
- $sendback = add_query_arg( 'shipadd', $shipadd, $sendback );
- }
- if ( !isset( $_SESSION['wpsc_settings_curr_page'] ) )
- $_SESSION['wpsc_settings_curr_page'] = '';
- if ( !isset( $_POST['page_title'] ) )
- $_POST['page_title'] = '';
- if ( isset( $_SESSION['wpsc_settings_curr_page'] ) ) {
- $sendback = add_query_arg( 'tab', $_SESSION['wpsc_settings_curr_page'], $sendback );
- }
- $sendback = add_query_arg( 'page', 'wpsc-settings', $sendback );
- wp_redirect( $sendback );
- exit();
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'submit_options') )
- add_action( 'admin_init', 'wpsc_submit_options' );
- function wpsc_change_currency() {
- if ( is_numeric( $_POST['currencyid'] ) ) {
- $currency_data = $wpdb->get_results( "SELECT `symbol`,`symbol_html`,`code` FROM `" . WPSC_TABLE_CURRENCY_LIST . "` WHERE `id`='" . $_POST['currencyid'] . "' LIMIT 1", ARRAY_A );
- $price_out = null;
- if ( $currency_data[0]['symbol'] != '' ) {
- $currency_sign = $currency_data[0]['symbol_html'];
- } else {
- $currency_sign = $currency_data[0]['code'];
- }
- echo $currency_sign;
- }
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'change_currency') )
- add_action( 'admin_init', 'wpsc_change_currency' );
- function wpsc_rearrange_images() {
- global $wpdb;
- $images = explode( ",", $_POST['order'] );
- $product_id = absint( $_POST['product_id'] );
- $timestamp = time();
- $new_main_image = null;
- $have_set_first_item = false;
- $i = 0;
- foreach ( $images as $image ) {
- if ( $image > 0 ) {
- $wpdb->query( $wpdb->prepare( "UPDATE `{$wpdb->posts}` SET `menu_order`='%d' WHERE `ID`='%d' LIMIT 1", $i, $image ) );
- $i++;
- }
- }
- $output = wpsc_main_product_image_menu( $product_id );
- echo "image_menu = '';\n\r";
- echo "image_id = '" . $new_main_image . "';\n\r";
- exit();
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'rearrange_images') )
- add_action( 'admin_init', 'wpsc_rearrange_images' );
- /**
- * wpsc_update_page_urls gets the permalinks for products pages and stores them in the options for quick reference
- * @public
- *
- * @since 3.6
- * @param $auto (Boolean) true if coming from WordPress Permalink Page, false otherwise
- * @return nothing
- */
- function wpsc_update_page_urls($auto = false) {
- global $wpdb;
- $wpsc_pageurl_option['product_list_url'] = '[productspage]';
- $wpsc_pageurl_option['shopping_cart_url'] = '[shoppingcart]';
- $check_chekout = $wpdb->get_var( "SELECT `guid` FROM `{$wpdb->posts}` WHERE `post_content` LIKE '%[checkout]%' LIMIT 1" );
- if ( $check_chekout != null ) {
- $wpsc_pageurl_option['checkout_url'] = '[checkout]';
- } else {
- $wpsc_pageurl_option['checkout_url'] = '[checkout]';
- }
- $wpsc_pageurl_option['transact_url'] = '[transactionresults]';
- $wpsc_pageurl_option['user_account_url'] = '[userlog]';
- $changes_made = false;
- foreach ( $wpsc_pageurl_option as $option_key => $page_string ) {
- $post_id = $wpdb->get_var( "SELECT `ID` FROM `{$wpdb->posts}` WHERE `post_type` IN('page','post') AND `post_content` LIKE '%$page_string%' LIMIT 1" );
- if ( ! $post_id )
- continue;
- $the_new_link = _get_page_link( $post_id );
- if ( stristr( get_option( $option_key ), "https://" ) ) {
- $the_new_link = str_replace( 'http://', "https://", $the_new_link );
- }
- update_option( $option_key, $the_new_link );
- }
-
- if(!$auto){
- $sendback = wp_get_referer();
- if ( isset( $updated ) )
- $sendback = add_query_arg( 'updated', $updated, $sendback );
- if ( isset( $_SESSION['wpsc_settings_curr_page'] ) )
- $sendback = add_query_arg( 'tab', $_SESSION['wpsc_settings_curr_page'], $sendback );
-
- wp_redirect( $sendback );
- exit();
- }
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'update_page_urls') )
- add_action( 'admin_init', 'wpsc_update_page_urls' );
- function wpsc_clean_categories() {
- global $wpdb, $wp_rewrite;
- $sql_query = "SELECT `id`, `name`, `active` FROM `" . WPSC_TABLE_PRODUCT_CATEGORIES . "`";
- $sql_data = $wpdb->get_results( $sql_query, ARRAY_A );
- foreach ( (array)$sql_data as $datarow ) {
- if ( $datarow['active'] == 1 ) {
- $tidied_name = trim( $datarow['name'] );
- $tidied_name = strtolower( $tidied_name );
- $url_name = sanitize_title( $tidied_name );
- $similar_names = $wpdb->get_row( "SELECT COUNT(*) AS `count`, MAX(REPLACE(`nice-name`, '$url_name', '')) AS `max_number` FROM `" . WPSC_TABLE_PRODUCT_CATEGORIES . "` WHERE `nice-name` REGEXP '^($url_name){1}(\d)*$' AND `id` NOT IN ('{$datarow['id']}') ", ARRAY_A );
- $extension_number = '';
- if ( $similar_names['count'] > 0 ) {
- $extension_number = (int)$similar_names['max_number'] + 2;
- }
- $url_name .= $extension_number;
- $wpdb->query( "UPDATE `" . WPSC_TABLE_PRODUCT_CATEGORIES . "` SET `nice-name` = '$url_name' WHERE `id` = '{$datarow['id']}' LIMIT 1 ;" );
- $updated;
- } else if ( $datarow['active'] == 0 ) {
- $wpdb->query( "UPDATE `" . WPSC_TABLE_PRODUCT_CATEGORIES . "` SET `nice-name` = '' WHERE `id` = '{$datarow['id']}' LIMIT 1 ;" );
- $updated;
- }
- }
- $wp_rewrite->flush_rules();
- $sendback = wp_get_referer();
- if ( isset( $updated ) ) {
- $sendback = add_query_arg( 'updated', $updated, $sendback );
- }
- if ( isset( $_SESSION['wpsc_settings_curr_page'] ) ) {
- $sendback = add_query_arg( 'tab', $_SESSION['wpsc_settings_curr_page'], $sendback );
- }
- wp_redirect( $sendback );
- exit();
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'clean_categories') )
- add_action( 'admin_init', 'wpsc_clean_categories' );
- //change the regions tax settings
- function wpsc_change_region_tax() {
- global $wpdb;
- if ( is_array( $_POST['region_tax'] ) ) {
- foreach ( $_POST['region_tax'] as $region_id => $tax ) {
- if ( is_numeric( $region_id ) && is_numeric( $tax ) ) {
- $previous_tax = $wpdb->get_var( "SELECT `tax` FROM `" . WPSC_TABLE_REGION_TAX . "` WHERE `id` = '$region_id' LIMIT 1" );
- if ( $tax != $previous_tax ) {
- $wpdb->query( "UPDATE `" . WPSC_TABLE_REGION_TAX . "` SET `tax` = '$tax' WHERE `id` = '$region_id' LIMIT 1" );
- $changes_made = true;
- }
- }
- }
- $sendback = wp_get_referer();
- wp_redirect( $sendback );
- }
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'change_region_tax') )
- add_action( 'admin_init', 'wpsc_change_region_tax' );
- function wpsc_product_files_existing() {
- //List all product_files, with checkboxes
- $product_id = absint( $_GET["product_id"] );
- $file_list = wpsc_uploaded_files();
- $args = array(
- 'post_type' => 'wpsc-product-file',
- 'post_parent' => $product_id,
- 'numberposts' => -1,
- 'post_status' => 'all'
- );
- $attached_files = (array)get_posts( $args );
- foreach ( $attached_files as $key => $attached_file ) {
- $attached_files_by_file[$attached_file->post_title] = & $attached_files[$key];
- }
- $output = "<span class='admin_product_notes select_product_note '>" . __( 'Choose a downloadable file for this product:', 'wpsc' ) . "</span><br>";
- $output .= "<form method='post' class='product_upload'>";
- $output .= "<div class='ui-widget-content multiple-select select_product_file'>";
- $num = 0;
- foreach ( (array)$file_list as $file ) {
- $num++;
- $checked_curr_file = "";
- if ( isset( $attached_files_by_file[$file['display_filename']] ) ) {
- $checked_curr_file = "checked='checked'";
- }
- $output .= "<p " . ((($num % 2) > 0) ? '' : "class='alt'") . " id='select_product_file_row_$num'>\n";
- $output .= " <input type='checkbox' name='select_product_file[]' value='" . $file['real_filename'] . "' id='select_product_file_$num' " . $checked_curr_file . " />\n";
- $output .= " <label for='select_product_file_$num'>" . $file['display_filename'] . "</label>\n";
- $output .= "</p>\n";
- }
- $output .= "</div>";
- $output .= "<input type='hidden' id='hidden_id' value='$product_id' />";
- $output .= "<input type='submit' name='save' name='product_files_submit' class='button-primary prdfil' value='Save Product Files' />";
- $output .= "</form>";
- $output .= "<div class='" . ((is_numeric( $product_id )) ? "edit_" : "") . "select_product_handle'><div></div></div>";
- $output .= "<script type='text/javascript'>\n\r";
- $output .= "var select_min_height = " . (25 * 3) . ";\n\r";
- $output .= "var select_max_height = " . (25 * ($num + 1)) . ";\n\r";
- $output .= "</script>";
- echo $output;
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'product_files_existing') )
- add_action( 'admin_init', 'wpsc_product_files_existing' );
- function prod_upload() {
- global $wpdb;
- $product_id = absint( $_POST["product_id"] );
- $output = '';
- foreach ( $_POST["select_product_file"] as $selected_file ) {
- // if we already use this file, there is no point doing anything more.
- $sql = $wpdb->prepare( "SELECT * FROM $wpdb->posts WHERE post_type = 'wpsc-product-file' AND post_title = %s", $selected_file ); // TODO it's safer to select by post ID, in that case we will use get_posts()
- $file_post_data = $wpdb->get_row( $sql, ARRAY_A );
- $selected_file_path = WPSC_FILE_DIR . basename( $selected_file );
- if ( empty( $file_post_data ) ) {
- $type = wpsc_get_mimetype( $selected_file_path );
- $attachment = array(
- 'post_mime_type' => $type,
- 'post_parent' => $product_id,
- 'post_title' => $selected_file,
- 'post_content' => '',
- 'post_type' => "wpsc-product-file",
- 'post_status' => 'inherit'
- );
- $id = wp_insert_post( $attachment );
- } else {
- // already attached
- if ( $file_post_data['post_parent'] == $product_id )
- continue;
- $type = $file_post_data["post_mime_type"];
- $url = $file_post_data["guid"];
- $title = $file_post_data["post_title"];
- $content = $file_post_data["post_content"];
- // Construct the attachment
- $attachment = array(
- 'post_mime_type' => $type,
- 'guid' => $url,
- 'post_parent' => absint( $product_id ),
- 'post_title' => $title,
- 'post_content' => $content,
- 'post_type' => "wpsc-product-file",
- 'post_status' => 'inherit'
- );
- // Save the data
- $id = wp_insert_post( $attachment );
- }
-
- $deletion_url = wp_nonce_url( "admin.php?wpsc_admin_action=delete_file&file_name={$attachment['post_title']}&product_id={$product_id}", 'delete_file_' . $attachment['post_title'] );
- $output .= "<p id='select_product_file_row_id_" . $id . "'>\n";
- $output .= " <a class='file_delete_button' href='{$deletion_url}' >\n";
- $output .= " <img src='" . WPSC_CORE_IMAGES_URL . "/cross.png' />\n";
- $output .= " </a>\n";
- $output .= " <label for='select_product_file_row_id_" . $id . "'>" . $attachment['post_title'] . "</label>\n";
- $output .= "</p>\n";
- }
-
- echo $output;
- }
- if ( isset( $_GET['wpsc_admin_action'] ) && ($_GET['wpsc_admin_action'] == 'product_files_upload') )
- add_action( 'admin_init', 'prod_upload' );
- //change the gateway settings
- function wpsc_gateway_settings() {
- //To update options
- if ( isset( $_POST['wpsc_options'] ) ) {
- foreach ( $_POST['wpsc_options'] as $key => $value ) {
- if ( $value != get_option( $key ) ) {
- update_option( $key, $value );
- }
- }
- unset( $_POST['wpsc_options'] );
- }
- if ( isset( $_POST['user_defined_name'] ) && is_array( $_POST['user_defined_name'] ) ) {
- $payment_gateway_names = get_option( 'payment_gateway_names' );
- if ( !is_array( $payment_gateway_names ) ) {
- $payment_gateway_names = array( );
- }
- $payment_gateway_names = array_merge( $payment_gateway_names, (array)$_POST['user_defined_name'] );
- update_option( 'payment_gateway_names', $payment_gateway_names );
- }
- $custom_gateways = get_option( 'custom_gateway_options' );
- $nzshpcrt_gateways = nzshpcrt_get_gateways();
- foreach ( $nzshpcrt_gateways as $gateway ) {
- if ( in_array( $gateway['internalname'], $custom_gateways ) ) {
- if ( isset( $gateway['submit_function'] ) ) {
- call_user_func_array( $gateway['submit_function'], array( ) );
- $changes_made = true;
- }
- }
- }
- if ( (isset( $_POST['payment_gw'] ) && $_POST['payment_gw'] != null ) ) {
- update_option( 'payment_gateway', $_POST['payment_gw'] );
- }
- $sendback = wp_get_referer();
- if ( isset( $updated ) ) {
- $sendback = add_query_arg( 'updated', $updated, $sendback );
- }
- if ( isset( $_SESSION['wpsc_settings_curr_page'] ) ) {
- $sendback = add_query_arg( 'page', 'wpsc-settings', $sendback );
- $sendback = add_query_arg( 'tab', $_SESSION['wpsc_settings_curr_page'], $sendback );
- }
- wp_redirect( $sendback );
- exit();
- }
- if ( isset( $_REQUEST['wpsc_gateway_settings'] ) && ($_REQUEST['wpsc_gateway_settings'] == 'gateway_settings') )
- add_action( 'admin_init', 'wpsc_gateway_settings' );
- function wpsc_check_form_options() {
- global $wpdb;
- $id = $wpdb->escape( $_POST['form_id'] );
- $sql = 'SELECT `options` FROM `' . WPSC_TABLE_CHECKOUT_FORMS . '` WHERE `id`=' . $id;
- $options = $wpdb->get_var( $sql );
- if ( $options != '' ) {
- $options = maybe_unserialize( $options );
- if ( !is_array( $options ) ) {
- $options = unserialize( $options );
- }
- $output = "<tr class='wpsc_grey'><td></td><td colspan='5'>Please Save your changes before trying to Order your Checkout Forms again.</td></tr>\r\n<tr class='wpsc_grey'><td></td><th>Label</th><th >Value</th><td colspan='3'><a href='' class='wpsc_add_new_checkout_option' title='form_options[" . $id . "]'>+ New Layer</a></td></tr>";
- foreach ( (array)$options as $key => $value ) {
- $output .="<tr class='wpsc_grey'><td></td><td><input type='text' value='" . $key . "' name='wpsc_checkout_option_label[" . $id . "][]' /></td><td colspan='4'><input type='text' value='" . $value . "' name='wpsc_checkout_option_value[" . $id . "][]' /> <a class='wpsc_delete_option' href='' <img src='" . WPSC_CORE_IMAGES_URL . "/trash.gif' alt='" . __( 'Delete', 'wpsc' ) . "' title='" . __( 'Delete', 'wpsc' ) . "' /></a></td></tr>";
- }
- } else {
- $output = '';
- }
- exit( $output );
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'check_form_options') )
- add_action( 'admin_init', 'wpsc_check_form_options' );
- //handles the editing and adding of new checkout fields
- function wpsc_checkout_settings() {
- global $wpdb;
- $wpdb->show_errors = true;
- $filter = isset( $_POST['selected_form_set'] ) ? $_POST['selected_form_set'] : 0;
- if ( $_POST['new_form_set'] != null ) {
- $checkout_sets = get_option( 'wpsc_checkout_form_sets' );
- $checkout_sets[] = $_POST['new_form_set'];
- update_option( 'wpsc_checkout_form_sets', $checkout_sets );
- }
- /*
- // Save checkout options
- */
- $options = array( );
- if ( isset($_POST['wpsc_checkout_option_label']) && is_array( $_POST['wpsc_checkout_option_label'] ) ) {
- foreach ( $_POST['wpsc_checkout_option_label'] as $form_id => $values ) {
- $options = array( );
- foreach ( (array)$values as $key => $form_option ) {
- $form_option = str_ireplace( "'", "", $form_option );
- $form_val = str_ireplace( "'", "", sanitize_title( $_POST['wpsc_checkout_option_value'][$form_id][$key] ) );
- $options[$form_option] = $form_val;
- }
- $options = serialize( $options );
- $wpdb->update(
- WPSC_TABLE_CHECKOUT_FORMS,
- array( 'options' => $options ),
- array( 'id' => $form_id ),
- '%s',
- '%d'
- );
- }
- }
- if ( $_POST['form_name'] != null ) {
- foreach ( $_POST['form_name'] as $form_id => $form_name ) {
- $form_type = $_POST['form_type'][$form_id];
- $form_mandatory = 0;
- if ( isset( $_POST['form_mandatory'][$form_id] ) && ($_POST['form_mandatory'][$form_id] == 1) ) {
- $form_mandatory = 1;
- }
- $form_display_log = 0;
- if ( isset( $_POST['form_display_log'][$form_id] ) && ($_POST['form_display_log'][$form_id] == 1) ) {
- $form_display_log = 1;
- }
- $unique_name = '';
- if ( $_POST['unique_names'][$form_id] != '-1' ) {
- $unique_name = $_POST['unique_names'][$form_id];
- }
- $wpdb->update(
- WPSC_TABLE_CHECKOUT_FORMS,
- array(
- 'name' => $form_name,
- 'type' => $form_type,
- 'mandatory' => $form_mandatory,
- 'display_log' => $form_display_log,
- 'unique_name' => $unique_name,
- ),
- array( 'id' => $form_id ),
- '%s',
- '%d'
- );
- }
- }
- if ( isset( $_POST['new_form_name'] ) ) {
- foreach ( $_POST['new_form_name'] as $form_id => $form_name ) {
- $form_type = $_POST['new_form_type'][$form_id];
- $form_mandatory = 0;
- if ( $_POST['new_form_mandatory'][$form_id] == 1 ) {
- $form_mandatory = 1;
- }
- $form_display_log = 0;
- if ( isset( $_POST['new_form_display_log'][$form_id] ) && $_POST['new_form_display_log'][$form_id] == 1 ) {
- $form_display_log = 1;
- }
- if ( $_POST['new_form_unique_name'][$form_id] != '-1' ) {
- $form_unique_name = $_POST['new_form_unique_name'][$form_id];
- }
- $max_order_sql = "SELECT MAX(`checkout_order`) AS `checkout_order` FROM `" . WPSC_TABLE_CHECKOUT_FORMS . "` WHERE `active` = '1';";
- if ( isset( $_POST['new_form_order'][$form_id] ) && $_POST['new_form_order'][$form_id] != '' ) {
- $order_number = $_POST['new_form_order'][$form_id];
- } else {
- $max_order_sql = $wpdb->get_results( $max_order_sql, ARRAY_A );
- $order_number = $max_order_sql[0]['checkout_order'] + 1;
- }
- $wpdb->insert(
- WPSC_TABLE_CHECKOUT_FORMS,
- array(
- 'name' => $form_name,
- 'type' => $form_type,
- 'mandatory' => $form_mandatory,
- 'display_log' => $form_display_log,
- 'default' => '',
- 'active' => '1',
- 'checkout_order' => $order_number,
- 'unique_name' => $form_unique_name,
- 'checkout_set' => $filter,
- ),
- array( '%s', '%s', '%s', '%s', '%s', '%s', '%d', '%s', '%s' )
- );
- $added++;
- }
- }
- if ( isset( $_POST['wpsc_options'] ) ) {
- foreach ( $_POST['wpsc_options'] as $key => $value ) {
- if ( $value != get_option( $key ) ) {
- update_option( $key, $value );
- $updated++;
- }
- }
- }
- $sendback = wp_get_referer();
- if ( isset( $form_set_key ) ) {
- $sendback = add_query_arg( 'checkout-set', $form_set_key, $sendback );
- } else if ( isset( $_POST['wpsc_form_set'] ) ) {
- $filter = $_POST['wpsc_form_set'];
- $sendback = add_query_arg( 'checkout-set', $filter, $sendback );
- }
- if ( isset( $updated ) ) {
- $sendback = add_query_arg( 'updated', $updated, $sendback );
- }
- if ( isset( $added ) ) {
- $sendback = add_query_arg( 'added', $added, $sendback );
- }
- if ( isset( $_SESSION['wpsc_settings_curr_page'] ) ) {
- $sendback = add_query_arg( 'tab', $_SESSION['wpsc_settings_curr_page'], $sendback );
- }
- $sendback = add_query_arg( 'page', 'wpsc-settings', $sendback );
- wp_redirect( $sendback );
- exit();
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'checkout_settings') )
- add_action( 'admin_init', 'wpsc_checkout_settings' );
- function wpsc_google_shipping_settings() {
- if ( isset( $_POST['submit'] ) ) {
- foreach ( (array)$_POST['google_shipping'] as $key => $country ) {
- if ( $country == 'on' ) {
- $google_shipping_country[] = $key;
- $updated++;
- }
- }
- update_option( 'google_shipping_country', $google_shipping_country );
- $sendback = wp_get_referer();
- $sendback = remove_query_arg( 'googlecheckoutshipping', $sendback );
- if ( isset( $updated ) ) {
- $sendback = add_query_arg( 'updated', $updated, $sendback );
- }
- wp_redirect( $sendback );
- exit();
- }
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'google_shipping_settings') ) {
- add_action( 'admin_init', 'wpsc_google_shipping_settings' );
- }
- //for ajax call of settings page tabs
- function wpsc_settings_page_ajax() {
- $html = '';
- $modified_page_title = $_POST['page_title'];
- $page_title = str_replace( "tab-", "", $modified_page_title );
- check_admin_referer( $modified_page_title );
- switch ( $page_title ) {
- case 'checkout' :
- require_once( WPSC_FILE_PATH . '/wpsc-admin/includes/settings-pages/checkout.php' );
- wpsc_options_checkout();
- break;
- case 'gateway' :
- require_once( WPSC_FILE_PATH . '/wpsc-admin/includes/settings-pages/gateway.php' );
- wpsc_options_gateway();
- break;
- case 'shipping' :
- require_once( WPSC_FILE_PATH . '/wpsc-admin/includes/settings-pages/shipping.php' );
- wpsc_options_shipping();
- break;
- case 'admin' :
- require_once( WPSC_FILE_PATH . '/wpsc-admin/includes/settings-pages/admin.php' );
- wpsc_options_admin();
- break;
- case 'presentation' :
- require_once( WPSC_FILE_PATH . '/wpsc-admin/includes/settings-pages/presentation.php' );
- wpsc_options_presentation();
- break;
- case 'taxes' :
- wpec_taxes_settings_page(); //see wpec-taxes view
- break;
- case 'marketing' :
- require_once( WPSC_FILE_PATH . '/wpsc-admin/includes/settings-pages/marketing.php' );
- wpsc_options_marketing();
- break;
- case 'import' :
- require_once( WPSC_FILE_PATH . '/wpsc-admin/includes/settings-pages/import.php' );
- wpsc_options_import();
- break;
- case 'general' :
- default;
- require_once( WPSC_FILE_PATH . '/wpsc-admin/includes/settings-pages/general.php' );
- wpsc_options_general();
- break;
- }
- $_SESSION['wpsc_settings_curr_page'] = $page_title;
- exit( $html );
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ($_REQUEST['wpsc_admin_action'] == 'settings_page_ajax') )
- add_action( 'admin_init', 'wpsc_settings_page_ajax' );
- function wpsc_update_variations() {
- $product_id = absint( $_POST["product_id"] );
- $product_type_object = get_post_type_object('wpsc-product');
- if (!current_user_can($product_type_object->cap->edit_post, $product_id))
- return;
-
- //Setup postdata
- $post_data = array( );
- $post_data['edit_var_val'] = isset( $_POST['edit_var_val'] ) ? $_POST["edit_var_val"] : '';
- $post_data['description'] = isset( $_POST['description'] ) ? $_POST["description"] : '';
- $post_data['additional_description'] = isset( $_POST['additional_description'] ) ? $_POST['additional_description'] : '';
- $post_data['name'] = (!empty($_POST['name']))?$_POST['name']:$_POST["post_title"];
- //Add or delete variations
- wpsc_edit_product_variations( $product_id, $post_data );
- if (defined('DOING_AJAX') && DOING_AJAX) {
- wpsc_admin_product_listing( $product_id );
- die();
- }
- }
- if ( isset($_POST["edit_var_val"]) )
- add_action( 'admin_init', 'wpsc_update_variations', 50 );
- add_action('wp_ajax_wpsc_update_variations', 'wpsc_update_variations', 50 );
- function wpsc_delete_variation_set() {
- check_admin_referer( 'delete-variation' );
- if ( is_numeric( $_GET['deleteid'] ) ) {
- $variation_id = absint( $_GET['deleteid'] );
- $variation_set = get_term( $variation_id, 'wpsc-variation', ARRAY_A );
- $variations = get_terms( 'wpsc-variation', array(
- 'hide_empty' => 0,
- 'parent' => $variation_id
- ) );
- foreach ( (array)$variations as $variation ) {
- $return_value = wp_delete_term( $variation->term_id, 'wpsc-variation' );
- }
- if ( !empty( $variation_set ) ) {
- $return_value = wp_delete_term( $variation_set['term_id'], 'wpsc-variation' );
- }
- $deleted = 1;
- }
- $sendback = wp_get_referer();
- if ( isset( $deleted ) ) {
- $sendback = add_query_arg( 'deleted', $deleted, $sendback );
- }
- $sendback = remove_query_arg( array(
- 'deleteid',
- 'variation_id'
- ), $sendback );
- wp_redirect( $sendback );
- exit();
- }
- function wpsc_force_flush_theme_transients() {
- // Flush transients
- wpsc_flush_theme_transients( true );
- // Bounce back
- $sendback = wp_get_referer();
- wp_redirect( $sendback );
- exit();
- }
- if ( isset( $_REQUEST['wpsc_flush_theme_transients'] ) && ( $_REQUEST['wpsc_flush_theme_transients'] == 'true' ) )
- add_action( 'admin_init', 'wpsc_force_flush_theme_transients' );
- function wpsc_backup_theme() {
- $wp_theme_path = get_stylesheet_directory();
- wpsc_recursive_copy( $wp_theme_path, WPSC_THEME_BACKUP_DIR );
- $_SESSION['wpsc_themes_backup'] = true;
- $sendback = wp_get_referer();
- wp_redirect( $sendback );
- exit();
- }
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ( $_REQUEST['wpsc_admin_action'] == 'backup_themes' ) )
- add_action( 'admin_init', 'wpsc_backup_theme' );
- function wpsc_delete_coupon(){
- global $wpdb;
-
- check_admin_referer( 'delete-coupon' );
- $coupon_id = (int)$_GET['delete_id'];
-
- if(isset($coupon_id)) {
- $wpdb->query("DELETE FROM `".WPSC_TABLE_COUPON_CODES."` WHERE `id` = '$coupon_id' LIMIT 1;");
-
- $deleted = 1;
- }
- $sendback = wp_get_referer();
- if ( isset( $deleted ) )
- $sendback = add_query_arg( 'deleted', $deleted, $sendback );
-
- $sendback = remove_query_arg( array('deleteid',), $sendback );
- wp_redirect( $sendback );
- exit();
- }
- if ( isset( $_GET['action'] ) && ( 'purchase_log' == $_GET['action'] ) )
- add_action( 'admin_init', 'wpsc_admin_sale_rss' );
- if ( isset( $_GET['purchase_log_csv'] ) && ( 'true' == $_GET['purchase_log_csv'] ) )
- add_action( 'admin_init', 'wpsc_purchase_log_csv' );
- if ( isset( $_REQUEST['ajax'] ) && isset( $_REQUEST['admin'] ) && ($_REQUEST['ajax'] == "true") && ($_REQUEST['admin'] == "true") )
- add_action( 'admin_init', 'wpsc_admin_ajax' );
- // Variation set deleting init code starts here
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ( 'wpsc-delete-variation-set' == $_REQUEST['wpsc_admin_action'] ) )
- add_action( 'admin_init', 'wpsc_delete_variation_set' );
-
- //Delete Coupon
- if ( isset( $_REQUEST['wpsc_admin_action'] ) && ( 'wpsc-delete-coupon' == $_REQUEST['wpsc_admin_action'] ) )
- add_action( 'admin_init', 'wpsc_delete_coupon' );
- function flat_price( $price ) {
- if ( isset( $price ) && !empty( $price ) && strchr( $price, '-' ) === false && strchr( $price, '+' ) === false && strchr( $price, '%' ) === false )
- return true;
- }
- function percentile_price( $price ) {
- if ( isset( $price ) && !empty( $price ) && ( strchr( $price, '-' ) || strchr( $price, '+' ) ) && strchr( $price, '%' ) )
- return true;
- }
- function differential_price( $price ) {
- if ( isset( $price ) && !empty( $price ) && ( strchr( $price, '-' ) || strchr( $price, '+' ) ) && strchr( $price, '%' ) === false )
- return true;
- }
- /**
- * If it doesn't exist, let's create a multi-dimensional associative array
- * that will contain all of the term/price associations
- *
- * @param <type> $variation
- */
- function variation_price_field( $variation ) {
- $term_prices = get_option( 'term_prices' );
- if ( is_object( $variation ) )
- $term_id = $variation->term_id;
- if ( empty( $term_prices ) || !is_array( $term_prices ) ) {
- $term_prices = array( );
- if ( isset( $term_id ) ) {
- $term_prices[$term_id] = array( );
- $term_prices[$term_id]["price"] = '';
- $term_prices[$term_id]["checked"] = '';
- }
- add_option( 'term_prices', $term_prices );
- }
- if ( isset( $term_id ) && is_array( $term_prices ) && array_key_exists( $term_id, $term_prices ) )
- $price = esc_attr( $term_prices[$term_id]["price"] );
- else
- $price = '';
- if( !isset( $_GET['action'] ) ) {
- ?>
- <div class="form-field">
- <label for="variation_price"><?php _e( 'Variation Price', 'wpsc' ); ?></label>
- <input type="text" name="variation_price" id="variation_price" style="width:50px;" value="<?php echo $price; ?>"><br />
- <span class="description"><?php _e( 'You can list a default price here for this variation. You can list a regular price (18.99), differential price (+1.99 / -2) or even a percentage-based price (+50% / -25%).', 'wpsc' ); ?></span>
- </div>
- <script type="text/javascript">
- jQuery('#parent option:contains(" ")').remove();
- jQuery('#parent').mousedown(function(){
- jQuery('#parent option:contains(" ")').remove();
- });
- </script>
- <?php
- } else{
- ?>
- <tr class="form-field">
- <th scope="row" valign="top">
- <label for="variation_price"><?php _e( 'Variation Price', 'wpsc' ); ?></label>
- </th>
- <td>
- <input type="text" name="variation_price" id="variation_price" style="width:50px;" value="<?php echo $price; ?>"><br />
- <span class="description"><?php _e( 'You can list a default price here for this variation. You can list a regular price (18.99), differential price (+1.99 / -2) or even a percentage-based price (+50% / -25%).', 'wpsc' ); ?></span>
- </td>
- </tr>
- <?php
- }
- }
- add_action( 'wpsc-variation_edit_form_fields', 'variation_price_field' );
- add_action( 'wpsc-variation_add_form_fields', 'variation_price_field' );
- function variation_price_field_check( $variation ) {
- $term_prices = get_option( 'term_prices' );
- if ( is_array( $term_prices ) && array_key_exists( $variation->term_id, $term_prices ) )
- $checked = ($term_prices[$variation->term_id]["checked"] == 'checked') ? 'checked' : '';
- else
- $checked = ''; ?>
- <tr class="form-field">
- <th scope="row" valign="top"><label for="apply_to_current"><?php _e( 'Apply to current variations?' ) ?></label></th>
- <td>
- <span class="description"><input type="checkbox" name="apply_to_current" id="apply_to_current" style="width:2%;" <?php echo $checked; ?> /><?php _e( 'By checking this box, the price rule you implement above will be applied to all variations that currently exist. If you leave it unchecked, it will only apply to products that use this variation created or edited from now on. Take note, this will apply this rule to <strong>every</strong> product using this variation. If you need to override it for any reason on a specific product, simply go to that product and change the price.', 'wpsc' ); ?></span>
- </td>
- </tr>
- <?php
- }
- add_action( 'wpsc-variation_edit_form_fields', 'variation_price_field_check' );
- /**
- * @todo - Should probably refactor this at some point - very procedural,
- * WAY too many foreach loops for my liking :) But it does the trick
- *
- * @param <type> $term_id
- */
- function save_term_prices( $term_id ) {
- // First - Saves options from input
- if ( isset( $_POST['variation_price'] ) || isset( $_POST["apply_to_current"] ) ) {
- $term_prices = get_option( 'term_prices' );
- $term_prices[$term_id]["price"] = $_POST["variation_price"];
- $term_prices[$term_id]["checked"] = (isset( $_POST["apply_to_current"] )) ? "checked" : "unchecked";
- update_option( 'term_prices', $term_prices );
- }
- // Second - If box was checked, let's then check whether or not it was flat, differential, or percentile, then let's apply the pricing to every product appropriately
- if ( isset( $_POST["apply_to_current"] ) ) {
- //Check for flat, percentile or differential
- $var_price_type = '';
- if ( flat_price( $_POST["variation_price"] ) )
- $var_price_type = 'flat';
- elseif ( differential_price( $_POST["variation_price"] ) )
- $var_price_type = 'differential';
- elseif ( percentile_price( $_POST["variation_price"] ) )
- $var_price_type = 'percentile';
- //Now, find all products with this term_id, update their pricing structure (terms returned include only parents at this point, we'll grab relevent children soon)
- $products_to_mod = get_objects_in_term( $term_id, "wpsc-variation" );
- $product_parents = array( );
- foreach ( (array)$products_to_mod as $get_parent ) {
- $post = get_post( $get_parent );
- if ( !$post->post_parent )
- $product_parents[] = $post->ID;
- }
- //Now that we have all parent IDs with this term, we can get the children (only the ones that are also in $products_to_mod, we don't want to apply pricing to ALL kids)
- foreach ( $product_parents as $parent ) {
- $args = array(
- 'post_parent' => $parent,
- 'post_type' => 'wpsc-product'
- );
- $children = get_children( $args, ARRAY_A );
- foreach ( $children as $childrens ) {
- $parent = $childrens["post_parent"];
- $children_ids[$parent][] = $childrens["ID"];
- $children_ids[$parent] = array_intersect( $children_ids[$parent], $products_to_mod );
- }
- }
- //Got the right kids, let's grab their parent pricing and modify their pricing based on var_price_type
- foreach ( (array)$children_ids as $parents => $kids ) {
- $kids = array_values( $kids );
- $parent_pricing = get_product_meta( $parents, "price", true );
- foreach ( $kids as $kiddos ) {
- $child_pricing = get_product_meta( $kiddos, "price", true );
- if ( $var_price_type == 'flat' ) {
- update_product_meta( $kiddos, "price", floatval( $_POST["variation_price"] ) );
- } elseif ( $var_price_type == 'percentile' ) {
- //Are we decreasing or increasing the price?
- if ( strchr( $_POST["variation_price"], '-' ) )
- $positive = false;
- else
- $positive = true;
- //Now, let's get the parent product price, +/- by the percentage given
- $percentage = (absint( $_POST["variation_price"] ) / 100);
- if ( $positive )
- $price = $parent_pricing + ($parent_pricing * $percentage);
- else
- $price = $parent_pricing - ($parent_pricing * $percentage);
- update_product_meta( $kiddos, "price", $price );
- } elseif ( $var_price_type == 'differential' ) {
-
- //Are we decreasing or increasing the price?
- if ( strchr( $_POST["variation_price"], '-' ) )
- $positive = false;
- else
- $positive = true;
- //Now, let's get the parent product price, +/- by the differential given
- $differential = (absint( $_POST["variation_price"] ));
- if ( $positive )
- $price = $parent_pricing + $differential;
- else
- $price = $parent_pricing - $differential;
- update_product_meta( $kiddos, "price", $price );
- }
- }
- }
- }
- }
- add_action( 'edited_wpsc-variation', 'save_term_prices' );
- add_action( 'created_wpsc-variation', 'save_term_prices' );
- ?>