Freeside:4:Documentation:Developer/FS/discount plan
From Freeside
Contents
NAME
FS::discount_plan - A term discount as applied to an invoice
DESCRIPTION
An FS::discount_plan object represents a term prepayment discount available for an invoice (FS::cust_bill). FS::discount_plan objects are non-persistent and do not inherit from FS::Record.
CLASS METHODS
- new OPTIONS
- Calculate a discount plan. OPTIONS must include:
- cust_bill - the invoice to calculate discounts for
- months - the number of months to be prepaid
- If there are no line items on the invoice eligible for the discount new() will return undef.
- all CUST_BILL
- For an FS::cust_bill object, return a hash of all available discount plans, with discount term (months) as the key.
METHODS
- discounted_total
- Returns the total price for the term after applying discounts. This is the price the customer would have to pay to receive the discount. Note that this includes the monthly fees for all packages (including non-discountable ones) for each month in the term, but only includes fees for other packages as they appear on the current invoice.
- base_total
- Returns the total price for the term before applying discounts.
- pkgnums
- Returns a list of package numbers that are receiving discounts under this plan.
- list_pkgnums
- Returns a true value if any packages listed on the invoice do not receive a discount, either because there isn't one at the specified term length or because they're not monthly recurring packages.