-
Use a temporary file to atomically write speaker notes.
We weren't writing the file all-at-once before, so if you were using a simple tool like
tail -F
before, this could cause some speaker notes to not be displayed.
-
Incrementally display output of
eval
commands (#132)Rather than waiting for the process to complete and then displaying its output,
patat
now fetches thestdout
andstderr
as it becomes available and refreshes the display.This means that by default, stderr is now displayed as well. To disable displaying
stderr
, you can addstderr: false
to the eval configuration, e.g.:patat: eval: bash: command: bash stderr: false
- Fix width of code blocks when using wide characters (#171)
- Bump
pandoc
upper bound to 3.3.
-
Render tabs in code blocks by expanding them to spaces. The amount of spaces a tab character aligns to is customizable using
tabStop
, e.g.tabStop: 8
. The default is 4. -
Rename eval.wrap to eval.container (#167)
wrap
is used at the top-level of settings for wrapping at a certain column, and insideeval
to determine the type in which the result is "wrapped". Using the same name for both is confusing, so this addseval.container
as the new name foreval.wrap
.eval.wrap
will continue to be supported for the forseeable future, but its use will be discouraged.This also changes the values (again keeping the original ones for backwards-compat), so the complete changes to a configuration would be:
wrap: code
becomescontainer: code
wrap: raw
becomescontainer: none
wrap: rawInline
becomescontainer: inline
-
Add a
type: matrix
transition effect, loosely inspired by the 1999 science fiction movie.
-
Support wrapping at a specific column (#164)
Using a specific wrap column, e.g.
wrap: 60
, works well together withauto
margins (see below). -
Support centering content with auto margins (#164)
Configuration is done through the existing
margins
setting.To vertically center content, use
top: auto
. To horizontally center content, use bothleft: auto
andright: auto
. For example:--- title: Centered presentation author: John Doe patat: margins: left: auto right: auto top: auto ... Hello world
Setting
wrap: true
is recommended when vertically centering content if there are any lines that are too wide for the terminal.
-
Add eval.wrap option
This adds a new
wrap
section to theeval
configuration.By default, the output is wrapped in a code block again with the original syntax highlighting. You can customize this behaviour by setting
wrap
to:code
: the default setting.raw
: no formatting applied.rawInline
: no formatting applied and no trailing newline.
You can use
rawInline
to draw graphics. In order to do that, for example, we could configurekitten
code snippets to evaluate using Kitty's commandicat
. This uses therawInline
code setting to ensure that the resulting output is not wrapped in a code block, and thefragment
andreplace
settings immediately replace the snippet:--- patat: eval: kitten: command: sed 's/^/kitten /' | bash replace: true fragment: false wrap: rawInline ... See, for example: ```kitten icat --align left dank-meme.jpg ```
-
Fix issues in text wrapping when starting a transition
This could show transitions using different wrapping or dropped characters when a line extends past the terminal width.
-
Add dissolve transition effect (#150)
-
Add random transitions (#151)
Set transition
type
torandom
to randomly sample transition effects
-
Add transition effects (#149)
This adds a framework for setting transition effects in between slides. Only a single transition type is implemented at this point,
slideLeft
.Example configuration:
patat: transition: type: slideLeft frames: 24 # Optional duration: 1 # Seconds, optional
-
Allow overriding certain settings in slides (#148)
Configuration was typically done in the metadata block of the input file, or in a per-user configuration. These settings are applied to the entire presentation.
We now allow selectively overriding these settings on a per-slide basis, by adding one or more config blocks to those slides. Config blocks are comments that start with
config:
. They can be placed anywhere in the slide.# This is a normal slide Normal slide content # This slide has a different colour header <!--config: theme: header: [vividYellow] --> Wow, how did that happen?
-
Allow configuring top margin (#147)
-
Read configuration from XDG standard directory (#146)
The per-user patat configuration file was
$HOME/.patat.yaml
, which does not follow the XDG standard. We now support$XDG_CONFIG_DIRECTORY/patat/config.yaml
(typically$XDG_CONFIG_DIRECTORY
is set to$HOME/.config
) which is compliant with the standard.Note that
$HOME/.patat.yaml
is still supported for backward-compatibility, but anything in$XDG_CONFIG_DIRECTORY
takes precedence. -
Support filenames in bash completion (#145) (#126)
-
Fall back to forcing UTF-8 if decoding fails (#144) (#127)
When we try to read a file that is encoded in UTF-8, and the system locale is not set to UTF-8, the GHC runtime system will throw an error.
While this typically indicates that the user should update their system locale using e.g. the
LANG
environment variable, we want to provide a good initial experience for people unfamiliar with this, and in 2023 it's reasonable to assume files may be encoded in UTF-8. -
Dependency updates:
- Bump
skylighting
upper bound to 0.15 (#143)
- Bump
-
Add proper support for speaker notes (#142)
You can configure
patat
to write the speaker notes for the current slide to a file whenever the slide changes:patat: speakerNotes: file: /tmp/notes.txt
Then, you can display these in a second terminal (presumably on a second monitor) by just displaying this file whenever it changes. entr is one way to do that:
echo /tmp/notes.txt | entr -s 'clear; cat /tmp/notes.txt'
Alternatively, just use a second
patat
instance with--watch
enabled:patat -w /tmp/notes.txt
-
Add support for showing plain text files (#141)
This isn't super useful on its own, it's meant to support speaker notes.
-
Add syntaxDefinitions to settings (#140)
This allows users to add custom kate highlighting XML files in the settings:
--- patat: syntaxDefinitions: - 'impurescript.xml' ... Here is some *im*purescript: ```impurescript ... ```
- Apply block quote theming to entire block (#119) (#111)
- Fix table header theming (#128)
- Dependency updates:
aeson
to 2.1optparse-applicative
to 0.18pandoc
to 3.1pandoc-types
to 1.23text
to 2.0time
to 1.12
- Allow hiding slide number (contribution by Paweł Dybiec)
- Support additional markdown extensions (contribution by Spreadcat)
- Dependency updates:
aeson
to 2.0ansi-terminal
to 0.11base64-bytestring
to 1.2bytestring
to 0.11optparse-applicative
to 1.16pandoc
to 2.19skylighting
to 0.13
- Fix alignment and display of CJK characters in presentation title, author and tables
- Add support for showing images in Kitty terminal
- Search in
$PATH
forw3mimgdisplay
- Bump
pandoc
dependency to 2.11 - Refactor
Patat.Presentation.Display
module to make it pure
- Fix issue with laziness for evaluted code blocks, they should only be evaluated when we actually want to show them
- Bump stack resolver to
lts-16.9
- Allow evaluating code blocks (see README for more info)
- Refactor implementation of fragments
- Add breadcrumbs to title based on headers
- Error out when YAML parsing fails
- Bump
pandoc
dependency to 2.9 - Switch to
goldplate
for testing
- Fix Haddock syntax in some comments (contribution by Asad Saeeduddin)
- Add builds for Mac OS
- Refactor CircleCI config & Makefile
- Bump CircleCI configuration
- Bump release script
- Add slide seeking to
--help
output
- Add slide seeking (enter slide number +
enter
) - Fix turning tty echo off/on during presentation
- Run
w3mimgdisplay
cleanup action, fixing image issues on some terminals
- Fix test failure again, and ensure that it works for multiple pandoc versions by slightly modifying test input
- Include pandoc version info in
patat --version
- Fix test failure caused by slightly different pandoc output for lists
- Bump
optparse-applicative
upper bound to 0.16 - Bump
skylighting
upper bound to 0.9
- Bump upper
pandoc
dependency to 2.8
- Bump lower
base
dependency to 4.8
- Bump
pandoc
to 2.6 - Bump
ansi-terminal
to 0.10
- GHC 7.8 compatibility
- Bump
pandoc
to 2.4 - Bump
yaml
to 0.11
- Work around test failure caused by slightly different syntax highlighting in different pandoc versions
- Tickle CircleCI cache
- Add support for italic ansi code in themes
- Fix centered titles not being centered (contribution by Hamza Haiken)
- Themed border rendering improvements (contribution by Hamza Haiken)
- Add support for margins (contribution by Hamza Haiken)
- Add RGB colour support for themes (contribution by Hamza Haiken)
- Add experimental images support
- Add images support for iTerm2 (contribution by @2mol)
- GHC 8.4 compatibility
- GHC 8.4 compatibility
- Support HTML-style comments
- Bump
pandoc
to 2.2
- Bump
aeson
to 1.3 - Bump
skylighting
to 0.7 - Bump
time
to 1.9 - Bump
ansi-terminal
to 0.8
- Bump
skylighting
to 0.6 - Bump
pandoc
to 2.1 - Bump
ansi-terminal
to 0.7
- Automatically upload linux binary to GitHub
- Make pandoc extensions customizable in the configuration
- Bump
pandoc
to 2.0
- Add
network-uri
dependency to fix travis build
- Bump
optparse-applicative-0.14
dependency
- Add navigation using
PageUp
andPageDown
. - Use
skylighting
instead of deprecatedhighlighting-kate
for syntax highlighting.
- Make build reproducible even if timezone changes (patch by Félix Sipma)
- Include
README
inExtra-source-files
so it gets displayed on Hackage
- Bump
aeson-1.2
dependency - Fix vertical alignment of title slides
- Fix wrapping issue with inline code at end of line
- Add bash-completion script generation to Makefile
-
Add a
slideLevel
option & autodetect it. This changes the waypatat
splits slides. For more information, see theREADME
or theman
page. If you just want to get the old behavior back, just add:--- patat: slideLevel: 1 ...
To the top of your presentation.
-
Clear the screen when finished with the presentation.
- Bump
directory-1.3
dependency - Bump
time-1.7
dependency
- Bump
aeson-1.1
dependency - Parse YAML for settings using
yaml
instead of pandoc - Clarify watch & autoAdvance combination in documentation.
- Redraw the screen on unknown commands to prevent accidental typing from showing up.
- Make the cursor invisible during the presentation.
- Move the footer down one more line to gain some screen real estate.
- Render the date in a locale-independent manner (patch by Daniel Shahaf).
- Force the use of UTF-8 when generating the man page.
- Use
SOURCE_DATE_EPOCH
if it is present instead of getting the date fromgit log
.
- Fix issues with man page generation on Travis.
- Fix compatibility with
pandoc-1.18
andpandoc-1.19
. - Add a man page.
- Add configurable auto advancing.
- Support fragmented slides.
- Add a
--version
flag. - Add support for
pandoc-1.18
which includes a newLineBlock
element.
- Keep running even if errors are encountered during reload.
- Fix compilation with
lts-6.22
.
- Add syntax highlighting support.
- Fixed slide clipping after reload.
- Add theming support.
- Fix links display.
- Add support for wrapping.
- Allow org mode as input format.
- Upload first version from hotel wifi in Kalaw.