1
0
mirror of https://github.com/Jermolene/TiddlyWiki5 synced 2025-01-15 19:55:40 +00:00
TiddlyWiki5/editions/tw5.com/tiddlers/howtos/Using Stylesheets.tid

74 lines
3.2 KiB
Plaintext
Raw Normal View History

2014-03-05 09:13:14 +00:00
created: 20140305091244145
modified: 201804111739
tags: [[Customise TiddlyWiki]]
2014-03-05 09:13:14 +00:00
title: Using Stylesheets
type: text/vnd.tiddlywiki
\define tv-config-toolbar-text() yes
2014-03-05 09:13:14 +00:00
\define openCpTheme()
<$action-setfield $tiddler="$:/state/tab-1749438307" $value="$:/core/ui/ControlPanel/Appearance"/>
<$action-setfield $tiddler="$:/state/tab--1963855381" $value="$:/core/ui/ControlPanel/Theme"/>
<$action-navigate $to="$:/ControlPanel"/>
\end
2014-03-05 09:13:14 +00:00
! Theme and Colorpalette
2014-03-05 09:13:14 +00:00
The first steps to changing the appearance of ~TiddlyWiki are to choose and apply:
2014-03-05 09:13:14 +00:00
* One of the available themes: <span class="tc-btn-standard"> {{$:/core/ui/Buttons/theme}} </span>
* Modify the colour palette: <span class="tc-btn-standard"> {{$:/core/ui/Buttons/palette}} </span>
* Experiment with the <$button actions=<<openCpTheme>> >{{$:/core/images/options-button}} ControlPanel</$button>
2014-03-05 09:13:14 +00:00
! Work with Stylesheets
2017-02-27 15:54:15 +00:00
In addition to the control panel, custom styles can be defined by tagging a tiddler `$:/tags/Stylesheet`. Try creating a custom stylesheet now with the following content in order to change the page background colour to red:
2017-02-27 15:54:15 +00:00
```
body.tc-body {
background: red;
}
2017-02-27 15:54:15 +00:00
```
!! Additional Resrouces
2017-02-27 15:54:15 +00:00
* [[Cascading Style Sheets (CSS) at mozilla|https://developer.mozilla.org/en-US/docs/Web/CSS]]
* [[Cascading Style Sheets (CSS) at w3scools|http://www.w3schools.com/css]]
2017-02-27 15:54:15 +00:00
! Overriding Theme Settings
Custom stylesheets are applied independently from theme stylesheets. Therefore, it is often necessary for the css rules in your custom stylesheet to be more specific than those of the theme you want to override. For example, `html body.tc-body` is more specific than `body.tc-body`.
<<.tip "''You should always start with the least specific value that works!''<br><br>">>
2017-02-27 15:54:15 +00:00
2014-03-05 09:13:14 +00:00
! Stylesheet Types
Usually it is best to use the type `text/css` for stylesheets. This treats them as plain stylesheets, and ensures that ~TiddlyWiki doesn't apply any wiki processing to them.
2014-03-05 09:13:14 +00:00
If you wish to use macros and transclusions in your stylesheets you should instead use the default WikiText type `text/vnd.tiddlywiki`. This allows full ~WikiText processing to be performed. Here is an example:
2014-03-05 09:13:14 +00:00
```
\rules only filteredtranscludeinline transcludeinline macrodef macrocallinline html
2014-03-05 09:13:14 +00:00
2014-12-19 14:48:12 +00:00
body.tc-body pre {
<<box-shadow "inset 0 1px 0 #fff">>
2014-03-05 09:13:14 +00:00
}
```
The `\rules` pragma at the top of the tiddler restricts the ~WikiText to just allow macros and transclusion. This avoids mistakenly triggering unwanted ~WikiText processing.
2014-03-05 09:13:14 +00:00
2014-12-19 14:48:12 +00:00
A stylesheet tiddler is processed such that it is first wikified and then the text portion of the ouput is extracted to apply as the CSS. Any HTML tags you will use in your stylesheet are thus ignored. For example, HTML elements generated by the RevealWidget will not affect the output. As in the following example, you can wrap CSS rules in `<pre>` tags to display them as a codeblock without affecting processing, including handling the inner macro.
```
\rules only filteredtranscludeinline transcludeinline macrodef macrocallinline html
<pre>body.tc-body pre {
<<box-shadow "inset 0 1px 0 #fff">>
}
</pre>
```
2014-03-05 09:13:14 +00:00
!! Stylesheet Macros
The ~TiddlyWiki core provides several [[global macros that are helpful in constructing stylesheets|Stylesheet Macros]].