在引入参数后编译yesod路由时遇到问题

时间:2016-02-13 16:57:08

标签: haskell yesod hamlet

我正在运行一个修改过的例子 http://www.yesodweb.com/book/blog-example-advanced

以前没有使用DBEntitySchemaId类型的参数id。 自介绍以来,我正在

Handler/Entity.hs:146:34:
    Couldn't match type ‘DBEntitySchemaId -> Route App’
                  with ‘Route (HandlerSite (WidgetT App IO))’
    Expected type: WidgetT
                    App IO ((DBEntitySchemaId -> Route App) -> [(Text, Text)] -> Text)
     Actual type: WidgetT
                    App
                    IO
                    (Route (HandlerSite (WidgetT App IO)) -> [(Text, Text)] -> Text)
   In the first argument of ‘(>>=)’, namely ‘getUrlRenderParams’
   In a stmt of a 'do' block:
     (getUrlRenderParams
      >>=
        (\ urender_akdM
           -> (asWidgetT GHC.Base.. toWidget)
                (toHtml (\ u_akdN -> urender_akdM u_akdN [] EntityR))))

指的是使用defaultLayout的行。 相关代码是:

getEntityR :: DBEntitySchemaId -> Handler Html
getEntityR id = do
  oldEntities <- runDB $ selectList [DBEntityDbentitySchemaId ==. id] []
  fields <- runDB $ selectList [DBFieldDbentitySchemaId ==. id, DBFieldFieldTypeId ==. (toSqlKey 1)] []
  mauthId <- maybeAuthId
  ((res, widget), enctype) <- runFormPost (form fields)
  case (mauthId,res) of
    (Just userId, FormSuccess (attributeValues)) -> do
      setMessageI $ MsgSubmittedKarma
      let entity = DBEntity "Test" id
      entId <- runDB $ insert entity
      let fieldsNVals = zip fields attributeValues
      let einfuegen field attributeValue = case (field, attributeValue) of
                                      ((Entity fldId _), (FormSuccess val)) -> do
                                         a <- runDB $ insert (Attribute {attributeEntityId = entId, attributeDbfieldId = fldId, attributeStringValue =  val})
                                         return (Just a)
                                      _ -> return Nothing
      _ <- forM fieldsNVals (\(field, attributeValue) -> einfuegen field attributeValue)

      redirect $ (EntityR id)
    _ -> do        
      --render <- getUrlRenderParams
      --return $ renderHtml $ [hamlet|
      defaultLayout [whamlet|
          $if null oldEntities
              <p>There are no entities
          $else
              <ul>
                  $forall Entity entityId entity  <- oldEntities
                      <li>
                          <p>#{dBEntityName entity}
          $if mauthId == Nothing
              <form method=post action=@{EntityR} enctype=#{enctype}>
                  <input type=submit value=_{MsgPleaseLogin}>
          $else
              <form method=post action=@{EntityR} enctype=#{enctype}>
                  ^{widget}
                  <input type=submit>
      |]

我已经尝试过将whamlet改为哈姆雷特和 从这里添加一些代码行(注释掉)

Trying to send an email in yesod using hamlet

和 改变

[whamlet| 

[whamlet|@{getEntityR}/#{id}|

[whamlet||@?{urlParams id}|

以及

启发的一些变体

Render url with query parameters https://groups.google.com/forum/#!topic/yesodweb/q1gtkOgM32I

我认为只有一个小的修改。但是我对whamlet / hamlet的理解并不是很好。所以我发布这个以防它是一个微不足道的问题。我完全理解我需要投入更多的工作,我在搜索问题时遇到了麻烦。所以请耐心等待。

1 个答案:

答案 0 :(得分:2)

修改路线后,您忘记将新添加的参数传递到@{EntityR}插值,如下所示:@{EntityR param}