From 968b0c13eee8ae6ca573c55307365048431cf2e9 Mon Sep 17 00:00:00 2001 From: John MacFarlane Date: Wed, 1 Jan 2025 23:00:35 -0800 Subject: [PATCH] Typst writer: fix handling of pixel image dimensions. These are now converted to inches as in the LaTeX writer. Closes #9945. --- src/Text/Pandoc/Writers/Typst.hs | 33 ++++++++++++++++++++------------ test/command/9945.md | 28 +++++++++++++++++++++++++++ 2 files changed, 49 insertions(+), 12 deletions(-) create mode 100644 test/command/9945.md diff --git a/src/Text/Pandoc/Writers/Typst.hs b/src/Text/Pandoc/Writers/Typst.hs index bee2b5c620d1..562b86f79a5f 100644 --- a/src/Text/Pandoc/Writers/Typst.hs +++ b/src/Text/Pandoc/Writers/Typst.hs @@ -18,6 +18,8 @@ module Text.Pandoc.Writers.Typst ( ) where import Text.Pandoc.Definition import Text.Pandoc.Class ( PandocMonad) +import Text.Pandoc.ImageSize ( dimension, Dimension(Pixel), Direction(..), + showInInch ) import Text.Pandoc.Options ( WriterOptions(..), WrapOption(..), isEnabled, CaptionPosition(..) ) import Data.Text (Text) @@ -309,12 +311,13 @@ blockToTypst block = $$ blankline Figure (ident,_,_) (Caption _mbshort capt) blocks -> do caption <- blocksToTypst capt + opts <- gets stOptions contents <- case blocks of -- don't need #box around block-level image - [Para [Image (_,_,kvs) _ (src, _)]] - -> pure $ mkImage False src kvs - [Plain [Image (_,_,kvs) _ (src, _)]] - -> pure $ mkImage False src kvs + [Para [Image attr _ (src, _)]] + -> pure $ mkImage opts False src attr + [Plain [Image attr _ (src, _)]] + -> pure $ mkImage opts False src attr _ -> brackets <$> blocksToTypst blocks let lab = toLabel FreestandingLabel ident return $ "#figure(" <> nest 2 ((contents <> ",") @@ -433,23 +436,29 @@ inlineToTypst inline = (if inlines == [Str src] then mempty else nowrap $ brackets contents) <> endCode - Image (_,_,kvs) _inlines (src,_tit) -> pure $ mkImage True src kvs + Image attr _inlines (src,_tit) -> do + opts <- gets stOptions + pure $ mkImage opts True src attr Note blocks -> do contents <- blocksToTypst blocks return $ "#footnote" <> brackets (chomp contents) <> endCode -- see #9104; need box or image is treated as block-level -mkImage :: Bool -> Text -> [(Text, Text)] -> Doc Text -mkImage useBox src kvs +mkImage :: WriterOptions -> Bool -> Text -> Attr -> Doc Text +mkImage opts useBox src attr | useBox = "#box" <> parens coreImage | otherwise = coreImage where src' = T.pack $ unEscapeString $ T.unpack src -- #9389 - toDimAttr k = - case lookup k kvs of - Just v -> ", " <> literal k <> ": " <> literal v - Nothing -> mempty - dimAttrs = mconcat $ map toDimAttr ["height", "width"] + showDim (Pixel a) = literal (showInInch opts (Pixel a) <> "in") + showDim dim = text (show dim) + dimAttrs = + (case dimension Height attr of + Nothing -> mempty + Just dim -> ", height: " <> showDim dim) <> + (case dimension Width attr of + Nothing -> mempty + Just dim -> ", width: " <> showDim dim) isData = "data:" `T.isPrefixOf` src' dataSvg = " src' <> "\" />" coreImage diff --git a/test/command/9945.md b/test/command/9945.md new file mode 100644 index 000000000000..76154342d88d --- /dev/null +++ b/test/command/9945.md @@ -0,0 +1,28 @@ +``` +% pandoc -t typst --dpi 300 +![](image.jpg){width=300 height=300} +^D +#box(image("image.jpg", height: 1in, width: 1in)) +``` + +``` +% pandoc -t typst --dpi 600 +![](image.jpg){width=300px height=300px} +^D +#box(image("image.jpg", height: 0.5in, width: 0.5in)) +``` + +``` +% pandoc -t typst --dpi 600 +![](image.jpg){width=1in height=3cm} +^D +#box(image("image.jpg", height: 3cm, width: 1in)) +``` + + +``` +% pandoc -t typst --dpi 600 +![](image.jpg){.foo .bar baz=3} +^D +#box(image("image.jpg")) +```