# The Revenue class is an account type used to represents increases in owners equity. # # === Normal Balance # The normal balance on Revenue accounts is a *Credit*. # # @see http://en.wikipedia.org/wiki/Revenue Revenue # # @author Michael Bulat class Revenue < Account # The credit balance for the account. # # @example # >> revenue.credits_balance # => # # # @return [BigDecimal] The decimal value credit balance def credits_balance credits_balance = BigDecimal.new('0') credit_transactions.each do |credit_transaction| credits_balance = credits_balance + credit_transaction.amount end return credits_balance end # The debit balance for the account. # # @example # >> revenue.debits_balance # => # # # @return [BigDecimal] The decimal value credit balance def debits_balance debits_balance = BigDecimal.new('0') debit_transactions.each do |debit_transaction| debits_balance = debits_balance + debit_transaction.amount end return debits_balance end # The balance of the account. # # Revenue accounts have normal credit balances, so the debits are subtracted from the credits # unless this is a contra account, in which credits are subtracted from debits # # @example # >> asset.balance # => # # # @return [BigDecimal] The decimal value balance def balance unless contra credits_balance - debits_balance else debits_balance - credits_balance end end # This class method is used to return # the balance of all Revenue accounts. # # Contra accounts are automatically subtracted from the balance. # # @example # >> Revenue.balance # => # # # @return [BigDecimal] The decimal value balance def self.balance accounts_balance = BigDecimal.new('0') accounts = self.find(:all) accounts.each do |revenue| unless revenue.contra accounts_balance += revenue.balance else accounts_balance -= revenue.balance end end accounts_balance end end