prefix."woocommerce_order_items"; if($order_id){ $sql = "SELECT order_item_id FROM $item_table_name WHERE order_item_type = 'line_item' AND order_id=$order_id"; $results = $wpdb->get_results($sql); //or die(mysql_error()); if(!empty($results)){ $order_item_id = $results[0]->order_item_id; $table_name = $wpdb->prefix."woocommerce_order_itemmeta"; $sql2 = "SELECT meta_value FROM $table_name WHERE order_item_id =$order_item_id AND meta_key='_event_service_info'"; $results2 = $wpdb->get_results($sql2); if($results2){ return unserialize($results2[0]->meta_value); }else{ return array(); } }else{ return array(); } }else{ return array(); } } function mep_get_extra_service_order_qty($name, $array) { if(!empty($array)){ foreach ($array as $key => $val) { if ($val['option_name'] === $name ) { return $val['option_qty']; // return $key; } } } return null; } // Add action hook only if action=download_csv if ( isset($_GET['action'] ) && $_GET['action'] == 'download_csv' ) { // Handle CSV Export add_action( 'admin_init', 'csv_export') ; } function csv_export() { // Check for current user privileges if( !current_user_can( 'manage_options' ) ){ return false; } // Check if we are in WP-Admin if( !is_admin() ){ return false; } // Nonce Check // $nonce = isset( $_GET['_wpnonce'] ) ? $_GET['_wpnonce'] : ''; // if ( ! wp_verify_nonce( $nonce, 'download_csv' ) ) { // die( 'Security check error' ); // } ob_start(); $domain = $_SERVER['SERVER_NAME']; $filename = 'Event_Manager_Export_' . $domain . '_' . time() . '.csv'; if(isset($_GET['meta_value'])){ $post_id = strip_tags($_GET['meta_value']); $header_row = mep_get_event_user_fields($post_id); }else{ $header_row = array( 'Order ID', 'Event', 'Ticket', 'Full Name', 'Email', 'Phone', 'Addresss', 'Tee Size' ); } $data_rows = array(); global $wpdb; if(isset($_GET['meta_value'])){ $meta = $_GET['meta_value']; $query = "SELECT post_id FROM {$wpdb->prefix}postmeta WHERE meta_value = $meta ORDER BY meta_id ASC"; }else{ $query = "SELECT ID FROM {$wpdb->prefix}posts WHERE post_type ='mep_events_attendees' ORDER BY ID ASC"; } $posts = $wpdb->get_results($query); foreach ( $posts as $i=>$post ) { if(isset($_GET['meta_value'])){ $post_id = $post->post_id; }else{ $post_id = $post->ID; } $status = get_post_status($post_id); if($status=='publish'){ if(isset($_GET['meta_value'])){ $event = strip_tags($_GET['meta_value']); $row = mep_get_event_user_fields_data($post_id,$event); }else{ $post_id = $post->ID; $row = array( get_post_meta( $post_id, 'ea_order_id', true ), get_post_meta( $post_id, 'ea_event_name', true ), get_post_meta( $post_id, 'ea_ticket_type', true ), get_post_meta( $post_id, 'ea_name', true ), get_post_meta( $post_id, 'ea_email', true ), get_post_meta( $post_id, 'ea_phone', true ), get_post_meta( $post_id, 'ea_address_1', true ), get_post_meta( $post_id, 'ea_tshirtsize', true ) ); } $data_rows[] = $row; } } $fh = @fopen( 'php://output', 'w' ); fprintf( $fh, chr(0xEF) . chr(0xBB) . chr(0xBF) ); header( 'Cache-Control: must-revalidate, post-check=0, pre-check=0' ); header( 'Content-Description: File Transfer' ); header( 'Content-type: text/csv' ); header( "Content-Disposition: attachment; filename={$filename}" ); header( 'Expires: 0' ); header( 'Pragma: public' ); fputcsv( $fh, $header_row ); foreach ( $data_rows as $data_row ) { fputcsv( $fh, $data_row ); } fclose( $fh ); ob_end_flush(); die(); }