2011-12-08 15:13:15 +00:00
< ? php
/**
* WooCommerce Ajax Handlers
*
* Handles AJAX requests via wp_ajax hook ( both admin and front - end events )
*
* @ author WooThemes
* @ category AJAX
* @ package WooCommerce
*/
2011-12-09 19:55:09 +00:00
/** Frontend AJAX events **************************************************/
/**
* Process ajax login
*/
add_action ( 'wp_ajax_nopriv_woocommerce_sidebar_login_process' , 'woocommerce_sidebar_login_ajax_process' );
function woocommerce_sidebar_login_ajax_process () {
check_ajax_referer ( 'woocommerce-sidebar-login-action' , 'security' );
// Get post data
$creds = array ();
$creds [ 'user_login' ] = esc_attr ( $_POST [ 'user_login' ]);
$creds [ 'user_password' ] = esc_attr ( $_POST [ 'user_password' ]);
$creds [ 'remember' ] = 'forever' ;
$redirect_to = esc_attr ( $_POST [ 'redirect_to' ]);
// Check for Secure Cookie
$secure_cookie = '' ;
// If the user wants ssl but the session is not ssl, force a secure cookie.
if ( ! empty ( $_POST [ 'log' ]) && ! force_ssl_admin () ) {
$user_name = sanitize_user ( $_POST [ 'log' ]);
if ( $user = get_user_by ( 'login' , $user_name ) ) {
if ( get_user_option ( 'use_ssl' , $user -> ID ) ) {
$secure_cookie = true ;
force_ssl_admin ( true );
}
}
}
2011-12-09 17:01:56 +00:00
2011-12-09 19:55:09 +00:00
if ( ! $secure_cookie && is_ssl () && force_ssl_login () && ! force_ssl_admin () && ( 0 !== strpos ( $redirect_to , 'https' ) ) && ( 0 === strpos ( $redirect_to , 'http' ) ) )
$secure_cookie = false ;
// Login
$user = wp_signon ( $creds , $secure_cookie );
2011-12-09 17:01:56 +00:00
2011-12-09 19:55:09 +00:00
// Redirect filter
if ( $secure_cookie && false !== strpos ( $redirect_to , 'wp-admin' ) ) $redirect_to = preg_replace ( '|^http://|' , 'https://' , $redirect_to );
// Result
$result = array ();
if ( ! is_wp_error ( $user ) ) :
$result [ 'success' ] = 1 ;
$result [ 'redirect' ] = $redirect_to ;
else :
$result [ 'success' ] = 0 ;
foreach ( $user -> errors as $error ) {
$result [ 'error' ] = $error [ 0 ];
break ;
2011-12-09 17:01:56 +00:00
}
2011-12-09 19:55:09 +00:00
endif ;
2011-12-09 17:01:56 +00:00
2011-12-09 19:55:09 +00:00
echo json_encode ( $result );
die ();
}
/**
* AJAX update shipping method on cart page
*/
add_action ( 'wp_ajax_woocommerce_update_shipping_method' , 'woocommerce_ajax_update_shipping_method' );
add_action ( 'wp_ajax_nopriv_woocommerce_update_shipping_method' , 'woocommerce_ajax_update_shipping_method' );
function woocommerce_ajax_update_shipping_method () {
global $woocommerce ;
2011-12-09 17:01:56 +00:00
2011-12-09 19:55:09 +00:00
check_ajax_referer ( 'update-shipping-method' , 'security' );
2011-12-09 17:01:56 +00:00
2011-12-09 19:55:09 +00:00
if ( isset ( $_POST [ 'shipping_method' ])) $_SESSION [ '_chosen_shipping_method' ] = $_POST [ 'shipping_method' ];
$woocommerce -> cart -> calculate_totals ();
woocommerce_cart_totals ();
die ();
}
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
/**
* AJAX update order review on checkout
*/
add_action ( 'wp_ajax_woocommerce_update_order_review' , 'woocommerce_ajax_update_order_review' );
add_action ( 'wp_ajax_nopriv_woocommerce_update_order_review' , 'woocommerce_ajax_update_order_review' );
function woocommerce_ajax_update_order_review () {
global $woocommerce ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
check_ajax_referer ( 'update-order-review' , 'security' );
if ( ! defined ( 'WOOCOMMERCE_CHECKOUT' )) define ( 'WOOCOMMERCE_CHECKOUT' , true );
if ( sizeof ( $woocommerce -> cart -> get_cart ()) == 0 ) :
echo '<p class="error">' . __ ( 'Sorry, your session has expired.' , 'woothemes' ) . ' <a href="' . home_url () . '">' . __ ( 'Return to homepage →' , 'woothemes' ) . '</a></p>' ;
2011-12-08 15:13:15 +00:00
die ();
2011-12-09 19:55:09 +00:00
endif ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
do_action ( 'woocommerce_checkout_update_order_review' , $_POST [ 'post_data' ]);
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
if ( isset ( $_POST [ 'shipping_method' ])) $_SESSION [ '_chosen_shipping_method' ] = $_POST [ 'shipping_method' ];
if ( isset ( $_POST [ 'country' ])) $woocommerce -> customer -> set_country ( $_POST [ 'country' ] );
if ( isset ( $_POST [ 'state' ])) $woocommerce -> customer -> set_state ( $_POST [ 'state' ] );
if ( isset ( $_POST [ 'postcode' ])) $woocommerce -> customer -> set_postcode ( $_POST [ 'postcode' ] );
if ( isset ( $_POST [ 's_country' ])) $woocommerce -> customer -> set_shipping_country ( $_POST [ 's_country' ] );
if ( isset ( $_POST [ 's_state' ])) $woocommerce -> customer -> set_shipping_state ( $_POST [ 's_state' ] );
if ( isset ( $_POST [ 's_postcode' ])) $woocommerce -> customer -> set_shipping_postcode ( $_POST [ 's_postcode' ] );
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
$woocommerce -> cart -> calculate_totals ();
do_action ( 'woocommerce_checkout_order_review' ); // Display review order table
die ();
}
/**
* AJAX add to cart
*/
add_action ( 'wp_ajax_woocommerce_add_to_cart' , 'woocommerce_ajax_add_to_cart' );
add_action ( 'wp_ajax_nopriv_woocommerce_add_to_cart' , 'woocommerce_ajax_add_to_cart' );
function woocommerce_ajax_add_to_cart () {
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
global $woocommerce ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
check_ajax_referer ( 'add-to-cart' , 'security' );
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
$product_id = ( int ) $_POST [ 'product_id' ];
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
if ( $woocommerce -> cart -> add_to_cart ( $product_id , 1 )) :
// Return html fragments
$data = apply_filters ( 'add_to_cart_fragments' , array ());
else :
// Return error
$data = array (
'error' => $woocommerce -> errors [ 0 ]
);
$woocommerce -> clear_messages ();
endif ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
echo json_encode ( $data );
die ();
}
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
/**
* Process ajax checkout form
*/
add_action ( 'wp_ajax_woocommerce-checkout' , 'woocommerce_process_checkout' );
add_action ( 'wp_ajax_nopriv_woocommerce-checkout' , 'woocommerce_process_checkout' );
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
function woocommerce_process_checkout () {
global $woocommerce , $woocommerce_checkout ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
$woocommerce_checkout = $woocommerce -> checkout ();
$woocommerce_checkout -> process_checkout ();
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
die ( 0 );
}
/** Admin AJAX events *****************************************************/
/**
* Feature a product from admin
*/
function woocommerce_feature_product () {
if ( ! is_admin () ) die ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
if ( ! current_user_can ( 'edit_posts' ) ) wp_die ( __ ( 'You do not have sufficient permissions to access this page.' , 'woothemes' ) );
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
if ( ! check_admin_referer ()) wp_die ( __ ( 'You have taken too long. Please go back and retry.' , 'woothemes' ) );
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
$post_id = isset ( $_GET [ 'product_id' ]) && ( int ) $_GET [ 'product_id' ] ? ( int ) $_GET [ 'product_id' ] : '' ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
if ( ! $post_id ) die ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
$post = get_post ( $post_id );
if ( ! $post ) die ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
if ( $post -> post_type !== 'product' ) die ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
$product = new woocommerce_product ( $post -> ID );
if ( $product -> is_featured ()) update_post_meta ( $post -> ID , 'featured' , 'no' );
else update_post_meta ( $post -> ID , 'featured' , 'yes' );
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
$sendback = remove_query_arg ( array ( 'trashed' , 'untrashed' , 'deleted' , 'ids' ), wp_get_referer () );
wp_safe_redirect ( $sendback );
}
add_action ( 'wp_ajax_woocommerce-feature-product' , 'woocommerce_feature_product' );
/**
* Mark an order as complete
*/
function woocommerce_mark_order_complete () {
if ( ! is_admin () ) die ;
if ( ! current_user_can ( 'edit_posts' ) ) wp_die ( __ ( 'You do not have sufficient permissions to access this page.' , 'woothemes' ) );
if ( ! check_admin_referer ()) wp_die ( __ ( 'You have taken too long. Please go back and retry.' , 'woothemes' ) );
$order_id = isset ( $_GET [ 'order_id' ]) && ( int ) $_GET [ 'order_id' ] ? ( int ) $_GET [ 'order_id' ] : '' ;
if ( ! $order_id ) die ;
$order = & new woocommerce_order ( $order_id );
$order -> update_status ( 'completed' );
wp_safe_redirect ( wp_get_referer () );
}
add_action ( 'wp_ajax_woocommerce-mark-order-complete' , 'woocommerce_mark_order_complete' );
/**
* Mark an order as processing
*/
function woocommerce_mark_order_processing () {
if ( ! is_admin () ) die ;
if ( ! current_user_can ( 'edit_posts' ) ) wp_die ( __ ( 'You do not have sufficient permissions to access this page.' , 'woothemes' ) );
if ( ! check_admin_referer ()) wp_die ( __ ( 'You have taken too long. Please go back and retry.' , 'woothemes' ) );
$order_id = isset ( $_GET [ 'order_id' ]) && ( int ) $_GET [ 'order_id' ] ? ( int ) $_GET [ 'order_id' ] : '' ;
if ( ! $order_id ) die ;
$order = & new woocommerce_order ( $order_id );
$order -> update_status ( 'processing' );
wp_safe_redirect ( wp_get_referer () );
}
add_action ( 'wp_ajax_woocommerce-mark-order-processing' , 'woocommerce_mark_order_processing' );
/**
* Delete variation via ajax function
*/
add_action ( 'wp_ajax_woocommerce_remove_variation' , 'woocommerce_remove_variation' );
function woocommerce_remove_variation () {
check_ajax_referer ( 'delete-variation' , 'security' );
$variation_id = intval ( $_POST [ 'variation_id' ] );
$variation = get_post ( $variation_id );
if ( $variation && $variation -> post_type == " product_variation " ) wp_delete_post ( $variation_id );
die ();
}
/**
* Add variation via ajax function
*/
add_action ( 'wp_ajax_woocommerce_add_variation' , 'woocommerce_add_variation' );
function woocommerce_add_variation () {
check_ajax_referer ( 'add-variation' , 'security' );
$post_id = intval ( $_POST [ 'post_id' ] );
$variation = array (
'post_title' => 'Product #' . $post_id . ' Variation' ,
'post_content' => '' ,
'post_status' => 'publish' ,
'post_author' => get_current_user_id (),
'post_parent' => $post_id ,
'post_type' => 'product_variation'
);
$variation_id = wp_insert_post ( $variation );
echo $variation_id ;
die ();
}
/**
* Link all variations via ajax function
*/
add_action ( 'wp_ajax_woocommerce_link_all_variations' , 'woocommerce_link_all_variations' );
function woocommerce_link_all_variations () {
check_ajax_referer ( 'link-variations' , 'security' );
$post_id = intval ( $_POST [ 'post_id' ] );
if ( ! $post_id ) die ();
$variations = array ();
$_product = & new woocommerce_product ( $post_id );
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
// Put variation attributes into an array
foreach ( $_product -> get_attributes () as $attribute ) :
if ( ! $attribute [ 'is_variation' ] ) continue ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
$attribute_field_name = 'attribute_' . sanitize_title ( $attribute [ 'name' ]);
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
if ( $attribute [ 'is_taxonomy' ]) :
$post_terms = wp_get_post_terms ( $post_id , $attribute [ 'name' ] );
$options = array ();
foreach ( $post_terms as $term ) :
$options [] = $term -> slug ;
endforeach ;
else :
$options = explode ( '|' , $attribute [ 'value' ]);
endif ;
$options = array_map ( 'trim' , $options );
$variations [ $attribute_field_name ] = $options ;
endforeach ;
// Quit out if none were found
if ( sizeof ( $variations ) == 0 ) die ();
// Get existing variations so we don't create duplicated
$available_variations = array ();
foreach ( $_product -> get_children () as $child_id ) {
$child = $_product -> get_child ( $child_id );
if ( $child instanceof woocommerce_product_variation ) {
$available_variations [] = $child -> get_variation_attributes ();
}
}
// Created posts will all have the following data
$variation_post_data = array (
'post_title' => 'Product #' . $post_id . ' Variation' ,
'post_content' => '' ,
'post_status' => 'publish' ,
'post_author' => get_current_user_id (),
'post_parent' => $post_id ,
'post_type' => 'product_variation'
);
// Now find all combinations and create posts
if ( ! function_exists ( 'array_cartesian' )) {
function array_cartesian ( $input ) {
$result = array ();
while ( list ( $key , $values ) = each ( $input )) {
// If a sub-array is empty, it doesn't affect the cartesian product
if ( empty ( $values )) {
continue ;
}
// Special case: seeding the product array with the values from the first sub-array
if ( empty ( $result )) {
foreach ( $values as $value ) {
$result [] = array ( $key => $value );
}
}
else {
// Second and subsequent input sub-arrays work like this:
// 1. In each existing array inside $product, add an item with
// key == $key and value == first item in input sub-array
// 2. Then, for each remaining item in current input sub-array,
// add a copy of each existing array inside $product with
// key == $key and value == first item in current input sub-array
// Store all items to be added to $product here; adding them on the spot
// inside the foreach will result in an infinite loop
$append = array ();
foreach ( $result as & $product ) {
// Do step 1 above. array_shift is not the most efficient, but it
// allows us to iterate over the rest of the items with a simple
// foreach, making the code short and familiar.
$product [ $key ] = array_shift ( $values );
// $product is by reference (that's why the key we added above
// will appear in the end result), so make a copy of it here
$copy = $product ;
// Do step 2 above.
foreach ( $values as $item ) {
$copy [ $key ] = $item ;
$append [] = $copy ;
}
// Undo the side effecst of array_shift
array_unshift ( $values , $product [ $key ]);
}
// Out of the foreach, we can add to $results now
$result = array_merge ( $result , $append );
}
}
return $result ;
}
2011-12-08 15:13:15 +00:00
}
2011-12-09 19:55:09 +00:00
$variation_ids = array ();
$possible_variations = array_cartesian ( $variations );
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
foreach ( $possible_variations as $variation ) :
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
// Check if variation already exists
if ( in_array ( $variation , $available_variations )) continue ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
$variation_id = wp_insert_post ( $variation_post_data );
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
$variation_ids [] = $variation_id ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
foreach ( $variation as $key => $value ) :
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
update_post_meta ( $variation_id , $key , $value );
2011-12-08 15:13:15 +00:00
endforeach ;
2011-12-09 19:55:09 +00:00
endforeach ;
echo 1 ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
die ();
}
/**
* Get customer details via ajax
*/
add_action ( 'wp_ajax_woocommerce_get_customer_details' , 'woocommerce_get_customer_details' );
function woocommerce_get_customer_details () {
global $woocommerce ;
check_ajax_referer ( 'get-customer-details' , 'security' );
$user_id = ( int ) trim ( stripslashes ( $_POST [ 'user_id' ]));
$type_to_load = esc_attr ( trim ( stripslashes ( $_POST [ 'type_to_load' ])));
$customer_data = array (
$type_to_load . '_first_name' => get_user_meta ( $user_id , $type_to_load . '_first_name' , true ),
$type_to_load . '_last_name' => get_user_meta ( $user_id , $type_to_load . '_last_name' , true ),
$type_to_load . '_company' => get_user_meta ( $user_id , $type_to_load . '_company' , true ),
$type_to_load . '_address_1' => get_user_meta ( $user_id , $type_to_load . '_address_1' , true ),
$type_to_load . '_address_2' => get_user_meta ( $user_id , $type_to_load . '_address_2' , true ),
$type_to_load . '_city' => get_user_meta ( $user_id , $type_to_load . '_city' , true ),
$type_to_load . '_postcode' => get_user_meta ( $user_id , $type_to_load . '_postcode' , true ),
$type_to_load . '_country' => get_user_meta ( $user_id , $type_to_load . '_country' , true ),
$type_to_load . '_state' => get_user_meta ( $user_id , $type_to_load . '_state' , true ),
$type_to_load . '_email' => get_user_meta ( $user_id , $type_to_load . '_email' , true ),
$type_to_load . '_phone' => get_user_meta ( $user_id , $type_to_load . '_phone' , true ),
);
echo json_encode ( $customer_data );
// Quit out
die ();
}
/**
* Add order item via ajax
*/
add_action ( 'wp_ajax_woocommerce_add_order_item' , 'woocommerce_add_order_item' );
function woocommerce_add_order_item () {
global $woocommerce ;
check_ajax_referer ( 'add-order-item' , 'security' );
global $wpdb ;
$index = trim ( stripslashes ( $_POST [ 'index' ]));
$item_to_add = trim ( stripslashes ( $_POST [ 'item_to_add' ]));
$post = '' ;
// Find the item
if ( is_numeric ( $item_to_add )) :
$post = get_post ( $item_to_add );
endif ;
if ( ! $post || ( $post -> post_type !== 'product' && $post -> post_type !== 'product_variation' )) :
$post_id = $wpdb -> get_var ( $wpdb -> prepare ( "
SELECT post_id
FROM $wpdb -> posts
LEFT JOIN $wpdb -> postmeta ON ( $wpdb -> posts . ID = $wpdb -> postmeta . post_id )
WHERE $wpdb -> postmeta . meta_key = 'sku'
AND $wpdb -> posts . post_status = 'publish'
AND $wpdb -> posts . post_type = 'shop_product'
AND $wpdb -> postmeta . meta_value = % s
LIMIT 1
" ), $item_to_add );
$post = get_post ( $post_id );
endif ;
if ( ! $post || ( $post -> post_type !== 'product' && $post -> post_type !== 'product_variation' )) :
2011-12-08 15:13:15 +00:00
die ();
2011-12-09 19:55:09 +00:00
endif ;
if ( $post -> post_type == " product " ) :
$_product = & new woocommerce_product ( $post -> ID );
else :
$_product = & new woocommerce_product_variation ( $post -> ID );
endif ;
?>
< tr class = " item " rel = " <?php echo $index ; ?> " >
< td class = " product-id " >
< img class = " tips " tip = " <?php
echo '<strong>' . __ ( 'Product ID:' , 'woothemes' ) . '</strong> ' . $_product -> id ;
echo '<br/><strong>' . __ ( 'Variation ID:' , 'woothemes' ) . '</strong> ' ; if ( $_product -> variation_id ) echo $_product -> variation_id ; else echo '-' ;
echo '<br/><strong>' . __ ( 'Product SKU:' , 'woothemes' ) . '</strong> ' ; if ( $_product -> sku ) echo $_product -> sku ; else echo '-' ;
?> " src="<?php echo $woocommerce->plugin_url(); ?>/assets/images/tip.png" />
</ td >
< td class = " sku " >< ? php if ( $_product -> sku ) echo $_product -> sku ; else echo '-' ; ?> </td>
< td class = " name " >
< a href = " <?php echo esc_url( admin_url('post.php?post='. $_product->id .'&action=edit') ); ?> " >< ? php echo $_product -> get_title (); ?> </a>
< ? php
if ( isset ( $_product -> variation_data )) :
echo '<br/>' . woocommerce_get_formatted_variation ( $_product -> variation_data , true );
endif ;
?>
</ td >
< td >
< table class = " meta " cellspacing = " 0 " >
< tfoot >
< tr >
< td colspan = " 3 " >< button class = " add_meta button " >< ? php _e ( 'Add meta' , 'woothemes' ); ?> </button></td>
</ tr >
</ tfoot >
< tbody class = " meta_items " ></ tbody >
</ table >
</ td >
< ? php do_action ( 'woocommerce_admin_order_item_values' , $_product ); ?>
2011-12-19 11:36:29 +00:00
< td class = " quantity " >< input type = " text " name = " item_quantity[<?php echo $index ; ?>] " placeholder = " 0 " value = " 1 " /></ td >
< td class = " cost " >< input type = " text " name = " base_item_cost[<?php echo $index ; ?>] " placeholder = " 0.00 " value = " <?php echo esc_attr( $_product->get_price_excluding_tax ( false ) ); ?> " /></ td >
< td class = " cost " >< input type = " text " name = " item_cost[<?php echo $index ; ?>] " placeholder = " 0.00 " value = " <?php echo esc_attr( $_product->get_price_excluding_tax ( false ) ); ?> " /></ td >
< td class = " tax " >< input type = " text " name = " item_tax_rate[<?php echo $index ; ?>] " placeholder = " 0.0000 " value = " <?php echo esc_attr( $_product->get_tax_base_rate () ); ?> " /></ td >
2011-12-09 19:55:09 +00:00
< td class = " center " >
< input type = " hidden " name = " item_id[<?php echo $index ; ?>] " value = " <?php echo esc_attr( $_product->id ); ?> " />
< input type = " hidden " name = " item_name[<?php echo $index ; ?>] " value = " <?php echo esc_attr( $_product->get_title () ); ?> " />
< input type = " hidden " name = " item_variation[<?php echo $index ; ?>] " value = " <?php if (isset( $_product->variation_id )) echo $_product->variation_id ; ?> " />
< button type = " button " class = " remove_row button " >& times ; </ button >
</ td >
</ tr >
< ? php
// Quit out
die ();
}
/**
* Add order note via ajax
*/
add_action ( 'wp_ajax_woocommerce_add_order_note' , 'woocommerce_add_order_note' );
function woocommerce_add_order_note () {
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
global $woocommerce ;
check_ajax_referer ( 'add-order-note' , 'security' );
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
$post_id = ( int ) $_POST [ 'post_id' ];
$note = strip_tags ( woocommerce_clean ( $_POST [ 'note' ]));
$note_type = $_POST [ 'note_type' ];
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
$is_customer_note = ( $note_type == 'customer' ) ? 1 : 0 ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
if ( $post_id > 0 ) :
$order = & new woocommerce_order ( $post_id );
$comment_id = $order -> add_order_note ( $note , $is_customer_note );
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
echo '<li rel="' . $comment_id . '" class="note ' ;
if ( $is_customer_note ) echo 'customer-note' ;
echo '"><div class="note_content">' ;
echo wpautop ( wptexturize ( $note ));
echo '</div><p class="meta">' . sprintf ( __ ( 'added %s ago' , 'woothemes' ), human_time_diff ( current_time ( 'timestamp' ))) . ' - <a href="#" class="delete_note">' . __ ( 'Delete note' , 'woothemes' ) . '</a></p>' ;
echo '</li>' ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
endif ;
// Quit out
die ();
}
/**
* Delete order note via ajax
*/
add_action ( 'wp_ajax_woocommerce_delete_order_note' , 'woocommerce_delete_order_note' );
function woocommerce_delete_order_note () {
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
global $woocommerce ;
check_ajax_referer ( 'delete-order-note' , 'security' );
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
$note_id = ( int ) $_POST [ 'note_id' ];
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
if ( $note_id > 0 ) :
wp_delete_comment ( $note_id );
endif ;
// Quit out
die ();
}
/**
* Search for products for upsells / crosssells
*/
add_action ( 'wp_ajax_woocommerce_upsell_crosssell_search_products' , 'woocommerce_upsell_crosssell_search_products' );
function woocommerce_upsell_crosssell_search_products () {
check_ajax_referer ( 'search-products' , 'security' );
$search = ( string ) urldecode ( stripslashes ( strip_tags ( $_POST [ 'search' ])));
$name = ( string ) urldecode ( stripslashes ( strip_tags ( $_POST [ 'name' ])));
if ( empty ( $search )) die ();
if ( is_numeric ( $search )) :
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
$args = array (
'post_type' => 'product' ,
'post_status' => 'publish' ,
'posts_per_page' => 15 ,
'post__in' => array ( 0 , $search )
);
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
else :
$args = array (
'post_type' => 'product' ,
'post_status' => 'publish' ,
'posts_per_page' => 15 ,
's' => $search
);
endif ;
$posts = get_posts ( $args );
if ( $posts ) : foreach ( $posts as $post ) :
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
$SKU = get_post_meta ( $post -> ID , 'sku' , true );
2011-12-08 15:13:15 +00:00
?>
2011-12-09 19:55:09 +00:00
< li rel = " <?php echo $post->ID ; ?> " >< button type = " button " name = " Add " class = " button add_crosssell " title = " Add " >< ? php _e ( 'Cross-sell' , 'woothemes' ); ?> →</button><button type="button" name="Add" class="button add_upsell" title="Add"><?php _e('Up-sell', 'woothemes'); ?> →</button><strong><?php echo $post->post_title; ?></strong> – #<?php echo $post->ID; ?> <?php if (isset($SKU) && $SKU) echo 'SKU: '.$SKU; ?><input type="hidden" class="product_id" value="0" /></li>
2011-12-08 15:13:15 +00:00
< ? php
2011-12-09 19:55:09 +00:00
endforeach ; else :
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
?> <li><?php _e('No products found', 'woothemes'); ?></li><?php
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
endif ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
die ();
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
}
/**
* Ajax request handling for categories ordering
*/
function woocommerce_term_ordering () {
global $wpdb ;
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
$id = ( int ) $_POST [ 'id' ];
$next_id = isset ( $_POST [ 'nextid' ]) && ( int ) $_POST [ 'nextid' ] ? ( int ) $_POST [ 'nextid' ] : null ;
$taxonomy = isset ( $_POST [ 'thetaxonomy' ]) ? esc_attr ( $_POST [ 'thetaxonomy' ] ) : null ;
$term = get_term_by ( 'id' , $id , $taxonomy );
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
if ( ! $id || ! $term || ! $taxonomy ) die ( 0 );
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
woocommerce_order_terms ( $term , $next_id , $taxonomy );
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
$children = get_terms ( $taxonomy , " child_of= $id &menu_order=ASC&hide_empty=0 " );
2011-12-08 15:13:15 +00:00
2011-12-09 19:55:09 +00:00
if ( $term && sizeof ( $children ) ) {
echo 'children' ;
die ;
2011-12-08 15:13:15 +00:00
}
2011-12-09 19:55:09 +00:00
}
add_action ( 'wp_ajax_woocommerce-term-ordering' , 'woocommerce_term_ordering' );