woocommerce/includes/class-wc-order-factory.php

67 lines
1.7 KiB
PHP
Raw Normal View History

2014-06-13 13:20:14 +00:00
<?php
/**
* Order Factory Class
*
* The WooCommerce order factory creating the right order objects
*
* @class WC_Order_Factory
* @version 2.2.0
* @package WooCommerce/Classes
* @category Class
* @author WooThemes
*/
class WC_Order_Factory {
/**
* get_order function.
*
* @access public
* @param bool $the_order (default: false)
* @param array $args (default: array())
* @return WC_Order
*/
public function get_order( $the_order = false, $args = array() ) {
global $post;
if ( false === $the_order ) {
$the_order = $post;
} elseif ( is_numeric( $the_order ) ) {
$the_order = get_post( $the_order );
}
2014-07-08 17:20:40 +00:00
if ( ! $the_order || ! is_object( $the_order ) ) {
2014-06-13 13:20:14 +00:00
return false;
}
2014-07-07 10:44:27 +00:00
$order_id = absint( $the_order->ID );
$post_type = $the_order->post_type;
2014-06-13 13:20:14 +00:00
if ( 'shop_order' == $post_type ) {
$terms = get_the_terms( $order_id, 'order_type' );
$order_type = ! empty( $terms ) && isset( current( $terms )->name ) ? sanitize_title( current( $terms )->name ) : 'simple';
// Create a WC coding standards compliant class name e.g. WC_Order_Type_Class instead of WC_order_type-class
$classname = 'WC_Order_' . implode( '_', array_map( 'ucfirst', explode( '-', $order_type ) ) );
// The default order class must be WC_Order to provide backwards compatibility
if ( 'WC_Order_Simple' ) {
$classname = 'WC_Order';
}
2014-07-08 17:20:40 +00:00
2014-06-13 13:20:14 +00:00
} else {
2014-07-07 10:44:27 +00:00
$classname = false;
2014-06-13 13:20:14 +00:00
$order_type = false;
}
// Filter classname so that the class can be overridden if extended.
$classname = apply_filters( 'woocommerce_order_class', $classname, $order_type, $post_type, $order_id );
2014-07-07 10:44:27 +00:00
if ( ! class_exists( $classname ) ) {
$classname = 'WC_Order';
2014-07-07 10:44:27 +00:00
}
2014-06-13 13:20:14 +00:00
return new $classname( $the_order, $args );
}
}