diff options
| author | John MacFarlane <jgm@berkeley.edu> | 2015-03-29 09:47:49 -0700 | 
|---|---|---|
| committer | John MacFarlane <jgm@berkeley.edu> | 2015-03-29 09:47:49 -0700 | 
| commit | 91128aac9953fb3bdc1ce4af1a9449eb2e853739 (patch) | |
| tree | 09a33f3c78c817b06a01037a0056d63bd43e0765 | |
| parent | ef07974dc47a834ed3b0f2b7eccbd79bc8c9a9ed (diff) | |
| parent | 4d1e85a09e7e1a26a5b715c6bfdfed65a59d13bf (diff) | |
| download | pandoc-91128aac9953fb3bdc1ce4af1a9449eb2e853739.tar.gz | |
Merge pull request #2037 from lierdakil/issue458
Docx Writer: support for --toc option
| -rw-r--r-- | data/docx/word/styles.xml | 19 | ||||
| -rw-r--r-- | src/Text/Pandoc/Writers/Docx.hs | 30 | 
2 files changed, 48 insertions, 1 deletions
| diff --git a/data/docx/word/styles.xml b/data/docx/word/styles.xml index 0de21bd4c..01190ef5a 100644 --- a/data/docx/word/styles.xml +++ b/data/docx/word/styles.xml @@ -340,4 +340,23 @@        <w:color w:val="4F81BD" w:themeColor="accent1" />      </w:rPr>    </w:style> +  <w:style w:type="paragraph" w:styleId="TOCHeading"> +    <w:name w:val="TOC Heading" /> +    <w:basedOn w:val="Heading1" /> +    <w:next w:val="BodyText" /> +    <w:uiPriority w:val="39" /> +    <w:unhideWhenUsed /> +    <w:qFormat /> +    <w:pPr> +      <w:spacing w:before="240" w:line="259" w:lineRule="auto" /> +      <w:outlineLvl w:val="9" /> +    </w:pPr> +    <w:rPr> +      <w:rFonts w:asciiTheme="majorHAnsi" w:eastAsiaTheme="majorEastAsia" w:hAnsiTheme="majorHAnsi" w:cstheme="majorBidi" /> +      <w:b w:val="0" /> +      <w:bCs w:val="0" /> +      <w:color w:val="365F91" w:themeColor="accent1" +      w:themeShade="BF" /> +    </w:rPr> +  </w:style>  </w:styles> diff --git a/src/Text/Pandoc/Writers/Docx.hs b/src/Text/Pandoc/Writers/Docx.hs index d96faaf86..70319e94c 100644 --- a/src/Text/Pandoc/Writers/Docx.hs +++ b/src/Text/Pandoc/Writers/Docx.hs @@ -598,6 +598,33 @@ mkLvl marker lvl =  getNumId :: WS Int  getNumId = (((baseListId - 1) +) . length) `fmap` gets stLists +makeTOC :: WriterOptions -> WS [Element] +makeTOC opts | writerTableOfContents opts = do +  let depth = "1-"++(show (writerTOCDepth opts)) +  let tocCmd = "TOC \\o \""++depth++"\" \\h \\z \\u" +  title <- withParaPropM (pStyleM "TOC Heading") (blocksToOpenXML opts [Para [Str "Table of Contents"]]) +  return $ +    [mknode "w:sdt" [] ([ +      mknode "w:sdtPr" [] ( +        mknode "w:docPartObj" [] ( +          [mknode "w:docPartGallery" [("w:val","Table of Contents")] (), +          mknode "w:docPartUnique" [] ()] +        ) -- w:docPartObj +      ), -- w:sdtPr +      mknode "w:sdtContent" [] (title++[ +        mknode "w:p" [] ( +          mknode "w:r" [] ([ +            mknode "w:fldChar" [("w:fldCharType","begin"),("w:dirty","true")] (), +            mknode "w:instrText" [("xml:space","preserve")] tocCmd, +            mknode "w:fldChar" [("w:fldCharType","separate")] (), +            mknode "w:fldChar" [("w:fldCharType","end")] () +          ]) -- w:r +        ) -- w:p +      ]) +    ])] -- w:sdt +makeTOC _ = return [] + +  -- | Convert Pandoc document to two lists of  -- OpenXML elements (the main document and footnotes).  writeOpenXML :: WriterOptions -> Pandoc -> WS ([Element], [Element]) @@ -630,7 +657,8 @@ writeOpenXML opts (Pandoc meta blocks) = do    let blocks' = bottomUp convertSpace blocks    doc' <- (setFirstPara >> blocksToOpenXML opts blocks')    notes' <- reverse `fmap` gets stFootnotes -  let meta' = title ++ subtitle ++ authors ++ date ++ abstract +  toc <- makeTOC opts +  let meta' = title ++ subtitle ++ authors ++ date ++ abstract ++ toc    return (meta' ++ doc', notes')  -- | Convert a list of Pandoc blocks to OpenXML. | 
