canonicalize API type before generating jquery functions, flattening everything on the way
This commit is contained in:
parent
84f8f814c7
commit
ad0c6521ed
3 changed files with 24 additions and 20 deletions
|
@ -1,5 +1,6 @@
|
||||||
{-# LANGUAGE DataKinds #-}
|
{-# LANGUAGE DataKinds #-}
|
||||||
{-# LANGUAGE TypeOperators #-}
|
{-# LANGUAGE TypeOperators #-}
|
||||||
|
{-# LANGUAGE FlexibleContexts #-}
|
||||||
{-# LANGUAGE FlexibleInstances #-}
|
{-# LANGUAGE FlexibleInstances #-}
|
||||||
-----------------------------------------------------------------------------
|
-----------------------------------------------------------------------------
|
||||||
-- |
|
-- |
|
||||||
|
@ -20,10 +21,11 @@ import Control.Lens
|
||||||
import Data.List
|
import Data.List
|
||||||
import Data.Monoid
|
import Data.Monoid
|
||||||
import Data.Proxy
|
import Data.Proxy
|
||||||
|
import Servant.API
|
||||||
import Servant.JQuery.Internal
|
import Servant.JQuery.Internal
|
||||||
|
|
||||||
jquery :: HasJQ layout => Proxy layout -> JQ layout
|
jquery :: HasJQ (Canonicalize layout) => Proxy layout -> JQ layout
|
||||||
jquery p = jqueryFor p defReq
|
jquery p = jqueryFor (canonicalize p) defReq
|
||||||
|
|
||||||
-- js codegen
|
-- js codegen
|
||||||
generateJS :: AjaxReq -> String
|
generateJS :: AjaxReq -> String
|
||||||
|
|
|
@ -167,12 +167,14 @@ type family Elem (a :: *) (ls::[*]) :: Constraint where
|
||||||
Elem a (b ': list) = Elem a list
|
Elem a (b ': list) = Elem a list
|
||||||
|
|
||||||
class HasJQ (layout :: *) where
|
class HasJQ (layout :: *) where
|
||||||
type JQ layout :: *
|
type JQ' layout :: *
|
||||||
jqueryFor :: Proxy layout -> AjaxReq -> JQ layout
|
jqueryFor :: Proxy layout -> AjaxReq -> JQ' layout
|
||||||
|
|
||||||
|
type JQ layout = JQ' (Canonicalize layout)
|
||||||
|
|
||||||
instance (HasJQ a, HasJQ b)
|
instance (HasJQ a, HasJQ b)
|
||||||
=> HasJQ (a :<|> b) where
|
=> HasJQ (a :<|> b) where
|
||||||
type JQ (a :<|> b) = JQ a :<|> JQ b
|
type JQ' (a :<|> b) = JQ' a :<|> JQ' b
|
||||||
|
|
||||||
jqueryFor Proxy req =
|
jqueryFor Proxy req =
|
||||||
jqueryFor (Proxy :: Proxy a) req
|
jqueryFor (Proxy :: Proxy a) req
|
||||||
|
@ -180,7 +182,7 @@ instance (HasJQ a, HasJQ b)
|
||||||
|
|
||||||
instance (KnownSymbol sym, HasJQ sublayout)
|
instance (KnownSymbol sym, HasJQ sublayout)
|
||||||
=> HasJQ (Capture sym a :> sublayout) where
|
=> HasJQ (Capture sym a :> sublayout) where
|
||||||
type JQ (Capture sym a :> sublayout) = JQ sublayout
|
type JQ' (Capture sym a :> sublayout) = JQ' sublayout
|
||||||
|
|
||||||
jqueryFor Proxy req =
|
jqueryFor Proxy req =
|
||||||
jqueryFor (Proxy :: Proxy sublayout) $
|
jqueryFor (Proxy :: Proxy sublayout) $
|
||||||
|
@ -189,14 +191,14 @@ instance (KnownSymbol sym, HasJQ sublayout)
|
||||||
where str = symbolVal (Proxy :: Proxy sym)
|
where str = symbolVal (Proxy :: Proxy sym)
|
||||||
|
|
||||||
instance HasJQ Delete where
|
instance HasJQ Delete where
|
||||||
type JQ Delete = AjaxReq
|
type JQ' Delete = AjaxReq
|
||||||
|
|
||||||
jqueryFor Proxy req =
|
jqueryFor Proxy req =
|
||||||
req & funcName %~ ("delete" <>)
|
req & funcName %~ ("delete" <>)
|
||||||
& reqMethod .~ "DELETE"
|
& reqMethod .~ "DELETE"
|
||||||
|
|
||||||
instance Elem JSON list => HasJQ (Get list a) where
|
instance Elem JSON list => HasJQ (Get list a) where
|
||||||
type JQ (Get list a) = AjaxReq
|
type JQ' (Get list a) = AjaxReq
|
||||||
|
|
||||||
jqueryFor Proxy req =
|
jqueryFor Proxy req =
|
||||||
req & funcName %~ ("get" <>)
|
req & funcName %~ ("get" <>)
|
||||||
|
@ -204,7 +206,7 @@ instance Elem JSON list => HasJQ (Get list a) where
|
||||||
|
|
||||||
instance (KnownSymbol sym, HasJQ sublayout)
|
instance (KnownSymbol sym, HasJQ sublayout)
|
||||||
=> HasJQ (Header sym a :> sublayout) where
|
=> HasJQ (Header sym a :> sublayout) where
|
||||||
type JQ (Header sym a :> sublayout) = JQ sublayout
|
type JQ' (Header sym a :> sublayout) = JQ' sublayout
|
||||||
|
|
||||||
jqueryFor Proxy req =
|
jqueryFor Proxy req =
|
||||||
jqueryFor subP (req & reqHeaders <>~ [HeaderArg hname])
|
jqueryFor subP (req & reqHeaders <>~ [HeaderArg hname])
|
||||||
|
@ -213,14 +215,14 @@ instance (KnownSymbol sym, HasJQ sublayout)
|
||||||
subP = Proxy :: Proxy sublayout
|
subP = Proxy :: Proxy sublayout
|
||||||
|
|
||||||
instance Elem JSON list => HasJQ (Post list a) where
|
instance Elem JSON list => HasJQ (Post list a) where
|
||||||
type JQ (Post list a) = AjaxReq
|
type JQ' (Post list a) = AjaxReq
|
||||||
|
|
||||||
jqueryFor Proxy req =
|
jqueryFor Proxy req =
|
||||||
req & funcName %~ ("post" <>)
|
req & funcName %~ ("post" <>)
|
||||||
& reqMethod .~ "POST"
|
& reqMethod .~ "POST"
|
||||||
|
|
||||||
instance Elem JSON list => HasJQ (Put list a) where
|
instance Elem JSON list => HasJQ (Put list a) where
|
||||||
type JQ (Put list a) = AjaxReq
|
type JQ' (Put list a) = AjaxReq
|
||||||
|
|
||||||
jqueryFor Proxy req =
|
jqueryFor Proxy req =
|
||||||
req & funcName %~ ("put" <>)
|
req & funcName %~ ("put" <>)
|
||||||
|
@ -228,7 +230,7 @@ instance Elem JSON list => HasJQ (Put list a) where
|
||||||
|
|
||||||
instance (KnownSymbol sym, HasJQ sublayout)
|
instance (KnownSymbol sym, HasJQ sublayout)
|
||||||
=> HasJQ (QueryParam sym a :> sublayout) where
|
=> HasJQ (QueryParam sym a :> sublayout) where
|
||||||
type JQ (QueryParam sym a :> sublayout) = JQ sublayout
|
type JQ' (QueryParam sym a :> sublayout) = JQ' sublayout
|
||||||
|
|
||||||
jqueryFor Proxy req =
|
jqueryFor Proxy req =
|
||||||
jqueryFor (Proxy :: Proxy sublayout) $
|
jqueryFor (Proxy :: Proxy sublayout) $
|
||||||
|
@ -238,7 +240,7 @@ instance (KnownSymbol sym, HasJQ sublayout)
|
||||||
|
|
||||||
instance (KnownSymbol sym, HasJQ sublayout)
|
instance (KnownSymbol sym, HasJQ sublayout)
|
||||||
=> HasJQ (QueryParams sym a :> sublayout) where
|
=> HasJQ (QueryParams sym a :> sublayout) where
|
||||||
type JQ (QueryParams sym a :> sublayout) = JQ sublayout
|
type JQ' (QueryParams sym a :> sublayout) = JQ' sublayout
|
||||||
|
|
||||||
jqueryFor Proxy req =
|
jqueryFor Proxy req =
|
||||||
jqueryFor (Proxy :: Proxy sublayout) $
|
jqueryFor (Proxy :: Proxy sublayout) $
|
||||||
|
@ -248,7 +250,7 @@ instance (KnownSymbol sym, HasJQ sublayout)
|
||||||
|
|
||||||
instance (KnownSymbol sym, HasJQ sublayout)
|
instance (KnownSymbol sym, HasJQ sublayout)
|
||||||
=> HasJQ (QueryFlag sym :> sublayout) where
|
=> HasJQ (QueryFlag sym :> sublayout) where
|
||||||
type JQ (QueryFlag sym :> sublayout) = JQ sublayout
|
type JQ' (QueryFlag sym :> sublayout) = JQ' sublayout
|
||||||
|
|
||||||
jqueryFor Proxy req =
|
jqueryFor Proxy req =
|
||||||
jqueryFor (Proxy :: Proxy sublayout) $
|
jqueryFor (Proxy :: Proxy sublayout) $
|
||||||
|
@ -257,14 +259,14 @@ instance (KnownSymbol sym, HasJQ sublayout)
|
||||||
where str = symbolVal (Proxy :: Proxy sym)
|
where str = symbolVal (Proxy :: Proxy sym)
|
||||||
|
|
||||||
instance HasJQ Raw where
|
instance HasJQ Raw where
|
||||||
type JQ Raw = Method -> AjaxReq
|
type JQ' Raw = Method -> AjaxReq
|
||||||
|
|
||||||
jqueryFor Proxy req method =
|
jqueryFor Proxy req method =
|
||||||
req & funcName %~ ((toLower <$> method) <>)
|
req & funcName %~ ((toLower <$> method) <>)
|
||||||
& reqMethod .~ method
|
& reqMethod .~ method
|
||||||
|
|
||||||
instance (Elem JSON list, HasJQ sublayout) => HasJQ (ReqBody list a :> sublayout) where
|
instance (Elem JSON list, HasJQ sublayout) => HasJQ (ReqBody list a :> sublayout) where
|
||||||
type JQ (ReqBody list a :> sublayout) = JQ sublayout
|
type JQ' (ReqBody list a :> sublayout) = JQ' sublayout
|
||||||
|
|
||||||
jqueryFor Proxy req =
|
jqueryFor Proxy req =
|
||||||
jqueryFor (Proxy :: Proxy sublayout) $
|
jqueryFor (Proxy :: Proxy sublayout) $
|
||||||
|
@ -272,7 +274,7 @@ instance (Elem JSON list, HasJQ sublayout) => HasJQ (ReqBody list a :> sublayout
|
||||||
|
|
||||||
instance (KnownSymbol path, HasJQ sublayout)
|
instance (KnownSymbol path, HasJQ sublayout)
|
||||||
=> HasJQ (path :> sublayout) where
|
=> HasJQ (path :> sublayout) where
|
||||||
type JQ (path :> sublayout) = JQ sublayout
|
type JQ' (path :> sublayout) = JQ' sublayout
|
||||||
|
|
||||||
jqueryFor Proxy req =
|
jqueryFor Proxy req =
|
||||||
jqueryFor (Proxy :: Proxy sublayout) $
|
jqueryFor (Proxy :: Proxy sublayout) $
|
||||||
|
|
|
@ -22,7 +22,7 @@ data Authorization (sym :: Symbol) a
|
||||||
|
|
||||||
instance (KnownSymbol sym, HasJQ sublayout)
|
instance (KnownSymbol sym, HasJQ sublayout)
|
||||||
=> HasJQ (Authorization sym a :> sublayout) where
|
=> HasJQ (Authorization sym a :> sublayout) where
|
||||||
type JQ (Authorization sym a :> sublayout) = JQ sublayout
|
type JQ' (Authorization sym a :> sublayout) = JQ' sublayout
|
||||||
|
|
||||||
jqueryFor Proxy req = jqueryFor (Proxy :: Proxy sublayout) $
|
jqueryFor Proxy req = jqueryFor (Proxy :: Proxy sublayout) $
|
||||||
req & reqHeaders <>~ [ ReplaceHeaderArg "Authorization" $
|
req & reqHeaders <>~ [ ReplaceHeaderArg "Authorization" $
|
||||||
|
@ -35,7 +35,7 @@ data MyLovelyHorse a
|
||||||
|
|
||||||
instance (HasJQ sublayout)
|
instance (HasJQ sublayout)
|
||||||
=> HasJQ (MyLovelyHorse a :> sublayout) where
|
=> HasJQ (MyLovelyHorse a :> sublayout) where
|
||||||
type JQ (MyLovelyHorse a :> sublayout) = JQ sublayout
|
type JQ' (MyLovelyHorse a :> sublayout) = JQ' sublayout
|
||||||
|
|
||||||
jqueryFor Proxy req = jqueryFor (Proxy :: Proxy sublayout) $
|
jqueryFor Proxy req = jqueryFor (Proxy :: Proxy sublayout) $
|
||||||
req & reqHeaders <>~ [ ReplaceHeaderArg "X-MyLovelyHorse" tpl ]
|
req & reqHeaders <>~ [ ReplaceHeaderArg "X-MyLovelyHorse" tpl ]
|
||||||
|
@ -47,7 +47,7 @@ data WhatsForDinner a
|
||||||
|
|
||||||
instance (HasJQ sublayout)
|
instance (HasJQ sublayout)
|
||||||
=> HasJQ (WhatsForDinner a :> sublayout) where
|
=> HasJQ (WhatsForDinner a :> sublayout) where
|
||||||
type JQ (WhatsForDinner a :> sublayout) = JQ sublayout
|
type JQ' (WhatsForDinner a :> sublayout) = JQ' sublayout
|
||||||
|
|
||||||
jqueryFor Proxy req = jqueryFor (Proxy :: Proxy sublayout) $
|
jqueryFor Proxy req = jqueryFor (Proxy :: Proxy sublayout) $
|
||||||
req & reqHeaders <>~ [ ReplaceHeaderArg "X-WhatsForDinner" tpl ]
|
req & reqHeaders <>~ [ ReplaceHeaderArg "X-WhatsForDinner" tpl ]
|
||||||
|
|
Loading…
Add table
Reference in a new issue