Duplicate code is one of the most pungent code smells. A rule that is often used is to re-structure code once it is duplicated in three or more places.
Common duplication problems, and corresponding solutions are:
Complex classes like WC_Abstract_Order often do a lot of different things. To break such a class down, we need to identify a cohesive component within that class. A common approach to find such a component is to look for fields/methods that share the same prefixes, or suffixes. You can also have a look at the cohesion graph to spot any un-connected, or weakly-connected components.
Once you have determined the fields that belong together, you can apply the Extract Class refactoring. If the component makes sense as a sub-class, Extract Subclass is also a candidate, and is often faster.
While breaking up the class, it is a good idea to analyze how other classes use WC_Abstract_Order, and based on these observations, apply Extract Interface, too.
| 1 | <?php | ||
| 20 | abstract class WC_Abstract_Order extends WC_Abstract_Legacy_Order { | ||
| 21 | |||
| 22 | /** | ||
| 23 | * Order Data array, with defaults. This is the core order data exposed | ||
| 24 | * in APIs since 2.7.0. | ||
| 25 | * | ||
| 26 | * Notes: | ||
| 27 | * order_tax = Sum of all taxes. | ||
| 28 | * cart_tax = cart_tax is the new name for the legacy 'order_tax' which is the tax for items only, not shipping. | ||
| 29 | * | ||
| 30 | * @since 2.7.0 | ||
| 31 | * @var array | ||
| 32 | */ | ||
| 33 | protected $_data = array( | ||
| 34 | 'id' => 0, | ||
| 35 | 'parent_id' => 0, | ||
| 36 | 'status' => '', | ||
| 37 | 'currency' => '', | ||
| 38 | 'version' => '', | ||
| 39 | 'prices_include_tax' => false, | ||
| 40 | 'date_created' => '', | ||
| 41 | 'date_modified' => '', | ||
| 42 | 'discount_total' => 0, | ||
| 43 | 'discount_tax' => 0, | ||
| 44 | 'shipping_total' => 0, | ||
| 45 | 'shipping_tax' => 0, | ||
| 46 | 'cart_tax' => 0, | ||
| 47 | 'total' => 0, | ||
| 48 | 'total_tax' => 0, | ||
| 49 | ); | ||
| 50 | |||
| 51 | /** | ||
| 52 | * Data stored in meta keys, but not considered "meta" for an order. | ||
| 53 | * @since 2.7.0 | ||
| 54 | * @var array | ||
| 55 | */ | ||
| 56 | protected $_internal_meta_keys = array( | ||
| 57 | '_order_currency', '_cart_discount', | ||
| 58 | '_cart_discount_tax', '_order_shipping', '_order_shipping_tax', | ||
| 59 | '_order_tax', '_order_total', '_order_version', '_prices_include_tax', | ||
| 60 | '_payment_tokens', | ||
| 61 | ); | ||
| 62 | |||
| 63 | /** | ||
| 64 | * Order items will be stored here, sometimes before they persist in the DB. | ||
| 65 | * @since 2.7.0 | ||
| 66 | * @var array | ||
| 67 | */ | ||
| 68 | protected $_items = array( | ||
| 69 | 'line_items' => null, | ||
| 70 | 'coupon_lines' => null, | ||
| 71 | 'shipping_lines' => null, | ||
| 72 | 'fee_lines' => null, | ||
| 73 | 'tax_lines' => null, | ||
| 74 | ); | ||
| 75 | |||
| 76 | /** | ||
| 77 | * Order items that need deleting are stored here. | ||
| 78 | * @since 2.7.0 | ||
| 79 | * @var array | ||
| 80 | */ | ||
| 81 | protected $_items_to_delete = array(); | ||
| 82 | |||
| 83 | /** | ||
| 84 | * Internal meta type used to store order data. | ||
| 85 | * @var string | ||
| 86 | */ | ||
| 87 | protected $_meta_type = 'post'; | ||
| 88 | |||
| 89 | /** | ||
| 90 | * Stores meta in cache for future reads. | ||
| 91 | * A group must be set to to enable caching. | ||
| 92 | * @var string | ||
| 93 | */ | ||
| 94 | protected $_cache_group = 'order'; | ||
| 95 | |||
| 96 | /** | ||
| 97 | * Get the order if ID is passed, otherwise the order is new and empty. | ||
| 98 | * This class should NOT be instantiated, but the get_order function or new WC_Order_Factory. | ||
| 99 | * should be used. It is possible, but the aforementioned are preferred and are the only. | ||
| 100 | * methods that will be maintained going forward. | ||
| 101 | * | ||
| 102 | * @param int|object|WC_Order $order Order to init. | ||
| 103 | */ | ||
| 104 | 	public function __construct( $order = 0 ) { | ||
| 105 | 		if ( is_numeric( $order ) && $order > 0 ) { | ||
| 106 | $this->read( $order ); | ||
| 107 | 		} elseif ( $order instanceof self ) { | ||
| 108 | $this->read( absint( $order->get_id() ) ); | ||
| 109 | 		} elseif ( ! empty( $order->ID ) ) { | ||
| 110 | $this->read( absint( $order->ID ) ); | ||
| 111 | } | ||
| 112 | // Set default status if none were read. | ||
| 113 | 		if ( ! $this->get_status() ) { | ||
| 114 | $this->set_status( apply_filters( 'woocommerce_default_order_status', 'pending' ) ); | ||
| 115 | } | ||
| 116 | } | ||
| 117 | |||
| 118 | /* | ||
| 119 | |-------------------------------------------------------------------------- | ||
| 120 | | CRUD methods | ||
| 121 | |-------------------------------------------------------------------------- | ||
| 122 | | | ||
| 123 | | Methods which create, read, update and delete orders from the database. | ||
| 124 | | Written in abstract fashion so that the way orders are stored can be | ||
| 125 | | changed more easily in the future. | ||
| 126 | | | ||
| 127 | | A save method is included for convenience (chooses update or create based | ||
| 128 | | on if the order exists yet). | ||
| 129 | | | ||
| 130 | */ | ||
| 131 | |||
| 132 | /** | ||
| 133 | * Get internal type (post type.) | ||
| 134 | * @return string | ||
| 135 | */ | ||
| 136 | 	public function get_type() { | ||
| 137 | return 'shop_order'; | ||
| 138 | } | ||
| 139 | |||
| 140 | /** | ||
| 141 | * Get a title for the new post type. | ||
| 142 | */ | ||
| 143 | 	protected function get_post_title() { | ||
| 144 | return sprintf( __( 'Order – %s', 'woocommerce' ), strftime( _x( '%b %d, %Y @ %I:%M %p', 'Order date parsed by strftime', 'woocommerce' ) ) ); | ||
| 145 | } | ||
| 146 | |||
| 147 | /** | ||
| 148 | * Insert data into the database. | ||
| 149 | * @since 2.7.0 | ||
| 150 | */ | ||
| 151 | 	public function create() { | ||
| 152 | $this->set_date_created( current_time( 'timestamp' ) ); | ||
| 153 | $this->set_currency( $this->get_currency() ? $this->get_currency() : get_woocommerce_currency() ); | ||
| 154 | |||
| 155 | $order_id = wp_insert_post( apply_filters( 'woocommerce_new_order_data', array( | ||
| 156 | 'post_date' => date( 'Y-m-d H:i:s', $this->get_date_created() ), | ||
| 157 | 'post_date_gmt' => get_gmt_from_date( date( 'Y-m-d H:i:s', $this->get_date_created() ) ), | ||
| 158 | 'post_type' => $this->get_type(), | ||
| 159 | 'post_status' => 'wc-' . ( $this->get_status() ? $this->get_status() : apply_filters( 'woocommerce_default_order_status', 'pending' ) ), | ||
| 160 | 'ping_status' => 'closed', | ||
| 161 | 'post_author' => 1, | ||
| 162 | 'post_title' => $this->get_post_title(), | ||
| 163 | 'post_password' => uniqid( 'order_' ), | ||
| 164 | 'post_parent' => $this->get_parent_id(), | ||
| 165 | ) ), true ); | ||
| 166 | |||
| 167 | 		if ( $order_id ) { | ||
| 168 | $this->set_id( $order_id ); | ||
| 169 | |||
| 170 | // Set meta data | ||
| 171 | $this->update_post_meta( '_order_currency', $this->get_currency() ); | ||
| 172 | $this->update_post_meta( '_cart_discount', $this->get_discount_total( true ) ); | ||
| 173 | $this->update_post_meta( '_cart_discount_tax', $this->get_discount_tax( true ) ); | ||
| 174 | $this->update_post_meta( '_order_shipping', $this->get_shipping_total( true ) ); | ||
| 175 | $this->update_post_meta( '_order_shipping_tax', $this->get_shipping_tax( true ) ); | ||
| 176 | $this->update_post_meta( '_order_tax', $this->get_cart_tax( true ) ); | ||
| 177 | $this->update_post_meta( '_order_total', $this->get_total( true ) ); | ||
| 178 | $this->update_post_meta( '_order_version', $this->get_version() ); | ||
| 179 | $this->update_post_meta( '_prices_include_tax', $this->get_prices_include_tax() ); | ||
| 180 | $this->save_meta_data(); | ||
| 181 | } | ||
| 182 | } | ||
| 183 | |||
| 184 | /** | ||
| 185 | * Read from the database. | ||
| 186 | * @since 2.7.0 | ||
| 187 | * @param int $id ID of object to read. | ||
| 188 | */ | ||
| 189 | 	public function read( $id ) { | ||
| 190 | 		if ( empty( $id ) || ! ( $post_object = get_post( $id ) ) ) { | ||
| 191 | return; | ||
| 192 | } | ||
| 193 | |||
| 194 | // Map standard post data | ||
| 195 | $this->set_id( $post_object->ID ); | ||
| 196 | $this->set_parent_id( $post_object->post_parent ); | ||
| 197 | $this->set_date_created( $post_object->post_date ); | ||
| 198 | $this->set_date_modified( $post_object->post_modified ); | ||
| 199 | $this->set_status( $post_object->post_status ); | ||
| 200 | $this->set_currency( get_post_meta( $this->get_id(), '_order_currency', true ) ); | ||
| 201 | $this->set_discount_total( get_post_meta( $this->get_id(), '_cart_discount', true ) ); | ||
| 202 | $this->set_discount_tax( get_post_meta( $this->get_id(), '_cart_discount_tax', true ) ); | ||
| 203 | $this->set_shipping_total( get_post_meta( $this->get_id(), '_order_shipping', true ) ); | ||
| 204 | $this->set_shipping_tax( get_post_meta( $this->get_id(), '_order_shipping_tax', true ) ); | ||
| 205 | $this->set_cart_tax( get_post_meta( $this->get_id(), '_order_tax', true ) ); | ||
| 206 | $this->set_total( get_post_meta( $this->get_id(), '_order_total', true ) ); | ||
| 207 | $this->set_version( get_post_meta( $this->get_id(), '_order_version', true ) ); | ||
| 208 | |||
| 209 | // Orders store the state of prices including tax when created. | ||
| 210 | $this->set_prices_include_tax( metadata_exists( 'post', $this->get_id(), '_prices_include_tax' ) ? 'yes' === get_post_meta( $this->get_id(), '_prices_include_tax', true ) : 'yes' === get_option( 'woocommerce_prices_include_tax' ) ); | ||
| 211 | |||
| 212 | // Load meta data | ||
| 213 | $this->read_meta_data(); | ||
| 214 | } | ||
| 215 | |||
| 216 | /** | ||
| 217 | * Post meta update wrapper. Sets or deletes based on value. | ||
| 218 | * @since 2.7.0 | ||
| 219 | * @return bool Was it changed? | ||
| 220 | */ | ||
| 221 | 	protected function update_post_meta( $key, $value ) { | ||
| 228 | |||
| 229 | /** | ||
| 230 | * Update data in the database. | ||
| 231 | * @since 2.7.0 | ||
| 232 | */ | ||
| 233 | 	public function update() { | ||
| 263 | |||
| 264 | /** | ||
| 265 | * Delete data from the database. | ||
| 266 | * @since 2.7.0 | ||
| 267 | */ | ||
| 268 | 	public function delete() { | ||
| 271 | |||
| 272 | /** | ||
| 273 | * Save data to the database. | ||
| 274 | * @since 2.7.0 | ||
| 275 | * @return int order ID | ||
| 276 | */ | ||
| 277 | 	public function save() { | ||
| 292 | |||
| 293 | /** | ||
| 294 | * Save all order items which are part of this order. | ||
| 295 | */ | ||
| 296 | 	protected function save_items() { | ||
| 339 | |||
| 340 | /* | ||
| 341 | |-------------------------------------------------------------------------- | ||
| 342 | | Getters | ||
| 343 | |-------------------------------------------------------------------------- | ||
| 344 | | | ||
| 345 | | Methods for getting data from the order object. | ||
| 346 | | | ||
| 347 | */ | ||
| 348 | |||
| 349 | /** | ||
| 350 | * Get all class data in array format. | ||
| 351 | * @since 2.7.0 | ||
| 352 | * @return array | ||
| 353 | */ | ||
| 354 | View Code Duplication | 	public function get_data() { | |
| 367 | |||
| 368 | /** | ||
| 369 | * Get order ID. | ||
| 370 | * @since 2.7.0 | ||
| 371 | * @return integer | ||
| 372 | */ | ||
| 373 | 	public function get_id() { | ||
| 376 | |||
| 377 | /** | ||
| 378 | * Get parent order ID. | ||
| 379 | * @since 2.7.0 | ||
| 380 | * @return integer | ||
| 381 | */ | ||
| 382 | 	public function get_parent_id() { | ||
| 385 | |||
| 386 | /** | ||
| 387 | * Gets order currency. | ||
| 388 | * @return string | ||
| 389 | */ | ||
| 390 | 	public function get_currency() { | ||
| 393 | |||
| 394 | /** | ||
| 395 | * Get order_version | ||
| 396 | * @return string | ||
| 397 | */ | ||
| 398 | 	public function get_version() { | ||
| 401 | |||
| 402 | /** | ||
| 403 | * Get prices_include_tax | ||
| 404 | * @return bool | ||
| 405 | */ | ||
| 406 | 	public function get_prices_include_tax() { | ||
| 409 | |||
| 410 | /** | ||
| 411 | * Get date_created | ||
| 412 | * @return int | ||
| 413 | */ | ||
| 414 | 	public function get_date_created() { | ||
| 417 | |||
| 418 | /** | ||
| 419 | * Get date_modified | ||
| 420 | * @return int | ||
| 421 | */ | ||
| 422 | 	public function get_date_modified() { | ||
| 425 | |||
| 426 | /** | ||
| 427 | * Return the order statuses without wc- internal prefix. | ||
| 428 | * @return string | ||
| 429 | */ | ||
| 430 | 	public function get_status() { | ||
| 433 | |||
| 434 | /** | ||
| 435 | * Get discount_total | ||
| 436 | * @param bool $raw Gets raw unfiltered value. | ||
| 437 | * @return string | ||
| 438 | */ | ||
| 439 | 	public function get_discount_total( $raw = false ) { | ||
| 443 | |||
| 444 | /** | ||
| 445 | * Get discount_tax | ||
| 446 | * @param bool $raw Gets raw unfiltered value. | ||
| 447 | * @return string | ||
| 448 | */ | ||
| 449 | 	public function get_discount_tax( $raw = false ) { | ||
| 453 | |||
| 454 | /** | ||
| 455 | * Get shipping_total | ||
| 456 | * @param bool $raw Gets raw unfiltered value. | ||
| 457 | * @return string | ||
| 458 | */ | ||
| 459 | 	public function get_shipping_total( $raw = false ) { | ||
| 463 | |||
| 464 | /** | ||
| 465 | * Get shipping_tax. | ||
| 466 | * @param bool $raw Gets raw unfiltered value. | ||
| 467 | * @return string | ||
| 468 | */ | ||
| 469 | 	public function get_shipping_tax( $raw = false ) { | ||
| 473 | |||
| 474 | /** | ||
| 475 | * Gets cart tax amount. | ||
| 476 | * @param bool $raw Gets raw unfiltered value. | ||
| 477 | * @return float | ||
| 478 | */ | ||
| 479 | 	public function get_cart_tax( $raw = false ) { | ||
| 483 | |||
| 484 | /** | ||
| 485 | * Gets order grand total. incl. taxes. Used in gateways. Filtered. | ||
| 486 | * @param bool $raw Gets raw unfiltered value. | ||
| 487 | * @return float | ||
| 488 | */ | ||
| 489 | 	public function get_total( $raw = false ) { | ||
| 493 | |||
| 494 | /** | ||
| 495 | * Get total tax amount. Alias for get_order_tax(). | ||
| 496 | * | ||
| 497 | * @since 2.7.0 woocommerce_order_amount_total_tax filter has been removed to avoid | ||
| 498 | * these values being modified and then saved back to the DB. There are | ||
| 499 | * other, later hooks available to change totals on display. e.g. | ||
| 500 | * woocommerce_get_order_item_totals. | ||
| 501 | * @param bool $raw Gets raw unfiltered value. | ||
| 502 | * @return float | ||
| 503 | */ | ||
| 504 | 	public function get_total_tax( $raw = false ) { | ||
| 508 | |||
| 509 | /** | ||
| 510 | * Gets the total discount amount. | ||
| 511 | * @param bool $ex_tax Show discount excl any tax. | ||
| 512 | * @return float | ||
| 513 | */ | ||
| 514 | 	public function get_total_discount( $ex_tax = true ) { | ||
| 522 | |||
| 523 | /** | ||
| 524 | * Gets order subtotal. | ||
| 525 | * @return float | ||
| 526 | */ | ||
| 527 | 	public function get_subtotal() { | ||
| 536 | |||
| 537 | /** | ||
| 538 | * Get taxes, merged by code, formatted ready for output. | ||
| 539 | * | ||
| 540 | * @return array | ||
| 541 | */ | ||
| 542 | 	public function get_tax_totals() { | ||
| 568 | |||
| 569 | /* | ||
| 570 | |-------------------------------------------------------------------------- | ||
| 571 | | Setters | ||
| 572 | |-------------------------------------------------------------------------- | ||
| 573 | | | ||
| 574 | | Functions for setting order data. These should not update anything in the | ||
| 575 | | database itself and should only change what is stored in the class | ||
| 576 | | object. However, for backwards compatibility pre 2.7.0 some of these | ||
| 577 | | setters may handle both. | ||
| 578 | | | ||
| 579 | */ | ||
| 580 | |||
| 581 | /** | ||
| 582 | * Set order ID. | ||
| 583 | * @since 2.7.0 | ||
| 584 | * @param int $value | ||
| 585 | */ | ||
| 586 | 	public function set_id( $value ) { | ||
| 589 | |||
| 590 | /** | ||
| 591 | * Set parent order ID. | ||
| 592 | * @since 2.7.0 | ||
| 593 | * @param int $value | ||
| 594 | */ | ||
| 595 | 	public function set_parent_id( $value ) { | ||
| 598 | |||
| 599 | /** | ||
| 600 | * Set order status. | ||
| 601 | * @since 2.7.0 | ||
| 602 | * @param string $new_status Status to change the order to. No internal wc- prefix is required. | ||
| 603 | * @param array details of change | ||
| 604 | */ | ||
| 605 | 	 public function set_status( $new_status ) { | ||
| 626 | |||
| 627 | /** | ||
| 628 | * Set order_version | ||
| 629 | * @param string $value | ||
| 630 | */ | ||
| 631 | 	public function set_version( $value ) { | ||
| 634 | |||
| 635 | /** | ||
| 636 | * Set order_currency | ||
| 637 | * @param string $value | ||
| 638 | */ | ||
| 639 | 	public function set_currency( $value ) { | ||
| 645 | |||
| 646 | /** | ||
| 647 | * Set prices_include_tax | ||
| 648 | * @param bool $value | ||
| 649 | */ | ||
| 650 | 	public function set_prices_include_tax( $value ) { | ||
| 653 | |||
| 654 | /** | ||
| 655 | * Set date_created | ||
| 656 | * @param string $timestamp Timestamp | ||
| 657 | */ | ||
| 658 | 	public function set_date_created( $timestamp ) { | ||
| 661 | |||
| 662 | /** | ||
| 663 | * Set date_modified | ||
| 664 | * @param string $timestamp | ||
| 665 | */ | ||
| 666 | 	public function set_date_modified( $timestamp ) { | ||
| 669 | |||
| 670 | /** | ||
| 671 | * Set discount_total | ||
| 672 | * @param string $value | ||
| 673 | */ | ||
| 674 | 	public function set_discount_total( $value ) { | ||
| 677 | |||
| 678 | /** | ||
| 679 | * Set discount_tax | ||
| 680 | * @param string $value | ||
| 681 | */ | ||
| 682 | 	public function set_discount_tax( $value ) { | ||
| 685 | |||
| 686 | /** | ||
| 687 | * Set shipping_total | ||
| 688 | * @param string $value | ||
| 689 | */ | ||
| 690 | 	public function set_shipping_total( $value ) { | ||
| 693 | |||
| 694 | /** | ||
| 695 | * Set shipping_tax | ||
| 696 | * @param string $value | ||
| 697 | */ | ||
| 698 | 	public function set_shipping_tax( $value ) { | ||
| 702 | |||
| 703 | /** | ||
| 704 | * Set cart tax | ||
| 705 | * @param string $value | ||
| 706 | */ | ||
| 707 | 	public function set_cart_tax( $value ) { | ||
| 711 | |||
| 712 | /** | ||
| 713 | * Sets order tax (sum of cart and shipping tax). Used internaly only. | ||
| 714 | * @param string $value | ||
| 715 | */ | ||
| 716 | 	protected function set_total_tax( $value ) { | ||
| 719 | |||
| 720 | /** | ||
| 721 | * Set total | ||
| 722 | * @param string $value | ||
| 723 | * @param string $deprecated Function used to set different totals based on this. | ||
| 724 | */ | ||
| 725 | 	public function set_total( $value, $deprecated = '' ) { | ||
| 732 | |||
| 733 | /* | ||
| 734 | |-------------------------------------------------------------------------- | ||
| 735 | | Order Item Handling | ||
| 736 | |-------------------------------------------------------------------------- | ||
| 737 | | | ||
| 738 | | Order items are used for products, taxes, shipping, and fees within | ||
| 739 | | each order. | ||
| 740 | | | ||
| 741 | */ | ||
| 742 | |||
| 743 | /** | ||
| 744 | * Remove all line items (products, coupons, shipping, taxes) from the order. | ||
| 745 | * @param string $type Order item type. Default null. | ||
| 746 | */ | ||
| 747 | 	public function remove_order_items( $type = null ) { | ||
| 767 | |||
| 768 | /** | ||
| 769 | * Convert a type to a types group. | ||
| 770 | * @param string $type | ||
| 771 | * @return string group | ||
| 772 | */ | ||
| 773 | 	protected function type_to_group( $type ) { | ||
| 783 | |||
| 784 | /** | ||
| 785 | * Return an array of items/products within this order. | ||
| 786 | * @param string|array $types Types of line items to get (array or string). | ||
| 787 | * @return Array of WC_Order_item | ||
| 788 | */ | ||
| 789 | 	public function get_items( $types = 'line_item' ) { | ||
| 805 | |||
| 806 | /** | ||
| 807 | * Gets items from the database by type. | ||
| 808 | * @param string $type | ||
| 809 | * @return array | ||
| 810 | */ | ||
| 811 | 	protected function get_items_from_db( $type ) { | ||
| 825 | |||
| 826 | /** | ||
| 827 | * Return an array of fees within this order. | ||
| 828 | * @return array | ||
| 829 | */ | ||
| 830 | 	public function get_fees() { | ||
| 833 | |||
| 834 | /** | ||
| 835 | * Return an array of taxes within this order. | ||
| 836 | * @return array | ||
| 837 | */ | ||
| 838 | 	public function get_taxes() { | ||
| 841 | |||
| 842 | /** | ||
| 843 | * Return an array of shipping costs within this order. | ||
| 844 | * @return array | ||
| 845 | */ | ||
| 846 | 	public function get_shipping_methods() { | ||
| 849 | |||
| 850 | /** | ||
| 851 | * Gets formatted shipping method title. | ||
| 852 | * @return string | ||
| 853 | */ | ||
| 854 | 	public function get_shipping_method() { | ||
| 861 | |||
| 862 | /** | ||
| 863 | * Get coupon codes only. | ||
| 864 | * @return array | ||
| 865 | */ | ||
| 866 | 	public function get_used_coupons() { | ||
| 875 | |||
| 876 | /** | ||
| 877 | * Gets the count of order items of a certain type. | ||
| 878 | * | ||
| 879 | * @param string $item_type | ||
| 880 | * @return string | ||
| 881 | */ | ||
| 882 | 	public function get_item_count( $item_type = '' ) { | ||
| 892 | |||
| 893 | /** | ||
| 894 | * Get an order item object, based on it's type. | ||
| 895 | * @since 2.7.0 | ||
| 896 | * @param int $item_id | ||
| 897 | * @return WC_Order_Item | ||
| 898 | */ | ||
| 899 | 	public function get_item( $item_id ) { | ||
| 902 | |||
| 903 | /** | ||
| 904 | * Get key for where a certain item type is stored in _items. | ||
| 905 | * @since 2.7.0 | ||
| 906 | * @param $item object Order item (product, shipping, fee, coupon, tax) | ||
| 907 | * @return string | ||
| 908 | */ | ||
| 909 | 	protected function get_items_key( $item ) { | ||
| 924 | |||
| 925 | /** | ||
| 926 | * Remove item from the order. | ||
| 927 | * @param int $item_id | ||
| 928 | */ | ||
| 929 | 	public function remove_item( $item_id ) { | ||
| 940 | |||
| 941 | /** | ||
| 942 | * Adds an order item to this order. The order item will not persist until save. | ||
| 943 | * @param object Order item (product, shipping, fee, coupon, tax) | ||
| 944 | */ | ||
| 945 | 	public function add_item( $item ) { | ||
| 962 | |||
| 963 | /** | ||
| 964 | * Add a product line item to the order. | ||
| 965 | * @param \WC_Product $product | ||
| 966 | * @param int $qty | ||
| 967 | * @param array $args | ||
| 968 | * @return int order item ID | ||
| 969 | */ | ||
| 970 | 	public function add_product( $product, $qty = 1, $args = array() ) { | ||
| 1009 | |||
| 1010 | /** | ||
| 1011 | * Add coupon code to the order. | ||
| 1012 | * @param string $code | ||
| 1013 | * @param int $discount tax amount. | ||
| 1014 | * @param int $discount_tax amount. | ||
| 1015 | * @return int order item ID | ||
| 1016 | */ | ||
| 1017 | 	public function add_coupon( $code = array(), $discount = 0, $discount_tax = 0 ) { | ||
| 1029 | |||
| 1030 | /** | ||
| 1031 | * Add a tax row to the order. | ||
| 1032 | * @param array $args | ||
| 1033 | * @param int $deprecated1 2.7.0 tax_rate_id, amount, shipping amount. | ||
| 1034 | * @param int $deprecated2 2.7.0 tax_rate_id, amount, shipping amount. | ||
| 1035 | * @return int order item ID | ||
| 1036 | */ | ||
| 1037 | 	public function add_tax( $args = array(), $deprecated1 = 0, $deprecated2 = 0 ) { | ||
| 1061 | |||
| 1062 | /** | ||
| 1063 | * Add a shipping row to the order. | ||
| 1064 | * @param WC_Shipping_Rate shipping_rate | ||
| 1065 | * @return int order item ID | ||
| 1066 | */ | ||
| 1067 | 	public function add_shipping( $shipping_rate ) { | ||
| 1081 | |||
| 1082 | /** | ||
| 1083 | * Add a fee to the order. | ||
| 1084 | * Order must be saved prior to adding items. | ||
| 1085 | * @param object $fee | ||
| 1086 | * @return int updated order item ID | ||
| 1087 | */ | ||
| 1088 | 	public function add_fee( $fee ) { | ||
| 1104 | |||
| 1105 | /* | ||
| 1106 | |-------------------------------------------------------------------------- | ||
| 1107 | | Payment Token Handling | ||
| 1108 | |-------------------------------------------------------------------------- | ||
| 1109 | | | ||
| 1110 | | Payment tokens are hashes used to take payments by certain gateways. | ||
| 1111 | | | ||
| 1112 | */ | ||
| 1113 | |||
| 1114 | /** | ||
| 1115 | * Add a payment token to an order | ||
| 1116 | * | ||
| 1117 | * @since 2.6 | ||
| 1118 | * @param WC_Payment_Token $token Payment token object | ||
| 1119 | * @return boolean|int The new token ID or false if it failed. | ||
| 1120 | */ | ||
| 1121 | 	public function add_payment_token( $token ) { | ||
| 1138 | |||
| 1139 | /** | ||
| 1140 | * Returns a list of all payment tokens associated with the current order | ||
| 1141 | * | ||
| 1142 | * @since 2.6 | ||
| 1143 | * @return array An array of payment token objects | ||
| 1144 | */ | ||
| 1145 | 	public function get_payment_tokens() { | ||
| 1148 | |||
| 1149 | /* | ||
| 1150 | |-------------------------------------------------------------------------- | ||
| 1151 | | Calculations. | ||
| 1152 | |-------------------------------------------------------------------------- | ||
| 1153 | | | ||
| 1154 | | These methods calculate order totals and taxes based on the current data. | ||
| 1155 | | | ||
| 1156 | */ | ||
| 1157 | |||
| 1158 | /** | ||
| 1159 | * Calculate shipping total. | ||
| 1160 | * | ||
| 1161 | * @since 2.2 | ||
| 1162 | * @return float | ||
| 1163 | */ | ||
| 1164 | 	public function calculate_shipping() { | ||
| 1176 | |||
| 1177 | /** | ||
| 1178 | * Get all tax classes for items in the order. | ||
| 1179 | * | ||
| 1180 | * @since 2.6.3 | ||
| 1181 | * @return array | ||
| 1182 | */ | ||
| 1183 | 	public function get_items_tax_classes() { | ||
| 1194 | |||
| 1195 | /** | ||
| 1196 | * Calculate taxes for all line items and shipping, and store the totals and tax rows. | ||
| 1197 | * | ||
| 1198 | * Will use the base country unless customer addresses are set. | ||
| 1199 | * @param $args array Added in 2.7.0 to pass things like location. | ||
| 1200 | */ | ||
| 1201 | 	public function calculate_taxes( $args = array() ) { | ||
| 1286 | |||
| 1287 | /** | ||
| 1288 | * Update tax lines for the order based on the line item taxes themselves. | ||
| 1289 | */ | ||
| 1290 | 	public function update_taxes() { | ||
| 1325 | |||
| 1326 | /** | ||
| 1327 | * Calculate totals by looking at the contents of the order. Stores the totals and returns the orders final total. | ||
| 1328 | * | ||
| 1329 | * @since 2.2 | ||
| 1330 | * @param bool $and_taxes Calc taxes if true. | ||
| 1331 | * @return float calculated grand total. | ||
| 1332 | */ | ||
| 1333 | 	public function calculate_totals( $and_taxes = true ) { | ||
| 1367 | |||
| 1368 | /** | ||
| 1369 | * Get item subtotal - this is the cost before discount. | ||
| 1370 | * | ||
| 1371 | * @param object $item | ||
| 1372 | * @param bool $inc_tax (default: false). | ||
| 1373 | * @param bool $round (default: true). | ||
| 1374 | * @return float | ||
| 1375 | */ | ||
| 1376 | View Code Duplication | 	public function get_item_subtotal( $item, $inc_tax = false, $round = true ) { | |
| 1391 | |||
| 1392 | /** | ||
| 1393 | * Get line subtotal - this is the cost before discount. | ||
| 1394 | * | ||
| 1395 | * @param object $item | ||
| 1396 | * @param bool $inc_tax (default: false). | ||
| 1397 | * @param bool $round (default: true). | ||
| 1398 | * @return float | ||
| 1399 | */ | ||
| 1400 | View Code Duplication | 	public function get_line_subtotal( $item, $inc_tax = false, $round = true ) { | |
| 1415 | |||
| 1416 | /** | ||
| 1417 | * Calculate item cost - useful for gateways. | ||
| 1418 | * | ||
| 1419 | * @param object $item | ||
| 1420 | * @param bool $inc_tax (default: false). | ||
| 1421 | * @param bool $round (default: true). | ||
| 1422 | * @return float | ||
| 1423 | */ | ||
| 1424 | View Code Duplication | 	public function get_item_total( $item, $inc_tax = false, $round = true ) { | |
| 1439 | |||
| 1440 | /** | ||
| 1441 | * Calculate line total - useful for gateways. | ||
| 1442 | * | ||
| 1443 | * @param object $item | ||
| 1444 | * @param bool $inc_tax (default: false). | ||
| 1445 | * @param bool $round (default: true). | ||
| 1446 | * @return float | ||
| 1447 | */ | ||
| 1448 | View Code Duplication | 	public function get_line_total( $item, $inc_tax = false, $round = true ) { | |
| 1461 | |||
| 1462 | /** | ||
| 1463 | * Get item tax - useful for gateways. | ||
| 1464 | * | ||
| 1465 | * @param mixed $item | ||
| 1466 | * @param bool $round (default: true). | ||
| 1467 | * @return float | ||
| 1468 | */ | ||
| 1469 | 	public function get_item_tax( $item, $round = true ) { | ||
| 1479 | |||
| 1480 | /** | ||
| 1481 | * Get line tax - useful for gateways. | ||
| 1482 | * | ||
| 1483 | * @param mixed $item | ||
| 1484 | * @return float | ||
| 1485 | */ | ||
| 1486 | 	public function get_line_tax( $item ) { | ||
| 1489 | |||
| 1490 | /** | ||
| 1491 | * Gets line subtotal - formatted for display. | ||
| 1492 | * | ||
| 1493 | * @param array $item | ||
| 1494 | * @param string $tax_display | ||
| 1495 | * @return string | ||
| 1496 | */ | ||
| 1497 | 	public function get_formatted_line_subtotal( $item, $tax_display = '' ) { | ||
| 1510 | |||
| 1511 | /** | ||
| 1512 | * Gets order total - formatted for display. | ||
| 1513 | * @return string | ||
| 1514 | */ | ||
| 1515 | 	public function get_formatted_order_total() { | ||
| 1519 | |||
| 1520 | /** | ||
| 1521 | * Gets subtotal - subtotal is shown before discounts, but with localised taxes. | ||
| 1522 | * | ||
| 1523 | * @param bool $compound (default: false). | ||
| 1524 | * @param string $tax_display (default: the tax_display_cart value). | ||
| 1525 | * @return string | ||
| 1526 | */ | ||
| 1527 | 	public function get_subtotal_to_display( $compound = false, $tax_display = '' ) { | ||
| 1573 | |||
| 1574 | /** | ||
| 1575 | * Gets shipping (formatted). | ||
| 1576 | * | ||
| 1577 | * @return string | ||
| 1578 | */ | ||
| 1579 | 	public function get_shipping_to_display( $tax_display = '' ) { | ||
| 1614 | |||
| 1615 | /** | ||
| 1616 | * Get the discount amount (formatted). | ||
| 1617 | * @since 2.3.0 | ||
| 1618 | * @return string | ||
| 1619 | */ | ||
| 1620 | 	public function get_discount_to_display( $tax_display = '' ) { | ||
| 1624 | |||
| 1625 | /** | ||
| 1626 | * Get totals for display on pages and in emails. | ||
| 1627 | * | ||
| 1628 | * @param mixed $tax_display | ||
| 1629 | * @return array | ||
| 1630 | */ | ||
| 1631 | 	public function get_order_item_totals( $tax_display = '' ) { | ||
| 1713 | |||
| 1714 | /* | ||
| 1715 | |-------------------------------------------------------------------------- | ||
| 1716 | | Conditionals | ||
| 1717 | |-------------------------------------------------------------------------- | ||
| 1718 | | | ||
| 1719 | | Checks if a condition is true or false. | ||
| 1720 | | | ||
| 1721 | */ | ||
| 1722 | |||
| 1723 | /** | ||
| 1724 | * Checks the order status against a passed in status. | ||
| 1725 | * | ||
| 1726 | * @return bool | ||
| 1727 | */ | ||
| 1728 | 	public function has_status( $status ) { | ||
| 1731 | |||
| 1732 | /** | ||
| 1733 | * Check whether this order has a specific shipping method or not. | ||
| 1734 | * | ||
| 1735 | * @param string $method_id | ||
| 1736 | * @return bool | ||
| 1737 | */ | ||
| 1738 | 	public function has_shipping_method( $method_id ) { | ||
| 1746 | |||
| 1747 | /** | ||
| 1748 | * Returns true if the order contains a free product. | ||
| 1749 | * @since 2.5.0 | ||
| 1750 | * @return bool | ||
| 1751 | */ | ||
| 1752 | 	public function has_free_item() { | ||
| 1760 | } | ||
| 1761 | 
Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.
You can also find more detailed suggestions in the “Code” section of your repository.