From d359e1d6203728783c97ed1313e62088dd44f386 Mon Sep 17 00:00:00 2001 From: Joris Date: Fri, 21 Apr 2017 17:31:50 +0200 Subject: Sort table by clicking on the header --- src/Order.purs | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) create mode 100644 src/Order.purs (limited to 'src/Order.purs') diff --git a/src/Order.purs b/src/Order.purs new file mode 100644 index 0000000..33c2be9 --- /dev/null +++ b/src/Order.purs @@ -0,0 +1,54 @@ +module Order + ( Order + , OrderKind(..) + , OrderDirection(..) + , init + , select + ) where + +import Prelude (class Eq, (==)) +import Data.Generic (class Generic, gEq) + +type Order = + { kind :: OrderKind + , direction :: OrderDirection + } + +data OrderKind = + Name + | GlycemicIndex + | Carbohydrates + | GlycemicLoad + +derive instance genericOrderKind :: Generic OrderKind + +instance eqOrderKind :: Eq OrderKind where + eq = gEq + +data OrderDirection = + Ascending + | Descending + +derive instance genericOrderDirection :: Generic OrderDirection + +instance eqOrderDirection :: Eq OrderDirection where + eq = gEq + +init :: Order +init = + { kind: Name + , direction: initDirection + } + +select :: OrderKind -> Order -> Order +select kind order = + if order.kind == kind + then order { direction = otherDirection order.direction } + else order { kind = kind, direction = initDirection } + +otherDirection :: OrderDirection -> OrderDirection +otherDirection Ascending = Descending +otherDirection Descending = Ascending + +initDirection :: OrderDirection +initDirection = Ascending -- cgit v1.2.3