Im trying to export data from bulk action in custom WP_List_Table class. I have following function for exporting data but I get "headers already sent" errors all the time i want to export data. Could you please point what I'm doing wrong?
public static function export_mailings ($data) {
if ( !current_user_can( 'manage_options') ) {
return;
}
global $wpdb;
$filename = 'mailings-' . date('d-M-Y') . '.csv';
$sql = "SELECT * FROM {$wpdb->prefix}wpsml WHERE `id` IN (" . implode(',', array_map('intval', $data)) . ")";
$results = $wpdb->get_results($sql);
$csv_headers = array();
$csv_headers[] = 'Date';
$csv_headers[] = 'Name';
$csv_headers[] = 'Email';
$filename = 'export' . date('d-M-Y');
$output_handle = fopen('php://output', 'w');
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=' . $output_filename );
header( 'Expires: 0' );
header( 'Pragma: public' );
fputcsv($output_handle, $csv_headers);
foreach ($results as $result) {
fputcsv($output_handle, (array)$result);
}
fclose($output_handle);
die();
}