typst/tests/suite/styling/show-set.typ
2024-04-13 08:39:45 +00:00

71 lines
2.1 KiB
Typst

// Test show-set rules.
--- show-set-override ---
// Test overriding show-set rules.
#show strong: set text(red)
Hello *World*
#show strong: set text(blue)
Hello *World*
--- show-set-on-same-element ---
// Test show-set rule on the same element.
#set figure(supplement: [Default])
#show figure.where(kind: table): set figure(supplement: [Tableau])
#figure(
table(columns: 2)[A][B][C][D],
caption: [Four letters],
)
--- show-set-same-element-and-order ---
// Test both things at once.
#show heading: set text(red)
= Level 1
== Level 2
#show heading.where(level: 1): set text(blue)
#show heading.where(level: 1): set text(green)
#show heading.where(level: 1): set heading(numbering: "(I)")
= Level 1
== Level 2
--- show-set-same-element-matched-field ---
// Test setting the thing we just matched on.
// This is quite cursed, but it works.
#set heading(numbering: "(I)")
#show heading.where(numbering: "(I)"): set heading(numbering: "1.")
= Heading
--- show-set-same-element-synthesized-matched-field ---
// Same thing, but even more cursed, because `kind` is synthesized.
#show figure.where(kind: table): set figure(kind: raw)
#figure(table[A], caption: [Code])
--- show-set-same-element-matching-interaction ---
// Test that show-set rules on the same element don't affect each other. This
// could be implemented, but isn't as of yet.
#show heading.where(level: 1): set heading(numbering: "(I)")
#show heading.where(numbering: "(I)"): set text(red)
= Heading
--- show-set-on-layoutable-element ---
// Test show-set rules on layoutable element to ensure it is realized
// even though it implements `LayoutMultiple`.
#show table: set text(red)
#pad(table(columns: 4)[A][B][C][D])
--- show-function-order-with-set ---
// These are both red because in the expanded form, `set text(red)` ends up
// closer to the content than `set text(blue)`.
#show strong: it => { set text(red); it }
Hello *World*
#show strong: it => { set text(blue); it }
Hello *World*
--- show-function-set-on-it ---
// This doesn't have an effect. An element is materialized before any show
// rules run.
#show heading: it => { set heading(numbering: "(I)"); it }
= Heading