Initial Commit

This commit is contained in:
David Stone
2024-11-30 18:24:12 -07:00
commit e8f7955c1c
5432 changed files with 1397750 additions and 0 deletions

View File

@ -0,0 +1,118 @@
<?php
/**
* Discount Code Functions
*
* @package WP_Ultimo\Functions
* @since 2.0.0
*/
// Exit if accessed directly
defined('ABSPATH') || exit;
use \WP_Ultimo\Models\Discount_Code;
/**
* Returns a discount code object searching by the code.
*
* @since 2.0.0
*
* @param string $coupon_code Coupon code to search.
* @return \WP_Ultimo\Models\Discount_Code|false
*/
function wu_get_discount_code_by_code($coupon_code) {
return \WP_Ultimo\Models\Discount_Code::get_by('code', $coupon_code);
} // end wu_get_discount_code_by_code;
/**
* Gets a discount code based on the ID.
*
* @since 2.0.0
*
* @param integer $discount_code_id ID of the discount code to retrieve.
* @return \WP_Ultimo\Models\Discount_Code|false
*/
function wu_get_discount_code($discount_code_id) {
return \WP_Ultimo\Models\Discount_Code::get_by_id($discount_code_id);
} // end wu_get_discount_code;
/**
* Queries discount codes.
*
* @since 2.0.0
*
* @param array $query Query arguments.
* @return \WP_Ultimo\Models\Discount_Code[]
*/
function wu_get_discount_codes($query = array()) {
return \WP_Ultimo\Models\Discount_Code::query($query);
} // end wu_get_discount_codes;
/**
* Calculates the discounted price after running it through the discount code.
*
* @since 2.0.0
*
* @param float $base_price Original price of the product.
* @param float $amount Discount amount.
* @param string $type Type of the discount, can be percentage or absolute.
* @param boolean $format If we should format the results or not.
* @return float|string
*/
function wu_get_discounted_price($base_price, $amount, $type, $format = true) {
if ($type === 'percentage') {
$discounted_price = $base_price - ($base_price * ($amount / 100));
} elseif ($type === 'absolute') {
$discounted_price = $base_price - $amount;
} // end if;
if (!$format) {
return $discounted_price;
} // end if;
return number_format((float) $discounted_price, 2);
} // end wu_get_discounted_price;
/**
* Creates a new discount code.
*
* Check the wp_parse_args below to see what parameters are necessary.
*
* @since 2.0.0
*
* @param array $discount_code_data Discount code attributes.
* @return \WP_Error|\WP_Ultimo\Models\Discount_Code
*/
function wu_create_discount_code($discount_code_data) {
$discount_code_data = wp_parse_args($discount_code_data, array(
'max_uses' => true,
'name' => false,
'code' => false,
'value' => false,
'setup_fee_value' => false,
'start_date' => false,
'active' => true,
'expiration_date' => false,
'date_created' => wu_get_current_time('mysql', true),
'date_modified' => wu_get_current_time('mysql', true),
'skip_validation' => false,
));
$discount_code = new Discount_Code($discount_code_data);
$saved = $discount_code->save();
return is_wp_error($saved) ? $saved : $discount_code;
} // end wu_create_discount_code;