2014-08-18 19:52:36 +00:00
|
|
|
title: $:/core/macros/toc
|
|
|
|
tags: $:/tags/Macro
|
|
|
|
|
2024-02-07 13:32:22 +00:00
|
|
|
<!--
|
2024-02-10 16:34:31 +00:00
|
|
|
Naming rules
|
|
|
|
- functions eg: tf.toc-variableName, "tf." ... function prefix reservered for TW, "toc-" ... global macro prefix, "variableName"
|
2024-02-07 13:32:22 +00:00
|
|
|
- procedures eg: toc-procedureName,
|
|
|
|
- macro parameters: path, itemTemplate
|
2024-02-10 16:34:31 +00:00
|
|
|
- derived macro parameters: _path, _itemTemplate ... derived variables start with an underscore
|
|
|
|
- some \function definitions are near their first use in the middle of the code, to find them easily
|
2024-02-09 11:23:24 +00:00
|
|
|
|
2024-02-10 16:34:31 +00:00
|
|
|
The toc-macro code is heavily reused from top to bottom.
|
|
|
|
toc-tabbed-internal-nav calls toc-tabbed-external-nav, which calls toc-selective-expandable, which calls toc-expandable
|
2024-02-09 11:23:24 +00:00
|
|
|
|
2024-02-10 16:34:31 +00:00
|
|
|
The very first toc macro is _not_ reused. So it can be used as a simple reference implementation, because it is relatively easy to debug.
|
2024-02-07 13:32:22 +00:00
|
|
|
-->
|
|
|
|
|
2024-02-01 17:07:40 +00:00
|
|
|
\whitespace trim
|
2022-11-14 22:04:30 +00:00
|
|
|
|
2024-05-13 10:58:04 +00:00
|
|
|
<!-- The field to show depends on the following cascade - default: title -->
|
|
|
|
\procedure _hasItemTemplate() [<itemTemplate>!is[blank]then[text]]
|
|
|
|
\procedure _hasCaptionField() [get<captionField>!is[blank]then<captionField>]
|
|
|
|
\procedure _hasCaption() [has[caption]then[caption]]
|
|
|
|
|
2024-05-14 01:19:26 +00:00
|
|
|
\function tf.toc-getTooltip() [<currentTiddler>get[toc-tooltip]!is[blank]] :else[<currentTiddler>]
|
|
|
|
|
2024-05-13 10:58:04 +00:00
|
|
|
<!-- Use this item template as a default -->
|
2024-02-07 10:30:10 +00:00
|
|
|
\procedure toc-defaultItemTemplate()
|
2024-05-13 10:58:04 +00:00
|
|
|
<$let tv-wikilinks="no"
|
|
|
|
field={{{ [<currentTiddler>] :cascade[<_hasItemTemplate>append<_hasCaptionField>append<_hasCaption>append[title]] }}}
|
|
|
|
>
|
2024-05-13 12:10:29 +00:00
|
|
|
<span class=""
|
2024-05-13 10:58:04 +00:00
|
|
|
data-fieldClass=`field-$(field)$`
|
2024-05-14 01:19:26 +00:00
|
|
|
title=<<tf.toc-getTooltip>>
|
2024-02-06 16:39:51 +00:00
|
|
|
>
|
2024-05-13 10:58:04 +00:00
|
|
|
<$transclude $field=<<field>>/>
|
|
|
|
</span>
|
2024-02-04 05:15:49 +00:00
|
|
|
</$let>
|
|
|
|
\end
|
|
|
|
|
2024-05-13 10:58:04 +00:00
|
|
|
<!--
|
|
|
|
Check if a user defined item template should be used.
|
2024-05-13 12:10:29 +00:00
|
|
|
It can be a macro parameter: itemTemplate or a tiddler field: toc-itemTemplate.
|
2024-05-13 10:58:04 +00:00
|
|
|
-->
|
|
|
|
\function tf.toc-getItemTemplateTitle() [<currentTiddler>get[toc-itemTemplate]] :filter[has[text]] :else[<itemTemplate>has[text]then<itemTemplate>]
|
2024-02-07 10:30:10 +00:00
|
|
|
|
2024-02-07 11:45:12 +00:00
|
|
|
\procedure _itemTemplate()
|
2024-05-04 13:28:11 +00:00
|
|
|
<$transclude $tiddler=<<tf.toc-getItemTemplateTitle>> >
|
2024-02-07 10:30:10 +00:00
|
|
|
<<toc-defaultItemTemplate>>
|
|
|
|
</$transclude>
|
|
|
|
\end
|
|
|
|
|
2024-02-10 16:34:31 +00:00
|
|
|
<!-- Next 2 allow custom icons (TW v5.2.4). Keep names for backwards compatibility -->
|
2024-02-01 17:07:40 +00:00
|
|
|
\procedure toc-open-icon() $:/core/images/down-arrow
|
|
|
|
\procedure toc-closed-icon() $:/core/images/right-arrow
|
2024-02-01 13:12:35 +00:00
|
|
|
|
2024-02-10 16:34:31 +00:00
|
|
|
<!-- Default field names -->
|
2024-02-07 11:45:12 +00:00
|
|
|
\procedure toc-hideField() toc-hide
|
|
|
|
\procedure toc-includeField() toc-include
|
|
|
|
\procedure toc-filterField() toc-filter
|
2024-02-05 20:14:44 +00:00
|
|
|
|
2024-05-04 13:28:11 +00:00
|
|
|
<!-- Helper functions for LI class definitions on the branch level -->
|
2024-02-04 06:37:24 +00:00
|
|
|
\function tf.toc-itemClassFilter() [<selectedTiddler>get[text]match<currentTiddler>then[toc-item-selected]else[toc-item]]
|
2024-02-14 12:38:35 +00:00
|
|
|
\function tf.toc-includeClass() [subfilter<tf.toc-include>match<currentTiddler>then[tc-toc-include]]
|
|
|
|
\function tf.toc-filterClass() [subfilter<tf.toc-filter>match<currentTiddler>then[tc-toc-filter]]
|
|
|
|
\function tf.toc-hideClass() [<tf.toc-hide>!is[blank]then[tc-toc-hide]]
|
2024-02-04 06:37:24 +00:00
|
|
|
<!-- join the CSS definitions from above -->
|
2024-02-07 00:25:12 +00:00
|
|
|
\function tf.toc-itemClass() [<tf.toc-itemClassFilter>] [<tf.toc-includeClass>] [<tf.toc-filterClass>] [<tf.toc-hideClass>] +[join[ ]]
|
2024-02-01 13:12:35 +00:00
|
|
|
|
2024-02-10 16:34:31 +00:00
|
|
|
<!-- Special case: if toc-hide field is "yes", we need a currentTiddler *titlelist* - otherwise return the content as text -->
|
2024-05-04 13:28:11 +00:00
|
|
|
<!-- The following functions need to use <currentTiddler> -->
|
2024-02-07 11:45:12 +00:00
|
|
|
\function tf.toc-getHideText() [<currentTiddler>get<toc-hideField>]
|
2024-02-07 00:25:12 +00:00
|
|
|
\function tf.toc-hideIsYes() [<currentTiddler>format:titlelist[]]
|
|
|
|
\function tf.toc-hide() [<tf.toc-getHideText>match[yes]then<tf.toc-hideIsYes>] :else[<tf.toc-getHideText>]
|
2014-12-11 17:00:57 +00:00
|
|
|
|
2024-05-04 13:28:11 +00:00
|
|
|
<!-- Read tf.toc-include and tf.toc-filter from fields. Need to use the <tag> variable -->
|
2024-02-07 13:32:22 +00:00
|
|
|
\function tf.toc-include() [<tag>get<toc-includeField>]
|
|
|
|
\function tf.toc-filter() [<tag>get<toc-filterField>]
|
2024-02-07 00:25:12 +00:00
|
|
|
|
2024-02-09 11:23:24 +00:00
|
|
|
<!-- Define default filter strings for different usecases: tag (default), parentField or tagField for using a tag-like field -->
|
2024-02-07 00:25:12 +00:00
|
|
|
\procedure toc-filterDefault() [all[shadows+tiddlers]tag<tag>!has[draft.of]]
|
|
|
|
\procedure toc-filterParent() [has<parentField>!has[draft.of]] :filter[get<parentField>match<tag>]
|
2024-02-08 11:53:07 +00:00
|
|
|
\procedure toc-filterTagLike() [<tag>get<tagField>enlist-input[]!has[draft.of]]
|
|
|
|
|
2024-02-09 11:23:24 +00:00
|
|
|
<!-- TODO tiddlers with parentField MAY need caching -->
|
2024-02-07 00:25:12 +00:00
|
|
|
|
2024-05-04 13:28:11 +00:00
|
|
|
<!-- Activate the filterString depending on tagField, parentField or default. tagField takes precedence -->
|
2024-02-07 00:25:12 +00:00
|
|
|
\function tf.toc-filterString() [<tagField>!is[blank]then<toc-filterTagLike>] :else[<parentField>!is[blank]then<toc-filterParent>else<toc-filterDefault>]
|
2024-02-03 02:04:41 +00:00
|
|
|
|
2024-05-04 13:28:11 +00:00
|
|
|
<!-- Define unique path based state title -->
|
2024-02-04 06:37:24 +00:00
|
|
|
\function tf.toc-newPath() [<path>addsuffix[/]addsuffix<tag>]
|
2024-02-04 05:15:49 +00:00
|
|
|
|
2024-02-09 11:23:24 +00:00
|
|
|
<!-- ====================================================================================
|
|
|
|
Simple toc macro which shows the full tree
|
|
|
|
This macro is _not_ used by other toc-macros
|
|
|
|
v5.3.4 itemClassFilter has been replaced by tf.toc-itemClassFilter see: tf.toc-itemClass()
|
|
|
|
========================================================================================== -->
|
|
|
|
\procedure toc(tag,sort:"",itemClassFilter,exclude,captionField,tagField,parentField,itemTemplate)
|
|
|
|
<$macrocall $name="toc-body" tag=<<tag>> sort=<<sort>> exclude=<<exclude>>/>
|
|
|
|
\end
|
|
|
|
|
2024-05-04 13:28:11 +00:00
|
|
|
<!-- Simple toc helper body -->
|
2024-02-01 17:07:40 +00:00
|
|
|
\procedure toc-body(tag,sort:"",itemClassFilter,exclude,path)
|
2024-02-07 00:25:12 +00:00
|
|
|
<!-- Be aware: if parentField is set, the "tag" parameter contains the currentTiddler -->
|
|
|
|
<$set name=currentTiddler filter="[<parentField>!is[blank]then<tag>else<currentTiddler>]">
|
2014-08-31 13:05:43 +00:00
|
|
|
<ol class="tc-toc">
|
2024-02-09 11:23:24 +00:00
|
|
|
<!-- text substitution for $(sort)$ parameter backwards compatibility -->
|
2024-02-05 19:07:10 +00:00
|
|
|
<$list filter=` [subfilter<tf.toc-filter>]
|
2024-02-07 00:25:12 +00:00
|
|
|
:else[subfilter<tf.toc-filterString>$(sort)$]
|
2024-02-04 20:57:34 +00:00
|
|
|
[subfilter<tf.toc-include>] -[<tag>] -[subfilter<exclude>]`>
|
|
|
|
<%if [<currentTiddler>] -[subfilter<tf.toc-hide>] %>
|
2024-02-07 13:32:22 +00:00
|
|
|
<$let _path=<<tf.toc-newPath>> >
|
2024-02-04 20:57:34 +00:00
|
|
|
<!-- adding tf.toc-hide, excludes blocked elements from all visible sub-nodes -->
|
2024-02-06 16:39:51 +00:00
|
|
|
<$set name="_excluded" filter="[subfilter<exclude>] [<tag>] [subfilter<tf.toc-hide>]">
|
2024-02-04 05:15:49 +00:00
|
|
|
<li class=<<tf.toc-itemClass>>>
|
|
|
|
<% if [all[current]toc-link[no]] %>
|
2024-02-07 11:45:12 +00:00
|
|
|
<<_itemTemplate>>
|
2024-02-04 05:15:49 +00:00
|
|
|
<% else %>
|
2024-05-04 13:28:11 +00:00
|
|
|
<!-- Since v5.1.23 use target-field if present in tiddler -->
|
2024-02-04 05:15:49 +00:00
|
|
|
<$link to={{{ [<currentTiddler>get[target]else<currentTiddler>] }}}>
|
2024-02-07 11:45:12 +00:00
|
|
|
<<_itemTemplate>>
|
2024-02-04 05:15:49 +00:00
|
|
|
</$link>
|
|
|
|
<% endif %>
|
2024-02-07 11:45:12 +00:00
|
|
|
<!-- toc-body only calls itself, so only modified variables have to be passed on. -->
|
2024-02-07 13:32:22 +00:00
|
|
|
<!-- The rest can be reused from toc parameters -->
|
|
|
|
<$macrocall $name="toc-body" tag=<<currentTiddler>> exclude=<<_excluded>> path=<<_path>>
|
2024-02-04 05:15:49 +00:00
|
|
|
/>
|
|
|
|
</li>
|
|
|
|
</$set>
|
|
|
|
</$let>
|
|
|
|
<% endif %>
|
2024-02-01 17:07:40 +00:00
|
|
|
</$list>
|
2014-08-18 19:52:36 +00:00
|
|
|
</ol>
|
2024-02-07 11:45:12 +00:00
|
|
|
</$set>
|
2014-08-18 19:52:36 +00:00
|
|
|
\end
|
2024-02-07 00:25:12 +00:00
|
|
|
<!-- -->
|
|
|
|
<!-- <$log tag=<<tag>> parentField=<<parentField>> toc-filter=<<toc-filter>> ct=<<currentTiddler>> captionField=<<captionField>>/> -->
|
|
|
|
<!-- -->
|
2014-08-18 19:52:36 +00:00
|
|
|
|
2024-02-09 11:23:24 +00:00
|
|
|
<!-- Helper functions for toc-openBranch and toc-closeBranch procedures -->
|
2024-02-14 12:39:36 +00:00
|
|
|
\procedure toc-tagLikeChildFilter() [<currentTiddler>get<tagField>enlist-input[]] -[toc-hide[yes]]
|
|
|
|
\procedure toc-parentChildFilter() [has<parentField>] :filter[get<parentField>match<..currentTiddler>] -[toc-hide[yes]]
|
|
|
|
\procedure toc-tagChildFilter() [tag<currentTiddler>] -[toc-hide[yes]]
|
2024-02-08 11:53:07 +00:00
|
|
|
|
|
|
|
<!-- this function uses the variables NOT the tiddler fields -->
|
2024-02-08 13:44:34 +00:00
|
|
|
\function tf.toc-hasChildren()
|
|
|
|
[<tagField>!is[blank]then<toc-tagLikeChildFilter>]
|
2024-02-14 12:39:36 +00:00
|
|
|
:else[<parentField>!is[blank]then<toc-parentChildFilter>]
|
|
|
|
:else[<toc-tagChildFilter>]
|
2024-02-08 13:44:34 +00:00
|
|
|
\end
|
2024-02-08 11:53:07 +00:00
|
|
|
|
2024-02-10 16:34:31 +00:00
|
|
|
\function tf.toc-stateTitle() [[$:/state/toc]] [<path>] "/" [<currentTiddler>] +[join[]]
|
|
|
|
|
2024-02-09 11:23:24 +00:00
|
|
|
<!-- toc-openBranch internally uses a recursiveOpen() procedure -->
|
2024-02-07 19:27:23 +00:00
|
|
|
\procedure toc-openBranch(path,currentTiddler,manual:"no")
|
2024-05-04 13:28:11 +00:00
|
|
|
\procedure recursiveOpen(exclude, path)
|
|
|
|
<!-- tf.toc-stateTitle needs the path variable! -->
|
|
|
|
<$let path={{{ [<path>] "/" [<currentTiddler>] +[join[]] }}}>
|
|
|
|
<!-- It's common that users tag the <currentTiddler> with itself, so avoid redundant state tiddlers with -[<currentTiddler>] -->
|
|
|
|
<$list filter="[subfilter<tf.toc-hasChildren>] [subfilter<tf.toc-curTidInclude>] -[<currentTiddler>] -[subfilter<exclude>]" >
|
|
|
|
<% if [subfilter<tf.toc-hasChildren>] [subfilter<tf.toc-curTidInclude>] -[<currentTiddler>] -[subfilter<exclude>] %>
|
|
|
|
<$set name="_excluded" filter="[subfilter<exclude>] [<currentTiddler>]">
|
|
|
|
<!-- tf.toc-stateTitle needs the path variable! -->
|
|
|
|
<$qualify name="toc-state" title=<<tf.toc-stateTitle>> >
|
|
|
|
<$action-setfield $tiddler=<<toc-state>> text="open"/>
|
|
|
|
<$macrocall $name="recursiveOpen" exclude=<<_excluded>> path=<<path>> />
|
|
|
|
</$qualify>
|
|
|
|
</$set>
|
|
|
|
<% endif %>
|
|
|
|
</$list>
|
|
|
|
</$let>
|
|
|
|
\end recursiveOpen
|
2024-02-09 11:23:24 +00:00
|
|
|
|
2024-02-07 19:27:23 +00:00
|
|
|
<% if [<manual>match[yes]] %>
|
|
|
|
<$qualify name="toc-state" title=<<tf.toc-stateTitle>> >
|
|
|
|
<$action-setfield $tiddler=<<toc-state>> text="open"/>
|
|
|
|
<$macrocall $name="recursiveOpen" exclude=<<exclude>> path=<<path>> />
|
|
|
|
</$qualify>
|
|
|
|
<% elseif [<modifier>match[ctrl]] %>
|
|
|
|
<$macrocall $name="recursiveOpen" exclude=<<exclude>> path=<<path>> />
|
|
|
|
<% endif %>
|
|
|
|
\end
|
2024-02-08 11:53:07 +00:00
|
|
|
<!-- <$action-log/> -->
|
|
|
|
<!-- <$action-log ct=<<currentTiddler>> hasChildren=<<tf.toc-hasChildren>> path=<<path>> exclude=<<exclude>>/> -->
|
2024-02-07 19:27:23 +00:00
|
|
|
<!-- <$action-log toc-state=<<toc-state>> path=<<path>> exclude=<<exclude>> ct=<<currentTiddler>> /> -->
|
|
|
|
<!-- <$action-log ct=<<currentTiddler>> prefix=<<prefix>> toc-state=<<toc-state>>/> -->
|
|
|
|
|
|
|
|
\procedure toc-closeBranch(path,currentTiddler,manual:"no")
|
|
|
|
<% if [<modifier>match[ctrl]] :else[<manual>match[yes]] %>
|
2024-02-08 11:53:07 +00:00
|
|
|
<$let prefix={{{ [<tf.toc-stateTitle>] }}} >
|
|
|
|
<$action-deletetiddler $filter="[prefix<prefix>]"/>
|
|
|
|
</$let>
|
2024-02-07 19:27:23 +00:00
|
|
|
<% endif %>
|
|
|
|
\end
|
|
|
|
|
2024-02-01 17:53:55 +00:00
|
|
|
<!--
|
2024-02-07 13:32:22 +00:00
|
|
|
If a toc-item shows a link. Clicking the caption will open the tiddler
|
2024-02-07 11:45:12 +00:00
|
|
|
If toc-item is linked, the _itemTemplate is managed in the parent procedure
|
2024-05-04 13:28:11 +00:00
|
|
|
If a toc-item should not show a link, the _itemTemplate is part of the button. So it can be clicked to open or close one branch
|
|
|
|
The buttons also call toc-stateOpen and toc-stateClose, which by default allow us to CTRL-click to expand or fold the whole branch
|
2024-02-01 17:53:55 +00:00
|
|
|
-->
|
2024-02-01 17:07:40 +00:00
|
|
|
\procedure toc-item(isUnlinked:"")
|
2024-02-01 23:42:40 +00:00
|
|
|
<% if [<toc-state>get[text]else[close]match[close]] %>
|
2024-05-12 16:13:54 +00:00
|
|
|
<!-- <$button actions=<<toc-openBranch>> setTitle=<<toc-state>> setTo="open" class="tc-btn-invisible" tooltip=<<toc-state>>> -->
|
2024-05-13 12:10:29 +00:00
|
|
|
<$button actions=<<toc-openBranch>> setTitle=<<toc-state>> setTo="open" class="tc-btn-invisible tc-tiny-gap-right">
|
2024-02-01 23:42:40 +00:00
|
|
|
<$transclude tiddler=<<toc-closed-icon>> />
|
|
|
|
<% if [<isUnlinked>match[yes]] %>
|
2024-02-07 11:45:12 +00:00
|
|
|
<<_itemTemplate>>
|
2024-02-01 23:42:40 +00:00
|
|
|
<% endif %>
|
|
|
|
</$button>
|
|
|
|
<% elseif [<toc-state>get[text]match[open]] %>
|
2024-05-12 16:13:54 +00:00
|
|
|
<!-- <$button actions=<<toc-closeBranch>> setTitle=<<toc-state>> setTo="close" class="tc-btn-invisible" tooltip=<<toc-state>>> -->
|
2024-05-13 12:10:29 +00:00
|
|
|
<$button actions=<<toc-closeBranch>> setTitle=<<toc-state>> setTo="close" class="tc-btn-invisible tc-tiny-gap-right">
|
2024-02-01 23:42:40 +00:00
|
|
|
<$transclude tiddler=<<toc-open-icon>> />
|
|
|
|
<% if [<isUnlinked>match[yes]] %>
|
2024-02-07 11:45:12 +00:00
|
|
|
<<_itemTemplate>>
|
2024-02-01 23:42:40 +00:00
|
|
|
<% endif %>
|
|
|
|
</$button>
|
|
|
|
<% endif %>
|
2024-02-01 17:07:40 +00:00
|
|
|
\end
|
|
|
|
|
2024-02-07 12:17:38 +00:00
|
|
|
\procedure toc-linked-expandable-body(tag,sort:"",itemClassFilter,exclude,path,captionField,tagField,parentField,itemTemplate)
|
2024-02-01 17:53:55 +00:00
|
|
|
<$qualify name="toc-state" title=<<tf.toc-stateTitle>> >
|
2024-02-04 05:15:49 +00:00
|
|
|
<li class=<<tf.toc-itemClass>>>
|
2024-02-01 23:42:40 +00:00
|
|
|
<!-- v5.1.23 use target-field if present in tiddler -->
|
2024-02-01 17:07:40 +00:00
|
|
|
<$link to={{{ [<currentTiddler>get[target]else<currentTiddler>] }}}>
|
|
|
|
<<toc-item>>
|
2024-02-07 11:45:12 +00:00
|
|
|
<<_itemTemplate>>
|
2024-02-01 17:07:40 +00:00
|
|
|
</$link>
|
2024-02-01 20:51:53 +00:00
|
|
|
<!-- TODO auto expand -->
|
|
|
|
<% if [<toc-state>get[text]match[open]] %>
|
2024-02-07 11:45:12 +00:00
|
|
|
<$macrocall $name="toc-expandable"
|
2024-02-06 17:47:33 +00:00
|
|
|
tag=<<currentTiddler>> sort=<<sort>> exclude=<<exclude>> path=<<path>>
|
2024-02-07 12:17:38 +00:00
|
|
|
captionField=<<captionField>> tagField=<<tagField>> parentField=<<parentField>>
|
2024-02-07 11:45:12 +00:00
|
|
|
itemTemplate=<<itemTemplate>>
|
2024-02-01 17:53:55 +00:00
|
|
|
/>
|
2024-02-01 20:51:53 +00:00
|
|
|
<% endif %>
|
2024-02-01 17:07:40 +00:00
|
|
|
</li>
|
2018-11-06 15:29:13 +00:00
|
|
|
</$qualify>
|
2014-08-18 19:52:36 +00:00
|
|
|
\end
|
|
|
|
|
2024-02-07 12:17:38 +00:00
|
|
|
\procedure toc-unlinked-expandable-body(tag,sort:"",itemClassFilter,exclude,path,captionField,tagField,parentField,itemTemplate)
|
2024-02-01 17:53:55 +00:00
|
|
|
<$qualify name="toc-state" title=<<tf.toc-stateTitle>>>
|
2024-02-04 05:15:49 +00:00
|
|
|
<li class=<<tf.toc-itemClass>>>
|
2024-02-01 17:07:40 +00:00
|
|
|
<<toc-item isUnlinked:"yes">>
|
2024-02-01 20:51:53 +00:00
|
|
|
<!-- TODO auto expand -->
|
|
|
|
<% if [<toc-state>get[text]match[open]] %>
|
2024-02-07 11:45:12 +00:00
|
|
|
<$macrocall $name="toc-expandable"
|
2024-02-06 17:47:33 +00:00
|
|
|
tag=<<currentTiddler>> sort=<<sort>> exclude=<<exclude>> path=<<path>>
|
2024-02-07 12:17:38 +00:00
|
|
|
captionField=<<captionField>> tagField=<<tagField>> parentField=<<parentField>>
|
2024-02-07 11:45:12 +00:00
|
|
|
itemTemplate=<<itemTemplate>>
|
2024-02-01 17:53:55 +00:00
|
|
|
/>
|
2024-02-01 20:51:53 +00:00
|
|
|
<% endif %>
|
2024-02-01 17:07:40 +00:00
|
|
|
</li>
|
2018-11-06 15:29:13 +00:00
|
|
|
</$qualify>
|
2014-09-05 08:49:10 +00:00
|
|
|
\end
|
|
|
|
|
2024-02-01 18:23:48 +00:00
|
|
|
<!-- ==========================================================
|
|
|
|
Shows an expandable toc. Item always have an open/close chevron
|
|
|
|
=============================================================== -->
|
2024-02-07 12:17:38 +00:00
|
|
|
\procedure toc-expandable(tag,sort:"",itemClassFilter:"",exclude,path,captionField,tagField,parentField,itemTemplate)
|
2024-02-07 11:45:12 +00:00
|
|
|
<$set name=currentTiddler filter="[<parentField>!is[blank]then<tag>else<currentTiddler>]">
|
2024-02-04 04:16:22 +00:00
|
|
|
<ol class="tc-toc toc-expandable">
|
2024-05-04 13:28:11 +00:00
|
|
|
<!-- Text substitution is needed for backwards compatibility -->
|
2024-02-05 19:07:10 +00:00
|
|
|
<$list filter=` [subfilter<tf.toc-filter>]
|
2024-02-07 11:45:12 +00:00
|
|
|
:else[subfilter<tf.toc-filterString>$(sort)$]
|
2024-02-04 20:57:34 +00:00
|
|
|
[subfilter<tf.toc-include>] -[<tag>] -[subfilter<exclude>]`>
|
|
|
|
<%if [<currentTiddler>] -[subfilter<tf.toc-hide>] %>
|
2024-02-06 16:39:51 +00:00
|
|
|
<$let _path=<<tf.toc-newPath>>>
|
|
|
|
<$set name="_excluded" filter="[subfilter<exclude>] [<tag>] [subfilter<tf.toc-hide>]">
|
2024-02-04 05:15:49 +00:00
|
|
|
<% if [all[current]toc-link[no]] %>
|
2024-02-07 11:45:12 +00:00
|
|
|
<$macrocall $name="toc-unlinked-expandable-body"
|
2024-02-06 17:47:33 +00:00
|
|
|
tag=<<tag>> sort=<<sort>> exclude=<<_excluded>> path=<<_path>>
|
2024-02-07 12:17:38 +00:00
|
|
|
captionField=<<captionField>> tagField=<<tagField>> parentField=<<parentField>>
|
2024-02-07 11:45:12 +00:00
|
|
|
itemTemplate=<<itemTemplate>>
|
2024-02-04 05:15:49 +00:00
|
|
|
/>
|
|
|
|
<% else %>
|
2024-02-07 11:45:12 +00:00
|
|
|
<$macrocall $name="toc-linked-expandable-body"
|
2024-02-06 17:47:33 +00:00
|
|
|
tag=<<tag>> sort=<<sort>> exclude=<<_excluded>> path=<<_path>>
|
2024-02-07 12:17:38 +00:00
|
|
|
captionField=<<captionField>> tagField=<<tagField>> parentField=<<parentField>>
|
2024-02-07 11:45:12 +00:00
|
|
|
itemTemplate=<<itemTemplate>>
|
2024-02-04 05:15:49 +00:00
|
|
|
/>
|
|
|
|
<% endif %>
|
|
|
|
</$set>
|
|
|
|
</$let>
|
|
|
|
<% endif %>
|
2024-02-04 04:16:22 +00:00
|
|
|
</$list>
|
|
|
|
</ol>
|
2024-02-07 11:45:12 +00:00
|
|
|
</$set>
|
2014-08-19 11:30:22 +00:00
|
|
|
\end
|
|
|
|
|
2024-02-08 13:44:34 +00:00
|
|
|
\function tf.toc-curTidInclude() [<currentTiddler>get<toc-includeField>] [<currentTiddler>get<toc-filterField>]
|
2024-02-04 06:37:24 +00:00
|
|
|
|
2024-02-07 12:17:38 +00:00
|
|
|
\procedure toc-linked-selective-expandable-body(tag,sort:"",itemClassFilter,exclude,path,captionField,tagField,parentField,itemTemplate)
|
2024-02-01 17:53:55 +00:00
|
|
|
<$qualify name="toc-state" title=<<tf.toc-stateTitle>>>
|
2024-02-04 05:15:49 +00:00
|
|
|
<li class=<<tf.toc-itemClass>>>
|
2024-02-01 23:42:40 +00:00
|
|
|
<!-- v5.1.23 use target-field if present in tiddler -->
|
2024-02-01 17:07:40 +00:00
|
|
|
<$link to={{{ [<currentTiddler>get[target]else<currentTiddler>] }}}>
|
2024-05-04 13:28:11 +00:00
|
|
|
<!-- The subfilter<exclude> must to be the last filter run -->
|
2024-02-08 12:42:58 +00:00
|
|
|
<% if [subfilter<tf.toc-hasChildren>] [subfilter<tf.toc-curTidInclude>] -[<currentTiddler>] -[subfilter<exclude>] +[limit[1]] %>
|
2024-02-01 17:07:40 +00:00
|
|
|
<<toc-item>>
|
2024-02-01 17:53:55 +00:00
|
|
|
<% else %>
|
2024-05-13 12:10:29 +00:00
|
|
|
<$button class='tc-btn-invisible tc-tiny-gap-right' tabindex="-1">
|
2024-02-01 17:53:55 +00:00
|
|
|
{{$:/core/images/blank}}
|
|
|
|
</$button>
|
|
|
|
<% endif %>
|
2024-02-07 11:45:12 +00:00
|
|
|
<<_itemTemplate>>
|
2024-02-01 17:07:40 +00:00
|
|
|
</$link>
|
2024-02-01 20:51:53 +00:00
|
|
|
<!-- TODO auto expand -->
|
|
|
|
<% if [<toc-state>get[text]match[open]] %>
|
2024-02-07 11:45:12 +00:00
|
|
|
<$macrocall $name="toc-selective-expandable"
|
2024-02-06 17:47:33 +00:00
|
|
|
tag=<<currentTiddler>> sort=<<sort>> exclude=<<exclude>> path=<<path>>
|
2024-02-07 12:17:38 +00:00
|
|
|
captionField=<<captionField>> tagField=<<tagField>> parentField=<<parentField>>
|
2024-02-07 11:45:12 +00:00
|
|
|
itemTemplate=<<itemTemplate>>
|
2024-02-01 17:53:55 +00:00
|
|
|
/>
|
2024-02-01 20:51:53 +00:00
|
|
|
<% endif %>
|
2024-02-01 17:07:40 +00:00
|
|
|
</li>
|
2018-11-06 15:29:13 +00:00
|
|
|
</$qualify>
|
2014-08-19 11:30:22 +00:00
|
|
|
\end
|
2024-05-04 13:28:11 +00:00
|
|
|
<!-- Keep them for now -->
|
2024-02-08 12:42:58 +00:00
|
|
|
<!-- <$log ct=<<currentTiddler>>
|
|
|
|
includeList={{{ [subfilter<tf.toc-hasChildren>] [subfilter<tf.toc-curTidInclude>] -[subfilter<exclude>] +[limit[1]] }}}
|
2024-05-04 13:28:11 +00:00
|
|
|
hasChildren={{{ [subfilter<tf.toc-hasChildren>] }}} path=<<path>> exclude=<<exclude>>/>
|
|
|
|
-->
|
|
|
|
<!-- <$log
|
|
|
|
ct=<<currentTiddler>>
|
|
|
|
tf.toc-hasChildren=<<tf.toc-hasChildren>>
|
|
|
|
tf.toc-hasChildren-f= {{{ [subfilter<tf.toc-hasChildren>]
|
|
|
|
exclude=<<exclude>> }}}
|
|
|
|
filter={{{ [subfilter<tf.toc-hasChildren>] [subfilter<tf.toc-curTidInclude>] -[<currentTiddler>] -[subfilter<exclude>] }}}
|
|
|
|
/> -->
|
2014-08-19 11:30:22 +00:00
|
|
|
|
2024-02-07 12:17:38 +00:00
|
|
|
\procedure toc-unlinked-selective-expandable-body(tag,sort:"",itemClassFilter,exclude,path,captionField,tagField,parentField,itemTemplate)
|
2024-02-01 17:53:55 +00:00
|
|
|
<$qualify name="toc-state" title=<<tf.toc-stateTitle>> >
|
2024-02-04 05:15:49 +00:00
|
|
|
<li class=<<tf.toc-itemClass>>>
|
2024-02-08 12:42:58 +00:00
|
|
|
<% if [subfilter<tf.toc-hasChildren>] [subfilter<tf.toc-curTidInclude>] -[<currentTiddler>] -[subfilter<exclude>] +[limit[1]] %>
|
2024-02-01 17:07:40 +00:00
|
|
|
<<toc-item isUnlinked:"yes">>
|
2024-02-01 17:53:55 +00:00
|
|
|
<% else %>
|
2024-05-13 12:10:29 +00:00
|
|
|
<$button class="tc-btn-invisible tc-tiny-gap-right">
|
2024-02-01 17:53:55 +00:00
|
|
|
{{$:/core/images/blank}}
|
|
|
|
</$button>
|
|
|
|
<span class="toc-item-muted">
|
2024-02-07 11:45:12 +00:00
|
|
|
<<_itemTemplate>>
|
2024-02-01 17:53:55 +00:00
|
|
|
</span>
|
|
|
|
<% endif %>
|
2024-02-01 20:51:53 +00:00
|
|
|
<!-- TODO auto expand -->
|
|
|
|
<% if [<toc-state>get[text]match[open]] %>
|
2024-02-07 11:45:12 +00:00
|
|
|
<$macrocall $name="toc-selective-expandable"
|
2024-02-06 17:47:33 +00:00
|
|
|
tag=<<currentTiddler>> sort=<<sort>> exclude=<<exclude>> path=<<path>
|
2024-02-07 12:17:38 +00:00
|
|
|
captionField=<<captionField>> tagField=<<tagField>> parentField=<<parentField>>
|
2024-02-07 11:45:12 +00:00
|
|
|
itemTemplate=<<itemTemplate>>
|
2024-02-01 17:53:55 +00:00
|
|
|
/>
|
2024-02-01 20:51:53 +00:00
|
|
|
<% endif %>
|
2024-02-01 17:07:40 +00:00
|
|
|
</li>
|
2018-11-06 15:29:13 +00:00
|
|
|
</$qualify>
|
2014-09-05 08:49:10 +00:00
|
|
|
\end
|
|
|
|
|
2024-02-01 18:23:48 +00:00
|
|
|
<!-- =====================================================
|
2024-05-04 13:28:11 +00:00
|
|
|
Shows a selctive expandable toc.
|
2024-02-01 18:23:48 +00:00
|
|
|
If an item has no children, there is no open/close chevron
|
|
|
|
========================================================== -->
|
2024-02-07 12:17:38 +00:00
|
|
|
\procedure toc-selective-expandable(tag,sort:"",itemClassFilter,exclude,path,captionField,tagField,parentField,itemTemplate)
|
2024-02-07 11:45:12 +00:00
|
|
|
<$set name=currentTiddler filter="[<parentField>!is[blank]then<tag>else<currentTiddler>]">
|
2024-02-04 04:16:22 +00:00
|
|
|
<ol class="tc-toc toc-selective-expandable">
|
|
|
|
<!-- text substitution is needed for backwards compatibility -->
|
2024-02-05 19:07:10 +00:00
|
|
|
<$list filter=` [subfilter<tf.toc-filter>]
|
2024-02-07 11:45:12 +00:00
|
|
|
:else[subfilter<tf.toc-filterString>$(sort)$]
|
2024-02-04 20:57:34 +00:00
|
|
|
[subfilter<tf.toc-include>] -[<tag>] -[subfilter<exclude>]`>
|
|
|
|
<%if [<currentTiddler>] -[subfilter<tf.toc-hide>] %>
|
2024-02-06 16:39:51 +00:00
|
|
|
<$let _path=<<tf.toc-newPath>>>
|
|
|
|
<$set name="_excluded" filter="[subfilter<exclude>] [<tag>] [subfilter<tf.toc-hide>]">
|
2024-02-04 05:15:49 +00:00
|
|
|
<% if [all[current]toc-link[no]] %>
|
2024-02-07 11:45:12 +00:00
|
|
|
<$macrocall $name="toc-unlinked-selective-expandable-body"
|
2024-02-06 17:47:33 +00:00
|
|
|
tag=<<tag>> sort=<<sort>> exclude=<<_excluded>> path=<<_path>>
|
2024-02-07 12:17:38 +00:00
|
|
|
captionField=<<captionField>> tagField=<<tagField>> parentField=<<parentField>>
|
2024-02-07 11:45:12 +00:00
|
|
|
itemTemplate=<<itemTemplate>>
|
2024-02-04 05:15:49 +00:00
|
|
|
/>
|
|
|
|
<% else %>
|
2024-02-07 11:45:12 +00:00
|
|
|
<$macrocall $name="toc-linked-selective-expandable-body"
|
2024-02-06 17:47:33 +00:00
|
|
|
tag=<<tag>> sort=<<sort>> exclude=<<_excluded>> path=<<_path>>
|
2024-02-07 12:17:38 +00:00
|
|
|
captionField=<<captionField>> tagField=<<tagField>> parentField=<<parentField>>
|
2024-02-07 11:45:12 +00:00
|
|
|
itemTemplate=<<itemTemplate>>
|
2024-02-04 05:15:49 +00:00
|
|
|
/>
|
|
|
|
<% endif %>
|
|
|
|
</$set>
|
|
|
|
</$let>
|
|
|
|
<% endif %>
|
2024-02-04 04:16:22 +00:00
|
|
|
</$list>
|
|
|
|
</ol>
|
2024-02-07 11:45:12 +00:00
|
|
|
</$set>
|
2014-08-18 19:52:36 +00:00
|
|
|
\end
|
2014-11-13 21:39:28 +00:00
|
|
|
|
2024-05-04 13:28:11 +00:00
|
|
|
<!-- ====================================================================
|
2024-02-01 18:23:48 +00:00
|
|
|
Shows a tabbed toc.
|
2024-05-04 13:28:11 +00:00
|
|
|
If a toc-item link is clicked it will open the tiddler in the story river
|
|
|
|
========================================================================= -->
|
2024-02-07 12:17:38 +00:00
|
|
|
\procedure toc-tabbed-external-nav(tag,sort:"",selectedTiddler:"$:/temp/toc/selectedTiddler",unselectedText,missingText,template:"",exclude,captionField,tagField,parentField,itemTemplate)
|
2024-02-01 17:07:40 +00:00
|
|
|
<$tiddler tiddler={{{ [<selectedTiddler>get[text]] }}}>
|
|
|
|
<div class="tc-tabbed-table-of-contents">
|
|
|
|
<$linkcatcher to=<<selectedTiddler>>>
|
|
|
|
<div class="tc-table-of-contents">
|
2024-02-04 06:37:24 +00:00
|
|
|
<!-- v5.3.4 itemClassFilter has been replaced by tf.toc-itemClassFilter -->
|
2024-02-07 11:45:12 +00:00
|
|
|
<$macrocall $name="toc-selective-expandable"
|
|
|
|
tag=<<tag>> sort=<<sort>> exclude=<<exclude>>
|
2024-02-07 12:17:38 +00:00
|
|
|
captionField=<<captionField>> tagField=<<tagField>> parentField=<<parentField>>
|
2024-02-07 10:30:10 +00:00
|
|
|
itemTemplate=<<itemTemplate>>
|
2024-02-01 17:07:40 +00:00
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</$linkcatcher>
|
|
|
|
<div class="tc-tabbed-table-of-contents-content">
|
|
|
|
<$reveal stateTitle=<<selectedTiddler>> type="nomatch" text="">
|
|
|
|
<$transclude mode="block" tiddler=<<template>>>
|
2024-02-07 11:45:12 +00:00
|
|
|
<h1><<_itemTemplate>></h1>
|
2024-02-01 17:07:40 +00:00
|
|
|
<$transclude mode="block">$missingText$</$transclude>
|
|
|
|
</$transclude>
|
|
|
|
</$reveal>
|
|
|
|
<$reveal stateTitle=<<selectedTiddler>> type="match" text="">
|
|
|
|
<<unselectedText>>
|
|
|
|
</$reveal>
|
|
|
|
</div>
|
|
|
|
</div>
|
2014-11-13 21:39:28 +00:00
|
|
|
</$tiddler>
|
2014-11-14 17:06:21 +00:00
|
|
|
\end
|
|
|
|
|
2024-02-01 18:23:48 +00:00
|
|
|
<!-- ========================================================
|
2024-05-04 13:28:11 +00:00
|
|
|
Shows a tabbed toc. If a toc-item link is clicked
|
2024-02-01 18:23:48 +00:00
|
|
|
it will open the tiddler in the view area of the same tiddler
|
|
|
|
============================================================= -->
|
2024-02-07 12:17:38 +00:00
|
|
|
\procedure toc-tabbed-internal-nav(tag,sort:"",selectedTiddler:"$:/temp/toc/selectedTiddler",unselectedText,missingText,template:"",exclude,captionField,tagField,parentField,itemTemplate)
|
2024-02-01 17:07:40 +00:00
|
|
|
<$linkcatcher to=<<selectedTiddler>>>
|
2024-02-07 11:45:12 +00:00
|
|
|
<$macrocall $name="toc-tabbed-external-nav"
|
2024-02-01 17:07:40 +00:00
|
|
|
tag=<<tag>>
|
|
|
|
sort=<<sort>>
|
|
|
|
selectedTiddler=<<selectedTiddler>>
|
|
|
|
unselectedText=<<unselectedText>>
|
|
|
|
missingText=<<missingText>>
|
|
|
|
template=<<template>>
|
|
|
|
exclude=<<exclude>>
|
2024-02-07 12:17:38 +00:00
|
|
|
captionField=<<captionField>>
|
2024-02-07 11:45:12 +00:00
|
|
|
tagField=<<tagField>>
|
|
|
|
parentField=<<parentField>>
|
2024-02-07 10:30:10 +00:00
|
|
|
itemTemplate=<<itemTemplate>>
|
2024-02-01 17:07:40 +00:00
|
|
|
/>
|
2014-11-13 21:39:28 +00:00
|
|
|
</$linkcatcher>
|
2024-02-10 16:58:33 +00:00
|
|
|
\end
|