import_page = 'woocommerce_tax_rate_csv'; } /** * Registered callback function for the WordPress Importer * * Manages the three separate stages of the CSV import process */ function dispatch() { $this->header(); if ( ! empty( $_POST['delimiter'] ) ) $this->delimiter = stripslashes( trim( $_POST['delimiter'] ) ); if ( ! $this->delimiter ) $this->delimiter = ','; $step = empty( $_GET['step'] ) ? 0 : (int) $_GET['step']; switch ( $step ) { case 0: $this->greet(); break; case 1: check_admin_referer( 'import-upload' ); if ( $this->handle_upload() ) { if ( $this->id ) $file = get_attached_file( $this->id ); else $file = ABSPATH . $this->file_url; add_filter( 'http_request_timeout', array( &$this, 'bump_request_timeout' ) ); if ( function_exists( 'gc_enable' ) ) gc_enable(); @set_time_limit(0); @ob_flush(); @flush(); $this->import( $file ); } break; } $this->footer(); } /** * format_data_from_csv function. * * @access public * @param mixed $data * @param mixed $enc * @return void */ function format_data_from_csv( $data, $enc ) { return ( $enc == 'UTF-8' ) ? $data : utf8_encode( $data ); } /** * import function. * * @access public * @param mixed $file * @return void */ function import( $file ) { global $woocommerce, $wpdb; $this->imported = $this->skipped = 0; if ( ! is_file($file) ) { echo '
' . __( 'Sorry, there has been an error.', 'woocommerce' ) . '
';
echo __( 'The file does not exist, please try again.', 'woocommerce' ) . '
' . __( 'Sorry, there has been an error.', 'woocommerce' ) . '
';
echo __( 'The CSV is invalid.', 'woocommerce' ) . '
'.sprintf( __('Import complete - imported %s tax rates and skipped %s.', 'woocommerce'), $this->imported, $this->skipped ).'
' . __( 'All done!', 'woocommerce' ) . ' ' . __( 'View Tax Rates', 'woocommerce' ) . '' . '
'; do_action( 'import_end' ); } /** * Handles the CSV upload and initial parsing of the file to prepare for * displaying author import options * * @return bool False if error uploading or invalid file, true otherwise */ function handle_upload() { if ( empty( $_POST['file_url'] ) ) { $file = wp_import_handle_upload(); if ( isset( $file['error'] ) ) { echo '' . __( 'Sorry, there has been an error.', 'woocommerce' ) . '
';
echo esc_html( $file['error'] ) . '
' . __( 'Sorry, there has been an error.', 'woocommerce' ) . '
'; return false; } } return true; } /** * header function. * * @access public * @return void */ function header() { echo '' . __( 'Hi there! Upload a CSV file containing tax rates to import the contents into your shop. Choose a .csv file to upload, then click "Upload file and import".', 'woocommerce' ).'
'; echo '' . sprintf( __( 'Tax rates need to be defined with columns in a specific order (6 columns). Click here to download a sample.', 'woocommerce' ), $woocommerce->plugin_url() . '/admin/importers/samples/sample_tax_rates.csv' ) . '
'; echo '' . sprintf( __( 'Local tax rates also need to be defined with columns in a specific order (8 columns). Click here to download a sample.', 'woocommerce' ), $woocommerce->plugin_url() . '/admin/importers/samples/sample_local_tax_rates.csv' ) . '
'; $action = 'admin.php?import=woocommerce_tax_rate_csv&step=1'; $bytes = apply_filters( 'import_upload_size_limit', wp_max_upload_size() ); $size = wp_convert_bytes_to_hr( $bytes ); $upload_dir = wp_upload_dir(); if ( ! empty( $upload_dir['error'] ) ) : ?>