From 9d10fe13dd829eff188b5c1e414a28c88063a1b7 Mon Sep 17 00:00:00 2001 From: Ivan Lazar Miljenovic Date: Wed, 11 Oct 2017 10:48:22 +1100 Subject: [PATCH 1/3] Use 3rd-level headings For some reason, 2nd-level headings are used for introductions and for each API endpoint, but then it immediately jumps to 4th-level headings. Instead, promote everything that's 4th-level to 3rd-level. --- servant-docs/src/Servant/Docs/Internal.hs | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/servant-docs/src/Servant/Docs/Internal.hs b/servant-docs/src/Servant/Docs/Internal.hs index e4bae223..0c22e0cf 100644 --- a/servant-docs/src/Servant/Docs/Internal.hs +++ b/servant-docs/src/Servant/Docs/Internal.hs @@ -619,7 +619,7 @@ markdownWith RenderingOptions{..} api = unlines $ noteStr :: DocNote -> [String] noteStr nt = - ("#### " ++ nt ^. noteTitle) : + ("### " ++ nt ^. noteTitle) : "" : intersperse "" (nt ^. noteBody) ++ "" : @@ -631,7 +631,7 @@ markdownWith RenderingOptions{..} api = unlines $ authStr auths = let authIntros = mapped %~ view authIntro $ auths clientInfos = mapped %~ view authDataRequired $ auths - in "#### Authentication": + in "### Authentication": "": unlines authIntros : "": @@ -643,7 +643,7 @@ markdownWith RenderingOptions{..} api = unlines $ capturesStr :: [DocCapture] -> [String] capturesStr [] = [] capturesStr l = - "#### Captures:" : + "### Captures:" : "" : map captureStr l ++ "" : @@ -655,7 +655,7 @@ markdownWith RenderingOptions{..} api = unlines $ headersStr :: [Text] -> [String] headersStr [] = [] headersStr l = - "#### Headers:" : + "### Headers:" : "" : map headerStr l ++ "" : @@ -667,7 +667,7 @@ markdownWith RenderingOptions{..} api = unlines $ paramsStr :: HTTP.Method -> [DocQueryParam] -> [String] paramsStr _ [] = [] paramsStr m l = - ("#### " ++ cs m ++ " Parameters:") : + ("### " ++ cs m ++ " Parameters:") : "" : map (paramStr m) l ++ "" : @@ -693,7 +693,7 @@ markdownWith RenderingOptions{..} api = unlines $ rqbodyStr :: [M.MediaType] -> [(Text, M.MediaType, ByteString)]-> [String] rqbodyStr [] [] = [] rqbodyStr types s = - ["#### Request:", ""] + ["### Request:", ""] <> formatTypes types <> formatBodies _requestExamples s @@ -749,7 +749,7 @@ markdownWith RenderingOptions{..} api = unlines $ responseStr :: Response -> [String] responseStr resp = - "#### Response:" : + "### Response:" : "" : ("- Status code " ++ show (resp ^. respStatus)) : ("- Headers: " ++ show (resp ^. respHeaders)) : From 6df200326fdc58b15fdbd35952995700aaadc45f Mon Sep 17 00:00:00 2001 From: Ivan Lazar Miljenovic Date: Wed, 11 Oct 2017 12:12:48 +1100 Subject: [PATCH 2/3] Add an option to wrap notes in a separate header Closes #831, using option 3. --- servant-docs/src/Servant/Docs.hs | 2 +- servant-docs/src/Servant/Docs/Internal.hs | 17 +++++++++++++---- 2 files changed, 14 insertions(+), 5 deletions(-) diff --git a/servant-docs/src/Servant/Docs.hs b/servant-docs/src/Servant/Docs.hs index 5d7661fe..83699bb2 100644 --- a/servant-docs/src/Servant/Docs.hs +++ b/servant-docs/src/Servant/Docs.hs @@ -26,7 +26,7 @@ module Servant.Docs HasDocs(..), docs, pretty, markdown -- ** Customising generated documentation , markdownWith, RenderingOptions(..), defRenderingOptions - , requestExamples, responseExamples, ShowContentTypes(..) + , requestExamples, responseExamples, ShowContentTypes(..), notesHeading -- * Generating docs with extra information , docsWith, docsWithIntros, docsWithOptions , ExtraInfo(..), extraInfo diff --git a/servant-docs/src/Servant/Docs/Internal.hs b/servant-docs/src/Servant/Docs/Internal.hs index 0c22e0cf..f71430d6 100644 --- a/servant-docs/src/Servant/Docs/Internal.hs +++ b/servant-docs/src/Servant/Docs/Internal.hs @@ -313,18 +313,22 @@ data RenderingOptions = RenderingOptions -- ^ How many content types to display for request body examples? , _responseExamples :: !ShowContentTypes -- ^ How many content types to display for response body examples? + , _notesHeading :: !(Maybe String) + -- ^ Optionally group all 'notes' together under a common heading. } deriving (Show) -- | Default API generation options. -- -- All content types are shown for both 'requestExamples' and --- 'responseExamples'. +-- 'responseExamples'; 'notesHeading' is set to 'Nothing' +-- (i.e. un-grouped). -- -- @since 0.11.1 defRenderingOptions :: RenderingOptions defRenderingOptions = RenderingOptions { _requestExamples = AllContentTypes , _responseExamples = AllContentTypes + , _notesHeading = Nothing } -- gimme some lenses @@ -615,16 +619,21 @@ markdownWith RenderingOptions{..} api = unlines $ [] notesStr :: [DocNote] -> [String] - notesStr = concatMap noteStr + notesStr = addHeading + . concatMap noteStr + where + addHeading nts = maybe nts (\hd -> ("### " ++ hd) : "" : nts) _notesHeading noteStr :: DocNote -> [String] noteStr nt = - ("### " ++ nt ^. noteTitle) : + (hdr ++ nt ^. noteTitle) : "" : intersperse "" (nt ^. noteBody) ++ "" : [] - + where + hdr | isJust _notesHeading = "#### " + | otherwise = "### " authStr :: [DocAuthentication] -> [String] authStr [] = [] From 0d97deada9e84b22ace60d6ce8551706586cc1ae Mon Sep 17 00:00:00 2001 From: Ivan Lazar Miljenovic Date: Wed, 11 Oct 2017 12:19:00 +1100 Subject: [PATCH 3/3] Note change --- servant-docs/CHANGELOG.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/servant-docs/CHANGELOG.md b/servant-docs/CHANGELOG.md index c77af0a9..a3209d2b 100644 --- a/servant-docs/CHANGELOG.md +++ b/servant-docs/CHANGELOG.md @@ -7,8 +7,10 @@ * Document the HTTP Method the parameters of an endpoint belong to (rather than assuming `GET` for all of them). * Content type of sample response body is also displayed. -* Can now control how many content-types for each example are shown - with `markdownWith` and `RenderingOptions`. +* Can now customise various aspects of how the document is produced + using `markdownWith` and `RenderingOptions`: + - How many content-types for each example are shown + - Whether notes should be grouped together under their own header. 0.11 ----