I have data types:
import cats.Monoid
import cats.implicits._
object Domain {
case class Money(amount: Double) extends AnyVal {}
implicit val moneyMonoid = new Monoid[Money] {
override def combine(a: Money, b: Money): Money = Money(a.amount + b.amount)
override def empty: Money = Money(0)
}
case class Operation(account: Account, amount: Money) extends AnyRef
type Operations = List[Operation]
}
I want to implement totalAmountCalculation
like function composition
val calcTotalAmount = map(x => x.amount) >>> combineAll
For this I wrote some code:
def map[A, B](F: A => B): List[A] => List[B] = (m: List[A]) => m.map(F)
val combineAll = moneyMonoid.combineAll _
val calcTotalAmount = map[Operation, Money](x => x.amount) >>> combineAll
What cats features I can use for avoid write Monad wrapper for use it in functions composition ?
I want to see my code like:
map(x => x + 1) >>>
filter(x < 100) >>>
fold(1)((a,b) => a+b))