-
Notifications
You must be signed in to change notification settings - Fork 53
Expand file tree
/
Copy pathAccount.scala
More file actions
71 lines (56 loc) · 1.6 KB
/
Account.scala
File metadata and controls
71 lines (56 loc) · 1.6 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
package com.abc
import com.abc.AccountTypes._
sealed trait Account {
protected val transactions = new Transactions
def deposit(amount: Double) {
checkPositive(amount)
transactions += Transaction(amount)
}
def withdraw(amount: Double) {
checkPositive(amount)
transactions += Transaction(-amount)
}
private def checkPositive(amount : Double) =
assert(amount > 0, "amount must be greater than zero")
def sumTransactions : Double =
transactions.sum
def interestEarned: Double
def getStatement: String
}
class CheckingAccount extends Account {
override def interestEarned: Double =
sumTransactions * 0.001
override def getStatement: String =
"Checking Account\n" + transactions.getSummary
}
class SavingsAccount extends Account {
override def interestEarned: Double = {
val amount = sumTransactions
if (amount <= 1000)
amount * 0.001
else
1 + (amount - 1000) * 0.002
}
override def getStatement: String =
"Savings Account\n" + transactions.getSummary
}
class MaxiSavingsAccount extends Account {
override def interestEarned: Double = {
val amount = sumTransactions
if (amount <= 1000)
amount * 0.02
else if (amount <= 2000)
20 + (amount - 1000) * 0.05
else
70 + (amount - 2000) * 0.1
}
override def getStatement: String =
"Maxi Savings Account\n" + transactions.getSummary
}
object Account {
def apply(accountType : AccountType) : Account = accountType match {
case Checking => new CheckingAccount
case Savings => new SavingsAccount
case MaxiSavings => new MaxiSavingsAccount
}
}