<<dbadge AGL Vorlage type:info>>
''Fields''
Art
Reihenfolge
AGL
Gesetz
Rechtsfolge
\define dbadge(subject,status, type:"primary")
<div class="dbadge"><span class="dbadge-subject">$subject$</span><span class="dbadge-status dbadge-$type$ ">$status$</span></div>
\end
/*Credits:
Nishant Srivastava https://codepen.io/nisrulz/pen/bpQWLW
Mohammad Rahmani: https://github.com/kookma
*/
.dbadge {
display: inline-block;
margin: 0.0em;
}
.dbadge > span {
color: #ffffff;
font-size: 0.8em;
font-weight: 400;
line-height: 1;
padding: .2em .6em;
text-align: center;
vertical-align: baseline;
white-space: nowrap;}
.dbadge-subject{
background-color: #656565;
border-bottom-left-radius: 0.25em;
border-top-left-radius: 0.25em;}
.dbadge-status {
border-bottom-right-radius: 0.25em;
border-top-right-radius: 0.25em;}
.dbadge-primary {
background-color: #337ab7;}
.dbadge-success {
background-color: #5cb85c;}
.dbadge-info {
background-color: #5bc0de;}
.dbadge-warning {
background-color: #f0ad4e;}
.dbadge-danger {
background-color: #d9534f;}
A topical index of known plugins, tutorials, themes, and other helpful tools for ~TiddlyWiki.
{{!!url}}
Some of the topics indexed so far include:
* Background images and background colors
* Breadcrumbs
* Business - examples
* CSS / Styles, general
* Calendars, dates and timelines
* Checklists
* Collaboration
* Color palettes
* Colors
* Data visualizations
* Developer / advanced tools
* Diplay tiddlers horizontally
* Dropdowns
* Educational
* External files
* Fields
* Fonts
* Fun and games
* Home and lifestyle
* IFrames and embedding media
* Image galleries, modals and lightboxes
* Images, icons, emojis
* Importing and exporting between TiddlyWiki files
* Includes scaffolding within a tiddler, dragging to reorder tiddlers, choosing the number of columns
* Interfacing with, importing and exporting to and from other formats
* Knowledge bases, dictionaries and glossaries
* Layout/UI
* Lightboxes
* Links, linking
* Lists and filters
* Maps and geography
* Masonry, scaffolding
* Math
* ~MindMapping
* Mobile tools
* Music and sound
* Navigation
* node.js
* Note-taking
* Open the "filter" tab
* Partially hidden tiddlers
* Personal websites (examples)
* Presentations and slideshows
* Printing
* Project management
* Publishing and hosting TiddlyWikis on the web
* Searching tools
* Security and backup tools
* Social media, sharing, comments
* Spreadsheets and math
* Startup
* Sticky titles
* Story and screenplay creation
* Table of contents
* Tables, charts and graphs (cf data visualizations)
* Tabs
* Tags, tagging
* Task management and productivity - to do lists
* Themes
* Understanding TiddlyWiki
* Writing and editing
\define extract(tiddler,start:""" """,end:"""ç-noEnd-ç""",prefix:"""""",suffix:"""""",
limit:"yes",class:"", rmQuotes:'no' mode:"block")
<$vars start="""$start$""" end="""$end$""" prefix="""$prefix$""" suffix="""$suffix$""">
<$set name="tid" filter="[field:title[$tiddler$]]" value="""$tiddler$""" emptyValue=<<currentTiddler>>>
<$list variable="fulltext" filter="""[<tid>get[text]addprefix[ ]addsuffix[ç-noEnd-ç]]""" emptyValue="$start$ error: no text field $end$ ç-noEnd-ç">
<$list variable="beforeStart" emptyMessage="filter error"
filter="""[<fulltext>splitbefore<start>]""">
<$list variable="firstRest" filter="[<fulltext>removeprefix<beforeStart>]">
<span class="te-summary $class$">
<$macrocall $name="extractSnippet" rest=<<firstRest>> start=<<start>> end=<<end>> prefix=<<prefix>> suffix=<<suffix>> limit="$limit$" rmQuotes='$rmQuotes$' mode="$mode$"/>
</span>
</$list>
</$list>
</$list>
</$set>
</$vars>
\end
\define extractSnippet(rest,start,end,prefix,suffix,limit,rmQuotes,mode)
<$vars text="""$rest$""" start="""$start$""" end="""$end$""" prefix="""$prefix$""" suffix="""$suffix$""">
<$list variable="snippet" filter="""[<text>splitbefore<end>removesuffix<end>]""" emptyValue="summary empty">
<$set name="mymode" filter="""[[$mode$]removeprefix[block]]""" value="blockOutput" emptyValue="inlineOutput">
<$set name="snipify" filter="""[[$mode$]removeprefix[link]]""" value="linkedOutput" emptyValue=<<mymode>>>
<$set name="extracted" filter="""[[$rmQuotes$]removeprefix[no]]""" value=<<noQuotes>> emptyValue=<<removeQuotes>>>
<$macrocall $name=<<snipify>>/>
</$set>
</$set>
</$set>
<$list variable="newRest" filter="""[<text>removeprefix<snippet>removeprefix<end>]"""
emptyValue="never empty">
<$set name="unlimited" filter="""[[$limit$]removeprefix[y]]""" emptyValue="checkRest">
<$macrocall $name=<<unlimited>> rest=<<newRest>> start=<<start>> end=<<end>> prefix=<<prefix>> suffix=<<suffix>> limit="$limit$" rmQuotes='$rmQuotes$' mode="$mode$"/>
</$set>
</$list>
</$list>
</$vars>
\end
\define linkedOutput()
$(prefix)$[[$(extracted)$]]$(suffix)$
\end
\define inlineOutput()
$(prefix)$$(extracted)$$(suffix)$
\end
\define blockOutput()
<span>
$(prefix)$$(extracted)$$(suffix)$
</span>
\end
\define checkRest(rest,start,end,prefix,suffix,limit,rmQuotes,mode)
<$set name="text" value="""$rest$""">
<$list variable="beforeStart" filter="""[<text>splitbefore[$start$]]""">
<$set name="proceed" filter="""[<beforeStart>removesuffix[$start$]] +[addsuffix[ç-TestPassed-ç]]"""
emptyValue="es">
<$set name="proceedto" filter="""[<proceed>removesuffix[ç-TestPassed-ç]regexp[es]]""" emptyValue="extractSnippet">
<$list variable="newRest" filter="""[<text>removeprefix<beforeStart>]""">
<$macrocall $name=<<proceedto>> rest=<<newRest>> start="""$start$""" end="""$end$""" prefix="""$prefix$""" suffix="""$suffix$""" limit="$limit$" rmQuotes='$rmQuotes$' mode="$mode$"/>
</$list>
</$set>
</$set>
</$list>
</$set>
\end
\define es()
<span class='summaryend'></span>
\end
\define removeQuotes()
<$vars output=$(snippet)$>
<<output>>
</$vars>
\end
\define noQuotes()
$(snippet)$
\end
<!-- !! Extract Macro Documentation
* Version: 0.9.3
** Bugfix for capturing the beginning of a text with no start parameter
** Minor cleanup
* parameters
** tiddler – if not provided, the current tiddler is used
** start and end – text-identifiers that sourround the snippet you want to extract
** prefix and suffix – text to attach to the result
** limit – defaults to "yes" and produces one result, collects all matches if set to "no"
** class – CSS class(es) to append to the surrounding span
** rmQuotes – defaults to 'no', removes surrounding quotes (") when set to "yes"
** mode – defaults to "block", set to "inline" to omit surrounding tags, set to "link" to get links in inline mode
!!! Advantages
* find content to extract based on common markup or comments
* handle wiki syntax where start and end are the same, e.g. `''` or `//`
* ''start or end can be omitted when extracting the beginning or to the end of the text''
* to collect several snippets from the same tiddler set limit to "no"
-->
<!-- !!! FAQ
; The output is something like " end:" – what can I do?
: This happens, when you try to extract from the tiddler, where the extract macro is called: the macro call contains the start marker. Solutions:
* if you are using a filter, exclude the calling tiddler using ![tiddler]
* transclude the macrocall from somewhere else, e.g. from a field in the tiddler
; The list widget produces results only for tiddlers without spaces in the title?
: Lists need to be constructed carefully according to the examples below. Macro calls from lists with the parameter `tiddler=<<tiddler>>` and similar work only for titles without spaces.
* see: http://tid.li/tw5/hacks.html#Tweeting for a working example
* or: http://tid.li/tw5/numbers.html
; Can I use start or end markers containing " (quotes)?
: This will not work – but you can remove surrounding quotes by setting rmQuotes to "yes".
-->
<!-- !!! Procedure – How it Works
* get the text field of the tiddler
** cut off everything before the first start tag, including start tag
* extract a snippet from the rest
** ''put texts in variables to avoid problems with square brackets''
** cut after end tag, remove end tag
** prepend prefix, output snippet, append the suffix
* check, if limit is "no", else exit via es()
** es() prints an empty span which can be used for design purposes
* check the rest
** cut off everything before start tag, including start tag and save in //beforeStart// (contains all text if no start tag is found)
** try to remove start tag from beforeStart, if found, add a confirmation suffix
*** no start tag? => exit via es()
** if a start tag exists, proceed with extracting
!!! Missing – Ideas for Improvement
* allow users to specify an empty-message
* support for some kinds of transclusion (e.g. from a tiddler’s own fields)
* Possible optimisations (low priority)
** limit to a defined number of loops
** limit to a defined number of chars – this might not be useful as tags could get cut in pieces.
-->
\define ref(content:"empty")
<$macrocall $name="strex" content="""$content$""" label="​" start="start" end="​" class="hint numbers"/>
\end
\define slice(tiddler,nr,mode:"block")
<$macrocall $name="extract" tiddler="""$tiddler$""" start="<sli$nr$>" end="</sli$nr$>" mode="$mode$" class="slice"/>
\end
\define strex(content:"TextStretch", label:"…", start:"[", end:"]", class:"", id:"_false_")
<$vars content="""$content$""" id="""$id$""">
<$set name="uid" filter="[<id>!prefix[_false_]]" value=<<id>> emptyValue=<<content>> >
<span class="strex-container $class$"><$macrocall $name="strexx" content=<<content>> label="""$label$""" start="""$start$""" end="""$end$""" class="""$class$""" uid=<<uid>>/></span>
</$set>
</$vars>
\end
\define strexx(content, label, start, end, class, uid)
<$set name="xuid" filter="[<uid>prefix[_false_]]" value="error: xuid hashing" emptyValue=<<HashStr """$uid$""">> >
<$macrocall $name="strexxx" content="""$content$""" label="""$label$""" start="""$start$""" end="""$end$""" class="""$class$""" xuid=<<xuid>>/>
</$set>
\end
\define strexxx(content, label, start, end, class, xuid)
<$vars content="""$content$""" label="""$label$""" start="""$start$""" end="""$end$""" class="""$class$""" xuid="""$xuid$""">
<$set name="qualstate" value=<<qualify "$:/state/strex_$xuid$_">> >
<$vars openclass="strex-open $class$" contentclass="strex-content $class$" startclass="strex-close strex-start $class$" endclass="strex-close strex-end $class$">
<$reveal type="nomatch" state=<<qualstate>> text="visible" animate="yes"><$button set=<<qualstate>> setTo="visible" class=<<openclass>> tooltip="show text part"><<label>></$button></$reveal><$reveal type="match" state=<<qualstate>> text="visible" animate="yes">
<span class="strex-all $class$"><span class="strex-inner $class$"><$button class=<<startclass>> tooltip="hide text part">$start$<$action-deletetiddler $tiddler=<<qualstate>>/></$button><span class=<<contentclass>> > <<content>> </span></span><$button class=<<endclass>> tooltip="hide text part">$end$<$action-deletetiddler $tiddler=<<qualstate>>/></$button></span></$reveal>
</$vars>
</$set>
</$vars>
\end
<!-- step 1 (x): check for id, replace with content if param is empty -->
<!-- step 2 (xx): hash id -->
<!-- step 3 (xxx): generate output, use state with hashed id -->
/* strex standard styling */
.strex-container, .strex-container .tc-reveal, .strex-all {
position:relative;
}
.strex-open, .strex-start, .strex-end {
color: <<colour tiddler-link-foreground>>;
padding: 0 6px 3px 6px;
line-height: 96%;
background-color: #f0f0f0;
border: 1px solid lightgray;
}
.strex-open:hover, .strex-start:hover, .strex-end:hover {
border: 1px solid black;
}
.strex-open:active, .strex-start:active, .strex-end:active,
.strex-open:focus, .strex-start:focus, .strex-end:focus {
border: 1px solid lightgray;
}
.strex-content .tc-reveal .strex-close {
color: <<colour foreground>>;
}
.strex-content {
color: #c44;
display:inline;
-webkit-animation: expandtext 1s ease 0s running;
animation-name: expandtext;
animation-duration: 1s;
animation-timing-function: ease;
animation-delay: 0s;
animation-iteration-count: 1;
animation-direction: normal;
}
.strex-content .tc-reveal .strex-content {
color: #766;
}
/* * * * * * * * * * * *
** Footnotes with Numbers
* * * * * * * * * * * * */
body {
counter-reset: notenr; /* set counter to 0 */
}
div .tc-tiddler-frame {
counter-reset: tidnotenr;
}
.strex-container.storynumbers {
counter-increment: notenr; /* counter +1 */
}
.strex-container.numbers {
counter-increment: tidnotenr;
}
button.strex-open.storynumbers::before,
button.strex-start.storynumbers::before {
content: counter(notenr); /* Display the counter */
font-size: xx-small;
vertical-align: top;
}
button.strex-end.storynumbers::after {
content: counter(notenr);
font-size: xx-small;
vertical-align: top;
}
button.strex-open.numbers::before,
button.strex-start.numbers::before {
content: counter(tidnotenr);
}
button.strex-end.numbers::after {
content: counter(tidnotenr);
}
/* Footer Collection as Numbered List `<ol>` */
.footnotes p ol {
list-style-type: none;
margin: 0;
padding: 0;
counter-reset: li-counter;
}
.footnotes p ol span > li {
position: relative;
margin-bottom: 0.6em;
margin-left: 2.25rem;
padding: 0.2em;
background-color: <<colour sidebar-tab-background-selected>>;
min-height: 2.1em;
}
.footnotes p ol span > li:before {
position: absolute;
top: 0;
width: 1.75rem;
height: 1.75rem;
font-size: 0.75rem;
line-height: 1;
text-align: right;
color: <<colour sidebar-tab-foreground>>;
background-color: <<colour sidebar-tab-background>>;
content: counter(li-counter);
counter-increment: li-counter;
padding: 0.1em 0.2em 0.2em 0.1em;
margin-left: -2.5rem;
}
/* * * * * * * * * * * *
** Special Styles
* * * * * * * * * * * * */
/* hidden parts */
.strex-content.nocontent, .strex-start.nostart, .strex-end.noend, .strex-close.noclose {
display: none;
}
/* standard text color */
.strex-content.standardcolor {
color: <<colour foreground>>;
}
/* block */
.strex-content.block, .strex-inner.blockinner,
.strex-container.blockcontainer {
display: block;
}
/* hint */
.strex-inner.hint {
position: absolute;
min-width: 220px;
background-color: rgb(252, 254, 211);
border: 1px solid black;
box-shadow: 5px 5px 10px #aaa;
padding: 15px 13px 12px 15px;
margin: 24px 0 0 -5px;
z-index: 998;
}
.strexXX-inner.hint {
display: block;
}
.strex-start.hint {
letter-spacing: -0.5em;
color: rgba(1,1,1,0) !important;
background-color: transparent;
border: 0;
position: absolute;
padding: 0 6px 3px;
right: 10px;
top: 5px;
}
.strex-inner.hint button::before {
content: " ×";
font-size: 1.2em;
color: <<colour tiddler-link-foreground>>;
}
.strex-content.hint {
padding-right: 10px;
}
/* note top right */
.strex-inner.note {
background-color: rgb(252, 254, 211);
border: 1px solid black;
box-shadow: 5px 5px 10px #aaa;
display: block;
min-width: 220px;
padding: 26px 10px 15px 15px;
position: fixed;
right: 5%;
top: 5%;
z-index: 998;
}
.strex-start.note {
position: absolute;
padding: 0 6px 3px;
right: 5px;
top: 5px;
}
.strex-content.note {
padding-right: 10px;
}
/* note flex */
.strex-inner.noteflex {
background-color: rgb(252, 254, 211);
border: 1px solid black;
box-shadow: 5px 5px 10px #aaa;
display: flex;
flex-flow: column wrap;
min-width: 220px;
padding: 10px 15px 15px 15px;
position: fixed;
right: 5%;
top: 5%;
z-index: 999;
justify-content: center;
}
.strex-start.noteflex {
display: flex;
order: 2;
margin: 10px auto 1px;
order: 2;
padding: 3px 10px 5px;
}
.strex-content.noteflex {
display: flex;
order: 1;
margin-top: 8px;
width: 100%;
}
/* * * * * * * * * * * *
** stretch animation
* * * * * * * * * * * * */
@keyframes expandtext {
0% {
letter-spacing: -0.48em;
rotateY(88deg);
opacity: 0;
}
70.0% {
opacity: 0.35;
}
100.0% {
letter-spacing: 0;
rotateY(0deg);
opacity: 1;
}
}
@-webkit-keyframes expandtext {
0% {
letter-spacing: -0.48em;
rotateY(88deg);
opacity: 0;
}
100.0% {
letter-spacing: 0;
rotateY(0deg);
opacity: 1;
}
}
\define summary(tiddler,start:"<header>",end:"</header>",suffix:"")
<$vars tid="""$tiddler$""">
<$list variable="beforeEndTag" emptyMessage="Error: no end marker"
filter="""[<tid>get[text]splitbefore[$end$]removesuffix[$end$]addsuffix[$suffix$]] +[first[]]""">
<$list variable="toRemove"
emptyMessage="Hint: If start is missing, we remove everything; the result is empty."
filter="""[<beforeEndTag>splitbefore[$start$]]""">
<$list variable="output" emptyMessage="Hint: We fail before, not here."
filter="""[<beforeEndTag>removeprefix<toRemove>]""">
<<output>>
</$list>
</$list>
</$list>
</$vars>
\end
\define summary3(tiddler,start:"<header>",end:"</header>",suffix:" …")
<$vars tid="""$tiddler$""">
<$set name="toRemove" filter="[<tid>get[text]splitbefore[$start$]]" select="0">
<$macrocall $name="summaryCutStart" tiddler="$tiddler$" start="$start$" end="$end$" suffix="$suffix$" prefix=<<toRemove>>/>
</$set>
</$vars>
\end
\define summaryCutStart(tiddler,start:"<header>",end:"</header>",suffix:" …",prefix:"")
<$set name="tiddler" filter="[field:title[$tiddler$]]" emptyValue=<<currentTiddler>>>
<$tiddler tiddler=$tiddler$>
<$list emptyMessage="Error: no end marker"
filter="[<currentTiddler>get[text]splitbefore[$end$]removesuffix[$end$]addsuffix[$suffix$]removeprefix[$prefix$]] +[first[]]">
<div style="color:grey;">
<<currentTiddler>>
</div>
</$list>
</$tiddler>
</$set>
\end
\define summary2(tiddler,start:"<header>",end:"</header>",suffix:" …")
<$set name="tiddler" filter="[field:title[$tiddler$]]" emptyValue=<<currentTiddler>>>
<$tiddler tiddler=$tiddler$>
<$list emptyMessage="Error: no end marker"
filter="""[<currentTiddler>get[text]splitbefore[$end$]removesuffix[$end$]addsuffix[$suffix$]] +[first[]]""">
<$set name="toRemove" filter="""[<tiddler>get[text]splitbefore[$start$]]""">
<div style="color:green;">
<<toRemove>>
</div>
<$list emptyMessage="Hint: We fail before, not here."
filter="""[<currentTiddler>removeprefix<toRemove>]""">
<div style="color:grey;">
<<currentTiddler>>
</div>
</$list>
</$set>
</$list>
</$tiddler>
</$set>
\end
/*\
title: $:/core/modules/macros/HashStr.js
type: application/javascript
module-type: macro
Generate a numeric hash from a string
uses $:/core/modules/utils/utils.js
\*/
(function(){
/*jslint node: true, browser: true */
/*global $tw: false */
"use strict";
/*
Information about this macro
*/
exports.name = "HashStr";
exports.params = [
{name: "str"}
];
/*
Run the macro
*/
exports.run = function(str) {
var hash = $tw.utils.hashString(str);
return hash;
};
})();
\define new-field-value-dropdown()
<$button popup=<<qualify "$:/state/popup/field-value-dropdown">>
class="tc-btn-invisible tc-btn-dropdown nfvd-center">
{{$:/core/images/down-arrow}}
</$button>
<$reveal state=<<qualify "$:/state/popup/field-value-dropdown">>
type="nomatch" text="" default="" class="nfvd-center">
<div class="tc-block-dropdown tc-edit-type-dropdown">
<$linkcatcher to="$:/temp/newfieldvalue">
<div class="tc-dropdown-item">
<$list filter="[[$:/temp/newfieldname]!has[text]]">
Enter field name to then select field value
</$list>
<$list filter="[[$:/temp/newfieldname]has[text]]">
"{{$:/temp/newfieldname}}" values in other tiddlers:
</$list>
</div>
<$list filter="[[$:/temp/newfieldname]!text[list-before]!text[list-after]]">
<$list filter="[all[shadows+tiddlers]has{$:/temp/newfieldname}count[]prefix[0]]">
[Previously unused field name]
</$list>
<$list filter="[all[shadows+tiddlers]has{$:/temp/newfieldname}get{$:/temp/newfieldname}each[]]" variable="currentValue">
<$link to=<<currentValue>>>
<<currentValue>>
</$link>
</$list>
</$list>
<$list filter="[[$:/temp/newfieldname]text[list-before]] [[$:/temp/newfieldname]text[list-after]]">
<<list-before/after>>
</$list>
</$linkcatcher>
</div>
</$reveal>
\end
\define list-before/after()
<div class="smaller-dropdown">
,,ViewTemplates,,
<$list filter="[all[shadows+tiddlers]tag[$:/tags/ViewTemplate]prefix[$:/core/ui/ViewTemplate/]]"><$link to={{!!title}}><$view field=title/></$link>
</$list>
,,Custom ViewTemplates,,
<$list filter="[all[shadows+tiddlers]tag[$:/tags/ViewTemplate]!prefix[$:/core/ui/ViewTemplate/]!prefix[Draft of]]"><$link to={{!!title}}><$view field=title/></$link>
</$list>
,,EditTemplates,,
<$list filter="[all[shadows+tiddlers]tag[$:/tags/EditTemplate]prefix[$:/core/ui/EditTemplate/]]"><$link to={{!!title}}><$view field=title/></$link>
</$list>
,,Custom EditTemplates,,
<$list filter="[all[shadows+tiddlers]tag[$:/tags/EditTemplate]!prefix[$:/core/ui/EditTemplate/]!prefix[Draft of]]">
<$link to={{!!title}}><$view field=title/></$link>
</$list>
</div>
\end
<<new-field-value-dropdown>>
<style>
.nfvd-center {margin:0 auto; display:block;}
.nfvd-center .tc-block-dropdown {margin-left:20%;}
.smaller-dropdown > a {padding:0; margin-left:14px}
</style>
\define tselement(tid,cur)
{{$cur$||$tid$}}
\end
<div id="ts_outer"><div id="ts_inner"><div class="tidsidebar">
<div class="ts_menu">
<$set name="cur" value=<<currentTiddler>>>
<$list filter="[tag[$:/TiddlerSidebar]]">
<div class="ts_item"><div class="ts_tab">{{!!title}}</div><div class="ts_content"><$macrocall $name=tselement tid={{!!title}} cur=<<cur>>/>
</div></div>
</$list></$set>
</div> <!-- closing of ts_menu --->
<div class="ts_nomenu"></div>
</div></div></div>
<style>
#ts_outer { position: relative; }
#ts_inner { position: absolute; left: -40px; top: 0px;}
.ts_nomenu { display:block; position:absolute; width:42px; height:130px; top:-70px; z-index:9999;}
.ts_menu { display: none; position:absolute; z-index:10001; min-width:42px; }
.tidsidebar:hover .ts_menu{ display:block; background-color:lightblue; }
.ts_item {border: 1px solid lightgray; border-right:0; border-left:0; line-height:300%; padding-left:3px; color:gray; }
.ts_content {display:none; position:absolute; }
.ts_item:hover {color:black;}
.ts_menu:hover .ts_content{z-index:10000;}
.ts_item:hover .ts_content{ display:inline-block; top:0px; border: 1px solid lightgray; border-left:0; padding:15px; background-color:lightblue; font-size:90%; min-width:250px; min-height:100%; line-height:130%; font-weight:normal; color:darkblue; box-shadow: 3px 3px 7px lightgray;}
.ts_tab {min-width:20px; display:inline-block;}
</style>
/*BLOCKQUOTES*/
blockquote { border-left: 5px solid white; margin-left: 25px; padding-left: 10px; }
/*DETAILS and SUMMARY*/
.bluedemon {display:inline;font-size:16pt;color:#08d;}
details summary::-webkit-details-marker {display:none;}
details .bluedetails {display:inline;font-size:16pt;color:#08d;}
details .source {font-color:#888; font-size:10pt;}
/*EDITTEMPLATE OVERFLOW*/
.tc-message-box {
height: 400px;
overflow: scroll;
}
/*FLOAT*/
.floatleft {float:left;}
.floatright {float:right;}
/*FONT STUFF (colors)*/
html body.tc-body .red {color: red; font-weight: bold;}
html body.tc-body .green {color:#0a5;font-weight:bold;}
html body.tc-body .blue {color:#0e34a2;font-weight:bold;}
html body.tc-body .orange {color:#e81;font-weight: bold;}
html body.tc-body .dkgrn {color:#063;font-weight: bold;}
html body.tc-body .pink {color:#f36;font-weight: bold;}
html body.tc-body .purple {color:#990099;font-weight: bold;}
html body.tc-body .gray {color:#777777;font-weight: bold;}
html body.tc-body .wine {color:#903;font-weight: bold;}
html body.tc-body .brown {color:#773300;font-weight: bold;}
html body.tc-body .gold {color:#cc7700;font-weight: bold;}
html body.tc-body .white {color: white;}
html body.tc-body .yellow {background: #ffff99;}
html body.tc-body .greenbk {background:#cf9;padding:1px 4px 1px 4px;}
html body.tc-body .bluebk {background:#ccf;padding:1px 4px 1px 4px;}
html body.tc-body .orangebk {background:#fd7;padding:1px 4px 1px 4px;}
html body.tc-body .pinkbk {background:#fde;padding:1px 4px 1px 4px;}
html body.tc-body .purplebk {background:#ecf;padding:1px 4px 1px 4px;}
html body.tc-body .graybk {background:#ddd;padding:1px 4px 1px 4px;}
html body.tc-body .tanbk {background:#e8dfa1;padding:1px 4px 1px 4px;}
html body.tc-body .yellowbk {background:#ff6;padding:1px 4px 1px 4px;}
html body.tc-body .turqbk {background:#bdb;padding:1px 4px 1px 4px;}
/*FONT - HEADERS*/
h1, h2, h3 {font-weight:bold;display:inline;}
h2 a {text-decoration:none;color:#000;margin-bottom:none;padding-bottom:none;}
/*FONT STUFF (languages)*/
html body.tc-body .greek {font-family: Gentium; font-size: 12pt;}
html body.tc-body .greekbig {font-family: Gentium; font-size: 16pt;}
html body.tc-body .hebrewNoAlign {font-family: Gentium; font-size: 20pt;}
/*FONT STUFF (misc)*/
.source {color:#aaa; font-size:10pt;}
sup {
vertical-align: super;
font-size: smaller;
font-weight:bold;
color:red;
}
/*HIDDEN*/
.hide {display: none ! important;}
.high {background-color:white;}
/*HORIZONTAL RULE*/
html body.tc-body hr {border:0px;}
html body.tc-body hr {
border-top: 1px solid #dddddd;
text-align: center;
width:100%; margin-top:30px; margin-bottom:30px;
}
/*ICONS*/
html body.tc-body .tc-image-edit-button {stroke: white;fill:#000;}
html body.tc-body .tc-image-delete-button {stroke: white;fill:#ff2222;}
html body.tc-body .tc-image-cancel-button {stroke: white;fill:#ffdd55;}
html body.tc-body .tc-image-done-button {stroke: white;fill:#99ee22;}
html body.tc-body .tc-image-home-button {stroke: white;fill:#5778d8;height:20px;}
html body.tc-body .tc-image-palette {stroke: white;fill:#7897fc;}
html body.tc-body .tc-image-new-button {stroke: white;fill:#7897fc;}
html body.tc-body .tc-image-menu-button {stroke: white;fill:#2B0;}
html body.tc-body .tc-image-picture {stroke: white;fill:#7897fc;}
html body.tc-body .tc-image-heading-1 {stroke: white;fill:#7897fc;}
html body.tc-body .tc-image-favicon {stroke: white;fill:#7897fc;}
/*INDENTING*/
html body.tc-body .indent {margin-left:3em;}
html body.tc-body .indent1 {margin-left:1.5em;display:block;}
html body.tc-body .indent1gray {margin-left:1.5em;display:block;color:#777;}
html body.tc-body .indent2 {margin-left:6em;display:block;}
html body.tc-body .indent3 {margin-left:9em;display:block;}
html body.tc-body .indent4 {margin-left:12em;display:block;}
html body.tc-body .indent5 {margin-left:15em;display:block;}
html body.tc-body .indent6 {margin-left:18em;display:block;}
html body.tc-body .indent7 {margin-left:21em;display:block;}
/*LINKS*/
html body.tc-body a.tc-tiddlylink {text-decoration: none;font-style: normal;font-weight: normal;color:#5778d8;}
html body.tc-body a.tc-tiddlylink-missing {font-weight:normal; color:#333;font-weight:normal;}
html body.tc-body a.tc-tiddlylink-external {text-decoration: none;font-weight: normal;color: #5778d8;}
html body.tc-body .tc-site-title a.tc-tiddlylink {
font-weight:bold;}
.source a {color:#555; font-size:10pt;text-decoration: underline;}
/*LISTS*/
html body.tc-body li {padding-bottom:.2em;padding-top:.2em;}
html body.tc-body .doublelist li {padding-bottom:.5em;padding-top:.5em;}
html body.tc-body ul {list-style: none;}
html body.tc-body ul li::before {content: "•"; color: #66f;font-size:150%;
display: inline-block; width: 1em;vertical-align:middle;
margin-left: -1em}
html body.tc-body .bullet {font-size:150%;}
/*TABLES BASIC*/
table th, table td {padding: 0 0 0 0;border: 1px solid black;font-size:100%;}
table th {padding: 10px; vertical-align:top; background-color:#eee;font-weight:bold;text-align:left;font-size:100%;}
table td {padding: 10px; vertical-align:top; white-space:normal;font-size:100%;}
/*TABLES ALTGRAY*/
html body.tc-body .altgray {width: 100%;border: 1px solid white;}
html body.tc-body .altgray table, table th, table td {border: 1px solid white;font-size:100%;padding-left:20px;}
html body.tc-body .altgray tr:nth-child(even) td {background-color:#eee;}
html body.tc-body .altgray tr:nth-child(odd) td {background-color:#fff;}
/*TABLES BLUEBYCELL*/
html body.tc-body .bluebycell table {border: 1px solid black;}
html body.tc-body .bluebycell th {padding: 10px; vertical-align:top;font-weight:normal;text-align:left;border: 1px solid black;background:#DDF;}
html body.tc-body .bluebycell td {padding: 10px; vertical-align:top;border: 1px solid black;background: #eef;}
html body.tc-body .bluebycell {
-moz-box-shadow: 20px 20px 10px #bbb;
-webkit-box-shadow: 20px 20px 10px #bbb;
box-shadow: 20px 20px 10px #bbb;
}
/*TABLES BLUEALTROWS*/
html body.tc-body .bluealtrows {
-moz-box-shadow: 20px 20px 10px #bbb;
-webkit-box-shadow: 20px 20px 10px #bbb;
box-shadow: 20px 20px 10px #bbb;
}
html body.tc-body .bluealtrows th {padding: 15px; border: 1px solid black;vertical-align:top;font-weight:bold;text-align:left;font-size:100%;}
html body.tc-body .bluealtrows td {padding: 15px; border: 1px solid black;vertical-align:top;font-size:100%;}
html body.tc-body .bluealtrows tr:nth-child(even) td {background-color:#DDF;}
html body.tc-body .bluealtrows tr:nth-child(odd) td {background-color:#EEF;}
/*TABLES 3D*/
html body.tc-body .3d {
-moz-box-shadow: 10px 10px 5px #bbb;
-webkit-box-shadow: 10px 10px 5px #bbb;
box-shadow: 10px 10px 5px #bbb;
}
/*DISTRIBUTION*/
html body.tc-body .distribution {border: 1px solid black;}
html body.tc-body .distribution tr {border: 1px solid black;}
html body.tc-body .distribution td {border: 1px solid black;padding:4px;font-size:70%;min-width:35px;text-align:center;}
/*TABLES INVISIBLE*/
html body.tc-body .invisibletable th {border: 0px solid white; background-color:white;border-collapse: collapse;font-size:80%;}
html body.tc-body .invisibletable td {border: 0px solid white; background-color:white;border-collapse: collapse;font-size:80%;}
/*TABLES NORMALBASIC*/
html body.tc-body .invisibletable th {padding: 0 0 0 0;border: 1px solid black;font-size:80%;}
html body.tc-body .invisibletable td {padding: 0 0 0 0;border: 1px solid black;font-size:x-small;font-size:80%;}
/*TABLES - ROWSTABLE*/
html body.tc-body .rowstable, html body.tc-body .tc-sidebar-lists .rowstable
{background-color: #fff; border-collapse:none; border-color:#fff;font-size:0.9em;}
html body.tc-body .rowstable, html body.tc-body .tc-sidebar-lists .rowstable th
{background-color:#fff;border-color:#fff;border-bottom: 2px solid #446699;color: #446699;padding:10px;}
html body.tc-body .rowstable, html body.tc-body .tc-sidebar-lists .rowstable td
{background-color:#fff;border-color:#fff;border-bottom: 1px solid #ccc;color: #6677aa;padding: 6px 8px;}
/*TABLES THEMEMAP*/
html body.tc-body .thememap table {border: 0px solid white;font-size:8px;}
html body.tc-body .thememap th {padding: 5px; vertical-align:top;font-weight:normal;text-align:left;border: 0px solid white;background:#99F;}
html body.tc-body .thememap td {padding: 5px; vertical-align:top;border: 0px solid white;background: #eee;}
/*TABLES TIGHT*/
html body.tc-body .tight table {border: 2px solid white;}
html body.tc-body .tight th {padding: 5px; vertical-align:top;font-weight:bold;text-align:left;border: 2px solid white;font-size:10pt;font-family: 'Arial', sans-serif;}
html body.tc-body .tight td {padding: 5px; vertical-align:top;border: 2px solid white;font-size:10pt;font-family: 'Arial', sans-serif;}
html body.tc-body .tight tr:nth-child(even) td {background-color:#CDF;}
html body.tc-body .tight tr:nth-child(odd) td {background-color:#dae9fe;}
/*TABLES WHITELINES*/
html body.tc-body .whitelines {background:#eee; border-collapse: collapse;border-color:#eee;}
html body.tc-body .whitelines th {background-color:#eee;border-color:#eee;border-bottom: 2px solid #000;color: #000;padding:10px;font-weight:bold;}
html body.tc-body .whitelines td {background:#eee; border-color:#eee;border-bottom: 1px solid #aaa;color: #000;padding: 6px 8px;min-width:150px;}
/*TAG EDITOR AND DROPDOWNS*/
html body.tc-body .tc-block-dropdown-wrapper {width:800px;color:#2200bb;}
html body.tc-body .tc-block-dropdown {width:800px;white-space:normal;color:#2200bb;}
html body.tc-body .tc-block-dropdown a {display: inline-block;color:#2200bb;}
html body.tc-body .tc-block-dropdown svg {height: 1.2em;fill:#ccc;display:inline;color:#2200bb;}
/*TAG LABELS*/
html body.tc-body .tc-tag-label {font-family: 'Arial'; font-size:10pt; color:#2200bb;background-color:#eee;margin-bottom:6px;font-weight: bold;}
html body.tc-body .tc-menu-list-item {font-weight: bold; color:#2200bb;}
/*TEXT BOXES*/
@media print {.avisos {display: none ! important;}}
html body.tc-body .avisos {display:block;background-color:#f9f9f9;padding:20px;margin-left:10px;margin-top:10px;margin-bottom:20px;width:95%; box-shadow: 10px 10px 5px #eee;font-size:9pt;}
@media print {.avisos {display: none ! important;}}
/*HIDE SECTIONS FOR PRINTING*/
@media print {#tc-page-background {display: none ! important;}}
@media print {.tc-tags-wrapper {display: none ! important;}}
@media print { body.tc-body {background-color: transparent;}
@media print {.tc-image-chevron-up {display: none ! important;}}
@media print {.tc-image-chevron-down {display: none ! important;}}
.sidebar-header, .tc-topbar {
display: none;
}
@media print {
.story-river {
margin: 0;
padding: 0;
}
html body.tc-body .tc-tiddler-frame {
margin: 0;
border-bottom: 1px solid #ccc;
padding: 5px;}
html body.tc-body a.tc-tiddlylink-external:hover {
border: 1px solid <<colour tiddler-border>>;
}
html body.tc-body .tc-tiddler-info {
padding: 14px 42px 14px 42px;
background-color: <<colour tiddler-info-background>>;}
}
}
\define journalButton()
<$button tooltip={{$:/language/Buttons/NewJournal/Hint}} aria-label={{$:/language/Buttons/NewJournal/Caption}} class=<<tv-config-toolbar-class>>>
<$action-sendmessage $message="tm-new-tiddler" $param="$:/.giffmex/template/entry" title=<<now "$(journalTitleTemplate)$">> authortitle={{$:/.giffmex/currently.reading}} />
<$list filter="[<tv-config-toolbar-icons>prefix[yes]]">
{{$:/core/images/new-button}}
</$list>
<$list filter="[<tv-config-toolbar-text>prefix[yes]]">
<span class="tc-btn-text"><$text text={{$:/language/Buttons/NewJournal/Caption}}/></span>
</$list>
</$button>
\end
<$set name="journalTitleTemplate" value={{$:/config/NewJournal/Title}}>
<$set name="journalTags" value={{$:/config/NewJournal/Tags}}>
<$set name="journalText" value={{$:/config/NewJournal/Text}}>
<<journalButton>>
</$set></$set></$set>
\define journalButton()
<$button tooltip={{$:/language/Buttons/NewJournal/Hint}} aria-label={{$:/language/Buttons/NewJournal/Caption}} class=<<tv-config-toolbar-class>>>
<$action-sendmessage $message="tm-new-tiddler" $param="$:/.giffmex/template/topic.list" title="Give your topic a title" />
<$list filter="[<tv-config-toolbar-icons>prefix[yes]]">
{{$:/core/images/menu-button}}
</$list>
<$list filter="[<tv-config-toolbar-text>prefix[yes]]">
<span class="tc-btn-text"><$text text={{$:/language/Buttons/NewJournal/Caption}}/></span>
</$list>
</$button>
\end
<$set name="journalTitleTemplate" value={{$:/config/NewJournal/Title}}>
<$set name="journalTags" value={{$:/config/NewJournal/Tags}}>
<$set name="journalText" value={{$:/config/NewJournal/Text}}>
<<journalButton>>
</$set></$set></$set>
Entry. - @@.source <$transclude field="authortitle"/>, <$view field="page"/>.@@
<<xlist filter:"[topic1{!!title}] +[sort[title]]" each:topic2>>
<br>
!!The basic process
<span class="doublelist">
#''Read'' a book or other source, and take notes or highlight or underline as you go.
#In a copy of the present file, which you have downloaded and saved properly ([[learn about TiddlyWiki here|https://tiddlywiki.com/]]), ''add the author and book title'' in the long field on the front page ([[HQ]]). This will make the next step go more quickly.
#Go back through the book and use the blue + symbol to ''create note entries'' for each page or section of the book you want to keep track of. The authortitle field will already be populated with what you put in the field in step 2. Add page #s and the two levels of topics the note naturally falls under (e.g., Diabetes, and Diabetes diet tips). I recommend typing your topic2 topic between the `<h2>` and `</h2>` tags, so that it looks nice in the final product. In the text field, replace the word 'Entry' with the actual note. Done, unless you want to replace the datetime stamp with a title, which is optional. Open [[Sample entry]] and edit it to see how it works.
#''Topic lists:'' If you don't currently have a tiddler for the data in your 'topic1' field, click the green menu button and create one. Just paste your title (ie, Diabetes) and save.<br><br> If you want to have an even higher level of topics, called domains (in this case, Health), then use tagging to add a third level. This is optional.<br><br>The note you created on diabetes should appear in the Diabetes tiddler under the heading 'Diabetes diet tips'. The author, title and page number appear in gray text after the note itself. And the blue diamond that acts as a bullet also is a link to the note tiddler, in case you have to edit it. See [[Sample topic]] to see what topic lists will look like as you create notes.
#So as you add notes you are also'' indexing your notes by topic and subtopic'' (and domains if you like). When you need to ''review notes'', you can search in the list of topics on the front page and open the one you want. If you used tags, there is a link to a list of tags, too.
</span>
I did this because I want to index my books, using short blurbs that refer to the contents of a section in a book, like 'Chart of basic food groups' or 'Great quote on friendship' or 'Nice definition of chiasm'. Since I doubt it will scale, I intend to use several copies of this file, one for each kind of book I read.
This adaptation is not ideal for pasting long quotes. I have a different adaptation for that, which I call Giffmarks. http://giffmex.org/giffmarks.html. Giffmarks is a bit more sophisticated than this Simple Note Index. It creates lists of quotes by topic, but also creates lists of links to topics within the tiddlers for each book or source.
The Simple index lets me add the other data BEFORE I think of the topic and subtopic. It is easier on the mind. The current Simple index is for rapid indexing of books I have already finished, which is easier for physical books. Giffmarks is for leisurely adding great quotes from good books as I read, on electronic books that allow me to copy and paste.
!!!Kudos
This adaptation would not be possible without not only the wonderful ~TiddlyWiki open source program, but also the following plugins
*$:/.tb/macros/list-search
*$:/plugins/tobibeer/xlist
\define list-search(
filter:"[tags[]]",
search:"search:title",
state:"$:/temp/list-search",
template:"$:/core/ui/ListItemTemplate",
placeholder:"Filter",
limit:100000
)
<div>
<$edit-text
tiddler="$state$"
type="search"
tag="input"
default=""
placeholder="$placeholder$"/>
</div>
<$reveal state="$state$" type="match" text="">
<$list filter="$filter$+[limit[$limit$]]" template="$template$"/>
</$reveal>
<$reveal state="$state$" type="nomatch" text="">
<$list filter="$filter$+[$search${$state$}]+[limit[$limit$]]" template="$template$"/>
</$reveal>
\end
\define source(source)
[[$source$]]:
<pre><$view tiddler="$source$" format="text"/></pre>
\end
\define static(tiddler:"HelloThere",height:"400px",scrolling:"no")
<div class="static pretty">
<iframe src="http://tiddlywiki.com/static/$tiddler$" style="height:$height$;" scrolling="$scrolling$"/>
</div>
\end
\define tagline(index)
<$tiddler tiddler="$:/.tb/macros/tagline/data"><$transclude field=prefix/><$reveal type=match default="" text="$index$"><$list filter="[<currentTiddler>indexes[]let:RANDOM[]]" variable=index><span class="tagline-text"><$transclude index=<<index>>/></span></$list></$reveal><$reveal type=nomatch default="" text="$index$"><span class="tagline-text"><$transclude index="$index$"/></span></$reveal><$transclude field=suffix/></$tiddler>
\end
; no parameter = random tagline
:`<<tagline>>`
:: <<tagline>>
; tagline at index 4
: `<<tagline 4>>`
:: <<tagline 4>>
1: Own It Like A Document. Use It Like A Website.
2: Your Information. Your way.
3: As Mighty As You Need. As Simple As You Dare.
4: Scattered Brains? Organize. Now. Free!
.overview > div {
margin-bottom:1em;
}
.overview > span > a {
float:left;
}
.tc-tiddler-body .tc-tags-wrapper,
.overview .tc-tags-wrapper{
margin:0;
}
.overview pre {
clear:both;
margin-top:3px;
background-color: #f9f9f9;
border: 1px solid #eee;
padding: 1px;
border-radius: 3px;
font-size: 0.9em;
}
.overview-link{
float:right;
font-size:1.2em;
}
.overview .tc-tag-list-item{
margin:0;
}
.by-operator > span > a,
.info {
float:none;
display:block;
font-size: 1.5em;
margin-top: 20px;
display:block;
background:#eef;
padding:7px;
border-radius:7px;
}
.operator-group {
margin: 10px 0 10px 0px;
}
.align-top td{
vertical-align:top;
}
.static {
display:block;
overflow:hidden;
}
.static iframe {
overflow:hidden;
width:100%;
height:400px;
margin:-120px 0 0 -5px;
border:0;
}
.tb5-home{
margin-top:20px;
}
.tb5-home-title{
display:inline-block;
text-align:right;
margin: 0 7px 7px 0;
width:120px;
font-size:1.5em;
vertical-align:top;
}
.tb5-home-summary{
display:inline-block;
width:450px;;
}
.tc-tiddler-title-icon > svg{
fill:#bbb;
}
.tc-tagged-Dev{
background-color:#fff6f6;
}
.tb-taglist-columns{
column-count: 4;
-moz-column-count: 4;
-webkit-column-count: 4;
}
.tb-taglist .tb-taglist-item{
width:145px;
}
.tb-taglist-columns .tb-taglist-item{
width:auto;
display:block;
}
.tb-taglist .tc-menu-list-count,
.tb-taglist-columns .tc-menu-list-count{
margin-left:-10px;
display:inline-block;
width:25px;
text-align:right;
}
.tb-taglist-item{
display:inline-block;
padding-top:5px;
}
.tb-timeline-item{
margin:2px -5px 5px -5px;
padding:2px 5px 5px 5px;
}
.tb-timeline-item:hover{
background: #f3f3f3;
}
.tb-timeline-date{
float:right;
color:#ccf;
font-size:0.8em;
}
.tb-timeline-tags {
color:#ccc;
}
.tb-timeline-tags button {
font-size:0.8em;
}
.tb-timeline-tags .tc-tag-list-item {
margin-right: 3px;
}
.tb-thumbs{
width: 160px;
margin: 0 10px 10px 0;
}
.redirected {
color:#dd1144;
}
.tb-links dd span:not(:last-child):after{
content:", ";
}
.no-border,
.no-border tr,
.no-border td {
border:0;
}
.warn,
.warn a {
color: #dd1144;
}
dl:not(.tb5-markup){
margin:0;
}
dd{
margin-left:14px;
}
dd:before{
content: "»";
padding-right:7px;
}
<table>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
<$list filter="[all[shadows]sort[title]prefix[$:/language/Docs/Fields/]]" variable=info>
<$list filter="[<info>removeprefix[$:/language/Docs/Fields/]]" variable=field>
<tr>
<td><$link to=<<info>>><<field>></$link></td>
<td><$transclude tiddler=<<info>>/></td>
</tr>
</$list>
</$list>
</table>
<ul>
<$list filter="[all[current]fields[]sort[title]]-[all[shadows]removeprefix[$:/language/Docs/Fields/]]" mode="block">
<li>{{!!title}}</li>
</$list>
</ul>
<ul>
<$list filter="[all[tiddlers]fields[]sort[title]] -[all[shadows]removeprefix[$:/language/Docs/Fields/]]" mode="block">
<li>{{!!title}}</li>
</$list>
</ul>
\define field-info(element) $:/language/Docs/Fields/$(field)$
<table>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
<$list filter="[[title]][[text]][[tags]][[modified]][[modifier]][[created]][[creator]][[list]]" variable=field>
<tr>
<td><$link to=<<field-info>>><<field>></$link></td>
<td><$transclude tiddler=<<field-info>>/></td>
</tr>
</$list>
</table>
<$link to=<<currentTiddler>>><$view field=title/></$link>
<$transclude tiddler="$:/.tb/template/list-tags" mode=inline/><br>
<pre><$view field=filter format=text/></pre>
<$reveal type="nomatch" default="" text={{!!filter2}}>
<pre style="margin:-10px 0 0 15px" class="secondary"><$view field=filter2 format=text/></pre>
</$reveal>
<$reveal type="nomatch" default="" text={{!!parent}}>
<pre style="margin:-10px 0 0 15px" class="secondary"><$view field=parent format=text/></pre>
</$reveal>
<span class="tc-tags-wrapper" style="float:right;">
<$list
filter="[all[current]tags[]sort[title]] -Filters -Fields "
template="$:/core/ui/TagTemplate"
storyview="pop"/>
</span>
\define tag-styles()
background-color:$(backgroundColor)$;
fill:$(foregroundColor)$;
color:$(foregroundColor)$;
\end
\define tag-body-inner(colour,fallbackTarget,colourA,colourB)
<$set name="tagging" value="[all[current]tagging[]]">
<$vars backgroundColor="""$colour$"""
foregroundColor=<<contrastcolour target:"""$colour$""" fallbackTarget:"""$fallbackTarget$""" colourA:"""$colourA$""" colourB:"""$colourB$""">>>
<$reveal type="match" text="" default=<<tagging>>>
<$button class="tc-btn-invisible tc-tag-label" style=<<tag-styles>>>
<$action-navigate $to=<<currentTiddler>>/>
<$text text=<<currentTiddler>>/>
</$button>
</$reveal>
<$reveal type="nomatch" text="" default=<<tagging>>>
<$appear type=popup button-class="tc-btn-invisible tc-tag-label" style=<<tag-styles>> show="""<$transclude tiddler={{!!icon}}/> <$view field="title" format="text" />""" position="below" animate="yes" handler="popups">
<$transclude tiddler="$:/core/ui/ListItemTemplate"/>
<hr>
<$list filter="[all[current]tagging[]sort[title]]" template="$:/core/ui/ListItemTemplate"/>
</$appear>
</$reveal>
</$vars>
</$set>
\end
\define tag-body(colour,palette)
<span class="tc-tag-list-item">
<$macrocall $name="tag-body-inner" colour="""$colour$""" fallbackTarget={{$palette$##tag-background}} colourA={{$palette$##foreground}} colourB={{$palette$##background}}/>
</span>
\end
<$macrocall $name="tag-body" colour={{!!color}} palette={{$:/palette}}/>
\define drop-values() $:/config/EditTemplateFields/Visibility/$(currentField)$
<$list filter="[title<currentTiddler>tag[Journal]]">
<div class="tc-edit-fields">
<table class="tc-edit-fields">
<tbody>
<$list filter="[list[$:/.tb/ui/EditTemplate/drop-fields!!fields]]" variable="currentField">
<tr class="tc-edit-field">
<td class="tc-edit-field-name">
<$text text=<<currentField>>/>:</td>
<td class="tc-edit-field-value">
<$select field=<<currentField>>>
<$list filter="[<drop-values>get[values]]">
<$list filter=<<currentTiddler>>>
<option value=<<currentTiddler>>><$text text=<<currentTiddler>>/></option>
</$list>
</$list>
</$select>
</td>
</tr>
</$list>
</tbody>
</table>
</div>
</$list>
<$list filter="[all[current]tag[Filters]] [all[current]tag[FilterOperator]]">
<br><h3>[[« Back To Overview|Filter Examples]]</h3>
</$list>
<$list filter="[all[current]tag[Fields]]">
@@.info
[[See here|Fields]] for an overview of fields.
@@
</$list>
<$list filter="[all[current]has[filter]]">
''filter'': <code><$view field=filter format=text/></code>
<$reveal type="nomatch" default="" text={{!!filter2}}>
<br>@@margin:0 0 0 40px;—> <code><$view field=filter2 format=text/></code>@@
</$reveal>
<$reveal type="nomatch" default="" text={{!!parent}}>
<br>@@margin:0 0 0 40px;—> <code><$view field=parent format=text/></code>@@
</$reveal>
</$list>
\define url()
[ext[FilterOperator: $(currentTiddler)$ @ tiddlywiki.com|http://tiddlywiki.com/#FilterOperator%3A%20$(currentTiddler)$]]
\end
\define static-filter() FilterOperator%253A%2520$(currentTiddler)$
<$list filter="[all[current]tag[FilterOperator]]">
<<url>>
<$macrocall $name=static tiddler=<<static-filter>> height={{!!height}} scrolling="yes"/>
<h2>Filter Examples</h2>
<dl class="overview">
<<list-search
"[all[current]tagging[]sort[title]]"
"search"
"$:/temp/list-search-list-examples"
"$:/.tb/template/list-examples"
placeholder:"Filter all examples..." >>
</dl>
</$list>
\define url()
[ext[FilterOperator: $(operator)$ @ tiddlywiki.com|http://tiddlywiki.com/#FilterOperator%3A%20$(operator)$]]
\end
\define static-filter()
FilterOperator%253A%2520$(operator)$
\end
<$list filter="[all[current]tag[FilterOperand]]">
<$list filter="[all[current]tag[AllOperand]]">
<$set name=operator value=all>
<<url>>
<$macrocall $name=static tiddler=<<static-filter>> height=550px scrolling="yes"/>
</$set>
</$list><$list filter="[all[current]tag[IsOperand]]">
<<url>>
<$set name=operator value=is>
<$macrocall $name=static tiddler=<<static-filter>> height=810px scrolling="yes"/>
</$set>
</$list>
<h2>Filter Examples</h2>
<dl class="overview">
<<list-search
"[all[current]tagging[]sort[title]]"
"search"
"$:/temp/list-search-list-examples"
"$:/.tb/template/list-examples"
placeholder:"Filter all examples..." >>
</dl>
</$list>
<$list filter="[all[current]has[static]]">
<$macrocall $name=static tiddler={{!!static}} height={{!!height}} scrolling=yes/>
</$list>
<$list filter="[all[current]has[summary]]">
@@color:grey; //<$transclude field="summary" mode="block"/> //@@
</$list>
<$list filter="[all[current]has[url]]">
<$transclude field="url" mode="block"/>
</$list>
\define lingo-base() $:/bimlas/field-list-below-title/field-title/
<!-- Show desired fields, specify the caption in lingo-base directory -->
//{{!!description}}//
<$list filter="[is[current]fields[]] +([[website]] [[gesetz]] [[gesetz-art]])" variable="fieldname">
<$list filter="[is[current]has<fieldname>]">
<div><<lingo $(fieldname)$>> <$list filter="[all[current]get<fieldname>]" variable="value"><<value>></$list></div>
</$list>
</$list>
<$list filter="[is[current]has[origin]]">
<div><<lingo "origin">>:<$list filter="[all[current]enlist{!!origin}]" variable="link"><br><<link>></$list></div>
</$list>
\define _list-references-draggable(tag,subFilter,emptyMessage,itemTemplate,elementTag:"div")
<$set name="tag" value="""$tag$""">
<$list filter="[<tag>backlinks[]$subFilter$]" emptyMessage=<<__emptyMessage__>>>
<$elementTag$ class="tc-menu-list-item">
<$droppable actions=<<list-tagged-draggable-drop-actions>>>
<$elementTag$ class="tc-droppable-placeholder">
</$elementTag$>
<$elementTag$>
<$transclude tiddler="""$itemTemplate$""">
<$link to={{!!title}}>
<$view field="title"/>
</$link>
</$transclude>
</$elementTag$>
</$droppable>
</$elementTag$>
</$list>
<$tiddler tiddler="">
<$droppable actions=<<list-tagged-draggable-drop-actions>>>
<$elementTag$ class="tc-droppable-placeholder">
</$elementTag$>
<$elementTag$ style="height:0.5em;">
</$elementTag$>
</$droppable>
</$tiddler>
</$set>
\end
\define _tagging-pill()
<$list filter="[<storyTiddler>tagging[]first[]]">
<span class="tc-tag-list-item">
<$set name="transclusion" value=<<qualify "tagging-pill-dropdown">> >
<$macrocall $name="tag-pill-body" tag="Tagging" icon={{!!icon}} colour="#eee8d5" palette={{$:/palette}} element-tag="""$button""" element-attributes="""popup=<<transclusion>> dragFilter='[<storyTiddler>tagging[]]' tag='span'"""/>
<$reveal state=<<transclusion>> type="popup" position="below" animate="yes" class="tc-drop-down">
<$macrocall $name="list-tagged-draggable" tag=<<storyTiddler>>/>
</$reveal>
</$set>
</span>
</$list>
\end
\define _references-pill()
<$list filter="[<storyTiddler>backlinks[]first[]]">
<span class="tc-tag-list-item">
<$set name="transclusion" value=<<qualify "references-pill-dropdown">> >
<$macrocall $name="tag-pill-body" tag="References" icon={{!!icon}} colour="#eee8d5" palette={{$:/palette}} element-tag="""$button""" element-attributes="""popup=<<transclusion>> dragFilter='[<storyTiddler>backlinks[]]' tag='span'"""/>
<$reveal state=<<transclusion>> type="popup" position="below" animate="yes" class="tc-drop-down">
<$macrocall $name="_list-references-draggable" tag=<<storyTiddler>>/>
</$reveal>
</$set>
</span>
</$list>
\end
<<_tagging-pill>>
<<_references-pill>>
\define filteredtag-filter(prefix suffix) $prefix$<$list filter="[[$:/temp/bimlas/FilteredTag]tags[]]" variable=tag-here>tag[<<tag-here>>]</$list>$suffix$
\define filteredtag(tag)
<$wikify name=filter text="""<<filteredtag-filter "[tag[$tag$]" "search{$:/temp/search}first[]]" >>""">
<$list filter=<<filter>> >
<$checkbox tiddler="$:/temp/bimlas/FilteredTag" tag="$tag$">
{{$tag$||$:/bimlas/sidebar/filteredtag/template}}
</$checkbox>
</$list>
</$wikify>
\end
<$list filter="[prefix[$:/state/popup/search-dropdown]] [[The other is not exists]] +[first[]!is[system]]">
<$checkbox tiddler="$:/temp/bimlas/FilteredTag" field="show-tags-without-search" checked="yes" unchecked="" default=""> Show all tags without search</$checkbox>
<$list filter="[{$:/temp/search}minlength{$:/config/Search/MinLength}] [[$:/temp/bimlas/FilteredTag]field:show-tags-without-search[yes]] +[first[]]">
<$list filter="[[$:/temp/bimlas/FilteredTag]tags[]first[]]">
<$button class="tc-btn-invisible">
<$action-setfield $tiddler="$:/temp/bimlas/FilteredTag" tags=""/>
{{$:/core/images/close-button}}
</$button>
</$list>
<$list filter="[tags[]prefix[_]] +[each:value[]sort[]]" variable="category">
<strong><<category>></strong>
<$list filter="[tag<category>sort[title]]" variable="tag">
<$macrocall $name="filteredtag" tag=<<tag>>/>
</$list>
</$list>
<strong>Uncategorized</strong>
<$list filter="[tags[]!is[system]!prefix[_]sort[title]] -[tags[]prefix[_]tagging[]]" variable="uncategorizedTag">
<$macrocall $name="filteredtag" tag=<<uncategorizedTag>>/>
</$list>
</$list>
</$list>
<span class="tc-tag-list-item">
<$set name="transclusion" value=<<currentTiddler>>>
<$macrocall $name="tag-pill-body" tag=<<currentTiddler>> icon={{!!icon}} colour={{!!color}} palette={{$:/palette}} element-tag="""$button""" element-attributes="""popup=<<qualify "$:/state/popup/tag">> dragFilter='[all[current]tagging[]]' tag='span'"""/>
<$reveal state=<<qualify "$:/state/popup/tag">> type="popup" position="below" animate="yes" class="tc-drop-down">
<$transclude tiddler="$:/core/ui/ListItemTemplate"/>
<$list filter="[all[shadows+tiddlers]tag[$:/tags/TagDropdown]!has[draft.of]]" variable="listItem">
<$transclude tiddler=<<listItem>>/>
</$list>
<hr>
<$wikify name=subfilter text="""<<filteredtag-filter "" "] +[search{$:/temp/search}] -[[$:/temp/bimlas/FilteredTag]">>""">
<$macrocall $name="list-tagged-draggable" tag=<<currentTiddler>> subFilter=<<subfilter>>/>
</$wikify>
</$reveal>
</$set>
</span>
<$list filter="[get[kind]] -[title[example]] +[each:value[]sort[title]]" variable="currentKind">
<strong><<currentKind>></strong>
<$list filter="[kind<currentKind>]" variable="tag">
<$macrocall $name="filteredtag" tag=<<tag>>>
</$list>
</$list>
{{$:/macros/SearchFields}}
{{$:/plugins/kookma/commander/ui/search}}
<<slider-ii title:"$:/plugins/kookma/commander/ui/tiddler-selection">>
<<tabs "[all[shadows+tiddlers]tag[$:/tags/Commander]!has[draft.of]]" default:"$:/plugins/kookma/commander/ui/tiddler-operation" class:"cm-tab-colorful">>
---
<<slider-ii title:"$:/plugins/kookma/commander/ui/log-status">>
blue: #458a6f
red: #bf8b39
yellow: #FFFFDD
Toggle the header searchbar on or off
<div class="tc-control-panel">
<<tabs "[all[shadows+tiddlers]tag[$:/tags/ControlPanel]!has[draft.of]]" "$:/core/ui/ControlPanel/Info">>
</div>
{
"tiddlers": {
"$:/Acknowledgements": {
"title": "$:/Acknowledgements",
"text": "TiddlyWiki incorporates code from these fine OpenSource projects:\n\n* [[The Stanford Javascript Crypto Library|http://bitwiseshiftleft.github.io/sjcl/]]\n* [[The Jasmine JavaScript Test Framework|http://pivotal.github.io/jasmine/]]\n* [[Normalize.css by Nicolas Gallagher|http://necolas.github.io/normalize.css/]]\n\nAnd media from these projects:\n\n* World flag icons from [[Wikipedia|http://commons.wikimedia.org/wiki/Category:SVG_flags_by_country]]\n"
},
"$:/core/copyright.txt": {
"title": "$:/core/copyright.txt",
"type": "text/plain",
"text": "TiddlyWiki created by Jeremy Ruston, (jeremy [at] jermolene [dot] com)\n\nCopyright (c) 2004-2007, Jeremy Ruston\nCopyright (c) 2007-2018, UnaMesa Association\nAll rights reserved.\n\nRedistribution and use in source and binary forms, with or without\nmodification, are permitted provided that the following conditions are met:\n\n* Redistributions of source code must retain the above copyright notice, this\n list of conditions and the following disclaimer.\n\n* Redistributions in binary form must reproduce the above copyright notice,\n this list of conditions and the following disclaimer in the documentation\n and/or other materials provided with the distribution.\n\n* Neither the name of the copyright holder nor the names of its\n contributors may be used to endorse or promote products derived from\n this software without specific prior written permission.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 'AS IS'\nAND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\nIMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\nFOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\nDAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\nSERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\nCAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\nOR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\nOF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
},
"$:/core/icon": {
"title": "$:/core/icon",
"tags": "$:/tags/Image",
"text": "<svg width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\"><path d=\"M64 0l54.56 32v64L64 128 9.44 96V32L64 0zm21.127 95.408c-3.578-.103-5.15-.094-6.974-3.152l-1.42.042c-1.653-.075-.964-.04-2.067-.097-1.844-.07-1.548-1.86-1.873-2.8-.52-3.202.687-6.43.65-9.632-.014-1.14-1.593-5.17-2.157-6.61-1.768.34-3.546.406-5.34.497-4.134-.01-8.24-.527-12.317-1.183-.8 3.35-3.16 8.036-1.21 11.44 2.37 3.52 4.03 4.495 6.61 4.707 2.572.212 3.16 3.18 2.53 4.242-.55.73-1.52.864-2.346 1.04l-1.65.08c-1.296-.046-2.455-.404-3.61-.955-1.93-1.097-3.925-3.383-5.406-5.024.345.658.55 1.938.24 2.53-.878 1.27-4.665 1.26-6.4.47-1.97-.89-6.73-7.162-7.468-11.86 1.96-3.78 4.812-7.07 6.255-11.186-3.146-2.05-4.83-5.384-4.61-9.16l.08-.44c-3.097.59-1.49.37-4.82.628-10.608-.032-19.935-7.37-14.68-18.774.34-.673.664-1.287 1.243-.994.466.237.4 1.18.166 2.227-3.005 13.627 11.67 13.732 20.69 11.21.89-.25 2.67-1.936 3.905-2.495 2.016-.91 4.205-1.282 6.376-1.55 5.4-.63 11.893 2.276 15.19 2.37 3.3.096 7.99-.805 10.87-.615 2.09.098 4.143.483 6.16 1.03 1.306-6.49 1.4-11.27 4.492-12.38 1.814.293 3.213 2.818 4.25 4.167 2.112-.086 4.12.46 6.115 1.066 3.61-.522 6.642-2.593 9.833-4.203-3.234 2.69-3.673 7.075-3.303 11.127.138 2.103-.444 4.386-1.164 6.54-1.348 3.507-3.95 7.204-6.97 7.014-1.14-.036-1.805-.695-2.653-1.4-.164 1.427-.81 2.7-1.434 3.96-1.44 2.797-5.203 4.03-8.687 7.016-3.484 2.985 1.114 13.65 2.23 15.594 1.114 1.94 4.226 2.652 3.02 4.406-.37.58-.936.785-1.54 1.01l-.82.11zm-40.097-8.85l.553.14c.694-.27 2.09.15 2.83.353-1.363-1.31-3.417-3.24-4.897-4.46-.485-1.47-.278-2.96-.174-4.46l.02-.123c-.582 1.205-1.322 2.376-1.72 3.645-.465 1.71 2.07 3.557 3.052 4.615l.336.3z\" fill-rule=\"evenodd\"/></svg>"
},
"$:/core/images/add-comment": {
"title": "$:/core/images/add-comment",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-add-comment tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\"><path d=\"M56 56H36a8 8 0 1 0 0 16h20v20a8 8 0 1 0 16 0V72h20a8 8 0 1 0 0-16H72V36a8 8 0 1 0-16 0v20zm-12.595 58.362c-6.683 7.659-20.297 12.903-36.006 12.903-2.196 0-4.35-.102-6.451-.3 9.652-3.836 17.356-12.24 21.01-22.874C8.516 94.28 0 79.734 0 63.5 0 33.953 28.206 10 63 10s63 23.953 63 53.5S97.794 117 63 117c-6.841 0-13.428-.926-19.595-2.638z\" fill-rule=\"evenodd\"/></svg>"
},
"$:/core/images/advanced-search-button": {
"title": "$:/core/images/advanced-search-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-advanced-search-button tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M74.5651535,87.9848361 C66.9581537,93.0488876 57.8237115,96 48,96 C21.490332,96 0,74.509668 0,48 C0,21.490332 21.490332,0 48,0 C74.509668,0 96,21.490332 96,48 C96,57.8541369 93.0305793,67.0147285 87.9377231,74.6357895 L122.284919,108.982985 C125.978897,112.676963 125.973757,118.65366 122.284271,122.343146 C118.593975,126.033442 112.613238,126.032921 108.92411,122.343793 L74.5651535,87.9848361 Z M48,80 C65.673112,80 80,65.673112 80,48 C80,30.326888 65.673112,16 48,16 C30.326888,16 16,30.326888 16,48 C16,65.673112 30.326888,80 48,80 Z\"></path>\n <circle cx=\"48\" cy=\"48\" r=\"8\"></circle>\n <circle cx=\"28\" cy=\"48\" r=\"8\"></circle>\n <circle cx=\"68\" cy=\"48\" r=\"8\"></circle>\n </g>\n</svg>"
},
"$:/core/images/auto-height": {
"title": "$:/core/images/auto-height",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-auto-height tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <path d=\"M67.9867828,114.356363 L67.9579626,99.8785426 C67.9550688,98.4248183 67.1636987,97.087107 65.8909901,96.3845863 L49.9251455,87.5716209 L47.992126,95.0735397 L79.8995411,95.0735397 C84.1215894,95.0735397 85.4638131,89.3810359 81.686497,87.4948823 L49.7971476,71.5713518 L48.0101917,79.1500092 L79.992126,79.1500092 C84.2093753,79.1500092 85.5558421,73.4676733 81.7869993,71.5753162 L49.805065,55.517008 L48.0101916,63.0917009 L79.9921259,63.0917015 C84.2035118,63.0917016 85.5551434,57.4217887 81.7966702,55.5218807 L65.7625147,47.4166161 L67.9579705,50.9864368 L67.9579705,35.6148245 L77.1715737,44.8284272 C78.7336709,46.3905243 81.2663308,46.3905243 82.8284279,44.8284271 C84.390525,43.2663299 84.390525,40.7336699 82.8284278,39.1715728 L66.8284271,23.1715728 C65.2663299,21.6094757 62.73367,21.6094757 61.1715729,23.1715729 L45.1715729,39.1715729 C43.6094757,40.73367 43.6094757,43.26633 45.1715729,44.8284271 C46.73367,46.3905243 49.26633,46.3905243 50.8284271,44.8284271 L59.9579705,35.6988837 L59.9579705,50.9864368 C59.9579705,52.495201 60.806922,53.8755997 62.1534263,54.5562576 L78.1875818,62.6615223 L79.9921261,55.0917015 L48.0101917,55.0917009 C43.7929424,55.0917008 42.4464755,60.7740368 46.2153183,62.6663939 L78.1972526,78.7247021 L79.992126,71.1500092 L48.0101917,71.1500092 C43.7881433,71.1500092 42.4459197,76.842513 46.2232358,78.7286665 L78.1125852,94.6521971 L79.8995411,87.0735397 L47.992126,87.0735397 C43.8588276,87.0735397 42.4404876,92.5780219 46.0591064,94.5754586 L62.024951,103.388424 L59.9579785,99.8944677 L59.9867142,114.32986 L50.8284271,105.171573 C49.26633,103.609476 46.73367,103.609476 45.1715729,105.171573 C43.6094757,106.73367 43.6094757,109.26633 45.1715729,110.828427 L61.1715729,126.828427 C62.73367,128.390524 65.2663299,128.390524 66.8284271,126.828427 L82.8284278,110.828427 C84.390525,109.26633 84.390525,106.73367 82.8284279,105.171573 C81.2663308,103.609476 78.7336709,103.609476 77.1715737,105.171573 L67.9867828,114.356363 L67.9867828,114.356363 Z M16,20 L112,20 C114.209139,20 116,18.209139 116,16 C116,13.790861 114.209139,12 112,12 L16,12 C13.790861,12 12,13.790861 12,16 C12,18.209139 13.790861,20 16,20 L16,20 Z\"></path>\n</svg>"
},
"$:/core/images/blank": {
"title": "$:/core/images/blank",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-blank tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\"></svg>"
},
"$:/core/images/bold": {
"title": "$:/core/images/bold",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-bold tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M41.1456583,51.8095238 L41.1456583,21.8711485 L67.4985994,21.8711485 C70.0084159,21.8711485 72.4285598,22.0802967 74.7591036,22.4985994 C77.0896475,22.9169022 79.1512515,23.6638602 80.9439776,24.7394958 C82.7367036,25.8151314 84.170863,27.3090474 85.2464986,29.2212885 C86.3221342,31.1335296 86.859944,33.5835518 86.859944,36.5714286 C86.859944,41.9496067 85.2465147,45.8337882 82.0196078,48.2240896 C78.792701,50.614391 74.6694929,51.8095238 69.6498599,51.8095238 L41.1456583,51.8095238 Z M13,0 L13,128 L75.0280112,128 C80.7647346,128 86.3519803,127.28292 91.789916,125.848739 C97.2278517,124.414559 102.068139,122.203563 106.310924,119.215686 C110.553709,116.22781 113.929959,112.373506 116.439776,107.652661 C118.949592,102.931816 120.204482,97.3445701 120.204482,90.8907563 C120.204482,82.8832466 118.262391,76.0411115 114.378151,70.3641457 C110.493911,64.6871798 104.607883,60.7133634 96.719888,58.442577 C102.456611,55.6937304 106.788968,52.1680887 109.717087,47.8655462 C112.645206,43.5630037 114.109244,38.1849062 114.109244,31.7310924 C114.109244,25.7553389 113.123259,20.7357813 111.151261,16.6722689 C109.179262,12.6087565 106.400578,9.35201972 102.815126,6.90196078 C99.2296739,4.45190185 94.927196,2.68908101 89.907563,1.61344538 C84.8879301,0.537809748 79.3305627,0 73.2352941,0 L13,0 Z M41.1456583,106.128852 L41.1456583,70.9915966 L71.8011204,70.9915966 C77.896389,70.9915966 82.7964334,72.3958776 86.5014006,75.2044818 C90.2063677,78.0130859 92.0588235,82.7039821 92.0588235,89.2773109 C92.0588235,92.6237329 91.4911355,95.3725383 90.3557423,97.5238095 C89.2203491,99.6750808 87.6965548,101.378145 85.7843137,102.633053 C83.8720726,103.887961 81.661077,104.784311 79.1512605,105.322129 C76.641444,105.859947 74.0121519,106.128852 71.2633053,106.128852 L41.1456583,106.128852 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/cancel-button": {
"title": "$:/core/images/cancel-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-cancel-button tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\">\n\t<g fill-rule=\"evenodd\">\n\t <path d=\"M64,76.3137085 L47.0294734,93.2842351 C43.9038742,96.4098343 38.8399231,96.4084656 35.7157288,93.2842712 C32.5978915,90.166434 32.5915506,85.0947409 35.7157649,81.9705266 L52.6862915,65 L35.7157649,48.0294734 C32.5901657,44.9038742 32.5915344,39.8399231 35.7157288,36.7157288 C38.833566,33.5978915 43.9052591,33.5915506 47.0294734,36.7157649 L64,53.6862915 L80.9705266,36.7157649 C84.0961258,33.5901657 89.1600769,33.5915344 92.2842712,36.7157288 C95.4021085,39.833566 95.4084494,44.9052591 92.2842351,48.0294734 L75.3137085,65 L92.2842351,81.9705266 C95.4098343,85.0961258 95.4084656,90.1600769 92.2842712,93.2842712 C89.166434,96.4021085 84.0947409,96.4084494 80.9705266,93.2842351 L64,76.3137085 Z M64,129 C99.346224,129 128,100.346224 128,65 C128,29.653776 99.346224,1 64,1 C28.653776,1 1.13686838e-13,29.653776 1.13686838e-13,65 C1.13686838e-13,100.346224 28.653776,129 64,129 Z M64,113 C90.509668,113 112,91.509668 112,65 C112,38.490332 90.509668,17 64,17 C37.490332,17 16,38.490332 16,65 C16,91.509668 37.490332,113 64,113 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/chevron-down": {
"title": "$:/core/images/chevron-down",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-chevron-down tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n\t<g fill-rule=\"evenodd\" transform=\"translate(64.000000, 40.500000) rotate(-270.000000) translate(-64.000000, -40.500000) translate(-22.500000, -26.500000)\">\n <path d=\"M112.743107,112.12741 C111.310627,113.561013 109.331747,114.449239 107.145951,114.449239 L27.9777917,114.449239 C23.6126002,114.449239 20.0618714,110.904826 20.0618714,106.532572 C20.0618714,102.169214 23.6059497,98.6159054 27.9777917,98.6159054 L99.2285381,98.6159054 L99.2285381,27.365159 C99.2285381,22.9999675 102.77295,19.4492387 107.145205,19.4492387 C111.508562,19.4492387 115.061871,22.993317 115.061871,27.365159 L115.061871,106.533318 C115.061871,108.71579 114.175869,110.694669 112.743378,112.127981 Z\" transform=\"translate(67.561871, 66.949239) rotate(-45.000000) translate(-67.561871, -66.949239) \"></path>\n <path d=\"M151.35638,112.12741 C149.923899,113.561013 147.94502,114.449239 145.759224,114.449239 L66.5910645,114.449239 C62.225873,114.449239 58.6751442,110.904826 58.6751442,106.532572 C58.6751442,102.169214 62.2192225,98.6159054 66.5910645,98.6159054 L137.841811,98.6159054 L137.841811,27.365159 C137.841811,22.9999675 141.386223,19.4492387 145.758478,19.4492387 C150.121835,19.4492387 153.675144,22.993317 153.675144,27.365159 L153.675144,106.533318 C153.675144,108.71579 152.789142,110.694669 151.356651,112.127981 Z\" transform=\"translate(106.175144, 66.949239) rotate(-45.000000) translate(-106.175144, -66.949239) \"></path>\n\t</g>\n</svg>"
},
"$:/core/images/chevron-left": {
"title": "$:/core/images/chevron-left",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-chevron-left tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\" version=\"1.1\">\n <g fill-rule=\"evenodd\" transform=\"translate(92.500000, 64.000000) rotate(-180.000000) translate(-92.500000, -64.000000) translate(6.000000, -3.000000)\">\n <path d=\"M112.743107,112.12741 C111.310627,113.561013 109.331747,114.449239 107.145951,114.449239 L27.9777917,114.449239 C23.6126002,114.449239 20.0618714,110.904826 20.0618714,106.532572 C20.0618714,102.169214 23.6059497,98.6159054 27.9777917,98.6159054 L99.2285381,98.6159054 L99.2285381,27.365159 C99.2285381,22.9999675 102.77295,19.4492387 107.145205,19.4492387 C111.508562,19.4492387 115.061871,22.993317 115.061871,27.365159 L115.061871,106.533318 C115.061871,108.71579 114.175869,110.694669 112.743378,112.127981 Z\" transform=\"translate(67.561871, 66.949239) rotate(-45.000000) translate(-67.561871, -66.949239) \"></path>\n <path d=\"M151.35638,112.12741 C149.923899,113.561013 147.94502,114.449239 145.759224,114.449239 L66.5910645,114.449239 C62.225873,114.449239 58.6751442,110.904826 58.6751442,106.532572 C58.6751442,102.169214 62.2192225,98.6159054 66.5910645,98.6159054 L137.841811,98.6159054 L137.841811,27.365159 C137.841811,22.9999675 141.386223,19.4492387 145.758478,19.4492387 C150.121835,19.4492387 153.675144,22.993317 153.675144,27.365159 L153.675144,106.533318 C153.675144,108.71579 152.789142,110.694669 151.356651,112.127981 Z\" transform=\"translate(106.175144, 66.949239) rotate(-45.000000) translate(-106.175144, -66.949239) \"></path>\n </g>\n</svg>"
},
"$:/core/images/chevron-right": {
"title": "$:/core/images/chevron-right",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-chevron-right tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\" transform=\"translate(-48.000000, -3.000000)\">\n <path d=\"M112.743107,112.12741 C111.310627,113.561013 109.331747,114.449239 107.145951,114.449239 L27.9777917,114.449239 C23.6126002,114.449239 20.0618714,110.904826 20.0618714,106.532572 C20.0618714,102.169214 23.6059497,98.6159054 27.9777917,98.6159054 L99.2285381,98.6159054 L99.2285381,27.365159 C99.2285381,22.9999675 102.77295,19.4492387 107.145205,19.4492387 C111.508562,19.4492387 115.061871,22.993317 115.061871,27.365159 L115.061871,106.533318 C115.061871,108.71579 114.175869,110.694669 112.743378,112.127981 Z\" transform=\"translate(67.561871, 66.949239) rotate(-45.000000) translate(-67.561871, -66.949239) \"></path>\n <path d=\"M151.35638,112.12741 C149.923899,113.561013 147.94502,114.449239 145.759224,114.449239 L66.5910645,114.449239 C62.225873,114.449239 58.6751442,110.904826 58.6751442,106.532572 C58.6751442,102.169214 62.2192225,98.6159054 66.5910645,98.6159054 L137.841811,98.6159054 L137.841811,27.365159 C137.841811,22.9999675 141.386223,19.4492387 145.758478,19.4492387 C150.121835,19.4492387 153.675144,22.993317 153.675144,27.365159 L153.675144,106.533318 C153.675144,108.71579 152.789142,110.694669 151.356651,112.127981 Z\" transform=\"translate(106.175144, 66.949239) rotate(-45.000000) translate(-106.175144, -66.949239) \"></path>\n </g>\n</svg>"
},
"$:/core/images/chevron-up": {
"title": "$:/core/images/chevron-up",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-chevron-up tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n\t<g fill-rule=\"evenodd\" transform=\"translate(64.000000, 89.500000) rotate(-90.000000) translate(-64.000000, -89.500000) translate(-22.500000, 22.500000)\">\n <path d=\"M112.743107,112.12741 C111.310627,113.561013 109.331747,114.449239 107.145951,114.449239 L27.9777917,114.449239 C23.6126002,114.449239 20.0618714,110.904826 20.0618714,106.532572 C20.0618714,102.169214 23.6059497,98.6159054 27.9777917,98.6159054 L99.2285381,98.6159054 L99.2285381,27.365159 C99.2285381,22.9999675 102.77295,19.4492387 107.145205,19.4492387 C111.508562,19.4492387 115.061871,22.993317 115.061871,27.365159 L115.061871,106.533318 C115.061871,108.71579 114.175869,110.694669 112.743378,112.127981 Z\" transform=\"translate(67.561871, 66.949239) rotate(-45.000000) translate(-67.561871, -66.949239) \"></path>\n <path d=\"M151.35638,112.12741 C149.923899,113.561013 147.94502,114.449239 145.759224,114.449239 L66.5910645,114.449239 C62.225873,114.449239 58.6751442,110.904826 58.6751442,106.532572 C58.6751442,102.169214 62.2192225,98.6159054 66.5910645,98.6159054 L137.841811,98.6159054 L137.841811,27.365159 C137.841811,22.9999675 141.386223,19.4492387 145.758478,19.4492387 C150.121835,19.4492387 153.675144,22.993317 153.675144,27.365159 L153.675144,106.533318 C153.675144,108.71579 152.789142,110.694669 151.356651,112.127981 Z\" transform=\"translate(106.175144, 66.949239) rotate(-45.000000) translate(-106.175144, -66.949239) \"></path>\n\t</g>\n</svg>"
},
"$:/core/images/clone-button": {
"title": "$:/core/images/clone-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-clone-button tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M32.2650915,96 L32.2650915,120.002359 C32.2650915,124.419334 35.8432884,128 40.2627323,128 L120.002359,128 C124.419334,128 128,124.421803 128,120.002359 L128,40.2627323 C128,35.8457573 124.421803,32.2650915 120.002359,32.2650915 L96,32.2650915 L96,48 L108.858899,48 C110.519357,48 111.853018,49.3405131 111.853018,50.9941198 L111.853018,108.858899 C111.853018,110.519357 110.512505,111.853018 108.858899,111.853018 L50.9941198,111.853018 C49.333661,111.853018 48,110.512505 48,108.858899 L48,96 L32.2650915,96 Z\"></path>\n <path d=\"M40,56 L32.0070969,56 C27.5881712,56 24,52.418278 24,48 C24,43.5907123 27.5848994,40 32.0070969,40 L40,40 L40,32.0070969 C40,27.5881712 43.581722,24 48,24 C52.4092877,24 56,27.5848994 56,32.0070969 L56,40 L63.9929031,40 C68.4118288,40 72,43.581722 72,48 C72,52.4092877 68.4151006,56 63.9929031,56 L56,56 L56,63.9929031 C56,68.4118288 52.418278,72 48,72 C43.5907123,72 40,68.4151006 40,63.9929031 L40,56 Z M7.9992458,0 C3.58138434,0 0,3.5881049 0,7.9992458 L0,88.0007542 C0,92.4186157 3.5881049,96 7.9992458,96 L88.0007542,96 C92.4186157,96 96,92.4118951 96,88.0007542 L96,7.9992458 C96,3.58138434 92.4118951,0 88.0007542,0 L7.9992458,0 Z M19.0010118,16 C17.3435988,16 16,17.336731 16,19.0010118 L16,76.9989882 C16,78.6564012 17.336731,80 19.0010118,80 L76.9989882,80 C78.6564012,80 80,78.663269 80,76.9989882 L80,19.0010118 C80,17.3435988 78.663269,16 76.9989882,16 L19.0010118,16 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/close-all-button": {
"title": "$:/core/images/close-all-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-close-all-button tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\" transform=\"translate(-23.000000, -23.000000)\">\n <path d=\"M43,131 L22.9976794,131 C18.5827987,131 15,127.418278 15,123 C15,118.590712 18.5806831,115 22.9976794,115 L43,115 L43,94.9976794 C43,90.5827987 46.581722,87 51,87 C55.4092877,87 59,90.5806831 59,94.9976794 L59,115 L79.0023206,115 C83.4172013,115 87,118.581722 87,123 C87,127.409288 83.4193169,131 79.0023206,131 L59,131 L59,151.002321 C59,155.417201 55.418278,159 51,159 C46.5907123,159 43,155.419317 43,151.002321 L43,131 Z\" transform=\"translate(51.000000, 123.000000) rotate(-45.000000) translate(-51.000000, -123.000000) \"></path>\n <path d=\"M43,59 L22.9976794,59 C18.5827987,59 15,55.418278 15,51 C15,46.5907123 18.5806831,43 22.9976794,43 L43,43 L43,22.9976794 C43,18.5827987 46.581722,15 51,15 C55.4092877,15 59,18.5806831 59,22.9976794 L59,43 L79.0023206,43 C83.4172013,43 87,46.581722 87,51 C87,55.4092877 83.4193169,59 79.0023206,59 L59,59 L59,79.0023206 C59,83.4172013 55.418278,87 51,87 C46.5907123,87 43,83.4193169 43,79.0023206 L43,59 Z\" transform=\"translate(51.000000, 51.000000) rotate(-45.000000) translate(-51.000000, -51.000000) \"></path>\n <path d=\"M115,59 L94.9976794,59 C90.5827987,59 87,55.418278 87,51 C87,46.5907123 90.5806831,43 94.9976794,43 L115,43 L115,22.9976794 C115,18.5827987 118.581722,15 123,15 C127.409288,15 131,18.5806831 131,22.9976794 L131,43 L151.002321,43 C155.417201,43 159,46.581722 159,51 C159,55.4092877 155.419317,59 151.002321,59 L131,59 L131,79.0023206 C131,83.4172013 127.418278,87 123,87 C118.590712,87 115,83.4193169 115,79.0023206 L115,59 Z\" transform=\"translate(123.000000, 51.000000) rotate(-45.000000) translate(-123.000000, -51.000000) \"></path>\n <path d=\"M115,131 L94.9976794,131 C90.5827987,131 87,127.418278 87,123 C87,118.590712 90.5806831,115 94.9976794,115 L115,115 L115,94.9976794 C115,90.5827987 118.581722,87 123,87 C127.409288,87 131,90.5806831 131,94.9976794 L131,115 L151.002321,115 C155.417201,115 159,118.581722 159,123 C159,127.409288 155.419317,131 151.002321,131 L131,131 L131,151.002321 C131,155.417201 127.418278,159 123,159 C118.590712,159 115,155.419317 115,151.002321 L115,131 Z\" transform=\"translate(123.000000, 123.000000) rotate(-45.000000) translate(-123.000000, -123.000000) \"></path>\n </g>\n</svg>"
},
"$:/core/images/close-button": {
"title": "$:/core/images/close-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-close-button tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\">\n <g fill-rule=\"evenodd\">\n <path d=\"M65.0864256,75.4091629 L14.9727349,125.522854 C11.8515951,128.643993 6.78104858,128.64922 3.65685425,125.525026 C0.539017023,122.407189 0.5336324,117.334539 3.65902635,114.209145 L53.7727171,64.0954544 L3.65902635,13.9817637 C0.537886594,10.8606239 0.532659916,5.79007744 3.65685425,2.6658831 C6.77469148,-0.451954124 11.8473409,-0.457338747 14.9727349,2.66805521 L65.0864256,52.7817459 L115.200116,2.66805521 C118.321256,-0.453084553 123.391803,-0.458311231 126.515997,2.6658831 C129.633834,5.78372033 129.639219,10.8563698 126.513825,13.9817637 L76.4001341,64.0954544 L126.513825,114.209145 C129.634965,117.330285 129.640191,122.400831 126.515997,125.525026 C123.39816,128.642863 118.32551,128.648248 115.200116,125.522854 L65.0864256,75.4091629 L65.0864256,75.4091629 Z\"></path>\n </g>\n</svg>\n"
},
"$:/core/images/close-others-button": {
"title": "$:/core/images/close-others-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-close-others-button tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M64,128 C99.346224,128 128,99.346224 128,64 C128,28.653776 99.346224,0 64,0 C28.653776,0 0,28.653776 0,64 C0,99.346224 28.653776,128 64,128 Z M64,112 C90.509668,112 112,90.509668 112,64 C112,37.490332 90.509668,16 64,16 C37.490332,16 16,37.490332 16,64 C16,90.509668 37.490332,112 64,112 Z M64,96 C81.673112,96 96,81.673112 96,64 C96,46.326888 81.673112,32 64,32 C46.326888,32 32,46.326888 32,64 C32,81.673112 46.326888,96 64,96 Z M64,80 C72.836556,80 80,72.836556 80,64 C80,55.163444 72.836556,48 64,48 C55.163444,48 48,55.163444 48,64 C48,72.836556 55.163444,80 64,80 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/copy-clipboard": {
"title": "$:/core/images/copy-clipboard",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-copy-clipboard tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n\t<g fill-rule=\"evenodd\">\n\t\t<rect x=\"40\" y=\"40\" width=\"33\" height=\"8\" rx=\"4\"></rect>\n\t\t<rect x=\"40\" y=\"82\" width=\"17\" height=\"8\" rx=\"4\"></rect>\n\t\t<rect x=\"40\" y=\"54\" width=\"17\" height=\"8\" rx=\"4\"></rect>\n\t\t<rect x=\"40\" y=\"96\" width=\"33\" height=\"8\" rx=\"4\"></rect>\n\t\t<rect x=\"40\" y=\"68\" width=\"12\" height=\"8\" rx=\"4\"></rect>\n\t\t<path d=\"M40,16 L23.9992458,16 C19.5813843,16 16,19.5907123 16,24 C16,24.0016363 16.0000005,24.0032725 16.0000015,24.0049086 C16.0000005,24.0065441 16,24.0081803 16,24.0098166 L16,119.990183 C16,119.99182 16.0000005,119.993456 16.0000015,119.995092 C16.0000005,119.996727 16,119.998364 16,120 C16,124.409288 19.5813843,128 23.9992458,128 L104.000754,128 C106.205061,128 108.203844,127.105595 109.652065,125.659342 C111.102424,124.21251 112,122.214511 112,120.007595 L112,103.992405 C112,99.5776607 108.418278,96 104,96 C99.5907123,96 96,99.5783218 96,103.992405 L96,112 L32,112 L32,32 L96,32 L96,40.0075946 C96,44.4223393 99.581722,48 104,48 C108.409288,48 112,44.4216782 112,40.0075946 L112,23.9924054 C112,21.7851587 111.104671,19.7871591 109.657101,18.3409203 C108.203844,16.8944047 106.205061,16 104.000754,16 L88,16 C88,11.5907123 84.4151006,8 79.9929031,8 L48.0070969,8 C43.5881712,8 40,11.581722 40,16 Z M44,14.9958262 C44,12.7889923 45.7964248,11 48.0000255,11 L79.9999745,11 C82.2091276,11 84,12.7965212 84,14.9958262 L84,19.0041738 C84,21.2110077 82.2035752,23 79.9999745,23 L48.0000255,23 C45.7908724,23 44,21.2034788 44,19.0041738 L44,14.9958262 Z\"></path>\n\t\t<rect x=\"62\" y=\"64\" width=\"66\" height=\"16\" rx=\"8\"></rect>\n\t\t<path d=\"M60.6568542,85.6568542 L76.6568542,69.6568543 L65.3431458,69.6568542 L81.3431458,85.6568542 C84.4673401,88.7810486 89.5326599,88.7810486 92.6568542,85.6568542 C95.7810486,82.5326599 95.7810486,77.4673401 92.6568542,74.3431458 L76.6568542,58.3431458 C73.5326599,55.2189514 68.4673401,55.2189514 65.3431458,58.3431457 L49.3431458,74.3431457 C46.2189514,77.4673401 46.2189514,82.5326599 49.3431457,85.6568542 C52.4673401,88.7810486 57.5326599,88.7810486 60.6568542,85.6568542 L60.6568542,85.6568542 Z\" transform=\"translate(71.000000, 72.000000) rotate(-90.000000) translate(-71.000000, -72.000000) \"></path>\n\t</g>\n</svg>"
},
"$:/core/images/delete-button": {
"title": "$:/core/images/delete-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-delete-button tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\">\n <g fill-rule=\"evenodd\" transform=\"translate(12.000000, 0.000000)\">\n <rect x=\"0\" y=\"11\" width=\"105\" height=\"16\" rx=\"8\"></rect>\n <rect x=\"28\" y=\"0\" width=\"48\" height=\"16\" rx=\"8\"></rect>\n <rect x=\"8\" y=\"16\" width=\"16\" height=\"112\" rx=\"8\"></rect>\n <rect x=\"8\" y=\"112\" width=\"88\" height=\"16\" rx=\"8\"></rect>\n <rect x=\"80\" y=\"16\" width=\"16\" height=\"112\" rx=\"8\"></rect>\n <rect x=\"56\" y=\"16\" width=\"16\" height=\"112\" rx=\"8\"></rect>\n <rect x=\"32\" y=\"16\" width=\"16\" height=\"112\" rx=\"8\"></rect>\n </g>\n</svg>"
},
"$:/core/images/done-button": {
"title": "$:/core/images/done-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-done-button tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\">\n <g fill-rule=\"evenodd\">\n <path d=\"M3.52445141,76.8322939 C2.07397484,75.3828178 1.17514421,73.3795385 1.17514421,71.1666288 L1.17514421,23.1836596 C1.17514421,18.7531992 4.75686621,15.1751442 9.17514421,15.1751442 C13.5844319,15.1751442 17.1751442,18.7606787 17.1751442,23.1836596 L17.1751442,63.1751442 L119.173716,63.1751442 C123.590457,63.1751442 127.175144,66.7568662 127.175144,71.1751442 C127.175144,75.5844319 123.592783,79.1751442 119.173716,79.1751442 L9.17657227,79.1751442 C6.96796403,79.1751442 4.9674142,78.279521 3.51911285,76.8315312 Z\" id=\"Rectangle-285\" transform=\"translate(64.175144, 47.175144) rotate(-45.000000) translate(-64.175144, -47.175144) \"></path>\n </g>\n</svg>"
},
"$:/core/images/down-arrow": {
"title": "$:/core/images/down-arrow",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-down-arrow tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\">\n <path d=\"M109.35638,81.3533152 C107.923899,82.7869182 105.94502,83.6751442 103.759224,83.6751442 L24.5910645,83.6751442 C20.225873,83.6751442 16.6751442,80.1307318 16.6751442,75.7584775 C16.6751442,71.3951199 20.2192225,67.8418109 24.5910645,67.8418109 L95.8418109,67.8418109 L95.8418109,-3.40893546 C95.8418109,-7.77412698 99.3862233,-11.3248558 103.758478,-11.3248558 C108.121835,-11.3248558 111.675144,-7.78077754 111.675144,-3.40893546 L111.675144,75.7592239 C111.675144,77.9416955 110.789142,79.9205745 109.356651,81.3538862 Z\" transform=\"translate(64.175144, 36.175144) rotate(45.000000) translate(-64.175144, -36.175144) \"></path>\n</svg>"
},
"$:/core/images/download-button": {
"title": "$:/core/images/download-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-download-button tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\"><g fill-rule=\"evenodd\"><path class=\"tc-image-download-button-ring\" d=\"M64,128 C99.346224,128 128,99.346224 128,64 C128,28.653776 99.346224,0 64,0 C28.653776,0 0,28.653776 0,64 C0,99.346224 28.653776,128 64,128 Z M64,112 C90.509668,112 112,90.509668 112,64 C112,37.490332 90.509668,16 64,16 C37.490332,16 16,37.490332 16,64 C16,90.509668 37.490332,112 64,112 Z\"/><path d=\"M34.3496823,66.4308767 L61.2415823,93.634668 C63.0411536,95.4551107 65.9588502,95.4551107 67.7584215,93.634668 L94.6503215,66.4308767 C96.4498928,64.610434 96.4498928,61.6588981 94.6503215,59.8384554 C93.7861334,58.9642445 92.6140473,58.4731195 91.3919019,58.4731195 L82.9324098,58.4731195 C80.3874318,58.4731195 78.3243078,56.3860674 78.3243078,53.8115729 L78.3243078,38.6615466 C78.3243078,36.0870521 76.2611837,34 73.7162058,34 L55.283798,34 C52.7388201,34 50.675696,36.0870521 50.675696,38.6615466 L50.675696,38.6615466 L50.675696,53.8115729 C50.675696,56.3860674 48.612572,58.4731195 46.0675941,58.4731195 L37.608102,58.4731195 C35.063124,58.4731195 33,60.5601716 33,63.134666 C33,64.3709859 33.4854943,65.5566658 34.3496823,66.4308767 L34.3496823,66.4308767 Z\"/></g></svg>"
},
"$:/core/images/edit-button": {
"title": "$:/core/images/edit-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-edit-button tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\">\n <g fill-rule=\"evenodd\">\n <path d=\"M116.870058,45.3431458 L108.870058,45.3431458 L108.870058,45.3431458 L108.870058,61.3431458 L116.870058,61.3431458 L116.870058,45.3431458 Z M124.870058,45.3431458 L127.649881,45.3431458 C132.066101,45.3431458 135.656854,48.9248678 135.656854,53.3431458 C135.656854,57.7524334 132.07201,61.3431458 127.649881,61.3431458 L124.870058,61.3431458 L124.870058,45.3431458 Z M100.870058,45.3431458 L15.6638275,45.3431458 C15.5064377,45.3431458 15.3501085,45.3476943 15.1949638,45.3566664 L15.1949638,45.3566664 C15.0628002,45.3477039 14.928279,45.3431458 14.7913977,45.3431458 C6.68160973,45.3431458 -8.34314575,53.3431458 -8.34314575,53.3431458 C-8.34314575,53.3431458 6.85614548,61.3431458 14.7913977,61.3431458 C14.9266533,61.3431458 15.0596543,61.3384973 15.190398,61.3293588 C15.3470529,61.3385075 15.5049057,61.3431458 15.6638275,61.3431458 L100.870058,61.3431458 L100.870058,45.3431458 L100.870058,45.3431458 Z\" transform=\"translate(63.656854, 53.343146) rotate(-45.000000) translate(-63.656854, -53.343146) \"></path>\n <path d=\"M35.1714596,124.189544 C41.9594858,123.613403 49.068777,121.917633 58.85987,118.842282 C60.6854386,118.268877 62.4306907,117.705515 65.1957709,116.802278 C81.1962861,111.575575 87.0734839,109.994907 93.9414474,109.655721 C102.29855,109.242993 107.795169,111.785371 111.520478,118.355045 C112.610163,120.276732 115.051363,120.951203 116.97305,119.861518 C118.894737,118.771832 119.569207,116.330633 118.479522,114.408946 C113.146151,105.003414 104.734907,101.112919 93.5468356,101.66546 C85.6716631,102.054388 79.4899908,103.716944 62.7116783,109.197722 C59.9734132,110.092199 58.2519873,110.64787 56.4625698,111.20992 C37.002649,117.322218 25.6914684,118.282267 16.8654804,112.957098 C14.9739614,111.815848 12.5154166,112.424061 11.3741667,114.31558 C10.2329168,116.207099 10.84113,118.665644 12.7326489,119.806894 C19.0655164,123.627836 26.4866335,124.926678 35.1714596,124.189544 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/erase": {
"title": "$:/core/images/erase",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-erase tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M60.0870401,127.996166 L123.102318,64.980888 C129.636723,58.4464827 129.629513,47.8655877 123.098967,41.3350425 L99.4657866,17.7018617 C92.927448,11.1635231 82.3486358,11.1698163 75.8199411,17.698511 L4.89768189,88.6207702 C-1.63672343,95.1551755 -1.6295126,105.736071 4.90103262,112.266616 L20.6305829,127.996166 L60.0870401,127.996166 Z M25.1375576,120.682546 L10.812569,106.357558 C7.5455063,103.090495 7.54523836,97.793808 10.8048093,94.5342371 L46.2691086,59.0699377 L81.7308914,94.5317205 L55.5800654,120.682546 L25.1375576,120.682546 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/excise": {
"title": "$:/core/images/excise",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-excise tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M56,107.313709 L53.6568542,109.656854 C50.5326599,112.781049 45.4673401,112.781049 42.3431457,109.656854 C39.2189514,106.53266 39.2189514,101.46734 42.3431458,98.3431457 L58.3431458,82.3431457 C61.4673401,79.2189514 66.5326599,79.2189514 69.6568542,82.3431458 L85.6568542,98.3431458 C88.7810486,101.46734 88.7810486,106.53266 85.6568542,109.656854 C82.5326599,112.781049 77.4673401,112.781049 74.3431458,109.656854 L72,107.313708 L72,121.597798 C72,125.133636 68.418278,128 64,128 C59.581722,128 56,125.133636 56,121.597798 L56,107.313709 Z M0,40.0070969 C0,35.5848994 3.59071231,32 8,32 C12.418278,32 16,35.5881712 16,40.0070969 L16,71.9929031 C16,76.4151006 12.4092877,80 8,80 C3.581722,80 0,76.4118288 0,71.9929031 L0,40.0070969 Z M32,40.0070969 C32,35.5848994 35.5907123,32 40,32 C44.418278,32 48,35.5881712 48,40.0070969 L48,71.9929031 C48,76.4151006 44.4092877,80 40,80 C35.581722,80 32,76.4118288 32,71.9929031 L32,40.0070969 Z M80,40.0070969 C80,35.5848994 83.5907123,32 88,32 C92.418278,32 96,35.5881712 96,40.0070969 L96,71.9929031 C96,76.4151006 92.4092877,80 88,80 C83.581722,80 80,76.4118288 80,71.9929031 L80,40.0070969 Z M56,8.00709688 C56,3.58489938 59.5907123,0 64,0 C68.418278,0 72,3.58817117 72,8.00709688 L72,39.9929031 C72,44.4151006 68.4092877,48 64,48 C59.581722,48 56,44.4118288 56,39.9929031 L56,8.00709688 Z M112,40.0070969 C112,35.5848994 115.590712,32 120,32 C124.418278,32 128,35.5881712 128,40.0070969 L128,71.9929031 C128,76.4151006 124.409288,80 120,80 C115.581722,80 112,76.4118288 112,71.9929031 L112,40.0070969 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/export-button": {
"title": "$:/core/images/export-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-export-button tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M8.00348646,127.999999 C8.00464867,128 8.00581094,128 8.00697327,128 L119.993027,128 C122.205254,128 124.207939,127.101378 125.657096,125.651198 L125.656838,125.65759 C127.104563,124.210109 128,122.21009 128,119.999949 L128,56.0000511 C128,51.5817449 124.409288,48 120,48 C115.581722,48 112,51.5797863 112,56.0000511 L112,112 L16,112 L16,56.0000511 C16,51.5817449 12.4092877,48 8,48 C3.581722,48 7.10542736e-15,51.5797863 7.10542736e-15,56.0000511 L7.10542736e-15,119.999949 C7.10542736e-15,124.418255 3.59071231,128 8,128 C8.00116233,128 8.0023246,128 8.00348681,127.999999 Z M56.6235633,27.3113724 L47.6580188,36.2769169 C44.5333664,39.4015692 39.4634864,39.4061295 36.339292,36.2819351 C33.2214548,33.1640979 33.2173444,28.0901742 36.3443103,24.9632084 L58.9616908,2.34582788 C60.5248533,0.782665335 62.5748436,0.000361191261 64.624516,2.38225238e-14 L64.6193616,0.00151809229 C66.6695374,0.000796251595 68.7211167,0.781508799 70.2854358,2.34582788 L92.9028163,24.9632084 C96.0274686,28.0878607 96.0320289,33.1577408 92.9078345,36.2819351 C89.7899973,39.3997724 84.7160736,39.4038827 81.5891078,36.2769169 L72.6235633,27.3113724 L72.6235633,88.5669606 C72.6235633,92.9781015 69.0418413,96.5662064 64.6235633,96.5662064 C60.2142756,96.5662064 56.6235633,92.984822 56.6235633,88.5669606 L56.6235633,27.3113724 L56.6235633,27.3113724 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/file": {
"title": "$:/core/images/file",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-file tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"nonzero\">\n <path d=\"M111.96811,30.5 L112,30.5 L112,119.999079 C112,124.417866 108.419113,128 104.000754,128 L23.9992458,128 C19.5813843,128 16,124.417687 16,119.999079 L16,8.00092105 C16,3.58213437 19.5808867,0 23.9992458,0 L81,0 L81,0.0201838424 C83.1589869,-0.071534047 85.3482153,0.707077645 86.9982489,2.35711116 L109.625176,24.9840387 C111.151676,26.510538 111.932942,28.4998414 111.96811,30.5 L111.96811,30.5 Z M81,8 L24,8 L24,120 L104,120 L104,30.5 L89.0003461,30.5 C84.5818769,30.5 81,26.9216269 81,22.4996539 L81,8 Z\"></path>\n <rect x=\"32\" y=\"36\" width=\"64\" height=\"8\" rx=\"4\"></rect>\n <rect x=\"32\" y=\"52\" width=\"64\" height=\"8\" rx=\"4\"></rect>\n <rect x=\"32\" y=\"68\" width=\"64\" height=\"8\" rx=\"4\"></rect>\n <rect x=\"32\" y=\"84\" width=\"64\" height=\"8\" rx=\"4\"></rect>\n <rect x=\"32\" y=\"100\" width=\"64\" height=\"8\" rx=\"4\"></rect>\n <rect x=\"32\" y=\"20\" width=\"40\" height=\"8\" rx=\"4\"></rect>\n </g>\n</svg>"
},
"$:/core/images/fixed-height": {
"title": "$:/core/images/fixed-height",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-fixed-height tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M60,35.6568542 L50.8284271,44.8284271 C49.26633,46.3905243 46.73367,46.3905243 45.1715729,44.8284271 C43.6094757,43.26633 43.6094757,40.73367 45.1715729,39.1715729 L61.1715729,23.1715729 C62.73367,21.6094757 65.2663299,21.6094757 66.8284271,23.1715728 L82.8284278,39.1715728 C84.390525,40.7336699 84.390525,43.2663299 82.8284279,44.8284271 C81.2663308,46.3905243 78.7336709,46.3905243 77.1715737,44.8284272 L68,35.6568539 L68,93.3431461 L77.1715737,84.1715728 C78.7336709,82.6094757 81.2663308,82.6094757 82.8284279,84.1715729 C84.390525,85.7336701 84.390525,88.2663301 82.8284278,89.8284272 L66.8284271,105.828427 C65.2663299,107.390524 62.73367,107.390524 61.1715729,105.828427 L45.1715729,89.8284271 C43.6094757,88.26633 43.6094757,85.73367 45.1715729,84.1715729 C46.73367,82.6094757 49.26633,82.6094757 50.8284271,84.1715729 L60,93.3431458 L60,35.6568542 L60,35.6568542 Z M16,116 L112,116 C114.209139,116 116,114.209139 116,112 C116,109.790861 114.209139,108 112,108 L16,108 C13.790861,108 12,109.790861 12,112 C12,114.209139 13.790861,116 16,116 L16,116 Z M16,20 L112,20 C114.209139,20 116,18.209139 116,16 C116,13.790861 114.209139,12 112,12 L16,12 C13.790861,12 12,13.790861 12,16 C12,18.209139 13.790861,20 16,20 L16,20 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/fold-all-button": {
"title": "$:/core/images/fold-all-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-fold-all tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <rect x=\"0\" y=\"0\" width=\"128\" height=\"16\" rx=\"8\"></rect>\n <rect x=\"0\" y=\"64\" width=\"128\" height=\"16\" rx=\"8\"></rect>\n <path d=\"M64.0292774,58.6235628 C61.9791013,58.6242848 59.9275217,57.8435723 58.3632024,56.279253 L35.7458219,33.6618725 C32.6211696,30.5372202 32.6166093,25.4673401 35.7408036,22.3431458 C38.8586409,19.2253085 43.9325646,19.2211982 47.0595304,22.348164 L64.0250749,39.3137085 L80.9906194,22.348164 C84.1152717,19.2235117 89.1851518,19.2189514 92.3093461,22.3431458 C95.4271834,25.460983 95.4312937,30.5349067 92.3043279,33.6618725 L69.6869474,56.279253 C68.1237851,57.8424153 66.0737951,58.6247195 64.0241231,58.6250809 Z\" transform=\"translate(64.024316, 39.313708) scale(1, -1) translate(-64.024316, -39.313708) \"></path>\n <path d=\"M64.0292774,123.621227 C61.9791013,123.621949 59.9275217,122.841236 58.3632024,121.276917 L35.7458219,98.6595365 C32.6211696,95.5348842 32.6166093,90.4650041 35.7408036,87.3408098 C38.8586409,84.2229725 43.9325646,84.2188622 47.0595304,87.345828 L64.0250749,104.311373 L80.9906194,87.345828 C84.1152717,84.2211757 89.1851518,84.2166154 92.3093461,87.3408098 C95.4271834,90.458647 95.4312937,95.5325707 92.3043279,98.6595365 L69.6869474,121.276917 C68.1237851,122.840079 66.0737951,123.622383 64.0241231,123.622745 Z\" transform=\"translate(64.024316, 104.311372) scale(1, -1) translate(-64.024316, -104.311372) \"></path>\n </g>\n</svg>"
},
"$:/core/images/fold-button": {
"title": "$:/core/images/fold-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-fold tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <rect x=\"0\" y=\"0\" width=\"128\" height=\"16\" rx=\"8\"></rect>\n <path d=\"M64.0292774,63.6235628 C61.9791013,63.6242848 59.9275217,62.8435723 58.3632024,61.279253 L35.7458219,38.6618725 C32.6211696,35.5372202 32.6166093,30.4673401 35.7408036,27.3431458 C38.8586409,24.2253085 43.9325646,24.2211982 47.0595304,27.348164 L64.0250749,44.3137085 L80.9906194,27.348164 C84.1152717,24.2235117 89.1851518,24.2189514 92.3093461,27.3431458 C95.4271834,30.460983 95.4312937,35.5349067 92.3043279,38.6618725 L69.6869474,61.279253 C68.1237851,62.8424153 66.0737951,63.6247195 64.0241231,63.6250809 Z\" transform=\"translate(64.024316, 44.313708) scale(1, -1) translate(-64.024316, -44.313708) \"></path>\n <path d=\"M64.0049614,105.998482 C61.9547853,105.999204 59.9032057,105.218491 58.3388864,103.654172 L35.7215059,81.0367916 C32.5968535,77.9121393 32.5922933,72.8422592 35.7164876,69.7180649 C38.8343248,66.6002276 43.9082485,66.5961173 47.0352144,69.7230831 L64.0007589,86.6886276 L80.9663034,69.7230831 C84.0909557,66.5984308 89.1608358,66.5938705 92.2850301,69.7180649 C95.4028673,72.8359021 95.4069777,77.9098258 92.2800119,81.0367916 L69.6626314,103.654172 C68.099469,105.217334 66.0494791,105.999639 63.999807,106 Z\" transform=\"translate(64.000000, 86.688628) scale(1, -1) translate(-64.000000, -86.688628) \"></path>\n </g>\n</svg>"
},
"$:/core/images/fold-others-button": {
"title": "$:/core/images/fold-others-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-fold-others tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <rect x=\"0\" y=\"56.0314331\" width=\"128\" height=\"16\" rx=\"8\"></rect>\n <path d=\"M101.657101,104.948818 C100.207918,103.498614 98.2051847,102.599976 95.9929031,102.599976 L72,102.599976 L72,78.6070725 C72,76.3964271 71.1036108,74.3936927 69.6545293,72.9441002 L69.6571005,72.9488183 C68.2079177,71.4986143 66.2051847,70.5999756 63.9929031,70.5999756 L32.0070969,70.5999756 C27.5881712,70.5999756 24,74.1816976 24,78.5999756 C24,83.0092633 27.5848994,86.5999756 32.0070969,86.5999756 L56,86.5999756 L56,110.592879 C56,112.803524 56.8963895,114.806259 58.3454713,116.255852 L58.3429,116.251133 C59.7920828,117.701337 61.7948156,118.599976 64.0070969,118.599976 L88,118.599976 L88,142.592879 C88,147.011804 91.581722,150.599976 96,150.599976 C100.409288,150.599976 104,147.015076 104,142.592879 L104,110.607072 C104,108.396427 103.103611,106.393693 101.654529,104.9441 Z\" transform=\"translate(64.000000, 110.599976) rotate(-45.000000) translate(-64.000000, -110.599976) \"></path>\n <path d=\"M101.725643,11.7488671 C100.27646,10.2986632 98.2737272,9.40002441 96.0614456,9.40002441 L72.0685425,9.40002441 L72.0685425,-14.5928787 C72.0685425,-16.8035241 71.1721533,-18.8062584 69.7230718,-20.255851 L69.725643,-20.2511329 C68.2764602,-21.7013368 66.2737272,-22.5999756 64.0614456,-22.5999756 L32.0756394,-22.5999756 C27.6567137,-22.5999756 24.0685425,-19.0182536 24.0685425,-14.5999756 C24.0685425,-10.1906879 27.6534419,-6.59997559 32.0756394,-6.59997559 L56.0685425,-6.59997559 L56.0685425,17.3929275 C56.0685425,19.6035732 56.964932,21.6063078 58.4140138,23.0559004 L58.4114425,23.0511823 C59.8606253,24.5013859 61.8633581,25.4000244 64.0756394,25.4000244 L88.0685425,25.4000244 L88.0685425,49.3929275 C88.0685425,53.8118532 91.6502645,57.4000244 96.0685425,57.4000244 C100.47783,57.4000244 104.068542,53.815125 104.068542,49.3929275 L104.068542,17.4071213 C104.068542,15.1964759 103.172153,13.1937416 101.723072,11.744149 Z\" transform=\"translate(64.068542, 17.400024) scale(1, -1) rotate(-45.000000) translate(-64.068542, -17.400024) \"></path>\n </g>\n</svg>"
},
"$:/core/images/folder": {
"title": "$:/core/images/folder",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-folder tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M55.6943257,128.000004 L7.99859666,128.000004 C3.5810937,128.000004 0,124.413822 0,119.996384 L0,48.0036243 C0,43.5833471 3.58387508,40.0000044 7.99859666,40.0000044 L16,40.0000044 L16,31.9999914 C16,27.5817181 19.5783731,24 24.0003461,24 L55.9996539,24 C60.4181231,24 64,27.5800761 64,31.9999914 L64,40.0000044 L104.001403,40.0000044 C108.418906,40.0000044 112,43.5861868 112,48.0036243 L112,59.8298353 L104,59.7475921 L104,51.9994189 C104,49.7887607 102.207895,48.0000044 99.9972215,48.0000044 L56,48.0000044 L56,36.0000255 C56,33.7898932 54.2072328,32 51.9957423,32 L28.0042577,32 C25.7890275,32 24,33.7908724 24,36.0000255 L24,48.0000044 L12.0027785,48.0000044 C9.78987688,48.0000044 8,49.7906032 8,51.9994189 L8,116.00059 C8,118.211248 9.79210499,120.000004 12.0027785,120.000004 L58.7630167,120.000004 L55.6943257,128.000004 L55.6943257,128.000004 Z\"></path>\n <path d=\"M23.8728955,55.5 L119.875702,55.5 C124.293205,55.5 126.87957,59.5532655 125.650111,64.5630007 L112.305967,118.936999 C111.077582,123.942356 106.497904,128 102.083183,128 L6.08037597,128 C1.66287302,128 -0.923492342,123.946735 0.305967145,118.936999 L13.650111,64.5630007 C14.878496,59.5576436 19.4581739,55.5 23.8728955,55.5 L23.8728955,55.5 L23.8728955,55.5 Z M25.6530124,64 L113.647455,64 C115.858129,64 117.151473,66.0930612 116.538306,68.6662267 L105.417772,115.333773 C104.803671,117.910859 102.515967,120 100.303066,120 L12.3086228,120 C10.0979492,120 8.8046054,117.906939 9.41777189,115.333773 L20.5383062,68.6662267 C21.1524069,66.0891409 23.4401107,64 25.6530124,64 L25.6530124,64 L25.6530124,64 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/full-screen-button": {
"title": "$:/core/images/full-screen-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-full-screen-button tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g>\n <g>\n <path d=\"M5.29777586e-31,8 C1.59060409e-15,3.581722 3.581722,0 8,0 L40,0 C44.418278,0 48,3.581722 48,8 C48,12.418278 44.418278,16 40,16 L16,16 L16,40 C16,44.418278 12.418278,48 8,48 C3.581722,48 -3.55271368e-15,44.418278 0,40 L3.55271368e-15,8 Z\"></path>\n </g>\n <g transform=\"translate(104.000000, 104.000000) rotate(-180.000000) translate(-104.000000, -104.000000) translate(80.000000, 80.000000)\">\n <path d=\"M5.29777586e-31,8 C1.59060409e-15,3.581722 3.581722,0 8,0 L40,0 C44.418278,0 48,3.581722 48,8 C48,12.418278 44.418278,16 40,16 L16,16 L16,40 C16,44.418278 12.418278,48 8,48 C3.581722,48 -3.55271368e-15,44.418278 0,40 L3.55271368e-15,8 Z\"></path>\n </g>\n <g transform=\"translate(24.000000, 104.000000) rotate(-90.000000) translate(-24.000000, -104.000000) translate(0.000000, 80.000000)\">\n <path d=\"M5.29777586e-31,8 C1.59060409e-15,3.581722 3.581722,0 8,0 L40,0 C44.418278,0 48,3.581722 48,8 C48,12.418278 44.418278,16 40,16 L16,16 L16,40 C16,44.418278 12.418278,48 8,48 C3.581722,48 -3.55271368e-15,44.418278 0,40 L3.55271368e-15,8 Z\"></path>\n </g>\n <g transform=\"translate(104.000000, 24.000000) rotate(90.000000) translate(-104.000000, -24.000000) translate(80.000000, 0.000000)\">\n <path d=\"M5.29777586e-31,8 C1.59060409e-15,3.581722 3.581722,0 8,0 L40,0 C44.418278,0 48,3.581722 48,8 C48,12.418278 44.418278,16 40,16 L16,16 L16,40 C16,44.418278 12.418278,48 8,48 C3.581722,48 -3.55271368e-15,44.418278 0,40 L3.55271368e-15,8 Z\"></path>\n </g>\n </g>\n</svg>"
},
"$:/core/images/github": {
"title": "$:/core/images/github",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-github tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M63.9383506,1.60695328 C28.6017227,1.60695328 -0.055756057,30.2970814 -0.055756057,65.6906208 C-0.055756057,94.003092 18.2804728,118.019715 43.7123154,126.493393 C46.9143781,127.083482 48.0812647,125.104717 48.0812647,123.405261 C48.0812647,121.886765 48.02626,117.85449 47.9948287,112.508284 C30.1929317,116.379268 26.4368926,103.916587 26.4368926,103.916587 C23.5255693,96.5129372 19.3294921,94.5420399 19.3294921,94.5420399 C13.5186324,90.5687739 19.7695302,90.6474524 19.7695302,90.6474524 C26.1933001,91.099854 29.5721638,97.2525155 29.5721638,97.2525155 C35.2808718,107.044059 44.5531024,104.215566 48.1991321,102.575118 C48.7806109,98.4366275 50.4346826,95.612068 52.2616263,94.0109598 C38.0507543,92.3941159 23.1091047,86.8944862 23.1091047,62.3389152 C23.1091047,55.3443933 25.6039634,49.6205298 29.6978889,45.1437211 C29.0378318,43.5229433 26.8415704,37.0044266 30.3265147,28.1845627 C30.3265147,28.1845627 35.6973364,26.4615028 47.9241083,34.7542205 C53.027764,33.330139 58.5046663,32.6220321 63.9462084,32.5944947 C69.3838216,32.6220321 74.856795,33.330139 79.9683085,34.7542205 C92.1872225,26.4615028 97.5501864,28.1845627 97.5501864,28.1845627 C101.042989,37.0044266 98.8467271,43.5229433 98.190599,45.1437211 C102.292382,49.6205298 104.767596,55.3443933 104.767596,62.3389152 C104.767596,86.9574291 89.8023734,92.3744463 75.5482834,93.9598188 C77.8427675,95.9385839 79.8897303,99.8489072 79.8897303,105.828476 C79.8897303,114.392635 79.8111521,121.304544 79.8111521,123.405261 C79.8111521,125.120453 80.966252,127.114954 84.2115327,126.489459 C109.623731,117.996111 127.944244,93.9952241 127.944244,65.6906208 C127.944244,30.2970814 99.2867652,1.60695328 63.9383506,1.60695328\"></path>\n </g>\n </svg>\n"
},
"$:/core/images/gitter": {
"title": "$:/core/images/gitter",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-gitter tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 18 25\">\n <rect x=\"15\" y=\"5\" width=\"2\" height=\"10\"></rect>\n <rect x=\"10\" y=\"5\" width=\"2\" height=\"20\"></rect>\n <rect x=\"5\" y=\"5\" width=\"2\" height=\"20\"></rect>\n <rect width=\"2\" height=\"15\"></rect>\n</svg>\n"
},
"$:/core/images/globe": {
"title": "$:/core/images/globe",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-globe tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M72.8111354,37.1275855 C72.8111354,37.9789875 72.8111354,38.8303894 72.8111354,39.6817913 C72.8111354,41.8784743 73.7885604,46.5631866 72.8111354,48.5143758 C71.3445471,51.4420595 68.1617327,52.0543531 66.4170946,54.3812641 C65.2352215,55.9575873 61.7987417,64.9821523 62.7262858,67.3005778 C66.6959269,77.2228204 74.26087,70.4881886 80.6887657,76.594328 C81.5527211,77.415037 83.5758191,78.8666631 83.985137,79.8899578 C87.2742852,88.1128283 76.4086873,94.8989524 87.7419325,106.189751 C88.9872885,107.430443 91.555495,102.372895 91.8205061,101.575869 C92.6726866,99.0129203 98.5458765,96.1267309 100.908882,94.5234439 C102.928056,93.1534443 105.782168,91.8557166 107.236936,89.7775886 C109.507391,86.5342557 108.717505,82.2640435 110.334606,79.0328716 C112.473794,74.7585014 114.163418,69.3979002 116.332726,65.0674086 C120.230862,57.2857361 121.054075,67.1596684 121.400359,67.5059523 C121.757734,67.8633269 122.411167,67.5059523 122.916571,67.5059523 C123.011132,67.5059523 124.364019,67.6048489 124.432783,67.5059523 C125.0832,66.5705216 123.390209,49.5852316 123.114531,48.2089091 C121.710578,41.1996597 116.17083,32.4278331 111.249523,27.7092761 C104.975994,21.6942076 104.160516,11.5121686 92.9912146,12.7547535 C92.7872931,12.7774397 87.906794,22.9027026 85.2136766,26.2672064 C81.486311,30.9237934 82.7434931,22.1144904 78.6876623,22.1144904 C78.6065806,22.1144904 77.5045497,22.0107615 77.4353971,22.1144904 C76.8488637,22.9942905 75.9952305,26.0101404 75.1288269,26.5311533 C74.8635477,26.6906793 73.4071369,26.2924966 73.2826811,26.5311533 C71.0401728,30.8313939 81.5394677,28.7427264 79.075427,34.482926 C76.7225098,39.9642538 72.747373,32.4860199 72.747373,43.0434079\"></path>\n <path d=\"M44.4668556,7.01044608 C54.151517,13.1403033 45.1489715,19.2084878 47.1611905,23.2253896 C48.8157833,26.5283781 51.4021933,28.6198851 48.8753629,33.038878 C46.8123257,36.6467763 42.0052989,37.0050492 39.251679,39.7621111 C36.2115749,42.8060154 33.7884281,48.7028116 32.4624592,52.6732691 C30.8452419,57.5158356 47.0088721,59.5388126 44.5246867,63.6811917 C43.1386839,65.9923513 37.7785192,65.1466282 36.0880227,63.8791519 C34.9234453,63.0059918 32.4946425,63.3331166 31.6713597,62.0997342 C29.0575851,58.1839669 29.4107339,54.0758543 28.0457962,49.9707786 C27.1076833,47.1493864 21.732611,47.8501656 20.2022714,49.3776393 C19.6790362,49.8998948 19.8723378,51.1703278 19.8723378,51.8829111 C19.8723378,57.1682405 26.9914913,55.1986414 26.9914913,58.3421973 C26.9914913,72.9792302 30.9191897,64.8771867 38.1313873,69.6793121 C48.1678018,76.3618966 45.9763926,76.981595 53.0777543,84.0829567 C56.7511941,87.7563965 60.8192437,87.7689005 62.503478,93.3767069 C64.1046972,98.7081071 53.1759798,98.7157031 50.786754,100.825053 C49.663965,101.816317 47.9736094,104.970571 46.5680513,105.439676 C44.7757187,106.037867 43.334221,105.93607 41.6242359,107.219093 C39.1967302,109.040481 37.7241465,112.151588 37.6034934,112.030935 C35.4555278,109.88297 34.0848666,96.5511248 33.7147244,93.7726273 C33.1258872,89.3524817 28.1241923,88.2337027 26.7275443,84.7420826 C25.1572737,80.8164061 28.2518481,75.223612 25.599097,70.9819941 C19.0797019,60.557804 13.7775712,56.4811506 10.2493953,44.6896152 C9.3074899,41.5416683 13.5912267,38.1609942 15.1264825,35.8570308 C17.0029359,33.0410312 17.7876232,30.0028946 19.8723378,27.2224065 C22.146793,24.1888519 40.8551166,9.46076832 43.8574051,8.63490613 L44.4668556,7.01044608 Z\"></path>\n <path d=\"M64,126 C98.2416545,126 126,98.2416545 126,64 C126,29.7583455 98.2416545,2 64,2 C29.7583455,2 2,29.7583455 2,64 C2,98.2416545 29.7583455,126 64,126 Z M64,120 C94.927946,120 120,94.927946 120,64 C120,33.072054 94.927946,8 64,8 C33.072054,8 8,33.072054 8,64 C8,94.927946 33.072054,120 64,120 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/heading-1": {
"title": "$:/core/images/heading-1",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-heading-1 tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M14,30 L27.25,30 L27.25,60.104 L61.7,60.104 L61.7,30 L74.95,30 L74.95,105.684 L61.7,105.684 L61.7,71.552 L27.25,71.552 L27.25,105.684 L14,105.684 L14,30 Z M84.3350766,43.78 C86.8790893,43.78 89.3523979,43.5680021 91.7550766,43.144 C94.1577553,42.7199979 96.3307336,42.0133383 98.2740766,41.024 C100.21742,40.0346617 101.87807,38.7626744 103.256077,37.208 C104.634084,35.6533256 105.535075,33.7453446 105.959077,31.484 L115.817077,31.484 L115.817077,105.684 L102.567077,105.684 L102.567077,53.32 L84.3350766,53.32 L84.3350766,43.78 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/heading-2": {
"title": "$:/core/images/heading-2",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-heading-2 tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M6,30 L19.25,30 L19.25,60.104 L53.7,60.104 L53.7,30 L66.95,30 L66.95,105.684 L53.7,105.684 L53.7,71.552 L19.25,71.552 L19.25,105.684 L6,105.684 L6,30 Z M125.519077,105.684 L74.8510766,105.684 C74.9217436,99.5359693 76.4057288,94.1653563 79.3030766,89.572 C82.2004244,84.9786437 86.1577182,80.986017 91.1750766,77.594 C93.5777553,75.8273245 96.0863969,74.113675 98.7010766,72.453 C101.315756,70.792325 103.718399,69.0080095 105.909077,67.1 C108.099754,65.1919905 109.901736,63.1250111 111.315077,60.899 C112.728417,58.6729889 113.47041,56.1113478 113.541077,53.214 C113.541077,51.8713266 113.382078,50.4403409 113.064077,48.921 C112.746075,47.4016591 112.127748,45.9883399 111.209077,44.681 C110.290405,43.3736601 109.018418,42.2783377 107.393077,41.395 C105.767735,40.5116622 103.647756,40.07 101.033077,40.07 C98.6303979,40.07 96.6340846,40.5469952 95.0440766,41.501 C93.4540687,42.4550048 92.1820814,43.762325 91.2280766,45.423 C90.2740719,47.083675 89.5674123,49.0446554 89.1080766,51.306 C88.648741,53.5673446 88.3837436,56.0053203 88.3130766,58.62 L76.2290766,58.62 C76.2290766,54.5213128 76.7767378,50.7230175 77.8720766,47.225 C78.9674154,43.7269825 80.610399,40.7060127 82.8010766,38.162 C84.9917542,35.6179873 87.6593942,33.6216739 90.8040766,32.173 C93.948759,30.7243261 97.6057224,30 101.775077,30 C106.297766,30 110.078395,30.7419926 113.117077,32.226 C116.155758,33.7100074 118.611401,35.5826554 120.484077,37.844 C122.356753,40.1053446 123.681739,42.5609868 124.459077,45.211 C125.236414,47.8610133 125.625077,50.3873213 125.625077,52.79 C125.625077,55.7580148 125.165748,58.4433213 124.247077,60.846 C123.328405,63.2486787 122.091751,65.4569899 120.537077,67.471 C118.982402,69.4850101 117.215753,71.3399915 115.237077,73.036 C113.2584,74.7320085 111.209087,76.3219926 109.089077,77.806 C106.969066,79.2900074 104.849087,80.7033266 102.729077,82.046 C100.609066,83.3886734 98.6480856,84.7313266 96.8460766,86.074 C95.0440676,87.4166734 93.47175,88.8123261 92.1290766,90.261 C90.7864032,91.7096739 89.8677458,93.2466585 89.3730766,94.872 L125.519077,94.872 L125.519077,105.684 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/heading-3": {
"title": "$:/core/images/heading-3",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-heading-3 tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M6,30 L19.25,30 L19.25,60.104 L53.7,60.104 L53.7,30 L66.95,30 L66.95,105.684 L53.7,105.684 L53.7,71.552 L19.25,71.552 L19.25,105.684 L6,105.684 L6,30 Z M94.8850766,62.224 C96.8637532,62.294667 98.8424001,62.1533351 100.821077,61.8 C102.799753,61.4466649 104.566402,60.8283378 106.121077,59.945 C107.675751,59.0616623 108.930072,57.8426744 109.884077,56.288 C110.838081,54.7333256 111.315077,52.8253446 111.315077,50.564 C111.315077,47.3839841 110.237421,44.8400095 108.082077,42.932 C105.926733,41.0239905 103.153094,40.07 99.7610766,40.07 C97.641066,40.07 95.8037511,40.4939958 94.2490766,41.342 C92.6944022,42.1900042 91.4047484,43.3383261 90.3800766,44.787 C89.3554048,46.2356739 88.5957458,47.860991 88.1010766,49.663 C87.6064075,51.465009 87.3944096,53.3199905 87.4650766,55.228 L75.3810766,55.228 C75.5224107,51.623982 76.1937373,48.2850154 77.3950766,45.211 C78.596416,42.1369846 80.2393995,39.4693446 82.3240766,37.208 C84.4087537,34.9466554 86.9350618,33.1800064 89.9030766,31.908 C92.8710915,30.6359936 96.2277246,30 99.9730766,30 C102.870424,30 105.714729,30.4239958 108.506077,31.272 C111.297424,32.1200042 113.806065,33.3566585 116.032077,34.982 C118.258088,36.6073415 120.042403,38.6743208 121.385077,41.183 C122.72775,43.6916792 123.399077,46.5713171 123.399077,49.822 C123.399077,53.5673521 122.551085,56.8356527 120.855077,59.627 C119.159068,62.4183473 116.509095,64.4499936 112.905077,65.722 L112.905077,65.934 C117.145098,66.7820042 120.448731,68.8843166 122.816077,72.241 C125.183422,75.5976835 126.367077,79.6786426 126.367077,84.484 C126.367077,88.017351 125.660417,91.1796527 124.247077,93.971 C122.833736,96.7623473 120.925755,99.129657 118.523077,101.073 C116.120398,103.016343 113.329093,104.517995 110.149077,105.578 C106.969061,106.638005 103.612428,107.168 100.079077,107.168 C95.7683884,107.168 92.005426,106.549673 88.7900766,105.313 C85.5747272,104.076327 82.8894207,102.327345 80.7340766,100.066 C78.5787325,97.8046554 76.9357489,95.0840159 75.8050766,91.904 C74.6744043,88.7239841 74.0737436,85.1906861 74.0030766,81.304 L86.0870766,81.304 C85.9457426,85.8266893 87.0587315,89.5896517 89.4260766,92.593 C91.7934218,95.5963483 95.3443863,97.098 100.079077,97.098 C104.107097,97.098 107.481396,95.9496782 110.202077,93.653 C112.922757,91.3563219 114.283077,88.0880212 114.283077,83.848 C114.283077,80.9506522 113.717749,78.6540085 112.587077,76.958 C111.456404,75.2619915 109.972419,73.9723378 108.135077,73.089 C106.297734,72.2056623 104.230755,71.6580011 101.934077,71.446 C99.6373985,71.2339989 97.2877553,71.163333 94.8850766,71.234 L94.8850766,62.224 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/heading-4": {
"title": "$:/core/images/heading-4",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-heading-4 tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M8,30 L21.25,30 L21.25,60.104 L55.7,60.104 L55.7,30 L68.95,30 L68.95,105.684 L55.7,105.684 L55.7,71.552 L21.25,71.552 L21.25,105.684 L8,105.684 L8,30 Z M84.5890766,78.548 L107.061077,78.548 L107.061077,45.9 L106.849077,45.9 L84.5890766,78.548 Z M128.049077,88.088 L118.509077,88.088 L118.509077,105.684 L107.061077,105.684 L107.061077,88.088 L75.2610766,88.088 L75.2610766,76.11 L107.061077,31.484 L118.509077,31.484 L118.509077,78.548 L128.049077,78.548 L128.049077,88.088 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/heading-5": {
"title": "$:/core/images/heading-5",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-heading-5 tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M6,30 L19.25,30 L19.25,60.104 L53.7,60.104 L53.7,30 L66.95,30 L66.95,105.684 L53.7,105.684 L53.7,71.552 L19.25,71.552 L19.25,105.684 L6,105.684 L6,30 Z M83.7550766,31.484 L122.127077,31.484 L122.127077,42.296 L92.7650766,42.296 L88.9490766,61.164 L89.1610766,61.376 C90.7864181,59.5386575 92.8533974,58.1430048 95.3620766,57.189 C97.8707558,56.2349952 100.361731,55.758 102.835077,55.758 C106.509762,55.758 109.795729,56.3763272 112.693077,57.613 C115.590424,58.8496729 118.0284,60.5809889 120.007077,62.807 C121.985753,65.0330111 123.487405,67.6653181 124.512077,70.704 C125.536748,73.7426819 126.049077,77.028649 126.049077,80.562 C126.049077,83.5300148 125.572081,86.5863176 124.618077,89.731 C123.664072,92.8756824 122.144754,95.7376538 120.060077,98.317 C117.9754,100.896346 115.30776,103.016325 112.057077,104.677 C108.806394,106.337675 104.919766,107.168 100.397077,107.168 C96.7930586,107.168 93.454092,106.691005 90.3800766,105.737 C87.3060613,104.782995 84.6030883,103.35201 82.2710766,101.444 C79.939065,99.5359905 78.0840835,97.1863473 76.7060766,94.395 C75.3280697,91.6036527 74.5684107,88.3353521 74.4270766,84.59 L86.5110766,84.59 C86.8644117,88.6180201 88.2423979,91.7096559 90.6450766,93.865 C93.0477553,96.0203441 96.2277235,97.098 100.185077,97.098 C102.729089,97.098 104.884401,96.6740042 106.651077,95.826 C108.417752,94.9779958 109.848738,93.8120074 110.944077,92.328 C112.039415,90.8439926 112.816741,89.1126766 113.276077,87.134 C113.735412,85.1553234 113.965077,83.0353446 113.965077,80.774 C113.965077,78.7246564 113.682413,76.763676 113.117077,74.891 C112.55174,73.018324 111.703749,71.3753404 110.573077,69.962 C109.442404,68.5486596 107.976086,67.4180042 106.174077,66.57 C104.372068,65.7219958 102.269755,65.298 99.8670766,65.298 C97.3230639,65.298 94.9380878,65.7749952 92.7120766,66.729 C90.4860655,67.6830048 88.8784149,69.4673203 87.8890766,72.082 L75.8050766,72.082 L83.7550766,31.484 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/heading-6": {
"title": "$:/core/images/heading-6",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-heading-6 tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M6,30 L19.25,30 L19.25,60.104 L53.7,60.104 L53.7,30 L66.95,30 L66.95,105.684 L53.7,105.684 L53.7,71.552 L19.25,71.552 L19.25,105.684 L6,105.684 L6,30 Z M112.587077,50.246 C112.304409,47.2073181 111.226753,44.751676 109.354077,42.879 C107.481401,41.006324 104.955093,40.07 101.775077,40.07 C99.584399,40.07 97.6940846,40.4763293 96.1040766,41.289 C94.5140687,42.1016707 93.1714154,43.1793266 92.0760766,44.522 C90.9807378,45.8646734 90.0974133,47.401658 89.4260766,49.133 C88.7547399,50.864342 88.2070787,52.6839905 87.7830766,54.592 C87.3590745,56.5000095 87.0587442,58.390324 86.8820766,60.263 C86.7054091,62.135676 86.5464107,63.8846585 86.4050766,65.51 L86.6170766,65.722 C88.2424181,62.7539852 90.4860623,60.5456739 93.3480766,59.097 C96.2100909,57.6483261 99.3017267,56.924 102.623077,56.924 C106.297762,56.924 109.583729,57.5599936 112.481077,58.832 C115.378424,60.1040064 117.834067,61.8529889 119.848077,64.079 C121.862087,66.3050111 123.399071,68.9373181 124.459077,71.976 C125.519082,75.0146819 126.049077,78.300649 126.049077,81.834 C126.049077,85.438018 125.466082,88.7769846 124.300077,91.851 C123.134071,94.9250154 121.455754,97.6103219 119.265077,99.907 C117.074399,102.203678 114.459758,103.987994 111.421077,105.26 C108.382395,106.532006 105.025762,107.168 101.351077,107.168 C95.9097161,107.168 91.4400941,106.16101 87.9420766,104.147 C84.4440591,102.13299 81.6880867,99.3770175 79.6740766,95.879 C77.6600666,92.3809825 76.2644138,88.2823568 75.4870766,83.583 C74.7097394,78.8836432 74.3210766,73.8133605 74.3210766,68.372 C74.3210766,63.9199777 74.7980719,59.4326893 75.7520766,54.91 C76.7060814,50.3873107 78.278399,46.2710186 80.4690766,42.561 C82.6597542,38.8509815 85.5393921,35.8300117 89.1080766,33.498 C92.6767611,31.1659883 97.0757171,30 102.305077,30 C105.273091,30 108.064397,30.4946617 110.679077,31.484 C113.293756,32.4733383 115.608067,33.8513245 117.622077,35.618 C119.636087,37.3846755 121.27907,39.5046543 122.551077,41.978 C123.823083,44.4513457 124.529743,47.2073181 124.671077,50.246 L112.587077,50.246 Z M100.927077,97.098 C103.117754,97.098 105.025735,96.6563378 106.651077,95.773 C108.276418,94.8896623 109.636738,93.7413404 110.732077,92.328 C111.827415,90.9146596 112.640074,89.271676 113.170077,87.399 C113.700079,85.526324 113.965077,83.6006766 113.965077,81.622 C113.965077,79.6433234 113.700079,77.7353425 113.170077,75.898 C112.640074,74.0606575 111.827415,72.4530069 110.732077,71.075 C109.636738,69.6969931 108.276418,68.5840042 106.651077,67.736 C105.025735,66.8879958 103.117754,66.464 100.927077,66.464 C98.736399,66.464 96.8107516,66.8703293 95.1500766,67.683 C93.4894017,68.4956707 92.0937489,69.5909931 90.9630766,70.969 C89.8324043,72.3470069 88.9844128,73.9546575 88.4190766,75.792 C87.8537405,77.6293425 87.5710766,79.5726564 87.5710766,81.622 C87.5710766,83.6713436 87.8537405,85.6146575 88.4190766,87.452 C88.9844128,89.2893425 89.8324043,90.9323261 90.9630766,92.381 C92.0937489,93.8296739 93.4894017,94.9779958 95.1500766,95.826 C96.8107516,96.6740042 98.736399,97.098 100.927077,97.098 L100.927077,97.098 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/help": {
"title": "$:/core/images/help",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-help tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M36.0548906,111.44117 C30.8157418,115.837088 20.8865444,118.803477 9.5,118.803477 C7.86465619,118.803477 6.25937294,118.742289 4.69372699,118.624467 C12.612543,115.984876 18.7559465,110.02454 21.0611049,102.609942 C8.74739781,92.845129 1.04940554,78.9359851 1.04940554,63.5 C1.04940554,33.9527659 29.2554663,10 64.0494055,10 C98.8433448,10 127.049406,33.9527659 127.049406,63.5 C127.049406,93.0472341 98.8433448,117 64.0494055,117 C53.9936953,117 44.48824,114.999337 36.0548906,111.44117 L36.0548906,111.44117 Z M71.4042554,77.5980086 C71.406883,77.2865764 71.4095079,76.9382011 71.4119569,76.5610548 C71.4199751,75.3262169 71.4242825,74.0811293 71.422912,72.9158546 C71.4215244,71.736154 71.4143321,70.709635 71.4001396,69.8743525 C71.4078362,68.5173028 71.9951951,67.7870427 75.1273009,65.6385471 C75.2388969,65.5619968 76.2124091,64.8981068 76.5126553,64.6910879 C79.6062455,62.5580654 81.5345849,60.9050204 83.2750652,58.5038955 C85.6146327,55.2762841 86.8327108,51.426982 86.8327108,46.8554323 C86.8327108,33.5625756 76.972994,24.9029551 65.3778484,24.9029551 C54.2752771,24.9029551 42.8794554,34.5115163 41.3121702,47.1975534 C40.9043016,50.4989536 43.2499725,53.50591 46.5513726,53.9137786 C49.8527728,54.3216471 52.8597292,51.9759763 53.2675978,48.6745761 C54.0739246,42.1479456 60.2395837,36.9492759 65.3778484,36.9492759 C70.6427674,36.9492759 74.78639,40.5885487 74.78639,46.8554323 C74.78639,50.4892974 73.6853224,52.008304 69.6746221,54.7736715 C69.4052605,54.9593956 68.448509,55.6118556 68.3131127,55.7047319 C65.6309785,57.5445655 64.0858213,58.803255 62.6123358,60.6352315 C60.5044618,63.2559399 59.3714208,66.3518252 59.3547527,69.9487679 C59.3684999,70.8407274 59.3752803,71.8084521 59.3765995,72.9300232 C59.3779294,74.0607297 59.3737237,75.2764258 59.36589,76.482835 C59.3634936,76.8518793 59.3609272,77.1924914 59.3583633,77.4963784 C59.3568319,77.6778944 59.3556368,77.8074256 59.3549845,77.8730928 C59.3219814,81.1994287 61.9917551,83.9227111 65.318091,83.9557142 C68.644427,83.9887173 71.3677093,81.3189435 71.4007124,77.9926076 C71.4014444,77.9187458 71.402672,77.7856841 71.4042554,77.5980086 Z M65.3778489,102.097045 C69.5359735,102.097045 72.9067994,98.7262189 72.9067994,94.5680944 C72.9067994,90.4099698 69.5359735,87.0391439 65.3778489,87.0391439 C61.2197243,87.0391439 57.8488984,90.4099698 57.8488984,94.5680944 C57.8488984,98.7262189 61.2197243,102.097045 65.3778489,102.097045 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/home-button": {
"title": "$:/core/images/home-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-home-button tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\">\n <g fill-rule=\"evenodd\">\n <path d=\"M112.9847,119.501583 C112.99485,119.336814 113,119.170705 113,119.003406 L113,67.56802 C116.137461,70.5156358 121.076014,70.4518569 124.133985,67.3938855 C127.25818,64.2696912 127.260618,59.2068102 124.131541,56.0777326 L70.3963143,2.34250601 C68.8331348,0.779326498 66.7828947,-0.000743167069 64.7337457,1.61675364e-05 C62.691312,-0.00409949529 60.6426632,0.777559815 59.077717,2.34250601 L33,28.420223 L33,28.420223 L33,8.00697327 C33,3.58484404 29.4092877,0 25,0 C20.581722,0 17,3.59075293 17,8.00697327 L17,44.420223 L5.3424904,56.0777326 C2.21694607,59.2032769 2.22220878,64.2760483 5.34004601,67.3938855 C8.46424034,70.5180798 13.5271213,70.5205187 16.6561989,67.3914411 L17,67.04764 L17,119.993027 C17,119.994189 17.0000002,119.995351 17.0000007,119.996514 C17.0000002,119.997675 17,119.998838 17,120 C17,124.418278 20.5881049,128 24.9992458,128 L105.000754,128 C109.418616,128 113,124.409288 113,120 C113,119.832611 112.99485,119.666422 112.9847,119.501583 Z M97,112 L97,51.5736087 L97,51.5736087 L64.7370156,19.3106244 L33,51.04764 L33,112 L97,112 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/import-button": {
"title": "$:/core/images/import-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-import-button tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M105.449437,94.2138951 C105.449437,94.2138951 110.049457,94.1897106 110.049457,99.4026111 C110.049457,104.615512 105.163246,104.615511 105.163246,104.615511 L45.0075072,105.157833 C45.0075072,105.157833 0.367531803,106.289842 0.367532368,66.6449212 C0.367532934,27.0000003 45.0428249,27.0000003 45.0428249,27.0000003 L105.532495,27.0000003 C105.532495,27.0000003 138.996741,25.6734987 138.996741,55.1771866 C138.996741,84.6808745 105.727102,82.8457535 105.727102,82.8457535 L56.1735087,82.8457535 C56.1735087,82.8457535 22.6899229,85.1500223 22.6899229,66.0913753 C22.6899229,47.0327282 56.1735087,49.3383013 56.1735087,49.3383013 L105.727102,49.3383013 C105.727102,49.3383013 111.245209,49.3383024 111.245209,54.8231115 C111.245209,60.3079206 105.727102,60.5074524 105.727102,60.5074524 L56.1735087,60.5074524 C56.1735087,60.5074524 37.48913,60.5074528 37.48913,66.6449195 C37.48913,72.7823862 56.1735087,71.6766023 56.1735087,71.6766023 L105.727102,71.6766029 C105.727102,71.6766029 127.835546,73.1411469 127.835546,55.1771866 C127.835546,35.5304025 105.727102,38.3035317 105.727102,38.3035317 L45.0428249,38.3035317 C45.0428249,38.3035317 11.5287276,38.3035313 11.5287276,66.6449208 C11.5287276,94.9863103 45.0428244,93.9579678 45.0428244,93.9579678 L105.449437,94.2138951 Z\" transform=\"translate(69.367532, 66.000000) rotate(-45.000000) translate(-69.367532, -66.000000) \"></path>\n </g>\n</svg>"
},
"$:/core/images/info-button": {
"title": "$:/core/images/info-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-info-button tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\">\n <g fill-rule=\"evenodd\">\n <g transform=\"translate(0.049406, 0.000000)\">\n <path d=\"M64,128 C99.346224,128 128,99.346224 128,64 C128,28.653776 99.346224,0 64,0 C28.653776,0 0,28.653776 0,64 C0,99.346224 28.653776,128 64,128 Z M64,112 C90.509668,112 112,90.509668 112,64 C112,37.490332 90.509668,16 64,16 C37.490332,16 16,37.490332 16,64 C16,90.509668 37.490332,112 64,112 Z\"></path>\n <circle cx=\"64\" cy=\"32\" r=\"8\"></circle>\n <rect x=\"56\" y=\"48\" width=\"16\" height=\"56\" rx=\"8\"></rect>\n </g>\n </g>\n</svg>"
},
"$:/core/images/italic": {
"title": "$:/core/images/italic",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-italic tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <polygon points=\"66.7114846 0 89.1204482 0 62.4089636 128 40 128\"></polygon>\n </g>\n</svg>"
},
"$:/core/images/left-arrow": {
"title": "$:/core/images/left-arrow",
"created": "20150315234410875",
"modified": "20150315235324760",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-left-arrow tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <path transform=\"rotate(135, 63.8945, 64.1752)\" d=\"m109.07576,109.35336c-1.43248,1.43361 -3.41136,2.32182 -5.59717,2.32182l-79.16816,0c-4.36519,0 -7.91592,-3.5444 -7.91592,-7.91666c0,-4.36337 3.54408,-7.91667 7.91592,-7.91667l71.25075,0l0,-71.25075c0,-4.3652 3.54442,-7.91592 7.91667,-7.91592c4.36336,0 7.91667,3.54408 7.91667,7.91592l0,79.16815c0,2.1825 -0.88602,4.16136 -2.3185,5.59467l-0.00027,-0.00056z\"/>\n</svg>\n"
},
"$:/core/images/line-width": {
"title": "$:/core/images/line-width",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-line-width tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M128,-97 L112.992786,-97 C112.452362,-97 112,-96.5522847 112,-96 C112,-95.4438648 112.444486,-95 112.992786,-95 L128,-95 L128,-97 Z M128,-78.6794919 L111.216185,-88.3696322 C110.748163,-88.6398444 110.132549,-88.4782926 109.856406,-88 C109.578339,-87.5183728 109.741342,-86.9117318 110.216185,-86.6375814 L128,-76.3700908 L128,-78.6794919 Z M78.6794919,-128 L88.3696322,-111.216185 C88.6437826,-110.741342 88.4816272,-110.134474 88,-109.856406 C87.5217074,-109.580264 86.9077936,-109.748163 86.6375814,-110.216185 L76.3700908,-128 L78.6794919,-128 Z M97,-128 L97,-112.992786 C97,-112.444486 96.5561352,-112 96,-112 C95.4477153,-112 95,-112.452362 95,-112.992786 L95,-128 L97,-128 Z M115.629909,-128 L105.362419,-110.216185 C105.088268,-109.741342 104.481627,-109.578339 104,-109.856406 C103.521707,-110.132549 103.360156,-110.748163 103.630368,-111.216185 L113.320508,-128 L115.629909,-128 Z M128,-113.320508 L111.216185,-103.630368 C110.741342,-103.356217 110.134474,-103.518373 109.856406,-104 C109.580264,-104.478293 109.748163,-105.092206 110.216185,-105.362419 L128,-115.629909 L128,-113.320508 Z M48,-96 C48,-96.5522847 48.4523621,-97 48.9927864,-97 L79.0072136,-97 C79.5555144,-97 80,-96.5561352 80,-96 C80,-95.4477153 79.5476379,-95 79.0072136,-95 L48.9927864,-95 C48.4444856,-95 48,-95.4438648 48,-96 Z M54.4307806,-120 C54.706923,-120.478293 55.3225377,-120.639844 55.7905589,-120.369632 L81.7838153,-105.362419 C82.2586577,-105.088268 82.4216611,-104.481627 82.1435935,-104 C81.8674512,-103.521707 81.2518365,-103.360156 80.7838153,-103.630368 L54.7905589,-118.637581 C54.3157165,-118.911732 54.152713,-119.518373 54.4307806,-120 Z M104,-82.1435935 C104.478293,-82.4197359 105.092206,-82.2518365 105.362419,-81.7838153 L120.369632,-55.7905589 C120.643783,-55.3157165 120.481627,-54.7088482 120,-54.4307806 C119.521707,-54.1546382 118.907794,-54.3225377 118.637581,-54.7905589 L103.630368,-80.7838153 C103.356217,-81.2586577 103.518373,-81.865526 104,-82.1435935 Z M96,-80 C96.5522847,-80 97,-79.5476379 97,-79.0072136 L97,-48.9927864 C97,-48.4444856 96.5561352,-48 96,-48 C95.4477153,-48 95,-48.4523621 95,-48.9927864 L95,-79.0072136 C95,-79.5555144 95.4438648,-80 96,-80 Z M88,-82.1435935 C88.4782926,-81.8674512 88.6398444,-81.2518365 88.3696322,-80.7838153 L73.3624186,-54.7905589 C73.0882682,-54.3157165 72.4816272,-54.152713 72,-54.4307806 C71.5217074,-54.706923 71.3601556,-55.3225377 71.6303678,-55.7905589 L86.6375814,-81.7838153 C86.9117318,-82.2586577 87.5183728,-82.4216611 88,-82.1435935 Z M82.1435935,-88 C82.4197359,-87.5217074 82.2518365,-86.9077936 81.7838153,-86.6375814 L55.7905589,-71.6303678 C55.3157165,-71.3562174 54.7088482,-71.5183728 54.4307806,-72 C54.1546382,-72.4782926 54.3225377,-73.0922064 54.7905589,-73.3624186 L80.7838153,-88.3696322 C81.2586577,-88.6437826 81.865526,-88.4816272 82.1435935,-88 Z M1.30626177e-08,-41.9868843 L15.0170091,-57.9923909 L20.7983821,-52.9749272 L44.7207091,-81.2095939 L73.4260467,-42.1002685 L85.984793,-56.6159488 L104.48741,-34.0310661 L127.969109,-47.4978019 L127.969109,7.99473128e-07 L1.30626177e-08,7.99473128e-07 L1.30626177e-08,-41.9868843 Z M96,-84 C102.627417,-84 108,-89.372583 108,-96 C108,-102.627417 102.627417,-108 96,-108 C89.372583,-108 84,-102.627417 84,-96 C84,-89.372583 89.372583,-84 96,-84 Z\"></path>\n <path d=\"M16,18 L112,18 C113.104569,18 114,17.1045695 114,16 C114,14.8954305 113.104569,14 112,14 L16,14 C14.8954305,14 14,14.8954305 14,16 C14,17.1045695 14.8954305,18 16,18 L16,18 Z M16,35 L112,35 C114.209139,35 116,33.209139 116,31 C116,28.790861 114.209139,27 112,27 L16,27 C13.790861,27 12,28.790861 12,31 C12,33.209139 13.790861,35 16,35 L16,35 Z M16,56 L112,56 C115.313708,56 118,53.3137085 118,50 C118,46.6862915 115.313708,44 112,44 L16,44 C12.6862915,44 10,46.6862915 10,50 C10,53.3137085 12.6862915,56 16,56 L16,56 Z M16,85 L112,85 C117.522847,85 122,80.5228475 122,75 C122,69.4771525 117.522847,65 112,65 L16,65 C10.4771525,65 6,69.4771525 6,75 C6,80.5228475 10.4771525,85 16,85 L16,85 Z M16,128 L112,128 C120.836556,128 128,120.836556 128,112 C128,103.163444 120.836556,96 112,96 L16,96 C7.163444,96 0,103.163444 0,112 C0,120.836556 7.163444,128 16,128 L16,128 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/link": {
"title": "$:/core/images/link",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-link tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M128.719999,57.568543 C130.219553,53.8628171 131.045202,49.8121445 131.045202,45.5685425 C131.045202,27.8915447 116.718329,13.5685425 99.0452364,13.5685425 L67.0451674,13.5685425 C49.3655063,13.5685425 35.0452019,27.8954305 35.0452019,45.5685425 C35.0452019,63.2455403 49.3720745,77.5685425 67.0451674,77.5685425 L99.0452364,77.5685425 C100.406772,77.5685425 101.748384,77.4835732 103.065066,77.3186499 C96.4792444,73.7895096 91.1190212,68.272192 87.7873041,61.5685425 L67.0506214,61.5685425 C58.2110723,61.5685425 51.0452019,54.4070414 51.0452019,45.5685425 C51.0452019,36.7319865 58.2005234,29.5685425 67.0506214,29.5685425 L99.0397824,29.5685425 C107.879331,29.5685425 115.045202,36.7300436 115.045202,45.5685425 C115.045202,48.9465282 113.99957,52.0800164 112.21335,54.6623005 C114.314383,56.4735917 117.050039,57.5685425 120.041423,57.5685425 L128.720003,57.5685425 Z\" transform=\"translate(83.045202, 45.568542) rotate(-225.000000) translate(-83.045202, -45.568542)\"></path>\n <path d=\"M-0.106255113,71.0452019 C-1.60580855,74.7509276 -2.43145751,78.8016001 -2.43145751,83.0452019 C-2.43145751,100.7222 11.8954151,115.045202 29.568508,115.045202 L61.568577,115.045202 C79.2482381,115.045202 93.5685425,100.718314 93.5685425,83.0452019 C93.5685425,65.3682041 79.2416699,51.0452019 61.568577,51.0452019 L29.568508,51.0452019 C28.206973,51.0452019 26.8653616,51.1301711 25.5486799,51.2950943 C32.1345,54.8242347 37.4947231,60.3415524 40.8264403,67.0452019 L61.563123,67.0452019 C70.4026721,67.0452019 77.5685425,74.206703 77.5685425,83.0452019 C77.5685425,91.8817579 70.413221,99.0452019 61.563123,99.0452019 L29.573962,99.0452019 C20.7344129,99.0452019 13.5685425,91.8837008 13.5685425,83.0452019 C13.5685425,79.6672162 14.6141741,76.533728 16.4003949,73.9514439 C14.2993609,72.1401527 11.5637054,71.0452019 8.5723215,71.0452019 L-0.106255113,71.0452019 Z\" transform=\"translate(45.568542, 83.045202) rotate(-225.000000) translate(-45.568542, -83.045202)\"></path>\n </g>\n</svg>"
},
"$:/core/images/linkify": {
"title": "$:/core/images/linkify",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-linkify-button tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\"><path d=\"M17.031 31.919H9.048V96.85h7.983v6.92H0V25h17.031v6.919zm24.66 0h-7.983V96.85h7.983v6.92H24.66V25h17.03v6.919zM67.77 56.422l11.975-3.903 2.306 7.096-12.063 3.903 7.628 10.379-6.12 4.435-7.63-10.467-7.45 10.2-5.943-4.523L58.1 63.518 45.95 59.35l2.306-7.096 12.064 4.17V43.825h7.45v12.596zM86.31 96.85h7.982V31.92H86.31V25h17.031v78.77H86.31v-6.92zm24.659 0h7.983V31.92h-7.983V25H128v78.77h-17.031v-6.92z\" fill-rule=\"evenodd\"/></svg>"
},
"$:/core/images/list-bullet": {
"title": "$:/core/images/list-bullet",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-list-bullet tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M11.6363636,40.2727273 C18.0629498,40.2727273 23.2727273,35.0629498 23.2727273,28.6363636 C23.2727273,22.2097775 18.0629498,17 11.6363636,17 C5.20977746,17 0,22.2097775 0,28.6363636 C0,35.0629498 5.20977746,40.2727273 11.6363636,40.2727273 Z M11.6363636,75.1818182 C18.0629498,75.1818182 23.2727273,69.9720407 23.2727273,63.5454545 C23.2727273,57.1188684 18.0629498,51.9090909 11.6363636,51.9090909 C5.20977746,51.9090909 0,57.1188684 0,63.5454545 C0,69.9720407 5.20977746,75.1818182 11.6363636,75.1818182 Z M11.6363636,110.090909 C18.0629498,110.090909 23.2727273,104.881132 23.2727273,98.4545455 C23.2727273,92.0279593 18.0629498,86.8181818 11.6363636,86.8181818 C5.20977746,86.8181818 0,92.0279593 0,98.4545455 C0,104.881132 5.20977746,110.090909 11.6363636,110.090909 Z M34.9090909,22.8181818 L128,22.8181818 L128,34.4545455 L34.9090909,34.4545455 L34.9090909,22.8181818 Z M34.9090909,57.7272727 L128,57.7272727 L128,69.3636364 L34.9090909,69.3636364 L34.9090909,57.7272727 Z M34.9090909,92.6363636 L128,92.6363636 L128,104.272727 L34.9090909,104.272727 L34.9090909,92.6363636 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/list-number": {
"title": "$:/core/images/list-number",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-list-number tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M33.8390805,22.3563218 L128,22.3563218 L128,34.1264368 L33.8390805,34.1264368 L33.8390805,22.3563218 Z M33.8390805,57.6666667 L128,57.6666667 L128,69.4367816 L33.8390805,69.4367816 L33.8390805,57.6666667 Z M33.8390805,92.9770115 L128,92.9770115 L128,104.747126 L33.8390805,104.747126 L33.8390805,92.9770115 Z M0.379509711,42.6307008 L0.379509711,40.4082314 L1.37821948,40.4082314 C2.20382368,40.4082314 2.82301754,40.268077 3.23581964,39.9877642 C3.64862174,39.7074513 3.85501969,39.0400498 3.85501969,37.9855395 L3.85501969,22.7686318 C3.85501969,21.3270228 3.66193774,20.4327047 3.27576803,20.0856507 C2.88959832,19.7385967 1.79768657,19.5650723 0,19.5650723 L0,17.4226919 C3.50215975,17.2758613 6.25191314,16.4683055 8.24934266,15 L10.3666074,15 L10.3666074,37.865406 C10.3666074,38.786434 10.5164123,39.4404875 10.8160268,39.8275862 C11.1156412,40.2146849 11.764796,40.4082314 12.7635108,40.4082314 L13.7622206,40.4082314 L13.7622206,42.6307008 L0.379509711,42.6307008 Z M0.0798967812,77.9873934 L0.0798967812,76.0852799 C7.27064304,69.5312983 10.8659622,63.5046623 10.8659622,58.005191 C10.8659622,56.4434479 10.5397203,55.195407 9.88722667,54.2610308 C9.23473303,53.3266546 8.36253522,52.8594735 7.27060709,52.8594735 C6.3784219,52.8594735 5.61608107,53.1764892 4.98356173,53.8105302 C4.35104238,54.4445712 4.03478745,55.1753759 4.03478745,56.0029663 C4.03478745,56.9773871 4.28113339,57.8316611 4.77383268,58.5658139 C4.88036225,58.7259926 4.93362624,58.8461249 4.93362624,58.9262143 C4.93362624,59.0730449 4.77383427,59.2065252 4.45424555,59.3266593 C4.2411864,59.4067486 3.70188852,59.6336652 2.83633573,60.0074156 C1.99741533,60.3811661 1.47809145,60.5680386 1.2783485,60.5680386 C1.03865696,60.5680386 0.765679018,60.1976307 0.459406492,59.4568039 C0.153133966,58.715977 0,57.9184322 0,57.0641453 C0,55.1153036 0.848894811,53.5202138 2.5467099,52.2788283 C4.24452499,51.0374428 6.34512352,50.4167594 8.84856852,50.4167594 C11.3120649,50.4167594 13.3793735,51.0874979 15.0505562,52.4289952 C16.7217389,53.7704924 17.5573177,55.5224215 17.5573177,57.684835 C17.5573177,58.9662652 17.2743527,60.2076321 16.7084144,61.4089729 C16.142476,62.6103138 14.7875733,64.4623531 12.6436656,66.9651465 C10.4997579,69.4679398 8.40914641,71.7804862 6.3717683,73.902855 L17.8169822,73.902855 L16.7982982,79.6292176 L14.6810335,79.6292176 C14.7609307,79.3489048 14.8008787,79.0952922 14.8008787,78.8683723 C14.8008787,78.4812736 14.7010087,78.237672 14.5012658,78.1375603 C14.3015228,78.0374485 13.9020429,77.9873934 13.3028141,77.9873934 L0.0798967812,77.9873934 Z M12.2042333,97.1935484 C13.9486551,97.2335931 15.4400468,97.8309175 16.6784531,98.9855395 C17.9168594,100.140162 18.5360532,101.75861 18.5360532,103.840934 C18.5360532,106.830938 17.4041935,109.233584 15.14044,111.048943 C12.8766866,112.864303 10.1402492,113.771969 6.93104577,113.771969 C4.92030005,113.771969 3.26245842,113.388213 1.95747114,112.62069 C0.652483855,111.853166 0,110.848727 0,109.607341 C0,108.833144 0.26964894,108.209124 0.808954909,107.735261 C1.34826088,107.261399 1.93749375,107.024472 2.57667119,107.024472 C3.21584864,107.024472 3.73850152,107.224692 4.14464552,107.625139 C4.55078953,108.025586 4.92696644,108.67964 5.27318756,109.587319 C5.73925445,110.855401 6.51158227,111.489433 7.59019421,111.489433 C8.85523291,111.489433 9.87723568,111.012241 10.6562332,110.057842 C11.4352307,109.103444 11.8247236,107.371536 11.8247236,104.862069 C11.8247236,103.153495 11.7048796,101.838714 11.4651881,100.917686 C11.2254966,99.9966584 10.6728827,99.5361513 9.80732989,99.5361513 C9.22141723,99.5361513 8.62219737,99.843156 8.00965231,100.457175 C7.51695303,100.951059 7.07752513,101.197998 6.69135542,101.197998 C6.3584505,101.197998 6.08880156,101.051169 5.88240051,100.757508 C5.67599946,100.463847 5.57280049,100.183539 5.57280049,99.916574 C5.57280049,99.5962164 5.67599946,99.3225818 5.88240051,99.0956618 C6.08880156,98.8687419 6.57150646,98.5016711 7.33052967,97.9944383 C10.2068282,96.0722929 11.6449559,93.9766521 11.6449559,91.7074527 C11.6449559,90.5194601 11.3386879,89.615131 10.7261429,88.9944383 C10.1135978,88.3737455 9.37455999,88.0634038 8.5090072,88.0634038 C7.71003539,88.0634038 6.98431355,88.3270274 6.33181991,88.8542825 C5.67932627,89.3815377 5.35308434,90.0122321 5.35308434,90.7463849 C5.35308434,91.3871 5.60608828,91.9810874 6.11210376,92.5283648 C6.28521432,92.7285883 6.3717683,92.8954387 6.3717683,93.028921 C6.3717683,93.1490551 5.80250943,93.4560598 4.6639746,93.9499444 C3.52543978,94.4438289 2.80970494,94.6907675 2.51674861,94.6907675 C2.10394651,94.6907675 1.76771758,94.3570667 1.50805174,93.6896552 C1.24838591,93.0222436 1.11855494,92.4082342 1.11855494,91.8476085 C1.11855494,90.0989901 2.04734573,88.6240327 3.90495518,87.4226919 C5.76256463,86.2213511 7.86982116,85.6206897 10.226788,85.6206897 C12.2907985,85.6206897 14.0784711,86.0678487 15.5898594,86.9621802 C17.1012478,87.8565117 17.8569306,89.0778566 17.8569306,90.6262514 C17.8569306,91.987771 17.2876717,93.2491599 16.1491369,94.4104561 C15.0106021,95.5717522 13.6956474,96.4994404 12.2042333,97.1935484 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/list": {
"title": "$:/core/images/list",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-list tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M0.719999312,185.568543 C2.21955287,181.862817 3.0452019,177.812144 3.0452019,173.568542 C3.0452019,155.891545 -11.2816707,141.568542 -28.9547636,141.568542 L-60.9548326,141.568542 C-78.6344937,141.568542 -92.9547981,155.895431 -92.9547981,173.568542 C-92.9547981,191.24554 -78.6279255,205.568542 -60.9548326,205.568542 L-28.9547636,205.568542 C-27.593228,205.568542 -26.2516158,205.483573 -24.9349335,205.31865 C-31.5207556,201.78951 -36.8809788,196.272192 -40.2126959,189.568542 L-60.9493786,189.568542 C-69.7889277,189.568542 -76.9547981,182.407041 -76.9547981,173.568542 C-76.9547981,164.731986 -69.7994766,157.568542 -60.9493786,157.568542 L-28.9602176,157.568542 C-20.1206685,157.568542 -12.9547981,164.730044 -12.9547981,173.568542 C-12.9547981,176.946528 -14.0004297,180.080016 -15.7866505,182.6623 C-13.6856165,184.473592 -10.949961,185.568542 -7.9585771,185.568542 L0.720002586,185.568542 Z\" transform=\"translate(-44.954798, 173.568542) rotate(-225.000000) translate(44.954798, -173.568542) \"></path>\n <path d=\"M87.7480315,128 L23.9992458,128 C19.5813843,128 16,124.409247 16,119.993027 L16,8.00697327 C16,3.58484404 19.5881049,0 23.9992458,0 L104.000754,0 C108.418616,0 112,3.59075293 112,8.00697327 L112,104 L91.2492027,104 C90.2848199,104 89.410573,104.391703 88.7768998,105.025201 C88.1373658,105.661376 87.7480315,106.53563 87.7480315,107.501171 L87.7480315,128 Z M95.7480315,127.879386 L111.627417,112 L95.7480315,112 L95.7480315,127.879386 Z M40,15.5089165 C40,13.5709954 41.5636015,12 43.4998101,12 L98.5001899,12 C100.433082,12 102,13.5614718 102,15.5089165 L102,16.4910835 C102,18.4290046 100.436399,20 98.5001899,20 L43.4998101,20 C41.5669183,20 40,18.4385282 40,16.4910835 L40,15.5089165 Z M32,22 C35.3137085,22 38,19.3137085 38,16 C38,12.6862915 35.3137085,10 32,10 C28.6862915,10 26,12.6862915 26,16 C26,19.3137085 28.6862915,22 32,22 Z M40,31.5089165 C40,29.5709954 41.5636015,28 43.4998101,28 L98.5001899,28 C100.433082,28 102,29.5614718 102,31.5089165 L102,32.4910835 C102,34.4290046 100.436399,36 98.5001899,36 L43.4998101,36 C41.5669183,36 40,34.4385282 40,32.4910835 L40,31.5089165 Z M40,47.5089165 C40,45.5709954 41.5636015,44 43.4998101,44 L98.5001899,44 C100.433082,44 102,45.5614718 102,47.5089165 L102,48.4910835 C102,50.4290046 100.436399,52 98.5001899,52 L43.4998101,52 C41.5669183,52 40,50.4385282 40,48.4910835 L40,47.5089165 Z M40,63.5089165 C40,61.5709954 41.5636015,60 43.4998101,60 L98.5001899,60 C100.433082,60 102,61.5614718 102,63.5089165 L102,64.4910835 C102,66.4290046 100.436399,68 98.5001899,68 L43.4998101,68 C41.5669183,68 40,66.4385282 40,64.4910835 L40,63.5089165 Z M40,79.5089165 C40,77.5709954 41.5636015,76 43.4998101,76 L98.5001899,76 C100.433082,76 102,77.5614718 102,79.5089165 L102,80.4910835 C102,82.4290046 100.436399,84 98.5001899,84 L43.4998101,84 C41.5669183,84 40,82.4385282 40,80.4910835 L40,79.5089165 Z M40,95.5089165 C40,93.5709954 41.5636015,92 43.4998101,92 L98.5001899,92 C100.433082,92 102,93.5614718 102,95.5089165 L102,96.4910835 C102,98.4290046 100.436399,100 98.5001899,100 L43.4998101,100 C41.5669183,100 40,98.4385282 40,96.4910835 L40,95.5089165 Z M40,111.508916 C40,109.570995 41.5680474,108 43.4972017,108 L76.5027983,108 C78.4342495,108 80,109.561472 80,111.508916 L80,112.491084 C80,114.429005 78.4319526,116 76.5027983,116 L43.4972017,116 C41.5657505,116 40,114.438528 40,112.491084 L40,111.508916 Z M32,38 C35.3137085,38 38,35.3137085 38,32 C38,28.6862915 35.3137085,26 32,26 C28.6862915,26 26,28.6862915 26,32 C26,35.3137085 28.6862915,38 32,38 Z M32,54 C35.3137085,54 38,51.3137085 38,48 C38,44.6862915 35.3137085,42 32,42 C28.6862915,42 26,44.6862915 26,48 C26,51.3137085 28.6862915,54 32,54 Z M32,70 C35.3137085,70 38,67.3137085 38,64 C38,60.6862915 35.3137085,58 32,58 C28.6862915,58 26,60.6862915 26,64 C26,67.3137085 28.6862915,70 32,70 Z M32,86 C35.3137085,86 38,83.3137085 38,80 C38,76.6862915 35.3137085,74 32,74 C28.6862915,74 26,76.6862915 26,80 C26,83.3137085 28.6862915,86 32,86 Z M32,102 C35.3137085,102 38,99.3137085 38,96 C38,92.6862915 35.3137085,90 32,90 C28.6862915,90 26,92.6862915 26,96 C26,99.3137085 28.6862915,102 32,102 Z M32,118 C35.3137085,118 38,115.313708 38,112 C38,108.686292 35.3137085,106 32,106 C28.6862915,106 26,108.686292 26,112 C26,115.313708 28.6862915,118 32,118 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/locked-padlock": {
"title": "$:/core/images/locked-padlock",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-locked-padlock tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M96.4723753,64 L105,64 L105,96.0097716 C105,113.673909 90.6736461,128 73.001193,128 L55.998807,128 C38.3179793,128 24,113.677487 24,96.0097716 L24,64 L32.0000269,64 C32.0028554,48.2766389 32.3030338,16.2688026 64.1594984,16.2688041 C95.9543927,16.2688056 96.4648869,48.325931 96.4723753,64 Z M80.5749059,64 L48.4413579,64 C48.4426205,47.71306 48.5829272,31.9999996 64.1595001,31.9999996 C79.8437473,31.9999996 81.1369461,48.1359182 80.5749059,64 Z M67.7315279,92.3641717 C70.8232551,91.0923621 73,88.0503841 73,84.5 C73,79.8055796 69.1944204,76 64.5,76 C59.8055796,76 56,79.8055796 56,84.5 C56,87.947435 58.0523387,90.9155206 61.0018621,92.2491029 L55.9067479,115.020857 L72.8008958,115.020857 L67.7315279,92.3641717 L67.7315279,92.3641717 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/mail": {
"title": "$:/core/images/mail",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-mail tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M122.826782,104.894066 C121.945525,105.22777 120.990324,105.41043 119.993027,105.41043 L8.00697327,105.41043 C7.19458381,105.41043 6.41045219,105.289614 5.67161357,105.064967 L5.67161357,105.064967 L39.8346483,70.9019325 L60.6765759,91.7438601 C61.6118278,92.679112 62.8865166,93.0560851 64.0946097,92.8783815 C65.2975108,93.0473238 66.5641085,92.6696979 67.4899463,91.7438601 L88.5941459,70.6396605 C88.6693095,70.7292352 88.7490098,70.8162939 88.8332479,70.9005321 L122.826782,104.894066 Z M127.903244,98.6568194 C127.966933,98.2506602 128,97.8343714 128,97.4103789 L128,33.410481 C128,32.7414504 127.917877,32.0916738 127.763157,31.4706493 L94.2292399,65.0045665 C94.3188145,65.0797417 94.4058701,65.1594458 94.4901021,65.2436778 L127.903244,98.6568194 Z M0.205060636,99.2178117 C0.0709009529,98.6370366 0,98.0320192 0,97.4103789 L0,33.410481 C0,32.694007 0.0944223363,31.9995312 0.27147538,31.3387595 L0.27147538,31.3387595 L34.1777941,65.2450783 L0.205060636,99.2178117 L0.205060636,99.2178117 Z M5.92934613,25.6829218 C6.59211333,25.5051988 7.28862283,25.4104299 8.00697327,25.4104299 L119.993027,25.4104299 C120.759109,25.4104299 121.500064,25.5178649 122.201605,25.7184927 L122.201605,25.7184927 L64.0832611,83.8368368 L5.92934613,25.6829218 L5.92934613,25.6829218 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/menu-button": {
"title": "$:/core/images/menu-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-menu-button tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\">\n <rect x=\"0\" y=\"16\" width=\"128\" height=\"16\" rx=\"8\"></rect>\n <rect x=\"0\" y=\"56\" width=\"128\" height=\"16\" rx=\"8\"></rect>\n <rect x=\"0\" y=\"96\" width=\"128\" height=\"16\" rx=\"8\"></rect>\n</svg>"
},
"$:/core/images/mono-block": {
"title": "$:/core/images/mono-block",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-mono-block tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M23.9653488,32.9670593 L24.3217888,32.9670593 C25.0766067,32.9670593 25.6497006,33.1592554 26.0410876,33.5436534 C26.4324747,33.9280514 26.6281653,34.4906619 26.6281653,35.2315017 C26.6281653,36.0562101 26.4219913,36.6502709 26.009637,37.0137017 C25.5972828,37.3771326 24.9158602,37.5588453 23.9653488,37.5588453 L17.6542639,37.5588453 C16.6897744,37.5588453 16.0048573,37.380627 15.5994921,37.0241852 C15.1941269,36.6677435 14.9914474,36.0701882 14.9914474,35.2315017 C14.9914474,34.4207713 15.1941269,33.8406885 15.5994921,33.4912358 C16.0048573,33.141783 16.6897744,32.9670593 17.6542639,32.9670593 L18.388111,32.9670593 L17.5284616,30.5139133 L8.47069195,30.5139133 L7.5691084,32.9670593 L8.30295547,32.9670593 C9.25346691,32.9670593 9.93488953,33.1452775 10.3472438,33.5017193 C10.759598,33.8581611 10.965772,34.4347494 10.965772,35.2315017 C10.965772,36.0562101 10.759598,36.6502709 10.3472438,37.0137017 C9.93488953,37.3771326 9.25346691,37.5588453 8.30295547,37.5588453 L2.89345418,37.5588453 C1.92896463,37.5588453 1.24404754,37.3771326 0.838682371,37.0137017 C0.433317198,36.6502709 0.230637652,36.0562101 0.230637652,35.2315017 C0.230637652,34.4906619 0.426328248,33.9280514 0.817715312,33.5436534 C1.20910238,33.1592554 1.78219626,32.9670593 2.53701417,32.9670593 L2.89345418,32.9670593 L8.51262607,17.3256331 L6.83526132,17.3256331 C5.88474988,17.3256331 5.20332727,17.1439204 4.79097304,16.7804895 C4.37861882,16.4170587 4.1724448,15.8299869 4.1724448,15.0192565 C4.1724448,14.1945481 4.37861882,13.6004873 4.79097304,13.2370565 C5.20332727,12.8736257 5.88474988,12.691913 6.83526132,12.691913 L14.6979086,12.691913 C15.9419603,12.691913 16.815579,13.3628521 17.318791,14.7047506 L17.318791,14.7676518 L23.9653488,32.9670593 Z M12.9786097,17.3256331 L9.9383861,26.1737321 L16.0188333,26.1737321 L12.9786097,17.3256331 Z M35.3809383,26.6979086 L35.3809383,33.0928616 L38.5259972,33.0928616 C40.7485166,33.0928616 42.3140414,32.8482484 43.2226185,32.3590146 C44.1311956,31.8697807 44.5854773,31.0520736 44.5854773,29.9058686 C44.5854773,28.7456855 44.1521624,27.9209895 43.2855197,27.4317556 C42.4188769,26.9425218 40.9022748,26.6979086 38.7356678,26.6979086 L35.3809383,26.6979086 Z M46.0741385,24.370565 C47.5977525,24.9296893 48.7159844,25.6949794 49.428868,26.666458 C50.1417516,27.6379366 50.498188,28.8784752 50.498188,30.388111 C50.498188,31.6601189 50.1906743,32.8202846 49.5756374,33.8686428 C48.9606006,34.917001 48.0799929,35.7766419 46.933788,36.4475911 C46.2628387,36.8389782 45.5115266,37.1220307 44.6798291,37.296757 C43.8481316,37.4714834 42.6704935,37.5588453 41.1468796,37.5588453 L39.3856466,37.5588453 L30.2020747,37.5588453 C29.2795194,37.5588453 28.6190637,37.3771326 28.2206876,37.0137017 C27.8223114,36.6502709 27.6231264,36.0562101 27.6231264,35.2315017 C27.6231264,34.4906619 27.811828,33.9280514 28.189237,33.5436534 C28.5666459,33.1592554 29.118773,32.9670593 29.8456347,32.9670593 L30.2020747,32.9670593 L30.2020747,17.3256331 L29.8456347,17.3256331 C29.118773,17.3256331 28.5666459,17.1299425 28.189237,16.7385554 C27.811828,16.3471683 27.6231264,15.7740744 27.6231264,15.0192565 C27.6231264,14.2085262 27.8258059,13.6179599 28.2311711,13.24754 C28.6365363,12.8771201 29.2934976,12.691913 30.2020747,12.691913 L39.8469219,12.691913 C42.796303,12.691913 45.0362615,13.2650068 46.5668644,14.4112118 C48.0974674,15.5574168 48.8627574,17.2347648 48.8627574,19.443306 C48.8627574,20.5335986 48.6286276,21.4945792 48.1603609,22.3262767 C47.6920943,23.1579742 46.9966938,23.8393968 46.0741385,24.370565 L46.0741385,24.370565 Z M35.3809383,17.1998307 L35.3809383,22.4835296 L38.2114913,22.4835296 C39.9307988,22.4835296 41.1433816,22.2808501 41.8492761,21.8754849 C42.5551706,21.4701197 42.9081126,20.7852027 42.9081126,19.8207131 C42.9081126,18.912136 42.5901154,18.2481858 41.9541114,17.8288425 C41.3181074,17.4094992 40.2872373,17.1998307 38.8614701,17.1998307 L35.3809383,17.1998307 Z M71.244119,13.3838259 C71.5236812,12.880614 71.8102281,12.5241775 72.1037684,12.3145059 C72.3973087,12.1048342 72.7677231,12 73.2150226,12 C73.8999499,12 74.3856819,12.1817127 74.6722332,12.5451435 C74.9587844,12.9085744 75.1020579,13.5305909 75.1020579,14.4112118 L75.143992,19.8626472 C75.143992,20.8271368 74.9867406,21.4771091 74.6722332,21.8125837 C74.3577257,22.1480584 73.7881263,22.3157932 72.9634178,22.3157932 C72.3763372,22.3157932 71.92555,22.1760142 71.6110425,21.896452 C71.2965351,21.6168898 71.0274605,21.0997075 70.8038107,20.3448896 C70.4403799,19.0169692 69.8602971,18.0629775 69.0635448,17.482886 C68.2667926,16.9027945 67.1625385,16.612753 65.7507494,16.612753 C63.5981206,16.612753 61.9487284,17.3396038 60.8025235,18.7933272 C59.6563185,20.2470506 59.0832246,22.3507245 59.0832246,25.104412 C59.0832246,27.8441215 59.6633074,29.9477954 60.8234905,31.4154969 C61.9836736,32.8831984 63.6400547,33.6170381 65.7926836,33.6170381 C67.2603851,33.6170381 68.878327,33.1278116 70.6465578,32.149344 C72.4147886,31.1708763 73.5295261,30.6816498 73.9908037,30.6816498 C74.53595,30.6816498 74.9937262,30.9122852 75.3641461,31.3735628 C75.734566,31.8348404 75.9197732,32.4079343 75.9197732,33.0928616 C75.9197732,34.3229353 74.836486,35.4831009 72.669879,36.5733935 C70.5032721,37.663686 68.0641285,38.2088241 65.3523753,38.2088241 C61.6901107,38.2088241 58.7267959,36.9997358 56.4623422,34.5815228 C54.1978885,32.1633099 53.0656786,29.0043046 53.0656786,25.104412 C53.0656786,21.3443006 54.2118664,18.22024 56.5042763,15.7321366 C58.7966863,13.2440331 61.7040894,12 65.226573,12 C66.2190187,12 67.1974717,12.1118232 68.1619613,12.3354729 C69.1264508,12.5591227 70.1538264,12.9085702 71.244119,13.3838259 L71.244119,13.3838259 Z M81.4645862,32.9670593 L81.4645862,17.3256331 L81.1081461,17.3256331 C80.3533282,17.3256331 79.7802344,17.1299425 79.3888473,16.7385554 C78.9974602,16.3471683 78.8017696,15.7740744 78.8017696,15.0192565 C78.8017696,14.2085262 79.0114381,13.6179599 79.4307814,13.24754 C79.8501247,12.8771201 80.5280528,12.691913 81.4645862,12.691913 L85.4063933,12.691913 L86.6434498,12.691913 C89.5648747,12.691913 91.7034933,12.8177141 93.0593699,13.06932 C94.4152465,13.320926 95.5684233,13.740263 96.5189347,14.3273436 C98.210286,15.3337675 99.5067362,16.7699967 100.408324,18.6360743 C101.309912,20.5021519 101.7607,22.6582429 101.7607,25.104412 C101.7607,27.6903623 101.247012,29.9512876 100.219621,31.8872557 C99.1922296,33.8232239 97.7350336,35.2874089 95.8479888,36.2798546 C94.9953241,36.7271541 93.9959043,37.0521403 92.8496993,37.2548229 C91.7034944,37.4575055 89.9981906,37.5588453 87.7337369,37.5588453 L85.4063933,37.5588453 L81.4645862,37.5588453 C80.5000966,37.5588453 79.8151795,37.380627 79.4098143,37.0241852 C79.0044492,36.6677435 78.8017696,36.0701882 78.8017696,35.2315017 C78.8017696,34.4906619 78.9974602,33.9280514 79.3888473,33.5436534 C79.7802344,33.1592554 80.3533282,32.9670593 81.1081461,32.9670593 L81.4645862,32.9670593 Z M86.8740874,17.2417648 L86.8740874,32.9670593 L88.0692098,32.9670593 C90.7110725,32.9670593 92.6609895,32.3205814 93.9190194,31.0276063 C95.1770492,29.7346312 95.8060547,27.7462749 95.8060547,25.0624779 C95.8060547,22.4206153 95.1665658,20.4497314 93.8875688,19.1497672 C92.6085718,17.849803 90.6831161,17.1998307 88.1111439,17.1998307 C87.7756693,17.1998307 87.5205727,17.2033252 87.3458463,17.2103142 C87.1711199,17.2173033 87.0138685,17.2277867 86.8740874,17.2417648 L86.8740874,17.2417648 Z M121.94052,17.1159625 L112.190837,17.1159625 L112.190837,22.4835296 L115.88104,22.4835296 L115.88104,22.2319249 C115.88104,21.4351727 116.055763,20.841112 116.405216,20.4497249 C116.754669,20.0583378 117.285829,19.8626472 117.998713,19.8626472 C118.627728,19.8626472 119.141415,20.0408655 119.539792,20.3973072 C119.938168,20.753749 120.137353,21.2045363 120.137353,21.7496826 C120.137353,21.7776388 120.144342,21.8684951 120.15832,22.0222543 C120.172298,22.1760135 120.179287,22.3297704 120.179287,22.4835296 L120.179287,26.8237109 C120.179287,27.7602442 120.011552,28.4311834 119.676077,28.8365486 C119.340603,29.2419138 118.795465,29.4445933 118.040647,29.4445933 C117.327763,29.4445933 116.789614,29.2558917 116.426183,28.8784827 C116.062752,28.5010738 115.88104,27.9419578 115.88104,27.201118 L115.88104,26.8237109 L112.190837,26.8237109 L112.190837,33.0928616 L121.94052,33.0928616 L121.94052,30.5977816 C121.94052,29.6612482 122.118738,28.9903091 122.47518,28.5849439 C122.831622,28.1795787 123.415199,27.9768992 124.225929,27.9768992 C125.022682,27.9768992 125.592281,28.1760842 125.934745,28.5744604 C126.277208,28.9728365 126.448438,29.6472701 126.448438,30.5977816 L126.448438,35.6718099 C126.448438,36.4266278 126.30167,36.9298322 126.008129,37.1814382 C125.714589,37.4330442 125.134506,37.5588453 124.267863,37.5588453 L107.095842,37.5588453 C106.173287,37.5588453 105.512831,37.3771326 105.114455,37.0137017 C104.716079,36.6502709 104.516894,36.0562101 104.516894,35.2315017 C104.516894,34.4906619 104.705595,33.9280514 105.083004,33.5436534 C105.460413,33.1592554 106.01254,32.9670593 106.739402,32.9670593 L107.095842,32.9670593 L107.095842,17.3256331 L106.739402,17.3256331 C106.026518,17.3256331 105.477886,17.126448 105.093488,16.7280719 C104.70909,16.3296957 104.516894,15.7600963 104.516894,15.0192565 C104.516894,14.2085262 104.719573,13.6179599 105.124938,13.24754 C105.530304,12.8771201 106.187265,12.691913 107.095842,12.691913 L124.267863,12.691913 C125.120528,12.691913 125.697116,12.8212085 125.997646,13.0798036 C126.298175,13.3383986 126.448438,13.8520864 126.448438,14.6208824 L126.448438,19.3175037 C126.448438,20.2680151 126.273714,20.9494377 125.924261,21.361792 C125.574808,21.7741462 125.008703,21.9803202 124.225929,21.9803202 C123.415199,21.9803202 122.831622,21.7706517 122.47518,21.3513084 C122.118738,20.9319652 121.94052,20.254037 121.94052,19.3175037 L121.94052,17.1159625 Z M19.7719369,47.6405477 C20.037521,47.1373358 20.3205734,46.7808993 20.6211028,46.5712277 C20.9216322,46.361556 21.295541,46.2567218 21.7428405,46.2567218 C22.4277678,46.2567218 22.9134998,46.4384345 23.2000511,46.8018653 C23.4866023,47.1652962 23.6298758,47.7873127 23.6298758,48.6679336 L23.6718099,54.119369 C23.6718099,55.0838586 23.5145586,55.7338309 23.2000511,56.0693055 C22.8855436,56.4047802 22.3089553,56.572515 21.4702687,56.572515 C20.8831881,56.572515 20.4254119,56.4292415 20.0969263,56.1426902 C19.7684407,55.856139 19.4993662,55.3424512 19.2896945,54.6016114 C18.9122856,53.2597129 18.3322027,52.3022267 17.5494286,51.7291243 C16.7666545,51.1560218 15.6693894,50.8694748 14.2576003,50.8694748 C12.1049715,50.8694748 10.4590738,51.5963256 9.31985785,53.050049 C8.18064193,54.5037724 7.61104252,56.6074463 7.61104252,59.3611338 C7.61104252,62.1148214 8.20859773,64.2429566 9.40372609,65.7456034 C10.5988544,67.2482501 12.2936748,67.9995623 14.488238,67.9995623 C14.9914499,67.9995623 15.5645438,67.9401562 16.2075368,67.8213423 C16.8505299,67.7025283 17.6053364,67.5173212 18.4719792,67.2657152 L18.4719792,63.9529198 L16.1027015,63.9529198 C15.1521901,63.9529198 14.4777564,63.7781961 14.0793803,63.4287433 C13.6810042,63.0792906 13.4818191,62.4992078 13.4818191,61.6884774 C13.4818191,60.8497908 13.6810042,60.2522356 14.0793803,59.8957938 C14.4777564,59.5393521 15.1521901,59.3611338 16.1027015,59.3611338 L23.6718099,59.3611338 C24.6502776,59.3611338 25.3386891,59.5358576 25.7370653,59.8853103 C26.1354414,60.2347631 26.3346265,60.8218348 26.3346265,61.6465433 C26.3346265,62.3873831 26.1354414,62.9569825 25.7370653,63.3553586 C25.3386891,63.7537347 24.7621008,63.9529198 24.0072829,63.9529198 L23.6718099,63.9529198 L23.6718099,68.9430799 L23.6718099,69.1946846 C23.6718099,69.6419841 23.6228873,69.9529924 23.5250405,70.1277188 C23.4271937,70.3024451 23.2315031,70.4806634 22.9379628,70.6623788 C22.1412106,71.1376345 20.8762107,71.5569715 19.1429251,71.9204023 C17.4096396,72.2838332 15.6554131,72.4655459 13.8801932,72.4655459 C10.2179286,72.4655459 7.25461383,71.2564576 4.99016011,68.8382446 C2.72570638,66.4200317 1.59349651,63.2610264 1.59349651,59.3611338 C1.59349651,55.6010224 2.73968428,52.4769618 5.03209423,49.9888583 C7.32450417,47.5007549 10.2319073,46.2567218 13.7543909,46.2567218 C14.7328585,46.2567218 15.7078171,46.368545 16.6792957,46.5921947 C17.6507743,46.8158445 18.6816444,47.165292 19.7719369,47.6405477 L19.7719369,47.6405477 Z M35.611576,51.5823548 L35.611576,56.4047785 L42.4678043,56.4047785 L42.4678043,51.5823548 L42.1323314,51.5823548 C41.3775135,51.5823548 40.8009251,51.3866642 40.402549,50.9952772 C40.0041729,50.6038901 39.8049878,50.0307962 39.8049878,49.2759783 C39.8049878,48.4512699 40.0111618,47.8572091 40.4235161,47.4937783 C40.8358703,47.1303474 41.5172929,46.9486347 42.4678043,46.9486347 L47.8773056,46.9486347 C48.8278171,46.9486347 49.5022507,47.1303474 49.9006269,47.4937783 C50.299003,47.8572091 50.498188,48.4512699 50.498188,49.2759783 C50.498188,50.0307962 50.3059919,50.6038901 49.9215939,50.9952772 C49.5371959,51.3866642 48.9745854,51.5823548 48.2337456,51.5823548 L47.8773056,51.5823548 L47.8773056,67.2237811 L48.2337456,67.2237811 C48.9885636,67.2237811 49.5616574,67.4159772 49.9530445,67.8003752 C50.3444316,68.1847732 50.5401222,68.7473837 50.5401222,69.4882235 C50.5401222,70.3129319 50.3374426,70.9069927 49.9320774,71.2704235 C49.5267123,71.6338543 48.8417952,71.815567 47.8773056,71.815567 L42.4678043,71.815567 C41.5033148,71.815567 40.8183977,71.6373488 40.4130325,71.280907 C40.0076674,70.9244652 39.8049878,70.32691 39.8049878,69.4882235 C39.8049878,68.7473837 40.0041729,68.1847732 40.402549,67.8003752 C40.8009251,67.4159772 41.3775135,67.2237811 42.1323314,67.2237811 L42.4678043,67.2237811 L42.4678043,61.0384986 L35.611576,61.0384986 L35.611576,67.2237811 L35.9470489,67.2237811 C36.7018668,67.2237811 37.2784552,67.4159772 37.6768313,67.8003752 C38.0752074,68.1847732 38.2743925,68.7473837 38.2743925,69.4882235 C38.2743925,70.3129319 38.0682185,70.9069927 37.6558642,71.2704235 C37.24351,71.6338543 36.5620874,71.815567 35.611576,71.815567 L30.2020747,71.815567 C29.2375851,71.815567 28.552668,71.6373488 28.1473029,71.280907 C27.7419377,70.9244652 27.5392581,70.32691 27.5392581,69.4882235 C27.5392581,68.7473837 27.7349487,68.1847732 28.1263358,67.8003752 C28.5177229,67.4159772 29.0908168,67.2237811 29.8456347,67.2237811 L30.2020747,67.2237811 L30.2020747,51.5823548 L29.8456347,51.5823548 C29.1047949,51.5823548 28.5421844,51.3866642 28.1577864,50.9952772 C27.7733884,50.6038901 27.5811923,50.0307962 27.5811923,49.2759783 C27.5811923,48.4512699 27.7803773,47.8572091 28.1787534,47.4937783 C28.5771296,47.1303474 29.2515632,46.9486347 30.2020747,46.9486347 L35.611576,46.9486347 C36.5481093,46.9486347 37.2260374,47.1303474 37.6453807,47.4937783 C38.064724,47.8572091 38.2743925,48.4512699 38.2743925,49.2759783 C38.2743925,50.0307962 38.0752074,50.6038901 37.6768313,50.9952772 C37.2784552,51.3866642 36.7018668,51.5823548 35.9470489,51.5823548 L35.611576,51.5823548 Z M67.365213,51.5823548 L67.365213,67.2237811 L70.887679,67.2237811 C71.8381904,67.2237811 72.519613,67.4019993 72.9319673,67.7584411 C73.3443215,68.1148829 73.5504955,68.6914712 73.5504955,69.4882235 C73.5504955,70.2989538 73.340827,70.8895201 72.9214837,71.25994 C72.5021404,71.6303599 71.8242123,71.815567 70.887679,71.815567 L58.4332458,71.815567 C57.4827343,71.815567 56.8013117,71.6338543 56.3889575,71.2704235 C55.9766033,70.9069927 55.7704292,70.3129319 55.7704292,69.4882235 C55.7704292,68.6774931 55.9731088,68.0974103 56.378474,67.7479575 C56.7838391,67.3985048 57.4687562,67.2237811 58.4332458,67.2237811 L61.9557117,67.2237811 L61.9557117,51.5823548 L58.4332458,51.5823548 C57.4827343,51.5823548 56.8013117,51.4006421 56.3889575,51.0372113 C55.9766033,50.6737805 55.7704292,50.0867087 55.7704292,49.2759783 C55.7704292,48.4512699 55.9731088,47.8641981 56.378474,47.5147453 C56.7838391,47.1652926 57.4687562,46.9905689 58.4332458,46.9905689 L70.887679,46.9905689 C71.8801247,46.9905689 72.5720308,47.1652926 72.9634178,47.5147453 C73.3548049,47.8641981 73.5504955,48.4512699 73.5504955,49.2759783 C73.5504955,50.0867087 73.347816,50.6737805 72.9424508,51.0372113 C72.5370856,51.4006421 71.8521685,51.5823548 70.887679,51.5823548 L67.365213,51.5823548 Z M97.8608265,51.5823548 L97.8608265,63.1771386 L97.8608265,63.5755127 C97.8608265,65.4485794 97.7385199,66.8044357 97.493903,67.6431222 C97.2492861,68.4818088 96.8404325,69.2296264 96.26733,69.8865976 C95.5264902,70.7392623 94.4991146,71.3822457 93.1851723,71.815567 C91.87123,72.2488884 90.2917273,72.4655459 88.4466169,72.4655459 C87.1466527,72.4655459 85.8921362,72.3397448 84.6830298,72.0881388 C83.4739233,71.8365328 82.3102631,71.4591296 81.1920144,70.9559176 C80.5769776,70.6763554 80.175113,70.31293 79.9864085,69.8656305 C79.797704,69.418331 79.7033532,68.6914802 79.7033532,67.6850564 L79.7033532,63.3658422 C79.7033532,62.1637247 79.8780769,61.3250508 80.2275297,60.849795 C80.5769824,60.3745393 81.185021,60.136915 82.0516638,60.136915 C83.2957156,60.136915 83.9806326,61.0524675 84.1064356,62.8835998 C84.1204137,63.2050963 84.1413806,63.4497096 84.1693368,63.6174469 C84.3370741,65.2389076 84.7144774,66.3466561 85.301558,66.9407258 C85.8886386,67.5347954 86.8251579,67.8318258 88.1111439,67.8318258 C89.7046484,67.8318258 90.8263749,67.4089943 91.476357,66.5633187 C92.126339,65.7176431 92.4513252,64.1765796 92.4513252,61.9400821 L92.4513252,51.5823548 L88.9288593,51.5823548 C87.9783478,51.5823548 87.2969252,51.4006421 86.884571,51.0372113 C86.4722168,50.6737805 86.2660427,50.0867087 86.2660427,49.2759783 C86.2660427,48.4512699 86.4652278,47.8641981 86.8636039,47.5147453 C87.26198,47.1652926 87.9503916,46.9905689 88.9288593,46.9905689 L99.6220595,46.9905689 C100.600527,46.9905689 101.288939,47.1652926 101.687315,47.5147453 C102.085691,47.8641981 102.284876,48.4512699 102.284876,49.2759783 C102.284876,50.0867087 102.078702,50.6737805 101.666348,51.0372113 C101.253994,51.4006421 100.572571,51.5823548 99.6220595,51.5823548 L97.8608265,51.5823548 Z M112.505343,51.5823548 L112.505343,57.9353738 L118.984165,51.4565525 C118.257303,51.3726838 117.747109,51.1665098 117.453569,50.8380242 C117.160029,50.5095387 117.013261,49.9888619 117.013261,49.2759783 C117.013261,48.4512699 117.212446,47.8572091 117.610822,47.4937783 C118.009198,47.1303474 118.683632,46.9486347 119.634143,46.9486347 L124.771073,46.9486347 C125.721584,46.9486347 126.396018,47.1303474 126.794394,47.4937783 C127.19277,47.8572091 127.391955,48.4512699 127.391955,49.2759783 C127.391955,50.0447743 127.19277,50.6213627 126.794394,51.0057607 C126.396018,51.3901587 125.812441,51.5823548 125.043645,51.5823548 L124.561402,51.5823548 L118.459988,57.641835 C119.592215,58.4805215 120.626579,59.5812811 121.563113,60.9441468 C122.499646,62.3070125 123.596911,64.400203 124.854941,67.2237811 L125.127513,67.2237811 L125.546854,67.2237811 C126.371563,67.2237811 126.98659,67.4124827 127.391955,67.7898917 C127.79732,68.1673006 128,68.7334056 128,69.4882235 C128,70.3129319 127.793826,70.9069927 127.381472,71.2704235 C126.969118,71.6338543 126.287695,71.815567 125.337183,71.815567 L122.758235,71.815567 C121.626008,71.815567 120.710456,71.0537715 120.01155,69.5301576 C119.885747,69.2505954 119.787902,69.026949 119.718012,68.8592117 C118.795456,66.9022764 117.949793,65.3926632 117.180997,64.3303269 C116.412201,63.2679906 115.510627,62.2965265 114.476247,61.4159056 L112.505343,63.302941 L112.505343,67.2237811 L112.840816,67.2237811 C113.595634,67.2237811 114.172222,67.4159772 114.570599,67.8003752 C114.968975,68.1847732 115.16816,68.7473837 115.16816,69.4882235 C115.16816,70.3129319 114.961986,70.9069927 114.549631,71.2704235 C114.137277,71.6338543 113.455855,71.815567 112.505343,71.815567 L107.095842,71.815567 C106.131352,71.815567 105.446435,71.6373488 105.04107,71.280907 C104.635705,70.9244652 104.433025,70.32691 104.433025,69.4882235 C104.433025,68.7473837 104.628716,68.1847732 105.020103,67.8003752 C105.41149,67.4159772 105.984584,67.2237811 106.739402,67.2237811 L107.095842,67.2237811 L107.095842,51.5823548 L106.739402,51.5823548 C105.998562,51.5823548 105.435952,51.3866642 105.051554,50.9952772 C104.667156,50.6038901 104.474959,50.0307962 104.474959,49.2759783 C104.474959,48.4512699 104.674145,47.8572091 105.072521,47.4937783 C105.470897,47.1303474 106.14533,46.9486347 107.095842,46.9486347 L112.505343,46.9486347 C113.441877,46.9486347 114.119805,47.1303474 114.539148,47.4937783 C114.958491,47.8572091 115.16816,48.4512699 115.16816,49.2759783 C115.16816,50.0307962 114.968975,50.6038901 114.570599,50.9952772 C114.172222,51.3866642 113.595634,51.5823548 112.840816,51.5823548 L112.505343,51.5823548 Z M13.439885,96.325622 L17.4445933,84.4372993 C17.6961993,83.6545252 18.0456468,83.0849258 18.4929463,82.728484 C18.9402458,82.3720422 19.5343065,82.193824 20.2751463,82.193824 L23.5460076,82.193824 C24.496519,82.193824 25.1779416,82.3755367 25.5902958,82.7389675 C26.0026501,83.1023984 26.2088241,83.6964591 26.2088241,84.5211676 C26.2088241,85.2759855 26.009639,85.8490794 25.6112629,86.2404664 C25.2128868,86.6318535 24.6362984,86.8275441 23.8814805,86.8275441 L23.5460076,86.8275441 L24.1330852,102.46897 L24.4895252,102.46897 C25.2443431,102.46897 25.8104481,102.661166 26.187857,103.045564 C26.565266,103.429962 26.7539676,103.992573 26.7539676,104.733413 C26.7539676,105.558121 26.5547826,106.152182 26.1564064,106.515613 C25.7580303,106.879044 25.0835967,107.060756 24.1330852,107.060756 L19.4154969,107.060756 C18.4649855,107.060756 17.7905518,106.882538 17.3921757,106.526096 C16.9937996,106.169654 16.7946145,105.572099 16.7946145,104.733413 C16.7946145,103.992573 16.9868106,103.429962 17.3712086,103.045564 C17.7556066,102.661166 18.325206,102.46897 19.0800239,102.46897 L19.4154969,102.46897 L19.1219581,89.6790642 L16.0607674,99.1981091 C15.8371177,99.9109927 15.5191204,100.42468 15.1067662,100.739188 C14.694412,101.053695 14.1248126,101.210947 13.3979509,101.210947 C12.6710892,101.210947 12.0945008,101.053695 11.6681685,100.739188 C11.2418362,100.42468 10.91685,99.9109927 10.6932002,99.1981091 L7.65297664,89.6790642 L7.35943781,102.46897 L7.69491075,102.46897 C8.44972866,102.46897 9.01932808,102.661166 9.40372609,103.045564 C9.78812409,103.429962 9.98032022,103.992573 9.98032022,104.733413 C9.98032022,105.558121 9.77764067,106.152182 9.3722755,106.515613 C8.96691032,106.879044 8.29597114,107.060756 7.35943781,107.060756 L2.62088241,107.060756 C1.68434908,107.060756 1.01340989,106.879044 0.608044719,106.515613 C0.202679546,106.152182 0,105.558121 0,104.733413 C0,103.992573 0.192196121,103.429962 0.57659413,103.045564 C0.960992139,102.661166 1.53059155,102.46897 2.28540946,102.46897 L2.62088241,102.46897 L3.22892713,86.8275441 L2.89345418,86.8275441 C2.13863627,86.8275441 1.56204791,86.6318535 1.16367179,86.2404664 C0.765295672,85.8490794 0.5661106,85.2759855 0.5661106,84.5211676 C0.5661106,83.6964591 0.772284622,83.1023984 1.18463885,82.7389675 C1.59699308,82.3755367 2.27841569,82.193824 3.22892713,82.193824 L6.49978838,82.193824 C7.22665007,82.193824 7.81022738,82.3685477 8.25053783,82.7180005 C8.69084827,83.0674532 9.05077919,83.6405471 9.33034138,84.4372993 L13.439885,96.325622 Z M43.8935644,98.3803938 L43.8935644,86.8275441 L42.7403761,86.8275441 C41.8178209,86.8275441 41.1573651,86.6458314 40.758989,86.2824006 C40.3606129,85.9189697 40.1614278,85.3318979 40.1614278,84.5211676 C40.1614278,83.7104372 40.3606129,83.119871 40.758989,82.7494511 C41.1573651,82.3790312 41.8178209,82.193824 42.7403761,82.193824 L48.6950209,82.193824 C49.6035981,82.193824 50.2605593,82.3790312 50.6659245,82.7494511 C51.0712897,83.119871 51.2739692,83.7104372 51.2739692,84.5211676 C51.2739692,85.2620074 51.0817731,85.8316068 50.6973751,86.2299829 C50.3129771,86.628359 49.7643445,86.8275441 49.051461,86.8275441 L48.6950209,86.8275441 L48.6950209,105.865634 C48.6950209,106.522605 48.6251315,106.934953 48.4853504,107.10269 C48.3455693,107.270428 48.0310665,107.354295 47.5418327,107.354295 L45.4451268,107.354295 C44.7741775,107.354295 44.3024234,107.284406 44.0298503,107.144625 C43.7572771,107.004843 43.5231473,106.76023 43.3274538,106.410777 L34.6051571,91.0838571 L34.6051571,102.46897 L35.8212466,102.46897 C36.7298237,102.46897 37.379796,102.643694 37.7711831,102.993147 C38.1625701,103.3426 38.3582607,103.922682 38.3582607,104.733413 C38.3582607,105.558121 38.1590757,106.152182 37.7606995,106.515613 C37.3623234,106.879044 36.7158456,107.060756 35.8212466,107.060756 L29.8037005,107.060756 C28.8951234,107.060756 28.2381621,106.879044 27.832797,106.515613 C27.4274318,106.152182 27.2247522,105.558121 27.2247522,104.733413 C27.2247522,103.992573 27.4134539,103.429962 27.7908629,103.045564 C28.1682718,102.661166 28.7273878,102.46897 29.4682276,102.46897 L29.8037005,102.46897 L29.8037005,86.8275441 L29.4682276,86.8275441 C28.755344,86.8275441 28.203217,86.628359 27.8118299,86.2299829 C27.4204428,85.8316068 27.2247522,85.2620074 27.2247522,84.5211676 C27.2247522,83.7104372 27.4309263,83.119871 27.8432805,82.7494511 C28.2556347,82.3790312 28.9091015,82.193824 29.8037005,82.193824 L33.2422983,82.193824 C34.0670067,82.193824 34.6261227,82.3021527 34.919663,82.5188134 C35.2132033,82.7354741 35.5416839,83.1722835 35.9051148,83.8292546 L43.8935644,98.3803938 Z M64.6604624,86.3662688 C62.8572863,86.3662688 61.4420239,87.0931196 60.4146329,88.546843 C59.3872418,90.0005663 58.873554,92.0203728 58.873554,94.6063231 C58.873554,97.1922733 59.3907363,99.2190688 60.4251164,100.68677 C61.4594965,102.154472 62.8712644,102.888312 64.6604624,102.888312 C66.4636385,102.888312 67.8823953,102.157966 68.9167754,100.697254 C69.9511555,99.2365414 70.4683378,97.2062514 70.4683378,94.6063231 C70.4683378,92.0203728 69.95465,90.0005663 68.9272589,88.546843 C67.8998679,87.0931196 66.4776166,86.3662688 64.6604624,86.3662688 L64.6604624,86.3662688 Z M64.6604624,81.501911 C68.0990773,81.501911 70.929602,82.7319662 73.1521214,85.1921135 C75.3746408,87.6522607 76.4858838,90.7902992 76.4858838,94.6063231 C76.4858838,98.4503032 75.3816297,101.595331 73.1730884,104.0415 C70.9645471,106.487669 68.1270335,107.710735 64.6604624,107.710735 C61.2358256,107.710735 58.4053009,106.477185 56.1688034,104.010049 C53.9323059,101.542913 52.8140739,98.4083688 52.8140739,94.6063231 C52.8140739,90.7763211 53.9218224,87.6347881 56.1373528,85.1816299 C58.3528831,82.7284717 61.1938912,81.501911 64.6604624,81.501911 L64.6604624,81.501911 Z M87.4611651,98.1707232 L87.4611651,102.46897 L89.6207722,102.46897 C90.5293493,102.46897 91.1758272,102.643694 91.5602252,102.993147 C91.9446232,103.3426 92.1368193,103.922682 92.1368193,104.733413 C92.1368193,105.558121 91.9411287,106.152182 91.5497417,106.515613 C91.1583546,106.879044 90.5153712,107.060756 89.6207722,107.060756 L82.3661697,107.060756 C81.4436145,107.060756 80.7831587,106.879044 80.3847826,106.515613 C79.9864065,106.152182 79.7872214,105.558121 79.7872214,104.733413 C79.7872214,103.992573 79.9759231,103.429962 80.353332,103.045564 C80.730741,102.661166 81.282868,102.46897 82.0097297,102.46897 L82.3661697,102.46897 L82.3661697,86.8275441 L82.0097297,86.8275441 C81.2968461,86.8275441 80.7482136,86.628359 80.3638155,86.2299829 C79.9794175,85.8316068 79.7872214,85.2620074 79.7872214,84.5211676 C79.7872214,83.7104372 79.989901,83.119871 80.3952661,82.7494511 C80.8006313,82.3790312 81.4575926,82.193824 82.3661697,82.193824 L91.0255652,82.193824 C94.450202,82.193824 97.0396079,82.8507853 98.7938606,84.1647276 C100.548113,85.4786699 101.425227,87.414609 101.425227,89.972603 C101.425227,92.6703781 100.551608,94.7111515 98.8043442,96.0949843 C97.0570805,97.4788171 94.4641801,98.1707232 91.0255652,98.1707232 L87.4611651,98.1707232 Z M87.4611651,86.8275441 L87.4611651,93.4531348 L90.4384875,93.4531348 C92.0879044,93.4531348 93.328443,93.1735768 94.1601405,92.6144525 C94.9918381,92.0553281 95.4076806,91.2166541 95.4076806,90.0984053 C95.4076806,89.0500471 94.9778602,88.2428234 94.1182064,87.67671 C93.2585527,87.1105966 92.031992,86.8275441 90.4384875,86.8275441 L87.4611651,86.8275441 Z M114.727851,107.396229 L113.092421,109.03166 C113.69348,108.835966 114.284046,108.689198 114.864137,108.591352 C115.444229,108.493505 116.013828,108.444582 116.572953,108.444582 C117.677223,108.444582 118.840883,108.608823 120.063968,108.937308 C121.287053,109.265794 122.031376,109.430034 122.29696,109.430034 C122.744259,109.430034 123.327837,109.279772 124.047709,108.979242 C124.767582,108.678713 125.253314,108.52845 125.50492,108.52845 C126.02211,108.52845 126.45193,108.727636 126.794394,109.126012 C127.136858,109.524388 127.308087,110.024098 127.308087,110.625156 C127.308087,111.421909 126.836333,112.099837 125.892811,112.658961 C124.949288,113.218086 123.792617,113.497643 122.422762,113.497643 C121.486229,113.497643 120.28413,113.277492 118.816428,112.837181 C117.348727,112.396871 116.286406,112.176719 115.629435,112.176719 C114.636989,112.176719 113.518757,112.449288 112.274706,112.994434 C111.030654,113.53958 110.261869,113.812149 109.968329,113.812149 C109.36727,113.812149 108.857077,113.612964 108.437734,113.214588 C108.01839,112.816212 107.808722,112.337469 107.808722,111.778345 C107.808722,111.386958 107.941512,110.971115 108.207096,110.530805 C108.47268,110.090494 108.94094,109.520895 109.611889,108.821989 L111.729562,106.683349 C109.395218,105.830685 107.536157,104.29661 106.152324,102.08108 C104.768491,99.8655494 104.076585,97.3180772 104.076585,94.4385866 C104.076585,90.6365409 105.180839,87.5299526 107.389381,85.1187288 C109.597922,82.7075049 112.442425,81.501911 115.922974,81.501911 C119.389545,81.501911 122.227059,82.7109994 124.4356,85.1292123 C126.644141,87.5474252 127.748395,90.650519 127.748395,94.4385866 C127.748395,98.2126762 126.65113,101.322759 124.456567,103.768928 C122.262004,106.215097 119.480402,107.438163 116.111677,107.438163 C115.888028,107.438163 115.660887,107.434669 115.430248,107.42768 C115.199609,107.420691 114.965479,107.410207 114.727851,107.396229 L114.727851,107.396229 Z M115.922974,86.3662688 C114.119798,86.3662688 112.704535,87.0931196 111.677144,88.546843 C110.649753,90.0005663 110.136065,92.0203728 110.136065,94.6063231 C110.136065,97.1922733 110.653248,99.2190688 111.687628,100.68677 C112.722008,102.154472 114.133776,102.888312 115.922974,102.888312 C117.72615,102.888312 119.144907,102.157966 120.179287,100.697254 C121.213667,99.2365414 121.730849,97.2062514 121.730849,94.6063231 C121.730849,92.0203728 121.217161,90.0005663 120.18977,88.546843 C119.162379,87.0931196 117.740128,86.3662688 115.922974,86.3662688 L115.922974,86.3662688 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/mono-line": {
"title": "$:/core/images/mono-line",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-mono-line tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M60.4374591,84.522627 L61.3450888,84.522627 C63.2671377,84.522627 64.7264493,85.0120303 65.7230673,85.9908515 C66.7196852,86.9696727 67.2179868,88.4022896 67.2179868,90.288745 C67.2179868,92.3887615 66.6929905,93.9014625 65.6429823,94.8268935 C64.5929741,95.7523244 62.857817,96.215033 60.4374591,96.215033 L44.3670747,96.215033 C41.9111232,96.215033 40.1670679,95.7612227 39.1348565,94.8535884 C38.102645,93.9459542 37.586547,92.424355 37.586547,90.288745 C37.586547,88.2243221 38.102645,86.747214 39.1348565,85.8573766 C40.1670679,84.9675391 41.9111232,84.522627 44.3670747,84.522627 L46.235724,84.522627 L44.0467348,78.2759992 L20.9822627,78.2759992 L18.6864935,84.522627 L20.5551429,84.522627 C22.9755008,84.522627 24.7106579,84.9764373 25.7606661,85.8840716 C26.8106743,86.7917058 27.3356705,88.2599156 27.3356705,90.288745 C27.3356705,92.3887615 26.8106743,93.9014625 25.7606661,94.8268935 C24.7106579,95.7523244 22.9755008,96.215033 20.5551429,96.215033 L6.78052766,96.215033 C4.32457622,96.215033 2.58052094,95.7523244 1.54830946,94.8268935 C0.516097994,93.9014625 0,92.3887615 0,90.288745 C0,88.4022896 0.498301511,86.9696727 1.49491948,85.9908515 C2.49153745,85.0120303 3.95084902,84.522627 5.87289797,84.522627 L6.78052766,84.522627 L21.0890427,44.6937008 L16.8178442,44.6937008 C14.3974863,44.6937008 12.6623292,44.2309922 11.612321,43.3055613 C10.5623128,42.3801303 10.0373165,40.8852258 10.0373165,38.8208028 C10.0373165,36.7207864 10.5623128,35.2080854 11.612321,34.2826544 C12.6623292,33.3572234 14.3974863,32.8945149 16.8178442,32.8945149 L36.8390873,32.8945149 C40.0069087,32.8945149 42.231469,34.6029772 43.512835,38.0199531 L43.512835,38.180123 L60.4374591,84.522627 Z M32.4611088,44.6937008 L24.7195615,67.224273 L40.2026561,67.224273 L32.4611088,44.6937008 Z M89.5058233,68.5590225 L89.5058233,84.8429669 L97.5143205,84.8429669 C103.173687,84.8429669 107.160099,84.22009 109.473676,82.9743176 C111.787254,81.7285451 112.944025,79.6463566 112.944025,76.7276897 C112.944025,73.7734293 111.840643,71.6734444 109.633846,70.4276719 C107.427049,69.1818994 103.565213,68.5590225 98.0482204,68.5590225 L89.5058233,68.5590225 Z M116.734714,62.6327346 C120.614405,64.0564746 123.461842,66.0051894 125.277111,68.4789376 C127.092379,70.9526857 128,74.1115614 128,77.9556593 C128,81.1946677 127.216955,84.1488838 125.650841,86.8183962 C124.084727,89.4879087 121.84237,91.676876 118.923703,93.385364 C117.215215,94.3819819 115.302093,95.1027395 113.18428,95.5476582 C111.066467,95.9925769 108.06776,96.215033 104.188068,96.215033 L99.7033098,96.215033 L76.3184979,96.215033 C73.9693269,96.215033 72.2875593,95.7523244 71.2731446,94.8268935 C70.2587299,93.9014625 69.7515301,92.3887615 69.7515301,90.288745 C69.7515301,88.4022896 70.2320352,86.9696727 71.1930596,85.9908515 C72.1540841,85.0120303 73.5600062,84.522627 75.4108682,84.522627 L76.3184979,84.522627 L76.3184979,44.6937008 L75.4108682,44.6937008 C73.5600062,44.6937008 72.1540841,44.1953993 71.1930596,43.1987813 C70.2320352,42.2021633 69.7515301,40.7428518 69.7515301,38.8208028 C69.7515301,36.7563799 70.2676281,35.2525771 71.2998396,34.3093494 C72.3320511,33.3661217 74.0049204,32.8945149 76.3184979,32.8945149 L100.877889,32.8945149 C108.388118,32.8945149 114.09189,34.3538264 117.989378,37.2724934 C121.886867,40.1911603 123.835581,44.4623161 123.835581,50.0860889 C123.835581,52.8623819 123.239399,55.3093982 122.047017,57.4272114 C120.854635,59.5450246 119.083885,61.2801816 116.734714,62.6327346 L116.734714,62.6327346 Z M89.5058233,44.3733609 L89.5058233,57.8276363 L96.7134708,57.8276363 C101.091471,57.8276363 104.179161,57.3115383 105.976633,56.2793268 C107.774104,55.2471153 108.672827,53.50306 108.672827,51.0471086 C108.672827,48.7335312 107.863087,47.0428653 106.243583,45.9750604 C104.624078,44.9072554 101.999097,44.3733609 98.3685602,44.3733609 L89.5058233,44.3733609 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/new-button": {
"title": "$:/core/images/new-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-new-button tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\">\n <g fill-rule=\"evenodd\">\n <path d=\"M56,72 L8.00697327,72 C3.59075293,72 0,68.418278 0,64 C0,59.5907123 3.58484404,56 8.00697327,56 L56,56 L56,8.00697327 C56,3.59075293 59.581722,0 64,0 C68.4092877,0 72,3.58484404 72,8.00697327 L72,56 L119.993027,56 C124.409247,56 128,59.581722 128,64 C128,68.4092877 124.415156,72 119.993027,72 L72,72 L72,119.993027 C72,124.409247 68.418278,128 64,128 C59.5907123,128 56,124.415156 56,119.993027 L56,72 L56,72 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/new-here-button": {
"title": "$:/core/images/new-here-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-new-here-button tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n \t<g transform=\"translate(52.233611, 64.389922) rotate(75.000000) translate(-52.233611, -64.389922) translate(-7.734417, 3.702450)\">\n\t <path d=\"M18.9270186,45.959338 L18.9080585,49.6521741 C18.8884833,53.4648378 21.0574548,58.7482162 23.7526408,61.4434022 L78.5671839,116.257945 C81.2617332,118.952495 85.6348701,118.950391 88.3334363,116.251825 L115.863237,88.7220241 C118.555265,86.0299959 118.564544,81.6509578 115.869358,78.9557717 L61.0548144,24.1412286 C58.3602652,21.4466794 53.0787224,19.2788426 49.2595808,19.3006519 L25.9781737,19.4336012 C22.1633003,19.4553862 19.0471195,22.5673232 19.0275223,26.3842526 L18.9871663,34.2443819 C19.0818862,34.255617 19.1779758,34.2665345 19.2754441,34.2771502 C22.6891275,34.6489512 27.0485594,34.2348566 31.513244,33.2285542 C31.7789418,32.8671684 32.075337,32.5211298 32.4024112,32.1940556 C34.8567584,29.7397084 38.3789778,29.0128681 41.4406288,30.0213822 C41.5958829,29.9543375 41.7503946,29.8866669 41.9041198,29.8183808 L42.1110981,30.2733467 C43.1114373,30.6972371 44.0473796,31.3160521 44.8614145,32.1300869 C48.2842088,35.5528813 48.2555691,41.130967 44.7974459,44.5890903 C41.4339531,47.952583 36.0649346,48.0717177 32.6241879,44.9262969 C27.8170558,45.8919233 23.0726921,46.2881596 18.9270186,45.959338 Z\"></path>\n\t <path d=\"M45.4903462,38.8768094 C36.7300141,42.6833154 26.099618,44.7997354 18.1909048,43.9383587 C7.2512621,42.7468685 1.50150083,35.8404432 4.66865776,24.7010202 C7.51507386,14.6896965 15.4908218,6.92103848 24.3842626,4.38423012 C34.1310219,1.60401701 42.4070208,6.15882777 42.4070209,16.3101169 L34.5379395,16.310117 C34.5379394,11.9285862 31.728784,10.3825286 26.5666962,11.8549876 C20.2597508,13.6540114 14.3453742,19.4148216 12.2444303,26.8041943 C10.4963869,32.9523565 12.6250796,35.5092726 19.0530263,36.2093718 C25.5557042,36.9176104 35.0513021,34.9907189 42.7038419,31.5913902 L42.7421786,31.6756595 C44.3874154,31.5384763 47.8846101,37.3706354 45.9274416,38.6772897 L45.9302799,38.6835285 C45.9166992,38.6895612 45.9031139,38.6955897 45.8895238,38.7016142 C45.8389288,38.7327898 45.7849056,38.7611034 45.7273406,38.7863919 C45.6506459,38.8200841 45.571574,38.8501593 45.4903462,38.8768094 Z\"></path>\n </g>\n <rect x=\"96\" y=\"80\" width=\"16\" height=\"48\" rx=\"8\"></rect>\n <rect x=\"80\" y=\"96\" width=\"48\" height=\"16\" rx=\"8\"></rect>\n </g>\n </g>\n</svg>"
},
"$:/core/images/new-image-button": {
"title": "$:/core/images/new-image-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-new-image-button tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\">\n <g fill-rule=\"evenodd\">\n <path d=\"M81.3619177,73.6270062 L97.1875317,46.2162388 C97.91364,44.9585822 97.4824378,43.3533085 96.2260476,42.6279312 L46.2162388,13.7547547 C44.9585822,13.0286463 43.3533085,13.4598485 42.6279312,14.7162388 L30.0575956,36.4886988 L40.0978909,31.2276186 C43.1404959,29.6333041 46.8692155,31.3421319 47.6479264,34.6877101 L51.2545483,52.3903732 L61.1353556,53.2399953 C63.2899974,53.4346096 65.1046382,54.9309951 65.706105,57.0091178 C65.7395572,57.1246982 65.8069154,57.3539875 65.9047035,57.6813669 C66.0696435,58.2335608 66.2581528,58.852952 66.4667073,59.5238092 C67.0618822,61.4383079 67.6960725,63.3742727 68.3393254,65.2021174 C68.5462918,65.7902259 68.7511789,66.3583016 68.953259,66.9034738 C69.5777086,68.5881157 70.1617856,70.0172008 70.6783305,71.110045 C70.9334784,71.6498566 71.1627732,72.0871602 71.4035746,72.5373068 C71.6178999,72.7492946 71.9508843,72.9623307 72.4151452,73.1586945 C73.5561502,73.6412938 75.1990755,73.899146 77.0720271,73.9171651 C77.9355886,73.9254732 78.7819239,73.8832103 79.5638842,73.8072782 C80.0123946,73.7637257 80.3172916,73.7224469 80.4352582,73.7027375 C80.7503629,73.6500912 81.0598053,73.6256267 81.3619177,73.6270062 L81.3619177,73.6270062 L81.3619177,73.6270062 L81.3619177,73.6270062 Z M37.4707881,2.64867269 C38.9217993,0.135447653 42.1388058,-0.723707984 44.6486727,0.725364314 L108.293614,37.4707881 C110.806839,38.9217993 111.665994,42.1388058 110.216922,44.6486727 L73.4714982,108.293614 C72.0204871,110.806839 68.8034805,111.665994 66.2936136,110.216922 L2.64867269,73.4714982 C0.135447653,72.0204871 -0.723707984,68.8034805 0.725364314,66.2936136 L37.4707881,2.64867269 L37.4707881,2.64867269 L37.4707881,2.64867269 L37.4707881,2.64867269 Z M80.3080975,53.1397764 C82.8191338,54.5895239 86.0299834,53.7291793 87.4797308,51.218143 C88.9294783,48.7071068 88.0691338,45.4962571 85.5580975,44.0465097 C83.0470612,42.5967622 79.8362116,43.4571068 78.3864641,45.968143 C76.9367166,48.4791793 77.7970612,51.6900289 80.3080975,53.1397764 L80.3080975,53.1397764 L80.3080975,53.1397764 L80.3080975,53.1397764 Z M96,112 L88.0070969,112 C83.5881712,112 80,108.418278 80,104 C80,99.5907123 83.5848994,96 88.0070969,96 L96,96 L96,88.0070969 C96,83.5881712 99.581722,80 104,80 C108.409288,80 112,83.5848994 112,88.0070969 L112,96 L119.992903,96 C124.411829,96 128,99.581722 128,104 C128,108.409288 124.415101,112 119.992903,112 L112,112 L112,119.992903 C112,124.411829 108.418278,128 104,128 C99.5907123,128 96,124.415101 96,119.992903 L96,112 L96,112 Z M33.3471097,51.7910932 C40.7754579,59.7394511 42.3564368,62.4818351 40.7958321,65.1848818 C39.2352273,67.8879286 26.9581062,62.8571718 24.7019652,66.7649227 C22.4458242,70.6726735 23.7947046,70.0228006 22.2648667,72.6725575 L41.9944593,84.0634431 C41.9944593,84.0634431 36.3904568,75.8079231 37.7602356,73.4353966 C40.2754811,69.0788636 46.5298923,72.1787882 48.1248275,69.4162793 C50.538989,65.234829 43.0222016,59.7770885 33.3471097,51.7910932 L33.3471097,51.7910932 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/new-journal-button": {
"title": "$:/core/images/new-journal-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-new-journal-button tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M102.545455,112.818182 L102.545455,124.636364 L102.545455,124.636364 L102.545455,124.636364 C102.545455,125.941761 103.630828,127 104.969697,127 L111.030303,127 C112.369172,127 113.454545,125.941761 113.454545,124.636364 L113.454545,112.818182 L125.575758,112.818182 C126.914626,112.818182 128,111.759982 128,110.454545 L128,104.545455 C128,103.240018 126.914626,102.181818 125.575758,102.181818 L113.454545,102.181818 L113.454545,90.3636364 C113.454545,89.0582 112.369172,88 111.030303,88 L104.969697,88 L104.969697,88 C103.630828,88 102.545455,89.0582 102.545455,90.3636364 L102.545455,102.181818 L90.4242424,102.181818 L90.4242424,102.181818 C89.0853705,102.181818 88,103.240018 88,104.545455 L88,110.454545 L88,110.454545 L88,110.454545 C88,111.759982 89.0853705,112.818182 90.4242424,112.818182 L102.545455,112.818182 Z\"></path>\n <g transform=\"translate(59.816987, 64.316987) rotate(30.000000) translate(-59.816987, -64.316987) translate(20.316987, 12.816987)\">\n <g transform=\"translate(0.000000, 0.000000)\">\n <path d=\"M9.99631148,0 C4.4755011,0 -2.27373675e-13,4.48070044 -2.27373675e-13,9.99759461 L-2.27373675e-13,91.6128884 C-2.27373675e-13,97.1344074 4.46966773,101.610483 9.99631148,101.610483 L68.9318917,101.610483 C74.4527021,101.610483 78.9282032,97.1297826 78.9282032,91.6128884 L78.9282032,9.99759461 C78.9282032,4.47607557 74.4585355,0 68.9318917,0 L9.99631148,0 Z M20.8885263,26 C24.2022348,26 26.8885263,23.3137085 26.8885263,20 C26.8885263,16.6862915 24.2022348,14 20.8885263,14 C17.5748178,14 14.8885263,16.6862915 14.8885263,20 C14.8885263,23.3137085 17.5748178,26 20.8885263,26 Z M57.3033321,25.6783342 C60.6170406,25.6783342 63.3033321,22.9920427 63.3033321,19.6783342 C63.3033321,16.3646258 60.6170406,13.6783342 57.3033321,13.6783342 C53.9896236,13.6783342 51.3033321,16.3646258 51.3033321,19.6783342 C51.3033321,22.9920427 53.9896236,25.6783342 57.3033321,25.6783342 Z\"></path>\n <text font-family=\"Helvetica\" font-size=\"47.1724138\" font-weight=\"bold\" fill=\"#FFFFFF\">\n <tspan x=\"42\" y=\"77.4847912\" text-anchor=\"middle\"><<now \"DD\">></tspan>\n </text>\n </g>\n </g>\n </g>\n</svg>"
},
"$:/core/images/opacity": {
"title": "$:/core/images/opacity",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-opacity tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M102.361773,65 C101.833691,67.051742 101.183534,69.0544767 100.419508,71 L82.5835324,71 C83.7602504,69.1098924 84.7666304,67.1027366 85.581205,65 L102.361773,65 Z M102.834311,63 C103.256674,61.0388326 103.568427,59.0365486 103.762717,57 L87.6555706,57 C87.3692052,59.0609452 86.9083652,61.0660782 86.2884493,63 L102.834311,63 Z M99.5852583,73 C98.6682925,75.0747721 97.6196148,77.0783056 96.4498253,79 L75.8124196,79 C77.8387053,77.2115633 79.6621163,75.1985844 81.2437158,73 L99.5852583,73 Z M95.1689122,81 C93.7449202,83.1155572 92.1695234,85.1207336 90.458251,87 L60.4614747,87 C65.1836162,85.86248 69.5430327,83.794147 73.3347255,81 L95.1689122,81 Z M87.6555706,47 L103.762717,47 C101.246684,20.6269305 79.0321807,0 52,0 C23.281193,0 0,23.281193 0,52 C0,77.2277755 17.9651296,98.2595701 41.8000051,103 L62.1999949,103 C67.8794003,101.870444 73.2255333,99.8158975 78.074754,97 L39,97 L39,95 L81.2493857,95 C83.8589242,93.2215015 86.2981855,91.2116653 88.5376609,89 L39,89 L39,87 L43.5385253,87 C27.7389671,83.1940333 16,68.967908 16,52 C16,32.117749 32.117749,16 52,16 C70.1856127,16 85.2217929,29.4843233 87.6555706,47 Z M87.8767787,49 L103.914907,49 C103.971379,49.9928025 104,50.9930589 104,52 C104,53.0069411 103.971379,54.0071975 103.914907,55 L87.8767787,55 C87.958386,54.0107999 88,53.0102597 88,52 C88,50.9897403 87.958386,49.9892001 87.8767787,49 Z\"></path>\n <path d=\"M76,128 C104.718807,128 128,104.718807 128,76 C128,47.281193 104.718807,24 76,24 C47.281193,24 24,47.281193 24,76 C24,104.718807 47.281193,128 76,128 L76,128 Z M76,112 C95.882251,112 112,95.882251 112,76 C112,56.117749 95.882251,40 76,40 C56.117749,40 40,56.117749 40,76 C40,95.882251 56.117749,112 76,112 L76,112 Z\"></path>\n <path d=\"M37,58 L90,58 L90,62 L37,62 L37,58 L37,58 Z M40,50 L93,50 L93,54 L40,54 L40,50 L40,50 Z M40,42 L93,42 L93,46 L40,46 L40,42 L40,42 Z M32,66 L85,66 L85,70 L32,70 L32,66 L32,66 Z M30,74 L83,74 L83,78 L30,78 L30,74 L30,74 Z M27,82 L80,82 L80,86 L27,86 L27,82 L27,82 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/open-window": {
"title": "$:/core/images/open-window",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-open-window tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M16,112 L104.993898,112 C108.863261,112 112,115.590712 112,120 C112,124.418278 108.858091,128 104.993898,128 L7.00610161,128 C3.13673853,128 0,124.409288 0,120 C0,119.998364 4.30952878e-07,119.996727 1.29273572e-06,119.995091 C4.89579306e-07,119.993456 0,119.99182 0,119.990183 L0,24.0098166 C0,19.586117 3.59071231,16 8,16 C12.418278,16 16,19.5838751 16,24.0098166 L16,112 Z\"></path>\n <path d=\"M96,43.1959595 L96,56 C96,60.418278 99.581722,64 104,64 C108.418278,64 112,60.418278 112,56 L112,24 C112,19.5907123 108.415101,16 103.992903,16 L72.0070969,16 C67.5881712,16 64,19.581722 64,24 C64,28.4092877 67.5848994,32 72.0070969,32 L84.5685425,32 L48.2698369,68.2987056 C45.1421332,71.4264093 45.1434327,76.4904296 48.267627,79.614624 C51.3854642,82.7324612 56.4581306,82.7378289 59.5835454,79.6124141 L96,43.1959595 Z M32,7.9992458 C32,3.58138434 35.5881049,0 39.9992458,0 L120.000754,0 C124.418616,0 128,3.5881049 128,7.9992458 L128,88.0007542 C128,92.4186157 124.411895,96 120.000754,96 L39.9992458,96 C35.5813843,96 32,92.4118951 32,88.0007542 L32,7.9992458 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/options-button": {
"title": "$:/core/images/options-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-options-button tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M110.48779,76.0002544 C109.354214,80.4045063 107.611262,84.5641217 105.354171,88.3838625 L105.354171,88.3838625 L112.07833,95.1080219 C115.20107,98.2307613 115.210098,103.299824 112.089164,106.420759 L106.420504,112.089418 C103.301049,115.208874 98.2346851,115.205502 95.1077675,112.078585 L88.3836082,105.354425 C84.5638673,107.611516 80.4042519,109.354468 76,110.488045 L76,110.488045 L76,119.993281 C76,124.409501 72.4220153,128.000254 68.0083475,128.000254 L59.9916525,128.000254 C55.5800761,128.000254 52,124.41541 52,119.993281 L52,110.488045 C47.5957481,109.354468 43.4361327,107.611516 39.6163918,105.354425 L32.8922325,112.078585 C29.7694931,115.201324 24.7004301,115.210353 21.5794957,112.089418 L15.9108363,106.420759 C12.7913807,103.301303 12.7947522,98.2349395 15.9216697,95.1080219 L22.6458291,88.3838625 C20.3887383,84.5641217 18.6457859,80.4045063 17.5122098,76.0002544 L8.00697327,76.0002544 C3.59075293,76.0002544 2.19088375e-16,72.4222697 4.89347582e-16,68.0086019 L9.80228577e-16,59.9919069 C1.25035972e-15,55.5803305 3.58484404,52.0002544 8.00697327,52.0002544 L17.5122098,52.0002544 C18.6457859,47.5960025 20.3887383,43.4363871 22.6458291,39.6166462 L15.9216697,32.8924868 C12.7989304,29.7697475 12.7899019,24.7006845 15.9108363,21.5797501 L21.5794957,15.9110907 C24.6989513,12.7916351 29.7653149,12.7950065 32.8922325,15.9219241 L39.6163918,22.6460835 C43.4361327,20.3889927 47.5957481,18.6460403 52,17.5124642 L52,8.00722764 C52,3.5910073 55.5779847,0.000254375069 59.9916525,0.000254375069 L68.0083475,0.000254375069 C72.4199239,0.000254375069 76,3.58509841 76,8.00722764 L76,17.5124642 C80.4042519,18.6460403 84.5638673,20.3889927 88.3836082,22.6460835 L95.1077675,15.9219241 C98.2305069,12.7991848 103.29957,12.7901562 106.420504,15.9110907 L112.089164,21.5797501 C115.208619,24.6992057 115.205248,29.7655693 112.07833,32.8924868 L105.354171,39.6166462 L105.354171,39.6166462 C107.611262,43.4363871 109.354214,47.5960025 110.48779,52.0002544 L119.993027,52.0002544 C124.409247,52.0002544 128,55.5782391 128,59.9919069 L128,68.0086019 C128,72.4201783 124.415156,76.0002544 119.993027,76.0002544 L110.48779,76.0002544 L110.48779,76.0002544 Z M64,96.0002544 C81.673112,96.0002544 96,81.6733664 96,64.0002544 C96,46.3271424 81.673112,32.0002544 64,32.0002544 C46.326888,32.0002544 32,46.3271424 32,64.0002544 C32,81.6733664 46.326888,96.0002544 64,96.0002544 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/paint": {
"title": "$:/core/images/paint",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-paint tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M83.5265806,76.1907935 C90.430962,69.2864121 91.8921169,59.0000433 87.9100453,50.6642209 L125.812763,12.7615036 C128.732035,9.84223095 128.72611,5.10322984 125.812796,2.18991592 C122.893542,-0.729338085 118.161775,-0.730617045 115.241209,2.18994966 L77.3384914,40.092667 C69.002669,36.1105954 58.7163002,37.5717503 51.8119188,44.4761317 L83.5265806,76.1907935 L83.5265806,76.1907935 L83.5265806,76.1907935 L83.5265806,76.1907935 Z M80.8836921,78.8336819 L49.1690303,47.1190201 C49.1690303,47.1190201 8.50573364,81.242543 0,80.2820711 C0,80.2820711 3.78222974,85.8744423 6.82737483,88.320684 C20.8514801,82.630792 44.1526049,63.720771 44.1526049,63.720771 L44.8144806,64.3803375 C44.8144806,64.3803375 19.450356,90.2231043 9.18040433,92.0477601 C10.4017154,93.4877138 13.5343883,96.1014812 15.4269991,97.8235871 C20.8439164,96.3356979 50.1595367,69.253789 50.1595367,69.253789 L50.8214124,69.9133555 L18.4136144,100.936036 L23.6993903,106.221812 L56.1060358,75.2002881 L56.7679115,75.8598546 C56.7679115,75.8598546 28.9040131,106.396168 28.0841366,108.291555 C28.0841366,108.291555 34.1159238,115.144621 35.6529617,116.115796 C36.3545333,113.280171 63.5365402,82.6307925 63.5365402,82.6307925 L64.1984159,83.290359 C64.1984159,83.290359 43.6013016,107.04575 39.2343772,120.022559 C42.443736,123.571575 46.7339155,125.159692 50.1595362,126.321151 C47.9699978,114.504469 80.8836921,78.8336819 80.8836921,78.8336819 L80.8836921,78.8336819 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/palette": {
"title": "$:/core/images/palette",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-palette tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M80.2470434,39.1821571 C75.0645698,38.2680897 69.6261555,37.7814854 64.0193999,37.7814854 C28.6624616,37.7814854 0,57.1324214 0,81.0030106 C0,90.644534 4.67604329,99.5487133 12.5805659,106.738252 C23.5031767,91.1899067 26.3405471,72.3946229 36.8885698,63.5622337 C52.0716764,50.8486559 63.4268694,55.7343343 63.4268694,55.7343343 L80.2470434,39.1821571 Z M106.781666,48.8370714 C119.830962,56.749628 128.0388,68.229191 128.0388,81.0030106 C128.0388,90.3534932 128.557501,98.4142085 116.165191,106.082518 C105.367708,112.763955 112.341384,99.546808 104.321443,95.1851533 C96.3015017,90.8234987 84.3749007,96.492742 86.1084305,103.091059 C89.3087234,115.272303 105.529892,114.54645 92.4224435,119.748569 C79.3149955,124.950687 74.2201582,124.224536 64.0193999,124.224536 C56.1979176,124.224536 48.7040365,123.277578 41.7755684,121.544216 C51.620343,117.347916 69.6563669,109.006202 75.129737,102.088562 C82.7876655,92.4099199 87.3713218,80.0000002 83.3235694,72.4837191 C83.1303943,72.1250117 94.5392656,60.81569 106.781666,48.8370714 Z M1.13430476,123.866563 C0.914084026,123.867944 0.693884185,123.868637 0.473712455,123.868637 C33.9526848,108.928928 22.6351223,59.642592 59.2924543,59.6425917 C59.6085574,61.0606542 59.9358353,62.5865065 60.3541977,64.1372318 C34.4465025,59.9707319 36.7873124,112.168427 1.13429588,123.866563 L1.13430476,123.866563 Z M1.84669213,123.859694 C40.7185279,123.354338 79.9985412,101.513051 79.9985401,79.0466836 C70.7284906,79.0466835 65.9257264,75.5670082 63.1833375,71.1051511 C46.585768,64.1019718 32.81846,116.819636 1.84665952,123.859695 L1.84669213,123.859694 Z M67.1980193,59.8524981 C62.748213,63.9666823 72.0838429,76.2846822 78.5155805,71.1700593 C89.8331416,59.8524993 112.468264,37.2173758 123.785825,25.8998146 C135.103386,14.5822535 123.785825,3.26469247 112.468264,14.5822535 C101.150703,25.8998144 78.9500931,48.9868127 67.1980193,59.8524981 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/permalink-button": {
"title": "$:/core/images/permalink-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-permalink-button tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M80.4834582,48 L73.0956761,80 L73.0956761,80 L47.5165418,80 L54.9043239,48 L80.4834582,48 Z M84.1773493,32 L89.8007299,7.64246248 C90.7941633,3.33942958 95.0918297,0.64641956 99.3968675,1.64031585 C103.693145,2.63218977 106.385414,6.93288901 105.390651,11.2416793 L100.598215,32 L104.000754,32 C108.411895,32 112,35.581722 112,40 C112,44.4092877 108.418616,48 104.000754,48 L96.9043239,48 L89.5165418,80 L104.000754,80 C108.411895,80 112,83.581722 112,88 C112,92.4092877 108.418616,96 104.000754,96 L85.8226507,96 L80.1992701,120.357538 C79.2058367,124.66057 74.9081703,127.35358 70.6031325,126.359684 C66.3068546,125.36781 63.6145865,121.067111 64.6093491,116.758321 L69.401785,96 L43.8226507,96 L38.1992701,120.357538 C37.2058367,124.66057 32.9081703,127.35358 28.6031325,126.359684 C24.3068546,125.36781 21.6145865,121.067111 22.6093491,116.758321 L27.401785,96 L23.9992458,96 C19.5881049,96 16,92.418278 16,88 C16,83.5907123 19.5813843,80 23.9992458,80 L31.0956761,80 L38.4834582,48 L23.9992458,48 C19.5881049,48 16,44.418278 16,40 C16,35.5907123 19.5813843,32 23.9992458,32 L42.1773493,32 L47.8007299,7.64246248 C48.7941633,3.33942958 53.0918297,0.64641956 57.3968675,1.64031585 C61.6931454,2.63218977 64.3854135,6.93288901 63.3906509,11.2416793 L58.598215,32 L84.1773493,32 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/permaview-button": {
"title": "$:/core/images/permaview-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-permaview-button tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M81.4834582,48 L79.6365127,56 L79.6365127,56 L74.0573784,56 L75.9043239,48 L81.4834582,48 Z M85.1773493,32 L90.8007299,7.64246248 C91.7941633,3.33942958 96.0918297,0.64641956 100.396867,1.64031585 C104.693145,2.63218977 107.385414,6.93288901 106.390651,11.2416793 L101.598215,32 L104.000754,32 C108.411895,32 112,35.581722 112,40 C112,44.4092877 108.418616,48 104.000754,48 L97.9043239,48 L96.0573784,56 L104.000754,56 C108.411895,56 112,59.581722 112,64 C112,68.4092877 108.418616,72 104.000754,72 L92.3634873,72 L90.5165418,80 L104.000754,80 C108.411895,80 112,83.581722 112,88 C112,92.4092877 108.418616,96 104.000754,96 L86.8226507,96 L81.1992701,120.357538 C80.2058367,124.66057 75.9081703,127.35358 71.6031325,126.359684 C67.3068546,125.36781 64.6145865,121.067111 65.6093491,116.758321 L70.401785,96 L64.8226507,96 L59.1992701,120.357538 C58.2058367,124.66057 53.9081703,127.35358 49.6031325,126.359684 C45.3068546,125.36781 42.6145865,121.067111 43.6093491,116.758321 L48.401785,96 L42.8226507,96 L37.1992701,120.357538 C36.2058367,124.66057 31.9081703,127.35358 27.6031325,126.359684 C23.3068546,125.36781 20.6145865,121.067111 21.6093491,116.758321 L26.401785,96 L23.9992458,96 C19.5881049,96 16,92.418278 16,88 C16,83.5907123 19.5813843,80 23.9992458,80 L30.0956761,80 L31.9426216,72 L23.9992458,72 C19.5881049,72 16,68.418278 16,64 C16,59.5907123 19.5813843,56 23.9992458,56 L35.6365127,56 L37.4834582,48 L23.9992458,48 C19.5881049,48 16,44.418278 16,40 C16,35.5907123 19.5813843,32 23.9992458,32 L41.1773493,32 L46.8007299,7.64246248 C47.7941633,3.33942958 52.0918297,0.64641956 56.3968675,1.64031585 C60.6931454,2.63218977 63.3854135,6.93288901 62.3906509,11.2416793 L57.598215,32 L63.1773493,32 L68.8007299,7.64246248 C69.7941633,3.33942958 74.0918297,0.64641956 78.3968675,1.64031585 C82.6931454,2.63218977 85.3854135,6.93288901 84.3906509,11.2416793 L79.598215,32 L85.1773493,32 Z M53.9043239,48 L52.0573784,56 L57.6365127,56 L59.4834582,48 L53.9043239,48 Z M75.9426216,72 L74.0956761,80 L74.0956761,80 L68.5165418,80 L70.3634873,72 L75.9426216,72 L75.9426216,72 Z M48.3634873,72 L46.5165418,80 L52.0956761,80 L53.9426216,72 L48.3634873,72 L48.3634873,72 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/picture": {
"title": "$:/core/images/picture",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-picture tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M112,68.2332211 L112,20.0027785 C112,17.7898769 110.207895,16 107.997221,16 L20.0027785,16 C17.7898769,16 16,17.792105 16,20.0027785 L16,58.312373 L25.2413115,43.7197989 C28.041793,39.297674 34.2643908,38.7118128 37.8410347,42.5335275 L56.0882845,63.1470817 L69.7748997,56.7400579 C72.766567,55.3552503 76.3013751,55.9473836 78.678437,58.2315339 C78.8106437,58.3585731 79.0742301,58.609836 79.4527088,58.9673596 C80.0910923,59.570398 80.8117772,60.2441563 81.598127,60.9705595 C83.8422198,63.043576 86.1541548,65.1151944 88.3956721,67.0372264 C89.1168795,67.6556396 89.8200801,68.2492007 90.5021258,68.8146755 C92.6097224,70.5620551 94.4693308,72.0029474 95.9836366,73.0515697 C96.7316295,73.5695379 97.3674038,73.9719282 98.0281481,74.3824999 C98.4724987,74.4989557 99.0742374,74.5263881 99.8365134,74.4317984 C101.709944,74.1993272 104.074502,73.2878514 106.559886,71.8846196 C107.705822,71.2376318 108.790494,70.5370325 109.764561,69.8410487 C110.323259,69.4418522 110.694168,69.1550757 110.834827,69.0391868 C111.210545,68.7296319 111.600264,68.4615815 112,68.2332211 L112,68.2332211 Z M0,8.00697327 C0,3.58484404 3.59075293,0 8.00697327,0 L119.993027,0 C124.415156,0 128,3.59075293 128,8.00697327 L128,119.993027 C128,124.415156 124.409247,128 119.993027,128 L8.00697327,128 C3.58484404,128 0,124.409247 0,119.993027 L0,8.00697327 L0,8.00697327 Z M95,42 C99.418278,42 103,38.418278 103,34 C103,29.581722 99.418278,26 95,26 C90.581722,26 87,29.581722 87,34 C87,38.418278 90.581722,42 95,42 L95,42 Z M32,76 C47.8587691,80.8294182 52.0345556,83.2438712 52.0345556,88 C52.0345556,92.7561288 32,95.4712486 32,102.347107 C32,109.222965 33.2849191,107.337637 33.2849191,112 L67.999999,112 C67.999999,112 54.3147136,105.375255 54.3147136,101.200691 C54.3147136,93.535181 64.9302432,92.860755 64.9302432,88 C64.9302432,80.6425555 50.8523779,79.167282 32,76 L32,76 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/plugin-generic-language": {
"title": "$:/core/images/plugin-generic-language",
"tags": "$:/tags/Image",
"text": "<svg width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M61.2072232,68.1369825 C56.8829239,70.9319564 54.2082892,74.793177 54.2082892,79.0581634 C54.2082892,86.9638335 63.3980995,93.4821994 75.2498076,94.3940006 C77.412197,98.2964184 83.8475284,101.178858 91.5684735,101.403106 C86.4420125,100.27851 82.4506393,97.6624107 80.9477167,94.3948272 C92.8046245,93.4861461 102,86.9662269 102,79.0581634 C102,70.5281905 91.3014611,63.6132813 78.1041446,63.6132813 C71.5054863,63.6132813 65.5315225,65.3420086 61.2072232,68.1369825 Z M74.001066,53.9793443 C69.6767667,56.7743182 63.7028029,58.5030456 57.1041446,58.5030456 C54.4851745,58.5030456 51.9646095,58.2307276 49.6065315,57.7275105 C46.2945155,59.9778212 41.2235699,61.4171743 35.5395922,61.4171743 C35.4545771,61.4171743 35.3696991,61.4168523 35.2849622,61.4162104 C39.404008,60.5235193 42.7961717,58.6691298 44.7630507,56.286533 C37.8379411,53.5817651 33.2082892,48.669413 33.2082892,43.0581634 C33.2082892,34.5281905 43.9068281,27.6132812 57.1041446,27.6132812 C70.3014611,27.6132812 81,34.5281905 81,43.0581634 C81,47.3231498 78.3253653,51.1843704 74.001066,53.9793443 Z M64,0 L118.5596,32 L118.5596,96 L64,128 L9.44039956,96 L9.44039956,32 L64,0 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/plugin-generic-plugin": {
"title": "$:/core/images/plugin-generic-plugin",
"tags": "$:/tags/Image",
"text": "<svg width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M40.3972881,76.4456988 L40.3972881,95.3404069 L54.5170166,95.3404069 L54.5170166,95.3404069 C54.5165526,95.3385183 54.516089,95.3366295 54.515626,95.3347404 C54.6093153,95.3385061 54.7034848,95.3404069 54.7980982,95.3404069 C58.6157051,95.3404069 61.710487,92.245625 61.710487,88.4280181 C61.710487,86.6197822 61.01617,84.9737128 59.8795929,83.7418666 L59.8795929,83.7418666 C59.8949905,83.7341665 59.9104102,83.7265043 59.925852,83.7188798 C58.8840576,82.5086663 58.2542926,80.9336277 58.2542926,79.2114996 C58.2542926,75.3938927 61.3490745,72.2991108 65.1666814,72.2991108 C68.9842884,72.2991108 72.0790703,75.3938927 72.0790703,79.2114996 C72.0790703,81.1954221 71.2432806,82.9841354 69.9045961,84.2447446 L69.9045961,84.2447446 C69.9333407,84.2629251 69.9619885,84.281245 69.9905383,84.2997032 L69.9905383,84.2997032 C69.1314315,85.4516923 68.6228758,86.8804654 68.6228758,88.4280181 C68.6228758,91.8584969 71.1218232,94.7053153 74.3986526,95.2474079 C74.3913315,95.2784624 74.3838688,95.3094624 74.3762652,95.3404069 L95.6963988,95.3404069 L95.6963988,75.5678578 L95.6963988,75.5678578 C95.6466539,75.5808558 95.5967614,75.5934886 95.5467242,75.6057531 C95.5504899,75.5120637 95.5523907,75.4178943 95.5523907,75.3232809 C95.5523907,71.505674 92.4576088,68.4108921 88.6400019,68.4108921 C86.831766,68.4108921 85.1856966,69.105209 83.9538504,70.2417862 L83.9538504,70.2417862 C83.9461503,70.2263886 83.938488,70.2109688 83.9308636,70.1955271 C82.7206501,71.2373215 81.1456115,71.8670865 79.4234834,71.8670865 C75.6058765,71.8670865 72.5110946,68.7723046 72.5110946,64.9546976 C72.5110946,61.1370907 75.6058765,58.0423088 79.4234834,58.0423088 C81.4074059,58.0423088 83.1961192,58.8780985 84.4567284,60.2167829 L84.4567284,60.2167829 C84.4749089,60.1880383 84.4932288,60.1593906 84.511687,60.1308407 L84.511687,60.1308407 C85.6636761,60.9899475 87.0924492,61.4985032 88.6400019,61.4985032 C92.0704807,61.4985032 94.9172991,58.9995558 95.4593917,55.7227265 C95.538755,55.7414363 95.6177614,55.761071 95.6963988,55.7816184 L95.6963988,40.0412962 L74.3762652,40.0412962 L74.3762652,40.0412962 C74.3838688,40.0103516 74.3913315,39.9793517 74.3986526,39.9482971 L74.3986526,39.9482971 C71.1218232,39.4062046 68.6228758,36.5593862 68.6228758,33.1289073 C68.6228758,31.5813547 69.1314315,30.1525815 69.9905383,29.0005925 C69.9619885,28.9821342 69.9333407,28.9638143 69.9045961,28.9456339 C71.2432806,27.6850247 72.0790703,25.8963113 72.0790703,23.9123888 C72.0790703,20.0947819 68.9842884,17 65.1666814,17 C61.3490745,17 58.2542926,20.0947819 58.2542926,23.9123888 C58.2542926,25.6345169 58.8840576,27.2095556 59.925852,28.419769 L59.925852,28.419769 C59.9104102,28.4273935 59.8949905,28.4350558 59.8795929,28.4427558 C61.01617,29.674602 61.710487,31.3206715 61.710487,33.1289073 C61.710487,36.9465143 58.6157051,40.0412962 54.7980982,40.0412962 C54.7034848,40.0412962 54.6093153,40.0393953 54.515626,40.0356296 L54.515626,40.0356296 C54.516089,40.0375187 54.5165526,40.0394075 54.5170166,40.0412962 L40.3972881,40.0412962 L40.3972881,52.887664 L40.3972881,52.887664 C40.4916889,53.3430132 40.5412962,53.8147625 40.5412962,54.2980982 C40.5412962,58.1157051 37.4465143,61.210487 33.6289073,61.210487 C32.0813547,61.210487 30.6525815,60.7019313 29.5005925,59.8428245 C29.4821342,59.8713744 29.4638143,59.9000221 29.4456339,59.9287667 C28.1850247,58.5900823 26.3963113,57.7542926 24.4123888,57.7542926 C20.5947819,57.7542926 17.5,60.8490745 17.5,64.6666814 C17.5,68.4842884 20.5947819,71.5790703 24.4123888,71.5790703 C26.134517,71.5790703 27.7095556,70.9493053 28.919769,69.9075109 L28.919769,69.9075109 C28.9273935,69.9229526 28.9350558,69.9383724 28.9427558,69.95377 C30.174602,68.8171928 31.8206715,68.1228758 33.6289073,68.1228758 C37.4465143,68.1228758 40.5412962,71.2176578 40.5412962,75.0352647 C40.5412962,75.5186004 40.4916889,75.9903496 40.3972881,76.4456988 Z M64,0 L118.5596,32 L118.5596,96 L64,128 L9.44039956,96 L9.44039956,32 L64,0 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/plugin-generic-theme": {
"title": "$:/core/images/plugin-generic-theme",
"tags": "$:/tags/Image",
"text": "<svg width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M29.4078519,91.4716406 L51.4693474,69.4101451 L51.4646675,69.4054652 C50.5969502,68.5377479 50.5929779,67.1348725 51.4693474,66.2585029 C52.3396494,65.3882009 53.7499654,65.3874786 54.6163097,66.2538229 L64.0805963,75.7181095 C64.9483136,76.5858268 64.9522859,77.9887022 64.0759163,78.8650718 C63.2056143,79.7353737 61.7952984,79.736096 60.9289541,78.8697517 L60.9242741,78.8650718 L60.9242741,78.8650718 L38.8627786,100.926567 C36.2518727,103.537473 32.0187578,103.537473 29.4078519,100.926567 C26.796946,98.3156614 26.796946,94.0825465 29.4078519,91.4716406 Z M60.8017407,66.3810363 C58.3659178,63.6765806 56.3370667,61.2899536 54.9851735,59.5123615 C48.1295381,50.4979488 44.671561,55.2444054 40.7586738,59.5123614 C36.8457866,63.7803174 41.789473,67.2384487 38.0759896,70.2532832 C34.3625062,73.2681177 34.5917646,74.3131575 28.3243876,68.7977024 C22.0570105,63.2822473 21.6235306,61.7636888 24.5005999,58.6166112 C27.3776691,55.4695337 29.7823103,60.4247912 35.6595047,54.8320442 C41.5366991,49.2392972 36.5996215,44.2825646 36.5996215,44.2825646 C36.5996215,44.2825646 48.8365511,19.267683 65.1880231,21.1152173 C81.5394952,22.9627517 59.0022276,18.7228947 53.3962199,38.3410355 C50.9960082,46.7405407 53.8429162,44.7613399 58.3941742,48.3090467 C59.7875202,49.3951602 64.4244828,52.7100463 70.1884353,56.9943417 L90.8648751,36.3179019 L92.4795866,31.5515482 L100.319802,26.8629752 L103.471444,30.0146174 L98.782871,37.8548326 L94.0165173,39.4695441 L73.7934912,59.6925702 C86.4558549,69.2403631 102.104532,81.8392557 102.104532,86.4016913 C102.104533,93.6189834 99.0337832,97.9277545 92.5695848,95.5655717 C87.8765989,93.8506351 73.8015497,80.3744087 63.8173444,69.668717 L60.9242741,72.5617873 L57.7726319,69.4101451 L60.8017407,66.3810363 L60.8017407,66.3810363 Z M63.9533761,1.42108547e-13 L118.512977,32 L118.512977,96 L63.9533761,128 L9.39377563,96 L9.39377563,32 L63.9533761,1.42108547e-13 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/preview-closed": {
"title": "$:/core/images/preview-closed",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-preview-closed tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M0.0881363238,64 C-0.210292223,65.8846266 0.249135869,67.8634737 1.4664206,69.4579969 C16.2465319,88.8184886 39.1692554,100.414336 64,100.414336 C88.8307446,100.414336 111.753468,88.8184886 126.533579,69.4579969 C127.750864,67.8634737 128.210292,65.8846266 127.911864,64 C110.582357,78.4158332 88.3036732,87.0858436 64,87.0858436 C39.6963268,87.0858436 17.4176431,78.4158332 0.0881363238,64 Z\"></path>\n <rect x=\"62\" y=\"96\" width=\"4\" height=\"16\" rx=\"4\"></rect>\n <rect transform=\"translate(80.000000, 101.000000) rotate(-5.000000) translate(-80.000000, -101.000000) \" x=\"78\" y=\"93\" width=\"4\" height=\"16\" rx=\"4\"></rect>\n <rect transform=\"translate(48.000000, 101.000000) rotate(-355.000000) translate(-48.000000, -101.000000) \" x=\"46\" y=\"93\" width=\"4\" height=\"16\" rx=\"4\"></rect>\n <rect transform=\"translate(32.000000, 96.000000) rotate(-350.000000) translate(-32.000000, -96.000000) \" x=\"30\" y=\"88\" width=\"4\" height=\"16\" rx=\"4\"></rect>\n <rect transform=\"translate(96.000000, 96.000000) rotate(-10.000000) translate(-96.000000, -96.000000) \" x=\"94\" y=\"88\" width=\"4\" height=\"16\" rx=\"4\"></rect>\n <rect transform=\"translate(112.000000, 88.000000) rotate(-20.000000) translate(-112.000000, -88.000000) \" x=\"110\" y=\"80\" width=\"4\" height=\"16\" rx=\"4\"></rect>\n <rect transform=\"translate(16.000000, 88.000000) rotate(-340.000000) translate(-16.000000, -88.000000) \" x=\"14\" y=\"80\" width=\"4\" height=\"16\" rx=\"4\"></rect>\n </g>\n</svg>"
},
"$:/core/images/preview-open": {
"title": "$:/core/images/preview-open",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-preview-open tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M64.1099282,99.5876785 C39.2791836,99.5876785 16.3564602,87.9918313 1.57634884,68.6313396 C-0.378878622,66.070184 -0.378878622,62.5174945 1.57634884,59.9563389 C16.3564602,40.5958472 39.2791836,29 64.1099282,29 C88.9406729,29 111.863396,40.5958472 126.643508,59.9563389 C128.598735,62.5174945 128.598735,66.070184 126.643508,68.6313396 C111.863396,87.9918313 88.9406729,99.5876785 64.1099282,99.5876785 Z M110.213805,67.5808331 C111.654168,66.0569335 111.654168,63.9430665 110.213805,62.4191669 C99.3257042,50.8995835 82.4391647,44 64.1470385,44 C45.8549124,44 28.9683729,50.8995835 18.0802717,62.4191669 C16.6399094,63.9430665 16.6399094,66.0569335 18.0802717,67.5808331 C28.9683729,79.1004165 45.8549124,86 64.1470385,86 C82.4391647,86 99.3257042,79.1004165 110.213805,67.5808331 Z\"></path>\n <path d=\"M63.5,88 C76.4786916,88 87,77.4786916 87,64.5 C87,51.5213084 76.4786916,41 63.5,41 C50.5213084,41 40,51.5213084 40,64.5 C40,77.4786916 50.5213084,88 63.5,88 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/print-button": {
"title": "$:/core/images/print-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-print-button tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\">\n <g fill-rule=\"evenodd\">\n <path d=\"M112,71 L112,30.5 L111.96811,30.5 L111.96811,30.5 C111.932942,28.4998414 111.151676,26.510538 109.625176,24.9840387 L86.9982489,2.35711116 C85.3482153,0.707077645 83.1589869,-0.071534047 81,0.0201838424 L81,0 L23.9992458,0 C19.5808867,0 16,3.58213437 16,8.00092105 L16,71 L24,71 L24,8 L81,8 L81,22.4996539 C81,26.9216269 84.5818769,30.5 89.0003461,30.5 L104,30.5 L104,71 L112,71 Z\"></path>\n <rect x=\"32\" y=\"36\" width=\"64\" height=\"8\" rx=\"4\"></rect>\n <rect x=\"32\" y=\"52\" width=\"64\" height=\"8\" rx=\"4\"></rect>\n <rect x=\"32\" y=\"20\" width=\"40\" height=\"8\" rx=\"4\"></rect>\n <path d=\"M0,80.0054195 C0,71.1658704 7.15611005,64 16.0008841,64 L111.999116,64 C120.83616,64 128,71.1553215 128,80.0054195 L128,111.99458 C128,120.83413 120.84389,128 111.999116,128 L16.0008841,128 C7.16383982,128 0,120.844679 0,111.99458 L0,80.0054195 Z M104,96 C108.418278,96 112,92.418278 112,88 C112,83.581722 108.418278,80 104,80 C99.581722,80 96,83.581722 96,88 C96,92.418278 99.581722,96 104,96 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/quote": {
"title": "$:/core/images/quote",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-quote tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M51.2188077,117.712501 L51.2188077,62.1993386 L27.4274524,62.1993386 C27.4274524,53.3075754 29.1096526,45.797753 32.4741035,39.669646 C35.8385544,33.541539 42.0867267,28.9154883 51.2188077,25.7913554 L51.2188077,2 C43.7689521,2.96127169 36.8599155,5.18417913 30.4914905,8.668789 C24.1230656,12.1533989 18.6559149,16.5391352 14.0898743,21.8261295 C9.52383382,27.1131238 5.97919764,33.2411389 3.45585945,40.2103586 C0.932521268,47.1795784 -0.208971741,54.6293222 0.0313461819,62.5598136 L0.0313461819,117.712501 L51.2188077,117.712501 Z M128,117.712501 L128,62.1993386 L104.208645,62.1993386 C104.208645,53.3075754 105.890845,45.797753 109.255296,39.669646 C112.619747,33.541539 118.867919,28.9154883 128,25.7913554 L128,2 C120.550144,2.96127169 113.641108,5.18417913 107.272683,8.668789 C100.904258,12.1533989 95.4371072,16.5391352 90.8710666,21.8261295 C86.3050261,27.1131238 82.7603899,33.2411389 80.2370517,40.2103586 C77.7137136,47.1795784 76.5722206,54.6293222 76.8125385,62.5598136 L76.8125385,117.712501 L128,117.712501 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/refresh-button": {
"title": "$:/core/images/refresh-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-refresh-button tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M106.369002,39.4325143 C116.529932,60.3119371 112.939592,86.1974934 95.5979797,103.539105 C73.7286194,125.408466 38.2713806,125.408466 16.4020203,103.539105 C-5.46734008,81.6697449 -5.46734008,46.2125061 16.4020203,24.3431458 C19.5262146,21.2189514 24.5915344,21.2189514 27.7157288,24.3431458 C30.8399231,27.4673401 30.8399231,32.5326599 27.7157288,35.6568542 C12.0947571,51.2778259 12.0947571,76.6044251 27.7157288,92.2253967 C43.3367004,107.846368 68.6632996,107.846368 84.2842712,92.2253967 C97.71993,78.7897379 99.5995262,58.1740623 89.9230597,42.729491 L83.4844861,54.9932839 C81.4307001,58.9052072 76.5945372,60.4115251 72.682614,58.3577391 C68.7706907,56.3039532 67.2643728,51.4677903 69.3181587,47.555867 L84.4354914,18.7613158 C86.4966389,14.8353707 91.3577499,13.3347805 95.273202,15.415792 L124.145886,30.7612457 C128.047354,32.8348248 129.52915,37.6785572 127.455571,41.5800249 C125.381992,45.4814927 120.53826,46.9632892 116.636792,44.8897102 L106.369002,39.4325143 Z M98.1470904,27.0648707 C97.9798954,26.8741582 97.811187,26.6843098 97.6409651,26.4953413 L98.6018187,26.1987327 L98.1470904,27.0648707 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/right-arrow": {
"title": "$:/core/images/right-arrow",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-right-arrow tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <path d=\"M80.3563798,109.353315 C78.9238993,110.786918 76.9450203,111.675144 74.7592239,111.675144 L-4.40893546,111.675144 C-8.77412698,111.675144 -12.3248558,108.130732 -12.3248558,103.758478 C-12.3248558,99.3951199 -8.78077754,95.8418109 -4.40893546,95.8418109 L66.8418109,95.8418109 L66.8418109,24.5910645 C66.8418109,20.225873 70.3862233,16.6751442 74.7584775,16.6751442 C79.1218352,16.6751442 82.6751442,20.2192225 82.6751442,24.5910645 L82.6751442,103.759224 C82.6751442,105.941695 81.7891419,107.920575 80.3566508,109.353886 Z\" transform=\"translate(35.175144, 64.175144) rotate(-45.000000) translate(-35.175144, -64.175144) \"></path>\n</svg>"
},
"$:/core/images/rotate-left": {
"title": "$:/core/images/rotate-left",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-rotate-left tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\"><g fill-rule=\"evenodd\"><rect width=\"32\" height=\"80\" rx=\"8\"/><rect x=\"48\" y=\"96\" width=\"80\" height=\"32\" rx=\"8\"/><path d=\"M61.32 36.65c19.743 2.45 35.023 19.287 35.023 39.693a4 4 0 0 1-8 0c0-15.663-11.254-28.698-26.117-31.46l3.916 3.916a4 4 0 1 1-5.657 5.657L49.172 43.142a4 4 0 0 1 0-5.657l11.313-11.313a4 4 0 1 1 5.657 5.656l-4.821 4.822z\"/></g></svg>"
},
"$:/core/images/save-button": {
"title": "$:/core/images/save-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-save-button tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\">\n <g fill-rule=\"evenodd\">\n <path d=\"M120.78304,34.329058 C125.424287,43.1924006 128.049406,53.2778608 128.049406,63.9764502 C128.049406,99.3226742 99.3956295,127.97645 64.0494055,127.97645 C28.7031816,127.97645 0.0494055385,99.3226742 0.0494055385,63.9764502 C0.0494055385,28.6302262 28.7031816,-0.0235498012 64.0494055,-0.0235498012 C82.8568763,-0.0235498012 99.769563,8.08898558 111.479045,21.0056358 L114.159581,18.3250998 C117.289194,15.1954866 122.356036,15.1939641 125.480231,18.3181584 C128.598068,21.4359957 128.601317,26.5107804 125.473289,29.6388083 L120.78304,34.329058 Z M108.72451,46.3875877 C110.870571,51.8341374 112.049406,57.767628 112.049406,63.9764502 C112.049406,90.4861182 90.5590735,111.97645 64.0494055,111.97645 C37.5397375,111.97645 16.0494055,90.4861182 16.0494055,63.9764502 C16.0494055,37.4667822 37.5397375,15.9764502 64.0494055,15.9764502 C78.438886,15.9764502 91.3495036,22.308215 100.147097,32.3375836 L58.9411255,73.5435552 L41.975581,56.5780107 C38.8486152,53.4510448 33.7746915,53.4551552 30.6568542,56.5729924 C27.5326599,59.6971868 27.5372202,64.7670668 30.6618725,67.8917192 L53.279253,90.5090997 C54.8435723,92.073419 56.8951519,92.8541315 58.9380216,92.8558261 C60.987971,92.8559239 63.0389578,92.0731398 64.6049211,90.5071765 L108.72451,46.3875877 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/size": {
"title": "$:/core/images/size",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-size tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <path d=\"M92.3431458,26 L83.1715729,35.1715729 C81.6094757,36.73367 81.6094757,39.26633 83.1715729,40.8284271 C84.73367,42.3905243 87.26633,42.3905243 88.8284271,40.8284271 L104.828427,24.8284271 C106.390524,23.26633 106.390524,20.73367 104.828427,19.1715729 L88.8284271,3.17157288 C87.26633,1.60947571 84.73367,1.60947571 83.1715729,3.17157288 C81.6094757,4.73367004 81.6094757,7.26632996 83.1715729,8.82842712 L92.3431457,18 L22,18 C19.790861,18 18,19.790861 18,22 L18,92.3431458 L8.82842712,83.1715729 C7.26632996,81.6094757 4.73367004,81.6094757 3.17157288,83.1715729 C1.60947571,84.73367 1.60947571,87.26633 3.17157288,88.8284271 L19.1715729,104.828427 C20.73367,106.390524 23.26633,106.390524 24.8284271,104.828427 L40.8284271,88.8284271 C42.3905243,87.26633 42.3905243,84.73367 40.8284271,83.1715729 C39.26633,81.6094757 36.73367,81.6094757 35.1715729,83.1715729 L26,92.3431458 L26,22 L22,26 L92.3431458,26 L92.3431458,26 Z M112,52 L112,116 L116,112 L52,112 C49.790861,112 48,113.790861 48,116 C48,118.209139 49.790861,120 52,120 L116,120 C118.209139,120 120,118.209139 120,116 L120,52 C120,49.790861 118.209139,48 116,48 C113.790861,48 112,49.790861 112,52 L112,52 Z\"></path>\n</svg>"
},
"$:/core/images/spiral": {
"title": "$:/core/images/spiral",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-spiral tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"nonzero\">\n <path d=\"M64.534 68.348c3.39 0 6.097-2.62 6.476-5.968l-4.755-.538 4.75.583c.377-3.07-1.194-6.054-3.89-7.78-2.757-1.773-6.34-2.01-9.566-.7-3.46 1.403-6.14 4.392-7.35 8.148l-.01.026c-1.3 4.08-.72 8.64 1.58 12.52 2.5 4.2 6.77 7.2 11.76 8.27 5.37 1.15 11.11-.05 15.83-3.31 5.04-3.51 8.46-9.02 9.45-15.3 1.05-6.7-.72-13.63-4.92-19.19l.02.02c-4.42-5.93-11.2-9.82-18.78-10.78-7.96-1.01-16.13 1.31-22.59 6.43-6.81 5.39-11.18 13.41-12.11 22.26-.98 9.27 1.87 18.65 7.93 26.02 6.32 7.69 15.6 12.56 25.74 13.48 10.54.96 21.15-2.42 29.45-9.4l.01-.01c8.58-7.25 13.94-17.78 14.86-29.21.94-11.84-2.96-23.69-10.86-32.9-8.19-9.5-19.95-15.36-32.69-16.27-13.16-.94-26.24 3.49-36.34 12.34l.01-.01c-10.41 9.08-16.78 22.1-17.68 36.15-.93 14.44 4.03 28.77 13.79 39.78 10.03 11.32 24.28 18.2 39.6 19.09 15.73.92 31.31-4.56 43.24-15.234 12.23-10.954 19.61-26.44 20.5-43.074.14-2.64-1.89-4.89-4.52-5.03-2.64-.14-4.89 1.88-5.03 4.52-.75 14.1-7 27.2-17.33 36.45-10.03 8.98-23.11 13.58-36.3 12.81-12.79-.75-24.67-6.48-33-15.89-8.07-9.11-12.17-20.94-11.41-32.827.74-11.52 5.942-22.15 14.43-29.54l.01-.01c8.18-7.17 18.74-10.75 29.35-9.998 10.21.726 19.6 5.41 26.11 12.96 6.24 7.273 9.32 16.61 8.573 25.894-.718 8.9-4.88 17.064-11.504 22.66l.01-.007c-6.36 5.342-14.44 7.92-22.425 7.19-7.604-.68-14.52-4.314-19.21-10.027-4.44-5.4-6.517-12.23-5.806-18.94.67-6.3 3.76-11.977 8.54-15.766 4.46-3.54 10.05-5.128 15.44-4.44 5.03.63 9.46 3.18 12.32 7.01l.02.024c2.65 3.5 3.75 7.814 3.1 11.92-.59 3.71-2.58 6.925-5.45 8.924-2.56 1.767-5.61 2.403-8.38 1.81-2.42-.516-4.42-1.92-5.53-3.79-.93-1.56-1.15-3.3-.69-4.75l-4.56-1.446L59.325 65c.36-1.12 1.068-1.905 1.84-2.22.25-.103.48-.14.668-.13.06.006.11.015.14.025.01 0 .01 0-.01-.01-.02-.015-.054-.045-.094-.088-.06-.064-.12-.145-.17-.244-.15-.29-.23-.678-.18-1.11l-.005.04c.15-1.332 1.38-2.523 3.035-2.523-2.65 0-4.79 2.144-4.79 4.787s2.14 4.785 4.78 4.785z\"></path>\n </g>\n</svg>"
},
"$:/core/images/stamp": {
"title": "$:/core/images/stamp",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-stamp tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M49.7334301,64 L16.0098166,64 C11.5838751,64 8,67.5829053 8,72.002643 L8,74.4986785 L8,97 L120,97 L120,74.4986785 L120,72.002643 C120,67.5737547 116.413883,64 111.990183,64 L78.2665699,64 C76.502049,60.7519149 75.5,57.0311962 75.5,53.0769231 C75.5,46.6017951 78.1869052,40.7529228 82.5087769,36.5800577 C85.3313113,32.7688808 87,28.0549983 87,22.952183 C87,10.2760423 76.7025492,0 64,0 C51.2974508,0 41,10.2760423 41,22.952183 C41,28.0549983 42.6686887,32.7688808 45.4912231,36.5800577 C49.8130948,40.7529228 52.5,46.6017951 52.5,53.0769231 C52.5,57.0311962 51.497951,60.7519149 49.7334301,64 Z M8,104 L120,104 L120,112 L8,112 L8,104 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/star-filled": {
"title": "$:/core/images/star-filled",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-star-filled tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"nonzero\">\n <path d=\"M61.8361286,96.8228569 L99.1627704,124.110219 C101.883827,126.099427 105.541968,123.420868 104.505636,120.198072 L90.2895569,75.9887263 L89.0292911,79.8977279 L126.314504,52.5528988 C129.032541,50.5595011 127.635256,46.2255025 124.273711,46.2229134 L78.1610486,46.1873965 L81.4604673,48.6032923 L67.1773543,4.41589688 C66.1361365,1.19470104 61.6144265,1.19470104 60.5732087,4.41589688 L46.2900957,48.6032923 L49.5895144,46.1873965 L3.47685231,46.2229134 C0.115307373,46.2255025 -1.28197785,50.5595011 1.43605908,52.5528988 L38.7212719,79.8977279 L37.4610061,75.9887263 L23.2449266,120.198072 C22.2085954,123.420868 25.8667356,126.099427 28.5877926,124.110219 L65.9144344,96.8228569 L61.8361286,96.8228569 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/storyview-classic": {
"title": "$:/core/images/storyview-classic",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-storyview-classic tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M8.00697327,0 C3.58484404,0 0,3.59075293 0,8.00697327 L0,119.993027 C0,124.415156 3.59075293,128 8.00697327,128 L119.993027,128 C124.415156,128 128,124.409247 128,119.993027 L128,8.00697327 C128,3.58484404 124.409247,0 119.993027,0 L8.00697327,0 L8.00697327,0 Z M23.9992458,16 C19.5813843,16 16,19.5776607 16,23.9924054 L16,40.0075946 C16,44.4216782 19.5881049,48 23.9992458,48 L104.000754,48 C108.418616,48 112,44.4223393 112,40.0075946 L112,23.9924054 C112,19.5783218 108.411895,16 104.000754,16 L23.9992458,16 L23.9992458,16 Z M23.9992458,64 C19.5813843,64 16,67.5907123 16,72 C16,76.418278 19.5881049,80 23.9992458,80 L104.000754,80 C108.418616,80 112,76.4092877 112,72 C112,67.581722 108.411895,64 104.000754,64 L23.9992458,64 L23.9992458,64 Z M23.9992458,96 C19.5813843,96 16,99.5907123 16,104 C16,108.418278 19.5881049,112 23.9992458,112 L104.000754,112 C108.418616,112 112,108.409288 112,104 C112,99.581722 108.411895,96 104.000754,96 L23.9992458,96 L23.9992458,96 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/storyview-pop": {
"title": "$:/core/images/storyview-pop",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-storyview-pop tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M8.00697327,0 C3.58484404,0 0,3.59075293 0,8.00697327 L0,119.993027 C0,124.415156 3.59075293,128 8.00697327,128 L119.993027,128 C124.415156,128 128,124.409247 128,119.993027 L128,8.00697327 C128,3.58484404 124.409247,0 119.993027,0 L8.00697327,0 L8.00697327,0 Z M23.9992458,16 C19.5813843,16 16,19.5776607 16,23.9924054 L16,40.0075946 C16,44.4216782 19.5881049,48 23.9992458,48 L104.000754,48 C108.418616,48 112,44.4223393 112,40.0075946 L112,23.9924054 C112,19.5783218 108.411895,16 104.000754,16 L23.9992458,16 L23.9992458,16 Z M16.0098166,56 C11.586117,56 8,59.5776607 8,63.9924054 L8,80.0075946 C8,84.4216782 11.5838751,88 16.0098166,88 L111.990183,88 C116.413883,88 120,84.4223393 120,80.0075946 L120,63.9924054 C120,59.5783218 116.416125,56 111.990183,56 L16.0098166,56 L16.0098166,56 Z M23.9992458,96 C19.5813843,96 16,99.5907123 16,104 C16,108.418278 19.5881049,112 23.9992458,112 L104.000754,112 C108.418616,112 112,108.409288 112,104 C112,99.581722 108.411895,96 104.000754,96 L23.9992458,96 L23.9992458,96 Z M23.9992458,64 C19.5813843,64 16,67.5907123 16,72 C16,76.418278 19.5881049,80 23.9992458,80 L104.000754,80 C108.418616,80 112,76.4092877 112,72 C112,67.581722 108.411895,64 104.000754,64 L23.9992458,64 L23.9992458,64 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/storyview-zoomin": {
"title": "$:/core/images/storyview-zoomin",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-storyview-zoomin tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M8.00697327,0 C3.58484404,0 0,3.59075293 0,8.00697327 L0,119.993027 C0,124.415156 3.59075293,128 8.00697327,128 L119.993027,128 C124.415156,128 128,124.409247 128,119.993027 L128,8.00697327 C128,3.58484404 124.409247,0 119.993027,0 L8.00697327,0 L8.00697327,0 Z M23.9992458,16 C19.5813843,16 16,19.578055 16,24.0085154 L16,71.9914846 C16,76.4144655 19.5881049,80 23.9992458,80 L104.000754,80 C108.418616,80 112,76.421945 112,71.9914846 L112,24.0085154 C112,19.5855345 108.411895,16 104.000754,16 L23.9992458,16 L23.9992458,16 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/strikethrough": {
"title": "$:/core/images/strikethrough",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-strikethrough tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M92.793842,38.7255689 L108.215529,38.7255689 C107.987058,31.985687 106.70193,26.1883331 104.360107,21.3333333 C102.018284,16.4783336 98.8197436,12.4516001 94.7643909,9.25301205 C90.7090382,6.05442399 85.9969032,3.71263572 80.6278447,2.22757697 C75.2587862,0.742518233 69.4328739,0 63.1499331,0 C57.552404,0 52.0977508,0.713959839 46.7858099,2.14190094 C41.473869,3.56984203 36.7331757,5.74027995 32.5635877,8.65327979 C28.3939997,11.5662796 25.0526676,15.2788708 22.5394913,19.7911647 C20.026315,24.3034585 18.7697456,29.6438781 18.7697456,35.8125837 C18.7697456,41.4101128 19.883523,46.0651309 22.1111111,49.7777778 C24.3386992,53.4904246 27.3087722,56.5176144 31.021419,58.8594378 C34.7340659,61.2012612 38.9321497,63.0861151 43.6157965,64.5140562 C48.2994433,65.9419973 53.068695,67.1985666 57.9236948,68.2838019 C62.7786945,69.3690371 67.5479462,70.4256977 72.231593,71.4538153 C76.9152398,72.4819329 81.1133237,73.8241773 84.8259705,75.480589 C88.5386174,77.1370007 91.5086903,79.2788802 93.7362784,81.9062918 C95.9638666,84.5337035 97.0776439,87.9607107 97.0776439,92.1874163 C97.0776439,96.6425926 96.1637753,100.298067 94.3360107,103.153949 C92.5082461,106.009831 90.109341,108.265944 87.1392236,109.922356 C84.1691061,111.578768 80.827774,112.749662 77.1151272,113.435074 C73.4024803,114.120485 69.7184476,114.463186 66.0629183,114.463186 C61.4935068,114.463186 57.0383974,113.892018 52.6974565,112.749665 C48.3565156,111.607312 44.5582492,109.836692 41.3025435,107.437751 C38.0468378,105.03881 35.4194656,101.983062 33.4203481,98.270415 C31.4212305,94.5577681 30.4216867,90.1312171 30.4216867,84.9906292 L15,84.9906292 C15,92.4159229 16.3422445,98.8415614 19.0267738,104.267738 C21.711303,109.693914 25.3667774,114.149023 29.9933066,117.633199 C34.6198357,121.117376 39.9888137,123.71619 46.1004016,125.429719 C52.2119895,127.143248 58.6947448,128 65.5488621,128 C71.1463912,128 76.7723948,127.343157 82.4270415,126.029451 C88.0816882,124.715745 93.1936407,122.602424 97.7630522,119.689424 C102.332464,116.776425 106.073613,113.006717 108.986613,108.380187 C111.899613,103.753658 113.356091,98.1847715 113.356091,91.6733601 C113.356091,85.6188899 112.242314,80.5926126 110.014726,76.5943775 C107.787137,72.5961424 104.817065,69.2833688 101.104418,66.6559572 C97.3917708,64.0285455 93.193687,61.9437828 88.5100402,60.4016064 C83.8263934,58.85943 79.0571416,57.5171855 74.2021419,56.3748327 C69.3471422,55.2324798 64.5778904,54.1758192 59.8942436,53.2048193 C55.2105968,52.2338193 51.012513,51.0058084 47.2998661,49.5207497 C43.5872193,48.0356909 40.6171463,46.1222786 38.3895582,43.7804552 C36.1619701,41.4386318 35.0481928,38.3828836 35.0481928,34.6131191 C35.0481928,30.6148841 35.8192694,27.273552 37.3614458,24.5890228 C38.9036222,21.9044935 40.9598265,19.762614 43.5301205,18.1633199 C46.1004145,16.5640259 49.041929,15.4216902 52.3547523,14.7362784 C55.6675757,14.0508667 59.0374661,13.708166 62.4645248,13.708166 C70.9179361,13.708166 77.8576257,15.6786952 83.2838019,19.6198126 C88.709978,23.56093 91.8799597,29.9294518 92.793842,38.7255689 L92.793842,38.7255689 Z\"></path>\n <rect x=\"5\" y=\"54\" width=\"118\" height=\"16\"></rect>\n </g>\n</svg>"
},
"$:/core/images/subscript": {
"title": "$:/core/images/subscript",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-subscript tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M2.27170276,16 L22.1825093,16 L43.8305003,49.6746527 L66.4138983,16 L85.1220387,16 L53.5854592,61.9685735 L87.3937414,111.411516 L67.0820462,111.411516 L43.295982,74.9306422 L19.1090291,111.411516 L0,111.411516 L33.8082822,61.9685735 L2.27170276,16 Z M127.910914,128.411516 L85.3276227,128.411516 C85.3870139,123.24448 86.6342108,118.730815 89.0692508,114.870386 C91.5042907,111.009956 94.8301491,107.654403 99.0469256,104.803624 C101.066227,103.318844 103.174584,101.878629 105.372059,100.482935 C107.569534,99.0872413 109.588805,97.5876355 111.429933,95.9840726 C113.271061,94.3805097 114.785514,92.6433426 115.973338,90.7725192 C117.161163,88.9016958 117.784761,86.7487964 117.844152,84.3137564 C117.844152,83.1853233 117.710524,81.9826691 117.443264,80.7057579 C117.176003,79.4288467 116.656338,78.2410402 115.884252,77.1423026 C115.112166,76.0435651 114.04314,75.123015 112.677142,74.3806248 C111.311144,73.6382345 109.529434,73.267045 107.331959,73.267045 C105.312658,73.267045 103.634881,73.6679297 102.298579,74.4697112 C100.962276,75.2714926 99.8932503,76.3702137 99.0914688,77.7659073 C98.2896874,79.161601 97.6957841,80.8096826 97.3097412,82.7102016 C96.9236982,84.6107206 96.7009845,86.6596869 96.6415933,88.857162 L86.4857457,88.857162 C86.4857457,85.4124713 86.9460207,82.2202411 87.8665846,79.2803758 C88.7871485,76.3405105 90.1679736,73.801574 92.0091014,71.6634901 C93.8502292,69.5254062 96.092214,67.8476295 98.7351233,66.6301095 C101.378033,65.4125895 104.451482,64.8038386 107.955564,64.8038386 C111.756602,64.8038386 114.933984,65.4274371 117.487807,66.6746527 C120.041629,67.9218683 122.105443,69.4957119 123.67931,71.3962309 C125.253178,73.2967499 126.366746,75.3605638 127.02005,77.5877345 C127.673353,79.8149053 128,81.9381095 128,83.9574109 C128,86.4518421 127.613963,88.7086746 126.841877,90.727976 C126.069791,92.7472774 125.03046,94.6032252 123.723854,96.2958749 C122.417247,97.9885247 120.932489,99.5475208 119.269534,100.97291 C117.60658,102.398299 115.884261,103.734582 114.102524,104.981797 C112.320788,106.229013 110.539078,107.416819 108.757341,108.545253 C106.975605,109.673686 105.327523,110.802102 103.813047,111.930535 C102.298571,113.058968 100.977136,114.231927 99.8487031,115.449447 C98.7202699,116.666967 97.9481956,117.958707 97.5324571,119.324705 L127.910914,119.324705 L127.910914,128.411516 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/superscript": {
"title": "$:/core/images/superscript",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-superscript tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M2.27170276,16 L22.1825093,16 L43.8305003,49.6746527 L66.4138983,16 L85.1220387,16 L53.5854592,61.9685735 L87.3937414,111.411516 L67.0820462,111.411516 L43.295982,74.9306422 L19.1090291,111.411516 L0,111.411516 L33.8082822,61.9685735 L2.27170276,16 Z M127.910914,63.4115159 L85.3276227,63.4115159 C85.3870139,58.2444799 86.6342108,53.7308149 89.0692508,49.8703857 C91.5042907,46.0099565 94.8301491,42.654403 99.0469256,39.8036245 C101.066227,38.318844 103.174584,36.8786285 105.372059,35.4829349 C107.569534,34.0872413 109.588805,32.5876355 111.429933,30.9840726 C113.271061,29.3805097 114.785514,27.6433426 115.973338,25.7725192 C117.161163,23.9016958 117.784761,21.7487964 117.844152,19.3137564 C117.844152,18.1853233 117.710524,16.9826691 117.443264,15.7057579 C117.176003,14.4288467 116.656338,13.2410402 115.884252,12.1423026 C115.112166,11.0435651 114.04314,10.123015 112.677142,9.38062477 C111.311144,8.63823453 109.529434,8.26704499 107.331959,8.26704499 C105.312658,8.26704499 103.634881,8.6679297 102.298579,9.46971115 C100.962276,10.2714926 99.8932503,11.3702137 99.0914688,12.7659073 C98.2896874,14.161601 97.6957841,15.8096826 97.3097412,17.7102016 C96.9236982,19.6107206 96.7009845,21.6596869 96.6415933,23.857162 L86.4857457,23.857162 C86.4857457,20.4124713 86.9460207,17.2202411 87.8665846,14.2803758 C88.7871485,11.3405105 90.1679736,8.80157397 92.0091014,6.6634901 C93.8502292,4.52540622 96.092214,2.84762946 98.7351233,1.63010947 C101.378033,0.412589489 104.451482,-0.196161372 107.955564,-0.196161372 C111.756602,-0.196161372 114.933984,0.427437071 117.487807,1.67465266 C120.041629,2.92186826 122.105443,4.49571195 123.67931,6.39623095 C125.253178,8.29674995 126.366746,10.3605638 127.02005,12.5877345 C127.673353,14.8149053 128,16.9381095 128,18.9574109 C128,21.4518421 127.613963,23.7086746 126.841877,25.727976 C126.069791,27.7472774 125.03046,29.6032252 123.723854,31.2958749 C122.417247,32.9885247 120.932489,34.5475208 119.269534,35.97291 C117.60658,37.3982993 115.884261,38.7345816 114.102524,39.9817972 C112.320788,41.2290128 110.539078,42.4168194 108.757341,43.5452525 C106.975605,44.6736857 105.327523,45.8021019 103.813047,46.9305351 C102.298571,48.0589682 100.977136,49.2319272 99.8487031,50.4494472 C98.7202699,51.6669672 97.9481956,52.9587068 97.5324571,54.3247048 L127.910914,54.3247048 L127.910914,63.4115159 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/tag-button": {
"title": "$:/core/images/tag-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-tag-button tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M18.1643182,47.6600756 L18.1677196,51.7651887 C18.1708869,55.5878829 20.3581578,60.8623899 23.0531352,63.5573673 L84.9021823,125.406414 C87.5996731,128.103905 91.971139,128.096834 94.6717387,125.396234 L125.766905,94.3010679 C128.473612,91.5943612 128.472063,87.2264889 125.777085,84.5315115 L63.9280381,22.6824644 C61.2305472,19.9849735 55.9517395,17.801995 52.1318769,17.8010313 L25.0560441,17.7942007 C21.2311475,17.7932358 18.1421354,20.8872832 18.1452985,24.7049463 L18.1535504,34.6641936 C18.2481119,34.6754562 18.3439134,34.6864294 18.4409623,34.6971263 C22.1702157,35.1081705 26.9295004,34.6530132 31.806204,33.5444844 C32.1342781,33.0700515 32.5094815,32.6184036 32.9318197,32.1960654 C35.6385117,29.4893734 39.5490441,28.718649 42.94592,29.8824694 C43.0432142,29.8394357 43.1402334,29.7961748 43.2369683,29.7526887 L43.3646982,30.0368244 C44.566601,30.5115916 45.6933052,31.2351533 46.6655958,32.2074439 C50.4612154,36.0030635 50.4663097,42.1518845 46.6769742,45.94122 C43.0594074,49.5587868 37.2914155,49.7181264 33.4734256,46.422636 C28.1082519,47.5454734 22.7987486,48.0186448 18.1643182,47.6600756 Z\"></path>\n <path d=\"M47.6333528,39.5324628 L47.6562932,39.5834939 C37.9670934,43.9391617 26.0718874,46.3819521 17.260095,45.4107025 C5.27267473,44.0894301 -1.02778744,36.4307276 2.44271359,24.0779512 C5.56175386,12.9761516 14.3014034,4.36129832 24.0466405,1.54817001 C34.7269254,-1.53487574 43.7955833,3.51606438 43.7955834,14.7730751 L35.1728168,14.7730752 C35.1728167,9.91428944 32.0946059,8.19982862 26.4381034,9.83267419 C19.5270911,11.8276553 13.046247,18.2159574 10.7440788,26.4102121 C8.82861123,33.2280582 11.161186,36.0634845 18.2047888,36.8398415 C25.3302805,37.6252244 35.7353482,35.4884477 44.1208333,31.7188498 L44.1475077,31.7781871 C44.159701,31.7725635 44.1718402,31.7671479 44.1839238,31.7619434 C45.9448098,31.0035157 50.4503245,38.3109156 47.7081571,39.5012767 C47.6834429,39.512005 47.6585061,39.5223987 47.6333528,39.5324628 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/theme-button": {
"title": "$:/core/images/theme-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-theme-button tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M55.854113,66.9453198 C54.3299482,65.1432292 53.0133883,63.518995 51.9542746,62.1263761 C40.8899947,47.578055 35.3091807,55.2383404 28.9941893,62.1263758 C22.6791979,69.0144112 30.6577916,74.5954741 24.6646171,79.4611023 C18.6714426,84.3267304 19.0414417,86.0133155 8.92654943,77.1119468 C-1.18834284,68.2105781 -1.88793412,65.7597832 2.7553553,60.6807286 C7.39864472,55.601674 11.2794845,63.5989423 20.7646627,54.5728325 C30.2498409,45.5467226 22.2819131,37.5470737 22.2819131,37.5470737 C22.2819131,37.5470737 42.0310399,-2.82433362 68.4206088,0.157393922 C94.8101776,3.13912147 58.4373806,-3.70356506 49.3898693,27.958066 C45.5161782,41.5139906 50.1107906,38.3197672 57.4560458,44.0453955 C59.1625767,45.3756367 63.8839488,48.777453 70.127165,53.3625321 C63.9980513,59.2416709 58.9704753,64.0315459 55.854113,66.9453198 Z M67.4952439,79.8919946 C83.5082212,96.9282402 105.237121,117.617674 112.611591,120.312493 C123.044132,124.12481 128.000001,117.170903 128,105.522947 C127.999999,98.3705516 104.170675,78.980486 84.0760493,63.7529565 C76.6683337,70.9090328 70.7000957,76.7055226 67.4952439,79.8919946 Z\"></path>\n <path d=\"M58.2852966,138.232794 L58.2852966,88.3943645 C56.318874,88.3923153 54.7254089,86.7952906 54.7254089,84.8344788 C54.7254089,82.8684071 56.3175932,81.2745911 58.2890859,81.2745911 L79.6408336,81.2745911 C81.608998,81.2745911 83.2045105,82.8724076 83.2045105,84.8344788 C83.2045105,86.7992907 81.614366,88.3923238 79.6446228,88.3943645 L79.6446228,88.3943646 L79.6446228,138.232794 C79.6446228,144.131009 74.8631748,148.912457 68.9649597,148.912457 C63.0667446,148.912457 58.2852966,144.131009 58.2852966,138.232794 Z M65.405072,-14.8423767 L72.5248474,-14.8423767 L76.0847351,-0.690681892 L72.5248474,6.51694947 L72.5248474,81.2745911 L65.405072,81.2745911 L65.405072,6.51694947 L61.8451843,-0.690681892 L65.405072,-14.8423767 Z\" transform=\"translate(68.964960, 67.035040) rotate(45.000000) translate(-68.964960, -67.035040) \"></path>\n </g>\n</svg>"
},
"$:/core/images/timestamp-off": {
"title": "$:/core/images/timestamp-off",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-timestamp-off tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M58.25 11C26.08 11 0 37.082 0 69.25s26.08 58.25 58.25 58.25c32.175 0 58.25-26.082 58.25-58.25S90.425 11 58.25 11zm0 100.5C34.914 111.5 16 92.586 16 69.25 16 45.92 34.914 27 58.25 27s42.25 18.92 42.25 42.25c0 23.336-18.914 42.25-42.25 42.25zM49.704 10c-2.762 0-5-2.24-5-5-.004-2.756 2.238-5 5-5H66.69c2.762 0 5.002 2.24 5 5 .006 2.757-2.238 5-5 5H49.705z\"/><path d=\"M58.25 35.88c-18.777 0-33.998 15.224-33.998 33.998 0 18.773 15.22 34.002 33.998 34.002 18.784 0 34.002-15.23 34.002-34.002 0-18.774-15.218-33.998-34.002-33.998zm-3.03 50.123H44.196v-34H55.22v34zm16.976 0H61.17v-34h11.025v34z\"/>\n </g>\n</svg>\n"
},
"$:/core/images/timestamp-on": {
"title": "$:/core/images/timestamp-on",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-timestamp-on tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M58.25 11C26.08 11 0 37.082 0 69.25s26.08 58.25 58.25 58.25c32.175 0 58.25-26.082 58.25-58.25S90.425 11 58.25 11zm0 100.5C34.914 111.5 16 92.586 16 69.25 16 45.92 34.914 27 58.25 27s42.25 18.92 42.25 42.25c0 23.336-18.914 42.25-42.25 42.25zM49.704 10c-2.762 0-5-2.24-5-5-.004-2.756 2.238-5 5-5H66.69c2.762 0 5.002 2.24 5 5 .006 2.757-2.238 5-5 5H49.705z\"/><path d=\"M13.41 27.178c-2.116 1.775-5.27 1.498-7.045-.613-1.772-2.11-1.498-5.27.616-7.047l9.95-8.348c2.115-1.774 5.27-1.5 7.045.618 1.775 2.108 1.498 5.27-.616 7.043l-9.95 8.348zM102.983 27.178c2.116 1.775 5.27 1.498 7.045-.613 1.772-2.11 1.498-5.27-.616-7.047l-9.95-8.348c-2.114-1.774-5.27-1.5-7.044.618-1.775 2.108-1.498 5.27.616 7.043l9.95 8.348zM65.097 71.072c0 3.826-3.09 6.928-6.897 6.928-3.804.006-6.9-3.102-6.903-6.928 0 0 4.76-39.072 6.903-39.072s6.897 39.072 6.897 39.072z\"/>\n </g>\n</svg>\n"
},
"$:/core/images/tip": {
"title": "$:/core/images/tip",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-tip tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M64,128.241818 C99.346224,128.241818 128,99.5880417 128,64.2418177 C128,28.8955937 99.346224,0.241817675 64,0.241817675 C28.653776,0.241817675 0,28.8955937 0,64.2418177 C0,99.5880417 28.653776,128.241818 64,128.241818 Z M75.9358659,91.4531941 C75.3115438,95.581915 70.2059206,98.8016748 64,98.8016748 C57.7940794,98.8016748 52.6884562,95.581915 52.0641341,91.4531941 C54.3299053,94.0502127 58.8248941,95.8192805 64,95.8192805 C69.1751059,95.8192805 73.6700947,94.0502127 75.9358659,91.4531941 L75.9358659,91.4531941 Z M75.9358659,95.9453413 C75.3115438,100.074062 70.2059206,103.293822 64,103.293822 C57.7940794,103.293822 52.6884562,100.074062 52.0641341,95.9453413 C54.3299053,98.5423599 58.8248941,100.311428 64,100.311428 C69.1751059,100.311428 73.6700947,98.5423599 75.9358659,95.9453413 L75.9358659,95.9453413 Z M75.9358659,100.40119 C75.3115438,104.529911 70.2059206,107.74967 64,107.74967 C57.7940794,107.74967 52.6884562,104.529911 52.0641341,100.40119 C54.3299053,102.998208 58.8248941,104.767276 64,104.767276 C69.1751059,104.767276 73.6700947,102.998208 75.9358659,100.40119 L75.9358659,100.40119 Z M75.9358659,104.893337 C75.3115438,109.022058 70.2059206,112.241818 64,112.241818 C57.7940794,112.241818 52.6884562,109.022058 52.0641341,104.893337 C54.3299053,107.490356 58.8248941,109.259423 64,109.259423 C69.1751059,109.259423 73.6700947,107.490356 75.9358659,104.893337 L75.9358659,104.893337 Z M64.3010456,24.2418177 C75.9193117,24.2418188 88.0000013,32.0619847 88,48.4419659 C87.9999987,64.8219472 75.9193018,71.7540963 75.9193021,83.5755932 C75.9193022,89.4486648 70.0521957,92.8368862 63.9999994,92.8368862 C57.947803,92.8368862 51.9731007,89.8295115 51.9731007,83.5755932 C51.9731007,71.1469799 39.9999998,65.4700602 40,48.4419647 C40.0000002,31.4138691 52.6827796,24.2418166 64.3010456,24.2418177 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/transcludify": {
"title": "$:/core/images/transcludify",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-transcludify-button tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\"><path d=\"M0 59.482c.591 0 1.36-.089 2.306-.266a10.417 10.417 0 0 0 2.75-.932 6.762 6.762 0 0 0 2.306-1.907c.651-.828.976-1.863.976-3.104V35.709c0-2.01.414-3.74 1.242-5.19.828-1.448 1.833-2.66 3.016-3.636s2.425-1.7 3.726-2.173c1.3-.473 2.424-.71 3.37-.71h8.073v7.451h-4.88c-1.241 0-2.232.207-2.97.621-.74.414-1.302.932-1.686 1.552a4.909 4.909 0 0 0-.71 1.996c-.089.71-.133 1.39-.133 2.04v16.677c0 1.715-.325 3.134-.976 4.258-.65 1.123-1.434 2.025-2.35 2.705-.917.68-1.863 1.168-2.839 1.464-.976.296-1.818.473-2.528.532v.178c.71.059 1.552.207 2.528.443.976.237 1.922.68 2.839 1.33.916.651 1.7 1.583 2.35 2.795.65 1.212.976 2.853.976 4.923v16.144c0 .65.044 1.33.133 2.04.089.71.325 1.375.71 1.996.384.621.946 1.139 1.685 1.553.74.414 1.73.62 2.972.62h4.879v7.452h-8.073c-.946 0-2.07-.237-3.37-.71-1.301-.473-2.543-1.197-3.726-2.173-1.183-.976-2.188-2.188-3.016-3.637-.828-1.449-1.242-3.179-1.242-5.19V74.119c0-1.42-.325-2.572-.976-3.46-.65-.886-1.419-1.581-2.306-2.084a8.868 8.868 0 0 0-2.75-1.02C1.36 67.377.591 67.288 0 67.288v-7.806zm24.66 0c.591 0 1.36-.089 2.306-.266a10.417 10.417 0 0 0 2.75-.932 6.762 6.762 0 0 0 2.306-1.907c.65-.828.976-1.863.976-3.104V35.709c0-2.01.414-3.74 1.242-5.19.828-1.448 1.833-2.66 3.016-3.636s2.425-1.7 3.726-2.173c1.3-.473 2.424-.71 3.37-.71h8.073v7.451h-4.88c-1.241 0-2.232.207-2.97.621-.74.414-1.302.932-1.686 1.552a4.909 4.909 0 0 0-.71 1.996c-.089.71-.133 1.39-.133 2.04v16.677c0 1.715-.325 3.134-.976 4.258-.65 1.123-1.434 2.025-2.35 2.705-.917.68-1.863 1.168-2.839 1.464-.976.296-1.818.473-2.528.532v.178c.71.059 1.552.207 2.528.443.976.237 1.922.68 2.839 1.33.916.651 1.7 1.583 2.35 2.795.65 1.212.976 2.853.976 4.923v16.144c0 .65.044 1.33.133 2.04.089.71.325 1.375.71 1.996.384.621.946 1.139 1.685 1.553.74.414 1.73.62 2.972.62h4.879v7.452h-8.073c-.946 0-2.07-.237-3.37-.71-1.301-.473-2.543-1.197-3.726-2.173-1.183-.976-2.188-2.188-3.016-3.637-.828-1.449-1.242-3.179-1.242-5.19V74.119c0-1.42-.325-2.572-.976-3.46-.65-.886-1.419-1.581-2.306-2.084a8.868 8.868 0 0 0-2.75-1.02c-.946-.177-1.715-.266-2.306-.266v-7.806zm43.965-3.538L80.6 52.041l2.306 7.097-12.063 3.903 7.628 10.378-6.12 4.435-7.63-10.467-7.45 10.201-5.943-4.524 7.628-10.023-12.152-4.17 2.306-7.096 12.064 4.17V43.347h7.451v12.596zm34.425 11.344c-.65 0-1.449.089-2.395.266-.946.177-1.863.488-2.75.931a6.356 6.356 0 0 0-2.262 1.908c-.62.828-.931 1.862-.931 3.104v17.564c0 2.01-.414 3.74-1.242 5.189-.828 1.449-1.833 2.661-3.016 3.637s-2.425 1.7-3.726 2.173c-1.3.473-2.424.71-3.37.71h-8.073v-7.451h4.88c1.241 0 2.232-.207 2.97-.621.74-.414 1.302-.932 1.686-1.553a4.9 4.9 0 0 0 .71-1.995c.089-.71.133-1.39.133-2.04V72.432c0-1.715.325-3.134.976-4.258.65-1.124 1.434-2.01 2.35-2.661.917-.65 1.863-1.124 2.839-1.42.976-.295 1.818-.502 2.528-.62v-.178c-.71-.059-1.552-.207-2.528-.443-.976-.237-1.922-.68-2.839-1.33-.916-.651-1.7-1.583-2.35-2.795-.65-1.212-.976-2.853-.976-4.923V37.66c0-.651-.044-1.331-.133-2.04a4.909 4.909 0 0 0-.71-1.997c-.384-.62-.946-1.138-1.685-1.552-.74-.414-1.73-.62-2.972-.62h-4.879V24h8.073c.946 0 2.07.237 3.37.71 1.301.473 2.543 1.197 3.726 2.173 1.183.976 2.188 2.188 3.016 3.637.828 1.449 1.242 3.178 1.242 5.189v16.943c0 1.419.31 2.572.931 3.46a6.897 6.897 0 0 0 2.262 2.084 8.868 8.868 0 0 0 2.75 1.02c.946.177 1.745.266 2.395.266v7.806zm24.66 0c-.65 0-1.449.089-2.395.266-.946.177-1.863.488-2.75.931a6.356 6.356 0 0 0-2.262 1.908c-.62.828-.931 1.862-.931 3.104v17.564c0 2.01-.414 3.74-1.242 5.189-.828 1.449-1.833 2.661-3.016 3.637s-2.425 1.7-3.726 2.173c-1.3.473-2.424.71-3.37.71h-8.073v-7.451h4.88c1.241 0 2.232-.207 2.97-.621.74-.414 1.302-.932 1.686-1.553a4.9 4.9 0 0 0 .71-1.995c.089-.71.133-1.39.133-2.04V72.432c0-1.715.325-3.134.976-4.258.65-1.124 1.434-2.01 2.35-2.661.917-.65 1.863-1.124 2.839-1.42.976-.295 1.818-.502 2.528-.62v-.178c-.71-.059-1.552-.207-2.528-.443-.976-.237-1.922-.68-2.839-1.33-.916-.651-1.7-1.583-2.35-2.795-.65-1.212-.976-2.853-.976-4.923V37.66c0-.651-.044-1.331-.133-2.04a4.909 4.909 0 0 0-.71-1.997c-.384-.62-.946-1.138-1.685-1.552-.74-.414-1.73-.62-2.972-.62h-4.879V24h8.073c.946 0 2.07.237 3.37.71 1.301.473 2.543 1.197 3.726 2.173 1.183.976 2.188 2.188 3.016 3.637.828 1.449 1.242 3.178 1.242 5.189v16.943c0 1.419.31 2.572.931 3.46a6.897 6.897 0 0 0 2.262 2.084 8.868 8.868 0 0 0 2.75 1.02c.946.177 1.745.266 2.395.266v7.806z\" fill-rule=\"evenodd\"/></svg>\n"
},
"$:/core/images/twitter": {
"title": "$:/core/images/twitter",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-twitter tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M41.6263422,115.803477 C27.0279663,115.803477 13.4398394,111.540813 1.99987456,104.234833 C4.02221627,104.472643 6.08004574,104.594302 8.16644978,104.594302 C20.277456,104.594302 31.4238403,100.47763 40.270894,93.5715185 C28.9590538,93.3635501 19.4123842,85.9189246 16.1230832,75.6885328 C17.7011365,75.9892376 19.320669,76.1503787 20.9862896,76.1503787 C23.344152,76.1503787 25.6278127,75.8359011 27.7971751,75.247346 C15.9709927,72.8821073 7.06079851,62.4745062 7.06079851,49.9982394 C7.06079851,49.8898938 7.06079851,49.7820074 7.06264203,49.67458 C10.5482779,51.6032228 14.5339687,52.7615103 18.7717609,52.8951059 C11.8355159,48.277565 7.2714207,40.3958845 7.2714207,31.4624258 C7.2714207,26.7434257 8.54621495,22.3200804 10.7713439,18.5169676 C23.5211299,34.0957738 42.568842,44.3472839 64.0532269,45.4210985 C63.6126256,43.5365285 63.3835682,41.5711584 63.3835682,39.5529928 C63.3835682,25.3326379 74.95811,13.8034766 89.2347917,13.8034766 C96.6697089,13.8034766 103.387958,16.930807 108.103682,21.9353619 C113.991886,20.780288 119.52429,18.6372496 124.518847,15.6866694 C122.588682,21.6993889 118.490075,26.7457211 113.152623,29.9327334 C118.381769,29.3102055 123.363882,27.926045 127.999875,25.8780385 C124.534056,31.0418981 120.151087,35.5772616 115.100763,39.2077561 C115.150538,40.3118708 115.175426,41.4224128 115.175426,42.538923 C115.175426,76.5663154 89.1744164,115.803477 41.6263422,115.803477\"></path>\n </g>\n</svg>\n"
},
"$:/core/images/underline": {
"title": "$:/core/images/underline",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-underline tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M7,117.421488 L121.247934,117.421488 L121.247934,128 L7,128 L7,117.421488 Z M104.871212,98.8958333 L104.871212,0 L88.6117424,0 L88.6117424,55.8560606 C88.6117424,60.3194668 88.0060035,64.432115 86.7945076,68.1941288 C85.5830116,71.9561425 83.7657949,75.239885 81.342803,78.0454545 C78.9198111,80.8510241 75.8911167,83.0189317 72.2566288,84.5492424 C68.6221409,86.0795531 64.3182067,86.844697 59.344697,86.844697 C53.0959284,86.844697 48.1862552,85.0593613 44.6155303,81.4886364 C41.0448054,77.9179114 39.2594697,73.0720003 39.2594697,66.9507576 L39.2594697,0 L23,0 L23,65.0378788 C23,70.3939662 23.5419769,75.2717583 24.625947,79.6714015 C25.709917,84.0710447 27.5908957,87.864883 30.2689394,91.0530303 C32.9469831,94.2411776 36.4538925,96.6960141 40.7897727,98.4176136 C45.125653,100.139213 50.545422,101 57.0492424,101 C64.3182182,101 70.630655,99.5653553 75.9867424,96.6960227 C81.3428298,93.8266902 85.742407,89.33147 89.1856061,83.2102273 L89.5681818,83.2102273 L89.5681818,98.8958333 L104.871212,98.8958333 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/unfold-all-button": {
"title": "$:/core/images/unfold-all-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-unfold-all tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <rect x=\"0\" y=\"0\" width=\"128\" height=\"16\" rx=\"8\"></rect>\n <rect x=\"0\" y=\"64\" width=\"128\" height=\"16\" rx=\"8\"></rect>\n <path d=\"M85.598226,8.34884273 C84.1490432,6.89863875 82.1463102,6 79.9340286,6 L47.9482224,6 C43.5292967,6 39.9411255,9.581722 39.9411255,14 C39.9411255,18.4092877 43.5260249,22 47.9482224,22 L71.9411255,22 L71.9411255,45.9929031 C71.9411255,50.4118288 75.5228475,54 79.9411255,54 C84.3504132,54 87.9411255,50.4151006 87.9411255,45.9929031 L87.9411255,14.0070969 C87.9411255,11.7964515 87.0447363,9.79371715 85.5956548,8.34412458 Z\" transform=\"translate(63.941125, 30.000000) scale(1, -1) rotate(-45.000000) translate(-63.941125, -30.000000) \"></path>\n <path d=\"M85.6571005,72.2899682 C84.2079177,70.8397642 82.2051847,69.9411255 79.9929031,69.9411255 L48.0070969,69.9411255 C43.5881712,69.9411255 40,73.5228475 40,77.9411255 C40,82.3504132 43.5848994,85.9411255 48.0070969,85.9411255 L72,85.9411255 L72,109.934029 C72,114.352954 75.581722,117.941125 80,117.941125 C84.4092877,117.941125 88,114.356226 88,109.934029 L88,77.9482224 C88,75.737577 87.1036108,73.7348426 85.6545293,72.2852501 Z\" transform=\"translate(64.000000, 93.941125) scale(1, -1) rotate(-45.000000) translate(-64.000000, -93.941125) \"></path>\n </g>\n</svg>"
},
"$:/core/images/unfold-button": {
"title": "$:/core/images/unfold-button",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-unfold tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <rect x=\"0\" y=\"0\" width=\"128\" height=\"16\" rx=\"8\"></rect>\n <path d=\"M85.598226,11.3488427 C84.1490432,9.89863875 82.1463102,9 79.9340286,9 L47.9482224,9 C43.5292967,9 39.9411255,12.581722 39.9411255,17 C39.9411255,21.4092877 43.5260249,25 47.9482224,25 L71.9411255,25 L71.9411255,48.9929031 C71.9411255,53.4118288 75.5228475,57 79.9411255,57 C84.3504132,57 87.9411255,53.4151006 87.9411255,48.9929031 L87.9411255,17.0070969 C87.9411255,14.7964515 87.0447363,12.7937171 85.5956548,11.3441246 Z\" transform=\"translate(63.941125, 33.000000) scale(1, -1) rotate(-45.000000) translate(-63.941125, -33.000000) \"></path>\n <path d=\"M85.6571005,53.4077172 C84.2079177,51.9575133 82.2051847,51.0588745 79.9929031,51.0588745 L48.0070969,51.0588745 C43.5881712,51.0588745 40,54.6405965 40,59.0588745 C40,63.4681622 43.5848994,67.0588745 48.0070969,67.0588745 L72,67.0588745 L72,91.0517776 C72,95.4707033 75.581722,99.0588745 80,99.0588745 C84.4092877,99.0588745 88,95.4739751 88,91.0517776 L88,59.0659714 C88,56.855326 87.1036108,54.8525917 85.6545293,53.4029991 Z\" transform=\"translate(64.000000, 75.058875) scale(1, -1) rotate(-45.000000) translate(-64.000000, -75.058875) \"></path>\n </g>\n</svg>"
},
"$:/core/images/unlocked-padlock": {
"title": "$:/core/images/unlocked-padlock",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-unlocked-padlock tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M48.6266053,64 L105,64 L105,96.0097716 C105,113.673909 90.6736461,128 73.001193,128 L55.998807,128 C38.3179793,128 24,113.677487 24,96.0097716 L24,64 L30.136303,64 C19.6806213,51.3490406 2.77158986,28.2115132 25.8366966,8.85759246 C50.4723026,-11.8141335 71.6711028,13.2108337 81.613302,25.0594855 C91.5555012,36.9081373 78.9368488,47.4964439 69.1559674,34.9513593 C59.375086,22.4062748 47.9893192,10.8049522 35.9485154,20.9083862 C23.9077117,31.0118202 34.192312,43.2685325 44.7624679,55.8655518 C47.229397,58.805523 48.403443,61.5979188 48.6266053,64 Z M67.7315279,92.3641717 C70.8232551,91.0923621 73,88.0503841 73,84.5 C73,79.8055796 69.1944204,76 64.5,76 C59.8055796,76 56,79.8055796 56,84.5 C56,87.947435 58.0523387,90.9155206 61.0018621,92.2491029 L55.9067479,115.020857 L72.8008958,115.020857 L67.7315279,92.3641717 L67.7315279,92.3641717 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/up-arrow": {
"title": "$:/core/images/up-arrow",
"created": "20150316000544368",
"modified": "20150316000831867",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-up-arrow tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n<path transform=\"rotate(-135, 63.8945, 64.1752)\" d=\"m109.07576,109.35336c-1.43248,1.43361 -3.41136,2.32182 -5.59717,2.32182l-79.16816,0c-4.36519,0 -7.91592,-3.5444 -7.91592,-7.91666c0,-4.36337 3.54408,-7.91667 7.91592,-7.91667l71.25075,0l0,-71.25074c0,-4.3652 3.54442,-7.91592 7.91667,-7.91592c4.36336,0 7.91667,3.54408 7.91667,7.91592l0,79.16815c0,2.1825 -0.88602,4.16136 -2.3185,5.59467l-0.00027,-0.00056l0.00001,-0.00001z\" />\n</svg>\n \n"
},
"$:/core/images/video": {
"title": "$:/core/images/video",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-video tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M64,12 C29.0909091,12 8.72727273,14.9166667 5.81818182,17.8333333 C2.90909091,20.75 1.93784382e-15,41.1666667 0,64.5 C1.93784382e-15,87.8333333 2.90909091,108.25 5.81818182,111.166667 C8.72727273,114.083333 29.0909091,117 64,117 C98.9090909,117 119.272727,114.083333 122.181818,111.166667 C125.090909,108.25 128,87.8333333 128,64.5 C128,41.1666667 125.090909,20.75 122.181818,17.8333333 C119.272727,14.9166667 98.9090909,12 64,12 Z M54.9161194,44.6182253 C51.102648,42.0759111 48.0112186,43.7391738 48.0112186,48.3159447 L48.0112186,79.6840553 C48.0112186,84.2685636 51.109784,85.9193316 54.9161194,83.3817747 L77.0838806,68.6032672 C80.897352,66.0609529 80.890216,61.9342897 77.0838806,59.3967328 L54.9161194,44.6182253 Z\"></path>\n </g>\n</svg>"
},
"$:/core/images/warning": {
"title": "$:/core/images/warning",
"tags": "$:/tags/Image",
"text": "<svg class=\"tc-image-warning tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n <g fill-rule=\"evenodd\">\n <path d=\"M57.0717968,11 C60.1509982,5.66666667 67.8490018,5.66666667 70.9282032,11 L126.353829,107 C129.433031,112.333333 125.584029,119 119.425626,119 L8.57437416,119 C2.41597129,119 -1.43303051,112.333333 1.64617093,107 L57.0717968,11 Z M64,37 C59.581722,37 56,40.5820489 56,44.9935776 L56,73.0064224 C56,77.4211534 59.5907123,81 64,81 C68.418278,81 72,77.4179511 72,73.0064224 L72,44.9935776 C72,40.5788466 68.4092877,37 64,37 Z M64,104 C68.418278,104 72,100.418278 72,96 C72,91.581722 68.418278,88 64,88 C59.581722,88 56,91.581722 56,96 C56,100.418278 59.581722,104 64,104 Z\"></path>\n </g>\n</svg>"
},
"$:/language/Buttons/AdvancedSearch/Caption": {
"title": "$:/language/Buttons/AdvancedSearch/Caption",
"text": "advanced search"
},
"$:/language/Buttons/AdvancedSearch/Hint": {
"title": "$:/language/Buttons/AdvancedSearch/Hint",
"text": "Advanced search"
},
"$:/language/Buttons/Cancel/Caption": {
"title": "$:/language/Buttons/Cancel/Caption",
"text": "cancel"
},
"$:/language/Buttons/Cancel/Hint": {
"title": "$:/language/Buttons/Cancel/Hint",
"text": "Discard changes to this tiddler"
},
"$:/language/Buttons/Clone/Caption": {
"title": "$:/language/Buttons/Clone/Caption",
"text": "clone"
},
"$:/language/Buttons/Clone/Hint": {
"title": "$:/language/Buttons/Clone/Hint",
"text": "Clone this tiddler"
},
"$:/language/Buttons/Close/Caption": {
"title": "$:/language/Buttons/Close/Caption",
"text": "close"
},
"$:/language/Buttons/Close/Hint": {
"title": "$:/language/Buttons/Close/Hint",
"text": "Close this tiddler"
},
"$:/language/Buttons/CloseAll/Caption": {
"title": "$:/language/Buttons/CloseAll/Caption",
"text": "close all"
},
"$:/language/Buttons/CloseAll/Hint": {
"title": "$:/language/Buttons/CloseAll/Hint",
"text": "Close all tiddlers"
},
"$:/language/Buttons/CloseOthers/Caption": {
"title": "$:/language/Buttons/CloseOthers/Caption",
"text": "close others"
},
"$:/language/Buttons/CloseOthers/Hint": {
"title": "$:/language/Buttons/CloseOthers/Hint",
"text": "Close other tiddlers"
},
"$:/language/Buttons/ControlPanel/Caption": {
"title": "$:/language/Buttons/ControlPanel/Caption",
"text": "control panel"
},
"$:/language/Buttons/ControlPanel/Hint": {
"title": "$:/language/Buttons/ControlPanel/Hint",
"text": "Open control panel"
},
"$:/language/Buttons/CopyToClipboard/Caption": {
"title": "$:/language/Buttons/CopyToClipboard/Caption",
"text": "copy to clipboard"
},
"$:/language/Buttons/CopyToClipboard/Hint": {
"title": "$:/language/Buttons/CopyToClipboard/Hint",
"text": "Copy this text to the clipboard"
},
"$:/language/Buttons/Delete/Caption": {
"title": "$:/language/Buttons/Delete/Caption",
"text": "delete"
},
"$:/language/Buttons/Delete/Hint": {
"title": "$:/language/Buttons/Delete/Hint",
"text": "Delete this tiddler"
},
"$:/language/Buttons/Edit/Caption": {
"title": "$:/language/Buttons/Edit/Caption",
"text": "edit"
},
"$:/language/Buttons/Edit/Hint": {
"title": "$:/language/Buttons/Edit/Hint",
"text": "Edit this tiddler"
},
"$:/language/Buttons/Encryption/Caption": {
"title": "$:/language/Buttons/Encryption/Caption",
"text": "encryption"
},
"$:/language/Buttons/Encryption/Hint": {
"title": "$:/language/Buttons/Encryption/Hint",
"text": "Set or clear a password for saving this wiki"
},
"$:/language/Buttons/Encryption/ClearPassword/Caption": {
"title": "$:/language/Buttons/Encryption/ClearPassword/Caption",
"text": "clear password"
},
"$:/language/Buttons/Encryption/ClearPassword/Hint": {
"title": "$:/language/Buttons/Encryption/ClearPassword/Hint",
"text": "Clear the password and save this wiki without encryption"
},
"$:/language/Buttons/Encryption/SetPassword/Caption": {
"title": "$:/language/Buttons/Encryption/SetPassword/Caption",
"text": "set password"
},
"$:/language/Buttons/Encryption/SetPassword/Hint": {
"title": "$:/language/Buttons/Encryption/SetPassword/Hint",
"text": "Set a password for saving this wiki with encryption"
},
"$:/language/Buttons/ExportPage/Caption": {
"title": "$:/language/Buttons/ExportPage/Caption",
"text": "export all"
},
"$:/language/Buttons/ExportPage/Hint": {
"title": "$:/language/Buttons/ExportPage/Hint",
"text": "Export all tiddlers"
},
"$:/language/Buttons/ExportTiddler/Caption": {
"title": "$:/language/Buttons/ExportTiddler/Caption",
"text": "export tiddler"
},
"$:/language/Buttons/ExportTiddler/Hint": {
"title": "$:/language/Buttons/ExportTiddler/Hint",
"text": "Export tiddler"
},
"$:/language/Buttons/ExportTiddlers/Caption": {
"title": "$:/language/Buttons/ExportTiddlers/Caption",
"text": "export tiddlers"
},
"$:/language/Buttons/ExportTiddlers/Hint": {
"title": "$:/language/Buttons/ExportTiddlers/Hint",
"text": "Export tiddlers"
},
"$:/language/Buttons/Fold/Caption": {
"title": "$:/language/Buttons/Fold/Caption",
"text": "fold tiddler"
},
"$:/language/Buttons/Fold/Hint": {
"title": "$:/language/Buttons/Fold/Hint",
"text": "Fold the body of this tiddler"
},
"$:/language/Buttons/Fold/FoldBar/Caption": {
"title": "$:/language/Buttons/Fold/FoldBar/Caption",
"text": "fold-bar"
},
"$:/language/Buttons/Fold/FoldBar/Hint": {
"title": "$:/language/Buttons/Fold/FoldBar/Hint",
"text": "Optional bars to fold and unfold tiddlers"
},
"$:/language/Buttons/Unfold/Caption": {
"title": "$:/language/Buttons/Unfold/Caption",
"text": "unfold tiddler"
},
"$:/language/Buttons/Unfold/Hint": {
"title": "$:/language/Buttons/Unfold/Hint",
"text": "Unfold the body of this tiddler"
},
"$:/language/Buttons/FoldOthers/Caption": {
"title": "$:/language/Buttons/FoldOthers/Caption",
"text": "fold other tiddlers"
},
"$:/language/Buttons/FoldOthers/Hint": {
"title": "$:/language/Buttons/FoldOthers/Hint",
"text": "Fold the bodies of other opened tiddlers"
},
"$:/language/Buttons/FoldAll/Caption": {
"title": "$:/language/Buttons/FoldAll/Caption",
"text": "fold all tiddlers"
},
"$:/language/Buttons/FoldAll/Hint": {
"title": "$:/language/Buttons/FoldAll/Hint",
"text": "Fold the bodies of all opened tiddlers"
},
"$:/language/Buttons/UnfoldAll/Caption": {
"title": "$:/language/Buttons/UnfoldAll/Caption",
"text": "unfold all tiddlers"
},
"$:/language/Buttons/UnfoldAll/Hint": {
"title": "$:/language/Buttons/UnfoldAll/Hint",
"text": "Unfold the bodies of all opened tiddlers"
},
"$:/language/Buttons/FullScreen/Caption": {
"title": "$:/language/Buttons/FullScreen/Caption",
"text": "full-screen"
},
"$:/language/Buttons/FullScreen/Hint": {
"title": "$:/language/Buttons/FullScreen/Hint",
"text": "Enter or leave full-screen mode"
},
"$:/language/Buttons/Help/Caption": {
"title": "$:/language/Buttons/Help/Caption",
"text": "help"
},
"$:/language/Buttons/Help/Hint": {
"title": "$:/language/Buttons/Help/Hint",
"text": "Show help panel"
},
"$:/language/Buttons/Import/Caption": {
"title": "$:/language/Buttons/Import/Caption",
"text": "import"
},
"$:/language/Buttons/Import/Hint": {
"title": "$:/language/Buttons/Import/Hint",
"text": "Import many types of file including text, image, TiddlyWiki or JSON"
},
"$:/language/Buttons/Info/Caption": {
"title": "$:/language/Buttons/Info/Caption",
"text": "info"
},
"$:/language/Buttons/Info/Hint": {
"title": "$:/language/Buttons/Info/Hint",
"text": "Show information for this tiddler"
},
"$:/language/Buttons/Home/Caption": {
"title": "$:/language/Buttons/Home/Caption",
"text": "home"
},
"$:/language/Buttons/Home/Hint": {
"title": "$:/language/Buttons/Home/Hint",
"text": "Open the default tiddlers"
},
"$:/language/Buttons/Language/Caption": {
"title": "$:/language/Buttons/Language/Caption",
"text": "language"
},
"$:/language/Buttons/Language/Hint": {
"title": "$:/language/Buttons/Language/Hint",
"text": "Choose the user interface language"
},
"$:/language/Buttons/Manager/Caption": {
"title": "$:/language/Buttons/Manager/Caption",
"text": "tiddler manager"
},
"$:/language/Buttons/Manager/Hint": {
"title": "$:/language/Buttons/Manager/Hint",
"text": "Open tiddler manager"
},
"$:/language/Buttons/More/Caption": {
"title": "$:/language/Buttons/More/Caption",
"text": "more"
},
"$:/language/Buttons/More/Hint": {
"title": "$:/language/Buttons/More/Hint",
"text": "More actions"
},
"$:/language/Buttons/NewHere/Caption": {
"title": "$:/language/Buttons/NewHere/Caption",
"text": "new here"
},
"$:/language/Buttons/NewHere/Hint": {
"title": "$:/language/Buttons/NewHere/Hint",
"text": "Create a new tiddler tagged with this one"
},
"$:/language/Buttons/NewJournal/Caption": {
"title": "$:/language/Buttons/NewJournal/Caption",
"text": "new journal"
},
"$:/language/Buttons/NewJournal/Hint": {
"title": "$:/language/Buttons/NewJournal/Hint",
"text": "Create a new journal tiddler"
},
"$:/language/Buttons/NewJournalHere/Caption": {
"title": "$:/language/Buttons/NewJournalHere/Caption",
"text": "new journal here"
},
"$:/language/Buttons/NewJournalHere/Hint": {
"title": "$:/language/Buttons/NewJournalHere/Hint",
"text": "Create a new journal tiddler tagged with this one"
},
"$:/language/Buttons/NewImage/Caption": {
"title": "$:/language/Buttons/NewImage/Caption",
"text": "new image"
},
"$:/language/Buttons/NewImage/Hint": {
"title": "$:/language/Buttons/NewImage/Hint",
"text": "Create a new image tiddler"
},
"$:/language/Buttons/NewMarkdown/Caption": {
"title": "$:/language/Buttons/NewMarkdown/Caption",
"text": "new Markdown tiddler"
},
"$:/language/Buttons/NewMarkdown/Hint": {
"title": "$:/language/Buttons/NewMarkdown/Hint",
"text": "Create a new Markdown tiddler"
},
"$:/language/Buttons/NewTiddler/Caption": {
"title": "$:/language/Buttons/NewTiddler/Caption",
"text": "new tiddler"
},
"$:/language/Buttons/NewTiddler/Hint": {
"title": "$:/language/Buttons/NewTiddler/Hint",
"text": "Create a new tiddler"
},
"$:/language/Buttons/OpenWindow/Caption": {
"title": "$:/language/Buttons/OpenWindow/Caption",
"text": "open in new window"
},
"$:/language/Buttons/OpenWindow/Hint": {
"title": "$:/language/Buttons/OpenWindow/Hint",
"text": "Open tiddler in new window"
},
"$:/language/Buttons/Palette/Caption": {
"title": "$:/language/Buttons/Palette/Caption",
"text": "palette"
},
"$:/language/Buttons/Palette/Hint": {
"title": "$:/language/Buttons/Palette/Hint",
"text": "Choose the colour palette"
},
"$:/language/Buttons/Permalink/Caption": {
"title": "$:/language/Buttons/Permalink/Caption",
"text": "permalink"
},
"$:/language/Buttons/Permalink/Hint": {
"title": "$:/language/Buttons/Permalink/Hint",
"text": "Set browser address bar to a direct link to this tiddler"
},
"$:/language/Buttons/Permaview/Caption": {
"title": "$:/language/Buttons/Permaview/Caption",
"text": "permaview"
},
"$:/language/Buttons/Permaview/Hint": {
"title": "$:/language/Buttons/Permaview/Hint",
"text": "Set browser address bar to a direct link to all the tiddlers in this story"
},
"$:/language/Buttons/Print/Caption": {
"title": "$:/language/Buttons/Print/Caption",
"text": "print page"
},
"$:/language/Buttons/Print/Hint": {
"title": "$:/language/Buttons/Print/Hint",
"text": "Print the current page"
},
"$:/language/Buttons/Refresh/Caption": {
"title": "$:/language/Buttons/Refresh/Caption",
"text": "refresh"
},
"$:/language/Buttons/Refresh/Hint": {
"title": "$:/language/Buttons/Refresh/Hint",
"text": "Perform a full refresh of the wiki"
},
"$:/language/Buttons/Save/Caption": {
"title": "$:/language/Buttons/Save/Caption",
"text": "ok"
},
"$:/language/Buttons/Save/Hint": {
"title": "$:/language/Buttons/Save/Hint",
"text": "Confirm changes to this tiddler"
},
"$:/language/Buttons/SaveWiki/Caption": {
"title": "$:/language/Buttons/SaveWiki/Caption",
"text": "save changes"
},
"$:/language/Buttons/SaveWiki/Hint": {
"title": "$:/language/Buttons/SaveWiki/Hint",
"text": "Save changes"
},
"$:/language/Buttons/StoryView/Caption": {
"title": "$:/language/Buttons/StoryView/Caption",
"text": "storyview"
},
"$:/language/Buttons/StoryView/Hint": {
"title": "$:/language/Buttons/StoryView/Hint",
"text": "Choose the story visualisation"
},
"$:/language/Buttons/HideSideBar/Caption": {
"title": "$:/language/Buttons/HideSideBar/Caption",
"text": "hide sidebar"
},
"$:/language/Buttons/HideSideBar/Hint": {
"title": "$:/language/Buttons/HideSideBar/Hint",
"text": "Hide sidebar"
},
"$:/language/Buttons/ShowSideBar/Caption": {
"title": "$:/language/Buttons/ShowSideBar/Caption",
"text": "show sidebar"
},
"$:/language/Buttons/ShowSideBar/Hint": {
"title": "$:/language/Buttons/ShowSideBar/Hint",
"text": "Show sidebar"
},
"$:/language/Buttons/TagManager/Caption": {
"title": "$:/language/Buttons/TagManager/Caption",
"text": "tag manager"
},
"$:/language/Buttons/TagManager/Hint": {
"title": "$:/language/Buttons/TagManager/Hint",
"text": "Open tag manager"
},
"$:/language/Buttons/Timestamp/Caption": {
"title": "$:/language/Buttons/Timestamp/Caption",
"text": "timestamps"
},
"$:/language/Buttons/Timestamp/Hint": {
"title": "$:/language/Buttons/Timestamp/Hint",
"text": "Choose whether modifications update timestamps"
},
"$:/language/Buttons/Timestamp/On/Caption": {
"title": "$:/language/Buttons/Timestamp/On/Caption",
"text": "timestamps are on"
},
"$:/language/Buttons/Timestamp/On/Hint": {
"title": "$:/language/Buttons/Timestamp/On/Hint",
"text": "Update timestamps when tiddlers are modified"
},
"$:/language/Buttons/Timestamp/Off/Caption": {
"title": "$:/language/Buttons/Timestamp/Off/Caption",
"text": "timestamps are off"
},
"$:/language/Buttons/Timestamp/Off/Hint": {
"title": "$:/language/Buttons/Timestamp/Off/Hint",
"text": "Don't update timestamps when tiddlers are modified"
},
"$:/language/Buttons/Theme/Caption": {
"title": "$:/language/Buttons/Theme/Caption",
"text": "theme"
},
"$:/language/Buttons/Theme/Hint": {
"title": "$:/language/Buttons/Theme/Hint",
"text": "Choose the display theme"
},
"$:/language/Buttons/Bold/Caption": {
"title": "$:/language/Buttons/Bold/Caption",
"text": "bold"
},
"$:/language/Buttons/Bold/Hint": {
"title": "$:/language/Buttons/Bold/Hint",
"text": "Apply bold formatting to selection"
},
"$:/language/Buttons/Clear/Caption": {
"title": "$:/language/Buttons/Clear/Caption",
"text": "clear"
},
"$:/language/Buttons/Clear/Hint": {
"title": "$:/language/Buttons/Clear/Hint",
"text": "Clear image to solid colour"
},
"$:/language/Buttons/EditorHeight/Caption": {
"title": "$:/language/Buttons/EditorHeight/Caption",
"text": "editor height"
},
"$:/language/Buttons/EditorHeight/Caption/Auto": {
"title": "$:/language/Buttons/EditorHeight/Caption/Auto",
"text": "Automatically adjust height to fit content"
},
"$:/language/Buttons/EditorHeight/Caption/Fixed": {
"title": "$:/language/Buttons/EditorHeight/Caption/Fixed",
"text": "Fixed height:"
},
"$:/language/Buttons/EditorHeight/Hint": {
"title": "$:/language/Buttons/EditorHeight/Hint",
"text": "Choose the height of the text editor"
},
"$:/language/Buttons/Excise/Caption": {
"title": "$:/language/Buttons/Excise/Caption",
"text": "excise"
},
"$:/language/Buttons/Excise/Caption/Excise": {
"title": "$:/language/Buttons/Excise/Caption/Excise",
"text": "Perform excision"
},
"$:/language/Buttons/Excise/Caption/MacroName": {
"title": "$:/language/Buttons/Excise/Caption/MacroName",
"text": "Macro name:"
},
"$:/language/Buttons/Excise/Caption/NewTitle": {
"title": "$:/language/Buttons/Excise/Caption/NewTitle",
"text": "Title of new tiddler:"
},
"$:/language/Buttons/Excise/Caption/Replace": {
"title": "$:/language/Buttons/Excise/Caption/Replace",
"text": "Replace excised text with:"
},
"$:/language/Buttons/Excise/Caption/Replace/Macro": {
"title": "$:/language/Buttons/Excise/Caption/Replace/Macro",
"text": "macro"
},
"$:/language/Buttons/Excise/Caption/Replace/Link": {
"title": "$:/language/Buttons/Excise/Caption/Replace/Link",
"text": "link"
},
"$:/language/Buttons/Excise/Caption/Replace/Transclusion": {
"title": "$:/language/Buttons/Excise/Caption/Replace/Transclusion",
"text": "transclusion"
},
"$:/language/Buttons/Excise/Caption/Tag": {
"title": "$:/language/Buttons/Excise/Caption/Tag",
"text": "Tag new tiddler with the title of this tiddler"
},
"$:/language/Buttons/Excise/Caption/TiddlerExists": {
"title": "$:/language/Buttons/Excise/Caption/TiddlerExists",
"text": "Warning: tiddler already exists"
},
"$:/language/Buttons/Excise/Hint": {
"title": "$:/language/Buttons/Excise/Hint",
"text": "Excise the selected text into a new tiddler"
},
"$:/language/Buttons/Heading1/Caption": {
"title": "$:/language/Buttons/Heading1/Caption",
"text": "heading 1"
},
"$:/language/Buttons/Heading1/Hint": {
"title": "$:/language/Buttons/Heading1/Hint",
"text": "Apply heading level 1 formatting to lines containing selection"
},
"$:/language/Buttons/Heading2/Caption": {
"title": "$:/language/Buttons/Heading2/Caption",
"text": "heading 2"
},
"$:/language/Buttons/Heading2/Hint": {
"title": "$:/language/Buttons/Heading2/Hint",
"text": "Apply heading level 2 formatting to lines containing selection"
},
"$:/language/Buttons/Heading3/Caption": {
"title": "$:/language/Buttons/Heading3/Caption",
"text": "heading 3"
},
"$:/language/Buttons/Heading3/Hint": {
"title": "$:/language/Buttons/Heading3/Hint",
"text": "Apply heading level 3 formatting to lines containing selection"
},
"$:/language/Buttons/Heading4/Caption": {
"title": "$:/language/Buttons/Heading4/Caption",
"text": "heading 4"
},
"$:/language/Buttons/Heading4/Hint": {
"title": "$:/language/Buttons/Heading4/Hint",
"text": "Apply heading level 4 formatting to lines containing selection"
},
"$:/language/Buttons/Heading5/Caption": {
"title": "$:/language/Buttons/Heading5/Caption",
"text": "heading 5"
},
"$:/language/Buttons/Heading5/Hint": {
"title": "$:/language/Buttons/Heading5/Hint",
"text": "Apply heading level 5 formatting to lines containing selection"
},
"$:/language/Buttons/Heading6/Caption": {
"title": "$:/language/Buttons/Heading6/Caption",
"text": "heading 6"
},
"$:/language/Buttons/Heading6/Hint": {
"title": "$:/language/Buttons/Heading6/Hint",
"text": "Apply heading level 6 formatting to lines containing selection"
},
"$:/language/Buttons/Italic/Caption": {
"title": "$:/language/Buttons/Italic/Caption",
"text": "italic"
},
"$:/language/Buttons/Italic/Hint": {
"title": "$:/language/Buttons/Italic/Hint",
"text": "Apply italic formatting to selection"
},
"$:/language/Buttons/LineWidth/Caption": {
"title": "$:/language/Buttons/LineWidth/Caption",
"text": "line width"
},
"$:/language/Buttons/LineWidth/Hint": {
"title": "$:/language/Buttons/LineWidth/Hint",
"text": "Set line width for painting"
},
"$:/language/Buttons/Link/Caption": {
"title": "$:/language/Buttons/Link/Caption",
"text": "link"
},
"$:/language/Buttons/Link/Hint": {
"title": "$:/language/Buttons/Link/Hint",
"text": "Create wikitext link"
},
"$:/language/Buttons/Linkify/Caption": {
"title": "$:/language/Buttons/Linkify/Caption",
"text": "wikilink"
},
"$:/language/Buttons/Linkify/Hint": {
"title": "$:/language/Buttons/Linkify/Hint",
"text": "Wrap selection in square brackets"
},
"$:/language/Buttons/ListBullet/Caption": {
"title": "$:/language/Buttons/ListBullet/Caption",
"text": "bulleted list"
},
"$:/language/Buttons/ListBullet/Hint": {
"title": "$:/language/Buttons/ListBullet/Hint",
"text": "Apply bulleted list formatting to lines containing selection"
},
"$:/language/Buttons/ListNumber/Caption": {
"title": "$:/language/Buttons/ListNumber/Caption",
"text": "numbered list"
},
"$:/language/Buttons/ListNumber/Hint": {
"title": "$:/language/Buttons/ListNumber/Hint",
"text": "Apply numbered list formatting to lines containing selection"
},
"$:/language/Buttons/MonoBlock/Caption": {
"title": "$:/language/Buttons/MonoBlock/Caption",
"text": "monospaced block"
},
"$:/language/Buttons/MonoBlock/Hint": {
"title": "$:/language/Buttons/MonoBlock/Hint",
"text": "Apply monospaced block formatting to lines containing selection"
},
"$:/language/Buttons/MonoLine/Caption": {
"title": "$:/language/Buttons/MonoLine/Caption",
"text": "monospaced"
},
"$:/language/Buttons/MonoLine/Hint": {
"title": "$:/language/Buttons/MonoLine/Hint",
"text": "Apply monospaced character formatting to selection"
},
"$:/language/Buttons/Opacity/Caption": {
"title": "$:/language/Buttons/Opacity/Caption",
"text": "opacity"
},
"$:/language/Buttons/Opacity/Hint": {
"title": "$:/language/Buttons/Opacity/Hint",
"text": "Set painting opacity"
},
"$:/language/Buttons/Paint/Caption": {
"title": "$:/language/Buttons/Paint/Caption",
"text": "paint colour"
},
"$:/language/Buttons/Paint/Hint": {
"title": "$:/language/Buttons/Paint/Hint",
"text": "Set painting colour"
},
"$:/language/Buttons/Picture/Caption": {
"title": "$:/language/Buttons/Picture/Caption",
"text": "picture"
},
"$:/language/Buttons/Picture/Hint": {
"title": "$:/language/Buttons/Picture/Hint",
"text": "Insert picture"
},
"$:/language/Buttons/Preview/Caption": {
"title": "$:/language/Buttons/Preview/Caption",
"text": "preview"
},
"$:/language/Buttons/Preview/Hint": {
"title": "$:/language/Buttons/Preview/Hint",
"text": "Show preview pane"
},
"$:/language/Buttons/PreviewType/Caption": {
"title": "$:/language/Buttons/PreviewType/Caption",
"text": "preview type"
},
"$:/language/Buttons/PreviewType/Hint": {
"title": "$:/language/Buttons/PreviewType/Hint",
"text": "Choose preview type"
},
"$:/language/Buttons/Quote/Caption": {
"title": "$:/language/Buttons/Quote/Caption",
"text": "quote"
},
"$:/language/Buttons/Quote/Hint": {
"title": "$:/language/Buttons/Quote/Hint",
"text": "Apply quoted text formatting to lines containing selection"
},
"$:/language/Buttons/RotateLeft/Caption": {
"title": "$:/language/Buttons/RotateLeft/Caption",
"text": "rotate left"
},
"$:/language/Buttons/RotateLeft/Hint": {
"title": "$:/language/Buttons/RotateLeft/Hint",
"text": "Rotate image left by 90 degrees"
},
"$:/language/Buttons/Size/Caption": {
"title": "$:/language/Buttons/Size/Caption",
"text": "image size"
},
"$:/language/Buttons/Size/Caption/Height": {
"title": "$:/language/Buttons/Size/Caption/Height",
"text": "Height:"
},
"$:/language/Buttons/Size/Caption/Resize": {
"title": "$:/language/Buttons/Size/Caption/Resize",
"text": "Resize image"
},
"$:/language/Buttons/Size/Caption/Width": {
"title": "$:/language/Buttons/Size/Caption/Width",
"text": "Width:"
},
"$:/language/Buttons/Size/Hint": {
"title": "$:/language/Buttons/Size/Hint",
"text": "Set image size"
},
"$:/language/Buttons/Stamp/Caption": {
"title": "$:/language/Buttons/Stamp/Caption",
"text": "stamp"
},
"$:/language/Buttons/Stamp/Caption/New": {
"title": "$:/language/Buttons/Stamp/Caption/New",
"text": "Add your own"
},
"$:/language/Buttons/Stamp/Hint": {
"title": "$:/language/Buttons/Stamp/Hint",
"text": "Insert a preconfigured snippet of text"
},
"$:/language/Buttons/Stamp/New/Title": {
"title": "$:/language/Buttons/Stamp/New/Title",
"text": "Name as shown in menu"
},
"$:/language/Buttons/Stamp/New/Text": {
"title": "$:/language/Buttons/Stamp/New/Text",
"text": "Text of snippet. (Remember to add a descriptive title in the caption field)."
},
"$:/language/Buttons/Strikethrough/Caption": {
"title": "$:/language/Buttons/Strikethrough/Caption",
"text": "strikethrough"
},
"$:/language/Buttons/Strikethrough/Hint": {
"title": "$:/language/Buttons/Strikethrough/Hint",
"text": "Apply strikethrough formatting to selection"
},
"$:/language/Buttons/Subscript/Caption": {
"title": "$:/language/Buttons/Subscript/Caption",
"text": "subscript"
},
"$:/language/Buttons/Subscript/Hint": {
"title": "$:/language/Buttons/Subscript/Hint",
"text": "Apply subscript formatting to selection"
},
"$:/language/Buttons/Superscript/Caption": {
"title": "$:/language/Buttons/Superscript/Caption",
"text": "superscript"
},
"$:/language/Buttons/Superscript/Hint": {
"title": "$:/language/Buttons/Superscript/Hint",
"text": "Apply superscript formatting to selection"
},
"$:/language/Buttons/Transcludify/Caption": {
"title": "$:/language/Buttons/Transcludify/Caption",
"text": "transclusion"
},
"$:/language/Buttons/Transcludify/Hint": {
"title": "$:/language/Buttons/Transcludify/Hint",
"text": "Wrap selection in curly brackets"
},
"$:/language/Buttons/Underline/Caption": {
"title": "$:/language/Buttons/Underline/Caption",
"text": "underline"
},
"$:/language/Buttons/Underline/Hint": {
"title": "$:/language/Buttons/Underline/Hint",
"text": "Apply underline formatting to selection"
},
"$:/language/ControlPanel/Advanced/Caption": {
"title": "$:/language/ControlPanel/Advanced/Caption",
"text": "Advanced"
},
"$:/language/ControlPanel/Advanced/Hint": {
"title": "$:/language/ControlPanel/Advanced/Hint",
"text": "Internal information about this TiddlyWiki"
},
"$:/language/ControlPanel/Appearance/Caption": {
"title": "$:/language/ControlPanel/Appearance/Caption",
"text": "Appearance"
},
"$:/language/ControlPanel/Appearance/Hint": {
"title": "$:/language/ControlPanel/Appearance/Hint",
"text": "Ways to customise the appearance of your TiddlyWiki."
},
"$:/language/ControlPanel/Basics/AnimDuration/Prompt": {
"title": "$:/language/ControlPanel/Basics/AnimDuration/Prompt",
"text": "Animation duration:"
},
"$:/language/ControlPanel/Basics/Caption": {
"title": "$:/language/ControlPanel/Basics/Caption",
"text": "Basics"
},
"$:/language/ControlPanel/Basics/DefaultTiddlers/BottomHint": {
"title": "$:/language/ControlPanel/Basics/DefaultTiddlers/BottomHint",
"text": "Use [[double square brackets]] for titles with spaces. Or you can choose to <$button set=\"$:/DefaultTiddlers\" setTo=\"[list[$:/StoryList]]\">retain story ordering</$button>"
},
"$:/language/ControlPanel/Basics/DefaultTiddlers/Prompt": {
"title": "$:/language/ControlPanel/Basics/DefaultTiddlers/Prompt",
"text": "Default tiddlers:"
},
"$:/language/ControlPanel/Basics/DefaultTiddlers/TopHint": {
"title": "$:/language/ControlPanel/Basics/DefaultTiddlers/TopHint",
"text": "Choose which tiddlers are displayed at startup:"
},
"$:/language/ControlPanel/Basics/Language/Prompt": {
"title": "$:/language/ControlPanel/Basics/Language/Prompt",
"text": "Hello! Current language:"
},
"$:/language/ControlPanel/Basics/NewJournal/Title/Prompt": {
"title": "$:/language/ControlPanel/Basics/NewJournal/Title/Prompt",
"text": "Title of new journal tiddlers"
},
"$:/language/ControlPanel/Basics/NewJournal/Text/Prompt": {
"title": "$:/language/ControlPanel/Basics/NewJournal/Text/Prompt",
"text": "Text for new journal tiddlers"
},
"$:/language/ControlPanel/Basics/NewJournal/Tags/Prompt": {
"title": "$:/language/ControlPanel/Basics/NewJournal/Tags/Prompt",
"text": "Tags for new journal tiddlers"
},
"$:/language/ControlPanel/Basics/NewTiddler/Title/Prompt": {
"title": "$:/language/ControlPanel/Basics/NewTiddler/Title/Prompt",
"text": "Title of new tiddlers"
},
"$:/language/ControlPanel/Basics/OverriddenShadowTiddlers/Prompt": {
"title": "$:/language/ControlPanel/Basics/OverriddenShadowTiddlers/Prompt",
"text": "Number of overridden shadow tiddlers:"
},
"$:/language/ControlPanel/Basics/ShadowTiddlers/Prompt": {
"title": "$:/language/ControlPanel/Basics/ShadowTiddlers/Prompt",
"text": "Number of shadow tiddlers:"
},
"$:/language/ControlPanel/Basics/Subtitle/Prompt": {
"title": "$:/language/ControlPanel/Basics/Subtitle/Prompt",
"text": "Subtitle:"
},
"$:/language/ControlPanel/Basics/SystemTiddlers/Prompt": {
"title": "$:/language/ControlPanel/Basics/SystemTiddlers/Prompt",
"text": "Number of system tiddlers:"
},
"$:/language/ControlPanel/Basics/Tags/Prompt": {
"title": "$:/language/ControlPanel/Basics/Tags/Prompt",
"text": "Number of tags:"
},
"$:/language/ControlPanel/Basics/Tiddlers/Prompt": {
"title": "$:/language/ControlPanel/Basics/Tiddlers/Prompt",
"text": "Number of tiddlers:"
},
"$:/language/ControlPanel/Basics/Title/Prompt": {
"title": "$:/language/ControlPanel/Basics/Title/Prompt",
"text": "Title of this ~TiddlyWiki:"
},
"$:/language/ControlPanel/Basics/Username/Prompt": {
"title": "$:/language/ControlPanel/Basics/Username/Prompt",
"text": "Username for signing edits:"
},
"$:/language/ControlPanel/Basics/Version/Prompt": {
"title": "$:/language/ControlPanel/Basics/Version/Prompt",
"text": "~TiddlyWiki version:"
},
"$:/language/ControlPanel/EditorTypes/Caption": {
"title": "$:/language/ControlPanel/EditorTypes/Caption",
"text": "Editor Types"
},
"$:/language/ControlPanel/EditorTypes/Editor/Caption": {
"title": "$:/language/ControlPanel/EditorTypes/Editor/Caption",
"text": "Editor"
},
"$:/language/ControlPanel/EditorTypes/Hint": {
"title": "$:/language/ControlPanel/EditorTypes/Hint",
"text": "These tiddlers determine which editor is used to edit specific tiddler types."
},
"$:/language/ControlPanel/EditorTypes/Type/Caption": {
"title": "$:/language/ControlPanel/EditorTypes/Type/Caption",
"text": "Type"
},
"$:/language/ControlPanel/Info/Caption": {
"title": "$:/language/ControlPanel/Info/Caption",
"text": "Info"
},
"$:/language/ControlPanel/Info/Hint": {
"title": "$:/language/ControlPanel/Info/Hint",
"text": "Information about this TiddlyWiki"
},
"$:/language/ControlPanel/KeyboardShortcuts/Add/Prompt": {
"title": "$:/language/ControlPanel/KeyboardShortcuts/Add/Prompt",
"text": "Type shortcut here"
},
"$:/language/ControlPanel/KeyboardShortcuts/Add/Caption": {
"title": "$:/language/ControlPanel/KeyboardShortcuts/Add/Caption",
"text": "add shortcut"
},
"$:/language/ControlPanel/KeyboardShortcuts/Caption": {
"title": "$:/language/ControlPanel/KeyboardShortcuts/Caption",
"text": "Keyboard Shortcuts"
},
"$:/language/ControlPanel/KeyboardShortcuts/Hint": {
"title": "$:/language/ControlPanel/KeyboardShortcuts/Hint",
"text": "Manage keyboard shortcut assignments"
},
"$:/language/ControlPanel/KeyboardShortcuts/NoShortcuts/Caption": {
"title": "$:/language/ControlPanel/KeyboardShortcuts/NoShortcuts/Caption",
"text": "No keyboard shortcuts assigned"
},
"$:/language/ControlPanel/KeyboardShortcuts/Remove/Hint": {
"title": "$:/language/ControlPanel/KeyboardShortcuts/Remove/Hint",
"text": "remove keyboard shortcut"
},
"$:/language/ControlPanel/KeyboardShortcuts/Platform/All": {
"title": "$:/language/ControlPanel/KeyboardShortcuts/Platform/All",
"text": "All platforms"
},
"$:/language/ControlPanel/KeyboardShortcuts/Platform/Mac": {
"title": "$:/language/ControlPanel/KeyboardShortcuts/Platform/Mac",
"text": "Macintosh platform only"
},
"$:/language/ControlPanel/KeyboardShortcuts/Platform/NonMac": {
"title": "$:/language/ControlPanel/KeyboardShortcuts/Platform/NonMac",
"text": "Non-Macintosh platforms only"
},
"$:/language/ControlPanel/KeyboardShortcuts/Platform/Linux": {
"title": "$:/language/ControlPanel/KeyboardShortcuts/Platform/Linux",
"text": "Linux platform only"
},
"$:/language/ControlPanel/KeyboardShortcuts/Platform/NonLinux": {
"title": "$:/language/ControlPanel/KeyboardShortcuts/Platform/NonLinux",
"text": "Non-Linux platforms only"
},
"$:/language/ControlPanel/KeyboardShortcuts/Platform/Windows": {
"title": "$:/language/ControlPanel/KeyboardShortcuts/Platform/Windows",
"text": "Windows platform only"
},
"$:/language/ControlPanel/KeyboardShortcuts/Platform/NonWindows": {
"title": "$:/language/ControlPanel/KeyboardShortcuts/Platform/NonWindows",
"text": "Non-Windows platforms only"
},
"$:/language/ControlPanel/LoadedModules/Caption": {
"title": "$:/language/ControlPanel/LoadedModules/Caption",
"text": "Loaded Modules"
},
"$:/language/ControlPanel/LoadedModules/Hint": {
"title": "$:/language/ControlPanel/LoadedModules/Hint",
"text": "These are the currently loaded tiddler modules linked to their source tiddlers. Any italicised modules lack a source tiddler, typically because they were setup during the boot process."
},
"$:/language/ControlPanel/Palette/Caption": {
"title": "$:/language/ControlPanel/Palette/Caption",
"text": "Palette"
},
"$:/language/ControlPanel/Palette/Editor/Clone/Caption": {
"title": "$:/language/ControlPanel/Palette/Editor/Clone/Caption",
"text": "clone"
},
"$:/language/ControlPanel/Palette/Editor/Clone/Prompt": {
"title": "$:/language/ControlPanel/Palette/Editor/Clone/Prompt",
"text": "It is recommended that you clone this shadow palette before editing it"
},
"$:/language/ControlPanel/Palette/Editor/Prompt/Modified": {
"title": "$:/language/ControlPanel/Palette/Editor/Prompt/Modified",
"text": "This shadow palette has been modified"
},
"$:/language/ControlPanel/Palette/Editor/Prompt": {
"title": "$:/language/ControlPanel/Palette/Editor/Prompt",
"text": "Editing"
},
"$:/language/ControlPanel/Palette/Editor/Reset/Caption": {
"title": "$:/language/ControlPanel/Palette/Editor/Reset/Caption",
"text": "reset"
},
"$:/language/ControlPanel/Palette/HideEditor/Caption": {
"title": "$:/language/ControlPanel/Palette/HideEditor/Caption",
"text": "hide editor"
},
"$:/language/ControlPanel/Palette/Prompt": {
"title": "$:/language/ControlPanel/Palette/Prompt",
"text": "Current palette:"
},
"$:/language/ControlPanel/Palette/ShowEditor/Caption": {
"title": "$:/language/ControlPanel/Palette/ShowEditor/Caption",
"text": "show editor"
},
"$:/language/ControlPanel/Parsing/Caption": {
"title": "$:/language/ControlPanel/Parsing/Caption",
"text": "Parsing"
},
"$:/language/ControlPanel/Parsing/Hint": {
"title": "$:/language/ControlPanel/Parsing/Hint",
"text": "Here you can globally disable/enable wiki parser rules. For changes to take effect, save and reload your wiki. Disabling certain parser rules can prevent <$text text=\"TiddlyWiki\"/> from functioning correctly. Use [[safe mode|https://tiddlywiki.com/#SafeMode]] to restore normal operation."
},
"$:/language/ControlPanel/Parsing/Block/Caption": {
"title": "$:/language/ControlPanel/Parsing/Block/Caption",
"text": "Block Parse Rules"
},
"$:/language/ControlPanel/Parsing/Inline/Caption": {
"title": "$:/language/ControlPanel/Parsing/Inline/Caption",
"text": "Inline Parse Rules"
},
"$:/language/ControlPanel/Parsing/Pragma/Caption": {
"title": "$:/language/ControlPanel/Parsing/Pragma/Caption",
"text": "Pragma Parse Rules"
},
"$:/language/ControlPanel/Plugins/Add/Caption": {
"title": "$:/language/ControlPanel/Plugins/Add/Caption",
"text": "Get more plugins"
},
"$:/language/ControlPanel/Plugins/Add/Hint": {
"title": "$:/language/ControlPanel/Plugins/Add/Hint",
"text": "Install plugins from the official library"
},
"$:/language/ControlPanel/Plugins/AlreadyInstalled/Hint": {
"title": "$:/language/ControlPanel/Plugins/AlreadyInstalled/Hint",
"text": "This plugin is already installed at version <$text text=<<installedVersion>>/>"
},
"$:/language/ControlPanel/Plugins/Caption": {
"title": "$:/language/ControlPanel/Plugins/Caption",
"text": "Plugins"
},
"$:/language/ControlPanel/Plugins/Disable/Caption": {
"title": "$:/language/ControlPanel/Plugins/Disable/Caption",
"text": "disable"
},
"$:/language/ControlPanel/Plugins/Disable/Hint": {
"title": "$:/language/ControlPanel/Plugins/Disable/Hint",
"text": "Disable this plugin when reloading page"
},
"$:/language/ControlPanel/Plugins/Disabled/Status": {
"title": "$:/language/ControlPanel/Plugins/Disabled/Status",
"text": "(disabled)"
},
"$:/language/ControlPanel/Plugins/Empty/Hint": {
"title": "$:/language/ControlPanel/Plugins/Empty/Hint",
"text": "None"
},
"$:/language/ControlPanel/Plugins/Enable/Caption": {
"title": "$:/language/ControlPanel/Plugins/Enable/Caption",
"text": "enable"
},
"$:/language/ControlPanel/Plugins/Enable/Hint": {
"title": "$:/language/ControlPanel/Plugins/Enable/Hint",
"text": "Enable this plugin when reloading page"
},
"$:/language/ControlPanel/Plugins/Install/Caption": {
"title": "$:/language/ControlPanel/Plugins/Install/Caption",
"text": "install"
},
"$:/language/ControlPanel/Plugins/Installed/Hint": {
"title": "$:/language/ControlPanel/Plugins/Installed/Hint",
"text": "Currently installed plugins:"
},
"$:/language/ControlPanel/Plugins/Languages/Caption": {
"title": "$:/language/ControlPanel/Plugins/Languages/Caption",
"text": "Languages"
},
"$:/language/ControlPanel/Plugins/Languages/Hint": {
"title": "$:/language/ControlPanel/Plugins/Languages/Hint",
"text": "Language pack plugins"
},
"$:/language/ControlPanel/Plugins/NoInfoFound/Hint": {
"title": "$:/language/ControlPanel/Plugins/NoInfoFound/Hint",
"text": "No ''\"<$text text=<<currentTab>>/>\"'' found"
},
"$:/language/ControlPanel/Plugins/NotInstalled/Hint": {
"title": "$:/language/ControlPanel/Plugins/NotInstalled/Hint",
"text": "This plugin is not currently installed"
},
"$:/language/ControlPanel/Plugins/OpenPluginLibrary": {
"title": "$:/language/ControlPanel/Plugins/OpenPluginLibrary",
"text": "open plugin library"
},
"$:/language/ControlPanel/Plugins/ClosePluginLibrary": {
"title": "$:/language/ControlPanel/Plugins/ClosePluginLibrary",
"text": "close plugin library"
},
"$:/language/ControlPanel/Plugins/Plugins/Caption": {
"title": "$:/language/ControlPanel/Plugins/Plugins/Caption",
"text": "Plugins"
},
"$:/language/ControlPanel/Plugins/Plugins/Hint": {
"title": "$:/language/ControlPanel/Plugins/Plugins/Hint",
"text": "Plugins"
},
"$:/language/ControlPanel/Plugins/Reinstall/Caption": {
"title": "$:/language/ControlPanel/Plugins/Reinstall/Caption",
"text": "reinstall"
},
"$:/language/ControlPanel/Plugins/Themes/Caption": {
"title": "$:/language/ControlPanel/Plugins/Themes/Caption",
"text": "Themes"
},
"$:/language/ControlPanel/Plugins/Themes/Hint": {
"title": "$:/language/ControlPanel/Plugins/Themes/Hint",
"text": "Theme plugins"
},
"$:/language/ControlPanel/Saving/Caption": {
"title": "$:/language/ControlPanel/Saving/Caption",
"text": "Saving"
},
"$:/language/ControlPanel/Saving/DownloadSaver/AutoSave/Description": {
"title": "$:/language/ControlPanel/Saving/DownloadSaver/AutoSave/Description",
"text": "Permit automatic saving for the download saver"
},
"$:/language/ControlPanel/Saving/DownloadSaver/AutoSave/Hint": {
"title": "$:/language/ControlPanel/Saving/DownloadSaver/AutoSave/Hint",
"text": "Enable Autosave for Download Saver"
},
"$:/language/ControlPanel/Saving/DownloadSaver/Caption": {
"title": "$:/language/ControlPanel/Saving/DownloadSaver/Caption",
"text": "Download Saver"
},
"$:/language/ControlPanel/Saving/DownloadSaver/Hint": {
"title": "$:/language/ControlPanel/Saving/DownloadSaver/Hint",
"text": "These settings apply to the HTML5-compatible download saver"
},
"$:/language/ControlPanel/Saving/General/Caption": {
"title": "$:/language/ControlPanel/Saving/General/Caption",
"text": "General"
},
"$:/language/ControlPanel/Saving/General/Hint": {
"title": "$:/language/ControlPanel/Saving/General/Hint",
"text": "These settings apply to all the loaded savers"
},
"$:/language/ControlPanel/Saving/Hint": {
"title": "$:/language/ControlPanel/Saving/Hint",
"text": "Settings used for saving the entire TiddlyWiki as a single file via a saver module"
},
"$:/language/ControlPanel/Saving/TiddlySpot/Advanced/Heading": {
"title": "$:/language/ControlPanel/Saving/TiddlySpot/Advanced/Heading",
"text": "Advanced Settings"
},
"$:/language/ControlPanel/Saving/TiddlySpot/BackupDir": {
"title": "$:/language/ControlPanel/Saving/TiddlySpot/BackupDir",
"text": "Backup Directory"
},
"$:/language/ControlPanel/Saving/TiddlySpot/Backups": {
"title": "$:/language/ControlPanel/Saving/TiddlySpot/Backups",
"text": "Backups"
},
"$:/language/ControlPanel/Saving/TiddlySpot/Caption": {
"title": "$:/language/ControlPanel/Saving/TiddlySpot/Caption",
"text": "~TiddlySpot Saver"
},
"$:/language/ControlPanel/Saving/TiddlySpot/Description": {
"title": "$:/language/ControlPanel/Saving/TiddlySpot/Description",
"text": "These settings are only used when saving to http://tiddlyspot.com or a compatible remote server"
},
"$:/language/ControlPanel/Saving/TiddlySpot/Filename": {
"title": "$:/language/ControlPanel/Saving/TiddlySpot/Filename",
"text": "Upload Filename"
},
"$:/language/ControlPanel/Saving/TiddlySpot/Heading": {
"title": "$:/language/ControlPanel/Saving/TiddlySpot/Heading",
"text": "~TiddlySpot"
},
"$:/language/ControlPanel/Saving/TiddlySpot/Hint": {
"title": "$:/language/ControlPanel/Saving/TiddlySpot/Hint",
"text": "//The server URL defaults to `http://<wikiname>.tiddlyspot.com/store.cgi` and can be changed to use a custom server address, e.g. `http://example.com/store.php`.//"
},
"$:/language/ControlPanel/Saving/TiddlySpot/Password": {
"title": "$:/language/ControlPanel/Saving/TiddlySpot/Password",
"text": "Password"
},
"$:/language/ControlPanel/Saving/TiddlySpot/ServerURL": {
"title": "$:/language/ControlPanel/Saving/TiddlySpot/ServerURL",
"text": "Server URL"
},
"$:/language/ControlPanel/Saving/TiddlySpot/UploadDir": {
"title": "$:/language/ControlPanel/Saving/TiddlySpot/UploadDir",
"text": "Upload Directory"
},
"$:/language/ControlPanel/Saving/TiddlySpot/UserName": {
"title": "$:/language/ControlPanel/Saving/TiddlySpot/UserName",
"text": "Wiki Name"
},
"$:/language/ControlPanel/Settings/AutoSave/Caption": {
"title": "$:/language/ControlPanel/Settings/AutoSave/Caption",
"text": "Autosave"
},
"$:/language/ControlPanel/Settings/AutoSave/Disabled/Description": {
"title": "$:/language/ControlPanel/Settings/AutoSave/Disabled/Description",
"text": "Do not save changes automatically"
},
"$:/language/ControlPanel/Settings/AutoSave/Enabled/Description": {
"title": "$:/language/ControlPanel/Settings/AutoSave/Enabled/Description",
"text": "Save changes automatically"
},
"$:/language/ControlPanel/Settings/AutoSave/Hint": {
"title": "$:/language/ControlPanel/Settings/AutoSave/Hint",
"text": "Attempt to automatically save changes during editing when using a supporting saver"
},
"$:/language/ControlPanel/Settings/CamelCase/Caption": {
"title": "$:/language/ControlPanel/Settings/CamelCase/Caption",
"text": "Camel Case Wiki Links"
},
"$:/language/ControlPanel/Settings/CamelCase/Hint": {
"title": "$:/language/ControlPanel/Settings/CamelCase/Hint",
"text": "You can globally disable automatic linking of ~CamelCase phrases. Requires reload to take effect"
},
"$:/language/ControlPanel/Settings/CamelCase/Description": {
"title": "$:/language/ControlPanel/Settings/CamelCase/Description",
"text": "Enable automatic ~CamelCase linking"
},
"$:/language/ControlPanel/Settings/Caption": {
"title": "$:/language/ControlPanel/Settings/Caption",
"text": "Settings"
},
"$:/language/ControlPanel/Settings/EditorToolbar/Caption": {
"title": "$:/language/ControlPanel/Settings/EditorToolbar/Caption",
"text": "Editor Toolbar"
},
"$:/language/ControlPanel/Settings/EditorToolbar/Hint": {
"title": "$:/language/ControlPanel/Settings/EditorToolbar/Hint",
"text": "Enable or disable the editor toolbar:"
},
"$:/language/ControlPanel/Settings/EditorToolbar/Description": {
"title": "$:/language/ControlPanel/Settings/EditorToolbar/Description",
"text": "Show editor toolbar"
},
"$:/language/ControlPanel/Settings/InfoPanelMode/Caption": {
"title": "$:/language/ControlPanel/Settings/InfoPanelMode/Caption",
"text": "Tiddler Info Panel Mode"
},
"$:/language/ControlPanel/Settings/InfoPanelMode/Hint": {
"title": "$:/language/ControlPanel/Settings/InfoPanelMode/Hint",
"text": "Control when the tiddler info panel closes:"
},
"$:/language/ControlPanel/Settings/InfoPanelMode/Popup/Description": {
"title": "$:/language/ControlPanel/Settings/InfoPanelMode/Popup/Description",
"text": "Tiddler info panel closes automatically"
},
"$:/language/ControlPanel/Settings/InfoPanelMode/Sticky/Description": {
"title": "$:/language/ControlPanel/Settings/InfoPanelMode/Sticky/Description",
"text": "Tiddler info panel stays open until explicitly closed"
},
"$:/language/ControlPanel/Settings/Hint": {
"title": "$:/language/ControlPanel/Settings/Hint",
"text": "These settings let you customise the behaviour of TiddlyWiki."
},
"$:/language/ControlPanel/Settings/NavigationAddressBar/Caption": {
"title": "$:/language/ControlPanel/Settings/NavigationAddressBar/Caption",
"text": "Navigation Address Bar"
},
"$:/language/ControlPanel/Settings/NavigationAddressBar/Hint": {
"title": "$:/language/ControlPanel/Settings/NavigationAddressBar/Hint",
"text": "Behaviour of the browser address bar when navigating to a tiddler:"
},
"$:/language/ControlPanel/Settings/NavigationAddressBar/No/Description": {
"title": "$:/language/ControlPanel/Settings/NavigationAddressBar/No/Description",
"text": "Do not update the address bar"
},
"$:/language/ControlPanel/Settings/NavigationAddressBar/Permalink/Description": {
"title": "$:/language/ControlPanel/Settings/NavigationAddressBar/Permalink/Description",
"text": "Include the target tiddler"
},
"$:/language/ControlPanel/Settings/NavigationAddressBar/Permaview/Description": {
"title": "$:/language/ControlPanel/Settings/NavigationAddressBar/Permaview/Description",
"text": "Include the target tiddler and the current story sequence"
},
"$:/language/ControlPanel/Settings/NavigationHistory/Caption": {
"title": "$:/language/ControlPanel/Settings/NavigationHistory/Caption",
"text": "Navigation History"
},
"$:/language/ControlPanel/Settings/NavigationHistory/Hint": {
"title": "$:/language/ControlPanel/Settings/NavigationHistory/Hint",
"text": "Update browser history when navigating to a tiddler:"
},
"$:/language/ControlPanel/Settings/NavigationHistory/No/Description": {
"title": "$:/language/ControlPanel/Settings/NavigationHistory/No/Description",
"text": "Do not update history"
},
"$:/language/ControlPanel/Settings/NavigationHistory/Yes/Description": {
"title": "$:/language/ControlPanel/Settings/NavigationHistory/Yes/Description",
"text": "Update history"
},
"$:/language/ControlPanel/Settings/NavigationPermalinkviewMode/Caption": {
"title": "$:/language/ControlPanel/Settings/NavigationPermalinkviewMode/Caption",
"text": "Permalink/permaview Mode"
},
"$:/language/ControlPanel/Settings/NavigationPermalinkviewMode/Hint": {
"title": "$:/language/ControlPanel/Settings/NavigationPermalinkviewMode/Hint",
"text": "Choose how permalink/permaview is handled:"
},
"$:/language/ControlPanel/Settings/NavigationPermalinkviewMode/CopyToClipboard/Description": {
"title": "$:/language/ControlPanel/Settings/NavigationPermalinkviewMode/CopyToClipboard/Description",
"text": "Copy permalink/permaview URL to clipboard"
},
"$:/language/ControlPanel/Settings/NavigationPermalinkviewMode/UpdateAddressBar/Description": {
"title": "$:/language/ControlPanel/Settings/NavigationPermalinkviewMode/UpdateAddressBar/Description",
"text": "Update address bar with permalink/permaview URL"
},
"$:/language/ControlPanel/Settings/PerformanceInstrumentation/Caption": {
"title": "$:/language/ControlPanel/Settings/PerformanceInstrumentation/Caption",
"text": "Performance Instrumentation"
},
"$:/language/ControlPanel/Settings/PerformanceInstrumentation/Hint": {
"title": "$:/language/ControlPanel/Settings/PerformanceInstrumentation/Hint",
"text": "Displays performance statistics in the browser developer console. Requires reload to take effect"
},
"$:/language/ControlPanel/Settings/PerformanceInstrumentation/Description": {
"title": "$:/language/ControlPanel/Settings/PerformanceInstrumentation/Description",
"text": "Enable performance instrumentation"
},
"$:/language/ControlPanel/Settings/ToolbarButtonStyle/Caption": {
"title": "$:/language/ControlPanel/Settings/ToolbarButtonStyle/Caption",
"text": "Toolbar Button Style"
},
"$:/language/ControlPanel/Settings/ToolbarButtonStyle/Hint": {
"title": "$:/language/ControlPanel/Settings/ToolbarButtonStyle/Hint",
"text": "Choose the style for toolbar buttons:"
},
"$:/language/ControlPanel/Settings/ToolbarButtonStyle/Styles/Borderless": {
"title": "$:/language/ControlPanel/Settings/ToolbarButtonStyle/Styles/Borderless",
"text": "Borderless"
},
"$:/language/ControlPanel/Settings/ToolbarButtonStyle/Styles/Boxed": {
"title": "$:/language/ControlPanel/Settings/ToolbarButtonStyle/Styles/Boxed",
"text": "Boxed"
},
"$:/language/ControlPanel/Settings/ToolbarButtonStyle/Styles/Rounded": {
"title": "$:/language/ControlPanel/Settings/ToolbarButtonStyle/Styles/Rounded",
"text": "Rounded"
},
"$:/language/ControlPanel/Settings/ToolbarButtons/Caption": {
"title": "$:/language/ControlPanel/Settings/ToolbarButtons/Caption",
"text": "Toolbar Buttons"
},
"$:/language/ControlPanel/Settings/ToolbarButtons/Hint": {
"title": "$:/language/ControlPanel/Settings/ToolbarButtons/Hint",
"text": "Default toolbar button appearance:"
},
"$:/language/ControlPanel/Settings/ToolbarButtons/Icons/Description": {
"title": "$:/language/ControlPanel/Settings/ToolbarButtons/Icons/Description",
"text": "Include icon"
},
"$:/language/ControlPanel/Settings/ToolbarButtons/Text/Description": {
"title": "$:/language/ControlPanel/Settings/ToolbarButtons/Text/Description",
"text": "Include text"
},
"$:/language/ControlPanel/Settings/DefaultSidebarTab/Caption": {
"title": "$:/language/ControlPanel/Settings/DefaultSidebarTab/Caption",
"text": "Default Sidebar Tab"
},
"$:/language/ControlPanel/Settings/DefaultSidebarTab/Hint": {
"title": "$:/language/ControlPanel/Settings/DefaultSidebarTab/Hint",
"text": "Specify which sidebar tab is displayed by default"
},
"$:/language/ControlPanel/Settings/DefaultMoreSidebarTab/Caption": {
"title": "$:/language/ControlPanel/Settings/DefaultMoreSidebarTab/Caption",
"text": "Default More Sidebar Tab"
},
"$:/language/ControlPanel/Settings/DefaultMoreSidebarTab/Hint": {
"title": "$:/language/ControlPanel/Settings/DefaultMoreSidebarTab/Hint",
"text": "Specify which More sidebar tab is displayed by default"
},
"$:/language/ControlPanel/Settings/LinkToBehaviour/Caption": {
"title": "$:/language/ControlPanel/Settings/LinkToBehaviour/Caption",
"text": "Tiddler Opening Behaviour"
},
"$:/language/ControlPanel/Settings/LinkToBehaviour/InsideRiver/Hint": {
"title": "$:/language/ControlPanel/Settings/LinkToBehaviour/InsideRiver/Hint",
"text": "Navigation from //within// the story river"
},
"$:/language/ControlPanel/Settings/LinkToBehaviour/OutsideRiver/Hint": {
"title": "$:/language/ControlPanel/Settings/LinkToBehaviour/OutsideRiver/Hint",
"text": "Navigation from //outside// the story river"
},
"$:/language/ControlPanel/Settings/LinkToBehaviour/OpenAbove": {
"title": "$:/language/ControlPanel/Settings/LinkToBehaviour/OpenAbove",
"text": "Open above the current tiddler"
},
"$:/language/ControlPanel/Settings/LinkToBehaviour/OpenBelow": {
"title": "$:/language/ControlPanel/Settings/LinkToBehaviour/OpenBelow",
"text": "Open below the current tiddler"
},
"$:/language/ControlPanel/Settings/LinkToBehaviour/OpenAtTop": {
"title": "$:/language/ControlPanel/Settings/LinkToBehaviour/OpenAtTop",
"text": "Open at the top of the story river"
},
"$:/language/ControlPanel/Settings/LinkToBehaviour/OpenAtBottom": {
"title": "$:/language/ControlPanel/Settings/LinkToBehaviour/OpenAtBottom",
"text": "Open at the bottom of the story river"
},
"$:/language/ControlPanel/Settings/TitleLinks/Caption": {
"title": "$:/language/ControlPanel/Settings/TitleLinks/Caption",
"text": "Tiddler Titles"
},
"$:/language/ControlPanel/Settings/TitleLinks/Hint": {
"title": "$:/language/ControlPanel/Settings/TitleLinks/Hint",
"text": "Optionally display tiddler titles as links"
},
"$:/language/ControlPanel/Settings/TitleLinks/No/Description": {
"title": "$:/language/ControlPanel/Settings/TitleLinks/No/Description",
"text": "Do not display tiddler titles as links"
},
"$:/language/ControlPanel/Settings/TitleLinks/Yes/Description": {
"title": "$:/language/ControlPanel/Settings/TitleLinks/Yes/Description",
"text": "Display tiddler titles as links"
},
"$:/language/ControlPanel/Settings/MissingLinks/Caption": {
"title": "$:/language/ControlPanel/Settings/MissingLinks/Caption",
"text": "Wiki Links"
},
"$:/language/ControlPanel/Settings/MissingLinks/Hint": {
"title": "$:/language/ControlPanel/Settings/MissingLinks/Hint",
"text": "Choose whether to link to tiddlers that do not exist yet"
},
"$:/language/ControlPanel/Settings/MissingLinks/Description": {
"title": "$:/language/ControlPanel/Settings/MissingLinks/Description",
"text": "Enable links to missing tiddlers"
},
"$:/language/ControlPanel/StoryView/Caption": {
"title": "$:/language/ControlPanel/StoryView/Caption",
"text": "Story View"
},
"$:/language/ControlPanel/StoryView/Prompt": {
"title": "$:/language/ControlPanel/StoryView/Prompt",
"text": "Current view:"
},
"$:/language/ControlPanel/Stylesheets/Caption": {
"title": "$:/language/ControlPanel/Stylesheets/Caption",
"text": "Stylesheets"
},
"$:/language/ControlPanel/Stylesheets/Expand/Caption": {
"title": "$:/language/ControlPanel/Stylesheets/Expand/Caption",
"text": "Expand All"
},
"$:/language/ControlPanel/Stylesheets/Hint": {
"title": "$:/language/ControlPanel/Stylesheets/Hint",
"text": "This is the rendered CSS of the current stylesheet tiddlers tagged with <<tag \"$:/tags/Stylesheet\">>"
},
"$:/language/ControlPanel/Stylesheets/Restore/Caption": {
"title": "$:/language/ControlPanel/Stylesheets/Restore/Caption",
"text": "Restore"
},
"$:/language/ControlPanel/Theme/Caption": {
"title": "$:/language/ControlPanel/Theme/Caption",
"text": "Theme"
},
"$:/language/ControlPanel/Theme/Prompt": {
"title": "$:/language/ControlPanel/Theme/Prompt",
"text": "Current theme:"
},
"$:/language/ControlPanel/TiddlerFields/Caption": {
"title": "$:/language/ControlPanel/TiddlerFields/Caption",
"text": "Tiddler Fields"
},
"$:/language/ControlPanel/TiddlerFields/Hint": {
"title": "$:/language/ControlPanel/TiddlerFields/Hint",
"text": "This is the full set of TiddlerFields in use in this wiki (including system tiddlers but excluding shadow tiddlers)."
},
"$:/language/ControlPanel/Toolbars/Caption": {
"title": "$:/language/ControlPanel/Toolbars/Caption",
"text": "Toolbars"
},
"$:/language/ControlPanel/Toolbars/EditToolbar/Caption": {
"title": "$:/language/ControlPanel/Toolbars/EditToolbar/Caption",
"text": "Edit Toolbar"
},
"$:/language/ControlPanel/Toolbars/EditToolbar/Hint": {
"title": "$:/language/ControlPanel/Toolbars/EditToolbar/Hint",
"text": "Choose which buttons are displayed for tiddlers in edit mode. Drag and drop to change the ordering"
},
"$:/language/ControlPanel/Toolbars/Hint": {
"title": "$:/language/ControlPanel/Toolbars/Hint",
"text": "Select which toolbar buttons are displayed"
},
"$:/language/ControlPanel/Toolbars/PageControls/Caption": {
"title": "$:/language/ControlPanel/Toolbars/PageControls/Caption",
"text": "Page Toolbar"
},
"$:/language/ControlPanel/Toolbars/PageControls/Hint": {
"title": "$:/language/ControlPanel/Toolbars/PageControls/Hint",
"text": "Choose which buttons are displayed on the main page toolbar. Drag and drop to change the ordering"
},
"$:/language/ControlPanel/Toolbars/EditorToolbar/Caption": {
"title": "$:/language/ControlPanel/Toolbars/EditorToolbar/Caption",
"text": "Editor Toolbar"
},
"$:/language/ControlPanel/Toolbars/EditorToolbar/Hint": {
"title": "$:/language/ControlPanel/Toolbars/EditorToolbar/Hint",
"text": "Choose which buttons are displayed in the editor toolbar. Note that some buttons will only appear when editing tiddlers of a certain type. Drag and drop to change the ordering"
},
"$:/language/ControlPanel/Toolbars/ViewToolbar/Caption": {
"title": "$:/language/ControlPanel/Toolbars/ViewToolbar/Caption",
"text": "View Toolbar"
},
"$:/language/ControlPanel/Toolbars/ViewToolbar/Hint": {
"title": "$:/language/ControlPanel/Toolbars/ViewToolbar/Hint",
"text": "Choose which buttons are displayed for tiddlers in view mode. Drag and drop to change the ordering"
},
"$:/language/ControlPanel/Tools/Download/Full/Caption": {
"title": "$:/language/ControlPanel/Tools/Download/Full/Caption",
"text": "Download full wiki"
},
"$:/language/Date/DaySuffix/1": {
"title": "$:/language/Date/DaySuffix/1",
"text": "st"
},
"$:/language/Date/DaySuffix/2": {
"title": "$:/language/Date/DaySuffix/2",
"text": "nd"
},
"$:/language/Date/DaySuffix/3": {
"title": "$:/language/Date/DaySuffix/3",
"text": "rd"
},
"$:/language/Date/DaySuffix/4": {
"title": "$:/language/Date/DaySuffix/4",
"text": "th"
},
"$:/language/Date/DaySuffix/5": {
"title": "$:/language/Date/DaySuffix/5",
"text": "th"
},
"$:/language/Date/DaySuffix/6": {
"title": "$:/language/Date/DaySuffix/6",
"text": "th"
},
"$:/language/Date/DaySuffix/7": {
"title": "$:/language/Date/DaySuffix/7",
"text": "th"
},
"$:/language/Date/DaySuffix/8": {
"title": "$:/language/Date/DaySuffix/8",
"text": "th"
},
"$:/language/Date/DaySuffix/9": {
"title": "$:/language/Date/DaySuffix/9",
"text": "th"
},
"$:/language/Date/DaySuffix/10": {
"title": "$:/language/Date/DaySuffix/10",
"text": "th"
},
"$:/language/Date/DaySuffix/11": {
"title": "$:/language/Date/DaySuffix/11",
"text": "th"
},
"$:/language/Date/DaySuffix/12": {
"title": "$:/language/Date/DaySuffix/12",
"text": "th"
},
"$:/language/Date/DaySuffix/13": {
"title": "$:/language/Date/DaySuffix/13",
"text": "th"
},
"$:/language/Date/DaySuffix/14": {
"title": "$:/language/Date/DaySuffix/14",
"text": "th"
},
"$:/language/Date/DaySuffix/15": {
"title": "$:/language/Date/DaySuffix/15",
"text": "th"
},
"$:/language/Date/DaySuffix/16": {
"title": "$:/language/Date/DaySuffix/16",
"text": "th"
},
"$:/language/Date/DaySuffix/17": {
"title": "$:/language/Date/DaySuffix/17",
"text": "th"
},
"$:/language/Date/DaySuffix/18": {
"title": "$:/language/Date/DaySuffix/18",
"text": "th"
},
"$:/language/Date/DaySuffix/19": {
"title": "$:/language/Date/DaySuffix/19",
"text": "th"
},
"$:/language/Date/DaySuffix/20": {
"title": "$:/language/Date/DaySuffix/20",
"text": "th"
},
"$:/language/Date/DaySuffix/21": {
"title": "$:/language/Date/DaySuffix/21",
"text": "st"
},
"$:/language/Date/DaySuffix/22": {
"title": "$:/language/Date/DaySuffix/22",
"text": "nd"
},
"$:/language/Date/DaySuffix/23": {
"title": "$:/language/Date/DaySuffix/23",
"text": "rd"
},
"$:/language/Date/DaySuffix/24": {
"title": "$:/language/Date/DaySuffix/24",
"text": "th"
},
"$:/language/Date/DaySuffix/25": {
"title": "$:/language/Date/DaySuffix/25",
"text": "th"
},
"$:/language/Date/DaySuffix/26": {
"title": "$:/language/Date/DaySuffix/26",
"text": "th"
},
"$:/language/Date/DaySuffix/27": {
"title": "$:/language/Date/DaySuffix/27",
"text": "th"
},
"$:/language/Date/DaySuffix/28": {
"title": "$:/language/Date/DaySuffix/28",
"text": "th"
},
"$:/language/Date/DaySuffix/29": {
"title": "$:/language/Date/DaySuffix/29",
"text": "th"
},
"$:/language/Date/DaySuffix/30": {
"title": "$:/language/Date/DaySuffix/30",
"text": "th"
},
"$:/language/Date/DaySuffix/31": {
"title": "$:/language/Date/DaySuffix/31",
"text": "st"
},
"$:/language/Date/Long/Day/0": {
"title": "$:/language/Date/Long/Day/0",
"text": "Sunday"
},
"$:/language/Date/Long/Day/1": {
"title": "$:/language/Date/Long/Day/1",
"text": "Monday"
},
"$:/language/Date/Long/Day/2": {
"title": "$:/language/Date/Long/Day/2",
"text": "Tuesday"
},
"$:/language/Date/Long/Day/3": {
"title": "$:/language/Date/Long/Day/3",
"text": "Wednesday"
},
"$:/language/Date/Long/Day/4": {
"title": "$:/language/Date/Long/Day/4",
"text": "Thursday"
},
"$:/language/Date/Long/Day/5": {
"title": "$:/language/Date/Long/Day/5",
"text": "Friday"
},
"$:/language/Date/Long/Day/6": {
"title": "$:/language/Date/Long/Day/6",
"text": "Saturday"
},
"$:/language/Date/Long/Month/1": {
"title": "$:/language/Date/Long/Month/1",
"text": "January"
},
"$:/language/Date/Long/Month/2": {
"title": "$:/language/Date/Long/Month/2",
"text": "February"
},
"$:/language/Date/Long/Month/3": {
"title": "$:/language/Date/Long/Month/3",
"text": "March"
},
"$:/language/Date/Long/Month/4": {
"title": "$:/language/Date/Long/Month/4",
"text": "April"
},
"$:/language/Date/Long/Month/5": {
"title": "$:/language/Date/Long/Month/5",
"text": "May"
},
"$:/language/Date/Long/Month/6": {
"title": "$:/language/Date/Long/Month/6",
"text": "June"
},
"$:/language/Date/Long/Month/7": {
"title": "$:/language/Date/Long/Month/7",
"text": "July"
},
"$:/language/Date/Long/Month/8": {
"title": "$:/language/Date/Long/Month/8",
"text": "August"
},
"$:/language/Date/Long/Month/9": {
"title": "$:/language/Date/Long/Month/9",
"text": "September"
},
"$:/language/Date/Long/Month/10": {
"title": "$:/language/Date/Long/Month/10",
"text": "October"
},
"$:/language/Date/Long/Month/11": {
"title": "$:/language/Date/Long/Month/11",
"text": "November"
},
"$:/language/Date/Long/Month/12": {
"title": "$:/language/Date/Long/Month/12",
"text": "December"
},
"$:/language/Date/Period/am": {
"title": "$:/language/Date/Period/am",
"text": "am"
},
"$:/language/Date/Period/pm": {
"title": "$:/language/Date/Period/pm",
"text": "pm"
},
"$:/language/Date/Short/Day/0": {
"title": "$:/language/Date/Short/Day/0",
"text": "Sun"
},
"$:/language/Date/Short/Day/1": {
"title": "$:/language/Date/Short/Day/1",
"text": "Mon"
},
"$:/language/Date/Short/Day/2": {
"title": "$:/language/Date/Short/Day/2",
"text": "Tue"
},
"$:/language/Date/Short/Day/3": {
"title": "$:/language/Date/Short/Day/3",
"text": "Wed"
},
"$:/language/Date/Short/Day/4": {
"title": "$:/language/Date/Short/Day/4",
"text": "Thu"
},
"$:/language/Date/Short/Day/5": {
"title": "$:/language/Date/Short/Day/5",
"text": "Fri"
},
"$:/language/Date/Short/Day/6": {
"title": "$:/language/Date/Short/Day/6",
"text": "Sat"
},
"$:/language/Date/Short/Month/1": {
"title": "$:/language/Date/Short/Month/1",
"text": "Jan"
},
"$:/language/Date/Short/Month/2": {
"title": "$:/language/Date/Short/Month/2",
"text": "Feb"
},
"$:/language/Date/Short/Month/3": {
"title": "$:/language/Date/Short/Month/3",
"text": "Mar"
},
"$:/language/Date/Short/Month/4": {
"title": "$:/language/Date/Short/Month/4",
"text": "Apr"
},
"$:/language/Date/Short/Month/5": {
"title": "$:/language/Date/Short/Month/5",
"text": "May"
},
"$:/language/Date/Short/Month/6": {
"title": "$:/language/Date/Short/Month/6",
"text": "Jun"
},
"$:/language/Date/Short/Month/7": {
"title": "$:/language/Date/Short/Month/7",
"text": "Jul"
},
"$:/language/Date/Short/Month/8": {
"title": "$:/language/Date/Short/Month/8",
"text": "Aug"
},
"$:/language/Date/Short/Month/9": {
"title": "$:/language/Date/Short/Month/9",
"text": "Sep"
},
"$:/language/Date/Short/Month/10": {
"title": "$:/language/Date/Short/Month/10",
"text": "Oct"
},
"$:/language/Date/Short/Month/11": {
"title": "$:/language/Date/Short/Month/11",
"text": "Nov"
},
"$:/language/Date/Short/Month/12": {
"title": "$:/language/Date/Short/Month/12",
"text": "Dec"
},
"$:/language/RelativeDate/Future/Days": {
"title": "$:/language/RelativeDate/Future/Days",
"text": "<<period>> days from now"
},
"$:/language/RelativeDate/Future/Hours": {
"title": "$:/language/RelativeDate/Future/Hours",
"text": "<<period>> hours from now"
},
"$:/language/RelativeDate/Future/Minutes": {
"title": "$:/language/RelativeDate/Future/Minutes",
"text": "<<period>> minutes from now"
},
"$:/language/RelativeDate/Future/Months": {
"title": "$:/language/RelativeDate/Future/Months",
"text": "<<period>> months from now"
},
"$:/language/RelativeDate/Future/Second": {
"title": "$:/language/RelativeDate/Future/Second",
"text": "1 second from now"
},
"$:/language/RelativeDate/Future/Seconds": {
"title": "$:/language/RelativeDate/Future/Seconds",
"text": "<<period>> seconds from now"
},
"$:/language/RelativeDate/Future/Years": {
"title": "$:/language/RelativeDate/Future/Years",
"text": "<<period>> years from now"
},
"$:/language/RelativeDate/Past/Days": {
"title": "$:/language/RelativeDate/Past/Days",
"text": "<<period>> days ago"
},
"$:/language/RelativeDate/Past/Hours": {
"title": "$:/language/RelativeDate/Past/Hours",
"text": "<<period>> hours ago"
},
"$:/language/RelativeDate/Past/Minutes": {
"title": "$:/language/RelativeDate/Past/Minutes",
"text": "<<period>> minutes ago"
},
"$:/language/RelativeDate/Past/Months": {
"title": "$:/language/RelativeDate/Past/Months",
"text": "<<period>> months ago"
},
"$:/language/RelativeDate/Past/Second": {
"title": "$:/language/RelativeDate/Past/Second",
"text": "1 second ago"
},
"$:/language/RelativeDate/Past/Seconds": {
"title": "$:/language/RelativeDate/Past/Seconds",
"text": "<<period>> seconds ago"
},
"$:/language/RelativeDate/Past/Years": {
"title": "$:/language/RelativeDate/Past/Years",
"text": "<<period>> years ago"
},
"$:/language/Docs/ModuleTypes/allfilteroperator": {
"title": "$:/language/Docs/ModuleTypes/allfilteroperator",
"text": "A sub-operator for the ''all'' filter operator."
},
"$:/language/Docs/ModuleTypes/animation": {
"title": "$:/language/Docs/ModuleTypes/animation",
"text": "Animations that may be used with the RevealWidget."
},
"$:/language/Docs/ModuleTypes/authenticator": {
"title": "$:/language/Docs/ModuleTypes/authenticator",
"text": "Defines how requests are authenticated by the built-in HTTP server."
},
"$:/language/Docs/ModuleTypes/bitmapeditoroperation": {
"title": "$:/language/Docs/ModuleTypes/bitmapeditoroperation",
"text": "A bitmap editor toolbar operation."
},
"$:/language/Docs/ModuleTypes/command": {
"title": "$:/language/Docs/ModuleTypes/command",
"text": "Commands that can be executed under Node.js."
},
"$:/language/Docs/ModuleTypes/config": {
"title": "$:/language/Docs/ModuleTypes/config",
"text": "Data to be inserted into `$tw.config`."
},
"$:/language/Docs/ModuleTypes/filteroperator": {
"title": "$:/language/Docs/ModuleTypes/filteroperator",
"text": "Individual filter operator methods."
},
"$:/language/Docs/ModuleTypes/global": {
"title": "$:/language/Docs/ModuleTypes/global",
"text": "Global data to be inserted into `$tw`."
},
"$:/language/Docs/ModuleTypes/info": {
"title": "$:/language/Docs/ModuleTypes/info",
"text": "Publishes system information via the [[$:/temp/info-plugin]] pseudo-plugin."
},
"$:/language/Docs/ModuleTypes/isfilteroperator": {
"title": "$:/language/Docs/ModuleTypes/isfilteroperator",
"text": "Operands for the ''is'' filter operator."
},
"$:/language/Docs/ModuleTypes/library": {
"title": "$:/language/Docs/ModuleTypes/library",
"text": "Generic module type for general purpose JavaScript modules."
},
"$:/language/Docs/ModuleTypes/macro": {
"title": "$:/language/Docs/ModuleTypes/macro",
"text": "JavaScript macro definitions."
},
"$:/language/Docs/ModuleTypes/parser": {
"title": "$:/language/Docs/ModuleTypes/parser",
"text": "Parsers for different content types."
},
"$:/language/Docs/ModuleTypes/route": {
"title": "$:/language/Docs/ModuleTypes/route",
"text": "Defines how individual URL patterns are handled by the built-in HTTP server."
},
"$:/language/Docs/ModuleTypes/saver": {
"title": "$:/language/Docs/ModuleTypes/saver",
"text": "Savers handle different methods for saving files from the browser."
},
"$:/language/Docs/ModuleTypes/startup": {
"title": "$:/language/Docs/ModuleTypes/startup",
"text": "Startup functions."
},
"$:/language/Docs/ModuleTypes/storyview": {
"title": "$:/language/Docs/ModuleTypes/storyview",
"text": "Story views customise the animation and behaviour of list widgets."
},
"$:/language/Docs/ModuleTypes/texteditoroperation": {
"title": "$:/language/Docs/ModuleTypes/texteditoroperation",
"text": "A text editor toolbar operation."
},
"$:/language/Docs/ModuleTypes/tiddlerdeserializer": {
"title": "$:/language/Docs/ModuleTypes/tiddlerdeserializer",
"text": "Converts different content types into tiddlers."
},
"$:/language/Docs/ModuleTypes/tiddlerfield": {
"title": "$:/language/Docs/ModuleTypes/tiddlerfield",
"text": "Defines the behaviour of an individual tiddler field."
},
"$:/language/Docs/ModuleTypes/tiddlermethod": {
"title": "$:/language/Docs/ModuleTypes/tiddlermethod",
"text": "Adds methods to the `$tw.Tiddler` prototype."
},
"$:/language/Docs/ModuleTypes/upgrader": {
"title": "$:/language/Docs/ModuleTypes/upgrader",
"text": "Applies upgrade processing to tiddlers during an upgrade/import."
},
"$:/language/Docs/ModuleTypes/utils": {
"title": "$:/language/Docs/ModuleTypes/utils",
"text": "Adds methods to `$tw.utils`."
},
"$:/language/Docs/ModuleTypes/utils-node": {
"title": "$:/language/Docs/ModuleTypes/utils-node",
"text": "Adds Node.js-specific methods to `$tw.utils`."
},
"$:/language/Docs/ModuleTypes/widget": {
"title": "$:/language/Docs/ModuleTypes/widget",
"text": "Widgets encapsulate DOM rendering and refreshing."
},
"$:/language/Docs/ModuleTypes/wikimethod": {
"title": "$:/language/Docs/ModuleTypes/wikimethod",
"text": "Adds methods to `$tw.Wiki`."
},
"$:/language/Docs/ModuleTypes/wikirule": {
"title": "$:/language/Docs/ModuleTypes/wikirule",
"text": "Individual parser rules for the main WikiText parser."
},
"$:/language/Docs/PaletteColours/alert-background": {
"title": "$:/language/Docs/PaletteColours/alert-background",
"text": "Alert background"
},
"$:/language/Docs/PaletteColours/alert-border": {
"title": "$:/language/Docs/PaletteColours/alert-border",
"text": "Alert border"
},
"$:/language/Docs/PaletteColours/alert-highlight": {
"title": "$:/language/Docs/PaletteColours/alert-highlight",
"text": "Alert highlight"
},
"$:/language/Docs/PaletteColours/alert-muted-foreground": {
"title": "$:/language/Docs/PaletteColours/alert-muted-foreground",
"text": "Alert muted foreground"
},
"$:/language/Docs/PaletteColours/background": {
"title": "$:/language/Docs/PaletteColours/background",
"text": "General background"
},
"$:/language/Docs/PaletteColours/blockquote-bar": {
"title": "$:/language/Docs/PaletteColours/blockquote-bar",
"text": "Blockquote bar"
},
"$:/language/Docs/PaletteColours/button-background": {
"title": "$:/language/Docs/PaletteColours/button-background",
"text": "Default button background"
},
"$:/language/Docs/PaletteColours/button-border": {
"title": "$:/language/Docs/PaletteColours/button-border",
"text": "Default button border"
},
"$:/language/Docs/PaletteColours/button-foreground": {
"title": "$:/language/Docs/PaletteColours/button-foreground",
"text": "Default button foreground"
},
"$:/language/Docs/PaletteColours/dirty-indicator": {
"title": "$:/language/Docs/PaletteColours/dirty-indicator",
"text": "Unsaved changes indicator"
},
"$:/language/Docs/PaletteColours/code-background": {
"title": "$:/language/Docs/PaletteColours/code-background",
"text": "Code background"
},
"$:/language/Docs/PaletteColours/code-border": {
"title": "$:/language/Docs/PaletteColours/code-border",
"text": "Code border"
},
"$:/language/Docs/PaletteColours/code-foreground": {
"title": "$:/language/Docs/PaletteColours/code-foreground",
"text": "Code foreground"
},
"$:/language/Docs/PaletteColours/download-background": {
"title": "$:/language/Docs/PaletteColours/download-background",
"text": "Download button background"
},
"$:/language/Docs/PaletteColours/download-foreground": {
"title": "$:/language/Docs/PaletteColours/download-foreground",
"text": "Download button foreground"
},
"$:/language/Docs/PaletteColours/dragger-background": {
"title": "$:/language/Docs/PaletteColours/dragger-background",
"text": "Dragger background"
},
"$:/language/Docs/PaletteColours/dragger-foreground": {
"title": "$:/language/Docs/PaletteColours/dragger-foreground",
"text": "Dragger foreground"
},
"$:/language/Docs/PaletteColours/dropdown-background": {
"title": "$:/language/Docs/PaletteColours/dropdown-background",
"text": "Dropdown background"
},
"$:/language/Docs/PaletteColours/dropdown-border": {
"title": "$:/language/Docs/PaletteColours/dropdown-border",
"text": "Dropdown border"
},
"$:/language/Docs/PaletteColours/dropdown-tab-background-selected": {
"title": "$:/language/Docs/PaletteColours/dropdown-tab-background-selected",
"text": "Dropdown tab background for selected tabs"
},
"$:/language/Docs/PaletteColours/dropdown-tab-background": {
"title": "$:/language/Docs/PaletteColours/dropdown-tab-background",
"text": "Dropdown tab background"
},
"$:/language/Docs/PaletteColours/dropzone-background": {
"title": "$:/language/Docs/PaletteColours/dropzone-background",
"text": "Dropzone background"
},
"$:/language/Docs/PaletteColours/external-link-background-hover": {
"title": "$:/language/Docs/PaletteColours/external-link-background-hover",
"text": "External link background hover"
},
"$:/language/Docs/PaletteColours/external-link-background-visited": {
"title": "$:/language/Docs/PaletteColours/external-link-background-visited",
"text": "External link background visited"
},
"$:/language/Docs/PaletteColours/external-link-background": {
"title": "$:/language/Docs/PaletteColours/external-link-background",
"text": "External link background"
},
"$:/language/Docs/PaletteColours/external-link-foreground-hover": {
"title": "$:/language/Docs/PaletteColours/external-link-foreground-hover",
"text": "External link foreground hover"
},
"$:/language/Docs/PaletteColours/external-link-foreground-visited": {
"title": "$:/language/Docs/PaletteColours/external-link-foreground-visited",
"text": "External link foreground visited"
},
"$:/language/Docs/PaletteColours/external-link-foreground": {
"title": "$:/language/Docs/PaletteColours/external-link-foreground",
"text": "External link foreground"
},
"$:/language/Docs/PaletteColours/foreground": {
"title": "$:/language/Docs/PaletteColours/foreground",
"text": "General foreground"
},
"$:/language/Docs/PaletteColours/message-background": {
"title": "$:/language/Docs/PaletteColours/message-background",
"text": "Message box background"
},
"$:/language/Docs/PaletteColours/message-border": {
"title": "$:/language/Docs/PaletteColours/message-border",
"text": "Message box border"
},
"$:/language/Docs/PaletteColours/message-foreground": {
"title": "$:/language/Docs/PaletteColours/message-foreground",
"text": "Message box foreground"
},
"$:/language/Docs/PaletteColours/modal-backdrop": {
"title": "$:/language/Docs/PaletteColours/modal-backdrop",
"text": "Modal backdrop"
},
"$:/language/Docs/PaletteColours/modal-background": {
"title": "$:/language/Docs/PaletteColours/modal-background",
"text": "Modal background"
},
"$:/language/Docs/PaletteColours/modal-border": {
"title": "$:/language/Docs/PaletteColours/modal-border",
"text": "Modal border"
},
"$:/language/Docs/PaletteColours/modal-footer-background": {
"title": "$:/language/Docs/PaletteColours/modal-footer-background",
"text": "Modal footer background"
},
"$:/language/Docs/PaletteColours/modal-footer-border": {
"title": "$:/language/Docs/PaletteColours/modal-footer-border",
"text": "Modal footer border"
},
"$:/language/Docs/PaletteColours/modal-header-border": {
"title": "$:/language/Docs/PaletteColours/modal-header-border",
"text": "Modal header border"
},
"$:/language/Docs/PaletteColours/muted-foreground": {
"title": "$:/language/Docs/PaletteColours/muted-foreground",
"text": "General muted foreground"
},
"$:/language/Docs/PaletteColours/notification-background": {
"title": "$:/language/Docs/PaletteColours/notification-background",
"text": "Notification background"
},
"$:/language/Docs/PaletteColours/notification-border": {
"title": "$:/language/Docs/PaletteColours/notification-border",
"text": "Notification border"
},
"$:/language/Docs/PaletteColours/page-background": {
"title": "$:/language/Docs/PaletteColours/page-background",
"text": "Page background"
},
"$:/language/Docs/PaletteColours/pre-background": {
"title": "$:/language/Docs/PaletteColours/pre-background",
"text": "Preformatted code background"
},
"$:/language/Docs/PaletteColours/pre-border": {
"title": "$:/language/Docs/PaletteColours/pre-border",
"text": "Preformatted code border"
},
"$:/language/Docs/PaletteColours/primary": {
"title": "$:/language/Docs/PaletteColours/primary",
"text": "General primary"
},
"$:/language/Docs/PaletteColours/select-tag-background": {
"title": "$:/language/Docs/PaletteColours/select-tag-background",
"text": "`<select>` element background"
},
"$:/language/Docs/PaletteColours/select-tag-foreground": {
"title": "$:/language/Docs/PaletteColours/select-tag-foreground",
"text": "`<select>` element text"
},
"$:/language/Docs/PaletteColours/sidebar-button-foreground": {
"title": "$:/language/Docs/PaletteColours/sidebar-button-foreground",
"text": "Sidebar button foreground"
},
"$:/language/Docs/PaletteColours/sidebar-controls-foreground-hover": {
"title": "$:/language/Docs/PaletteColours/sidebar-controls-foreground-hover",
"text": "Sidebar controls foreground hover"
},
"$:/language/Docs/PaletteColours/sidebar-controls-foreground": {
"title": "$:/language/Docs/PaletteColours/sidebar-controls-foreground",
"text": "Sidebar controls foreground"
},
"$:/language/Docs/PaletteColours/sidebar-foreground-shadow": {
"title": "$:/language/Docs/PaletteColours/sidebar-foreground-shadow",
"text": "Sidebar foreground shadow"
},
"$:/language/Docs/PaletteColours/sidebar-foreground": {
"title": "$:/language/Docs/PaletteColours/sidebar-foreground",
"text": "Sidebar foreground"
},
"$:/language/Docs/PaletteColours/sidebar-muted-foreground-hover": {
"title": "$:/language/Docs/PaletteColours/sidebar-muted-foreground-hover",
"text": "Sidebar muted foreground hover"
},
"$:/language/Docs/PaletteColours/sidebar-muted-foreground": {
"title": "$:/language/Docs/PaletteColours/sidebar-muted-foreground",
"text": "Sidebar muted foreground"
},
"$:/language/Docs/PaletteColours/sidebar-tab-background-selected": {
"title": "$:/language/Docs/PaletteColours/sidebar-tab-background-selected",
"text": "Sidebar tab background for selected tabs"
},
"$:/language/Docs/PaletteColours/sidebar-tab-background": {
"title": "$:/language/Docs/PaletteColours/sidebar-tab-background",
"text": "Sidebar tab background"
},
"$:/language/Docs/PaletteColours/sidebar-tab-border-selected": {
"title": "$:/language/Docs/PaletteColours/sidebar-tab-border-selected",
"text": "Sidebar tab border for selected tabs"
},
"$:/language/Docs/PaletteColours/sidebar-tab-border": {
"title": "$:/language/Docs/PaletteColours/sidebar-tab-border",
"text": "Sidebar tab border"
},
"$:/language/Docs/PaletteColours/sidebar-tab-divider": {
"title": "$:/language/Docs/PaletteColours/sidebar-tab-divider",
"text": "Sidebar tab divider"
},
"$:/language/Docs/PaletteColours/sidebar-tab-foreground-selected": {
"title": "$:/language/Docs/PaletteColours/sidebar-tab-foreground-selected",
"text": "Sidebar tab foreground for selected tabs"
},
"$:/language/Docs/PaletteColours/sidebar-tab-foreground": {
"title": "$:/language/Docs/PaletteColours/sidebar-tab-foreground",
"text": "Sidebar tab foreground"
},
"$:/language/Docs/PaletteColours/sidebar-tiddler-link-foreground-hover": {
"title": "$:/language/Docs/PaletteColours/sidebar-tiddler-link-foreground-hover",
"text": "Sidebar tiddler link foreground hover"
},
"$:/language/Docs/PaletteColours/sidebar-tiddler-link-foreground": {
"title": "$:/language/Docs/PaletteColours/sidebar-tiddler-link-foreground",
"text": "Sidebar tiddler link foreground"
},
"$:/language/Docs/PaletteColours/site-title-foreground": {
"title": "$:/language/Docs/PaletteColours/site-title-foreground",
"text": "Site title foreground"
},
"$:/language/Docs/PaletteColours/static-alert-foreground": {
"title": "$:/language/Docs/PaletteColours/static-alert-foreground",
"text": "Static alert foreground"
},
"$:/language/Docs/PaletteColours/tab-background-selected": {
"title": "$:/language/Docs/PaletteColours/tab-background-selected",
"text": "Tab background for selected tabs"
},
"$:/language/Docs/PaletteColours/tab-background": {
"title": "$:/language/Docs/PaletteColours/tab-background",
"text": "Tab background"
},
"$:/language/Docs/PaletteColours/tab-border-selected": {
"title": "$:/language/Docs/PaletteColours/tab-border-selected",
"text": "Tab border for selected tabs"
},
"$:/language/Docs/PaletteColours/tab-border": {
"title": "$:/language/Docs/PaletteColours/tab-border",
"text": "Tab border"
},
"$:/language/Docs/PaletteColours/tab-divider": {
"title": "$:/language/Docs/PaletteColours/tab-divider",
"text": "Tab divider"
},
"$:/language/Docs/PaletteColours/tab-foreground-selected": {
"title": "$:/language/Docs/PaletteColours/tab-foreground-selected",
"text": "Tab foreground for selected tabs"
},
"$:/language/Docs/PaletteColours/tab-foreground": {
"title": "$:/language/Docs/PaletteColours/tab-foreground",
"text": "Tab foreground"
},
"$:/language/Docs/PaletteColours/table-border": {
"title": "$:/language/Docs/PaletteColours/table-border",
"text": "Table border"
},
"$:/language/Docs/PaletteColours/table-footer-background": {
"title": "$:/language/Docs/PaletteColours/table-footer-background",
"text": "Table footer background"
},
"$:/language/Docs/PaletteColours/table-header-background": {
"title": "$:/language/Docs/PaletteColours/table-header-background",
"text": "Table header background"
},
"$:/language/Docs/PaletteColours/tag-background": {
"title": "$:/language/Docs/PaletteColours/tag-background",
"text": "Tag background"
},
"$:/language/Docs/PaletteColours/tag-foreground": {
"title": "$:/language/Docs/PaletteColours/tag-foreground",
"text": "Tag foreground"
},
"$:/language/Docs/PaletteColours/tiddler-background": {
"title": "$:/language/Docs/PaletteColours/tiddler-background",
"text": "Tiddler background"
},
"$:/language/Docs/PaletteColours/tiddler-border": {
"title": "$:/language/Docs/PaletteColours/tiddler-border",
"text": "Tiddler border"
},
"$:/language/Docs/PaletteColours/tiddler-controls-foreground-hover": {
"title": "$:/language/Docs/PaletteColours/tiddler-controls-foreground-hover",
"text": "Tiddler controls foreground hover"
},
"$:/language/Docs/PaletteColours/tiddler-controls-foreground-selected": {
"title": "$:/language/Docs/PaletteColours/tiddler-controls-foreground-selected",
"text": "Tiddler controls foreground for selected controls"
},
"$:/language/Docs/PaletteColours/tiddler-controls-foreground": {
"title": "$:/language/Docs/PaletteColours/tiddler-controls-foreground",
"text": "Tiddler controls foreground"
},
"$:/language/Docs/PaletteColours/tiddler-editor-background": {
"title": "$:/language/Docs/PaletteColours/tiddler-editor-background",
"text": "Tiddler editor background"
},
"$:/language/Docs/PaletteColours/tiddler-editor-border-image": {
"title": "$:/language/Docs/PaletteColours/tiddler-editor-border-image",
"text": "Tiddler editor border image"
},
"$:/language/Docs/PaletteColours/tiddler-editor-border": {
"title": "$:/language/Docs/PaletteColours/tiddler-editor-border",
"text": "Tiddler editor border"
},
"$:/language/Docs/PaletteColours/tiddler-editor-fields-even": {
"title": "$:/language/Docs/PaletteColours/tiddler-editor-fields-even",
"text": "Tiddler editor background for even fields"
},
"$:/language/Docs/PaletteColours/tiddler-editor-fields-odd": {
"title": "$:/language/Docs/PaletteColours/tiddler-editor-fields-odd",
"text": "Tiddler editor background for odd fields"
},
"$:/language/Docs/PaletteColours/tiddler-info-background": {
"title": "$:/language/Docs/PaletteColours/tiddler-info-background",
"text": "Tiddler info panel background"
},
"$:/language/Docs/PaletteColours/tiddler-info-border": {
"title": "$:/language/Docs/PaletteColours/tiddler-info-border",
"text": "Tiddler info panel border"
},
"$:/language/Docs/PaletteColours/tiddler-info-tab-background": {
"title": "$:/language/Docs/PaletteColours/tiddler-info-tab-background",
"text": "Tiddler info panel tab background"
},
"$:/language/Docs/PaletteColours/tiddler-link-background": {
"title": "$:/language/Docs/PaletteColours/tiddler-link-background",
"text": "Tiddler link background"
},
"$:/language/Docs/PaletteColours/tiddler-link-foreground": {
"title": "$:/language/Docs/PaletteColours/tiddler-link-foreground",
"text": "Tiddler link foreground"
},
"$:/language/Docs/PaletteColours/tiddler-subtitle-foreground": {
"title": "$:/language/Docs/PaletteColours/tiddler-subtitle-foreground",
"text": "Tiddler subtitle foreground"
},
"$:/language/Docs/PaletteColours/tiddler-title-foreground": {
"title": "$:/language/Docs/PaletteColours/tiddler-title-foreground",
"text": "Tiddler title foreground"
},
"$:/language/Docs/PaletteColours/toolbar-new-button": {
"title": "$:/language/Docs/PaletteColours/toolbar-new-button",
"text": "Toolbar 'new tiddler' button foreground"
},
"$:/language/Docs/PaletteColours/toolbar-options-button": {
"title": "$:/language/Docs/PaletteColours/toolbar-options-button",
"text": "Toolbar 'options' button foreground"
},
"$:/language/Docs/PaletteColours/toolbar-save-button": {
"title": "$:/language/Docs/PaletteColours/toolbar-save-button",
"text": "Toolbar 'save' button foreground"
},
"$:/language/Docs/PaletteColours/toolbar-info-button": {
"title": "$:/language/Docs/PaletteColours/toolbar-info-button",
"text": "Toolbar 'info' button foreground"
},
"$:/language/Docs/PaletteColours/toolbar-edit-button": {
"title": "$:/language/Docs/PaletteColours/toolbar-edit-button",
"text": "Toolbar 'edit' button foreground"
},
"$:/language/Docs/PaletteColours/toolbar-close-button": {
"title": "$:/language/Docs/PaletteColours/toolbar-close-button",
"text": "Toolbar 'close' button foreground"
},
"$:/language/Docs/PaletteColours/toolbar-delete-button": {
"title": "$:/language/Docs/PaletteColours/toolbar-delete-button",
"text": "Toolbar 'delete' button foreground"
},
"$:/language/Docs/PaletteColours/toolbar-cancel-button": {
"title": "$:/language/Docs/PaletteColours/toolbar-cancel-button",
"text": "Toolbar 'cancel' button foreground"
},
"$:/language/Docs/PaletteColours/toolbar-done-button": {
"title": "$:/language/Docs/PaletteColours/toolbar-done-button",
"text": "Toolbar 'done' button foreground"
},
"$:/language/Docs/PaletteColours/untagged-background": {
"title": "$:/language/Docs/PaletteColours/untagged-background",
"text": "Untagged pill background"
},
"$:/language/Docs/PaletteColours/very-muted-foreground": {
"title": "$:/language/Docs/PaletteColours/very-muted-foreground",
"text": "Very muted foreground"
},
"$:/language/EditTemplate/Body/External/Hint": {
"title": "$:/language/EditTemplate/Body/External/Hint",
"text": "This tiddler shows content stored outside of the main TiddlyWiki file. You can edit the tags and fields but cannot directly edit the content itself"
},
"$:/language/EditTemplate/Body/Placeholder": {
"title": "$:/language/EditTemplate/Body/Placeholder",
"text": "Type the text for this tiddler"
},
"$:/language/EditTemplate/Body/Preview/Type/Output": {
"title": "$:/language/EditTemplate/Body/Preview/Type/Output",
"text": "output"
},
"$:/language/EditTemplate/Field/Remove/Caption": {
"title": "$:/language/EditTemplate/Field/Remove/Caption",
"text": "remove field"
},
"$:/language/EditTemplate/Field/Remove/Hint": {
"title": "$:/language/EditTemplate/Field/Remove/Hint",
"text": "Remove field"
},
"$:/language/EditTemplate/Field/Dropdown/Caption": {
"title": "$:/language/EditTemplate/Field/Dropdown/Caption",
"text": "field list"
},
"$:/language/EditTemplate/Field/Dropdown/Hint": {
"title": "$:/language/EditTemplate/Field/Dropdown/Hint",
"text": "Show field list"
},
"$:/language/EditTemplate/Fields/Add/Button": {
"title": "$:/language/EditTemplate/Fields/Add/Button",
"text": "add"
},
"$:/language/EditTemplate/Fields/Add/Name/Placeholder": {
"title": "$:/language/EditTemplate/Fields/Add/Name/Placeholder",
"text": "field name"
},
"$:/language/EditTemplate/Fields/Add/Prompt": {
"title": "$:/language/EditTemplate/Fields/Add/Prompt",
"text": "Add a new field:"
},
"$:/language/EditTemplate/Fields/Add/Value/Placeholder": {
"title": "$:/language/EditTemplate/Fields/Add/Value/Placeholder",
"text": "field value"
},
"$:/language/EditTemplate/Fields/Add/Dropdown/System": {
"title": "$:/language/EditTemplate/Fields/Add/Dropdown/System",
"text": "System fields"
},
"$:/language/EditTemplate/Fields/Add/Dropdown/User": {
"title": "$:/language/EditTemplate/Fields/Add/Dropdown/User",
"text": "User fields"
},
"$:/language/EditTemplate/Shadow/Warning": {
"title": "$:/language/EditTemplate/Shadow/Warning",
"text": "This is a shadow tiddler. Any changes you make will override the default version from the plugin <<pluginLink>>"
},
"$:/language/EditTemplate/Shadow/OverriddenWarning": {
"title": "$:/language/EditTemplate/Shadow/OverriddenWarning",
"text": "This is a modified shadow tiddler. You can revert to the default version in the plugin <<pluginLink>> by deleting this tiddler"
},
"$:/language/EditTemplate/Tags/Add/Button": {
"title": "$:/language/EditTemplate/Tags/Add/Button",
"text": "add"
},
"$:/language/EditTemplate/Tags/Add/Placeholder": {
"title": "$:/language/EditTemplate/Tags/Add/Placeholder",
"text": "tag name"
},
"$:/language/EditTemplate/Tags/Dropdown/Caption": {
"title": "$:/language/EditTemplate/Tags/Dropdown/Caption",
"text": "tag list"
},
"$:/language/EditTemplate/Tags/Dropdown/Hint": {
"title": "$:/language/EditTemplate/Tags/Dropdown/Hint",
"text": "Show tag list"
},
"$:/language/EditTemplate/Title/BadCharacterWarning": {
"title": "$:/language/EditTemplate/Title/BadCharacterWarning",
"text": "Warning: avoid using any of the characters <<bad-chars>> in tiddler titles"
},
"$:/language/EditTemplate/Title/Exists/Prompt": {
"title": "$:/language/EditTemplate/Title/Exists/Prompt",
"text": "Target tiddler already exists"
},
"$:/language/EditTemplate/Title/Relink/Prompt": {
"title": "$:/language/EditTemplate/Title/Relink/Prompt",
"text": "Update ''<$text text=<<fromTitle>>/>'' to ''<$text text=<<toTitle>>/>'' in the //tags// and //list// fields of other tiddlers"
},
"$:/language/EditTemplate/Title/References/Prompt": {
"title": "$:/language/EditTemplate/Title/References/Prompt",
"text": "The following references to this tiddler will not be automatically updated:"
},
"$:/language/EditTemplate/Type/Dropdown/Caption": {
"title": "$:/language/EditTemplate/Type/Dropdown/Caption",
"text": "content type list"
},
"$:/language/EditTemplate/Type/Dropdown/Hint": {
"title": "$:/language/EditTemplate/Type/Dropdown/Hint",
"text": "Show content type list"
},
"$:/language/EditTemplate/Type/Delete/Caption": {
"title": "$:/language/EditTemplate/Type/Delete/Caption",
"text": "delete content type"
},
"$:/language/EditTemplate/Type/Delete/Hint": {
"title": "$:/language/EditTemplate/Type/Delete/Hint",
"text": "Delete content type"
},
"$:/language/EditTemplate/Type/Placeholder": {
"title": "$:/language/EditTemplate/Type/Placeholder",
"text": "content type"
},
"$:/language/EditTemplate/Type/Prompt": {
"title": "$:/language/EditTemplate/Type/Prompt",
"text": "Type:"
},
"$:/language/Exporters/StaticRiver": {
"title": "$:/language/Exporters/StaticRiver",
"text": "Static HTML"
},
"$:/language/Exporters/JsonFile": {
"title": "$:/language/Exporters/JsonFile",
"text": "JSON file"
},
"$:/language/Exporters/CsvFile": {
"title": "$:/language/Exporters/CsvFile",
"text": "CSV file"
},
"$:/language/Exporters/TidFile": {
"title": "$:/language/Exporters/TidFile",
"text": "\".tid\" file"
},
"$:/language/Docs/Fields/_canonical_uri": {
"title": "$:/language/Docs/Fields/_canonical_uri",
"text": "The full URI of an external image tiddler"
},
"$:/language/Docs/Fields/bag": {
"title": "$:/language/Docs/Fields/bag",
"text": "The name of the bag from which a tiddler came"
},
"$:/language/Docs/Fields/caption": {
"title": "$:/language/Docs/Fields/caption",
"text": "The text to be displayed on a tab or button"
},
"$:/language/Docs/Fields/color": {
"title": "$:/language/Docs/Fields/color",
"text": "The CSS color value associated with a tiddler"
},
"$:/language/Docs/Fields/component": {
"title": "$:/language/Docs/Fields/component",
"text": "The name of the component responsible for an [[alert tiddler|AlertMechanism]]"
},
"$:/language/Docs/Fields/current-tiddler": {
"title": "$:/language/Docs/Fields/current-tiddler",
"text": "Used to cache the top tiddler in a [[history list|HistoryMechanism]]"
},
"$:/language/Docs/Fields/created": {
"title": "$:/language/Docs/Fields/created",
"text": "The date a tiddler was created"
},
"$:/language/Docs/Fields/creator": {
"title": "$:/language/Docs/Fields/creator",
"text": "The name of the person who created a tiddler"
},
"$:/language/Docs/Fields/dependents": {
"title": "$:/language/Docs/Fields/dependents",
"text": "For a plugin, lists the dependent plugin titles"
},
"$:/language/Docs/Fields/description": {
"title": "$:/language/Docs/Fields/description",
"text": "The descriptive text for a plugin, or a modal dialogue"
},
"$:/language/Docs/Fields/draft.of": {
"title": "$:/language/Docs/Fields/draft.of",
"text": "For draft tiddlers, contains the title of the tiddler of which this is a draft"
},
"$:/language/Docs/Fields/draft.title": {
"title": "$:/language/Docs/Fields/draft.title",
"text": "For draft tiddlers, contains the proposed new title of the tiddler"
},
"$:/language/Docs/Fields/footer": {
"title": "$:/language/Docs/Fields/footer",
"text": "The footer text for a wizard"
},
"$:/language/Docs/Fields/hack-to-give-us-something-to-compare-against": {
"title": "$:/language/Docs/Fields/hack-to-give-us-something-to-compare-against",
"text": "A temporary storage field used in [[$:/core/templates/static.content]]"
},
"$:/language/Docs/Fields/icon": {
"title": "$:/language/Docs/Fields/icon",
"text": "The title of the tiddler containing the icon associated with a tiddler"
},
"$:/language/Docs/Fields/library": {
"title": "$:/language/Docs/Fields/library",
"text": "If set to \"yes\" indicates that a tiddler should be saved as a JavaScript library"
},
"$:/language/Docs/Fields/list": {
"title": "$:/language/Docs/Fields/list",
"text": "An ordered list of tiddler titles associated with a tiddler"
},
"$:/language/Docs/Fields/list-before": {
"title": "$:/language/Docs/Fields/list-before",
"text": "If set, the title of a tiddler before which this tiddler should be added to the ordered list of tiddler titles, or at the start of the list if this field is present but empty"
},
"$:/language/Docs/Fields/list-after": {
"title": "$:/language/Docs/Fields/list-after",
"text": "If set, the title of the tiddler after which this tiddler should be added to the ordered list of tiddler titles, or at the end of the list if this field is present but empty"
},
"$:/language/Docs/Fields/modified": {
"title": "$:/language/Docs/Fields/modified",
"text": "The date and time at which a tiddler was last modified"
},
"$:/language/Docs/Fields/modifier": {
"title": "$:/language/Docs/Fields/modifier",
"text": "The tiddler title associated with the person who last modified a tiddler"
},
"$:/language/Docs/Fields/name": {
"title": "$:/language/Docs/Fields/name",
"text": "The human readable name associated with a plugin tiddler"
},
"$:/language/Docs/Fields/plugin-priority": {
"title": "$:/language/Docs/Fields/plugin-priority",
"text": "A numerical value indicating the priority of a plugin tiddler"
},
"$:/language/Docs/Fields/plugin-type": {
"title": "$:/language/Docs/Fields/plugin-type",
"text": "The type of plugin in a plugin tiddler"
},
"$:/language/Docs/Fields/revision": {
"title": "$:/language/Docs/Fields/revision",
"text": "The revision of the tiddler held at the server"
},
"$:/language/Docs/Fields/released": {
"title": "$:/language/Docs/Fields/released",
"text": "Date of a TiddlyWiki release"
},
"$:/language/Docs/Fields/source": {
"title": "$:/language/Docs/Fields/source",
"text": "The source URL associated with a tiddler"
},
"$:/language/Docs/Fields/subtitle": {
"title": "$:/language/Docs/Fields/subtitle",
"text": "The subtitle text for a wizard"
},
"$:/language/Docs/Fields/tags": {
"title": "$:/language/Docs/Fields/tags",
"text": "A list of tags associated with a tiddler"
},
"$:/language/Docs/Fields/text": {
"title": "$:/language/Docs/Fields/text",
"text": "The body text of a tiddler"
},
"$:/language/Docs/Fields/title": {
"title": "$:/language/Docs/Fields/title",
"text": "The unique name of a tiddler"
},
"$:/language/Docs/Fields/type": {
"title": "$:/language/Docs/Fields/type",
"text": "The content type of a tiddler"
},
"$:/language/Docs/Fields/version": {
"title": "$:/language/Docs/Fields/version",
"text": "Version information for a plugin"
},
"$:/language/Filters/AllTiddlers": {
"title": "$:/language/Filters/AllTiddlers",
"text": "All tiddlers except system tiddlers"
},
"$:/language/Filters/RecentSystemTiddlers": {
"title": "$:/language/Filters/RecentSystemTiddlers",
"text": "Recently modified tiddlers, including system tiddlers"
},
"$:/language/Filters/RecentTiddlers": {
"title": "$:/language/Filters/RecentTiddlers",
"text": "Recently modified tiddlers"
},
"$:/language/Filters/AllTags": {
"title": "$:/language/Filters/AllTags",
"text": "All tags except system tags"
},
"$:/language/Filters/Missing": {
"title": "$:/language/Filters/Missing",
"text": "Missing tiddlers"
},
"$:/language/Filters/Drafts": {
"title": "$:/language/Filters/Drafts",
"text": "Draft tiddlers"
},
"$:/language/Filters/Orphans": {
"title": "$:/language/Filters/Orphans",
"text": "Orphan tiddlers"
},
"$:/language/Filters/SystemTiddlers": {
"title": "$:/language/Filters/SystemTiddlers",
"text": "System tiddlers"
},
"$:/language/Filters/ShadowTiddlers": {
"title": "$:/language/Filters/ShadowTiddlers",
"text": "Shadow tiddlers"
},
"$:/language/Filters/OverriddenShadowTiddlers": {
"title": "$:/language/Filters/OverriddenShadowTiddlers",
"text": "Overridden shadow tiddlers"
},
"$:/language/Filters/SystemTags": {
"title": "$:/language/Filters/SystemTags",
"text": "System tags"
},
"$:/language/Filters/StoryList": {
"title": "$:/language/Filters/StoryList",
"text": "Tiddlers in the story river, excluding <$text text=\"$:/AdvancedSearch\"/>"
},
"$:/language/Filters/TypedTiddlers": {
"title": "$:/language/Filters/TypedTiddlers",
"text": "Non wiki-text tiddlers"
},
"GettingStarted": {
"title": "GettingStarted",
"text": "\\define lingo-base() $:/language/ControlPanel/Basics/\nWelcome to ~TiddlyWiki and the ~TiddlyWiki community\n\nBefore you start storing important information in ~TiddlyWiki it is vital to make sure that you can reliably save changes. See https://tiddlywiki.com/#GettingStarted for details\n\n!! Set up this ~TiddlyWiki\n\n<div class=\"tc-control-panel\">\n\n|<$link to=\"$:/SiteTitle\"><<lingo Title/Prompt>></$link> |<$edit-text tiddler=\"$:/SiteTitle\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/SiteSubtitle\"><<lingo Subtitle/Prompt>></$link> |<$edit-text tiddler=\"$:/SiteSubtitle\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/DefaultTiddlers\"><<lingo DefaultTiddlers/Prompt>></$link> |<<lingo DefaultTiddlers/TopHint>><br> <$edit tag=\"textarea\" tiddler=\"$:/DefaultTiddlers\"/><br>//<<lingo DefaultTiddlers/BottomHint>>// |\n</div>\n\nSee the [[control panel|$:/ControlPanel]] for more options.\n"
},
"$:/language/Help/build": {
"title": "$:/language/Help/build",
"description": "Automatically run configured commands",
"text": "Build the specified build targets for the current wiki. If no build targets are specified then all available targets will be built.\n\n```\n--build <target> [<target> ...]\n```\n\nBuild targets are defined in the `tiddlywiki.info` file of a wiki folder.\n\n"
},
"$:/language/Help/clearpassword": {
"title": "$:/language/Help/clearpassword",
"description": "Clear a password for subsequent crypto operations",
"text": "Clear the password for subsequent crypto operations\n\n```\n--clearpassword\n```\n"
},
"$:/language/Help/default": {
"title": "$:/language/Help/default",
"text": "\\define commandTitle()\n$:/language/Help/$(command)$\n\\end\n```\nusage: tiddlywiki [<wikifolder>] [--<command> [<args>...]...]\n```\n\nAvailable commands:\n\n<ul>\n<$list filter=\"[commands[]sort[title]]\" variable=\"command\">\n<li><$link to=<<commandTitle>>><$macrocall $name=\"command\" $type=\"text/plain\" $output=\"text/plain\"/></$link>: <$transclude tiddler=<<commandTitle>> field=\"description\"/></li>\n</$list>\n</ul>\n\nTo get detailed help on a command:\n\n```\ntiddlywiki --help <command>\n```\n"
},
"$:/language/Help/editions": {
"title": "$:/language/Help/editions",
"description": "Lists the available editions of TiddlyWiki",
"text": "Lists the names and descriptions of the available editions. You can create a new wiki of a specified edition with the `--init` command.\n\n```\n--editions\n```\n"
},
"$:/language/Help/fetch": {
"title": "$:/language/Help/fetch",
"description": "Fetch tiddlers from wiki by URL",
"text": "Fetch one or more files over HTTP/HTTPS, and import the tiddlers matching a filter, optionally transforming the incoming titles.\n\n```\n--fetch file <url> <import-filter> <transform-filter>\n--fetch files <url-filter> <import-filter> <transform-filter>\n--fetch raw-file <url> <transform-filter>\n--fetch raw-files <url-filter> <transform-filter>\n```\n\nThe \"file\" and \"files\" variants fetch the specified files and attempt to import the tiddlers within them (the same processing as if the files were dragged into the browser window). The \"raw-file\" and \"raw-files\" variants fetch the specified files and then store the raw file data in tiddlers, without applying the import logic.\n\nWith the \"file\" and \"raw-file\" variants only a single file is fetched and the first parameter is the URL of the file to read.\n\nWith the \"files\" and \"raw-files\" variants, multiple files are fetched and the first parameter is a filter yielding a list of URLs of the files to read. For example, given a set of tiddlers tagged \"remote-server\" that have a field \"url\" the filter `[tag[remote-server]get[url]]` will retrieve all the available URLs.\n\nFor the \"file\" and \"files\" variants, the `<import-filter>` parameter specifies a filter determining which tiddlers are imported. It defaults to `[all[tiddlers]]` if not provided.\n\nFor all variants, the `<transform-filter>` parameter specifies an optional filter that transforms the titles of the imported tiddlers. For example, `[addprefix[$:/myimports/]]` would add the prefix `$:/myimports/` to each title.\n\nPreceding the `--fetch` command with `--verbose` will output progress information during the import.\n\nNote that TiddlyWiki will not fetch an older version of an already loaded plugin.\n\nThe following example retrieves all the non-system tiddlers from https://tiddlywiki.com and saves them to a JSON file:\n\n```\ntiddlywiki --verbose --fetch file \"https://tiddlywiki.com/\" \"[!is[system]]\" \"\" --rendertiddler \"$:/core/templates/exporters/JsonFile\" output.json text/plain \"\" exportFilter \"[!is[system]]\"\n```\n\nThe following example retrieves the \"favicon\" file from tiddlywiki.com and saves it in a file called \"output.ico\". Note that the intermediate tiddler \"Icon Tiddler\" is quoted in the \"--fetch\" command because it is being used as a transformation filter to replace the default title, while there are no quotes for the \"--savetiddler\" command because it is being used directly as a title.\n\n```\ntiddlywiki --verbose --fetch raw-file \"https://tiddlywiki.com/favicon.ico\" \"[[Icon Tiddler]]\" --savetiddler \"Icon Tiddler\" output.ico\n```\n\n"
},
"$:/language/Help/help": {
"title": "$:/language/Help/help",
"description": "Display help for TiddlyWiki commands",
"text": "Displays help text for a command:\n\n```\n--help [<command>]\n```\n\nIf the command name is omitted then a list of available commands is displayed.\n"
},
"$:/language/Help/import": {
"title": "$:/language/Help/import",
"description": "Import tiddlers from a file",
"text": "Import tiddlers from TiddlyWiki (`.html`), `.tiddler`, `.tid`, `.json` or other local files. The deserializer must be explicitly specified, unlike the `load` command which infers the deserializer from the file extension.\n\n```\n--import <filepath> <deserializer> [<title>] [<encoding>]\n```\n\nThe deserializers in the core include:\n\n* application/javascript\n* application/json\n* application/x-tiddler\n* application/x-tiddler-html-div\n* application/x-tiddlers\n* text/html\n* text/plain\n\nThe title of the imported tiddler defaults to the filename.\n\nThe encoding defaults to \"utf8\", but can be \"base64\" for importing binary files.\n\nNote that TiddlyWiki will not import an older version of an already loaded plugin.\n"
},
"$:/language/Help/init": {
"title": "$:/language/Help/init",
"description": "Initialise a new wiki folder",
"text": "Initialise an empty [[WikiFolder|WikiFolders]] with a copy of the specified edition.\n\n```\n--init <edition> [<edition> ...]\n```\n\nFor example:\n\n```\ntiddlywiki ./MyWikiFolder --init empty\n```\n\nNote:\n\n* The wiki folder directory will be created if necessary\n* The \"edition\" defaults to ''empty''\n* The init command will fail if the wiki folder is not empty\n* The init command removes any `includeWikis` definitions in the edition's `tiddlywiki.info` file\n* When multiple editions are specified, editions initialised later will overwrite any files shared with earlier editions (so, the final `tiddlywiki.info` file will be copied from the last edition)\n* `--editions` returns a list of available editions\n"
},
"$:/language/Help/listen": {
"title": "$:/language/Help/listen",
"description": "Provides an HTTP server interface to TiddlyWiki",
"text": "Serves a wiki over HTTP.\n\nThe listen command uses NamedCommandParameters:\n\n```\n--listen [<name>=<value>]...\n```\n\nAll parameters are optional with safe defaults, and can be specified in any order. The recognised parameters are:\n\n* ''host'' - optional hostname to serve from (defaults to \"127.0.0.1\" aka \"localhost\")\n* ''path-prefix'' - optional prefix for paths\n* ''port'' - port number on which to listen; non-numeric values are interpreted as a system environment variable from which the port number is extracted (defaults to \"8080\")\n* ''credentials'' - pathname of credentials CSV file (relative to wiki folder)\n* ''anon-username'' - the username for signing edits for anonymous users\n* ''username'' - optional username for basic authentication\n* ''password'' - optional password for basic authentication\n* ''authenticated-user-header'' - optional name of header to be used for trusted authentication\n* ''readers'' - comma separated list of principals allowed to read from this wiki\n* ''writers'' - comma separated list of principals allowed to write to this wiki\n* ''csrf-disable'' - set to \"yes\" to disable CSRF checks (defaults to \"no\")\n* ''root-tiddler'' - the tiddler to serve at the root (defaults to \"$:/core/save/all\")\n* ''root-render-type'' - the content type to which the root tiddler should be rendered (defaults to \"text/plain\")\n* ''root-serve-type'' - the content type with which the root tiddler should be served (defaults to \"text/html\")\n* ''tls-cert'' - pathname of TLS certificate file (relative to wiki folder)\n* ''tls-key'' - pathname of TLS key file (relative to wiki folder)\n* ''debug-level'' - optional debug level; set to \"debug\" to view request details (defaults to \"none\")\n\nFor information on opening up your instance to the entire local network, and possible security concerns, see the WebServer tiddler at TiddlyWiki.com.\n\n"
},
"$:/language/Help/load": {
"title": "$:/language/Help/load",
"description": "Load tiddlers from a file",
"text": "Load tiddlers from TiddlyWiki (`.html`), `.tiddler`, `.tid`, `.json` or other local files. The processing applied to incoming files is determined by the file extension. Use the alternative `import` command if you need to specify the deserializer and encoding explicitly.\n\n```\n--load <filepath>\n--load <dirpath>\n```\n\nTo load tiddlers from an encrypted TiddlyWiki file you should first specify the password with the PasswordCommand. For example:\n\n```\ntiddlywiki ./MyWiki --password pa55w0rd --load my_encrypted_wiki.html\n```\n\nNote that TiddlyWiki will not load an older version of an already loaded plugin.\n"
},
"$:/language/Help/makelibrary": {
"title": "$:/language/Help/makelibrary",
"description": "Construct library plugin required by upgrade process",
"text": "Constructs the `$:/UpgradeLibrary` tiddler for the upgrade process.\n\nThe upgrade library is formatted as an ordinary plugin tiddler with the plugin type `library`. It contains a copy of each of the plugins, themes and language packs available within the TiddlyWiki5 repository.\n\nThis command is intended for internal use; it is only relevant to users constructing a custom upgrade procedure.\n\n```\n--makelibrary <title>\n```\n\nThe title argument defaults to `$:/UpgradeLibrary`.\n"
},
"$:/language/Help/notfound": {
"title": "$:/language/Help/notfound",
"text": "No such help item"
},
"$:/language/Help/output": {
"title": "$:/language/Help/output",
"description": "Set the base output directory for subsequent commands",
"text": "Sets the base output directory for subsequent commands. The default output directory is the `output` subdirectory of the edition directory.\n\n```\n--output <pathname>\n```\n\nIf the specified pathname is relative then it is resolved relative to the current working directory. For example `--output .` sets the output directory to the current working directory.\n\n"
},
"$:/language/Help/password": {
"title": "$:/language/Help/password",
"description": "Set a password for subsequent crypto operations",
"text": "Set a password for subsequent crypto operations\n\n```\n--password <password>\n```\n\n''Note'': This should not be used for serving TiddlyWiki with password protection. Instead, see the password option under the [[ServerCommand]].\n"
},
"$:/language/Help/render": {
"title": "$:/language/Help/render",
"description": "Renders individual tiddlers to files",
"text": "Render individual tiddlers identified by a filter and save the results to the specified files.\n\nOptionally, the title of a template tiddler can be specified. In this case, instead of directly rendering each tiddler, the template tiddler is rendered with the \"currentTiddler\" variable set to the title of the tiddler that is being rendered.\n\nA name and value for an additional variable may optionally also be specified.\n\n```\n--render <tiddler-filter> [<filename-filter>] [<render-type>] [<template>] [<name>] [<value>]\n```\n\n* ''tiddler-filter'': A filter identifying the tiddler(s) to be rendered\n* ''filename-filter'': Optional filter transforming tiddler titles into pathnames. If omitted, defaults to `[is[tiddler]addsuffix[.html]]`, which uses the unchanged tiddler title as the filename\n* ''template'': Optional template through which each tiddler is rendered\n* ''render-type'': Optional render type: `text/html` (the default) returns the full HTML text and `text/plain` just returns the text content (ie it ignores HTML tags and other unprintable material)\n* ''name'': Name of optional variable\n* ''value'': Value of optional variable\n\nBy default, the filename is resolved relative to the `output` subdirectory of the edition directory. The `--output` command can be used to direct output to a different directory.\n\nNotes:\n\n* The output directory is not cleared of any existing files\n* Any missing directories in the path to the filename are automatically created.\n* When referring to a tiddler with spaces in its title, take care to use both the quotes required by your shell and also TiddlyWiki's double square brackets : `--render \"[[Motovun Jack.jpg]]\"`\n* The filename filter is evaluated with the selected items being set to the title of the tiddler currently being rendered, allowing the title to be used as the basis for computing the filename. For example `[encodeuricomponent[]addprefix[static/]]` applies URI encoding to each title, and then adds the prefix `static/`\n* The `--render` command is a more flexible replacement for both the `--rendertiddler` and `--rendertiddlers` commands, which are deprecated\n\nExamples:\n\n* `--render \"[!is[system]]\" \"[encodeuricomponent[]addprefix[tiddlers/]addsuffix[.html]]\"` -- renders all non-system tiddlers as files in the subdirectory \"tiddlers\" with URL-encoded titles and the extension HTML\n\n"
},
"$:/language/Help/rendertiddler": {
"title": "$:/language/Help/rendertiddler",
"description": "Render an individual tiddler as a specified ContentType",
"text": "(Note: The `--rendertiddler` command is deprecated in favour of the new, more flexible `--render` command)\n\nRender an individual tiddler as a specified ContentType, defaulting to `text/html` and save it to the specified filename.\n\nOptionally the title of a template tiddler can be specified, in which case the template tiddler is rendered with the \"currentTiddler\" variable set to the tiddler that is being rendered (the first parameter value).\n\nA name and value for an additional variable may optionally also be specified.\n\n```\n--rendertiddler <title> <filename> [<type>] [<template>] [<name>] [<value>]\n```\n\nBy default, the filename is resolved relative to the `output` subdirectory of the edition directory. The `--output` command can be used to direct output to a different directory.\n\nAny missing directories in the path to the filename are automatically created.\n\nFor example, the following command saves all tiddlers matching the filter `[tag[done]]` to a JSON file titled `output.json` by employing the core template `$:/core/templates/exporters/JsonFile`.\n\n```\n--rendertiddler \"$:/core/templates/exporters/JsonFile\" output.json text/plain \"\" exportFilter \"[tag[done]]\"\n```\n"
},
"$:/language/Help/rendertiddlers": {
"title": "$:/language/Help/rendertiddlers",
"description": "Render tiddlers matching a filter to a specified ContentType",
"text": "(Note: The `--rendertiddlers` command is deprecated in favour of the new, more flexible `--render` command)\n\nRender a set of tiddlers matching a filter to separate files of a specified ContentType (defaults to `text/html`) and extension (defaults to `.html`).\n\n```\n--rendertiddlers <filter> <template> <pathname> [<type>] [<extension>] [\"noclean\"]\n```\n\nFor example:\n\n```\n--rendertiddlers [!is[system]] $:/core/templates/static.tiddler.html ./static text/plain\n```\n\nBy default, the pathname is resolved relative to the `output` subdirectory of the edition directory. The `--output` command can be used to direct output to a different directory.\n\nAny files in the target directory are deleted unless the ''noclean'' flag is specified. The target directory is recursively created if it is missing.\n"
},
"$:/language/Help/save": {
"title": "$:/language/Help/save",
"description": "Saves individual raw tiddlers to files",
"text": "Saves individual tiddlers identified by a filter in their raw text or binary format to the specified files.\n\n```\n--save <tiddler-filter> <filename-filter>\n```\n\n* ''tiddler-filter'': A filter identifying the tiddler(s) to be saved\n* ''filename-filter'': Optional filter transforming tiddler titles into pathnames. If omitted, defaults to `[is[tiddler]]`, which uses the unchanged tiddler title as the filename\n\nBy default, the filename is resolved relative to the `output` subdirectory of the edition directory. The `--output` command can be used to direct output to a different directory.\n\nNotes:\n\n* The output directory is not cleared of any existing files\n* Any missing directories in the path to the filename are automatically created.\n* When saving a tiddler with spaces in its title, take care to use both the quotes required by your shell and also TiddlyWiki's double square brackets : `--save \"[[Motovun Jack.jpg]]\"`\n* The filename filter is evaluated with the selected items being set to the title of the tiddler currently being saved, allowing the title to be used as the basis for computing the filename. For example `[encodeuricomponent[]addprefix[static/]]` applies URI encoding to each title, and then adds the prefix `static/`\n* The `--save` command is a more flexible replacement for both the `--savetiddler` and `--savetiddlers` commands, which are deprecated\n\nExamples:\n\n* `--save \"[!is[system]is[image]]\" \"[encodeuricomponent[]addprefix[tiddlers/]]\"` -- saves all non-system image tiddlers as files in the subdirectory \"tiddlers\" with URL-encoded titles\n"
},
"$:/language/Help/savetiddler": {
"title": "$:/language/Help/savetiddler",
"description": "Saves a raw tiddler to a file",
"text": "(Note: The `--savetiddler` command is deprecated in favour of the new, more flexible `--save` command)\n\nSaves an individual tiddler in its raw text or binary format to the specified filename.\n\n```\n--savetiddler <title> <filename>\n```\n\nBy default, the filename is resolved relative to the `output` subdirectory of the edition directory. The `--output` command can be used to direct output to a different directory.\n\nAny missing directories in the path to the filename are automatically created.\n"
},
"$:/language/Help/savetiddlers": {
"title": "$:/language/Help/savetiddlers",
"description": "Saves a group of raw tiddlers to a directory",
"text": "(Note: The `--savetiddlers` command is deprecated in favour of the new, more flexible `--save` command)\n\nSaves a group of tiddlers in their raw text or binary format to the specified directory.\n\n```\n--savetiddlers <filter> <pathname> [\"noclean\"]\n```\n\nBy default, the pathname is resolved relative to the `output` subdirectory of the edition directory. The `--output` command can be used to direct output to a different directory.\n\nThe output directory is cleared of existing files before saving the specified files. The deletion can be disabled by specifying the ''noclean'' flag.\n\nAny missing directories in the pathname are automatically created.\n"
},
"$:/language/Help/server": {
"title": "$:/language/Help/server",
"description": "Provides an HTTP server interface to TiddlyWiki (deprecated in favour of the new listen command)",
"text": "Legacy command to serve a wiki over HTTP.\n\n```\n--server <port> <root-tiddler> <root-render-type> <root-serve-type> <username> <password> <host> <path-prefix> <debug-level>\n```\n\nThe parameters are:\n\n* ''port'' - port number on which to listen; non-numeric values are interpreted as a system environment variable from which the port number is extracted (defaults to \"8080\")\n* ''root-tiddler'' - the tiddler to serve at the root (defaults to \"$:/core/save/all\")\n* ''root-render-type'' - the content type to which the root tiddler should be rendered (defaults to \"text/plain\")\n* ''root-serve-type'' - the content type with which the root tiddler should be served (defaults to \"text/html\")\n* ''username'' - the default username for signing edits\n* ''password'' - optional password for basic authentication\n* ''host'' - optional hostname to serve from (defaults to \"127.0.0.1\" aka \"localhost\")\n* ''path-prefix'' - optional prefix for paths\n* ''debug-level'' - optional debug level; set to \"debug\" to view request details (defaults to \"none\")\n\nIf the password parameter is specified then the browser will prompt the user for the username and password. Note that the password is transmitted in plain text so this implementation should only be used on a trusted network or over HTTPS.\n\nFor example:\n\n```\n--server 8080 $:/core/save/all text/plain text/html MyUserName passw0rd\n```\n\nThe username and password can be specified as empty strings if you need to set the hostname or pathprefix and don't want to require a password.\n\n\n```\n--server 8080 $:/core/save/all text/plain text/html \"\" \"\" 192.168.0.245\n```\n\nUsing an address like this exposes your system to the local network. For information on opening up your instance to the entire local network, and possible security concerns, see the WebServer tiddler at TiddlyWiki.com.\n\nTo run multiple TiddlyWiki servers at the same time you'll need to put each one on a different port. It can be useful to use an environment variable to pass the port number to the Node.js process. This example references an environment variable called \"MY_PORT_NUMBER\":\n\n```\n--server MY_PORT_NUMBER $:/core/save/all text/plain text/html MyUserName passw0rd\n```\n"
},
"$:/language/Help/setfield": {
"title": "$:/language/Help/setfield",
"description": "Prepares external tiddlers for use",
"text": "//Note that this command is experimental and may change or be replaced before being finalised//\n\nSets the specified field of a group of tiddlers to the result of wikifying a template tiddler with the `currentTiddler` variable set to the tiddler.\n\n```\n--setfield <filter> <fieldname> <templatetitle> <rendertype>\n```\n\nThe parameters are:\n\n* ''filter'' - filter identifying the tiddlers to be affected\n* ''fieldname'' - the field to modify (defaults to \"text\")\n* ''templatetitle'' - the tiddler to wikify into the specified field. If blank or missing then the specified field is deleted\n* ''rendertype'' - the text type to render (defaults to \"text/plain\"; \"text/html\" can be used to include HTML tags)\n"
},
"$:/language/Help/unpackplugin": {
"title": "$:/language/Help/unpackplugin",
"description": "Unpack the payload tiddlers from a plugin",
"text": "Extract the payload tiddlers from a plugin, creating them as ordinary tiddlers:\n\n```\n--unpackplugin <title>\n```\n"
},
"$:/language/Help/verbose": {
"title": "$:/language/Help/verbose",
"description": "Triggers verbose output mode",
"text": "Triggers verbose output, useful for debugging\n\n```\n--verbose\n```\n"
},
"$:/language/Help/version": {
"title": "$:/language/Help/version",
"description": "Displays the version number of TiddlyWiki",
"text": "Displays the version number of TiddlyWiki.\n\n```\n--version\n```\n"
},
"$:/language/Import/Imported/Hint": {
"title": "$:/language/Import/Imported/Hint",
"text": "The following tiddlers were imported:"
},
"$:/language/Import/Listing/Cancel/Caption": {
"title": "$:/language/Import/Listing/Cancel/Caption",
"text": "Cancel"
},
"$:/language/Import/Listing/Hint": {
"title": "$:/language/Import/Listing/Hint",
"text": "These tiddlers are ready to import:"
},
"$:/language/Import/Listing/Import/Caption": {
"title": "$:/language/Import/Listing/Import/Caption",
"text": "Import"
},
"$:/language/Import/Listing/Select/Caption": {
"title": "$:/language/Import/Listing/Select/Caption",
"text": "Select"
},
"$:/language/Import/Listing/Status/Caption": {
"title": "$:/language/Import/Listing/Status/Caption",
"text": "Status"
},
"$:/language/Import/Listing/Title/Caption": {
"title": "$:/language/Import/Listing/Title/Caption",
"text": "Title"
},
"$:/language/Import/Listing/Preview": {
"title": "$:/language/Import/Listing/Preview",
"text": "Preview:"
},
"$:/language/Import/Listing/Preview/Text": {
"title": "$:/language/Import/Listing/Preview/Text",
"text": "Text"
},
"$:/language/Import/Listing/Preview/TextRaw": {
"title": "$:/language/Import/Listing/Preview/TextRaw",
"text": "Text (Raw)"
},
"$:/language/Import/Listing/Preview/Fields": {
"title": "$:/language/Import/Listing/Preview/Fields",
"text": "Fields"
},
"$:/language/Import/Listing/Preview/Diff": {
"title": "$:/language/Import/Listing/Preview/Diff",
"text": "Diff"
},
"$:/language/Import/Listing/Preview/DiffFields": {
"title": "$:/language/Import/Listing/Preview/DiffFields",
"text": "Diff (Fields)"
},
"$:/language/Import/Upgrader/Plugins/Suppressed/Incompatible": {
"title": "$:/language/Import/Upgrader/Plugins/Suppressed/Incompatible",
"text": "Blocked incompatible or obsolete plugin"
},
"$:/language/Import/Upgrader/Plugins/Suppressed/Version": {
"title": "$:/language/Import/Upgrader/Plugins/Suppressed/Version",
"text": "Blocked plugin (due to incoming <<incoming>> being older than existing <<existing>>)"
},
"$:/language/Import/Upgrader/Plugins/Upgraded": {
"title": "$:/language/Import/Upgrader/Plugins/Upgraded",
"text": "Upgraded plugin from <<incoming>> to <<upgraded>>"
},
"$:/language/Import/Upgrader/State/Suppressed": {
"title": "$:/language/Import/Upgrader/State/Suppressed",
"text": "Blocked temporary state tiddler"
},
"$:/language/Import/Upgrader/System/Suppressed": {
"title": "$:/language/Import/Upgrader/System/Suppressed",
"text": "Blocked system tiddler"
},
"$:/language/Import/Upgrader/ThemeTweaks/Created": {
"title": "$:/language/Import/Upgrader/ThemeTweaks/Created",
"text": "Migrated theme tweak from <$text text=<<from>>/>"
},
"$:/language/AboveStory/ClassicPlugin/Warning": {
"title": "$:/language/AboveStory/ClassicPlugin/Warning",
"text": "It looks like you are trying to load a plugin designed for ~TiddlyWiki Classic. Please note that [[these plugins do not work with TiddlyWiki version 5.x.x|https://tiddlywiki.com/#TiddlyWikiClassic]]. ~TiddlyWiki Classic plugins detected:"
},
"$:/language/BinaryWarning/Prompt": {
"title": "$:/language/BinaryWarning/Prompt",
"text": "This tiddler contains binary data"
},
"$:/language/ClassicWarning/Hint": {
"title": "$:/language/ClassicWarning/Hint",
"text": "This tiddler is written in TiddlyWiki Classic wiki text format, which is not fully compatible with TiddlyWiki version 5. See https://tiddlywiki.com/static/Upgrading.html for more details."
},
"$:/language/ClassicWarning/Upgrade/Caption": {
"title": "$:/language/ClassicWarning/Upgrade/Caption",
"text": "upgrade"
},
"$:/language/CloseAll/Button": {
"title": "$:/language/CloseAll/Button",
"text": "close all"
},
"$:/language/ColourPicker/Recent": {
"title": "$:/language/ColourPicker/Recent",
"text": "Recent:"
},
"$:/language/ConfirmCancelTiddler": {
"title": "$:/language/ConfirmCancelTiddler",
"text": "Do you wish to discard changes to the tiddler \"<$text text=<<title>>/>\"?"
},
"$:/language/ConfirmDeleteTiddler": {
"title": "$:/language/ConfirmDeleteTiddler",
"text": "Do you wish to delete the tiddler \"<$text text=<<title>>/>\"?"
},
"$:/language/ConfirmOverwriteTiddler": {
"title": "$:/language/ConfirmOverwriteTiddler",
"text": "Do you wish to overwrite the tiddler \"<$text text=<<title>>/>\"?"
},
"$:/language/ConfirmEditShadowTiddler": {
"title": "$:/language/ConfirmEditShadowTiddler",
"text": "You are about to edit a ShadowTiddler. Any changes will override the default system making future upgrades non-trivial. Are you sure you want to edit \"<$text text=<<title>>/>\"?"
},
"$:/language/Count": {
"title": "$:/language/Count",
"text": "count"
},
"$:/language/DefaultNewTiddlerTitle": {
"title": "$:/language/DefaultNewTiddlerTitle",
"text": "New Tiddler"
},
"$:/language/Diffs/CountMessage": {
"title": "$:/language/Diffs/CountMessage",
"text": "<<diff-count>> differences"
},
"$:/language/DropMessage": {
"title": "$:/language/DropMessage",
"text": "Drop here (or use the 'Escape' key to cancel)"
},
"$:/language/Encryption/Cancel": {
"title": "$:/language/Encryption/Cancel",
"text": "Cancel"
},
"$:/language/Encryption/ConfirmClearPassword": {
"title": "$:/language/Encryption/ConfirmClearPassword",
"text": "Do you wish to clear the password? This will remove the encryption applied when saving this wiki"
},
"$:/language/Encryption/PromptSetPassword": {
"title": "$:/language/Encryption/PromptSetPassword",
"text": "Set a new password for this TiddlyWiki"
},
"$:/language/Encryption/Username": {
"title": "$:/language/Encryption/Username",
"text": "Username"
},
"$:/language/Encryption/Password": {
"title": "$:/language/Encryption/Password",
"text": "Password"
},
"$:/language/Encryption/RepeatPassword": {
"title": "$:/language/Encryption/RepeatPassword",
"text": "Repeat password"
},
"$:/language/Encryption/PasswordNoMatch": {
"title": "$:/language/Encryption/PasswordNoMatch",
"text": "Passwords do not match"
},
"$:/language/Encryption/SetPassword": {
"title": "$:/language/Encryption/SetPassword",
"text": "Set password"
},
"$:/language/Error/Caption": {
"title": "$:/language/Error/Caption",
"text": "Error"
},
"$:/language/Error/EditConflict": {
"title": "$:/language/Error/EditConflict",
"text": "File changed on server"
},
"$:/language/Error/Filter": {
"title": "$:/language/Error/Filter",
"text": "Filter error"
},
"$:/language/Error/FilterSyntax": {
"title": "$:/language/Error/FilterSyntax",
"text": "Syntax error in filter expression"
},
"$:/language/Error/IsFilterOperator": {
"title": "$:/language/Error/IsFilterOperator",
"text": "Filter Error: Unknown operand for the 'is' filter operator"
},
"$:/language/Error/LoadingPluginLibrary": {
"title": "$:/language/Error/LoadingPluginLibrary",
"text": "Error loading plugin library"
},
"$:/language/Error/RecursiveTransclusion": {
"title": "$:/language/Error/RecursiveTransclusion",
"text": "Recursive transclusion error in transclude widget"
},
"$:/language/Error/RetrievingSkinny": {
"title": "$:/language/Error/RetrievingSkinny",
"text": "Error retrieving skinny tiddler list"
},
"$:/language/Error/SavingToTWEdit": {
"title": "$:/language/Error/SavingToTWEdit",
"text": "Error saving to TWEdit"
},
"$:/language/Error/WhileSaving": {
"title": "$:/language/Error/WhileSaving",
"text": "Error while saving"
},
"$:/language/Error/XMLHttpRequest": {
"title": "$:/language/Error/XMLHttpRequest",
"text": "XMLHttpRequest error code"
},
"$:/language/InternalJavaScriptError/Title": {
"title": "$:/language/InternalJavaScriptError/Title",
"text": "Internal JavaScript Error"
},
"$:/language/InternalJavaScriptError/Hint": {
"title": "$:/language/InternalJavaScriptError/Hint",
"text": "Well, this is embarrassing. It is recommended that you restart TiddlyWiki by refreshing your browser"
},
"$:/language/InvalidFieldName": {
"title": "$:/language/InvalidFieldName",
"text": "Illegal characters in field name \"<$text text=<<fieldName>>/>\". Fields can only contain lowercase letters, digits and the characters underscore (`_`), hyphen (`-`) and period (`.`)"
},
"$:/language/LazyLoadingWarning": {
"title": "$:/language/LazyLoadingWarning",
"text": "<p>Trying to load external content from ''<$text text={{!!_canonical_uri}}/>''</p><p>If this message doesn't disappear, either the tiddler content type doesn't match the type of the external content, or you may be using a browser that doesn't support external content for wikis loaded as standalone files. See https://tiddlywiki.com/#ExternalText</p>"
},
"$:/language/LoginToTiddlySpace": {
"title": "$:/language/LoginToTiddlySpace",
"text": "Login to TiddlySpace"
},
"$:/language/Manager/Controls/FilterByTag/None": {
"title": "$:/language/Manager/Controls/FilterByTag/None",
"text": "(none)"
},
"$:/language/Manager/Controls/FilterByTag/Prompt": {
"title": "$:/language/Manager/Controls/FilterByTag/Prompt",
"text": "Filter by tag:"
},
"$:/language/Manager/Controls/Order/Prompt": {
"title": "$:/language/Manager/Controls/Order/Prompt",
"text": "Reverse order"
},
"$:/language/Manager/Controls/Search/Placeholder": {
"title": "$:/language/Manager/Controls/Search/Placeholder",
"text": "Search"
},
"$:/language/Manager/Controls/Search/Prompt": {
"title": "$:/language/Manager/Controls/Search/Prompt",
"text": "Search:"
},
"$:/language/Manager/Controls/Show/Option/Tags": {
"title": "$:/language/Manager/Controls/Show/Option/Tags",
"text": "tags"
},
"$:/language/Manager/Controls/Show/Option/Tiddlers": {
"title": "$:/language/Manager/Controls/Show/Option/Tiddlers",
"text": "tiddlers"
},
"$:/language/Manager/Controls/Show/Prompt": {
"title": "$:/language/Manager/Controls/Show/Prompt",
"text": "Show:"
},
"$:/language/Manager/Controls/Sort/Prompt": {
"title": "$:/language/Manager/Controls/Sort/Prompt",
"text": "Sort by:"
},
"$:/language/Manager/Item/Colour": {
"title": "$:/language/Manager/Item/Colour",
"text": "Colour"
},
"$:/language/Manager/Item/Fields": {
"title": "$:/language/Manager/Item/Fields",
"text": "Fields"
},
"$:/language/Manager/Item/Icon/None": {
"title": "$:/language/Manager/Item/Icon/None",
"text": "(none)"
},
"$:/language/Manager/Item/Icon": {
"title": "$:/language/Manager/Item/Icon",
"text": "Icon"
},
"$:/language/Manager/Item/RawText": {
"title": "$:/language/Manager/Item/RawText",
"text": "Raw text"
},
"$:/language/Manager/Item/Tags": {
"title": "$:/language/Manager/Item/Tags",
"text": "Tags"
},
"$:/language/Manager/Item/Tools": {
"title": "$:/language/Manager/Item/Tools",
"text": "Tools"
},
"$:/language/Manager/Item/WikifiedText": {
"title": "$:/language/Manager/Item/WikifiedText",
"text": "Wikified text"
},
"$:/language/MissingTiddler/Hint": {
"title": "$:/language/MissingTiddler/Hint",
"text": "Missing tiddler \"<$text text=<<currentTiddler>>/>\" -- click {{||$:/core/ui/Buttons/edit}} to create"
},
"$:/language/No": {
"title": "$:/language/No",
"text": "No"
},
"$:/language/OfficialPluginLibrary": {
"title": "$:/language/OfficialPluginLibrary",
"text": "Official ~TiddlyWiki Plugin Library"
},
"$:/language/OfficialPluginLibrary/Hint": {
"title": "$:/language/OfficialPluginLibrary/Hint",
"text": "The official ~TiddlyWiki plugin library at tiddlywiki.com. Plugins, themes and language packs are maintained by the core team."
},
"$:/language/PluginReloadWarning": {
"title": "$:/language/PluginReloadWarning",
"text": "Please save {{$:/core/ui/Buttons/save-wiki}} and reload {{$:/core/ui/Buttons/refresh}} to allow changes to plugins to take effect"
},
"$:/language/RecentChanges/DateFormat": {
"title": "$:/language/RecentChanges/DateFormat",
"text": "DDth MMM YYYY"
},
"$:/language/SystemTiddler/Tooltip": {
"title": "$:/language/SystemTiddler/Tooltip",
"text": "This is a system tiddler"
},
"$:/language/SystemTiddlers/Include/Prompt": {
"title": "$:/language/SystemTiddlers/Include/Prompt",
"text": "Include system tiddlers"
},
"$:/language/TagManager/Colour/Heading": {
"title": "$:/language/TagManager/Colour/Heading",
"text": "Colour"
},
"$:/language/TagManager/Count/Heading": {
"title": "$:/language/TagManager/Count/Heading",
"text": "Count"
},
"$:/language/TagManager/Icon/Heading": {
"title": "$:/language/TagManager/Icon/Heading",
"text": "Icon"
},
"$:/language/TagManager/Info/Heading": {
"title": "$:/language/TagManager/Info/Heading",
"text": "Info"
},
"$:/language/TagManager/Tag/Heading": {
"title": "$:/language/TagManager/Tag/Heading",
"text": "Tag"
},
"$:/language/Tiddler/DateFormat": {
"title": "$:/language/Tiddler/DateFormat",
"text": "DDth MMM YYYY at hh12:0mmam"
},
"$:/language/UnsavedChangesWarning": {
"title": "$:/language/UnsavedChangesWarning",
"text": "You have unsaved changes in TiddlyWiki"
},
"$:/language/Yes": {
"title": "$:/language/Yes",
"text": "Yes"
},
"$:/language/Modals/Download": {
"title": "$:/language/Modals/Download",
"subtitle": "Download changes",
"footer": "<$button message=\"tm-close-tiddler\">Close</$button>",
"help": "https://tiddlywiki.com/static/DownloadingChanges.html",
"text": "Your browser only supports manual saving.\n\nTo save your modified wiki, right click on the download link below and select \"Download file\" or \"Save file\", and then choose the folder and filename.\n\n//You can marginally speed things up by clicking the link with the control key (Windows) or the options/alt key (Mac OS X). You will not be prompted for the folder or filename, but your browser is likely to give it an unrecognisable name -- you may need to rename the file to include an `.html` extension before you can do anything useful with it.//\n\nOn smartphones that do not allow files to be downloaded you can instead bookmark the link, and then sync your bookmarks to a desktop computer from where the wiki can be saved normally.\n"
},
"$:/language/Modals/SaveInstructions": {
"title": "$:/language/Modals/SaveInstructions",
"subtitle": "Save your work",
"footer": "<$button message=\"tm-close-tiddler\">Close</$button>",
"help": "https://tiddlywiki.com/static/SavingChanges.html",
"text": "Your changes to this wiki need to be saved as a ~TiddlyWiki HTML file.\n\n!!! Desktop browsers\n\n# Select ''Save As'' from the ''File'' menu\n# Choose a filename and location\n#* Some browsers also require you to explicitly specify the file saving format as ''Webpage, HTML only'' or similar\n# Close this tab\n\n!!! Smartphone browsers\n\n# Create a bookmark to this page\n#* If you've got iCloud or Google Sync set up then the bookmark will automatically sync to your desktop where you can open it and save it as above\n# Close this tab\n\n//If you open the bookmark again in Mobile Safari you will see this message again. If you want to go ahead and use the file, just click the ''close'' button below//\n"
},
"$:/config/NewJournal/Title": {
"title": "$:/config/NewJournal/Title",
"text": "DDth MMM YYYY"
},
"$:/config/NewJournal/Text": {
"title": "$:/config/NewJournal/Text",
"text": ""
},
"$:/config/NewJournal/Tags": {
"title": "$:/config/NewJournal/Tags",
"text": "Journal"
},
"$:/language/Notifications/Save/Done": {
"title": "$:/language/Notifications/Save/Done",
"text": "Saved wiki"
},
"$:/language/Notifications/Save/Starting": {
"title": "$:/language/Notifications/Save/Starting",
"text": "Starting to save wiki"
},
"$:/language/Notifications/CopiedToClipboard/Succeeded": {
"title": "$:/language/Notifications/CopiedToClipboard/Succeeded",
"text": "Copied to clipboard!"
},
"$:/language/Notifications/CopiedToClipboard/Failed": {
"title": "$:/language/Notifications/CopiedToClipboard/Failed",
"text": "Failed to copy to clipboard!"
},
"$:/language/Search/DefaultResults/Caption": {
"title": "$:/language/Search/DefaultResults/Caption",
"text": "List"
},
"$:/language/Search/Filter/Caption": {
"title": "$:/language/Search/Filter/Caption",
"text": "Filter"
},
"$:/language/Search/Filter/Hint": {
"title": "$:/language/Search/Filter/Hint",
"text": "Search via a [[filter expression|https://tiddlywiki.com/static/Filters.html]]"
},
"$:/language/Search/Filter/Matches": {
"title": "$:/language/Search/Filter/Matches",
"text": "//<small><<resultCount>> matches</small>//"
},
"$:/language/Search/Matches": {
"title": "$:/language/Search/Matches",
"text": "//<small><<resultCount>> matches</small>//"
},
"$:/language/Search/Matches/All": {
"title": "$:/language/Search/Matches/All",
"text": "All matches:"
},
"$:/language/Search/Matches/Title": {
"title": "$:/language/Search/Matches/Title",
"text": "Title matches:"
},
"$:/language/Search/Search": {
"title": "$:/language/Search/Search",
"text": "Search"
},
"$:/language/Search/Search/TooShort": {
"title": "$:/language/Search/Search/TooShort",
"text": "Search text too short"
},
"$:/language/Search/Shadows/Caption": {
"title": "$:/language/Search/Shadows/Caption",
"text": "Shadows"
},
"$:/language/Search/Shadows/Hint": {
"title": "$:/language/Search/Shadows/Hint",
"text": "Search for shadow tiddlers"
},
"$:/language/Search/Shadows/Matches": {
"title": "$:/language/Search/Shadows/Matches",
"text": "//<small><<resultCount>> matches</small>//"
},
"$:/language/Search/Standard/Caption": {
"title": "$:/language/Search/Standard/Caption",
"text": "Standard"
},
"$:/language/Search/Standard/Hint": {
"title": "$:/language/Search/Standard/Hint",
"text": "Search for standard tiddlers"
},
"$:/language/Search/Standard/Matches": {
"title": "$:/language/Search/Standard/Matches",
"text": "//<small><<resultCount>> matches</small>//"
},
"$:/language/Search/System/Caption": {
"title": "$:/language/Search/System/Caption",
"text": "System"
},
"$:/language/Search/System/Hint": {
"title": "$:/language/Search/System/Hint",
"text": "Search for system tiddlers"
},
"$:/language/Search/System/Matches": {
"title": "$:/language/Search/System/Matches",
"text": "//<small><<resultCount>> matches</small>//"
},
"$:/language/SideBar/All/Caption": {
"title": "$:/language/SideBar/All/Caption",
"text": "All"
},
"$:/language/SideBar/Contents/Caption": {
"title": "$:/language/SideBar/Contents/Caption",
"text": "Contents"
},
"$:/language/SideBar/Drafts/Caption": {
"title": "$:/language/SideBar/Drafts/Caption",
"text": "Drafts"
},
"$:/language/SideBar/Explorer/Caption": {
"title": "$:/language/SideBar/Explorer/Caption",
"text": "Explorer"
},
"$:/language/SideBar/Missing/Caption": {
"title": "$:/language/SideBar/Missing/Caption",
"text": "Missing"
},
"$:/language/SideBar/More/Caption": {
"title": "$:/language/SideBar/More/Caption",
"text": "More"
},
"$:/language/SideBar/Open/Caption": {
"title": "$:/language/SideBar/Open/Caption",
"text": "Open"
},
"$:/language/SideBar/Orphans/Caption": {
"title": "$:/language/SideBar/Orphans/Caption",
"text": "Orphans"
},
"$:/language/SideBar/Recent/Caption": {
"title": "$:/language/SideBar/Recent/Caption",
"text": "Recent"
},
"$:/language/SideBar/Shadows/Caption": {
"title": "$:/language/SideBar/Shadows/Caption",
"text": "Shadows"
},
"$:/language/SideBar/System/Caption": {
"title": "$:/language/SideBar/System/Caption",
"text": "System"
},
"$:/language/SideBar/Tags/Caption": {
"title": "$:/language/SideBar/Tags/Caption",
"text": "Tags"
},
"$:/language/SideBar/Tags/Untagged/Caption": {
"title": "$:/language/SideBar/Tags/Untagged/Caption",
"text": "untagged"
},
"$:/language/SideBar/Tools/Caption": {
"title": "$:/language/SideBar/Tools/Caption",
"text": "Tools"
},
"$:/language/SideBar/Types/Caption": {
"title": "$:/language/SideBar/Types/Caption",
"text": "Types"
},
"$:/SiteSubtitle": {
"title": "$:/SiteSubtitle",
"text": "a non-linear personal web notebook"
},
"$:/SiteTitle": {
"title": "$:/SiteTitle",
"text": "My ~TiddlyWiki"
},
"$:/language/Snippets/ListByTag": {
"title": "$:/language/Snippets/ListByTag",
"tags": "$:/tags/TextEditor/Snippet",
"caption": "List of tiddlers by tag",
"text": "<<list-links \"[tag[task]sort[title]]\">>\n"
},
"$:/language/Snippets/MacroDefinition": {
"title": "$:/language/Snippets/MacroDefinition",
"tags": "$:/tags/TextEditor/Snippet",
"caption": "Macro definition",
"text": "\\define macroName(param1:\"default value\",param2)\nText of the macro\n\\end\n"
},
"$:/language/Snippets/Table4x3": {
"title": "$:/language/Snippets/Table4x3",
"tags": "$:/tags/TextEditor/Snippet",
"caption": "Table with 4 columns by 3 rows",
"text": "|! |!Alpha |!Beta |!Gamma |!Delta |\n|!One | | | | |\n|!Two | | | | |\n|!Three | | | | |\n"
},
"$:/language/Snippets/TableOfContents": {
"title": "$:/language/Snippets/TableOfContents",
"tags": "$:/tags/TextEditor/Snippet",
"caption": "Table of Contents",
"text": "<div class=\"tc-table-of-contents\">\n\n<<toc-selective-expandable 'TableOfContents'>>\n\n</div>"
},
"$:/language/ThemeTweaks/ThemeTweaks": {
"title": "$:/language/ThemeTweaks/ThemeTweaks",
"text": "Theme Tweaks"
},
"$:/language/ThemeTweaks/ThemeTweaks/Hint": {
"title": "$:/language/ThemeTweaks/ThemeTweaks/Hint",
"text": "You can tweak certain aspects of the ''Vanilla'' theme."
},
"$:/language/ThemeTweaks/Options": {
"title": "$:/language/ThemeTweaks/Options",
"text": "Options"
},
"$:/language/ThemeTweaks/Options/SidebarLayout": {
"title": "$:/language/ThemeTweaks/Options/SidebarLayout",
"text": "Sidebar layout"
},
"$:/language/ThemeTweaks/Options/SidebarLayout/Fixed-Fluid": {
"title": "$:/language/ThemeTweaks/Options/SidebarLayout/Fixed-Fluid",
"text": "Fixed story, fluid sidebar"
},
"$:/language/ThemeTweaks/Options/SidebarLayout/Fluid-Fixed": {
"title": "$:/language/ThemeTweaks/Options/SidebarLayout/Fluid-Fixed",
"text": "Fluid story, fixed sidebar"
},
"$:/language/ThemeTweaks/Options/StickyTitles": {
"title": "$:/language/ThemeTweaks/Options/StickyTitles",
"text": "Sticky titles"
},
"$:/language/ThemeTweaks/Options/StickyTitles/Hint": {
"title": "$:/language/ThemeTweaks/Options/StickyTitles/Hint",
"text": "Causes tiddler titles to \"stick\" to the top of the browser window"
},
"$:/language/ThemeTweaks/Options/CodeWrapping": {
"title": "$:/language/ThemeTweaks/Options/CodeWrapping",
"text": "Wrap long lines in code blocks"
},
"$:/language/ThemeTweaks/Settings": {
"title": "$:/language/ThemeTweaks/Settings",
"text": "Settings"
},
"$:/language/ThemeTweaks/Settings/FontFamily": {
"title": "$:/language/ThemeTweaks/Settings/FontFamily",
"text": "Font family"
},
"$:/language/ThemeTweaks/Settings/CodeFontFamily": {
"title": "$:/language/ThemeTweaks/Settings/CodeFontFamily",
"text": "Code font family"
},
"$:/language/ThemeTweaks/Settings/EditorFontFamily": {
"title": "$:/language/ThemeTweaks/Settings/EditorFontFamily",
"text": "Editor font family"
},
"$:/language/ThemeTweaks/Settings/BackgroundImage": {
"title": "$:/language/ThemeTweaks/Settings/BackgroundImage",
"text": "Page background image"
},
"$:/language/ThemeTweaks/Settings/BackgroundImageAttachment": {
"title": "$:/language/ThemeTweaks/Settings/BackgroundImageAttachment",
"text": "Page background image attachment"
},
"$:/language/ThemeTweaks/Settings/BackgroundImageAttachment/Scroll": {
"title": "$:/language/ThemeTweaks/Settings/BackgroundImageAttachment/Scroll",
"text": "Scroll with tiddlers"
},
"$:/language/ThemeTweaks/Settings/BackgroundImageAttachment/Fixed": {
"title": "$:/language/ThemeTweaks/Settings/BackgroundImageAttachment/Fixed",
"text": "Fixed to window"
},
"$:/language/ThemeTweaks/Settings/BackgroundImageSize": {
"title": "$:/language/ThemeTweaks/Settings/BackgroundImageSize",
"text": "Page background image size"
},
"$:/language/ThemeTweaks/Settings/BackgroundImageSize/Auto": {
"title": "$:/language/ThemeTweaks/Settings/BackgroundImageSize/Auto",
"text": "Auto"
},
"$:/language/ThemeTweaks/Settings/BackgroundImageSize/Cover": {
"title": "$:/language/ThemeTweaks/Settings/BackgroundImageSize/Cover",
"text": "Cover"
},
"$:/language/ThemeTweaks/Settings/BackgroundImageSize/Contain": {
"title": "$:/language/ThemeTweaks/Settings/BackgroundImageSize/Contain",
"text": "Contain"
},
"$:/language/ThemeTweaks/Metrics": {
"title": "$:/language/ThemeTweaks/Metrics",
"text": "Sizes"
},
"$:/language/ThemeTweaks/Metrics/FontSize": {
"title": "$:/language/ThemeTweaks/Metrics/FontSize",
"text": "Font size"
},
"$:/language/ThemeTweaks/Metrics/LineHeight": {
"title": "$:/language/ThemeTweaks/Metrics/LineHeight",
"text": "Line height"
},
"$:/language/ThemeTweaks/Metrics/BodyFontSize": {
"title": "$:/language/ThemeTweaks/Metrics/BodyFontSize",
"text": "Font size for tiddler body"
},
"$:/language/ThemeTweaks/Metrics/BodyLineHeight": {
"title": "$:/language/ThemeTweaks/Metrics/BodyLineHeight",
"text": "Line height for tiddler body"
},
"$:/language/ThemeTweaks/Metrics/StoryLeft": {
"title": "$:/language/ThemeTweaks/Metrics/StoryLeft",
"text": "Story left position"
},
"$:/language/ThemeTweaks/Metrics/StoryLeft/Hint": {
"title": "$:/language/ThemeTweaks/Metrics/StoryLeft/Hint",
"text": "how far the left margin of the story river<br>(tiddler area) is from the left of the page"
},
"$:/language/ThemeTweaks/Metrics/StoryTop": {
"title": "$:/language/ThemeTweaks/Metrics/StoryTop",
"text": "Story top position"
},
"$:/language/ThemeTweaks/Metrics/StoryTop/Hint": {
"title": "$:/language/ThemeTweaks/Metrics/StoryTop/Hint",
"text": "how far the top margin of the story river<br>is from the top of the page"
},
"$:/language/ThemeTweaks/Metrics/StoryRight": {
"title": "$:/language/ThemeTweaks/Metrics/StoryRight",
"text": "Story right"
},
"$:/language/ThemeTweaks/Metrics/StoryRight/Hint": {
"title": "$:/language/ThemeTweaks/Metrics/StoryRight/Hint",
"text": "how far the left margin of the sidebar <br>is from the left of the page"
},
"$:/language/ThemeTweaks/Metrics/StoryWidth": {
"title": "$:/language/ThemeTweaks/Metrics/StoryWidth",
"text": "Story width"
},
"$:/language/ThemeTweaks/Metrics/StoryWidth/Hint": {
"title": "$:/language/ThemeTweaks/Metrics/StoryWidth/Hint",
"text": "the overall width of the story river"
},
"$:/language/ThemeTweaks/Metrics/TiddlerWidth": {
"title": "$:/language/ThemeTweaks/Metrics/TiddlerWidth",
"text": "Tiddler width"
},
"$:/language/ThemeTweaks/Metrics/TiddlerWidth/Hint": {
"title": "$:/language/ThemeTweaks/Metrics/TiddlerWidth/Hint",
"text": "within the story river"
},
"$:/language/ThemeTweaks/Metrics/SidebarBreakpoint": {
"title": "$:/language/ThemeTweaks/Metrics/SidebarBreakpoint",
"text": "Sidebar breakpoint"
},
"$:/language/ThemeTweaks/Metrics/SidebarBreakpoint/Hint": {
"title": "$:/language/ThemeTweaks/Metrics/SidebarBreakpoint/Hint",
"text": "the minimum page width at which the story<br>river and sidebar will appear side by side"
},
"$:/language/ThemeTweaks/Metrics/SidebarWidth": {
"title": "$:/language/ThemeTweaks/Metrics/SidebarWidth",
"text": "Sidebar width"
},
"$:/language/ThemeTweaks/Metrics/SidebarWidth/Hint": {
"title": "$:/language/ThemeTweaks/Metrics/SidebarWidth/Hint",
"text": "the width of the sidebar in fluid-fixed layout"
},
"$:/language/TiddlerInfo/Advanced/Caption": {
"title": "$:/language/TiddlerInfo/Advanced/Caption",
"text": "Advanced"
},
"$:/language/TiddlerInfo/Advanced/PluginInfo/Empty/Hint": {
"title": "$:/language/TiddlerInfo/Advanced/PluginInfo/Empty/Hint",
"text": "none"
},
"$:/language/TiddlerInfo/Advanced/PluginInfo/Heading": {
"title": "$:/language/TiddlerInfo/Advanced/PluginInfo/Heading",
"text": "Plugin Details"
},
"$:/language/TiddlerInfo/Advanced/PluginInfo/Hint": {
"title": "$:/language/TiddlerInfo/Advanced/PluginInfo/Hint",
"text": "This plugin contains the following shadow tiddlers:"
},
"$:/language/TiddlerInfo/Advanced/ShadowInfo/Heading": {
"title": "$:/language/TiddlerInfo/Advanced/ShadowInfo/Heading",
"text": "Shadow Status"
},
"$:/language/TiddlerInfo/Advanced/ShadowInfo/NotShadow/Hint": {
"title": "$:/language/TiddlerInfo/Advanced/ShadowInfo/NotShadow/Hint",
"text": "The tiddler <$link to=<<infoTiddler>>><$text text=<<infoTiddler>>/></$link> is not a shadow tiddler"
},
"$:/language/TiddlerInfo/Advanced/ShadowInfo/Shadow/Hint": {
"title": "$:/language/TiddlerInfo/Advanced/ShadowInfo/Shadow/Hint",
"text": "The tiddler <$link to=<<infoTiddler>>><$text text=<<infoTiddler>>/></$link> is a shadow tiddler"
},
"$:/language/TiddlerInfo/Advanced/ShadowInfo/Shadow/Source": {
"title": "$:/language/TiddlerInfo/Advanced/ShadowInfo/Shadow/Source",
"text": "It is defined in the plugin <$link to=<<pluginTiddler>>><$text text=<<pluginTiddler>>/></$link>"
},
"$:/language/TiddlerInfo/Advanced/ShadowInfo/OverriddenShadow/Hint": {
"title": "$:/language/TiddlerInfo/Advanced/ShadowInfo/OverriddenShadow/Hint",
"text": "It is overridden by an ordinary tiddler"
},
"$:/language/TiddlerInfo/Fields/Caption": {
"title": "$:/language/TiddlerInfo/Fields/Caption",
"text": "Fields"
},
"$:/language/TiddlerInfo/List/Caption": {
"title": "$:/language/TiddlerInfo/List/Caption",
"text": "List"
},
"$:/language/TiddlerInfo/List/Empty": {
"title": "$:/language/TiddlerInfo/List/Empty",
"text": "This tiddler does not have a list"
},
"$:/language/TiddlerInfo/Listed/Caption": {
"title": "$:/language/TiddlerInfo/Listed/Caption",
"text": "Listed"
},
"$:/language/TiddlerInfo/Listed/Empty": {
"title": "$:/language/TiddlerInfo/Listed/Empty",
"text": "This tiddler is not listed by any others"
},
"$:/language/TiddlerInfo/References/Caption": {
"title": "$:/language/TiddlerInfo/References/Caption",
"text": "References"
},
"$:/language/TiddlerInfo/References/Empty": {
"title": "$:/language/TiddlerInfo/References/Empty",
"text": "No tiddlers link to this one"
},
"$:/language/TiddlerInfo/Tagging/Caption": {
"title": "$:/language/TiddlerInfo/Tagging/Caption",
"text": "Tagging"
},
"$:/language/TiddlerInfo/Tagging/Empty": {
"title": "$:/language/TiddlerInfo/Tagging/Empty",
"text": "No tiddlers are tagged with this one"
},
"$:/language/TiddlerInfo/Tools/Caption": {
"title": "$:/language/TiddlerInfo/Tools/Caption",
"text": "Tools"
},
"$:/language/Docs/Types/application/javascript": {
"title": "$:/language/Docs/Types/application/javascript",
"description": "JavaScript code",
"name": "application/javascript",
"group": "Developer",
"group-sort": "2"
},
"$:/language/Docs/Types/application/json": {
"title": "$:/language/Docs/Types/application/json",
"description": "JSON data",
"name": "application/json",
"group": "Developer",
"group-sort": "2"
},
"$:/language/Docs/Types/application/x-tiddler-dictionary": {
"title": "$:/language/Docs/Types/application/x-tiddler-dictionary",
"description": "Data dictionary",
"name": "application/x-tiddler-dictionary",
"group": "Developer",
"group-sort": "2"
},
"$:/language/Docs/Types/image/gif": {
"title": "$:/language/Docs/Types/image/gif",
"description": "GIF image",
"name": "image/gif",
"group": "Image",
"group-sort": "1"
},
"$:/language/Docs/Types/image/jpeg": {
"title": "$:/language/Docs/Types/image/jpeg",
"description": "JPEG image",
"name": "image/jpeg",
"group": "Image",
"group-sort": "1"
},
"$:/language/Docs/Types/image/png": {
"title": "$:/language/Docs/Types/image/png",
"description": "PNG image",
"name": "image/png",
"group": "Image",
"group-sort": "1"
},
"$:/language/Docs/Types/image/svg+xml": {
"title": "$:/language/Docs/Types/image/svg+xml",
"description": "Structured Vector Graphics image",
"name": "image/svg+xml",
"group": "Image",
"group-sort": "1"
},
"$:/language/Docs/Types/image/x-icon": {
"title": "$:/language/Docs/Types/image/x-icon",
"description": "ICO format icon file",
"name": "image/x-icon",
"group": "Image",
"group-sort": "1"
},
"$:/language/Docs/Types/text/css": {
"title": "$:/language/Docs/Types/text/css",
"description": "Static stylesheet",
"name": "text/css",
"group": "Developer",
"group-sort": "2"
},
"$:/language/Docs/Types/text/html": {
"title": "$:/language/Docs/Types/text/html",
"description": "HTML markup",
"name": "text/html",
"group": "Text",
"group-sort": "0"
},
"$:/language/Docs/Types/text/plain": {
"title": "$:/language/Docs/Types/text/plain",
"description": "Plain text",
"name": "text/plain",
"group": "Text",
"group-sort": "0"
},
"$:/language/Docs/Types/text/vnd.tiddlywiki": {
"title": "$:/language/Docs/Types/text/vnd.tiddlywiki",
"description": "TiddlyWiki 5",
"name": "text/vnd.tiddlywiki",
"group": "Text",
"group-sort": "0"
},
"$:/language/Docs/Types/text/x-tiddlywiki": {
"title": "$:/language/Docs/Types/text/x-tiddlywiki",
"description": "TiddlyWiki Classic",
"name": "text/x-tiddlywiki",
"group": "Text",
"group-sort": "0"
},
"$:/languages/en-GB/icon": {
"title": "$:/languages/en-GB/icon",
"type": "image/svg+xml",
"text": "<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 60 30\" width=\"1200\" height=\"600\">\n<clipPath id=\"t\">\n\t<path d=\"M30,15 h30 v15 z v15 h-30 z h-30 v-15 z v-15 h30 z\"/>\n</clipPath>\n<path d=\"M0,0 v30 h60 v-30 z\" fill=\"#00247d\"/>\n<path d=\"M0,0 L60,30 M60,0 L0,30\" stroke=\"#fff\" stroke-width=\"6\"/>\n<path d=\"M0,0 L60,30 M60,0 L0,30\" clip-path=\"url(#t)\" stroke=\"#cf142b\" stroke-width=\"4\"/>\n<path d=\"M30,0 v30 M0,15 h60\" stroke=\"#fff\" stroke-width=\"10\"/>\n<path d=\"M30,0 v30 M0,15 h60\" stroke=\"#cf142b\" stroke-width=\"6\"/>\n</svg>\n"
},
"$:/languages/en-GB": {
"title": "$:/languages/en-GB",
"name": "en-GB",
"description": "English (British)",
"author": "JeremyRuston",
"core-version": ">=5.0.0\"",
"text": "Stub pseudo-plugin for the default language"
},
"$:/core/modules/commander.js": {
"title": "$:/core/modules/commander.js",
"text": "/*\\\ntitle: $:/core/modules/commander.js\ntype: application/javascript\nmodule-type: global\n\nThe $tw.Commander class is a command interpreter\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nParse a sequence of commands\n\tcommandTokens: an array of command string tokens\n\twiki: reference to the wiki store object\n\tstreams: {output:, error:}, each of which has a write(string) method\n\tcallback: a callback invoked as callback(err) where err is null if there was no error\n*/\nvar Commander = function(commandTokens,callback,wiki,streams) {\n\tvar path = require(\"path\");\n\tthis.commandTokens = commandTokens;\n\tthis.nextToken = 0;\n\tthis.callback = callback;\n\tthis.wiki = wiki;\n\tthis.streams = streams;\n\tthis.outputPath = path.resolve($tw.boot.wikiPath,$tw.config.wikiOutputSubDir);\n};\n\n/*\nLog a string if verbose flag is set\n*/\nCommander.prototype.log = function(str) {\n\tif(this.verbose) {\n\t\tthis.streams.output.write(str + \"\\n\");\n\t}\n};\n\n/*\nWrite a string if verbose flag is set\n*/\nCommander.prototype.write = function(str) {\n\tif(this.verbose) {\n\t\tthis.streams.output.write(str);\n\t}\n};\n\n/*\nAdd a string of tokens to the command queue\n*/\nCommander.prototype.addCommandTokens = function(commandTokens) {\n\tvar params = commandTokens.slice(0);\n\tparams.unshift(0);\n\tparams.unshift(this.nextToken);\n\tArray.prototype.splice.apply(this.commandTokens,params);\n};\n\n/*\nExecute the sequence of commands and invoke a callback on completion\n*/\nCommander.prototype.execute = function() {\n\tthis.executeNextCommand();\n};\n\n/*\nExecute the next command in the sequence\n*/\nCommander.prototype.executeNextCommand = function() {\n\tvar self = this;\n\t// Invoke the callback if there are no more commands\n\tif(this.nextToken >= this.commandTokens.length) {\n\t\tthis.callback(null);\n\t} else {\n\t\t// Get and check the command token\n\t\tvar commandName = this.commandTokens[this.nextToken++];\n\t\tif(commandName.substr(0,2) !== \"--\") {\n\t\t\tthis.callback(\"Missing command: \" + commandName);\n\t\t} else {\n\t\t\tcommandName = commandName.substr(2); // Trim off the --\n\t\t\t// Accumulate the parameters to the command\n\t\t\tvar params = [];\n\t\t\twhile(this.nextToken < this.commandTokens.length && \n\t\t\t\tthis.commandTokens[this.nextToken].substr(0,2) !== \"--\") {\n\t\t\t\tparams.push(this.commandTokens[this.nextToken++]);\n\t\t\t}\n\t\t\t// Get the command info\n\t\t\tvar command = $tw.commands[commandName],\n\t\t\t\tc,err;\n\t\t\tif(!command) {\n\t\t\t\tthis.callback(\"Unknown command: \" + commandName);\n\t\t\t} else {\n\t\t\t\tif(this.verbose) {\n\t\t\t\t\tthis.streams.output.write(\"Executing command: \" + commandName + \" \" + params.join(\" \") + \"\\n\");\n\t\t\t\t}\n\t\t\t\t// Parse named parameters if required\n\t\t\t\tif(command.info.namedParameterMode) {\n\t\t\t\t\tparams = this.extractNamedParameters(params,command.info.mandatoryParameters);\n\t\t\t\t\tif(typeof params === \"string\") {\n\t\t\t\t\t\treturn this.callback(params);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif(command.info.synchronous) {\n\t\t\t\t\t// Synchronous command\n\t\t\t\t\tc = new command.Command(params,this);\n\t\t\t\t\terr = c.execute();\n\t\t\t\t\tif(err) {\n\t\t\t\t\t\tthis.callback(err);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.executeNextCommand();\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t// Asynchronous command\n\t\t\t\t\tc = new command.Command(params,this,function(err) {\n\t\t\t\t\t\tif(err) {\n\t\t\t\t\t\t\tself.callback(err);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tself.executeNextCommand();\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t\terr = c.execute();\n\t\t\t\t\tif(err) {\n\t\t\t\t\t\tthis.callback(err);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n};\n\n/*\nGiven an array of parameter strings `params` in name:value format, and an array of mandatory parameter names in `mandatoryParameters`, returns a hashmap of values or a string if error\n*/\nCommander.prototype.extractNamedParameters = function(params,mandatoryParameters) {\n\tmandatoryParameters = mandatoryParameters || [];\n\tvar errors = [],\n\t\tparamsByName = Object.create(null);\n\t// Extract the parameters\n\t$tw.utils.each(params,function(param) {\n\t\tvar index = param.indexOf(\"=\");\n\t\tif(index < 1) {\n\t\t\terrors.push(\"malformed named parameter: '\" + param + \"'\");\n\t\t}\n\t\tparamsByName[param.slice(0,index)] = $tw.utils.trim(param.slice(index+1));\n\t});\n\t// Check the mandatory parameters are present\n\t$tw.utils.each(mandatoryParameters,function(mandatoryParameter) {\n\t\tif(!$tw.utils.hop(paramsByName,mandatoryParameter)) {\n\t\t\terrors.push(\"missing mandatory parameter: '\" + mandatoryParameter + \"'\");\n\t\t}\n\t});\n\t// Return any errors\n\tif(errors.length > 0) {\n\t\treturn errors.join(\" and\\n\");\n\t} else {\n\t\treturn paramsByName;\t\t\n\t}\n};\n\nCommander.initCommands = function(moduleType) {\n\tmoduleType = moduleType || \"command\";\n\t$tw.commands = {};\n\t$tw.modules.forEachModuleOfType(moduleType,function(title,module) {\n\t\tvar c = $tw.commands[module.info.name] = {};\n\t\t// Add the methods defined by the module\n\t\tfor(var f in module) {\n\t\t\tif($tw.utils.hop(module,f)) {\n\t\t\t\tc[f] = module[f];\n\t\t\t}\n\t\t}\n\t});\n};\n\nexports.Commander = Commander;\n\n})();\n",
"type": "application/javascript",
"module-type": "global"
},
"$:/core/modules/commands/build.js": {
"title": "$:/core/modules/commands/build.js",
"text": "/*\\\ntitle: $:/core/modules/commands/build.js\ntype: application/javascript\nmodule-type: command\n\nCommand to build a build target\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"build\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander) {\n\tthis.params = params;\n\tthis.commander = commander;\n};\n\nCommand.prototype.execute = function() {\n\t// Get the build targets defined in the wiki\n\tvar buildTargets = $tw.boot.wikiInfo.build;\n\tif(!buildTargets) {\n\t\treturn \"No build targets defined\";\n\t}\n\t// Loop through each of the specified targets\n\tvar targets;\n\tif(this.params.length > 0) {\n\t\ttargets = this.params;\n\t} else {\n\t\ttargets = Object.keys(buildTargets);\n\t}\n\tfor(var targetIndex=0; targetIndex<targets.length; targetIndex++) {\n\t\tvar target = targets[targetIndex],\n\t\t\tcommands = buildTargets[target];\n\t\tif(!commands) {\n\t\t\treturn \"Build target '\" + target + \"' not found\";\n\t\t}\n\t\t// Add the commands to the queue\n\t\tthis.commander.addCommandTokens(commands);\n\t}\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/clearpassword.js": {
"title": "$:/core/modules/commands/clearpassword.js",
"text": "/*\\\ntitle: $:/core/modules/commands/clearpassword.js\ntype: application/javascript\nmodule-type: command\n\nClear password for crypto operations\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"clearpassword\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander,callback) {\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\t$tw.crypto.setPassword(null);\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/editions.js": {
"title": "$:/core/modules/commands/editions.js",
"text": "/*\\\ntitle: $:/core/modules/commands/editions.js\ntype: application/javascript\nmodule-type: command\n\nCommand to list the available editions\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"editions\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander) {\n\tthis.params = params;\n\tthis.commander = commander;\n};\n\nCommand.prototype.execute = function() {\n\tvar self = this;\n\t// Output the list\n\tthis.commander.streams.output.write(\"Available editions:\\n\\n\");\n\tvar editionInfo = $tw.utils.getEditionInfo();\n\t$tw.utils.each(editionInfo,function(info,name) {\n\t\tself.commander.streams.output.write(\" \" + name + \": \" + info.description + \"\\n\");\n\t});\n\tthis.commander.streams.output.write(\"\\n\");\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/fetch.js": {
"title": "$:/core/modules/commands/fetch.js",
"text": "/*\\\ntitle: $:/core/modules/commands/fetch.js\ntype: application/javascript\nmodule-type: command\n\nCommands to fetch external tiddlers\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"fetch\",\n\tsynchronous: false\n};\n\nvar Command = function(params,commander,callback) {\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\tif(this.params.length < 2) {\n\t\treturn \"Missing subcommand and url\";\n\t}\n\tswitch(this.params[0]) {\n\t\tcase \"raw-file\":\n\t\t\treturn this.fetchFiles({\n\t\t\t\traw: true,\n\t\t\t\turl: this.params[1],\n\t\t\t\ttransformFilter: this.params[2] || \"\",\n\t\t\t\tcallback: this.callback\n\t\t\t});\n\t\t\tbreak;\n\t\tcase \"file\":\n\t\t\treturn this.fetchFiles({\n\t\t\t\turl: this.params[1],\n\t\t\t\timportFilter: this.params[2],\n\t\t\t\ttransformFilter: this.params[3] || \"\",\n\t\t\t\tcallback: this.callback\n\t\t\t});\n\t\t\tbreak;\n\t\tcase \"raw-files\":\n\t\t\treturn this.fetchFiles({\n\t\t\t\traw: true,\n\t\t\t\turlFilter: this.params[1],\n\t\t\t\ttransformFilter: this.params[2] || \"\",\n\t\t\t\tcallback: this.callback\n\t\t\t});\n\t\t\tbreak;\n\t\tcase \"files\":\n\t\t\treturn this.fetchFiles({\n\t\t\t\turlFilter: this.params[1],\n\t\t\t\timportFilter: this.params[2],\n\t\t\t\ttransformFilter: this.params[3] || \"\",\n\t\t\t\tcallback: this.callback\n\t\t\t});\n\t\t\tbreak;\n\t}\n\treturn null;\n};\n\nCommand.prototype.fetchFiles = function(options) {\n\tvar self = this;\n\t// Get the list of URLs\n\tvar urls;\n\tif(options.url) {\n\t\turls = [options.url]\n\t} else if(options.urlFilter) {\n\t\turls = $tw.wiki.filterTiddlers(options.urlFilter);\n\t} else {\n\t\treturn \"Missing URL\";\n\t}\n\t// Process each URL in turn\n\tvar next = 0;\n\tvar getNextFile = function(err) {\n\t\tif(err) {\n\t\t\treturn options.callback(err);\n\t\t}\n\t\tif(next < urls.length) {\n\t\t\tself.fetchFile(urls[next++],options,getNextFile);\n\t\t} else {\n\t\t\toptions.callback(null);\n\t\t}\n\t};\n\tgetNextFile(null);\n\t// Success\n\treturn null;\n};\n\nCommand.prototype.fetchFile = function(url,options,callback,redirectCount) {\n\tif(redirectCount > 10) {\n\t\treturn callback(\"Error too many redirects retrieving \" + url);\n\t}\n\tvar self = this,\n\t\tlib = url.substr(0,8) === \"https://\" ? require(\"https\") : require(\"http\");\n\tlib.get(url).on(\"response\",function(response) {\n\t var type = (response.headers[\"content-type\"] || \"\").split(\";\")[0],\n\t \tdata = [];\n\t self.commander.write(\"Reading \" + url + \": \");\n\t response.on(\"data\",function(chunk) {\n\t data.push(chunk);\n\t self.commander.write(\".\");\n\t });\n\t response.on(\"end\",function() {\n\t self.commander.write(\"\\n\");\n\t if(response.statusCode === 200) {\n\t\t self.processBody(Buffer.concat(data),type,options,url);\n\t\t callback(null);\n\t } else {\n\t \tif(response.statusCode === 302 || response.statusCode === 303 || response.statusCode === 307) {\n\t \t\treturn self.fetchFile(response.headers.location,options,callback,redirectCount + 1);\n\t \t} else {\n\t\t \treturn callback(\"Error \" + response.statusCode + \" retrieving \" + url)\t \t\t\n\t \t}\n\t }\n\t \t});\n\t \tresponse.on(\"error\",function(e) {\n\t\t\tconsole.log(\"Error on GET request: \" + e);\n\t\t\tcallback(e);\n\t \t});\n\t});\n\treturn null;\n};\n\nCommand.prototype.processBody = function(body,type,options,url) {\n\tvar self = this;\n\t// Collect the tiddlers in a wiki\n\tvar incomingWiki = new $tw.Wiki();\n\tif(options.raw) {\n\t\tvar typeInfo = type ? $tw.config.contentTypeInfo[type] : null,\n\t\t\tencoding = typeInfo ? typeInfo.encoding : \"utf8\";\n\t\tincomingWiki.addTiddler(new $tw.Tiddler({\n\t\t\ttitle: url,\n\t\t\ttype: type,\n\t\t\ttext: body.toString(encoding)\n\t\t}));\n\t} else {\n\t\t// Deserialise the file to extract the tiddlers\n\t\tvar tiddlers = this.commander.wiki.deserializeTiddlers(type || \"text/html\",body.toString(\"utf8\"),{});\n\t\t$tw.utils.each(tiddlers,function(tiddler) {\n\t\t\tincomingWiki.addTiddler(new $tw.Tiddler(tiddler));\n\t\t});\n\t}\n\t// Filter the tiddlers to select the ones we want\n\tvar filteredTitles = incomingWiki.filterTiddlers(options.importFilter || \"[all[tiddlers]]\");\n\t// Import the selected tiddlers\n\tvar count = 0;\n\tincomingWiki.each(function(tiddler,title) {\n\t\tif(filteredTitles.indexOf(title) !== -1) {\n\t\t\tvar newTiddler;\n\t\t\tif(options.transformFilter) {\n\t\t\t\tvar transformedTitle = (incomingWiki.filterTiddlers(options.transformFilter,null,self.commander.wiki.makeTiddlerIterator([title])) || [\"\"])[0];\n\t\t\t\tif(transformedTitle) {\n\t\t\t\t\tself.commander.log(\"Importing \" + title + \" as \" + transformedTitle)\n\t\t\t\t\tnewTiddler = new $tw.Tiddler(tiddler,{title: transformedTitle});\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tself.commander.log(\"Importing \" + title)\n\t\t\t\tnewTiddler = tiddler;\n\t\t\t}\n\t\t\tself.commander.wiki.importTiddler(newTiddler);\n\t\t\tcount++;\n\t\t}\n\t});\n\tself.commander.log(\"Imported \" + count + \" tiddlers\")\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/help.js": {
"title": "$:/core/modules/commands/help.js",
"text": "/*\\\ntitle: $:/core/modules/commands/help.js\ntype: application/javascript\nmodule-type: command\n\nHelp command\n\n\\*/\n(function(){\n\n/*jshint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"help\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander) {\n\tthis.params = params;\n\tthis.commander = commander;\n};\n\nCommand.prototype.execute = function() {\n\tvar subhelp = this.params[0] || \"default\",\n\t\thelpBase = \"$:/language/Help/\",\n\t\ttext;\n\tif(!this.commander.wiki.getTiddler(helpBase + subhelp)) {\n\t\tsubhelp = \"notfound\";\n\t}\n\t// Wikify the help as formatted text (ie block elements generate newlines)\n\ttext = this.commander.wiki.renderTiddler(\"text/plain-formatted\",helpBase + subhelp);\n\t// Remove any leading linebreaks\n\ttext = text.replace(/^(\\r?\\n)*/g,\"\");\n\tthis.commander.streams.output.write(text);\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/import.js": {
"title": "$:/core/modules/commands/import.js",
"text": "/*\\\ntitle: $:/core/modules/commands/import.js\ntype: application/javascript\nmodule-type: command\n\nCommand to import tiddlers from a file\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"import\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander,callback) {\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\tvar self = this,\n\t\tfs = require(\"fs\"),\n\t\tpath = require(\"path\");\n\tif(this.params.length < 2) {\n\t\treturn \"Missing parameters\";\n\t}\n\tvar filename = self.params[0],\n\t\tdeserializer = self.params[1],\n\t\ttitle = self.params[2] || filename,\n\t\tencoding = self.params[3] || \"utf8\",\n\t\ttext = fs.readFileSync(filename,encoding),\n\t\ttiddlers = this.commander.wiki.deserializeTiddlers(null,text,{title: title},{deserializer: deserializer});\n\t$tw.utils.each(tiddlers,function(tiddler) {\n\t\tself.commander.wiki.importTiddler(new $tw.Tiddler(tiddler));\n\t});\n\tthis.commander.log(tiddlers.length + \" tiddler(s) imported\");\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/init.js": {
"title": "$:/core/modules/commands/init.js",
"text": "/*\\\ntitle: $:/core/modules/commands/init.js\ntype: application/javascript\nmodule-type: command\n\nCommand to initialise an empty wiki folder\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"init\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander) {\n\tthis.params = params;\n\tthis.commander = commander;\n};\n\nCommand.prototype.execute = function() {\n\tvar fs = require(\"fs\"),\n\t\tpath = require(\"path\");\n\t// Check that we don't already have a valid wiki folder\n\tif($tw.boot.wikiTiddlersPath || ($tw.utils.isDirectory($tw.boot.wikiPath) && !$tw.utils.isDirectoryEmpty($tw.boot.wikiPath))) {\n\t\treturn \"Wiki folder is not empty\";\n\t}\n\t// Loop through each of the specified editions\n\tvar editions = this.params.length > 0 ? this.params : [\"empty\"];\n\tfor(var editionIndex=0; editionIndex<editions.length; editionIndex++) {\n\t\tvar editionName = editions[editionIndex];\n\t\t// Check the edition exists\n\t\tvar editionPath = $tw.findLibraryItem(editionName,$tw.getLibraryItemSearchPaths($tw.config.editionsPath,$tw.config.editionsEnvVar));\n\t\tif(!$tw.utils.isDirectory(editionPath)) {\n\t\t\treturn \"Edition '\" + editionName + \"' not found\";\n\t\t}\n\t\t// Copy the edition content\n\t\tvar err = $tw.utils.copyDirectory(editionPath,$tw.boot.wikiPath);\n\t\tif(!err) {\n\t\t\tthis.commander.streams.output.write(\"Copied edition '\" + editionName + \"' to \" + $tw.boot.wikiPath + \"\\n\");\n\t\t} else {\n\t\t\treturn err;\n\t\t}\n\t}\n\t// Tweak the tiddlywiki.info to remove any included wikis\n\tvar packagePath = $tw.boot.wikiPath + \"/tiddlywiki.info\",\n\t\tpackageJson = JSON.parse(fs.readFileSync(packagePath));\n\tdelete packageJson.includeWikis;\n\tfs.writeFileSync(packagePath,JSON.stringify(packageJson,null,$tw.config.preferences.jsonSpaces));\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/listen.js": {
"title": "$:/core/modules/commands/listen.js",
"text": "/*\\\ntitle: $:/core/modules/commands/listen.js\ntype: application/javascript\nmodule-type: command\n\nListen for HTTP requests and serve tiddlers\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Server = require(\"$:/core/modules/server/server.js\").Server;\n\nexports.info = {\n\tname: \"listen\",\n\tsynchronous: true,\n\tnamedParameterMode: true,\n\tmandatoryParameters: [],\n};\n\nvar Command = function(params,commander,callback) {\n\tvar self = this;\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\tvar self = this;\n\tif(!$tw.boot.wikiTiddlersPath) {\n\t\t$tw.utils.warning(\"Warning: Wiki folder '\" + $tw.boot.wikiPath + \"' does not exist or is missing a tiddlywiki.info file\");\n\t}\n\t// Set up server\n\tthis.server = new Server({\n\t\twiki: this.commander.wiki,\n\t\tvariables: self.params\n\t});\n\tvar nodeServer = this.server.listen();\n\t$tw.hooks.invokeHook(\"th-server-command-post-start\",this.server,nodeServer,\"tiddlywiki\");\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/load.js": {
"title": "$:/core/modules/commands/load.js",
"text": "/*\\\ntitle: $:/core/modules/commands/load.js\ntype: application/javascript\nmodule-type: command\n\nCommand to load tiddlers from a file or directory\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"load\",\n\tsynchronous: false\n};\n\nvar Command = function(params,commander,callback) {\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\tvar self = this,\n\t\tfs = require(\"fs\"),\n\t\tpath = require(\"path\");\n\tif(this.params.length < 1) {\n\t\treturn \"Missing filename\";\n\t}\n\tvar tiddlers = $tw.loadTiddlersFromPath(self.params[0]),\n\t\tcount = 0;\n\t$tw.utils.each(tiddlers,function(tiddlerInfo) {\n\t\t$tw.utils.each(tiddlerInfo.tiddlers,function(tiddler) {\n\t\t\tself.commander.wiki.importTiddler(new $tw.Tiddler(tiddler));\n\t\t\tcount++;\n\t\t});\n\t});\n\tif(!count) {\n\t\tself.callback(\"No tiddlers found in file \\\"\" + self.params[0] + \"\\\"\");\n\t} else {\n\t\tself.callback(null);\n\t}\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/makelibrary.js": {
"title": "$:/core/modules/commands/makelibrary.js",
"text": "/*\\\ntitle: $:/core/modules/commands/makelibrary.js\ntype: application/javascript\nmodule-type: command\n\nCommand to pack all of the plugins in the library into a plugin tiddler of type \"library\"\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"makelibrary\",\n\tsynchronous: true\n};\n\nvar UPGRADE_LIBRARY_TITLE = \"$:/UpgradeLibrary\";\n\nvar Command = function(params,commander,callback) {\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\tvar wiki = this.commander.wiki,\n\t\tfs = require(\"fs\"),\n\t\tpath = require(\"path\"),\n\t\tupgradeLibraryTitle = this.params[0] || UPGRADE_LIBRARY_TITLE,\n\t\ttiddlers = {};\n\t// Collect up the library plugins\n\tvar collectPlugins = function(folder) {\n\t\t\tvar pluginFolders = fs.readdirSync(folder);\n\t\t\tfor(var p=0; p<pluginFolders.length; p++) {\n\t\t\t\tif(!$tw.boot.excludeRegExp.test(pluginFolders[p])) {\n\t\t\t\t\tpluginFields = $tw.loadPluginFolder(path.resolve(folder,\"./\" + pluginFolders[p]));\n\t\t\t\t\tif(pluginFields && pluginFields.title) {\n\t\t\t\t\t\ttiddlers[pluginFields.title] = pluginFields;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\tcollectPublisherPlugins = function(folder) {\n\t\t\tvar publisherFolders = fs.readdirSync(folder);\n\t\t\tfor(var t=0; t<publisherFolders.length; t++) {\n\t\t\t\tif(!$tw.boot.excludeRegExp.test(publisherFolders[t])) {\n\t\t\t\t\tcollectPlugins(path.resolve(folder,\"./\" + publisherFolders[t]));\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\tcollectPublisherPlugins(path.resolve($tw.boot.corePath,$tw.config.pluginsPath));\n\tcollectPublisherPlugins(path.resolve($tw.boot.corePath,$tw.config.themesPath));\n\tcollectPlugins(path.resolve($tw.boot.corePath,$tw.config.languagesPath));\n\t// Save the upgrade library tiddler\n\tvar pluginFields = {\n\t\ttitle: upgradeLibraryTitle,\n\t\ttype: \"application/json\",\n\t\t\"plugin-type\": \"library\",\n\t\t\"text\": JSON.stringify({tiddlers: tiddlers},null,$tw.config.preferences.jsonSpaces)\n\t};\n\twiki.addTiddler(new $tw.Tiddler(pluginFields));\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/output.js": {
"title": "$:/core/modules/commands/output.js",
"text": "/*\\\ntitle: $:/core/modules/commands/output.js\ntype: application/javascript\nmodule-type: command\n\nCommand to set the default output location (defaults to current working directory)\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"output\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander,callback) {\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\tvar fs = require(\"fs\"),\n\t\tpath = require(\"path\");\n\tif(this.params.length < 1) {\n\t\treturn \"Missing output path\";\n\t}\n\tthis.commander.outputPath = path.resolve(process.cwd(),this.params[0]);\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/password.js": {
"title": "$:/core/modules/commands/password.js",
"text": "/*\\\ntitle: $:/core/modules/commands/password.js\ntype: application/javascript\nmodule-type: command\n\nSave password for crypto operations\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"password\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander,callback) {\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\tif(this.params.length < 1) {\n\t\treturn \"Missing password\";\n\t}\n\t$tw.crypto.setPassword(this.params[0]);\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/render.js": {
"title": "$:/core/modules/commands/render.js",
"text": "/*\\\ntitle: $:/core/modules/commands/render.js\ntype: application/javascript\nmodule-type: command\n\nRender individual tiddlers and save the results to the specified files\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar widget = require(\"$:/core/modules/widgets/widget.js\");\n\nexports.info = {\n\tname: \"render\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander,callback) {\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\tif(this.params.length < 1) {\n\t\treturn \"Missing tiddler filter\";\n\t}\n\tvar self = this,\n\t\tfs = require(\"fs\"),\n\t\tpath = require(\"path\"),\n\t\twiki = this.commander.wiki,\n\t\ttiddlerFilter = this.params[0],\n\t\tfilenameFilter = this.params[1] || \"[is[tiddler]addsuffix[.html]]\",\n\t\ttype = this.params[2] || \"text/html\",\n\t\ttemplate = this.params[3],\n\t\tvarName = this.params[4],\n\t\tvarValue = this.params[5],\n\t\ttiddlers = wiki.filterTiddlers(tiddlerFilter);\n\t$tw.utils.each(tiddlers,function(title) {\n\t\tvar parser = wiki.parseTiddler(template || title),\n\t\t\tvariables = {currentTiddler: title};\n\t\tif(varName) {\n\t\t\tvariables[varName] = varValue || \"\";\n\t\t}\n\t\tvar widgetNode = wiki.makeWidget(parser,{variables: variables}),\n\t\t\tcontainer = $tw.fakeDocument.createElement(\"div\");\n\t\twidgetNode.render(container,null);\n\t\tvar text = type === \"text/html\" ? container.innerHTML : container.textContent,\n\t\t\tfilepath = path.resolve(self.commander.outputPath,wiki.filterTiddlers(filenameFilter,$tw.rootWidget,wiki.makeTiddlerIterator([title]))[0]);\n\t\tif(self.commander.verbose) {\n\t\t\tconsole.log(\"Rendering \\\"\" + title + \"\\\" to \\\"\" + filepath + \"\\\"\");\n\t\t}\n\t\t$tw.utils.createFileDirectories(filepath);\n\t\tfs.writeFileSync(filepath,text,\"utf8\");\n\t});\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/rendertiddler.js": {
"title": "$:/core/modules/commands/rendertiddler.js",
"text": "/*\\\ntitle: $:/core/modules/commands/rendertiddler.js\ntype: application/javascript\nmodule-type: command\n\nCommand to render a tiddler and save it to a file\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"rendertiddler\",\n\tsynchronous: false\n};\n\nvar Command = function(params,commander,callback) {\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\tif(this.params.length < 2) {\n\t\treturn \"Missing filename\";\n\t}\n\tvar self = this,\n\t\tfs = require(\"fs\"),\n\t\tpath = require(\"path\"),\n\t\ttitle = this.params[0],\n\t\tfilename = path.resolve(this.commander.outputPath,this.params[1]),\n\t\ttype = this.params[2] || \"text/html\",\n\t\ttemplate = this.params[3],\n\t\tname = this.params[4],\n\t\tvalue = this.params[5],\n\t\tvariables = {};\n\t$tw.utils.createFileDirectories(filename);\n\tif(template) {\n\t\tvariables.currentTiddler = title;\n\t\ttitle = template;\n\t}\n\tif(name && value) {\n\t\tvariables[name] = value;\n\t}\n\tfs.writeFile(filename,this.commander.wiki.renderTiddler(type,title,{variables: variables}),\"utf8\",function(err) {\n\t\tself.callback(err);\n\t});\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/rendertiddlers.js": {
"title": "$:/core/modules/commands/rendertiddlers.js",
"text": "/*\\\ntitle: $:/core/modules/commands/rendertiddlers.js\ntype: application/javascript\nmodule-type: command\n\nCommand to render several tiddlers to a folder of files\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar widget = require(\"$:/core/modules/widgets/widget.js\");\n\nexports.info = {\n\tname: \"rendertiddlers\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander,callback) {\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\tif(this.params.length < 2) {\n\t\treturn \"Missing filename\";\n\t}\n\tvar self = this,\n\t\tfs = require(\"fs\"),\n\t\tpath = require(\"path\"),\n\t\twiki = this.commander.wiki,\n\t\tfilter = this.params[0],\n\t\ttemplate = this.params[1],\n\t\toutputPath = this.commander.outputPath,\n\t\tpathname = path.resolve(outputPath,this.params[2]),\t\t\n\t\ttype = this.params[3] || \"text/html\",\n\t\textension = this.params[4] || \".html\",\n\t\tdeleteDirectory = (this.params[5] || \"\").toLowerCase() !== \"noclean\",\n\t\ttiddlers = wiki.filterTiddlers(filter);\n\tif(deleteDirectory) {\n\t\t$tw.utils.deleteDirectory(pathname);\n\t}\n\t$tw.utils.each(tiddlers,function(title) {\n\t\tvar parser = wiki.parseTiddler(template),\n\t\t\twidgetNode = wiki.makeWidget(parser,{variables: {currentTiddler: title}}),\n\t\t\tcontainer = $tw.fakeDocument.createElement(\"div\");\n\t\twidgetNode.render(container,null);\n\t\tvar text = type === \"text/html\" ? container.innerHTML : container.textContent,\n\t\t\texportPath = null;\n\t\tif($tw.utils.hop($tw.macros,\"tv-get-export-path\")) {\n\t\t\tvar macroPath = $tw.macros[\"tv-get-export-path\"].run.apply(self,[title]);\n\t\t\tif(macroPath) {\n\t\t\t\texportPath = path.resolve(outputPath,macroPath + extension);\n\t\t\t}\n\t\t}\n\t\tvar finalPath = exportPath || path.resolve(pathname,encodeURIComponent(title) + extension);\n\t\t$tw.utils.createFileDirectories(finalPath);\n\t\tfs.writeFileSync(finalPath,text,\"utf8\");\n\t});\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/save.js": {
"title": "$:/core/modules/commands/save.js",
"text": "/*\\\ntitle: $:/core/modules/commands/save.js\ntype: application/javascript\nmodule-type: command\n\nSaves individual tiddlers in their raw text or binary format to the specified files\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"save\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander,callback) {\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\tif(this.params.length < 1) {\n\t\treturn \"Missing filename filter\";\n\t}\n\tvar self = this,\n\t\tfs = require(\"fs\"),\n\t\tpath = require(\"path\"),\n\t\twiki = this.commander.wiki,\n\t\ttiddlerFilter = this.params[0],\n\t\tfilenameFilter = this.params[1] || \"[is[tiddler]]\",\n\t\ttiddlers = wiki.filterTiddlers(tiddlerFilter);\n\t$tw.utils.each(tiddlers,function(title) {\n\t\tvar tiddler = self.commander.wiki.getTiddler(title),\n\t\t\ttype = tiddler.fields.type || \"text/vnd.tiddlywiki\",\n\t\t\tcontentTypeInfo = $tw.config.contentTypeInfo[type] || {encoding: \"utf8\"},\n\t\t\tfilepath = path.resolve(self.commander.outputPath,wiki.filterTiddlers(filenameFilter,$tw.rootWidget,wiki.makeTiddlerIterator([title]))[0]);\n\t\tif(self.commander.verbose) {\n\t\t\tconsole.log(\"Saving \\\"\" + title + \"\\\" to \\\"\" + filepath + \"\\\"\");\n\t\t}\n\t\t$tw.utils.createFileDirectories(filepath);\n\t\tfs.writeFileSync(filepath,tiddler.fields.text,contentTypeInfo.encoding);\n\t});\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/savelibrarytiddlers.js": {
"title": "$:/core/modules/commands/savelibrarytiddlers.js",
"text": "/*\\\ntitle: $:/core/modules/commands/savelibrarytiddlers.js\ntype: application/javascript\nmodule-type: command\n\nCommand to save the subtiddlers of a bundle tiddler as a series of JSON files\n\n--savelibrarytiddlers <tiddler> <pathname> <skinnylisting>\n\nThe tiddler identifies the bundle tiddler that contains the subtiddlers.\n\nThe pathname specifies the pathname to the folder in which the JSON files should be saved. The filename is the URL encoded title of the subtiddler.\n\nThe skinnylisting specifies the title of the tiddler to which a JSON catalogue of the subtiddlers will be saved. The JSON file contains the same data as the bundle tiddler but with the `text` field removed.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"savelibrarytiddlers\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander,callback) {\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\tif(this.params.length < 2) {\n\t\treturn \"Missing filename\";\n\t}\n\tvar self = this,\n\t\tfs = require(\"fs\"),\n\t\tpath = require(\"path\"),\n\t\tcontainerTitle = this.params[0],\n\t\tfilter = this.params[1],\n\t\tbasepath = this.params[2],\n\t\tskinnyListTitle = this.params[3];\n\t// Get the container tiddler as data\n\tvar containerData = self.commander.wiki.getTiddlerDataCached(containerTitle,undefined);\n\tif(!containerData) {\n\t\treturn \"'\" + containerTitle + \"' is not a tiddler bundle\";\n\t}\n\t// Filter the list of plugins\n\tvar pluginList = [];\n\t$tw.utils.each(containerData.tiddlers,function(tiddler,title) {\n\t\tpluginList.push(title);\n\t});\n\tvar filteredPluginList;\n\tif(filter) {\n\t\tfilteredPluginList = self.commander.wiki.filterTiddlers(filter,null,self.commander.wiki.makeTiddlerIterator(pluginList));\n\t} else {\n\t\tfilteredPluginList = pluginList;\n\t}\n\t// Iterate through the plugins\n\tvar skinnyList = [];\n\t$tw.utils.each(filteredPluginList,function(title) {\n\t\tvar tiddler = containerData.tiddlers[title];\n\t\t// Save each JSON file and collect the skinny data\n\t\tvar pathname = path.resolve(self.commander.outputPath,basepath + encodeURIComponent(title) + \".json\");\n\t\t$tw.utils.createFileDirectories(pathname);\n\t\tfs.writeFileSync(pathname,JSON.stringify(tiddler,null,$tw.config.preferences.jsonSpaces),\"utf8\");\n\t\t// Collect the skinny list data\n\t\tvar pluginTiddlers = JSON.parse(tiddler.text),\n\t\t\treadmeContent = (pluginTiddlers.tiddlers[title + \"/readme\"] || {}).text,\n\t\t\ticonTiddler = pluginTiddlers.tiddlers[title + \"/icon\"] || {},\n\t\t\ticonType = iconTiddler.type,\n\t\t\ticonText = iconTiddler.text,\n\t\t\ticonContent;\n\t\tif(iconType && iconText) {\n\t\t\ticonContent = $tw.utils.makeDataUri(iconText,iconType);\n\t\t}\n\t\tskinnyList.push($tw.utils.extend({},tiddler,{text: undefined, readme: readmeContent, icon: iconContent}));\n\t});\n\t// Save the catalogue tiddler\n\tif(skinnyListTitle) {\n\t\tself.commander.wiki.setTiddlerData(skinnyListTitle,skinnyList);\n\t}\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/savetiddler.js": {
"title": "$:/core/modules/commands/savetiddler.js",
"text": "/*\\\ntitle: $:/core/modules/commands/savetiddler.js\ntype: application/javascript\nmodule-type: command\n\nCommand to save the content of a tiddler to a file\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"savetiddler\",\n\tsynchronous: false\n};\n\nvar Command = function(params,commander,callback) {\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\tif(this.params.length < 2) {\n\t\treturn \"Missing filename\";\n\t}\n\tvar self = this,\n\t\tfs = require(\"fs\"),\n\t\tpath = require(\"path\"),\n\t\ttitle = this.params[0],\n\t\tfilename = path.resolve(this.commander.outputPath,this.params[1]),\n\t\ttiddler = this.commander.wiki.getTiddler(title);\n\tif(tiddler) {\n\t\tvar type = tiddler.fields.type || \"text/vnd.tiddlywiki\",\n\t\t\tcontentTypeInfo = $tw.config.contentTypeInfo[type] || {encoding: \"utf8\"};\n\t\t$tw.utils.createFileDirectories(filename);\n\t\tfs.writeFile(filename,tiddler.fields.text,contentTypeInfo.encoding,function(err) {\n\t\t\tself.callback(err);\n\t\t});\n\t} else {\n\t\treturn \"Missing tiddler: \" + title;\n\t}\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/savetiddlers.js": {
"title": "$:/core/modules/commands/savetiddlers.js",
"text": "/*\\\ntitle: $:/core/modules/commands/savetiddlers.js\ntype: application/javascript\nmodule-type: command\n\nCommand to save several tiddlers to a folder of files\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar widget = require(\"$:/core/modules/widgets/widget.js\");\n\nexports.info = {\n\tname: \"savetiddlers\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander,callback) {\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\tif(this.params.length < 1) {\n\t\treturn \"Missing filename\";\n\t}\n\tvar self = this,\n\t\tfs = require(\"fs\"),\n\t\tpath = require(\"path\"),\n\t\twiki = this.commander.wiki,\n\t\tfilter = this.params[0],\n\t\tpathname = path.resolve(this.commander.outputPath,this.params[1]),\n\t\tdeleteDirectory = (this.params[2] || \"\").toLowerCase() !== \"noclean\",\n\t\ttiddlers = wiki.filterTiddlers(filter);\n\tif(deleteDirectory) {\n\t\t$tw.utils.deleteDirectory(pathname);\n\t}\n\t$tw.utils.createDirectory(pathname);\n\t$tw.utils.each(tiddlers,function(title) {\n\t\tvar tiddler = self.commander.wiki.getTiddler(title),\n\t\t\ttype = tiddler.fields.type || \"text/vnd.tiddlywiki\",\n\t\t\tcontentTypeInfo = $tw.config.contentTypeInfo[type] || {encoding: \"utf8\"},\n\t\t\tfilename = path.resolve(pathname,encodeURIComponent(title));\n\t\tfs.writeFileSync(filename,tiddler.fields.text,contentTypeInfo.encoding);\n\t});\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/server.js": {
"title": "$:/core/modules/commands/server.js",
"text": "/*\\\ntitle: $:/core/modules/commands/server.js\ntype: application/javascript\nmodule-type: command\n\nDeprecated legacy command for serving tiddlers\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Server = require(\"$:/core/modules/server/server.js\").Server;\n\nexports.info = {\n\tname: \"server\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander,callback) {\n\tvar self = this;\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\tif(!$tw.boot.wikiTiddlersPath) {\n\t\t$tw.utils.warning(\"Warning: Wiki folder '\" + $tw.boot.wikiPath + \"' does not exist or is missing a tiddlywiki.info file\");\n\t}\n\t// Set up server\n\tthis.server = new Server({\n\t\twiki: this.commander.wiki,\n\t\tvariables: {\n\t\t\tport: this.params[0],\n\t\t\thost: this.params[6],\n\t\t\t\"root-tiddler\": this.params[1],\n\t\t\t\"root-render-type\": this.params[2],\n\t\t\t\"root-serve-type\": this.params[3],\n\t\t\tusername: this.params[4],\n\t\t\tpassword: this.params[5],\n\t\t\t\"path-prefix\": this.params[7],\n\t\t\t\"debug-level\": this.params[8]\n\t\t}\n\t});\n\tvar nodeServer = this.server.listen();\n\t$tw.hooks.invokeHook(\"th-server-command-post-start\",this.server,nodeServer,\"tiddlywiki\");\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/setfield.js": {
"title": "$:/core/modules/commands/setfield.js",
"text": "/*\\\ntitle: $:/core/modules/commands/setfield.js\ntype: application/javascript\nmodule-type: command\n\nCommand to modify selected tiddlers to set a field to the text of a template tiddler that has been wikified with the selected tiddler as the current tiddler.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar widget = require(\"$:/core/modules/widgets/widget.js\");\n\nexports.info = {\n\tname: \"setfield\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander,callback) {\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\tif(this.params.length < 4) {\n\t\treturn \"Missing parameters\";\n\t}\n\tvar self = this,\n\t\twiki = this.commander.wiki,\n\t\tfilter = this.params[0],\n\t\tfieldname = this.params[1] || \"text\",\n\t\ttemplatetitle = this.params[2],\n\t\trendertype = this.params[3] || \"text/plain\",\n\t\ttiddlers = wiki.filterTiddlers(filter);\n\t$tw.utils.each(tiddlers,function(title) {\n\t\tvar parser = wiki.parseTiddler(templatetitle),\n\t\t\tnewFields = {},\n\t\t\ttiddler = wiki.getTiddler(title);\n\t\tif(parser) {\n\t\t\tvar widgetNode = wiki.makeWidget(parser,{variables: {currentTiddler: title}});\n\t\t\tvar container = $tw.fakeDocument.createElement(\"div\");\n\t\t\twidgetNode.render(container,null);\n\t\t\tnewFields[fieldname] = rendertype === \"text/html\" ? container.innerHTML : container.textContent;\n\t\t} else {\n\t\t\tnewFields[fieldname] = undefined;\n\t\t}\n\t\twiki.addTiddler(new $tw.Tiddler(tiddler,newFields));\n\t});\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/unpackplugin.js": {
"title": "$:/core/modules/commands/unpackplugin.js",
"text": "/*\\\ntitle: $:/core/modules/commands/unpackplugin.js\ntype: application/javascript\nmodule-type: command\n\nCommand to extract the shadow tiddlers from within a plugin\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"unpackplugin\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander,callback) {\n\tthis.params = params;\n\tthis.commander = commander;\n\tthis.callback = callback;\n};\n\nCommand.prototype.execute = function() {\n\tif(this.params.length < 1) {\n\t\treturn \"Missing plugin name\";\n\t}\n\tvar self = this,\n\t\ttitle = this.params[0],\n\t\tpluginData = this.commander.wiki.getTiddlerDataCached(title);\n\tif(!pluginData) {\n\t\treturn \"Plugin '\" + title + \"' not found\";\n\t}\n\t$tw.utils.each(pluginData.tiddlers,function(tiddler) {\n\t\tself.commander.wiki.addTiddler(new $tw.Tiddler(tiddler));\n\t});\n\treturn null;\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/verbose.js": {
"title": "$:/core/modules/commands/verbose.js",
"text": "/*\\\ntitle: $:/core/modules/commands/verbose.js\ntype: application/javascript\nmodule-type: command\n\nVerbose command\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"verbose\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander) {\n\tthis.params = params;\n\tthis.commander = commander;\n};\n\nCommand.prototype.execute = function() {\n\tthis.commander.verbose = true;\n\t// Output the boot message log\n\tthis.commander.streams.output.write(\"Boot log:\\n \" + $tw.boot.logMessages.join(\"\\n \") + \"\\n\");\n\treturn null; // No error\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/commands/version.js": {
"title": "$:/core/modules/commands/version.js",
"text": "/*\\\ntitle: $:/core/modules/commands/version.js\ntype: application/javascript\nmodule-type: command\n\nVersion command\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.info = {\n\tname: \"version\",\n\tsynchronous: true\n};\n\nvar Command = function(params,commander) {\n\tthis.params = params;\n\tthis.commander = commander;\n};\n\nCommand.prototype.execute = function() {\n\tthis.commander.streams.output.write($tw.version + \"\\n\");\n\treturn null; // No error\n};\n\nexports.Command = Command;\n\n})();\n",
"type": "application/javascript",
"module-type": "command"
},
"$:/core/modules/config.js": {
"title": "$:/core/modules/config.js",
"text": "/*\\\ntitle: $:/core/modules/config.js\ntype: application/javascript\nmodule-type: config\n\nCore configuration constants\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.preferences = {};\n\nexports.preferences.notificationDuration = 3 * 1000;\nexports.preferences.jsonSpaces = 4;\n\nexports.textPrimitives = {\n\tupperLetter: \"[A-Z\\u00c0-\\u00d6\\u00d8-\\u00de\\u0150\\u0170]\",\n\tlowerLetter: \"[a-z\\u00df-\\u00f6\\u00f8-\\u00ff\\u0151\\u0171]\",\n\tanyLetter: \"[A-Za-z0-9\\u00c0-\\u00d6\\u00d8-\\u00de\\u00df-\\u00f6\\u00f8-\\u00ff\\u0150\\u0170\\u0151\\u0171]\",\n\tblockPrefixLetters:\t\"[A-Za-z0-9-_\\u00c0-\\u00d6\\u00d8-\\u00de\\u00df-\\u00f6\\u00f8-\\u00ff\\u0150\\u0170\\u0151\\u0171]\"\n};\n\nexports.textPrimitives.unWikiLink = \"~\";\nexports.textPrimitives.wikiLink = exports.textPrimitives.upperLetter + \"+\" +\n\texports.textPrimitives.lowerLetter + \"+\" +\n\texports.textPrimitives.upperLetter +\n\texports.textPrimitives.anyLetter + \"*\";\n\nexports.htmlEntities = {quot:34, amp:38, apos:39, lt:60, gt:62, nbsp:160, iexcl:161, cent:162, pound:163, curren:164, yen:165, brvbar:166, sect:167, uml:168, copy:169, ordf:170, laquo:171, not:172, shy:173, reg:174, macr:175, deg:176, plusmn:177, sup2:178, sup3:179, acute:180, micro:181, para:182, middot:183, cedil:184, sup1:185, ordm:186, raquo:187, frac14:188, frac12:189, frac34:190, iquest:191, Agrave:192, Aacute:193, Acirc:194, Atilde:195, Auml:196, Aring:197, AElig:198, Ccedil:199, Egrave:200, Eacute:201, Ecirc:202, Euml:203, Igrave:204, Iacute:205, Icirc:206, Iuml:207, ETH:208, Ntilde:209, Ograve:210, Oacute:211, Ocirc:212, Otilde:213, Ouml:214, times:215, Oslash:216, Ugrave:217, Uacute:218, Ucirc:219, Uuml:220, Yacute:221, THORN:222, szlig:223, agrave:224, aacute:225, acirc:226, atilde:227, auml:228, aring:229, aelig:230, ccedil:231, egrave:232, eacute:233, ecirc:234, euml:235, igrave:236, iacute:237, icirc:238, iuml:239, eth:240, ntilde:241, ograve:242, oacute:243, ocirc:244, otilde:245, ouml:246, divide:247, oslash:248, ugrave:249, uacute:250, ucirc:251, uuml:252, yacute:253, thorn:254, yuml:255, OElig:338, oelig:339, Scaron:352, scaron:353, Yuml:376, fnof:402, circ:710, tilde:732, Alpha:913, Beta:914, Gamma:915, Delta:916, Epsilon:917, Zeta:918, Eta:919, Theta:920, Iota:921, Kappa:922, Lambda:923, Mu:924, Nu:925, Xi:926, Omicron:927, Pi:928, Rho:929, Sigma:931, Tau:932, Upsilon:933, Phi:934, Chi:935, Psi:936, Omega:937, alpha:945, beta:946, gamma:947, delta:948, epsilon:949, zeta:950, eta:951, theta:952, iota:953, kappa:954, lambda:955, mu:956, nu:957, xi:958, omicron:959, pi:960, rho:961, sigmaf:962, sigma:963, tau:964, upsilon:965, phi:966, chi:967, psi:968, omega:969, thetasym:977, upsih:978, piv:982, ensp:8194, emsp:8195, thinsp:8201, zwnj:8204, zwj:8205, lrm:8206, rlm:8207, ndash:8211, mdash:8212, lsquo:8216, rsquo:8217, sbquo:8218, ldquo:8220, rdquo:8221, bdquo:8222, dagger:8224, Dagger:8225, bull:8226, hellip:8230, permil:8240, prime:8242, Prime:8243, lsaquo:8249, rsaquo:8250, oline:8254, frasl:8260, euro:8364, image:8465, weierp:8472, real:8476, trade:8482, alefsym:8501, larr:8592, uarr:8593, rarr:8594, darr:8595, harr:8596, crarr:8629, lArr:8656, uArr:8657, rArr:8658, dArr:8659, hArr:8660, forall:8704, part:8706, exist:8707, empty:8709, nabla:8711, isin:8712, notin:8713, ni:8715, prod:8719, sum:8721, minus:8722, lowast:8727, radic:8730, prop:8733, infin:8734, ang:8736, and:8743, or:8744, cap:8745, cup:8746, int:8747, there4:8756, sim:8764, cong:8773, asymp:8776, ne:8800, equiv:8801, le:8804, ge:8805, sub:8834, sup:8835, nsub:8836, sube:8838, supe:8839, oplus:8853, otimes:8855, perp:8869, sdot:8901, lceil:8968, rceil:8969, lfloor:8970, rfloor:8971, lang:9001, rang:9002, loz:9674, spades:9824, clubs:9827, hearts:9829, diams:9830 };\n\nexports.htmlVoidElements = \"area,base,br,col,command,embed,hr,img,input,keygen,link,meta,param,source,track,wbr\".split(\",\");\n\nexports.htmlBlockElements = \"address,article,aside,audio,blockquote,canvas,dd,div,dl,fieldset,figcaption,figure,footer,form,h1,h2,h3,h4,h5,h6,header,hgroup,hr,li,noscript,ol,output,p,pre,section,table,tfoot,ul,video\".split(\",\");\n\nexports.htmlUnsafeElements = \"script\".split(\",\");\n\n})();\n",
"type": "application/javascript",
"module-type": "config"
},
"$:/core/modules/deserializers.js": {
"title": "$:/core/modules/deserializers.js",
"text": "/*\\\ntitle: $:/core/modules/deserializers.js\ntype: application/javascript\nmodule-type: tiddlerdeserializer\n\nFunctions to deserialise tiddlers from a block of text\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nUtility function to parse an old-style tiddler DIV in a *.tid file. It looks like this:\n\n<div title=\"Title\" creator=\"JoeBloggs\" modifier=\"JoeBloggs\" created=\"201102111106\" modified=\"201102111310\" tags=\"myTag [[my long tag]]\">\n<pre>The text of the tiddler (without the expected HTML encoding).\n</pre>\n</div>\n\nNote that the field attributes are HTML encoded, but that the body of the <PRE> tag is not encoded.\n\nWhen these tiddler DIVs are encountered within a TiddlyWiki HTML file then the body is encoded in the usual way.\n*/\nvar parseTiddlerDiv = function(text /* [,fields] */) {\n\t// Slot together the default results\n\tvar result = {};\n\tif(arguments.length > 1) {\n\t\tfor(var f=1; f<arguments.length; f++) {\n\t\t\tvar fields = arguments[f];\n\t\t\tfor(var t in fields) {\n\t\t\t\tresult[t] = fields[t];\t\t\n\t\t\t}\n\t\t}\n\t}\n\t// Parse the DIV body\n\tvar startRegExp = /^\\s*<div\\s+([^>]*)>(\\s*<pre>)?/gi,\n\t\tendRegExp,\n\t\tmatch = startRegExp.exec(text);\n\tif(match) {\n\t\t// Old-style DIVs don't have the <pre> tag\n\t\tif(match[2]) {\n\t\t\tendRegExp = /<\\/pre>\\s*<\\/div>\\s*$/gi;\n\t\t} else {\n\t\t\tendRegExp = /<\\/div>\\s*$/gi;\n\t\t}\n\t\tvar endMatch = endRegExp.exec(text);\n\t\tif(endMatch) {\n\t\t\t// Extract the text\n\t\t\tresult.text = text.substring(match.index + match[0].length,endMatch.index);\n\t\t\t// Process the attributes\n\t\t\tvar attrRegExp = /\\s*([^=\\s]+)\\s*=\\s*(?:\"([^\"]*)\"|'([^']*)')/gi,\n\t\t\t\tattrMatch;\n\t\t\tdo {\n\t\t\t\tattrMatch = attrRegExp.exec(match[1]);\n\t\t\t\tif(attrMatch) {\n\t\t\t\t\tvar name = attrMatch[1];\n\t\t\t\t\tvar value = attrMatch[2] !== undefined ? attrMatch[2] : attrMatch[3];\n\t\t\t\t\tresult[name] = value;\n\t\t\t\t}\n\t\t\t} while(attrMatch);\n\t\t\treturn result;\n\t\t}\n\t}\n\treturn undefined;\n};\n\nexports[\"application/x-tiddler-html-div\"] = function(text,fields) {\n\treturn [parseTiddlerDiv(text,fields)];\n};\n\nexports[\"application/json\"] = function(text,fields) {\n\tvar incoming,\n\t\tresults = [];\n\ttry {\n\t\tincoming = JSON.parse(text);\n\t} catch(e) {\n\t\tincoming = [{\n\t\t\ttitle: \"JSON error: \" + e,\n\t\t\ttext: \"\"\n\t\t}]\n\t}\n\tif(!$tw.utils.isArray(incoming)) {\n\t\tincoming = [incoming];\n\t}\n\tfor(var t=0; t<incoming.length; t++) {\n\t\tvar incomingFields = incoming[t],\n\t\t\tfields = {};\n\t\tfor(var f in incomingFields) {\n\t\t\tif(typeof incomingFields[f] === \"string\") {\n\t\t\t\tfields[f] = incomingFields[f];\n\t\t\t}\n\t\t}\n\t\tresults.push(fields);\n\t}\n\treturn results;\n};\n\n/*\nParse an HTML file into tiddlers. There are three possibilities:\n# A TiddlyWiki classic HTML file containing `text/x-tiddlywiki` tiddlers\n# A TiddlyWiki5 HTML file containing `text/vnd.tiddlywiki` tiddlers\n# An ordinary HTML file\n*/\nexports[\"text/html\"] = function(text,fields) {\n\t// Check if we've got a store area\n\tvar storeAreaMarkerRegExp = /<div id=[\"']?storeArea['\"]?( style=[\"']?display:none;[\"']?)?>/gi,\n\t\tmatch = storeAreaMarkerRegExp.exec(text);\n\tif(match) {\n\t\t// If so, it's either a classic TiddlyWiki file or an unencrypted TW5 file\n\t\t// First read the normal tiddlers\n\t\tvar results = deserializeTiddlyWikiFile(text,storeAreaMarkerRegExp.lastIndex,!!match[1],fields);\n\t\t// Then any system tiddlers\n\t\tvar systemAreaMarkerRegExp = /<div id=[\"']?systemArea['\"]?( style=[\"']?display:none;[\"']?)?>/gi,\n\t\t\tsysMatch = systemAreaMarkerRegExp.exec(text);\n\t\tif(sysMatch) {\n\t\t\tresults.push.apply(results,deserializeTiddlyWikiFile(text,systemAreaMarkerRegExp.lastIndex,!!sysMatch[1],fields));\n\t\t}\n\t\treturn results;\n\t} else {\n\t\t// Check whether we've got an encrypted file\n\t\tvar encryptedStoreArea = $tw.utils.extractEncryptedStoreArea(text);\n\t\tif(encryptedStoreArea) {\n\t\t\t// If so, attempt to decrypt it using the current password\n\t\t\treturn $tw.utils.decryptStoreArea(encryptedStoreArea);\n\t\t} else {\n\t\t\t// It's not a TiddlyWiki so we'll return the entire HTML file as a tiddler\n\t\t\treturn deserializeHtmlFile(text,fields);\n\t\t}\n\t}\n};\n\nfunction deserializeHtmlFile(text,fields) {\n\tvar result = {};\n\t$tw.utils.each(fields,function(value,name) {\n\t\tresult[name] = value;\n\t});\n\tresult.text = text;\n\tresult.type = \"text/html\";\n\treturn [result];\n}\n\nfunction deserializeTiddlyWikiFile(text,storeAreaEnd,isTiddlyWiki5,fields) {\n\tvar results = [],\n\t\tendOfDivRegExp = /(<\\/div>\\s*)/gi,\n\t\tstartPos = storeAreaEnd,\n\t\tdefaultType = isTiddlyWiki5 ? undefined : \"text/x-tiddlywiki\";\n\tendOfDivRegExp.lastIndex = startPos;\n\tvar match = endOfDivRegExp.exec(text);\n\twhile(match) {\n\t\tvar endPos = endOfDivRegExp.lastIndex,\n\t\t\ttiddlerFields = parseTiddlerDiv(text.substring(startPos,endPos),fields,{type: defaultType});\n\t\tif(!tiddlerFields) {\n\t\t\tbreak;\n\t\t}\n\t\t$tw.utils.each(tiddlerFields,function(value,name) {\n\t\t\tif(typeof value === \"string\") {\n\t\t\t\ttiddlerFields[name] = $tw.utils.htmlDecode(value);\n\t\t\t}\n\t\t});\n\t\tif(tiddlerFields.text !== null) {\n\t\t\tresults.push(tiddlerFields);\n\t\t}\n\t\tstartPos = endPos;\n\t\tmatch = endOfDivRegExp.exec(text);\n\t}\n\treturn results;\n}\n\n})();\n",
"type": "application/javascript",
"module-type": "tiddlerdeserializer"
},
"$:/core/modules/editor/engines/framed.js": {
"title": "$:/core/modules/editor/engines/framed.js",
"text": "/*\\\ntitle: $:/core/modules/editor/engines/framed.js\ntype: application/javascript\nmodule-type: library\n\nText editor engine based on a simple input or textarea within an iframe. This is done so that the selection is preserved even when clicking away from the textarea\n\n\\*/\n(function(){\n\n/*jslint node: true,browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar HEIGHT_VALUE_TITLE = \"$:/config/TextEditor/EditorHeight/Height\";\n\nfunction FramedEngine(options) {\n\t// Save our options\n\toptions = options || {};\n\tthis.widget = options.widget;\n\tthis.value = options.value;\n\tthis.parentNode = options.parentNode;\n\tthis.nextSibling = options.nextSibling;\n\t// Create our hidden dummy text area for reading styles\n\tthis.dummyTextArea = this.widget.document.createElement(\"textarea\");\n\tif(this.widget.editClass) {\n\t\tthis.dummyTextArea.className = this.widget.editClass;\n\t}\n\tthis.dummyTextArea.setAttribute(\"hidden\",\"true\");\n\tthis.parentNode.insertBefore(this.dummyTextArea,this.nextSibling);\n\tthis.widget.domNodes.push(this.dummyTextArea);\n\t// Create the iframe\n\tthis.iframeNode = this.widget.document.createElement(\"iframe\");\n\tthis.parentNode.insertBefore(this.iframeNode,this.nextSibling);\n\tthis.iframeDoc = this.iframeNode.contentWindow.document;\n\t// (Firefox requires us to put some empty content in the iframe)\n\tthis.iframeDoc.open();\n\tthis.iframeDoc.write(\"\");\n\tthis.iframeDoc.close();\n\t// Style the iframe\n\tthis.iframeNode.className = this.dummyTextArea.className;\n\tthis.iframeNode.style.border = \"none\";\n\tthis.iframeNode.style.padding = \"0\";\n\tthis.iframeNode.style.resize = \"none\";\n\tthis.iframeDoc.body.style.margin = \"0\";\n\tthis.iframeDoc.body.style.padding = \"0\";\n\tthis.widget.domNodes.push(this.iframeNode);\n\t// Construct the textarea or input node\n\tvar tag = this.widget.editTag;\n\tif($tw.config.htmlUnsafeElements.indexOf(tag) !== -1) {\n\t\ttag = \"input\";\n\t}\n\tthis.domNode = this.iframeDoc.createElement(tag);\n\t// Set the text\n\tif(this.widget.editTag === \"textarea\") {\n\t\tthis.domNode.appendChild(this.iframeDoc.createTextNode(this.value));\n\t} else {\n\t\tthis.domNode.value = this.value;\n\t}\n\t// Set the attributes\n\tif(this.widget.editType) {\n\t\tthis.domNode.setAttribute(\"type\",this.widget.editType);\n\t}\n\tif(this.widget.editPlaceholder) {\n\t\tthis.domNode.setAttribute(\"placeholder\",this.widget.editPlaceholder);\n\t}\n\tif(this.widget.editSize) {\n\t\tthis.domNode.setAttribute(\"size\",this.widget.editSize);\n\t}\n\tif(this.widget.editRows) {\n\t\tthis.domNode.setAttribute(\"rows\",this.widget.editRows);\n\t}\n\t// Copy the styles from the dummy textarea\n\tthis.copyStyles();\n\t// Add event listeners\n\t$tw.utils.addEventListeners(this.domNode,[\n\t\t{name: \"click\",handlerObject: this,handlerMethod: \"handleClickEvent\"},\n\t\t{name: \"input\",handlerObject: this,handlerMethod: \"handleInputEvent\"},\n\t\t{name: \"keydown\",handlerObject: this.widget,handlerMethod: \"handleKeydownEvent\"}\n\t]);\n\t// Insert the element into the DOM\n\tthis.iframeDoc.body.appendChild(this.domNode);\n}\n\n/*\nCopy styles from the dummy text area to the textarea in the iframe\n*/\nFramedEngine.prototype.copyStyles = function() {\n\t// Copy all styles\n\t$tw.utils.copyStyles(this.dummyTextArea,this.domNode);\n\t// Override the ones that should not be set the same as the dummy textarea\n\tthis.domNode.style.display = \"block\";\n\tthis.domNode.style.width = \"100%\";\n\tthis.domNode.style.margin = \"0\";\n\t// In Chrome setting -webkit-text-fill-color overrides the placeholder text colour\n\tthis.domNode.style[\"-webkit-text-fill-color\"] = \"currentcolor\";\n};\n\n/*\nSet the text of the engine if it doesn't currently have focus\n*/\nFramedEngine.prototype.setText = function(text,type) {\n\tif(!this.domNode.isTiddlyWikiFakeDom) {\n\t\tif(this.domNode.ownerDocument.activeElement !== this.domNode) {\n\t\t\tthis.domNode.value = text;\n\t\t}\n\t\t// Fix the height if needed\n\t\tthis.fixHeight();\n\t}\n};\n\n/*\nGet the text of the engine\n*/\nFramedEngine.prototype.getText = function() {\n\treturn this.domNode.value;\n};\n\n/*\nFix the height of textarea to fit content\n*/\nFramedEngine.prototype.fixHeight = function() {\n\t// Make sure styles are updated\n\tthis.copyStyles();\n\t// Adjust height\n\tif(this.widget.editTag === \"textarea\") {\n\t\tif(this.widget.editAutoHeight) {\n\t\t\tif(this.domNode && !this.domNode.isTiddlyWikiFakeDom) {\n\t\t\t\tvar newHeight = $tw.utils.resizeTextAreaToFit(this.domNode,this.widget.editMinHeight);\n\t\t\t\tthis.iframeNode.style.height = (newHeight + 14) + \"px\"; // +14 for the border on the textarea\n\t\t\t}\n\t\t} else {\n\t\t\tvar fixedHeight = parseInt(this.widget.wiki.getTiddlerText(HEIGHT_VALUE_TITLE,\"400px\"),10);\n\t\t\tfixedHeight = Math.max(fixedHeight,20);\n\t\t\tthis.domNode.style.height = fixedHeight + \"px\";\n\t\t\tthis.iframeNode.style.height = (fixedHeight + 14) + \"px\";\n\t\t}\n\t}\n};\n\n/*\nFocus the engine node\n*/\nFramedEngine.prototype.focus = function() {\n\tif(this.domNode.focus && this.domNode.select) {\n\t\tthis.domNode.focus();\n\t\tthis.domNode.select();\n\t}\n};\n\n/*\nHandle a click\n*/\nFramedEngine.prototype.handleClickEvent = function(event) {\n\tthis.fixHeight();\n\treturn true;\n};\n\n/*\nHandle a dom \"input\" event which occurs when the text has changed\n*/\nFramedEngine.prototype.handleInputEvent = function(event) {\n\tthis.widget.saveChanges(this.getText());\n\tthis.fixHeight();\n\treturn true;\n};\n\n/*\nCreate a blank structure representing a text operation\n*/\nFramedEngine.prototype.createTextOperation = function() {\n\tvar operation = {\n\t\ttext: this.domNode.value,\n\t\tselStart: this.domNode.selectionStart,\n\t\tselEnd: this.domNode.selectionEnd,\n\t\tcutStart: null,\n\t\tcutEnd: null,\n\t\treplacement: null,\n\t\tnewSelStart: null,\n\t\tnewSelEnd: null\n\t};\n\toperation.selection = operation.text.substring(operation.selStart,operation.selEnd);\n\treturn operation;\n};\n\n/*\nExecute a text operation\n*/\nFramedEngine.prototype.executeTextOperation = function(operation) {\n\t// Perform the required changes to the text area and the underlying tiddler\n\tvar newText = operation.text;\n\tif(operation.replacement !== null) {\n\t\tnewText = operation.text.substring(0,operation.cutStart) + operation.replacement + operation.text.substring(operation.cutEnd);\n\t\t// Attempt to use a execCommand to modify the value of the control\n\t\tif(this.iframeDoc.queryCommandSupported(\"insertText\") && this.iframeDoc.queryCommandSupported(\"delete\") && !$tw.browser.isFirefox) {\n\t\t\tthis.domNode.focus();\n\t\t\tthis.domNode.setSelectionRange(operation.cutStart,operation.cutEnd);\n\t\t\tif(operation.replacement === \"\") {\n\t\t\t\tthis.iframeDoc.execCommand(\"delete\",false,\"\");\n\t\t\t} else {\n\t\t\t\tthis.iframeDoc.execCommand(\"insertText\",false,operation.replacement);\n\t\t\t}\n\t\t} else {\n\t\t\tthis.domNode.value = newText;\n\t\t}\n\t\tthis.domNode.focus();\n\t\tthis.domNode.setSelectionRange(operation.newSelStart,operation.newSelEnd);\n\t}\n\tthis.domNode.focus();\n\treturn newText;\n};\n\nexports.FramedEngine = FramedEngine;\n\n})();\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/core/modules/editor/engines/simple.js": {
"title": "$:/core/modules/editor/engines/simple.js",
"text": "/*\\\ntitle: $:/core/modules/editor/engines/simple.js\ntype: application/javascript\nmodule-type: library\n\nText editor engine based on a simple input or textarea tag\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar HEIGHT_VALUE_TITLE = \"$:/config/TextEditor/EditorHeight/Height\";\n\nfunction SimpleEngine(options) {\n\t// Save our options\n\toptions = options || {};\n\tthis.widget = options.widget;\n\tthis.value = options.value;\n\tthis.parentNode = options.parentNode;\n\tthis.nextSibling = options.nextSibling;\n\t// Construct the textarea or input node\n\tvar tag = this.widget.editTag;\n\tif($tw.config.htmlUnsafeElements.indexOf(tag) !== -1) {\n\t\ttag = \"input\";\n\t}\n\tthis.domNode = this.widget.document.createElement(tag);\n\t// Set the text\n\tif(this.widget.editTag === \"textarea\") {\n\t\tthis.domNode.appendChild(this.widget.document.createTextNode(this.value));\n\t} else {\n\t\tthis.domNode.value = this.value;\n\t}\n\t// Set the attributes\n\tif(this.widget.editType) {\n\t\tthis.domNode.setAttribute(\"type\",this.widget.editType);\n\t}\n\tif(this.widget.editPlaceholder) {\n\t\tthis.domNode.setAttribute(\"placeholder\",this.widget.editPlaceholder);\n\t}\n\tif(this.widget.editSize) {\n\t\tthis.domNode.setAttribute(\"size\",this.widget.editSize);\n\t}\n\tif(this.widget.editRows) {\n\t\tthis.domNode.setAttribute(\"rows\",this.widget.editRows);\n\t}\n\tif(this.widget.editClass) {\n\t\tthis.domNode.className = this.widget.editClass;\n\t}\n\t// Add an input event handler\n\t$tw.utils.addEventListeners(this.domNode,[\n\t\t{name: \"focus\", handlerObject: this, handlerMethod: \"handleFocusEvent\"},\n\t\t{name: \"input\", handlerObject: this, handlerMethod: \"handleInputEvent\"}\n\t]);\n\t// Insert the element into the DOM\n\tthis.parentNode.insertBefore(this.domNode,this.nextSibling);\n\tthis.widget.domNodes.push(this.domNode);\n}\n\n/*\nSet the text of the engine if it doesn't currently have focus\n*/\nSimpleEngine.prototype.setText = function(text,type) {\n\tif(!this.domNode.isTiddlyWikiFakeDom) {\n\t\tif(this.domNode.ownerDocument.activeElement !== this.domNode || text === \"\") {\n\t\t\tthis.domNode.value = text;\n\t\t}\n\t\t// Fix the height if needed\n\t\tthis.fixHeight();\n\t}\n};\n\n/*\nGet the text of the engine\n*/\nSimpleEngine.prototype.getText = function() {\n\treturn this.domNode.value;\n};\n\n/*\nFix the height of textarea to fit content\n*/\nSimpleEngine.prototype.fixHeight = function() {\n\tif(this.widget.editTag === \"textarea\") {\n\t\tif(this.widget.editAutoHeight) {\n\t\t\tif(this.domNode && !this.domNode.isTiddlyWikiFakeDom) {\n\t\t\t\t$tw.utils.resizeTextAreaToFit(this.domNode,this.widget.editMinHeight);\n\t\t\t}\n\t\t} else {\n\t\t\tvar fixedHeight = parseInt(this.widget.wiki.getTiddlerText(HEIGHT_VALUE_TITLE,\"400px\"),10);\n\t\t\tfixedHeight = Math.max(fixedHeight,20);\n\t\t\tthis.domNode.style.height = fixedHeight + \"px\";\n\t\t}\n\t}\n};\n\n/*\nFocus the engine node\n*/\nSimpleEngine.prototype.focus = function() {\n\tif(this.domNode.focus && this.domNode.select) {\n\t\tthis.domNode.focus();\n\t\tthis.domNode.select();\n\t}\n};\n\n/*\nHandle a dom \"input\" event which occurs when the text has changed\n*/\nSimpleEngine.prototype.handleInputEvent = function(event) {\n\tthis.widget.saveChanges(this.getText());\n\tthis.fixHeight();\n\treturn true;\n};\n\n/*\nHandle a dom \"focus\" event\n*/\nSimpleEngine.prototype.handleFocusEvent = function(event) {\n\tif(this.widget.editFocusPopup) {\n\t\t$tw.popup.triggerPopup({\n\t\t\tdomNode: this.domNode,\n\t\t\ttitle: this.widget.editFocusPopup,\n\t\t\twiki: this.widget.wiki,\n\t\t\tforce: true\n\t\t});\n\t}\n\treturn true;\n};\n\n/*\nCreate a blank structure representing a text operation\n*/\nSimpleEngine.prototype.createTextOperation = function() {\n\treturn null;\n};\n\n/*\nExecute a text operation\n*/\nSimpleEngine.prototype.executeTextOperation = function(operation) {\n};\n\nexports.SimpleEngine = SimpleEngine;\n\n})();\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/core/modules/editor/factory.js": {
"title": "$:/core/modules/editor/factory.js",
"text": "/*\\\ntitle: $:/core/modules/editor/factory.js\ntype: application/javascript\nmodule-type: library\n\nFactory for constructing text editor widgets with specified engines for the toolbar and non-toolbar cases\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar DEFAULT_MIN_TEXT_AREA_HEIGHT = \"100px\"; // Minimum height of textareas in pixels\n\n// Configuration tiddlers\nvar HEIGHT_MODE_TITLE = \"$:/config/TextEditor/EditorHeight/Mode\";\nvar ENABLE_TOOLBAR_TITLE = \"$:/config/TextEditor/EnableToolbar\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nfunction editTextWidgetFactory(toolbarEngine,nonToolbarEngine) {\n\n\tvar EditTextWidget = function(parseTreeNode,options) {\n\t\t// Initialise the editor operations if they've not been done already\n\t\tif(!this.editorOperations) {\n\t\t\tEditTextWidget.prototype.editorOperations = {};\n\t\t\t$tw.modules.applyMethods(\"texteditoroperation\",this.editorOperations);\n\t\t}\n\t\tthis.initialise(parseTreeNode,options);\n\t};\n\n\t/*\n\tInherit from the base widget class\n\t*/\n\tEditTextWidget.prototype = new Widget();\n\n\t/*\n\tRender this widget into the DOM\n\t*/\n\tEditTextWidget.prototype.render = function(parent,nextSibling) {\n\t\t// Save the parent dom node\n\t\tthis.parentDomNode = parent;\n\t\t// Compute our attributes\n\t\tthis.computeAttributes();\n\t\t// Execute our logic\n\t\tthis.execute();\n\t\t// Create the wrapper for the toolbar and render its content\n\t\tif(this.editShowToolbar) {\n\t\t\tthis.toolbarNode = this.document.createElement(\"div\");\n\t\t\tthis.toolbarNode.className = \"tc-editor-toolbar\";\n\t\t\tparent.insertBefore(this.toolbarNode,nextSibling);\n\t\t\tthis.renderChildren(this.toolbarNode,null);\n\t\t\tthis.domNodes.push(this.toolbarNode);\n\t\t}\n\t\t// Create our element\n\t\tvar editInfo = this.getEditInfo(),\n\t\t\tEngine = this.editShowToolbar ? toolbarEngine : nonToolbarEngine;\n\t\tthis.engine = new Engine({\n\t\t\t\twidget: this,\n\t\t\t\tvalue: editInfo.value,\n\t\t\t\ttype: editInfo.type,\n\t\t\t\tparentNode: parent,\n\t\t\t\tnextSibling: nextSibling\n\t\t\t});\n\t\t// Call the postRender hook\n\t\tif(this.postRender) {\n\t\t\tthis.postRender();\n\t\t}\n\t\t// Fix height\n\t\tthis.engine.fixHeight();\n\t\t// Focus if required\n\t\tif(this.editFocus === \"true\" || this.editFocus === \"yes\") {\n\t\t\tthis.engine.focus();\n\t\t}\n\t\t// Add widget message listeners\n\t\tthis.addEventListeners([\n\t\t\t{type: \"tm-edit-text-operation\", handler: \"handleEditTextOperationMessage\"}\n\t\t]);\n\t};\n\n\t/*\n\tGet the tiddler being edited and current value\n\t*/\n\tEditTextWidget.prototype.getEditInfo = function() {\n\t\t// Get the edit value\n\t\tvar self = this,\n\t\t\tvalue,\n\t\t\ttype = \"text/plain\",\n\t\t\tupdate;\n\t\tif(this.editIndex) {\n\t\t\tvalue = this.wiki.extractTiddlerDataItem(this.editTitle,this.editIndex,this.editDefault);\n\t\t\tupdate = function(value) {\n\t\t\t\tvar data = self.wiki.getTiddlerData(self.editTitle,{});\n\t\t\t\tif(data[self.editIndex] !== value) {\n\t\t\t\t\tdata[self.editIndex] = value;\n\t\t\t\t\tself.wiki.setTiddlerData(self.editTitle,data);\n\t\t\t\t}\n\t\t\t};\n\t\t} else {\n\t\t\t// Get the current tiddler and the field name\n\t\t\tvar tiddler = this.wiki.getTiddler(this.editTitle);\n\t\t\tif(tiddler) {\n\t\t\t\t// If we've got a tiddler, the value to display is the field string value\n\t\t\t\tvalue = tiddler.getFieldString(this.editField);\n\t\t\t\tif(this.editField === \"text\") {\n\t\t\t\t\ttype = tiddler.fields.type || \"text/vnd.tiddlywiki\";\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// Otherwise, we need to construct a default value for the editor\n\t\t\t\tswitch(this.editField) {\n\t\t\t\t\tcase \"text\":\n\t\t\t\t\t\tvalue = \"Type the text for the tiddler '\" + this.editTitle + \"'\";\n\t\t\t\t\t\ttype = \"text/vnd.tiddlywiki\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase \"title\":\n\t\t\t\t\t\tvalue = this.editTitle;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tvalue = \"\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\tif(this.editDefault !== undefined) {\n\t\t\t\t\tvalue = this.editDefault;\n\t\t\t\t}\n\t\t\t}\n\t\t\tupdate = function(value) {\n\t\t\t\tvar tiddler = self.wiki.getTiddler(self.editTitle),\n\t\t\t\t\tupdateFields = {\n\t\t\t\t\t\ttitle: self.editTitle\n\t\t\t\t\t};\n\t\t\t\tupdateFields[self.editField] = value;\n\t\t\t\tself.wiki.addTiddler(new $tw.Tiddler(self.wiki.getCreationFields(),tiddler,updateFields,self.wiki.getModificationFields()));\n\t\t\t};\n\t\t}\n\t\tif(this.editType) {\n\t\t\ttype = this.editType;\n\t\t}\n\t\treturn {value: value || \"\", type: type, update: update};\n\t};\n\n\t/*\n\tHandle an edit text operation message from the toolbar\n\t*/\n\tEditTextWidget.prototype.handleEditTextOperationMessage = function(event) {\n\t\t// Prepare information about the operation\n\t\tvar operation = this.engine.createTextOperation();\n\t\t// Invoke the handler for the selected operation\n\t\tvar handler = this.editorOperations[event.param];\n\t\tif(handler) {\n\t\t\thandler.call(this,event,operation);\n\t\t}\n\t\t// Execute the operation via the engine\n\t\tvar newText = this.engine.executeTextOperation(operation);\n\t\t// Fix the tiddler height and save changes\n\t\tthis.engine.fixHeight();\n\t\tthis.saveChanges(newText);\n\t};\n\n\t/*\n\tCompute the internal state of the widget\n\t*/\n\tEditTextWidget.prototype.execute = function() {\n\t\t// Get our parameters\n\t\tthis.editTitle = this.getAttribute(\"tiddler\",this.getVariable(\"currentTiddler\"));\n\t\tthis.editField = this.getAttribute(\"field\",\"text\");\n\t\tthis.editIndex = this.getAttribute(\"index\");\n\t\tthis.editDefault = this.getAttribute(\"default\");\n\t\tthis.editClass = this.getAttribute(\"class\");\n\t\tthis.editPlaceholder = this.getAttribute(\"placeholder\");\n\t\tthis.editSize = this.getAttribute(\"size\");\n\t\tthis.editRows = this.getAttribute(\"rows\");\n\t\tthis.editAutoHeight = this.wiki.getTiddlerText(HEIGHT_MODE_TITLE,\"auto\");\n\t\tthis.editAutoHeight = this.getAttribute(\"autoHeight\",this.editAutoHeight === \"auto\" ? \"yes\" : \"no\") === \"yes\";\n\t\tthis.editMinHeight = this.getAttribute(\"minHeight\",DEFAULT_MIN_TEXT_AREA_HEIGHT);\n\t\tthis.editFocusPopup = this.getAttribute(\"focusPopup\");\n\t\tthis.editFocus = this.getAttribute(\"focus\");\n\t\t// Get the default editor element tag and type\n\t\tvar tag,type;\n\t\tif(this.editField === \"text\") {\n\t\t\ttag = \"textarea\";\n\t\t} else {\n\t\t\ttag = \"input\";\n\t\t\tvar fieldModule = $tw.Tiddler.fieldModules[this.editField];\n\t\t\tif(fieldModule && fieldModule.editTag) {\n\t\t\t\ttag = fieldModule.editTag;\n\t\t\t}\n\t\t\tif(fieldModule && fieldModule.editType) {\n\t\t\t\ttype = fieldModule.editType;\n\t\t\t}\n\t\t\ttype = type || \"text\";\n\t\t}\n\t\t// Get the rest of our parameters\n\t\tthis.editTag = this.getAttribute(\"tag\",tag);\n\t\tthis.editType = this.getAttribute(\"type\",type);\n\t\t// Make the child widgets\n\t\tthis.makeChildWidgets();\n\t\t// Determine whether to show the toolbar\n\t\tthis.editShowToolbar = this.wiki.getTiddlerText(ENABLE_TOOLBAR_TITLE,\"yes\");\n\t\tthis.editShowToolbar = (this.editShowToolbar === \"yes\") && !!(this.children && this.children.length > 0) && (!this.document.isTiddlyWikiFakeDom);\n\t};\n\n\t/*\n\tSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n\t*/\n\tEditTextWidget.prototype.refresh = function(changedTiddlers) {\n\t\tvar changedAttributes = this.computeAttributes();\n\t\t// Completely rerender if any of our attributes have changed\n\t\tif(changedAttributes.tiddler || changedAttributes.field || changedAttributes.index || changedAttributes[\"default\"] || changedAttributes[\"class\"] || changedAttributes.placeholder || changedAttributes.size || changedAttributes.autoHeight || changedAttributes.minHeight || changedAttributes.focusPopup || changedAttributes.rows || changedTiddlers[HEIGHT_MODE_TITLE] || changedTiddlers[ENABLE_TOOLBAR_TITLE]) {\n\t\t\tthis.refreshSelf();\n\t\t\treturn true;\n\t\t} else if(changedTiddlers[this.editTitle]) {\n\t\t\tvar editInfo = this.getEditInfo();\n\t\t\tthis.updateEditor(editInfo.value,editInfo.type);\n\t\t}\n\t\tthis.engine.fixHeight();\n\t\tif(this.editShowToolbar) {\n\t\t\treturn this.refreshChildren(changedTiddlers);\t\t\t\n\t\t} else {\n\t\t\treturn false;\n\t\t}\n\t};\n\n\t/*\n\tUpdate the editor with new text. This method is separate from updateEditorDomNode()\n\tso that subclasses can override updateEditor() and still use updateEditorDomNode()\n\t*/\n\tEditTextWidget.prototype.updateEditor = function(text,type) {\n\t\tthis.updateEditorDomNode(text,type);\n\t};\n\n\t/*\n\tUpdate the editor dom node with new text\n\t*/\n\tEditTextWidget.prototype.updateEditorDomNode = function(text,type) {\n\t\tthis.engine.setText(text,type);\n\t};\n\n\t/*\n\tSave changes back to the tiddler store\n\t*/\n\tEditTextWidget.prototype.saveChanges = function(text) {\n\t\tvar editInfo = this.getEditInfo();\n\t\tif(text !== editInfo.value) {\n\t\t\teditInfo.update(text);\n\t\t}\n\t};\n\n\t/*\n\tHandle a dom \"keydown\" event, which we'll bubble up to our container for the keyboard widgets benefit\n\t*/\n\tEditTextWidget.prototype.handleKeydownEvent = function(event) {\n\t\t// Check for a keyboard shortcut\n\t\tif(this.toolbarNode) {\n\t\t\tvar shortcutElements = this.toolbarNode.querySelectorAll(\"[data-tw-keyboard-shortcut]\");\n\t\t\tfor(var index=0; index<shortcutElements.length; index++) {\n\t\t\t\tvar el = shortcutElements[index],\n\t\t\t\t\tshortcutData = el.getAttribute(\"data-tw-keyboard-shortcut\"),\n\t\t\t\t\tkeyInfoArray = $tw.keyboardManager.parseKeyDescriptors(shortcutData,{\n\t\t\t\t\t\twiki: this.wiki\n\t\t\t\t\t});\n\t\t\t\tif($tw.keyboardManager.checkKeyDescriptors(event,keyInfoArray)) {\n\t\t\t\t\tvar clickEvent = this.document.createEvent(\"Events\");\n\t\t\t\t clickEvent.initEvent(\"click\",true,false);\n\t\t\t\t el.dispatchEvent(clickEvent);\n\t\t\t\t\tevent.preventDefault();\n\t\t\t\t\tevent.stopPropagation();\n\t\t\t\t\treturn true;\t\t\t\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t// Propogate the event to the container\n\t\tif(this.propogateKeydownEvent(event)) {\n\t\t\t// Ignore the keydown if it was already handled\n\t\t\tevent.preventDefault();\n\t\t\tevent.stopPropagation();\n\t\t\treturn true;\n\t\t}\n\t\t// Otherwise, process the keydown normally\n\t\treturn false;\n\t};\n\n\t/*\n\tPropogate keydown events to our container for the keyboard widgets benefit\n\t*/\n\tEditTextWidget.prototype.propogateKeydownEvent = function(event) {\n\t\tvar newEvent = this.document.createEventObject ? this.document.createEventObject() : this.document.createEvent(\"Events\");\n\t\tif(newEvent.initEvent) {\n\t\t\tnewEvent.initEvent(\"keydown\", true, true);\n\t\t}\n\t\tnewEvent.keyCode = event.keyCode;\n\t\tnewEvent.which = event.which;\n\t\tnewEvent.metaKey = event.metaKey;\n\t\tnewEvent.ctrlKey = event.ctrlKey;\n\t\tnewEvent.altKey = event.altKey;\n\t\tnewEvent.shiftKey = event.shiftKey;\n\t\treturn !this.parentDomNode.dispatchEvent(newEvent);\n\t};\n\n\treturn EditTextWidget;\n\n}\n\nexports.editTextWidgetFactory = editTextWidgetFactory;\n\n})();\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/core/modules/editor/operations/bitmap/clear.js": {
"title": "$:/core/modules/editor/operations/bitmap/clear.js",
"text": "/*\\\ntitle: $:/core/modules/editor/operations/bitmap/clear.js\ntype: application/javascript\nmodule-type: bitmapeditoroperation\n\nBitmap editor operation to clear the image\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports[\"clear\"] = function(event) {\n\tvar ctx = this.canvasDomNode.getContext(\"2d\");\n\tctx.globalAlpha = 1;\n\tctx.fillStyle = event.paramObject.colour || \"white\";\n\tctx.fillRect(0,0,this.canvasDomNode.width,this.canvasDomNode.height);\n\t// Save changes\n\tthis.strokeEnd();\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "bitmapeditoroperation"
},
"$:/core/modules/editor/operations/bitmap/resize.js": {
"title": "$:/core/modules/editor/operations/bitmap/resize.js",
"text": "/*\\\ntitle: $:/core/modules/editor/operations/bitmap/resize.js\ntype: application/javascript\nmodule-type: bitmapeditoroperation\n\nBitmap editor operation to resize the image\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports[\"resize\"] = function(event) {\n\t// Get the new width\n\tvar newWidth = parseInt(event.paramObject.width || this.canvasDomNode.width,10),\n\t\tnewHeight = parseInt(event.paramObject.height || this.canvasDomNode.height,10);\n\t// Update if necessary\n\tif(newWidth > 0 && newHeight > 0 && !(newWidth === this.currCanvas.width && newHeight === this.currCanvas.height)) {\n\t\tthis.changeCanvasSize(newWidth,newHeight);\n\t}\n\t// Update the input controls\n\tthis.refreshToolbar();\n\t// Save the image into the tiddler\n\tthis.saveChanges();\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "bitmapeditoroperation"
},
"$:/core/modules/editor/operations/bitmap/rotate-left.js": {
"title": "$:/core/modules/editor/operations/bitmap/rotate-left.js",
"text": "/*\\\ntitle: $:/core/modules/editor/operations/bitmap/rotate-left.js\ntype: application/javascript\nmodule-type: bitmapeditoroperation\n\nBitmap editor operation to rotate the image left by 90 degrees\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports[\"rotate-left\"] = function(event) {\n\t// Rotate the canvas left by 90 degrees\n\tthis.rotateCanvasLeft();\n\t// Update the input controls\n\tthis.refreshToolbar();\n\t// Save the image into the tiddler\n\tthis.saveChanges();\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "bitmapeditoroperation"
},
"$:/core/modules/editor/operations/text/excise.js": {
"title": "$:/core/modules/editor/operations/text/excise.js",
"text": "/*\\\ntitle: $:/core/modules/editor/operations/text/excise.js\ntype: application/javascript\nmodule-type: texteditoroperation\n\nText editor operation to excise the selection to a new tiddler\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports[\"excise\"] = function(event,operation) {\n\tvar editTiddler = this.wiki.getTiddler(this.editTitle),\n\t\teditTiddlerTitle = this.editTitle;\n\tif(editTiddler && editTiddler.fields[\"draft.of\"]) {\n\t\teditTiddlerTitle = editTiddler.fields[\"draft.of\"];\n\t}\n\tvar excisionTitle = event.paramObject.title || this.wiki.generateNewTitle(\"New Excision\");\n\tthis.wiki.addTiddler(new $tw.Tiddler(\n\t\tthis.wiki.getCreationFields(),\n\t\tthis.wiki.getModificationFields(),\n\t\t{\n\t\t\ttitle: excisionTitle,\n\t\t\ttext: operation.selection,\n\t\t\ttags: event.paramObject.tagnew === \"yes\" ? [editTiddlerTitle] : []\n\t\t}\n\t));\n\toperation.replacement = excisionTitle;\n\tswitch(event.paramObject.type || \"transclude\") {\n\t\tcase \"transclude\":\n\t\t\toperation.replacement = \"{{\" + operation.replacement+ \"}}\";\n\t\t\tbreak;\n\t\tcase \"link\":\n\t\t\toperation.replacement = \"[[\" + operation.replacement+ \"]]\";\n\t\t\tbreak;\n\t\tcase \"macro\":\n\t\t\toperation.replacement = \"<<\" + (event.paramObject.macro || \"translink\") + \" \\\"\\\"\\\"\" + operation.replacement + \"\\\"\\\"\\\">>\";\n\t\t\tbreak;\n\t}\n\toperation.cutStart = operation.selStart;\n\toperation.cutEnd = operation.selEnd;\n\toperation.newSelStart = operation.selStart;\n\toperation.newSelEnd = operation.selStart + operation.replacement.length;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "texteditoroperation"
},
"$:/core/modules/editor/operations/text/make-link.js": {
"title": "$:/core/modules/editor/operations/text/make-link.js",
"text": "/*\\\ntitle: $:/core/modules/editor/operations/text/make-link.js\ntype: application/javascript\nmodule-type: texteditoroperation\n\nText editor operation to make a link\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports[\"make-link\"] = function(event,operation) {\n\tif(operation.selection) {\n\t\toperation.replacement = \"[[\" + operation.selection + \"|\" + event.paramObject.text + \"]]\";\n\t\toperation.cutStart = operation.selStart;\n\t\toperation.cutEnd = operation.selEnd;\n\t} else {\n\t\toperation.replacement = \"[[\" + event.paramObject.text + \"]]\";\n\t\toperation.cutStart = operation.selStart;\n\t\toperation.cutEnd = operation.selEnd;\n\t}\n\toperation.newSelStart = operation.selStart + operation.replacement.length;\n\toperation.newSelEnd = operation.newSelStart;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "texteditoroperation"
},
"$:/core/modules/editor/operations/text/prefix-lines.js": {
"title": "$:/core/modules/editor/operations/text/prefix-lines.js",
"text": "/*\\\ntitle: $:/core/modules/editor/operations/text/prefix-lines.js\ntype: application/javascript\nmodule-type: texteditoroperation\n\nText editor operation to add a prefix to the selected lines\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports[\"prefix-lines\"] = function(event,operation) {\n\t// Cut just past the preceding line break, or the start of the text\n\toperation.cutStart = $tw.utils.findPrecedingLineBreak(operation.text,operation.selStart);\n\t// Cut to just past the following line break, or to the end of the text\n\toperation.cutEnd = $tw.utils.findFollowingLineBreak(operation.text,operation.selEnd);\n\t// Compose the required prefix\n\tvar prefix = $tw.utils.repeat(event.paramObject.character,event.paramObject.count);\n\t// Process each line\n\tvar lines = operation.text.substring(operation.cutStart,operation.cutEnd).split(/\\r?\\n/mg);\n\t$tw.utils.each(lines,function(line,index) {\n\t\t// Remove and count any existing prefix characters\n\t\tvar count = 0;\n\t\twhile(line.charAt(0) === event.paramObject.character) {\n\t\t\tline = line.substring(1);\n\t\t\tcount++;\n\t\t}\n\t\t// Remove any whitespace\n\t\twhile(line.charAt(0) === \" \") {\n\t\t\tline = line.substring(1);\n\t\t}\n\t\t// We're done if we removed the exact required prefix, otherwise add it\n\t\tif(count !== event.paramObject.count) {\n\t\t\t// Apply the prefix\n\t\t\tline = prefix + \" \" + line;\n\t\t}\n\t\t// Save the modified line\n\t\tlines[index] = line;\n\t});\n\t// Stitch the replacement text together and set the selection\n\toperation.replacement = lines.join(\"\\n\");\n\tif(lines.length === 1) {\n\t\toperation.newSelStart = operation.cutStart + operation.replacement.length;\n\t\toperation.newSelEnd = operation.newSelStart;\n\t} else {\n\t\toperation.newSelStart = operation.cutStart;\n\t\toperation.newSelEnd = operation.newSelStart + operation.replacement.length;\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "texteditoroperation"
},
"$:/core/modules/editor/operations/text/replace-all.js": {
"title": "$:/core/modules/editor/operations/text/replace-all.js",
"text": "/*\\\ntitle: $:/core/modules/editor/operations/text/replace-all.js\ntype: application/javascript\nmodule-type: texteditoroperation\n\nText editor operation to replace the entire text\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports[\"replace-all\"] = function(event,operation) {\n\toperation.cutStart = 0;\n\toperation.cutEnd = operation.text.length;\n\toperation.replacement = event.paramObject.text;\n\toperation.newSelStart = 0;\n\toperation.newSelEnd = operation.replacement.length;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "texteditoroperation"
},
"$:/core/modules/editor/operations/text/replace-selection.js": {
"title": "$:/core/modules/editor/operations/text/replace-selection.js",
"text": "/*\\\ntitle: $:/core/modules/editor/operations/text/replace-selection.js\ntype: application/javascript\nmodule-type: texteditoroperation\n\nText editor operation to replace the selection\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports[\"replace-selection\"] = function(event,operation) {\n\toperation.replacement = event.paramObject.text;\n\toperation.cutStart = operation.selStart;\n\toperation.cutEnd = operation.selEnd;\n\toperation.newSelStart = operation.selStart;\n\toperation.newSelEnd = operation.selStart + operation.replacement.length;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "texteditoroperation"
},
"$:/core/modules/editor/operations/text/save-selection.js": {
"title": "$:/core/modules/editor/operations/text/save-selection.js",
"text": "/*\\\ntitle: $:/core/modules/editor/operations/text/save-selection.js\ntype: application/javascript\nmodule-type: texteditoroperation\n\nText editor operation to save the current selection in a specified tiddler\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports[\"save-selection\"] = function(event,operation) {\n\tvar tiddler = event.paramObject.tiddler,\n\t\tfield = event.paramObject.field || \"text\";\n\tif(tiddler && field) {\n\t\tthis.wiki.setText(tiddler,field,null,operation.text.substring(operation.selStart,operation.selEnd));\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "texteditoroperation"
},
"$:/core/modules/editor/operations/text/wrap-lines.js": {
"title": "$:/core/modules/editor/operations/text/wrap-lines.js",
"text": "/*\\\ntitle: $:/core/modules/editor/operations/text/wrap-lines.js\ntype: application/javascript\nmodule-type: texteditoroperation\n\nText editor operation to wrap the selected lines with a prefix and suffix\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports[\"wrap-lines\"] = function(event,operation) {\n\t// Cut just past the preceding line break, or the start of the text\n\toperation.cutStart = $tw.utils.findPrecedingLineBreak(operation.text,operation.selStart);\n\t// Cut to just past the following line break, or to the end of the text\n\toperation.cutEnd = $tw.utils.findFollowingLineBreak(operation.text,operation.selEnd);\n\t// Add the prefix and suffix\n\toperation.replacement = event.paramObject.prefix + \"\\n\" +\n\t\t\t\toperation.text.substring(operation.cutStart,operation.cutEnd) + \"\\n\" +\n\t\t\t\tevent.paramObject.suffix + \"\\n\";\n\toperation.newSelStart = operation.cutStart + event.paramObject.prefix.length + 1;\n\toperation.newSelEnd = operation.newSelStart + (operation.cutEnd - operation.cutStart);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "texteditoroperation"
},
"$:/core/modules/editor/operations/text/wrap-selection.js": {
"title": "$:/core/modules/editor/operations/text/wrap-selection.js",
"text": "/*\\\ntitle: $:/core/modules/editor/operations/text/wrap-selection.js\ntype: application/javascript\nmodule-type: texteditoroperation\n\nText editor operation to wrap the selection with the specified prefix and suffix\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports[\"wrap-selection\"] = function(event,operation) {\n\tif(operation.selStart === operation.selEnd) {\n\t\t// No selection; check if we're within the prefix/suffix\n\t\tif(operation.text.substring(operation.selStart - event.paramObject.prefix.length,operation.selStart + event.paramObject.suffix.length) === event.paramObject.prefix + event.paramObject.suffix) {\n\t\t\t// Remove the prefix and suffix unless they comprise the entire text\n\t\t\tif(operation.selStart > event.paramObject.prefix.length || (operation.selEnd + event.paramObject.suffix.length) < operation.text.length ) {\n\t\t\t\toperation.cutStart = operation.selStart - event.paramObject.prefix.length;\n\t\t\t\toperation.cutEnd = operation.selEnd + event.paramObject.suffix.length;\n\t\t\t\toperation.replacement = \"\";\n\t\t\t\toperation.newSelStart = operation.cutStart;\n\t\t\t\toperation.newSelEnd = operation.newSelStart;\n\t\t\t}\n\t\t} else {\n\t\t\t// Wrap the cursor instead\n\t\t\toperation.cutStart = operation.selStart;\n\t\t\toperation.cutEnd = operation.selEnd;\n\t\t\toperation.replacement = event.paramObject.prefix + event.paramObject.suffix;\n\t\t\toperation.newSelStart = operation.selStart + event.paramObject.prefix.length;\n\t\t\toperation.newSelEnd = operation.newSelStart;\n\t\t}\n\t} else if(operation.text.substring(operation.selStart,operation.selStart + event.paramObject.prefix.length) === event.paramObject.prefix && operation.text.substring(operation.selEnd - event.paramObject.suffix.length,operation.selEnd) === event.paramObject.suffix) {\n\t\t// Prefix and suffix are already present, so remove them\n\t\toperation.cutStart = operation.selStart;\n\t\toperation.cutEnd = operation.selEnd;\n\t\toperation.replacement = operation.selection.substring(event.paramObject.prefix.length,operation.selection.length - event.paramObject.suffix.length);\n\t\toperation.newSelStart = operation.selStart;\n\t\toperation.newSelEnd = operation.selStart + operation.replacement.length;\n\t} else {\n\t\t// Add the prefix and suffix\n\t\toperation.cutStart = operation.selStart;\n\t\toperation.cutEnd = operation.selEnd;\n\t\toperation.replacement = event.paramObject.prefix + operation.selection + event.paramObject.suffix;\n\t\toperation.newSelStart = operation.selStart;\n\t\toperation.newSelEnd = operation.selStart + operation.replacement.length;\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "texteditoroperation"
},
"$:/core/modules/filters/addprefix.js": {
"title": "$:/core/modules/filters/addprefix.js",
"text": "/*\\\ntitle: $:/core/modules/filters/addprefix.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for adding a prefix to each title in the list. This is\nespecially useful in contexts where only a filter expression is allowed\nand macro substitution isn't available.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.addprefix = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push(operator.operand + title);\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/addsuffix.js": {
"title": "$:/core/modules/filters/addsuffix.js",
"text": "/*\\\ntitle: $:/core/modules/filters/addsuffix.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for adding a suffix to each title in the list. This is\nespecially useful in contexts where only a filter expression is allowed\nand macro substitution isn't available.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.addsuffix = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push(title + operator.operand);\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/after.js": {
"title": "$:/core/modules/filters/after.js",
"text": "/*\\\ntitle: $:/core/modules/filters/after.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator returning the tiddler from the current list that is after the tiddler named in the operand.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.after = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push(title);\n\t});\n\tvar index = results.indexOf(operator.operand);\n\tif(index === -1 || index > (results.length - 2)) {\n\t\treturn [];\n\t} else {\n\t\treturn [results[index + 1]];\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/all/current.js": {
"title": "$:/core/modules/filters/all/current.js",
"text": "/*\\\ntitle: $:/core/modules/filters/all/current.js\ntype: application/javascript\nmodule-type: allfilteroperator\n\nFilter function for [all[current]]\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.current = function(source,prefix,options) {\n\tvar currTiddlerTitle = options.widget && options.widget.getVariable(\"currentTiddler\");\n\tif(currTiddlerTitle) {\n\t\treturn [currTiddlerTitle];\n\t} else {\n\t\treturn [];\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "allfilteroperator"
},
"$:/core/modules/filters/all/missing.js": {
"title": "$:/core/modules/filters/all/missing.js",
"text": "/*\\\ntitle: $:/core/modules/filters/all/missing.js\ntype: application/javascript\nmodule-type: allfilteroperator\n\nFilter function for [all[missing]]\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.missing = function(source,prefix,options) {\n\treturn options.wiki.getMissingTitles();\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "allfilteroperator"
},
"$:/core/modules/filters/all/orphans.js": {
"title": "$:/core/modules/filters/all/orphans.js",
"text": "/*\\\ntitle: $:/core/modules/filters/all/orphans.js\ntype: application/javascript\nmodule-type: allfilteroperator\n\nFilter function for [all[orphans]]\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.orphans = function(source,prefix,options) {\n\treturn options.wiki.getOrphanTitles();\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "allfilteroperator"
},
"$:/core/modules/filters/all/shadows.js": {
"title": "$:/core/modules/filters/all/shadows.js",
"text": "/*\\\ntitle: $:/core/modules/filters/all/shadows.js\ntype: application/javascript\nmodule-type: allfilteroperator\n\nFilter function for [all[shadows]]\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.shadows = function(source,prefix,options) {\n\treturn options.wiki.allShadowTitles();\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "allfilteroperator"
},
"$:/core/modules/filters/all/tags.js": {
"title": "$:/core/modules/filters/all/tags.js",
"text": "/*\\\ntitle: $:/core/modules/filters/all/tags.js\ntype: application/javascript\nmodule-type: allfilteroperator\n\nFilter function for [all[tags]]\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.tags = function(source,prefix,options) {\n\treturn Object.keys(options.wiki.getTagMap());\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "allfilteroperator"
},
"$:/core/modules/filters/all/tiddlers.js": {
"title": "$:/core/modules/filters/all/tiddlers.js",
"text": "/*\\\ntitle: $:/core/modules/filters/all/tiddlers.js\ntype: application/javascript\nmodule-type: allfilteroperator\n\nFilter function for [all[tiddlers]]\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.tiddlers = function(source,prefix,options) {\n\treturn options.wiki.allTitles();\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "allfilteroperator"
},
"$:/core/modules/filters/all.js": {
"title": "$:/core/modules/filters/all.js",
"text": "/*\\\ntitle: $:/core/modules/filters/all.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for selecting tiddlers\n\n[all[shadows+tiddlers]]\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar allFilterOperators;\n\nfunction getAllFilterOperators() {\n\tif(!allFilterOperators) {\n\t\tallFilterOperators = {};\n\t\t$tw.modules.applyMethods(\"allfilteroperator\",allFilterOperators);\n\t}\n\treturn allFilterOperators;\n}\n\n/*\nExport our filter function\n*/\nexports.all = function(source,operator,options) {\n\t// Get our suboperators\n\tvar allFilterOperators = getAllFilterOperators();\n\t// Cycle through the suboperators accumulating their results\n\tvar results = [],\n\t\tsubops = operator.operand.split(\"+\");\n\t// Check for common optimisations\n\tif(subops.length === 1 && subops[0] === \"\") {\n\t\treturn source;\n\t} else if(subops.length === 1 && subops[0] === \"tiddlers\") {\n\t\treturn options.wiki.each;\n\t} else if(subops.length === 1 && subops[0] === \"shadows\") {\n\t\treturn options.wiki.eachShadow;\n\t} else if(subops.length === 2 && subops[0] === \"tiddlers\" && subops[1] === \"shadows\") {\n\t\treturn options.wiki.eachTiddlerPlusShadows;\n\t} else if(subops.length === 2 && subops[0] === \"shadows\" && subops[1] === \"tiddlers\") {\n\t\treturn options.wiki.eachShadowPlusTiddlers;\n\t}\n\t// Do it the hard way\n\tfor(var t=0; t<subops.length; t++) {\n\t\tvar subop = allFilterOperators[subops[t]];\n\t\tif(subop) {\n\t\t\t$tw.utils.pushTop(results,subop(source,operator.prefix,options));\n\t\t}\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/backlinks.js": {
"title": "$:/core/modules/filters/backlinks.js",
"text": "/*\\\ntitle: $:/core/modules/filters/backlinks.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for returning all the backlinks from a tiddler\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.backlinks = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\t$tw.utils.pushTop(results,options.wiki.getTiddlerBacklinks(title));\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/before.js": {
"title": "$:/core/modules/filters/before.js",
"text": "/*\\\ntitle: $:/core/modules/filters/before.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator returning the tiddler from the current list that is before the tiddler named in the operand.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.before = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push(title);\n\t});\n\tvar index = results.indexOf(operator.operand);\n\tif(index <= 0) {\n\t\treturn [];\n\t} else {\n\t\treturn [results[index - 1]];\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/commands.js": {
"title": "$:/core/modules/filters/commands.js",
"text": "/*\\\ntitle: $:/core/modules/filters/commands.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for returning the names of the commands available in this wiki\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.commands = function(source,operator,options) {\n\tvar results = [];\n\t$tw.utils.each($tw.commands,function(commandInfo,name) {\n\t\tresults.push(name);\n\t});\n\tresults.sort();\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/contains.js": {
"title": "$:/core/modules/filters/contains.js",
"text": "/*\\\ntitle: $:/core/modules/filters/contains.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for finding values in array fields\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.contains = function(source,operator,options) {\n\tvar results = [],\n\t\tfieldname = (operator.suffix || \"list\").toLowerCase();\n\tif(operator.prefix === \"!\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(tiddler) {\n\t\t\t\tvar list = tiddler.getFieldList(fieldname);\n\t\t\t\tif(list.indexOf(operator.operand) === -1) {\n\t\t\t\t\tresults.push(title);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(tiddler) {\n\t\t\t\tvar list = tiddler.getFieldList(fieldname);\n\t\t\t\tif(list.indexOf(operator.operand) !== -1) {\n\t\t\t\t\tresults.push(title);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/count.js": {
"title": "$:/core/modules/filters/count.js",
"text": "/*\\\ntitle: $:/core/modules/filters/count.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator returning the number of entries in the current list.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.count = function(source,operator,options) {\n\tvar count = 0;\n\tsource(function(tiddler,title) {\n\t\tcount++;\n\t});\n\treturn [count + \"\"];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/days.js": {
"title": "$:/core/modules/filters/days.js",
"text": "/*\\\ntitle: $:/core/modules/filters/days.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator that selects tiddlers with a specified date field within a specified date interval.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.days = function(source,operator,options) {\n\tvar results = [],\n\t\tfieldName = operator.suffix || \"modified\",\n\t\tdayInterval = (parseInt(operator.operand,10)||0),\n\t\tdayIntervalSign = $tw.utils.sign(dayInterval),\n\t\ttargetTimeStamp = (new Date()).setHours(0,0,0,0) + 1000*60*60*24*dayInterval,\n\t\tisWithinDays = function(dateField) {\n\t\t\tvar sign = $tw.utils.sign(targetTimeStamp - (new Date(dateField)).setHours(0,0,0,0));\n\t\t\treturn sign === 0 || sign === dayIntervalSign;\n\t\t};\n\n\tif(operator.prefix === \"!\") {\n\t\ttargetTimeStamp = targetTimeStamp - 1000*60*60*24*dayIntervalSign;\n\t\tsource(function(tiddler,title) {\n\t\t\tif(tiddler && tiddler.fields[fieldName]) {\n\t\t\t\tif(!isWithinDays($tw.utils.parseDate(tiddler.fields[fieldName]))) {\n\t\t\t\t\tresults.push(title);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(tiddler && tiddler.fields[fieldName]) {\n\t\t\t\tif(isWithinDays($tw.utils.parseDate(tiddler.fields[fieldName]))) {\n\t\t\t\t\tresults.push(title);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/each.js": {
"title": "$:/core/modules/filters/each.js",
"text": "/*\\\ntitle: $:/core/modules/filters/each.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator that selects one tiddler for each unique value of the specified field.\nWith suffix \"list\", selects all tiddlers that are values in a specified list field.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.each = function(source,operator,options) {\n\tvar results =[] ,\n\tvalue,values = {},\n\tfield = operator.operand || \"title\";\n\tif(operator.suffix === \"value\" && field === \"title\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(!$tw.utils.hop(values,title)) {\n\t\t\t\tvalues[title] = true;\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t} else if(operator.suffix !== \"list-item\") {\n\t\tif(field === \"title\") {\n\t\t\tsource(function(tiddler,title) {\n\t\t\t\tif(tiddler && !$tw.utils.hop(values,title)) {\n\t\t\t\t\tvalues[title] = true;\n\t\t\t\t\tresults.push(title);\n\t\t\t\t}\n\t\t\t});\n\t\t} else {\n\t\t\tsource(function(tiddler,title) {\n\t\t\t\tif(tiddler) {\n\t\t\t\t\tvalue = tiddler.getFieldString(field);\n\t\t\t\t\tif(!$tw.utils.hop(values,value)) {\n\t\t\t\t\t\tvalues[value] = true;\n\t\t\t\t\t\tresults.push(title);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(tiddler) {\n\t\t\t\t$tw.utils.each(\n\t\t\t\t\toptions.wiki.getTiddlerList(title,field),\n\t\t\t\t\tfunction(value) {\n\t\t\t\t\t\tif(!$tw.utils.hop(values,value)) {\n\t\t\t\t\t\t\tvalues[value] = true;\n\t\t\t\t\t\t\tresults.push(value);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/eachday.js": {
"title": "$:/core/modules/filters/eachday.js",
"text": "/*\\\ntitle: $:/core/modules/filters/eachday.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator that selects one tiddler for each unique day covered by the specified date field\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.eachday = function(source,operator,options) {\n\tvar results = [],\n\t\tvalues = [],\n\t\tfieldName = operator.operand || \"modified\";\n\t// Function to convert a date/time to a date integer\n\tvar toDate = function(value) {\n\t\tvalue = (new Date(value)).setHours(0,0,0,0);\n\t\treturn value+0;\n\t};\n\tsource(function(tiddler,title) {\n\t\tif(tiddler && tiddler.fields[fieldName]) {\n\t\t\tvar value = toDate($tw.utils.parseDate(tiddler.fields[fieldName]));\n\t\t\tif(values.indexOf(value) === -1) {\n\t\t\t\tvalues.push(value);\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t}\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/editiondescription.js": {
"title": "$:/core/modules/filters/editiondescription.js",
"text": "/*\\\ntitle: $:/core/modules/filters/editiondescription.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for returning the descriptions of the specified edition names\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.editiondescription = function(source,operator,options) {\n\tvar results = [],\n\t\teditionInfo = $tw.utils.getEditionInfo();\n\tif(editionInfo) {\n\t\tsource(function(tiddler,title) {\n\t\t\tif($tw.utils.hop(editionInfo,title)) {\n\t\t\t\tresults.push(editionInfo[title].description || \"\");\t\t\t\t\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/editions.js": {
"title": "$:/core/modules/filters/editions.js",
"text": "/*\\\ntitle: $:/core/modules/filters/editions.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for returning the names of the available editions in this wiki\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.editions = function(source,operator,options) {\n\tvar results = [],\n\t\teditionInfo = $tw.utils.getEditionInfo();\n\tif(editionInfo) {\n\t\t$tw.utils.each(editionInfo,function(info,name) {\n\t\t\tresults.push(name);\n\t\t});\n\t}\n\tresults.sort();\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/decodeuricomponent.js": {
"title": "$:/core/modules/filters/decodeuricomponent.js",
"text": "/*\\\ntitle: $:/core/modules/filters/decodeuricomponent.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for applying decodeURIComponent() to each item.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter functions\n*/\n\nexports.decodeuricomponent = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tvar value = title;\n\t\ttry {\n\t\t\tvalue = decodeURIComponent(title);\n\t\t} catch(e) {\n\t\t}\n\t\tresults.push(value);\n\t});\n\treturn results;\n};\n\nexports.encodeuricomponent = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push(encodeURIComponent(title));\n\t});\n\treturn results;\n};\n\nexports.decodeuri = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tvar value = title;\n\t\ttry {\n\t\t\tvalue = decodeURI(title);\n\t\t} catch(e) {\n\t\t}\n\t\tresults.push(value);\n\t});\n\treturn results;\n};\n\nexports.encodeuri = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push(encodeURI(title));\n\t});\n\treturn results;\n};\n\nexports.decodehtml = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push($tw.utils.htmlDecode(title));\n\t});\n\treturn results;\n};\n\nexports.encodehtml = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push($tw.utils.htmlEncode(title));\n\t});\n\treturn results;\n};\n\nexports.stringify = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push($tw.utils.stringify(title));\n\t});\n\treturn results;\n};\n\nexports.jsonstringify = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push($tw.utils.jsonStringify(title));\n\t});\n\treturn results;\n};\n\nexports.escaperegexp = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push($tw.utils.escapeRegExp(title));\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/enlist.js": {
"title": "$:/core/modules/filters/enlist.js",
"text": "/*\\\ntitle: $:/core/modules/filters/enlist.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator returning its operand parsed as a list\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.enlist = function(source,operator,options) {\n\tvar list = $tw.utils.parseStringArray(operator.operand);\n\tif(operator.prefix === \"!\") {\n\t\tvar results = [];\n\t\tsource(function(tiddler,title) {\n\t\t\tif(list.indexOf(title) === -1) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t\treturn results;\n\t} else {\n\t\treturn list;\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/field.js": {
"title": "$:/core/modules/filters/field.js",
"text": "/*\\\ntitle: $:/core/modules/filters/field.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for comparing fields for equality\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.field = function(source,operator,options) {\n\tvar results = [],\n\t\tfieldname = (operator.suffix || operator.operator || \"title\").toLowerCase();\n\tif(operator.prefix === \"!\") {\n\t\tif(operator.regexp) {\n\t\t\tsource(function(tiddler,title) {\n\t\t\t\tif(tiddler) {\n\t\t\t\t\tvar text = tiddler.getFieldString(fieldname);\n\t\t\t\t\tif(text !== null && !operator.regexp.exec(text)) {\n\t\t\t\t\t\tresults.push(title);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tresults.push(title);\n\t\t\t\t}\n\t\t\t});\n\t\t} else {\n\t\t\tsource(function(tiddler,title) {\n\t\t\t\tif(tiddler) {\n\t\t\t\t\tvar text = tiddler.getFieldString(fieldname);\n\t\t\t\t\tif(text !== null && text !== operator.operand) {\n\t\t\t\t\t\tresults.push(title);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tresults.push(title);\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t} else {\n\t\tif(operator.regexp) {\n\t\t\tsource(function(tiddler,title) {\n\t\t\t\tif(tiddler) {\n\t\t\t\t\tvar text = tiddler.getFieldString(fieldname);\n\t\t\t\t\tif(text !== null && !!operator.regexp.exec(text)) {\n\t\t\t\t\t\tresults.push(title);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t} else {\n\t\t\tsource(function(tiddler,title) {\n\t\t\t\tif(tiddler) {\n\t\t\t\t\tvar text = tiddler.getFieldString(fieldname);\n\t\t\t\t\tif(text !== null && text === operator.operand) {\n\t\t\t\t\t\tresults.push(title);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/fields.js": {
"title": "$:/core/modules/filters/fields.js",
"text": "/*\\\ntitle: $:/core/modules/filters/fields.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for returning the names of the fields on the selected tiddlers\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.fields = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tif(tiddler) {\n\t\t\tfor(var fieldName in tiddler.fields) {\n\t\t\t\t$tw.utils.pushTop(results,fieldName);\n\t\t\t}\n\t\t}\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/get.js": {
"title": "$:/core/modules/filters/get.js",
"text": "/*\\\ntitle: $:/core/modules/filters/get.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for replacing tiddler titles by the value of the field specified in the operand.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.get = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tif(tiddler) {\n\t\t\tvar value = tiddler.getFieldString(operator.operand);\n\t\t\tif(value) {\n\t\t\t\tresults.push(value);\n\t\t\t}\n\t\t}\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/getindex.js": {
"title": "$:/core/modules/filters/getindex.js",
"text": "/*\\\ntitle: $:/core/modules/filters/getindex.js\ntype: application/javascript\nmodule-type: filteroperator\n\nreturns the value at a given index of datatiddlers\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.getindex = function(source,operator,options) {\n\tvar data,title,results = [];\n\tif(operator.operand){\n\t\tsource(function(tiddler,title) {\n\t\t\ttitle = tiddler ? tiddler.fields.title : title;\n\t\t\tdata = options.wiki.extractTiddlerDataItem(tiddler,operator.operand);\n\t\t\tif(data) {\n\t\t\t\tresults.push(data);\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/has.js": {
"title": "$:/core/modules/filters/has.js",
"text": "/*\\\ntitle: $:/core/modules/filters/has.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for checking if a tiddler has the specified field\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.has = function(source,operator,options) {\n\tvar results = [],\n\t\tinvert = operator.prefix === \"!\";\n\n\tif(operator.suffix === \"field\") {\n\t\tif(invert) {\n\t\t\tsource(function(tiddler,title) {\n\t\t\t\tif(!tiddler || (tiddler && (!$tw.utils.hop(tiddler.fields,operator.operand)))) {\n\t\t\t\t\tresults.push(title);\n\t\t\t\t}\n\t\t\t});\n\t\t} else {\n\t\t\tsource(function(tiddler,title) {\n\t\t\t\tif(tiddler && $tw.utils.hop(tiddler.fields,operator.operand)) {\n\t\t\t\t\tresults.push(title);\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t} else {\n\t\tif(invert) {\n\t\t\tsource(function(tiddler,title) {\n\t\t\t\tif(!tiddler || !$tw.utils.hop(tiddler.fields,operator.operand) || (tiddler.fields[operator.operand] === \"\")) {\n\t\t\t\t\tresults.push(title);\n\t\t\t\t}\n\t\t\t});\n\t\t} else {\n\t\t\tsource(function(tiddler,title) {\n\t\t\t\tif(tiddler && $tw.utils.hop(tiddler.fields,operator.operand) && !(tiddler.fields[operator.operand] === \"\" || tiddler.fields[operator.operand].length === 0)) {\n\t\t\t\t\tresults.push(title);\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/haschanged.js": {
"title": "$:/core/modules/filters/haschanged.js",
"text": "/*\\\ntitle: $:/core/modules/filters/haschanged.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator returns tiddlers from the list that have a non-zero changecount.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.haschanged = function(source,operator,options) {\n\tvar results = [];\n\tif(operator.prefix === \"!\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(options.wiki.getChangeCount(title) === 0) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(options.wiki.getChangeCount(title) > 0) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/indexes.js": {
"title": "$:/core/modules/filters/indexes.js",
"text": "/*\\\ntitle: $:/core/modules/filters/indexes.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for returning the indexes of a data tiddler\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.indexes = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tvar data = options.wiki.getTiddlerDataCached(title);\n\t\tif(data) {\n\t\t\t$tw.utils.pushTop(results,Object.keys(data));\n\t\t}\n\t});\n\tresults.sort();\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/insertbefore.js": {
"title": "$:/core/modules/filters/insertbefore.js",
"text": "/*\\\ntitle: $:/core/modules/filters/insertbefore.js\ntype: application/javascript\nmodule-type: filteroperator\n\nInsert an item before another item in a list\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nOrder a list\n*/\nexports.insertbefore = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push(title);\n\t});\n\tvar target = options.widget && options.widget.getVariable(operator.suffix || \"currentTiddler\");\n\tif(target !== operator.operand) {\n\t\t// Remove the entry from the list if it is present\n\t\tvar pos = results.indexOf(operator.operand);\n\t\tif(pos !== -1) {\n\t\t\tresults.splice(pos,1);\n\t\t}\n\t\t// Insert the entry before the target marker\n\t\tpos = results.indexOf(target);\n\t\tif(pos !== -1) {\n\t\t\tresults.splice(pos,0,operator.operand);\n\t\t} else {\n\t\t\tresults.push(operator.operand);\n\t\t}\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/is/current.js": {
"title": "$:/core/modules/filters/is/current.js",
"text": "/*\\\ntitle: $:/core/modules/filters/is/current.js\ntype: application/javascript\nmodule-type: isfilteroperator\n\nFilter function for [is[current]]\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.current = function(source,prefix,options) {\n\tvar results = [],\n\t\tcurrTiddlerTitle = options.widget && options.widget.getVariable(\"currentTiddler\");\n\tif(prefix === \"!\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(title !== currTiddlerTitle) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(title === currTiddlerTitle) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "isfilteroperator"
},
"$:/core/modules/filters/is/image.js": {
"title": "$:/core/modules/filters/is/image.js",
"text": "/*\\\ntitle: $:/core/modules/filters/is/image.js\ntype: application/javascript\nmodule-type: isfilteroperator\n\nFilter function for [is[image]]\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.image = function(source,prefix,options) {\n\tvar results = [];\n\tif(prefix === \"!\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(!options.wiki.isImageTiddler(title)) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(options.wiki.isImageTiddler(title)) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "isfilteroperator"
},
"$:/core/modules/filters/is/missing.js": {
"title": "$:/core/modules/filters/is/missing.js",
"text": "/*\\\ntitle: $:/core/modules/filters/is/missing.js\ntype: application/javascript\nmodule-type: isfilteroperator\n\nFilter function for [is[missing]]\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.missing = function(source,prefix,options) {\n\tvar results = [];\n\tif(prefix === \"!\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(options.wiki.tiddlerExists(title)) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(!options.wiki.tiddlerExists(title)) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "isfilteroperator"
},
"$:/core/modules/filters/is/orphan.js": {
"title": "$:/core/modules/filters/is/orphan.js",
"text": "/*\\\ntitle: $:/core/modules/filters/is/orphan.js\ntype: application/javascript\nmodule-type: isfilteroperator\n\nFilter function for [is[orphan]]\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.orphan = function(source,prefix,options) {\n\tvar results = [],\n\t\torphanTitles = options.wiki.getOrphanTitles();\n\tif(prefix === \"!\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(orphanTitles.indexOf(title) === -1) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(orphanTitles.indexOf(title) !== -1) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "isfilteroperator"
},
"$:/core/modules/filters/is/shadow.js": {
"title": "$:/core/modules/filters/is/shadow.js",
"text": "/*\\\ntitle: $:/core/modules/filters/is/shadow.js\ntype: application/javascript\nmodule-type: isfilteroperator\n\nFilter function for [is[shadow]]\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.shadow = function(source,prefix,options) {\n\tvar results = [];\n\tif(prefix === \"!\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(!options.wiki.isShadowTiddler(title)) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(options.wiki.isShadowTiddler(title)) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "isfilteroperator"
},
"$:/core/modules/filters/is/system.js": {
"title": "$:/core/modules/filters/is/system.js",
"text": "/*\\\ntitle: $:/core/modules/filters/is/system.js\ntype: application/javascript\nmodule-type: isfilteroperator\n\nFilter function for [is[system]]\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.system = function(source,prefix,options) {\n\tvar results = [];\n\tif(prefix === \"!\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(!options.wiki.isSystemTiddler(title)) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(options.wiki.isSystemTiddler(title)) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "isfilteroperator"
},
"$:/core/modules/filters/is/tag.js": {
"title": "$:/core/modules/filters/is/tag.js",
"text": "/*\\\ntitle: $:/core/modules/filters/is/tag.js\ntype: application/javascript\nmodule-type: isfilteroperator\n\nFilter function for [is[tag]]\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.tag = function(source,prefix,options) {\n\tvar results = [],\n\t\ttagMap = options.wiki.getTagMap();\n\tif(prefix === \"!\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(!$tw.utils.hop(tagMap,title)) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\tif($tw.utils.hop(tagMap,title)) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "isfilteroperator"
},
"$:/core/modules/filters/is/tiddler.js": {
"title": "$:/core/modules/filters/is/tiddler.js",
"text": "/*\\\ntitle: $:/core/modules/filters/is/tiddler.js\ntype: application/javascript\nmodule-type: isfilteroperator\n\nFilter function for [is[tiddler]]\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.tiddler = function(source,prefix,options) {\n\tvar results = [];\n\tif(prefix === \"!\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(!options.wiki.tiddlerExists(title)) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(options.wiki.tiddlerExists(title)) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "isfilteroperator"
},
"$:/core/modules/filters/is.js": {
"title": "$:/core/modules/filters/is.js",
"text": "/*\\\ntitle: $:/core/modules/filters/is.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for checking tiddler properties\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar isFilterOperators;\n\nfunction getIsFilterOperators() {\n\tif(!isFilterOperators) {\n\t\tisFilterOperators = {};\n\t\t$tw.modules.applyMethods(\"isfilteroperator\",isFilterOperators);\n\t}\n\treturn isFilterOperators;\n}\n\n/*\nExport our filter function\n*/\nexports.is = function(source,operator,options) {\n\t// Dispatch to the correct isfilteroperator\n\tvar isFilterOperators = getIsFilterOperators();\n\tif(operator.operand) {\n\t\tvar isFilterOperator = isFilterOperators[operator.operand];\n\t\tif(isFilterOperator) {\n\t\t\treturn isFilterOperator(source,operator.prefix,options);\n\t\t} else {\n\t\t\treturn [$tw.language.getString(\"Error/IsFilterOperator\")];\n\t\t}\n\t} else {\n\t\t// Return all tiddlers if the operand is missing\n\t\tvar results = [];\n\t\tsource(function(tiddler,title) {\n\t\t\tresults.push(title);\n\t\t});\n\t\treturn results;\n\t}\n};\n\n})();",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/limit.js": {
"title": "$:/core/modules/filters/limit.js",
"text": "/*\\\ntitle: $:/core/modules/filters/limit.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for chopping the results to a specified maximum number of entries\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.limit = function(source,operator,options) {\n\tvar results = [];\n\t// Convert to an array\n\tsource(function(tiddler,title) {\n\t\tresults.push(title);\n\t});\n\t// Slice the array if necessary\n\tvar limit = Math.min(results.length,parseInt(operator.operand,10));\n\tif(operator.prefix === \"!\") {\n\t\tresults = results.slice(-limit);\n\t} else {\n\t\tresults = results.slice(0,limit);\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/links.js": {
"title": "$:/core/modules/filters/links.js",
"text": "/*\\\ntitle: $:/core/modules/filters/links.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for returning all the links from a tiddler\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.links = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\t$tw.utils.pushTop(results,options.wiki.getTiddlerLinks(title));\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/list.js": {
"title": "$:/core/modules/filters/list.js",
"text": "/*\\\ntitle: $:/core/modules/filters/list.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator returning the tiddlers whose title is listed in the operand tiddler\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.list = function(source,operator,options) {\n\tvar results = [],\n\t\ttr = $tw.utils.parseTextReference(operator.operand),\n\t\tcurrTiddlerTitle = options.widget && options.widget.getVariable(\"currentTiddler\"),\n\t\tlist = options.wiki.getTiddlerList(tr.title || currTiddlerTitle,tr.field,tr.index);\n\tif(operator.prefix === \"!\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(list.indexOf(title) === -1) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t} else {\n\t\tresults = list;\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/listed.js": {
"title": "$:/core/modules/filters/listed.js",
"text": "/*\\\ntitle: $:/core/modules/filters/listed.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator returning all tiddlers that have the selected tiddlers in a list\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.listed = function(source,operator,options) {\n\tvar field = operator.operand || \"list\",\n\t\tresults = [];\n\tsource(function(tiddler,title) {\n\t\t$tw.utils.pushTop(results,options.wiki.findListingsOfTiddler(title,field));\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/listops.js": {
"title": "$:/core/modules/filters/listops.js",
"text": "/*\\\ntitle: $:/core/modules/filters/listops.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operators for manipulating the current selection list\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nOrder a list\n*/\nexports.order = function(source,operator,options) {\n\tvar results = [];\n\tif(operator.operand.toLowerCase() === \"reverse\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tresults.unshift(title);\n\t\t});\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\tresults.push(title);\n\t\t});\n\t}\n\treturn results;\n};\n\n/*\nReverse list\n*/\nexports.reverse = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tresults.unshift(title);\n\t});\n\treturn results;\n};\n\n/*\nFirst entry/entries in list\n*/\nexports.first = function(source,operator,options) {\n\tvar count = $tw.utils.getInt(operator.operand,1),\n\t\tresults = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push(title);\n\t});\n\treturn results.slice(0,count);\n};\n\n/*\nLast entry/entries in list\n*/\nexports.last = function(source,operator,options) {\n\tvar count = $tw.utils.getInt(operator.operand,1),\n\t\tresults = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push(title);\n\t});\n\treturn results.slice(-count);\n};\n\n/*\nAll but the first entry/entries of the list\n*/\nexports.rest = function(source,operator,options) {\n\tvar count = $tw.utils.getInt(operator.operand,1),\n\t\tresults = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push(title);\n\t});\n\treturn results.slice(count);\n};\nexports.butfirst = exports.rest;\nexports.bf = exports.rest;\n\n/*\nAll but the last entry/entries of the list\n*/\nexports.butlast = function(source,operator,options) {\n\tvar count = $tw.utils.getInt(operator.operand,1),\n\t\tresults = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push(title);\n\t});\n\treturn results.slice(0,-count);\n};\nexports.bl = exports.butlast;\n\n/*\nThe nth member of the list\n*/\nexports.nth = function(source,operator,options) {\n\tvar count = $tw.utils.getInt(operator.operand,1),\n\t\tresults = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push(title);\n\t});\n\treturn results.slice(count - 1,count);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/lookup.js": {
"title": "$:/core/modules/filters/lookup.js",
"text": "/*\\\ntitle: $:/core/modules/filters/lookup.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator that looks up values via a title prefix\n\n[lookup:<field>[<prefix>]]\n\nPrepends the prefix to the selected items and returns the specified field value\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.lookup = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push(options.wiki.getTiddlerText(operator.operand + title) || options.wiki.getTiddlerText(operator.operand + operator.suffix));\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/minlength.js": {
"title": "$:/core/modules/filters/minlength.js",
"text": "/*\\\ntitle: $:/core/modules/filters/minlength.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for filtering out titles that don't meet the minimum length in the operand\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.minlength = function(source,operator,options) {\n\tvar results = [],\n\t\tminLength = parseInt(operator.operand || \"\",10) || 0;\n\tsource(function(tiddler,title) {\n\t\tif(title.length >= minLength) {\n\t\t\tresults.push(title);\n\t\t}\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/modules.js": {
"title": "$:/core/modules/filters/modules.js",
"text": "/*\\\ntitle: $:/core/modules/filters/modules.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for returning the titles of the modules of a given type in this wiki\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.modules = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\t$tw.utils.each($tw.modules.types[title],function(moduleInfo,moduleName) {\n\t\t\tresults.push(moduleName);\n\t\t});\n\t});\n\tresults.sort();\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/moduletypes.js": {
"title": "$:/core/modules/filters/moduletypes.js",
"text": "/*\\\ntitle: $:/core/modules/filters/moduletypes.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for returning the names of the module types in this wiki\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.moduletypes = function(source,operator,options) {\n\tvar results = [];\n\t$tw.utils.each($tw.modules.types,function(moduleInfo,type) {\n\t\tresults.push(type);\n\t});\n\tresults.sort();\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/next.js": {
"title": "$:/core/modules/filters/next.js",
"text": "/*\\\ntitle: $:/core/modules/filters/next.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator returning the tiddler whose title occurs next in the list supplied in the operand tiddler\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.next = function(source,operator,options) {\n\tvar results = [],\n\t\tlist = options.wiki.getTiddlerList(operator.operand);\n\tsource(function(tiddler,title) {\n\t\tvar match = list.indexOf(title);\n\t\t// increment match and then test if result is in range\n\t\tmatch++;\n\t\tif(match > 0 && match < list.length) {\n\t\t\tresults.push(list[match]);\n\t\t}\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/plugintiddlers.js": {
"title": "$:/core/modules/filters/plugintiddlers.js",
"text": "/*\\\ntitle: $:/core/modules/filters/plugintiddlers.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for returning the titles of the shadow tiddlers within a plugin\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.plugintiddlers = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tvar pluginInfo = options.wiki.getPluginInfo(title) || options.wiki.getTiddlerDataCached(title,{tiddlers:[]});\n\t\tif(pluginInfo && pluginInfo.tiddlers) {\n\t\t\t$tw.utils.each(pluginInfo.tiddlers,function(fields,title) {\n\t\t\t\tresults.push(title);\n\t\t\t});\n\t\t}\n\t});\n\tresults.sort();\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/prefix.js": {
"title": "$:/core/modules/filters/prefix.js",
"text": "/*\\\ntitle: $:/core/modules/filters/prefix.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for checking if a title starts with a prefix\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.prefix = function(source,operator,options) {\n\tvar results = [];\n\tif(operator.prefix === \"!\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(title.substr(0,operator.operand.length) !== operator.operand) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(title.substr(0,operator.operand.length) === operator.operand) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/previous.js": {
"title": "$:/core/modules/filters/previous.js",
"text": "/*\\\ntitle: $:/core/modules/filters/previous.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator returning the tiddler whose title occurs immediately prior in the list supplied in the operand tiddler\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.previous = function(source,operator,options) {\n\tvar results = [],\n\t\tlist = options.wiki.getTiddlerList(operator.operand);\n\tsource(function(tiddler,title) {\n\t\tvar match = list.indexOf(title);\n\t\t// increment match and then test if result is in range\n\t\tmatch--;\n\t\tif(match >= 0) {\n\t\t\tresults.push(list[match]);\n\t\t}\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/range.js": {
"title": "$:/core/modules/filters/range.js",
"text": "/*\\\ntitle: $:/core/modules/filters/range.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for generating a numeric range.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.range = function(source,operator,options) {\n\tvar results = [];\n\t// Split the operand into numbers delimited by these symbols\n\tvar parts = operator.operand.split(/[,:;]/g),\n\t\tbeg, end, inc, i, fixed = 0;\n\tfor (i=0; i<parts.length; i++) {\n\t\t// Validate real number\n\t\tif(!/^\\s*[+-]?((\\d+(\\.\\d*)?)|(\\.\\d+))\\s*$/.test(parts[i])) {\n\t\t\treturn [\"range: bad number \\\"\" + parts[i] + \"\\\"\"];\n\t\t}\n\t\t// Count digits; the most precise number determines decimal places in output.\n\t\tvar frac = /\\.\\d+/.exec(parts[i]);\n\t\tif(frac) {\n\t\t\tfixed = Math.max(fixed,frac[0].length-1);\n\t\t}\n\t\tparts[i] = parseFloat(parts[i]);\n\t}\n\tswitch(parts.length) {\n\t\tcase 1:\n\t\t\tend = parts[0];\n\t\t\tif (end >= 1) {\n\t\t\t\tbeg = 1;\n\t\t\t}\n\t\t\telse if (end <= -1) {\n\t\t\t\tbeg = -1;\n\t\t\t}\n\t\t\telse {\n\t\t\t\treturn [];\n\t\t\t}\n\t\t\tinc = 1;\n\t\t\tbreak;\n\t\tcase 2:\n\t\t\tbeg = parts[0];\n\t\t\tend = parts[1];\n\t\t\tinc = 1;\n\t\t\tbreak;\n\t\tcase 3:\n\t\t\tbeg = parts[0];\n\t\t\tend = parts[1];\n\t\t\tinc = Math.abs(parts[2]);\n\t\t\tbreak;\n\t}\n\tif(inc === 0) {\n\t\treturn [\"range: increment 0 causes infinite loop\"];\n\t}\n\t// May need to count backwards\n\tvar direction = ((end < beg) ? -1 : 1);\n\tinc *= direction;\n\t// Estimate number of resulting elements\n\tif((end - beg) / inc > 10000) {\n\t\treturn [\"range: too many steps (over 10K)\"];\n\t}\n\t// Avoid rounding error on last step\n\tend += direction * 0.5 * Math.pow(0.1,fixed);\n\tvar safety = 10010;\n\t// Enumerate the range\n\tif (end<beg) {\n\t\tfor(i=beg; i>end; i+=inc) {\n\t\t\tresults.push(i.toFixed(fixed));\n\t\t\tif(--safety<0) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t} else {\n\t\tfor(i=beg; i<end; i+=inc) {\n\t\t\tresults.push(i.toFixed(fixed));\n\t\t\tif(--safety<0) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\tif(safety<0) {\n\t\treturn [\"range: unexpectedly large output\"];\n\t}\n\t// Reverse?\n\tif(operator.prefix === \"!\") {\n\t\tresults.reverse();\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/regexp.js": {
"title": "$:/core/modules/filters/regexp.js",
"text": "/*\\\ntitle: $:/core/modules/filters/regexp.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for regexp matching\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.regexp = function(source,operator,options) {\n\tvar results = [],\n\t\tfieldname = (operator.suffix || \"title\").toLowerCase(),\n\t\tregexpString, regexp, flags = \"\", match,\n\t\tgetFieldString = function(tiddler,title) {\n\t\t\tif(tiddler) {\n\t\t\t\treturn tiddler.getFieldString(fieldname);\n\t\t\t} else if(fieldname === \"title\") {\n\t\t\t\treturn title;\n\t\t\t} else {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t};\n\t// Process flags and construct regexp\n\tregexpString = operator.operand;\n\tmatch = /^\\(\\?([gim]+)\\)/.exec(regexpString);\n\tif(match) {\n\t\tflags = match[1];\n\t\tregexpString = regexpString.substr(match[0].length);\n\t} else {\n\t\tmatch = /\\(\\?([gim]+)\\)$/.exec(regexpString);\n\t\tif(match) {\n\t\t\tflags = match[1];\n\t\t\tregexpString = regexpString.substr(0,regexpString.length - match[0].length);\n\t\t}\n\t}\n\ttry {\n\t\tregexp = new RegExp(regexpString,flags);\n\t} catch(e) {\n\t\treturn [\"\" + e];\n\t}\n\t// Process the incoming tiddlers\n\tif(operator.prefix === \"!\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tvar text = getFieldString(tiddler,title);\n\t\t\tif(text !== null) {\n\t\t\t\tif(!regexp.exec(text)) {\n\t\t\t\t\tresults.push(title);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\tvar text = getFieldString(tiddler,title);\n\t\t\tif(text !== null) {\n\t\t\t\tif(!!regexp.exec(text)) {\n\t\t\t\t\tresults.push(title);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/removeprefix.js": {
"title": "$:/core/modules/filters/removeprefix.js",
"text": "/*\\\ntitle: $:/core/modules/filters/removeprefix.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for removing a prefix from each title in the list. Titles that do not start with the prefix are removed.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.removeprefix = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tif(title.substr(0,operator.operand.length) === operator.operand) {\n\t\t\tresults.push(title.substr(operator.operand.length));\n\t\t}\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/removesuffix.js": {
"title": "$:/core/modules/filters/removesuffix.js",
"text": "/*\\\ntitle: $:/core/modules/filters/removesuffix.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for removing a suffix from each title in the list. Titles that do not end with the suffix are removed.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.removesuffix = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tif(title.substr(-operator.operand.length) === operator.operand) {\n\t\t\tresults.push(title.substr(0,title.length - operator.operand.length));\n\t\t}\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/sameday.js": {
"title": "$:/core/modules/filters/sameday.js",
"text": "/*\\\ntitle: $:/core/modules/filters/sameday.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator that selects tiddlers with a modified date field on the same day as the provided value.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.sameday = function(source,operator,options) {\n\tvar results = [],\n\t\tfieldName = operator.suffix || \"modified\",\n\t\ttargetDate = (new Date($tw.utils.parseDate(operator.operand))).setHours(0,0,0,0);\n\t// Function to convert a date/time to a date integer\n\tsource(function(tiddler,title) {\n\t\tif(tiddler) {\n\t\t\tif(tiddler.getFieldDay(fieldName) === targetDate) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t}\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/search.js": {
"title": "$:/core/modules/filters/search.js",
"text": "/*\\\ntitle: $:/core/modules/filters/search.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for searching for the text in the operand tiddler\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.search = function(source,operator,options) {\n\tvar invert = operator.prefix === \"!\";\n\tif(operator.suffixes) {\n\t\tvar hasFlag = function(flag) {\n\t\t\t\treturn (operator.suffixes[1] || []).indexOf(flag) !== -1;\n\t\t\t},\n\t\t\texcludeFields = false,\n\t\t\tfieldList = operator.suffixes[0] || [],\n\t\t\tfirstField = fieldList[0] || \"\", \n\t\t\tfirstChar = firstField.charAt(0),\n\t\t\tfields;\n\t\tif(firstChar === \"-\") {\n\t\t\tfields = [firstField.slice(1)].concat(fieldList.slice(1));\n\t\t\texcludeFields = true;\n\t\t} else if(fieldList[0] === \"*\"){\n\t\t\tfields = [];\n\t\t\texcludeFields = true;\n\t\t} else {\n\t\t\tfields = fieldList.slice(0);\n\t\t}\n\t\treturn options.wiki.search(operator.operand,{\n\t\t\tsource: source,\n\t\t\tinvert: invert,\n\t\t\tfield: fields,\n\t\t\texcludeField: excludeFields,\n\t\t\tcaseSensitive: hasFlag(\"casesensitive\"),\n\t\t\tliteral: hasFlag(\"literal\"),\n\t\t\twhitespace: hasFlag(\"whitespace\"),\n\t\t\tregexp: hasFlag(\"regexp\"),\n\t\t\twords: hasFlag(\"words\")\n\t\t});\n\t} else {\n\t\treturn options.wiki.search(operator.operand,{\n\t\t\tsource: source,\n\t\t\tinvert: invert\n\t\t});\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/shadowsource.js": {
"title": "$:/core/modules/filters/shadowsource.js",
"text": "/*\\\ntitle: $:/core/modules/filters/shadowsource.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for returning the source plugins for shadow tiddlers\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.shadowsource = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tvar source = options.wiki.getShadowSource(title);\n\t\tif(source) {\n\t\t\t$tw.utils.pushTop(results,source);\n\t\t}\n\t});\n\tresults.sort();\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/sort.js": {
"title": "$:/core/modules/filters/sort.js",
"text": "/*\\\ntitle: $:/core/modules/filters/sort.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for sorting\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.sort = function(source,operator,options) {\n\tvar results = prepare_results(source);\n\toptions.wiki.sortTiddlers(results,operator.operand || \"title\",operator.prefix === \"!\",false,false);\n\treturn results;\n};\n\nexports.nsort = function(source,operator,options) {\n\tvar results = prepare_results(source);\n\toptions.wiki.sortTiddlers(results,operator.operand || \"title\",operator.prefix === \"!\",false,true);\n\treturn results;\n};\n\nexports.sortan = function(source, operator, options) {\n\tvar results = prepare_results(source);\n\toptions.wiki.sortTiddlers(results, operator.operand || \"title\", operator.prefix === \"!\",false,false,true);\n\treturn results;\n};\n\nexports.sortcs = function(source,operator,options) {\n\tvar results = prepare_results(source);\n\toptions.wiki.sortTiddlers(results,operator.operand || \"title\",operator.prefix === \"!\",true,false);\n\treturn results;\n};\n\nexports.nsortcs = function(source,operator,options) {\n\tvar results = prepare_results(source);\n\toptions.wiki.sortTiddlers(results,operator.operand || \"title\",operator.prefix === \"!\",true,true);\n\treturn results;\n};\n\nvar prepare_results = function (source) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tresults.push(title);\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/splitbefore.js": {
"title": "$:/core/modules/filters/splitbefore.js",
"text": "/*\\\ntitle: $:/core/modules/filters/splitbefore.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator that splits each result on the first occurance of the specified separator and returns the unique values.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.splitbefore = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tvar parts = title.split(operator.operand);\n\t\tif(parts.length === 1) {\n\t\t\t$tw.utils.pushTop(results,parts[0]);\n\t\t} else {\n\t\t\t$tw.utils.pushTop(results,parts[0] + operator.operand);\n\t\t}\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/storyviews.js": {
"title": "$:/core/modules/filters/storyviews.js",
"text": "/*\\\ntitle: $:/core/modules/filters/storyviews.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for returning the names of the story views in this wiki\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.storyviews = function(source,operator,options) {\n\tvar results = [],\n\t\tstoryviews = {};\n\t$tw.modules.applyMethods(\"storyview\",storyviews);\n\t$tw.utils.each(storyviews,function(info,name) {\n\t\tresults.push(name);\n\t});\n\tresults.sort();\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/subfilter.js": {
"title": "$:/core/modules/filters/subfilter.js",
"text": "/*\\\ntitle: $:/core/modules/filters/subfilter.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator returning its operand evaluated as a filter\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.subfilter = function(source,operator,options) {\n\tvar list = options.wiki.filterTiddlers(operator.operand,options.widget,source);\n\tif(operator.prefix === \"!\") {\n\t\tvar results = [];\n\t\tsource(function(tiddler,title) {\n\t\t\tif(list.indexOf(title) === -1) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t\treturn results;\n\t} else {\n\t\treturn list;\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/subtiddlerfields.js": {
"title": "$:/core/modules/filters/subtiddlerfields.js",
"text": "/*\\\ntitle: $:/core/modules/filters/subtiddlerfields.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for returning the names of the fields on the selected subtiddlers of the plugin named in the operand\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.subtiddlerfields = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\tvar subtiddler = options.wiki.getSubTiddler(operator.operand,title);\n\t\tif(subtiddler) {\n\t\t\tfor(var fieldName in subtiddler.fields) {\n\t\t\t\t$tw.utils.pushTop(results,fieldName);\n\t\t\t}\n\t\t}\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/suffix.js": {
"title": "$:/core/modules/filters/suffix.js",
"text": "/*\\\ntitle: $:/core/modules/filters/suffix.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for checking if a title ends with a suffix\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.suffix = function(source,operator,options) {\n\tvar results = [];\n\tif(operator.prefix === \"!\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(title.substr(-operator.operand.length) !== operator.operand) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(title.substr(-operator.operand.length) === operator.operand) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/tag.js": {
"title": "$:/core/modules/filters/tag.js",
"text": "/*\\\ntitle: $:/core/modules/filters/tag.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for checking for the presence of a tag\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.tag = function(source,operator,options) {\n\tvar results = [];\n\tif((operator.suffix || \"\").toLowerCase() === \"strict\" && !operator.operand) {\n\t\t// New semantics:\n\t\t// Always return copy of input if operator.operand is missing\n\t\tsource(function(tiddler,title) {\n\t\t\tresults.push(title);\n\t\t});\n\t} else {\n\t\t// Old semantics:\n\t\tvar tiddlers = options.wiki.getTiddlersWithTag(operator.operand);\n\t\tif(operator.prefix === \"!\") {\n\t\t\t// Returns a copy of the input if operator.operand is missing\n\t\t\tsource(function(tiddler,title) {\n\t\t\t\tif(tiddlers.indexOf(title) === -1) {\n\t\t\t\t\tresults.push(title);\n\t\t\t\t}\n\t\t\t});\n\t\t} else {\n\t\t\t// Returns empty results if operator.operand is missing\n\t\t\tsource(function(tiddler,title) {\n\t\t\t\tif(tiddlers.indexOf(title) !== -1) {\n\t\t\t\t\tresults.push(title);\n\t\t\t\t}\n\t\t\t});\n\t\t\tresults = options.wiki.sortByList(results,operator.operand);\n\t\t}\t\t\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/tagging.js": {
"title": "$:/core/modules/filters/tagging.js",
"text": "/*\\\ntitle: $:/core/modules/filters/tagging.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator returning all tiddlers that are tagged with the selected tiddlers\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.tagging = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\t$tw.utils.pushTop(results,options.wiki.getTiddlersWithTag(title));\n\t});\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/tags.js": {
"title": "$:/core/modules/filters/tags.js",
"text": "/*\\\ntitle: $:/core/modules/filters/tags.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator returning all the tags of the selected tiddlers\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.tags = function(source,operator,options) {\n\tvar tags = {};\n\tsource(function(tiddler,title) {\n\t\tvar t, length;\n\t\tif(tiddler && tiddler.fields.tags) {\n\t\t\tfor(t=0, length=tiddler.fields.tags.length; t<length; t++) {\n\t\t\t\ttags[tiddler.fields.tags[t]] = true;\n\t\t\t}\n\t\t}\n\t});\n\treturn Object.keys(tags);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/title.js": {
"title": "$:/core/modules/filters/title.js",
"text": "/*\\\ntitle: $:/core/modules/filters/title.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for comparing title fields for equality\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.title = function(source,operator,options) {\n\tvar results = [];\n\tif(operator.prefix === \"!\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(tiddler && tiddler.fields.title !== operator.operand) {\n\t\t\t\tresults.push(title);\n\t\t\t}\n\t\t});\n\t} else {\n\t\tresults.push(operator.operand);\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/untagged.js": {
"title": "$:/core/modules/filters/untagged.js",
"text": "/*\\\ntitle: $:/core/modules/filters/untagged.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator returning all the selected tiddlers that are untagged\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.untagged = function(source,operator,options) {\n\tvar results = [];\n\tif(operator.prefix === \"!\") {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(tiddler && $tw.utils.isArray(tiddler.fields.tags) && tiddler.fields.tags.length > 0) {\n\t\t\t\t$tw.utils.pushTop(results,title);\n\t\t\t}\n\t\t});\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\tif(!tiddler || !tiddler.hasField(\"tags\") || ($tw.utils.isArray(tiddler.fields.tags) && tiddler.fields.tags.length === 0)) {\n\t\t\t\t$tw.utils.pushTop(results,title);\n\t\t\t}\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/wikiparserrules.js": {
"title": "$:/core/modules/filters/wikiparserrules.js",
"text": "/*\\\ntitle: $:/core/modules/filters/wikiparserrules.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for returning the names of the wiki parser rules in this wiki\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.wikiparserrules = function(source,operator,options) {\n\tvar results = [],\n\t\toperand = operator.operand;\n\t$tw.utils.each($tw.modules.types.wikirule,function(mod) {\n\t\tvar exp = mod.exports;\n\t\tif(!operand || exp.types[operand]) {\n\t\t\tresults.push(exp.name);\n\t\t}\n\t});\n\tresults.sort();\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters/x-listops.js": {
"title": "$:/core/modules/filters/x-listops.js",
"text": "/*\\\ntitle: $:/core/modules/filters/x-listops.js\ntype: application/javascript\nmodule-type: filteroperator\n\nExtended filter operators to manipulate the current list.\n\n\\*/\n(function () {\n\n /*jslint node: true, browser: true */\n /*global $tw: false */\n \"use strict\";\n\n /*\n Fetch titles from the current list\n */\n var prepare_results = function (source) {\n var results = [];\n source(function (tiddler, title) {\n results.push(title);\n });\n return results;\n };\n\n /*\n Moves a number of items from the tail of the current list before the item named in the operand\n */\n exports.putbefore = function (source, operator) {\n var results = prepare_results(source),\n index = results.indexOf(operator.operand),\n count = $tw.utils.getInt(operator.suffix,1);\n return (index === -1) ?\n results.slice(0, -1) :\n results.slice(0, index).concat(results.slice(-count)).concat(results.slice(index, -count));\n };\n\n /*\n Moves a number of items from the tail of the current list after the item named in the operand\n */\n exports.putafter = function (source, operator) {\n var results = prepare_results(source),\n index = results.indexOf(operator.operand),\n count = $tw.utils.getInt(operator.suffix,1);\n return (index === -1) ?\n results.slice(0, -1) :\n results.slice(0, index + 1).concat(results.slice(-count)).concat(results.slice(index + 1, -count));\n };\n\n /*\n Replaces the item named in the operand with a number of items from the tail of the current list\n */\n exports.replace = function (source, operator) {\n var results = prepare_results(source),\n index = results.indexOf(operator.operand),\n count = $tw.utils.getInt(operator.suffix,1);\n return (index === -1) ?\n results.slice(0, -count) :\n results.slice(0, index).concat(results.slice(-count)).concat(results.slice(index + 1, -count));\n };\n\n /*\n Moves a number of items from the tail of the current list to the head of the list\n */\n exports.putfirst = function (source, operator) {\n var results = prepare_results(source),\n count = $tw.utils.getInt(operator.suffix,1);\n return results.slice(-count).concat(results.slice(0, -count));\n };\n\n /*\n Moves a number of items from the head of the current list to the tail of the list\n */\n exports.putlast = function (source, operator) {\n var results = prepare_results(source),\n count = $tw.utils.getInt(operator.suffix,1);\n return results.slice(count).concat(results.slice(0, count));\n };\n\n /*\n Moves the item named in the operand a number of places forward or backward in the list\n */\n exports.move = function (source, operator) {\n var results = prepare_results(source),\n index = results.indexOf(operator.operand),\n count = $tw.utils.getInt(operator.suffix,1),\n marker = results.splice(index, 1),\n offset = (index + count) > 0 ? index + count : 0;\n return results.slice(0, offset).concat(marker).concat(results.slice(offset));\n };\n\n /*\n Returns the items from the current list that are after the item named in the operand\n */\n exports.allafter = function (source, operator) {\n var results = prepare_results(source),\n index = results.indexOf(operator.operand);\n return (index === -1 || index > (results.length - 2)) ? [] :\n (operator.suffix) ? results.slice(index) :\n results.slice(index + 1);\n };\n\n /*\n Returns the items from the current list that are before the item named in the operand\n */\n exports.allbefore = function (source, operator) {\n var results = prepare_results(source),\n index = results.indexOf(operator.operand);\n return (index < 0) ? [] :\n (operator.suffix) ? results.slice(0, index + 1) :\n results.slice(0, index);\n };\n\n /*\n Appends the items listed in the operand array to the tail of the current list\n */\n exports.append = function (source, operator) {\n var append = $tw.utils.parseStringArray(operator.operand, \"true\"),\n results = prepare_results(source),\n count = parseInt(operator.suffix) || append.length;\n return (append.length === 0) ? results :\n (operator.prefix) ? results.concat(append.slice(-count)) :\n results.concat(append.slice(0, count));\n };\n\n /*\n Prepends the items listed in the operand array to the head of the current list\n */\n exports.prepend = function (source, operator) {\n var prepend = $tw.utils.parseStringArray(operator.operand, \"true\"),\n results = prepare_results(source),\n count = $tw.utils.getInt(operator.suffix,prepend.length);\n return (prepend.length === 0) ? results :\n (operator.prefix) ? prepend.slice(-count).concat(results) :\n prepend.slice(0, count).concat(results);\n };\n\n /*\n Returns all items from the current list except the items listed in the operand array\n */\n exports.remove = function (source, operator) {\n var array = $tw.utils.parseStringArray(operator.operand, \"true\"),\n results = prepare_results(source),\n count = parseInt(operator.suffix) || array.length,\n p,\n len,\n index;\n len = array.length - 1;\n for (p = 0; p < count; ++p) {\n if (operator.prefix) {\n index = results.indexOf(array[len - p]);\n } else {\n index = results.indexOf(array[p]);\n }\n if (index !== -1) {\n results.splice(index, 1);\n }\n }\n return results;\n };\n\n /*\n Returns all items from the current list sorted in the order of the items in the operand array\n */\n exports.sortby = function (source, operator) {\n var results = prepare_results(source);\n if (!results || results.length < 2) {\n return results;\n }\n var lookup = $tw.utils.parseStringArray(operator.operand, \"true\");\n results.sort(function (a, b) {\n return lookup.indexOf(a) - lookup.indexOf(b);\n });\n return results;\n };\n\n /*\n Removes all duplicate items from the current list\n */\n exports.unique = function (source, operator) {\n var results = prepare_results(source);\n var set = results.reduce(function (a, b) {\n if (a.indexOf(b) < 0) {\n a.push(b);\n }\n return a;\n }, []);\n return set;\n };\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/core/modules/filters.js": {
"title": "$:/core/modules/filters.js",
"text": "/*\\\ntitle: $:/core/modules/filters.js\ntype: application/javascript\nmodule-type: wikimethod\n\nAdds tiddler filtering methods to the $tw.Wiki object.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nParses an operation (i.e. a run) within a filter string\n\toperators: Array of array of operator nodes into which results should be inserted\n\tfilterString: filter string\n\tp: start position within the string\nReturns the new start position, after the parsed operation\n*/\nfunction parseFilterOperation(operators,filterString,p) {\n\tvar nextBracketPos, operator;\n\t// Skip the starting square bracket\n\tif(filterString.charAt(p++) !== \"[\") {\n\t\tthrow \"Missing [ in filter expression\";\n\t}\n\t// Process each operator in turn\n\tdo {\n\t\toperator = {};\n\t\t// Check for an operator prefix\n\t\tif(filterString.charAt(p) === \"!\") {\n\t\t\toperator.prefix = filterString.charAt(p++);\n\t\t}\n\t\t// Get the operator name\n\t\tnextBracketPos = filterString.substring(p).search(/[\\[\\{<\\/]/);\n\t\tif(nextBracketPos === -1) {\n\t\t\tthrow \"Missing [ in filter expression\";\n\t\t}\n\t\tnextBracketPos += p;\n\t\tvar bracket = filterString.charAt(nextBracketPos);\n\t\toperator.operator = filterString.substring(p,nextBracketPos);\n\t\t// Any suffix?\n\t\tvar colon = operator.operator.indexOf(':');\n\t\tif(colon > -1) {\n\t\t\t// The raw suffix for older filters\n\t\t\toperator.suffix = operator.operator.substring(colon + 1);\n\t\t\toperator.operator = operator.operator.substring(0,colon) || \"field\";\n\t\t\t// The processed suffix for newer filters\n\t\t\toperator.suffixes = [];\n\t\t\t$tw.utils.each(operator.suffix.split(\":\"),function(subsuffix) {\n\t\t\t\toperator.suffixes.push([]);\n\t\t\t\t$tw.utils.each(subsuffix.split(\",\"),function(entry) {\n\t\t\t\t\tentry = $tw.utils.trim(entry);\n\t\t\t\t\tif(entry) {\n\t\t\t\t\t\toperator.suffixes[operator.suffixes.length - 1].push(entry); \n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t});\n\t\t}\n\t\t// Empty operator means: title\n\t\telse if(operator.operator === \"\") {\n\t\t\toperator.operator = \"title\";\n\t\t}\n\n\t\tp = nextBracketPos + 1;\n\t\tswitch (bracket) {\n\t\t\tcase \"{\": // Curly brackets\n\t\t\t\toperator.indirect = true;\n\t\t\t\tnextBracketPos = filterString.indexOf(\"}\",p);\n\t\t\t\tbreak;\n\t\t\tcase \"[\": // Square brackets\n\t\t\t\tnextBracketPos = filterString.indexOf(\"]\",p);\n\t\t\t\tbreak;\n\t\t\tcase \"<\": // Angle brackets\n\t\t\t\toperator.variable = true;\n\t\t\t\tnextBracketPos = filterString.indexOf(\">\",p);\n\t\t\t\tbreak;\n\t\t\tcase \"/\": // regexp brackets\n\t\t\t\tvar rex = /^((?:[^\\\\\\/]*|\\\\.)*)\\/(?:\\(([mygi]+)\\))?/g,\n\t\t\t\t\trexMatch = rex.exec(filterString.substring(p));\n\t\t\t\tif(rexMatch) {\n\t\t\t\t\toperator.regexp = new RegExp(rexMatch[1], rexMatch[2]);\n// DEPRECATION WARNING\nconsole.log(\"WARNING: Filter\",operator.operator,\"has a deprecated regexp operand\",operator.regexp);\n\t\t\t\t\tnextBracketPos = p + rex.lastIndex - 1;\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tthrow \"Unterminated regular expression in filter expression\";\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t}\n\n\t\tif(nextBracketPos === -1) {\n\t\t\tthrow \"Missing closing bracket in filter expression\";\n\t\t}\n\t\tif(!operator.regexp) {\n\t\t\toperator.operand = filterString.substring(p,nextBracketPos);\n\t\t}\n\t\tp = nextBracketPos + 1;\n\n\t\t// Push this operator\n\t\toperators.push(operator);\n\t} while(filterString.charAt(p) !== \"]\");\n\t// Skip the ending square bracket\n\tif(filterString.charAt(p++) !== \"]\") {\n\t\tthrow \"Missing ] in filter expression\";\n\t}\n\t// Return the parsing position\n\treturn p;\n}\n\n/*\nParse a filter string\n*/\nexports.parseFilter = function(filterString) {\n\tfilterString = filterString || \"\";\n\tvar results = [], // Array of arrays of operator nodes {operator:,operand:}\n\t\tp = 0, // Current position in the filter string\n\t\tmatch;\n\tvar whitespaceRegExp = /(\\s+)/mg,\n\t\toperandRegExp = /((?:\\+|\\-|~)?)(?:(\\[)|(?:\"([^\"]*)\")|(?:'([^']*)')|([^\\s\\[\\]]+))/mg;\n\twhile(p < filterString.length) {\n\t\t// Skip any whitespace\n\t\twhitespaceRegExp.lastIndex = p;\n\t\tmatch = whitespaceRegExp.exec(filterString);\n\t\tif(match && match.index === p) {\n\t\t\tp = p + match[0].length;\n\t\t}\n\t\t// Match the start of the operation\n\t\tif(p < filterString.length) {\n\t\t\toperandRegExp.lastIndex = p;\n\t\t\tmatch = operandRegExp.exec(filterString);\n\t\t\tif(!match || match.index !== p) {\n\t\t\t\tthrow $tw.language.getString(\"Error/FilterSyntax\");\n\t\t\t}\n\t\t\tvar operation = {\n\t\t\t\tprefix: \"\",\n\t\t\t\toperators: []\n\t\t\t};\n\t\t\tif(match[1]) {\n\t\t\t\toperation.prefix = match[1];\n\t\t\t\tp++;\n\t\t\t}\n\t\t\tif(match[2]) { // Opening square bracket\n\t\t\t\tp = parseFilterOperation(operation.operators,filterString,p);\n\t\t\t} else {\n\t\t\t\tp = match.index + match[0].length;\n\t\t\t}\n\t\t\tif(match[3] || match[4] || match[5]) { // Double quoted string, single quoted string or unquoted title\n\t\t\t\toperation.operators.push(\n\t\t\t\t\t{operator: \"title\", operand: match[3] || match[4] || match[5]}\n\t\t\t\t);\n\t\t\t}\n\t\t\tresults.push(operation);\n\t\t}\n\t}\n\treturn results;\n};\n\nexports.getFilterOperators = function() {\n\tif(!this.filterOperators) {\n\t\t$tw.Wiki.prototype.filterOperators = {};\n\t\t$tw.modules.applyMethods(\"filteroperator\",this.filterOperators);\n\t}\n\treturn this.filterOperators;\n};\n\nexports.filterTiddlers = function(filterString,widget,source) {\n\tvar fn = this.compileFilter(filterString);\n\treturn fn.call(this,source,widget);\n};\n\n/*\nCompile a filter into a function with the signature fn(source,widget) where:\nsource: an iterator function for the source tiddlers, called source(iterator), where iterator is called as iterator(tiddler,title)\nwidget: an optional widget node for retrieving the current tiddler etc.\n*/\nexports.compileFilter = function(filterString) {\n\tvar filterParseTree;\n\ttry {\n\t\tfilterParseTree = this.parseFilter(filterString);\n\t} catch(e) {\n\t\treturn function(source,widget) {\n\t\t\treturn [$tw.language.getString(\"Error/Filter\") + \": \" + e];\n\t\t};\n\t}\n\t// Get the hashmap of filter operator functions\n\tvar filterOperators = this.getFilterOperators();\n\t// Assemble array of functions, one for each operation\n\tvar operationFunctions = [];\n\t// Step through the operations\n\tvar self = this;\n\t$tw.utils.each(filterParseTree,function(operation) {\n\t\t// Create a function for the chain of operators in the operation\n\t\tvar operationSubFunction = function(source,widget) {\n\t\t\tvar accumulator = source,\n\t\t\t\tresults = [],\n\t\t\t\tcurrTiddlerTitle = widget && widget.getVariable(\"currentTiddler\");\n\t\t\t$tw.utils.each(operation.operators,function(operator) {\n\t\t\t\tvar operand = operator.operand,\n\t\t\t\t\toperatorFunction;\n\t\t\t\tif(!operator.operator) {\n\t\t\t\t\toperatorFunction = filterOperators.title;\n\t\t\t\t} else if(!filterOperators[operator.operator]) {\n\t\t\t\t\toperatorFunction = filterOperators.field;\n\t\t\t\t} else {\n\t\t\t\t\toperatorFunction = filterOperators[operator.operator];\n\t\t\t\t}\n\t\t\t\tif(operator.indirect) {\n\t\t\t\t\toperand = self.getTextReference(operator.operand,\"\",currTiddlerTitle);\n\t\t\t\t}\n\t\t\t\tif(operator.variable) {\n\t\t\t\t\toperand = widget.getVariable(operator.operand,{defaultValue: \"\"});\n\t\t\t\t}\n\t\t\t\t// Invoke the appropriate filteroperator module\n\t\t\t\tresults = operatorFunction(accumulator,{\n\t\t\t\t\t\t\toperator: operator.operator,\n\t\t\t\t\t\t\toperand: operand,\n\t\t\t\t\t\t\tprefix: operator.prefix,\n\t\t\t\t\t\t\tsuffix: operator.suffix,\n\t\t\t\t\t\t\tsuffixes: operator.suffixes,\n\t\t\t\t\t\t\tregexp: operator.regexp\n\t\t\t\t\t\t},{\n\t\t\t\t\t\t\twiki: self,\n\t\t\t\t\t\t\twidget: widget\n\t\t\t\t\t\t});\n\t\t\t\tif($tw.utils.isArray(results)) {\n\t\t\t\t\taccumulator = self.makeTiddlerIterator(results);\n\t\t\t\t} else {\n\t\t\t\t\taccumulator = results;\n\t\t\t\t}\n\t\t\t});\n\t\t\tif($tw.utils.isArray(results)) {\n\t\t\t\treturn results;\n\t\t\t} else {\n\t\t\t\tvar resultArray = [];\n\t\t\t\tresults(function(tiddler,title) {\n\t\t\t\t\tresultArray.push(title);\n\t\t\t\t});\n\t\t\t\treturn resultArray;\n\t\t\t}\n\t\t};\n\t\t// Wrap the operator functions in a wrapper function that depends on the prefix\n\t\toperationFunctions.push((function() {\n\t\t\tswitch(operation.prefix || \"\") {\n\t\t\t\tcase \"\": // No prefix means that the operation is unioned into the result\n\t\t\t\t\treturn function(results,source,widget) {\n\t\t\t\t\t\t$tw.utils.pushTop(results,operationSubFunction(source,widget));\n\t\t\t\t\t};\n\t\t\t\tcase \"-\": // The results of this operation are removed from the main result\n\t\t\t\t\treturn function(results,source,widget) {\n\t\t\t\t\t\t$tw.utils.removeArrayEntries(results,operationSubFunction(source,widget));\n\t\t\t\t\t};\n\t\t\t\tcase \"+\": // This operation is applied to the main results so far\n\t\t\t\t\treturn function(results,source,widget) {\n\t\t\t\t\t\t// This replaces all the elements of the array, but keeps the actual array so that references to it are preserved\n\t\t\t\t\t\tsource = self.makeTiddlerIterator(results);\n\t\t\t\t\t\tresults.splice(0,results.length);\n\t\t\t\t\t\t$tw.utils.pushTop(results,operationSubFunction(source,widget));\n\t\t\t\t\t};\n\t\t\t\tcase \"~\": // This operation is unioned into the result only if the main result so far is empty\n\t\t\t\t\treturn function(results,source,widget) {\n\t\t\t\t\t\tif(results.length === 0) {\n\t\t\t\t\t\t\t// Main result so far is empty\n\t\t\t\t\t\t\t$tw.utils.pushTop(results,operationSubFunction(source,widget));\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t}\n\t\t})());\n\t});\n\t// Return a function that applies the operations to a source iterator of tiddler titles\n\treturn $tw.perf.measure(\"filter\",function filterFunction(source,widget) {\n\t\tif(!source) {\n\t\t\tsource = self.each;\n\t\t} else if(typeof source === \"object\") { // Array or hashmap\n\t\t\tsource = self.makeTiddlerIterator(source);\n\t\t}\n\t\tvar results = [];\n\t\t$tw.utils.each(operationFunctions,function(operationFunction) {\n\t\t\toperationFunction(results,source,widget);\n\t\t});\n\t\treturn results;\n\t});\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikimethod"
},
"$:/core/modules/info/platform.js": {
"title": "$:/core/modules/info/platform.js",
"text": "/*\\\ntitle: $:/core/modules/info/platform.js\ntype: application/javascript\nmodule-type: info\n\nInitialise basic platform $:/info/ tiddlers\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.getInfoTiddlerFields = function() {\n\tvar mapBoolean = function(value) {return value ? \"yes\" : \"no\";},\n\t\tinfoTiddlerFields = [];\n\t// Basics\n\tinfoTiddlerFields.push({title: \"$:/info/browser\", text: mapBoolean(!!$tw.browser)});\n\tinfoTiddlerFields.push({title: \"$:/info/node\", text: mapBoolean(!!$tw.node)});\n\tif($tw.browser) {\n\t\t// Document location\n\t\tvar setLocationProperty = function(name,value) {\n\t\t\t\tinfoTiddlerFields.push({title: \"$:/info/url/\" + name, text: value});\t\t\t\n\t\t\t},\n\t\t\tlocation = document.location;\n\t\tsetLocationProperty(\"full\", (location.toString()).split(\"#\")[0]);\n\t\tsetLocationProperty(\"host\", location.host);\n\t\tsetLocationProperty(\"hostname\", location.hostname);\n\t\tsetLocationProperty(\"protocol\", location.protocol);\n\t\tsetLocationProperty(\"port\", location.port);\n\t\tsetLocationProperty(\"pathname\", location.pathname);\n\t\tsetLocationProperty(\"search\", location.search);\n\t\tsetLocationProperty(\"origin\", location.origin);\n\t\t// Screen size\n\t\tinfoTiddlerFields.push({title: \"$:/info/browser/screen/width\", text: window.screen.width.toString()});\n\t\tinfoTiddlerFields.push({title: \"$:/info/browser/screen/height\", text: window.screen.height.toString()});\n\t}\n\treturn infoTiddlerFields;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "info"
},
"$:/core/modules/keyboard.js": {
"title": "$:/core/modules/keyboard.js",
"text": "/*\\\ntitle: $:/core/modules/keyboard.js\ntype: application/javascript\nmodule-type: global\n\nKeyboard handling utilities\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar namedKeys = {\n\t\"cancel\": 3,\n\t\"help\": 6,\n\t\"backspace\": 8,\n\t\"tab\": 9,\n\t\"clear\": 12,\n\t\"return\": 13,\n\t\"enter\": 13,\n\t\"pause\": 19,\n\t\"escape\": 27,\n\t\"space\": 32,\n\t\"page_up\": 33,\n\t\"page_down\": 34,\n\t\"end\": 35,\n\t\"home\": 36,\n\t\"left\": 37,\n\t\"up\": 38,\n\t\"right\": 39,\n\t\"down\": 40,\n\t\"printscreen\": 44,\n\t\"insert\": 45,\n\t\"delete\": 46,\n\t\"0\": 48,\n\t\"1\": 49,\n\t\"2\": 50,\n\t\"3\": 51,\n\t\"4\": 52,\n\t\"5\": 53,\n\t\"6\": 54,\n\t\"7\": 55,\n\t\"8\": 56,\n\t\"9\": 57,\n\t\"firefoxsemicolon\": 59,\n\t\"firefoxequals\": 61,\n\t\"a\": 65,\n\t\"b\": 66,\n\t\"c\": 67,\n\t\"d\": 68,\n\t\"e\": 69,\n\t\"f\": 70,\n\t\"g\": 71,\n\t\"h\": 72,\n\t\"i\": 73,\n\t\"j\": 74,\n\t\"k\": 75,\n\t\"l\": 76,\n\t\"m\": 77,\n\t\"n\": 78,\n\t\"o\": 79,\n\t\"p\": 80,\n\t\"q\": 81,\n\t\"r\": 82,\n\t\"s\": 83,\n\t\"t\": 84,\n\t\"u\": 85,\n\t\"v\": 86,\n\t\"w\": 87,\n\t\"x\": 88,\n\t\"y\": 89,\n\t\"z\": 90,\n\t\"numpad0\": 96,\n\t\"numpad1\": 97,\n\t\"numpad2\": 98,\n\t\"numpad3\": 99,\n\t\"numpad4\": 100,\n\t\"numpad5\": 101,\n\t\"numpad6\": 102,\n\t\"numpad7\": 103,\n\t\"numpad8\": 104,\n\t\"numpad9\": 105,\n\t\"multiply\": 106,\n\t\"add\": 107,\n\t\"separator\": 108,\n\t\"subtract\": 109,\n\t\"decimal\": 110,\n\t\"divide\": 111,\n\t\"f1\": 112,\n\t\"f2\": 113,\n\t\"f3\": 114,\n\t\"f4\": 115,\n\t\"f5\": 116,\n\t\"f6\": 117,\n\t\"f7\": 118,\n\t\"f8\": 119,\n\t\"f9\": 120,\n\t\"f10\": 121,\n\t\"f11\": 122,\n\t\"f12\": 123,\n\t\"f13\": 124,\n\t\"f14\": 125,\n\t\"f15\": 126,\n\t\"f16\": 127,\n\t\"f17\": 128,\n\t\"f18\": 129,\n\t\"f19\": 130,\n\t\"f20\": 131,\n\t\"f21\": 132,\n\t\"f22\": 133,\n\t\"f23\": 134,\n\t\"f24\": 135,\n\t\"firefoxminus\": 173,\n\t\"semicolon\": 186,\n\t\"equals\": 187,\n\t\"comma\": 188,\n\t\"dash\": 189,\n\t\"period\": 190,\n\t\"slash\": 191,\n\t\"backquote\": 192,\n\t\"openbracket\": 219,\n\t\"backslash\": 220,\n\t\"closebracket\": 221,\n\t\"quote\": 222\n};\n\nfunction KeyboardManager(options) {\n\tvar self = this;\n\toptions = options || \"\";\n\t// Save the named key hashmap\n\tthis.namedKeys = namedKeys;\n\t// Create a reverse mapping of code to keyname\n\tthis.keyNames = [];\n\t$tw.utils.each(namedKeys,function(keyCode,name) {\n\t\tself.keyNames[keyCode] = name.substr(0,1).toUpperCase() + name.substr(1);\n\t});\n\t// Save the platform-specific name of the \"meta\" key\n\tthis.metaKeyName = $tw.platform.isMac ? \"cmd-\" : \"win-\";\n\tthis.shortcutKeysList = [], // Stores the shortcut-key descriptors\n\tthis.shortcutActionList = [], // Stores the corresponding action strings\n\tthis.shortcutParsedList = []; // Stores the parsed key descriptors\n\tthis.lookupNames = [\"shortcuts\"];\n\tthis.lookupNames.push($tw.platform.isMac ? \"shortcuts-mac\" : \"shortcuts-not-mac\")\n\tthis.lookupNames.push($tw.platform.isWindows ? \"shortcuts-windows\" : \"shortcuts-not-windows\");\n\tthis.lookupNames.push($tw.platform.isLinux ? \"shortcuts-linux\" : \"shortcuts-not-linux\");\n\tthis.updateShortcutLists(this.getShortcutTiddlerList());\n\t$tw.wiki.addEventListener(\"change\",function(changes) {\n\t\tself.handleShortcutChanges(changes);\n\t});\n}\n\n/*\nReturn an array of keycodes for the modifier keys ctrl, shift, alt, meta\n*/\nKeyboardManager.prototype.getModifierKeys = function() {\n\treturn [\n\t\t16, // Shift\n\t\t17, // Ctrl\n\t\t18, // Alt\n\t\t20, // CAPS LOCK\n\t\t91, // Meta (left)\n\t\t93, // Meta (right)\n\t\t224 // Meta (Firefox)\n\t]\n};\n\n/*\nParses a key descriptor into the structure:\n{\n\tkeyCode: numeric keycode\n\tshiftKey: boolean\n\taltKey: boolean\n\tctrlKey: boolean\n\tmetaKey: boolean\n}\nKey descriptors have the following format:\n\tctrl+enter\n\tctrl+shift+alt+A\n*/\nKeyboardManager.prototype.parseKeyDescriptor = function(keyDescriptor) {\n\tvar components = keyDescriptor.split(/\\+|\\-/),\n\t\tinfo = {\n\t\t\tkeyCode: 0,\n\t\t\tshiftKey: false,\n\t\t\taltKey: false,\n\t\t\tctrlKey: false,\n\t\t\tmetaKey: false\n\t\t};\n\tfor(var t=0; t<components.length; t++) {\n\t\tvar s = components[t].toLowerCase(),\n\t\t\tc = s.charCodeAt(0);\n\t\t// Look for modifier keys\n\t\tif(s === \"ctrl\") {\n\t\t\tinfo.ctrlKey = true;\n\t\t} else if(s === \"shift\") {\n\t\t\tinfo.shiftKey = true;\n\t\t} else if(s === \"alt\") {\n\t\t\tinfo.altKey = true;\n\t\t} else if(s === \"meta\" || s === \"cmd\" || s === \"win\") {\n\t\t\tinfo.metaKey = true;\n\t\t}\n\t\t// Replace named keys with their code\n\t\tif(this.namedKeys[s]) {\n\t\t\tinfo.keyCode = this.namedKeys[s];\n\t\t}\n\t}\n\tif(info.keyCode) {\n\t\treturn info;\n\t} else {\n\t\treturn null;\n\t}\n};\n\n/*\nParse a list of key descriptors into an array of keyInfo objects. The key descriptors can be passed as an array of strings or a space separated string\n*/\nKeyboardManager.prototype.parseKeyDescriptors = function(keyDescriptors,options) {\n\tvar self = this;\n\toptions = options || {};\n\toptions.stack = options.stack || [];\n\tvar wiki = options.wiki || $tw.wiki;\n\tif(typeof keyDescriptors === \"string\" && keyDescriptors === \"\") {\n\t\treturn [];\n\t}\n\tif(!$tw.utils.isArray(keyDescriptors)) {\n\t\tkeyDescriptors = keyDescriptors.split(\" \");\n\t}\n\tvar result = [];\n\t$tw.utils.each(keyDescriptors,function(keyDescriptor) {\n\t\t// Look for a named shortcut\n\t\tif(keyDescriptor.substr(0,2) === \"((\" && keyDescriptor.substr(-2,2) === \"))\") {\n\t\t\tif(options.stack.indexOf(keyDescriptor) === -1) {\n\t\t\t\toptions.stack.push(keyDescriptor);\n\t\t\t\tvar name = keyDescriptor.substring(2,keyDescriptor.length - 2),\n\t\t\t\t\tlookupName = function(configName) {\n\t\t\t\t\t\tvar keyDescriptors = wiki.getTiddlerText(\"$:/config/\" + configName + \"/\" + name);\n\t\t\t\t\t\tif(keyDescriptors) {\n\t\t\t\t\t\t\tresult.push.apply(result,self.parseKeyDescriptors(keyDescriptors,options));\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t$tw.utils.each(self.lookupNames,function(platformDescriptor) {\n\t\t\t\t\tlookupName(platformDescriptor);\n\t\t\t\t});\n\t\t\t}\n\t\t} else {\n\t\t\tresult.push(self.parseKeyDescriptor(keyDescriptor));\n\t\t}\n\t});\n\treturn result;\n};\n\nKeyboardManager.prototype.getPrintableShortcuts = function(keyInfoArray) {\n\tvar self = this,\n\t\tresult = [];\n\t$tw.utils.each(keyInfoArray,function(keyInfo) {\n\t\tif(keyInfo) {\n\t\t\tresult.push((keyInfo.ctrlKey ? \"ctrl-\" : \"\") + \n\t\t\t\t (keyInfo.shiftKey ? \"shift-\" : \"\") + \n\t\t\t\t (keyInfo.altKey ? \"alt-\" : \"\") + \n\t\t\t\t (keyInfo.metaKey ? self.metaKeyName : \"\") + \n\t\t\t\t (self.keyNames[keyInfo.keyCode]));\n\t\t}\n\t});\n\treturn result;\n}\n\nKeyboardManager.prototype.checkKeyDescriptor = function(event,keyInfo) {\n\treturn keyInfo &&\n\t\t\tevent.keyCode === keyInfo.keyCode && \n\t\t\tevent.shiftKey === keyInfo.shiftKey && \n\t\t\tevent.altKey === keyInfo.altKey && \n\t\t\tevent.ctrlKey === keyInfo.ctrlKey && \n\t\t\tevent.metaKey === keyInfo.metaKey;\n};\n\nKeyboardManager.prototype.checkKeyDescriptors = function(event,keyInfoArray) {\n\tfor(var t=0; t<keyInfoArray.length; t++) {\n\t\tif(this.checkKeyDescriptor(event,keyInfoArray[t])) {\n\t\t\treturn true;\n\t\t}\n\t}\n\treturn false;\n};\n\nKeyboardManager.prototype.getShortcutTiddlerList = function() {\n\treturn $tw.wiki.getTiddlersWithTag(\"$:/tags/KeyboardShortcut\");\n};\n\nKeyboardManager.prototype.updateShortcutLists = function(tiddlerList) {\n\tthis.shortcutTiddlers = tiddlerList;\n\tfor(var i=0; i<tiddlerList.length; i++) {\n\t\tvar title = tiddlerList[i],\n\t\t\ttiddlerFields = $tw.wiki.getTiddler(title).fields;\n\t\tthis.shortcutKeysList[i] = tiddlerFields.key !== undefined ? tiddlerFields.key : undefined;\n\t\tthis.shortcutActionList[i] = tiddlerFields.text;\n\t\tthis.shortcutParsedList[i] = this.shortcutKeysList[i] !== undefined ? this.parseKeyDescriptors(this.shortcutKeysList[i]) : undefined;\n\t}\n};\n\nKeyboardManager.prototype.handleKeydownEvent = function(event) {\n\tvar key, action;\n\tfor(var i=0; i<this.shortcutTiddlers.length; i++) {\n\t\tif(this.shortcutParsedList[i] !== undefined && this.checkKeyDescriptors(event,this.shortcutParsedList[i])) {\n\t\t\tkey = this.shortcutParsedList[i];\n\t\t\taction = this.shortcutActionList[i];\n\t\t}\n\t}\n\tif(key !== undefined) {\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t\t$tw.rootWidget.invokeActionString(action,$tw.rootWidget);\n\t\treturn true;\n\t}\n\treturn false;\n};\n\nKeyboardManager.prototype.detectNewShortcuts = function(changedTiddlers) {\n\tvar shortcutConfigTiddlers = [],\n\t\thandled = false;\n\t$tw.utils.each(this.lookupNames,function(platformDescriptor) {\n\t\tvar descriptorString = \"$:/config/\" + platformDescriptor + \"/\";\n\t\tObject.keys(changedTiddlers).forEach(function(configTiddler) {\n\t\t\tvar configString = configTiddler.substr(0, configTiddler.lastIndexOf(\"/\") + 1);\n\t\t\tif(configString === descriptorString) {\n\t\t\t\tshortcutConfigTiddlers.push(configTiddler);\n\t\t\t\thandled = true;\n\t\t\t}\n\t\t});\n\t});\n\tif(handled) {\n\t\treturn $tw.utils.hopArray(changedTiddlers,shortcutConfigTiddlers);\n\t} else {\n\t\treturn false;\n\t}\n};\n\nKeyboardManager.prototype.handleShortcutChanges = function(changedTiddlers) {\n\tvar newList = this.getShortcutTiddlerList();\n\tvar hasChanged = $tw.utils.hopArray(changedTiddlers,this.shortcutTiddlers) ? true :\n\t\t($tw.utils.hopArray(changedTiddlers,newList) ? true :\n\t\t(this.detectNewShortcuts(changedTiddlers))\n\t);\n\t// Re-cache shortcuts if something changed\n\tif(hasChanged) {\n\t\tthis.updateShortcutLists(newList);\n\t}\n};\n\nexports.KeyboardManager = KeyboardManager;\n\n})();\n",
"type": "application/javascript",
"module-type": "global"
},
"$:/core/modules/language.js": {
"title": "$:/core/modules/language.js",
"text": "/*\\\ntitle: $:/core/modules/language.js\ntype: application/javascript\nmodule-type: global\n\nThe $tw.Language() manages translateable strings\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nCreate an instance of the language manager. Options include:\nwiki: wiki from which to retrieve translation tiddlers\n*/\nfunction Language(options) {\n\toptions = options || \"\";\n\tthis.wiki = options.wiki || $tw.wiki;\n}\n\n/*\nReturn a wikified translateable string. The title is automatically prefixed with \"$:/language/\"\nOptions include:\nvariables: optional hashmap of variables to supply to the language wikification\n*/\nLanguage.prototype.getString = function(title,options) {\n\toptions = options || {};\n\ttitle = \"$:/language/\" + title;\n\treturn this.wiki.renderTiddler(\"text/plain\",title,{variables: options.variables});\n};\n\n/*\nReturn a raw, unwikified translateable string. The title is automatically prefixed with \"$:/language/\"\n*/\nLanguage.prototype.getRawString = function(title) {\n\ttitle = \"$:/language/\" + title;\n\treturn this.wiki.getTiddlerText(title);\n};\n\nexports.Language = Language;\n\n})();\n",
"type": "application/javascript",
"module-type": "global"
},
"$:/core/modules/macros/changecount.js": {
"title": "$:/core/modules/macros/changecount.js",
"text": "/*\\\ntitle: $:/core/modules/macros/changecount.js\ntype: application/javascript\nmodule-type: macro\n\nMacro to return the changecount for the current tiddler\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nInformation about this macro\n*/\n\nexports.name = \"changecount\";\n\nexports.params = [];\n\n/*\nRun the macro\n*/\nexports.run = function() {\n\treturn this.wiki.getChangeCount(this.getVariable(\"currentTiddler\")) + \"\";\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "macro"
},
"$:/core/modules/macros/contrastcolour.js": {
"title": "$:/core/modules/macros/contrastcolour.js",
"text": "/*\\\ntitle: $:/core/modules/macros/contrastcolour.js\ntype: application/javascript\nmodule-type: macro\n\nMacro to choose which of two colours has the highest contrast with a base colour\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nInformation about this macro\n*/\n\nexports.name = \"contrastcolour\";\n\nexports.params = [\n\t{name: \"target\"},\n\t{name: \"fallbackTarget\"},\n\t{name: \"colourA\"},\n\t{name: \"colourB\"}\n];\n\n/*\nRun the macro\n*/\nexports.run = function(target,fallbackTarget,colourA,colourB) {\n\tvar rgbTarget = $tw.utils.parseCSSColor(target) || $tw.utils.parseCSSColor(fallbackTarget);\n\tif(!rgbTarget) {\n\t\treturn colourA;\n\t}\n\tvar rgbColourA = $tw.utils.parseCSSColor(colourA),\n\t\trgbColourB = $tw.utils.parseCSSColor(colourB);\n\tif(rgbColourA && !rgbColourB) {\n\t\treturn rgbColourA;\n\t}\n\tif(rgbColourB && !rgbColourA) {\n\t\treturn rgbColourB;\n\t}\n\tif(!rgbColourA && !rgbColourB) {\n\t\t// If neither colour is readable, return a crude inverse of the target\n\t\treturn [255 - rgbTarget[0],255 - rgbTarget[1],255 - rgbTarget[2],rgbTarget[3]];\n\t}\n\t// Colour brightness formula derived from http://www.w3.org/WAI/ER/WD-AERT/#color-contrast\n\tvar brightnessTarget = rgbTarget[0] * 0.299 + rgbTarget[1] * 0.587 + rgbTarget[2] * 0.114,\n\t\tbrightnessA = rgbColourA[0] * 0.299 + rgbColourA[1] * 0.587 + rgbColourA[2] * 0.114,\n\t\tbrightnessB = rgbColourB[0] * 0.299 + rgbColourB[1] * 0.587 + rgbColourB[2] * 0.114;\n\treturn Math.abs(brightnessTarget - brightnessA) > Math.abs(brightnessTarget - brightnessB) ? colourA : colourB;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "macro"
},
"$:/core/modules/macros/csvtiddlers.js": {
"title": "$:/core/modules/macros/csvtiddlers.js",
"text": "/*\\\ntitle: $:/core/modules/macros/csvtiddlers.js\ntype: application/javascript\nmodule-type: macro\n\nMacro to output tiddlers matching a filter to CSV\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nInformation about this macro\n*/\n\nexports.name = \"csvtiddlers\";\n\nexports.params = [\n\t{name: \"filter\"},\n\t{name: \"format\"},\n];\n\n/*\nRun the macro\n*/\nexports.run = function(filter,format) {\n\tvar self = this,\n\t\ttiddlers = this.wiki.filterTiddlers(filter),\n\t\ttiddler,\n\t\tfields = [],\n\t\tt,f;\n\t// Collect all the fields\n\tfor(t=0;t<tiddlers.length; t++) {\n\t\ttiddler = this.wiki.getTiddler(tiddlers[t]);\n\t\tfor(f in tiddler.fields) {\n\t\t\tif(fields.indexOf(f) === -1) {\n\t\t\t\tfields.push(f);\n\t\t\t}\n\t\t}\n\t}\n\t// Sort the fields and bring the standard ones to the front\n\tfields.sort();\n\t\"title text modified modifier created creator\".split(\" \").reverse().forEach(function(value,index) {\n\t\tvar p = fields.indexOf(value);\n\t\tif(p !== -1) {\n\t\t\tfields.splice(p,1);\n\t\t\tfields.unshift(value)\n\t\t}\n\t});\n\t// Output the column headings\n\tvar output = [], row = [];\n\tfields.forEach(function(value) {\n\t\trow.push(quoteAndEscape(value))\n\t});\n\toutput.push(row.join(\",\"));\n\t// Output each tiddler\n\tfor(var t=0;t<tiddlers.length; t++) {\n\t\trow = [];\n\t\ttiddler = this.wiki.getTiddler(tiddlers[t]);\n\t\t\tfor(f=0; f<fields.length; f++) {\n\t\t\t\trow.push(quoteAndEscape(tiddler ? tiddler.getFieldString(fields[f]) || \"\" : \"\"));\n\t\t\t}\n\t\toutput.push(row.join(\",\"));\n\t}\n\treturn output.join(\"\\n\");\n};\n\nfunction quoteAndEscape(value) {\n\treturn \"\\\"\" + value.replace(/\"/mg,\"\\\"\\\"\") + \"\\\"\";\n}\n\n})();\n",
"type": "application/javascript",
"module-type": "macro"
},
"$:/core/modules/macros/displayshortcuts.js": {
"title": "$:/core/modules/macros/displayshortcuts.js",
"text": "/*\\\ntitle: $:/core/modules/macros/displayshortcuts.js\ntype: application/javascript\nmodule-type: macro\n\nMacro to display a list of keyboard shortcuts in human readable form. Notably, it resolves named shortcuts like `((bold))` to the underlying keystrokes.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nInformation about this macro\n*/\n\nexports.name = \"displayshortcuts\";\n\nexports.params = [\n\t{name: \"shortcuts\"},\n\t{name: \"prefix\"},\n\t{name: \"separator\"},\n\t{name: \"suffix\"}\n];\n\n/*\nRun the macro\n*/\nexports.run = function(shortcuts,prefix,separator,suffix) {\n\tvar shortcutArray = $tw.keyboardManager.getPrintableShortcuts($tw.keyboardManager.parseKeyDescriptors(shortcuts,{\n\t\twiki: this.wiki\n\t}));\n\tif(shortcutArray.length > 0) {\n\t\tshortcutArray.sort(function(a,b) {\n\t\t return a.toLowerCase().localeCompare(b.toLowerCase());\n\t\t})\n\t\treturn prefix + shortcutArray.join(separator) + suffix;\n\t} else {\n\t\treturn \"\";\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "macro"
},
"$:/core/modules/macros/dumpvariables.js": {
"title": "$:/core/modules/macros/dumpvariables.js",
"text": "/*\\\ntitle: $:/core/modules/macros/dumpvariables.js\ntype: application/javascript\nmodule-type: macro\n\nMacro to dump all active variable values\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nInformation about this macro\n*/\n\nexports.name = \"dumpvariables\";\n\nexports.params = [\n];\n\n/*\nRun the macro\n*/\nexports.run = function() {\n\tvar output = [\"|!Variable |!Value |\"],\n\t\tvariables = [], variable;\n\tfor(variable in this.variables) {\n\t\tvariables.push(variable);\n\t}\n\tvariables.sort();\n\tfor(var index=0; index<variables.length; index++) {\n\t\tvar variable = variables[index];\n\t\toutput.push(\"|\" + variable + \" |<input size=50 value=<<\" + variable + \">>/> |\")\n\t}\n\treturn output.join(\"\\n\");\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "macro"
},
"$:/core/modules/macros/jsontiddler.js": {
"title": "$:/core/modules/macros/jsontiddler.js",
"text": "/*\\\ntitle: $:/core/modules/macros/jsontiddler.js\ntype: application/javascript\nmodule-type: macro\n\nMacro to output a single tiddler to JSON\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nInformation about this macro\n*/\n\nexports.name = \"jsontiddler\";\n\nexports.params = [\n\t{name: \"title\"}\n];\n\n/*\nRun the macro\n*/\nexports.run = function(title) {\n\ttitle = title || this.getVariable(\"currentTiddler\");\n\tvar tiddler = !!title && this.wiki.getTiddler(title),\n\t\tfields = new Object();\n\tif(tiddler) {\n\t\tfor(var field in tiddler.fields) {\n\t\t\tfields[field] = tiddler.getFieldString(field);\n\t\t}\n\t}\n\treturn JSON.stringify(fields,null,$tw.config.preferences.jsonSpaces);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "macro"
},
"$:/core/modules/macros/jsontiddlers.js": {
"title": "$:/core/modules/macros/jsontiddlers.js",
"text": "/*\\\ntitle: $:/core/modules/macros/jsontiddlers.js\ntype: application/javascript\nmodule-type: macro\n\nMacro to output tiddlers matching a filter to JSON\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nInformation about this macro\n*/\n\nexports.name = \"jsontiddlers\";\n\nexports.params = [\n\t{name: \"filter\"}\n];\n\n/*\nRun the macro\n*/\nexports.run = function(filter) {\n\treturn this.wiki.getTiddlersAsJson(filter);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "macro"
},
"$:/core/modules/macros/makedatauri.js": {
"title": "$:/core/modules/macros/makedatauri.js",
"text": "/*\\\ntitle: $:/core/modules/macros/makedatauri.js\ntype: application/javascript\nmodule-type: macro\n\nMacro to convert a string of text to a data URI\n\n<<makedatauri text:\"Text to be converted\" type:\"text/vnd.tiddlywiki\">>\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nInformation about this macro\n*/\n\nexports.name = \"makedatauri\";\n\nexports.params = [\n\t{name: \"text\"},\n\t{name: \"type\"}\n];\n\n/*\nRun the macro\n*/\nexports.run = function(text,type) {\n\treturn $tw.utils.makeDataUri(text,type);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "macro"
},
"$:/core/modules/macros/now.js": {
"title": "$:/core/modules/macros/now.js",
"text": "/*\\\ntitle: $:/core/modules/macros/now.js\ntype: application/javascript\nmodule-type: macro\n\nMacro to return a formatted version of the current time\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nInformation about this macro\n*/\n\nexports.name = \"now\";\n\nexports.params = [\n\t{name: \"format\"}\n];\n\n/*\nRun the macro\n*/\nexports.run = function(format) {\n\treturn $tw.utils.formatDateString(new Date(),format || \"0hh:0mm, DDth MMM YYYY\");\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "macro"
},
"$:/core/modules/macros/qualify.js": {
"title": "$:/core/modules/macros/qualify.js",
"text": "/*\\\ntitle: $:/core/modules/macros/qualify.js\ntype: application/javascript\nmodule-type: macro\n\nMacro to qualify a state tiddler title according\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nInformation about this macro\n*/\n\nexports.name = \"qualify\";\n\nexports.params = [\n\t{name: \"title\"}\n];\n\n/*\nRun the macro\n*/\nexports.run = function(title) {\n\treturn title + \"-\" + this.getStateQualifier();\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "macro"
},
"$:/core/modules/macros/resolvepath.js": {
"title": "$:/core/modules/macros/resolvepath.js",
"text": "/*\\\ntitle: $:/core/modules/macros/resolvepath.js\ntype: application/javascript\nmodule-type: macro\n\nResolves a relative path for an absolute rootpath.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"resolvepath\";\n\nexports.params = [\n\t{name: \"source\"},\n\t{name: \"root\"}\n];\n\n/*\nRun the macro\n*/\nexports.run = function(source, root) {\n\treturn $tw.utils.resolvePath(source, root);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "macro"
},
"$:/core/modules/macros/version.js": {
"title": "$:/core/modules/macros/version.js",
"text": "/*\\\ntitle: $:/core/modules/macros/version.js\ntype: application/javascript\nmodule-type: macro\n\nMacro to return the TiddlyWiki core version number\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nInformation about this macro\n*/\n\nexports.name = \"version\";\n\nexports.params = [];\n\n/*\nRun the macro\n*/\nexports.run = function() {\n\treturn $tw.version;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "macro"
},
"$:/core/modules/parsers/audioparser.js": {
"title": "$:/core/modules/parsers/audioparser.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/audioparser.js\ntype: application/javascript\nmodule-type: parser\n\nThe audio parser parses an audio tiddler into an embeddable HTML element\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar AudioParser = function(type,text,options) {\n\tvar element = {\n\t\t\ttype: \"element\",\n\t\t\ttag: \"audio\",\n\t\t\tattributes: {\n\t\t\t\tcontrols: {type: \"string\", value: \"controls\"}\n\t\t\t}\n\t\t},\n\t\tsrc;\n\tif(options._canonical_uri) {\n\t\telement.attributes.src = {type: \"string\", value: options._canonical_uri};\n\t} else if(text) {\n\t\telement.attributes.src = {type: \"string\", value: \"data:\" + type + \";base64,\" + text};\n\t}\n\tthis.tree = [element];\n};\n\nexports[\"audio/ogg\"] = AudioParser;\nexports[\"audio/mpeg\"] = AudioParser;\nexports[\"audio/mp3\"] = AudioParser;\nexports[\"audio/mp4\"] = AudioParser;\n\n})();\n\n",
"type": "application/javascript",
"module-type": "parser"
},
"$:/core/modules/parsers/binaryparser.js": {
"title": "$:/core/modules/parsers/binaryparser.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/binaryparser.js\ntype: application/javascript\nmodule-type: parser\n\nThe video parser parses a video tiddler into an embeddable HTML element\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar BINARY_WARNING_MESSAGE = \"$:/core/ui/BinaryWarning\";\n\nvar BinaryParser = function(type,text,options) {\n\tthis.tree = [{\n\t\ttype: \"transclude\",\n\t\tattributes: {\n\t\t\ttiddler: {type: \"string\", value: BINARY_WARNING_MESSAGE}\n\t\t}\n\t}];\n};\n\nexports[\"application/octet-stream\"] = BinaryParser;\n\n})();\n\n",
"type": "application/javascript",
"module-type": "parser"
},
"$:/core/modules/parsers/csvparser.js": {
"title": "$:/core/modules/parsers/csvparser.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/csvparser.js\ntype: application/javascript\nmodule-type: parser\n\nThe CSV text parser processes CSV files into a table wrapped in a scrollable widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar CsvParser = function(type,text,options) {\n\t// Table framework\n\tthis.tree = [{\n\t\t\"type\": \"scrollable\", \"children\": [{\n\t\t\t\"type\": \"element\", \"tag\": \"table\", \"children\": [{\n\t\t\t\t\"type\": \"element\", \"tag\": \"tbody\", \"children\": []\n\t\t\t}], \"attributes\": {\n\t\t\t\t\"class\": {\"type\": \"string\", \"value\": \"tc-csv-table\"}\n\t\t\t}\n\t\t}]\n\t}];\n\t// Split the text into lines\n\tvar lines = text.split(/\\r?\\n/mg),\n\t\ttag = \"th\";\n\tfor(var line=0; line<lines.length; line++) {\n\t\tvar lineText = lines[line];\n\t\tif(lineText) {\n\t\t\tvar row = {\n\t\t\t\t\t\"type\": \"element\", \"tag\": \"tr\", \"children\": []\n\t\t\t\t};\n\t\t\tvar columns = lineText.split(\",\");\n\t\t\tfor(var column=0; column<columns.length; column++) {\n\t\t\t\trow.children.push({\n\t\t\t\t\t\t\"type\": \"element\", \"tag\": tag, \"children\": [{\n\t\t\t\t\t\t\t\"type\": \"text\",\n\t\t\t\t\t\t\t\"text\": columns[column]\n\t\t\t\t\t\t}]\n\t\t\t\t\t});\n\t\t\t}\n\t\t\ttag = \"td\";\n\t\t\tthis.tree[0].children[0].children[0].children.push(row);\n\t\t}\n\t}\n};\n\nexports[\"text/csv\"] = CsvParser;\n\n})();\n\n",
"type": "application/javascript",
"module-type": "parser"
},
"$:/core/modules/parsers/htmlparser.js": {
"title": "$:/core/modules/parsers/htmlparser.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/htmlparser.js\ntype: application/javascript\nmodule-type: parser\n\nThe HTML parser displays text as raw HTML\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar HtmlParser = function(type,text,options) {\n\tvar src;\n\tif(options._canonical_uri) {\n\t\tsrc = options._canonical_uri;\n\t} else if(text) {\n\t\tsrc = \"data:text/html;charset=utf-8,\" + encodeURIComponent(text);\n\t}\n\tthis.tree = [{\n\t\ttype: \"element\",\n\t\ttag: \"iframe\",\n\t\tattributes: {\n\t\t\tsrc: {type: \"string\", value: src},\n\t\t\tsandbox: {type: \"string\", value: \"\"}\n\t\t}\n\t}];\n};\n\nexports[\"text/html\"] = HtmlParser;\n\n})();\n\n",
"type": "application/javascript",
"module-type": "parser"
},
"$:/core/modules/parsers/imageparser.js": {
"title": "$:/core/modules/parsers/imageparser.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/imageparser.js\ntype: application/javascript\nmodule-type: parser\n\nThe image parser parses an image into an embeddable HTML element\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar ImageParser = function(type,text,options) {\n\tvar element = {\n\t\t\ttype: \"element\",\n\t\t\ttag: \"img\",\n\t\t\tattributes: {}\n\t\t};\n\tif(options._canonical_uri) {\n\t\telement.attributes.src = {type: \"string\", value: options._canonical_uri};\n\t} else if(text) {\n\t\tif(type === \"image/svg+xml\" || type === \".svg\") {\n\t\t\telement.attributes.src = {type: \"string\", value: \"data:image/svg+xml,\" + encodeURIComponent(text)};\n\t\t} else {\n\t\t\telement.attributes.src = {type: \"string\", value: \"data:\" + type + \";base64,\" + text};\n\t\t}\n\t}\n\tthis.tree = [element];\n};\n\nexports[\"image/svg+xml\"] = ImageParser;\nexports[\"image/jpg\"] = ImageParser;\nexports[\"image/jpeg\"] = ImageParser;\nexports[\"image/png\"] = ImageParser;\nexports[\"image/gif\"] = ImageParser;\nexports[\"image/webp\"] = ImageParser;\nexports[\"image/heic\"] = ImageParser;\nexports[\"image/heif\"] = ImageParser;\nexports[\"image/x-icon\"] = ImageParser;\n\n})();\n\n",
"type": "application/javascript",
"module-type": "parser"
},
"$:/core/modules/utils/parseutils.js": {
"title": "$:/core/modules/utils/parseutils.js",
"text": "/*\\\ntitle: $:/core/modules/utils/parseutils.js\ntype: application/javascript\nmodule-type: utils\n\nUtility functions concerned with parsing text into tokens.\n\nMost functions have the following pattern:\n\n* The parameters are:\n** `source`: the source string being parsed\n** `pos`: the current parse position within the string\n** Any further parameters are used to identify the token that is being parsed\n* The return value is:\n** null if the token was not found at the specified position\n** an object representing the token with the following standard fields:\n*** `type`: string indicating the type of the token\n*** `start`: start position of the token in the source string\n*** `end`: end position of the token in the source string\n*** Any further fields required to describe the token\n\nThe exception is `skipWhiteSpace`, which just returns the position after the whitespace.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nLook for a whitespace token. Returns null if not found, otherwise returns {type: \"whitespace\", start:, end:,}\n*/\nexports.parseWhiteSpace = function(source,pos) {\n\tvar p = pos,c;\n\twhile(true) {\n\t\tc = source.charAt(p);\n\t\tif((c === \" \") || (c === \"\\f\") || (c === \"\\n\") || (c === \"\\r\") || (c === \"\\t\") || (c === \"\\v\") || (c === \"\\u00a0\")) { // Ignores some obscure unicode spaces\n\t\t\tp++;\n\t\t} else {\n\t\t\tbreak;\n\t\t}\n\t}\n\tif(p === pos) {\n\t\treturn null;\n\t} else {\n\t\treturn {\n\t\t\ttype: \"whitespace\",\n\t\t\tstart: pos,\n\t\t\tend: p\n\t\t}\n\t}\n};\n\n/*\nConvenience wrapper for parseWhiteSpace. Returns the position after the whitespace\n*/\nexports.skipWhiteSpace = function(source,pos) {\n\tvar c;\n\twhile(true) {\n\t\tc = source.charAt(pos);\n\t\tif((c === \" \") || (c === \"\\f\") || (c === \"\\n\") || (c === \"\\r\") || (c === \"\\t\") || (c === \"\\v\") || (c === \"\\u00a0\")) { // Ignores some obscure unicode spaces\n\t\t\tpos++;\n\t\t} else {\n\t\t\treturn pos;\n\t\t}\n\t}\n};\n\n/*\nLook for a given string token. Returns null if not found, otherwise returns {type: \"token\", value:, start:, end:,}\n*/\nexports.parseTokenString = function(source,pos,token) {\n\tvar match = source.indexOf(token,pos) === pos;\n\tif(match) {\n\t\treturn {\n\t\t\ttype: \"token\",\n\t\t\tvalue: token,\n\t\t\tstart: pos,\n\t\t\tend: pos + token.length\n\t\t};\n\t}\n\treturn null;\n};\n\n/*\nLook for a token matching a regex. Returns null if not found, otherwise returns {type: \"regexp\", match:, start:, end:,}\n*/\nexports.parseTokenRegExp = function(source,pos,reToken) {\n\tvar node = {\n\t\ttype: \"regexp\",\n\t\tstart: pos\n\t};\n\treToken.lastIndex = pos;\n\tnode.match = reToken.exec(source);\n\tif(node.match && node.match.index === pos) {\n\t\tnode.end = pos + node.match[0].length;\n\t\treturn node;\n\t} else {\n\t\treturn null;\n\t}\n};\n\n/*\nLook for a string literal. Returns null if not found, otherwise returns {type: \"string\", value:, start:, end:,}\n*/\nexports.parseStringLiteral = function(source,pos) {\n\tvar node = {\n\t\ttype: \"string\",\n\t\tstart: pos\n\t};\n\tvar reString = /(?:\"\"\"([\\s\\S]*?)\"\"\"|\"([^\"]*)\")|(?:'([^']*)')/g;\n\treString.lastIndex = pos;\n\tvar match = reString.exec(source);\n\tif(match && match.index === pos) {\n\t\tnode.value = match[1] !== undefined ? match[1] :(\n\t\t\tmatch[2] !== undefined ? match[2] : match[3] \n\t\t\t\t\t);\n\t\tnode.end = pos + match[0].length;\n\t\treturn node;\n\t} else {\n\t\treturn null;\n\t}\n};\n\n/*\nLook for a macro invocation parameter. Returns null if not found, or {type: \"macro-parameter\", name:, value:, start:, end:}\n*/\nexports.parseMacroParameter = function(source,pos) {\n\tvar node = {\n\t\ttype: \"macro-parameter\",\n\t\tstart: pos\n\t};\n\t// Define our regexp\n\tvar reMacroParameter = /(?:([A-Za-z0-9\\-_]+)\\s*:)?(?:\\s*(?:\"\"\"([\\s\\S]*?)\"\"\"|\"([^\"]*)\"|'([^']*)'|\\[\\[([^\\]]*)\\]\\]|([^\\s>\"'=]+)))/g;\n\t// Skip whitespace\n\tpos = $tw.utils.skipWhiteSpace(source,pos);\n\t// Look for the parameter\n\tvar token = $tw.utils.parseTokenRegExp(source,pos,reMacroParameter);\n\tif(!token) {\n\t\treturn null;\n\t}\n\tpos = token.end;\n\t// Get the parameter details\n\tnode.value = token.match[2] !== undefined ? token.match[2] : (\n\t\t\t\t\ttoken.match[3] !== undefined ? token.match[3] : (\n\t\t\t\t\t\ttoken.match[4] !== undefined ? token.match[4] : (\n\t\t\t\t\t\t\ttoken.match[5] !== undefined ? token.match[5] : (\n\t\t\t\t\t\t\t\ttoken.match[6] !== undefined ? token.match[6] : (\n\t\t\t\t\t\t\t\t\t\"\"\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t)\n\t\t\t\t\t)\n\t\t\t\t);\n\tif(token.match[1]) {\n\t\tnode.name = token.match[1];\n\t}\n\t// Update the end position\n\tnode.end = pos;\n\treturn node;\n};\n\n/*\nLook for a macro invocation. Returns null if not found, or {type: \"macrocall\", name:, parameters:, start:, end:}\n*/\nexports.parseMacroInvocation = function(source,pos) {\n\tvar node = {\n\t\ttype: \"macrocall\",\n\t\tstart: pos,\n\t\tparams: []\n\t};\n\t// Define our regexps\n\tvar reMacroName = /([^\\s>\"'=]+)/g;\n\t// Skip whitespace\n\tpos = $tw.utils.skipWhiteSpace(source,pos);\n\t// Look for a double less than sign\n\tvar token = $tw.utils.parseTokenString(source,pos,\"<<\");\n\tif(!token) {\n\t\treturn null;\n\t}\n\tpos = token.end;\n\t// Get the macro name\n\tvar name = $tw.utils.parseTokenRegExp(source,pos,reMacroName);\n\tif(!name) {\n\t\treturn null;\n\t}\n\tnode.name = name.match[1];\n\tpos = name.end;\n\t// Process parameters\n\tvar parameter = $tw.utils.parseMacroParameter(source,pos);\n\twhile(parameter) {\n\t\tnode.params.push(parameter);\n\t\tpos = parameter.end;\n\t\t// Get the next parameter\n\t\tparameter = $tw.utils.parseMacroParameter(source,pos);\n\t}\n\t// Skip whitespace\n\tpos = $tw.utils.skipWhiteSpace(source,pos);\n\t// Look for a double greater than sign\n\ttoken = $tw.utils.parseTokenString(source,pos,\">>\");\n\tif(!token) {\n\t\treturn null;\n\t}\n\tpos = token.end;\n\t// Update the end position\n\tnode.end = pos;\n\treturn node;\n};\n\n/*\nLook for an HTML attribute definition. Returns null if not found, otherwise returns {type: \"attribute\", name:, valueType: \"string|indirect|macro\", value:, start:, end:,}\n*/\nexports.parseAttribute = function(source,pos) {\n\tvar node = {\n\t\tstart: pos\n\t};\n\t// Define our regexps\n\tvar reAttributeName = /([^\\/\\s>\"'=]+)/g,\n\t\treUnquotedAttribute = /([^\\/\\s<>\"'=]+)/g,\n\t\treFilteredValue = /\\{\\{\\{(.+?)\\}\\}\\}/g,\n\t\treIndirectValue = /\\{\\{([^\\}]+)\\}\\}/g;\n\t// Skip whitespace\n\tpos = $tw.utils.skipWhiteSpace(source,pos);\n\t// Get the attribute name\n\tvar name = $tw.utils.parseTokenRegExp(source,pos,reAttributeName);\n\tif(!name) {\n\t\treturn null;\n\t}\n\tnode.name = name.match[1];\n\tpos = name.end;\n\t// Skip whitespace\n\tpos = $tw.utils.skipWhiteSpace(source,pos);\n\t// Look for an equals sign\n\tvar token = $tw.utils.parseTokenString(source,pos,\"=\");\n\tif(token) {\n\t\tpos = token.end;\n\t\t// Skip whitespace\n\t\tpos = $tw.utils.skipWhiteSpace(source,pos);\n\t\t// Look for a string literal\n\t\tvar stringLiteral = $tw.utils.parseStringLiteral(source,pos);\n\t\tif(stringLiteral) {\n\t\t\tpos = stringLiteral.end;\n\t\t\tnode.type = \"string\";\n\t\t\tnode.value = stringLiteral.value;\n\t\t} else {\n\t\t\t// Look for a filtered value\n\t\t\tvar filteredValue = $tw.utils.parseTokenRegExp(source,pos,reFilteredValue);\n\t\t\tif(filteredValue) {\n\t\t\t\tpos = filteredValue.end;\n\t\t\t\tnode.type = \"filtered\";\n\t\t\t\tnode.filter = filteredValue.match[1];\n\t\t\t} else {\n\t\t\t\t// Look for an indirect value\n\t\t\t\tvar indirectValue = $tw.utils.parseTokenRegExp(source,pos,reIndirectValue);\n\t\t\t\tif(indirectValue) {\n\t\t\t\t\tpos = indirectValue.end;\n\t\t\t\t\tnode.type = \"indirect\";\n\t\t\t\t\tnode.textReference = indirectValue.match[1];\n\t\t\t\t} else {\n\t\t\t\t\t// Look for a unquoted value\n\t\t\t\t\tvar unquotedValue = $tw.utils.parseTokenRegExp(source,pos,reUnquotedAttribute);\n\t\t\t\t\tif(unquotedValue) {\n\t\t\t\t\t\tpos = unquotedValue.end;\n\t\t\t\t\t\tnode.type = \"string\";\n\t\t\t\t\t\tnode.value = unquotedValue.match[1];\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// Look for a macro invocation value\n\t\t\t\t\t\tvar macroInvocation = $tw.utils.parseMacroInvocation(source,pos);\n\t\t\t\t\t\tif(macroInvocation) {\n\t\t\t\t\t\t\tpos = macroInvocation.end;\n\t\t\t\t\t\t\tnode.type = \"macro\";\n\t\t\t\t\t\t\tnode.value = macroInvocation;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tnode.type = \"string\";\n\t\t\t\t\t\t\tnode.value = \"true\";\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t} else {\n\t\tnode.type = \"string\";\n\t\tnode.value = \"true\";\n\t}\n\t// Update the end position\n\tnode.end = pos;\n\treturn node;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/parsers/pdfparser.js": {
"title": "$:/core/modules/parsers/pdfparser.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/pdfparser.js\ntype: application/javascript\nmodule-type: parser\n\nThe PDF parser embeds a PDF viewer\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar ImageParser = function(type,text,options) {\n\tvar element = {\n\t\t\ttype: \"element\",\n\t\t\ttag: \"embed\",\n\t\t\tattributes: {}\n\t\t},\n\t\tsrc;\n\tif(options._canonical_uri) {\n\t\telement.attributes.src = {type: \"string\", value: options._canonical_uri};\n\t} else if(text) {\n\t\telement.attributes.src = {type: \"string\", value: \"data:application/pdf;base64,\" + text};\n\t}\n\tthis.tree = [element];\n};\n\nexports[\"application/pdf\"] = ImageParser;\n\n})();\n\n",
"type": "application/javascript",
"module-type": "parser"
},
"$:/core/modules/parsers/textparser.js": {
"title": "$:/core/modules/parsers/textparser.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/textparser.js\ntype: application/javascript\nmodule-type: parser\n\nThe plain text parser processes blocks of source text into a degenerate parse tree consisting of a single text node\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar TextParser = function(type,text,options) {\n\tthis.tree = [{\n\t\ttype: \"codeblock\",\n\t\tattributes: {\n\t\t\tcode: {type: \"string\", value: text},\n\t\t\tlanguage: {type: \"string\", value: type}\n\t\t}\n\t}];\n};\n\nexports[\"text/plain\"] = TextParser;\nexports[\"text/x-tiddlywiki\"] = TextParser;\nexports[\"application/javascript\"] = TextParser;\nexports[\"application/json\"] = TextParser;\nexports[\"text/css\"] = TextParser;\nexports[\"application/x-tiddler-dictionary\"] = TextParser;\n\n})();\n\n",
"type": "application/javascript",
"module-type": "parser"
},
"$:/core/modules/parsers/videoparser.js": {
"title": "$:/core/modules/parsers/videoparser.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/videoparser.js\ntype: application/javascript\nmodule-type: parser\n\nThe video parser parses a video tiddler into an embeddable HTML element\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar VideoParser = function(type,text,options) {\n\tvar element = {\n\t\t\ttype: \"element\",\n\t\t\ttag: \"video\",\n\t\t\tattributes: {\n\t\t\t\tcontrols: {type: \"string\", value: \"controls\"}\n\t\t\t}\n\t\t},\n\t\tsrc;\n\tif(options._canonical_uri) {\n\t\telement.attributes.src = {type: \"string\", value: options._canonical_uri};\n\t} else if(text) {\n\t\telement.attributes.src = {type: \"string\", value: \"data:\" + type + \";base64,\" + text};\n\t}\n\tthis.tree = [element];\n};\n\nexports[\"video/mp4\"] = VideoParser;\nexports[\"video/quicktime\"] = VideoParser;\n\n})();\n\n",
"type": "application/javascript",
"module-type": "parser"
},
"$:/core/modules/parsers/wikiparser/rules/codeblock.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/codeblock.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/codeblock.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text rule for code blocks. For example:\n\n```\n\t```\n\tThis text will not be //wikified//\n\t```\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"codeblock\";\nexports.types = {block: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match and get language if defined\n\tthis.matchRegExp = /```([\\w-]*)\\r?\\n/mg;\n};\n\nexports.parse = function() {\n\tvar reEnd = /(\\r?\\n```$)/mg;\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\n\t// Look for the end of the block\n\treEnd.lastIndex = this.parser.pos;\n\tvar match = reEnd.exec(this.parser.source),\n\t\ttext;\n\t// Process the block\n\tif(match) {\n\t\ttext = this.parser.source.substring(this.parser.pos,match.index);\n\t\tthis.parser.pos = match.index + match[0].length;\n\t} else {\n\t\ttext = this.parser.source.substr(this.parser.pos);\n\t\tthis.parser.pos = this.parser.sourceLength;\n\t}\n\t// Return the $codeblock widget\n\treturn [{\n\t\t\ttype: \"codeblock\",\n\t\t\tattributes: {\n\t\t\t\t\tcode: {type: \"string\", value: text},\n\t\t\t\t\tlanguage: {type: \"string\", value: this.match[1]}\n\t\t\t}\n\t}];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/codeinline.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/codeinline.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/codeinline.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for code runs. For example:\n\n```\n\tThis is a `code run`.\n\tThis is another ``code run``\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"codeinline\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /(``?)/mg;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\tvar reEnd = new RegExp(this.match[1], \"mg\");\n\t// Look for the end marker\n\treEnd.lastIndex = this.parser.pos;\n\tvar match = reEnd.exec(this.parser.source),\n\t\ttext;\n\t// Process the text\n\tif(match) {\n\t\ttext = this.parser.source.substring(this.parser.pos,match.index);\n\t\tthis.parser.pos = match.index + match[0].length;\n\t} else {\n\t\ttext = this.parser.source.substr(this.parser.pos);\n\t\tthis.parser.pos = this.parser.sourceLength;\n\t}\n\treturn [{\n\t\ttype: \"element\",\n\t\ttag: \"code\",\n\t\tchildren: [{\n\t\t\ttype: \"text\",\n\t\t\ttext: text\n\t\t}]\n\t}];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/commentblock.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/commentblock.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/commentblock.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text block rule for HTML comments. For example:\n\n```\n<!-- This is a comment -->\n```\n\nNote that the syntax for comments is simplified to an opening \"<!--\" sequence and a closing \"-->\" sequence -- HTML itself implements a more complex format (see http://ostermiller.org/findhtmlcomment.html)\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"commentblock\";\nexports.types = {block: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\tthis.matchRegExp = /<!--/mg;\n\tthis.endMatchRegExp = /-->/mg;\n};\n\nexports.findNextMatch = function(startPos) {\n\tthis.matchRegExp.lastIndex = startPos;\n\tthis.match = this.matchRegExp.exec(this.parser.source);\n\tif(this.match) {\n\t\tthis.endMatchRegExp.lastIndex = startPos + this.match[0].length;\n\t\tthis.endMatch = this.endMatchRegExp.exec(this.parser.source);\n\t\tif(this.endMatch) {\n\t\t\treturn this.match.index;\n\t\t}\n\t}\n\treturn undefined;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.endMatchRegExp.lastIndex;\n\t// Don't return any elements\n\treturn [];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/commentinline.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/commentinline.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/commentinline.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for HTML comments. For example:\n\n```\n<!-- This is a comment -->\n```\n\nNote that the syntax for comments is simplified to an opening \"<!--\" sequence and a closing \"-->\" sequence -- HTML itself implements a more complex format (see http://ostermiller.org/findhtmlcomment.html)\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"commentinline\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\tthis.matchRegExp = /<!--/mg;\n\tthis.endMatchRegExp = /-->/mg;\n};\n\nexports.findNextMatch = function(startPos) {\n\tthis.matchRegExp.lastIndex = startPos;\n\tthis.match = this.matchRegExp.exec(this.parser.source);\n\tif(this.match) {\n\t\tthis.endMatchRegExp.lastIndex = startPos + this.match[0].length;\n\t\tthis.endMatch = this.endMatchRegExp.exec(this.parser.source);\n\t\tif(this.endMatch) {\n\t\t\treturn this.match.index;\n\t\t}\n\t}\n\treturn undefined;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.endMatchRegExp.lastIndex;\n\t// Don't return any elements\n\treturn [];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/dash.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/dash.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/dash.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for dashes. For example:\n\n```\nThis is an en-dash: --\n\nThis is an em-dash: ---\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"dash\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /-{2,3}(?!-)/mg;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\tvar dash = this.match[0].length === 2 ? \"–\" : \"—\";\n\treturn [{\n\t\ttype: \"entity\",\n\t\tentity: dash\n\t}];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/emphasis/bold.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/emphasis/bold.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/emphasis/bold.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for emphasis - bold. For example:\n\n```\n\tThis is ''bold'' text\n```\n\nThis wikiparser can be modified using the rules eg:\n\n```\n\\rules except bold \n\\rules only bold \n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"bold\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /''/mg;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\n\t// Parse the run including the terminator\n\tvar tree = this.parser.parseInlineRun(/''/mg,{eatTerminator: true});\n\n\t// Return the classed span\n\treturn [{\n\t\ttype: \"element\",\n\t\ttag: \"strong\",\n\t\tchildren: tree\n\t}];\n};\n\n})();",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/emphasis/italic.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/emphasis/italic.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/emphasis/italic.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for emphasis - italic. For example:\n\n```\n\tThis is //italic// text\n```\n\nThis wikiparser can be modified using the rules eg:\n\n```\n\\rules except italic\n\\rules only italic\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"italic\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /\\/\\//mg;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\n\t// Parse the run including the terminator\n\tvar tree = this.parser.parseInlineRun(/\\/\\//mg,{eatTerminator: true});\n\n\t// Return the classed span\n\treturn [{\n\t\ttype: \"element\",\n\t\ttag: \"em\",\n\t\tchildren: tree\n\t}];\n};\n\n})();",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/emphasis/strikethrough.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/emphasis/strikethrough.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/emphasis/strikethrough.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for emphasis - strikethrough. For example:\n\n```\n\tThis is ~~strikethrough~~ text\n```\n\nThis wikiparser can be modified using the rules eg:\n\n```\n\\rules except strikethrough \n\\rules only strikethrough \n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"strikethrough\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /~~/mg;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\n\t// Parse the run including the terminator\n\tvar tree = this.parser.parseInlineRun(/~~/mg,{eatTerminator: true});\n\n\t// Return the classed span\n\treturn [{\n\t\ttype: \"element\",\n\t\ttag: \"strike\",\n\t\tchildren: tree\n\t}];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/emphasis/subscript.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/emphasis/subscript.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/emphasis/subscript.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for emphasis - subscript. For example:\n\n```\n\tThis is ,,subscript,, text\n```\n\nThis wikiparser can be modified using the rules eg:\n\n```\n\\rules except subscript \n\\rules only subscript \n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"subscript\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /,,/mg;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\n\t// Parse the run including the terminator\n\tvar tree = this.parser.parseInlineRun(/,,/mg,{eatTerminator: true});\n\n\t// Return the classed span\n\treturn [{\n\t\ttype: \"element\",\n\t\ttag: \"sub\",\n\t\tchildren: tree\n\t}];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/emphasis/superscript.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/emphasis/superscript.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/emphasis/superscript.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for emphasis - superscript. For example:\n\n```\n\tThis is ^^superscript^^ text\n```\n\nThis wikiparser can be modified using the rules eg:\n\n```\n\\rules except superscript \n\\rules only superscript \n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"superscript\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /\\^\\^/mg;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\n\t// Parse the run including the terminator\n\tvar tree = this.parser.parseInlineRun(/\\^\\^/mg,{eatTerminator: true});\n\n\t// Return the classed span\n\treturn [{\n\t\ttype: \"element\",\n\t\ttag: \"sup\",\n\t\tchildren: tree\n\t}];\n};\n\n})();",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/emphasis/underscore.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/emphasis/underscore.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/emphasis/underscore.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for emphasis - underscore. For example:\n\n```\n\tThis is __underscore__ text\n```\n\nThis wikiparser can be modified using the rules eg:\n\n```\n\\rules except underscore \n\\rules only underscore\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"underscore\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /__/mg;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\n\t// Parse the run including the terminator\n\tvar tree = this.parser.parseInlineRun(/__/mg,{eatTerminator: true});\n\n\t// Return the classed span\n\treturn [{\n\t\ttype: \"element\",\n\t\ttag: \"u\",\n\t\tchildren: tree\n\t}];\n};\n\n})();",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/entity.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/entity.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/entity.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for HTML entities. For example:\n\n```\n\tThis is a copyright symbol: ©\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"entity\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /(&#?[a-zA-Z0-9]{2,8};)/mg;\n};\n\n/*\nParse the most recent match\n*/\nexports.parse = function() {\n\t// Get all the details of the match\n\tvar entityString = this.match[1];\n\t// Move past the macro call\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// Return the entity\n\treturn [{type: \"entity\", entity: this.match[0]}];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/extlink.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/extlink.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/extlink.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for external links. For example:\n\n```\nAn external link: https://www.tiddlywiki.com/\n\nA suppressed external link: ~http://www.tiddlyspace.com/\n```\n\nExternal links can be suppressed by preceding them with `~`.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"extlink\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /~?(?:file|http|https|mailto|ftp|irc|news|data|skype):[^\\s<>{}\\[\\]`|\"\\\\^]+(?:\\/|\\b)/mg;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// Create the link unless it is suppressed\n\tif(this.match[0].substr(0,1) === \"~\") {\n\t\treturn [{type: \"text\", text: this.match[0].substr(1)}];\n\t} else {\n\t\treturn [{\n\t\t\ttype: \"element\",\n\t\t\ttag: \"a\",\n\t\t\tattributes: {\n\t\t\t\thref: {type: \"string\", value: this.match[0]},\n\t\t\t\t\"class\": {type: \"string\", value: \"tc-tiddlylink-external\"},\n\t\t\t\ttarget: {type: \"string\", value: \"_blank\"},\n\t\t\t\trel: {type: \"string\", value: \"noopener noreferrer\"}\n\t\t\t},\n\t\t\tchildren: [{\n\t\t\t\ttype: \"text\", text: this.match[0]\n\t\t\t}]\n\t\t}];\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/filteredtranscludeblock.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/filteredtranscludeblock.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/filteredtranscludeblock.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text rule for block-level filtered transclusion. For example:\n\n```\n{{{ [tag[docs]] }}}\n{{{ [tag[docs]] |tooltip}}}\n{{{ [tag[docs]] ||TemplateTitle}}}\n{{{ [tag[docs]] |tooltip||TemplateTitle}}}\n{{{ [tag[docs]] }}width:40;height:50;}.class.class\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"filteredtranscludeblock\";\nexports.types = {block: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /\\{\\{\\{([^\\|]+?)(?:\\|([^\\|\\{\\}]+))?(?:\\|\\|([^\\|\\{\\}]+))?\\}\\}([^\\}]*)\\}(?:\\.(\\S+))?(?:\\r?\\n|$)/mg;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// Get the match details\n\tvar filter = this.match[1],\n\t\ttooltip = this.match[2],\n\t\ttemplate = $tw.utils.trim(this.match[3]),\n\t\tstyle = this.match[4],\n\t\tclasses = this.match[5];\n\t// Return the list widget\n\tvar node = {\n\t\ttype: \"list\",\n\t\tattributes: {\n\t\t\tfilter: {type: \"string\", value: filter}\n\t\t},\n\t\tisBlock: true\n\t};\n\tif(tooltip) {\n\t\tnode.attributes.tooltip = {type: \"string\", value: tooltip};\n\t}\n\tif(template) {\n\t\tnode.attributes.template = {type: \"string\", value: template};\n\t}\n\tif(style) {\n\t\tnode.attributes.style = {type: \"string\", value: style};\n\t}\n\tif(classes) {\n\t\tnode.attributes.itemClass = {type: \"string\", value: classes.split(\".\").join(\" \")};\n\t}\n\treturn [node];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/filteredtranscludeinline.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/filteredtranscludeinline.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/filteredtranscludeinline.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text rule for inline filtered transclusion. For example:\n\n```\n{{{ [tag[docs]] }}}\n{{{ [tag[docs]] |tooltip}}}\n{{{ [tag[docs]] ||TemplateTitle}}}\n{{{ [tag[docs]] |tooltip||TemplateTitle}}}\n{{{ [tag[docs]] }}width:40;height:50;}.class.class\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"filteredtranscludeinline\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /\\{\\{\\{([^\\|]+?)(?:\\|([^\\|\\{\\}]+))?(?:\\|\\|([^\\|\\{\\}]+))?\\}\\}([^\\}]*)\\}(?:\\.(\\S+))?/mg;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// Get the match details\n\tvar filter = this.match[1],\n\t\ttooltip = this.match[2],\n\t\ttemplate = $tw.utils.trim(this.match[3]),\n\t\tstyle = this.match[4],\n\t\tclasses = this.match[5];\n\t// Return the list widget\n\tvar node = {\n\t\ttype: \"list\",\n\t\tattributes: {\n\t\t\tfilter: {type: \"string\", value: filter}\n\t\t}\n\t};\n\tif(tooltip) {\n\t\tnode.attributes.tooltip = {type: \"string\", value: tooltip};\n\t}\n\tif(template) {\n\t\tnode.attributes.template = {type: \"string\", value: template};\n\t}\n\tif(style) {\n\t\tnode.attributes.style = {type: \"string\", value: style};\n\t}\n\tif(classes) {\n\t\tnode.attributes.itemClass = {type: \"string\", value: classes.split(\".\").join(\" \")};\n\t}\n\treturn [node];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/hardlinebreaks.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/hardlinebreaks.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/hardlinebreaks.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for marking areas with hard line breaks. For example:\n\n```\n\"\"\"\nThis is some text\nThat is set like\nIt is a Poem\nWhen it is\nClearly\nNot\n\"\"\"\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"hardlinebreaks\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /\"\"\"(?:\\r?\\n)?/mg;\n};\n\nexports.parse = function() {\n\tvar reEnd = /(\"\"\")|(\\r?\\n)/mg,\n\t\ttree = [],\n\t\tmatch;\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\tdo {\n\t\t// Parse the run up to the terminator\n\t\ttree.push.apply(tree,this.parser.parseInlineRun(reEnd,{eatTerminator: false}));\n\t\t// Redo the terminator match\n\t\treEnd.lastIndex = this.parser.pos;\n\t\tmatch = reEnd.exec(this.parser.source);\n\t\tif(match) {\n\t\t\tthis.parser.pos = reEnd.lastIndex;\n\t\t\t// Add a line break if the terminator was a line break\n\t\t\tif(match[2]) {\n\t\t\t\ttree.push({type: \"element\", tag: \"br\"});\n\t\t\t}\n\t\t}\n\t} while(match && !match[1]);\n\t// Return the nodes\n\treturn tree;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/heading.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/heading.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/heading.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text block rule for headings\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"heading\";\nexports.types = {block: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /(!{1,6})/mg;\n};\n\n/*\nParse the most recent match\n*/\nexports.parse = function() {\n\t// Get all the details of the match\n\tvar headingLevel = this.match[1].length;\n\t// Move past the !s\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// Parse any classes, whitespace and then the heading itself\n\tvar classes = this.parser.parseClasses();\n\tthis.parser.skipWhitespace({treatNewlinesAsNonWhitespace: true});\n\tvar tree = this.parser.parseInlineRun(/(\\r?\\n)/mg);\n\t// Return the heading\n\treturn [{\n\t\ttype: \"element\",\n\t\ttag: \"h\" + headingLevel, \n\t\tattributes: {\n\t\t\t\"class\": {type: \"string\", value: classes.join(\" \")}\n\t\t},\n\t\tchildren: tree\n\t}];\n};\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/horizrule.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/horizrule.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/horizrule.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text block rule for rules. For example:\n\n```\n---\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"horizrule\";\nexports.types = {block: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /-{3,}\\r?(?:\\n|$)/mg;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\treturn [{type: \"element\", tag: \"hr\"}];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/html.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/html.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/html.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki rule for HTML elements and widgets. For example:\n\n{{{\n<aside>\nThis is an HTML5 aside element\n</aside>\n\n<$slider target=\"MyTiddler\">\nThis is a widget invocation\n</$slider>\n\n}}}\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"html\";\nexports.types = {inline: true, block: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n};\n\nexports.findNextMatch = function(startPos) {\n\t// Find the next tag\n\tthis.nextTag = this.findNextTag(this.parser.source,startPos,{\n\t\trequireLineBreak: this.is.block\n\t});\n\treturn this.nextTag ? this.nextTag.start : undefined;\n};\n\n/*\nParse the most recent match\n*/\nexports.parse = function() {\n\t// Retrieve the most recent match so that recursive calls don't overwrite it\n\tvar tag = this.nextTag;\n\tthis.nextTag = null;\n\t// Advance the parser position to past the tag\n\tthis.parser.pos = tag.end;\n\t// Check for an immediately following double linebreak\n\tvar hasLineBreak = !tag.isSelfClosing && !!$tw.utils.parseTokenRegExp(this.parser.source,this.parser.pos,/([^\\S\\n\\r]*\\r?\\n(?:[^\\S\\n\\r]*\\r?\\n|$))/g);\n\t// Set whether we're in block mode\n\ttag.isBlock = this.is.block || hasLineBreak;\n\t// Parse the body if we need to\n\tif(!tag.isSelfClosing && $tw.config.htmlVoidElements.indexOf(tag.tag) === -1) {\n\t\t\tvar reEndString = \"</\" + $tw.utils.escapeRegExp(tag.tag) + \">\",\n\t\t\t\treEnd = new RegExp(\"(\" + reEndString + \")\",\"mg\");\n\t\tif(hasLineBreak) {\n\t\t\ttag.children = this.parser.parseBlocks(reEndString);\n\t\t} else {\n\t\t\ttag.children = this.parser.parseInlineRun(reEnd);\n\t\t}\n\t\treEnd.lastIndex = this.parser.pos;\n\t\tvar endMatch = reEnd.exec(this.parser.source);\n\t\tif(endMatch && endMatch.index === this.parser.pos) {\n\t\t\tthis.parser.pos = endMatch.index + endMatch[0].length;\n\t\t}\n\t}\n\t// Return the tag\n\treturn [tag];\n};\n\n/*\nLook for an HTML tag. Returns null if not found, otherwise returns {type: \"element\", name:, attributes: [], isSelfClosing:, start:, end:,}\n*/\nexports.parseTag = function(source,pos,options) {\n\toptions = options || {};\n\tvar token,\n\t\tnode = {\n\t\t\ttype: \"element\",\n\t\t\tstart: pos,\n\t\t\tattributes: {}\n\t\t};\n\t// Define our regexps\n\tvar reTagName = /([a-zA-Z0-9\\-\\$]+)/g;\n\t// Skip whitespace\n\tpos = $tw.utils.skipWhiteSpace(source,pos);\n\t// Look for a less than sign\n\ttoken = $tw.utils.parseTokenString(source,pos,\"<\");\n\tif(!token) {\n\t\treturn null;\n\t}\n\tpos = token.end;\n\t// Get the tag name\n\ttoken = $tw.utils.parseTokenRegExp(source,pos,reTagName);\n\tif(!token) {\n\t\treturn null;\n\t}\n\tnode.tag = token.match[1];\n\tif(node.tag.slice(1).indexOf(\"$\") !== -1) {\n\t\treturn null;\n\t}\n\tif(node.tag.charAt(0) === \"$\") {\n\t\tnode.type = node.tag.substr(1);\n\t}\n\tpos = token.end;\n\t// Check that the tag is terminated by a space, / or >\n\tif(!$tw.utils.parseWhiteSpace(source,pos) && !(source.charAt(pos) === \"/\") && !(source.charAt(pos) === \">\") ) {\n\t\treturn null;\n\t}\n\t// Process attributes\n\tvar attribute = $tw.utils.parseAttribute(source,pos);\n\twhile(attribute) {\n\t\tnode.attributes[attribute.name] = attribute;\n\t\tpos = attribute.end;\n\t\t// Get the next attribute\n\t\tattribute = $tw.utils.parseAttribute(source,pos);\n\t}\n\t// Skip whitespace\n\tpos = $tw.utils.skipWhiteSpace(source,pos);\n\t// Look for a closing slash\n\ttoken = $tw.utils.parseTokenString(source,pos,\"/\");\n\tif(token) {\n\t\tpos = token.end;\n\t\tnode.isSelfClosing = true;\n\t}\n\t// Look for a greater than sign\n\ttoken = $tw.utils.parseTokenString(source,pos,\">\");\n\tif(!token) {\n\t\treturn null;\n\t}\n\tpos = token.end;\n\t// Check for a required line break\n\tif(options.requireLineBreak) {\n\t\ttoken = $tw.utils.parseTokenRegExp(source,pos,/([^\\S\\n\\r]*\\r?\\n(?:[^\\S\\n\\r]*\\r?\\n|$))/g);\n\t\tif(!token) {\n\t\t\treturn null;\n\t\t}\n\t}\n\t// Update the end position\n\tnode.end = pos;\n\treturn node;\n};\n\nexports.findNextTag = function(source,pos,options) {\n\t// A regexp for finding candidate HTML tags\n\tvar reLookahead = /<([a-zA-Z\\-\\$]+)/g;\n\t// Find the next candidate\n\treLookahead.lastIndex = pos;\n\tvar match = reLookahead.exec(source);\n\twhile(match) {\n\t\t// Try to parse the candidate as a tag\n\t\tvar tag = this.parseTag(source,match.index,options);\n\t\t// Return success\n\t\tif(tag && this.isLegalTag(tag)) {\n\t\t\treturn tag;\n\t\t}\n\t\t// Look for the next match\n\t\treLookahead.lastIndex = match.index + 1;\n\t\tmatch = reLookahead.exec(source);\n\t}\n\t// Failed\n\treturn null;\n};\n\nexports.isLegalTag = function(tag) {\n\t// Widgets are always OK\n\tif(tag.type !== \"element\") {\n\t\treturn true;\n\t// If it's an HTML tag that starts with a dash then it's not legal\n\t} else if(tag.tag.charAt(0) === \"-\") {\n\t\treturn false;\n\t} else {\n\t\t// Otherwise it's OK\n\t\treturn true;\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/image.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/image.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/image.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for embedding images. For example:\n\n```\n[img[https://tiddlywiki.com/fractalveg.jpg]]\n[img width=23 height=24 [https://tiddlywiki.com/fractalveg.jpg]]\n[img width={{!!width}} height={{!!height}} [https://tiddlywiki.com/fractalveg.jpg]]\n[img[Description of image|https://tiddlywiki.com/fractalveg.jpg]]\n[img[TiddlerTitle]]\n[img[Description of image|TiddlerTitle]]\n```\n\nGenerates the `<$image>` widget.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"image\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n};\n\nexports.findNextMatch = function(startPos) {\n\t// Find the next tag\n\tthis.nextImage = this.findNextImage(this.parser.source,startPos);\n\treturn this.nextImage ? this.nextImage.start : undefined;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.nextImage.end;\n\tvar node = {\n\t\ttype: \"image\",\n\t\tattributes: this.nextImage.attributes\n\t};\n\treturn [node];\n};\n\n/*\nFind the next image from the current position\n*/\nexports.findNextImage = function(source,pos) {\n\t// A regexp for finding candidate HTML tags\n\tvar reLookahead = /(\\[img)/g;\n\t// Find the next candidate\n\treLookahead.lastIndex = pos;\n\tvar match = reLookahead.exec(source);\n\twhile(match) {\n\t\t// Try to parse the candidate as a tag\n\t\tvar tag = this.parseImage(source,match.index);\n\t\t// Return success\n\t\tif(tag) {\n\t\t\treturn tag;\n\t\t}\n\t\t// Look for the next match\n\t\treLookahead.lastIndex = match.index + 1;\n\t\tmatch = reLookahead.exec(source);\n\t}\n\t// Failed\n\treturn null;\n};\n\n/*\nLook for an image at the specified position. Returns null if not found, otherwise returns {type: \"image\", attributes: [], isSelfClosing:, start:, end:,}\n*/\nexports.parseImage = function(source,pos) {\n\tvar token,\n\t\tnode = {\n\t\t\ttype: \"image\",\n\t\t\tstart: pos,\n\t\t\tattributes: {}\n\t\t};\n\t// Skip whitespace\n\tpos = $tw.utils.skipWhiteSpace(source,pos);\n\t// Look for the `[img`\n\ttoken = $tw.utils.parseTokenString(source,pos,\"[img\");\n\tif(!token) {\n\t\treturn null;\n\t}\n\tpos = token.end;\n\t// Skip whitespace\n\tpos = $tw.utils.skipWhiteSpace(source,pos);\n\t// Process attributes\n\tif(source.charAt(pos) !== \"[\") {\n\t\tvar attribute = $tw.utils.parseAttribute(source,pos);\n\t\twhile(attribute) {\n\t\t\tnode.attributes[attribute.name] = attribute;\n\t\t\tpos = attribute.end;\n\t\t\tpos = $tw.utils.skipWhiteSpace(source,pos);\n\t\t\tif(source.charAt(pos) !== \"[\") {\n\t\t\t\t// Get the next attribute\n\t\t\t\tattribute = $tw.utils.parseAttribute(source,pos);\n\t\t\t} else {\n\t\t\t\tattribute = null;\n\t\t\t}\n\t\t}\n\t}\n\t// Skip whitespace\n\tpos = $tw.utils.skipWhiteSpace(source,pos);\n\t// Look for the `[` after the attributes\n\ttoken = $tw.utils.parseTokenString(source,pos,\"[\");\n\tif(!token) {\n\t\treturn null;\n\t}\n\tpos = token.end;\n\t// Skip whitespace\n\tpos = $tw.utils.skipWhiteSpace(source,pos);\n\t// Get the source up to the terminating `]]`\n\ttoken = $tw.utils.parseTokenRegExp(source,pos,/(?:([^|\\]]*?)\\|)?([^\\]]+?)\\]\\]/g);\n\tif(!token) {\n\t\treturn null;\n\t}\n\tpos = token.end;\n\tif(token.match[1]) {\n\t\tnode.attributes.tooltip = {type: \"string\", value: token.match[1].trim()};\n\t}\n\tnode.attributes.source = {type: \"string\", value: (token.match[2] || \"\").trim()};\n\t// Update the end position\n\tnode.end = pos;\n\treturn node;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/import.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/import.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/import.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki pragma rule for importing variable definitions\n\n```\n\\import [[$:/core/ui/PageMacros]] [all[shadows+tiddlers]tag[$:/tags/Macro]!has[draft.of]]\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"import\";\nexports.types = {pragma: true};\n\n/*\nInstantiate parse rule\n*/\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /^\\\\import[^\\S\\n]/mg;\n};\n\n/*\nParse the most recent match\n*/\nexports.parse = function() {\n\tvar self = this;\n\t// Move past the pragma invocation\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// Parse the filter terminated by a line break\n\tvar reMatch = /(.*)(\\r?\\n)|$/mg;\n\treMatch.lastIndex = this.parser.pos;\n\tvar match = reMatch.exec(this.parser.source);\n\tthis.parser.pos = reMatch.lastIndex;\n\t// Parse tree nodes to return\n\treturn [{\n\t\ttype: \"importvariables\",\n\t\tattributes: {\n\t\t\tfilter: {type: \"string\", value: match[1]}\n\t\t},\n\t\tchildren: []\n\t}];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/list.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/list.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/list.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text block rule for lists. For example:\n\n```\n* This is an unordered list\n* It has two items\n\n# This is a numbered list\n## With a subitem\n# And a third item\n\n; This is a term that is being defined\n: This is the definition of that term\n```\n\nNote that lists can be nested arbitrarily:\n\n```\n#** One\n#* Two\n#** Three\n#**** Four\n#**# Five\n#**## Six\n## Seven\n### Eight\n## Nine\n```\n\nA CSS class can be applied to a list item as follows:\n\n```\n* List item one\n*.active List item two has the class `active`\n* List item three\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"list\";\nexports.types = {block: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /([\\*#;:>]+)/mg;\n};\n\nvar listTypes = {\n\t\"*\": {listTag: \"ul\", itemTag: \"li\"},\n\t\"#\": {listTag: \"ol\", itemTag: \"li\"},\n\t\";\": {listTag: \"dl\", itemTag: \"dt\"},\n\t\":\": {listTag: \"dl\", itemTag: \"dd\"},\n\t\">\": {listTag: \"blockquote\", itemTag: \"p\"}\n};\n\n/*\nParse the most recent match\n*/\nexports.parse = function() {\n\t// Array of parse tree nodes for the previous row of the list\n\tvar listStack = [];\n\t// Cycle through the items in the list\n\twhile(true) {\n\t\t// Match the list marker\n\t\tvar reMatch = /([\\*#;:>]+)/mg;\n\t\treMatch.lastIndex = this.parser.pos;\n\t\tvar match = reMatch.exec(this.parser.source);\n\t\tif(!match || match.index !== this.parser.pos) {\n\t\t\tbreak;\n\t\t}\n\t\t// Check whether the list type of the top level matches\n\t\tvar listInfo = listTypes[match[0].charAt(0)];\n\t\tif(listStack.length > 0 && listStack[0].tag !== listInfo.listTag) {\n\t\t\tbreak;\n\t\t}\n\t\t// Move past the list marker\n\t\tthis.parser.pos = match.index + match[0].length;\n\t\t// Walk through the list markers for the current row\n\t\tfor(var t=0; t<match[0].length; t++) {\n\t\t\tlistInfo = listTypes[match[0].charAt(t)];\n\t\t\t// Remove any stacked up element if we can't re-use it because the list type doesn't match\n\t\t\tif(listStack.length > t && listStack[t].tag !== listInfo.listTag) {\n\t\t\t\tlistStack.splice(t,listStack.length - t);\n\t\t\t}\n\t\t\t// Construct the list element or reuse the previous one at this level\n\t\t\tif(listStack.length <= t) {\n\t\t\t\tvar listElement = {type: \"element\", tag: listInfo.listTag, children: [\n\t\t\t\t\t{type: \"element\", tag: listInfo.itemTag, children: []}\n\t\t\t\t]};\n\t\t\t\t// Link this list element into the last child item of the parent list item\n\t\t\t\tif(t) {\n\t\t\t\t\tvar prevListItem = listStack[t-1].children[listStack[t-1].children.length-1];\n\t\t\t\t\tprevListItem.children.push(listElement);\n\t\t\t\t}\n\t\t\t\t// Save this element in the stack\n\t\t\t\tlistStack[t] = listElement;\n\t\t\t} else if(t === (match[0].length - 1)) {\n\t\t\t\tlistStack[t].children.push({type: \"element\", tag: listInfo.itemTag, children: []});\n\t\t\t}\n\t\t}\n\t\tif(listStack.length > match[0].length) {\n\t\t\tlistStack.splice(match[0].length,listStack.length - match[0].length);\n\t\t}\n\t\t// Process the body of the list item into the last list item\n\t\tvar lastListChildren = listStack[listStack.length-1].children,\n\t\t\tlastListItem = lastListChildren[lastListChildren.length-1],\n\t\t\tclasses = this.parser.parseClasses();\n\t\tthis.parser.skipWhitespace({treatNewlinesAsNonWhitespace: true});\n\t\tvar tree = this.parser.parseInlineRun(/(\\r?\\n)/mg);\n\t\tlastListItem.children.push.apply(lastListItem.children,tree);\n\t\tif(classes.length > 0) {\n\t\t\t$tw.utils.addClassToParseTreeNode(lastListItem,classes.join(\" \"));\n\t\t}\n\t\t// Consume any whitespace following the list item\n\t\tthis.parser.skipWhitespace();\n\t}\n\t// Return the root element of the list\n\treturn [listStack[0]];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/macrocallblock.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/macrocallblock.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/macrocallblock.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki rule for block macro calls\n\n```\n<<name value value2>>\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"macrocallblock\";\nexports.types = {block: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /<<([^>\\s]+)(?:\\s*)((?:[^>]|(?:>(?!>)))*?)>>(?:\\r?\\n|$)/mg;\n};\n\n/*\nParse the most recent match\n*/\nexports.parse = function() {\n\t// Get all the details of the match\n\tvar macroName = this.match[1],\n\t\tparamString = this.match[2];\n\t// Move past the macro call\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\tvar params = [],\n\t\treParam = /\\s*(?:([A-Za-z0-9\\-_]+)\\s*:)?(?:\\s*(?:\"\"\"([\\s\\S]*?)\"\"\"|\"([^\"]*)\"|'([^']*)'|\\[\\[([^\\]]*)\\]\\]|([^\"'\\s]+)))/mg,\n\t\tparamMatch = reParam.exec(paramString);\n\twhile(paramMatch) {\n\t\t// Process this parameter\n\t\tvar paramInfo = {\n\t\t\tvalue: paramMatch[2] || paramMatch[3] || paramMatch[4] || paramMatch[5] || paramMatch[6]\n\t\t};\n\t\tif(paramMatch[1]) {\n\t\t\tparamInfo.name = paramMatch[1];\n\t\t}\n\t\tparams.push(paramInfo);\n\t\t// Find the next match\n\t\tparamMatch = reParam.exec(paramString);\n\t}\n\treturn [{\n\t\ttype: \"macrocall\",\n\t\tname: macroName,\n\t\tparams: params,\n\t\tisBlock: true\n\t}];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/macrocallinline.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/macrocallinline.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/macrocallinline.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki rule for macro calls\n\n```\n<<name value value2>>\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"macrocallinline\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /<<([^\\s>]+)\\s*([\\s\\S]*?)>>/mg;\n};\n\n/*\nParse the most recent match\n*/\nexports.parse = function() {\n\t// Get all the details of the match\n\tvar macroName = this.match[1],\n\t\tparamString = this.match[2];\n\t// Move past the macro call\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\tvar params = [],\n\t\treParam = /\\s*(?:([A-Za-z0-9\\-_]+)\\s*:)?(?:\\s*(?:\"\"\"([\\s\\S]*?)\"\"\"|\"([^\"]*)\"|'([^']*)'|\\[\\[([^\\]]*)\\]\\]|([^\"'\\s]+)))/mg,\n\t\tparamMatch = reParam.exec(paramString);\n\twhile(paramMatch) {\n\t\t// Process this parameter\n\t\tvar paramInfo = {\n\t\t\tvalue: paramMatch[2] || paramMatch[3] || paramMatch[4] || paramMatch[5]|| paramMatch[6]\n\t\t};\n\t\tif(paramMatch[1]) {\n\t\t\tparamInfo.name = paramMatch[1];\n\t\t}\n\t\tparams.push(paramInfo);\n\t\t// Find the next match\n\t\tparamMatch = reParam.exec(paramString);\n\t}\n\treturn [{\n\t\ttype: \"macrocall\",\n\t\tname: macroName,\n\t\tparams: params\n\t}];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/macrodef.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/macrodef.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/macrodef.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki pragma rule for macro definitions\n\n```\n\\define name(param:defaultvalue,param2:defaultvalue)\ndefinition text, including $param$ markers\n\\end\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"macrodef\";\nexports.types = {pragma: true};\n\n/*\nInstantiate parse rule\n*/\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /^\\\\define\\s+([^(\\s]+)\\(\\s*([^)]*)\\)(\\s*\\r?\\n)?/mg;\n};\n\n/*\nParse the most recent match\n*/\nexports.parse = function() {\n\t// Move past the macro name and parameters\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// Parse the parameters\n\tvar paramString = this.match[2],\n\t\tparams = [];\n\tif(paramString !== \"\") {\n\t\tvar reParam = /\\s*([A-Za-z0-9\\-_]+)(?:\\s*:\\s*(?:\"\"\"([\\s\\S]*?)\"\"\"|\"([^\"]*)\"|'([^']*)'|\\[\\[([^\\]]*)\\]\\]|([^\"'\\s]+)))?/mg,\n\t\t\tparamMatch = reParam.exec(paramString);\n\t\twhile(paramMatch) {\n\t\t\t// Save the parameter details\n\t\t\tvar paramInfo = {name: paramMatch[1]},\n\t\t\t\tdefaultValue = paramMatch[2] || paramMatch[3] || paramMatch[4] || paramMatch[5] || paramMatch[6];\n\t\t\tif(defaultValue) {\n\t\t\t\tparamInfo[\"default\"] = defaultValue;\n\t\t\t}\n\t\t\tparams.push(paramInfo);\n\t\t\t// Look for the next parameter\n\t\t\tparamMatch = reParam.exec(paramString);\n\t\t}\n\t}\n\t// Is this a multiline definition?\n\tvar reEnd;\n\tif(this.match[3]) {\n\t\t// If so, the end of the body is marked with \\end\n\t\treEnd = /(\\r?\\n\\\\end[^\\S\\n\\r]*(?:$|\\r?\\n))/mg;\n\t} else {\n\t\t// Otherwise, the end of the definition is marked by the end of the line\n\t\treEnd = /($|\\r?\\n)/mg;\n\t\t// Move past any whitespace\n\t\tthis.parser.pos = $tw.utils.skipWhiteSpace(this.parser.source,this.parser.pos);\n\t}\n\t// Find the end of the definition\n\treEnd.lastIndex = this.parser.pos;\n\tvar text,\n\t\tendMatch = reEnd.exec(this.parser.source);\n\tif(endMatch) {\n\t\ttext = this.parser.source.substring(this.parser.pos,endMatch.index);\n\t\tthis.parser.pos = endMatch.index + endMatch[0].length;\n\t} else {\n\t\t// We didn't find the end of the definition, so we'll make it blank\n\t\ttext = \"\";\n\t}\n\t// Save the macro definition\n\treturn [{\n\t\ttype: \"set\",\n\t\tattributes: {\n\t\t\tname: {type: \"string\", value: this.match[1]},\n\t\t\tvalue: {type: \"string\", value: text}\n\t\t},\n\t\tchildren: [],\n\t\tparams: params,\n\t\tisMacroDefinition: true\n\t}];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/prettyextlink.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/prettyextlink.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/prettyextlink.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for external links. For example:\n\n```\n[ext[https://tiddlywiki.com/fractalveg.jpg]]\n[ext[Tooltip|https://tiddlywiki.com/fractalveg.jpg]]\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"prettyextlink\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n};\n\nexports.findNextMatch = function(startPos) {\n\t// Find the next tag\n\tthis.nextLink = this.findNextLink(this.parser.source,startPos);\n\treturn this.nextLink ? this.nextLink.start : undefined;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.nextLink.end;\n\treturn [this.nextLink];\n};\n\n/*\nFind the next link from the current position\n*/\nexports.findNextLink = function(source,pos) {\n\t// A regexp for finding candidate links\n\tvar reLookahead = /(\\[ext\\[)/g;\n\t// Find the next candidate\n\treLookahead.lastIndex = pos;\n\tvar match = reLookahead.exec(source);\n\twhile(match) {\n\t\t// Try to parse the candidate as a link\n\t\tvar link = this.parseLink(source,match.index);\n\t\t// Return success\n\t\tif(link) {\n\t\t\treturn link;\n\t\t}\n\t\t// Look for the next match\n\t\treLookahead.lastIndex = match.index + 1;\n\t\tmatch = reLookahead.exec(source);\n\t}\n\t// Failed\n\treturn null;\n};\n\n/*\nLook for an link at the specified position. Returns null if not found, otherwise returns {type: \"element\", tag: \"a\", attributes: [], isSelfClosing:, start:, end:,}\n*/\nexports.parseLink = function(source,pos) {\n\tvar token,\n\t\ttextNode = {\n\t\t\ttype: \"text\"\n\t\t},\n\t\tnode = {\n\t\t\ttype: \"element\",\n\t\t\ttag: \"a\",\n\t\t\tstart: pos,\n\t\t\tattributes: {\n\t\t\t\t\"class\": {type: \"string\", value: \"tc-tiddlylink-external\"},\n\t\t\t},\n\t\t\tchildren: [textNode]\n\t\t};\n\t// Skip whitespace\n\tpos = $tw.utils.skipWhiteSpace(source,pos);\n\t// Look for the `[ext[`\n\ttoken = $tw.utils.parseTokenString(source,pos,\"[ext[\");\n\tif(!token) {\n\t\treturn null;\n\t}\n\tpos = token.end;\n\t// Look ahead for the terminating `]]`\n\tvar closePos = source.indexOf(\"]]\",pos);\n\tif(closePos === -1) {\n\t\treturn null;\n\t}\n\t// Look for a `|` separating the tooltip\n\tvar splitPos = source.indexOf(\"|\",pos);\n\tif(splitPos === -1 || splitPos > closePos) {\n\t\tsplitPos = null;\n\t}\n\t// Pull out the tooltip and URL\n\tvar tooltip, URL;\n\tif(splitPos) {\n\t\tURL = source.substring(splitPos + 1,closePos).trim();\n\t\ttextNode.text = source.substring(pos,splitPos).trim();\n\t} else {\n\t\tURL = source.substring(pos,closePos).trim();\n\t\ttextNode.text = URL;\n\t}\n\tnode.attributes.href = {type: \"string\", value: URL};\n\tnode.attributes.target = {type: \"string\", value: \"_blank\"};\n\tnode.attributes.rel = {type: \"string\", value: \"noopener noreferrer\"};\n\t// Update the end position\n\tnode.end = closePos + 2;\n\treturn node;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/prettylink.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/prettylink.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/prettylink.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for pretty links. For example:\n\n```\n[[Introduction]]\n\n[[Link description|TiddlerTitle]]\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"prettylink\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /\\[\\[(.*?)(?:\\|(.*?))?\\]\\]/mg;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// Process the link\n\tvar text = this.match[1],\n\t\tlink = this.match[2] || text;\n\tif($tw.utils.isLinkExternal(link)) {\n\t\treturn [{\n\t\t\ttype: \"element\",\n\t\t\ttag: \"a\",\n\t\t\tattributes: {\n\t\t\t\thref: {type: \"string\", value: link},\n\t\t\t\t\"class\": {type: \"string\", value: \"tc-tiddlylink-external\"},\n\t\t\t\ttarget: {type: \"string\", value: \"_blank\"},\n\t\t\t\trel: {type: \"string\", value: \"noopener noreferrer\"}\n\t\t\t},\n\t\t\tchildren: [{\n\t\t\t\ttype: \"text\", text: text\n\t\t\t}]\n\t\t}];\n\t} else {\n\t\treturn [{\n\t\t\ttype: \"link\",\n\t\t\tattributes: {\n\t\t\t\tto: {type: \"string\", value: link}\n\t\t\t},\n\t\t\tchildren: [{\n\t\t\t\ttype: \"text\", text: text\n\t\t\t}]\n\t\t}];\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/quoteblock.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/quoteblock.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/quoteblock.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text rule for quote blocks. For example:\n\n```\n\t<<<.optionalClass(es) optional cited from\n\ta quote\n\t<<<\n\t\n\t<<<.optionalClass(es)\n\ta quote\n\t<<< optional cited from\n```\n\nQuotes can be quoted by putting more <s\n\n```\n\t<<<\n\tQuote Level 1\n\t\n\t<<<<\n\tQuoteLevel 2\n\t<<<<\n\t\n\t<<<\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"quoteblock\";\nexports.types = {block: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /(<<<+)/mg;\n};\n\nexports.parse = function() {\n\tvar classes = [\"tc-quote\"];\n\t// Get all the details of the match\n\tvar reEndString = \"^\" + this.match[1] + \"(?!<)\";\n\t// Move past the <s\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t\n\t// Parse any classes, whitespace and then the optional cite itself\n\tclasses.push.apply(classes, this.parser.parseClasses());\n\tthis.parser.skipWhitespace({treatNewlinesAsNonWhitespace: true});\n\tvar cite = this.parser.parseInlineRun(/(\\r?\\n)/mg);\n\t// before handling the cite, parse the body of the quote\n\tvar tree= this.parser.parseBlocks(reEndString);\n\t// If we got a cite, put it before the text\n\tif(cite.length > 0) {\n\t\ttree.unshift({\n\t\t\ttype: \"element\",\n\t\t\ttag: \"cite\",\n\t\t\tchildren: cite\n\t\t});\n\t}\n\t// Parse any optional cite\n\tthis.parser.skipWhitespace({treatNewlinesAsNonWhitespace: true});\n\tcite = this.parser.parseInlineRun(/(\\r?\\n)/mg);\n\t// If we got a cite, push it\n\tif(cite.length > 0) {\n\t\ttree.push({\n\t\t\ttype: \"element\",\n\t\t\ttag: \"cite\",\n\t\t\tchildren: cite\n\t\t});\n\t}\n\t// Return the blockquote element\n\treturn [{\n\t\ttype: \"element\",\n\t\ttag: \"blockquote\",\n\t\tattributes: {\n\t\t\tclass: { type: \"string\", value: classes.join(\" \") },\n\t\t},\n\t\tchildren: tree\n\t}];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/rules.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/rules.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/rules.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki pragma rule for rules specifications\n\n```\n\\rules except ruleone ruletwo rulethree\n\\rules only ruleone ruletwo rulethree\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"rules\";\nexports.types = {pragma: true};\n\n/*\nInstantiate parse rule\n*/\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /^\\\\rules[^\\S\\n]/mg;\n};\n\n/*\nParse the most recent match\n*/\nexports.parse = function() {\n\t// Move past the pragma invocation\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// Parse whitespace delimited tokens terminated by a line break\n\tvar reMatch = /[^\\S\\n]*(\\S+)|(\\r?\\n)/mg,\n\t\ttokens = [];\n\treMatch.lastIndex = this.parser.pos;\n\tvar match = reMatch.exec(this.parser.source);\n\twhile(match && match.index === this.parser.pos) {\n\t\tthis.parser.pos = reMatch.lastIndex;\n\t\t// Exit if we've got the line break\n\t\tif(match[2]) {\n\t\t\tbreak;\n\t\t}\n\t\t// Process the token\n\t\tif(match[1]) {\n\t\t\ttokens.push(match[1]);\n\t\t}\n\t\t// Match the next token\n\t\tmatch = reMatch.exec(this.parser.source);\n\t}\n\t// Process the tokens\n\tif(tokens.length > 0) {\n\t\tthis.parser.amendRules(tokens[0],tokens.slice(1));\n\t}\n\t// No parse tree nodes to return\n\treturn [];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/styleblock.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/styleblock.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/styleblock.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text block rule for assigning styles and classes to paragraphs and other blocks. For example:\n\n```\n@@.myClass\n@@background-color:red;\nThis paragraph will have the CSS class `myClass`.\n\n* The `<ul>` around this list will also have the class `myClass`\n* List item 2\n\n@@\n```\n\nNote that classes and styles can be mixed subject to the rule that styles must precede classes. For example\n\n```\n@@.myFirstClass.mySecondClass\n@@width:100px;.myThirdClass\nThis is a paragraph\n@@\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"styleblock\";\nexports.types = {block: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /@@((?:[^\\.\\r\\n\\s:]+:[^\\r\\n;]+;)+)?(?:\\.([^\\r\\n\\s]+))?\\r?\\n/mg;\n};\n\nexports.parse = function() {\n\tvar reEndString = \"^@@(?:\\\\r?\\\\n)?\";\n\tvar classes = [], styles = [];\n\tdo {\n\t\t// Get the class and style\n\t\tif(this.match[1]) {\n\t\t\tstyles.push(this.match[1]);\n\t\t}\n\t\tif(this.match[2]) {\n\t\t\tclasses.push(this.match[2].split(\".\").join(\" \"));\n\t\t}\n\t\t// Move past the match\n\t\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t\t// Look for another line of classes and styles\n\t\tthis.match = this.matchRegExp.exec(this.parser.source);\n\t} while(this.match && this.match.index === this.parser.pos);\n\t// Parse the body\n\tvar tree = this.parser.parseBlocks(reEndString);\n\tfor(var t=0; t<tree.length; t++) {\n\t\tif(classes.length > 0) {\n\t\t\t$tw.utils.addClassToParseTreeNode(tree[t],classes.join(\" \"));\n\t\t}\n\t\tif(styles.length > 0) {\n\t\t\t$tw.utils.addAttributeToParseTreeNode(tree[t],\"style\",styles.join(\"\"));\n\t\t}\n\t}\n\treturn tree;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/styleinline.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/styleinline.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/styleinline.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for assigning styles and classes to inline runs. For example:\n\n```\n@@.myClass This is some text with a class@@\n@@background-color:red;This is some text with a background colour@@\n@@width:100px;.myClass This is some text with a class and a width@@\n```\n\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"styleinline\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /@@((?:[^\\.\\r\\n\\s:]+:[^\\r\\n;]+;)+)?(\\.(?:[^\\r\\n\\s]+)\\s+)?/mg;\n};\n\nexports.parse = function() {\n\tvar reEnd = /@@/g;\n\t// Get the styles and class\n\tvar stylesString = this.match[1],\n\t\tclassString = this.match[2] ? this.match[2].split(\".\").join(\" \") : undefined;\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// Parse the run up to the terminator\n\tvar tree = this.parser.parseInlineRun(reEnd,{eatTerminator: true});\n\t// Return the classed span\n\tvar node = {\n\t\ttype: \"element\",\n\t\ttag: \"span\",\n\t\tattributes: {\n\t\t\t\"class\": {type: \"string\", value: \"tc-inline-style\"}\n\t\t},\n\t\tchildren: tree\n\t};\n\tif(classString) {\n\t\t$tw.utils.addClassToParseTreeNode(node,classString);\n\t}\n\tif(stylesString) {\n\t\t$tw.utils.addAttributeToParseTreeNode(node,\"style\",stylesString);\n\t}\n\treturn [node];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/syslink.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/syslink.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/syslink.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for system tiddler links.\nCan be suppressed preceding them with `~`.\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"syslink\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = new RegExp(\n\t\t\"~?\\\\$:\\\\/[\" +\n\t\t$tw.config.textPrimitives.anyLetter.substr(1,$tw.config.textPrimitives.anyLetter.length - 2) +\n\t\t\"\\/._-]+\",\n\t\t\"mg\"\n\t);\n};\n\nexports.parse = function() {\n\tvar match = this.match[0];\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// Create the link unless it is suppressed\n\tif(match.substr(0,1) === \"~\") {\n\t\treturn [{type: \"text\", text: match.substr(1)}];\n\t} else {\n\t\treturn [{\n\t\t\ttype: \"link\",\n\t\t\tattributes: {\n\t\t\t\tto: {type: \"string\", value: match}\n\t\t\t},\n\t\t\tchildren: [{\n\t\t\t\ttype: \"text\",\n\t\t\t\ttext: match\n\t\t\t}]\n\t\t}];\n\t}\n};\n\n})();",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/table.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/table.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/table.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text block rule for tables.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"table\";\nexports.types = {block: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /^\\|(?:[^\\n]*)\\|(?:[fhck]?)\\r?(?:\\n|$)/mg;\n};\n\nvar processRow = function(prevColumns) {\n\tvar cellRegExp = /(?:\\|([^\\n\\|]*)\\|)|(\\|[fhck]?\\r?(?:\\n|$))/mg,\n\t\tcellTermRegExp = /((?:\\x20*)\\|)/mg,\n\t\ttree = [],\n\t\tcol = 0,\n\t\tcolSpanCount = 1,\n\t\tprevCell,\n\t\tvAlign;\n\t// Match a single cell\n\tcellRegExp.lastIndex = this.parser.pos;\n\tvar cellMatch = cellRegExp.exec(this.parser.source);\n\twhile(cellMatch && cellMatch.index === this.parser.pos) {\n\t\tif(cellMatch[1] === \"~\") {\n\t\t\t// Rowspan\n\t\t\tvar last = prevColumns[col];\n\t\t\tif(last) {\n\t\t\t\tlast.rowSpanCount++;\n\t\t\t\t$tw.utils.addAttributeToParseTreeNode(last.element,\"rowspan\",last.rowSpanCount);\n\t\t\t\tvAlign = $tw.utils.getAttributeValueFromParseTreeNode(last.element,\"valign\",\"center\");\n\t\t\t\t$tw.utils.addAttributeToParseTreeNode(last.element,\"valign\",vAlign);\n\t\t\t\tif(colSpanCount > 1) {\n\t\t\t\t\t$tw.utils.addAttributeToParseTreeNode(last.element,\"colspan\",colSpanCount);\n\t\t\t\t\tcolSpanCount = 1;\n\t\t\t\t}\n\t\t\t}\n\t\t\t// Move to just before the `|` terminating the cell\n\t\t\tthis.parser.pos = cellRegExp.lastIndex - 1;\n\t\t} else if(cellMatch[1] === \">\") {\n\t\t\t// Colspan\n\t\t\tcolSpanCount++;\n\t\t\t// Move to just before the `|` terminating the cell\n\t\t\tthis.parser.pos = cellRegExp.lastIndex - 1;\n\t\t} else if(cellMatch[1] === \"<\" && prevCell) {\n\t\t\tcolSpanCount = 1 + $tw.utils.getAttributeValueFromParseTreeNode(prevCell,\"colspan\",1);\n\t\t\t$tw.utils.addAttributeToParseTreeNode(prevCell,\"colspan\",colSpanCount);\n\t\t\tcolSpanCount = 1;\n\t\t\t// Move to just before the `|` terminating the cell\n\t\t\tthis.parser.pos = cellRegExp.lastIndex - 1;\n\t\t} else if(cellMatch[2]) {\n\t\t\t// End of row\n\t\t\tif(prevCell && colSpanCount > 1) {\n\t\t\t\tif(prevCell.attributes && prevCell.attributes && prevCell.attributes.colspan) {\n\t\t\t\t\t\tcolSpanCount += prevCell.attributes.colspan.value;\n\t\t\t\t} else {\n\t\t\t\t\tcolSpanCount -= 1;\n\t\t\t\t}\n\t\t\t\t$tw.utils.addAttributeToParseTreeNode(prevCell,\"colspan\",colSpanCount);\n\t\t\t}\n\t\t\tthis.parser.pos = cellRegExp.lastIndex - 1;\n\t\t\tbreak;\n\t\t} else {\n\t\t\t// For ordinary cells, step beyond the opening `|`\n\t\t\tthis.parser.pos++;\n\t\t\t// Look for a space at the start of the cell\n\t\t\tvar spaceLeft = false;\n\t\t\tvAlign = null;\n\t\t\tif(this.parser.source.substr(this.parser.pos).search(/^\\^([^\\^]|\\^\\^)/) === 0) {\n\t\t\t\tvAlign = \"top\";\n\t\t\t} else if(this.parser.source.substr(this.parser.pos).search(/^,([^,]|,,)/) === 0) {\n\t\t\t\tvAlign = \"bottom\";\n\t\t\t}\n\t\t\tif(vAlign) {\n\t\t\t\tthis.parser.pos++;\n\t\t\t}\n\t\t\tvar chr = this.parser.source.substr(this.parser.pos,1);\n\t\t\twhile(chr === \" \") {\n\t\t\t\tspaceLeft = true;\n\t\t\t\tthis.parser.pos++;\n\t\t\t\tchr = this.parser.source.substr(this.parser.pos,1);\n\t\t\t}\n\t\t\t// Check whether this is a heading cell\n\t\t\tvar cell;\n\t\t\tif(chr === \"!\") {\n\t\t\t\tthis.parser.pos++;\n\t\t\t\tcell = {type: \"element\", tag: \"th\", children: []};\n\t\t\t} else {\n\t\t\t\tcell = {type: \"element\", tag: \"td\", children: []};\n\t\t\t}\n\t\t\ttree.push(cell);\n\t\t\t// Record information about this cell\n\t\t\tprevCell = cell;\n\t\t\tprevColumns[col] = {rowSpanCount:1,element:cell};\n\t\t\t// Check for a colspan\n\t\t\tif(colSpanCount > 1) {\n\t\t\t\t$tw.utils.addAttributeToParseTreeNode(cell,\"colspan\",colSpanCount);\n\t\t\t\tcolSpanCount = 1;\n\t\t\t}\n\t\t\t// Parse the cell\n\t\t\tcell.children = this.parser.parseInlineRun(cellTermRegExp,{eatTerminator: true});\n\t\t\t// Set the alignment for the cell\n\t\t\tif(vAlign) {\n\t\t\t\t$tw.utils.addAttributeToParseTreeNode(cell,\"valign\",vAlign);\n\t\t\t}\n\t\t\tif(this.parser.source.substr(this.parser.pos - 2,1) === \" \") { // spaceRight\n\t\t\t\t$tw.utils.addAttributeToParseTreeNode(cell,\"align\",spaceLeft ? \"center\" : \"left\");\n\t\t\t} else if(spaceLeft) {\n\t\t\t\t$tw.utils.addAttributeToParseTreeNode(cell,\"align\",\"right\");\n\t\t\t}\n\t\t\t// Move back to the closing `|`\n\t\t\tthis.parser.pos--;\n\t\t}\n\t\tcol++;\n\t\tcellRegExp.lastIndex = this.parser.pos;\n\t\tcellMatch = cellRegExp.exec(this.parser.source);\n\t}\n\treturn tree;\n};\n\nexports.parse = function() {\n\tvar rowContainerTypes = {\"c\":\"caption\", \"h\":\"thead\", \"\":\"tbody\", \"f\":\"tfoot\"},\n\t\ttable = {type: \"element\", tag: \"table\", children: []},\n\t\trowRegExp = /^\\|([^\\n]*)\\|([fhck]?)\\r?(?:\\n|$)/mg,\n\t\trowTermRegExp = /(\\|(?:[fhck]?)\\r?(?:\\n|$))/mg,\n\t\tprevColumns = [],\n\t\tcurrRowType,\n\t\trowContainer,\n\t\trowCount = 0;\n\t// Match the row\n\trowRegExp.lastIndex = this.parser.pos;\n\tvar rowMatch = rowRegExp.exec(this.parser.source);\n\twhile(rowMatch && rowMatch.index === this.parser.pos) {\n\t\tvar rowType = rowMatch[2];\n\t\t// Check if it is a class assignment\n\t\tif(rowType === \"k\") {\n\t\t\t$tw.utils.addClassToParseTreeNode(table,rowMatch[1]);\n\t\t\tthis.parser.pos = rowMatch.index + rowMatch[0].length;\n\t\t} else {\n\t\t\t// Otherwise, create a new row if this one is of a different type\n\t\t\tif(rowType !== currRowType) {\n\t\t\t\trowContainer = {type: \"element\", tag: rowContainerTypes[rowType], children: []};\n\t\t\t\ttable.children.push(rowContainer);\n\t\t\t\tcurrRowType = rowType;\n\t\t\t}\n\t\t\t// Is this a caption row?\n\t\t\tif(currRowType === \"c\") {\n\t\t\t\t// If so, move past the opening `|` of the row\n\t\t\t\tthis.parser.pos++;\n\t\t\t\t// Move the caption to the first row if it isn't already\n\t\t\t\tif(table.children.length !== 1) {\n\t\t\t\t\ttable.children.pop(); // Take rowContainer out of the children array\n\t\t\t\t\ttable.children.splice(0,0,rowContainer); // Insert it at the bottom\t\t\t\t\t\t\n\t\t\t\t}\n\t\t\t\t// Set the alignment - TODO: figure out why TW did this\n//\t\t\t\trowContainer.attributes.align = rowCount === 0 ? \"top\" : \"bottom\";\n\t\t\t\t// Parse the caption\n\t\t\t\trowContainer.children = this.parser.parseInlineRun(rowTermRegExp,{eatTerminator: true});\n\t\t\t} else {\n\t\t\t\t// Create the row\n\t\t\t\tvar theRow = {type: \"element\", tag: \"tr\", children: []};\n\t\t\t\t$tw.utils.addClassToParseTreeNode(theRow,rowCount%2 ? \"oddRow\" : \"evenRow\");\n\t\t\t\trowContainer.children.push(theRow);\n\t\t\t\t// Process the row\n\t\t\t\ttheRow.children = processRow.call(this,prevColumns);\n\t\t\t\tthis.parser.pos = rowMatch.index + rowMatch[0].length;\n\t\t\t\t// Increment the row count\n\t\t\t\trowCount++;\n\t\t\t}\n\t\t}\n\t\trowMatch = rowRegExp.exec(this.parser.source);\n\t}\n\treturn [table];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/transcludeblock.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/transcludeblock.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/transcludeblock.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text rule for block-level transclusion. For example:\n\n```\n{{MyTiddler}}\n{{MyTiddler||TemplateTitle}}\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"transcludeblock\";\nexports.types = {block: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /\\{\\{([^\\{\\}\\|]*)(?:\\|\\|([^\\|\\{\\}]+))?\\}\\}(?:\\r?\\n|$)/mg;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// Get the match details\n\tvar template = $tw.utils.trim(this.match[2]),\n\t\ttextRef = $tw.utils.trim(this.match[1]);\n\t// Prepare the transclude widget\n\tvar transcludeNode = {\n\t\t\ttype: \"transclude\",\n\t\t\tattributes: {},\n\t\t\tisBlock: true\n\t\t};\n\t// Prepare the tiddler widget\n\tvar tr, targetTitle, targetField, targetIndex, tiddlerNode;\n\tif(textRef) {\n\t\ttr = $tw.utils.parseTextReference(textRef);\n\t\ttargetTitle = tr.title;\n\t\ttargetField = tr.field;\n\t\ttargetIndex = tr.index;\n\t\ttiddlerNode = {\n\t\t\ttype: \"tiddler\",\n\t\t\tattributes: {\n\t\t\t\ttiddler: {type: \"string\", value: targetTitle}\n\t\t\t},\n\t\t\tisBlock: true,\n\t\t\tchildren: [transcludeNode]\n\t\t};\n\t}\n\tif(template) {\n\t\ttranscludeNode.attributes.tiddler = {type: \"string\", value: template};\n\t\tif(textRef) {\n\t\t\treturn [tiddlerNode];\n\t\t} else {\n\t\t\treturn [transcludeNode];\n\t\t}\n\t} else {\n\t\tif(textRef) {\n\t\t\ttranscludeNode.attributes.tiddler = {type: \"string\", value: targetTitle};\n\t\t\tif(targetField) {\n\t\t\t\ttranscludeNode.attributes.field = {type: \"string\", value: targetField};\n\t\t\t}\n\t\t\tif(targetIndex) {\n\t\t\t\ttranscludeNode.attributes.index = {type: \"string\", value: targetIndex};\n\t\t\t}\n\t\t\treturn [tiddlerNode];\n\t\t} else {\n\t\t\treturn [transcludeNode];\n\t\t}\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/transcludeinline.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/transcludeinline.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/transcludeinline.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text rule for inline-level transclusion. For example:\n\n```\n{{MyTiddler}}\n{{MyTiddler||TemplateTitle}}\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"transcludeinline\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /\\{\\{([^\\{\\}\\|]*)(?:\\|\\|([^\\|\\{\\}]+))?\\}\\}/mg;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// Get the match details\n\tvar template = $tw.utils.trim(this.match[2]),\n\t\ttextRef = $tw.utils.trim(this.match[1]);\n\t// Prepare the transclude widget\n\tvar transcludeNode = {\n\t\t\ttype: \"transclude\",\n\t\t\tattributes: {}\n\t\t};\n\t// Prepare the tiddler widget\n\tvar tr, targetTitle, targetField, targetIndex, tiddlerNode;\n\tif(textRef) {\n\t\ttr = $tw.utils.parseTextReference(textRef);\n\t\ttargetTitle = tr.title;\n\t\ttargetField = tr.field;\n\t\ttargetIndex = tr.index;\n\t\ttiddlerNode = {\n\t\t\ttype: \"tiddler\",\n\t\t\tattributes: {\n\t\t\t\ttiddler: {type: \"string\", value: targetTitle}\n\t\t\t},\n\t\t\tchildren: [transcludeNode]\n\t\t};\n\t}\n\tif(template) {\n\t\ttranscludeNode.attributes.tiddler = {type: \"string\", value: template};\n\t\tif(textRef) {\n\t\t\treturn [tiddlerNode];\n\t\t} else {\n\t\t\treturn [transcludeNode];\n\t\t}\n\t} else {\n\t\tif(textRef) {\n\t\t\ttranscludeNode.attributes.tiddler = {type: \"string\", value: targetTitle};\n\t\t\tif(targetField) {\n\t\t\t\ttranscludeNode.attributes.field = {type: \"string\", value: targetField};\n\t\t\t}\n\t\t\tif(targetIndex) {\n\t\t\t\ttranscludeNode.attributes.index = {type: \"string\", value: targetIndex};\n\t\t\t}\n\t\t\treturn [tiddlerNode];\n\t\t} else {\n\t\t\treturn [transcludeNode];\n\t\t}\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/typedblock.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/typedblock.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/typedblock.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text rule for typed blocks. For example:\n\n```\n$$$.js\nThis will be rendered as JavaScript\n$$$\n\n$$$.svg\n<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"150\" height=\"100\">\n <circle cx=\"100\" cy=\"50\" r=\"40\" stroke=\"black\" stroke-width=\"2\" fill=\"red\" />\n</svg>\n$$$\n\n$$$text/vnd.tiddlywiki>text/html\nThis will be rendered as an //HTML representation// of WikiText\n$$$\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar widget = require(\"$:/core/modules/widgets/widget.js\");\n\nexports.name = \"typedblock\";\nexports.types = {block: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /\\$\\$\\$([^ >\\r\\n]*)(?: *> *([^ \\r\\n]+))?\\r?\\n/mg;\n};\n\nexports.parse = function() {\n\tvar reEnd = /\\r?\\n\\$\\$\\$\\r?(?:\\n|$)/mg;\n\t// Save the type\n\tvar parseType = this.match[1],\n\t\trenderType = this.match[2];\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// Look for the end of the block\n\treEnd.lastIndex = this.parser.pos;\n\tvar match = reEnd.exec(this.parser.source),\n\t\ttext;\n\t// Process the block\n\tif(match) {\n\t\ttext = this.parser.source.substring(this.parser.pos,match.index);\n\t\tthis.parser.pos = match.index + match[0].length;\n\t} else {\n\t\ttext = this.parser.source.substr(this.parser.pos);\n\t\tthis.parser.pos = this.parser.sourceLength;\n\t}\n\t// Parse the block according to the specified type\n\tvar parser = this.parser.wiki.parseText(parseType,text,{defaultType: \"text/plain\"});\n\t// If there's no render type, just return the parse tree\n\tif(!renderType) {\n\t\treturn parser.tree;\n\t} else {\n\t\t// Otherwise, render to the rendertype and return in a <PRE> tag\n\t\tvar widgetNode = this.parser.wiki.makeWidget(parser),\n\t\t\tcontainer = $tw.fakeDocument.createElement(\"div\");\n\t\twidgetNode.render(container,null);\n\t\ttext = renderType === \"text/html\" ? container.innerHTML : container.textContent;\n\t\treturn [{\n\t\t\ttype: \"element\",\n\t\t\ttag: \"pre\",\n\t\t\tchildren: [{\n\t\t\t\ttype: \"text\",\n\t\t\t\ttext: text\n\t\t\t}]\n\t\t}];\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/whitespace.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/whitespace.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/whitespace.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki pragma rule for whitespace specifications\n\n```\n\\whitespace trim\n\\whitespace notrim\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"whitespace\";\nexports.types = {pragma: true};\n\n/*\nInstantiate parse rule\n*/\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /^\\\\whitespace[^\\S\\n]/mg;\n};\n\n/*\nParse the most recent match\n*/\nexports.parse = function() {\n\tvar self = this;\n\t// Move past the pragma invocation\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// Parse whitespace delimited tokens terminated by a line break\n\tvar reMatch = /[^\\S\\n]*(\\S+)|(\\r?\\n)/mg,\n\t\ttokens = [];\n\treMatch.lastIndex = this.parser.pos;\n\tvar match = reMatch.exec(this.parser.source);\n\twhile(match && match.index === this.parser.pos) {\n\t\tthis.parser.pos = reMatch.lastIndex;\n\t\t// Exit if we've got the line break\n\t\tif(match[2]) {\n\t\t\tbreak;\n\t\t}\n\t\t// Process the token\n\t\tif(match[1]) {\n\t\t\ttokens.push(match[1]);\n\t\t}\n\t\t// Match the next token\n\t\tmatch = reMatch.exec(this.parser.source);\n\t}\n\t// Process the tokens\n\t$tw.utils.each(tokens,function(token) {\n\t\tswitch(token) {\n\t\t\tcase \"trim\":\n\t\t\t\tself.parser.configTrimWhiteSpace = true;\n\t\t\t\tbreak;\n\t\t\tcase \"notrim\":\n\t\t\t\tself.parser.configTrimWhiteSpace = false;\n\t\t\t\tbreak;\n\t\t}\n\t});\n\t// No parse tree nodes to return\n\treturn [];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/rules/wikilink.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/wikilink.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/wikilink.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for wiki links. For example:\n\n```\nAWikiLink\nAnotherLink\n~SuppressedLink\n```\n\nPrecede a camel case word with `~` to prevent it from being recognised as a link.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"wikilink\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = new RegExp($tw.config.textPrimitives.unWikiLink + \"?\" + $tw.config.textPrimitives.wikiLink,\"mg\");\n};\n\n/*\nParse the most recent match\n*/\nexports.parse = function() {\n\t// Get the details of the match\n\tvar linkText = this.match[0];\n\t// Move past the macro call\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// If the link starts with the unwikilink character then just output it as plain text\n\tif(linkText.substr(0,1) === $tw.config.textPrimitives.unWikiLink) {\n\t\treturn [{type: \"text\", text: linkText.substr(1)}];\n\t}\n\t// If the link has been preceded with a blocked letter then don't treat it as a link\n\tif(this.match.index > 0) {\n\t\tvar preRegExp = new RegExp($tw.config.textPrimitives.blockPrefixLetters,\"mg\");\n\t\tpreRegExp.lastIndex = this.match.index-1;\n\t\tvar preMatch = preRegExp.exec(this.parser.source);\n\t\tif(preMatch && preMatch.index === this.match.index-1) {\n\t\t\treturn [{type: \"text\", text: linkText}];\n\t\t}\n\t}\n\treturn [{\n\t\ttype: \"link\",\n\t\tattributes: {\n\t\t\tto: {type: \"string\", value: linkText}\n\t\t},\n\t\tchildren: [{\n\t\t\ttype: \"text\",\n\t\t\ttext: linkText\n\t\t}]\n\t}];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/core/modules/parsers/wikiparser/wikiparser.js": {
"title": "$:/core/modules/parsers/wikiparser/wikiparser.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/wikiparser.js\ntype: application/javascript\nmodule-type: parser\n\nThe wiki text parser processes blocks of source text into a parse tree.\n\nThe parse tree is made up of nested arrays of these JavaScript objects:\n\n\t{type: \"element\", tag: <string>, attributes: {}, children: []} - an HTML element\n\t{type: \"text\", text: <string>} - a text node\n\t{type: \"entity\", value: <string>} - an entity\n\t{type: \"raw\", html: <string>} - raw HTML\n\nAttributes are stored as hashmaps of the following objects:\n\n\t{type: \"string\", value: <string>} - literal string\n\t{type: \"indirect\", textReference: <textReference>} - indirect through a text reference\n\t{type: \"macro\", macro: <TBD>} - indirect through a macro invocation\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar WikiParser = function(type,text,options) {\n\tthis.wiki = options.wiki;\n\tvar self = this;\n\t// Check for an externally linked tiddler\n\tif($tw.browser && (text || \"\") === \"\" && options._canonical_uri) {\n\t\tthis.loadRemoteTiddler(options._canonical_uri);\n\t\ttext = $tw.language.getRawString(\"LazyLoadingWarning\");\n\t}\n\t// Initialise the classes if we don't have them already\n\tif(!this.pragmaRuleClasses) {\n\t\tWikiParser.prototype.pragmaRuleClasses = $tw.modules.createClassesFromModules(\"wikirule\",\"pragma\",$tw.WikiRuleBase);\n\t\tthis.setupRules(WikiParser.prototype.pragmaRuleClasses,\"$:/config/WikiParserRules/Pragmas/\");\n\t}\n\tif(!this.blockRuleClasses) {\n\t\tWikiParser.prototype.blockRuleClasses = $tw.modules.createClassesFromModules(\"wikirule\",\"block\",$tw.WikiRuleBase);\n\t\tthis.setupRules(WikiParser.prototype.blockRuleClasses,\"$:/config/WikiParserRules/Block/\");\n\t}\n\tif(!this.inlineRuleClasses) {\n\t\tWikiParser.prototype.inlineRuleClasses = $tw.modules.createClassesFromModules(\"wikirule\",\"inline\",$tw.WikiRuleBase);\n\t\tthis.setupRules(WikiParser.prototype.inlineRuleClasses,\"$:/config/WikiParserRules/Inline/\");\n\t}\n\t// Save the parse text\n\tthis.type = type || \"text/vnd.tiddlywiki\";\n\tthis.source = text || \"\";\n\tthis.sourceLength = this.source.length;\n\t// Flag for ignoring whitespace\n\tthis.configTrimWhiteSpace = false;\n\t// Set current parse position\n\tthis.pos = 0;\n\t// Instantiate the pragma parse rules\n\tthis.pragmaRules = this.instantiateRules(this.pragmaRuleClasses,\"pragma\",0);\n\t// Instantiate the parser block and inline rules\n\tthis.blockRules = this.instantiateRules(this.blockRuleClasses,\"block\",0);\n\tthis.inlineRules = this.instantiateRules(this.inlineRuleClasses,\"inline\",0);\n\t// Parse any pragmas\n\tthis.tree = [];\n\tvar topBranch = this.parsePragmas();\n\t// Parse the text into inline runs or blocks\n\tif(options.parseAsInline) {\n\t\ttopBranch.push.apply(topBranch,this.parseInlineRun());\n\t} else {\n\t\ttopBranch.push.apply(topBranch,this.parseBlocks());\n\t}\n\t// Return the parse tree\n};\n\n/*\n*/\nWikiParser.prototype.loadRemoteTiddler = function(url) {\n\tvar self = this;\n\t$tw.utils.httpRequest({\n\t\turl: url,\n\t\ttype: \"GET\",\n\t\tcallback: function(err,data) {\n\t\t\tif(!err) {\n\t\t\t\tvar tiddlers = self.wiki.deserializeTiddlers(\".tid\",data,self.wiki.getCreationFields());\n\t\t\t\t$tw.utils.each(tiddlers,function(tiddler) {\n\t\t\t\t\ttiddler[\"_canonical_uri\"] = url;\n\t\t\t\t});\n\t\t\t\tif(tiddlers) {\n\t\t\t\t\tself.wiki.addTiddlers(tiddlers);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t});\n};\n\n/*\n*/\nWikiParser.prototype.setupRules = function(proto,configPrefix) {\n\tvar self = this;\n\tif(!$tw.safemode) {\n\t\t$tw.utils.each(proto,function(object,name) {\n\t\t\tif(self.wiki.getTiddlerText(configPrefix + name,\"enable\") !== \"enable\") {\n\t\t\t\tdelete proto[name];\n\t\t\t}\n\t\t});\n\t}\n};\n\n/*\nInstantiate an array of parse rules\n*/\nWikiParser.prototype.instantiateRules = function(classes,type,startPos) {\n\tvar rulesInfo = [],\n\t\tself = this;\n\t$tw.utils.each(classes,function(RuleClass) {\n\t\t// Instantiate the rule\n\t\tvar rule = new RuleClass(self);\n\t\trule.is = {};\n\t\trule.is[type] = true;\n\t\trule.init(self);\n\t\tvar matchIndex = rule.findNextMatch(startPos);\n\t\tif(matchIndex !== undefined) {\n\t\t\trulesInfo.push({\n\t\t\t\trule: rule,\n\t\t\t\tmatchIndex: matchIndex\n\t\t\t});\n\t\t}\n\t});\n\treturn rulesInfo;\n};\n\n/*\nSkip any whitespace at the current position. Options are:\n\ttreatNewlinesAsNonWhitespace: true if newlines are NOT to be treated as whitespace\n*/\nWikiParser.prototype.skipWhitespace = function(options) {\n\toptions = options || {};\n\tvar whitespaceRegExp = options.treatNewlinesAsNonWhitespace ? /([^\\S\\n]+)/mg : /(\\s+)/mg;\n\twhitespaceRegExp.lastIndex = this.pos;\n\tvar whitespaceMatch = whitespaceRegExp.exec(this.source);\n\tif(whitespaceMatch && whitespaceMatch.index === this.pos) {\n\t\tthis.pos = whitespaceRegExp.lastIndex;\n\t}\n};\n\n/*\nGet the next match out of an array of parse rule instances\n*/\nWikiParser.prototype.findNextMatch = function(rules,startPos) {\n\t// Find the best matching rule by finding the closest match position\n\tvar matchingRule,\n\t\tmatchingRulePos = this.sourceLength;\n\t// Step through each rule\n\tfor(var t=0; t<rules.length; t++) {\n\t\tvar ruleInfo = rules[t];\n\t\t// Ask the rule to get the next match if we've moved past the current one\n\t\tif(ruleInfo.matchIndex !== undefined && ruleInfo.matchIndex < startPos) {\n\t\t\truleInfo.matchIndex = ruleInfo.rule.findNextMatch(startPos);\n\t\t}\n\t\t// Adopt this match if it's closer than the current best match\n\t\tif(ruleInfo.matchIndex !== undefined && ruleInfo.matchIndex <= matchingRulePos) {\n\t\t\tmatchingRule = ruleInfo;\n\t\t\tmatchingRulePos = ruleInfo.matchIndex;\n\t\t}\n\t}\n\treturn matchingRule;\n};\n\n/*\nParse any pragmas at the beginning of a block of parse text\n*/\nWikiParser.prototype.parsePragmas = function() {\n\tvar currentTreeBranch = this.tree;\n\twhile(true) {\n\t\t// Skip whitespace\n\t\tthis.skipWhitespace();\n\t\t// Check for the end of the text\n\t\tif(this.pos >= this.sourceLength) {\n\t\t\tbreak;\n\t\t}\n\t\t// Check if we've arrived at a pragma rule match\n\t\tvar nextMatch = this.findNextMatch(this.pragmaRules,this.pos);\n\t\t// If not, just exit\n\t\tif(!nextMatch || nextMatch.matchIndex !== this.pos) {\n\t\t\tbreak;\n\t\t}\n\t\t// Process the pragma rule\n\t\tvar subTree = nextMatch.rule.parse();\n\t\tif(subTree.length > 0) {\n\t\t\t// Quick hack; we only cope with a single parse tree node being returned, which is true at the moment\n\t\t\tcurrentTreeBranch.push.apply(currentTreeBranch,subTree);\n\t\t\tsubTree[0].children = [];\n\t\t\tcurrentTreeBranch = subTree[0].children;\n\t\t}\n\t}\n\treturn currentTreeBranch;\n};\n\n/*\nParse a block from the current position\n\tterminatorRegExpString: optional regular expression string that identifies the end of plain paragraphs. Must not include capturing parenthesis\n*/\nWikiParser.prototype.parseBlock = function(terminatorRegExpString) {\n\tvar terminatorRegExp = terminatorRegExpString ? new RegExp(\"(\" + terminatorRegExpString + \"|\\\\r?\\\\n\\\\r?\\\\n)\",\"mg\") : /(\\r?\\n\\r?\\n)/mg;\n\tthis.skipWhitespace();\n\tif(this.pos >= this.sourceLength) {\n\t\treturn [];\n\t}\n\t// Look for a block rule that applies at the current position\n\tvar nextMatch = this.findNextMatch(this.blockRules,this.pos);\n\tif(nextMatch && nextMatch.matchIndex === this.pos) {\n\t\treturn nextMatch.rule.parse();\n\t}\n\t// Treat it as a paragraph if we didn't find a block rule\n\treturn [{type: \"element\", tag: \"p\", children: this.parseInlineRun(terminatorRegExp)}];\n};\n\n/*\nParse a series of blocks of text until a terminating regexp is encountered or the end of the text\n\tterminatorRegExpString: terminating regular expression\n*/\nWikiParser.prototype.parseBlocks = function(terminatorRegExpString) {\n\tif(terminatorRegExpString) {\n\t\treturn this.parseBlocksTerminated(terminatorRegExpString);\n\t} else {\n\t\treturn this.parseBlocksUnterminated();\n\t}\n};\n\n/*\nParse a block from the current position to the end of the text\n*/\nWikiParser.prototype.parseBlocksUnterminated = function() {\n\tvar tree = [];\n\twhile(this.pos < this.sourceLength) {\n\t\ttree.push.apply(tree,this.parseBlock());\n\t}\n\treturn tree;\n};\n\n/*\nParse blocks of text until a terminating regexp is encountered\n*/\nWikiParser.prototype.parseBlocksTerminated = function(terminatorRegExpString) {\n\tvar terminatorRegExp = new RegExp(\"(\" + terminatorRegExpString + \")\",\"mg\"),\n\t\ttree = [];\n\t// Skip any whitespace\n\tthis.skipWhitespace();\n\t// Check if we've got the end marker\n\tterminatorRegExp.lastIndex = this.pos;\n\tvar match = terminatorRegExp.exec(this.source);\n\t// Parse the text into blocks\n\twhile(this.pos < this.sourceLength && !(match && match.index === this.pos)) {\n\t\tvar blocks = this.parseBlock(terminatorRegExpString);\n\t\ttree.push.apply(tree,blocks);\n\t\t// Skip any whitespace\n\t\tthis.skipWhitespace();\n\t\t// Check if we've got the end marker\n\t\tterminatorRegExp.lastIndex = this.pos;\n\t\tmatch = terminatorRegExp.exec(this.source);\n\t}\n\tif(match && match.index === this.pos) {\n\t\tthis.pos = match.index + match[0].length;\n\t}\n\treturn tree;\n};\n\n/*\nParse a run of text at the current position\n\tterminatorRegExp: a regexp at which to stop the run\n\toptions: see below\nOptions available:\n\teatTerminator: move the parse position past any encountered terminator (default false)\n*/\nWikiParser.prototype.parseInlineRun = function(terminatorRegExp,options) {\n\tif(terminatorRegExp) {\n\t\treturn this.parseInlineRunTerminated(terminatorRegExp,options);\n\t} else {\n\t\treturn this.parseInlineRunUnterminated(options);\n\t}\n};\n\nWikiParser.prototype.parseInlineRunUnterminated = function(options) {\n\tvar tree = [];\n\t// Find the next occurrence of an inline rule\n\tvar nextMatch = this.findNextMatch(this.inlineRules,this.pos);\n\t// Loop around the matches until we've reached the end of the text\n\twhile(this.pos < this.sourceLength && nextMatch) {\n\t\t// Process the text preceding the run rule\n\t\tif(nextMatch.matchIndex > this.pos) {\n\t\t\tthis.pushTextWidget(tree,this.source.substring(this.pos,nextMatch.matchIndex));\n\t\t\tthis.pos = nextMatch.matchIndex;\n\t\t}\n\t\t// Process the run rule\n\t\ttree.push.apply(tree,nextMatch.rule.parse());\n\t\t// Look for the next run rule\n\t\tnextMatch = this.findNextMatch(this.inlineRules,this.pos);\n\t}\n\t// Process the remaining text\n\tif(this.pos < this.sourceLength) {\n\t\tthis.pushTextWidget(tree,this.source.substr(this.pos));\n\t}\n\tthis.pos = this.sourceLength;\n\treturn tree;\n};\n\nWikiParser.prototype.parseInlineRunTerminated = function(terminatorRegExp,options) {\n\toptions = options || {};\n\tvar tree = [];\n\t// Find the next occurrence of the terminator\n\tterminatorRegExp.lastIndex = this.pos;\n\tvar terminatorMatch = terminatorRegExp.exec(this.source);\n\t// Find the next occurrence of a inlinerule\n\tvar inlineRuleMatch = this.findNextMatch(this.inlineRules,this.pos);\n\t// Loop around until we've reached the end of the text\n\twhile(this.pos < this.sourceLength && (terminatorMatch || inlineRuleMatch)) {\n\t\t// Return if we've found the terminator, and it precedes any inline rule match\n\t\tif(terminatorMatch) {\n\t\t\tif(!inlineRuleMatch || inlineRuleMatch.matchIndex >= terminatorMatch.index) {\n\t\t\t\tif(terminatorMatch.index > this.pos) {\n\t\t\t\t\tthis.pushTextWidget(tree,this.source.substring(this.pos,terminatorMatch.index));\n\t\t\t\t}\n\t\t\t\tthis.pos = terminatorMatch.index;\n\t\t\t\tif(options.eatTerminator) {\n\t\t\t\t\tthis.pos += terminatorMatch[0].length;\n\t\t\t\t}\n\t\t\t\treturn tree;\n\t\t\t}\n\t\t}\n\t\t// Process any inline rule, along with the text preceding it\n\t\tif(inlineRuleMatch) {\n\t\t\t// Preceding text\n\t\t\tif(inlineRuleMatch.matchIndex > this.pos) {\n\t\t\t\tthis.pushTextWidget(tree,this.source.substring(this.pos,inlineRuleMatch.matchIndex));\n\t\t\t\tthis.pos = inlineRuleMatch.matchIndex;\n\t\t\t}\n\t\t\t// Process the inline rule\n\t\t\ttree.push.apply(tree,inlineRuleMatch.rule.parse());\n\t\t\t// Look for the next inline rule\n\t\t\tinlineRuleMatch = this.findNextMatch(this.inlineRules,this.pos);\n\t\t\t// Look for the next terminator match\n\t\t\tterminatorRegExp.lastIndex = this.pos;\n\t\t\tterminatorMatch = terminatorRegExp.exec(this.source);\n\t\t}\n\t}\n\t// Process the remaining text\n\tif(this.pos < this.sourceLength) {\n\t\tthis.pushTextWidget(tree,this.source.substr(this.pos));\n\t}\n\tthis.pos = this.sourceLength;\n\treturn tree;\n};\n\n/*\nPush a text widget onto an array, respecting the configTrimWhiteSpace setting\n*/\nWikiParser.prototype.pushTextWidget = function(array,text) {\n\tif(this.configTrimWhiteSpace) {\n\t\ttext = $tw.utils.trim(text);\n\t}\n\tif(text) {\n\t\tarray.push({type: \"text\", text: text});\t\t\n\t}\n};\n\n/*\nParse zero or more class specifiers `.classname`\n*/\nWikiParser.prototype.parseClasses = function() {\n\tvar classRegExp = /\\.([^\\s\\.]+)/mg,\n\t\tclassNames = [];\n\tclassRegExp.lastIndex = this.pos;\n\tvar match = classRegExp.exec(this.source);\n\twhile(match && match.index === this.pos) {\n\t\tthis.pos = match.index + match[0].length;\n\t\tclassNames.push(match[1]);\n\t\tmatch = classRegExp.exec(this.source);\n\t}\n\treturn classNames;\n};\n\n/*\nAmend the rules used by this instance of the parser\n\ttype: `only` keeps just the named rules, `except` keeps all but the named rules\n\tnames: array of rule names\n*/\nWikiParser.prototype.amendRules = function(type,names) {\n\tnames = names || [];\n\t// Define the filter function\n\tvar keepFilter;\n\tif(type === \"only\") {\n\t\tkeepFilter = function(name) {\n\t\t\treturn names.indexOf(name) !== -1;\n\t\t};\n\t} else if(type === \"except\") {\n\t\tkeepFilter = function(name) {\n\t\t\treturn names.indexOf(name) === -1;\n\t\t};\n\t} else {\n\t\treturn;\n\t}\n\t// Define a function to process each of our rule arrays\n\tvar processRuleArray = function(ruleArray) {\n\t\tfor(var t=ruleArray.length-1; t>=0; t--) {\n\t\t\tif(!keepFilter(ruleArray[t].rule.name)) {\n\t\t\t\truleArray.splice(t,1);\n\t\t\t}\n\t\t}\n\t};\n\t// Process each rule array\n\tprocessRuleArray(this.pragmaRules);\n\tprocessRuleArray(this.blockRules);\n\tprocessRuleArray(this.inlineRules);\n};\n\nexports[\"text/vnd.tiddlywiki\"] = WikiParser;\n\n})();\n\n",
"type": "application/javascript",
"module-type": "parser"
},
"$:/core/modules/parsers/wikiparser/rules/wikirulebase.js": {
"title": "$:/core/modules/parsers/wikiparser/rules/wikirulebase.js",
"text": "/*\\\ntitle: $:/core/modules/parsers/wikiparser/rules/wikirulebase.js\ntype: application/javascript\nmodule-type: global\n\nBase class for wiki parser rules\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nThis constructor is always overridden with a blank constructor, and so shouldn't be used\n*/\nvar WikiRuleBase = function() {\n};\n\n/*\nTo be overridden by individual rules\n*/\nWikiRuleBase.prototype.init = function(parser) {\n\tthis.parser = parser;\n};\n\n/*\nDefault implementation of findNextMatch uses RegExp matching\n*/\nWikiRuleBase.prototype.findNextMatch = function(startPos) {\n\tthis.matchRegExp.lastIndex = startPos;\n\tthis.match = this.matchRegExp.exec(this.parser.source);\n\treturn this.match ? this.match.index : undefined;\n};\n\nexports.WikiRuleBase = WikiRuleBase;\n\n})();\n",
"type": "application/javascript",
"module-type": "global"
},
"$:/core/modules/pluginswitcher.js": {
"title": "$:/core/modules/pluginswitcher.js",
"text": "/*\\\ntitle: $:/core/modules/pluginswitcher.js\ntype: application/javascript\nmodule-type: global\n\nManages switching plugins for themes and languages.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\noptions:\nwiki: wiki store to be used\npluginType: type of plugin to be switched\ncontrollerTitle: title of tiddler used to control switching of this resource\ndefaultPlugins: array of default plugins to be used if nominated plugin isn't found\nonSwitch: callback when plugin is switched (single parameter is array of plugin titles)\n*/\nfunction PluginSwitcher(options) {\n\tthis.wiki = options.wiki;\n\tthis.pluginType = options.pluginType;\n\tthis.controllerTitle = options.controllerTitle;\n\tthis.defaultPlugins = options.defaultPlugins || [];\n\tthis.onSwitch = options.onSwitch;\n\t// Switch to the current plugin\n\tthis.switchPlugins();\n\t// Listen for changes to the selected plugin\n\tvar self = this;\n\tthis.wiki.addEventListener(\"change\",function(changes) {\n\t\tif($tw.utils.hop(changes,self.controllerTitle)) {\n\t\t\tself.switchPlugins();\n\t\t}\n\t});\n}\n\nPluginSwitcher.prototype.switchPlugins = function() {\n\t// Get the name of the current theme\n\tvar selectedPluginTitle = this.wiki.getTiddlerText(this.controllerTitle);\n\t// If it doesn't exist, then fallback to one of the default themes\n\tvar index = 0;\n\twhile(!this.wiki.getTiddler(selectedPluginTitle) && index < this.defaultPlugins.length) {\n\t\tselectedPluginTitle = this.defaultPlugins[index++];\n\t}\n\t// Accumulate the titles of the plugins that we need to load\n\tvar plugins = [],\n\t\tself = this,\n\t\taccumulatePlugin = function(title) {\n\t\t\tvar tiddler = self.wiki.getTiddler(title);\n\t\t\tif(tiddler && tiddler.isPlugin() && plugins.indexOf(title) === -1) {\n\t\t\t\tplugins.push(title);\n\t\t\t\tvar pluginInfo = JSON.parse(self.wiki.getTiddlerText(title)),\n\t\t\t\t\tdependents = $tw.utils.parseStringArray(tiddler.fields.dependents || \"\");\n\t\t\t\t$tw.utils.each(dependents,function(title) {\n\t\t\t\t\taccumulatePlugin(title);\n\t\t\t\t});\n\t\t\t}\n\t\t};\n\taccumulatePlugin(selectedPluginTitle);\n\t// Unregister any existing theme tiddlers\n\tvar unregisteredTiddlers = $tw.wiki.unregisterPluginTiddlers(this.pluginType);\n\t// Register any new theme tiddlers\n\tvar registeredTiddlers = $tw.wiki.registerPluginTiddlers(this.pluginType,plugins);\n\t// Unpack the current theme tiddlers\n\t$tw.wiki.unpackPluginTiddlers();\n\t// Call the switch handler\n\tif(this.onSwitch) {\n\t\tthis.onSwitch(plugins);\n\t}\n};\n\nexports.PluginSwitcher = PluginSwitcher;\n\n})();\n",
"type": "application/javascript",
"module-type": "global"
},
"$:/core/modules/saver-handler.js": {
"title": "$:/core/modules/saver-handler.js",
"text": "/*\\\ntitle: $:/core/modules/saver-handler.js\ntype: application/javascript\nmodule-type: global\n\nThe saver handler tracks changes to the store and handles saving the entire wiki via saver modules.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nInstantiate the saver handler with the following options:\nwiki: wiki to be synced\ndirtyTracking: true if dirty tracking should be performed\n*/\nfunction SaverHandler(options) {\n\tvar self = this;\n\tthis.wiki = options.wiki;\n\tthis.dirtyTracking = options.dirtyTracking;\n\tthis.pendingAutoSave = false;\n\t// Make a logger\n\tthis.logger = new $tw.utils.Logger(\"saver-handler\");\n\t// Initialise our savers\n\tif($tw.browser) {\n\t\tthis.initSavers();\n\t}\n\t// Only do dirty tracking if required\n\tif($tw.browser && this.dirtyTracking) {\n\t\t// Compile the dirty tiddler filter\n\t\tthis.filterFn = this.wiki.compileFilter(this.wiki.getTiddlerText(this.titleSyncFilter));\n\t\t// Count of changes that have not yet been saved\n\t\tthis.numChanges = 0;\n\t\t// Listen out for changes to tiddlers\n\t\tthis.wiki.addEventListener(\"change\",function(changes) {\n\t\t\t// Filter the changes so that we only count changes to tiddlers that we care about\n\t\t\tvar filteredChanges = self.filterFn.call(self.wiki,function(iterator) {\n\t\t\t\t$tw.utils.each(changes,function(change,title) {\n\t\t\t\t\tvar tiddler = self.wiki.getTiddler(title);\n\t\t\t\t\titerator(tiddler,title);\n\t\t\t\t});\n\t\t\t});\n\t\t\t// Adjust the number of changes\n\t\t\tself.numChanges += filteredChanges.length;\n\t\t\tself.updateDirtyStatus();\n\t\t\t// Do any autosave if one is pending and there's no more change events\n\t\t\tif(self.pendingAutoSave && self.wiki.getSizeOfTiddlerEventQueue() === 0) {\n\t\t\t\t// Check if we're dirty\n\t\t\t\tif(self.numChanges > 0) {\n\t\t\t\t\tself.saveWiki({\n\t\t\t\t\t\tmethod: \"autosave\",\n\t\t\t\t\t\tdownloadType: \"text/plain\"\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\tself.pendingAutoSave = false;\n\t\t\t}\n\t\t});\n\t\t// Listen for the autosave event\n\t\t$tw.rootWidget.addEventListener(\"tm-auto-save-wiki\",function(event) {\n\t\t\t// Do the autosave unless there are outstanding tiddler change events\n\t\t\tif(self.wiki.getSizeOfTiddlerEventQueue() === 0) {\n\t\t\t\t// Check if we're dirty\n\t\t\t\tif(self.numChanges > 0) {\n\t\t\t\t\tself.saveWiki({\n\t\t\t\t\t\tmethod: \"autosave\",\n\t\t\t\t\t\tdownloadType: \"text/plain\"\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// Otherwise put ourselves in the \"pending autosave\" state and wait for the change event before we do the autosave\n\t\t\t\tself.pendingAutoSave = true;\n\t\t\t}\n\t\t});\n\t\t// Set up our beforeunload handler\n\t\t$tw.addUnloadTask(function(event) {\n\t\t\tvar confirmationMessage;\n\t\t\tif(self.isDirty()) {\n\t\t\t\tconfirmationMessage = $tw.language.getString(\"UnsavedChangesWarning\");\n\t\t\t\tevent.returnValue = confirmationMessage; // Gecko\n\t\t\t}\n\t\t\treturn confirmationMessage;\n\t\t});\n\t}\n\t// Install the save action handlers\n\tif($tw.browser) {\n\t\t$tw.rootWidget.addEventListener(\"tm-save-wiki\",function(event) {\n\t\t\tself.saveWiki({\n\t\t\t\ttemplate: event.param,\n\t\t\t\tdownloadType: \"text/plain\",\n\t\t\t\tvariables: event.paramObject\n\t\t\t});\n\t\t});\n\t\t$tw.rootWidget.addEventListener(\"tm-download-file\",function(event) {\n\t\t\tself.saveWiki({\n\t\t\t\tmethod: \"download\",\n\t\t\t\ttemplate: event.param,\n\t\t\t\tdownloadType: \"text/plain\",\n\t\t\t\tvariables: event.paramObject\n\t\t\t});\n\t\t});\n\t}\n}\n\nSaverHandler.prototype.titleSyncFilter = \"$:/config/SaverFilter\";\nSaverHandler.prototype.titleAutoSave = \"$:/config/AutoSave\";\nSaverHandler.prototype.titleSavedNotification = \"$:/language/Notifications/Save/Done\";\n\n/*\nSelect the appropriate saver modules and set them up\n*/\nSaverHandler.prototype.initSavers = function(moduleType) {\n\tmoduleType = moduleType || \"saver\";\n\t// Instantiate the available savers\n\tthis.savers = [];\n\tvar self = this;\n\t$tw.modules.forEachModuleOfType(moduleType,function(title,module) {\n\t\tif(module.canSave(self)) {\n\t\t\tself.savers.push(module.create(self.wiki));\n\t\t}\n\t});\n\t// Sort the savers into priority order\n\tthis.savers.sort(function(a,b) {\n\t\tif(a.info.priority < b.info.priority) {\n\t\t\treturn -1;\n\t\t} else {\n\t\t\tif(a.info.priority > b.info.priority) {\n\t\t\t\treturn +1;\n\t\t\t} else {\n\t\t\t\treturn 0;\n\t\t\t}\n\t\t}\n\t});\n};\n\n/*\nSave the wiki contents. Options are:\n\tmethod: \"save\", \"autosave\" or \"download\"\n\ttemplate: the tiddler containing the template to save\n\tdownloadType: the content type for the saved file\n*/\nSaverHandler.prototype.saveWiki = function(options) {\n\toptions = options || {};\n\tvar self = this,\n\t\tmethod = options.method || \"save\",\n\t\tvariables = options.variables || {},\n\t\ttemplate = options.template || \"$:/core/save/all\",\n\t\tdownloadType = options.downloadType || \"text/plain\",\n\t\ttext = this.wiki.renderTiddler(downloadType,template,options),\n\t\tcallback = function(err) {\n\t\t\tif(err) {\n\t\t\t\talert($tw.language.getString(\"Error/WhileSaving\") + \":\\n\\n\" + err);\n\t\t\t} else {\n\t\t\t\t// Clear the task queue if we're saving (rather than downloading)\n\t\t\t\tif(method !== \"download\") {\n\t\t\t\t\tself.numChanges = 0;\n\t\t\t\t\tself.updateDirtyStatus();\n\t\t\t\t}\n\t\t\t\t$tw.notifier.display(self.titleSavedNotification);\n\t\t\t\tif(options.callback) {\n\t\t\t\t\toptions.callback();\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t// Ignore autosave if disabled\n\tif(method === \"autosave\" && this.wiki.getTiddlerText(this.titleAutoSave,\"yes\") !== \"yes\") {\n\t\treturn false;\n\t}\n\t// Call the highest priority saver that supports this method\n\tfor(var t=this.savers.length-1; t>=0; t--) {\n\t\tvar saver = this.savers[t];\n\t\tif(saver.info.capabilities.indexOf(method) !== -1 && saver.save(text,method,callback,{variables: {filename: variables.filename}})) {\n\t\t\tthis.logger.log(\"Saving wiki with method\",method,\"through saver\",saver.info.name);\n\t\t\treturn true;\n\t\t}\n\t}\n\treturn false;\n};\n\n/*\nChecks whether the wiki is dirty (ie the window shouldn't be closed)\n*/\nSaverHandler.prototype.isDirty = function() {\n\treturn this.numChanges > 0;\n};\n\n/*\nUpdate the document body with the class \"tc-dirty\" if the wiki has unsaved/unsynced changes\n*/\nSaverHandler.prototype.updateDirtyStatus = function() {\n\tif($tw.browser) {\n\t\t$tw.utils.toggleClass(document.body,\"tc-dirty\",this.isDirty());\n\t}\n};\n\nexports.SaverHandler = SaverHandler;\n\n})();\n",
"type": "application/javascript",
"module-type": "global"
},
"$:/core/modules/savers/andtidwiki.js": {
"title": "$:/core/modules/savers/andtidwiki.js",
"text": "/*\\\ntitle: $:/core/modules/savers/andtidwiki.js\ntype: application/javascript\nmodule-type: saver\n\nHandles saving changes via the AndTidWiki Android app\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false, netscape: false, Components: false */\n\"use strict\";\n\nvar AndTidWiki = function(wiki) {\n};\n\nAndTidWiki.prototype.save = function(text,method,callback) {\n\t// Get the pathname of this document\n\tvar pathname = decodeURIComponent(document.location.toString().split(\"#\")[0]);\n\t// Strip the file://\n\tif(pathname.indexOf(\"file://\") === 0) {\n\t\tpathname = pathname.substr(7);\n\t}\n\t// Strip any query or location part\n\tvar p = pathname.indexOf(\"?\");\n\tif(p !== -1) {\n\t\tpathname = pathname.substr(0,p);\n\t}\n\tp = pathname.indexOf(\"#\");\n\tif(p !== -1) {\n\t\tpathname = pathname.substr(0,p);\n\t}\n\t// Save the file\n\twindow.twi.saveFile(pathname,text);\n\t// Call the callback\n\tcallback(null);\n\treturn true;\n};\n\n/*\nInformation about this saver\n*/\nAndTidWiki.prototype.info = {\n\tname: \"andtidwiki\",\n\tpriority: 1600,\n\tcapabilities: [\"save\", \"autosave\"]\n};\n\n/*\nStatic method that returns true if this saver is capable of working\n*/\nexports.canSave = function(wiki) {\n\treturn !!window.twi && !!window.twi.saveFile;\n};\n\n/*\nCreate an instance of this saver\n*/\nexports.create = function(wiki) {\n\treturn new AndTidWiki(wiki);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "saver"
},
"$:/core/modules/savers/beaker.js": {
"title": "$:/core/modules/savers/beaker.js",
"text": "/*\\\ntitle: $:/core/modules/savers/beaker.js\ntype: application/javascript\nmodule-type: saver\n\nSaves files using the Beaker browser's (https://beakerbrowser.com) Dat protocol (https://datproject.org/)\nCompatible with beaker >= V0.7.2\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nSet up the saver\n*/\nvar BeakerSaver = function(wiki) {\n\tthis.wiki = wiki;\n};\n\nBeakerSaver.prototype.save = function(text,method,callback) {\n\tvar dat = new DatArchive(\"\" + window.location),\n\t\tpathname = (\"\" + window.location.pathname).split(\"#\")[0];\n\tdat.stat(pathname).then(function(value) {\n\t\tif(value.isDirectory()) {\n\t\t\tpathname = pathname + \"/index.html\";\n\t\t}\n\t\tdat.writeFile(pathname,text,\"utf8\").then(function(value) {\n\t\t\tcallback(null);\n\t\t},function(reason) {\n\t\t\tcallback(\"Beaker Saver Write Error: \" + reason);\n\t\t});\n\t},function(reason) {\n\t\tcallback(\"Beaker Saver Stat Error: \" + reason);\n\t});\n\treturn true;\n};\n\n/*\nInformation about this saver\n*/\nBeakerSaver.prototype.info = {\n\tname: \"beaker\",\n\tpriority: 3000,\n\tcapabilities: [\"save\", \"autosave\"]\n};\n\n/*\nStatic method that returns true if this saver is capable of working\n*/\nexports.canSave = function(wiki) {\n\treturn !!window.DatArchive && location.protocol===\"dat:\";\n};\n\n/*\nCreate an instance of this saver\n*/\nexports.create = function(wiki) {\n\treturn new BeakerSaver(wiki);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "saver"
},
"$:/core/modules/savers/download.js": {
"title": "$:/core/modules/savers/download.js",
"text": "/*\\\ntitle: $:/core/modules/savers/download.js\ntype: application/javascript\nmodule-type: saver\n\nHandles saving changes via HTML5's download APIs\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nSelect the appropriate saver module and set it up\n*/\nvar DownloadSaver = function(wiki) {\n};\n\nDownloadSaver.prototype.save = function(text,method,callback,options) {\n\toptions = options || {};\n\t// Get the current filename\n\tvar filename = options.variables.filename;\n\tif(!filename) {\n\t\tvar p = document.location.pathname.lastIndexOf(\"/\");\n\t\tif(p !== -1) {\n\t\t\t// We decode the pathname because document.location is URL encoded by the browser\n\t\t\tfilename = decodeURIComponent(document.location.pathname.substr(p+1));\n\t\t}\n\t}\n\tif(!filename) {\n\t\tfilename = \"tiddlywiki.html\";\n\t}\n\t// Set up the link\n\tvar link = document.createElement(\"a\");\n\tif(Blob !== undefined) {\n\t\tvar blob = new Blob([text], {type: \"text/html\"});\n\t\tlink.setAttribute(\"href\", URL.createObjectURL(blob));\n\t} else {\n\t\tlink.setAttribute(\"href\",\"data:text/html,\" + encodeURIComponent(text));\n\t}\n\tlink.setAttribute(\"download\",filename);\n\tdocument.body.appendChild(link);\n\tlink.click();\n\tdocument.body.removeChild(link);\n\t// Callback that we succeeded\n\tcallback(null);\n\treturn true;\n};\n\n/*\nInformation about this saver\n*/\nDownloadSaver.prototype.info = {\n\tname: \"download\",\n\tpriority: 100\n};\n\nObject.defineProperty(DownloadSaver.prototype.info, \"capabilities\", {\n\tget: function() {\n\t\tvar capabilities = [\"save\", \"download\"];\n\t\tif(($tw.wiki.getTextReference(\"$:/config/DownloadSaver/AutoSave\") || \"\").toLowerCase() === \"yes\") {\n\t\t\tcapabilities.push(\"autosave\");\n\t\t}\n\t\treturn capabilities;\n\t}\n});\n\n/*\nStatic method that returns true if this saver is capable of working\n*/\nexports.canSave = function(wiki) {\n\treturn document.createElement(\"a\").download !== undefined;\n};\n\n/*\nCreate an instance of this saver\n*/\nexports.create = function(wiki) {\n\treturn new DownloadSaver(wiki);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "saver"
},
"$:/core/modules/savers/fsosaver.js": {
"title": "$:/core/modules/savers/fsosaver.js",
"text": "/*\\\ntitle: $:/core/modules/savers/fsosaver.js\ntype: application/javascript\nmodule-type: saver\n\nHandles saving changes via MS FileSystemObject ActiveXObject\n\nNote: Since TiddlyWiki's markup contains the MOTW, the FileSystemObject normally won't be available. \nHowever, if the wiki is loaded as an .HTA file (Windows HTML Applications) then the FSO can be used.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nSelect the appropriate saver module and set it up\n*/\nvar FSOSaver = function(wiki) {\n};\n\nFSOSaver.prototype.save = function(text,method,callback) {\n\t// Get the pathname of this document\n\tvar pathname = unescape(document.location.pathname);\n\t// Test for a Windows path of the form /x:\\blah...\n\tif(/^\\/[A-Z]\\:\\\\[^\\\\]+/i.test(pathname)) {\t// ie: ^/[a-z]:/[^/]+\n\t\t// Remove the leading slash\n\t\tpathname = pathname.substr(1);\n\t} else if(document.location.hostname !== \"\" && /^\\/\\\\[^\\\\]+\\\\[^\\\\]+/i.test(pathname)) {\t// test for \\\\server\\share\\blah... - ^/[^/]+/[^/]+\n\t\t// Remove the leading slash\n\t\tpathname = pathname.substr(1);\n\t\t// reconstruct UNC path\n\t\tpathname = \"\\\\\\\\\" + document.location.hostname + pathname;\n\t} else {\n\t\treturn false;\n\t}\n\t// Save the file (as UTF-16)\n\tvar fso = new ActiveXObject(\"Scripting.FileSystemObject\");\n\tvar file = fso.OpenTextFile(pathname,2,-1,-1);\n\tfile.Write(text);\n\tfile.Close();\n\t// Callback that we succeeded\n\tcallback(null);\n\treturn true;\n};\n\n/*\nInformation about this saver\n*/\nFSOSaver.prototype.info = {\n\tname: \"FSOSaver\",\n\tpriority: 120,\n\tcapabilities: [\"save\", \"autosave\"]\n};\n\n/*\nStatic method that returns true if this saver is capable of working\n*/\nexports.canSave = function(wiki) {\n\ttry {\n\t\treturn (window.location.protocol === \"file:\") && !!(new ActiveXObject(\"Scripting.FileSystemObject\"));\n\t} catch(e) { return false; }\n};\n\n/*\nCreate an instance of this saver\n*/\nexports.create = function(wiki) {\n\treturn new FSOSaver(wiki);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "saver"
},
"$:/core/modules/savers/manualdownload.js": {
"title": "$:/core/modules/savers/manualdownload.js",
"text": "/*\\\ntitle: $:/core/modules/savers/manualdownload.js\ntype: application/javascript\nmodule-type: saver\n\nHandles saving changes via HTML5's download APIs\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n// Title of the tiddler containing the download message\nvar downloadInstructionsTitle = \"$:/language/Modals/Download\";\n\n/*\nSelect the appropriate saver module and set it up\n*/\nvar ManualDownloadSaver = function(wiki) {\n};\n\nManualDownloadSaver.prototype.save = function(text,method,callback) {\n\t$tw.modal.display(downloadInstructionsTitle,{\n\t\tdownloadLink: \"data:text/html,\" + encodeURIComponent(text)\n\t});\n\t// Callback that we succeeded\n\tcallback(null);\n\treturn true;\n};\n\n/*\nInformation about this saver\n*/\nManualDownloadSaver.prototype.info = {\n\tname: \"manualdownload\",\n\tpriority: 0,\n\tcapabilities: [\"save\", \"download\"]\n};\n\n/*\nStatic method that returns true if this saver is capable of working\n*/\nexports.canSave = function(wiki) {\n\treturn true;\n};\n\n/*\nCreate an instance of this saver\n*/\nexports.create = function(wiki) {\n\treturn new ManualDownloadSaver(wiki);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "saver"
},
"$:/core/modules/savers/msdownload.js": {
"title": "$:/core/modules/savers/msdownload.js",
"text": "/*\\\ntitle: $:/core/modules/savers/msdownload.js\ntype: application/javascript\nmodule-type: saver\n\nHandles saving changes via window.navigator.msSaveBlob()\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nSelect the appropriate saver module and set it up\n*/\nvar MsDownloadSaver = function(wiki) {\n};\n\nMsDownloadSaver.prototype.save = function(text,method,callback) {\n\t// Get the current filename\n\tvar filename = \"tiddlywiki.html\",\n\t\tp = document.location.pathname.lastIndexOf(\"/\");\n\tif(p !== -1) {\n\t\tfilename = document.location.pathname.substr(p+1);\n\t}\n\t// Set up the link\n\tvar blob = new Blob([text], {type: \"text/html\"});\n\twindow.navigator.msSaveBlob(blob,filename);\n\t// Callback that we succeeded\n\tcallback(null);\n\treturn true;\n};\n\n/*\nInformation about this saver\n*/\nMsDownloadSaver.prototype.info = {\n\tname: \"msdownload\",\n\tpriority: 110,\n\tcapabilities: [\"save\", \"download\"]\n};\n\n/*\nStatic method that returns true if this saver is capable of working\n*/\nexports.canSave = function(wiki) {\n\treturn !!window.navigator.msSaveBlob;\n};\n\n/*\nCreate an instance of this saver\n*/\nexports.create = function(wiki) {\n\treturn new MsDownloadSaver(wiki);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "saver"
},
"$:/core/modules/savers/put.js": {
"title": "$:/core/modules/savers/put.js",
"text": "/*\\\ntitle: $:/core/modules/savers/put.js\ntype: application/javascript\nmodule-type: saver\n\nSaves wiki by performing a PUT request to the server\n\nWorks with any server which accepts a PUT request\nto the current URL, such as a WebDAV server.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nRetrieve ETag if available\n*/\nvar retrieveETag = function(self) {\n\tvar headers = {\n\t\tAccept: \"*/*;charset=UTF-8\"\n\t};\n\t$tw.utils.httpRequest({\n\t\turl: self.uri(),\n\t\ttype: \"HEAD\",\n\t\theaders: headers,\n\t\tcallback: function(err,data,xhr) {\n\t\t\tif(err) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tvar etag = xhr.getResponseHeader(\"ETag\");\n\t\t\tif(!etag) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tself.etag = etag.replace(/^W\\//,\"\");\n\t\t}\n\t});\n};\n\n\n/*\nSelect the appropriate saver module and set it up\n*/\nvar PutSaver = function(wiki) {\n\tthis.wiki = wiki;\n\tvar self = this;\n\tvar uri = this.uri();\n\t// Async server probe. Until probe finishes, save will fail fast\n\t// See also https://github.com/Jermolene/TiddlyWiki5/issues/2276\n\t$tw.utils.httpRequest({\n\t\turl: uri,\n\t\ttype: \"OPTIONS\",\n\t\tcallback: function(err,data,xhr) {\n\t\t\t// Check DAV header http://www.webdav.org/specs/rfc2518.html#rfc.section.9.1\n\t\t\tif(!err) {\n\t\t\t\tself.serverAcceptsPuts = xhr.status === 200 && !!xhr.getResponseHeader(\"dav\");\n\t\t\t}\n\t\t}\n\t});\n\tretrieveETag(this);\n};\n\nPutSaver.prototype.uri = function() {\n\treturn document.location.toString().split(\"#\")[0];\n};\n\n// TODO: in case of edit conflict\n// Prompt: Do you want to save over this? Y/N\n// Merging would be ideal, and may be possible using future generic merge flow\nPutSaver.prototype.save = function(text,method,callback) {\n\tif(!this.serverAcceptsPuts) {\n\t\treturn false;\n\t}\n\tvar self = this;\n\tvar headers = {\n\t\t\"Content-Type\": \"text/html;charset=UTF-8\"\n\t};\n\tif(this.etag) {\n\t\theaders[\"If-Match\"] = this.etag;\n\t}\n\t$tw.utils.httpRequest({\n\t\turl: this.uri(),\n\t\ttype: \"PUT\",\n\t\theaders: headers,\n\t\tdata: text,\n\t\tcallback: function(err,data,xhr) {\n\t\t\tif(err) {\n\t\t\t\t// response is textual: \"XMLHttpRequest error code: 412\"\n\t\t\t\tvar status = Number(err.substring(err.indexOf(':') + 2, err.length))\n\t\t\t\tif(status === 412) { // edit conflict\n\t\t\t\t\tvar message = $tw.language.getString(\"Error/EditConflict\");\n\t\t\t\t\tcallback(message);\n\t\t\t\t} else {\n\t\t\t\t\tcallback(err); // fail\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tself.etag = xhr.getResponseHeader(\"ETag\");\n\t\t\t\tif(self.etag == null) {\n\t\t\t\t\tretrieveETag(self);\n\t\t\t\t}\n\t\t\t\tcallback(null); // success\n\t\t\t}\n\t\t}\n\t});\n\treturn true;\n};\n\n/*\nInformation about this saver\n*/\nPutSaver.prototype.info = {\n\tname: \"put\",\n\tpriority: 2000,\n\tcapabilities: [\"save\",\"autosave\"]\n};\n\n/*\nStatic method that returns true if this saver is capable of working\n*/\nexports.canSave = function(wiki) {\n\treturn /^https?:/.test(location.protocol);\n};\n\n/*\nCreate an instance of this saver\n*/\nexports.create = function(wiki) {\n\treturn new PutSaver(wiki);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "saver"
},
"$:/core/modules/savers/tiddlyfox.js": {
"title": "$:/core/modules/savers/tiddlyfox.js",
"text": "/*\\\ntitle: $:/core/modules/savers/tiddlyfox.js\ntype: application/javascript\nmodule-type: saver\n\nHandles saving changes via the TiddlyFox file extension\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false, netscape: false, Components: false */\n\"use strict\";\n\nvar TiddlyFoxSaver = function(wiki) {\n};\n\nTiddlyFoxSaver.prototype.save = function(text,method,callback) {\n\tvar messageBox = document.getElementById(\"tiddlyfox-message-box\");\n\tif(messageBox) {\n\t\t// Get the pathname of this document\n\t\tvar pathname = document.location.toString().split(\"#\")[0];\n\t\t// Replace file://localhost/ with file:///\n\t\tif(pathname.indexOf(\"file://localhost/\") === 0) {\n\t\t\tpathname = \"file://\" + pathname.substr(16);\n\t\t}\n\t\t// Windows path file:///x:/blah/blah --> x:\\blah\\blah\n\t\tif(/^file\\:\\/\\/\\/[A-Z]\\:\\//i.test(pathname)) {\n\t\t\t// Remove the leading slash and convert slashes to backslashes\n\t\t\tpathname = pathname.substr(8).replace(/\\//g,\"\\\\\");\n\t\t// Firefox Windows network path file://///server/share/blah/blah --> //server/share/blah/blah\n\t\t} else if(pathname.indexOf(\"file://///\") === 0) {\n\t\t\tpathname = \"\\\\\\\\\" + unescape(pathname.substr(10)).replace(/\\//g,\"\\\\\");\n\t\t// Mac/Unix local path file:///path/path --> /path/path\n\t\t} else if(pathname.indexOf(\"file:///\") === 0) {\n\t\t\tpathname = unescape(pathname.substr(7));\n\t\t// Mac/Unix local path file:/path/path --> /path/path\n\t\t} else if(pathname.indexOf(\"file:/\") === 0) {\n\t\t\tpathname = unescape(pathname.substr(5));\n\t\t// Otherwise Windows networth path file://server/share/path/path --> \\\\server\\share\\path\\path\n\t\t} else {\n\t\t\tpathname = \"\\\\\\\\\" + unescape(pathname.substr(7)).replace(new RegExp(\"/\",\"g\"),\"\\\\\");\n\t\t}\n\t\t// Create the message element and put it in the message box\n\t\tvar message = document.createElement(\"div\");\n\t\tmessage.setAttribute(\"data-tiddlyfox-path\",decodeURIComponent(pathname));\n\t\tmessage.setAttribute(\"data-tiddlyfox-content\",text);\n\t\tmessageBox.appendChild(message);\n\t\t// Add an event handler for when the file has been saved\n\t\tmessage.addEventListener(\"tiddlyfox-have-saved-file\",function(event) {\n\t\t\tcallback(null);\n\t\t}, false);\n\t\t// Create and dispatch the custom event to the extension\n\t\tvar event = document.createEvent(\"Events\");\n\t\tevent.initEvent(\"tiddlyfox-save-file\",true,false);\n\t\tmessage.dispatchEvent(event);\n\t\treturn true;\n\t} else {\n\t\treturn false;\n\t}\n};\n\n/*\nInformation about this saver\n*/\nTiddlyFoxSaver.prototype.info = {\n\tname: \"tiddlyfox\",\n\tpriority: 1500,\n\tcapabilities: [\"save\", \"autosave\"]\n};\n\n/*\nStatic method that returns true if this saver is capable of working\n*/\nexports.canSave = function(wiki) {\n\treturn true;\n};\n\n/*\nCreate an instance of this saver\n*/\nexports.create = function(wiki) {\n\treturn new TiddlyFoxSaver(wiki);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "saver"
},
"$:/core/modules/savers/tiddlyie.js": {
"title": "$:/core/modules/savers/tiddlyie.js",
"text": "/*\\\ntitle: $:/core/modules/savers/tiddlyie.js\ntype: application/javascript\nmodule-type: saver\n\nHandles saving changes via Internet Explorer BHO extenion (TiddlyIE)\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nSelect the appropriate saver module and set it up\n*/\nvar TiddlyIESaver = function(wiki) {\n};\n\nTiddlyIESaver.prototype.save = function(text,method,callback) {\n\t// Check existence of TiddlyIE BHO extension (note: only works after document is complete)\n\tif(typeof(window.TiddlyIE) != \"undefined\") {\n\t\t// Get the pathname of this document\n\t\tvar pathname = unescape(document.location.pathname);\n\t\t// Test for a Windows path of the form /x:/blah...\n\t\tif(/^\\/[A-Z]\\:\\/[^\\/]+/i.test(pathname)) {\t// ie: ^/[a-z]:/[^/]+ (is this better?: ^/[a-z]:/[^/]+(/[^/]+)*\\.[^/]+ )\n\t\t\t// Remove the leading slash\n\t\t\tpathname = pathname.substr(1);\n\t\t\t// Convert slashes to backslashes\n\t\t\tpathname = pathname.replace(/\\//g,\"\\\\\");\n\t\t} else if(document.hostname !== \"\" && /^\\/[^\\/]+\\/[^\\/]+/i.test(pathname)) {\t// test for \\\\server\\share\\blah... - ^/[^/]+/[^/]+\n\t\t\t// Convert slashes to backslashes\n\t\t\tpathname = pathname.replace(/\\//g,\"\\\\\");\n\t\t\t// reconstruct UNC path\n\t\t\tpathname = \"\\\\\\\\\" + document.location.hostname + pathname;\n\t\t} else return false;\n\t\t// Prompt the user to save the file\n\t\twindow.TiddlyIE.save(pathname, text);\n\t\t// Callback that we succeeded\n\t\tcallback(null);\n\t\treturn true;\n\t} else {\n\t\treturn false;\n\t}\n};\n\n/*\nInformation about this saver\n*/\nTiddlyIESaver.prototype.info = {\n\tname: \"tiddlyiesaver\",\n\tpriority: 1500,\n\tcapabilities: [\"save\"]\n};\n\n/*\nStatic method that returns true if this saver is capable of working\n*/\nexports.canSave = function(wiki) {\n\treturn (window.location.protocol === \"file:\");\n};\n\n/*\nCreate an instance of this saver\n*/\nexports.create = function(wiki) {\n\treturn new TiddlyIESaver(wiki);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "saver"
},
"$:/core/modules/savers/twedit.js": {
"title": "$:/core/modules/savers/twedit.js",
"text": "/*\\\ntitle: $:/core/modules/savers/twedit.js\ntype: application/javascript\nmodule-type: saver\n\nHandles saving changes via the TWEdit iOS app\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false, netscape: false, Components: false */\n\"use strict\";\n\nvar TWEditSaver = function(wiki) {\n};\n\nTWEditSaver.prototype.save = function(text,method,callback) {\n\t// Bail if we're not running under TWEdit\n\tif(typeof DeviceInfo !== \"object\") {\n\t\treturn false;\n\t}\n\t// Get the pathname of this document\n\tvar pathname = decodeURIComponent(document.location.pathname);\n\t// Strip any query or location part\n\tvar p = pathname.indexOf(\"?\");\n\tif(p !== -1) {\n\t\tpathname = pathname.substr(0,p);\n\t}\n\tp = pathname.indexOf(\"#\");\n\tif(p !== -1) {\n\t\tpathname = pathname.substr(0,p);\n\t}\n\t// Remove the leading \"/Documents\" from path\n\tvar prefix = \"/Documents\";\n\tif(pathname.indexOf(prefix) === 0) {\n\t\tpathname = pathname.substr(prefix.length);\n\t}\n\t// Error handler\n\tvar errorHandler = function(event) {\n\t\t// Error\n\t\tcallback($tw.language.getString(\"Error/SavingToTWEdit\") + \": \" + event.target.error.code);\n\t};\n\t// Get the file system\n\twindow.requestFileSystem(LocalFileSystem.PERSISTENT,0,function(fileSystem) {\n\t\t// Now we've got the filesystem, get the fileEntry\n\t\tfileSystem.root.getFile(pathname, {create: true}, function(fileEntry) {\n\t\t\t// Now we've got the fileEntry, create the writer\n\t\t\tfileEntry.createWriter(function(writer) {\n\t\t\t\twriter.onerror = errorHandler;\n\t\t\t\twriter.onwrite = function() {\n\t\t\t\t\tcallback(null);\n\t\t\t\t};\n\t\t\t\twriter.position = 0;\n\t\t\t\twriter.write(text);\n\t\t\t},errorHandler);\n\t\t}, errorHandler);\n\t}, errorHandler);\n\treturn true;\n};\n\n/*\nInformation about this saver\n*/\nTWEditSaver.prototype.info = {\n\tname: \"twedit\",\n\tpriority: 1600,\n\tcapabilities: [\"save\", \"autosave\"]\n};\n\n/*\nStatic method that returns true if this saver is capable of working\n*/\nexports.canSave = function(wiki) {\n\treturn true;\n};\n\n/*\nCreate an instance of this saver\n*/\nexports.create = function(wiki) {\n\treturn new TWEditSaver(wiki);\n};\n\n/////////////////////////// Hack\n// HACK: This ensures that TWEdit recognises us as a TiddlyWiki document\nif($tw.browser) {\n\twindow.version = {title: \"TiddlyWiki\"};\n}\n\n})();\n",
"type": "application/javascript",
"module-type": "saver"
},
"$:/core/modules/savers/upload.js": {
"title": "$:/core/modules/savers/upload.js",
"text": "/*\\\ntitle: $:/core/modules/savers/upload.js\ntype: application/javascript\nmodule-type: saver\n\nHandles saving changes via upload to a server.\n\nDesigned to be compatible with BidiX's UploadPlugin at http://tiddlywiki.bidix.info/#UploadPlugin\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nSelect the appropriate saver module and set it up\n*/\nvar UploadSaver = function(wiki) {\n\tthis.wiki = wiki;\n};\n\nUploadSaver.prototype.save = function(text,method,callback) {\n\t// Get the various parameters we need\n\tvar backupDir = this.wiki.getTextReference(\"$:/UploadBackupDir\") || \".\",\n\t\tusername = this.wiki.getTextReference(\"$:/UploadName\"),\n\t\tpassword = $tw.utils.getPassword(\"upload\"),\n\t\tuploadDir = this.wiki.getTextReference(\"$:/UploadDir\") || \".\",\n\t\tuploadFilename = this.wiki.getTextReference(\"$:/UploadFilename\") || \"index.html\",\n\t\turl = this.wiki.getTextReference(\"$:/UploadURL\");\n\t// Bail out if we don't have the bits we need\n\tif(!username || username.toString().trim() === \"\" || !password || password.toString().trim() === \"\") {\n\t\treturn false;\n\t}\n\t// Construct the url if not provided\n\tif(!url) {\n\t\turl = \"http://\" + username + \".tiddlyspot.com/store.cgi\";\n\t}\n\t// Assemble the header\n\tvar boundary = \"---------------------------\" + \"AaB03x\";\t\n\tvar uploadFormName = \"UploadPlugin\";\n\tvar head = [];\n\thead.push(\"--\" + boundary + \"\\r\\nContent-disposition: form-data; name=\\\"UploadPlugin\\\"\\r\\n\");\n\thead.push(\"backupDir=\" + backupDir + \";user=\" + username + \";password=\" + password + \";uploaddir=\" + uploadDir + \";;\"); \n\thead.push(\"\\r\\n\" + \"--\" + boundary);\n\thead.push(\"Content-disposition: form-data; name=\\\"userfile\\\"; filename=\\\"\" + uploadFilename + \"\\\"\");\n\thead.push(\"Content-Type: text/html;charset=UTF-8\");\n\thead.push(\"Content-Length: \" + text.length + \"\\r\\n\");\n\thead.push(\"\");\n\t// Assemble the tail and the data itself\n\tvar tail = \"\\r\\n--\" + boundary + \"--\\r\\n\",\n\t\tdata = head.join(\"\\r\\n\") + text + tail;\n\t// Do the HTTP post\n\tvar http = new XMLHttpRequest();\n\thttp.open(\"POST\",url,true,username,password);\n\thttp.setRequestHeader(\"Content-Type\",\"multipart/form-data; charset=UTF-8; boundary=\" + boundary);\n\thttp.onreadystatechange = function() {\n\t\tif(http.readyState == 4 && http.status == 200) {\n\t\t\tif(http.responseText.substr(0,4) === \"0 - \") {\n\t\t\t\tcallback(null);\n\t\t\t} else {\n\t\t\t\tcallback(http.responseText);\n\t\t\t}\n\t\t}\n\t};\n\ttry {\n\t\thttp.send(data);\n\t} catch(ex) {\n\t\treturn callback($tw.language.getString(\"Error/Caption\") + \":\" + ex);\n\t}\n\t$tw.notifier.display(\"$:/language/Notifications/Save/Starting\");\n\treturn true;\n};\n\n/*\nInformation about this saver\n*/\nUploadSaver.prototype.info = {\n\tname: \"upload\",\n\tpriority: 2000,\n\tcapabilities: [\"save\", \"autosave\"]\n};\n\n/*\nStatic method that returns true if this saver is capable of working\n*/\nexports.canSave = function(wiki) {\n\treturn true;\n};\n\n/*\nCreate an instance of this saver\n*/\nexports.create = function(wiki) {\n\treturn new UploadSaver(wiki);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "saver"
},
"$:/core/modules/server/authenticators/basic.js": {
"title": "$:/core/modules/server/authenticators/basic.js",
"text": "/*\\\ntitle: $:/core/modules/server/authenticators/basic.js\ntype: application/javascript\nmodule-type: authenticator\n\nAuthenticator for WWW basic authentication\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nif($tw.node) {\n\tvar util = require(\"util\"),\n\t\tfs = require(\"fs\"),\n\t\turl = require(\"url\"),\n\t\tpath = require(\"path\");\n}\n\nfunction BasicAuthenticator(server) {\n\tthis.server = server;\n\tthis.credentialsData = [];\n}\n\n/*\nReturns true if the authenticator is active, false if it is inactive, or a string if there is an error\n*/\nBasicAuthenticator.prototype.init = function() {\n\t// Read the credentials data\n\tthis.credentialsFilepath = this.server.get(\"credentials\");\n\tif(this.credentialsFilepath) {\n\t\tvar resolveCredentialsFilepath = path.resolve($tw.boot.wikiPath,this.credentialsFilepath);\n\t\tif(fs.existsSync(resolveCredentialsFilepath) && !fs.statSync(resolveCredentialsFilepath).isDirectory()) {\n\t\t\tvar credentialsText = fs.readFileSync(resolveCredentialsFilepath,\"utf8\"),\n\t\t\t\tcredentialsData = $tw.utils.parseCsvStringWithHeader(credentialsText);\n\t\t\tif(typeof credentialsData === \"string\") {\n\t\t\t\treturn \"Error: \" + credentialsData + \" reading credentials from '\" + resolveCredentialsFilepath + \"'\";\n\t\t\t} else {\n\t\t\t\tthis.credentialsData = credentialsData;\n\t\t\t}\n\t\t} else {\n\t\t\treturn \"Error: Unable to load user credentials from '\" + credentialsFilepath + \"'\";\n\t\t}\n\t}\n\t// Add the hardcoded username and password if specified\n\tif(this.server.get(\"username\") && this.server.get(\"password\")) {\n\t\tthis.credentialsData = this.credentialsData || [];\n\t\tthis.credentialsData.push({\n\t\t\tusername: this.server.get(\"username\"),\n\t\t\tpassword: this.server.get(\"password\")\n\t\t});\n\t}\n\treturn this.credentialsData.length > 0;\n};\n\n/*\nReturns true if the request is authenticated and assigns the \"authenticatedUsername\" state variable.\nReturns false if the request couldn't be authenticated having sent an appropriate response to the browser\n*/\nBasicAuthenticator.prototype.authenticateRequest = function(request,response,state) {\n\t// Extract the incoming username and password from the request\n\tvar header = request.headers.authorization || \"\";\n\tif(!header && state.allowAnon) {\n\t\t// If there's no header and anonymous access is allowed then we don't set authenticatedUsername\n\t\treturn true;\n\t}\n\tvar token = header.split(/\\s+/).pop() || \"\",\n\t\tauth = $tw.utils.base64Decode(token),\n\t\tparts = auth.split(/:/),\n\t\tincomingUsername = parts[0],\n\t\tincomingPassword = parts[1];\n\t// Check that at least one of the credentials matches\n\tvar matchingCredentials = this.credentialsData.find(function(credential) {\n\t\treturn credential.username === incomingUsername && credential.password === incomingPassword;\n\t});\n\tif(matchingCredentials) {\n\t\t// If so, add the authenticated username to the request state\n\t\tstate.authenticatedUsername = incomingUsername;\n\t\treturn true;\n\t} else {\n\t\t// If not, return an authentication challenge\n\t\tresponse.writeHead(401,\"Authentication required\",{\n\t\t\t\"WWW-Authenticate\": 'Basic realm=\"Please provide your username and password to login to ' + state.server.servername + '\"'\n\t\t});\n\t\tresponse.end();\n\t\treturn false;\n\t}\n};\n\nexports.AuthenticatorClass = BasicAuthenticator;\n\n})();\n",
"type": "application/javascript",
"module-type": "authenticator"
},
"$:/core/modules/server/authenticators/header.js": {
"title": "$:/core/modules/server/authenticators/header.js",
"text": "/*\\\ntitle: $:/core/modules/server/authenticators/header.js\ntype: application/javascript\nmodule-type: authenticator\n\nAuthenticator for trusted header authentication\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nfunction HeaderAuthenticator(server) {\n\tthis.server = server;\n\tthis.header = server.get(\"authenticated-user-header\");\n}\n\n/*\nReturns true if the authenticator is active, false if it is inactive, or a string if there is an error\n*/\nHeaderAuthenticator.prototype.init = function() {\n\treturn !!this.header;\n};\n\n/*\nReturns true if the request is authenticated and assigns the \"authenticatedUsername\" state variable.\nReturns false if the request couldn't be authenticated having sent an appropriate response to the browser\n*/\nHeaderAuthenticator.prototype.authenticateRequest = function(request,response,state) {\n\t// Otherwise, authenticate as the username in the specified header\n\tvar username = request.headers[this.header];\n\tif(!username && !state.allowAnon) {\n\t\tresponse.writeHead(401,\"Authorization header required to login to '\" + state.server.servername + \"'\");\n\t\tresponse.end();\n\t\treturn false;\n\t} else {\n\t\t// authenticatedUsername will be undefined for anonymous users\n\t\tstate.authenticatedUsername = username;\n\t\treturn true;\n\t}\n};\n\nexports.AuthenticatorClass = HeaderAuthenticator;\n\n})();\n",
"type": "application/javascript",
"module-type": "authenticator"
},
"$:/core/modules/server/routes/delete-tiddler.js": {
"title": "$:/core/modules/server/routes/delete-tiddler.js",
"text": "/*\\\ntitle: $:/core/modules/server/routes/delete-tiddler.js\ntype: application/javascript\nmodule-type: route\n\nDELETE /recipes/default/tiddlers/:title\n\n\\*/\n(function() {\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.method = \"DELETE\";\n\nexports.path = /^\\/bags\\/default\\/tiddlers\\/(.+)$/;\n\nexports.handler = function(request,response,state) {\n\tvar title = decodeURIComponent(state.params[0]);\n\tstate.wiki.deleteTiddler(title);\n\tresponse.writeHead(204, \"OK\", {\n\t\t\"Content-Type\": \"text/plain\"\n\t});\n\tresponse.end();\n};\n\n}());\n",
"type": "application/javascript",
"module-type": "route"
},
"$:/core/modules/server/routes/get-favicon.js": {
"title": "$:/core/modules/server/routes/get-favicon.js",
"text": "/*\\\ntitle: $:/core/modules/server/routes/get-favicon.js\ntype: application/javascript\nmodule-type: route\n\nGET /favicon.ico\n\n\\*/\n(function() {\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.method = \"GET\";\n\nexports.path = /^\\/favicon.ico$/;\n\nexports.handler = function(request,response,state) {\n\tresponse.writeHead(200, {\"Content-Type\": \"image/x-icon\"});\n\tvar buffer = state.wiki.getTiddlerText(\"$:/favicon.ico\",\"\");\n\tresponse.end(buffer,\"base64\");\n};\n\n}());\n",
"type": "application/javascript",
"module-type": "route"
},
"$:/core/modules/server/routes/get-file.js": {
"title": "$:/core/modules/server/routes/get-file.js",
"text": "/*\\\ntitle: $:/core/modules/server/routes/get-file.js\ntype: application/javascript\nmodule-type: route\n\nGET /files/:filepath\n\n\\*/\n(function() {\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.method = \"GET\";\n\nexports.path = /^\\/files\\/(.+)$/;\n\nexports.handler = function(request,response,state) {\n\tvar path = require(\"path\"),\n\t\tfs = require(\"fs\"),\n\t\tutil = require(\"util\");\n\tvar filename = path.resolve($tw.boot.wikiPath,\"files\",decodeURIComponent(state.params[0])),\n\t\textension = path.extname(filename);\n\tfs.readFile(filename,function(err,content) {\n\t\tvar status,content,type = \"text/plain\";\n\t\tif(err) {\n\t\t\tif(err.code === \"ENOENT\") {\n\t\t\t\tstatus = 404;\n\t\t\t\tcontent = \"File '\" + filename + \"' not found\";\n\t\t\t} else if(err.code === \"EACCES\") {\n\t\t\t\tstatus = 403;\n\t\t\t\tcontent = \"You do not have permission to access the file '\" + filename + \"'\";\n\t\t\t} else {\n\t\t\t\tstatus = 500;\n\t\t\t\tcontent = err.toString();\n\t\t\t}\n\t\t} else {\n\t\t\tstatus = 200;\n\t\t\tcontent = content;\n\t\t\ttype = ($tw.config.fileExtensionInfo[extension] ? $tw.config.fileExtensionInfo[extension].type : \"application/octet-stream\");\n\t\t}\n\t\tresponse.writeHead(status,{\n\t\t\t\"Content-Type\": type\n\t\t});\n\t\tresponse.end(content);\n\t});\n};\n\n}());\n",
"type": "application/javascript",
"module-type": "route"
},
"$:/core/modules/server/routes/get-index.js": {
"title": "$:/core/modules/server/routes/get-index.js",
"text": "/*\\\ntitle: $:/core/modules/server/routes/get-index.js\ntype: application/javascript\nmodule-type: route\n\nGET /\n\n\\*/\n(function() {\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.method = \"GET\";\n\nexports.path = /^\\/$/;\n\nexports.handler = function(request,response,state) {\n\tresponse.writeHead(200, {\"Content-Type\": state.server.get(\"root-serve-type\")});\n\tvar text = state.wiki.renderTiddler(state.server.get(\"root-render-type\"),state.server.get(\"root-tiddler\"));\n\tresponse.end(text,\"utf8\");\n};\n\n}());\n",
"type": "application/javascript",
"module-type": "route"
},
"$:/core/modules/server/routes/get-login-basic.js": {
"title": "$:/core/modules/server/routes/get-login-basic.js",
"text": "/*\\\ntitle: $:/core/modules/server/routes/get-login-basic.js\ntype: application/javascript\nmodule-type: route\n\nGET /login-basic -- force a Basic Authentication challenge\n\n\\*/\n(function() {\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.method = \"GET\";\n\nexports.path = /^\\/login-basic$/;\n\nexports.handler = function(request,response,state) {\n\tif(!state.authenticatedUsername) {\n\t\t// Challenge if there's no username\n\t\tresponse.writeHead(401,{\n\t\t\t\"WWW-Authenticate\": 'Basic realm=\"Please provide your username and password to login to ' + state.server.servername + '\"'\n\t\t});\n\t\tresponse.end();\t\t\n\t} else {\n\t\t// Redirect to the root wiki if login worked\n\t\tresponse.writeHead(302,{\n\t\t\tLocation: \"/\"\n\t\t});\n\t\tresponse.end();\n\t}\n};\n\n}());\n",
"type": "application/javascript",
"module-type": "route"
},
"$:/core/modules/server/routes/get-status.js": {
"title": "$:/core/modules/server/routes/get-status.js",
"text": "/*\\\ntitle: $:/core/modules/server/routes/get-status.js\ntype: application/javascript\nmodule-type: route\n\nGET /status\n\n\\*/\n(function() {\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.method = \"GET\";\n\nexports.path = /^\\/status$/;\n\nexports.handler = function(request,response,state) {\n\tresponse.writeHead(200, {\"Content-Type\": \"application/json\"});\n\tvar text = JSON.stringify({\n\t\tusername: state.authenticatedUsername || state.server.get(\"anon-username\") || \"\",\n\t\tanonymous: !state.authenticatedUsername,\n\t\tread_only: !state.server.isAuthorized(\"writers\",state.authenticatedUsername),\n\t\tspace: {\n\t\t\trecipe: \"default\"\n\t\t},\n\t\ttiddlywiki_version: $tw.version\n\t});\n\tresponse.end(text,\"utf8\");\n};\n\n}());\n",
"type": "application/javascript",
"module-type": "route"
},
"$:/core/modules/server/routes/get-tiddler-html.js": {
"title": "$:/core/modules/server/routes/get-tiddler-html.js",
"text": "/*\\\ntitle: $:/core/modules/server/routes/get-tiddler-html.js\ntype: application/javascript\nmodule-type: route\n\nGET /:title\n\n\\*/\n(function() {\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.method = \"GET\";\n\nexports.path = /^\\/([^\\/]+)$/;\n\nexports.handler = function(request,response,state) {\n\tvar title = decodeURIComponent(state.params[0]),\n\t\ttiddler = state.wiki.getTiddler(title);\n\tif(tiddler) {\n\t\tvar renderType = tiddler.getFieldString(\"_render_type\"),\n\t\t\trenderTemplate = tiddler.getFieldString(\"_render_template\");\n\t\t// Tiddler fields '_render_type' and '_render_template' overwrite\n\t\t// system wide settings for render type and template\n\t\tif(state.wiki.isSystemTiddler(title)) {\n\t\t\trenderType = renderType || state.server.get(\"system-tiddler-render-type\");\n\t\t\trenderTemplate = renderTemplate || state.server.get(\"system-tiddler-render-template\");\n\t\t} else {\n\t\t\trenderType = renderType || state.server.get(\"tiddler-render-type\");\n\t\t\trenderTemplate = renderTemplate || state.server.get(\"tiddler-render-template\");\n\t\t}\n\t\tvar text = state.wiki.renderTiddler(renderType,renderTemplate,{parseAsInline: true, variables: {currentTiddler: title}});\n\t\t// Naughty not to set a content-type, but it's the easiest way to ensure the browser will see HTML pages as HTML, and accept plain text tiddlers as CSS or JS\n\t\tresponse.writeHead(200);\n\t\tresponse.end(text,\"utf8\");\n\t} else {\n\t\tresponse.writeHead(404);\n\t\tresponse.end();\n\t}\n};\n\n}());\n",
"type": "application/javascript",
"module-type": "route"
},
"$:/core/modules/server/routes/get-tiddler.js": {
"title": "$:/core/modules/server/routes/get-tiddler.js",
"text": "/*\\\ntitle: $:/core/modules/server/routes/get-tiddler.js\ntype: application/javascript\nmodule-type: route\n\nGET /recipes/default/tiddlers/:title\n\n\\*/\n(function() {\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.method = \"GET\";\n\nexports.path = /^\\/recipes\\/default\\/tiddlers\\/(.+)$/;\n\nexports.handler = function(request,response,state) {\n\tvar title = decodeURIComponent(state.params[0]),\n\t\ttiddler = state.wiki.getTiddler(title),\n\t\ttiddlerFields = {},\n\t\tknownFields = [\n\t\t\t\"bag\", \"created\", \"creator\", \"modified\", \"modifier\", \"permissions\", \"recipe\", \"revision\", \"tags\", \"text\", \"title\", \"type\", \"uri\"\n\t\t];\n\tif(tiddler) {\n\t\t$tw.utils.each(tiddler.fields,function(field,name) {\n\t\t\tvar value = tiddler.getFieldString(name);\n\t\t\tif(knownFields.indexOf(name) !== -1) {\n\t\t\t\ttiddlerFields[name] = value;\n\t\t\t} else {\n\t\t\t\ttiddlerFields.fields = tiddlerFields.fields || {};\n\t\t\t\ttiddlerFields.fields[name] = value;\n\t\t\t}\n\t\t});\n\t\ttiddlerFields.revision = state.wiki.getChangeCount(title);\n\t\ttiddlerFields.type = tiddlerFields.type || \"text/vnd.tiddlywiki\";\n\t\tresponse.writeHead(200, {\"Content-Type\": \"application/json\"});\n\t\tresponse.end(JSON.stringify(tiddlerFields),\"utf8\");\n\t} else {\n\t\tresponse.writeHead(404);\n\t\tresponse.end();\n\t}\n};\n\n}());\n",
"type": "application/javascript",
"module-type": "route"
},
"$:/core/modules/server/routes/get-tiddlers-json.js": {
"title": "$:/core/modules/server/routes/get-tiddlers-json.js",
"text": "/*\\\ntitle: $:/core/modules/server/routes/get-tiddlers-json.js\ntype: application/javascript\nmodule-type: route\n\nGET /recipes/default/tiddlers/tiddlers.json\n\n\\*/\n(function() {\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.method = \"GET\";\n\nexports.path = /^\\/recipes\\/default\\/tiddlers.json$/;\n\nexports.handler = function(request,response,state) {\n\tresponse.writeHead(200, {\"Content-Type\": \"application/json\"});\n\tvar tiddlers = [];\n\tstate.wiki.forEachTiddler({sortField: \"title\"},function(title,tiddler) {\n\t\tvar tiddlerFields = {};\n\t\t$tw.utils.each(tiddler.fields,function(field,name) {\n\t\t\tif(name !== \"text\") {\n\t\t\t\ttiddlerFields[name] = tiddler.getFieldString(name);\n\t\t\t}\n\t\t});\n\t\ttiddlerFields.revision = state.wiki.getChangeCount(title);\n\t\ttiddlerFields.type = tiddlerFields.type || \"text/vnd.tiddlywiki\";\n\t\ttiddlers.push(tiddlerFields);\n\t});\n\tvar text = JSON.stringify(tiddlers);\n\tresponse.end(text,\"utf8\");\n};\n\n}());\n",
"type": "application/javascript",
"module-type": "route"
},
"$:/core/modules/server/routes/put-tiddler.js": {
"title": "$:/core/modules/server/routes/put-tiddler.js",
"text": "/*\\\ntitle: $:/core/modules/server/routes/put-tiddler.js\ntype: application/javascript\nmodule-type: route\n\nPUT /recipes/default/tiddlers/:title\n\n\\*/\n(function() {\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.method = \"PUT\";\n\nexports.path = /^\\/recipes\\/default\\/tiddlers\\/(.+)$/;\n\nexports.handler = function(request,response,state) {\n\tvar title = decodeURIComponent(state.params[0]),\n\tfields = JSON.parse(state.data);\n\t// Pull up any subfields in the `fields` object\n\tif(fields.fields) {\n\t\t$tw.utils.each(fields.fields,function(field,name) {\n\t\t\tfields[name] = field;\n\t\t});\n\t\tdelete fields.fields;\n\t}\n\t// Remove any revision field\n\tif(fields.revision) {\n\t\tdelete fields.revision;\n\t}\n\tstate.wiki.addTiddler(new $tw.Tiddler(state.wiki.getCreationFields(),fields,{title: title},state.wiki.getModificationFields()));\n\tvar changeCount = state.wiki.getChangeCount(title).toString();\n\tresponse.writeHead(204, \"OK\",{\n\t\tEtag: \"\\\"default/\" + encodeURIComponent(title) + \"/\" + changeCount + \":\\\"\",\n\t\t\"Content-Type\": \"text/plain\"\n\t});\n\tresponse.end();\n};\n\n}());\n",
"type": "application/javascript",
"module-type": "route"
},
"$:/core/modules/server/server.js": {
"title": "$:/core/modules/server/server.js",
"text": "/*\\\ntitle: $:/core/modules/server/server.js\ntype: application/javascript\nmodule-type: library\n\nServe tiddlers over http\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nif($tw.node) {\n\tvar util = require(\"util\"),\n\t\tfs = require(\"fs\"),\n\t\turl = require(\"url\"),\n\t\tpath = require(\"path\");\n}\n\n/*\nA simple HTTP server with regexp-based routes\noptions: variables - optional hashmap of variables to set (a misnomer - they are really constant parameters)\n\t\t routes - optional array of routes to use\n\t\t wiki - reference to wiki object\n*/\nfunction Server(options) {\n\tvar self = this;\n\tthis.routes = options.routes || [];\n\tthis.authenticators = options.authenticators || [];\n\tthis.wiki = options.wiki;\n\tthis.servername = $tw.utils.transliterateToSafeASCII(this.wiki.getTiddlerText(\"$:/SiteTitle\") || \"TiddlyWiki5\");\n\t// Initialise the variables\n\tthis.variables = $tw.utils.extend({},this.defaultVariables);\n\tif(options.variables) {\n\t\tfor(var variable in options.variables) {\n\t\t\tif(options.variables[variable]) {\n\t\t\t\tthis.variables[variable] = options.variables[variable];\n\t\t\t}\n\t\t}\t\t\n\t}\n\t$tw.utils.extend({},this.defaultVariables,options.variables);\n\t// Initialise CSRF\n\tthis.csrfDisable = this.get(\"csrf-disable\") === \"yes\";\n\t// Initialise authorization\n\tvar authorizedUserName = (this.get(\"username\") && this.get(\"password\")) ? this.get(\"username\") : \"(anon)\";\n\tthis.authorizationPrincipals = {\n\t\treaders: (this.get(\"readers\") || authorizedUserName).split(\",\").map($tw.utils.trim),\n\t\twriters: (this.get(\"writers\") || authorizedUserName).split(\",\").map($tw.utils.trim)\n\t}\n\t// Load and initialise authenticators\n\t$tw.modules.forEachModuleOfType(\"authenticator\", function(title,authenticatorDefinition) {\n\t\t// console.log(\"Loading server route \" + title);\n\t\tself.addAuthenticator(authenticatorDefinition.AuthenticatorClass);\n\t});\n\t// Load route handlers\n\t$tw.modules.forEachModuleOfType(\"route\", function(title,routeDefinition) {\n\t\t// console.log(\"Loading server route \" + title);\n\t\tself.addRoute(routeDefinition);\n\t});\n\t// Initialise the http vs https\n\tthis.listenOptions = null;\n\tthis.protocol = \"http\";\n\tvar tlsKeyFilepath = this.get(\"tls-key\"),\n\t\ttlsCertFilepath = this.get(\"tls-cert\");\n\tif(tlsCertFilepath && tlsKeyFilepath) {\n\t\tthis.listenOptions = {\n\t\t\tkey: fs.readFileSync(path.resolve($tw.boot.wikiPath,tlsKeyFilepath),\"utf8\"),\n\t\t\tcert: fs.readFileSync(path.resolve($tw.boot.wikiPath,tlsCertFilepath),\"utf8\")\n\t\t};\n\t\tthis.protocol = \"https\";\n\t}\n\tthis.transport = require(this.protocol);\n}\n\nServer.prototype.defaultVariables = {\n\tport: \"8080\",\n\thost: \"127.0.0.1\",\n\t\"root-tiddler\": \"$:/core/save/all\",\n\t\"root-render-type\": \"text/plain\",\n\t\"root-serve-type\": \"text/html\",\n\t\"tiddler-render-type\": \"text/html\",\n\t\"tiddler-render-template\": \"$:/core/templates/server/static.tiddler.html\",\n\t\"system-tiddler-render-type\": \"text/plain\",\n\t\"system-tiddler-render-template\": \"$:/core/templates/wikified-tiddler\",\n\t\"debug-level\": \"none\"\n};\n\nServer.prototype.get = function(name) {\n\treturn this.variables[name];\n};\n\nServer.prototype.addRoute = function(route) {\n\tthis.routes.push(route);\n};\n\nServer.prototype.addAuthenticator = function(AuthenticatorClass) {\n\t// Instantiate and initialise the authenticator\n\tvar authenticator = new AuthenticatorClass(this),\n\t\tresult = authenticator.init();\n\tif(typeof result === \"string\") {\n\t\t$tw.utils.error(\"Error: \" + result);\n\t} else if(result) {\n\t\t// Only use the authenticator if it initialised successfully\n\t\tthis.authenticators.push(authenticator);\n\t}\n};\n\nServer.prototype.findMatchingRoute = function(request,state) {\n\tvar pathprefix = this.get(\"path-prefix\") || \"\";\n\tfor(var t=0; t<this.routes.length; t++) {\n\t\tvar potentialRoute = this.routes[t],\n\t\t\tpathRegExp = potentialRoute.path,\n\t\t\tpathname = state.urlInfo.pathname,\n\t\t\tmatch;\n\t\tif(pathprefix) {\n\t\t\tif(pathname.substr(0,pathprefix.length) === pathprefix) {\n\t\t\t\tpathname = pathname.substr(pathprefix.length) || \"/\";\n\t\t\t\tmatch = potentialRoute.path.exec(pathname);\n\t\t\t} else {\n\t\t\t\tmatch = false;\n\t\t\t}\n\t\t} else {\n\t\t\tmatch = potentialRoute.path.exec(pathname);\n\t\t}\n\t\tif(match && request.method === potentialRoute.method) {\n\t\t\tstate.params = [];\n\t\t\tfor(var p=1; p<match.length; p++) {\n\t\t\t\tstate.params.push(match[p]);\n\t\t\t}\n\t\t\treturn potentialRoute;\n\t\t}\n\t}\n\treturn null;\n};\n\nServer.prototype.methodMappings = {\n\t\"GET\": \"readers\",\n\t\"OPTIONS\": \"readers\",\n\t\"HEAD\": \"readers\",\n\t\"PUT\": \"writers\",\n\t\"POST\": \"writers\",\n\t\"DELETE\": \"writers\"\n};\n\n/*\nCheck whether a given user is authorized for the specified authorizationType (\"readers\" or \"writers\"). Pass null or undefined as the username to check for anonymous access\n*/\nServer.prototype.isAuthorized = function(authorizationType,username) {\n\tvar principals = this.authorizationPrincipals[authorizationType] || [];\n\treturn principals.indexOf(\"(anon)\") !== -1 || (username && (principals.indexOf(\"(authenticated)\") !== -1 || principals.indexOf(username) !== -1));\n}\n\nServer.prototype.requestHandler = function(request,response) {\n\t// Compose the state object\n\tvar self = this;\n\tvar state = {};\n\tstate.wiki = self.wiki;\n\tstate.server = self;\n\tstate.urlInfo = url.parse(request.url);\n\t// Get the principals authorized to access this resource\n\tvar authorizationType = this.methodMappings[request.method] || \"readers\";\n\t// Check for the CSRF header if this is a write\n\tif(!this.csrfDisable && authorizationType === \"writers\" && request.headers[\"x-requested-with\"] !== \"TiddlyWiki\") {\n\t\tresponse.writeHead(403,\"'X-Requested-With' header required to login to '\" + this.servername + \"'\");\n\t\tresponse.end();\n\t\treturn;\t\t\n\t}\n\t// Check whether anonymous access is granted\n\tstate.allowAnon = this.isAuthorized(authorizationType,null);\n\t// Authenticate with the first active authenticator\n\tif(this.authenticators.length > 0) {\n\t\tif(!this.authenticators[0].authenticateRequest(request,response,state)) {\n\t\t\t// Bail if we failed (the authenticator will have sent the response)\n\t\t\treturn;\n\t\t}\t\t\n\t}\n\t// Authorize with the authenticated username\n\tif(!this.isAuthorized(authorizationType,state.authenticatedUsername)) {\n\t\tresponse.writeHead(401,\"'\" + state.authenticatedUsername + \"' is not authorized to access '\" + this.servername + \"'\");\n\t\tresponse.end();\n\t\treturn;\n\t}\n\t// Find the route that matches this path\n\tvar route = self.findMatchingRoute(request,state);\n\t// Optionally output debug info\n\tif(self.get(\"debug-level\") !== \"none\") {\n\t\tconsole.log(\"Request path:\",JSON.stringify(state.urlInfo));\n\t\tconsole.log(\"Request headers:\",JSON.stringify(request.headers));\n\t\tconsole.log(\"authenticatedUsername:\",state.authenticatedUsername);\n\t}\n\t// Return a 404 if we didn't find a route\n\tif(!route) {\n\t\tresponse.writeHead(404);\n\t\tresponse.end();\n\t\treturn;\n\t}\n\t// Receive the request body if necessary and hand off to the route handler\n\tif(route.bodyFormat === \"stream\" || request.method === \"GET\" || request.method === \"HEAD\") {\n\t\t// Let the route handle the request stream itself\n\t\troute.handler(request,response,state);\n\t} else if(route.bodyFormat === \"string\" || !route.bodyFormat) {\n\t\t// Set the encoding for the incoming request\n\t\trequest.setEncoding(\"utf8\");\n\t\tvar data = \"\";\n\t\trequest.on(\"data\",function(chunk) {\n\t\t\tdata += chunk.toString();\n\t\t});\n\t\trequest.on(\"end\",function() {\n\t\t\tstate.data = data;\n\t\t\troute.handler(request,response,state);\n\t\t});\n\t} else if(route.bodyFormat === \"buffer\") {\n\t\tvar data = [];\n\t\trequest.on(\"data\",function(chunk) {\n\t\t\tdata.push(chunk);\n\t\t});\n\t\trequest.on(\"end\",function() {\n\t\t\tstate.data = Buffer.concat(data);\n\t\t\troute.handler(request,response,state);\n\t\t})\n\t} else {\n\t\tresponse.writeHead(400,\"Invalid bodyFormat \" + route.bodyFormat + \" in route \" + route.method + \" \" + route.path.source);\n\t\tresponse.end();\n\t}\n};\n\n/*\nListen for requests\nport: optional port number (falls back to value of \"port\" variable)\nhost: optional host address (falls back to value of \"hist\" variable)\n*/\nServer.prototype.listen = function(port,host) {\n\t// Handle defaults for port and host\n\tport = port || this.get(\"port\");\n\thost = host || this.get(\"host\");\n\t// Check for the port being a string and look it up as an environment variable\n\tif(parseInt(port,10).toString() !== port) {\n\t\tport = process.env[port] || 8080;\n\t}\n\t$tw.utils.log(\"Serving on \" + this.protocol + \"://\" + host + \":\" + port,\"brown/orange\");\n\t$tw.utils.log(\"(press ctrl-C to exit)\",\"red\");\n\t// Warn if required plugins are missing\n\tif(!$tw.wiki.getTiddler(\"$:/plugins/tiddlywiki/tiddlyweb\") || !$tw.wiki.getTiddler(\"$:/plugins/tiddlywiki/filesystem\")) {\n\t\t$tw.utils.warning(\"Warning: Plugins required for client-server operation (\\\"tiddlywiki/filesystem\\\" and \\\"tiddlywiki/tiddlyweb\\\") are missing from tiddlywiki.info file\");\n\t}\n\t// Listen\n\tvar server;\n\tif(this.listenOptions) {\n\t\tserver = this.transport.createServer(this.listenOptions,this.requestHandler.bind(this));\n\t} else {\n\t\tserver = this.transport.createServer(this.requestHandler.bind(this));\n\t}\n\treturn server.listen(port,host);\n};\n\nexports.Server = Server;\n\n})();\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/core/modules/browser-messaging.js": {
"title": "$:/core/modules/browser-messaging.js",
"text": "/*\\\ntitle: $:/core/modules/browser-messaging.js\ntype: application/javascript\nmodule-type: startup\n\nBrowser message handling\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n// Export name and synchronous status\nexports.name = \"browser-messaging\";\nexports.platforms = [\"browser\"];\nexports.after = [\"startup\"];\nexports.synchronous = true;\n\n/*\nLoad a specified url as an iframe and call the callback when it is loaded. If the url is already loaded then the existing iframe instance is used\n*/\nfunction loadIFrame(url,callback) {\n\t// Check if iframe already exists\n\tvar iframeInfo = $tw.browserMessaging.iframeInfoMap[url];\n\tif(iframeInfo) {\n\t\t// We've already got the iframe\n\t\tcallback(null,iframeInfo);\n\t} else {\n\t\t// Create the iframe and save it in the list\n\t\tvar iframe = document.createElement(\"iframe\");\n\t\tiframeInfo = {\n\t\t\turl: url,\n\t\t\tstatus: \"loading\",\n\t\t\tdomNode: iframe\n\t\t};\n\t\t$tw.browserMessaging.iframeInfoMap[url] = iframeInfo;\n\t\tsaveIFrameInfoTiddler(iframeInfo);\n\t\t// Add the iframe to the DOM and hide it\n\t\tiframe.style.display = \"none\";\n\t\tiframe.setAttribute(\"library\",\"true\");\n\t\tdocument.body.appendChild(iframe);\n\t\t// Set up onload\n\t\tiframe.onload = function() {\n\t\t\tiframeInfo.status = \"loaded\";\n\t\t\tsaveIFrameInfoTiddler(iframeInfo);\n\t\t\tcallback(null,iframeInfo);\n\t\t};\n\t\tiframe.onerror = function() {\n\t\t\tcallback(\"Cannot load iframe\");\n\t\t};\n\t\ttry {\n\t\t\tiframe.src = url;\n\t\t} catch(ex) {\n\t\t\tcallback(ex);\n\t\t}\n\t}\n}\n\n/*\nUnload library iframe for given url\n*/\nfunction unloadIFrame(url){\n\t$tw.utils.each(document.getElementsByTagName('iframe'), function(iframe) {\n\t\tif(iframe.getAttribute(\"library\") === \"true\" &&\n\t\t iframe.getAttribute(\"src\") === url) {\n\t\t\tiframe.parentNode.removeChild(iframe);\n\t\t}\n\t});\n}\n\nfunction saveIFrameInfoTiddler(iframeInfo) {\n\t$tw.wiki.addTiddler(new $tw.Tiddler($tw.wiki.getCreationFields(),{\n\t\ttitle: \"$:/temp/ServerConnection/\" + iframeInfo.url,\n\t\ttext: iframeInfo.status,\n\t\ttags: [\"$:/tags/ServerConnection\"],\n\t\turl: iframeInfo.url\n\t},$tw.wiki.getModificationFields()));\n}\n\nexports.startup = function() {\n\t// Initialise the store of iframes we've created\n\t$tw.browserMessaging = {\n\t\tiframeInfoMap: {} // Hashmap by URL of {url:,status:\"loading/loaded\",domNode:}\n\t};\n\t// Listen for widget messages to control loading the plugin library\n\t$tw.rootWidget.addEventListener(\"tm-load-plugin-library\",function(event) {\n\t\tvar paramObject = event.paramObject || {},\n\t\t\turl = paramObject.url;\n\t\tif(url) {\n\t\t\tloadIFrame(url,function(err,iframeInfo) {\n\t\t\t\tif(err) {\n\t\t\t\t\talert($tw.language.getString(\"Error/LoadingPluginLibrary\") + \": \" + url);\n\t\t\t\t} else {\n\t\t\t\t\tiframeInfo.domNode.contentWindow.postMessage({\n\t\t\t\t\t\tverb: \"GET\",\n\t\t\t\t\t\turl: \"recipes/library/tiddlers.json\",\n\t\t\t\t\t\tcookies: {\n\t\t\t\t\t\t\ttype: \"save-info\",\n\t\t\t\t\t\t\tinfoTitlePrefix: paramObject.infoTitlePrefix || \"$:/temp/RemoteAssetInfo/\",\n\t\t\t\t\t\t\turl: url\n\t\t\t\t\t\t}\n\t\t\t\t\t},\"*\");\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t});\n\t// Listen for widget messages to control unloading the plugin library\n\t$tw.rootWidget.addEventListener(\"tm-unload-plugin-library\",function(event) {\n\t\tvar paramObject = event.paramObject || {},\n\t\t\turl = paramObject.url;\n\t\t$tw.browserMessaging.iframeInfoMap[url] = undefined;\n\t\tif(url) {\n\t\t\tunloadIFrame(url);\n\t\t\t$tw.utils.each(\n\t\t\t\t$tw.wiki.filterTiddlers(\"[[$:/temp/ServerConnection/\" + url + \"]] [prefix[$:/temp/RemoteAssetInfo/\" + url + \"/]]\"),\n\t\t\t\tfunction(title) {\n\t\t\t\t\t$tw.wiki.deleteTiddler(title);\n\t\t\t\t}\n\t\t\t);\n\t\t}\n\t});\n\t$tw.rootWidget.addEventListener(\"tm-load-plugin-from-library\",function(event) {\n\t\tvar paramObject = event.paramObject || {},\n\t\t\turl = paramObject.url,\n\t\t\ttitle = paramObject.title;\n\t\tif(url && title) {\n\t\t\tloadIFrame(url,function(err,iframeInfo) {\n\t\t\t\tif(err) {\n\t\t\t\t\talert($tw.language.getString(\"Error/LoadingPluginLibrary\") + \": \" + url);\n\t\t\t\t} else {\n\t\t\t\t\tiframeInfo.domNode.contentWindow.postMessage({\n\t\t\t\t\t\tverb: \"GET\",\n\t\t\t\t\t\turl: \"recipes/library/tiddlers/\" + encodeURIComponent(title) + \".json\",\n\t\t\t\t\t\tcookies: {\n\t\t\t\t\t\t\ttype: \"save-tiddler\",\n\t\t\t\t\t\t\turl: url\n\t\t\t\t\t\t}\n\t\t\t\t\t},\"*\");\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t});\n\t// Listen for window messages from other windows\n\twindow.addEventListener(\"message\",function listener(event){\n\t\tconsole.log(\"browser-messaging: \",document.location.toString())\n\t\tconsole.log(\"browser-messaging: Received message from\",event.origin);\n\t\tconsole.log(\"browser-messaging: Message content\",event.data);\n\t\tswitch(event.data.verb) {\n\t\t\tcase \"GET-RESPONSE\":\n\t\t\t\tif(event.data.status.charAt(0) === \"2\") {\n\t\t\t\t\tif(event.data.cookies) {\n\t\t\t\t\t\tif(event.data.cookies.type === \"save-info\") {\n\t\t\t\t\t\t\tvar tiddlers = JSON.parse(event.data.body);\n\t\t\t\t\t\t\t$tw.utils.each(tiddlers,function(tiddler) {\n\t\t\t\t\t\t\t\t$tw.wiki.addTiddler(new $tw.Tiddler($tw.wiki.getCreationFields(),tiddler,{\n\t\t\t\t\t\t\t\t\ttitle: event.data.cookies.infoTitlePrefix + event.data.cookies.url + \"/\" + tiddler.title,\n\t\t\t\t\t\t\t\t\t\"original-title\": tiddler.title,\n\t\t\t\t\t\t\t\t\ttext: \"\",\n\t\t\t\t\t\t\t\t\ttype: \"text/vnd.tiddlywiki\",\n\t\t\t\t\t\t\t\t\t\"original-type\": tiddler.type,\n\t\t\t\t\t\t\t\t\t\"plugin-type\": undefined,\n\t\t\t\t\t\t\t\t\t\"original-plugin-type\": tiddler[\"plugin-type\"],\n\t\t\t\t\t\t\t\t\t\"module-type\": undefined,\n\t\t\t\t\t\t\t\t\t\"original-module-type\": tiddler[\"module-type\"],\n\t\t\t\t\t\t\t\t\ttags: [\"$:/tags/RemoteAssetInfo\"],\n\t\t\t\t\t\t\t\t\t\"original-tags\": $tw.utils.stringifyList(tiddler.tags || []),\n\t\t\t\t\t\t\t\t\t\"server-url\": event.data.cookies.url\n\t\t\t\t\t\t\t\t},$tw.wiki.getModificationFields()));\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t} else if(event.data.cookies.type === \"save-tiddler\") {\n\t\t\t\t\t\t\tvar tiddler = JSON.parse(event.data.body);\n\t\t\t\t\t\t\t$tw.wiki.addTiddler(new $tw.Tiddler(tiddler));\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t}\n\t},false);\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "startup"
},
"$:/core/modules/startup/commands.js": {
"title": "$:/core/modules/startup/commands.js",
"text": "/*\\\ntitle: $:/core/modules/startup/commands.js\ntype: application/javascript\nmodule-type: startup\n\nCommand processing\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n// Export name and synchronous status\nexports.name = \"commands\";\nexports.platforms = [\"node\"];\nexports.after = [\"story\"];\nexports.synchronous = false;\n\nexports.startup = function(callback) {\n\t// On the server, start a commander with the command line arguments\n\tvar commander = new $tw.Commander(\n\t\t$tw.boot.argv,\n\t\tfunction(err) {\n\t\t\tif(err) {\n\t\t\t\treturn $tw.utils.error(\"Error: \" + err);\n\t\t\t}\n\t\t\tcallback();\n\t\t},\n\t\t$tw.wiki,\n\t\t{output: process.stdout, error: process.stderr}\n\t);\n\tcommander.execute();\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "startup"
},
"$:/core/modules/startup/favicon.js": {
"title": "$:/core/modules/startup/favicon.js",
"text": "/*\\\ntitle: $:/core/modules/startup/favicon.js\ntype: application/javascript\nmodule-type: startup\n\nFavicon handling\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n// Export name and synchronous status\nexports.name = \"favicon\";\nexports.platforms = [\"browser\"];\nexports.after = [\"startup\"];\nexports.synchronous = true;\n\t\t\n// Favicon tiddler\nvar FAVICON_TITLE = \"$:/favicon.ico\";\n\nexports.startup = function() {\n\t// Set up the favicon\n\tsetFavicon();\n\t// Reset the favicon when the tiddler changes\n\t$tw.wiki.addEventListener(\"change\",function(changes) {\n\t\tif($tw.utils.hop(changes,FAVICON_TITLE)) {\n\t\t\tsetFavicon();\n\t\t}\n\t});\n};\n\nfunction setFavicon() {\n\tvar tiddler = $tw.wiki.getTiddler(FAVICON_TITLE);\n\tif(tiddler) {\n\t\tvar faviconLink = document.getElementById(\"faviconLink\");\n\t\tfaviconLink.setAttribute(\"href\",\"data:\" + tiddler.fields.type + \";base64,\" + tiddler.fields.text);\n\t}\n}\n\n})();\n",
"type": "application/javascript",
"module-type": "startup"
},
"$:/core/modules/startup/info.js": {
"title": "$:/core/modules/startup/info.js",
"text": "/*\\\ntitle: $:/core/modules/startup/info.js\ntype: application/javascript\nmodule-type: startup\n\nInitialise $:/info tiddlers via $:/temp/info-plugin pseudo-plugin\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n// Export name and synchronous status\nexports.name = \"info\";\nexports.before = [\"startup\"];\nexports.after = [\"load-modules\"];\nexports.synchronous = true;\n\nexports.startup = function() {\n\t// Collect up the info tiddlers\n\tvar infoTiddlerFields = {};\n\t// Give each info module a chance to fill in as many info tiddlers as they want\n\t$tw.modules.forEachModuleOfType(\"info\",function(title,moduleExports) {\n\t\tif(moduleExports && moduleExports.getInfoTiddlerFields) {\n\t\t\tvar tiddlerFieldsArray = moduleExports.getInfoTiddlerFields(infoTiddlerFields);\n\t\t\t$tw.utils.each(tiddlerFieldsArray,function(fields) {\n\t\t\t\tif(fields) {\n\t\t\t\t\tinfoTiddlerFields[fields.title] = fields;\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t});\n\t// Bake the info tiddlers into a plugin\n\tvar fields = {\n\t\ttitle: \"$:/temp/info-plugin\",\n\t\ttype: \"application/json\",\n\t\t\"plugin-type\": \"info\",\n\t\ttext: JSON.stringify({tiddlers: infoTiddlerFields},null,$tw.config.preferences.jsonSpaces)\n\t};\n\t$tw.wiki.addTiddler(new $tw.Tiddler(fields));\n\t$tw.wiki.readPluginInfo();\n\t$tw.wiki.registerPluginTiddlers(\"info\");\n\t$tw.wiki.unpackPluginTiddlers();\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "startup"
},
"$:/core/modules/startup/load-modules.js": {
"title": "$:/core/modules/startup/load-modules.js",
"text": "/*\\\ntitle: $:/core/modules/startup/load-modules.js\ntype: application/javascript\nmodule-type: startup\n\nLoad core modules\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n// Export name and synchronous status\nexports.name = \"load-modules\";\nexports.synchronous = true;\n\nexports.startup = function() {\n\t// Load modules\n\t$tw.modules.applyMethods(\"utils\",$tw.utils);\n\tif($tw.node) {\n\t\t$tw.modules.applyMethods(\"utils-node\",$tw.utils);\n\t}\n\t$tw.modules.applyMethods(\"global\",$tw);\n\t$tw.modules.applyMethods(\"config\",$tw.config);\n\t$tw.Tiddler.fieldModules = $tw.modules.getModulesByTypeAsHashmap(\"tiddlerfield\");\n\t$tw.modules.applyMethods(\"tiddlermethod\",$tw.Tiddler.prototype);\n\t$tw.modules.applyMethods(\"wikimethod\",$tw.Wiki.prototype);\n\t$tw.modules.applyMethods(\"tiddlerdeserializer\",$tw.Wiki.tiddlerDeserializerModules);\n\t$tw.macros = $tw.modules.getModulesByTypeAsHashmap(\"macro\");\n\t$tw.wiki.initParsers();\n\t$tw.Commander.initCommands();\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "startup"
},
"$:/core/modules/startup/password.js": {
"title": "$:/core/modules/startup/password.js",
"text": "/*\\\ntitle: $:/core/modules/startup/password.js\ntype: application/javascript\nmodule-type: startup\n\nPassword handling\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n// Export name and synchronous status\nexports.name = \"password\";\nexports.platforms = [\"browser\"];\nexports.after = [\"startup\"];\nexports.synchronous = true;\n\nexports.startup = function() {\n\t$tw.rootWidget.addEventListener(\"tm-set-password\",function(event) {\n\t\t$tw.passwordPrompt.createPrompt({\n\t\t\tserviceName: $tw.language.getString(\"Encryption/PromptSetPassword\"),\n\t\t\tnoUserName: true,\n\t\t\tsubmitText: $tw.language.getString(\"Encryption/SetPassword\"),\n\t\t\tcanCancel: true,\n\t\t\trepeatPassword: true,\n\t\t\tcallback: function(data) {\n\t\t\t\tif(data) {\n\t\t\t\t\t$tw.crypto.setPassword(data.password);\n\t\t\t\t}\n\t\t\t\treturn true; // Get rid of the password prompt\n\t\t\t}\n\t\t});\n\t});\n\t$tw.rootWidget.addEventListener(\"tm-clear-password\",function(event) {\n\t\tif($tw.browser) {\n\t\t\tif(!confirm($tw.language.getString(\"Encryption/ConfirmClearPassword\"))) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\t\t$tw.crypto.setPassword(null);\n\t});\n\t// Ensure that $:/isEncrypted is maintained properly\n\t$tw.wiki.addEventListener(\"change\",function(changes) {\n\t\tif($tw.utils.hop(changes,\"$:/isEncrypted\")) {\n\t\t\t$tw.crypto.updateCryptoStateTiddler();\n\t\t}\n\t});\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "startup"
},
"$:/core/modules/startup/render.js": {
"title": "$:/core/modules/startup/render.js",
"text": "/*\\\ntitle: $:/core/modules/startup/render.js\ntype: application/javascript\nmodule-type: startup\n\nTitle, stylesheet and page rendering\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n// Export name and synchronous status\nexports.name = \"render\";\nexports.platforms = [\"browser\"];\nexports.after = [\"story\"];\nexports.synchronous = true;\n\n// Default story and history lists\nvar PAGE_TITLE_TITLE = \"$:/core/wiki/title\";\nvar PAGE_STYLESHEET_TITLE = \"$:/core/ui/PageStylesheet\";\nvar PAGE_TEMPLATE_TITLE = \"$:/core/ui/PageTemplate\";\n\n// Time (in ms) that we defer refreshing changes to draft tiddlers\nvar DRAFT_TIDDLER_TIMEOUT_TITLE = \"$:/config/Drafts/TypingTimeout\";\nvar DRAFT_TIDDLER_TIMEOUT = 400;\n\nexports.startup = function() {\n\t// Set up the title\n\t$tw.titleWidgetNode = $tw.wiki.makeTranscludeWidget(PAGE_TITLE_TITLE,{document: $tw.fakeDocument, parseAsInline: true});\n\t$tw.titleContainer = $tw.fakeDocument.createElement(\"div\");\n\t$tw.titleWidgetNode.render($tw.titleContainer,null);\n\tdocument.title = $tw.titleContainer.textContent;\n\t$tw.wiki.addEventListener(\"change\",function(changes) {\n\t\tif($tw.titleWidgetNode.refresh(changes,$tw.titleContainer,null)) {\n\t\t\tdocument.title = $tw.titleContainer.textContent;\n\t\t}\n\t});\n\t// Set up the styles\n\t$tw.styleWidgetNode = $tw.wiki.makeTranscludeWidget(PAGE_STYLESHEET_TITLE,{document: $tw.fakeDocument});\n\t$tw.styleContainer = $tw.fakeDocument.createElement(\"style\");\n\t$tw.styleWidgetNode.render($tw.styleContainer,null);\n\t$tw.styleElement = document.createElement(\"style\");\n\t$tw.styleElement.innerHTML = $tw.styleContainer.textContent;\n\tdocument.head.insertBefore($tw.styleElement,document.head.firstChild);\n\t$tw.wiki.addEventListener(\"change\",$tw.perf.report(\"styleRefresh\",function(changes) {\n\t\tif($tw.styleWidgetNode.refresh(changes,$tw.styleContainer,null)) {\n\t\t\t$tw.styleElement.innerHTML = $tw.styleContainer.textContent;\n\t\t}\n\t}));\n\t// Display the $:/core/ui/PageTemplate tiddler to kick off the display\n\t$tw.perf.report(\"mainRender\",function() {\n\t\t$tw.pageWidgetNode = $tw.wiki.makeTranscludeWidget(PAGE_TEMPLATE_TITLE,{document: document, parentWidget: $tw.rootWidget});\n\t\t$tw.pageContainer = document.createElement(\"div\");\n\t\t$tw.utils.addClass($tw.pageContainer,\"tc-page-container-wrapper\");\n\t\tdocument.body.insertBefore($tw.pageContainer,document.body.firstChild);\n\t\t$tw.pageWidgetNode.render($tw.pageContainer,null);\n \t\t$tw.hooks.invokeHook(\"th-page-refreshed\");\n\t})();\n\t// Remove any splash screen elements\n\tvar removeList = document.querySelectorAll(\".tc-remove-when-wiki-loaded\");\n\t$tw.utils.each(removeList,function(removeItem) {\n\t\tif(removeItem.parentNode) {\n\t\t\tremoveItem.parentNode.removeChild(removeItem);\n\t\t}\n\t});\n\t// Prepare refresh mechanism\n\tvar deferredChanges = Object.create(null),\n\t\ttimerId;\n\tfunction refresh() {\n\t\t// Process the refresh\n\t\t$tw.pageWidgetNode.refresh(deferredChanges);\n\t\tdeferredChanges = Object.create(null);\n \t\t$tw.hooks.invokeHook(\"th-page-refreshed\");\n\t}\n\t// Add the change event handler\n\t$tw.wiki.addEventListener(\"change\",$tw.perf.report(\"mainRefresh\",function(changes) {\n\t\t// Check if only drafts have changed\n\t\tvar onlyDraftsHaveChanged = true;\n\t\tfor(var title in changes) {\n\t\t\tvar tiddler = $tw.wiki.getTiddler(title);\n\t\t\tif(!tiddler || !tiddler.hasField(\"draft.of\")) {\n\t\t\t\tonlyDraftsHaveChanged = false;\n\t\t\t}\n\t\t}\n\t\t// Defer the change if only drafts have changed\n\t\tif(timerId) {\n\t\t\tclearTimeout(timerId);\n\t\t}\n\t\ttimerId = null;\n\t\tif(onlyDraftsHaveChanged) {\n\t\t\tvar timeout = parseInt($tw.wiki.getTiddlerText(DRAFT_TIDDLER_TIMEOUT_TITLE,\"\"),10);\n\t\t\tif(isNaN(timeout)) {\n\t\t\t\ttimeout = DRAFT_TIDDLER_TIMEOUT;\n\t\t\t}\n\t\t\ttimerId = setTimeout(refresh,timeout);\n\t\t\t$tw.utils.extend(deferredChanges,changes);\n\t\t} else {\n\t\t\t$tw.utils.extend(deferredChanges,changes);\n\t\t\trefresh();\n\t\t}\n\t}));\n\t// Fix up the link between the root widget and the page container\n\t$tw.rootWidget.domNodes = [$tw.pageContainer];\n\t$tw.rootWidget.children = [$tw.pageWidgetNode];\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "startup"
},
"$:/core/modules/startup/rootwidget.js": {
"title": "$:/core/modules/startup/rootwidget.js",
"text": "/*\\\ntitle: $:/core/modules/startup/rootwidget.js\ntype: application/javascript\nmodule-type: startup\n\nSetup the root widget and the core root widget handlers\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n// Export name and synchronous status\nexports.name = \"rootwidget\";\nexports.platforms = [\"browser\"];\nexports.after = [\"startup\"];\nexports.before = [\"story\"];\nexports.synchronous = true;\n\nexports.startup = function() {\n\t// Install the modal message mechanism\n\t$tw.modal = new $tw.utils.Modal($tw.wiki);\n\t$tw.rootWidget.addEventListener(\"tm-modal\",function(event) {\n\t\t$tw.modal.display(event.param,{variables: event.paramObject, event: event});\n\t});\n\t// Install the notification mechanism\n\t$tw.notifier = new $tw.utils.Notifier($tw.wiki);\n\t$tw.rootWidget.addEventListener(\"tm-notify\",function(event) {\n\t\t$tw.notifier.display(event.param,{variables: event.paramObject});\n\t});\n\t// Install the copy-to-clipboard mechanism\n\t$tw.rootWidget.addEventListener(\"tm-copy-to-clipboard\",function(event) {\n\t\t$tw.utils.copyToClipboard(event.param);\n\t});\n\t// Install the scroller\n\t$tw.pageScroller = new $tw.utils.PageScroller();\n\t$tw.rootWidget.addEventListener(\"tm-scroll\",function(event) {\n\t\t$tw.pageScroller.handleEvent(event);\n\t});\n\tvar fullscreen = $tw.utils.getFullScreenApis();\n\tif(fullscreen) {\n\t\t$tw.rootWidget.addEventListener(\"tm-full-screen\",function(event) {\n\t\t\tif(event.param === \"enter\") {\n\t\t\t\tevent.event.target.ownerDocument.documentElement[fullscreen._requestFullscreen](Element.ALLOW_KEYBOARD_INPUT);\n\t\t\t} else if(event.param === \"exit\") {\n\t\t\t\tevent.event.target.ownerDocument[fullscreen._exitFullscreen]();\n\t\t\t} else {\n\t\t\t\tif(event.event.target.ownerDocument[fullscreen._fullscreenElement]) {\n\t\t\t\t\tevent.event.target.ownerDocument[fullscreen._exitFullscreen]();\n\t\t\t\t} else {\n\t\t\t\t\tevent.event.target.ownerDocument.documentElement[fullscreen._requestFullscreen](Element.ALLOW_KEYBOARD_INPUT);\n\t\t\t\t}\t\t\t\t\n\t\t\t}\n\t\t});\n\t}\n\t// If we're being viewed on a data: URI then give instructions for how to save\n\tif(document.location.protocol === \"data:\") {\n\t\t$tw.rootWidget.dispatchEvent({\n\t\t\ttype: \"tm-modal\",\n\t\t\tparam: \"$:/language/Modals/SaveInstructions\"\n\t\t});\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "startup"
},
"$:/core/modules/startup.js": {
"title": "$:/core/modules/startup.js",
"text": "/*\\\ntitle: $:/core/modules/startup.js\ntype: application/javascript\nmodule-type: startup\n\nMiscellaneous startup logic for both the client and server.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n// Export name and synchronous status\nexports.name = \"startup\";\nexports.after = [\"load-modules\"];\nexports.synchronous = true;\n\n// Set to `true` to enable performance instrumentation\nvar PERFORMANCE_INSTRUMENTATION_CONFIG_TITLE = \"$:/config/Performance/Instrumentation\";\n\nvar widget = require(\"$:/core/modules/widgets/widget.js\");\n\nexports.startup = function() {\n\tvar modules,n,m,f;\n\t// Minimal browser detection\n\tif($tw.browser) {\n\t\t$tw.browser.isIE = (/msie|trident/i.test(navigator.userAgent));\n\t\t$tw.browser.isFirefox = !!document.mozFullScreenEnabled;\n\t}\n\t// Platform detection\n\t$tw.platform = {};\n\tif($tw.browser) {\n\t\t$tw.platform.isMac = /Mac/.test(navigator.platform);\n\t\t$tw.platform.isWindows = /win/i.test(navigator.platform);\n\t\t$tw.platform.isLinux = /Linux/i.test(navigator.platform);\n\t} else {\n\t\tswitch(require(\"os\").platform()) {\n\t\t\tcase \"darwin\":\n\t\t\t\t$tw.platform.isMac = true;\n\t\t\t\tbreak;\n\t\t\tcase \"win32\":\n\t\t\t\t$tw.platform.isWindows = true;\n\t\t\t\tbreak;\n\t\t\tcase \"freebsd\":\n\t\t\t\t$tw.platform.isLinux = true;\n\t\t\t\tbreak;\n\t\t\tcase \"linux\":\n\t\t\t\t$tw.platform.isLinux = true;\n\t\t\t\tbreak;\n\t\t}\n\t}\n\t// Initialise version\n\t$tw.version = $tw.utils.extractVersionInfo();\n\t// Set up the performance framework\n\t$tw.perf = new $tw.Performance($tw.wiki.getTiddlerText(PERFORMANCE_INSTRUMENTATION_CONFIG_TITLE,\"no\") === \"yes\");\n\t// Kick off the language manager and switcher\n\t$tw.language = new $tw.Language();\n\t$tw.languageSwitcher = new $tw.PluginSwitcher({\n\t\twiki: $tw.wiki,\n\t\tpluginType: \"language\",\n\t\tcontrollerTitle: \"$:/language\",\n\t\tdefaultPlugins: [\n\t\t\t\"$:/languages/en-US\"\n\t\t],\n\t\tonSwitch: function(plugins) {\n\t\t\tif($tw.browser) {\n\t\t\t\tvar pluginTiddler = $tw.wiki.getTiddler(plugins[0]);\n\t\t\t\tif(pluginTiddler) {\n\t\t\t\t\tdocument.documentElement.setAttribute(\"dir\",pluginTiddler.getFieldString(\"text-direction\") || \"auto\");\n\t\t\t\t} else {\n\t\t\t\t\tdocument.documentElement.removeAttribute(\"dir\");\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t});\n\t// Kick off the theme manager\n\t$tw.themeManager = new $tw.PluginSwitcher({\n\t\twiki: $tw.wiki,\n\t\tpluginType: \"theme\",\n\t\tcontrollerTitle: \"$:/theme\",\n\t\tdefaultPlugins: [\n\t\t\t\"$:/themes/tiddlywiki/snowwhite\",\n\t\t\t\"$:/themes/tiddlywiki/vanilla\"\n\t\t]\n\t});\n\t// Kick off the keyboard manager\n\t$tw.keyboardManager = new $tw.KeyboardManager();\n\t// Listen for shortcuts\n\tif($tw.browser) {\n\t\t$tw.utils.addEventListeners(document,[{\n\t\t\tname: \"keydown\",\n\t\t\thandlerObject: $tw.keyboardManager,\n\t\t\thandlerMethod: \"handleKeydownEvent\"\n\t\t}]);\n\t}\n\t// Create a root widget for attaching event handlers. By using it as the parentWidget for another widget tree, one can reuse the event handlers\n\t$tw.rootWidget = new widget.widget({\n\t\ttype: \"widget\",\n\t\tchildren: []\n\t},{\n\t\twiki: $tw.wiki,\n\t\tdocument: $tw.browser ? document : $tw.fakeDocument\n\t});\n\t// Execute any startup actions\n\tvar executeStartupTiddlers = function(tag) {\n\t\t$tw.utils.each($tw.wiki.filterTiddlers(\"[all[shadows+tiddlers]tag[\" + tag + \"]!has[draft.of]]\"),function(title) {\n\t\t\t$tw.rootWidget.invokeActionString($tw.wiki.getTiddlerText(title),$tw.rootWidget);\n\t\t});\n\t};\n\texecuteStartupTiddlers(\"$:/tags/StartupAction\");\n\tif($tw.browser) {\n\t\texecuteStartupTiddlers(\"$:/tags/StartupAction/Browser\");\t\t\n\t}\n\tif($tw.node) {\n\t\texecuteStartupTiddlers(\"$:/tags/StartupAction/Node\");\t\t\n\t}\n\t// Clear outstanding tiddler store change events to avoid an unnecessary refresh cycle at startup\n\t$tw.wiki.clearTiddlerEventQueue();\n\t// Find a working syncadaptor\n\t$tw.syncadaptor = undefined;\n\t$tw.modules.forEachModuleOfType(\"syncadaptor\",function(title,module) {\n\t\tif(!$tw.syncadaptor && module.adaptorClass) {\n\t\t\t$tw.syncadaptor = new module.adaptorClass({wiki: $tw.wiki});\n\t\t}\n\t});\n\t// Set up the syncer object if we've got a syncadaptor\n\tif($tw.syncadaptor) {\n\t\t$tw.syncer = new $tw.Syncer({wiki: $tw.wiki, syncadaptor: $tw.syncadaptor});\n\t} \n\t// Setup the saver handler\n\t$tw.saverHandler = new $tw.SaverHandler({wiki: $tw.wiki, dirtyTracking: !$tw.syncadaptor});\n\t// Host-specific startup\n\tif($tw.browser) {\n\t\t// Install the popup manager\n\t\t$tw.popup = new $tw.utils.Popup();\n\t\t// Install the animator\n\t\t$tw.anim = new $tw.utils.Animator();\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "startup"
},
"$:/core/modules/startup/story.js": {
"title": "$:/core/modules/startup/story.js",
"text": "/*\\\ntitle: $:/core/modules/startup/story.js\ntype: application/javascript\nmodule-type: startup\n\nLoad core modules\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n// Export name and synchronous status\nexports.name = \"story\";\nexports.after = [\"startup\"];\nexports.synchronous = true;\n\n// Default story and history lists\nvar DEFAULT_STORY_TITLE = \"$:/StoryList\";\nvar DEFAULT_HISTORY_TITLE = \"$:/HistoryList\";\n\n// Default tiddlers\nvar DEFAULT_TIDDLERS_TITLE = \"$:/DefaultTiddlers\";\n\n// Config\nvar CONFIG_UPDATE_ADDRESS_BAR = \"$:/config/Navigation/UpdateAddressBar\"; // Can be \"no\", \"permalink\", \"permaview\"\nvar CONFIG_UPDATE_HISTORY = \"$:/config/Navigation/UpdateHistory\"; // Can be \"yes\" or \"no\"\nvar CONFIG_PERMALINKVIEW_COPY_TO_CLIPBOARD = \"$:/config/Navigation/Permalinkview/CopyToClipboard\"; // Can be \"yes\" (default) or \"no\"\nvar CONFIG_PERMALINKVIEW_UPDATE_ADDRESS_BAR = \"$:/config/Navigation/Permalinkview/UpdateAddressBar\"; // Can be \"yes\" (default) or \"no\"\n\n\n// Links to help, if there is no param\nvar HELP_OPEN_EXTERNAL_WINDOW = \"http://tiddlywiki.com/#WidgetMessage%3A%20tm-open-external-window\";\n\nexports.startup = function() {\n\t// Open startup tiddlers\n\topenStartupTiddlers();\n\tif($tw.browser) {\n\t\t// Set up location hash update\n\t\t$tw.wiki.addEventListener(\"change\",function(changes) {\n\t\t\tif($tw.utils.hop(changes,DEFAULT_STORY_TITLE) || $tw.utils.hop(changes,DEFAULT_HISTORY_TITLE)) {\n\t\t\t\tupdateLocationHash({\n\t\t\t\t\tupdateAddressBar: $tw.wiki.getTiddlerText(CONFIG_UPDATE_ADDRESS_BAR,\"permaview\").trim(),\n\t\t\t\t\tupdateHistory: $tw.wiki.getTiddlerText(CONFIG_UPDATE_HISTORY,\"no\").trim()\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\t\t// Listen for changes to the browser location hash\n\t\twindow.addEventListener(\"hashchange\",function() {\n\t\t\tvar hash = $tw.utils.getLocationHash();\n\t\t\tif(hash !== $tw.locationHash) {\n\t\t\t\t$tw.locationHash = hash;\n\t\t\t\topenStartupTiddlers({defaultToCurrentStory: true});\n\t\t\t}\n\t\t},false);\n\t\t// Listen for the tm-browser-refresh message\n\t\t$tw.rootWidget.addEventListener(\"tm-browser-refresh\",function(event) {\n\t\t\twindow.location.reload(true);\n\t\t});\n\t\t// Listen for tm-open-external-window message\n\t\t$tw.rootWidget.addEventListener(\"tm-open-external-window\",function(event) {\n\t\t\tvar paramObject = event.paramObject || {},\n\t\t\t\tstrUrl = event.param || HELP_OPEN_EXTERNAL_WINDOW,\n\t\t\t\tstrWindowName = paramObject.windowName,\n\t\t\t\tstrWindowFeatures = paramObject.windowFeatures;\n\t\t\twindow.open(strUrl, strWindowName, strWindowFeatures);\n\t\t});\n\t\t// Listen for the tm-print message\n\t\t$tw.rootWidget.addEventListener(\"tm-print\",function(event) {\n\t\t\t(event.event.view || window).print();\n\t\t});\n\t\t// Listen for the tm-home message\n\t\t$tw.rootWidget.addEventListener(\"tm-home\",function(event) {\n\t\t\twindow.location.hash = \"\";\n\t\t\tvar storyFilter = $tw.wiki.getTiddlerText(DEFAULT_TIDDLERS_TITLE),\n\t\t\t\tstoryList = $tw.wiki.filterTiddlers(storyFilter);\n\t\t\t//invoke any hooks that might change the default story list\n\t\t\tstoryList = $tw.hooks.invokeHook(\"th-opening-default-tiddlers-list\",storyList);\n\t\t\t$tw.wiki.addTiddler({title: DEFAULT_STORY_TITLE, text: \"\", list: storyList},$tw.wiki.getModificationFields());\n\t\t\tif(storyList[0]) {\n\t\t\t\t$tw.wiki.addToHistory(storyList[0]);\n\t\t\t}\n\t\t});\n\t\t// Listen for the tm-permalink message\n\t\t$tw.rootWidget.addEventListener(\"tm-permalink\",function(event) {\n\t\t\tupdateLocationHash({\n\t\t\t\tupdateAddressBar: $tw.wiki.getTiddlerText(CONFIG_PERMALINKVIEW_UPDATE_ADDRESS_BAR,\"yes\").trim() === \"yes\" ? \"permalink\" : \"none\",\n\t\t\t\tupdateHistory: $tw.wiki.getTiddlerText(CONFIG_UPDATE_HISTORY,\"no\").trim(),\n\t\t\t\ttargetTiddler: event.param || event.tiddlerTitle,\n\t\t\t\tcopyToClipboard: $tw.wiki.getTiddlerText(CONFIG_PERMALINKVIEW_COPY_TO_CLIPBOARD,\"yes\").trim() === \"yes\" ? \"permalink\" : \"none\"\n\t\t\t});\n\t\t});\n\t\t// Listen for the tm-permaview message\n\t\t$tw.rootWidget.addEventListener(\"tm-permaview\",function(event) {\n\t\t\tupdateLocationHash({\n\t\t\t\tupdateAddressBar: $tw.wiki.getTiddlerText(CONFIG_PERMALINKVIEW_UPDATE_ADDRESS_BAR,\"yes\").trim() === \"yes\" ? \"permaview\" : \"none\",\n\t\t\t\tupdateHistory: $tw.wiki.getTiddlerText(CONFIG_UPDATE_HISTORY,\"no\").trim(),\n\t\t\t\ttargetTiddler: event.param || event.tiddlerTitle,\n\t\t\t\tcopyToClipboard: $tw.wiki.getTiddlerText(CONFIG_PERMALINKVIEW_COPY_TO_CLIPBOARD,\"yes\").trim() === \"yes\" ? \"permaview\" : \"none\"\n\t\t\t});\t\t\t\t\n\t\t});\n\t}\n};\n\n/*\nProcess the location hash to open the specified tiddlers. Options:\ndefaultToCurrentStory: If true, the current story is retained as the default, instead of opening the default tiddlers\n*/\nfunction openStartupTiddlers(options) {\n\toptions = options || {};\n\t// Work out the target tiddler and the story filter. \"null\" means \"unspecified\"\n\tvar target = null,\n\t\tstoryFilter = null;\n\tif($tw.locationHash.length > 1) {\n\t\tvar hash = $tw.locationHash.substr(1),\n\t\t\tsplit = hash.indexOf(\":\");\n\t\tif(split === -1) {\n\t\t\ttarget = decodeURIComponent(hash.trim());\n\t\t} else {\n\t\t\ttarget = decodeURIComponent(hash.substr(0,split).trim());\n\t\t\tstoryFilter = decodeURIComponent(hash.substr(split + 1).trim());\n\t\t}\n\t}\n\t// If the story wasn't specified use the current tiddlers or a blank story\n\tif(storyFilter === null) {\n\t\tif(options.defaultToCurrentStory) {\n\t\t\tvar currStoryList = $tw.wiki.getTiddlerList(DEFAULT_STORY_TITLE);\n\t\t\tstoryFilter = $tw.utils.stringifyList(currStoryList);\n\t\t} else {\n\t\t\tif(target && target !== \"\") {\n\t\t\t\tstoryFilter = \"\";\n\t\t\t} else {\n\t\t\t\tstoryFilter = $tw.wiki.getTiddlerText(DEFAULT_TIDDLERS_TITLE);\n\t\t\t}\n\t\t}\n\t}\n\t// Process the story filter to get the story list\n\tvar storyList = $tw.wiki.filterTiddlers(storyFilter);\n\t// Invoke any hooks that want to change the default story list\n\tstoryList = $tw.hooks.invokeHook(\"th-opening-default-tiddlers-list\",storyList);\n\t// If the target tiddler isn't included then splice it in at the top\n\tif(target && storyList.indexOf(target) === -1) {\n\t\tstoryList.unshift(target);\n\t}\n\t// Save the story list\n\t$tw.wiki.addTiddler({title: DEFAULT_STORY_TITLE, text: \"\", list: storyList},$tw.wiki.getModificationFields());\n\t// If a target tiddler was specified add it to the history stack\n\tif(target && target !== \"\") {\n\t\t// The target tiddler doesn't need double square brackets, but we'll silently remove them if they're present\n\t\tif(target.indexOf(\"[[\") === 0 && target.substr(-2) === \"]]\") {\n\t\t\ttarget = target.substr(2,target.length - 4);\n\t\t}\n\t\t$tw.wiki.addToHistory(target);\n\t} else if(storyList.length > 0) {\n\t\t$tw.wiki.addToHistory(storyList[0]);\n\t}\n}\n\n/*\noptions: See below\noptions.updateAddressBar: \"permalink\", \"permaview\" or \"no\" (defaults to \"permaview\")\noptions.updateHistory: \"yes\" or \"no\" (defaults to \"no\")\noptions.copyToClipboard: \"permalink\", \"permaview\" or \"no\" (defaults to \"no\")\noptions.targetTiddler: optional title of target tiddler for permalink\n*/\nfunction updateLocationHash(options) {\n\t// Get the story and the history stack\n\tvar storyList = $tw.wiki.getTiddlerList(DEFAULT_STORY_TITLE),\n\t\thistoryList = $tw.wiki.getTiddlerData(DEFAULT_HISTORY_TITLE,[]),\n\t\ttargetTiddler = \"\";\n\tif(options.targetTiddler) {\n\t\ttargetTiddler = options.targetTiddler;\n\t} else {\n\t\t// The target tiddler is the one at the top of the stack\n\t\tif(historyList.length > 0) {\n\t\t\ttargetTiddler = historyList[historyList.length-1].title;\n\t\t}\n\t\t// Blank the target tiddler if it isn't present in the story\n\t\tif(storyList.indexOf(targetTiddler) === -1) {\n\t\t\ttargetTiddler = \"\";\n\t\t}\n\t}\n\t// Assemble the location hash\n\tswitch(options.updateAddressBar) {\n\t\tcase \"permalink\":\n\t\t\t$tw.locationHash = \"#\" + encodeURIComponent(targetTiddler);\n\t\t\tbreak;\n\t\tcase \"permaview\":\n\t\t\t$tw.locationHash = \"#\" + encodeURIComponent(targetTiddler) + \":\" + encodeURIComponent($tw.utils.stringifyList(storyList));\n\t\t\tbreak;\n\t}\n\t// Copy URL to the clipboard\n\tswitch(options.copyToClipboard) {\n\t\tcase \"permalink\":\n\t\t\t$tw.utils.copyToClipboard($tw.utils.getLocationPath() + \"#\" + encodeURIComponent(targetTiddler));\n\t\t\tbreak;\n\t\tcase \"permaview\":\n\t\t\t$tw.utils.copyToClipboard($tw.utils.getLocationPath() + \"#\" + encodeURIComponent(targetTiddler) + \":\" + encodeURIComponent($tw.utils.stringifyList(storyList)));\n\t\t\tbreak;\n\t}\n\t// Only change the location hash if we must, thus avoiding unnecessary onhashchange events\n\tif($tw.utils.getLocationHash() !== $tw.locationHash) {\n\t\tif(options.updateHistory === \"yes\") {\n\t\t\t// Assign the location hash so that history is updated\n\t\t\twindow.location.hash = $tw.locationHash;\n\t\t} else {\n\t\t\t// We use replace so that browser history isn't affected\n\t\t\twindow.location.replace(window.location.toString().split(\"#\")[0] + $tw.locationHash);\n\t\t}\n\t}\n}\n\n})();\n",
"type": "application/javascript",
"module-type": "startup"
},
"$:/core/modules/startup/windows.js": {
"title": "$:/core/modules/startup/windows.js",
"text": "/*\\\ntitle: $:/core/modules/startup/windows.js\ntype: application/javascript\nmodule-type: startup\n\nSetup root widget handlers for the messages concerned with opening external browser windows\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n// Export name and synchronous status\nexports.name = \"windows\";\nexports.platforms = [\"browser\"];\nexports.after = [\"startup\"];\nexports.synchronous = true;\n\n// Global to keep track of open windows (hashmap by title)\nvar windows = {};\n\nexports.startup = function() {\n\t// Handle open window message\n\t$tw.rootWidget.addEventListener(\"tm-open-window\",function(event) {\n\t\t// Get the parameters\n\t\tvar refreshHandler,\n\t\t\ttitle = event.param || event.tiddlerTitle,\n\t\t\tparamObject = event.paramObject || {},\n\t\t\ttemplate = paramObject.template || \"$:/core/templates/single.tiddler.window\",\n\t\t\twidth = paramObject.width || \"700\",\n\t\t\theight = paramObject.height || \"600\",\n\t\t\tvariables = $tw.utils.extend({},paramObject,{currentTiddler: title});\n\t\t// Open the window\n\t\tvar srcWindow,\n\t\t srcDocument;\n\t\t// In case that popup blockers deny opening a new window\n\t\ttry {\n\t\t\tsrcWindow = window.open(\"\",\"external-\" + title,\"scrollbars,width=\" + width + \",height=\" + height),\n\t\t\tsrcDocument = srcWindow.document;\n\t\t}\n\t\tcatch(e) {\n\t\t\treturn;\n\t\t}\n\t\twindows[title] = srcWindow;\n\t\t// Check for reopening the same window\n\t\tif(srcWindow.haveInitialisedWindow) {\n\t\t\treturn;\n\t\t}\n\t\t// Initialise the document\n\t\tsrcDocument.write(\"<html><head></head><body class='tc-body tc-single-tiddler-window'></body></html>\");\n\t\tsrcDocument.close();\n\t\tsrcDocument.title = title;\n\t\tsrcWindow.addEventListener(\"beforeunload\",function(event) {\n\t\t\tdelete windows[title];\n\t\t\t$tw.wiki.removeEventListener(\"change\",refreshHandler);\n\t\t},false);\n\t\t// Set up the styles\n\t\tvar styleWidgetNode = $tw.wiki.makeTranscludeWidget(\"$:/core/ui/PageStylesheet\",{\n\t\t\t\tdocument: $tw.fakeDocument,\n\t\t\t\tvariables: variables,\n\t\t\t\timportPageMacros: true}),\n\t\t\tstyleContainer = $tw.fakeDocument.createElement(\"style\");\n\t\tstyleWidgetNode.render(styleContainer,null);\n\t\tvar styleElement = srcDocument.createElement(\"style\");\n\t\tstyleElement.innerHTML = styleContainer.textContent;\n\t\tsrcDocument.head.insertBefore(styleElement,srcDocument.head.firstChild);\n\t\t// Render the text of the tiddler\n\t\tvar parser = $tw.wiki.parseTiddler(template),\n\t\t\twidgetNode = $tw.wiki.makeWidget(parser,{document: srcDocument, parentWidget: $tw.rootWidget, variables: variables});\n\t\twidgetNode.render(srcDocument.body,srcDocument.body.firstChild);\n\t\t// Function to handle refreshes\n\t\trefreshHandler = function(changes) {\n\t\t\tif(styleWidgetNode.refresh(changes,styleContainer,null)) {\n\t\t\t\tstyleElement.innerHTML = styleContainer.textContent;\n\t\t\t}\n\t\t\twidgetNode.refresh(changes);\n\t\t};\n\t\t$tw.wiki.addEventListener(\"change\",refreshHandler);\n\t\t// Listen for keyboard shortcuts\n\t\t$tw.utils.addEventListeners(srcDocument,[{\n\t\t\tname: \"keydown\",\n\t\t\thandlerObject: $tw.keyboardManager,\n\t\t\thandlerMethod: \"handleKeydownEvent\"\n\t\t},{\n\t\t\tname: \"click\",\n\t\t\thandlerObject: $tw.popup,\n\t\t\thandlerMethod: \"handleEvent\"\n\t\t}]);\n\t\tsrcWindow.haveInitialisedWindow = true;\n\t});\n\t// Close open windows when unloading main window\n\t$tw.addUnloadTask(function() {\n\t\t$tw.utils.each(windows,function(win) {\n\t\t\twin.close();\n\t\t});\n\t});\n\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "startup"
},
"$:/core/modules/story.js": {
"title": "$:/core/modules/story.js",
"text": "/*\\\ntitle: $:/core/modules/story.js\ntype: application/javascript\nmodule-type: global\n\nLightweight object for managing interactions with the story and history lists.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nConstruct Story object with options:\nwiki: reference to wiki object to use to resolve tiddler titles\nstoryTitle: title of story list tiddler\nhistoryTitle: title of history list tiddler\n*/\nfunction Story(options) {\n\toptions = options || {};\n\tthis.wiki = options.wiki || $tw.wiki;\n\tthis.storyTitle = options.storyTitle || \"$:/StoryList\";\n\tthis.historyTitle = options.historyTitle || \"$:/HistoryList\";\n};\n\nStory.prototype.navigateTiddler = function(navigateTo,navigateFromTitle,navigateFromClientRect) {\n\tthis.addToStory(navigateTo,navigateFromTitle);\n\tthis.addToHistory(navigateTo,navigateFromClientRect);\n};\n\nStory.prototype.getStoryList = function() {\n\treturn this.wiki.getTiddlerList(this.storyTitle) || [];\n};\n\nStory.prototype.addToStory = function(navigateTo,navigateFromTitle,options) {\n\toptions = options || {};\n\tvar storyList = this.getStoryList();\n\t// See if the tiddler is already there\n\tvar slot = storyList.indexOf(navigateTo);\n\t// Quit if it already exists in the story river\n\tif(slot >= 0) {\n\t\treturn;\n\t}\n\t// First we try to find the position of the story element we navigated from\n\tvar fromIndex = storyList.indexOf(navigateFromTitle);\n\tif(fromIndex >= 0) {\n\t\t// The tiddler is added from inside the river\n\t\t// Determine where to insert the tiddler; Fallback is \"below\"\n\t\tswitch(options.openLinkFromInsideRiver) {\n\t\t\tcase \"top\":\n\t\t\t\tslot = 0;\n\t\t\t\tbreak;\n\t\t\tcase \"bottom\":\n\t\t\t\tslot = storyList.length;\n\t\t\t\tbreak;\n\t\t\tcase \"above\":\n\t\t\t\tslot = fromIndex;\n\t\t\t\tbreak;\n\t\t\tcase \"below\": // Intentional fall-through\n\t\t\tdefault:\n\t\t\t\tslot = fromIndex + 1;\n\t\t\t\tbreak;\n\t\t}\n\t} else {\n\t\t// The tiddler is opened from outside the river. Determine where to insert the tiddler; default is \"top\"\n\t\tif(options.openLinkFromOutsideRiver === \"bottom\") {\n\t\t\t// Insert at bottom\n\t\t\tslot = storyList.length;\n\t\t} else {\n\t\t\t// Insert at top\n\t\t\tslot = 0;\n\t\t}\n\t}\n\t// Add the tiddler\n\tstoryList.splice(slot,0,navigateTo);\n\t// Save the story\n\tthis.saveStoryList(storyList);\n};\n\nStory.prototype.saveStoryList = function(storyList) {\n\tvar storyTiddler = this.wiki.getTiddler(this.storyTitle);\n\tthis.wiki.addTiddler(new $tw.Tiddler(\n\t\tthis.wiki.getCreationFields(),\n\t\t{title: this.storyTitle},\n\t\tstoryTiddler,\n\t\t{list: storyList},\n\t\tthis.wiki.getModificationFields()\n\t));\n};\n\nStory.prototype.addToHistory = function(navigateTo,navigateFromClientRect) {\n\tvar titles = $tw.utils.isArray(navigateTo) ? navigateTo : [navigateTo];\n\t// Add a new record to the top of the history stack\n\tvar historyList = this.wiki.getTiddlerData(this.historyTitle,[]);\n\t$tw.utils.each(titles,function(title) {\n\t\thistoryList.push({title: title, fromPageRect: navigateFromClientRect});\n\t});\n\tthis.wiki.setTiddlerData(this.historyTitle,historyList,{\"current-tiddler\": titles[titles.length-1]});\n};\n\nStory.prototype.storyCloseTiddler = function(targetTitle) {\n// TBD\n};\n\nStory.prototype.storyCloseAllTiddlers = function() {\n// TBD\n};\n\nStory.prototype.storyCloseOtherTiddlers = function(targetTitle) {\n// TBD\n};\n\nStory.prototype.storyEditTiddler = function(targetTitle) {\n// TBD\n};\n\nStory.prototype.storyDeleteTiddler = function(targetTitle) {\n// TBD\n};\n\nStory.prototype.storySaveTiddler = function(targetTitle) {\n// TBD\n};\n\nStory.prototype.storyCancelTiddler = function(targetTitle) {\n// TBD\n};\n\nStory.prototype.storyNewTiddler = function(targetTitle) {\n// TBD\n};\n\nexports.Story = Story;\n\n\n})();\n",
"type": "application/javascript",
"module-type": "global"
},
"$:/core/modules/storyviews/classic.js": {
"title": "$:/core/modules/storyviews/classic.js",
"text": "/*\\\ntitle: $:/core/modules/storyviews/classic.js\ntype: application/javascript\nmodule-type: storyview\n\nViews the story as a linear sequence\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar easing = \"cubic-bezier(0.645, 0.045, 0.355, 1)\"; // From http://easings.net/#easeInOutCubic\n\nvar ClassicStoryView = function(listWidget) {\n\tthis.listWidget = listWidget;\n};\n\nClassicStoryView.prototype.navigateTo = function(historyInfo) {\n\tvar listElementIndex = this.listWidget.findListItem(0,historyInfo.title);\n\tif(listElementIndex === undefined) {\n\t\treturn;\n\t}\n\tvar listItemWidget = this.listWidget.children[listElementIndex],\n\t\ttargetElement = listItemWidget.findFirstDomNode();\n\t// Abandon if the list entry isn't a DOM element (it might be a text node)\n\tif(!(targetElement instanceof Element)) {\n\t\treturn;\n\t}\n\t// Scroll the node into view\n\tthis.listWidget.dispatchEvent({type: \"tm-scroll\", target: targetElement});\n};\n\nClassicStoryView.prototype.insert = function(widget) {\n\tvar targetElement = widget.findFirstDomNode(),\n\t\tduration = $tw.utils.getAnimationDuration();\n\t// Abandon if the list entry isn't a DOM element (it might be a text node)\n\tif(!(targetElement instanceof Element)) {\n\t\treturn;\n\t}\n\t// Get the current height of the tiddler\n\tvar computedStyle = window.getComputedStyle(targetElement),\n\t\tcurrMarginBottom = parseInt(computedStyle.marginBottom,10),\n\t\tcurrMarginTop = parseInt(computedStyle.marginTop,10),\n\t\tcurrHeight = targetElement.offsetHeight + currMarginTop;\n\t// Reset the margin once the transition is over\n\tsetTimeout(function() {\n\t\t$tw.utils.setStyle(targetElement,[\n\t\t\t{transition: \"none\"},\n\t\t\t{marginBottom: \"\"}\n\t\t]);\n\t},duration);\n\t// Set up the initial position of the element\n\t$tw.utils.setStyle(targetElement,[\n\t\t{transition: \"none\"},\n\t\t{marginBottom: (-currHeight) + \"px\"},\n\t\t{opacity: \"0.0\"}\n\t]);\n\t$tw.utils.forceLayout(targetElement);\n\t// Transition to the final position\n\t$tw.utils.setStyle(targetElement,[\n\t\t{transition: \"opacity \" + duration + \"ms \" + easing + \", \" +\n\t\t\t\t\t\"margin-bottom \" + duration + \"ms \" + easing},\n\t\t{marginBottom: currMarginBottom + \"px\"},\n\t\t{opacity: \"1.0\"}\n\t]);\n};\n\nClassicStoryView.prototype.remove = function(widget) {\n\tvar targetElement = widget.findFirstDomNode(),\n\t\tduration = $tw.utils.getAnimationDuration(),\n\t\tremoveElement = function() {\n\t\t\twidget.removeChildDomNodes();\n\t\t};\n\t// Abandon if the list entry isn't a DOM element (it might be a text node)\n\tif(!(targetElement instanceof Element)) {\n\t\tremoveElement();\n\t\treturn;\n\t}\n\t// Get the current height of the tiddler\n\tvar currWidth = targetElement.offsetWidth,\n\t\tcomputedStyle = window.getComputedStyle(targetElement),\n\t\tcurrMarginBottom = parseInt(computedStyle.marginBottom,10),\n\t\tcurrMarginTop = parseInt(computedStyle.marginTop,10),\n\t\tcurrHeight = targetElement.offsetHeight + currMarginTop;\n\t// Remove the dom nodes of the widget at the end of the transition\n\tsetTimeout(removeElement,duration);\n\t// Animate the closure\n\t$tw.utils.setStyle(targetElement,[\n\t\t{transition: \"none\"},\n\t\t{transform: \"translateX(0px)\"},\n\t\t{marginBottom: currMarginBottom + \"px\"},\n\t\t{opacity: \"1.0\"}\n\t]);\n\t$tw.utils.forceLayout(targetElement);\n\t$tw.utils.setStyle(targetElement,[\n\t\t{transition: $tw.utils.roundTripPropertyName(\"transform\") + \" \" + duration + \"ms \" + easing + \", \" +\n\t\t\t\t\t\"opacity \" + duration + \"ms \" + easing + \", \" +\n\t\t\t\t\t\"margin-bottom \" + duration + \"ms \" + easing},\n\t\t{transform: \"translateX(-\" + currWidth + \"px)\"},\n\t\t{marginBottom: (-currHeight) + \"px\"},\n\t\t{opacity: \"0.0\"}\n\t]);\n};\n\nexports.classic = ClassicStoryView;\n\n})();",
"type": "application/javascript",
"module-type": "storyview"
},
"$:/core/modules/storyviews/pop.js": {
"title": "$:/core/modules/storyviews/pop.js",
"text": "/*\\\ntitle: $:/core/modules/storyviews/pop.js\ntype: application/javascript\nmodule-type: storyview\n\nAnimates list insertions and removals\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar PopStoryView = function(listWidget) {\n\tthis.listWidget = listWidget;\n};\n\nPopStoryView.prototype.navigateTo = function(historyInfo) {\n\tvar listElementIndex = this.listWidget.findListItem(0,historyInfo.title);\n\tif(listElementIndex === undefined) {\n\t\treturn;\n\t}\n\tvar listItemWidget = this.listWidget.children[listElementIndex],\n\t\ttargetElement = listItemWidget.findFirstDomNode();\n\t// Abandon if the list entry isn't a DOM element (it might be a text node)\n\tif(!(targetElement instanceof Element)) {\n\t\treturn;\n\t}\n\t// Scroll the node into view\n\tthis.listWidget.dispatchEvent({type: \"tm-scroll\", target: targetElement});\n};\n\nPopStoryView.prototype.insert = function(widget) {\n\tvar targetElement = widget.findFirstDomNode(),\n\t\tduration = $tw.utils.getAnimationDuration();\n\t// Abandon if the list entry isn't a DOM element (it might be a text node)\n\tif(!(targetElement instanceof Element)) {\n\t\treturn;\n\t}\n\t// Reset once the transition is over\n\tsetTimeout(function() {\n\t\t$tw.utils.setStyle(targetElement,[\n\t\t\t{transition: \"none\"},\n\t\t\t{transform: \"none\"}\n\t\t]);\n\t},duration);\n\t// Set up the initial position of the element\n\t$tw.utils.setStyle(targetElement,[\n\t\t{transition: \"none\"},\n\t\t{transform: \"scale(2)\"},\n\t\t{opacity: \"0.0\"}\n\t]);\n\t$tw.utils.forceLayout(targetElement);\n\t// Transition to the final position\n\t$tw.utils.setStyle(targetElement,[\n\t\t{transition: $tw.utils.roundTripPropertyName(\"transform\") + \" \" + duration + \"ms ease-in-out, \" +\n\t\t\t\t\t\"opacity \" + duration + \"ms ease-in-out\"},\n\t\t{transform: \"scale(1)\"},\n\t\t{opacity: \"1.0\"}\n\t]);\n};\n\nPopStoryView.prototype.remove = function(widget) {\n\tvar targetElement = widget.findFirstDomNode(),\n\t\tduration = $tw.utils.getAnimationDuration(),\n\t\tremoveElement = function() {\n\t\t\tif(targetElement.parentNode) {\n\t\t\t\twidget.removeChildDomNodes();\n\t\t\t}\n\t\t};\n\t// Abandon if the list entry isn't a DOM element (it might be a text node)\n\tif(!(targetElement instanceof Element)) {\n\t\tremoveElement();\n\t\treturn;\n\t}\n\t// Remove the element at the end of the transition\n\tsetTimeout(removeElement,duration);\n\t// Animate the closure\n\t$tw.utils.setStyle(targetElement,[\n\t\t{transition: \"none\"},\n\t\t{transform: \"scale(1)\"},\n\t\t{opacity: \"1.0\"}\n\t]);\n\t$tw.utils.forceLayout(targetElement);\n\t$tw.utils.setStyle(targetElement,[\n\t\t{transition: $tw.utils.roundTripPropertyName(\"transform\") + \" \" + duration + \"ms ease-in-out, \" +\n\t\t\t\t\t\"opacity \" + duration + \"ms ease-in-out\"},\n\t\t{transform: \"scale(0.1)\"},\n\t\t{opacity: \"0.0\"}\n\t]);\n};\n\nexports.pop = PopStoryView;\n\n})();\n",
"type": "application/javascript",
"module-type": "storyview"
},
"$:/core/modules/storyviews/zoomin.js": {
"title": "$:/core/modules/storyviews/zoomin.js",
"text": "/*\\\ntitle: $:/core/modules/storyviews/zoomin.js\ntype: application/javascript\nmodule-type: storyview\n\nZooms between individual tiddlers\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar easing = \"cubic-bezier(0.645, 0.045, 0.355, 1)\"; // From http://easings.net/#easeInOutCubic\n\nvar ZoominListView = function(listWidget) {\n\tvar self = this;\n\tthis.listWidget = listWidget;\n\t// Get the index of the tiddler that is at the top of the history\n\tvar history = this.listWidget.wiki.getTiddlerDataCached(this.listWidget.historyTitle,[]),\n\t\ttargetTiddler;\n\tif(history.length > 0) {\n\t\ttargetTiddler = history[history.length-1].title;\n\t}\n\t// Make all the tiddlers position absolute, and hide all but the top (or first) one\n\t$tw.utils.each(this.listWidget.children,function(itemWidget,index) {\n\t\tvar domNode = itemWidget.findFirstDomNode();\n\t\t// Abandon if the list entry isn't a DOM element (it might be a text node)\n\t\tif(!(domNode instanceof Element)) {\n\t\t\treturn;\n\t\t}\n\t\tif((targetTiddler && targetTiddler !== itemWidget.parseTreeNode.itemTitle) || (!targetTiddler && index)) {\n\t\t\tdomNode.style.display = \"none\";\n\t\t} else {\n\t\t\tself.currentTiddlerDomNode = domNode;\n\t\t}\n\t\t$tw.utils.addClass(domNode,\"tc-storyview-zoomin-tiddler\");\n\t});\n};\n\nZoominListView.prototype.navigateTo = function(historyInfo) {\n\tvar duration = $tw.utils.getAnimationDuration(),\n\t\tlistElementIndex = this.listWidget.findListItem(0,historyInfo.title);\n\tif(listElementIndex === undefined) {\n\t\treturn;\n\t}\n\tvar listItemWidget = this.listWidget.children[listElementIndex],\n\t\ttargetElement = listItemWidget.findFirstDomNode();\n\t// Abandon if the list entry isn't a DOM element (it might be a text node)\n\tif(!(targetElement instanceof Element)) {\n\t\treturn;\n\t}\n\t// Make the new tiddler be position absolute and visible so that we can measure it\n\t$tw.utils.addClass(targetElement,\"tc-storyview-zoomin-tiddler\");\n\t$tw.utils.setStyle(targetElement,[\n\t\t{display: \"block\"},\n\t\t{transformOrigin: \"0 0\"},\n\t\t{transform: \"translateX(0px) translateY(0px) scale(1)\"},\n\t\t{transition: \"none\"},\n\t\t{opacity: \"0.0\"}\n\t]);\n\t// Get the position of the source node, or use the centre of the window as the source position\n\tvar sourceBounds = historyInfo.fromPageRect || {\n\t\t\tleft: window.innerWidth/2 - 2,\n\t\t\ttop: window.innerHeight/2 - 2,\n\t\t\twidth: window.innerWidth/8,\n\t\t\theight: window.innerHeight/8\n\t\t};\n\t// Try to find the title node in the target tiddler\n\tvar titleDomNode = findTitleDomNode(listItemWidget) || listItemWidget.findFirstDomNode(),\n\t\tzoomBounds = titleDomNode.getBoundingClientRect();\n\t// Compute the transform for the target tiddler to make the title lie over the source rectange\n\tvar targetBounds = targetElement.getBoundingClientRect(),\n\t\tscale = sourceBounds.width / zoomBounds.width,\n\t\tx = sourceBounds.left - targetBounds.left - (zoomBounds.left - targetBounds.left) * scale,\n\t\ty = sourceBounds.top - targetBounds.top - (zoomBounds.top - targetBounds.top) * scale;\n\t// Transform the target tiddler to its starting position\n\t$tw.utils.setStyle(targetElement,[\n\t\t{transform: \"translateX(\" + x + \"px) translateY(\" + y + \"px) scale(\" + scale + \")\"}\n\t]);\n\t// Force layout\n\t$tw.utils.forceLayout(targetElement);\n\t// Apply the ending transitions with a timeout to ensure that the previously applied transformations are applied first\n\tvar self = this,\n\t\tprevCurrentTiddler = this.currentTiddlerDomNode;\n\tthis.currentTiddlerDomNode = targetElement;\n\t// Transform the target tiddler to its natural size\n\t$tw.utils.setStyle(targetElement,[\n\t\t{transition: $tw.utils.roundTripPropertyName(\"transform\") + \" \" + duration + \"ms \" + easing + \", opacity \" + duration + \"ms \" + easing},\n\t\t{opacity: \"1.0\"},\n\t\t{transform: \"translateX(0px) translateY(0px) scale(1)\"},\n\t\t{zIndex: \"500\"},\n\t]);\n\t// Transform the previous tiddler out of the way and then hide it\n\tif(prevCurrentTiddler && prevCurrentTiddler !== targetElement) {\n\t\tscale = zoomBounds.width / sourceBounds.width;\n\t\tx = zoomBounds.left - targetBounds.left - (sourceBounds.left - targetBounds.left) * scale;\n\t\ty = zoomBounds.top - targetBounds.top - (sourceBounds.top - targetBounds.top) * scale;\n\t\t$tw.utils.setStyle(prevCurrentTiddler,[\n\t\t\t{transition: $tw.utils.roundTripPropertyName(\"transform\") + \" \" + duration + \"ms \" + easing + \", opacity \" + duration + \"ms \" + easing},\n\t\t\t{opacity: \"0.0\"},\n\t\t\t{transformOrigin: \"0 0\"},\n\t\t\t{transform: \"translateX(\" + x + \"px) translateY(\" + y + \"px) scale(\" + scale + \")\"},\n\t\t\t{zIndex: \"0\"}\n\t\t]);\n\t\t// Hide the tiddler when the transition has finished\n\t\tsetTimeout(function() {\n\t\t\tif(self.currentTiddlerDomNode !== prevCurrentTiddler) {\n\t\t\t\tprevCurrentTiddler.style.display = \"none\";\n\t\t\t}\n\t\t},duration);\n\t}\n\t// Scroll the target into view\n//\t$tw.pageScroller.scrollIntoView(targetElement);\n};\n\n/*\nFind the first child DOM node of a widget that has the class \"tc-title\"\n*/\nfunction findTitleDomNode(widget,targetClass) {\n\ttargetClass = targetClass || \"tc-title\";\n\tvar domNode = widget.findFirstDomNode();\n\tif(domNode && domNode.querySelector) {\n\t\treturn domNode.querySelector(\".\" + targetClass);\n\t}\n\treturn null;\n}\n\nZoominListView.prototype.insert = function(widget) {\n\tvar targetElement = widget.findFirstDomNode();\n\t// Abandon if the list entry isn't a DOM element (it might be a text node)\n\tif(!(targetElement instanceof Element)) {\n\t\treturn;\n\t}\n\t// Make the newly inserted node position absolute and hidden\n\t$tw.utils.addClass(targetElement,\"tc-storyview-zoomin-tiddler\");\n\t$tw.utils.setStyle(targetElement,[\n\t\t{display: \"none\"}\n\t]);\n};\n\nZoominListView.prototype.remove = function(widget) {\n\tvar targetElement = widget.findFirstDomNode(),\n\t\tduration = $tw.utils.getAnimationDuration(),\n\t\tremoveElement = function() {\n\t\t\twidget.removeChildDomNodes();\n\t\t};\n\t// Abandon if the list entry isn't a DOM element (it might be a text node)\n\tif(!(targetElement instanceof Element)) {\n\t\tremoveElement();\n\t\treturn;\n\t}\n\t// Abandon if hidden\n\tif(targetElement.style.display != \"block\" ) {\n\t\tremoveElement();\n\t\treturn;\n\t}\n\t// Set up the tiddler that is being closed\n\t$tw.utils.addClass(targetElement,\"tc-storyview-zoomin-tiddler\");\n\t$tw.utils.setStyle(targetElement,[\n\t\t{display: \"block\"},\n\t\t{transformOrigin: \"50% 50%\"},\n\t\t{transform: \"translateX(0px) translateY(0px) scale(1)\"},\n\t\t{transition: \"none\"},\n\t\t{zIndex: \"0\"}\n\t]);\n\t// We'll move back to the previous or next element in the story\n\tvar toWidget = widget.previousSibling();\n\tif(!toWidget) {\n\t\ttoWidget = widget.nextSibling();\n\t}\n\tvar toWidgetDomNode = toWidget && toWidget.findFirstDomNode();\n\t// Set up the tiddler we're moving back in\n\tif(toWidgetDomNode) {\n\t\t$tw.utils.addClass(toWidgetDomNode,\"tc-storyview-zoomin-tiddler\");\n\t\t$tw.utils.setStyle(toWidgetDomNode,[\n\t\t\t{display: \"block\"},\n\t\t\t{transformOrigin: \"50% 50%\"},\n\t\t\t{transform: \"translateX(0px) translateY(0px) scale(10)\"},\n\t\t\t{transition: $tw.utils.roundTripPropertyName(\"transform\") + \" \" + duration + \"ms \" + easing + \", opacity \" + duration + \"ms \" + easing},\n\t\t\t{opacity: \"0\"},\n\t\t\t{zIndex: \"500\"}\n\t\t]);\n\t\tthis.currentTiddlerDomNode = toWidgetDomNode;\n\t}\n\t// Animate them both\n\t// Force layout\n\t$tw.utils.forceLayout(this.listWidget.parentDomNode);\n\t// First, the tiddler we're closing\n\t$tw.utils.setStyle(targetElement,[\n\t\t{transformOrigin: \"50% 50%\"},\n\t\t{transform: \"translateX(0px) translateY(0px) scale(0.1)\"},\n\t\t{transition: $tw.utils.roundTripPropertyName(\"transform\") + \" \" + duration + \"ms \" + easing + \", opacity \" + duration + \"ms \" + easing},\n\t\t{opacity: \"0\"},\n\t\t{zIndex: \"0\"}\n\t]);\n\tsetTimeout(removeElement,duration);\n\t// Now the tiddler we're going back to\n\tif(toWidgetDomNode) {\n\t\t$tw.utils.setStyle(toWidgetDomNode,[\n\t\t\t{transform: \"translateX(0px) translateY(0px) scale(1)\"},\n\t\t\t{opacity: \"1\"}\n\t\t]);\n\t}\n\treturn true; // Indicate that we'll delete the DOM node\n};\n\nexports.zoomin = ZoominListView;\n\n})();\n",
"type": "application/javascript",
"module-type": "storyview"
},
"$:/core/modules/syncer.js": {
"title": "$:/core/modules/syncer.js",
"text": "/*\\\ntitle: $:/core/modules/syncer.js\ntype: application/javascript\nmodule-type: global\n\nThe syncer tracks changes to the store. If a syncadaptor is used then individual tiddlers are synchronised through it. If there is no syncadaptor then the entire wiki is saved via saver modules.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nDefaults\n*/\nSyncer.prototype.titleIsLoggedIn = \"$:/status/IsLoggedIn\";\nSyncer.prototype.titleIsAnonymous = \"$:/status/IsAnonymous\";\nSyncer.prototype.titleIsReadOnly = \"$:/status/IsReadOnly\";\nSyncer.prototype.titleUserName = \"$:/status/UserName\";\nSyncer.prototype.titleSyncFilter = \"$:/config/SyncFilter\";\nSyncer.prototype.titleSyncPollingInterval = \"$:/config/SyncPollingInterval\";\nSyncer.prototype.titleSavedNotification = \"$:/language/Notifications/Save/Done\";\nSyncer.prototype.taskTimerInterval = 1 * 1000; // Interval for sync timer\nSyncer.prototype.throttleInterval = 1 * 1000; // Defer saving tiddlers if they've changed in the last 1s...\nSyncer.prototype.fallbackInterval = 10 * 1000; // Unless the task is older than 10s\nSyncer.prototype.pollTimerInterval = 60 * 1000; // Interval for polling for changes from the adaptor\n\n/*\nInstantiate the syncer with the following options:\nsyncadaptor: reference to syncadaptor to be used\nwiki: wiki to be synced\n*/\nfunction Syncer(options) {\n\tvar self = this;\n\tthis.wiki = options.wiki;\n\tthis.syncadaptor = options.syncadaptor;\n\tthis.disableUI = !!options.disableUI;\n\tthis.titleIsLoggedIn = options.titleIsLoggedIn || this.titleIsLoggedIn;\n\tthis.titleUserName = options.titleUserName || this.titleUserName;\n\tthis.titleSyncFilter = options.titleSyncFilter || this.titleSyncFilter;\n\tthis.titleSavedNotification = options.titleSavedNotification || this.titleSavedNotification;\n\tthis.taskTimerInterval = options.taskTimerInterval || this.taskTimerInterval;\n\tthis.throttleInterval = options.throttleInterval || this.throttleInterval;\n\tthis.fallbackInterval = options.fallbackInterval || this.fallbackInterval;\n\tthis.pollTimerInterval = options.pollTimerInterval || parseInt(this.wiki.getTiddlerText(this.titleSyncPollingInterval,\"\"),10) || this.pollTimerInterval;\n\tthis.logging = \"logging\" in options ? options.logging : true;\n\t// Make a logger\n\tthis.logger = new $tw.utils.Logger(\"syncer\" + ($tw.browser ? \"-browser\" : \"\") + ($tw.node ? \"-server\" : \"\") + (this.syncadaptor.name ? (\"-\" + this.syncadaptor.name) : \"\"),{\n\t\t\tcolour: \"cyan\",\n\t\t\tenable: this.logging\n\t\t});\n\t// Compile the dirty tiddler filter\n\tthis.filterFn = this.wiki.compileFilter(this.wiki.getTiddlerText(this.titleSyncFilter));\n\t// Record information for known tiddlers\n\tthis.readTiddlerInfo();\n\t// Tasks are {type: \"load\"/\"save\"/\"delete\", title:, queueTime:, lastModificationTime:}\n\tthis.taskQueue = {}; // Hashmap of tasks yet to be performed\n\tthis.taskInProgress = {}; // Hash of tasks in progress\n\tthis.taskTimerId = null; // Timer for task dispatch\n\tthis.pollTimerId = null; // Timer for polling server\n\t// Listen out for changes to tiddlers\n\tthis.wiki.addEventListener(\"change\",function(changes) {\n\t\tself.syncToServer(changes);\n\t});\n\t// Browser event handlers\n\tif($tw.browser && !this.disableUI) {\n\t\t// Set up our beforeunload handler\n\t\t$tw.addUnloadTask(function(event) {\n\t\t\tvar confirmationMessage;\n\t\t\tif(self.isDirty()) {\n\t\t\t\tconfirmationMessage = $tw.language.getString(\"UnsavedChangesWarning\");\n\t\t\t\tevent.returnValue = confirmationMessage; // Gecko\n\t\t\t}\n\t\t\treturn confirmationMessage;\n\t\t});\n\t\t// Listen out for login/logout/refresh events in the browser\n\t\t$tw.rootWidget.addEventListener(\"tm-login\",function() {\n\t\t\tself.handleLoginEvent();\n\t\t});\n\t\t$tw.rootWidget.addEventListener(\"tm-logout\",function() {\n\t\t\tself.handleLogoutEvent();\n\t\t});\n\t\t$tw.rootWidget.addEventListener(\"tm-server-refresh\",function() {\n\t\t\tself.handleRefreshEvent();\n\t\t});\n\t}\n\t// Listen out for lazyLoad events\n\tif(!this.disableUI) {\n\t\tthis.wiki.addEventListener(\"lazyLoad\",function(title) {\n\t\t\tself.handleLazyLoadEvent(title);\n\t\t});\t\t\n\t}\n\t// Get the login status\n\tthis.getStatus(function(err,isLoggedIn) {\n\t\t// Do a sync from the server\n\t\tself.syncFromServer();\n\t});\n}\n\n/*\nRead (or re-read) the latest tiddler info from the store\n*/\nSyncer.prototype.readTiddlerInfo = function() {\n\t// Hashmap by title of {revision:,changeCount:,adaptorInfo:}\n\tthis.tiddlerInfo = {};\n\t// Record information for known tiddlers\n\tvar self = this,\n\t\ttiddlers = this.filterFn.call(this.wiki);\n\t$tw.utils.each(tiddlers,function(title) {\n\t\tvar tiddler = self.wiki.getTiddler(title);\n\t\tself.tiddlerInfo[title] = {\n\t\t\trevision: tiddler.fields.revision,\n\t\t\tadaptorInfo: self.syncadaptor && self.syncadaptor.getTiddlerInfo(tiddler),\n\t\t\tchangeCount: self.wiki.getChangeCount(title),\n\t\t\thasBeenLazyLoaded: false\n\t\t};\n\t});\n};\n\n/*\nCreate an tiddlerInfo structure if it doesn't already exist\n*/\nSyncer.prototype.createTiddlerInfo = function(title) {\n\tif(!$tw.utils.hop(this.tiddlerInfo,title)) {\n\t\tthis.tiddlerInfo[title] = {\n\t\t\trevision: null,\n\t\t\tadaptorInfo: {},\n\t\t\tchangeCount: -1,\n\t\t\thasBeenLazyLoaded: false\n\t\t};\n\t}\n};\n\n/*\nChecks whether the wiki is dirty (ie the window shouldn't be closed)\n*/\nSyncer.prototype.isDirty = function() {\n\treturn (this.numTasksInQueue() > 0) || (this.numTasksInProgress() > 0);\n};\n\n/*\nUpdate the document body with the class \"tc-dirty\" if the wiki has unsaved/unsynced changes\n*/\nSyncer.prototype.updateDirtyStatus = function() {\n\tif($tw.browser && !this.disableUI) {\n\t\t$tw.utils.toggleClass(document.body,\"tc-dirty\",this.isDirty());\n\t}\n};\n\n/*\nSave an incoming tiddler in the store, and updates the associated tiddlerInfo\n*/\nSyncer.prototype.storeTiddler = function(tiddlerFields,hasBeenLazyLoaded) {\n\t// Save the tiddler\n\tvar tiddler = new $tw.Tiddler(tiddlerFields);\n\tthis.wiki.addTiddler(tiddler);\n\t// Save the tiddler revision and changeCount details\n\tthis.tiddlerInfo[tiddlerFields.title] = {\n\t\trevision: tiddlerFields.revision,\n\t\tadaptorInfo: this.syncadaptor.getTiddlerInfo(tiddler),\n\t\tchangeCount: this.wiki.getChangeCount(tiddlerFields.title),\n\t\thasBeenLazyLoaded: hasBeenLazyLoaded !== undefined ? hasBeenLazyLoaded : true\n\t};\n};\n\nSyncer.prototype.getStatus = function(callback) {\n\tvar self = this;\n\t// Check if the adaptor supports getStatus()\n\tif(this.syncadaptor && this.syncadaptor.getStatus) {\n\t\t// Mark us as not logged in\n\t\tthis.wiki.addTiddler({title: this.titleIsLoggedIn,text: \"no\"});\n\t\t// Get login status\n\t\tthis.syncadaptor.getStatus(function(err,isLoggedIn,username,isReadOnly,isAnonymous) {\n\t\t\tif(err) {\n\t\t\t\tself.logger.alert(err);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\t// Set the various status tiddlers\n\t\t\tself.wiki.addTiddler({title: self.titleIsReadOnly,text: isReadOnly ? \"yes\" : \"no\"});\n\t\t\tself.wiki.addTiddler({title: self.titleIsAnonymous,text: isAnonymous ? \"yes\" : \"no\"});\n\t\t\tself.wiki.addTiddler({title: self.titleIsLoggedIn,text: isLoggedIn ? \"yes\" : \"no\"});\n\t\t\tif(isLoggedIn) {\n\t\t\t\tself.wiki.addTiddler({title: self.titleUserName,text: username || \"\"});\n\t\t\t}\n\t\t\t// Invoke the callback\n\t\t\tif(callback) {\n\t\t\t\tcallback(err,isLoggedIn,username);\n\t\t\t}\n\t\t});\n\t} else {\n\t\tcallback(null,true,\"UNAUTHENTICATED\");\n\t}\n};\n\n/*\nSynchronise from the server by reading the skinny tiddler list and queuing up loads for any tiddlers that we don't already have up to date\n*/\nSyncer.prototype.syncFromServer = function() {\n\tif(this.syncadaptor && this.syncadaptor.getSkinnyTiddlers) {\n\t\tthis.logger.log(\"Retrieving skinny tiddler list\");\n\t\tvar self = this;\n\t\tif(this.pollTimerId) {\n\t\t\tclearTimeout(this.pollTimerId);\n\t\t\tthis.pollTimerId = null;\n\t\t}\n\t\tthis.syncadaptor.getSkinnyTiddlers(function(err,tiddlers) {\n\t\t\t// Trigger the next sync\n\t\t\tself.pollTimerId = setTimeout(function() {\n\t\t\t\tself.pollTimerId = null;\n\t\t\t\tself.syncFromServer.call(self);\n\t\t\t},self.pollTimerInterval);\n\t\t\t// Check for errors\n\t\t\tif(err) {\n\t\t\t\tself.logger.alert($tw.language.getString(\"Error/RetrievingSkinny\") + \":\",err);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\t// Process each incoming tiddler\n\t\t\tfor(var t=0; t<tiddlers.length; t++) {\n\t\t\t\t// Get the incoming tiddler fields, and the existing tiddler\n\t\t\t\tvar tiddlerFields = tiddlers[t],\n\t\t\t\t\tincomingRevision = tiddlerFields.revision + \"\",\n\t\t\t\t\ttiddler = self.wiki.getTiddler(tiddlerFields.title),\n\t\t\t\t\ttiddlerInfo = self.tiddlerInfo[tiddlerFields.title],\n\t\t\t\t\tcurrRevision = tiddlerInfo ? tiddlerInfo.revision : null;\n\t\t\t\t// Ignore the incoming tiddler if it's the same as the revision we've already got\n\t\t\t\tif(currRevision !== incomingRevision) {\n\t\t\t\t\t// Do a full load if we've already got a fat version of the tiddler\n\t\t\t\t\tif(tiddler && tiddler.fields.text !== undefined) {\n\t\t\t\t\t\t// Do a full load of this tiddler\n\t\t\t\t\t\tself.enqueueSyncTask({\n\t\t\t\t\t\t\ttype: \"load\",\n\t\t\t\t\t\t\ttitle: tiddlerFields.title\n\t\t\t\t\t\t});\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// Load the skinny version of the tiddler\n\t\t\t\t\t\tself.storeTiddler(tiddlerFields,false);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n};\n\n/*\nSynchronise a set of changes to the server\n*/\nSyncer.prototype.syncToServer = function(changes) {\n\tvar self = this,\n\t\tnow = Date.now(),\n\t\tfilteredChanges = this.filterFn.call(this.wiki,function(callback) {\n\t\t\t$tw.utils.each(changes,function(change,title) {\n\t\t\t\tvar tiddler = self.wiki.getTiddler(title);\n\t\t\t\tcallback(tiddler,title);\n\t\t\t});\n\t\t});\n\t$tw.utils.each(changes,function(change,title,object) {\n\t\t// Process the change if it is a deletion of a tiddler we're already syncing, or is on the filtered change list\n\t\tif((change.deleted && $tw.utils.hop(self.tiddlerInfo,title)) || filteredChanges.indexOf(title) !== -1) {\n\t\t\t// Queue a task to sync this tiddler\n\t\t\tself.enqueueSyncTask({\n\t\t\t\ttype: change.deleted ? \"delete\" : \"save\",\n\t\t\t\ttitle: title\n\t\t\t});\n\t\t}\n\t});\n};\n\n/*\nLazily load a skinny tiddler if we can\n*/\nSyncer.prototype.handleLazyLoadEvent = function(title) {\n\t// Don't lazy load the same tiddler twice\n\tvar info = this.tiddlerInfo[title];\n\tif(!info || !info.hasBeenLazyLoaded) {\n\t\t// Don't lazy load if the tiddler isn't included in the sync filter\n\t\tif(this.filterFn.call(this.wiki).indexOf(title) !== -1) {\n\t\t\tthis.createTiddlerInfo(title);\n\t\t\tthis.tiddlerInfo[title].hasBeenLazyLoaded = true;\n\t\t\t// Queue up a sync task to load this tiddler\n\t\t\tthis.enqueueSyncTask({\n\t\t\t\ttype: \"load\",\n\t\t\t\ttitle: title\n\t\t\t});\n\t\t}\n\t}\n};\n\n/*\nDispay a password prompt and allow the user to login\n*/\nSyncer.prototype.handleLoginEvent = function() {\n\tvar self = this;\n\tthis.getStatus(function(err,isLoggedIn,username) {\n\t\tif(!isLoggedIn) {\n\t\t\t$tw.passwordPrompt.createPrompt({\n\t\t\t\tserviceName: $tw.language.getString(\"LoginToTiddlySpace\"),\n\t\t\t\tcallback: function(data) {\n\t\t\t\t\tself.login(data.username,data.password,function(err,isLoggedIn) {\n\t\t\t\t\t\tself.syncFromServer();\n\t\t\t\t\t});\n\t\t\t\t\treturn true; // Get rid of the password prompt\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t});\n};\n\n/*\nAttempt to login to TiddlyWeb.\n\tusername: username\n\tpassword: password\n\tcallback: invoked with arguments (err,isLoggedIn)\n*/\nSyncer.prototype.login = function(username,password,callback) {\n\tthis.logger.log(\"Attempting to login as\",username);\n\tvar self = this;\n\tif(this.syncadaptor.login) {\n\t\tthis.syncadaptor.login(username,password,function(err) {\n\t\t\tif(err) {\n\t\t\t\treturn callback(err);\n\t\t\t}\n\t\t\tself.getStatus(function(err,isLoggedIn,username) {\n\t\t\t\tif(callback) {\n\t\t\t\t\tcallback(null,isLoggedIn);\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t} else {\n\t\tcallback(null,true);\n\t}\n};\n\n/*\nAttempt to log out of TiddlyWeb\n*/\nSyncer.prototype.handleLogoutEvent = function() {\n\tthis.logger.log(\"Attempting to logout\");\n\tvar self = this;\n\tif(this.syncadaptor.logout) {\n\t\tthis.syncadaptor.logout(function(err) {\n\t\t\tif(err) {\n\t\t\t\tself.logger.alert(err);\n\t\t\t} else {\n\t\t\t\tself.getStatus();\n\t\t\t}\n\t\t});\n\t}\n};\n\n/*\nImmediately refresh from the server\n*/\nSyncer.prototype.handleRefreshEvent = function() {\n\tthis.syncFromServer();\n};\n\n/*\nQueue up a sync task. If there is already a pending task for the tiddler, just update the last modification time\n*/\nSyncer.prototype.enqueueSyncTask = function(task) {\n\tvar self = this,\n\t\tnow = Date.now();\n\t// Set the timestamps on this task\n\ttask.queueTime = now;\n\ttask.lastModificationTime = now;\n\t// Fill in some tiddlerInfo if the tiddler is one we haven't seen before\n\tthis.createTiddlerInfo(task.title);\n\t// Bail if this is a save and the tiddler is already at the changeCount that the server has\n\tif(task.type === \"save\" && this.wiki.getChangeCount(task.title) <= this.tiddlerInfo[task.title].changeCount) {\n\t\treturn;\n\t}\n\t// Check if this tiddler is already in the queue\n\tif($tw.utils.hop(this.taskQueue,task.title)) {\n\t\t// this.logger.log(\"Re-queueing up sync task with type:\",task.type,\"title:\",task.title);\n\t\tvar existingTask = this.taskQueue[task.title];\n\t\t// If so, just update the last modification time\n\t\texistingTask.lastModificationTime = task.lastModificationTime;\n\t\t// If the new task is a save then we upgrade the existing task to a save. Thus a pending load is turned into a save if the tiddler changes locally in the meantime. But a pending save is not modified to become a load\n\t\tif(task.type === \"save\" || task.type === \"delete\") {\n\t\t\texistingTask.type = task.type;\n\t\t}\n\t} else {\n\t\t// this.logger.log(\"Queuing up sync task with type:\",task.type,\"title:\",task.title);\n\t\t// If it is not in the queue, insert it\n\t\tthis.taskQueue[task.title] = task;\n\t\tthis.updateDirtyStatus();\n\t}\n\t// Process the queue\n\t$tw.utils.nextTick(function() {self.processTaskQueue.call(self);});\n};\n\n/*\nReturn the number of tasks in progress\n*/\nSyncer.prototype.numTasksInProgress = function() {\n\treturn $tw.utils.count(this.taskInProgress);\n};\n\n/*\nReturn the number of tasks in the queue\n*/\nSyncer.prototype.numTasksInQueue = function() {\n\treturn $tw.utils.count(this.taskQueue);\n};\n\n/*\nTrigger a timeout if one isn't already outstanding\n*/\nSyncer.prototype.triggerTimeout = function() {\n\tvar self = this;\n\tif(!this.taskTimerId) {\n\t\tthis.taskTimerId = setTimeout(function() {\n\t\t\tself.taskTimerId = null;\n\t\t\tself.processTaskQueue.call(self);\n\t\t},self.taskTimerInterval);\n\t}\n};\n\n/*\nProcess the task queue, performing the next task if appropriate\n*/\nSyncer.prototype.processTaskQueue = function() {\n\tvar self = this;\n\t// Only process a task if the sync adaptor is fully initialised and we're not already performing a task. If we are already performing a task then we'll dispatch the next one when it completes\n\tif((!this.syncadaptor.isReady || this.syncadaptor.isReady()) && this.numTasksInProgress() === 0) {\n\t\t// Choose the next task to perform\n\t\tvar task = this.chooseNextTask();\n\t\t// Perform the task if we had one\n\t\tif(task) {\n\t\t\t// Remove the task from the queue and add it to the in progress list\n\t\t\tdelete this.taskQueue[task.title];\n\t\t\tthis.taskInProgress[task.title] = task;\n\t\t\tthis.updateDirtyStatus();\n\t\t\t// Dispatch the task\n\t\t\tthis.dispatchTask(task,function(err) {\n\t\t\t\tif(err) {\n\t\t\t\t\tself.logger.alert(\"Sync error while processing '\" + task.title + \"':\\n\" + err);\n\t\t\t\t}\n\t\t\t\t// Mark that this task is no longer in progress\n\t\t\t\tdelete self.taskInProgress[task.title];\n\t\t\t\tself.updateDirtyStatus();\n\t\t\t\t// Process the next task\n\t\t\t\tself.processTaskQueue.call(self);\n\t\t\t});\n\t\t} else {\n\t\t\t// Make sure we've set a time if there wasn't a task to perform, but we've still got tasks in the queue\n\t\t\tif(this.numTasksInQueue() > 0) {\n\t\t\t\tthis.triggerTimeout();\n\t\t\t}\n\t\t}\n\t}\n};\n\n/*\nChoose the next applicable task\n*/\nSyncer.prototype.chooseNextTask = function() {\n\tvar self = this,\n\t\tcandidateTask = null,\n\t\tnow = Date.now();\n\t// Select the best candidate task\n\t$tw.utils.each(this.taskQueue,function(task,title) {\n\t\t// Exclude the task if there's one of the same name in progress\n\t\tif($tw.utils.hop(self.taskInProgress,title)) {\n\t\t\treturn;\n\t\t}\n\t\t// Exclude the task if it is a save and the tiddler has been modified recently, but not hit the fallback time\n\t\tif(task.type === \"save\" && (now - task.lastModificationTime) < self.throttleInterval &&\n\t\t\t(now - task.queueTime) < self.fallbackInterval) {\n\t\t\treturn;\n\t\t}\n\t\t// Exclude the task if it is newer than the current best candidate\n\t\tif(candidateTask && candidateTask.queueTime < task.queueTime) {\n\t\t\treturn;\n\t\t}\n\t\t// Now this is our best candidate\n\t\tcandidateTask = task;\n\t});\n\treturn candidateTask;\n};\n\n/*\nDispatch a task and invoke the callback\n*/\nSyncer.prototype.dispatchTask = function(task,callback) {\n\tvar self = this;\n\tif(task.type === \"save\") {\n\t\tvar changeCount = this.wiki.getChangeCount(task.title),\n\t\t\ttiddler = this.wiki.getTiddler(task.title);\n\t\tthis.logger.log(\"Dispatching 'save' task:\",task.title);\n\t\tif(tiddler) {\n\t\t\tthis.syncadaptor.saveTiddler(tiddler,function(err,adaptorInfo,revision) {\n\t\t\t\tif(err) {\n\t\t\t\t\treturn callback(err);\n\t\t\t\t}\n\t\t\t\t// Adjust the info stored about this tiddler\n\t\t\t\tself.tiddlerInfo[task.title] = {\n\t\t\t\t\tchangeCount: changeCount,\n\t\t\t\t\tadaptorInfo: adaptorInfo,\n\t\t\t\t\trevision: revision\n\t\t\t\t};\n\t\t\t\t// Invoke the callback\n\t\t\t\tcallback(null);\n\t\t\t},{\n\t\t\t\ttiddlerInfo: self.tiddlerInfo[task.title]\n\t\t\t});\n\t\t} else {\n\t\t\tthis.logger.log(\" Not Dispatching 'save' task:\",task.title,\"tiddler does not exist\");\n\t\t\treturn callback(null);\n\t\t}\n\t} else if(task.type === \"load\") {\n\t\t// Load the tiddler\n\t\tthis.logger.log(\"Dispatching 'load' task:\",task.title);\n\t\tthis.syncadaptor.loadTiddler(task.title,function(err,tiddlerFields) {\n\t\t\tif(err) {\n\t\t\t\treturn callback(err);\n\t\t\t}\n\t\t\t// Store the tiddler\n\t\t\tif(tiddlerFields) {\n\t\t\t\tself.storeTiddler(tiddlerFields,true);\n\t\t\t}\n\t\t\t// Invoke the callback\n\t\t\tcallback(null);\n\t\t});\n\t} else if(task.type === \"delete\") {\n\t\t// Delete the tiddler\n\t\tthis.logger.log(\"Dispatching 'delete' task:\",task.title);\n\t\tthis.syncadaptor.deleteTiddler(task.title,function(err) {\n\t\t\tif(err) {\n\t\t\t\treturn callback(err);\n\t\t\t}\n\t\t\tdelete self.tiddlerInfo[task.title];\n\t\t\t// Invoke the callback\n\t\t\tcallback(null);\n\t\t},{\n\t\t\ttiddlerInfo: self.tiddlerInfo[task.title]\n\t\t});\n\t}\n};\n\nexports.Syncer = Syncer;\n\n})();\n",
"type": "application/javascript",
"module-type": "global"
},
"$:/core/modules/tiddler.js": {
"title": "$:/core/modules/tiddler.js",
"text": "/*\\\ntitle: $:/core/modules/tiddler.js\ntype: application/javascript\nmodule-type: tiddlermethod\n\nExtension methods for the $tw.Tiddler object (constructor and methods required at boot time are in boot/boot.js)\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.hasTag = function(tag) {\n\treturn this.fields.tags && this.fields.tags.indexOf(tag) !== -1;\n};\n\nexports.isPlugin = function() {\n\treturn this.fields.type === \"application/json\" && this.hasField(\"plugin-type\");\n};\n\nexports.isDraft = function() {\n\treturn this.hasField(\"draft.of\");\n};\n\nexports.getFieldString = function(field) {\n\tvar value = this.fields[field];\n\t// Check for a missing field\n\tif(value === undefined || value === null) {\n\t\treturn \"\";\n\t}\n\t// Parse the field with the associated module (if any)\n\tvar fieldModule = $tw.Tiddler.fieldModules[field];\n\tif(fieldModule && fieldModule.stringify) {\n\t\treturn fieldModule.stringify.call(this,value);\n\t} else {\n\t\treturn value.toString();\n\t}\n};\n\n/*\nGet the value of a field as a list\n*/\nexports.getFieldList = function(field) {\n\tvar value = this.fields[field];\n\t// Check for a missing field\n\tif(value === undefined || value === null) {\n\t\treturn [];\n\t}\n\treturn $tw.utils.parseStringArray(value);\n};\n\n/*\nGet all the fields as a hashmap of strings. Options:\n\texclude: an array of field names to exclude\n*/\nexports.getFieldStrings = function(options) {\n\toptions = options || {};\n\tvar exclude = options.exclude || [];\n\tvar fields = {};\n\tfor(var field in this.fields) {\n\t\tif($tw.utils.hop(this.fields,field)) {\n\t\t\tif(exclude.indexOf(field) === -1) {\n\t\t\t\tfields[field] = this.getFieldString(field);\n\t\t\t}\n\t\t}\n\t}\n\treturn fields;\n};\n\n/*\nGet all the fields as a name:value block. Options:\n\texclude: an array of field names to exclude\n*/\nexports.getFieldStringBlock = function(options) {\n\toptions = options || {};\n\tvar exclude = options.exclude || [];\n\tvar fields = [];\n\tfor(var field in this.fields) {\n\t\tif($tw.utils.hop(this.fields,field)) {\n\t\t\tif(exclude.indexOf(field) === -1) {\n\t\t\t\tfields.push(field + \": \" + this.getFieldString(field));\n\t\t\t}\n\t\t}\n\t}\n\treturn fields.join(\"\\n\");\n};\n\n/*\nCompare two tiddlers for equality\ntiddler: the tiddler to compare\nexcludeFields: array of field names to exclude from the comparison\n*/\nexports.isEqual = function(tiddler,excludeFields) {\n\tif(!(tiddler instanceof $tw.Tiddler)) {\n\t\treturn false;\n\t}\n\texcludeFields = excludeFields || [];\n\tvar self = this,\n\t\tdifferences = []; // Fields that have differences\n\t// Add to the differences array\n\tfunction addDifference(fieldName) {\n\t\t// Check for this field being excluded\n\t\tif(excludeFields.indexOf(fieldName) === -1) {\n\t\t\t// Save the field as a difference\n\t\t\t$tw.utils.pushTop(differences,fieldName);\n\t\t}\n\t}\n\t// Returns true if the two values of this field are equal\n\tfunction isFieldValueEqual(fieldName) {\n\t\tvar valueA = self.fields[fieldName],\n\t\t\tvalueB = tiddler.fields[fieldName];\n\t\t// Check for identical string values\n\t\tif(typeof(valueA) === \"string\" && typeof(valueB) === \"string\" && valueA === valueB) {\n\t\t\treturn true;\n\t\t}\n\t\t// Check for identical array values\n\t\tif($tw.utils.isArray(valueA) && $tw.utils.isArray(valueB) && $tw.utils.isArrayEqual(valueA,valueB)) {\n\t\t\treturn true;\n\t\t}\n\t\t// Otherwise the fields must be different\n\t\treturn false;\n\t}\n\t// Compare our fields\n\tfor(var fieldName in this.fields) {\n\t\tif(!isFieldValueEqual(fieldName)) {\n\t\t\taddDifference(fieldName);\n\t\t}\n\t}\n\t// There's a difference for every field in the other tiddler that we don't have\n\tfor(fieldName in tiddler.fields) {\n\t\tif(!(fieldName in this.fields)) {\n\t\t\taddDifference(fieldName);\n\t\t}\n\t}\n\t// Return whether there were any differences\n\treturn differences.length === 0;\n};\n\nexports.getFieldDay = function(field) {\n\tif(this.cache && this.cache.day && $tw.utils.hop(this.cache.day,field) ) {\n\t\treturn this.cache.day[field];\n\t}\n\tvar day = \"\";\n\tif(this.fields[field]) {\n\t\tday = (new Date($tw.utils.parseDate(this.fields[field]))).setHours(0,0,0,0);\n\t}\n\tthis.cache.day = this.cache.day || {};\n\tthis.cache.day[field] = day;\n\treturn day;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "tiddlermethod"
},
"$:/core/modules/upgraders/plugins.js": {
"title": "$:/core/modules/upgraders/plugins.js",
"text": "/*\\\ntitle: $:/core/modules/upgraders/plugins.js\ntype: application/javascript\nmodule-type: upgrader\n\nUpgrader module that checks that plugins are newer than any already installed version\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar UPGRADE_LIBRARY_TITLE = \"$:/UpgradeLibrary\";\n\nvar BLOCKED_PLUGINS = {\n\t\"$:/themes/tiddlywiki/stickytitles\": {\n\t\tversions: [\"*\"]\n\t},\n\t\"$:/plugins/tiddlywiki/fullscreen\": {\n\t\tversions: [\"*\"]\n\t}\n};\n\nexports.upgrade = function(wiki,titles,tiddlers) {\n\tvar self = this,\n\t\tmessages = {},\n\t\tupgradeLibrary,\n\t\tgetLibraryTiddler = function(title) {\n\t\t\tif(!upgradeLibrary) {\n\t\t\t\tupgradeLibrary = wiki.getTiddlerData(UPGRADE_LIBRARY_TITLE,{});\n\t\t\t\tupgradeLibrary.tiddlers = upgradeLibrary.tiddlers || {};\n\t\t\t}\n\t\t\treturn upgradeLibrary.tiddlers[title];\n\t\t};\n\n\t// Go through all the incoming tiddlers\n\t$tw.utils.each(titles,function(title) {\n\t\tvar incomingTiddler = tiddlers[title];\n\t\t// Check if we're dealing with a plugin\n\t\tif(incomingTiddler && incomingTiddler[\"plugin-type\"] && incomingTiddler.version) {\n\t\t\t// Upgrade the incoming plugin if it is in the upgrade library\n\t\t\tvar libraryTiddler = getLibraryTiddler(title);\n\t\t\tif(libraryTiddler && libraryTiddler[\"plugin-type\"] && libraryTiddler.version) {\n\t\t\t\ttiddlers[title] = libraryTiddler;\n\t\t\t\tmessages[title] = $tw.language.getString(\"Import/Upgrader/Plugins/Upgraded\",{variables: {incoming: incomingTiddler.version, upgraded: libraryTiddler.version}});\n\t\t\t\treturn;\n\t\t\t}\n\t\t\t// Suppress the incoming plugin if it is older than the currently installed one\n\t\t\tvar existingTiddler = wiki.getTiddler(title);\n\t\t\tif(existingTiddler && existingTiddler.hasField(\"plugin-type\") && existingTiddler.hasField(\"version\")) {\n\t\t\t\t// Reject the incoming plugin by blanking all its fields\n\t\t\t\tif($tw.utils.checkVersions(existingTiddler.fields.version,incomingTiddler.version)) {\n\t\t\t\t\ttiddlers[title] = Object.create(null);\n\t\t\t\t\tmessages[title] = $tw.language.getString(\"Import/Upgrader/Plugins/Suppressed/Version\",{variables: {incoming: incomingTiddler.version, existing: existingTiddler.fields.version}});\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tif(incomingTiddler && incomingTiddler[\"plugin-type\"]) {\n\t\t\t// Check whether the plugin is on the blocked list\n\t\t\tvar blockInfo = BLOCKED_PLUGINS[title];\n\t\t\tif(blockInfo) {\n\t\t\t\tif(blockInfo.versions.indexOf(\"*\") !== -1 || (incomingTiddler.version && blockInfo.versions.indexOf(incomingTiddler.version) !== -1)) {\n\t\t\t\t\ttiddlers[title] = Object.create(null);\n\t\t\t\t\tmessages[title] = $tw.language.getString(\"Import/Upgrader/Plugins/Suppressed/Incompatible\");\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t});\n\treturn messages;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "upgrader"
},
"$:/core/modules/upgraders/system.js": {
"title": "$:/core/modules/upgraders/system.js",
"text": "/*\\\ntitle: $:/core/modules/upgraders/system.js\ntype: application/javascript\nmodule-type: upgrader\n\nUpgrader module that suppresses certain system tiddlers that shouldn't be imported\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar DONT_IMPORT_LIST = [\"$:/StoryList\",\"$:/HistoryList\"],\n\tDONT_IMPORT_PREFIX_LIST = [\"$:/temp/\",\"$:/state/\"];\n\nexports.upgrade = function(wiki,titles,tiddlers) {\n\tvar self = this,\n\t\tmessages = {};\n\t// Check for tiddlers on our list\n\t$tw.utils.each(titles,function(title) {\n\t\tif(DONT_IMPORT_LIST.indexOf(title) !== -1) {\n\t\t\ttiddlers[title] = Object.create(null);\n\t\t\tmessages[title] = $tw.language.getString(\"Import/Upgrader/System/Suppressed\");\n\t\t} else {\n\t\t\tfor(var t=0; t<DONT_IMPORT_PREFIX_LIST.length; t++) {\n\t\t\t\tvar prefix = DONT_IMPORT_PREFIX_LIST[t];\n\t\t\t\tif(title.substr(0,prefix.length) === prefix) {\n\t\t\t\t\ttiddlers[title] = Object.create(null);\n\t\t\t\t\tmessages[title] = $tw.language.getString(\"Import/Upgrader/State/Suppressed\");\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t});\n\treturn messages;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "upgrader"
},
"$:/core/modules/upgraders/themetweaks.js": {
"title": "$:/core/modules/upgraders/themetweaks.js",
"text": "/*\\\ntitle: $:/core/modules/upgraders/themetweaks.js\ntype: application/javascript\nmodule-type: upgrader\n\nUpgrader module that handles the change in theme tweak storage introduced in 5.0.14-beta.\n\nPreviously, theme tweaks were stored in two data tiddlers:\n\n* $:/themes/tiddlywiki/vanilla/metrics\n* $:/themes/tiddlywiki/vanilla/settings\n\nNow, each tweak is stored in its own separate tiddler.\n\nThis upgrader copies any values from the old format to the new. The old data tiddlers are not deleted in case they have been used to store additional indexes.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar MAPPINGS = {\n\t\"$:/themes/tiddlywiki/vanilla/metrics\": {\n\t\t\"fontsize\": \"$:/themes/tiddlywiki/vanilla/metrics/fontsize\",\n\t\t\"lineheight\": \"$:/themes/tiddlywiki/vanilla/metrics/lineheight\",\n\t\t\"storyleft\": \"$:/themes/tiddlywiki/vanilla/metrics/storyleft\",\n\t\t\"storytop\": \"$:/themes/tiddlywiki/vanilla/metrics/storytop\",\n\t\t\"storyright\": \"$:/themes/tiddlywiki/vanilla/metrics/storyright\",\n\t\t\"storywidth\": \"$:/themes/tiddlywiki/vanilla/metrics/storywidth\",\n\t\t\"tiddlerwidth\": \"$:/themes/tiddlywiki/vanilla/metrics/tiddlerwidth\"\n\t},\n\t\"$:/themes/tiddlywiki/vanilla/settings\": {\n\t\t\"fontfamily\": \"$:/themes/tiddlywiki/vanilla/settings/fontfamily\"\n\t}\n};\n\nexports.upgrade = function(wiki,titles,tiddlers) {\n\tvar self = this,\n\t\tmessages = {};\n\t// Check for tiddlers on our list\n\t$tw.utils.each(titles,function(title) {\n\t\tvar mapping = MAPPINGS[title];\n\t\tif(mapping) {\n\t\t\tvar tiddler = new $tw.Tiddler(tiddlers[title]),\n\t\t\t\ttiddlerData = wiki.getTiddlerDataCached(tiddler,{});\n\t\t\tfor(var index in mapping) {\n\t\t\t\tvar mappedTitle = mapping[index];\n\t\t\t\tif(!tiddlers[mappedTitle] || tiddlers[mappedTitle].title !== mappedTitle) {\n\t\t\t\t\ttiddlers[mappedTitle] = {\n\t\t\t\t\t\ttitle: mappedTitle,\n\t\t\t\t\t\ttext: tiddlerData[index]\n\t\t\t\t\t};\n\t\t\t\t\tmessages[mappedTitle] = $tw.language.getString(\"Import/Upgrader/ThemeTweaks/Created\",{variables: {\n\t\t\t\t\t\tfrom: title + \"##\" + index\n\t\t\t\t\t}});\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t});\n\treturn messages;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "upgrader"
},
"$:/core/modules/utils/crypto.js": {
"title": "$:/core/modules/utils/crypto.js",
"text": "/*\\\ntitle: $:/core/modules/utils/crypto.js\ntype: application/javascript\nmodule-type: utils\n\nUtility functions related to crypto.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nLook for an encrypted store area in the text of a TiddlyWiki file\n*/\nexports.extractEncryptedStoreArea = function(text) {\n\tvar encryptedStoreAreaStartMarker = \"<pre id=\\\"encryptedStoreArea\\\" type=\\\"text/plain\\\" style=\\\"display:none;\\\">\",\n\t\tencryptedStoreAreaStart = text.indexOf(encryptedStoreAreaStartMarker);\n\tif(encryptedStoreAreaStart !== -1) {\n\t\tvar encryptedStoreAreaEnd = text.indexOf(\"</pre>\",encryptedStoreAreaStart);\n\t\tif(encryptedStoreAreaEnd !== -1) {\n\t\t\treturn $tw.utils.htmlDecode(text.substring(encryptedStoreAreaStart + encryptedStoreAreaStartMarker.length,encryptedStoreAreaEnd-1));\n\t\t}\n\t}\n\treturn null;\n};\n\n/*\nAttempt to extract the tiddlers from an encrypted store area using the current password. If the password is not provided then the password in the password store will be used\n*/\nexports.decryptStoreArea = function(encryptedStoreArea,password) {\n\tvar decryptedText = $tw.crypto.decrypt(encryptedStoreArea,password);\n\tif(decryptedText) {\n\t\tvar json = JSON.parse(decryptedText),\n\t\t\ttiddlers = [];\n\t\tfor(var title in json) {\n\t\t\tif(title !== \"$:/isEncrypted\") {\n\t\t\t\ttiddlers.push(json[title]);\n\t\t\t}\n\t\t}\n\t\treturn tiddlers;\n\t} else {\n\t\treturn null;\n\t}\n};\n\n\n/*\nAttempt to extract the tiddlers from an encrypted store area using the current password. If that fails, the user is prompted for a password.\nencryptedStoreArea: text of the TiddlyWiki encrypted store area\ncallback: function(tiddlers) called with the array of decrypted tiddlers\n\nThe following configuration settings are supported:\n\n$tw.config.usePasswordVault: causes any password entered by the user to also be put into the system password vault\n*/\nexports.decryptStoreAreaInteractive = function(encryptedStoreArea,callback,options) {\n\t// Try to decrypt with the current password\n\tvar tiddlers = $tw.utils.decryptStoreArea(encryptedStoreArea);\n\tif(tiddlers) {\n\t\tcallback(tiddlers);\n\t} else {\n\t\t// Prompt for a new password and keep trying\n\t\t$tw.passwordPrompt.createPrompt({\n\t\t\tserviceName: \"Enter a password to decrypt the imported TiddlyWiki\",\n\t\t\tnoUserName: true,\n\t\t\tcanCancel: true,\n\t\t\tsubmitText: \"Decrypt\",\n\t\t\tcallback: function(data) {\n\t\t\t\t// Exit if the user cancelled\n\t\t\t\tif(!data) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t\t// Attempt to decrypt the tiddlers\n\t\t\t\tvar tiddlers = $tw.utils.decryptStoreArea(encryptedStoreArea,data.password);\n\t\t\t\tif(tiddlers) {\n\t\t\t\t\tif($tw.config.usePasswordVault) {\n\t\t\t\t\t\t$tw.crypto.setPassword(data.password);\n\t\t\t\t\t}\n\t\t\t\t\tcallback(tiddlers);\n\t\t\t\t\t// Exit and remove the password prompt\n\t\t\t\t\treturn true;\n\t\t\t\t} else {\n\t\t\t\t\t// We didn't decrypt everything, so continue to prompt for password\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/utils/csv.js": {
"title": "$:/core/modules/utils/csv.js",
"text": "/*\\\ntitle: $:/core/modules/utils/csv.js\ntype: application/javascript\nmodule-type: utils\n\nA barebones CSV parser\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nParse a CSV string with a header row and return an array of hashmaps.\n*/\nexports.parseCsvStringWithHeader = function(text,options) {\n\toptions = options || {};\n\tvar separator = options.separator || \",\",\n\t\trows = text.split(/\\r?\\n/mg).map(function(row) {\n\t\t\treturn $tw.utils.trim(row);\n\t\t}).filter(function(row) {\n\t\t\treturn row !== \"\";\n\t\t});\n\tif(rows.length < 1) {\n\t\treturn \"Missing header row\";\n\t}\n\tvar headings = rows[0].split(separator),\n\t\tresults = [];\n\tfor(var row=1; row<rows.length; row++) {\n\t\tvar columns = rows[row].split(separator),\n\t\t\tcolumnResult = Object.create(null);\n\t\tif(columns.length !== headings.length) {\n\t\t\treturn \"Malformed CSV row '\" + rows[row] + \"'\";\n\t\t}\n\t\tfor(var column=0; column<columns.length; column++) {\n\t\t\tvar columnName = headings[column];\n\t\t\tcolumnResult[columnName] = $tw.utils.trim(columns[column] || \"\");\n\t\t}\n\t\tresults.push(columnResult);\t\t\t\n\t}\n\treturn results;\n}\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/utils/diff-match-patch/diff_match_patch.js": {
"text": "(function(){function diff_match_patch(){this.Diff_Timeout=1;this.Diff_EditCost=4;this.Match_Threshold=.5;this.Match_Distance=1E3;this.Patch_DeleteThreshold=.5;this.Patch_Margin=4;this.Match_MaxBits=32}var DIFF_DELETE=-1,DIFF_INSERT=1,DIFF_EQUAL=0;\ndiff_match_patch.prototype.diff_main=function(a,b,c,d){\"undefined\"==typeof d&&(d=0>=this.Diff_Timeout?Number.MAX_VALUE:(new Date).getTime()+1E3*this.Diff_Timeout);if(null==a||null==b)throw Error(\"Null input. (diff_main)\");if(a==b)return a?[[DIFF_EQUAL,a]]:[];\"undefined\"==typeof c&&(c=!0);var e=c,f=this.diff_commonPrefix(a,b);c=a.substring(0,f);a=a.substring(f);b=b.substring(f);f=this.diff_commonSuffix(a,b);var g=a.substring(a.length-f);a=a.substring(0,a.length-f);b=b.substring(0,b.length-f);a=this.diff_compute_(a,\nb,e,d);c&&a.unshift([DIFF_EQUAL,c]);g&&a.push([DIFF_EQUAL,g]);this.diff_cleanupMerge(a);return a};\ndiff_match_patch.prototype.diff_compute_=function(a,b,c,d){if(!a)return[[DIFF_INSERT,b]];if(!b)return[[DIFF_DELETE,a]];var e=a.length>b.length?a:b,f=a.length>b.length?b:a,g=e.indexOf(f);return-1!=g?(c=[[DIFF_INSERT,e.substring(0,g)],[DIFF_EQUAL,f],[DIFF_INSERT,e.substring(g+f.length)]],a.length>b.length&&(c[0][0]=c[2][0]=DIFF_DELETE),c):1==f.length?[[DIFF_DELETE,a],[DIFF_INSERT,b]]:(e=this.diff_halfMatch_(a,b))?(b=e[1],f=e[3],a=e[4],e=this.diff_main(e[0],e[2],c,d),c=this.diff_main(b,f,c,d),e.concat([[DIFF_EQUAL,\na]],c)):c&&100<a.length&&100<b.length?this.diff_lineMode_(a,b,d):this.diff_bisect_(a,b,d)};\ndiff_match_patch.prototype.diff_lineMode_=function(a,b,c){var d=this.diff_linesToChars_(a,b);a=d.chars1;b=d.chars2;d=d.lineArray;a=this.diff_main(a,b,!1,c);this.diff_charsToLines_(a,d);this.diff_cleanupSemantic(a);a.push([DIFF_EQUAL,\"\"]);for(var e=d=b=0,f=\"\",g=\"\";b<a.length;){switch(a[b][0]){case DIFF_INSERT:e++;g+=a[b][1];break;case DIFF_DELETE:d++;f+=a[b][1];break;case DIFF_EQUAL:if(1<=d&&1<=e){a.splice(b-d-e,d+e);b=b-d-e;d=this.diff_main(f,g,!1,c);for(e=d.length-1;0<=e;e--)a.splice(b,0,d[e]);b+=\nd.length}d=e=0;g=f=\"\"}b++}a.pop();return a};\ndiff_match_patch.prototype.diff_bisect_=function(a,b,c){for(var d=a.length,e=b.length,f=Math.ceil((d+e)/2),g=2*f,h=Array(g),l=Array(g),k=0;k<g;k++)h[k]=-1,l[k]=-1;h[f+1]=0;l[f+1]=0;k=d-e;for(var m=0!=k%2,p=0,x=0,w=0,q=0,t=0;t<f&&!((new Date).getTime()>c);t++){for(var v=-t+p;v<=t-x;v+=2){var n=f+v;var r=v==-t||v!=t&&h[n-1]<h[n+1]?h[n+1]:h[n-1]+1;for(var y=r-v;r<d&&y<e&&a.charAt(r)==b.charAt(y);)r++,y++;h[n]=r;if(r>d)x+=2;else if(y>e)p+=2;else if(m&&(n=f+k-v,0<=n&&n<g&&-1!=l[n])){var u=d-l[n];if(r>=\nu)return this.diff_bisectSplit_(a,b,r,y,c)}}for(v=-t+w;v<=t-q;v+=2){n=f+v;u=v==-t||v!=t&&l[n-1]<l[n+1]?l[n+1]:l[n-1]+1;for(r=u-v;u<d&&r<e&&a.charAt(d-u-1)==b.charAt(e-r-1);)u++,r++;l[n]=u;if(u>d)q+=2;else if(r>e)w+=2;else if(!m&&(n=f+k-v,0<=n&&n<g&&-1!=h[n]&&(r=h[n],y=f+r-n,u=d-u,r>=u)))return this.diff_bisectSplit_(a,b,r,y,c)}}return[[DIFF_DELETE,a],[DIFF_INSERT,b]]};\ndiff_match_patch.prototype.diff_bisectSplit_=function(a,b,c,d,e){var f=a.substring(0,c),g=b.substring(0,d);a=a.substring(c);b=b.substring(d);f=this.diff_main(f,g,!1,e);e=this.diff_main(a,b,!1,e);return f.concat(e)};\ndiff_match_patch.prototype.diff_linesToChars_=function(a,b){function c(a){for(var b=\"\",c=0,f=-1,g=d.length;f<a.length-1;){f=a.indexOf(\"\\n\",c);-1==f&&(f=a.length-1);var h=a.substring(c,f+1);c=f+1;(e.hasOwnProperty?e.hasOwnProperty(h):void 0!==e[h])?b+=String.fromCharCode(e[h]):(b+=String.fromCharCode(g),e[h]=g,d[g++]=h)}return b}var d=[],e={};d[0]=\"\";var f=c(a),g=c(b);return{chars1:f,chars2:g,lineArray:d}};\ndiff_match_patch.prototype.diff_charsToLines_=function(a,b){for(var c=0;c<a.length;c++){for(var d=a[c][1],e=[],f=0;f<d.length;f++)e[f]=b[d.charCodeAt(f)];a[c][1]=e.join(\"\")}};diff_match_patch.prototype.diff_commonPrefix=function(a,b){if(!a||!b||a.charAt(0)!=b.charAt(0))return 0;for(var c=0,d=Math.min(a.length,b.length),e=d,f=0;c<e;)a.substring(f,e)==b.substring(f,e)?f=c=e:d=e,e=Math.floor((d-c)/2+c);return e};\ndiff_match_patch.prototype.diff_commonSuffix=function(a,b){if(!a||!b||a.charAt(a.length-1)!=b.charAt(b.length-1))return 0;for(var c=0,d=Math.min(a.length,b.length),e=d,f=0;c<e;)a.substring(a.length-e,a.length-f)==b.substring(b.length-e,b.length-f)?f=c=e:d=e,e=Math.floor((d-c)/2+c);return e};\ndiff_match_patch.prototype.diff_commonOverlap_=function(a,b){var c=a.length,d=b.length;if(0==c||0==d)return 0;c>d?a=a.substring(c-d):c<d&&(b=b.substring(0,c));c=Math.min(c,d);if(a==b)return c;d=0;for(var e=1;;){var f=a.substring(c-e);f=b.indexOf(f);if(-1==f)return d;e+=f;if(0==f||a.substring(c-e)==b.substring(0,e))d=e,e++}};\ndiff_match_patch.prototype.diff_halfMatch_=function(a,b){function c(a,b,c){for(var d=a.substring(c,c+Math.floor(a.length/4)),e=-1,g=\"\",h,k,l,m;-1!=(e=b.indexOf(d,e+1));){var p=f.diff_commonPrefix(a.substring(c),b.substring(e)),u=f.diff_commonSuffix(a.substring(0,c),b.substring(0,e));g.length<u+p&&(g=b.substring(e-u,e)+b.substring(e,e+p),h=a.substring(0,c-u),k=a.substring(c+p),l=b.substring(0,e-u),m=b.substring(e+p))}return 2*g.length>=a.length?[h,k,l,m,g]:null}if(0>=this.Diff_Timeout)return null;\nvar d=a.length>b.length?a:b,e=a.length>b.length?b:a;if(4>d.length||2*e.length<d.length)return null;var f=this,g=c(d,e,Math.ceil(d.length/4));d=c(d,e,Math.ceil(d.length/2));if(g||d)g=d?g?g[4].length>d[4].length?g:d:d:g;else return null;if(a.length>b.length){d=g[0];e=g[1];var h=g[2];var l=g[3]}else h=g[0],l=g[1],d=g[2],e=g[3];return[d,e,h,l,g[4]]};\ndiff_match_patch.prototype.diff_cleanupSemantic=function(a){for(var b=!1,c=[],d=0,e=null,f=0,g=0,h=0,l=0,k=0;f<a.length;)a[f][0]==DIFF_EQUAL?(c[d++]=f,g=l,h=k,k=l=0,e=a[f][1]):(a[f][0]==DIFF_INSERT?l+=a[f][1].length:k+=a[f][1].length,e&&e.length<=Math.max(g,h)&&e.length<=Math.max(l,k)&&(a.splice(c[d-1],0,[DIFF_DELETE,e]),a[c[d-1]+1][0]=DIFF_INSERT,d--,d--,f=0<d?c[d-1]:-1,k=l=h=g=0,e=null,b=!0)),f++;b&&this.diff_cleanupMerge(a);this.diff_cleanupSemanticLossless(a);for(f=1;f<a.length;){if(a[f-1][0]==\nDIFF_DELETE&&a[f][0]==DIFF_INSERT){b=a[f-1][1];c=a[f][1];d=this.diff_commonOverlap_(b,c);e=this.diff_commonOverlap_(c,b);if(d>=e){if(d>=b.length/2||d>=c.length/2)a.splice(f,0,[DIFF_EQUAL,c.substring(0,d)]),a[f-1][1]=b.substring(0,b.length-d),a[f+1][1]=c.substring(d),f++}else if(e>=b.length/2||e>=c.length/2)a.splice(f,0,[DIFF_EQUAL,b.substring(0,e)]),a[f-1][0]=DIFF_INSERT,a[f-1][1]=c.substring(0,c.length-e),a[f+1][0]=DIFF_DELETE,a[f+1][1]=b.substring(e),f++;f++}f++}};\ndiff_match_patch.prototype.diff_cleanupSemanticLossless=function(a){function b(a,b){if(!a||!b)return 6;var c=a.charAt(a.length-1),d=b.charAt(0),e=c.match(diff_match_patch.nonAlphaNumericRegex_),f=d.match(diff_match_patch.nonAlphaNumericRegex_),g=e&&c.match(diff_match_patch.whitespaceRegex_),h=f&&d.match(diff_match_patch.whitespaceRegex_);c=g&&c.match(diff_match_patch.linebreakRegex_);d=h&&d.match(diff_match_patch.linebreakRegex_);var k=c&&a.match(diff_match_patch.blanklineEndRegex_),l=d&&b.match(diff_match_patch.blanklineStartRegex_);\nreturn k||l?5:c||d?4:e&&!g&&h?3:g||h?2:e||f?1:0}for(var c=1;c<a.length-1;){if(a[c-1][0]==DIFF_EQUAL&&a[c+1][0]==DIFF_EQUAL){var d=a[c-1][1],e=a[c][1],f=a[c+1][1],g=this.diff_commonSuffix(d,e);if(g){var h=e.substring(e.length-g);d=d.substring(0,d.length-g);e=h+e.substring(0,e.length-g);f=h+f}g=d;h=e;for(var l=f,k=b(d,e)+b(e,f);e.charAt(0)===f.charAt(0);){d+=e.charAt(0);e=e.substring(1)+f.charAt(0);f=f.substring(1);var m=b(d,e)+b(e,f);m>=k&&(k=m,g=d,h=e,l=f)}a[c-1][1]!=g&&(g?a[c-1][1]=g:(a.splice(c-\n1,1),c--),a[c][1]=h,l?a[c+1][1]=l:(a.splice(c+1,1),c--))}c++}};diff_match_patch.nonAlphaNumericRegex_=/[^a-zA-Z0-9]/;diff_match_patch.whitespaceRegex_=/\\s/;diff_match_patch.linebreakRegex_=/[\\r\\n]/;diff_match_patch.blanklineEndRegex_=/\\n\\r?\\n$/;diff_match_patch.blanklineStartRegex_=/^\\r?\\n\\r?\\n/;\ndiff_match_patch.prototype.diff_cleanupEfficiency=function(a){for(var b=!1,c=[],d=0,e=null,f=0,g=!1,h=!1,l=!1,k=!1;f<a.length;)a[f][0]==DIFF_EQUAL?(a[f][1].length<this.Diff_EditCost&&(l||k)?(c[d++]=f,g=l,h=k,e=a[f][1]):(d=0,e=null),l=k=!1):(a[f][0]==DIFF_DELETE?k=!0:l=!0,e&&(g&&h&&l&&k||e.length<this.Diff_EditCost/2&&3==g+h+l+k)&&(a.splice(c[d-1],0,[DIFF_DELETE,e]),a[c[d-1]+1][0]=DIFF_INSERT,d--,e=null,g&&h?(l=k=!0,d=0):(d--,f=0<d?c[d-1]:-1,l=k=!1),b=!0)),f++;b&&this.diff_cleanupMerge(a)};\ndiff_match_patch.prototype.diff_cleanupMerge=function(a){a.push([DIFF_EQUAL,\"\"]);for(var b=0,c=0,d=0,e=\"\",f=\"\",g;b<a.length;)switch(a[b][0]){case DIFF_INSERT:d++;f+=a[b][1];b++;break;case DIFF_DELETE:c++;e+=a[b][1];b++;break;case DIFF_EQUAL:1<c+d?(0!==c&&0!==d&&(g=this.diff_commonPrefix(f,e),0!==g&&(0<b-c-d&&a[b-c-d-1][0]==DIFF_EQUAL?a[b-c-d-1][1]+=f.substring(0,g):(a.splice(0,0,[DIFF_EQUAL,f.substring(0,g)]),b++),f=f.substring(g),e=e.substring(g)),g=this.diff_commonSuffix(f,e),0!==g&&(a[b][1]=f.substring(f.length-\ng)+a[b][1],f=f.substring(0,f.length-g),e=e.substring(0,e.length-g))),0===c?a.splice(b-d,c+d,[DIFF_INSERT,f]):0===d?a.splice(b-c,c+d,[DIFF_DELETE,e]):a.splice(b-c-d,c+d,[DIFF_DELETE,e],[DIFF_INSERT,f]),b=b-c-d+(c?1:0)+(d?1:0)+1):0!==b&&a[b-1][0]==DIFF_EQUAL?(a[b-1][1]+=a[b][1],a.splice(b,1)):b++,c=d=0,f=e=\"\"}\"\"===a[a.length-1][1]&&a.pop();c=!1;for(b=1;b<a.length-1;)a[b-1][0]==DIFF_EQUAL&&a[b+1][0]==DIFF_EQUAL&&(a[b][1].substring(a[b][1].length-a[b-1][1].length)==a[b-1][1]?(a[b][1]=a[b-1][1]+a[b][1].substring(0,\na[b][1].length-a[b-1][1].length),a[b+1][1]=a[b-1][1]+a[b+1][1],a.splice(b-1,1),c=!0):a[b][1].substring(0,a[b+1][1].length)==a[b+1][1]&&(a[b-1][1]+=a[b+1][1],a[b][1]=a[b][1].substring(a[b+1][1].length)+a[b+1][1],a.splice(b+1,1),c=!0)),b++;c&&this.diff_cleanupMerge(a)};\ndiff_match_patch.prototype.diff_xIndex=function(a,b){var c=0,d=0,e=0,f=0,g;for(g=0;g<a.length;g++){a[g][0]!==DIFF_INSERT&&(c+=a[g][1].length);a[g][0]!==DIFF_DELETE&&(d+=a[g][1].length);if(c>b)break;e=c;f=d}return a.length!=g&&a[g][0]===DIFF_DELETE?f:f+(b-e)};\ndiff_match_patch.prototype.diff_prettyHtml=function(a){for(var b=[],c=/&/g,d=/</g,e=/>/g,f=/\\n/g,g=0;g<a.length;g++){var h=a[g][0],l=a[g][1].replace(c,\"&\").replace(d,\"<\").replace(e,\">\").replace(f,\"¶<br>\");switch(h){case DIFF_INSERT:b[g]='<ins style=\"background:#e6ffe6;\">'+l+\"</ins>\";break;case DIFF_DELETE:b[g]='<del style=\"background:#ffe6e6;\">'+l+\"</del>\";break;case DIFF_EQUAL:b[g]=\"<span>\"+l+\"</span>\"}}return b.join(\"\")};\ndiff_match_patch.prototype.diff_text1=function(a){for(var b=[],c=0;c<a.length;c++)a[c][0]!==DIFF_INSERT&&(b[c]=a[c][1]);return b.join(\"\")};diff_match_patch.prototype.diff_text2=function(a){for(var b=[],c=0;c<a.length;c++)a[c][0]!==DIFF_DELETE&&(b[c]=a[c][1]);return b.join(\"\")};\ndiff_match_patch.prototype.diff_levenshtein=function(a){for(var b=0,c=0,d=0,e=0;e<a.length;e++){var f=a[e][1];switch(a[e][0]){case DIFF_INSERT:c+=f.length;break;case DIFF_DELETE:d+=f.length;break;case DIFF_EQUAL:b+=Math.max(c,d),d=c=0}}return b+=Math.max(c,d)};\ndiff_match_patch.prototype.diff_toDelta=function(a){for(var b=[],c=0;c<a.length;c++)switch(a[c][0]){case DIFF_INSERT:b[c]=\"+\"+encodeURI(a[c][1]);break;case DIFF_DELETE:b[c]=\"-\"+a[c][1].length;break;case DIFF_EQUAL:b[c]=\"=\"+a[c][1].length}return b.join(\"\\t\").replace(/%20/g,\" \")};\ndiff_match_patch.prototype.diff_fromDelta=function(a,b){for(var c=[],d=0,e=0,f=b.split(/\\t/g),g=0;g<f.length;g++){var h=f[g].substring(1);switch(f[g].charAt(0)){case \"+\":try{c[d++]=[DIFF_INSERT,decodeURI(h)]}catch(k){throw Error(\"Illegal escape in diff_fromDelta: \"+h);}break;case \"-\":case \"=\":var l=parseInt(h,10);if(isNaN(l)||0>l)throw Error(\"Invalid number in diff_fromDelta: \"+h);h=a.substring(e,e+=l);\"=\"==f[g].charAt(0)?c[d++]=[DIFF_EQUAL,h]:c[d++]=[DIFF_DELETE,h];break;default:if(f[g])throw Error(\"Invalid diff operation in diff_fromDelta: \"+\nf[g]);}}if(e!=a.length)throw Error(\"Delta length (\"+e+\") does not equal source text length (\"+a.length+\").\");return c};diff_match_patch.prototype.match_main=function(a,b,c){if(null==a||null==b||null==c)throw Error(\"Null input. (match_main)\");c=Math.max(0,Math.min(c,a.length));return a==b?0:a.length?a.substring(c,c+b.length)==b?c:this.match_bitap_(a,b,c):-1};\ndiff_match_patch.prototype.match_bitap_=function(a,b,c){function d(a,d){var e=a/b.length,g=Math.abs(c-d);return f.Match_Distance?e+g/f.Match_Distance:g?1:e}if(b.length>this.Match_MaxBits)throw Error(\"Pattern too long for this browser.\");var e=this.match_alphabet_(b),f=this,g=this.Match_Threshold,h=a.indexOf(b,c);-1!=h&&(g=Math.min(d(0,h),g),h=a.lastIndexOf(b,c+b.length),-1!=h&&(g=Math.min(d(0,h),g)));var l=1<<b.length-1;h=-1;for(var k,m,p=b.length+a.length,x,w=0;w<b.length;w++){k=0;for(m=p;k<m;)d(w,\nc+m)<=g?k=m:p=m,m=Math.floor((p-k)/2+k);p=m;k=Math.max(1,c-m+1);var q=Math.min(c+m,a.length)+b.length;m=Array(q+2);for(m[q+1]=(1<<w)-1;q>=k;q--){var t=e[a.charAt(q-1)];m[q]=0===w?(m[q+1]<<1|1)&t:(m[q+1]<<1|1)&t|(x[q+1]|x[q])<<1|1|x[q+1];if(m[q]&l&&(t=d(w,q-1),t<=g))if(g=t,h=q-1,h>c)k=Math.max(1,2*c-h);else break}if(d(w+1,c)>g)break;x=m}return h};\ndiff_match_patch.prototype.match_alphabet_=function(a){for(var b={},c=0;c<a.length;c++)b[a.charAt(c)]=0;for(c=0;c<a.length;c++)b[a.charAt(c)]|=1<<a.length-c-1;return b};\ndiff_match_patch.prototype.patch_addContext_=function(a,b){if(0!=b.length){for(var c=b.substring(a.start2,a.start2+a.length1),d=0;b.indexOf(c)!=b.lastIndexOf(c)&&c.length<this.Match_MaxBits-this.Patch_Margin-this.Patch_Margin;)d+=this.Patch_Margin,c=b.substring(a.start2-d,a.start2+a.length1+d);d+=this.Patch_Margin;(c=b.substring(a.start2-d,a.start2))&&a.diffs.unshift([DIFF_EQUAL,c]);(d=b.substring(a.start2+a.length1,a.start2+a.length1+d))&&a.diffs.push([DIFF_EQUAL,d]);a.start1-=c.length;a.start2-=\nc.length;a.length1+=c.length+d.length;a.length2+=c.length+d.length}};\ndiff_match_patch.prototype.patch_make=function(a,b,c){if(\"string\"==typeof a&&\"string\"==typeof b&&\"undefined\"==typeof c){var d=a;b=this.diff_main(d,b,!0);2<b.length&&(this.diff_cleanupSemantic(b),this.diff_cleanupEfficiency(b))}else if(a&&\"object\"==typeof a&&\"undefined\"==typeof b&&\"undefined\"==typeof c)b=a,d=this.diff_text1(b);else if(\"string\"==typeof a&&b&&\"object\"==typeof b&&\"undefined\"==typeof c)d=a;else if(\"string\"==typeof a&&\"string\"==typeof b&&c&&\"object\"==typeof c)d=a,b=c;else throw Error(\"Unknown call format to patch_make.\");\nif(0===b.length)return[];c=[];a=new diff_match_patch.patch_obj;for(var e=0,f=0,g=0,h=d,l=0;l<b.length;l++){var k=b[l][0],m=b[l][1];e||k===DIFF_EQUAL||(a.start1=f,a.start2=g);switch(k){case DIFF_INSERT:a.diffs[e++]=b[l];a.length2+=m.length;d=d.substring(0,g)+m+d.substring(g);break;case DIFF_DELETE:a.length1+=m.length;a.diffs[e++]=b[l];d=d.substring(0,g)+d.substring(g+m.length);break;case DIFF_EQUAL:m.length<=2*this.Patch_Margin&&e&&b.length!=l+1?(a.diffs[e++]=b[l],a.length1+=m.length,a.length2+=m.length):\nm.length>=2*this.Patch_Margin&&e&&(this.patch_addContext_(a,h),c.push(a),a=new diff_match_patch.patch_obj,e=0,h=d,f=g)}k!==DIFF_INSERT&&(f+=m.length);k!==DIFF_DELETE&&(g+=m.length)}e&&(this.patch_addContext_(a,h),c.push(a));return c};\ndiff_match_patch.prototype.patch_deepCopy=function(a){for(var b=[],c=0;c<a.length;c++){var d=a[c],e=new diff_match_patch.patch_obj;e.diffs=[];for(var f=0;f<d.diffs.length;f++)e.diffs[f]=d.diffs[f].slice();e.start1=d.start1;e.start2=d.start2;e.length1=d.length1;e.length2=d.length2;b[c]=e}return b};\ndiff_match_patch.prototype.patch_apply=function(a,b){if(0==a.length)return[b,[]];a=this.patch_deepCopy(a);var c=this.patch_addPadding(a);b=c+b+c;this.patch_splitMax(a);for(var d=0,e=[],f=0;f<a.length;f++){var g=a[f].start2+d,h=this.diff_text1(a[f].diffs),l=-1;if(h.length>this.Match_MaxBits){var k=this.match_main(b,h.substring(0,this.Match_MaxBits),g);-1!=k&&(l=this.match_main(b,h.substring(h.length-this.Match_MaxBits),g+h.length-this.Match_MaxBits),-1==l||k>=l)&&(k=-1)}else k=this.match_main(b,h,\ng);if(-1==k)e[f]=!1,d-=a[f].length2-a[f].length1;else if(e[f]=!0,d=k-g,g=-1==l?b.substring(k,k+h.length):b.substring(k,l+this.Match_MaxBits),h==g)b=b.substring(0,k)+this.diff_text2(a[f].diffs)+b.substring(k+h.length);else if(g=this.diff_main(h,g,!1),h.length>this.Match_MaxBits&&this.diff_levenshtein(g)/h.length>this.Patch_DeleteThreshold)e[f]=!1;else{this.diff_cleanupSemanticLossless(g);h=0;var m;for(l=0;l<a[f].diffs.length;l++){var p=a[f].diffs[l];p[0]!==DIFF_EQUAL&&(m=this.diff_xIndex(g,h));p[0]===\nDIFF_INSERT?b=b.substring(0,k+m)+p[1]+b.substring(k+m):p[0]===DIFF_DELETE&&(b=b.substring(0,k+m)+b.substring(k+this.diff_xIndex(g,h+p[1].length)));p[0]!==DIFF_DELETE&&(h+=p[1].length)}}}b=b.substring(c.length,b.length-c.length);return[b,e]};\ndiff_match_patch.prototype.patch_addPadding=function(a){for(var b=this.Patch_Margin,c=\"\",d=1;d<=b;d++)c+=String.fromCharCode(d);for(d=0;d<a.length;d++)a[d].start1+=b,a[d].start2+=b;d=a[0];var e=d.diffs;if(0==e.length||e[0][0]!=DIFF_EQUAL)e.unshift([DIFF_EQUAL,c]),d.start1-=b,d.start2-=b,d.length1+=b,d.length2+=b;else if(b>e[0][1].length){var f=b-e[0][1].length;e[0][1]=c.substring(e[0][1].length)+e[0][1];d.start1-=f;d.start2-=f;d.length1+=f;d.length2+=f}d=a[a.length-1];e=d.diffs;0==e.length||e[e.length-\n1][0]!=DIFF_EQUAL?(e.push([DIFF_EQUAL,c]),d.length1+=b,d.length2+=b):b>e[e.length-1][1].length&&(f=b-e[e.length-1][1].length,e[e.length-1][1]+=c.substring(0,f),d.length1+=f,d.length2+=f);return c};\ndiff_match_patch.prototype.patch_splitMax=function(a){for(var b=this.Match_MaxBits,c=0;c<a.length;c++)if(!(a[c].length1<=b)){var d=a[c];a.splice(c--,1);for(var e=d.start1,f=d.start2,g=\"\";0!==d.diffs.length;){var h=new diff_match_patch.patch_obj,l=!0;h.start1=e-g.length;h.start2=f-g.length;\"\"!==g&&(h.length1=h.length2=g.length,h.diffs.push([DIFF_EQUAL,g]));for(;0!==d.diffs.length&&h.length1<b-this.Patch_Margin;){g=d.diffs[0][0];var k=d.diffs[0][1];g===DIFF_INSERT?(h.length2+=k.length,f+=k.length,h.diffs.push(d.diffs.shift()),\nl=!1):g===DIFF_DELETE&&1==h.diffs.length&&h.diffs[0][0]==DIFF_EQUAL&&k.length>2*b?(h.length1+=k.length,e+=k.length,l=!1,h.diffs.push([g,k]),d.diffs.shift()):(k=k.substring(0,b-h.length1-this.Patch_Margin),h.length1+=k.length,e+=k.length,g===DIFF_EQUAL?(h.length2+=k.length,f+=k.length):l=!1,h.diffs.push([g,k]),k==d.diffs[0][1]?d.diffs.shift():d.diffs[0][1]=d.diffs[0][1].substring(k.length))}g=this.diff_text2(h.diffs);g=g.substring(g.length-this.Patch_Margin);k=this.diff_text1(d.diffs).substring(0,\nthis.Patch_Margin);\"\"!==k&&(h.length1+=k.length,h.length2+=k.length,0!==h.diffs.length&&h.diffs[h.diffs.length-1][0]===DIFF_EQUAL?h.diffs[h.diffs.length-1][1]+=k:h.diffs.push([DIFF_EQUAL,k]));l||a.splice(++c,0,h)}}};diff_match_patch.prototype.patch_toText=function(a){for(var b=[],c=0;c<a.length;c++)b[c]=a[c];return b.join(\"\")};\ndiff_match_patch.prototype.patch_fromText=function(a){var b=[];if(!a)return b;a=a.split(\"\\n\");for(var c=0,d=/^@@ -(\\d+),?(\\d*) \\+(\\d+),?(\\d*) @@$/;c<a.length;){var e=a[c].match(d);if(!e)throw Error(\"Invalid patch string: \"+a[c]);var f=new diff_match_patch.patch_obj;b.push(f);f.start1=parseInt(e[1],10);\"\"===e[2]?(f.start1--,f.length1=1):\"0\"==e[2]?f.length1=0:(f.start1--,f.length1=parseInt(e[2],10));f.start2=parseInt(e[3],10);\"\"===e[4]?(f.start2--,f.length2=1):\"0\"==e[4]?f.length2=0:(f.start2--,f.length2=\nparseInt(e[4],10));for(c++;c<a.length;){e=a[c].charAt(0);try{var g=decodeURI(a[c].substring(1))}catch(h){throw Error(\"Illegal escape in patch_fromText: \"+g);}if(\"-\"==e)f.diffs.push([DIFF_DELETE,g]);else if(\"+\"==e)f.diffs.push([DIFF_INSERT,g]);else if(\" \"==e)f.diffs.push([DIFF_EQUAL,g]);else if(\"@\"==e)break;else if(\"\"!==e)throw Error('Invalid patch mode \"'+e+'\" in: '+g);c++}}return b};diff_match_patch.patch_obj=function(){this.diffs=[];this.start2=this.start1=null;this.length2=this.length1=0};\ndiff_match_patch.patch_obj.prototype.toString=function(){for(var a=[\"@@ -\"+(0===this.length1?this.start1+\",0\":1==this.length1?this.start1+1:this.start1+1+\",\"+this.length1)+\" +\"+(0===this.length2?this.start2+\",0\":1==this.length2?this.start2+1:this.start2+1+\",\"+this.length2)+\" @@\\n\"],b,c=0;c<this.diffs.length;c++){switch(this.diffs[c][0]){case DIFF_INSERT:b=\"+\";break;case DIFF_DELETE:b=\"-\";break;case DIFF_EQUAL:b=\" \"}a[c+1]=b+encodeURI(this.diffs[c][1])+\"\\n\"}return a.join(\"\").replace(/%20/g,\" \")};\nthis.diff_match_patch=diff_match_patch;this.DIFF_DELETE=DIFF_DELETE;this.DIFF_INSERT=DIFF_INSERT;this.DIFF_EQUAL=DIFF_EQUAL;\n}).call(exports);",
"type": "application/javascript",
"title": "$:/core/modules/utils/diff-match-patch/diff_match_patch.js",
"module-type": "library"
},
"$:/core/modules/utils/dom/animations/slide.js": {
"title": "$:/core/modules/utils/dom/animations/slide.js",
"text": "/*\\\ntitle: $:/core/modules/utils/dom/animations/slide.js\ntype: application/javascript\nmodule-type: animation\n\nA simple slide animation that varies the height of the element\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nfunction slideOpen(domNode,options) {\n\toptions = options || {};\n\tvar duration = options.duration || $tw.utils.getAnimationDuration();\n\t// Get the current height of the domNode\n\tvar computedStyle = window.getComputedStyle(domNode),\n\t\tcurrMarginBottom = parseInt(computedStyle.marginBottom,10),\n\t\tcurrMarginTop = parseInt(computedStyle.marginTop,10),\n\t\tcurrPaddingBottom = parseInt(computedStyle.paddingBottom,10),\n\t\tcurrPaddingTop = parseInt(computedStyle.paddingTop,10),\n\t\tcurrHeight = domNode.offsetHeight;\n\t// Reset the margin once the transition is over\n\tsetTimeout(function() {\n\t\t$tw.utils.setStyle(domNode,[\n\t\t\t{transition: \"none\"},\n\t\t\t{marginBottom: \"\"},\n\t\t\t{marginTop: \"\"},\n\t\t\t{paddingBottom: \"\"},\n\t\t\t{paddingTop: \"\"},\n\t\t\t{height: \"auto\"},\n\t\t\t{opacity: \"\"}\n\t\t]);\n\t\tif(options.callback) {\n\t\t\toptions.callback();\n\t\t}\n\t},duration);\n\t// Set up the initial position of the element\n\t$tw.utils.setStyle(domNode,[\n\t\t{transition: \"none\"},\n\t\t{marginTop: \"0px\"},\n\t\t{marginBottom: \"0px\"},\n\t\t{paddingTop: \"0px\"},\n\t\t{paddingBottom: \"0px\"},\n\t\t{height: \"0px\"},\n\t\t{opacity: \"0\"}\n\t]);\n\t$tw.utils.forceLayout(domNode);\n\t// Transition to the final position\n\t$tw.utils.setStyle(domNode,[\n\t\t{transition: \"margin-top \" + duration + \"ms ease-in-out, \" +\n\t\t\t\t\t\"margin-bottom \" + duration + \"ms ease-in-out, \" +\n\t\t\t\t\t\"padding-top \" + duration + \"ms ease-in-out, \" +\n\t\t\t\t\t\"padding-bottom \" + duration + \"ms ease-in-out, \" +\n\t\t\t\t\t\"height \" + duration + \"ms ease-in-out, \" +\n\t\t\t\t\t\"opacity \" + duration + \"ms ease-in-out\"},\n\t\t{marginBottom: currMarginBottom + \"px\"},\n\t\t{marginTop: currMarginTop + \"px\"},\n\t\t{paddingBottom: currPaddingBottom + \"px\"},\n\t\t{paddingTop: currPaddingTop + \"px\"},\n\t\t{height: currHeight + \"px\"},\n\t\t{opacity: \"1\"}\n\t]);\n}\n\nfunction slideClosed(domNode,options) {\n\toptions = options || {};\n\tvar duration = options.duration || $tw.utils.getAnimationDuration(),\n\t\tcurrHeight = domNode.offsetHeight;\n\t// Clear the properties we've set when the animation is over\n\tsetTimeout(function() {\n\t\t$tw.utils.setStyle(domNode,[\n\t\t\t{transition: \"none\"},\n\t\t\t{marginBottom: \"\"},\n\t\t\t{marginTop: \"\"},\n\t\t\t{paddingBottom: \"\"},\n\t\t\t{paddingTop: \"\"},\n\t\t\t{height: \"auto\"},\n\t\t\t{opacity: \"\"}\n\t\t]);\n\t\tif(options.callback) {\n\t\t\toptions.callback();\n\t\t}\n\t},duration);\n\t// Set up the initial position of the element\n\t$tw.utils.setStyle(domNode,[\n\t\t{height: currHeight + \"px\"},\n\t\t{opacity: \"1\"}\n\t]);\n\t$tw.utils.forceLayout(domNode);\n\t// Transition to the final position\n\t$tw.utils.setStyle(domNode,[\n\t\t{transition: \"margin-top \" + duration + \"ms ease-in-out, \" +\n\t\t\t\t\t\"margin-bottom \" + duration + \"ms ease-in-out, \" +\n\t\t\t\t\t\"padding-top \" + duration + \"ms ease-in-out, \" +\n\t\t\t\t\t\"padding-bottom \" + duration + \"ms ease-in-out, \" +\n\t\t\t\t\t\"height \" + duration + \"ms ease-in-out, \" +\n\t\t\t\t\t\"opacity \" + duration + \"ms ease-in-out\"},\n\t\t{marginTop: \"0px\"},\n\t\t{marginBottom: \"0px\"},\n\t\t{paddingTop: \"0px\"},\n\t\t{paddingBottom: \"0px\"},\n\t\t{height: \"0px\"},\n\t\t{opacity: \"0\"}\n\t]);\n}\n\nexports.slide = {\n\topen: slideOpen,\n\tclose: slideClosed\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "animation"
},
"$:/core/modules/utils/dom/animator.js": {
"title": "$:/core/modules/utils/dom/animator.js",
"text": "/*\\\ntitle: $:/core/modules/utils/dom/animator.js\ntype: application/javascript\nmodule-type: utils\n\nOrchestrates animations and transitions\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nfunction Animator() {\n\t// Get the registered animation modules\n\tthis.animations = {};\n\t$tw.modules.applyMethods(\"animation\",this.animations);\n}\n\nAnimator.prototype.perform = function(type,domNode,options) {\n\toptions = options || {};\n\t// Find an animation that can handle this type\n\tvar chosenAnimation;\n\t$tw.utils.each(this.animations,function(animation,name) {\n\t\tif($tw.utils.hop(animation,type)) {\n\t\t\tchosenAnimation = animation[type];\n\t\t}\n\t});\n\tif(!chosenAnimation) {\n\t\tchosenAnimation = function(domNode,options) {\n\t\t\tif(options.callback) {\n\t\t\t\toptions.callback();\n\t\t\t}\n\t\t};\n\t}\n\t// Call the animation\n\tchosenAnimation(domNode,options);\n};\n\nexports.Animator = Animator;\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/utils/dom/browser.js": {
"title": "$:/core/modules/utils/dom/browser.js",
"text": "/*\\\ntitle: $:/core/modules/utils/dom/browser.js\ntype: application/javascript\nmodule-type: utils\n\nBrowser feature detection\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nSet style properties of an element\n\telement: dom node\n\tstyles: ordered array of {name: value} pairs\n*/\nexports.setStyle = function(element,styles) {\n\tif(element.nodeType === 1) { // Element.ELEMENT_NODE\n\t\tfor(var t=0; t<styles.length; t++) {\n\t\t\tfor(var styleName in styles[t]) {\n\t\t\t\telement.style[$tw.utils.convertStyleNameToPropertyName(styleName)] = styles[t][styleName];\n\t\t\t}\n\t\t}\n\t}\n};\n\n/*\nConverts a standard CSS property name into the local browser-specific equivalent. For example:\n\t\"background-color\" --> \"backgroundColor\"\n\t\"transition\" --> \"webkitTransition\"\n*/\n\nvar styleNameCache = {}; // We'll cache the style name conversions\n\nexports.convertStyleNameToPropertyName = function(styleName) {\n\t// Return from the cache if we can\n\tif(styleNameCache[styleName]) {\n\t\treturn styleNameCache[styleName];\n\t}\n\t// Convert it by first removing any hyphens\n\tvar propertyName = $tw.utils.unHyphenateCss(styleName);\n\t// Then check if it needs a prefix\n\tif($tw.browser && document.body.style[propertyName] === undefined) {\n\t\tvar prefixes = [\"O\",\"MS\",\"Moz\",\"webkit\"];\n\t\tfor(var t=0; t<prefixes.length; t++) {\n\t\t\tvar prefixedName = prefixes[t] + propertyName.substr(0,1).toUpperCase() + propertyName.substr(1);\n\t\t\tif(document.body.style[prefixedName] !== undefined) {\n\t\t\t\tpropertyName = prefixedName;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\t// Put it in the cache too\n\tstyleNameCache[styleName] = propertyName;\n\treturn propertyName;\n};\n\n/*\nConverts a JS format CSS property name back into the dashed form used in CSS declarations. For example:\n\t\"backgroundColor\" --> \"background-color\"\n\t\"webkitTransform\" --> \"-webkit-transform\"\n*/\nexports.convertPropertyNameToStyleName = function(propertyName) {\n\t// Rehyphenate the name\n\tvar styleName = $tw.utils.hyphenateCss(propertyName);\n\t// If there's a webkit prefix, add a dash (other browsers have uppercase prefixes, and so get the dash automatically)\n\tif(styleName.indexOf(\"webkit\") === 0) {\n\t\tstyleName = \"-\" + styleName;\n\t} else if(styleName.indexOf(\"-m-s\") === 0) {\n\t\tstyleName = \"-ms\" + styleName.substr(4);\n\t}\n\treturn styleName;\n};\n\n/*\nRound trip a stylename to a property name and back again. For example:\n\t\"transform\" --> \"webkitTransform\" --> \"-webkit-transform\"\n*/\nexports.roundTripPropertyName = function(propertyName) {\n\treturn $tw.utils.convertPropertyNameToStyleName($tw.utils.convertStyleNameToPropertyName(propertyName));\n};\n\n/*\nConverts a standard event name into the local browser specific equivalent. For example:\n\t\"animationEnd\" --> \"webkitAnimationEnd\"\n*/\n\nvar eventNameCache = {}; // We'll cache the conversions\n\nvar eventNameMappings = {\n\t\"transitionEnd\": {\n\t\tcorrespondingCssProperty: \"transition\",\n\t\tmappings: {\n\t\t\ttransition: \"transitionend\",\n\t\t\tOTransition: \"oTransitionEnd\",\n\t\t\tMSTransition: \"msTransitionEnd\",\n\t\t\tMozTransition: \"transitionend\",\n\t\t\twebkitTransition: \"webkitTransitionEnd\"\n\t\t}\n\t},\n\t\"animationEnd\": {\n\t\tcorrespondingCssProperty: \"animation\",\n\t\tmappings: {\n\t\t\tanimation: \"animationend\",\n\t\t\tOAnimation: \"oAnimationEnd\",\n\t\t\tMSAnimation: \"msAnimationEnd\",\n\t\t\tMozAnimation: \"animationend\",\n\t\t\twebkitAnimation: \"webkitAnimationEnd\"\n\t\t}\n\t}\n};\n\nexports.convertEventName = function(eventName) {\n\tif(eventNameCache[eventName]) {\n\t\treturn eventNameCache[eventName];\n\t}\n\tvar newEventName = eventName,\n\t\tmappings = eventNameMappings[eventName];\n\tif(mappings) {\n\t\tvar convertedProperty = $tw.utils.convertStyleNameToPropertyName(mappings.correspondingCssProperty);\n\t\tif(mappings.mappings[convertedProperty]) {\n\t\t\tnewEventName = mappings.mappings[convertedProperty];\n\t\t}\n\t}\n\t// Put it in the cache too\n\teventNameCache[eventName] = newEventName;\n\treturn newEventName;\n};\n\n/*\nReturn the names of the fullscreen APIs\n*/\nexports.getFullScreenApis = function() {\n\tvar d = document,\n\t\tdb = d.body,\n\t\tresult = {\n\t\t\"_requestFullscreen\": db.webkitRequestFullscreen !== undefined ? \"webkitRequestFullscreen\" :\n\t\t\t\t\t\t\tdb.mozRequestFullScreen !== undefined ? \"mozRequestFullScreen\" :\n\t\t\t\t\t\t\tdb.msRequestFullscreen !== undefined ? \"msRequestFullscreen\" :\n\t\t\t\t\t\t\tdb.requestFullscreen !== undefined ? \"requestFullscreen\" : \"\",\n\t\t\"_exitFullscreen\": d.webkitExitFullscreen !== undefined ? \"webkitExitFullscreen\" :\n\t\t\t\t\t\t\td.mozCancelFullScreen !== undefined ? \"mozCancelFullScreen\" :\n\t\t\t\t\t\t\td.msExitFullscreen !== undefined ? \"msExitFullscreen\" :\n\t\t\t\t\t\t\td.exitFullscreen !== undefined ? \"exitFullscreen\" : \"\",\n\t\t\"_fullscreenElement\": d.webkitFullscreenElement !== undefined ? \"webkitFullscreenElement\" :\n\t\t\t\t\t\t\td.mozFullScreenElement !== undefined ? \"mozFullScreenElement\" :\n\t\t\t\t\t\t\td.msFullscreenElement !== undefined ? \"msFullscreenElement\" :\n\t\t\t\t\t\t\td.fullscreenElement !== undefined ? \"fullscreenElement\" : \"\",\n\t\t\"_fullscreenChange\": d.webkitFullscreenElement !== undefined ? \"webkitfullscreenchange\" :\n\t\t\t\t\t\t\td.mozFullScreenElement !== undefined ? \"mozfullscreenchange\" :\n\t\t\t\t\t\t\td.msFullscreenElement !== undefined ? \"MSFullscreenChange\" :\n\t\t\t\t\t\t\td.fullscreenElement !== undefined ? \"fullscreenchange\" : \"\"\n\t};\n\tif(!result._requestFullscreen || !result._exitFullscreen || !result._fullscreenElement || !result._fullscreenChange) {\n\t\treturn null;\n\t} else {\n\t\treturn result;\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/utils/dom/csscolorparser.js": {
"title": "$:/core/modules/utils/dom/csscolorparser.js",
"text": "// (c) Dean McNamee <dean@gmail.com>, 2012.\n//\n// https://github.com/deanm/css-color-parser-js\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to\n// deal in the Software without restriction, including without limitation the\n// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n// sell copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\n// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS\n// IN THE SOFTWARE.\n\n// http://www.w3.org/TR/css3-color/\nvar kCSSColorTable = {\n \"transparent\": [0,0,0,0], \"aliceblue\": [240,248,255,1],\n \"antiquewhite\": [250,235,215,1], \"aqua\": [0,255,255,1],\n \"aquamarine\": [127,255,212,1], \"azure\": [240,255,255,1],\n \"beige\": [245,245,220,1], \"bisque\": [255,228,196,1],\n \"black\": [0,0,0,1], \"blanchedalmond\": [255,235,205,1],\n \"blue\": [0,0,255,1], \"blueviolet\": [138,43,226,1],\n \"brown\": [165,42,42,1], \"burlywood\": [222,184,135,1],\n \"cadetblue\": [95,158,160,1], \"chartreuse\": [127,255,0,1],\n \"chocolate\": [210,105,30,1], \"coral\": [255,127,80,1],\n \"cornflowerblue\": [100,149,237,1], \"cornsilk\": [255,248,220,1],\n \"crimson\": [220,20,60,1], \"cyan\": [0,255,255,1],\n \"darkblue\": [0,0,139,1], \"darkcyan\": [0,139,139,1],\n \"darkgoldenrod\": [184,134,11,1], \"darkgray\": [169,169,169,1],\n \"darkgreen\": [0,100,0,1], \"darkgrey\": [169,169,169,1],\n \"darkkhaki\": [189,183,107,1], \"darkmagenta\": [139,0,139,1],\n \"darkolivegreen\": [85,107,47,1], \"darkorange\": [255,140,0,1],\n \"darkorchid\": [153,50,204,1], \"darkred\": [139,0,0,1],\n \"darksalmon\": [233,150,122,1], \"darkseagreen\": [143,188,143,1],\n \"darkslateblue\": [72,61,139,1], \"darkslategray\": [47,79,79,1],\n \"darkslategrey\": [47,79,79,1], \"darkturquoise\": [0,206,209,1],\n \"darkviolet\": [148,0,211,1], \"deeppink\": [255,20,147,1],\n \"deepskyblue\": [0,191,255,1], \"dimgray\": [105,105,105,1],\n \"dimgrey\": [105,105,105,1], \"dodgerblue\": [30,144,255,1],\n \"firebrick\": [178,34,34,1], \"floralwhite\": [255,250,240,1],\n \"forestgreen\": [34,139,34,1], \"fuchsia\": [255,0,255,1],\n \"gainsboro\": [220,220,220,1], \"ghostwhite\": [248,248,255,1],\n \"gold\": [255,215,0,1], \"goldenrod\": [218,165,32,1],\n \"gray\": [128,128,128,1], \"green\": [0,128,0,1],\n \"greenyellow\": [173,255,47,1], \"grey\": [128,128,128,1],\n \"honeydew\": [240,255,240,1], \"hotpink\": [255,105,180,1],\n \"indianred\": [205,92,92,1], \"indigo\": [75,0,130,1],\n \"ivory\": [255,255,240,1], \"khaki\": [240,230,140,1],\n \"lavender\": [230,230,250,1], \"lavenderblush\": [255,240,245,1],\n \"lawngreen\": [124,252,0,1], \"lemonchiffon\": [255,250,205,1],\n \"lightblue\": [173,216,230,1], \"lightcoral\": [240,128,128,1],\n \"lightcyan\": [224,255,255,1], \"lightgoldenrodyellow\": [250,250,210,1],\n \"lightgray\": [211,211,211,1], \"lightgreen\": [144,238,144,1],\n \"lightgrey\": [211,211,211,1], \"lightpink\": [255,182,193,1],\n \"lightsalmon\": [255,160,122,1], \"lightseagreen\": [32,178,170,1],\n \"lightskyblue\": [135,206,250,1], \"lightslategray\": [119,136,153,1],\n \"lightslategrey\": [119,136,153,1], \"lightsteelblue\": [176,196,222,1],\n \"lightyellow\": [255,255,224,1], \"lime\": [0,255,0,1],\n \"limegreen\": [50,205,50,1], \"linen\": [250,240,230,1],\n \"magenta\": [255,0,255,1], \"maroon\": [128,0,0,1],\n \"mediumaquamarine\": [102,205,170,1], \"mediumblue\": [0,0,205,1],\n \"mediumorchid\": [186,85,211,1], \"mediumpurple\": [147,112,219,1],\n \"mediumseagreen\": [60,179,113,1], \"mediumslateblue\": [123,104,238,1],\n \"mediumspringgreen\": [0,250,154,1], \"mediumturquoise\": [72,209,204,1],\n \"mediumvioletred\": [199,21,133,1], \"midnightblue\": [25,25,112,1],\n \"mintcream\": [245,255,250,1], \"mistyrose\": [255,228,225,1],\n \"moccasin\": [255,228,181,1], \"navajowhite\": [255,222,173,1],\n \"navy\": [0,0,128,1], \"oldlace\": [253,245,230,1],\n \"olive\": [128,128,0,1], \"olivedrab\": [107,142,35,1],\n \"orange\": [255,165,0,1], \"orangered\": [255,69,0,1],\n \"orchid\": [218,112,214,1], \"palegoldenrod\": [238,232,170,1],\n \"palegreen\": [152,251,152,1], \"paleturquoise\": [175,238,238,1],\n \"palevioletred\": [219,112,147,1], \"papayawhip\": [255,239,213,1],\n \"peachpuff\": [255,218,185,1], \"peru\": [205,133,63,1],\n \"pink\": [255,192,203,1], \"plum\": [221,160,221,1],\n \"powderblue\": [176,224,230,1], \"purple\": [128,0,128,1],\n \"red\": [255,0,0,1], \"rosybrown\": [188,143,143,1],\n \"royalblue\": [65,105,225,1], \"saddlebrown\": [139,69,19,1],\n \"salmon\": [250,128,114,1], \"sandybrown\": [244,164,96,1],\n \"seagreen\": [46,139,87,1], \"seashell\": [255,245,238,1],\n \"sienna\": [160,82,45,1], \"silver\": [192,192,192,1],\n \"skyblue\": [135,206,235,1], \"slateblue\": [106,90,205,1],\n \"slategray\": [112,128,144,1], \"slategrey\": [112,128,144,1],\n \"snow\": [255,250,250,1], \"springgreen\": [0,255,127,1],\n \"steelblue\": [70,130,180,1], \"tan\": [210,180,140,1],\n \"teal\": [0,128,128,1], \"thistle\": [216,191,216,1],\n \"tomato\": [255,99,71,1], \"turquoise\": [64,224,208,1],\n \"violet\": [238,130,238,1], \"wheat\": [245,222,179,1],\n \"white\": [255,255,255,1], \"whitesmoke\": [245,245,245,1],\n \"yellow\": [255,255,0,1], \"yellowgreen\": [154,205,50,1]}\n\nfunction clamp_css_byte(i) { // Clamp to integer 0 .. 255.\n i = Math.round(i); // Seems to be what Chrome does (vs truncation).\n return i < 0 ? 0 : i > 255 ? 255 : i;\n}\n\nfunction clamp_css_float(f) { // Clamp to float 0.0 .. 1.0.\n return f < 0 ? 0 : f > 1 ? 1 : f;\n}\n\nfunction parse_css_int(str) { // int or percentage.\n if (str[str.length - 1] === '%')\n return clamp_css_byte(parseFloat(str) / 100 * 255);\n return clamp_css_byte(parseInt(str));\n}\n\nfunction parse_css_float(str) { // float or percentage.\n if (str[str.length - 1] === '%')\n return clamp_css_float(parseFloat(str) / 100);\n return clamp_css_float(parseFloat(str));\n}\n\nfunction css_hue_to_rgb(m1, m2, h) {\n if (h < 0) h += 1;\n else if (h > 1) h -= 1;\n\n if (h * 6 < 1) return m1 + (m2 - m1) * h * 6;\n if (h * 2 < 1) return m2;\n if (h * 3 < 2) return m1 + (m2 - m1) * (2/3 - h) * 6;\n return m1;\n}\n\nfunction parseCSSColor(css_str) {\n // Remove all whitespace, not compliant, but should just be more accepting.\n var str = css_str.replace(/ /g, '').toLowerCase();\n\n // Color keywords (and transparent) lookup.\n if (str in kCSSColorTable) return kCSSColorTable[str].slice(); // dup.\n\n // #abc and #abc123 syntax.\n if (str[0] === '#') {\n if (str.length === 4) {\n var iv = parseInt(str.substr(1), 16); // TODO(deanm): Stricter parsing.\n if (!(iv >= 0 && iv <= 0xfff)) return null; // Covers NaN.\n return [((iv & 0xf00) >> 4) | ((iv & 0xf00) >> 8),\n (iv & 0xf0) | ((iv & 0xf0) >> 4),\n (iv & 0xf) | ((iv & 0xf) << 4),\n 1];\n } else if (str.length === 7) {\n var iv = parseInt(str.substr(1), 16); // TODO(deanm): Stricter parsing.\n if (!(iv >= 0 && iv <= 0xffffff)) return null; // Covers NaN.\n return [(iv & 0xff0000) >> 16,\n (iv & 0xff00) >> 8,\n iv & 0xff,\n 1];\n }\n\n return null;\n }\n\n var op = str.indexOf('('), ep = str.indexOf(')');\n if (op !== -1 && ep + 1 === str.length) {\n var fname = str.substr(0, op);\n var params = str.substr(op+1, ep-(op+1)).split(',');\n var alpha = 1; // To allow case fallthrough.\n switch (fname) {\n case 'rgba':\n if (params.length !== 4) return null;\n alpha = parse_css_float(params.pop());\n // Fall through.\n case 'rgb':\n if (params.length !== 3) return null;\n return [parse_css_int(params[0]),\n parse_css_int(params[1]),\n parse_css_int(params[2]),\n alpha];\n case 'hsla':\n if (params.length !== 4) return null;\n alpha = parse_css_float(params.pop());\n // Fall through.\n case 'hsl':\n if (params.length !== 3) return null;\n var h = (((parseFloat(params[0]) % 360) + 360) % 360) / 360; // 0 .. 1\n // NOTE(deanm): According to the CSS spec s/l should only be\n // percentages, but we don't bother and let float or percentage.\n var s = parse_css_float(params[1]);\n var l = parse_css_float(params[2]);\n var m2 = l <= 0.5 ? l * (s + 1) : l + s - l * s;\n var m1 = l * 2 - m2;\n return [clamp_css_byte(css_hue_to_rgb(m1, m2, h+1/3) * 255),\n clamp_css_byte(css_hue_to_rgb(m1, m2, h) * 255),\n clamp_css_byte(css_hue_to_rgb(m1, m2, h-1/3) * 255),\n alpha];\n default:\n return null;\n }\n }\n\n return null;\n}\n\ntry { exports.parseCSSColor = parseCSSColor } catch(e) { }\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/utils/dom.js": {
"title": "$:/core/modules/utils/dom.js",
"text": "/*\\\ntitle: $:/core/modules/utils/dom.js\ntype: application/javascript\nmodule-type: utils\n\nVarious static DOM-related utility functions.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nDetermines whether element 'a' contains element 'b'\nCode thanks to John Resig, http://ejohn.org/blog/comparing-document-position/\n*/\nexports.domContains = function(a,b) {\n\treturn a.contains ?\n\t\ta !== b && a.contains(b) :\n\t\t!!(a.compareDocumentPosition(b) & 16);\n};\n\nexports.removeChildren = function(node) {\n\twhile(node.hasChildNodes()) {\n\t\tnode.removeChild(node.firstChild);\n\t}\n};\n\nexports.hasClass = function(el,className) {\n\treturn el && el.className && el.className.toString().split(\" \").indexOf(className) !== -1;\n};\n\nexports.addClass = function(el,className) {\n\tvar c = el.className.split(\" \");\n\tif(c.indexOf(className) === -1) {\n\t\tc.push(className);\n\t}\n\tel.className = c.join(\" \");\n};\n\nexports.removeClass = function(el,className) {\n\tvar c = el.className.split(\" \"),\n\t\tp = c.indexOf(className);\n\tif(p !== -1) {\n\t\tc.splice(p,1);\n\t\tel.className = c.join(\" \");\n\t}\n};\n\nexports.toggleClass = function(el,className,status) {\n\tif(status === undefined) {\n\t\tstatus = !exports.hasClass(el,className);\n\t}\n\tif(status) {\n\t\texports.addClass(el,className);\n\t} else {\n\t\texports.removeClass(el,className);\n\t}\n};\n\n/*\nGet the first parent element that has scrollbars or use the body as fallback.\n*/\nexports.getScrollContainer = function(el) {\n\tvar doc = el.ownerDocument;\n\twhile(el.parentNode) {\t\n\t\tel = el.parentNode;\n\t\tif(el.scrollTop) {\n\t\t\treturn el;\n\t\t}\n\t}\n\treturn doc.body;\n};\n\n/*\nGet the scroll position of the viewport\nReturns:\n\t{\n\t\tx: horizontal scroll position in pixels,\n\t\ty: vertical scroll position in pixels\n\t}\n*/\nexports.getScrollPosition = function(srcWindow) {\n\tvar scrollWindow = srcWindow || window;\n\tif(\"scrollX\" in scrollWindow) {\n\t\treturn {x: scrollWindow.scrollX, y: scrollWindow.scrollY};\n\t} else {\n\t\treturn {x: scrollWindow.document.documentElement.scrollLeft, y: scrollWindow.document.documentElement.scrollTop};\n\t}\n};\n\n/*\nAdjust the height of a textarea to fit its content, preserving scroll position, and return the height\n*/\nexports.resizeTextAreaToFit = function(domNode,minHeight) {\n\t// Get the scroll container and register the current scroll position\n\tvar container = $tw.utils.getScrollContainer(domNode),\n\t\tscrollTop = container.scrollTop;\n // Measure the specified minimum height\n\tdomNode.style.height = minHeight;\n\tvar measuredHeight = domNode.offsetHeight || parseInt(minHeight,10);\n\t// Set its height to auto so that it snaps to the correct height\n\tdomNode.style.height = \"auto\";\n\t// Calculate the revised height\n\tvar newHeight = Math.max(domNode.scrollHeight + domNode.offsetHeight - domNode.clientHeight,measuredHeight);\n\t// Only try to change the height if it has changed\n\tif(newHeight !== domNode.offsetHeight) {\n\t\tdomNode.style.height = newHeight + \"px\";\n\t\t// Make sure that the dimensions of the textarea are recalculated\n\t\t$tw.utils.forceLayout(domNode);\n\t\t// Set the container to the position we registered at the beginning\n\t\tcontainer.scrollTop = scrollTop;\n\t}\n\treturn newHeight;\n};\n\n/*\nGets the bounding rectangle of an element in absolute page coordinates\n*/\nexports.getBoundingPageRect = function(element) {\n\tvar scrollPos = $tw.utils.getScrollPosition(element.ownerDocument.defaultView),\n\t\tclientRect = element.getBoundingClientRect();\n\treturn {\n\t\tleft: clientRect.left + scrollPos.x,\n\t\twidth: clientRect.width,\n\t\tright: clientRect.right + scrollPos.x,\n\t\ttop: clientRect.top + scrollPos.y,\n\t\theight: clientRect.height,\n\t\tbottom: clientRect.bottom + scrollPos.y\n\t};\n};\n\n/*\nSaves a named password in the browser\n*/\nexports.savePassword = function(name,password) {\n\ttry {\n\t\tif(window.localStorage) {\n\t\t\tlocalStorage.setItem(\"tw5-password-\" + name,password);\n\t\t}\n\t} catch(e) {\n\t}\n};\n\n/*\nRetrieve a named password from the browser\n*/\nexports.getPassword = function(name) {\n\ttry {\n\t\treturn window.localStorage ? localStorage.getItem(\"tw5-password-\" + name) : \"\";\n\t} catch(e) {\n\t\treturn \"\";\n\t}\n};\n\n/*\nForce layout of a dom node and its descendents\n*/\nexports.forceLayout = function(element) {\n\tvar dummy = element.offsetWidth;\n};\n\n/*\nPulse an element for debugging purposes\n*/\nexports.pulseElement = function(element) {\n\t// Event handler to remove the class at the end\n\telement.addEventListener($tw.browser.animationEnd,function handler(event) {\n\t\telement.removeEventListener($tw.browser.animationEnd,handler,false);\n\t\t$tw.utils.removeClass(element,\"pulse\");\n\t},false);\n\t// Apply the pulse class\n\t$tw.utils.removeClass(element,\"pulse\");\n\t$tw.utils.forceLayout(element);\n\t$tw.utils.addClass(element,\"pulse\");\n};\n\n/*\nAttach specified event handlers to a DOM node\ndomNode: where to attach the event handlers\nevents: array of event handlers to be added (see below)\nEach entry in the events array is an object with these properties:\nhandlerFunction: optional event handler function\nhandlerObject: optional event handler object\nhandlerMethod: optionally specifies object handler method name (defaults to `handleEvent`)\n*/\nexports.addEventListeners = function(domNode,events) {\n\t$tw.utils.each(events,function(eventInfo) {\n\t\tvar handler;\n\t\tif(eventInfo.handlerFunction) {\n\t\t\thandler = eventInfo.handlerFunction;\n\t\t} else if(eventInfo.handlerObject) {\n\t\t\tif(eventInfo.handlerMethod) {\n\t\t\t\thandler = function(event) {\n\t\t\t\t\teventInfo.handlerObject[eventInfo.handlerMethod].call(eventInfo.handlerObject,event);\n\t\t\t\t};\t\n\t\t\t} else {\n\t\t\t\thandler = eventInfo.handlerObject;\n\t\t\t}\n\t\t}\n\t\tdomNode.addEventListener(eventInfo.name,handler,false);\n\t});\n};\n\n/*\nGet the computed styles applied to an element as an array of strings of individual CSS properties\n*/\nexports.getComputedStyles = function(domNode) {\n\tvar textAreaStyles = window.getComputedStyle(domNode,null),\n\t\tstyleDefs = [],\n\t\tname;\n\tfor(var t=0; t<textAreaStyles.length; t++) {\n\t\tname = textAreaStyles[t];\n\t\tstyleDefs.push(name + \": \" + textAreaStyles.getPropertyValue(name) + \";\");\n\t}\n\treturn styleDefs;\n};\n\n/*\nApply a set of styles passed as an array of strings of individual CSS properties\n*/\nexports.setStyles = function(domNode,styleDefs) {\n\tdomNode.style.cssText = styleDefs.join(\"\");\n};\n\n/*\nCopy the computed styles from a source element to a destination element\n*/\nexports.copyStyles = function(srcDomNode,dstDomNode) {\n\t$tw.utils.setStyles(dstDomNode,$tw.utils.getComputedStyles(srcDomNode));\n};\n\n/*\nCopy plain text to the clipboard on browsers that support it\n*/\nexports.copyToClipboard = function(text,options) {\n\toptions = options || {};\n\tvar textArea = document.createElement(\"textarea\");\n\ttextArea.style.position = \"fixed\";\n\ttextArea.style.top = 0;\n\ttextArea.style.left = 0;\n\ttextArea.style.fontSize = \"12pt\";\n\ttextArea.style.width = \"2em\";\n\ttextArea.style.height = \"2em\";\n\ttextArea.style.padding = 0;\n\ttextArea.style.border = \"none\";\n\ttextArea.style.outline = \"none\";\n\ttextArea.style.boxShadow = \"none\";\n\ttextArea.style.background = \"transparent\";\n\ttextArea.value = text;\n\tdocument.body.appendChild(textArea);\n\ttextArea.select();\n\ttextArea.setSelectionRange(0,text.length);\n\tvar succeeded = false;\n\ttry {\n\t\tsucceeded = document.execCommand(\"copy\");\n\t} catch (err) {\n\t}\n\tif(!options.doNotNotify) {\n\t\t$tw.notifier.display(succeeded ? \"$:/language/Notifications/CopiedToClipboard/Succeeded\" : \"$:/language/Notifications/CopiedToClipboard/Failed\");\n\t}\n\tdocument.body.removeChild(textArea);\n};\n\nexports.getLocationPath = function() {\n\treturn window.location.toString().split(\"#\")[0];\n};\n\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/utils/dom/dragndrop.js": {
"title": "$:/core/modules/utils/dom/dragndrop.js",
"text": "/*\\\ntitle: $:/core/modules/utils/dom/dragndrop.js\ntype: application/javascript\nmodule-type: utils\n\nBrowser data transfer utilities, used with the clipboard and drag and drop\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nOptions:\n\ndomNode: dom node to make draggable\ndragImageType: \"pill\" or \"dom\"\ndragTiddlerFn: optional function to retrieve the title of tiddler to drag\ndragFilterFn: optional function to retreive the filter defining a list of tiddlers to drag\nwidget: widget to use as the contect for the filter\n*/\nexports.makeDraggable = function(options) {\n\tvar dragImageType = options.dragImageType || \"dom\",\n\t\tdragImage,\n\t\tdomNode = options.domNode;\n\t// Make the dom node draggable (not necessary for anchor tags)\n\tif((domNode.tagName || \"\").toLowerCase() !== \"a\") {\n\t\tdomNode.setAttribute(\"draggable\",\"true\");\t\t\n\t}\n\t// Add event handlers\n\t$tw.utils.addEventListeners(domNode,[\n\t\t{name: \"dragstart\", handlerFunction: function(event) {\n\t\t\tif(event.dataTransfer === undefined) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\t// Collect the tiddlers being dragged\n\t\t\tvar dragTiddler = options.dragTiddlerFn && options.dragTiddlerFn(),\n\t\t\t\tdragFilter = options.dragFilterFn && options.dragFilterFn(),\n\t\t\t\ttitles = dragTiddler ? [dragTiddler] : [],\n\t\t\t \tstartActions = options.startActions;\n\t\t\tif(dragFilter) {\n\t\t\t\ttitles.push.apply(titles,options.widget.wiki.filterTiddlers(dragFilter,options.widget));\n\t\t\t}\n\t\t\tvar titleString = $tw.utils.stringifyList(titles);\n\t\t\t// Check that we've something to drag\n\t\t\tif(titles.length > 0 && event.target === domNode) {\n\t\t\t\t// Mark the drag in progress\n\t\t\t\t$tw.dragInProgress = domNode;\n\t\t\t\t// Set the dragging class on the element being dragged\n\t\t\t\t$tw.utils.addClass(event.target,\"tc-dragging\");\n\t\t\t\t// Invoke drag-start actions if given\n\t\t\t\tif(startActions !== undefined) {\n\t\t\t\t\toptions.widget.invokeActionString(startActions,options.widget,event,{actionTiddler: titleString});\n\t\t\t\t}\n\t\t\t\t// Create the drag image elements\n\t\t\t\tdragImage = options.widget.document.createElement(\"div\");\n\t\t\t\tdragImage.className = \"tc-tiddler-dragger\";\n\t\t\t\tvar inner = options.widget.document.createElement(\"div\");\n\t\t\t\tinner.className = \"tc-tiddler-dragger-inner\";\n\t\t\t\tinner.appendChild(options.widget.document.createTextNode(\n\t\t\t\t\ttitles.length === 1 ? \n\t\t\t\t\t\ttitles[0] :\n\t\t\t\t\t\ttitles.length + \" tiddlers\"\n\t\t\t\t));\n\t\t\t\tdragImage.appendChild(inner);\n\t\t\t\toptions.widget.document.body.appendChild(dragImage);\n\t\t\t\t// Set the data transfer properties\n\t\t\t\tvar dataTransfer = event.dataTransfer;\n\t\t\t\t// Set up the image\n\t\t\t\tdataTransfer.effectAllowed = \"all\";\n\t\t\t\tif(dataTransfer.setDragImage) {\n\t\t\t\t\tif(dragImageType === \"pill\") {\n\t\t\t\t\t\tdataTransfer.setDragImage(dragImage.firstChild,-16,-16);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvar r = domNode.getBoundingClientRect();\n\t\t\t\t\t\tdataTransfer.setDragImage(domNode,event.clientX-r.left,event.clientY-r.top);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t// Set up the data transfer\n\t\t\t\tif(dataTransfer.clearData) {\n\t\t\t\t\tdataTransfer.clearData();\t\t\t\t\t\n\t\t\t\t}\n\t\t\t\tvar jsonData = [];\n\t\t\t\tif(titles.length > 1) {\n\t\t\t\t\ttitles.forEach(function(title) {\n\t\t\t\t\t\tjsonData.push(options.widget.wiki.getTiddlerAsJson(title));\n\t\t\t\t\t});\n\t\t\t\t\tjsonData = \"[\" + jsonData.join(\",\") + \"]\";\n\t\t\t\t} else {\n\t\t\t\t\tjsonData = options.widget.wiki.getTiddlerAsJson(titles[0]);\n\t\t\t\t}\n\t\t\t\t// IE doesn't like these content types\n\t\t\t\tif(!$tw.browser.isIE) {\n\t\t\t\t\tdataTransfer.setData(\"text/vnd.tiddler\",jsonData);\n\t\t\t\t\tdataTransfer.setData(\"text/plain\",titleString);\n\t\t\t\t\tdataTransfer.setData(\"text/x-moz-url\",\"data:text/vnd.tiddler,\" + encodeURIComponent(jsonData));\n\t\t\t\t}\n\t\t\t\tdataTransfer.setData(\"URL\",\"data:text/vnd.tiddler,\" + encodeURIComponent(jsonData));\n\t\t\t\tdataTransfer.setData(\"Text\",titleString);\n\t\t\t\tevent.stopPropagation();\n\t\t\t}\n\t\t\treturn false;\n\t\t}},\n\t\t{name: \"dragend\", handlerFunction: function(event) {\n\t\t\tif(event.target === domNode) {\n\t\t\t\t// Collect the tiddlers being dragged\n\t\t\t\tvar dragTiddler = options.dragTiddlerFn && options.dragTiddlerFn(),\n\t\t\t\t\tdragFilter = options.dragFilterFn && options.dragFilterFn(),\n\t\t\t\t\ttitles = dragTiddler ? [dragTiddler] : [],\n\t\t\t \t\tendActions = options.endActions;\n\t\t\t\tif(dragFilter) {\n\t\t\t\t\ttitles.push.apply(titles,options.widget.wiki.filterTiddlers(dragFilter,options.widget));\n\t\t\t\t}\n\t\t\t\tvar titleString = $tw.utils.stringifyList(titles);\n\t\t\t\t$tw.dragInProgress = null;\n\t\t\t\t// Invoke drag-end actions if given\n\t\t\t\tif(endActions !== undefined) {\n\t\t\t\t\toptions.widget.invokeActionString(endActions,options.widget,event,{actionTiddler: titleString});\n\t\t\t\t}\n\t\t\t\t// Remove the dragging class on the element being dragged\n\t\t\t\t$tw.utils.removeClass(event.target,\"tc-dragging\");\n\t\t\t\t// Delete the drag image element\n\t\t\t\tif(dragImage) {\n\t\t\t\t\tdragImage.parentNode.removeChild(dragImage);\n\t\t\t\t\tdragImage = null;\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn false;\n\t\t}}\n\t]);\n};\n\nexports.importDataTransfer = function(dataTransfer,fallbackTitle,callback) {\n\t// Try each provided data type in turn\n\tif($tw.log.IMPORT) {\n\t\tconsole.log(\"Available data types:\");\n\t\tfor(var type=0; type<dataTransfer.types.length; type++) {\n\t\t\tconsole.log(\"type\",dataTransfer.types[type],dataTransfer.getData(dataTransfer.types[type]))\n\t\t}\n\t}\n\tfor(var t=0; t<importDataTypes.length; t++) {\n\t\tif(!$tw.browser.isIE || importDataTypes[t].IECompatible) {\n\t\t\t// Get the data\n\t\t\tvar dataType = importDataTypes[t];\n\t\t\t\tvar data = dataTransfer.getData(dataType.type);\n\t\t\t// Import the tiddlers in the data\n\t\t\tif(data !== \"\" && data !== null) {\n\t\t\t\tif($tw.log.IMPORT) {\n\t\t\t\t\tconsole.log(\"Importing data type '\" + dataType.type + \"', data: '\" + data + \"'\")\n\t\t\t\t}\n\t\t\t\tvar tiddlerFields = dataType.toTiddlerFieldsArray(data,fallbackTitle);\n\t\t\t\tcallback(tiddlerFields);\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\t}\n};\n\nvar importDataTypes = [\n\t{type: \"text/vnd.tiddler\", IECompatible: false, toTiddlerFieldsArray: function(data,fallbackTitle) {\n\t\treturn parseJSONTiddlers(data,fallbackTitle);\n\t}},\n\t{type: \"URL\", IECompatible: true, toTiddlerFieldsArray: function(data,fallbackTitle) {\n\t\t// Check for tiddler data URI\n\t\tvar match = decodeURIComponent(data).match(/^data\\:text\\/vnd\\.tiddler,(.*)/i);\n\t\tif(match) {\n\t\t\treturn parseJSONTiddlers(match[1],fallbackTitle);\n\t\t} else {\n\t\t\treturn [{title: fallbackTitle, text: data}]; // As URL string\n\t\t}\n\t}},\n\t{type: \"text/x-moz-url\", IECompatible: false, toTiddlerFieldsArray: function(data,fallbackTitle) {\n\t\t// Check for tiddler data URI\n\t\tvar match = decodeURIComponent(data).match(/^data\\:text\\/vnd\\.tiddler,(.*)/i);\n\t\tif(match) {\n\t\t\treturn parseJSONTiddlers(match[1],fallbackTitle);\n\t\t} else {\n\t\t\treturn [{title: fallbackTitle, text: data}]; // As URL string\n\t\t}\n\t}},\n\t{type: \"text/html\", IECompatible: false, toTiddlerFieldsArray: function(data,fallbackTitle) {\n\t\treturn [{title: fallbackTitle, text: data}];\n\t}},\n\t{type: \"text/plain\", IECompatible: false, toTiddlerFieldsArray: function(data,fallbackTitle) {\n\t\treturn [{title: fallbackTitle, text: data}];\n\t}},\n\t{type: \"Text\", IECompatible: true, toTiddlerFieldsArray: function(data,fallbackTitle) {\n\t\treturn [{title: fallbackTitle, text: data}];\n\t}},\n\t{type: \"text/uri-list\", IECompatible: false, toTiddlerFieldsArray: function(data,fallbackTitle) {\n\t\treturn [{title: fallbackTitle, text: data}];\n\t}}\n];\n\nfunction parseJSONTiddlers(json,fallbackTitle) {\n\tvar data = JSON.parse(json);\n\tif(!$tw.utils.isArray(data)) {\n\t\tdata = [data];\n\t}\n\tdata.forEach(function(fields) {\n\t\tfields.title = fields.title || fallbackTitle;\n\t});\n\treturn data;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/utils/dom/http.js": {
"title": "$:/core/modules/utils/dom/http.js",
"text": "/*\\\ntitle: $:/core/modules/utils/dom/http.js\ntype: application/javascript\nmodule-type: utils\n\nBrowser HTTP support\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nA quick and dirty HTTP function; to be refactored later. Options are:\n\turl: URL to retrieve\n\theaders: hashmap of headers to send\n\ttype: GET, PUT, POST etc\n\tcallback: function invoked with (err,data)\n\treturnProp: string name of the property to return as first argument of callback\n*/\nexports.httpRequest = function(options) {\n\tvar type = options.type || \"GET\",\n\t\theaders = options.headers || {accept: \"application/json\"},\n\t\treturnProp = options.returnProp || \"responseText\",\n\t\trequest = new XMLHttpRequest(),\n\t\tdata = \"\",\n\t\tf,results;\n\t// Massage the data hashmap into a string\n\tif(options.data) {\n\t\tif(typeof options.data === \"string\") { // Already a string\n\t\t\tdata = options.data;\n\t\t} else { // A hashmap of strings\n\t\t\tresults = [];\n\t\t\t$tw.utils.each(options.data,function(dataItem,dataItemTitle) {\n\t\t\t\tresults.push(dataItemTitle + \"=\" + encodeURIComponent(dataItem));\n\t\t\t});\n\t\t\tdata = results.join(\"&\");\n\t\t}\n\t}\n\t// Set up the state change handler\n\trequest.onreadystatechange = function() {\n\t\tif(this.readyState === 4) {\n\t\t\tif(this.status === 200 || this.status === 201 || this.status === 204) {\n\t\t\t\t// Success!\n\t\t\t\toptions.callback(null,this[returnProp],this);\n\t\t\t\treturn;\n\t\t\t}\n\t\t// Something went wrong\n\t\toptions.callback($tw.language.getString(\"Error/XMLHttpRequest\") + \": \" + this.status);\n\t\t}\n\t};\n\t// Make the request\n\trequest.open(type,options.url,true);\n\tif(headers) {\n\t\t$tw.utils.each(headers,function(header,headerTitle,object) {\n\t\t\trequest.setRequestHeader(headerTitle,header);\n\t\t});\n\t}\n\tif(data && !$tw.utils.hop(headers,\"Content-type\")) {\n\t\trequest.setRequestHeader(\"Content-type\",\"application/x-www-form-urlencoded; charset=UTF-8\");\n\t}\n\tif(!$tw.utils.hop(headers,\"X-Requested-With\")) {\n\t\trequest.setRequestHeader(\"X-Requested-With\",\"TiddlyWiki\");\n\t}\n\ttry {\n\t\trequest.send(data);\n\t} catch(e) {\n\t\toptions.callback(e);\n\t}\n\treturn request;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/utils/dom/keyboard.js": {
"title": "$:/core/modules/utils/dom/keyboard.js",
"text": "/*\\\ntitle: $:/core/modules/utils/dom/keyboard.js\ntype: application/javascript\nmodule-type: utils\n\nKeyboard utilities; now deprecated. Instead, use $tw.keyboardManager\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n[\"parseKeyDescriptor\",\"checkKeyDescriptor\"].forEach(function(method) {\n\texports[method] = function() {\n\t\tif($tw.keyboardManager) {\n\t\t\treturn $tw.keyboardManager[method].apply($tw.keyboardManager,Array.prototype.slice.call(arguments,0));\n\t\t} else {\n\t\t\treturn null\n\t\t}\n\t};\n});\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/utils/dom/modal.js": {
"title": "$:/core/modules/utils/dom/modal.js",
"text": "/*\\\ntitle: $:/core/modules/utils/dom/modal.js\ntype: application/javascript\nmodule-type: utils\n\nModal message mechanism\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar widget = require(\"$:/core/modules/widgets/widget.js\");\n\nvar Modal = function(wiki) {\n\tthis.wiki = wiki;\n\tthis.modalCount = 0;\n};\n\n/*\nDisplay a modal dialogue\n\ttitle: Title of tiddler to display\n\toptions: see below\nOptions include:\n\tdownloadLink: Text of a big download link to include\n*/\nModal.prototype.display = function(title,options) {\n\toptions = options || {};\n\tthis.srcDocument = options.variables && (options.variables.rootwindow === \"true\" ||\n\t\t\t\toptions.variables.rootwindow === \"yes\") ? document :\n\t\t\t\t(options.event.event ? options.event.event.target.ownerDocument : document);\n\tthis.srcWindow = this.srcDocument.defaultView;\n\tvar self = this,\n\t\trefreshHandler,\n\t\tduration = $tw.utils.getAnimationDuration(),\n\t\ttiddler = this.wiki.getTiddler(title);\n\t// Don't do anything if the tiddler doesn't exist\n\tif(!tiddler) {\n\t\treturn;\n\t}\n\t// Create the variables\n\tvar variables = $tw.utils.extend({currentTiddler: title},options.variables);\n\t// Create the wrapper divs\n\tvar wrapper = this.srcDocument.createElement(\"div\"),\n\t\tmodalBackdrop = this.srcDocument.createElement(\"div\"),\n\t\tmodalWrapper = this.srcDocument.createElement(\"div\"),\n\t\tmodalHeader = this.srcDocument.createElement(\"div\"),\n\t\theaderTitle = this.srcDocument.createElement(\"h3\"),\n\t\tmodalBody = this.srcDocument.createElement(\"div\"),\n\t\tmodalLink = this.srcDocument.createElement(\"a\"),\n\t\tmodalFooter = this.srcDocument.createElement(\"div\"),\n\t\tmodalFooterHelp = this.srcDocument.createElement(\"span\"),\n\t\tmodalFooterButtons = this.srcDocument.createElement(\"span\");\n\t// Up the modal count and adjust the body class\n\tthis.modalCount++;\n\tthis.adjustPageClass();\n\t// Add classes\n\t$tw.utils.addClass(wrapper,\"tc-modal-wrapper\");\n\t$tw.utils.addClass(modalBackdrop,\"tc-modal-backdrop\");\n\t$tw.utils.addClass(modalWrapper,\"tc-modal\");\n\t$tw.utils.addClass(modalHeader,\"tc-modal-header\");\n\t$tw.utils.addClass(modalBody,\"tc-modal-body\");\n\t$tw.utils.addClass(modalFooter,\"tc-modal-footer\");\n\t// Join them together\n\twrapper.appendChild(modalBackdrop);\n\twrapper.appendChild(modalWrapper);\n\tmodalHeader.appendChild(headerTitle);\n\tmodalWrapper.appendChild(modalHeader);\n\tmodalWrapper.appendChild(modalBody);\n\tmodalFooter.appendChild(modalFooterHelp);\n\tmodalFooter.appendChild(modalFooterButtons);\n\tmodalWrapper.appendChild(modalFooter);\n\t// Render the title of the message\n\tvar headerWidgetNode = this.wiki.makeTranscludeWidget(title,{\n\t\tfield: \"subtitle\",\n\t\tmode: \"inline\",\n\t\tchildren: [{\n\t\t\ttype: \"text\",\n\t\t\tattributes: {\n\t\t\t\ttext: {\n\t\t\t\t\ttype: \"string\",\n\t\t\t\t\tvalue: title\n\t\t}}}],\n\t\tparentWidget: $tw.rootWidget,\n\t\tdocument: this.srcDocument,\n\t\tvariables: variables,\n\t\timportPageMacros: true\n\t});\n\theaderWidgetNode.render(headerTitle,null);\n\t// Render the body of the message\n\tvar bodyWidgetNode = this.wiki.makeTranscludeWidget(title,{\n\t\tparentWidget: $tw.rootWidget,\n\t\tdocument: this.srcDocument,\n\t\tvariables: variables,\n\t\timportPageMacros: true\n\t});\n\tbodyWidgetNode.render(modalBody,null);\n\t// Setup the link if present\n\tif(options.downloadLink) {\n\t\tmodalLink.href = options.downloadLink;\n\t\tmodalLink.appendChild(this.srcDocument.createTextNode(\"Right-click to save changes\"));\n\t\tmodalBody.appendChild(modalLink);\n\t}\n\t// Render the footer of the message\n\tif(tiddler && tiddler.fields && tiddler.fields.help) {\n\t\tvar link = this.srcDocument.createElement(\"a\");\n\t\tlink.setAttribute(\"href\",tiddler.fields.help);\n\t\tlink.setAttribute(\"target\",\"_blank\");\n\t\tlink.setAttribute(\"rel\",\"noopener noreferrer\");\n\t\tlink.appendChild(this.srcDocument.createTextNode(\"Help\"));\n\t\tmodalFooterHelp.appendChild(link);\n\t\tmodalFooterHelp.style.float = \"left\";\n\t}\n\tvar footerWidgetNode = this.wiki.makeTranscludeWidget(title,{\n\t\tfield: \"footer\",\n\t\tmode: \"inline\",\n\t\tchildren: [{\n\t\t\ttype: \"button\",\n\t\t\tattributes: {\n\t\t\t\tmessage: {\n\t\t\t\t\ttype: \"string\",\n\t\t\t\t\tvalue: \"tm-close-tiddler\"\n\t\t\t\t}\n\t\t\t},\n\t\t\tchildren: [{\n\t\t\t\ttype: \"text\",\n\t\t\t\tattributes: {\n\t\t\t\t\ttext: {\n\t\t\t\t\t\ttype: \"string\",\n\t\t\t\t\t\tvalue: $tw.language.getString(\"Buttons/Close/Caption\")\n\t\t\t}}}\n\t\t]}],\n\t\tparentWidget: $tw.rootWidget,\n\t\tdocument: this.srcDocument,\n\t\tvariables: variables,\n\t\timportPageMacros: true\n\t});\n\tfooterWidgetNode.render(modalFooterButtons,null);\n\t// Set up the refresh handler\n\trefreshHandler = function(changes) {\n\t\theaderWidgetNode.refresh(changes,modalHeader,null);\n\t\tbodyWidgetNode.refresh(changes,modalBody,null);\n\t\tfooterWidgetNode.refresh(changes,modalFooterButtons,null);\n\t};\n\tthis.wiki.addEventListener(\"change\",refreshHandler);\n\t// Add the close event handler\n\tvar closeHandler = function(event) {\n\t\t// Remove our refresh handler\n\t\tself.wiki.removeEventListener(\"change\",refreshHandler);\n\t\t// Decrease the modal count and adjust the body class\n\t\tself.modalCount--;\n\t\tself.adjustPageClass();\n\t\t// Force layout and animate the modal message away\n\t\t$tw.utils.forceLayout(modalBackdrop);\n\t\t$tw.utils.forceLayout(modalWrapper);\n\t\t$tw.utils.setStyle(modalBackdrop,[\n\t\t\t{opacity: \"0\"}\n\t\t]);\n\t\t$tw.utils.setStyle(modalWrapper,[\n\t\t\t{transform: \"translateY(\" + self.srcWindow.innerHeight + \"px)\"}\n\t\t]);\n\t\t// Set up an event for the transition end\n\t\tself.srcWindow.setTimeout(function() {\n\t\t\tif(wrapper.parentNode) {\n\t\t\t\t// Remove the modal message from the DOM\n\t\t\t\tself.srcDocument.body.removeChild(wrapper);\n\t\t\t}\n\t\t},duration);\n\t\t// Don't let anyone else handle the tm-close-tiddler message\n\t\treturn false;\n\t};\n\theaderWidgetNode.addEventListener(\"tm-close-tiddler\",closeHandler,false);\n\tbodyWidgetNode.addEventListener(\"tm-close-tiddler\",closeHandler,false);\n\tfooterWidgetNode.addEventListener(\"tm-close-tiddler\",closeHandler,false);\n\t// Set the initial styles for the message\n\t$tw.utils.setStyle(modalBackdrop,[\n\t\t{opacity: \"0\"}\n\t]);\n\t$tw.utils.setStyle(modalWrapper,[\n\t\t{transformOrigin: \"0% 0%\"},\n\t\t{transform: \"translateY(\" + (-this.srcWindow.innerHeight) + \"px)\"}\n\t]);\n\t// Put the message into the document\n\tthis.srcDocument.body.appendChild(wrapper);\n\t// Set up animation for the styles\n\t$tw.utils.setStyle(modalBackdrop,[\n\t\t{transition: \"opacity \" + duration + \"ms ease-out\"}\n\t]);\n\t$tw.utils.setStyle(modalWrapper,[\n\t\t{transition: $tw.utils.roundTripPropertyName(\"transform\") + \" \" + duration + \"ms ease-in-out\"}\n\t]);\n\t// Force layout\n\t$tw.utils.forceLayout(modalBackdrop);\n\t$tw.utils.forceLayout(modalWrapper);\n\t// Set final animated styles\n\t$tw.utils.setStyle(modalBackdrop,[\n\t\t{opacity: \"0.7\"}\n\t]);\n\t$tw.utils.setStyle(modalWrapper,[\n\t\t{transform: \"translateY(0px)\"}\n\t]);\n};\n\nModal.prototype.adjustPageClass = function() {\n\tvar windowContainer = $tw.pageContainer ? ($tw.pageContainer === this.srcDocument.body.firstChild ? $tw.pageContainer : this.srcDocument.body.firstChild) : null;\n\tif(windowContainer) {\n\t\t$tw.utils.toggleClass(windowContainer,\"tc-modal-displayed\",this.modalCount > 0);\n\t}\n};\n\nexports.Modal = Modal;\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/utils/dom/notifier.js": {
"title": "$:/core/modules/utils/dom/notifier.js",
"text": "/*\\\ntitle: $:/core/modules/utils/dom/notifier.js\ntype: application/javascript\nmodule-type: utils\n\nNotifier mechanism\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar widget = require(\"$:/core/modules/widgets/widget.js\");\n\nvar Notifier = function(wiki) {\n\tthis.wiki = wiki;\n};\n\n/*\nDisplay a notification\n\ttitle: Title of tiddler containing the notification text\n\toptions: see below\nOptions include:\n*/\nNotifier.prototype.display = function(title,options) {\n\toptions = options || {};\n\t// Create the wrapper divs\n\tvar self = this,\n\t\tnotification = document.createElement(\"div\"),\n\t\ttiddler = this.wiki.getTiddler(title),\n\t\tduration = $tw.utils.getAnimationDuration(),\n\t\trefreshHandler;\n\t// Don't do anything if the tiddler doesn't exist\n\tif(!tiddler) {\n\t\treturn;\n\t}\n\t// Add classes\n\t$tw.utils.addClass(notification,\"tc-notification\");\n\t// Create the variables\n\tvar variables = $tw.utils.extend({currentTiddler: title},options.variables);\n\t// Render the body of the notification\n\tvar widgetNode = this.wiki.makeTranscludeWidget(title,{\n\t\tparentWidget: $tw.rootWidget,\n\t\tdocument: document,\n\t\tvariables: variables,\n\t\timportPageMacros: true});\n\twidgetNode.render(notification,null);\n\trefreshHandler = function(changes) {\n\t\twidgetNode.refresh(changes,notification,null);\n\t};\n\tthis.wiki.addEventListener(\"change\",refreshHandler);\n\t// Set the initial styles for the notification\n\t$tw.utils.setStyle(notification,[\n\t\t{opacity: \"0\"},\n\t\t{transformOrigin: \"0% 0%\"},\n\t\t{transform: \"translateY(\" + (-window.innerHeight) + \"px)\"},\n\t\t{transition: \"opacity \" + duration + \"ms ease-out, \" + $tw.utils.roundTripPropertyName(\"transform\") + \" \" + duration + \"ms ease-in-out\"}\n\t]);\n\t// Add the notification to the DOM\n\tdocument.body.appendChild(notification);\n\t// Force layout\n\t$tw.utils.forceLayout(notification);\n\t// Set final animated styles\n\t$tw.utils.setStyle(notification,[\n\t\t{opacity: \"1.0\"},\n\t\t{transform: \"translateY(0px)\"}\n\t]);\n\t// Set a timer to remove the notification\n\twindow.setTimeout(function() {\n\t\t// Remove our change event handler\n\t\tself.wiki.removeEventListener(\"change\",refreshHandler);\n\t\t// Force layout and animate the notification away\n\t\t$tw.utils.forceLayout(notification);\n\t\t$tw.utils.setStyle(notification,[\n\t\t\t{opacity: \"0.0\"},\n\t\t\t{transform: \"translateX(\" + (notification.offsetWidth) + \"px)\"}\n\t\t]);\n\t\t// Remove the modal message from the DOM once the transition ends\n\t\tsetTimeout(function() {\n\t\t\tif(notification.parentNode) {\n\t\t\t\tdocument.body.removeChild(notification);\n\t\t\t}\n\t\t},duration);\n\t},$tw.config.preferences.notificationDuration);\n};\n\nexports.Notifier = Notifier;\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/utils/dom/popup.js": {
"title": "$:/core/modules/utils/dom/popup.js",
"text": "/*\\\ntitle: $:/core/modules/utils/dom/popup.js\ntype: application/javascript\nmodule-type: utils\n\nModule that creates a $tw.utils.Popup object prototype that manages popups in the browser\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nCreates a Popup object with these options:\n\trootElement: the DOM element to which the popup zapper should be attached\n*/\nvar Popup = function(options) {\n\toptions = options || {};\n\tthis.rootElement = options.rootElement || document.documentElement;\n\tthis.popups = []; // Array of {title:,wiki:,domNode:} objects\n};\n\n/*\nTrigger a popup open or closed. Parameters are in a hashmap:\n\ttitle: title of the tiddler where the popup details are stored\n\tdomNode: dom node to which the popup will be positioned (one of domNode or domNodeRect is required)\n\tdomNodeRect: rectangle to which the popup will be positioned\n\twiki: wiki\n\tforce: if specified, forces the popup state to true or false (instead of toggling it)\n\tfloating: if true, skips registering the popup, meaning that it will need manually clearing\n*/\nPopup.prototype.triggerPopup = function(options) {\n\t// Check if this popup is already active\n\tvar index = this.findPopup(options.title);\n\t// Compute the new state\n\tvar state = index === -1;\n\tif(options.force !== undefined) {\n\t\tstate = options.force;\n\t}\n\t// Show or cancel the popup according to the new state\n\tif(state) {\n\t\tthis.show(options);\n\t} else {\n\t\tthis.cancel(index);\n\t}\n};\n\nPopup.prototype.findPopup = function(title) {\n\tvar index = -1;\n\tfor(var t=0; t<this.popups.length; t++) {\n\t\tif(this.popups[t].title === title) {\n\t\t\tindex = t;\n\t\t}\n\t}\n\treturn index;\n};\n\nPopup.prototype.handleEvent = function(event) {\n\tif(event.type === \"click\") {\n\t\t// Find out what was clicked on\n\t\tvar info = this.popupInfo(event.target),\n\t\t\tcancelLevel = info.popupLevel - 1;\n\t\t// Don't remove the level that was clicked on if we clicked on a handle\n\t\tif(info.isHandle) {\n\t\t\tcancelLevel++;\n\t\t}\n\t\t// Cancel\n\t\tthis.cancel(cancelLevel);\n\t}\n};\n\n/*\nFind the popup level containing a DOM node. Returns:\npopupLevel: count of the number of nested popups containing the specified element\nisHandle: true if the specified element is within a popup handle\n*/\nPopup.prototype.popupInfo = function(domNode) {\n\tvar isHandle = false,\n\t\tpopupCount = 0,\n\t\tnode = domNode;\n\t// First check ancestors to see if we're within a popup handle\n\twhile(node) {\n\t\tif($tw.utils.hasClass(node,\"tc-popup-handle\")) {\n\t\t\tisHandle = true;\n\t\t\tpopupCount++;\n\t\t}\n\t\tif($tw.utils.hasClass(node,\"tc-popup-keep\")) {\n\t\t\tisHandle = true;\n\t\t}\n\t\tnode = node.parentNode;\n\t}\n\t// Then count the number of ancestor popups\n\tnode = domNode;\n\twhile(node) {\n\t\tif($tw.utils.hasClass(node,\"tc-popup\")) {\n\t\t\tpopupCount++;\n\t\t}\n\t\tnode = node.parentNode;\n\t}\n\tvar info = {\n\t\tpopupLevel: popupCount,\n\t\tisHandle: isHandle\n\t};\n\treturn info;\n};\n\n/*\nDisplay a popup by adding it to the stack\n*/\nPopup.prototype.show = function(options) {\n\t// Find out what was clicked on\n\tvar info = this.popupInfo(options.domNode);\n\t// Cancel any higher level popups\n\tthis.cancel(info.popupLevel);\n\n\t// Store the popup details if not already there\n\tif(!options.floating && this.findPopup(options.title) === -1) {\n\t\tthis.popups.push({\n\t\t\ttitle: options.title,\n\t\t\twiki: options.wiki,\n\t\t\tdomNode: options.domNode\n\t\t});\n\t}\n\t// Set the state tiddler\n\tvar rect;\n\tif(options.domNodeRect) {\n\t\trect = options.domNodeRect;\n\t} else {\n\t\trect = {\n\t\t\tleft: options.domNode.offsetLeft,\n\t\t\ttop: options.domNode.offsetTop,\n\t\t\twidth: options.domNode.offsetWidth,\n\t\t\theight: options.domNode.offsetHeight\n\t\t};\n\t}\n\tvar popupRect = \"(\" + rect.left + \",\" + rect.top + \",\" + \n\t\t\t\trect.width + \",\" + rect.height + \")\";\n\tif(options.noStateReference) {\n\t\toptions.wiki.setText(options.title,\"text\",undefined,popupRect);\n\t} else {\n\t\toptions.wiki.setTextReference(options.title,popupRect);\n\t}\n\t// Add the click handler if we have any popups\n\tif(this.popups.length > 0) {\n\t\tthis.rootElement.addEventListener(\"click\",this,true);\t\t\n\t}\n};\n\n/*\nCancel all popups at or above a specified level or DOM node\nlevel: popup level to cancel (0 cancels all popups)\n*/\nPopup.prototype.cancel = function(level) {\n\tvar numPopups = this.popups.length;\n\tlevel = Math.max(0,Math.min(level,numPopups));\n\tfor(var t=level; t<numPopups; t++) {\n\t\tvar popup = this.popups.pop();\n\t\tif(popup.title) {\n\t\t\tpopup.wiki.deleteTiddler(popup.title);\n\t\t}\n\t}\n\tif(this.popups.length === 0) {\n\t\tthis.rootElement.removeEventListener(\"click\",this,false);\n\t}\n};\n\n/*\nReturns true if the specified title and text identifies an active popup\n*/\nPopup.prototype.readPopupState = function(text) {\n\tvar popupLocationRegExp = /^\\((-?[0-9\\.E]+),(-?[0-9\\.E]+),(-?[0-9\\.E]+),(-?[0-9\\.E]+)\\)$/;\n\treturn popupLocationRegExp.test(text);\n};\n\nexports.Popup = Popup;\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/utils/dom/scroller.js": {
"title": "$:/core/modules/utils/dom/scroller.js",
"text": "/*\\\ntitle: $:/core/modules/utils/dom/scroller.js\ntype: application/javascript\nmodule-type: utils\n\nModule that creates a $tw.utils.Scroller object prototype that manages scrolling in the browser\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nEvent handler for when the `tm-scroll` event hits the document body\n*/\nvar PageScroller = function() {\n\tthis.idRequestFrame = null;\n\tthis.requestAnimationFrame = window.requestAnimationFrame ||\n\t\twindow.webkitRequestAnimationFrame ||\n\t\twindow.mozRequestAnimationFrame ||\n\t\tfunction(callback) {\n\t\t\treturn window.setTimeout(callback, 1000/60);\n\t\t};\n\tthis.cancelAnimationFrame = window.cancelAnimationFrame ||\n\t\twindow.webkitCancelAnimationFrame ||\n\t\twindow.webkitCancelRequestAnimationFrame ||\n\t\twindow.mozCancelAnimationFrame ||\n\t\twindow.mozCancelRequestAnimationFrame ||\n\t\tfunction(id) {\n\t\t\twindow.clearTimeout(id);\n\t\t};\n};\n\nPageScroller.prototype.cancelScroll = function(srcWindow) {\n\tif(this.idRequestFrame) {\n\t\tthis.cancelAnimationFrame.call(srcWindow,this.idRequestFrame);\n\t\tthis.idRequestFrame = null;\n\t}\n};\n\n/*\nHandle an event\n*/\nPageScroller.prototype.handleEvent = function(event) {\n\tif(event.type === \"tm-scroll\") {\n\t\treturn this.scrollIntoView(event.target);\n\t}\n\treturn true;\n};\n\n/*\nHandle a scroll event hitting the page document\n*/\nPageScroller.prototype.scrollIntoView = function(element,callback) {\n\tvar self = this,\n\t\tduration = $tw.utils.getAnimationDuration(),\n\t srcWindow = element ? element.ownerDocument.defaultView : window;\n\t// Now get ready to scroll the body\n\tthis.cancelScroll(srcWindow);\n\tthis.startTime = Date.now();\n\t// Get the height of any position:fixed toolbars\n\tvar toolbar = srcWindow.document.querySelector(\".tc-adjust-top-of-scroll\"),\n\t\toffset = 0;\n\tif(toolbar) {\n\t\toffset = toolbar.offsetHeight;\n\t}\n\t// Get the client bounds of the element and adjust by the scroll position\n\tvar getBounds = function() {\n\t\t\tvar clientBounds = typeof callback === 'function' ? callback() : element.getBoundingClientRect(),\n\t\t\t\tscrollPosition = $tw.utils.getScrollPosition(srcWindow);\n\t\t\treturn {\n\t\t\t\tleft: clientBounds.left + scrollPosition.x,\n\t\t\t\ttop: clientBounds.top + scrollPosition.y - offset,\n\t\t\t\twidth: clientBounds.width,\n\t\t\t\theight: clientBounds.height\n\t\t\t};\n\t\t},\n\t\t// We'll consider the horizontal and vertical scroll directions separately via this function\n\t\t// targetPos/targetSize - position and size of the target element\n\t\t// currentPos/currentSize - position and size of the current scroll viewport\n\t\t// returns: new position of the scroll viewport\n\t\tgetEndPos = function(targetPos,targetSize,currentPos,currentSize) {\n\t\t\tvar newPos = targetPos;\n\t\t\t// If we are scrolling within 50 pixels of the top/left then snap to zero\n\t\t\tif(newPos < 50) {\n\t\t\t\tnewPos = 0;\n\t\t\t}\n\t\t\treturn newPos;\n\t\t},\n\t\tdrawFrame = function drawFrame() {\n\t\t\tvar t;\n\t\t\tif(duration <= 0) {\n\t\t\t\tt = 1;\n\t\t\t} else {\n\t\t\t\tt = ((Date.now()) - self.startTime) / duration;\t\n\t\t\t}\n\t\t\tif(t >= 1) {\n\t\t\t\tself.cancelScroll(srcWindow);\n\t\t\t\tt = 1;\n\t\t\t}\n\t\t\tt = $tw.utils.slowInSlowOut(t);\n\t\t\tvar scrollPosition = $tw.utils.getScrollPosition(srcWindow),\n\t\t\t\tbounds = getBounds(),\n\t\t\t\tendX = getEndPos(bounds.left,bounds.width,scrollPosition.x,srcWindow.innerWidth),\n\t\t\t\tendY = getEndPos(bounds.top,bounds.height,scrollPosition.y,srcWindow.innerHeight);\n\t\t\tsrcWindow.scrollTo(scrollPosition.x + (endX - scrollPosition.x) * t,scrollPosition.y + (endY - scrollPosition.y) * t);\n\t\t\tif(t < 1) {\n\t\t\t\tself.idRequestFrame = self.requestAnimationFrame.call(srcWindow,drawFrame);\n\t\t\t}\n\t\t};\n\tdrawFrame();\n};\n\nexports.PageScroller = PageScroller;\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/utils/edition-info.js": {
"title": "$:/core/modules/utils/edition-info.js",
"text": "/*\\\ntitle: $:/core/modules/utils/edition-info.js\ntype: application/javascript\nmodule-type: utils-node\n\nInformation about the available editions\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar fs = require(\"fs\"),\n\tpath = require(\"path\");\n\nvar editionInfo;\n\nexports.getEditionInfo = function() {\n\tif(!editionInfo) {\n\t\t// Enumerate the edition paths\n\t\tvar editionPaths = $tw.getLibraryItemSearchPaths($tw.config.editionsPath,$tw.config.editionsEnvVar);\n\t\teditionInfo = {};\n\t\tfor(var editionIndex=0; editionIndex<editionPaths.length; editionIndex++) {\n\t\t\tvar editionPath = editionPaths[editionIndex];\n\t\t\t// Enumerate the folders\n\t\t\tvar entries = fs.readdirSync(editionPath);\n\t\t\tfor(var entryIndex=0; entryIndex<entries.length; entryIndex++) {\n\t\t\t\tvar entry = entries[entryIndex];\n\t\t\t\t// Check if directories have a valid tiddlywiki.info\n\t\t\t\tif(!editionInfo[entry] && $tw.utils.isDirectory(path.resolve(editionPath,entry))) {\n\t\t\t\t\tvar info;\n\t\t\t\t\ttry {\n\t\t\t\t\t\tinfo = JSON.parse(fs.readFileSync(path.resolve(editionPath,entry,\"tiddlywiki.info\"),\"utf8\"));\n\t\t\t\t\t} catch(ex) {\n\t\t\t\t\t}\n\t\t\t\t\tif(info) {\n\t\t\t\t\t\teditionInfo[entry] = info;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\treturn editionInfo;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "utils-node"
},
"$:/core/modules/utils/fakedom.js": {
"title": "$:/core/modules/utils/fakedom.js",
"text": "/*\\\ntitle: $:/core/modules/utils/fakedom.js\ntype: application/javascript\nmodule-type: global\n\nA barebones implementation of DOM interfaces needed by the rendering mechanism.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n// Sequence number used to enable us to track objects for testing\nvar sequenceNumber = null;\n\nvar bumpSequenceNumber = function(object) {\n\tif(sequenceNumber !== null) {\n\t\tobject.sequenceNumber = sequenceNumber++;\n\t}\n};\n\nvar TW_TextNode = function(text) {\n\tbumpSequenceNumber(this);\n\tthis.textContent = text + \"\";\n};\n\nObject.defineProperty(TW_TextNode.prototype, \"nodeType\", {\n\tget: function() {\n\t\treturn 3;\n\t}\n});\n\nObject.defineProperty(TW_TextNode.prototype, \"formattedTextContent\", {\n\tget: function() {\n\t\treturn this.textContent.replace(/(\\r?\\n)/g,\"\");\n\t}\n});\n\nvar TW_Element = function(tag,namespace) {\n\tbumpSequenceNumber(this);\n\tthis.isTiddlyWikiFakeDom = true;\n\tthis.tag = tag;\n\tthis.attributes = {};\n\tthis.isRaw = false;\n\tthis.children = [];\n\tthis.style = {};\n\tthis.namespaceURI = namespace || \"http://www.w3.org/1999/xhtml\";\n};\n\nObject.defineProperty(TW_Element.prototype, \"nodeType\", {\n\tget: function() {\n\t\treturn 1;\n\t}\n});\n\nTW_Element.prototype.getAttribute = function(name) {\n\tif(this.isRaw) {\n\t\tthrow \"Cannot getAttribute on a raw TW_Element\";\n\t}\n\treturn this.attributes[name];\n};\n\nTW_Element.prototype.setAttribute = function(name,value) {\n\tif(this.isRaw) {\n\t\tthrow \"Cannot setAttribute on a raw TW_Element\";\n\t}\n\tthis.attributes[name] = value + \"\";\n};\n\nTW_Element.prototype.setAttributeNS = function(namespace,name,value) {\n\tthis.setAttribute(name,value);\n};\n\nTW_Element.prototype.removeAttribute = function(name) {\n\tif(this.isRaw) {\n\t\tthrow \"Cannot removeAttribute on a raw TW_Element\";\n\t}\n\tif($tw.utils.hop(this.attributes,name)) {\n\t\tdelete this.attributes[name];\n\t}\n};\n\nTW_Element.prototype.appendChild = function(node) {\n\tthis.children.push(node);\n\tnode.parentNode = this;\n};\n\nTW_Element.prototype.insertBefore = function(node,nextSibling) {\n\tif(nextSibling) {\n\t\tvar p = this.children.indexOf(nextSibling);\n\t\tif(p !== -1) {\n\t\t\tthis.children.splice(p,0,node);\n\t\t\tnode.parentNode = this;\n\t\t} else {\n\t\t\tthis.appendChild(node);\n\t\t}\n\t} else {\n\t\tthis.appendChild(node);\n\t}\n};\n\nTW_Element.prototype.removeChild = function(node) {\n\tvar p = this.children.indexOf(node);\n\tif(p !== -1) {\n\t\tthis.children.splice(p,1);\n\t}\n};\n\nTW_Element.prototype.hasChildNodes = function() {\n\treturn !!this.children.length;\n};\n\nObject.defineProperty(TW_Element.prototype, \"childNodes\", {\n\tget: function() {\n\t\treturn this.children;\n\t}\n});\n\nObject.defineProperty(TW_Element.prototype, \"firstChild\", {\n\tget: function() {\n\t\treturn this.children[0];\n\t}\n});\n\nTW_Element.prototype.addEventListener = function(type,listener,useCapture) {\n\t// Do nothing\n};\n\nObject.defineProperty(TW_Element.prototype, \"tagName\", {\n\tget: function() {\n\t\treturn this.tag || \"\";\n\t}\n});\n\nObject.defineProperty(TW_Element.prototype, \"className\", {\n\tget: function() {\n\t\treturn this.attributes[\"class\"] || \"\";\n\t},\n\tset: function(value) {\n\t\tthis.attributes[\"class\"] = value + \"\";\n\t}\n});\n\nObject.defineProperty(TW_Element.prototype, \"value\", {\n\tget: function() {\n\t\treturn this.attributes.value || \"\";\n\t},\n\tset: function(value) {\n\t\tthis.attributes.value = value + \"\";\n\t}\n});\n\nObject.defineProperty(TW_Element.prototype, \"outerHTML\", {\n\tget: function() {\n\t\tvar output = [],attr,a,v;\n\t\toutput.push(\"<\",this.tag);\n\t\tif(this.attributes) {\n\t\t\tattr = [];\n\t\t\tfor(a in this.attributes) {\n\t\t\t\tattr.push(a);\n\t\t\t}\n\t\t\tattr.sort();\n\t\t\tfor(a=0; a<attr.length; a++) {\n\t\t\t\tv = this.attributes[attr[a]];\n\t\t\t\tif(v !== undefined) {\n\t\t\t\t\toutput.push(\" \",attr[a],\"=\\\"\",$tw.utils.htmlEncode(v),\"\\\"\");\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tif(this.style) {\n\t\t\tvar style = [];\n\t\t\tfor(var s in this.style) {\n\t\t\t\tstyle.push(s + \":\" + this.style[s] + \";\");\n\t\t\t}\n\t\t\tif(style.length > 0) {\n\t\t\t\toutput.push(\" style=\\\"\",style.join(\"\"),\"\\\"\")\n\t\t\t}\n\t\t}\n\t\toutput.push(\">\");\n\t\tif($tw.config.htmlVoidElements.indexOf(this.tag) === -1) {\n\t\t\toutput.push(this.innerHTML);\n\t\t\toutput.push(\"</\",this.tag,\">\");\n\t\t}\n\t\treturn output.join(\"\");\n\t}\n});\n\nObject.defineProperty(TW_Element.prototype, \"innerHTML\", {\n\tget: function() {\n\t\tif(this.isRaw) {\n\t\t\treturn this.rawHTML;\n\t\t} else {\n\t\t\tvar b = [];\n\t\t\t$tw.utils.each(this.children,function(node) {\n\t\t\t\tif(node instanceof TW_Element) {\n\t\t\t\t\tb.push(node.outerHTML);\n\t\t\t\t} else if(node instanceof TW_TextNode) {\n\t\t\t\t\tb.push($tw.utils.htmlEncode(node.textContent));\n\t\t\t\t}\n\t\t\t});\n\t\t\treturn b.join(\"\");\n\t\t}\n\t},\n\tset: function(value) {\n\t\tthis.isRaw = true;\n\t\tthis.rawHTML = value;\n\t\tthis.rawTextContent = null;\n\t}\n});\n\nObject.defineProperty(TW_Element.prototype, \"textInnerHTML\", {\n\tset: function(value) {\n\t\tif(this.isRaw) {\n\t\t\tthis.rawTextContent = value;\n\t\t} else {\n\t\t\tthrow \"Cannot set textInnerHTML of a non-raw TW_Element\";\n\t\t}\n\t}\n});\n\nObject.defineProperty(TW_Element.prototype, \"textContent\", {\n\tget: function() {\n\t\tif(this.isRaw) {\n\t\t\tif(this.rawTextContent === null) {\n\t\t\t\treturn \"\";\n\t\t\t} else {\n\t\t\t\treturn this.rawTextContent;\n\t\t\t}\n\t\t} else {\n\t\t\tvar b = [];\n\t\t\t$tw.utils.each(this.children,function(node) {\n\t\t\t\tb.push(node.textContent);\n\t\t\t});\n\t\t\treturn b.join(\"\");\n\t\t}\n\t},\n\tset: function(value) {\n\t\tthis.children = [new TW_TextNode(value)];\n\t}\n});\n\nObject.defineProperty(TW_Element.prototype, \"formattedTextContent\", {\n\tget: function() {\n\t\tif(this.isRaw) {\n\t\t\treturn \"\";\n\t\t} else {\n\t\t\tvar b = [],\n\t\t\t\tisBlock = $tw.config.htmlBlockElements.indexOf(this.tag) !== -1;\n\t\t\tif(isBlock) {\n\t\t\t\tb.push(\"\\n\");\n\t\t\t}\n\t\t\tif(this.tag === \"li\") {\n\t\t\t\tb.push(\"* \");\n\t\t\t}\n\t\t\t$tw.utils.each(this.children,function(node) {\n\t\t\t\tb.push(node.formattedTextContent);\n\t\t\t});\n\t\t\tif(isBlock) {\n\t\t\t\tb.push(\"\\n\");\n\t\t\t}\n\t\t\treturn b.join(\"\");\n\t\t}\n\t}\n});\n\nvar document = {\n\tsetSequenceNumber: function(value) {\n\t\tsequenceNumber = value;\n\t},\n\tcreateElementNS: function(namespace,tag) {\n\t\treturn new TW_Element(tag,namespace);\n\t},\n\tcreateElement: function(tag) {\n\t\treturn new TW_Element(tag);\n\t},\n\tcreateTextNode: function(text) {\n\t\treturn new TW_TextNode(text);\n\t},\n\tcompatMode: \"CSS1Compat\", // For KaTeX to know that we're not a browser in quirks mode\n\tisTiddlyWikiFakeDom: true\n};\n\nexports.fakeDocument = document;\n\n})();\n",
"type": "application/javascript",
"module-type": "global"
},
"$:/core/modules/utils/filesystem.js": {
"title": "$:/core/modules/utils/filesystem.js",
"text": "/*\\\ntitle: $:/core/modules/utils/filesystem.js\ntype: application/javascript\nmodule-type: utils-node\n\nFile system utilities\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar fs = require(\"fs\"),\n\tpath = require(\"path\");\n\n/*\nRecursively (and synchronously) copy a directory and all its content\n*/\nexports.copyDirectory = function(srcPath,dstPath) {\n\t// Remove any trailing path separators\n\tsrcPath = $tw.utils.removeTrailingSeparator(srcPath);\n\tdstPath = $tw.utils.removeTrailingSeparator(dstPath);\n\t// Create the destination directory\n\tvar err = $tw.utils.createDirectory(dstPath);\n\tif(err) {\n\t\treturn err;\n\t}\n\t// Function to copy a folder full of files\n\tvar copy = function(srcPath,dstPath) {\n\t\tvar srcStats = fs.lstatSync(srcPath),\n\t\t\tdstExists = fs.existsSync(dstPath);\n\t\tif(srcStats.isFile()) {\n\t\t\t$tw.utils.copyFile(srcPath,dstPath);\n\t\t} else if(srcStats.isDirectory()) {\n\t\t\tvar items = fs.readdirSync(srcPath);\n\t\t\tfor(var t=0; t<items.length; t++) {\n\t\t\t\tvar item = items[t],\n\t\t\t\t\terr = copy(srcPath + path.sep + item,dstPath + path.sep + item);\n\t\t\t\tif(err) {\n\t\t\t\t\treturn err;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t};\n\tcopy(srcPath,dstPath);\n\treturn null;\n};\n\n/*\nCopy a file\n*/\nvar FILE_BUFFER_LENGTH = 64 * 1024,\n\tfileBuffer;\n\nexports.copyFile = function(srcPath,dstPath) {\n\t// Create buffer if required\n\tif(!fileBuffer) {\n\t\tfileBuffer = Buffer.alloc(FILE_BUFFER_LENGTH);\n\t}\n\t// Create any directories in the destination\n\t$tw.utils.createDirectory(path.dirname(dstPath));\n\t// Copy the file\n\tvar srcFile = fs.openSync(srcPath,\"r\"),\n\t\tdstFile = fs.openSync(dstPath,\"w\"),\n\t\tbytesRead = 1,\n\t\tpos = 0;\n\twhile (bytesRead > 0) {\n\t\tbytesRead = fs.readSync(srcFile,fileBuffer,0,FILE_BUFFER_LENGTH,pos);\n\t\tfs.writeSync(dstFile,fileBuffer,0,bytesRead);\n\t\tpos += bytesRead;\n\t}\n\tfs.closeSync(srcFile);\n\tfs.closeSync(dstFile);\n\treturn null;\n};\n\n/*\nRemove trailing path separator\n*/\nexports.removeTrailingSeparator = function(dirPath) {\n\tvar len = dirPath.length;\n\tif(dirPath.charAt(len-1) === path.sep) {\n\t\tdirPath = dirPath.substr(0,len-1);\n\t}\n\treturn dirPath;\n};\n\n/*\nRecursively create a directory\n*/\nexports.createDirectory = function(dirPath) {\n\tif(dirPath.substr(dirPath.length-1,1) !== path.sep) {\n\t\tdirPath = dirPath + path.sep;\n\t}\n\tvar pos = 1;\n\tpos = dirPath.indexOf(path.sep,pos);\n\twhile(pos !== -1) {\n\t\tvar subDirPath = dirPath.substr(0,pos);\n\t\tif(!$tw.utils.isDirectory(subDirPath)) {\n\t\t\ttry {\n\t\t\t\tfs.mkdirSync(subDirPath);\n\t\t\t} catch(e) {\n\t\t\t\treturn \"Error creating directory '\" + subDirPath + \"'\";\n\t\t\t}\n\t\t}\n\t\tpos = dirPath.indexOf(path.sep,pos + 1);\n\t}\n\treturn null;\n};\n\n/*\nRecursively create directories needed to contain a specified file\n*/\nexports.createFileDirectories = function(filePath) {\n\treturn $tw.utils.createDirectory(path.dirname(filePath));\n};\n\n/*\nRecursively delete a directory\n*/\nexports.deleteDirectory = function(dirPath) {\n\tif(fs.existsSync(dirPath)) {\n\t\tvar entries = fs.readdirSync(dirPath);\n\t\tfor(var entryIndex=0; entryIndex<entries.length; entryIndex++) {\n\t\t\tvar currPath = dirPath + path.sep + entries[entryIndex];\n\t\t\tif(fs.lstatSync(currPath).isDirectory()) {\n\t\t\t\t$tw.utils.deleteDirectory(currPath);\n\t\t\t} else {\n\t\t\t\tfs.unlinkSync(currPath);\n\t\t\t}\n\t\t}\n\tfs.rmdirSync(dirPath);\n\t}\n\treturn null;\n};\n\n/*\nCheck if a path identifies a directory\n*/\nexports.isDirectory = function(dirPath) {\n\treturn fs.existsSync(dirPath) && fs.statSync(dirPath).isDirectory();\n};\n\n/*\nCheck if a path identifies a directory that is empty\n*/\nexports.isDirectoryEmpty = function(dirPath) {\n\tif(!$tw.utils.isDirectory(dirPath)) {\n\t\treturn false;\n\t}\n\tvar files = fs.readdirSync(dirPath),\n\t\tempty = true;\n\t$tw.utils.each(files,function(file,index) {\n\t\tif(file.charAt(0) !== \".\") {\n\t\t\tempty = false;\n\t\t}\n\t});\n\treturn empty;\n};\n\n/*\nRecursively delete a tree of empty directories\n*/\nexports.deleteEmptyDirs = function(dirpath,callback) {\n\tvar self = this;\n\tfs.readdir(dirpath,function(err,files) {\n\t\tif(err) {\n\t\t\treturn callback(err);\n\t\t}\n\t\tif(files.length > 0) {\n\t\t\treturn callback(null);\n\t\t}\n\t\tfs.rmdir(dirpath,function(err) {\n\t\t\tif(err) {\n\t\t\t\treturn callback(err);\n\t\t\t}\n\t\t\tself.deleteEmptyDirs(path.dirname(dirpath),callback);\n\t\t});\n\t});\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "utils-node"
},
"$:/core/modules/utils/logger.js": {
"title": "$:/core/modules/utils/logger.js",
"text": "/*\\\ntitle: $:/core/modules/utils/logger.js\ntype: application/javascript\nmodule-type: utils\n\nA basic logging implementation\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar ALERT_TAG = \"$:/tags/Alert\";\n\n/*\nMake a new logger\n*/\nfunction Logger(componentName,options) {\n\toptions = options || {};\n\tthis.componentName = componentName || \"\";\n\tthis.colour = options.colour || \"white\";\n\tthis.enable = \"enable\" in options ? options.enable : true;\n}\n\n/*\nLog a message\n*/\nLogger.prototype.log = function(/* args */) {\n\tif(this.enable && console !== undefined && console.log !== undefined) {\n\t\treturn Function.apply.call(console.log, console, [$tw.utils.terminalColour(this.colour),this.componentName + \":\"].concat(Array.prototype.slice.call(arguments,0)).concat($tw.utils.terminalColour()));\n\t}\n};\n\n/*\nAlert a message\n*/\nLogger.prototype.alert = function(/* args */) {\n\tif(this.enable) {\n\t\t// Prepare the text of the alert\n\t\tvar text = Array.prototype.join.call(arguments,\" \");\n\t\t// Create alert tiddlers in the browser\n\t\tif($tw.browser) {\n\t\t\t// Check if there is an existing alert with the same text and the same component\n\t\t\tvar existingAlerts = $tw.wiki.getTiddlersWithTag(ALERT_TAG),\n\t\t\t\talertFields,\n\t\t\t\texistingCount,\n\t\t\t\tself = this;\n\t\t\t$tw.utils.each(existingAlerts,function(title) {\n\t\t\t\tvar tiddler = $tw.wiki.getTiddler(title);\n\t\t\t\tif(tiddler.fields.text === text && tiddler.fields.component === self.componentName && tiddler.fields.modified && (!alertFields || tiddler.fields.modified < alertFields.modified)) {\n\t\t\t\t\t\talertFields = $tw.utils.extend({},tiddler.fields);\n\t\t\t\t}\n\t\t\t});\n\t\t\tif(alertFields) {\n\t\t\t\texistingCount = alertFields.count || 1;\n\t\t\t} else {\n\t\t\t\talertFields = {\n\t\t\t\t\ttitle: $tw.wiki.generateNewTitle(\"$:/temp/alerts/alert\",{prefix: \"\"}),\n\t\t\t\t\ttext: text,\n\t\t\t\t\ttags: [ALERT_TAG],\n\t\t\t\t\tcomponent: this.componentName\n\t\t\t\t};\n\t\t\t\texistingCount = 0;\n\t\t\t}\n\t\t\talertFields.modified = new Date();\n\t\t\tif(++existingCount > 1) {\n\t\t\t\talertFields.count = existingCount;\n\t\t\t} else {\n\t\t\t\talertFields.count = undefined;\n\t\t\t}\n\t\t\t$tw.wiki.addTiddler(new $tw.Tiddler(alertFields));\n\t\t\t// Log the alert as well\n\t\t\tthis.log.apply(this,Array.prototype.slice.call(arguments,0));\n\t\t} else {\n\t\t\t// Print an orange message to the console if not in the browser\n\t\t\tconsole.error(\"\\x1b[1;33m\" + text + \"\\x1b[0m\");\n\t\t}\t\t\n\t}\n};\n\nexports.Logger = Logger;\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/utils/parsetree.js": {
"title": "$:/core/modules/utils/parsetree.js",
"text": "/*\\\ntitle: $:/core/modules/utils/parsetree.js\ntype: application/javascript\nmodule-type: utils\n\nParse tree utility functions.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.addAttributeToParseTreeNode = function(node,name,value) {\n\tnode.attributes = node.attributes || {};\n\tnode.attributes[name] = {type: \"string\", value: value};\n};\n\nexports.getAttributeValueFromParseTreeNode = function(node,name,defaultValue) {\n\tif(node.attributes && node.attributes[name] && node.attributes[name].value !== undefined) {\n\t\treturn node.attributes[name].value;\n\t}\n\treturn defaultValue;\n};\n\nexports.addClassToParseTreeNode = function(node,classString) {\n\tvar classes = [];\n\tnode.attributes = node.attributes || {};\n\tnode.attributes[\"class\"] = node.attributes[\"class\"] || {type: \"string\", value: \"\"};\n\tif(node.attributes[\"class\"].type === \"string\") {\n\t\tif(node.attributes[\"class\"].value !== \"\") {\n\t\t\tclasses = node.attributes[\"class\"].value.split(\" \");\n\t\t}\n\t\tif(classString !== \"\") {\n\t\t\t$tw.utils.pushTop(classes,classString.split(\" \"));\n\t\t}\n\t\tnode.attributes[\"class\"].value = classes.join(\" \");\n\t}\n};\n\nexports.addStyleToParseTreeNode = function(node,name,value) {\n\t\tnode.attributes = node.attributes || {};\n\t\tnode.attributes.style = node.attributes.style || {type: \"string\", value: \"\"};\n\t\tif(node.attributes.style.type === \"string\") {\n\t\t\tnode.attributes.style.value += name + \":\" + value + \";\";\n\t\t}\n};\n\nexports.findParseTreeNode = function(nodeArray,search) {\n\tfor(var t=0; t<nodeArray.length; t++) {\n\t\tif(nodeArray[t].type === search.type && nodeArray[t].tag === search.tag) {\n\t\t\treturn nodeArray[t];\n\t\t}\n\t}\n\treturn undefined;\n};\n\n/*\nHelper to get the text of a parse tree node or array of nodes\n*/\nexports.getParseTreeText = function getParseTreeText(tree) {\n\tvar output = [];\n\tif($tw.utils.isArray(tree)) {\n\t\t$tw.utils.each(tree,function(node) {\n\t\t\toutput.push(getParseTreeText(node));\n\t\t});\n\t} else {\n\t\tif(tree.type === \"text\") {\n\t\t\toutput.push(tree.text);\n\t\t}\n\t\tif(tree.children) {\n\t\t\treturn getParseTreeText(tree.children);\n\t\t}\n\t}\n\treturn output.join(\"\");\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/utils/performance.js": {
"title": "$:/core/modules/utils/performance.js",
"text": "/*\\\ntitle: $:/core/modules/utils/performance.js\ntype: application/javascript\nmodule-type: global\n\nPerformance measurement.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nfunction Performance(enabled) {\n\tthis.enabled = !!enabled;\n\tthis.measures = {}; // Hashmap of current values of measurements\n\tthis.logger = new $tw.utils.Logger(\"performance\");\n}\n\n/*\nWrap performance reporting around a top level function\n*/\nPerformance.prototype.report = function(name,fn) {\n\tvar self = this;\n\tif(this.enabled) {\n\t\treturn function() {\n\t\t\tself.measures = {};\n\t\t\tvar startTime = $tw.utils.timer(),\n\t\t\t\tresult = fn.apply(this,arguments);\n\t\t\tself.logger.log(name + \": \" + $tw.utils.timer(startTime).toFixed(2) + \"ms\");\n\t\t\tfor(var m in self.measures) {\n\t\t\t\tself.logger.log(\"+\" + m + \": \" + self.measures[m].toFixed(2) + \"ms\");\n\t\t\t}\n\t\t\treturn result;\n\t\t};\n\t} else {\n\t\treturn fn;\n\t}\n};\n\n/*\nWrap performance measurements around a subfunction\n*/\nPerformance.prototype.measure = function(name,fn) {\n\tvar self = this;\n\tif(this.enabled) {\n\t\treturn function() {\n\t\t\tvar startTime = $tw.utils.timer(),\n\t\t\t\tresult = fn.apply(this,arguments),\n\t\t\t\tvalue = self.measures[name] || 0;\n\t\t\tself.measures[name] = value + $tw.utils.timer(startTime);\n\t\t\treturn result;\n\t\t};\n\t} else {\n\t\treturn fn;\n\t}\n};\n\nexports.Performance = Performance;\n\n})();\n",
"type": "application/javascript",
"module-type": "global"
},
"$:/core/modules/utils/pluginmaker.js": {
"title": "$:/core/modules/utils/pluginmaker.js",
"text": "/*\\\ntitle: $:/core/modules/utils/pluginmaker.js\ntype: application/javascript\nmodule-type: utils\n\nA quick and dirty way to pack up plugins within the browser.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nRepack a plugin, and then delete any non-shadow payload tiddlers\n*/\nexports.repackPlugin = function(title,additionalTiddlers,excludeTiddlers) {\n\tadditionalTiddlers = additionalTiddlers || [];\n\texcludeTiddlers = excludeTiddlers || [];\n\t// Get the plugin tiddler\n\tvar pluginTiddler = $tw.wiki.getTiddler(title);\n\tif(!pluginTiddler) {\n\t\tthrow \"No such tiddler as \" + title;\n\t}\n\t// Extract the JSON\n\tvar jsonPluginTiddler;\n\ttry {\n\t\tjsonPluginTiddler = JSON.parse(pluginTiddler.fields.text);\n\t} catch(e) {\n\t\tthrow \"Cannot parse plugin tiddler \" + title + \"\\n\" + $tw.language.getString(\"Error/Caption\") + \": \" + e;\n\t}\n\t// Get the list of tiddlers\n\tvar tiddlers = Object.keys(jsonPluginTiddler.tiddlers);\n\t// Add the additional tiddlers\n\t$tw.utils.pushTop(tiddlers,additionalTiddlers);\n\t// Remove any excluded tiddlers\n\tfor(var t=tiddlers.length-1; t>=0; t--) {\n\t\tif(excludeTiddlers.indexOf(tiddlers[t]) !== -1) {\n\t\t\ttiddlers.splice(t,1);\n\t\t}\n\t}\n\t// Pack up the tiddlers into a block of JSON\n\tvar plugins = {};\n\t$tw.utils.each(tiddlers,function(title) {\n\t\tvar tiddler = $tw.wiki.getTiddler(title),\n\t\t\tfields = {};\n\t\t$tw.utils.each(tiddler.fields,function (value,name) {\n\t\t\tfields[name] = tiddler.getFieldString(name);\n\t\t});\n\t\tplugins[title] = fields;\n\t});\n\t// Retrieve and bump the version number\n\tvar pluginVersion = $tw.utils.parseVersion(pluginTiddler.getFieldString(\"version\") || \"0.0.0\") || {\n\t\t\tmajor: \"0\",\n\t\t\tminor: \"0\",\n\t\t\tpatch: \"0\"\n\t\t};\n\tpluginVersion.patch++;\n\tvar version = pluginVersion.major + \".\" + pluginVersion.minor + \".\" + pluginVersion.patch;\n\tif(pluginVersion.prerelease) {\n\t\tversion += \"-\" + pluginVersion.prerelease;\n\t}\n\tif(pluginVersion.build) {\n\t\tversion += \"+\" + pluginVersion.build;\n\t}\n\t// Save the tiddler\n\t$tw.wiki.addTiddler(new $tw.Tiddler(pluginTiddler,{text: JSON.stringify({tiddlers: plugins},null,4), version: version}));\n\t// Delete any non-shadow constituent tiddlers\n\t$tw.utils.each(tiddlers,function(title) {\n\t\tif($tw.wiki.tiddlerExists(title)) {\n\t\t\t$tw.wiki.deleteTiddler(title);\n\t\t}\n\t});\n\t// Trigger an autosave\n\t$tw.rootWidget.dispatchEvent({type: \"tm-auto-save-wiki\"});\n\t// Return a heartwarming confirmation\n\treturn \"Plugin \" + title + \" successfully saved\";\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/utils/transliterate.js": {
"title": "$:/core/modules/utils/transliterate.js",
"text": "/*\\\ntitle: $:/core/modules/utils/transliterate.js\ntype: application/javascript\nmodule-type: utils\n\nTransliteration static utility functions.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nTransliterate string to ASCII\n\n(Some pairs taken from http://semplicewebsites.com/removing-accents-javascript)\n*/\nexports.transliterationPairs = {\n\t\"Á\":\"A\",\n\t\"Ă\":\"A\",\n\t\"Ắ\":\"A\",\n\t\"Ặ\":\"A\",\n\t\"Ằ\":\"A\",\n\t\"Ẳ\":\"A\",\n\t\"Ẵ\":\"A\",\n\t\"Ǎ\":\"A\",\n\t\"Â\":\"A\",\n\t\"Ấ\":\"A\",\n\t\"Ậ\":\"A\",\n\t\"Ầ\":\"A\",\n\t\"Ẩ\":\"A\",\n\t\"Ẫ\":\"A\",\n\t\"Ä\":\"A\",\n\t\"Ǟ\":\"A\",\n\t\"Ȧ\":\"A\",\n\t\"Ǡ\":\"A\",\n\t\"Ạ\":\"A\",\n\t\"Ȁ\":\"A\",\n\t\"À\":\"A\",\n\t\"Ả\":\"A\",\n\t\"Ȃ\":\"A\",\n\t\"Ā\":\"A\",\n\t\"Ą\":\"A\",\n\t\"Å\":\"A\",\n\t\"Ǻ\":\"A\",\n\t\"Ḁ\":\"A\",\n\t\"Ⱥ\":\"A\",\n\t\"Ã\":\"A\",\n\t\"Ꜳ\":\"AA\",\n\t\"Æ\":\"AE\",\n\t\"Ǽ\":\"AE\",\n\t\"Ǣ\":\"AE\",\n\t\"Ꜵ\":\"AO\",\n\t\"Ꜷ\":\"AU\",\n\t\"Ꜹ\":\"AV\",\n\t\"Ꜻ\":\"AV\",\n\t\"Ꜽ\":\"AY\",\n\t\"Ḃ\":\"B\",\n\t\"Ḅ\":\"B\",\n\t\"Ɓ\":\"B\",\n\t\"Ḇ\":\"B\",\n\t\"Ƀ\":\"B\",\n\t\"Ƃ\":\"B\",\n\t\"Ć\":\"C\",\n\t\"Č\":\"C\",\n\t\"Ç\":\"C\",\n\t\"Ḉ\":\"C\",\n\t\"Ĉ\":\"C\",\n\t\"Ċ\":\"C\",\n\t\"Ƈ\":\"C\",\n\t\"Ȼ\":\"C\",\n\t\"Ď\":\"D\",\n\t\"Ḑ\":\"D\",\n\t\"Ḓ\":\"D\",\n\t\"Ḋ\":\"D\",\n\t\"Ḍ\":\"D\",\n\t\"Ɗ\":\"D\",\n\t\"Ḏ\":\"D\",\n\t\"Dz\":\"D\",\n\t\"Dž\":\"D\",\n\t\"Đ\":\"D\",\n\t\"Ƌ\":\"D\",\n\t\"DZ\":\"DZ\",\n\t\"DŽ\":\"DZ\",\n\t\"É\":\"E\",\n\t\"Ĕ\":\"E\",\n\t\"Ě\":\"E\",\n\t\"Ȩ\":\"E\",\n\t\"Ḝ\":\"E\",\n\t\"Ê\":\"E\",\n\t\"Ế\":\"E\",\n\t\"Ệ\":\"E\",\n\t\"Ề\":\"E\",\n\t\"Ể\":\"E\",\n\t\"Ễ\":\"E\",\n\t\"Ḙ\":\"E\",\n\t\"Ë\":\"E\",\n\t\"Ė\":\"E\",\n\t\"Ẹ\":\"E\",\n\t\"Ȅ\":\"E\",\n\t\"È\":\"E\",\n\t\"Ẻ\":\"E\",\n\t\"Ȇ\":\"E\",\n\t\"Ē\":\"E\",\n\t\"Ḗ\":\"E\",\n\t\"Ḕ\":\"E\",\n\t\"Ę\":\"E\",\n\t\"Ɇ\":\"E\",\n\t\"Ẽ\":\"E\",\n\t\"Ḛ\":\"E\",\n\t\"Ꝫ\":\"ET\",\n\t\"Ḟ\":\"F\",\n\t\"Ƒ\":\"F\",\n\t\"Ǵ\":\"G\",\n\t\"Ğ\":\"G\",\n\t\"Ǧ\":\"G\",\n\t\"Ģ\":\"G\",\n\t\"Ĝ\":\"G\",\n\t\"Ġ\":\"G\",\n\t\"Ɠ\":\"G\",\n\t\"Ḡ\":\"G\",\n\t\"Ǥ\":\"G\",\n\t\"Ḫ\":\"H\",\n\t\"Ȟ\":\"H\",\n\t\"Ḩ\":\"H\",\n\t\"Ĥ\":\"H\",\n\t\"Ⱨ\":\"H\",\n\t\"Ḧ\":\"H\",\n\t\"Ḣ\":\"H\",\n\t\"Ḥ\":\"H\",\n\t\"Ħ\":\"H\",\n\t\"Í\":\"I\",\n\t\"Ĭ\":\"I\",\n\t\"Ǐ\":\"I\",\n\t\"Î\":\"I\",\n\t\"Ï\":\"I\",\n\t\"Ḯ\":\"I\",\n\t\"İ\":\"I\",\n\t\"Ị\":\"I\",\n\t\"Ȉ\":\"I\",\n\t\"Ì\":\"I\",\n\t\"Ỉ\":\"I\",\n\t\"Ȋ\":\"I\",\n\t\"Ī\":\"I\",\n\t\"Į\":\"I\",\n\t\"Ɨ\":\"I\",\n\t\"Ĩ\":\"I\",\n\t\"Ḭ\":\"I\",\n\t\"Ꝺ\":\"D\",\n\t\"Ꝼ\":\"F\",\n\t\"Ᵹ\":\"G\",\n\t\"Ꞃ\":\"R\",\n\t\"Ꞅ\":\"S\",\n\t\"Ꞇ\":\"T\",\n\t\"Ꝭ\":\"IS\",\n\t\"Ĵ\":\"J\",\n\t\"Ɉ\":\"J\",\n\t\"Ḱ\":\"K\",\n\t\"Ǩ\":\"K\",\n\t\"Ķ\":\"K\",\n\t\"Ⱪ\":\"K\",\n\t\"Ꝃ\":\"K\",\n\t\"Ḳ\":\"K\",\n\t\"Ƙ\":\"K\",\n\t\"Ḵ\":\"K\",\n\t\"Ꝁ\":\"K\",\n\t\"Ꝅ\":\"K\",\n\t\"Ĺ\":\"L\",\n\t\"Ƚ\":\"L\",\n\t\"Ľ\":\"L\",\n\t\"Ļ\":\"L\",\n\t\"Ḽ\":\"L\",\n\t\"Ḷ\":\"L\",\n\t\"Ḹ\":\"L\",\n\t\"Ⱡ\":\"L\",\n\t\"Ꝉ\":\"L\",\n\t\"Ḻ\":\"L\",\n\t\"Ŀ\":\"L\",\n\t\"Ɫ\":\"L\",\n\t\"Lj\":\"L\",\n\t\"Ł\":\"L\",\n\t\"LJ\":\"LJ\",\n\t\"Ḿ\":\"M\",\n\t\"Ṁ\":\"M\",\n\t\"Ṃ\":\"M\",\n\t\"Ɱ\":\"M\",\n\t\"Ń\":\"N\",\n\t\"Ň\":\"N\",\n\t\"Ņ\":\"N\",\n\t\"Ṋ\":\"N\",\n\t\"Ṅ\":\"N\",\n\t\"Ṇ\":\"N\",\n\t\"Ǹ\":\"N\",\n\t\"Ɲ\":\"N\",\n\t\"Ṉ\":\"N\",\n\t\"Ƞ\":\"N\",\n\t\"Nj\":\"N\",\n\t\"Ñ\":\"N\",\n\t\"NJ\":\"NJ\",\n\t\"Ó\":\"O\",\n\t\"Ŏ\":\"O\",\n\t\"Ǒ\":\"O\",\n\t\"Ô\":\"O\",\n\t\"Ố\":\"O\",\n\t\"Ộ\":\"O\",\n\t\"Ồ\":\"O\",\n\t\"Ổ\":\"O\",\n\t\"Ỗ\":\"O\",\n\t\"Ö\":\"O\",\n\t\"Ȫ\":\"O\",\n\t\"Ȯ\":\"O\",\n\t\"Ȱ\":\"O\",\n\t\"Ọ\":\"O\",\n\t\"Ő\":\"O\",\n\t\"Ȍ\":\"O\",\n\t\"Ò\":\"O\",\n\t\"Ỏ\":\"O\",\n\t\"Ơ\":\"O\",\n\t\"Ớ\":\"O\",\n\t\"Ợ\":\"O\",\n\t\"Ờ\":\"O\",\n\t\"Ở\":\"O\",\n\t\"Ỡ\":\"O\",\n\t\"Ȏ\":\"O\",\n\t\"Ꝋ\":\"O\",\n\t\"Ꝍ\":\"O\",\n\t\"Ō\":\"O\",\n\t\"Ṓ\":\"O\",\n\t\"Ṑ\":\"O\",\n\t\"Ɵ\":\"O\",\n\t\"Ǫ\":\"O\",\n\t\"Ǭ\":\"O\",\n\t\"Ø\":\"O\",\n\t\"Ǿ\":\"O\",\n\t\"Õ\":\"O\",\n\t\"Ṍ\":\"O\",\n\t\"Ṏ\":\"O\",\n\t\"Ȭ\":\"O\",\n\t\"Ƣ\":\"OI\",\n\t\"Ꝏ\":\"OO\",\n\t\"Ɛ\":\"E\",\n\t\"Ɔ\":\"O\",\n\t\"Ȣ\":\"OU\",\n\t\"Ṕ\":\"P\",\n\t\"Ṗ\":\"P\",\n\t\"Ꝓ\":\"P\",\n\t\"Ƥ\":\"P\",\n\t\"Ꝕ\":\"P\",\n\t\"Ᵽ\":\"P\",\n\t\"Ꝑ\":\"P\",\n\t\"Ꝙ\":\"Q\",\n\t\"Ꝗ\":\"Q\",\n\t\"Ŕ\":\"R\",\n\t\"Ř\":\"R\",\n\t\"Ŗ\":\"R\",\n\t\"Ṙ\":\"R\",\n\t\"Ṛ\":\"R\",\n\t\"Ṝ\":\"R\",\n\t\"Ȑ\":\"R\",\n\t\"Ȓ\":\"R\",\n\t\"Ṟ\":\"R\",\n\t\"Ɍ\":\"R\",\n\t\"Ɽ\":\"R\",\n\t\"Ꜿ\":\"C\",\n\t\"Ǝ\":\"E\",\n\t\"Ś\":\"S\",\n\t\"Ṥ\":\"S\",\n\t\"Š\":\"S\",\n\t\"Ṧ\":\"S\",\n\t\"Ş\":\"S\",\n\t\"Ŝ\":\"S\",\n\t\"Ș\":\"S\",\n\t\"Ṡ\":\"S\",\n\t\"Ṣ\":\"S\",\n\t\"Ṩ\":\"S\",\n\t\"Ť\":\"T\",\n\t\"Ţ\":\"T\",\n\t\"Ṱ\":\"T\",\n\t\"Ț\":\"T\",\n\t\"Ⱦ\":\"T\",\n\t\"Ṫ\":\"T\",\n\t\"Ṭ\":\"T\",\n\t\"Ƭ\":\"T\",\n\t\"Ṯ\":\"T\",\n\t\"Ʈ\":\"T\",\n\t\"Ŧ\":\"T\",\n\t\"Ɐ\":\"A\",\n\t\"Ꞁ\":\"L\",\n\t\"Ɯ\":\"M\",\n\t\"Ʌ\":\"V\",\n\t\"Ꜩ\":\"TZ\",\n\t\"Ú\":\"U\",\n\t\"Ŭ\":\"U\",\n\t\"Ǔ\":\"U\",\n\t\"Û\":\"U\",\n\t\"Ṷ\":\"U\",\n\t\"Ü\":\"U\",\n\t\"Ǘ\":\"U\",\n\t\"Ǚ\":\"U\",\n\t\"Ǜ\":\"U\",\n\t\"Ǖ\":\"U\",\n\t\"Ṳ\":\"U\",\n\t\"Ụ\":\"U\",\n\t\"Ű\":\"U\",\n\t\"Ȕ\":\"U\",\n\t\"Ù\":\"U\",\n\t\"Ủ\":\"U\",\n\t\"Ư\":\"U\",\n\t\"Ứ\":\"U\",\n\t\"Ự\":\"U\",\n\t\"Ừ\":\"U\",\n\t\"Ử\":\"U\",\n\t\"Ữ\":\"U\",\n\t\"Ȗ\":\"U\",\n\t\"Ū\":\"U\",\n\t\"Ṻ\":\"U\",\n\t\"Ų\":\"U\",\n\t\"Ů\":\"U\",\n\t\"Ũ\":\"U\",\n\t\"Ṹ\":\"U\",\n\t\"Ṵ\":\"U\",\n\t\"Ꝟ\":\"V\",\n\t\"Ṿ\":\"V\",\n\t\"Ʋ\":\"V\",\n\t\"Ṽ\":\"V\",\n\t\"Ꝡ\":\"VY\",\n\t\"Ẃ\":\"W\",\n\t\"Ŵ\":\"W\",\n\t\"Ẅ\":\"W\",\n\t\"Ẇ\":\"W\",\n\t\"Ẉ\":\"W\",\n\t\"Ẁ\":\"W\",\n\t\"Ⱳ\":\"W\",\n\t\"Ẍ\":\"X\",\n\t\"Ẋ\":\"X\",\n\t\"Ý\":\"Y\",\n\t\"Ŷ\":\"Y\",\n\t\"Ÿ\":\"Y\",\n\t\"Ẏ\":\"Y\",\n\t\"Ỵ\":\"Y\",\n\t\"Ỳ\":\"Y\",\n\t\"Ƴ\":\"Y\",\n\t\"Ỷ\":\"Y\",\n\t\"Ỿ\":\"Y\",\n\t\"Ȳ\":\"Y\",\n\t\"Ɏ\":\"Y\",\n\t\"Ỹ\":\"Y\",\n\t\"Ź\":\"Z\",\n\t\"Ž\":\"Z\",\n\t\"Ẑ\":\"Z\",\n\t\"Ⱬ\":\"Z\",\n\t\"Ż\":\"Z\",\n\t\"Ẓ\":\"Z\",\n\t\"Ȥ\":\"Z\",\n\t\"Ẕ\":\"Z\",\n\t\"Ƶ\":\"Z\",\n\t\"IJ\":\"IJ\",\n\t\"Œ\":\"OE\",\n\t\"ᴀ\":\"A\",\n\t\"ᴁ\":\"AE\",\n\t\"ʙ\":\"B\",\n\t\"ᴃ\":\"B\",\n\t\"ᴄ\":\"C\",\n\t\"ᴅ\":\"D\",\n\t\"ᴇ\":\"E\",\n\t\"ꜰ\":\"F\",\n\t\"ɢ\":\"G\",\n\t\"ʛ\":\"G\",\n\t\"ʜ\":\"H\",\n\t\"ɪ\":\"I\",\n\t\"ʁ\":\"R\",\n\t\"ᴊ\":\"J\",\n\t\"ᴋ\":\"K\",\n\t\"ʟ\":\"L\",\n\t\"ᴌ\":\"L\",\n\t\"ᴍ\":\"M\",\n\t\"ɴ\":\"N\",\n\t\"ᴏ\":\"O\",\n\t\"ɶ\":\"OE\",\n\t\"ᴐ\":\"O\",\n\t\"ᴕ\":\"OU\",\n\t\"ᴘ\":\"P\",\n\t\"ʀ\":\"R\",\n\t\"ᴎ\":\"N\",\n\t\"ᴙ\":\"R\",\n\t\"ꜱ\":\"S\",\n\t\"ᴛ\":\"T\",\n\t\"ⱻ\":\"E\",\n\t\"ᴚ\":\"R\",\n\t\"ᴜ\":\"U\",\n\t\"ᴠ\":\"V\",\n\t\"ᴡ\":\"W\",\n\t\"ʏ\":\"Y\",\n\t\"ᴢ\":\"Z\",\n\t\"á\":\"a\",\n\t\"ă\":\"a\",\n\t\"ắ\":\"a\",\n\t\"ặ\":\"a\",\n\t\"ằ\":\"a\",\n\t\"ẳ\":\"a\",\n\t\"ẵ\":\"a\",\n\t\"ǎ\":\"a\",\n\t\"â\":\"a\",\n\t\"ấ\":\"a\",\n\t\"ậ\":\"a\",\n\t\"ầ\":\"a\",\n\t\"ẩ\":\"a\",\n\t\"ẫ\":\"a\",\n\t\"ä\":\"a\",\n\t\"ǟ\":\"a\",\n\t\"ȧ\":\"a\",\n\t\"ǡ\":\"a\",\n\t\"ạ\":\"a\",\n\t\"ȁ\":\"a\",\n\t\"à\":\"a\",\n\t\"ả\":\"a\",\n\t\"ȃ\":\"a\",\n\t\"ā\":\"a\",\n\t\"ą\":\"a\",\n\t\"ᶏ\":\"a\",\n\t\"ẚ\":\"a\",\n\t\"å\":\"a\",\n\t\"ǻ\":\"a\",\n\t\"ḁ\":\"a\",\n\t\"ⱥ\":\"a\",\n\t\"ã\":\"a\",\n\t\"ꜳ\":\"aa\",\n\t\"æ\":\"ae\",\n\t\"ǽ\":\"ae\",\n\t\"ǣ\":\"ae\",\n\t\"ꜵ\":\"ao\",\n\t\"ꜷ\":\"au\",\n\t\"ꜹ\":\"av\",\n\t\"ꜻ\":\"av\",\n\t\"ꜽ\":\"ay\",\n\t\"ḃ\":\"b\",\n\t\"ḅ\":\"b\",\n\t\"ɓ\":\"b\",\n\t\"ḇ\":\"b\",\n\t\"ᵬ\":\"b\",\n\t\"ᶀ\":\"b\",\n\t\"ƀ\":\"b\",\n\t\"ƃ\":\"b\",\n\t\"ɵ\":\"o\",\n\t\"ć\":\"c\",\n\t\"č\":\"c\",\n\t\"ç\":\"c\",\n\t\"ḉ\":\"c\",\n\t\"ĉ\":\"c\",\n\t\"ɕ\":\"c\",\n\t\"ċ\":\"c\",\n\t\"ƈ\":\"c\",\n\t\"ȼ\":\"c\",\n\t\"ď\":\"d\",\n\t\"ḑ\":\"d\",\n\t\"ḓ\":\"d\",\n\t\"ȡ\":\"d\",\n\t\"ḋ\":\"d\",\n\t\"ḍ\":\"d\",\n\t\"ɗ\":\"d\",\n\t\"ᶑ\":\"d\",\n\t\"ḏ\":\"d\",\n\t\"ᵭ\":\"d\",\n\t\"ᶁ\":\"d\",\n\t\"đ\":\"d\",\n\t\"ɖ\":\"d\",\n\t\"ƌ\":\"d\",\n\t\"ı\":\"i\",\n\t\"ȷ\":\"j\",\n\t\"ɟ\":\"j\",\n\t\"ʄ\":\"j\",\n\t\"dz\":\"dz\",\n\t\"dž\":\"dz\",\n\t\"é\":\"e\",\n\t\"ĕ\":\"e\",\n\t\"ě\":\"e\",\n\t\"ȩ\":\"e\",\n\t\"ḝ\":\"e\",\n\t\"ê\":\"e\",\n\t\"ế\":\"e\",\n\t\"ệ\":\"e\",\n\t\"ề\":\"e\",\n\t\"ể\":\"e\",\n\t\"ễ\":\"e\",\n\t\"ḙ\":\"e\",\n\t\"ë\":\"e\",\n\t\"ė\":\"e\",\n\t\"ẹ\":\"e\",\n\t\"ȅ\":\"e\",\n\t\"è\":\"e\",\n\t\"ẻ\":\"e\",\n\t\"ȇ\":\"e\",\n\t\"ē\":\"e\",\n\t\"ḗ\":\"e\",\n\t\"ḕ\":\"e\",\n\t\"ⱸ\":\"e\",\n\t\"ę\":\"e\",\n\t\"ᶒ\":\"e\",\n\t\"ɇ\":\"e\",\n\t\"ẽ\":\"e\",\n\t\"ḛ\":\"e\",\n\t\"ꝫ\":\"et\",\n\t\"ḟ\":\"f\",\n\t\"ƒ\":\"f\",\n\t\"ᵮ\":\"f\",\n\t\"ᶂ\":\"f\",\n\t\"ǵ\":\"g\",\n\t\"ğ\":\"g\",\n\t\"ǧ\":\"g\",\n\t\"ģ\":\"g\",\n\t\"ĝ\":\"g\",\n\t\"ġ\":\"g\",\n\t\"ɠ\":\"g\",\n\t\"ḡ\":\"g\",\n\t\"ᶃ\":\"g\",\n\t\"ǥ\":\"g\",\n\t\"ḫ\":\"h\",\n\t\"ȟ\":\"h\",\n\t\"ḩ\":\"h\",\n\t\"ĥ\":\"h\",\n\t\"ⱨ\":\"h\",\n\t\"ḧ\":\"h\",\n\t\"ḣ\":\"h\",\n\t\"ḥ\":\"h\",\n\t\"ɦ\":\"h\",\n\t\"ẖ\":\"h\",\n\t\"ħ\":\"h\",\n\t\"ƕ\":\"hv\",\n\t\"í\":\"i\",\n\t\"ĭ\":\"i\",\n\t\"ǐ\":\"i\",\n\t\"î\":\"i\",\n\t\"ï\":\"i\",\n\t\"ḯ\":\"i\",\n\t\"ị\":\"i\",\n\t\"ȉ\":\"i\",\n\t\"ì\":\"i\",\n\t\"ỉ\":\"i\",\n\t\"ȋ\":\"i\",\n\t\"ī\":\"i\",\n\t\"į\":\"i\",\n\t\"ᶖ\":\"i\",\n\t\"ɨ\":\"i\",\n\t\"ĩ\":\"i\",\n\t\"ḭ\":\"i\",\n\t\"ꝺ\":\"d\",\n\t\"ꝼ\":\"f\",\n\t\"ᵹ\":\"g\",\n\t\"ꞃ\":\"r\",\n\t\"ꞅ\":\"s\",\n\t\"ꞇ\":\"t\",\n\t\"ꝭ\":\"is\",\n\t\"ǰ\":\"j\",\n\t\"ĵ\":\"j\",\n\t\"ʝ\":\"j\",\n\t\"ɉ\":\"j\",\n\t\"ḱ\":\"k\",\n\t\"ǩ\":\"k\",\n\t\"ķ\":\"k\",\n\t\"ⱪ\":\"k\",\n\t\"ꝃ\":\"k\",\n\t\"ḳ\":\"k\",\n\t\"ƙ\":\"k\",\n\t\"ḵ\":\"k\",\n\t\"ᶄ\":\"k\",\n\t\"ꝁ\":\"k\",\n\t\"ꝅ\":\"k\",\n\t\"ĺ\":\"l\",\n\t\"ƚ\":\"l\",\n\t\"ɬ\":\"l\",\n\t\"ľ\":\"l\",\n\t\"ļ\":\"l\",\n\t\"ḽ\":\"l\",\n\t\"ȴ\":\"l\",\n\t\"ḷ\":\"l\",\n\t\"ḹ\":\"l\",\n\t\"ⱡ\":\"l\",\n\t\"ꝉ\":\"l\",\n\t\"ḻ\":\"l\",\n\t\"ŀ\":\"l\",\n\t\"ɫ\":\"l\",\n\t\"ᶅ\":\"l\",\n\t\"ɭ\":\"l\",\n\t\"ł\":\"l\",\n\t\"lj\":\"lj\",\n\t\"ſ\":\"s\",\n\t\"ẜ\":\"s\",\n\t\"ẛ\":\"s\",\n\t\"ẝ\":\"s\",\n\t\"ḿ\":\"m\",\n\t\"ṁ\":\"m\",\n\t\"ṃ\":\"m\",\n\t\"ɱ\":\"m\",\n\t\"ᵯ\":\"m\",\n\t\"ᶆ\":\"m\",\n\t\"ń\":\"n\",\n\t\"ň\":\"n\",\n\t\"ņ\":\"n\",\n\t\"ṋ\":\"n\",\n\t\"ȵ\":\"n\",\n\t\"ṅ\":\"n\",\n\t\"ṇ\":\"n\",\n\t\"ǹ\":\"n\",\n\t\"ɲ\":\"n\",\n\t\"ṉ\":\"n\",\n\t\"ƞ\":\"n\",\n\t\"ᵰ\":\"n\",\n\t\"ᶇ\":\"n\",\n\t\"ɳ\":\"n\",\n\t\"ñ\":\"n\",\n\t\"nj\":\"nj\",\n\t\"ó\":\"o\",\n\t\"ŏ\":\"o\",\n\t\"ǒ\":\"o\",\n\t\"ô\":\"o\",\n\t\"ố\":\"o\",\n\t\"ộ\":\"o\",\n\t\"ồ\":\"o\",\n\t\"ổ\":\"o\",\n\t\"ỗ\":\"o\",\n\t\"ö\":\"o\",\n\t\"ȫ\":\"o\",\n\t\"ȯ\":\"o\",\n\t\"ȱ\":\"o\",\n\t\"ọ\":\"o\",\n\t\"ő\":\"o\",\n\t\"ȍ\":\"o\",\n\t\"ò\":\"o\",\n\t\"ỏ\":\"o\",\n\t\"ơ\":\"o\",\n\t\"ớ\":\"o\",\n\t\"ợ\":\"o\",\n\t\"ờ\":\"o\",\n\t\"ở\":\"o\",\n\t\"ỡ\":\"o\",\n\t\"ȏ\":\"o\",\n\t\"ꝋ\":\"o\",\n\t\"ꝍ\":\"o\",\n\t\"ⱺ\":\"o\",\n\t\"ō\":\"o\",\n\t\"ṓ\":\"o\",\n\t\"ṑ\":\"o\",\n\t\"ǫ\":\"o\",\n\t\"ǭ\":\"o\",\n\t\"ø\":\"o\",\n\t\"ǿ\":\"o\",\n\t\"õ\":\"o\",\n\t\"ṍ\":\"o\",\n\t\"ṏ\":\"o\",\n\t\"ȭ\":\"o\",\n\t\"ƣ\":\"oi\",\n\t\"ꝏ\":\"oo\",\n\t\"ɛ\":\"e\",\n\t\"ᶓ\":\"e\",\n\t\"ɔ\":\"o\",\n\t\"ᶗ\":\"o\",\n\t\"ȣ\":\"ou\",\n\t\"ṕ\":\"p\",\n\t\"ṗ\":\"p\",\n\t\"ꝓ\":\"p\",\n\t\"ƥ\":\"p\",\n\t\"ᵱ\":\"p\",\n\t\"ᶈ\":\"p\",\n\t\"ꝕ\":\"p\",\n\t\"ᵽ\":\"p\",\n\t\"ꝑ\":\"p\",\n\t\"ꝙ\":\"q\",\n\t\"ʠ\":\"q\",\n\t\"ɋ\":\"q\",\n\t\"ꝗ\":\"q\",\n\t\"ŕ\":\"r\",\n\t\"ř\":\"r\",\n\t\"ŗ\":\"r\",\n\t\"ṙ\":\"r\",\n\t\"ṛ\":\"r\",\n\t\"ṝ\":\"r\",\n\t\"ȑ\":\"r\",\n\t\"ɾ\":\"r\",\n\t\"ᵳ\":\"r\",\n\t\"ȓ\":\"r\",\n\t\"ṟ\":\"r\",\n\t\"ɼ\":\"r\",\n\t\"ᵲ\":\"r\",\n\t\"ᶉ\":\"r\",\n\t\"ɍ\":\"r\",\n\t\"ɽ\":\"r\",\n\t\"ↄ\":\"c\",\n\t\"ꜿ\":\"c\",\n\t\"ɘ\":\"e\",\n\t\"ɿ\":\"r\",\n\t\"ś\":\"s\",\n\t\"ṥ\":\"s\",\n\t\"š\":\"s\",\n\t\"ṧ\":\"s\",\n\t\"ş\":\"s\",\n\t\"ŝ\":\"s\",\n\t\"ș\":\"s\",\n\t\"ṡ\":\"s\",\n\t\"ṣ\":\"s\",\n\t\"ṩ\":\"s\",\n\t\"ʂ\":\"s\",\n\t\"ᵴ\":\"s\",\n\t\"ᶊ\":\"s\",\n\t\"ȿ\":\"s\",\n\t\"ɡ\":\"g\",\n\t\"ᴑ\":\"o\",\n\t\"ᴓ\":\"o\",\n\t\"ᴝ\":\"u\",\n\t\"ť\":\"t\",\n\t\"ţ\":\"t\",\n\t\"ṱ\":\"t\",\n\t\"ț\":\"t\",\n\t\"ȶ\":\"t\",\n\t\"ẗ\":\"t\",\n\t\"ⱦ\":\"t\",\n\t\"ṫ\":\"t\",\n\t\"ṭ\":\"t\",\n\t\"ƭ\":\"t\",\n\t\"ṯ\":\"t\",\n\t\"ᵵ\":\"t\",\n\t\"ƫ\":\"t\",\n\t\"ʈ\":\"t\",\n\t\"ŧ\":\"t\",\n\t\"ᵺ\":\"th\",\n\t\"ɐ\":\"a\",\n\t\"ᴂ\":\"ae\",\n\t\"ǝ\":\"e\",\n\t\"ᵷ\":\"g\",\n\t\"ɥ\":\"h\",\n\t\"ʮ\":\"h\",\n\t\"ʯ\":\"h\",\n\t\"ᴉ\":\"i\",\n\t\"ʞ\":\"k\",\n\t\"ꞁ\":\"l\",\n\t\"ɯ\":\"m\",\n\t\"ɰ\":\"m\",\n\t\"ᴔ\":\"oe\",\n\t\"ɹ\":\"r\",\n\t\"ɻ\":\"r\",\n\t\"ɺ\":\"r\",\n\t\"ⱹ\":\"r\",\n\t\"ʇ\":\"t\",\n\t\"ʌ\":\"v\",\n\t\"ʍ\":\"w\",\n\t\"ʎ\":\"y\",\n\t\"ꜩ\":\"tz\",\n\t\"ú\":\"u\",\n\t\"ŭ\":\"u\",\n\t\"ǔ\":\"u\",\n\t\"û\":\"u\",\n\t\"ṷ\":\"u\",\n\t\"ü\":\"u\",\n\t\"ǘ\":\"u\",\n\t\"ǚ\":\"u\",\n\t\"ǜ\":\"u\",\n\t\"ǖ\":\"u\",\n\t\"ṳ\":\"u\",\n\t\"ụ\":\"u\",\n\t\"ű\":\"u\",\n\t\"ȕ\":\"u\",\n\t\"ù\":\"u\",\n\t\"ủ\":\"u\",\n\t\"ư\":\"u\",\n\t\"ứ\":\"u\",\n\t\"ự\":\"u\",\n\t\"ừ\":\"u\",\n\t\"ử\":\"u\",\n\t\"ữ\":\"u\",\n\t\"ȗ\":\"u\",\n\t\"ū\":\"u\",\n\t\"ṻ\":\"u\",\n\t\"ų\":\"u\",\n\t\"ᶙ\":\"u\",\n\t\"ů\":\"u\",\n\t\"ũ\":\"u\",\n\t\"ṹ\":\"u\",\n\t\"ṵ\":\"u\",\n\t\"ᵫ\":\"ue\",\n\t\"ꝸ\":\"um\",\n\t\"ⱴ\":\"v\",\n\t\"ꝟ\":\"v\",\n\t\"ṿ\":\"v\",\n\t\"ʋ\":\"v\",\n\t\"ᶌ\":\"v\",\n\t\"ⱱ\":\"v\",\n\t\"ṽ\":\"v\",\n\t\"ꝡ\":\"vy\",\n\t\"ẃ\":\"w\",\n\t\"ŵ\":\"w\",\n\t\"ẅ\":\"w\",\n\t\"ẇ\":\"w\",\n\t\"ẉ\":\"w\",\n\t\"ẁ\":\"w\",\n\t\"ⱳ\":\"w\",\n\t\"ẘ\":\"w\",\n\t\"ẍ\":\"x\",\n\t\"ẋ\":\"x\",\n\t\"ᶍ\":\"x\",\n\t\"ý\":\"y\",\n\t\"ŷ\":\"y\",\n\t\"ÿ\":\"y\",\n\t\"ẏ\":\"y\",\n\t\"ỵ\":\"y\",\n\t\"ỳ\":\"y\",\n\t\"ƴ\":\"y\",\n\t\"ỷ\":\"y\",\n\t\"ỿ\":\"y\",\n\t\"ȳ\":\"y\",\n\t\"ẙ\":\"y\",\n\t\"ɏ\":\"y\",\n\t\"ỹ\":\"y\",\n\t\"ź\":\"z\",\n\t\"ž\":\"z\",\n\t\"ẑ\":\"z\",\n\t\"ʑ\":\"z\",\n\t\"ⱬ\":\"z\",\n\t\"ż\":\"z\",\n\t\"ẓ\":\"z\",\n\t\"ȥ\":\"z\",\n\t\"ẕ\":\"z\",\n\t\"ᵶ\":\"z\",\n\t\"ᶎ\":\"z\",\n\t\"ʐ\":\"z\",\n\t\"ƶ\":\"z\",\n\t\"ɀ\":\"z\",\n\t\"ff\":\"ff\",\n\t\"ffi\":\"ffi\",\n\t\"ffl\":\"ffl\",\n\t\"fi\":\"fi\",\n\t\"fl\":\"fl\",\n\t\"ij\":\"ij\",\n\t\"œ\":\"oe\",\n\t\"st\":\"st\",\n\t\"ₐ\":\"a\",\n\t\"ₑ\":\"e\",\n\t\"ᵢ\":\"i\",\n\t\"ⱼ\":\"j\",\n\t\"ₒ\":\"o\",\n\t\"ᵣ\":\"r\",\n\t\"ᵤ\":\"u\",\n\t\"ᵥ\":\"v\",\n\t\"ₓ\":\"x\",\n\t\"Ё\":\"YO\",\n\t\"Й\":\"I\",\n\t\"Ц\":\"TS\",\n\t\"У\":\"U\",\n\t\"К\":\"K\",\n\t\"Е\":\"E\",\n\t\"Н\":\"N\",\n\t\"Г\":\"G\",\n\t\"Ш\":\"SH\",\n\t\"Щ\":\"SCH\",\n\t\"З\":\"Z\",\n\t\"Х\":\"H\",\n\t\"Ъ\":\"'\",\n\t\"ё\":\"yo\",\n\t\"й\":\"i\",\n\t\"ц\":\"ts\",\n\t\"у\":\"u\",\n\t\"к\":\"k\",\n\t\"е\":\"e\",\n\t\"н\":\"n\",\n\t\"г\":\"g\",\n\t\"ш\":\"sh\",\n\t\"щ\":\"sch\",\n\t\"з\":\"z\",\n\t\"х\":\"h\",\n\t\"ъ\":\"'\",\n\t\"Ф\":\"F\",\n\t\"Ы\":\"I\",\n\t\"В\":\"V\",\n\t\"А\":\"a\",\n\t\"П\":\"P\",\n\t\"Р\":\"R\",\n\t\"О\":\"O\",\n\t\"Л\":\"L\",\n\t\"Д\":\"D\",\n\t\"Ж\":\"ZH\",\n\t\"Э\":\"E\",\n\t\"ф\":\"f\",\n\t\"ы\":\"i\",\n\t\"в\":\"v\",\n\t\"а\":\"a\",\n\t\"п\":\"p\",\n\t\"р\":\"r\",\n\t\"о\":\"o\",\n\t\"л\":\"l\",\n\t\"д\":\"d\",\n\t\"ж\":\"zh\",\n\t\"э\":\"e\",\n\t\"Я\":\"Ya\",\n\t\"Ч\":\"CH\",\n\t\"С\":\"S\",\n\t\"М\":\"M\",\n\t\"И\":\"I\",\n\t\"Т\":\"T\",\n\t\"Ь\":\"'\",\n\t\"Б\":\"B\",\n\t\"Ю\":\"YU\",\n\t\"я\":\"ya\",\n\t\"ч\":\"ch\",\n\t\"с\":\"s\",\n\t\"м\":\"m\",\n\t\"и\":\"i\",\n\t\"т\":\"t\",\n\t\"ь\":\"'\",\n\t\"б\":\"b\",\n\t\"ю\":\"yu\"\n};\n\nexports.transliterate = function(str) {\n\treturn str.replace(/[^A-Za-z0-9\\[\\] ]/g,function(ch) {\n\t\treturn exports.transliterationPairs[ch] || ch\n\t});\n};\n\nexports.transliterateToSafeASCII = function(str) {\n\treturn str.replace(/[^\\x00-\\x7F]/g,function(ch) {\n\t\treturn exports.transliterationPairs[ch] || \"\"\n\t});\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/utils/utils.js": {
"title": "$:/core/modules/utils/utils.js",
"text": "/*\\\ntitle: $:/core/modules/utils/utils.js\ntype: application/javascript\nmodule-type: utils\n\nVarious static utility functions.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nDisplay a message, in colour if we're on a terminal\n*/\nexports.log = function(text,colour) {\n\tconsole.log($tw.node ? exports.terminalColour(colour) + text + exports.terminalColour() : text);\n};\n\nexports.terminalColour = function(colour) {\n\tif(!$tw.browser && $tw.node && process.stdout.isTTY) {\n\t\tif(colour) {\n\t\t\tvar code = exports.terminalColourLookup[colour];\n\t\t\tif(code) {\n\t\t\t\treturn \"\\x1b[\" + code + \"m\";\n\t\t\t}\n\t\t} else {\n\t\t\treturn \"\\x1b[0m\"; // Cancel colour\n\t\t}\n\t}\n\treturn \"\";\n};\n\nexports.terminalColourLookup = {\n\t\"black\": \"0;30\",\n\t\"red\": \"0;31\",\n\t\"green\": \"0;32\",\n\t\"brown/orange\": \"0;33\",\n\t\"blue\": \"0;34\",\n\t\"purple\": \"0;35\",\n\t\"cyan\": \"0;36\",\n\t\"light gray\": \"0;37\"\n};\n\n/*\nDisplay a warning, in colour if we're on a terminal\n*/\nexports.warning = function(text) {\n\texports.log(text,\"brown/orange\");\n};\n\n/*\nReturn the integer represented by the str (string).\nReturn the dflt (default) parameter if str is not a base-10 number.\n*/\nexports.getInt = function(str,deflt) {\n\tvar i = parseInt(str,10);\n\treturn isNaN(i) ? deflt : i;\n}\n\n/*\nRepeatedly replaces a substring within a string. Like String.prototype.replace, but without any of the default special handling of $ sequences in the replace string\n*/\nexports.replaceString = function(text,search,replace) {\n\treturn text.replace(search,function() {\n\t\treturn replace;\n\t});\n};\n\n/*\nRepeats a string\n*/\nexports.repeat = function(str,count) {\n\tvar result = \"\";\n\tfor(var t=0;t<count;t++) {\n\t\tresult += str;\n\t}\n\treturn result;\n};\n\n/*\nTrim whitespace from the start and end of a string\nThanks to Steven Levithan, http://blog.stevenlevithan.com/archives/faster-trim-javascript\n*/\nexports.trim = function(str) {\n\tif(typeof str === \"string\") {\n\t\treturn str.replace(/^\\s\\s*/, '').replace(/\\s\\s*$/, '');\n\t} else {\n\t\treturn str;\n\t}\n};\n\n/*\nFind the line break preceding a given position in a string\nReturns position immediately after that line break, or the start of the string\n*/\nexports.findPrecedingLineBreak = function(text,pos) {\n\tvar result = text.lastIndexOf(\"\\n\",pos - 1);\n\tif(result === -1) {\n\t\tresult = 0;\n\t} else {\n\t\tresult++;\n\t\tif(text.charAt(result) === \"\\r\") {\n\t\t\tresult++;\n\t\t}\n\t}\n\treturn result;\n};\n\n/*\nFind the line break following a given position in a string\n*/\nexports.findFollowingLineBreak = function(text,pos) {\n\t// Cut to just past the following line break, or to the end of the text\n\tvar result = text.indexOf(\"\\n\",pos);\n\tif(result === -1) {\n\t\tresult = text.length;\n\t} else {\n\t\tif(text.charAt(result) === \"\\r\") {\n\t\t\tresult++;\n\t\t}\n\t}\n\treturn result;\n};\n\n/*\nReturn the number of keys in an object\n*/\nexports.count = function(object) {\n\treturn Object.keys(object || {}).length;\n};\n\n/*\nCheck if an array is equal by value and by reference.\n*/\nexports.isArrayEqual = function(array1,array2) {\n\tif(array1 === array2) {\n\t\treturn true;\n\t}\n\tarray1 = array1 || [];\n\tarray2 = array2 || [];\n\tif(array1.length !== array2.length) {\n\t\treturn false;\n\t}\n\treturn array1.every(function(value,index) {\n\t\treturn value === array2[index];\n\t});\n};\n\n/*\nDetermine whether an array-item is an object-property\n*/\nexports.hopArray = function(object,array) {\n\tfor(var i=0; i<array.length; i++) {\n\t\tif($tw.utils.hop(object,array[i])) {\n\t\t\treturn true;\n\t\t}\n\t}\n\treturn false;\n};\n\n/*\nPush entries onto an array, removing them first if they already exist in the array\n\tarray: array to modify (assumed to be free of duplicates)\n\tvalue: a single value to push or an array of values to push\n*/\nexports.pushTop = function(array,value) {\n\tvar t,p;\n\tif($tw.utils.isArray(value)) {\n\t\t// Remove any array entries that are duplicated in the new values\n\t\tif(value.length !== 0) {\n\t\t\tif(array.length !== 0) {\n\t\t\t\tif(value.length < array.length) {\n\t\t\t\t\tfor(t=0; t<value.length; t++) {\n\t\t\t\t\t\tp = array.indexOf(value[t]);\n\t\t\t\t\t\tif(p !== -1) {\n\t\t\t\t\t\t\tarray.splice(p,1);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tfor(t=array.length-1; t>=0; t--) {\n\t\t\t\t\t\tp = value.indexOf(array[t]);\n\t\t\t\t\t\tif(p !== -1) {\n\t\t\t\t\t\t\tarray.splice(t,1);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\t// Push the values on top of the main array\n\t\t\tarray.push.apply(array,value);\n\t\t}\n\t} else {\n\t\tp = array.indexOf(value);\n\t\tif(p !== -1) {\n\t\t\tarray.splice(p,1);\n\t\t}\n\t\tarray.push(value);\n\t}\n\treturn array;\n};\n\n/*\nRemove entries from an array\n\tarray: array to modify\n\tvalue: a single value to remove, or an array of values to remove\n*/\nexports.removeArrayEntries = function(array,value) {\n\tvar t,p;\n\tif($tw.utils.isArray(value)) {\n\t\tfor(t=0; t<value.length; t++) {\n\t\t\tp = array.indexOf(value[t]);\n\t\t\tif(p !== -1) {\n\t\t\t\tarray.splice(p,1);\n\t\t\t}\n\t\t}\n\t} else {\n\t\tp = array.indexOf(value);\n\t\tif(p !== -1) {\n\t\t\tarray.splice(p,1);\n\t\t}\n\t}\n};\n\n/*\nCheck whether any members of a hashmap are present in another hashmap\n*/\nexports.checkDependencies = function(dependencies,changes) {\n\tvar hit = false;\n\t$tw.utils.each(changes,function(change,title) {\n\t\tif($tw.utils.hop(dependencies,title)) {\n\t\t\thit = true;\n\t\t}\n\t});\n\treturn hit;\n};\n\nexports.extend = function(object /* [, src] */) {\n\t$tw.utils.each(Array.prototype.slice.call(arguments, 1), function(source) {\n\t\tif(source) {\n\t\t\tfor(var property in source) {\n\t\t\t\tobject[property] = source[property];\n\t\t\t}\n\t\t}\n\t});\n\treturn object;\n};\n\nexports.deepCopy = function(object) {\n\tvar result,t;\n\tif($tw.utils.isArray(object)) {\n\t\t// Copy arrays\n\t\tresult = object.slice(0);\n\t} else if(typeof object === \"object\") {\n\t\tresult = {};\n\t\tfor(t in object) {\n\t\t\tif(object[t] !== undefined) {\n\t\t\t\tresult[t] = $tw.utils.deepCopy(object[t]);\n\t\t\t}\n\t\t}\n\t} else {\n\t\tresult = object;\n\t}\n\treturn result;\n};\n\nexports.extendDeepCopy = function(object,extendedProperties) {\n\tvar result = $tw.utils.deepCopy(object),t;\n\tfor(t in extendedProperties) {\n\t\tif(extendedProperties[t] !== undefined) {\n\t\t\tresult[t] = $tw.utils.deepCopy(extendedProperties[t]);\n\t\t}\n\t}\n\treturn result;\n};\n\nexports.deepFreeze = function deepFreeze(object) {\n\tvar property, key;\n\tif(object) {\n\t\tObject.freeze(object);\n\t\tfor(key in object) {\n\t\t\tproperty = object[key];\n\t\t\tif($tw.utils.hop(object,key) && (typeof property === \"object\") && !Object.isFrozen(property)) {\n\t\t\t\tdeepFreeze(property);\n\t\t\t}\n\t\t}\n\t}\n};\n\nexports.slowInSlowOut = function(t) {\n\treturn (1 - ((Math.cos(t * Math.PI) + 1) / 2));\n};\n\nexports.formatDateString = function(date,template) {\n\tvar result = \"\",\n\t\tt = template,\n\t\tmatches = [\n\t\t\t[/^0hh12/, function() {\n\t\t\t\treturn $tw.utils.pad($tw.utils.getHours12(date));\n\t\t\t}],\n\t\t\t[/^wYYYY/, function() {\n\t\t\t\treturn $tw.utils.getYearForWeekNo(date);\n\t\t\t}],\n\t\t\t[/^hh12/, function() {\n\t\t\t\treturn $tw.utils.getHours12(date);\n\t\t\t}],\n\t\t\t[/^DDth/, function() {\n\t\t\t\treturn date.getDate() + $tw.utils.getDaySuffix(date);\n\t\t\t}],\n\t\t\t[/^YYYY/, function() {\n\t\t\t\treturn date.getFullYear();\n\t\t\t}],\n\t\t\t[/^0hh/, function() {\n\t\t\t\treturn $tw.utils.pad(date.getHours());\n\t\t\t}],\n\t\t\t[/^0mm/, function() {\n\t\t\t\treturn $tw.utils.pad(date.getMinutes());\n\t\t\t}],\n\t\t\t[/^0ss/, function() {\n\t\t\t\treturn $tw.utils.pad(date.getSeconds());\n\t\t\t}],\n\t\t\t[/^0XXX/, function() {\n\t\t\t\treturn $tw.utils.pad(date.getMilliseconds());\n\t\t\t}],\n\t\t\t[/^0DD/, function() {\n\t\t\t\treturn $tw.utils.pad(date.getDate());\n\t\t\t}],\n\t\t\t[/^0MM/, function() {\n\t\t\t\treturn $tw.utils.pad(date.getMonth()+1);\n\t\t\t}],\n\t\t\t[/^0WW/, function() {\n\t\t\t\treturn $tw.utils.pad($tw.utils.getWeek(date));\n\t\t\t}],\n\t\t\t[/^ddd/, function() {\n\t\t\t\treturn $tw.language.getString(\"Date/Short/Day/\" + date.getDay());\n\t\t\t}],\n\t\t\t[/^mmm/, function() {\n\t\t\t\treturn $tw.language.getString(\"Date/Short/Month/\" + (date.getMonth() + 1));\n\t\t\t}],\n\t\t\t[/^DDD/, function() {\n\t\t\t\treturn $tw.language.getString(\"Date/Long/Day/\" + date.getDay());\n\t\t\t}],\n\t\t\t[/^MMM/, function() {\n\t\t\t\treturn $tw.language.getString(\"Date/Long/Month/\" + (date.getMonth() + 1));\n\t\t\t}],\n\t\t\t[/^TZD/, function() {\n\t\t\t\tvar tz = date.getTimezoneOffset(),\n\t\t\t\tatz = Math.abs(tz);\n\t\t\t\treturn (tz < 0 ? '+' : '-') + $tw.utils.pad(Math.floor(atz / 60)) + ':' + $tw.utils.pad(atz % 60);\n\t\t\t}],\n\t\t\t[/^wYY/, function() {\n\t\t\t\treturn $tw.utils.pad($tw.utils.getYearForWeekNo(date) - 2000);\n\t\t\t}],\n\t\t\t[/^[ap]m/, function() {\n\t\t\t\treturn $tw.utils.getAmPm(date).toLowerCase();\n\t\t\t}],\n\t\t\t[/^hh/, function() {\n\t\t\t\treturn date.getHours();\n\t\t\t}],\n\t\t\t[/^mm/, function() {\n\t\t\t\treturn date.getMinutes();\n\t\t\t}],\n\t\t\t[/^ss/, function() {\n\t\t\t\treturn date.getSeconds();\n\t\t\t}],\n\t\t\t[/^XXX/, function() {\n\t\t\t\treturn date.getMilliseconds();\n\t\t\t}],\n\t\t\t[/^[AP]M/, function() {\n\t\t\t\treturn $tw.utils.getAmPm(date).toUpperCase();\n\t\t\t}],\n\t\t\t[/^DD/, function() {\n\t\t\t\treturn date.getDate();\n\t\t\t}],\n\t\t\t[/^MM/, function() {\n\t\t\t\treturn date.getMonth() + 1;\n\t\t\t}],\n\t\t\t[/^WW/, function() {\n\t\t\t\treturn $tw.utils.getWeek(date);\n\t\t\t}],\n\t\t\t[/^YY/, function() {\n\t\t\t\treturn $tw.utils.pad(date.getFullYear() - 2000);\n\t\t\t}]\n\t\t];\n\t// If the user wants everything in UTC, shift the datestamp\n\t// Optimize for format string that essentially means\n\t// 'return raw UTC (tiddlywiki style) date string.'\n\tif(t.indexOf(\"[UTC]\") == 0 ) {\n\t\tif(t == \"[UTC]YYYY0MM0DD0hh0mm0ssXXX\")\n\t\t\treturn $tw.utils.stringifyDate(new Date());\n\t\tvar offset = date.getTimezoneOffset() ; // in minutes\n\t\tdate = new Date(date.getTime()+offset*60*1000) ;\n\t\tt = t.substr(5) ;\n\t}\n\twhile(t.length){\n\t\tvar matchString = \"\";\n\t\t$tw.utils.each(matches, function(m) {\n\t\t\tvar match = m[0].exec(t);\n\t\t\tif(match) {\n\t\t\t\tmatchString = m[1].call();\n\t\t\t\tt = t.substr(match[0].length);\n\t\t\t\treturn false;\n\t\t\t}\n\t\t});\n\t\tif(matchString) {\n\t\t\tresult += matchString;\n\t\t} else {\n\t\t\tresult += t.charAt(0);\n\t\t\tt = t.substr(1);\n\t\t}\n\t}\n\tresult = result.replace(/\\\\(.)/g,\"$1\");\n\treturn result;\n};\n\nexports.getAmPm = function(date) {\n\treturn $tw.language.getString(\"Date/Period/\" + (date.getHours() >= 12 ? \"pm\" : \"am\"));\n};\n\nexports.getDaySuffix = function(date) {\n\treturn $tw.language.getString(\"Date/DaySuffix/\" + date.getDate());\n};\n\nexports.getWeek = function(date) {\n\tvar dt = new Date(date.getTime());\n\tvar d = dt.getDay();\n\tif(d === 0) {\n\t\td = 7; // JavaScript Sun=0, ISO Sun=7\n\t}\n\tdt.setTime(dt.getTime() + (4 - d) * 86400000);// shift day to Thurs of same week to calculate weekNo\n\tvar x = new Date(dt.getFullYear(),0,1);\n\tvar n = Math.floor((dt.getTime() - x.getTime()) / 86400000);\n\treturn Math.floor(n / 7) + 1;\n};\n\nexports.getYearForWeekNo = function(date) {\n\tvar dt = new Date(date.getTime());\n\tvar d = dt.getDay();\n\tif(d === 0) {\n\t\td = 7; // JavaScript Sun=0, ISO Sun=7\n\t}\n\tdt.setTime(dt.getTime() + (4 - d) * 86400000);// shift day to Thurs of same week\n\treturn dt.getFullYear();\n};\n\nexports.getHours12 = function(date) {\n\tvar h = date.getHours();\n\treturn h > 12 ? h-12 : ( h > 0 ? h : 12 );\n};\n\n/*\nConvert a date delta in milliseconds into a string representation of \"23 seconds ago\", \"27 minutes ago\" etc.\n\tdelta: delta in milliseconds\nReturns an object with these members:\n\tdescription: string describing the delta period\n\tupdatePeriod: time in millisecond until the string will be inaccurate\n*/\nexports.getRelativeDate = function(delta) {\n\tvar futurep = false;\n\tif(delta < 0) {\n\t\tdelta = -1 * delta;\n\t\tfuturep = true;\n\t}\n\tvar units = [\n\t\t{name: \"Years\", duration: 365 * 24 * 60 * 60 * 1000},\n\t\t{name: \"Months\", duration: (365/12) * 24 * 60 * 60 * 1000},\n\t\t{name: \"Days\", duration: 24 * 60 * 60 * 1000},\n\t\t{name: \"Hours\", duration: 60 * 60 * 1000},\n\t\t{name: \"Minutes\", duration: 60 * 1000},\n\t\t{name: \"Seconds\", duration: 1000}\n\t];\n\tfor(var t=0; t<units.length; t++) {\n\t\tvar result = Math.floor(delta / units[t].duration);\n\t\tif(result >= 2) {\n\t\t\treturn {\n\t\t\t\tdelta: delta,\n\t\t\t\tdescription: $tw.language.getString(\n\t\t\t\t\t\"RelativeDate/\" + (futurep ? \"Future\" : \"Past\") + \"/\" + units[t].name,\n\t\t\t\t\t{variables:\n\t\t\t\t\t\t{period: result.toString()}\n\t\t\t\t\t}\n\t\t\t\t),\n\t\t\t\tupdatePeriod: units[t].duration\n\t\t\t};\n\t\t}\n\t}\n\treturn {\n\t\tdelta: delta,\n\t\tdescription: $tw.language.getString(\n\t\t\t\"RelativeDate/\" + (futurep ? \"Future\" : \"Past\") + \"/Second\",\n\t\t\t{variables:\n\t\t\t\t{period: \"1\"}\n\t\t\t}\n\t\t),\n\t\tupdatePeriod: 1000\n\t};\n};\n\n// Convert & to \"&\", < to \"<\", > to \">\", \" to \""\"\nexports.htmlEncode = function(s) {\n\tif(s) {\n\t\treturn s.toString().replace(/&/mg,\"&\").replace(/</mg,\"<\").replace(/>/mg,\">\").replace(/\\\"/mg,\""\");\n\t} else {\n\t\treturn \"\";\n\t}\n};\n\n// Converts all HTML entities to their character equivalents\nexports.entityDecode = function(s) {\n\tvar converter = String.fromCodePoint || String.fromCharCode,\n\t\te = s.substr(1,s.length-2), // Strip the & and the ;\n\t\tc;\n\tif(e.charAt(0) === \"#\") {\n\t\tif(e.charAt(1) === \"x\" || e.charAt(1) === \"X\") {\n\t\t\tc = parseInt(e.substr(2),16);\n\t\t} else {\n\t\t\tc = parseInt(e.substr(1),10);\n\t\t}\n\t\tif(isNaN(c)) {\n\t\t\treturn s;\n\t\t} else {\n\t\t\treturn converter(c);\n\t\t}\n\t} else {\n\t\tc = $tw.config.htmlEntities[e];\n\t\tif(c) {\n\t\t\treturn converter(c);\n\t\t} else {\n\t\t\treturn s; // Couldn't convert it as an entity, just return it raw\n\t\t}\n\t}\n};\n\nexports.unescapeLineBreaks = function(s) {\n\treturn s.replace(/\\\\n/mg,\"\\n\").replace(/\\\\b/mg,\" \").replace(/\\\\s/mg,\"\\\\\").replace(/\\r/mg,\"\");\n};\n\n/*\n * Returns an escape sequence for given character. Uses \\x for characters <=\n * 0xFF to save space, \\u for the rest.\n *\n * The code needs to be in sync with th code template in the compilation\n * function for \"action\" nodes.\n */\n// Copied from peg.js, thanks to David Majda\nexports.escape = function(ch) {\n\tvar charCode = ch.charCodeAt(0);\n\tif(charCode <= 0xFF) {\n\t\treturn '\\\\x' + $tw.utils.pad(charCode.toString(16).toUpperCase());\n\t} else {\n\t\treturn '\\\\u' + $tw.utils.pad(charCode.toString(16).toUpperCase(),4);\n\t}\n};\n\n// Turns a string into a legal JavaScript string\n// Copied from peg.js, thanks to David Majda\nexports.stringify = function(s) {\n\t/*\n\t* ECMA-262, 5th ed., 7.8.4: All characters may appear literally in a string\n\t* literal except for the closing quote character, backslash, carriage return,\n\t* line separator, paragraph separator, and line feed. Any character may\n\t* appear in the form of an escape sequence.\n\t*\n\t* For portability, we also escape all non-ASCII characters.\n\t*/\n\treturn (s || \"\")\n\t\t.replace(/\\\\/g, '\\\\\\\\') // backslash\n\t\t.replace(/\"/g, '\\\\\"') // double quote character\n\t\t.replace(/'/g, \"\\\\'\") // single quote character\n\t\t.replace(/\\r/g, '\\\\r') // carriage return\n\t\t.replace(/\\n/g, '\\\\n') // line feed\n\t\t.replace(/[\\x00-\\x1f\\x80-\\uFFFF]/g, exports.escape); // non-ASCII characters\n};\n\n// Turns a string into a legal JSON string\n// Derived from peg.js, thanks to David Majda\nexports.jsonStringify = function(s) {\n\t// See http://www.json.org/\n\treturn (s || \"\")\n\t\t.replace(/\\\\/g, '\\\\\\\\') // backslash\n\t\t.replace(/\"/g, '\\\\\"') // double quote character\n\t\t.replace(/\\r/g, '\\\\r') // carriage return\n\t\t.replace(/\\n/g, '\\\\n') // line feed\n\t\t.replace(/\\x08/g, '\\\\b') // backspace\n\t\t.replace(/\\x0c/g, '\\\\f') // formfeed\n\t\t.replace(/\\t/g, '\\\\t') // tab\n\t\t.replace(/[\\x00-\\x1f\\x80-\\uFFFF]/g,function(s) {\n\t\t\treturn '\\\\u' + $tw.utils.pad(s.charCodeAt(0).toString(16).toUpperCase(),4);\n\t\t}); // non-ASCII characters\n};\n\n/*\nEscape the RegExp special characters with a preceding backslash\n*/\nexports.escapeRegExp = function(s) {\n return s.replace(/[\\-\\/\\\\\\^\\$\\*\\+\\?\\.\\(\\)\\|\\[\\]\\{\\}]/g, '\\\\$&');\n};\n\n// Checks whether a link target is external, i.e. not a tiddler title\nexports.isLinkExternal = function(to) {\n\tvar externalRegExp = /^(?:file|http|https|mailto|ftp|irc|news|data|skype):[^\\s<>{}\\[\\]`|\"\\\\^]+(?:\\/|\\b)/i;\n\treturn externalRegExp.test(to);\n};\n\nexports.nextTick = function(fn) {\n/*global window: false */\n\tif(typeof process === \"undefined\") {\n\t\t// Apparently it would be faster to use postMessage - http://dbaron.org/log/20100309-faster-timeouts\n\t\twindow.setTimeout(fn,4);\n\t} else {\n\t\tprocess.nextTick(fn);\n\t}\n};\n\n/*\nConvert a hyphenated CSS property name into a camel case one\n*/\nexports.unHyphenateCss = function(propName) {\n\treturn propName.replace(/-([a-z])/gi, function(match0,match1) {\n\t\treturn match1.toUpperCase();\n\t});\n};\n\n/*\nConvert a camelcase CSS property name into a dashed one (\"backgroundColor\" --> \"background-color\")\n*/\nexports.hyphenateCss = function(propName) {\n\treturn propName.replace(/([A-Z])/g, function(match0,match1) {\n\t\treturn \"-\" + match1.toLowerCase();\n\t});\n};\n\n/*\nParse a text reference of one of these forms:\n* title\n* !!field\n* title!!field\n* title##index\n* etc\nReturns an object with the following fields, all optional:\n* title: tiddler title\n* field: tiddler field name\n* index: JSON property index\n*/\nexports.parseTextReference = function(textRef) {\n\t// Separate out the title, field name and/or JSON indices\n\tvar reTextRef = /(?:(.*?)!!(.+))|(?:(.*?)##(.+))|(.*)/mg,\n\t\tmatch = reTextRef.exec(textRef),\n\t\tresult = {};\n\tif(match && reTextRef.lastIndex === textRef.length) {\n\t\t// Return the parts\n\t\tif(match[1]) {\n\t\t\tresult.title = match[1];\n\t\t}\n\t\tif(match[2]) {\n\t\t\tresult.field = match[2];\n\t\t}\n\t\tif(match[3]) {\n\t\t\tresult.title = match[3];\n\t\t}\n\t\tif(match[4]) {\n\t\t\tresult.index = match[4];\n\t\t}\n\t\tif(match[5]) {\n\t\t\tresult.title = match[5];\n\t\t}\n\t} else {\n\t\t// If we couldn't parse it\n\t\tresult.title = textRef\n\t}\n\treturn result;\n};\n\n/*\nChecks whether a string is a valid fieldname\n*/\nexports.isValidFieldName = function(name) {\n\tif(!name || typeof name !== \"string\") {\n\t\treturn false;\n\t}\n\tname = name.toLowerCase().trim();\n\tvar fieldValidatorRegEx = /^[a-z0-9\\-\\._]+$/mg;\n\treturn fieldValidatorRegEx.test(name);\n};\n\n/*\nExtract the version number from the meta tag or from the boot file\n*/\n\n// Browser version\nexports.extractVersionInfo = function() {\n\tif($tw.packageInfo) {\n\t\treturn $tw.packageInfo.version;\n\t} else {\n\t\tvar metatags = document.getElementsByTagName(\"meta\");\n\t\tfor(var t=0; t<metatags.length; t++) {\n\t\t\tvar m = metatags[t];\n\t\t\tif(m.name === \"tiddlywiki-version\") {\n\t\t\t\treturn m.content;\n\t\t\t}\n\t\t}\n\t}\n\treturn null;\n};\n\n/*\nGet the animation duration in ms\n*/\nexports.getAnimationDuration = function() {\n\treturn parseInt($tw.wiki.getTiddlerText(\"$:/config/AnimationDuration\",\"400\"),10);\n};\n\n/*\nHash a string to a number\nDerived from http://stackoverflow.com/a/15710692\n*/\nexports.hashString = function(str) {\n\treturn str.split(\"\").reduce(function(a,b) {\n\t\ta = ((a << 5) - a) + b.charCodeAt(0);\n\t\treturn a & a;\n\t},0);\n};\n\n/*\nDecode a base64 string\n*/\nexports.base64Decode = function(string64) {\n\tif($tw.browser) {\n\t\t// TODO\n\t\tthrow \"$tw.utils.base64Decode() doesn't work in the browser\";\n\t} else {\n\t\treturn Buffer.from(string64,\"base64\").toString();\n\t}\n};\n\n/*\nConvert a hashmap into a tiddler dictionary format sequence of name:value pairs\n*/\nexports.makeTiddlerDictionary = function(data) {\n\tvar output = [];\n\tfor(var name in data) {\n\t\toutput.push(name + \": \" + data[name]);\n\t}\n\treturn output.join(\"\\n\");\n};\n\n/*\nHigh resolution microsecond timer for profiling\n*/\nexports.timer = function(base) {\n\tvar m;\n\tif($tw.node) {\n\t\tvar r = process.hrtime();\n\t\tm = r[0] * 1e3 + (r[1] / 1e6);\n\t} else if(window.performance) {\n\t\tm = performance.now();\n\t} else {\n\t\tm = Date.now();\n\t}\n\tif(typeof base !== \"undefined\") {\n\t\tm = m - base;\n\t}\n\treturn m;\n};\n\n/*\nConvert text and content type to a data URI\n*/\nexports.makeDataUri = function(text,type) {\n\ttype = type || \"text/vnd.tiddlywiki\";\n\tvar typeInfo = $tw.config.contentTypeInfo[type] || $tw.config.contentTypeInfo[\"text/plain\"],\n\t\tisBase64 = typeInfo.encoding === \"base64\",\n\t\tparts = [];\n\tparts.push(\"data:\");\n\tparts.push(type);\n\tparts.push(isBase64 ? \";base64\" : \"\");\n\tparts.push(\",\");\n\tparts.push(isBase64 ? text : encodeURIComponent(text));\n\treturn parts.join(\"\");\n};\n\n/*\nUseful for finding out the fully escaped CSS selector equivalent to a given tag. For example:\n\n$tw.utils.tagToCssSelector(\"$:/tags/Stylesheet\") --> tc-tagged-\\%24\\%3A\\%2Ftags\\%2FStylesheet\n*/\nexports.tagToCssSelector = function(tagName) {\n\treturn \"tc-tagged-\" + encodeURIComponent(tagName).replace(/[!\"#$%&'()*+,\\-./:;<=>?@[\\\\\\]^`{\\|}~,]/mg,function(c) {\n\t\treturn \"\\\\\" + c;\n\t});\n};\n\n/*\nIE does not have sign function\n*/\nexports.sign = Math.sign || function(x) {\n\tx = +x; // convert to a number\n\tif (x === 0 || isNaN(x)) {\n\t\treturn x;\n\t}\n\treturn x > 0 ? 1 : -1;\n};\n\n/*\nIE does not have an endsWith function\n*/\nexports.strEndsWith = function(str,ending,position) {\n\tif(str.endsWith) {\n\t\treturn str.endsWith(ending,position);\n\t} else {\n\t\tif (typeof position !== 'number' || !isFinite(position) || Math.floor(position) !== position || position > str.length) {\n\t\t\tposition = str.length;\n\t\t}\n\t\tposition -= ending.length;\n\t\tvar lastIndex = str.indexOf(ending, position);\n\t\treturn lastIndex !== -1 && lastIndex === position;\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/widgets/action-createtiddler.js": {
"title": "$:/core/modules/widgets/action-createtiddler.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/action-createtiddler.js\ntype: application/javascript\nmodule-type: widget\n\nAction widget to create a new tiddler with a unique name and specified fields.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar CreateTiddlerWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nCreateTiddlerWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nCreateTiddlerWidget.prototype.render = function(parent,nextSibling) {\n\tthis.computeAttributes();\n\tthis.execute();\n};\n\n/*\nCompute the internal state of the widget\n*/\nCreateTiddlerWidget.prototype.execute = function() {\n\tthis.actionBaseTitle = this.getAttribute(\"$basetitle\");\n\tthis.actionSaveTitle = this.getAttribute(\"$savetitle\");\n\tthis.actionTimestamp = this.getAttribute(\"$timestamp\",\"yes\") === \"yes\";\n};\n\n/*\nRefresh the widget by ensuring our attributes are up to date\n*/\nCreateTiddlerWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif($tw.utils.count(changedAttributes) > 0) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\n/*\nInvoke the action associated with this widget\n*/\nCreateTiddlerWidget.prototype.invokeAction = function(triggeringWidget,event) {\n\tvar title = this.wiki.generateNewTitle(this.actionBaseTitle),\n\t\tfields = {},\n\t\tcreationFields,\n\t\tmodificationFields;\n\t$tw.utils.each(this.attributes,function(attribute,name) {\n\t\tif(name.charAt(0) !== \"$\") {\n\t\t\tfields[name] = attribute;\n\t\t}\n\t});\n\tif(this.actionTimestamp) {\n\t\tcreationFields = this.wiki.getCreationFields();\n\t\tmodificationFields = this.wiki.getModificationFields();\n\t}\n\tvar tiddler = this.wiki.addTiddler(new $tw.Tiddler(creationFields,fields,modificationFields,{title: title}));\n\tif(this.actionSaveTitle) {\n\t\tthis.wiki.setTextReference(this.actionSaveTitle,title,this.getVariable(\"currentTiddler\"));\n\t}\n\treturn true; // Action was invoked\n};\n\nexports[\"action-createtiddler\"] = CreateTiddlerWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/action-deletefield.js": {
"title": "$:/core/modules/widgets/action-deletefield.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/action-deletefield.js\ntype: application/javascript\nmodule-type: widget\n\nAction widget to delete fields of a tiddler.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar DeleteFieldWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nDeleteFieldWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nDeleteFieldWidget.prototype.render = function(parent,nextSibling) {\n\tthis.computeAttributes();\n\tthis.execute();\n};\n\n/*\nCompute the internal state of the widget\n*/\nDeleteFieldWidget.prototype.execute = function() {\n\tthis.actionTiddler = this.getAttribute(\"$tiddler\",this.getVariable(\"currentTiddler\"));\n\tthis.actionField = this.getAttribute(\"$field\");\n};\n\n/*\nRefresh the widget by ensuring our attributes are up to date\n*/\nDeleteFieldWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes[\"$tiddler\"]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\n/*\nInvoke the action associated with this widget\n*/\nDeleteFieldWidget.prototype.invokeAction = function(triggeringWidget,event) {\n\tvar self = this,\n\t\ttiddler = this.wiki.getTiddler(self.actionTiddler),\n\t\tremoveFields = {},\n\t\thasChanged = false;\n\tif(this.actionField) {\n\t\tremoveFields[this.actionField] = undefined;\n\t\tif(this.actionField in tiddler.fields) {\n\t\t\thasChanged = true;\n\t\t}\n\t}\n\tif(tiddler) {\n\t\t$tw.utils.each(this.attributes,function(attribute,name) {\n\t\t\tif(name.charAt(0) !== \"$\" && name !== \"title\") {\n\t\t\t\tremoveFields[name] = undefined;\n\t\t\t\thasChanged = true;\n\t\t\t}\n\t\t});\n\t\tif(hasChanged) {\n\t\t\tthis.wiki.addTiddler(new $tw.Tiddler(this.wiki.getCreationFields(),tiddler,removeFields,this.wiki.getModificationFields()));\t\t\t\n\t\t}\n\t}\n\treturn true; // Action was invoked\n};\n\nexports[\"action-deletefield\"] = DeleteFieldWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/action-deletetiddler.js": {
"title": "$:/core/modules/widgets/action-deletetiddler.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/action-deletetiddler.js\ntype: application/javascript\nmodule-type: widget\n\nAction widget to delete a tiddler.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar DeleteTiddlerWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nDeleteTiddlerWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nDeleteTiddlerWidget.prototype.render = function(parent,nextSibling) {\n\tthis.computeAttributes();\n\tthis.execute();\n};\n\n/*\nCompute the internal state of the widget\n*/\nDeleteTiddlerWidget.prototype.execute = function() {\n\tthis.actionFilter = this.getAttribute(\"$filter\");\n\tthis.actionTiddler = this.getAttribute(\"$tiddler\");\n};\n\n/*\nRefresh the widget by ensuring our attributes are up to date\n*/\nDeleteTiddlerWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes[\"$filter\"] || changedAttributes[\"$tiddler\"]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\n/*\nInvoke the action associated with this widget\n*/\nDeleteTiddlerWidget.prototype.invokeAction = function(triggeringWidget,event) {\n\tvar tiddlers = [];\n\tif(this.actionFilter) {\n\t\ttiddlers = this.wiki.filterTiddlers(this.actionFilter,this);\n\t}\n\tif(this.actionTiddler) {\n\t\ttiddlers.push(this.actionTiddler);\n\t}\n\tfor(var t=0; t<tiddlers.length; t++) {\n\t\tthis.wiki.deleteTiddler(tiddlers[t]);\n\t}\n\treturn true; // Action was invoked\n};\n\nexports[\"action-deletetiddler\"] = DeleteTiddlerWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/action-listops.js": {
"title": "$:/core/modules/widgets/action-listops.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/action-listops.js\ntype: application/javascript\nmodule-type: widget\n\nAction widget to apply list operations to any tiddler field (defaults to the 'list' field of the current tiddler)\n\n\\*/\n(function() {\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\nvar ActionListopsWidget = function(parseTreeNode, options) {\n\tthis.initialise(parseTreeNode, options);\n};\n/**\n * Inherit from the base widget class\n */\nActionListopsWidget.prototype = new Widget();\n/**\n * Render this widget into the DOM\n */\nActionListopsWidget.prototype.render = function(parent, nextSibling) {\n\tthis.computeAttributes();\n\tthis.execute();\n};\n/**\n * Compute the internal state of the widget\n */\nActionListopsWidget.prototype.execute = function() {\n\t// Get our parameters\n\tthis.target = this.getAttribute(\"$tiddler\", this.getVariable(\n\t\t\"currentTiddler\"));\n\tthis.filter = this.getAttribute(\"$filter\");\n\tthis.subfilter = this.getAttribute(\"$subfilter\");\n\tthis.listField = this.getAttribute(\"$field\", \"list\");\n\tthis.listIndex = this.getAttribute(\"$index\");\n\tthis.filtertags = this.getAttribute(\"$tags\");\n};\n/**\n * \tRefresh the widget by ensuring our attributes are up to date\n */\nActionListopsWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.$tiddler || changedAttributes.$filter ||\n\t\tchangedAttributes.$subfilter || changedAttributes.$field ||\n\t\tchangedAttributes.$index || changedAttributes.$tags) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n/**\n * \tInvoke the action associated with this widget\n */\nActionListopsWidget.prototype.invokeAction = function(triggeringWidget,\n\tevent) {\n\t//Apply the specified filters to the lists\n\tvar field = this.listField,\n\t\tindex,\n\t\ttype = \"!!\",\n\t\tlist = this.listField;\n\tif(this.listIndex) {\n\t\tfield = undefined;\n\t\tindex = this.listIndex;\n\t\ttype = \"##\";\n\t\tlist = this.listIndex;\n\t}\n\tif(this.filter) {\n\t\tthis.wiki.setText(this.target, field, index, $tw.utils.stringifyList(\n\t\t\tthis.wiki\n\t\t\t.filterTiddlers(this.filter, this)));\n\t}\n\tif(this.subfilter) {\n\t\tvar subfilter = \"[list[\" + this.target + type + list + \"]] \" + this.subfilter;\n\t\tthis.wiki.setText(this.target, field, index, $tw.utils.stringifyList(\n\t\t\tthis.wiki\n\t\t\t.filterTiddlers(subfilter, this)));\n\t}\n\tif(this.filtertags) {\n\t\tvar tiddler = this.wiki.getTiddler(this.target),\n\t\t\toldtags = tiddler ? (tiddler.fields.tags || []).slice(0) : [],\n\t\t\ttagfilter = \"[list[\" + this.target + \"!!tags]] \" + this.filtertags,\n\t\t\tnewtags = this.wiki.filterTiddlers(tagfilter,this);\n\t\tif($tw.utils.stringifyList(oldtags.sort()) !== $tw.utils.stringifyList(newtags.sort())) {\n\t\t\tthis.wiki.setText(this.target,\"tags\",undefined,$tw.utils.stringifyList(newtags));\t\t\t\n\t\t}\n\t}\n\treturn true; // Action was invoked\n};\n\nexports[\"action-listops\"] = ActionListopsWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/action-navigate.js": {
"title": "$:/core/modules/widgets/action-navigate.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/action-navigate.js\ntype: application/javascript\nmodule-type: widget\n\nAction widget to navigate to a tiddler\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar NavigateWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nNavigateWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nNavigateWidget.prototype.render = function(parent,nextSibling) {\n\tthis.computeAttributes();\n\tthis.execute();\n};\n\n/*\nCompute the internal state of the widget\n*/\nNavigateWidget.prototype.execute = function() {\n\tthis.actionTo = this.getAttribute(\"$to\");\n\tthis.actionScroll = this.getAttribute(\"$scroll\");\n};\n\n/*\nRefresh the widget by ensuring our attributes are up to date\n*/\nNavigateWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes[\"$to\"] || changedAttributes[\"$scroll\"]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\n/*\nInvoke the action associated with this widget\n*/\nNavigateWidget.prototype.invokeAction = function(triggeringWidget,event) {\n\tevent = event || {};\n\tvar bounds = triggeringWidget && triggeringWidget.getBoundingClientRect && triggeringWidget.getBoundingClientRect(),\n\t\tsuppressNavigation = event.metaKey || event.ctrlKey || (event.button === 1);\n\tif(this.actionScroll === \"yes\") {\n\t\tsuppressNavigation = false;\n\t} else if(this.actionScroll === \"no\") {\n\t\tsuppressNavigation = true;\n\t}\n\tthis.dispatchEvent({\n\t\ttype: \"tm-navigate\",\n\t\tnavigateTo: this.actionTo === undefined ? this.getVariable(\"currentTiddler\") : this.actionTo,\n\t\tnavigateFromTitle: this.getVariable(\"storyTiddler\"),\n\t\tnavigateFromNode: triggeringWidget,\n\t\tnavigateFromClientRect: bounds && { top: bounds.top, left: bounds.left, width: bounds.width, right: bounds.right, bottom: bounds.bottom, height: bounds.height\n\t\t},\n\t\tnavigateSuppressNavigation: suppressNavigation\n\t});\n\treturn true; // Action was invoked\n};\n\nexports[\"action-navigate\"] = NavigateWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/action-sendmessage.js": {
"title": "$:/core/modules/widgets/action-sendmessage.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/action-sendmessage.js\ntype: application/javascript\nmodule-type: widget\n\nAction widget to send a message\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar SendMessageWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nSendMessageWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nSendMessageWidget.prototype.render = function(parent,nextSibling) {\n\tthis.computeAttributes();\n\tthis.execute();\n};\n\n/*\nCompute the internal state of the widget\n*/\nSendMessageWidget.prototype.execute = function() {\n\tthis.actionMessage = this.getAttribute(\"$message\");\n\tthis.actionParam = this.getAttribute(\"$param\");\n\tthis.actionName = this.getAttribute(\"$name\");\n\tthis.actionValue = this.getAttribute(\"$value\",\"\");\n};\n\n/*\nRefresh the widget by ensuring our attributes are up to date\n*/\nSendMessageWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(Object.keys(changedAttributes).length) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\n/*\nInvoke the action associated with this widget\n*/\nSendMessageWidget.prototype.invokeAction = function(triggeringWidget,event) {\n\t// Get the string parameter\n\tvar param = this.actionParam;\n\t// Assemble the attributes as a hashmap\n\tvar paramObject = Object.create(null);\n\tvar count = 0;\n\t$tw.utils.each(this.attributes,function(attribute,name) {\n\t\tif(name.charAt(0) !== \"$\") {\n\t\t\tparamObject[name] = attribute;\n\t\t\tcount++;\n\t\t}\n\t});\n\t// Add name/value pair if present\n\tif(this.actionName) {\n\t\tparamObject[this.actionName] = this.actionValue;\n\t}\n\t// Dispatch the message\n\tthis.dispatchEvent({\n\t\ttype: this.actionMessage,\n\t\tparam: param,\n\t\tparamObject: paramObject,\n\t\ttiddlerTitle: this.getVariable(\"currentTiddler\"),\n\t\tnavigateFromTitle: this.getVariable(\"storyTiddler\"),\n\t\tevent: event\n\t});\n\treturn true; // Action was invoked\n};\n\nexports[\"action-sendmessage\"] = SendMessageWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/action-setfield.js": {
"title": "$:/core/modules/widgets/action-setfield.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/action-setfield.js\ntype: application/javascript\nmodule-type: widget\n\nAction widget to set a single field or index on a tiddler.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar SetFieldWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nSetFieldWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nSetFieldWidget.prototype.render = function(parent,nextSibling) {\n\tthis.computeAttributes();\n\tthis.execute();\n};\n\n/*\nCompute the internal state of the widget\n*/\nSetFieldWidget.prototype.execute = function() {\n\tthis.actionTiddler = this.getAttribute(\"$tiddler\",this.getVariable(\"currentTiddler\"));\n\tthis.actionField = this.getAttribute(\"$field\");\n\tthis.actionIndex = this.getAttribute(\"$index\");\n\tthis.actionValue = this.getAttribute(\"$value\");\n\tthis.actionTimestamp = this.getAttribute(\"$timestamp\",\"yes\") === \"yes\";\n};\n\n/*\nRefresh the widget by ensuring our attributes are up to date\n*/\nSetFieldWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes[\"$tiddler\"] || changedAttributes[\"$field\"] || changedAttributes[\"$index\"] || changedAttributes[\"$value\"]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\n/*\nInvoke the action associated with this widget\n*/\nSetFieldWidget.prototype.invokeAction = function(triggeringWidget,event) {\n\tvar self = this,\n\t\toptions = {};\n\toptions.suppressTimestamp = !this.actionTimestamp;\n\tif((typeof this.actionField == \"string\") || (typeof this.actionIndex == \"string\") || (typeof this.actionValue == \"string\")) {\n\t\tthis.wiki.setText(this.actionTiddler,this.actionField,this.actionIndex,this.actionValue,options);\n\t}\n\t$tw.utils.each(this.attributes,function(attribute,name) {\n\t\tif(name.charAt(0) !== \"$\") {\n\t\t\tself.wiki.setText(self.actionTiddler,name,undefined,attribute,options);\n\t\t}\n\t});\n\treturn true; // Action was invoked\n};\n\nexports[\"action-setfield\"] = SetFieldWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/browse.js": {
"title": "$:/core/modules/widgets/browse.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/browse.js\ntype: application/javascript\nmodule-type: widget\n\nBrowse widget for browsing for files to import\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar BrowseWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nBrowseWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nBrowseWidget.prototype.render = function(parent,nextSibling) {\n\tvar self = this;\n\t// Remember parent\n\tthis.parentDomNode = parent;\n\t// Compute attributes and execute state\n\tthis.computeAttributes();\n\tthis.execute();\n\t// Create element\n\tvar domNode = this.document.createElement(\"input\");\n\tdomNode.setAttribute(\"type\",\"file\");\n\tif(this.browseMultiple) {\n\t\tdomNode.setAttribute(\"multiple\",\"multiple\");\n\t}\n\tif(this.tooltip) {\n\t\tdomNode.setAttribute(\"title\",this.tooltip);\n\t}\n\t// Nw.js supports \"nwsaveas\" to force a \"save as\" dialogue that allows a new or existing file to be selected\n\tif(this.nwsaveas) {\n\t\tdomNode.setAttribute(\"nwsaveas\",this.nwsaveas);\n\t}\n\t// Nw.js supports \"webkitdirectory\" and \"nwdirectory\" to allow a directory to be selected\n\tif(this.webkitdirectory) {\n\t\tdomNode.setAttribute(\"webkitdirectory\",this.webkitdirectory);\n\t}\n\tif(this.nwdirectory) {\n\t\tdomNode.setAttribute(\"nwdirectory\",this.nwdirectory);\n\t}\n\t// Add a click event handler\n\tdomNode.addEventListener(\"change\",function (event) {\n\t\tif(self.message) {\n\t\t\tself.dispatchEvent({type: self.message, param: self.param, files: event.target.files});\n\t\t} else {\n\t\t\tself.wiki.readFiles(event.target.files,{\n\t\t\t\tcallback: function(tiddlerFieldsArray) {\n\t\t\t\t\tself.dispatchEvent({type: \"tm-import-tiddlers\", param: JSON.stringify(tiddlerFieldsArray)});\n\t\t\t\t},\n\t\t\t\tdeserializer: self.deserializer\n\t\t\t});\n\t\t}\n\t\treturn false;\n\t},false);\n\t// Insert element\n\tparent.insertBefore(domNode,nextSibling);\n\tthis.renderChildren(domNode,null);\n\tthis.domNodes.push(domNode);\n};\n\n/*\nCompute the internal state of the widget\n*/\nBrowseWidget.prototype.execute = function() {\n\tthis.browseMultiple = this.getAttribute(\"multiple\");\n\tthis.deserializer = this.getAttribute(\"deserializer\");\n\tthis.message = this.getAttribute(\"message\");\n\tthis.param = this.getAttribute(\"param\");\n\tthis.tooltip = this.getAttribute(\"tooltip\");\n\tthis.nwsaveas = this.getAttribute(\"nwsaveas\");\n\tthis.webkitdirectory = this.getAttribute(\"webkitdirectory\");\n\tthis.nwdirectory = this.getAttribute(\"nwdirectory\");\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nBrowseWidget.prototype.refresh = function(changedTiddlers) {\n\treturn false;\n};\n\nexports.browse = BrowseWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/button.js": {
"title": "$:/core/modules/widgets/button.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/button.js\ntype: application/javascript\nmodule-type: widget\n\nButton widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar ButtonWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nButtonWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nButtonWidget.prototype.render = function(parent,nextSibling) {\n\tvar self = this;\n\t// Remember parent\n\tthis.parentDomNode = parent;\n\t// Compute attributes and execute state\n\tthis.computeAttributes();\n\tthis.execute();\n\t// Create element\n\tvar tag = \"button\";\n\tif(this.buttonTag && $tw.config.htmlUnsafeElements.indexOf(this.buttonTag) === -1) {\n\t\ttag = this.buttonTag;\n\t}\n\tvar domNode = this.document.createElement(tag);\n\t// Assign classes\n\tvar classes = this[\"class\"].split(\" \") || [],\n\t\tisPoppedUp = (this.popup || this.popupTitle) && this.isPoppedUp();\n\tif(this.selectedClass) {\n\t\tif((this.set || this.setTitle) && this.setTo && this.isSelected()) {\n\t\t\t$tw.utils.pushTop(classes,this.selectedClass.split(\" \"));\n\t\t}\n\t\tif(isPoppedUp) {\n\t\t\t$tw.utils.pushTop(classes,this.selectedClass.split(\" \"));\n\t\t}\n\t}\n\tif(isPoppedUp) {\n\t\t$tw.utils.pushTop(classes,\"tc-popup-handle\");\n\t}\n\tdomNode.className = classes.join(\" \");\n\t// Assign other attributes\n\tif(this.style) {\n\t\tdomNode.setAttribute(\"style\",this.style);\n\t}\n\tif(this.tooltip) {\n\t\tdomNode.setAttribute(\"title\",this.tooltip);\n\t}\n\tif(this[\"aria-label\"]) {\n\t\tdomNode.setAttribute(\"aria-label\",this[\"aria-label\"]);\n\t}\n\t// Add a click event handler\n\tdomNode.addEventListener(\"click\",function (event) {\n\t\tvar handled = false;\n\t\tif(self.invokeActions(self,event)) {\n\t\t\thandled = true;\n\t\t}\n\t\tif(self.to) {\n\t\t\tself.navigateTo(event);\n\t\t\thandled = true;\n\t\t}\n\t\tif(self.message) {\n\t\t\tself.dispatchMessage(event);\n\t\t\thandled = true;\n\t\t}\n\t\tif(self.popup || self.popupTitle) {\n\t\t\tself.triggerPopup(event);\n\t\t\thandled = true;\n\t\t}\n\t\tif(self.set || self.setTitle) {\n\t\t\tself.setTiddler();\n\t\t\thandled = true;\n\t\t}\n\t\tif(self.actions) {\n\t\t\tself.invokeActionString(self.actions,self,event);\n\t\t}\n\t\tif(handled) {\n\t\t\tevent.preventDefault();\n\t\t\tevent.stopPropagation();\n\t\t}\n\t\treturn handled;\n\t},false);\n\t// Make it draggable if required\n\tif(this.dragTiddler || this.dragFilter) {\n\t\t$tw.utils.makeDraggable({\n\t\t\tdomNode: domNode,\n\t\t\tdragTiddlerFn: function() {return self.dragTiddler;},\n\t\t\tdragFilterFn: function() {return self.dragFilter;},\n\t\t\twidget: this\n\t\t});\n\t}\n\t// Insert element\n\tparent.insertBefore(domNode,nextSibling);\n\tthis.renderChildren(domNode,null);\n\tthis.domNodes.push(domNode);\n};\n\n/*\nWe don't allow actions to propagate because we trigger actions ourselves\n*/\nButtonWidget.prototype.allowActionPropagation = function() {\n\treturn false;\n};\n\nButtonWidget.prototype.getBoundingClientRect = function() {\n\treturn this.domNodes[0].getBoundingClientRect();\n};\n\nButtonWidget.prototype.isSelected = function() {\n return this.setTitle ? (this.setField ? this.wiki.getTiddler(this.setTitle).getFieldString(this.setField) === this.setTo :\n\t\t(this.setIndex ? this.wiki.extractTiddlerDataItem(this.setTitle,this.setIndex) === this.setTo :\n\t\t\tthis.wiki.getTiddlerText(this.setTitle))) || this.defaultSetValue || this.getVariable(\"currentTiddler\") :\n\t\tthis.wiki.getTextReference(this.set,this.defaultSetValue,this.getVariable(\"currentTiddler\")) === this.setTo;\n};\n\nButtonWidget.prototype.isPoppedUp = function() {\n\tvar tiddler = this.popupTitle ? this.wiki.getTiddler(this.popupTitle) : this.wiki.getTiddler(this.popup);\n\tvar result = tiddler && tiddler.fields.text ? $tw.popup.readPopupState(tiddler.fields.text) : false;\n\treturn result;\n};\n\nButtonWidget.prototype.navigateTo = function(event) {\n\tvar bounds = this.getBoundingClientRect();\n\tthis.dispatchEvent({\n\t\ttype: \"tm-navigate\",\n\t\tnavigateTo: this.to,\n\t\tnavigateFromTitle: this.getVariable(\"storyTiddler\"),\n\t\tnavigateFromNode: this,\n\t\tnavigateFromClientRect: { top: bounds.top, left: bounds.left, width: bounds.width, right: bounds.right, bottom: bounds.bottom, height: bounds.height\n\t\t},\n\t\tnavigateSuppressNavigation: event.metaKey || event.ctrlKey || (event.button === 1),\n\t\tevent: event\n\t});\n};\n\nButtonWidget.prototype.dispatchMessage = function(event) {\n\tthis.dispatchEvent({type: this.message, param: this.param, tiddlerTitle: this.getVariable(\"currentTiddler\"), event: event});\n};\n\nButtonWidget.prototype.triggerPopup = function(event) {\n\tif(this.popupTitle) {\n\t\t$tw.popup.triggerPopup({\n\t\t\tdomNode: this.domNodes[0],\n\t\t\ttitle: this.popupTitle,\n\t\t\twiki: this.wiki,\n\t\t\tnoStateReference: true\n\t\t});\n\t} else {\n\t\t$tw.popup.triggerPopup({\n\t\t\tdomNode: this.domNodes[0],\n\t\t\ttitle: this.popup,\n\t\t\twiki: this.wiki\n\t\t});\n\t}\n};\n\nButtonWidget.prototype.setTiddler = function() {\n\tif(this.setTitle) {\n\t\tthis.setField ? this.wiki.setText(this.setTitle,this.setField,undefined,this.setTo) :\n\t\t\t\t(this.setIndex ? this.wiki.setText(this.setTitle,undefined,this.setIndex,this.setTo) :\n\t\t\t\tthis.wiki.setText(this.setTitle,\"text\",undefined,this.setTo));\n\t} else {\n\t\tthis.wiki.setTextReference(this.set,this.setTo,this.getVariable(\"currentTiddler\"));\n\t}\n};\n\n/*\nCompute the internal state of the widget\n*/\nButtonWidget.prototype.execute = function() {\n\t// Get attributes\n\tthis.actions = this.getAttribute(\"actions\");\n\tthis.to = this.getAttribute(\"to\");\n\tthis.message = this.getAttribute(\"message\");\n\tthis.param = this.getAttribute(\"param\");\n\tthis.set = this.getAttribute(\"set\");\n\tthis.setTo = this.getAttribute(\"setTo\");\n\tthis.popup = this.getAttribute(\"popup\");\n\tthis.hover = this.getAttribute(\"hover\");\n\tthis[\"class\"] = this.getAttribute(\"class\",\"\");\n\tthis[\"aria-label\"] = this.getAttribute(\"aria-label\");\n\tthis.tooltip = this.getAttribute(\"tooltip\");\n\tthis.style = this.getAttribute(\"style\");\n\tthis.selectedClass = this.getAttribute(\"selectedClass\");\n\tthis.defaultSetValue = this.getAttribute(\"default\",\"\");\n\tthis.buttonTag = this.getAttribute(\"tag\");\n\tthis.dragTiddler = this.getAttribute(\"dragTiddler\");\n\tthis.dragFilter = this.getAttribute(\"dragFilter\");\n\tthis.setTitle = this.getAttribute(\"setTitle\");\n\tthis.setField = this.getAttribute(\"setField\");\n\tthis.setIndex = this.getAttribute(\"setIndex\");\n\tthis.popupTitle = this.getAttribute(\"popupTitle\");\n\t// Make child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nButtonWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.to || changedAttributes.message || changedAttributes.param || changedAttributes.set || changedAttributes.setTo || changedAttributes.popup || changedAttributes.hover || changedAttributes[\"class\"] || changedAttributes.selectedClass || changedAttributes.style || changedAttributes.dragFilter || changedAttributes.dragTiddler || (this.set && changedTiddlers[this.set]) || (this.popup && changedTiddlers[this.popup]) || (this.popupTitle && changedTiddlers[this.popupTitle]) || changedAttributes.setTitle || changedAttributes.setField || changedAttributes.setIndex || changedAttributes.popupTitle) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\nexports.button = ButtonWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/checkbox.js": {
"title": "$:/core/modules/widgets/checkbox.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/checkbox.js\ntype: application/javascript\nmodule-type: widget\n\nCheckbox widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar CheckboxWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nCheckboxWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nCheckboxWidget.prototype.render = function(parent,nextSibling) {\n\t// Save the parent dom node\n\tthis.parentDomNode = parent;\n\t// Compute our attributes\n\tthis.computeAttributes();\n\t// Execute our logic\n\tthis.execute();\n\t// Create our elements\n\tthis.labelDomNode = this.document.createElement(\"label\");\n\tthis.labelDomNode.setAttribute(\"class\",this.checkboxClass);\n\tthis.inputDomNode = this.document.createElement(\"input\");\n\tthis.inputDomNode.setAttribute(\"type\",\"checkbox\");\n\tif(this.getValue()) {\n\t\tthis.inputDomNode.setAttribute(\"checked\",\"true\");\n\t}\n\tthis.labelDomNode.appendChild(this.inputDomNode);\n\tthis.spanDomNode = this.document.createElement(\"span\");\n\tthis.labelDomNode.appendChild(this.spanDomNode);\n\t// Add a click event handler\n\t$tw.utils.addEventListeners(this.inputDomNode,[\n\t\t{name: \"change\", handlerObject: this, handlerMethod: \"handleChangeEvent\"}\n\t]);\n\t// Insert the label into the DOM and render any children\n\tparent.insertBefore(this.labelDomNode,nextSibling);\n\tthis.renderChildren(this.spanDomNode,null);\n\tthis.domNodes.push(this.labelDomNode);\n};\n\nCheckboxWidget.prototype.getValue = function() {\n\tvar tiddler = this.wiki.getTiddler(this.checkboxTitle);\n\tif(tiddler) {\n\t\tif(this.checkboxTag) {\n\t\t\tif(this.checkboxInvertTag) {\n\t\t\t\treturn !tiddler.hasTag(this.checkboxTag);\n\t\t\t} else {\n\t\t\t\treturn tiddler.hasTag(this.checkboxTag);\n\t\t\t}\n\t\t}\n\t\tif(this.checkboxField) {\n\t\t\tvar value;\n\t\t\tif($tw.utils.hop(tiddler.fields,this.checkboxField)) {\n\t\t\t\tvalue = tiddler.fields[this.checkboxField] || \"\";\n\t\t\t} else {\n\t\t\t\tvalue = this.checkboxDefault || \"\";\n\t\t\t}\n\t\t\tif(value === this.checkboxChecked) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t\tif(value === this.checkboxUnchecked) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\t\tif(this.checkboxIndex) {\n\t\t\tvar value = this.wiki.extractTiddlerDataItem(tiddler,this.checkboxIndex,this.checkboxDefault || \"\");\n\t\t\tif(value === this.checkboxChecked) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t\tif(value === this.checkboxUnchecked) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\t} else {\n\t\tif(this.checkboxTag) {\n\t\t\treturn false;\n\t\t}\n\t\tif(this.checkboxField) {\n\t\t\tif(this.checkboxDefault === this.checkboxChecked) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t\tif(this.checkboxDefault === this.checkboxUnchecked) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\t}\n\treturn false;\n};\n\nCheckboxWidget.prototype.handleChangeEvent = function(event) {\n\tvar checked = this.inputDomNode.checked,\n\t\ttiddler = this.wiki.getTiddler(this.checkboxTitle),\n\t\tfallbackFields = {text: \"\"},\n\t\tnewFields = {title: this.checkboxTitle},\n\t\thasChanged = false,\n\t\ttagCheck = false,\n\t\thasTag = tiddler && tiddler.hasTag(this.checkboxTag),\n\t\tvalue = checked ? this.checkboxChecked : this.checkboxUnchecked;\n\tif(this.checkboxTag && this.checkboxInvertTag === \"yes\") {\n\t\ttagCheck = hasTag === checked;\n\t} else {\n\t\ttagCheck = hasTag !== checked;\n\t}\n\t// Set the tag if specified\n\tif(this.checkboxTag && (!tiddler || tagCheck)) {\n\t\tnewFields.tags = tiddler ? (tiddler.fields.tags || []).slice(0) : [];\n\t\tvar pos = newFields.tags.indexOf(this.checkboxTag);\n\t\tif(pos !== -1) {\n\t\t\tnewFields.tags.splice(pos,1);\n\t\t}\n\t\tif(this.checkboxInvertTag === \"yes\" && !checked) {\n\t\t\tnewFields.tags.push(this.checkboxTag);\n\t\t} else if(this.checkboxInvertTag !== \"yes\" && checked) {\n\t\t\tnewFields.tags.push(this.checkboxTag);\n\t\t}\n\t\thasChanged = true;\n\t}\n\t// Set the field if specified\n\tif(this.checkboxField) {\n\t\tif(!tiddler || tiddler.fields[this.checkboxField] !== value) {\n\t\t\tnewFields[this.checkboxField] = value;\n\t\t\thasChanged = true;\n\t\t}\n\t}\n\t// Set the index if specified\n\tif(this.checkboxIndex) {\n\t\tvar indexValue = this.wiki.extractTiddlerDataItem(this.checkboxTitle,this.checkboxIndex);\n\t\tif(!tiddler || indexValue !== value) {\n\t\t\thasChanged = true;\n\t\t}\n\t}\n\tif(hasChanged) {\n\t\tif(this.checkboxIndex) {\n\t\t\tthis.wiki.setText(this.checkboxTitle,\"\",this.checkboxIndex,value);\n\t\t} else {\n\t\t\tthis.wiki.addTiddler(new $tw.Tiddler(this.wiki.getCreationFields(),fallbackFields,tiddler,newFields,this.wiki.getModificationFields()));\n\t\t}\n\t}\n\t// Trigger actions\n\tif(this.checkboxActions) {\n\t\tthis.invokeActionString(this.checkboxActions,this,event);\n\t}\n\tif(this.checkboxUncheckActions && !checked) {\n\t\tthis.invokeActionString(this.checkboxUncheckActions,this,event);\n\t}\n};\n\n/*\nCompute the internal state of the widget\n*/\nCheckboxWidget.prototype.execute = function() {\n\t// Get the parameters from the attributes\n\tthis.checkboxActions = this.getAttribute(\"actions\");\n\tthis.checkboxUncheckActions = this.getAttribute(\"uncheckactions\");\n\tthis.checkboxTitle = this.getAttribute(\"tiddler\",this.getVariable(\"currentTiddler\"));\n\tthis.checkboxTag = this.getAttribute(\"tag\");\n\tthis.checkboxField = this.getAttribute(\"field\");\n\tthis.checkboxIndex = this.getAttribute(\"index\");\n\tthis.checkboxChecked = this.getAttribute(\"checked\");\n\tthis.checkboxUnchecked = this.getAttribute(\"unchecked\");\n\tthis.checkboxDefault = this.getAttribute(\"default\");\n\tthis.checkboxClass = this.getAttribute(\"class\",\"\");\n\tthis.checkboxInvertTag = this.getAttribute(\"invertTag\",\"\");\n\t// Make the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nCheckboxWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.tiddler || changedAttributes.tag || changedAttributes.invertTag || changedAttributes.field || changedAttributes.index || changedAttributes.checked || changedAttributes.unchecked || changedAttributes[\"default\"] || changedAttributes[\"class\"]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\tvar refreshed = false;\n\t\tif(changedTiddlers[this.checkboxTitle]) {\n\t\t\tthis.inputDomNode.checked = this.getValue();\n\t\t\trefreshed = true;\n\t\t}\n\t\treturn this.refreshChildren(changedTiddlers) || refreshed;\n\t}\n};\n\nexports.checkbox = CheckboxWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/codeblock.js": {
"title": "$:/core/modules/widgets/codeblock.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/codeblock.js\ntype: application/javascript\nmodule-type: widget\n\nCode block node widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar CodeBlockWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nCodeBlockWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nCodeBlockWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tvar codeNode = this.document.createElement(\"code\"),\n\t\tdomNode = this.document.createElement(\"pre\");\n\tcodeNode.appendChild(this.document.createTextNode(this.getAttribute(\"code\")));\n\tdomNode.appendChild(codeNode);\n\tparent.insertBefore(domNode,nextSibling);\n\tthis.domNodes.push(domNode);\n\tif(this.postRender) {\n\t\tthis.postRender();\n\t}\n};\n\n/*\nCompute the internal state of the widget\n*/\nCodeBlockWidget.prototype.execute = function() {\n\tthis.language = this.getAttribute(\"language\");\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nCodeBlockWidget.prototype.refresh = function(changedTiddlers) {\n\treturn false;\n};\n\nexports.codeblock = CodeBlockWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/count.js": {
"title": "$:/core/modules/widgets/count.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/count.js\ntype: application/javascript\nmodule-type: widget\n\nCount widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar CountWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nCountWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nCountWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tvar textNode = this.document.createTextNode(this.currentCount);\n\tparent.insertBefore(textNode,nextSibling);\n\tthis.domNodes.push(textNode);\n};\n\n/*\nCompute the internal state of the widget\n*/\nCountWidget.prototype.execute = function() {\n\t// Get parameters from our attributes\n\tthis.filter = this.getAttribute(\"filter\");\n\t// Execute the filter\n\tif(this.filter) {\n\t\tthis.currentCount = this.wiki.filterTiddlers(this.filter,this).length;\n\t} else {\n\t\tthis.currentCount = undefined;\n\t}\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nCountWidget.prototype.refresh = function(changedTiddlers) {\n\t// Re-execute the filter to get the count\n\tthis.computeAttributes();\n\tvar oldCount = this.currentCount;\n\tthis.execute();\n\tif(this.currentCount !== oldCount) {\n\t\t// Regenerate and rerender the widget and replace the existing DOM node\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn false;\n\t}\n\n};\n\nexports.count = CountWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/diff-text.js": {
"title": "$:/core/modules/widgets/diff-text.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/diff-text.js\ntype: application/javascript\nmodule-type: widget\n\nWidget to display a diff between two texts\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget,\n\tdmp = require(\"$:/core/modules/utils/diff-match-patch/diff_match_patch.js\");\n\nvar DiffTextWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nDiffTextWidget.prototype = new Widget();\n\nDiffTextWidget.prototype.invisibleCharacters = {\n\t\"\\n\": \"↩︎\\n\",\n\t\"\\r\": \"⇠\",\n\t\"\\t\": \"⇥\\t\"\n};\n\n/*\nRender this widget into the DOM\n*/\nDiffTextWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\t// Create the diff\n\tvar dmpObject = new dmp.diff_match_patch(),\n\t\tdiffs = dmpObject.diff_main(this.getAttribute(\"source\"),this.getAttribute(\"dest\"));\n\t// Apply required cleanup\n\tswitch(this.getAttribute(\"cleanup\",\"semantic\")) {\n\t\tcase \"none\":\n\t\t\t// No cleanup\n\t\t\tbreak;\n\t\tcase \"efficiency\":\n\t\t\tdmpObject.diff_cleanupEfficiency(diffs);\n\t\t\tbreak;\n\t\tdefault: // case \"semantic\"\n\t\t\tdmpObject.diff_cleanupSemantic(diffs);\n\t\t\tbreak;\n\t}\n\t// Create the elements\n\tvar domContainer = this.document.createElement(\"div\"), \n\t\tdomDiff = this.createDiffDom(diffs);\n\tparent.insertBefore(domContainer,nextSibling);\n\t// Set variables\n\tthis.setVariable(\"diff-count\",diffs.reduce(function(acc,diff) {\n\t\tif(diff[0] !== dmp.DIFF_EQUAL) {\n\t\t\tacc++;\n\t\t}\n\t\treturn acc;\n\t},0).toString());\n\t// Render child widgets\n\tthis.renderChildren(domContainer,null);\n\t// Render the diff\n\tdomContainer.appendChild(domDiff);\n\t// Save our container\n\tthis.domNodes.push(domContainer);\n};\n\n/*\nCreate DOM elements representing a list of diffs\n*/\nDiffTextWidget.prototype.createDiffDom = function(diffs) {\n\tvar self = this;\n\t// Create the element and assign the attributes\n\tvar domPre = this.document.createElement(\"pre\"),\n\t\tdomCode = this.document.createElement(\"code\");\n\t$tw.utils.each(diffs,function(diff) {\n\t\tvar tag = diff[0] === dmp.DIFF_INSERT ? \"ins\" : (diff[0] === dmp.DIFF_DELETE ? \"del\" : \"span\"),\n\t\t\tclassName = diff[0] === dmp.DIFF_INSERT ? \"tc-diff-insert\" : (diff[0] === dmp.DIFF_DELETE ? \"tc-diff-delete\" : \"tc-diff-equal\"),\n\t\t\tdom = self.document.createElement(tag),\n\t\t\ttext = diff[1],\n\t\t\tcurrPos = 0,\n\t\t\tre = /([\\x00-\\x1F])/mg,\n\t\t\tmatch = re.exec(text),\n\t\t\tspan,\n\t\t\tprintable;\n\t\tdom.className = className;\n\t\twhile(match) {\n\t\t\tif(currPos < match.index) {\n\t\t\t\tdom.appendChild(self.document.createTextNode(text.slice(currPos,match.index)));\n\t\t\t}\n\t\t\tspan = self.document.createElement(\"span\");\n\t\t\tspan.className = \"tc-diff-invisible\";\n\t\t\tprintable = self.invisibleCharacters[match[0]] || (\"[0x\" + match[0].charCodeAt(0).toString(16) + \"]\");\n\t\t\tspan.appendChild(self.document.createTextNode(printable));\n\t\t\tdom.appendChild(span);\n\t\t\tcurrPos = match.index + match[0].length;\n\t\t\tmatch = re.exec(text);\n\t\t}\n\t\tif(currPos < text.length) {\n\t\t\tdom.appendChild(self.document.createTextNode(text.slice(currPos)));\n\t\t}\n\t\tdomCode.appendChild(dom);\n\t});\n\tdomPre.appendChild(domCode);\n\treturn domPre;\n};\n\n/*\nCompute the internal state of the widget\n*/\nDiffTextWidget.prototype.execute = function() {\n\t// Make child widgets\n\tvar parseTreeNodes;\n\tif(this.parseTreeNode && this.parseTreeNode.children && this.parseTreeNode.children.length > 0) {\n\t\tparseTreeNodes = this.parseTreeNode.children;\n\t} else {\n\t\tparseTreeNodes = [{\n\t\t\ttype: \"transclude\",\n\t\t\tattributes: {\n\t\t\t\ttiddler: {type: \"string\", value: \"$:/language/Diffs/CountMessage\"}\n\t\t\t}\n\t\t}];\n\t}\n\tthis.makeChildWidgets(parseTreeNodes);\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nDiffTextWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.source || changedAttributes.dest || changedAttributes.cleanup) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn this.refreshChildren(changedTiddlers);\n\t}\n};\n\nexports[\"diff-text\"] = DiffTextWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/draggable.js": {
"title": "$:/core/modules/widgets/draggable.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/draggable.js\ntype: application/javascript\nmodule-type: widget\n\nDraggable widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar DraggableWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nDraggableWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nDraggableWidget.prototype.render = function(parent,nextSibling) {\n\tvar self = this;\n\t// Save the parent dom node\n\tthis.parentDomNode = parent;\n\t// Compute our attributes\n\tthis.computeAttributes();\n\t// Execute our logic\n\tthis.execute();\n\t// Sanitise the specified tag\n\tvar tag = this.draggableTag;\n\tif($tw.config.htmlUnsafeElements.indexOf(tag) !== -1) {\n\t\ttag = \"div\";\n\t}\n\t// Create our element\n\tvar domNode = this.document.createElement(tag);\n\t// Assign classes\n\tvar classes = [\"tc-draggable\"];\n\tif(this.draggableClasses) {\n\t\tclasses.push(this.draggableClasses);\n\t}\n\tdomNode.setAttribute(\"class\",classes.join(\" \"));\n\t// Add event handlers\n\t$tw.utils.makeDraggable({\n\t\tdomNode: domNode,\n\t\tdragTiddlerFn: function() {return self.getAttribute(\"tiddler\");},\n\t\tdragFilterFn: function() {return self.getAttribute(\"filter\");},\n\t\tstartActions: self.startActions,\n\t\tendActions: self.endActions,\n\t\twidget: this\n\t});\n\t// Insert the link into the DOM and render any children\n\tparent.insertBefore(domNode,nextSibling);\n\tthis.renderChildren(domNode,null);\n\tthis.domNodes.push(domNode);\n};\n\n/*\nCompute the internal state of the widget\n*/\nDraggableWidget.prototype.execute = function() {\n\t// Pick up our attributes\n\tthis.draggableTag = this.getAttribute(\"tag\",\"div\");\n\tthis.draggableClasses = this.getAttribute(\"class\");\n\tthis.startActions = this.getAttribute(\"startactions\");\n\tthis.endActions = this.getAttribute(\"endactions\");\n\t// Make the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nDraggableWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedTiddlers.tag || changedTiddlers[\"class\"]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\nexports.draggable = DraggableWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/droppable.js": {
"title": "$:/core/modules/widgets/droppable.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/droppable.js\ntype: application/javascript\nmodule-type: widget\n\nDroppable widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar DroppableWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nDroppableWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nDroppableWidget.prototype.render = function(parent,nextSibling) {\n\tvar self = this;\n\t// Remember parent\n\tthis.parentDomNode = parent;\n\t// Compute attributes and execute state\n\tthis.computeAttributes();\n\tthis.execute();\n\tvar tag = this.parseTreeNode.isBlock ? \"div\" : \"span\";\n\tif(this.droppableTag && $tw.config.htmlUnsafeElements.indexOf(this.droppableTag) === -1) {\n\t\ttag = this.droppableTag;\n\t}\n\t// Create element and assign classes\n\tvar domNode = this.document.createElement(tag),\n\t\tclasses = (this[\"class\"] || \"\").split(\" \");\n\tclasses.push(\"tc-droppable\");\n\tdomNode.className = classes.join(\" \");\n\t// Add event handlers\n\t$tw.utils.addEventListeners(domNode,[\n\t\t{name: \"dragenter\", handlerObject: this, handlerMethod: \"handleDragEnterEvent\"},\n\t\t{name: \"dragover\", handlerObject: this, handlerMethod: \"handleDragOverEvent\"},\n\t\t{name: \"dragleave\", handlerObject: this, handlerMethod: \"handleDragLeaveEvent\"},\n\t\t{name: \"drop\", handlerObject: this, handlerMethod: \"handleDropEvent\"}\n\t]);\n\t// Insert element\n\tparent.insertBefore(domNode,nextSibling);\n\tthis.renderChildren(domNode,null);\n\tthis.domNodes.push(domNode);\n\t// Stack of outstanding enter/leave events\n\tthis.currentlyEntered = [];\n};\n\nDroppableWidget.prototype.enterDrag = function(event) {\n\tif(this.currentlyEntered.indexOf(event.target) === -1) {\n\t\tthis.currentlyEntered.push(event.target);\n\t}\n\t// If we're entering for the first time we need to apply highlighting\n\t$tw.utils.addClass(this.domNodes[0],\"tc-dragover\");\n};\n\nDroppableWidget.prototype.leaveDrag = function(event) {\n\tvar pos = this.currentlyEntered.indexOf(event.target);\n\tif(pos !== -1) {\n\t\tthis.currentlyEntered.splice(pos,1);\n\t}\n\t// Remove highlighting if we're leaving externally. The hacky second condition is to resolve a problem with Firefox whereby there is an erroneous dragenter event if the node being dragged is within the dropzone\n\tif(this.currentlyEntered.length === 0 || (this.currentlyEntered.length === 1 && this.currentlyEntered[0] === $tw.dragInProgress)) {\n\t\tthis.currentlyEntered = [];\n\t\t$tw.utils.removeClass(this.domNodes[0],\"tc-dragover\");\n\t}\n};\n\nDroppableWidget.prototype.handleDragEnterEvent = function(event) {\n\tthis.enterDrag(event);\n\t// Tell the browser that we're ready to handle the drop\n\tevent.preventDefault();\n\t// Tell the browser not to ripple the drag up to any parent drop handlers\n\tevent.stopPropagation();\n\treturn false;\n};\n\nDroppableWidget.prototype.handleDragOverEvent = function(event) {\n\t// Check for being over a TEXTAREA or INPUT\n\tif([\"TEXTAREA\",\"INPUT\"].indexOf(event.target.tagName) !== -1) {\n\t\treturn false;\n\t}\n\t// Tell the browser that we're still interested in the drop\n\tevent.preventDefault();\n\t// Set the drop effect\n\tevent.dataTransfer.dropEffect = this.droppableEffect;\n\treturn false;\n};\n\nDroppableWidget.prototype.handleDragLeaveEvent = function(event) {\n\tthis.leaveDrag(event);\n\treturn false;\n};\n\nDroppableWidget.prototype.handleDropEvent = function(event) {\n\tvar self = this;\n\tthis.leaveDrag(event);\n\t// Check for being over a TEXTAREA or INPUT\n\tif([\"TEXTAREA\",\"INPUT\"].indexOf(event.target.tagName) !== -1) {\n\t\treturn false;\n\t}\n\tvar dataTransfer = event.dataTransfer;\n\t// Remove highlighting\n\t$tw.utils.removeClass(this.domNodes[0],\"tc-dragover\");\n\t// Try to import the various data types we understand\n\t$tw.utils.importDataTransfer(dataTransfer,null,function(fieldsArray) {\n\t\tfieldsArray.forEach(function(fields) {\n\t\t\tself.performActions(fields.title || fields.text,event);\n\t\t});\n\t});\n\t// Tell the browser that we handled the drop\n\tevent.preventDefault();\n\t// Stop the drop ripple up to any parent handlers\n\tevent.stopPropagation();\n\treturn false;\n};\n\nDroppableWidget.prototype.performActions = function(title,event) {\n\tif(this.droppableActions) {\n\t\tvar modifierKey = event.ctrlKey && ! event.shiftKey ? \"ctrl\" : event.shiftKey && !event.ctrlKey ? \"shift\" : \n\t\t\t\tevent.ctrlKey && event.shiftKey ? \"ctrl-shift\" : \"normal\" ;\n\t\tthis.invokeActionString(this.droppableActions,this,event,{actionTiddler: title, modifier: modifierKey});\n\t}\n};\n\n/*\nCompute the internal state of the widget\n*/\nDroppableWidget.prototype.execute = function() {\n\tthis.droppableActions = this.getAttribute(\"actions\");\n\tthis.droppableEffect = this.getAttribute(\"effect\",\"copy\");\n\tthis.droppableTag = this.getAttribute(\"tag\");\n\tthis.droppableClass = this.getAttribute(\"class\");\n\t// Make child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nDroppableWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes[\"class\"] || changedAttributes.tag) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\nexports.droppable = DroppableWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/dropzone.js": {
"title": "$:/core/modules/widgets/dropzone.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/dropzone.js\ntype: application/javascript\nmodule-type: widget\n\nDropzone widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar DropZoneWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nDropZoneWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nDropZoneWidget.prototype.render = function(parent,nextSibling) {\n\tvar self = this;\n\t// Remember parent\n\tthis.parentDomNode = parent;\n\t// Compute attributes and execute state\n\tthis.computeAttributes();\n\tthis.execute();\n\t// Create element\n\tvar domNode = this.document.createElement(\"div\");\n\tdomNode.className = \"tc-dropzone\";\n\t// Add event handlers\n\t$tw.utils.addEventListeners(domNode,[\n\t\t{name: \"dragenter\", handlerObject: this, handlerMethod: \"handleDragEnterEvent\"},\n\t\t{name: \"dragover\", handlerObject: this, handlerMethod: \"handleDragOverEvent\"},\n\t\t{name: \"dragleave\", handlerObject: this, handlerMethod: \"handleDragLeaveEvent\"},\n\t\t{name: \"drop\", handlerObject: this, handlerMethod: \"handleDropEvent\"},\n\t\t{name: \"paste\", handlerObject: this, handlerMethod: \"handlePasteEvent\"}\n\t]);\n\tdomNode.addEventListener(\"click\",function (event) {\n\t},false);\n\t// Insert element\n\tparent.insertBefore(domNode,nextSibling);\n\tthis.renderChildren(domNode,null);\n\tthis.domNodes.push(domNode);\n\t// Stack of outstanding enter/leave events\n\tthis.currentlyEntered = [];\n};\n\nDropZoneWidget.prototype.enterDrag = function(event) {\n\tif(this.currentlyEntered.indexOf(event.target) === -1) {\n\t\tthis.currentlyEntered.push(event.target);\n\t}\n\t// If we're entering for the first time we need to apply highlighting\n\t$tw.utils.addClass(this.domNodes[0],\"tc-dragover\");\n};\n\nDropZoneWidget.prototype.leaveDrag = function(event) {\n\tvar pos = this.currentlyEntered.indexOf(event.target);\n\tif(pos !== -1) {\n\t\tthis.currentlyEntered.splice(pos,1);\n\t}\n\t// Remove highlighting if we're leaving externally\n\tif(this.currentlyEntered.length === 0) {\n\t\t$tw.utils.removeClass(this.domNodes[0],\"tc-dragover\");\n\t}\n};\n\nDropZoneWidget.prototype.handleDragEnterEvent = function(event) {\n\t// Check for this window being the source of the drag\n\tif($tw.dragInProgress) {\n\t\treturn false;\n\t}\n\tthis.enterDrag(event);\n\t// Tell the browser that we're ready to handle the drop\n\tevent.preventDefault();\n\t// Tell the browser not to ripple the drag up to any parent drop handlers\n\tevent.stopPropagation();\n};\n\nDropZoneWidget.prototype.handleDragOverEvent = function(event) {\n\t// Check for being over a TEXTAREA or INPUT\n\tif([\"TEXTAREA\",\"INPUT\"].indexOf(event.target.tagName) !== -1) {\n\t\treturn false;\n\t}\n\t// Check for this window being the source of the drag\n\tif($tw.dragInProgress) {\n\t\treturn false;\n\t}\n\t// Tell the browser that we're still interested in the drop\n\tevent.preventDefault();\n\tevent.dataTransfer.dropEffect = \"copy\"; // Explicitly show this is a copy\n};\n\nDropZoneWidget.prototype.handleDragLeaveEvent = function(event) {\n\tthis.leaveDrag(event);\n};\n\nDropZoneWidget.prototype.handleDropEvent = function(event) {\n\tvar self = this,\n\t\treadFileCallback = function(tiddlerFieldsArray) {\n\t\t\tself.dispatchEvent({type: \"tm-import-tiddlers\", param: JSON.stringify(tiddlerFieldsArray)});\n\t\t};\n\tthis.leaveDrag(event);\n\t// Check for being over a TEXTAREA or INPUT\n\tif([\"TEXTAREA\",\"INPUT\"].indexOf(event.target.tagName) !== -1) {\n\t\treturn false;\n\t}\n\t// Check for this window being the source of the drag\n\tif($tw.dragInProgress) {\n\t\treturn false;\n\t}\n\tvar self = this,\n\t\tdataTransfer = event.dataTransfer;\n\t// Remove highlighting\n\t$tw.utils.removeClass(this.domNodes[0],\"tc-dragover\");\n\t// Import any files in the drop\n\tvar numFiles = 0;\n\tif(dataTransfer.files) {\n\t\tnumFiles = this.wiki.readFiles(dataTransfer.files,{\n\t\t\tcallback: readFileCallback,\n\t\t\tdeserializer: this.dropzoneDeserializer\n\t\t});\n\t}\n\t// Try to import the various data types we understand\n\tif(numFiles === 0) {\n\t\t$tw.utils.importDataTransfer(dataTransfer,this.wiki.generateNewTitle(\"Untitled\"),readFileCallback);\n\t}\n\t// Tell the browser that we handled the drop\n\tevent.preventDefault();\n\t// Stop the drop ripple up to any parent handlers\n\tevent.stopPropagation();\n};\n\nDropZoneWidget.prototype.handlePasteEvent = function(event) {\n\tvar self = this,\n\t\treadFileCallback = function(tiddlerFieldsArray) {\n\t\t\tself.dispatchEvent({type: \"tm-import-tiddlers\", param: JSON.stringify(tiddlerFieldsArray)});\n\t\t};\n\t// Let the browser handle it if we're in a textarea or input box\n\tif([\"TEXTAREA\",\"INPUT\"].indexOf(event.target.tagName) == -1 && !event.target.isContentEditable) {\n\t\tvar self = this,\n\t\t\titems = event.clipboardData.items;\n\t\t// Enumerate the clipboard items\n\t\tfor(var t = 0; t<items.length; t++) {\n\t\t\tvar item = items[t];\n\t\t\tif(item.kind === \"file\") {\n\t\t\t\t// Import any files\n\t\t\t\tthis.wiki.readFile(item.getAsFile(),{\n\t\t\t\t\tcallback: readFileCallback,\n\t\t\t\t\tdeserializer: this.dropzoneDeserializer\n\t\t\t\t});\n\t\t\t} else if(item.kind === \"string\") {\n\t\t\t\t// Create tiddlers from string items\n\t\t\t\tvar type = item.type;\n\t\t\t\titem.getAsString(function(str) {\n\t\t\t\t\tvar tiddlerFields = {\n\t\t\t\t\t\ttitle: self.wiki.generateNewTitle(\"Untitled\"),\n\t\t\t\t\t\ttext: str,\n\t\t\t\t\t\ttype: type\n\t\t\t\t\t};\n\t\t\t\t\tif($tw.log.IMPORT) {\n\t\t\t\t\t\tconsole.log(\"Importing string '\" + str + \"', type: '\" + type + \"'\");\n\t\t\t\t\t}\n\t\t\t\t\tself.dispatchEvent({type: \"tm-import-tiddlers\", param: JSON.stringify([tiddlerFields])});\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t\t// Tell the browser that we've handled the paste\n\t\tevent.stopPropagation();\n\t\tevent.preventDefault();\n\t}\n};\n\n/*\nCompute the internal state of the widget\n*/\nDropZoneWidget.prototype.execute = function() {\n\tthis.dropzoneDeserializer = this.getAttribute(\"deserializer\");\n\t// Make child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nDropZoneWidget.prototype.refresh = function(changedTiddlers) {\n\treturn this.refreshChildren(changedTiddlers);\n};\n\nexports.dropzone = DropZoneWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/edit-binary.js": {
"title": "$:/core/modules/widgets/edit-binary.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/edit-binary.js\ntype: application/javascript\nmodule-type: widget\n\nEdit-binary widget; placeholder for editing binary tiddlers\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar BINARY_WARNING_MESSAGE = \"$:/core/ui/BinaryWarning\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar EditBinaryWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nEditBinaryWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nEditBinaryWidget.prototype.render = function(parent,nextSibling) {\n\tvar self = this;\n\t// Save the parent dom node\n\tthis.parentDomNode = parent;\n\t// Compute our attributes\n\tthis.computeAttributes();\n\t// Execute our logic\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n};\n\n/*\nCompute the internal state of the widget\n*/\nEditBinaryWidget.prototype.execute = function() {\n\t// Construct the child widgets\n\tthis.makeChildWidgets([{\n\t\ttype: \"transclude\",\n\t\tattributes: {\n\t\t\ttiddler: {type: \"string\", value: BINARY_WARNING_MESSAGE}\n\t\t}\n\t}]);\n};\n\n/*\nRefresh by refreshing our child widget\n*/\nEditBinaryWidget.prototype.refresh = function(changedTiddlers) {\n\treturn this.refreshChildren(changedTiddlers);\n};\n\nexports[\"edit-binary\"] = EditBinaryWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/edit-bitmap.js": {
"title": "$:/core/modules/widgets/edit-bitmap.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/edit-bitmap.js\ntype: application/javascript\nmodule-type: widget\n\nEdit-bitmap widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n// Default image sizes\nvar DEFAULT_IMAGE_WIDTH = 600,\n\tDEFAULT_IMAGE_HEIGHT = 370;\n\n// Configuration tiddlers\nvar LINE_WIDTH_TITLE = \"$:/config/BitmapEditor/LineWidth\",\n\tLINE_COLOUR_TITLE = \"$:/config/BitmapEditor/Colour\",\n\tLINE_OPACITY_TITLE = \"$:/config/BitmapEditor/Opacity\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar EditBitmapWidget = function(parseTreeNode,options) {\n\t// Initialise the editor operations if they've not been done already\n\tif(!this.editorOperations) {\n\t\tEditBitmapWidget.prototype.editorOperations = {};\n\t\t$tw.modules.applyMethods(\"bitmapeditoroperation\",this.editorOperations);\n\t}\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nEditBitmapWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nEditBitmapWidget.prototype.render = function(parent,nextSibling) {\n\tvar self = this;\n\t// Save the parent dom node\n\tthis.parentDomNode = parent;\n\t// Compute our attributes\n\tthis.computeAttributes();\n\t// Execute our logic\n\tthis.execute();\n\t// Create the wrapper for the toolbar and render its content\n\tthis.toolbarNode = this.document.createElement(\"div\");\n\tthis.toolbarNode.className = \"tc-editor-toolbar\";\n\tparent.insertBefore(this.toolbarNode,nextSibling);\n\tthis.domNodes.push(this.toolbarNode);\n\t// Create the on-screen canvas\n\tthis.canvasDomNode = $tw.utils.domMaker(\"canvas\",{\n\t\tdocument: this.document,\n\t\t\"class\":\"tc-edit-bitmapeditor\",\n\t\teventListeners: [{\n\t\t\tname: \"touchstart\", handlerObject: this, handlerMethod: \"handleTouchStartEvent\"\n\t\t},{\n\t\t\tname: \"touchmove\", handlerObject: this, handlerMethod: \"handleTouchMoveEvent\"\n\t\t},{\n\t\t\tname: \"touchend\", handlerObject: this, handlerMethod: \"handleTouchEndEvent\"\n\t\t},{\n\t\t\tname: \"mousedown\", handlerObject: this, handlerMethod: \"handleMouseDownEvent\"\n\t\t},{\n\t\t\tname: \"mousemove\", handlerObject: this, handlerMethod: \"handleMouseMoveEvent\"\n\t\t},{\n\t\t\tname: \"mouseup\", handlerObject: this, handlerMethod: \"handleMouseUpEvent\"\n\t\t}]\n\t});\n\t// Set the width and height variables\n\tthis.setVariable(\"tv-bitmap-editor-width\",this.canvasDomNode.width + \"px\");\n\tthis.setVariable(\"tv-bitmap-editor-height\",this.canvasDomNode.height + \"px\");\n\t// Render toolbar child widgets\n\tthis.renderChildren(this.toolbarNode,null);\n\t// // Insert the elements into the DOM\n\tparent.insertBefore(this.canvasDomNode,nextSibling);\n\tthis.domNodes.push(this.canvasDomNode);\n\t// Load the image into the canvas\n\tif($tw.browser) {\n\t\tthis.loadCanvas();\n\t}\n\t// Add widget message listeners\n\tthis.addEventListeners([\n\t\t{type: \"tm-edit-bitmap-operation\", handler: \"handleEditBitmapOperationMessage\"}\n\t]);\n};\n\n/*\nHandle an edit bitmap operation message from the toolbar\n*/\nEditBitmapWidget.prototype.handleEditBitmapOperationMessage = function(event) {\n\t// Invoke the handler\n\tvar handler = this.editorOperations[event.param];\n\tif(handler) {\n\t\thandler.call(this,event);\n\t}\n};\n\n/*\nCompute the internal state of the widget\n*/\nEditBitmapWidget.prototype.execute = function() {\n\t// Get our parameters\n\tthis.editTitle = this.getAttribute(\"tiddler\",this.getVariable(\"currentTiddler\"));\n\t// Make the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nJust refresh the toolbar\n*/\nEditBitmapWidget.prototype.refresh = function(changedTiddlers) {\n\treturn this.refreshChildren(changedTiddlers);\n};\n\n/*\nSet the bitmap size variables and refresh the toolbar\n*/\nEditBitmapWidget.prototype.refreshToolbar = function() {\n\t// Set the width and height variables\n\tthis.setVariable(\"tv-bitmap-editor-width\",this.canvasDomNode.width + \"px\");\n\tthis.setVariable(\"tv-bitmap-editor-height\",this.canvasDomNode.height + \"px\");\n\t// Refresh each of our child widgets\n\t$tw.utils.each(this.children,function(childWidget) {\n\t\tchildWidget.refreshSelf();\n\t});\n};\n\nEditBitmapWidget.prototype.loadCanvas = function() {\n\tvar tiddler = this.wiki.getTiddler(this.editTitle),\n\t\tcurrImage = new Image();\n\t// Set up event handlers for loading the image\n\tvar self = this;\n\tcurrImage.onload = function() {\n\t\t// Copy the image to the on-screen canvas\n\t\tself.initCanvas(self.canvasDomNode,currImage.width,currImage.height,currImage);\n\t\t// And also copy the current bitmap to the off-screen canvas\n\t\tself.currCanvas = self.document.createElement(\"canvas\");\n\t\tself.initCanvas(self.currCanvas,currImage.width,currImage.height,currImage);\n\t\t// Set the width and height input boxes\n\t\tself.refreshToolbar();\n\t};\n\tcurrImage.onerror = function() {\n\t\t// Set the on-screen canvas size and clear it\n\t\tself.initCanvas(self.canvasDomNode,DEFAULT_IMAGE_WIDTH,DEFAULT_IMAGE_HEIGHT);\n\t\t// Set the off-screen canvas size and clear it\n\t\tself.currCanvas = self.document.createElement(\"canvas\");\n\t\tself.initCanvas(self.currCanvas,DEFAULT_IMAGE_WIDTH,DEFAULT_IMAGE_HEIGHT);\n\t\t// Set the width and height input boxes\n\t\tself.refreshToolbar();\n\t};\n\t// Get the current bitmap into an image object\n\tcurrImage.src = \"data:\" + tiddler.fields.type + \";base64,\" + tiddler.fields.text;\n};\n\nEditBitmapWidget.prototype.initCanvas = function(canvas,width,height,image) {\n\tcanvas.width = width;\n\tcanvas.height = height;\n\tvar ctx = canvas.getContext(\"2d\");\n\tif(image) {\n\t\tctx.drawImage(image,0,0);\n\t} else {\n\t\tctx.fillStyle = \"#fff\";\n\t\tctx.fillRect(0,0,canvas.width,canvas.height);\n\t}\n};\n\n/*\n** Change the size of the canvas, preserving the current image\n*/\nEditBitmapWidget.prototype.changeCanvasSize = function(newWidth,newHeight) {\n\t// Create and size a new canvas\n\tvar newCanvas = this.document.createElement(\"canvas\");\n\tthis.initCanvas(newCanvas,newWidth,newHeight);\n\t// Copy the old image\n\tvar ctx = newCanvas.getContext(\"2d\");\n\tctx.drawImage(this.currCanvas,0,0);\n\t// Set the new canvas as the current one\n\tthis.currCanvas = newCanvas;\n\t// Set the size of the onscreen canvas\n\tthis.canvasDomNode.width = newWidth;\n\tthis.canvasDomNode.height = newHeight;\n\t// Paint the onscreen canvas with the offscreen canvas\n\tctx = this.canvasDomNode.getContext(\"2d\");\n\tctx.drawImage(this.currCanvas,0,0);\n};\n\n/*\n** Rotate the canvas left by 90 degrees\n*/\nEditBitmapWidget.prototype.rotateCanvasLeft = function() {\n\t// Get the current size of the image\n\tvar origWidth = this.currCanvas.width,\n\t\torigHeight = this.currCanvas.height;\n\t// Create and size a new canvas\n\tvar newCanvas = this.document.createElement(\"canvas\"),\n\t\tnewWidth = origHeight,\n\t\tnewHeight = origWidth;\n\tthis.initCanvas(newCanvas,newWidth,newHeight);\n\t// Copy the old image\n\tvar ctx = newCanvas.getContext(\"2d\");\n\tctx.save();\n\tctx.translate(newWidth / 2,newHeight / 2);\n\tctx.rotate(-Math.PI / 2);\n\tctx.drawImage(this.currCanvas,-origWidth / 2,-origHeight / 2);\n\tctx.restore();\n\t// Set the new canvas as the current one\n\tthis.currCanvas = newCanvas;\n\t// Set the size of the onscreen canvas\n\tthis.canvasDomNode.width = newWidth;\n\tthis.canvasDomNode.height = newHeight;\n\t// Paint the onscreen canvas with the offscreen canvas\n\tctx = this.canvasDomNode.getContext(\"2d\");\n\tctx.drawImage(this.currCanvas,0,0);\n};\n\nEditBitmapWidget.prototype.handleTouchStartEvent = function(event) {\n\tthis.brushDown = true;\n\tthis.strokeStart(event.touches[0].clientX,event.touches[0].clientY);\n\tevent.preventDefault();\n\tevent.stopPropagation();\n\treturn false;\n};\n\nEditBitmapWidget.prototype.handleTouchMoveEvent = function(event) {\n\tif(this.brushDown) {\n\t\tthis.strokeMove(event.touches[0].clientX,event.touches[0].clientY);\n\t}\n\tevent.preventDefault();\n\tevent.stopPropagation();\n\treturn false;\n};\n\nEditBitmapWidget.prototype.handleTouchEndEvent = function(event) {\n\tif(this.brushDown) {\n\t\tthis.brushDown = false;\n\t\tthis.strokeEnd();\n\t}\n\tevent.preventDefault();\n\tevent.stopPropagation();\n\treturn false;\n};\n\nEditBitmapWidget.prototype.handleMouseDownEvent = function(event) {\n\tthis.strokeStart(event.clientX,event.clientY);\n\tthis.brushDown = true;\n\tevent.preventDefault();\n\tevent.stopPropagation();\n\treturn false;\n};\n\nEditBitmapWidget.prototype.handleMouseMoveEvent = function(event) {\n\tif(this.brushDown) {\n\t\tthis.strokeMove(event.clientX,event.clientY);\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t\treturn false;\n\t}\n\treturn true;\n};\n\nEditBitmapWidget.prototype.handleMouseUpEvent = function(event) {\n\tif(this.brushDown) {\n\t\tthis.brushDown = false;\n\t\tthis.strokeEnd();\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t\treturn false;\n\t}\n\treturn true;\n};\n\nEditBitmapWidget.prototype.adjustCoordinates = function(x,y) {\n\tvar canvasRect = this.canvasDomNode.getBoundingClientRect(),\n\t\tscale = this.canvasDomNode.width/canvasRect.width;\n\treturn {x: (x - canvasRect.left) * scale, y: (y - canvasRect.top) * scale};\n};\n\nEditBitmapWidget.prototype.strokeStart = function(x,y) {\n\t// Start off a new stroke\n\tthis.stroke = [this.adjustCoordinates(x,y)];\n};\n\nEditBitmapWidget.prototype.strokeMove = function(x,y) {\n\tvar ctx = this.canvasDomNode.getContext(\"2d\"),\n\t\tt;\n\t// Add the new position to the end of the stroke\n\tthis.stroke.push(this.adjustCoordinates(x,y));\n\t// Redraw the previous image\n\tctx.drawImage(this.currCanvas,0,0);\n\t// Render the stroke\n\tctx.globalAlpha = parseFloat(this.wiki.getTiddlerText(LINE_OPACITY_TITLE,\"1.0\"));\n\tctx.strokeStyle = this.wiki.getTiddlerText(LINE_COLOUR_TITLE,\"#ff0\");\n\tctx.lineWidth = parseFloat(this.wiki.getTiddlerText(LINE_WIDTH_TITLE,\"3\"));\n\tctx.lineCap = \"round\";\n\tctx.lineJoin = \"round\";\n\tctx.beginPath();\n\tctx.moveTo(this.stroke[0].x,this.stroke[0].y);\n\tfor(t=1; t<this.stroke.length-1; t++) {\n\t\tvar s1 = this.stroke[t],\n\t\t\ts2 = this.stroke[t-1],\n\t\t\ttx = (s1.x + s2.x)/2,\n\t\t\tty = (s1.y + s2.y)/2;\n\t\tctx.quadraticCurveTo(s2.x,s2.y,tx,ty);\n\t}\n\tctx.stroke();\n};\n\nEditBitmapWidget.prototype.strokeEnd = function() {\n\t// Copy the bitmap to the off-screen canvas\n\tvar ctx = this.currCanvas.getContext(\"2d\");\n\tctx.drawImage(this.canvasDomNode,0,0);\n\t// Save the image into the tiddler\n\tthis.saveChanges();\n};\n\nEditBitmapWidget.prototype.saveChanges = function() {\n\tvar tiddler = this.wiki.getTiddler(this.editTitle);\n\tif(tiddler) {\n\t\t// data URIs look like \"data:<type>;base64,<text>\"\n\t\tvar dataURL = this.canvasDomNode.toDataURL(tiddler.fields.type),\n\t\t\tposColon = dataURL.indexOf(\":\"),\n\t\t\tposSemiColon = dataURL.indexOf(\";\"),\n\t\t\tposComma = dataURL.indexOf(\",\"),\n\t\t\ttype = dataURL.substring(posColon+1,posSemiColon),\n\t\t\ttext = dataURL.substring(posComma+1);\n\t\tvar update = {type: type, text: text};\n\t\tthis.wiki.addTiddler(new $tw.Tiddler(this.wiki.getModificationFields(),tiddler,update,this.wiki.getCreationFields()));\n\t}\n};\n\nexports[\"edit-bitmap\"] = EditBitmapWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/edit-shortcut.js": {
"title": "$:/core/modules/widgets/edit-shortcut.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/edit-shortcut.js\ntype: application/javascript\nmodule-type: widget\n\nWidget to display an editable keyboard shortcut\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar EditShortcutWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nEditShortcutWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nEditShortcutWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.inputNode = this.document.createElement(\"input\");\n\t// Assign classes\n\tif(this.shortcutClass) {\n\t\tthis.inputNode.className = this.shortcutClass;\t\t\n\t}\n\t// Assign other attributes\n\tif(this.shortcutStyle) {\n\t\tthis.inputNode.setAttribute(\"style\",this.shortcutStyle);\n\t}\n\tif(this.shortcutTooltip) {\n\t\tthis.inputNode.setAttribute(\"title\",this.shortcutTooltip);\n\t}\n\tif(this.shortcutPlaceholder) {\n\t\tthis.inputNode.setAttribute(\"placeholder\",this.shortcutPlaceholder);\n\t}\n\tif(this.shortcutAriaLabel) {\n\t\tthis.inputNode.setAttribute(\"aria-label\",this.shortcutAriaLabel);\n\t}\n\t// Assign the current shortcut\n\tthis.updateInputNode();\n\t// Add event handlers\n\t$tw.utils.addEventListeners(this.inputNode,[\n\t\t{name: \"keydown\", handlerObject: this, handlerMethod: \"handleKeydownEvent\"}\n\t]);\n\t// Link into the DOM\n\tparent.insertBefore(this.inputNode,nextSibling);\n\tthis.domNodes.push(this.inputNode);\n};\n\n/*\nCompute the internal state of the widget\n*/\nEditShortcutWidget.prototype.execute = function() {\n\tthis.shortcutTiddler = this.getAttribute(\"tiddler\");\n\tthis.shortcutField = this.getAttribute(\"field\");\n\tthis.shortcutIndex = this.getAttribute(\"index\");\n\tthis.shortcutPlaceholder = this.getAttribute(\"placeholder\");\n\tthis.shortcutDefault = this.getAttribute(\"default\",\"\");\n\tthis.shortcutClass = this.getAttribute(\"class\");\n\tthis.shortcutStyle = this.getAttribute(\"style\");\n\tthis.shortcutTooltip = this.getAttribute(\"tooltip\");\n\tthis.shortcutAriaLabel = this.getAttribute(\"aria-label\");\n};\n\n/*\nUpdate the value of the input node\n*/\nEditShortcutWidget.prototype.updateInputNode = function() {\n\tif(this.shortcutField) {\n\t\tvar tiddler = this.wiki.getTiddler(this.shortcutTiddler);\n\t\tif(tiddler && $tw.utils.hop(tiddler.fields,this.shortcutField)) {\n\t\t\tthis.inputNode.value = tiddler.getFieldString(this.shortcutField);\n\t\t} else {\n\t\t\tthis.inputNode.value = this.shortcutDefault;\n\t\t}\n\t} else if(this.shortcutIndex) {\n\t\tthis.inputNode.value = this.wiki.extractTiddlerDataItem(this.shortcutTiddler,this.shortcutIndex,this.shortcutDefault);\n\t} else {\n\t\tthis.inputNode.value = this.wiki.getTiddlerText(this.shortcutTiddler,this.shortcutDefault);\n\t}\n};\n\n/*\nHandle a dom \"keydown\" event\n*/\nEditShortcutWidget.prototype.handleKeydownEvent = function(event) {\n\t// Ignore shift, ctrl, meta, alt\n\tif(event.keyCode && $tw.keyboardManager.getModifierKeys().indexOf(event.keyCode) === -1) {\n\t\t// Get the shortcut text representation\n\t\tvar value = $tw.keyboardManager.getPrintableShortcuts([{\n\t\t\tctrlKey: event.ctrlKey,\n\t\t\tshiftKey: event.shiftKey,\n\t\t\taltKey: event.altKey,\n\t\t\tmetaKey: event.metaKey,\n\t\t\tkeyCode: event.keyCode\n\t\t}]);\n\t\tif(value.length > 0) {\n\t\t\tthis.wiki.setText(this.shortcutTiddler,this.shortcutField,this.shortcutIndex,value[0]);\n\t\t}\n\t\t// Ignore the keydown if it was already handled\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t\treturn true;\t\t\n\t} else {\n\t\treturn false;\n\t}\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget needed re-rendering\n*/\nEditShortcutWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.tiddler || changedAttributes.field || changedAttributes.index || changedAttributes.placeholder || changedAttributes[\"default\"] || changedAttributes[\"class\"] || changedAttributes.style || changedAttributes.tooltip || changedAttributes[\"aria-label\"]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else if(changedTiddlers[this.shortcutTiddler]) {\n\t\tthis.updateInputNode();\n\t\treturn true;\n\t} else {\n\t\treturn false;\t\n\t}\n};\n\nexports[\"edit-shortcut\"] = EditShortcutWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/edit-text.js": {
"title": "$:/core/modules/widgets/edit-text.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/edit-text.js\ntype: application/javascript\nmodule-type: widget\n\nEdit-text widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar editTextWidgetFactory = require(\"$:/core/modules/editor/factory.js\").editTextWidgetFactory,\n\tFramedEngine = require(\"$:/core/modules/editor/engines/framed.js\").FramedEngine,\n\tSimpleEngine = require(\"$:/core/modules/editor/engines/simple.js\").SimpleEngine;\n\nexports[\"edit-text\"] = editTextWidgetFactory(FramedEngine,SimpleEngine);\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/edit.js": {
"title": "$:/core/modules/widgets/edit.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/edit.js\ntype: application/javascript\nmodule-type: widget\n\nEdit widget is a meta-widget chooses the appropriate actual editting widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar EditWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nEditWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nEditWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n};\n\n// Mappings from content type to editor type are stored in tiddlers with this prefix\nvar EDITOR_MAPPING_PREFIX = \"$:/config/EditorTypeMappings/\";\n\n/*\nCompute the internal state of the widget\n*/\nEditWidget.prototype.execute = function() {\n\t// Get our parameters\n\tthis.editTitle = this.getAttribute(\"tiddler\",this.getVariable(\"currentTiddler\"));\n\tthis.editField = this.getAttribute(\"field\",\"text\");\n\tthis.editIndex = this.getAttribute(\"index\");\n\tthis.editClass = this.getAttribute(\"class\");\n\tthis.editPlaceholder = this.getAttribute(\"placeholder\");\n\t// Choose the appropriate edit widget\n\tthis.editorType = this.getEditorType();\n\t// Make the child widgets\n\tthis.makeChildWidgets([{\n\t\ttype: \"edit-\" + this.editorType,\n\t\tattributes: {\n\t\t\ttiddler: {type: \"string\", value: this.editTitle},\n\t\t\tfield: {type: \"string\", value: this.editField},\n\t\t\tindex: {type: \"string\", value: this.editIndex},\n\t\t\t\"class\": {type: \"string\", value: this.editClass},\n\t\t\t\"placeholder\": {type: \"string\", value: this.editPlaceholder}\n\t\t},\n\t\tchildren: this.parseTreeNode.children\n\t}]);\n};\n\nEditWidget.prototype.getEditorType = function() {\n\t// Get the content type of the thing we're editing\n\tvar type;\n\tif(this.editField === \"text\") {\n\t\tvar tiddler = this.wiki.getTiddler(this.editTitle);\n\t\tif(tiddler) {\n\t\t\ttype = tiddler.fields.type;\n\t\t}\n\t}\n\ttype = type || \"text/vnd.tiddlywiki\";\n\tvar editorType = this.wiki.getTiddlerText(EDITOR_MAPPING_PREFIX + type);\n\tif(!editorType) {\n\t\tvar typeInfo = $tw.config.contentTypeInfo[type];\n\t\tif(typeInfo && typeInfo.encoding === \"base64\") {\n\t\t\teditorType = \"binary\";\n\t\t} else {\n\t\t\teditorType = \"text\";\n\t\t}\n\t}\n\treturn editorType;\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nEditWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\t// Refresh if an attribute has changed, or the type associated with the target tiddler has changed\n\tif(changedAttributes.tiddler || changedAttributes.field || changedAttributes.index || (changedTiddlers[this.editTitle] && this.getEditorType() !== this.editorType)) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn this.refreshChildren(changedTiddlers);\t\t\n\t}\n};\n\nexports.edit = EditWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/element.js": {
"title": "$:/core/modules/widgets/element.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/element.js\ntype: application/javascript\nmodule-type: widget\n\nElement widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar ElementWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nElementWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nElementWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\t// Neuter blacklisted elements\n\tvar tag = this.parseTreeNode.tag;\n\tif($tw.config.htmlUnsafeElements.indexOf(tag) !== -1) {\n\t\ttag = \"safe-\" + tag;\n\t}\n\t// Adjust headings by the current base level\n\tvar headingLevel = [\"h1\",\"h2\",\"h3\",\"h4\",\"h5\",\"h6\"].indexOf(tag);\n\tif(headingLevel !== -1) {\n\t\tvar baseLevel = parseInt(this.getVariable(\"tv-adjust-heading-level\",\"0\"),10) || 0;\n\t\theadingLevel = Math.min(Math.max(headingLevel + 1 + baseLevel,1),6);\n\t\ttag = \"h\" + headingLevel;\n\t}\n\t// Create the DOM node\n\tvar domNode = this.document.createElementNS(this.namespace,tag);\n\tthis.assignAttributes(domNode,{excludeEventAttributes: true});\n\tparent.insertBefore(domNode,nextSibling);\n\tthis.renderChildren(domNode,null);\n\tthis.domNodes.push(domNode);\n};\n\n/*\nCompute the internal state of the widget\n*/\nElementWidget.prototype.execute = function() {\n\t// Select the namespace for the tag\n\tvar tagNamespaces = {\n\t\t\tsvg: \"http://www.w3.org/2000/svg\",\n\t\t\tmath: \"http://www.w3.org/1998/Math/MathML\",\n\t\t\tbody: \"http://www.w3.org/1999/xhtml\"\n\t\t};\n\tthis.namespace = tagNamespaces[this.parseTreeNode.tag];\n\tif(this.namespace) {\n\t\tthis.setVariable(\"namespace\",this.namespace);\n\t} else {\n\t\tthis.namespace = this.getVariable(\"namespace\",{defaultValue: \"http://www.w3.org/1999/xhtml\"});\n\t}\n\t// Make the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nElementWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes(),\n\t\thasChangedAttributes = $tw.utils.count(changedAttributes) > 0;\n\tif(hasChangedAttributes) {\n\t\t// Update our attributes\n\t\tthis.assignAttributes(this.domNodes[0],{excludeEventAttributes: true});\n\t}\n\treturn this.refreshChildren(changedTiddlers) || hasChangedAttributes;\n};\n\nexports.element = ElementWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/encrypt.js": {
"title": "$:/core/modules/widgets/encrypt.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/encrypt.js\ntype: application/javascript\nmodule-type: widget\n\nEncrypt widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar EncryptWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nEncryptWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nEncryptWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tvar textNode = this.document.createTextNode(this.encryptedText);\n\tparent.insertBefore(textNode,nextSibling);\n\tthis.domNodes.push(textNode);\n};\n\n/*\nCompute the internal state of the widget\n*/\nEncryptWidget.prototype.execute = function() {\n\t// Get parameters from our attributes\n\tthis.filter = this.getAttribute(\"filter\",\"[!is[system]]\");\n\t// Encrypt the filtered tiddlers\n\tvar tiddlers = this.wiki.filterTiddlers(this.filter),\n\t\tjson = {},\n\t\tself = this;\n\t$tw.utils.each(tiddlers,function(title) {\n\t\tvar tiddler = self.wiki.getTiddler(title),\n\t\t\tjsonTiddler = {};\n\t\tfor(var f in tiddler.fields) {\n\t\t\tjsonTiddler[f] = tiddler.getFieldString(f);\n\t\t}\n\t\tjson[title] = jsonTiddler;\n\t});\n\tthis.encryptedText = $tw.utils.htmlEncode($tw.crypto.encrypt(JSON.stringify(json)));\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nEncryptWidget.prototype.refresh = function(changedTiddlers) {\n\t// We don't need to worry about refreshing because the encrypt widget isn't for interactive use\n\treturn false;\n};\n\nexports.encrypt = EncryptWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/entity.js": {
"title": "$:/core/modules/widgets/entity.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/entity.js\ntype: application/javascript\nmodule-type: widget\n\nHTML entity widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar EntityWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nEntityWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nEntityWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.execute();\n\tvar entityString = this.getAttribute(\"entity\",this.parseTreeNode.entity || \"\"),\n\t\ttextNode = this.document.createTextNode($tw.utils.entityDecode(entityString));\n\tparent.insertBefore(textNode,nextSibling);\n\tthis.domNodes.push(textNode);\n};\n\n/*\nCompute the internal state of the widget\n*/\nEntityWidget.prototype.execute = function() {\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nEntityWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.entity) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn false;\t\n\t}\n};\n\nexports.entity = EntityWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/fieldmangler.js": {
"title": "$:/core/modules/widgets/fieldmangler.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/fieldmangler.js\ntype: application/javascript\nmodule-type: widget\n\nField mangler widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar FieldManglerWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n\tthis.addEventListeners([\n\t\t{type: \"tm-remove-field\", handler: \"handleRemoveFieldEvent\"},\n\t\t{type: \"tm-add-field\", handler: \"handleAddFieldEvent\"},\n\t\t{type: \"tm-remove-tag\", handler: \"handleRemoveTagEvent\"},\n\t\t{type: \"tm-add-tag\", handler: \"handleAddTagEvent\"}\n\t]);\n};\n\n/*\nInherit from the base widget class\n*/\nFieldManglerWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nFieldManglerWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n};\n\n/*\nCompute the internal state of the widget\n*/\nFieldManglerWidget.prototype.execute = function() {\n\t// Get our parameters\n\tthis.mangleTitle = this.getAttribute(\"tiddler\",this.getVariable(\"currentTiddler\"));\n\t// Construct the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nFieldManglerWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.tiddler) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn this.refreshChildren(changedTiddlers);\t\t\n\t}\n};\n\nFieldManglerWidget.prototype.handleRemoveFieldEvent = function(event) {\n\tvar tiddler = this.wiki.getTiddler(this.mangleTitle),\n\t\tdeletion = {};\n\tdeletion[event.param] = undefined;\n\tthis.wiki.addTiddler(new $tw.Tiddler(tiddler,deletion));\n\treturn true;\n};\n\nFieldManglerWidget.prototype.handleAddFieldEvent = function(event) {\n\tvar tiddler = this.wiki.getTiddler(this.mangleTitle),\n\t\taddition = this.wiki.getModificationFields(),\n\t\thadInvalidFieldName = false,\n\t\taddField = function(name,value) {\n\t\t\tvar trimmedName = name.toLowerCase().trim();\n\t\t\tif(!$tw.utils.isValidFieldName(trimmedName)) {\n\t\t\t\tif(!hadInvalidFieldName) {\n\t\t\t\t\talert($tw.language.getString(\n\t\t\t\t\t\t\"InvalidFieldName\",\n\t\t\t\t\t\t{variables:\n\t\t\t\t\t\t\t{fieldName: trimmedName}\n\t\t\t\t\t\t}\n\t\t\t\t\t));\n\t\t\t\t\thadInvalidFieldName = true;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif(!value && tiddler) {\n\t\t\t\t\tvalue = tiddler.fields[trimmedName];\n\t\t\t\t}\n\t\t\t\taddition[trimmedName] = value || \"\";\n\t\t\t}\n\t\t\treturn;\n\t\t};\n\taddition.title = this.mangleTitle;\n\tif(typeof event.param === \"string\") {\n\t\taddField(event.param,\"\");\n\t}\n\tif(typeof event.paramObject === \"object\") {\n\t\tfor(var name in event.paramObject) {\n\t\t\taddField(name,event.paramObject[name]);\n\t\t}\n\t}\n\tthis.wiki.addTiddler(new $tw.Tiddler(tiddler,addition));\n\treturn true;\n};\n\nFieldManglerWidget.prototype.handleRemoveTagEvent = function(event) {\n\tvar tiddler = this.wiki.getTiddler(this.mangleTitle),\n\t\tmodification = this.wiki.getModificationFields();\n\tif(tiddler && tiddler.fields.tags) {\n\t\tvar p = tiddler.fields.tags.indexOf(event.param);\n\t\tif(p !== -1) {\n\t\t\tmodification.tags = (tiddler.fields.tags || []).slice(0);\n\t\t\tmodification.tags.splice(p,1);\n\t\t\tif(modification.tags.length === 0) {\n\t\t\t\tmodification.tags = undefined;\n\t\t\t}\n\t\t\tthis.wiki.addTiddler(new $tw.Tiddler(tiddler,modification));\n\t\t}\n\t}\n\treturn true;\n};\n\nFieldManglerWidget.prototype.handleAddTagEvent = function(event) {\n\tvar tiddler = this.wiki.getTiddler(this.mangleTitle),\n\t\tmodification = this.wiki.getModificationFields();\n\tif(tiddler && typeof event.param === \"string\") {\n\t\tvar tag = event.param.trim();\n\t\tif(tag !== \"\") {\n\t\t\tmodification.tags = (tiddler.fields.tags || []).slice(0);\n\t\t\t$tw.utils.pushTop(modification.tags,tag);\n\t\t\tthis.wiki.addTiddler(new $tw.Tiddler(tiddler,modification));\t\t\t\n\t\t}\n\t} else if(typeof event.param === \"string\" && event.param.trim() !== \"\" && this.mangleTitle.trim() !== \"\") {\n\t\tvar tag = [];\n\t\ttag.push(event.param.trim());\n\t\tthis.wiki.addTiddler(new $tw.Tiddler({title: this.mangleTitle, tags: tag},modification));\n\t}\n\treturn true;\n};\n\nexports.fieldmangler = FieldManglerWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/fields.js": {
"title": "$:/core/modules/widgets/fields.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/fields.js\ntype: application/javascript\nmodule-type: widget\n\nFields widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar FieldsWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nFieldsWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nFieldsWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tvar textNode = this.document.createTextNode(this.text);\n\tparent.insertBefore(textNode,nextSibling);\n\tthis.domNodes.push(textNode);\n};\n\n/*\nCompute the internal state of the widget\n*/\nFieldsWidget.prototype.execute = function() {\n\t// Get parameters from our attributes\n\tthis.tiddlerTitle = this.getAttribute(\"tiddler\",this.getVariable(\"currentTiddler\"));\n\tthis.template = this.getAttribute(\"template\");\n\tthis.exclude = this.getAttribute(\"exclude\");\n\tthis.stripTitlePrefix = this.getAttribute(\"stripTitlePrefix\",\"no\") === \"yes\";\n\t// Get the value to display\n\tvar tiddler = this.wiki.getTiddler(this.tiddlerTitle);\n\t// Get the exclusion list\n\tvar exclude;\n\tif(this.exclude) {\n\t\texclude = this.exclude.split(\" \");\n\t} else {\n\t\texclude = [\"text\"]; \n\t}\n\t// Compose the template\n\tvar text = [];\n\tif(this.template && tiddler) {\n\t\tvar fields = [];\n\t\tfor(var fieldName in tiddler.fields) {\n\t\t\tif(exclude.indexOf(fieldName) === -1) {\n\t\t\t\tfields.push(fieldName);\n\t\t\t}\n\t\t}\n\t\tfields.sort();\n\t\tfor(var f=0; f<fields.length; f++) {\n\t\t\tfieldName = fields[f];\n\t\t\tif(exclude.indexOf(fieldName) === -1) {\n\t\t\t\tvar row = this.template,\n\t\t\t\t\tvalue = tiddler.getFieldString(fieldName);\n\t\t\t\tif(this.stripTitlePrefix && fieldName === \"title\") {\n\t\t\t\t\tvar reStrip = /^\\{[^\\}]+\\}(.+)/mg,\n\t\t\t\t\t\treMatch = reStrip.exec(value);\n\t\t\t\t\tif(reMatch) {\n\t\t\t\t\t\tvalue = reMatch[1];\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\trow = $tw.utils.replaceString(row,\"$name$\",fieldName);\n\t\t\t\trow = $tw.utils.replaceString(row,\"$value$\",value);\n\t\t\t\trow = $tw.utils.replaceString(row,\"$encoded_value$\",$tw.utils.htmlEncode(value));\n\t\t\t\ttext.push(row);\n\t\t\t}\n\t\t}\n\t}\n\tthis.text = text.join(\"\");\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nFieldsWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.tiddler || changedAttributes.template || changedAttributes.exclude || changedAttributes.stripTitlePrefix || changedTiddlers[this.tiddlerTitle]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn false;\t\n\t}\n};\n\nexports.fields = FieldsWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/image.js": {
"title": "$:/core/modules/widgets/image.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/image.js\ntype: application/javascript\nmodule-type: widget\n\nThe image widget displays an image referenced with an external URI or with a local tiddler title.\n\n```\n<$image src=\"TiddlerTitle\" width=\"320\" height=\"400\" class=\"classnames\">\n```\n\nThe image source can be the title of an existing tiddler or the URL of an external image.\n\nExternal images always generate an HTML `<img>` tag.\n\nTiddlers that have a _canonical_uri field generate an HTML `<img>` tag with the src attribute containing the URI.\n\nTiddlers that contain image data generate an HTML `<img>` tag with the src attribute containing a base64 representation of the image.\n\nTiddlers that contain wikitext could be rendered to a DIV of the usual size of a tiddler, and then transformed to the size requested.\n\nThe width and height attributes are interpreted as a number of pixels, and do not need to include the \"px\" suffix.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar ImageWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nImageWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nImageWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\t// Create element\n\t// Determine what type of image it is\n\tvar tag = \"img\", src = \"\",\n\t\ttiddler = this.wiki.getTiddler(this.imageSource);\n\tif(!tiddler) {\n\t\t// The source isn't the title of a tiddler, so we'll assume it's a URL\n\t\tsrc = this.getVariable(\"tv-get-export-image-link\",{params: [{name: \"src\",value: this.imageSource}],defaultValue: this.imageSource});\n\t} else {\n\t\t// Check if it is an image tiddler\n\t\tif(this.wiki.isImageTiddler(this.imageSource)) {\n\t\t\tvar type = tiddler.fields.type,\n\t\t\t\ttext = tiddler.fields.text,\n\t\t\t\t_canonical_uri = tiddler.fields._canonical_uri;\n\t\t\t// If the tiddler has body text then it doesn't need to be lazily loaded\n\t\t\tif(text) {\n\t\t\t\t// Render the appropriate element for the image type\n\t\t\t\tswitch(type) {\n\t\t\t\t\tcase \"application/pdf\":\n\t\t\t\t\t\ttag = \"embed\";\n\t\t\t\t\t\tsrc = \"data:application/pdf;base64,\" + text;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase \"image/svg+xml\":\n\t\t\t\t\t\tsrc = \"data:image/svg+xml,\" + encodeURIComponent(text);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tsrc = \"data:\" + type + \";base64,\" + text;\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t} else if(_canonical_uri) {\n\t\t\t\tswitch(type) {\n\t\t\t\t\tcase \"application/pdf\":\n\t\t\t\t\t\ttag = \"embed\";\n\t\t\t\t\t\tsrc = _canonical_uri;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase \"image/svg+xml\":\n\t\t\t\t\t\tsrc = _canonical_uri;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tsrc = _canonical_uri;\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\t\n\t\t\t} else {\n\t\t\t\t// Just trigger loading of the tiddler\n\t\t\t\tthis.wiki.getTiddlerText(this.imageSource);\n\t\t\t}\n\t\t}\n\t}\n\t// Create the element and assign the attributes\n\tvar domNode = this.document.createElement(tag);\n\tdomNode.setAttribute(\"src\",src);\n\tif(this.imageClass) {\n\t\tdomNode.setAttribute(\"class\",this.imageClass);\t\t\n\t}\n\tif(this.imageWidth) {\n\t\tdomNode.setAttribute(\"width\",this.imageWidth);\n\t}\n\tif(this.imageHeight) {\n\t\tdomNode.setAttribute(\"height\",this.imageHeight);\n\t}\n\tif(this.imageTooltip) {\n\t\tdomNode.setAttribute(\"title\",this.imageTooltip);\t\t\n\t}\n\tif(this.imageAlt) {\n\t\tdomNode.setAttribute(\"alt\",this.imageAlt);\t\t\n\t}\n\t// Insert element\n\tparent.insertBefore(domNode,nextSibling);\n\tthis.domNodes.push(domNode);\n};\n\n/*\nCompute the internal state of the widget\n*/\nImageWidget.prototype.execute = function() {\n\t// Get our parameters\n\tthis.imageSource = this.getAttribute(\"source\");\n\tthis.imageWidth = this.getAttribute(\"width\");\n\tthis.imageHeight = this.getAttribute(\"height\");\n\tthis.imageClass = this.getAttribute(\"class\");\n\tthis.imageTooltip = this.getAttribute(\"tooltip\");\n\tthis.imageAlt = this.getAttribute(\"alt\");\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nImageWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.source || changedAttributes.width || changedAttributes.height || changedAttributes[\"class\"] || changedAttributes.tooltip || changedTiddlers[this.imageSource]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn false;\t\t\n\t}\n};\n\nexports.image = ImageWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/importvariables.js": {
"title": "$:/core/modules/widgets/importvariables.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/importvariables.js\ntype: application/javascript\nmodule-type: widget\n\nImport variable definitions from other tiddlers\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar ImportVariablesWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nImportVariablesWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nImportVariablesWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n};\n\n/*\nCompute the internal state of the widget\n*/\nImportVariablesWidget.prototype.execute = function(tiddlerList) {\n\tvar self = this;\n\t// Get our parameters\n\tthis.filter = this.getAttribute(\"filter\");\n\t// Compute the filter\n\tthis.tiddlerList = tiddlerList || this.wiki.filterTiddlers(this.filter,this);\n\t// Accumulate the <$set> widgets from each tiddler\n\tvar widgetStackStart,widgetStackEnd;\n\tfunction addWidgetNode(widgetNode) {\n\t\tif(widgetNode) {\n\t\t\tif(!widgetStackStart && !widgetStackEnd) {\n\t\t\t\twidgetStackStart = widgetNode;\n\t\t\t\twidgetStackEnd = widgetNode;\n\t\t\t} else {\n\t\t\t\twidgetStackEnd.children = [widgetNode];\n\t\t\t\twidgetStackEnd = widgetNode;\n\t\t\t}\n\t\t}\n\t}\n\t$tw.utils.each(this.tiddlerList,function(title) {\n\t\tvar parser = self.wiki.parseTiddler(title);\n\t\tif(parser) {\n\t\t\tvar parseTreeNode = parser.tree[0];\n\t\t\twhile(parseTreeNode && parseTreeNode.type === \"set\") {\n\t\t\t\taddWidgetNode({\n\t\t\t\t\ttype: \"set\",\n\t\t\t\t\tattributes: parseTreeNode.attributes,\n\t\t\t\t\tparams: parseTreeNode.params,\n\t\t\t\t\tisMacroDefinition: parseTreeNode.isMacroDefinition\n\t\t\t\t});\n\t\t\t\tparseTreeNode = parseTreeNode.children[0];\n\t\t\t}\n\t\t} \n\t});\n\t// Add our own children to the end of the pile\n\tvar parseTreeNodes;\n\tif(widgetStackStart && widgetStackEnd) {\n\t\tparseTreeNodes = [widgetStackStart];\n\t\twidgetStackEnd.children = this.parseTreeNode.children;\n\t} else {\n\t\tparseTreeNodes = this.parseTreeNode.children;\n\t}\n\t// Construct the child widgets\n\tthis.makeChildWidgets(parseTreeNodes);\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nImportVariablesWidget.prototype.refresh = function(changedTiddlers) {\n\t// Recompute our attributes and the filter list\n\tvar changedAttributes = this.computeAttributes(),\n\t\ttiddlerList = this.wiki.filterTiddlers(this.getAttribute(\"filter\"),this);\n\t// Refresh if the filter has changed, or the list of tiddlers has changed, or any of the tiddlers in the list has changed\n\tfunction haveListedTiddlersChanged() {\n\t\tvar changed = false;\n\t\ttiddlerList.forEach(function(title) {\n\t\t\tif(changedTiddlers[title]) {\n\t\t\t\tchanged = true;\n\t\t\t}\n\t\t});\n\t\treturn changed;\n\t}\n\tif(changedAttributes.filter || !$tw.utils.isArrayEqual(this.tiddlerList,tiddlerList) || haveListedTiddlersChanged()) {\n\t\t// Compute the filter\n\t\tthis.removeChildDomNodes();\n\t\tthis.execute(tiddlerList);\n\t\tthis.renderChildren(this.parentDomNode,this.findNextSiblingDomNode());\n\t\treturn true;\n\t} else {\n\t\treturn this.refreshChildren(changedTiddlers);\t\t\n\t}\n};\n\nexports.importvariables = ImportVariablesWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/keyboard.js": {
"title": "$:/core/modules/widgets/keyboard.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/keyboard.js\ntype: application/javascript\nmodule-type: widget\n\nKeyboard shortcut widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar KeyboardWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nKeyboardWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nKeyboardWidget.prototype.render = function(parent,nextSibling) {\n\tvar self = this;\n\t// Remember parent\n\tthis.parentDomNode = parent;\n\t// Compute attributes and execute state\n\tthis.computeAttributes();\n\tthis.execute();\n\tvar tag = this.parseTreeNode.isBlock ? \"div\" : \"span\";\n\tif(this.tag && $tw.config.htmlUnsafeElements.indexOf(this.tag) === -1) {\n\t\ttag = this.tag;\n\t}\n\t// Create element\n\tvar domNode = this.document.createElement(tag);\n\t// Assign classes\n\tvar classes = (this[\"class\"] || \"\").split(\" \");\n\tclasses.push(\"tc-keyboard\");\n\tdomNode.className = classes.join(\" \");\n\t// Add a keyboard event handler\n\tdomNode.addEventListener(\"keydown\",function (event) {\n\t\tif($tw.keyboardManager.checkKeyDescriptors(event,self.keyInfoArray)) {\n\t\t\tself.invokeActions(self,event);\n\t\t\tif(self.actions) {\n\t\t\t\tself.invokeActionString(self.actions,self,event);\n\t\t\t}\n\t\t\tself.dispatchMessage(event);\n\t\t\tevent.preventDefault();\n\t\t\tevent.stopPropagation();\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t},false);\n\t// Insert element\n\tparent.insertBefore(domNode,nextSibling);\n\tthis.renderChildren(domNode,null);\n\tthis.domNodes.push(domNode);\n};\n\nKeyboardWidget.prototype.dispatchMessage = function(event) {\n\tthis.dispatchEvent({type: this.message, param: this.param, tiddlerTitle: this.getVariable(\"currentTiddler\")});\n};\n\n/*\nCompute the internal state of the widget\n*/\nKeyboardWidget.prototype.execute = function() {\n\tvar self = this;\n\t// Get attributes\n\tthis.actions = this.getAttribute(\"actions\");\n\tthis.message = this.getAttribute(\"message\");\n\tthis.param = this.getAttribute(\"param\");\n\tthis.key = this.getAttribute(\"key\");\n\tthis.tag = this.getAttribute(\"tag\");\n\tthis.keyInfoArray = $tw.keyboardManager.parseKeyDescriptors(this.key);\n\tthis[\"class\"] = this.getAttribute(\"class\");\n\tif(this.key.substr(0,2) === \"((\" && this.key.substr(-2,2) === \"))\") {\n\t\tthis.shortcutTiddlers = [];\n\t\tvar name = this.key.substring(2,this.key.length -2);\n\t\t$tw.utils.each($tw.keyboardManager.lookupNames,function(platformDescriptor) {\n\t\t\tself.shortcutTiddlers.push(\"$:/config/\" + platformDescriptor + \"/\" + name);\n\t\t});\n\t}\n\t// Make child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nKeyboardWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.message || changedAttributes.param || changedAttributes.key || changedAttributes[\"class\"] || changedAttributes.tag) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\t// Update the keyInfoArray if one of its shortcut-config-tiddlers has changed\n\tif(this.shortcutTiddlers && $tw.utils.hopArray(changedTiddlers,this.shortcutTiddlers)) {\n\t\tthis.keyInfoArray = $tw.keyboardManager.parseKeyDescriptors(this.key);\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\nexports.keyboard = KeyboardWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/link.js": {
"title": "$:/core/modules/widgets/link.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/link.js\ntype: application/javascript\nmodule-type: widget\n\nLink widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar LinkWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nLinkWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nLinkWidget.prototype.render = function(parent,nextSibling) {\n\t// Save the parent dom node\n\tthis.parentDomNode = parent;\n\t// Compute our attributes\n\tthis.computeAttributes();\n\t// Execute our logic\n\tthis.execute();\n\t// Get the value of the tv-wikilinks configuration macro\n\tvar wikiLinksMacro = this.getVariable(\"tv-wikilinks\"),\n\t\tuseWikiLinks = wikiLinksMacro ? (wikiLinksMacro.trim() !== \"no\") : true,\n\t\tmissingLinksEnabled = !(this.hideMissingLinks && this.isMissing && !this.isShadow);\n\t// Render the link if required\n\tif(useWikiLinks && missingLinksEnabled) {\n\t\tthis.renderLink(parent,nextSibling);\n\t} else {\n\t\t// Just insert the link text\n\t\tvar domNode = this.document.createElement(\"span\");\n\t\tparent.insertBefore(domNode,nextSibling);\n\t\tthis.renderChildren(domNode,null);\n\t\tthis.domNodes.push(domNode);\n\t}\n};\n\n/*\nRender this widget into the DOM\n*/\nLinkWidget.prototype.renderLink = function(parent,nextSibling) {\n\tvar self = this;\n\t// Sanitise the specified tag\n\tvar tag = this.linkTag;\n\tif($tw.config.htmlUnsafeElements.indexOf(tag) !== -1) {\n\t\ttag = \"a\";\n\t}\n\t// Create our element\n\tvar domNode = this.document.createElement(tag);\n\t// Assign classes\n\tvar classes = [];\n\tif(this.overrideClasses === undefined) {\n\t\tclasses.push(\"tc-tiddlylink\");\n\t\tif(this.isShadow) {\n\t\t\tclasses.push(\"tc-tiddlylink-shadow\");\n\t\t}\n\t\tif(this.isMissing && !this.isShadow) {\n\t\t\tclasses.push(\"tc-tiddlylink-missing\");\n\t\t} else {\n\t\t\tif(!this.isMissing) {\n\t\t\t\tclasses.push(\"tc-tiddlylink-resolves\");\n\t\t\t}\n\t\t}\n\t\tif(this.linkClasses) {\n\t\t\tclasses.push(this.linkClasses);\t\t\t\n\t\t}\n\t} else if(this.overrideClasses !== \"\") {\n\t\tclasses.push(this.overrideClasses)\n\t}\n\tif(classes.length > 0) {\n\t\tdomNode.setAttribute(\"class\",classes.join(\" \"));\n\t}\n\t// Set an href\n\tvar wikilinkTransformFilter = this.getVariable(\"tv-filter-export-link\"),\n\t\twikiLinkText;\n\tif(wikilinkTransformFilter) {\n\t\t// Use the filter to construct the href\n\t\twikiLinkText = this.wiki.filterTiddlers(wikilinkTransformFilter,this,function(iterator) {\n\t\t\titerator(self.wiki.getTiddler(self.to),self.to)\n\t\t})[0];\n\t} else {\n\t\t// Expand the tv-wikilink-template variable to construct the href\n\t\tvar wikiLinkTemplateMacro = this.getVariable(\"tv-wikilink-template\"),\n\t\t\twikiLinkTemplate = wikiLinkTemplateMacro ? wikiLinkTemplateMacro.trim() : \"#$uri_encoded$\";\n\t\twikiLinkText = $tw.utils.replaceString(wikiLinkTemplate,\"$uri_encoded$\",encodeURIComponent(this.to));\n\t\twikiLinkText = $tw.utils.replaceString(wikiLinkText,\"$uri_doubleencoded$\",encodeURIComponent(encodeURIComponent(this.to)));\n\t}\n\t// Override with the value of tv-get-export-link if defined\n\twikiLinkText = this.getVariable(\"tv-get-export-link\",{params: [{name: \"to\",value: this.to}],defaultValue: wikiLinkText});\n\tif(tag === \"a\") {\n\t\tdomNode.setAttribute(\"href\",wikiLinkText);\n\t}\n\t// Set the tabindex\n\tif(this.tabIndex) {\n\t\tdomNode.setAttribute(\"tabindex\",this.tabIndex);\n\t}\n\t// Set the tooltip\n\t// HACK: Performance issues with re-parsing the tooltip prevent us defaulting the tooltip to \"<$transclude field='tooltip'><$transclude field='title'/></$transclude>\"\n\tvar tooltipWikiText = this.tooltip || this.getVariable(\"tv-wikilink-tooltip\");\n\tif(tooltipWikiText) {\n\t\tvar tooltipText = this.wiki.renderText(\"text/plain\",\"text/vnd.tiddlywiki\",tooltipWikiText,{\n\t\t\t\tparseAsInline: true,\n\t\t\t\tvariables: {\n\t\t\t\t\tcurrentTiddler: this.to\n\t\t\t\t},\n\t\t\t\tparentWidget: this\n\t\t\t});\n\t\tdomNode.setAttribute(\"title\",tooltipText);\n\t}\n\tif(this[\"aria-label\"]) {\n\t\tdomNode.setAttribute(\"aria-label\",this[\"aria-label\"]);\n\t}\n\t// Add a click event handler\n\t$tw.utils.addEventListeners(domNode,[\n\t\t{name: \"click\", handlerObject: this, handlerMethod: \"handleClickEvent\"},\n\t]);\n\t// Make the link draggable if required\n\tif(this.draggable === \"yes\") {\n\t\t$tw.utils.makeDraggable({\n\t\t\tdomNode: domNode,\n\t\t\tdragTiddlerFn: function() {return self.to;},\n\t\t\twidget: this\n\t\t});\n\t}\n\t// Insert the link into the DOM and render any children\n\tparent.insertBefore(domNode,nextSibling);\n\tthis.renderChildren(domNode,null);\n\tthis.domNodes.push(domNode);\n};\n\nLinkWidget.prototype.handleClickEvent = function(event) {\n\t// Send the click on its way as a navigate event\n\tvar bounds = this.domNodes[0].getBoundingClientRect();\n\tthis.dispatchEvent({\n\t\ttype: \"tm-navigate\",\n\t\tnavigateTo: this.to,\n\t\tnavigateFromTitle: this.getVariable(\"storyTiddler\"),\n\t\tnavigateFromNode: this,\n\t\tnavigateFromClientRect: { top: bounds.top, left: bounds.left, width: bounds.width, right: bounds.right, bottom: bounds.bottom, height: bounds.height\n\t\t},\n\t\tnavigateSuppressNavigation: event.metaKey || event.ctrlKey || (event.button === 1),\n\t\tmetaKey: event.metaKey,\n\t\tctrlKey: event.ctrlKey,\n\t\taltKey: event.altKey,\n\t\tshiftKey: event.shiftKey\n\t});\n\tif(this.domNodes[0].hasAttribute(\"href\")) {\n\t\tevent.preventDefault();\n\t}\n\tevent.stopPropagation();\n\treturn false;\n};\n\n/*\nCompute the internal state of the widget\n*/\nLinkWidget.prototype.execute = function() {\n\t// Pick up our attributes\n\tthis.to = this.getAttribute(\"to\",this.getVariable(\"currentTiddler\"));\n\tthis.tooltip = this.getAttribute(\"tooltip\");\n\tthis[\"aria-label\"] = this.getAttribute(\"aria-label\");\n\tthis.linkClasses = this.getAttribute(\"class\");\n\tthis.overrideClasses = this.getAttribute(\"overrideClass\");\n\tthis.tabIndex = this.getAttribute(\"tabindex\");\n\tthis.draggable = this.getAttribute(\"draggable\",\"yes\");\n\tthis.linkTag = this.getAttribute(\"tag\",\"a\");\n\t// Determine the link characteristics\n\tthis.isMissing = !this.wiki.tiddlerExists(this.to);\n\tthis.isShadow = this.wiki.isShadowTiddler(this.to);\n\tthis.hideMissingLinks = (this.getVariable(\"tv-show-missing-links\") || \"yes\") === \"no\";\n\t// Make the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nLinkWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.to || changedTiddlers[this.to] || changedAttributes[\"aria-label\"] || changedAttributes.tooltip) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\nexports.link = LinkWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/linkcatcher.js": {
"title": "$:/core/modules/widgets/linkcatcher.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/linkcatcher.js\ntype: application/javascript\nmodule-type: widget\n\nLinkcatcher widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar LinkCatcherWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n\tthis.addEventListeners([\n\t\t{type: \"tm-navigate\", handler: \"handleNavigateEvent\"}\n\t]);\n};\n\n/*\nInherit from the base widget class\n*/\nLinkCatcherWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nLinkCatcherWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n};\n\n/*\nCompute the internal state of the widget\n*/\nLinkCatcherWidget.prototype.execute = function() {\n\t// Get our parameters\n\tthis.catchTo = this.getAttribute(\"to\");\n\tthis.catchMessage = this.getAttribute(\"message\");\n\tthis.catchSet = this.getAttribute(\"set\");\n\tthis.catchSetTo = this.getAttribute(\"setTo\");\n\tthis.catchActions = this.getAttribute(\"actions\");\n\t// Construct the child widgets\n\tthis.makeChildWidgets();\n\t// When executing actions we avoid trapping navigate events, so that we don't trigger ourselves recursively\n\tthis.executingActions = false;\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nLinkCatcherWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.to || changedAttributes.message || changedAttributes.set || changedAttributes.setTo) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn this.refreshChildren(changedTiddlers);\t\t\n\t}\n};\n\n/*\nHandle a tm-navigate event\n*/\nLinkCatcherWidget.prototype.handleNavigateEvent = function(event) {\n\tif(!this.executingActions) {\n\t\t// Execute the actions\n\t\tif(this.catchTo) {\n\t\t\tthis.wiki.setTextReference(this.catchTo,event.navigateTo,this.getVariable(\"currentTiddler\"));\n\t\t}\n\t\tif(this.catchMessage && this.parentWidget) {\n\t\t\tthis.parentWidget.dispatchEvent({\n\t\t\t\ttype: this.catchMessage,\n\t\t\t\tparam: event.navigateTo,\n\t\t\t\tnavigateTo: event.navigateTo\n\t\t\t});\n\t\t}\n\t\tif(this.catchSet) {\n\t\t\tvar tiddler = this.wiki.getTiddler(this.catchSet);\n\t\t\tthis.wiki.addTiddler(new $tw.Tiddler(tiddler,{title: this.catchSet, text: this.catchSetTo}));\n\t\t}\n\t\tif(this.catchActions) {\n\t\t\tthis.executingActions = true;\n\t\t\tthis.invokeActionString(this.catchActions,this,event,{navigateTo: event.navigateTo});\n\t\t\tthis.executingActions = false;\n\t\t}\n\t} else {\n\t\t// This is a navigate event generated by the actions of this linkcatcher, so we don't trap it again, but just pass it to the parent\n\t\tthis.parentWidget.dispatchEvent({\n\t\t\ttype: \"tm-navigate\",\n\t\t\tparam: event.navigateTo,\n\t\t\tnavigateTo: event.navigateTo\n\t\t});\n\t}\n\treturn false;\n};\n\nexports.linkcatcher = LinkCatcherWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/list.js": {
"title": "$:/core/modules/widgets/list.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/list.js\ntype: application/javascript\nmodule-type: widget\n\nList and list item widgets\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\n/*\nThe list widget creates list element sub-widgets that reach back into the list widget for their configuration\n*/\n\nvar ListWidget = function(parseTreeNode,options) {\n\t// Initialise the storyviews if they've not been done already\n\tif(!this.storyViews) {\n\t\tListWidget.prototype.storyViews = {};\n\t\t$tw.modules.applyMethods(\"storyview\",this.storyViews);\n\t}\n\t// Main initialisation inherited from widget.js\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nListWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nListWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n\t// Construct the storyview\n\tvar StoryView = this.storyViews[this.storyViewName];\n\tif(this.storyViewName && !StoryView) {\n\t\tStoryView = this.storyViews[\"classic\"];\n\t}\n\tif(StoryView && !this.document.isTiddlyWikiFakeDom) {\n\t\tthis.storyview = new StoryView(this);\n\t} else {\n\t\tthis.storyview = null;\n\t}\n};\n\n/*\nCompute the internal state of the widget\n*/\nListWidget.prototype.execute = function() {\n\t// Get our attributes\n\tthis.template = this.getAttribute(\"template\");\n\tthis.editTemplate = this.getAttribute(\"editTemplate\");\n\tthis.variableName = this.getAttribute(\"variable\",\"currentTiddler\");\n\tthis.storyViewName = this.getAttribute(\"storyview\");\n\tthis.historyTitle = this.getAttribute(\"history\");\n\t// Compose the list elements\n\tthis.list = this.getTiddlerList();\n\tvar members = [],\n\t\tself = this;\n\t// Check for an empty list\n\tif(this.list.length === 0) {\n\t\tmembers = this.getEmptyMessage();\n\t} else {\n\t\t$tw.utils.each(this.list,function(title,index) {\n\t\t\tmembers.push(self.makeItemTemplate(title));\n\t\t});\n\t}\n\t// Construct the child widgets\n\tthis.makeChildWidgets(members);\n\t// Clear the last history\n\tthis.history = [];\n};\n\nListWidget.prototype.getTiddlerList = function() {\n\tvar defaultFilter = \"[!is[system]sort[title]]\";\n\treturn this.wiki.filterTiddlers(this.getAttribute(\"filter\",defaultFilter),this);\n};\n\nListWidget.prototype.getEmptyMessage = function() {\n\tvar emptyMessage = this.getAttribute(\"emptyMessage\",\"\"),\n\t\tparser = this.wiki.parseText(\"text/vnd.tiddlywiki\",emptyMessage,{parseAsInline: true});\n\tif(parser) {\n\t\treturn parser.tree;\n\t} else {\n\t\treturn [];\n\t}\n};\n\n/*\nCompose the template for a list item\n*/\nListWidget.prototype.makeItemTemplate = function(title) {\n\t// Check if the tiddler is a draft\n\tvar tiddler = this.wiki.getTiddler(title),\n\t\tisDraft = tiddler && tiddler.hasField(\"draft.of\"),\n\t\ttemplate = this.template,\n\t\ttemplateTree;\n\tif(isDraft && this.editTemplate) {\n\t\ttemplate = this.editTemplate;\n\t}\n\t// Compose the transclusion of the template\n\tif(template) {\n\t\ttemplateTree = [{type: \"transclude\", attributes: {tiddler: {type: \"string\", value: template}}}];\n\t} else {\n\t\tif(this.parseTreeNode.children && this.parseTreeNode.children.length > 0) {\n\t\t\ttemplateTree = this.parseTreeNode.children;\n\t\t} else {\n\t\t\t// Default template is a link to the title\n\t\t\ttemplateTree = [{type: \"element\", tag: this.parseTreeNode.isBlock ? \"div\" : \"span\", children: [{type: \"link\", attributes: {to: {type: \"string\", value: title}}, children: [\n\t\t\t\t\t{type: \"text\", text: title}\n\t\t\t]}]}];\n\t\t}\n\t}\n\t// Return the list item\n\treturn {type: \"listitem\", itemTitle: title, variableName: this.variableName, children: templateTree};\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nListWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes(),\n\t\tresult;\n\t// Call the storyview\n\tif(this.storyview && this.storyview.refreshStart) {\n\t\tthis.storyview.refreshStart(changedTiddlers,changedAttributes);\n\t}\n\t// Completely refresh if any of our attributes have changed\n\tif(changedAttributes.filter || changedAttributes.template || changedAttributes.editTemplate || changedAttributes.emptyMessage || changedAttributes.storyview || changedAttributes.history) {\n\t\tthis.refreshSelf();\n\t\tresult = true;\n\t} else {\n\t\t// Handle any changes to the list\n\t\tresult = this.handleListChanges(changedTiddlers);\n\t\t// Handle any changes to the history stack\n\t\tif(this.historyTitle && changedTiddlers[this.historyTitle]) {\n\t\t\tthis.handleHistoryChanges();\n\t\t}\n\t}\n\t// Call the storyview\n\tif(this.storyview && this.storyview.refreshEnd) {\n\t\tthis.storyview.refreshEnd(changedTiddlers,changedAttributes);\n\t}\n\treturn result;\n};\n\n/*\nHandle any changes to the history list\n*/\nListWidget.prototype.handleHistoryChanges = function() {\n\t// Get the history data\n\tvar newHistory = this.wiki.getTiddlerDataCached(this.historyTitle,[]);\n\t// Ignore any entries of the history that match the previous history\n\tvar entry = 0;\n\twhile(entry < newHistory.length && entry < this.history.length && newHistory[entry].title === this.history[entry].title) {\n\t\tentry++;\n\t}\n\t// Navigate forwards to each of the new tiddlers\n\twhile(entry < newHistory.length) {\n\t\tif(this.storyview && this.storyview.navigateTo) {\n\t\t\tthis.storyview.navigateTo(newHistory[entry]);\n\t\t}\n\t\tentry++;\n\t}\n\t// Update the history\n\tthis.history = newHistory;\n};\n\n/*\nProcess any changes to the list\n*/\nListWidget.prototype.handleListChanges = function(changedTiddlers) {\n\t// Get the new list\n\tvar prevList = this.list;\n\tthis.list = this.getTiddlerList();\n\t// Check for an empty list\n\tif(this.list.length === 0) {\n\t\t// Check if it was empty before\n\t\tif(prevList.length === 0) {\n\t\t\t// If so, just refresh the empty message\n\t\t\treturn this.refreshChildren(changedTiddlers);\n\t\t} else {\n\t\t\t// Replace the previous content with the empty message\n\t\t\tfor(t=this.children.length-1; t>=0; t--) {\n\t\t\t\tthis.removeListItem(t);\n\t\t\t}\n\t\t\tvar nextSibling = this.findNextSiblingDomNode();\n\t\t\tthis.makeChildWidgets(this.getEmptyMessage());\n\t\t\tthis.renderChildren(this.parentDomNode,nextSibling);\n\t\t\treturn true;\n\t\t}\n\t} else {\n\t\t// If the list was empty then we need to remove the empty message\n\t\tif(prevList.length === 0) {\n\t\t\tthis.removeChildDomNodes();\n\t\t\tthis.children = [];\n\t\t}\n\t\t// Cycle through the list, inserting and removing list items as needed\n\t\tvar hasRefreshed = false;\n\t\tfor(var t=0; t<this.list.length; t++) {\n\t\t\tvar index = this.findListItem(t,this.list[t]);\n\t\t\tif(index === undefined) {\n\t\t\t\t// The list item must be inserted\n\t\t\t\tthis.insertListItem(t,this.list[t]);\n\t\t\t\thasRefreshed = true;\n\t\t\t} else {\n\t\t\t\t// There are intervening list items that must be removed\n\t\t\t\tfor(var n=index-1; n>=t; n--) {\n\t\t\t\t\tthis.removeListItem(n);\n\t\t\t\t\thasRefreshed = true;\n\t\t\t\t}\n\t\t\t\t// Refresh the item we're reusing\n\t\t\t\tvar refreshed = this.children[t].refresh(changedTiddlers);\n\t\t\t\thasRefreshed = hasRefreshed || refreshed;\n\t\t\t}\n\t\t}\n\t\t// Remove any left over items\n\t\tfor(t=this.children.length-1; t>=this.list.length; t--) {\n\t\t\tthis.removeListItem(t);\n\t\t\thasRefreshed = true;\n\t\t}\n\t\treturn hasRefreshed;\n\t}\n};\n\n/*\nFind the list item with a given title, starting from a specified position\n*/\nListWidget.prototype.findListItem = function(startIndex,title) {\n\twhile(startIndex < this.children.length) {\n\t\tif(this.children[startIndex].parseTreeNode.itemTitle === title) {\n\t\t\treturn startIndex;\n\t\t}\n\t\tstartIndex++;\n\t}\n\treturn undefined;\n};\n\n/*\nInsert a new list item at the specified index\n*/\nListWidget.prototype.insertListItem = function(index,title) {\n\t// Create, insert and render the new child widgets\n\tvar widget = this.makeChildWidget(this.makeItemTemplate(title));\n\twidget.parentDomNode = this.parentDomNode; // Hack to enable findNextSiblingDomNode() to work\n\tthis.children.splice(index,0,widget);\n\tvar nextSibling = widget.findNextSiblingDomNode();\n\twidget.render(this.parentDomNode,nextSibling);\n\t// Animate the insertion if required\n\tif(this.storyview && this.storyview.insert) {\n\t\tthis.storyview.insert(widget);\n\t}\n\treturn true;\n};\n\n/*\nRemove the specified list item\n*/\nListWidget.prototype.removeListItem = function(index) {\n\tvar widget = this.children[index];\n\t// Animate the removal if required\n\tif(this.storyview && this.storyview.remove) {\n\t\tthis.storyview.remove(widget);\n\t} else {\n\t\twidget.removeChildDomNodes();\n\t}\n\t// Remove the child widget\n\tthis.children.splice(index,1);\n};\n\nexports.list = ListWidget;\n\nvar ListItemWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nListItemWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nListItemWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n};\n\n/*\nCompute the internal state of the widget\n*/\nListItemWidget.prototype.execute = function() {\n\t// Set the current list item title\n\tthis.setVariable(this.parseTreeNode.variableName,this.parseTreeNode.itemTitle);\n\t// Construct the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nListItemWidget.prototype.refresh = function(changedTiddlers) {\n\treturn this.refreshChildren(changedTiddlers);\n};\n\nexports.listitem = ListItemWidget;\n\n})();",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/macrocall.js": {
"title": "$:/core/modules/widgets/macrocall.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/macrocall.js\ntype: application/javascript\nmodule-type: widget\n\nMacrocall widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar MacroCallWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nMacroCallWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nMacroCallWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n};\n\n/*\nCompute the internal state of the widget\n*/\nMacroCallWidget.prototype.execute = function() {\n\t// Get the parse type if specified\n\tthis.parseType = this.getAttribute(\"$type\",\"text/vnd.tiddlywiki\");\n\tthis.renderOutput = this.getAttribute(\"$output\",\"text/html\");\n\t// Merge together the parameters specified in the parse tree with the specified attributes\n\tvar params = this.parseTreeNode.params ? this.parseTreeNode.params.slice(0) : [];\n\t$tw.utils.each(this.attributes,function(attribute,name) {\n\t\tif(name.charAt(0) !== \"$\") {\n\t\t\tparams.push({name: name, value: attribute});\t\t\t\n\t\t}\n\t});\n\t// Get the macro value\n\tvar macroName = this.parseTreeNode.name || this.getAttribute(\"$name\"),\n\t\tvariableInfo = this.getVariableInfo(macroName,{params: params}),\n\t\ttext = variableInfo.text,\n\t\tparseTreeNodes;\n\t// Are we rendering to HTML?\n\tif(this.renderOutput === \"text/html\") {\n\t\t// If so we'll return the parsed macro\n\t\tvar parser = this.wiki.parseText(this.parseType,text,\n\t\t\t\t\t\t\t{parseAsInline: !this.parseTreeNode.isBlock});\n\t\tparseTreeNodes = parser ? parser.tree : [];\n\t\t// Wrap the parse tree in a vars widget assigning the parameters to variables named \"__paramname__\"\n\t\tvar attributes = {};\n\t\t$tw.utils.each(variableInfo.params,function(param) {\n\t\t\tvar name = \"__\" + param.name + \"__\";\n\t\t\tattributes[name] = {\n\t\t\t\tname: name,\n\t\t\t\ttype: \"string\",\n\t\t\t\tvalue: param.value\n\t\t\t};\n\t\t});\n\t\tparseTreeNodes = [{\n\t\t\ttype: \"vars\",\n\t\t\tattributes: attributes,\n\t\t\tchildren: parseTreeNodes\n\t\t}];\n\t} else {\n\t\t// Otherwise, we'll render the text\n\t\tvar plainText = this.wiki.renderText(\"text/plain\",this.parseType,text,{parentWidget: this});\n\t\tparseTreeNodes = [{type: \"text\", text: plainText}];\n\t}\n\t// Construct the child widgets\n\tthis.makeChildWidgets(parseTreeNodes);\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nMacroCallWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif($tw.utils.count(changedAttributes) > 0) {\n\t\t// Rerender ourselves\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn this.refreshChildren(changedTiddlers);\n\t}\n};\n\nexports.macrocall = MacroCallWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/navigator.js": {
"title": "$:/core/modules/widgets/navigator.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/navigator.js\ntype: application/javascript\nmodule-type: widget\n\nNavigator widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar IMPORT_TITLE = \"$:/Import\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar NavigatorWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n\tthis.addEventListeners([\n\t\t{type: \"tm-navigate\", handler: \"handleNavigateEvent\"},\n\t\t{type: \"tm-edit-tiddler\", handler: \"handleEditTiddlerEvent\"},\n\t\t{type: \"tm-delete-tiddler\", handler: \"handleDeleteTiddlerEvent\"},\n\t\t{type: \"tm-save-tiddler\", handler: \"handleSaveTiddlerEvent\"},\n\t\t{type: \"tm-cancel-tiddler\", handler: \"handleCancelTiddlerEvent\"},\n\t\t{type: \"tm-close-tiddler\", handler: \"handleCloseTiddlerEvent\"},\n\t\t{type: \"tm-close-all-tiddlers\", handler: \"handleCloseAllTiddlersEvent\"},\n\t\t{type: \"tm-close-other-tiddlers\", handler: \"handleCloseOtherTiddlersEvent\"},\n\t\t{type: \"tm-new-tiddler\", handler: \"handleNewTiddlerEvent\"},\n\t\t{type: \"tm-import-tiddlers\", handler: \"handleImportTiddlersEvent\"},\n\t\t{type: \"tm-perform-import\", handler: \"handlePerformImportEvent\"},\n\t\t{type: \"tm-fold-tiddler\", handler: \"handleFoldTiddlerEvent\"},\n\t\t{type: \"tm-fold-other-tiddlers\", handler: \"handleFoldOtherTiddlersEvent\"},\n\t\t{type: \"tm-fold-all-tiddlers\", handler: \"handleFoldAllTiddlersEvent\"},\n\t\t{type: \"tm-unfold-all-tiddlers\", handler: \"handleUnfoldAllTiddlersEvent\"},\n\t\t{type: \"tm-rename-tiddler\", handler: \"handleRenameTiddlerEvent\"}\n\t]);\n};\n\n/*\nInherit from the base widget class\n*/\nNavigatorWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nNavigatorWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n};\n\n/*\nCompute the internal state of the widget\n*/\nNavigatorWidget.prototype.execute = function() {\n\t// Get our parameters\n\tthis.storyTitle = this.getAttribute(\"story\");\n\tthis.historyTitle = this.getAttribute(\"history\");\n\tthis.setVariable(\"tv-story-list\",this.storyTitle);\n\tthis.setVariable(\"tv-history-list\",this.historyTitle);\n\t// Construct the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nNavigatorWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.story || changedAttributes.history) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn this.refreshChildren(changedTiddlers);\n\t}\n};\n\nNavigatorWidget.prototype.getStoryList = function() {\n\treturn this.storyTitle ? this.wiki.getTiddlerList(this.storyTitle) : null;\n};\n\nNavigatorWidget.prototype.saveStoryList = function(storyList) {\n\tvar storyTiddler = this.wiki.getTiddler(this.storyTitle);\n\tthis.wiki.addTiddler(new $tw.Tiddler(\n\t\t{title: this.storyTitle},\n\t\tstoryTiddler,\n\t\t{list: storyList}\n\t));\n};\n\nNavigatorWidget.prototype.removeTitleFromStory = function(storyList,title) {\n\tvar p = storyList.indexOf(title);\n\twhile(p !== -1) {\n\t\tstoryList.splice(p,1);\n\t\tp = storyList.indexOf(title);\n\t}\n};\n\nNavigatorWidget.prototype.replaceFirstTitleInStory = function(storyList,oldTitle,newTitle) {\n\tvar pos = storyList.indexOf(oldTitle);\n\tif(pos !== -1) {\n\t\tstoryList[pos] = newTitle;\n\t\tdo {\n\t\t\tpos = storyList.indexOf(oldTitle,pos + 1);\n\t\t\tif(pos !== -1) {\n\t\t\t\tstoryList.splice(pos,1);\n\t\t\t}\n\t\t} while(pos !== -1);\n\t} else {\n\t\tstoryList.splice(0,0,newTitle);\n\t}\n};\n\nNavigatorWidget.prototype.addToStory = function(title,fromTitle) {\n\tthis.wiki.addToStory(title,fromTitle,this.storyTitle,{openLinkFromInsideRiver: this.getAttribute(\"openLinkFromInsideRiver\",\"top\"),openLinkFromOutsideRiver: this.getAttribute(\"openLinkFromOutsideRiver\",\"top\")});\n};\n\n/*\nAdd a new record to the top of the history stack\ntitle: a title string or an array of title strings\nfromPageRect: page coordinates of the origin of the navigation\n*/\nNavigatorWidget.prototype.addToHistory = function(title,fromPageRect) {\n\tthis.wiki.addToHistory(title,fromPageRect,this.historyTitle);\n};\n\n/*\nHandle a tm-navigate event\n*/\nNavigatorWidget.prototype.handleNavigateEvent = function(event) {\n\tevent = $tw.hooks.invokeHook(\"th-navigating\",event);\n\tif(event.navigateTo) {\n\t\tthis.addToStory(event.navigateTo,event.navigateFromTitle);\n\t\tif(!event.navigateSuppressNavigation) {\n\t\t\tthis.addToHistory(event.navigateTo,event.navigateFromClientRect);\n\t\t}\n\t}\n\treturn false;\n};\n\n// Close a specified tiddler\nNavigatorWidget.prototype.handleCloseTiddlerEvent = function(event) {\n\tvar title = event.param || event.tiddlerTitle,\n\t\tstoryList = this.getStoryList();\n\t// Look for tiddlers with this title to close\n\tthis.removeTitleFromStory(storyList,title);\n\tthis.saveStoryList(storyList);\n\treturn false;\n};\n\n// Close all tiddlers\nNavigatorWidget.prototype.handleCloseAllTiddlersEvent = function(event) {\n\tthis.saveStoryList([]);\n\treturn false;\n};\n\n// Close other tiddlers\nNavigatorWidget.prototype.handleCloseOtherTiddlersEvent = function(event) {\n\tvar title = event.param || event.tiddlerTitle;\n\tthis.saveStoryList([title]);\n\treturn false;\n};\n\n// Place a tiddler in edit mode\nNavigatorWidget.prototype.handleEditTiddlerEvent = function(event) {\n\tvar editTiddler = $tw.hooks.invokeHook(\"th-editing-tiddler\",event);\n\tif(!editTiddler) {\n\t\treturn false;\n\t}\n\tvar self = this;\n\tfunction isUnmodifiedShadow(title) {\n\t\treturn self.wiki.isShadowTiddler(title) && !self.wiki.tiddlerExists(title);\n\t}\n\tfunction confirmEditShadow(title) {\n\t\treturn confirm($tw.language.getString(\n\t\t\t\"ConfirmEditShadowTiddler\",\n\t\t\t{variables:\n\t\t\t\t{title: title}\n\t\t\t}\n\t\t));\n\t}\n\tvar title = event.param || event.tiddlerTitle;\n\tif(isUnmodifiedShadow(title) && !confirmEditShadow(title)) {\n\t\treturn false;\n\t}\n\t// Replace the specified tiddler with a draft in edit mode\n\tvar draftTiddler = this.makeDraftTiddler(title);\n\t// Update the story and history if required\n\tif(!event.paramObject || event.paramObject.suppressNavigation !== \"yes\") {\n\t\tvar draftTitle = draftTiddler.fields.title,\n\t\t\tstoryList = this.getStoryList();\n\t\tthis.removeTitleFromStory(storyList,draftTitle);\n\t\tthis.replaceFirstTitleInStory(storyList,title,draftTitle);\n\t\tthis.addToHistory(draftTitle,event.navigateFromClientRect);\n\t\tthis.saveStoryList(storyList);\n\t\treturn false;\n\t}\n};\n\n// Delete a tiddler\nNavigatorWidget.prototype.handleDeleteTiddlerEvent = function(event) {\n\t// Get the tiddler we're deleting\n\tvar title = event.param || event.tiddlerTitle,\n\t\ttiddler = this.wiki.getTiddler(title),\n\t\tstoryList = this.getStoryList(),\n\t\toriginalTitle = tiddler ? tiddler.fields[\"draft.of\"] : \"\",\n\t\toriginalTiddler = originalTitle ? this.wiki.getTiddler(originalTitle) : undefined,\n\t\tconfirmationTitle;\n\tif(!tiddler) {\n\t\treturn false;\n\t}\n\t// Check if the tiddler we're deleting is in draft mode\n\tif(originalTitle) {\n\t\t// If so, we'll prompt for confirmation referencing the original tiddler\n\t\tconfirmationTitle = originalTitle;\n\t} else {\n\t\t// If not a draft, then prompt for confirmation referencing the specified tiddler\n\t\tconfirmationTitle = title;\n\t}\n\t// Seek confirmation\n\tif((this.wiki.getTiddler(originalTitle) || (tiddler.fields.text || \"\") !== \"\") && !confirm($tw.language.getString(\n\t\t\t\t\"ConfirmDeleteTiddler\",\n\t\t\t\t{variables:\n\t\t\t\t\t{title: confirmationTitle}\n\t\t\t\t}\n\t\t\t))) {\n\t\treturn false;\n\t}\n\t// Delete the original tiddler\n\tif(originalTitle) {\n\t\tif(originalTiddler) {\n\t\t\t$tw.hooks.invokeHook(\"th-deleting-tiddler\",originalTiddler);\n\t\t}\n\t\tthis.wiki.deleteTiddler(originalTitle);\n\t\tthis.removeTitleFromStory(storyList,originalTitle);\n\t}\n\t// Invoke the hook function and delete this tiddler\n\t$tw.hooks.invokeHook(\"th-deleting-tiddler\",tiddler);\n\tthis.wiki.deleteTiddler(title);\n\t// Remove the closed tiddler from the story\n\tthis.removeTitleFromStory(storyList,title);\n\tthis.saveStoryList(storyList);\n\t// Trigger an autosave\n\t$tw.rootWidget.dispatchEvent({type: \"tm-auto-save-wiki\"});\n\treturn false;\n};\n\n/*\nCreate/reuse the draft tiddler for a given title\n*/\nNavigatorWidget.prototype.makeDraftTiddler = function(targetTitle) {\n\t// See if there is already a draft tiddler for this tiddler\n\tvar draftTitle = this.wiki.findDraft(targetTitle);\n\tif(draftTitle) {\n\t\treturn this.wiki.getTiddler(draftTitle);\n\t}\n\t// Get the current value of the tiddler we're editing\n\tvar tiddler = this.wiki.getTiddler(targetTitle);\n\t// Save the initial value of the draft tiddler\n\tdraftTitle = this.generateDraftTitle(targetTitle);\n\tvar draftTiddler = new $tw.Tiddler(\n\t\t\ttiddler,\n\t\t\t{\n\t\t\t\ttitle: draftTitle,\n\t\t\t\t\"draft.title\": targetTitle,\n\t\t\t\t\"draft.of\": targetTitle\n\t\t\t},\n\t\t\tthis.wiki.getModificationFields()\n\t\t);\n\tthis.wiki.addTiddler(draftTiddler);\n\treturn draftTiddler;\n};\n\n/*\nGenerate a title for the draft of a given tiddler\n*/\nNavigatorWidget.prototype.generateDraftTitle = function(title) {\n\tvar c = 0,\n\t\tdraftTitle,\n\t\tusername = this.wiki.getTiddlerText(\"$:/status/UserName\"),\n\t\tattribution = username ? \" by \" + username : \"\";\n\tdo {\n\t\tdraftTitle = \"Draft \" + (c ? (c + 1) + \" \" : \"\") + \"of '\" + title + \"'\" + attribution;\n\t\tc++;\n\t} while(this.wiki.tiddlerExists(draftTitle));\n\treturn draftTitle;\n};\n\n// Take a tiddler out of edit mode, saving the changes\nNavigatorWidget.prototype.handleSaveTiddlerEvent = function(event) {\n\tvar title = event.param || event.tiddlerTitle,\n\t\ttiddler = this.wiki.getTiddler(title),\n\t\tstoryList = this.getStoryList();\n\t// Replace the original tiddler with the draft\n\tif(tiddler) {\n\t\tvar draftTitle = (tiddler.fields[\"draft.title\"] || \"\").trim(),\n\t\t\tdraftOf = (tiddler.fields[\"draft.of\"] || \"\").trim();\n\t\tif(draftTitle) {\n\t\t\tvar isRename = draftOf !== draftTitle,\n\t\t\t\tisConfirmed = true;\n\t\t\tif(isRename && this.wiki.tiddlerExists(draftTitle)) {\n\t\t\t\tisConfirmed = confirm($tw.language.getString(\n\t\t\t\t\t\"ConfirmOverwriteTiddler\",\n\t\t\t\t\t{variables:\n\t\t\t\t\t\t{title: draftTitle}\n\t\t\t\t\t}\n\t\t\t\t));\n\t\t\t}\n\t\t\tif(isConfirmed) {\n\t\t\t\t// Create the new tiddler and pass it through the th-saving-tiddler hook\n\t\t\t\tvar newTiddler = new $tw.Tiddler(this.wiki.getCreationFields(),tiddler,{\n\t\t\t\t\ttitle: draftTitle,\n\t\t\t\t\t\"draft.title\": undefined,\n\t\t\t\t\t\"draft.of\": undefined\n\t\t\t\t},this.wiki.getModificationFields());\n\t\t\t\tnewTiddler = $tw.hooks.invokeHook(\"th-saving-tiddler\",newTiddler);\n\t\t\t\tthis.wiki.addTiddler(newTiddler);\n\t\t\t\t// If enabled, relink references to renamed tiddler\n\t\t\t\tvar shouldRelink = this.getAttribute(\"relinkOnRename\",\"no\").toLowerCase().trim() === \"yes\";\n\t\t\t\tif(isRename && shouldRelink && this.wiki.tiddlerExists(draftOf)) {\nconsole.log(\"Relinking '\" + draftOf + \"' to '\" + draftTitle + \"'\");\n\t\t\t\t\tthis.wiki.relinkTiddler(draftOf,draftTitle);\n\t\t\t\t}\n\t\t\t\t// Remove the draft tiddler\n\t\t\t\tthis.wiki.deleteTiddler(title);\n\t\t\t\t// Remove the original tiddler if we're renaming it\n\t\t\t\tif(isRename) {\n\t\t\t\t\tthis.wiki.deleteTiddler(draftOf);\n\t\t\t\t}\n\t\t\t\t// #2381 always remove new title & old\n\t\t\t\tthis.removeTitleFromStory(storyList,draftTitle);\n\t\t\t\tthis.removeTitleFromStory(storyList,draftOf);\n\t\t\t\tif(!event.paramObject || event.paramObject.suppressNavigation !== \"yes\") {\n\t\t\t\t\t// Replace the draft in the story with the original\n\t\t\t\t\tthis.replaceFirstTitleInStory(storyList,title,draftTitle);\n\t\t\t\t\tthis.addToHistory(draftTitle,event.navigateFromClientRect);\n\t\t\t\t\tif(draftTitle !== this.storyTitle) {\n\t\t\t\t\t\tthis.saveStoryList(storyList);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t// Trigger an autosave\n\t\t\t\t$tw.rootWidget.dispatchEvent({type: \"tm-auto-save-wiki\"});\n\t\t\t}\n\t\t}\n\t}\n\treturn false;\n};\n\n// Take a tiddler out of edit mode without saving the changes\nNavigatorWidget.prototype.handleCancelTiddlerEvent = function(event) {\n\tevent = $tw.hooks.invokeHook(\"th-cancelling-tiddler\", event);\n\t// Flip the specified tiddler from draft back to the original\n\tvar draftTitle = event.param || event.tiddlerTitle,\n\t\tdraftTiddler = this.wiki.getTiddler(draftTitle),\n\t\toriginalTitle = draftTiddler && draftTiddler.fields[\"draft.of\"];\n\tif(draftTiddler && originalTitle) {\n\t\t// Ask for confirmation if the tiddler text has changed\n\t\tvar isConfirmed = true,\n\t\t\toriginalTiddler = this.wiki.getTiddler(originalTitle),\n\t\t\tstoryList = this.getStoryList();\n\t\tif(this.wiki.isDraftModified(draftTitle)) {\n\t\t\tisConfirmed = confirm($tw.language.getString(\n\t\t\t\t\"ConfirmCancelTiddler\",\n\t\t\t\t{variables:\n\t\t\t\t\t{title: draftTitle}\n\t\t\t\t}\n\t\t\t));\n\t\t}\n\t\t// Remove the draft tiddler\n\t\tif(isConfirmed) {\n\t\t\tthis.wiki.deleteTiddler(draftTitle);\n\t\t\tif(!event.paramObject || event.paramObject.suppressNavigation !== \"yes\") {\n\t\t\t\tif(originalTiddler) {\n\t\t\t\t\tthis.replaceFirstTitleInStory(storyList,draftTitle,originalTitle);\n\t\t\t\t\tthis.addToHistory(originalTitle,event.navigateFromClientRect);\n\t\t\t\t} else {\n\t\t\t\t\tthis.removeTitleFromStory(storyList,draftTitle);\n\t\t\t\t}\n\t\t\t\tthis.saveStoryList(storyList);\n\t\t\t}\n\t\t}\n\t}\n\treturn false;\n};\n\n// Create a new draft tiddler\n// event.param can either be the title of a template tiddler, or a hashmap of fields.\n//\n// The title of the newly created tiddler follows these rules:\n// * If a hashmap was used and a title field was specified, use that title\n// * If a hashmap was used without a title field, use a default title, if necessary making it unique with a numeric suffix\n// * If a template tiddler was used, use the title of the template, if necessary making it unique with a numeric suffix\n//\n// If a draft of the target tiddler already exists then it is reused\nNavigatorWidget.prototype.handleNewTiddlerEvent = function(event) {\n\tevent = $tw.hooks.invokeHook(\"th-new-tiddler\", event);\n\t// Get the story details\n\tvar storyList = this.getStoryList(),\n\t\ttemplateTiddler, additionalFields, title, draftTitle, existingTiddler;\n\t// Get the template tiddler (if any)\n\tif(typeof event.param === \"string\") {\n\t\t// Get the template tiddler\n\t\ttemplateTiddler = this.wiki.getTiddler(event.param);\n\t\t// Generate a new title\n\t\ttitle = this.wiki.generateNewTitle(event.param || $tw.language.getString(\"DefaultNewTiddlerTitle\"));\n\t}\n\t// Get the specified additional fields\n\tif(typeof event.paramObject === \"object\") {\n\t\tadditionalFields = event.paramObject;\n\t}\n\tif(typeof event.param === \"object\") { // Backwards compatibility with 5.1.3\n\t\tadditionalFields = event.param;\n\t}\n\tif(additionalFields && additionalFields.title) {\n\t\ttitle = additionalFields.title;\n\t}\n\t// Make a copy of the additional fields excluding any blank ones\n\tvar filteredAdditionalFields = $tw.utils.extend({},additionalFields);\n\tObject.keys(filteredAdditionalFields).forEach(function(fieldName) {\n\t\tif(filteredAdditionalFields[fieldName] === \"\") {\n\t\t\tdelete filteredAdditionalFields[fieldName];\n\t\t}\n\t});\n\t// Generate a title if we don't have one\n\ttitle = title || this.wiki.generateNewTitle($tw.language.getString(\"DefaultNewTiddlerTitle\"));\n\t// Find any existing draft for this tiddler\n\tdraftTitle = this.wiki.findDraft(title);\n\t// Pull in any existing tiddler\n\tif(draftTitle) {\n\t\texistingTiddler = this.wiki.getTiddler(draftTitle);\n\t} else {\n\t\tdraftTitle = this.generateDraftTitle(title);\n\t\texistingTiddler = this.wiki.getTiddler(title);\n\t}\n\t// Merge the tags\n\tvar mergedTags = [];\n\tif(existingTiddler && existingTiddler.fields.tags) {\n\t\t$tw.utils.pushTop(mergedTags,existingTiddler.fields.tags);\n\t}\n\tif(additionalFields && additionalFields.tags) {\n\t\t// Merge tags\n\t\tmergedTags = $tw.utils.pushTop(mergedTags,$tw.utils.parseStringArray(additionalFields.tags));\n\t}\n\tif(templateTiddler && templateTiddler.fields.tags) {\n\t\t// Merge tags\n\t\tmergedTags = $tw.utils.pushTop(mergedTags,templateTiddler.fields.tags);\n\t}\n\t// Save the draft tiddler\n\tvar draftTiddler = new $tw.Tiddler({\n\t\t\ttext: \"\",\n\t\t\t\"draft.title\": title\n\t\t},\n\t\ttemplateTiddler,\n\t\tadditionalFields,\n\t\tthis.wiki.getCreationFields(),\n\t\texistingTiddler,\n\t\tfilteredAdditionalFields,\n\t\t{\n\t\t\ttitle: draftTitle,\n\t\t\t\"draft.of\": title,\n\t\t\ttags: mergedTags\n\t\t},this.wiki.getModificationFields());\n\tthis.wiki.addTiddler(draftTiddler);\n\t// Update the story to insert the new draft at the top and remove any existing tiddler\n\tif(storyList.indexOf(draftTitle) === -1) {\n\t\tvar slot = storyList.indexOf(event.navigateFromTitle);\n\t\tif(slot === -1) {\n\t\t\tslot = this.getAttribute(\"openLinkFromOutsideRiver\",\"top\") === \"bottom\" ? storyList.length - 1 : slot;\n\t\t}\n\t\tstoryList.splice(slot + 1,0,draftTitle);\n\t}\n\tif(storyList.indexOf(title) !== -1) {\n\t\tstoryList.splice(storyList.indexOf(title),1);\n\t}\n\tthis.saveStoryList(storyList);\n\t// Add a new record to the top of the history stack\n\tthis.addToHistory(draftTitle);\n\treturn false;\n};\n\n// Import JSON tiddlers into a pending import tiddler\nNavigatorWidget.prototype.handleImportTiddlersEvent = function(event) {\n\t// Get the tiddlers\n\tvar tiddlers = [];\n\ttry {\n\t\ttiddlers = JSON.parse(event.param);\n\t} catch(e) {\n\t}\n\t// Get the current $:/Import tiddler\n\tvar importTiddler = this.wiki.getTiddler(IMPORT_TITLE),\n\t\timportData = this.wiki.getTiddlerData(IMPORT_TITLE,{}),\n\t\tnewFields = new Object({\n\t\t\ttitle: IMPORT_TITLE,\n\t\t\ttype: \"application/json\",\n\t\t\t\"plugin-type\": \"import\",\n\t\t\t\"status\": \"pending\"\n\t\t}),\n\t\tincomingTiddlers = [];\n\t// Process each tiddler\n\timportData.tiddlers = importData.tiddlers || {};\n\t$tw.utils.each(tiddlers,function(tiddlerFields) {\n\t\ttiddlerFields.title = $tw.utils.trim(tiddlerFields.title);\n\t\tvar title = tiddlerFields.title;\n\t\tif(title) {\n\t\t\tincomingTiddlers.push(title);\n\t\t\timportData.tiddlers[title] = tiddlerFields;\n\t\t}\n\t});\n\t// Give the active upgrader modules a chance to process the incoming tiddlers\n\tvar messages = this.wiki.invokeUpgraders(incomingTiddlers,importData.tiddlers);\n\t$tw.utils.each(messages,function(message,title) {\n\t\tnewFields[\"message-\" + title] = message;\n\t});\n\t// Deselect any suppressed tiddlers\n\t$tw.utils.each(importData.tiddlers,function(tiddler,title) {\n\t\tif($tw.utils.count(tiddler) === 0) {\n\t\t\tnewFields[\"selection-\" + title] = \"unchecked\";\n\t\t}\n\t});\n\t// Save the $:/Import tiddler\n\tnewFields.text = JSON.stringify(importData,null,$tw.config.preferences.jsonSpaces);\n\tthis.wiki.addTiddler(new $tw.Tiddler(importTiddler,newFields));\n\t// Update the story and history details\n\tif(this.getVariable(\"tv-auto-open-on-import\") !== \"no\") {\n\t\tvar storyList = this.getStoryList(),\n\t\t\thistory = [];\n\t\t// Add it to the story\n\t\tif(storyList.indexOf(IMPORT_TITLE) === -1) {\n\t\t\tstoryList.unshift(IMPORT_TITLE);\n\t\t}\n\t\t// And to history\n\t\thistory.push(IMPORT_TITLE);\n\t\t// Save the updated story and history\n\t\tthis.saveStoryList(storyList);\n\t\tthis.addToHistory(history);\n\t}\n\treturn false;\n};\n\n//\nNavigatorWidget.prototype.handlePerformImportEvent = function(event) {\n\tvar self = this,\n\t\timportTiddler = this.wiki.getTiddler(event.param),\n\t\timportData = this.wiki.getTiddlerDataCached(event.param,{tiddlers: {}}),\n\t\timportReport = [];\n\t// Add the tiddlers to the store\n\timportReport.push($tw.language.getString(\"Import/Imported/Hint\") + \"\\n\");\n\t$tw.utils.each(importData.tiddlers,function(tiddlerFields) {\n\t\tvar title = tiddlerFields.title;\n\t\tif(title && importTiddler && importTiddler.fields[\"selection-\" + title] !== \"unchecked\") {\n\t\t\tvar tiddler = new $tw.Tiddler(tiddlerFields);\n\t\t\ttiddler = $tw.hooks.invokeHook(\"th-importing-tiddler\",tiddler);\n\t\t\tself.wiki.addTiddler(tiddler);\n\t\t\timportReport.push(\"# [[\" + tiddlerFields.title + \"]]\");\n\t\t}\n\t});\n\t// Replace the $:/Import tiddler with an import report\n\tthis.wiki.addTiddler(new $tw.Tiddler({\n\t\ttitle: event.param,\n\t\ttext: importReport.join(\"\\n\"),\n\t\t\"status\": \"complete\"\n\t}));\n\t// Navigate to the $:/Import tiddler\n\tthis.addToHistory([event.param]);\n\t// Trigger an autosave\n\t$tw.rootWidget.dispatchEvent({type: \"tm-auto-save-wiki\"});\n};\n\nNavigatorWidget.prototype.handleFoldTiddlerEvent = function(event) {\n\tvar paramObject = event.paramObject || {};\n\tif(paramObject.foldedState) {\n\t\tvar foldedState = this.wiki.getTiddlerText(paramObject.foldedState,\"show\") === \"show\" ? \"hide\" : \"show\";\n\t\tthis.wiki.setText(paramObject.foldedState,\"text\",null,foldedState);\n\t}\n};\n\nNavigatorWidget.prototype.handleFoldOtherTiddlersEvent = function(event) {\n\tvar self = this,\n\t\tparamObject = event.paramObject || {},\n\t\tprefix = paramObject.foldedStatePrefix;\n\t$tw.utils.each(this.getStoryList(),function(title) {\n\t\tself.wiki.setText(prefix + title,\"text\",null,event.param === title ? \"show\" : \"hide\");\n\t});\n};\n\nNavigatorWidget.prototype.handleFoldAllTiddlersEvent = function(event) {\n\tvar self = this,\n\t\tparamObject = event.paramObject || {},\n\t\tprefix = paramObject.foldedStatePrefix;\n\t$tw.utils.each(this.getStoryList(),function(title) {\n\t\tself.wiki.setText(prefix + title,\"text\",null,\"hide\");\n\t});\n};\n\nNavigatorWidget.prototype.handleUnfoldAllTiddlersEvent = function(event) {\n\tvar self = this,\n\t\tparamObject = event.paramObject || {},\n\t\tprefix = paramObject.foldedStatePrefix;\n\t$tw.utils.each(this.getStoryList(),function(title) {\n\t\tself.wiki.setText(prefix + title,\"text\",null,\"show\");\n\t});\n};\n\nNavigatorWidget.prototype.handleRenameTiddlerEvent = function(event) {\n\tevent = $tw.hooks.invokeHook(\"th-renaming-tiddler\", event);\n\tvar paramObject = event.paramObject || {},\n\t\tfrom = paramObject.from || event.tiddlerTitle,\n\t\tto = paramObject.to;\n\t$tw.wiki.renameTiddler(from,to);\n};\n\nexports.navigator = NavigatorWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/password.js": {
"title": "$:/core/modules/widgets/password.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/password.js\ntype: application/javascript\nmodule-type: widget\n\nPassword widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar PasswordWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nPasswordWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nPasswordWidget.prototype.render = function(parent,nextSibling) {\n\t// Save the parent dom node\n\tthis.parentDomNode = parent;\n\t// Compute our attributes\n\tthis.computeAttributes();\n\t// Execute our logic\n\tthis.execute();\n\t// Get the current password\n\tvar password = $tw.browser ? $tw.utils.getPassword(this.passwordName) || \"\" : \"\";\n\t// Create our element\n\tvar domNode = this.document.createElement(\"input\");\n\tdomNode.setAttribute(\"type\",\"password\");\n\tdomNode.setAttribute(\"value\",password);\n\t// Add a click event handler\n\t$tw.utils.addEventListeners(domNode,[\n\t\t{name: \"change\", handlerObject: this, handlerMethod: \"handleChangeEvent\"}\n\t]);\n\t// Insert the label into the DOM and render any children\n\tparent.insertBefore(domNode,nextSibling);\n\tthis.renderChildren(domNode,null);\n\tthis.domNodes.push(domNode);\n};\n\nPasswordWidget.prototype.handleChangeEvent = function(event) {\n\tvar password = this.domNodes[0].value;\n\treturn $tw.utils.savePassword(this.passwordName,password);\n};\n\n/*\nCompute the internal state of the widget\n*/\nPasswordWidget.prototype.execute = function() {\n\t// Get the parameters from the attributes\n\tthis.passwordName = this.getAttribute(\"name\",\"\");\n\t// Make the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nPasswordWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.name) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn this.refreshChildren(changedTiddlers);\n\t}\n};\n\nexports.password = PasswordWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/qualify.js": {
"title": "$:/core/modules/widgets/qualify.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/qualify.js\ntype: application/javascript\nmodule-type: widget\n\nQualify text to a variable \n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar QualifyWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nQualifyWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nQualifyWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n};\n\n/*\nCompute the internal state of the widget\n*/\nQualifyWidget.prototype.execute = function() {\n\t// Get our parameters\n\tthis.qualifyName = this.getAttribute(\"name\");\n\tthis.qualifyTitle = this.getAttribute(\"title\");\n\t// Set context variable\n\tif(this.qualifyName) {\n\t\tthis.setVariable(this.qualifyName,this.qualifyTitle + \"-\" + this.getStateQualifier());\n\t}\n\t// Construct the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nQualifyWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.name || changedAttributes.title) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn this.refreshChildren(changedTiddlers);\n\t}\n};\n\nexports.qualify = QualifyWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/radio.js": {
"title": "$:/core/modules/widgets/radio.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/radio.js\ntype: application/javascript\nmodule-type: widget\n\nSet a field or index at a given tiddler via radio buttons\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar RadioWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nRadioWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nRadioWidget.prototype.render = function(parent,nextSibling) {\n\t// Save the parent dom node\n\tthis.parentDomNode = parent;\n\t// Compute our attributes\n\tthis.computeAttributes();\n\t// Execute our logic\n\tthis.execute();\n\tvar isChecked = this.getValue() === this.radioValue;\n\t// Create our elements\n\tthis.labelDomNode = this.document.createElement(\"label\");\n\tthis.labelDomNode.setAttribute(\"class\",\n \t\t\"tc-radio \" + this.radioClass + (isChecked ? \" tc-radio-selected\" : \"\")\n \t);\n\tthis.inputDomNode = this.document.createElement(\"input\");\n\tthis.inputDomNode.setAttribute(\"type\",\"radio\");\n\tif(isChecked) {\n\t\tthis.inputDomNode.setAttribute(\"checked\",\"true\");\n\t}\n\tthis.labelDomNode.appendChild(this.inputDomNode);\n\tthis.spanDomNode = this.document.createElement(\"span\");\n\tthis.labelDomNode.appendChild(this.spanDomNode);\n\t// Add a click event handler\n\t$tw.utils.addEventListeners(this.inputDomNode,[\n\t\t{name: \"change\", handlerObject: this, handlerMethod: \"handleChangeEvent\"}\n\t]);\n\t// Insert the label into the DOM and render any children\n\tparent.insertBefore(this.labelDomNode,nextSibling);\n\tthis.renderChildren(this.spanDomNode,null);\n\tthis.domNodes.push(this.labelDomNode);\n};\n\nRadioWidget.prototype.getValue = function() {\n\tvar value,\n\t\ttiddler = this.wiki.getTiddler(this.radioTitle);\n\tif (this.radioIndex) {\n\t\tvalue = this.wiki.extractTiddlerDataItem(this.radioTitle,this.radioIndex);\n\t} else {\n\t\tvalue = tiddler && tiddler.getFieldString(this.radioField);\n\t}\n\treturn value;\n};\n\nRadioWidget.prototype.setValue = function() {\n\tif(this.radioIndex) {\n\t\tthis.wiki.setText(this.radioTitle,\"\",this.radioIndex,this.radioValue);\n\t} else {\n\t\tvar tiddler = this.wiki.getTiddler(this.radioTitle),\n\t\t\taddition = {};\n\t\taddition[this.radioField] = this.radioValue;\n\t\tthis.wiki.addTiddler(new $tw.Tiddler(this.wiki.getCreationFields(),{title: this.radioTitle},tiddler,addition,this.wiki.getModificationFields()));\n\t}\n};\n\nRadioWidget.prototype.handleChangeEvent = function(event) {\n\tif(this.inputDomNode.checked) {\n\t\tthis.setValue();\n\t}\n};\n\n/*\nCompute the internal state of the widget\n*/\nRadioWidget.prototype.execute = function() {\n\t// Get the parameters from the attributes\n\tthis.radioTitle = this.getAttribute(\"tiddler\",this.getVariable(\"currentTiddler\"));\n\tthis.radioField = this.getAttribute(\"field\",\"text\");\n\tthis.radioIndex = this.getAttribute(\"index\");\n\tthis.radioValue = this.getAttribute(\"value\");\n\tthis.radioClass = this.getAttribute(\"class\",\"\");\n\t// Make the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nRadioWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.tiddler || changedAttributes.field || changedAttributes.index || changedAttributes.value || changedAttributes[\"class\"]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\tvar refreshed = false;\n\t\tif(changedTiddlers[this.radioTitle]) {\n\t\t\tthis.inputDomNode.checked = this.getValue() === this.radioValue;\n\t\t\trefreshed = true;\n\t\t}\n\t\treturn this.refreshChildren(changedTiddlers) || refreshed;\n\t}\n};\n\nexports.radio = RadioWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/range.js": {
"title": "$:/core/modules/widgets/range.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/range.js\ntype: application/javascript\nmodule-type: widget\n\nRange widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar RangeWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nRangeWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nRangeWidget.prototype.render = function(parent,nextSibling) {\n\t// Save the parent dom node\n\tthis.parentDomNode = parent;\n\t// Compute our attributes\n\tthis.computeAttributes();\n\t// Execute our logic\n\tthis.execute();\n\t// Create our elements\n\tthis.inputDomNode = this.document.createElement(\"input\");\n\tthis.inputDomNode.setAttribute(\"type\",\"range\");\n\tthis.inputDomNode.setAttribute(\"class\",this.elementClass);\n\tif(this.minValue){\n\t\tthis.inputDomNode.setAttribute(\"min\", this.minValue);\n\t}\n\tif(this.maxValue){\n\t\tthis.inputDomNode.setAttribute(\"max\", this.maxValue);\n\t}\n\tif(this.increment){\n\t\tthis.inputDomNode.setAttribute(\"step\", this.increment);\n\t}\n\tthis.inputDomNode.value = this.getValue();\n\n\n\t// Add a click event handler\n\t$tw.utils.addEventListeners(this.inputDomNode,[\n\t\t{name: \"input\", handlerObject: this, handlerMethod: \"handleChangeEvent\"}\n\t]);\n\t// Insert the label into the DOM and render any children\n\tparent.insertBefore(this.inputDomNode,nextSibling);\n\tthis.domNodes.push(this.inputDomNode);\n};\n\nRangeWidget.prototype.getValue = function() {\n\tvar tiddler = this.wiki.getTiddler(this.tiddlerTitle),\n\t\tvalue = this.defaultValue;\n\tif(tiddler) {\n\t\tif($tw.utils.hop(tiddler.fields,this.tiddlerField)) {\n\t\t\tvalue = tiddler.fields[this.tiddlerField] || \"\";\n\t\t} else {\n\t\t\tvalue = this.defaultValue || \"\";\n\t\t}\n\t}\n\treturn value;\n};\n\nRangeWidget.prototype.handleChangeEvent = function(event) {\n\tthis.wiki.setText(this.tiddlerTitle ,this.tiddlerField, null,this.inputDomNode.value);\n};\n\n/*\nCompute the internal state of the widget\n*/\nRangeWidget.prototype.execute = function() {\n\t// Get the parameters from the attributes\n\tthis.tiddlerTitle = this.getAttribute(\"tiddler\",this.getVariable(\"currentTiddler\"));\n\tthis.tiddlerField = this.getAttribute(\"field\");\n\tthis.minValue = this.getAttribute(\"min\");\n\tthis.maxValue = this.getAttribute(\"max\");\n\tthis.increment = this.getAttribute(\"increment\");\n\tthis.defaultValue = this.getAttribute(\"default\");\n\tthis.elementClass = this.getAttribute(\"class\",\"\");\n\t// Make the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nRangeWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.tiddler || changedAttributes.field || changedAttributes['min'] || changedAttributes['max'] || changedAttributes['increment'] || changedAttributes[\"default\"] || changedAttributes[\"class\"]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\tvar refreshed = false;\n\t\tif(changedTiddlers[this.tiddlerTitle]) {\n\t\t\tthis.inputDomNode.checked = this.getValue();\n\t\t\trefreshed = true;\n\t\t}\n\t\treturn this.refreshChildren(changedTiddlers) || refreshed;\n\t}\n};\n\nexports.range = RangeWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/raw.js": {
"title": "$:/core/modules/widgets/raw.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/raw.js\ntype: application/javascript\nmodule-type: widget\n\nRaw widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar RawWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nRawWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nRawWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.execute();\n\tvar div = this.document.createElement(\"div\");\n\tdiv.innerHTML=this.parseTreeNode.html;\n\tparent.insertBefore(div,nextSibling);\n\tthis.domNodes.push(div);\t\n};\n\n/*\nCompute the internal state of the widget\n*/\nRawWidget.prototype.execute = function() {\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nRawWidget.prototype.refresh = function(changedTiddlers) {\n\treturn false;\n};\n\nexports.raw = RawWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/reveal.js": {
"title": "$:/core/modules/widgets/reveal.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/reveal.js\ntype: application/javascript\nmodule-type: widget\n\nReveal widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar RevealWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nRevealWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nRevealWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tvar tag = this.parseTreeNode.isBlock ? \"div\" : \"span\";\n\tif(this.revealTag && $tw.config.htmlUnsafeElements.indexOf(this.revealTag) === -1) {\n\t\ttag = this.revealTag;\n\t}\n\tvar domNode = this.document.createElement(tag);\n\tvar classes = this[\"class\"].split(\" \") || [];\n\tclasses.push(\"tc-reveal\");\n\tdomNode.className = classes.join(\" \");\n\tif(this.style) {\n\t\tdomNode.setAttribute(\"style\",this.style);\n\t}\n\tparent.insertBefore(domNode,nextSibling);\n\tthis.renderChildren(domNode,null);\n\tif(!domNode.isTiddlyWikiFakeDom && this.type === \"popup\" && this.isOpen) {\n\t\tthis.positionPopup(domNode);\n\t\t$tw.utils.addClass(domNode,\"tc-popup\"); // Make sure that clicks don't dismiss popups within the revealed content\n\t}\n\tif(!this.isOpen) {\n\t\tdomNode.setAttribute(\"hidden\",\"true\");\n\t}\n\tthis.domNodes.push(domNode);\n};\n\nRevealWidget.prototype.positionPopup = function(domNode) {\n\tdomNode.style.position = \"absolute\";\n\tdomNode.style.zIndex = \"1000\";\n\tswitch(this.position) {\n\t\tcase \"left\":\n\t\t\tdomNode.style.left = Math.max(0, this.popup.left - domNode.offsetWidth) + \"px\";\n\t\t\tdomNode.style.top = this.popup.top + \"px\";\n\t\t\tbreak;\n\t\tcase \"above\":\n\t\t\tdomNode.style.left = this.popup.left + \"px\";\n\t\t\tdomNode.style.top = Math.max(0, this.popup.top - domNode.offsetHeight) + \"px\";\n\t\t\tbreak;\n\t\tcase \"aboveright\":\n\t\t\tdomNode.style.left = (this.popup.left + this.popup.width) + \"px\";\n\t\t\tdomNode.style.top = Math.max(0, this.popup.top + this.popup.height - domNode.offsetHeight) + \"px\";\n\t\t\tbreak;\n\t\tcase \"right\":\n\t\t\tdomNode.style.left = (this.popup.left + this.popup.width) + \"px\";\n\t\t\tdomNode.style.top = this.popup.top + \"px\";\n\t\t\tbreak;\n\t\tcase \"belowleft\":\n\t\t\tdomNode.style.left = Math.max(0, this.popup.left + this.popup.width - domNode.offsetWidth) + \"px\";\n\t\t\tdomNode.style.top = (this.popup.top + this.popup.height) + \"px\";\n\t\t\tbreak;\n\t\tdefault: // Below\n\t\t\tdomNode.style.left = this.popup.left + \"px\";\n\t\t\tdomNode.style.top = (this.popup.top + this.popup.height) + \"px\";\n\t\t\tbreak;\n\t}\n};\n\n/*\nCompute the internal state of the widget\n*/\nRevealWidget.prototype.execute = function() {\n\t// Get our parameters\n\tthis.state = this.getAttribute(\"state\");\n\tthis.revealTag = this.getAttribute(\"tag\");\n\tthis.type = this.getAttribute(\"type\");\n\tthis.text = this.getAttribute(\"text\");\n\tthis.position = this.getAttribute(\"position\");\n\tthis[\"class\"] = this.getAttribute(\"class\",\"\");\n\tthis.style = this.getAttribute(\"style\",\"\");\n\tthis[\"default\"] = this.getAttribute(\"default\",\"\");\n\tthis.animate = this.getAttribute(\"animate\",\"no\");\n\tthis.retain = this.getAttribute(\"retain\",\"no\");\n\tthis.openAnimation = this.animate === \"no\" ? undefined : \"open\";\n\tthis.closeAnimation = this.animate === \"no\" ? undefined : \"close\";\n\t// Compute the title of the state tiddler and read it\n\tthis.stateTiddlerTitle = this.state;\n\tthis.stateTitle = this.getAttribute(\"stateTitle\");\n\tthis.stateField = this.getAttribute(\"stateField\");\n\tthis.stateIndex = this.getAttribute(\"stateIndex\");\n\tthis.readState();\n\t// Construct the child widgets\n\tvar childNodes = this.isOpen ? this.parseTreeNode.children : [];\n\tthis.hasChildNodes = this.isOpen;\n\tthis.makeChildWidgets(childNodes);\n};\n\n/*\nRead the state tiddler\n*/\nRevealWidget.prototype.readState = function() {\n\t// Read the information from the state tiddler\n\tvar state = this.stateTitle ? (this.stateField ? this.wiki.getTiddler(this.stateTitle).getFieldString(this.stateField) :\n\t\t(this.stateIndex ? this.wiki.extractTiddlerDataItem(this.stateTitle,this.stateIndex) :\n\t\t\tthis.wiki.getTiddlerText(this.stateTitle))) || this[\"default\"] || this.getVariable(\"currentTiddler\") :\n\t\t(this.stateTiddlerTitle ? this.wiki.getTextReference(this.state,this[\"default\"],this.getVariable(\"currentTiddler\")) : this[\"default\"]);\n\tif(state === null) {\n\t\tstate = this[\"default\"];\n\t}\n\tswitch(this.type) {\n\t\tcase \"popup\":\n\t\t\tthis.readPopupState(state);\n\t\t\tbreak;\n\t\tcase \"match\":\n\t\t\tthis.isOpen = !!(this.compareStateText(state) == 0);\n\t\t\tbreak;\n\t\tcase \"nomatch\":\n\t\t\tthis.isOpen = !(this.compareStateText(state) == 0);\n\t\t\tbreak;\n\t\tcase \"lt\":\n\t\t\tthis.isOpen = !!(this.compareStateText(state) < 0);\n\t\t\tbreak;\n\t\tcase \"gt\":\n\t\t\tthis.isOpen = !!(this.compareStateText(state) > 0);\n\t\t\tbreak;\n\t\tcase \"lteq\":\n\t\t\tthis.isOpen = !(this.compareStateText(state) > 0);\n\t\t\tbreak;\n\t\tcase \"gteq\":\n\t\t\tthis.isOpen = !(this.compareStateText(state) < 0);\n\t\t\tbreak;\n\t}\n};\n\nRevealWidget.prototype.compareStateText = function(state) {\n\treturn state.localeCompare(this.text,undefined,{numeric: true,sensitivity: \"case\"});\n};\n\nRevealWidget.prototype.readPopupState = function(state) {\n\tvar popupLocationRegExp = /^\\((-?[0-9\\.E]+),(-?[0-9\\.E]+),(-?[0-9\\.E]+),(-?[0-9\\.E]+)\\)$/,\n\t\tmatch = popupLocationRegExp.exec(state);\n\t// Check if the state matches the location regexp\n\tif(match) {\n\t\t// If so, we're open\n\t\tthis.isOpen = true;\n\t\t// Get the location\n\t\tthis.popup = {\n\t\t\tleft: parseFloat(match[1]),\n\t\t\ttop: parseFloat(match[2]),\n\t\t\twidth: parseFloat(match[3]),\n\t\t\theight: parseFloat(match[4])\n\t\t};\n\t} else {\n\t\t// If not, we're closed\n\t\tthis.isOpen = false;\n\t}\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nRevealWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.state || changedAttributes.type || changedAttributes.text || changedAttributes.position || changedAttributes[\"default\"] || changedAttributes.animate || changedAttributes.stateTitle || changedAttributes.stateField || changedAttributes.stateIndex) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\tvar currentlyOpen = this.isOpen;\n\t\tthis.readState();\n\t\tif(this.isOpen !== currentlyOpen || (this.stateTiddlerTitle && changedTiddlers[this.stateTiddlerTitle])) {\n\t\t\tif(this.retain === \"yes\") {\n\t\t\t\tthis.updateState();\n\t\t\t} else {\n\t\t\t\tthis.refreshSelf();\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t\treturn this.refreshChildren(changedTiddlers);\n\t}\n};\n\n/*\nCalled by refresh() to dynamically show or hide the content\n*/\nRevealWidget.prototype.updateState = function() {\n\tvar self = this;\n\t// Read the current state\n\tthis.readState();\n\t// Construct the child nodes if needed\n\tvar domNode = this.domNodes[0];\n\tif(this.isOpen && !this.hasChildNodes) {\n\t\tthis.hasChildNodes = true;\n\t\tthis.makeChildWidgets(this.parseTreeNode.children);\n\t\tthis.renderChildren(domNode,null);\n\t}\n\t// Animate our DOM node\n\tif(!domNode.isTiddlyWikiFakeDom && this.type === \"popup\" && this.isOpen) {\n\t\tthis.positionPopup(domNode);\n\t\t$tw.utils.addClass(domNode,\"tc-popup\"); // Make sure that clicks don't dismiss popups within the revealed content\n\n\t}\n\tif(this.isOpen) {\n\t\tdomNode.removeAttribute(\"hidden\");\n $tw.anim.perform(this.openAnimation,domNode);\n\t} else {\n\t\t$tw.anim.perform(this.closeAnimation,domNode,{callback: function() {\n\t\t\t//make sure that the state hasn't changed during the close animation\n\t\t\tself.readState()\n\t\t\tif(!self.isOpen) {\n\t\t\t\tdomNode.setAttribute(\"hidden\",\"true\");\n\t\t\t}\n\t\t}});\n\t}\n};\n\nexports.reveal = RevealWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/scrollable.js": {
"title": "$:/core/modules/widgets/scrollable.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/scrollable.js\ntype: application/javascript\nmodule-type: widget\n\nScrollable widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar ScrollableWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n\tthis.scaleFactor = 1;\n\tthis.addEventListeners([\n\t\t{type: \"tm-scroll\", handler: \"handleScrollEvent\"}\n\t]);\n\tif($tw.browser) {\n\t\tthis.requestAnimationFrame = window.requestAnimationFrame ||\n\t\t\twindow.webkitRequestAnimationFrame ||\n\t\t\twindow.mozRequestAnimationFrame ||\n\t\t\tfunction(callback) {\n\t\t\t\treturn window.setTimeout(callback, 1000/60);\n\t\t\t};\n\t\tthis.cancelAnimationFrame = window.cancelAnimationFrame ||\n\t\t\twindow.webkitCancelAnimationFrame ||\n\t\t\twindow.webkitCancelRequestAnimationFrame ||\n\t\t\twindow.mozCancelAnimationFrame ||\n\t\t\twindow.mozCancelRequestAnimationFrame ||\n\t\t\tfunction(id) {\n\t\t\t\twindow.clearTimeout(id);\n\t\t\t};\n\t}\n};\n\n/*\nInherit from the base widget class\n*/\nScrollableWidget.prototype = new Widget();\n\nScrollableWidget.prototype.cancelScroll = function() {\n\tif(this.idRequestFrame) {\n\t\tthis.cancelAnimationFrame.call(window,this.idRequestFrame);\n\t\tthis.idRequestFrame = null;\n\t}\n};\n\n/*\nHandle a scroll event\n*/\nScrollableWidget.prototype.handleScrollEvent = function(event) {\n\t// Pass the scroll event through if our offsetsize is larger than our scrollsize\n\tif(this.outerDomNode.scrollWidth <= this.outerDomNode.offsetWidth && this.outerDomNode.scrollHeight <= this.outerDomNode.offsetHeight && this.fallthrough === \"yes\") {\n\t\treturn true;\n\t}\n\tthis.scrollIntoView(event.target);\n\treturn false; // Handled event\n};\n\n/*\nScroll an element into view\n*/\nScrollableWidget.prototype.scrollIntoView = function(element) {\n\tvar duration = $tw.utils.getAnimationDuration();\n\tthis.cancelScroll();\n\tthis.startTime = Date.now();\n\tvar scrollPosition = {\n\t\tx: this.outerDomNode.scrollLeft,\n\t\ty: this.outerDomNode.scrollTop\n\t};\n\t// Get the client bounds of the element and adjust by the scroll position\n\tvar scrollableBounds = this.outerDomNode.getBoundingClientRect(),\n\t\tclientTargetBounds = element.getBoundingClientRect(),\n\t\tbounds = {\n\t\t\tleft: clientTargetBounds.left + scrollPosition.x - scrollableBounds.left,\n\t\t\ttop: clientTargetBounds.top + scrollPosition.y - scrollableBounds.top,\n\t\t\twidth: clientTargetBounds.width,\n\t\t\theight: clientTargetBounds.height\n\t\t};\n\t// We'll consider the horizontal and vertical scroll directions separately via this function\n\tvar getEndPos = function(targetPos,targetSize,currentPos,currentSize) {\n\t\t\t// If the target is already visible then stay where we are\n\t\t\tif(targetPos >= currentPos && (targetPos + targetSize) <= (currentPos + currentSize)) {\n\t\t\t\treturn currentPos;\n\t\t\t// If the target is above/left of the current view, then scroll to its top/left\n\t\t\t} else if(targetPos <= currentPos) {\n\t\t\t\treturn targetPos;\n\t\t\t// If the target is smaller than the window and the scroll position is too far up, then scroll till the target is at the bottom of the window\n\t\t\t} else if(targetSize < currentSize && currentPos < (targetPos + targetSize - currentSize)) {\n\t\t\t\treturn targetPos + targetSize - currentSize;\n\t\t\t// If the target is big, then just scroll to the top\n\t\t\t} else if(currentPos < targetPos) {\n\t\t\t\treturn targetPos;\n\t\t\t// Otherwise, stay where we are\n\t\t\t} else {\n\t\t\t\treturn currentPos;\n\t\t\t}\n\t\t},\n\t\tendX = getEndPos(bounds.left,bounds.width,scrollPosition.x,this.outerDomNode.offsetWidth),\n\t\tendY = getEndPos(bounds.top,bounds.height,scrollPosition.y,this.outerDomNode.offsetHeight);\n\t// Only scroll if necessary\n\tif(endX !== scrollPosition.x || endY !== scrollPosition.y) {\n\t\tvar self = this,\n\t\t\tdrawFrame;\n\t\tdrawFrame = function () {\n\t\t\tvar t;\n\t\t\tif(duration <= 0) {\n\t\t\t\tt = 1;\n\t\t\t} else {\n\t\t\t\tt = ((Date.now()) - self.startTime) / duration;\t\n\t\t\t}\n\t\t\tif(t >= 1) {\n\t\t\t\tself.cancelScroll();\n\t\t\t\tt = 1;\n\t\t\t}\n\t\t\tt = $tw.utils.slowInSlowOut(t);\n\t\t\tself.outerDomNode.scrollLeft = scrollPosition.x + (endX - scrollPosition.x) * t;\n\t\t\tself.outerDomNode.scrollTop = scrollPosition.y + (endY - scrollPosition.y) * t;\n\t\t\tif(t < 1) {\n\t\t\t\tself.idRequestFrame = self.requestAnimationFrame.call(window,drawFrame);\n\t\t\t}\n\t\t};\n\t\tdrawFrame();\n\t}\n};\n\n/*\nRender this widget into the DOM\n*/\nScrollableWidget.prototype.render = function(parent,nextSibling) {\n\tvar self = this;\n\t// Remember parent\n\tthis.parentDomNode = parent;\n\t// Compute attributes and execute state\n\tthis.computeAttributes();\n\tthis.execute();\n\t// Create elements\n\tthis.outerDomNode = this.document.createElement(\"div\");\n\t$tw.utils.setStyle(this.outerDomNode,[\n\t\t{overflowY: \"auto\"},\n\t\t{overflowX: \"auto\"},\n\t\t{webkitOverflowScrolling: \"touch\"}\n\t]);\n\tthis.innerDomNode = this.document.createElement(\"div\");\n\tthis.outerDomNode.appendChild(this.innerDomNode);\n\t// Assign classes\n\tthis.outerDomNode.className = this[\"class\"] || \"\";\n\t// Insert element\n\tparent.insertBefore(this.outerDomNode,nextSibling);\n\tthis.renderChildren(this.innerDomNode,null);\n\tthis.domNodes.push(this.outerDomNode);\n};\n\n/*\nCompute the internal state of the widget\n*/\nScrollableWidget.prototype.execute = function() {\n\t// Get attributes\n\tthis.fallthrough = this.getAttribute(\"fallthrough\",\"yes\");\n\tthis[\"class\"] = this.getAttribute(\"class\");\n\t// Make child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nScrollableWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes[\"class\"]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\nexports.scrollable = ScrollableWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/select.js": {
"title": "$:/core/modules/widgets/select.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/select.js\ntype: application/javascript\nmodule-type: widget\n\nSelect widget:\n\n```\n<$select tiddler=\"MyTiddler\" field=\"text\">\n<$list filter=\"[tag[chapter]]\">\n<option value=<<currentTiddler>>>\n<$view field=\"description\"/>\n</option>\n</$list>\n</$select>\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar SelectWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nSelectWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nSelectWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n\tthis.setSelectValue();\n\t$tw.utils.addEventListeners(this.getSelectDomNode(),[\n\t\t{name: \"change\", handlerObject: this, handlerMethod: \"handleChangeEvent\"}\n\t]);\n};\n\n/*\nHandle a change event\n*/\nSelectWidget.prototype.handleChangeEvent = function(event) {\n\t// Get the new value and assign it to the tiddler\n\tif(this.selectMultiple == false) {\n\t\tvar value = this.getSelectDomNode().value;\n\t} else {\n\t\tvar value = this.getSelectValues()\n\t\t\t\tvalue = $tw.utils.stringifyList(value);\n\t}\n\tthis.wiki.setText(this.selectTitle,this.selectField,this.selectIndex,value);\n\t// Trigger actions\n\tif(this.selectActions) {\n\t\tthis.invokeActionString(this.selectActions,this,event);\n\t}\n};\n\n/*\nIf necessary, set the value of the select element to the current value\n*/\nSelectWidget.prototype.setSelectValue = function() {\n\tvar value = this.selectDefault;\n\t// Get the value\n\tif(this.selectIndex) {\n\t\tvalue = this.wiki.extractTiddlerDataItem(this.selectTitle,this.selectIndex,value);\n\t} else {\n\t\tvar tiddler = this.wiki.getTiddler(this.selectTitle);\n\t\tif(tiddler) {\n\t\t\tif(this.selectField === \"text\") {\n\t\t\t\t// Calling getTiddlerText() triggers lazy loading of skinny tiddlers\n\t\t\t\tvalue = this.wiki.getTiddlerText(this.selectTitle);\n\t\t\t} else {\n\t\t\t\tif($tw.utils.hop(tiddler.fields,this.selectField)) {\n\t\t\t\t\tvalue = tiddler.getFieldString(this.selectField);\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tif(this.selectField === \"title\") {\n\t\t\t\tvalue = this.selectTitle;\n\t\t\t}\n\t\t}\n\t}\n\t// Assign it to the select element if it's different than the current value\n\tif (this.selectMultiple) {\n\t\tvalue = value === undefined ? \"\" : value;\n\t\tvar select = this.getSelectDomNode();\n\t\tvar values = Array.isArray(value) ? value : $tw.utils.parseStringArray(value);\n\t\tfor(var i=0; i < select.children.length; i++){\n\t\t\tif(values.indexOf(select.children[i].value) != -1) {\n\t\t\t\tselect.children[i].selected = true;\n\t\t\t}\n\t\t}\n\t\t\n\t} else {\n\t\tvar domNode = this.getSelectDomNode();\n\t\tif(domNode.value !== value) {\n\t\t\tdomNode.value = value;\n\t\t}\n\t}\n};\n\n/*\nGet the DOM node of the select element\n*/\nSelectWidget.prototype.getSelectDomNode = function() {\n\treturn this.children[0].domNodes[0];\n};\n\n// Return an array of the selected opion values\n// select is an HTML select element\nSelectWidget.prototype.getSelectValues = function() {\n\tvar select, result, options, opt;\n\tselect = this.getSelectDomNode();\n\tresult = [];\n\toptions = select && select.options;\n\tfor (var i=0; i<options.length; i++) {\n\t\topt = options[i];\n\t\tif (opt.selected) {\n\t\t\tresult.push(opt.value || opt.text);\n\t\t}\n\t}\n\treturn result;\n}\n\n/*\nCompute the internal state of the widget\n*/\nSelectWidget.prototype.execute = function() {\n\t// Get our parameters\n\tthis.selectActions = this.getAttribute(\"actions\");\n\tthis.selectTitle = this.getAttribute(\"tiddler\",this.getVariable(\"currentTiddler\"));\n\tthis.selectField = this.getAttribute(\"field\",\"text\");\n\tthis.selectIndex = this.getAttribute(\"index\");\n\tthis.selectClass = this.getAttribute(\"class\");\n\tthis.selectDefault = this.getAttribute(\"default\");\n\tthis.selectMultiple = this.getAttribute(\"multiple\", false);\n\tthis.selectSize = this.getAttribute(\"size\");\n\t// Make the child widgets\n\tvar selectNode = {\n\t\ttype: \"element\",\n\t\ttag: \"select\",\n\t\tchildren: this.parseTreeNode.children\n\t};\n\tif(this.selectClass) {\n\t\t$tw.utils.addAttributeToParseTreeNode(selectNode,\"class\",this.selectClass);\n\t}\n\tif(this.selectMultiple) {\n\t\t$tw.utils.addAttributeToParseTreeNode(selectNode,\"multiple\",\"multiple\");\n\t}\n\tif(this.selectSize) {\n\t\t$tw.utils.addAttributeToParseTreeNode(selectNode,\"size\",this.selectSize);\n\t}\n\tthis.makeChildWidgets([selectNode]);\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nSelectWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\t// If we're using a different tiddler/field/index then completely refresh ourselves\n\tif(changedAttributes.selectTitle || changedAttributes.selectField || changedAttributes.selectIndex) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t// If the target tiddler value has changed, just update setting and refresh the children\n\t} else {\n\t\tvar childrenRefreshed = this.refreshChildren(changedTiddlers);\n\t\tif(changedTiddlers[this.selectTitle] || childrenRefreshed) {\n\t\t\tthis.setSelectValue();\n\t\t} \n\t\treturn childrenRefreshed;\n\t}\n};\n\nexports.select = SelectWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/set.js": {
"title": "$:/core/modules/widgets/set.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/set.js\ntype: application/javascript\nmodule-type: widget\n\nSet variable widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar SetWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nSetWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nSetWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n};\n\n/*\nCompute the internal state of the widget\n*/\nSetWidget.prototype.execute = function() {\n\t// Get our parameters\n\tthis.setName = this.getAttribute(\"name\",\"currentTiddler\");\n\tthis.setFilter = this.getAttribute(\"filter\");\n\tthis.setSelect = this.getAttribute(\"select\");\n\tthis.setTiddler = this.getAttribute(\"tiddler\");\n\tthis.setSubTiddler = this.getAttribute(\"subtiddler\");\n\tthis.setField = this.getAttribute(\"field\");\n\tthis.setIndex = this.getAttribute(\"index\");\n\tthis.setValue = this.getAttribute(\"value\");\n\tthis.setEmptyValue = this.getAttribute(\"emptyValue\");\n\t// Set context variable\n\tthis.setVariable(this.setName,this.getValue(),this.parseTreeNode.params,!!this.parseTreeNode.isMacroDefinition);\n\t// Construct the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nGet the value to be assigned\n*/\nSetWidget.prototype.getValue = function() {\n\tvar value = this.setValue;\n\tif(this.setTiddler) {\n\t\tvar tiddler;\n\t\tif(this.setSubTiddler) {\n\t\t\ttiddler = this.wiki.getSubTiddler(this.setTiddler,this.setSubTiddler);\n\t\t} else {\n\t\t\ttiddler = this.wiki.getTiddler(this.setTiddler);\t\t\t\n\t\t}\n\t\tif(!tiddler) {\n\t\t\tvalue = this.setEmptyValue;\n\t\t} else if(this.setField) {\n\t\t\tvalue = tiddler.getFieldString(this.setField) || this.setEmptyValue;\n\t\t} else if(this.setIndex) {\n\t\t\tvalue = this.wiki.extractTiddlerDataItem(this.setTiddler,this.setIndex,this.setEmptyValue);\n\t\t} else {\n\t\t\tvalue = tiddler.fields.text || this.setEmptyValue ;\n\t\t}\n\t} else if(this.setFilter) {\n\t\tvar results = this.wiki.filterTiddlers(this.setFilter,this);\n\t\tif(this.setValue == null) {\n\t\t\tvar select;\n\t\t\tif(this.setSelect) {\n\t\t\t\tselect = parseInt(this.setSelect,10);\n\t\t\t}\n\t\t\tif(select !== undefined) {\n\t\t\t\tvalue = results[select] || \"\";\n\t\t\t} else {\n\t\t\t\tvalue = $tw.utils.stringifyList(results);\t\t\t\n\t\t\t}\n\t\t}\n\t\tif(results.length === 0 && this.setEmptyValue !== undefined) {\n\t\t\tvalue = this.setEmptyValue;\n\t\t}\n\t} else if(!value && this.setEmptyValue) {\n\t\tvalue = this.setEmptyValue;\n\t}\n\treturn value || \"\";\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nSetWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.name || changedAttributes.filter || changedAttributes.select || changedAttributes.tiddler || (this.setTiddler && changedTiddlers[this.setTiddler]) || changedAttributes.field || changedAttributes.index || changedAttributes.value || changedAttributes.emptyValue ||\n\t (this.setFilter && this.getValue() != this.variables[this.setName].value)) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn this.refreshChildren(changedTiddlers);\n\t}\n};\n\nexports.setvariable = SetWidget;\nexports.set = SetWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/text.js": {
"title": "$:/core/modules/widgets/text.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/text.js\ntype: application/javascript\nmodule-type: widget\n\nText node widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar TextNodeWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nTextNodeWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nTextNodeWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tvar text = this.getAttribute(\"text\",this.parseTreeNode.text || \"\");\n\ttext = text.replace(/\\r/mg,\"\");\n\tvar textNode = this.document.createTextNode(text);\n\tparent.insertBefore(textNode,nextSibling);\n\tthis.domNodes.push(textNode);\n};\n\n/*\nCompute the internal state of the widget\n*/\nTextNodeWidget.prototype.execute = function() {\n\t// Nothing to do for a text node\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nTextNodeWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.text) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn false;\t\n\t}\n};\n\nexports.text = TextNodeWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/tiddler.js": {
"title": "$:/core/modules/widgets/tiddler.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/tiddler.js\ntype: application/javascript\nmodule-type: widget\n\nTiddler widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar TiddlerWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nTiddlerWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nTiddlerWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n};\n\n/*\nCompute the internal state of the widget\n*/\nTiddlerWidget.prototype.execute = function() {\n\tthis.tiddlerState = this.computeTiddlerState();\n\tthis.setVariable(\"currentTiddler\",this.tiddlerState.currentTiddler);\n\tthis.setVariable(\"missingTiddlerClass\",this.tiddlerState.missingTiddlerClass);\n\tthis.setVariable(\"shadowTiddlerClass\",this.tiddlerState.shadowTiddlerClass);\n\tthis.setVariable(\"systemTiddlerClass\",this.tiddlerState.systemTiddlerClass);\n\tthis.setVariable(\"tiddlerTagClasses\",this.tiddlerState.tiddlerTagClasses);\n\t// Construct the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nCompute the tiddler state flags\n*/\nTiddlerWidget.prototype.computeTiddlerState = function() {\n\t// Get our parameters\n\tthis.tiddlerTitle = this.getAttribute(\"tiddler\",this.getVariable(\"currentTiddler\"));\n\t// Compute the state\n\tvar state = {\n\t\tcurrentTiddler: this.tiddlerTitle || \"\",\n\t\tmissingTiddlerClass: (this.wiki.tiddlerExists(this.tiddlerTitle) || this.wiki.isShadowTiddler(this.tiddlerTitle)) ? \"tc-tiddler-exists\" : \"tc-tiddler-missing\",\n\t\tshadowTiddlerClass: this.wiki.isShadowTiddler(this.tiddlerTitle) ? \"tc-tiddler-shadow\" : \"\",\n\t\tsystemTiddlerClass: this.wiki.isSystemTiddler(this.tiddlerTitle) ? \"tc-tiddler-system\" : \"\",\n\t\ttiddlerTagClasses: this.getTagClasses()\n\t};\n\t// Compute a simple hash to make it easier to detect changes\n\tstate.hash = state.currentTiddler + state.missingTiddlerClass + state.shadowTiddlerClass + state.systemTiddlerClass + state.tiddlerTagClasses;\n\treturn state;\n};\n\n/*\nCreate a string of CSS classes derived from the tags of the current tiddler\n*/\nTiddlerWidget.prototype.getTagClasses = function() {\n\tvar tiddler = this.wiki.getTiddler(this.tiddlerTitle);\n\tif(tiddler) {\n\t\tvar tags = [];\n\t\t$tw.utils.each(tiddler.fields.tags,function(tag) {\n\t\t\ttags.push(\"tc-tagged-\" + encodeURIComponent(tag));\n\t\t});\n\t\treturn tags.join(\" \");\n\t} else {\n\t\treturn \"\";\n\t}\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nTiddlerWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes(),\n\t\tnewTiddlerState = this.computeTiddlerState();\n\tif(changedAttributes.tiddler || newTiddlerState.hash !== this.tiddlerState.hash) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn this.refreshChildren(changedTiddlers);\t\t\n\t}\n};\n\nexports.tiddler = TiddlerWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/transclude.js": {
"title": "$:/core/modules/widgets/transclude.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/transclude.js\ntype: application/javascript\nmodule-type: widget\n\nTransclude widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar TranscludeWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nTranscludeWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nTranscludeWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n};\n\n/*\nCompute the internal state of the widget\n*/\nTranscludeWidget.prototype.execute = function() {\n\t// Get our parameters\n\tthis.transcludeTitle = this.getAttribute(\"tiddler\",this.getVariable(\"currentTiddler\"));\n\tthis.transcludeSubTiddler = this.getAttribute(\"subtiddler\");\n\tthis.transcludeField = this.getAttribute(\"field\");\n\tthis.transcludeIndex = this.getAttribute(\"index\");\n\tthis.transcludeMode = this.getAttribute(\"mode\");\n\t// Parse the text reference\n\tvar parseAsInline = !this.parseTreeNode.isBlock;\n\tif(this.transcludeMode === \"inline\") {\n\t\tparseAsInline = true;\n\t} else if(this.transcludeMode === \"block\") {\n\t\tparseAsInline = false;\n\t}\n\tvar parser = this.wiki.parseTextReference(\n\t\t\t\t\t\tthis.transcludeTitle,\n\t\t\t\t\t\tthis.transcludeField,\n\t\t\t\t\t\tthis.transcludeIndex,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tparseAsInline: parseAsInline,\n\t\t\t\t\t\t\tsubTiddler: this.transcludeSubTiddler\n\t\t\t\t\t\t}),\n\t\tparseTreeNodes = parser ? parser.tree : this.parseTreeNode.children;\n\t// Set context variables for recursion detection\n\tvar recursionMarker = this.makeRecursionMarker();\n\tthis.setVariable(\"transclusion\",recursionMarker);\n\t// Check for recursion\n\tif(parser) {\n\t\tif(this.parentWidget && this.parentWidget.hasVariable(\"transclusion\",recursionMarker)) {\n\t\t\tparseTreeNodes = [{type: \"element\", tag: \"span\", attributes: {\n\t\t\t\t\"class\": {type: \"string\", value: \"tc-error\"}\n\t\t\t}, children: [\n\t\t\t\t{type: \"text\", text: $tw.language.getString(\"Error/RecursiveTransclusion\")}\n\t\t\t]}];\n\t\t}\n\t}\n\t// Construct the child widgets\n\tthis.makeChildWidgets(parseTreeNodes);\n};\n\n/*\nCompose a string comprising the title, field and/or index to identify this transclusion for recursion detection\n*/\nTranscludeWidget.prototype.makeRecursionMarker = function() {\n\tvar output = [];\n\toutput.push(\"{\");\n\toutput.push(this.getVariable(\"currentTiddler\",{defaultValue: \"\"}));\n\toutput.push(\"|\");\n\toutput.push(this.transcludeTitle || \"\");\n\toutput.push(\"|\");\n\toutput.push(this.transcludeField || \"\");\n\toutput.push(\"|\");\n\toutput.push(this.transcludeIndex || \"\");\n\toutput.push(\"|\");\n\toutput.push(this.transcludeSubTiddler || \"\");\n\toutput.push(\"}\");\n\treturn output.join(\"\");\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nTranscludeWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.tiddler || changedAttributes.field || changedAttributes.index || changedTiddlers[this.transcludeTitle]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn this.refreshChildren(changedTiddlers);\t\t\n\t}\n};\n\nexports.transclude = TranscludeWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/vars.js": {
"title": "$:/core/modules/widgets/vars.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/vars.js\ntype: application/javascript\nmodule-type: widget\n\nThis widget allows multiple variables to be set in one go:\n\n```\n\\define helloworld() Hello world!\n<$vars greeting=\"Hi\" me={{!!title}} sentence=<<helloworld>>>\n <<greeting>>! I am <<me>> and I say: <<sentence>>\n</$vars>\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar VarsWidget = function(parseTreeNode,options) {\n\t// Call the constructor\n\tWidget.call(this);\n\t// Initialise\t\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nVarsWidget.prototype = Object.create(Widget.prototype);\n\n/*\nRender this widget into the DOM\n*/\nVarsWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n};\n\n/*\nCompute the internal state of the widget\n*/\nVarsWidget.prototype.execute = function() {\n\t// Parse variables\n\tvar self = this;\n\t$tw.utils.each(this.attributes,function(val,key) {\n\t\tif(key.charAt(0) !== \"$\") {\n\t\t\tself.setVariable(key,val);\n\t\t}\n\t});\n\t// Construct the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nRefresh the widget by ensuring our attributes are up to date\n*/\nVarsWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(Object.keys(changedAttributes).length) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\nexports[\"vars\"] = VarsWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/view.js": {
"title": "$:/core/modules/widgets/view.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/view.js\ntype: application/javascript\nmodule-type: widget\n\nView widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar ViewWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nViewWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nViewWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tif(this.text) {\n\t\tvar textNode = this.document.createTextNode(this.text);\n\t\tparent.insertBefore(textNode,nextSibling);\n\t\tthis.domNodes.push(textNode);\n\t} else {\n\t\tthis.makeChildWidgets();\n\t\tthis.renderChildren(parent,nextSibling);\n\t}\n};\n\n/*\nCompute the internal state of the widget\n*/\nViewWidget.prototype.execute = function() {\n\t// Get parameters from our attributes\n\tthis.viewTitle = this.getAttribute(\"tiddler\",this.getVariable(\"currentTiddler\"));\n\tthis.viewSubtiddler = this.getAttribute(\"subtiddler\");\n\tthis.viewField = this.getAttribute(\"field\",\"text\");\n\tthis.viewIndex = this.getAttribute(\"index\");\n\tthis.viewFormat = this.getAttribute(\"format\",\"text\");\n\tthis.viewTemplate = this.getAttribute(\"template\",\"\");\n\tthis.viewMode = this.getAttribute(\"mode\",\"block\");\n\tswitch(this.viewFormat) {\n\t\tcase \"htmlwikified\":\n\t\t\tthis.text = this.getValueAsHtmlWikified(this.viewMode);\n\t\t\tbreak;\n\t\tcase \"plainwikified\":\n\t\t\tthis.text = this.getValueAsPlainWikified(this.viewMode);\n\t\t\tbreak;\n\t\tcase \"htmlencodedplainwikified\":\n\t\t\tthis.text = this.getValueAsHtmlEncodedPlainWikified(this.viewMode);\n\t\t\tbreak;\n\t\tcase \"htmlencoded\":\n\t\t\tthis.text = this.getValueAsHtmlEncoded();\n\t\t\tbreak;\n\t\tcase \"urlencoded\":\n\t\t\tthis.text = this.getValueAsUrlEncoded();\n\t\t\tbreak;\n\t\tcase \"doubleurlencoded\":\n\t\t\tthis.text = this.getValueAsDoubleUrlEncoded();\n\t\t\tbreak;\n\t\tcase \"date\":\n\t\t\tthis.text = this.getValueAsDate(this.viewTemplate);\n\t\t\tbreak;\n\t\tcase \"relativedate\":\n\t\t\tthis.text = this.getValueAsRelativeDate();\n\t\t\tbreak;\n\t\tcase \"stripcomments\":\n\t\t\tthis.text = this.getValueAsStrippedComments();\n\t\t\tbreak;\n\t\tcase \"jsencoded\":\n\t\t\tthis.text = this.getValueAsJsEncoded();\n\t\t\tbreak;\n\t\tdefault: // \"text\"\n\t\t\tthis.text = this.getValueAsText();\n\t\t\tbreak;\n\t}\n};\n\n/*\nThe various formatter functions are baked into this widget for the moment. Eventually they will be replaced by macro functions\n*/\n\n/*\nRetrieve the value of the widget. Options are:\nasString: Optionally return the value as a string\n*/\nViewWidget.prototype.getValue = function(options) {\n\toptions = options || {};\n\tvar value = options.asString ? \"\" : undefined;\n\tif(this.viewIndex) {\n\t\tvalue = this.wiki.extractTiddlerDataItem(this.viewTitle,this.viewIndex);\n\t} else {\n\t\tvar tiddler;\n\t\tif(this.viewSubtiddler) {\n\t\t\ttiddler = this.wiki.getSubTiddler(this.viewTitle,this.viewSubtiddler);\t\n\t\t} else {\n\t\t\ttiddler = this.wiki.getTiddler(this.viewTitle);\n\t\t}\n\t\tif(tiddler) {\n\t\t\tif(this.viewField === \"text\" && !this.viewSubtiddler) {\n\t\t\t\t// Calling getTiddlerText() triggers lazy loading of skinny tiddlers\n\t\t\t\tvalue = this.wiki.getTiddlerText(this.viewTitle);\n\t\t\t} else {\n\t\t\t\tif($tw.utils.hop(tiddler.fields,this.viewField)) {\n\t\t\t\t\tif(options.asString) {\n\t\t\t\t\t\tvalue = tiddler.getFieldString(this.viewField);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvalue = tiddler.fields[this.viewField];\t\t\t\t\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tif(this.viewField === \"title\") {\n\t\t\t\tvalue = this.viewTitle;\n\t\t\t}\n\t\t}\n\t}\n\treturn value;\n};\n\nViewWidget.prototype.getValueAsText = function() {\n\treturn this.getValue({asString: true});\n};\n\nViewWidget.prototype.getValueAsHtmlWikified = function(mode) {\n\treturn this.wiki.renderText(\"text/html\",\"text/vnd.tiddlywiki\",this.getValueAsText(),{\n\t\tparseAsInline: mode !== \"block\",\n\t\tparentWidget: this\n\t});\n};\n\nViewWidget.prototype.getValueAsPlainWikified = function(mode) {\n\treturn this.wiki.renderText(\"text/plain\",\"text/vnd.tiddlywiki\",this.getValueAsText(),{\n\t\tparseAsInline: mode !== \"block\",\n\t\tparentWidget: this\n\t});\n};\n\nViewWidget.prototype.getValueAsHtmlEncodedPlainWikified = function(mode) {\n\treturn $tw.utils.htmlEncode(this.wiki.renderText(\"text/plain\",\"text/vnd.tiddlywiki\",this.getValueAsText(),{\n\t\tparseAsInline: mode !== \"block\",\n\t\tparentWidget: this\n\t}));\n};\n\nViewWidget.prototype.getValueAsHtmlEncoded = function() {\n\treturn $tw.utils.htmlEncode(this.getValueAsText());\n};\n\nViewWidget.prototype.getValueAsUrlEncoded = function() {\n\treturn encodeURIComponent(this.getValueAsText());\n};\n\nViewWidget.prototype.getValueAsDoubleUrlEncoded = function() {\n\treturn encodeURIComponent(encodeURIComponent(this.getValueAsText()));\n};\n\nViewWidget.prototype.getValueAsDate = function(format) {\n\tformat = format || \"YYYY MM DD 0hh:0mm\";\n\tvar value = $tw.utils.parseDate(this.getValue());\n\tif(value && $tw.utils.isDate(value) && value.toString() !== \"Invalid Date\") {\n\t\treturn $tw.utils.formatDateString(value,format);\n\t} else {\n\t\treturn \"\";\n\t}\n};\n\nViewWidget.prototype.getValueAsRelativeDate = function(format) {\n\tvar value = $tw.utils.parseDate(this.getValue());\n\tif(value && $tw.utils.isDate(value) && value.toString() !== \"Invalid Date\") {\n\t\treturn $tw.utils.getRelativeDate((new Date()) - (new Date(value))).description;\n\t} else {\n\t\treturn \"\";\n\t}\n};\n\nViewWidget.prototype.getValueAsStrippedComments = function() {\n\tvar lines = this.getValueAsText().split(\"\\n\"),\n\t\tout = [];\n\tfor(var line=0; line<lines.length; line++) {\n\t\tvar text = lines[line];\n\t\tif(!/^\\s*\\/\\/#/.test(text)) {\n\t\t\tout.push(text);\n\t\t}\n\t}\n\treturn out.join(\"\\n\");\n};\n\nViewWidget.prototype.getValueAsJsEncoded = function() {\n\treturn $tw.utils.stringify(this.getValueAsText());\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nViewWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.tiddler || changedAttributes.field || changedAttributes.index || changedAttributes.template || changedAttributes.format || changedTiddlers[this.viewTitle]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn false;\t\n\t}\n};\n\nexports.view = ViewWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/widget.js": {
"title": "$:/core/modules/widgets/widget.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/widget.js\ntype: application/javascript\nmodule-type: widget\n\nWidget base class\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nCreate a widget object for a parse tree node\n\tparseTreeNode: reference to the parse tree node to be rendered\n\toptions: see below\nOptions include:\n\twiki: mandatory reference to wiki associated with this render tree\n\tparentWidget: optional reference to a parent renderer node for the context chain\n\tdocument: optional document object to use instead of global document\n*/\nvar Widget = function(parseTreeNode,options) {\n\tif(arguments.length > 0) {\n\t\tthis.initialise(parseTreeNode,options);\n\t}\n};\n\n/*\nInitialise widget properties. These steps are pulled out of the constructor so that we can reuse them in subclasses\n*/\nWidget.prototype.initialise = function(parseTreeNode,options) {\n\toptions = options || {};\n\t// Save widget info\n\tthis.parseTreeNode = parseTreeNode;\n\tthis.wiki = options.wiki;\n\tthis.parentWidget = options.parentWidget;\n\tthis.variablesConstructor = function() {};\n\tthis.variablesConstructor.prototype = this.parentWidget ? this.parentWidget.variables : {};\n\tthis.variables = new this.variablesConstructor();\n\tthis.document = options.document;\n\tthis.attributes = {};\n\tthis.children = [];\n\tthis.domNodes = [];\n\tthis.eventListeners = {};\n\t// Hashmap of the widget classes\n\tif(!this.widgetClasses) {\n\t\tWidget.prototype.widgetClasses = $tw.modules.applyMethods(\"widget\");\n\t}\n};\n\n/*\nRender this widget into the DOM\n*/\nWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n};\n\n/*\nCompute the internal state of the widget\n*/\nWidget.prototype.execute = function() {\n\tthis.makeChildWidgets();\n};\n\n/*\nSet the value of a context variable\nname: name of the variable\nvalue: value of the variable\nparams: array of {name:, default:} for each parameter\nisMacroDefinition: true if the variable is set via a \\define macro pragma (and hence should have variable substitution performed)\n*/\nWidget.prototype.setVariable = function(name,value,params,isMacroDefinition) {\n\tthis.variables[name] = {value: value, params: params, isMacroDefinition: !!isMacroDefinition};\n};\n\n/*\nGet the prevailing value of a context variable\nname: name of variable\noptions: see below\nOptions include\nparams: array of {name:, value:} for each parameter\ndefaultValue: default value if the variable is not defined\n\nReturns an object with the following fields:\n\nparams: array of {name:,value:} of parameters passed to wikitext variables\ntext: text of variable, with parameters properly substituted\n*/\nWidget.prototype.getVariableInfo = function(name,options) {\n\toptions = options || {};\n\tvar actualParams = options.params || [],\n\t\tparentWidget = this.parentWidget;\n\t// Check for the variable defined in the parent widget (or an ancestor in the prototype chain)\n\tif(parentWidget && name in parentWidget.variables) {\n\t\tvar variable = parentWidget.variables[name],\n\t\t\tvalue = variable.value,\n\t\t\tparams = this.resolveVariableParameters(variable.params,actualParams);\n\t\t// Substitute any parameters specified in the definition\n\t\t$tw.utils.each(params,function(param) {\n\t\t\tvalue = $tw.utils.replaceString(value,new RegExp(\"\\\\$\" + $tw.utils.escapeRegExp(param.name) + \"\\\\$\",\"mg\"),param.value);\n\t\t});\n\t\t// Only substitute variable references if this variable was defined with the \\define pragma\n\t\tif(variable.isMacroDefinition) {\n\t\t\tvalue = this.substituteVariableReferences(value);\t\t\t\n\t\t}\n\t\treturn {\n\t\t\ttext: value,\n\t\t\tparams: params\n\t\t};\n\t}\n\t// If the variable doesn't exist in the parent widget then look for a macro module\n\treturn {\n\t\ttext: this.evaluateMacroModule(name,actualParams,options.defaultValue)\n\t};\n};\n\n/*\nSimplified version of getVariableInfo() that just returns the text\n*/\nWidget.prototype.getVariable = function(name,options) {\n\treturn this.getVariableInfo(name,options).text;\n};\n\nWidget.prototype.resolveVariableParameters = function(formalParams,actualParams) {\n\tformalParams = formalParams || [];\n\tactualParams = actualParams || [];\n\tvar nextAnonParameter = 0, // Next candidate anonymous parameter in macro call\n\t\tparamInfo, paramValue,\n\t\tresults = [];\n\t// Step through each of the parameters in the macro definition\n\tfor(var p=0; p<formalParams.length; p++) {\n\t\t// Check if we've got a macro call parameter with the same name\n\t\tparamInfo = formalParams[p];\n\t\tparamValue = undefined;\n\t\tfor(var m=0; m<actualParams.length; m++) {\n\t\t\tif(actualParams[m].name === paramInfo.name) {\n\t\t\t\tparamValue = actualParams[m].value;\n\t\t\t}\n\t\t}\n\t\t// If not, use the next available anonymous macro call parameter\n\t\twhile(nextAnonParameter < actualParams.length && actualParams[nextAnonParameter].name) {\n\t\t\tnextAnonParameter++;\n\t\t}\n\t\tif(paramValue === undefined && nextAnonParameter < actualParams.length) {\n\t\t\tparamValue = actualParams[nextAnonParameter++].value;\n\t\t}\n\t\t// If we've still not got a value, use the default, if any\n\t\tparamValue = paramValue || paramInfo[\"default\"] || \"\";\n\t\t// Store the parameter name and value\n\t\tresults.push({name: paramInfo.name, value: paramValue});\n\t}\n\treturn results;\n};\n\nWidget.prototype.substituteVariableReferences = function(text) {\n\tvar self = this;\n\treturn (text || \"\").replace(/\\$\\(([^\\)\\$]+)\\)\\$/g,function(match,p1,offset,string) {\n\t\treturn self.getVariable(p1,{defaultValue: \"\"});\n\t});\n};\n\nWidget.prototype.evaluateMacroModule = function(name,actualParams,defaultValue) {\n\tif($tw.utils.hop($tw.macros,name)) {\n\t\tvar macro = $tw.macros[name],\n\t\t\targs = [];\n\t\tif(macro.params.length > 0) {\n\t\t\tvar nextAnonParameter = 0, // Next candidate anonymous parameter in macro call\n\t\t\t\tparamInfo, paramValue;\n\t\t\t// Step through each of the parameters in the macro definition\n\t\t\tfor(var p=0; p<macro.params.length; p++) {\n\t\t\t\t// Check if we've got a macro call parameter with the same name\n\t\t\t\tparamInfo = macro.params[p];\n\t\t\t\tparamValue = undefined;\n\t\t\t\tfor(var m=0; m<actualParams.length; m++) {\n\t\t\t\t\tif(actualParams[m].name === paramInfo.name) {\n\t\t\t\t\t\tparamValue = actualParams[m].value;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t// If not, use the next available anonymous macro call parameter\n\t\t\t\twhile(nextAnonParameter < actualParams.length && actualParams[nextAnonParameter].name) {\n\t\t\t\t\tnextAnonParameter++;\n\t\t\t\t}\n\t\t\t\tif(paramValue === undefined && nextAnonParameter < actualParams.length) {\n\t\t\t\t\tparamValue = actualParams[nextAnonParameter++].value;\n\t\t\t\t}\n\t\t\t\t// If we've still not got a value, use the default, if any\n\t\t\t\tparamValue = paramValue || paramInfo[\"default\"] || \"\";\n\t\t\t\t// Save the parameter\n\t\t\t\targs.push(paramValue);\n\t\t\t}\n\t\t}\n\t\telse for(var i=0; i<actualParams.length; ++i) {\n\t\t\targs.push(actualParams[i].value);\n\t\t}\n\t\treturn (macro.run.apply(this,args) || \"\").toString();\n\t} else {\n\t\treturn defaultValue;\n\t}\n};\n\n/*\nCheck whether a given context variable value exists in the parent chain\n*/\nWidget.prototype.hasVariable = function(name,value) {\n\tvar node = this;\n\twhile(node) {\n\t\tif($tw.utils.hop(node.variables,name) && node.variables[name].value === value) {\n\t\t\treturn true;\n\t\t}\n\t\tnode = node.parentWidget;\n\t}\n\treturn false;\n};\n\n/*\nConstruct a qualifying string based on a hash of concatenating the values of a given variable in the parent chain\n*/\nWidget.prototype.getStateQualifier = function(name) {\n\tthis.qualifiers = this.qualifiers || Object.create(null);\n\tname = name || \"transclusion\";\n\tif(this.qualifiers[name]) {\n\t\treturn this.qualifiers[name];\n\t} else {\n\t\tvar output = [],\n\t\t\tnode = this;\n\t\twhile(node && node.parentWidget) {\n\t\t\tif($tw.utils.hop(node.parentWidget.variables,name)) {\n\t\t\t\toutput.push(node.getVariable(name));\n\t\t\t}\n\t\t\tnode = node.parentWidget;\n\t\t}\n\t\tvar value = $tw.utils.hashString(output.join(\"\"));\n\t\tthis.qualifiers[name] = value;\n\t\treturn value;\n\t}\n};\n\n/*\nCompute the current values of the attributes of the widget. Returns a hashmap of the names of the attributes that have changed\n*/\nWidget.prototype.computeAttributes = function() {\n\tvar changedAttributes = {},\n\t\tself = this,\n\t\tvalue;\n\t$tw.utils.each(this.parseTreeNode.attributes,function(attribute,name) {\n\t\tif(attribute.type === \"filtered\") {\n\t\t\tvalue = self.wiki.filterTiddlers(attribute.filter,self)[0] || \"\";\n\t\t} else if(attribute.type === \"indirect\") {\n\t\t\tvalue = self.wiki.getTextReference(attribute.textReference,\"\",self.getVariable(\"currentTiddler\"));\n\t\t} else if(attribute.type === \"macro\") {\n\t\t\tvalue = self.getVariable(attribute.value.name,{params: attribute.value.params});\n\t\t} else { // String attribute\n\t\t\tvalue = attribute.value;\n\t\t}\n\t\t// Check whether the attribute has changed\n\t\tif(self.attributes[name] !== value) {\n\t\t\tself.attributes[name] = value;\n\t\t\tchangedAttributes[name] = true;\n\t\t}\n\t});\n\treturn changedAttributes;\n};\n\n/*\nCheck for the presence of an attribute\n*/\nWidget.prototype.hasAttribute = function(name) {\n\treturn $tw.utils.hop(this.attributes,name);\n};\n\n/*\nGet the value of an attribute\n*/\nWidget.prototype.getAttribute = function(name,defaultText) {\n\tif($tw.utils.hop(this.attributes,name)) {\n\t\treturn this.attributes[name];\n\t} else {\n\t\treturn defaultText;\n\t}\n};\n\n/*\nAssign the computed attributes of the widget to a domNode\noptions include:\nexcludeEventAttributes: ignores attributes whose name begins with \"on\"\n*/\nWidget.prototype.assignAttributes = function(domNode,options) {\n\toptions = options || {};\n\tvar self = this;\n\t$tw.utils.each(this.attributes,function(v,a) {\n\t\t// Check exclusions\n\t\tif(options.excludeEventAttributes && a.substr(0,2) === \"on\") {\n\t\t\tv = undefined;\n\t\t}\n\t\tif(v !== undefined) {\n\t\t\tvar b = a.split(\":\");\n\t\t\t// Setting certain attributes can cause a DOM error (eg xmlns on the svg element)\n\t\t\ttry {\n\t\t\t\tif (b.length == 2 && b[0] == \"xlink\"){\n\t\t\t\t\tdomNode.setAttributeNS(\"http://www.w3.org/1999/xlink\",b[1],v);\n\t\t\t\t} else {\n\t\t\t\t\tdomNode.setAttributeNS(null,a,v);\n\t\t\t\t}\n\t\t\t} catch(e) {\n\t\t\t}\n\t\t}\n\t});\n};\n\n/*\nMake child widgets correspondng to specified parseTreeNodes\n*/\nWidget.prototype.makeChildWidgets = function(parseTreeNodes) {\n\tthis.children = [];\n\tvar self = this;\n\t$tw.utils.each(parseTreeNodes || (this.parseTreeNode && this.parseTreeNode.children),function(childNode) {\n\t\tself.children.push(self.makeChildWidget(childNode));\n\t});\n};\n\n/*\nConstruct the widget object for a parse tree node\n*/\nWidget.prototype.makeChildWidget = function(parseTreeNode) {\n\tvar WidgetClass = this.widgetClasses[parseTreeNode.type];\n\tif(!WidgetClass) {\n\t\tWidgetClass = this.widgetClasses.text;\n\t\tparseTreeNode = {type: \"text\", text: \"Undefined widget '\" + parseTreeNode.type + \"'\"};\n\t}\n\treturn new WidgetClass(parseTreeNode,{\n\t\twiki: this.wiki,\n\t\tvariables: {},\n\t\tparentWidget: this,\n\t\tdocument: this.document\n\t});\n};\n\n/*\nGet the next sibling of this widget\n*/\nWidget.prototype.nextSibling = function() {\n\tif(this.parentWidget) {\n\t\tvar index = this.parentWidget.children.indexOf(this);\n\t\tif(index !== -1 && index < this.parentWidget.children.length-1) {\n\t\t\treturn this.parentWidget.children[index+1];\n\t\t}\n\t}\n\treturn null;\n};\n\n/*\nGet the previous sibling of this widget\n*/\nWidget.prototype.previousSibling = function() {\n\tif(this.parentWidget) {\n\t\tvar index = this.parentWidget.children.indexOf(this);\n\t\tif(index !== -1 && index > 0) {\n\t\t\treturn this.parentWidget.children[index-1];\n\t\t}\n\t}\n\treturn null;\n};\n\n/*\nRender the children of this widget into the DOM\n*/\nWidget.prototype.renderChildren = function(parent,nextSibling) {\n\t$tw.utils.each(this.children,function(childWidget) {\n\t\tchildWidget.render(parent,nextSibling);\n\t});\n};\n\n/*\nAdd a list of event listeners from an array [{type:,handler:},...]\n*/\nWidget.prototype.addEventListeners = function(listeners) {\n\tvar self = this;\n\t$tw.utils.each(listeners,function(listenerInfo) {\n\t\tself.addEventListener(listenerInfo.type,listenerInfo.handler);\n\t});\n};\n\n/*\nAdd an event listener\n*/\nWidget.prototype.addEventListener = function(type,handler) {\n\tvar self = this;\n\tif(typeof handler === \"string\") { // The handler is a method name on this widget\n\t\tthis.eventListeners[type] = function(event) {\n\t\t\treturn self[handler].call(self,event);\n\t\t};\n\t} else { // The handler is a function\n\t\tthis.eventListeners[type] = function(event) {\n\t\t\treturn handler.call(self,event);\n\t\t};\n\t}\n};\n\n/*\nDispatch an event to a widget. If the widget doesn't handle the event then it is also dispatched to the parent widget\n*/\nWidget.prototype.dispatchEvent = function(event) {\n\t// Dispatch the event if this widget handles it\n\tvar listener = this.eventListeners[event.type];\n\tif(listener) {\n\t\t// Don't propagate the event if the listener returned false\n\t\tif(!listener(event)) {\n\t\t\treturn false;\n\t\t}\n\t}\n\t// Dispatch the event to the parent widget\n\tif(this.parentWidget) {\n\t\treturn this.parentWidget.dispatchEvent(event);\n\t}\n\treturn true;\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nWidget.prototype.refresh = function(changedTiddlers) {\n\treturn this.refreshChildren(changedTiddlers);\n};\n\n/*\nRebuild a previously rendered widget\n*/\nWidget.prototype.refreshSelf = function() {\n\tvar nextSibling = this.findNextSiblingDomNode();\n\tthis.removeChildDomNodes();\n\tthis.render(this.parentDomNode,nextSibling);\n};\n\n/*\nRefresh all the children of a widget\n*/\nWidget.prototype.refreshChildren = function(changedTiddlers) {\n\tvar self = this,\n\t\trefreshed = false;\n\t$tw.utils.each(this.children,function(childWidget) {\n\t\trefreshed = childWidget.refresh(changedTiddlers) || refreshed;\n\t});\n\treturn refreshed;\n};\n\n/*\nFind the next sibling in the DOM to this widget. This is done by scanning the widget tree through all next siblings and their descendents that share the same parent DOM node\n*/\nWidget.prototype.findNextSiblingDomNode = function(startIndex) {\n\t// Refer to this widget by its index within its parents children\n\tvar parent = this.parentWidget,\n\t\tindex = startIndex !== undefined ? startIndex : parent.children.indexOf(this);\nif(index === -1) {\n\tthrow \"node not found in parents children\";\n}\n\t// Look for a DOM node in the later siblings\n\twhile(++index < parent.children.length) {\n\t\tvar domNode = parent.children[index].findFirstDomNode();\n\t\tif(domNode) {\n\t\t\treturn domNode;\n\t\t}\n\t}\n\t// Go back and look for later siblings of our parent if it has the same parent dom node\n\tvar grandParent = parent.parentWidget;\n\tif(grandParent && parent.parentDomNode === this.parentDomNode) {\n\t\tindex = grandParent.children.indexOf(parent);\n\t\tif(index !== -1) {\n\t\t\treturn parent.findNextSiblingDomNode(index);\n\t\t}\n\t}\n\treturn null;\n};\n\n/*\nFind the first DOM node generated by a widget or its children\n*/\nWidget.prototype.findFirstDomNode = function() {\n\t// Return the first dom node of this widget, if we've got one\n\tif(this.domNodes.length > 0) {\n\t\treturn this.domNodes[0];\n\t}\n\t// Otherwise, recursively call our children\n\tfor(var t=0; t<this.children.length; t++) {\n\t\tvar domNode = this.children[t].findFirstDomNode();\n\t\tif(domNode) {\n\t\t\treturn domNode;\n\t\t}\n\t}\n\treturn null;\n};\n\n/*\nRemove any DOM nodes created by this widget or its children\n*/\nWidget.prototype.removeChildDomNodes = function() {\n\t// If this widget has directly created DOM nodes, delete them and exit. This assumes that any child widgets are contained within the created DOM nodes, which would normally be the case\n\tif(this.domNodes.length > 0) {\n\t\t$tw.utils.each(this.domNodes,function(domNode) {\n\t\t\tdomNode.parentNode.removeChild(domNode);\n\t\t});\n\t\tthis.domNodes = [];\n\t} else {\n\t\t// Otherwise, ask the child widgets to delete their DOM nodes\n\t\t$tw.utils.each(this.children,function(childWidget) {\n\t\t\tchildWidget.removeChildDomNodes();\n\t\t});\n\t}\n};\n\n/*\nInvoke the action widgets that are descendents of the current widget.\n*/\nWidget.prototype.invokeActions = function(triggeringWidget,event) {\n\tvar handled = false;\n\t// For each child widget\n\tfor(var t=0; t<this.children.length; t++) {\n\t\tvar child = this.children[t];\n\t\t// Invoke the child if it is an action widget\n\t\tif(child.invokeAction) {\n\t\t\tchild.refreshSelf();\n\t\t\tif(child.invokeAction(triggeringWidget,event)) {\n\t\t\t\thandled = true;\n\t\t\t}\n\t\t}\n\t\t// Propagate through through the child if it permits it\n\t\tif(child.allowActionPropagation() && child.invokeActions(triggeringWidget,event)) {\n\t\t\thandled = true;\n\t\t}\n\t}\n\treturn handled;\n};\n\n/*\nInvoke the action widgets defined in a string\n*/\nWidget.prototype.invokeActionString = function(actions,triggeringWidget,event,variables) {\n\tactions = actions || \"\";\n\tvar parser = this.wiki.parseText(\"text/vnd.tiddlywiki\",actions,{\n\t\t\tparentWidget: this,\n\t\t\tdocument: this.document\n\t\t}),\n\t\twidgetNode = this.wiki.makeWidget(parser,{\n\t\t\tparentWidget: this,\n\t\t\tdocument: this.document,\n\t\t\tvariables: variables\n\t\t});\n\tvar container = this.document.createElement(\"div\");\n\twidgetNode.render(container,null);\n\treturn widgetNode.invokeActions(this,event);\n};\n\nWidget.prototype.allowActionPropagation = function() {\n\treturn true;\n};\n\nexports.widget = Widget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/widgets/wikify.js": {
"title": "$:/core/modules/widgets/wikify.js",
"text": "/*\\\ntitle: $:/core/modules/widgets/wikify.js\ntype: application/javascript\nmodule-type: widget\n\nWidget to wikify text into a variable\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar WikifyWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nWikifyWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nWikifyWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n};\n\n/*\nCompute the internal state of the widget\n*/\nWikifyWidget.prototype.execute = function() {\n\t// Get our parameters\n\tthis.wikifyName = this.getAttribute(\"name\");\n\tthis.wikifyText = this.getAttribute(\"text\");\n\tthis.wikifyType = this.getAttribute(\"type\");\n\tthis.wikifyMode = this.getAttribute(\"mode\",\"block\");\n\tthis.wikifyOutput = this.getAttribute(\"output\",\"text\");\n\t// Create the parse tree\n\tthis.wikifyParser = this.wiki.parseText(this.wikifyType,this.wikifyText,{\n\t\t\tparseAsInline: this.wikifyMode === \"inline\"\n\t\t});\n\t// Create the widget tree \n\tthis.wikifyWidgetNode = this.wiki.makeWidget(this.wikifyParser,{\n\t\t\tdocument: $tw.fakeDocument,\n\t\t\tparentWidget: this\n\t\t});\n\t// Render the widget tree to the container\n\tthis.wikifyContainer = $tw.fakeDocument.createElement(\"div\");\n\tthis.wikifyWidgetNode.render(this.wikifyContainer,null);\n\tthis.wikifyResult = this.getResult();\n\t// Set context variable\n\tthis.setVariable(this.wikifyName,this.wikifyResult);\n\t// Construct the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nReturn the result string\n*/\nWikifyWidget.prototype.getResult = function() {\n\tvar result;\n\tswitch(this.wikifyOutput) {\n\t\tcase \"text\":\n\t\t\tresult = this.wikifyContainer.textContent;\n\t\t\tbreak;\n\t\tcase \"formattedtext\":\n\t\t\tresult = this.wikifyContainer.formattedTextContent;\n\t\t\tbreak;\n\t\tcase \"html\":\n\t\t\tresult = this.wikifyContainer.innerHTML;\n\t\t\tbreak;\n\t\tcase \"parsetree\":\n\t\t\tresult = JSON.stringify(this.wikifyParser.tree,0,$tw.config.preferences.jsonSpaces);\n\t\t\tbreak;\n\t\tcase \"widgettree\":\n\t\t\tresult = JSON.stringify(this.getWidgetTree(),0,$tw.config.preferences.jsonSpaces);\n\t\t\tbreak;\n\t}\n\treturn result;\n};\n\n/*\nReturn a string of the widget tree\n*/\nWikifyWidget.prototype.getWidgetTree = function() {\n\tvar copyNode = function(widgetNode,resultNode) {\n\t\t\tvar type = widgetNode.parseTreeNode.type;\n\t\t\tresultNode.type = type;\n\t\t\tswitch(type) {\n\t\t\t\tcase \"element\":\n\t\t\t\t\tresultNode.tag = widgetNode.parseTreeNode.tag;\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"text\":\n\t\t\t\t\tresultNode.text = widgetNode.parseTreeNode.text;\n\t\t\t\t\tbreak;\t\n\t\t\t}\n\t\t\tif(Object.keys(widgetNode.attributes || {}).length > 0) {\n\t\t\t\tresultNode.attributes = {};\n\t\t\t\t$tw.utils.each(widgetNode.attributes,function(attr,attrName) {\n\t\t\t\t\tresultNode.attributes[attrName] = widgetNode.getAttribute(attrName);\n\t\t\t\t});\n\t\t\t}\n\t\t\tif(Object.keys(widgetNode.children || {}).length > 0) {\n\t\t\t\tresultNode.children = [];\n\t\t\t\t$tw.utils.each(widgetNode.children,function(widgetChildNode) {\n\t\t\t\t\tvar node = {};\n\t\t\t\t\tresultNode.children.push(node);\n\t\t\t\t\tcopyNode(widgetChildNode,node);\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tresults = {};\n\tcopyNode(this.wikifyWidgetNode,results);\n\treturn results;\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nWikifyWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\t// Refresh ourselves entirely if any of our attributes have changed\n\tif(changedAttributes.name || changedAttributes.text || changedAttributes.type || changedAttributes.mode || changedAttributes.output) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\t// Refresh the widget tree\n\t\tif(this.wikifyWidgetNode.refresh(changedTiddlers)) {\n\t\t\t// Check if there was any change\n\t\t\tvar result = this.getResult();\n\t\t\tif(result !== this.wikifyResult) {\n\t\t\t\t// If so, save the change\n\t\t\t\tthis.wikifyResult = result;\n\t\t\t\tthis.setVariable(this.wikifyName,this.wikifyResult);\n\t\t\t\t// Refresh each of our child widgets\n\t\t\t\t$tw.utils.each(this.children,function(childWidget) {\n\t\t\t\t\tchildWidget.refreshSelf();\n\t\t\t\t});\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t\t// Just refresh the children\n\t\treturn this.refreshChildren(changedTiddlers);\n\t}\n};\n\nexports.wikify = WikifyWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/core/modules/wiki-bulkops.js": {
"title": "$:/core/modules/wiki-bulkops.js",
"text": "/*\\\ntitle: $:/core/modules/wiki-bulkops.js\ntype: application/javascript\nmodule-type: wikimethod\n\nBulk tiddler operations such as rename.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nRename a tiddler, and relink any tags or lists that reference it.\n*/\nfunction renameTiddler(fromTitle,toTitle,options) {\n\tfromTitle = (fromTitle || \"\").trim();\n\ttoTitle = (toTitle || \"\").trim();\n\toptions = options || {};\n\tif(fromTitle && toTitle && fromTitle !== toTitle) {\n\t\t// Rename the tiddler itself\n\t\tvar oldTiddler = this.getTiddler(fromTitle),\n\t\t\tnewTiddler = new $tw.Tiddler(oldTiddler,{title: toTitle},this.getModificationFields());\n\t\tnewTiddler = $tw.hooks.invokeHook(\"th-renaming-tiddler\",newTiddler,oldTiddler);\n\t\tthis.addTiddler(newTiddler);\n\t\tthis.deleteTiddler(fromTitle);\n\t\t// Rename any tags or lists that reference it\n\t\tthis.relinkTiddler(fromTitle,toTitle,options)\n\t}\n}\n\n/*\nRelink any tags or lists that reference a given tiddler\n*/\nfunction relinkTiddler(fromTitle,toTitle,options) {\n\tvar self = this;\n\tfromTitle = (fromTitle || \"\").trim();\n\ttoTitle = (toTitle || \"\").trim();\n\toptions = options || {};\n\tif(fromTitle && toTitle && fromTitle !== toTitle) {\n\t\tthis.each(function(tiddler,title) {\n\t\t\tvar type = tiddler.fields.type || \"\";\n\t\t\t// Don't touch plugins or JavaScript modules\n\t\t\tif(!tiddler.fields[\"plugin-type\"] && type !== \"application/javascript\") {\n\t\t\t\tvar tags = (tiddler.fields.tags || []).slice(0),\n\t\t\t\t\tlist = (tiddler.fields.list || []).slice(0),\n\t\t\t\t\tisModified = false;\n\t\t\t\tif(!options.dontRenameInTags) {\n\t\t\t\t\t// Rename tags\n\t\t\t\t\t$tw.utils.each(tags,function (title,index) {\n\t\t\t\t\t\tif(title === fromTitle) {\nconsole.log(\"Renaming tag '\" + tags[index] + \"' to '\" + toTitle + \"' of tiddler '\" + tiddler.fields.title + \"'\");\n\t\t\t\t\t\t\ttags[index] = toTitle;\n\t\t\t\t\t\t\tisModified = true;\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\tif(!options.dontRenameInLists) {\n\t\t\t\t\t// Rename lists\n\t\t\t\t\t$tw.utils.each(list,function (title,index) {\n\t\t\t\t\t\tif(title === fromTitle) {\nconsole.log(\"Renaming list item '\" + list[index] + \"' to '\" + toTitle + \"' of tiddler '\" + tiddler.fields.title + \"'\");\n\t\t\t\t\t\t\tlist[index] = toTitle;\n\t\t\t\t\t\t\tisModified = true;\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\tif(isModified) {\n\t\t\t\t\tvar newTiddler = new $tw.Tiddler(tiddler,{tags: tags, list: list},self.getModificationFields())\n\t\t\t\t\tnewTiddler = $tw.hooks.invokeHook(\"th-relinking-tiddler\",newTiddler,tiddler);\n\t\t\t\t\tself.addTiddler(newTiddler);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n};\n\nexports.renameTiddler = renameTiddler;\nexports.relinkTiddler = relinkTiddler;\n\n})();\n",
"type": "application/javascript",
"module-type": "wikimethod"
},
"$:/core/modules/wiki.js": {
"title": "$:/core/modules/wiki.js",
"text": "/*\\\ntitle: $:/core/modules/wiki.js\ntype: application/javascript\nmodule-type: wikimethod\n\nExtension methods for the $tw.Wiki object\n\nAdds the following properties to the wiki object:\n\n* `eventListeners` is a hashmap by type of arrays of listener functions\n* `changedTiddlers` is a hashmap describing changes to named tiddlers since wiki change events were last dispatched. Each entry is a hashmap containing two fields:\n\tmodified: true/false\n\tdeleted: true/false\n* `changeCount` is a hashmap by tiddler title containing a numerical index that starts at zero and is incremented each time a tiddler is created changed or deleted\n* `caches` is a hashmap by tiddler title containing a further hashmap of named cache objects. Caches are automatically cleared when a tiddler is modified or deleted\n* `globalCache` is a hashmap by cache name of cache objects that are cleared whenever any tiddler change occurs\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar widget = require(\"$:/core/modules/widgets/widget.js\");\n\nvar USER_NAME_TITLE = \"$:/status/UserName\",\n\tTIMESTAMP_DISABLE_TITLE = \"$:/config/TimestampDisable\";\n\n/*\nGet the value of a text reference. Text references can have any of these forms:\n\t<tiddlertitle>\n\t<tiddlertitle>!!<fieldname>\n\t!!<fieldname> - specifies a field of the current tiddlers\n\t<tiddlertitle>##<index>\n*/\nexports.getTextReference = function(textRef,defaultText,currTiddlerTitle) {\n\tvar tr = $tw.utils.parseTextReference(textRef),\n\t\ttitle = tr.title || currTiddlerTitle;\n\tif(tr.field) {\n\t\tvar tiddler = this.getTiddler(title);\n\t\tif(tr.field === \"title\") { // Special case so we can return the title of a non-existent tiddler\n\t\t\treturn title;\n\t\t} else if(tiddler && $tw.utils.hop(tiddler.fields,tr.field)) {\n\t\t\treturn tiddler.getFieldString(tr.field);\n\t\t} else {\n\t\t\treturn defaultText;\n\t\t}\n\t} else if(tr.index) {\n\t\treturn this.extractTiddlerDataItem(title,tr.index,defaultText);\n\t} else {\n\t\treturn this.getTiddlerText(title,defaultText);\n\t}\n};\n\nexports.setTextReference = function(textRef,value,currTiddlerTitle) {\n\tvar tr = $tw.utils.parseTextReference(textRef),\n\t\ttitle = tr.title || currTiddlerTitle;\n\tthis.setText(title,tr.field,tr.index,value);\n};\n\nexports.setText = function(title,field,index,value,options) {\n\toptions = options || {};\n\tvar creationFields = options.suppressTimestamp ? {} : this.getCreationFields(),\n\t\tmodificationFields = options.suppressTimestamp ? {} : this.getModificationFields();\n\t// Check if it is a reference to a tiddler field\n\tif(index) {\n\t\tvar data = this.getTiddlerData(title,Object.create(null));\n\t\tif(value !== undefined) {\n\t\t\tdata[index] = value;\n\t\t} else {\n\t\t\tdelete data[index];\n\t\t}\n\t\tthis.setTiddlerData(title,data,modificationFields);\n\t} else {\n\t\tvar tiddler = this.getTiddler(title),\n\t\t\tfields = {title: title};\n\t\tfields[field || \"text\"] = value;\n\t\tthis.addTiddler(new $tw.Tiddler(creationFields,tiddler,fields,modificationFields));\n\t}\n};\n\nexports.deleteTextReference = function(textRef,currTiddlerTitle) {\n\tvar tr = $tw.utils.parseTextReference(textRef),\n\t\ttitle,tiddler,fields;\n\t// Check if it is a reference to a tiddler\n\tif(tr.title && !tr.field) {\n\t\tthis.deleteTiddler(tr.title);\n\t// Else check for a field reference\n\t} else if(tr.field) {\n\t\ttitle = tr.title || currTiddlerTitle;\n\t\ttiddler = this.getTiddler(title);\n\t\tif(tiddler && $tw.utils.hop(tiddler.fields,tr.field)) {\n\t\t\tfields = Object.create(null);\n\t\t\tfields[tr.field] = undefined;\n\t\t\tthis.addTiddler(new $tw.Tiddler(tiddler,fields,this.getModificationFields()));\n\t\t}\n\t}\n};\n\nexports.addEventListener = function(type,listener) {\n\tthis.eventListeners = this.eventListeners || {};\n\tthis.eventListeners[type] = this.eventListeners[type] || [];\n\tthis.eventListeners[type].push(listener);\t\n};\n\nexports.removeEventListener = function(type,listener) {\n\tvar listeners = this.eventListeners[type];\n\tif(listeners) {\n\t\tvar p = listeners.indexOf(listener);\n\t\tif(p !== -1) {\n\t\t\tlisteners.splice(p,1);\n\t\t}\n\t}\n};\n\nexports.dispatchEvent = function(type /*, args */) {\n\tvar args = Array.prototype.slice.call(arguments,1),\n\t\tlisteners = this.eventListeners[type];\n\tif(listeners) {\n\t\tfor(var p=0; p<listeners.length; p++) {\n\t\t\tvar listener = listeners[p];\n\t\t\tlistener.apply(listener,args);\n\t\t}\n\t}\n};\n\n/*\nCauses a tiddler to be marked as changed, incrementing the change count, and triggers event handlers.\nThis method should be called after the changes it describes have been made to the wiki.tiddlers[] array.\n\ttitle: Title of tiddler\n\tisDeleted: defaults to false (meaning the tiddler has been created or modified),\n\t\ttrue if the tiddler has been deleted\n*/\nexports.enqueueTiddlerEvent = function(title,isDeleted) {\n\t// Record the touch in the list of changed tiddlers\n\tthis.changedTiddlers = this.changedTiddlers || Object.create(null);\n\tthis.changedTiddlers[title] = this.changedTiddlers[title] || Object.create(null);\n\tthis.changedTiddlers[title][isDeleted ? \"deleted\" : \"modified\"] = true;\n\t// Increment the change count\n\tthis.changeCount = this.changeCount || Object.create(null);\n\tif($tw.utils.hop(this.changeCount,title)) {\n\t\tthis.changeCount[title]++;\n\t} else {\n\t\tthis.changeCount[title] = 1;\n\t}\n\t// Trigger events\n\tthis.eventListeners = this.eventListeners || {};\n\tif(!this.eventsTriggered) {\n\t\tvar self = this;\n\t\t$tw.utils.nextTick(function() {\n\t\t\tvar changes = self.changedTiddlers;\n\t\t\tself.changedTiddlers = Object.create(null);\n\t\t\tself.eventsTriggered = false;\n\t\t\tif($tw.utils.count(changes) > 0) {\n\t\t\t\tself.dispatchEvent(\"change\",changes);\n\t\t\t}\n\t\t});\n\t\tthis.eventsTriggered = true;\n\t}\n};\n\nexports.getSizeOfTiddlerEventQueue = function() {\n\treturn $tw.utils.count(this.changedTiddlers);\n};\n\nexports.clearTiddlerEventQueue = function() {\n\tthis.changedTiddlers = Object.create(null);\n\tthis.changeCount = Object.create(null);\n};\n\nexports.getChangeCount = function(title) {\n\tthis.changeCount = this.changeCount || Object.create(null);\n\tif($tw.utils.hop(this.changeCount,title)) {\n\t\treturn this.changeCount[title];\n\t} else {\n\t\treturn 0;\n\t}\n};\n\n/*\nGenerate an unused title from the specified base\n*/\nexports.generateNewTitle = function(baseTitle,options) {\n\toptions = options || {};\n\tvar c = 0,\n\t\ttitle = baseTitle;\n\twhile(this.tiddlerExists(title) || this.isShadowTiddler(title) || this.findDraft(title)) {\n\t\ttitle = baseTitle + \n\t\t\t(options.prefix || \" \") + \n\t\t\t(++c);\n\t}\n\treturn title;\n};\n\nexports.isSystemTiddler = function(title) {\n\treturn title && title.indexOf(\"$:/\") === 0;\n};\n\nexports.isTemporaryTiddler = function(title) {\n\treturn title && title.indexOf(\"$:/temp/\") === 0;\n};\n\nexports.isImageTiddler = function(title) {\n\tvar tiddler = this.getTiddler(title);\n\tif(tiddler) {\t\t\n\t\tvar contentTypeInfo = $tw.config.contentTypeInfo[tiddler.fields.type || \"text/vnd.tiddlywiki\"];\n\t\treturn !!contentTypeInfo && contentTypeInfo.flags.indexOf(\"image\") !== -1;\n\t} else {\n\t\treturn null;\n\t}\n};\n\n/*\nLike addTiddler() except it will silently reject any plugin tiddlers that are older than the currently loaded version. Returns true if the tiddler was imported\n*/\nexports.importTiddler = function(tiddler) {\n\tvar existingTiddler = this.getTiddler(tiddler.fields.title);\n\t// Check if we're dealing with a plugin\n\tif(tiddler && tiddler.hasField(\"plugin-type\") && tiddler.hasField(\"version\") && existingTiddler && existingTiddler.hasField(\"plugin-type\") && existingTiddler.hasField(\"version\")) {\n\t\t// Reject the incoming plugin if it is older\n\t\tif(!$tw.utils.checkVersions(tiddler.fields.version,existingTiddler.fields.version)) {\n\t\t\treturn false;\n\t\t}\n\t}\n\t// Fall through to adding the tiddler\n\tthis.addTiddler(tiddler);\n\treturn true;\n};\n\n/*\nReturn a hashmap of the fields that should be set when a tiddler is created\n*/\nexports.getCreationFields = function() {\n\tif(this.getTiddlerText(TIMESTAMP_DISABLE_TITLE,\"\").toLowerCase() !== \"yes\") {\n\t\tvar fields = {\n\t\t\t\tcreated: new Date()\n\t\t\t},\n\t\t\tcreator = this.getTiddlerText(USER_NAME_TITLE);\n\t\tif(creator) {\n\t\t\tfields.creator = creator;\n\t\t}\n\t\treturn fields;\n\t} else {\n\t\treturn {};\n\t}\n};\n\n/*\nReturn a hashmap of the fields that should be set when a tiddler is modified\n*/\nexports.getModificationFields = function() {\n\tif(this.getTiddlerText(TIMESTAMP_DISABLE_TITLE,\"\").toLowerCase() !== \"yes\") {\n\t\tvar fields = Object.create(null),\n\t\t\tmodifier = this.getTiddlerText(USER_NAME_TITLE);\n\t\tfields.modified = new Date();\n\t\tif(modifier) {\n\t\t\tfields.modifier = modifier;\n\t\t}\n\t\treturn fields;\n\t} else {\n\t\treturn {};\n\t}\n};\n\n/*\nReturn a sorted array of tiddler titles. Options include:\nsortField: field to sort by\nexcludeTag: tag to exclude\nincludeSystem: whether to include system tiddlers (defaults to false)\n*/\nexports.getTiddlers = function(options) {\n\toptions = options || Object.create(null);\n\tvar self = this,\n\t\tsortField = options.sortField || \"title\",\n\t\ttiddlers = [], t, titles = [];\n\tthis.each(function(tiddler,title) {\n\t\tif(options.includeSystem || !self.isSystemTiddler(title)) {\n\t\t\tif(!options.excludeTag || !tiddler.hasTag(options.excludeTag)) {\n\t\t\t\ttiddlers.push(tiddler);\n\t\t\t}\n\t\t}\n\t});\n\ttiddlers.sort(function(a,b) {\n\t\tvar aa = a.fields[sortField].toLowerCase() || \"\",\n\t\t\tbb = b.fields[sortField].toLowerCase() || \"\";\n\t\tif(aa < bb) {\n\t\t\treturn -1;\n\t\t} else {\n\t\t\tif(aa > bb) {\n\t\t\t\treturn 1;\n\t\t\t} else {\n\t\t\t\treturn 0;\n\t\t\t}\n\t\t}\n\t});\n\tfor(t=0; t<tiddlers.length; t++) {\n\t\ttitles.push(tiddlers[t].fields.title);\n\t}\n\treturn titles;\n};\n\nexports.countTiddlers = function(excludeTag) {\n\tvar tiddlers = this.getTiddlers({excludeTag: excludeTag});\n\treturn $tw.utils.count(tiddlers);\n};\n\n/*\nReturns a function iterator(callback) that iterates through the specified titles, and invokes the callback with callback(tiddler,title)\n*/\nexports.makeTiddlerIterator = function(titles) {\n\tvar self = this;\n\tif(!$tw.utils.isArray(titles)) {\n\t\ttitles = Object.keys(titles);\n\t} else {\n\t\ttitles = titles.slice(0);\n\t}\n\treturn function(callback) {\n\t\ttitles.forEach(function(title) {\n\t\t\tcallback(self.getTiddler(title),title);\n\t\t});\n\t};\n};\n\n/*\nSort an array of tiddler titles by a specified field\n\ttitles: array of titles (sorted in place)\n\tsortField: name of field to sort by\n\tisDescending: true if the sort should be descending\n\tisCaseSensitive: true if the sort should consider upper and lower case letters to be different\n*/\nexports.sortTiddlers = function(titles,sortField,isDescending,isCaseSensitive,isNumeric,isAlphaNumeric) {\n\tvar self = this;\n\ttitles.sort(function(a,b) {\n\t\tvar x,y,\n\t\t\tcompareNumbers = function(x,y) {\n\t\t\t\tvar result = \n\t\t\t\t\tisNaN(x) && !isNaN(y) ? (isDescending ? -1 : 1) :\n\t\t\t\t\t!isNaN(x) && isNaN(y) ? (isDescending ? 1 : -1) :\n\t\t\t\t\t\t\t\t\t\t\t(isDescending ? y - x : x - y);\n\t\t\t\treturn result;\n\t\t\t};\n\t\tif(sortField !== \"title\") {\n\t\t\tvar tiddlerA = self.getTiddler(a),\n\t\t\t\ttiddlerB = self.getTiddler(b);\n\t\t\tif(tiddlerA) {\n\t\t\t\ta = tiddlerA.fields[sortField] || \"\";\n\t\t\t} else {\n\t\t\t\ta = \"\";\n\t\t\t}\n\t\t\tif(tiddlerB) {\n\t\t\t\tb = tiddlerB.fields[sortField] || \"\";\n\t\t\t} else {\n\t\t\t\tb = \"\";\n\t\t\t}\n\t\t}\n\t\tx = Number(a);\n\t\ty = Number(b);\n\t\tif(isNumeric && (!isNaN(x) || !isNaN(y))) {\n\t\t\treturn compareNumbers(x,y);\n\t\t} else if(isAlphaNumeric) {\n\t\t\treturn isDescending ? b.localeCompare(a,undefined,{numeric: true,sensitivity: \"base\"}) : a.localeCompare(b,undefined,{numeric: true,sensitivity: \"base\"});\n\t\t} else if($tw.utils.isDate(a) && $tw.utils.isDate(b)) {\n\t\t\treturn isDescending ? b - a : a - b;\n\t\t} else {\n\t\t\ta = String(a);\n\t\t\tb = String(b);\n\t\t\tif(!isCaseSensitive) {\n\t\t\t\ta = a.toLowerCase();\n\t\t\t\tb = b.toLowerCase();\n\t\t\t}\n\t\t\treturn isDescending ? b.localeCompare(a) : a.localeCompare(b);\n\t\t}\n\t});\n};\n\n/*\nFor every tiddler invoke a callback(title,tiddler) with `this` set to the wiki object. Options include:\nsortField: field to sort by\nexcludeTag: tag to exclude\nincludeSystem: whether to include system tiddlers (defaults to false)\n*/\nexports.forEachTiddler = function(/* [options,]callback */) {\n\tvar arg = 0,\n\t\toptions = arguments.length >= 2 ? arguments[arg++] : {},\n\t\tcallback = arguments[arg++],\n\t\ttitles = this.getTiddlers(options),\n\t\tt, tiddler;\n\tfor(t=0; t<titles.length; t++) {\n\t\ttiddler = this.getTiddler(titles[t]);\n\t\tif(tiddler) {\n\t\t\tcallback.call(this,tiddler.fields.title,tiddler);\n\t\t}\n\t}\n};\n\n/*\nReturn an array of tiddler titles that are directly linked from the specified tiddler\n*/\nexports.getTiddlerLinks = function(title) {\n\tvar self = this;\n\t// We'll cache the links so they only get computed if the tiddler changes\n\treturn this.getCacheForTiddler(title,\"links\",function() {\n\t\t// Parse the tiddler\n\t\tvar parser = self.parseTiddler(title);\n\t\t// Count up the links\n\t\tvar links = [],\n\t\t\tcheckParseTree = function(parseTree) {\n\t\t\t\tfor(var t=0; t<parseTree.length; t++) {\n\t\t\t\t\tvar parseTreeNode = parseTree[t];\n\t\t\t\t\tif(parseTreeNode.type === \"link\" && parseTreeNode.attributes.to && parseTreeNode.attributes.to.type === \"string\") {\n\t\t\t\t\t\tvar value = parseTreeNode.attributes.to.value;\n\t\t\t\t\t\tif(links.indexOf(value) === -1) {\n\t\t\t\t\t\t\tlinks.push(value);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif(parseTreeNode.children) {\n\t\t\t\t\t\tcheckParseTree(parseTreeNode.children);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t};\n\t\tif(parser) {\n\t\t\tcheckParseTree(parser.tree);\n\t\t}\n\t\treturn links;\n\t});\n};\n\n/*\nReturn an array of tiddler titles that link to the specified tiddler\n*/\nexports.getTiddlerBacklinks = function(targetTitle) {\n\tvar self = this,\n\t\tbacklinks = [];\n\tthis.forEachTiddler(function(title,tiddler) {\n\t\tvar links = self.getTiddlerLinks(title);\n\t\tif(links.indexOf(targetTitle) !== -1) {\n\t\t\tbacklinks.push(title);\n\t\t}\n\t});\n\treturn backlinks;\n};\n\n/*\nReturn a hashmap of tiddler titles that are referenced but not defined. Each value is the number of times the missing tiddler is referenced\n*/\nexports.getMissingTitles = function() {\n\tvar self = this,\n\t\tmissing = [];\n// We should cache the missing tiddler list, even if we recreate it every time any tiddler is modified\n\tthis.forEachTiddler(function(title,tiddler) {\n\t\tvar links = self.getTiddlerLinks(title);\n\t\t$tw.utils.each(links,function(link) {\n\t\t\tif((!self.tiddlerExists(link) && !self.isShadowTiddler(link)) && missing.indexOf(link) === -1) {\n\t\t\t\tmissing.push(link);\n\t\t\t}\n\t\t});\n\t});\n\treturn missing;\n};\n\nexports.getOrphanTitles = function() {\n\tvar self = this,\n\t\torphans = this.getTiddlers();\n\tthis.forEachTiddler(function(title,tiddler) {\n\t\tvar links = self.getTiddlerLinks(title);\n\t\t$tw.utils.each(links,function(link) {\n\t\t\tvar p = orphans.indexOf(link);\n\t\t\tif(p !== -1) {\n\t\t\t\torphans.splice(p,1);\n\t\t\t}\n\t\t});\n\t});\n\treturn orphans; // Todo\n};\n\n/*\nRetrieves a list of the tiddler titles that are tagged with a given tag\n*/\nexports.getTiddlersWithTag = function(tag) {\n\tvar self = this;\n\treturn this.getGlobalCache(\"taglist-\" + tag,function() {\n\t\tvar tagmap = self.getTagMap();\n\t\treturn self.sortByList(tagmap[tag],tag);\n\t});\n};\n\n/*\nGet a hashmap by tag of arrays of tiddler titles\n*/\nexports.getTagMap = function() {\n\tvar self = this;\n\treturn this.getGlobalCache(\"tagmap\",function() {\n\t\tvar tags = Object.create(null),\n\t\t\tstoreTags = function(tagArray,title) {\n\t\t\t\tif(tagArray) {\n\t\t\t\t\tfor(var index=0; index<tagArray.length; index++) {\n\t\t\t\t\t\tvar tag = tagArray[index];\n\t\t\t\t\t\tif($tw.utils.hop(tags,tag)) {\n\t\t\t\t\t\t\ttags[tag].push(title);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\ttags[tag] = [title];\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t\ttitle, tiddler;\n\t\t// Collect up all the tags\n\t\tself.eachShadow(function(tiddler,title) {\n\t\t\tif(!self.tiddlerExists(title)) {\n\t\t\t\ttiddler = self.getTiddler(title);\n\t\t\t\tstoreTags(tiddler.fields.tags,title);\n\t\t\t}\n\t\t});\n\t\tself.each(function(tiddler,title) {\n\t\t\tstoreTags(tiddler.fields.tags,title);\n\t\t});\n\t\treturn tags;\n\t});\n};\n\n/*\nLookup a given tiddler and return a list of all the tiddlers that include it in the specified list field\n*/\nexports.findListingsOfTiddler = function(targetTitle,fieldName) {\n\tfieldName = fieldName || \"list\";\n\tvar titles = [];\n\tthis.each(function(tiddler,title) {\n\t\tvar list = $tw.utils.parseStringArray(tiddler.fields[fieldName]);\n\t\tif(list && list.indexOf(targetTitle) !== -1) {\n\t\t\ttitles.push(title);\n\t\t}\n\t});\n\treturn titles;\n};\n\n/*\nSorts an array of tiddler titles according to an ordered list\n*/\nexports.sortByList = function(array,listTitle) {\n\tvar self = this,\n\t\treplacedTitles = Object.create(null);\n\tfunction replaceItem(title) {\n\t\tif(!$tw.utils.hop(replacedTitles, title)) {\n\t\t\treplacedTitles[title] = true;\n\t\t\tvar newPos = -1,\n\t\t\t\ttiddler = self.getTiddler(title);\n\t\t\tif(tiddler) {\n\t\t\t\tvar beforeTitle = tiddler.fields[\"list-before\"],\n\t\t\t\t\tafterTitle = tiddler.fields[\"list-after\"];\n\t\t\t\tif(beforeTitle === \"\") {\n\t\t\t\t\tnewPos = 0;\n\t\t\t\t} else if(afterTitle === \"\") {\n\t\t\t\t\tnewPos = titles.length;\n\t\t\t\t} else if(beforeTitle) {\n\t\t\t\t\treplaceItem(beforeTitle);\n\t\t\t\t\tnewPos = titles.indexOf(beforeTitle);\n\t\t\t\t} else if(afterTitle) {\n\t\t\t\t\treplaceItem(afterTitle);\n\t\t\t\t\tnewPos = titles.indexOf(afterTitle);\n\t\t\t\t\tif(newPos >= 0) {\n\t\t\t\t\t\t++newPos;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t// We get the currPos //after// figuring out the newPos, because recursive replaceItem calls might alter title's currPos\n\t\t\t\tvar currPos = titles.indexOf(title);\n\t\t\t\tif(newPos === -1) {\n\t\t\t\t\tnewPos = currPos;\n\t\t\t\t}\n\t\t\t\tif(currPos >= 0 && newPos !== currPos) {\n\t\t\t\t\ttitles.splice(currPos,1);\n\t\t\t\t\tif(newPos >= currPos) {\n\t\t\t\t\t\tnewPos--;\n\t\t\t\t\t}\n\t\t\t\t\ttitles.splice(newPos,0,title);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\tvar list = this.getTiddlerList(listTitle);\n\tif(!array || array.length === 0) {\n\t\treturn [];\n\t} else {\n\t\tvar titles = [], t, title;\n\t\t// First place any entries that are present in the list\n\t\tfor(t=0; t<list.length; t++) {\n\t\t\ttitle = list[t];\n\t\t\tif(array.indexOf(title) !== -1) {\n\t\t\t\ttitles.push(title);\n\t\t\t}\n\t\t}\n\t\t// Then place any remaining entries\n\t\tfor(t=0; t<array.length; t++) {\n\t\t\ttitle = array[t];\n\t\t\tif(list.indexOf(title) === -1) {\n\t\t\t\ttitles.push(title);\n\t\t\t}\n\t\t}\n\t\t// Finally obey the list-before and list-after fields of each tiddler in turn\n\t\tvar sortedTitles = titles.slice(0);\n\t\tfor(t=0; t<sortedTitles.length; t++) {\n\t\t\ttitle = sortedTitles[t];\n\t\t\treplaceItem(title);\n\t\t}\n\t\treturn titles;\n\t}\n};\n\nexports.getSubTiddler = function(title,subTiddlerTitle) {\n\tvar bundleInfo = this.getPluginInfo(title) || this.getTiddlerDataCached(title);\n\tif(bundleInfo && bundleInfo.tiddlers) {\n\t\tvar subTiddler = bundleInfo.tiddlers[subTiddlerTitle];\n\t\tif(subTiddler) {\n\t\t\treturn new $tw.Tiddler(subTiddler);\n\t\t}\n\t}\n\treturn null;\n};\n\n/*\nRetrieve a tiddler as a JSON string of the fields\n*/\nexports.getTiddlerAsJson = function(title) {\n\tvar tiddler = this.getTiddler(title);\n\tif(tiddler) {\n\t\tvar fields = Object.create(null);\n\t\t$tw.utils.each(tiddler.fields,function(value,name) {\n\t\t\tfields[name] = tiddler.getFieldString(name);\n\t\t});\n\t\treturn JSON.stringify(fields);\n\t} else {\n\t\treturn JSON.stringify({title: title});\n\t}\n};\n\nexports.getTiddlersAsJson = function(filter) {\n\tvar tiddlers = this.filterTiddlers(filter),\n\t\tdata = [];\n\tfor(var t=0;t<tiddlers.length; t++) {\n\t\tvar tiddler = this.getTiddler(tiddlers[t]);\n\t\tif(tiddler) {\n\t\t\tvar fields = new Object();\n\t\t\tfor(var field in tiddler.fields) {\n\t\t\t\tfields[field] = tiddler.getFieldString(field);\n\t\t\t}\n\t\t\tdata.push(fields);\n\t\t}\n\t}\n\treturn JSON.stringify(data,null,$tw.config.preferences.jsonSpaces);\n};\n\n/*\nGet the content of a tiddler as a JavaScript object. How this is done depends on the type of the tiddler:\n\napplication/json: the tiddler JSON is parsed into an object\napplication/x-tiddler-dictionary: the tiddler is parsed as sequence of name:value pairs\n\nOther types currently just return null.\n\ntitleOrTiddler: string tiddler title or a tiddler object\ndefaultData: default data to be returned if the tiddler is missing or doesn't contain data\n\nNote that the same value is returned for repeated calls for the same tiddler data. The value is frozen to prevent modification; otherwise modifications would be visible to all callers\n*/\nexports.getTiddlerDataCached = function(titleOrTiddler,defaultData) {\n\tvar self = this,\n\t\ttiddler = titleOrTiddler;\n\tif(!(tiddler instanceof $tw.Tiddler)) {\n\t\ttiddler = this.getTiddler(tiddler);\t\n\t}\n\tif(tiddler) {\n\t\treturn this.getCacheForTiddler(tiddler.fields.title,\"data\",function() {\n\t\t\t// Return the frozen value\n\t\t\tvar value = self.getTiddlerData(tiddler.fields.title,undefined);\n\t\t\t$tw.utils.deepFreeze(value);\n\t\t\treturn value;\n\t\t}) || defaultData;\n\t} else {\n\t\treturn defaultData;\n\t}\n};\n\n/*\nAlternative, uncached version of getTiddlerDataCached(). The return value can be mutated freely and reused\n*/\nexports.getTiddlerData = function(titleOrTiddler,defaultData) {\n\tvar tiddler = titleOrTiddler,\n\t\tdata;\n\tif(!(tiddler instanceof $tw.Tiddler)) {\n\t\ttiddler = this.getTiddler(tiddler);\t\n\t}\n\tif(tiddler && tiddler.fields.text) {\n\t\tswitch(tiddler.fields.type) {\n\t\t\tcase \"application/json\":\n\t\t\t\t// JSON tiddler\n\t\t\t\ttry {\n\t\t\t\t\tdata = JSON.parse(tiddler.fields.text);\n\t\t\t\t} catch(ex) {\n\t\t\t\t\treturn defaultData;\n\t\t\t\t}\n\t\t\t\treturn data;\n\t\t\tcase \"application/x-tiddler-dictionary\":\n\t\t\t\treturn $tw.utils.parseFields(tiddler.fields.text);\n\t\t}\n\t}\n\treturn defaultData;\n};\n\n/*\nExtract an indexed field from within a data tiddler\n*/\nexports.extractTiddlerDataItem = function(titleOrTiddler,index,defaultText) {\n\tvar data = this.getTiddlerDataCached(titleOrTiddler,Object.create(null)),\n\t\ttext;\n\tif(data && $tw.utils.hop(data,index)) {\n\t\ttext = data[index];\n\t}\n\tif(typeof text === \"string\" || typeof text === \"number\") {\n\t\treturn text.toString();\n\t} else {\n\t\treturn defaultText;\n\t}\n};\n\n/*\nSet a tiddlers content to a JavaScript object. Currently this is done by setting the tiddler's type to \"application/json\" and setting the text to the JSON text of the data.\ntitle: title of tiddler\ndata: object that can be serialised to JSON\nfields: optional hashmap of additional tiddler fields to be set\n*/\nexports.setTiddlerData = function(title,data,fields) {\n\tvar existingTiddler = this.getTiddler(title),\n\t\tnewFields = {\n\t\t\ttitle: title\n\t};\n\tif(existingTiddler && existingTiddler.fields.type === \"application/x-tiddler-dictionary\") {\n\t\tnewFields.text = $tw.utils.makeTiddlerDictionary(data);\n\t} else {\n\t\tnewFields.type = \"application/json\";\n\t\tnewFields.text = JSON.stringify(data,null,$tw.config.preferences.jsonSpaces);\n\t}\n\tthis.addTiddler(new $tw.Tiddler(this.getCreationFields(),existingTiddler,fields,newFields,this.getModificationFields()));\n};\n\n/*\nReturn the content of a tiddler as an array containing each line\n*/\nexports.getTiddlerList = function(title,field,index) {\n\tif(index) {\n\t\treturn $tw.utils.parseStringArray(this.extractTiddlerDataItem(title,index,\"\"));\n\t}\n\tfield = field || \"list\";\n\tvar tiddler = this.getTiddler(title);\n\tif(tiddler) {\n\t\treturn ($tw.utils.parseStringArray(tiddler.fields[field]) || []).slice(0);\n\t}\n\treturn [];\n};\n\n// Return a named global cache object. Global cache objects are cleared whenever a tiddler change occurs\nexports.getGlobalCache = function(cacheName,initializer) {\n\tthis.globalCache = this.globalCache || Object.create(null);\n\tif($tw.utils.hop(this.globalCache,cacheName)) {\n\t\treturn this.globalCache[cacheName];\n\t} else {\n\t\tthis.globalCache[cacheName] = initializer();\n\t\treturn this.globalCache[cacheName];\n\t}\n};\n\nexports.clearGlobalCache = function() {\n\tthis.globalCache = Object.create(null);\n};\n\n// Return the named cache object for a tiddler. If the cache doesn't exist then the initializer function is invoked to create it\nexports.getCacheForTiddler = function(title,cacheName,initializer) {\n\tthis.caches = this.caches || Object.create(null);\n\tvar caches = this.caches[title];\n\tif(caches && caches[cacheName]) {\n\t\treturn caches[cacheName];\n\t} else {\n\t\tif(!caches) {\n\t\t\tcaches = Object.create(null);\n\t\t\tthis.caches[title] = caches;\n\t\t}\n\t\tcaches[cacheName] = initializer();\n\t\treturn caches[cacheName];\n\t}\n};\n\n// Clear all caches associated with a particular tiddler, or, if the title is null, clear all the caches for all the tiddlers\nexports.clearCache = function(title) {\n\tif(title) {\n\t\tthis.caches = this.caches || Object.create(null);\n\t\tif($tw.utils.hop(this.caches,title)) {\n\t\t\tdelete this.caches[title];\n\t\t}\n\t} else {\n\t\tthis.caches = Object.create(null);\n\t}\n};\n\nexports.initParsers = function(moduleType) {\n\t// Install the parser modules\n\t$tw.Wiki.parsers = {};\n\tvar self = this;\n\t$tw.modules.forEachModuleOfType(\"parser\",function(title,module) {\n\t\tfor(var f in module) {\n\t\t\tif($tw.utils.hop(module,f)) {\n\t\t\t\t$tw.Wiki.parsers[f] = module[f]; // Store the parser class\n\t\t\t}\n\t\t}\n\t});\n\t// Use the generic binary parser for any binary types not registered so far\n\tif($tw.Wiki.parsers[\"application/octet-stream\"]) {\n\t\tObject.keys($tw.config.contentTypeInfo).forEach(function(type) {\n\t\t\tif(!$tw.utils.hop($tw.Wiki.parsers,type) && $tw.config.contentTypeInfo[type].encoding === \"base64\") {\n\t\t\t\t$tw.Wiki.parsers[type] = $tw.Wiki.parsers[\"application/octet-stream\"];\n\t\t\t}\n\t\t});\t\t\n\t}\n};\n\n/*\nParse a block of text of a specified MIME type\n\ttype: content type of text to be parsed\n\ttext: text\n\toptions: see below\nOptions include:\n\tparseAsInline: if true, the text of the tiddler will be parsed as an inline run\n\t_canonical_uri: optional string of the canonical URI of this content\n*/\nexports.parseText = function(type,text,options) {\n\ttext = text || \"\";\n\toptions = options || {};\n\t// Select a parser\n\tvar Parser = $tw.Wiki.parsers[type];\n\tif(!Parser && $tw.utils.getFileExtensionInfo(type)) {\n\t\tParser = $tw.Wiki.parsers[$tw.utils.getFileExtensionInfo(type).type];\n\t}\n\tif(!Parser) {\n\t\tParser = $tw.Wiki.parsers[options.defaultType || \"text/vnd.tiddlywiki\"];\n\t}\n\tif(!Parser) {\n\t\treturn null;\n\t}\n\t// Return the parser instance\n\treturn new Parser(type,text,{\n\t\tparseAsInline: options.parseAsInline,\n\t\twiki: this,\n\t\t_canonical_uri: options._canonical_uri\n\t});\n};\n\n/*\nParse a tiddler according to its MIME type\n*/\nexports.parseTiddler = function(title,options) {\n\toptions = $tw.utils.extend({},options);\n\tvar cacheType = options.parseAsInline ? \"inlineParseTree\" : \"blockParseTree\",\n\t\ttiddler = this.getTiddler(title),\n\t\tself = this;\n\treturn tiddler ? this.getCacheForTiddler(title,cacheType,function() {\n\t\t\tif(tiddler.hasField(\"_canonical_uri\")) {\n\t\t\t\toptions._canonical_uri = tiddler.fields._canonical_uri;\n\t\t\t}\n\t\t\treturn self.parseText(tiddler.fields.type,tiddler.fields.text,options);\n\t\t}) : null;\n};\n\nexports.parseTextReference = function(title,field,index,options) {\n\tvar tiddler,text;\n\tif(options.subTiddler) {\n\t\ttiddler = this.getSubTiddler(title,options.subTiddler);\n\t} else {\n\t\ttiddler = this.getTiddler(title);\n\t\tif(field === \"text\" || (!field && !index)) {\n\t\t\tthis.getTiddlerText(title); // Force the tiddler to be lazily loaded\n\t\t\treturn this.parseTiddler(title,options);\n\t\t}\n\t}\n\tif(field === \"text\" || (!field && !index)) {\n\t\tif(tiddler && tiddler.fields) {\n\t\t\treturn this.parseText(tiddler.fields.type,tiddler.fields.text,options);\t\t\t\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t} else if(field) {\n\t\tif(field === \"title\") {\n\t\t\ttext = title;\n\t\t} else {\n\t\t\tif(!tiddler || !tiddler.hasField(field)) {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t\ttext = tiddler.fields[field];\n\t\t}\n\t\treturn this.parseText(\"text/vnd.tiddlywiki\",text.toString(),options);\n\t} else if(index) {\n\t\tthis.getTiddlerText(title); // Force the tiddler to be lazily loaded\n\t\ttext = this.extractTiddlerDataItem(tiddler,index,undefined);\n\t\tif(text === undefined) {\n\t\t\treturn null;\n\t\t}\n\t\treturn this.parseText(\"text/vnd.tiddlywiki\",text,options);\n\t}\n};\n\n/*\nMake a widget tree for a parse tree\nparser: parser object\noptions: see below\nOptions include:\ndocument: optional document to use\nvariables: hashmap of variables to set\nparentWidget: optional parent widget for the root node\n*/\nexports.makeWidget = function(parser,options) {\n\toptions = options || {};\n\tvar widgetNode = {\n\t\t\ttype: \"widget\",\n\t\t\tchildren: []\n\t\t},\n\t\tcurrWidgetNode = widgetNode;\n\t// Create set variable widgets for each variable\n\t$tw.utils.each(options.variables,function(value,name) {\n\t\tvar setVariableWidget = {\n\t\t\ttype: \"set\",\n\t\t\tattributes: {\n\t\t\t\tname: {type: \"string\", value: name},\n\t\t\t\tvalue: {type: \"string\", value: value}\n\t\t\t},\n\t\t\tchildren: []\n\t\t};\n\t\tcurrWidgetNode.children = [setVariableWidget];\n\t\tcurrWidgetNode = setVariableWidget;\n\t});\n\t// Add in the supplied parse tree nodes\n\tcurrWidgetNode.children = parser ? parser.tree : [];\n\t// Create the widget\n\treturn new widget.widget(widgetNode,{\n\t\twiki: this,\n\t\tdocument: options.document || $tw.fakeDocument,\n\t\tparentWidget: options.parentWidget\n\t});\n};\n\n/*\nMake a widget tree for transclusion\ntitle: target tiddler title\noptions: as for wiki.makeWidget() plus:\noptions.field: optional field to transclude (defaults to \"text\")\noptions.mode: transclusion mode \"inline\" or \"block\"\noptions.children: optional array of children for the transclude widget\noptions.importVariables: optional importvariables filter string for macros to be included\noptions.importPageMacros: optional boolean; if true, equivalent to passing \"[[$:/core/ui/PageMacros]] [all[shadows+tiddlers]tag[$:/tags/Macro]!has[draft.of]]\" to options.importVariables\n*/\nexports.makeTranscludeWidget = function(title,options) {\n\toptions = options || {};\n\tvar parseTreeDiv = {tree: [{\n\t\t\ttype: \"element\",\n\t\t\ttag: \"div\",\n\t\t\tchildren: []}]},\n\t\tparseTreeImportVariables = {\n\t\t\ttype: \"importvariables\",\n\t\t\tattributes: {\n\t\t\t\tfilter: {\n\t\t\t\t\tname: \"filter\",\n\t\t\t\t\ttype: \"string\"\n\t\t\t\t}\n\t\t\t},\n\t\t\tisBlock: false,\n\t\t\tchildren: []},\n\t\tparseTreeTransclude = {\n\t\t\ttype: \"transclude\",\n\t\t\tattributes: {\n\t\t\t\ttiddler: {\n\t\t\t\t\tname: \"tiddler\",\n\t\t\t\t\ttype: \"string\",\n\t\t\t\t\tvalue: title}},\n\t\t\tisBlock: !options.parseAsInline};\n\tif(options.importVariables || options.importPageMacros) {\n\t\tif(options.importVariables) {\n\t\t\tparseTreeImportVariables.attributes.filter.value = options.importVariables;\n\t\t} else if(options.importPageMacros) {\n\t\t\tparseTreeImportVariables.attributes.filter.value = \"[[$:/core/ui/PageMacros]] [all[shadows+tiddlers]tag[$:/tags/Macro]!has[draft.of]]\";\n\t\t}\n\t\tparseTreeDiv.tree[0].children.push(parseTreeImportVariables);\n\t\tparseTreeImportVariables.children.push(parseTreeTransclude);\n\t} else {\n\t\tparseTreeDiv.tree[0].children.push(parseTreeTransclude);\n\t}\n\tif(options.field) {\n\t\tparseTreeTransclude.attributes.field = {type: \"string\", value: options.field};\n\t}\n\tif(options.mode) {\n\t\tparseTreeTransclude.attributes.mode = {type: \"string\", value: options.mode};\n\t}\n\tif(options.children) {\n\t\tparseTreeTransclude.children = options.children;\n\t}\n\treturn $tw.wiki.makeWidget(parseTreeDiv,options);\n};\n\n/*\nParse text in a specified format and render it into another format\n\toutputType: content type for the output\n\ttextType: content type of the input text\n\ttext: input text\n\toptions: see below\nOptions include:\nvariables: hashmap of variables to set\nparentWidget: optional parent widget for the root node\n*/\nexports.renderText = function(outputType,textType,text,options) {\n\toptions = options || {};\n\tvar parser = this.parseText(textType,text,options),\n\t\twidgetNode = this.makeWidget(parser,options);\n\tvar container = $tw.fakeDocument.createElement(\"div\");\n\twidgetNode.render(container,null);\n\treturn outputType === \"text/html\" ? container.innerHTML : container.textContent;\n};\n\n/*\nParse text from a tiddler and render it into another format\n\toutputType: content type for the output\n\ttitle: title of the tiddler to be rendered\n\toptions: see below\nOptions include:\nvariables: hashmap of variables to set\nparentWidget: optional parent widget for the root node\n*/\nexports.renderTiddler = function(outputType,title,options) {\n\toptions = options || {};\n\tvar parser = this.parseTiddler(title,options),\n\t\twidgetNode = this.makeWidget(parser,options);\n\tvar container = $tw.fakeDocument.createElement(\"div\");\n\twidgetNode.render(container,null);\n\treturn outputType === \"text/html\" ? container.innerHTML : (outputType === \"text/plain-formatted\" ? container.formattedTextContent : container.textContent);\n};\n\n/*\nReturn an array of tiddler titles that match a search string\n\ttext: The text string to search for\n\toptions: see below\nOptions available:\n\tsource: an iterator function for the source tiddlers, called source(iterator), where iterator is called as iterator(tiddler,title)\n\texclude: An array of tiddler titles to exclude from the search\n\tinvert: If true returns tiddlers that do not contain the specified string\n\tcaseSensitive: If true forces a case sensitive search\n\tfield: If specified, restricts the search to the specified field, or an array of field names\n\texcludeField: If true, the field options are inverted to specify the fields that are not to be searched\n\tThe search mode is determined by the first of these boolean flags to be true\n\t\tliteral: searches for literal string\n\t\twhitespace: same as literal except runs of whitespace are treated as a single space\n\t\tregexp: treats the search term as a regular expression\n\t\twords: (default) treats search string as a list of tokens, and matches if all tokens are found, regardless of adjacency or ordering\n*/\nexports.search = function(text,options) {\n\toptions = options || {};\n\tvar self = this,\n\t\tt,\n\t\tinvert = !!options.invert;\n\t// Convert the search string into a regexp for each term\n\tvar terms, searchTermsRegExps,\n\t\tflags = options.caseSensitive ? \"\" : \"i\";\n\tif(options.literal) {\n\t\tif(text.length === 0) {\n\t\t\tsearchTermsRegExps = null;\n\t\t} else {\n\t\t\tsearchTermsRegExps = [new RegExp(\"(\" + $tw.utils.escapeRegExp(text) + \")\",flags)];\n\t\t}\n\t} else if(options.whitespace) {\n\t\tterms = [];\n\t\t$tw.utils.each(text.split(/\\s+/g),function(term) {\n\t\t\tif(term) {\n\t\t\t\tterms.push($tw.utils.escapeRegExp(term));\n\t\t\t}\n\t\t});\n\t\tsearchTermsRegExps = [new RegExp(\"(\" + terms.join(\"\\\\s+\") + \")\",flags)];\n\t} else if(options.regexp) {\n\t\ttry {\n\t\t\tsearchTermsRegExps = [new RegExp(\"(\" + text + \")\",flags)];\t\t\t\n\t\t} catch(e) {\n\t\t\tsearchTermsRegExps = null;\n\t\t\tconsole.log(\"Regexp error parsing /(\" + text + \")/\" + flags + \": \",e);\n\t\t}\n\t} else {\n\t\tterms = text.split(/ +/);\n\t\tif(terms.length === 1 && terms[0] === \"\") {\n\t\t\tsearchTermsRegExps = null;\n\t\t} else {\n\t\t\tsearchTermsRegExps = [];\n\t\t\tfor(t=0; t<terms.length; t++) {\n\t\t\t\tsearchTermsRegExps.push(new RegExp(\"(\" + $tw.utils.escapeRegExp(terms[t]) + \")\",flags));\n\t\t\t}\n\t\t}\n\t}\n\t// Accumulate the array of fields to be searched or excluded from the search\n\tvar fields = [];\n\tif(options.field) {\n\t\tif($tw.utils.isArray(options.field)) {\n\t\t\t$tw.utils.each(options.field,function(fieldName) {\n\t\t\t\tif(fieldName) {\n\t\t\t\t\tfields.push(fieldName);\t\t\t\t\t\n\t\t\t\t}\n\t\t\t});\n\t\t} else {\n\t\t\tfields.push(options.field);\n\t\t}\n\t}\n\t// Use default fields if none specified and we're not excluding fields (excluding fields with an empty field array is the same as searching all fields)\n\tif(fields.length === 0 && !options.excludeField) {\n\t\tfields.push(\"title\");\n\t\tfields.push(\"tags\");\n\t\tfields.push(\"text\");\n\t}\n\t// Function to check a given tiddler for the search term\n\tvar searchTiddler = function(title) {\n\t\tif(!searchTermsRegExps) {\n\t\t\treturn true;\n\t\t}\n\t\tvar notYetFound = searchTermsRegExps.slice();\n\n\t\tvar tiddler = self.getTiddler(title);\n\t\tif(!tiddler) {\n\t\t\ttiddler = new $tw.Tiddler({title: title, text: \"\", type: \"text/vnd.tiddlywiki\"});\n\t\t}\n\t\tvar contentTypeInfo = $tw.config.contentTypeInfo[tiddler.fields.type] || $tw.config.contentTypeInfo[\"text/vnd.tiddlywiki\"],\n\t\t\tsearchFields;\n\t\t// Get the list of fields we're searching\n\t\tif(options.excludeField) {\n\t\t\tsearchFields = Object.keys(tiddler.fields);\n\t\t\t$tw.utils.each(fields,function(fieldName) {\n\t\t\t\tvar p = searchFields.indexOf(fieldName);\n\t\t\t\tif(p !== -1) {\n\t\t\t\t\tsearchFields.splice(p,1);\n\t\t\t\t}\n\t\t\t});\n\t\t} else {\n\t\t\tsearchFields = fields;\n\t\t}\n\t\tfor(var fieldIndex=0; notYetFound.length>0 && fieldIndex<searchFields.length; fieldIndex++) {\n\t\t\t// Don't search the text field if the content type is binary\n\t\t\tvar fieldName = searchFields[fieldIndex];\n\t\t\tif(fieldName === \"text\" && contentTypeInfo.encoding !== \"utf8\") {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tvar str = tiddler.fields[fieldName],\n\t\t\t\tt;\n\t\t\tif(str) {\n\t\t\t\tif($tw.utils.isArray(str)) {\n\t\t\t\t\t// If the field value is an array, test each regexp against each field array entry and fail if each regexp doesn't match at least one field array entry\n\t\t\t\t\tfor(var s=0; s<str.length; s++) {\n\t\t\t\t\t\tfor(t=0; t<notYetFound.length;) {\n\t\t\t\t\t\t\tif(notYetFound[t].test(str[s])) {\n\t\t\t\t\t\t\t\tnotYetFound.splice(t, 1);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tt++;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t// If the field isn't an array, force it to a string and test each regexp against it and fail if any do not match\n\t\t\t\t\tstr = tiddler.getFieldString(fieldName);\n\t\t\t\t\tfor(t=0; t<notYetFound.length;) {\n\t\t\t\t\t\tif(notYetFound[t].test(str)) {\n\t\t\t\t\t\t\tnotYetFound.splice(t, 1);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tt++;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t\treturn notYetFound.length == 0;\n\t};\n\t// Loop through all the tiddlers doing the search\n\tvar results = [],\n\t\tsource = options.source || this.each;\n\tsource(function(tiddler,title) {\n\t\tif(searchTiddler(title) !== options.invert) {\n\t\t\tresults.push(title);\n\t\t}\n\t});\n\t// Remove any of the results we have to exclude\n\tif(options.exclude) {\n\t\tfor(t=0; t<options.exclude.length; t++) {\n\t\t\tvar p = results.indexOf(options.exclude[t]);\n\t\t\tif(p !== -1) {\n\t\t\t\tresults.splice(p,1);\n\t\t\t}\n\t\t}\n\t}\n\treturn results;\n};\n\n/*\nTrigger a load for a tiddler if it is skinny. Returns the text, or undefined if the tiddler is missing, null if the tiddler is being lazily loaded.\n*/\nexports.getTiddlerText = function(title,defaultText) {\n\tvar tiddler = this.getTiddler(title);\n\t// Return undefined if the tiddler isn't found\n\tif(!tiddler) {\n\t\treturn defaultText;\n\t}\n\tif(tiddler.fields.text !== undefined) {\n\t\t// Just return the text if we've got it\n\t\treturn tiddler.fields.text;\n\t} else {\n\t\t// Tell any listeners about the need to lazily load this tiddler\n\t\tthis.dispatchEvent(\"lazyLoad\",title);\n\t\t// Indicate that the text is being loaded\n\t\treturn null;\n\t}\n};\n\n/*\nCheck whether the text of a tiddler matches a given value. By default, the comparison is case insensitive, and any spaces at either end of the tiddler text is trimmed\n*/\nexports.checkTiddlerText = function(title,targetText,options) {\n\toptions = options || {};\n\tvar text = this.getTiddlerText(title,\"\");\n\tif(!options.noTrim) {\n\t\ttext = text.trim();\n\t}\n\tif(!options.caseSensitive) {\n\t\ttext = text.toLowerCase();\n\t\ttargetText = targetText.toLowerCase();\n\t}\n\treturn text === targetText;\n}\n\n/*\nRead an array of browser File objects, invoking callback(tiddlerFieldsArray) once they're all read\n*/\nexports.readFiles = function(files,options) {\n\tvar callback;\n\tif(typeof options === \"function\") {\n\t\tcallback = options;\n\t\toptions = {};\n\t} else {\n\t\tcallback = options.callback;\n\t}\n\tvar result = [],\n\t\toutstanding = files.length,\n\t\treadFileCallback = function(tiddlerFieldsArray) {\n\t\t\tresult.push.apply(result,tiddlerFieldsArray);\n\t\t\tif(--outstanding === 0) {\n\t\t\t\tcallback(result);\n\t\t\t}\n\t\t};\n\tfor(var f=0; f<files.length; f++) {\n\t\tthis.readFile(files[f],$tw.utils.extend({},options,{callback: readFileCallback}));\n\t}\n\treturn files.length;\n};\n\n/*\nRead a browser File object, invoking callback(tiddlerFieldsArray) with an array of tiddler fields objects\n*/\nexports.readFile = function(file,options) {\n\tvar callback;\n\tif(typeof options === \"function\") {\n\t\tcallback = options;\n\t\toptions = {};\n\t} else {\n\t\tcallback = options.callback;\n\t}\n\t// Get the type, falling back to the filename extension\n\tvar self = this,\n\t\ttype = file.type;\n\tif(type === \"\" || !type) {\n\t\tvar dotPos = file.name.lastIndexOf(\".\");\n\t\tif(dotPos !== -1) {\n\t\t\tvar fileExtensionInfo = $tw.utils.getFileExtensionInfo(file.name.substr(dotPos));\n\t\t\tif(fileExtensionInfo) {\n\t\t\t\ttype = fileExtensionInfo.type;\n\t\t\t}\n\t\t}\n\t}\n\t// Figure out if we're reading a binary file\n\tvar contentTypeInfo = $tw.config.contentTypeInfo[type],\n\t\tisBinary = contentTypeInfo ? contentTypeInfo.encoding === \"base64\" : false;\n\t// Log some debugging information\n\tif($tw.log.IMPORT) {\n\t\tconsole.log(\"Importing file '\" + file.name + \"', type: '\" + type + \"', isBinary: \" + isBinary);\n\t}\n\t// Give the hook a chance to process the drag\n\tif($tw.hooks.invokeHook(\"th-importing-file\",{\n\t\tfile: file,\n\t\ttype: type,\n\t\tisBinary: isBinary,\n\t\tcallback: callback\n\t}) !== true) {\n\t\tthis.readFileContent(file,type,isBinary,options.deserializer,callback);\n\t}\n};\n\n/*\nLower level utility to read the content of a browser File object, invoking callback(tiddlerFieldsArray) with an array of tiddler fields objects\n*/\nexports.readFileContent = function(file,type,isBinary,deserializer,callback) {\n\tvar self = this;\n\t// Create the FileReader\n\tvar reader = new FileReader();\n\t// Onload\n\treader.onload = function(event) {\n\t\tvar text = event.target.result,\n\t\t\ttiddlerFields = {title: file.name || \"Untitled\", type: type};\n\t\tif(isBinary) {\n\t\t\tvar commaPos = text.indexOf(\",\");\n\t\t\tif(commaPos !== -1) {\n\t\t\t\ttext = text.substr(commaPos + 1);\n\t\t\t}\n\t\t}\n\t\t// Check whether this is an encrypted TiddlyWiki file\n\t\tvar encryptedJson = $tw.utils.extractEncryptedStoreArea(text);\n\t\tif(encryptedJson) {\n\t\t\t// If so, attempt to decrypt it with the current password\n\t\t\t$tw.utils.decryptStoreAreaInteractive(encryptedJson,function(tiddlers) {\n\t\t\t\tcallback(tiddlers);\n\t\t\t});\n\t\t} else {\n\t\t\t// Otherwise, just try to deserialise any tiddlers in the file\n\t\t\tcallback(self.deserializeTiddlers(type,text,tiddlerFields,{deserializer: deserializer}));\n\t\t}\n\t};\n\t// Kick off the read\n\tif(isBinary) {\n\t\treader.readAsDataURL(file);\n\t} else {\n\t\treader.readAsText(file);\n\t}\n};\n\n/*\nFind any existing draft of a specified tiddler\n*/\nexports.findDraft = function(targetTitle) {\n\tvar draftTitle = undefined;\n\tthis.forEachTiddler({includeSystem: true},function(title,tiddler) {\n\t\tif(tiddler.fields[\"draft.title\"] && tiddler.fields[\"draft.of\"] === targetTitle) {\n\t\t\tdraftTitle = title;\n\t\t}\n\t});\n\treturn draftTitle;\n}\n\n/*\nCheck whether the specified draft tiddler has been modified.\nIf the original tiddler doesn't exist, create a vanilla tiddler variable,\nto check if additional fields have been added.\n*/\nexports.isDraftModified = function(title) {\n\tvar tiddler = this.getTiddler(title);\n\tif(!tiddler.isDraft()) {\n\t\treturn false;\n\t}\n\tvar ignoredFields = [\"created\", \"modified\", \"title\", \"draft.title\", \"draft.of\"],\n\t\torigTiddler = this.getTiddler(tiddler.fields[\"draft.of\"]) || new $tw.Tiddler({text:\"\", tags:[]}),\n\t\ttitleModified = tiddler.fields[\"draft.title\"] !== tiddler.fields[\"draft.of\"];\n\treturn titleModified || !tiddler.isEqual(origTiddler,ignoredFields);\n};\n\n/*\nAdd a new record to the top of the history stack\ntitle: a title string or an array of title strings\nfromPageRect: page coordinates of the origin of the navigation\nhistoryTitle: title of history tiddler (defaults to $:/HistoryList)\n*/\nexports.addToHistory = function(title,fromPageRect,historyTitle) {\n\tvar story = new $tw.Story({wiki: this, historyTitle: historyTitle});\n\tstory.addToHistory(title,fromPageRect);\n};\n\n/*\nAdd a new tiddler to the story river\ntitle: a title string or an array of title strings\nfromTitle: the title of the tiddler from which the navigation originated\nstoryTitle: title of story tiddler (defaults to $:/StoryList)\noptions: see story.js\n*/\nexports.addToStory = function(title,fromTitle,storyTitle,options) {\n\tvar story = new $tw.Story({wiki: this, storyTitle: storyTitle});\n\tstory.addToStory(title,fromTitle,options);\n};\n\n/*\nInvoke the available upgrader modules\ntitles: array of tiddler titles to be processed\ntiddlers: hashmap by title of tiddler fields of pending import tiddlers. These can be modified by the upgraders. An entry with no fields indicates a tiddler that was pending import has been suppressed. When entries are added to the pending import the tiddlers hashmap may have entries that are not present in the titles array\nReturns a hashmap of messages keyed by tiddler title.\n*/\nexports.invokeUpgraders = function(titles,tiddlers) {\n\t// Collect up the available upgrader modules\n\tvar self = this;\n\tif(!this.upgraderModules) {\n\t\tthis.upgraderModules = [];\n\t\t$tw.modules.forEachModuleOfType(\"upgrader\",function(title,module) {\n\t\t\tif(module.upgrade) {\n\t\t\t\tself.upgraderModules.push(module);\n\t\t\t}\n\t\t});\n\t}\n\t// Invoke each upgrader in turn\n\tvar messages = {};\n\tfor(var t=0; t<this.upgraderModules.length; t++) {\n\t\tvar upgrader = this.upgraderModules[t],\n\t\t\tupgraderMessages = upgrader.upgrade(this,titles,tiddlers);\n\t\t$tw.utils.extend(messages,upgraderMessages);\n\t}\n\treturn messages;\n};\n\n})();\n\n",
"type": "application/javascript",
"module-type": "wikimethod"
},
"$:/palettes/Blanca": {
"title": "$:/palettes/Blanca",
"name": "Blanca",
"description": "A clean white palette to let you focus",
"tags": "$:/tags/Palette",
"type": "application/x-tiddler-dictionary",
"text": "alert-background: #ffe476\nalert-border: #b99e2f\nalert-highlight: #881122\nalert-muted-foreground: #b99e2f\nbackground: #ffffff\nblockquote-bar: <<colour muted-foreground>>\nbutton-background:\nbutton-foreground:\nbutton-border:\ncode-background: #f7f7f9\ncode-border: #e1e1e8\ncode-foreground: #dd1144\ndirty-indicator: #ff0000\ndownload-background: #66cccc\ndownload-foreground: <<colour background>>\ndragger-background: <<colour foreground>>\ndragger-foreground: <<colour background>>\ndropdown-background: <<colour background>>\ndropdown-border: <<colour muted-foreground>>\ndropdown-tab-background-selected: #fff\ndropdown-tab-background: #ececec\ndropzone-background: rgba(0,200,0,0.7)\nexternal-link-background-hover: inherit\nexternal-link-background-visited: inherit\nexternal-link-background: inherit\nexternal-link-foreground-hover: inherit\nexternal-link-foreground-visited: #0000aa\nexternal-link-foreground: #0000ee\nforeground: #333333\nmessage-background: #ecf2ff\nmessage-border: #cfd6e6\nmessage-foreground: #547599\nmodal-backdrop: <<colour foreground>>\nmodal-background: <<colour background>>\nmodal-border: #999999\nmodal-footer-background: #f5f5f5\nmodal-footer-border: #dddddd\nmodal-header-border: #eeeeee\nmuted-foreground: #999999\nnotification-background: #ffffdd\nnotification-border: #999999\npage-background: #ffffff\npre-background: #f5f5f5\npre-border: #cccccc\nprimary: #7897f3\nselect-tag-background:\nselect-tag-foreground:\nsidebar-button-foreground: <<colour foreground>>\nsidebar-controls-foreground-hover: #000000\nsidebar-controls-foreground: #ccc\nsidebar-foreground-shadow: rgba(255,255,255, 0.8)\nsidebar-foreground: #acacac\nsidebar-muted-foreground-hover: #444444\nsidebar-muted-foreground: #c0c0c0\nsidebar-tab-background-selected: #ffffff\nsidebar-tab-background: <<colour tab-background>>\nsidebar-tab-border-selected: <<colour tab-border-selected>>\nsidebar-tab-border: <<colour tab-border>>\nsidebar-tab-divider: <<colour tab-divider>>\nsidebar-tab-foreground-selected: \nsidebar-tab-foreground: <<colour tab-foreground>>\nsidebar-tiddler-link-foreground-hover: #444444\nsidebar-tiddler-link-foreground: #7897f3\nsite-title-foreground: <<colour tiddler-title-foreground>>\nstatic-alert-foreground: #aaaaaa\ntab-background-selected: #ffffff\ntab-background: #eeeeee\ntab-border-selected: #cccccc\ntab-border: #cccccc\ntab-divider: #d8d8d8\ntab-foreground-selected: <<colour tab-foreground>>\ntab-foreground: #666666\ntable-border: #dddddd\ntable-footer-background: #a8a8a8\ntable-header-background: #f0f0f0\ntag-background: #ffeedd\ntag-foreground: #000\ntiddler-background: <<colour background>>\ntiddler-border: #eee\ntiddler-controls-foreground-hover: #888888\ntiddler-controls-foreground-selected: #444444\ntiddler-controls-foreground: #cccccc\ntiddler-editor-background: #f8f8f8\ntiddler-editor-border-image: #ffffff\ntiddler-editor-border: #cccccc\ntiddler-editor-fields-even: #e0e8e0\ntiddler-editor-fields-odd: #f0f4f0\ntiddler-info-background: #f8f8f8\ntiddler-info-border: #dddddd\ntiddler-info-tab-background: #f8f8f8\ntiddler-link-background: <<colour background>>\ntiddler-link-foreground: <<colour primary>>\ntiddler-subtitle-foreground: #c0c0c0\ntiddler-title-foreground: #ff9900\ntoolbar-new-button:\ntoolbar-options-button:\ntoolbar-save-button:\ntoolbar-info-button:\ntoolbar-edit-button:\ntoolbar-close-button:\ntoolbar-delete-button:\ntoolbar-cancel-button:\ntoolbar-done-button:\nuntagged-background: #999999\nvery-muted-foreground: #888888\n"
},
"$:/palettes/Blue": {
"title": "$:/palettes/Blue",
"name": "Blue",
"description": "A blue theme",
"tags": "$:/tags/Palette",
"type": "application/x-tiddler-dictionary",
"text": "alert-background: #ffe476\nalert-border: #b99e2f\nalert-highlight: #881122\nalert-muted-foreground: #b99e2f\nbackground: #fff\nblockquote-bar: <<colour muted-foreground>>\nbutton-background:\nbutton-foreground:\nbutton-border:\ncode-background: #f7f7f9\ncode-border: #e1e1e8\ncode-foreground: #dd1144\ndirty-indicator: #ff0000\ndownload-background: #34c734\ndownload-foreground: <<colour foreground>>\ndragger-background: <<colour foreground>>\ndragger-foreground: <<colour background>>\ndropdown-background: <<colour background>>\ndropdown-border: <<colour muted-foreground>>\ndropdown-tab-background-selected: #fff\ndropdown-tab-background: #ececec\ndropzone-background: rgba(0,200,0,0.7)\nexternal-link-background-hover: inherit\nexternal-link-background-visited: inherit\nexternal-link-background: inherit\nexternal-link-foreground-hover: inherit\nexternal-link-foreground-visited: #0000aa\nexternal-link-foreground: #0000ee\nforeground: #333353\nmessage-background: #ecf2ff\nmessage-border: #cfd6e6\nmessage-foreground: #547599\nmodal-backdrop: <<colour foreground>>\nmodal-background: <<colour background>>\nmodal-border: #999999\nmodal-footer-background: #f5f5f5\nmodal-footer-border: #dddddd\nmodal-header-border: #eeeeee\nmuted-foreground: #999999\nnotification-background: #ffffdd\nnotification-border: #999999\npage-background: #ddddff\npre-background: #f5f5f5\npre-border: #cccccc\nprimary: #5778d8\nselect-tag-background:\nselect-tag-foreground:\nsidebar-button-foreground: <<colour foreground>>\nsidebar-controls-foreground-hover: #000000\nsidebar-controls-foreground: #ffffff\nsidebar-foreground-shadow: rgba(255,255,255, 0.8)\nsidebar-foreground: #acacac\nsidebar-muted-foreground-hover: #444444\nsidebar-muted-foreground: #c0c0c0\nsidebar-tab-background-selected: <<colour page-background>>\nsidebar-tab-background: <<colour tab-background>>\nsidebar-tab-border-selected: <<colour tab-border-selected>>\nsidebar-tab-border: <<colour tab-border>>\nsidebar-tab-divider: <<colour tab-divider>>\nsidebar-tab-foreground-selected: \nsidebar-tab-foreground: <<colour tab-foreground>>\nsidebar-tiddler-link-foreground-hover: #444444\nsidebar-tiddler-link-foreground: #5959c0\nsite-title-foreground: <<colour tiddler-title-foreground>>\nstatic-alert-foreground: #aaaaaa\ntab-background-selected: <<colour background>>\ntab-background: #ccccdd\ntab-border-selected: #ccccdd\ntab-border: #cccccc\ntab-divider: #d8d8d8\ntab-foreground-selected: <<colour tab-foreground>>\ntab-foreground: #666666\ntable-border: #dddddd\ntable-footer-background: #a8a8a8\ntable-header-background: #f0f0f0\ntag-background: #eeeeff\ntag-foreground: #000\ntiddler-background: <<colour background>>\ntiddler-border: <<colour background>>\ntiddler-controls-foreground-hover: #666666\ntiddler-controls-foreground-selected: #444444\ntiddler-controls-foreground: #cccccc\ntiddler-editor-background: #f8f8f8\ntiddler-editor-border-image: #ffffff\ntiddler-editor-border: #cccccc\ntiddler-editor-fields-even: #e0e8e0\ntiddler-editor-fields-odd: #f0f4f0\ntiddler-info-background: #ffffff\ntiddler-info-border: #dddddd\ntiddler-info-tab-background: #ffffff\ntiddler-link-background: <<colour background>>\ntiddler-link-foreground: <<colour primary>>\ntiddler-subtitle-foreground: #c0c0c0\ntiddler-title-foreground: #5959c0\ntoolbar-new-button: #5eb95e\ntoolbar-options-button: rgb(128, 88, 165)\ntoolbar-save-button: #0e90d2\ntoolbar-info-button: #0e90d2\ntoolbar-edit-button: rgb(243, 123, 29)\ntoolbar-close-button: #dd514c\ntoolbar-delete-button: #dd514c\ntoolbar-cancel-button: rgb(243, 123, 29)\ntoolbar-done-button: #5eb95e\nuntagged-background: #999999\nvery-muted-foreground: #888888\n"
},
"$:/palettes/Muted": {
"title": "$:/palettes/Muted",
"name": "Muted",
"description": "Bright tiddlers on a muted background",
"tags": "$:/tags/Palette",
"type": "application/x-tiddler-dictionary",
"text": "alert-background: #ffe476\nalert-border: #b99e2f\nalert-highlight: #881122\nalert-muted-foreground: #b99e2f\nbackground: #ffffff\nblockquote-bar: <<colour muted-foreground>>\nbutton-background:\nbutton-foreground:\nbutton-border:\ncode-background: #f7f7f9\ncode-border: #e1e1e8\ncode-foreground: #dd1144\ndirty-indicator: #ff0000\ndownload-background: #34c734\ndownload-foreground: <<colour background>>\ndragger-background: <<colour foreground>>\ndragger-foreground: <<colour background>>\ndropdown-background: <<colour background>>\ndropdown-border: <<colour muted-foreground>>\ndropdown-tab-background-selected: #fff\ndropdown-tab-background: #ececec\ndropzone-background: rgba(0,200,0,0.7)\nexternal-link-background-hover: inherit\nexternal-link-background-visited: inherit\nexternal-link-background: inherit\nexternal-link-foreground-hover: inherit\nexternal-link-foreground-visited: #0000aa\nexternal-link-foreground: #0000ee\nforeground: #333333\nmessage-background: #ecf2ff\nmessage-border: #cfd6e6\nmessage-foreground: #547599\nmodal-backdrop: <<colour foreground>>\nmodal-background: <<colour background>>\nmodal-border: #999999\nmodal-footer-background: #f5f5f5\nmodal-footer-border: #dddddd\nmodal-header-border: #eeeeee\nmuted-foreground: #bbb\nnotification-background: #ffffdd\nnotification-border: #999999\npage-background: #6f6f70\npre-background: #f5f5f5\npre-border: #cccccc\nprimary: #29a6ee\nselect-tag-background:\nselect-tag-foreground:\nsidebar-button-foreground: <<colour foreground>>\nsidebar-controls-foreground-hover: #000000\nsidebar-controls-foreground: #c2c1c2\nsidebar-foreground-shadow: rgba(255,255,255,0)\nsidebar-foreground: #d3d2d4\nsidebar-muted-foreground-hover: #444444\nsidebar-muted-foreground: #c0c0c0\nsidebar-tab-background-selected: #6f6f70\nsidebar-tab-background: #666667\nsidebar-tab-border-selected: #999\nsidebar-tab-border: #515151\nsidebar-tab-divider: #999\nsidebar-tab-foreground-selected: \nsidebar-tab-foreground: #999\nsidebar-tiddler-link-foreground-hover: #444444\nsidebar-tiddler-link-foreground: #d1d0d2\nsite-title-foreground: <<colour tiddler-title-foreground>>\nstatic-alert-foreground: #aaaaaa\ntab-background-selected: #ffffff\ntab-background: #d8d8d8\ntab-border-selected: #d8d8d8\ntab-border: #cccccc\ntab-divider: #d8d8d8\ntab-foreground-selected: <<colour tab-foreground>>\ntab-foreground: #666666\ntable-border: #dddddd\ntable-footer-background: #a8a8a8\ntable-header-background: #f0f0f0\ntag-background: #d5ad34\ntag-foreground: #ffffff\ntiddler-background: <<colour background>>\ntiddler-border: <<colour background>>\ntiddler-controls-foreground-hover: #888888\ntiddler-controls-foreground-selected: #444444\ntiddler-controls-foreground: #cccccc\ntiddler-editor-background: #f8f8f8\ntiddler-editor-border-image: #ffffff\ntiddler-editor-border: #cccccc\ntiddler-editor-fields-even: #e0e8e0\ntiddler-editor-fields-odd: #f0f4f0\ntiddler-info-background: #f8f8f8\ntiddler-info-border: #dddddd\ntiddler-info-tab-background: #f8f8f8\ntiddler-link-background: <<colour background>>\ntiddler-link-foreground: <<colour primary>>\ntiddler-subtitle-foreground: #c0c0c0\ntiddler-title-foreground: #182955\ntoolbar-new-button: \ntoolbar-options-button: \ntoolbar-save-button: \ntoolbar-info-button: \ntoolbar-edit-button: \ntoolbar-close-button: \ntoolbar-delete-button: \ntoolbar-cancel-button: \ntoolbar-done-button: \nuntagged-background: #999999\nvery-muted-foreground: #888888\n"
},
"$:/palettes/ContrastLight": {
"title": "$:/palettes/ContrastLight",
"name": "Contrast (Light)",
"description": "High contrast and unambiguous (light version)",
"tags": "$:/tags/Palette",
"type": "application/x-tiddler-dictionary",
"text": "alert-background: #f00\nalert-border: <<colour background>>\nalert-highlight: <<colour foreground>>\nalert-muted-foreground: #800\nbackground: #fff\nblockquote-bar: <<colour muted-foreground>>\nbutton-background: <<colour background>>\nbutton-foreground: <<colour foreground>>\nbutton-border: <<colour foreground>>\ncode-background: <<colour background>>\ncode-border: <<colour foreground>>\ncode-foreground: <<colour foreground>>\ndirty-indicator: #f00\ndownload-background: #080\ndownload-foreground: <<colour background>>\ndragger-background: <<colour foreground>>\ndragger-foreground: <<colour background>>\ndropdown-background: <<colour background>>\ndropdown-border: <<colour muted-foreground>>\ndropdown-tab-background-selected: <<colour foreground>>\ndropdown-tab-background: <<colour foreground>>\ndropzone-background: rgba(0,200,0,0.7)\nexternal-link-background-hover: inherit\nexternal-link-background-visited: inherit\nexternal-link-background: inherit\nexternal-link-foreground-hover: inherit\nexternal-link-foreground-visited: #00a\nexternal-link-foreground: #00e\nforeground: #000\nmessage-background: <<colour foreground>>\nmessage-border: <<colour background>>\nmessage-foreground: <<colour background>>\nmodal-backdrop: <<colour foreground>>\nmodal-background: <<colour background>>\nmodal-border: <<colour foreground>>\nmodal-footer-background: <<colour background>>\nmodal-footer-border: <<colour foreground>>\nmodal-header-border: <<colour foreground>>\nmuted-foreground: <<colour foreground>>\nnotification-background: <<colour background>>\nnotification-border: <<colour foreground>>\npage-background: <<colour background>>\npre-background: <<colour background>>\npre-border: <<colour foreground>>\nprimary: #00f\nselect-tag-background:\nselect-tag-foreground:\nsidebar-button-foreground: <<colour foreground>>\nsidebar-controls-foreground-hover: <<colour background>>\nsidebar-controls-foreground: <<colour foreground>>\nsidebar-foreground-shadow: rgba(0,0,0, 0)\nsidebar-foreground: <<colour foreground>>\nsidebar-muted-foreground-hover: #444444\nsidebar-muted-foreground: <<colour foreground>>\nsidebar-tab-background-selected: <<colour background>>\nsidebar-tab-background: <<colour tab-background>>\nsidebar-tab-border-selected: <<colour tab-border-selected>>\nsidebar-tab-border: <<colour tab-border>>\nsidebar-tab-divider: <<colour tab-divider>>\nsidebar-tab-foreground-selected: <<colour foreground>>\nsidebar-tab-foreground: <<colour tab-foreground>>\nsidebar-tiddler-link-foreground-hover: <<colour foreground>>\nsidebar-tiddler-link-foreground: <<colour primary>>\nsite-title-foreground: <<colour tiddler-title-foreground>>\nstatic-alert-foreground: #aaaaaa\ntab-background-selected: <<colour background>>\ntab-background: <<colour foreground>>\ntab-border-selected: <<colour foreground>>\ntab-border: <<colour foreground>>\ntab-divider: <<colour foreground>>\ntab-foreground-selected: <<colour foreground>>\ntab-foreground: <<colour background>>\ntable-border: #dddddd\ntable-footer-background: #a8a8a8\ntable-header-background: #f0f0f0\ntag-background: #000\ntag-foreground: #fff\ntiddler-background: <<colour background>>\ntiddler-border: <<colour foreground>>\ntiddler-controls-foreground-hover: #ddd\ntiddler-controls-foreground-selected: #fdd\ntiddler-controls-foreground: <<colour foreground>>\ntiddler-editor-background: <<colour background>>\ntiddler-editor-border-image: <<colour foreground>>\ntiddler-editor-border: #cccccc\ntiddler-editor-fields-even: <<colour background>>\ntiddler-editor-fields-odd: <<colour background>>\ntiddler-info-background: <<colour background>>\ntiddler-info-border: <<colour foreground>>\ntiddler-info-tab-background: <<colour background>>\ntiddler-link-background: <<colour background>>\ntiddler-link-foreground: <<colour primary>>\ntiddler-subtitle-foreground: <<colour foreground>>\ntiddler-title-foreground: <<colour foreground>>\ntoolbar-new-button: \ntoolbar-options-button: \ntoolbar-save-button: \ntoolbar-info-button: \ntoolbar-edit-button: \ntoolbar-close-button: \ntoolbar-delete-button: \ntoolbar-cancel-button: \ntoolbar-done-button: \nuntagged-background: <<colour foreground>>\nvery-muted-foreground: #888888\n"
},
"$:/palettes/ContrastDark": {
"title": "$:/palettes/ContrastDark",
"name": "Contrast (Dark)",
"description": "High contrast and unambiguous (dark version)",
"tags": "$:/tags/Palette",
"type": "application/x-tiddler-dictionary",
"text": "alert-background: #f00\nalert-border: <<colour background>>\nalert-highlight: <<colour foreground>>\nalert-muted-foreground: #800\nbackground: #000\nblockquote-bar: <<colour muted-foreground>>\nbutton-background: <<colour background>>\nbutton-foreground: <<colour foreground>>\nbutton-border: <<colour foreground>>\ncode-background: <<colour background>>\ncode-border: <<colour foreground>>\ncode-foreground: <<colour foreground>>\ndirty-indicator: #f00\ndownload-background: #080\ndownload-foreground: <<colour background>>\ndragger-background: <<colour foreground>>\ndragger-foreground: <<colour background>>\ndropdown-background: <<colour background>>\ndropdown-border: <<colour muted-foreground>>\ndropdown-tab-background-selected: <<colour foreground>>\ndropdown-tab-background: <<colour foreground>>\ndropzone-background: rgba(0,200,0,0.7)\nexternal-link-background-hover: inherit\nexternal-link-background-visited: inherit\nexternal-link-background: inherit\nexternal-link-foreground-hover: inherit\nexternal-link-foreground-visited: #00a\nexternal-link-foreground: #00e\nforeground: #fff\nmessage-background: <<colour foreground>>\nmessage-border: <<colour background>>\nmessage-foreground: <<colour background>>\nmodal-backdrop: <<colour foreground>>\nmodal-background: <<colour background>>\nmodal-border: <<colour foreground>>\nmodal-footer-background: <<colour background>>\nmodal-footer-border: <<colour foreground>>\nmodal-header-border: <<colour foreground>>\nmuted-foreground: <<colour foreground>>\nnotification-background: <<colour background>>\nnotification-border: <<colour foreground>>\npage-background: <<colour background>>\npre-background: <<colour background>>\npre-border: <<colour foreground>>\nprimary: #00f\nselect-tag-background:\nselect-tag-foreground:\nsidebar-button-foreground: <<colour foreground>>\nsidebar-controls-foreground-hover: <<colour background>>\nsidebar-controls-foreground: <<colour foreground>>\nsidebar-foreground-shadow: rgba(0,0,0, 0)\nsidebar-foreground: <<colour foreground>>\nsidebar-muted-foreground-hover: #444444\nsidebar-muted-foreground: <<colour foreground>>\nsidebar-tab-background-selected: <<colour background>>\nsidebar-tab-background: <<colour tab-background>>\nsidebar-tab-border-selected: <<colour tab-border-selected>>\nsidebar-tab-border: <<colour tab-border>>\nsidebar-tab-divider: <<colour tab-divider>>\nsidebar-tab-foreground-selected: <<colour foreground>>\nsidebar-tab-foreground: <<colour tab-foreground>>\nsidebar-tiddler-link-foreground-hover: <<colour foreground>>\nsidebar-tiddler-link-foreground: <<colour primary>>\nsite-title-foreground: <<colour tiddler-title-foreground>>\nstatic-alert-foreground: #aaaaaa\ntab-background-selected: <<colour background>>\ntab-background: <<colour foreground>>\ntab-border-selected: <<colour foreground>>\ntab-border: <<colour foreground>>\ntab-divider: <<colour foreground>>\ntab-foreground-selected: <<colour foreground>>\ntab-foreground: <<colour background>>\ntable-border: #dddddd\ntable-footer-background: #a8a8a8\ntable-header-background: #f0f0f0\ntag-background: #fff\ntag-foreground: #000\ntiddler-background: <<colour background>>\ntiddler-border: <<colour foreground>>\ntiddler-controls-foreground-hover: #ddd\ntiddler-controls-foreground-selected: #fdd\ntiddler-controls-foreground: <<colour foreground>>\ntiddler-editor-background: <<colour background>>\ntiddler-editor-border-image: <<colour foreground>>\ntiddler-editor-border: #cccccc\ntiddler-editor-fields-even: <<colour background>>\ntiddler-editor-fields-odd: <<colour background>>\ntiddler-info-background: <<colour background>>\ntiddler-info-border: <<colour foreground>>\ntiddler-info-tab-background: <<colour background>>\ntiddler-link-background: <<colour background>>\ntiddler-link-foreground: <<colour primary>>\ntiddler-subtitle-foreground: <<colour foreground>>\ntiddler-title-foreground: <<colour foreground>>\ntoolbar-new-button: \ntoolbar-options-button: \ntoolbar-save-button: \ntoolbar-info-button: \ntoolbar-edit-button: \ntoolbar-close-button: \ntoolbar-delete-button: \ntoolbar-cancel-button: \ntoolbar-done-button: \nuntagged-background: <<colour foreground>>\nvery-muted-foreground: #888888\n"
},
"$:/palettes/DarkPhotos": {
"title": "$:/palettes/DarkPhotos",
"created": "20150402111612188",
"description": "Good with dark photo backgrounds",
"modified": "20150402112344080",
"name": "DarkPhotos",
"tags": "$:/tags/Palette",
"type": "application/x-tiddler-dictionary",
"text": "alert-background: #ffe476\nalert-border: #b99e2f\nalert-highlight: #881122\nalert-muted-foreground: #b99e2f\nbackground: #ffffff\nblockquote-bar: <<colour muted-foreground>>\nbutton-background: \nbutton-foreground: \nbutton-border: \ncode-background: #f7f7f9\ncode-border: #e1e1e8\ncode-foreground: #dd1144\ndirty-indicator: #ff0000\ndownload-background: #34c734\ndownload-foreground: <<colour background>>\ndragger-background: <<colour foreground>>\ndragger-foreground: <<colour background>>\ndropdown-background: <<colour background>>\ndropdown-border: <<colour muted-foreground>>\ndropdown-tab-background-selected: #fff\ndropdown-tab-background: #ececec\ndropzone-background: rgba(0,200,0,0.7)\nexternal-link-background-hover: inherit\nexternal-link-background-visited: inherit\nexternal-link-background: inherit\nexternal-link-foreground-hover: inherit\nexternal-link-foreground-visited: #0000aa\nexternal-link-foreground: #0000ee\nforeground: #333333\nmessage-background: #ecf2ff\nmessage-border: #cfd6e6\nmessage-foreground: #547599\nmodal-backdrop: <<colour foreground>>\nmodal-background: <<colour background>>\nmodal-border: #999999\nmodal-footer-background: #f5f5f5\nmodal-footer-border: #dddddd\nmodal-header-border: #eeeeee\nmuted-foreground: #ddd\nnotification-background: #ffffdd\nnotification-border: #999999\npage-background: #336438\npre-background: #f5f5f5\npre-border: #cccccc\nprimary: #5778d8\nselect-tag-background:\nselect-tag-foreground:\nsidebar-button-foreground: <<colour foreground>>\nsidebar-controls-foreground-hover: #ccf\nsidebar-controls-foreground: #fff\nsidebar-foreground-shadow: rgba(0,0,0, 0.5)\nsidebar-foreground: #fff\nsidebar-muted-foreground-hover: #444444\nsidebar-muted-foreground: #eee\nsidebar-tab-background-selected: rgba(255,255,255, 0.8)\nsidebar-tab-background: rgba(255,255,255, 0.4)\nsidebar-tab-border-selected: <<colour tab-border-selected>>\nsidebar-tab-border: <<colour tab-border>>\nsidebar-tab-divider: rgba(255,255,255, 0.2)\nsidebar-tab-foreground-selected: \nsidebar-tab-foreground: <<colour tab-foreground>>\nsidebar-tiddler-link-foreground-hover: #aaf\nsidebar-tiddler-link-foreground: #ddf\nsite-title-foreground: #fff\nstatic-alert-foreground: #aaaaaa\ntab-background-selected: #ffffff\ntab-background: #d8d8d8\ntab-border-selected: #d8d8d8\ntab-border: #cccccc\ntab-divider: #d8d8d8\ntab-foreground-selected: <<colour tab-foreground>>\ntab-foreground: #666666\ntable-border: #dddddd\ntable-footer-background: #a8a8a8\ntable-header-background: #f0f0f0\ntag-background: #ec6\ntag-foreground: #ffffff\ntiddler-background: <<colour background>>\ntiddler-border: <<colour background>>\ntiddler-controls-foreground-hover: #888888\ntiddler-controls-foreground-selected: #444444\ntiddler-controls-foreground: #cccccc\ntiddler-editor-background: #f8f8f8\ntiddler-editor-border-image: #ffffff\ntiddler-editor-border: #cccccc\ntiddler-editor-fields-even: #e0e8e0\ntiddler-editor-fields-odd: #f0f4f0\ntiddler-info-background: #f8f8f8\ntiddler-info-border: #dddddd\ntiddler-info-tab-background: #f8f8f8\ntiddler-link-background: <<colour background>>\ntiddler-link-foreground: <<colour primary>>\ntiddler-subtitle-foreground: #c0c0c0\ntiddler-title-foreground: #182955\ntoolbar-new-button: \ntoolbar-options-button: \ntoolbar-save-button: \ntoolbar-info-button: \ntoolbar-edit-button: \ntoolbar-close-button: \ntoolbar-delete-button: \ntoolbar-cancel-button: \ntoolbar-done-button: \nuntagged-background: #999999\nvery-muted-foreground: #888888\n"
},
"$:/palettes/Rocker": {
"title": "$:/palettes/Rocker",
"name": "Rocker",
"description": "A dark theme",
"tags": "$:/tags/Palette",
"type": "application/x-tiddler-dictionary",
"text": "alert-background: #ffe476\nalert-border: #b99e2f\nalert-highlight: #881122\nalert-muted-foreground: #b99e2f\nbackground: #ffffff\nblockquote-bar: <<colour muted-foreground>>\nbutton-background:\nbutton-foreground:\nbutton-border:\ncode-background: #f7f7f9\ncode-border: #e1e1e8\ncode-foreground: #dd1144\ndirty-indicator: #ff0000\ndownload-background: #34c734\ndownload-foreground: <<colour background>>\ndragger-background: <<colour foreground>>\ndragger-foreground: <<colour background>>\ndropdown-background: <<colour background>>\ndropdown-border: <<colour muted-foreground>>\ndropdown-tab-background-selected: #fff\ndropdown-tab-background: #ececec\ndropzone-background: rgba(0,200,0,0.7)\nexternal-link-background-hover: inherit\nexternal-link-background-visited: inherit\nexternal-link-background: inherit\nexternal-link-foreground-hover: inherit\nexternal-link-foreground-visited: #0000aa\nexternal-link-foreground: #0000ee\nforeground: #333333\nmessage-background: #ecf2ff\nmessage-border: #cfd6e6\nmessage-foreground: #547599\nmodal-backdrop: <<colour foreground>>\nmodal-background: <<colour background>>\nmodal-border: #999999\nmodal-footer-background: #f5f5f5\nmodal-footer-border: #dddddd\nmodal-header-border: #eeeeee\nmuted-foreground: #999999\nnotification-background: #ffffdd\nnotification-border: #999999\npage-background: #000\npre-background: #f5f5f5\npre-border: #cccccc\nprimary: #cc0000\nselect-tag-background:\nselect-tag-foreground:\nsidebar-button-foreground: <<colour foreground>>\nsidebar-controls-foreground-hover: #000000\nsidebar-controls-foreground: #ffffff\nsidebar-foreground-shadow: rgba(255,255,255, 0.0)\nsidebar-foreground: #acacac\nsidebar-muted-foreground-hover: #444444\nsidebar-muted-foreground: #c0c0c0\nsidebar-tab-background-selected: #000\nsidebar-tab-background: <<colour tab-background>>\nsidebar-tab-border-selected: <<colour tab-border-selected>>\nsidebar-tab-border: <<colour tab-border>>\nsidebar-tab-divider: <<colour tab-divider>>\nsidebar-tab-foreground-selected: \nsidebar-tab-foreground: <<colour tab-foreground>>\nsidebar-tiddler-link-foreground-hover: #ffbb99\nsidebar-tiddler-link-foreground: #cc0000\nsite-title-foreground: <<colour tiddler-title-foreground>>\nstatic-alert-foreground: #aaaaaa\ntab-background-selected: #ffffff\ntab-background: #d8d8d8\ntab-border-selected: #d8d8d8\ntab-border: #cccccc\ntab-divider: #d8d8d8\ntab-foreground-selected: <<colour tab-foreground>>\ntab-foreground: #666666\ntable-border: #dddddd\ntable-footer-background: #a8a8a8\ntable-header-background: #f0f0f0\ntag-background: #ffbb99\ntag-foreground: #000\ntiddler-background: <<colour background>>\ntiddler-border: <<colour background>>\ntiddler-controls-foreground-hover: #888888\ntiddler-controls-foreground-selected: #444444\ntiddler-controls-foreground: #cccccc\ntiddler-editor-background: #f8f8f8\ntiddler-editor-border-image: #ffffff\ntiddler-editor-border: #cccccc\ntiddler-editor-fields-even: #e0e8e0\ntiddler-editor-fields-odd: #f0f4f0\ntiddler-info-background: #f8f8f8\ntiddler-info-border: #dddddd\ntiddler-info-tab-background: #f8f8f8\ntiddler-link-background: <<colour background>>\ntiddler-link-foreground: <<colour primary>>\ntiddler-subtitle-foreground: #c0c0c0\ntiddler-title-foreground: #cc0000\ntoolbar-new-button:\ntoolbar-options-button:\ntoolbar-save-button:\ntoolbar-info-button:\ntoolbar-edit-button:\ntoolbar-close-button:\ntoolbar-delete-button:\ntoolbar-cancel-button:\ntoolbar-done-button:\nuntagged-background: #999999\nvery-muted-foreground: #888888\n"
},
"$:/palettes/SolarFlare": {
"title": "$:/palettes/SolarFlare",
"name": "Solar Flare",
"description": "Warm, relaxing earth colours",
"tags": "$:/tags/Palette",
"type": "application/x-tiddler-dictionary",
"text": ": Background Tones\n\nbase03: #002b36\nbase02: #073642\n\n: Content Tones\n\nbase01: #586e75\nbase00: #657b83\nbase0: #839496\nbase1: #93a1a1\n\n: Background Tones\n\nbase2: #eee8d5\nbase3: #fdf6e3\n\n: Accent Colors\n\nyellow: #b58900\norange: #cb4b16\nred: #dc322f\nmagenta: #d33682\nviolet: #6c71c4\nblue: #268bd2\ncyan: #2aa198\ngreen: #859900\n\n: Additional Tones (RA)\n\nbase10: #c0c4bb\nviolet-muted: #7c81b0\nblue-muted: #4e7baa\n\nyellow-hot: #ffcc44\norange-hot: #eb6d20\nred-hot: #ff2222\nblue-hot: #2298ee\ngreen-hot: #98ee22\n\n: Palette\n\n: Do not use colour macro for background and foreground\nbackground: #fdf6e3\n download-foreground: <<colour background>>\n dragger-foreground: <<colour background>>\n dropdown-background: <<colour background>>\n modal-background: <<colour background>>\n sidebar-foreground-shadow: <<colour background>>\n tiddler-background: <<colour background>>\n tiddler-border: <<colour background>>\n tiddler-link-background: <<colour background>>\n tab-background-selected: <<colour background>>\n dropdown-tab-background-selected: <<colour tab-background-selected>>\nforeground: #657b83\n dragger-background: <<colour foreground>>\n tab-foreground: <<colour foreground>>\n tab-foreground-selected: <<colour tab-foreground>>\n sidebar-tab-foreground-selected: <<colour tab-foreground-selected>>\n sidebar-tab-foreground: <<colour tab-foreground>>\n sidebar-button-foreground: <<colour foreground>>\n sidebar-controls-foreground: <<colour foreground>>\n sidebar-foreground: <<colour foreground>>\n: base03\n: base02\n: base01\n alert-muted-foreground: <<colour base01>>\n: base00\n code-foreground: <<colour base00>>\n message-foreground: <<colour base00>>\n tag-foreground: <<colour base00>>\n: base0\n sidebar-tiddler-link-foreground: <<colour base0>>\n: base1\n muted-foreground: <<colour base1>>\n blockquote-bar: <<colour muted-foreground>>\n dropdown-border: <<colour muted-foreground>>\n sidebar-muted-foreground: <<colour muted-foreground>>\n tiddler-title-foreground: <<colour muted-foreground>>\n site-title-foreground: <<colour tiddler-title-foreground>>\n: base2\n modal-footer-background: <<colour base2>>\n page-background: <<colour base2>>\n modal-backdrop: <<colour page-background>>\n notification-background: <<colour page-background>>\n code-background: <<colour page-background>>\n code-border: <<colour code-background>>\n pre-background: <<colour page-background>>\n pre-border: <<colour pre-background>>\n sidebar-tab-background-selected: <<colour page-background>>\n table-header-background: <<colour base2>>\n tag-background: <<colour base2>>\n tiddler-editor-background: <<colour base2>>\n tiddler-info-background: <<colour base2>>\n tiddler-info-tab-background: <<colour base2>>\n tab-background: <<colour base2>>\n dropdown-tab-background: <<colour tab-background>>\n: base3\n alert-background: <<colour base3>>\n message-background: <<colour base3>>\n: yellow\n: orange\n: red\n: magenta\n alert-highlight: <<colour magenta>>\n: violet\n external-link-foreground: <<colour violet>>\n: blue\n: cyan\n: green\n: base10\n tiddler-controls-foreground: <<colour base10>>\n: violet-muted\n external-link-foreground-visited: <<colour violet-muted>>\n: blue-muted\n primary: <<colour blue-muted>>\n download-background: <<colour primary>>\n tiddler-link-foreground: <<colour primary>>\n\nalert-border: #b99e2f\ndirty-indicator: #ff0000\ndropzone-background: rgba(0,200,0,0.7)\nexternal-link-background-hover: inherit\nexternal-link-background-visited: inherit\nexternal-link-background: inherit\nexternal-link-foreground-hover: inherit\nmessage-border: #cfd6e6\nmodal-border: #999999\nselect-tag-background:\nselect-tag-foreground:\nsidebar-controls-foreground-hover:\nsidebar-muted-foreground-hover:\nsidebar-tab-background: #ded8c5\nsidebar-tiddler-link-foreground-hover:\nstatic-alert-foreground: #aaaaaa\ntab-border: #cccccc\n modal-footer-border: <<colour tab-border>>\n modal-header-border: <<colour tab-border>>\n notification-border: <<colour tab-border>>\n sidebar-tab-border: <<colour tab-border>>\n tab-border-selected: <<colour tab-border>>\n sidebar-tab-border-selected: <<colour tab-border-selected>>\ntab-divider: #d8d8d8\n sidebar-tab-divider: <<colour tab-divider>>\ntable-border: #dddddd\ntable-footer-background: #a8a8a8\ntiddler-controls-foreground-hover: #888888\ntiddler-controls-foreground-selected: #444444\ntiddler-editor-border-image: #ffffff\ntiddler-editor-border: #cccccc\ntiddler-editor-fields-even: #e0e8e0\ntiddler-editor-fields-odd: #f0f4f0\ntiddler-info-border: #dddddd\ntiddler-subtitle-foreground: #c0c0c0\ntoolbar-new-button:\ntoolbar-options-button:\ntoolbar-save-button:\ntoolbar-info-button:\ntoolbar-edit-button:\ntoolbar-close-button:\ntoolbar-delete-button:\ntoolbar-cancel-button:\ntoolbar-done-button:\nuntagged-background: #999999\nvery-muted-foreground: #888888\n"
},
"$:/palettes/Vanilla": {
"title": "$:/palettes/Vanilla",
"name": "Vanilla",
"description": "Pale and unobtrusive",
"tags": "$:/tags/Palette",
"type": "application/x-tiddler-dictionary",
"text": "alert-background: #ffe476\nalert-border: #b99e2f\nalert-highlight: #881122\nalert-muted-foreground: #b99e2f\nbackground: #ffffff\nblockquote-bar: <<colour muted-foreground>>\nbutton-background:\nbutton-foreground:\nbutton-border:\ncode-background: #f7f7f9\ncode-border: #e1e1e8\ncode-foreground: #dd1144\ndiff-delete-background: #ffc9c9\ndiff-delete-foreground: <<colour foreground>>\ndiff-equal-background: \ndiff-equal-foreground: <<colour foreground>>\ndiff-insert-background: #aaefad\ndiff-insert-foreground: <<colour foreground>>\ndiff-invisible-background: \ndiff-invisible-foreground: <<colour muted-foreground>>\ndirty-indicator: #ff0000\ndownload-background: #34c734\ndownload-foreground: <<colour background>>\ndragger-background: <<colour foreground>>\ndragger-foreground: <<colour background>>\ndropdown-background: <<colour background>>\ndropdown-border: <<colour muted-foreground>>\ndropdown-tab-background-selected: #fff\ndropdown-tab-background: #ececec\ndropzone-background: rgba(0,200,0,0.7)\nexternal-link-background-hover: inherit\nexternal-link-background-visited: inherit\nexternal-link-background: inherit\nexternal-link-foreground-hover: inherit\nexternal-link-foreground-visited: #0000aa\nexternal-link-foreground: #0000ee\nforeground: #333333\nmessage-background: #ecf2ff\nmessage-border: #cfd6e6\nmessage-foreground: #547599\nmodal-backdrop: <<colour foreground>>\nmodal-background: <<colour background>>\nmodal-border: #999999\nmodal-footer-background: #f5f5f5\nmodal-footer-border: #dddddd\nmodal-header-border: #eeeeee\nmuted-foreground: #bbb\nnotification-background: #ffffdd\nnotification-border: #999999\npage-background: #f4f4f4\npre-background: #f5f5f5\npre-border: #cccccc\nprimary: #5778d8\nselect-tag-background:\nselect-tag-foreground:\nsidebar-button-foreground: <<colour foreground>>\nsidebar-controls-foreground-hover: #000000\nsidebar-controls-foreground: #aaaaaa\nsidebar-foreground-shadow: rgba(255,255,255, 0.8)\nsidebar-foreground: #acacac\nsidebar-muted-foreground-hover: #444444\nsidebar-muted-foreground: #c0c0c0\nsidebar-tab-background-selected: #f4f4f4\nsidebar-tab-background: #e0e0e0\nsidebar-tab-border-selected: <<colour tab-border-selected>>\nsidebar-tab-border: <<colour tab-border>>\nsidebar-tab-divider: #e4e4e4\nsidebar-tab-foreground-selected:\nsidebar-tab-foreground: <<colour tab-foreground>>\nsidebar-tiddler-link-foreground-hover: #444444\nsidebar-tiddler-link-foreground: #999999\nsite-title-foreground: <<colour tiddler-title-foreground>>\nstatic-alert-foreground: #aaaaaa\ntab-background-selected: #ffffff\ntab-background: #d8d8d8\ntab-border-selected: #d8d8d8\ntab-border: #cccccc\ntab-divider: #d8d8d8\ntab-foreground-selected: <<colour tab-foreground>>\ntab-foreground: #666666\ntable-border: #dddddd\ntable-footer-background: #a8a8a8\ntable-header-background: #f0f0f0\ntag-background: #ec6\ntag-foreground: #ffffff\ntiddler-background: <<colour background>>\ntiddler-border: <<colour background>>\ntiddler-controls-foreground-hover: #888888\ntiddler-controls-foreground-selected: #444444\ntiddler-controls-foreground: #cccccc\ntiddler-editor-background: #f8f8f8\ntiddler-editor-border-image: #ffffff\ntiddler-editor-border: #cccccc\ntiddler-editor-fields-even: #e0e8e0\ntiddler-editor-fields-odd: #f0f4f0\ntiddler-info-background: #f8f8f8\ntiddler-info-border: #dddddd\ntiddler-info-tab-background: #f8f8f8\ntiddler-link-background: <<colour background>>\ntiddler-link-foreground: <<colour primary>>\ntiddler-subtitle-foreground: #c0c0c0\ntiddler-title-foreground: #182955\ntoolbar-new-button:\ntoolbar-options-button:\ntoolbar-save-button:\ntoolbar-info-button:\ntoolbar-edit-button:\ntoolbar-close-button:\ntoolbar-delete-button:\ntoolbar-cancel-button:\ntoolbar-done-button:\nuntagged-background: #999999\nvery-muted-foreground: #888888\n"
},
"$:/core/readme": {
"title": "$:/core/readme",
"text": "This plugin contains TiddlyWiki's core components, comprising:\n\n* JavaScript code modules\n* Icons\n* Templates needed to create TiddlyWiki's user interface\n* British English (''en-GB'') translations of the localisable strings used by the core\n"
},
"$:/library/sjcl.js/license": {
"title": "$:/library/sjcl.js/license",
"type": "text/plain",
"text": "SJCL is open. You can use, modify and redistribute it under a BSD\nlicense or under the GNU GPL, version 2.0.\n\n---------------------------------------------------------------------\n\nhttp://opensource.org/licenses/BSD-2-Clause\n\nCopyright (c) 2009-2015, Emily Stark, Mike Hamburg and Dan Boneh at\nStanford University. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without\nmodification, are permitted provided that the following conditions are\nmet:\n\n1. Redistributions of source code must retain the above copyright\nnotice, this list of conditions and the following disclaimer.\n\n2. Redistributions in binary form must reproduce the above copyright\nnotice, this list of conditions and the following disclaimer in the\ndocumentation and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS\nIS\" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED\nTO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A\nPARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT\nHOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,\nSPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED\nTO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR\nPROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\nLIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\nNEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n\n---------------------------------------------------------------------\n\nhttp://opensource.org/licenses/GPL-2.0\n\nThe Stanford Javascript Crypto Library (hosted here on GitHub) is a\nproject by the Stanford Computer Security Lab to build a secure,\npowerful, fast, small, easy-to-use, cross-browser library for\ncryptography in Javascript.\n\nCopyright (c) 2009-2015, Emily Stark, Mike Hamburg and Dan Boneh at\nStanford University.\n\nThis program is free software; you can redistribute it and/or modify it\nunder the terms of the GNU General Public License as published by the\nFree Software Foundation; either version 2 of the License, or (at your\noption) any later version.\n\nThis program is distributed in the hope that it will be useful, but\nWITHOUT ANY WARRANTY; without even the implied warranty of\nMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General\nPublic License for more details.\n\nYou should have received a copy of the GNU General Public License along\nwith this program; if not, write to the Free Software Foundation, Inc.,\n59 Temple Place, Suite 330, Boston, MA 02111-1307 USA"
},
"$:/core/templates/MOTW.html": {
"title": "$:/core/templates/MOTW.html",
"text": "\\rules only filteredtranscludeinline transcludeinline entity\n<!-- The following comment is called a MOTW comment and is necessary for the TiddlyIE Internet Explorer extension -->\n<!-- saved from url=(0021)https://tiddlywiki.com --> "
},
"$:/core/templates/alltiddlers.template.html": {
"title": "$:/core/templates/alltiddlers.template.html",
"type": "text/vnd.tiddlywiki-html",
"text": "<!-- This template is provided for backwards compatibility with older versions of TiddlyWiki -->\n\n<$set name=\"exportFilter\" value=\"[!is[system]sort[title]]\">\n\n{{$:/core/templates/exporters/StaticRiver}}\n\n</$set>\n"
},
"$:/core/templates/canonical-uri-external-image": {
"title": "$:/core/templates/canonical-uri-external-image",
"text": "<!--\n\nThis template is used to assign the ''_canonical_uri'' field to external images.\n\nChange the `./images/` part to a different base URI. The URI can be relative or absolute.\n\n-->\n./images/<$view field=\"title\" format=\"doubleurlencoded\"/>"
},
"$:/core/templates/canonical-uri-external-raw": {
"title": "$:/core/templates/canonical-uri-external-raw",
"text": "<!--\n\nThis template is used to assign the ''_canonical_uri'' field to external raw files that are stored in the same directory\n\n-->\n<$view field=\"title\" format=\"doubleurlencoded\"/>"
},
"$:/core/templates/canonical-uri-external-text": {
"title": "$:/core/templates/canonical-uri-external-text",
"text": "<!--\n\nThis template is used to assign the ''_canonical_uri'' field to external text files.\n\nChange the `./text/` part to a different base URI. The URI can be relative or absolute.\n\n-->\n./text/<$view field=\"title\" format=\"doubleurlencoded\"/>.tid"
},
"$:/core/templates/css-tiddler": {
"title": "$:/core/templates/css-tiddler",
"text": "<!--\n\nThis template is used for saving CSS tiddlers as a style tag with data attributes representing the tiddler fields.\n\n-->`<style`<$fields template=' data-tiddler-$name$=\"$encoded_value$\"'></$fields>` type=\"text/css\">`<$view field=\"text\" format=\"text\" />`</style>`"
},
"$:/core/templates/exporters/CsvFile": {
"title": "$:/core/templates/exporters/CsvFile",
"tags": "$:/tags/Exporter",
"description": "{{$:/language/Exporters/CsvFile}}",
"extension": ".csv",
"text": "\\define renderContent()\n<$text text=<<csvtiddlers filter:\"\"\"$(exportFilter)$\"\"\" format:\"quoted-comma-sep\">>/>\n\\end\n<<renderContent>>\n"
},
"$:/core/templates/exporters/JsonFile": {
"title": "$:/core/templates/exporters/JsonFile",
"tags": "$:/tags/Exporter",
"description": "{{$:/language/Exporters/JsonFile}}",
"extension": ".json",
"text": "\\define renderContent()\n<$text text=<<jsontiddlers filter:\"\"\"$(exportFilter)$\"\"\">>/>\n\\end\n<<renderContent>>\n"
},
"$:/core/templates/exporters/StaticRiver": {
"title": "$:/core/templates/exporters/StaticRiver",
"tags": "$:/tags/Exporter",
"description": "{{$:/language/Exporters/StaticRiver}}",
"extension": ".html",
"text": "\\define tv-wikilink-template() #$uri_encoded$\n\\define tv-config-toolbar-icons() no\n\\define tv-config-toolbar-text() no\n\\define tv-config-toolbar-class() tc-btn-invisible\n\\rules only filteredtranscludeinline transcludeinline\n<!doctype html>\n<html>\n<head>\n<meta http-equiv=\"Content-Type\" content=\"text/html;charset=utf-8\" />\n<meta name=\"generator\" content=\"TiddlyWiki\" />\n<meta name=\"tiddlywiki-version\" content=\"{{$:/core/templates/version}}\" />\n<meta name=\"format-detection\" content=\"telephone=no\">\n<link id=\"faviconLink\" rel=\"shortcut icon\" href=\"favicon.ico\">\n<title>{{$:/core/wiki/title}}</title>\n<div id=\"styleArea\">\n{{$:/boot/boot.css||$:/core/templates/css-tiddler}}\n</div>\n<style type=\"text/css\">\n{{$:/core/ui/PageStylesheet||$:/core/templates/wikified-tiddler}}\n</style>\n</head>\n<body class=\"tc-body\">\n{{$:/StaticBanner||$:/core/templates/html-tiddler}}\n<section class=\"tc-story-river\">\n{{$:/core/templates/exporters/StaticRiver/Content||$:/core/templates/html-tiddler}}\n</section>\n</body>\n</html>\n"
},
"$:/core/templates/exporters/StaticRiver/Content": {
"title": "$:/core/templates/exporters/StaticRiver/Content",
"text": "\\define renderContent()\n{{{ $(exportFilter)$ ||$:/core/templates/static-tiddler}}}\n\\end\n\\import [[$:/core/ui/PageMacros]] [all[shadows+tiddlers]tag[$:/tags/Macro]!has[draft.of]]\n<<renderContent>>\n"
},
"$:/core/templates/exporters/TidFile": {
"title": "$:/core/templates/exporters/TidFile",
"tags": "$:/tags/Exporter",
"description": "{{$:/language/Exporters/TidFile}}",
"extension": ".tid",
"text": "\\define renderContent()\n{{{ $(exportFilter)$ +[limit[1]] ||$:/core/templates/tid-tiddler}}}\n\\end\n\\import [[$:/core/ui/PageMacros]] [all[shadows+tiddlers]tag[$:/tags/Macro]!has[draft.of]]\n<<renderContent>>"
},
"$:/core/save/all-external-js": {
"title": "$:/core/save/all-external-js",
"text": "\\define saveTiddlerFilter()\n[is[tiddler]] -[prefix[$:/state/popup/]] -[[$:/HistoryList]] -[[$:/core]] -[[$:/boot/boot.css]] -[type[application/javascript]library[yes]] -[[$:/boot/boot.js]] -[[$:/boot/bootprefix.js]] +[sort[title]] $(publishFilter)$\n\\end\n{{$:/core/templates/tiddlywiki5-external-js.html}}\n"
},
"$:/core/templates/tiddlywiki5.js": {
"title": "$:/core/templates/tiddlywiki5.js",
"text": "\\rules only filteredtranscludeinline transcludeinline codeinline\n\n/*\n{{ $:/core/copyright.txt ||$:/core/templates/plain-text-tiddler}}\n`*/\n`<!--~~ Library modules ~~-->\n{{{ [is[system]type[application/javascript]library[yes]] ||$:/core/templates/plain-text-tiddler}}}\n<!--~~ Boot prefix ~~-->\n{{ $:/boot/bootprefix.js ||$:/core/templates/plain-text-tiddler}}\n<!--~~ Core plugin ~~-->\n{{$:/core/templates/tiddlywiki5.js/tiddlers}}\n<!--~~ Boot kernel ~~-->\n{{ $:/boot/boot.js ||$:/core/templates/plain-text-tiddler}}\n"
},
"$:/core/templates/tiddlywiki5.js/tiddlers": {
"title": "$:/core/templates/tiddlywiki5.js/tiddlers",
"text": "`\n$tw.preloadTiddlerArray(`<$text text=<<jsontiddlers \"[[$:/core]]\">>/>`);\n$tw.preloadTiddlerArray([{\n\ttitle: \"$:/config/SaveWikiButton/Template\",\n\ttext: \"$:/core/save/all-external-js\"\n}]);\n`\n"
},
"$:/core/templates/tiddlywiki5-external-js.html": {
"title": "$:/core/templates/tiddlywiki5-external-js.html",
"text": "\\rules only filteredtranscludeinline transcludeinline\n<!doctype html>\n{{$:/core/templates/MOTW.html}}<html>\n<head>\n<meta http-equiv=\"X-UA-Compatible\" content=\"IE=Edge\">\n<meta http-equiv=\"Content-Type\" content=\"text/html;charset=utf-8\" />\n<meta name=\"application-name\" content=\"TiddlyWiki\" />\n<meta name=\"generator\" content=\"TiddlyWiki\" />\n<meta name=\"tiddlywiki-version\" content=\"{{$:/core/templates/version}}\" />\n<meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\" />\n<meta name=\"apple-mobile-web-app-capable\" content=\"yes\" />\n<meta name=\"apple-mobile-web-app-status-bar-style\" content=\"black-translucent\" />\n<meta name=\"mobile-web-app-capable\" content=\"yes\"/>\n<meta name=\"format-detection\" content=\"telephone=no\" />\n<meta name=\"copyright\" content=\"{{$:/core/copyright.txt}}\" />\n<link id=\"faviconLink\" rel=\"shortcut icon\" href=\"favicon.ico\">\n<title>{{$:/core/wiki/title}}</title>\n<!--~~ This is a Tiddlywiki file. The points of interest in the file are marked with this pattern ~~-->\n\n<!--~~ Raw markup ~~-->\n{{{ [all[shadows+tiddlers]tag[$:/core/wiki/rawmarkup]] [all[shadows+tiddlers]tag[$:/tags/RawMarkup]] ||$:/core/templates/plain-text-tiddler}}}\n{{{ [all[shadows+tiddlers]tag[$:/tags/RawMarkupWikified]] ||$:/core/templates/raw-static-tiddler}}}\n</head>\n<body class=\"tc-body\">\n<!--~~ Static styles ~~-->\n<div id=\"styleArea\">\n{{$:/boot/boot.css||$:/core/templates/css-tiddler}}\n</div>\n<!--~~ Static content for Google and browsers without JavaScript ~~-->\n<noscript>\n<div id=\"splashArea\">\n{{$:/core/templates/static.area}}\n</div>\n</noscript>\n<!--~~ Ordinary tiddlers ~~-->\n{{$:/core/templates/store.area.template.html}}\n</body>\n<script src=\"%24%3A%2Fcore%2Ftemplates%2Ftiddlywiki5.js\" onerror=\"alert('Error: Cannot load tiddlywiki.js');\"></script>\n</html>\n"
},
"$:/core/templates/html-div-tiddler": {
"title": "$:/core/templates/html-div-tiddler",
"text": "<!--\n\nThis template is used for saving tiddlers as an HTML DIV tag with attributes representing the tiddler fields.\n\n-->`<div`<$fields template=' $name$=\"$encoded_value$\"'></$fields>`>\n<pre>`<$view field=\"text\" format=\"htmlencoded\" />`</pre>\n</div>`\n"
},
"$:/core/templates/html-tiddler": {
"title": "$:/core/templates/html-tiddler",
"text": "<!--\n\nThis template is used for saving tiddlers as raw HTML\n\n--><$view field=\"text\" format=\"htmlwikified\" />"
},
"$:/core/templates/javascript-tiddler": {
"title": "$:/core/templates/javascript-tiddler",
"text": "<!--\n\nThis template is used for saving JavaScript tiddlers as a script tag with data attributes representing the tiddler fields.\n\n-->`<script`<$fields template=' data-tiddler-$name$=\"$encoded_value$\"'></$fields>` type=\"text/javascript\">`<$view field=\"text\" format=\"text\" />`</script>`"
},
"$:/core/templates/json-tiddler": {
"title": "$:/core/templates/json-tiddler",
"text": "<!--\n\nThis template is used for saving tiddlers as raw JSON\n\n--><$text text=<<jsontiddler>>/>"
},
"$:/core/templates/module-tiddler": {
"title": "$:/core/templates/module-tiddler",
"text": "<!--\n\nThis template is used for saving JavaScript tiddlers as a script tag with data attributes representing the tiddler fields. The body of the tiddler is wrapped in a call to the `$tw.modules.define` function in order to define the body of the tiddler as a module\n\n-->`<script`<$fields template=' data-tiddler-$name$=\"$encoded_value$\"'></$fields>` type=\"text/javascript\" data-module=\"yes\">$tw.modules.define(\"`<$view field=\"title\" format=\"jsencoded\" />`\",\"`<$view field=\"module-type\" format=\"jsencoded\" />`\",function(module,exports,require) {`<$view field=\"text\" format=\"text\" />`});\n</script>`"
},
"$:/core/templates/plain-text-tiddler": {
"title": "$:/core/templates/plain-text-tiddler",
"text": "<$view field=\"text\" format=\"text\" />"
},
"$:/core/templates/raw-static-tiddler": {
"title": "$:/core/templates/raw-static-tiddler",
"text": "<!--\n\nThis template is used for saving tiddlers as static HTML\n\n--><$view field=\"text\" format=\"plainwikified\" />"
},
"$:/core/save/all": {
"title": "$:/core/save/all",
"text": "\\define saveTiddlerFilter()\n[is[tiddler]] -[prefix[$:/state/popup/]] -[[$:/HistoryList]] -[[$:/boot/boot.css]] -[type[application/javascript]library[yes]] -[[$:/boot/boot.js]] -[[$:/boot/bootprefix.js]] +[sort[title]] $(publishFilter)$\n\\end\n{{$:/core/templates/tiddlywiki5.html}}\n"
},
"$:/core/save/empty": {
"title": "$:/core/save/empty",
"text": "\\define saveTiddlerFilter()\n[is[system]] -[prefix[$:/state/popup/]] -[[$:/boot/boot.css]] -[type[application/javascript]library[yes]] -[[$:/boot/boot.js]] -[[$:/boot/bootprefix.js]] +[sort[title]]\n\\end\n{{$:/core/templates/tiddlywiki5.html}}\n"
},
"$:/core/save/lazy-all": {
"title": "$:/core/save/lazy-all",
"text": "\\define saveTiddlerFilter()\n[is[system]] -[prefix[$:/state/popup/]] -[[$:/HistoryList]] -[[$:/boot/boot.css]] -[type[application/javascript]library[yes]] -[[$:/boot/boot.js]] -[[$:/boot/bootprefix.js]] +[sort[title]] \n\\end\n{{$:/core/templates/tiddlywiki5.html}}\n"
},
"$:/core/save/lazy-images": {
"title": "$:/core/save/lazy-images",
"text": "\\define saveTiddlerFilter()\n[is[tiddler]] -[prefix[$:/state/popup/]] -[[$:/HistoryList]] -[[$:/boot/boot.css]] -[type[application/javascript]library[yes]] -[[$:/boot/boot.js]] -[[$:/boot/bootprefix.js]] -[!is[system]is[image]] +[sort[title]] \n\\end\n{{$:/core/templates/tiddlywiki5.html}}\n"
},
"$:/core/templates/server/static.sidebar.wikitext": {
"title": "$:/core/templates/server/static.sidebar.wikitext",
"text": "\\whitespace trim\n<div class=\"tc-sidebar-scrollable\" style=\"overflow: auto;\">\n<div class=\"tc-sidebar-header\">\n<h1 class=\"tc-site-title\">\n<$transclude tiddler=\"$:/SiteTitle\"/>\n</h1>\n<div class=\"tc-site-subtitle\">\n<$transclude tiddler=\"$:/SiteSubtitle\"/>\n</div>\n<h2>\n</h2>\n<div class=\"tc-sidebar-lists\">\n<$list filter={{$:/DefaultTiddlers}}>\n<div class=\"tc-menu-list-subitem\">\n<$link><$text text=<<currentTiddler>>/></$link>\n</div>\n</$list>\n</div>\n<!-- Currently disabled the recent list as it is unweildy when the responsive narrow view kicks in\n<h2>\n{{$:/language/SideBar/Recent/Caption}}\n</h2>\n<div class=\"tc-sidebar-lists\">\n<$macrocall $name=\"timeline\" format={{$:/language/RecentChanges/DateFormat}}/>\n</div>\n</div>\n</div>\n-->\n"
},
"$:/core/templates/server/static.tiddler.html": {
"title": "$:/core/templates/server/static.tiddler.html",
"text": "\\whitespace trim\n\\define tv-wikilink-template() $uri_encoded$\n\\import [[$:/core/ui/PageMacros]] [all[shadows+tiddlers]tag[$:/tags/Macro]!has[draft.of]]\n<html>\n<head>\n<meta http-equiv=\"Content-Type\" content=\"text/html;charset=utf-8\" />\n<meta name=\"generator\" content=\"TiddlyWiki\" />\n<meta name=\"tiddlywiki-version\" content={{$:/core/templates/version}} />\n<meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\" />\n<meta name=\"apple-mobile-web-app-capable\" content=\"yes\" />\n<meta name=\"apple-mobile-web-app-status-bar-style\" content=\"black-translucent\" />\n<meta name=\"mobile-web-app-capable\" content=\"yes\"/>\n<meta name=\"format-detection\" content=\"telephone=no\">\n<link id=\"faviconLink\" rel=\"shortcut icon\" href=\"favicon.ico\">\n<link rel=\"stylesheet\" href=\"%24%3A%2Fcore%2Ftemplates%2Fstatic.template.css\">\n<title><$view field=\"caption\" format=\"plainwikified\"><$view field=\"title\"/></$view>: <$view tiddler=\"$:/core/wiki/title\" format=\"plainwikified\"/></title>\n</head>\n<body class=\"tc-body\">\n<$transclude tiddler=\"$:/core/templates/server/static.sidebar.wikitext\" mode=\"inline\"/>\n<section class=\"tc-story-river\">\n<div class=\"tc-tiddler-frame\">\n<$transclude tiddler=\"$:/core/templates/server/static.tiddler.wikitext\" mode=\"inline\"/>\n</div>\n</section>\n</body>\n</html>"
},
"$:/core/templates/server/static.tiddler.wikitext": {
"title": "$:/core/templates/server/static.tiddler.wikitext",
"text": "\\whitespace trim\n<div class=\"tc-tiddler-title\">\n<div class=\"tc-titlebar\">\n<h2><$text text=<<currentTiddler>>/></h2>\n</div>\n</div>\n<div class=\"tc-subtitle\">\n<$link to={{!!modifier}}>\n<$view field=\"modifier\"/>\n</$link> <$view field=\"modified\" format=\"date\" template={{$:/language/Tiddler/DateFormat}}/>\n</div>\n<div class=\"tc-tags-wrapper\">\n<$list filter=\"[all[current]tags[]sort[title]]\">\n<a href={{{ [<currentTiddler>encodeuricomponent[]] }}}>\n<$macrocall $name=\"tag-pill\" tag=<<currentTiddler>>/>\n</a>\n</$list>\n</div>\n<div class=\"tc-tiddler-body\">\n<$transclude mode=\"block\"/>\n</div>\n"
},
"$:/core/templates/single.tiddler.window": {
"title": "$:/core/templates/single.tiddler.window",
"text": "<$set name=\"themeTitle\" value={{$:/view}}>\n\n<$set name=\"tempCurrentTiddler\" value=<<currentTiddler>>>\n\n<$set name=\"currentTiddler\" value={{$:/language}}>\n\n<$set name=\"languageTitle\" value={{!!name}}>\n\n<$set name=\"currentTiddler\" value=<<tempCurrentTiddler>>>\n\n<$importvariables filter=\"[[$:/core/ui/PageMacros]] [all[shadows+tiddlers]tag[$:/tags/Macro]!has[draft.of]]\">\n\n<$navigator story=\"$:/StoryList\" history=\"$:/HistoryList\">\n\n<$transclude mode=\"block\"/>\n\n</$navigator>\n\n</$importvariables>\n\n</$set>\n\n</$set>\n\n</$set>\n\n</$set>\n\n</$set>\n\n"
},
"$:/core/templates/split-recipe": {
"title": "$:/core/templates/split-recipe",
"text": "<$list filter=\"[!is[system]]\">\ntiddler: <$view field=\"title\" format=\"urlencoded\"/>.tid\n</$list>\n"
},
"$:/core/templates/static-tiddler": {
"title": "$:/core/templates/static-tiddler",
"text": "<a name=<<currentTiddler>>>\n<$transclude tiddler=\"$:/core/ui/ViewTemplate\"/>\n</a>"
},
"$:/core/templates/static.area": {
"title": "$:/core/templates/static.area",
"text": "<$reveal type=\"nomatch\" state=\"$:/isEncrypted\" text=\"yes\">\n{{{ [all[shadows+tiddlers]tag[$:/tags/RawStaticContent]!has[draft.of]] ||$:/core/templates/raw-static-tiddler}}}\n{{$:/core/templates/static.content||$:/core/templates/html-tiddler}}\n</$reveal>\n<$reveal type=\"match\" state=\"$:/isEncrypted\" text=\"yes\">\nThis file contains an encrypted ~TiddlyWiki. Enable ~JavaScript and enter the decryption password when prompted.\n</$reveal>\n"
},
"$:/core/templates/static.content": {
"title": "$:/core/templates/static.content",
"text": "<!-- For Google, and people without JavaScript-->\nThis [[TiddlyWiki|https://tiddlywiki.com]] contains the following tiddlers:\n\n<ul>\n<$list filter=<<saveTiddlerFilter>>>\n<li><$view field=\"title\" format=\"text\"></$view></li>\n</$list>\n</ul>\n"
},
"$:/core/templates/static.template.css": {
"title": "$:/core/templates/static.template.css",
"text": "{{$:/boot/boot.css||$:/core/templates/plain-text-tiddler}}\n\n{{$:/core/ui/PageStylesheet||$:/core/templates/wikified-tiddler}}\n"
},
"$:/core/templates/static.template.html": {
"title": "$:/core/templates/static.template.html",
"type": "text/vnd.tiddlywiki-html",
"text": "\\define tv-wikilink-template() static/$uri_doubleencoded$.html\n\\define tv-config-toolbar-icons() no\n\\define tv-config-toolbar-text() no\n\\define tv-config-toolbar-class() tc-btn-invisible\n\\rules only filteredtranscludeinline transcludeinline\n<!doctype html>\n<html>\n<head>\n<meta http-equiv=\"Content-Type\" content=\"text/html;charset=utf-8\" />\n<meta name=\"generator\" content=\"TiddlyWiki\" />\n<meta name=\"tiddlywiki-version\" content=\"{{$:/core/templates/version}}\" />\n<meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\" />\n<meta name=\"apple-mobile-web-app-capable\" content=\"yes\" />\n<meta name=\"apple-mobile-web-app-status-bar-style\" content=\"black-translucent\" />\n<meta name=\"mobile-web-app-capable\" content=\"yes\"/>\n<meta name=\"format-detection\" content=\"telephone=no\">\n<link id=\"faviconLink\" rel=\"shortcut icon\" href=\"favicon.ico\">\n<title>{{$:/core/wiki/title}}</title>\n<div id=\"styleArea\">\n{{$:/boot/boot.css||$:/core/templates/css-tiddler}}\n</div>\n<style type=\"text/css\">\n{{$:/core/ui/PageStylesheet||$:/core/templates/wikified-tiddler}}\n</style>\n</head>\n<body class=\"tc-body\">\n{{$:/StaticBanner||$:/core/templates/html-tiddler}}\n{{$:/core/ui/PageTemplate||$:/core/templates/html-tiddler}}\n</body>\n</html>\n"
},
"$:/core/templates/static.tiddler.html": {
"title": "$:/core/templates/static.tiddler.html",
"text": "\\define tv-wikilink-template() $uri_doubleencoded$.html\n\\define tv-config-toolbar-icons() no\n\\define tv-config-toolbar-text() no\n\\define tv-config-toolbar-class() tc-btn-invisible\n\\import [[$:/core/ui/PageMacros]] [all[shadows+tiddlers]tag[$:/tags/Macro]!has[draft.of]]\n`<!doctype html>\n<html>\n<head>\n<meta http-equiv=\"Content-Type\" content=\"text/html;charset=utf-8\" />\n<meta name=\"generator\" content=\"TiddlyWiki\" />\n<meta name=\"tiddlywiki-version\" content=\"`{{$:/core/templates/version}}`\" />\n<meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\" />\n<meta name=\"apple-mobile-web-app-capable\" content=\"yes\" />\n<meta name=\"apple-mobile-web-app-status-bar-style\" content=\"black-translucent\" />\n<meta name=\"mobile-web-app-capable\" content=\"yes\"/>\n<meta name=\"format-detection\" content=\"telephone=no\">\n<link id=\"faviconLink\" rel=\"shortcut icon\" href=\"favicon.ico\">\n<link rel=\"stylesheet\" href=\"static.css\">\n<title>`<$view field=\"caption\"><$view field=\"title\"/></$view>: {{$:/core/wiki/title}}`</title>\n</head>\n<body class=\"tc-body\">\n`{{$:/StaticBanner||$:/core/templates/html-tiddler}}`\n<section class=\"tc-story-river\">\n`<$view tiddler=\"$:/core/ui/ViewTemplate\" format=\"htmlwikified\"/>`\n</section>\n</body>\n</html>\n`"
},
"$:/core/templates/store.area.template.html": {
"title": "$:/core/templates/store.area.template.html",
"text": "<$reveal type=\"nomatch\" state=\"$:/isEncrypted\" text=\"yes\">\n`<div id=\"storeArea\" style=\"display:none;\">`\n<$list filter=<<saveTiddlerFilter>> template=\"$:/core/templates/html-div-tiddler\"/>\n`</div>`\n</$reveal>\n<$reveal type=\"match\" state=\"$:/isEncrypted\" text=\"yes\">\n`<!--~~ Encrypted tiddlers ~~-->`\n`<pre id=\"encryptedStoreArea\" type=\"text/plain\" style=\"display:none;\">`\n<$encrypt filter=<<saveTiddlerFilter>>/>\n`</pre>`\n</$reveal>"
},
"$:/core/templates/tid-tiddler": {
"title": "$:/core/templates/tid-tiddler",
"text": "<!--\n\nThis template is used for saving tiddlers in TiddlyWeb *.tid format\n\n--><$fields exclude='text bag' template='$name$: $value$\n'></$fields>`\n`<$view field=\"text\" format=\"text\" />"
},
"$:/core/templates/tiddler-metadata": {
"title": "$:/core/templates/tiddler-metadata",
"text": "<!--\n\nThis template is used for saving tiddler metadata *.meta files\n\n--><$fields exclude='text bag' template='$name$: $value$\n'></$fields>"
},
"$:/core/templates/tiddlywiki5.html": {
"title": "$:/core/templates/tiddlywiki5.html",
"text": "\\rules only filteredtranscludeinline transcludeinline\n<!doctype html>\n{{$:/core/templates/MOTW.html}}<html>\n<head>\n<meta http-equiv=\"Content-Type\" content=\"text/html;charset=utf-8\" />\n<!--~~ Raw markup for the top of the head section ~~-->\n{{{ [all[shadows+tiddlers]tag[$:/tags/RawMarkupWikified/TopHead]] ||$:/core/templates/raw-static-tiddler}}}\n<meta http-equiv=\"X-UA-Compatible\" content=\"IE=Edge\"/>\n<meta name=\"application-name\" content=\"TiddlyWiki\" />\n<meta name=\"generator\" content=\"TiddlyWiki\" />\n<meta name=\"tiddlywiki-version\" content=\"{{$:/core/templates/version}}\" />\n<meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\" />\n<meta name=\"apple-mobile-web-app-capable\" content=\"yes\" />\n<meta name=\"apple-mobile-web-app-status-bar-style\" content=\"black-translucent\" />\n<meta name=\"mobile-web-app-capable\" content=\"yes\"/>\n<meta name=\"format-detection\" content=\"telephone=no\" />\n<meta name=\"copyright\" content=\"{{$:/core/copyright.txt}}\" />\n<link id=\"faviconLink\" rel=\"shortcut icon\" href=\"favicon.ico\">\n<title>{{$:/core/wiki/title}}</title>\n<!--~~ This is a Tiddlywiki file. The points of interest in the file are marked with this pattern ~~-->\n\n<!--~~ Raw markup ~~-->\n{{{ [all[shadows+tiddlers]tag[$:/core/wiki/rawmarkup]] [all[shadows+tiddlers]tag[$:/tags/RawMarkup]] ||$:/core/templates/plain-text-tiddler}}}\n{{{ [all[shadows+tiddlers]tag[$:/tags/RawMarkupWikified]] ||$:/core/templates/raw-static-tiddler}}}\n</head>\n<body class=\"tc-body\">\n<!--~~ Raw markup for the top of the body section ~~-->\n{{{ [all[shadows+tiddlers]tag[$:/tags/RawMarkupWikified/TopBody]] ||$:/core/templates/raw-static-tiddler}}}\n<!--~~ Static styles ~~-->\n<div id=\"styleArea\">\n{{$:/boot/boot.css||$:/core/templates/css-tiddler}}\n</div>\n<!--~~ Static content for Google and browsers without JavaScript ~~-->\n<noscript>\n<div id=\"splashArea\">\n{{$:/core/templates/static.area}}\n</div>\n</noscript>\n<!--~~ Ordinary tiddlers ~~-->\n{{$:/core/templates/store.area.template.html}}\n<!--~~ Library modules ~~-->\n<div id=\"libraryModules\" style=\"display:none;\">\n{{{ [is[system]type[application/javascript]library[yes]] ||$:/core/templates/javascript-tiddler}}}\n</div>\n<!--~~ Boot kernel prologue ~~-->\n<div id=\"bootKernelPrefix\" style=\"display:none;\">\n{{ $:/boot/bootprefix.js ||$:/core/templates/javascript-tiddler}}\n</div>\n<!--~~ Boot kernel ~~-->\n<div id=\"bootKernel\" style=\"display:none;\">\n{{ $:/boot/boot.js ||$:/core/templates/javascript-tiddler}}\n</div>\n<!--~~ Raw markup for the bottom of the body section ~~-->\n{{{ [all[shadows+tiddlers]tag[$:/tags/RawMarkupWikified/BottomBody]] ||$:/core/templates/raw-static-tiddler}}}\n</body>\n</html>\n"
},
"$:/core/templates/version": {
"title": "$:/core/templates/version",
"text": "<<version>>"
},
"$:/core/templates/wikified-tiddler": {
"title": "$:/core/templates/wikified-tiddler",
"text": "<$transclude />"
},
"$:/core/ui/AboveStory/tw2-plugin-check": {
"title": "$:/core/ui/AboveStory/tw2-plugin-check",
"tags": "$:/tags/AboveStory",
"text": "\\define lingo-base() $:/language/AboveStory/ClassicPlugin/\n<$list filter=\"[all[system+tiddlers]tag[systemConfig]limit[1]]\">\n\n<div class=\"tc-message-box\">\n\n<<lingo Warning>>\n\n<ul>\n\n<$list filter=\"[all[system+tiddlers]tag[systemConfig]]\">\n\n<li>\n\n<$link><$view field=\"title\"/></$link>\n\n</li>\n\n</$list>\n\n</ul>\n\n</div>\n\n</$list>\n"
},
"$:/core/ui/Actions/new-image": {
"title": "$:/core/ui/Actions/new-image",
"tags": "$:/tags/Actions",
"description": "create a new image tiddler",
"text": "\\define get-type()\nimage/$(imageType)$\n\\end\n<$vars imageType={{$:/config/NewImageType}}>\n<$action-sendmessage $message=\"tm-new-tiddler\" type=<<get-type>>/>\n</$vars>\n"
},
"$:/core/ui/Actions/new-journal": {
"title": "$:/core/ui/Actions/new-journal",
"tags": "$:/tags/Actions",
"description": "create a new journal tiddler",
"text": "<$vars journalTitleTemplate={{$:/config/NewJournal/Title}} journalTags={{$:/config/NewJournal/Tags}} journalText={{$:/config/NewJournal/Text}}>\n<$wikify name=\"journalTitle\" text=\"\"\"<$macrocall $name=\"now\" format=<<journalTitleTemplate>>/>\"\"\">\n<$reveal type=\"nomatch\" state=<<journalTitle>> text=\"\">\n<$action-sendmessage $message=\"tm-new-tiddler\" title=<<journalTitle>> tags=<<journalTags>> text={{{ [<journalTitle>get[]] }}}/>\n</$reveal>\n<$reveal type=\"match\" state=<<journalTitle>> text=\"\">\n<$action-sendmessage $message=\"tm-new-tiddler\" title=<<journalTitle>> tags=<<journalTags>> text=<<journalText>>/>\n</$reveal>\n</$wikify>\n</$vars>\n"
},
"$:/core/ui/Actions/new-tiddler": {
"title": "$:/core/ui/Actions/new-tiddler",
"tags": "$:/tags/Actions",
"description": "create a new empty tiddler",
"text": "<$action-sendmessage $message=\"tm-new-tiddler\"/>\n"
},
"$:/core/ui/AdvancedSearch/Filter": {
"title": "$:/core/ui/AdvancedSearch/Filter",
"tags": "$:/tags/AdvancedSearch",
"caption": "{{$:/language/Search/Filter/Caption}}",
"text": "\\define lingo-base() $:/language/Search/\n<<lingo Filter/Hint>>\n\n<div class=\"tc-search tc-advanced-search\">\n<$edit-text tiddler=\"$:/temp/advancedsearch\" type=\"search\" tag=\"input\"/>\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/AdvancedSearch/FilterButton]!has[draft.of]]\"><$transclude/></$list>\n</div>\n\n<$reveal state=\"$:/temp/advancedsearch\" type=\"nomatch\" text=\"\">\n<$set name=\"resultCount\" value=\"\"\"<$count filter={{$:/temp/advancedsearch}}/>\"\"\">\n<div class=\"tc-search-results\">\n<<lingo Filter/Matches>>\n<$list filter={{$:/temp/advancedsearch}} template=\"$:/core/ui/ListItemTemplate\"/>\n</div>\n</$set>\n</$reveal>\n"
},
"$:/core/ui/AdvancedSearch/Filter/FilterButtons/clear": {
"title": "$:/core/ui/AdvancedSearch/Filter/FilterButtons/clear",
"tags": "$:/tags/AdvancedSearch/FilterButton",
"text": "<$reveal state=\"$:/temp/advancedsearch\" type=\"nomatch\" text=\"\">\n<$button class=\"tc-btn-invisible\">\n<$action-setfield $tiddler=\"$:/temp/advancedsearch\" $field=\"text\" $value=\"\"/>\n{{$:/core/images/close-button}}\n</$button>\n</$reveal>\n"
},
"$:/core/ui/AdvancedSearch/Filter/FilterButtons/delete": {
"title": "$:/core/ui/AdvancedSearch/Filter/FilterButtons/delete",
"tags": "$:/tags/AdvancedSearch/FilterButton",
"text": "<$reveal state=\"$:/temp/advancedsearch\" type=\"nomatch\" text=\"\">\n<$button popup=<<qualify \"$:/state/filterDeleteDropdown\">> class=\"tc-btn-invisible\">\n{{$:/core/images/delete-button}}\n</$button>\n</$reveal>\n\n<$reveal state=<<qualify \"$:/state/filterDeleteDropdown\">> type=\"popup\" position=\"belowleft\" animate=\"yes\">\n<div class=\"tc-block-dropdown-wrapper\">\n<div class=\"tc-block-dropdown tc-edit-type-dropdown\">\n<div class=\"tc-dropdown-item-plain\">\n<$set name=\"resultCount\" value=\"\"\"<$count filter={{$:/temp/advancedsearch}}/>\"\"\">\nAre you sure you wish to delete <<resultCount>> tiddler(s)?\n</$set>\n</div>\n<div class=\"tc-dropdown-item-plain\">\n<$button class=\"tc-btn\">\n<$action-deletetiddler $filter={{$:/temp/advancedsearch}}/>\nDelete these tiddlers\n</$button>\n</div>\n</div>\n</div>\n</$reveal>\n"
},
"$:/core/ui/AdvancedSearch/Filter/FilterButtons/dropdown": {
"title": "$:/core/ui/AdvancedSearch/Filter/FilterButtons/dropdown",
"tags": "$:/tags/AdvancedSearch/FilterButton",
"text": "<span class=\"tc-popup-keep\">\n<$button popup=<<qualify \"$:/state/filterDropdown\">> class=\"tc-btn-invisible\">\n{{$:/core/images/down-arrow}}\n</$button>\n</span>\n\n<$reveal state=<<qualify \"$:/state/filterDropdown\">> type=\"popup\" position=\"belowleft\" animate=\"yes\">\n<$set name=\"tv-show-missing-links\" value=\"yes\">\n<$linkcatcher to=\"$:/temp/advancedsearch\">\n<div class=\"tc-block-dropdown-wrapper\">\n<div class=\"tc-block-dropdown tc-edit-type-dropdown\">\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/Filter]]\"><$link to={{!!filter}}><$transclude field=\"description\"/></$link>\n</$list>\n</div>\n</div>\n</$linkcatcher>\n</$set>\n</$reveal>\n"
},
"$:/core/ui/AdvancedSearch/Filter/FilterButtons/export": {
"title": "$:/core/ui/AdvancedSearch/Filter/FilterButtons/export",
"tags": "$:/tags/AdvancedSearch/FilterButton",
"text": "<$reveal state=\"$:/temp/advancedsearch\" type=\"nomatch\" text=\"\">\n<$macrocall $name=\"exportButton\" exportFilter={{$:/temp/advancedsearch}} lingoBase=\"$:/language/Buttons/ExportTiddlers/\"/>\n</$reveal>\n"
},
"$:/core/ui/AdvancedSearch/Shadows": {
"title": "$:/core/ui/AdvancedSearch/Shadows",
"tags": "$:/tags/AdvancedSearch",
"caption": "{{$:/language/Search/Shadows/Caption}}",
"text": "\\define lingo-base() $:/language/Search/\n<$linkcatcher to=\"$:/temp/advancedsearch\">\n\n<<lingo Shadows/Hint>>\n\n<div class=\"tc-search\">\n<$edit-text tiddler=\"$:/temp/advancedsearch\" type=\"search\" tag=\"input\"/>\n<$reveal state=\"$:/temp/advancedsearch\" type=\"nomatch\" text=\"\">\n<$button class=\"tc-btn-invisible\">\n<$action-setfield $tiddler=\"$:/temp/advancedsearch\" $field=\"text\" $value=\"\"/>\n{{$:/core/images/close-button}}\n</$button>\n</$reveal>\n</div>\n\n</$linkcatcher>\n\n<$reveal state=\"$:/temp/advancedsearch\" type=\"nomatch\" text=\"\">\n\n<$list filter=\"[{$:/temp/advancedsearch}minlength{$:/config/Search/MinLength}limit[1]]\" emptyMessage=\"\"\"<div class=\"tc-search-results\">{{$:/language/Search/Search/TooShort}}</div>\"\"\" variable=\"listItem\">\n\n<$set name=\"resultCount\" value=\"\"\"<$count filter=\"[all[shadows]search{$:/temp/advancedsearch}] -[[$:/temp/advancedsearch]]\"/>\"\"\">\n\n<div class=\"tc-search-results\">\n\n<<lingo Shadows/Matches>>\n\n<$list filter=\"[all[shadows]search{$:/temp/advancedsearch}sort[title]limit[250]] -[[$:/temp/advancedsearch]]\" template=\"$:/core/ui/ListItemTemplate\"/>\n\n</div>\n\n</$set>\n\n</$list>\n\n</$reveal>\n\n<$reveal state=\"$:/temp/advancedsearch\" type=\"match\" text=\"\">\n\n</$reveal>\n"
},
"$:/core/ui/AdvancedSearch/Standard": {
"title": "$:/core/ui/AdvancedSearch/Standard",
"tags": "$:/tags/AdvancedSearch",
"caption": "{{$:/language/Search/Standard/Caption}}",
"text": "\\define lingo-base() $:/language/Search/\n<$linkcatcher to=\"$:/temp/advancedsearch\">\n\n<<lingo Standard/Hint>>\n\n<div class=\"tc-search\">\n<$edit-text tiddler=\"$:/temp/advancedsearch\" type=\"search\" tag=\"input\"/>\n<$reveal state=\"$:/temp/advancedsearch\" type=\"nomatch\" text=\"\">\n<$button class=\"tc-btn-invisible\">\n<$action-setfield $tiddler=\"$:/temp/advancedsearch\" $field=\"text\" $value=\"\"/>\n{{$:/core/images/close-button}}\n</$button>\n</$reveal>\n</div>\n\n</$linkcatcher>\n\n<$reveal state=\"$:/temp/advancedsearch\" type=\"nomatch\" text=\"\">\n<$list filter=\"[{$:/temp/advancedsearch}minlength{$:/config/Search/MinLength}limit[1]]\" emptyMessage=\"\"\"<div class=\"tc-search-results\">{{$:/language/Search/Search/TooShort}}</div>\"\"\" variable=\"listItem\">\n<$set name=\"searchTiddler\" value=\"$:/temp/advancedsearch\">\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/SearchResults]!has[draft.of]butfirst[]limit[1]]\" emptyMessage=\"\"\"\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/SearchResults]!has[draft.of]]\">\n<$transclude/>\n</$list>\n\"\"\">\n<$macrocall $name=\"tabs\" tabsList=\"[all[shadows+tiddlers]tag[$:/tags/SearchResults]!has[draft.of]]\" default={{$:/config/SearchResults/Default}}/>\n</$list>\n</$set>\n</$list>\n</$reveal>\n"
},
"$:/core/ui/AdvancedSearch/System": {
"title": "$:/core/ui/AdvancedSearch/System",
"tags": "$:/tags/AdvancedSearch",
"caption": "{{$:/language/Search/System/Caption}}",
"text": "\\define lingo-base() $:/language/Search/\n<$linkcatcher to=\"$:/temp/advancedsearch\">\n\n<<lingo System/Hint>>\n\n<div class=\"tc-search\">\n<$edit-text tiddler=\"$:/temp/advancedsearch\" type=\"search\" tag=\"input\"/>\n<$reveal state=\"$:/temp/advancedsearch\" type=\"nomatch\" text=\"\">\n<$button class=\"tc-btn-invisible\">\n<$action-setfield $tiddler=\"$:/temp/advancedsearch\" $field=\"text\" $value=\"\"/>\n{{$:/core/images/close-button}}\n</$button>\n</$reveal>\n</div>\n\n</$linkcatcher>\n\n<$reveal state=\"$:/temp/advancedsearch\" type=\"nomatch\" text=\"\">\n\n<$list filter=\"[{$:/temp/advancedsearch}minlength{$:/config/Search/MinLength}limit[1]]\" emptyMessage=\"\"\"<div class=\"tc-search-results\">{{$:/language/Search/Search/TooShort}}</div>\"\"\" variable=\"listItem\">\n\n<$set name=\"resultCount\" value=\"\"\"<$count filter=\"[is[system]search{$:/temp/advancedsearch}] -[[$:/temp/advancedsearch]]\"/>\"\"\">\n\n<div class=\"tc-search-results\">\n\n<<lingo System/Matches>>\n\n<$list filter=\"[is[system]search{$:/temp/advancedsearch}sort[title]limit[250]] -[[$:/temp/advancedsearch]]\" template=\"$:/core/ui/ListItemTemplate\"/>\n\n</div>\n\n</$set>\n\n</$list>\n\n</$reveal>\n\n<$reveal state=\"$:/temp/advancedsearch\" type=\"match\" text=\"\">\n\n</$reveal>\n"
},
"$:/AdvancedSearch": {
"title": "$:/AdvancedSearch",
"icon": "$:/core/images/advanced-search-button",
"color": "#bbb",
"text": "<div class=\"tc-advanced-search\">\n<<tabs \"[all[shadows+tiddlers]tag[$:/tags/AdvancedSearch]!has[draft.of]]\" \"$:/core/ui/AdvancedSearch/System\">>\n</div>\n"
},
"$:/core/ui/AlertTemplate": {
"title": "$:/core/ui/AlertTemplate",
"text": "<div class=\"tc-alert\">\n<div class=\"tc-alert-toolbar\">\n<$button class=\"tc-btn-invisible\"><$action-deletetiddler $tiddler=<<currentTiddler>>/>{{$:/core/images/delete-button}}</$button>\n</div>\n<div class=\"tc-alert-subtitle\">\n<$view field=\"component\"/> - <$view field=\"modified\" format=\"date\" template=\"0hh:0mm:0ss DD MM YYYY\"/> <$reveal type=\"nomatch\" state=\"!!count\" text=\"\"><span class=\"tc-alert-highlight\">({{$:/language/Count}}: <$view field=\"count\"/>)</span></$reveal>\n</div>\n<div class=\"tc-alert-body\">\n\n<$transclude/>\n\n</div>\n</div>\n"
},
"$:/core/ui/BinaryWarning": {
"title": "$:/core/ui/BinaryWarning",
"text": "\\define lingo-base() $:/language/BinaryWarning/\n<div class=\"tc-binary-warning\">\n\n<<lingo Prompt>>\n\n</div>\n"
},
"$:/core/ui/Components/plugin-info": {
"title": "$:/core/ui/Components/plugin-info",
"text": "\\define lingo-base() $:/language/ControlPanel/Plugins/\n\n\\define popup-state-macro()\n$(qualified-state)$-$(currentTiddler)$\n\\end\n\n\\define tabs-state-macro()\n$(popup-state)$-$(pluginInfoType)$\n\\end\n\n\\define plugin-icon-title()\n$(currentTiddler)$/icon\n\\end\n\n\\define plugin-disable-title()\n$:/config/Plugins/Disabled/$(currentTiddler)$\n\\end\n\n\\define plugin-table-body(type,disabledMessage,default-popup-state)\n<div class=\"tc-plugin-info-chunk tc-small-icon\">\n<$reveal type=\"nomatch\" state=<<popup-state>> text=\"yes\" default=\"\"\"$default-popup-state$\"\"\">\n<$button class=\"tc-btn-invisible tc-btn-dropdown\" set=<<popup-state>> setTo=\"yes\">\n{{$:/core/images/right-arrow}}\n</$button>\n</$reveal>\n<$reveal type=\"match\" state=<<popup-state>> text=\"yes\" default=\"\"\"$default-popup-state$\"\"\">\n<$button class=\"tc-btn-invisible tc-btn-dropdown\" set=<<popup-state>> setTo=\"no\">\n{{$:/core/images/down-arrow}}\n</$button>\n</$reveal>\n</div>\n<div class=\"tc-plugin-info-chunk\">\n<$transclude tiddler=<<currentTiddler>> subtiddler=<<plugin-icon-title>>>\n<$transclude tiddler=\"$:/core/images/plugin-generic-$type$\"/>\n</$transclude>\n</div>\n<div class=\"tc-plugin-info-chunk\">\n<h1>\n''<$view field=\"description\"><$view field=\"title\"/></$view>'' $disabledMessage$\n</h1>\n<h2>\n<$view field=\"title\"/>\n</h2>\n<h2>\n<div><em><$view field=\"version\"/></em></div>\n</h2>\n</div>\n\\end\n\n\\define plugin-info(type,default-popup-state)\n<$set name=\"popup-state\" value=<<popup-state-macro>>>\n<$reveal type=\"nomatch\" state=<<plugin-disable-title>> text=\"yes\">\n<$link to={{!!title}} class=\"tc-plugin-info\">\n<<plugin-table-body type:\"$type$\" default-popup-state:\"\"\"$default-popup-state$\"\"\">>\n</$link>\n</$reveal>\n<$reveal type=\"match\" state=<<plugin-disable-title>> text=\"yes\">\n<$link to={{!!title}} class=\"tc-plugin-info tc-plugin-info-disabled\">\n<<plugin-table-body type:\"$type$\" default-popup-state:\"\"\"$default-popup-state$\"\"\" disabledMessage:\"<$macrocall $name='lingo' title='Disabled/Status'/>\">>\n</$link>\n</$reveal>\n<$reveal type=\"match\" text=\"yes\" state=<<popup-state>> default=\"\"\"$default-popup-state$\"\"\">\n<div class=\"tc-plugin-info-dropdown\">\n<div class=\"tc-plugin-info-dropdown-body\">\n<$list filter=\"[all[current]] -[[$:/core]]\">\n<div style=\"float:right;\">\n<$reveal type=\"nomatch\" state=<<plugin-disable-title>> text=\"yes\">\n<$button set=<<plugin-disable-title>> setTo=\"yes\" tooltip={{$:/language/ControlPanel/Plugins/Disable/Hint}} aria-label={{$:/language/ControlPanel/Plugins/Disable/Caption}}>\n<<lingo Disable/Caption>>\n</$button>\n</$reveal>\n<$reveal type=\"match\" state=<<plugin-disable-title>> text=\"yes\">\n<$button set=<<plugin-disable-title>> setTo=\"no\" tooltip={{$:/language/ControlPanel/Plugins/Enable/Hint}} aria-label={{$:/language/ControlPanel/Plugins/Enable/Caption}}>\n<<lingo Enable/Caption>>\n</$button>\n</$reveal>\n</div>\n</$list>\n<$set name=\"tabsList\" filter=\"[<currentTiddler>list[]] contents\">\n<$macrocall $name=\"tabs\" state=<<tabs-state-macro>> tabsList=<<tabsList>> default={{{ [enlist<tabsList>] }}} template=\"$:/core/ui/PluginInfo\"/>\n</$set>\n</div>\n</div>\n</$reveal>\n</$set>\n\\end\n\n<$macrocall $name=\"plugin-info\" type=<<plugin-type>> default-popup-state=<<default-popup-state>>/>\n"
},
"$:/core/ui/Components/tag-link": {
"title": "$:/core/ui/Components/tag-link",
"text": "<$link>\n<$set name=\"backgroundColor\" value={{!!color}}>\n<span style=<<tag-styles>> class=\"tc-tag-label\">\n<$view field=\"title\" format=\"text\"/>\n</span>\n</$set>\n</$link>"
},
"$:/core/ui/ControlPanel/Advanced": {
"title": "$:/core/ui/ControlPanel/Advanced",
"tags": "$:/tags/ControlPanel/Info",
"caption": "{{$:/language/ControlPanel/Advanced/Caption}}",
"text": "{{$:/language/ControlPanel/Advanced/Hint}}\n\n<div class=\"tc-control-panel\">\n<<tabs \"[all[shadows+tiddlers]tag[$:/tags/ControlPanel/Advanced]!has[draft.of]]\" \"$:/core/ui/ControlPanel/TiddlerFields\">>\n</div>\n"
},
"$:/core/ui/ControlPanel/Appearance": {
"title": "$:/core/ui/ControlPanel/Appearance",
"tags": "$:/tags/ControlPanel",
"caption": "{{$:/language/ControlPanel/Appearance/Caption}}",
"text": "{{$:/language/ControlPanel/Appearance/Hint}}\n\n<div class=\"tc-control-panel\">\n<<tabs \"[all[shadows+tiddlers]tag[$:/tags/ControlPanel/Appearance]!has[draft.of]]\" \"$:/core/ui/ControlPanel/Theme\">>\n</div>\n"
},
"$:/core/ui/ControlPanel/Basics": {
"title": "$:/core/ui/ControlPanel/Basics",
"tags": "$:/tags/ControlPanel/Info",
"caption": "{{$:/language/ControlPanel/Basics/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Basics/\n\n\\define show-filter-count(filter)\n<$button class=\"tc-btn-invisible\">\n<$action-setfield $tiddler=\"$:/temp/advancedsearch\" $value=\"\"\"$filter$\"\"\"/>\n<$action-setfield $tiddler=\"$:/state/tab--1498284803\" $value=\"$:/core/ui/AdvancedSearch/Filter\"/>\n<$action-navigate $to=\"$:/AdvancedSearch\"/>\n''<$count filter=\"\"\"$filter$\"\"\"/>''\n{{$:/core/images/advanced-search-button}}\n</$button>\n\\end\n\n|<<lingo Version/Prompt>> |''<<version>>'' |\n|<$link to=\"$:/SiteTitle\"><<lingo Title/Prompt>></$link> |<$edit-text tiddler=\"$:/SiteTitle\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/SiteSubtitle\"><<lingo Subtitle/Prompt>></$link> |<$edit-text tiddler=\"$:/SiteSubtitle\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/status/UserName\"><<lingo Username/Prompt>></$link> |<$edit-text tiddler=\"$:/status/UserName\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/config/AnimationDuration\"><<lingo AnimDuration/Prompt>></$link> |<$edit-text tiddler=\"$:/config/AnimationDuration\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/DefaultTiddlers\"><<lingo DefaultTiddlers/Prompt>></$link> |<<lingo DefaultTiddlers/TopHint>><br> <$edit tag=\"textarea\" tiddler=\"$:/DefaultTiddlers\" class=\"tc-edit-texteditor\"/><br>//<<lingo DefaultTiddlers/BottomHint>>// |\n|<$link to=\"$:/language/DefaultNewTiddlerTitle\"><<lingo NewTiddler/Title/Prompt>></$link> |<$edit-text tiddler=\"$:/language/DefaultNewTiddlerTitle\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/config/NewJournal/Title\"><<lingo NewJournal/Title/Prompt>></$link> |<$edit-text tiddler=\"$:/config/NewJournal/Title\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/config/NewJournal/Text\"><<lingo NewJournal/Text/Prompt>></$link> |<$edit tiddler=\"$:/config/NewJournal/Text\" tag=\"textarea\" class=\"tc-edit-texteditor\" default=\"\"/> |\n|<$link to=\"$:/config/NewJournal/Tags\"><<lingo NewJournal/Tags/Prompt>></$link> |<$edit-text tiddler=\"$:/config/NewJournal/Tags\" default=\"\" tag=\"input\"/> |\n|<<lingo Language/Prompt>> |{{$:/snippets/minilanguageswitcher}} |\n|<<lingo Tiddlers/Prompt>> |<<show-filter-count \"[!is[system]sort[title]]\">> |\n|<<lingo Tags/Prompt>> |<<show-filter-count \"[tags[]sort[title]]\">> |\n|<<lingo SystemTiddlers/Prompt>> |<<show-filter-count \"[is[system]sort[title]]\">> |\n|<<lingo ShadowTiddlers/Prompt>> |<<show-filter-count \"[all[shadows]sort[title]]\">> |\n|<<lingo OverriddenShadowTiddlers/Prompt>> |<<show-filter-count \"[is[tiddler]is[shadow]sort[title]]\">> |\n"
},
"$:/core/ui/ControlPanel/EditorTypes": {
"title": "$:/core/ui/ControlPanel/EditorTypes",
"tags": "$:/tags/ControlPanel/Advanced",
"caption": "{{$:/language/ControlPanel/EditorTypes/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/EditorTypes/\n\n<<lingo Hint>>\n\n<table>\n<tbody>\n<tr>\n<th><<lingo Type/Caption>></th>\n<th><<lingo Editor/Caption>></th>\n</tr>\n<$list filter=\"[all[shadows+tiddlers]prefix[$:/config/EditorTypeMappings/]sort[title]]\">\n<tr>\n<td>\n<$link>\n<$list filter=\"[all[current]removeprefix[$:/config/EditorTypeMappings/]]\">\n<$text text={{!!title}}/>\n</$list>\n</$link>\n</td>\n<td>\n<$view field=\"text\"/>\n</td>\n</tr>\n</$list>\n</tbody>\n</table>\n"
},
"$:/core/ui/ControlPanel/Info": {
"title": "$:/core/ui/ControlPanel/Info",
"tags": "$:/tags/ControlPanel",
"caption": "{{$:/language/ControlPanel/Info/Caption}}",
"text": "{{$:/language/ControlPanel/Info/Hint}}\n\n<div class=\"tc-control-panel\">\n<<tabs \"[all[shadows+tiddlers]tag[$:/tags/ControlPanel/Info]!has[draft.of]]\" \"$:/core/ui/ControlPanel/Basics\">>\n</div>\n"
},
"$:/core/ui/ControlPanel/KeyboardShortcuts": {
"title": "$:/core/ui/ControlPanel/KeyboardShortcuts",
"tags": "$:/tags/ControlPanel",
"caption": "{{$:/language/ControlPanel/KeyboardShortcuts/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/KeyboardShortcuts/\n\n\\define new-shortcut(title)\n<div class=\"tc-dropdown-item-plain\">\n<$edit-shortcut tiddler=\"$title$\" placeholder={{$:/language/ControlPanel/KeyboardShortcuts/Add/Prompt}} style=\"width:auto;\"/> <$button>\n<<lingo Add/Caption>>\n<$action-listops\n\t$tiddler=\"$(shortcutTitle)$\"\n\t$field=\"text\"\n\t$subfilter=\"[{$title$}]\"\n/>\n<$action-deletetiddler\n\t$tiddler=\"$title$\"\n/>\n</$button>\n</div>\n\\end\n\n\\define shortcut-list-item(caption)\n<td>\n</td>\n<td style=\"text-align:right;font-size:0.7em;\">\n<<lingo Platform/$caption$>>\n</td>\n<td>\n<div style=\"position:relative;\">\n<$button popup=<<qualify \"$:/state/dropdown/$(shortcutTitle)$\">> class=\"tc-btn-invisible\">\n{{$:/core/images/edit-button}}\n</$button>\n<$macrocall $name=\"displayshortcuts\" $output=\"text/html\" shortcuts={{$(shortcutTitle)$}} prefix=\"<kbd>\" separator=\"</kbd> <kbd>\" suffix=\"</kbd>\"/>\n\n<$reveal state=<<qualify \"$:/state/dropdown/$(shortcutTitle)$\">> type=\"popup\" position=\"below\" animate=\"yes\">\n<div class=\"tc-block-dropdown-wrapper\">\n<div class=\"tc-block-dropdown tc-edit-type-dropdown tc-popup-keep\">\n<$list filter=\"[list[$(shortcutTitle)$!!text]sort[title]]\" variable=\"shortcut\" emptyMessage=\"\"\"\n<div class=\"tc-dropdown-item-plain\">\n//<<lingo NoShortcuts/Caption>>//\n</div>\n\"\"\">\n<div class=\"tc-dropdown-item-plain\">\n<$button class=\"tc-btn-invisible\" tooltip=<<lingo Remove/Hint>>>\n<$action-listops\n\t$tiddler=\"$(shortcutTitle)$\"\n\t$field=\"text\"\n\t$subfilter=\"+[remove<shortcut>]\"\n/>\n×\n</$button>\n<kbd>\n<$macrocall $name=\"displayshortcuts\" $output=\"text/html\" shortcuts=<<shortcut>>/>\n</kbd>\n</div>\n</$list>\n<hr/>\n<$macrocall $name=\"new-shortcut\" title=<<qualify \"$:/state/new-shortcut/$(shortcutTitle)$\">>/>\n</div>\n</div>\n</$reveal>\n</div>\n</td>\n\\end\n\n\\define shortcut-list(caption,prefix)\n<tr>\n<$list filter=\"[[$prefix$$(shortcutName)$]]\" variable=\"shortcutTitle\">\n<<shortcut-list-item \"$caption$\">>\n</$list>\n</tr>\n\\end\n\n\\define shortcut-editor()\n<<shortcut-list \"All\" \"$:/config/shortcuts/\">>\n<<shortcut-list \"Mac\" \"$:/config/shortcuts-mac/\">>\n<<shortcut-list \"NonMac\" \"$:/config/shortcuts-not-mac/\">>\n<<shortcut-list \"Linux\" \"$:/config/shortcuts-linux/\">>\n<<shortcut-list \"NonLinux\" \"$:/config/shortcuts-not-linux/\">>\n<<shortcut-list \"Windows\" \"$:/config/shortcuts-windows/\">>\n<<shortcut-list \"NonWindows\" \"$:/config/shortcuts-not-windows/\">>\n\\end\n\n\\define shortcut-preview()\n<$macrocall $name=\"displayshortcuts\" $output=\"text/html\" shortcuts={{$(shortcutPrefix)$$(shortcutName)$}} prefix=\"<kbd>\" separator=\"</kbd> <kbd>\" suffix=\"</kbd>\"/>\n\\end\n\n\\define shortcut-item-inner()\n<tr>\n<td>\n<$reveal type=\"nomatch\" state=<<dropdownStateTitle>> text=\"open\">\n<$button class=\"tc-btn-invisible\">\n<$action-setfield\n\t$tiddler=<<dropdownStateTitle>>\n\t$value=\"open\"\n/>\n{{$:/core/images/right-arrow}}\n</$button>\n</$reveal>\n<$reveal type=\"match\" state=<<dropdownStateTitle>> text=\"open\">\n<$button class=\"tc-btn-invisible\">\n<$action-setfield\n\t$tiddler=<<dropdownStateTitle>>\n\t$value=\"close\"\n/>\n{{$:/core/images/down-arrow}}\n</$button>\n</$reveal>\n''<$text text=<<shortcutName>>/>''\n</td>\n<td>\n<$transclude tiddler=\"$:/config/ShortcutInfo/$(shortcutName)$\"/>\n</td>\n<td>\n<$list filter=\"$:/config/shortcuts/ $:/config/shortcuts-mac/ $:/config/shortcuts-not-mac/ $:/config/shortcuts-linux/ $:/config/shortcuts-not-linux/ $:/config/shortcuts-windows/ $:/config/shortcuts-not-windows/\" variable=\"shortcutPrefix\">\n<<shortcut-preview>>\n</$list>\n</td>\n</tr>\n<$set name=\"dropdownState\" value={{$(dropdownStateTitle)$}}>\n<$list filter=\"[<dropdownState>prefix[open]]\" variable=\"listItem\">\n<<shortcut-editor>>\n</$list>\n</$set>\n\\end\n\n\\define shortcut-item()\n<$set name=\"dropdownStateTitle\" value=<<qualify \"$:/state/dropdown/keyboardshortcut/$(shortcutName)$\">>>\n<<shortcut-item-inner>>\n</$set>\n\\end\n\n<table>\n<tbody>\n<$list filter=\"[all[shadows+tiddlers]removeprefix[$:/config/ShortcutInfo/]]\" variable=\"shortcutName\">\n<<shortcut-item>>\n</$list>\n</tbody>\n</table>\n"
},
"$:/core/ui/ControlPanel/LoadedModules": {
"title": "$:/core/ui/ControlPanel/LoadedModules",
"tags": "$:/tags/ControlPanel/Advanced",
"caption": "{{$:/language/ControlPanel/LoadedModules/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/\n<<lingo LoadedModules/Hint>>\n\n{{$:/snippets/modules}}\n"
},
"$:/core/ui/ControlPanel/Modals/AddPlugins": {
"title": "$:/core/ui/ControlPanel/Modals/AddPlugins",
"subtitle": "{{$:/core/images/download-button}} {{$:/language/ControlPanel/Plugins/Add/Caption}}",
"text": "\\define install-plugin-button()\n<$button>\n<$action-sendmessage $message=\"tm-load-plugin-from-library\" url={{!!url}} title={{$(assetInfo)$!!original-title}}/>\n<$list filter=\"[<assetInfo>get[original-title]get[version]]\" variable=\"installedVersion\" emptyMessage=\"\"\"{{$:/language/ControlPanel/Plugins/Install/Caption}}\"\"\">\n{{$:/language/ControlPanel/Plugins/Reinstall/Caption}}\n</$list>\n</$button>\n\\end\n\n\\define popup-state-macro()\n$:/state/add-plugin-info/$(connectionTiddler)$/$(assetInfo)$\n\\end\n\n\\define display-plugin-info(type)\n<$set name=\"popup-state\" value=<<popup-state-macro>>>\n<div class=\"tc-plugin-info\">\n<div class=\"tc-plugin-info-chunk tc-small-icon\">\n<$reveal type=\"nomatch\" state=<<popup-state>> text=\"yes\">\n<$button class=\"tc-btn-invisible tc-btn-dropdown\" set=<<popup-state>> setTo=\"yes\">\n{{$:/core/images/right-arrow}}\n</$button>\n</$reveal>\n<$reveal type=\"match\" state=<<popup-state>> text=\"yes\">\n<$button class=\"tc-btn-invisible tc-btn-dropdown\" set=<<popup-state>> setTo=\"no\">\n{{$:/core/images/down-arrow}}\n</$button>\n</$reveal>\n</div>\n<div class=\"tc-plugin-info-chunk\">\n<$list filter=\"[<assetInfo>has[icon]]\" emptyMessage=\"\"\"<$transclude tiddler=\"$:/core/images/plugin-generic-$type$\"/>\"\"\">\n<img src={{$(assetInfo)$!!icon}}/>\n</$list>\n</div>\n<div class=\"tc-plugin-info-chunk\">\n<h1><$view tiddler=<<assetInfo>> field=\"description\"/></h1>\n<h2><$view tiddler=<<assetInfo>> field=\"original-title\"/></h2>\n<div><em><$view tiddler=<<assetInfo>> field=\"version\"/></em></div>\n</div>\n<div class=\"tc-plugin-info-chunk\">\n<<install-plugin-button>>\n</div>\n</div>\n<$reveal type=\"match\" text=\"yes\" state=<<popup-state>>>\n<div class=\"tc-plugin-info-dropdown\">\n<div class=\"tc-plugin-info-dropdown-message\">\n<$list filter=\"[<assetInfo>get[original-title]get[version]]\" variable=\"installedVersion\" emptyMessage=\"\"\"{{$:/language/ControlPanel/Plugins/NotInstalled/Hint}}\"\"\">\n<em>\n{{$:/language/ControlPanel/Plugins/AlreadyInstalled/Hint}}\n</em>\n</$list>\n</div>\n<div class=\"tc-plugin-info-dropdown-body\">\n<$transclude tiddler=<<assetInfo>> field=\"readme\" mode=\"block\"/>\n</div>\n</div>\n</$reveal>\n</$set>\n\\end\n\n\\define load-plugin-library-button()\n<$button class=\"tc-btn-big-green\">\n<$action-sendmessage $message=\"tm-load-plugin-library\" url={{!!url}} infoTitlePrefix=\"$:/temp/RemoteAssetInfo/\"/>\n{{$:/core/images/chevron-right}} {{$:/language/ControlPanel/Plugins/OpenPluginLibrary}}\n</$button>\n\\end\n\n\\define display-server-assets(type)\n{{$:/language/Search/Search}}: <$edit-text tiddler=\"\"\"$:/temp/RemoteAssetSearch/$(currentTiddler)$\"\"\" default=\"\" type=\"search\" tag=\"input\"/>\n<$reveal state=\"\"\"$:/temp/RemoteAssetSearch/$(currentTiddler)$\"\"\" type=\"nomatch\" text=\"\">\n<$button class=\"tc-btn-invisible\">\n<$action-setfield $tiddler=\"\"\"$:/temp/RemoteAssetSearch/$(currentTiddler)$\"\"\" $field=\"text\" $value=\"\"/>\n{{$:/core/images/close-button}}\n</$button>\n</$reveal>\n<div class=\"tc-plugin-library-listing\">\n<$list filter=\"[all[tiddlers+shadows]tag[$:/tags/RemoteAssetInfo]server-url{!!url}original-plugin-type[$type$]search{$:/temp/RemoteAssetSearch/$(currentTiddler)$}sort[description]]\" variable=\"assetInfo\">\n<<display-plugin-info \"$type$\">>\n</$list>\n</div>\n\\end\n\n\\define display-server-connection()\n<$list filter=\"[all[tiddlers+shadows]tag[$:/tags/ServerConnection]suffix{!!url}]\" variable=\"connectionTiddler\" emptyMessage=<<load-plugin-library-button>>>\n\n<<tabs \"[[$:/core/ui/ControlPanel/Plugins/Add/Plugins]] [[$:/core/ui/ControlPanel/Plugins/Add/Themes]] [[$:/core/ui/ControlPanel/Plugins/Add/Languages]]\" \"$:/core/ui/ControlPanel/Plugins/Add/Plugins\">>\n\n</$list>\n\\end\n\n\\define close-library-button()\n<$reveal type='nomatch' state='$:/temp/ServerConnection/$(PluginLibraryURL)$' text=''>\n<$button class='tc-btn-big-green'>\n<$action-sendmessage $message=\"tm-unload-plugin-library\" url={{!!url}}/>\n{{$:/core/images/chevron-left}} {{$:/language/ControlPanel/Plugins/ClosePluginLibrary}}\n<$action-deletetiddler $filter=\"[prefix[$:/temp/ServerConnection/$(PluginLibraryURL)$]][prefix[$:/temp/RemoteAssetInfo/$(PluginLibraryURL)$]]\"/>\n</$button>\n</$reveal>\n\\end\n\n\\define plugin-library-listing()\n<$list filter=\"[all[tiddlers+shadows]tag[$:/tags/PluginLibrary]]\">\n<div class=\"tc-plugin-library\">\n\n!! <$link><$transclude field=\"caption\"><$view field=\"title\"/></$transclude></$link>\n\n//<$view field=\"url\"/>//\n\n<$transclude/>\n\n<$set name=PluginLibraryURL value={{!!url}}>\n<<close-library-button>>\n</$set>\n\n<<display-server-connection>>\n</div>\n</$list>\n\\end\n\n\\import [[$:/core/ui/PageMacros]] [all[shadows+tiddlers]tag[$:/tags/Macro]!has[draft.of]]\n\n<div>\n<<plugin-library-listing>>\n</div>\n"
},
"$:/core/ui/ControlPanel/Palette": {
"title": "$:/core/ui/ControlPanel/Palette",
"tags": "$:/tags/ControlPanel/Appearance",
"caption": "{{$:/language/ControlPanel/Palette/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Palette/\n\n{{$:/snippets/paletteswitcher}}\n\n<$reveal type=\"nomatch\" state=\"$:/state/ShowPaletteEditor\" text=\"yes\">\n\n<$button set=\"$:/state/ShowPaletteEditor\" setTo=\"yes\"><<lingo ShowEditor/Caption>></$button>\n\n</$reveal>\n\n<$reveal type=\"match\" state=\"$:/state/ShowPaletteEditor\" text=\"yes\">\n\n<$button set=\"$:/state/ShowPaletteEditor\" setTo=\"no\"><<lingo HideEditor/Caption>></$button>\n{{$:/snippets/paletteeditor}}\n\n</$reveal>\n\n"
},
"$:/core/ui/ControlPanel/Parsing": {
"title": "$:/core/ui/ControlPanel/Parsing",
"tags": "$:/tags/ControlPanel/Advanced",
"caption": "{{$:/language/ControlPanel/Parsing/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Parsing/\n\n\\define toggle(Type)\n<$checkbox\ntiddler=\"\"\"$:/config/WikiParserRules/$Type$/$(rule)$\"\"\"\nfield=\"text\"\nchecked=\"enable\"\nunchecked=\"disable\"\ndefault=\"enable\">\n<<rule>>\n</$checkbox>\n\\end\n\n\\define rules(type,Type)\n<$list filter=\"[wikiparserrules[$type$]]\" variable=\"rule\">\n<dd><<toggle $Type$>></dd>\n</$list>\n\\end\n\n<<lingo Hint>>\n\n<dl>\n<dt><<lingo Pragma/Caption>></dt>\n<<rules pragma Pragma>>\n<dt><<lingo Inline/Caption>></dt>\n<<rules inline Inline>>\n<dt><<lingo Block/Caption>></dt>\n<<rules block Block>>\n</dl>"
},
"$:/core/ui/ControlPanel/Plugins/Add/Languages": {
"title": "$:/core/ui/ControlPanel/Plugins/Add/Languages",
"caption": "{{$:/language/ControlPanel/Plugins/Languages/Caption}} (<$count filter=\"[all[tiddlers+shadows]tag[$:/tags/RemoteAssetInfo]server-url{!!url}original-plugin-type[language]]\"/>)",
"text": "<<display-server-assets language>>\n"
},
"$:/core/ui/ControlPanel/Plugins/Add/Plugins": {
"title": "$:/core/ui/ControlPanel/Plugins/Add/Plugins",
"caption": "{{$:/language/ControlPanel/Plugins/Plugins/Caption}} (<$count filter=\"[all[tiddlers+shadows]tag[$:/tags/RemoteAssetInfo]server-url{!!url}original-plugin-type[plugin]]\"/>)",
"text": "<<display-server-assets plugin>>\n"
},
"$:/core/ui/ControlPanel/Plugins/Add/Themes": {
"title": "$:/core/ui/ControlPanel/Plugins/Add/Themes",
"caption": "{{$:/language/ControlPanel/Plugins/Themes/Caption}} (<$count filter=\"[all[tiddlers+shadows]tag[$:/tags/RemoteAssetInfo]server-url{!!url}original-plugin-type[theme]]\"/>)",
"text": "<<display-server-assets theme>>\n"
},
"$:/core/ui/ControlPanel/Plugins/AddPlugins": {
"title": "$:/core/ui/ControlPanel/Plugins/AddPlugins",
"text": "\\define lingo-base() $:/language/ControlPanel/Plugins/\n\n<$button message=\"tm-modal\" param=\"$:/core/ui/ControlPanel/Modals/AddPlugins\" tooltip={{$:/language/ControlPanel/Plugins/Add/Hint}} class=\"tc-btn-big-green\" style=\"background:blue;\">\n{{$:/core/images/download-button}} <<lingo Add/Caption>>\n</$button>\n"
},
"$:/core/ui/ControlPanel/Plugins/Installed/Languages": {
"title": "$:/core/ui/ControlPanel/Plugins/Installed/Languages",
"caption": "{{$:/language/ControlPanel/Plugins/Languages/Caption}} (<$count filter=\"[!has[draft.of]plugin-type[language]]\"/>)",
"text": "<<plugin-table language>>\n"
},
"$:/core/ui/ControlPanel/Plugins/Installed/Plugins": {
"title": "$:/core/ui/ControlPanel/Plugins/Installed/Plugins",
"caption": "{{$:/language/ControlPanel/Plugins/Plugins/Caption}} (<$count filter=\"[!has[draft.of]plugin-type[plugin]]\"/>)",
"text": "<<plugin-table plugin>>\n"
},
"$:/core/ui/ControlPanel/Plugins/Installed/Themes": {
"title": "$:/core/ui/ControlPanel/Plugins/Installed/Themes",
"caption": "{{$:/language/ControlPanel/Plugins/Themes/Caption}} (<$count filter=\"[!has[draft.of]plugin-type[theme]]\"/>)",
"text": "<<plugin-table theme>>\n"
},
"$:/core/ui/ControlPanel/Plugins": {
"title": "$:/core/ui/ControlPanel/Plugins",
"tags": "$:/tags/ControlPanel",
"caption": "{{$:/language/ControlPanel/Plugins/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Plugins/\n\n\\define plugin-table(type)\n<$set name=\"plugin-type\" value=\"\"\"$type$\"\"\">\n<$set name=\"qualified-state\" value=<<qualify \"$:/state/plugin-info\">>>\n<$list filter=\"[!has[draft.of]plugin-type[$type$]sort[description]]\" emptyMessage=<<lingo \"Empty/Hint\">> template=\"$:/core/ui/Components/plugin-info\"/>\n</$set>\n</$set>\n\\end\n\n{{$:/core/ui/ControlPanel/Plugins/AddPlugins}}\n\n<<lingo Installed/Hint>>\n\n<<tabs \"[[$:/core/ui/ControlPanel/Plugins/Installed/Plugins]] [[$:/core/ui/ControlPanel/Plugins/Installed/Themes]] [[$:/core/ui/ControlPanel/Plugins/Installed/Languages]]\" \"$:/core/ui/ControlPanel/Plugins/Installed/Plugins\">>\n"
},
"$:/core/ui/ControlPanel/Saving/DownloadSaver": {
"title": "$:/core/ui/ControlPanel/Saving/DownloadSaver",
"tags": "$:/tags/ControlPanel/Saving",
"caption": "{{$:/language/ControlPanel/Saving/DownloadSaver/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Saving/DownloadSaver/\n\n<<lingo Hint>>\n\n!! <$link to=\"$:/config/DownloadSaver/AutoSave\"><<lingo AutoSave/Hint>></$link>\n\n<$checkbox tiddler=\"$:/config/DownloadSaver/AutoSave\" field=\"text\" checked=\"yes\" unchecked=\"no\" default=\"no\"> <<lingo AutoSave/Description>> </$checkbox>\n"
},
"$:/core/ui/ControlPanel/Saving/General": {
"title": "$:/core/ui/ControlPanel/Saving/General",
"tags": "$:/tags/ControlPanel/Saving",
"caption": "{{$:/language/ControlPanel/Saving/General/Caption}}",
"list-before": "",
"text": "\\define lingo-base() $:/language/ControlPanel/Settings/\n\n{{$:/language/ControlPanel/Saving/General/Hint}}\n\n!! <$link to=\"$:/config/AutoSave\"><<lingo AutoSave/Caption>></$link>\n\n<<lingo AutoSave/Hint>>\n\n<$radio tiddler=\"$:/config/AutoSave\" value=\"yes\"> <<lingo AutoSave/Enabled/Description>> </$radio>\n\n<$radio tiddler=\"$:/config/AutoSave\" value=\"no\"> <<lingo AutoSave/Disabled/Description>> </$radio>\n"
},
"$:/core/ui/ControlPanel/Saving/TiddlySpot": {
"title": "$:/core/ui/ControlPanel/Saving/TiddlySpot",
"tags": "$:/tags/ControlPanel/Saving",
"caption": "{{$:/language/ControlPanel/Saving/TiddlySpot/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Saving/TiddlySpot/\n\n\\define backupURL()\nhttp://$(userName)$.tiddlyspot.com/backup/\n\\end\n\\define backupLink()\n<$reveal type=\"nomatch\" state=\"$:/UploadName\" text=\"\">\n<$set name=\"userName\" value={{$:/UploadName}}>\n<$reveal type=\"match\" state=\"$:/UploadURL\" text=\"\">\n<<backupURL>>\n</$reveal>\n<$reveal type=\"nomatch\" state=\"$:/UploadURL\" text=\"\">\n<$macrocall $name=resolvePath source={{$:/UploadBackupDir}} root={{$:/UploadURL}}>>\n</$reveal>\n</$set>\n</$reveal>\n\\end\n\n<<lingo Description>>\n\n|<<lingo UserName>> |<$edit-text tiddler=\"$:/UploadName\" default=\"\" tag=\"input\"/> |\n|<<lingo Password>> |<$password name=\"upload\"/> |\n|<<lingo Backups>> |<<backupLink>> |\n\n''<<lingo Advanced/Heading>>''\n\n|<<lingo ServerURL>> |<$edit-text tiddler=\"$:/UploadURL\" default=\"\" tag=\"input\"/> |\n|<<lingo Filename>> |<$edit-text tiddler=\"$:/UploadFilename\" default=\"index.html\" tag=\"input\"/> |\n|<<lingo UploadDir>> |<$edit-text tiddler=\"$:/UploadDir\" default=\".\" tag=\"input\"/> |\n|<<lingo BackupDir>> |<$edit-text tiddler=\"$:/UploadBackupDir\" default=\".\" tag=\"input\"/> |\n\n<<lingo TiddlySpot/Hint>>"
},
"$:/core/ui/ControlPanel/Saving": {
"title": "$:/core/ui/ControlPanel/Saving",
"tags": "$:/tags/ControlPanel",
"caption": "{{$:/language/ControlPanel/Saving/Caption}}",
"text": "{{$:/language/ControlPanel/Saving/Hint}}\n\n<div class=\"tc-control-panel\">\n<<tabs \"[all[shadows+tiddlers]tag[$:/tags/ControlPanel/Saving]!has[draft.of]]\" \"$:/core/ui/ControlPanel/Saving/General\">>\n</div>\n"
},
"$:/core/buttonstyles/Borderless": {
"title": "$:/core/buttonstyles/Borderless",
"tags": "$:/tags/ToolbarButtonStyle",
"caption": "{{$:/language/ControlPanel/Settings/ToolbarButtonStyle/Styles/Borderless}}",
"text": "tc-btn-invisible"
},
"$:/core/buttonstyles/Boxed": {
"title": "$:/core/buttonstyles/Boxed",
"tags": "$:/tags/ToolbarButtonStyle",
"caption": "{{$:/language/ControlPanel/Settings/ToolbarButtonStyle/Styles/Boxed}}",
"text": "tc-btn-boxed"
},
"$:/core/buttonstyles/Rounded": {
"title": "$:/core/buttonstyles/Rounded",
"tags": "$:/tags/ToolbarButtonStyle",
"caption": "{{$:/language/ControlPanel/Settings/ToolbarButtonStyle/Styles/Rounded}}",
"text": "tc-btn-rounded"
},
"$:/core/ui/ControlPanel/Settings/CamelCase": {
"title": "$:/core/ui/ControlPanel/Settings/CamelCase",
"tags": "$:/tags/ControlPanel/Settings",
"caption": "{{$:/language/ControlPanel/Settings/CamelCase/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Settings/CamelCase/\n<<lingo Hint>>\n\n<$checkbox tiddler=\"$:/config/WikiParserRules/Inline/wikilink\" field=\"text\" checked=\"enable\" unchecked=\"disable\" default=\"enable\"> <$link to=\"$:/config/WikiParserRules/Inline/wikilink\"><<lingo Description>></$link> </$checkbox>\n"
},
"$:/core/ui/ControlPanel/Settings/DefaultMoreSidebarTab": {
"title": "$:/core/ui/ControlPanel/Settings/DefaultMoreSidebarTab",
"caption": "{{$:/language/ControlPanel/Settings/DefaultMoreSidebarTab/Caption}}",
"tags": "$:/tags/ControlPanel/Settings",
"text": "\\define lingo-base() $:/language/ControlPanel/Settings/DefaultMoreSidebarTab/\n\n<$link to=\"$:/config/DefaultMoreSidebarTab\"><<lingo Hint>></$link>\n\n<$select tiddler=\"$:/config/DefaultMoreSidebarTab\">\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/MoreSideBar]!has[draft.of]]\">\n<option value=<<currentTiddler>>><$transclude field=\"caption\"><$text text=<<currentTiddler>>/></$transclude></option>\n</$list>\n</$select>\n"
},
"$:/core/ui/ControlPanel/Settings/DefaultSidebarTab": {
"title": "$:/core/ui/ControlPanel/Settings/DefaultSidebarTab",
"caption": "{{$:/language/ControlPanel/Settings/DefaultSidebarTab/Caption}}",
"tags": "$:/tags/ControlPanel/Settings",
"text": "\\define lingo-base() $:/language/ControlPanel/Settings/DefaultSidebarTab/\n\n<$link to=\"$:/config/DefaultSidebarTab\"><<lingo Hint>></$link>\n\n<$select tiddler=\"$:/config/DefaultSidebarTab\">\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/SideBar]!has[draft.of]]\">\n<option value=<<currentTiddler>>><$transclude field=\"caption\"><$text text=<<currentTiddler>>/></$transclude></option>\n</$list>\n</$select>\n"
},
"$:/core/ui/ControlPanel/Settings/EditorToolbar": {
"title": "$:/core/ui/ControlPanel/Settings/EditorToolbar",
"tags": "$:/tags/ControlPanel/Settings",
"caption": "{{$:/language/ControlPanel/Settings/EditorToolbar/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Settings/EditorToolbar/\n<<lingo Hint>>\n\n<$checkbox tiddler=\"$:/config/TextEditor/EnableToolbar\" field=\"text\" checked=\"yes\" unchecked=\"no\" default=\"yes\"> <$link to=\"$:/config/TextEditor/EnableToolbar\"><<lingo Description>></$link> </$checkbox>\n\n"
},
"$:/core/ui/ControlPanel/Settings/InfoPanelMode": {
"title": "$:/core/ui/ControlPanel/Settings/InfoPanelMode",
"tags": "$:/tags/ControlPanel/Settings",
"caption": "{{$:/language/ControlPanel/Settings/InfoPanelMode/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Settings/InfoPanelMode/\n<$link to=\"$:/config/TiddlerInfo/Mode\"><<lingo Hint>></$link>\n\n<$radio tiddler=\"$:/config/TiddlerInfo/Mode\" value=\"popup\"> <<lingo Popup/Description>> </$radio>\n\n<$radio tiddler=\"$:/config/TiddlerInfo/Mode\" value=\"sticky\"> <<lingo Sticky/Description>> </$radio>\n"
},
"$:/core/ui/ControlPanel/Settings/LinkToBehaviour": {
"title": "$:/core/ui/ControlPanel/Settings/LinkToBehaviour",
"tags": "$:/tags/ControlPanel/Settings",
"caption": "{{$:/language/ControlPanel/Settings/LinkToBehaviour/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Settings/LinkToBehaviour/\n\n<$link to=\"$:/config/Navigation/openLinkFromInsideRiver\"><<lingo \"InsideRiver/Hint\">></$link>\n\n<$select tiddler=\"$:/config/Navigation/openLinkFromInsideRiver\">\n <option value=\"above\"><<lingo \"OpenAbove\">></option>\n <option value=\"below\"><<lingo \"OpenBelow\">></option>\n <option value=\"top\"><<lingo \"OpenAtTop\">></option>\n <option value=\"bottom\"><<lingo \"OpenAtBottom\">></option>\n</$select>\n\n<$link to=\"$:/config/Navigation/openLinkFromOutsideRiver\"><<lingo \"OutsideRiver/Hint\">></$link>\n\n<$select tiddler=\"$:/config/Navigation/openLinkFromOutsideRiver\">\n <option value=\"top\"><<lingo \"OpenAtTop\">></option>\n <option value=\"bottom\"><<lingo \"OpenAtBottom\">></option>\n</$select>\n"
},
"$:/core/ui/ControlPanel/Settings/MissingLinks": {
"title": "$:/core/ui/ControlPanel/Settings/MissingLinks",
"tags": "$:/tags/ControlPanel/Settings",
"caption": "{{$:/language/ControlPanel/Settings/MissingLinks/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Settings/MissingLinks/\n<<lingo Hint>>\n\n<$checkbox tiddler=\"$:/config/MissingLinks\" field=\"text\" checked=\"yes\" unchecked=\"no\" default=\"yes\"> <$link to=\"$:/config/MissingLinks\"><<lingo Description>></$link> </$checkbox>\n\n"
},
"$:/core/ui/ControlPanel/Settings/NavigationAddressBar": {
"title": "$:/core/ui/ControlPanel/Settings/NavigationAddressBar",
"tags": "$:/tags/ControlPanel/Settings",
"caption": "{{$:/language/ControlPanel/Settings/NavigationAddressBar/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Settings/NavigationAddressBar/\n\n<$link to=\"$:/config/Navigation/UpdateAddressBar\"><<lingo Hint>></$link>\n\n<$radio tiddler=\"$:/config/Navigation/UpdateAddressBar\" value=\"permaview\"> <<lingo Permaview/Description>> </$radio>\n\n<$radio tiddler=\"$:/config/Navigation/UpdateAddressBar\" value=\"permalink\"> <<lingo Permalink/Description>> </$radio>\n\n<$radio tiddler=\"$:/config/Navigation/UpdateAddressBar\" value=\"no\"> <<lingo No/Description>> </$radio>\n"
},
"$:/core/ui/ControlPanel/Settings/NavigationHistory": {
"title": "$:/core/ui/ControlPanel/Settings/NavigationHistory",
"tags": "$:/tags/ControlPanel/Settings",
"caption": "{{$:/language/ControlPanel/Settings/NavigationHistory/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Settings/NavigationHistory/\n<$link to=\"$:/config/Navigation/UpdateHistory\"><<lingo Hint>></$link>\n\n<$radio tiddler=\"$:/config/Navigation/UpdateHistory\" value=\"yes\"> <<lingo Yes/Description>> </$radio>\n\n<$radio tiddler=\"$:/config/Navigation/UpdateHistory\" value=\"no\"> <<lingo No/Description>> </$radio>\n"
},
"$:/core/ui/ControlPanel/Settings/NavigationPermalinkviewMode": {
"title": "$:/core/ui/ControlPanel/Settings/NavigationPermalinkviewMode",
"tags": "$:/tags/ControlPanel/Settings",
"caption": "{{$:/language/ControlPanel/Settings/NavigationPermalinkviewMode/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Settings/NavigationPermalinkviewMode/\n<<lingo Hint>>\n\n<$checkbox tiddler=\"$:/config/Navigation/Permalinkview/CopyToClipboard\" field=\"text\" checked=\"yes\" unchecked=\"no\" default=\"yes\"> <$link to=\"$:/config/Navigation/Permalinkview/CopyToClipboard\"><<lingo CopyToClipboard/Description>></$link> </$checkbox>\n\n<$checkbox tiddler=\"$:/config/Navigation/Permalinkview/UpdateAddressBar\" field=\"text\" checked=\"yes\" unchecked=\"no\" default=\"yes\"> <$link to=\"$:/config/Navigation/Permalinkview/UpdateAddressBar\"><<lingo UpdateAddressBar/Description>></$link> </$checkbox>\n"
},
"$:/core/ui/ControlPanel/Settings/PerformanceInstrumentation": {
"title": "$:/core/ui/ControlPanel/Settings/PerformanceInstrumentation",
"tags": "$:/tags/ControlPanel/Settings",
"caption": "{{$:/language/ControlPanel/Settings/PerformanceInstrumentation/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Settings/PerformanceInstrumentation/\n<<lingo Hint>>\n\n<$checkbox tiddler=\"$:/config/Performance/Instrumentation\" field=\"text\" checked=\"yes\" unchecked=\"no\" default=\"no\"> <$link to=\"$:/config/Performance/Instrumentation\"><<lingo Description>></$link> </$checkbox>\n"
},
"$:/core/ui/ControlPanel/Settings/TitleLinks": {
"title": "$:/core/ui/ControlPanel/Settings/TitleLinks",
"tags": "$:/tags/ControlPanel/Settings",
"caption": "{{$:/language/ControlPanel/Settings/TitleLinks/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Settings/TitleLinks/\n<$link to=\"$:/config/Tiddlers/TitleLinks\"><<lingo Hint>></$link>\n\n<$radio tiddler=\"$:/config/Tiddlers/TitleLinks\" value=\"yes\"> <<lingo Yes/Description>> </$radio>\n\n<$radio tiddler=\"$:/config/Tiddlers/TitleLinks\" value=\"no\"> <<lingo No/Description>> </$radio>\n"
},
"$:/core/ui/ControlPanel/Settings/ToolbarButtonStyle": {
"title": "$:/core/ui/ControlPanel/Settings/ToolbarButtonStyle",
"tags": "$:/tags/ControlPanel/Settings",
"caption": "{{$:/language/ControlPanel/Settings/ToolbarButtonStyle/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Settings/ToolbarButtonStyle/\n<$link to=\"$:/config/Toolbar/ButtonClass\"><<lingo \"Hint\">></$link>\n\n<$select tiddler=\"$:/config/Toolbar/ButtonClass\">\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/ToolbarButtonStyle]]\">\n<option value={{!!text}}>{{!!caption}}</option>\n</$list>\n</$select>\n"
},
"$:/core/ui/ControlPanel/Settings/ToolbarButtons": {
"title": "$:/core/ui/ControlPanel/Settings/ToolbarButtons",
"tags": "$:/tags/ControlPanel/Settings",
"caption": "{{$:/language/ControlPanel/Settings/ToolbarButtons/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Settings/ToolbarButtons/\n<<lingo Hint>>\n\n<$checkbox tiddler=\"$:/config/Toolbar/Icons\" field=\"text\" checked=\"yes\" unchecked=\"no\" default=\"yes\"> <$link to=\"$:/config/Toolbar/Icons\"><<lingo Icons/Description>></$link> </$checkbox>\n\n<$checkbox tiddler=\"$:/config/Toolbar/Text\" field=\"text\" checked=\"yes\" unchecked=\"no\" default=\"no\"> <$link to=\"$:/config/Toolbar/Text\"><<lingo Text/Description>></$link> </$checkbox>\n"
},
"$:/core/ui/ControlPanel/Settings": {
"title": "$:/core/ui/ControlPanel/Settings",
"tags": "$:/tags/ControlPanel",
"caption": "{{$:/language/ControlPanel/Settings/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/Settings/\n\n<<lingo Hint>>\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/ControlPanel/Settings]]\">\n\n<div style=\"border-top:1px solid #eee;\">\n\n!! <$link><$transclude field=\"caption\"/></$link>\n\n<$transclude/>\n\n</div>\n\n</$list>\n"
},
"$:/core/ui/ControlPanel/StoryView": {
"title": "$:/core/ui/ControlPanel/StoryView",
"tags": "$:/tags/ControlPanel/Appearance",
"caption": "{{$:/language/ControlPanel/StoryView/Caption}}",
"text": "{{$:/snippets/viewswitcher}}\n"
},
"$:/core/ui/ControlPanel/Stylesheets": {
"title": "$:/core/ui/ControlPanel/Stylesheets",
"tags": "$:/tags/ControlPanel/Advanced",
"caption": "{{$:/language/ControlPanel/Stylesheets/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/\n\n<<lingo Stylesheets/Hint>>\n\n{{$:/snippets/peek-stylesheets}}\n"
},
"$:/core/ui/ControlPanel/Theme": {
"title": "$:/core/ui/ControlPanel/Theme",
"tags": "$:/tags/ControlPanel/Appearance",
"caption": "{{$:/language/ControlPanel/Theme/Caption}}",
"text": "{{$:/snippets/themeswitcher}}\n"
},
"$:/core/ui/ControlPanel/TiddlerFields": {
"title": "$:/core/ui/ControlPanel/TiddlerFields",
"tags": "$:/tags/ControlPanel/Advanced",
"caption": "{{$:/language/ControlPanel/TiddlerFields/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/\n\n<<lingo TiddlerFields/Hint>>\n\n{{$:/snippets/allfields}}"
},
"$:/core/ui/ControlPanel/Toolbars/EditToolbar": {
"title": "$:/core/ui/ControlPanel/Toolbars/EditToolbar",
"tags": "$:/tags/ControlPanel/Toolbars",
"caption": "{{$:/language/ControlPanel/Toolbars/EditToolbar/Caption}}",
"text": "\\define lingo-base() $:/language/TiddlerInfo/\n\n\\define config-base() $:/config/EditToolbarButtons/Visibility/\n\n{{$:/language/ControlPanel/Toolbars/EditToolbar/Hint}}\n\n<$set name=\"tv-config-toolbar-icons\" value=\"yes\">\n\n<$set name=\"tv-config-toolbar-text\" value=\"yes\">\n\n<$macrocall $name=\"list-tagged-draggable\" tag=\"$:/tags/EditToolbar\" itemTemplate=\"$:/core/ui/ControlPanel/Toolbars/ItemTemplate\"/>\n\n</$set>\n\n</$set>"
},
"$:/core/ui/ControlPanel/Toolbars/EditorItemTemplate": {
"title": "$:/core/ui/ControlPanel/Toolbars/EditorItemTemplate",
"text": "\\define config-title()\n$(config-base)$$(currentTiddler)$\n\\end\n\n<$draggable tiddler=<<currentTiddler>>>\n<$checkbox tiddler=<<config-title>> field=\"text\" checked=\"show\" unchecked=\"hide\" default=\"show\"/> <span class=\"tc-icon-wrapper\"><$transclude tiddler={{!!icon}}/></span> <$transclude field=\"caption\"/> -- <i class=\"tc-muted\"><$transclude field=\"description\"/></i>\n</$draggable>\n"
},
"$:/core/ui/ControlPanel/Toolbars/EditorToolbar": {
"title": "$:/core/ui/ControlPanel/Toolbars/EditorToolbar",
"tags": "$:/tags/ControlPanel/Toolbars",
"caption": "{{$:/language/ControlPanel/Toolbars/EditorToolbar/Caption}}",
"text": "\\define lingo-base() $:/language/TiddlerInfo/\n\n\\define config-base() $:/config/EditorToolbarButtons/Visibility/\n\n{{$:/language/ControlPanel/Toolbars/EditorToolbar/Hint}}\n\n<$macrocall $name=\"list-tagged-draggable\" tag=\"$:/tags/EditorToolbar\" itemTemplate=\"$:/core/ui/ControlPanel/Toolbars/EditorItemTemplate\"/>\n"
},
"$:/core/ui/ControlPanel/Toolbars/ItemTemplate": {
"title": "$:/core/ui/ControlPanel/Toolbars/ItemTemplate",
"text": "\\define config-title()\n$(config-base)$$(currentTiddler)$\n\\end\n\n<$draggable tiddler=<<currentTiddler>>>\n<$checkbox tiddler=<<config-title>> field=\"text\" checked=\"show\" unchecked=\"hide\" default=\"show\"/> <span class=\"tc-icon-wrapper\"> <$transclude field=\"caption\"/> <i class=\"tc-muted\">-- <$transclude field=\"description\"/></i></span>\n</$draggable>\n"
},
"$:/core/ui/ControlPanel/Toolbars/PageControls": {
"title": "$:/core/ui/ControlPanel/Toolbars/PageControls",
"tags": "$:/tags/ControlPanel/Toolbars",
"caption": "{{$:/language/ControlPanel/Toolbars/PageControls/Caption}}",
"text": "\\define lingo-base() $:/language/TiddlerInfo/\n\n\\define config-base() $:/config/PageControlButtons/Visibility/\n\n{{$:/language/ControlPanel/Toolbars/PageControls/Hint}}\n\n<$set name=\"tv-config-toolbar-icons\" value=\"yes\">\n\n<$set name=\"tv-config-toolbar-text\" value=\"yes\">\n\n<$macrocall $name=\"list-tagged-draggable\" tag=\"$:/tags/PageControls\" itemTemplate=\"$:/core/ui/ControlPanel/Toolbars/ItemTemplate\"/>\n\n</$set>\n\n</$set>\n"
},
"$:/core/ui/ControlPanel/Toolbars/ViewToolbar": {
"title": "$:/core/ui/ControlPanel/Toolbars/ViewToolbar",
"tags": "$:/tags/ControlPanel/Toolbars",
"caption": "{{$:/language/ControlPanel/Toolbars/ViewToolbar/Caption}}",
"text": "\\define lingo-base() $:/language/TiddlerInfo/\n\n\\define config-base() $:/config/ViewToolbarButtons/Visibility/\n\n{{$:/language/ControlPanel/Toolbars/ViewToolbar/Hint}}\n\n<$set name=\"tv-config-toolbar-icons\" value=\"yes\">\n\n<$set name=\"tv-config-toolbar-text\" value=\"yes\">\n\n<$macrocall $name=\"list-tagged-draggable\" tag=\"$:/tags/ViewToolbar\" itemTemplate=\"$:/core/ui/ControlPanel/Toolbars/ItemTemplate\"/>\n\n</$set>\n\n</$set>\n"
},
"$:/core/ui/ControlPanel/Toolbars": {
"title": "$:/core/ui/ControlPanel/Toolbars",
"tags": "$:/tags/ControlPanel/Appearance",
"caption": "{{$:/language/ControlPanel/Toolbars/Caption}}",
"text": "{{$:/language/ControlPanel/Toolbars/Hint}}\n\n<div class=\"tc-control-panel\">\n<<tabs \"[all[shadows+tiddlers]tag[$:/tags/ControlPanel/Toolbars]!has[draft.of]]\" \"$:/core/ui/ControlPanel/Toolbars/ViewToolbar\" \"$:/state/tabs/controlpanel/toolbars\" \"tc-vertical\">>\n</div>\n"
},
"$:/ControlPanel": {
"title": "$:/ControlPanel",
"icon": "$:/core/images/options-button",
"color": "#bbb",
"text": "<div class=\"tc-control-panel\">\n<<tabs \"[all[shadows+tiddlers]tag[$:/tags/ControlPanel]!has[draft.of]]\" \"$:/core/ui/ControlPanel/Info\">>\n</div>\n"
},
"$:/core/ui/DefaultSearchResultList": {
"title": "$:/core/ui/DefaultSearchResultList",
"tags": "$:/tags/SearchResults",
"caption": "{{$:/language/Search/DefaultResults/Caption}}",
"text": "\\define searchResultList()\n//<small>{{$:/language/Search/Matches/Title}}</small>//\n\n<$list filter=\"[!is[system]search:title{$(searchTiddler)$}sort[title]limit[250]]\" template=\"$:/core/ui/ListItemTemplate\"/>\n\n//<small>{{$:/language/Search/Matches/All}}</small>//\n\n<$list filter=\"[!is[system]search{$(searchTiddler)$}sort[title]limit[250]]\" template=\"$:/core/ui/ListItemTemplate\"/>\n\n\\end\n<<searchResultList>>\n"
},
"$:/core/ui/EditTemplate/body/preview/diffs-current": {
"title": "$:/core/ui/EditTemplate/body/preview/diffs-current",
"tags": "$:/tags/EditPreview",
"caption": "differences from current",
"list-after": "$:/core/ui/EditTemplate/body/preview/output",
"text": "<$list filter=\"[<currentTiddler>!is[image]]\" emptyMessage={{$:/core/ui/EditTemplate/body/preview/output}}>\n\n<$macrocall $name=\"compareTiddlerText\" sourceTiddlerTitle={{!!draft.of}} destTiddlerTitle=<<currentTiddler>>/>\n\n</$list>\n\n"
},
"$:/core/ui/EditTemplate/body/preview/diffs-shadow": {
"title": "$:/core/ui/EditTemplate/body/preview/diffs-shadow",
"tags": "$:/tags/EditPreview",
"caption": "differences from shadow (if any)",
"list-after": "$:/core/ui/EditTemplate/body/preview/output",
"text": "<$list filter=\"[<currentTiddler>!is[image]]\" emptyMessage={{$:/core/ui/EditTemplate/body/preview/output}}>\n\n<$macrocall $name=\"compareTiddlerText\" sourceTiddlerTitle={{{ [{!!draft.of}shadowsource[]] }}} sourceSubTiddlerTitle={{!!draft.of}} destTiddlerTitle=<<currentTiddler>>/>\n\n</$list>\n\n"
},
"$:/core/ui/EditTemplate/body/preview/output": {
"title": "$:/core/ui/EditTemplate/body/preview/output",
"tags": "$:/tags/EditPreview",
"caption": "{{$:/language/EditTemplate/Body/Preview/Type/Output}}",
"text": "<$set name=\"tv-tiddler-preview\" value=\"yes\">\n\n<$transclude />\n\n</$set>\n"
},
"$:/state/showeditpreview": {
"title": "$:/state/showeditpreview",
"text": "no"
},
"$:/core/ui/EditTemplate/body/editor": {
"title": "$:/core/ui/EditTemplate/body/editor",
"text": "<$edit\n\n field=\"text\"\n class=\"tc-edit-texteditor\"\n placeholder={{$:/language/EditTemplate/Body/Placeholder}}\n\n><$set\n\n name=\"targetTiddler\"\n value=<<currentTiddler>>\n\n><$list\n\n filter=\"[all[shadows+tiddlers]tag[$:/tags/EditorToolbar]!has[draft.of]]\"\n\n><$reveal\n\n type=\"nomatch\"\n state=<<config-visibility-title>>\n text=\"hide\"\n class=\"tc-text-editor-toolbar-item-wrapper\"\n\n><$transclude\n\n tiddler=\"$:/core/ui/EditTemplate/body/toolbar/button\"\n mode=\"inline\"\n\n/></$reveal></$list></$set></$edit>\n"
},
"$:/core/ui/EditTemplate/body/toolbar/button": {
"title": "$:/core/ui/EditTemplate/body/toolbar/button",
"text": "\\define toolbar-button-icon()\n<$list\n\n filter=\"[all[current]!has[custom-icon]]\"\n variable=\"no-custom-icon\"\n\n><$transclude\n\n tiddler={{!!icon}}\n\n/></$list>\n\\end\n\n\\define toolbar-button-tooltip()\n{{!!description}}<$macrocall $name=\"displayshortcuts\" $output=\"text/plain\" shortcuts={{!!shortcuts}} prefix=\"` - [\" separator=\"] [\" suffix=\"]`\"/>\n\\end\n\n\\define toolbar-button()\n<$list\n\n filter={{!!condition}}\n variable=\"list-condition\"\n\n><$wikify\n\n name=\"tooltip-text\"\n text=<<toolbar-button-tooltip>>\n mode=\"inline\"\n output=\"text\"\n\n><$list\n\n filter=\"[all[current]!has[dropdown]]\"\n variable=\"no-dropdown\"\n\n><$button\n\n class=\"tc-btn-invisible $(buttonClasses)$\"\n tooltip=<<tooltip-text>>\n actions={{!!actions}}\n\n><span\n\n data-tw-keyboard-shortcut={{!!shortcuts}}\n\n/><<toolbar-button-icon>><$transclude\n\n tiddler=<<currentTiddler>>\n field=\"text\"\n\n/></$button></$list><$list\n\n filter=\"[all[current]has[dropdown]]\"\n variable=\"dropdown\"\n\n><$set\n\n name=\"dropdown-state\"\n value=<<qualify \"$:/state/EditorToolbarDropdown\">>\n\n><$button\n\n popup=<<dropdown-state>>\n class=\"tc-popup-keep tc-btn-invisible $(buttonClasses)$\"\n selectedClass=\"tc-selected\"\n tooltip=<<tooltip-text>>\n actions={{!!actions}}\n\n><span\n\n data-tw-keyboard-shortcut={{!!shortcuts}}\n\n/><<toolbar-button-icon>><$transclude\n\n tiddler=<<currentTiddler>>\n field=\"text\"\n\n/></$button><$reveal\n\n state=<<dropdown-state>>\n type=\"popup\"\n position=\"below\"\n animate=\"yes\"\n tag=\"span\"\n\n><div\n\n class=\"tc-drop-down tc-popup-keep\"\n\n><$transclude\n\n tiddler={{!!dropdown}}\n mode=\"block\"\n\n/></div></$reveal></$set></$list></$wikify></$list>\n\\end\n\n\\define toolbar-button-outer()\n<$set\n\n name=\"buttonClasses\"\n value={{!!button-classes}}\n\n><<toolbar-button>></$set>\n\\end\n\n<<toolbar-button-outer>>"
},
"$:/core/ui/EditTemplate/body": {
"title": "$:/core/ui/EditTemplate/body",
"tags": "$:/tags/EditTemplate",
"text": "\\define lingo-base() $:/language/EditTemplate/Body/\n\\define config-visibility-title()\n$:/config/EditorToolbarButtons/Visibility/$(currentTiddler)$\n\\end\n<$list filter=\"[all[current]has[_canonical_uri]]\">\n\n<div class=\"tc-message-box\">\n\n<<lingo External/Hint>>\n\n<a href={{!!_canonical_uri}}><$text text={{!!_canonical_uri}}/></a>\n\n<$edit-text field=\"_canonical_uri\" class=\"tc-edit-fields\"></$edit-text>\n\n</div>\n\n</$list>\n\n<$list filter=\"[all[current]!has[_canonical_uri]]\">\n\n<$reveal state=\"$:/state/showeditpreview\" type=\"match\" text=\"yes\">\n\n<div class=\"tc-tiddler-preview\">\n\n<$transclude tiddler=\"$:/core/ui/EditTemplate/body/editor\" mode=\"inline\"/>\n\n<div class=\"tc-tiddler-preview-preview\">\n\n<$transclude tiddler={{$:/state/editpreviewtype}} mode=\"inline\">\n\n<$transclude tiddler=\"$:/core/ui/EditTemplate/body/preview/output\" mode=\"inline\"/>\n\n</$transclude>\n\n</div>\n\n</div>\n\n</$reveal>\n\n<$reveal state=\"$:/state/showeditpreview\" type=\"nomatch\" text=\"yes\">\n\n<$transclude tiddler=\"$:/core/ui/EditTemplate/body/editor\" mode=\"inline\"/>\n\n</$reveal>\n\n</$list>\n"
},
"$:/core/ui/EditTemplate/controls": {
"title": "$:/core/ui/EditTemplate/controls",
"tags": "$:/tags/EditTemplate",
"text": "\\define config-title()\n$:/config/EditToolbarButtons/Visibility/$(listItem)$\n\\end\n<div class=\"tc-tiddler-title tc-tiddler-edit-title\">\n<$view field=\"title\"/>\n<span class=\"tc-tiddler-controls tc-titlebar\"><$list filter=\"[all[shadows+tiddlers]tag[$:/tags/EditToolbar]!has[draft.of]]\" variable=\"listItem\"><$reveal type=\"nomatch\" state=<<config-title>> text=\"hide\"><$transclude tiddler=<<listItem>>/></$reveal></$list></span>\n<div style=\"clear: both;\"></div>\n</div>\n"
},
"$:/core/ui/EditTemplate/fields": {
"title": "$:/core/ui/EditTemplate/fields",
"tags": "$:/tags/EditTemplate",
"text": "\\define lingo-base() $:/language/EditTemplate/\n\\define config-title()\n$:/config/EditTemplateFields/Visibility/$(currentField)$\n\\end\n\n\\define config-filter()\n[[hide]] -[title{$(config-title)$}]\n\\end\n\n\\define new-field()\n<$vars name={{$:/temp/newfieldname}}>\n<$reveal type=\"nomatch\" text=\"\" default=<<name>>>\n<$button>\n<$action-sendmessage $message=\"tm-add-field\"\n$name=<<name>>\n$value={{$:/temp/newfieldvalue}}/>\n<$action-deletetiddler $tiddler=\"$:/temp/newfieldname\"/>\n<$action-deletetiddler $tiddler=\"$:/temp/newfieldvalue\"/>\n<<lingo Fields/Add/Button>>\n</$button>\n</$reveal>\n<$reveal type=\"match\" text=\"\" default=<<name>>>\n<$button>\n<<lingo Fields/Add/Button>>\n</$button>\n</$reveal>\n</$vars>\n\\end\n\n<div class=\"tc-edit-fields\">\n<table class=\"tc-edit-fields\">\n<tbody>\n<$list filter=\"[all[current]fields[]] +[sort[title]]\" variable=\"currentField\">\n<$list filter=<<config-filter>> variable=\"temp\">\n<tr class=\"tc-edit-field\">\n<td class=\"tc-edit-field-name\">\n<$text text=<<currentField>>/>:</td>\n<td class=\"tc-edit-field-value\">\n<$edit-text tiddler=<<currentTiddler>> field=<<currentField>> placeholder={{$:/language/EditTemplate/Fields/Add/Value/Placeholder}}/>\n</td>\n<td class=\"tc-edit-field-remove\">\n<$button class=\"tc-btn-invisible\" tooltip={{$:/language/EditTemplate/Field/Remove/Hint}} aria-label={{$:/language/EditTemplate/Field/Remove/Caption}}>\n<$action-deletefield $field=<<currentField>>/>\n{{$:/core/images/delete-button}}\n</$button>\n</td>\n</tr>\n</$list>\n</$list>\n</tbody>\n</table>\n</div>\n\n<$fieldmangler>\n<div class=\"tc-edit-field-add\">\n<em class=\"tc-edit\">\n<<lingo Fields/Add/Prompt>>\n</em>\n<span class=\"tc-edit-field-add-name\">\n<$edit-text tiddler=\"$:/temp/newfieldname\" tag=\"input\" default=\"\" placeholder={{$:/language/EditTemplate/Fields/Add/Name/Placeholder}} focusPopup=<<qualify \"$:/state/popup/field-dropdown\">> class=\"tc-edit-texteditor tc-popup-handle\"/>\n</span>\n<$button popup=<<qualify \"$:/state/popup/field-dropdown\">> class=\"tc-btn-invisible tc-btn-dropdown\" tooltip={{$:/language/EditTemplate/Field/Dropdown/Hint}} aria-label={{$:/language/EditTemplate/Field/Dropdown/Caption}}>{{$:/core/images/down-arrow}}</$button>\n<$reveal state=<<qualify \"$:/state/popup/field-dropdown\">> type=\"nomatch\" text=\"\" default=\"\">\n<div class=\"tc-block-dropdown tc-edit-type-dropdown\">\n<$set name=\"tv-show-missing-links\" value=\"yes\">\n<$linkcatcher to=\"$:/temp/newfieldname\">\n<div class=\"tc-dropdown-item\">\n<<lingo Fields/Add/Dropdown/User>>\n</div>\n<$list filter=\"[!is[shadow]!is[system]fields[]search:title{$:/temp/newfieldname}sort[]] -created -creator -draft.of -draft.title -modified -modifier -tags -text -title -type\" variable=\"currentField\">\n<$link to=<<currentField>>>\n<<currentField>>\n</$link>\n</$list>\n<div class=\"tc-dropdown-item\">\n<<lingo Fields/Add/Dropdown/System>>\n</div>\n<$list filter=\"[fields[]search:title{$:/temp/newfieldname}sort[]] -[!is[shadow]!is[system]fields[]]\" variable=\"currentField\">\n<$link to=<<currentField>>>\n<<currentField>>\n</$link>\n</$list>\n</$linkcatcher>\n</$set>\n</div>\n</$reveal>\n<span class=\"tc-edit-field-add-value\">\n<$edit-text tiddler=\"$:/temp/newfieldvalue\" tag=\"input\" default=\"\" placeholder={{$:/language/EditTemplate/Fields/Add/Value/Placeholder}} class=\"tc-edit-texteditor\"/>\n</span>\n<span class=\"tc-edit-field-add-button\">\n<$macrocall $name=\"new-field\"/>\n</span>\n</div>\n</$fieldmangler>\n"
},
"$:/core/ui/EditTemplate/shadow": {
"title": "$:/core/ui/EditTemplate/shadow",
"tags": "$:/tags/EditTemplate",
"text": "\\define lingo-base() $:/language/EditTemplate/Shadow/\n\\define pluginLinkBody()\n<$link to=\"\"\"$(pluginTitle)$\"\"\">\n<$text text=\"\"\"$(pluginTitle)$\"\"\"/>\n</$link>\n\\end\n<$list filter=\"[all[current]get[draft.of]is[shadow]!is[tiddler]]\">\n\n<$list filter=\"[all[current]shadowsource[]]\" variable=\"pluginTitle\">\n\n<$set name=\"pluginLink\" value=<<pluginLinkBody>>>\n<div class=\"tc-message-box\">\n\n<<lingo Warning>>\n\n</div>\n</$set>\n</$list>\n\n</$list>\n\n<$list filter=\"[all[current]get[draft.of]is[shadow]is[tiddler]]\">\n\n<$list filter=\"[all[current]shadowsource[]]\" variable=\"pluginTitle\">\n\n<$set name=\"pluginLink\" value=<<pluginLinkBody>>>\n<div class=\"tc-message-box\">\n\n<<lingo OverriddenWarning>>\n\n</div>\n</$set>\n</$list>\n\n</$list>"
},
"$:/core/ui/EditTemplate/tags": {
"title": "$:/core/ui/EditTemplate/tags",
"tags": "$:/tags/EditTemplate",
"text": "\\whitespace trim\n\n\\define lingo-base() $:/language/EditTemplate/\n\n\\define tag-styles()\nbackground-color:$(backgroundColor)$;\nfill:$(foregroundColor)$;\ncolor:$(foregroundColor)$;\n\\end\n\n\\define tag-body-inner(colour,fallbackTarget,colourA,colourB,icon)\n\\whitespace trim\n<$vars foregroundColor=<<contrastcolour target:\"\"\"$colour$\"\"\" fallbackTarget:\"\"\"$fallbackTarget$\"\"\" colourA:\"\"\"$colourA$\"\"\" colourB:\"\"\"$colourB$\"\"\">> backgroundColor=\"\"\"$colour$\"\"\">\n<span style=<<tag-styles>> class=\"tc-tag-label tc-tag-list-item\">\n<$transclude tiddler=\"\"\"$icon$\"\"\"/> <$view field=\"title\" format=\"text\" />\n<$button message=\"tm-remove-tag\" param={{!!title}} class=\"tc-btn-invisible tc-remove-tag-button\">×</$button>\n</span>\n</$vars>\n\\end\n\n\\define tag-body(colour,palette,icon)\n<$macrocall $name=\"tag-body-inner\" colour=\"\"\"$colour$\"\"\" fallbackTarget={{$palette$##tag-background}} colourA={{$palette$##foreground}} colourB={{$palette$##background}} icon=\"\"\"$icon$\"\"\"/>\n\\end\n\n\\define tag-picker-actions()\n<$action-listops\n\t$tiddler=<<currentTiddler>>\n\t$field=\"tags\"\n\t$subfilter=\"[<tag>] [all[current]tags[]]\"\n/>\n\\end\n\n<div class=\"tc-edit-tags\">\n<$fieldmangler>\n<$list filter=\"[all[current]tags[]sort[title]]\" storyview=\"pop\">\n<$macrocall $name=\"tag-body\" colour={{!!color}} palette={{$:/palette}} icon={{!!icon}}/>\n</$list>\n</$fieldmangler>\n<$macrocall $name=\"tag-picker\" actions=<<tag-picker-actions>>/>\n</div>\n"
},
"$:/core/ui/EditTemplate/title": {
"title": "$:/core/ui/EditTemplate/title",
"tags": "$:/tags/EditTemplate",
"text": "<$edit-text field=\"draft.title\" class=\"tc-titlebar tc-edit-texteditor\" focus=\"true\"/>\n\n<$vars pattern=\"\"\"[\\|\\[\\]{}]\"\"\" bad-chars=\"\"\"`| [ ] { }`\"\"\">\n\n<$list filter=\"[all[current]regexp:draft.title<pattern>]\" variable=\"listItem\">\n\n<div class=\"tc-message-box\">\n\n{{$:/core/images/warning}} {{$:/language/EditTemplate/Title/BadCharacterWarning}}\n\n</div>\n\n</$list>\n\n</$vars>\n\n<$reveal state=\"!!draft.title\" type=\"nomatch\" text={{!!draft.of}} tag=\"div\">\n\n<$list filter=\"[{!!draft.title}!is[missing]]\" variable=\"listItem\">\n\n<div class=\"tc-message-box\">\n\n{{$:/core/images/warning}} {{$:/language/EditTemplate/Title/Exists/Prompt}}\n\n</div>\n\n</$list>\n\n<$list filter=\"[{!!draft.of}!is[missing]]\" variable=\"listItem\">\n\n<$vars fromTitle={{!!draft.of}} toTitle={{!!draft.title}}>\n\n<$checkbox tiddler=\"$:/config/RelinkOnRename\" field=\"text\" checked=\"yes\" unchecked=\"no\" default=\"no\"> {{$:/language/EditTemplate/Title/Relink/Prompt}}</$checkbox>\n\n<$vars stateTiddler=<<qualify \"$:/state/edit/references\">> >\n\n<$reveal type=\"nomatch\" state=<<stateTiddler>> text=\"show\">\n<$button set=<<stateTiddler>> setTo=\"show\" class=\"tc-btn-invisible\">{{$:/core/images/right-arrow}} \n<<lingo EditTemplate/Title/References/Prompt>></$button>\n</$reveal>\n<$reveal type=\"match\" state=<<stateTiddler>> text=\"show\">\n<$button set=<<stateTiddler>> setTo=\"hide\" class=\"tc-btn-invisible\">{{$:/core/images/down-arrow}} \n<<lingo EditTemplate/Title/References/Prompt>></$button>\n</$reveal>\n\n<$reveal type=\"match\" state=<<stateTiddler>> text=\"show\">\n<$tiddler tiddler=<<fromTitle>> >\n<$transclude tiddler=\"$:/core/ui/TiddlerInfo/References\"/>\n</$tiddler>\n</$reveal>\n\n</$vars>\n\n</$vars>\n\n</$list>\n\n</$reveal>\n"
},
"$:/core/ui/EditTemplate/type": {
"title": "$:/core/ui/EditTemplate/type",
"tags": "$:/tags/EditTemplate",
"text": "\\define lingo-base() $:/language/EditTemplate/\n<div class=\"tc-type-selector\"><$fieldmangler>\n<em class=\"tc-edit\"><<lingo Type/Prompt>></em> <$edit-text field=\"type\" tag=\"input\" default=\"\" placeholder={{$:/language/EditTemplate/Type/Placeholder}} focusPopup=<<qualify \"$:/state/popup/type-dropdown\">> class=\"tc-edit-typeeditor tc-popup-handle\"/> <$button popup=<<qualify \"$:/state/popup/type-dropdown\">> class=\"tc-btn-invisible tc-btn-dropdown\" tooltip={{$:/language/EditTemplate/Type/Dropdown/Hint}} aria-label={{$:/language/EditTemplate/Type/Dropdown/Caption}}>{{$:/core/images/down-arrow}}</$button> <$button message=\"tm-remove-field\" param=\"type\" class=\"tc-btn-invisible tc-btn-icon\" tooltip={{$:/language/EditTemplate/Type/Delete/Hint}} aria-label={{$:/language/EditTemplate/Type/Delete/Caption}}>{{$:/core/images/delete-button}}</$button>\n</$fieldmangler></div>\n\n<div class=\"tc-block-dropdown-wrapper\">\n<$set name=\"tv-show-missing-links\" value=\"yes\">\n<$reveal state=<<qualify \"$:/state/popup/type-dropdown\">> type=\"nomatch\" text=\"\" default=\"\">\n<div class=\"tc-block-dropdown tc-edit-type-dropdown\">\n<$linkcatcher to=\"!!type\">\n<$list filter='[all[shadows+tiddlers]prefix[$:/language/Docs/Types/]each[group]sort[group-sort]]'>\n<div class=\"tc-dropdown-item\">\n<$text text={{!!group}}/>\n</div>\n<$list filter=\"[all[shadows+tiddlers]prefix[$:/language/Docs/Types/]group{!!group}] +[sort[description]]\"><$link to={{!!name}}><$view field=\"description\"/> (<$view field=\"name\"/>)</$link>\n</$list>\n</$list>\n</$linkcatcher>\n</div>\n</$reveal>\n</$set>\n</div>\n"
},
"$:/core/ui/EditTemplate": {
"title": "$:/core/ui/EditTemplate",
"text": "\\define actions()\n<$action-sendmessage $message=\"tm-add-tag\" $param={{$:/temp/NewTagName}}/>\n<$action-deletetiddler $tiddler=\"$:/temp/NewTagName\"/>\n<$action-sendmessage $message=\"tm-add-field\" $name={{$:/temp/newfieldname}} $value={{$:/temp/newfieldvalue}}/>\n<$action-deletetiddler $tiddler=\"$:/temp/newfieldname\"/>\n<$action-deletetiddler $tiddler=\"$:/temp/newfieldvalue\"/>\n<$action-sendmessage $message=\"tm-save-tiddler\"/>\n\\end\n\\define frame-classes()\ntc-tiddler-frame tc-tiddler-edit-frame $(missingTiddlerClass)$ $(shadowTiddlerClass)$ $(systemTiddlerClass)$\n\\end\n<div class=<<frame-classes>> data-tiddler-title=<<currentTiddler>>>\n<$fieldmangler>\n<$set name=\"storyTiddler\" value=<<currentTiddler>>>\n<$keyboard key=\"((cancel-edit-tiddler))\" message=\"tm-cancel-tiddler\">\n<$keyboard key=\"((save-tiddler))\" actions=<<actions>>>\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/EditTemplate]!has[draft.of]]\" variable=\"listItem\">\n<$set name=\"tv-config-toolbar-class\" filter=\"[<tv-config-toolbar-class>] [<listItem>encodeuricomponent[]addprefix[tc-btn-]]\">\n<$transclude tiddler=<<listItem>>/>\n</$set>\n</$list>\n</$keyboard>\n</$keyboard>\n</$set>\n</$fieldmangler>\n</div>\n"
},
"$:/core/ui/Buttons/cancel": {
"title": "$:/core/ui/Buttons/cancel",
"tags": "$:/tags/EditToolbar",
"caption": "{{$:/core/images/cancel-button}} {{$:/language/Buttons/Cancel/Caption}}",
"description": "{{$:/language/Buttons/Cancel/Hint}}",
"text": "<$button message=\"tm-cancel-tiddler\" tooltip={{$:/language/Buttons/Cancel/Hint}} aria-label={{$:/language/Buttons/Cancel/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/cancel-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/Cancel/Caption}}/></span>\n</$list>\n</$button>"
},
"$:/core/ui/Buttons/delete": {
"title": "$:/core/ui/Buttons/delete",
"tags": "$:/tags/EditToolbar $:/tags/ViewToolbar",
"caption": "{{$:/core/images/delete-button}} {{$:/language/Buttons/Delete/Caption}}",
"description": "{{$:/language/Buttons/Delete/Hint}}",
"text": "<$button message=\"tm-delete-tiddler\" tooltip={{$:/language/Buttons/Delete/Hint}} aria-label={{$:/language/Buttons/Delete/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/delete-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/Delete/Caption}}/></span>\n</$list>\n</$button>"
},
"$:/core/ui/Buttons/save": {
"title": "$:/core/ui/Buttons/save",
"tags": "$:/tags/EditToolbar",
"caption": "{{$:/core/images/done-button}} {{$:/language/Buttons/Save/Caption}}",
"description": "{{$:/language/Buttons/Save/Hint}}",
"text": "<$fieldmangler><$button tooltip={{$:/language/Buttons/Save/Hint}} aria-label={{$:/language/Buttons/Save/Caption}} class=<<tv-config-toolbar-class>>>\n<$action-sendmessage $message=\"tm-add-tag\" $param={{$:/temp/NewTagName}}/>\n<$action-deletetiddler $tiddler=\"$:/temp/NewTagName\"/>\n<$action-sendmessage $message=\"tm-add-field\" $name={{$:/temp/newfieldname}} $value={{$:/temp/newfieldvalue}}/>\n<$action-deletetiddler $tiddler=\"$:/temp/newfieldname\"/>\n<$action-deletetiddler $tiddler=\"$:/temp/newfieldvalue\"/>\n<$action-sendmessage $message=\"tm-save-tiddler\"/>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/done-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/Save/Caption}}/></span>\n</$list>\n</$button></$fieldmangler>\n"
},
"$:/core/ui/EditorToolbar/bold": {
"title": "$:/core/ui/EditorToolbar/bold",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/bold",
"caption": "{{$:/language/Buttons/Bold/Caption}}",
"description": "{{$:/language/Buttons/Bold/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"shortcuts": "((bold))",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"wrap-selection\"\n\tprefix=\"''\"\n\tsuffix=\"''\"\n/>\n"
},
"$:/core/ui/EditorToolbar/clear-dropdown": {
"title": "$:/core/ui/EditorToolbar/clear-dropdown",
"text": "''{{$:/language/Buttons/Clear/Hint}}''\n\n<div class=\"tc-colour-chooser\">\n\n<$macrocall $name=\"colour-picker\" actions=\"\"\"\n\n<$action-sendmessage\n\t$message=\"tm-edit-bitmap-operation\"\n\t$param=\"clear\"\n\tcolour=<<colour-picker-value>>\n/>\n\n<$action-deletetiddler\n\t$tiddler=<<dropdown-state>>\n/>\n\n\"\"\"/>\n\n</div>\n"
},
"$:/core/ui/EditorToolbar/clear": {
"title": "$:/core/ui/EditorToolbar/clear",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/erase",
"caption": "{{$:/language/Buttons/Clear/Caption}}",
"description": "{{$:/language/Buttons/Clear/Hint}}",
"condition": "[<targetTiddler>is[image]]",
"dropdown": "$:/core/ui/EditorToolbar/clear-dropdown",
"text": ""
},
"$:/core/ui/EditorToolbar/editor-height-dropdown": {
"title": "$:/core/ui/EditorToolbar/editor-height-dropdown",
"text": "\\define lingo-base() $:/language/Buttons/EditorHeight/\n''<<lingo Hint>>''\n\n<$radio tiddler=\"$:/config/TextEditor/EditorHeight/Mode\" value=\"auto\"> {{$:/core/images/auto-height}} <<lingo Caption/Auto>></$radio>\n\n<$radio tiddler=\"$:/config/TextEditor/EditorHeight/Mode\" value=\"fixed\"> {{$:/core/images/fixed-height}} <<lingo Caption/Fixed>> <$edit-text tag=\"input\" tiddler=\"$:/config/TextEditor/EditorHeight/Height\" default=\"100px\"/></$radio>\n"
},
"$:/core/ui/EditorToolbar/editor-height": {
"title": "$:/core/ui/EditorToolbar/editor-height",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/fixed-height",
"custom-icon": "yes",
"caption": "{{$:/language/Buttons/EditorHeight/Caption}}",
"description": "{{$:/language/Buttons/EditorHeight/Hint}}",
"condition": "[<targetTiddler>type[]] [<targetTiddler>get[type]prefix[text/]] +[first[]]",
"dropdown": "$:/core/ui/EditorToolbar/editor-height-dropdown",
"text": "<$reveal tag=\"span\" state=\"$:/config/TextEditor/EditorHeight/Mode\" type=\"match\" text=\"fixed\">\n{{$:/core/images/fixed-height}}\n</$reveal>\n<$reveal tag=\"span\" state=\"$:/config/TextEditor/EditorHeight/Mode\" type=\"match\" text=\"auto\">\n{{$:/core/images/auto-height}}\n</$reveal>\n"
},
"$:/core/ui/EditorToolbar/excise-dropdown": {
"title": "$:/core/ui/EditorToolbar/excise-dropdown",
"text": "\\define lingo-base() $:/language/Buttons/Excise/\n\n\\define body(config-title)\n''<<lingo Hint>>''\n\n<<lingo Caption/NewTitle>> <$edit-text tag=\"input\" tiddler=\"$config-title$/new-title\" default=\"\" focus=\"true\"/>\n\n<$set name=\"new-title\" value={{$config-title$/new-title}}>\n<$list filter=\"\"\"[<new-title>is[tiddler]]\"\"\">\n<div class=\"tc-error\">\n<<lingo Caption/TiddlerExists>>\n</div>\n</$list>\n</$set>\n\n<$checkbox tiddler=\"\"\"$config-title$/tagnew\"\"\" field=\"text\" checked=\"yes\" unchecked=\"no\" default=\"false\"> <<lingo Caption/Tag>></$checkbox>\n\n<<lingo Caption/Replace>> <$select tiddler=\"\"\"$config-title$/type\"\"\" default=\"transclude\">\n<option value=\"link\"><<lingo Caption/Replace/Link>></option>\n<option value=\"transclude\"><<lingo Caption/Replace/Transclusion>></option>\n<option value=\"macro\"><<lingo Caption/Replace/Macro>></option>\n</$select>\n\n<$reveal state=\"\"\"$config-title$/type\"\"\" type=\"match\" text=\"macro\">\n<<lingo Caption/MacroName>> <$edit-text tag=\"input\" tiddler=\"\"\"$config-title$/macro-title\"\"\" default=\"translink\"/>\n</$reveal>\n\n<$button>\n<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"excise\"\n\ttitle={{$config-title$/new-title}}\n\ttype={{$config-title$/type}}\n\tmacro={{$config-title$/macro-title}}\n\ttagnew={{$config-title$/tagnew}}\n/>\n<$action-deletetiddler\n\t$tiddler=\"$config-title$/new-title\"\n/>\n<$action-deletetiddler\n\t$tiddler=<<dropdown-state>>\n/>\n<<lingo Caption/Excise>>\n</$button>\n\\end\n\n<$macrocall $name=\"body\" config-title=<<qualify \"$:/state/Excise/\">>/>\n"
},
"$:/core/ui/EditorToolbar/excise": {
"title": "$:/core/ui/EditorToolbar/excise",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/excise",
"caption": "{{$:/language/Buttons/Excise/Caption}}",
"description": "{{$:/language/Buttons/Excise/Hint}}",
"condition": "[<targetTiddler>type[]] [<targetTiddler>type[text/vnd.tiddlywiki]] +[first[]]",
"shortcuts": "((excise))",
"dropdown": "$:/core/ui/EditorToolbar/excise-dropdown",
"text": ""
},
"$:/core/ui/EditorToolbar/heading-1": {
"title": "$:/core/ui/EditorToolbar/heading-1",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/heading-1",
"caption": "{{$:/language/Buttons/Heading1/Caption}}",
"description": "{{$:/language/Buttons/Heading1/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"button-classes": "tc-text-editor-toolbar-item-start-group",
"shortcuts": "((heading-1))",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"prefix-lines\"\n\tcharacter=\"!\"\n\tcount=\"1\"\n/>\n"
},
"$:/core/ui/EditorToolbar/heading-2": {
"title": "$:/core/ui/EditorToolbar/heading-2",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/heading-2",
"caption": "{{$:/language/Buttons/Heading2/Caption}}",
"description": "{{$:/language/Buttons/Heading2/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"shortcuts": "((heading-2))",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"prefix-lines\"\n\tcharacter=\"!\"\n\tcount=\"2\"\n/>\n"
},
"$:/core/ui/EditorToolbar/heading-3": {
"title": "$:/core/ui/EditorToolbar/heading-3",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/heading-3",
"caption": "{{$:/language/Buttons/Heading3/Caption}}",
"description": "{{$:/language/Buttons/Heading3/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"shortcuts": "((heading-3))",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"prefix-lines\"\n\tcharacter=\"!\"\n\tcount=\"3\"\n/>\n"
},
"$:/core/ui/EditorToolbar/heading-4": {
"title": "$:/core/ui/EditorToolbar/heading-4",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/heading-4",
"caption": "{{$:/language/Buttons/Heading4/Caption}}",
"description": "{{$:/language/Buttons/Heading4/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"shortcuts": "((heading-4))",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"prefix-lines\"\n\tcharacter=\"!\"\n\tcount=\"4\"\n/>\n"
},
"$:/core/ui/EditorToolbar/heading-5": {
"title": "$:/core/ui/EditorToolbar/heading-5",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/heading-5",
"caption": "{{$:/language/Buttons/Heading5/Caption}}",
"description": "{{$:/language/Buttons/Heading5/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"shortcuts": "((heading-5))",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"prefix-lines\"\n\tcharacter=\"!\"\n\tcount=\"5\"\n/>\n"
},
"$:/core/ui/EditorToolbar/heading-6": {
"title": "$:/core/ui/EditorToolbar/heading-6",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/heading-6",
"caption": "{{$:/language/Buttons/Heading6/Caption}}",
"description": "{{$:/language/Buttons/Heading6/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"shortcuts": "((heading-6))",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"prefix-lines\"\n\tcharacter=\"!\"\n\tcount=\"6\"\n/>\n"
},
"$:/core/ui/EditorToolbar/italic": {
"title": "$:/core/ui/EditorToolbar/italic",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/italic",
"caption": "{{$:/language/Buttons/Italic/Caption}}",
"description": "{{$:/language/Buttons/Italic/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"shortcuts": "((italic))",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"wrap-selection\"\n\tprefix=\"//\"\n\tsuffix=\"//\"\n/>\n"
},
"$:/core/ui/EditorToolbar/line-width-dropdown": {
"title": "$:/core/ui/EditorToolbar/line-width-dropdown",
"text": "\\define lingo-base() $:/language/Buttons/LineWidth/\n\n\\define toolbar-line-width-inner()\n<$button tag=\"a\" tooltip=\"\"\"$(line-width)$\"\"\">\n\n<$action-setfield\n\t$tiddler=\"$:/config/BitmapEditor/LineWidth\"\n\t$value=\"$(line-width)$\"\n/>\n\n<$action-deletetiddler\n\t$tiddler=<<dropdown-state>>\n/>\n\n<div style=\"display: inline-block; margin: 4px calc(80px - $(line-width)$); background-color: #000; width: calc(100px + $(line-width)$ * 2); height: $(line-width)$; border-radius: 120px; vertical-align: middle;\"/>\n\n<span style=\"margin-left: 8px;\">\n\n<$text text=\"\"\"$(line-width)$\"\"\"/>\n\n<$reveal state=\"$:/config/BitmapEditor/LineWidth\" type=\"match\" text=\"\"\"$(line-width)$\"\"\" tag=\"span\">\n\n<$entity entity=\" \"/>\n\n<$entity entity=\"✓\"/>\n\n</$reveal>\n\n</span>\n\n</$button>\n\\end\n\n''<<lingo Hint>>''\n\n<$list filter={{$:/config/BitmapEditor/LineWidths}} variable=\"line-width\">\n\n<<toolbar-line-width-inner>>\n\n</$list>\n"
},
"$:/core/ui/EditorToolbar/line-width": {
"title": "$:/core/ui/EditorToolbar/line-width",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/line-width",
"caption": "{{$:/language/Buttons/LineWidth/Caption}}",
"description": "{{$:/language/Buttons/LineWidth/Hint}}",
"condition": "[<targetTiddler>is[image]]",
"dropdown": "$:/core/ui/EditorToolbar/line-width-dropdown",
"text": "<$text text={{$:/config/BitmapEditor/LineWidth}}/>"
},
"$:/core/ui/EditorToolbar/link-dropdown": {
"title": "$:/core/ui/EditorToolbar/link-dropdown",
"text": "\\define lingo-base() $:/language/Buttons/Link/\n\n\\define add-link-actions()\n<$action-sendmessage $message=\"tm-edit-text-operation\" $param=\"make-link\" text={{$(linkTiddler)$}} />\n<$action-deletetiddler $tiddler=<<dropdown-state>> />\n<$action-deletetiddler $tiddler=<<searchTiddler>> />\n<$action-deletetiddler $tiddler=<<linkTiddler>> />\n\\end\n\n\\define external-link()\n<$button class=\"tc-btn-invisible\" style=\"width: auto; display: inline-block; background-colour: inherit;\" actions=<<add-link-actions>>>\n{{$:/core/images/chevron-right}}\n</$button>\n\\end\n\n\\define body(config-title)\n''<<lingo Hint>>''\n\n<$vars searchTiddler=\"\"\"$config-title$/search\"\"\" linkTiddler=\"\"\"$config-title$/link\"\"\" linktext=\"\" >\n\n<$vars linkTiddler=<<searchTiddler>>>\n<$keyboard key=\"ENTER\" actions=<<add-link-actions>>>\n<$edit-text tiddler=<<searchTiddler>> type=\"search\" tag=\"input\" focus=\"true\" placeholder={{$:/language/Search/Search}} default=\"\"/>\n<$reveal tag=\"span\" state=<<searchTiddler>> type=\"nomatch\" text=\"\">\n<<external-link>>\n<$button class=\"tc-btn-invisible\" style=\"width: auto; display: inline-block; background-colour: inherit;\">\n<$action-setfield $tiddler=<<searchTiddler>> text=\"\" />\n{{$:/core/images/close-button}}\n</$button>\n</$reveal>\n</$keyboard>\n</$vars>\n\n<$reveal tag=\"div\" state=<<searchTiddler>> type=\"nomatch\" text=\"\">\n\n<$linkcatcher actions=<<add-link-actions>> to=<<linkTiddler>>>\n\n{{$:/core/ui/SearchResults}}\n\n</$linkcatcher>\n\n</$reveal>\n\n</$vars>\n\n\\end\n\n<$macrocall $name=\"body\" config-title=<<qualify \"$:/state/Link/\">>/>"
},
"$:/core/ui/EditorToolbar/link": {
"title": "$:/core/ui/EditorToolbar/link",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/link",
"caption": "{{$:/language/Buttons/Link/Caption}}",
"description": "{{$:/language/Buttons/Link/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"button-classes": "tc-text-editor-toolbar-item-start-group",
"shortcuts": "((link))",
"dropdown": "$:/core/ui/EditorToolbar/link-dropdown",
"text": ""
},
"$:/core/ui/EditorToolbar/linkify": {
"title": "$:/core/ui/EditorToolbar/linkify",
"caption": "{{$:/language/Buttons/Linkify/Caption}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"description": "{{$:/language/Buttons/Linkify/Hint}}",
"icon": "$:/core/images/linkify",
"list-before": "$:/core/ui/EditorToolbar/mono-block",
"shortcuts": "((linkify))",
"tags": "$:/tags/EditorToolbar",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"wrap-selection\"\n\tprefix=\"[[\"\n\tsuffix=\"]]\"\n/>\n"
},
"$:/core/ui/EditorToolbar/list-bullet": {
"title": "$:/core/ui/EditorToolbar/list-bullet",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/list-bullet",
"caption": "{{$:/language/Buttons/ListBullet/Caption}}",
"description": "{{$:/language/Buttons/ListBullet/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"shortcuts": "((list-bullet))",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"prefix-lines\"\n\tcharacter=\"*\"\n\tcount=\"1\"\n/>\n"
},
"$:/core/ui/EditorToolbar/list-number": {
"title": "$:/core/ui/EditorToolbar/list-number",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/list-number",
"caption": "{{$:/language/Buttons/ListNumber/Caption}}",
"description": "{{$:/language/Buttons/ListNumber/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"shortcuts": "((list-number))",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"prefix-lines\"\n\tcharacter=\"#\"\n\tcount=\"1\"\n/>\n"
},
"$:/core/ui/EditorToolbar/mono-block": {
"title": "$:/core/ui/EditorToolbar/mono-block",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/mono-block",
"caption": "{{$:/language/Buttons/MonoBlock/Caption}}",
"description": "{{$:/language/Buttons/MonoBlock/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"button-classes": "tc-text-editor-toolbar-item-start-group",
"shortcuts": "((mono-block))",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"wrap-lines\"\n\tprefix=\"\n```\"\n\tsuffix=\"```\"\n/>\n"
},
"$:/core/ui/EditorToolbar/mono-line": {
"title": "$:/core/ui/EditorToolbar/mono-line",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/mono-line",
"caption": "{{$:/language/Buttons/MonoLine/Caption}}",
"description": "{{$:/language/Buttons/MonoLine/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"shortcuts": "((mono-line))",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"wrap-selection\"\n\tprefix=\"`\"\n\tsuffix=\"`\"\n/>\n"
},
"$:/core/ui/EditorToolbar/more-dropdown": {
"title": "$:/core/ui/EditorToolbar/more-dropdown",
"text": "\\define config-title()\n$:/config/EditorToolbarButtons/Visibility/$(toolbarItem)$\n\\end\n\n\\define conditional-button()\n<$list filter={{$(toolbarItem)$!!condition}} variable=\"condition\">\n<$transclude tiddler=\"$:/core/ui/EditTemplate/body/toolbar/button\" mode=\"inline\"/> <$transclude tiddler=<<toolbarItem>> field=\"description\"/>\n</$list>\n\\end\n\n<div class=\"tc-text-editor-toolbar-more\">\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/EditorToolbar]!has[draft.of]] -[[$:/core/ui/EditorToolbar/more]]\">\n<$reveal type=\"match\" state=<<config-visibility-title>> text=\"hide\" tag=\"div\">\n<<conditional-button>>\n</$reveal>\n</$list>\n</div>\n"
},
"$:/core/ui/EditorToolbar/more": {
"title": "$:/core/ui/EditorToolbar/more",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/down-arrow",
"caption": "{{$:/language/Buttons/More/Caption}}",
"description": "{{$:/language/Buttons/More/Hint}}",
"condition": "[<targetTiddler>]",
"dropdown": "$:/core/ui/EditorToolbar/more-dropdown",
"text": ""
},
"$:/core/ui/EditorToolbar/opacity-dropdown": {
"title": "$:/core/ui/EditorToolbar/opacity-dropdown",
"text": "\\define lingo-base() $:/language/Buttons/Opacity/\n\n\\define toolbar-opacity-inner()\n<$button tag=\"a\" tooltip=\"\"\"$(opacity)$\"\"\">\n\n<$action-setfield\n\t$tiddler=\"$:/config/BitmapEditor/Opacity\"\n\t$value=\"$(opacity)$\"\n/>\n\n<$action-deletetiddler\n\t$tiddler=<<dropdown-state>>\n/>\n\n<div style=\"display: inline-block; vertical-align: middle; background-color: $(current-paint-colour)$; opacity: $(opacity)$; width: 1em; height: 1em; border-radius: 50%;\"/>\n\n<span style=\"margin-left: 8px;\">\n\n<$text text=\"\"\"$(opacity)$\"\"\"/>\n\n<$reveal state=\"$:/config/BitmapEditor/Opacity\" type=\"match\" text=\"\"\"$(opacity)$\"\"\" tag=\"span\">\n\n<$entity entity=\" \"/>\n\n<$entity entity=\"✓\"/>\n\n</$reveal>\n\n</span>\n\n</$button>\n\\end\n\n\\define toolbar-opacity()\n''<<lingo Hint>>''\n\n<$list filter={{$:/config/BitmapEditor/Opacities}} variable=\"opacity\">\n\n<<toolbar-opacity-inner>>\n\n</$list>\n\\end\n\n<$set name=\"current-paint-colour\" value={{$:/config/BitmapEditor/Colour}}>\n\n<$set name=\"current-opacity\" value={{$:/config/BitmapEditor/Opacity}}>\n\n<<toolbar-opacity>>\n\n</$set>\n\n</$set>\n"
},
"$:/core/ui/EditorToolbar/opacity": {
"title": "$:/core/ui/EditorToolbar/opacity",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/opacity",
"caption": "{{$:/language/Buttons/Opacity/Caption}}",
"description": "{{$:/language/Buttons/Opacity/Hint}}",
"condition": "[<targetTiddler>is[image]]",
"dropdown": "$:/core/ui/EditorToolbar/opacity-dropdown",
"text": "<$text text={{$:/config/BitmapEditor/Opacity}}/>\n"
},
"$:/core/ui/EditorToolbar/paint-dropdown": {
"title": "$:/core/ui/EditorToolbar/paint-dropdown",
"text": "''{{$:/language/Buttons/Paint/Hint}}''\n\n<$macrocall $name=\"colour-picker\" actions=\"\"\"\n\n<$action-setfield\n\t$tiddler=\"$:/config/BitmapEditor/Colour\"\n\t$value=<<colour-picker-value>>\n/>\n\n<$action-deletetiddler\n\t$tiddler=<<dropdown-state>>\n/>\n\n\"\"\"/>\n"
},
"$:/core/ui/EditorToolbar/paint": {
"title": "$:/core/ui/EditorToolbar/paint",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/paint",
"caption": "{{$:/language/Buttons/Paint/Caption}}",
"description": "{{$:/language/Buttons/Paint/Hint}}",
"condition": "[<targetTiddler>is[image]]",
"dropdown": "$:/core/ui/EditorToolbar/paint-dropdown",
"text": "\\define toolbar-paint()\n<div style=\"display: inline-block; vertical-align: middle; background-color: $(colour-picker-value)$; width: 1em; height: 1em; border-radius: 50%;\"/>\n\\end\n<$set name=\"colour-picker-value\" value={{$:/config/BitmapEditor/Colour}}>\n<<toolbar-paint>>\n</$set>\n"
},
"$:/core/ui/EditorToolbar/picture-dropdown": {
"title": "$:/core/ui/EditorToolbar/picture-dropdown",
"text": "\\define replacement-text()\n[img[$(imageTitle)$]]\n\\end\n\n''{{$:/language/Buttons/Picture/Hint}}''\n\n<$macrocall $name=\"image-picker\" actions=\"\"\"\n\n<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"replace-selection\"\n\ttext=<<replacement-text>>\n/>\n\n<$action-deletetiddler\n\t$tiddler=<<dropdown-state>>\n/>\n\n\"\"\"/>\n"
},
"$:/core/ui/EditorToolbar/picture": {
"title": "$:/core/ui/EditorToolbar/picture",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/picture",
"caption": "{{$:/language/Buttons/Picture/Caption}}",
"description": "{{$:/language/Buttons/Picture/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"shortcuts": "((picture))",
"dropdown": "$:/core/ui/EditorToolbar/picture-dropdown",
"text": ""
},
"$:/core/ui/EditorToolbar/preview-type-dropdown": {
"title": "$:/core/ui/EditorToolbar/preview-type-dropdown",
"text": "\\define preview-type-button()\n<$button tag=\"a\">\n\n<$action-setfield $tiddler=\"$:/state/editpreviewtype\" $value=\"$(previewType)$\"/>\n\n<$action-deletetiddler\n\t$tiddler=<<dropdown-state>>\n/>\n\n<$transclude tiddler=<<previewType>> field=\"caption\" mode=\"inline\">\n\n<$view tiddler=<<previewType>> field=\"title\" mode=\"inline\"/>\n\n</$transclude> \n\n<$reveal tag=\"span\" state=\"$:/state/editpreviewtype\" type=\"match\" text=<<previewType>> default=\"$:/core/ui/EditTemplate/body/preview/output\">\n\n<$entity entity=\" \"/>\n\n<$entity entity=\"✓\"/>\n\n</$reveal>\n\n</$button>\n\\end\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/EditPreview]!has[draft.of]]\" variable=\"previewType\">\n\n<<preview-type-button>>\n\n</$list>\n"
},
"$:/core/ui/EditorToolbar/preview-type": {
"title": "$:/core/ui/EditorToolbar/preview-type",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/chevron-down",
"caption": "{{$:/language/Buttons/PreviewType/Caption}}",
"description": "{{$:/language/Buttons/PreviewType/Hint}}",
"condition": "[all[shadows+tiddlers]tag[$:/tags/EditPreview]!has[draft.of]butfirst[]limit[1]]",
"button-classes": "tc-text-editor-toolbar-item-adjunct",
"dropdown": "$:/core/ui/EditorToolbar/preview-type-dropdown"
},
"$:/core/ui/EditorToolbar/preview": {
"title": "$:/core/ui/EditorToolbar/preview",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/preview-open",
"custom-icon": "yes",
"caption": "{{$:/language/Buttons/Preview/Caption}}",
"description": "{{$:/language/Buttons/Preview/Hint}}",
"condition": "[<targetTiddler>]",
"button-classes": "tc-text-editor-toolbar-item-start-group",
"shortcuts": "((preview))",
"text": "<$reveal state=\"$:/state/showeditpreview\" type=\"match\" text=\"yes\" tag=\"span\">\n{{$:/core/images/preview-open}}\n<$action-setfield $tiddler=\"$:/state/showeditpreview\" $value=\"no\"/>\n</$reveal>\n<$reveal state=\"$:/state/showeditpreview\" type=\"nomatch\" text=\"yes\" tag=\"span\">\n{{$:/core/images/preview-closed}}\n<$action-setfield $tiddler=\"$:/state/showeditpreview\" $value=\"yes\"/>\n</$reveal>\n"
},
"$:/core/ui/EditorToolbar/quote": {
"title": "$:/core/ui/EditorToolbar/quote",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/quote",
"caption": "{{$:/language/Buttons/Quote/Caption}}",
"description": "{{$:/language/Buttons/Quote/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"shortcuts": "((quote))",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"wrap-lines\"\n\tprefix=\"\n<<<\"\n\tsuffix=\"<<<\"\n/>\n"
},
"$:/core/ui/EditorToolbar/rotate-left": {
"title": "$:/core/ui/EditorToolbar/rotate-left",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/rotate-left",
"caption": "{{$:/language/Buttons/RotateLeft/Caption}}",
"description": "{{$:/language/Buttons/RotateLeft/Hint}}",
"condition": "[<targetTiddler>is[image]]",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-bitmap-operation\"\n\t$param=\"rotate-left\"\n/>\n"
},
"$:/core/ui/EditorToolbar/size-dropdown": {
"title": "$:/core/ui/EditorToolbar/size-dropdown",
"text": "\\define lingo-base() $:/language/Buttons/Size/\n\n\\define toolbar-button-size-preset(config-title)\n<$set name=\"width\" filter=\"$(sizePair)$ +[first[]]\">\n\n<$set name=\"height\" filter=\"$(sizePair)$ +[last[]]\">\n\n<$button tag=\"a\">\n\n<$action-setfield\n\t$tiddler=\"\"\"$config-title$/new-width\"\"\"\n\t$value=<<width>>\n/>\n\n<$action-setfield\n\t$tiddler=\"\"\"$config-title$/new-height\"\"\"\n\t$value=<<height>>\n/>\n\n<$action-deletetiddler\n\t$tiddler=\"\"\"$config-title$/presets-popup\"\"\"\n/>\n\n<$text text=<<width>>/> × <$text text=<<height>>/>\n\n</$button>\n\n</$set>\n\n</$set>\n\\end\n\n\\define toolbar-button-size(config-title)\n''{{$:/language/Buttons/Size/Hint}}''\n\n<<lingo Caption/Width>> <$edit-text tag=\"input\" tiddler=\"\"\"$config-title$/new-width\"\"\" default=<<tv-bitmap-editor-width>> focus=\"true\" size=\"8\"/> <<lingo Caption/Height>> <$edit-text tag=\"input\" tiddler=\"\"\"$config-title$/new-height\"\"\" default=<<tv-bitmap-editor-height>> size=\"8\"/> <$button popup=\"\"\"$config-title$/presets-popup\"\"\" class=\"tc-btn-invisible tc-popup-keep\" style=\"width: auto; display: inline-block; background-colour: inherit;\" selectedClass=\"tc-selected\">\n{{$:/core/images/down-arrow}}\n</$button>\n\n<$reveal tag=\"span\" state=\"\"\"$config-title$/presets-popup\"\"\" type=\"popup\" position=\"belowleft\" animate=\"yes\">\n\n<div class=\"tc-drop-down tc-popup-keep\">\n\n<$list filter={{$:/config/BitmapEditor/ImageSizes}} variable=\"sizePair\">\n\n<$macrocall $name=\"toolbar-button-size-preset\" config-title=\"$config-title$\"/>\n\n</$list>\n\n</div>\n\n</$reveal>\n\n<$button>\n<$action-sendmessage\n\t$message=\"tm-edit-bitmap-operation\"\n\t$param=\"resize\"\n\twidth={{$config-title$/new-width}}\n\theight={{$config-title$/new-height}}\n/>\n<$action-deletetiddler\n\t$tiddler=\"\"\"$config-title$/new-width\"\"\"\n/>\n<$action-deletetiddler\n\t$tiddler=\"\"\"$config-title$/new-height\"\"\"\n/>\n<$action-deletetiddler\n\t$tiddler=<<dropdown-state>>\n/>\n<<lingo Caption/Resize>>\n</$button>\n\\end\n\n<$macrocall $name=\"toolbar-button-size\" config-title=<<qualify \"$:/state/Size/\">>/>\n"
},
"$:/core/ui/EditorToolbar/size": {
"title": "$:/core/ui/EditorToolbar/size",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/size",
"caption": "{{$:/language/Buttons/Size/Caption}}",
"description": "{{$:/language/Buttons/Size/Hint}}",
"condition": "[<targetTiddler>is[image]]",
"dropdown": "$:/core/ui/EditorToolbar/size-dropdown",
"text": ""
},
"$:/core/ui/EditorToolbar/stamp-dropdown": {
"title": "$:/core/ui/EditorToolbar/stamp-dropdown",
"text": "\\define toolbar-button-stamp-inner()\n<$button tag=\"a\">\n\n<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"replace-selection\"\n\ttext={{$(snippetTitle)$}}\n/>\n\n<$action-deletetiddler\n\t$tiddler=<<dropdown-state>>\n/>\n\n<$view tiddler=<<snippetTitle>> field=\"caption\" mode=\"inline\">\n\n<$view tiddler=<<snippetTitle>> field=\"title\" mode=\"inline\"/>\n\n</$view>\n\n</$button>\n\\end\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/TextEditor/Snippet]!has[draft.of]sort[caption]]\" variable=\"snippetTitle\">\n\n<<toolbar-button-stamp-inner>>\n\n</$list>\n\n----\n\n<$button tag=\"a\">\n\n<$action-sendmessage\n\t$message=\"tm-new-tiddler\"\n\ttags=\"$:/tags/TextEditor/Snippet\"\n\tcaption={{$:/language/Buttons/Stamp/New/Title}}\n\ttext={{$:/language/Buttons/Stamp/New/Text}}\n/>\n\n<$action-deletetiddler\n\t$tiddler=<<dropdown-state>>\n/>\n\n<em>\n\n<$text text={{$:/language/Buttons/Stamp/Caption/New}}/>\n\n</em>\n\n</$button>\n"
},
"$:/core/ui/EditorToolbar/stamp": {
"title": "$:/core/ui/EditorToolbar/stamp",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/stamp",
"caption": "{{$:/language/Buttons/Stamp/Caption}}",
"description": "{{$:/language/Buttons/Stamp/Hint}}",
"condition": "[<targetTiddler>type[]] [<targetTiddler>get[type]prefix[text/]] +[first[]]",
"shortcuts": "((stamp))",
"dropdown": "$:/core/ui/EditorToolbar/stamp-dropdown",
"text": ""
},
"$:/core/ui/EditorToolbar/strikethrough": {
"title": "$:/core/ui/EditorToolbar/strikethrough",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/strikethrough",
"caption": "{{$:/language/Buttons/Strikethrough/Caption}}",
"description": "{{$:/language/Buttons/Strikethrough/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"shortcuts": "((strikethrough))",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"wrap-selection\"\n\tprefix=\"~~\"\n\tsuffix=\"~~\"\n/>\n"
},
"$:/core/ui/EditorToolbar/subscript": {
"title": "$:/core/ui/EditorToolbar/subscript",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/subscript",
"caption": "{{$:/language/Buttons/Subscript/Caption}}",
"description": "{{$:/language/Buttons/Subscript/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"shortcuts": "((subscript))",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"wrap-selection\"\n\tprefix=\",,\"\n\tsuffix=\",,\"\n/>\n"
},
"$:/core/ui/EditorToolbar/superscript": {
"title": "$:/core/ui/EditorToolbar/superscript",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/superscript",
"caption": "{{$:/language/Buttons/Superscript/Caption}}",
"description": "{{$:/language/Buttons/Superscript/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"shortcuts": "((superscript))",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"wrap-selection\"\n\tprefix=\"^^\"\n\tsuffix=\"^^\"\n/>\n"
},
"$:/core/ui/EditorToolbar/transcludify": {
"title": "$:/core/ui/EditorToolbar/transcludify",
"caption": "{{$:/language/Buttons/Transcludify/Caption}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"description": "{{$:/language/Buttons/Transcludify/Hint}}",
"icon": "$:/core/images/transcludify",
"list-before": "$:/core/ui/EditorToolbar/mono-block",
"shortcuts": "((transcludify))",
"tags": "$:/tags/EditorToolbar",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"wrap-selection\"\n\tprefix=\"{{\"\n\tsuffix=\"}}\"\n/>\n"
},
"$:/core/ui/EditorToolbar/underline": {
"title": "$:/core/ui/EditorToolbar/underline",
"tags": "$:/tags/EditorToolbar",
"icon": "$:/core/images/underline",
"caption": "{{$:/language/Buttons/Underline/Caption}}",
"description": "{{$:/language/Buttons/Underline/Hint}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"shortcuts": "((underline))",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"wrap-selection\"\n\tprefix=\"__\"\n\tsuffix=\"__\"\n/>\n"
},
"$:/core/Filters/AllTags": {
"title": "$:/core/Filters/AllTags",
"tags": "$:/tags/Filter",
"filter": "[tags[]!is[system]sort[title]]",
"description": "{{$:/language/Filters/AllTags}}",
"text": ""
},
"$:/core/Filters/AllTiddlers": {
"title": "$:/core/Filters/AllTiddlers",
"tags": "$:/tags/Filter",
"filter": "[!is[system]sort[title]]",
"description": "{{$:/language/Filters/AllTiddlers}}",
"text": ""
},
"$:/core/Filters/Drafts": {
"title": "$:/core/Filters/Drafts",
"tags": "$:/tags/Filter",
"filter": "[has[draft.of]sort[title]]",
"description": "{{$:/language/Filters/Drafts}}",
"text": ""
},
"$:/core/Filters/Missing": {
"title": "$:/core/Filters/Missing",
"tags": "$:/tags/Filter",
"filter": "[all[missing]sort[title]]",
"description": "{{$:/language/Filters/Missing}}",
"text": ""
},
"$:/core/Filters/Orphans": {
"title": "$:/core/Filters/Orphans",
"tags": "$:/tags/Filter",
"filter": "[all[orphans]sort[title]]",
"description": "{{$:/language/Filters/Orphans}}",
"text": ""
},
"$:/core/Filters/OverriddenShadowTiddlers": {
"title": "$:/core/Filters/OverriddenShadowTiddlers",
"tags": "$:/tags/Filter",
"filter": "[is[shadow]]",
"description": "{{$:/language/Filters/OverriddenShadowTiddlers}}",
"text": ""
},
"$:/core/Filters/RecentSystemTiddlers": {
"title": "$:/core/Filters/RecentSystemTiddlers",
"tags": "$:/tags/Filter",
"filter": "[has[modified]!sort[modified]limit[50]]",
"description": "{{$:/language/Filters/RecentSystemTiddlers}}",
"text": ""
},
"$:/core/Filters/RecentTiddlers": {
"title": "$:/core/Filters/RecentTiddlers",
"tags": "$:/tags/Filter",
"filter": "[!is[system]has[modified]!sort[modified]limit[50]]",
"description": "{{$:/language/Filters/RecentTiddlers}}",
"text": ""
},
"$:/core/Filters/ShadowTiddlers": {
"title": "$:/core/Filters/ShadowTiddlers",
"tags": "$:/tags/Filter",
"filter": "[all[shadows]sort[title]]",
"description": "{{$:/language/Filters/ShadowTiddlers}}",
"text": ""
},
"$:/core/Filters/StoryList": {
"title": "$:/core/Filters/StoryList",
"tags": "$:/tags/Filter",
"filter": "[list[$:/StoryList]] -$:/AdvancedSearch",
"description": "{{$:/language/Filters/StoryList}}",
"text": ""
},
"$:/core/Filters/SystemTags": {
"title": "$:/core/Filters/SystemTags",
"tags": "$:/tags/Filter",
"filter": "[all[shadows+tiddlers]tags[]is[system]sort[title]]",
"description": "{{$:/language/Filters/SystemTags}}",
"text": ""
},
"$:/core/Filters/SystemTiddlers": {
"title": "$:/core/Filters/SystemTiddlers",
"tags": "$:/tags/Filter",
"filter": "[is[system]sort[title]]",
"description": "{{$:/language/Filters/SystemTiddlers}}",
"text": ""
},
"$:/core/Filters/TypedTiddlers": {
"title": "$:/core/Filters/TypedTiddlers",
"tags": "$:/tags/Filter",
"filter": "[!is[system]has[type]each[type]sort[type]] -[type[text/vnd.tiddlywiki]]",
"description": "{{$:/language/Filters/TypedTiddlers}}",
"text": ""
},
"$:/core/ui/ImportListing": {
"title": "$:/core/ui/ImportListing",
"text": "\\define lingo-base() $:/language/Import/\n\n\\define messageField()\nmessage-$(payloadTiddler)$\n\\end\n\n\\define selectionField()\nselection-$(payloadTiddler)$\n\\end\n\n\\define previewPopupState()\n$(currentTiddler)$!!popup-$(payloadTiddler)$\n\\end\n\n\\define select-all-actions()\n<$list filter=\"[all[current]plugintiddlers[]sort[title]]\" variable=\"payloadTiddler\">\n<$action-setfield $field={{{ [<payloadTiddler>addprefix[selection-]] }}} $value={{$:/state/import/select-all}}/>\n</$list>\n\\end\n\n<table>\n<tbody>\n<tr>\n<th>\n<$checkbox tiddler=\"$:/state/import/select-all\" field=\"text\" checked=\"checked\" unchecked=\"unchecked\" default=\"checked\" actions=<<select-all-actions>>>\n<<lingo Listing/Select/Caption>>\n</$checkbox>\n</th>\n<th>\n<<lingo Listing/Title/Caption>>\n</th>\n<th>\n<<lingo Listing/Status/Caption>>\n</th>\n</tr>\n<$list filter=\"[all[current]plugintiddlers[]sort[title]]\" variable=\"payloadTiddler\">\n<tr>\n<td>\n<$checkbox field=<<selectionField>> checked=\"checked\" unchecked=\"unchecked\" default=\"checked\"/>\n</td>\n<td>\n<$reveal type=\"nomatch\" stateTitle=<<previewPopupState>> text=\"yes\" tag=\"div\">\n<$button class=\"tc-btn-invisible tc-btn-dropdown\" setTitle=<<previewPopupState>> setTo=\"yes\">\n{{$:/core/images/right-arrow}} <$text text=<<payloadTiddler>>/>\n</$button>\n</$reveal>\n<$reveal type=\"match\" stateTitle=<<previewPopupState>> text=\"yes\" tag=\"div\">\n<$button class=\"tc-btn-invisible tc-btn-dropdown\" setTitle=<<previewPopupState>> setTo=\"no\">\n{{$:/core/images/down-arrow}} <$text text=<<payloadTiddler>>/>\n</$button>\n</$reveal>\n</td>\n<td>\n<$view field=<<messageField>>/>\n</td>\n</tr>\n<tr>\n<td colspan=\"3\">\n<$reveal type=\"match\" text=\"yes\" stateTitle=<<previewPopupState>> tag=\"div\">\n<$list filter=\"[{$:/state/importpreviewtype}has[text]]\" variable=\"listItem\" emptyMessage={{$:/core/ui/ImportPreviews/Text}}>\n<$transclude tiddler={{$:/state/importpreviewtype}}/>\n</$list>\n</$reveal>\n</td>\n</tr>\n</$list>\n</tbody>\n</table>\n"
},
"$:/core/ui/ImportPreviews/Diff": {
"title": "$:/core/ui/ImportPreviews/Diff",
"tags": "$:/tags/ImportPreview",
"caption": "{{$:/language/Import/Listing/Preview/Diff}}",
"text": "<$macrocall $name=\"compareTiddlerText\" sourceTiddlerTitle=<<payloadTiddler>> destTiddlerTitle=<<currentTiddler>> destSubTiddlerTitle=<<payloadTiddler>>/>\n"
},
"$:/core/ui/ImportPreviews/DiffFields": {
"title": "$:/core/ui/ImportPreviews/DiffFields",
"tags": "$:/tags/ImportPreview",
"caption": "{{$:/language/Import/Listing/Preview/DiffFields}}",
"text": "<$macrocall $name=\"compareTiddlers\" sourceTiddlerTitle=<<payloadTiddler>> destTiddlerTitle=<<currentTiddler>> destSubTiddlerTitle=<<payloadTiddler>> exclude=\"text\"/>\n"
},
"$:/core/ui/ImportPreviews/Fields": {
"title": "$:/core/ui/ImportPreviews/Fields",
"tags": "$:/tags/ImportPreview",
"caption": "{{$:/language/Import/Listing/Preview/Fields}}",
"text": "<table class=\"tc-view-field-table\">\n<tbody>\n<$list filter=\"[<payloadTiddler>subtiddlerfields<currentTiddler>sort[]] -text\" variable=\"fieldName\">\n<tr class=\"tc-view-field\">\n<td class=\"tc-view-field-name\">\n<$text text=<<fieldName>>/>\n</td>\n<td class=\"tc-view-field-value\">\n<$view field=<<fieldName>> tiddler=<<currentTiddler>> subtiddler=<<payloadTiddler>>/>\n</td>\n</tr>\n</$list>\n</tbody>\n</table>\n"
},
"$:/core/ui/ImportPreviews/Text": {
"title": "$:/core/ui/ImportPreviews/Text",
"tags": "$:/tags/ImportPreview",
"caption": "{{$:/language/Import/Listing/Preview/Text}}",
"text": "<$transclude tiddler=<<currentTiddler>> subtiddler=<<payloadTiddler>> mode=\"block\"/>\n"
},
"$:/core/ui/ImportPreviews/TextRaw": {
"title": "$:/core/ui/ImportPreviews/TextRaw",
"tags": "$:/tags/ImportPreview",
"caption": "{{$:/language/Import/Listing/Preview/TextRaw}}",
"text": "<pre><code><$view tiddler=<<currentTiddler>> subtiddler=<<payloadTiddler>> /></code></pre>"
},
"$:/core/ui/KeyboardShortcuts/new-image": {
"title": "$:/core/ui/KeyboardShortcuts/new-image",
"tags": "$:/tags/KeyboardShortcut",
"key": "((new-image))",
"text": "<$navigator story=\"$:/StoryList\" history=\"$:/HistoryList\" openLinkFromInsideRiver={{$:/config/Navigation/openLinkFromInsideRiver}} openLinkFromOutsideRiver={{$:/config/Navigation/openLinkFromOutsideRiver}} relinkOnRename={{$:/config/RelinkOnRename}}>\n{{$:/core/ui/Actions/new-image}}\n</$navigator>\n"
},
"$:/core/ui/KeyboardShortcuts/new-journal": {
"title": "$:/core/ui/KeyboardShortcuts/new-journal",
"tags": "$:/tags/KeyboardShortcut",
"key": "((new-journal))",
"text": "<$navigator story=\"$:/StoryList\" history=\"$:/HistoryList\" openLinkFromInsideRiver={{$:/config/Navigation/openLinkFromInsideRiver}} openLinkFromOutsideRiver={{$:/config/Navigation/openLinkFromOutsideRiver}} relinkOnRename={{$:/config/RelinkOnRename}}>\n{{$:/core/ui/Actions/new-journal}}\n</$navigator>\n"
},
"$:/core/ui/KeyboardShortcuts/new-tiddler": {
"title": "$:/core/ui/KeyboardShortcuts/new-tiddler",
"tags": "$:/tags/KeyboardShortcut",
"key": "((new-tiddler))",
"text": "<$navigator story=\"$:/StoryList\" history=\"$:/HistoryList\" openLinkFromInsideRiver={{$:/config/Navigation/openLinkFromInsideRiver}} openLinkFromOutsideRiver={{$:/config/Navigation/openLinkFromOutsideRiver}} relinkOnRename={{$:/config/RelinkOnRename}}>\n{{$:/core/ui/Actions/new-tiddler}}\n</$navigator>\n"
},
"$:/core/ui/ListItemTemplate": {
"title": "$:/core/ui/ListItemTemplate",
"text": "<div class=\"tc-menu-list-item\">\n<$link to={{!!title}}>\n<$view field=\"title\"/>\n</$link>\n</div>"
},
"$:/Manager/ItemMain/Fields": {
"title": "$:/Manager/ItemMain/Fields",
"tags": "$:/tags/Manager/ItemMain",
"caption": "{{$:/language/Manager/Item/Fields}}",
"text": "<table>\n<tbody>\n<$list filter=\"[all[current]fields[]sort[title]] -text\" template=\"$:/core/ui/TiddlerFieldTemplate\" variable=\"listItem\"/>\n</tbody>\n</table>\n"
},
"$:/Manager/ItemMain/RawText": {
"title": "$:/Manager/ItemMain/RawText",
"tags": "$:/tags/Manager/ItemMain",
"caption": "{{$:/language/Manager/Item/RawText}}",
"text": "<pre><code><$view/></code></pre>\n"
},
"$:/Manager/ItemMain/WikifiedText": {
"title": "$:/Manager/ItemMain/WikifiedText",
"tags": "$:/tags/Manager/ItemMain",
"caption": "{{$:/language/Manager/Item/WikifiedText}}",
"text": "<$transclude mode=\"block\"/>\n"
},
"$:/Manager/ItemSidebar/Colour": {
"title": "$:/Manager/ItemSidebar/Colour",
"tags": "$:/tags/Manager/ItemSidebar",
"caption": "{{$:/language/Manager/Item/Colour}}",
"text": "\\define swatch-styles()\nheight: 1em;\nbackground-color: $(colour)$\n\\end\n\n<$vars colour={{!!color}}>\n<p style=<<swatch-styles>>/>\n</$vars>\n<p>\n<$edit-text field=\"color\" tag=\"input\" type=\"color\"/> / <$edit-text field=\"color\" tag=\"input\" type=\"text\" size=\"9\"/>\n</p>\n"
},
"$:/Manager/ItemSidebar/Icon": {
"title": "$:/Manager/ItemSidebar/Icon",
"tags": "$:/tags/Manager/ItemSidebar",
"caption": "{{$:/language/Manager/Item/Icon}}",
"text": "<p>\n<div class=\"tc-manager-icon-editor\">\n<$button popup=<<qualify \"$:/state/popup/image-picker\">> class=\"tc-btn-invisible\">\n<$transclude tiddler={{!!icon}}>\n{{$:/language/Manager/Item/Icon/None}}\n</$transclude>\n</$button>\n<div class=\"tc-block-dropdown-wrapper\" style=\"position: static;\">\n<$reveal state=<<qualify \"$:/state/popup/image-picker\">> type=\"nomatch\" text=\"\" default=\"\" tag=\"div\" class=\"tc-popup\">\n<div class=\"tc-block-dropdown tc-popup-keep\" style=\"width: 80%; left: 10%; right: 10%; padding: 0.5em;\">\n<$macrocall $name=\"image-picker-include-tagged-images\" actions=\"\"\"\n<$action-setfield $field=\"icon\" $value=<<imageTitle>>/>\n<$action-deletetiddler $tiddler=<<qualify \"$:/state/popup/image-picker\">>/>\n\"\"\"/>\n</div>\n</$reveal>\n</div>\n</div>\n</p>\n"
},
"$:/Manager/ItemSidebar/Tags": {
"title": "$:/Manager/ItemSidebar/Tags",
"tags": "$:/tags/Manager/ItemSidebar",
"caption": "{{$:/language/Manager/Item/Tags}}",
"text": "\\define tag-checkbox-actions()\n<$action-listops\n\t$tiddler=\"$:/config/Manager/RecentTags\"\n\t$subfilter=\"[<tag>] [list[$:/config/Manager/RecentTags]] +[limit[12]]\"\n/>\n\\end\n\n\\define tag-picker-actions()\n<<tag-checkbox-actions>>\n<$action-listops\n\t$tiddler=<<currentTiddler>>\n\t$field=\"tags\"\n\t$subfilter=\"[<tag>] [all[current]tags[]]\"\n/>\n\\end\n\n<p>\n<$list filter=\"[all[current]tags[]] [list[$:/config/Manager/RecentTags]] +[sort[title]] \" variable=\"tag\">\n<div>\n<$checkbox tiddler=<<currentTiddler>> tag=<<tag>> actions=<<tag-checkbox-actions>>>\n<$macrocall $name=\"tag-pill\" tag=<<tag>>/>\n</$checkbox>\n</div>\n</$list>\n</p>\n<p>\n<$macrocall $name=\"tag-picker\" actions=<<tag-picker-actions>>/>\n</p>\n"
},
"$:/Manager/ItemSidebar/Tools": {
"title": "$:/Manager/ItemSidebar/Tools",
"tags": "$:/tags/Manager/ItemSidebar",
"caption": "{{$:/language/Manager/Item/Tools}}",
"text": "<p>\n<$button to=<<currentTiddler>>>{{$:/core/images/link}} open</$button>\n</p>\n<p>\n<$button message=\"tm-edit-tiddler\" param=<<currentTiddler>>>{{$:/core/images/edit-button}} edit</$button>\n</p>\n"
},
"$:/Manager": {
"title": "$:/Manager",
"icon": "$:/core/images/list",
"color": "#bbb",
"text": "\\define lingo-base() $:/language/Manager/\n\n\\define list-item-content-item()\n<div class=\"tc-manager-list-item-content-item\">\n\t<$vars state-title=\"\"\"$:/state/popup/manager/item/$(listItem)$\"\"\">\n\t\t<$reveal state=<<state-title>> type=\"match\" text=\"show\" default=\"show\" tag=\"div\">\n\t\t\t<$button set=<<state-title>> setTo=\"hide\" class=\"tc-btn-invisible tc-manager-list-item-content-item-heading\">\n\t\t\t\t{{$:/core/images/down-arrow}} <$transclude tiddler=<<listItem>> field=\"caption\"/>\n\t\t\t</$button>\n\t\t</$reveal>\n\t\t<$reveal state=<<state-title>> type=\"nomatch\" text=\"show\" default=\"show\" tag=\"div\">\n\t\t\t<$button set=<<state-title>> setTo=\"show\" class=\"tc-btn-invisible tc-manager-list-item-content-item-heading\">\n\t\t\t\t{{$:/core/images/right-arrow}} <$transclude tiddler=<<listItem>> field=\"caption\"/>\n\t\t\t</$button>\n\t\t</$reveal>\n\t\t<$reveal state=<<state-title>> type=\"match\" text=\"show\" default=\"show\" tag=\"div\" class=\"tc-manager-list-item-content-item-body\">\n\t\t\t<$transclude tiddler=<<listItem>>/>\n\t\t</$reveal>\n\t</$vars>\n</div>\n\\end\n\n<div class=\"tc-manager-wrapper\">\n\t<div class=\"tc-manager-controls\">\n\t\t<div class=\"tc-manager-control\">\n\t\t\t<<lingo Controls/Show/Prompt>> <$select tiddler=\"$:/config/Manager/Show\" default=\"tiddlers\">\n\t\t\t\t<option value=\"tiddlers\"><<lingo Controls/Show/Option/Tiddlers>></option>\n\t\t\t\t<option value=\"tags\"><<lingo Controls/Show/Option/Tags>></option>\n\t\t\t</$select>\n\t\t</div>\n\t\t<div class=\"tc-manager-control\">\n\t\t\t<<lingo Controls/Search/Prompt>> <$edit-text tiddler=\"$:/config/Manager/Filter\" tag=\"input\" default=\"\" placeholder={{$:/language/Manager/Controls/Search/Placeholder}}/>\n\t\t</div>\n\t\t<div class=\"tc-manager-control\">\n\t\t\t<<lingo Controls/FilterByTag/Prompt>> <$select tiddler=\"$:/config/Manager/Tag\" default=\"\">\n\t\t\t\t<option value=\"\"><<lingo Controls/FilterByTag/None>></option>\n\t\t\t\t<$list filter=\"[!is{$:/config/Manager/System}tags[]!is[system]sort[title]]\" variable=\"tag\">\n\t\t\t\t\t<option value=<<tag>>><$text text=<<tag>>/></option>\n\t\t\t\t</$list>\n\t\t\t</$select>\n\t\t</div>\n\t\t<div class=\"tc-manager-control\">\n\t\t\t<<lingo Controls/Sort/Prompt>> <$select tiddler=\"$:/config/Manager/Sort\" default=\"title\">\n\t\t\t\t<optgroup label=\"Common\">\n\t\t\t\t\t<$list filter=\"title modified modifier created creator created\" variable=\"field\">\n\t\t\t\t\t\t<option value=<<field>>><$text text=<<field>>/></option>\n\t\t\t\t\t</$list>\n\t\t\t\t</optgroup>\n\t\t\t\t<optgroup label=\"All\">\n\t\t\t\t\t<$list filter=\"[all{$:/config/Manager/Show}!is{$:/config/Manager/System}fields[]sort[title]] -title -modified -modifier -created -creator -created\" variable=\"field\">\n\t\t\t\t\t\t<option value=<<field>>><$text text=<<field>>/></option>\n\t\t\t\t\t</$list>\n\t\t\t\t</optgroup>\n\t\t\t</$select>\n\t\t\t<$checkbox tiddler=\"$:/config/Manager/Order\" field=\"text\" checked=\"reverse\" unchecked=\"forward\" default=\"forward\">\n\t\t\t\t<<lingo Controls/Order/Prompt>>\n\t\t\t</$checkbox>\n\t\t</div>\n\t\t<div class=\"tc-manager-control\">\n\t\t\t<$checkbox tiddler=\"$:/config/Manager/System\" field=\"text\" checked=\"\" unchecked=\"system\" default=\"system\">\n\t\t\t\t{{$:/language/SystemTiddlers/Include/Prompt}}\n\t\t\t</$checkbox>\n\t\t</div>\n\t</div>\n\t<div class=\"tc-manager-list\">\n\t\t<$list filter=\"[all{$:/config/Manager/Show}!is{$:/config/Manager/System}search{$:/config/Manager/Filter}tag:strict{$:/config/Manager/Tag}sort{$:/config/Manager/Sort}order{$:/config/Manager/Order}]\">\n\t\t\t<$vars transclusion=<<currentTiddler>>>\n\t\t\t\t<div style=\"tc-manager-list-item\">\n\t\t\t\t\t<$button popup=<<qualify \"$:/state/manager/popup\">> class=\"tc-btn-invisible tc-manager-list-item-heading\" selectedClass=\"tc-manager-list-item-heading-selected\">\n\t\t\t\t\t\t<$text text=<<currentTiddler>>/>\n\t\t\t\t\t</$button>\n\t\t\t\t\t<$reveal state=<<qualify \"$:/state/manager/popup\">> type=\"nomatch\" text=\"\" default=\"\" tag=\"div\" class=\"tc-manager-list-item-content tc-popup-handle\">\n\t\t\t\t\t\t<div class=\"tc-manager-list-item-content-tiddler\">\n\t\t\t\t\t\t\t<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/Manager/ItemMain]!has[draft.of]]\" variable=\"listItem\">\n\t\t\t\t\t\t\t\t<<list-item-content-item>>\n\t\t\t\t\t\t\t</$list>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t\t<div class=\"tc-manager-list-item-content-sidebar\">\n\t\t\t\t\t\t\t<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/Manager/ItemSidebar]!has[draft.of]]\" variable=\"listItem\">\n\t\t\t\t\t\t\t\t<<list-item-content-item>>\n\t\t\t\t\t\t\t</$list>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</$reveal>\n\t\t\t\t</div>\n\t\t\t</$vars>\n\t\t</$list>\n\t</div>\n</div>\n"
},
"$:/core/ui/MissingTemplate": {
"title": "$:/core/ui/MissingTemplate",
"text": "<div class=\"tc-tiddler-missing\">\n<$button popup=<<qualify \"$:/state/popup/missing\">> class=\"tc-btn-invisible tc-missing-tiddler-label\">\n<$view field=\"title\" format=\"text\" />\n</$button>\n<$reveal state=<<qualify \"$:/state/popup/missing\">> type=\"popup\" position=\"below\" animate=\"yes\">\n<div class=\"tc-drop-down\">\n<$transclude tiddler=\"$:/core/ui/ListItemTemplate\"/>\n<hr>\n<$list filter=\"[all[current]backlinks[]sort[title]]\" template=\"$:/core/ui/ListItemTemplate\"/>\n</div>\n</$reveal>\n</div>\n"
},
"$:/core/ui/MoreSideBar/All": {
"title": "$:/core/ui/MoreSideBar/All",
"tags": "$:/tags/MoreSideBar",
"caption": "{{$:/language/SideBar/All/Caption}}",
"text": "<$list filter={{$:/core/Filters/AllTiddlers!!filter}} template=\"$:/core/ui/ListItemTemplate\"/>\n"
},
"$:/core/ui/MoreSideBar/Drafts": {
"title": "$:/core/ui/MoreSideBar/Drafts",
"tags": "$:/tags/MoreSideBar",
"caption": "{{$:/language/SideBar/Drafts/Caption}}",
"text": "<$list filter={{$:/core/Filters/Drafts!!filter}} template=\"$:/core/ui/ListItemTemplate\"/>\n"
},
"$:/core/ui/MoreSideBar/Explorer": {
"title": "$:/core/ui/MoreSideBar/Explorer",
"tags": "$:/tags/MoreSideBar",
"caption": "{{$:/language/SideBar/Explorer/Caption}}",
"text": "<<tree \"$:/\">>\n"
},
"$:/core/ui/MoreSideBar/Missing": {
"title": "$:/core/ui/MoreSideBar/Missing",
"tags": "$:/tags/MoreSideBar",
"caption": "{{$:/language/SideBar/Missing/Caption}}",
"text": "<$list filter={{$:/core/Filters/Missing!!filter}} template=\"$:/core/ui/MissingTemplate\"/>\n"
},
"$:/core/ui/MoreSideBar/Orphans": {
"title": "$:/core/ui/MoreSideBar/Orphans",
"tags": "$:/tags/MoreSideBar",
"caption": "{{$:/language/SideBar/Orphans/Caption}}",
"text": "<$list filter={{$:/core/Filters/Orphans!!filter}} template=\"$:/core/ui/ListItemTemplate\"/>\n"
},
"$:/core/ui/MoreSideBar/Plugins": {
"title": "$:/core/ui/MoreSideBar/Plugins",
"tags": "$:/tags/MoreSideBar",
"caption": "{{$:/language/ControlPanel/Plugins/Caption}}",
"text": "\n{{$:/language/ControlPanel/Plugins/Installed/Hint}}\n\n<<tabs \"[all[shadows+tiddlers]tag[$:/tags/MoreSideBar/Plugins]!has[draft.of]]\" \"$:/core/ui/MoreSideBar/Plugins/Plugins\">>\n"
},
"$:/core/ui/MoreSideBar/Recent": {
"title": "$:/core/ui/MoreSideBar/Recent",
"tags": "$:/tags/MoreSideBar",
"caption": "{{$:/language/SideBar/Recent/Caption}}",
"text": "<$macrocall $name=\"timeline\" format={{$:/language/RecentChanges/DateFormat}}/>\n"
},
"$:/core/ui/MoreSideBar/Shadows": {
"title": "$:/core/ui/MoreSideBar/Shadows",
"tags": "$:/tags/MoreSideBar",
"caption": "{{$:/language/SideBar/Shadows/Caption}}",
"text": "<$list filter={{$:/core/Filters/ShadowTiddlers!!filter}} template=\"$:/core/ui/ListItemTemplate\"/>\n"
},
"$:/core/ui/MoreSideBar/System": {
"title": "$:/core/ui/MoreSideBar/System",
"tags": "$:/tags/MoreSideBar",
"caption": "{{$:/language/SideBar/System/Caption}}",
"text": "<$list filter={{$:/core/Filters/SystemTiddlers!!filter}} template=\"$:/core/ui/ListItemTemplate\"/>\n"
},
"$:/core/ui/MoreSideBar/Tags": {
"title": "$:/core/ui/MoreSideBar/Tags",
"tags": "$:/tags/MoreSideBar",
"caption": "{{$:/language/SideBar/Tags/Caption}}",
"text": "<$set name=\"tv-config-toolbar-icons\" value=\"yes\">\n\n<$set name=\"tv-config-toolbar-text\" value=\"yes\">\n\n<$set name=\"tv-config-toolbar-class\" value=\"\">\n\n{{$:/core/ui/Buttons/tag-manager}}\n\n</$set>\n\n</$set>\n\n</$set>\n\n<$list filter={{$:/core/Filters/AllTags!!filter}}>\n\n<$transclude tiddler=\"$:/core/ui/TagTemplate\"/>\n\n</$list>\n\n<hr class=\"tc-untagged-separator\">\n\n{{$:/core/ui/UntaggedTemplate}}\n"
},
"$:/core/ui/MoreSideBar/Types": {
"title": "$:/core/ui/MoreSideBar/Types",
"tags": "$:/tags/MoreSideBar",
"caption": "{{$:/language/SideBar/Types/Caption}}",
"text": "<$list filter={{$:/core/Filters/TypedTiddlers!!filter}}>\n<div class=\"tc-menu-list-item\">\n<$view field=\"type\"/>\n<$list filter=\"[type{!!type}!is[system]sort[title]]\">\n<div class=\"tc-menu-list-subitem\">\n<$link to={{!!title}}><$view field=\"title\"/></$link>\n</div>\n</$list>\n</div>\n</$list>\n"
},
"$:/core/ui/MoreSideBar/Plugins/Languages": {
"title": "$:/core/ui/MoreSideBar/Plugins/Languages",
"tags": "$:/tags/MoreSideBar/Plugins",
"caption": "{{$:/language/ControlPanel/Plugins/Languages/Caption}}",
"text": "<$list filter=\"[!has[draft.of]plugin-type[language]sort[description]]\" template=\"$:/core/ui/PluginListItemTemplate\" emptyMessage={{$:/language/ControlPanel/Plugins/Empty/Hint}}/>\n"
},
"$:/core/ui/MoreSideBar/Plugins/Plugins": {
"title": "$:/core/ui/MoreSideBar/Plugins/Plugins",
"tags": "$:/tags/MoreSideBar/Plugins",
"caption": "{{$:/language/ControlPanel/Plugins/Plugins/Caption}}",
"text": "<$list filter=\"[!has[draft.of]plugin-type[plugin]sort[description]]\" template=\"$:/core/ui/PluginListItemTemplate\" emptyMessage={{$:/language/ControlPanel/Plugins/Empty/Hint}}>>/>\n"
},
"$:/core/ui/MoreSideBar/Plugins/Theme": {
"title": "$:/core/ui/MoreSideBar/Plugins/Theme",
"tags": "$:/tags/MoreSideBar/Plugins",
"caption": "{{$:/language/ControlPanel/Plugins/Themes/Caption}}",
"text": "<$list filter=\"[!has[draft.of]plugin-type[theme]sort[description]]\" template=\"$:/core/ui/PluginListItemTemplate\" emptyMessage={{$:/language/ControlPanel/Plugins/Empty/Hint}}/>\n"
},
"$:/core/ui/Buttons/advanced-search": {
"title": "$:/core/ui/Buttons/advanced-search",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/advanced-search-button}} {{$:/language/Buttons/AdvancedSearch/Caption}}",
"description": "{{$:/language/Buttons/AdvancedSearch/Hint}}",
"text": "\\define control-panel-button(class)\n<$button to=\"$:/AdvancedSearch\" tooltip={{$:/language/Buttons/AdvancedSearch/Hint}} aria-label={{$:/language/Buttons/AdvancedSearch/Caption}} class=\"\"\"$(tv-config-toolbar-class)$ $class$\"\"\">\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/advanced-search-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/AdvancedSearch/Caption}}/></span>\n</$list>\n</$button>\n\\end\n\n<$list filter=\"[list[$:/StoryList]] +[field:title[$:/AdvancedSearch]]\" emptyMessage=<<control-panel-button>>>\n<<control-panel-button \"tc-selected\">>\n</$list>\n"
},
"$:/core/ui/Buttons/close-all": {
"title": "$:/core/ui/Buttons/close-all",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/close-all-button}} {{$:/language/Buttons/CloseAll/Caption}}",
"description": "{{$:/language/Buttons/CloseAll/Hint}}",
"text": "<$button message=\"tm-close-all-tiddlers\" tooltip={{$:/language/Buttons/CloseAll/Hint}} aria-label={{$:/language/Buttons/CloseAll/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/close-all-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/CloseAll/Caption}}/></span>\n</$list>\n</$button>"
},
"$:/core/ui/Buttons/control-panel": {
"title": "$:/core/ui/Buttons/control-panel",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/options-button}} {{$:/language/Buttons/ControlPanel/Caption}}",
"description": "{{$:/language/Buttons/ControlPanel/Hint}}",
"text": "\\define control-panel-button(class)\n<$button to=\"$:/ControlPanel\" tooltip={{$:/language/Buttons/ControlPanel/Hint}} aria-label={{$:/language/Buttons/ControlPanel/Caption}} class=\"\"\"$(tv-config-toolbar-class)$ $class$\"\"\">\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/options-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/ControlPanel/Caption}}/></span>\n</$list>\n</$button>\n\\end\n\n<$list filter=\"[list[$:/StoryList]] +[field:title[$:/ControlPanel]]\" emptyMessage=<<control-panel-button>>>\n<<control-panel-button \"tc-selected\">>\n</$list>\n"
},
"$:/core/ui/Buttons/encryption": {
"title": "$:/core/ui/Buttons/encryption",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/locked-padlock}} {{$:/language/Buttons/Encryption/Caption}}",
"description": "{{$:/language/Buttons/Encryption/Hint}}",
"text": "<$reveal type=\"match\" state=\"$:/isEncrypted\" text=\"yes\">\n<$button message=\"tm-clear-password\" tooltip={{$:/language/Buttons/Encryption/ClearPassword/Hint}} aria-label={{$:/language/Buttons/Encryption/ClearPassword/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/locked-padlock}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/Encryption/ClearPassword/Caption}}/></span>\n</$list>\n</$button>\n</$reveal>\n<$reveal type=\"nomatch\" state=\"$:/isEncrypted\" text=\"yes\">\n<$button message=\"tm-set-password\" tooltip={{$:/language/Buttons/Encryption/SetPassword/Hint}} aria-label={{$:/language/Buttons/Encryption/SetPassword/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/unlocked-padlock}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/Encryption/SetPassword/Caption}}/></span>\n</$list>\n</$button>\n</$reveal>"
},
"$:/core/ui/Buttons/export-page": {
"title": "$:/core/ui/Buttons/export-page",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/export-button}} {{$:/language/Buttons/ExportPage/Caption}}",
"description": "{{$:/language/Buttons/ExportPage/Hint}}",
"text": "<$macrocall $name=\"exportButton\" exportFilter=\"[!is[system]sort[title]]\" lingoBase=\"$:/language/Buttons/ExportPage/\"/>"
},
"$:/core/ui/Buttons/fold-all": {
"title": "$:/core/ui/Buttons/fold-all",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/fold-all-button}} {{$:/language/Buttons/FoldAll/Caption}}",
"description": "{{$:/language/Buttons/FoldAll/Hint}}",
"text": "<$button tooltip={{$:/language/Buttons/FoldAll/Hint}} aria-label={{$:/language/Buttons/FoldAll/Caption}} class=<<tv-config-toolbar-class>>>\n<$action-sendmessage $message=\"tm-fold-all-tiddlers\" $param=<<currentTiddler>> foldedStatePrefix=\"$:/state/folded/\"/>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\" variable=\"listItem\">\n{{$:/core/images/fold-all-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/FoldAll/Caption}}/></span>\n</$list>\n</$button>"
},
"$:/core/ui/Buttons/full-screen": {
"title": "$:/core/ui/Buttons/full-screen",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/full-screen-button}} {{$:/language/Buttons/FullScreen/Caption}}",
"description": "{{$:/language/Buttons/FullScreen/Hint}}",
"text": "<$button message=\"tm-full-screen\" tooltip={{$:/language/Buttons/FullScreen/Hint}} aria-label={{$:/language/Buttons/FullScreen/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/full-screen-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/FullScreen/Caption}}/></span>\n</$list>\n</$button>"
},
"$:/core/ui/Buttons/home": {
"title": "$:/core/ui/Buttons/home",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/home-button}} {{$:/language/Buttons/Home/Caption}}",
"description": "{{$:/language/Buttons/Home/Hint}}",
"text": "<$button message=\"tm-home\" tooltip={{$:/language/Buttons/Home/Hint}} aria-label={{$:/language/Buttons/Home/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/home-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/Home/Caption}}/></span>\n</$list>\n</$button>"
},
"$:/core/ui/Buttons/import": {
"title": "$:/core/ui/Buttons/import",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/import-button}} {{$:/language/Buttons/Import/Caption}}",
"description": "{{$:/language/Buttons/Import/Hint}}",
"text": "<div class=\"tc-file-input-wrapper\">\n<$button tooltip={{$:/language/Buttons/Import/Hint}} aria-label={{$:/language/Buttons/Import/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/import-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/Import/Caption}}/></span>\n</$list>\n</$button>\n<$browse tooltip={{$:/language/Buttons/Import/Hint}}/>\n</div>"
},
"$:/core/ui/Buttons/language": {
"title": "$:/core/ui/Buttons/language",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/globe}} {{$:/language/Buttons/Language/Caption}}",
"description": "{{$:/language/Buttons/Language/Hint}}",
"text": "\\define flag-title()\n$(languagePluginTitle)$/icon\n\\end\n<span class=\"tc-popup-keep\">\n<$button popup=<<qualify \"$:/state/popup/language\">> tooltip={{$:/language/Buttons/Language/Hint}} aria-label={{$:/language/Buttons/Language/Caption}} class=<<tv-config-toolbar-class>> selectedClass=\"tc-selected\">\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n<span class=\"tc-image-button\">\n<$set name=\"languagePluginTitle\" value={{$:/language}}>\n<$image source=<<flag-title>>/>\n</$set>\n</span>\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/Language/Caption}}/></span>\n</$list>\n</$button>\n</span>\n<$reveal state=<<qualify \"$:/state/popup/language\">> type=\"popup\" position=\"below\" animate=\"yes\">\n<div class=\"tc-drop-down\">\n{{$:/snippets/languageswitcher}}\n</div>\n</$reveal>"
},
"$:/core/ui/Buttons/manager": {
"title": "$:/core/ui/Buttons/manager",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/list}} {{$:/language/Buttons/Manager/Caption}}",
"description": "{{$:/language/Buttons/Manager/Hint}}",
"text": "\\define manager-button(class)\n<$button to=\"$:/Manager\" tooltip={{$:/language/Buttons/Manager/Hint}} aria-label={{$:/language/Buttons/Manager/Caption}} class=\"\"\"$(tv-config-toolbar-class)$ $class$\"\"\">\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/list}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/Manager/Caption}}/></span>\n</$list>\n</$button>\n\\end\n\n<$list filter=\"[list[$:/StoryList]] +[field:title[$:/Manager]]\" emptyMessage=<<manager-button>>>\n<<manager-button \"tc-selected\">>\n</$list>\n"
},
"$:/core/ui/Buttons/more-page-actions": {
"title": "$:/core/ui/Buttons/more-page-actions",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/down-arrow}} {{$:/language/Buttons/More/Caption}}",
"description": "{{$:/language/Buttons/More/Hint}}",
"text": "\\define config-title()\n$:/config/PageControlButtons/Visibility/$(listItem)$\n\\end\n<$button popup=<<qualify \"$:/state/popup/more\">> tooltip={{$:/language/Buttons/More/Hint}} aria-label={{$:/language/Buttons/More/Caption}} class=<<tv-config-toolbar-class>> selectedClass=\"tc-selected\">\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/down-arrow}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/More/Caption}}/></span>\n</$list>\n</$button><$reveal state=<<qualify \"$:/state/popup/more\">> type=\"popup\" position=\"below\" animate=\"yes\">\n\n<div class=\"tc-drop-down\">\n\n<$set name=\"tv-config-toolbar-icons\" value=\"yes\">\n\n<$set name=\"tv-config-toolbar-text\" value=\"yes\">\n\n<$set name=\"tv-config-toolbar-class\" value=\"tc-btn-invisible\">\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/PageControls]!has[draft.of]] -[[$:/core/ui/Buttons/more-page-actions]]\" variable=\"listItem\">\n\n<$reveal type=\"match\" state=<<config-title>> text=\"hide\">\n\n<$set name=\"tv-config-toolbar-class\" filter=\"[<tv-config-toolbar-class>] [<listItem>encodeuricomponent[]addprefix[tc-btn-]]\">\n\n<$transclude tiddler=<<listItem>> mode=\"inline\"/>\n\n</$set>\n\n</$reveal>\n\n</$list>\n\n</$set>\n\n</$set>\n\n</$set>\n\n</div>\n\n</$reveal>"
},
"$:/core/ui/Buttons/new-image": {
"title": "$:/core/ui/Buttons/new-image",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/new-image-button}} {{$:/language/Buttons/NewImage/Caption}}",
"description": "{{$:/language/Buttons/NewImage/Hint}}",
"text": "<$button tooltip={{$:/language/Buttons/NewImage/Hint}} aria-label={{$:/language/Buttons/NewImage/Caption}} class=<<tv-config-toolbar-class>> actions={{$:/core/ui/Actions/new-image}}>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/new-image-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/NewImage/Caption}}/></span>\n</$list>\n</$button>\n"
},
"$:/core/ui/Buttons/new-journal": {
"title": "$:/core/ui/Buttons/new-journal",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/new-journal-button}} {{$:/language/Buttons/NewJournal/Caption}}",
"description": "{{$:/language/Buttons/NewJournal/Hint}}",
"text": "\\define journalButton()\n<$button tooltip={{$:/language/Buttons/NewJournal/Hint}} aria-label={{$:/language/Buttons/NewJournal/Caption}} class=<<tv-config-toolbar-class>> actions={{$:/core/ui/Actions/new-journal}}>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/new-journal-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/NewJournal/Caption}}/></span>\n</$list>\n</$button>\n\\end\n<<journalButton>>\n"
},
"$:/core/ui/Buttons/new-tiddler": {
"title": "$:/core/ui/Buttons/new-tiddler",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/new-button}} {{$:/language/Buttons/NewTiddler/Caption}}",
"description": "{{$:/language/Buttons/NewTiddler/Hint}}",
"text": "<$button actions={{$:/core/ui/Actions/new-tiddler}} tooltip={{$:/language/Buttons/NewTiddler/Hint}} aria-label={{$:/language/Buttons/NewTiddler/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/new-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/NewTiddler/Caption}}/></span>\n</$list>\n</$button>\n"
},
"$:/core/ui/Buttons/palette": {
"title": "$:/core/ui/Buttons/palette",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/palette}} {{$:/language/Buttons/Palette/Caption}}",
"description": "{{$:/language/Buttons/Palette/Hint}}",
"text": "<span class=\"tc-popup-keep\">\n<$button popup=<<qualify \"$:/state/popup/palette\">> tooltip={{$:/language/Buttons/Palette/Hint}} aria-label={{$:/language/Buttons/Palette/Caption}} class=<<tv-config-toolbar-class>> selectedClass=\"tc-selected\">\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/palette}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/Palette/Caption}}/></span>\n</$list>\n</$button>\n</span>\n<$reveal state=<<qualify \"$:/state/popup/palette\">> type=\"popup\" position=\"below\" animate=\"yes\">\n<div class=\"tc-drop-down\" style=\"font-size:0.7em;\">\n{{$:/snippets/paletteswitcher}}\n</div>\n</$reveal>"
},
"$:/core/ui/Buttons/print": {
"title": "$:/core/ui/Buttons/print",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/print-button}} {{$:/language/Buttons/Print/Caption}}",
"description": "{{$:/language/Buttons/Print/Hint}}",
"text": "<$button message=\"tm-print\" tooltip={{$:/language/Buttons/Print/Hint}} aria-label={{$:/language/Buttons/Print/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/print-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/Print/Caption}}/></span>\n</$list>\n</$button>"
},
"$:/core/ui/Buttons/refresh": {
"title": "$:/core/ui/Buttons/refresh",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/refresh-button}} {{$:/language/Buttons/Refresh/Caption}}",
"description": "{{$:/language/Buttons/Refresh/Hint}}",
"text": "<$button message=\"tm-browser-refresh\" tooltip={{$:/language/Buttons/Refresh/Hint}} aria-label={{$:/language/Buttons/Refresh/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/refresh-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/Refresh/Caption}}/></span>\n</$list>\n</$button>"
},
"$:/core/ui/Buttons/save-wiki": {
"title": "$:/core/ui/Buttons/save-wiki",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/save-button}} {{$:/language/Buttons/SaveWiki/Caption}}",
"description": "{{$:/language/Buttons/SaveWiki/Hint}}",
"text": "<$button tooltip={{$:/language/Buttons/SaveWiki/Hint}} aria-label={{$:/language/Buttons/SaveWiki/Caption}} class=<<tv-config-toolbar-class>>>\n<$wikify name=\"site-title\" text={{$:/config/SaveWikiButton/Filename}}>\n<$action-sendmessage $message=\"tm-save-wiki\" $param={{$:/config/SaveWikiButton/Template}} filename=<<site-title>>/>\n</$wikify>\n<span class=\"tc-dirty-indicator\">\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/save-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/SaveWiki/Caption}}/></span>\n</$list>\n</span>\n</$button>"
},
"$:/core/ui/Buttons/storyview": {
"title": "$:/core/ui/Buttons/storyview",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/storyview-classic}} {{$:/language/Buttons/StoryView/Caption}}",
"description": "{{$:/language/Buttons/StoryView/Hint}}",
"text": "\\define icon()\n$:/core/images/storyview-$(storyview)$\n\\end\n<span class=\"tc-popup-keep\">\n<$button popup=<<qualify \"$:/state/popup/storyview\">> tooltip={{$:/language/Buttons/StoryView/Hint}} aria-label={{$:/language/Buttons/StoryView/Caption}} class=<<tv-config-toolbar-class>> selectedClass=\"tc-selected\">\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n<$set name=\"storyview\" value={{$:/view}}>\n<$transclude tiddler=<<icon>>/>\n</$set>\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/StoryView/Caption}}/></span>\n</$list>\n</$button>\n</span>\n<$reveal state=<<qualify \"$:/state/popup/storyview\">> type=\"popup\" position=\"below\" animate=\"yes\">\n<div class=\"tc-drop-down\">\n{{$:/snippets/viewswitcher}}\n</div>\n</$reveal>"
},
"$:/core/ui/Buttons/tag-manager": {
"title": "$:/core/ui/Buttons/tag-manager",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/tag-button}} {{$:/language/Buttons/TagManager/Caption}}",
"description": "{{$:/language/Buttons/TagManager/Hint}}",
"text": "\\define control-panel-button(class)\n<$button to=\"$:/TagManager\" tooltip={{$:/language/Buttons/TagManager/Hint}} aria-label={{$:/language/Buttons/TagManager/Caption}} class=\"\"\"$(tv-config-toolbar-class)$ $class$\"\"\">\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/tag-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/TagManager/Caption}}/></span>\n</$list>\n</$button>\n\\end\n\n<$list filter=\"[list[$:/StoryList]] +[field:title[$:/TagManager]]\" emptyMessage=<<control-panel-button>>>\n<<control-panel-button \"tc-selected\">>\n</$list>\n"
},
"$:/core/ui/Buttons/theme": {
"title": "$:/core/ui/Buttons/theme",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/theme-button}} {{$:/language/Buttons/Theme/Caption}}",
"description": "{{$:/language/Buttons/Theme/Hint}}",
"text": "<span class=\"tc-popup-keep\">\n<$button popup=<<qualify \"$:/state/popup/theme\">> tooltip={{$:/language/Buttons/Theme/Hint}} aria-label={{$:/language/Buttons/Theme/Caption}} class=<<tv-config-toolbar-class>> selectedClass=\"tc-selected\">\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/theme-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/Theme/Caption}}/></span>\n</$list>\n</$button>\n</span>\n<$reveal state=<<qualify \"$:/state/popup/theme\">> type=\"popup\" position=\"below\" animate=\"yes\">\n<div class=\"tc-drop-down\">\n<$linkcatcher to=\"$:/theme\">\n{{$:/snippets/themeswitcher}}\n</$linkcatcher>\n</div>\n</$reveal>"
},
"$:/core/ui/Buttons/timestamp": {
"title": "$:/core/ui/Buttons/timestamp",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/timestamp-on}} {{$:/language/Buttons/Timestamp/Caption}}",
"description": "{{$:/language/Buttons/Timestamp/Hint}}",
"text": "<$reveal type=\"nomatch\" state=\"$:/config/TimestampDisable\" text=\"yes\">\n<$button tooltip={{$:/language/Buttons/Timestamp/On/Hint}} aria-label={{$:/language/Buttons/Timestamp/On/Caption}} class=<<tv-config-toolbar-class>>>\n<$action-setfield $tiddler=\"$:/config/TimestampDisable\" $value=\"yes\"/>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/timestamp-on}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/Timestamp/On/Caption}}/></span>\n</$list>\n</$button>\n</$reveal>\n<$reveal type=\"match\" state=\"$:/config/TimestampDisable\" text=\"yes\">\n<$button tooltip={{$:/language/Buttons/Timestamp/Off/Hint}} aria-label={{$:/language/Buttons/Timestamp/Off/Caption}} class=<<tv-config-toolbar-class>>>\n<$action-setfield $tiddler=\"$:/config/TimestampDisable\" $value=\"no\"/>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/timestamp-off}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/Timestamp/Off/Caption}}/></span>\n</$list>\n</$button>\n</$reveal>"
},
"$:/core/ui/Buttons/unfold-all": {
"title": "$:/core/ui/Buttons/unfold-all",
"tags": "$:/tags/PageControls",
"caption": "{{$:/core/images/unfold-all-button}} {{$:/language/Buttons/UnfoldAll/Caption}}",
"description": "{{$:/language/Buttons/UnfoldAll/Hint}}",
"text": "<$button tooltip={{$:/language/Buttons/UnfoldAll/Hint}} aria-label={{$:/language/Buttons/UnfoldAll/Caption}} class=<<tv-config-toolbar-class>>>\n<$action-sendmessage $message=\"tm-unfold-all-tiddlers\" $param=<<currentTiddler>> foldedStatePrefix=\"$:/state/folded/\"/>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\" variable=\"listItem\">\n{{$:/core/images/unfold-all-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/UnfoldAll/Caption}}/></span>\n</$list>\n</$button>"
},
"$:/core/ui/PageTemplate/pagecontrols": {
"title": "$:/core/ui/PageTemplate/pagecontrols",
"text": "\\define config-title()\n$:/config/PageControlButtons/Visibility/$(listItem)$\n\\end\n<div class=\"tc-page-controls\">\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/PageControls]!has[draft.of]]\" variable=\"listItem\">\n<$reveal type=\"nomatch\" state=<<config-title>> text=\"hide\">\n<$set name=\"tv-config-toolbar-class\" filter=\"[<tv-config-toolbar-class>] [<listItem>encodeuricomponent[]addprefix[tc-btn-]]\">\n<$transclude tiddler=<<listItem>> mode=\"inline\"/>\n</$set>\n</$reveal>\n</$list>\n</div>\n\n"
},
"$:/core/ui/PageStylesheet": {
"title": "$:/core/ui/PageStylesheet",
"text": "\\import [[$:/core/ui/PageMacros]] [all[shadows+tiddlers]tag[$:/tags/Macro]!has[draft.of]]\n\n<$set name=\"currentTiddler\" value={{$:/language}}>\n\n<$set name=\"languageTitle\" value={{!!name}}>\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/Stylesheet]!has[draft.of]]\">\n<$transclude mode=\"block\"/>\n</$list>\n\n</$set>\n\n</$set>\n"
},
"$:/core/ui/PageTemplate/alerts": {
"title": "$:/core/ui/PageTemplate/alerts",
"tags": "$:/tags/PageTemplate",
"text": "<div class=\"tc-alerts\">\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/Alert]!has[draft.of]]\" template=\"$:/core/ui/AlertTemplate\" storyview=\"pop\"/>\n\n</div>\n"
},
"$:/core/ui/PageTemplate/drafts": {
"title": "$:/core/ui/PageTemplate/drafts",
"tags": "$:/tags/PageTemplate",
"text": "\\whitespace trim\n<$reveal state=\"$:/status/IsReadOnly\" type=\"nomatch\" text=\"yes\" tag=\"div\" class=\"tc-drafts-list\">\n<$list filter=\"[has[draft.of]!sort[modified]] -[list[$:/StoryList]]\">\n<$link>\n{{$:/core/images/edit-button}} <$text text=<<currentTiddler>>/>\n</$link>\n</$list>\n</$reveal>\n"
},
"$:/core/ui/PageTemplate/pluginreloadwarning": {
"title": "$:/core/ui/PageTemplate/pluginreloadwarning",
"tags": "$:/tags/PageTemplate",
"text": "\\define lingo-base() $:/language/\n\n<$list filter=\"[has[plugin-type]haschanged[]!plugin-type[import]limit[1]]\">\n\n<$reveal type=\"nomatch\" state=\"$:/temp/HidePluginWarning\" text=\"yes\">\n\n<div class=\"tc-plugin-reload-warning\">\n\n<$set name=\"tv-config-toolbar-class\" value=\"\">\n\n<<lingo PluginReloadWarning>> <$button set=\"$:/temp/HidePluginWarning\" setTo=\"yes\" class=\"tc-btn-invisible\">{{$:/core/images/close-button}}</$button>\n\n</$set>\n\n</div>\n\n</$reveal>\n\n</$list>\n"
},
"$:/core/ui/PageTemplate/sidebar": {
"title": "$:/core/ui/PageTemplate/sidebar",
"tags": "$:/tags/PageTemplate",
"text": "\\define config-title()\n$:/config/SideBarSegments/Visibility/$(listItem)$\n\\end\n\n<$scrollable fallthrough=\"no\" class=\"tc-sidebar-scrollable\">\n\n<div class=\"tc-sidebar-header\">\n\n<$reveal state=\"$:/state/sidebar\" type=\"match\" text=\"yes\" default=\"yes\" retain=\"yes\" animate=\"yes\">\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/SideBarSegment]!has[draft.of]]\" variable=\"listItem\">\n\n<$reveal type=\"nomatch\" state=<<config-title>> text=\"hide\" tag=\"div\">\n\n<$transclude tiddler=<<listItem>> mode=\"block\"/>\n\n</$reveal>\n\n</$list>\n\n</$reveal>\n\n</div>\n\n</$scrollable>"
},
"$:/core/ui/PageTemplate/story": {
"title": "$:/core/ui/PageTemplate/story",
"tags": "$:/tags/PageTemplate",
"text": "<section class=\"tc-story-river\">\n\n<section class=\"story-backdrop\">\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/AboveStory]!has[draft.of]]\">\n\n<$transclude/>\n\n</$list>\n\n</section>\n\n<$list filter=\"[list[$:/StoryList]]\" history=\"$:/HistoryList\" template=\"$:/core/ui/ViewTemplate\" editTemplate=\"$:/core/ui/EditTemplate\" storyview={{$:/view}} emptyMessage={{$:/config/EmptyStoryMessage}}/>\n\n<section class=\"story-frontdrop\">\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/BelowStory]!has[draft.of]]\">\n\n<$transclude/>\n\n</$list>\n\n</section>\n\n</section>\n"
},
"$:/core/ui/PageTemplate/topleftbar": {
"title": "$:/core/ui/PageTemplate/topleftbar",
"tags": "$:/tags/PageTemplate",
"text": "<span class=\"tc-topbar tc-topbar-left\">\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/TopLeftBar]!has[draft.of]]\" variable=\"listItem\">\n\n<$transclude tiddler=<<listItem>> mode=\"inline\"/>\n\n</$list>\n\n</span>\n"
},
"$:/core/ui/PageTemplate/toprightbar": {
"title": "$:/core/ui/PageTemplate/toprightbar",
"tags": "$:/tags/PageTemplate",
"text": "<span class=\"tc-topbar tc-topbar-right\">\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/TopRightBar]!has[draft.of]]\" variable=\"listItem\">\n\n<$transclude tiddler=<<listItem>> mode=\"inline\"/>\n\n</$list>\n\n</span>\n"
},
"$:/core/ui/PageTemplate": {
"title": "$:/core/ui/PageTemplate",
"text": "\\define containerClasses()\ntc-page-container tc-page-view-$(storyviewTitle)$ tc-language-$(languageTitle)$\n\\end\n\\import [[$:/core/ui/PageMacros]] [all[shadows+tiddlers]tag[$:/tags/Macro]!has[draft.of]]\n\n<$set name=\"tv-config-toolbar-icons\" value={{$:/config/Toolbar/Icons}}>\n\n<$set name=\"tv-config-toolbar-text\" value={{$:/config/Toolbar/Text}}>\n\n<$set name=\"tv-config-toolbar-class\" value={{$:/config/Toolbar/ButtonClass}}>\n\n<$set name=\"tv-show-missing-links\" value={{$:/config/MissingLinks}}>\n\n<$set name=\"storyviewTitle\" value={{$:/view}}>\n\n<$set name=\"currentTiddler\" value={{$:/language}}>\n\n<$set name=\"languageTitle\" value={{!!name}}>\n\n<$set name=\"currentTiddler\" value=\"\">\n\n<div class=<<containerClasses>>>\n\n<$navigator story=\"$:/StoryList\" history=\"$:/HistoryList\" openLinkFromInsideRiver={{$:/config/Navigation/openLinkFromInsideRiver}} openLinkFromOutsideRiver={{$:/config/Navigation/openLinkFromOutsideRiver}} relinkOnRename={{$:/config/RelinkOnRename}}>\n\n<$dropzone>\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/PageTemplate]!has[draft.of]]\" variable=\"listItem\">\n\n<$transclude tiddler=<<listItem>>/>\n\n</$list>\n\n</$dropzone>\n\n</$navigator>\n\n</div>\n\n</$set>\n\n</$set>\n\n</$set>\n\n</$set>\n\n</$set>\n\n</$set>\n\n</$set>\n\n</$set>\n"
},
"$:/core/ui/PluginInfo": {
"title": "$:/core/ui/PluginInfo",
"text": "\\define localised-info-tiddler-title()\n$(currentTiddler)$/$(languageTitle)$/$(currentTab)$\n\\end\n\\define info-tiddler-title()\n$(currentTiddler)$/$(currentTab)$\n\\end\n\\define default-tiddler-title()\n$:/core/ui/PluginInfo/Default/$(currentTab)$\n\\end\n<$transclude tiddler=<<localised-info-tiddler-title>> mode=\"block\">\n<$transclude tiddler=<<currentTiddler>> subtiddler=<<localised-info-tiddler-title>> mode=\"block\">\n<$transclude tiddler=<<currentTiddler>> subtiddler=<<info-tiddler-title>> mode=\"block\">\n<$transclude tiddler=<<default-tiddler-title>> mode=\"block\">\n{{$:/language/ControlPanel/Plugin/NoInfoFound/Hint}}\n</$transclude>\n</$transclude>\n</$transclude>\n</$transclude>\n"
},
"$:/core/ui/PluginInfo/Default/contents": {
"title": "$:/core/ui/PluginInfo/Default/contents",
"text": "\\define lingo-base() $:/language/TiddlerInfo/Advanced/PluginInfo/\n<<lingo Hint>>\n<ul>\n<$list filter=\"[all[current]plugintiddlers[]sort[title]]\" emptyMessage=<<lingo Empty/Hint>>>\n<li>\n<$link to={{!!title}}>\n<$view field=\"title\"/>\n</$link>\n</li>\n</$list>\n</ul>\n"
},
"$:/core/ui/PluginListItemTemplate": {
"title": "$:/core/ui/PluginListItemTemplate",
"text": "<div class=\"tc-menu-list-item\">\n<$link to={{!!title}}>\n<$view field=\"description\">\n<$view field=\"title\"/>\n</$view>\n</$link>\n</div>"
},
"$:/core/ui/SearchResults": {
"title": "$:/core/ui/SearchResults",
"text": "<div class=\"tc-search-results\">\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/SearchResults]!has[draft.of]butfirst[]limit[1]]\" emptyMessage=\"\"\"\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/SearchResults]!has[draft.of]]\">\n<$transclude mode=\"block\"/>\n</$list>\n\"\"\">\n\n<$macrocall $name=\"tabs\" tabsList=\"[all[shadows+tiddlers]tag[$:/tags/SearchResults]!has[draft.of]]\" default={{$:/config/SearchResults/Default}}/>\n\n</$list>\n\n</div>\n"
},
"$:/core/ui/SideBar/More": {
"title": "$:/core/ui/SideBar/More",
"tags": "$:/tags/SideBar",
"caption": "{{$:/language/SideBar/More/Caption}}",
"text": "<div class=\"tc-more-sidebar\">\n<$macrocall $name=\"tabs\" tabsList=\"[all[shadows+tiddlers]tag[$:/tags/MoreSideBar]!has[draft.of]]\" default={{$:/config/DefaultMoreSidebarTab}} state=\"$:/state/tab/moresidebar\" class=\"tc-vertical\" />\n</div>"
},
"$:/core/ui/SideBar/Open": {
"title": "$:/core/ui/SideBar/Open",
"tags": "$:/tags/SideBar",
"caption": "{{$:/language/SideBar/Open/Caption}}",
"text": "\\whitespace trim\n\\define lingo-base() $:/language/CloseAll/\n\n\\define drop-actions()\n<$action-listops $tiddler=\"$:/StoryList\" $subfilter=\"+[insertbefore:currentTiddler<actionTiddler>]\"/>\n\\end\n\n<$list filter=\"[list[$:/StoryList]]\" history=\"$:/HistoryList\" storyview=\"pop\">\n<div style=\"position: relative;\">\n<$droppable actions=<<drop-actions>>>\n<div class=\"tc-droppable-placeholder\">\n \n</div>\n<div>\n<$button message=\"tm-close-tiddler\" tooltip={{$:/language/Buttons/Close/Hint}} aria-label={{$:/language/Buttons/Close/Caption}} class=\"tc-btn-invisible tc-btn-mini\">×</$button> <$link to={{!!title}}><$view field=\"title\"/></$link>\n</div>\n</$droppable>\n</div>\n</$list>\n<$tiddler tiddler=\"\">\n<$droppable actions=<<drop-actions>>>\n<div class=\"tc-droppable-placeholder\">\n \n</div>\n<$button message=\"tm-close-all-tiddlers\" class=\"tc-btn-invisible tc-btn-mini\"><<lingo Button>></$button>\n</$droppable>\n</$tiddler>\n"
},
"$:/core/ui/SideBar/Recent": {
"title": "$:/core/ui/SideBar/Recent",
"tags": "$:/tags/SideBar",
"caption": "{{$:/language/SideBar/Recent/Caption}}",
"text": "<$macrocall $name=\"timeline\" format={{$:/language/RecentChanges/DateFormat}}/>\n"
},
"$:/core/ui/SideBar/Tools": {
"title": "$:/core/ui/SideBar/Tools",
"tags": "$:/tags/SideBar",
"caption": "{{$:/language/SideBar/Tools/Caption}}",
"text": "\\define lingo-base() $:/language/ControlPanel/\n\\define config-title()\n$:/config/PageControlButtons/Visibility/$(listItem)$\n\\end\n\n<<lingo Basics/Version/Prompt>> <<version>>\n\n<$set name=\"tv-config-toolbar-icons\" value=\"yes\">\n\n<$set name=\"tv-config-toolbar-text\" value=\"yes\">\n\n<$set name=\"tv-config-toolbar-class\" value=\"\">\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/PageControls]!has[draft.of]]\" variable=\"listItem\">\n\n<div style=\"position:relative;\" class={{{ [<listItem>encodeuricomponent[]addprefix[tc-btn-]] }}}>\n\n<$checkbox tiddler=<<config-title>> field=\"text\" checked=\"show\" unchecked=\"hide\" default=\"show\"/> <$transclude tiddler=<<listItem>>/> <i class=\"tc-muted\"><$transclude tiddler=<<listItem>> field=\"description\"/></i>\n\n</div>\n\n</$list>\n\n</$set>\n\n</$set>\n\n</$set>\n"
},
"$:/core/ui/SideBarLists": {
"title": "$:/core/ui/SideBarLists",
"text": "<$transclude tiddler=\"$:/core/ui/SideBarSegments/search\"/>\n\n<$transclude tiddler=\"$:/core/ui/SideBarSegments/tabs\"/>\n\n"
},
"$:/core/ui/SideBarSegments/page-controls": {
"title": "$:/core/ui/SideBarSegments/page-controls",
"tags": "$:/tags/SideBarSegment",
"text": "{{||$:/core/ui/PageTemplate/pagecontrols}}\n"
},
"$:/core/ui/SideBarSegments/search": {
"title": "$:/core/ui/SideBarSegments/search",
"tags": "$:/tags/SideBarSegment",
"text": "<div class=\"tc-sidebar-lists\">\n\n<$set name=\"searchTiddler\" value=\"$:/temp/search\">\n<div class=\"tc-search\">\n<$edit-text tiddler=\"$:/temp/search\" type=\"search\" tag=\"input\" focus={{$:/config/Search/AutoFocus}} focusPopup=<<qualify \"$:/state/popup/search-dropdown\">> class=\"tc-popup-handle\"/>\n<$reveal state=\"$:/temp/search\" type=\"nomatch\" text=\"\">\n<$button tooltip={{$:/language/Buttons/AdvancedSearch/Hint}} aria-label={{$:/language/Buttons/AdvancedSearch/Caption}} class=\"tc-btn-invisible\">\n<$action-setfield $tiddler=\"$:/temp/advancedsearch\" text={{$:/temp/search}}/>\n<$action-setfield $tiddler=\"$:/temp/search\" text=\"\"/>\n<$action-navigate $to=\"$:/AdvancedSearch\"/>\n{{$:/core/images/advanced-search-button}}\n</$button>\n<$button class=\"tc-btn-invisible\">\n<$action-setfield $tiddler=\"$:/temp/search\" text=\"\" />\n{{$:/core/images/close-button}}\n</$button>\n<$button popup=<<qualify \"$:/state/popup/search-dropdown\">> class=\"tc-btn-invisible\">\n{{$:/core/images/down-arrow}}\n<$list filter=\"[{$:/temp/search}minlength{$:/config/Search/MinLength}limit[1]]\" variable=\"listItem\">\n<$set name=\"searchTerm\" value={{{ [<searchTiddler>get[text]] }}}>\n<$set name=\"resultCount\" value=\"\"\"<$count filter=\"[!is[system]search<searchTerm>]\"/>\"\"\">\n{{$:/language/Search/Matches}}\n</$set>\n</$set>\n</$list>\n</$button>\n</$reveal>\n<$reveal state=\"$:/temp/search\" type=\"match\" text=\"\">\n<$button to=\"$:/AdvancedSearch\" tooltip={{$:/language/Buttons/AdvancedSearch/Hint}} aria-label={{$:/language/Buttons/AdvancedSearch/Caption}} class=\"tc-btn-invisible\">\n{{$:/core/images/advanced-search-button}}\n</$button>\n</$reveal>\n</div>\n\n<$reveal tag=\"div\" class=\"tc-block-dropdown-wrapper\" state=\"$:/temp/search\" type=\"nomatch\" text=\"\">\n\n<$reveal tag=\"div\" class=\"tc-block-dropdown tc-search-drop-down tc-popup-handle\" state=<<qualify \"$:/state/popup/search-dropdown\">> type=\"nomatch\" text=\"\" default=\"\">\n\n<$list filter=\"[{$:/temp/search}minlength{$:/config/Search/MinLength}limit[1]]\" emptyMessage=\"\"\"<div class=\"tc-search-results\">{{$:/language/Search/Search/TooShort}}</div>\"\"\" variable=\"listItem\">\n\n{{$:/core/ui/SearchResults}}\n\n</$list>\n\n</$reveal>\n\n</$reveal>\n\n</$set>\n\n</div>\n"
},
"$:/core/ui/SideBarSegments/site-subtitle": {
"title": "$:/core/ui/SideBarSegments/site-subtitle",
"tags": "$:/tags/SideBarSegment",
"text": "<div class=\"tc-site-subtitle\">\n\n<$transclude tiddler=\"$:/SiteSubtitle\" mode=\"inline\"/>\n\n</div>\n"
},
"$:/core/ui/SideBarSegments/site-title": {
"title": "$:/core/ui/SideBarSegments/site-title",
"tags": "$:/tags/SideBarSegment",
"text": "<h1 class=\"tc-site-title\">\n\n<$transclude tiddler=\"$:/SiteTitle\" mode=\"inline\"/>\n\n</h1>\n"
},
"$:/core/ui/SideBarSegments/tabs": {
"title": "$:/core/ui/SideBarSegments/tabs",
"tags": "$:/tags/SideBarSegment",
"text": "<div class=\"tc-sidebar-lists\">\n\n<$macrocall $name=\"tabs\" tabsList=\"[all[shadows+tiddlers]tag[$:/tags/SideBar]!has[draft.of]]\" default={{$:/config/DefaultSidebarTab}} state=\"$:/state/tab/sidebar\" />\n\n</div>\n"
},
"$:/TagManager": {
"title": "$:/TagManager",
"icon": "$:/core/images/tag-button",
"color": "#bbb",
"caption": "{{$:/language/TagManager/Caption}}",
"text": "\\define lingo-base() $:/language/TagManager/\n\\define iconEditorTab(type)\n<$list filter=\"[all[shadows+tiddlers]is[image]] [all[shadows+tiddlers]tag[$:/tags/Image]] -[type[application/pdf]] +[sort[title]] +[$type$is[system]]\">\n<$link to={{!!title}}>\n<$transclude/> <$view field=\"title\"/>\n</$link>\n</$list>\n\\end\n\\define iconEditor(title)\n<div class=\"tc-drop-down-wrapper\">\n<$button popupTitle={{{ [[$:/state/popup/icon/]addsuffix<__title__>] }}} class=\"tc-btn-invisible tc-btn-dropdown\">{{$:/core/images/down-arrow}}</$button>\n<$reveal stateTitle={{{ [[$:/state/popup/icon/]addsuffix<__title__>] }}} type=\"popup\" position=\"belowleft\" text=\"\" default=\"\">\n<div class=\"tc-drop-down\">\n<$linkcatcher actions=\"\"\"<$action-setfield $tiddler=<<__title__>> icon=<<navigateTo>>/>\"\"\">\n<<iconEditorTab type:\"!\">>\n<hr/>\n<<iconEditorTab type:\"\">>\n</$linkcatcher>\n</div>\n</$reveal>\n</div>\n\\end\n\\define toggleButton(state)\n<$reveal stateTitle=<<__state__>> type=\"match\" text=\"closed\" default=\"closed\">\n<$button setTitle=<<__state__>> setTo=\"open\" class=\"tc-btn-invisible tc-btn-dropdown\" selectedClass=\"tc-selected\">\n{{$:/core/images/info-button}}\n</$button>\n</$reveal>\n<$reveal stateTitle=<<__state__>> type=\"match\" text=\"open\" default=\"closed\">\n<$button setTitle=<<__state__>> setTo=\"closed\" class=\"tc-btn-invisible tc-btn-dropdown\" selectedClass=\"tc-selected\">\n{{$:/core/images/info-button}}\n</$button>\n</$reveal>\n\\end\n<table class=\"tc-tag-manager-table\">\n<tbody>\n<tr>\n<th><<lingo Colour/Heading>></th>\n<th class=\"tc-tag-manager-tag\"><<lingo Tag/Heading>></th>\n<th><<lingo Count/Heading>></th>\n<th><<lingo Icon/Heading>></th>\n<th><<lingo Info/Heading>></th>\n</tr>\n<$list filter=\"[tags[]!is[system]sort[title]]\">\n<tr>\n<td><$edit-text field=\"color\" tag=\"input\" type=\"color\"/></td>\n<td>{{||$:/core/ui/TagTemplate}}</td>\n<td><$count filter=\"[all[current]tagging[]]\"/></td>\n<td>\n<$macrocall $name=\"iconEditor\" title={{!!title}}/>\n</td>\n<td>\n<$macrocall $name=\"toggleButton\" state={{{ [[$:/state/tag-manager/]addsuffix<currentTiddler>] }}} /> \n</td>\n</tr>\n<tr>\n<td></td>\n<td colspan=\"4\">\n<$reveal stateTitle={{{ [[$:/state/tag-manager/]addsuffix<currentTiddler>] }}} type=\"match\" text=\"open\" default=\"\">\n<table>\n<tbody>\n<tr><td><<lingo Colour/Heading>></td><td><$edit-text field=\"color\" tag=\"input\" type=\"text\" size=\"9\"/></td></tr>\n<tr><td><<lingo Icon/Heading>></td><td><$edit-text field=\"icon\" tag=\"input\" size=\"45\"/></td></tr>\n</tbody>\n</table>\n</$reveal>\n</td>\n</tr>\n</$list>\n<tr>\n<td></td>\n<td style=\"position:relative;\">\n{{$:/core/ui/UntaggedTemplate}}\n</td>\n<td>\n<small class=\"tc-menu-list-count\"><$count filter=\"[untagged[]!is[system]] -[tags[]]\"/></small>\n</td>\n<td></td>\n<td></td>\n</tr>\n</tbody>\n</table>\n"
},
"$:/core/ui/TagTemplate": {
"title": "$:/core/ui/TagTemplate",
"text": "\\whitespace trim\n<span class=\"tc-tag-list-item\">\n<$set name=\"transclusion\" value=<<currentTiddler>>>\n<$macrocall $name=\"tag-pill-body\" tag=<<currentTiddler>> icon={{!!icon}} colour={{!!color}} palette={{$:/palette}} element-tag=\"\"\"$button\"\"\" element-attributes=\"\"\"popup=<<qualify \"$:/state/popup/tag\">> dragFilter='[all[current]tagging[]]' tag='span'\"\"\"/>\n<$reveal state=<<qualify \"$:/state/popup/tag\">> type=\"popup\" position=\"below\" animate=\"yes\" class=\"tc-drop-down\">\n<$set name=\"tv-show-missing-links\" value=\"yes\">\n<$transclude tiddler=\"$:/core/ui/ListItemTemplate\"/>\n</$set>\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/TagDropdown]!has[draft.of]]\" variable=\"listItem\"> \n<$transclude tiddler=<<listItem>>/> \n</$list>\n<hr>\n<$macrocall $name=\"list-tagged-draggable\" tag=<<currentTiddler>>/>\n</$reveal>\n</$set>\n</span>\n"
},
"$:/core/ui/TiddlerFieldTemplate": {
"title": "$:/core/ui/TiddlerFieldTemplate",
"text": "<tr class=\"tc-view-field\">\n<td class=\"tc-view-field-name\">\n<$text text=<<listItem>>/>\n</td>\n<td class=\"tc-view-field-value\">\n<$view field=<<listItem>>/>\n</td>\n</tr>"
},
"$:/core/ui/TiddlerFields": {
"title": "$:/core/ui/TiddlerFields",
"text": "<table class=\"tc-view-field-table\">\n<tbody>\n<$list filter=\"[all[current]fields[]sort[title]] -text\" template=\"$:/core/ui/TiddlerFieldTemplate\" variable=\"listItem\"/>\n</tbody>\n</table>\n"
},
"$:/core/ui/TiddlerInfo/Advanced/PluginInfo": {
"title": "$:/core/ui/TiddlerInfo/Advanced/PluginInfo",
"tags": "$:/tags/TiddlerInfo/Advanced",
"text": "\\define lingo-base() $:/language/TiddlerInfo/Advanced/PluginInfo/\n<$list filter=\"[all[current]has[plugin-type]]\">\n\n! <<lingo Heading>>\n\n<<lingo Hint>>\n<ul>\n<$list filter=\"[all[current]plugintiddlers[]sort[title]]\" emptyMessage=<<lingo Empty/Hint>>>\n<li>\n<$link to={{!!title}}>\n<$view field=\"title\"/>\n</$link>\n</li>\n</$list>\n</ul>\n\n</$list>\n"
},
"$:/core/ui/TiddlerInfo/Advanced/ShadowInfo": {
"title": "$:/core/ui/TiddlerInfo/Advanced/ShadowInfo",
"tags": "$:/tags/TiddlerInfo/Advanced",
"text": "\\define lingo-base() $:/language/TiddlerInfo/Advanced/ShadowInfo/\n<$set name=\"infoTiddler\" value=<<currentTiddler>>>\n\n''<<lingo Heading>>''\n\n<$list filter=\"[all[current]!is[shadow]]\">\n\n<<lingo NotShadow/Hint>>\n\n</$list>\n\n<$list filter=\"[all[current]is[shadow]]\">\n\n<<lingo Shadow/Hint>>\n\n<$list filter=\"[all[current]shadowsource[]]\">\n\n<$set name=\"pluginTiddler\" value=<<currentTiddler>>>\n<<lingo Shadow/Source>>\n</$set>\n\n</$list>\n\n<$list filter=\"[all[current]is[shadow]is[tiddler]]\">\n\n<<lingo OverriddenShadow/Hint>>\n\n</$list>\n\n\n</$list>\n</$set>\n"
},
"$:/core/ui/TiddlerInfo/Advanced": {
"title": "$:/core/ui/TiddlerInfo/Advanced",
"tags": "$:/tags/TiddlerInfo",
"caption": "{{$:/language/TiddlerInfo/Advanced/Caption}}",
"text": "<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/TiddlerInfo/Advanced]!has[draft.of]]\" variable=\"listItem\">\n<$transclude tiddler=<<listItem>>/>\n\n</$list>\n"
},
"$:/core/ui/TiddlerInfo/Fields": {
"title": "$:/core/ui/TiddlerInfo/Fields",
"tags": "$:/tags/TiddlerInfo",
"caption": "{{$:/language/TiddlerInfo/Fields/Caption}}",
"text": "<$transclude tiddler=\"$:/core/ui/TiddlerFields\"/>\n"
},
"$:/core/ui/TiddlerInfo/List": {
"title": "$:/core/ui/TiddlerInfo/List",
"tags": "$:/tags/TiddlerInfo",
"caption": "{{$:/language/TiddlerInfo/List/Caption}}",
"text": "\\define lingo-base() $:/language/TiddlerInfo/\n<$list filter=\"[list{!!title}]\" emptyMessage=<<lingo List/Empty>> template=\"$:/core/ui/ListItemTemplate\"/>\n"
},
"$:/core/ui/TiddlerInfo/Listed": {
"title": "$:/core/ui/TiddlerInfo/Listed",
"tags": "$:/tags/TiddlerInfo",
"caption": "{{$:/language/TiddlerInfo/Listed/Caption}}",
"text": "\\define lingo-base() $:/language/TiddlerInfo/\n<$list filter=\"[all[current]listed[]!is[system]]\" emptyMessage=<<lingo Listed/Empty>> template=\"$:/core/ui/ListItemTemplate\"/>\n"
},
"$:/core/ui/TiddlerInfo/References": {
"title": "$:/core/ui/TiddlerInfo/References",
"tags": "$:/tags/TiddlerInfo",
"caption": "{{$:/language/TiddlerInfo/References/Caption}}",
"text": "\\define lingo-base() $:/language/TiddlerInfo/\n<$list filter=\"[all[current]backlinks[]sort[title]]\" emptyMessage=<<lingo References/Empty>> template=\"$:/core/ui/ListItemTemplate\">\n</$list>"
},
"$:/core/ui/TiddlerInfo/Tagging": {
"title": "$:/core/ui/TiddlerInfo/Tagging",
"tags": "$:/tags/TiddlerInfo",
"caption": "{{$:/language/TiddlerInfo/Tagging/Caption}}",
"text": "\\define lingo-base() $:/language/TiddlerInfo/\n<$list filter=\"[all[current]tagging[]]\" emptyMessage=<<lingo Tagging/Empty>> template=\"$:/core/ui/ListItemTemplate\"/>\n"
},
"$:/core/ui/TiddlerInfo/Tools": {
"title": "$:/core/ui/TiddlerInfo/Tools",
"tags": "$:/tags/TiddlerInfo",
"caption": "{{$:/language/TiddlerInfo/Tools/Caption}}",
"text": "\\define lingo-base() $:/language/TiddlerInfo/\n\\define config-title()\n$:/config/ViewToolbarButtons/Visibility/$(listItem)$\n\\end\n<$set name=\"tv-config-toolbar-icons\" value=\"yes\">\n\n<$set name=\"tv-config-toolbar-text\" value=\"yes\">\n\n<$set name=\"tv-config-toolbar-class\" value=\"\">\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/ViewToolbar]!has[draft.of]]\" variable=\"listItem\">\n\n<$checkbox tiddler=<<config-title>> field=\"text\" checked=\"show\" unchecked=\"hide\" default=\"show\"/> <$transclude tiddler=<<listItem>>/> <i class=\"tc-muted\"><$transclude tiddler=<<listItem>> field=\"description\"/></i>\n\n</$list>\n\n</$set>\n\n</$set>\n\n</$set>\n"
},
"$:/core/ui/TiddlerInfo": {
"title": "$:/core/ui/TiddlerInfo",
"text": "<div style=\"position:relative;\">\n<div class=\"tc-tiddler-controls\" style=\"position:absolute;right:0;\">\n<$reveal state=\"$:/config/TiddlerInfo/Mode\" type=\"match\" text=\"sticky\">\n<$button set=<<tiddlerInfoState>> setTo=\"\" tooltip={{$:/language/Buttons/Info/Hint}} aria-label={{$:/language/Buttons/Info/Caption}} class=\"tc-btn-invisible\">\n{{$:/core/images/close-button}}\n</$button>\n</$reveal>\n</div>\n</div>\n\n<$macrocall $name=\"tabs\" tabsList=\"[all[shadows+tiddlers]tag[$:/tags/TiddlerInfo]!has[draft.of]]\" default={{$:/config/TiddlerInfo/Default}}/>"
},
"$:/core/ui/TopBar/menu": {
"title": "$:/core/ui/TopBar/menu",
"tags": "$:/tags/TopRightBar",
"text": "<$reveal state=\"$:/state/sidebar\" type=\"nomatch\" text=\"no\">\n<$button set=\"$:/state/sidebar\" setTo=\"no\" tooltip={{$:/language/Buttons/HideSideBar/Hint}} aria-label={{$:/language/Buttons/HideSideBar/Caption}} class=\"tc-btn-invisible\">{{$:/core/images/chevron-right}}</$button>\n</$reveal>\n<$reveal state=\"$:/state/sidebar\" type=\"match\" text=\"no\">\n<$button set=\"$:/state/sidebar\" setTo=\"yes\" tooltip={{$:/language/Buttons/ShowSideBar/Hint}} aria-label={{$:/language/Buttons/ShowSideBar/Caption}} class=\"tc-btn-invisible\">{{$:/core/images/chevron-left}}</$button>\n</$reveal>\n"
},
"$:/core/ui/UntaggedTemplate": {
"title": "$:/core/ui/UntaggedTemplate",
"text": "\\define lingo-base() $:/language/SideBar/\n<$button popup=<<qualify \"$:/state/popup/tag\">> class=\"tc-btn-invisible tc-untagged-label tc-tag-label\">\n<<lingo Tags/Untagged/Caption>>\n</$button>\n<$reveal state=<<qualify \"$:/state/popup/tag\">> type=\"popup\" position=\"below\">\n<div class=\"tc-drop-down\">\n<$list filter=\"[untagged[]!is[system]] -[tags[]] +[sort[title]]\" template=\"$:/core/ui/ListItemTemplate\"/>\n</div>\n</$reveal>\n"
},
"$:/core/ui/ViewTemplate/body": {
"title": "$:/core/ui/ViewTemplate/body",
"tags": "$:/tags/ViewTemplate",
"text": "<$reveal tag=\"div\" class=\"tc-tiddler-body\" type=\"nomatch\" stateTitle=<<folded-state>> text=\"hide\" retain=\"yes\" animate=\"yes\">\n\n<$list filter=\"[all[current]!has[plugin-type]!field:hide-body[yes]]\">\n\n<$transclude>\n\n<$transclude tiddler=\"$:/language/MissingTiddler/Hint\"/>\n\n</$transclude>\n\n</$list>\n\n</$reveal>\n"
},
"$:/core/ui/ViewTemplate/classic": {
"title": "$:/core/ui/ViewTemplate/classic",
"tags": "$:/tags/ViewTemplate $:/tags/EditTemplate",
"text": "\\define lingo-base() $:/language/ClassicWarning/\n<$list filter=\"[all[current]type[text/x-tiddlywiki]]\">\n<div class=\"tc-message-box\">\n\n<<lingo Hint>>\n\n<$button set=\"!!type\" setTo=\"text/vnd.tiddlywiki\"><<lingo Upgrade/Caption>></$button>\n\n</div>\n</$list>\n"
},
"$:/core/ui/ViewTemplate/import": {
"title": "$:/core/ui/ViewTemplate/import",
"tags": "$:/tags/ViewTemplate",
"text": "\\define lingo-base() $:/language/Import/\n\n\\define buttons()\n<$button message=\"tm-delete-tiddler\" param=<<currentTiddler>>><<lingo Listing/Cancel/Caption>></$button>\n<$button message=\"tm-perform-import\" param=<<currentTiddler>>><<lingo Listing/Import/Caption>></$button>\n<<lingo Listing/Preview>> <$select tiddler=\"$:/state/importpreviewtype\" default=\"$:/core/ui/ImportPreviews/Text\">\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/ImportPreview]!has[draft.of]]\">\n<option value=<<currentTiddler>>>{{!!caption}}</option>\n</$list>\n</$select>\n\\end\n\n<$list filter=\"[all[current]field:plugin-type[import]]\">\n\n<div class=\"tc-import\">\n\n<<lingo Listing/Hint>>\n\n<<buttons>>\n\n{{||$:/core/ui/ImportListing}}\n\n<<buttons>>\n\n</div>\n\n</$list>\n"
},
"$:/core/ui/ViewTemplate/plugin": {
"title": "$:/core/ui/ViewTemplate/plugin",
"tags": "$:/tags/ViewTemplate",
"text": "<$list filter=\"[all[current]has[plugin-type]] -[all[current]field:plugin-type[import]]\">\n<$set name=\"plugin-type\" value={{!!plugin-type}}>\n<$set name=\"default-popup-state\" value=\"yes\">\n<$set name=\"qualified-state\" value=<<qualify \"$:/state/plugin-info\">>>\n{{||$:/core/ui/Components/plugin-info}}\n</$set>\n</$set>\n</$set>\n</$list>\n"
},
"$:/core/ui/ViewTemplate/subtitle": {
"title": "$:/core/ui/ViewTemplate/subtitle",
"tags": "$:/tags/ViewTemplate",
"text": "<$reveal type=\"nomatch\" stateTitle=<<folded-state>> text=\"hide\" tag=\"div\" retain=\"yes\" animate=\"yes\">\n<div class=\"tc-subtitle\">\n<$link to={{!!modifier}}>\n<$view field=\"modifier\"/>\n</$link> <$view field=\"modified\" format=\"date\" template={{$:/language/Tiddler/DateFormat}}/>\n</div>\n</$reveal>\n"
},
"$:/core/ui/ViewTemplate/tags": {
"title": "$:/core/ui/ViewTemplate/tags",
"tags": "$:/tags/ViewTemplate",
"text": "<$reveal type=\"nomatch\" stateTitle=<<folded-state>> text=\"hide\" tag=\"div\" retain=\"yes\" animate=\"yes\">\n<div class=\"tc-tags-wrapper\"><$list filter=\"[all[current]tags[]sort[title]]\" template=\"$:/core/ui/TagTemplate\" storyview=\"pop\"/></div>\n</$reveal>\n"
},
"$:/core/ui/ViewTemplate/title": {
"title": "$:/core/ui/ViewTemplate/title",
"tags": "$:/tags/ViewTemplate",
"text": "\\define title-styles()\nfill:$(foregroundColor)$;\n\\end\n\\define config-title()\n$:/config/ViewToolbarButtons/Visibility/$(listItem)$\n\\end\n<div class=\"tc-tiddler-title\">\n<div class=\"tc-titlebar\">\n<span class=\"tc-tiddler-controls\">\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/ViewToolbar]!has[draft.of]]\" variable=\"listItem\"><$reveal type=\"nomatch\" state=<<config-title>> text=\"hide\"><$set name=\"tv-config-toolbar-class\" filter=\"[<tv-config-toolbar-class>] [<listItem>encodeuricomponent[]addprefix[tc-btn-]]\"><$transclude tiddler=<<listItem>>/></$set></$reveal></$list>\n</span>\n<$set name=\"tv-wikilinks\" value={{$:/config/Tiddlers/TitleLinks}}>\n<$link>\n<$set name=\"foregroundColor\" value={{!!color}}>\n<span class=\"tc-tiddler-title-icon\" style=<<title-styles>>>\n<$transclude tiddler={{!!icon}}/>\n</span>\n</$set>\n<$list filter=\"[all[current]removeprefix[$:/]]\">\n<h2 class=\"tc-title\" title={{$:/language/SystemTiddler/Tooltip}}>\n<span class=\"tc-system-title-prefix\">$:/</span><$text text=<<currentTiddler>>/>\n</h2>\n</$list>\n<$list filter=\"[all[current]!prefix[$:/]]\">\n<h2 class=\"tc-title\">\n<$view field=\"title\"/>\n</h2>\n</$list>\n</$link>\n</$set>\n</div>\n\n<$reveal type=\"nomatch\" text=\"\" default=\"\" state=<<tiddlerInfoState>> class=\"tc-tiddler-info tc-popup-handle\" animate=\"yes\" retain=\"yes\">\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/TiddlerInfoSegment]!has[draft.of]] [[$:/core/ui/TiddlerInfo]]\" variable=\"listItem\"><$transclude tiddler=<<listItem>> mode=\"block\"/></$list>\n\n</$reveal>\n</div>"
},
"$:/core/ui/ViewTemplate/unfold": {
"title": "$:/core/ui/ViewTemplate/unfold",
"tags": "$:/tags/ViewTemplate",
"text": "<$reveal tag=\"div\" type=\"nomatch\" state=\"$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/fold-bar\" text=\"hide\">\n<$reveal tag=\"div\" type=\"nomatch\" stateTitle=<<folded-state>> text=\"hide\" default=\"show\" retain=\"yes\" animate=\"yes\">\n<$button tooltip={{$:/language/Buttons/Fold/Hint}} aria-label={{$:/language/Buttons/Fold/Caption}} class=\"tc-fold-banner\">\n<$action-sendmessage $message=\"tm-fold-tiddler\" $param=<<currentTiddler>> foldedState=<<folded-state>>/>\n{{$:/core/images/chevron-up}}\n</$button>\n</$reveal>\n<$reveal tag=\"div\" type=\"nomatch\" stateTitle=<<folded-state>> text=\"show\" default=\"show\" retain=\"yes\" animate=\"yes\">\n<$button tooltip={{$:/language/Buttons/Unfold/Hint}} aria-label={{$:/language/Buttons/Unfold/Caption}} class=\"tc-unfold-banner\">\n<$action-sendmessage $message=\"tm-fold-tiddler\" $param=<<currentTiddler>> foldedState=<<folded-state>>/>\n{{$:/core/images/chevron-down}}\n</$button>\n</$reveal>\n</$reveal>\n"
},
"$:/core/ui/ViewTemplate": {
"title": "$:/core/ui/ViewTemplate",
"text": "\\define frame-classes()\ntc-tiddler-frame tc-tiddler-view-frame $(missingTiddlerClass)$ $(shadowTiddlerClass)$ $(systemTiddlerClass)$ $(tiddlerTagClasses)$ $(userClass)$\n\\end\n\\define folded-state()\n$:/state/folded/$(currentTiddler)$\n\\end\n<$vars storyTiddler=<<currentTiddler>> tiddlerInfoState=<<qualify \"$:/state/popup/tiddler-info\">> userClass={{!!class}}><$tiddler tiddler=<<currentTiddler>>><div data-tiddler-title=<<currentTiddler>> data-tags={{!!tags}} class=<<frame-classes>>><$list filter=\"[all[shadows+tiddlers]tag[$:/tags/ViewTemplate]!has[draft.of]]\" variable=\"listItem\"><$transclude tiddler=<<listItem>>/></$list>\n</div>\n</$tiddler></$vars>\n"
},
"$:/core/ui/Buttons/clone": {
"title": "$:/core/ui/Buttons/clone",
"tags": "$:/tags/ViewToolbar",
"caption": "{{$:/core/images/clone-button}} {{$:/language/Buttons/Clone/Caption}}",
"description": "{{$:/language/Buttons/Clone/Hint}}",
"text": "\\whitespace trim\n<$button message=\"tm-new-tiddler\" param=<<currentTiddler>> tooltip={{$:/language/Buttons/Clone/Hint}} aria-label={{$:/language/Buttons/Clone/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/clone-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\">\n<$text text=\" \"/>\n<$text text={{$:/language/Buttons/Clone/Caption}}/>\n</span>\n</$list>\n</$button>"
},
"$:/core/ui/Buttons/close-others": {
"title": "$:/core/ui/Buttons/close-others",
"tags": "$:/tags/ViewToolbar",
"caption": "{{$:/core/images/close-others-button}} {{$:/language/Buttons/CloseOthers/Caption}}",
"description": "{{$:/language/Buttons/CloseOthers/Hint}}",
"text": "\\whitespace trim\n<$button message=\"tm-close-other-tiddlers\" param=<<currentTiddler>> tooltip={{$:/language/Buttons/CloseOthers/Hint}} aria-label={{$:/language/Buttons/CloseOthers/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/close-others-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\">\n<$text text=\" \"/>\n<$text text={{$:/language/Buttons/CloseOthers/Caption}}/>\n</span>\n</$list>\n</$button>"
},
"$:/core/ui/Buttons/close": {
"title": "$:/core/ui/Buttons/close",
"tags": "$:/tags/ViewToolbar",
"caption": "{{$:/core/images/close-button}} {{$:/language/Buttons/Close/Caption}}",
"description": "{{$:/language/Buttons/Close/Hint}}",
"text": "\\whitespace trim\n<$button message=\"tm-close-tiddler\" tooltip={{$:/language/Buttons/Close/Hint}} aria-label={{$:/language/Buttons/Close/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/close-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\">\n<$text text={{$:/language/Buttons/Close/Caption}}/>\n</span>\n</$list>\n</$button>"
},
"$:/core/ui/Buttons/edit": {
"title": "$:/core/ui/Buttons/edit",
"tags": "$:/tags/ViewToolbar",
"caption": "{{$:/core/images/edit-button}} {{$:/language/Buttons/Edit/Caption}}",
"description": "{{$:/language/Buttons/Edit/Hint}}",
"text": "\\whitespace trim\n<$button message=\"tm-edit-tiddler\" tooltip={{$:/language/Buttons/Edit/Hint}} aria-label={{$:/language/Buttons/Edit/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/edit-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\">\n<$text text=\" \"/>\n<$text text={{$:/language/Buttons/Edit/Caption}}/>\n</span>\n</$list>\n</$button>"
},
"$:/core/ui/Buttons/export-tiddler": {
"title": "$:/core/ui/Buttons/export-tiddler",
"tags": "$:/tags/ViewToolbar",
"caption": "{{$:/core/images/export-button}} {{$:/language/Buttons/ExportTiddler/Caption}}",
"description": "{{$:/language/Buttons/ExportTiddler/Hint}}",
"text": "\\define makeExportFilter()\n[[$(currentTiddler)$]]\n\\end\n<$macrocall $name=\"exportButton\" exportFilter=<<makeExportFilter>> lingoBase=\"$:/language/Buttons/ExportTiddler/\" baseFilename=<<currentTiddler>>/>"
},
"$:/core/ui/Buttons/fold-bar": {
"title": "$:/core/ui/Buttons/fold-bar",
"tags": "$:/tags/ViewToolbar",
"caption": "{{$:/core/images/chevron-up}} {{$:/language/Buttons/Fold/FoldBar/Caption}}",
"description": "{{$:/language/Buttons/Fold/FoldBar/Hint}}",
"text": "<!-- This dummy toolbar button is here to allow visibility of the fold-bar to be controlled as if it were a toolbar button -->"
},
"$:/core/ui/Buttons/fold-others": {
"title": "$:/core/ui/Buttons/fold-others",
"tags": "$:/tags/ViewToolbar",
"caption": "{{$:/core/images/fold-others-button}} {{$:/language/Buttons/FoldOthers/Caption}}",
"description": "{{$:/language/Buttons/FoldOthers/Hint}}",
"text": "\\whitespace trim\n<$button tooltip={{$:/language/Buttons/FoldOthers/Hint}} aria-label={{$:/language/Buttons/FoldOthers/Caption}} class=<<tv-config-toolbar-class>>>\n<$action-sendmessage $message=\"tm-fold-other-tiddlers\" $param=<<currentTiddler>> foldedStatePrefix=\"$:/state/folded/\"/>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\" variable=\"listItem\">\n{{$:/core/images/fold-others-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\">\n<$text text=\" \"/>\n<$text text={{$:/language/Buttons/FoldOthers/Caption}}/>\n</span>\n</$list>\n</$button>"
},
"$:/core/ui/Buttons/fold": {
"title": "$:/core/ui/Buttons/fold",
"tags": "$:/tags/ViewToolbar",
"caption": "{{$:/core/images/fold-button}} {{$:/language/Buttons/Fold/Caption}}",
"description": "{{$:/language/Buttons/Fold/Hint}}",
"text": "\\whitespace trim\n<$reveal type=\"nomatch\" stateTitle=<<folded-state>> text=\"hide\" default=\"show\">\n<$button tooltip={{$:/language/Buttons/Fold/Hint}} aria-label={{$:/language/Buttons/Fold/Caption}} class=<<tv-config-toolbar-class>>>\n<$action-sendmessage $message=\"tm-fold-tiddler\" $param=<<currentTiddler>> foldedState=<<folded-state>>/>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\" variable=\"listItem\">\n{{$:/core/images/fold-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\">\n<$text text=\" \"/>\n<$text text={{$:/language/Buttons/Fold/Caption}}/>\n</span>\n</$list>\n</$button>\n</$reveal>\n<$reveal type=\"match\" stateTitle=<<folded-state>> text=\"hide\" default=\"show\">\n<$button tooltip={{$:/language/Buttons/Unfold/Hint}} aria-label={{$:/language/Buttons/Unfold/Caption}} class=<<tv-config-toolbar-class>>>\n<$action-sendmessage $message=\"tm-fold-tiddler\" $param=<<currentTiddler>> foldedState=<<folded-state>>/>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\" variable=\"listItem\">\n{{$:/core/images/unfold-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\">\n<$text text=\" \"/>\n<$text text={{$:/language/Buttons/Unfold/Caption}}/>\n</span>\n</$list>\n</$button>\n</$reveal>\n"
},
"$:/core/ui/Buttons/info": {
"title": "$:/core/ui/Buttons/info",
"tags": "$:/tags/ViewToolbar",
"caption": "{{$:/core/images/info-button}} {{$:/language/Buttons/Info/Caption}}",
"description": "{{$:/language/Buttons/Info/Hint}}",
"text": "\\whitespace trim\n\\define button-content()\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/info-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\">\n<$text text={{$:/language/Buttons/Info/Caption}}/>\n</span>\n</$list>\n\\end\n<$reveal state=\"$:/config/TiddlerInfo/Mode\" type=\"match\" text=\"popup\">\n<$button popup=<<tiddlerInfoState>> tooltip={{$:/language/Buttons/Info/Hint}} aria-label={{$:/language/Buttons/Info/Caption}} class=<<tv-config-toolbar-class>> selectedClass=\"tc-selected\">\n<$macrocall $name=\"button-content\" mode=\"inline\"/>\n</$button>\n</$reveal>\n<$reveal state=\"$:/config/TiddlerInfo/Mode\" type=\"match\" text=\"sticky\">\n<$reveal state=<<tiddlerInfoState>> type=\"match\" text=\"\" default=\"\">\n<$button set=<<tiddlerInfoState>> setTo=\"yes\" tooltip={{$:/language/Buttons/Info/Hint}} aria-label={{$:/language/Buttons/Info/Caption}} class=<<tv-config-toolbar-class>> selectedClass=\"tc-selected\">\n<$macrocall $name=\"button-content\" mode=\"inline\"/>\n</$button>\n</$reveal>\n<$reveal state=<<tiddlerInfoState>> type=\"nomatch\" text=\"\" default=\"\">\n<$button set=<<tiddlerInfoState>> setTo=\"\" tooltip={{$:/language/Buttons/Info/Hint}} aria-label={{$:/language/Buttons/Info/Caption}} class=<<tv-config-toolbar-class>> selectedClass=\"tc-selected\">\n<$macrocall $name=\"button-content\" mode=\"inline\"/>\n</$button>\n</$reveal>\n</$reveal>"
},
"$:/core/ui/Buttons/more-tiddler-actions": {
"title": "$:/core/ui/Buttons/more-tiddler-actions",
"tags": "$:/tags/ViewToolbar",
"caption": "{{$:/core/images/down-arrow}} {{$:/language/Buttons/More/Caption}}",
"description": "{{$:/language/Buttons/More/Hint}}",
"text": "\\whitespace trim\n\\define config-title()\n$:/config/ViewToolbarButtons/Visibility/$(listItem)$\n\\end\n<$button popup=<<qualify \"$:/state/popup/more\">> tooltip={{$:/language/Buttons/More/Hint}} aria-label={{$:/language/Buttons/More/Caption}} class=<<tv-config-toolbar-class>> selectedClass=\"tc-selected\">\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/down-arrow}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\">\n<$text text=\" \"/>\n<$text text={{$:/language/Buttons/More/Caption}}/>\n</span>\n</$list>\n</$button>\n<$reveal state=<<qualify \"$:/state/popup/more\">> type=\"popup\" position=\"belowleft\" animate=\"yes\">\n\n<div class=\"tc-drop-down\">\n\n<$set name=\"tv-config-toolbar-icons\" value=\"yes\">\n\n<$set name=\"tv-config-toolbar-text\" value=\"yes\">\n\n<$set name=\"tv-config-toolbar-class\" value=\"tc-btn-invisible\">\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/ViewToolbar]!has[draft.of]] -[[$:/core/ui/Buttons/more-tiddler-actions]]\" variable=\"listItem\">\n\n<$reveal type=\"match\" state=<<config-title>> text=\"hide\">\n\n<$set name=\"tv-config-toolbar-class\" filter=\"[<tv-config-toolbar-class>] [<listItem>encodeuricomponent[]addprefix[tc-btn-]]\">\n\n<$transclude tiddler=<<listItem>> mode=\"inline\"/>\n\n</$set>\n\n</$reveal>\n\n</$list>\n\n</$set>\n\n</$set>\n\n</$set>\n\n</div>\n\n</$reveal>"
},
"$:/core/ui/Buttons/new-here": {
"title": "$:/core/ui/Buttons/new-here",
"tags": "$:/tags/ViewToolbar",
"caption": "{{$:/core/images/new-here-button}} {{$:/language/Buttons/NewHere/Caption}}",
"description": "{{$:/language/Buttons/NewHere/Hint}}",
"text": "\\whitespace trim\n\\define newHereButtonTags()\n[[$(currentTiddler)$]]\n\\end\n\\define newHereButton()\n<$button tooltip={{$:/language/Buttons/NewHere/Hint}} aria-label={{$:/language/Buttons/NewHere/Caption}} class=<<tv-config-toolbar-class>>>\n<$action-sendmessage $message=\"tm-new-tiddler\" tags=<<newHereButtonTags>>/>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/new-here-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\">\n<$text text={{$:/language/Buttons/NewHere/Caption}}/>\n</span>\n</$list>\n</$button>\n\\end\n<<newHereButton>>"
},
"$:/core/ui/Buttons/new-journal-here": {
"title": "$:/core/ui/Buttons/new-journal-here",
"tags": "$:/tags/ViewToolbar",
"caption": "{{$:/core/images/new-journal-button}} {{$:/language/Buttons/NewJournalHere/Caption}}",
"description": "{{$:/language/Buttons/NewJournalHere/Hint}}",
"text": "\\whitespace trim\n\\define journalButtonTags()\n[[$(currentTiddlerTag)$]] $(journalTags)$\n\\end\n\\define journalButton()\n<$button tooltip={{$:/language/Buttons/NewJournalHere/Hint}} aria-label={{$:/language/Buttons/NewJournalHere/Caption}} class=<<tv-config-toolbar-class>>>\n<$wikify name=\"journalTitle\" text=\"\"\"<$macrocall $name=\"now\" format=<<journalTitleTemplate>>/>\"\"\">\n<$action-sendmessage $message=\"tm-new-tiddler\" title=<<journalTitle>> tags=<<journalButtonTags>>/>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/new-journal-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\">\n<$text text={{$:/language/Buttons/NewJournalHere/Caption}}/>\n</span>\n</$list>\n</$wikify>\n</$button>\n\\end\n<$set name=\"journalTitleTemplate\" value={{$:/config/NewJournal/Title}}>\n<$set name=\"journalTags\" value={{$:/config/NewJournal/Tags}}>\n<$set name=\"currentTiddlerTag\" value=<<currentTiddler>>>\n<<journalButton>>\n</$set>\n</$set>\n</$set>"
},
"$:/core/ui/Buttons/open-window": {
"title": "$:/core/ui/Buttons/open-window",
"tags": "$:/tags/ViewToolbar",
"caption": "{{$:/core/images/open-window}} {{$:/language/Buttons/OpenWindow/Caption}}",
"description": "{{$:/language/Buttons/OpenWindow/Hint}}",
"text": "\\whitespace trim\n<$button message=\"tm-open-window\" tooltip={{$:/language/Buttons/OpenWindow/Hint}} aria-label={{$:/language/Buttons/OpenWindow/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/open-window}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\">\n<$text text=\" \"/>\n<$text text={{$:/language/Buttons/OpenWindow/Caption}}/>\n</span>\n</$list>\n</$button>"
},
"$:/core/ui/Buttons/permalink": {
"title": "$:/core/ui/Buttons/permalink",
"tags": "$:/tags/ViewToolbar",
"caption": "{{$:/core/images/permalink-button}} {{$:/language/Buttons/Permalink/Caption}}",
"description": "{{$:/language/Buttons/Permalink/Hint}}",
"text": "\\whitespace trim\n<$button message=\"tm-permalink\" tooltip={{$:/language/Buttons/Permalink/Hint}} aria-label={{$:/language/Buttons/Permalink/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/permalink-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\">\n<$text text=\" \"/>\n<$text text={{$:/language/Buttons/Permalink/Caption}}/>\n</span>\n</$list>\n</$button>"
},
"$:/core/ui/Buttons/permaview": {
"title": "$:/core/ui/Buttons/permaview",
"tags": "$:/tags/ViewToolbar $:/tags/PageControls",
"caption": "{{$:/core/images/permaview-button}} {{$:/language/Buttons/Permaview/Caption}}",
"description": "{{$:/language/Buttons/Permaview/Hint}}",
"text": "\\whitespace trim\n<$button message=\"tm-permaview\" tooltip={{$:/language/Buttons/Permaview/Hint}} aria-label={{$:/language/Buttons/Permaview/Caption}} class=<<tv-config-toolbar-class>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/permaview-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\">\n<$text text=\" \"/>\n<$text text={{$:/language/Buttons/Permaview/Caption}}/>\n</span>\n</$list>\n</$button>"
},
"$:/DefaultTiddlers": {
"title": "$:/DefaultTiddlers",
"text": "GettingStarted\n"
},
"$:/temp/advancedsearch": {
"title": "$:/temp/advancedsearch",
"text": ""
},
"$:/snippets/allfields": {
"title": "$:/snippets/allfields",
"text": "\\define renderfield(title)\n<tr class=\"tc-view-field\"><td class=\"tc-view-field-name\">''$title$'':</td><td class=\"tc-view-field-value\">//{{$:/language/Docs/Fields/$title$}}//</td></tr>\n\\end\n<table class=\"tc-view-field-table\"><tbody><$list filter=\"[fields[]sort[title]]\" variable=\"listItem\"><$macrocall $name=\"renderfield\" title=<<listItem>>/></$list>\n</tbody></table>\n"
},
"$:/config/AnimationDuration": {
"title": "$:/config/AnimationDuration",
"text": "400"
},
"$:/config/AutoSave": {
"title": "$:/config/AutoSave",
"text": "yes"
},
"$:/config/BitmapEditor/Colour": {
"title": "$:/config/BitmapEditor/Colour",
"text": "#444"
},
"$:/config/BitmapEditor/ImageSizes": {
"title": "$:/config/BitmapEditor/ImageSizes",
"text": "[[62px 100px]] [[100px 62px]] [[124px 200px]] [[200px 124px]] [[248px 400px]] [[371px 600px]] [[400px 248px]] [[556px 900px]] [[600px 371px]] [[742px 1200px]] [[900px 556px]] [[1200px 742px]]"
},
"$:/config/BitmapEditor/LineWidth": {
"title": "$:/config/BitmapEditor/LineWidth",
"text": "3px"
},
"$:/config/BitmapEditor/LineWidths": {
"title": "$:/config/BitmapEditor/LineWidths",
"text": "0.25px 0.5px 1px 2px 3px 4px 6px 8px 10px 16px 20px 28px 40px 56px 80px"
},
"$:/config/BitmapEditor/Opacities": {
"title": "$:/config/BitmapEditor/Opacities",
"text": "0.01 0.025 0.05 0.075 0.1 0.15 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0"
},
"$:/config/BitmapEditor/Opacity": {
"title": "$:/config/BitmapEditor/Opacity",
"text": "1.0"
},
"$:/config/DefaultMoreSidebarTab": {
"title": "$:/config/DefaultMoreSidebarTab",
"text": "$:/core/ui/MoreSideBar/Tags"
},
"$:/config/DefaultSidebarTab": {
"title": "$:/config/DefaultSidebarTab",
"text": "$:/core/ui/SideBar/Open"
},
"$:/config/DownloadSaver/AutoSave": {
"title": "$:/config/DownloadSaver/AutoSave",
"text": "no"
},
"$:/config/Drafts/TypingTimeout": {
"title": "$:/config/Drafts/TypingTimeout",
"text": "400"
},
"$:/config/EditTemplateFields/Visibility/title": {
"title": "$:/config/EditTemplateFields/Visibility/title",
"text": "hide"
},
"$:/config/EditTemplateFields/Visibility/tags": {
"title": "$:/config/EditTemplateFields/Visibility/tags",
"text": "hide"
},
"$:/config/EditTemplateFields/Visibility/text": {
"title": "$:/config/EditTemplateFields/Visibility/text",
"text": "hide"
},
"$:/config/EditTemplateFields/Visibility/creator": {
"title": "$:/config/EditTemplateFields/Visibility/creator",
"text": "hide"
},
"$:/config/EditTemplateFields/Visibility/created": {
"title": "$:/config/EditTemplateFields/Visibility/created",
"text": "hide"
},
"$:/config/EditTemplateFields/Visibility/modified": {
"title": "$:/config/EditTemplateFields/Visibility/modified",
"text": "hide"
},
"$:/config/EditTemplateFields/Visibility/modifier": {
"title": "$:/config/EditTemplateFields/Visibility/modifier",
"text": "hide"
},
"$:/config/EditTemplateFields/Visibility/type": {
"title": "$:/config/EditTemplateFields/Visibility/type",
"text": "hide"
},
"$:/config/EditTemplateFields/Visibility/draft.title": {
"title": "$:/config/EditTemplateFields/Visibility/draft.title",
"text": "hide"
},
"$:/config/EditTemplateFields/Visibility/draft.of": {
"title": "$:/config/EditTemplateFields/Visibility/draft.of",
"text": "hide"
},
"$:/config/EditTemplateFields/Visibility/revision": {
"title": "$:/config/EditTemplateFields/Visibility/revision",
"text": "hide"
},
"$:/config/EditTemplateFields/Visibility/bag": {
"title": "$:/config/EditTemplateFields/Visibility/bag",
"text": "hide"
},
"$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/heading-4": {
"title": "$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/heading-4",
"text": "hide"
},
"$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/heading-5": {
"title": "$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/heading-5",
"text": "hide"
},
"$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/heading-6": {
"title": "$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/heading-6",
"text": "hide"
},
"$:/config/EditorTypeMappings/image/gif": {
"title": "$:/config/EditorTypeMappings/image/gif",
"text": "bitmap"
},
"$:/config/EditorTypeMappings/image/webp": {
"title": "$:/config/EditorTypeMappings/image/webp",
"text": "bitmap"
},
"$:/config/EditorTypeMappings/image/heic": {
"title": "$:/config/EditorTypeMappings/image/heic",
"text": "bitmap"
},
"$:/config/EditorTypeMappings/image/heif": {
"title": "$:/config/EditorTypeMappings/image/heif",
"text": "bitmap"
},
"$:/config/EditorTypeMappings/image/jpeg": {
"title": "$:/config/EditorTypeMappings/image/jpeg",
"text": "bitmap"
},
"$:/config/EditorTypeMappings/image/jpg": {
"title": "$:/config/EditorTypeMappings/image/jpg",
"text": "bitmap"
},
"$:/config/EditorTypeMappings/image/png": {
"title": "$:/config/EditorTypeMappings/image/png",
"text": "bitmap"
},
"$:/config/EditorTypeMappings/image/x-icon": {
"title": "$:/config/EditorTypeMappings/image/x-icon",
"text": "bitmap"
},
"$:/config/EditorTypeMappings/text/vnd.tiddlywiki": {
"title": "$:/config/EditorTypeMappings/text/vnd.tiddlywiki",
"text": "text"
},
"$:/config/Manager/Show": {
"title": "$:/config/Manager/Show",
"text": "tiddlers"
},
"$:/config/Manager/Filter": {
"title": "$:/config/Manager/Filter",
"text": ""
},
"$:/config/Manager/Order": {
"title": "$:/config/Manager/Order",
"text": "forward"
},
"$:/config/Manager/Sort": {
"title": "$:/config/Manager/Sort",
"text": "title"
},
"$:/config/Manager/System": {
"title": "$:/config/Manager/System",
"text": "system"
},
"$:/config/Manager/Tag": {
"title": "$:/config/Manager/Tag",
"text": ""
},
"$:/state/popup/manager/item/$:/Manager/ItemMain/RawText": {
"title": "$:/state/popup/manager/item/$:/Manager/ItemMain/RawText",
"text": "hide"
},
"$:/config/MissingLinks": {
"title": "$:/config/MissingLinks",
"text": "yes"
},
"$:/config/Navigation/UpdateAddressBar": {
"title": "$:/config/Navigation/UpdateAddressBar",
"text": "no"
},
"$:/config/Navigation/UpdateHistory": {
"title": "$:/config/Navigation/UpdateHistory",
"text": "no"
},
"$:/config/NewImageType": {
"title": "$:/config/NewImageType",
"text": "jpeg"
},
"$:/config/OfficialPluginLibrary": {
"title": "$:/config/OfficialPluginLibrary",
"tags": "$:/tags/PluginLibrary",
"url": "https://tiddlywiki.com/library/v5.1.19/index.html",
"caption": "{{$:/language/OfficialPluginLibrary}}",
"text": "{{$:/language/OfficialPluginLibrary/Hint}}\n"
},
"$:/config/Navigation/openLinkFromInsideRiver": {
"title": "$:/config/Navigation/openLinkFromInsideRiver",
"text": "below"
},
"$:/config/Navigation/openLinkFromOutsideRiver": {
"title": "$:/config/Navigation/openLinkFromOutsideRiver",
"text": "top"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/advanced-search": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/advanced-search",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/close-all": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/close-all",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/encryption": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/encryption",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/export-page": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/export-page",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/fold-all": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/fold-all",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/full-screen": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/full-screen",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/home": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/home",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/refresh": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/refresh",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/import": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/import",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/language": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/language",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/tag-manager": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/tag-manager",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/manager": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/manager",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/more-page-actions": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/more-page-actions",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/new-journal": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/new-journal",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/new-image": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/new-image",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/palette": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/palette",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/permaview": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/permaview",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/print": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/print",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/storyview": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/storyview",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/timestamp": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/timestamp",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/theme": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/theme",
"text": "hide"
},
"$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/unfold-all": {
"title": "$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/unfold-all",
"text": "hide"
},
"$:/config/Performance/Instrumentation": {
"title": "$:/config/Performance/Instrumentation",
"text": "no"
},
"$:/config/SaveWikiButton/Template": {
"title": "$:/config/SaveWikiButton/Template",
"text": "$:/core/save/all"
},
"$:/config/SaverFilter": {
"title": "$:/config/SaverFilter",
"text": "[all[]] -[[$:/HistoryList]] -[[$:/StoryList]] -[[$:/Import]] -[[$:/isEncrypted]] -[[$:/UploadName]] -[prefix[$:/state/]] -[prefix[$:/temp/]]"
},
"$:/config/Search/AutoFocus": {
"title": "$:/config/Search/AutoFocus",
"text": "true"
},
"$:/config/Search/MinLength": {
"title": "$:/config/Search/MinLength",
"text": "3"
},
"$:/config/SearchResults/Default": {
"title": "$:/config/SearchResults/Default",
"text": "$:/core/ui/DefaultSearchResultList"
},
"$:/config/ShortcutInfo/bold": {
"title": "$:/config/ShortcutInfo/bold",
"text": "{{$:/language/Buttons/Bold/Hint}}"
},
"$:/config/ShortcutInfo/cancel-edit-tiddler": {
"title": "$:/config/ShortcutInfo/cancel-edit-tiddler",
"text": "{{$:/language/Buttons/Cancel/Hint}}"
},
"$:/config/ShortcutInfo/excise": {
"title": "$:/config/ShortcutInfo/excise",
"text": "{{$:/language/Buttons/Excise/Hint}}"
},
"$:/config/ShortcutInfo/heading-1": {
"title": "$:/config/ShortcutInfo/heading-1",
"text": "{{$:/language/Buttons/Heading1/Hint}}"
},
"$:/config/ShortcutInfo/heading-2": {
"title": "$:/config/ShortcutInfo/heading-2",
"text": "{{$:/language/Buttons/Heading2/Hint}}"
},
"$:/config/ShortcutInfo/heading-3": {
"title": "$:/config/ShortcutInfo/heading-3",
"text": "{{$:/language/Buttons/Heading3/Hint}}"
},
"$:/config/ShortcutInfo/heading-4": {
"title": "$:/config/ShortcutInfo/heading-4",
"text": "{{$:/language/Buttons/Heading4/Hint}}"
},
"$:/config/ShortcutInfo/heading-5": {
"title": "$:/config/ShortcutInfo/heading-5",
"text": "{{$:/language/Buttons/Heading5/Hint}}"
},
"$:/config/ShortcutInfo/heading-6": {
"title": "$:/config/ShortcutInfo/heading-6",
"text": "{{$:/language/Buttons/Heading6/Hint}}"
},
"$:/config/ShortcutInfo/italic": {
"title": "$:/config/ShortcutInfo/italic",
"text": "{{$:/language/Buttons/Italic/Hint}}"
},
"$:/config/ShortcutInfo/link": {
"title": "$:/config/ShortcutInfo/link",
"text": "{{$:/language/Buttons/Link/Hint}}"
},
"$:/config/ShortcutInfo/list-bullet": {
"title": "$:/config/ShortcutInfo/list-bullet",
"text": "{{$:/language/Buttons/ListBullet/Hint}}"
},
"$:/config/ShortcutInfo/list-number": {
"title": "$:/config/ShortcutInfo/list-number",
"text": "{{$:/language/Buttons/ListNumber/Hint}}"
},
"$:/config/ShortcutInfo/mono-block": {
"title": "$:/config/ShortcutInfo/mono-block",
"text": "{{$:/language/Buttons/MonoBlock/Hint}}"
},
"$:/config/ShortcutInfo/mono-line": {
"title": "$:/config/ShortcutInfo/mono-line",
"text": "{{$:/language/Buttons/MonoLine/Hint}}"
},
"$:/config/ShortcutInfo/new-image": {
"title": "$:/config/ShortcutInfo/new-image",
"text": "{{$:/language/Buttons/NewImage/Hint}}"
},
"$:/config/ShortcutInfo/new-journal": {
"title": "$:/config/ShortcutInfo/new-journal",
"text": "{{$:/language/Buttons/NewJournal/Hint}}"
},
"$:/config/ShortcutInfo/new-tiddler": {
"title": "$:/config/ShortcutInfo/new-tiddler",
"text": "{{$:/language/Buttons/NewTiddler/Hint}}"
},
"$:/config/ShortcutInfo/picture": {
"title": "$:/config/ShortcutInfo/picture",
"text": "{{$:/language/Buttons/Picture/Hint}}"
},
"$:/config/ShortcutInfo/preview": {
"title": "$:/config/ShortcutInfo/preview",
"text": "{{$:/language/Buttons/Preview/Hint}}"
},
"$:/config/ShortcutInfo/quote": {
"title": "$:/config/ShortcutInfo/quote",
"text": "{{$:/language/Buttons/Quote/Hint}}"
},
"$:/config/ShortcutInfo/save-tiddler": {
"title": "$:/config/ShortcutInfo/save-tiddler",
"text": "{{$:/language/Buttons/Save/Hint}}"
},
"$:/config/ShortcutInfo/stamp": {
"title": "$:/config/ShortcutInfo/stamp",
"text": "{{$:/language/Buttons/Stamp/Hint}}"
},
"$:/config/ShortcutInfo/strikethrough": {
"title": "$:/config/ShortcutInfo/strikethrough",
"text": "{{$:/language/Buttons/Strikethrough/Hint}}"
},
"$:/config/ShortcutInfo/subscript": {
"title": "$:/config/ShortcutInfo/subscript",
"text": "{{$:/language/Buttons/Subscript/Hint}}"
},
"$:/config/ShortcutInfo/superscript": {
"title": "$:/config/ShortcutInfo/superscript",
"text": "{{$:/language/Buttons/Superscript/Hint}}"
},
"$:/config/ShortcutInfo/underline": {
"title": "$:/config/ShortcutInfo/underline",
"text": "{{$:/language/Buttons/Underline/Hint}}"
},
"$:/config/SyncFilter": {
"title": "$:/config/SyncFilter",
"text": "[is[tiddler]] -[[$:/HistoryList]] -[[$:/Import]] -[[$:/isEncrypted]] -[prefix[$:/status/]] -[prefix[$:/state/]] -[prefix[$:/temp/]]"
},
"$:/config/Tags/MinLength": {
"title": "$:/config/Tags/MinLength",
"text": "0"
},
"$:/config/TextEditor/EditorHeight/Height": {
"title": "$:/config/TextEditor/EditorHeight/Height",
"text": "400px"
},
"$:/config/TextEditor/EditorHeight/Mode": {
"title": "$:/config/TextEditor/EditorHeight/Mode",
"text": "auto"
},
"$:/config/TiddlerInfo/Default": {
"title": "$:/config/TiddlerInfo/Default",
"text": "$:/core/ui/TiddlerInfo/Fields"
},
"$:/config/TiddlerInfo/Mode": {
"title": "$:/config/TiddlerInfo/Mode",
"text": "popup"
},
"$:/config/Tiddlers/TitleLinks": {
"title": "$:/config/Tiddlers/TitleLinks",
"text": "no"
},
"$:/config/Toolbar/ButtonClass": {
"title": "$:/config/Toolbar/ButtonClass",
"text": "tc-btn-invisible"
},
"$:/config/Toolbar/Icons": {
"title": "$:/config/Toolbar/Icons",
"text": "yes"
},
"$:/config/Toolbar/Text": {
"title": "$:/config/Toolbar/Text",
"text": "no"
},
"$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/clone": {
"title": "$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/clone",
"text": "hide"
},
"$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/close-others": {
"title": "$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/close-others",
"text": "hide"
},
"$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/export-tiddler": {
"title": "$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/export-tiddler",
"text": "hide"
},
"$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/info": {
"title": "$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/info",
"text": "hide"
},
"$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/more-tiddler-actions": {
"title": "$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/more-tiddler-actions",
"text": "show"
},
"$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/new-here": {
"title": "$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/new-here",
"text": "hide"
},
"$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/new-journal-here": {
"title": "$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/new-journal-here",
"text": "hide"
},
"$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/open-window": {
"title": "$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/open-window",
"text": "hide"
},
"$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/permalink": {
"title": "$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/permalink",
"text": "hide"
},
"$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/permaview": {
"title": "$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/permaview",
"text": "hide"
},
"$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/delete": {
"title": "$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/delete",
"text": "hide"
},
"$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/fold": {
"title": "$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/fold",
"text": "hide"
},
"$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/fold-bar": {
"title": "$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/fold-bar",
"text": "hide"
},
"$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/fold-others": {
"title": "$:/config/ViewToolbarButtons/Visibility/$:/core/ui/Buttons/fold-others",
"text": "hide"
},
"$:/config/shortcuts-mac/bold": {
"title": "$:/config/shortcuts-mac/bold",
"text": "meta-B"
},
"$:/config/shortcuts-mac/italic": {
"title": "$:/config/shortcuts-mac/italic",
"text": "meta-I"
},
"$:/config/shortcuts-mac/underline": {
"title": "$:/config/shortcuts-mac/underline",
"text": "meta-U"
},
"$:/config/shortcuts-mac/new-image": {
"title": "$:/config/shortcuts-mac/new-image",
"text": "ctrl-I"
},
"$:/config/shortcuts-mac/new-journal": {
"title": "$:/config/shortcuts-mac/new-journal",
"text": "ctrl-J"
},
"$:/config/shortcuts-mac/new-tiddler": {
"title": "$:/config/shortcuts-mac/new-tiddler",
"text": "ctrl-N"
},
"$:/config/shortcuts-not-mac/bold": {
"title": "$:/config/shortcuts-not-mac/bold",
"text": "ctrl-B"
},
"$:/config/shortcuts-not-mac/italic": {
"title": "$:/config/shortcuts-not-mac/italic",
"text": "ctrl-I"
},
"$:/config/shortcuts-not-mac/underline": {
"title": "$:/config/shortcuts-not-mac/underline",
"text": "ctrl-U"
},
"$:/config/shortcuts-not-mac/new-image": {
"title": "$:/config/shortcuts-not-mac/new-image",
"text": "alt-I"
},
"$:/config/shortcuts-not-mac/new-journal": {
"title": "$:/config/shortcuts-not-mac/new-journal",
"text": "alt-J"
},
"$:/config/shortcuts-not-mac/new-tiddler": {
"title": "$:/config/shortcuts-not-mac/new-tiddler",
"text": "alt-N"
},
"$:/config/shortcuts/cancel-edit-tiddler": {
"title": "$:/config/shortcuts/cancel-edit-tiddler",
"text": "escape"
},
"$:/config/shortcuts/excise": {
"title": "$:/config/shortcuts/excise",
"text": "ctrl-E"
},
"$:/config/shortcuts/heading-1": {
"title": "$:/config/shortcuts/heading-1",
"text": "ctrl-1"
},
"$:/config/shortcuts/heading-2": {
"title": "$:/config/shortcuts/heading-2",
"text": "ctrl-2"
},
"$:/config/shortcuts/heading-3": {
"title": "$:/config/shortcuts/heading-3",
"text": "ctrl-3"
},
"$:/config/shortcuts/heading-4": {
"title": "$:/config/shortcuts/heading-4",
"text": "ctrl-4"
},
"$:/config/shortcuts/heading-5": {
"title": "$:/config/shortcuts/heading-5",
"text": "ctrl-5"
},
"$:/config/shortcuts/heading-6": {
"title": "$:/config/shortcuts/heading-6",
"text": "ctrl-6"
},
"$:/config/shortcuts/link": {
"title": "$:/config/shortcuts/link",
"text": "ctrl-L"
},
"$:/config/shortcuts/linkify": {
"title": "$:/config/shortcuts/linkify",
"text": "alt-shift-L"
},
"$:/config/shortcuts/list-bullet": {
"title": "$:/config/shortcuts/list-bullet",
"text": "ctrl-shift-L"
},
"$:/config/shortcuts/list-number": {
"title": "$:/config/shortcuts/list-number",
"text": "ctrl-shift-N"
},
"$:/config/shortcuts/mono-block": {
"title": "$:/config/shortcuts/mono-block",
"text": "ctrl-shift-M"
},
"$:/config/shortcuts/mono-line": {
"title": "$:/config/shortcuts/mono-line",
"text": "ctrl-M"
},
"$:/config/shortcuts/picture": {
"title": "$:/config/shortcuts/picture",
"text": "ctrl-shift-I"
},
"$:/config/shortcuts/preview": {
"title": "$:/config/shortcuts/preview",
"text": "alt-P"
},
"$:/config/shortcuts/quote": {
"title": "$:/config/shortcuts/quote",
"text": "ctrl-Q"
},
"$:/config/shortcuts/save-tiddler": {
"title": "$:/config/shortcuts/save-tiddler",
"text": "ctrl+enter"
},
"$:/config/shortcuts/stamp": {
"title": "$:/config/shortcuts/stamp",
"text": "ctrl-S"
},
"$:/config/shortcuts/strikethrough": {
"title": "$:/config/shortcuts/strikethrough",
"text": "ctrl-T"
},
"$:/config/shortcuts/subscript": {
"title": "$:/config/shortcuts/subscript",
"text": "ctrl-shift-B"
},
"$:/config/shortcuts/superscript": {
"title": "$:/config/shortcuts/superscript",
"text": "ctrl-shift-P"
},
"$:/config/shortcuts/transcludify": {
"title": "$:/config/shortcuts/transcludify",
"text": "alt-shift-T"
},
"$:/config/WikiParserRules/Inline/wikilink": {
"title": "$:/config/WikiParserRules/Inline/wikilink",
"text": "enable"
},
"$:/snippets/currpalettepreview": {
"title": "$:/snippets/currpalettepreview",
"text": "\\define swatchStyle()\nbackground-color: $(swatchColour)$;\n\\end\n\\define swatch()\n<$set name=\"swatchColour\" value={{##$(colour)$}}\n><div class=\"tc-swatch\" style=<<swatchStyle>> title=<<colour>>/></$set>\n\\end\n<div class=\"tc-swatches-horiz\"><$list filter=\"\nforeground\nbackground\nmuted-foreground\nprimary\npage-background\ntab-background\ntiddler-info-background\n\" variable=\"colour\"><<swatch>></$list></div>"
},
"$:/snippets/download-wiki-button": {
"title": "$:/snippets/download-wiki-button",
"text": "\\define lingo-base() $:/language/ControlPanel/Tools/Download/\n<$button class=\"tc-btn-big-green\">\n<$action-sendmessage $message=\"tm-download-file\" $param=\"$:/core/save/all\" filename=\"index.html\"/>\n<<lingo Full/Caption>> {{$:/core/images/save-button}}\n</$button>"
},
"$:/language": {
"title": "$:/language",
"text": "$:/languages/en-GB"
},
"$:/snippets/languageswitcher": {
"title": "$:/snippets/languageswitcher",
"text": "\\define flag-title()\n$(languagePluginTitle)$/icon\n\\end\n\n<$linkcatcher to=\"$:/language\">\n<div class=\"tc-chooser tc-language-chooser\">\n<$list filter=\"[[$:/languages/en-GB]] [plugin-type[language]sort[description]]\">\n<$set name=\"cls\" filter=\"[all[current]field:title{$:/language}]\" value=\"tc-chooser-item tc-chosen\" emptyValue=\"tc-chooser-item\"><div class=<<cls>>>\n<$link>\n<span class=\"tc-image-button\">\n<$set name=\"languagePluginTitle\" value=<<currentTiddler>>>\n<$transclude subtiddler=<<flag-title>>>\n<$list filter=\"[all[current]field:title[$:/languages/en-GB]]\">\n<$transclude tiddler=\"$:/languages/en-GB/icon\"/>\n</$list>\n</$transclude>\n</$set>\n</span>\n<$view field=\"description\">\n<$view field=\"name\">\n<$view field=\"title\"/>\n</$view>\n</$view>\n</$link>\n</div>\n</$set>\n</$list>\n</div>\n</$linkcatcher>"
},
"$:/core/macros/CSS": {
"title": "$:/core/macros/CSS",
"tags": "$:/tags/Macro",
"text": "\\define colour(name)\n<$transclude tiddler={{$:/palette}} index=\"$name$\"><$transclude tiddler=\"$:/palettes/Vanilla\" index=\"$name$\"/></$transclude>\n\\end\n\n\\define color(name)\n<<colour $name$>>\n\\end\n\n\\define box-shadow(shadow)\n``\n -webkit-box-shadow: $shadow$;\n -moz-box-shadow: $shadow$;\n box-shadow: $shadow$;\n``\n\\end\n\n\\define filter(filter)\n``\n -webkit-filter: $filter$;\n -moz-filter: $filter$;\n filter: $filter$;\n``\n\\end\n\n\\define transition(transition)\n``\n -webkit-transition: $transition$;\n -moz-transition: $transition$;\n transition: $transition$;\n``\n\\end\n\n\\define transform-origin(origin)\n``\n -webkit-transform-origin: $origin$;\n -moz-transform-origin: $origin$;\n transform-origin: $origin$;\n``\n\\end\n\n\\define background-linear-gradient(gradient)\n``\nbackground-image: linear-gradient($gradient$);\nbackground-image: -o-linear-gradient($gradient$);\nbackground-image: -moz-linear-gradient($gradient$);\nbackground-image: -webkit-linear-gradient($gradient$);\nbackground-image: -ms-linear-gradient($gradient$);\n``\n\\end\n\n\\define column-count(columns)\n``\n-moz-column-count: $columns$;\n-webkit-column-count: $columns$;\ncolumn-count: $columns$;\n``\n\\end\n\n\\define datauri(title)\n<$macrocall $name=\"makedatauri\" type={{$title$!!type}} text={{$title$}}/>\n\\end\n\n\\define if-sidebar(text)\n<$reveal state=\"$:/state/sidebar\" type=\"match\" text=\"yes\" default=\"yes\">$text$</$reveal>\n\\end\n\n\\define if-no-sidebar(text)\n<$reveal state=\"$:/state/sidebar\" type=\"nomatch\" text=\"yes\" default=\"yes\">$text$</$reveal>\n\\end\n\n\\define if-background-attachment(text)\n<$reveal state=\"$:/themes/tiddlywiki/vanilla/settings/backgroundimage\" type=\"nomatch\" text=\"\">$text$</$reveal>\n\\end\n"
},
"$:/core/macros/colour-picker": {
"title": "$:/core/macros/colour-picker",
"tags": "$:/tags/Macro",
"text": "\\define colour-picker-update-recent()\n<$action-listops\n\t$tiddler=\"$:/config/ColourPicker/Recent\"\n\t$subfilter=\"$(colour-picker-value)$ [list[$:/config/ColourPicker/Recent]remove[$(colour-picker-value)$]] +[limit[8]]\"\n/>\n\\end\n\n\\define colour-picker-inner(actions)\n<$button tag=\"a\" tooltip=\"\"\"$(colour-picker-value)$\"\"\">\n\n$(colour-picker-update-recent)$\n\n$actions$\n\n<div style=\"background-color: $(colour-picker-value)$; width: 100%; height: 100%; border-radius: 50%;\"/>\n\n</$button>\n\\end\n\n\\define colour-picker-recent-inner(actions)\n<$set name=\"colour-picker-value\" value=\"$(recentColour)$\">\n<$macrocall $name=\"colour-picker-inner\" actions=\"\"\"$actions$\"\"\"/>\n</$set>\n\\end\n\n\\define colour-picker-recent(actions)\n{{$:/language/ColourPicker/Recent}} <$list filter=\"[list[$:/config/ColourPicker/Recent]]\" variable=\"recentColour\">\n<$macrocall $name=\"colour-picker-recent-inner\" actions=\"\"\"$actions$\"\"\"/></$list>\n\\end\n\n\\define colour-picker(actions)\n<div class=\"tc-colour-chooser\">\n\n<$macrocall $name=\"colour-picker-recent\" actions=\"\"\"$actions$\"\"\"/>\n\n---\n\n<$list filter=\"LightPink Pink Crimson LavenderBlush PaleVioletRed HotPink DeepPink MediumVioletRed Orchid Thistle Plum Violet Magenta Fuchsia DarkMagenta Purple MediumOrchid DarkViolet DarkOrchid Indigo BlueViolet MediumPurple MediumSlateBlue SlateBlue DarkSlateBlue Lavender GhostWhite Blue MediumBlue MidnightBlue DarkBlue Navy RoyalBlue CornflowerBlue LightSteelBlue LightSlateGrey SlateGrey DodgerBlue AliceBlue SteelBlue LightSkyBlue SkyBlue DeepSkyBlue LightBlue PowderBlue CadetBlue Azure LightCyan PaleTurquoise Cyan Aqua DarkTurquoise DarkSlateGrey DarkCyan Teal MediumTurquoise LightSeaGreen Turquoise Aquamarine MediumAquamarine MediumSpringGreen MintCream SpringGreen MediumSeaGreen SeaGreen Honeydew LightGreen PaleGreen DarkSeaGreen LimeGreen Lime ForestGreen Green DarkGreen Chartreuse LawnGreen GreenYellow DarkOliveGreen YellowGreen OliveDrab Beige LightGoldenrodYellow Ivory LightYellow Yellow Olive DarkKhaki LemonChiffon PaleGoldenrod Khaki Gold Cornsilk Goldenrod DarkGoldenrod FloralWhite OldLace Wheat Moccasin Orange PapayaWhip BlanchedAlmond NavajoWhite AntiqueWhite Tan BurlyWood Bisque DarkOrange Linen Peru PeachPuff SandyBrown Chocolate SaddleBrown Seashell Sienna LightSalmon Coral OrangeRed DarkSalmon Tomato MistyRose Salmon Snow LightCoral RosyBrown IndianRed Red Brown FireBrick DarkRed Maroon White WhiteSmoke Gainsboro LightGrey Silver DarkGrey Grey DimGrey Black\" variable=\"colour-picker-value\">\n<$macrocall $name=\"colour-picker-inner\" actions=\"\"\"$actions$\"\"\"/>\n</$list>\n\n---\n\n<$edit-text tiddler=\"$:/config/ColourPicker/New\" tag=\"input\" default=\"\" placeholder=\"\"/> \n<$edit-text tiddler=\"$:/config/ColourPicker/New\" type=\"color\" tag=\"input\"/>\n<$set name=\"colour-picker-value\" value={{$:/config/ColourPicker/New}}>\n<$macrocall $name=\"colour-picker-inner\" actions=\"\"\"$actions$\"\"\"/>\n</$set>\n\n</div>\n\n\\end\n"
},
"$:/core/macros/copy-to-clipboard": {
"title": "$:/core/macros/copy-to-clipboard",
"tags": "$:/tags/Macro",
"text": "\\define copy-to-clipboard(src,class:\"tc-btn-invisible\",style)\n<$button class=<<__class__>> style=<<__style__>> message=\"tm-copy-to-clipboard\" param=<<__src__>> tooltip={{$:/language/Buttons/CopyToClipboard/Hint}}>\n{{$:/core/images/copy-clipboard}} <$text text={{$:/language/Buttons/CopyToClipboard/Caption}}/>\n</$button>\n\\end\n\n\\define copy-to-clipboard-above-right(src,class:\"tc-btn-invisible\",style)\n<div style=\"position: relative;\">\n<div style=\"position: absolute; bottom: 0; right: 0;\">\n<$macrocall $name=\"copy-to-clipboard\" src=<<__src__>> class=<<__class__>> style=<<__style__>>/>\n</div>\n</div>\n\\end\n\n"
},
"$:/core/macros/diff": {
"title": "$:/core/macros/diff",
"tags": "$:/tags/Macro",
"text": "\\define compareTiddlerText(sourceTiddlerTitle,sourceSubTiddlerTitle,destTiddlerTitle,destSubTiddlerTitle)\n<$set name=\"source\" tiddler=<<__sourceTiddlerTitle__>> subtiddler=<<__sourceSubTiddlerTitle__>>>\n<$set name=\"dest\" tiddler=<<__destTiddlerTitle__>> subtiddler=<<__destSubTiddlerTitle__>>>\n<$diff-text source=<<source>> dest=<<dest>>/>\n</$set>\n</$set>\n\\end\n\n\\define compareTiddlers(sourceTiddlerTitle,sourceSubTiddlerTitle,destTiddlerTitle,destSubTiddlerTitle,exclude)\n<table class=\"tc-diff-tiddlers\">\n<tbody>\n<$set name=\"sourceFields\" filter=\"[<__sourceTiddlerTitle__>fields[]sort[]]\">\n<$set name=\"destFields\" filter=\"[<__destSubTiddlerTitle__>subtiddlerfields<__destTiddlerTitle__>sort[]]\">\n<$list filter=\"[enlist<sourceFields>] [enlist<destFields>] -[enlist<__exclude__>] +[sort[]]\" variable=\"fieldName\">\n<tr>\n<th>\n<$text text=<<fieldName>>/> \n</th>\n<td>\n<$set name=\"source\" tiddler=<<__sourceTiddlerTitle__>> subtiddler=<<__sourceSubTiddlerTitle__>> field=<<fieldName>>>\n<$set name=\"dest\" tiddler=<<__destTiddlerTitle__>> subtiddler=<<__destSubTiddlerTitle__>> field=<<fieldName>>>\n<$diff-text source=<<source>> dest=<<dest>>>\n</$diff-text>\n</$set>\n</$set>\n</td>\n</tr>\n</$list>\n</$set>\n</$set>\n</tbody>\n</table>\n\\end\n"
},
"$:/core/macros/export": {
"title": "$:/core/macros/export",
"tags": "$:/tags/Macro",
"text": "\\define exportButtonFilename(baseFilename)\n$baseFilename$$(extension)$\n\\end\n\n\\define exportButton(exportFilter:\"[!is[system]sort[title]]\",lingoBase,baseFilename:\"tiddlers\")\n<span class=\"tc-popup-keep\"><$button popup=<<qualify \"$:/state/popup/export\">> tooltip={{$lingoBase$Hint}} aria-label={{$lingoBase$Caption}} class=<<tv-config-toolbar-class>> selectedClass=\"tc-selected\">\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/export-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$lingoBase$Caption}}/></span>\n</$list>\n</$button></span><$reveal state=<<qualify \"$:/state/popup/export\">> type=\"popup\" position=\"below\" animate=\"yes\">\n<div class=\"tc-drop-down\">\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/Exporter]]\">\n<$set name=\"extension\" value={{!!extension}}>\n<$button class=\"tc-btn-invisible\">\n<$action-sendmessage $message=\"tm-download-file\" $param=<<currentTiddler>> exportFilter=\"\"\"$exportFilter$\"\"\" filename=<<exportButtonFilename \"\"\"$baseFilename$\"\"\">>/>\n<$action-deletetiddler $tiddler=<<qualify \"$:/state/popup/export\">>/>\n<$transclude field=\"description\"/>\n</$button>\n</$set>\n</$list>\n</div>\n</$reveal>\n\\end\n"
},
"$:/core/macros/image-picker": {
"title": "$:/core/macros/image-picker",
"created": "20170715180840889",
"modified": "20170715180914005",
"tags": "$:/tags/Macro",
"type": "text/vnd.tiddlywiki",
"text": "\\define image-picker-thumbnail(actions)\n<$button tag=\"a\" tooltip=\"\"\"$(imageTitle)$\"\"\">\n$actions$\n<$transclude tiddler=<<imageTitle>>/>\n</$button>\n\\end\n\n\\define image-picker-list(filter,actions)\n<$list filter=\"\"\"$filter$\"\"\" variable=\"imageTitle\">\n<$macrocall $name=\"image-picker-thumbnail\" actions=\"\"\"$actions$\"\"\"/>\n</$list>\n\\end\n\n\\define image-picker(actions,filter:\"[all[shadows+tiddlers]is[image]] -[type[application/pdf]] +[!has[draft.of]$subfilter$sort[title]]\",subfilter:\"\")\n<div class=\"tc-image-chooser\">\n<$vars state-system=<<qualify \"$:/state/image-picker/system\">>>\n<$checkbox tiddler=<<state-system>> field=\"text\" checked=\"show\" unchecked=\"hide\" default=\"hide\">\n{{$:/language/SystemTiddlers/Include/Prompt}}\n</$checkbox>\n<$reveal state=<<state-system>> type=\"match\" text=\"hide\" default=\"hide\" tag=\"div\">\n<$macrocall $name=\"image-picker-list\" filter=\"\"\"$filter$ +[!is[system]]\"\"\" actions=\"\"\"$actions$\"\"\"/>\n</$reveal>\n<$reveal state=<<state-system>> type=\"nomatch\" text=\"hide\" default=\"hide\" tag=\"div\">\n<$macrocall $name=\"image-picker-list\" filter=\"\"\"$filter$\"\"\" actions=\"\"\"$actions$\"\"\"/>\n</$reveal>\n</$vars>\n</div>\n\\end\n\n\\define image-picker-include-tagged-images(actions)\n<$macrocall $name=\"image-picker\" filter=\"[all[shadows+tiddlers]is[image]] [all[shadows+tiddlers]tag[$:/tags/Image]] -[type[application/pdf]] +[!has[draft.of]sort[title]]\" actions=\"\"\"$actions$\"\"\"/>\n\\end\n"
},
"$:/core/macros/lingo": {
"title": "$:/core/macros/lingo",
"tags": "$:/tags/Macro",
"text": "\\define lingo-base()\n$:/language/\n\\end\n\n\\define lingo(title)\n{{$(lingo-base)$$title$}}\n\\end\n"
},
"$:/core/macros/list": {
"title": "$:/core/macros/list",
"tags": "$:/tags/Macro",
"text": "\\define list-links(filter,type:\"ul\",subtype:\"li\",class:\"\",emptyMessage)\n<$type$ class=\"$class$\">\n<$list filter=\"$filter$\" emptyMessage=<<__emptyMessage__>>>\n<$subtype$>\n<$link to={{!!title}}>\n<$transclude field=\"caption\">\n<$view field=\"title\"/>\n</$transclude>\n</$link>\n</$subtype$>\n</$list>\n</$type$>\n\\end\n\n\\define list-links-draggable-drop-actions()\n<$action-listops $tiddler=<<targetTiddler>> $field=<<targetField>> $subfilter=\"+[insertbefore:currentTiddler<actionTiddler>]\"/>\n\\end\n\n\\define list-links-draggable(tiddler,field:\"list\",type:\"ul\",subtype:\"li\",class:\"\",itemTemplate)\n<$vars targetTiddler=\"\"\"$tiddler$\"\"\" targetField=\"\"\"$field$\"\"\">\n<$type$ class=\"$class$\">\n<$list filter=\"[list[$tiddler$!!$field$]]\">\n<$droppable actions=<<list-links-draggable-drop-actions>> tag=\"\"\"$subtype$\"\"\">\n<div class=\"tc-droppable-placeholder\">\n \n</div>\n<div>\n<$transclude tiddler=\"\"\"$itemTemplate$\"\"\">\n<$link to={{!!title}}>\n<$transclude field=\"caption\">\n<$view field=\"title\"/>\n</$transclude>\n</$link>\n</$transclude>\n</div>\n</$droppable>\n</$list>\n</$type$>\n<$tiddler tiddler=\"\">\n<$droppable actions=<<list-links-draggable-drop-actions>> tag=\"div\">\n<div class=\"tc-droppable-placeholder\">\n \n</div>\n<div style=\"height:0.5em;\"/>\n</$droppable>\n</$tiddler>\n</$vars>\n\\end\n\n\\define list-tagged-draggable-drop-actions(tag)\n<!-- Save the current ordering of the tiddlers with this tag -->\n<$set name=\"order\" filter=\"[<__tag__>tagging[]]\">\n<!-- Remove any list-after or list-before fields from the tiddlers with this tag -->\n<$list filter=\"[<__tag__>tagging[]]\">\n<$action-deletefield $field=\"list-before\"/>\n<$action-deletefield $field=\"list-after\"/>\n</$list>\n<!-- Save the new order to the Tag Tiddler -->\n<$action-listops $tiddler=<<__tag__>> $field=\"list\" $filter=\"+[enlist<order>] +[insertbefore:currentTiddler<actionTiddler>]\"/>\n<!-- Make sure the newly added item has the right tag -->\n<!-- Removing this line makes dragging tags within the dropdown work as intended -->\n<!--<$action-listops $tiddler=<<actionTiddler>> $tags=<<__tag__>>/>-->\n<!-- Using the following 5 lines as replacement makes dragging titles from outside into the dropdown apply the tag -->\n<$list filter=\"[<actionTiddler>!contains:tags<__tag__>]\">\n<$fieldmangler tiddler=<<actionTiddler>>>\n<$action-sendmessage $message=\"tm-add-tag\" $param=<<__tag__>>/>\n</$fieldmangler>\n</$list>\n</$set>\n\\end\n\n\\define list-tagged-draggable(tag,subFilter,emptyMessage,itemTemplate,elementTag:\"div\")\n<$set name=\"tag\" value=<<__tag__>>>\n<$list filter=\"[<__tag__>tagging[]$subFilter$]\" emptyMessage=<<__emptyMessage__>>>\n<$elementTag$ class=\"tc-menu-list-item\">\n<$droppable actions=\"\"\"<$macrocall $name=\"list-tagged-draggable-drop-actions\" tag=<<__tag__>>/>\"\"\">\n<$elementTag$ class=\"tc-droppable-placeholder\">\n \n</$elementTag$>\n<$elementTag$>\n<$transclude tiddler=\"\"\"$itemTemplate$\"\"\">\n<$link to={{!!title}}>\n<$view field=\"title\"/>\n</$link>\n</$transclude>\n</$elementTag$>\n</$droppable>\n</$elementTag$>\n</$list>\n<$tiddler tiddler=\"\">\n<$droppable actions=\"\"\"<$macrocall $name=\"list-tagged-draggable-drop-actions\" tag=<<__tag__>>/>\"\"\">\n<$elementTag$ class=\"tc-droppable-placeholder\">\n \n</$elementTag$>\n<$elementTag$ style=\"height:0.5em;\">\n</$elementTag$>\n</$droppable>\n</$tiddler>\n</$set>\n\\end\n"
},
"$:/core/macros/tabs": {
"title": "$:/core/macros/tabs",
"tags": "$:/tags/Macro",
"text": "\\define tabs(tabsList,default,state:\"$:/state/tab\",class,template,buttonTemplate,retain)\n<div class=\"tc-tab-set $class$\">\n<div class=\"tc-tab-buttons $class$\">\n<$list filter=\"$tabsList$\" variable=\"currentTab\"><$set name=\"save-currentTiddler\" value=<<currentTiddler>>><$tiddler tiddler=<<currentTab>>><$button set=<<qualify \"$state$\">> setTo=<<currentTab>> default=\"$default$\" selectedClass=\"tc-tab-selected\" tooltip={{!!tooltip}}>\n<$tiddler tiddler=<<save-currentTiddler>>>\n<$set name=\"tv-wikilinks\" value=\"no\">\n<$transclude tiddler=\"$buttonTemplate$\" mode=\"inline\">\n<$transclude tiddler=<<currentTab>> field=\"caption\">\n<$macrocall $name=\"currentTab\" $type=\"text/plain\" $output=\"text/plain\"/>\n</$transclude>\n</$transclude>\n</$set></$tiddler></$button></$tiddler></$set></$list>\n</div>\n<div class=\"tc-tab-divider $class$\"/>\n<div class=\"tc-tab-content $class$\">\n<$list filter=\"$tabsList$\" variable=\"currentTab\">\n\n<$reveal type=\"match\" state=<<qualify \"$state$\">> text=<<currentTab>> default=\"$default$\" retain=\"\"\"$retain$\"\"\">\n\n<$transclude tiddler=\"$template$\" mode=\"block\">\n\n<$transclude tiddler=<<currentTab>> mode=\"block\"/>\n\n</$transclude>\n\n</$reveal>\n\n</$list>\n</div>\n</div>\n\\end\n"
},
"$:/core/macros/tag-picker": {
"title": "$:/core/macros/tag-picker",
"tags": "$:/tags/Macro",
"text": "\\define add-tag-actions()\n<$action-sendmessage $message=\"tm-add-tag\" $param={{$:/temp/NewTagName}}/>\n<$action-deletetiddler $tiddler=\"$:/temp/NewTagName\"/>\n\\end\n\n\\define add-tag-actions()\n<$action-sendmessage $message=\"tm-add-tag\" $param={{$:/temp/NewTagName}}/>\n<$action-deletetiddler $tiddler=\"$:/temp/NewTagName\"/>\n\\end\n\n\\define tag-button()\n<$button class=\"tc-btn-invisible\" tag=\"a\">\n$(actions)$\n<$action-deletetiddler $tiddler=\"$:/temp/NewTagName\"/>\n<$macrocall $name=\"tag-pill\" tag=<<tag>>/>\n</$button>\n\\end\n\n\\define tag-picker(actions)\n<$set name=\"actions\" value=\"\"\"$actions$\"\"\">\n<div class=\"tc-edit-add-tag\">\n<span class=\"tc-add-tag-name\">\n<$keyboard key=\"ENTER\" actions=<<add-tag-actions>>>\n<$edit-text tiddler=\"$:/temp/NewTagName\" tag=\"input\" default=\"\" placeholder={{$:/language/EditTemplate/Tags/Add/Placeholder}} focusPopup=<<qualify \"$:/state/popup/tags-auto-complete\">> class=\"tc-edit-texteditor tc-popup-handle\"/>\n</$keyboard>\n</span> <$button popup=<<qualify \"$:/state/popup/tags-auto-complete\">> class=\"tc-btn-invisible\" tooltip={{$:/language/EditTemplate/Tags/Dropdown/Hint}} aria-label={{$:/language/EditTemplate/Tags/Dropdown/Caption}}>{{$:/core/images/down-arrow}}</$button> <span class=\"tc-add-tag-button\">\n<$set name=\"tag\" value={{$:/temp/NewTagName}}>\n<$button set=\"$:/temp/NewTagName\" setTo=\"\" class=\"\">\n$actions$\n<$action-deletetiddler $tiddler=\"$:/temp/NewTagName\"/>\n{{$:/language/EditTemplate/Tags/Add/Button}}\n</$button>\n</$set>\n</span>\n</div>\n<div class=\"tc-block-dropdown-wrapper\">\n<$reveal state=<<qualify \"$:/state/popup/tags-auto-complete\">> type=\"nomatch\" text=\"\" default=\"\">\n<div class=\"tc-block-dropdown\">\n<$list filter=\"[{$:/temp/NewTagName}minlength{$:/config/Tags/MinLength}limit[1]]\" emptyMessage=\"\"\"<div class=\"tc-search-results\">{{$:/language/Search/Search/TooShort}}</div>\"\"\" variable=\"listItem\">\n<$list filter=\"[tags[]!is[system]search:title{$:/temp/NewTagName}sort[]]\" variable=\"tag\">\n<<tag-button>>\n</$list></$list>\n<hr>\n<$list filter=\"[{$:/temp/NewTagName}minlength{$:/config/Tags/MinLength}limit[1]]\" emptyMessage=\"\"\"<div class=\"tc-search-results\">{{$:/language/Search/Search/TooShort}}</div>\"\"\" variable=\"listItem\">\n<$list filter=\"[tags[]is[system]search:title{$:/temp/NewTagName}sort[]]\" variable=\"tag\">\n<<tag-button>>\n</$list></$list>\n</div>\n</$reveal>\n</div>\n</$set>\n\\end\n"
},
"$:/core/macros/tag": {
"title": "$:/core/macros/tag",
"tags": "$:/tags/Macro",
"text": "\\define tag-pill-styles()\nbackground-color:$(backgroundColor)$;\nfill:$(foregroundColor)$;\ncolor:$(foregroundColor)$;\n\\end\n\n\\define tag-pill-inner(tag,icon,colour,fallbackTarget,colourA,colourB,element-tag,element-attributes,actions)\n<$vars foregroundColor=<<contrastcolour target:\"\"\"$colour$\"\"\" fallbackTarget:\"\"\"$fallbackTarget$\"\"\" colourA:\"\"\"$colourA$\"\"\" colourB:\"\"\"$colourB$\"\"\">> backgroundColor=\"\"\"$colour$\"\"\">\n<$element-tag$ $element-attributes$ class=\"tc-tag-label tc-btn-invisible\" style=<<tag-pill-styles>>>\n$actions$<$transclude tiddler=\"\"\"$icon$\"\"\"/> <$view tiddler=<<__tag__>> field=\"title\" format=\"text\" />\n</$element-tag$>\n</$vars>\n\\end\n\n\\define tag-pill-body(tag,icon,colour,palette,element-tag,element-attributes,actions)\n<$macrocall $name=\"tag-pill-inner\" tag=<<__tag__>> icon=\"\"\"$icon$\"\"\" colour=\"\"\"$colour$\"\"\" fallbackTarget={{$palette$##tag-background}} colourA={{$palette$##foreground}} colourB={{$palette$##background}} element-tag=\"\"\"$element-tag$\"\"\" element-attributes=\"\"\"$element-attributes$\"\"\" actions=\"\"\"$actions$\"\"\"/>\n\\end\n\n\\define tag-pill(tag,element-tag:\"span\",element-attributes:\"\",actions:\"\")\n<span class=\"tc-tag-list-item\">\n<$macrocall $name=\"tag-pill-body\" tag=<<__tag__>> icon={{{ [<__tag__>get[icon]] }}} colour={{{ [<__tag__>get[color]] }}} palette={{$:/palette}} element-tag=\"\"\"$element-tag$\"\"\" element-attributes=\"\"\"$element-attributes$\"\"\" actions=\"\"\"$actions$\"\"\"/>\n</span>\n\\end\n\n\\define tag(tag)\n{{$tag$||$:/core/ui/TagTemplate}}\n\\end\n"
},
"$:/core/macros/thumbnails": {
"title": "$:/core/macros/thumbnails",
"tags": "$:/tags/Macro",
"text": "\\define thumbnail(link,icon,color,background-color,image,caption,width:\"280\",height:\"157\")\n<$link to=\"\"\"$link$\"\"\"><div class=\"tc-thumbnail-wrapper\">\n<div class=\"tc-thumbnail-image\" style=\"width:$width$px;height:$height$px;\"><$reveal type=\"nomatch\" text=\"\" default=\"\"\"$image$\"\"\" tag=\"div\" style=\"width:$width$px;height:$height$px;\">\n[img[$image$]]\n</$reveal><$reveal type=\"match\" text=\"\" default=\"\"\"$image$\"\"\" tag=\"div\" class=\"tc-thumbnail-background\" style=\"width:$width$px;height:$height$px;background-color:$background-color$;\"></$reveal></div><div class=\"tc-thumbnail-icon\" style=\"fill:$color$;color:$color$;\">\n$icon$\n</div><div class=\"tc-thumbnail-caption\">\n$caption$\n</div>\n</div></$link>\n\\end\n\n\\define thumbnail-right(link,icon,color,background-color,image,caption,width:\"280\",height:\"157\")\n<div class=\"tc-thumbnail-right-wrapper\"><<thumbnail \"\"\"$link$\"\"\" \"\"\"$icon$\"\"\" \"\"\"$color$\"\"\" \"\"\"$background-color$\"\"\" \"\"\"$image$\"\"\" \"\"\"$caption$\"\"\" \"\"\"$width$\"\"\" \"\"\"$height$\"\"\">></div>\n\\end\n\n\\define list-thumbnails(filter,width:\"280\",height:\"157\")\n<$list filter=\"\"\"$filter$\"\"\"><$macrocall $name=\"thumbnail\" link={{!!link}} icon={{!!icon}} color={{!!color}} background-color={{!!background-color}} image={{!!image}} caption={{!!caption}} width=\"\"\"$width$\"\"\" height=\"\"\"$height$\"\"\"/></$list>\n\\end\n"
},
"$:/core/macros/timeline": {
"title": "$:/core/macros/timeline",
"created": "20141212105914482",
"modified": "20141212110330815",
"tags": "$:/tags/Macro",
"text": "\\define timeline-title()\n<!-- Override this macro with a global macro \n of the same name if you need to change \n how titles are displayed on the timeline \n -->\n<$view field=\"title\"/>\n\\end\n\\define timeline(limit:\"100\",format:\"DDth MMM YYYY\",subfilter:\"\",dateField:\"modified\")\n<div class=\"tc-timeline\">\n<$list filter=\"[!is[system]$subfilter$has[$dateField$]!sort[$dateField$]limit[$limit$]eachday[$dateField$]]\">\n<div class=\"tc-menu-list-item\">\n<$view field=\"$dateField$\" format=\"date\" template=\"$format$\"/>\n<$list filter=\"[sameday:$dateField${!!$dateField$}!is[system]$subfilter$!sort[$dateField$]]\">\n<div class=\"tc-menu-list-subitem\">\n<$link to={{!!title}}>\n<<timeline-title>>\n</$link>\n</div>\n</$list>\n</div>\n</$list>\n</div>\n\\end\n"
},
"$:/core/macros/toc": {
"title": "$:/core/macros/toc",
"tags": "$:/tags/Macro",
"text": "\\define toc-caption()\n<$set name=\"tv-wikilinks\" value=\"no\">\n <$transclude field=\"caption\">\n <$view field=\"title\"/>\n </$transclude>\n</$set>\n\\end\n\n\\define toc-body(tag,sort:\"\",itemClassFilter,exclude,path)\n<ol class=\"tc-toc\">\n <$list filter=\"\"\"[all[shadows+tiddlers]tag<__tag__>!has[draft.of]$sort$] -[<__tag__>] -[enlist<__exclude__>]\"\"\">\n <$vars item=<<currentTiddler>> path={{{ [<__path__>addsuffix[/]addsuffix<__tag__>] }}} excluded=\"\"\"[enlist<__exclude__>] -[<__tag__>]\"\"\">\n <$set name=\"toc-item-class\" filter=<<__itemClassFilter__>> emptyValue=\"toc-item\" value=\"toc-item-selected\">\n <li class=<<toc-item-class>>>\n <$list filter=\"[all[current]toc-link[no]]\" emptyMessage=\"<$link><$view field='caption'><$view field='title'/></$view></$link>\">\n <<toc-caption>>\n </$list>\n <$macrocall $name=\"toc-body\" tag=<<item>> sort=<<__sort__>> itemClassFilter=<<__itemClassFilter__>> exclude=<<excluded>> path=<<path>>/>\n </li>\n </$set>\n </$vars>\n </$list>\n</ol>\n\\end\n\n\\define toc(tag,sort:\"\",itemClassFilter:\" \")\n<$macrocall $name=\"toc-body\" tag=<<__tag__>> sort=<<__sort__>> itemClassFilter=<<__itemClassFilter__>> />\n\\end\n\n\\define toc-linked-expandable-body(tag,sort:\"\",itemClassFilter,exclude,path)\n<!-- helper function -->\n<$qualify name=\"toc-state\" title={{{ [[$:/state/toc]addsuffix<__path__>addsuffix[-]addsuffix<currentTiddler>] }}}>\n <$set name=\"toc-item-class\" filter=<<__itemClassFilter__>> emptyValue=\"toc-item\" value=\"toc-item-selected\">\n <li class=<<toc-item-class>>>\n <$link>\n <$reveal type=\"nomatch\" stateTitle=<<toc-state>> text=\"open\">\n <$button setTitle=<<toc-state>> setTo=\"open\" class=\"tc-btn-invisible tc-popup-keep\">\n {{$:/core/images/right-arrow}}\n </$button>\n </$reveal>\n <$reveal type=\"match\" stateTitle=<<toc-state>> text=\"open\">\n <$button setTitle=<<toc-state>> setTo=\"close\" class=\"tc-btn-invisible tc-popup-keep\">\n {{$:/core/images/down-arrow}}\n </$button>\n </$reveal>\n <<toc-caption>>\n </$link>\n <$reveal type=\"match\" stateTitle=<<toc-state>> text=\"open\">\n <$macrocall $name=\"toc-expandable\" tag=<<currentTiddler>> sort=<<__sort__>> itemClassFilter=<<__itemClassFilter__>> exclude=<<__exclude__>> path=<<__path__>>/>\n </$reveal>\n </li>\n </$set>\n</$qualify>\n\\end\n\n\\define toc-unlinked-expandable-body(tag,sort:\"\",itemClassFilter:\" \",exclude,path)\n<!-- helper function -->\n<$qualify name=\"toc-state\" title={{{ [[$:/state/toc]addsuffix<__path__>addsuffix[-]addsuffix<currentTiddler>] }}}>\n <$set name=\"toc-item-class\" filter=<<__itemClassFilter__>> emptyValue=\"toc-item\" value=\"toc-item-selected\">\n <li class=<<toc-item-class>>>\n <$reveal type=\"nomatch\" stateTitle=<<toc-state>> text=\"open\">\n <$button setTitle=<<toc-state>> setTo=\"open\" class=\"tc-btn-invisible tc-popup-keep\">\n {{$:/core/images/right-arrow}}\n <<toc-caption>>\n </$button>\n </$reveal>\n <$reveal type=\"match\" stateTitle=<<toc-state>> text=\"open\">\n <$button setTitle=<<toc-state>> setTo=\"close\" class=\"tc-btn-invisible tc-popup-keep\">\n {{$:/core/images/down-arrow}}\n <<toc-caption>>\n </$button>\n </$reveal>\n <$reveal type=\"match\" stateTitle=<<toc-state>> text=\"open\">\n <$macrocall $name=\"toc-expandable\" tag=<<currentTiddler>> sort=<<__sort__>> itemClassFilter=<<__itemClassFilter__>> exclude=<<__exclude__>> path=<<__path__>>/>\n </$reveal>\n </li>\n </$set>\n</$qualify>\n\\end\n\n\\define toc-expandable-empty-message()\n<$macrocall $name=\"toc-linked-expandable-body\" tag=<<tag>> sort=<<sort>> itemClassFilter=<<itemClassFilter>> exclude=<<excluded>> path=<<path>>/>\n\\end\n\n\\define toc-expandable(tag,sort:\"\",itemClassFilter:\" \",exclude,path)\n<$vars tag=<<__tag__>> sort=<<__sort__>> itemClassFilter=<<__itemClassFilter__>> excluded=\"\"\"[enlist<__exclude__>] -[<__tag__>]\"\"\" path={{{ [<__path__>addsuffix[/]addsuffix<__tag__>] }}}>\n <ol class=\"tc-toc toc-expandable\">\n <$list filter=\"\"\"[all[shadows+tiddlers]tag<__tag__>!has[draft.of]$sort$] -[<__tag__>] -[enlist<__exclude__>]\"\"\">\n <$list filter=\"[all[current]toc-link[no]]\" emptyMessage=<<toc-expandable-empty-message>> >\n <$macrocall $name=\"toc-unlinked-expandable-body\" tag=<<__tag__>> sort=<<__sort__>> itemClassFilter=\"\"\"itemClassFilter\"\"\" exclude=<<excluded>> path=<<path>> />\n </$list>\n </$list>\n </ol>\n</$vars>\n\\end\n\n\\define toc-linked-selective-expandable-body(tag,sort:\"\",itemClassFilter:\" \",exclude,path)\n<$qualify name=\"toc-state\" title={{{ [[$:/state/toc]addsuffix<__path__>addsuffix[-]addsuffix<currentTiddler>] }}}>\n <$set name=\"toc-item-class\" filter=<<__itemClassFilter__>> emptyValue=\"toc-item\" value=\"toc-item-selected\" >\n <li class=<<toc-item-class>>>\n <$link>\n <$list filter=\"[all[current]tagging[]limit[1]]\" variable=\"ignore\" emptyMessage=\"<$button class='tc-btn-invisible'>{{$:/core/images/blank}}</$button>\">\n <$reveal type=\"nomatch\" stateTitle=<<toc-state>> text=\"open\">\n <$button setTitle=<<toc-state>> setTo=\"open\" class=\"tc-btn-invisible tc-popup-keep\">\n {{$:/core/images/right-arrow}}\n </$button>\n </$reveal>\n <$reveal type=\"match\" stateTitle=<<toc-state>> text=\"open\">\n <$button setTitle=<<toc-state>> setTo=\"close\" class=\"tc-btn-invisible tc-popup-keep\">\n {{$:/core/images/down-arrow}}\n </$button>\n </$reveal>\n </$list>\n <<toc-caption>>\n </$link>\n <$reveal type=\"match\" stateTitle=<<toc-state>> text=\"open\">\n <$macrocall $name=\"toc-selective-expandable\" tag=<<currentTiddler>> sort=<<__sort__>> itemClassFilter=<<__itemClassFilter__>> exclude=<<__exclude__>> path=<<__path__>>/>\n </$reveal>\n </li>\n </$set>\n</$qualify>\n\\end\n\n\\define toc-unlinked-selective-expandable-body(tag,sort:\"\",itemClassFilter:\" \",exclude,path)\n<$qualify name=\"toc-state\" title={{{ [[$:/state/toc]addsuffix<__path__>addsuffix[-]addsuffix<currentTiddler>] }}}>\n <$set name=\"toc-item-class\" filter=<<__itemClassFilter__>> emptyValue=\"toc-item\" value=\"toc-item-selected\">\n <li class=<<toc-item-class>>>\n <$list filter=\"[all[current]tagging[]limit[1]]\" variable=\"ignore\" emptyMessage=\"<$button class='tc-btn-invisible'>{{$:/core/images/blank}}</$button> <$view field='caption'><$view field='title'/></$view>\">\n <$reveal type=\"nomatch\" stateTitle=<<toc-state>> text=\"open\">\n <$button setTitle=<<toc-state>> setTo=\"open\" class=\"tc-btn-invisible tc-popup-keep\">\n {{$:/core/images/right-arrow}}\n <<toc-caption>>\n </$button>\n </$reveal>\n <$reveal type=\"match\" stateTitle=<<toc-state>> text=\"open\">\n <$button setTitle=<<toc-state>> setTo=\"close\" class=\"tc-btn-invisible tc-popup-keep\">\n {{$:/core/images/down-arrow}}\n <<toc-caption>>\n </$button>\n </$reveal>\n </$list>\n <$reveal type=\"match\" stateTitle=<<toc-state>> text=\"open\">\n <$macrocall $name=\"toc-selective-expandable\" tag=<<currentTiddler>> sort=<<__sort__>> itemClassFilter=<<__itemClassFilter__>> exclude=<<__exclude__>> path=<<__path__>>/>\n </$reveal>\n </li>\n </$set>\n</$qualify>\n\\end\n\n\\define toc-selective-expandable-empty-message()\n<$macrocall $name=\"toc-linked-selective-expandable-body\" tag=<<tag>> sort=<<sort>> itemClassFilter=<<itemClassFilter>> exclude=<<excluded>> path=<<path>>/>\n\\end\n\n\\define toc-selective-expandable(tag,sort:\"\",itemClassFilter,exclude,path)\n<$vars tag=<<__tag__>> sort=<<__sort__>> itemClassFilter=<<__itemClassFilter__>> excluded=\"\"\"[enlist<__exclude__>] -[<__tag__>]\"\"\" path={{{ [<__path__>addsuffix[/]addsuffix<__tag__>] }}}>\n <ol class=\"tc-toc toc-selective-expandable\">\n <$list filter=\"\"\"[all[shadows+tiddlers]tag<__tag__>!has[draft.of]$sort$] -[<__tag__>] -[enlist<__exclude__>]\"\"\">\n <$list filter=\"[all[current]toc-link[no]]\" variable=\"ignore\" emptyMessage=<<toc-selective-expandable-empty-message>> >\n <$macrocall $name=\"toc-unlinked-selective-expandable-body\" tag=<<__tag__>> sort=<<__sort__>> itemClassFilter=<<__itemClassFilter__>> exclude=<<excluded>> path=<<path>>/>\n </$list>\n </$list>\n </ol>\n</$vars>\n\\end\n\n\\define toc-tabbed-external-nav(tag,sort:\"\",selectedTiddler:\"$:/temp/toc/selectedTiddler\",unselectedText,missingText,template:\"\")\n<$tiddler tiddler={{{ [<__selectedTiddler__>get[text]] }}}>\n <div class=\"tc-tabbed-table-of-contents\">\n <$linkcatcher to=<<__selectedTiddler__>>>\n <div class=\"tc-table-of-contents\">\n <$macrocall $name=\"toc-selective-expandable\" tag=<<__tag__>> sort=<<__sort__>> itemClassFilter=\"[all[current]field:title<__selectedTiddler__>]\"/>\n </div>\n </$linkcatcher>\n <div class=\"tc-tabbed-table-of-contents-content\">\n <$reveal stateTitle=<<__selectedTiddler__>> type=\"nomatch\" text=\"\">\n <$transclude mode=\"block\" tiddler=<<__template__>>>\n <h1><<toc-caption>></h1>\n <$transclude mode=\"block\">$missingText$</$transclude>\n </$transclude>\n </$reveal>\n <$reveal stateTitle=<<__selectedTiddler__>> type=\"match\" text=\"\">\n $unselectedText$\n </$reveal>\n </div>\n </div>\n</$tiddler>\n\\end\n\n\\define toc-tabbed-internal-nav(tag,sort:\"\",selectedTiddler:\"$:/temp/toc/selectedTiddler\",unselectedText,missingText,template:\"\")\n<$linkcatcher to=<<__selectedTiddler__>>>\n <$macrocall $name=\"toc-tabbed-external-nav\" tag=<<__tag__>> sort=<<__sort__>> selectedTiddler=<<__selectedTiddler__>> unselectedText=<<__unselectedText__>> missingText=<<__missingText__>> template=<<__template__>>/>\n</$linkcatcher>\n\\end\n\n"
},
"$:/core/macros/translink": {
"title": "$:/core/macros/translink",
"tags": "$:/tags/Macro",
"text": "\\define translink(title,mode:\"block\")\n<div style=\"border:1px solid #ccc; padding: 0.5em; background: black; foreground; white;\">\n<$link to=\"\"\"$title$\"\"\">\n<$text text=\"\"\"$title$\"\"\"/>\n</$link>\n<div style=\"border:1px solid #ccc; padding: 0.5em; background: white; foreground; black;\">\n<$transclude tiddler=\"\"\"$title$\"\"\" mode=\"$mode$\">\n\"<$text text=\"\"\"$title$\"\"\"/>\" is missing\n</$transclude>\n</div>\n</div>\n\\end\n"
},
"$:/core/macros/tree": {
"title": "$:/core/macros/tree",
"tags": "$:/tags/Macro",
"text": "\\define leaf-link(full-title, chunk)\n<$link to=<<__full-title__>>><$text text=<<__chunk__>>/></$link>\n\\end\n\n\\define leaf-node(prefix, chunk)\n<li>\n<$list filter=\"[<__prefix__>addsuffix<__chunk__>is[shadow]] [<__prefix__>addsuffix<__chunk__>is[tiddler]]\" variable=\"full-title\">\n<$list filter=\"[<full-title>removeprefix<__prefix__>]\" variable=\"chunk\">\n<span>{{$:/core/images/file}}</span> <$macrocall $name=\"leaf-link\" full-title=<<full-title>> chunk=<<chunk>>/>\n</$list>\n</$list>\n</li>\n\\end\n\n\\define branch-node(prefix, chunk)\n<li>\n<$set name=\"reveal-state\" value={{{ [[$:/state/tree/]addsuffix<__prefix__>addsuffix<__chunk__>] }}}>\n<$reveal type=\"nomatch\" stateTitle=<<reveal-state>> text=\"show\">\n<$button setTitle=<<reveal-state>> setTo=\"show\" class=\"tc-btn-invisible\">\n{{$:/core/images/folder}} <$text text=<<__chunk__>>/>\n</$button>\n</$reveal>\n<$reveal type=\"match\" stateTitle=<<reveal-state>> text=\"show\">\n<$button setTitle=<<reveal-state>> setTo=\"hide\" class=\"tc-btn-invisible\">\n{{$:/core/images/folder}} <$text text=<<__chunk__>>/>\n</$button>\n</$reveal>\n<span>(<$count filter=\"[all[shadows+tiddlers]removeprefix<__prefix__>removeprefix<__chunk__>] -[<__prefix__>addsuffix<__chunk__>]\"/>)</span>\n<$reveal type=\"match\" stateTitle=<<reveal-state>> text=\"show\">\n<$macrocall $name=\"tree-node\" prefix={{{ [<__prefix__>addsuffix<__chunk__>] }}}/>\n</$reveal>\n</$set>\n</li>\n\\end\n\n\\define tree-node(prefix)\n<ol>\n<$list filter=\"[all[shadows+tiddlers]removeprefix<__prefix__>splitbefore[/]sort[]!suffix[/]]\" variable=\"chunk\">\n<$macrocall $name=\"leaf-node\" prefix=<<__prefix__>> chunk=<<chunk>>/>\n</$list>\n<$list filter=\"[all[shadows+tiddlers]removeprefix<__prefix__>splitbefore[/]sort[]suffix[/]]\" variable=\"chunk\">\n<$macrocall $name=\"branch-node\" prefix=<<__prefix__>> chunk=<<chunk>>/>\n</$list>\n</ol>\n\\end\n\n\\define tree(prefix: \"$:/\")\n<div class=\"tc-tree\">\n<span><$text text=<<__prefix__>>/></span>\n<div>\n<$macrocall $name=\"tree-node\" prefix=<<__prefix__>>/>\n</div>\n</div>\n\\end\n"
},
"$:/snippets/minilanguageswitcher": {
"title": "$:/snippets/minilanguageswitcher",
"text": "<$select tiddler=\"$:/language\">\n<$list filter=\"[[$:/languages/en-GB]] [plugin-type[language]sort[title]]\">\n<option value=<<currentTiddler>>><$view field=\"description\"><$view field=\"name\"><$view field=\"title\"/></$view></$view></option>\n</$list>\n</$select>"
},
"$:/snippets/minithemeswitcher": {
"title": "$:/snippets/minithemeswitcher",
"text": "\\define lingo-base() $:/language/ControlPanel/Theme/\n<<lingo Prompt>> <$select tiddler=\"$:/theme\">\n<$list filter=\"[plugin-type[theme]sort[title]]\">\n<option value=<<currentTiddler>>><$view field=\"name\"><$view field=\"title\"/></$view></option>\n</$list>\n</$select>"
},
"$:/snippets/modules": {
"title": "$:/snippets/modules",
"text": "\\define describeModuleType(type)\n{{$:/language/Docs/ModuleTypes/$type$}}\n\\end\n<$list filter=\"[moduletypes[]]\">\n\n!! <$macrocall $name=\"currentTiddler\" $type=\"text/plain\" $output=\"text/plain\"/>\n\n<$macrocall $name=\"describeModuleType\" type=<<currentTiddler>>/>\n\n<ul><$list filter=\"[all[current]modules[]]\"><li><$link><<currentTiddler>></$link>\n</li>\n</$list>\n</ul>\n</$list>\n"
},
"$:/palette": {
"title": "$:/palette",
"text": "$:/palettes/Vanilla"
},
"$:/snippets/paletteeditor": {
"title": "$:/snippets/paletteeditor",
"text": "\\define lingo-base() $:/language/ControlPanel/Palette/Editor/\n\\define describePaletteColour(colour)\n<$transclude tiddler=\"$:/language/Docs/PaletteColours/$colour$\"><$text text=\"$colour$\"/></$transclude>\n\\end\n<$set name=\"currentTiddler\" value={{$:/palette}}>\n\n<<lingo Prompt>> <$link to={{$:/palette}}><$macrocall $name=\"currentTiddler\" $output=\"text/plain\"/></$link>\n\n<$list filter=\"[all[current]is[shadow]is[tiddler]]\" variable=\"listItem\">\n<<lingo Prompt/Modified>>\n<$button message=\"tm-delete-tiddler\" param={{$:/palette}}><<lingo Reset/Caption>></$button>\n</$list>\n\n<$list filter=\"[all[current]is[shadow]!is[tiddler]]\" variable=\"listItem\">\n<<lingo Clone/Prompt>>\n</$list>\n\n<$button message=\"tm-new-tiddler\" param={{$:/palette}}><<lingo Clone/Caption>></$button>\n\n<table>\n<tbody>\n<$list filter=\"[all[current]indexes[]]\" variable=\"colourName\">\n<tr>\n<td>\n''<$macrocall $name=\"describePaletteColour\" colour=<<colourName>>/>''<br/>\n<$macrocall $name=\"colourName\" $output=\"text/plain\"/>\n</td>\n<td>\n<$edit-text index=<<colourName>> tag=\"input\"/>\n<br>\n<$edit-text index=<<colourName>> type=\"color\" tag=\"input\"/>\n</td>\n</tr>\n</$list>\n</tbody>\n</table>\n</$set>\n"
},
"$:/snippets/palettepreview": {
"title": "$:/snippets/palettepreview",
"text": "<$set name=\"currentTiddler\" value={{$:/palette}}>\n{{||$:/snippets/currpalettepreview}}\n</$set>\n"
},
"$:/snippets/paletteswitcher": {
"title": "$:/snippets/paletteswitcher",
"text": "<$linkcatcher to=\"$:/palette\">\n<div class=\"tc-chooser\"><$list filter=\"[all[shadows+tiddlers]tag[$:/tags/Palette]sort[description]]\"><$set name=\"cls\" filter=\"[all[current]prefix{$:/palette}]\" value=\"tc-chooser-item tc-chosen\" emptyValue=\"tc-chooser-item\"><div class=<<cls>>><$link to={{!!title}}>''<$view field=\"name\" format=\"text\"/>'' - <$view field=\"description\" format=\"text\"/>{{||$:/snippets/currpalettepreview}}</$link>\n</div></$set>\n</$list>\n</div>\n</$linkcatcher>"
},
"$:/snippets/peek-stylesheets": {
"title": "$:/snippets/peek-stylesheets",
"text": "\\define expandable-stylesheets-list()\n<ol>\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/Stylesheet]!has[draft.of]]\">\n<$vars state=<<qualify \"$:/config/peek-stylesheets/open/\">>>\n<$set name=\"state\" value={{{ [<state>addsuffix<currentTiddler>] }}}>\n<li>\n<$reveal type=\"match\" state=<<state>> text=\"yes\" tag=\"span\">\n<$button set=<<state>> setTo=\"no\" class=\"tc-btn-invisible\">\n{{$:/core/images/down-arrow}}\n</$button>\n</$reveal>\n<$reveal type=\"nomatch\" state=<<state>> text=\"yes\" tag=\"span\">\n<$button set=<<state>> setTo=\"yes\" class=\"tc-btn-invisible\">\n{{$:/core/images/right-arrow}}\n</$button>\n</$reveal>\n<$link>\n<$view field=\"title\"/>\n</$link>\n<$reveal type=\"match\" state=<<state>> text=\"yes\" tag=\"div\">\n<$set name=\"source\" tiddler=<<currentTiddler>>>\n<$wikify name=\"styles\" text=<<source>>>\n<pre>\n<code>\n<$text text=<<styles>>/>\n</code>\n</pre>\n</$wikify>\n</$set>\n</$reveal>\n</li>\n</$set>\n</$vars>\n</$list>\n</ol>\n\\end\n\n\\define stylesheets-list()\n<ol>\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/Stylesheet]!has[draft.of]]\">\n<li>\n<$link>\n<$view field=\"title\"/>\n</$link>\n<$set name=\"source\" tiddler=<<currentTiddler>>>\n<$wikify name=\"styles\" text=<<source>>>\n<pre>\n<code>\n<$text text=<<styles>>/>\n</code>\n</pre>\n</$wikify>\n</$set>\n</li>\n</$list>\n</ol>\n\\end\n\n<$vars modeState=<<qualify \"$:/config/peek-stylesheets/mode/\">>>\n\n<$reveal type=\"nomatch\" state=<<modeState>> text=\"expanded\" tag=\"div\">\n<$button set=<<modeState>> setTo=\"expanded\" class=\"tc-btn-invisible\">{{$:/core/images/chevron-right}} {{$:/language/ControlPanel/Stylesheets/Expand/Caption}}</$button>\n</$reveal>\n<$reveal type=\"match\" state=<<modeState>> text=\"expanded\" tag=\"div\">\n<$button set=<<modeState>> setTo=\"restored\" class=\"tc-btn-invisible\">{{$:/core/images/chevron-down}} {{$:/language/ControlPanel/Stylesheets/Restore/Caption}}</$button>\n</$reveal>\n\n<$reveal type=\"nomatch\" state=<<modeState>> text=\"expanded\" tag=\"div\">\n<<expandable-stylesheets-list>>\n</$reveal>\n<$reveal type=\"match\" state=<<modeState>> text=\"expanded\" tag=\"div\">\n<<stylesheets-list>>\n</$reveal>\n\n</$vars>\n"
},
"$:/temp/search": {
"title": "$:/temp/search",
"text": ""
},
"$:/tags/AdvancedSearch": {
"title": "$:/tags/AdvancedSearch",
"list": "[[$:/core/ui/AdvancedSearch/Standard]] [[$:/core/ui/AdvancedSearch/System]] [[$:/core/ui/AdvancedSearch/Shadows]] [[$:/core/ui/AdvancedSearch/Filter]]"
},
"$:/tags/AdvancedSearch/FilterButton": {
"title": "$:/tags/AdvancedSearch/FilterButton",
"list": "$:/core/ui/AdvancedSearch/Filter/FilterButtons/dropdown $:/core/ui/AdvancedSearch/Filter/FilterButtons/clear $:/core/ui/AdvancedSearch/Filter/FilterButtons/export $:/core/ui/AdvancedSearch/Filter/FilterButtons/delete"
},
"$:/tags/ControlPanel": {
"title": "$:/tags/ControlPanel",
"list": "$:/core/ui/ControlPanel/Info $:/core/ui/ControlPanel/Appearance $:/core/ui/ControlPanel/Settings $:/core/ui/ControlPanel/Saving $:/core/ui/ControlPanel/Plugins $:/core/ui/ControlPanel/Tools $:/core/ui/ControlPanel/Internals"
},
"$:/tags/ControlPanel/Info": {
"title": "$:/tags/ControlPanel/Info",
"list": "$:/core/ui/ControlPanel/Basics $:/core/ui/ControlPanel/Advanced"
},
"$:/tags/ControlPanel/Plugins": {
"title": "$:/tags/ControlPanel/Plugins",
"list": "[[$:/core/ui/ControlPanel/Plugins/Installed]] [[$:/core/ui/ControlPanel/Plugins/Add]]"
},
"$:/tags/EditTemplate": {
"title": "$:/tags/EditTemplate",
"list": "[[$:/core/ui/EditTemplate/controls]] [[$:/core/ui/EditTemplate/title]] [[$:/core/ui/EditTemplate/tags]] [[$:/core/ui/EditTemplate/shadow]] [[$:/core/ui/ViewTemplate/classic]] [[$:/core/ui/EditTemplate/body]] [[$:/core/ui/EditTemplate/type]] [[$:/core/ui/EditTemplate/fields]]"
},
"$:/tags/EditToolbar": {
"title": "$:/tags/EditToolbar",
"list": "[[$:/core/ui/Buttons/delete]] [[$:/core/ui/Buttons/cancel]] [[$:/core/ui/Buttons/save]]"
},
"$:/tags/EditorToolbar": {
"title": "$:/tags/EditorToolbar",
"list": "$:/core/ui/EditorToolbar/paint $:/core/ui/EditorToolbar/opacity $:/core/ui/EditorToolbar/line-width $:/core/ui/EditorToolbar/rotate-left $:/core/ui/EditorToolbar/clear $:/core/ui/EditorToolbar/bold $:/core/ui/EditorToolbar/italic $:/core/ui/EditorToolbar/strikethrough $:/core/ui/EditorToolbar/underline $:/core/ui/EditorToolbar/superscript $:/core/ui/EditorToolbar/subscript $:/core/ui/EditorToolbar/mono-line $:/core/ui/EditorToolbar/mono-block $:/core/ui/EditorToolbar/quote $:/core/ui/EditorToolbar/list-bullet $:/core/ui/EditorToolbar/list-number $:/core/ui/EditorToolbar/heading-1 $:/core/ui/EditorToolbar/heading-2 $:/core/ui/EditorToolbar/heading-3 $:/core/ui/EditorToolbar/heading-4 $:/core/ui/EditorToolbar/heading-5 $:/core/ui/EditorToolbar/heading-6 $:/core/ui/EditorToolbar/link $:/core/ui/EditorToolbar/excise $:/core/ui/EditorToolbar/picture $:/core/ui/EditorToolbar/stamp $:/core/ui/EditorToolbar/size $:/core/ui/EditorToolbar/editor-height $:/core/ui/EditorToolbar/more $:/core/ui/EditorToolbar/preview $:/core/ui/EditorToolbar/preview-type"
},
"$:/tags/Manager/ItemMain": {
"title": "$:/tags/Manager/ItemMain",
"list": "$:/Manager/ItemMain/WikifiedText $:/Manager/ItemMain/RawText $:/Manager/ItemMain/Fields"
},
"$:/tags/Manager/ItemSidebar": {
"title": "$:/tags/Manager/ItemSidebar",
"list": "$:/Manager/ItemSidebar/Tags $:/Manager/ItemSidebar/Colour $:/Manager/ItemSidebar/Icon $:/Manager/ItemSidebar/Tools"
},
"$:/tags/MoreSideBar": {
"title": "$:/tags/MoreSideBar",
"list": "[[$:/core/ui/MoreSideBar/All]] [[$:/core/ui/MoreSideBar/Recent]] [[$:/core/ui/MoreSideBar/Tags]] [[$:/core/ui/MoreSideBar/Missing]] [[$:/core/ui/MoreSideBar/Drafts]] [[$:/core/ui/MoreSideBar/Orphans]] [[$:/core/ui/MoreSideBar/Types]] [[$:/core/ui/MoreSideBar/System]] [[$:/core/ui/MoreSideBar/Shadows]] [[$:/core/ui/MoreSideBar/Explorer]] [[$:/core/ui/MoreSideBar/Plugins]]",
"text": ""
},
"$:/tags/PageControls": {
"title": "$:/tags/PageControls",
"list": "[[$:/core/ui/Buttons/home]] [[$:/core/ui/Buttons/close-all]] [[$:/core/ui/Buttons/fold-all]] [[$:/core/ui/Buttons/unfold-all]] [[$:/core/ui/Buttons/permaview]] [[$:/core/ui/Buttons/new-tiddler]] [[$:/core/ui/Buttons/new-journal]] [[$:/core/ui/Buttons/new-image]] [[$:/core/ui/Buttons/import]] [[$:/core/ui/Buttons/export-page]] [[$:/core/ui/Buttons/control-panel]] [[$:/core/ui/Buttons/advanced-search]] [[$:/core/ui/Buttons/manager]] [[$:/core/ui/Buttons/tag-manager]] [[$:/core/ui/Buttons/language]] [[$:/core/ui/Buttons/palette]] [[$:/core/ui/Buttons/theme]] [[$:/core/ui/Buttons/storyview]] [[$:/core/ui/Buttons/encryption]] [[$:/core/ui/Buttons/timestamp]] [[$:/core/ui/Buttons/full-screen]] [[$:/core/ui/Buttons/print]] [[$:/core/ui/Buttons/save-wiki]] [[$:/core/ui/Buttons/refresh]] [[$:/core/ui/Buttons/more-page-actions]]"
},
"$:/tags/PageTemplate": {
"title": "$:/tags/PageTemplate",
"list": "[[$:/core/ui/PageTemplate/topleftbar]] [[$:/core/ui/PageTemplate/toprightbar]] [[$:/core/ui/PageTemplate/sidebar]] [[$:/core/ui/PageTemplate/story]] [[$:/core/ui/PageTemplate/alerts]]",
"text": ""
},
"$:/tags/SideBar": {
"title": "$:/tags/SideBar",
"list": "[[$:/core/ui/SideBar/Open]] [[$:/core/ui/SideBar/Recent]] [[$:/core/ui/SideBar/Tools]] [[$:/core/ui/SideBar/More]]",
"text": ""
},
"$:/tags/SideBarSegment": {
"title": "$:/tags/SideBarSegment",
"list": "[[$:/core/ui/SideBarSegments/site-title]] [[$:/core/ui/SideBarSegments/site-subtitle]] [[$:/core/ui/SideBarSegments/page-controls]] [[$:/core/ui/SideBarSegments/search]] [[$:/core/ui/SideBarSegments/tabs]]"
},
"$:/tags/TiddlerInfo": {
"title": "$:/tags/TiddlerInfo",
"list": "[[$:/core/ui/TiddlerInfo/Tools]] [[$:/core/ui/TiddlerInfo/References]] [[$:/core/ui/TiddlerInfo/Tagging]] [[$:/core/ui/TiddlerInfo/List]] [[$:/core/ui/TiddlerInfo/Listed]] [[$:/core/ui/TiddlerInfo/Fields]]",
"text": ""
},
"$:/tags/TiddlerInfo/Advanced": {
"title": "$:/tags/TiddlerInfo/Advanced",
"list": "[[$:/core/ui/TiddlerInfo/Advanced/ShadowInfo]] [[$:/core/ui/TiddlerInfo/Advanced/PluginInfo]]"
},
"$:/tags/ViewTemplate": {
"title": "$:/tags/ViewTemplate",
"list": "[[$:/core/ui/ViewTemplate/title]] [[$:/core/ui/ViewTemplate/unfold]] [[$:/core/ui/ViewTemplate/subtitle]] [[$:/core/ui/ViewTemplate/tags]] [[$:/core/ui/ViewTemplate/classic]] [[$:/core/ui/ViewTemplate/body]]"
},
"$:/tags/ViewToolbar": {
"title": "$:/tags/ViewToolbar",
"list": "[[$:/core/ui/Buttons/more-tiddler-actions]] [[$:/core/ui/Buttons/info]] [[$:/core/ui/Buttons/new-here]] [[$:/core/ui/Buttons/new-journal-here]] [[$:/core/ui/Buttons/clone]] [[$:/core/ui/Buttons/export-tiddler]] [[$:/core/ui/Buttons/edit]] [[$:/core/ui/Buttons/delete]] [[$:/core/ui/Buttons/permalink]] [[$:/core/ui/Buttons/permaview]] [[$:/core/ui/Buttons/open-window]] [[$:/core/ui/Buttons/close-others]] [[$:/core/ui/Buttons/close]] [[$:/core/ui/Buttons/fold-others]] [[$:/core/ui/Buttons/fold]]"
},
"$:/snippets/themeswitcher": {
"title": "$:/snippets/themeswitcher",
"text": "<$linkcatcher to=\"$:/theme\">\n<div class=\"tc-chooser\"><$list filter=\"[plugin-type[theme]sort[title]]\"><$set name=\"cls\" filter=\"[all[current]field:title{$:/theme}] [[$:/theme]!has[text]addsuffix[s/tiddlywiki/vanilla]field:title<currentTiddler>] +[limit[1]]\" value=\"tc-chooser-item tc-chosen\" emptyValue=\"tc-chooser-item\"><div class=<<cls>>><$link to={{!!title}}>''<$view field=\"name\" format=\"text\"/>'' <$view field=\"description\" format=\"text\"/></$link></div>\n</$set>\n</$list>\n</div>\n</$linkcatcher>"
},
"$:/core/wiki/title": {
"title": "$:/core/wiki/title",
"text": "{{$:/SiteTitle}} --- {{$:/SiteSubtitle}}"
},
"$:/view": {
"title": "$:/view",
"text": "classic"
},
"$:/snippets/viewswitcher": {
"title": "$:/snippets/viewswitcher",
"text": "\\define icon()\n$:/core/images/storyview-$(storyview)$\n\\end\n<$linkcatcher to=\"$:/view\">\n<div class=\"tc-chooser\">\n<$list filter=\"[storyviews[]]\" variable=\"storyview\">\n<$set name=\"cls\" filter=\"[<storyview>prefix{$:/view}]\" value=\"tc-chooser-item tc-chosen\" emptyValue=\"tc-chooser-item\"><div class=<<cls>>>\n<$link to=<<storyview>>>\n<$transclude tiddler=<<icon>>/>\n<$text text=<<storyview>>/>\n</$link>\n</div>\n</$set>\n</$list>\n</div>\n</$linkcatcher>"
}
}
}
<svg class="tc-image-advanced-search-button tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"/>
<path d="M0 0h24v24H0z" fill="none"/>
</svg>
<svg class="tc-image-cancel-button tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12 17 15.59z"/>
<path d="M0 0h24v24H0z" fill="none"/>
</svg>
<svg class="tc-image-close-button tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"/>
<path d="M0 0h24v24H0z" fill="none"/>
</svg>
<svg class="tc-image-delete-button tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zM19 4h-3.5l-1-1h-5l-1 1H5v2h14V4z"/>
<path d="M0 0h24v24H0z" fill="none"/>
</svg>
<svg class="tc-image-done-button tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M0 0h24v24H0z" fill="none"/>
<path d="M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4L9 16.2z"/>
</svg>
<svg class="tc-image-down-arrow tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M7.41 7.84L12 12.42l4.59-4.58L18 9.25l-6 6-6-6z"/>
<path d="M0-.75h24v24H0z" fill="none"/>
</svg>
<svg class="tc-image-edit-button tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M3 17.25V21h3.75L17.81 9.94l-3.75-3.75L3 17.25zM20.71 7.04c.39-.39.39-1.02 0-1.41l-2.34-2.34c-.39-.39-1.02-.39-1.41 0l-1.83 1.83 3.75 3.75 1.83-1.83z"/>
<path d="M0 0h24v24H0z" fill="none"/>
</svg>
<svg class="tc-image-export-button tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M9 3L5 6.99h3V14h2V6.99h3L9 3zm7 14.01V10h-2v7.01h-3L15 21l4-3.99h-3z"/>
<path d="M0 0h24v24H0z" fill="none"/>
</svg>
<svg class="tc-image-info-button tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M0 0h24v24H0z" fill="none"/>
<path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-6h2v6zm0-8h-2V7h2v2z"/>
</svg>
<svg class="tc-image-left-arrow tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M15.41 16.09l-4.58-4.59 4.58-4.59L14 5.5l-6 6 6 6z"/>
<path d="M0-.5h24v24H0z" fill="none"/>
</svg>
<svg class="tc-image-menu-button tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M0 0h24v24H0z" fill="none"/>
<path d="M3 18h18v-2H3v2zm0-5h18v-2H3v2zm0-7v2h18V6H3z"/>
</svg>
<svg class="tc-image-new-button tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z"/>
<path d="M0 0h24v24H0z" fill="none"/>
</svg>
<svg class="tc-image-new-image-button tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M0 0h24v24H0z" fill="none"/>
<path d="M7 14c-1.66 0-3 1.34-3 3 0 1.31-1.16 2-2 2 .92 1.22 2.49 2 4 2 2.21 0 4-1.79 4-4 0-1.66-1.34-3-3-3zm13.71-9.37l-1.34-1.34c-.39-.39-1.02-.39-1.41 0L9 12.25 11.75 15l8.96-8.96c.39-.39.39-1.02 0-1.41z"/>
</svg>
<svg class="tc-image-new-journal-button tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M9 11H7v2h2v-2zm4 0h-2v2h2v-2zm4 0h-2v2h2v-2zm2-7h-1V2h-2v2H8V2H6v2H5c-1.11 0-1.99.9-1.99 2L3 20c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 16H5V9h14v11z"/>
<path d="M0 0h24v24H0z" fill="none"/>
</svg>
<svg class="tc-image-options-button tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M0 0h24v24H0z" fill="none"/>
<path d="M19.43 12.98c.04-.32.07-.64.07-.98s-.03-.66-.07-.98l2.11-1.65c.19-.15.24-.42.12-.64l-2-3.46c-.12-.22-.39-.3-.61-.22l-2.49 1c-.52-.4-1.08-.73-1.69-.98l-.38-2.65C14.46 2.18 14.25 2 14 2h-4c-.25 0-.46.18-.49.42l-.38 2.65c-.61.25-1.17.59-1.69.98l-2.49-1c-.23-.09-.49 0-.61.22l-2 3.46c-.13.22-.07.49.12.64l2.11 1.65c-.04.32-.07.65-.07.98s.03.66.07.98l-2.11 1.65c-.19.15-.24.42-.12.64l2 3.46c.12.22.39.3.61.22l2.49-1c.52.4 1.08.73 1.69.98l.38 2.65c.03.24.24.42.49.42h4c.25 0 .46-.18.49-.42l.38-2.65c.61-.25 1.17-.59 1.69-.98l2.49 1c.23.09.49 0 .61-.22l2-3.46c.12-.22.07-.49-.12-.64l-2.11-1.65zM12 15.5c-1.93 0-3.5-1.57-3.5-3.5s1.57-3.5 3.5-3.5 3.5 1.57 3.5 3.5-1.57 3.5-3.5 3.5z"/>
</svg>
<svg class="tc-image-right-arrow tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M8.59 16.34l4.58-4.59-4.58-4.59L10 5.75l6 6-6 6z"/>
<path d="M0-.25h24v24H0z" fill="none"/>
</svg>
<svg class="tc-image-save-button tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M0 0h24v24H0z" fill="none"/>
<path d="M17 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V7l-4-4zm-5 16c-1.66 0-3-1.34-3-3s1.34-3 3-3 3 1.34 3 3-1.34 3-3 3zm3-10H5V5h10v4z"/>
</svg>
<svg class="tc-image-up-arrow tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<svg height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg">
<path d="M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6z"/>
<path d="M0 0h24v24H0z" fill="none"/>
</svg>
/*\
title: $:/core/modules/filters/count.js
type: application/javascript
module-type: filteroperator
Filter operator that gives the counts the current list's members
\*/
(function(){
/*jslint node: true, browser: true */
/*global $tw: false */
"use strict";
/*
Export our filter function
*/
exports.count = function(source,operator,options) {
// count the source if it's not an array
var count = 0;
if(!$tw.utils.isArray(source)) {
$tw.utils.each(source,function(element,title) {
++count;
});
return [ "" + count ];
}
// return array's length
return [ "" + source.length ];
};
})();
/*\
title: $:/core/modules/filters/split.js
type: application/javascript
module-type: filteroperator
Filter operator for splitting each current list element
into several new elements.
\*/
(function(){
/*jslint node: true, browser: true */
/*global $tw: false */
"use strict";
/*
Export our filter function
*/
exports.split = function(source,operator,options) {
var results = [],
fieldname = (operator.suffix || operator.operator).toLowerCase();
// Function to check an individual title
function checkTiddler(title) {
var tiddler = options.wiki.getTiddler(title);
if(tiddler) {
var splitted,
text = tiddler.getFieldString(fieldname);
if(operator.regexp) {
splitted = text.split(operator.regexp);
} else {
splitted = text.split(operator.operand);
}
if(splitted) {
$tw.utils.pushTop(results,splitted);
}
}
}
// Iterate through the source tiddlers
if($tw.utils.isArray(source)) {
$tw.utils.each(source,function(title) {
checkTiddler(title);
});
} else {
$tw.utils.each(source,function(element,title) {
checkTiddler(title);
});
}
return results;
};
})();
<!--
This template is used to assign the ''_canonical_uri'' field to external images.
Change the `./images/` part to a different base URI. The URI can be relative or absolute.
-->
./images/<$view field="title" format="doubleurlencoded"/>
<!--
This template is used to assign the ''_canonical_uri'' field to external raw files that are stored in the same directory
-->
<$view field="title" format="doubleurlencoded"/>
<!--
This template is used to assign the ''_canonical_uri'' field to external text files.
Change the `./text/` part to a different base URI. The URI can be relative or absolute.
-->
./text/<$view field="title" format="doubleurlencoded"/>.tid
\define control-panel-button(class)
<$button to="$:/ControlPanel" tooltip={{$:/language/Buttons/ControlPanel/Hint}} aria-label={{$:/language/Buttons/ControlPanel/Caption}} class="""$(tv-config-toolbar-class)$ $class$""">
<$list filter="[<tv-config-toolbar-icons>prefix[yes]]">
{{$:/core/images/options-button}}
</$list>
<$list filter="[<tv-config-toolbar-text>prefix[yes]]">
<span class="tc-btn-text"><$text text={{$:/language/Buttons/ControlPanel/Caption}}/></span>
</$list>
</$button>
\end
<$list filter="[list[$:/StoryList]] +[field:title[$:/ControlPanel]]" emptyMessage=<<control-panel-button>>>
<<control-panel-button "tc-selected">>
</$list>
<$button message="tm-home" tooltip={{$:/language/Buttons/Home/Hint}} aria-label={{$:/language/Buttons/Home/Caption}} class=<<tv-config-toolbar-class>>>
<$list filter="[<tv-config-toolbar-icons>prefix[yes]]">
{{$:/core/images/home-button}}
</$list>
<$list filter="[<tv-config-toolbar-text>prefix[yes]]">
<span class="tc-btn-text"><$text text={{$:/language/Buttons/Home/Caption}}/></span>
</$list>
</$button>
\define config-title()
$:/config/PageControlButtons/Visibility/$(listItem)$
\end
<$button popup=<<qualify "$:/state/popup/more">> tooltip={{$:/language/Buttons/More/Hint}} aria-label={{$:/language/Buttons/More/Caption}} class=<<tv-config-toolbar-class>> selectedClass="tc-selected">
<$list filter="[<tv-config-toolbar-icons>prefix[yes]]">
{{$:/core/images/down-arrow}}
</$list>
<$list filter="[<tv-config-toolbar-text>prefix[yes]]">
<span class="tc-btn-text"><$text text={{$:/language/Buttons/More/Caption}}/></span>
</$list>
</$button><$reveal state=<<qualify "$:/state/popup/more">> type="popup" position="below" animate="yes">
<div class="tc-drop-down">
<$set name="tv-config-toolbar-icons" value="yes">
<$set name="tv-config-toolbar-text" value="yes">
<$set name="tv-config-toolbar-class" value="tc-btn-invisible">
<$list filter="[all[shadows+tiddlers]tag[$:/tags/PageControls]!has[draft.of]] -[[$:/core/ui/Buttons/more-page-actions]]" variable="listItem">
<$reveal type="match" state=<<config-title>> text="hide">
<$set name="tv-config-toolbar-class" filter="[<tv-config-toolbar-class>] [<listItem>encodeuricomponent[]addprefix[tc-btn-]]">
<$transclude tiddler=<<listItem>> mode="inline"/>
</$set>
</$reveal>
</$list>
</$set>
</$set>
</$set>
</div>
</$reveal>
<$button actions={{$:/core/ui/Actions/new-tiddler}} tooltip={{$:/language/Buttons/NewTiddler/Hint}} aria-label={{$:/language/Buttons/NewTiddler/Caption}} class=<<tv-config-toolbar-class>>>
<$list filter="[<tv-config-toolbar-icons>prefix[yes]]">
{{$:/core/images/new-button}}
</$list>
<$list filter="[<tv-config-toolbar-text>prefix[yes]]">
<span class="tc-btn-text"><$text text={{$:/language/Buttons/NewTiddler/Caption}}/></span>
</$list>
</$button>
<span class="tc-popup-keep">
<$button popup=<<qualify "$:/state/popup/theme">> tooltip={{$:/language/Buttons/Theme/Hint}} aria-label={{$:/language/Buttons/Theme/Caption}} class=<<tv-config-toolbar-class>> selectedClass="tc-selected">
<$list filter="[<tv-config-toolbar-icons>prefix[yes]]">
{{$:/core/images/theme-button}}
</$list>
<$list filter="[<tv-config-toolbar-text>prefix[yes]]">
<span class="tc-btn-text"><$text text={{$:/language/Buttons/Theme/Caption}}/></span>
</$list>
</$button>
</span>
<$reveal state=<<qualify "$:/state/popup/theme">> type="popup" position="below" animate="yes">
<div class="tc-drop-down">
<$linkcatcher to="$:/theme">
{{$:/snippets/themeswitcher}}
</$linkcatcher>
</div>
</$reveal>
\whitespace trim
\define lingo-base() $:/language/EditTemplate/
\define tag-styles()
background-color:$(backgroundColor)$;
fill:$(foregroundColor)$;
color:$(foregroundColor)$;
\end
\define tag-body-inner(colour,fallbackTarget,colourA,colourB,icon)
\whitespace trim
<$vars foregroundColor=<<contrastcolour target:"""$colour$""" fallbackTarget:"""$fallbackTarget$""" colourA:"""$colourA$""" colourB:"""$colourB$""">> backgroundColor="""$colour$""">
<span style=<<tag-styles>> class="tc-tag-label tc-tag-list-item">
<$transclude tiddler="""$icon$"""/> <$view field="title" format="text" />
<$button message="tm-remove-tag" param={{!!title}} class="tc-btn-invisible tc-remove-tag-button">×</$button>
</span>
</$vars>
\end
\define tag-body(colour,palette,icon)
<$macrocall $name="tag-body-inner" colour="""$colour$""" fallbackTarget={{$palette$##tag-background}} colourA={{$palette$##foreground}} colourB={{$palette$##background}} icon="""$icon$"""/>
\end
\define tag-picker-actions()
<$action-listops
$tiddler=<<currentTiddler>>
$field="tags"
$subfilter="[<tag>] [all[current]tags[]]"
/>
\end
<div class="tc-edit-tags">
<$fieldmangler>
<$list filter="[all[current]tags[]sort[title]]" storyview="pop">
<$macrocall $name="tag-body" colour={{!!color}} palette={{$:/palette}} icon={{!!icon}}/>
</$list>
</$fieldmangler>
<$macrocall $name="tag-picker" actions=<<tag-picker-actions>>/>
</div>
<div class="tc-menu-list-item">
<$link to={{!!title}}>
<$view field="title"/>
</$link>
</div>
\define containerClasses()
tc-page-container tc-page-view-$(storyviewTitle)$ tc-language-$(languageTitle)$
\end
\import [[$:/core/ui/PageMacros]] [all[shadows+tiddlers]tag[$:/tags/Macro]!has[draft.of]]
<$set name="tv-config-toolbar-icons" value={{$:/config/Toolbar/Icons}}>
<$set name="tv-config-toolbar-text" value={{$:/config/Toolbar/Text}}>
<$set name="tv-config-toolbar-class" value={{$:/config/Toolbar/ButtonClass}}>
<$set name="tv-show-missing-links" value={{$:/config/MissingLinks}}>
<$set name="storyviewTitle" value={{$:/view}}>
<$set name="currentTiddler" value={{$:/language}}>
<$set name="languageTitle" value={{!!name}}>
<$set name="currentTiddler" value="">
<div class=<<containerClasses>>>
<$navigator story="$:/StoryList" history="$:/HistoryList" openLinkFromInsideRiver={{$:/config/Navigation/openLinkFromInsideRiver}} openLinkFromOutsideRiver={{$:/config/Navigation/openLinkFromOutsideRiver}} relinkOnRename={{$:/config/RelinkOnRename}}>
<$dropzone>
<$list filter="[all[shadows+tiddlers]tag[$:/tags/PageTemplate]!has[draft.of]]" variable="listItem">
<$transclude tiddler=<<listItem>>/>
</$list>
</$dropzone>
</$navigator>
</div>
</$set>
</$set>
</$set>
</$set>
</$set>
</$set>
</$set>
</$set>
\define config-title()
$:/config/PageControlButtons/Visibility/$(listItem)$
\end
<div class="tc-page-controls">
<$list filter="[all[shadows+tiddlers]tag[$:/tags/PageControls]!has[draft.of]]" variable="listItem">
<$reveal type="nomatch" state=<<config-title>> text="hide">
<$set name="tv-config-toolbar-class" filter="[<tv-config-toolbar-class>] [<listItem>encodeuricomponent[]addprefix[tc-btn-]]">
<$transclude tiddler=<<listItem>> mode="inline"/>
</$set>
</$reveal>
</$list>
</div>
<section class="tc-story-river">
<section class="story-backdrop">
<$list filter="[all[shadows+tiddlers]tag[$:/tags/AboveStory]!has[draft.of]]">
<$transclude/>
</$list>
</section>
<$list filter="[list[$:/StoryList]!prefix[tw-href]]" history="$:/HistoryList" template="$:/core/ui/ViewTemplate" editTemplate="$:/core/ui/EditTemplate" storyview={{$:/view}} emptyMessage={{$:/config/EmptyStoryMessage}}/>
<section class="story-frontdrop">
<$list filter="[all[shadows+tiddlers]tag[$:/tags/BelowStory]!has[draft.of]]">
<$transclude/>
</$list>
</section>
</section>
<span class="tc-topbar tc-topbar-left">
<$list filter="[all[shadows+tiddlers]tag[$:/tags/TopLeftBar]!has[draft.of]]" variable="listItem">
<$transclude tiddler=<<listItem>> mode="inline"/>
</$list>
</span>
<span class="tc-topbar tc-topbar-right">
<$list filter="[all[shadows+tiddlers]tag[$:/tags/TopRightBar]!has[draft.of]]" variable="listItem">
<$transclude tiddler=<<listItem>> mode="inline"/>
</$list>
</span>
<div class="tc-more-sidebar">
<$macrocall $name="tabs" tabsList="[all[shadows+tiddlers]tag[$:/tags/MoreSideBar]!has[draft.of]]" default={{$:/config/DefaultMoreSidebarTab}} state="$:/state/tab/moresidebar" class="tc-vertical" />
</div>
\define lingo-base() $:/language/CloseAll/
<$list filter="[list[$:/StoryList]!prefix[tw-href]]" history="$:/HistoryList" storyview="pop">
<$button message="tm-close-tiddler" tooltip={{$:/language/Buttons/Close/Hint}} aria-label={{$:/language/Buttons/Close/Caption}} class="tc-btn-invisible tc-btn-mini">×</$button> <$link to={{!!title}}><$view field="title"/></$link>
</$list>
<$button message="tm-close-all-tiddlers" class="tc-btn-invisible tc-btn-mini"><<lingo Button>></$button>
<$macrocall $name="timeline" format={{$:/language/RecentChanges/DateFormat}}/>
\define lingo-base() $:/language/ControlPanel/
\define config-title()
$:/config/PageControlButtons/Visibility/$(listItem)$
\end
<<lingo Basics/Version/Prompt>> <<version>>
<$set name="tv-config-toolbar-icons" value="yes">
<$set name="tv-config-toolbar-text" value="yes">
<$set name="tv-config-toolbar-class" value="">
<$list filter="[all[shadows+tiddlers]tag[$:/tags/PageControls]!has[draft.of]]" variable="listItem">
<div style="position:relative;" class={{{ [<listItem>encodeuricomponent[]addprefix[tc-btn-]] }}}>
<$checkbox tiddler=<<config-title>> field="text" checked="show" unchecked="hide" default="show"/> <$transclude tiddler=<<listItem>>/> <i class="tc-muted"><$transclude tiddler=<<listItem>> field="description"/></i>
</div>
</$list>
</$set>
</$set>
</$set>
<div class="tw-subtitle">
<$link to={{!!modifier}}>
<$view field="modifier"/>
</$link> <$view field="modified" format="relativedate"/>
</div>
/*\
creator: Danielo Rodriguez
title: $:/danielo515/macros/remove_from_list.js
type: application/javascript
module-type: macro
\*/
(function(){
/*jslint node: true, browser: true */
/*global $tw: false */
"use strict";
/*
Information about this macro
Returns the list without the given element.
*/
exports.name = "remove_from_list";
exports.params = [
{ name: "listfield" },
{ name: "remove" },
{ name: "tiddler" }
];
/*
Run the macro
*/
exports.run = function(remove,listfield,tiddler) {
var title=tiddler || this.getVariable("currentTiddler"),
list=$tw.wiki.getTiddlerList(title,listfield);
console.log("removing ",remove," from ",list);
var result="", position=list.indexOf(remove);
if( position !== -1 ){
list.splice(position,1);
return $tw.utils.stringifyList(list);
}
return $tw.utils.stringifyList(list);
}
})();
\define appendButton(now, add, to,caption:"add")
<$button set="$to$!!tokens" setTo="$now$ [[$add$]]" to="" message="tm-navigate">$caption$</$button>
\end
\define appendTokenButton(field:"tokens",caption)
<$linkcatcher to="$:/temp/addtoken">
<$macrocall $name="appendButton" now={{!!$field$}} add={{$:/temp/addtoken}} to=<<currentTiddler>>/>
</$linkcatcher>
\end
\define tokeneditor( ) <$edit-text tiddler="$:/temp/addtoken" tag="input" default=""/>
\define list-element(element)
<$set name="backgroundColor" value={{!!color}}><span style=<<tag-styles>> class="tc-tag-label">
<$button class="tc-btn-invisible" set="!!tokens" setTo=<<remove_from_list "$element$" "tokens">> >$element$ x</$button></span>
\end
<$list filter="[list[!!tokens]]" variable="item">
<$macrocall $name="list-element" element=<<item>>/>
</$list>
{
"Test Entry": "22th December 2018"
}
{
"TiddlerInformation": "1",
"Kaufrecht": "1"
}
[[StartBaum]]
[[See Recent Tiddlers]]
[[Tiddler Eingabe]]
[[$:/ControlPanel]]
[[$:/core/ui/SideBar/More]]
[[AGL -visuel]]
MagicTabs
iVBORw0KGgoAAAANSUhEUgAAAGEAAABlCAYAAABdl421AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAAEnQAABJ0Ad5mH3gAAAAcdEVYdFNvZnR3YXJlAEFkb2JlIFBob3Rvc2hvcCA3LjDJbLm3AAAAB3RJTUUH1wEKDC8KauFn9AAAISJJREFUeF7d3XWUZUcRBvC7i7tLcHd3CO4OwR2C5+AcNGiABHd3OEhw9xAsCSGE4BAI7u7uzK92vpeam/fezOy+t3/sd05v32qprq7qru7bt9/slgMOOOB/wy6M//1vbfe2bt26Ju1YxzrWMcps2bKlysF///vfCZ1ys2jYTPnQ22ruotBJHe4B5tGUI+4KCz3OH9ObLR96lzYC6OhmQhBlJS10MIvebPl6rn93IRhhCRDFpMP9GXp+0ikIdhpd/+4ioHgd7KFDp/nsXu4///lPpUEMJ46CIPQ4fxotFvAWj/On0buUEcZIJwN0lJM8z6HFm8mfRcNm6u/SRpiHKEPodLDR/GBH6u8UI7C6RpcBvBOm0dBpHY8sXUHBvPyl0fXvEsHfHv/4xx9+8IMfTBpdFChWhxLwt+/vIWVCkydrQGLrgnKz8uXhHUNuhhYLkW8avVQjEOLYxz728Le//W042clONhzveMebCLqzoLOQdtPxKIh83UDj/ChrR2hAwzR66TNBYzpqNvz9739fTd05SEchyhE6fZKTnGQ44IAD1qSNn2GZ9FKNoBGK+Mtf/jKc4AQnqIaDKKgrqj9vFOokBJ0mQ9qddHqVPu5xjzt87WtfGz7wgQ8MJz7xiSczYVb5pdH175IQRZzoRCeqDkY5AkHEBBHLN2M8z0Pqp1xcSQJ+eCfgK4BYGWsAUPyDH/zgMoay8sI7csGy6aUaQUPp+L///e8yxglPeMLK+9e//lXpQAExgDqzkPweOtKpDryV6x2XdpzjHGf461//OvziF78Yrne9600ME74pP66/DHqpRgg0SMl3uctdal04xSlOUaOPgQhCAYT55je/OTHMLCjfwzxoN0jnMyhsEl7wghdU3nWuc53hH//4Rz2HZ8oHy6SX7o4oP7OAkq91rWsNN7jBDWpBBIIIymU0qjctQO9IR/KDXl6H+7P4lKc85fC6172u0pOfQdHLw9Lp+neJiDK4HzAKz3jGM05GPMUTxjb2ghe8YCmCkAnK9aBsz1deG7Noz4J6Ysa2XX70ox9d7YONQ9aFcXlYNr10I2jMLHjDG94wXO5ylxvOcpazDF/4whcmSgqUM2M6ImQwpgGP3iHPazrY8sUGw+9///uS5/73v/9wgQtcYHjRi15UBk7ZXn5cfxn00o1gZNqe6vRuu+1WAT796U/XIk2Q7YWOBOlc+IUOQp/+9KcfrnSlKw2PetSjhgc84AHDK1/5yuHLX/5yrRFxR718sEx6qUbQCEX985//LFfzsY99rI4v4EEPetBw1FFHlSGU6QrtzzAtv9M6BJNOzaDtiLyYPfnJTx5ud7vbDb/61a+Gk570pJV/5JFH1mCBlA82yn+76fp3ydDYyU9+8uEPf/jD8JOf/KTSGObOd77z8POf/7w6zx1QrLJ5BqPTKJVOiSmjI1knpCk3D/K5oktd6lLDNa5xjXJJ3J9d0S1ucYvh5S9/ea0XQpSDN6TNyLRIWj+WagSN6AiFO7bo0Fm4+c1vXttWuxWGMjLlKS8mpEUbr6wZOgDS0pEYwwJL2f2cKm2pZyNAHnlobd/hDncYPvjBD9aCnY3COKS8thZJV1pJt2RQCEUCIaAvwrate++9d7kJu5Z3vetdNXIp9jSnOU29V8Qg0sT9GXTGTFHPzGIMdXXWaFe2Qz11lFf2zGc+c7nIM53pTGXEzCxlIOWDRdJLvfISaxvdt771rYfvf//7qzmbg0XUWy3F4Ak64dmaQvmUnFFM6c997nOHz33uc8MNb3jD4W53u9vE/chXN/DMCIcccshwv/vdb3jve99bBlG2GyJBm6m/ozR4Xvq9Ix2xI7rIRS5Su5If/ehHZYyb3OQmwxWveMXh6le/epWzXmSHwkW86lWvKreh7BFHHFFlZmH33Xcf/vjHPw5f+cpXVlOOhneSpz/96cM5z3nOoilBGwLDRSlmjTJk/eIXvzh897vfncwsrtFMNhuVp0x1PEOnS6mrtEGRwSFOm/IFKH474/IX5T7kIQ8ZXv/619d5DVAwZQs6F8HSkWxf07koAd7//vfXttIib7RvBOc///mHd7zjHcNvfvObGvkUjGeUZk0yYz71qU8Nl7jEJYZ3v/vdJasXOcqLATxHgZE5CM1of/7znys2oygeYohx/aW7Iw1T+IEHHjg85jGPGQ477LDKIxxFEyqCiSlFHX65C9/TsmhTJN7SISPXAv+73/2unsW2ot/61reGK1/5ypXH8L/85S/L7aRt7w93v/vdJ98WYM899yyZ9eNPf/pTtZWBQM6O0OEn6J/16be//e3EiNKh11/LacHQIMG9MXMLnimRAQiHjh8nvDzCeSa0dLSYoj2ra3QaxTonxkegXPm2vcqrd6pTnareUfbYY486upaPDwV51qaZ+tWvfnWNAeDVr371cI5znGN47WtfW0Y47WlPW7MoCsQfQgO5lTnrWc9a68w973nP2nUxQIwwrr90d5SGrQUWSe7DSKZ8eRlZgTRCRsCMLGnJE2K0KDXle33PkPqgXnjIl0cWBsKPG3G4eOihh5ZR9t9//6oH1i8vedYg7aqHjxkoZngzzcC4z33uM3zkIx+pejYK3/nOdyYyRp6JrDvDCEbd5z//+eFWt7pVLXoaFhggMyHoShwjwscwlNbri3u9aXQUHxqPGFSQRmlkplwGMeOMbrPXBkK+PLzgox/96HDqU5+61p2XvOQltanosOO66EUvWmvMWJ7SxSq9FBDSVP/2t79dMaXrgJkgb2yAMdJJiOGMNgqRF2Mkv/OaRY/LxwBiLg1/coq5vZ/+9Kf1bHRbR0BftK+cute97nWHy1/+8uV2bafN+q9//evDU57ylCpvQ6C9ji7fUo0Api2Bz3Wuc9X7wnnOc56a8joSyE8IdNBoIyiBPXMZOkohfD0FQDoYJWdEJ/R86ArxHENoM3WkyZMmjtIZJINH8AwGlzLybZfJ69OpdcRBofS029vH42hqQRgrNB0hLMFMaUYwNdM5gqSzFM2vWigPOuigGp3KWkue8IQn1LsG3/zQhz60djTeprkMQb0Yh7EYnTIjS9qqjq+0lfbFyU+MhzhBmV5P0KfUVd5zDCrYDps9ZoK+S5vW/kLXhGK40kCHEW9Rslu42tWuVqPEO4PjAW/Bdh1GCeMo66TVEYbtpOPvM5zhDCWsb8GgY16+XvOa15TSvfDJNxLx8q3CTAFf8PLxhhK0w9hBFBIsgo5i9eeFL3xhyQrWElvljtRfuBEI0aHzP/vZz2rUXuUqV6mRwSUxiFNUC5p6RtDpTne6Wtwuc5nLDO985zvLANIpr7sv11TMBIdulMrldUQZn/3sZye8u7JgLOciac/eQfQtL6c//OEPS06ywJryq/F2QycTINYNNMxFJM1MMII/8YlP1AwBAtnjezmyuzCCGIDy8WUAUz8dsO+3dbzHPe5RHTXNAR9uSJ0nPelJtYAH0tLxxJFpUTRI064BEJcL3vLtuOAY9evf7UQ61kO3tKAhaUYC/PjHPy6lUfRVr3rVymMAPv35z3/+cLGLXazWDLyjXOtCnqVDrlV6McviiNfZzna24fGPf/xw4xvfuNySPDJ02fCQFl47QqePicmpHYOPfNLA+Vdc4ZjfDhlhIyAcJe6zzz6136Y0I/niF794pRPEyKEsW0LBIRoh06kIn46CYxBvtM55fKL0TWCvvfaqRfCmN71pjcIoCdLx8FgULXT+mb1mKLcbw9uWQ+p0fks1goYEo1ZjXM3b3/72Osex+HJH0gmqnGcG4a7QPV3nwOJmLeGKGMyIt2OyADMCd6eekNkDeERhsCxam3Z4Zr51MC6RDiB1ev1NGyGKFWah52kM/da3vrVmwNve9rbhG9/4Rn24MWrzwYbwdhCmrecImNgCbyY5NrBrsnuy1rjLpA3KZ6i+dgTyoSsAdpQGaZ024sn04he/uPpr12ZG2N1FL8fgV/9uEJhg0IO0HpIe4ShFsLU8+9nPPlzhCleo0UHRdkD2/2hlGeSBD3xgHQNARrIPMhbie9/73sN973vfuiBg5H/yk5+sWxu+I1z60pcu5TOot1VbxBiDXOQRb4SGWfm9b4K05Avg0gBj2BU+8pGPLKPc6173qhPdXj91NmWEMXrjCUkXoOcZ6Y997GNre2onBI94xCNK+cpnG3rb2952eOlLX1qHaE4w73SnO9W7BTfl4xCXZG1hPB9ibnOb29QLnLdTs8NaY+YIaTuypvOzaIb3HHcmrecLgIZeH8hk9D/taU8rd+Q4w9GHQSHuizNU/c28J6ioUjCmgUA6IM5I7pBG2RR6oxvdqEaJxdUMgDe96U0lsHcB5RyBX/aylx1+/etfl1HMBqNeR3XIToprAjsr5zjyLnShC5VhuDAYyzmL1qf4cTucKD35YzpAC14YP/OZz9QRtg3CM5/5zBoMvIF3JC+pnnv9dY0QiwW9sryu6Bglwmt8DGUoT75yPq7vu+++NYIh5/wrcg3nO9/56q1aG9yQbS1Y2M0GfLzgOSL/3ve+N5z3vOetNcWnSrPB1RabgVyz0WZk7LQ4weDIsYp3DrL0PntWDlI/+frrlFhfXK1x0fgVr3jFxDVarG2h1YFJ/aJmIA30IC0BxguhZ8oRPPf8cR0j3Zcr2zmjV7rFzLGvBVhHrCUWtfe9731V11GEugyDH2PYnrrK+KEPfajKSeP6LPw+3nt7jczkEhvt2gPPFE5ZD3/4w8v4fjgS9wja6/2PAkEc/RgMtt/g7ArPDErvQ6nX6881whip3IOGwzD0tLI9PzThfNu1s5EeY/Gdjr995Dd6HOTl5p7jCltTSgnva17zmjXaBQq04Hv5gze/+c11vqQ810ax2tJ2Zip+vgEcfvjhteDbCFiXcuQQeWHcX8Ab7M60ZTaTxXrgmbGVcX6mj70+fpsyAqjYQxDhgtBJm5Yf2FcTzijVEQIbnWId8ImRm7F+mOrehOMmxHYi3JL61gDnT3ZQFmywJTa7rBm2yAwPFEFJXIg8F5bx9D1AG4yEJgv5YghIfzLjxWSxOQAukxGlmQ1mQY4tIPXruf5t0FDCNHRFBhiCPKHT02L5+KPTCc9ixxoUT3gKlc+/o82YLMjpNAXpIF/LbUlH2z25TGYG2V2BNC+JFkfuh5GVtW1mJDMiPBnAgDBzGBGNN/T+kVWMl61xXJiNhIGAxsdAYVhlx/pZYwSKUaCHaUaRrlEBolCgSCHPoJz8BOAu0gGxTvoESvFGprdg7sEsCcJH+0YzpaQNaeEvTcytWBt84eKiUtaC7QTWSMUz/ZPPAORBk8n6QgYzjSLTjhjIoLy1yyzNTGBMa5pBoyze6qctPMSwZnckMcwhhTt6ZyEdhjDutKAOoQis00YfIxghysvTST40W0q42c1uNjz1qU+t8vHPlKTOXe9613oLNzsgyuxI29K9izAIhQqURnYy8d+5sq9s6jhqcJPPttN9JEckdml9rVCWsbw4cmdeSPH1XcPCzAVFrugjCL1mJkxDCiZM6yiMjRPadCQ0YYwUAkdwI4gBlKEU7wFPfOIT65a0Dtjd2OYdfPDBZSSj35T2XkFxDIKXTos70r48BrLtRKtv4Qd5aNvSLrtYfbJxZxZ3b+VeFNUB+UJGurdkBtAn7pOsGfkpH/7Q6a0KJcCY7hVnAUOYMG20Tpqiznu8SDm0YwyCGpGM4dmINAu8wDGETjtfMqUdzHnxMSr5b9AGI0BmgRjSPsRdxOCUGOV4n7DzMuLlq4cHudUzU/n1zE7bY7KGPx7WFjPs+te/fqXJw1+aviUNpukHVuij/b9EQvQgrZeBGKjHYQihxRRltJiqRpWLwfbi0qN8z5Sgvbgei6jFlkHc2rP/9mtLZUA9nTTDkkbJ6UfkzUzwrLxn8qjnHSV1pJM3fbKjsW7YleFhkTegyIl/Ap6uTNqRgfrKMEJ4iaOPLl94HD1kpiBMOlI5jDsNYZx8ndRB+36wV/cWLI8RQBlKYQz10lH53Ij6pru7ojEWd+QzqDMl7iztqAeRh3wQWn2ujhFzLsUo8hPw064XQLB99WZvocdPmcwU/Oy2zCbGkkcG21xlxvqaJt9cI4yRihDmQeikhTZSjCA7Emc+jijySxl5lMct+arG91tAdQwo1TPjOJHMVtNZkeskbsJZzLUzS56gy2d9Ofe5z12fWG0ltSMfyKSf3rSdX3n7dfnA1jluTFmGs5bYyXGRScfLVteg6pglDxzj7AgT6JaCTk8qT4mNBnECJaojGC1cjTJGUTeCKy63v/3th2c961m1duiIOmkXL7IxnjtMlAD4Z7b0dmFa7MXPL0i5D7srx8uRBeySuEuzwCGgtck6ZlSTJfwFLpOBlM/A0R8yOvawvuGd9mGsvzIe4XvIlIrixrTnCAPyhf6sQ0nzrB4fywDqxjCedc5MoRQuyyiPUoPetnMmC6WtqXp4jqd9l09baDDLGMFLneMP7YD62jPjzMa4Id8w8k0cwh+tX67nm42gHekGhzzGM3NAvd6HyBe5juGOemfA85oKc/LFOhQQijGk5wjXnluachl98o0Y21R8tKGscp4h7SkX/x9jwiz5ss5oy8i1lrioy8/jn/bIYxdnvQIns76IaQ/CL7JSsOCsiDzpC17Kajc0pH6XT4xeY4QUhBQWOh3MytcxQumUhZX/ta9POb6SwMrZCYVHAuX2DgfhL59b6+VglnwUlqMD7Tp/clLL3WXURonPfvazV2sP5aoYLDx7+2a1WWBNgJQhj6BffqSObzBLvnqufxtkKJBn2CgNOmy0E4YhvPbbmu633351X98IYQB1dWYWIkfipFGCT4YOyFJ/nnxkMGPyrD75gKxkMaLNApd5gY/nquRB75/6Bpd3DNtukN8HBCPIY2TtRi59NwjH8m458MADj669gjHD8YgL0zCKQlPPsw7oqOnszfEtb3lL7Wb4fC6HUghkdFJMeAIeeHXac+fvBYkiMtJ6/pgOLwF6mmf9c9GMG/r4xz9eZchJPrPD8UrKaU+g5BjWlluafoA1RD1rla2wvPDyocpawch5mSv9razua4wQYQMCd3Q6HUkdMWGkacSRQwdfTGhGSsd6e54XTY/lHedTsssCfsmD9imVsijxwx/+8PCe97ynlG4HZ/RT6OMe97iSnxLNRorWl2wWzCxxDKMsoA1O+fhEd1tWrL8pIyQ/6WmglyMQ4XTC6LIrsdDZ6pkd9uhGQOrCuJ1F0WN5A7Q8H+ONWPIILpLZWoJts+/UY5Cf63KWlK9oZiZ+jMcNobk7imcQs1d6DANkKEOsvLBMNCEhwkZBFApd2emYmOCpk/SkaVgsmL7gNDK+NOU6vy7DjtLgWTqM870T+CmvkR9401WGbJToDinF+oswII0ygRu74x3vWAeOzrjsvmxrHXe4d2Thxke79Ihvl4VOyhtYEyQQTKEUiKCpGDpMp5UP7Vla6iaYgq4vup0tr+fP49dpMaRu2hKSnrTQvX5ggfQRxl8TIJeRe+ELX7i+aVBmFMQNqWsE++7tnGgMeV4wua3cmeJ63bXNUQcZIhve6kSelbS1Cuv0aoE1tOdZ5UNDaCE0oPlS5WoUrJaZx6/TQhbC5EH49/ZhXD87Ii99DGCRtBB7WzeibRx6O1yJ7Sx/72hd7MIxpftm7Pu2X+KYLTEAXPva165FmIGh94cMnuVVW1kTInwwix53NtgorWHTmQGkUQhstL4YD6MunUp6xyzajsy7y/Oe97xaswTKdkuDf2ccMpHPNlieqzT6bQRnMY6rlR6fLzaTnvOc59SC72Kbra96aR9f51XSbFLIU0ZIAZ3CdB5NwM2Un0YTBDxLE2Aj9QlvilNktnjKxJiQ8kFvgwEF9Z3MWpQZlEzSKT1t2lD4KzSu0nBRZp98ZWMQsfS8FJLDthydd40uj2eyqMsFVpp/ogzxNBojQYOwXvn16CgsafPKR+h0hPAU6PTSHxK0L5dPEZQjhE9cFuVSSvg5HYX8op/y8pEf8FDOjLXwevu1i0LjoY4y4RnDhObSGCC8AnJElzEArLS11meO6XFYr/xm6FUB5pYXoOdThsXddtfi5zjbdpKiKILyA/WkcRee5Qn26hSEJ6VwJVF+6mnHTDBj9txzz3IfkDKRR9zlDQ1RuqMWGwGGkA9i9SfzJMyC0OMQzCofLIs2gijQEbQbGb4Xcym2mnywPbwZa3RTvjqUS8m2jPm+7EudsyH+3U+ruJAoDrQH2rL4+qGiywV8vDxlUwZmyas++aw9vs7lO0MvX1zCbJLY6ITA87zysCgapHVap4wsad4+fa92ycs3Ap8/jVbp8dnKURj/7q/M+FZtV8OFMIB8dfCZJo9j82c84xlF+2UQY5ChGyExRF6DgPJ9mrWmOMTM7qrzhxV6m5CCzoHnFJCWBntZ+WLYERpPz4kTprUH8dtoU/xhD3tYXbr1occ3Y7eh86tPZQV8wHV17sDxg/o5A6LU+Hvo7SnjYpjLBuBjDdfGwMC1KYuvQPmC4w5/V88Mcy5FVrMXwj/tbTnooIO2Pa0iAkMKRiBxnmER9Li99cp3mnvx53H87QiLtWvz1gmjnUKcX0VJto3OfIxMs4arokgj08UwP+JgMO4ubYgjn5mkjrYg3yPw11a2nV/60pfqncGdqfwCFa2M8l1+zxUOPvjgNUZIoTQea3VlwaLocXvBRmi+XvA1znG5hdnVEzsa+S75eiFzIcAPF3MD3PqgX9yFY3G+nmEYAL/wT0yR3pwzqyiby5Nm1HNZFO3DVdwlXmJBGXXwFodvsOWQQw4pLXdlRzFiTFIBrdyiaPAsHbaHn6DzLvp66wWLH2XkvpC7QxZUriUKMjIp0RG7a5KUI29ae2J5Rn3P88xAYvzwYCgzLErvPIIx/629YcHzuFJo8Xo0Hp7TUARBE6znC+rM49fpcX3w7F3BMYJjA8owKhnANXdvvfwx10RBeIWHdwPvCpQbZUoP//5MsZ6jL4ii5XuWjhfEDaa9BEh/wmcyEyCNBimYtGn5YzoNQc+38FEOdzBpfEr9MZ0p7JmCKTJlxDprhNvpeBYb4X6aZEYY9V6cPKuLH5CTW/LR3zoij4LH7S+anqbPicYI1SuETtqs/GAeLTbqeic3Wp/QRrK4L5ryBYaleHlGM19tZshzvKFNrkleDMCo0hnGLT/GyCwL0n6wKDppPb9alQC9AGyWBmk9n/JMZcrqLyqwEf4WNQus0UyZ0NvD00yQp624i/h9eZA64mwvM6sYR51gnjywcNo/BJAQQTotFlTM8yxaUKfX10GK4Hu5iSgp+eP2xrRR7oTTwkpp43wjeOymuCWyyKNw5SJbZgGabJ7VU0c+dP6LpINx/oos25SZjGk0tAoVz6N7fRgvUmP+82iuwg4m7Uwr3xE6+QnT+MO4/DT+i6LB8zHyDz300MpFdCyS1hhoOOkbrW+0Gs3ckTfVzIaN1k/bGy0fLIuOMXp+PSVhLPAiaM9cQBa+pCUfZtFiSuffrQ1jA6xXHzbT3jJoYd3y/snUiJUWSfO53FH22dJ6PoE895jBvM06l48rE4J59RPQwri9cf2sC9YVyCKtXekwr/48GvAIn1n8VuTcJnwylkEDGsb5AvR8B2z+lI7zmp4ffuvVh0738mOaYgwQP9VykuqzpA2EoMx69efR4HlWfvK2HHbYYVVaZsfOogkBoSnFyaOXOruqnP9vtH6wUZqLc+bkXpTfQLiOw/15N3GE7V0Dtpd/jDGvfBkhCbHQouhgTCsngLw8i7kFl8Te+MY31l+E8ZLV88f8x/U3K5/2bIMd4vne0OEebQ7kYCP8x7G665UvSkYKLILOsw6a1hqVxs96jp/PHj71BccN6vhTlgwQfuGRgBasHzn3SfvhN40WQ/ioD35FBMkHRgjf1IdZNFB6jJZ4XD5l0vZKG2t91I7SUbQFzluyr0no3I7ILokQXEGvL/hGwD0408FDHsgD5SG0mPvIgtr5iafRMT6QR31/ywLSHtgSw3r8QqfsrPzk9QDberSCFA62lzYqMzL5dsfIvvs683fF0Lk95JghSH2x+rakDJU2ZrWnHMNRpAEQzCoPmWGMIXBHPkGCNrNTyuIM8/hB6KTNy++hjHP44YcvbE0Az0alUS7fWb/Pin4KC75IuarCGF7ALL7KBRRpdGZkQ29vHCsjqCeW1vlBT0tM+U52LcAM6Icj+bOhAX65ugLqSpsnDyPO0k/oMSo3wqfAZmgNeBYL0qJE6XYcvs/6vurH4Q7c3Pn0CdJZv0+ARrJ0o1o9s0Rdio1B40LiR8NfnBmQ9qVTRuoLkTWxtvzpA7FtKQPYEhv94PMk4BOeYggN8oU8w6zy4uhpFLYpMQU3SwtpCMb58bk+qlC+G8umPqO4M8QVOBtyJ8dfU8nvynTIOmKk2r/jC323EoPI8yxmLEZTjttJOkP0mPLzyxyK9+nTnVQf6BnFPaPex2n9h3n50+gxKv2II44obgp3bJQO42n58ihEx11DzygD09yv5RnEz1D9WeMxKPKSl7xk3fvxJw38pJXyKBZfxuVSMtqzzjAEo0c25c00vl6ebxvcoa9vvkdzlWjlfZ3zXRqffGeAWf1XDmblB718N8bECCkgU+JGafAcpuN8sVFrVPmjtEZ2NbpaPtBRxvC7NrcVuBFrBQWD2eDji5+/+lsU3IZZ5D/ZNruU5dpcR2ccOyu/wHd9EdyocPXRtXYvf9Ykd43cyPa/m5ALGA5fNHnGH3um6UP/5uWP48zijjKCTBUxqMRGi9Fh1NNCz6vvOwBFGXF+za9T8sMHHZ9udhilOs8ludrozqk/w8a1mEmMkA/44Do7I1A8d5K7PeAvB+DpmguYKW7t3fKWt6w/mxPlgxt5rs+Yla6vcEnanNc/oNTN5nuWFmxZWZy25axAxprMxgym5a9HcwOuoft5KqXarkKEEwiXxXcaHB0wDGX7dMmNUZQZ4jad/bx8b9p+Iuvv4DkA1B5FcmlGfn6q1WEQcGX+boYveH6/5m4r40mPnBB5g8i+mXz0TCN0ZUPoFJ6VH8yi+WG7H0pxO84fnY1gFBCkw5C6aCEzZQx8uCxl1LFGMDokbVZd+QxkjXFE4rqMK47+DjcDqNsVGJmC0MrARvMjVzdC5aTAtAalzcrfCE1JOuvN+WUve1n9pivlCAQE7b63I0pMZ8TqmTn45OyHq2Fo5QVGTXlQJ+2BttR1VdGf9AQG4A7lCepqo/dnTMNm6Q5tbJUhKJjn0IJCESYdmkeHT2Lgp+1u/OZLYAjgfqIsMcUCPhkx0qI8cXjHOL0dUCZyKOPZIAjCy60MfzXG7MwfjNWWOIFMeU4b6nd5lJHXZYDQ5AA8lEfneRu9dfg/zMM/68F+Qd4AAAAASUVORK5CYII=
@@.IMPORTANT
The widget is not yet compatible to 5.1 and newer. To fix it, edit [[$:/plugins/skeeve/newtiddler.js]] and change
* `type: "tw-navigate",`
** to `type: "tm-navigate",`
* `this.newtiddlerClass = "tw-newtiddler-button" +`
** to `this.newtiddlerClass = "tm-newtiddler-button" +`
* `this.dispatchEvent({type: "tw-edit-tiddler",`
** to `this.dispatchEvent({type: "tm-edit-tiddler",`
@@
This is a test for the highly experimental New-Tiddler-Button which allows to pre fill a skeleton tiddler with variable data.
The New-Tiddler-Button expects 2 parameters:
|Parameter |Mandatory |Explanation |h
|title |yes |the title of the new tiddler. Will get numbers appended |
|skeleton |yes |an existing tiddler which may contain variable placeholders |
|edit |no |This defines wether to open the new tiddler in edit mode. Must be one of "yes", "no", "show" or (not implemented yet) "inline". Defaults to "yes". |
The most important part lies in the skeleton! TiddlyWiki already can clone tiddlers, but you can't really prefill data of the newly created tiddler.
With `<$newtiddler>` you can put placeholders of the form `$(variable)$` ''anywhere'' in the tiddler and they will be replaced by the values of the variables set with the `<$set>` or `<$let>` widget. Please note: The placeholders can be ''anywhere''! In the tiddlers body, in fields, types, you name it…
The example skeleton used here looks like this:
|Property |Content |h
|title |skeleton 1 |
|text |This is some test: $(placeholder)$ |
|tags |$(tag1}$ |
|field1 |$(f1)$ |
|field2 |$(f2)$ |
If we now put this into our tiddler:
```
<$set name="f1" value=<<qualify "unique">> >
<$set name="f2" value="field-2">
<$set name="placeholder" value="pl1">
<$set name="tag1" value="testtag">
<$newtiddler title="test" skeleton="$:/plugins/skeeve/newtiddler/SkeletonExample">Create</$newtiddler>
</$set>
</$set>
</$set>
</$set>
```
We get a <$set name="f1" value=<<qualify "unique">> ><$set name="f2" value="field-2"><$set name="placeholder" value="pl1"><$set name="tag1" value="testtag"><$newtiddler title="test" skeleton="$:/plugins/skeeve/newtiddler/SkeletonExample">Create</$newtiddler></$set></$set></$set></$set> button.
Clicking it, will open a new tiddler with some values pre-filled.
The following tiddlers were imported:
# [[$:/plugins/ValdikSS/neocities]]
alert-background: #ffca13
alert-border: #ffca13
alert-highlight: <<colour primary>>
alert-muted-foreground: <<colour muted-foreground>>
background: #eae6e1
blockquote-bar: <<colour muted-foreground>>
button-background: <<colour page-background>>
button-foreground: <<colour primary>>
button-border: <<colour primary>>; border-radius: 2px; border-width: 1px; border-style: solid
code-background: <<colour page-background>>
code-border: <<colour page-background>>
code-foreground: <<colour muted-foreground>>
dirty-indicator: <<colour primary>>
download-background: #ffca13
download-foreground: <<colour background>>
dragger-background: <<colour foreground>>
dragger-foreground: <<colour background>>
dropdown-background: <<colour background>>
dropdown-border: <<colour background>>
dropdown-tab-background-selected: <<colour background>>
dropdown-tab-background: <<colour background>>
dropzone-background: <<colour primary>>
external-link-background-hover: inherit
external-link-background-visited: inherit
external-link-background: inherit
external-link-foreground-hover: inherit
external-link-foreground-visited: #9e6129
external-link-foreground: <<colour primary>>
foreground: #433f36
message-background: #9e6129
message-border: #9e6129
message-foreground: <<colour foreground>>
modal-backdrop: <<colour foreground>>
modal-background: <<colour background>>
modal-border: <<colour background>>
modal-footer-background: <<colour background>>
modal-footer-border: <<colour foreground>>
modal-header-border: <<colour muted-foreground>>
muted-foreground: #737373
notification-background: #ffca13
notification-border: #ffca13
page-background: #cfcdcd
pre-background: <<colour page-background>>
pre-border: <<colour page-background>>
primary: #2d539b
sidebar-button-foreground: <<colour primary>>
sidebar-controls-foreground-hover: inherit
sidebar-controls-foreground: <<colour muted-foreground>>
sidebar-foreground-shadow: #d8d8d8
sidebar-foreground: <<colour primary>>
sidebar-muted-foreground-hover: inherit
sidebar-muted-foreground: <<colour muted-foreground>>
sidebar-tab-background-selected: <<colour page-background>>
sidebar-tab-background: transparent
sidebar-tab-border-selected: rgba(0,0,0,0.15)
sidebar-tab-border: transparent
sidebar-tab-divider: ; margin-top: -1.5px;
sidebar-tab-foreground-selected: <<colour foreground>>
sidebar-tab-foreground: <<colour muted-foreground>>
sidebar-tiddler-link-foreground-hover: inherit
sidebar-tiddler-link-foreground: <<colour muted-foreground>>
site-title-foreground: <<colour foreground>>
static-alert-foreground: <<colour foreground>>
tab-background-selected: <<colour background>>
tab-background: transparent
tab-border-selected: <<colour page-background>>
tab-border: transparent
tab-divider: <<colour page-background>>
tab-foreground-selected: <<colour foreground>>
tab-foreground: <<colour muted-foreground>>
table-border: <<colour page-background>>
table-footer-background: <<colour page-background>>
table-header-background: <<colour page-background>>
tag-background: #ffca13
tag-foreground: <<colour primary>>
tiddler-background: <<colour background>>
tiddler-border: <<colour background>>
tiddler-controls-foreground-hover: inherit
tiddler-controls-foreground-selected: inherit
tiddler-controls-foreground: #a28f86
tiddler-editor-background: <<colour background>>
tiddler-editor-border-image: <<colour background>>
tiddler-editor-border: rgba(0,0,0,0.12)
tiddler-editor-fields-even: rgba(0,0,0,0.04)
tiddler-editor-fields-odd: rgba(0,0,0,0.08)
tiddler-info-background: <<colour background>>
tiddler-info-border: <<colour page-background>>
tiddler-info-tab-background: <<colour background>>
tiddler-link-background: <<colour background>>
tiddler-link-foreground: <<colour primary>>
tiddler-subtitle-foreground: <<colour muted-foreground>>
tiddler-title-foreground: <<colour primary>>
toolbar-new-button:
toolbar-options-button:
toolbar-save-button:
toolbar-info-button:
toolbar-edit-button:
toolbar-close-button:
toolbar-delete-button:
toolbar-cancel-button:
toolbar-done-button:
untagged-background: #c0bbb6
very-muted-foreground: #898989
alert-background: #644a7d
alert-border: #644a7d
alert-highlight: <<colour primary>>
alert-muted-foreground: <<colour muted-foreground>>
background: #2A2B30
blockquote-bar: <<colour muted-foreground>>
button-background: <<colour page-background>>
button-foreground: <<colour foreground>>
button-border: <<colour tag-background>>; border-radius: 2px; border-width: 1px; border-style: solid
code-background: <<colour page-background>>
code-border: <<colour page-background>>
code-foreground: <<colour muted-foreground>>
dirty-indicator: <<colour primary>>
download-background: #644a7d
download-foreground: <<colour background>>
dragger-background: <<colour foreground>>
dragger-foreground: <<colour background>>
dropdown-background: <<colour background>>
dropdown-border: <<colour background>>
dropdown-tab-background-selected: <<colour background>>
dropdown-tab-background: <<colour background>>
dropzone-background: <<colour primary>>
external-link-background-hover: inherit
external-link-background-visited: inherit
external-link-background: inherit
external-link-foreground-hover: inherit
external-link-foreground-visited: #644a7d
external-link-foreground: <<colour primary>>
foreground: rgba(255,255,255,0.67)
message-background: #644a7d
message-border: #644a7d
message-foreground: <<colour foreground>>
modal-backdrop: <<colour page-background>>
modal-background: <<colour background>>
modal-border: <<colour background>>
modal-footer-background: <<colour background>>
modal-footer-border: <<colour muted-foreground>>
modal-header-border: <<colour muted-foreground>>
muted-foreground: rgba(255,255,255,0.54)
notification-background: #644a7d
notification-border: #644a7d
page-background: #1c1d22
pre-background: <<colour page-background>>
pre-border: <<colour page-background>>
primary: #c80000
sidebar-button-foreground: <<colour foreground>>
sidebar-controls-foreground-hover: inherit
sidebar-controls-foreground: <<colour muted-foreground>>
sidebar-foreground-shadow: transparent
sidebar-foreground: <<colour foreground>>
sidebar-muted-foreground-hover: inherit
sidebar-muted-foreground: <<colour foreground>>
sidebar-tab-background-selected: <<colour page-background>>
sidebar-tab-background: transparent
sidebar-tab-border-selected: <<colour primary>>
sidebar-tab-border: transparent
sidebar-tab-divider: <<colour primary>> !important; margin-top: -1.5px; width: 80%;
sidebar-tab-foreground-selected: #ff5555
sidebar-tab-foreground: <<colour muted-foreground>>
sidebar-tiddler-link-foreground-hover: inherit
sidebar-tiddler-link-foreground: <<colour muted-foreground>>
site-title-foreground: white
static-alert-foreground: <<colour foreground>>
tab-background-selected: <<colour background>>
tab-background: transparent
tab-border-selected: <<colour primary>>
tab-border: transparent
tab-divider: <<colour primary>>
tab-foreground-selected: <<colour sidebar-tab-foreground-selected>>
tab-foreground: <<colour muted-foreground>>
table-border: <<colour page-background>>
table-footer-background: rgba(0, 0, 0, 0.2)
table-header-background: rgba(0, 0, 0, 0.1)
tag-background: #644a7d
tag-foreground: <<colour foreground>>
tiddler-background: <<colour background>>
tiddler-border: <<colour background>>
tiddler-controls-foreground-hover: inherit
tiddler-controls-foreground-selected: <<colour foreground>>
tiddler-controls-foreground: #6b6b6b
tiddler-editor-background: <<colour background>>
tiddler-editor-border-image: <<colour background>>
tiddler-editor-border: rgba(255,255,255,0.1)
tiddler-editor-fields-even: #3a3a3a
tiddler-editor-fields-odd: <<colour page-background>>
tiddler-info-background: <<colour background>>
tiddler-info-border: <<colour page-background>>
tiddler-info-tab-background: <<colour background>>
tiddler-link-background: <<colour background>>
tiddler-link-foreground: <<colour primary>>
tiddler-subtitle-foreground: <<colour muted-foreground>>
tiddler-title-foreground: <<colour primary>>
toolbar-new-button:
toolbar-options-button:
toolbar-save-button:
toolbar-info-button:
toolbar-edit-button:
toolbar-close-button:
toolbar-delete-button:
toolbar-cancel-button:
toolbar-done-button:
untagged-background: #644a7d
very-muted-foreground: rgba(255,255,255,0.2)
alert-background: <<colour tag-background>>
alert-border: <<colour tag-background>>
alert-highlight: <<colour primary>>
alert-muted-foreground: <<colour muted-foreground>>
background: #fbfbfb
blockquote-bar: <<colour muted-foreground>>
button-background: <<colour page-background>>
button-foreground: <<colour primary>>
button-border: <<colour primary>>; border-radius: 2px; border-width: 1px; border-style: solid
code-background: <<colour page-background>>
code-border: <<colour page-background>>
code-foreground: <<colour muted-foreground>>
dirty-indicator: <<colour primary>>
download-background: <<colour tag-background>>
download-foreground: <<colour background>>
dragger-background: <<colour foreground>>
dragger-foreground: <<colour background>>
dropdown-background: <<colour background>>
dropdown-border: <<colour background>>
dropdown-tab-background-selected: <<colour background>>
dropdown-tab-background: <<colour background>>
dropzone-background: <<colour primary>>
external-link-background-hover: inherit
external-link-background-visited: inherit
external-link-background: inherit
external-link-foreground-hover: inherit
external-link-foreground-visited: #237544
external-link-foreground: #40EFF2
foreground: #38363B
message-background: #D7DCDF
message-border: #D7DCDF
message-foreground: <<colour foreground>>
modal-backdrop: <<colour foreground>>
modal-background: <<colour background>>
modal-border: <<colour background>>
modal-footer-background: <<colour background>>
modal-footer-border: <<colour muted-foreground>>
modal-header-border: <<colour muted-foreground>>
muted-foreground: #868686
notification-background: <<colour tag-background>>
notification-border: <<colour tag-background>>
page-background: #ebeeef
pre-background: <<colour page-background>>
pre-border: <<colour page-background>>
primary: #237544
sidebar-button-foreground: <<colour primary>>
sidebar-controls-foreground-hover: inherit
sidebar-controls-foreground: <<colour muted-foreground>>
sidebar-foreground-shadow: transparent
sidebar-foreground: <<colour primary>>
sidebar-muted-foreground-hover: inherit
sidebar-muted-foreground: <<colour muted-foreground>>
sidebar-tab-background-selected: <<colour page-background>>
sidebar-tab-background: transparent
sidebar-tab-border-selected: rgba(0,0,0,0.15)
sidebar-tab-border: transparent
sidebar-tab-divider: ; margin-top: -1.5px;
sidebar-tab-foreground-selected: <<colour foreground>>
sidebar-tab-foreground: <<colour muted-foreground>>
sidebar-tiddler-link-foreground-hover: inherit
sidebar-tiddler-link-foreground: <<colour muted-foreground>>
site-title-foreground: <<colour foreground>>
static-alert-foreground: <<colour foreground>>
tab-background-selected: <<colour background>>
tab-background: transparent
tab-border-selected: <<colour page-background>>
tab-border: transparent
tab-divider: <<colour page-background>>
tab-foreground-selected: <<colour foreground>>
tab-foreground: <<colour muted-foreground>>
table-border: <<colour page-background>>
table-footer-background: <<colour page-background>>
table-header-background: <<colour page-background>>
tag-background: #94DC20
tag-foreground: <<general primary>>
tiddler-background: <<colour background>>
tiddler-border: <<colour background>>
tiddler-controls-foreground-hover: <<colour tag-background>>
tiddler-controls-foreground-selected: inherit
tiddler-controls-foreground: #697c69
tiddler-editor-background: <<colour background>>
tiddler-editor-border-image: <<colour background>>
tiddler-editor-border: rgba(0,0,0,0.12)
tiddler-editor-fields-even: rgba(0,0,0,0.08)
tiddler-editor-fields-odd: rgba(0,0,0,0.04)
tiddler-info-background: <<colour background>>
tiddler-info-border: <<colour page-background>>
tiddler-info-tab-background: <<colour background>>
tiddler-link-background: <<colour background>>
tiddler-link-foreground: <<colour primary>>
tiddler-subtitle-foreground: <<colour muted-foreground>>
tiddler-title-foreground: <<colour primary>>
toolbar-new-button:
toolbar-options-button:
toolbar-save-button:
toolbar-info-button:
toolbar-edit-button:
toolbar-close-button:
toolbar-delete-button:
toolbar-cancel-button:
toolbar-done-button:
untagged-background: #d2cfcc
very-muted-foreground: #a3a3a3
alert-background: #644a7d
alert-border: #644a7d
alert-highlight: <<colour primary>>
alert-muted-foreground: <<colour muted-foreground>>
background: #2A2B30
blockquote-bar: <<colour muted-foreground>>
button-background: <<colour page-background>>
button-foreground: <<colour foreground>>
button-border: <<colour tag-background>>; border-radius: 2px; border-width: 1px; border-style: solid
code-background: <<colour page-background>>
code-border: <<colour page-background>>
code-foreground: <<colour muted-foreground>>
dirty-indicator: <<colour primary>>
download-background: #644a7d
download-foreground: <<colour background>>
dragger-background: <<colour foreground>>
dragger-foreground: <<colour background>>
dropdown-background: <<colour background>>
dropdown-border: <<colour background>>
dropdown-tab-background-selected: <<colour background>>
dropdown-tab-background: <<colour background>>
dropzone-background: <<colour primary>>
external-link-background-hover: inherit
external-link-background-visited: inherit
external-link-background: inherit
external-link-foreground-hover: inherit
external-link-foreground-visited: <<colour tag-background>>
external-link-foreground: #f0b000
foreground: rgba(255,255,255,0.87)
message-background: #644a7d
message-border: #644a7d
message-foreground: <<colour foreground>>
modal-backdrop: <<colour page-background>>
modal-background: <<colour background>>
modal-border: <<colour background>>
modal-footer-background: <<colour background>>
modal-footer-border: <<colour background>>
modal-header-border: <<colour muted-foreground>>
muted-foreground: rgba(255,255,255,0.5)
notification-background: #644a7d
notification-border: #644a7d
page-background: #1c1d22
pre-background: <<colour page-background>>
pre-border: <<colour page-background>>
primary: #00a9c7
sidebar-button-foreground: <<colour foreground>>
sidebar-controls-foreground-hover: inherit
sidebar-controls-foreground: <<colour muted-foreground>>
sidebar-foreground-shadow: transparent
sidebar-foreground: <<colour foreground>>
sidebar-muted-foreground-hover: inherit
sidebar-muted-foreground: <<colour foreground>>
sidebar-tab-background-selected: <<colour page-background>>
sidebar-tab-background: transparent
sidebar-tab-border-selected: <<colour primary>>
sidebar-tab-border: transparent
sidebar-tab-divider: <<colour primary>> !important; margin-top: -1.5px; width: 80%;
sidebar-tab-foreground-selected: <<colour primary>>
sidebar-tab-foreground: <<colour muted-foreground>>
sidebar-tiddler-link-foreground-hover: inherit
sidebar-tiddler-link-foreground: <<colour muted-foreground>>
site-title-foreground: white
static-alert-foreground: <<colour foreground>>
tab-background-selected: <<colour background>>
tab-background: transparent
tab-border-selected: <<colour primary>>
tab-border: transparent
tab-divider: <<colour primary>>
tab-foreground-selected: <<colour primary>>
tab-foreground: <<colour muted-foreground>>
table-border: <<colour page-background>>
table-footer-background: rgba(0, 0, 0, 0.1)
table-header-background: rgba(0, 0, 0, 0.2)
tag-background: #8a6ca8
tag-foreground: <<colour foreground>>
tiddler-background: <<colour background>>
tiddler-border: <<colour background>>
tiddler-controls-foreground-hover: inherit
tiddler-controls-foreground-selected: <<colour foreground>>
tiddler-controls-foreground: #6b6b6b
tiddler-editor-background: <<colour background>>
tiddler-editor-border-image: <<colour background>>
tiddler-editor-border: rgba(255,255,255,0.1)
tiddler-editor-fields-even: #3a3a3a
tiddler-editor-fields-odd: <<colour page-background>>
tiddler-info-background: <<colour background>>
tiddler-info-border: <<colour page-background>>
tiddler-info-tab-background: <<colour background>>
tiddler-link-background: <<colour background>>
tiddler-link-foreground: <<colour primary>>
tiddler-subtitle-foreground: <<colour muted-foreground>>
tiddler-title-foreground: <<colour primary>>
toolbar-new-button:
toolbar-options-button:
toolbar-save-button:
toolbar-info-button:
toolbar-edit-button:
toolbar-close-button:
toolbar-delete-button:
toolbar-cancel-button:
toolbar-done-button:
untagged-background: #3a3a3a
very-muted-foreground: rgba(255,255,255,0.2)
<$action-setfield $tiddler="$:/state/header-searchbar" text="open"/>
<$action-setfield $tiddler="$:/state/sidebar" text="no"/>
\define macroName(param1:"default value",param2)
Text of the macro
\end
|! |!Alpha |!Beta |!Gamma |!Delta |
|!One | | | | |
|!Two | | | | |
|!Three | | | | |
\define ref(label)
<$button popup="$:/state/$label$" class="tc-btn-invisible tc-slider"><sup style="color:green">$label$</sup></$button>
\end
\define definition(label,text)
<$reveal type="popup" state="$:/state/$label$" animate="yes">
<div class="tc-drop-down">
<dl>
<dt>$label$</dt>
<dd>$text$</dd>
</dl>
</div>
</$reveal>
\end
\define footnote(label,text)
<<ref "$label$">>
<<definition "$label$" "$text$">>
\end
\define footnotes(label,text)
<<definition "$label$" "$text$">>
<sub><span style="color:green">$label$ : </span> $text$</sub>
\end
/*\
title: $:/macros/skeeve/rojo.js
type: application/javascript
module-type: macro
\*/
(function(){
/*jslint node: true, browser: true */
/*global $tw: false */
"use strict";
/*
Information about this macro
This is developed to put some text in red.
*/
exports.name = "rojo";
exports.params = [
{ name: "textToColorize" }
];
/*
Run the macro
*/
exports.run = function(textToColorize) {
if( !textToColorize) textToColorize = "IMPORTANT";
return spanize(textToColorize,"red");
function spanize(texto,color){
return "<span style='color:" + color + "'>" + texto + "</span>";
}
};
})();
\define searchInField(field, for, ci)
<$list filter="[!is[shadow]!is[system]regexp:$field$[$for$$ci$]limit[1]]">
<dt>$field$</dt>
</$list>
<$list filter="[!is[shadow]!is[system]regexp:$field$[$for$$ci$]]">
<dd><$link><$view field="title"/></$link></dd>
</$list>
\end
<style>.tc-advanced-search-check imput {width:auto !important;}</style>
Search in fields:
<span class="tc-advanced-search-check"><$checkbox field="case-insensitive" tiddler="$:/temp/advancedsearch" checked="(?i)"> case insensitive</$checkbox></span>
<div class="tc-search">
<$edit-text tiddler="$:/temp/advancedsearch" type="search" tag="input"/> <$select field="field" tiddler="$:/temp/advancedsearch" default="">
<option value="">*any</option>
<$list filter="[!is[shadow]!is[system]fields[]sort[]]" variable="field">
<option value=<<field>>><<field>></option>
</$list>
</$select>
<$reveal state="$:/temp/advancedsearch" type="nomatch" text="">
<$button class="tc-btn-invisible">
<$action-setfield $tiddler="$:/temp/advancedsearch" $field="text" $value=""/>
{{$:/core/images/close-button}}
</$button>
</$reveal>
</div>
<$reveal state="$:/temp/advancedsearch" type="nomatch" text="">
<$reveal state="$:/temp/advancedsearch!!field" type="match" text="">
<dl>
<$list filter="[!is[shadow]!is[system]fields[]]" variable="field">
<$reveal type=nomatch text=text default=<<field>>>
<$macrocall $name="searchInField" field=<<field>> for={{$:/temp/advancedsearch}} ci={{$:/temp/advancedsearch!!case-insensitive}}/>
</$reveal>
</$list>
</dl>
</$reveal>
<$reveal state="$:/temp/advancedsearch!!field" type="nomatch" text="">
<dl>
<$macrocall $name="searchInField" field={{$:/temp/advancedsearch!!field}} for={{$:/temp/advancedsearch}} ci={{$:/temp/advancedsearch!!case-insensitive}}/>
</dl>
</$reveal>
</$reveal>
\define lingo-base() $:/language/Manager/
\define list-item-content-item()
<div class="tc-manager-list-item-content-item">
<$vars state-title="""$:/state/popup/manager/item/$(listItem)$""">
<$reveal state=<<state-title>> type="match" text="show" default="show" tag="div">
<$button set=<<state-title>> setTo="hide" class="tc-btn-invisible tc-manager-list-item-content-item-heading">
{{$:/core/images/down-arrow}} <$transclude tiddler=<<listItem>> field="caption"/>
</$button>
</$reveal>
<$reveal state=<<state-title>> type="nomatch" text="show" default="show" tag="div">
<$button set=<<state-title>> setTo="show" class="tc-btn-invisible tc-manager-list-item-content-item-heading">
{{$:/core/images/right-arrow}} <$transclude tiddler=<<listItem>> field="caption"/>
</$button>
</$reveal>
<$reveal state=<<state-title>> type="match" text="show" default="show" tag="div" class="tc-manager-list-item-content-item-body">
<$transclude tiddler=<<listItem>>/>
</$reveal>
</$vars>
</div>
\end
<div class="tc-manager-wrapper">
<div class="tc-manager-controls">
<div class="tc-manager-control">
<<lingo Controls/Show/Prompt>> <$select tiddler="$:/config/Manager/Show" default="tiddlers">
<option value="tiddlers"><<lingo Controls/Show/Option/Tiddlers>></option>
<option value="tags"><<lingo Controls/Show/Option/Tags>></option>
</$select>
</div>
<div class="tc-manager-control">
<<lingo Controls/Search/Prompt>> <$edit-text tiddler="$:/config/Manager/Filter" tag="input" default="" placeholder={{$:/language/Manager/Controls/Search/Placeholder}}/>
</div>
<div class="tc-manager-control">
<<lingo Controls/FilterByTag/Prompt>> <$select tiddler="$:/config/Manager/Tag" default="">
<option value=""><<lingo Controls/FilterByTag/None>></option>
<$list filter="[!is{$:/config/Manager/System}tags[]!is[system]sort[title]]" variable="tag">
<option value=<<tag>>><$text text=<<tag>>/></option>
</$list>
</$select>
</div>
<div class="tc-manager-control">
<<lingo Controls/Sort/Prompt>> <$select tiddler="$:/config/Manager/Sort" default="title">
<optgroup label="Common">
<$list filter="title modified modifier created creator created" variable="field">
<option value=<<field>>><$text text=<<field>>/></option>
</$list>
</optgroup>
<optgroup label="All">
<$list filter="[all{$:/config/Manager/Show}!is{$:/config/Manager/System}fields[]sort[title]] -title -modified -modifier -created -creator -created" variable="field">
<option value=<<field>>><$text text=<<field>>/></option>
</$list>
</optgroup>
</$select>
<$checkbox tiddler="$:/config/Manager/Order" field="text" checked="reverse" unchecked="forward" default="forward">
<<lingo Controls/Order/Prompt>>
</$checkbox>
</div>
<div class="tc-manager-control">
<$checkbox tiddler="$:/config/Manager/System" field="text" checked="" unchecked="system" default="system">
{{$:/language/SystemTiddlers/Include/Prompt}}
</$checkbox>
</div>
</div>
<div class="tc-manager-list">
<$list filter="[all{$:/config/Manager/Show}!is{$:/config/Manager/System}search{$:/config/Manager/Filter}tag:strict{$:/config/Manager/Tag}sort{$:/config/Manager/Sort}order{$:/config/Manager/Order}]">
<$vars transclusion=<<currentTiddler>>>
<div style="tc-manager-list-item">
<$button popup=<<qualify "$:/state/manager/popup">> class="tc-btn-invisible tc-manager-list-item-heading" selectedClass="tc-manager-list-item-heading-selected">
<$text text=<<currentTiddler>>/>
</$button>
<$reveal state=<<qualify "$:/state/manager/popup">> type="nomatch" text="" default="" tag="div" class="tc-manager-list-item-content tc-popup-handle">
<div class="tc-manager-list-item-content-tiddler">
<$list filter="[all[shadows+tiddlers]tag[$:/tags/Manager/ItemMain]!has[draft.of]]" variable="listItem">
<<list-item-content-item>>
</$list>
</div>
<div class="tc-manager-list-item-content-sidebar">
<$list filter="[all[shadows+tiddlers]tag[$:/tags/Manager/ItemSidebar]!has[draft.of]]" variable="listItem">
<<list-item-content-item>>
</$list>
</div>
</$reveal>
</div>
</$vars>
</$list>
</div>
</div>
base03: #002b36
base02: #073642
base01: #586e75
base00: #657b83
base0: #839496
base1: #93a1a1
base2: #eee8d5
base3: #fdf6e3
yellow: #b58900
orange: #cb4b16
red: #dc322f
magenta: #d33682
violet: #6c71c4
blue: #268bd2
cyan: #2aa198
green: #a5415c
base10: #c0c4bb
violet-muted: #7c81b0
blue-muted: #3a4267
yellow-hot: #ffcc44
orange-hot: #eb6d20
red-hot: #ff2222
blue-hot: #2298ee
green-hot: #98ee22
background: #fdf6e3
download-foreground: <<colour background>>
dragger-foreground: <<colour background>>
dropdown-background: <<colour background>>
modal-background: <<colour background>>
sidebar-foreground-shadow: <<colour background>>
tiddler-background: <<colour background>>
tiddler-border: <<colour background>>
tiddler-link-background: <<colour background>>
tab-background-selected: <<colour background>>
dropdown-tab-background-selected: <<colour tab-background-selected>>
foreground: #657b83
dragger-background: <<colour foreground>>
tab-foreground: <<colour foreground>>
tab-foreground-selected: <<colour tab-foreground>>
sidebar-tab-foreground-selected: <<colour tab-foreground-selected>>
sidebar-tab-foreground: <<colour tab-foreground>>
sidebar-button-foreground: <<colour foreground>>
sidebar-controls-foreground: <<colour foreground>>
sidebar-foreground: <<colour foreground>>
alert-muted-foreground: <<colour base01>>
code-foreground: <<colour base00>>
message-foreground: <<colour base00>>
tag-foreground: <<colour base00>>
sidebar-tiddler-link-foreground: <<colour base0>>
muted-foreground: <<colour base1>>
blockquote-bar: <<colour muted-foreground>>
dropdown-border: <<colour muted-foreground>>
sidebar-muted-foreground: <<colour muted-foreground>>
tiddler-title-foreground: <<colour muted-foreground>>
site-title-foreground: <<colour tiddler-title-foreground>>
modal-footer-background: <<colour base2>>
page-background: <<colour base2>>
modal-backdrop: <<colour page-background>>
notification-background: <<colour page-background>>
code-background: <<colour page-background>>
code-border: <<colour code-background>>
pre-background: <<colour page-background>>
pre-border: <<colour pre-background>>
sidebar-tab-background-selected: <<colour page-background>>
table-header-background: <<colour base2>>
tag-background: <<colour base2>>
tiddler-editor-background: <<colour base2>>
tiddler-info-background: <<colour base2>>
tiddler-info-tab-background: <<colour base2>>
tab-background: <<colour base2>>
dropdown-tab-background: <<colour tab-background>>
alert-background: <<colour base3>>
message-background: <<colour base3>>
alert-highlight: <<colour magenta>>
external-link-foreground: <<colour violet>>
tiddler-controls-foreground: <<colour base10>>
external-link-foreground-visited: <<colour violet-muted>>
primary: <<colour blue-muted>>
download-background: <<colour primary>>
tiddler-link-foreground: <<colour primary>>
alert-border: #b99e2f
dirty-indicator: #ff0000
dropzone-background: rgba(0,200,0,0.7)
external-link-background-hover: inherit
external-link-background-visited: inherit
external-link-background: inherit
external-link-foreground-hover: inherit
message-border: #cfd6e6
modal-border: #999999
select-tag-background:
select-tag-foreground:
sidebar-controls-foreground-hover:
sidebar-muted-foreground-hover:
sidebar-tab-background: #ded8c5
sidebar-tiddler-link-foreground-hover:
static-alert-foreground: #aaaaaa
tab-border: #cccccc
modal-footer-border: <<colour tab-border>>
modal-header-border: <<colour tab-border>>
notification-border: <<colour tab-border>>
sidebar-tab-border: <<colour tab-border>>
tab-border-selected: <<colour tab-border>>
sidebar-tab-border-selected: <<colour tab-border-selected>>
tab-divider: #d8d8d8
sidebar-tab-divider: <<colour tab-divider>>
table-border: #dddddd
table-footer-background: #a8a8a8
tiddler-controls-foreground-hover: #888888
tiddler-controls-foreground-selected: #444444
tiddler-editor-border-image: #ffffff
tiddler-editor-border: #cccccc
tiddler-editor-fields-even: #e0e8e0
tiddler-editor-fields-odd: #f0f4f0
tiddler-info-border: #dddddd
tiddler-subtitle-foreground: #c0c0c0
toolbar-new-button:
toolbar-options-button:
toolbar-save-button:
toolbar-info-button:
toolbar-edit-button:
toolbar-close-button:
toolbar-delete-button:
toolbar-cancel-button:
toolbar-done-button:
untagged-background: #999999
very-muted-foreground: #888888
<$set name="pluginPrefix" value="$:/themes/jd/Material" >
<$set name="currentTiddler" value="$:/plugins/ahahn/tinka/temp/$:/themes/jd/Material - Help Tab" >
<$transclude tiddler="$:/plugins/ahahn/tinka/pluginSidePanel" />
</$set>
</$set>
{
"tiddlers": {
"$:/language/Buttons/Choose/Caption": {
"text": "choose",
"title": "$:/language/Buttons/Choose/Caption"
},
"$:/language/Buttons/Choose/Hint": {
"text": "Add to favorites list",
"title": "$:/language/Buttons/Choose/Hint"
},
"$:/language/Buttons/Favorites/Caption": {
"text": "favorite",
"title": "$:/language/Buttons/Favorites/Caption"
},
"$:/language/Buttons/Favorites/Hint": {
"text": "Remove from favorites list",
"title": "$:/language/Buttons/Favorites/Hint"
},
"$:/language/SideBar/Favorites/Caption": {
"text": "Favorites",
"title": "$:/language/SideBar/Favorites/Caption"
},
"$:/plugins/ajh/favorites/icon": {
"text": "\\define my-svg()\n<svg class='tc-image-favorites tc-image-button' width='22pt' height='22pt' viewBox='0 0 192 192'><path fill='#f08' stroke='#30f' stroke-width='7.5' d='m13.5,52.2l82.5,-48l82.5,48v87.3l-82.5,48l-82.5,-48v-87.3z'/><path fill='#ff0' stroke='#f90' stroke-width='5' d='m$(m)$$(path)$'/></g></svg>\n\\end\n\n<$vars m='96,122' path={{$:/plugins/ajh/favorites/image!!path}}>\n<<my-svg>>\n</$vars>",
"title": "$:/plugins/ajh/favorites/icon",
"tags": "$:/tags/Image"
},
"$:/plugins/ajh/favorites/readme": {
"text": "This plugin adds the <$list filter='[<tv-config-toolbar-icons>prefix[yes]]'><span class='tc-btn-dropdown'>{{$:/core/images/star-filled}}</span></$list> <$list filter='[<tv-config-toolbar-text>prefix[yes]]'>{{$:/language/Buttons/Choose/Caption}}</$list> button to the View Toolbar and also the <span class='tc-favorites'>{{$:/core/images/star-filled}}</span> tab to the Sidebar. The button becomes <$list filter='[<tv-config-toolbar-icons>prefix[yes]]'><span class='tc-favorites'>{{$:/core/images/star-filled}}</span></$list> <$list filter='[<tv-config-toolbar-text>prefix[yes]]'>{{$:/language/Buttons/Favorites/Caption}}</$list> when selected and then the tiddler appears in the list on the <span class='tc-favorites'>{{$:/core/images/star-filled}}</span> tab. The list can be sorted using drag and drop. To drag an item, select it, then hold down the mouse or track-pad button while you drag it to a new location in the list. Release the button to drop the item into place. Unneeded favorites can be removed from the list by using the <$list filter='[<tv-config-toolbar-icons>prefix[yes]]'><span class='tc-favorites'>{{$:/core/images/star-filled}}</span></$list> <$list filter='[<tv-config-toolbar-text>prefix[yes]]'>{{$:/language/Buttons/Favorites/Caption}}</$list> button in the tiddler.\n\nSimply drag $:/plugins/ajh/favorites to the top of your tiddlywiki display, save and reload.\n\nThis plugin comprises:\n\n* Icon\n* Template\n* Stylesheet\n* Sidebar tab\n* Caption and hint",
"title": "$:/plugins/ajh/favorites/readme"
},
"$:/plugins/ajh/favorites/SideBar": {
"text": "\\define drop-actions()\n<$action-listops $tiddler='$:/plugins/ajh/favorites/list' $subfilter='+[insertbefore:currentTiddler<actionTiddler>]'/>\n\\end\n\n<$list filter='[list[$:/plugins/ajh/favorites/list]]'>\n<div style='position: relative;'>\n<$droppable actions=<<drop-actions>>>\n<div class='tc-droppable-placeholder'>\n \n</div>\n<div>\n <$link to={{!!title}}>\n<$view field='caption'><$view field='title'/></$view></$link>\n</div>\n</$droppable>\n</div>\n</$list>\n",
"title": "$:/plugins/ajh/favorites/SideBar",
"tags": "$:/tags/SideBar",
"list-before": "",
"caption": "<span class='tc-tab-buttons' title={{$:/language/SideBar/Favorites/Caption}}>{{$:/plugins/ajh/favorites/image}}</span><span class='tc-favorites-hidden'>{{$:/language/SideBar/Favorites/Caption}}</span>"
},
"$:/plugins/ajh/favorites/template": {
"text": "\\define add() [[$(currentTiddler)$]]\n\\define remove() -[[$(currentTiddler)$]]\n\\define my-svg()\n<svg class='tc-image-favorites tc-image-button' width='22pt' height='22pt' viewBox='0 0 128 128'><path fill='$(fill)$' stroke='$(stroke)$' stroke-width='5' d='m$(m)$$(path)$'/></g></svg>\n\\end\n\n<$list filter='[list[$:/plugins/ajh/favorites/list]is[current]]'><$button tooltip={{$:/language/Buttons/Favorites/Hint}} aria-label={{$:/language/Buttons/Favorites/Caption}} class=<<tv-config-toolbar-class>>>\n<$action-listops $tiddler='$:/plugins/ajh/favorites/list' $field='list' $subfilter=<<remove>>/>\n<$list filter='[<tv-config-toolbar-icons>prefix[yes]]'>\n<$vars fill={{$:/plugins/ajh/favorites/stylesheet!!button-color}} stroke={{$:/plugins/ajh/favorites/stylesheet!!button-outline-color}} m='64,96.1' path={{$:/plugins/ajh/favorites/image!!path}}>\n<<my-svg>>\n</$vars>\n</$list>\n<$list filter='[<tv-config-toolbar-text>prefix[yes]]'>\n<span class='tc-btn-text'>\n<$text text={{$:/language/Buttons/Favorites/Caption}}/>\n</span>\n</$list>\n</$button></$list><$list filter='[all[current]!list[$:/plugins/ajh/favorites/list]]'><$button tooltip={{$:/language/Buttons/Choose/Hint}} aria-label={{$:/language/Buttons/Choose/Caption}} class=<<tv-config-toolbar-class>>>\n<$action-listops $tiddler='$:/plugins/ajh/favorites/list' $field='list' $subfilter=<<add>>/>\n<$list filter='[<tv-config-toolbar-icons>prefix[yes]]'>\n{{$:/core/images/star-filled}}\n</$list>\n<$list filter='[<tv-config-toolbar-text>prefix[yes]]'>\n<span class='tc-btn-text'>\n<$text text={{$:/language/Buttons/Choose/Caption}}/>\n</span>\n</$list>\n</$button></$list>",
"title": "$:/plugins/ajh/favorites/template",
"tags": "$:/tags/ViewToolbar",
"list-after": "$:/core/ui/Buttons/more-tiddler-actions",
"description": "{{$:/language/Buttons/Favorites/Hint}}",
"caption": "{{ $:/core/images/star-filled}} {{$:/language/Buttons/Favorites/Caption}}"
},
"$:/plugins/ajh/favorites/stylesheet": {
"text": ".tc-tab-buttons + .tc-favorites-hidden {\n display: none;\n}\n.tc-tab-buttons button.tc-tab-selected {\n fill: {{!!tab-icon-selected-color}};\n stroke: {{!!tab-icon-outline-color}}; \n}\n.tc-tab-buttons button:not(.tc-tab-selected) {\n fill: {{!!tab-icon-unselected-color}};\n}\n.tc-favorites {\n stroke: {{!!button-outline-color}};\n stroke-width:5;\n fill: {{!!button-color}};\n}\n.tc-image-star-filled {\n height:1em;\n width:1em;\n}",
"title": "$:/plugins/ajh/favorites/stylesheet",
"tags": "$:/tags/Stylesheet",
"tab-icon-unselected-color": "#999",
"tab-icon-selected-color": "#ff0",
"tab-icon-outline-color": "#000",
"caption": "Favorites",
"button-outline-color": "#000",
"button-color": "#ff0"
},
"$:/plugins/ajh/favorites/image": {
"text": "\\define my-svg()\n<svg class='tc-image-favorites tc-image-button' width='22pt' height='22pt' viewBox='0 0 128 128'><path stroke-width='5' d='m$(m)$$(path)$'/></svg>\n\\end\n\n<$vars m='64,96.1' path={{!!path}}>\n<<my-svg>>\n</$vars>",
"title": "$:/plugins/ajh/favorites/image",
"tags": "$:/tags/Image",
"path": "l32.7,24.2c2.4,1.7 5.6,-0.6 4.6,-3.4l-12.4,-38.6l32.5,-23.8c2.4,-1.7 1.1,-5.5 -1.8,-5.5l-40.2,0l-12.5,-38.5c-0.9,-2.8 -4.8,-2.8 -5.8,0l-12.5,38.5l-40.2,0c-2.9,0 -4.2,3.8 -1.8,5.5l32.5,23.8l-12.4,38.6c-0.9,2.8 2.3,5.1 4.6,3.4l32.7,-24.2z"
}
}
}
<$button tooltip="Open MagicTabs dashboard" aria-label="Open MagicTabs dashboard" class=<<tv-config-toolbar-class>>>
<$action-navigate $to="MagicTabs"/>
<$list filter="[<tv-config-toolbar-icons>prefix[yes]]">
{{$:/plugins/amp/MagicTabs/images/magic}}
</$list>
<$list filter="[<tv-config-toolbar-text>prefix[yes]]">
<span class="tc-btn-text"><$text text="Open MagicTabs dashboard"/></span>
</$list>
</$button>
{
"tiddlers": {
"$:/plugins/amp/MagicTabs/images/info": {
"text": "<$reveal state=\"$:/plugins/TheDiveO/FontAwesome/fonts/FontAwesome!!modified\" type=\"nomatch\" text=\"\">\n+ <i class=\"fa fa-info\"></i>\n</$reveal>\n<$reveal state=\"$:/plugins/TheDiveO/FontAwesome/fonts/FontAwesome!!modified\" type=\"match\" text=\"\">\ninfo\n</$reveal>",
"created": "20141108172611187",
"creator": "Alberto Molina Pérez",
"title": "$:/plugins/amp/MagicTabs/images/info",
"modified": "20150129055334746",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common"
},
"$:/plugins/amp/MagicTabs/tabs/info": {
"created": "20141106161534068",
"creator": "Alberto Molina Pérez",
"text": "\\define mt-seek-children()\n<$list filter=\"[all[tiddlers]$(sourceField)$[$(storyTiddler)$]!is[system]!has[draft.of]sort[]]\">\n<$link><$transclude tiddler={{!!icon}}/><$view field=\"title\"/></$link><br>\n</$list>\n\\end\n\\define mt-seek-children-list()\n<$list filter=\"[all[current]listed[$(sourceFieldList)$]!is[system]!has[draft.of]sort[]]\">\n<$link><$transclude tiddler={{!!icon}}/><$view field=\"title\"/></$link><br>\n</$list>\n\\end\n\n\\define tabInfo()\n<div class=\"tc-menu-list-item\">\n<div class=\"text-grey\">\nChildren of this tiddler:\n</div>\n<div class=\"tc-menu-list-subitem\">\n<$list filter=\"[all[tiddlers]fields[]prefix[mt-source]!suffix[list]sort[]] -mt-source.root\" variable=\"sourceField\">\n<<mt-seek-children>>\n</$list>\n<$list filter=\"[all[tiddlers]fields[]prefix[mt-source]suffix[list]sort[]] -mt-source.root\" variable=\"sourceFieldList\">\n<<mt-seek-children-list>>\n</$list>\n\n<$list filter=\"[all[current]listed[mt-source.parents.list]] +[!is[system]!has[draft.of]]\" template={{$(currentTab)$!!mt-list.template}} emptyMessage=\"@@.text-grey none@@\"/>\n\n</div>\n\n<div class=\"text-grey\">\nAbout this tiddler:\n</div>\n<div class=\"tc-menu-list-subitem\">\n\n<$list filter=\"[all[current]listed[mt-topics.list]!is[system]!has[draft.of]]\" template={{$(currentTab)$!!mt-list.template}} emptyMessage=\"@@.text-grey none@@\"/>\n\n</div>\n\n<div class=\"text-grey\">\nTagging:\n</div>\n<div class=\"tc-menu-list-subitem\">\n\n<$list filter=\"[all[current]tagging[]!is[system]!has[draft.of]] -[[$(currentTiddler)$]]\" template={{$(currentTab)$!!mt-list.template}} emptyMessage=\"@@.text-grey none@@\"/>\n\n</div>\n</div>\n\\end\n\n<<tabInfo>>",
"caption": "{{$:/plugins/amp/MagicTabs/images/info}}",
"description": "Info",
"icon": "",
"modified": "20150308161544317",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/type/tab $:/plugins/amp/MagicTabs/common $:/tabs/all",
"title": "$:/plugins/amp/MagicTabs/tabs/info",
"mt-list.filter": "",
"mt-list.template": "$:/plugins/amp/MagicTabs/templates/tabs/info",
"mt-list.heading": ""
},
"$:/plugins/amp/MagicTabs/images/person": {
"text": "<<mt-image \"fa-user\" \"person\" \"Person\">>",
"created": "20140725155839838",
"creator": "Alberto Molina Pérez",
"modified": "20150129055337430",
"modifier": "Alberto Molina Pérez",
"title": "$:/plugins/amp/MagicTabs/images/person",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common"
},
"$:/plugins/amp/MagicTabs/images/done": {
"text": "<<mt-image \"fa-check\" \"done\" \"Done\">>",
"created": "20141104120913843",
"creator": "Alberto Molina Pérez",
"modified": "20150129055338292",
"modifier": "Alberto Molina Pérez",
"title": "$:/plugins/amp/MagicTabs/images/done",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common"
},
"$:/plugins/amp/MagicTabs/images/comments-o": {
"text": "<$reveal state=\"$:/plugins/TheDiveO/FontAwesome/fonts/FontAwesome!!modified\" type=\"nomatch\" text=\"\">\n<i class=\"fa fa-comments-o\"></i>\n</$reveal>\n<$reveal state=\"$:/plugins/TheDiveO/FontAwesome/fonts/FontAwesome!!modified\" type=\"match\" text=\"\">\ncomments\n</$reveal>",
"created": "20141116005848105",
"creator": "Alberto Molina Pérez",
"title": "$:/plugins/amp/MagicTabs/images/comments-o",
"modified": "20150129055339227",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common"
},
"$:/plugins/amp/MagicTabs/tabs/comments": {
"created": "20140517111844484",
"creator": "Alberto Molina Pérez",
"text": "<<mt-slider-input>>\n\n<<mt-tab-contents>>",
"caption": "<<mt-tab-caption>>",
"color": "#d3d3d3",
"description": "Comments",
"modified": "20150223205634420",
"modifier": "Alberto Molina Pérez",
"mt-contents.type": "$:/type/comment",
"mt-list.filter": "",
"mt-list.filter_alt": "",
"mt-list.heading": "Comments",
"mt-list.heading_alt": "Related",
"mt-list.template": "$:/plugins/amp/MagicTabs/templates/tabs/comments",
"mt-list.template_alt": "$:/plugins/amp/MagicTabs/templates/tabs/comments",
"tags": "MagicTabs $:/type/tab $:/plugins/amp/MagicTabs/common $:/tabs/all",
"title": "$:/plugins/amp/MagicTabs/tabs/comments",
"icon": "$:/plugins/amp/MagicTabs/images/comments-o"
},
"$:/plugins/amp/MagicTabs/images/check": {
"text": "<<mt-image \"fa-check-square-o\" \"tasks\" \"Tasks\">>",
"created": "20140725151137471",
"creator": "Alberto Molina Pérez",
"modified": "20150129055340099",
"modifier": "Alberto Molina Pérez",
"title": "$:/plugins/amp/MagicTabs/images/check",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common"
},
"$:/plugins/amp/MagicTabs/images/edit": {
"created": "20141122232121975",
"creator": "Alberto Molina Pérez",
"text": "<<mt-image \"fa-pencil\" \"edit\" \"Edit\">>",
"modified": "20150208201744915",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/edit"
},
"$:/config/MagicTabs/colors/$:/plugins/amp/MagicTabs": {
"text": "blue:#F6F6FF\nred:#FFEEEE\nyellow:#FFFFDD",
"created": "20141107223855525",
"creator": "Alberto Molina Pérez",
"modified": "20141123115654084",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs",
"title": "$:/config/MagicTabs/colors/$:/plugins/amp/MagicTabs",
"type": "application/x-tiddler-dictionary"
},
"$:/config/MagicTabs/position/$:/plugins/amp/MagicTabs": {
"title": "$:/config/MagicTabs/position/$:/plugins/amp/MagicTabs",
"text": "right",
"created": "20141111235818715",
"creator": "Alberto Molina Pérez",
"modified": "20141123143632943",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs"
},
"$:/config/SystemTags/Visibility/$:/plugins/amp/MagicTabs/noSysTags": {
"created": "20141123120338681",
"text": "hide",
"creator": "Alberto Molina Pérez",
"modified": "20141123121106548",
"modifier": "Alberto Molina Pérez",
"title": "$:/config/SystemTags/Visibility/$:/plugins/amp/MagicTabs/noSysTags"
},
"$:/plugins/amp/MagicTabs/button/noSysTags": {
"text": "<$reveal state=\"$:/config/SystemTags/Visibility/$:/plugins/amp/MagicTabs/noSysTags\" type=\"match\" text=\"show\" default=\"hide\">\n<$button>\n <$action-setfield $tiddler=\"$:/core/ui/ViewTemplate/tags\" tags=\"\"/>\n <$action-setfield $tiddler=\"$:/plugins/amp/MagicTabs/noSysTags/ViewTemplate/tags\" tags=\"$:/tags/ViewTemplate\"/>\n <$action-setfield $tiddler=\"$:/config/SystemTags/Visibility/$:/plugins/amp/MagicTabs/noSysTags\" text=\"hide\"/>\n <$action-sendmessage $message=\"tm-notify\" $param=\"$:/plugins/amp/MagicTabs/noSysTags/notification/hidden\"/>\nHide\n</$button>\n</$reveal>\n<$reveal state=\"$:/config/SystemTags/Visibility/$:/plugins/amp/MagicTabs/noSysTags\" type=\"match\" text=\"hide\" default=\"hide\">\n<$button>\n <$action-setfield $tiddler=\"$:/core/ui/ViewTemplate/tags\" tags=\"$:/tags/ViewTemplate\"/>\n <$action-setfield $tiddler=\"$:/plugins/amp/MagicTabs/noSysTags/ViewTemplate/tags\" tags=\"\"/>\n <$action-setfield $tiddler=\"$:/config/SystemTags/Visibility/$:/plugins/amp/MagicTabs/noSysTags\" text=\"show\"/>\n <$action-sendmessage $message=\"tm-notify\" $param=\"$:/plugins/amp/MagicTabs/noSysTags/notification/visible\"/>\nShow\n</$button>\n</$reveal>",
"created": "20141108192721447",
"creator": "Alberto Molina Pérez",
"dependencies": "$:/config/SystemTags/Visibility/$:/plugins/amp/MagicTabs/noSysTags $:/core/ui/ViewTemplate/tags $:/plugins/amp/MagicTabs/noSysTags/ViewTemplate/tags $:/plugins/amp/MagicTabs/noSysTags/notification/hidden $:/plugins/amp/MagicTabs/noSysTags/notification/visible",
"modified": "20150129055341772",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/button/noSysTags"
},
"$:/plugins/amp/MagicTabs/config/noSysTags": {
"text": "\\define buttonState()\n<$reveal state=\"$:/config/SystemTags/Visibility/$:/plugins/amp/MagicTabs/noSysTags\" type=\"match\" text=\"show\" default=\"hide\">Hide</$reveal>\n<$reveal state=\"$:/config/SystemTags/Visibility/$:/plugins/amp/MagicTabs/noSysTags\" type=\"match\" text=\"hide\" default=\"hide\">Show</$reveal>\n\\end\n\n<<buttonState>> the system tags (those starting with `$:/`) from the regular tiddlers:\n{{$:/plugins/amp/MagicTabs/button/noSysTags}}\n",
"caption": "System tags",
"created": "20141123122514969",
"creator": "Alberto Molina Pérez",
"dependencies": "$:/config/SystemTags/Visibility/$:/plugins/amp/MagicTabs/noSysTags $:/plugins/amp/MagicTabs/button/noSysTags",
"modified": "20150129055342469",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/ControlPanel/Appearance $:/tags/config MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/config/noSysTags"
},
"$:/plugins/amp/MagicTabs/config/appearance": {
"text": "!!~MagicTabs tweaks\n\n<<tabs \"[all[tiddlers+shadows]tag[$:/tags/config]tag[MagicTabs]]\" \"$:/plugins/amp/MagicTabs/config/MagicTabs\" class:\"tc-vertical\">>",
"caption": "~MagicTabs tweaks",
"created": "20141123140253665",
"creator": "Alberto Molina Pérez",
"dependencies": "$:/plugins/amp/MagicTabs/config/MagicTabs",
"modified": "20150129055343194",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/tags/ControlPanel/Appearance $:/tags/MagicTabs/config $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/config/appearance"
},
"$:/plugins/amp/MagicTabs/notification/noSysTags/hidden": {
"text": "System tags are now hidden",
"created": "20141108202520892",
"creator": "Alberto Molina Pérez",
"modified": "20150129055343842",
"modifier": "Alberto Molina Pérez",
"title": "$:/plugins/amp/MagicTabs/notification/noSysTags/hidden",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"dependencies": ""
},
"$:/plugins/amp/MagicTabs/notification/noSysTags/visible": {
"text": "System tags are now visible",
"created": "20141108202218743",
"creator": "Alberto Molina Pérez",
"modified": "20150129055344512",
"modifier": "Alberto Molina Pérez",
"title": "$:/plugins/amp/MagicTabs/notification/noSysTags/visible",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"dependencies": ""
},
"$:/plugins/amp/MagicTabs/config/subtitle": {
"text": "!Subtitle\n\n<$checkbox tiddler=\"$:/core/ui/ViewTemplate/subtitle\" tag=\"$:/tags/ViewTemplate\"> Default</$checkbox>\n\n<$checkbox tiddler=\"$:/plugins/amp/MagicTabs/ViewTemplate/subtitle\" tag=\"$:/tags/ViewTemplate\"> Custom </$checkbox>",
"created": "20141123122514969",
"creator": "Alberto Molina Pérez",
"caption": "Subtitle",
"dependencies": "$:/core/ui/ViewTemplate/subtitle $:/plugins/amp/MagicTabs/ViewTemplate/subtitle",
"modified": "20150129055345175",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/config MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/config/subtitle"
},
"$:/core/ui/ViewTemplate/subtitle": {
"text": "<div class=\"tw-subtitle\">\n<$link to={{!!modifier}}>\n<$view field=\"modifier\"/>\n</$link> <$view field=\"modified\" format=\"relativedate\"/>\n</div>\n",
"created": "20140619154629980",
"modified": "20141123230529692",
"modifier": "Alberto Molina Pérez",
"tags": "",
"title": "$:/core/ui/ViewTemplate/subtitle"
},
"$:/plugins/amp/MagicTabs/button/newJournalHere": {
"created": "20141109111500946",
"creator": "Alberto Molina Pérez",
"text": "\\define journalButtonTags()\n$:/type/journal\n\\end\n\\define journalButton()\n<$button tooltip={{!!description}} class=<<tv-config-toolbar-class>>>\n<$action-sendmessage $message=\"tm-new-tiddler\" title=<<now \"$(currentTiddlerTag)$ - $(journalTitleTemplate)$\">> tags=<<journalButtonTags>> mt-topics.list=\"[[$(currentTiddlerTag)$]]\" datetime=<<now \"YY0MM0DD0hh0mm0ss\">> description=\"\" tasks=\"\"/>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/new-journal-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/NewJournalHere/Caption}}/></span>\n</$list>\n</$button>\n\\end\n<$set name=\"journalTitleTemplate\" value=\"0DD/0MM/YY\">\n<$set name=\"currentTiddlerTag\" value=<<currentTiddler>>>\n<<journalButton>>\n</$set></$set>",
"caption": "{{$:/core/images/new-journal-button}} {{$:/language/Buttons/NewJournalHere/Caption}}",
"description": "Custom new-here journal button",
"modified": "20150308160028282",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/ViewToolbar MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/button/newJournalHere"
},
"$:/plugins/amp/MagicTabs/ViewTemplate/subtitle": {
"text": "\\define fieldValue()\n\t<$tiddler tiddler={{!!$(fieldName)$}}>\n\t\t<$transclude tiddler={{!!icon}}/>\n <$link><$view field=\"title\"/></$link> \n </$tiddler>\n\\end\n\\define fieldList()\n\t<$list filter=\"[all[current]list[!!$(fieldName)$]]\">\n \t<$transclude tiddler={{!!icon}}/>\n <$link><$view field=\"title\"/></$link> \n </$list>\n\\end\n<div class=\"tc-subtitle\">\n <$list filter=\"[all[current]!tag[$:/action/show/modifier]!tag[$:/action/hide/subtitle]]\">\n <$list filter=\"[all[current]tag[$:/type/person]!is[system]]\">\n {{!!mt-person.birth.place}} {{!!mt-person.birth.date}} – {{!!mt-person.death.place}} {{!!mt-person.death.date}}<br>\n </$list>\n <$list filter=\"[all[current]fields[]prefix[mt-source]!suffix[list]]\" variable=\"fieldName\">\n \t<<fieldValue>>\n </$list>\n <$list filter=\"[all[current]fields[]prefix[mt-source]suffix[list]]\" variable=\"fieldName\">\n \t<<fieldList>>\n </$list>\n </$list>\n <$list filter=\"[all[current]tag[$:/action/show/modifier]]\">\n {{||$:/core/ui/ViewTemplate/subtitle}}\n </$list>\n</div>",
"created": "20140430190143854",
"creator": "Alberto Molina",
"list-after": "$:/core/ui/ViewTemplate/title",
"modified": "20150304193740933",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/ViewTemplate MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/ViewTemplate/subtitle",
"type": ""
},
"$:/plugins/amp/MagicTabs/images/history": {
"text": "<<mt-image \"fa-history\" \"history\" \"Journal\">>",
"created": "20141125085514841",
"creator": "Alberto Molina Pérez",
"modified": "20150129055409735",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/history"
},
"$:/plugins/amp/MagicTabs/css/text/columns": {
"text": ".deuxcolonnes {\nvertical-align:top; display:block; \ncolumn-count:2;\n-moz-column-count:2; \n-webkit-column-count:2;\n}\n\n.troiscolonnes {\nvertical-align:top; display:block; \ncolumn-count:3;\n-moz-column-count:3; \n-webkit-column-count:3;\n}\n\n.quatrecolonnes {\nvertical-align:top; display:block; \ncolumn-count:4;\n-moz-column-count:4; \n-webkit-column-count:4;\n}",
"created": "20140421190344485",
"creator": "Alberto Molina",
"dependencies": "",
"modified": "20150129055405696",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Stylesheet MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/css/text/columns",
"type": "text/css"
},
"$:/plugins/amp/MagicTabs/ViewTemplate/TabsBar": {
"created": "20141106113206200",
"text": "\\define resettab(state)\n<$reveal state=<<qualify $state$>> type=\"nomatch\" text=\"\">\n <$tiddler tiddler=<<qualify $state$>>>\n <div style=\"float:right;clear:right;\" class=\"tc-tiddler-controls\">\n <span title=\"Close tabs\">\n <$button set={{!!title}} setTo=\"\" class=\"tc-btn-invisible close-tabs\">{{$:/core/images/close-button}}</$button>\n </span>\n </div>\n </$tiddler>\n</$reveal>\n\\end\n\n\\define bottom-tabs()\n<$tiddler tiddler=<<storyTiddler>> >\n<$list filter=\"[all[current]tags[]prefix[$:/type/]limit[1]]\" variable=\"ignore\">\n<<tabs tabsList:\"[all[shadows+tiddlers]tag[$:/tabs/all]] [all[shadows+tiddlers]tag[$:/tabs/typed]] [all[current]tags[]prefix[$:/type/]removeprefix[$:/type/]addprefix[$:/tabs/]tagging[]] -[has[draft.of]]\" class:\"bottom-tabs $(color)$\" template:\"$:/plugins/amp/MagicTabs/TabsBar/template\">>\n</$list>\n<$list filter=\"[all[current]] -[all[current]tags[]prefix[$:/type/]tagging[]field:title{!!title}] +[limit[1]]\" variable=\"ignore\">\n<<tabs tabsList:\"[all[shadows+tiddlers]tag[$:/tabs/all]] [all[shadows+tiddlers]tag[$:/tabs/untyped]] [all[current]tags[]prefix[$:/type/]removeprefix[$:/type/]addprefix[$:/tabs/]tagging[]] -[has[draft.of]]\" class:\"bottom-tabs $(color)$\" template:\"$:/plugins/amp/MagicTabs/TabsBar/template\">>\n</$list>\n </$tiddler>\n\\end\n\n<$list filter=\"[all[current]!tag[$:/action/hide/tabs]limit[1]]\">\n<div style=\"clear:both;\">\n<<resettab \"$:/state/tab\">>\n<$tiddler tiddler=<<tabsTag>> >\n <$reveal state=<<qualify \"$:/state/tab\">> type=\"nomatch\" text=\"\">\n <$reveal state=\"!!tabs-color\" type=\"nomatch\" text=\"\">\n <$set name=\"color\" value={{!!tabs-color}} > \n <<bottom-tabs>> \n </$set>\n </$reveal>\n <$reveal state=\"!!tabs-color\" type=\"match\" text=\"\">\n <$set name=\"color\" value=\"blue\" > \n <<bottom-tabs>> \n </$set>\n </$reveal>\n </$reveal>\n <$reveal state=<<qualify \"$:/state/tab\">> type=\"match\" text=\"\">\n <$set name=\"color\" value=\"\" > \n <<bottom-tabs>> \n </$set>\n </$reveal>\n</$tiddler>\n</div>\n</$list>\n\n\n",
"creator": "Alberto Molina Pérez",
"modified": "20150228081706470",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/ViewTemplate MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/ViewTemplate/TabsBar",
"list-after": ""
},
"$:/plugins/amp/MagicTabs/ViewTemplate/tags": {
"created": "20141108192418225",
"creator": "Alberto Molina Pérez",
"text": "<div class=\"tc-tags-wrapper\">\n<$list filter=\"[all[current]!tag[$:/action/hide/tags]]\" variable=\"yes\">\n<$list filter=\"[all[current]!is[system]list[!!mt-topics.list]]\" template=\"$:/core/ui/TagTemplate\" storyview=\"pop\"/>\n<$list filter=\"[all[current]!is[system]tags[]!is[system]sort[title]] [all[current]is[system]tags[]]\" template=\"$:/core/ui/TagTemplate\" storyview=\"pop\"/>\n</$list>\n</div>",
"list-before": "$:/core/ui/ViewTemplate/body",
"modified": "20150308161307182",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/ViewTemplate MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/ViewTemplate/tags",
"type": ""
},
"$:/plugins/amp/MagicTabs/css/text/box": {
"text": ".box {\ndisplay:inline-block;\n-moz-border-radius: 10px;\nborder-radius: 10px;\nmargin: 0.3em 1em 1.25em 1em; \npadding:0.25em 3em;\nbackground-color:#ececec;\n}\n\n.box.yellow {\n\tbackground-color:#FFFFDD;\n}\n\n.box.red {\n\tbackground-color:#FFDDDD;\n}\n\n.box.blue {\n\tbackground-color:#F6F6FF;\n}\n\n.important {\n\tdisplay:inline-block;\n\tborder:1px solid #CCCCCC;\n\t-moz-border-radius: 10px;\n\tborder-radius: 10px;\n\tmargin: 1em 1em 1em 1em; \n\tpadding: 0em 3em 1em 6em;\n\tbackground-color:#FFFFCC;\n\tfont-weight: 700;\n\tbox-shadow: 10px 10px 5px #888888;\n}\n\n.important:before {\n\tdisplay: block;\n\tcontent: \"!\";\n\tfont-size: 80px;\n\tfont-weight: bold;\n\tposition: relative;\n\tleft: -50px;\n\ttop: 50px;\n\tcolor: <<color foreground>>;\n}\n\n.important b {\ncolor:red;\n}",
"created": "20141208172252734",
"creator": "Alberto Molina Pérez",
"modified": "20150129055405038",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Stylesheet MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/css/text/box"
},
"$:/plugins/amp/MagicTabs/css/subtitle": {
"text": ".my-subtitle {\n font-size: 1.8em;\n font-style: bold;\n font-weight: 300; \n line-height: 1.0;\n margin: 0.2em 0 0.5em 0;\n text-align: left;\n color: #b0b0b0;\n}",
"created": "20140427104944650",
"creator": "Alberto Molina",
"modified": "20150129055403678",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Stylesheet MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/css/subtitle"
},
"$:/plugins/amp/MagicTabs/macros/searchBox": {
"text": "\\define lingo-base() $:/language/Search/\n\\define searchBox()\n<$linkcatcher to=\"$:/temp/advancedsearch\">\n\n<<lingo Standard/Hint>>\n\n<div class=\"tc-search\">\n<$edit-text tiddler=\"$:/temp/advancedsearch\" type=\"search\" tag=\"input\" placeholder=\"search here\" size=\"30\"/>\n<$reveal state=\"$:/temp/advancedsearch\" type=\"nomatch\" text=\"\">\n<$button class=\"tc-btn-invisible\">\n<$action-setfield $tiddler=\"$:/temp/advancedsearch\" $field=\"text\" $value=\"\" size=\"30\"/>\n{{$:/core/images/close-button}}\n</$button>\n \n</$reveal>\n</div>\n\n</$linkcatcher>\n\n\\end\n\n<<searchBox>>\n\n\n\n\n\n\n\n\n\n\n\n",
"created": "20141210121920873",
"creator": "Alberto Molina Pérez",
"modified": "20150304195932699",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/searchBox"
},
"$:/core/ui/ViewTemplate/tags": {
"text": "<div class=\"tw-tags-wrapper\"><$list filter=\"[all[current]tags[]sort[title]]\" template=\"$:/core/ui/TagTemplate\" storyview=\"pop\"/></div>\n",
"created": "20140506153005819",
"list-after": "$:/_ui/ViewTemplate/title",
"modified": "20140616142921885",
"title": "$:/core/ui/ViewTemplate/tags"
},
"$:/plugins/amp/MagicTabs/css/text/grey": {
"text": ".text-grey {\n\tfont-size: 0.9em;\n\tcolor: #c0c0c0;\n\tfont-weight: 300;\n}",
"created": "20140614234722764",
"creator": "Alberto Molina Pérez",
"modified": "20150129055406377",
"modifier": "Alberto Molina Pérez",
"title": "$:/plugins/amp/MagicTabs/css/text/grey",
"tags": "$:/tags/Stylesheet MagicTabs $:/plugins/amp/MagicTabs/common"
},
"$:/plugins/amp/MagicTabs/css/image/person": {
"text": ".person {\n\tborder: none;\n\twidth: 128px;\n\tfloat: right;\n\tclear: both;\n\tmargin: 0 0 1em 0.5em;\n\tbox-shadow: 2px 2px 15px 1px rgba(119, 119, 119, 0.5);\n\t-moz-box-shadow: 2px 2px 15px 1px rgba(119, 119, 119, 0.5);\n\t-webkit-box-shadow: 2px 2px 15px 1px rgba(119, 119, 119, 0.5);\n\n}\n",
"created": "20140711080416780",
"creator": "Alberto Molina Pérez",
"modified": "20150129055402934",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Stylesheet MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/css/image/person"
},
"$:/plugins/amp/MagicTabs/ViewTemplate/person/picture": {
"text": "<$list filter=\"[all[current]tag[$:/type/person]]\">\n<$reveal type=\"nomatch\" state=\"!!picture\" text=\"\">\n<$image source={{!!picture}} class=\"person\"/>\n</$reveal>\n</$list>\n",
"created": "20141206162301561",
"creator": "Alberto Molina Pérez",
"list-before": "$:/core/ui/ViewTemplate/body",
"modified": "20150208012811451",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/ViewTemplate MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/ViewTemplate/person/picture"
},
"$:/plugins/amp/MagicTabs/images/search": {
"text": "<<mt-image \"fa-search\" \"search\" \"Search\">>",
"created": "20141210122006626",
"creator": "Alberto Molina Pérez",
"modified": "20150129055413267",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/search"
},
"$:/plugins/amp/MagicTabs/images/question": {
"text": "<<mt-image \"fa-question\" \"question\" \"Question\">>",
"created": "20141210122048073",
"creator": "Alberto Molina Pérez",
"modified": "20150129055412585",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/question"
},
"$:/plugins/amp/MagicTabs/images/comment": {
"text": "<<mt-image \"fa-comment-o\" \"comment\" \"Comment\">>",
"created": "20141212082901738",
"creator": "Alberto Molina Pérez",
"title": "$:/plugins/amp/MagicTabs/images/comment",
"modified": "20150129055407713",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common"
},
"$:/plugins/amp/MagicTabs/images/people": {
"text": "<<mt-image \"fa-users\" \"people\" \"People\">>",
"created": "20141212221823959",
"creator": "Alberto Molina Pérez",
"modified": "20150129055411918",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/people"
},
"$:/plugins/amp/MagicTabs/css/buttons": {
"text": ".agenda td button {\n\tpadding: 10%;\n\tmargin: 0px 0px;\n\twidth: 100%;\n\theight: 100%;\n\tborder: none;\n\ttext-align: center;\n\tbackground: #FFFFDD;\n}\n\n.btn-sidebar {\n\theight: 6em;\n\twidth: 6em;\n\tmargin: 0px -10px 0px 0px;\n\tbackground: none;\n\tcolor: <<color sidebar-controls-foreground>>;\n\tborder: none;\n\tfont-size: 1em;\n\tline-height: 1.2em;\n}\n\n.btn-sidebar-down {\n\theight: 6em;\n\twidth: 6em;\n\tmargin: 0px -10px 0px 0px;\n\tbackground: none;\n\tcolor: <<color sidebar-controls-foreground-hover>>;\n\tborder: none;\n\tfont-size: 1em;\n\tline-height: 1.4em;\n}\n\n.btn-sidebar:hover {\n\tcolor: <<color sidebar-controls-foreground-hover>>;\n}\n\n.btn-sidebar-down:hover {\n\tcolor: <<color sidebar-controls-foreground>>;\n}\n\n.btn-newHere-sidebar {\n\tbackground: none;\n\tcolor: #FFFFFF;\n\tborder: 1px solid white;\n\tfont-size: 1.2em;\n\tfont-weight:bold;\n\tline-height: 1.6em;\n}\n\n\n.btn-big {\n\tpadding: 8px;\n\tmargin: 0px 8px 4px 0px;\n\tcolor: <<colour download-foreground>>;\n\tfill: <<colour download-foreground>>;\n\tborder: none;\n\tfont-size: 1.2em;\n\tfont-weight: bold;\n\tline-height: 1.4em;\n}\n\n.btn-big.grey {\n\tbackground: grey;\n}\n\n.btn-big.green {\n\tbackground: <<colour download-background>>;\n}\n\n.btn-big.red {\n\tbackground: red;\n}\n\n.btn-slider-input {\n\tpadding: 0;\n\tmargin: 0;\n\tbackground: none;\n\tborder: none;\n}\n\n.btn-slider-input.tab {\n\tfloat: right;\n\tposition:relative;\n\ttop: -3px;\n}\n\n.btn-slider-input.dashboard {\n\tfloat: right;\n\tposition:relative;\n\ttop: 0px;\n}\n\n",
"created": "20141213163744005",
"creator": "Alberto Molina Pérez",
"modified": "20150129055401472",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Stylesheet MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/css/buttons"
},
"tag": {
"text": "{{!!title||$:/core/ui/TagTemplate}}",
"created": "20140421102052631",
"creator": "Alberto Molina",
"modified": "20140422132035362",
"modifier": "Alberto Molina",
"tags": "nouveau",
"title": "tag"
},
"$:/config/MagicTabs/caption/font-size/$:/plugins/amp/MagicTabs": {
"created": "20141228161847285",
"creator": "Alberto Molina Pérez",
"title": "$:/config/MagicTabs/caption/font-size/$:/plugins/amp/MagicTabs",
"text": "1.25em",
"modified": "20141228163224485",
"modifier": "Alberto Molina Pérez"
},
"$:/config/MagicTabs/caption-selected/font-size/$:/plugins/amp/MagicTabs": {
"created": "20141228161853049",
"creator": "Alberto Molina Pérez",
"title": "$:/config/MagicTabs/caption-selected/font-size/$:/plugins/amp/MagicTabs",
"text": "1.25em",
"modified": "20141229101154480",
"modifier": "Alberto Molina Pérez"
},
"$:/plugins/amp/MagicTabs/config/MagicTabs": {
"text": "!Default tabs\n\n<div class=\"troiscolonnes\">\n<$list filter=\"[all[tiddlers+shadows]prefix[$:/plugins/amp/MagicTabs/tabs]sort[]]\">\n<$set name=\"tabName\" filter=\"[all[current]has[description]!description[]]\" value=\"description\" emptyValue=\"title\">\n <$checkbox tag=\"$:/tabs/all\"> \n <$link>\n <$view field=<<tabName>>/>\n </$link>\n </$checkbox>\n<br>\n\n</$set>\n</$list>\n</div>\n\n!Position\n\n<$radio tiddler=\"$:/config/MagicTabs/position/$:/plugins/amp/MagicTabs\" field=\"text\" value=\"left\">Left</$radio> \n<$radio tiddler=\"$:/config/MagicTabs/position/$:/plugins/amp/MagicTabs\" field=\"text\" value=\"right\">Right</$radio>\n\n! Colors\n\n<$tiddler tiddler=\"$:/config/MagicTabs/colors/$:/plugins/amp/MagicTabs\">\n\n|!Blue: |<$edit-text index=\"blue\" tag=\"input\"/>|<$edit-text index=\"blue\" type=\"color\" tag=\"input\"/>|\n|!Red: |<$edit-text index=\"red\" tag=\"input\"/>|<$edit-text index=\"red\" type=\"color\" tag=\"input\"/>|\n|!Yellow: |<$edit-text index=\"yellow\" tag=\"input\"/>|<$edit-text index=\"yellow\" type=\"color\" tag=\"input\"/>|\n\n</$tiddler>\n\n!Caption\n\nFont-size: <$edit-text tiddler=\"$:/config/MagicTabs/caption/font-size/$:/plugins/amp/MagicTabs\" default=\"1em\" tag=\"input\" size=\"6\"/>\n\nFont-size selected: <$edit-text tiddler=\"$:/config/MagicTabs/caption-selected/font-size/$:/plugins/amp/MagicTabs\" tag=\"input\" size=\"6\"/>\n\nFont-size counter: <$edit-text tiddler=\"$:/config/MagicTabs/caption-counter/font-size/$:/plugins/amp/MagicTabs\" tag=\"input\" size=\"6\"/>\n\nColor: <$edit-text tiddler=\"$:/config/MagicTabs/caption/color/$:/plugins/amp/MagicTabs\" tag=\"input\" default=\"\"/> <$edit-text tiddler=\"$:/config/MagicTabs/caption/color/$:/plugins/amp/MagicTabs\" tag=\"input\" type=\"color\"/>\n\nCounter: \n<$radio tiddler=\"$:/config/MagicTabs/caption/counter/$:/plugins/amp/MagicTabs\" field=\"text\" value=\"show\">Show</$radio> \n<$radio tiddler=\"$:/config/MagicTabs/caption/counter/$:/plugins/amp/MagicTabs\" field=\"text\" value=\"hide\">Hide</$radio>",
"caption": "Tabs bar",
"created": "20140720092609150",
"creator": "Alberto Molina Pérez",
"dependencies": "$:/plugins/amp/MagicTabs/tabs/info $:/plugins/amp/MagicTabs/tabs/comments $:/config/MagicTabs/position/$:/plugins/amp/MagicTabs $:/config/MagicTabs/colors/$:/plugins/amp/MagicTabs",
"modified": "20150129055848422",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/tags/config $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/config/MagicTabs"
},
"$:/config/MagicTabs/caption/counter/$:/plugins/amp/MagicTabs": {
"text": "show",
"created": "20141229085818253",
"creator": "Alberto Molina Pérez",
"modified": "20150305001520115",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs",
"title": "$:/config/MagicTabs/caption/counter/$:/plugins/amp/MagicTabs"
},
"$:/config/MagicTabs/caption/color/$:/plugins/amp/MagicTabs": {
"text": "#C0C0C0",
"created": "20141228164936682",
"creator": "Alberto Molina Pérez",
"modified": "20141228172124900",
"modifier": "Alberto Molina Pérez",
"tags": "",
"title": "$:/config/MagicTabs/caption/color/$:/plugins/amp/MagicTabs"
},
"$:/plugins/amp/MagicTabs/templates/tabs/comments": {
"created": "20141229104951332",
"creator": "Alberto Molina Pérez",
"text": "<h2><$link to={{!!title}}><$view field=\"title\"/></$link></h2>\n<h3><$transclude field=\"description\"/></h3>\n<$list filter=\"[all[current]get[mt-source.tiddler]] [all[current]list[!!mt-topics.list]] [all[current]list[!!mt-source.parents.list]] -[title<storyTiddler>]\" template=\"$:/core/ui/TagTemplate\"/><$list filter=\"[all[current]tags[]!is[system]]\" template=\"$:/core/ui/TagTemplate\"/>\n\n<blockquote>\n\n<$transclude field=\"text\" mode=\"block\"/>\n\n</blockquote>\n\n<br>",
"modified": "20150308161440650",
"modifier": "Alberto Molina Pérez",
"tags": "$:/type/template MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/templates/tabs/comments"
},
"$:/plugins/amp/MagicTabs/templates/tabs/info": {
"created": "20141229201354721",
"text": "<$link><$transclude tiddler={{!!icon}}/> <$view field=\"title\"/></$link><br>",
"creator": "Alberto Molina Pérez",
"modified": "20150223205656773",
"modifier": "Alberto Molina Pérez",
"tags": "$:/type/template MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/templates/tabs/info"
},
"$:/type/person": {
"created": "20141230120636464",
"text": "",
"caption": "person",
"color": "#ff8383",
"creator": "Alberto Molina Pérez",
"icon": "$:/plugins/amp/MagicTabs/images/person",
"modified": "20150223120711713",
"modifier": "Alberto Molina Pérez",
"mt-dashboard.add.content": "$:/plugins/amp/MagicTabs/new/person",
"mt-dashboard.heading": "People",
"mt-dashboard.icon": "$:/plugins/amp/MagicTabs/images/people",
"mt-template.fields": "$:/plugins/amp/MagicTabs/templates/types/person",
"mt-template.form": "$:/plugins/amp/MagicTabs/new/person",
"tags": "$:/tags/MagicTabs/dashboard MagicTabs",
"title": "$:/type/person",
"mt-source.type": "$:/type/root"
},
"$:/type/comment": {
"created": "20141231095243291",
"text": "",
"caption": "comment",
"color": "#daa520",
"creator": "Alberto Molina Pérez",
"icon": "$:/plugins/amp/MagicTabs/images/comment",
"modified": "20150223120830034",
"modifier": "Alberto Molina Pérez",
"mt-template.fields": "$:/plugins/amp/MagicTabs/templates/types/comment",
"mt-template.form": "",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/type/comment",
"mt-source.type": "$:/type/note"
},
"$:/plugins/amp/MagicTabs/images/config": {
"created": "20150106010921551",
"creator": "Alberto Molina Pérez",
"text": "<<mt-image \"fa-ellipsis-v \" \"config\" \"BT Configuration\">>",
"title": "$:/plugins/amp/MagicTabs/images/config",
"modified": "20150205113753268",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common"
},
"$:/config/ViewToolbarButtons/Visibility/$:/plugins/amp/MagicTabs/button/newJournalHere": {
"text": "hide",
"modified": "20141204213332498",
"modifier": "Alberto Molina Pérez",
"title": "$:/config/ViewToolbarButtons/Visibility/$:/plugins/amp/MagicTabs/button/newJournalHere"
},
"MagicTabs": {
"created": "20150106011534872",
"creator": "Alberto Molina Pérez",
"text": "{{$:/plugins/amp/MagicTabs/dashboard}}",
"modified": "20150205231622205",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/action/hide/tags $:/type/dashboard $:/action/hide/tabs $:/favorite",
"title": "MagicTabs",
"icon": "$:/plugins/amp/MagicTabs/images/magic"
},
"$:/plugins/amp/MagicTabs/buttons/MagicTabs": {
"text": "<$button tooltip=\"Open MagicTabs dashboard\" aria-label=\"Open MagicTabs dashboard\" class=<<tv-config-toolbar-class>>>\n<$action-navigate $to=\"MagicTabs\"/>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/plugins/amp/MagicTabs/images/magic}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text=\"Open MagicTabs dashboard\"/></span>\n</$list>\n</$button>",
"created": "20150106020337437",
"creator": "Alberto Molina Pérez",
"modified": "20150129055354689",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/PageControls MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/buttons/MagicTabs",
"list-after": "",
"caption": "MagicTabs",
"description": "Open MagicTabs dashboard"
},
"$:/plugins/amp/MagicTabs/images/magic": {
"text": "<<mt-image \"fa-magic\" \"magic tabs\" \"MagicTabs\">>",
"created": "20150106014743951",
"creator": "Alberto Molina Pérez",
"modified": "20150129055411201",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/magic"
},
"$:/plugins/amp/MagicTabs/images/idea": {
"text": "<<mt-image \"fa-lightbulb-o\" \"idea\" \"Idea\">>",
"created": "20141123005333276",
"creator": "Alberto Molina Pérez",
"modified": "20150129055410457",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/idea"
},
"$:/plugins/amp/MagicTabs/tabs/ideas": {
"created": "20141122233839041",
"creator": "Alberto Molina Pérez",
"text": "<<mt-slider-input>>\n\n<<mt-tab-contents>>",
"caption": "<<mt-tab-caption>>",
"color": "#d3d3d3",
"description": "Ideas",
"icon": "$:/plugins/amp/MagicTabs/images/idea",
"modified": "20150223205609791",
"modifier": "Alberto Molina Pérez",
"mt-contents.type": "$:/type/idea",
"mt-list.filter": "",
"mt-list.filter_alt": "",
"mt-list.heading": "Ideas",
"mt-list.heading_alt": "Related",
"mt-list.template": "$:/plugins/amp/MagicTabs/templates/tabs/notes",
"mt-list.template_alt": "",
"tags": "MagicTabs $:/type/tab $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/tabs/ideas"
},
"$:/plugins/amp/MagicTabs/tabs/notes": {
"text": "<<mt-slider-input \"$:/plugins/amp/MagicTabs/new/default\">>\n\n<<mt-tab-contents>>",
"caption": "<<mt-tab-caption>>",
"color": "#d3d3d3",
"created": "20141122233839041",
"creator": "Alberto Molina Pérez",
"description": "Notes",
"icon": "$:/plugins/amp/MagicTabs/images/note",
"modified": "20150305103446528",
"modifier": "Alberto Molina Pérez",
"mt-contents.type": "$:/type/note",
"mt-list.filter": "",
"mt-list.filter_alt": "",
"mt-list.heading": "Notes",
"mt-list.heading_alt": "Related",
"mt-list.template": "$:/plugins/amp/MagicTabs/templates/tabs/notes",
"mt-list.template_alt": "$:/plugins/amp/MagicTabs/templates/tabs/notes",
"tags": "MagicTabs $:/type/tab $:/plugins/amp/MagicTabs/common $:/tabs/all $:/tabs/publication $:/tabs/part",
"title": "$:/plugins/amp/MagicTabs/tabs/notes"
},
"$:/state/sort/notes": {
"title": "$:/state/sort/notes",
"text": "[tag[$:/type/note]]",
"modified": "20150122000432332",
"modifier": "Alberto Molina Pérez",
"tags": "$:/type/note $:/type/comment $:/type/idea $:/type/quote $:/type/bug $:/type/release",
"logic": "or"
},
"$:/type/idea": {
"created": "20141231095139943",
"text": "",
"caption": "idea",
"color": "#ffd700",
"creator": "Alberto Molina Pérez",
"icon": "$:/plugins/amp/MagicTabs/images/idea",
"modified": "20150223120904610",
"modifier": "Alberto Molina Pérez",
"mt-template.fields": "$:/plugins/amp/MagicTabs/templates/types/idea",
"mt-template.form": "",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/type/idea",
"mt-source.type": "$:/type/note"
},
"$:/type/note": {
"created": "20141231095056897",
"text": "",
"caption": "note",
"color": "#ffa500",
"creator": "Alberto Molina Pérez",
"icon": "$:/plugins/amp/MagicTabs/images/note",
"modified": "20150224234941773",
"modifier": "Alberto Molina Pérez",
"mt-dashboard.heading": "Notes",
"mt-dashboard.icon": "$:/plugins/amp/MagicTabs/images/note",
"mt-template.fields": "$:/plugins/amp/MagicTabs/templates/types/note",
"mt-template.form": "",
"tags": "$:/tags/MagicTabs/dashboard MagicTabs",
"title": "$:/type/note",
"mt-source.type": "$:/type/root"
},
"$:/plugins/amp/MagicTabs/css/button/grey": {
"text": ".tc-btn-grey {\n\tfont-size: 1em;\n\tcolor: #c0c0c0;\n\tfont-weight: 200;\n\tpadding: 0;\n\tmargin: 0;\n\tbackground: none;\n\tborder: none;\n}",
"created": "20141127102404932",
"creator": "Alberto Molina Pérez",
"title": "$:/plugins/amp/MagicTabs/css/button/grey",
"tags": "$:/tags/Stylesheet MagicTabs $:/plugins/amp/MagicTabs/common",
"modified": "20150129055400740",
"modifier": "Alberto Molina Pérez"
},
"$:/plugins/amp/MagicTabs/templates/tabs/notes": {
"created": "20141229112157236",
"creator": "Alberto Molina Pérez",
"text": "<h2><$link to={{!!title}}><$view field=\"caption\"><$view field=\"title\"/></$view></$link></h2>\n\n<$reveal state=\"!!description\" type=\"nomatch\" text=\"\">\n<h3><$transclude field=\"description\"/></h3>\n</$reveal>\n\n<$list filter=\"[all[current]get[mt-source.tiddler]] [all[current]list[!!mt-topics.list]] [all[current]list[!!mt-source.parents.list]] -[title<storyTiddler>]\" template=\"$:/core/ui/TagTemplate\"/>\n<$list filter=\"[all[current]tags[]!is[system]]\" template=\"$:/core/ui/TagTemplate\"/>\n\n<blockquote>\n\n<$transclude field=\"text\" mode=\"block\"/>\n\n</blockquote>\n\n<br>",
"modified": "20150308161420721",
"modifier": "Alberto Molina Pérez",
"tags": "$:/type/template MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/templates/tabs/notes"
},
"$:/plugins/amp/MagicTabs/images/default": {
"text": "<<mt-image \"fa-fire\" \"default\" \"Default\">>",
"created": "20150107124020856",
"creator": "Alberto Molina Pérez",
"modified": "20150129055409104",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/default"
},
"$:/plugins/amp/MagicTabs/css/buttons/touch": {
"created": "20150107162841278",
"creator": "Alberto Molina Pérez",
"text": ".btn-touch-big {\n\tbackground: none;\n\tcolor: #999999;\n\tborder: none;\n\tfont-size: {{$:/config/MagicTabs/btn-touch/font-size/$:/plugins/amp/MagicTabs}};\n}\n\n.btn-touch-big-down {\n\tbackground: none;\n\tcolor: #333333;\n\tborder: none;\n\tfont-size: {{$:/config/MagicTabs/btn-touch/font-size/$:/plugins/amp/MagicTabs}};\n}\n\n.btn-touch-big:hover {\n\tcolor: <<couleur btn-courses-hover>>;\n}\n\n",
"title": "$:/plugins/amp/MagicTabs/css/buttons/touch",
"tags": "MagicTabs $:/tags/Stylesheet $:/plugins/amp/MagicTabs/common",
"modified": "20150205194643694",
"modifier": "Alberto Molina Pérez"
},
"$:/config/MagicTabs/btn-touch/font-size/$:/plugins/amp/MagicTabs": {
"created": "20150107163109820",
"creator": "Alberto Molina Pérez",
"text": "2.5em",
"modified": "20150205193718961",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs",
"title": "$:/config/MagicTabs/btn-touch/font-size/$:/plugins/amp/MagicTabs"
},
"$:/plugins/amp/MagicTabs/dashboard": {
"text": "\\define lingo-base() $:/language/Search/\n\\define mt-typed-list2(type, tags, heading, state, tiddler)\n<<mt-slider-input tiddler:\"$:/plugins/amp/MagicTabs/dashboard/input\" type:\"$type$\" btnClass:\"dashboard\" contentClass:\"tc-tiddler-info\">>\n\n<h1>$heading$</h1>\n\n<$linkcatcher to=\"$:/temp/advancedsearch\">\n\n<<searchBox>>\n\n<<mt-typed-filter \"$type$\" \"$state$\">>\n\n</$linkcatcher>\n\n\n\n<div class=\"deuxcolonnes\">\n <$list filter=\"$tags$ +[tagging[]!is[system]search{$:/temp/advancedsearch}!has[draft.of]sort[]]\">\n <$reveal state=\"$:/temp/advancedsearch\" type=\"nomatch\" text=\"\">\n <$link><$transclude tiddler={{!!icon}}/><$view field=\"title\"/></$link><br>\n </$reveal>\n\n <$reveal state=\"$:/temp/advancedsearch\" type=\"match\" text=\"\"> \n <$link><$transclude tiddler={{!!icon}}/><$view field=\"title\"/></$link><br>\n </$reveal>\n </$list>\n</div>\n\\end\n\n\n\n\n\\define mt-typed-list(type:\"$:/type/note\",heading)\n<$reveal state=\"$:/state/mt-typed-list/$type$!!modified\" type=\"nomatch\" text=\"\">\n\n<$macrocall $name=\"mt-typed-list2\"\n type=\"$type$\"\n tags={{$:/state/mt-typed-list/$type$!!tags}}\n heading=\"$heading$\"\n state=\"$:/state/mt-typed-list/$type$\"\n tiddler={{$type$!!mt-dashboard.add.content}}\n />\n\n</$reveal>\n\n<$reveal state=\"$:/state/mt-typed-list/$type$!!modified\" type=\"match\" text=\"\">\n<$macrocall $name=\"mt-typed-list2\"\n type=\"$type$\"\n tags=\"$type$\"\n heading=\"$heading$\"\n state=\"$:/state/mt-typed-list/$type$\"\n tiddler={{$type$!!mt-dashboard.add.content}}\n />\n</$reveal>\n\\end\n\n\n<br>\n<$list filter=\"[[$:/plugins/amp/MagicTabs/SideBarLists]] [all[shadows+tiddlers]tag[$:/tags/MagicTabs/dashboard]] [[$:/plugins/amp/MagicTabs/dashboard/configuration]]\">\n<$reveal type=\"nomatch\" state=\"$:/state/mt/dashboard\" text={{!!title}} default=\"$:/type/note\">\n <$button class=\"btn-touch-big\" tooltip={{!!mt-dashboard.heading}}>\n <$action-setfield $tiddler=\"$:/state/mt/dashboard\" text={{!!title}}/>\n <$action-setfield $tiddler=\"$:/state/mt/dashboard/input\" text={{!!title}}/>\n <$transclude tiddler={{!!mt-dashboard.icon}}/>\n </$button>\n</$reveal>\n<$reveal type=\"match\" state=\"$:/state/mt/dashboard\" text={{!!title}} default=\"$:/type/note\">\n <$button class=\"btn-touch-big-down\" style=\"line-height:5%;position:relative; top:0.5em\">\n <$transclude tiddler={{!!mt-dashboard.icon}}/><br><span style=\"font-size:0.4em;\">{{$:/plugins/amp/MagicTabs/images/caret-up}}</span>\n </$button>\n</$reveal>\n</$list>\n\n<div style=\"border-top:solid 1px #ececec;\">\n\n\n<$list filter=\"[[$:/state/mt/dashboard]!text[$:/plugins/amp/MagicTabs/SideBarLists]!text[$:/plugins/amp/MagicTabs/dashboard/configuration]]\">\n<$tiddler tiddler={{$:/state/mt/dashboard}}>\n<$macrocall $name=\"mt-typed-list\"\n type={{!!title}}\n heading={{!!mt-dashboard.heading}}\n />\n</$tiddler>\n</$list>\n\n\n<$list filter=\"[[$:/state/mt/dashboard]text[$:/plugins/amp/MagicTabs/SideBarLists]] [[$:/state/mt/dashboard]text[$:/plugins/amp/MagicTabs/dashboard/configuration]]\">\n\n<$tiddler tiddler={{$:/state/mt/dashboard}}>\n\n<h1>{{!!mt-dashboard.heading}}</h1>\n\n<$transclude tiddler={{!!title}} mode=\"inline\"/>\n\n</$tiddler>\n\n</$list>\n\n\n</div>\n",
"created": "20150107164040302",
"creator": "Alberto Molina Pérez",
"modified": "20150309231446655",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/dashboard"
},
"$:/plugins/amp/MagicTabs/config/dashboard": {
"created": "20150107163550761",
"creator": "Alberto Molina Pérez",
"text": "!!!Dashboard buttons\n<$list filter=\"[all[shadows+tiddlers]prefix[$:/type/]sort[]]\">\n<$checkbox tag=\"$:/tags/MagicTabs/dashboard\">\n{{!!caption}}\n</$checkbox>\n<br>\n</$list>\n\nButtons size: <$edit-text tiddler=\"$:/config/MagicTabs/btn-touch/font-size/$:/plugins/amp/MagicTabs\" tag=\"input\" size=\"6\"/>\n",
"caption": "Dashboard",
"modified": "20150205193634102",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/tags/config $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/config/dashboard"
},
"$:/plugins/amp/MagicTabs/templates/type": {
"text": "",
"caption": "",
"color": "",
"created": "20150118120813338",
"creator": "Alberto Molina Pérez",
"icon": "",
"modified": "20150208013056600",
"modifier": "Alberto Molina Pérez",
"parents": "",
"tags": "MagicTabs",
"template": "",
"title": "$:/plugins/amp/MagicTabs/templates/type"
},
"$:/plugins/amp/MagicTabs/config/TabManager": {
"created": "20150118141800084",
"creator": "Alberto Molina Pérez",
"text": "\\define fields(fieldTitle:\"title\")\n\n<br><br><$checkbox tag=\"$:/tabs/all\"> default (applies to all tiddlers)</$checkbox>\n <$checkbox tag=\"$:/tabs/typed\"> typed (all typed tiddlers)</$checkbox>\n <$checkbox tag=\"$:/tabs/untyped\"> typed (all ''untyped'' tiddlers)</$checkbox>\n\n<table class=\"tc-view-field-table\">\n<tbody>\n<tr>\n<td>title</td>\n<td><$edit-text field=\"$fieldTitle$\" size=\"40\"/></td>\n</tr>\n<$list filter=\"[all[current]fields[]sort[title]] -text -created -creator -modified -modifier -title -draft.title\" variable=\"field\">\n<tr>\n<td><<field>></td>\n<td><$edit-text field=<<field>> size=\"40\"/></td>\n</tr>\n</$list>\n<tr>\n<td>text</td>\n<td><$edit-text field=\"text\" size=\"40\"/></td>\n</tr>\n</tbody>\n</table>\n\\end\n\n\\define accordion()\n <$reveal state=<<qualify \"$:/state/mt/accordion\">> type=\"nomatch\" text=<<currentTiddler>>>\n <$button set=<<qualify \"$:/state/mt/accordion\">> setTo=<<currentTiddler>> class=\"tc-btn-invisible\" style=\"padding-left:1em\">\n <strong>{{$:/core/images/right-arrow}} <$view field=\"description\"/></strong>\n </$button>\n </$reveal>\n\n <$reveal state=<<qualify \"$:/state/mt/accordion\">> type=\"match\" text=<<currentTiddler>>>\n <$button set=<<qualify \"$:/state/mt/accordion\">> setTo=\"\" class=\"tc-btn-invisible\" style=\"padding-left:1em\">\n <strong>{{$:/core/images/down-arrow}} <$view field=\"description\"/></strong>\n </$button>\n <$link to={{!!title}}>…</$link>\n\n <<fields>>\n\n </$reveal>\n\\end\n<<mt-slider-input tiddler:\"$:/plugins/amp/MagicTabs/new/tab\" type:\"$:/type/tab\" contentClass:\"tc-tiddler-info\">>\n\n!!Tab manager\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/type/tab]tags[]has[plugin-type]plugin-type[plugin]]\">\n\n!!!<$link to={{!!title}}><$view field=\"description\"/></$link>\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/type/tab]tag{!!title}!has[draft.of]!prefix[$:/temp/]]\">\n\n<<accordion>>\n\n</$list>\n\n</$list>\n\n!!!Custom\n\n<$list filter=\"[all[shadows+tiddlers]tag[$:/type/tab]] -[all[shadows+tiddlers]plugin-type[plugin]tagging[]] -$:/plugins/amp/MagicTabs/templates/types/tab +[!has[draft.of]!prefix[$:/temp/]sort[]]\" emptyMessage=\"none\">\n\n<<accordion>>\n\n</$list>\n",
"caption": "Tab manager",
"modified": "20150228092725551",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/tags/MagicTabs/config $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/config/TabManager",
"type": ""
},
"$:/plugins/amp/MagicTabs/config/TypeManager": {
"created": "20150116233105131",
"text": "\\define edit-type(style)\n <$reveal state=<<qualify \"$:/state/mt/edit-type\">> type=\"nomatch\" text=<<currentTiddler>>>\n <$button set=<<qualify \"$:/state/mt/edit-type\">> setTo=<<currentTiddler>> class=\"tc-btn-invisible\" style=\"$style$\">\n {{$:/core/images/right-arrow}} <$view field=\"caption\"/>\n </$button>\n </$reveal>\n\n <$reveal state=<<qualify \"$:/state/mt/edit-type\">> type=\"match\" text=<<currentTiddler>>>\n <$button set=<<qualify \"$:/state/mt/edit-type\">> setTo=\"\" class=\"tc-btn-invisible\" style=\"$style$\">\n \t{{$:/core/images/down-arrow}} <$view field=\"caption\"/>\n </$button>\n <$link to=<<currentTiddler>>>…</$link>\n \n <<fields-table>>\n\n <$checkbox tag=\"$:/tags/MagicTabs/dashboard\"> Show in dashboard</$checkbox><br>\n\n <$list filter=\"[all[current]tag[$:/tags/MagicTabs/dashboard]]\">\n <h3>Dashboard</h3>\n <table>\n <tr>\n <td>mt-dashboard.add.content</td>\n <td><$edit-text field=\"mt-dashboard.add.content\" size=\"40\"/></td>\n </tr>\n <tr>\n <td>mt-dashboard.heading</td>\n <td><$edit-text field=\"mt-dashboard.heading\" size=\"40\"/></td>\n </tr>\n <tr>\n <td>mt-dashboard.icon</td>\n <td><$edit-text field=\"mt-dashboard.icon\" size=\"40\"/></td>\n </tr>\n </table>\n </$list>\n\n <br><h3>Template for {{!!caption}}</h3>\n\n <$list filter=\"[all[current]has[mt-template.fields]!mt-template.fields[]]\" emptyMessage=\"The template title hasn't been defined\">\n\n <$macrocall $name=\"fields-table\" tiddler={{!!mt-template.fields}}/>\n\n </$list>\n\n <br><br>\n\n </$reveal>\n\\end\n\n<<mt-slider-input tiddler:\"$:/plugins/amp/MagicTabs/new/type\" type:\"$:/type/type\" contentClass:\"tc-tiddler-info\">>\n\n!!Type manager\n\n<$list filter=\"[all[shadows+tiddlers]prefix[$:/type/]mt-source.type[$:/type/root]sort[]]\">\n\n <<edit-type \"font-size: 1.2em; font-weight: 500;\">>\n\n <$list filter=\"[all[shadows+tiddlers]prefix[$:/type]mt-source.type<currentTiddler>sort[]]\">\n\n <<edit-type \"padding-left:1.5em; font-size: 1.1em; font-weight: 400;\">>\n \n \t<$list filter=\"[all[shadows+tiddlers]prefix[$:/type]mt-source.type<currentTiddler>sort[]]\">\n\n \t<<edit-type \"padding-left:3em; font-size: 1.0em; font-weight: 300;\">>\n\n \t</$list>\n\n </$list>\n\n</$list>\n\n<strong>Unclassified</strong>\n\n<$list filter=\"[all[shadows+tiddlers]prefix[$:/type/]mt-source.type[]sort[]]\">\n\n<<edit-type \"padding-left:1em;\">>\n\n</$list>\n\n",
"caption": "Type manager",
"creator": "Alberto Molina Pérez",
"modified": "20150223123551714",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/config/TypeManager"
},
"$:/plugins/amp/MagicTabs/macros/typed-lists/filter": {
"created": "20150121220552330",
"text": "\\define mt-typed-filter-types(state)\n\n <$reveal state=\"$state$!!logic\" text=\"and\" type=\"match\">\n <$checkbox tiddler=\"$state$\" tag=\"$(type)$\">\n {{$(type)$!!caption}}\n </$checkbox>\n </$reveal>\n\n <$reveal state=\"$state$!!logic\" text=\"or\" type=\"match\">\n <$radio tiddler=\"$state$\" field=\"tags\" value=\"$(type)$\">\n {{$(type)$!!caption}}\n </$radio>\n </$reveal>\n\n\\end\n\n\\define mt-typed-filter(type,state)\n<table class=\"invisible\">\n<tr>\n<td class=\"\">\n<tr>\n<td style=\"padding:0.5em;\">\n<$set name=\"types\" filter=\"[[$type$]] [all[shadows+tiddlers]mt-source.type[$type$]]\">\n<$radio tiddler=\"$state$\" field=\"tags\" value=<<types>> > all</$radio>\n</$set>\n</td>\n<td style=\"padding:0.5em;\">\n<$radio tiddler=\"$state$\" field=\"tags\" value=\"\" > none</$radio>\n</td>\n</tr>\n<tr>\n<td style=\"padding:0.5em;\">\n<$radio tiddler=\"$state$\" field=\"logic\" value=\"or\" > or</$radio>\n</td>\n<td style=\"padding:0.5em;\">\n<$radio tiddler=\"$state$\" field=\"logic\" value=\"and\" > and</$radio>\n</td>\n</tr>\n</td>\n<$list filter=\"[[$type$]] [all[shadows+tiddlers]mt-source.type[$type$]]\" variable=\"type\">\n<td>\n<<mt-typed-filter-types \"$state$\">>\n</td>\n</$list>\n</tr>\n</table>\n\\end\n\n<<mt-typed-filter \"$:/type/note\" \"$:/state/MagicTabs/list/notes\">>\n\n\n",
"creator": "Alberto Molina Pérez",
"modified": "20150225205055149",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/tags/Macro $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/typed-lists/filter"
},
"$:/plugins/amp/MagicTabs/macros/fields-table": {
"created": "20150119104938431",
"text": "\\define fields-table2(tiddler, fieldTitle:\"title\")\n <$reveal state=\"$tiddler$!!modified\" type=\"match\" text=\"\">\n The tiddler [[$tiddler$]] doesn't exist.\n </$reveal>\n <$reveal state=\"$tiddler$!!modified\" type=\"nomatch\" text=\"\">\n <$tiddler tiddler=\"$tiddler$\">\n <table class=\"\" style=\"width: 100%\">\n <tbody>\n <tr>\n <td>title</td>\n <td><$edit-text field=\"$fieldTitle$\" size=\"40\" class=\"tc-edit-fields\"/></td>\n </tr>\n <$list filter=\"[all[current]fields[]sort[]] -created -creator -modified -modifier -title -text\" variable=\"field\">\n <tr>\n <td><<field>></td>\n <td><$edit-text field=<<field>> size=\"40\" class=\"tc-edit-fields\"/></td>\n </tr>\n </$list>\n <tr>\n <td>text</td>\n <td><$edit-text field=\"text\" class=\"tc-edit-texteditor\"/></td>\n </tr>\n </tbody>\n </table>\n </$tiddler>\n </$reveal>\n\\end\n\n\\define fields-table(tiddler, fieldTitle:\"title\")\n <$reveal default=\"$tiddler$\" text=\"\" type=\"match\">\n <$macrocall $name=\"fields-table2\" tiddler=<<currentTiddler>> fieldTitle=\"$fieldTitle$\"/>\n </$reveal>\n <$reveal default=\"$tiddler$\" text=\"\" type=\"nomatch\">\n <$macrocall $name=\"fields-table2\" tiddler=\"$tiddler$\" fieldTitle=\"$fieldTitle$\"/>\n </$reveal>\n\\end\n",
"creator": "Alberto Molina Pérez",
"modified": "20150223120200103",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/tags/Macro $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/fields-table"
},
"$:/plugins/amp/MagicTabs/config/plugins": {
"text": "<$set name=\"plugins\" filter=>\n<table>\n<tr>\n<th colspan=\"3\" style=\"text-align:left; height:2em;\">Plugins installed</th>\n</tr>\n<tr style=\"text-align:left; height:2em;\">\n<td>Name</td>\n<td>Version</td>\n<td>Description</td>\n</tr>\n<$list filter=\"[type[application/json]prefix[$:/plugins/amp/MagicTabs]]\">\n<tr>\n<td><$link to={{!!title}}><$view field=\"caption\"/></$link></td>\n<td><$view field=\"version\"/></td>\n<td><$view field=\"description\"/></td>\n</tr>\n</$list>\n</table>\n</$set>",
"caption": "Plugins",
"created": "20150122145739025",
"creator": "Alberto Molina Pérez",
"modified": "20150129055356679",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/tags/MagicTabs/config $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/config/plugins"
},
"$:/plugins/amp/MagicTabs/templates/types/person": {
"created": "20150124080530695",
"text": "",
"about": "",
"creator": "Alberto Molina Pérez",
"icon": "$:/plugins/amp/MagicTabs/images/person",
"modified": "20150225225836903",
"modifier": "Alberto Molina Pérez",
"tags": "$:/type/person",
"title": "$:/plugins/amp/MagicTabs/templates/types/person",
"mt-person.birth.date": "",
"mt-person.birth.place": "",
"mt-person.death.date": "",
"mt-person.death.place": "",
"mt-person.gender": "",
"mt-person.name": "",
"mt-person.surname": "",
"mt-person.picture": ""
},
"$:/plugins/amp/MagicTabs/templates/types/note": {
"created": "20150124150601521",
"text": "",
"about": "",
"color": "#FFA500",
"creator": "Alberto Molina Pérez",
"description": "",
"icon": "$:/plugins/amp/MagicTabs/images/note",
"modified": "20150225225818542",
"modifier": "Alberto Molina Pérez",
"mt-source.tiddler": "",
"tags": "$:/type/note",
"title": "$:/plugins/amp/MagicTabs/templates/types/note",
"mt-source.parents.list": ""
},
"$:/plugins/amp/MagicTabs/templates/types/idea": {
"created": "20150124150700629",
"text": "",
"color": "#FFA500",
"creator": "Alberto Molina Pérez",
"description": "",
"icon": "$:/plugins/amp/MagicTabs/images/idea",
"modified": "20150225225952676",
"modifier": "Alberto Molina Pérez",
"tags": "$:/type/note $:/type/idea",
"title": "$:/plugins/amp/MagicTabs/templates/types/idea"
},
"$:/plugins/amp/MagicTabs/templates/types/comment": {
"created": "20150124152743141",
"text": "",
"color": "#daa520",
"creator": "Alberto Molina Pérez",
"icon": "$:/plugins/amp/MagicTabs/images/comment",
"modified": "20150225230007481",
"modifier": "Alberto Molina Pérez",
"mt-source.tiddler": "",
"tags": "$:/type/comment $:/type/note",
"title": "$:/plugins/amp/MagicTabs/templates/types/comment"
},
"$:/plugins/amp/MagicTabs/macros/mt-slider-input": {
"created": "20150124213722018",
"creator": "Alberto Molina Pérez",
"text": "\\define mt-current-type() $:/temp/$(currentType)$\n\n\\define mt-topics-inherit() $(sourceTopics)$ $(templateTopics)$\n\n\\define mt-slider-input-button(tiddler, type, template, btnClass:\"tab\", contentClass)\n\n\t<$set name=\"currentType\" value={{$:/state/mt/slider-input}}>\n\n\t\t<$set name=\"currentTemp\" value=<<mt-current-type>>>\n\n\t\t\t<$reveal state=\"$type$!!modified\" type=\"match\" text=\"\">\n\n\t\t\t\t<$button popup=<<qualify \"$:/state/mt/slider-input-popup\">> class=\"btn-slider-input $btnClass$\" tooltip=\"add\">\n\n\t\t\t\t\t<$action-deletetiddler $tiddler=<<currentTemp>>/>\n\n\t\t\t\t\t<$reveal state=<<qualify \"$:/state/mt/slider-input-popup\">> type=\"match\" text=\"\" default=\"\">\n\n\t\t\t\t\t\t{{$:/core/images/new-button}}\n\n\t\t\t\t\t</$reveal>\n\n\t\t\t\t\t<$reveal state=<<qualify \"$:/state/mt/slider-input-popup\">> type=\"nomatch\" text=\"\" default=\"\">\n\n\t\t\t\t\t\t{{$:/core/images/cancel-button}}\n\n\t\t\t\t\t</$reveal>\n\n\t\t\t\t</$button>\n\n\t\t\t</$reveal>\n\n\t\t\t<$reveal state=\"$type$!!modified\" type=\"nomatch\" text=\"\">\n\n\t\t\t\t<$reveal default={{$type$!!mt-template.fields}} type=\"nomatch\" text=\"\">\n \n\t\t\t\t\t<$set name=\"hasRoot\" filter=\"[[$(storyTiddler)$]!mt-source.root[]]\" value={{$(storyTiddler)$!!mt-source.root}} emptyValue=\"\">\n\n\t\t\t\t\t\t<$set name=\"noRoot\" filter=\"[[$(storyTiddler)$]!mt-source.tiddler[]mt-source.root[]]\" value={{$(storyTiddler)$!!mt-source.tiddler}} emptyValue=\"\">\n\n\t\t\t\t\t\t\t<$set name=\"rootTiddler\" value=<<mt-select-root>>>\n\n\t\t\t\t\t\t\t<$set name=\"templateTopics\" filter=\"[[$template$]has[modified]!modified[]has[mt-topics.list]!mt-topics.list[]]\" value={{$template$!!mt-topics.list}} emptyValue=\"\">\n\n\t\t\t\t\t\t\t<$set name=\"sourceTopics\" value={{$(storyTiddler)$!!mt-topics.list}}>\n\n\n\t\t\t\t\t\t\t\t<$button popup=<<qualify \"$:/state/mt/slider-input-popup\">> class=\"btn-slider-input $btnClass$\" tooltip=\"add\">\n\n\t\t\t\t\t\t\t\t\t<$action-deletetiddler $tiddler=<<currentTemp>>/>\n\n\t\t\t\t\t\t\t\t\t<$action-setfield $tiddler=\"$:/state/mt/slider-input\" text=\"$type$\"/>\n \n\t\t\t\t\t\t\t\t\t<$action-setfield $tiddler={{$type$!!mt-template.fields}} title=\"$:/temp/$type$\"/>\n\n\t\t\t\t\t\t\t\t\t<$action-setfield $tiddler=\"$:/temp/$type$\" mt-source.tiddler=\"$(storyTiddler)$\" mt-source.root=<<rootTiddler>> mt-topics.list=<<mt-topics-inherit>>/>\n\n\t\t\t\t\t\t\t\t\t<$reveal state=<<qualify \"$:/state/mt/slider-input-popup\">> type=\"match\" text=\"\" default=\"\">\n\n\t\t\t\t\t\t\t\t\t\t{{$:/core/images/new-button}}\n\n\t\t\t\t\t\t\t\t\t</$reveal>\n\n\t\t\t\t\t\t\t\t\t<$reveal state=<<qualify \"$:/state/mt/slider-input-popup\">> type=\"nomatch\" text=\"\" default=\"\">\n\n\t\t\t\t\t\t\t\t\t\t{{$:/core/images/cancel-button}}\n\n\t\t\t\t\t\t\t\t\t</$reveal>\n\n\t\t\t\t\t\t\t\t</$button>\n\n\t\t\t\t\t\t\t</$set>\n\n\t\t\t\t\t\t\t</$set>\n\n\t\t\t\t\t\t\t</$set>\n\n\t\t\t\t\t\t</$set>\n\n\t\t\t\t\t</$set>\n\n\t\t\t\t</$reveal>\n\n\t\t\t</$reveal>\n\n\t\t</$set>\n\n\t</$set>\n \n \n\n\t<$reveal type=\"nomatch\" text=\"\" default=\"\" state=<<qualify \"$:/state/mt/slider-input-popup\">> class=\"tc-popup-handle\" animate=\"yes\" retain=\"yes\">\n\n\t\t<$reveal default=\"$tiddler$\" type=\"nomatch\" text=\"\">\n\n\t\t\t<div class=\"$contentClass$\">\n\n\t\t\t\t<$tiddler tiddler=\"$(storyTiddler)$\">\n\n\t\t\t\t\t<$transclude tiddler=\"\"\"$tiddler$\"\"\"/>\n\n </$tiddler>\n\n </div>\n\n </$reveal>\n\n <$reveal default=\"$tiddler$\" type=\"match\" text=\"\">\n\n <$list filter=\"[[$type$]prefix[$:/type/]has[modified]!modified[]]\" emptyMessage=\"\"\"No valid type defined\"\"\">\n\n <div class=\"$contentClass$\">\n\n !New {{$type$!!caption}}\n\n <<mt-new-tiddler \"$type$\">>\n\n </div>\n\n </$list>\n\n </$reveal>\n\n</$reveal>\n\\end\n\n\n\n\n\\define mt-slider-input-seek-template(tiddler, type, btnClass, contentClass)\n\n <$macrocall $name=\"mt-slider-input-button\"\n tiddler=\"$tiddler$\"\n type=\"$type$\"\n template={{$type$!!mt-template.fields}}\n btnClass=\"$btnClass$\"\n contentClass=\"$contentClass$\"\n />\n\n\\end\n\n\n\n\\define mt-slider-input-seek-form(type, btnClass, contentClass)\n\n <$macrocall $name=\"mt-slider-input-button\"\n tiddler={{$type$!!mt-template.form}}\n type=\"$type$\"\n template={{$type$!!mt-template.fields}}\n btnClass=\"$btnClass$\"\n contentClass=\"$contentClass$\"\n />\n\n\\end\n\n\n\n\n\\define mt-slider-input(tiddler, type, btnClass, contentClass)\n\n<$list filter=\"[[$tiddler$]] [[$type$]prefix[$:/type/]] +[has[title]limit[1]]\" emptyMessage=\"\"\"\n\t<$reveal state=\"$(currentTab)$!!mt-contents.type\" type=\"nomatch\" text=\"\">\n\t\t<$macrocall $name='mt-slider-input-seek-form' \n\t\t\ttype={{$(currentTab)$!!mt-contents.type}}\n\t\t\tbtnClass='$btnClass$'\n\t\t\tcontentClass='$contentClass$'\n\t\t\t/>\n\t</$reveal>\"\"\">\n\n<$list filter=\"[[$type$]has[modified]!modified[]]\" variable=\"ignore\" emptyMessage=\"\"\"\n\t<$macrocall $name='mt-slider-input-seek-template'\n\t\ttiddler='$tiddler$'\n\t\ttype={{$(currentTab)$!!mt-contents.type}}\n\t\tbtnClass='$btnClass$'\n\t\tcontentClass='$contentClass$'\n\t\t/>\n \"\"\">\n\n\t<$macrocall $name=\"mt-slider-input-button\"\n\t\ttiddler=\"$tiddler$\"\n\t\ttype=\"$type$\"\n\t\ttemplate={{$type$!!mt-template.fields}}\n\t\tbtnClass=\"$btnClass$\"\n\t\tcontentClass=\"$contentClass$\"\n\t\t/>\n\n</$list>\n\n</$list>\n\\end\n\n<<mt-slider-input type:\"$:/type/note\">>",
"modified": "20150308162649312",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/mt-slider-input",
"type": ""
},
"$:/plugins/amp/MagicTabs/macros/mt-tab-caption": {
"text": "\\define mt-tab-caption3(type, caption)\n<$set name=\"mt-list.filter\" filter=\"[[$(currentTab)$]has[mt-list.filter]!mt-list.filter[]]\" value={{$(currentTab)$!!mt-list.filter}} emptyValue=<<mt-tab-filter \"$type$\">> >\n<$set name=\"mt-list.filter_alt\" filter=\"[[$(currentTab)$]has[mt-list.filter_alt]!mt-list.filter_alt[]]\" value={{$(currentTab)$!!mt-list.filter_alt}} emptyValue=<<mt-tab-filter-alt \"$type$\">> >\n$caption$\n<$reveal state=\"$:/config/MagicTabs/caption/counter/$:/plugins/amp/MagicTabs\" type=\"match\" text=\"show\">\n <small><$count filter=<<mt-list.filter>>/>/<$count filter=<<mt-list.filter_alt>>/></small>\n</$reveal>\n</$set>\n</$set>\n\\end\n\n\n\n\n\n\n\\define mt-tab-caption2(type,caption)\n$caption$\n\\end\n\n\n\\define mt-tab-caption1(type, icon)\n <$macrocall $name=\"mt-tab-caption3\" type=\"$type$\" caption={{$icon$}}/>\n\\end\n\n\n\\define mt-tab-caption()\n <$reveal state=\"$(currentTab)$!!icon\" type=\"nomatch\" text=\"\">\n <$macrocall $name=\"mt-tab-caption1\" type={{$(currentTab)$!!mt-contents.type}} icon={{$(currentTab)$!!icon}}/>\n </$reveal>\n <$reveal state=\"$(currentTab)$!!icon\" type=\"match\" text=\"\">\n <$reveal state=\"$(currentTab)$!!description\" type=\"nomatch\" text=\"\">\n <$macrocall $name=\"mt-tab-caption3\" type={{$(currentTab)$!!mt-contents.type}} caption={{$(currentTab)$!!description}}/>\n </$reveal>\n <$reveal state=\"$(currentTab)$!!description\" type=\"match\" text=\"\">\n <$reveal state=\"$(currentTab)$!!mt-contents.type\" type=\"nomatch\" text=\"\">\n <$set name=\"caption\" filter=\"[[$(currentTab)$]get[mt-contents.type]removeprefix[$:/type/]]\">\n <$macrocall $name=\"mt-tab-caption3\" type={{$(currentTab)$!!mt-contents.type}} caption=<<caption>>/>\n </$set>\n </$reveal>\n <$reveal state=\"$(currentTab)$!!mt-contents.type\" type=\"match\" text=\"\">\n $(currentTab)$\n </$reveal>\n </$reveal>\n </$reveal>\n\\end",
"created": "20150124235715677",
"creator": "Alberto Molina Pérez",
"modified": "20150309185306109",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/mt-tab-caption"
},
"$:/plugins/amp/MagicTabs/templates/types/tab": {
"created": "20150125013421426",
"text": "<<mt-slider-input>>\n\n<<mt-tab-contents>>",
"caption": "<<mt-tab-caption>>",
"color": "#d3d3d3",
"creator": "Alberto Molina Pérez",
"description": "",
"icon": "",
"modified": "20150225230114429",
"modifier": "Alberto Molina Pérez",
"mt-contents.type": "",
"mt-list.filter": "",
"mt-list.filter_alt": "",
"mt-list.heading": "",
"mt-list.heading_alt": "",
"mt-list.sort": "",
"mt-list.sort_alt": "",
"mt-list.template": "",
"mt-list.template_alt": "",
"tags": "$:/type/tab MagicTabs",
"title": "$:/plugins/amp/MagicTabs/templates/types/tab"
},
"$:/plugins/amp/MagicTabs/templates/types/type": {
"created": "20150125150841844",
"text": "",
"caption": "",
"creator": "Alberto Molina Pérez",
"modified": "20150225230226262",
"modifier": "Alberto Molina Pérez",
"mt-template.fields": "",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/templates/types/type",
"mt-template.form": "",
"mt-source.type": ""
},
"$:/plugins/amp/MagicTabs/dashboard/input": {
"created": "20150126104647061",
"text": "\\define mt-current-temp()\n$:/temp/$(currentType)$\n\\end\n\n\\define mt-dashboard-input-button(type, template)\n\n<$set name=\"currentType\" value={{$:/state/mt/slider-input}}>\n\n\t\t<$button>\n\n\t\t\t<$action-deletetiddler $tiddler=<<mt-current-temp>>/>\n\n\t\t\t<$action-setfield $tiddler=\"$:/state/mt/slider-input\" text=\"$type$\"/>\n \n\t\t\t<$action-setfield $tiddler=\"$template$\" title=\"$:/temp/$type$\"/>\n\n\t\t\t<$action-setfield $tiddler=\"$:/state/mt/slider-input\" text=\"$type$\" default=\"$:/type/note\"/>\n\n\t\t\t{{$type$!!caption}}\n\n\t\t</$button>\n\n</$set>\n\n\\end\n\n\n\\define mt-dashboard-input-list(rootType, state)\n\n\t<$list filter=\"$rootType$ [all[shadows+tiddlers]prefix[$:/type]mt-source.type[$rootType$]sort[title]]\">\n\n\t\t<$macrocall $name=\"mt-dashboard-input-button\" type=<<currentTiddler>> template={{!!mt-template.fields}}/>\n\n\t</$list>\n\n\t<$reveal state=\"$state$\" type=\"nomatch\" text=\"\" default=\"$rootType$\">\n\n\t\t<$tiddler tiddler={{$state$!!text}}>\n\n\t\t\t!New {{!!caption}}\n\n\t\t\t<$list filter=\"[all[current]has[mt-dashboard.add.content]!mt-dashboard.add.content[]]\" emptyMessage=\"\"\"<$macrocall $name='mt-new-tiddler' type={{!!title}}/>\"\"\">\n\n\t\t\t\t<$transclude tiddler={{!!mt-dashboard.add.content}} mode=\"block\"/>\n \n\t\t\t</$list>\n\n\t\t</$tiddler>\n\n\t</$reveal>\n\\end\n\n<$macrocall $name=\"mt-dashboard-input-list\" rootType={{$:/state/mt/dashboard}} state=\"$:/state/mt/slider-input\"/>\n",
"creator": "Alberto Molina Pérez",
"modified": "20150227231945905",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/dashboard/input",
"type": ""
},
"$:/plugins/amp/MagicTabs/macros/mt-tab-contents": {
"text": "\\define mt-tab-contents3(tag, sort)\n<$list filter=\"[all[current]listed[mt-source.topics.list]] [all[tiddlers]mt-source.tiddler[$(storyTiddler)$]] +[tag[$tag$]!is[system]!has[draft.of]sort[$sort$]]\">\n<$link><$transclude tiddler={{!!icon}}/><$view field=\"title\"/></$link><br>\n</$list>\n\\end\n\n\\define mt-tab-contents2(tag, sort)\n<$set name=\"icon\" filter=\"[[$(currentTab)$]has[icon]!icon[]]\" value={{$(currentTab)$!!icon}}>\n<$set name=\"mt-list.heading\" filter=\"[[$(currentTab)$]has[mt-list.heading]!mt-list.heading[]]\" value={{$(currentTab)$!!mt-list.heading}} emptyValue={{$(currentTab)$!!description}}>\n<$set name=\"mt-list.heading_alt\" filter=\"[[$(currentTab)$]has[mt-list.heading_alt]!mt-list.heading[]]\" value={{$(currentTab)$!!mt-list.heading_alt}} emptyValue=\"Tagging\">\n<$set name=\"mt-list.filter\" filter=\"[[$(currentTab)$]has[mt-list.filter]!mt-list.filter[]]\" value={{$(currentTab)$!!mt-list.filter}} emptyValue=<<mt-tab-filter \"$tag$\" \"$sort$\">> >\n<$set name=\"mt-list.filter_alt\" filter=\"[[$(currentTab)$]has[mt-list.filter_alt]!mt-list.filter_alt[]]\" value={{$(currentTab)$!!mt-list.filter_alt}} emptyValue=<<mt-tab-filter-alt \"$tag$\">> >\n\n <h1><$transclude tiddler=<<icon>>/> <$text text=<<mt-list.heading>>/></h1>\n\n <$list filter=<<mt-list.filter>> template={{$(currentTab)$!!mt-list.template}} emptyMessage=\"none\"/>\n\n <h1><$transclude tiddler=<<icon>>/> <$text text=<<mt-list.heading_alt>>/></h1>\n\n <$list filter=<<mt-list.filter_alt>> template={{$(currentTab)$!!mt-list.template_alt}} emptyMessage=\"none\"/>\n\n</$set>\n</$set>\n</$set>\n</$set>\n\\end\n\n\\define buttonConfig(text)\n<$button set=<<qualify \"$:/state/MagicTabs/tab\">> setTo=\"$text$\">\n{{$:/core/images/options-button}}\n</$button>\n\\end\n\n\\define mt-tab-contents()\n<$reveal state=\"$(currentTab)$!!mt-contents.type\" type=\"nomatch\" text=\"\">\n\n <$macrocall $name=\"mt-tab-contents2\" tag={{$(currentTab)$!!mt-contents.type}} sort={{$(currentTab)$!!mt-list.sort}}/>\n\n</$reveal>\n\n<$reveal state=\"$(currentTab)$!!mt-contents.type\" text=\"\" type=\"match\">\n\n <$reveal state=\"$(currentTab)$!!mt-list.filter\" text=\"\" type=\"match\">\n\n!No results here!\n\n!!What do you want to show in this tab?\n\nPlease define either:\n\n# the type and description of the tiddlers you want to show (for instance: $:/type/comment):\n#> fill the fields `mt-contents.type` and `description` in the tiddler [[$(currentTab)$]]\n\n# the list filter, heading and template you want to use to show results:\n#> fill the fields `mt-list.filter`, `mt-list.heading`, `mt-list.template` in the tiddler [[$(currentTab)$]]\n\n </$reveal>\n\n</$reveal>\n\n\\end",
"created": "20150125101343318",
"creator": "Alberto Molina Pérez",
"modified": "20150309232620887",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/mt-tab-contents"
},
"$:/plugins/amp/MagicTabs/macros/mt-new-tiddler": {
"created": "20150128172217090",
"text": "\\define mt-select-root()\n$(hasRoot)$$(noRoot)$\n\\end\n\\define mt-new-tiddler-button(type, template, label:\"add\", class=\"\")\n\n<$set name=\"hasRoot\" filter=\"[[$(storyTiddler)$]!mt-source.root[]]\" value={{$(storyTiddler)$!!mt-source.root}} emptyValue=\"\">\n\n<$set name=\"noRoot\" filter=\"[[$(storyTiddler)$]!mt-source.tiddler[]mt-source.root[]]\" value={{$(storyTiddler)$!!mt-source.tiddler}} emptyValue=\"\">\n\n<$set name=\"rootTiddler\" value=<<mt-select-root>>>\n\n <$button tooltip=\"$label$\" class=\"$class$\">\n <$action-setfield $tiddler=\"$:/state/mt/new-tiddler\" text={{$:/temp/$type$!!draft.title}}/>\n <$action-setfield $tiddler=\"$:/temp/$type$\" title={{$:/temp/$type$!!draft.title}}/>\n <$action-setfield $tiddler={{$:/temp/$type$!!draft.title}} mt-source.tiddler=\"$(storyTiddler)$\" mt-source.root=<<rootTiddler>>/>\n <$action-deletetiddler $tiddler=\"$:/temp/$type$\"/>\n <$action-setfield $tiddler=\"$template$\" title=\"$:/temp/$type$\"/>\n <$action-setfield $tiddler=\"$:/temp/$type$\" mt-source.tiddler=\"$(storyTiddler)$\" mt-source.root=<<rootTiddler>>/>\n <$action-sendmessage $message=\"tm-notify\" $param=\"$:/plugins/amp/MagicTabs/notifications/new-tiddler\"/>\n $label$\n </$button>\n \n</$set>\n \n</$set>\n \n</$set>\n\n\\end\n\n\\define mt-new-tiddler(type,label:\"add\",class=\"\")\n\n <<mt-fields-form \"$type$\">>\n\n<$reveal state=\"$:/temp/$type$!!draft.title\" type=\"nomatch\" text=\"\">\n\n <$reveal default=\"$(currentTab)$\" type=\"nomatch\" text=\"\">\n\n <$macrocall $name=\"mt-new-tiddler-button\"\n type=\"$type$\"\n template={{$type$!!mt-template.fields}}\n mt-source.tiddler=\"$(storyTiddler)$\"\n />\n\n </$reveal>\n\n <$reveal default=\"$(currentTab)$\" type=\"match\" text=\"\">\n\n <$macrocall $name=\"mt-new-tiddler-button\"\n type=\"$type$\"\n template={{$type$!!mt-template.fields}}\n />\n\n </$reveal>\n\n</$reveal>\n\n\\end\n\n<<mt-new-tiddler \"$:/type/biography\">>",
"creator": "Alberto Molina Pérez",
"modified": "20150223234245094",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/tags/Macro $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/mt-new-tiddler"
},
"$:/plugins/amp/MagicTabs/macros/mt-fields-form": {
"created": "20150128172521135",
"creator": "Alberto Molina Pérez",
"text": "\\define mt-more-fields-btn()\n<div class=\"tc-table-of-contents\">\n\t<$reveal state=<<qualify \"$:/state/mt/slider\">> type=\"nomatch\" text=\"show\" default=\"\">\n <$button set=<<qualify \"$:/state/mt/slider\">> setTo=\"show\" class=\"tc-btn-invisible\">\n {{$:/core/images/right-arrow}} more\n </$button>\n </$reveal>\n <$reveal state=<<qualify \"$:/state/mt/slider\">> type=\"match\" text=\"show\" default=\"\">\n <$button set=<<qualify \"$:/state/mt/slider\">> setTo=\"hide\" class=\"tc-btn-invisible\">\n {{$:/core/images/down-arrow}} less\n </$button> \n </$reveal>\n</div>\n\\end\n\n\n\n\n\n\n\n\n\n\n\\define edit-field()\n<$edit-text field=$(field)$ placeholder={{$(template)$!!$(field)$}} default=\"\" class=\"tc-edit-fields\"/>\n\\end\n\n\n\n\n\n\n\n\n\\define mt-fields-form-more-table(type)\n\n<table class=\"\" style=\"width:100%\">\n <tr>\n \t<td style=\"height: 2em;\">Source:</td>\n \t<td colspan=\"4\" style=\"text-align: left;\"><$view field=\"mt-source.tiddler\"/></td>\n </tr>\n <tr>\n \t\t<td>Tags</td>\n \t<td colspan=\"4\"><$transclude tiddler=\"$:/core/ui/EditTemplate/tags\"/></td>\n </tr>\n <tr>\n \t<td>Icon</td>\n \t<td><$transclude tiddler={{!!icon}}/><<mt-change-icon>></td>\n \t<td style=\"text-align: right;\">Color</td>\n \t<td><$edit-text field=\"color\" tag=\"input\" class=\"tc-edit-fields\"/></td>\n\t</tr>\n <tr>\n \t<td>Description:</td>\n \t<td colspan=\"4\"><$edit-text field=\"description\" placeholder=\"Description\" tag=\"input\" class=\"tc-edit-fields\"/></td>\n </tr>\n <tr>\n \t<td>Parents:</td>\n \t<td colspan=\"4\"><$edit-text field=\"mt-source.parents.list\" placeholder=\"Parents\" tag=\"input\" class=\"tc-edit-fields\"/></td>\n </tr>\n <$list filter=\"[[$:/temp/$type$]tags[]prefix[$:/type/]get[mt-template.fields]fields[]] [[$(template)$]fields[]] -created -creator -modified -modifier -title -tags -mt-topics.list -text -icon -color -mt-source.parents.list -mt-source.tiddler -description\" variable=\"field\">\n <tr>\n <td><<field>></td>\n <td colspan=\"4\"><$macrocall $name=\"edit-field\"/></td>\n </tr>\n </$list>\n \t<tr style=\"text-align:right;\">\n <td colspan=\"5\">\n <small>\n <$list filter=\"[[$(template)$]has[title]!title[]limit[1]]\">\n [[edit the template|$(template)$]]\n </$list>\n <$list filter=\"[[$(template)$]!has[title]] +[limit[1]]\">\n This is a form based on a default template. You should create a custom template for <$link to=\"$type$\">$type$</$link>\n </$list>\n </small>\n </td>\n \t</tr>\n</table>\n\n\\end\n\n\n\n\n\n\n\n\n\\define mt-fields-form-more-inherit(type)\n\t<$set name=\"show\" filter=\"[[$type$]has[mt-source.type]!mt-source.type[]!mt-source.type[$:/type/root]]\" value=\"yes\" emptyValue=\"no\"> \n <$reveal default=<<show>> type=\"match\" text=\"yes\">\n <br><$checkbox tag=\"$(parentType)$\"> inherit fields (from {{$(parentType)$!!caption}}'s type)</$checkbox>\n </$reveal>\n\t</$set>\n\\end\n\n\n\n\n\n\n\n\\define mt-fields-form-more(type, size)\n\n<$tiddler tiddler=\"$:/temp/$type$\">\n\n<$set name=\"template\" filter=\"[[$type$]has[mt-template.fields]!mt-template.fields[]get[mt-template.fields]has[modified]!modified[]]\" value={{$type$!!mt-template.fields}} emptyValue=\"\">\n\n<$set name=\"parentType\" value={{$type$!!mt-source.type}}>\n\n<<mt-more-fields-btn>>\n\n<$reveal state=<<qualify \"$:/state/mt/slider\">> type=\"match\" text=\"show\" default=\"$default$\">\n\n<<mt-fields-form-more-inherit type:\"$type$\">>\n\n<<mt-fields-form-more-table type:\"$type$\">>\n\n</$reveal>\n\n</$set>\n\n</$set>\n\n</$tiddler>\n\n\\end\n\n\n\n\n\n\n\n\\define mt-fields-form(type)\n<$list filter=\"[[$type$]has[modified]!modified[]]\" emptyMessage=\"The tiddler [[$type$]] doesn't exist.\">\n\n<$reveal state=\"$:/temp/$type$!!modified\" type=\"nomatch\" text=\"\" default=\"\">\n\n<$tiddler tiddler=\"$:/temp/$type$\">\n\n<table class=\"invisible\" style=\"width:100%\">\n<tr>\n<td>\n<$edit-text field<$edit-text field=\"draft.title\" placeholder=\"Title\" class=\"tc-edit-fields\"/><<mt-check-title>>\n</td>\n<td>\n</td>\n</tr>\n<tr>\n<td>\n<$edit-text field=\"mt-topics.list\" placeholder=\"Topics [[Inside brackets]]\" tag=\"input\" class=\"tc-edit-fields\"/>\n</td>\n<td style=\"width: 5px;\">{{$:/plugins/amp/MagicTabs/images/question-circle}}</td>\n</tr>\n<tr>\n<td>\n<$edit-text field=\"text\" placeholder=\"Text\" default=\"\" tag=\"textarea\" class=\"tc-edit-fields\"/>\n</td>\n<td></td>\n</tr>\n</table>\n\n<<mt-fields-form-more type:\"$type$\">>\n\n</$tiddler>\n\n</$reveal>\n\n<$reveal state=\"$:/temp/$type$!!modified\" type=\"match\" text=\"\" default=\"\">\n\n[[$:/temp/$type$]] doesn't exit!\n\n</$reveal>\n\n</$list>\n\\end\n\n<<mt-fields-form type:\"$:/type/comment\">>",
"modified": "20150308162756702",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/tags/Macro $:/plugins/amp/MagicTabs/common",
"test": "",
"title": "$:/plugins/amp/MagicTabs/macros/mt-fields-form"
},
"$:/plugins/amp/MagicTabs/css/table/invisible": {
"text": "html body.tc-body .invisible {\n border-color:#fff;\n border-width:0px\n}\n\nhtml body.tc-body .invisible th {\n border-color:#fff;\n border-width:0px;\n}\n\nhtml body.tc-body .invisible tr {\n border-color:#fff;\n border-width:0px;\n}\n\nhtml body.tc-body .invisible td {\n border-color:#fff;\n border-width:0px;\n}",
"created": "20150128211934202",
"creator": "Alberto Molina Pérez",
"modified": "20150129055404332",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Stylesheet MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/css/table/invisible"
},
"$:/plugins/amp/MagicTabs/css/bottom-tabs": {
"created": "20140620142406356",
"text": ".bottom-tabs {\n margin: 0px 0px -42px 0px;\n}\n\n.tc-tab-divider {\n display: none;\n}\n\n.tc-tiddler-controls .close-tabs {\n color: red;\n min-width:2em;\n position: relative;\n bottom: -3px;\n right: -6px;\n}\n\n.bottom-tabs div.tc-tab-buttons {\n text-align: {{$:/config/MagicTabs/position/$:/plugins/amp/MagicTabs}};\n padding: 0px 0px 14px 0px;\n}\n\n.bottom-tabs .tc-tab-buttons button{\n color: {{$:/config/MagicTabs/caption/color/$:/plugins/amp/MagicTabs}};\n background-color: transparent;\n min-width:2em;\n display:inline-block;\n font-size: {{$:/config/MagicTabs/caption/font-size/$:/plugins/amp/MagicTabs}};\n text-align:center;\n border-radius: 10px 10px 0px 0px;\n box-shadow: 2px 2px 3px rgba(0, 0, 0, 0) inset;\n}\n\n\n.bottom-tabs .tc-tab-buttons button:not(.tc-tab-selected) {\n background-color: <<color background>>;\n border-left: <<color background>>;\n border-right: <<color background>>;\n border-top: <<color background>>;\n}\n\n.bottom-tabs .tc-tab-buttons button:not(.tc-tab-selected):hover {\n color: <<color foreground>>;\n font-weight: bold;\n font-size: {{$:/config/MagicTabs/caption-selected/font-size/$:/plugins/amp/MagicTabs}};\n margin-top:-5px;\n}\n\n\n.bottom-tabs .tc-tab-buttons button.tc-tab-selected {\n font-weight: bold;\n font-size: {{$:/config/MagicTabs/caption-selected/font-size/$:/plugins/amp/MagicTabs}};\n padding-bottom:6px;\n margin-bottom: -4px;\n box-shadow: 2px 2px 3px rgba(0, 0, 0, 0.1) inset;\n}\n\n.bottom-tabs .tc-tab-buttons.blue button.tc-tab-selected {\n background-color: {{$:/config/MagicTabs/colors/$:/plugins/amp/MagicTabs##blue}};\n}\n\n.bottom-tabs .tc-tab-buttons.red button.tc-tab-selected {\n background-color: {{$:/config/MagicTabs/colors/$:/plugins/amp/MagicTabs##red}};\n}\n\n.bottom-tabs .tc-tab-buttons.yellow button.tc-tab-selected {\n background-color: {{$:/config/MagicTabs/colors/$:/plugins/amp/MagicTabs##yellow}};\n}\n\n.bottom-tabs .tc-tab-content {\n margin: -14px -42px 0px -42px;\n padding: 14px 42px 14px 42px;\n}\n\n.bottom-tabs .tc-tab-content.blue {\n background-color: {{$:/config/MagicTabs/colors/$:/plugins/amp/MagicTabs##blue}};\n border-top: 1px solid <<colour tiddler-info-border>>;\n border-bottom: 1px solid <<colour tiddler-info-border>>;\n box-shadow: 1px 2px 3px rgba(0, 0, 0, 0.1) inset;\n}\n\n.bottom-tabs .tc-tab-content.red {\n background-color: {{$:/config/MagicTabs/colors/$:/plugins/amp/MagicTabs##red}};\n border-top: 1px solid <<colour tiddler-info-border>>;\n border-bottom: 1px solid <<colour tiddler-info-border>>;\n box-shadow: 1px 2px 3px rgba(0, 0, 0, 0.1) inset;\n}\n\n.bottom-tabs .tc-tab-content.yellow {\n background-color: {{$:/config/MagicTabs/colors/$:/plugins/amp/MagicTabs##yellow}};\n border-top: 1px solid <<colour tiddler-info-border>>;\n border-bottom: 1px solid <<colour tiddler-info-border>>;\n box-shadow: 1px 2px 3px rgba(0, 0, 0, 0.1) inset;\n}",
"creator": "Alberto Molina Pérez",
"title": "$:/plugins/amp/MagicTabs/css/bottom-tabs",
"tags": "$:/tags/Stylesheet MagicTabs $:/plugins/amp/MagicTabs/common",
"modifier": "Alberto Molina Pérez",
"modified": "20150213101654520",
"list-after": "",
"dependencies": "$:/config/MagicTabs/colors/$:/plugins/amp/MagicTabs $:/config/MagicTabs/position/$:/plugins/amp/MagicTabs"
},
"$:/plugins/amp/MagicTabs/macros/mt-tab-filter": {
"text": "\\define mt-tab-filter(type:\"$:/type/note\", sort)\n[all[current]listed[mt-topics.list]] [all[current]listed[mt-source.authors.list]] [all[current]listed[mt-source.parents.list]] [all[tiddlers]mt-source.tiddler[$(storyTiddler)$]] +[tag[$type$]!is[system]!has[draft.of]sort[$sort$]]\n\\end\n\n\\define mt-tab-filter-alt(type:\"$:/type/note\", sort)\n[all[current]tagging[]] [all[tiddlers]mt-source.root<currentTiddler>] -[all[tiddlers]mt-source.tiddler<currentTiddler>] -[all[current]listed[mt-topics.list]] -[all[current]listed[mt-source.authors.list]] -[all[current]listed[mt-source.parents.list]] +[tag[$type$]!title{!!title}!is[system]!has[draft.of]sort[$sort$]]\n\\end\n\n",
"created": "20150103211944329",
"creator": "Alberto Molina Pérez",
"modified": "20150309185945746",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/mt-tab-filter",
"type": ""
},
"$:/plugins/amp/MagicTabs/dashboard/configuration": {
"created": "20150106011214786",
"creator": "Alberto Molina Pérez",
"text": "<<tabs \"$:/plugins/amp/MagicTabs/config/plugins $:/plugins/amp/MagicTabs/config/TypeManager $:/plugins/amp/MagicTabs/config/TabManager $:/plugins/amp/MagicTabs/config/appearance\" \"$:/plugins/amp/MagicTabs/config/plugins\">>",
"caption": "~MagicTabs",
"icon": "$:/plugins/amp/MagicTabs/images/config",
"modified": "20150208171729445",
"modifier": "Alberto Molina Pérez",
"mt-dashboard.heading": "Configuration",
"mt-dashboard.icon": "$:/plugins/amp/MagicTabs/images/config",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common $:/tags/ControlPanel",
"title": "$:/plugins/amp/MagicTabs/dashboard/configuration"
},
"$:/plugins/amp/MagicTabs/images/caret-up": {
"text": "<<mt-image \"fa-caret-up\" \"here\" \"Here\">>",
"created": "20150129120721935",
"creator": "Alberto Molina Pérez",
"modified": "20150129120829575",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/caret-up"
},
"$:/plugins/amp/MagicTabs/new/type": {
"created": "20150125145129803",
"text": "\\define new-type-button(extension)\n <$reveal state=\"!!caption\" type=\"nomatch\" text=\"\">\n <$button set=\"$:/state/new-type\" setTo=\"$:/type/$extension$\" class=\"btn-big green\">\n <$action-sendmessage $message=\"tm-notify\" $param=\"$:/plugins/amp/MagicTabs/notifications/new-type\"/>\n <$action-setfield title=\"$:/type/$extension$\"/>\n\t\t\tcreate\n </$button>\n </$reveal>\n\n <$reveal state=\"!!caption\" type=\"match\" text=\"\">\n <$button class=\"btn-big grey\">\n create\n </$button>\n </$reveal>\n\\end\n\n\n\n\\define mt-check-template(template, type)\n <$reveal state=\"$template$!!modified\" type=\"nomatch\" text=\"\">\n <$button set=\"$:/state/new-template\" setTo=\"$template$\">\n assign @@color:green;{{$:/plugins/amp/MagicTabs/images/done}}@@\n </$button>\n </$reveal>\n\n <$reveal state=\"$template$!!modified\" type=\"match\" text=\"\">\n <$button set=\"$:/state/new-template\" setTo=\"$template$\">\n <$action-setfield $tiddler=\"$:/temp/new-template\" tags=\"$type$\"/>\n <$action-setfield $tiddler=\"$:/temp/new-template\" title=\"$template$\"/>\n create\n </$button>\n </$reveal>\n\\end\n\n\n\n\n\\define mt-new-template-done(template)\n <$button set=\"$:/state/new-template\" setTo=\"done\" class=\"btn-big green\">\n <$action-sendmessage $message=\"tm-notify\" $param=\"$:/plugins/amp/MagicTabs/notifications/new-type\"/>\n <$action-sendmessage $message=\"tm-notify\" $param=\"$:/plugins/amp/MagicTabs/notifications/new-template\"/>\n done\n </$button>\n\\end\n\n\n\n\n\\define mt-start-again-button()\n <$button class=\"btn-big red\">\n <$action-deletetiddler $tiddler=\"$:/state/new-type\"/>\n <$action-deletetiddler $tiddler=\"$:/state/new-template\"/>\n <$action-deletetiddler $tiddler=\"$:/temp/$:/type/type\"/>\n <$action-deletetiddler $tiddler=\"$:/state/new-template\"/>\n <$action-setfield $tiddler=\"$:/temp/$:/type/type\" text=\"\"/>\n start again\n </$button>\n\\end\n\n\n\n\n\n!New tiddler type in two steps\n\n\n<$reveal state=\"$:/state/new-type\" type=\"match\" text=\"\" default=\"\">\n\n\n<$tiddler tiddler=\"$:/temp/$:/type/type\">\n\n!!1. Create a new type\n\n<<<\n\n<table class=\"invisible\">\n<tr>\n<td>name</td>\n<td>$:/type/<$reveal state=\"!!caption\" type=\"match\" text=\"\">@@color:grey;extension@@</$reveal><$reveal state=\"!!caption\" type=\"nomatch\" text=\"\">{{!!caption}}</$reveal></td>\n</tr>\n<tr>\n<td>extension</td>\n<td>\n<$edit-text field=\"caption\" placeholder=\"example: note, journal, task, etc.\" tag=\"input\" size=\"30\"/>\n</td>\n</tr>\n<tr>\n<td></td>\n<td></td>\n</tr>\n<tr>\n<td>parents</td>\n<td>\n<$select field=\"parents\">\n<option></option>\n<$list filter=\"[all[shadows+tiddlers]prefix[$:/type/]sort[]]\" variable=\"type\">\n<option value=<<type>>><$view tiddler=<<type>> field=\"caption\"/></option>\n</$list>\n</$select>\n</td>\n</tr>\n<tr style=\"\">\n<td></td>\n<td style=\"text-align:left\"><br><$macrocall $name=\"new-type-button\" extension={{!!caption}}/></td>\n</tr>\n</table>\n\n<<<\n\n@@color:grey;\n!!2. Assign or create a template\n@@\n\n</$tiddler>\n\n</$reveal>\n\n\n\n\n\n\n<$reveal state=\"$:/state/new-type\" type=\"nomatch\" text=\"\" default=\"\">\n\n<$tiddler tiddler={{$:/state/new-type}}>\n\n!!1. Create a new type @@color:green;{{$:/plugins/amp/MagicTabs/images/done}}@@\n\n:<$transclude tiddler=\"tag\"/>\n\n\n<$reveal state=\"$:/state/new-template\" type=\"nomatch\" text=\"done\" default=\"\">\n\n!!2. Assign or create a template\n\n</$reveal>\n\n\n<$reveal state=\"$:/state/new-template\" type=\"match\" text=\"done\" default=\"\">\n\n!!2. Assign or create a template@@color:green;{{$:/plugins/amp/MagicTabs/images/done}}@@\n\n:<$link to={{!!mt-template.fields}}><$view field=\"mt-template.fields\"/></$link>\n\n<<mt-start-again-button>>\n\n</$reveal>\n\n\n\n<$reveal state=\"$:/state/new-template\" type=\"match\" text=\"\" default=\"\">\n\n<table class=\"invisible\">\n<tr>\n<td>//In order to create new tiddlers based on that type, you should assign or create a template://<br><br></td>\n</tr>\n<tr>\n<td><$edit-text field=\"mt-template.fields\" placeholder=\"template title\" tag=\"input\" size=\"40\"/>\n<$reveal state=\"!!mt-template.fields\" type=\"nomatch\" text=\"\"> <$macrocall $name=\"mt-check-template\" template={{!!mt-template.fields}} type={{$:/state/new-type}}/></$reveal>\n</td>\n</tr>\n</table>\n\n</$reveal>\n\n\n<$reveal state=\"!!mt-template.fields\" type=\"nomatch\" text=\"\">\n<$reveal state=\"$:/state/new-template\" type=\"match\" text={{!!mt-template.fields}} default=\"\">\n\n<$tiddler tiddler={{!!mt-template.fields}}>\n\n<table class=\"invisible\">\n<tr>\n<td>Edit the template</td>\n</tr>\n<tr>\n<td>\n<h2><$view field=\"title\"/></h2>\n</td>\n</tr>\n<tr>\n<td>{{||$:/core/ui/EditTemplate/tags}}</td>\n</tr>\n<tr>\n<td><$edit-text field=\"text\" placeholder=\"text\" class=\"tc-edit-texteditor\"/></td>\n</tr>\n<tr>\n<td>{{||$:/core/ui/EditTemplate/fields}}</td>\n</tr>\n<tr>\n<td><br><<mt-new-template-done template={{!!mt-template.fields}}>></td>\n</tr>\n</table>\n\n\n\n</$tiddler>\n\n</$reveal>\n</$reveal>\n\n</$tiddler>\n\n</$reveal>",
"creator": "Alberto Molina Pérez",
"modified": "20150223121300171",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs",
"title": "$:/plugins/amp/MagicTabs/new/type"
},
"$:/plugins/amp/MagicTabs/notifications/new-type": {
"created": "20150131213454204",
"creator": "Alberto Molina Pérez",
"text": "<$tiddler tiddler={{$:/state/new-type}}>\n<$reveal state=\"!!modified\" type=\"nomatch\" text=\"\" default=\"\">\n<$tiddler tiddler={{$:/state/new-type}}>\n<$transclude tiddler=\"tag\"/>\n</$tiddler>\n</$reveal>\n</$tiddler>\n successfully created !",
"modified": "20150204104631020",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/notifications/new-type"
},
"$:/plugins/amp/MagicTabs/notifications/new-template": {
"text": "<$tiddler tiddler={{$:/state/new-template}}>\n<$reveal state=\"!!modified\" type=\"nomatch\" text=\"\" default=\"\">\n<$link><$view field=\"title\"/></$link>\n</$reveal>\n</$tiddler>\n\nSuccessfully created !",
"created": "20150131213906720",
"creator": "Alberto Molina Pérez",
"modified": "20150131215909682",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/notifications/new-template"
},
"$:/plugins/amp/MagicTabs/new/tab": {
"created": "20150131222839042",
"creator": "Alberto Molina Pérez",
"text": "\\define mt-type-selector()\n <$select tiddler=\"$:/temp/$:/type/tab\" field=\"mt-contents.type\" default=\"\">\n <option></option>\n <$list filter=\"[all[shadows+tiddlers]prefix[$:/type/]mt-source.parents.list[$:/type/root]sort[]]\">\n <option value={{!!title}}><strong><$view field=\"caption\"/></strong></option>\n <$list filter=\"[all[shadows+tiddlers]mt-source.parents.list{!!title}sort[]]\">\n <option value={{!!title}}> <$view field=\"caption\"/></option>\n </$list>\n </$list>\n <$list filter=\"[all[shadows+tiddlers]prefix[$:/type/]mt-source.parents.list[]sort[]]\">\n <option value={{!!title}}><$view field=\"caption\"/></option>\n </$list>\n </$select>\n\\end\n\n\n\n\n\n\n\n\\define mt-check-template()\n <$reveal state=\"!!mt-contents.type\" type=\"nomatch\" text=\"\">\n <$tiddler tiddler={{!!mt-contents.type}}>\n <$reveal state=\"!!mt-template.fields\" type=\"match\" text=\"\">\n @@color:red;This type has no valid template!@@\n </$reveal>\n <$reveal state=\"!!mt-template.fields\" type=\"nomatch\" text=\"\">\n <$tiddler tiddler={{!!mt-template.fields}}>\n <$reveal state=\"!!modified\" type=\"match\" text=\"\">\n @@color:red;This type has no valid template!@@\n </$reveal>\n </$tiddler>\n </$reveal>\n </$tiddler>\n </$reveal>\n\\end\n\n\n\n\n\n\n\\define mt-types-list-checkboxes()\n <div class=\"troiscolonnes\">\n <$checkbox tiddler=\"$:/temp/$:/type/tab\" tag=\"$:/tabs/all\"> ''all''</$checkbox><br>\n <$checkbox tiddler=\"$:/temp/$:/type/tab\" tag=\"$:/tabs/typed\"> ''typed''</$checkbox><br><br><br>\n </div>\n <div class=\"troiscolonnes\">\n <$list filter=\"[all[shadows+tiddlers]prefix[$:/type/]] -$:/type/type -$:/type/tab +[removeprefix[$:/type/]addprefix[$:/tabs/]sort[]]\">\n <$set name=\"caption\" filter=\"[all[current]removeprefix[$:/tabs/]]\">\n <$checkbox tiddler=\"$:/temp/$:/type/tab\" tag={{!!title}}> <<caption>></$checkbox><br>\n </$set>\n </$list>\n </div>\n\\end\n\n\n\n\n\n\n\\define mt-seek-icon()\n <$reveal state=\"$:/state/mt/new-tab!!icon\" type=\"nomatch\" text=\"change\" default=\"\">\n <div class=\"troiscolonnes\">\n <$radio tiddler=\"$:/temp/$:/type/tab\" field=\"icon\" value=\"$:/plugins/amp/MagicTabs/images/default\">\n <$transclude tiddler=\"$:/plugins/amp/MagicTabs/images/default\"/>\n <span class=\"text-grey\">\n (default)\n </span>\n </$radio>\n <br> \n <$list filter=\"[all[current]has[mt-contents.type]!field:mt-contents.type[]get[mt-contents.type]has[mt-template.fields]!mt-template.fields[]get[mt-template.fields]has[icon]!icon[]]\">\n <$radio tiddler=\"$:/temp/$:/type/tab\" field=\"icon\" value={{!!icon}}>\n <$transclude tiddler={{!!icon}}/>\n <span class=\"text-grey\">\n <$tiddler tiddler={{$:/temp/$:/type/tab!!mt-contents.type}}>\n (<$view field=\"caption\"/>)\n </$tiddler>\n </span>\n </$radio>\n </$list>\n <br> \n <$radio tiddler=\"$:/state/mt/new-tab\" field=\"icon\" value=\"change\">\n <$button set=\"$:/state/mt/new-tab!!icon\" setTo=\"change\" class=\"tc-btn-invisible\">\n other\n </$button>\n </$radio>\n </div>\n </$reveal>\n\n <$reveal state=\"$:/state/mt/new-tab!!icon\" type=\"match\" text=\"change\" default=\"\">\n <$edit-text tiddler=\"$:/temp/$:/type/tab\" field=\"icon\" tag=\"input\" size=\"40\"/>\n <$macrocall $name=\"mt-clear-field\" tiddler=\"$:/temp/$:/type/tab\" field=\"icon\" state=\"$:/state/mt/new-tab!!icon\"/>\n </$reveal>\n\\end\n\n\n\n\n\n\n\n\n\n\n\n\\define mt-new-tab-more-info()\n <div class=\"tc-table-of-contents\">\n <$reveal state=\"$:/state/mt/new-tab!!more-info\" type=\"nomatch\" text=\"show\" default=\"hide\">\n <$button set=\"$:/state/mt/new-tab!!more-info\" setTo=\"show\" class=\"tc-btn-invisible\">\n {{$:/core/images/right-arrow}} more info\n </$button>\n </$reveal>\n <$reveal state=\"$:/state/mt/new-tab!!more-info\" type=\"match\" text=\"show\">\n <$button set=\"$:/state/mt/new-tab!!more-info\" setTo=\"hide\" class=\"tc-btn-invisible\">\n {{$:/core/images/down-arrow}} more info\n </$button>\n </$reveal>\n </div>\n\n <$reveal state=\"$:/state/mt/new-tab!!more-info\" type=\"match\" text=\"show\">\n <span class=\"text-grey\">The information above is enough to create a magic tab using default parameters. But if you want more control, you can fill or change the fields below. </span>\n <table>\n <$list filter=\"[[$:/plugins/amp/MagicTabs/templates/types/tab]fields[]sort[]] -created -creator -modified -modifier -title -draft.title -text\" variable=\"field\">\n <tr>\n <td><<field>></td>\n <td><$edit-text tiddler=\"$:/temp/$:/type/tab\" field=<<field>> size=\"40\"/></td>\n </tr>\n </$list>\n <tr>\n <td>text</td>\n <td><$edit-text tiddler=\"$:/temp/$:/type/tab\" field=\"text\" class=\"tc-edit-texteditor\"/></td>\n </tr>\n </table>\n </$reveal>\n\\end\n\n\n\n\n\n\n\n\n\n\n\\define mt-check-field(field)\n<$reveal state=\"$:/state/mt/new-tab!!status\" type=\"match\" text=\"incomplete\"><$reveal state=\"$field$\" type=\"match\" text=\"\">@@color:red; incomplete@@</$reveal></$reveal>\n\\end\n\n\n\n\n\n\n\n\n\n\n!Create a new tab\n\n<$tiddler tiddler=\"$:/temp/$:/type/tab\">\n\n|invisible|k\n|Tiddler: |<$edit-text field=\"draft.title\" placeholder=\"title of the tiddler that will contain the tab\" tag=\"input\" size=\"40\"/><<mt-check-field \"draft.title\">>|\n|Description: |<$edit-text field=\"description\" placeholder=\"what this tab is about (ie notes, quotes, tasks…)\" tag=\"input\" size=\"40\"/><<mt-check-field \"description\">>|\n|Contents type*: |<<mt-type-selector>> <<mt-check-template>>|\n| |<span class=\"text-grey\">* The type of contents you want to show in that tab. Required information will be taken from its template.</span> |\n\n|invisible|k\n|Tiddlers typed: |<span class=\"text-grey\">This tab will be displayed at the bottom of tiddlers belonging to the following types.</span> |\n| |<<mt-types-list-checkboxes>>|\n| | |\n|Icon: |<<mt-seek-icon>> |\n| | |\n|<<mt-new-tab-more-info>>|<|\n\n\n<br>\n<$reveal state=\"!!draft.title\" type=\"nomatch\" text=\"\" default=\"\">\n<$reveal state=\"!!description\" type=\"nomatch\" text=\"\" default=\"\">\n\n<$button class=\"btn-big green\">\n<$action-setfield title={{!!draft.title}}/>\n<$action-deletetiddler $tiddler=\"$:/temp/$:/type/tab\"/>\n<$action-deletetiddler $tiddler=\"$:/state/mt/new-tab\"/>\n<$action-setfield $tiddler=\"$:/plugins/amp/MagicTabs/templates/types/tab\" title=\"$:/temp/$:/type/tab\"/>\n<$action-setfield $tiddler=\"$:/temp/$:/type/tab\" description=\"\"/>\ncreate\n</$button>\n\n</$reveal>\n</$reveal>\n\n<$list filter=\"[all[current]!has[draft.title]] [all[current]has[draft.title]field:draft.title[]] [all[current]!has[description]] [all[current]has[description]field:description[]]\">\n<$button set=\"$:/state/mt/new-tab!!status\" setTo=\"incomplete\" class=\"btn-big grey\">\ncreate\n</$button>\n</$list>\n\n</$tiddler>",
"modified": "20150308161622807",
"modifier": "Alberto Molina Pérez",
"tags": "$:/plugins/amp/MagicTabs/common MagicTabs",
"title": "$:/plugins/amp/MagicTabs/new/tab"
},
"$:/plugins/amp/MagicTabs/macros/mt-clear-field": {
"text": "\\define mt-clear-field(tiddler, field, state)\n<$button set=\"$state$\" setTo=\"\" class=\"tc-btn-invisible\">\n <$action-setfield $tiddler=\"$tiddler$\" $field$=\"\"/>\n {{$:/core/images/close-button}}\n</$button>\n\\end\n\n<<mt-clear-field>>",
"created": "20141122104624235",
"creator": "Alberto Molina Pérez",
"modified": "20150208011602092",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/mt-clear-field"
},
"$:/type/tab": {
"text": "",
"caption": "tab",
"created": "20141231095605837",
"creator": "Alberto Molina Pérez",
"icon": "$:/plugins/amp/MagicTabs/images/magic",
"modified": "20150220220853357",
"modifier": "Alberto Molina Pérez",
"mt-source.parents": "",
"mt-template.fields": "$:/plugins/amp/MagicTabs/templates/types/tab",
"mt-template.form": "",
"title": "$:/type/tab"
},
"$:/type/type": {
"created": "20150125151011440",
"text": "",
"caption": "type",
"creator": "Alberto Molina Pérez",
"modified": "20150223121018888",
"modifier": "Alberto Molina Pérez",
"mt-template.fields": "$:/plugins/amp/MagicTabs/templates/types/type",
"title": "$:/type/type",
"mt-source.type": ""
},
"$:/plugins/amp/MagicTabs/notifications/new-tiddler": {
"created": "20150202180208817",
"creator": "Alberto Molina Pérez",
"text": "<$tiddler tiddler={{$:/state/mt/new-tiddler}}>\n<$reveal state=\"!!modified\" type=\"nomatch\" text=\"\" default=\"\">\n<$link><$view field=\"title\"/></$link>\n</$reveal>\n</$tiddler>\nhas been successfully created !",
"modified": "20150202182216822",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/notifications/new-tiddler"
},
"$:/type/biography": {
"created": "20150125150841844",
"text": "",
"caption": "biography",
"creator": "Alberto Molina Pérez",
"modified": "20150223120937733",
"modifier": "Alberto Molina Pérez",
"mt-template.fields": "$:/plugins/amp/MagicTabs/templates/types/biography",
"mt-template.form": "",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/type/biography",
"mt-source.type": "$:/type/note"
},
"$:/plugins/amp/MagicTabs/tabs/biography": {
"created": "20150125013421426",
"text": "<<mt-slider-input>>\n\n<<mt-tab-contents>>",
"caption": "<<mt-tab-caption>>",
"color": "#d3d3d3",
"creator": "Alberto Molina Pérez",
"description": "Biography",
"icon": "$:/plugins/amp/MagicTabs/images/default",
"modified": "20150223210141637",
"modifier": "Alberto Molina Pérez",
"mt-contents.type": "$:/type/biography",
"mt-list.filter": "",
"mt-list.filter_alt": "",
"mt-list.heading": "",
"mt-list.heading_alt": "",
"mt-list.template": "$:/plugins/amp/MagicTabs/templates/tabs/biography",
"mt-list.template_alt": "",
"tags": "$:/type/tab $:/tabs/person $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/tabs/biography"
},
"$:/plugins/amp/MagicTabs/templates/tabs/biography": {
"created": "20150203133155624",
"creator": "Alberto Molina Pérez",
"text": "<h2><$link to={{!!title}}><$view field=\"title\"/></$link></h2>\n\n<h3><$transclude field=\"description\"/></h3>\n\n<$list filter=\"[all[current]mt-source.tiddler<currentTiddler>] [all[current]list[!!mt-topics.list]] [all[current]list[!!mt-source.parents.list]] -[title<storyTiddler>]\" template=\"$:/core/ui/TagTemplate\"/><$list filter=\"[all[current]tags[]!is[system]]\" template=\"$:/core/ui/TagTemplate\"/>\n\n<$transclude tiddler={{!!title}} mode=\"block\"/>\n",
"modified": "20150308161458215",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/reading",
"title": "$:/plugins/amp/MagicTabs/templates/tabs/biography"
},
"$:/plugins/amp/MagicTabs/templates/types/biography": {
"created": "20150225230043584",
"text": "",
"modified": "20150225230043584",
"modifier": "Alberto Molina Pérez",
"tags": "$:/type/biography",
"title": "$:/plugins/amp/MagicTabs/templates/types/biography",
"mt-source.tiddler": ""
},
"$:/type/task": {
"created": "20150125150841844",
"text": "",
"caption": "task",
"creator": "Alberto Molina Pérez",
"icon": "$:/plugins/amp/MagicTabs/images/check",
"modified": "20150223121409575",
"modifier": "Alberto Molina Pérez",
"mt-dashboard.heading": "Tasks",
"mt-dashboard.icon": "$:/plugins/amp/MagicTabs/images/check",
"mt-template.fields": "$:/plugins/amp/MagicTabs/templates/types/task",
"mt-template.form": "",
"tags": "$:/tags/MagicTabs/dashboard MagicTabs",
"title": "$:/type/task",
"mt-source.type": "$:/type/root"
},
"$:/plugins/amp/MagicTabs/tabs/tasks": {
"text": "<<mt-slider-input>>\n\n<<mt-tab-contents>>",
"caption": "<<mt-tab-caption>>",
"color": "#d3d3d3",
"created": "20150125013421426",
"creator": "Alberto Molina Pérez",
"description": "Tasks",
"icon": "$:/plugins/amp/MagicTabs/images/check",
"modified": "20150226123818107",
"modifier": "Alberto Molina Pérez",
"mt-contents.type": "$:/type/task",
"mt-list.filter": "",
"mt-list.filter_alt": "",
"mt-list.heading": "",
"mt-list.heading_alt": "Completed",
"mt-list.template": "$:/plugins/amp/MagicTabs/templates/tabs/tasks",
"mt-list.template_alt": "",
"tags": "$:/type/tab $:/plugins/amp/MagicTabs/common MagicTabs",
"title": "$:/plugins/amp/MagicTabs/tabs/tasks"
},
"$:/plugins/amp/MagicTabs/templates/tabs/tasks": {
"created": "20150109094612829",
"creator": "Alberto Molina Pérez",
"text": "<$checkbox field=\"mt-task.status\" checked=\"done\" unchecked=\"\"> <$link to={{!!title}}><$view field=\"title\"/></$link></$checkbox><br>",
"modified": "20150204112751323",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs",
"title": "$:/plugins/amp/MagicTabs/templates/tabs/tasks"
},
"$:/plugins/amp/MagicTabs/templates/types/task": {
"created": "20150204111530682",
"text": "",
"about": "",
"creator": "Alberto Molina Pérez",
"icon": "$:/plugins/amp/MagicTabs/images/check",
"modified": "20150225230139595",
"modifier": "Alberto Molina Pérez",
"mt-date.alpha": "",
"mt-date.due": "",
"mt-date.omega": "",
"mt-source.parents.list": "",
"mt-source.tiddler": "",
"mt-task.owner": "",
"mt-task.prority": "",
"mt-task.status": "",
"tags": "$:/type/task",
"title": "$:/plugins/amp/MagicTabs/templates/types/task"
},
"$:/plugins/amp/MagicTabs/templates/types/journal": {
"created": "20150223192616759",
"text": "",
"about": "",
"datetime": "",
"description": "",
"icon": "$:/core/images/new-journal-button",
"modified": "20150225225912940",
"modifier": "Alberto Molina Pérez",
"mt-source.tiddler": "",
"tags": "$:/type/journal",
"title": "$:/plugins/amp/MagicTabs/templates/types/journal"
},
"$:/plugins/amp/MagicTabs/macros/mt-accordion": {
"text": "\\define mt-accordion(caption, body, heading:\"a\")\n<div class=\"\">\n <$reveal state=<<qualify \"$:/state/mt/accordion\">> type=\"nomatch\" text=\"$body$\">\n <$button set=<<qualify \"$:/state/mt/accordion\">> setTo=\"$body$\" class=\"tc-btn-invisible\">\n <$heading$>{{$:/core/images/right-arrow}} $caption$</$heading$>\n </$button>\n </$reveal>\n <$reveal state=<<qualify \"$:/state/mt/accordion\">> type=\"match\" text=\"$body$\">\n <$button set=<<qualify \"$:/state/mt/accordion\">> setTo=\"\" class=\"tc-btn-invisible\">\n <$heading$>{{$:/core/images/down-arrow}} $caption$</$heading$>\n </$button>\n <$transclude tiddler=\"$body$\" mode=\"block\"/>\n </$reveal>\n</div>\n\\end",
"created": "20150117231839610",
"creator": "Alberto Molina Pérez",
"modified": "20150208011628004",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/mt-accordion"
},
"$:/plugins/amp/MagicTabs/macros/mt-toc": {
"created": "20150207222410132",
"text": "\\define mt-toc-caption()\n<$set name=\"tv-wikilinks\" value=\"no\">\n<$transclude field=\"caption\">\n<$view field=\"title\"/>\n</$transclude>\n</$set>\n\\end\n\n\\define mt-toc-body(root, parent, operator:\"mt-source.tiddler\", sort:\"\", itemClassFilter)\n<ol class=\"tc-toc\">\n<$list filter=\"\"\"[all[tiddlers]$operator$[$parent$]!is[system]!has[draft.of]$sort$]\"\"\">\n<$set name=\"toc-item-class\" filter=\"\"\"$itemClassFilter$\"\"\" value=\"toc-item-selected\" emptyValue=\"toc-item\">\n<li class=<<toc-item-class>>>\n<$list filter=\"[all[current]toc-link[no]]\" emptyMessage=\"<$link><$view field='caption'><$view field='title'/></$view></$link>\">\n<<mt-toc-caption>>\n</$list>\n<$list filter=\"\"\"[all[current]] -[[$root$]]\"\"\">\n<$macrocall $name=\"mt-toc-body\" root=\"\"\"$root$\"\"\" parent=<<currentTiddler>> operator=\"\"\"source\"\"\" sort=\"\"\"$sort$\"\"\" itemClassFilter=\"\"\"$itemClassFilter$\"\"\"/>\n</$list>\n</li>\n</$set>\n</$list>\n</ol>\n\\end\n\n\\define mt-toc(parent:\"$:/tags/toc\", operator:\"tag\", sort:\"\", itemClassFilter)\n<<mt-toc-body rootTag:\"\"\"$parent$\"\"\" parent:\"\"\"$parent$\"\"\" operator:\"\"\"tag\"\"\" sort:\"\"\"$sort$\"\"\" itemClassFilter:\"\"\"itemClassFilter\"\"\">>\n\\end\n\n\n\n\n\n\\define mt-toc-linked-expandable-body(parent:\"$:/tags/toc\", operator:\"mt-source.tiddler\", sort:\"\",itemClassFilter)\n<$set name=\"toc-state\" value=<<qualify \"$:/state/toc/$tag$-$(currentTiddler)$\">>>\n<$set name=\"toc-item-class\" filter=\"\"\"$itemClassFilter$\"\"\" value=\"toc-item-selected\" emptyValue=\"toc-item\">\n<li class=<<toc-item-class>>>\n<$link>\n<$reveal type=\"nomatch\" state=<<toc-state>> text=\"open\">\n<$button set=<<toc-state>> setTo=\"open\" class=\"tc-btn-invisible\">\n{{$:/core/images/right-arrow}}\n</$button>\n</$reveal>\n<$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n<$button set=<<toc-state>> setTo=\"close\" class=\"tc-btn-invisible\">\n{{$:/core/images/down-arrow}}\n</$button>\n</$reveal>\n<<mt-toc-caption>>\n</$link>\n<$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n<$macrocall $name=\"mt-toc-expandable\" parent=<<currentTiddler>> operator=\"\"\"$operator$\"\"\" sort=\"\"\"$sort$\"\"\" itemClassFilter=\"\"\"$itemClassFilter$\"\"\"/>\n</$reveal>\n</li>\n</$set>\n</$set>\n\\end\n\n\\define mt-toc-unlinked-expandable-body(parent:\"$:/tags/toc\",operator:\"mt-source.tiddler\",sort:\"\",itemClassFilter)\n<$set name=\"toc-state\" value=<<qualify \"$:/state/toc/$tag$-$(currentTiddler)$\">>>\n<$set name=\"toc-item-class\" filter=\"\"\"$itemClassFilter$\"\"\" value=\"toc-item-selected\" emptyValue=\"toc-item\">\n<li class=<<toc-item-class>>>\n<$reveal type=\"nomatch\" state=<<toc-state>> text=\"open\">\n<$button set=<<toc-state>> setTo=\"open\" class=\"tc-btn-invisible\">\n{{$:/core/images/right-arrow}}\n<<mt-toc-caption>>\n</$button>\n</$reveal>\n<$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n<$button set=<<toc-state>> setTo=\"close\" class=\"tc-btn-invisible\">\n{{$:/core/images/down-arrow}}\n<<mt-toc-caption>>\n</$button>\n</$reveal>\n<$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n<$macrocall $name=\"mt-toc-expandable\" parent=<<currentTiddler>> operator=\"\"\"$operator$\"\"\" sort=\"\"\"$sort$\"\"\" itemClassFilter=\"\"\"$itemClassFilter$\"\"\"/>\n</$reveal>\n</li>\n</$set>\n</$set>\n\\end\n\n\\define mt-toc-expandable(parent:\"$:/tags/toc\", operator:\"mt-source.tiddler\", sort:\"\",itemClassFilter)\n<ol class=\"tc-toc toc-expandable\">\n<$list filter=\"[all[shadows+tiddlers]$operator$[$parent$]!has[draft.of]$sort$]\">\n<$list filter=\"[all[current]toc-link[no]]\" emptyMessage=\"<<mt-toc-linked-expandable-body parent:'$parent$' operator:'$operator$' sort:'$sort$' itemClassFilter:'$itemClassFilter$'>>\">\n<<mt-toc-unlinked-expandable-body parent:\"\"\"$parent$\"\"\" operator:\"\"\"operator\"\"\" sort:\"\"\"$sort$\"\"\" itemClassFilter:\"\"\"itemClassFilter\"\"\">>\n</$list>\n</$list>\n</ol>\n\\end\n\n\n\n\n\n\n\\define mt-toc-linked-selective-expandable-body(parent, operator:\"mt-source.tiddler\", sort:\"\", itemClassFilter)\n\t<$set name=\"toc-state\" value=<<qualify \"$:/state/toc/$tag$-$(currentTiddler)$\">>>\n\t\t<$set name=\"toc-item-class\" filter=\"\"\"$itemClassFilter$\"\"\" value=\"toc-item-selected\" emptyValue=\"toc-item\">\n\t\t\t<li class=<<toc-item-class>>>\n\t\t\t\t<$link>\n\t\t\t\t\t<$list filter=\"[all[shadows+tiddlers]$operator$<currentTiddler>limit[1]]\" variable=\"ignore\" emptyMessage=\"<$button class='tc-btn-invisible'>{{$:/core/images/blank}}</$button>\">\n\t\t\t\t\t\t<$reveal type=\"nomatch\" state=<<toc-state>> text=\"open\">\n\t\t\t\t\t\t\t<$button set=<<toc-state>> setTo=\"open\" class=\"tc-btn-invisible\">\n\t\t\t\t\t\t\t\t{{$:/core/images/right-arrow}}\n\t\t\t\t\t\t\t</$button>\n\t\t\t\t\t\t</$reveal>\n\t\t\t\t\t\t<$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n\t\t\t\t\t\t\t<$button set=<<toc-state>> setTo=\"close\" class=\"tc-btn-invisible\">\n\t\t\t\t\t\t\t\t{{$:/core/images/down-arrow}}\n\t\t\t\t\t\t\t</$button>\n\t\t\t\t\t\t</$reveal>\n\t\t\t\t\t</$list>\n\t\t\t\t\t<<mt-toc-caption>>\n\t\t\t\t</$link>\n\t\t\t\t<$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n\t\t\t\t\t<$macrocall $name=\"mt-toc-selective-expandable\" \n \tparent=<<currentTiddler>> \n operator=\"\"\"$operator$\"\"\" \n sort=\"\"\"$sort$\"\"\" \n itemClassFilter=\"\"\"$itemClassFilter$\"\"\"\n />\n\t\t\t\t</$reveal>\n\t\t\t</li>\n\t\t</$set>\n\t</$set>\n\\end\n\n\\define mt-toc-unlinked-selective-expandable-body(parent, operator:\"mt-source.tiddler\", sort:\"\", itemClassFilter)\n\t<$set name=\"toc-state\" value=<<qualify \"$:/state/toc/$tag$-$(currentTiddler)$\">>>\n\t\t<$set name=\"toc-item-class\" filter=\"\"\"$itemClassFilter$\"\"\" value=\"toc-item-selected\" emptyValue=\"toc-item\">\n\t\t\t<li class=<<toc-item-class>>>\n\t\t\t\t<$list filter=\"[all[shadows+tiddlers]$operator<currentTiddler>limit[1]]\" variable=\"ignore\" emptyMessage=\"<$button class='tc-btn-invisible'>{{$:/core/images/blank}}</$button> <$view field='caption'><$view field='title'/></$view>\">\n\t\t\t\t\t<$reveal type=\"nomatch\" state=<<toc-state>> text=\"open\">\n\t\t\t\t\t\t<$button set=<<toc-state>> setTo=\"open\" class=\"tc-btn-invisible\">\n\t\t\t\t\t\t\t{{$:/core/images/right-arrow}}\n\t\t\t\t\t\t\t<<mt-toc-caption>>\n\t\t\t\t\t\t</$button>\n\t\t\t\t\t</$reveal>\n\t\t\t\t\t<$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n\t\t\t\t\t\t<$button set=<<toc-state>> setTo=\"close\" class=\"tc-btn-invisible\">\n\t\t\t\t\t\t\t{{$:/core/images/down-arrow}}\n\t\t\t\t\t\t\t<<mt-toc-caption>>\n\t\t\t\t\t\t</$button>\n\t\t\t\t\t</$reveal>\n\t\t\t\t</$list>\n\t\t\t\t<$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n\t\t\t\t\t<$macrocall $name=\"\"\"mt-toc-selective-expandable\"\"\" \n \tparent=<<currentTiddler>> \n operator=\"\"\"$operator$\"\"\" \n sort=\"\"\"$sort$\"\"\" \n itemClassFilter=\"\"\"$itemClassFilter$\"\"\"\n />\n\t\t\t\t</$reveal>\n\t\t\t</li>\n\t\t</$set>\n\t</$set>\n\\end\n\n\\define mt-toc-selective-expandable(parent:\"$:/tags/toc\", operator:\"mt-source.tiddler\", sort:\"\", itemClassFilter)\n\t<ol class=\"tc-toc toc-selective-expandable\">\n\t\t<$list filter=\"[all[tiddlers]$operator$[$parent$]!is[system]!has[draft.of]$sort$]\">\n\t\t\t<$list filter=\"[all[current]toc-link[no]]\" variable=\"ignore\" emptyMessage=\"<<mt-toc-linked-selective-expandable-body parent:'$parent$' operator:'$operator$' sort:'$sort$' itemClassFilter:'$itemClassFilter$'>>\">\n\t\t\t\t<<mt-toc-unlinked-selective-expandable-body\n \tparent:\"\"\"$parent$\"\"\" \n operator:\"\"\"$operator$\"\"\" \n sort:\"\"\"$sort$\"\"\" \n itemClassFilter:\"\"\"$itemClassFilter$\"\"\"\n >>\n\t\t\t</$list>\n\t\t</$list>\n\t</ol>\n\\end\n\n\\define mt-tocsx(parent:\"$:/tags/toc\", operator:\"tag\", sort:\"\", itemClassFilter)\n\t<ol class=\"tc-toc toc-selective-expandable\">\n\t\t<$list filter=\"[all[tiddlers]$operator$[$parent$]!is[system]!has[draft.of]$sort$]\">\n\t\t\t<$list filter=\"[all[current]toc-link[no]]\" variable=\"ignore\" emptyMessage=\"<<mt-toc-linked-selective-expandable-body parent:'$parent$' operator:'mt-source.tiddler' sort:'$sort$' itemClassFilter:'$itemClassFilter$'>>\">\n\t\t\t\t<<mt-toc-unlinked-selective-expandable-body\n \tparent:\"\"\"$parent$\"\"\" \n operator:\"\"\"mt-source.tiddler\"\"\" \n sort:\"\"\"$sort$\"\"\" \n itemClassFilter:\"\"\"$itemClassFilter$\"\"\"\n >>\n\t\t\t</$list>\n\t\t</$list>\n\t</ol>\n\\end",
"creator": "Alberto Molina Pérez",
"modified": "20150223155151165",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Macro $:/plugins/amp/MagicTabs/common MagicTabs",
"title": "$:/plugins/amp/MagicTabs/macros/mt-toc"
},
"$:/plugins/amp/MagicTabs/macros/mt-image": {
"text": "\\define mt-image(fa-name,image-name,label)\n<$reveal state=\"$:/_images/$image-name$!!modified\" type=\"nomatch\" text=\"\">\n {{$:/_images/$image-name$}}\n</$reveal>\n<$reveal state=\"$:/_images/$image-name$!!modified\" type=\"match\" text=\"\">\n <$reveal state=\"$:/plugins/TheDiveO/FontAwesome/fonts/FontAwesome!!modified\" type=\"nomatch\" text=\"\">\n <i class=\"fa $fa-name$\"></i>\n </$reveal>\n <$reveal state=\"$:/plugins/TheDiveO/FontAwesome/fonts/FontAwesome!!modified\" type=\"match\" text=\"\">\n $label$\n </$reveal>\n</$reveal>\n\\end",
"created": "20150208013147529",
"creator": "Alberto Molina Pérez",
"modified": "20150208013223399",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/mt-image"
},
"$:/plugins/amp/MagicTabs/TableOfContents": {
"text": "<div class=\"tc-table-of-contents\">\n\n<<mt-tocsx sort:'sort[mt-part.order]'>>\n\n</div>\n",
"caption": "Contents",
"created": "20140809114010378",
"creator": "Alberto Molina Pérez",
"list-before": "$:/core/ui/SideBar/Open",
"modified": "20150304173949245",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/SideBar $:/plugins/amp/MagicTabs/common MagicTabs",
"title": "$:/plugins/amp/MagicTabs/TableOfContents",
"type": "text/vnd.tiddlywiki"
},
"$:/plugins/amp/MagicTabs/images/ToC": {
"text": "<<mt-image \"fa-list\" \"ToC\" \"ToC\">>",
"created": "20150208020325976",
"creator": "Alberto Molina Pérez",
"modified": "20150208020357451",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/ToC"
},
"$:/plugins/amp/MagicTabs/images/note": {
"created": "20150208201701871",
"creator": "Alberto Molina Pérez",
"text": "<<mt-image \"fa-edit\" \"note\" \"Note\">>",
"modified": "20150209020926139",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/note"
},
"$:/plugins/amp/MagicTabs/macros/mt-full": {
"created": "20150209160430622",
"text": "\\define full-caption()\n<$set name=\"tv-wikilinks\" value=\"no\">\n<$reveal state=\"!!order\" type=\"nomatch\" text=\"\"><$view field=\"order\"/>. </$reveal>\n<$transclude field=\"caption\">\n<$view field=\"title\"/>\n</$transclude>\n</$set>\n\\end\n\n\\define mt-full-body-show(body:\"\")\n <$reveal state=<<qualify \"$:/state/mt/edit/$body$\">> type=\"nomatch\" text=\"yes\" default=\"no\">\n <$transclude tiddler=\"$body$\" mode=\"block\"/>\n </$reveal>\n <$reveal state=<<qualify \"$:/state/mt/edit/$body$\">> type=\"match\" text=\"yes\" default=\"no\">\n {{$body$||$:/core/ui/EditTemplate/body}}\n </$reveal>\n\\end\n\n\\define mt-full-body(root, parent, operator:\"source\", sort:\"\", itemClassFilter, body:\"\") \n <<mt-full-body-show body:\"$body$\">>\n <ol class=\"tc-toc\">\n <$list filter=\"\"\"[all[tiddlers]$operator$[$parent$]!is[system]!has[draft.of]$sort$]\"\"\">\n <$set name=\"toc-item-class\" \n filter=\"\"\"$itemClassFilter$\"\"\" \n value=\"toc-item-selected\" \n emptyValue=\"toc-item\"\n >\n <li class=<<toc-item-class>>>\n <heading>\n <$list filter=\"[all[current]toc-link[no]]\"\n emptyMessage=\"<$link>\n <$view field='caption'>\n <$view field='title'/>\n </$view>\n </$link>\n <<mt-slider-full-edit>>\"\n >\n <<full-caption>>\n </$list>\n </heading>\n <$list filter=\"\"\"[all[current]] -[[$root$]]\"\"\">\n <$macrocall $name=\"mt-full-body\"\n root=\"\"\"$root$\"\"\" \n parent=<<currentTiddler>> \n operator=\"\"\"$operator$\"\"\" \n sort=\"\"\"$sort$\"\"\" \n itemClassFilter=\"\"\"$itemClassFilter$\"\"\" \n body={{!!title}}\n />\n </$list>\n </li>\n </$set>\n </$list>\n </ol>\n\\end\n\n\\define mt-full(parent,operator:\"source\",sort:\"\",itemClassFilter)\n <$list filter=\"[[$parent$]is[tiddler]]\">\n <<mt-full-body \n root:\"\"\"$parent$\"\"\" \n parent:\"\"\"$parent$\"\"\" \n operator:\"\"\"$operator$\"\"\" \n sort:\"\"\"$sort$\"\"\" \n itemClassFilter:\"\"\"itemClassFilter\"\"\"\n >>\n </$list>\n <$list filter=\"[[$parent$]!is[tiddler]]\">\n <<mt-full-body \n root:\"\"\"$(currentTiddler)$\"\"\"\n parent:\"\"\"$(currentTiddler)$\"\"\" \n operator:\"\"\"$operator$\"\"\" \n sort:\"\"\"$sort$\"\"\" \n itemClassFilter:\"\"\"itemClassFilter\"\"\"\n >>\n </$list>\n\\end\n\n\n\n\n\n\\define mt-full-linked-expandable-body(parent:\"$:/tags/toc\", operator:\"source\", sort:\"\", itemClassFilter, body:\"\")\n <$set name=\"toc-state\" value=<<qualify \"$:/state/toc/$parent$-$(currentTiddler)$\">>>\n <$set name=\"toc-item-class\" filter=\"\"\"$itemClassFilter$\"\"\" value=\"toc-item-selected\" emptyValue=\"toc-item\">\n <li class=<<toc-item-class>>>\n <$link>\n <$reveal type=\"nomatch\" state=<<toc-state>> text=\"open\">\n <$button set=<<toc-state>> setTo=\"open\" class=\"tc-btn-invisible\">\n {{$:/core/images/right-arrow}}\n </$button>\n </$reveal>\n <$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n <$button set=<<toc-state>> setTo=\"close\" class=\"tc-btn-invisible\">\n {{$:/core/images/down-arrow}}\n </$button>\n </$reveal>\n <<full-caption>>\n </$link>\n <$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n <$macrocall $name=\"mt-full-expandable\" \n parent=<<currentTiddler>> \n operator=\"\"\"$operator$\"\"\" \n sort=\"\"\"$sort$\"\"\" \n itemClassFilter=\"\"\"$itemClassFilter$\"\"\"\n />\n </$reveal>\n </li>\n </$set>\n </$set>\n\\end\n\n\n\\define mt-full-unlinked-expandable-body(parent:\"$:/tags/toc\", operator:\"source\", sort:\"\", itemClassFilter)\n <$set name=\"toc-state\" value=<<qualify \"$:/state/toc/$parent$-$(currentTiddler)$\">>>\n<$set name=\"toc-item-class\" filter=\"\"\"$itemClassFilter$\"\"\" value=\"toc-item-selected\" emptyValue=\"toc-item\">\n<li class=<<toc-item-class>>>\n<$reveal type=\"nomatch\" state=<<toc-state>> text=\"open\">\n<$button set=<<toc-state>> setTo=\"open\" class=\"tc-btn-invisible\">\n{{$:/core/images/right-arrow}}\n<<full-caption>>\n</$button>\n</$reveal>\n<$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n<$button set=<<toc-state>> setTo=\"close\" class=\"tc-btn-invisible\">\n{{$:/core/images/down-arrow}}\n<<full-caption>>\n</$button>\n</$reveal>\n<$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n<$macrocall $name=\"mt-full-expandable\" parent=<<currentTiddler>> operator=\"\"\"$operator$\"\"\" sort=\"\"\"$sort$\"\"\" itemClassFilter=\"\"\"$itemClassFilter$\"\"\"/>\n</$reveal>\n</li>\n</$set>\n</$set>\n\\end\n\n\\define mt-full-expandable(parent:\"$:/tags/toc\", operator:\"source\", sort:\"\", itemClassFilter, body:\"\")\n <ol class=\"tc-toc toc-expandable\">\n <$list filter=\"[all[shadows+tiddlers]$operator$[$parent$]!has[draft.of]$sort$]\">\n <$list filter=\"[all[current]toc-link[no]]\" emptyMessage=\"<<mt-full-linked-expandable-body parent:'$parent$' operator:'$operator$' sort:'$sort$' itemClassFilter:'$itemClassFilter$'>>\">\n <<mt-full-unlinked-expandable-body parent:\"\"\"$parent$\"\"\" operator:\"\"\"operator\"\"\" sort:\"\"\"$sort$\"\"\" itemClassFilter:\"\"\"itemClassFilter\"\"\">>\n </$list>\n </$list>\n </ol>\n\\end\n\n\n\n\n\n\n\n\n\n\n\n\n\n\\define mt-full-linked-selective-expandable-body(parent, operator:\"mt-source.tiddler\",sort:\"\", itemClassFilter, body:\"\")\n <$set name=\"toc-state\" value=<<qualify \"$:/state/toc/$parent$-$(currentTiddler)$\">>>\n <$set name=\"toc-item-class\" filter=\"\"\"$itemClassFilter$\"\"\" value=\"toc-item-selected\" emptyValue=\"toc-item\">\n <li class=<<toc-item-class>>>\n <heading>\n <$list filter=\"[all[tiddlers]$operator$<currentTiddler>] [all[current]has[text]!text[]] +[!is[system]limit[1]]\" \n variable=\"ignore\" \n emptyMessage=\"<$button class='tc-btn-invisible'>{{$:/core/images/blank}}</$button><<full-caption>>\"\n >\n <$reveal type=\"nomatch\" state=<<toc-state>> text=\"open\">\n <$button set=<<toc-state>> setTo=\"open\" class=\"tc-btn-invisible\">\n {{$:/core/images/right-arrow}} <<full-caption>>\n </$button>\n </$reveal>\n <$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n <$button set=<<toc-state>> setTo=\"close\" class=\"tc-btn-invisible\">\n {{$:/core/images/down-arrow}} <<full-caption>>\n </$button><<mt-slider-full-edit>>\n </$reveal>\n </$list> \n </heading>\n <$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n <$macrocall $name=\"mt-full-selective-expandable\" \n parent=<<currentTiddler>> \n operator=\"\"\"$operator$\"\"\" \n sort=\"\"\"$sort$\"\"\" \n itemClassFilter=\"\"\"$itemClassFilter$\"\"\"\n body=<<currentTiddler>>\n />\n </$reveal>\n </li>\n </$set>\n </$set>\n\\end\n\n\\define mt-full-unlinked-selective-expandable-body(parent, operator:\"mt-source.tiddler\", sort:\"\", itemClassFilter)\n3. cocouCOUCOUCOUCOUCOUCOUCOUCUOCOCUOCUOCUCOUOCUCUOCOU\n <$set name=\"toc-state\" value=<<qualify \"$:/state/toc/$parent$-$(currentTiddler)$\">>>\n <$set name=\"toc-item-class\" filter=\"\"\"$itemClassFilter$\"\"\" value=\"toc-item-selected\" emptyValue=\"toc-item\">\n <li class=<<toc-item-class>>>\n <$list filter=\"[all[shadows+tiddlers]$operator<currentTiddler>limit[1]]\" \n variable=\"ignore\" \n emptyMessage=\"<$button class='tc-btn-invisible'>\n {{$:/core/images/blank}}\n </$button> \n <$view field='caption'><$view field='title'/></$view>\">\n <$reveal type=\"nomatch\" state=<<toc-state>> text=\"open\">\n <$button set=<<toc-state>> setTo=\"open\" class=\"tc-btn-invisible\">\n {{$:/core/images/right-arrow}}\n <<full-caption>>\n </$button>\n </$reveal>\n <$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n <$button set=<<toc-state>> setTo=\"close\" class=\"tc-btn-invisible\">\n {{$:/core/images/down-arrow}}\n <<full-caption>>\n </$button>\n </$reveal>\n </$list>\n <$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n \n <$macrocall $name=\"\"\"mt-full-selective-expandable\"\"\" \n parent=<<currentTiddler>> \n operator=\"\"\"$operator$\"\"\" \n sort=\"\"\"$sort$\"\"\" \n itemClassFilter=\"\"\"$itemClassFilter$\"\"\"\n body=<<currentTiddler>>\n />\n </$reveal>\n </li>\n </$set>\n </$set>\n\\end\n\n\\define mt-full-selective-expandable(parent, operator:\"mt-source.tiddler\", sort:\"\", itemClassFilter, body:\"\")\n <ul><<mt-full-body-show body:\"$body$\">></ul>\n <ol class=\"tc-toc toc-selective-expandable\">\n <$list filter=\"[all[tiddlers]$operator$[$parent$]!is[system]!has[draft.of]$sort$]\">\n <$list filter=\"[all[current]toc-link[no]]\" \n variable=\"ignore\" \n emptyMessage=\"<<mt-full-linked-selective-expandable-body \n parent:'$parent$' \n operator:'$operator$' \n sort:'$sort$' \n itemClassFilter:'$itemClassFilter$'>>\"\n >\n 1. COUCOUCOUCOUCOUCOUCOUCOUCOUCCOU\n <<mt-full-unlinked-selective-expandable-body \n parent:\"\"\"$parent$\"\"\" \n operator:\"\"\"operator\"\"\" \n sort:\"\"\"$sort$\"\"\" \n itemClassFilter:\"\"\"$itemClassFilter$\"\"\"\n >>\n </$list>\n </$list>\n </ol>\n\\end\n\n",
"creator": "Alberto Molina Pérez",
"modified": "20150224235720767",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/mt-full"
},
"$:/plugins/amp/MagicTabs/css/mt-toc": {
"text": "/*\n** Table of contents\n*/\n\n.tc-sidebar-lists .mt-table-of-contents {\n\twhite-space: nowrap;\n}\n\n.mt-table-of-contents button {\n\ttext-align: left;\n}\n\n.mt-table-of-contents svg {\n\twidth: 0.7em;\n\theight: 0.7em;\n\tvertical-align: middle;\n\tfill: <<colour sidebar-foreground>>;\n}\n\n.mt-table-of-contents ol {\n\tlist-style-type: none;\n\tpadding-left: 0;\n\ttext-align: left;\n}\n\n.mt-table-of-contents ol ol {\n\tpadding-left: 1em;\n}\n\n.mt-table-of-contents li {\n\tfont-size: 1.0em;\n\tfont-weight: normal;\n}\n\n.mt-table-of-contents li heading {\n\tfont-size: 1.5em;\n\tline-height: 2.0em;\n\tfont-weight: 500;\n}\n\n.mt-table-of-contents li ul {\n\tmargin: 0px 0px 1em 0px;\n}\n\n.mt-table-of-contents li ul ul {\n\tmargin: 0px 0px 0px 0px;\n}\n\n.mt-table-of-contents li a {\n\tfont-weight: bold;\n}\n\n.mt-table-of-contents li li {\n\tfont-size: 1em;\n\tfont-weight: normal;\n\tline-height: 1.4;\n}\n\n.mt-table-of-contents li li heading{\n\tfont-size: 1.3em;\n\tfont-weight: 500;\n}\n\n.mt-table-of-contents li li a {\n\tfont-weight: normal;\n}\n\n.mt-table-of-contents li li li {\n\tfont-size: 1em;\n\tfont-weight: 200;\n\tline-height: 1.5;\n}\n\n.mt-table-of-contents li li li heading {\n\tfont-size: 1.15em;\n\tfont-weight: 400;\n\tline-height: 2.0em;\n}\n\n.mt-table-of-contents li li li ul {\n\tmargin: 0px 0px 1em 0px;\n}\n\n.mt-table-of-contents li li li a {\n\tfont-weight: bold;\n}\n\n.mt-table-of-contents li li li li {\n\tfont-size: 1em;\n\tfont-weight: 200;\n}\n\n.mt-table-of-contents li li li li heading {\n\tfont-size: 1.0em;\n\tfont-weight: 300;\n\tline-height: 1.75em;\n}\n\n.tc-tabbed-table-of-contents {\n\tdisplay: -webkit-flex;\n\tdisplay: flex;\n}\n\n.tc-tabbed-table-of-contents .tc-table-of-contents {\n\tz-index: 100;\n\tdisplay: inline-block;\n\tpadding-left: 1em;\n\tmax-width: 50%;\n\t-webkit-flex: 0 0 auto;\n\tflex: 0 0 auto;\n\tbackground: <<colour tab-background>>;\n\tborder-left: 1px solid <<colour tab-border>>;\n\tborder-top: 1px solid <<colour tab-border>>;\n\tborder-bottom: 1px solid <<colour tab-border>>;\n}\n\n.tc-tabbed-table-of-contents .tc-table-of-contents .toc-item > a,\n.tc-tabbed-table-of-contents .tc-table-of-contents .toc-item-selected > a {\n\tdisplay: block;\n\tpadding: 0.12em 1em 0.12em 0.25em;\n}\n\n.tc-tabbed-table-of-contents .tc-table-of-contents .toc-item > a {\n\tborder-top: 1px solid <<colour tab-background>>;\n\tborder-left: 1px solid <<colour tab-background>>;\n\tborder-bottom: 1px solid <<colour tab-background>>;\n}\n\n.tc-tabbed-table-of-contents .tc-table-of-contents .toc-item > a:hover {\n\ttext-decoration: none;\n\tborder-top: 1px solid <<colour tab-border>>;\n\tborder-left: 1px solid <<colour tab-border>>;\n\tborder-bottom: 1px solid <<colour tab-border>>;\n\tbackground: <<colour tab-border>>;\n}\n\n.tc-tabbed-table-of-contents .tc-table-of-contents .toc-item-selected > a {\n\tborder-top: 1px solid <<colour tab-border>>;\n\tborder-left: 1px solid <<colour tab-border>>;\n\tborder-bottom: 1px solid <<colour tab-border>>;\n\tbackground: <<colour background>>;\n\tmargin-right: -1px;\n}\n\n.tc-tabbed-table-of-contents .tc-table-of-contents .toc-item-selected > a:hover {\n\ttext-decoration: none;\n}\n\n.tc-tabbed-table-of-contents .tc-tabbed-table-of-contents-content {\n\tdisplay: inline-block;\n\tvertical-align: top;\n\tpadding-left: 1.5em;\n\tpadding-right: 1.5em;\n\tborder: 1px solid <<colour tab-border>>;\n\t-webkit-flex: 1 0 50%;\n\tflex: 1 0 50%;\n}\n\n",
"created": "20150210104201979",
"modified": "20150225112637280",
"tags": "$:/tags/Stylesheet",
"title": "$:/plugins/amp/MagicTabs/css/mt-toc"
},
"$:/plugins/amp/MagicTabs/macros/mt-accordion-full": {
"created": "20150208202721187",
"text": "\\define mt-accordion-full-edit()\n <$reveal state=<<qualify \"$:/state/mt/edit/$(currentTiddler)$\">> type=\"nomatch\" text=\"yes\" default=\"no\">\n <$button set=<<qualify \"$:/state/mt/edit/$(currentTiddler)$\">> setTo=\"yes\" tooltip=\"edit this section\" class=\"tc-btn-invisible text-grey\" style=\"background-color: #ffffff;\"> \n {{$:/plugins/amp/MagicTabs/images/edit}}\n </$button>\n </$reveal>\n <$reveal state=<<qualify \"$:/state/mt/edit/$(currentTiddler)$\">> type=\"match\" text=\"yes\" default=\"no\">\n <$button set=<<qualify \"$:/state/mt/edit/$(currentTiddler)$\">> setTo=\"no\" tooltip=\"done\" class=\"tc-btn-invisible small\" style=\"background-color: #ffffff; color: green;\"> \n {{$:/plugins/amp/MagicTabs/images/done}}\n </$button>\n </$reveal>\n\\end\n\n\n\n\\define mt-accordion-full-button(tiddler, pre, heading)\n<$set name=\"caption\" filter=\"[[$tiddler$]has[caption]!caption[]]\" value={{$tiddler$!!caption}} emptyValue=\"$tiddler$\">\n<div class=\"\">\n <$reveal state=<<qualify \"$:/state/mt/accordion\">> type=\"nomatch\" text=\"$tiddler$\">\n <$button set=<<qualify \"$:/state/mt/accordion\">> setTo=\"$tiddler$\" class=\"tc-btn-invisible\">\n <$heading$>{{$:/core/images/right-arrow}} $pre$ <<caption>> <<mt-accordion-full-edit>></$heading$>\n </$button>\n </$reveal>\n <$reveal state=<<qualify \"$:/state/mt/accordion\">> type=\"match\" text=\"$tiddler$\">\n <$button set=<<qualify \"$:/state/mt/accordion\">> setTo=\"\" class=\"tc-btn-invisible\">\n <$heading$>{{$:/core/images/down-arrow}} $pre$ <<caption>> <<mt-accordion-full-edit>></$heading$>\n </$button>\n <$transclude tiddler=\"$tiddler$\" mode=\"block\"/>\n </$reveal>\n</div>\n</$set>\n\\end\n\\define mt-accordion-full(tiddler, pre, heading:\"a\")\n<$set name=\"tiddler\" filter=\"[[$tiddler$]is[tiddler]]\" value=\"$tiddler$\" emptyValue=<<currentTiddler>>>\n<$macrocall $name=\"mt-accordion-full-button\" tiddler=<<tiddler>> heading=\"$heading$\" pre=\"\"\"$pre$\"\"\"/>\n</$set>\n\\end",
"creator": "Alberto Molina Pérez",
"modified": "20150210225934508",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/mt-accordion-full"
},
"$:/plugins/amp/MagicTabs/macros/mt-slider-full": {
"created": "20150208214411130",
"text": "\\define mt-slider-full-edit()\n <$reveal state=<<qualify \"$:/state/mt/edit/$(currentTiddler)$\">> type=\"nomatch\" text=\"yes\" default=\"no\">\n <$button set=<<qualify \"$:/state/mt/edit/$(currentTiddler)$\">> setTo=\"yes\" tooltip=\"edit this section\" class=\"tc-btn-invisible text-grey\"> \n {{$:/plugins/amp/MagicTabs/images/edit}}\n </$button>\n </$reveal>\n <$reveal state=<<qualify \"$:/state/mt/edit/$(currentTiddler)$\">> type=\"match\" text=\"yes\" default=\"no\">\n <$button set=<<qualify \"$:/state/mt/edit/$(currentTiddler)$\">> setTo=\"no\" tooltip=\"done\" class=\"tc-btn-invisible small\" style=\"color: green;\"> \n {{$:/plugins/amp/MagicTabs/images/done}}\n </$button>\n </$reveal>\n\\end\n\n\n\n\\define mt-slider-full-button(tiddler, pre, heading, default)\n<$set name=\"caption\" filter=\"[[$tiddler$]has[caption]!caption[]]\" value={{$tiddler$!!caption}} emptyValue=\"$tiddler$\">\n<div class=\"\">\n <$reveal state=<<qualify \"$:/state/mt/slider-$tiddler$\">> type=\"match\" text=\"hide\" default=\"$default$\">\n <$button set=<<qualify \"$:/state/mt/slider-$tiddler$\">> setTo=\"show\" class=\"tc-btn-invisible\">\n <$heading$>{{$:/core/images/right-arrow}} $pre$ <<caption>> <<mt-accordion-full-edit>></$heading$>\n </$button>\n </$reveal>\n <$reveal state=<<qualify \"$:/state/mt/slider-$tiddler$\">> type=\"match\" text=\"show\" default=\"$default$\">\n <$button set=<<qualify \"$:/state/mt/slider-$tiddler$\">> setTo=\"hide\" class=\"tc-btn-invisible\">\n <$heading$>{{$:/core/images/down-arrow}} $pre$ <<caption>> <<mt-accordion-full-edit>></$heading$>\n </$button>\n <$transclude tiddler=\"$tiddler$\" mode=\"block\"/>\n </$reveal>\n</div>\n</$set>\n\\end\n\\define mt-slider-full(tiddler, pre, heading:\"a\", default:\"show\")\n<$set name=\"tiddler\" filter=\"[[$tiddler$]is[tiddler]]\" value=\"$tiddler$\" emptyValue=<<currentTiddler>>>\n<$macrocall $name=\"mt-slider-full-button\" tiddler=<<tiddler>> heading=\"$heading$\" pre=\"\"\"$pre$\"\"\" default=\"$default$\"/>\n</$set>\n\\end\n\n<<mt-slider-full tiddler:\"Antecedentes de la Revolución\" heading:\"h1\">>",
"creator": "Alberto Molina Pérez",
"modified": "20150210230337646",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/mt-slider-full"
},
"$:/plugins/amp/MagicTabs/images/help": {
"text": "<<mt-image \"fa-life-ring\" \"help\" \"Help\">>",
"created": "20150211102203059",
"creator": "Alberto Molina Pérez",
"modified": "20150211112249498",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/help"
},
"$:/plugins/amp/MagicTabs/macros/SearchBox/filters": {
"text": "\\define mt-filter-select()\ntag[$(currentTiddler)$]\n\\end\n\\define searchResultFilters()\n<div class=\"tc-table-of-contents\" style=\"margin-bottom: -20px;\">\n <$reveal state=<<qualify \"$:/state/mt/filter-search\">> type=\"nomatch\" text=\"show\" default=\"hide\">\n <$button class=\"tc-btn-invisible\">\n <$action-setfield $tiddler=<<qualify \"$:/state/mt/filter-search\">> text=\"show\"/>\n {{$:/core/images/right-arrow}} filters\n </$button>\n </$reveal>\n <$reveal state=<<qualify \"$:/state/mt/filter-search\">> type=\"match\" text=\"show\" default=\"hide\">\n <$button class=\"tc-btn-invisible\">\n <$action-setfield $tiddler=<<qualify \"$:/state/mt/filter-search\">> text=\"hide\"/>\n {{$:/core/images/down-arrow}} filters\n </$button>\n </$reveal>\n</div>\n<table class=\"invisible\" style=\"font-size: 90%\">\n<$reveal state=<<qualify \"$:/state/mt/filter-search\">> type=\"match\" text=\"show\" default=\"hide\">\n<$tiddler tiddler=\"$:/temp/mt/searchresults\">\n<table class=\"invisible\">\n<tr>\n<td>Filter by: </td>\n<td>\n<$select tiddler='$:/temp/mt/searchresults' field=\"filter\" default=''>\n<option value=\"\"></option>\n<$list filter='[all[shadows+tiddlers]tag[$:/tags/MagicTabs/dashboard]sort[]]'>\n<option value=<<mt-filter-select>>><$view field='caption'/></option>\n</$list>\n</$select>\n{{$:/plugins/amp/MagicTabs/images/filter}}\n</td>\n</tr>\n</table>\n\n<table>\n<tr>\n<td>Sort by: </td>\n<td><<mt-sort-title>></td>\n<td><<mt-sort-modified>></td>\n<td></td>\n</tr>\n</table>\n\n\nsort: {{!!sort}}<br>\n\norder: {{!!order}}\n\n</$tiddler>\n</$reveal>\n</table>\n\n\n\\end",
"created": "20150210174209149",
"modified": "20150304194607854",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/SearchBox/filters",
"type": ""
},
"$:/plugins/amp/MagicTabs/images/filter": {
"text": "<<mt-image \"fa-filter\" \"filter\" \"Filter\">>",
"created": "20150211231838336",
"creator": "Alberto Molina Pérez",
"modified": "20150211231936839",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/filter"
},
"$:/plugins/amp/MagicTabs/images/sort": {
"text": "<<mt-image \"fa-sort\" \"sort\" \"Sort\">>",
"created": "20150211231957735",
"creator": "Alberto Molina Pérez",
"modified": "20150211232038120",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/sort"
},
"$:/plugins/amp/MagicTabs/images/sort-alpha-asc": {
"text": "<<mt-image \"fa-sort-alpha-asc\" \"sort-alpha-asc\" \"sort-alpha-asc\">>",
"created": "20150211232122100",
"creator": "Alberto Molina Pérez",
"modified": "20150211232159569",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/sort-alpha-asc"
},
"$:/plugins/amp/MagicTabs/images/sort-alpha-desc": {
"text": "<<mt-image \"fa-sort-alpha-desc\" \"sort-alpha-desc\" \"Sort-alpha-desc\">>",
"created": "20150211232205463",
"creator": "Alberto Molina Pérez",
"modified": "20150211232248741",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/sort-alpha-desc"
},
"$:/plugins/amp/MagicTabs/images/sort-numeric-asc": {
"text": "<<mt-image \"fa-sort-numeric-asc\" \"sort-numeric-asc\" \"sort-numeric-asc\">>",
"created": "20150211235237842",
"creator": "Alberto Molina Pérez",
"modified": "20150211235302607",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/sort-numeric-asc"
},
"$:/plugins/amp/MagicTabs/images/sort-numeric-desc": {
"text": "<<mt-image \"fa-sort-numeric-desc\" \"sort-numeric-desc\" \"sort-numeric-desc\">>",
"created": "20150211235317514",
"creator": "Alberto Molina Pérez",
"modified": "20150211235340277",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/sort-numeric-desc"
},
"$:/plugins/amp/MagicTabs/macros/searchBox/SortModified": {
"text": "\\define mt-sort-modified()\n\t<$reveal state=\"!!sort\" type=\"match\" text=\"modified\">\n\n\t\t<$reveal state=\"!!order\" type=\"nomatch\" text=\"!\">\n\t\t\t<$button class=\"tc-btn-invisible\">\n\t\t\t\t<$action-setfield sort=\"modified\"/>\n\t\t\t\t<$action-setfield order=\"!\"/>\n\t\t\t\t@@color:black;recent {{$:/plugins/amp/MagicTabs/images/sort-numeric-asc}}@@\n\t\t\t</$button>\n\t\t</$reveal>\n\n\t\t<$reveal state=\"!!order\" type=\"match\" text=\"!\">\n\t\t\t<$button class=\"tc-btn-invisible\">\n\t\t\t\t<$action-setfield sort=\"modified\"/>\n\t\t\t\t<$action-setfield order=\"\"/>\n\t\t\t\t@@color:black;recent {{$:/plugins/amp/MagicTabs/images/sort-numeric-desc}}@@\n\t\t\t</$button>\n\t\t</$reveal>\n\n\t</$reveal>\n\n\t<$reveal state=\"!!sort\" type=\"nomatch\" text=\"modified\">\n\n\t\t<$reveal state=\"!!order\" type=\"nomatch\" text=\"!\">\n\t\t\t<$button class=\"tc-btn-invisible\">\n\t\t\t\t<$action-setfield sort=\"modified\"/>\n\t\t\t\t@@color:#aaaaaa;recent {{$:/plugins/amp/MagicTabs/images/sort-numeric-asc}}@@\n\t\t\t</$button>\n\t\t</$reveal>\n\n\t\t<$reveal state=\"!!order\" type=\"match\" text=\"!\">\n\t\t\t<$button class=\"tc-btn-invisible\">\n\t\t\t\t<$action-setfield sort=\"modified\"/>\n\t\t\t\t@@color:#aaaaaa;recent {{$:/plugins/amp/MagicTabs/images/sort-numeric-desc}}@@\n\t\t\t</$button>\n\t\t</$reveal>\n\n\t</$reveal>\n\\end\n<<mt-sort-modified>>",
"created": "20150211235614128",
"modified": "20150212125613165",
"sort": "modified",
"tags": "$:/tags/Macro",
"title": "$:/plugins/amp/MagicTabs/macros/searchBox/SortModified"
},
"$:/plugins/amp/MagicTabs/macros/searchBox/SortTitle": {
"text": "\\define mt-sort-title()\n\t<$reveal state=\"!!sort\" type=\"match\" text=\"title\">\n\n\t\t<$reveal state=\"!!order\" type=\"nomatch\" text=\"!\">\n\t\t\t<$button class=\"tc-btn-invisible\">\n\t\t\t\t<$action-setfield sort=\"title\"/>\n\t\t\t\t<$action-setfield order=\"!\"/>\n\t\t\t\t@@color:black;title: {{$:/plugins/amp/MagicTabs/images/sort-alpha-asc}}@@\n\t\t\t</$button>\n\t\t</$reveal>\n\n\t\t<$reveal state=\"!!order\" type=\"match\" text=\"!\">\n\t\t\t<$button class=\"tc-btn-invisible\">\n\t\t\t\t<$action-setfield sort=\"title\"/>\n\t\t\t\t<$action-setfield order=\"\"/>\n\t\t\t\t@@color:black;title: {{$:/plugins/amp/MagicTabs/images/sort-alpha-desc}}@@\n\t\t\t</$button>\n\t\t</$reveal>\n\n\t</$reveal>\n\n\t<$reveal state=\"!!sort\" type=\"nomatch\" text=\"title\">\n\n\t\t<$reveal state=\"!!order\" type=\"nomatch\" text=\"!\">\n\t\t\t<$button class=\"tc-btn-invisible\">\n\t\t\t\t<$action-setfield sort=\"title\"/>\n\t\t\t\t@@color:#aaaaaa;title: {{$:/plugins/amp/MagicTabs/images/sort-alpha-asc}}@@\n\t\t\t</$button>\n\t\t</$reveal>\n\n\t\t<$reveal state=\"!!order\" type=\"match\" text=\"!\">\n\t\t\t<$button class=\"tc-btn-invisible\">\n\t\t\t\t<$action-setfield sort=\"title\"/>\n\t\t\t\t@@color:#aaaaaa;title: {{$:/plugins/amp/MagicTabs/images/sort-alpha-desc}}@@\n\t\t\t</$button>\n\t\t</$reveal>\n\n\t</$reveal>\n\\end\n<<mt-sort-title>>",
"created": "20150211235524728",
"modified": "20150212125748985",
"sort": "title",
"tags": "$:/tags/Macro",
"title": "$:/plugins/amp/MagicTabs/macros/searchBox/SortTitle"
},
"$:/plugins/amp/MagicTabs/macros/mt-check-title": {
"text": "\\define mt-check-title()\n<$list filter=\"[all[current]get[draft.title]is[tiddler]]\">\n<$link><$view field=\"title\"/></$link> exists already!\n</$list>\n\\end",
"created": "20150212155422694",
"modified": "20150213084725231",
"tags": "$:/tags/Macro $:/plugins/amp/MagicTabs/common MagicTabs",
"title": "$:/plugins/amp/MagicTabs/macros/mt-check-title"
},
"$:/plugins/amp/MagicTabs/new/person": {
"created": "20141206105846685",
"text": "<<mt-input-person type:\"$:/type/person\">>\n\n<br>\n<<mt-new-person type:\"$:/type/person\">>",
"creator": "Alberto Molina Pérez",
"modified": "20150226173306593",
"modifier": "Alberto Molina Pérez",
"tags": "$:/action/hide/tabs MagicTabs $:/action/hide/tags $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/new/person"
},
"$:/plugins/amp/MagicTabs/forms/input/person": {
"created": "20141204214445374",
"text": "\\define inputPersonMoreInfo(type)\n<$reveal state=\"$:/state/mt/input/person!!more_info\" type=\"nomatch\" text=\"show\" default=\"hide\">\n\n|invisible tc-table-of-contents|k\n|<<inputPersonConfigButton>>|<$button set=\"$:/state/mt/input/person!!more_info\" setTo=\"show\" class=\"tc-btn-invisible\">{{$:/core/images/right-arrow}} more info</$button>|\n\n</$reveal>\n\n<$reveal state=\"$:/state/mt/input/person!!more_info\" type=\"match\" text=\"show\" default=\"hide\">\n\n<div class=\"tc-table-of-contents\">\n\n|invisible|k\n|<<inputPersonConfigButton>>|<$button set=\"$:/state/mt/input/person!!more_info\" setTo=\"hide\" class=\"tc-btn-invisible\">{{$:/core/images/down-arrow}} less info</$button> |\n\n</div>\n\n<<inputPersonMoreInfoTable>>\n\n<<mt-fields-form-more type:\"$type$\">>\n\n</$reveal>\n\\end\n\n\n\\define mt-input-person(type:\"$:/type/person\")\n<$tiddler tiddler=\"$:/temp/$type$\">\n\n<<inputPersonName \"$type$\">>\n\n<<inputPersonRadioButtons>>\n\n<<inputPersonMoreInfo \"$type$\">>\n\n</$tiddler>\n\\end\n\n<<mt-input-person>>\n\n",
"creator": "Alberto Molina Pérez",
"modified": "20150228104033130",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common $:/tags/Macro",
"title": "$:/plugins/amp/MagicTabs/forms/input/person"
},
"$:/plugins/amp/MagicTabs/forms/input/person/config/button": {
"created": "20141208202702112",
"text": "\\define inputPersonConfigButton()\n<$reveal state=\"$:/state/mt/input/person!!config\" type=\"nomatch\" text=\"show\" default=\"hide\">\n<span><$button set=\"$:/state/mt/input/person!!config\" setTo=\"show\" class=\"tc-btn-invisible\">{{$:/core/images/options-button}}</$button></span>\n</$reveal>\n<$reveal state=\"$:/state/mt/input/person!!config\" type=\"match\" text=\"show\" default=\"hide\">\n<span><$button set=\"$:/state/mt/input/person!!config\" setTo=\"hide\" class=\"tc-btn-invisible\">{{$:/core/images/options-button}}</$button></span>\n</$reveal>\n\\end",
"creator": "Alberto Molina Pérez",
"modified": "20150226144954802",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/forms/input/person/config/button"
},
"$:/plugins/amp/MagicTabs/forms/input/person/config/RadioButtons": {
"created": "20141208202905627",
"text": "\\define inputPersonRadioButtons()\n<$tiddler tiddler=\"$:/config/MagicTabs/person/title/$:/plugins/amp/MagicTabs\">\n\n<$reveal state=\"$:/state/mt/input/person!!config\" type=\"match\" text=\"show\">\n ''Tiddler title:''<br>\n<span class=\"box\">\n\n<$radio field=\"text\" value=\"Name\"> Name </$radio>\n<$radio field=\"text\" value=\"Surname\"> Surname </$radio>\n<$radio field=\"text\" value=\"Both\"> Both</$radio>\n</span>\n</$reveal>\n\n</$tiddler>\n\\end\n<<inputPersonRadioButtons>>",
"creator": "Alberto Molina Pérez",
"modified": "20150226145938992",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Macro $:/plugins/amp/MagicTabs/common MagicTabs",
"title": "$:/plugins/amp/MagicTabs/forms/input/person/config/RadioButtons"
},
"$:/plugins/amp/MagicTabs/forms/input/person/more-info/table": {
"created": "20141208204520911",
"text": "\\define inputPersonMoreInfoTable()\n|invisible|k\n|<$radio field=\"mt-person.gender\" value=\"female\"> female </$radio> <$radio field=\"mt-person.gender\" value=\"male\"> male </$radio><$radio field=\"mt-person.gender\" value=\"other\"> other </$radio>|<|<|<|<|<|<|<|\n|<$edit-text field=\"mt-person.birth.place\" tag=\"input\" placeholder=\"Place of birth\" class=\"tc-edit-texteditor\" size=\"40\"/>|<$edit-text field=\"mt-person.birth.date\" tag=\"input\" placeholder=\"Date of birth\" class=\"tc-edit-texteditor\" size=\"10\"/>|<|<|<|<|<|<|\n|<$edit-text field=\"mt-person.death.place\" tag=\"input\" placeholder=\"Place of death\" class=\"tc-edit-texteditor\" size=\"40\"/>|<$edit-text field=\"mt-person.death.date\" tag=\"input\" placeholder=\"Date of death\" class=\"tc-edit-texteditor\" size=\"10\"/>|<|<|<|<|<|<|\n\\end\n<<inputPersonMoreInfoTable>>",
"creator": "Alberto Molina Pérez",
"modified": "20150228102620715",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/forms/input/person/more-info/table"
},
"$:/plugins/amp/MagicTabs/forms/input/person/name": {
"created": "20141208195650796",
"text": "\\define inputPersonName(type:\"$:/type/person\")\n<table class=\"invisible\" style=\"width: 100%\">\n<tr>\n<td><$edit-text tiddler=\"$:/temp/$type$\" field=\"mt-person.name\" tag=\"input\" placeholder=\"Name\" class=\"tc-edit-texteditor\" size=\"20\"/></td>\n<td><$edit-text tiddler=\"$:/temp/$type$\" field=\"mt-person.surname\" tag=\"input\" placeholder=\"Surname\" class=\"tc-edit-texteditor\" size=\"20\"/></td>\n<td><<buttonPersonPicture>></td>\n</tr>\n<tr>\n<td colspan=\"3\"><$list filter=\"[all[tiddlers]tag[$type$]has[mt-person.name]field:mt-person.name{!!mt-person.name}has[mt-person.surname]field:mt-person.surname{!!mt-person.surname}] -$:/temp/$type$\">@@color:red;There is already a tiddler for that person:@@ <$link><$view field=\"title\"/></$link></$list></td>\n</tr>\n</table>\n\\end\n\n<<inputPersonName>>",
"creator": "Alberto Molina Pérez",
"modified": "20150218212041103",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Macro $:/plugins/amp/MagicTabs/common MagicTabs",
"title": "$:/plugins/amp/MagicTabs/forms/input/person/name"
},
"$:/plugins/amp/MagicTabs/forms/input/person/picture": {
"created": "20141208202451894",
"text": "\\define buttonPersonPicture()\n<$button class=\"tc-btn-invisible pretty\">\n <$action-sendmessage $message=\"tm-modal\" $param=\"$:/plugins/amp/MagicTabs/forms/input/image\"/>\n <$reveal state=\"$:/temp/$:/type/image!!type\" type=\"match\" text=\"\">\n <span style=\"font-size:2em;\">{{$:/plugins/amp/MagicTabs/images/person}}</span>\n </$reveal>\n <$reveal state=\"$:/temp/$:/type/image!!type\" type=\"nomatch\" text=\"\">\n <$image source=\"$:/temp/$:/type/image\" width=\"128\"/>\n </$reveal>\n</$button>\n\\end\n<<buttonPersonPicture>>",
"creator": "Alberto Molina Pérez",
"modified": "20150218080729579",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/forms/input/person/picture"
},
"$:/plugins/amp/MagicTabs/forms/input/image": {
"created": "20141206113525643",
"text": "<$tiddler tiddler=\"$:/temp/$:/type/image\">\n\n|invisible|k\n|Address:|<|\n|<$edit-text field=\"_canonical_uri\" placeholder=\"paste or write here the address of the image\" tag=\"input\" class=\"tc-edit-texteditor\" size=\"60\"/>| <<clear \"$:/temp/$:/type/image\" \"_canonical_uri\">> |\n\n|invisible|k\n|{{||$:/core/ui/EditTemplate/type}} |\n\n|invisible|k\n| <$image source=\"$:/temp/$:/type/image\" height=\"300\"/> |\n\n</$tiddler>",
"creator": "Alberto Molina Pérez",
"modified": "20150218075908787",
"modifier": "Alberto Molina Pérez",
"subtitle": "External image",
"tags": "MagicTabs $:/action/hide/tabs $:/action/hide/tags $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/forms/input/image"
},
"$:/plugins/amp/MagicTabs/macros/mt-new-person": {
"created": "20150218090259678",
"text": "\\define mt-new-person-button(type, title, template, label:\"add\", class:\"btn-big green\")\n\n<$list filter=\"[[$:/temp/$:/type/image]has[_cannonical_uri]!_cannonical_uri[]]\">\n\n <$button tooltip=\"$label$\" class=\"$class$\">\n <$action-setfield $tiddler=\"$:/temp/$:/type/image\" title=\"$title$: picture\"/>\n <$action-deletetiddler $tiddler=\"$:/temp/$:/type/image\"/> \n <$action-setfield $tiddler=\"$:/temp/$type$\" mt-tiddler.picture=\"$title$: picture\"/>\n <$action-setfield $tiddler=\"$:/temp/$type$\" title=\"$title$\"/>\n <$action-deletetiddler $tiddler=\"$:/temp/$type$\"/>\n <$action-setfield $tiddler=\"$template$\" title=\"$:/temp/$type$\"/>\n <$action-sendmessage $message=\"tm-notify\" $param=\"$:/plugins/amp/MagicTabs/notifications/new-tiddler\"/>\n $label$\n </$button>\n \n</$list>\n\n<$list filter=\"[[$:/temp/$:/type/image]!has[_cannonical_uri]] [[$:/temp/$:/type/image]has[_cannonical_uri]_cannonical_uri[]]\">\n\n <$button tooltip=\"$label$\" class=\"$class$\">\n <$action-deletefield $tiddler=\"$:/temp/$type$\" mt-source.tiddler mt-source.root/>\n <$action-setfield $tiddler=\"$:/temp/$type$\" title=\"$title$\"/>\n <$action-deletetiddler $tiddler=\"$:/temp/$type$\"/>\n <$action-setfield $tiddler=\"$template$\" title=\"$:/temp/$type$\"/>\n <$action-sendmessage $message=\"tm-notify\" $param=\"$:/plugins/amp/MagicTabs/notifications/new-tiddler\"/>\n $label$\n </$button>\n \n</$list>\n\n\\end\n\n\n\n\n\n\n\\define authorTitleName()\n$(authorName)$\n\\end\n\n\\define authorTitleSurname()\n$(authorSurname)$\n\\end\n\n\\define authorTitleBoth()\n$(authorName)$ $(authorSurname)$\n\\end\n\n\n\n\n\n\\define mt-new-person-button-call(type)\n<$set name=\"mt-source.tiddler\" filter=\"[[$(currentTab)$]is[tiddler]]\" value=\"$(currentTab)$\" emptyValue=\"\">\n\n <$macrocall $name=\"mt-new-person-button\"\n type=\"$type$\"\n title=<<authorTitle$(person-title)$>>\n template={{$type$!!mt-template.fields}}\n source=<<mt-source.tiddler>>\n\t label=<<authorTitle$(person-title)$>>\n />\n\n</$set>\n\n\\end\n\n\\define mt-new-person(type:\"$:/type/person\")\n\n\t<$set name=\"authorName\" value={{$:/temp/$type$!!mt-person.name}}>\n\n\t\t<$set name=\"authorSurname\" value={{$:/temp/$type$!!mt-person.surname}}>\n\n\t\t\t<$set name=\"person-title\" value={{$:/config/MagicTabs/person/title/$:/plugins/amp/MagicTabs}}>\n\n\t\t\t\t<$reveal default=<<person-title>> type=\"match\" text=\"Name\">\n\n\t\t\t\t<$list filter=\"[[$:/temp/$type$]has[mt-person.name]!mt-person.name[]]\" variable=\"ignore\" \n\t\t\t\temptyMessage=\"\"\"\n\t\t\t\t<$button class=\"btn-big grey\">add</$button>\n\t\t\t\t \"\"\">\n\n\t\t\t\t\t<$macrocall $name=\"mt-new-person-button-call\" type=\"$type$\"/>\t\t\t\n\n\t\t\t\t</$list>\n\n\t\t\t\t</$reveal>\n\n\t\t\t\t<$reveal default=<<person-title>> type=\"match\" text=\"Surname\">\n\n\t\t\t\t<$list filter=\"[[$:/temp/$type$]!mt-person.surname[]]\" variable=\"ignore\" \n\t\t\t\temptyMessage=\"\"\"\n\t\t\t\t<$button class=\"btn-big grey\">add</$button>\n\t\t\t\t \"\"\">\n\n\t\t\t\t\t<$macrocall $name=\"mt-new-person-button-call\" type=\"$type$\"/>\t\t\t\n\n\t\t\t\t</$list>\n\n\t\t\t\t</$reveal>\n\n\t\t\t\t<$reveal default=<<person-title>> type=\"match\" text=\"Both\">\n\n\t\t\t\t<$list filter=\"[[$:/temp/$type$]!mt-person.name[]!mt-person.surname[]]\" variable=\"ignore\" \n\t\t\t\temptyMessage=\"\"\"\n\t\t\t\t<$button class=\"btn-big grey\">add</$button>\n\t\t\t\t \"\"\">\n\n\t\t\t\t\t<$macrocall $name=\"mt-new-person-button-call\" type=\"$type$\"/>\t\t\t\n\n\t\t\t\t</$list>\n\n\t\t\t\t</$reveal>\n\n\t\t\t</$set>\n\n\t\t</$set>\n\n\t</$set>\n\n\\end\n\n<<mt-new-person>>",
"creator": "Alberto Molina Pérez",
"modified": "20150226173220501",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/tags/Macro $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/mt-new-person"
},
"$:/plugins/amp/MagicTabs/ViewTemplate/picture": {
"text": "<$list filter=\"[all[current]has[mt-tiddler.picture]]\">\n<$reveal type=\"nomatch\" state=\"!!mt-tiddler.picture\" text=\"\">\n<$image source={{!!mt-tiddler.picture}} class=\"person\"/>\n</$reveal>\n</$list>\n",
"created": "20141206162301561",
"creator": "Alberto Molina Pérez",
"list-before": "$:/core/ui/ViewTemplate/body",
"modified": "20150218165726938",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/ViewTemplate MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/ViewTemplate/picture"
},
"$:/plugins/amp/MagicTabs/forms/input/part": {
"created": "20150221233401446",
"creator": "Alberto Molina Pérez",
"text": "\\define mt-more-fields-part(type, template, default)\n\t<$reveal state=<<qualify \"$:/state/mt/slider\">> type=\"nomatch\" text=\"show\" default=\"$default$\">\n <$button set=<<qualify \"$:/state/mt/slider\">> setTo=\"show\" class=\"tc-btn-invisible\">\n {{$:/core/images/right-arrow}} more\n </$button>\n </$reveal>\n <$reveal state=<<qualify \"$:/state/mt/slider\">> type=\"match\" text=\"show\" default=\"$default$\">\n <$button set=<<qualify \"$:/state/mt/slider\">> setTo=\"hide\" class=\"tc-btn-invisible\">\n {{$:/core/images/down-arrow}} less\n </$button> \n </$reveal>\n <$reveal state=<<qualify \"$:/state/mt/slider\">> type=\"match\" text=\"show\" default=\"$default$\">\n \n\n\n<$reveal state=<<qualify \"$:/state/mt/slider\">> type=\"match\" text=\"show\" default=\"$default$\">\n\n<table class=\"\" style=\"width:100%\">\n <tr>\n \t<td style=\"height: 2em;\">Source:</td>\n \t<td colspan=\"4\" style=\"text-align: left;\"><$view field=\"mt-source.tiddler\"/></td>\n </tr>\n <tr>\n \t<td>Description:</td>\n \t<td colspan=\"4\"><$edit-text field=\"description\" placeholder=\"Description\" tag=\"input\" class=\"tc-edit-fields\"/></td>\n </tr>\n <tr>\n \t<td>Parents:</td>\n \t<td colspan=\"4\"><$edit-text field=\"mt-source.parents\" placeholder=\"Parents\" tag=\"input\" class=\"tc-edit-fields\"/></td>\n </tr>\n <tr>\n \t\t<td>Tags</td>\n \t<td colspan=\"4\"><$transclude tiddler=\"$:/core/ui/EditTemplate/tags\"/></td>\n </tr>\n <tr>\n \t<td>Icon</td>\n \t<td><$transclude tiddler={{!!icon}}/><<mt-change-icon>></td>\n \t<td style=\"text-align: right;\">Color</td>\n \t<td><$edit-text field=\"color\" placeholder=\"Source\" tag=\"input\" class=\"tc-edit-fields\"/></td>\n\t\t</tr>\n <$list filter=\"[[$:/type/$type$]tags[]prefix[$:/type/]get[mt-template.fields]fields[]] [[$template$]fields[]] -created -creator -modified -modifier -title -tags -mt-topics.list -text -icon -color -mt-source.parents -mt-source.tiddler -description -mt-part.order\" variable=\"field\">\n <tr>\n <td><<field>></td>\n <td colspan=\"4\"><$macrocall $name=\"edit-field\" template=\"$template$\" field=<<field>> tempTiddler=\"$:/temp/$type$\"/></td>\n </tr>\n </$list>\n \t<tr style=\"text-align:right;\">\n <td colspan=\"5\">\n <small>\n <$list filter=\"[[$template$]has[title]!title[]limit[1]]\">\n [[edit the template|$template$]]\n </$list>\n <$list filter=\"[[$template$]!has[title]] +[limit[1]]\">\n This is a form based on a default template. You should create a custom template for <$link to=\"$type$\">$type$</$link>\n </$list>\n </small>\n </td>\n \t</tr>\n</table>\n\n</$reveal>\n \n\\end\n\n\n\n\n\n\n\\define changeTitle(type:\"$:/type/part\")\n\t<$reveal state=\"$:/state/mt/partTitle\" type=\"nomatch\" text=\"custom\" default=\"default\">\n \t$(storyTiddler)$$(pre)$$(order)$\n <$button set=\"$:/state/mt/partTitle\" setTo=\"custom\" class=\"tc-btn-invisible text-grey\">\n \t<$action-setfield draft.title={{!!mt-part.title}}/>\n \t<$action-setfield caption=\"\"/>\n (change)\n </$button>\n </$reveal>\n \n\t<$reveal state=\"$:/state/mt/partTitle\" type=\"match\" text=\"custom\" default=\"default\">\n\t\t<$edit-text field=\"draft.title\" placeholder=\"Tiddler title\" class=\"\" size=\"50\"/><<mt-check-title>>\n <$button set=\"$:/state/mt/partTitle\" setTo=\"draft.title\" class=\"\"> \n \t\t<$action-setfield draft.title=\"\"/>\n \t<$action-setfield caption={{!!mt-part.title}}/>\n default\n </$button>\n </$reveal>\n\\end\n\n\n\n\n\n\n\n\n\n\n\n\\define mt-preSelector()\n<$select tiddler=\"$:/temp/mt/part/preTitle\" field=\"text\">\n<option value=\"\"></option>\n<option value=\".\">.</option>\n<option value=\" – part \">part</option>\n<option value=\" – chap. \">chap.</option>\n<option value=\" – section \">section</option>\n</$select>\n\\end\n\n\n\n\n\n\n\n\n\n\\define mt-new-part-table(type:\"$:/type/part\")\n\n<$tiddler tiddler=\"$:/temp/$type$\">\n\n<$set name=\"pre\" value={{$:/temp/mt/part/preTitle}}>\n\n<table class=\"invisible\" style=\"width: 100%\">\n<tr>\n<td><$macrocall $name=\"changeTitle\" type=\"$type$\"/></td>\n</tr>\n<tr>\n<td><<mt-preSelector>><$edit-text field=\"mt-part.order\" placeholder=\"N°\" size=\"4\"/><$edit-text field=\"mt-part.title\" placeholder=\"Title of the part\" class=\"\" size=\"50\"/><<mt-check-title>></td>\n</tr>\n<tr>\n<td><$edit-text field=\"mt-topics.list\" placeholder=\"Topics [[Inside brackets]]\" tag=\"input\" class=\"tc-edit-fields\"/></td>\n</tr>\n<tr>\n<td colspan=\"2\"><$edit-text field=\"text\" placeholder=\"Text\" default=\"\" tag=\"textarea\" class=\"tc-edit-fields\"/></td>\n</tr>\n</table>\n\n</$set>\n\n<$macrocall $name=\"mt-more-fields-part\" type=\"$:/type/part\" template={{$:/type/part!!mt-template.fields}} title=/>\n\n</$tiddler>\n\n\\end\n",
"modified": "20150308161218213",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common $:/tags/Macro",
"title": "$:/plugins/amp/MagicTabs/forms/input/part",
"modifier": "Alberto Molina Pérez"
},
"$:/plugins/amp/MagicTabs/new/part": {
"created": "20150221111719111",
"text": "!New part\n\n<<mt-new-part-table \"$:/type/part\">>\n\n<$macrocall $name=\"mt-new-part-button\"\n type=\"$:/type/part\"\n template={{$:/type/part!!mt-template.fields}}\n title={{$:/temp/$:/type/part!!draft.title}}\n label=\"add\"\n class=\"\"\n pre={{$:/temp/mt/part/preTitle}}\n order={{$:/temp/$:/type/part!!mt-part.order}}\n\t/>",
"modified": "20150228073206301",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/new/part"
},
"$:/plugins/amp/MagicTabs/tabs/parts": {
"text": "<<mt-slider-input>>\n\n!Parts\n\n<$list filter=\"[!is[system]tag[$:/type/part]mt-source.tiddler<currentTiddler>sort[mt-part.order]]\" emptyMessage=\"\"\"\n<div class=\"tc-table-of-contents\">\n\n<$macrocall $name=\"mt-toc-selective-expandable\" parent=<<currentTiddler>> sort=\"sort[mt-part.order]\"/>\n\n</div>\"\"\"/>\n",
"caption": "<<mt-tab-caption>>",
"color": "#d3d3d3",
"created": "20150125013421426",
"creator": "Alberto Molina Pérez",
"description": "Parts (chapters, sections)",
"icon": "$:/plugins/amp/MagicTabs/images/part",
"modified": "20150304191718884",
"modifier": "Alberto Molina Pérez",
"mt-contents.type": "$:/type/part",
"mt-list.filter": "",
"mt-list.filter_alt": "",
"mt-list.heading": "",
"mt-list.heading_alt": "",
"mt-list.sort": "",
"mt-list.sort_alt": "",
"mt-list.template": "$:/plugins/amp/MagicTabs/templates/tabs/parts",
"mt-list.template_alt": "",
"tags": "$:/type/tab $:/tabs/publication $:/tabs/part MagicTabs $:/plugins/amp/MagicTabs/common $:/tabs/untyped",
"title": "$:/plugins/amp/MagicTabs/tabs/parts"
},
"$:/plugins/amp/MagicTabs/templates/types/part": {
"created": "20150220185139289",
"text": "",
"about": "",
"color": "#3333D3",
"icon": "$:/plugins/amp/MagicTabs/images/part",
"modified": "20150228123236425",
"mt-part.order": "",
"mt-part.title": "",
"mt-source.root": "",
"mt-source.tiddler": "",
"tags": "$:/type/part",
"title": "$:/plugins/amp/MagicTabs/templates/types/part"
},
"$:/type/part": {
"text": "",
"caption": "part",
"created": "20150125150841844",
"creator": "Alberto Molina Pérez",
"modified": "20150223193945377",
"modifier": "Alberto Molina Pérez",
"mt-slider-input.add": "",
"mt-slider-input.cancel": "",
"mt-source.type": "$:/type/root",
"mt-template.fields": "$:/plugins/amp/MagicTabs/templates/types/part",
"mt-template.form": "$:/plugins/amp/MagicTabs/new/part",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/type/part"
},
"$:/plugins/amp/MagicTabs/images/part": {
"text": "<<mt-image \"fa-bookmark-o\" \"part\" \"Part\">>",
"created": "20150223145056554",
"creator": "Alberto Molina Pérez",
"modified": "20150223145127567",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/part"
},
"$:/plugins/amp/MagicTabs/macros/mt-slider-input-button-add": {
"created": "20150223172214406",
"text": "\\define mt-slider-input-button-add(type, template, btnClass)\n\n$:/state/mt/slider-input: {{$:/state/mt/slider-input}}\n\n\n\t<$reveal default=\"$template$\" type=\"nomatch\" text=\"\">\n \n\t\t<$set name=\"hasRoot\" filter=\"[[$(storyTiddler)$]!mt-source.root[]]\" value={{$(storyTiddler)$!!mt-source.root}} emptyValue=\"\">\n\n\t\t<$set name=\"noRoot\" filter=\"[[$(storyTiddler)$]!mt-source.tiddler[]mt-source.root[]]\" value={{$(storyTiddler)$!!mt-source.tiddler}} emptyValue=\"\">\n\n\t\t<$set name=\"rootTiddler\" value=<<mt-select-root>>>\n\n\t\t\t<$button class=\"btn-slider-input $btnClass$\" tooltip=\"add\"> \n \n\t\t\t\t<$action-setfield $tiddler=\"$:/state/mt/slider-input\" text={{$:/state/mt/dashboard}}/>\n \n <$action-setfield $tiddler=\"$template$\" title=\"$:/temp/$type$\"/>\n\n <$action-setfield $tiddler=\"$:/temp/$type$\" mt-source.tiddler=\"$(storyTiddler)$\" mt-source.root=<<rootTiddler>>/>\n\n {{$:/core/images/new-button}}\n\n </$button>\n \n\t\t</$set>\n\n\t\t</$set>\n\n\t\t</$set>\n \n\t</$reveal>\n\n <$reveal default=\"$template$\" type=\"match\" text=\"\">\n\n \t<$button class=\"btn-slider-input $btnClass$\" tooltip=\"add\"> \n\n\t\t\t<$action-setfield $tiddler=\"$:/state/mt/slider-input\" text={{$:/state/mt/dashboard}}/>\n\n\t\t\t<$action-setfield $tiddler=\"$:/temp/$type$\" tags=\"$type$\"/>\n\n {{$:/core/images/new-button}}\n\n\t\t</$button>\n\n\t</$reveal>\n\\end\n\n<<mt-slider-input-button-add \"$:/type/part\">>",
"modified": "20150227081954390",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/mt-slider-input-button-add"
},
"$:/plugins/amp/MagicTabs/macros/mt-slider-input-button-cancel": {
"text": "\\define mt-slider-input-button-cancel(type, btnClass)\n\t<$button class=\"tc-btn-invisible\" tooltip=\"cancel\" class=\"btn-slider-input $btnClass$\">\n \t<$action-setfield $tiddler=\"$:/state/mt/slider-input\" text=\"\"/>\n\t\t<$action-deletetiddler $tiddler=\"$:/temp/$type$\"/>\n\t\t{{$:/core/images/cancel-button}}\n\t</$button>\n\\end",
"created": "20150223233252456",
"modified": "20150223233922660",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common $:/tags/Macro",
"title": "$:/plugins/amp/MagicTabs/macros/mt-slider-input-button-cancel"
},
"$:/plugins/amp/MagicTabs/templates/tabs/parts": {
"created": "20150223203847763",
"creator": "Alberto Molina Pérez",
"text": "<h2><$link to={{!!title}}><$view field=\"caption\"><$view field=\"title\"/></$view></$link></h2>\n\n<h3><$transclude field=\"description\"/></h3>\n\n<$list filter=\"[all[current]get[mt-source.tiddler]] [all[current]list[!!mt-topics.list]] [all[current]list[!!mt-source.parents.list]] -[title<storyTiddler>]\" template=\"$:/core/ui/TagTemplate\"/>\n<$list filter=\"[all[current]tags[]!is[system]]\" template=\"$:/core/ui/TagTemplate\"/>\n\n<blockquote>\n\n<$transclude field=\"text\" mode=\"block\"/>\n\n</blockquote>\n\n<br>",
"modified": "20150308161402623",
"modifier": "Alberto Molina Pérez",
"tags": "$:/type/template MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/templates/tabs/parts"
},
"$:/plugins/amp/MagicTabs/new/default": {
"created": "20150215124503441",
"creator": "Alberto Molina Pérez",
"text": "\\define mt-current-temp() $:/temp/$(currentType)$\n\\define mt-tab-input-button(type, template)\n\n\t<$set name=\"currentType\" value={{$:/state/mt/slider-input}}>\n\n\t<$set name=\"rootTiddler\" value=<<mt-select-root>>>\n\n\t<$set name=\"templateTopics\" filter=\"[[$template$]has[modified]!modified[]has[mt-topics.list]!mt-topics.list[]]\" value={{$template$!!mt-topics.list}} emptyValue=\"\">\n\n\t<$set name=\"sourceTopics\" value={{$(storyTiddler)$!!mt-topics.list}}>\n\n \t<$button>\n\n\t\t\t<$action-deletetiddler $tiddler=<<mt-current-temp>>/>\n\n\t\t\t<$action-setfield $tiddler=\"$:/state/mt/slider-input\" text=\"$type$\"/>\n \n\t\t\t<$action-setfield $tiddler=\"$template$\" title=\"$:/temp/$type$\"/>\n\n\t\t\t<$action-setfield $tiddler=\"$:/temp/$type$\" mt-source.tiddler=\"$(storyTiddler)$\" mt-source.root=<<rootTiddler>> mt-topics.list=<<mt-topics-inherit>>/>\n\n \t{{$type$!!caption}}\n\n \t</$button>\n\n\t</$set>\n\n\t</$set>\n\n\t</$set>\n\n\t</$set>\n\n\\end\n\n\\define mt-tab-input-list(rootType, inputType)\n\n <$list filter=\"$rootType$ [all[shadows+tiddlers]prefix[$:/type]mt-source.type[$rootType$]]\">\n\t\t<$set name=\"hasRoot\" filter=\"[[$(storyTiddler)$]!mt-source.root[]]\" value={{$(storyTiddler)$!!mt-source.root}} emptyValue=\"\">\n <$set name=\"noRoot\" filter=\"[[$(storyTiddler)$]!mt-source.tiddler[]mt-source.root[]]\" value={{$(storyTiddler)$!!mt-source.tiddler}} emptyValue=\"\">\n <$macrocall $name=\"mt-tab-input-button\"\n type=<<currentTiddler>> \n template={{!!mt-template.fields}} \n inputType=\"$inputType$\"\n />\n </$set>\n </$set>\n </$list>\n\n <$tiddler tiddler=\"$inputType$\">\n\n !New {{!!caption}}\n \n <$list filter=\"[all[current]has[mt-template.form]!mt-template.form[]]\" emptyMessage=\"\"\"<$macrocall $name='mt-new-tiddler' type={{!!title}}/>\"\"\">\n \n \t\t<$transclude tiddler={{!!mt-template.form}} mode=\"block\"/>\n \n </$list> \n\n </$tiddler>\n\n\\end\n\n\n\\define mt-tab-input()\n\t<$set name=\"inputType\" filter=\"[[$:/state/mt/slider-input]is[tiddler]]\" value={{$:/state/mt/slider-input}} emptyValue={{$(currentTab)$!!mt-contents.type}}>\n\n\t\t<$macrocall $name=\"mt-tab-input-list\" \n\t\t\trootType={{$(currentTab)$!!mt-contents.type}} \n\t\t\tinputType=<<inputType>>\n\t\t\t/>\n \n\t</$set>\n\\end\n\n<<mt-tab-input>>",
"modified": "20150308161743891",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/new/default",
"type": ""
},
"$:/plugins/amp/MagicTabs/macros/mt-new-part": {
"created": "20150225224858934",
"text": "\\define mt-new-part-button2(type:\"$:/type/part\", template, label:\"add\", class=\"\", pre, order)\n\n<$set name=\"hasRoot\" filter=\"[[$(storyTiddler)$]!mt-source.root[]]\" value={{$(storyTiddler)$!!mt-source.root}} emptyValue=\"\">\n\n<$set name=\"noRoot\" filter=\"[[$(storyTiddler)$]!mt-source.tiddler[]mt-source.root[]]\" value={{$(storyTiddler)$!!mt-source.tiddler}} emptyValue=\"\">\n\n<$set name=\"rootTiddler\" value=<<mt-select-root>>>\n\n<$reveal state=\"$:/temp/$type$!!draft.title\" type=\"nomatch\" text=\"\">\n\n<$set name=\"caption\" filter=\"[[$:/temp/$type$]has[mt-part.title]!mt-part.title[]]\" value={{$:/temp/$type$!!mt-part.title}} emptyValue={{$:/temp/$type$!!draft.title}}>\n\n <$button tooltip=\"$label$\" class=\"$class$\">\n <$action-setfield $tiddler=\"$:/state/mt/new-tiddler\" text={{$:/temp/$type$!!draft.title}}/>\n <$action-setfield $tiddler=\"$:/temp/$type$\" title={{$:/temp/$type$!!draft.title}}/>\n <$action-setfield $tiddler={{$:/temp/$type$!!draft.title}} mt-source.tiddler=\"$(storyTiddler)$\" mt-source.root=<<rootTiddler>> caption=<<caption>>/>\n <$action-deletetiddler $tiddler=\"$:/temp/$type$\"/>\n <$action-setfield $tiddler=\"$template$\" title=\"$:/temp/$type$\"/>\n <$action-setfield $tiddler=\"$:/temp/$type$\" mt-source.tiddler=\"$(storyTiddler)$\" mt-source.root=<<rootTiddler>>/>\n <$action-sendmessage $message=\"tm-notify\" $param=\"$:/plugins/amp/MagicTabs/notifications/new-tiddler\"/>\n $label$: {{$:/temp/$type$!!draft.title}}\n </$button>\n\n</$set>\n\n</$reveal>\n\n<$reveal state=\"$:/temp/$type$!!draft.title\" type=\"match\" text=\"\">\n\n<$set name=\"title\" value=\"$(storyTiddler)$$pre$$order$\">\n\n<$set name=\"caption\" filter=\"[[$:/temp/$type$]has[mt-part.title]!mt-part.title[]]\" value={{$:/temp/$type$!!mt-part.title}} emptyValue=<<title>>>\n\nCAPTION: <<caption>>\n\n <$button tooltip=\"$label$\" class=\"$class$\">\n <$action-setfield $tiddler=\"$:/state/mt/new-tiddler\" text=<<title>>/>\n <$action-setfield $tiddler=\"$:/temp/$type$\" title=<<title>>/>\n <$action-setfield $tiddler=<<title>> mt-source.tiddler=\"$(storyTiddler)$\" mt-source.root=<<rootTiddler>> caption=<<caption>>/>\n <$action-deletetiddler $tiddler=\"$:/temp/$type$\"/>\n <$action-setfield $tiddler=\"$template$\" title=\"$:/temp/$type$\"/>\n <$action-setfield $tiddler=\"$:/temp/$type$\" mt-source.tiddler=\"$(storyTiddler)$\" mt-source.root=<<rootTiddler>>/>\n <$action-sendmessage $message=\"tm-notify\" $param=\"$:/plugins/amp/MagicTabs/notifications/new-tiddler\"/>\n <<title>>\n </$button>\n \n</$set>\n \n</$set>\n\n</$reveal>\n\n</$set>\n \n</$set>\n \n</$set>\n\n\\end\n\n\\define mt-new-part-button(type:\"$:/type/part\")\n<$macrocall $name=\"mt-new-part-button2\"\n type=\"$type$\"\n template={{$type$!!mt-template.fields}}\n title={{$:/temp/$type$!!draft.title}}\n label=\"add\"\n class=\"\"\n pre={{$:/temp/mt/part/preTitle}}\n order={{$:/temp/$type$!!mt-part.order}}\n\t/>\n\\end\n<<mt-new-part>>",
"creator": "Alberto Molina Pérez",
"modified": "20150228080253405",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/tags/Macro $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/mt-new-part"
},
"$:/plugins/amp/MagicTabs/ViewTemplate/subtitle/part": {
"created": "20150224231823523",
"text": "<$list filter=\"[all[current]tag[$:/type/part]has[mt-part.title]!mt-part.title<currentTiddler>]\">\n<h1 style=\"color: grey;\"><$view field=\"mt-part.title\"/></h1>\n</$list>",
"creator": "Alberto Molina",
"list-before": "$:/core/ui/ViewTemplate/body",
"modified": "20150228101241822",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/ViewTemplate MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/ViewTemplate/subtitle/part",
"type": ""
},
"$:/plugins/amp/MagicTabs/images/question-circle": {
"text": "<<mt-image \"fa-question-circle\" \"question\" \"Question\">>\n",
"created": "20150228111645891",
"creator": "Alberto Molina Pérez",
"modified": "20150228111728473",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/images/question-circle"
},
"$:/config/MagicTabs/person/title/$:/plugins/amp/MagicTabs": {
"title": "$:/config/MagicTabs/person/title/$:/plugins/amp/MagicTabs",
"text": "Both",
"modified": "20150228144456867"
}
}
}
\define fields(fieldTitle:"title")
<br><br><$checkbox tag="$:/tabs/all"> default (applies to all tiddlers)</$checkbox>
<$checkbox tag="$:/tabs/typed"> typed (all typed tiddlers)</$checkbox>
<$checkbox tag="$:/tabs/untyped"> typed (all ''untyped'' tiddlers)</$checkbox>
<table class="tc-view-field-table">
<tbody>
<tr>
<td>title</td>
<td><$edit-text field="$fieldTitle$" size="40"/></td>
</tr>
<$list filter="[all[current]fields[]sort[title]] -text -created -creator -modified -modifier -title -draft.title" variable="field">
<tr>
<td><<field>></td>
<td><$edit-text field=<<field>> size="40"/></td>
</tr>
</$list>
<tr>
<td>text</td>
<td><$edit-text field="text" size="40"/></td>
</tr>
</tbody>
</table>
\end
\define accordion()
<$reveal state=<<qualify "$:/state/mt/accordion">> type="nomatch" text=<<currentTiddler>>>
<$button set=<<qualify "$:/state/mt/accordion">> setTo=<<currentTiddler>> class="tc-btn-invisible" style="padding-left:1em">
<strong>{{$:/core/images/right-arrow}} <$view field="description"/></strong>
</$button>
</$reveal>
<$reveal state=<<qualify "$:/state/mt/accordion">> type="match" text=<<currentTiddler>>>
<$button set=<<qualify "$:/state/mt/accordion">> setTo="" class="tc-btn-invisible" style="padding-left:1em">
<strong>{{$:/core/images/down-arrow}} <$view field="description"/></strong>
</$button>
<$link to={{!!title}}>…</$link>
<<fields>>
</$reveal>
\end
<<mt-slider-input tiddler:"$:/plugins/amp/MagicTabs/new/tab" type:"$:/type/tab" contentClass:"tc-tiddler-info">>
!!Tab manager
<$list filter="[all[shadows+tiddlers]tag[$:/type/tab]tags[]has[plugin-type]plugin-type[plugin]]">
!!!<$link to={{!!title}}><$view field="description"/></$link>
<$list filter="[all[shadows+tiddlers]tag[$:/type/tab]tag{!!title}!has[draft.of]!prefix[$:/temp/]]">
<<accordion>>
</$list>
</$list>
!!!Custom
<$list filter="[all[shadows+tiddlers]tag[$:/type/tab]] -[all[shadows+tiddlers]plugin-type[plugin]tagging[]] -$:/plugins/amp/MagicTabs/templates/types/tab +[!has[draft.of]!prefix[$:/temp/]sort[]]" emptyMessage="none">
<<accordion>>
</$list>
<<tabs "$:/plugins/amp/MagicTabs/config/plugins $:/plugins/amp/MagicTabs/config/TypeManager $:/plugins/amp/MagicTabs/config/TabManager $:/plugins/amp/MagicTabs/config/appearance" "$:/plugins/amp/MagicTabs/config/plugins">>
<<mt-image "fa-magic" "magic tabs" "MagicTabs">>
{
"tiddlers": {
"$:/plugins/amp/MagicTabs/images/quote": {
"text": "<<mt-image \"fa-quote-left\" \"quote\" \"Quote\">>",
"created": "20141123011539928",
"creator": "Alberto Molina Pérez",
"modified": "20141125094718235",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs",
"title": "$:/plugins/amp/MagicTabs/images/quote"
},
"$:/plugins/amp/MagicTabs/tabs/quotes": {
"text": "<<mt-slider-input>>\n\n<<mt-tab-contents>>",
"caption": "<<mt-tab-caption>>",
"color": "#d3d3d3",
"created": "20141123011444936",
"creator": "Alberto Molina Pérez",
"description": "Quotes",
"icon": "$:/plugins/amp/MagicTabs/images/quote",
"modified": "20150309190710908",
"modifier": "Alberto Molina Pérez",
"mt-contents.type": "$:/type/quote",
"mt-list.filter": "[all[tiddlers]mt-source.tiddler<currentTiddler>] [all[current]listed[mt-source.authors.list]] [all[current]listed[mt-topics.list]] +[tag[$:/type/quote]!has[draft.of]!is[system]nsort[mt-quote.page.alpha]]",
"mt-list.filter_alt": "[all[current]tagging[]] [all[tiddlers]mt-source.tiddler<currentTiddler>listed[mt-topics.list]] [all[tiddlers]mt-source.root<currentTiddler>] [all[tiddlers]mt-source.tiddler<currentTiddler>tagging[]] [all[current]listed[mt-topics.list]listed[mt-topics.list]] [all[current]listed[mt-topics.list]tagging[]] +[tag[$:/type/quote]!has[draft.of]!is[system]nsort[mt-quote.page.alpha]]",
"mt-list.heading": "Quotes",
"mt-list.heading_alt": "Related",
"mt-list.template": "$:/plugins/amp/MagicTabs/templates/tabs/quotes",
"mt-list.template_alt": "$:/plugins/amp/MagicTabs/templates/tabs/quotes",
"tags": "$:/type/tab MagicTabs $:/tabs/publication $:/tabs/author $:/tabs/concept $:/tabs/theory $:/plugins/amp/MagicTabs/reading $:/tabs/part",
"title": "$:/plugins/amp/MagicTabs/tabs/quotes"
},
"$:/plugins/amp/MagicTabs/css/quotes": {
"created": "20140421120131878",
"text": ".cit {\ndisplay: block;\nfont-family: Georgia, serif;\nfont-size: 14px;\nfont-style: normal;\ntext-align: justify;\nmargin: 2.25em 1em 2.25em 1em;\npadding: 0.25em 60px;\nline-height: 20px;\nposition: relative;\ncolor: <<color foreground>>;\n-moz-border-radius: 10px;\nborder-radius: 10px;\nbackground-color: #FFFFEE ;\n}\n\n.cit:before {\ndisplay: block;\ncontent: \"\\201C\";\nfont-size: 80px;\nposition: absolute;\nleft: 20px;\ntop: 25px;\ncolor: #7a7a7a;\n}\n\n.cit:after {\ndisplay: block;\ncontent: \"\\201D\";\nfont-size: 80px;\nposition: absolute;\nright: 20px;\nbottom: 0px;\ncolor: #7a7a7a;\n}\n\n.cit cite {\ncolor: #999999;\nfont-size: 14px;\ndisplay: block;\nmargin-top: 15px;\nmargin-bottom: 1em;\n}\n\n.cit cite:before {\ncontent: \"\\2014 \\2009\";\n}",
"creator": "Alberto Molina",
"modified": "20141123114322126",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/Stylesheet MagicTabs",
"title": "$:/plugins/amp/MagicTabs/css/quotes",
"type": "text/css"
},
"cit": {
"text": "<div class=\"cit\">\n\n{{!!text}}\n\n<cite>\n<$link>{{!!title}}</$link>\n</cite>\n</div>",
"created": "20140422115346864",
"creator": "Alberto Molina",
"modified": "20140628201603250",
"modifier": "Alberto Molina",
"tags": "nouveau",
"title": "cit"
},
"$:/plugins/amp/MagicTabs/images/book": {
"created": "20141124112530336",
"creator": "Alberto Molina Pérez",
"text": "<<mt-image \"fa-book\" \"book\" \"Book\">>",
"modified": "20141124112611466",
"modifier": "Alberto Molina Pérez",
"title": "$:/plugins/amp/MagicTabs/images/book",
"tags": "MagicTabs"
},
"$:/plugins/amp/MagicTabs/images/article": {
"text": "<<mt-image \"fa-file-text-o\" \"article\" \"Article\">>",
"created": "20141124112618595",
"creator": "Alberto Molina Pérez",
"modified": "20141125094811681",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs",
"title": "$:/plugins/amp/MagicTabs/images/article"
},
"$:/plugins/amp/MagicTabs/images/chapter": {
"created": "20141124185333156",
"creator": "Alberto Molina Pérez",
"text": "<<mt-image \"fa-bookmark-o\" \"chapter\" \"Chapter\">>",
"modified": "20141124185821455",
"modifier": "Alberto Molina Pérez",
"title": "$:/plugins/amp/MagicTabs/images/chapter",
"tags": "MagicTabs"
},
"$:/plugins/amp/MagicTabs/macros/pages": {
"text": "\\define pages()\n<$set name=\"page_alpha\" value={{$:/temp/quote!!page_alpha}}>\n<$set name=\"page_omega\" value={{$:/temp/quote!!page_omega}}>\n\n<$set name=\"p\" filter=\"[[$:/temp/quote]field:page_omega[]]\" \n value=<<page_alpha>>\n emptyValue=<<appendPages>>\n >\n\n<<p>>\n\n</$set>\n</$set>\n</$set>\n\\end",
"created": "20141126082734590",
"creator": "Alberto Molina Pérez",
"modified": "20141126083837593",
"modifier": "Alberto Molina Pérez",
"title": "$:/plugins/amp/MagicTabs/macros/pages"
},
"$:/plugins/amp/MagicTabs/buttons/input/quotes": {
"text": "\\define inputQuote(tempTiddler,authors,year,pages,source)\n<$button>\n <$action-sendmessage $message=\"tm-new-tiddler\" $param=\"$tempTiddler$\"\n title=\"$authors$ $year$: $pages$\"\n authors={{!!authors}}\n source=\"[[$source$]]\"\n tags=\"$:/type/quote\"\n icon={{$:/type/quote!!icon}}\n color={{$:/type/quote!!color}}\n />\n <$action-deletefield $tiddler=\"$tempTiddler$\" tags text about description chapter page_alpha page_omega/>\n <$action-deletefield $tiddler=\"$:/temp/title\" text/>\n add\n</$button>\n\\end\n\n<$set name=\"tempTiddler\" value=\"$:/temp/quote\">\n<$set name=\"page_alpha\" value={{$:/temp/quote!!page_alpha}}>\n<$set name=\"page_omega\" value={{$:/temp/quote!!page_omega}}>\n\n<$list filter=\"[<currentTiddler>tag[$:/type/publication]] [<currentTiddler>tag[$:/type/chapter]]\">\n\n<$reveal state=\"$:/temp/quote!!page_alpha\" type=\"nomatch\" text=\"\">\n\n<$set name=\"year\" filter=\"[all[current]has[publication_date]!publication_date[]]\" value={{!!publication_date}} emptyValue=\"(n.d.)\">\n\n<$set name=\"authors\" filter=\"[all[current]has[authors_title]!authors_title[]]\" value={{!!authors_title}} emptyValue={{!!authors}}>\n\n<$set name=\"pages\" filter=\"[[$:/temp/quote]page_omega[]]\"\n value={{$:/temp/quote!!page_alpha}}\n emptyValue=<<appendPages>>\n >\n\n<$macrocall $name=\"inputQuote\"\n tempTiddler=\"$:/temp/quote\"\n authors=<<authors>>\n year=<<year>>\n pages=<<pages>>\n source={{!!title}}\n />\n\n</$set>\n\n</$set>\n\n</$set>\n\n</$reveal>\n\n</$list>\n\n<$list filter=\"[<currentTiddler>tag[$:/type/author]] [<currentTiddler>tag[$:/type/person]]\">\n\n</$list>\n\n</$set>\n</$set>\n</$set>\n\n",
"created": "20141125101553189",
"creator": "Alberto Molina Pérez",
"modified": "20150203185420755",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs",
"title": "$:/plugins/amp/MagicTabs/buttons/input/quotes"
},
"$:/plugins/amp/MagicTabs/ViewTemplate/person/publications": {
"text": "\\define publicationsList()\n<$list filter=\"[all[current]!is[system]tag[$:/type/author]]\">\n <$list filter=\"[all[current]listed[]tag[$:/type/publication]!has[draft.of]] [all[current]listed[mt-source.authors.list]tag[$:/type/publication]!has[draft.of]] +[sort[mt-publication.date]]\">\n <br>— <$link to={{!!title}}><$transclude tiddler={{!!icon}}/> <$view field=\"mt-publication.title\"/>, <$view field=\"mt-publication.date\"/></$link>\n </$list>\n</$list>\n\\end\n\n<div class=\"tc-menu-list-item text-grey\">\n <$list filter=\"[all[current]listed[mt-source.authors.list]tag[$:/type/publication]] +[limit[1]]\">\n Publications :\n </$list>\n <<publicationsList>>\n</div>",
"created": "20140616154022572",
"creator": "Alberto Molina Pérez",
"list-before": "$:/plugins/amp/MagicTabs/ViewTemplate/TabsBar",
"modified": "20150221090651128",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/ViewTemplate $:/plugins/amp/MagicTabs/reading MagicTabs",
"title": "$:/plugins/amp/MagicTabs/ViewTemplate/person/publications"
},
"$:/plugins/amp/MagicTabs/new/author": {
"created": "20150218220825212",
"text": "<<mt-input-person type:\"$:/type/author\">>\n<<mt-new-person type:\"$:/type/author\">>",
"creator": "Alberto Molina Pérez",
"modified": "20150218221549867",
"modifier": "Alberto Molina Pérez",
"tags": "$:/action/hide/tabs MagicTabs $:/action/hide/tags $:/plugins/amp/MagicTabs/reading",
"title": "$:/plugins/amp/MagicTabs/new/author"
},
"$:/plugins/amp/MagicTabs/new/quote": {
"created": "20150225223059126",
"text": "<<mt-fields-form \"$:/type/quote\">>\n\n<<mt-new-quote-button>>",
"title": "$:/plugins/amp/MagicTabs/new/quote",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/reading",
"modified": "20150226084052884"
},
"$:/plugins/amp/MagicTabs/new/publication": {
"text": "{{$:/plugins/amp/MagicTabs/forms/input/publication}}\n\n{{$:/plugins/amp/MagicTabs/buttons/input/publication}}",
"created": "20150215091411739",
"creator": "Alberto Molina Pérez",
"modified": "20150221092504462",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/reading",
"test": "",
"title": "$:/plugins/amp/MagicTabs/new/publication"
},
"$:/plugins/amp/MagicTabs/templates/tabs/quotes": {
"created": "20140422115346864",
"creator": "Alberto Molina",
"text": "<div class=\"cit\">\n\n!!!''{{!!description}}''\n\n{{!!text}}\n\n<cite>\n<$link>{{!!title}}</$link>\n</cite>\n</div>",
"modified": "20141230101722919",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/type/template",
"title": "$:/plugins/amp/MagicTabs/templates/tabs/quotes"
},
"$:/plugins/amp/MagicTabs/templates/tabs/chapters": {
"text": "<h3><$link to={{!!title}}>Chap. <$view field=\"mt-chapter.order\"/> : <$view field=\"mt-chapter.title\"/></$link></h3>\n\n<h4><$transclude field=\"description\"/></h4>",
"created": "20141229113512679",
"creator": "Alberto Molina Pérez",
"modified": "20150220101811849",
"modifier": "Alberto Molina Pérez",
"tags": "$:/type/template MagicTabs",
"title": "$:/plugins/amp/MagicTabs/templates/tabs/chapters"
},
"$:/type/author": {
"created": "20141230112836838",
"text": "",
"caption": "author",
"color": "#ff8383",
"creator": "Alberto Molina Pérez",
"icon": "$:/plugins/amp/MagicTabs/images/person",
"modified": "20150223120755958",
"modifier": "Alberto Molina Pérez",
"mt-dashboard.add.content": "$:/plugins/amp/MagicTabs/new/author",
"mt-template.fields": "$:/plugins/amp/MagicTabs/templates/types/author",
"mt-template.form": "$:/plugins/amp/MagicTabs/new/author",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/reading",
"title": "$:/type/author",
"mt-source.type": "$:/type/person"
},
"$:/plugins/amp/MagicTabs/macros/pubButton": {
"text": "\\define pubButton2(type, tempTiddler:\"$:/temp/$:/type/publication\", number, state)\n<strong><<$type$Title$number$>></strong>\n<$tiddler tiddler=\"$:/type/$state$\">\n\n<$button>\n <$action-deletefield $tiddler=\"$tempTiddler$\" author1 author2 author3 author4/>\n <$action-setfield $tiddler=\"$tempTiddler$\" title=<<$type$Title$number$>>/>\n <$action-setfield $tiddler=<<$type$Title$number$>>\n authors=<<authors$number$>> \n authors_title=<<authorsTitle$number$>>\n />\n <$action-deletetiddler $tiddler=\"$tempTiddler$\"/>\n <$action-setfield $tiddler={{!!template}} title=\"$tempTiddler$\"/>\n add\n</$button>\n</$tiddler>\n\\end\n\n\\define pubButton(type, tempTiddler:\"$:/temp/$:/type/publication\", number)\n <$macrocall $name=\"pubButton2\"\n type=\"$type$\"\n tempTiddler=\"$tempTiddler$\"\n number=\"$number$\"\n state={{$:/state/input/pub}}\n />\n\\end\n",
"created": "20141231105432836",
"creator": "Alberto Molina Pérez",
"modified": "20150203230551504",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/tags/Macro",
"title": "$:/plugins/amp/MagicTabs/macros/pubButton"
},
"$:/config/EditTemplateFields/Visibility/authors_title": {
"created": "20141231122000041",
"creator": "Alberto Molina Pérez",
"text": "hide",
"title": "$:/config/EditTemplateFields/Visibility/authors_title",
"tags": "",
"modified": "20141231122103846",
"modifier": "Alberto Molina Pérez"
},
"$:/plugins/amp/MagicTabs/templates/tabs/publications": {
"created": "20150105112916833",
"creator": "Alberto Molina Pérez",
"text": "\\define title(type)\n\t<$transclude tiddler={{!!icon}}/>\n\t<$link to={{!!title}}>\n\t\t<$reveal type=\"nomatch\" state=\"!!mt-source.authors.list\" text=\"[[$(storyTiddler)$]]\">\n\t\t\t{{!!title}}\n </$reveal>\n\t\t<$reveal type=\"match\" state=\"!!mt-source.authors.list\" text=\"[[$(storyTiddler)$]]\">\n\t\t\t<$view field=\"mt-publication.title\"/>\n <$reveal type=\"nomatch\" state=\"!!mt-publication.date\" text=\"\">, \n \t<$view field=\"mt-publication.date\"/>\n\t\t\t</$reveal>\n </$reveal>\n\t</$link>\n\\end\n\n<h2><<title>></h2>\n<h3>{{!!description}}</h3>\n<$list filter=\"[all[current]list[!!mt-topics.list]!is[system]]\" template=\"$:/core/ui/TagTemplate\"/><$list filter=\"[all[current]tags[]!is[system]]\" template=\"$:/core/ui/TagTemplate\"/><br><br>\n\n{{!!text}}\n\n<br>",
"modified": "20150308161335260",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/reading",
"title": "$:/plugins/amp/MagicTabs/templates/tabs/publications"
},
"$:/plugins/amp/MagicTabs/templates/types/author": {
"created": "20150124084452165",
"creator": "Alberto Molina Pérez",
"text": "",
"about": "",
"icon": "$:/plugins/amp/MagicTabs/images/person",
"modified": "20150202225300760",
"modifier": "Alberto Molina Pérez",
"tags": "$:/type/person $:/type/author",
"title": "$:/plugins/amp/MagicTabs/templates/types/author",
"color": "#FF8383"
},
"$:/plugins/amp/MagicTabs/templates/types/quote": {
"created": "20150124151524517",
"creator": "Alberto Molina Pérez",
"text": "",
"color": "#DEB887",
"icon": "$:/plugins/amp/MagicTabs/images/quote",
"modified": "20150226085637428",
"modifier": "Alberto Molina Pérez",
"tags": "$:/type/quote $:/type/note",
"title": "$:/plugins/amp/MagicTabs/templates/types/quote",
"about": "",
"mt-source.tiddler": "",
"mt-source.authors.list": "",
"mt-quote.page.alpha": "",
"mt-quote.page.omega": "",
"mt-publication.title": "",
"mt-publication.date": "",
"mt-publication.part": ""
},
"$:/plugins/amp/MagicTabs/templates/types/article": {
"text": "",
"color": "#77ADD9",
"created": "20150203004946334",
"icon": "$:/plugins/amp/MagicTabs/images/article",
"modified": "20150216185827437",
"mt-publication.issue": "",
"mt-publication.journal": "",
"mt-publication.volume": "",
"tags": "$:/type/article $:/type/publication",
"title": "$:/plugins/amp/MagicTabs/templates/types/article"
},
"$:/plugins/amp/MagicTabs/templates/types/book": {
"created": "20150203005116435",
"text": "",
"color": "#D98F77",
"icon": "$:/plugins/amp/MagicTabs/images/book",
"modified": "20150216224942842",
"mt-publication.edition": "",
"mt-publication.publisher": "",
"mt-publication.volume": "",
"tags": "$:/type/book $:/type/publication",
"title": "$:/plugins/amp/MagicTabs/templates/types/book",
"mt-publication.city": ""
},
"$:/plugins/amp/MagicTabs/templates/types/publication": {
"text": "",
"color": "#D98F77",
"created": "20150215005821949",
"icon": "$:/plugins/amp/MagicTabs/images/book",
"modified": "20150228071426371",
"mt-publication.date": "",
"mt-publication.subtitle": "",
"mt-publication.title": "",
"mt-source.authors.list": "",
"tags": "$:/type/publication",
"title": "$:/plugins/amp/MagicTabs/templates/types/publication"
},
"$:/type/publication": {
"created": "20150125150841844",
"text": "",
"caption": "publication",
"creator": "Alberto Molina Pérez",
"modified": "20150223121447719",
"modifier": "Alberto Molina Pérez",
"mt-dashboard.add.content": "$:/plugins/amp/MagicTabs/new/publication",
"mt-dashboard.heading": "Publications",
"mt-dashboard.icon": "$:/plugins/amp/MagicTabs/images/book",
"mt-template.fields": "$:/plugins/amp/MagicTabs/templates/types/publication",
"mt-template.form": "$:/plugins/amp/MagicTabs/new/publication",
"tags": "$:/tags/MagicTabs/dashboard MagicTabs $:/plugins/amp/MagicTabs/reading",
"title": "$:/type/publication",
"mt-source.type": "$:/type/root"
},
"$:/plugins/amp/MagicTabs/tabs/publications": {
"text": "<<mt-slider-input \"$:/plugins/amp/MagicTabs/new/default\">>\n\n<<mt-tab-contents>>",
"caption": "<<mt-tab-caption>>",
"color": "#d3d3d3",
"created": "20150125013421426",
"creator": "Alberto Molina Pérez",
"description": "Publications",
"icon": "$:/plugins/amp/MagicTabs/images/article",
"modified": "20150309232412218",
"modifier": "Alberto Molina Pérez",
"mt-contents.type": "$:/type/publication",
"mt-list.filter": "[all[current]listed[mt-source.authors.list]] [all[current]listed[mt-topics.list]] +[tag[$:/type/publication]!is[system]!has[draft.of]nsort[mt-publication.date]]",
"mt-list.filter_alt": "",
"mt-list.heading": "",
"mt-list.heading_alt": "",
"mt-list.template": "$:/plugins/amp/MagicTabs/templates/tabs/publications",
"mt-list.template_alt": "",
"tags": "$:/type/tab $:/tabs/author $:/tabs/concept $:/tabs/theory $:/plugins/amp/MagicTabs/reading",
"title": "$:/plugins/amp/MagicTabs/tabs/publications"
},
"$:/plugins/amp/MagicTabs/tabs/chapters": {
"text": "<<mt-slider-input>>\n\n<<mt-tab-contents>>",
"caption": "<<mt-tab-caption>>",
"color": "#d3d3d3",
"created": "20150125013421426",
"creator": "Alberto Molina Pérez",
"description": "Chapters",
"icon": "$:/plugins/amp/MagicTabs/images/chapter",
"modified": "20150226161109321",
"modifier": "Alberto Molina Pérez",
"mt-contents.type": "$:/type/chapter",
"mt-list.filter": "",
"mt-list.filter_alt": "",
"mt-list.heading": "",
"mt-list.heading_alt": "",
"mt-list.template": "$:/plugins/amp/MagicTabs/templates/tabs/chapters",
"mt-list.template_alt": "",
"tags": "$:/type/tab $:/plugins/amp/MagicTabs/reading",
"title": "$:/plugins/amp/MagicTabs/tabs/chapters"
},
"$:/plugins/amp/MagicTabs/templates/types/chapter": {
"text": "",
"about": "",
"color": "#44ba46",
"created": "20150207180159702",
"icon": "$:/plugins/amp/MagicTabs/images/chapter",
"modified": "20150217225430119",
"order": "",
"parents": "",
"tags": "$:/type/chapter $:/type/publication",
"title": "$:/plugins/amp/MagicTabs/templates/types/chapter"
},
"$:/type/chapter": {
"text": "",
"caption": "chapter",
"created": "20150125150841844",
"creator": "Alberto Molina Pérez",
"modified": "20150220221246565",
"modifier": "Alberto Molina Pérez",
"mt-dashboard.add.content": "$:/plugins/amp/MagicTabs/new/chapter",
"mt-dashboard.heading": "Chapters",
"mt-dashboard.icon": "$:/plugins/amp/MagicTabs/images/chapter",
"mt-source.parents": "",
"mt-template.fields": "$:/plugins/amp/MagicTabs/templates/types/chapter",
"mt-template.form": "$:/plugins/amp/MagicTabs/new/chapter",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/reading",
"title": "$:/type/chapter"
},
"$:/type/quote": {
"created": "20150125150841844",
"text": "",
"caption": "quote",
"creator": "Alberto Molina Pérez",
"modified": "20150223115145566",
"modifier": "Alberto Molina Pérez",
"mt-template.fields": "$:/plugins/amp/MagicTabs/templates/types/quote",
"mt-template.form": "$:/plugins/amp/MagicTabs/new/quote",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/reading",
"title": "$:/type/quote",
"mt-source.type": "$:/type/note"
},
"$:/plugins/amp/MagicTabs/buttons/input/publication": {
"text": "\\define buttonPub(type:\"$:/type/publication\", authorsNumber:\"1\")\n\n<$tiddler tiddler=\"$:/temp/$type$\">\n\n<$set name=\"publicationTitle\" value={{!!mt-publication.title}}>\n\n<$set name=\"publicationDate\" filter=\"[all[current]has[mt-publication.date]!mt-publication.date[]]\" value={{!!mt-publication.date}} emptyValue=\"n.d.\">\n\n<$set name=\"author1\" filter=\"[[$(person1)$]has[mt-person.surname]!mt-person.surname[]]\" value={{$(person1)$!!mt-person.surname}} emptyValue={{$(person1)$!!mt-person.name}}>\n\n<$set name=\"author2\" filter=\"[[$(person2)$]has[mt-person.surname]!mt-person.surname[]]\" value={{$(person2)$!!mt-person.surname}} emptyValue={{$(person2)$!!mt-person.name}}>\n\n<$set name=\"author3\" filter=\"[[$(person3)$]has[mt-person.surname]!mt-person.surname[]]\" value={{$(person3)$!!mt-person.surname}} emptyValue={{$(person3)$!!mt-person.name}}>\n\n<$set name=\"author4\" filter=\"[[$(person4)$]has[mt-person.surname]!mt-person.surname[]]\" value={{$(person4)$!!mt-person.surname}} emptyValue={{$(person4)$!!mt-person.name}}>\n\n<$set name=\"authorsTitle\" value=<<authorsTitle$authorsNumber$>>>\n \n\t<$button>\n\t\t<$action-setfield title=<<pubTitle_book>>/>\n <$action-setfield $tiddler=<<pubTitle_book>> mt-source.authors.list=\"$(authorsList)$\" mt-authors.title=<<authorsTitle>> mt-source.tiddler=\"\"/>\n <$action-deletetiddler $tiddler=\"$:/temp/people\"/>\n <$action-deletetiddler $tiddler=\"$:/temp/$type$\"/>\n <$action-setfield $tiddler={{$type$!!mt-template.fields}} title=\"$:/temp/$type$\"/>\n\t\t<<pubTitle_book>>\n\t</$button>\n \n</$set> \n\n</$set> \n\n</$set> \n\n</$set> \n\n</$set>\n\n</$set>\n\n</$set>\n\n</$tiddler>\n\\end\n\n\\define mt-new-publication(type:\"$:/type/publication\")\n<$reveal state=\"$:/temp/people!!person.1\" type=\"nomatch\" text=\"\">\n\n<$reveal state=\"$:/temp/$type$!!mt-publication.title\" type=\"nomatch\" text=\"\">\n\n<$tiddler tiddler=\"$:/temp/people\">\n\n<$set name=\"authorsNumber\" filter=\"[all[current]fields[]prefix[person.]last[]removeprefix[person.]]\">\n\n<$set name=\"authorsList\" value={{$:/temp/people!!tags}}>\n\n<$set name=\"person1\" value={{$:/temp/people!!person.1}}>\n\n<$set name=\"person2\" value={{$:/temp/people!!person.2}}>\n\n<$set name=\"person3\" value={{$:/temp/people!!person.3}}>\n\n<$set name=\"person4\" value={{$:/temp/people!!person.4}}>\n\n<$macrocall $name=\"buttonPub\"\n\ttype=\"$type$\" \n authorsNumber=<<authorsNumber>>\n />\n \n</$set>\n \n</$set>\n \n</$set>\n \n</$set>\n \n</$set>\n \n</$set>\n\n</$tiddler>\n\n</$reveal>\n\n</$reveal>\n\\end\n<<mt-new-publication>>",
"created": "20150213213824500",
"modified": "20150228145626844",
"tags": "$:/plugins/amp/MagicTabs/reading MagicTabs",
"title": "$:/plugins/amp/MagicTabs/buttons/input/publication"
},
"$:/plugins/amp/MagicTabs/forms/input/publication": {
"created": "20150215112415072",
"creator": "Alberto Molina Pérez",
"text": "\\define mt-publication-form2(type, template, tempTiddler, parentType, size)\n <$tiddler tiddler=\"$tempTiddler$\">\n\n <$set name=\"show\" filter=\"[[$type$]has[mt-source.parents.list]!mt-source.parents.list[]!mt-source.parents.list[$:/type/root]]\" value=\"yes\" emptyValue=\"no\">\n <$reveal default=<<show>> type=\"match\" text=\"yes\">\n <$checkbox tiddler=\"$tempTiddler$\" tag=\"$parentType$\"> {{$parentType$!!caption}} (inherit fields)</$checkbox>\n </$reveal>\n </$set>\n\n<$edit-text field<$edit-text field=\"mt-publication.title\" placeholder=\"Publication title\" class=\"tc-edit-fields\"/>\n<$edit-text field<$edit-text field=\"mt-publication.date\" placeholder=\"Date\" class=\"\"/>\n\n<$edit-text field=\"mt-topics.list\" placeholder=\"Topics [[Inside brackets]]\" tag=\"input\" class=\"tc-edit-fields\"/>\n<$edit-text field=\"text\" placeholder=\"Text\" default=\"\" tag=\"textarea\" class=\"tc-edit-fields\"/>\n\n<<mt-fields-form-more \"$type$\">>\n\n</$tiddler>\n\\end\n\n\\define mt-publication-form(type, tempTiddler, size:\"65\")\n<$reveal state=\"$type$!!modified\" type=\"nomatch\" text=\"\">\n <$macrocall $name=\"mt-publication-form2\"\n type=\"$type$\"\n template={{$type$!!mt-template.fields}}\n tempTiddler=\"$:/temp/$type$\"\n parentType={{$type$!!mt-source.parents.list}}\n size=\"$size$\"\n />\n</$reveal>\n<$reveal state=\"$type$!!modified\" type=\"match\" text=\"\">\n The tiddler [[$type$]] doesn't exist.\n</$reveal>\n\\end\n\n<<mt-add-people \"$:/type/author\">>\n\n<<mt-publication-form type:\"$:/type/publication\">>",
"modified": "20150308162827192",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/reading",
"test": "",
"title": "$:/plugins/amp/MagicTabs/forms/input/publication"
},
"$:/plugins/amp/MagicTabs/macros/mt-add-people": {
"text": "\\define selectPerson()\n\t\t<$select tiddler=\"$:/temp/people\">\n \t\t<option value=\"\">{{$(type)$!!caption}}</option>\n \t\t<$list filter=\"[!is[system]tag[$:/type/person]] -[all[current]tags[]tag[$:/type/person]]\" variable=\"person\">\n \t\t\t<option><<person>></option>\n \t\t</$list>\n\t\t</$select>\n\\end\n\n\\define addPerson()\n\t<$tiddler tiddler=\"$:/temp/people\">\n\t\t<$fieldmangler>\n\t\t\t<$button>\n\t\t\t\t<$action-sendmessage $message=\"tm-add-tag\" $param={{!!text}}/>\n <$action-setfield person.$(number)$={{!!text}}/>\n \t\t\t<$action-setfield text=\"\"/>\n \t\t\tadd\n\t\t\t</$button>\n\t\t</$fieldmangler>\n\t</$tiddler>\n\\end\n\n\\define deletePersonButton()\n\t<$fieldmangler tiddler=\"$:/temp/people\"> \n\t\t<$button class=\"tc-btn-invisible tc-remove-tag-button\">\t\n\t\t\t<$action-sendmessage $message=\"tm-remove-tag\" $param={{!!person.$(number)$}}/>\n \t<$action-sendmessage $message=\"tm-remove-field\" $param=\"person.$(number)$\"/>\n\t\t\t×\n\t\t</$button>\n\t</$fieldmangler>\n\\end\n\n\\define addFilters()\n\n <$list filter=\"[all[current]!has[person.1]] [all[current]has[person.1]person.1[]]\">\n \t<$set name=\"number\" value=\"1\">\n \t\t<<selectPerson>>\n \t\t<<addPerson>>\n </$set>\n </$list>\n\n <$list filter=\"[all[current]has[person.1]!person.1[]!has[person.2]] [all[current]has[person.1]!person.1[]person.2[]]\">\n \t<$set name=\"number\" value=\"2\">\n \t\t<<selectPerson>>\n \t\t<<addPerson>>\n </$set>\n </$list>\n\n <$list filter=\"[all[current]has[person.2]!person.2[]!has[person.3]] [all[current]has[person.2]!person.2[]person.3[]]\">\n \t<$set name=\"number\" value=\"3\">\n \t\t<<selectPerson>>\n \t\t<<addPerson>>\n </$set>\n </$list>\n\n <$list filter=\"[all[current]has[person.3]!person.3[]!has[person.4]] [all[current]has[person.3]!person.3[]person.4[]]\">\n \t<$set name=\"number\" value=\"4\">\n \t\t<<selectPerson>>\n \t\t<<addPerson>>\n </$set>\n </$list>\n \n\\end\n\n\\define deleteFilter()\n \n <$list filter=\"[all[current]has[person.1]!person.1[]!has[person.2]] [all[current]has[person.1]!person.1[]has[person.2]person.2[]]\">\n\t <$set name=\"number\" value=\"1\">\n \t\t<<deletePersonButton>>\n </$set>\n </$list>\n \n <$list filter=\"[all[current]has[person.2]!person.2[]!has[person.3]] [all[current]has[person.2]!person.2[]has[person.3]person.3[]]\">\n\t <$set name=\"number\" value=\"2\">\n \t\t<<deletePersonButton>>\n </$set>\n </$list>\n \n <$list filter=\"[all[current]has[person.3]!person.3[]!has[person.4]] [all[current]has[person.3]!person.3[]has[person.4]person.4[]]\">\n\t <$set name=\"number\" value=\"3\">\n \t\t<<deletePersonButton>>\n </$set>\n </$list>\n \n <$list filter=\"[all[current]has[person.4]!person.4[]]\">\n\t <$set name=\"number\" value=\"4\">\n \t\t<<deletePersonButton>>\n </$set>\n </$list>\n \n\\end\n\n\\define personName()\n{{!!person.$(number)$}}\n\\end\n\n\\define mt-add-people(type:\"$:/type/person\")\n<$tiddler tiddler=\"$:/temp/people\">\n\n<$set name=\"type\" value=\"$type$\">\n\n<table class=\"invisible\" style=\"width: 100%;\">\n<tr>\n<$list filter=\"[all[current]fields[]prefix[person.]removeprefix[person.]nsort[]]\" variable=\"number\">\n<tr>\n<td><<personName>></td>\n<td>\n<$set name=\"last\" filter=\"[all[current]fields[]prefix[person.]removeprefix[person.]last[]]\">\n<$reveal type=\"match\" text=<<number>> default=<<last>>>\n<<deletePersonButton>>\n</$reveal>\n</$set>\n</td>\n</tr>\n</$list>\n<td><<addFilters>></td>\n</tr>\n</table>\n\n</$set>\n\n</$tiddler>\n\\end\n\n<<mt-add-people>>\n\n\n\n\n\n\n",
"created": "20150214103342669",
"modified": "20150225115130321",
"tags": "$:/favorite $:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/mt-add-people"
},
"$:/type/article": {
"created": "20150125150841844",
"text": "",
"caption": "article",
"creator": "Alberto Molina Pérez",
"modified": "20150223121515705",
"modifier": "Alberto Molina Pérez",
"mt-dashboard.add.content": "$:/plugins/amp/MagicTabs/new/article",
"mt-template.fields": "$:/plugins/amp/MagicTabs/templates/types/article",
"mt-template.form": "$:/plugins/amp/MagicTabs/new/article",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/reading",
"title": "$:/type/article",
"mt-source.type": "$:/type/publication"
},
"$:/type/book": {
"created": "20150125150841844",
"text": "",
"caption": "book",
"creator": "Alberto Molina Pérez",
"modified": "20150223121540687",
"modifier": "Alberto Molina Pérez",
"mt-dashboard.add.content": "$:/plugins/amp/MagicTabs/new/book",
"mt-template.fields": "$:/plugins/amp/MagicTabs/templates/types/book",
"mt-template.form": "$:/plugins/amp/MagicTabs/new/book",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/reading",
"title": "$:/type/book",
"mt-source.type": "$:/type/publication"
},
"$:/plugins/amp/MagicTabs/new/article": {
"text": "{{$:/plugins/amp/MagicTabs/forms/input/article}}\n\n{{$:/plugins/amp/MagicTabs/buttons/input/article}}",
"created": "20150216225140020",
"creator": "Alberto Molina Pérez",
"modified": "20150217111634556",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/reading",
"test": "",
"title": "$:/plugins/amp/MagicTabs/new/article"
},
"$:/plugins/amp/MagicTabs/new/book": {
"text": "{{$:/plugins/amp/MagicTabs/forms/input/book}}\n\n{{$:/plugins/amp/MagicTabs/buttons/input/book}}",
"created": "20150217111719125",
"creator": "Alberto Molina Pérez",
"modified": "20150221100702841",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/reading",
"test": "",
"title": "$:/plugins/amp/MagicTabs/new/book"
},
"$:/plugins/amp/MagicTabs/new/chapter": {
"created": "20150212171816817",
"creator": "Alberto Molina Pérez",
"text": "\\define mt-more-fields-chapter(type, template, default)\n\t<$reveal state=<<qualify \"$:/state/mt/slider\">> type=\"nomatch\" text=\"show\" default=\"$default$\">\n <$button set=<<qualify \"$:/state/mt/slider\">> setTo=\"show\" class=\"tc-btn-invisible\">\n {{$:/core/images/right-arrow}} more\n </$button>\n </$reveal>\n <$reveal state=<<qualify \"$:/state/mt/slider\">> type=\"match\" text=\"show\" default=\"$default$\">\n <$button set=<<qualify \"$:/state/mt/slider\">> setTo=\"hide\" class=\"tc-btn-invisible\">\n {{$:/core/images/down-arrow}} less\n </$button> \n </$reveal>\n <$reveal state=<<qualify \"$:/state/mt/slider\">> type=\"match\" text=\"show\" default=\"$default$\">\n \n\n\n<$reveal state=<<qualify \"$:/state/mt/slider\">> type=\"match\" text=\"show\" default=\"$default$\">\n\n<table class=\"\" style=\"width:100%\">\n <tr>\n \t<td style=\"height: 2em;\">Source:</td>\n \t<td colspan=\"4\" style=\"text-align: left;\"><$view field=\"source\"/></td>\n </tr>\n <tr>\n \t<td>Description:</td>\n \t<td colspan=\"4\"><$edit-text field=\"description\" placeholder=\"Description\" tag=\"input\" class=\"tc-edit-fields\"/></td>\n </tr>\n <tr>\n \t<td>Parents:</td>\n \t<td colspan=\"4\"><$edit-text field=\"parents\" placeholder=\"Parents\" tag=\"input\" class=\"tc-edit-fields\"/></td>\n </tr>\n <tr>\n \t\t<td>Tags</td>\n \t<td colspan=\"4\"><$transclude tiddler=\"$:/core/ui/EditTemplate/tags\"/></td>\n </tr>\n <tr>\n \t<td>Icon</td>\n \t<td><$transclude tiddler={{!!icon}}/><<mt-change-icon>></td>\n \t<td style=\"text-align: right;\">Color</td>\n \t<td><$edit-text field=\"color\" placeholder=\"Source\" tag=\"input\" class=\"tc-edit-fields\"/></td>\n\t\t</tr>\n <$list filter=\"[[$:/type/$:/type/chapter]tags[]prefix[$:/type/]get[mt-template.fields]fields[]] [[$template$]fields[]] -created -creator -modified -modifier -title -tags -mt-topics.list -text -icon -color -parents -source -description -order\" variable=\"field\">\n <tr>\n <td><<field>></td>\n <td colspan=\"4\"><$macrocall $name=\"edit-field\" template=\"$template$\" field=<<field>> tempTiddler=\"$:/temp/$:/type/chapter\"/></td>\n </tr>\n </$list>\n \t<tr style=\"text-align:right;\">\n <td colspan=\"5\">\n <small>\n <$list filter=\"[[$template$]has[title]!title[]limit[1]]\">\n [[edit the template|$template$]]\n </$list>\n <$list filter=\"[[$template$]!has[title]] +[limit[1]]\">\n This is a form based on a default template. You should create a custom template for <$link to=\"$type$\">$type$</$link>\n </$list>\n </small>\n </td>\n \t</tr>\n</table>\n\n</$reveal>\n \n\\end\n\n\\define mt-new-chapter-button(type, title, template, source, root)\n <$button tooltip=\"add chapter\" class=\"\">\n <$action-setfield $tiddler=\"$:/state/mt/new-tiddler\" text={{$:/temp/$type$!!draft.title}}/>\n <$action-setfield $tiddler=\"$:/temp/$type$\" title=\"$title$\"/>\n <$action-setfield $tiddler=\"$title$\" mt-chapter.root=\"$root$\"/>\n <$action-deletetiddler $tiddler=\"$:/temp/$type$\"/>\n <$action-setfield $tiddler=\"$template$\" title=\"$:/temp/$type$\"/>\n <$action-setfield $tiddler=\"$:/temp/$type$\" source=\"$source$\"/>\n <$action-sendmessage $message=\"tm-notify\" $param=\"$:/plugins/amp/MagicTabs/notifications/new-tiddler\"/>\n add\n </$button>\n\\end\n\n\\define changeTitle(chapterOrder, authorsTitle, publicationDate)\n\t<$reveal state=<<qualify \"$:/state/mt/chapterTitle\">> type=\"nomatch\" text=\"custom\" default=\"default\">\n \t''$authorsTitle$ ($publicationDate$) - chap. $chapterOrder$'' \n <$button set=<<qualify \"$:/state/mt/chapterTitle\">> setTo=\"custom\" class=\"\">\n change\n </$button>\n </$reveal>\n\n\t<$reveal state=<<qualify \"$:/state/mt/chapterTitle\">> type=\"match\" text=\"custom\" default=\"default\">\n\t<$edit-text field=\"draft.title\" placeholder=\"Tiddler title\" class=\"\" size=\"50\"/><<mt-check-title>>\n <$button set=<<qualify \"$:/state/mt/chapterTitle\">> setTo=\"default\"> \n \t<$action-setfield draft.title=\"\"/>\n \tdefault\n </$button>\n</$reveal>\n\n\\end\n\n\\define mt-new-chapter-table(type:\"$:/type/chapter\", chapterOrder, authorsTitle, publicationDate)\n\n<table class=\"invisible\" style=\"width: 100%\">\n<tr>\n<td><<changeTitle \"$chapterOrder$\" \"$authorsTitle$\" \"$publicationDate$\">></td>\n</tr>\n<tr>\n<td><$edit-text field=\"mt-chapter.order\" placeholder=\"N°\" size=\"4\"/><$edit-text field=\"mt-chapter.title\" placeholder=\"Title of the chapter\" class=\"\" size=\"50\"/><<mt-check-title>></td>\n</tr>\n<tr>\n<td><$edit-text field=\"mt-topics.list\" placeholder=\"Topics [[Inside brackets]]\" tag=\"input\" class=\"tc-edit-fields\"/></td>\n</tr>\n<tr>\n<td colspan=\"2\"><$edit-text field=\"text\" placeholder=\"Text\" default=\"\" tag=\"textarea\" class=\"tc-edit-fields\"/></td>\n</tr>\n</table>\n\n<$macrocall $name=\"mt-more-fields-chapter\" type=\"$:/type/chapter\" template={{$:/type/chapter!!mt-template.fields}} title=/>\n\n\\end\n\n\\define mt-new-chapter-button-call(type:\"$:/type/chapter\", chapterOrder, authorsTitle, publicationDate, root)\n\n<$reveal state=\"!!draft.title\" type=\"nomatch\" text=\"\">\n\n <$reveal default=\"$(currentTab)$\" type=\"nomatch\" text=\"\">\n\n <$macrocall $name=\"mt-new-chapter-button\"\n type=\"$type$\"\n title={{$:/temp/$type$!!draft.title}}\n template={{$:/type/chapter!!mt-template.fields}}\n source=\"$(storyTiddler)$\"\n root=\"$root$\"\n />\n\n </$reveal>\n\n</$reveal>\n\n<$reveal state=\"!!draft.title\" type=\"match\" text=\"\">\n\n <$reveal default=\"$(currentTab)$\" type=\"nomatch\" text=\"\">\n\n <$macrocall $name=\"mt-new-chapter-button\"\n type=\"$type$\"\n title=\"$authorsTitle$ ($publicationDate$) - chap. $chapterOrder$\"\n template={{$type$!!mt-template.fields}}\n source=\"$(storyTiddler)$\"\n root=\"$root$\"\n />\n\n </$reveal>\n\n</$reveal>\n\\end\n\n\\define mt-new-chapter(type:\"$:/type/chapter\")\n\n<$tiddler tiddler=\"$:/temp/$type$\">\n\n<$macrocall $name=\"mt-new-chapter-table\"\n \tauthorsTitle={{$(storyTiddler)$!!authors.title}}\n \tchapterOrder={{$:/temp/$type$!!mt-chapter.order}}\n publicationDate={{$(storyTiddler)$!!mt-publication.date}}\n />\n\n<$list filter=\"[[$(storyTiddler)$]tag[$:/type/publication]!tag[$:/type/chapter]]\">\n\n\t<$macrocall $name=\"mt-new-chapter-button-call\"\n \tauthorsTitle={{$(storyTiddler)$!!authors.title}}\n \tchapterOrder={{$:/temp/$type$!!mt-chapter.order}}\n publicationDate={{$(storyTiddler)$!!mt-publication.date}}\n root=\"$(storyTiddler)$\"\n \t/>\n\n</$list>\n\n</$tiddler>\n\t\t\n\\end\n\n<<mt-new-chapter>>\n\n",
"modified": "20150308161834478",
"tags": "$:/plugins/amp/MagicTabs/reading MagicTabs",
"title": "$:/plugins/amp/MagicTabs/new/chapter",
"modifier": "Alberto Molina Pérez"
},
"$:/plugins/amp/MagicTabs/config/publication/book-title": {
"text": "\\define pubTitle_book()\n$(authorsTitle)$ ($(publicationDate)$): $(publicationTitle)$\n\\end",
"created": "20150213221650320",
"modified": "20150217110849214",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/reading",
"title": "$:/plugins/amp/MagicTabs/config/publication/book-title"
},
"$:/plugins/amp/MagicTabs/config/publication/article-title": {
"text": "\\define pubTitle_article()\n$(authorsTitle)$ ($(publicationDate)$): “$(publicationTitle)$”\n\\end",
"created": "20150217105426083",
"modified": "20150217110927861",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/reading",
"title": "$:/plugins/amp/MagicTabs/config/publication/article-title"
},
"$:/plugins/amp/MagicTabs/buttons/input/book": {
"text": "\\define buttonPub(type, authorsNumber:\"1\")\n\n<$tiddler tiddler=\"$:/temp/$type$\">\n\n<$set name=\"publicationTitle\" value={{!!mt-publication.title}}>\n\n<$set name=\"publicationDate\" filter=\"[all[current]has[mt-publication.date]!mt-publication.date[]]\" value={{!!mt-publication.date}} emptyValue=\"n.d.\">\n\n<$set name=\"author1\" filter=\"[[$(person1)$]has[mt-person.surname]!mt-person.surname[]]\" value={{$(person1)$!!mt-person.surname}} emptyValue={{$(person1)$!!mt-person.name}}>\n\n<$set name=\"author2\" filter=\"[[$(person2)$]has[mt-person.surname]!mt-person.surname[]]\" value={{$(person2)$!!mt-person.surname}} emptyValue={{$(person2)$!!mt-person.name}}>\n\n<$set name=\"author3\" filter=\"[[$(person3)$]has[mt-person.surname]!mt-person.surname[]]\" value={{$(person3)$!!mt-person.surname}} emptyValue={{$(person3)$!!mt-person.name}}>\n\n<$set name=\"author4\" filter=\"[[$(person4)$]has[mt-person.surname]!mt-person.surname[]]\" value={{$(person4)$!!mt-person.surname}} emptyValue={{$(person4)$!!mt-person.name}}>\n\n<$set name=\"authorsTitle\" value=<<authorsTitle$authorsNumber$>>>\n \n\t<$button>\n\t\t<$action-setfield title=<<pubTitle_book>>/>\n <$action-setfield $tiddler=<<pubTitle_book>> mt-source.authors.list=\"$(authorsList)$\" mt-authors.title=<<authorsTitle>> mt-source.tiddler=\"\"/>\n <$action-deletetiddler $tiddler=\"$:/temp/people\"/>\n <$action-deletetiddler $tiddler=\"$:/temp/$type$\"/>\n <$action-setfield $tiddler={{$type$!!mt-template.fields}} title=\"$:/temp/$type$\"/>\n\t\t<<pubTitle_book>>\n\t</$button>\n \n</$set> \n\n</$set> \n\n</$set> \n\n</$set> \n\n</$set>\n\n</$set>\n\n</$set>\n\n</$tiddler>\n\\end\n\n\\define mt-new-book(type:\"$:/type/book\")\n<$reveal state=\"$:/temp/people!!person.1\" type=\"nomatch\" text=\"\">\n\n<$reveal state=\"$:/temp/$type$!!mt-publication.title\" type=\"nomatch\" text=\"\">\n\n<$tiddler tiddler=\"$:/temp/people\">\n\n<$set name=\"authorsNumber\" filter=\"[all[current]fields[]prefix[person.]last[]removeprefix[person.]]\">\n\n<$set name=\"authorsList\" value={{$:/temp/people!!tags}}>\n\n<$set name=\"person1\" value={{$:/temp/people!!person.1}}>\n\n<$set name=\"person2\" value={{$:/temp/people!!person.2}}>\n\n<$set name=\"person3\" value={{$:/temp/people!!person.3}}>\n\n<$set name=\"person4\" value={{$:/temp/people!!person.4}}>\n\n<$macrocall $name=\"buttonPub\"\n\ttype=\"$type$\" \n authorsNumber=<<authorsNumber>>\n />\n \n</$set>\n \n</$set>\n \n</$set>\n \n</$set>\n \n</$set>\n \n</$set>\n\n</$tiddler>\n\n</$reveal>\n\n</$reveal>\n\\end\n<<mt-new-book>>",
"created": "20150217103730754",
"modified": "20150226160252343",
"tags": "$:/plugins/amp/MagicTabs/reading MagicTabs",
"title": "$:/plugins/amp/MagicTabs/buttons/input/book"
},
"$:/plugins/amp/MagicTabs/config/authors/title-1": {
"created": "20150213224036081",
"text": "\\define authorsTitle1()\n$(author1)$\n\\end",
"modified": "20150217123035360",
"tags": "$:/tags/Macro $:/plugins/amp/MagicTabs/reading MagicTabs",
"title": "$:/plugins/amp/MagicTabs/config/authors/title-1"
},
"$:/plugins/amp/MagicTabs/config/authors/title-2": {
"text": "\\define authorsTitle2()\n$(author1)$ & $(author2)$\n\\end",
"created": "20150213224122316",
"modified": "20150217123106249",
"tags": "$:/tags/Macro $:/plugins/amp/MagicTabs/reading MagicTabs",
"title": "$:/plugins/amp/MagicTabs/config/authors/title-2"
},
"$:/plugins/amp/MagicTabs/config/authors/title-3": {
"text": "\\define authorsTitle3()\n$(author1)$, $(author2)$ & $(author3)$\n\\end",
"created": "20150213224623711",
"modified": "20150217123134125",
"tags": "$:/tags/Macro $:/plugins/amp/MagicTabs/reading MagicTabs",
"title": "$:/plugins/amp/MagicTabs/config/authors/title-3"
},
"$:/plugins/amp/MagicTabs/config/authors/title-4": {
"text": "\\define authorsTitle4()\n$(author1)$ et al.\n\\end",
"created": "20150215004954531",
"modified": "20150217123222929",
"tags": "$:/tags/Macro MagicTabs $:/plugins/amp/MagicTabs/reading",
"title": "$:/plugins/amp/MagicTabs/config/authors/title-4"
},
"$:/plugins/amp/MagicTabs/forms/input/article": {
"created": "20150217111202141",
"creator": "Alberto Molina Pérez",
"text": "\\define mt-publication-form2(type, template, tempTiddler, parentType, size)\n <$tiddler tiddler=\"$tempTiddler$\">\n\n <$set name=\"show\" filter=\"[[$type$]has[mt-source.parents.list]!mt-source.parents.list[]!mt-source.parents.list[$:/type/root]]\" value=\"yes\" emptyValue=\"no\">\n <$reveal default=<<show>> type=\"match\" text=\"yes\">\n <$checkbox tiddler=\"$tempTiddler$\" tag=\"$parentType$\"> {{$parentType$!!caption}} (inherit fields)</$checkbox>\n </$reveal>\n </$set>\n\n<$edit-text field=\"mt-publication.title\" placeholder=\"Article title\" class=\"tc-edit-fields\"/>\n<$edit-text field=\"mt-publication.journal\" placeholder=\"Journal\" class=\"\"/>\n\n<$edit-text field=\"mt-publication.volume\" placeholder=\"Volume\" class=\"\"/>\n<$edit-text field=\"mt-publication.issue\" placeholder=\"Issue\" class=\"\"/>\n<$edit-text field=\"mt-publication.date\" placeholder=\"Date\" class=\"\"/>\n\n<$edit-text field=\"mt-topics.list\" placeholder=\"Topics [[Inside brackets]]\" tag=\"input\" class=\"tc-edit-fields\"/>\n<$edit-text field=\"text\" placeholder=\"Text\" default=\"\" tag=\"textarea\" class=\"tc-edit-fields\"/>\n\n<<mt-fields-form-more \"$type$\">>\n\n</$tiddler>\n\\end\n\n\\define mt-publication-form(type, tempTiddler, size:\"65\")\n<$reveal state=\"$type$!!modified\" type=\"nomatch\" text=\"\">\n <$macrocall $name=\"mt-publication-form2\"\n type=\"$type$\"\n template={{$type$!!mt-template.fields}}\n tempTiddler=\"$:/temp/$type$\"\n parentType={{$type$!!mt-source.parents.list}}\n size=\"$size$\"\n />\n</$reveal>\n\\end\n\n<<mt-add-people \"$:/type/author\">>\n\n<<mt-publication-form type:\"$:/type/article\">>",
"modified": "20150308161030915",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/reading",
"test": "",
"title": "$:/plugins/amp/MagicTabs/forms/input/article"
},
"$:/plugins/amp/MagicTabs/buttons/input/article": {
"text": "\\define buttonPub(type, authorsNumber:\"1\")\n\n<$tiddler tiddler=\"$:/temp/$type$\">\n\n<$set name=\"publicationTitle\" value={{!!mt-publication.title}}>\n\n<$set name=\"publicationDate\" filter=\"[all[current]has[mt-publication.date]!mt-publication.date[]]\" value={{!!mt-publication.date}} emptyValue=\"n.d.\">\n\n<$set name=\"author1\" filter=\"[[$(person1)$]has[mt-person.surname]!mt-person.surname[]]\" value={{$(person1)$!!mt-person.surname}} emptyValue={{$(person1)$!!mt-person.name}}>\n\n<$set name=\"author2\" filter=\"[[$(person2)$]has[mt-person.surname]!mt-person.surname[]]\" value={{$(person2)$!!mt-person.surname}} emptyValue={{$(person2)$!!mt-person.name}}>\n\n<$set name=\"author3\" filter=\"[[$(person3)$]has[mt-person.surname]!mt-person.surname[]]\" value={{$(person3)$!!mt-person.surname}} emptyValue={{$(person3)$!!mt-person.name}}>\n\n<$set name=\"author4\" filter=\"[[$(person4)$]has[mt-person.surname]!mt-person.surname[]]\" value={{$(person4)$!!mt-person.surname}} emptyValue={{$(person4)$!!mt-person.name}}>\n\n<$set name=\"authorsTitle\" value=<<authorsTitle$authorsNumber$>>>\n \n\t<$button>\n\t\t<$action-setfield title=<<pubTitle_article>>/>\n <$action-setfield $tiddler=<<pubTitle_article>> mt-source.authors.list=\"$(authorsList)$\" mt-authors.title=<<authorsTitle>> mt-source.tiddler=\"\"/>\n <$action-deletetiddler $tiddler=\"$:/temp/people\"/>\n <$action-deletetiddler $tiddler=\"$:/temp/$type$\"/>\n <$action-setfield $tiddler={{$type$!!mt-template.fields}} title=\"$:/temp/$type$\"/>\n\t\t<<pubTitle_article>>\n\t</$button>\n \n</$set> \n\n</$set> \n\n</$set> \n\n</$set> \n\n</$set>\n\n</$set>\n\n</$set>\n\n</$tiddler>\n\\end\n\n\\define mt-new-article(type:\"$:/type/article\")\n\n<$reveal state=\"$:/temp/people!!person.1\" type=\"nomatch\" text=\"\">\n\n<$reveal state=\"$:/temp/$type$!!mt-publication.title\" type=\"nomatch\" text=\"\">\n\n<$tiddler tiddler=\"$:/temp/people\">\n\n<$set name=\"authorsNumber\" filter=\"[all[current]fields[]prefix[person.]last[]removeprefix[person.]]\">\n\n<$set name=\"authorsList\" value={{$:/temp/people!!tags}}>\n\n<$set name=\"person1\" value={{$:/temp/people!!person.1}}>\n\n<$set name=\"person2\" value={{$:/temp/people!!person.2}}>\n\n<$set name=\"person3\" value={{$:/temp/people!!person.3}}>\n\n<$set name=\"person4\" value={{$:/temp/people!!person.4}}>\n\n<$macrocall $name=\"buttonPub\"\n\ttype=\"$type$\" \n authorsNumber=<<authorsNumber>>\n />\n \n</$set>\n \n</$set>\n \n</$set>\n \n</$set>\n \n</$set>\n \n</$set>\n\n</$tiddler>\n\n</$reveal>\n\n</$reveal>\n\\end\n\n<<mt-new-article>>",
"created": "20150217105141439",
"modified": "20150226160330185",
"tags": "$:/plugins/amp/MagicTabs/reading MagicTabs",
"title": "$:/plugins/amp/MagicTabs/buttons/input/article"
},
"$:/plugins/amp/MagicTabs/forms/input/book": {
"created": "20150216220432569",
"creator": "Alberto Molina Pérez",
"text": "\\define mt-publication-form2(type, template, tempTiddler, parentType, size)\n <$tiddler tiddler=\"$tempTiddler$\">\n\n <$set name=\"show\" filter=\"[[$type$]has[mt-source.parents.list]!mt-source.parents.list[]!mt-source.parents.list[$:/type/root]]\" value=\"yes\" emptyValue=\"no\">\n <$reveal default=<<show>> type=\"match\" text=\"yes\">\n <$checkbox tiddler=\"$tempTiddler$\" tag=\"$parentType$\"> {{$parentType$!!caption}} (inherit fields)</$checkbox>\n </$reveal>\n </$set>\n\n<$edit-text field=\"mt-publication.title\" placeholder=\"Book title\" class=\"tc-edit-fields\"/>\n<$edit-text field=\"mt-publication.publisher\" placeholder=\"Publisher\" class=\"\"/>\n<$edit-text field=\"mt-publication.city\" placeholder=\"City\" class=\"\"/>\n\n<$edit-text field=\"mt-publication.edition\" placeholder=\"Edition\" class=\"\"/>\n<$edit-text field=\"mt-publication.volume\" placeholder=\"Volume\" class=\"\"/>\n<$edit-text field=\"mt-publication.date\" placeholder=\"Date\" class=\"\"/>\n\n<$edit-text field=\"mt-topics.list\" placeholder=\"Topics [[Inside brackets]]\" tag=\"input\" class=\"tc-edit-fields\"/>\n<$edit-text field=\"text\" placeholder=\"Text\" default=\"\" tag=\"textarea\" class=\"tc-edit-fields\"/>\n\n<<mt-fields-form-more \"$type$\">>\n\n</$tiddler>\n\\end\n\n\\define mt-publication-form(type, tempTiddler, size:\"65\")\n<$reveal state=\"$type$!!modified\" type=\"nomatch\" text=\"\">\n <$macrocall $name=\"mt-publication-form2\"\n type=\"$type$\"\n template={{$type$!!mt-template.fields}}\n tempTiddler=\"$:/temp/$type$\"\n parentType={{$type$!!mt-source.parents.list}}\n size=\"$size$\"\n />\n</$reveal>\n\\end\n\n<<mt-add-people \"$:/type/author\">>\n\n<<mt-publication-form type:\"$:/type/book\">>",
"modified": "20150308161119048",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/plugins/amp/MagicTabs/reading",
"test": "",
"title": "$:/plugins/amp/MagicTabs/forms/input/book"
},
"$:/plugins/amp/MagicTabs/macros/mt-new-quote": {
"text": "\\define mt-new-quote-button2(type, template, label:\"add\", class=\"\")\n\n<$set name=\"hasRoot\" filter=\"[[$(storyTiddler)$]!mt-source.root[]]\" value={{$(storyTiddler)$!!mt-source.root}} emptyValue=\"\">\n\n<$set name=\"noRoot\" filter=\"[[$(storyTiddler)$]!mt-source.tiddler[]mt-source.root[]]\" value={{$(storyTiddler)$!!mt-source.tiddler}} emptyValue=\"\">\n\n<$set name=\"rootTiddler\" value=<<mt-select-root>>>\n\n<$reveal state=\"$:/temp/$type$!!draft.title\" type=\"nomatch\" text=\"\">\n\n <$button tooltip=\"$label$\" class=\"$class$\">\n <$action-setfield $tiddler=\"$:/state/mt/new-tiddler\" text={{$:/temp/$type$!!draft.title}}/>\n <$action-setfield $tiddler=\"$:/temp/$type$\" title={{$:/temp/$type$!!draft.title}}/>\n <$action-setfield $tiddler={{$:/temp/$type$!!draft.title}} mt-source.tiddler=\"$(storyTiddler)$\" mt-source.root=<<rootTiddler>> mt-authors.title={{$(storyTiddler)$!!mt-authors.title}} mt-source.authors.list={{$(storyTiddler)$!!mt-source.authors.list}} mt-publication.title={{$(storyTiddler)$!!mt-publication.title}} mt-publication.date={{$(storyTiddler)$!!mt-publication.date}}/>\n <$action-deletetiddler $tiddler=\"$:/temp/$type$\"/>\n <$action-setfield $tiddler=\"$template$\" title=\"$:/temp/$type$\"/>\n <$action-setfield $tiddler=\"$:/temp/$type$\" mt-source.tiddler=\"$(storyTiddler)$\" mt-source.root=<<rootTiddler>>/>\n $label$: {{$:/temp/$type$!!draft.title}}\n </$button>\n\n</$reveal>\n\n<$reveal state=\"$:/temp/$type$!!draft.title\" type=\"match\" text=\"\">\n\n<$set name=\"title\" value=\"$(mt-authors.title)$ $(mt-publication.date)$: $(pages)$\">\n\n <$button tooltip=\"$label$\" class=\"$class$\">\n <$action-setfield $tiddler=\"$:/state/mt/new-tiddler\" text=<<title>>/>\n <$action-setfield $tiddler=\"$:/temp/$type$\" title=<<title>>/>\n <$action-setfield $tiddler=<<title>> mt-source.tiddler=\"$(storyTiddler)$\" mt-source.root=<<rootTiddler>> mt-authors.title={{$(storyTiddler)$!!mt-authors.title}} mt-source.authors.list={{$(storyTiddler)$!!mt-source.authors.list}} mt-publication.title={{$(storyTiddler)$!!mt-publication.title}} mt-publication.date={{$(storyTiddler)$!!mt-publication.date}}/>\n <$action-deletetiddler $tiddler=\"$:/temp/$type$\"/>\n <$action-setfield $tiddler=\"$template$\" title=\"$:/temp/$type$\"/>\n <$action-setfield $tiddler=\"$:/temp/$type$\" mt-source.tiddler=\"$(storyTiddler)$\" mt-source.root=<<rootTiddler>>/>\n $label$: <<title>>\n </$button>\n \n</$set>\n\n</$reveal>\n\n</$set>\n \n</$set>\n \n</$set>\n\n\\end\n\n\\define pages-alpha-omega()\n$(mt-quote.page.alpha)$-$(mt-quote.page.omega)$\n\\end\n\n\\define mt-new-quote-button(type:\"$:/type/quote\")\n\n<$set name=\"mt-authors.title\" value={{$(storyTiddler)$!!mt-authors.title}}>\n\n<$set name=\"mt-publication.date\" value={{$(storyTiddler)$!!mt-publication.date}}>\n\n<$set name=\"mt-quote.page.alpha\" value={{$:/temp/$type$!!mt-quote.page.alpha}}>\n\n<$set name=\"mt-quote.page.omega\" value={{$:/temp/$type$!!mt-quote.page.omega}}>\n\n<$set name=\"pages\" filter=\"[[$:/temp/$type$]mt-quote.page.omega[]]\" value=<<mt-quote.page.alpha>> emptyValue=<<pages-alpha-omega>>>\n\n<$macrocall $name=\"mt-new-quote-button2\"\n type=\"$type$\"\n template={{$type$!!mt-template.fields}}\n title={{$:/temp/$type$!!draft.title}}\n label=\"add\"\n class=\"\"\n\t/>\n \n</$set>\n \n</$set>\n \n</$set>\n \n</$set>\n \n</$set>\n\n\\end\n<<mt-new-quote-button>>",
"created": "20150225225416697",
"creator": "Alberto Molina Pérez",
"modified": "20150226090313385",
"modifier": "Alberto Molina Pérez",
"tags": "MagicTabs $:/tags/Macro $:/plugins/amp/MagicTabs/common",
"title": "$:/plugins/amp/MagicTabs/macros/mt-new-quote"
},
"$:/plugins/amp/MagicTabs/ViewTemplate/subtitle/publication": {
"text": "<$list filter=\"[all[current]tag[$:/type/publication]has[mt-publication.subtitle]]\">\n<div style=\"font-size: 2em; color: grey; background-color:transparent; line-height:1.2em; padding-top:0em;\"><$view field=\"mt-publication.subtitle\"/></div>\n</$list>",
"created": "20150228093918713",
"creator": "Alberto Molina",
"list-after": "$:/core/ui/ViewTemplate/title",
"modified": "20150309154330529",
"modifier": "Alberto Molina Pérez",
"tags": "$:/tags/ViewTemplate MagicTabs $:/plugins/amp/MagicTabs/reading",
"title": "$:/plugins/amp/MagicTabs/ViewTemplate/subtitle/publication",
"type": ""
}
}
}
<div class="tc-table-of-contents">
<<mt-tocsx sort:'sort[mt-part.order]'>>
</div>
<<mt-slider-input>>
<<mt-tab-contents>>
<<mt-slider-input>>
<<mt-tab-contents>>
<<mt-slider-input>>
<<mt-tab-contents>>
<<mt-slider-input>>
<<mt-tab-contents>>
\define mt-seek-children()
<$list filter="[all[tiddlers]$(sourceField)$[$(storyTiddler)$]!is[system]!has[draft.of]sort[]]">
<$link><$transclude tiddler={{!!icon}}/><$view field="title"/></$link><br>
</$list>
\end
\define mt-seek-children-list()
<$list filter="[all[current]listed[$(sourceFieldList)$]!is[system]!has[draft.of]sort[]]">
<$link><$transclude tiddler={{!!icon}}/><$view field="title"/></$link><br>
</$list>
\end
\define tabInfo()
<div class="tc-menu-list-item">
<div class="text-grey">
Children of this tiddler:
</div>
<div class="tc-menu-list-subitem">
<$list filter="[all[tiddlers]fields[]prefix[mt-source]!suffix[list]sort[]] -mt-source.root" variable="sourceField">
<<mt-seek-children>>
</$list>
<$list filter="[all[tiddlers]fields[]prefix[mt-source]suffix[list]sort[]] -mt-source.root" variable="sourceFieldList">
<<mt-seek-children-list>>
</$list>
<$list filter="[all[current]listed[mt-source.parents.list]] +[!is[system]!has[draft.of]]" template={{$(currentTab)$!!mt-list.template}} emptyMessage="@@.text-grey none@@"/>
</div>
<div class="text-grey">
About this tiddler:
</div>
<div class="tc-menu-list-subitem">
<$list filter="[all[current]listed[mt-topics.list]!is[system]!has[draft.of]]" template={{$(currentTab)$!!mt-list.template}} emptyMessage="@@.text-grey none@@"/>
</div>
<div class="text-grey">
Tagging:
</div>
<div class="tc-menu-list-subitem">
<$list filter="[all[current]tagging[]!is[system]!has[draft.of]] -[[$(currentTiddler)$]]" template={{$(currentTab)$!!mt-list.template}} emptyMessage="@@.text-grey none@@"/>
</div>
</div>
\end
<<tabInfo>>
<<mt-slider-input "$:/plugins/amp/MagicTabs/new/default">>
<<mt-tab-contents>>
<<mt-slider-input>>
!Parts
<$list filter="[!is[system]tag[$:/type/part]mt-source.tiddler<currentTiddler>sort[mt-part.order]]" emptyMessage="""
<div class="tc-table-of-contents">
<$macrocall $name="mt-toc-selective-expandable" parent=<<currentTiddler>> sort="sort[mt-part.order]"/>
</div>"""/>
<<mt-slider-input>>
<<mt-tab-contents>>
\define fieldValue()
<$tiddler tiddler={{!!$(fieldName)$}}>
<$transclude tiddler={{!!icon}}/>
<$link><$view field="title"/></$link>
</$tiddler>
\end
\define fieldList()
<$list filter="[all[current]list[!!$(fieldName)$]]">
<$transclude tiddler={{!!icon}}/>
<$link><$view field="title"/></$link>
</$list>
\end
<div class="tc-subtitle">
<$list filter="[all[current]!tag[$:/action/show/modifier]!tag[$:/action/hide/subtitle]]">
<$list filter="[all[current]tag[$:/type/person]!is[system]]">
{{!!mt-person.birth.place}} {{!!mt-person.birth.date}} – {{!!mt-person.death.place}} {{!!mt-person.death.date}}<br>
</$list>
<$list filter="[all[current]fields[]prefix[mt-source]!suffix[list]]" variable="fieldName">
<<fieldValue>>
</$list>
<$list filter="[all[current]fields[]prefix[mt-source]suffix[list]]" variable="fieldName">
<<fieldList>>
</$list>
</$list>
<$list filter="[all[current]tag[$:/action/show/modifier]]">
{{||$:/core/ui/ViewTemplate/subtitle}}
</$list>
</div>
{
"tiddlers": {
"$:/core/modules/filters/kin.js": {
"title": "$:/core/modules/filters/kin.js",
"text": "/*\\\ntitle: $:/core/modules/filters/kin.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFinds out where a tiddler originates from and what other tiddlers originate from it\n\n\\*/\n(function() {\n\n\t/*jslint node: true, browser: true */\n\t/*global $tw: true */\n\t\"use strict\";\n\n\tfunction collectTitlesRecursively(baseTiddler,baseTitle,options) {\n\t\tvar cacheName = \"kin-filter-\" + baseTitle + \"-\" + options.fieldName + \"-\",\n\t\t\ttitlesPointingFromBase = {},\n\t\t\ttitlesPointingToBase = {},\n\t\t\tresultsFrom = [],\n\t\t\tresultsTo = [];\n\n\t\tfunction addToResultsIfNotFoundAlready(alreadyFound,title,depth) {\n\t\t\tif(title in alreadyFound) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\talreadyFound[title] = depth;\n\t\t\treturn true\n\t\t}\n\n\t\tfunction collectTitlesPointingFrom(tiddler,title,currentDepth) {\n\t\t\tif(addToResultsIfNotFoundAlready(titlesPointingFromBase,title,currentDepth)) {\n\t\t\t\tcurrentDepth += 1;\n\t\t\t\tif(tiddler) {\n\t\t\t\t\t$tw.utils.each(tiddler.getFieldList(options.fieldName),function(targetTitle) {\n\t\t\t\t\t\tcollectTitlesPointingFrom(options.wiki.getTiddler(targetTitle),targetTitle,currentDepth);\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tfunction collectTitlesPointingTo(title,currentDepth) {\n\t\t\tif(addToResultsIfNotFoundAlready(titlesPointingToBase,title,currentDepth)) {\n\t\t\t\tcurrentDepth += 1;\n\t\t\t\t$tw.utils.each(options.wiki.findTiddlersByField(title,options.fieldName),function(targetTitle) {\n\t\t\t\t\tcollectTitlesPointingTo(targetTitle,currentDepth);\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tfunction getResultsInGivenDepth(cachedData) {\n\t\t\tif(options.depth) {\n\t\t\t\treturn $tw.utils.getObjectKeysByExpression(cachedData,function(value) {\n\t\t\t\t\treturn value <= options.depth;\n\t\t\t\t})\n\t\t\t} else {\n\t\t\t\treturn Object.keys(cachedData);\n\t\t\t}\n\t\t}\n\n\t\tif((options.direction === \"from\") || (options.direction === \"with\")) {\n\t\t\tresultsFrom = $tw.wiki.getGlobalCache(cacheName + \"from\",function() {\n\t\t\t\tcollectTitlesPointingFrom(baseTiddler,baseTitle,0);\n\t\t\t\treturn titlesPointingFromBase;\n\t\t\t});\n\t\t\tresultsFrom = getResultsInGivenDepth(resultsFrom);\n\t\t}\n\t\tif((options.direction === \"to\") || (options.direction === \"with\")) {\n\t\t\tresultsTo = $tw.wiki.getGlobalCache(cacheName + \"to\",function() {\n\t\t\t\tcollectTitlesPointingTo(baseTitle,0);\n\t\t\t\treturn titlesPointingToBase;\n\t\t\t});\n\t\t\tresultsTo = getResultsInGivenDepth(resultsTo);\n\t\t}\n\t\treturn $tw.utils.pushTop(resultsFrom,resultsTo);\n\t}\n\n\t/*\n\tExport our filter function\n\t*/\n\texports.kin = function(source,operator,options) {\n\t\tvar results = [],\n\t\t\tneedsExclusion = operator.prefix === \"!\",\n\t\t\tsuffixes = operator.suffixes || [],\n\t\t\tfilterOptions = {\n\t\t\t\twiki: options.wiki,\n\t\t\t\tfieldName: ((suffixes[0] || [])[0] || \"tags\").toLowerCase(),\n\t\t\t\tdirection: ((suffixes[1] || [])[0] || \"with\").toLowerCase(),\n\t\t\t\tdepth: Number((suffixes[2] || [])[0]),\n\t\t\t};\n\n\t\tif((operator.operand === \"\") && (needsExclusion)) {\n\t\t\treturn [];\n\t\t}\n\n\t\tif(operator.operand !== \"\") {\n\t\t\tvar baseTitle = operator.operand,\n\t\t\t\tbaseTiddler = options.wiki.getTiddler(baseTitle),\n\t\t\t\tfoundTitles = collectTitlesRecursively(baseTiddler,baseTitle,filterOptions);\n\n\t\t\tsource(function(tiddler,title) {\n\t\t\t\tif(needsExclusion === (foundTitles.indexOf(title) === -1)) {\n\t\t\t\t\tresults.push(title);\n\t\t\t\t}\n\t\t\t});\n\t\t} else {\n\t\t\tsource(function(tiddler,title) {\n\t\t\t\tresults = $tw.utils.pushTop(results,collectTitlesRecursively(tiddler,title,filterOptions));\n\t\t\t});\n\t\t}\n\n\t\treturn results;\n\t}\n})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/plugins/bimlas/kin-demo/readme": {
"title": "$:/plugins/bimlas/kin-demo/readme",
"text": "This is the ''demo version'' of the `kin` filter operator, ''use it only for\ntesting purposes'', do not install into an important wiki because it\noverwrites core modules.\n\nIt is based on TiddlyWiki v5.1.19\n\nOnce this pull request is merged and the filter is available by default,\ndelete this plugin and use the builtin version:\n\nhttps://github.com/Jermolene/TiddlyWiki5/pull/3511\n\n[[Source code|https://gitlab.com/bimlas/tw5-kin-demo]]\n\n! Installation\n\nTo add the plugin to your own TiddlyWiki5, just drag this link to the browser window:\n\n[[$:/plugins/bimlas/kin-demo]]\n"
},
"$:/core/modules/utils/utils.js": {
"title": "$:/core/modules/utils/utils.js",
"text": "/*\\\ntitle: $:/core/modules/utils/utils.js\ntype: application/javascript\nmodule-type: utils\n\nVarious static utility functions.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nDisplay a message, in colour if we're on a terminal\n*/\nexports.log = function(text,colour) {\n\tconsole.log($tw.node ? exports.terminalColour(colour) + text + exports.terminalColour() : text);\n};\n\nexports.terminalColour = function(colour) {\n\tif(!$tw.browser && $tw.node && process.stdout.isTTY) {\n\t\tif(colour) {\n\t\t\tvar code = exports.terminalColourLookup[colour];\n\t\t\tif(code) {\n\t\t\t\treturn \"\\x1b[\" + code + \"m\";\n\t\t\t}\n\t\t} else {\n\t\t\treturn \"\\x1b[0m\"; // Cancel colour\n\t\t}\n\t}\n\treturn \"\";\n};\n\nexports.terminalColourLookup = {\n\t\"black\": \"0;30\",\n\t\"red\": \"0;31\",\n\t\"green\": \"0;32\",\n\t\"brown/orange\": \"0;33\",\n\t\"blue\": \"0;34\",\n\t\"purple\": \"0;35\",\n\t\"cyan\": \"0;36\",\n\t\"light gray\": \"0;37\"\n};\n\n/*\nDisplay a warning, in colour if we're on a terminal\n*/\nexports.warning = function(text) {\n\texports.log(text,\"brown/orange\");\n};\n\n/*\nReturn the integer represented by the str (string).\nReturn the dflt (default) parameter if str is not a base-10 number.\n*/\nexports.getInt = function(str,deflt) {\n\tvar i = parseInt(str,10);\n\treturn isNaN(i) ? deflt : i;\n}\n\n/*\nRepeatedly replaces a substring within a string. Like String.prototype.replace, but without any of the default special handling of $ sequences in the replace string\n*/\nexports.replaceString = function(text,search,replace) {\n\treturn text.replace(search,function() {\n\t\treturn replace;\n\t});\n};\n\n/*\nRepeats a string\n*/\nexports.repeat = function(str,count) {\n\tvar result = \"\";\n\tfor(var t=0;t<count;t++) {\n\t\tresult += str;\n\t}\n\treturn result;\n};\n\n/*\nTrim whitespace from the start and end of a string\nThanks to Steven Levithan, http://blog.stevenlevithan.com/archives/faster-trim-javascript\n*/\nexports.trim = function(str) {\n\tif(typeof str === \"string\") {\n\t\treturn str.replace(/^\\s\\s*/, '').replace(/\\s\\s*$/, '');\n\t} else {\n\t\treturn str;\n\t}\n};\n\n/*\nFind the line break preceding a given position in a string\nReturns position immediately after that line break, or the start of the string\n*/\nexports.findPrecedingLineBreak = function(text,pos) {\n\tvar result = text.lastIndexOf(\"\\n\",pos - 1);\n\tif(result === -1) {\n\t\tresult = 0;\n\t} else {\n\t\tresult++;\n\t\tif(text.charAt(result) === \"\\r\") {\n\t\t\tresult++;\n\t\t}\n\t}\n\treturn result;\n};\n\n/*\nFind the line break following a given position in a string\n*/\nexports.findFollowingLineBreak = function(text,pos) {\n\t// Cut to just past the following line break, or to the end of the text\n\tvar result = text.indexOf(\"\\n\",pos);\n\tif(result === -1) {\n\t\tresult = text.length;\n\t} else {\n\t\tif(text.charAt(result) === \"\\r\") {\n\t\t\tresult++;\n\t\t}\n\t}\n\treturn result;\n};\n\n/*\nReturn the number of keys in an object\n*/\nexports.count = function(object) {\n\treturn Object.keys(object || {}).length;\n};\n\n/*\nCheck if an array is equal by value and by reference.\n*/\nexports.isArrayEqual = function(array1,array2) {\n\tif(array1 === array2) {\n\t\treturn true;\n\t}\n\tarray1 = array1 || [];\n\tarray2 = array2 || [];\n\tif(array1.length !== array2.length) {\n\t\treturn false;\n\t}\n\treturn array1.every(function(value,index) {\n\t\treturn value === array2[index];\n\t});\n};\n\n/*\nDetermine whether an array-item is an object-property\n*/\nexports.hopArray = function(object,array) {\n\tfor(var i=0; i<array.length; i++) {\n\t\tif($tw.utils.hop(object,array[i])) {\n\t\t\treturn true;\n\t\t}\n\t}\n\treturn false;\n};\n\n/*\nPush entries onto an array, removing them first if they already exist in the array\n\tarray: array to modify (assumed to be free of duplicates)\n\tvalue: a single value to push or an array of values to push\n*/\nexports.pushTop = function(array,value) {\n\tvar t,p;\n\tif($tw.utils.isArray(value)) {\n\t\t// Remove any array entries that are duplicated in the new values\n\t\tif(value.length !== 0) {\n\t\t\tif(array.length !== 0) {\n\t\t\t\tif(value.length < array.length) {\n\t\t\t\t\tfor(t=0; t<value.length; t++) {\n\t\t\t\t\t\tp = array.indexOf(value[t]);\n\t\t\t\t\t\tif(p !== -1) {\n\t\t\t\t\t\t\tarray.splice(p,1);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tfor(t=array.length-1; t>=0; t--) {\n\t\t\t\t\t\tp = value.indexOf(array[t]);\n\t\t\t\t\t\tif(p !== -1) {\n\t\t\t\t\t\t\tarray.splice(t,1);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\t// Push the values on top of the main array\n\t\t\tarray.push.apply(array,value);\n\t\t}\n\t} else {\n\t\tp = array.indexOf(value);\n\t\tif(p !== -1) {\n\t\t\tarray.splice(p,1);\n\t\t}\n\t\tarray.push(value);\n\t}\n\treturn array;\n};\n\n/*\nRemove entries from an array\n\tarray: array to modify\n\tvalue: a single value to remove, or an array of values to remove\n*/\nexports.removeArrayEntries = function(array,value) {\n\tvar t,p;\n\tif($tw.utils.isArray(value)) {\n\t\tfor(t=0; t<value.length; t++) {\n\t\t\tp = array.indexOf(value[t]);\n\t\t\tif(p !== -1) {\n\t\t\t\tarray.splice(p,1);\n\t\t\t}\n\t\t}\n\t} else {\n\t\tp = array.indexOf(value);\n\t\tif(p !== -1) {\n\t\t\tarray.splice(p,1);\n\t\t}\n\t}\n};\n\n/*\nCollect keys of object (probably hash) where callback yields to true\n */\nexports.getObjectKeysByExpression = function(object,callback) {\n\tvar key,\n\t\tresults = [];\n\tfor (key in object) {\n\t\tif (object.hasOwnProperty(key) && callback(object[key])) {\n\t\t\tresults.push(key);\n\t\t}\n\t}\n\treturn results;\n};\n\n/*\nCheck whether any members of a hashmap are present in another hashmap\n*/\nexports.checkDependencies = function(dependencies,changes) {\n\tvar hit = false;\n\t$tw.utils.each(changes,function(change,title) {\n\t\tif($tw.utils.hop(dependencies,title)) {\n\t\t\thit = true;\n\t\t}\n\t});\n\treturn hit;\n};\n\nexports.extend = function(object /* [, src] */) {\n\t$tw.utils.each(Array.prototype.slice.call(arguments, 1), function(source) {\n\t\tif(source) {\n\t\t\tfor(var property in source) {\n\t\t\t\tobject[property] = source[property];\n\t\t\t}\n\t\t}\n\t});\n\treturn object;\n};\n\nexports.deepCopy = function(object) {\n\tvar result,t;\n\tif($tw.utils.isArray(object)) {\n\t\t// Copy arrays\n\t\tresult = object.slice(0);\n\t} else if(typeof object === \"object\") {\n\t\tresult = {};\n\t\tfor(t in object) {\n\t\t\tif(object[t] !== undefined) {\n\t\t\t\tresult[t] = $tw.utils.deepCopy(object[t]);\n\t\t\t}\n\t\t}\n\t} else {\n\t\tresult = object;\n\t}\n\treturn result;\n};\n\nexports.extendDeepCopy = function(object,extendedProperties) {\n\tvar result = $tw.utils.deepCopy(object),t;\n\tfor(t in extendedProperties) {\n\t\tif(extendedProperties[t] !== undefined) {\n\t\t\tresult[t] = $tw.utils.deepCopy(extendedProperties[t]);\n\t\t}\n\t}\n\treturn result;\n};\n\nexports.deepFreeze = function deepFreeze(object) {\n\tvar property, key;\n\tif(object) {\n\t\tObject.freeze(object);\n\t\tfor(key in object) {\n\t\t\tproperty = object[key];\n\t\t\tif($tw.utils.hop(object,key) && (typeof property === \"object\") && !Object.isFrozen(property)) {\n\t\t\t\tdeepFreeze(property);\n\t\t\t}\n\t\t}\n\t}\n};\n\nexports.slowInSlowOut = function(t) {\n\treturn (1 - ((Math.cos(t * Math.PI) + 1) / 2));\n};\n\nexports.formatDateString = function(date,template) {\n\tvar result = \"\",\n\t\tt = template,\n\t\tmatches = [\n\t\t\t[/^0hh12/, function() {\n\t\t\t\treturn $tw.utils.pad($tw.utils.getHours12(date));\n\t\t\t}],\n\t\t\t[/^wYYYY/, function() {\n\t\t\t\treturn $tw.utils.getYearForWeekNo(date);\n\t\t\t}],\n\t\t\t[/^hh12/, function() {\n\t\t\t\treturn $tw.utils.getHours12(date);\n\t\t\t}],\n\t\t\t[/^DDth/, function() {\n\t\t\t\treturn date.getDate() + $tw.utils.getDaySuffix(date);\n\t\t\t}],\n\t\t\t[/^YYYY/, function() {\n\t\t\t\treturn date.getFullYear();\n\t\t\t}],\n\t\t\t[/^0hh/, function() {\n\t\t\t\treturn $tw.utils.pad(date.getHours());\n\t\t\t}],\n\t\t\t[/^0mm/, function() {\n\t\t\t\treturn $tw.utils.pad(date.getMinutes());\n\t\t\t}],\n\t\t\t[/^0ss/, function() {\n\t\t\t\treturn $tw.utils.pad(date.getSeconds());\n\t\t\t}],\n\t\t\t[/^0XXX/, function() {\n\t\t\t\treturn $tw.utils.pad(date.getMilliseconds());\n\t\t\t}],\n\t\t\t[/^0DD/, function() {\n\t\t\t\treturn $tw.utils.pad(date.getDate());\n\t\t\t}],\n\t\t\t[/^0MM/, function() {\n\t\t\t\treturn $tw.utils.pad(date.getMonth()+1);\n\t\t\t}],\n\t\t\t[/^0WW/, function() {\n\t\t\t\treturn $tw.utils.pad($tw.utils.getWeek(date));\n\t\t\t}],\n\t\t\t[/^ddd/, function() {\n\t\t\t\treturn $tw.language.getString(\"Date/Short/Day/\" + date.getDay());\n\t\t\t}],\n\t\t\t[/^mmm/, function() {\n\t\t\t\treturn $tw.language.getString(\"Date/Short/Month/\" + (date.getMonth() + 1));\n\t\t\t}],\n\t\t\t[/^DDD/, function() {\n\t\t\t\treturn $tw.language.getString(\"Date/Long/Day/\" + date.getDay());\n\t\t\t}],\n\t\t\t[/^MMM/, function() {\n\t\t\t\treturn $tw.language.getString(\"Date/Long/Month/\" + (date.getMonth() + 1));\n\t\t\t}],\n\t\t\t[/^TZD/, function() {\n\t\t\t\tvar tz = date.getTimezoneOffset(),\n\t\t\t\tatz = Math.abs(tz);\n\t\t\t\treturn (tz < 0 ? '+' : '-') + $tw.utils.pad(Math.floor(atz / 60)) + ':' + $tw.utils.pad(atz % 60);\n\t\t\t}],\n\t\t\t[/^wYY/, function() {\n\t\t\t\treturn $tw.utils.pad($tw.utils.getYearForWeekNo(date) - 2000);\n\t\t\t}],\n\t\t\t[/^[ap]m/, function() {\n\t\t\t\treturn $tw.utils.getAmPm(date).toLowerCase();\n\t\t\t}],\n\t\t\t[/^hh/, function() {\n\t\t\t\treturn date.getHours();\n\t\t\t}],\n\t\t\t[/^mm/, function() {\n\t\t\t\treturn date.getMinutes();\n\t\t\t}],\n\t\t\t[/^ss/, function() {\n\t\t\t\treturn date.getSeconds();\n\t\t\t}],\n\t\t\t[/^XXX/, function() {\n\t\t\t\treturn date.getMilliseconds();\n\t\t\t}],\n\t\t\t[/^[AP]M/, function() {\n\t\t\t\treturn $tw.utils.getAmPm(date).toUpperCase();\n\t\t\t}],\n\t\t\t[/^DD/, function() {\n\t\t\t\treturn date.getDate();\n\t\t\t}],\n\t\t\t[/^MM/, function() {\n\t\t\t\treturn date.getMonth() + 1;\n\t\t\t}],\n\t\t\t[/^WW/, function() {\n\t\t\t\treturn $tw.utils.getWeek(date);\n\t\t\t}],\n\t\t\t[/^YY/, function() {\n\t\t\t\treturn $tw.utils.pad(date.getFullYear() - 2000);\n\t\t\t}]\n\t\t];\n\t// If the user wants everything in UTC, shift the datestamp\n\t// Optimize for format string that essentially means\n\t// 'return raw UTC (tiddlywiki style) date string.'\n\tif(t.indexOf(\"[UTC]\") == 0 ) {\n\t\tif(t == \"[UTC]YYYY0MM0DD0hh0mm0ssXXX\")\n\t\t\treturn $tw.utils.stringifyDate(new Date());\n\t\tvar offset = date.getTimezoneOffset() ; // in minutes\n\t\tdate = new Date(date.getTime()+offset*60*1000) ;\n\t\tt = t.substr(5) ;\n\t}\n\twhile(t.length){\n\t\tvar matchString = \"\";\n\t\t$tw.utils.each(matches, function(m) {\n\t\t\tvar match = m[0].exec(t);\n\t\t\tif(match) {\n\t\t\t\tmatchString = m[1].call();\n\t\t\t\tt = t.substr(match[0].length);\n\t\t\t\treturn false;\n\t\t\t}\n\t\t});\n\t\tif(matchString) {\n\t\t\tresult += matchString;\n\t\t} else {\n\t\t\tresult += t.charAt(0);\n\t\t\tt = t.substr(1);\n\t\t}\n\t}\n\tresult = result.replace(/\\\\(.)/g,\"$1\");\n\treturn result;\n};\n\nexports.getAmPm = function(date) {\n\treturn $tw.language.getString(\"Date/Period/\" + (date.getHours() >= 12 ? \"pm\" : \"am\"));\n};\n\nexports.getDaySuffix = function(date) {\n\treturn $tw.language.getString(\"Date/DaySuffix/\" + date.getDate());\n};\n\nexports.getWeek = function(date) {\n\tvar dt = new Date(date.getTime());\n\tvar d = dt.getDay();\n\tif(d === 0) {\n\t\td = 7; // JavaScript Sun=0, ISO Sun=7\n\t}\n\tdt.setTime(dt.getTime() + (4 - d) * 86400000);// shift day to Thurs of same week to calculate weekNo\n\tvar x = new Date(dt.getFullYear(),0,1);\n\tvar n = Math.floor((dt.getTime() - x.getTime()) / 86400000);\n\treturn Math.floor(n / 7) + 1;\n};\n\nexports.getYearForWeekNo = function(date) {\n\tvar dt = new Date(date.getTime());\n\tvar d = dt.getDay();\n\tif(d === 0) {\n\t\td = 7; // JavaScript Sun=0, ISO Sun=7\n\t}\n\tdt.setTime(dt.getTime() + (4 - d) * 86400000);// shift day to Thurs of same week\n\treturn dt.getFullYear();\n};\n\nexports.getHours12 = function(date) {\n\tvar h = date.getHours();\n\treturn h > 12 ? h-12 : ( h > 0 ? h : 12 );\n};\n\n/*\nConvert a date delta in milliseconds into a string representation of \"23 seconds ago\", \"27 minutes ago\" etc.\n\tdelta: delta in milliseconds\nReturns an object with these members:\n\tdescription: string describing the delta period\n\tupdatePeriod: time in millisecond until the string will be inaccurate\n*/\nexports.getRelativeDate = function(delta) {\n\tvar futurep = false;\n\tif(delta < 0) {\n\t\tdelta = -1 * delta;\n\t\tfuturep = true;\n\t}\n\tvar units = [\n\t\t{name: \"Years\", duration: 365 * 24 * 60 * 60 * 1000},\n\t\t{name: \"Months\", duration: (365/12) * 24 * 60 * 60 * 1000},\n\t\t{name: \"Days\", duration: 24 * 60 * 60 * 1000},\n\t\t{name: \"Hours\", duration: 60 * 60 * 1000},\n\t\t{name: \"Minutes\", duration: 60 * 1000},\n\t\t{name: \"Seconds\", duration: 1000}\n\t];\n\tfor(var t=0; t<units.length; t++) {\n\t\tvar result = Math.floor(delta / units[t].duration);\n\t\tif(result >= 2) {\n\t\t\treturn {\n\t\t\t\tdelta: delta,\n\t\t\t\tdescription: $tw.language.getString(\n\t\t\t\t\t\"RelativeDate/\" + (futurep ? \"Future\" : \"Past\") + \"/\" + units[t].name,\n\t\t\t\t\t{variables:\n\t\t\t\t\t\t{period: result.toString()}\n\t\t\t\t\t}\n\t\t\t\t),\n\t\t\t\tupdatePeriod: units[t].duration\n\t\t\t};\n\t\t}\n\t}\n\treturn {\n\t\tdelta: delta,\n\t\tdescription: $tw.language.getString(\n\t\t\t\"RelativeDate/\" + (futurep ? \"Future\" : \"Past\") + \"/Second\",\n\t\t\t{variables:\n\t\t\t\t{period: \"1\"}\n\t\t\t}\n\t\t),\n\t\tupdatePeriod: 1000\n\t};\n};\n\n// Convert & to \"&\", < to \"<\", > to \">\", \" to \""\"\nexports.htmlEncode = function(s) {\n\tif(s) {\n\t\treturn s.toString().replace(/&/mg,\"&\").replace(/</mg,\"<\").replace(/>/mg,\">\").replace(/\\\"/mg,\""\");\n\t} else {\n\t\treturn \"\";\n\t}\n};\n\n// Converts all HTML entities to their character equivalents\nexports.entityDecode = function(s) {\n\tvar converter = String.fromCodePoint || String.fromCharCode,\n\t\te = s.substr(1,s.length-2), // Strip the & and the ;\n\t\tc;\n\tif(e.charAt(0) === \"#\") {\n\t\tif(e.charAt(1) === \"x\" || e.charAt(1) === \"X\") {\n\t\t\tc = parseInt(e.substr(2),16);\n\t\t} else {\n\t\t\tc = parseInt(e.substr(1),10);\n\t\t}\n\t\tif(isNaN(c)) {\n\t\t\treturn s;\n\t\t} else {\n\t\t\treturn converter(c);\n\t\t}\n\t} else {\n\t\tc = $tw.config.htmlEntities[e];\n\t\tif(c) {\n\t\t\treturn converter(c);\n\t\t} else {\n\t\t\treturn s; // Couldn't convert it as an entity, just return it raw\n\t\t}\n\t}\n};\n\nexports.unescapeLineBreaks = function(s) {\n\treturn s.replace(/\\\\n/mg,\"\\n\").replace(/\\\\b/mg,\" \").replace(/\\\\s/mg,\"\\\\\").replace(/\\r/mg,\"\");\n};\n\n/*\n * Returns an escape sequence for given character. Uses \\x for characters <=\n * 0xFF to save space, \\u for the rest.\n *\n * The code needs to be in sync with th code template in the compilation\n * function for \"action\" nodes.\n */\n// Copied from peg.js, thanks to David Majda\nexports.escape = function(ch) {\n\tvar charCode = ch.charCodeAt(0);\n\tif(charCode <= 0xFF) {\n\t\treturn '\\\\x' + $tw.utils.pad(charCode.toString(16).toUpperCase());\n\t} else {\n\t\treturn '\\\\u' + $tw.utils.pad(charCode.toString(16).toUpperCase(),4);\n\t}\n};\n\n// Turns a string into a legal JavaScript string\n// Copied from peg.js, thanks to David Majda\nexports.stringify = function(s) {\n\t/*\n\t* ECMA-262, 5th ed., 7.8.4: All characters may appear literally in a string\n\t* literal except for the closing quote character, backslash, carriage return,\n\t* line separator, paragraph separator, and line feed. Any character may\n\t* appear in the form of an escape sequence.\n\t*\n\t* For portability, we also escape all non-ASCII characters.\n\t*/\n\treturn (s || \"\")\n\t\t.replace(/\\\\/g, '\\\\\\\\') // backslash\n\t\t.replace(/\"/g, '\\\\\"') // double quote character\n\t\t.replace(/'/g, \"\\\\'\") // single quote character\n\t\t.replace(/\\r/g, '\\\\r') // carriage return\n\t\t.replace(/\\n/g, '\\\\n') // line feed\n\t\t.replace(/[\\x00-\\x1f\\x80-\\uFFFF]/g, exports.escape); // non-ASCII characters\n};\n\n// Turns a string into a legal JSON string\n// Derived from peg.js, thanks to David Majda\nexports.jsonStringify = function(s) {\n\t// See http://www.json.org/\n\treturn (s || \"\")\n\t\t.replace(/\\\\/g, '\\\\\\\\') // backslash\n\t\t.replace(/\"/g, '\\\\\"') // double quote character\n\t\t.replace(/\\r/g, '\\\\r') // carriage return\n\t\t.replace(/\\n/g, '\\\\n') // line feed\n\t\t.replace(/\\x08/g, '\\\\b') // backspace\n\t\t.replace(/\\x0c/g, '\\\\f') // formfeed\n\t\t.replace(/\\t/g, '\\\\t') // tab\n\t\t.replace(/[\\x00-\\x1f\\x80-\\uFFFF]/g,function(s) {\n\t\t\treturn '\\\\u' + $tw.utils.pad(s.charCodeAt(0).toString(16).toUpperCase(),4);\n\t\t}); // non-ASCII characters\n};\n\n/*\nEscape the RegExp special characters with a preceding backslash\n*/\nexports.escapeRegExp = function(s) {\n return s.replace(/[\\-\\/\\\\\\^\\$\\*\\+\\?\\.\\(\\)\\|\\[\\]\\{\\}]/g, '\\\\$&');\n};\n\n// Checks whether a link target is external, i.e. not a tiddler title\nexports.isLinkExternal = function(to) {\n\tvar externalRegExp = /^(?:file|http|https|mailto|ftp|irc|news|data|skype):[^\\s<>{}\\[\\]`|\"\\\\^]+(?:\\/|\\b)/i;\n\treturn externalRegExp.test(to);\n};\n\nexports.nextTick = function(fn) {\n/*global window: false */\n\tif(typeof process === \"undefined\") {\n\t\t// Apparently it would be faster to use postMessage - http://dbaron.org/log/20100309-faster-timeouts\n\t\twindow.setTimeout(fn,4);\n\t} else {\n\t\tprocess.nextTick(fn);\n\t}\n};\n\n/*\nConvert a hyphenated CSS property name into a camel case one\n*/\nexports.unHyphenateCss = function(propName) {\n\treturn propName.replace(/-([a-z])/gi, function(match0,match1) {\n\t\treturn match1.toUpperCase();\n\t});\n};\n\n/*\nConvert a camelcase CSS property name into a dashed one (\"backgroundColor\" --> \"background-color\")\n*/\nexports.hyphenateCss = function(propName) {\n\treturn propName.replace(/([A-Z])/g, function(match0,match1) {\n\t\treturn \"-\" + match1.toLowerCase();\n\t});\n};\n\n/*\nParse a text reference of one of these forms:\n* title\n* !!field\n* title!!field\n* title##index\n* etc\nReturns an object with the following fields, all optional:\n* title: tiddler title\n* field: tiddler field name\n* index: JSON property index\n*/\nexports.parseTextReference = function(textRef) {\n\t// Separate out the title, field name and/or JSON indices\n\tvar reTextRef = /(?:(.*?)!!(.+))|(?:(.*?)##(.+))|(.*)/mg,\n\t\tmatch = reTextRef.exec(textRef),\n\t\tresult = {};\n\tif(match && reTextRef.lastIndex === textRef.length) {\n\t\t// Return the parts\n\t\tif(match[1]) {\n\t\t\tresult.title = match[1];\n\t\t}\n\t\tif(match[2]) {\n\t\t\tresult.field = match[2];\n\t\t}\n\t\tif(match[3]) {\n\t\t\tresult.title = match[3];\n\t\t}\n\t\tif(match[4]) {\n\t\t\tresult.index = match[4];\n\t\t}\n\t\tif(match[5]) {\n\t\t\tresult.title = match[5];\n\t\t}\n\t} else {\n\t\t// If we couldn't parse it\n\t\tresult.title = textRef\n\t}\n\treturn result;\n};\n\n/*\nChecks whether a string is a valid fieldname\n*/\nexports.isValidFieldName = function(name) {\n\tif(!name || typeof name !== \"string\") {\n\t\treturn false;\n\t}\n\tname = name.toLowerCase().trim();\n\tvar fieldValidatorRegEx = /^[a-z0-9\\-\\._]+$/mg;\n\treturn fieldValidatorRegEx.test(name);\n};\n\n/*\nExtract the version number from the meta tag or from the boot file\n*/\n\n// Browser version\nexports.extractVersionInfo = function() {\n\tif($tw.packageInfo) {\n\t\treturn $tw.packageInfo.version;\n\t} else {\n\t\tvar metatags = document.getElementsByTagName(\"meta\");\n\t\tfor(var t=0; t<metatags.length; t++) {\n\t\t\tvar m = metatags[t];\n\t\t\tif(m.name === \"tiddlywiki-version\") {\n\t\t\t\treturn m.content;\n\t\t\t}\n\t\t}\n\t}\n\treturn null;\n};\n\n/*\nGet the animation duration in ms\n*/\nexports.getAnimationDuration = function() {\n\treturn parseInt($tw.wiki.getTiddlerText(\"$:/config/AnimationDuration\",\"400\"),10);\n};\n\n/*\nHash a string to a number\nDerived from http://stackoverflow.com/a/15710692\n*/\nexports.hashString = function(str) {\n\treturn str.split(\"\").reduce(function(a,b) {\n\t\ta = ((a << 5) - a) + b.charCodeAt(0);\n\t\treturn a & a;\n\t},0);\n};\n\n/*\nDecode a base64 string\n*/\nexports.base64Decode = function(string64) {\n\tif($tw.browser) {\n\t\t// TODO\n\t\tthrow \"$tw.utils.base64Decode() doesn't work in the browser\";\n\t} else {\n\t\treturn Buffer.from(string64,\"base64\").toString();\n\t}\n};\n\n/*\nConvert a hashmap into a tiddler dictionary format sequence of name:value pairs\n*/\nexports.makeTiddlerDictionary = function(data) {\n\tvar output = [];\n\tfor(var name in data) {\n\t\toutput.push(name + \": \" + data[name]);\n\t}\n\treturn output.join(\"\\n\");\n};\n\n/*\nHigh resolution microsecond timer for profiling\n*/\nexports.timer = function(base) {\n\tvar m;\n\tif($tw.node) {\n\t\tvar r = process.hrtime();\n\t\tm = r[0] * 1e3 + (r[1] / 1e6);\n\t} else if(window.performance) {\n\t\tm = performance.now();\n\t} else {\n\t\tm = Date.now();\n\t}\n\tif(typeof base !== \"undefined\") {\n\t\tm = m - base;\n\t}\n\treturn m;\n};\n\n/*\nConvert text and content type to a data URI\n*/\nexports.makeDataUri = function(text,type) {\n\ttype = type || \"text/vnd.tiddlywiki\";\n\tvar typeInfo = $tw.config.contentTypeInfo[type] || $tw.config.contentTypeInfo[\"text/plain\"],\n\t\tisBase64 = typeInfo.encoding === \"base64\",\n\t\tparts = [];\n\tparts.push(\"data:\");\n\tparts.push(type);\n\tparts.push(isBase64 ? \";base64\" : \"\");\n\tparts.push(\",\");\n\tparts.push(isBase64 ? text : encodeURIComponent(text));\n\treturn parts.join(\"\");\n};\n\n/*\nUseful for finding out the fully escaped CSS selector equivalent to a given tag. For example:\n\n$tw.utils.tagToCssSelector(\"$:/tags/Stylesheet\") --> tc-tagged-\\%24\\%3A\\%2Ftags\\%2FStylesheet\n*/\nexports.tagToCssSelector = function(tagName) {\n\treturn \"tc-tagged-\" + encodeURIComponent(tagName).replace(/[!\"#$%&'()*+,\\-./:;<=>?@[\\\\\\]^`{\\|}~,]/mg,function(c) {\n\t\treturn \"\\\\\" + c;\n\t});\n};\n\n/*\nIE does not have sign function\n*/\nexports.sign = Math.sign || function(x) {\n\tx = +x; // convert to a number\n\tif (x === 0 || isNaN(x)) {\n\t\treturn x;\n\t}\n\treturn x > 0 ? 1 : -1;\n};\n\n/*\nIE does not have an endsWith function\n*/\nexports.strEndsWith = function(str,ending,position) {\n\tif(str.endsWith) {\n\t\treturn str.endsWith(ending,position);\n\t} else {\n\t\tif (typeof position !== 'number' || !isFinite(position) || Math.floor(position) !== position || position > str.length) {\n\t\t\tposition = str.length;\n\t\t}\n\t\tposition -= ending.length;\n\t\tvar lastIndex = str.indexOf(ending, position);\n\t\treturn lastIndex !== -1 && lastIndex === position;\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "utils"
},
"$:/core/modules/wiki.js": {
"title": "$:/core/modules/wiki.js",
"text": "/*\\\ntitle: $:/core/modules/wiki.js\ntype: application/javascript\nmodule-type: wikimethod\n\nExtension methods for the $tw.Wiki object\n\nAdds the following properties to the wiki object:\n\n* `eventListeners` is a hashmap by type of arrays of listener functions\n* `changedTiddlers` is a hashmap describing changes to named tiddlers since wiki change events were last dispatched. Each entry is a hashmap containing two fields:\n\tmodified: true/false\n\tdeleted: true/false\n* `changeCount` is a hashmap by tiddler title containing a numerical index that starts at zero and is incremented each time a tiddler is created changed or deleted\n* `caches` is a hashmap by tiddler title containing a further hashmap of named cache objects. Caches are automatically cleared when a tiddler is modified or deleted\n* `globalCache` is a hashmap by cache name of cache objects that are cleared whenever any tiddler change occurs\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar widget = require(\"$:/core/modules/widgets/widget.js\");\n\nvar USER_NAME_TITLE = \"$:/status/UserName\",\n\tTIMESTAMP_DISABLE_TITLE = \"$:/config/TimestampDisable\";\n\n/*\nGet the value of a text reference. Text references can have any of these forms:\n\t<tiddlertitle>\n\t<tiddlertitle>!!<fieldname>\n\t!!<fieldname> - specifies a field of the current tiddlers\n\t<tiddlertitle>##<index>\n*/\nexports.getTextReference = function(textRef,defaultText,currTiddlerTitle) {\n\tvar tr = $tw.utils.parseTextReference(textRef),\n\t\ttitle = tr.title || currTiddlerTitle;\n\tif(tr.field) {\n\t\tvar tiddler = this.getTiddler(title);\n\t\tif(tr.field === \"title\") { // Special case so we can return the title of a non-existent tiddler\n\t\t\treturn title;\n\t\t} else if(tiddler && $tw.utils.hop(tiddler.fields,tr.field)) {\n\t\t\treturn tiddler.getFieldString(tr.field);\n\t\t} else {\n\t\t\treturn defaultText;\n\t\t}\n\t} else if(tr.index) {\n\t\treturn this.extractTiddlerDataItem(title,tr.index,defaultText);\n\t} else {\n\t\treturn this.getTiddlerText(title,defaultText);\n\t}\n};\n\nexports.setTextReference = function(textRef,value,currTiddlerTitle) {\n\tvar tr = $tw.utils.parseTextReference(textRef),\n\t\ttitle = tr.title || currTiddlerTitle;\n\tthis.setText(title,tr.field,tr.index,value);\n};\n\nexports.setText = function(title,field,index,value,options) {\n\toptions = options || {};\n\tvar creationFields = options.suppressTimestamp ? {} : this.getCreationFields(),\n\t\tmodificationFields = options.suppressTimestamp ? {} : this.getModificationFields();\n\t// Check if it is a reference to a tiddler field\n\tif(index) {\n\t\tvar data = this.getTiddlerData(title,Object.create(null));\n\t\tif(value !== undefined) {\n\t\t\tdata[index] = value;\n\t\t} else {\n\t\t\tdelete data[index];\n\t\t}\n\t\tthis.setTiddlerData(title,data,modificationFields);\n\t} else {\n\t\tvar tiddler = this.getTiddler(title),\n\t\t\tfields = {title: title};\n\t\tfields[field || \"text\"] = value;\n\t\tthis.addTiddler(new $tw.Tiddler(creationFields,tiddler,fields,modificationFields));\n\t}\n};\n\nexports.deleteTextReference = function(textRef,currTiddlerTitle) {\n\tvar tr = $tw.utils.parseTextReference(textRef),\n\t\ttitle,tiddler,fields;\n\t// Check if it is a reference to a tiddler\n\tif(tr.title && !tr.field) {\n\t\tthis.deleteTiddler(tr.title);\n\t// Else check for a field reference\n\t} else if(tr.field) {\n\t\ttitle = tr.title || currTiddlerTitle;\n\t\ttiddler = this.getTiddler(title);\n\t\tif(tiddler && $tw.utils.hop(tiddler.fields,tr.field)) {\n\t\t\tfields = Object.create(null);\n\t\t\tfields[tr.field] = undefined;\n\t\t\tthis.addTiddler(new $tw.Tiddler(tiddler,fields,this.getModificationFields()));\n\t\t}\n\t}\n};\n\nexports.addEventListener = function(type,listener) {\n\tthis.eventListeners = this.eventListeners || {};\n\tthis.eventListeners[type] = this.eventListeners[type] || [];\n\tthis.eventListeners[type].push(listener);\n};\n\nexports.removeEventListener = function(type,listener) {\n\tvar listeners = this.eventListeners[type];\n\tif(listeners) {\n\t\tvar p = listeners.indexOf(listener);\n\t\tif(p !== -1) {\n\t\t\tlisteners.splice(p,1);\n\t\t}\n\t}\n};\n\nexports.dispatchEvent = function(type /*, args */) {\n\tvar args = Array.prototype.slice.call(arguments,1),\n\t\tlisteners = this.eventListeners[type];\n\tif(listeners) {\n\t\tfor(var p=0; p<listeners.length; p++) {\n\t\t\tvar listener = listeners[p];\n\t\t\tlistener.apply(listener,args);\n\t\t}\n\t}\n};\n\n/*\nCauses a tiddler to be marked as changed, incrementing the change count, and triggers event handlers.\nThis method should be called after the changes it describes have been made to the wiki.tiddlers[] array.\n\ttitle: Title of tiddler\n\tisDeleted: defaults to false (meaning the tiddler has been created or modified),\n\t\ttrue if the tiddler has been deleted\n*/\nexports.enqueueTiddlerEvent = function(title,isDeleted) {\n\t// Record the touch in the list of changed tiddlers\n\tthis.changedTiddlers = this.changedTiddlers || Object.create(null);\n\tthis.changedTiddlers[title] = this.changedTiddlers[title] || Object.create(null);\n\tthis.changedTiddlers[title][isDeleted ? \"deleted\" : \"modified\"] = true;\n\t// Increment the change count\n\tthis.changeCount = this.changeCount || Object.create(null);\n\tif($tw.utils.hop(this.changeCount,title)) {\n\t\tthis.changeCount[title]++;\n\t} else {\n\t\tthis.changeCount[title] = 1;\n\t}\n\t// Trigger events\n\tthis.eventListeners = this.eventListeners || {};\n\tif(!this.eventsTriggered) {\n\t\tvar self = this;\n\t\t$tw.utils.nextTick(function() {\n\t\t\tvar changes = self.changedTiddlers;\n\t\t\tself.changedTiddlers = Object.create(null);\n\t\t\tself.eventsTriggered = false;\n\t\t\tif($tw.utils.count(changes) > 0) {\n\t\t\t\tself.dispatchEvent(\"change\",changes);\n\t\t\t}\n\t\t});\n\t\tthis.eventsTriggered = true;\n\t}\n};\n\nexports.getSizeOfTiddlerEventQueue = function() {\n\treturn $tw.utils.count(this.changedTiddlers);\n};\n\nexports.clearTiddlerEventQueue = function() {\n\tthis.changedTiddlers = Object.create(null);\n\tthis.changeCount = Object.create(null);\n};\n\nexports.getChangeCount = function(title) {\n\tthis.changeCount = this.changeCount || Object.create(null);\n\tif($tw.utils.hop(this.changeCount,title)) {\n\t\treturn this.changeCount[title];\n\t} else {\n\t\treturn 0;\n\t}\n};\n\n/*\nGenerate an unused title from the specified base\n*/\nexports.generateNewTitle = function(baseTitle,options) {\n\toptions = options || {};\n\tvar c = 0,\n\t\ttitle = baseTitle;\n\twhile(this.tiddlerExists(title) || this.isShadowTiddler(title) || this.findDraft(title)) {\n\t\ttitle = baseTitle +\n\t\t\t(options.prefix || \" \") +\n\t\t\t(++c);\n\t}\n\treturn title;\n};\n\nexports.isSystemTiddler = function(title) {\n\treturn title && title.indexOf(\"$:/\") === 0;\n};\n\nexports.isTemporaryTiddler = function(title) {\n\treturn title && title.indexOf(\"$:/temp/\") === 0;\n};\n\nexports.isImageTiddler = function(title) {\n\tvar tiddler = this.getTiddler(title);\n\tif(tiddler) {\n\t\tvar contentTypeInfo = $tw.config.contentTypeInfo[tiddler.fields.type || \"text/vnd.tiddlywiki\"];\n\t\treturn !!contentTypeInfo && contentTypeInfo.flags.indexOf(\"image\") !== -1;\n\t} else {\n\t\treturn null;\n\t}\n};\n\n/*\nLike addTiddler() except it will silently reject any plugin tiddlers that are older than the currently loaded version. Returns true if the tiddler was imported\n*/\nexports.importTiddler = function(tiddler) {\n\tvar existingTiddler = this.getTiddler(tiddler.fields.title);\n\t// Check if we're dealing with a plugin\n\tif(tiddler && tiddler.hasField(\"plugin-type\") && tiddler.hasField(\"version\") && existingTiddler && existingTiddler.hasField(\"plugin-type\") && existingTiddler.hasField(\"version\")) {\n\t\t// Reject the incoming plugin if it is older\n\t\tif(!$tw.utils.checkVersions(tiddler.fields.version,existingTiddler.fields.version)) {\n\t\t\treturn false;\n\t\t}\n\t}\n\t// Fall through to adding the tiddler\n\tthis.addTiddler(tiddler);\n\treturn true;\n};\n\n/*\nReturn a hashmap of the fields that should be set when a tiddler is created\n*/\nexports.getCreationFields = function() {\n\tif(this.getTiddlerText(TIMESTAMP_DISABLE_TITLE,\"\").toLowerCase() !== \"yes\") {\n\t\tvar fields = {\n\t\t\t\tcreated: new Date()\n\t\t\t},\n\t\t\tcreator = this.getTiddlerText(USER_NAME_TITLE);\n\t\tif(creator) {\n\t\t\tfields.creator = creator;\n\t\t}\n\t\treturn fields;\n\t} else {\n\t\treturn {};\n\t}\n};\n\n/*\nReturn a hashmap of the fields that should be set when a tiddler is modified\n*/\nexports.getModificationFields = function() {\n\tif(this.getTiddlerText(TIMESTAMP_DISABLE_TITLE,\"\").toLowerCase() !== \"yes\") {\n\t\tvar fields = Object.create(null),\n\t\t\tmodifier = this.getTiddlerText(USER_NAME_TITLE);\n\t\tfields.modified = new Date();\n\t\tif(modifier) {\n\t\t\tfields.modifier = modifier;\n\t\t}\n\t\treturn fields;\n\t} else {\n\t\treturn {};\n\t}\n};\n\n/*\nReturn a sorted array of tiddler titles. Options include:\nsortField: field to sort by\nexcludeTag: tag to exclude\nincludeSystem: whether to include system tiddlers (defaults to false)\n*/\nexports.getTiddlers = function(options) {\n\toptions = options || Object.create(null);\n\tvar self = this,\n\t\tsortField = options.sortField || \"title\",\n\t\ttiddlers = [], t, titles = [];\n\tthis.each(function(tiddler,title) {\n\t\tif(options.includeSystem || !self.isSystemTiddler(title)) {\n\t\t\tif(!options.excludeTag || !tiddler.hasTag(options.excludeTag)) {\n\t\t\t\ttiddlers.push(tiddler);\n\t\t\t}\n\t\t}\n\t});\n\ttiddlers.sort(function(a,b) {\n\t\tvar aa = a.fields[sortField].toLowerCase() || \"\",\n\t\t\tbb = b.fields[sortField].toLowerCase() || \"\";\n\t\tif(aa < bb) {\n\t\t\treturn -1;\n\t\t} else {\n\t\t\tif(aa > bb) {\n\t\t\t\treturn 1;\n\t\t\t} else {\n\t\t\t\treturn 0;\n\t\t\t}\n\t\t}\n\t});\n\tfor(t=0; t<tiddlers.length; t++) {\n\t\ttitles.push(tiddlers[t].fields.title);\n\t}\n\treturn titles;\n};\n\nexports.countTiddlers = function(excludeTag) {\n\tvar tiddlers = this.getTiddlers({excludeTag: excludeTag});\n\treturn $tw.utils.count(tiddlers);\n};\n\n/*\nReturns a function iterator(callback) that iterates through the specified titles, and invokes the callback with callback(tiddler,title)\n*/\nexports.makeTiddlerIterator = function(titles) {\n\tvar self = this;\n\tif(!$tw.utils.isArray(titles)) {\n\t\ttitles = Object.keys(titles);\n\t} else {\n\t\ttitles = titles.slice(0);\n\t}\n\treturn function(callback) {\n\t\ttitles.forEach(function(title) {\n\t\t\tcallback(self.getTiddler(title),title);\n\t\t});\n\t};\n};\n\n/*\nSort an array of tiddler titles by a specified field\n\ttitles: array of titles (sorted in place)\n\tsortField: name of field to sort by\n\tisDescending: true if the sort should be descending\n\tisCaseSensitive: true if the sort should consider upper and lower case letters to be different\n*/\nexports.sortTiddlers = function(titles,sortField,isDescending,isCaseSensitive,isNumeric,isAlphaNumeric) {\n\tvar self = this;\n\ttitles.sort(function(a,b) {\n\t\tvar x,y,\n\t\t\tcompareNumbers = function(x,y) {\n\t\t\t\tvar result =\n\t\t\t\t\tisNaN(x) && !isNaN(y) ? (isDescending ? -1 : 1) :\n\t\t\t\t\t!isNaN(x) && isNaN(y) ? (isDescending ? 1 : -1) :\n\t\t\t\t\t\t\t\t\t\t\t(isDescending ? y - x : x - y);\n\t\t\t\treturn result;\n\t\t\t};\n\t\tif(sortField !== \"title\") {\n\t\t\tvar tiddlerA = self.getTiddler(a),\n\t\t\t\ttiddlerB = self.getTiddler(b);\n\t\t\tif(tiddlerA) {\n\t\t\t\ta = tiddlerA.fields[sortField] || \"\";\n\t\t\t} else {\n\t\t\t\ta = \"\";\n\t\t\t}\n\t\t\tif(tiddlerB) {\n\t\t\t\tb = tiddlerB.fields[sortField] || \"\";\n\t\t\t} else {\n\t\t\t\tb = \"\";\n\t\t\t}\n\t\t}\n\t\tx = Number(a);\n\t\ty = Number(b);\n\t\tif(isNumeric && (!isNaN(x) || !isNaN(y))) {\n\t\t\treturn compareNumbers(x,y);\n\t\t} else if(isAlphaNumeric) {\n\t\t\treturn isDescending ? b.localeCompare(a,undefined,{numeric: true,sensitivity: \"base\"}) : a.localeCompare(b,undefined,{numeric: true,sensitivity: \"base\"});\n\t\t} else if($tw.utils.isDate(a) && $tw.utils.isDate(b)) {\n\t\t\treturn isDescending ? b - a : a - b;\n\t\t} else {\n\t\t\ta = String(a);\n\t\t\tb = String(b);\n\t\t\tif(!isCaseSensitive) {\n\t\t\t\ta = a.toLowerCase();\n\t\t\t\tb = b.toLowerCase();\n\t\t\t}\n\t\t\treturn isDescending ? b.localeCompare(a) : a.localeCompare(b);\n\t\t}\n\t});\n};\n\n/*\nFor every tiddler invoke a callback(title,tiddler) with `this` set to the wiki object. Options include:\nsortField: field to sort by\nexcludeTag: tag to exclude\nincludeSystem: whether to include system tiddlers (defaults to false)\n*/\nexports.forEachTiddler = function(/* [options,]callback */) {\n\tvar arg = 0,\n\t\toptions = arguments.length >= 2 ? arguments[arg++] : {},\n\t\tcallback = arguments[arg++],\n\t\ttitles = this.getTiddlers(options),\n\t\tt, tiddler;\n\tfor(t=0; t<titles.length; t++) {\n\t\ttiddler = this.getTiddler(titles[t]);\n\t\tif(tiddler) {\n\t\t\tcallback.call(this,tiddler.fields.title,tiddler);\n\t\t}\n\t}\n};\n\n/*\nReturn an array of tiddler titles that are directly linked from the specified tiddler\n*/\nexports.getTiddlerLinks = function(title) {\n\tvar self = this;\n\t// We'll cache the links so they only get computed if the tiddler changes\n\treturn this.getCacheForTiddler(title,\"links\",function() {\n\t\t// Parse the tiddler\n\t\tvar parser = self.parseTiddler(title);\n\t\t// Count up the links\n\t\tvar links = [],\n\t\t\tcheckParseTree = function(parseTree) {\n\t\t\t\tfor(var t=0; t<parseTree.length; t++) {\n\t\t\t\t\tvar parseTreeNode = parseTree[t];\n\t\t\t\t\tif(parseTreeNode.type === \"link\" && parseTreeNode.attributes.to && parseTreeNode.attributes.to.type === \"string\") {\n\t\t\t\t\t\tvar value = parseTreeNode.attributes.to.value;\n\t\t\t\t\t\tif(links.indexOf(value) === -1) {\n\t\t\t\t\t\t\tlinks.push(value);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif(parseTreeNode.children) {\n\t\t\t\t\t\tcheckParseTree(parseTreeNode.children);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t};\n\t\tif(parser) {\n\t\t\tcheckParseTree(parser.tree);\n\t\t}\n\t\treturn links;\n\t});\n};\n\n/*\nReturn an array of tiddler titles that link to the specified tiddler\n*/\nexports.getTiddlerBacklinks = function(targetTitle) {\n\tvar self = this,\n\t\tbacklinks = [];\n\tthis.forEachTiddler(function(title,tiddler) {\n\t\tvar links = self.getTiddlerLinks(title);\n\t\tif(links.indexOf(targetTitle) !== -1) {\n\t\t\tbacklinks.push(title);\n\t\t}\n\t});\n\treturn backlinks;\n};\n\n/*\nReturn a hashmap of tiddler titles that are referenced but not defined. Each value is the number of times the missing tiddler is referenced\n*/\nexports.getMissingTitles = function() {\n\tvar self = this,\n\t\tmissing = [];\n// We should cache the missing tiddler list, even if we recreate it every time any tiddler is modified\n\tthis.forEachTiddler(function(title,tiddler) {\n\t\tvar links = self.getTiddlerLinks(title);\n\t\t$tw.utils.each(links,function(link) {\n\t\t\tif((!self.tiddlerExists(link) && !self.isShadowTiddler(link)) && missing.indexOf(link) === -1) {\n\t\t\t\tmissing.push(link);\n\t\t\t}\n\t\t});\n\t});\n\treturn missing;\n};\n\nexports.getOrphanTitles = function() {\n\tvar self = this,\n\t\torphans = this.getTiddlers();\n\tthis.forEachTiddler(function(title,tiddler) {\n\t\tvar links = self.getTiddlerLinks(title);\n\t\t$tw.utils.each(links,function(link) {\n\t\t\tvar p = orphans.indexOf(link);\n\t\t\tif(p !== -1) {\n\t\t\t\torphans.splice(p,1);\n\t\t\t}\n\t\t});\n\t});\n\treturn orphans; // Todo\n};\n\n/*\nRetrieves a list of the tiddler titles that are tagged with a given tag\n*/\nexports.getTiddlersWithTag = function(tag) {\n\tvar self = this;\n\treturn this.getGlobalCache(\"taglist-\" + tag,function() {\n\t\tvar tagmap = self.getTagMap();\n\t\treturn self.sortByList(tagmap[tag],tag);\n\t});\n};\n\n/*\nGet a hashmap by tag of arrays of tiddler titles\n*/\nexports.getTagMap = function() {\n\tvar self = this;\n\treturn this.getGlobalCache(\"tagmap\",function() {\n\t\tvar tags = Object.create(null),\n\t\t\tstoreTags = function(tagArray,title) {\n\t\t\t\tif(tagArray) {\n\t\t\t\t\tfor(var index=0; index<tagArray.length; index++) {\n\t\t\t\t\t\tvar tag = tagArray[index];\n\t\t\t\t\t\tif($tw.utils.hop(tags,tag)) {\n\t\t\t\t\t\t\ttags[tag].push(title);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\ttags[tag] = [title];\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t\ttitle, tiddler;\n\t\t// Collect up all the tags\n\t\tself.eachShadow(function(tiddler,title) {\n\t\t\tif(!self.tiddlerExists(title)) {\n\t\t\t\ttiddler = self.getTiddler(title);\n\t\t\t\tstoreTags(tiddler.fields.tags,title);\n\t\t\t}\n\t\t});\n\t\tself.each(function(tiddler,title) {\n\t\t\tstoreTags(tiddler.fields.tags,title);\n\t\t});\n\t\treturn tags;\n\t});\n};\n\n/*\nLookup a given tiddler and return a list of all the tiddlers that include it in the specified list field\n*/\nexports.findTiddlersByField = function(targetTitle,fieldName) {\n\tfieldName = fieldName || \"list\";\n\tvar titles = [];\n\tthis.each(function(tiddler,title) {\n\t\tvar list = $tw.utils.parseStringArray(tiddler.fields[fieldName]);\n\t\tif(list && list.indexOf(targetTitle) !== -1) {\n\t\t\ttitles.push(title);\n\t\t}\n\t});\n\treturn titles;\n};\n\nexports.findListingsOfTiddler = function(targetTitle,fieldName) {\n\treturn this.findTiddlersByField(targetTitle, fieldName)\n};\n\n/*\nSorts an array of tiddler titles according to an ordered list\n*/\nexports.sortByList = function(array,listTitle) {\n\tvar self = this,\n\t\treplacedTitles = Object.create(null);\n\tfunction replaceItem(title) {\n\t\tif(!$tw.utils.hop(replacedTitles, title)) {\n\t\t\treplacedTitles[title] = true;\n\t\t\tvar newPos = -1,\n\t\t\t\ttiddler = self.getTiddler(title);\n\t\t\tif(tiddler) {\n\t\t\t\tvar beforeTitle = tiddler.fields[\"list-before\"],\n\t\t\t\t\tafterTitle = tiddler.fields[\"list-after\"];\n\t\t\t\tif(beforeTitle === \"\") {\n\t\t\t\t\tnewPos = 0;\n\t\t\t\t} else if(afterTitle === \"\") {\n\t\t\t\t\tnewPos = titles.length;\n\t\t\t\t} else if(beforeTitle) {\n\t\t\t\t\treplaceItem(beforeTitle);\n\t\t\t\t\tnewPos = titles.indexOf(beforeTitle);\n\t\t\t\t} else if(afterTitle) {\n\t\t\t\t\treplaceItem(afterTitle);\n\t\t\t\t\tnewPos = titles.indexOf(afterTitle);\n\t\t\t\t\tif(newPos >= 0) {\n\t\t\t\t\t\t++newPos;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t// We get the currPos //after// figuring out the newPos, because recursive replaceItem calls might alter title's currPos\n\t\t\t\tvar currPos = titles.indexOf(title);\n\t\t\t\tif(newPos === -1) {\n\t\t\t\t\tnewPos = currPos;\n\t\t\t\t}\n\t\t\t\tif(currPos >= 0 && newPos !== currPos) {\n\t\t\t\t\ttitles.splice(currPos,1);\n\t\t\t\t\tif(newPos >= currPos) {\n\t\t\t\t\t\tnewPos--;\n\t\t\t\t\t}\n\t\t\t\t\ttitles.splice(newPos,0,title);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\tvar list = this.getTiddlerList(listTitle);\n\tif(!array || array.length === 0) {\n\t\treturn [];\n\t} else {\n\t\tvar titles = [], t, title;\n\t\t// First place any entries that are present in the list\n\t\tfor(t=0; t<list.length; t++) {\n\t\t\ttitle = list[t];\n\t\t\tif(array.indexOf(title) !== -1) {\n\t\t\t\ttitles.push(title);\n\t\t\t}\n\t\t}\n\t\t// Then place any remaining entries\n\t\tfor(t=0; t<array.length; t++) {\n\t\t\ttitle = array[t];\n\t\t\tif(list.indexOf(title) === -1) {\n\t\t\t\ttitles.push(title);\n\t\t\t}\n\t\t}\n\t\t// Finally obey the list-before and list-after fields of each tiddler in turn\n\t\tvar sortedTitles = titles.slice(0);\n\t\tfor(t=0; t<sortedTitles.length; t++) {\n\t\t\ttitle = sortedTitles[t];\n\t\t\treplaceItem(title);\n\t\t}\n\t\treturn titles;\n\t}\n};\n\nexports.getSubTiddler = function(title,subTiddlerTitle) {\n\tvar bundleInfo = this.getPluginInfo(title) || this.getTiddlerDataCached(title);\n\tif(bundleInfo && bundleInfo.tiddlers) {\n\t\tvar subTiddler = bundleInfo.tiddlers[subTiddlerTitle];\n\t\tif(subTiddler) {\n\t\t\treturn new $tw.Tiddler(subTiddler);\n\t\t}\n\t}\n\treturn null;\n};\n\n/*\nRetrieve a tiddler as a JSON string of the fields\n*/\nexports.getTiddlerAsJson = function(title) {\n\tvar tiddler = this.getTiddler(title);\n\tif(tiddler) {\n\t\tvar fields = Object.create(null);\n\t\t$tw.utils.each(tiddler.fields,function(value,name) {\n\t\t\tfields[name] = tiddler.getFieldString(name);\n\t\t});\n\t\treturn JSON.stringify(fields);\n\t} else {\n\t\treturn JSON.stringify({title: title});\n\t}\n};\n\nexports.getTiddlersAsJson = function(filter) {\n\tvar tiddlers = this.filterTiddlers(filter),\n\t\tdata = [];\n\tfor(var t=0;t<tiddlers.length; t++) {\n\t\tvar tiddler = this.getTiddler(tiddlers[t]);\n\t\tif(tiddler) {\n\t\t\tvar fields = new Object();\n\t\t\tfor(var field in tiddler.fields) {\n\t\t\t\tfields[field] = tiddler.getFieldString(field);\n\t\t\t}\n\t\t\tdata.push(fields);\n\t\t}\n\t}\n\treturn JSON.stringify(data,null,$tw.config.preferences.jsonSpaces);\n};\n\n/*\nGet the content of a tiddler as a JavaScript object. How this is done depends on the type of the tiddler:\n\napplication/json: the tiddler JSON is parsed into an object\napplication/x-tiddler-dictionary: the tiddler is parsed as sequence of name:value pairs\n\nOther types currently just return null.\n\ntitleOrTiddler: string tiddler title or a tiddler object\ndefaultData: default data to be returned if the tiddler is missing or doesn't contain data\n\nNote that the same value is returned for repeated calls for the same tiddler data. The value is frozen to prevent modification; otherwise modifications would be visible to all callers\n*/\nexports.getTiddlerDataCached = function(titleOrTiddler,defaultData) {\n\tvar self = this,\n\t\ttiddler = titleOrTiddler;\n\tif(!(tiddler instanceof $tw.Tiddler)) {\n\t\ttiddler = this.getTiddler(tiddler);\n\t}\n\tif(tiddler) {\n\t\treturn this.getCacheForTiddler(tiddler.fields.title,\"data\",function() {\n\t\t\t// Return the frozen value\n\t\t\tvar value = self.getTiddlerData(tiddler.fields.title,undefined);\n\t\t\t$tw.utils.deepFreeze(value);\n\t\t\treturn value;\n\t\t}) || defaultData;\n\t} else {\n\t\treturn defaultData;\n\t}\n};\n\n/*\nAlternative, uncached version of getTiddlerDataCached(). The return value can be mutated freely and reused\n*/\nexports.getTiddlerData = function(titleOrTiddler,defaultData) {\n\tvar tiddler = titleOrTiddler,\n\t\tdata;\n\tif(!(tiddler instanceof $tw.Tiddler)) {\n\t\ttiddler = this.getTiddler(tiddler);\n\t}\n\tif(tiddler && tiddler.fields.text) {\n\t\tswitch(tiddler.fields.type) {\n\t\t\tcase \"application/json\":\n\t\t\t\t// JSON tiddler\n\t\t\t\ttry {\n\t\t\t\t\tdata = JSON.parse(tiddler.fields.text);\n\t\t\t\t} catch(ex) {\n\t\t\t\t\treturn defaultData;\n\t\t\t\t}\n\t\t\t\treturn data;\n\t\t\tcase \"application/x-tiddler-dictionary\":\n\t\t\t\treturn $tw.utils.parseFields(tiddler.fields.text);\n\t\t}\n\t}\n\treturn defaultData;\n};\n\n/*\nExtract an indexed field from within a data tiddler\n*/\nexports.extractTiddlerDataItem = function(titleOrTiddler,index,defaultText) {\n\tvar data = this.getTiddlerDataCached(titleOrTiddler,Object.create(null)),\n\t\ttext;\n\tif(data && $tw.utils.hop(data,index)) {\n\t\ttext = data[index];\n\t}\n\tif(typeof text === \"string\" || typeof text === \"number\") {\n\t\treturn text.toString();\n\t} else {\n\t\treturn defaultText;\n\t}\n};\n\n/*\nSet a tiddlers content to a JavaScript object. Currently this is done by setting the tiddler's type to \"application/json\" and setting the text to the JSON text of the data.\ntitle: title of tiddler\ndata: object that can be serialised to JSON\nfields: optional hashmap of additional tiddler fields to be set\n*/\nexports.setTiddlerData = function(title,data,fields) {\n\tvar existingTiddler = this.getTiddler(title),\n\t\tnewFields = {\n\t\t\ttitle: title\n\t};\n\tif(existingTiddler && existingTiddler.fields.type === \"application/x-tiddler-dictionary\") {\n\t\tnewFields.text = $tw.utils.makeTiddlerDictionary(data);\n\t} else {\n\t\tnewFields.type = \"application/json\";\n\t\tnewFields.text = JSON.stringify(data,null,$tw.config.preferences.jsonSpaces);\n\t}\n\tthis.addTiddler(new $tw.Tiddler(this.getCreationFields(),existingTiddler,fields,newFields,this.getModificationFields()));\n};\n\n/*\nReturn the content of a tiddler as an array containing each line\n*/\nexports.getTiddlerList = function(title,field,index) {\n\tif(index) {\n\t\treturn $tw.utils.parseStringArray(this.extractTiddlerDataItem(title,index,\"\"));\n\t}\n\tfield = field || \"list\";\n\tvar tiddler = this.getTiddler(title);\n\tif(tiddler) {\n\t\treturn ($tw.utils.parseStringArray(tiddler.fields[field]) || []).slice(0);\n\t}\n\treturn [];\n};\n\n// Return a named global cache object. Global cache objects are cleared whenever a tiddler change occurs\nexports.getGlobalCache = function(cacheName,initializer) {\n\tthis.globalCache = this.globalCache || Object.create(null);\n\tif($tw.utils.hop(this.globalCache,cacheName)) {\n\t\treturn this.globalCache[cacheName];\n\t} else {\n\t\tthis.globalCache[cacheName] = initializer();\n\t\treturn this.globalCache[cacheName];\n\t}\n};\n\nexports.clearGlobalCache = function() {\n\tthis.globalCache = Object.create(null);\n};\n\n// Return the named cache object for a tiddler. If the cache doesn't exist then the initializer function is invoked to create it\nexports.getCacheForTiddler = function(title,cacheName,initializer) {\n\tthis.caches = this.caches || Object.create(null);\n\tvar caches = this.caches[title];\n\tif(caches && caches[cacheName]) {\n\t\treturn caches[cacheName];\n\t} else {\n\t\tif(!caches) {\n\t\t\tcaches = Object.create(null);\n\t\t\tthis.caches[title] = caches;\n\t\t}\n\t\tcaches[cacheName] = initializer();\n\t\treturn caches[cacheName];\n\t}\n};\n\n// Clear all caches associated with a particular tiddler, or, if the title is null, clear all the caches for all the tiddlers\nexports.clearCache = function(title) {\n\tif(title) {\n\t\tthis.caches = this.caches || Object.create(null);\n\t\tif($tw.utils.hop(this.caches,title)) {\n\t\t\tdelete this.caches[title];\n\t\t}\n\t} else {\n\t\tthis.caches = Object.create(null);\n\t}\n};\n\nexports.initParsers = function(moduleType) {\n\t// Install the parser modules\n\t$tw.Wiki.parsers = {};\n\tvar self = this;\n\t$tw.modules.forEachModuleOfType(\"parser\",function(title,module) {\n\t\tfor(var f in module) {\n\t\t\tif($tw.utils.hop(module,f)) {\n\t\t\t\t$tw.Wiki.parsers[f] = module[f]; // Store the parser class\n\t\t\t}\n\t\t}\n\t});\n\t// Use the generic binary parser for any binary types not registered so far\n\tif($tw.Wiki.parsers[\"application/octet-stream\"]) {\n\t\tObject.keys($tw.config.contentTypeInfo).forEach(function(type) {\n\t\t\tif(!$tw.utils.hop($tw.Wiki.parsers,type) && $tw.config.contentTypeInfo[type].encoding === \"base64\") {\n\t\t\t\t$tw.Wiki.parsers[type] = $tw.Wiki.parsers[\"application/octet-stream\"];\n\t\t\t}\n\t\t});\n\t}\n};\n\n/*\nParse a block of text of a specified MIME type\n\ttype: content type of text to be parsed\n\ttext: text\n\toptions: see below\nOptions include:\n\tparseAsInline: if true, the text of the tiddler will be parsed as an inline run\n\t_canonical_uri: optional string of the canonical URI of this content\n*/\nexports.parseText = function(type,text,options) {\n\ttext = text || \"\";\n\toptions = options || {};\n\t// Select a parser\n\tvar Parser = $tw.Wiki.parsers[type];\n\tif(!Parser && $tw.utils.getFileExtensionInfo(type)) {\n\t\tParser = $tw.Wiki.parsers[$tw.utils.getFileExtensionInfo(type).type];\n\t}\n\tif(!Parser) {\n\t\tParser = $tw.Wiki.parsers[options.defaultType || \"text/vnd.tiddlywiki\"];\n\t}\n\tif(!Parser) {\n\t\treturn null;\n\t}\n\t// Return the parser instance\n\treturn new Parser(type,text,{\n\t\tparseAsInline: options.parseAsInline,\n\t\twiki: this,\n\t\t_canonical_uri: options._canonical_uri\n\t});\n};\n\n/*\nParse a tiddler according to its MIME type\n*/\nexports.parseTiddler = function(title,options) {\n\toptions = $tw.utils.extend({},options);\n\tvar cacheType = options.parseAsInline ? \"inlineParseTree\" : \"blockParseTree\",\n\t\ttiddler = this.getTiddler(title),\n\t\tself = this;\n\treturn tiddler ? this.getCacheForTiddler(title,cacheType,function() {\n\t\t\tif(tiddler.hasField(\"_canonical_uri\")) {\n\t\t\t\toptions._canonical_uri = tiddler.fields._canonical_uri;\n\t\t\t}\n\t\t\treturn self.parseText(tiddler.fields.type,tiddler.fields.text,options);\n\t\t}) : null;\n};\n\nexports.parseTextReference = function(title,field,index,options) {\n\tvar tiddler,text;\n\tif(options.subTiddler) {\n\t\ttiddler = this.getSubTiddler(title,options.subTiddler);\n\t} else {\n\t\ttiddler = this.getTiddler(title);\n\t\tif(field === \"text\" || (!field && !index)) {\n\t\t\tthis.getTiddlerText(title); // Force the tiddler to be lazily loaded\n\t\t\treturn this.parseTiddler(title,options);\n\t\t}\n\t}\n\tif(field === \"text\" || (!field && !index)) {\n\t\tif(tiddler && tiddler.fields) {\n\t\t\treturn this.parseText(tiddler.fields.type,tiddler.fields.text,options);\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t} else if(field) {\n\t\tif(field === \"title\") {\n\t\t\ttext = title;\n\t\t} else {\n\t\t\tif(!tiddler || !tiddler.hasField(field)) {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t\ttext = tiddler.fields[field];\n\t\t}\n\t\treturn this.parseText(\"text/vnd.tiddlywiki\",text.toString(),options);\n\t} else if(index) {\n\t\tthis.getTiddlerText(title); // Force the tiddler to be lazily loaded\n\t\ttext = this.extractTiddlerDataItem(tiddler,index,undefined);\n\t\tif(text === undefined) {\n\t\t\treturn null;\n\t\t}\n\t\treturn this.parseText(\"text/vnd.tiddlywiki\",text,options);\n\t}\n};\n\n/*\nMake a widget tree for a parse tree\nparser: parser object\noptions: see below\nOptions include:\ndocument: optional document to use\nvariables: hashmap of variables to set\nparentWidget: optional parent widget for the root node\n*/\nexports.makeWidget = function(parser,options) {\n\toptions = options || {};\n\tvar widgetNode = {\n\t\t\ttype: \"widget\",\n\t\t\tchildren: []\n\t\t},\n\t\tcurrWidgetNode = widgetNode;\n\t// Create set variable widgets for each variable\n\t$tw.utils.each(options.variables,function(value,name) {\n\t\tvar setVariableWidget = {\n\t\t\ttype: \"set\",\n\t\t\tattributes: {\n\t\t\t\tname: {type: \"string\", value: name},\n\t\t\t\tvalue: {type: \"string\", value: value}\n\t\t\t},\n\t\t\tchildren: []\n\t\t};\n\t\tcurrWidgetNode.children = [setVariableWidget];\n\t\tcurrWidgetNode = setVariableWidget;\n\t});\n\t// Add in the supplied parse tree nodes\n\tcurrWidgetNode.children = parser ? parser.tree : [];\n\t// Create the widget\n\treturn new widget.widget(widgetNode,{\n\t\twiki: this,\n\t\tdocument: options.document || $tw.fakeDocument,\n\t\tparentWidget: options.parentWidget\n\t});\n};\n\n/*\nMake a widget tree for transclusion\ntitle: target tiddler title\noptions: as for wiki.makeWidget() plus:\noptions.field: optional field to transclude (defaults to \"text\")\noptions.mode: transclusion mode \"inline\" or \"block\"\noptions.children: optional array of children for the transclude widget\noptions.importVariables: optional importvariables filter string for macros to be included\noptions.importPageMacros: optional boolean; if true, equivalent to passing \"[[$:/core/ui/PageMacros]] [all[shadows+tiddlers]tag[$:/tags/Macro]!has[draft.of]]\" to options.importVariables\n*/\nexports.makeTranscludeWidget = function(title,options) {\n\toptions = options || {};\n\tvar parseTreeDiv = {tree: [{\n\t\t\ttype: \"element\",\n\t\t\ttag: \"div\",\n\t\t\tchildren: []}]},\n\t\tparseTreeImportVariables = {\n\t\t\ttype: \"importvariables\",\n\t\t\tattributes: {\n\t\t\t\tfilter: {\n\t\t\t\t\tname: \"filter\",\n\t\t\t\t\ttype: \"string\"\n\t\t\t\t}\n\t\t\t},\n\t\t\tisBlock: false,\n\t\t\tchildren: []},\n\t\tparseTreeTransclude = {\n\t\t\ttype: \"transclude\",\n\t\t\tattributes: {\n\t\t\t\ttiddler: {\n\t\t\t\t\tname: \"tiddler\",\n\t\t\t\t\ttype: \"string\",\n\t\t\t\t\tvalue: title}},\n\t\t\tisBlock: !options.parseAsInline};\n\tif(options.importVariables || options.importPageMacros) {\n\t\tif(options.importVariables) {\n\t\t\tparseTreeImportVariables.attributes.filter.value = options.importVariables;\n\t\t} else if(options.importPageMacros) {\n\t\t\tparseTreeImportVariables.attributes.filter.value = \"[[$:/core/ui/PageMacros]] [all[shadows+tiddlers]tag[$:/tags/Macro]!has[draft.of]]\";\n\t\t}\n\t\tparseTreeDiv.tree[0].children.push(parseTreeImportVariables);\n\t\tparseTreeImportVariables.children.push(parseTreeTransclude);\n\t} else {\n\t\tparseTreeDiv.tree[0].children.push(parseTreeTransclude);\n\t}\n\tif(options.field) {\n\t\tparseTreeTransclude.attributes.field = {type: \"string\", value: options.field};\n\t}\n\tif(options.mode) {\n\t\tparseTreeTransclude.attributes.mode = {type: \"string\", value: options.mode};\n\t}\n\tif(options.children) {\n\t\tparseTreeTransclude.children = options.children;\n\t}\n\treturn $tw.wiki.makeWidget(parseTreeDiv,options);\n};\n\n/*\nParse text in a specified format and render it into another format\n\toutputType: content type for the output\n\ttextType: content type of the input text\n\ttext: input text\n\toptions: see below\nOptions include:\nvariables: hashmap of variables to set\nparentWidget: optional parent widget for the root node\n*/\nexports.renderText = function(outputType,textType,text,options) {\n\toptions = options || {};\n\tvar parser = this.parseText(textType,text,options),\n\t\twidgetNode = this.makeWidget(parser,options);\n\tvar container = $tw.fakeDocument.createElement(\"div\");\n\twidgetNode.render(container,null);\n\treturn outputType === \"text/html\" ? container.innerHTML : container.textContent;\n};\n\n/*\nParse text from a tiddler and render it into another format\n\toutputType: content type for the output\n\ttitle: title of the tiddler to be rendered\n\toptions: see below\nOptions include:\nvariables: hashmap of variables to set\nparentWidget: optional parent widget for the root node\n*/\nexports.renderTiddler = function(outputType,title,options) {\n\toptions = options || {};\n\tvar parser = this.parseTiddler(title,options),\n\t\twidgetNode = this.makeWidget(parser,options);\n\tvar container = $tw.fakeDocument.createElement(\"div\");\n\twidgetNode.render(container,null);\n\treturn outputType === \"text/html\" ? container.innerHTML : (outputType === \"text/plain-formatted\" ? container.formattedTextContent : container.textContent);\n};\n\n/*\nReturn an array of tiddler titles that match a search string\n\ttext: The text string to search for\n\toptions: see below\nOptions available:\n\tsource: an iterator function for the source tiddlers, called source(iterator), where iterator is called as iterator(tiddler,title)\n\texclude: An array of tiddler titles to exclude from the search\n\tinvert: If true returns tiddlers that do not contain the specified string\n\tcaseSensitive: If true forces a case sensitive search\n\tfield: If specified, restricts the search to the specified field, or an array of field names\n\texcludeField: If true, the field options are inverted to specify the fields that are not to be searched\n\tThe search mode is determined by the first of these boolean flags to be true\n\t\tliteral: searches for literal string\n\t\twhitespace: same as literal except runs of whitespace are treated as a single space\n\t\tregexp: treats the search term as a regular expression\n\t\twords: (default) treats search string as a list of tokens, and matches if all tokens are found, regardless of adjacency or ordering\n*/\nexports.search = function(text,options) {\n\toptions = options || {};\n\tvar self = this,\n\t\tt,\n\t\tinvert = !!options.invert;\n\t// Convert the search string into a regexp for each term\n\tvar terms, searchTermsRegExps,\n\t\tflags = options.caseSensitive ? \"\" : \"i\";\n\tif(options.literal) {\n\t\tif(text.length === 0) {\n\t\t\tsearchTermsRegExps = null;\n\t\t} else {\n\t\t\tsearchTermsRegExps = [new RegExp(\"(\" + $tw.utils.escapeRegExp(text) + \")\",flags)];\n\t\t}\n\t} else if(options.whitespace) {\n\t\tterms = [];\n\t\t$tw.utils.each(text.split(/\\s+/g),function(term) {\n\t\t\tif(term) {\n\t\t\t\tterms.push($tw.utils.escapeRegExp(term));\n\t\t\t}\n\t\t});\n\t\tsearchTermsRegExps = [new RegExp(\"(\" + terms.join(\"\\\\s+\") + \")\",flags)];\n\t} else if(options.regexp) {\n\t\ttry {\n\t\t\tsearchTermsRegExps = [new RegExp(\"(\" + text + \")\",flags)];\n\t\t} catch(e) {\n\t\t\tsearchTermsRegExps = null;\n\t\t\tconsole.log(\"Regexp error parsing /(\" + text + \")/\" + flags + \": \",e);\n\t\t}\n\t} else {\n\t\tterms = text.split(/ +/);\n\t\tif(terms.length === 1 && terms[0] === \"\") {\n\t\t\tsearchTermsRegExps = null;\n\t\t} else {\n\t\t\tsearchTermsRegExps = [];\n\t\t\tfor(t=0; t<terms.length; t++) {\n\t\t\t\tsearchTermsRegExps.push(new RegExp(\"(\" + $tw.utils.escapeRegExp(terms[t]) + \")\",flags));\n\t\t\t}\n\t\t}\n\t}\n\t// Accumulate the array of fields to be searched or excluded from the search\n\tvar fields = [];\n\tif(options.field) {\n\t\tif($tw.utils.isArray(options.field)) {\n\t\t\t$tw.utils.each(options.field,function(fieldName) {\n\t\t\t\tif(fieldName) {\n\t\t\t\t\tfields.push(fieldName);\n\t\t\t\t}\n\t\t\t});\n\t\t} else {\n\t\t\tfields.push(options.field);\n\t\t}\n\t}\n\t// Use default fields if none specified and we're not excluding fields (excluding fields with an empty field array is the same as searching all fields)\n\tif(fields.length === 0 && !options.excludeField) {\n\t\tfields.push(\"title\");\n\t\tfields.push(\"tags\");\n\t\tfields.push(\"text\");\n\t}\n\t// Function to check a given tiddler for the search term\n\tvar searchTiddler = function(title) {\n\t\tif(!searchTermsRegExps) {\n\t\t\treturn true;\n\t\t}\n\t\tvar notYetFound = searchTermsRegExps.slice();\n\n\t\tvar tiddler = self.getTiddler(title);\n\t\tif(!tiddler) {\n\t\t\ttiddler = new $tw.Tiddler({title: title, text: \"\", type: \"text/vnd.tiddlywiki\"});\n\t\t}\n\t\tvar contentTypeInfo = $tw.config.contentTypeInfo[tiddler.fields.type] || $tw.config.contentTypeInfo[\"text/vnd.tiddlywiki\"],\n\t\t\tsearchFields;\n\t\t// Get the list of fields we're searching\n\t\tif(options.excludeField) {\n\t\t\tsearchFields = Object.keys(tiddler.fields);\n\t\t\t$tw.utils.each(fields,function(fieldName) {\n\t\t\t\tvar p = searchFields.indexOf(fieldName);\n\t\t\t\tif(p !== -1) {\n\t\t\t\t\tsearchFields.splice(p,1);\n\t\t\t\t}\n\t\t\t});\n\t\t} else {\n\t\t\tsearchFields = fields;\n\t\t}\n\t\tfor(var fieldIndex=0; notYetFound.length>0 && fieldIndex<searchFields.length; fieldIndex++) {\n\t\t\t// Don't search the text field if the content type is binary\n\t\t\tvar fieldName = searchFields[fieldIndex];\n\t\t\tif(fieldName === \"text\" && contentTypeInfo.encoding !== \"utf8\") {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tvar str = tiddler.fields[fieldName],\n\t\t\t\tt;\n\t\t\tif(str) {\n\t\t\t\tif($tw.utils.isArray(str)) {\n\t\t\t\t\t// If the field value is an array, test each regexp against each field array entry and fail if each regexp doesn't match at least one field array entry\n\t\t\t\t\tfor(var s=0; s<str.length; s++) {\n\t\t\t\t\t\tfor(t=0; t<notYetFound.length;) {\n\t\t\t\t\t\t\tif(notYetFound[t].test(str[s])) {\n\t\t\t\t\t\t\t\tnotYetFound.splice(t, 1);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tt++;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t// If the field isn't an array, force it to a string and test each regexp against it and fail if any do not match\n\t\t\t\t\tstr = tiddler.getFieldString(fieldName);\n\t\t\t\t\tfor(t=0; t<notYetFound.length;) {\n\t\t\t\t\t\tif(notYetFound[t].test(str)) {\n\t\t\t\t\t\t\tnotYetFound.splice(t, 1);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tt++;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t\treturn notYetFound.length == 0;\n\t};\n\t// Loop through all the tiddlers doing the search\n\tvar results = [],\n\t\tsource = options.source || this.each;\n\tsource(function(tiddler,title) {\n\t\tif(searchTiddler(title) !== options.invert) {\n\t\t\tresults.push(title);\n\t\t}\n\t});\n\t// Remove any of the results we have to exclude\n\tif(options.exclude) {\n\t\tfor(t=0; t<options.exclude.length; t++) {\n\t\t\tvar p = results.indexOf(options.exclude[t]);\n\t\t\tif(p !== -1) {\n\t\t\t\tresults.splice(p,1);\n\t\t\t}\n\t\t}\n\t}\n\treturn results;\n};\n\n/*\nTrigger a load for a tiddler if it is skinny. Returns the text, or undefined if the tiddler is missing, null if the tiddler is being lazily loaded.\n*/\nexports.getTiddlerText = function(title,defaultText) {\n\tvar tiddler = this.getTiddler(title);\n\t// Return undefined if the tiddler isn't found\n\tif(!tiddler) {\n\t\treturn defaultText;\n\t}\n\tif(tiddler.fields.text !== undefined) {\n\t\t// Just return the text if we've got it\n\t\treturn tiddler.fields.text;\n\t} else {\n\t\t// Tell any listeners about the need to lazily load this tiddler\n\t\tthis.dispatchEvent(\"lazyLoad\",title);\n\t\t// Indicate that the text is being loaded\n\t\treturn null;\n\t}\n};\n\n/*\nCheck whether the text of a tiddler matches a given value. By default, the comparison is case insensitive, and any spaces at either end of the tiddler text is trimmed\n*/\nexports.checkTiddlerText = function(title,targetText,options) {\n\toptions = options || {};\n\tvar text = this.getTiddlerText(title,\"\");\n\tif(!options.noTrim) {\n\t\ttext = text.trim();\n\t}\n\tif(!options.caseSensitive) {\n\t\ttext = text.toLowerCase();\n\t\ttargetText = targetText.toLowerCase();\n\t}\n\treturn text === targetText;\n}\n\n/*\nRead an array of browser File objects, invoking callback(tiddlerFieldsArray) once they're all read\n*/\nexports.readFiles = function(files,options) {\n\tvar callback;\n\tif(typeof options === \"function\") {\n\t\tcallback = options;\n\t\toptions = {};\n\t} else {\n\t\tcallback = options.callback;\n\t}\n\tvar result = [],\n\t\toutstanding = files.length,\n\t\treadFileCallback = function(tiddlerFieldsArray) {\n\t\t\tresult.push.apply(result,tiddlerFieldsArray);\n\t\t\tif(--outstanding === 0) {\n\t\t\t\tcallback(result);\n\t\t\t}\n\t\t};\n\tfor(var f=0; f<files.length; f++) {\n\t\tthis.readFile(files[f],$tw.utils.extend({},options,{callback: readFileCallback}));\n\t}\n\treturn files.length;\n};\n\n/*\nRead a browser File object, invoking callback(tiddlerFieldsArray) with an array of tiddler fields objects\n*/\nexports.readFile = function(file,options) {\n\tvar callback;\n\tif(typeof options === \"function\") {\n\t\tcallback = options;\n\t\toptions = {};\n\t} else {\n\t\tcallback = options.callback;\n\t}\n\t// Get the type, falling back to the filename extension\n\tvar self = this,\n\t\ttype = file.type;\n\tif(type === \"\" || !type) {\n\t\tvar dotPos = file.name.lastIndexOf(\".\");\n\t\tif(dotPos !== -1) {\n\t\t\tvar fileExtensionInfo = $tw.utils.getFileExtensionInfo(file.name.substr(dotPos));\n\t\t\tif(fileExtensionInfo) {\n\t\t\t\ttype = fileExtensionInfo.type;\n\t\t\t}\n\t\t}\n\t}\n\t// Figure out if we're reading a binary file\n\tvar contentTypeInfo = $tw.config.contentTypeInfo[type],\n\t\tisBinary = contentTypeInfo ? contentTypeInfo.encoding === \"base64\" : false;\n\t// Log some debugging information\n\tif($tw.log.IMPORT) {\n\t\tconsole.log(\"Importing file '\" + file.name + \"', type: '\" + type + \"', isBinary: \" + isBinary);\n\t}\n\t// Give the hook a chance to process the drag\n\tif($tw.hooks.invokeHook(\"th-importing-file\",{\n\t\tfile: file,\n\t\ttype: type,\n\t\tisBinary: isBinary,\n\t\tcallback: callback\n\t}) !== true) {\n\t\tthis.readFileContent(file,type,isBinary,options.deserializer,callback);\n\t}\n};\n\n/*\nLower level utility to read the content of a browser File object, invoking callback(tiddlerFieldsArray) with an array of tiddler fields objects\n*/\nexports.readFileContent = function(file,type,isBinary,deserializer,callback) {\n\tvar self = this;\n\t// Create the FileReader\n\tvar reader = new FileReader();\n\t// Onload\n\treader.onload = function(event) {\n\t\tvar text = event.target.result,\n\t\t\ttiddlerFields = {title: file.name || \"Untitled\", type: type};\n\t\tif(isBinary) {\n\t\t\tvar commaPos = text.indexOf(\",\");\n\t\t\tif(commaPos !== -1) {\n\t\t\t\ttext = text.substr(commaPos + 1);\n\t\t\t}\n\t\t}\n\t\t// Check whether this is an encrypted TiddlyWiki file\n\t\tvar encryptedJson = $tw.utils.extractEncryptedStoreArea(text);\n\t\tif(encryptedJson) {\n\t\t\t// If so, attempt to decrypt it with the current password\n\t\t\t$tw.utils.decryptStoreAreaInteractive(encryptedJson,function(tiddlers) {\n\t\t\t\tcallback(tiddlers);\n\t\t\t});\n\t\t} else {\n\t\t\t// Otherwise, just try to deserialise any tiddlers in the file\n\t\t\tcallback(self.deserializeTiddlers(type,text,tiddlerFields,{deserializer: deserializer}));\n\t\t}\n\t};\n\t// Kick off the read\n\tif(isBinary) {\n\t\treader.readAsDataURL(file);\n\t} else {\n\t\treader.readAsText(file);\n\t}\n};\n\n/*\nFind any existing draft of a specified tiddler\n*/\nexports.findDraft = function(targetTitle) {\n\tvar draftTitle = undefined;\n\tthis.forEachTiddler({includeSystem: true},function(title,tiddler) {\n\t\tif(tiddler.fields[\"draft.title\"] && tiddler.fields[\"draft.of\"] === targetTitle) {\n\t\t\tdraftTitle = title;\n\t\t}\n\t});\n\treturn draftTitle;\n}\n\n/*\nCheck whether the specified draft tiddler has been modified.\nIf the original tiddler doesn't exist, create a vanilla tiddler variable,\nto check if additional fields have been added.\n*/\nexports.isDraftModified = function(title) {\n\tvar tiddler = this.getTiddler(title);\n\tif(!tiddler.isDraft()) {\n\t\treturn false;\n\t}\n\tvar ignoredFields = [\"created\", \"modified\", \"title\", \"draft.title\", \"draft.of\"],\n\t\torigTiddler = this.getTiddler(tiddler.fields[\"draft.of\"]) || new $tw.Tiddler({text:\"\", tags:[]}),\n\t\ttitleModified = tiddler.fields[\"draft.title\"] !== tiddler.fields[\"draft.of\"];\n\treturn titleModified || !tiddler.isEqual(origTiddler,ignoredFields);\n};\n\n/*\nAdd a new record to the top of the history stack\ntitle: a title string or an array of title strings\nfromPageRect: page coordinates of the origin of the navigation\nhistoryTitle: title of history tiddler (defaults to $:/HistoryList)\n*/\nexports.addToHistory = function(title,fromPageRect,historyTitle) {\n\tvar story = new $tw.Story({wiki: this, historyTitle: historyTitle});\n\tstory.addToHistory(title,fromPageRect);\n};\n\n/*\nAdd a new tiddler to the story river\ntitle: a title string or an array of title strings\nfromTitle: the title of the tiddler from which the navigation originated\nstoryTitle: title of story tiddler (defaults to $:/StoryList)\noptions: see story.js\n*/\nexports.addToStory = function(title,fromTitle,storyTitle,options) {\n\tvar story = new $tw.Story({wiki: this, storyTitle: storyTitle});\n\tstory.addToStory(title,fromTitle,options);\n};\n\n/*\nInvoke the available upgrader modules\ntitles: array of tiddler titles to be processed\ntiddlers: hashmap by title of tiddler fields of pending import tiddlers. These can be modified by the upgraders. An entry with no fields indicates a tiddler that was pending import has been suppressed. When entries are added to the pending import the tiddlers hashmap may have entries that are not present in the titles array\nReturns a hashmap of messages keyed by tiddler title.\n*/\nexports.invokeUpgraders = function(titles,tiddlers) {\n\t// Collect up the available upgrader modules\n\tvar self = this;\n\tif(!this.upgraderModules) {\n\t\tthis.upgraderModules = [];\n\t\t$tw.modules.forEachModuleOfType(\"upgrader\",function(title,module) {\n\t\t\tif(module.upgrade) {\n\t\t\t\tself.upgraderModules.push(module);\n\t\t\t}\n\t\t});\n\t}\n\t// Invoke each upgrader in turn\n\tvar messages = {};\n\tfor(var t=0; t<this.upgraderModules.length; t++) {\n\t\tvar upgrader = this.upgraderModules[t],\n\t\t\tupgraderMessages = upgrader.upgrade(this,titles,tiddlers);\n\t\t$tw.utils.extend(messages,upgraderMessages);\n\t}\n\treturn messages;\n};\n\n})();\n\n",
"type": "application/javascript",
"module-type": "wikimethod"
}
}
}
{
"tiddlers": {
"$:/plugins/bimlas/locator/README/README": {
"title": "$:/plugins/bimlas/locator/README/README",
"tags": "",
"type": "text/vnd.tiddlywiki",
"text": "! Locator\n\nFor those who use many tags or store many different topics in a common wiki the Locator plugin is ''a table of contents widget and an enhanced search engine'' that gives you the opportunity to ''filter results by related tags''. Unlike [[table of contents|https://tiddlywiki.com/#Table-of-Contents%20Macros%20(Examples)]], [[standard search|$:/core/ui/AdvancedSearch/Standard]] and [[list of tags|$:/core/ui/MoreSideBar/Tags]], this plugin offers these features in an organic, collaborative way.\n\n* https://gitlab.com/bimlas/tw5-locator (main repository)\n* https://github.com/bimlas/tw5-locator (mirror)\n\n! Benefits compared to built-in solutions\n\n* ''Shows related tags''<br/>You can mark a tiddler with multiple tags, but in the ToC you don't see them while browsing.\n* ''Phone friendlier''<br/>The width of the ToC is increasing and the size of the text is decrasing as we move down in the context, while Locator remains the same.\n* ''There is no need to include a table of contents in the main tiddler of each topic''<br/>Just press the \"locator sidebar\" button and you can browse the topic right away.\n* ''Easy way to search for tags''<br/>Find tags based on part of their name and find related tags by typing in to the standard search.\n* ''Limit the scope of search''<br/>You don't have to store your recipes and family tree in a separate wiki just to make them easier to find: you can easily define the scope of your search.\n\n@@.bimlas-locator-warning\n! REQUIREMENT: Some features need the `kin` filter operator (planned to TiddlyWiki v5.1.20)\n@@\n\nWhile this pull request is not merged and the filter is not available in the standard TiddlyWiki, ''you can't use the marked features of the plugin''. See https://github.com/Jermolene/TiddlyWiki5/pull/3511 for details.\n\nIf you can't wait for this to happen and you want to try all of the features in your wiki, ''you can install the [[demo version of the filter|https://bimlas.gitlab.io/tw5-kin-demo/]], but do it only in a testing environment''.\n"
},
"$:/plugins/bimlas/locator/README/TIPS": {
"title": "$:/plugins/bimlas/locator/README/TIPS",
"tags": "",
"type": "text/vnd.tiddlywiki",
"text": "! Tips\n\n!! Organic navigation\n\n* In `locator-tags`, look for a tag and apply it as an ancestor tag; the `locator-search` only affects tiddlers associated with it at any depth\n* Click on the tag in `locator-tags` to open its tiddler, then click on the \"locator sidebar\" button; the `locator-view` sidebar will show it's hierarchy\n* Navigate in the hierarchy of `locator-view` sidebar then search for a term in `locator-search`; pressing the \"copy context\" button restricting the search to the context of `locator-view` sidebar\n\n!! Speed up (on phones)\n\n!!! Conditional view\n\nBecause ''the plugin could be slow'' (depending on the context) and since we don't look at the table of contents and search results at the same time, we can ''hide the Locator while we are using the standard search''.\n\nTo achieve this, place the Locator view in the following condition:\n\n```\n<$reveal type=\"match\" default=\"\" text={{{ [prefix[$:/state/popup/search-dropdown]] }}}>\n<<locator-view \"TableOfContents\">>\n</$reveal>\n```\n\n''When you open TiddlyWiki'', the search entry is in focus by default, so ''the Locator sidebar is not visible''. To fix this, change the text of [[$:/config/Search/AutoFocus]] [[hidden setting|https://tiddlywiki.com/#Hidden%20Setting%3A%20Search%20AutoFocus]] to `false`.\n\n!!! Prefer the standard search\n\n''Typing in the search entry could be slow'' because of the slowness of the plugin. In this case, ''switch to the classic search listing'', enter the expression, and then return to the Locator search.\n"
},
"$:/plugins/bimlas/locator/README/search": {
"title": "$:/plugins/bimlas/locator/README/search",
"tags": "",
"type": "text/vnd.tiddlywiki",
"text": "! Usage of `locator-search` (customised search results)\n\n@@.bimlas-locator-warning\nRequires the `kin` filter operator!\n@@\n\nThe macro can be used to ''search only in the context defined by `locator-view` or `locator-tags`''.\n\n* Add a `locator-view` to the sidebar as described above\n* Create a new tiddler\n* Add the [[$:/tags/SearchResults]] tag\n* Add the `caption` field to change the title of the tab\n* Place this code in tiddler:\n\n```\n<<locator-search>>\n```\n\n@@.bimlas-locator-explanation\nIf you type something in the standard search, you can see the newly created tiddler as a new tab in the search results. Use the {{$:/core/images/close-others-button}} button to ''restrict the search to the context of the Locator sidebar'' by copying its breadcrumbs. Adding additional tags is possible in `locator-tags`.\n@@\n"
},
"$:/plugins/bimlas/locator/README/tags": {
"title": "$:/plugins/bimlas/locator/README/tags",
"tags": "",
"type": "text/vnd.tiddlywiki",
"text": "! Usage of `locator-tags` (customised search results for tags)\n\n@@.bimlas-locator-warning\nRequires the `kin` filter operator!\n@@\n\nTake the same steps you did for `locator-search`, but use this code:\n\n```\n<<locator-tags>>\n```\n\n''Search for tags instead of tiddler titles'', the list of tags is structured as follows:\n\n<div class=\"tc-tiddler-frame bimlas-locator-explanation\">\n{{$:/core/images/close-others-button}} {{$:/core/images/refresh-button}}<br/>\n<<tag-pill \"Breadcrumb tag pills\">><br/>\n<hr/>\n//Title matches//<br/>\n{{$:/core/images/link}} {{$:/core/images/tag-button}} <<tag-pill \"Tags with matching titles\">><br/>\n//Related tags//<br/>\n{{$:/core/images/link}} {{$:/core/images/tag-button}} <<tag-pill \"Tags of search results...\">><br/>\n{{$:/core/images/link}} {{$:/core/images/tag-button}} <<tag-pill \"...expect breadcrumbs...\">><br/>\n{{$:/core/images/link}} {{$:/core/images/tag-button}} <<tag-pill \"...and listed titles\">><br/>\n</div>\n\n@@.bimlas-locator-explanation\n* {{$:/core/images/close-others-button}}: Restrict the search to the context of the Locator sidebar by copying its breadcrumbs\n* {{$:/core/images/link}}: Look for the search term under this tag at any depth (this ancestor tag is broadly defining the topic of the search)\n* {{$:/core/images/tag-button}}: Look for the search term in tiddlers directly tagged by this tag (direct tag)\n@@\n\nThe picked tags using to ''narrow the scope of `locator-search`'', clicking on the title of the tag opens its tiddler.\n"
},
"$:/plugins/bimlas/locator/README/view": {
"title": "$:/plugins/bimlas/locator/README/view",
"tags": "",
"type": "text/vnd.tiddlywiki",
"text": "! Usage of `locator-view` (table of contents)\n\nUse the following macro to ''display a table of contents of a topic'' (the first parameter is the top tag of the hierarchy):\n\n```\n<<locator-view \"TableOfContents\">>\n```\n\nYou can use it in any tiddler, for example put it in the main tiddler of each topic in your wiki.\n\nThe table of contents is structured as follows:\n\n<div class=\"tc-tiddler-frame bimlas-locator-explanation\">\n{{$:/core/images/refresh-button}}<br/>\n<<tag-pill \"Breadcrumb tag pills\">><br/>\n<<tag-pill \"(The current context)\">><br/>\n<hr/>\n{{$:/core/images/tag-button}} <<tag-pill \"Direct tags\">><br/>\n{{$:/core/images/tag-button}} <<tag-pill \"(Tags of listed titles...)\">><br/>\n{{$:/core/images/tag-button}} <<tag-pill \"(...expect breadcrumbs...)\">><br/>\n{{$:/core/images/tag-button}} <<tag-pill \"(...and listed titles)\">><br/>\n{{$:/core/images/blank}} Title without button<br/>\n{{$:/core/images/blank}} (Normal list item)<br/>\n{{$:/core/images/right-arrow}} Title with button (ancestor tag)<br/>\n{{$:/core/images/right-arrow}} (Parent of other titles)<br/>\n</div>\n\n@@.bimlas-locator-explanation\n* {{$:/core/images/right-arrow}}: Move down in the context\n* {{$:/core/images/tag-button}}: Filter the list by the tag\n* {{$:/core/images/refresh-button}}: Reset the context by removing the breadcrumbs\n* <<tag-pill \"Breadcrumb tag pill\">>: Jump back to that context\n* Click on list items to open the tiddler (also works on tags)\n@@\n\n!! Pass additional filter\n\nYou can also ''pass a filter parameter to modify the list of items''. For example, ''filter items that can be found deeper in the hierarchy (remove duplicate entries)'' with the `filter-grandchildren` predefined filter expression.\n\n@@.bimlas-locator-warning\nThe `filter-grandchildren` requires the `kin` filter operator, besides this it could be slow!\n@@\n\n```\n<<locator-view \"TableOfContents\" \"+[!subfilter<filter-grandchildren>]\">>\n```\n\nIn another example, we sort them according to the last modification in reverse order.\n\n```\n<<locator-view \"TableOfContents\" \"+[sort[modified]reverse[]]\">>\n```\n\n!! Add to sidebar\n\n* Create a new tiddler\n* Add the [[$:/tags/SideBar]] tag\n* Add the `caption` field to change the title of the tab\n* Place the `locator-view` macro call in it as described above\n\n!! Open any tag in the sidebar\n\n@@.bimlas-locator-explanation\nThere is ''a new button in the toolbar of the tiddlers that are tags'': by pressing the \"{{$:/core/images/chevron-right}} locator sidebar\" button, you can ''display the current tiddler's hierarchy in the Locator sidebar''.\n@@\n\nIf you do not want to leave this button in the toolbar, you can turn it off in the [[$:/ControlPanel]] -> Apperance -> Toolbars -> [[View Toolbar|$:/core/ui/ControlPanel/Toolbars/ViewToolbar]].\n"
},
"$:/plugins/bimlas/locator/macros": {
"title": "$:/plugins/bimlas/locator/macros",
"tags": "",
"type": "text/vnd.tiddlywiki",
"text": "\\define filter-breadcrumbs() [title<contextState>each:list-item[breadcrumbs]]\n\\define filter-ancestor-tags() [title<contextState>each:list-item[ancestor-tags]]\n\\define filter-grandchildren() [subfilter<filter-ancestor-tags>last[]tagging[]tagging[]kin::to[]]\n\\define wikify-filter-search-context()\n <$list filter=<<filter-ancestor-tags>>><$text text=\"kin::to[\"/><$view field=\"title\"/><$text text=\"]\"/></$list><$list filter=\"[subfilter<filter-breadcrumbs>] -[subfilter<filter-ancestor-tags>]\"><$text text=\"tag[\"/><$view field=\"title\"/><$text text=\"]\"/></$list>\n\\end\n\\define wikify-list-redunant-direct-tags()\n\n <$set name=\"lastAncestorTag\" value={{{ [subfilter<filter-ancestor-tags>last[]] }}}>\n <$reveal type=\"nomatch\" default=\"\" text=<<lastAncestorTag>>>\n <$list filter=\"[title<baseTitle>] [title<lastAncestorTag>] [subfilter<filter-breadcrumbs>allafter<lastAncestorTag>]\">\n <$text text=\"[[\"/><$view field=\"title\"/><$text text=\"]]\"/>\n </$list>\n </$reveal>\n <$reveal type=\"match\" default=\"\" text=<<lastAncestorTag>>>\n <$list filter=\"[title<baseTitle>] [subfilter<filter-breadcrumbs>]\">\n <$text text=\"[[\"/><$view field=\"title\"/><$text text=\"]]\"/>\n </$list>\n </$reveal>\n </$set>\n\n\\end\n\\define wikify-list-context-items()\n\n <$set name=\"lastAncestorTagOrBaseTitle\" value={{{ [subfilter<filter-ancestor-tags>last[]] ~[title<baseTitle>] }}}>\n <$set name=\"baseTitleAndBreadcrumbs\" filter=\"[title<baseTitle>] [subfilter<filter-breadcrumbs>]\">\n <!-- I know this monster looks terrible, but I can't build this filter any other way. -->\n <$wikify name=\"taggedByLastAncestorAndDirectTags\" text=\"\"\"<$text text=\"[tag<lastAncestorTagOrBaseTitle>\"/><$list filter=\"[enlist<baseTitleAndBreadcrumbs>allafter<lastAncestorTagOrBaseTitle>]\">tag[<$view field=\"title\"/>]</$list><$text text=\"] \"/><$text text=<<__finalFilter__>>/>\"\"\">\n <$list filter=<<taggedByLastAncestorAndDirectTags>>>\n <$text text=\"[[\"/><$view field=\"title\"/><$text text=\"]]\"/>\n </$list>\n </$wikify>\n </$set>\n </$set>\n\n\\end\n\\define view-breadcrumbs-of-context()\n\n <$button class=\"tc-btn-invisible bimlas-locator\" actions=<<action-clear-tags>>>\n {{$:/core/images/refresh-button}}\n </$button>\n\n <$reveal type=\"nomatch\" default=\"\" text={{{ [title<contextState>get[base-title]] }}}>\n <$button class=\"tc-btn-invisible bimlas-locator\">\n <$action-listops $tiddler=<<contextState>> $field=\"base-title\" $filter=\"[[]]\"/>\n <<action-clear-tags>>\n {{$:/core/images/close-button}}\n </$button>\n <$link to=<<baseTitle>>><$view tiddler=<<baseTitle>> field=\"caption\"><$view tiddler=<<baseTitle>> field=\"title\"/></$view></$link>\n </$reveal>\n\n <$list filter=<<filter-breadcrumbs>>>\n\n <$button class=\"tc-btn-invisible bimlas-locator\" actions=<<action-click-on-breadcrumb>>>\n <$reveal type=\"nomatch\" default=\"\" text={{{ [all[current]!subfilter<filter-ancestor-tags>] }}}>\n {{$:/core/images/tag-button}}\n </$reveal>\n <$macrocall $name=\"tag-pill\" tag={{{ [all[current]get[caption]] [all[current]] }}}/>\n </$button>\n\n </$list>\n\n\\end\n\\define view-search-specific-actions()\n <$button class=\"tc-btn-invisible bimlas-locator\">\n <!--\n Copy the breadcrumbs from the Locator sidebar; interpret each tag as an\n ancestor tag, otherwise there would be no results for too many direct tags.\n -->\n <$action-listops $tiddler=<<contextState>> $field=\"breadcrumbs\" $filter=\"[enlist{$:/state/bimlas/locator!!base-title}] [enlist{$:/state/bimlas/locator!!breadcrumbs}]\"/>\n <$action-listops $tiddler=<<contextState>> $field=\"ancestor-tags\" $filter=\"[enlist{$:/state/bimlas/locator!!base-title}] [enlist{$:/state/bimlas/locator!!breadcrumbs}]\"/>\n {{$:/core/images/close-others-button}}\n </$button>\n\\end\n\\define view-tag-list-item(actions)\n <p class=\"tc-menu-list-item\">\n <$button class=\"tc-btn-invisible bimlas-locator\" actions=<<__actions__>>>\n {{$:/core/images/tag-button}}\n </$button>\n <$button class=\"tc-btn-invisible bimlas-locator\">\n <$action-navigate $to=<<currentTiddler>>/>\n <$macrocall $name=\"tag-pill\" tag={{{ [all[current]get[caption]] [all[current]] }}}/>\n </$button>\n </p>\n\\end\n\\define view-locator-tags-list-item()\n <p class=\"tc-menu-list-item bimlas-locator\">\n <$button class=\"tc-btn-invisible bimlas-locator\" actions=<<action-add-ancestor-tag>>>\n {{$:/core/images/link}}\n </$button>\n <$button class=\"tc-btn-invisible bimlas-locator\" actions=<<action-add-direct-tag>>>\n {{$:/core/images/tag-button}}\n </$button>\n <$button class=\"tc-btn-invisible bimlas-locator\">\n <$action-navigate $to=<<currentTiddler>>/>\n <$macrocall $name=\"tag-pill\"tag={{{ [all[current]get[caption]] [all[current]] }}}/>\n </$button>\n </p>\n\\end\n\\define action-add-ancestor-tag()\n\n <$action-listops $tiddler=<<contextState>> $field=\"breadcrumbs\" $subfilter=\"[all[current]]\"/>\n <$action-listops $tiddler=<<contextState>> $field=\"ancestor-tags\" $subfilter=\"[all[current]]\"/>\n\n\\end\n\\define action-add-direct-tag()\n\n <$action-listops $tiddler=<<contextState>> $field=\"breadcrumbs\" $subfilter=\"[all[current]]\"/>\n\n\\end\n\\define action-click-on-breadcrumb()\n\n <$set name=\"breadcrumbsUntilCurrent\" filter=\"[subfilter<filter-breadcrumbs>allbefore<currentTiddler>] [all[current]]\">\n <$action-listops $tiddler=<<contextState>> $field=\"ancestor-tags\" $subfilter=\"-[!enlist<breadcrumbsUntilCurrent>]\"/>\n <$action-listops $tiddler=<<contextState>> $field=\"breadcrumbs\" $filter=<<breadcrumbsUntilCurrent>>/>\n </$set>\n\n\\end\n\\define action-clear-tags()\n\n <$action-listops $tiddler=<<contextState>> $field=\"breadcrumbs\" $filter=\"[[]]\"/>\n <$action-listops $tiddler=<<contextState>> $field=\"ancestor-tags\" $filter=\"[[]]\"/>\n\n\\end\n"
},
"$:/plugins/bimlas/locator/search": {
"title": "$:/plugins/bimlas/locator/search",
"tags": "$:/tags/Macro",
"type": "text/vnd.tiddlywiki",
"text": "\\define locator-search(locatorViewTiddler: \"\")\n <!-- Hide internal macros, do not make them globally available -->\n <$importvariables filter=\"[[$:/plugins/bimlas/locator/macros]]\">\n <$set name=\"contextState\" value=\"$:/state/bimlas/locator-search\">\n <$wikify name=\"searchContextFilter\" text=<<wikify-filter-search-context>>>\n\n <<view-search-specific-actions>> <<view-breadcrumbs-of-context>>\n\n //<small>{{$:/language/Search/Matches/Title}}</small>//\n\n <$wikify name=\"filter\" text=\"\"\"<$text text=\"[!is[system]\"/><<searchContextFilter>><$text text=\"search:title{$(searchTiddler)$}sort[title]limit[250]]\"/>\"\"\">\n <$list filter=<<filter>> template=\"$:/core/ui/ListItemTemplate\"/>\n </$wikify>\n\n //<small>{{$:/language/Search/Matches/All}}</small>//\n\n <$wikify name=\"filter\" text=\"\"\"<$text text=\"[!is[system]\"/><<searchContextFilter>><$text text=\"search{$(searchTiddler)$}sort[title]limit[250]]\"/>\"\"\">\n <$list filter=<<filter>> template=\"$:/core/ui/ListItemTemplate\"/>\n </$wikify>\n\n </$wikify>\n </$set>\n </$importvariables>\n\\end\n"
},
"$:/plugins/bimlas/locator/stylesheet": {
"title": "$:/plugins/bimlas/locator/stylesheet",
"tags": "$:/tags/Stylesheet",
"type": "text/vnd.tiddlywiki",
"text": ".bimlas-locator-warning {\n color: red;\n font-weight: bold;\n}\n.tc-tiddler-frame.bimlas-locator-explanation {\n max-width: 400px;\n}\n.bimlas-locator-explanation svg {\n width: 1rem;\n height: 1rem;\n}\n.tc-drop-down button.bimlas-locator {\n width: auto;\n padding: 0;\n display: inline-block;\n background-color: inherit;\n}\n.tc-drop-down p.tc-menu-list-item.bimlas-locator {\n margin-top: 0;\n margin-bottom: 0;\n}\n"
},
"$:/plugins/bimlas/locator/tags": {
"title": "$:/plugins/bimlas/locator/tags",
"tags": "$:/tags/Macro",
"type": "text/vnd.tiddlywiki",
"text": "\\define locator-tags(locatorViewTiddler: \"\")\n <!-- Hide internal macros, do not make them globally available -->\n <$importvariables filter=\"[[$:/plugins/bimlas/locator/macros]]\">\n <$set name=\"contextState\" value=\"$:/state/bimlas/locator-search\">\n <$set name=\"redunantDirectTags\" value=\"[title<contextState>each:list-item[breadcrumbs]]\">\n <$wikify name=\"searchContextFilter\" text=<<wikify-filter-search-context>>>\n\n <<view-search-specific-actions>> <<view-breadcrumbs-of-context>>\n\n //<small>{{$:/language/Search/Matches/Title}}</small>//\n\n <$wikify name=\"filter\" text=\"\"\"<$text text=\"[!is[system]\"/><<searchContextFilter>><$text text=\"tags[]!subfilter<redunantDirectTags>search:title{$(searchTiddler)$}sort[title]limit[250]]\"/>\"\"\">\n <$list filter=<<filter>>>\n <<view-locator-tags-list-item>>\n </$list>\n </$wikify>\n\n //<small>Related tags</small>//\n\n <$wikify name=\"filter\" text=\"\"\"<$text text=\"[!is[system]\"/><<searchContextFilter>><$text text=\"search{$(searchTiddler)$}tags[]!subfilter<redunantDirectTags>] -[!is[system]\"/><<searchContextFilter>><$text text=\"search{$(searchTiddler)$}] +[sort[title]limit[250]]\"/>\"\"\">\n <$list filter=<<filter>>>\n <<view-locator-tags-list-item>>\n </$list>\n </$wikify>\n\n </$wikify>\n </$set>\n </$set>\n </$importvariables>\n\\end\n"
},
"$:/plugins/bimlas/locator/view": {
"title": "$:/plugins/bimlas/locator/view",
"tags": "$:/tags/Macro",
"type": "text/vnd.tiddlywiki",
"text": "\\define locator-view(baseTitle finalFilter=\"\")\n <!-- Hide internal macros, do not make them globally available -->\n <$importvariables filter=\"[[$:/plugins/bimlas/locator/macros]]\">\n <!-- If `currentTiddler` is empty (in the sidebar for example), then do not add trailing `/` -->\n <$wikify name=\"contextState\" text=\"\"\"<$text text=\"$:/state/bimlas/locator\"/><$list filter=\"[all[current]] -[[]] +[addprefix[/]]\"><$view field=\"title\"/></$list>\"\"\">\n <$set name=\"baseTitle\" value={{{ [title<contextState>each:list-item[base-title]] ~[title<__baseTitle__>] }}}>\n <$set name=\"finalFilter\" value=<<__finalFilter__>>>\n\n <<view-breadcrumbs-of-context>>\n\n ---\n\n <$wikify name=\"contextItems\" text=<<wikify-list-context-items>>>\n <div class=\"tc-table-of-contents\">\n <ol>\n\n <$wikify name=\"redunantDirectTags\" text=<<wikify-list-redunant-direct-tags>>>\n <$list filter=\"[enlist<contextItems>tags[]!enlist<contextItems>!enlist<redunantDirectTags>sort[title]]\">\n <li class=\"toc-item\">\n\n <$macrocall $name=\"view-tag-list-item\" actions=<<action-add-direct-tag>>/>\n\n </li>\n </$list>\n </$wikify>\n\n <$list filter=<<contextItems>>>\n <li class=\"toc-item\">\n\n <$reveal type=\"nomatch\" default=\"\" text={{{ [all[current]is[tag]] }}}>\n <$button class=\"tc-btn-invisible bimlas-locator\" actions=<<action-add-ancestor-tag>>>\n {{$:/core/images/right-arrow}}\n </$button>\n </$reveal>\n <$reveal type=\"match\" default=\"\" text={{{ [all[current]is[tag]] }}}>\n <$button class=\"tc-btn-invisible bimlas-locator\" to=<<currentTiddler>>>\n {{$:/core/images/blank}}\n </$button>\n </$reveal>\n <$link to=<<currentTiddler>>><$view field=\"caption\"><$view field=\"title\"/></$view></$link>\n\n </li>\n </$list>\n\n </ol>\n </div>\n </$wikify>\n\n </$set>\n </$set>\n </$wikify>\n </$importvariables>\n\\end\n"
},
"$:/plugins/bimlas/locator/viewtoolbar/open-in-sidebar": {
"title": "$:/plugins/bimlas/locator/viewtoolbar/open-in-sidebar",
"tags": "$:/tags/ViewToolbar",
"type": "text/vnd.tiddlywiki",
"caption": "{{$:/core/images/chevron-right}} locator sidebar",
"description": "Browse hierarchy of tag in Locator sidebar",
"list-before": "$:/core/ui/Buttons/open-window",
"text": "\\whitespace trim\n<$reveal type=\"nomatch\" default=\"\" text={{{ [all[current]is[tag]] }}}>\n<$button tooltip=\"Browse hierarchy of tag in Locator sidebar\" aria-label=\"locator sidebar\" class=<<tv-config-toolbar-class>>>\n<$action-listops $tiddler=\"$:/state/bimlas/locator\" $field=\"base-title\" $filter=\"[all[current]]\"/>\n<$action-listops $tiddler=\"$:/state/bimlas/locator\" $field=\"breadcrumbs\" $filter=[[]]/>\n<$action-listops $tiddler=\"$:/state/bimlas/locator\" $field=\"ancestor-tags\" $filter=[[]]/>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\" variable=\"listItem\">\n{{$:/core/images/chevron-right}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\">\n<$text text=\" \"/>\n<$text text=\"locator sidebar\"/>\n</span>\n</$list>\n</$button>\n</$reveal>\n"
}
}
}
{
"tiddlers": {
"$:/plugins/btheado/ftlist/main": {
"title": "$:/plugins/btheado/ftlist/main",
"created": "20181121183433937",
"modified": "20181121183748645",
"tags": "",
"text": "{{||$:/plugins/btheado/ftlist/tagbar}}\n\n---\n\n{{||$:/plugins/btheado/ftlist/tagged-list}}"
},
"$:/plugins/btheado/ftlist/readme": {
"title": "$:/plugins/btheado/ftlist/readme",
"created": "20181120004009252",
"creator": "0.0.0.0",
"modified": "20181120014059849",
"modifier": "0.0.0.0",
"type": "text/vnd.tiddlywiki",
"text": "!Overview\nThe `ftlist` plugin provides a way to quickly create `f`ragments of `t`ext and manage them as items in a `list`. The emphasis is on providing a low-friction way to capture thoughts and ideas.\n\nThe list items are stored as tiddler titles and can be used just like any other ~TiddlyWiki tiddlers.\n\nThe supported list operations are intentionally very few:\n\n# Add an item to the top of the list\n# Move an item to the top of the list\n# Remove an item from the list\n\nOften the most recent entered items are the ones of the most interest. Any items which are still of interest and sink too far down the list can be re-sent to the top. Items which are not of interest will continue to sink out of sight, only to be seen during times of occasional list review.\n\nIn addition to the list operations, ftlist provides a `tagbar` for easily applying tags to the list items via drag and drop. New tags can be added to the `tagbar` via drag and drop and then list items (any tiddly links) can be dropped onto these tags in order to apply them.\n\nMultiple lists are supported. The list functionality is implemented as a ~TiddlyWiki [[template|https://tiddlywiki.com/#TemplateTiddlers]]. Transcluding that template into any tiddler will make that tiddler into a container for a new list.\n\n! Getting started\nInstall the plugin by draggin this [[ftlist plugin|$:/plugins/btheado/ftlist]] link into your own tiddlywiki instance. Then create a tiddler in which you want to have your list (). Add this text somewhere in the body of the tiddler:\n\n```\n{{||$:/plugins/btheado/ftlist/main}}\n```\n\nThen start creating and organizing your list!\n\nThe list functionality can be used without the tagbar like this:\n\n```\n{{||$:/plugins/btheado/ftlist/tagged-list}}\n```\n\nThe tagbar can be used independent of the list like this:\n\n```\n{{||$:/plugins/btheado/ftlist/tagbar}}\n```\n\n!Under the covers\n\n*list items are stored as tiddler titles\n*the items in a given list are those which are tagged with the tiddler containing the list\n*the order of the items is determined by the [[standard Tiddlywiki ordering for tags|https://tiddlywiki.com/#Order%20of%20Tagged%20Tiddlers]], except that the reverse of that order is used.\n*this means that tags applied through normal tiddlywiki tagging mechanism can also be used to add items to the list.\n*when items are marked 'done', the tag which keeps it in the list is removed and a timestamp is appended to a field named `ftlist_done`.\n*as a future feature enhancement, this ftlist_done field can be used for a per-day timeline of done items similar to the standard ~TiddlyWiki timeline\n"
},
"$:/plugins/btheado/ftlist/tagbar": {
"title": "$:/plugins/btheado/ftlist/tagbar",
"created": "20181121000858641",
"modified": "20181121001447371",
"tags": "",
"text": "\\define droppable-tag-actions()\n<$action-listops $tiddler=<<actionTiddler>> $field=tags $subfilter='[title<currentTiddler>]'/>\n\\end\n\nDrag links here to apply the tag. Tag with \"tagbar\" to add new tags to the bar.\n\n<$list filter=\"[all[current]addsuffix[/tagbar]]\" variable=tagbar>\n <$tiddler tiddler=<<tagbar>>>\n <$droppable actions=<<droppable-tag-actions>>>\n <$macrocall $name=tag tag=<<currentTiddler>>/>\n </$droppable>\n </$tiddler>\n <$list filter=\"[tag<tagbar>]\">\n <$droppable actions=<<droppable-tag-actions>>>\n <$fieldmangler>\n <$button message=\"tm-remove-tag\" param=<<tagbar>> class=\"tc-btn-invisible tc-btn-mini\">×</$button>\n </$fieldmangler>\n <$macrocall $name=tag tag=<<currentTiddler>>/>\n </$droppable>\n </$list>\n</$list>"
},
"$:/plugins/btheado/ftlist/tagged-list-item": {
"title": "$:/plugins/btheado/ftlist/tagged-list-item",
"created": "20180429151224584",
"modified": "20181121183027232",
"tags": "",
"text": "\\define markDoneActions()\n <!-- Using this approach as found in the \"new journal\" button code. It allows for the\n timestamp to be calculated at the time the button is pressed rather than the time\n the button is rendered -->\n <$wikify name=timestamp text=\"\"\"<$macrocall $name=\"now\" format=\"[UTC]YYYY0MM0DD0hh0mm0ssXXX\"/>\"\"\">\n <!-- Remove from list, remove the tag, and add a timestamp to ftlist_done field -->\n <$action-listops $tiddler=<<currentListTiddler>> $subfilter=\"-[<currentTiddler>]\"/>\n <$action-listops $tiddler=<<currentTiddler>> $tags=\"-[<currentListTiddler>]\"/>\n <$action-listops $tiddler=<<currentTiddler>> $field=ftlist_done $subfilter=\"[<timestamp>]\"/>\n </$wikify>\n\\end\n\\define displayListItem()\n <div style=\"margin-left: 15px; white-space: normal; display: flex;\">\n <!-- \n Two side-by-side, flex-arranged divs. The one on the left with the icons will grow\n so there is no wrapping. The one on the right will have wrapping if too long to fit, but\n the text on the wrapped lines will line up with each other (rather than wrap around\n under the icons).\n -->\n <div style=\"flex-shrink: 0;\">\n <$button\n tooltip=\"move to top\"\n aria-label=\"move to top\"\n class=\"tc-btn-invisible tc-btn-mini\">\n <$action-listops $tiddler=<<currentListTiddler>> $subfilter=\"[<currentTiddler>]\"/>\n {{$:/core/images/up-arrow}}\n </$button>\n <$button\n tooltip=\"mark done and remove from list\"\n aria-label=\"mark done and remove from list\"\n class=\"tc-btn-invisible tc-btn-mini\"\n actions=<<markDoneActions>>>\n {{$:/core/images/done-button}}\n </$button>\n <$button\n message=\"tm-edit-tiddler\"\n tooltip={{$:/language/Buttons/Edit/Hint}}\n aria-label={{$:/language/Buttons/Edit/Caption}}\n class=\"tc-btn-invisible tc-btn-mini\">\n {{$:/core/images/edit-button}}\n </$button>\n\n <$reveal type=\"nomatch\" state=<<expandSublist>> text=<<currentTiddler>>>\n <$button\n set=<<expandSublist>>\n setTo=<<currentTiddler>>\n class=\"tc-btn-invisible tc-tiddlylink\"\n tooltip=\"Expand sublist\"\n aria-label=\"Expand sublist\"\n >\n {{$:/core/images/right-arrow}}\n </$button>\n </$reveal>\n <$reveal type=\"match\" state=<<expandSublist>> text=<<currentTiddler>>>\n <$button\n set=<<expandSublist>>\n setTo=\"\"\n class=\"tc-btn-invisible tc-tiddlylink\"\n tooltip=\"Expand sublist\"\n aria-label=\"Expand sublist\"\n >\n {{$:/core/images/down-arrow}}\n </$button>\n </$reveal>\n </div>\n <div>\n <$list filter=\"[all[current]!has[text]]\">\n <$link><<currentTiddler>></$link>\n </$list>\n <$list filter=\"[all[current]has[text]]\">\n <!-- Make tiddlers which have non-empty body text stand out -->\n <$link><b><<currentTiddler>></b></$link>\n </$list>\n <$reveal type=\"match\" state=<<showItemTags>> text=\"true\">\n <$list filter=\"[all[current]tags[]!title<currentListTiddler>]\">\n <$macrocall $name=tag tag=<<currentTiddler>>/>\n </$list>\n </$reveal>\n </div>\n </div>\n <$reveal type=\"match\" state=<<expandSublist>> text=<<currentTiddler>>>\n <div style=\"margin-left: 30px; white-space: normal;\">\n {{||$:/plugins/btheado/ftlist/tagged-list}}\n </div>\n </$reveal>\n\\end\n\n<$list filter=\"[all[current]!has[draft.of]]\">\n <$set name=\"expandSublist\" filter=\"[title<currentListTiddler>addprefix[$:/state/]addsuffix[/expanded]]\">\n <<displayListItem>>\n </$set>\n</$list>"
},
"$:/plugins/btheado/ftlist/tagged-list": {
"title": "$:/plugins/btheado/ftlist/tagged-list",
"created": "20180430181932157",
"modified": "20181122022423015",
"tags": "",
"text": "<$set name=\"showItemTags\" filter=\"[all[current]addprefix[$:/state/]addsuffix[/showItemTags]]\">\n {{||$:/plugins/btheado/ftlist/tagged-tiddler-creator}} {{$:/plugins/btheado/ftlist/toggle-tag-display}}\n\n <$set name=\"currentListTiddler\" value=<<currentTiddler>>>\n <$list filter=\"[<currentTiddler>tagging[]reverse[]]\" emptyMessage=\"<div>No items in the list. New items entered above will be displayed here.</div>\">\n {{||$:/plugins/btheado/ftlist/tagged-list-item}}\n </$list>\n </$set>\n</$set>\n"
},
"$:/plugins/btheado/ftlist/tagged-tiddler-creator": {
"title": "$:/plugins/btheado/ftlist/tagged-tiddler-creator",
"created": "20181121003752734",
"modified": "20181121185739954",
"tags": "",
"text": "<$set name=tempTiddler filter=\"[all[current]addprefix[$:/temp/]addsuffix[/newitem]]\">\n <$keyboard key=enter actions=\"\"\"\n <!-- Save the current ordering of the tiddlers with this tag -->\n <$list variable=actionTiddler filter=\"[<tempTiddler>get[draft.of]]\">\n <$set name=\"tag\" value=<<currentTiddler>>>\n <$set name=\"order\" filter=\"[<tag>tagging[]!title<actionTiddler>] [title<actionTiddler>]\">\n <!-- Assign the list field of the tag with the current ordering -->\n <$action-setfield $tiddler=<<tag>> $field=\"list\" $value=<<order>>/>\n <!-- Make sure the newly added item has the right tag -->\n <$action-listops $tiddler=<<actionTiddler>> $tags=\"[<tag>]\"/>\n </$set>\n </$set>\n </$list>\n <$action-setfield $tiddler=<<tempTiddler>> draft.of=\"\"/>\n <$action-sendmessage $message=\"tm-auto-save-wiki\"/>\n \"\"\">\n <!-- Using field=draft.of is crucial here. Without it there will be lag while typing -->\n <$edit-text tiddler=<<tempTiddler>> placeholder=\"new list item title\" field=\"draft.of\" tag=\"input\" type=\"text\" size=\"50\" focus=\"true\"/>\n </$keyboard>\n</$set>"
},
"$:/plugins/btheado/ftlist/toggle-tag-display": {
"title": "$:/plugins/btheado/ftlist/toggle-tag-display",
"created": "20181122021958782",
"modified": "20181122022134701",
"tags": "",
"text": "<$reveal type=\"match\" state=<<showItemTags>> text=\"true\">\n <$button\n set=<<showItemTags>>\n setTo=\"false\"\n class=\"tc-btn-invisible tc-tiddlylink\"\n tooltip=\"Hide tags for each item in the list\"\n aria-label=\"Hide tags for each item in the list\"\n >\n hide tags\n </$button>\n</$reveal>\n<$reveal type=\"nomatch\" state=<<showItemTags>> text=\"true\">\n <$button\n set=<<showItemTags>>\n setTo=\"true\"\n class=\"tc-btn-invisible tc-tiddlylink\"\n tooltip=\"Show tags for each item in the list\"\n aria-label=\"Show tags for each item in the list\"\n >\n show tags\n </$button>\n</$reveal>"
}
}
}
{
"tiddlers": {
"$:/plugins/BurningTree/hammerwidgets/widgets/swipe.js": {
"text": "/*\\\ntitle: $:/plugins/tiddlywiki/hammerjs/widgets/swipe.js\ntype: application/javascript\nmodule-type: widget\n\nactions triggered on swipe gestures\n\n\\*/\n(function (global) {\n\n\"use strict\";\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nif (typeof window !== 'undefined') {\n\tvar Hammer = require(\"$:/plugins/tiddlywiki/hammerjs/hammer.js\");\n}\n\nvar SwipeWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nSwipeWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nSwipeWidget.prototype.render = function(parent,nextSibling) {\n\tvar self = this;\n\tvar parentDomNode = parent;\n \n\t// Compute attributes and execute state\n\tthis.computeAttributes();\n\tthis.execute();\n\n\tvar swipeDomNode = this.document.createElement(this.swipeTag);\n\tswipeDomNode.setAttribute(\"class\",this.swipeClass);\n\tparent.insertBefore(swipeDomNode,nextSibling);\n\tthis.domNodes.push(swipeDomNode);\n\tthis.renderChildren(swipeDomNode,null);\n\n\tvar hammer = new Hammer.Manager(swipeDomNode);\n\n\thammer.add(new Hammer.Swipe({\n\t\tevent: 'swipe',\n\t\tpointers: self.swipePointers,\n\t\tthreshold: self.swipeThreshold,\n\t\tvelocity: self.swipeVelocity,\n\t\tdirection: Hammer.DIRECTION_ALL\n\t}));\n\n\t// Tell Hammer it should listen for the swipe event\n\thammer.get('swipe');\n\n\thammer.on(\"swiperight\", function(e) {\n\t\te.preventDefault && e.preventDefault();\n\t\te.stopPropagation && e.stopPropagation();\n $tw.wiki.setText(\"$:/state/swiping\",\"text\",undefined,\"yes\",null);\n\n\t\tif(self.swipeRightActions !== \"\") {\n\t\t\tself.invokeActionString(self.swipeRightActions,self,e);\n\t\t}\n\t\t$tw.wiki.deleteTiddler(\"$:/state/swiping\");\n\n\t\treturn true; // Action was invoked\n\t})\n\t.on(\"swipeleft\", function(e) {\n\t\te.preventDefault && e.preventDefault();\n\t\te.stopPropagation && e.stopPropagation();\n $tw.wiki.setText(\"$:/state/swiping\",\"text\",undefined,\"yes\",null);\n\n\t\tif(self.swipeLeftActions !== \"\") {\n\t\t\tself.invokeActionString(self.swipeLeftActions,self,e);\n\t\t}\n\n\t\t$tw.wiki.deleteTiddler(\"$:/state/swiping\");\n\n\t\treturn true; // Action was invoked\n\t})\n\t.on(\"swipeup\", function(e) {\n\t\te.preventDefault && e.preventDefault();\n\t\te.stopPropagation && e.stopPropagation();\n $tw.wiki.setText(\"$:/state/swiping\",\"text\",undefined,\"yes\",null);\n\n\t\tif(self.swipeUpActions !== \"\") {\n\t\t\tself.invokeActionString(self.swipeUpActions,self,e);\n\t\t}\n\n\t\t$tw.wiki.deleteTiddler(\"$:/state/swiping\");\n\n\t\treturn true; // Action was invoked\n\t})\n\t.on(\"swipedown\", function(e) {\n\t\te.preventDefault && e.preventDefault();\n\t\te.stopPropagation && e.stopPropagation();\n $tw.wiki.setText(\"$:/state/swiping\",\"text\",undefined,\"yes\",null);\n\n\t\tif(self.swipeDownActions !== \"\") {\n\t\t\tself.invokeActionString(self.swipeDownActions,self,e);\n\t\t}\n\n\t\t$tw.wiki.deleteTiddler(\"$:/state/swiping\");\n\n\t\treturn true; // Action was invoked\n\t});\n};\n\n/*\nCompute the internal state of the widget\n*/\nSwipeWidget.prototype.execute = function() {\n\tthis.swipeClass = this.getAttribute(\"class\", \"tc-swipe-element\");\n\tthis.swipeTag = this.getAttribute(\"tag\", \"div\");\n\tthis.swipeLeftActions = this.getAttribute(\"leftactions\",\"\");\n\tthis.swipeUpActions = this.getAttribute(\"upactions\",\"\");\n\tthis.swipeRightActions = this.getAttribute(\"rightactions\",\"\");\n\tthis.swipeDownActions = this.getAttribute(\"downactions\",\"\");\n\tthis.swipeVelocity = parseFloat(this.getAttribute(\"velocity\", \"0.1\"));\n\tthis.swipePointers = parseInt(this.getAttribute(\"pointers\",\"1\"));\n\tthis.swipeThreshold = parseInt(this.getAttribute(\"threshold\",\"0\"));\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nSwipeWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(Object.keys(changedAttributes).length) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\nexports.swipe = SwipeWidget;\n})();\n",
"type": "application/javascript",
"title": "$:/plugins/BurningTree/hammerwidgets/widgets/swipe.js",
"module-type": "widget"
},
"$:/plugins/BurningTree/hammerwidgets/widgets/press.js": {
"text": "/*\\\ntitle: $:/plugins/tiddlywiki/hammerjs/widgets/press.js\ntype: application/javascript\nmodule-type: widget\n\nactions triggered on press gestures\n\n\\*/\n(function (global) {\n\n\"use strict\";\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nif (typeof window !== 'undefined') {\n\tvar Hammer = require(\"$:/plugins/tiddlywiki/hammerjs/hammer.js\");\n}\n\nvar PressWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nPressWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nPressWidget.prototype.render = function(parent,nextSibling) {\n\tvar self = this;\n\tvar parentDomNode = parent;\n\t\n\t// Compute attributes and execute state\n\tthis.computeAttributes();\n\tthis.execute();\n\n\tvar pressDomNode = this.document.createElement(this.pressTag);\n\tpressDomNode.setAttribute(\"class\",this.pressClass);\n\tparent.insertBefore(pressDomNode,nextSibling);\n\tthis.domNodes.push(pressDomNode);\n\tthis.renderChildren(pressDomNode,null);\n\n\tvar hammer = new Hammer.Manager(pressDomNode);\n\n\t// Event Listener to cancel browser popup menu on long press\n\tpressDomNode.addEventListener('contextmenu', function(e) {\n\t\te.preventDefault && e.preventDefault();\n\t\te.stopPropagation && e.stopPropagation();\n\t\te.cancelBubble = true;\n\t\te.returnValue = false;\n\t\treturn false;\n\t});\n\n\thammer.add(new Hammer.Press({\n\t\tevent: 'press',\n\t\tpointers: self.pressPointers,\n\t\tthreshold: self.pressThreshold,\n\t\ttime: self.pressTime\n\t}));\n\t\n\thammer.get('press');\n\t\n\thammer.on('press', function(e) {\n\n\t\t$tw.wiki.setText(\"$:/state/pressing\",\"text\",undefined,\"yes\",null);\n\n\t\tif(self.pressStartActions) {\n\t\t\tself.invokeActionString(self.pressStartActions,self,e);\n\t\t}\n\t\treturn true;\n\t})\n\t.on('pressup', function(e) {\n\n\t\tif(self.pressEndActions) {\n\t\t\tself.invokeActionString(self.pressEndActions,self,e);\n\t\t}\n\n\t\t$tw.wiki.deleteTiddler(\"$:/state/pressing\");\n\n\t\treturn true;\n\t});\n};\n\n/*\nCompute the internal state of the widget\n*/\nPressWidget.prototype.execute = function() {\n\tthis.pressClass = this.getAttribute(\"class\", \"tc-press-element\");\n\tthis.pressTag = this.getAttribute(\"tag\", \"div\");\n\tthis.pressPointers = parseInt(this.getAttribute(\"pointers\",\"1\"));\n\tthis.pressTime = parseInt(this.getAttribute(\"time\",\"0\"));\n\tthis.pressThreshold = parseInt(this.getAttribute(\"threshold\",\"1000\"));\n\tthis.pressStartActions = this.getAttribute(\"startactions\",\"\");\n\tthis.pressEndActions = this.getAttribute(\"endactions\",\"\");\n\tthis.pressPopup = this.getAttribute(\"popup\");\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nPressWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(Object.keys(changedAttributes).length) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\nexports.press = PressWidget;\n})();",
"type": "application/javascript",
"title": "$:/plugins/BurningTree/hammerwidgets/widgets/press.js",
"module-type": "widget"
},
"$:/plugins/BurningTree/hammerwidgets/widgets/tap.js": {
"text": "/*\\\ntitle: $:/plugins/tiddlywiki/hammerjs/widgets/tap.js\ntype: application/javascript\nmodule-type: widget\n\nactions triggered on taps&clicks\n\n\\*/\n(function (global) {\n\n\"use strict\";\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nif (typeof window !== 'undefined') {\n\tvar Hammer = require(\"$:/plugins/tiddlywiki/hammerjs/hammer.js\");\n}\n\nvar TapWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nTapWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nTapWidget.prototype.render = function(parent,nextSibling) {\n\tvar self = this;\n\tvar parentDomNode = parent;\n\n\t// Compute attributes and execute state\n\tthis.computeAttributes();\n\tthis.execute();\n\t\n\tvar tapDomNode = this.document.createElement(this.tapTag);\n\ttapDomNode.setAttribute(\"class\",this.tapClass);\n\tparent.insertBefore(tapDomNode,nextSibling);\n\tthis.domNodes.push(tapDomNode);\n\tthis.renderChildren(tapDomNode,null);\n\n\tvar hammer = new Hammer.Manager(tapDomNode);\n\n\thammer.add(new Hammer.Tap({\n\t\tevent: 'usertap',\n\t\tpointers: self.tapPointers,\n\t\ttaps: self.tapCount,\n\t\tinterval: self.tapInterval,\n\t\ttime: self.tapTime,\n\t\tthreshold: self.tapThreshold,\n\t\tposThreshold: self.tapPosThreshold\n\t}));\n\n\thammer.get('usertap');\n\n\thammer.on('usertap', function(e) {\n\t\t$tw.wiki.setText(\"$:/state/tapping\",\"text\",undefined,\"yes\",null);\n\t\tif(self.tapActions) {\n\t\t\tself.invokeActionString(self.tapActions,self,e);\n\t\t}\n\n\t\t$tw.wiki.deleteTiddler(\"$:/state/tapping\");\n\t\treturn true; // Action was invoked\n\t});\n};\n\n/*\nCompute the internal state of the widget\n*/\nTapWidget.prototype.execute = function() {\n\tthis.tapClass = this.getAttribute(\"class\", \"tc-tap-element\");\n\tthis.tapTag = this.getAttribute(\"tag\", \"div\");\n\tthis.tapCount = parseInt(this.getAttribute(\"taps\",\"1\"));\n\tthis.tapPointers = parseInt(this.getAttribute(\"pointers\",\"1\"));\n\tthis.tapThreshold = parseInt(this.getAttribute(\"threshold\",\"100\"));\n\tthis.tapPosThreshold = parseInt(this.getAttribute(\"posthreshold\",\"200\"));\n\tthis.tapTime = parseInt(this.getAttribute(\"time\",\"250\"));\n\tthis.tapInterval = parseInt(this.getAttribute(\"interval\",\"300\"));\n\tthis.tapActions = this.getAttribute(\"actions\",\"\");\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nTapWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(Object.keys(changedAttributes).length) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\nexports.tap = TapWidget;\n})();",
"type": "application/javascript",
"title": "$:/plugins/BurningTree/hammerwidgets/widgets/tap.js",
"module-type": "widget"
},
"$:/plugins/BurningTree/hammerwidgets/widgets/pan.js": {
"text": "/*\\\ntitle: $:/plugins/tiddlywiki/hammerjs/widgets/pan.js\ntype: application/javascript\nmodule-type: widget\n\nactions triggered on pan gestures + event coordinates\n\n\\*/\n(function (global) {\n\n\"use strict\";\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nif (typeof window !== 'undefined') {\n\tvar Hammer = require(\"$:/plugins/tiddlywiki/hammerjs/hammer.js\");\n}\n\nvar PanWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nPanWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nPanWidget.prototype.render = function(parent,nextSibling) {\n\tvar self = this;\n\tvar parentDomNode = parent;\n\n\t// Compute attributes and execute state\n\tthis.computeAttributes();\n\tthis.execute();\n\n\tvar panDomNode = this.document.createElement(this.panTag);\n\tpanDomNode.setAttribute(\"class\",this.panClass);\n\tparent.insertBefore(panDomNode,nextSibling);\n\tthis.domNodes.push(panDomNode);\n\tthis.renderChildren(panDomNode,null);\n\n\tvar panStartValues = [];\n\tvar precision = this.userToFixed;\n\tvar panState = this.panStateTiddler;\n\n\tvar hammer = new Hammer.Manager(panDomNode);\n\n\thammer.add(new Hammer.Pan({\n\t\tevent: 'pan',\n\t\tpointers: self.panPointers,\n\t\tthreshold: self.panThreshold,\n\t\tdirection: Hammer.DIRECTION_ALL\n\t}));\n\n\thammer.get('pan');\n\n\tvar scrollLeft = window.pageXOffset || document.documentElement.scrollLeft,\n\t\t scrollTop = window.pageYOffset || document.documentElement.scrollTop;\n\n\tvar startActions = null;\n\tvar domNodeRect = null;\n\tvar parentDomNodeRect = null;\n\n\tvar fieldStartNames = [ 'starting-x', 'starting-y', 'element-top', 'element-left', 'element-bottom', 'element-right', 'element-width', 'element-height', 'pointer-type', 'parent-x', 'parent-y', 'parent-classname', 'absolute-x', 'absolute-y'];\n\n\thammer.on('touchmove panstart panmove', function(e) {\n\t\t// Prevent default behaviour\n\t\te.preventDefault && e.preventDefault();\n\t\te.stopPropagation && e.stopPropagation();\n\n\t\t//Caching values, big performance impact\n\t\tvar pointerCenter = e.center,\n\t\t\tpointerCenterX = pointerCenter.x.toFixed(precision),\n\t\t\tpointerCenterY = pointerCenter.y.toFixed(precision),\n\t\t\tpointerDeltaX = e.deltaX.toFixed(precision),\n\t\t\tpointerDeltaY = e.deltaY.toFixed(precision),\n\t\t\tpanAltKey = e.changedPointers[0].altKey,\n\t\t\tpanCtrlKey = e.changedPointers[0].ctrlKey,\n\t\t\tpanShiftKey = e.changedPointers[0].shiftKey,\n\t\t\tpanMetaKey = e.changedPointers[0].metaKey,\n\t\t\tparentDomNodeClassName;\n\n\t\t// Set a \"dragging\" state tiddler - gets deleted when panning ends\n\t\t$tw.wiki.setText(\"$:/state/dragging\",\"text\",undefined,\"yes\",null);\n\n\t\t// Get the coordinates of the parent Dom Node\n\t\tif (parentDomNodeRect === null && parentDomNode !== undefined && parentDomNode.offsetParent !== undefined) {\n\t\t\tparentDomNodeRect = parentDomNode.offsetParent.getBoundingClientRect();\n\t\t\tparentDomNodeClassName = parentDomNode.offsetParent.className;\n\t\t}\n\n\t\t// Get the current coordinates of the element\n\t\tif (domNodeRect === null) {\n\t\t\tdomNodeRect = panDomNode.getBoundingClientRect();\n\t\t}\n\n\t\tif (self.panStartActions && startActions !== \"done\") {\n\t\t\tself.invokeActionString(self.panStartActions,self,e);\n\t\t\tstartActions = \"done\";\n\t\t}\n\n\t\t// Absolute coordinates of the pointer\n\t\tvar elementAbsoluteLeft = e.changedPointers[0].pageX; //(e.center.x + scrollLeft).toFixed(precision);\n\t\tvar elementAbsoluteTop = e.changedPointers[0].pageY; //(e.center.y + scrollTop).toFixed(precision);\n\t\t// Set values at pan-start only\n\t\tif (panStartValues.length === 0) {\n\t\t\tvar domNodeTop = domNodeRect.top.toFixed(precision),\n\t\t\t\tdomNodeLeft = domNodeRect.left.toFixed(precision),\n\t\t\t\tdomNodeRight = domNodeRect.right.toFixed(precision),\n\t\t\t\tdomNodeBottom = domNodeRect.bottom.toFixed(precision),\n\t\t\t\tdomNodeWidth = domNodeRect.width.toFixed(precision),\n\t\t\t\tdomNodeHeight = domNodeRect.height.toFixed(precision),\n\t\t\t\tdomNodeParentLeft = parentDomNodeRect.left.toFixed(precision) || \"undefined\",\n\t\t\t\tdomNodeParentTop = parentDomNodeRect.top.toFixed(precision) || \"undefined\";\n\n\t\t\tpanStartValues[0] = pointerCenterX;\n\t\t\tpanStartValues[1] = pointerCenterY;\n\t\t\tpanStartValues[2] = domNodeTop;\n\t\t\tpanStartValues[3] = domNodeLeft;\n\t\t\tpanStartValues[4] = domNodeBottom;\n\t\t\tpanStartValues[5] = domNodeRight;\n\t\t\tpanStartValues[6] = domNodeWidth;\n\t\t\tpanStartValues[7] = domNodeHeight;\n\t\t\tpanStartValues[8] = e.pointerType;\n\t\t\tpanStartValues[9] = domNodeParentLeft;\n\t\t\tpanStartValues[10] = domNodeParentTop;\n\t\t\tpanStartValues[11] = parentDomNodeClassName;\n\t\t\tpanStartValues[12] = elementAbsoluteLeft;\n\t\t\tpanStartValues[13] = elementAbsoluteTop;\n\n\t\t\tfor(var t = 0; t<panStartValues.length; t++){\n\t\t\t\tself.setField(panState,fieldStartNames[t],panStartValues[t]);\n\t\t\t}\n\t\t}\n\n\t\tself.setField(panState,'delta-x',pointerDeltaX);\n\t\tself.setField(panState,'delta-y',pointerDeltaY);\n\t\tself.setField(panState,'relative-x',pointerCenterX);\n\t\tself.setField(panState,'relative-y',pointerCenterY);\n\t\tself.setField(panState,'absolute-x',elementAbsoluteLeft);\n\t\tself.setField(panState,'absolute-y',elementAbsoluteTop);\n\t\tself.setField(panState,'alt-key',panAltKey);\n self.setField(panState,'ctlr-key',panCtrlKey);\n self.setField(panState,'shift-key',panShiftKey);\n\t\tself.setField(panState,'meta-key',panMetaKey);\n\t})\n\n\t.on('panend pancancel touchend mouseup', function(e) {\n\n\t\tstartActions = null;\n\t\tdomNodeRect = null;\n\t\tparentDomNodeRect = null;\n\t\tpanStartValues = [];\n\n\t\tif(self.panEndActions) {\n\t\t\tself.invokeActionString(self.panEndActions,self,e);\n\t\t}\n\n\t\t// Delete the \"dragging\" state tiddler\n\t\t$tw.wiki.deleteTiddler(\"$:/state/dragging\");\n\t\treturn true;\n\t});\n};\n\n\n/*\nSet the computed values in the state-tiddler fields\n*/\nPanWidget.prototype.setField = function(tiddler,field,value) {\n\t$tw.wiki.setText(tiddler,field,undefined,value,{ suppressTimestamp: true });\n};\n\n/*\nCompute the internal state of the widget\n*/\nPanWidget.prototype.execute = function() {\n\tthis.panClass = this.getAttribute(\"class\", \"tc-pan-element\");\n\tthis.panTag = this.getAttribute(\"tag\", \"div\");\n\tthis.panStateTiddler = this.getAttribute(\"state\",\"$:/state/pan\");\n\tthis.panPointers = parseInt(this.getAttribute(\"pointers\",\"1\"));\n\tthis.panThreshold = parseInt(this.getAttribute(\"threshold\",\"0\"));\n\tthis.userToFixed = parseInt(this.getAttribute(\"decimals\",\"0\"));\n\tthis.panStartActions = this.getAttribute(\"startactions\",\"\");\n\tthis.panEndActions = this.getAttribute(\"endactions\",\"\");\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nPanWidget.prototype.refresh = function(changedTiddlers) {\n\tvar self = this;\n\tvar changedAttributes = this.computeAttributes();\n\tif(Object.keys(changedAttributes).length) {\n\t\tself.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\nexports.pan = PanWidget;\n})();\n",
"type": "application/javascript",
"title": "$:/plugins/BurningTree/hammerwidgets/widgets/pan.js",
"module-type": "widget"
},
"$:/plugins/BurningTree/hammerwidgets/widgets/pinch.js": {
"text": "/*\\\ntitle: $:/plugins/tiddlywiki/hammerjs/widgets/pinch.js\ntype: application/javascript\nmodule-type: widget\n\nactions triggered on pinch gestures + event values\n\n\\*/\n(function (global) {\n\n\"use strict\";\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nif (typeof window !== 'undefined') {\n\tvar Hammer = require(\"$:/plugins/tiddlywiki/hammerjs/hammer.js\");\n}\n\nvar PinchWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nPinchWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nPinchWidget.prototype.render = function(parent,nextSibling) {\n\tvar self = this;\n\tvar parentDomNode = parent;\n\n\t// Compute attributes and execute state\n\tthis.computeAttributes();\n\tthis.execute();\n\n\tvar pinchDomNode = this.document.createElement(this.pinchTag);\n\tpinchDomNode.setAttribute(\"class\",this.pinchClass);\n\tparent.insertBefore(pinchDomNode,nextSibling);\n\tthis.domNodes.push(pinchDomNode);\n\tthis.renderChildren(pinchDomNode,null);\n\n\tvar hammer = new Hammer.Manager(pinchDomNode);\n\n\thammer.add(new Hammer.Pinch({\n\t\tevent: 'pinch',\n\t\tpointers: 2,\n\t\tthreshold: self.pinchThreshold\n\t}));\n\n\thammer.get('pinch').set({ enable: true });\n\n\tvar firstSet = null;\n\tvar startActions = null;\n\n\thammer.on('pinch pinchstart pinchmove', function(e) {\n\n\t\t$tw.wiki.setText(\"$:/state/pinching\",\"text\",undefined,\"yes\",null);\n\n\t\tvar rotationValue = e.rotation.toFixed(self.userToFixed);\n\t\tvar scaleValue = e.scale.toFixed(3);\n\n\t\tif(startActions !== \"done\") {\n\t\t\tself.invokeActionString(self.pinchStartActions,self,e);\n\t\t\tstartActions = \"done\";\n\t\t}\n\n\t\tif(firstSet !== \"done\") {\n\t\t\tself.setField(self.pinchStateTiddler,'rotation',rotationValue);\n\t\t\tself.setField(self.pinchStateTiddler,'scale',scaleValue);\n\t\t\tfirstSet = \"done\";\n\t\t}\n\n\t\tself.setField(self.pinchStateTiddler,'rotation',rotationValue);\n\t\tself.setField(self.pinchStateTiddler,'scale',scaleValue);\n\t})\n\t.on('pinchend pinchcancel touchend', function(e) {\n\t\te.stopPropagation && e.stopPropagation();\n\n\t\tif(self.pinchEndActions) {\n\t\t\tself.invokeActionString(self.pinchEndActions,self,e);\n\t\t}\n\n\t\tfirstSet = null;\n\t\tstartActions = null;\n\n\t\t$tw.wiki.deleteTiddler(\"$:/state/pinching\");\n\n\t\treturn true; // Action was invoked\n\t});\n};\n\n/*\nSet the computed values in the state-tiddler fields\n*/\nPinchWidget.prototype.setField = function(tiddler,field,value) {\n\t$tw.wiki.setText(tiddler,field,undefined,value,{ suppressTimestamp: true });\n};\n\n/*\nCompute the internal state of the widget\n*/\nPinchWidget.prototype.execute = function() {\n\tthis.pinchClass = this.getAttribute(\"class\", \"tc-pinch-div\");\n\tthis.pinchTag = this.getAttribute(\"tag\", \"div\");\n\tthis.userToFixed = parseInt(this.getAttribute(\"decimals\",\"0\"));\n\tthis.pinchThreshold = parseInt(this.getAttribute(\"threshold\",\"0\"));\n\tthis.pinchStateTiddler = this.getAttribute(\"statetiddler\",\"$:/state/pinch\");\n\tthis.pinchStartActions = this.getAttribute(\"startactions\",\"\");\n\tthis.pinchEndActions = this.getAttribute(\"endactions\",\"\");\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nPinchWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(Object.keys(changedAttributes).length) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\nexports.pinch = PinchWidget;\n})();\n",
"type": "application/javascript",
"title": "$:/plugins/BurningTree/hammerwidgets/widgets/pinch.js",
"module-type": "widget"
},
"$:/plugins/BurningTree/hammerwidgets/styles": {
"title": "$:/plugins/BurningTree/hammerwidgets/styles",
"tags": "$:/tags/Stylesheet",
"text": "<$list filter=\"[[$:/state/dragging]!is[missing]]\">\n\niframe {\n pointer-events: none;\n}\n\n</$list>\n\n"
}
}
}
{
"tiddlers": {
"$:/config/EditTabIndex": {
"title": "$:/config/EditTabIndex",
"text": "0\n"
},
"$:/plugins/BurningTreeC/KeeBoord/config": {
"title": "$:/plugins/BurningTreeC/KeeBoord/config",
"text": "<$checkbox tiddler=\"$:/config/EditTabIndex\" field=\"text\" checked=\"1\" unchecked=\"0\" default=\"0\"> Enable <kbd>TAB</kbd> - Navigation for Tiddlers</$checkbox>\n\n"
},
"$:/core/modules/startup/keyboard.js": {
"text": "/*\\\ntitle: $:/core/modules/startup/keyboard.js\ntype: application/javascript\nmodule-type: startup\n\nKeyboard shortcut handling\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n// Export name and synchronous status\nexports.name = \"global-keyboard\";\nexports.platforms = [\"browser\"];\nexports.after = [\"startup\"];\nexports.synchronous = true;\n\nexports.startup = function() {\n\tif($tw.browser) {\n\t\t// Helper function to get a list of all shortcut tiddlers\n\t\tfunction getShortcutTiddlerList() {\n\t\t\treturn $tw.wiki.getTiddlersWithTag(\"$:/tags/KeyboardShortcut\");\n\t\t}\n\t\t// Get existing shortcut-tiddlers\n\t\tvar shortcutTiddlers = getShortcutTiddlerList(),\n\t\t\tshortcutKeysList = [], // Holds the shortcut-key descriptors\n\t\t\tshortcutActionList = [], // Holds the corresponding action strings\n\t\t\tshortcutParsedList = []; // Holds the parsed key descriptors\n\n\t\tfunction updateShortcutLists(tiddlerList) {\n\t\t\tshortcutTiddlers = tiddlerList;\n\t\t\tfor(var i=0; i < tiddlerList.length; i++) {\n\t\t\t\tvar title = tiddlerList[i],\n\t\t\t\t\ttiddlerFields = $tw.wiki.getTiddler(title).fields;\n\t\t\t\tshortcutKeysList[i] = tiddlerFields.key !== undefined ? tiddlerFields.key : undefined;\n\t\t\t\tshortcutActionList[i] = tiddlerFields.text;\n\t\t\t\tshortcutParsedList[i] = shortcutKeysList[i] !== undefined ? $tw.keyboardManager.parseKeyDescriptors(shortcutKeysList[i]) : undefined;\n\t\t\t}\n\t\t};\n\n\t\t// Cache shortcuts and corresponding actions at startup\n\t\tupdateShortcutLists(shortcutTiddlers);\n\n\t\t// Keydown Listener for shortcuts\n\t\tdocument.addEventListener(\"keydown\",function(event) {\n\t\t\tvar key, action;\n\t\t\tfor(var i=0; i < shortcutTiddlers.length; i++) {\n\t\t\t\tif(shortcutParsedList[i] !== undefined && $tw.keyboardManager.checkKeyDescriptors(event,shortcutParsedList[i])) {\n\t\t\t\t\tkey = shortcutParsedList[i];\n\t\t\t\t\taction = shortcutActionList[i];\n\t\t\t\t}\n\t\t\t}\n\t\t\tif(key !== undefined) {\n\t\t\t\t$tw.rootWidget.invokeActionString(action,$tw.rootWidget);\n\t\t\t\treturn true;\n\t\t\t}\n\t\t\treturn false;\n\t\t},false);\n\n\t\t// Listener for changing shortcuts \"on-the-fly\"\n\t\t$tw.wiki.addEventListener(\"change\",function(changes) {\n\t\t\tvar newList = getShortcutTiddlerList();\n\t\t\tvar hasChanged = false;\n\n\t\t\t// Returns true if a passed array contains a Tiddler that has changed\n\t\t\tfunction hasAnyTiddlerChanged(tiddlerList) {\n\t\t\t\tfor(var i=0; i < tiddlerList.length; i++) {\n\t\t\t\t\tif($tw.utils.hop(changes,tiddlerList[i])) {\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn false;\n\t\t\t};\n\n\t\t\t// First inspect the existing shortcut-tiddlers\n\t\t\thasChanged = hasAnyTiddlerChanged(shortcutTiddlers);\n\n\t\t\t// Check if there are new shortcut-actions\n\t\t\tif(!hasChanged) {\n\t\t\t\thasChanged = hasAnyTiddlerChanged(newList);\n\t\t\t}\n\n\t\t\t// Check if key-combinations have changed\n\t\t\tif(!hasChanged) {\n\t\t\t\tvar shortcutConfigTiddlers = [],\n\t\t\t\t\tpattern = /^\\$:\\/config\\/shortcuts\\/.*$/;\n\t\t\t\tObject.keys(changes).forEach(function(configTiddler) {\n\t\t\t\t\tif(pattern.test(configTiddler)) {\n\t\t\t\t\t\tshortcutConfigTiddlers.push(configTiddler);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\thasChanged = hasAnyTiddlerChanged(shortcutConfigTiddlers);\n\t\t\t}\n\n\t\t\t// Re-cache shortcuts if something changed\n\t\t\tif(hasChanged) {\n\t\t\t\tupdateShortcutLists(newList);\n\t\t\t}\n\t\t});\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"title": "$:/core/modules/startup/keyboard.js",
"module-type": "startup"
},
"$:/core/modules/editor/factory.js": {
"text": "/*\\\ntitle: $:/core/modules/editor/factory.js\ntype: application/javascript\nmodule-type: library\n\nFactory for constructing text editor widgets with specified engines for the toolbar and non-toolbar cases\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar DEFAULT_MIN_TEXT_AREA_HEIGHT = \"100px\"; // Minimum height of textareas in pixels\n\n// Configuration tiddlers\nvar HEIGHT_MODE_TITLE = \"$:/config/TextEditor/EditorHeight/Mode\";\nvar ENABLE_TOOLBAR_TITLE = \"$:/config/TextEditor/EnableToolbar\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nfunction editTextWidgetFactory(toolbarEngine,nonToolbarEngine) {\n\n\tvar EditTextWidget = function(parseTreeNode,options) {\n\t\t// Initialise the editor operations if they've not been done already\n\t\tif(!this.editorOperations) {\n\t\t\tEditTextWidget.prototype.editorOperations = {};\n\t\t\t$tw.modules.applyMethods(\"texteditoroperation\",this.editorOperations);\n\t\t}\n\t\tthis.initialise(parseTreeNode,options);\n\t};\n\n\t/*\n\tInherit from the base widget class\n\t*/\n\tEditTextWidget.prototype = new Widget();\n\n\t/*\n\tRender this widget into the DOM\n\t*/\n\tEditTextWidget.prototype.render = function(parent,nextSibling) {\n\t\t// Save the parent dom node\n\t\tthis.parentDomNode = parent;\n\t\t// Compute our attributes\n\t\tthis.computeAttributes();\n\t\t// Execute our logic\n\t\tthis.execute();\n\t\t// Create the wrapper for the toolbar and render its content\n\t\tif(this.editShowToolbar) {\n\t\t\tthis.toolbarNode = this.document.createElement(\"div\");\n\t\t\tthis.toolbarNode.className = \"tc-editor-toolbar\";\n\t\t\tparent.insertBefore(this.toolbarNode,nextSibling);\n\t\t\tthis.renderChildren(this.toolbarNode,null);\n\t\t\tthis.domNodes.push(this.toolbarNode);\n\t\t}\n\t\t// Create our element\n\t\tvar editInfo = this.getEditInfo(),\n\t\t\tEngine = this.editShowToolbar ? toolbarEngine : nonToolbarEngine;\n\t\tthis.engine = new Engine({\n\t\t\t\twidget: this,\n\t\t\t\tvalue: editInfo.value,\n\t\t\t\ttype: editInfo.type,\n\t\t\t\tparentNode: parent,\n\t\t\t\tnextSibling: nextSibling\n\t\t\t});\n\t\t// Call the postRender hook\n\t\tif(this.postRender) {\n\t\t\tthis.postRender();\n\t\t}\n\t\t// Fix height\n\t\tthis.engine.fixHeight();\n\t\t// Focus if required\n\t\tif(this.editFocus === \"true\" || this.editFocus === \"yes\") {\n\t\t\tthis.engine.focus();\n\t\t}\n\t\t// Add widget message listeners\n\t\tthis.addEventListeners([\n\t\t\t{type: \"tm-edit-text-operation\", handler: \"handleEditTextOperationMessage\"}\n\t\t]);\n\t};\n\n\t/*\n\tGet the tiddler being edited and current value\n\t*/\n\tEditTextWidget.prototype.getEditInfo = function() {\n\t\t// Get the edit value\n\t\tvar self = this,\n\t\t\tvalue,\n\t\t\ttype = \"text/plain\",\n\t\t\tupdate;\n\t\tif(this.editIndex) {\n\t\t\tvalue = this.wiki.extractTiddlerDataItem(this.editTitle,this.editIndex,this.editDefault);\n\t\t\tupdate = function(value) {\n\t\t\t\tvar data = self.wiki.getTiddlerData(self.editTitle,{});\n\t\t\t\tif(data[self.editIndex] !== value) {\n\t\t\t\t\tdata[self.editIndex] = value;\n\t\t\t\t\tself.wiki.setTiddlerData(self.editTitle,data);\n\t\t\t\t}\n\t\t\t};\n\t\t} else {\n\t\t\t// Get the current tiddler and the field name\n\t\t\tvar tiddler = this.wiki.getTiddler(this.editTitle);\n\t\t\tif(tiddler) {\n\t\t\t\t// If we've got a tiddler, the value to display is the field string value\n\t\t\t\tvalue = tiddler.getFieldString(this.editField);\n\t\t\t\tif(this.editField === \"text\") {\n\t\t\t\t\ttype = tiddler.fields.type || \"text/vnd.tiddlywiki\";\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// Otherwise, we need to construct a default value for the editor\n\t\t\t\tswitch(this.editField) {\n\t\t\t\t\tcase \"text\":\n\t\t\t\t\t\tvalue = \"Type the text for the tiddler '\" + this.editTitle + \"'\";\n\t\t\t\t\t\ttype = \"text/vnd.tiddlywiki\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase \"title\":\n\t\t\t\t\t\tvalue = this.editTitle;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tvalue = \"\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\tif(this.editDefault !== undefined) {\n\t\t\t\t\tvalue = this.editDefault;\n\t\t\t\t}\n\t\t\t}\n\t\t\tupdate = function(value) {\n\t\t\t\tvar tiddler = self.wiki.getTiddler(self.editTitle),\n\t\t\t\t\tupdateFields = {\n\t\t\t\t\t\ttitle: self.editTitle\n\t\t\t\t\t};\n\t\t\t\tupdateFields[self.editField] = value;\n\t\t\t\tself.wiki.addTiddler(new $tw.Tiddler(self.wiki.getCreationFields(),tiddler,updateFields,self.wiki.getModificationFields()));\n\t\t\t};\n\t\t}\n\t\tif(this.editType) {\n\t\t\ttype = this.editType;\n\t\t}\n\t\treturn {value: value || \"\", type: type, update: update};\n\t};\n\n\t/*\n\tHandle an edit text operation message from the toolbar\n\t*/\n\tEditTextWidget.prototype.handleEditTextOperationMessage = function(event) {\n\t\t// Prepare information about the operation\n\t\tvar operation = this.engine.createTextOperation();\n\t\t// Invoke the handler for the selected operation\n\t\tvar handler = this.editorOperations[event.param];\n\t\tif(handler) {\n\t\t\thandler.call(this,event,operation);\n\t\t}\n\t\t// Execute the operation via the engine\n\t\tvar newText = this.engine.executeTextOperation(operation);\n\t\t// Fix the tiddler height and save changes\n\t\tthis.engine.fixHeight();\n\t\tthis.saveChanges(newText);\n\t};\n\n\t/*\n\tCompute the internal state of the widget\n\t*/\n\tEditTextWidget.prototype.execute = function() {\n\t\t// Get our parameters\n\t\tthis.editTitle = this.getAttribute(\"tiddler\",this.getVariable(\"currentTiddler\"));\n\t\tthis.editField = this.getAttribute(\"field\",\"text\");\n\t\tthis.editIndex = this.getAttribute(\"index\");\n\t\tthis.editDefault = this.getAttribute(\"default\");\n\t\tthis.editClass = this.getAttribute(\"class\");\n\t\tthis.editPlaceholder = this.getAttribute(\"placeholder\");\n\t\tthis.editSize = this.getAttribute(\"size\");\n\t\tthis.editRows = this.getAttribute(\"rows\");\n\t\tthis.editAutoHeight = this.wiki.getTiddlerText(HEIGHT_MODE_TITLE,\"auto\");\n\t\tthis.editAutoHeight = this.getAttribute(\"autoHeight\",this.editAutoHeight === \"auto\" ? \"yes\" : \"no\") === \"yes\";\n\t\tthis.editMinHeight = this.getAttribute(\"minHeight\",DEFAULT_MIN_TEXT_AREA_HEIGHT);\n\t\tthis.editFocusPopup = this.getAttribute(\"focusPopup\");\n\t\tthis.editFocus = this.getAttribute(\"focus\");\n\t\t// Get the default editor element tag and type\n\t\tvar tag,type;\n\t\tif(this.editField === \"text\") {\n\t\t\ttag = \"textarea\";\n\t\t} else {\n\t\t\ttag = \"input\";\n\t\t\tvar fieldModule = $tw.Tiddler.fieldModules[this.editField];\n\t\t\tif(fieldModule && fieldModule.editTag) {\n\t\t\t\ttag = fieldModule.editTag;\n\t\t\t}\n\t\t\tif(fieldModule && fieldModule.editType) {\n\t\t\t\ttype = fieldModule.editType;\n\t\t\t}\n\t\t\ttype = type || \"text\";\n\t\t}\n\t\t// Get the rest of our parameters\n\t\tthis.editTag = this.getAttribute(\"tag\",tag);\n\t\tthis.editType = this.getAttribute(\"type\",type);\n\t\tthis.editTabIndex = this.getAttribute(\"tabIndex\");\n\t\tthis.editCancelPopups = this.getAttribute(\"cancelPopups\") === \"yes\";\n\t\t// Make the child widgets\n\t\tthis.makeChildWidgets();\n\t\t// Determine whether to show the toolbar\n\t\tthis.editShowToolbar = this.wiki.getTiddlerText(ENABLE_TOOLBAR_TITLE,\"yes\");\n\t\tthis.editShowToolbar = (this.editShowToolbar === \"yes\") && !!(this.children && this.children.length > 0) && (!this.document.isTiddlyWikiFakeDom);\n\t};\n\n\t/*\n\tSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n\t*/\n\tEditTextWidget.prototype.refresh = function(changedTiddlers) {\n\t\tvar changedAttributes = this.computeAttributes();\n\t\t// Completely rerender if any of our attributes have changed\n\t\tif(changedAttributes.tiddler || changedAttributes.field || changedAttributes.index || changedAttributes[\"default\"] || changedAttributes[\"class\"] || changedAttributes.placeholder || changedAttributes.size || changedAttributes.autoHeight || changedAttributes.minHeight || changedAttributes.focusPopup || changedAttributes.rows || changedTiddlers[HEIGHT_MODE_TITLE] || changedTiddlers[ENABLE_TOOLBAR_TITLE]) {\n\t\t\tthis.refreshSelf();\n\t\t\treturn true;\n\t\t} else if(changedTiddlers[this.editTitle]) {\n\t\t\tvar editInfo = this.getEditInfo();\n\t\t\tthis.updateEditor(editInfo.value,editInfo.type);\n\t\t}\n\t\tthis.engine.fixHeight();\n\t\tif(this.editShowToolbar) {\n\t\t\treturn this.refreshChildren(changedTiddlers);\n\t\t} else {\n\t\t\treturn false;\n\t\t}\n\t};\n\n\t/*\n\tUpdate the editor with new text. This method is separate from updateEditorDomNode()\n\tso that subclasses can override updateEditor() and still use updateEditorDomNode()\n\t*/\n\tEditTextWidget.prototype.updateEditor = function(text,type) {\n\t\tthis.updateEditorDomNode(text,type);\n\t};\n\n\t/*\n\tUpdate the editor dom node with new text\n\t*/\n\tEditTextWidget.prototype.updateEditorDomNode = function(text,type) {\n\t\tthis.engine.setText(text,type);\n\t};\n\n\t/*\n\tSave changes back to the tiddler store\n\t*/\n\tEditTextWidget.prototype.saveChanges = function(text) {\n\t\tvar editInfo = this.getEditInfo();\n\t\tif(text !== editInfo.value) {\n\t\t\teditInfo.update(text);\n\t\t}\n\t};\n\n\t/*\n\tHandle a dom \"keydown\" event, which we'll bubble up to our container for the keyboard widgets benefit\n\t*/\n\tEditTextWidget.prototype.handleKeydownEvent = function(event) {\n\t\t// Check for a keyboard shortcut\n\t\tif(this.toolbarNode) {\n\t\t\tvar shortcutElements = this.toolbarNode.querySelectorAll(\"[data-tw-keyboard-shortcut]\");\n\t\t\tfor(var index=0; index<shortcutElements.length; index++) {\n\t\t\t\tvar el = shortcutElements[index],\n\t\t\t\t\tshortcutData = el.getAttribute(\"data-tw-keyboard-shortcut\"),\n\t\t\t\t\tkeyInfoArray = $tw.keyboardManager.parseKeyDescriptors(shortcutData,{\n\t\t\t\t\t\twiki: this.wiki\n\t\t\t\t\t});\n\t\t\t\tif($tw.keyboardManager.checkKeyDescriptors(event,keyInfoArray)) {\n\t\t\t\t\tvar clickEvent = this.document.createEvent(\"Events\");\n\t\t\t\t clickEvent.initEvent(\"click\",true,false);\n\t\t\t\t el.dispatchEvent(clickEvent);\n\t\t\t\t\tevent.preventDefault();\n\t\t\t\t\tevent.stopPropagation();\n\t\t\t\t\treturn true;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t// Propogate the event to the container\n\t\tif(this.propogateKeydownEvent(event)) {\n\t\t\t// Ignore the keydown if it was already handled\n\t\t\tevent.preventDefault();\n\t\t\tevent.stopPropagation();\n\t\t\treturn true;\n\t\t}\n\t\t// Otherwise, process the keydown normally\n\t\treturn false;\n\t};\n\n\t/*\n\tPropogate keydown events to our container for the keyboard widgets benefit\n\t*/\n\tEditTextWidget.prototype.propogateKeydownEvent = function(event) {\n\t\tvar newEvent = this.document.createEventObject ? this.document.createEventObject() : this.document.createEvent(\"Events\");\n\t\tif(newEvent.initEvent) {\n\t\t\tnewEvent.initEvent(\"keydown\", true, true);\n\t\t}\n\t\tnewEvent.keyCode = event.keyCode;\n\t\tnewEvent.which = event.which;\n\t\tnewEvent.metaKey = event.metaKey;\n\t\tnewEvent.ctrlKey = event.ctrlKey;\n\t\tnewEvent.altKey = event.altKey;\n\t\tnewEvent.shiftKey = event.shiftKey;\n\t\treturn !this.parentDomNode.dispatchEvent(newEvent);\n\t};\n\n\treturn EditTextWidget;\n\n}\n\nexports.editTextWidgetFactory = editTextWidgetFactory;\n\n})();\n",
"type": "application/javascript",
"title": "$:/core/modules/editor/factory.js",
"module-type": "library"
},
"$:/core/modules/widgets/action-navigate.js": {
"text": "/*\\\ntitle: $:/core/modules/widgets/action-navigate.js\ntype: application/javascript\nmodule-type: widget\n\nAction widget to navigate to a tiddler\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar NavigateWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nNavigateWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nNavigateWidget.prototype.render = function(parent,nextSibling) {\n\tthis.computeAttributes();\n\tthis.execute();\n};\n\n/*\nCompute the internal state of the widget\n*/\nNavigateWidget.prototype.execute = function() {\n\tthis.actionTo = this.getAttribute(\"$to\");\n\tthis.actionScroll = this.getAttribute(\"$scroll\");\n};\n\n/*\nRefresh the widget by ensuring our attributes are up to date\n*/\nNavigateWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes[\"$to\"] || changedAttributes[\"$scroll\"]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\n/*\nInvoke the action associated with this widget\n*/\nNavigateWidget.prototype.invokeAction = function(triggeringWidget,event) {\n\tevent = event || {};\n\tvar bounds = triggeringWidget && triggeringWidget.getBoundingClientRect && triggeringWidget.getBoundingClientRect(),\n\t\tsuppressNavigation = event.metaKey || event.ctrlKey || (event.button === 1);\n\tif(this.actionScroll === \"yes\") {\n\t\tsuppressNavigation = false;\n\t} else if(this.actionScroll === \"no\") {\n\t\tsuppressNavigation = true;\n\t}\n\tthis.dispatchEvent({\n\t\ttype: \"tm-navigate\",\n\t\tnavigateTo: this.actionTo === undefined ? this.getVariable(\"currentTiddler\") : this.actionTo,\n\t\tnavigateFromTitle: this.getVariable(\"storyTiddler\"),\n\t\tnavigateFromNode: triggeringWidget,\n\t\tnavigateFromClientRect: bounds && { top: bounds.top, left: bounds.left, width: bounds.width, right: bounds.right, bottom: bounds.bottom, height: bounds.height\n\t\t},\n\t\tnavigateSuppressNavigation: suppressNavigation\n\t});\n\treturn true; // Action was invoked\n};\n\nexports[\"action-navigate\"] = NavigateWidget;\n\n})();\n",
"type": "application/javascript",
"title": "$:/core/modules/widgets/action-navigate.js",
"module-type": "widget"
},
"$:/core/modules/editor/engines/simple.js": {
"text": "/*\\\ntitle: $:/core/modules/editor/engines/simple.js\ntype: application/javascript\nmodule-type: library\n\nText editor engine based on a simple input or textarea tag\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar HEIGHT_VALUE_TITLE = \"$:/config/TextEditor/EditorHeight/Height\";\n\nfunction SimpleEngine(options) {\n\t// Save our options\n\toptions = options || {};\n\tthis.widget = options.widget;\n\tthis.value = options.value;\n\tthis.parentNode = options.parentNode;\n\tthis.nextSibling = options.nextSibling;\n\t// Construct the textarea or input node\n\tvar tag = this.widget.editTag;\n\tif($tw.config.htmlUnsafeElements.indexOf(tag) !== -1) {\n\t\ttag = \"input\";\n\t}\n\tthis.domNode = this.widget.document.createElement(tag);\n\t// Set the text\n\tif(this.widget.editTag === \"textarea\") {\n\t\tthis.domNode.appendChild(this.widget.document.createTextNode(this.value));\n\t} else {\n\t\tthis.domNode.value = this.value;\n\t}\n\t// Set the attributes\n\tif(this.widget.editType) {\n\t\tthis.domNode.setAttribute(\"type\",this.widget.editType);\n\t}\n\tif(this.widget.editPlaceholder) {\n\t\tthis.domNode.setAttribute(\"placeholder\",this.widget.editPlaceholder);\n\t}\n\tif(this.widget.editSize) {\n\t\tthis.domNode.setAttribute(\"size\",this.widget.editSize);\n\t}\n\tif(this.widget.editRows) {\n\t\tthis.domNode.setAttribute(\"rows\",this.widget.editRows);\n\t}\n\tif(this.widget.editClass) {\n\t\tthis.domNode.className = this.widget.editClass;\n\t}\n\tif(this.widget.editTabIndex) {\n\t\tthis.domNode.setAttribute(\"tabindex\",this.widget.editTabIndex);\n\t}\n\t// Add an input event handler\n\t$tw.utils.addEventListeners(this.domNode,[\n\t\t{name: \"focus\", handlerObject: this, handlerMethod: \"handleFocusEvent\"},\n\t\t{name: \"input\", handlerObject: this, handlerMethod: \"handleInputEvent\"}\n\t]);\n\t// Insert the element into the DOM\n\tthis.parentNode.insertBefore(this.domNode,this.nextSibling);\n\tthis.widget.domNodes.push(this.domNode);\n}\n\n/*\nSet the text of the engine if it doesn't currently have focus\n*/\nSimpleEngine.prototype.setText = function(text,type) {\n\tif(!this.domNode.isTiddlyWikiFakeDom) {\n\t\tif(this.domNode.ownerDocument.activeElement !== this.domNode || text === \"\") {\n\t\t\tthis.domNode.value = text;\n\t\t}\n\t\t// Fix the height if needed\n\t\tthis.fixHeight();\n\t}\n};\n\n/*\nGet the text of the engine\n*/\nSimpleEngine.prototype.getText = function() {\n\treturn this.domNode.value;\n};\n\n/*\nFix the height of textarea to fit content\n*/\nSimpleEngine.prototype.fixHeight = function() {\n\tif(this.widget.editTag === \"textarea\") {\n\t\tif(this.widget.editAutoHeight) {\n\t\t\tif(this.domNode && !this.domNode.isTiddlyWikiFakeDom) {\n\t\t\t\t$tw.utils.resizeTextAreaToFit(this.domNode,this.widget.editMinHeight);\n\t\t\t}\n\t\t} else {\n\t\t\tvar fixedHeight = parseInt(this.widget.wiki.getTiddlerText(HEIGHT_VALUE_TITLE,\"400px\"),10);\n\t\t\tfixedHeight = Math.max(fixedHeight,20);\n\t\t\tthis.domNode.style.height = fixedHeight + \"px\";\n\t\t}\n\t}\n};\n\n/*\nFocus the engine node\n*/\nSimpleEngine.prototype.focus = function() {\n\tif(this.domNode.focus && this.domNode.select) {\n\t\tthis.domNode.focus();\n\t\tthis.domNode.select();\n\t}\n};\n\n/*\nHandle a dom \"input\" event which occurs when the text has changed\n*/\nSimpleEngine.prototype.handleInputEvent = function(event) {\n\tthis.widget.saveChanges(this.getText());\n\tthis.fixHeight();\n\treturn true;\n};\n\n/*\nHandle a dom \"focus\" event\n*/\nSimpleEngine.prototype.handleFocusEvent = function(event) {\n\tif(this.widget.editCancelPopups) {\n\t\tvar numPopups = $tw.popup.popups.length;\n\t\tif(numPopups !== 0) {\n\t\t\tfor(var i=0; i < numPopups; i++) {\n\t\t\t\t$tw.popup.cancel(i);\n\t\t\t}\n\t\t}\n\t}\n\tif(this.widget.editFocusPopup) {\n\t\t$tw.popup.triggerPopup({\n\t\t\tdomNode: this.domNode,\n\t\t\ttitle: this.widget.editFocusPopup,\n\t\t\twiki: this.widget.wiki,\n\t\t\tforce: true\n\t\t});\n\t}\n\treturn true;\n};\n\n/*\nCreate a blank structure representing a text operation\n*/\nSimpleEngine.prototype.createTextOperation = function() {\n\treturn null;\n};\n\n/*\nExecute a text operation\n*/\nSimpleEngine.prototype.executeTextOperation = function(operation) {\n};\n\nexports.SimpleEngine = SimpleEngine;\n\n})();\n",
"type": "application/javascript",
"title": "$:/core/modules/editor/engines/simple.js",
"module-type": "library"
},
"$:/core/modules/editor/engines/framed.js": {
"text": "/*\\\ntitle: $:/core/modules/editor/engines/framed.js\ntype: application/javascript\nmodule-type: library\n\nText editor engine based on a simple input or textarea within an iframe. This is done so that the selection is preserved even when clicking away from the textarea\n\n\\*/\n(function(){\n\n/*jslint node: true,browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar HEIGHT_VALUE_TITLE = \"$:/config/TextEditor/EditorHeight/Height\";\n\nfunction FramedEngine(options) {\n\t// Save our options\n\toptions = options || {};\n\tthis.widget = options.widget;\n\tthis.value = options.value;\n\tthis.parentNode = options.parentNode;\n\tthis.nextSibling = options.nextSibling;\n\t// Create our hidden dummy text area for reading styles\n\tthis.dummyTextArea = this.widget.document.createElement(\"textarea\");\n\tif(this.widget.editClass) {\n\t\tthis.dummyTextArea.className = this.widget.editClass;\n\t}\n\tthis.dummyTextArea.setAttribute(\"hidden\",\"true\");\n\tthis.parentNode.insertBefore(this.dummyTextArea,this.nextSibling);\n\tthis.widget.domNodes.push(this.dummyTextArea);\n\t// Create the iframe\n\tthis.iframeNode = this.widget.document.createElement(\"iframe\");\n\tthis.parentNode.insertBefore(this.iframeNode,this.nextSibling);\n\tthis.iframeDoc = this.iframeNode.contentWindow.document;\n\t// (Firefox requires us to put some empty content in the iframe)\n\tthis.iframeDoc.open();\n\tthis.iframeDoc.write(\"\");\n\tthis.iframeDoc.close();\n\t// Style the iframe\n\tthis.iframeNode.className = this.dummyTextArea.className;\n\tthis.iframeNode.style.border = \"none\";\n\tthis.iframeNode.style.padding = \"0\";\n\tthis.iframeNode.style.resize = \"none\";\n\tthis.iframeDoc.body.style.margin = \"0\";\n\tthis.iframeDoc.body.style.padding = \"0\";\n\tthis.widget.domNodes.push(this.iframeNode);\n\t// Construct the textarea or input node\n\tvar tag = this.widget.editTag;\n\tif($tw.config.htmlUnsafeElements.indexOf(tag) !== -1) {\n\t\ttag = \"input\";\n\t}\n\tthis.domNode = this.iframeDoc.createElement(tag);\n\t// Set the text\n\tif(this.widget.editTag === \"textarea\") {\n\t\tthis.domNode.appendChild(this.iframeDoc.createTextNode(this.value));\n\t} else {\n\t\tthis.domNode.value = this.value;\n\t}\n\t// Set the attributes\n\tif(this.widget.editType) {\n\t\tthis.domNode.setAttribute(\"type\",this.widget.editType);\n\t}\n\tif(this.widget.editPlaceholder) {\n\t\tthis.domNode.setAttribute(\"placeholder\",this.widget.editPlaceholder);\n\t}\n\tif(this.widget.editSize) {\n\t\tthis.domNode.setAttribute(\"size\",this.widget.editSize);\n\t}\n\tif(this.widget.editRows) {\n\t\tthis.domNode.setAttribute(\"rows\",this.widget.editRows);\n\t}\n\tif(this.widget.editTabIndex) {\n\t\tthis.iframeNode.setAttribute(\"tabindex\",this.widget.editTabIndex);\n\t}\n\t// Copy the styles from the dummy textarea\n\tthis.copyStyles();\n\t// Add event listeners\n\t$tw.utils.addEventListeners(this.domNode,[\n\t\t{name: \"focus\",handlerObject: this,handlerMethod: \"handleFocusEvent\"},\n\t\t{name: \"click\",handlerObject: this,handlerMethod: \"handleClickEvent\"},\n\t\t{name: \"input\",handlerObject: this,handlerMethod: \"handleInputEvent\"},\n\t\t{name: \"keydown\",handlerObject: this.widget,handlerMethod: \"handleKeydownEvent\"}\n\t]);\n\t// Insert the element into the DOM\n\tthis.iframeDoc.body.appendChild(this.domNode);\n}\n\n/*\nCopy styles from the dummy text area to the textarea in the iframe\n*/\nFramedEngine.prototype.copyStyles = function() {\n\t// Copy all styles\n\t$tw.utils.copyStyles(this.dummyTextArea,this.domNode);\n\t// Override the ones that should not be set the same as the dummy textarea\n\tthis.domNode.style.display = \"block\";\n\tthis.domNode.style.width = \"100%\";\n\tthis.domNode.style.margin = \"0\";\n\t// In Chrome setting -webkit-text-fill-color overrides the placeholder text colour\n\tthis.domNode.style[\"-webkit-text-fill-color\"] = \"currentcolor\";\n};\n\n/*\nSet the text of the engine if it doesn't currently have focus\n*/\nFramedEngine.prototype.setText = function(text,type) {\n\tif(!this.domNode.isTiddlyWikiFakeDom) {\n\t\tif(this.domNode.ownerDocument.activeElement !== this.domNode) {\n\t\t\tthis.domNode.value = text;\n\t\t}\n\t\t// Fix the height if needed\n\t\tthis.fixHeight();\n\t}\n};\n\n/*\nGet the text of the engine\n*/\nFramedEngine.prototype.getText = function() {\n\treturn this.domNode.value;\n};\n\n/*\nFix the height of textarea to fit content\n*/\nFramedEngine.prototype.fixHeight = function() {\n\t// Make sure styles are updated\n\tthis.copyStyles();\n\t// Adjust height\n\tif(this.widget.editTag === \"textarea\") {\n\t\tif(this.widget.editAutoHeight) {\n\t\t\tif(this.domNode && !this.domNode.isTiddlyWikiFakeDom) {\n\t\t\t\tvar newHeight = $tw.utils.resizeTextAreaToFit(this.domNode,this.widget.editMinHeight);\n\t\t\t\tthis.iframeNode.style.height = (newHeight + 14) + \"px\"; // +14 for the border on the textarea\n\t\t\t}\n\t\t} else {\n\t\t\tvar fixedHeight = parseInt(this.widget.wiki.getTiddlerText(HEIGHT_VALUE_TITLE,\"400px\"),10);\n\t\t\tfixedHeight = Math.max(fixedHeight,20);\n\t\t\tthis.domNode.style.height = fixedHeight + \"px\";\n\t\t\tthis.iframeNode.style.height = (fixedHeight + 14) + \"px\";\n\t\t}\n\t}\n};\n\n/*\nFocus the engine node\n*/\nFramedEngine.prototype.focus = function() {\n\tif(this.domNode.focus && this.domNode.select) {\n\t\tthis.domNode.focus();\n\t\tthis.domNode.select();\n\t}\n};\n\n/*\nHandle a dom \"focus\" event\n*/\nFramedEngine.prototype.handleFocusEvent = function(event) {\n\tif(this.widget.editCancelPopups) {\n\t\tvar numPopups = $tw.popup.popups.length;\n\t\tif(numPopups !== 0) {\n\t\t\tfor(var i=0; i < numPopups; i++) {\n\t\t\t\t$tw.popup.cancel(i);\n\t\t\t}\n\t\t}\n\t}\n\treturn true;\n};\n\n/*\nHandle a click\n*/\nFramedEngine.prototype.handleClickEvent = function(event) {\n\tthis.fixHeight();\n\treturn true;\n};\n\n/*\nHandle a dom \"input\" event which occurs when the text has changed\n*/\nFramedEngine.prototype.handleInputEvent = function(event) {\n\tthis.widget.saveChanges(this.getText());\n\tthis.fixHeight();\n\treturn true;\n};\n\n/*\nCreate a blank structure representing a text operation\n*/\nFramedEngine.prototype.createTextOperation = function() {\n\tvar operation = {\n\t\ttext: this.domNode.value,\n\t\tselStart: this.domNode.selectionStart,\n\t\tselEnd: this.domNode.selectionEnd,\n\t\tcutStart: null,\n\t\tcutEnd: null,\n\t\treplacement: null,\n\t\tnewSelStart: null,\n\t\tnewSelEnd: null\n\t};\n\toperation.selection = operation.text.substring(operation.selStart,operation.selEnd);\n\treturn operation;\n};\n\n/*\nExecute a text operation\n*/\nFramedEngine.prototype.executeTextOperation = function(operation) {\n\t// Perform the required changes to the text area and the underlying tiddler\n\tvar newText = operation.text;\n\tif(operation.replacement !== null) {\n\t\tnewText = operation.text.substring(0,operation.cutStart) + operation.replacement + operation.text.substring(operation.cutEnd);\n\t\t// Attempt to use a execCommand to modify the value of the control\n\t\tif(this.iframeDoc.queryCommandSupported(\"insertText\") && this.iframeDoc.queryCommandSupported(\"delete\") && !$tw.browser.isFirefox) {\n\t\t\tthis.domNode.focus();\n\t\t\tthis.domNode.setSelectionRange(operation.cutStart,operation.cutEnd);\n\t\t\tif(operation.replacement === \"\") {\n\t\t\t\tthis.iframeDoc.execCommand(\"delete\",false,\"\");\n\t\t\t} else {\n\t\t\t\tthis.iframeDoc.execCommand(\"insertText\",false,operation.replacement);\n\t\t\t}\n\t\t} else {\n\t\t\tthis.domNode.value = newText;\n\t\t}\n\t\tthis.domNode.focus();\n\t\tthis.domNode.setSelectionRange(operation.newSelStart,operation.newSelEnd);\n\t}\n\tthis.domNode.focus();\n\treturn newText;\n};\n\nexports.FramedEngine = FramedEngine;\n\n})();\n",
"type": "application/javascript",
"title": "$:/core/modules/editor/engines/framed.js",
"module-type": "library"
},
"$:/core/modules/widgets/edit.js": {
"text": "/*\\\ntitle: $:/core/modules/widgets/edit.js\ntype: application/javascript\nmodule-type: widget\n\nEdit widget is a meta-widget chooses the appropriate actual editting widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar EditWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nEditWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nEditWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n};\n\n// Mappings from content type to editor type are stored in tiddlers with this prefix\nvar EDITOR_MAPPING_PREFIX = \"$:/config/EditorTypeMappings/\";\n\n/*\nCompute the internal state of the widget\n*/\nEditWidget.prototype.execute = function() {\n\t// Get our parameters\n\tthis.editTitle = this.getAttribute(\"tiddler\",this.getVariable(\"currentTiddler\"));\n\tthis.editField = this.getAttribute(\"field\",\"text\");\n\tthis.editIndex = this.getAttribute(\"index\");\n\tthis.editClass = this.getAttribute(\"class\");\n\tthis.editPlaceholder = this.getAttribute(\"placeholder\");\n\tthis.editTabIndex = this.getAttribute(\"tabIndex\");\n\tthis.editCancelPopups = this.getAttribute(\"cancelPopups\", \"no\");\n\t// Choose the appropriate edit widget\n\tthis.editorType = this.getEditorType();\n\t// Make the child widgets\n\tthis.makeChildWidgets([{\n\t\ttype: \"edit-\" + this.editorType,\n\t\tattributes: {\n\t\t\ttiddler: {type: \"string\", value: this.editTitle},\n\t\t\tfield: {type: \"string\", value: this.editField},\n\t\t\tindex: {type: \"string\", value: this.editIndex},\n\t\t\t\"class\": {type: \"string\", value: this.editClass},\n\t\t\t\"placeholder\": {type: \"string\", value: this.editPlaceholder},\n\t\t\t\"tabIndex\": {type: \"string\", value: this.editTabIndex},\n\t\t\t\"cancelPopups\": {type: \"string\", value: this.editCancelPopups}\n\t\t},\n\t\tchildren: this.parseTreeNode.children\n\t}]);\n};\n\nEditWidget.prototype.getEditorType = function() {\n\t// Get the content type of the thing we're editing\n\tvar type;\n\tif(this.editField === \"text\") {\n\t\tvar tiddler = this.wiki.getTiddler(this.editTitle);\n\t\tif(tiddler) {\n\t\t\ttype = tiddler.fields.type;\n\t\t}\n\t}\n\ttype = type || \"text/vnd.tiddlywiki\";\n\tvar editorType = this.wiki.getTiddlerText(EDITOR_MAPPING_PREFIX + type);\n\tif(!editorType) {\n\t\tvar typeInfo = $tw.config.contentTypeInfo[type];\n\t\tif(typeInfo && typeInfo.encoding === \"base64\") {\n\t\t\teditorType = \"binary\";\n\t\t} else {\n\t\t\teditorType = \"text\";\n\t\t}\n\t}\n\treturn editorType;\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nEditWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\t// Refresh if an attribute has changed, or the type associated with the target tiddler has changed\n\tif(changedAttributes.tiddler || changedAttributes.field || changedAttributes.index || (changedTiddlers[this.editTitle] && this.getEditorType() !== this.editorType)) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn this.refreshChildren(changedTiddlers);\n\t}\n};\n\nexports.edit = EditWidget;\n\n})();\n",
"type": "application/javascript",
"title": "$:/core/modules/widgets/edit.js",
"module-type": "widget"
},
"$:/core/macros/tag-picker": {
"title": "$:/core/macros/tag-picker",
"tags": "$:/tags/Macro",
"text": "\\define add-tag-actions()\n<$action-sendmessage $message=\"tm-add-tag\" $param={{$:/temp/NewTagName}}/>\n<$action-deletetiddler $tiddler=\"$:/temp/NewTagName\"/>\n\\end\n\n\\define add-tag-actions()\n<$action-sendmessage $message=\"tm-add-tag\" $param={{$:/temp/NewTagName}}/>\n<$action-deletetiddler $tiddler=\"$:/temp/NewTagName\"/>\n\\end\n\n\\define tag-button()\n<$button class=\"tc-btn-invisible\" tag=\"a\">\n$(actions)$\n<$action-deletetiddler $tiddler=\"$:/temp/NewTagName\"/>\n<$macrocall $name=\"tag-pill\" tag=<<tag>>/>\n</$button>\n\\end\n\n\\define tag-picker(actions)\n<$set name=\"actions\" value=\"\"\"$actions$\"\"\">\n<div class=\"tc-edit-add-tag\">\n<span class=\"tc-add-tag-name\">\n<$keyboard key=\"ENTER\" actions=<<add-tag-actions>>>\n<$edit-text tiddler=\"$:/temp/NewTagName\" tag=\"input\" default=\"\" placeholder={{$:/language/EditTemplate/Tags/Add/Placeholder}} focusPopup=<<qualify \"$:/state/popup/tags-auto-complete\">> class=\"tc-edit-texteditor tc-popup-handle\" cancelPopups=\"yes\" tabIndex={{$:/config/EditTabIndex}}/>\n</$keyboard>\n</span> <$button popup=<<qualify \"$:/state/popup/tags-auto-complete\">> class=\"tc-btn-invisible\" tooltip={{$:/language/EditTemplate/Tags/Dropdown/Hint}} aria-label={{$:/language/EditTemplate/Tags/Dropdown/Caption}}>{{$:/core/images/down-arrow}}</$button> <span class=\"tc-add-tag-button\">\n<$set name=\"tag\" value={{$:/temp/NewTagName}}>\n<$button set=\"$:/temp/NewTagName\" setTo=\"\" class=\"\">\n$actions$\n<$action-deletetiddler $tiddler=\"$:/temp/NewTagName\"/>\n{{$:/language/EditTemplate/Tags/Add/Button}}\n</$button>\n</$set>\n</span>\n</div>\n<div class=\"tc-block-dropdown-wrapper\">\n<$reveal state=<<qualify \"$:/state/popup/tags-auto-complete\">> type=\"nomatch\" text=\"\" default=\"\">\n<div class=\"tc-block-dropdown\">\n<$list filter=\"[{$:/temp/NewTagName}minlength{$:/config/Tags/MinLength}limit[1]]\" emptyMessage=\"\"\"<div class=\"tc-search-results\">{{$:/language/Search/Search/TooShort}}</div>\"\"\" variable=\"listItem\">\n<$list filter=\"[tags[]!is[system]search:title{$:/temp/NewTagName}sort[]]\" variable=\"tag\">\n<<tag-button>>\n</$list></$list>\n<hr>\n<$list filter=\"[{$:/temp/NewTagName}minlength{$:/config/Tags/MinLength}limit[1]]\" emptyMessage=\"\"\"<div class=\"tc-search-results\">{{$:/language/Search/Search/TooShort}}</div>\"\"\" variable=\"listItem\">\n<$list filter=\"[tags[]is[system]search:title{$:/temp/NewTagName}sort[]]\" variable=\"tag\">\n<<tag-button>>\n</$list></$list>\n</div>\n</$reveal>\n</div>\n</$set>\n\\end\n"
},
"$:/plugins/BurningTreeC/KeeBoord/readme": {
"title": "$:/plugins/BurningTreeC/KeeBoord/readme",
"text": "This plugin enhances ~TiddlyWiki5 with global keyboard shortcuts\n\nIt's recommended to use version 5.1.17 or newer of ~TiddlyWiki5\n\n"
},
"$:/core/ui/SideBarLists": {
"title": "$:/core/ui/SideBarLists",
"text": "<div class=\"tc-sidebar-lists\">\n\n<$set name=\"searchTiddler\" value=\"$:/temp/search\">\n<div class=\"tc-search\">\n<$edit-text tiddler=\"$:/temp/search\" type=\"search\" tag=\"input\" focus={{$:/config/Search/AutoFocus}} focusPopup=<<qualify \"$:/state/popup/search-dropdown\">> class=\"tc-popup-handle\" cancelPopups=\"yes\"/>\n<$reveal state=\"$:/temp/search\" type=\"nomatch\" text=\"\">\n<$button tooltip={{$:/language/Buttons/AdvancedSearch/Hint}} aria-label={{$:/language/Buttons/AdvancedSearch/Caption}} class=\"tc-btn-invisible\">\n<$action-setfield $tiddler=\"$:/temp/advancedsearch\" text={{$:/temp/search}}/>\n<$action-setfield $tiddler=\"$:/temp/search\" text=\"\"/>\n<$action-navigate $to=\"$:/AdvancedSearch\"/>\n{{$:/core/images/advanced-search-button}}\n</$button>\n<$button class=\"tc-btn-invisible\">\n<$action-setfield $tiddler=\"$:/temp/search\" text=\"\" />\n{{$:/core/images/close-button}}\n</$button>\n<$button popup=<<qualify \"$:/state/popup/search-dropdown\">> class=\"tc-btn-invisible\">\n{{$:/core/images/down-arrow}}\n<$list filter=\"[{$:/temp/search}minlength{$:/config/Search/MinLength}limit[1]]\" variable=\"listItem\">\n<$set name=\"resultCount\" value=\"\"\"<$count filter=\"[!is[system]search{$(searchTiddler)$}]\"/>\"\"\">\n{{$:/language/Search/Matches}}\n</$set>\n</$list>\n</$button>\n</$reveal>\n<$reveal state=\"$:/temp/search\" type=\"match\" text=\"\">\n<$button to=\"$:/AdvancedSearch\" tooltip={{$:/language/Buttons/AdvancedSearch/Hint}} aria-label={{$:/language/Buttons/AdvancedSearch/Caption}} class=\"tc-btn-invisible\">\n{{$:/core/images/advanced-search-button}}\n</$button>\n</$reveal>\n</div>\n\n<$reveal tag=\"div\" class=\"tc-block-dropdown-wrapper\" state=\"$:/temp/search\" type=\"nomatch\" text=\"\">\n\n<$reveal tag=\"div\" class=\"tc-block-dropdown tc-search-drop-down tc-popup-handle\" state=<<qualify \"$:/state/popup/search-dropdown\">> type=\"nomatch\" text=\"\" default=\"\">\n\n<$list filter=\"[{$:/temp/search}minlength{$:/config/Search/MinLength}limit[1]]\" emptyMessage=\"\"\"<div class=\"tc-search-results\">{{$:/language/Search/Search/TooShort}}</div>\"\"\" variable=\"listItem\">\n\n{{$:/core/ui/SearchResults}}\n\n</$list>\n\n</$reveal>\n\n</$reveal>\n\n</$set>\n\n<$macrocall $name=\"tabs\" tabsList=\"[all[shadows+tiddlers]tag[$:/tags/SideBar]!has[draft.of]]\" default={{$:/config/DefaultSidebarTab}} state=\"$:/state/tab/sidebar\" />\n\n</div>\n"
},
"$:/core/ui/EditTemplate/body/editor": {
"title": "$:/core/ui/EditTemplate/body/editor",
"text": "<$edit\n\n field=\"text\"\n class=\"tc-edit-texteditor\"\n placeholder={{$:/language/EditTemplate/Body/Placeholder}}\n tabIndex={{$:/config/EditTabIndex}}\n cancelPopups=\"yes\"\n\n><$set\n\n name=\"targetTiddler\"\n value=<<currentTiddler>>\n\n><$list\n\n filter=\"[all[shadows+tiddlers]tag[$:/tags/EditorToolbar]!has[draft.of]]\"\n\n><$reveal\n\n type=\"nomatch\"\n state=<<config-visibility-title>>\n text=\"hide\"\n class=\"tc-text-editor-toolbar-item-wrapper\"\n\n><$transclude\n\n tiddler=\"$:/core/ui/EditTemplate/body/toolbar/button\"\n mode=\"inline\"\n\n/></$reveal></$list></$set></$edit>\n"
},
"$:/core/ui/EditTemplate/body": {
"title": "$:/core/ui/EditTemplate/body",
"tags": "$:/tags/EditTemplate",
"text": "\\define lingo-base() $:/language/EditTemplate/Body/\n\\define config-visibility-title()\n$:/config/EditorToolbarButtons/Visibility/$(currentTiddler)$\n\\end\n<$list filter=\"[is[current]has[_canonical_uri]]\">\n\n<div class=\"tc-message-box\">\n\n<<lingo External/Hint>>\n\n<a href={{!!_canonical_uri}}><$text text={{!!_canonical_uri}}/></a>\n\n<$edit-text field=\"_canonical_uri\" class=\"tc-edit-fields\" cancelPopups=\"yes\"></$edit-text>\n\n</div>\n\n</$list>\n\n<$list filter=\"[is[current]!has[_canonical_uri]]\">\n\n<$reveal state=\"$:/state/showeditpreview\" type=\"match\" text=\"yes\">\n\n<div class=\"tc-tiddler-preview\">\n\n<$transclude tiddler=\"$:/core/ui/EditTemplate/body/editor\" mode=\"inline\"/>\n\n<div class=\"tc-tiddler-preview-preview\">\n\n<$transclude tiddler={{$:/state/editpreviewtype}} mode=\"inline\">\n\n<$transclude tiddler=\"$:/core/ui/EditTemplate/body/preview/output\" mode=\"inline\"/>\n\n</$transclude>\n\n</div>\n\n</div>\n\n</$reveal>\n\n<$reveal state=\"$:/state/showeditpreview\" type=\"nomatch\" text=\"yes\">\n\n<$transclude tiddler=\"$:/core/ui/EditTemplate/body/editor\" mode=\"inline\"/>\n\n</$reveal>\n\n</$list>\n"
},
"$:/core/ui/EditTemplate/fields": {
"title": "$:/core/ui/EditTemplate/fields",
"tags": "$:/tags/EditTemplate",
"text": "\\define lingo-base() $:/language/EditTemplate/\n\\define config-title()\n$:/config/EditTemplateFields/Visibility/$(currentField)$\n\\end\n\n\\define config-filter()\n[[hide]] -[title{$(config-title)$}]\n\\end\n\n\\define new-field()\n<$vars name={{$:/temp/newfieldname}}>\n<$reveal type=\"nomatch\" text=\"\" default=<<name>>>\n<$button>\n<$action-sendmessage $message=\"tm-add-field\"\n$name=<<name>>\n$value={{$:/temp/newfieldvalue}}/>\n<$action-deletetiddler $tiddler=\"$:/temp/newfieldname\"/>\n<$action-deletetiddler $tiddler=\"$:/temp/newfieldvalue\"/>\n<<lingo Fields/Add/Button>>\n</$button>\n</$reveal>\n<$reveal type=\"match\" text=\"\" default=<<name>>>\n<$button>\n<<lingo Fields/Add/Button>>\n</$button>\n</$reveal>\n</$vars>\n\\end\n\n<div class=\"tc-edit-fields\">\n<table class=\"tc-edit-fields\">\n<tbody>\n<$list filter=\"[all[current]fields[]] +[sort[title]]\" variable=\"currentField\">\n<$list filter=<<config-filter>> variable=\"temp\">\n<tr class=\"tc-edit-field\">\n<td class=\"tc-edit-field-name\">\n<$text text=<<currentField>>/>:</td>\n<td class=\"tc-edit-field-value\">\n<$edit-text tiddler=<<currentTiddler>> field=<<currentField>> placeholder={{$:/language/EditTemplate/Fields/Add/Value/Placeholder}} cancelPopups=\"yes\" tabIndex={{$:/config/EditTabIndex}}/>\n</td>\n<td class=\"tc-edit-field-remove\">\n<$button class=\"tc-btn-invisible\" tooltip={{$:/language/EditTemplate/Field/Remove/Hint}} aria-label={{$:/language/EditTemplate/Field/Remove/Caption}}>\n<$action-deletefield $field=<<currentField>>/>\n{{$:/core/images/delete-button}}\n</$button>\n</td>\n</tr>\n</$list>\n</$list>\n</tbody>\n</table>\n</div>\n\n<$fieldmangler>\n<div class=\"tc-edit-field-add\">\n<em class=\"tc-edit\">\n<<lingo Fields/Add/Prompt>>\n</em>\n<span class=\"tc-edit-field-add-name\">\n<$edit-text tiddler=\"$:/temp/newfieldname\" tag=\"input\" default=\"\" placeholder={{$:/language/EditTemplate/Fields/Add/Name/Placeholder}} focusPopup=<<qualify \"$:/state/popup/field-dropdown\">> class=\"tc-edit-texteditor tc-popup-handle\" cancelPopups=\"yes\" tabIndex={{$:/config/EditTabIndex}}/>\n</span>\n<$button popup=<<qualify \"$:/state/popup/field-dropdown\">> class=\"tc-btn-invisible tc-btn-dropdown\" tooltip={{$:/language/EditTemplate/Field/Dropdown/Hint}} aria-label={{$:/language/EditTemplate/Field/Dropdown/Caption}}>{{$:/core/images/down-arrow}}</$button>\n<$reveal state=<<qualify \"$:/state/popup/field-dropdown\">> type=\"nomatch\" text=\"\" default=\"\">\n<div class=\"tc-block-dropdown tc-edit-type-dropdown\">\n<$linkcatcher to=\"$:/temp/newfieldname\">\n<div class=\"tc-dropdown-item\">\n<<lingo Fields/Add/Dropdown/User>>\n</div>\n<$list filter=\"[!is[shadow]!is[system]fields[]search:title{$:/temp/newfieldname}sort[]] -created -creator -draft.of -draft.title -modified -modifier -tags -text -title -type\" variable=\"currentField\">\n<$link to=<<currentField>>>\n<<currentField>>\n</$link>\n</$list>\n<div class=\"tc-dropdown-item\">\n<<lingo Fields/Add/Dropdown/System>>\n</div>\n<$list filter=\"[fields[]search:title{$:/temp/newfieldname}sort[]] -[!is[shadow]!is[system]fields[]]\" variable=\"currentField\">\n<$link to=<<currentField>>>\n<<currentField>>\n</$link>\n</$list>\n</$linkcatcher>\n</div>\n</$reveal>\n<span class=\"tc-edit-field-add-value\">\n<$edit-text tiddler=\"$:/temp/newfieldvalue\" tag=\"input\" default=\"\" placeholder={{$:/language/EditTemplate/Fields/Add/Value/Placeholder}} class=\"tc-edit-texteditor\" cancelPopups=\"yes\" tabIndex={{$:/config/EditTabIndex}}/>\n</span>\n<span class=\"tc-edit-field-add-button\">\n<$macrocall $name=\"new-field\"/>\n</span>\n</div>\n</$fieldmangler>\n"
},
"$:/core/ui/EditTemplate/title": {
"title": "$:/core/ui/EditTemplate/title",
"tags": "$:/tags/EditTemplate",
"text": "<$edit-text field=\"draft.title\" class=\"tc-titlebar tc-edit-texteditor\" focus=\"true\" cancelPopups=\"yes\" tabIndex={{$:/config/EditTabIndex}}/>\n\n<$vars pattern=\"\"\"[\\|\\[\\]{}]\"\"\" bad-chars=\"\"\"`| [ ] { }`\"\"\">\n\n<$list filter=\"[is[current]regexp:draft.title<pattern>]\" variable=\"listItem\">\n\n<div class=\"tc-message-box\">\n\n{{$:/core/images/warning}} {{$:/language/EditTemplate/Title/BadCharacterWarning}}\n\n</div>\n\n</$list>\n\n</$vars>\n\n<$reveal state=\"!!draft.title\" type=\"nomatch\" text={{!!draft.of}} tag=\"div\">\n\n<$list filter=\"[{!!draft.title}!is[missing]]\" variable=\"listItem\">\n\n<div class=\"tc-message-box\">\n\n{{$:/core/images/warning}} {{$:/language/EditTemplate/Title/Exists/Prompt}}\n\n</div>\n\n</$list>\n\n<$list filter=\"[{!!draft.of}!is[missing]]\" variable=\"listItem\">\n\n<$vars fromTitle={{!!draft.of}} toTitle={{!!draft.title}}>\n\n<$checkbox tiddler=\"$:/config/RelinkOnRename\" field=\"text\" checked=\"yes\" unchecked=\"no\" default=\"no\"> {{$:/language/EditTemplate/Title/Relink/Prompt}}</$checkbox>\n\n</$vars>\n\n</$list>\n\n</$reveal>\n\n"
},
"$:/core/ui/EditTemplate/type": {
"title": "$:/core/ui/EditTemplate/type",
"tags": "$:/tags/EditTemplate",
"text": "\\define lingo-base() $:/language/EditTemplate/\n<div class=\"tc-type-selector\"><$fieldmangler>\n<em class=\"tc-edit\"><<lingo Type/Prompt>></em> <$edit-text field=\"type\" tag=\"input\" default=\"\" placeholder={{$:/language/EditTemplate/Type/Placeholder}} focusPopup=<<qualify \"$:/state/popup/type-dropdown\">> class=\"tc-edit-typeeditor tc-popup-handle\" cancelPopups=\"yes\" tabIndex={{$:/config/EditTabIndex}}/> <$button popup=<<qualify \"$:/state/popup/type-dropdown\">> class=\"tc-btn-invisible tc-btn-dropdown\" tooltip={{$:/language/EditTemplate/Type/Dropdown/Hint}} aria-label={{$:/language/EditTemplate/Type/Dropdown/Caption}}>{{$:/core/images/down-arrow}}</$button> <$button message=\"tm-remove-field\" param=\"type\" class=\"tc-btn-invisible tc-btn-icon\" tooltip={{$:/language/EditTemplate/Type/Delete/Hint}} aria-label={{$:/language/EditTemplate/Type/Delete/Caption}}>{{$:/core/images/delete-button}}</$button>\n</$fieldmangler></div>\n\n<div class=\"tc-block-dropdown-wrapper\">\n<$reveal state=<<qualify \"$:/state/popup/type-dropdown\">> type=\"nomatch\" text=\"\" default=\"\">\n<div class=\"tc-block-dropdown tc-edit-type-dropdown\">\n<$linkcatcher to=\"!!type\">\n<$list filter='[all[shadows+tiddlers]prefix[$:/language/Docs/Types/]each[group]sort[group-sort]]'>\n<div class=\"tc-dropdown-item\">\n<$text text={{!!group}}/>\n</div>\n<$list filter=\"[all[shadows+tiddlers]prefix[$:/language/Docs/Types/]group{!!group}] +[sort[description]]\"><$link to={{!!name}}><$view field=\"description\"/> (<$view field=\"name\"/>)</$link>\n</$list>\n</$list>\n</$linkcatcher>\n</div>\n</$reveal>\n</div>\n"
}
}
}
{
"tiddlers": {
"$:/plugins/felixhayashi/tiddlymap/layout": {
"text": "\\rules only filteredtranscludeinline transcludeinline macrodef macrocallinline \n\n@charset \"UTF-8\";\n/********************************************************************\n * README \n ********************************************************************\n * \n * If you add some non-valid css string that won't compile and \n * unquote also doesn't help, do the following: in this stylesheet,\n * add a placeholder of the form __yourVariable__ at the point where\n * you need the string to be inserted. Then visit the gulpfile.js\n * file and add a replace instruction for your variable so it will\n * be replaced after the sass compiler has finished.\n * \n * Careful of the variable scope. Variables defined in partials\n * are visible everywhere https://gist.github.com/matyus/4339721.\n * \n *******************************************************************/\n/**\n * Returns a makedatauri macro\n */\n/**\n * Do not allow blurred background for dialogs\n * see: https://github.com/Jermolene/TiddlyWiki5/issues/1893\n */\nbody .tc-page-container-wrapper.tc-modal-displayed {\n -webkit-filter: inherit;\n -moz-filter: inherit;\n filter: inherit; }\n\nbody .tc-modal-wrapper {\n z-index: 1010; }\n body .tc-modal-wrapper .tc-modal-header svg {\n vertical-align: sub; }\n body .tc-modal-wrapper .tc-modal-header h3 {\n line-height: 10px; }\n body .tc-modal-wrapper .tc-modal-body {\n min-height: 250px;\n max-height: 70vh;\n padding-top: 0px;\n padding-bottom: 0px;\n overflow: auto; }\n body .tc-modal-wrapper .tc-modal-footer {\n padding: 8px; }\n body .tc-modal-wrapper .tc-modal-footer .tmap-dialog-button {\n font-weight: bold; }\n body .tc-modal-wrapper .tc-modal-footer .tmap-hidden-close-button {\n display: none; }\n\ntable.tmap-table tr, .tc-modal-body table.tmap-config-table tr {\n /*\n &:hover {\n background-color: #FFFFF3;\n }\n*/ }\n table.tmap-table tr:nth-child(odd), .tc-modal-body table.tmap-config-table tr:nth-child(odd) {\n background-color: #F0F0F0; }\n table.tmap-table tr:nth-child(even), .tc-modal-body table.tmap-config-table tr:nth-child(even) {\n background-color: #FFFFFF; }\n\n.tmap-save-canvas-preview {\n text-align: center; }\n .tmap-save-canvas-preview img {\n background-color: white;\n border: 1px solid lightgray;\n max-width: 100%;\n max-height: 100px; }\n\n.tmap-list-separator {\n display: block;\n background-color: #efefef;\n margin: 10px 0 5px 0;\n cursor: default;\n border-bottom: 1px dotted gray;\n font-weight: bold;\n font-size: 0.8em; }\n\n.tmap-unicode-icon {\n width: 1em;\n display: inline-block;\n text-align: center;\n color: black; }\n\nhtml .tmap-link {\n color: #5778D8; }\n html .tmap-link:hover {\n color: white;\n background: #5778D8; }\n\nhtml .tmap-small-list, html .tmap-smaller-list, html .tmap-very-small-list {\n overflow: auto;\n min-height: 2em;\n max-height: 9em;\n display: block; }\n\nhtml .tmap-smaller-list {\n max-height: 7em; }\n\nhtml .tmap-very-small-list {\n max-height: 5empx; }\n\nhtml .tc-tiddler-controls button.tmap-active-button svg {\n fill: #888888; }\n\nhtml #tmap-node-filter-dialog #tmap-filter-tips {\n font-size: 0.8em; }\n\nhtml #tmap-node-filter-dialog textarea {\n height: 100px;\n max-height: 300px;\n overflow: auto;\n width: 100%;\n font-size: 11px;\n font-family: \"Courier New\", Courier, monospace; }\n\n@media (max-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n .tc-sidebar-scrollable .tmap-desktop-editor .tmap-widget:not(.tmap-fullscreen) {\n display: none; } }\n\n@media (min-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n .tc-sidebar-scrollable .tmap-mobile-editor {\n display: none; }\n .tc-modal-wrapper {\n z-index: 1010; }\n .tc-modal-wrapper .tc-modal {\n boder: 1px solid #999999;\n left: calc(50% - 400px);\n width: 802px; }\n .tc-modal-wrapper .tc-modal-body {\n left: calc(50% - 400px);\n width: 800px; } }\n\n/**\n * see https://developer.mozilla.org/en/docs/Web/CSS/animation\n */\n/*** Keyframes for animations *************************************/\n@-o-keyframes fadein-keyframes {\n 0% {\n opacity: 0; }\n 100% {\n opacity: 1; } }\n\n@-moz-keyframes fadein-keyframes {\n 0% {\n opacity: 0; }\n 100% {\n opacity: 1; } }\n\n@-webkit-keyframes fadein-keyframes {\n 0% {\n opacity: 0; }\n 100% {\n opacity: 1; } }\n\n@keyframes flash fadein-keyframes {\n 0% {\n opacity: 0; }\n 100% {\n opacity: 1; } }\n\n@-o-keyframes fadeout-keyframes {\n 0% {\n opacity: 1; }\n 100% {\n opacity: 0; } }\n\n@-moz-keyframes fadeout-keyframes {\n 0% {\n opacity: 1; }\n 100% {\n opacity: 0; } }\n\n@-webkit-keyframes fadeout-keyframes {\n 0% {\n opacity: 1; }\n 100% {\n opacity: 0; } }\n\n@keyframes flash fadeout-keyframes {\n 0% {\n opacity: 1; }\n 100% {\n opacity: 0; } }\n\n.tmap-config-widget {\n background: #F0F0F0;\n padding: 5px;\n margin: 5px 0;\n box-sizing: border-box;\n display: block; }\n .tmap-config-widget .vis-network {\n display: none; }\n .tmap-config-widget .vis-configuration-wrapper {\n width: 100%; }\n .tmap-config-widget .vis-configuration-wrapper .vis-config-rangeinput {\n height: inherit;\n margin-left: 4px; }\n .tmap-config-widget .vis-configuration-wrapper .vis-configuration.vis-config-item {\n width: 100%;\n height: inherit;\n background: none;\n padding-left: 0px;\n left: 0; }\n .tmap-config-widget .vis-configuration-wrapper .vis-configuration.vis-config-item.tmap-vis-config-item-active .vis-config-label::after {\n content: \"(inherited)\";\n position: absolute;\n display: inline-block;\n margin-left: 10px;\n -o-animation: fadein-keyframes 1s;\n -moz-animation: fadein-keyframes 1s;\n -webkit-animation: fadein-keyframes 1s;\n animation: fadein-keyframes 1s;\n content: \"✔\";\n color: green;\n font-weight: bold;\n font-size: 15px; }\n .tmap-config-widget .vis-configuration-wrapper .vis-configuration.vis-config-item.tmap-vis-config-item-inactive .vis-config-label::after {\n /*\n @include marker;\n content: \"✔\";\n color: lightgray;\n position: absolute;\n*/ }\n .tmap-config-widget .vis-configuration-wrapper .vis-configuration.vis-config-item button.tmap-config-item-reset {\n vertical-align: top;\n margin-left: 5px; }\n .tmap-config-widget .vis-configuration-wrapper .vis-configuration.vis-config-item .vis-config-range {\n width: 150px; }\n .tmap-config-widget .vis-configuration-wrapper .vis-configuration.vis-config-item .vis-config-range::-moz-range-track {\n width: 150px !important; }\n .tmap-config-widget .vis-configuration-wrapper .vis-configuration.vis-config-item .vis-config-label {\n width: 150px; }\n .tmap-config-widget::after {\n clear: both;\n content: \"\";\n display: block; }\n\n/*\n$color-picker-height: 200;\ndiv div.vis-color-picker {\n div.vis-color {\n width: $color-picker-height + px;\n height: $color-picker-height + px;\n }\n \n div.vis-brightness {\n top: ($color-picker-height + 30) + px;\n }\n \n div.vis-label.vis-brightness {\n top: ($color-picker-height + 43) + px;\n }\n \n div.vis-label.vis-opacity {\n top: 338px\n }\n \n div.vis-opacity {\n top: 351px;\n }\n div.vis-initial-color, vis-new-color {\n top: 381px;\n }\n \n div.vis-button {\n top: 411px;\n }\n\n}\n*/\n.tmap-flash-message {\n border: 1px solid lightgray;\n padding: 5px;\n margin: 6px 0;\n display: block;\n color: #333333; }\n .tmap-flash-message.tmap-info, .tmap-flash-message.tmap-plain, .tmap-flash-message.tmap-neutral {\n background: #F0F0F0; }\n .tmap-flash-message.tmap-info::before, .tmap-flash-message.tmap-plain::before, .tmap-flash-message.tmap-neutral::before {\n content: \"i\";\n display: inline-block;\n border-radius: 50%;\n width: 0.8em;\n border: 2px solid;\n font-family: serif;\n text-align: center;\n height: 0.8em;\n font-weight: bold;\n line-height: 0.8em;\n vertical-align: text-top;\n margin-right: 2px; }\n .tmap-flash-message.tmap-valid, .tmap-flash-message.tmap-success {\n background: #D1EED4; }\n .tmap-flash-message.tmap-valid::before, .tmap-flash-message.tmap-success::before {\n content: \"i\";\n display: inline-block;\n border-radius: 50%;\n width: 0.8em;\n border: 2px solid;\n font-family: serif;\n text-align: center;\n height: 0.8em;\n font-weight: bold;\n line-height: 0.8em;\n vertical-align: text-top;\n margin-right: 2px; }\n .tmap-flash-message.tmap-warning {\n background: #FFF6D1; }\n .tmap-flash-message.tmap-warning::before {\n content: \"\";\n display: inline-block;\n background: url(<<tmap \"datauri\" \"$:/core/images/warning\" \"\">>);\n display: inline-block;\n width: 1em;\n height: 1em;\n background-size: 100% 100%;\n vertical-align: text-top;\n margin-right: 2px; }\n .tmap-flash-message.tmap-malformed, .tmap-flash-message.tmap-invalid, .tmap-flash-message.tmap-danger {\n background: #EED5D1; }\n .tmap-flash-message.tmap-malformed::before, .tmap-flash-message.tmap-invalid::before, .tmap-flash-message.tmap-danger::before {\n content: \"\";\n display: inline-block;\n background: url(<<tmap \"datauri\" \"$:/core/images/warning\" \"\">>);\n display: inline-block;\n width: 1em;\n height: 1em;\n background-size: 100% 100%;\n vertical-align: text-top;\n margin-right: 2px; }\n\n.tmap-widget {\n background: #FFFFFF;\n width: auto;\n position: relative;\n border: 1px dotted lightgray;\n padding: 2px;\n color: #666666;\n display: block; }\n .tmap-widget.tmap-click-to-use:not(.tmap-fullscreen) .vis-network:not(.vis-active) {\n cursor: pointer; }\n .tmap-widget.tmap-click-to-use:not(.tmap-fullscreen) .vis-network:not(.vis-active) .vis-navigation {\n display: none; }\n .tmap-widget.tmap-click-to-use:not(.tmap-fullscreen) .vis-network:not(.vis-active):hover:before {\n color: gray;\n background: white;\n content: \"Click to use\";\n font-size: 14px;\n font-weight: bold;\n right: calc(50% - 65px - 5px);\n position: absolute;\n text-align: center;\n top: calc(50% - 14px - 5px);\n width: 130px;\n z-index: 2000;\n padding: 5px;\n pointer-events: none;\n background-color: rgba(255, 255, 255, 0.3); }\n .tmap-widget .tmap-loading-bar {\n display: none;\n position: absolute;\n text-align: center;\n font-size: 2em;\n padding: 10px;\n top: 50%;\n background: rgba(245, 245, 245, 0.5);\n z-index: 1;\n width: 250px;\n margin: auto;\n left: 0px;\n right: 0px; }\n .tmap-widget .tmap-vis-graph {\n height: calc(100% - 35px); }\n .tmap-widget.tmap-no-buttons .vis-navigation {\n display: none; }\n .tmap-widget.tmap-advanced-editor .tmap-topbar {\n background: #d6d9d8; }\n .tmap-widget.tmap-advanced-editor .tmap-topbar .tmap-active-button {\n color: #488DCD; }\n .tmap-widget.tmap-advanced-editor .tmap-topbar .tmap-active-button svg {\n fill: #488DCD; }\n .tmap-widget.tmap-advanced-editor .tmap-topbar .tmap-unicode-button {\n font-size: 1.5em;\n vertical-align: bottom; }\n .tmap-widget .tmap-menu-bar {\n width: 100%; }\n .tmap-widget .tmap-topbar {\n background: #F5F5F5;\n border-bottom: 1px solid lightgray;\n padding: 3px 5px;\n height: 35px;\n position: relative; }\n .tmap-widget .tmap-topbar .tmap-view-label {\n width: 100%;\n text-align: center;\n font-weight: bold;\n padding-top: 3px; }\n .tmap-widget .tmap-topbar .tmap-focus-button {\n position: absolute;\n right: 10px;\n top: 6px; }\n .tmap-widget .tmap-topbar .tmap-focus-button input {\n width: 140px; }\n .tmap-widget .tmap-topbar .tmap-search-dropdown {\n position: relative; }\n .tmap-widget .tmap-topbar .tmap-search-dropdown .tc-drop-down {\n position: absolute;\n z-index: 999;\n right: 0px; }\n .tmap-widget .tmap-topbar [hidden] {\n display: none; }\n .tmap-widget .tmap-topbar select {\n width: 30%;\n max-width: 200px;\n word-wrap: initial;\n padding: 0px; }\n .tmap-widget .tmap-topbar button {\n line-height: inherit;\n color: #666666; }\n .tmap-widget .tmap-topbar > * {\n display: inline-block; }\n .tmap-widget .tmap-topbar .tmap-separator:after {\n color: #bdbdbd;\n margin: 3px;\n content: \" | \"; }\n .tmap-widget .tmap-topbar .tc-edit-add-tag .tc-add-tag-name input {\n width: 70%; }\n .tmap-widget .tmap-topbar .tc-sidebar-header {\n text-shadow: none; }\n .tmap-widget .tmap-topbar .tc-edit-tags {\n border: none;\n padding: inherit;\n box-shadow: none; }\n\n.tmap-widget.tmap-static-mode .tmap-topbar {\n height: initial; }\n\n.tmap-widget.tmap-static-mode .tmap-vis-graph {\n text-align: center;\n cursor: not-allowed; }\n .tmap-widget.tmap-static-mode .tmap-vis-graph:not(.tmap-graph-placeholder):hover::before {\n box-shadow: 10px 10px 5px lightgray;\n color: gray;\n background: white;\n content: \"Static\";\n font-size: 18px;\n font-weight: bold;\n left: 50%;\n margin-left: -100px;\n position: absolute;\n text-align: center;\n top: 50px;\n width: 200px;\n z-index: 2000;\n padding: 5px;\n pointer-events: none; }\n .tmap-widget.tmap-static-mode .tmap-vis-graph.tmap-graph-placeholder::before {\n content: \"No Preview\";\n display: block;\n text-align: center;\n padding: 20px; }\n\n.tmap-widget .tc-drop-down {\n min-width: 170px;\n max-width: 210px;\n padding: 5px;\n margin: 5px 0; }\n .tmap-widget .tc-drop-down button, .tmap-widget .tc-drop-down a {\n padding: 0 2px;\n text-decoration: none; }\n .tmap-widget .tc-drop-down button:hover, .tmap-widget .tc-drop-down a:hover {\n color: #ffffff; }\n .tmap-widget .tc-drop-down button svg, .tmap-widget .tc-drop-down a svg {\n vertical-align: middle; }\n\n.tmap-widget .tc-block-dropdown {\n width: 370px;\n min-width: 370px;\n padding: 5px;\n margin: 15px 0 0 -370px; }\n .tmap-widget .tc-block-dropdown a {\n display: inline;\n padding: 0px; }\n\n.tmap-widget.tmap-plain-design {\n border: none;\n padding: 0px; }\n .tmap-widget.tmap-plain-design .tmap-topbar {\n display: none; }\n\n.tc-sidebar-scrollable .tmap-widget {\n position: absolute;\n min-height: 350px; }\n\n/*** vis ***********************************************************/\n.tmap-widget div.vis-network .vis-edit-mode {\n height: 26px; }\n\n.tmap-widget div.vis-network .vis-manipulation {\n height: 34px;\n border-top: 1px solid #d6d9d8;\n background: rgba(245, 245, 245, 0.7); }\n\n.tmap-widget div.vis-network .vis-navigation .vis-button.tmap-button-enabled {\n right: 15px; }\n .tmap-widget div.vis-network .vis-navigation .vis-button.tmap-button-enabled.tmap-fullscreen-button {\n bottom: 90px;\n background-image: url(<<tmap \"datauri\" \"$:/plugins/felixhayashi/tiddlymap/media/fullscreen.png\" \"\">>); }\n .tmap-widget div.vis-network .vis-navigation .vis-button.tmap-button-enabled.tmap-halfscreen-button {\n bottom: 130px;\n background-image: url(<<tmap \"datauri\" \"$:/plugins/felixhayashi/tiddlymap/media/halfscreen.png\" \"\">>); }\n\n.tmap-widget div.vis-network .vis-navigation .vis-button:hover {\n box-shadow: 0 0 3px 3px rgba(75, 75, 75, 0.3); }\n .tmap-widget div.vis-network .vis-navigation .vis-button:hover:before {\n background: beige;\n display: block;\n color: black;\n padding: 3px;\n position: relative;\n border: 1px solid lightgray;\n width: 80px;\n left: -100px;\n top: -50px;\n z-index: 1000;\n text-align: center; }\n .tmap-widget div.vis-network .vis-navigation .vis-button:hover.vis-up:before {\n left: 30px;\n content: \"Scroll up\"; }\n .tmap-widget div.vis-network .vis-navigation .vis-button:hover.vis-down:before {\n left: 30px;\n content: \"Scroll down\"; }\n .tmap-widget div.vis-network .vis-navigation .vis-button:hover.vis-right:before {\n left: 30px;\n content: \"Scroll right\"; }\n .tmap-widget div.vis-network .vis-navigation .vis-button:hover.vis-left:before {\n left: 30px;\n content: \"Scroll left\"; }\n .tmap-widget div.vis-network .vis-navigation .vis-button:hover.vis-zoomOut:before {\n content: \"Zoom out\"; }\n .tmap-widget div.vis-network .vis-navigation .vis-button:hover.vis-zoomIn:before {\n content: \"Zoom in\"; }\n .tmap-widget div.vis-network .vis-navigation .vis-button:hover.vis-zoomExtends:before {\n content: \"Fit whole graph\"; }\n .tmap-widget div.vis-network .vis-navigation .vis-button:hover.tmap-fullscreen-button:before {\n content: \"Toggle Fullscreen\"; }\n .tmap-widget div.vis-network .vis-navigation .vis-button:hover.tmap-halfscreen-button:before {\n content: \"Toggle Halfscreen\"; }\n\n.tc-dropzone > .tc-story-river .tmap-widget .vis-navigation .tmap-halfscreen-button {\n display: none; }\n\n.tc-dropzone > .tc-story-river .tmap-widget:not(.tmap-fullscreen) .vis-navigation .vis-button {\n display: none; }\n\n.tc-dropzone > .tc-story-river .tmap-widget:hover .vis-navigation .vis-button.tmap-fullscreen-button {\n display: block; }\n\n.tc-dropzone > .tc-story-river .tmap-widget:hover .vis-navigation .vis-button.vis-zoomExtends {\n display: block; }\n\n/*** Fullscreen ****************************************************/\nbody.tmap-has-fullscreen-widget {\n overflow: hidden; }\n body.tmap-has-fullscreen-widget .tmap-widget.tmap-fullscreen {\n background: white !important;\n height: 100% !important;\n width: 100% !important;\n position: fixed !important;\n top: 0 !important;\n right: 0 !important;\n bottom: 0 !important;\n left: 0 !important;\n z-index: 999 !important;\n border: none !important;\n margin: 0 !important; }\n body.tmap-has-fullscreen-widget .tc-dropzone > *.tmap-has-fullscreen-widget {\n background: white !important;\n height: 100% !important;\n width: 100% !important;\n position: fixed !important;\n top: 0 !important;\n right: 0 !important;\n bottom: 0 !important;\n left: 0 !important;\n z-index: 999 !important;\n border: none !important;\n margin: 0 !important; }\n body.tmap-has-fullscreen-widget .tc-dropzone > *:not(.tmap-has-fullscreen-widget) {\n display: none; }\n\nbody.tmap-has-halfscreen-widget .tmap-widget.tmap-halfscreen {\n background: white !important;\n height: 100% !important;\n width: 100% !important;\n position: fixed !important;\n top: 0 !important;\n right: 0 !important;\n bottom: 0 !important;\n left: 0 !important;\n z-index: 999 !important;\n border: none !important;\n margin: 0 !important;\n position: absolute !important;\n border-left: 1px solid lightgray !important; }\n\n.tc-modal-footer .tmap-hidden-close-button {\n display: none; }\n\n.tmap-modal-content {\n position: relative;\n padding: 1em 0;\n padding-top: 0; }\n .tmap-modal-content table tr td {\n vertical-align: top; }\n .tmap-modal-content :not(pre) > code {\n padding: 1px;\n font-size: 0.9em;\n position: relative;\n top: -1px; }\n .tmap-modal-content :not(pre) > code {\n color: #666666; }\n .tmap-modal-content .tc-tab-set .tc-tab-content {\n margin-top: 0.5em; }\n .tmap-modal-content .tc-image-button {\n font-size: 14px; }\n .tmap-modal-content fieldset {\n margin: 0px; }\n .tmap-modal-content fieldset legend {\n font-weight: bold; }\n\n.tc-modal-body .tmap-modal-editor > p {\n margin: 0px; }\n\n.tc-modal-body .tmap-modal-editor .tmap-template-select select {\n width: 50%; }\n\n.tc-modal-body .tmap-modal-editor .tc-tiddler-frame {\n margin: auto;\n width: auto; }\n .tc-modal-body .tmap-modal-editor .tc-tiddler-frame .tc-tiddler-controls {\n display: none; }\n .tc-modal-body .tmap-modal-editor .tc-tiddler-frame .tc-tiddler-title {\n display: none; }\n\n.tc-modal-body table {\n margin: 6px 0;\n border: none;\n width: 100%; }\n .tc-modal-body table td, .tc-modal-body table th {\n border: 1px solid lightgray; }\n .tc-modal-body table.tmap-key-value-table th {\n width: 30%;\n background-color: #F0F0F0; }\n .tc-modal-body table.tmap-config-table.tmap-large-input tr td:last-child {\n width: 20%; }\n .tc-modal-body table.tmap-config-table.tmap-small-input tr td:last-child {\n width: 60%; }\n .tc-modal-body table.tmap-config-table tr td {\n border: none;\n vertical-align: top;\n padding: 5px; }\n .tc-modal-body table.tmap-config-table tr td:first-child {\n width: 15%; }\n .tc-modal-body table.tmap-config-table tr td:last-child {\n width: 40%; }\n .tc-modal-body table.tmap-config-table tr td input:not([type=radio]), .tc-modal-body table.tmap-config-table tr td textarea, .tc-modal-body table.tmap-config-table tr td select {\n width: 100%;\n /* prevents bad looking select boxes and wrapping in textareas */\n word-wrap: normal; }\n .tc-modal-body table.tmap-config-table tr td textarea {\n height: 100%; }\n .tc-modal-body table.tmap-config-table tr td .tmap-no-stretch input, .tc-modal-body table.tmap-config-table tr td .tmap-no-stretch textarea, .tc-modal-body table.tmap-config-table tr td .tmap-no-stretch select {\n width: auto; }\n .tc-modal-body table.tmap-config-table tr td div.tmap-button-wrapper {\n text-align: center; }\n .tc-modal-body table.tmap-config-table tr td .tmap-note {\n margin-top: 0.5em; }\n .tc-modal-body table.tmap-config-table tr td .tmap-description {\n font-style: italic; }\n\n#tmap-element-type-manager > div:first-child {\n height: 50vh;\n float: left;\n width: 21%;\n background: linear-gradient(90deg, whitesmoke 0%, white 50%); }\n #tmap-element-type-manager > div:first-child .tmap-searchbar {\n padding: 1em 0 0 0; }\n #tmap-element-type-manager > div:first-child .tmap-searchbar input {\n width: calc(100% - 36px); }\n #tmap-element-type-manager > div:first-child .tmap-searchbar button {\n width: 30px;\n float: right; }\n #tmap-element-type-manager > div:first-child ul {\n height: calc(100% - 65px);\n overflow: auto;\n margin-top: 1em;\n padding: 0; }\n #tmap-element-type-manager > div:first-child ul.no-bullets li {\n list-style: none; }\n #tmap-element-type-manager > div:first-child ul li {\n white-space: nowrap; }\n #tmap-element-type-manager > div:first-child ul li .tmap-ranking {\n width: 30px;\n display: inline-block; }\n\n#tmap-element-type-manager > div:last-child {\n height: 100%;\n width: calc(79% - 15px);\n float: right; }\n #tmap-element-type-manager > div:last-child .tc-tab-set .tc-tab-content {\n overflow: auto;\n height: 50vh; }\n\n.tmap-manage-node-types .tmap-edge-type-specific {\n display: none !important; }\n\n.tmap-manage-edge-types .tmap-node-type-specific {\n display: none !important; }\n\n.tmap-modal-fullscreen-editor .tc-tab-content p {\n margin: 1em 0; }\n\n.tmap-has-pending-template {\n background-color: #C1EDC4; }\n\n#tmap-search-table td {\n border: none;\n padding-left: 0px; }\n #tmap-search-table td:first-child {\n width: 30px; }\n\n#tmap-search-table b {\n display: inline-block;\n width: 40px;\n text-align: right; }\n\n#tmap-search-table ul {\n padding-left: 20px;\n margin: 1em 0 0 0; }\n #tmap-search-table ul li {\n list-style: inherit; }\n #tmap-search-table ul button {\n text-align: left; }\n\nbutton.tmap-go-back {\n margin-bottom: 1em;\n font-weight: bold; }\n\n.tmap-badges > span, .tmap-badge {\n background: gray;\n font-size: 11px;\n color: white;\n padding: 3px 4px;\n display: inline-block;\n font-weight: bold;\n border-radius: 2px;\n line-height: 1em;\n cursor: help; }\n .tmap-badges > span.tmap-red-flag, .tmap-badge.tmap-red-flag {\n background: red; }\n\n/**\n * See http://stackoverflow.com/questions/3331353/transitions-on-the-display-property\n */\n.tmap-popup {\n display: none;\n position: absolute;\n opacity: 0;\n transition: opacity 0.3s ease; }\n .tmap-popup.tmap-popup-active {\n opacity: 1; }\n\n.tmap-tooltip {\n box-shadow: 3px 3px 10px rgba(0, 0, 0, 0.2);\n min-width: 100px;\n min-height: 50px;\n max-width: <<tmap option config.sys.popups.width>>;\n max-height: <<tmap option config.sys.popups.height>>;\n padding: 5px;\n resize: both;\n overflow: auto;\n cursor: auto;\n font-family: verdana;\n font-size: 14px;\n background-color: #f5f4ed;\n border: 1px solid #808074;\n -moz-border-radius: 3px;\n -webkit-border-radius: 3px;\n border-radius: 3px; }\n .tmap-tooltip[style*=\"height\"] {\n max-height: none !important; }\n .tmap-tooltip[style*=\"width\"] {\n max-width: none !important; }\n\n.tmap-quick-connect {\n font-size: 0.7em; }\n .tmap-quick-connect p {\n padding-left: 0;\n padding-right: 0; }\n .tmap-quick-connect .tc-drop-down {\n padding: 5px;\n width: 250px;\n white-space: normal;\n line-height: 1em;\n position: absolute;\n z-index: 1000;\n right: 50px;\n background: linear-gradient(45deg, whitesmoke 0%, white 50%, whitesmoke 100%); }\n .tmap-quick-connect .tc-drop-down:first-child {\n padding-top: 0;\n margin-top: 0; }\n .tmap-quick-connect .tc-drop-down .title {\n margin: 1.5em 0 0.5em 0;\n font-weight: bold;\n color: gray; }\n .tmap-quick-connect .tc-drop-down select {\n width: 80px;\n word-wrap: initial; }\n .tmap-quick-connect .tc-drop-down table {\n width: 100%;\n border: none;\n margin: 0.5em 0; }\n .tmap-quick-connect .tc-drop-down table td, .tmap-quick-connect .tc-drop-down table th {\n padding: 3px 3px 3px 0;\n vertical-align: middle;\n font-weight: normal;\n border: none; }\n .tmap-quick-connect .tc-drop-down table td table, .tmap-quick-connect .tc-drop-down table th table {\n margin: 0; }\n .tmap-quick-connect .tc-drop-down .tmap-quick-connect-search-bar, .tmap-quick-connect .tc-drop-down .tmap-quick-connect-existing-bar {\n background: #F1F1F1;\n margin-top: 0;\n border-bottom: 1px solid #D5D5D5;\n border-top: 1px solid #D5D5D5; }\n .tmap-quick-connect .tc-drop-down table.tmap-quick-connect-search-bar td, .tmap-quick-connect .tc-drop-down th {\n padding: 5px; }\n .tmap-quick-connect .tc-drop-down .tmap-quick-connect-existing-bar {\n padding: 5px; }\n .tmap-quick-connect .tc-drop-down .tmap-connection-table th, .tmap-quick-connect .tc-drop-down .tmap-connection-table td {\n text-align: left;\n padding: 1px 1px 1px 0; }\n .tmap-quick-connect .tc-drop-down .tmap-connection-table button {\n width: 20px;\n padding: 0px; }\n .tmap-quick-connect .tc-drop-down .tmap-scroll-table {\n height: 120px;\n overflow: auto;\n display: block; }\n .tmap-quick-connect .tc-drop-down hr {\n border: 0;\n height: 0;\n border-top: 1px solid rgba(0, 0, 0, 0.1);\n border-bottom: 1px solid rgba(255, 255, 255, 0.3); }\n .tmap-quick-connect .tc-drop-down a {\n display: inline;\n padding: 0;\n color: #5778d8;\n background: transparent; }\n .tmap-quick-connect .tc-drop-down a:hover {\n background: transparent;\n color: #5778d8;\n text-decoration: underline; }\n .tmap-quick-connect .tc-drop-down button {\n display: inline-block;\n padding: 0px 3px;\n text-align: center;\n color: #333333;\n line-height: 1.0; }\n .tmap-quick-connect .tc-drop-down button:hover {\n color: #ffffff; }\n .tmap-quick-connect .tc-drop-down button svg {\n fill: inherit; }\n .tmap-quick-connect .tc-drop-down button svg:hover {\n fill: #ffffff; }\n",
"title": "$:/plugins/felixhayashi/tiddlymap/layout",
"type": "text/vnd.tiddlywiki",
"tags": [
"$:/tags/Stylesheet"
]
},
"$:/plugins/felixhayashi/tiddlymap/js/AbstractEdgeTypeSubscriber": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/AbstractEdgeTypeSubscriber",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/AbstractEdgeTypeSubscriber\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\nvar _EdgeType = require('$:/plugins/felixhayashi/tiddlymap/js/EdgeType');\n\nvar _EdgeType2 = _interopRequireDefault(_EdgeType);\n\nvar _exception = require('$:/plugins/felixhayashi/tiddlymap/js/exception');\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\n * Super class for all edge type subscribers.\n */\nvar AbstractEdgeTypeSubscriber = function () {\n\n /**\n * @param {Object.<id, EdgeType>} allEdgeTypes - A list of all EdgeType instances that\n * are currently in the system. Each subscriber may use this list to build up an\n * index or perform mappings etc. Note that this list does not include types that are\n * just about to be inserted. Therefore, this list should only be used, if needed,\n * in the context of edge retrieval via loadEdges.\n * @param {number} [priority} - Subscribers with a higher priority get executed earlier\n * @param {boolean} [skipOthers] - In case of insert and delete operations: Whether or\n * not to skip any subsequent subscribers that also can handle the edge type\n * but have a lower priority assigned.\n * @param {boolean} [ignore] - Whether or not to completely ignore this subscriber.\n * This flag is useful if you want to dynamically at runtime whether or not to\n * include the subscriber.\n */\n function AbstractEdgeTypeSubscriber(allEdgeTypes) {\n var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},\n _ref$priority = _ref.priority,\n priority = _ref$priority === undefined ? 0 : _ref$priority,\n _ref$skipOthers = _ref.skipOthers,\n skipOthers = _ref$skipOthers === undefined ? true : _ref$skipOthers,\n _ref$ignore = _ref.ignore,\n ignore = _ref$ignore === undefined ? false : _ref$ignore;\n\n _classCallCheck(this, AbstractEdgeTypeSubscriber);\n\n this.allEdgeTypes = allEdgeTypes;\n this.priority = priority;\n this.skipOthers = skipOthers;\n this.ignore = ignore;\n }\n\n /**\n * DI\n * @param {Tracker} tracker\n */\n\n\n _createClass(AbstractEdgeTypeSubscriber, [{\n key: 'setTracker',\n value: function setTracker(tracker) {\n this.tracker = tracker;\n }\n\n /**\n * Returns all edges stored in the specified tiddler.\n *\n * @interface\n * @param {Tiddler} tObj - the tiddler that holds the references.\n * @param {Object<TiddlerReference, boolean>} toWL - a whitelist of tiddlers that are allowed to\n * be included in the result.\n * @param {Object<id, EdgeType>} [typeWL] - a whitelist that defines that only Tiddlers that are linked\n * via a type specified in the list may be included in the result. If typeWL is not passed it means\n * all types are included.\n * @return {Object<Id, Edge>|null}\n */\n\n }, {\n key: 'loadEdges',\n value: function loadEdges(tObj, toWL, typeWL) {\n\n throw new _exception.MissingOverrideError(this, 'loadEdges');\n }\n\n /**\n * Whether or not this subscriber instance can handle an edge of the given type.\n *\n * @interface\n * @param {EdgeType} edgeType\n * @return boolean\n */\n\n }, {\n key: 'canHandle',\n value: function canHandle(edgeType) {\n\n throw new _exception.MissingOverrideError(this, 'canHandle');\n }\n\n /**\n * Called by the Adapter whenever a type is inserted\n *\n * @param {Tiddler} tObj - the tiddler that holds the references.\n * @param {Edge} edge - the edge to be deleted\n * @param {EdgeType} type\n */\n\n }, {\n key: 'insertEdge',\n value: function insertEdge(tObj, edge, type) {}\n\n // optional\n\n /**\n * Called by the Adapter whenever a type is deleted\n *\n * @param {Tiddler} tObj - the tiddler that holds the references.\n * @param {Edge} edge - the edge to be deleted\n * @param {EdgeType} type\n */\n\n }, {\n key: 'deleteEdge',\n value: function deleteEdge(tObj, edge, type) {\n\n // optional\n\n }\n }]);\n\n return AbstractEdgeTypeSubscriber;\n}();\n\n/*** Exports *******************************************************/\n\nexports.default = AbstractEdgeTypeSubscriber;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/edgeTypeSubscriber/AbstractEdgeTypeSubscriber.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/AbstractMagicEdgeTypeSubscriber": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/AbstractMagicEdgeTypeSubscriber",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nvar _Edge = require('$:/plugins/felixhayashi/tiddlymap/js/Edge');\n\nvar _Edge2 = _interopRequireDefault(_Edge);\n\nvar _exception = require('$:/plugins/felixhayashi/tiddlymap/js/exception');\n\nvar _AbstractRefEdgeTypeSubscriber = require('$:/plugins/felixhayashi/tiddlymap/js/AbstractRefEdgeTypeSubscriber');\n\nvar _AbstractRefEdgeTypeSubscriber2 = _interopRequireDefault(_AbstractRefEdgeTypeSubscriber);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/AbstractMagicEdgeTypeSubscriber\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/**\n * @constructor\n */\nvar AbstractMagicEdgeTypeSubscriber = function (_AbstractRefEdgeTypeS) {\n _inherits(AbstractMagicEdgeTypeSubscriber, _AbstractRefEdgeTypeS);\n\n /**\n * @inheritDoc\n */\n function AbstractMagicEdgeTypeSubscriber(allEdgeTypes, options) {\n _classCallCheck(this, AbstractMagicEdgeTypeSubscriber);\n\n // later used for edge retrieval to identify those fields that hold connections\n var _this = _possibleConstructorReturn(this, (AbstractMagicEdgeTypeSubscriber.__proto__ || Object.getPrototypeOf(AbstractMagicEdgeTypeSubscriber)).call(this, allEdgeTypes, options));\n\n _this.edgeTypesByFieldName = _utils2.default.makeHashMap();\n\n for (var id in allEdgeTypes) {\n\n var edgeType = allEdgeTypes[id];\n if (_this.canHandle(edgeType)) {\n _this.edgeTypesByFieldName[edgeType.name] = edgeType;\n }\n }\n\n return _this;\n }\n\n /**\n * Returns all references to other tiddlers stored in the specified tiddler.\n *\n * @interface\n * @param {Tiddler} tObj - the tiddler that holds the references.\n * @param {String} fieldName - the name of the field to get the reference from.\n * @param {Object<TiddlerReference, boolean>} toWL - a whitelist of tiddlers that are allowed to\n * be included in the result.\n * @return {Object<Id, Edge>|null}\n */\n\n\n _createClass(AbstractMagicEdgeTypeSubscriber, [{\n key: 'getReferencesFromField',\n value: function getReferencesFromField(tObj, fieldName, toWL) {\n\n throw new _exception.MissingOverrideError(this, 'getReferencesFromField');\n }\n }, {\n key: 'getReferences',\n\n\n /**\n * @inheritDoc\n */\n value: function getReferences(tObj, toWL, typeWL) {\n\n var refsGroupedByType = _utils2.default.makeHashMap();\n var fieldNames = tObj.fields;\n\n for (var fieldName in fieldNames) {\n\n var type = this.edgeTypesByFieldName[fieldName];\n\n if (!type || typeWL && !typeWL[type.id]) continue;\n\n var toRefs = this.getReferencesFromField(tObj, fieldName, toWL);\n\n if (toRefs && toRefs.length) {\n refsGroupedByType[type.id] = toRefs;\n }\n }\n\n return refsGroupedByType;\n }\n }]);\n\n return AbstractMagicEdgeTypeSubscriber;\n}(_AbstractRefEdgeTypeSubscriber2.default);\n\n/*** Exports *******************************************************/\n\nexports.default = AbstractMagicEdgeTypeSubscriber;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/edgeTypeSubscriber/AbstractMagicEdgeTypeSubscriber.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/AbstractRefEdgeTypeSubscriber": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/AbstractRefEdgeTypeSubscriber",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nvar _Edge = require('$:/plugins/felixhayashi/tiddlymap/js/Edge');\n\nvar _Edge2 = _interopRequireDefault(_Edge);\n\nvar _exception = require('$:/plugins/felixhayashi/tiddlymap/js/exception');\n\nvar _AbstractEdgeTypeSubscriber = require('$:/plugins/felixhayashi/tiddlymap/js/AbstractEdgeTypeSubscriber');\n\nvar _AbstractEdgeTypeSubscriber2 = _interopRequireDefault(_AbstractEdgeTypeSubscriber);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/AbstractRefEdgeTypeSubscriber\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\n/*** Code **********************************************************/\n\n/**\n * Parent class for all subscribers that retrieve or store\n * non-TiddlyMap edges ({@see TmapEdgeTypeSubscriber) from a tiddler,\n * for example tag or list references.\n */\nvar AbstractRefEdgeTypeSubscriber = function (_AbstractEdgeTypeSubs) {\n _inherits(AbstractRefEdgeTypeSubscriber, _AbstractEdgeTypeSubs);\n\n function AbstractRefEdgeTypeSubscriber() {\n _classCallCheck(this, AbstractRefEdgeTypeSubscriber);\n\n return _possibleConstructorReturn(this, (AbstractRefEdgeTypeSubscriber.__proto__ || Object.getPrototypeOf(AbstractRefEdgeTypeSubscriber)).apply(this, arguments));\n }\n\n _createClass(AbstractRefEdgeTypeSubscriber, [{\n key: 'loadEdges',\n\n\n /**\n * @inheritDoc\n */\n value: function loadEdges(tObj, toWL, typeWL) {\n\n // references to other tiddlers grouped by their edge type\n var refsByType = this.getReferences(tObj, toWL, typeWL);\n\n if (!refsByType || !_utils2.default.hasElements(refsByType)) return;\n\n var fromId = tObj.fields['tmap.id'];\n var idByT = $tm.tracker.getIdsByTiddlers();\n var allETy = this.allEdgeTypes;\n var fromTRef = _utils2.default.getTiddlerRef(tObj);\n\n var edges = _utils2.default.makeHashMap();\n\n for (var typeId in refsByType) {\n\n var toRefs = refsByType[typeId];\n\n if (!toRefs) {\n continue;\n }\n\n var type = allETy[typeId];\n for (var i = toRefs.length; i--;) {\n var toTRef = toRefs[i];\n\n if (!toTRef || !$tw.wiki.tiddlerExists(toTRef) || _utils2.default.isSystemOrDraft(toTRef) || toWL && !toWL[toTRef]) {\n continue;\n }\n\n var id = type.id + $tw.utils.hashString(fromTRef + toTRef);\n edges[id] = new _Edge2.default(fromId, idByT[toTRef], type.id, id);\n }\n }\n\n return edges;\n }\n\n /**\n * Returns a list of tiddlers (= tiddler names) that are targeted by the specified tiddler.\n * Note: All referenced tiddlers have to be grouped by their edge type.\n *\n * @interface\n * @param {Tiddler} tObj - the tiddler that holds the references.\n * @param {Object<TiddlerReference, boolean>} toWL - a whitelist of tiddlers that are allowed to\n * be included in the result.\n * @param {Object<id, EdgeType>} typeWL - a whitelist that defines that only Tiddlers that are linked\n * via a type specified in the list may be included in the result.\n * @return {Object<string, TiddlerReference[]>|null} a list of referenced tiddlers grouped by their edge type.\n */\n\n }, {\n key: 'getReferences',\n value: function getReferences(tObj, toWL, typeWL) {\n\n throw new _exception.MissingOverrideError(this, 'getReferences');\n }\n }]);\n\n return AbstractRefEdgeTypeSubscriber;\n}(_AbstractEdgeTypeSubscriber2.default);\n\n/*** Exports *******************************************************/\n\nexports.default = AbstractRefEdgeTypeSubscriber;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/edgeTypeSubscriber/AbstractRefEdgeTypeSubscriber.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/EdgeTypeSubscriberRegistry": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/EdgeTypeSubscriberRegistry",
"text": "\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n// @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/EdgeTypeSubscriberRegistry\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/**\n * Registry to store and retrieve EdgeTypeSubcriber modules that are responsible\n * for handling the retrieval, insertion and deletion of EdgeType objects.\n */\nvar EdgeTypeSubscriberRegistry = function () {\n\n /**\n * @param {AbstractEdgeTypeSubscriber[]} subscribers\n * @param {EdgeType[]} allEdgeTypes\n * @param {Tracker} tracker\n */\n function EdgeTypeSubscriberRegistry(subscribers, allEdgeTypes, tracker) {\n _classCallCheck(this, EdgeTypeSubscriberRegistry);\n\n this.subscriberClasses = subscribers;\n this.tracker = tracker;\n\n this.updateIndex(allEdgeTypes);\n }\n\n /**\n * Gets all matching subscribers for a type.\n *\n * @param {EdgeType} edgeType\n * @returns AbstractEdgeTypeSubscriber[]\n */\n\n\n _createClass(EdgeTypeSubscriberRegistry, [{\n key: \"getAllForType\",\n value: function getAllForType(edgeType) {\n\n var allSubscribers = this.allSubscribers;\n var subscribersForType = [];\n\n for (var i = 0, l = allSubscribers.length; i < l; i++) {\n\n if (allSubscribers[i].canHandle(edgeType)) {\n\n subscribersForType.push(allSubscribers[i]);\n\n if (allSubscribers[i].skipOthers) {\n break;\n }\n }\n }\n\n return subscribersForType;\n }\n\n /**\n * Gets all subscribers.\n *\n * @returns AbstractEdgeTypeSubscriber[]\n */\n\n }, {\n key: \"getAll\",\n value: function getAll() {\n\n return this.allSubscribers;\n }\n\n /**\n * Indexes all subscribers. Moreover, subscribers get linked to the edge\n * types that currently exist in the wiki.\n *\n * This method should be called everytime after an edge type is added or\n * removed in the system.\n *\n * @param {EdgeType[]} allEdgeTypes\n */\n\n }, {\n key: \"updateIndex\",\n value: function updateIndex(allEdgeTypes) {\n\n var allSubscribers = [];\n\n // instantiate and register all active subscriber modules\n var subscriberClass = this.subscriberClasses;\n for (var moduleName in subscriberClass) {\n\n var subscriber = new subscriberClass[moduleName](allEdgeTypes);\n subscriber.setTracker(this.tracker);\n\n // ignore all subscribers that have their ignore flag set to false\n if (subscriber.ignore === true) {\n continue;\n }\n\n allSubscribers.push(subscriber);\n }\n\n // sort subscribers by priority\n allSubscribers.sort(function (s1, s2) {\n return s2.priority - s1.priority;\n });\n\n this.allSubscribers = allSubscribers;\n }\n }]);\n\n return EdgeTypeSubscriberRegistry;\n}();\n\n/*** Exports *******************************************************/\n\nexports.default = EdgeTypeSubscriberRegistry;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/edgeTypeSubscriber/EdgeTypeSubscriberRegistry.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/tmap": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/tmap",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.TmapEdgeTypeSubscriber = undefined;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nvar _Edge = require('$:/plugins/felixhayashi/tiddlymap/js/Edge');\n\nvar _Edge2 = _interopRequireDefault(_Edge);\n\nvar _AbstractEdgeTypeSubscriber = require('$:/plugins/felixhayashi/tiddlymap/js/AbstractEdgeTypeSubscriber');\n\nvar _AbstractEdgeTypeSubscriber2 = _interopRequireDefault(_AbstractEdgeTypeSubscriber);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/tmap\ntype: application/javascript\nmodule-type: tmap.edgetypehandler\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\n/*** Code **********************************************************/\n\n/**\n * TiddlyMap's original EdgeTypeSubscriber. It will store and retrieve edges by relying on\n * json stored in a tiddler field.\n *\n * @constructor\n */\nvar TmapEdgeTypeSubscriber = function (_AbstractEdgeTypeSubs) {\n _inherits(TmapEdgeTypeSubscriber, _AbstractEdgeTypeSubs);\n\n function TmapEdgeTypeSubscriber(allEdgeTypes) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n _classCallCheck(this, TmapEdgeTypeSubscriber);\n\n return _possibleConstructorReturn(this, (TmapEdgeTypeSubscriber.__proto__ || Object.getPrototypeOf(TmapEdgeTypeSubscriber)).call(this, allEdgeTypes, _extends({ priority: 0 }, options)));\n }\n\n /**\n * @inheritDoc\n */\n\n\n _createClass(TmapEdgeTypeSubscriber, [{\n key: 'loadEdges',\n value: function loadEdges(tObj, toWL, typeWL) {\n\n var connections = _utils2.default.parseFieldData(tObj, 'tmap.edges');\n if (!connections) {\n return;\n }\n\n var tById = this.tracker.getTiddlersByIds();\n var fromId = tObj.fields['tmap.id'];\n\n var edges = _utils2.default.makeHashMap();\n\n for (var conId in connections) {\n\n var con = connections[conId];\n var toTRef = tById[con.to];\n if (toTRef && (!toWL || toWL[toTRef]) && (!typeWL || typeWL[con.type])) {\n\n edges[conId] = new _Edge2.default(fromId, con.to, con.type, conId);\n }\n }\n\n return edges;\n }\n\n /**\n * @inheritDoc\n */\n\n }, {\n key: 'insertEdge',\n value: function insertEdge(tObj, edge, type) {\n\n // load existing connections\n var connections = _utils2.default.parseFieldData(tObj, 'tmap.edges', {});\n\n // assign new id if not present yet\n edge.id = edge.id || _utils2.default.genUUID();\n // add to connections object\n connections[edge.id] = { to: edge.to, type: type.id };\n\n // save\n _utils2.default.writeFieldData(tObj, 'tmap.edges', connections, $tm.config.sys.jsonIndentation);\n\n return edge;\n }\n\n /**\n * @inheritDoc\n */\n\n }, {\n key: 'deleteEdge',\n value: function deleteEdge(tObj, edge, type) {\n\n if (!edge.id) return;\n\n // load\n var connections = _utils2.default.parseFieldData(tObj, 'tmap.edges', {});\n\n // delete\n delete connections[edge.id];\n\n // save\n _utils2.default.writeFieldData(tObj, 'tmap.edges', connections, $tm.config.sys.jsonIndentation);\n\n return edge;\n }\n\n /**\n * @inheritDoc\n */\n\n }, {\n key: 'canHandle',\n value: function canHandle(edgeType) {\n\n return true;\n }\n }]);\n\n return TmapEdgeTypeSubscriber;\n}(_AbstractEdgeTypeSubscriber2.default);\n\n/*** Exports *******************************************************/\n\nexports.TmapEdgeTypeSubscriber = TmapEdgeTypeSubscriber;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/edgeTypeSubscriber/TmapEdgeTypeSubscriber.js.map\n",
"type": "application/javascript",
"module-type": "tmap.edgetypehandler"
},
"$:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/field": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/field",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.FieldEdgeTypeSubscriber = undefined;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nvar _AbstractMagicEdgeTypeSubscriber = require('$:/plugins/felixhayashi/tiddlymap/js/AbstractMagicEdgeTypeSubscriber');\n\nvar _AbstractMagicEdgeTypeSubscriber2 = _interopRequireDefault(_AbstractMagicEdgeTypeSubscriber);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/field\ntype: application/javascript\nmodule-type: tmap.edgetypehandler\n\n@preserve\n\n\\*/\n\n/**\n * The FieldEdgeTypeSubscriber deals with connections that are stored in form of tiddler fields.\n * In this case one field can only hold one connection.\n *\n * If an EdgeType with a \"tw-field\" namespace is inserted or deleted, the type's name\n * is interpreted as field name and the connection is stored or removed in a tiddler\n * field with of that name.\n *\n * E.g. creating an edge between the tiddlers \"Betsy\" and \"Dave\" with the type\n * tw-field:husband will create a field \"husband\" inside the \"Betsy\" tiddler and set\n * \"Dave\" as value.\n\n * Note: A single field can only hold one connection.\n *\n * @see http://tiddlymap.org/#tw-field\n *\n * @inheritDoc\n * @constructor\n */\nvar FieldEdgeTypeSubscriber = function (_AbstractMagicEdgeTyp) {\n _inherits(FieldEdgeTypeSubscriber, _AbstractMagicEdgeTyp);\n\n /**\n * @inheritDoc\n */\n function FieldEdgeTypeSubscriber(allEdgeTypes) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n _classCallCheck(this, FieldEdgeTypeSubscriber);\n\n return _possibleConstructorReturn(this, (FieldEdgeTypeSubscriber.__proto__ || Object.getPrototypeOf(FieldEdgeTypeSubscriber)).call(this, allEdgeTypes, _extends({ priority: 10 }, options)));\n }\n\n /**\n * @inheritDoc\n */\n\n\n _createClass(FieldEdgeTypeSubscriber, [{\n key: 'canHandle',\n value: function canHandle(edgeType) {\n\n return edgeType.namespace === 'tw-field';\n }\n\n /**\n * @override\n */\n\n }, {\n key: 'getReferencesFromField',\n value: function getReferencesFromField(tObj, fieldName, toWL) {\n\n // wrap in array\n return [tObj.fields[fieldName]];\n }\n\n /**\n * Stores and maybe overrides an edge in this tiddler\n */\n\n }, {\n key: 'insertEdge',\n value: function insertEdge(tObj, edge, type) {\n\n var toTRef = this.tracker.getTiddlerById(edge.to);\n if (toTRef == null) {\n // null or undefined\n return;\n }\n\n // only use the name without the private marker or the namespace\n _utils2.default.setField(tObj, type.name, toTRef);\n\n return edge;\n }\n }, {\n key: 'deleteEdge',\n\n\n /**\n * Deletes an edge in this tiddler\n */\n value: function deleteEdge(tObj, edge, type) {\n\n var toTRef = this.tracker.getTiddlerById(edge.to);\n\n if (toTRef == null) {\n // null or undefined\n return;\n }\n\n // only use the name without the private marker or the namespace\n _utils2.default.setField(tObj, type.name, undefined);\n\n return edge;\n }\n }]);\n\n return FieldEdgeTypeSubscriber;\n}(_AbstractMagicEdgeTypeSubscriber2.default);\n\n/*** Exports *******************************************************/\n\nexports.FieldEdgeTypeSubscriber = FieldEdgeTypeSubscriber;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/edgeTypeSubscriber/magicEdgeTypeSubscriber/FieldEdgeTypeSubscriber.js.map\n",
"type": "application/javascript",
"module-type": "tmap.edgetypehandler"
},
"$:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/filter": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/filter",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.FilterEdgeTypeSubstriber = undefined;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nvar _AbstractMagicEdgeTypeSubscriber = require('$:/plugins/felixhayashi/tiddlymap/js/AbstractMagicEdgeTypeSubscriber');\n\nvar _AbstractMagicEdgeTypeSubscriber2 = _interopRequireDefault(_AbstractMagicEdgeTypeSubscriber);\n\nvar _widget = require('$:/core/modules/widgets/widget.js');\n\nvar _widget2 = _interopRequireDefault(_widget);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/filter\ntype: application/javascript\nmodule-type: tmap.edgetypehandler\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\n/*** Code **********************************************************/\n\n/**\n * The FilterEdgeTypeSubstriber deals with connections that are stored inside\n * tiddler fields via a dynamic filter.\n *\n * @see http://tiddlymap.org/#tw-filter\n * @see https://github.com/felixhayashi/TW5-TiddlyMap/issues/206\n */\nvar FilterEdgeTypeSubstriber = function (_AbstractMagicEdgeTyp) {\n _inherits(FilterEdgeTypeSubstriber, _AbstractMagicEdgeTyp);\n\n /**\n * @inheritDoc\n */\n function FilterEdgeTypeSubstriber(allEdgeTypes) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n _classCallCheck(this, FilterEdgeTypeSubstriber);\n\n return _possibleConstructorReturn(this, (FilterEdgeTypeSubstriber.__proto__ || Object.getPrototypeOf(FilterEdgeTypeSubstriber)).call(this, allEdgeTypes, _extends({ priority: 10 }, options)));\n }\n\n /**\n * @inheritDoc\n */\n\n\n _createClass(FilterEdgeTypeSubstriber, [{\n key: 'canHandle',\n value: function canHandle(edgeType) {\n\n return edgeType.namespace === 'tw-filter';\n }\n\n /**\n * @override\n */\n\n }, {\n key: 'getReferencesFromField',\n value: function getReferencesFromField(tObj, fieldName, toWL) {\n\n var filter = tObj.fields[fieldName];\n\n // Solves https://github.com/felixhayashi/TW5-TiddlyMap/issues/278\n var parentWidget = new _widget2.default.widget({});\n parentWidget.setVariable(\"currentTiddler\", tObj.fields.title);\n var widget = new _widget2.default.widget({}, { \"parentWidget\": parentWidget });\n //noinspection UnnecessaryLocalVariableJS\n var toRefs = _utils2.default.getMatches(filter, toWL, widget);\n\n return toRefs;\n }\n\n /**\n * Stores and maybe overrides an edge in this tiddler\n */\n\n }, {\n key: 'insertEdge',\n value: function insertEdge(tObj, edge, type) {\n\n if (!edge.to) {\n return;\n }\n\n // get the name without the private marker or the namespace\n var name = type.name;\n var currentFilter = tObj.fields[name] || \"\";\n var toTRef = this.tracker.getTiddlerById(edge.to);\n // by treating the toTRef as a list of one, we can make\n // it safe to append to any filter.\n // \"tiddler\" -> \"tiddler\"\n // \"tiddler with spaces\" -> \"[[tiddler with spaces]]\"\n var safe_toTRef = $tw.utils.stringifyList([toTRef]);\n\n if (currentFilter.length > 0) {\n safe_toTRef = \" \" + safe_toTRef;\n }\n\n // save\n _utils2.default.setField(tObj, name, currentFilter + safe_toTRef);\n\n return edge;\n }\n }]);\n\n return FilterEdgeTypeSubstriber;\n}(_AbstractMagicEdgeTypeSubscriber2.default);\n\n/*** Exports *******************************************************/\n\nexports.FilterEdgeTypeSubstriber = FilterEdgeTypeSubstriber;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/edgeTypeSubscriber/magicEdgeTypeSubscriber/FilterEdgeTypeSubscriber.js.map\n",
"type": "application/javascript",
"module-type": "tmap.edgetypehandler"
},
"$:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/list": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/list",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ListEdgeTypeSubscriber = undefined;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nvar _AbstractMagicEdgeTypeSubscriber = require('$:/plugins/felixhayashi/tiddlymap/js/AbstractMagicEdgeTypeSubscriber');\n\nvar _AbstractMagicEdgeTypeSubscriber2 = _interopRequireDefault(_AbstractMagicEdgeTypeSubscriber);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/list\ntype: application/javascript\nmodule-type: tmap.edgetypehandler\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\n/*** Code **********************************************************/\n\n/**\n * The ListEdgeTypeSubstriber deals with connections that are stored inside\n * tiddler fields in a tiddler-list format.\n *\n * If an EdgeType with a 'tw-list\" namespace is inserted or deleted, the type's name\n * is interpreted as field name and the list of connections is stored or removed in a tiddler\n * field with of that name. Each outgoing connection to a tiddler is stored by\n * inserting the title the edge is pointing to into a list.\n *\n * Say you the user creates a connection between tiddler \"Dawna Dozal\" and\n * tiddler \"Toney Thacker\" and names the connection \"tw-list:friends\". Then a field\n * named \"friends\" will be created in tiddler \"Dawna Dozal\" and \"Toney Thacker\" will be\n * added to this field.\n *\n * @see http://tiddlymap.org/#tw-list\n */\nvar ListEdgeTypeSubscriber = function (_AbstractMagicEdgeTyp) {\n _inherits(ListEdgeTypeSubscriber, _AbstractMagicEdgeTyp);\n\n /**\n * @inheritDoc\n */\n function ListEdgeTypeSubscriber(allEdgeTypes) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n _classCallCheck(this, ListEdgeTypeSubscriber);\n\n return _possibleConstructorReturn(this, (ListEdgeTypeSubscriber.__proto__ || Object.getPrototypeOf(ListEdgeTypeSubscriber)).call(this, allEdgeTypes, _extends({ priority: 10 }, options)));\n }\n\n /**\n * @inheritDoc\n */\n\n\n _createClass(ListEdgeTypeSubscriber, [{\n key: 'canHandle',\n value: function canHandle(edgeType) {\n\n return edgeType.namespace === 'tw-list';\n }\n\n /**\n * @override\n */\n\n }, {\n key: 'getReferencesFromField',\n value: function getReferencesFromField(tObj, fieldName, toWL) {\n\n return $tw.utils.parseStringArray(tObj.fields[fieldName]);\n }\n\n /**\n * Stores and maybe overrides an edge in this tiddler\n */\n\n }, {\n key: 'insertEdge',\n value: function insertEdge(tObj, edge, type) {\n\n if (!edge.to) {\n return;\n }\n\n // get the name without the private marker or the namespace\n var name = type.name;\n\n var list = $tw.utils.parseStringArray(tObj.fields[name]);\n // we need to clone the array since tiddlywiki might directly\n // returned the auto-parsed field value (as in case of tags, or list)\n // and this array would be read only!\n list = (list || []).slice();\n\n // transform\n var toTRef = this.tracker.getTiddlerById(edge.to);\n\n list.push(toTRef);\n\n // save\n _utils2.default.setField(tObj, name, $tw.utils.stringifyList(list));\n\n return edge;\n }\n }, {\n key: 'deleteEdge',\n\n\n /**\n * Deletes an edge in this tiddler\n */\n value: function deleteEdge(tObj, edge, type) {\n\n var list = $tw.utils.parseStringArray(tObj.fields[type.name]);\n // we need to clone the array since tiddlywiki might directly\n // returned the auto-parsed field value (as in case of tags, or list)\n // and this array would be read only!\n list = (list || []).slice();\n\n // transform\n var toTRef = this.tracker.getTiddlerById(edge.to);\n\n var index = list.indexOf(toTRef);\n if (index > -1) {\n list.splice(index, 1);\n }\n\n // @see https://github.com/felixhayashi/TW5-TiddlyMap/issues/288\n var stringList = void 0;\n if (list.length > 0) {\n stringList = $tw.utils.stringifyList(list);\n }\n // save\n _utils2.default.setField(tObj, type.name, stringList);\n\n return edge;\n }\n }]);\n\n return ListEdgeTypeSubscriber;\n}(_AbstractMagicEdgeTypeSubscriber2.default);\n\n/*** Exports *******************************************************/\n\nexports.ListEdgeTypeSubscriber = ListEdgeTypeSubscriber;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/edgeTypeSubscriber/magicEdgeTypeSubscriber/ListEdgeTypeSubscriber.js.map\n",
"type": "application/javascript",
"module-type": "tmap.edgetypehandler"
},
"$:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/body/link": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/body/link",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.LinkEdgeTypeSubscriber = undefined;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _AbstractRefEdgeTypeSubscriber = require('$:/plugins/felixhayashi/tiddlymap/js/AbstractRefEdgeTypeSubscriber');\n\nvar _AbstractRefEdgeTypeSubscriber2 = _interopRequireDefault(_AbstractRefEdgeTypeSubscriber);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/body/link\ntype: application/javascript\nmodule-type: tmap.edgetypehandler\n\n@preserve\n\n\\*/\n\n/**\n * The LinkEdgeTypeSubscriber deals with connections that are stored inside\n * a tiddler' text field.\n *\n * Note: This subscriber only retrieves edges, however doesn't store or delete them.\n *\n * @see http://tiddlymap.org/#tw-body\n */\nvar LinkEdgeTypeSubscriber = function (_AbstractRefEdgeTypeS) {\n _inherits(LinkEdgeTypeSubscriber, _AbstractRefEdgeTypeS);\n\n /**\n * @inheritDoc\n */\n function LinkEdgeTypeSubscriber(allEdgeTypes) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n _classCallCheck(this, LinkEdgeTypeSubscriber);\n\n return _possibleConstructorReturn(this, (LinkEdgeTypeSubscriber.__proto__ || Object.getPrototypeOf(LinkEdgeTypeSubscriber)).call(this, allEdgeTypes, _extends({ priority: 20 }, options)));\n }\n\n /**\n * @inheritDoc\n */\n\n\n _createClass(LinkEdgeTypeSubscriber, [{\n key: 'canHandle',\n value: function canHandle(edgeType) {\n\n return edgeType.id === 'tw-body:link';\n }\n\n /**\n * @inheritDoc\n */\n\n }, {\n key: 'getReferences',\n value: function getReferences(tObj, toWL, typeWL) {\n\n if (typeWL && !typeWL['tw-body:link']) {\n return;\n }\n\n var toRefs = $tw.wiki.getTiddlerLinks(tObj.fields.title);\n\n if (!toRefs || !toRefs.length) {\n return;\n }\n\n return { 'tw-body:link': toRefs };\n }\n }]);\n\n return LinkEdgeTypeSubscriber;\n}(_AbstractRefEdgeTypeSubscriber2.default);\n\n/*** Exports *******************************************************/\n\nexports.LinkEdgeTypeSubscriber = LinkEdgeTypeSubscriber;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/edgeTypeSubscriber/refEdgeTypeSubscriber/LinkEdgeTypeSubscriber.js.map\n",
"type": "application/javascript",
"module-type": "tmap.edgetypehandler"
},
"$:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/body/transclude": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/body/transclude",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.TranscludeEdgeTypeSubscriber = undefined;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _AbstractRefEdgeTypeSubscriber = require('$:/plugins/felixhayashi/tiddlymap/js/AbstractRefEdgeTypeSubscriber');\n\nvar _AbstractRefEdgeTypeSubscriber2 = _interopRequireDefault(_AbstractRefEdgeTypeSubscriber);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/modules/edge-type-handler/body/transclude\ntype: application/javascript\nmodule-type: tmap.edgetypehandler\n\n@preserve\n\n\\*/\n\n/**\n * The TranscludeEdgeTypeSubscriber retrieves connections that result tiddler transclusions.\n *\n * Note: This subscriber only retrieves edges, however doesn't store or delete them. It only\n * works if the `$tw.wiki.getTiddlerTranscludes` method is present in the wiki.\n */\nvar TranscludeEdgeTypeSubscriber = function (_AbstractRefEdgeTypeS) {\n _inherits(TranscludeEdgeTypeSubscriber, _AbstractRefEdgeTypeS);\n\n /**\n * @inheritDoc\n */\n function TranscludeEdgeTypeSubscriber(allEdgeTypes) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n _classCallCheck(this, TranscludeEdgeTypeSubscriber);\n\n return _possibleConstructorReturn(this, (TranscludeEdgeTypeSubscriber.__proto__ || Object.getPrototypeOf(TranscludeEdgeTypeSubscriber)).call(this, allEdgeTypes, _extends({\n priority: 20,\n ignore: typeof $tw.wiki.getTiddlerTranscludes !== 'function'\n }, options)));\n }\n\n /**\n * @inheritDoc\n */\n\n\n _createClass(TranscludeEdgeTypeSubscriber, [{\n key: 'canHandle',\n value: function canHandle(edgeType) {\n\n return edgeType.id === 'tw-body:transclude';\n }\n\n /**\n * @inheritDoc\n */\n\n }, {\n key: 'getReferences',\n value: function getReferences(tObj, toWL, typeWL) {\n\n if (typeWL && !typeWL['tw-body:transclude']) {\n return;\n }\n\n var toRefs = $tw.wiki.getTiddlerTranscludes(tObj.fields.title);\n\n if (!toRefs || !toRefs.length) {\n return;\n }\n\n return { 'tw-body:transclude': toRefs };\n }\n }]);\n\n return TranscludeEdgeTypeSubscriber;\n}(_AbstractRefEdgeTypeSubscriber2.default);\n\n/*** Exports *******************************************************/\n\nexports.TranscludeEdgeTypeSubscriber = TranscludeEdgeTypeSubscriber;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/edgeTypeSubscriber/refEdgeTypeSubscriber/TranscludeEdgeTypeSubscriber.js.map\n",
"type": "application/javascript",
"module-type": "tmap.edgetypehandler"
},
"$:/plugins/felixhayashi/tiddlymap/js/Edge": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/Edge",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } } // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/Edge\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\n/*** Code **********************************************************/\n\n/**\n * @constructor\n */\nvar Edge = function Edge(from, to, type, id) {\n _classCallCheck(this, Edge);\n\n this.from = from;\n this.to = to;\n this.type = type;\n this.id = id || _utils2.default.genUUID();\n};\n\n/*** Exports *******************************************************/\n\nexports.default = Edge;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/graph/Edge.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/EdgeType": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/EdgeType",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _MapElementType2 = require('$:/plugins/felixhayashi/tiddlymap/js/MapElementType');\n\nvar _MapElementType3 = _interopRequireDefault(_MapElementType2);\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nvar _environment = require('$:/plugins/felixhayashi/tiddlymap/js/lib/environment');\n\nvar env = _interopRequireWildcard(_environment);\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/EdgeType\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\n/*** Code **********************************************************/\n\n/**\n * This class is used to abstract edge types. It facilitates the parsing\n * of style information, the translation of type names into actual type data\n * or the persistance of edge type data.\n *\n * Note: EdgeType instances are immutable (frozen).\n */\nvar EdgeType = function (_MapElementType) {\n _inherits(EdgeType, _MapElementType);\n\n /**\n * @param {EdgeTypeId} id\n * @param {Object} [data] @see http://visjs.org/docs/network/edges.html\n */\n function EdgeType(id, data) {\n _classCallCheck(this, EdgeType);\n\n // we do not simply use the provided id but disassemble and\n // reassemble it again to ensure the id is well formatted.\n var _EdgeType$getIdParts = EdgeType.getIdParts(id),\n marker = _EdgeType$getIdParts.marker,\n namespace = _EdgeType$getIdParts.namespace,\n name = _EdgeType$getIdParts.name;\n\n id = EdgeType.getId(marker, namespace, name);\n\n // call the parent constructor\n\n var _this = _possibleConstructorReturn(this, (EdgeType.__proto__ || Object.getPrototypeOf(EdgeType)).call(this, id, env.path.edgeTypes, EdgeType.fieldMeta, data));\n\n _this.id = id;\n _this.marker = marker;\n _this.name = name;\n _this.namespace = namespace;\n\n var arrows = (_this.style || {}).arrows;\n\n if (arrows) {\n\n _this.invertedArrow = isArrowEnabled(arrows, 'from');\n _this.toArrow = isArrowEnabled(arrows, 'to') || isArrowEnabled(arrows, 'middle');\n // determine if bi arrows (either from+to or no arrows)\n _this.biArrow = _this.invertedArrow === _this.toArrow;\n\n if (_this.biArrow) {\n _this.toArrow = true;\n _this.invertedArrow = true;\n }\n } else {\n\n _this.toArrow = true;\n }\n\n Object.freeze(_this);\n\n return _this;\n }\n\n /**\n * Returns an object holding the parts that make up the edge type id.\n *\n * @param {EdgeTypeId} id\n * @return {{marker: (*|string), namespace: (*|string), name: (*|string)}}\n */\n\n\n _createClass(EdgeType, [{\n key: 'getLabel',\n value: function getLabel() {\n\n return this.label || this.name;\n }\n }], [{\n key: 'getIdParts',\n value: function getIdParts() {\n var id = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';\n\n\n id = _utils2.default.getWithoutPrefix(id, env.path.edgeTypes + '/');\n var match = id.match(edgeTypeRegex) || [];\n\n return {\n marker: match[1] || '',\n namespace: match[3] && match[2] || '',\n name: match[3] || match[2] || ''\n };\n }\n }, {\n key: 'getId',\n\n\n /**\n * Creates an {@link EdgeTypeId} from a set of parts that make up the id.\n * If it is not possible to create the id from the parts, the default\n * edge type 'tmap:unknown' is returned.\n *\n * @param {string} marker\n * @param {string} namespace\n * @param {string} name\n * @return {EdgeTypeId}\n */\n value: function getId() {\n var marker = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';\n var namespace = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n var name = arguments[2];\n\n\n return name ? marker + (namespace && namespace + ':') + name : 'tmap:unknown';\n }\n }]);\n\n return EdgeType;\n}(_MapElementType3.default);\n\n/**\n * @see https://github.com/babel/babel/issues/4854\n * @param {string} id - Either the edge type id (name)\n * or a tiddler reference denoting the type or an\n * `EdgeType` object (that is directly bounced back). If the\n * id can be translated into a tiddler object that resides in\n * the edge type path, then its data is retrieved automatically.\n */\n\n\nEdgeType.getInstance = function (id) {\n return id instanceof EdgeType ? id : new EdgeType(id);\n};\n\nEdgeType.fieldMeta = _extends({}, _MapElementType3.default.fieldMeta, {\n 'label': {},\n 'show-label': {}\n});\n\n/**\n *\n * @param {Object} arrows\n * @param {('from'|'to'|'middle')} direction\n * @return {boolean}\n */\nvar isArrowEnabled = function isArrowEnabled(arrows, direction) {\n\n var arrow = arrows[direction];\n\n if (arrow == null && direction === 'to') {\n // if the arrow is not further specified and its direction is to\n // we regard it as enabled.\n return true;\n }\n\n return (typeof arrow === 'undefined' ? 'undefined' : _typeof(arrow)) === 'object' ? arrow.enabled !== false : arrow === true;\n};\n\n/**\n * An edge-type id consists of the following parts of which the\n * first two are optional: `[marker][namespace:]name`\n *\n * The colon is not considered to be part of the namespace.\n */\nvar edgeTypeRegex = new RegExp('^(_?)([^:_][^:]*):?([^:]*)');\n\n/*** Exports *******************************************************/\n\nexports.default = EdgeType;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/graph/EdgeType.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/MapElementType": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/MapElementType",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/MapElementType\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/*** Code **********************************************************/\n\n/**\n * @abstract\n */\nvar MapElementType = function () {\n function MapElementType(id, root, fieldMeta, data) {\n _classCallCheck(this, MapElementType);\n\n this.id = id;\n this.root = root;\n this._fieldMeta = fieldMeta;\n this.fullPath = this.root + '/' + this.id;\n this.isShipped = $tw.wiki.getSubTiddler($tm.path.pluginRoot, this.fullPath);\n\n // finally get the data\n this._load(data || this.fullPath);\n }\n\n /**\n * Load the type's data. Depending on the constructor arguments,\n * the data source can be a tiddler, a type store\n *\n * @private\n */\n\n\n _createClass(MapElementType, [{\n key: '_load',\n value: function _load(data) {\n\n if (!data) {\n\n return;\n }\n\n if (typeof data === 'string') {\n // assume id or full path\n\n var isFullPath = _utils2.default.startsWith(data, this.root);\n var tRef = isFullPath ? data : this.root + '/' + data;\n this._loadFromTiddler(tRef);\n } else if (data instanceof $tw.Tiddler) {\n\n this._loadFromTiddler(data);\n } else if ((typeof data === 'undefined' ? 'undefined' : _typeof(data)) === 'object') {\n // = type or a data object\n\n for (var field in this._fieldMeta) {\n this[field] = data[field];\n }\n }\n }\n\n /**\n * Retrieve all data from the tiddler provided. If a shadow tiddler\n * with the same id exists, its data is merged during the load\n * process.\n *\n * @private\n */\n\n }, {\n key: '_loadFromTiddler',\n value: function _loadFromTiddler(tiddler) {\n\n var tObj = _utils2.default.getTiddler(tiddler);\n\n if (!tObj) {\n\n return;\n }\n\n var shadowTObj = $tw.wiki.getSubTiddler($tm.path.pluginRoot, this.fullPath) || {};\n\n // copy object to allow manipulation of the data\n var rawData = $tw.utils.extend({}, shadowTObj.fields, tObj.fields);\n // allow parsers to transform the raw field data\n for (var field in this._fieldMeta) {\n\n var parser = this._fieldMeta[field].parse;\n var rawVal = rawData[field];\n\n this[field] = parser ? parser.call(this, rawVal) : rawVal;\n }\n }\n\n /**\n * Method to determine whether or not this type exists. A type\n * exists if a tiddler with the type's id can be found below\n * the type's root path.\n *\n * @return {boolean} True if the type exists, false otherwise.\n */\n\n }, {\n key: 'exists',\n value: function exists() {\n\n return _utils2.default.tiddlerExists(this.fullPath);\n }\n }, {\n key: 'setStyle',\n value: function setStyle(style, isMerge) {\n\n // preprocessing: try to turn string into json\n if (typeof style === 'string') {\n\n style = _utils2.default.parseJSON(style);\n }\n\n // merge or override\n if ((typeof style === 'undefined' ? 'undefined' : _typeof(style)) === 'object') {\n\n if (isMerge) {\n\n _utils2.default.merge(this.style, style);\n } else {\n\n this.style = style;\n }\n }\n }\n\n /**\n * Store the type object as tiddler in the wiki. If the `tRef`\n * property is not provided, the default type path prefix\n * will be used with the type id appended. Stringifiers provided in\n * the field meta object (that was passed to the constructor) are\n * called.\n *\n * @param {string} [tRef] - If `tRef` is provided, the type\n * data will be written into this tiddler and the id property\n * is added as extra field value. Only do this is only for\n * dumping purposes!\n * @param {boolean} [silently=false] do not update the modification date\n */\n\n }, {\n key: 'save',\n value: function save(tRef, silently) {\n\n if (!tRef) {\n\n tRef = this.fullPath;\n } else if (typeof tRef !== 'string') {\n\n return;\n }\n\n // also add an empty text field to guard against\n // https://github.com/Jermolene/TiddlyWiki5/issues/2025\n var fields = {\n title: tRef,\n text: ''\n };\n\n if (!_utils2.default.startsWith(tRef, this.root)) {\n\n // = not the standard path for storing this type!\n // in this case we add the id to the output.\n fields.id = this.id;\n }\n\n // allow parsers to transform the raw field data\n for (var field in this._fieldMeta) {\n\n var stringify = this._fieldMeta[field].stringify;\n\n fields[field] = stringify ? stringify.call(this, this[field]) : this[field];\n }\n\n if (!this.exists()) {\n // newly created\n Object.assign(fields, $tw.wiki.getCreationFields());\n }\n\n if (silently !== true) {\n // add modification date to the output;\n Object.assign(fields, $tw.wiki.getModificationFields());\n }\n\n $tw.wiki.addTiddler(new $tw.Tiddler(fields));\n }\n }]);\n\n return MapElementType;\n}();\n\n/**\n * A list of fields that are used as data identifiers. Only these\n * listed keys are acknowledged by the load and save functions in\n * this class.\n *\n * This object resembles tw's field modules that are used by\n * `boot.js` to decide how fields are parsed and stringified again.\n */\n\n\nMapElementType.fieldMeta = {\n 'description': {},\n 'style': {\n parse: _utils2.default.parseJSON,\n stringify: JSON.stringify\n },\n 'modified': {}, // translation handled by TW's core\n 'created': {} // translation handled by TW's core\n};\n\n/*** Exports *******************************************************/\n\nexports.default = MapElementType;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/graph/MapElementType.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/NodeType": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/NodeType",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _MapElementType2 = require('$:/plugins/felixhayashi/tiddlymap/js/MapElementType');\n\nvar _MapElementType3 = _interopRequireDefault(_MapElementType2);\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/NodeType\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\n/*** Code **********************************************************/\n\n/**\n * Used to define the type of a node.\n *\n * Note: NodeType instances are immutable (frozen).\n */\nvar NodeType = function (_MapElementType) {\n _inherits(NodeType, _MapElementType);\n\n function NodeType(id, data) {\n _classCallCheck(this, NodeType);\n\n id = typeof id === 'string' ? _utils2.default.getWithoutPrefix(id, $tm.path.nodeTypes + '/') : 'tmap:unknown';\n\n // call the parent constructor\n\n var _this = _possibleConstructorReturn(this, (NodeType.__proto__ || Object.getPrototypeOf(NodeType)).call(this, id, $tm.path.nodeTypes, NodeType.fieldMeta, data));\n\n Object.freeze(_this);\n\n return _this;\n }\n\n /**\n * Get all tiddlers that inherit this type.\n *\n * @param {Array<TiddlerReference>} [src=$tw.wiki.allTitles()] - A list\n * of tiddlers that is searched for inheritors.\n * @return {Array<TiddlerReference>} The inheritors.\n */\n\n\n _createClass(NodeType, [{\n key: 'getInheritors',\n value: function getInheritors(src) {\n\n return this.scope ? _utils2.default.getMatches(this.scope, src || $tw.wiki.allTitles()) : [];\n }\n }]);\n\n return NodeType;\n}(_MapElementType3.default);\n\n/**\n * @see https://github.com/babel/babel/issues/4854\n * @param {string} id - Either the edge type id (name)\n * or a tiddler reference denoting the type or an\n * `EdgeType` object (that is directly bounced back). If the\n * id can be translated into a tiddler object that resides in\n * the edge type path, then its data is retrieved automatically.\n */\n\n\nNodeType.getInstance = function (id) {\n return id instanceof NodeType ? id : new NodeType(id);\n};\n\nNodeType.fieldMeta = _extends({}, _MapElementType3.default.fieldMeta, {\n 'view': {},\n 'priority': {\n parse: function parse(raw) {\n return isNaN(raw) ? 1 : parseInt(raw);\n },\n stringify: function stringify(num) {\n return _utils2.default.isInteger(num) ? num.toString() : '1';\n }\n },\n 'scope': {\n stringify: _utils2.default.getWithoutNewLines\n },\n 'fa-icon': {},\n 'tw-icon': {}\n});\n\n/*** Exports *******************************************************/\n\nexports.default = NodeType;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/graph/NodeType.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/ViewAbstraction": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/ViewAbstraction",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/ViewAbstraction\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\nvar _EdgeType = require('$:/plugins/felixhayashi/tiddlymap/js/EdgeType');\n\nvar _EdgeType2 = _interopRequireDefault(_EdgeType);\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nvar _environment = require('$:/plugins/felixhayashi/tiddlymap/js/lib/environment');\n\nvar env = _interopRequireWildcard(_environment);\n\nvar _exception = require('$:/plugins/felixhayashi/tiddlymap/js/exception');\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/*** Code **********************************************************/\n\n/**\n * This class abstracts the various pieces that together make up the\n * view such as map, edge filter, node filter, config etc.\n * If {@code isCreate} is not specified, the viewAbstraction will only\n * represent the view and not create it or any missing part of it.\n */\nvar ViewAbstraction = function () {\n\n /**\n *\n * @param {string|ViewAbstraction|Tiddler} view - The view\n * @param {Object} options\n * @param {boolean} [options.isCreate] - True if the view should be created and override\n * any existing view, false otherwise.\n */\n function ViewAbstraction(view) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n _classCallCheck(this, ViewAbstraction);\n\n if (view instanceof ViewAbstraction) {\n\n // bounce back the object we received\n return view;\n }\n\n this._registerPaths(view);\n\n if (options.isCreate) {\n\n if (!this.configTRef) {\n\n var name = _utils2.default.getRandomLabel({ plural: true });\n this.configTRef = $tw.wiki.generateNewTitle($tm.path.views + '/' + name);\n }\n\n this._createView(options);\n } else if (!ViewAbstraction.exists(this.getRoot())) {\n // no valid config path\n\n throw new ResourceNotFoundException('ViewAbstraction', view);\n }\n }\n\n /**\n * Returns true if this view cannot be edited.\n * As a general rule, all views that come as plugins are locked.\n *\n * @return {boolean}\n */\n\n\n _createClass(ViewAbstraction, [{\n key: 'isLocked',\n value: function isLocked() {\n\n return $tw.wiki.isShadowTiddler(this.configTRef);\n }\n\n /**\n * Gives the view a chance to rebuild its properties cache.\n *\n * @param {Updates} updates\n * @return {boolean} True if changes affect parts of the view.\n */\n\n }, {\n key: 'update',\n value: function update(updates) {\n var changedTiddlers = updates.changedTiddlers;\n\n\n if (updates[env.path.edgeTypes] || _utils2.default.hasKeyWithPrefix(changedTiddlers, this.getRoot())) {\n this._clearCaches();\n\n return true;\n }\n\n return false;\n }\n\n /**\n * clones the tiddler denoted via tRef and uses it as placeholder\n * for this view when a widget using this view is displayed in\n * static mode\n *\n * @param {Tiddler} tiddler\n */\n\n }, {\n key: 'addPlaceholder',\n value: function addPlaceholder(tiddler) {\n\n _utils2.default.cp(_utils2.default.getTiddlerRef(tiddler), this.snapshotTRef, true);\n }\n\n /**\n * A view exists if the the view's root exists as tiddler in the store.\n *\n * @deprecated\n *\n * @return {boolean}\n */\n\n }, {\n key: 'exists',\n value: function exists() {\n\n return ViewAbstraction.exists(this);\n }\n\n /**\n * The path to the config tiddler that represents the view.\n *\n * @return {TiddlerReference}\n */\n\n }, {\n key: 'getRoot',\n value: function getRoot() {\n\n return this.configTRef;\n }\n\n /**\n * Returns this view's creation date.\n *\n * @param {boolean} [asString] True if the returned value should be a string in any case.\n * @return {string|object|undefined} The creation date in the specified output format.\n */\n\n }, {\n key: 'getCreationDate',\n value: function getCreationDate(asString) {\n\n var date = $tw.wiki.getTiddler(this.configTRef).fields['created'];\n\n if (asString) {\n // note: th will be translated as well!\n return date instanceof Date ? $tw.utils.formatDateString(date, 'DDth MMM YYYY') : '';\n }\n\n return date;\n }\n\n /**\n * The label of the view (which is basically the root-path's basename).\n *\n * @return {string} The label (name) of the view.\n */\n\n }, {\n key: 'getLabel',\n value: function getLabel() {\n\n return _utils2.default.getBasename(this.configTRef);\n }\n\n /**\n * Method to remove the view and its configuration.\n * It will make the view non-existent.\n *\n * Note: Do not use the object anymore after you called this function!\n */\n\n }, {\n key: 'destroy',\n value: function destroy() {\n\n // delete the view and all tiddlers stored in its path (map, edge-filter etc.)\n _utils2.default.deleteTiddlers(_utils2.default.getMatches('[prefix[' + this.configTRef + ']]'));\n }\n\n /**\n * Returns all tiddlers include tiddlymap widgets that reference this view.\n */\n\n }, {\n key: 'getOccurrences',\n value: function getOccurrences() {\n\n var filter = '[regexp:text[<\\\\$(tiddlymap|tmap).*?view=.' + this.getLabel() + '..*?>]]';\n return _utils2.default.getMatches(filter);\n }\n\n /**\n * Renames the view.\n *\n * @param {string} newLabel\n * @return {boolean}\n */\n\n }, {\n key: 'rename',\n value: function rename(newLabel) {\n\n if (typeof newLabel !== 'string') {\n\n return false;\n }\n\n if (_utils2.default.inArray('/', newLabel)) {\n\n $tm.notify('A view name must not contain any \"/\"');\n\n return false;\n }\n\n // keep a reference to the old label before we change it\n var oldLabel = this.getLabel();\n\n // start the renaming\n var newRoot = env.path.views + '/' + newLabel;\n var oldRoot = this.getRoot();\n\n _utils2.default.mv(oldRoot, newRoot, true);\n\n // update references\n\n if ($tm.config.sys.defaultView === oldLabel) {\n _utils2.default.setEntry($tm.ref.sysUserConf, 'defaultView', newLabel);\n }\n\n if ($tm.config.sys.liveTab.fallbackView === oldLabel) {\n _utils2.default.setEntry($tm.ref.sysUserConf, 'liveTab.fallbackView', newLabel);\n }\n\n $tw.wiki.each(function (tObj, tRef) {\n\n if (tObj.fields['tmap.open-view'] === oldLabel) {\n\n // update global node data fields referencing this view\n _utils2.default.setField(tRef, 'tmap.open-view', newLabel);\n\n return;\n }\n\n if (ViewAbstraction.exists(tRef)) {\n\n // update all local node data referencing this view\n var view = new ViewAbstraction(tRef);\n var nodes = view.getNodeData();\n\n for (var id in nodes) {\n if (nodes[id]['open-view'] === oldLabel) {\n nodes[id]['open-view'] = newLabel;\n }\n }\n\n view.saveNodeData(nodes);\n }\n });\n\n // clear caches registered to previous root before registering new paths\n this._clearCaches();\n this._registerPaths(newLabel);\n }\n\n /**\n * All configurations that are toggled via checkboxes to have a value\n * either `true` or `false` can be accessed via this method.\n *\n * @param {string} name - The configs name without the `_config` prefix.\n * @return {boolean} True if the configuration is enabled, false otherwise.\n */\n\n }, {\n key: 'isEnabled',\n value: function isEnabled(name) {\n\n return _utils2.default.isTrue(this.getConfig(name), false);\n }\n\n /**\n * Returns a configuration value relating to the given name. If no name\n * is given, an object with all configurations is returned.\n *\n * @param {string} [name] - Instead of all configurations being returned,\n * only the configuration named name is returned. The initial \"config.\"\n * may be omitted.\n * @result {string|Object} If `type` is not specified an object containing\n * all configurations is returned, otherwise a single value will be returned.\n */\n\n }, {\n key: 'getConfig',\n value: function getConfig(name) {\n var _this = this;\n\n var config = $tw.wiki.getCacheForTiddler(this.configTRef, \"tmap-config\", function () {\n\n var fields = _utils2.default.getTiddler(_this.configTRef).fields;\n return _utils2.default.getPropertiesByPrefix(fields, 'config.');\n });\n\n var prefixlessName = name && _utils2.default.startsWith(name, 'config.') ? name : 'config.' + name;\n\n return name ? config[prefixlessName] : config;\n }\n\n /**\n * Enables the api user to modify the view's configuration.\n *\n * In case two arguments are provided, the first is assumed to be the property\n * name and the second the value to be set.\n *\n * In case a single object is provided as argument, it is treated as a key-value\n * collection and each property in this object is saved as config.\n *\n * @param {*} args\n */\n\n }, {\n key: 'setConfig',\n value: function setConfig() {\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n if (args[0] == null) {\n // null or undefined\n\n return;\n }\n\n if (args.length === 1 && _typeof(args[0]) === 'object') {\n\n for (var prop in args[0]) {\n this.setConfig(prop, args[0][prop]);\n }\n } else if (args.length === 2 && typeof args[0] === 'string') {\n\n var _prop = _utils2.default.getWithoutPrefix(args[0], 'config.');\n var val = args[1];\n\n if (val === undefined) {\n\n return;\n }\n\n var config = this.getConfig();\n\n if (val === null) {\n\n $tm.logger('debug', 'Removing config', _prop);\n delete config['config.' + _prop];\n } else {\n\n if (_prop === 'edge_type_namespace') {\n var match = val.match(/[^:]+/);\n val = match ? match[0] : '';\n }\n }\n\n $tm.logger('log', 'Setting config', _prop, val);\n config['config.' + _prop] = val;\n\n // save\n $tw.wiki.addTiddler(new $tw.Tiddler(_utils2.default.getTiddler(this.configTRef), config));\n } else {\n // not allowed\n\n throw new (Function.prototype.bind.apply(_exception.InvalidArgumentException, [null].concat(args)))();\n }\n }\n\n /**\n * Whether this view represents the 'live view'\n *\n * @return {boolean}\n */\n\n }, {\n key: 'isLiveView',\n value: function isLiveView() {\n\n return this.getLabel() === $tm.misc.liveViewLabel;\n }\n\n /**\n * Whether the node is already explicitly contained in the view's node filter,\n * i.e. whether it is explicitly referenced by its title.\n *\n * @private\n *\n * @param {Node} node\n * @return {string}\n */\n\n }, {\n key: '_isNodeIncludedById',\n value: function _isNodeIncludedById(node) {\n\n var regex = $tw.utils.escapeRegExp(ViewAbstraction._getNodeIdFilterPart(node));\n\n return this.getNodeFilter('raw').match(regex);\n }\n\n /**\n * Sets and rebuilds the node filter according to the expression provided.\n *\n * @param {string} expr - A tiddlywiki filter expression.\n * @param {boolean} force\n */\n\n }, {\n key: 'setNodeFilter',\n value: function setNodeFilter(expr, force) {\n\n expr = expr.replace(/[\\n\\r]/g, ' ');\n\n if (this.getNodeFilter('raw') === expr) {\n // already up to date;\n // This check is critical to prevent recursion!\n return;\n }\n\n _utils2.default.setField(this.nodeFilterTRef, 'filter', expr);\n\n $tm.logger('debug', 'Node filter set to', expr);\n }\n\n /**\n * Sets and rebuilds the edge type filter according to the expression provided.\n *\n * @param {string} expr - A tiddlywiki filter expression.\n */\n\n }, {\n key: 'setEdgeTypeFilter',\n value: function setEdgeTypeFilter(expr) {\n\n expr = expr.replace(/[\\n\\r]/g, ' ');\n\n if (this.getEdgeTypeFilter('raw') === expr) {\n // already up to date\n // This check is critical to prevent recursion!\n return;\n }\n\n _utils2.default.setField(this.edgeTypeFilterTRef, 'filter', expr);\n\n $tm.logger('debug', 'Edge filter set to', expr);\n }\n\n /**\n * Method to append a filter part to the current filter (*or*-style).\n * The node's tmap.id will be used in the filter to reference the corresponding tiddler.\n *\n * @param {Node} node\n */\n\n }, {\n key: 'addNode',\n value: function addNode(node) {\n\n if (!this._isNodeIncludedById(node)) {\n\n // @see https://github.com/felixhayashi/TW5-TiddlyMap/issues/285\n if (_utils2.default.isTrue($tm.config.sys.alwaysAddNodeIdToViewFilter) || this.getNodeFilter('compiled')().indexOf(node.label) == -1) {\n\n var part = ViewAbstraction._getNodeIdFilterPart(node);\n var separator = ' ';\n this.setNodeFilter(this.getNodeFilter('raw') + separator + part);\n }\n\n this.saveNodePosition(node);\n }\n }\n\n /**\n * Removes a node from the the view filter that has been\n * explicitly added before.\n *\n * ATTENTION: Never remove the node data (i.e. style and positions)\n * from the node-data store. This will be done by a garbage\n * collector. See Adapter.prototype._removeObsoleteViewData\n *\n * @return {boolean} True if node was removed, false otherwise.\n * Note: false is also returned if the node did not exist before.\n */\n\n }, {\n key: 'removeNode',\n value: function removeNode(nodeId) {\n\n if (!this._isNodeIncludedById(nodeId)) {\n\n return false;\n }\n\n var part = ViewAbstraction._getNodeIdFilterPart(nodeId);\n var f = this.getNodeFilter('raw').replace(part, '');\n\n this.setNodeFilter(f);\n\n if (this.getNodeData(nodeId)) {\n this.saveNodeData(nodeId, null);\n }\n\n return true;\n }\n\n /**\n * Method will return a tiddlywiki edge-type filter that is used to\n * decide which edge types are displayed by the graph.\n *\n * Note: needs to be recalculated if the collection of edge types changed\n * in the wiki.\n *\n * @param {(\"raw\"|\"pretty\"|\"matches\"|\"whitelist\")} [type]\n * Use this param to control the output type.\n * @result {*}\n * Depends on the type param:\n * - raw: the original filter string\n * - pretty: the prettyfied filter string for usage in textareas\n * - matches: {Array<string>} all matches\n * - whitelist: A lookup table where all matches are true\n */\n\n }, {\n key: 'getEdgeTypeFilter',\n value: function getEdgeTypeFilter(type) {\n var _this2 = this;\n\n var filter = $tw.wiki.getCacheForTiddler(this.edgeTypeFilterTRef, \"tmap-edgeTypeFilter\", function () {\n\n var allETy = $tm.indeces.allETy;\n var src = Object.keys(allETy);\n var tObj = $tw.wiki.getTiddler(_this2.edgeTypeFilterTRef);\n\n var filter = {};\n filter.raw = tObj && tObj.fields.filter || '';\n filter.pretty = _utils2.default.getPrettyFilter(filter.raw);\n filter.matches = _utils2.default.getEdgeTypeMatches(filter.raw, allETy);\n filter.whitelist = _utils2.default.getLookupTable(filter.matches);\n\n return filter;\n });\n\n return type ? filter[type] : filter;\n }\n\n /**\n * Whether or not this EdgeType is visible in this view.\n *\n * @param {EdgeType|string} id\n * @return {*}\n */\n\n }, {\n key: 'isEdgeTypeVisible',\n value: function isEdgeTypeVisible(id) {\n\n return _utils2.default.isEdgeTypeMatch(_EdgeType2.default.getInstance(id).id, this.getEdgeTypeFilter(\"raw\"));\n }\n\n /**\n * Method will return a tiddlywiki node filter that is used to\n * decide which nodes are displayed by the graph.\n *\n * @param {(\"raw\"|\"pretty\"|\"compiled\")} [type] - Use this param to control the output type.\n * @result {*}\n * Depends on the type param:\n * - raw: the original filter string\n * - pretty: the prettyfied filter string for usage in textareas\n * - compiled: {Array<string>} all matches\n */\n\n }, {\n key: 'getNodeFilter',\n value: function getNodeFilter(type) {\n var _this3 = this;\n\n var filter = $tw.wiki.getCacheForTiddler(this.nodeFilterTRef, \"tmap-nodeFilter\", function () {\n\n var filter = _utils2.default.makeHashMap();\n var tObj = $tw.wiki.getTiddler(_this3.nodeFilterTRef);\n\n filter.raw = tObj && tObj.fields.filter || '';\n filter.pretty = _utils2.default.getPrettyFilter(filter.raw);\n filter.compiled = $tw.wiki.compileFilter(filter.raw);\n\n return filter;\n });\n\n return type ? filter[type] : filter;\n }\n\n /**\n * This method will return the node data stored in the view.\n *\n * @todo When to delete obsolete data?\n *\n * @param {string} nodeId\n * @result {Hashmap<Id, Object>} A Hashmap with node data.\n */\n\n }, {\n key: 'getNodeData',\n value: function getNodeData(nodeId) {\n var _this4 = this;\n\n var data = $tw.wiki.getCacheForTiddler(this.mapTRef, \"tmap-map\", function () {\n return _utils2.default.parseFieldData(_this4.mapTRef, 'text', {});\n });\n\n return nodeId ? data[nodeId] : data;\n }\n\n /**\n * A view equals another view either\n *\n * 1) if the js objects reference the same objects in the js runtime\n * 2) or if the views have the same root and both views exist\n *\n * @param view\n * @return {boolean}\n */\n\n }, {\n key: 'equals',\n value: function equals(view) {\n\n return view === this || ViewAbstraction.exists(view) && new ViewAbstraction(view).getRoot() === this.getRoot();\n }\n\n /**\n * This function will merge the given data in the view's node store.\n *\n * If a property is set to null, it will be removed.\n *\n * If two arguments are provided, the first parameter is assumed\n * to be a node id and the second to be the data object. The data\n * will extend the existing data. If data is not an object, it is\n * assumed to be a delete directive and consequently the node data\n * in the store will be deleted.\n *\n * Otherwise, if a single object parameter is provided, it is regarded\n * as a node collection and the whole object is used to extend the store.\n *\n * Note: The Adapter will routinely delete node content of nodes that are\n * not contained in the view anymore.\n */\n\n }, {\n key: 'saveNodeData',\n value: function saveNodeData() {\n\n var data = this.getNodeData();\n\n for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n\n if (args.length === 2) {\n\n if (_typeof(args[1]) === 'object') {\n\n if (args[1] === null) {\n\n delete data[args[0]];\n } else {\n\n data[args[0]] = Object.assign(data[args[0]] || {}, args[1]);\n }\n }\n } else if (args.length === 1 && _typeof(args[0]) === 'object') {\n\n $tm.logger('log', 'Storing data in', this.mapTRef);\n\n Object.assign(data, args[0]);\n } else {\n // not allowed\n\n throw new (Function.prototype.bind.apply(_exception.InvalidArgumentException, [null].concat(args)))();\n }\n\n _utils2.default.writeFieldData(this.mapTRef, 'text', data, $tm.config.sys.jsonIndentation);\n }\n\n /**\n * Saves a node's position to the store\n *\n * @param {Node} node\n */\n\n }, {\n key: 'saveNodePosition',\n value: function saveNodePosition(node) {\n\n if (node.id && node.x != null && node.y != null) {\n // only pass coordinates to prevent other data from being stored!\n this.saveNodeData(node.id, { x: node.x, y: node.y });\n }\n }\n\n /**\n * Saves a node's position to the store\n *\n * @param {Object} positions\n */\n\n }, {\n key: 'saveNodePositions',\n value: function saveNodePositions(positions) {\n\n var nodeData = this.getNodeData();\n\n for (var id in positions) {\n\n nodeData[id] = nodeData[id] || {};\n nodeData[id].x = positions[id].x;\n nodeData[id].y = positions[id].y;\n }\n\n this.saveNodeData(nodeData);\n }\n\n /**\n * Marks the node with the given id as central topic.\n *\n * @param nodeId\n */\n\n }, {\n key: 'setCentralTopic',\n value: function setCentralTopic(nodeId) {\n\n this.setConfig('central-topic', nodeId);\n }\n\n /**\n * Saves the provided style for the node with the specified id in the view's store.\n *\n * Note: The coordinates of the node on the map are not stored via this function.\n * For this task, use saveNodePosition() instead.\n *\n * @param {string} nodeId\n * @param {Object} style\n */\n\n }, {\n key: 'saveNodeStyle',\n value: function saveNodeStyle(nodeId, style) {\n\n // remove any previos style from store;\n // @TODO: optimize this only null in style var needs to be removed\n var data = this.getNodeData(nodeId) || {};\n\n var pos = { x: data.x, y: data.y };\n\n // tabula rasa! delete all previous properties\n for (var p in data) {\n delete data[p];\n }\n\n // save new style\n this.saveNodeData(nodeId, _extends({}, style, pos));\n }\n\n /**\n * The view's configTiddlerRef is stored in different tiddlers (paths).\n * This function registers these paths to this the view instance.\n *\n * @private\n * @params {ViewAbstraction|string} view\n */\n\n }, {\n key: '_registerPaths',\n value: function _registerPaths(view, isCreate) {\n\n // main config is stored here\n this.configTRef = ViewAbstraction._getRootPath(view);\n\n // store for node properties (positions and local node styles)\n this.mapTRef = this.configTRef + '/map';\n\n // filter stores\n this.nodeFilterTRef = this.configTRef + '/filter/nodes';\n this.edgeTypeFilterTRef = this.configTRef + '/filter/edges';\n\n this.snapshotTRef = this.getRoot() + '/snapshot';\n }\n\n /**\n * This will clear all cached tiddlers related to this view.\n *\n * @private\n * @return {boolean} true if the cache was dirty, false if cache was up-to-date and did\n */\n\n }, {\n key: '_clearCaches',\n value: function _clearCaches() {\n // clear all tiddler-caches below this path\n _utils2.default.getMatches('[prefix[' + this.getRoot() + ']]').forEach(function (tRef) {\n $tw.wiki.clearCache(tRef);\n });\n }\n\n /**\n * Will create the config tiddler which means that the view will\n * start to exist.\n *\n * @private\n */\n\n }, {\n key: '_createView',\n value: function _createView() {\n var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},\n isForce = _ref.isForce,\n protoView = _ref.protoView,\n isHidden = _ref.isHidden;\n\n // destroy any former view that existed in this path\n if (ViewAbstraction.exists(this)) {\n\n if (!isForce) {\n\n return;\n }\n\n this.destroy();\n }\n\n if (ViewAbstraction.exists(protoView)) {\n _utils2.default.cp(new ViewAbstraction(protoView).getRoot(), this.configTRef, true);\n }\n\n // create new view\n var fields = {\n title: this.configTRef,\n id: _utils2.default.genUUID() // maybe useful for future purposes…\n };\n\n if (!isHidden) {\n fields[$tm.field.viewMarker] = true;\n }\n\n $tw.wiki.addTiddler(new $tw.Tiddler(_utils2.default.getTiddler(this.configTRef), // in case we cloned the view\n fields));\n\n this.setEdgeTypeFilter(env.filter.defaultEdgeTypeFilter);\n }\n\n /**\n * Will return a filter part that matches the node's id.\n *\n * E.g. [field:tmap.id[1748576e-74bb-4165-85bb-0d312e3e4f1f]]\n *\n * @private\n *\n * @param node\n * @return {string}\n */\n\n }], [{\n key: '_getNodeIdFilterPart',\n value: function _getNodeIdFilterPart(node) {\n\n var id = (typeof node === 'undefined' ? 'undefined' : _typeof(node)) === 'object' ? node.id : node;\n\n return '[field:tmap.id[' + id + ']]';\n }\n\n /**\n * Will return the path to the config tiddler of this view, aka the view's root.\n *\n * @private\n *\n * @param {*} view - The constructor param to abstract or create the view.\n * @result {string|undefined} The view config path.\n */\n\n }, {\n key: '_getRootPath',\n value: function _getRootPath(view) {\n\n if (view instanceof ViewAbstraction) {\n\n return view.configTRef;\n }\n\n if (view instanceof $tw.Tiddler) {\n // is a tiddler object\n\n view = view.fields.title;\n }\n\n if (typeof view === 'string') {\n\n // remove prefix and slash\n var label = _utils2.default.getWithoutPrefix(view, $tm.path.views + '/');\n\n // a valid label must not contain any slashes\n if (label && !_utils2.default.hasSubString(label, '/')) {\n\n return $tm.path.views + '/' + label;\n }\n }\n }\n\n /**\n * A view exists if the the view's root exists as tiddler in the store.\n *\n * @return {ViewAbstraction|string}\n */\n\n }, {\n key: 'exists',\n value: function exists(view) {\n\n if (!view) {\n\n return false;\n }\n\n if (view instanceof ViewAbstraction) {\n\n view = view.configTRef;\n } else {\n\n view = ViewAbstraction._getRootPath(view);\n }\n\n return _utils2.default.tiddlerExists(view);\n }\n }]);\n\n return ViewAbstraction;\n}();\n\n/*** Exports *******************************************************/\n\nexports.default = ViewAbstraction;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/graph/ViewAbstraction.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/Popup": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/Popup",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**** Code *********************************************************/\n\n/**\n * Installs a hidden popup below `parentDomNode` that may be shown\n * and or hidden.\n *\n * @constructor\n *\n * @param {Element} [parentDomNode] - The popup container. The\n * popup will create itself in this container.\n * @param {Hashmap} [options] - An options object.\n * @param {string} [options.className] - A classname to be added to\n * the popup div.\n * @param {int} [options.delay] - The default delay for the popup\n * show and hide.\n */\nfunction Popup(parentDomNode, options) {\n\n options = options || {};\n\n this._parentDomNode = parentDomNode;\n this._domNode = document.createElement('div');\n this._domNode.style.display = 'none';\n this._domNode.className = 'tmap-popup';\n\n this._parentDomNode.appendChild(this._domNode);\n $tw.utils.addClass(this._domNode, options.className);\n\n this._isEnabled = true;\n this._isPreventShowOrHide = false;\n this._isHideOnClick = !!options.hideOnClick;\n this._timeoutShow = null;\n this._timeoutHide = null;\n this._isDisplayNoneAfterAnimation = true;\n\n // delays\n var val = parseInt(options.leavingDelay);\n this._hideDelayLeavingPopup = _utils2.default.isInteger(val) ? val : 200;\n\n val = parseInt(options.hideDelay);\n this._hideDelay = _utils2.default.isInteger(val) ? val : 200;\n\n val = parseInt(options.showDelay);\n this._showDelay = _utils2.default.isInteger(val) ? val : 200;\n\n // force early binding of functions to this context\n _utils2.default.bindTo(this, ['_show', '_hide', '_handleEnter', '_handleLeave', '_handleAnimationEnd', '_handleClick']);\n\n // specify handlers\n this._listeners = {\n 'mouseenter': this._handleEnter,\n 'mouseleave': this._handleLeave,\n 'click': [this._handleClick, true]\n };\n\n var fn = this._handleAnimationEnd;\n this._listeners[$tw.utils.convertEventName('animationEnd')] = fn;\n this._listeners[$tw.utils.convertEventName('transitionEnd')] = fn;\n\n // add handlers\n _utils2.default.setDomListeners('add', this._domNode, this._listeners, false);\n}\n\n/**\n * When the mouse is inside the popup, the popup will manage closing\n * itself and ignore all closing attempts from outside.\n */\n// @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/Popup\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\nPopup.prototype._handleEnter = function (ev) {\n\n //~ console.log(\"_handleEnter\");\n\n this._isPreventShowOrHide = true;\n};\n\n/**\n * Handler triggered when leaving the popup div.\n */\nPopup.prototype._handleLeave = function (ev) {\n\n //~ console.log(\"_handleLeave\");\n\n this._isPreventShowOrHide = false;\n\n // we need some delay because resizing may cause the mouse to\n // exit the popup for some miliseconds\n\n this.hide(this._hideDelayLeavingPopup);\n};\n\nPopup.prototype._handleClick = function (ev) {\n\n //~ console.log(\"_handleLeave\");\n\n if (this._isHideOnClick) {\n this._hide(true);\n }\n};\n\n/**\n * Handler triggered when leaving the popup div.\n */\nPopup.prototype._handleAnimationEnd = function () {\n\n if (this._isDisplayNoneAfterAnimation) {\n //~ console.log(\"display: none\");\n this._domNode.style.display = 'none';\n }\n};\n\n/**\n * Immediately hides the popup.\n */\nPopup.prototype._hide = function (isForce) {\n\n //~ console.log(\"_hide\");\n\n if (!isForce && this._isPreventShowOrHide) return;\n\n //~ console.log(\"_hide SUCCESS\");\n\n this._isDisplayNoneAfterAnimation = true;\n this._isPreventShowOrHide = false;\n\n $tw.utils.removeClass(this._domNode, 'tmap-popup-active');\n};\n\n/**\n * Makes the text visible as popup and registers it with the\n * given signature.\n *\n * The popup is spawned on the side that has the most space.\n *\n * @param {*} signature - The signature that has been\n * passed to {@link show}.\n */\nPopup.prototype._show = function (signature, text) {\n\n //~ console.log(\"_show\");\n\n if (this._isPreventShowOrHide || $tm.mouse.ctrlKey || !this._isEnabled) {\n return;\n }\n\n this._domNode.style.display = 'none';\n $tw.utils.removeClass(this._domNode, 'tmap-popup-active');\n\n // remove any positioning or modification done before\n this._domNode.removeAttribute('style');\n\n // remove any previous content\n _utils2.default.removeDOMChildNodes(this._domNode);\n var div = this._domNode.appendChild(document.createElement('div'));\n\n if (typeof text === 'function') {\n text(signature, div);\n } else {\n div.innerHTML = text;\n }\n\n if (!div.childNodes.length) return;\n\n var parRect = this._parentDomNode.getBoundingClientRect();\n var x = $tm.mouse.clientX;\n var y = $tm.mouse.clientY;\n\n //~ console.log(\"_show SUCCESS\");\n\n // ATTENTION: display needs to be true before we can get the bounds!\n\n // make sure that display is block so the animation is executed\n // and we can retrieve the size of the div.\n this._domNode.style.display = 'block';\n\n var popRect = this._domNode.getBoundingClientRect();\n\n var availSpaceRight = parRect.right - (x + popRect.width);\n var availSpaceLeft = x - popRect.width - parRect.left;\n var spawnRight = availSpaceRight > availSpaceLeft;\n\n var availSpaceBottom = parRect.bottom - (y + popRect.height);\n var availSpaceTop = y - popRect.height - parRect.top;\n var spawnBottom = availSpaceBottom > availSpaceTop;\n\n var shiftLeft = spawnRight ? -15 : popRect.width + 15;\n var shiftTop = spawnBottom ? -15 : popRect.height + 15;\n\n this._domNode.style.left = x - parRect.left - shiftLeft + 'px';\n this._domNode.style.top = y - parRect.top - shiftTop + 'px';\n\n // …and make sure that it stays block after the animation is done…\n this._isDisplayNoneAfterAnimation = false;\n // …and add the class that triggers the animation…\n $tw.utils.addClass(this._domNode, 'tmap-popup-active');\n};\n\n/**\n * Makes the text visible as popup after a given delay and\n * registers the popup under the specified signature.\n *\n * @param {*} signature - If {@param text} is provided as param and\n * is a function, then this will be passed later as argument to\n * text. It therefore acts as means to identify the popup later\n * on or pass data that survives the delay.\n * @param {string|Function} text - If text\n * is a string, it will be shown in the popup, otherwise,\n * if text is a function, it will be executed and it is\n * expected to populate the popup div passed as second parameter;\n * the first parameter will be the signature object.\n * @param{delay} delay - Delays the hide operation.\n */\nPopup.prototype.show = function (signature, text, delay) {\n\n //~ console.log(\"show\", delay);\n\n this._clearTimeouts();\n\n delay = _utils2.default.isInteger(delay) ? delay : this._showDelay;\n\n // start a new timeout\n this._timeoutShow = setTimeout(this._show, delay, signature, text);\n};\n\n/**\n * Hide the popup.\n *\n * @param {int} delay - Delays the hide operation.\n */\nPopup.prototype.hide = function (delay, isForce) {\n\n //~ console.log(\"hide\", delay);\n\n this._clearTimeouts();\n\n delay = _utils2.default.isInteger(delay) ? delay : this._hideDelay;\n\n if (isForce || delay === 0) {\n // @TODO is this really correct?\n this._hide(isForce);\n } else {\n this._timeoutHide = setTimeout(this._hide, delay, isForce);\n }\n};\n\n/**\n * Completely enable or disable the popup\n */\nPopup.prototype.setEnabled = function (isEnabled) {\n this._isEnabled = isEnabled;\n};\n\nPopup.prototype.isShown = function () {\n return this._domNode.style.display === 'block';\n};\n\nPopup.prototype._clearTimeouts = function () {\n\n clearTimeout(this._timeoutShow);\n clearTimeout(this._timeoutHide);\n\n this._timeoutShow = undefined;\n this._timeoutHide = undefined;\n};\n\n/*** Exports *******************************************************/\n\nexports.default = Popup;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/lib/Popup.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/lib/SelectionRectangle": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/lib/SelectionRectangle",
"text": "\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n// @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/lib/SelectionRectangle\ntype: application/SelectionRectangle\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/**** Code *********************************************************/\n\n/**\n * Represents a rectangle spanned by mouse selection\n *\n * @constructor\n *\n * @param {Element} [parentDomNode] - The popup container. The\n * popup will create itself in this container.\n * @param {Hashmap} [options] - An options object.\n * @param {string} [options.className] - A classname to be added to\n * the popup div.\n * @param {int} [options.delay] - The default delay for the popup\n * show and hide.\n */\nvar SelectionRectangle = function () {\n\n /**\n * Sets up the selection with the specified initial offset.\n *\n * @param {number} x - offset x\n * @param {number} y - offset y\n */\n function SelectionRectangle(x, y) {\n _classCallCheck(this, SelectionRectangle);\n\n this.x1 = x;\n this.x2 = x;\n\n this.y1 = y;\n this.y2 = y;\n }\n\n /**\n * Spans the selection.\n *\n * @param {number} x - x coordinate\n * @param {number} y - y coordinate\n */\n\n\n _createClass(SelectionRectangle, [{\n key: \"span\",\n value: function span(x, y) {\n\n this.x2 = x;\n this.y2 = y;\n }\n\n /**\n * @return {number} width\n */\n\n }, {\n key: \"getWidth\",\n value: function getWidth() {\n\n return this.x2 - this.x1;\n }\n\n /**\n * @return {number} height\n */\n\n }, {\n key: \"getHeight\",\n value: function getHeight() {\n\n return this.y2 - this.y1;\n }\n\n /**\n * @return {array} an array holding the following data in sequence: x, y, width, height\n */\n\n }, {\n key: \"getRect\",\n value: function getRect() {\n\n return [this.x1, this.y1, this.getWidth(), this.getHeight()];\n }\n\n /**\n * @param {number} x - x coordinate\n * @param {number} y - y coordinate\n * @return {boolean}\n */\n\n }, {\n key: \"isPointWithin\",\n value: function isPointWithin(_ref) {\n var x = _ref.x,\n y = _ref.y;\n var x1 = this.x1,\n x2 = this.x2,\n y1 = this.y1,\n y2 = this.y2;\n\n\n var mostLeft = Math.min(x1, x2);\n var mostRight = Math.max(x1, x2);\n var mostBottom = Math.min(y1, y2);\n var mostTop = Math.max(y1, y2);\n\n return mostLeft < x && x < mostRight && mostBottom < y && y < mostTop;\n }\n }]);\n\n return SelectionRectangle;\n}();\n\n/*** Exports *******************************************************/\n\nexports.default = SelectionRectangle;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/lib/SelectionRectangle.js.map\n",
"type": "application/SelectionRectangle",
"module-type": "library"
},
"/home/felo/projects/Tiddlywiki/TiddlyWiki5/plugins/felixhayashi/tiddlymap/js/lib/TypeDefs.js": {
"title": "/home/felo/projects/Tiddlywiki/TiddlyWiki5/plugins/felixhayashi/tiddlymap/js/lib/TypeDefs.js",
"text": "/**\n * @typedef {string} TiddlerReference\n *\n * A reference (title) that identifies a tiddler.\n */\n\n/**\n * @typedef {$tw.Tiddler|TiddlerReference} Tiddler\n *\n * Either a reference (title) that identifies the tiddler or an object\n * representation.\n */\n\n/**\n * @typedef {string|number} Id\n *\n * An id used to identify a node or tiddler. Ids may only contain characters\n * that are valid when used as tiddlywiki field values.\n */\n\n/**\n * @typedef {Object} Edge\n *\n * @property {Id} id - The id of the edge.\n * @property {Id} from - An id that refers to a {@link Node} and denotes the\n * from part of an edge.\n * @property {Id} to - An id that refers to a {@link Node} and denotes the\n * to part of an edge.\n * @property {string} label - The label of the edge that will be displayed\n * in the rendered graph.\n * @property {string} [view] - An optional viewname to which the edge is\n * bound to.\n *\n * An edge connects nodes in a vis.Network.\n */\n\n/**\n * @typedef {Object} EdgeTypeSubscriberInfo\n *\n * @property {(\"_\"|undefined)} [marker] - The marker of the edge type.\n * @property {string} [namespace] - The namespace of the edge type.\n * @property {string} [name] - The name of the edge type.\n * @property {boolean} [include=true] - Whether or not this subscriber should be registered.\n */\n\n/**\n * @typedef {Object} Node\n *\n * This object is used by the vis.Network.\n *\n * @property {Id} id - The id of the node.\n * @property {string} label - The label of the node that will be displayed\n * in the rendered graph.\n */\n\n/**\n * @typedef {Object} Hashmap\n *\n * Sometimes it makes semantically more sense to call an object a hashmap.\n * Then it becomes clear that we are talking about a simple key-value store.\n */\n\n/**\n * @typedef {Array.<*>|Hashmap.<Id, *>|vis.DataSet} Collection\n *\n * A collection contains a group of elements, usually nodes\n * (see {@link NodeCollection}) or edges (see {@link EdgeCollection}).\n *\n * A collection object corresponds to a {@link CollectionTypeString}.\n */\n\n/**\n * @typedef {Array.<Edge>|Hashmap.<Id, Edge>|vis.DataSet} EdgeCollection\n *\n * A collection of edges.\n */\n\n/**\n * @typedef {Array.<Node>|Hashmap.<Id, Node>|vis.DataSet} NodeCollection\n *\n * A collection of nodes.\n */\n\n/**\n * @typedef {Array.<Tiddler>|Hashmap.<Id, Tiddler>} TiddlerCollection\n *\n * A collection of tiddlers.\n */\n\n/**\n * @typedef {string|function} TiddlyWikiFilter\n *\n * A tiddlywiki filter expression or a compiled filter.\n */\n\n/**\n * @typedef {Tiddler|string|ViewAbstraction} View\n *\n * A view is identified either by a tiddler reference (title),\n * a Tiddler instance or a label. Moreover, a ViewAbstraction\n * may be used as view representation.\n */\n\n/**\n * @typedef {array|hashmap|dataset} CollectionTypeString\n *\n * Most of tiddlymap's select statements allow the user to choose one\n * of the specified output types, depending on what is most suitable.\n *\n * The output types relate to the different types of\n * {@link EdgeCollection} and {@link NodeCollection}.\n */\n\n/**\n * @typedef {Object} Position\n *\n * An object containing x, y properties.\n *\n * @property {number} x - The x coordinate.\n * @property {number} y - The y coordinate.\n */\n\n/**\n * @typedef {Object} Updates\n *\n * An object that carries information about wiki changes after a refresh cycle occurred.\n * This is a more advanced form of the changedTiddlers object.\n *\n * @property {Object<TiddlerReference, string>} changedTiddlers\n * a TiddlyWiki changedTiddlers list that has all draft tiddler changes removed\n * @property {Object<string, boolean>} paths\n * a list of root paths in which tiddler changes occured.\n */\n\n/**\n * @typedef {string} EdgeTypeId\n *\n * An edge-type id string consists of the following parts of which the\n * first two are optional: `[marker][namespace:]name`\n *\n * Note: The colon is not considered to be part of the namespace but is required\n * if a namespace exists.\n */\n\"use strict\";\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/lib/TypeDefs.js.map\n"
},
"$:/plugins/felixhayashi/tiddlymap/js/config/vis": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/config/vis",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n// @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/config/vis\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\nvar visConfig = {\n\n locale: 'en_EN',\n clickToUse: false,\n autoResize: false,\n height: '100%',\n width: '100%',\n configure: {\n enabled: false\n },\n interaction: {\n dragNodes: true,\n dragView: true,\n hideEdgesOnDrag: false,\n hideNodesOnDrag: false,\n hover: true,\n navigationButtons: true,\n multiselect: true,\n selectable: true,\n selectConnectedEdges: true,\n tooltipDelay: 600,\n zoomView: false,\n keyboard: {\n enabled: false,\n speed: {\n x: 10,\n y: 10,\n zoom: 0.02\n },\n bindToWindow: false\n }\n },\n manipulation: {\n initiallyActive: true\n },\n nodes: {\n shape: 'box',\n shadow: {\n enabled: false\n },\n color: {\n border: '#2B7CE9',\n background: '#97C2FC'\n }\n },\n edges: {\n smooth: {\n enabled: true\n },\n color: {\n color: '#848484',\n inherit: false\n },\n arrows: {\n to: {\n enabled: true\n }\n }\n },\n physics: {\n forceAtlas2Based: {\n // <- more repulsion between nodes - 0 - more attraction between nodes ->\n gravitationalConstant: -300, // default: -50\n // edge length\n springLength: 0, // default: 100\n // <- less stiff edges - 0 - stiffer edges ->\n springConstant: 0.2, // default: 0.08\n // pulls the entire network back to the center.\n centralGravity: 0.015, // default: 0.01\n // kinetic energy reduction\n damping: 0.4\n },\n solver: 'forceAtlas2Based',\n stabilization: {\n enabled: true,\n iterations: 1000,\n updateInterval: 10,\n onlyDynamicEdges: false,\n fit: false\n }\n }\n};\n\nexports.default = visConfig;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/lib/VisConfig.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/lib/environment": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/lib/environment",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\n// @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/lib/environment\ntype: application/javascript\n module-type: library\n\n@preserve\n\n\\*/\n\n/*** Code **********************************************************/\n\n/**\n * This module is responsible for registering a global namespace\n * under $tw and registering fundamental path variables.\n *\n * Everything that doesn't change when the global config object is\n * updated. This includes prefixes (paths) and tiddler titles.\n *\n * ATTENTION: The paths are deliberately written in full so they\n * are discovered when a search is performed over the TiddlyMap code.\n */\n\n// **ATTENTION: NO TRAILING SLASHES IN PATHS EVER**\nvar path = exports.path = {\n pluginRoot: '$:/plugins/felixhayashi/tiddlymap',\n edgeTypes: '$:/plugins/felixhayashi/tiddlymap/graph/edgeTypes',\n nodeTypes: '$:/plugins/felixhayashi/tiddlymap/graph/nodeTypes',\n views: '$:/plugins/felixhayashi/tiddlymap/graph/views',\n options: '$:/plugins/felixhayashi/tiddlymap/config',\n dialogs: '$:/plugins/felixhayashi/tiddlymap/dialog',\n footers: '$:/plugins/felixhayashi/tiddlymap/dialogFooter',\n tempRoot: '$:/temp/tmap',\n tempStates: '$:/temp/tmap/state',\n tempPopups: '$:/temp/tmap/state/popup',\n localHolders: '$:/temp/tmap/holders'\n};\n\n// static references to important tiddlers\nvar ref = exports.ref = {\n defaultViewHolder: '$:/plugins/felixhayashi/tiddlymap/misc/defaultViewHolder',\n graphBar: '$:/plugins/felixhayashi/tiddlymap/misc/advancedEditorBar',\n sysUserConf: '$:/plugins/felixhayashi/tiddlymap/config/sys/user',\n visUserConf: '$:/plugins/felixhayashi/tiddlymap/config/vis/user',\n welcomeFlag: '$:/plugins/felixhayashi/tiddlymap/flag/welcome',\n focusButton: '$:/plugins/felixhayashi/tiddlymap/misc/focusButton',\n sysMeta: '$:/plugins/felixhayashi/tiddlymap/misc/meta',\n liveTab: '$:/plugins/felixhayashi/tiddlymap/hook/liveTab',\n mainEditor: '$:/plugins/felixhayashi/tiddlymap/hook/editor',\n sidebarBreakpoint: '$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint'\n};\n\n// some other options\nvar misc = exports.misc = {\n // if no edge label is specified, this is used as label\n unknownEdgeLabel: 'tmap:undefined',\n liveViewLabel: 'Live View',\n defaultViewLabel: 'Default',\n mainEditorId: 'main_editor',\n arrows: { 'in': '⇦', 'out': '➡', 'bi': '⇄' }\n};\n\nvar config = exports.config = {\n sys: {\n field: {\n nodeLabel: 'caption',\n nodeIcon: 'icon',\n nodeInfo: 'description',\n viewMarker: 'isview'\n },\n liveTab: {\n fallbackView: misc.liveViewLabel\n },\n suppressedDialogs: {},\n edgeClickBehaviour: 'manager',\n debug: 'false',\n notifications: 'true',\n popups: {\n enabled: 'true',\n delay: '600',\n width: '240px',\n height: '140px'\n },\n jsonIndentation: '1',\n alwaysAddNodeIdToViewFilter: 'true',\n editNodeOnCreate: 'false',\n singleClickMode: 'false',\n nodeFilterNeighbours: 'false',\n editorMenuBar: {\n showNeighScopeButton: 'true',\n showRasterMenuButton: 'true',\n showScreenshotButton: 'true'\n }\n }\n};\n\n// some popular filters\nvar filter = exports.filter = {\n nodeTypes: '[prefix[' + path.nodeTypes + ']]',\n edgeTypes: '[prefix[' + path.edgeTypes + ']]',\n views: '[' + config.sys.field.viewMarker + '[true]]',\n defaultEdgeTypeFilter: '-[prefix[_]] -[[tw-body:link]] -[[tw-list:tags]] -[[tw-list:list]]'\n};\n\nvar allSelector = '[all[tiddlers+shadows]!has[draft.of]]';\n\n// some popular selectors\n// usually used from within tiddlers via the tmap macro\n\nvar s = {\n allEdgeTypes: allSelector + ' +' + filter.edgeTypes,\n allNodeTypes: allSelector + ' +' + filter.nodeTypes,\n allViews: allSelector + ' +' + filter.views,\n allPotentialNodes: '[all[tiddlers]!is[system]!has[draft.of]]'\n};\n\nvar selector = exports.selector = _extends({}, s, {\n allEdgeTypesById: s.allEdgeTypes + ' +[removeprefix[' + path.edgeTypes + '/]]',\n allNodeTypesById: s.allNodeTypes + ' +[removeprefix[' + path.nodeTypes + '/]]',\n allViewsByLabel: s.allViews + ' +[removeprefix[' + path.views + '/]]'\n});\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/lib/environment.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/exception": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/exception",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n// @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/exception\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/**\n * Base class for all Exceptions in TiddlyMap\n */\nvar TiddlyMapError = function (_Error) {\n _inherits(TiddlyMapError, _Error);\n\n /**\n *\n * @param {string} message\n * @param {array} payload\n */\n function TiddlyMapError(message, payload) {\n _classCallCheck(this, TiddlyMapError);\n\n var _this = _possibleConstructorReturn(this, (TiddlyMapError.__proto__ || Object.getPrototypeOf(TiddlyMapError)).call(this, message));\n\n _this.payload = payload;\n return _this;\n }\n\n _createClass(TiddlyMapError, [{\n key: 'getPayload',\n value: function getPayload() {\n return this.payload;\n }\n }]);\n\n return TiddlyMapError;\n}(Error);\n\n/**\n * Thrown if a css or dom structure is not present but was expected by TiddlyMap.\n */\n\n\nvar EnvironmentError = exports.EnvironmentError = function (_TiddlyMapError) {\n _inherits(EnvironmentError, _TiddlyMapError);\n\n function EnvironmentError(aspect) {\n _classCallCheck(this, EnvironmentError);\n\n return _possibleConstructorReturn(this, (EnvironmentError.__proto__ || Object.getPrototypeOf(EnvironmentError)).call(this, 'Critical parts of the underlying system changed: ' + aspect));\n }\n\n return EnvironmentError;\n}(TiddlyMapError);\n\n/**\n * Thrown if a plugin or any other kind of required dependency is missing.\n */\n\n\nvar DependencyError = exports.DependencyError = function (_TiddlyMapError2) {\n _inherits(DependencyError, _TiddlyMapError2);\n\n function DependencyError(dep) {\n _classCallCheck(this, DependencyError);\n\n return _possibleConstructorReturn(this, (DependencyError.__proto__ || Object.getPrototypeOf(DependencyError)).call(this, 'TiddlyMap cannot run without: : ' + dep));\n }\n\n return DependencyError;\n}(TiddlyMapError);\n\n/**\n * Thrown if an interface method is not fully implemented.\n */\n\n\nvar MissingOverrideError = exports.MissingOverrideError = function (_TiddlyMapError3) {\n _inherits(MissingOverrideError, _TiddlyMapError3);\n\n function MissingOverrideError(context, methodName) {\n _classCallCheck(this, MissingOverrideError);\n\n return _possibleConstructorReturn(this, (MissingOverrideError.__proto__ || Object.getPrototypeOf(MissingOverrideError)).call(this, context.constructor.name + ' does not override method \"' + methodName + '\"'));\n }\n\n return MissingOverrideError;\n}(TiddlyMapError);\n\n/**\n * Thrown if a resource such as a node, edge, view, tiddler etc. cannot be located\n * in the system.\n */\n\n\nvar ResourceNotFoundException = exports.ResourceNotFoundException = function (_TiddlyMapError4) {\n _inherits(ResourceNotFoundException, _TiddlyMapError4);\n\n /**\n * @param {string} resourceType\n * @param {*} payload\n */\n function ResourceNotFoundException(resourceType) {\n _classCallCheck(this, ResourceNotFoundException);\n\n for (var _len = arguments.length, payload = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n payload[_key - 1] = arguments[_key];\n }\n\n return _possibleConstructorReturn(this, (ResourceNotFoundException.__proto__ || Object.getPrototypeOf(ResourceNotFoundException)).call(this, 'Cannot resolve ' + resourceType, payload));\n }\n\n return ResourceNotFoundException;\n}(TiddlyMapError);\n\n/**\n * Thrown if a resource such as a node, edge, view, tiddler etc. cannot be located\n * in the system.\n */\n\n\nvar InvalidArgumentException = exports.InvalidArgumentException = function (_TiddlyMapError5) {\n _inherits(InvalidArgumentException, _TiddlyMapError5);\n\n function InvalidArgumentException() {\n _classCallCheck(this, InvalidArgumentException);\n\n for (var _len2 = arguments.length, payload = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n payload[_key2] = arguments[_key2];\n }\n\n return _possibleConstructorReturn(this, (InvalidArgumentException.__proto__ || Object.getPrototypeOf(InvalidArgumentException)).call(this, 'Invalid or missing argument provided', payload));\n }\n\n return InvalidArgumentException;\n}(TiddlyMapError);\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/lib/exceptions.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/URL": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/URL",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n// @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/URL\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/*** Code **********************************************************/\n\n/**\n * <<<\n * Lightweight URL manipulation with JavaScript. This library is\n * independent of any other libraries and has pretty simple interface\n * and lightweight code-base. Some ideas of query string parsing\n * had been taken from Jan Wolter.\"\n *\n * @see http://unixpapa.com/js/querystring.html\n * @license MIT\n * @author Mykhailo Stadnyk <mikhus@gmail.com>\n * <<< https://github.com/Mikhus/jsurl\n *\n * @class\n * @param {string} url\n */\nfunction Url(url) {\n this.paths = function (paths) {\n var prefix = '',\n i = 0,\n s;\n\n if (paths && paths.length && paths + '' !== paths) {\n if (this.isAbsolute()) {\n prefix = '/';\n }\n\n for (s = paths.length; i < s; i++) {\n paths[i] = encode(paths[i]);\n }\n\n this.path = prefix + paths.join('/');\n }\n\n paths = (this.path.charAt(0) === '/' ? this.path.slice(1) : this.path).split('/');\n\n for (i = 0, s = paths.length; i < s; i++) {\n paths[i] = decode(paths[i]);\n }\n\n return paths;\n };\n\n this.encode = encode;\n this.decode = decode;\n\n this.isAbsolute = function () {\n return this.protocol || this.path.charAt(0) === '/';\n };\n\n this.toString = function () {\n return (this.protocol && this.protocol + '://') + (this.user && encode(this.user) + (this.pass && ':' + encode(this.pass)) + '@') + (this.host && this.host) + (this.port && ':' + this.port) + (this.path && this.path) + (this.query.toString() && '?' + this.query) + (this.hash && '#' + encode(this.hash));\n };\n\n parse(this, url);\n}\n\nvar\n// mapping between what we want and <a> element properties\nmap = {\n protocol: 'protocol',\n host: 'hostname',\n port: 'port',\n path: 'pathname',\n query: 'search',\n hash: 'hash'\n},\n defaultPorts = {\n 'ftp': 21,\n 'gopher': 70,\n 'http': 80,\n 'https': 443,\n 'ws': 80,\n 'wss': 443\n},\n parse = function parse(self, url) {\n var d = document,\n link = d.createElement('a'),\n url = url || d.location.href,\n auth = url.match(/\\/\\/(.*?)(?::(.*?))?@/) || [],\n i;\n\n link.href = url;\n\n for (i in map) {\n self[i] = link[map[i]] || '';\n }\n\n // fix-up some parts\n self.protocol = self.protocol.replace(/:$/, '');\n self.query = self.query.replace(/^\\?/, '');\n self.hash = decode(self.hash.replace(/^#/, ''));\n self.user = decode(auth[1] || '');\n self.pass = decode(auth[2] || '');\n self.port = defaultPorts[self.protocol] == self.port || self.port == 0 ? '' : self.port; // IE fix, Android browser fix\n\n if (!self.protocol && !/^([a-z]+:)?\\/\\//.test(url)) {\n // is IE and path is relative\n var base = new Url(d.location.href.match(/(.*\\/)/)[0]),\n basePath = base.path.split('/'),\n selfPath = self.path.split('/'),\n props = ['protocol', 'user', 'pass', 'host', 'port'],\n s = props.length;\n\n basePath.pop();\n\n for (i = 0; i < s; i++) {\n self[props[i]] = base[props[i]];\n }\n\n while (selfPath[0] == '..') {\n // skip all \"../\n basePath.pop();\n selfPath.shift();\n }\n\n self.path = (url.charAt(0) != '/' ? basePath.join('/') : '') + '/' + selfPath.join('/');\n } else {\n // fix absolute URL's path in IE\n self.path = self.path.replace(/^\\/?/, '/');\n }\n\n self.paths((self.path.charAt(0) == '/' ? self.path.slice(1) : self.path).split('/'));\n\n parseQs(self);\n},\n encode = function encode(s) {\n return encodeURIComponent(s).replace(/'/g, '%27');\n},\n decode = function decode(s) {\n s = s.replace(/\\+/g, ' ');\n\n s = s.replace(/%([ef][0-9a-f])%([89ab][0-9a-f])%([89ab][0-9a-f])/gi, function (code, hex1, hex2, hex3) {\n var n1 = parseInt(hex1, 16) - 0xE0,\n n2 = parseInt(hex2, 16) - 0x80;\n\n if (n1 == 0 && n2 < 32) {\n return code;\n }\n\n var n3 = parseInt(hex3, 16) - 0x80,\n n = (n1 << 12) + (n2 << 6) + n3;\n\n if (n > 0xFFFF) {\n return code;\n }\n\n return String.fromCharCode(n);\n });\n\n s = s.replace(/%([cd][0-9a-f])%([89ab][0-9a-f])/gi, function (code, hex1, hex2) {\n var n1 = parseInt(hex1, 16) - 0xC0;\n\n if (n1 < 2) {\n return code;\n }\n\n var n2 = parseInt(hex2, 16) - 0x80;\n\n return String.fromCharCode((n1 << 6) + n2);\n });\n\n s = s.replace(/%([0-7][0-9a-f])/gi, function (code, hex) {\n return String.fromCharCode(parseInt(hex, 16));\n });\n\n return s;\n},\n parseQs = function parseQs(self) {\n var qs = self.query;\n\n self.query = new function (qs) {\n var re = /([^=&]+)(=([^&]*))?/g,\n match;\n\n while (match = re.exec(qs)) {\n var key = decodeURIComponent(match[1].replace(/\\+/g, ' ')),\n value = match[3] ? decode(match[3]) : '';\n\n if (this[key] != null) {\n if (!(this[key] instanceof Array)) {\n this[key] = [this[key]];\n }\n\n this[key].push(value);\n } else {\n this[key] = value;\n }\n }\n\n this.clear = function () {\n for (var key in this) {\n\n if (!(this[key] instanceof Function)) {\n\n delete this[key];\n }\n }\n };\n\n this.count = function () {\n var count = 0,\n key;\n for (key in this) {\n\n if (!(this[key] instanceof Function)) {\n count++;\n }\n }\n return count;\n };\n\n this.isEmpty = function () {\n return this.count() === 0;\n };\n\n this.toString = function () {\n var s = '',\n e = encode,\n i,\n ii;\n\n for (i in this) {\n\n if (this[i] instanceof Function) {\n continue;\n }\n\n if (this[i] instanceof Array) {\n\n var len = this[i].length;\n\n if (len) {\n for (ii = 0; ii < len; ii++) {\n s += s ? '&' : '';\n\n s += e(i) + '=' + e(this[i][ii]);\n }\n } else {\n // parameter is an empty array, so treat as\n // an empty argument\n\n s += (s ? '&' : '') + e(i) + '=';\n }\n } else {\n s += s ? '&' : '';\n\n s += e(i) + '=' + e(this[i]);\n }\n }\n\n return s;\n };\n }(qs);\n};\n\n/*** Exports *******************************************************/\n\nexports.default = Url;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/lib/url.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/lib/utils/basic": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/lib/utils/basic",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bindTo = exports.getNearestRasterPosition = exports.mod = exports.removeDOMChildNodes = exports.setDomListeners = exports.merge = exports.getRandomLabel = exports.getFirstElementByClassName = exports.getImgFromWeb = exports.pickRandom = exports.hasKeyWithPrefix = exports.getWithoutPrefix = exports.getPropertiesByPrefix = exports.removeArrayElement = exports.isTrue = exports.replaceAll = exports.isInteger = exports.findAndRemoveClassNames = exports.getAncestorWithClass = exports.makeHashMap = exports.getWithoutNewLines = exports.joinAndWrap = exports.parseJSON = exports.hasSubString = exports.inArray = exports.getRandomInt = exports.isEqual = exports.identity = exports.base64 = exports.startsWith = exports.getBasename = exports.escapeRegex = exports.hasElements = exports.ucFirst = undefined;\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/lib/utils/basic\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\nvar _exception = require('$:/plugins/felixhayashi/tiddlymap/js/exception');\n\n/**\n * Uppercase the first letter of a string.\n */\nvar ucFirst = exports.ucFirst = function ucFirst(string) {\n return string && string[0].toUpperCase() + string.slice(1);\n};\n\n/**\n * Function to find out whether an object has any enumerable properties\n * or, in case of an array, elements.\n *\n * @param {Object} obj\n * @return {boolean} True if at least one enumerable property exists,\n * false otherwise.\n */\nvar hasElements = exports.hasElements = function hasElements(obj) {\n return Object.keys(obj).length > 0;\n};\n\n/**\n * When we do not know the string, we need to escape it.\n * @deprecated use tw's escapeRegExp instead\n */\nvar escapeRegex = exports.escapeRegex = function escapeRegex(str) {\n return str.replace(/[-$^?.+*[\\]\\\\(){}|]/g, '\\\\$&');\n};\n\n/**\n * Returns the basename of a path.\n * A path is a string with slashes (or another separator).\n *\n * @param {string} path - The path\n * @param {string} [separator='/']\n * @return {string} The basename\n */\nvar getBasename = exports.getBasename = function getBasename(path) {\n var separator = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '/';\n return path.substring(path.lastIndexOf(separator) + 1);\n};\n\n/**\n * Helper to increase the code semantics.\n *\n * @param {string} str - The string to work with.\n * @param {string} prefix - The sequence to test.\n * @result {boolean} True if `str` starts with `prefix`, false otherwise.\n */\nvar startsWith = exports.startsWith = function startsWith(str, prefix) {\n return str.substring(0, prefix.length) === prefix;\n};\n\n/**\n * Converts a string to base64 encoding.\n *\n * To do so, we either choose the native btoa browser function or the Buffer class\n * received via scope.\n *\n * @param {string} str\n */\nvar base64 = exports.base64 = typeof window === 'undefined' ? function (str) {\n return new Buffer(str).toString('base64');\n} : window.btoa.bind(window);\n\n/**\n * If two objects have the same properties, with the same values\n * then identity identity(obj) === identity(obj2) will return true.\n *\n * @param obj\n * @return string\n */\nvar identity = exports.identity = function identity(obj) {\n return (typeof obj === 'undefined' ? 'undefined' : _typeof(obj)) === 'object' && obj !== null ? JSON.stringify(Object.keys(obj).sort().map(function (key) {\n return [key, obj[key]];\n })) : null;\n};\n\n/**\n * Returns true if both objects have the same properties\n * @param obj1\n * @param obj2\n */\nvar isEqual = exports.isEqual = function isEqual(obj1, obj2) {\n return identity(obj1) === identity(obj2);\n};\n\n/**\n *\n * @param min\n * @param max\n */\nvar getRandomInt = exports.getRandomInt = function getRandomInt(min, max) {\n return Math.floor(Math.random() * (max - min) + min);\n};\n\n/**\n * Checks if a value exists in an array. A strict search is used\n * which means that also the type of the needle in the haystack\n * is checked.\n *\n * @param {*} needle - The searched value.\n * @param {Array} haystack - The array.\n * @return Returns true if needle is found in the array, false otherwise.\n */\nvar inArray = exports.inArray = function inArray(needle, haystack) {\n return haystack.indexOf(needle) !== -1;\n};\n\n/**\n * Checks if a string exists in a string.\n */\nvar hasSubString = exports.hasSubString = function hasSubString(str, sub) {\n return str.indexOf(sub) !== -1;\n};\n\n/**\n * Try to turn the string into a javascript object. If the\n * transformation fails, return the optionally provided `data` object.\n *\n * @param {string} str - The string to parse.\n * @param {*} data - The default value if the operation fails.\n * @return {*} Either the object resulting from the parsing operation\n * or `undefined` or `data` if the operation failed.\n */\nvar parseJSON = exports.parseJSON = function parseJSON(str, data) {\n\n try {\n\n return JSON.parse(str);\n } catch (Error) {\n\n return data;\n }\n};\n\n/**\n * Joins all elements of an array into a string where all elements\n * are wrapped between `left` and `right`.\n *\n * @param {Array} arr - The array to perform the join on.\n * @param {string} left - The wrapping string for the left side.\n * @param {string} right - The wrapping string for the right side.\n * @param {string} [separator] - The separator between a wrapped element\n * and the next one. Defaults to space.\n * @return {string} The wrapped string, e.g. `[[hello]] [[world]]`.\n */\nvar joinAndWrap = exports.joinAndWrap = function joinAndWrap(arr, left, right) {\n var separator = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : ' ';\n return left + arr.join(right + separator + left) + right;\n};\n\n/**\n * Remove any newline from a string\n */\nvar getWithoutNewLines = exports.getWithoutNewLines = function getWithoutNewLines(str) {\n return typeof str === 'string' ? str.replace(/[\\n\\r]/g, ' ') : str;\n};\n\n/**\n * Factory function to return a prototypeless object that is used as\n * map. It only has the property hasOwnProperty in order to to be\n * exchangeble with other framworks that depend on this method like\n * e.g. visjs.\n *\n * @param {Object} [initialValues] - an object whose own properties will be\n * used to initialize the map.\n */\nvar makeHashMap = exports.makeHashMap = function makeHashMap(initialValues) {\n\n var map = Object.create(null);\n Object.defineProperty(map, 'hasOwnProperty', {\n enumerable: false,\n configurable: false,\n writable: false,\n value: Object.prototype.hasOwnProperty.bind(map)\n });\n\n if (initialValues) {\n for (var key in initialValues) {\n if (initialValues.hasOwnProperty(key)) {\n map[key] = initialValues[key];\n }\n }\n }\n\n return map;\n};\n\n/**\n * If an ancestor that possesses a specified class exists the the\n * element will be returned, otherwise undefined is returned.\n *\n * @param {Element} el\n * @param {string} className\n */\nvar getAncestorWithClass = exports.getAncestorWithClass = function getAncestorWithClass(el, className) {\n\n if ((typeof el === 'undefined' ? 'undefined' : _typeof(el)) !== 'object' || typeof className !== 'string') {\n return;\n }\n\n while (el.parentNode && el.parentNode !== document) {\n el = el.parentNode;\n if (el.classList.contains(className)) {\n return el;\n }\n }\n};\n\n/**\n * Searches the dom for elements that possess a certain class\n * and removes this class from each element.\n *\n * @param {Array<string>} classNames - The class names to remove.\n */\nvar findAndRemoveClassNames = exports.findAndRemoveClassNames = function findAndRemoveClassNames(classNames) {\n\n for (var i = classNames.length; i--;) {\n var elements = document.getElementsByClassName(classNames[i]);\n for (var j = elements.length; j--;) {\n elements[j].classList.remove(classNames[i]);\n }\n }\n};\n\n/**\n * Polyfill until `isInteger` has become official. If the target\n * value is an integer, return true, otherwise return false.\n * If the value is NaN or infinite, return false.\n *\n * @param {*} value - The value to be tested for being an integer.\n * @return {boolean} True if the value is an integer, false otherwise.\n */\nvar isInteger = exports.isInteger = Number.isInteger || function (value) {\n return typeof value === 'number' && isFinite(value) && Math.floor(value) === value;\n};\n\n/**\n *\n * @param {string} str\n * @param defaultReplacement\n * @param subStrings\n * @return {*}\n */\nvar replaceAll = exports.replaceAll = function replaceAll(str) {\n var defaultReplacement = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n var subStrings = arguments[2];\n\n\n for (var i = subStrings.length; i--;) {\n\n var subString = subStrings[i];\n var replacement = defaultReplacement;\n\n if (Array.isArray(subString)) {\n replacement = subString[1];\n subString = subString[0];\n }\n\n str = str.replace(subString, replacement);\n }\n\n return str;\n};\n\n/**\n * Sadly, setting fields with tw means that we lose the type information\n * since field values are persisted as strings and the type is not\n * included.\n *\n * To ensure that flags are always interpreted correctly, the following\n * function exists.\n *\n * We regard the following values as `true` (order matters):\n *\n * # Any string that can be translated into a number unequal `0`\n * # `\"true\"`\n * # Any number unequal `0`\n * # Boolean `true`\n *\n * The following as false (order matters):\n *\n * # Any string that can be translated into number `0`\n * # Every string unequal `\"true\"`\n * # The number `0`\n * # Boolean `false`\n *\n */\nvar isTrue = exports.isTrue = function isTrue(confVal, defVal) {\n\n if (confVal == null) {\n return !!defVal;\n } else if (typeof confVal === 'string') {\n var n = parseInt(confVal);\n return isNaN(n) ? confVal === 'true' : n !== 0;\n } else if (typeof confVal === 'boolean') {\n return confVal;\n } else if (typeof confVal === 'number') {\n return n !== 0;\n }\n\n return false;\n};\n\n/**\n * If the array contains the element, the element is removed from\n * the array in-place and the removed element.\n */\nvar removeArrayElement = exports.removeArrayElement = function removeArrayElement(arr, el) {\n\n var index = arr.indexOf(el);\n if (index > -1) {\n return arr.splice(index, 1)[0];\n }\n};\n\n/**\n * Returns a new object that contains only properties that start with\n * a certain prefix. The prefix is optionally removed from the result.\n *\n * @param {Object} obj\n * @param {string} prefix - The start sequence\n * @param {boolean} [removePrefix=false] - True if the prefix shall be removed\n * from the resulting property name, false otherwise.\n * @result {object}\n */\nvar getPropertiesByPrefix = exports.getPropertiesByPrefix = function getPropertiesByPrefix(obj, prefix, removePrefix) {\n\n var r = makeHashMap();\n for (var p in obj) {\n if (startsWith(p, prefix)) {\n r[removePrefix ? p.substr(prefix.length) : p] = obj[p];\n }\n }\n\n return r;\n};\n\n/**\n * Function to remove the prefix of a string\n */\nvar getWithoutPrefix = exports.getWithoutPrefix = function getWithoutPrefix(str, prefix) {\n return startsWith(str, prefix) ? str.substr(prefix.length) : str;\n};\n\n/**\n *\n */\nvar hasKeyWithPrefix = exports.hasKeyWithPrefix = function hasKeyWithPrefix(obj, prefix) {\n\n for (var p in obj) {\n if (startsWith(p, prefix)) {\n return true;\n }\n }\n\n return false;\n};\n\n/**\n *\n * @param arr\n */\nvar pickRandom = exports.pickRandom = function pickRandom(arr) {\n return arr[getRandomInt(0, arr.length - 1)];\n};\n\n/**\n * Loads the image from web and passes it to the callback as\n * object url.\n */\nvar getImgFromWeb = exports.getImgFromWeb = function getImgFromWeb(imgUri, callback) {\n\n if (!imgUri || typeof callback !== 'function') return;\n\n var xhr = new XMLHttpRequest();\n xhr.open('GET', imgUri, true);\n xhr.responseType = 'blob';\n xhr.onerror = function (e) {\n console.log(e);\n };\n xhr.onload = function (e) {\n if (this.readyState === 4 && (this.status === 200 || this.status === 0 && this.response.size > 0)) {\n var blob = this.response;\n callback(window.URL.createObjectURL(blob));\n }\n };\n\n try {\n xhr.send();\n } catch (e) {\n console.log(e);\n }\n};\n\n//~ utils.getNestedProperty = function(obj, propPath) {\n//~\n//~ propPath = propPath.split(\".\");\n//~ for (var i = propPath.length; i--;) {\n//~ if (obj !== null && typeof obj === \"object\") {\n//~ obj = obj[propPath[i]];\n//~ }\n//~\n//~ };\n\n/**\n * Works like get `getElementById()` but is based on a class name.\n * It will return the first element inside an optional parent (root)\n * that has a class of this name.\n *\n * @param {string} cls - The class name to search for.\n * @param {Element} [root=document] - The context to search in.\n * @param {boolean} [isRequired=true] - If true, an exception will be\n * thrown if no element can be retrieved. This is important\n * when depending on third party modules and class names change!\n * @throws {EnvironmentError} - May be thrown if\n * `isRequired` is set to true.\n * @return {Element} Either a dom element or null is returned.\n */\nvar getFirstElementByClassName = exports.getFirstElementByClassName = function getFirstElementByClassName(cls, root, isRequired) {\n\n var el = (root || document).getElementsByClassName(cls)[0];\n if (!el && (typeof isRequired === 'boolean' ? isRequired : true)) {\n var text = 'Missing element with class \"' + cls + '\" inside ' + root;\n throw new _exception.EnvironmentError(text);\n }\n\n return el;\n};\n\nvar getRandomLabel = exports.getRandomLabel = function getRandomLabel() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n\n var adjective = pickRandom(['exciting', 'notable', 'epic', 'new', 'fancy', 'great', 'cool', 'fresh', 'funky', 'clever']);\n\n var noun = (options.object || pickRandom(['concept', 'idea', 'thought', 'topic', 'subject'])) + (options.plural ? 's' : '');\n\n return 'My ' + adjective + ' ' + noun;\n};\n\nvar _merge = function _merge(dest, src) {\n\n if ((typeof dest === 'undefined' ? 'undefined' : _typeof(dest)) !== 'object') {\n dest = {};\n }\n\n for (var p in src) {\n if (src.hasOwnProperty(p)) {\n if (src[p] != null) {\n // skip null or undefined\n dest[p] = _typeof(src[p]) === 'object' ? _merge(dest[p], src[p]) : src[p]; // primitive type, stop recursion\n }\n }\n }\n\n return dest;\n};\n\n/**\n * Merges `src` into `dest` which means that the merge transforms\n * the `dest` object itself. If src and dest both have the same\n * property path, src does only replace the primitive data type\n * at the end of the path.\n *\n * @todo Should null really be skipped or treated as value?\n *\n * @param {Object} dest - The destination object.\n * @param {...Object} sources - At least one object to merge into `dest`.\n * @return {Object} The original `dest` object.\n */\nvar merge = exports.merge = function merge(dest) {\n for (var _len = arguments.length, sources = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n sources[_key - 1] = arguments[_key];\n }\n\n // start the merging; i = 1 since first argument is the destination\n for (var i = 0, l = sources.length; i < l; i++) {\n var src = sources[i];\n if (src != null && (typeof src === 'undefined' ? 'undefined' : _typeof(src)) === 'object') {\n dest = _merge(dest, src);\n }\n }\n\n return dest;\n};\n\n/**\n * Adds or removes listeners from the target in capture or\n * non-capture (bubbling) mode.\n *\n * @param {string} task - Either \"add\" or \"remove\". Make sure to\n * always call add and remove with *excatly* the same listeners\n * Note: if you use bind, you change the function object.\n * @param {Element} target - The element to attach or remove the\n * listener to or from.\n * @param {Object<string, (Function|Array)>} listeners - The key is\n * the event name and the value is either a handler function\n * or an array where the first index is the handler function and\n * the second is a boolean that specifies whether to use capture\n * or not.\n * @param {boolean} [isCapt=false] - Whether to run the handler in\n * bubbling or capturing phase.\n */\nvar setDomListeners = exports.setDomListeners = function setDomListeners(task, target, listeners, isCapt) {\n\n isCapt = typeof isCapt === 'boolean' ? isCapt : false;\n task = task + 'EventListener';\n\n for (var event in listeners) {\n\n var l = listeners[event];\n\n if (typeof l === 'function') {\n\n target[task](event, l, isCapt);\n } else {\n // expect Array\n\n target[task](event, l[0], typeof l[1] === 'boolean' ? l[1] : isCapt);\n }\n }\n};\n\n/**\n * Removes all child nodes of a DOM element. This includes element\n * and non-element objects.\n */\nvar removeDOMChildNodes = exports.removeDOMChildNodes = function removeDOMChildNodes(el) {\n\n for (var i = el.childNodes.length; i--;) {\n el.removeChild(el.childNodes[i]);\n }\n};\n\n/**\n * Implementation of the algebraic modulus operation.\n *\n * In javascript '%' is really a remainder operator, not a modulus.\n * Algebraically speaking, a modulus operation always yields\n * positive results, while '%' in js can yield negative results.\n *\n * Note: divident mod divisor\n *\n * @param {number} divident\n * @param {number} divisor\n * @return {number}\n */\nvar mod = exports.mod = function mod(divident, divisor) {\n\n var remainder = divident % divisor;\n\n return Math.floor(remainder >= 0 ? remainder : remainder + divisor);\n};\n\n/**\n * Maps a coordinate to the nearest raster coordinate.\n *\n * @param {number} x\n * @param {number} y\n * @param {number} raster\n * @return {{x: number, y: number}}\n */\nvar getNearestRasterPosition = exports.getNearestRasterPosition = function getNearestRasterPosition(_ref, raster) {\n var x = _ref.x,\n y = _ref.y;\n\n\n var rasterHalf = raster / 2;\n\n // calculate distances to previous raster lines\n var distPrevX = mod(x, raster);\n var distPrevY = mod(y, raster);\n\n return {\n x: distPrevX < rasterHalf ? x - distPrevX : x - distPrevX + raster,\n y: distPrevY < rasterHalf ? y - distPrevY : y - distPrevY + raster\n };\n};\n\n/**\n * Force early binding of functions to this context.\n *\n * @param context the context to bind this function to (typically `this`)\n * @param {Array<string>} fnNames - The prototype function names\n * to bind to this context.\n */\nvar bindTo = exports.bindTo = function bindTo(context, fnNames) {\n\n for (var i = fnNames.length; i--;) {\n var fn = context[fnNames[i]];\n context[fnNames[i]] = fn.bind(context);\n }\n};\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/lib/utils/basic.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/lib/utils/thirdParty": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/lib/utils/thirdParty",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n// @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/lib/utils/thirdParty\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/**\n * Modified TW-Code from Navigator widget\n * https://github.com/Jermolene/TiddlyWiki5/blob/master/core/modules/widgets/navigator.js\n */\nvar generateDraftTitle = exports.generateDraftTitle = function generateDraftTitle(title) {\n\n var c = 0,\n draftTitle = void 0;\n do {\n draftTitle = 'Draft ' + (c ? c + 1 + ' ' : '') + 'of \\'' + title + '\\'';\n c++;\n } while ($tw.wiki.tiddlerExists(draftTitle));\n return draftTitle;\n};\n\n/**\n * Modified TW-Code from Navigator widget\n * https://github.com/Jermolene/TiddlyWiki5/blob/master/core/modules/widgets/navigator.js\n */\nvar makeDraftTiddler = exports.makeDraftTiddler = function makeDraftTiddler(targetTitle) {\n\n // See if there is already a draft tiddler for this tiddler\n var draftTitle = $tw.wiki.findDraft(targetTitle);\n if (draftTitle) {\n return $tw.wiki.getTiddler(draftTitle);\n }\n // Get the current value of the tiddler we're editing\n var tiddler = $tw.wiki.getTiddler(targetTitle);\n // Save the initial value of the draft tiddler\n draftTitle = generateDraftTitle(targetTitle);\n var draftTiddler = new $tw.Tiddler(tiddler, {\n title: draftTitle,\n 'draft.title': targetTitle,\n 'draft.of': targetTitle\n }, $tw.wiki.getModificationFields());\n $tw.wiki.addTiddler(draftTiddler);\n return draftTiddler;\n};\n\n/**\n * TW-Code\n * @deprecated delete this in 2016 and use $tw.utils.getFullScreenApis instead\n */\nvar getFullScreenApis = exports.getFullScreenApis = function getFullScreenApis() {\n\n var d = document,\n db = d.body,\n result = {\n '_requestFullscreen': db.webkitRequestFullscreen !== undefined ? 'webkitRequestFullscreen' : db.mozRequestFullScreen !== undefined ? 'mozRequestFullScreen' : db.msRequestFullscreen !== undefined ? 'msRequestFullscreen' : db.requestFullscreen !== undefined ? 'requestFullscreen' : '',\n '_exitFullscreen': d.webkitExitFullscreen !== undefined ? 'webkitExitFullscreen' : d.mozCancelFullScreen !== undefined ? 'mozCancelFullScreen' : d.msExitFullscreen !== undefined ? 'msExitFullscreen' : d.exitFullscreen !== undefined ? 'exitFullscreen' : '',\n '_fullscreenElement': d.webkitFullscreenElement !== undefined ? 'webkitFullscreenElement' : d.mozFullScreenElement !== undefined ? 'mozFullScreenElement' : d.msFullscreenElement !== undefined ? 'msFullscreenElement' : d.fullscreenElement !== undefined ? 'fullscreenElement' : '',\n '_fullscreenChange': d.webkitFullscreenElement !== undefined ? 'webkitfullscreenchange' : d.mozFullScreenElement !== undefined ? 'mozfullscreenchange' : d.msFullscreenElement !== undefined ? 'MSFullscreenChange' : d.fullscreenElement !== undefined ? 'fullscreenchange' : ''\n };\n if (!result._requestFullscreen || !result._exitFullscreen || !result._fullscreenElement) {\n return null;\n } else {\n return result;\n }\n};\n\n/**\n *\n * Slightly modified by me to allow an optional prefix.\n *\n * For the original code:\n *\n * Copyright (c) 2014, Hugh Kennedy, All rights reserved.\n * Code published under the BSD 3-Clause License\n *\n * @see oringal repo https://github.com/hughsk/flat\n * @see snapshot https://github.com/felixhayashi/flat\n * @see http://opensource.org/licenses/BSD-3-Clause\n */\nvar flatten = exports.flatten = function flatten(target) {\n var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n\n var delimiter = opts.delimiter || '.';\n var prefix = opts.prefix || '';\n var output = {};\n\n function step(object, prev) {\n Object.keys(object).forEach(function (key) {\n var value = object[key];\n var isarray = opts.safe && Array.isArray(value);\n var type = Object.prototype.toString.call(value);\n var isobject = type === '[object Object]' || type === '[object Array]';\n\n var newKey = prev ? prev + delimiter + key : prefix + key;\n\n if (!isarray && isobject) {\n return step(value, newKey);\n }\n\n output[newKey] = value;\n });\n }\n\n step(target);\n\n return output;\n};\n\n/**\n * Copyright (c) 2014, Hugh Kennedy, All rights reserved.\n * Code published under the BSD 3-Clause License\n *\n * @see oringal repo https://github.com/hughsk/flat\n * @see snapshot https://github.com/felixhayashi/flat\n * @see http://opensource.org/licenses/BSD-3-Clause\n */\nvar unflatten = exports.unflatten = function unflatten(target) {\n var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n\n var delimiter = opts.delimiter || '.';\n var result = {};\n\n if (Object.prototype.toString.call(target) !== '[object Object]') {\n return target;\n }\n\n // safely ensure that the key is\n // an integer.\n function getkey(key) {\n var parsedKey = Number(key);\n\n return isNaN(parsedKey) || key.indexOf('.') !== -1 ? key : parsedKey;\n }\n\n Object.keys(target).forEach(function (key) {\n var split = key.split(delimiter);\n var key1 = getkey(split.shift());\n var key2 = getkey(split[0]);\n var recipient = result;\n\n while (key2 !== undefined) {\n if (recipient[key1] === undefined) {\n recipient[key1] = typeof key2 === 'number' && !opts.object ? [] : {};\n }\n\n recipient = recipient[key1];\n if (split.length > 0) {\n key1 = getkey(split.shift());\n key2 = getkey(split[0]);\n }\n }\n\n // unflatten again for 'messy objects'\n recipient[key1] = unflatten(target[key], opts);\n });\n\n return result;\n};\n\n/**\n * An adopted version of pmario's version to create\n * uuids of type RFC4122, version 4 ID.\n *\n * Shortened version:\n * pmario (1.0 - 2011.05.22):\n * http://chat-plugins.tiddlyspace.com/#UUIDPlugin\n *\n * Original version:\n * Math.uuid.js (v1.4)\n * http://www.broofa.com\n * mailto:robert@broofa.com\n *\n * Copyright (c) 2010 Robert Kieffer\n * Dual licensed under the MIT and GPL licenses.\n *\n * ---\n * @see https://github.com/almende/vis/issues/432\n*/\nvar genUUID = exports.genUUID = function () {\n\n // Private array of chars to use\n var CHARS = '0123456789abcdefghijklmnopqrstuvwxyz'.split('');\n\n return function () {\n var chars = CHARS,\n uuid = new Array(36);\n\n var rnd = 0,\n r;\n for (var i = 0; i < 36; i++) {\n if (i == 8 || i == 13 || i == 18 || i == 23) {\n uuid[i] = '-';\n } else if (i == 14) {\n uuid[i] = '4';\n } else {\n if (rnd <= 0x02) rnd = 0x2000000 + Math.random() * 0x1000000 | 0;\n r = rnd & 0xf;\n rnd = rnd >> 4;\n uuid[i] = chars[i == 19 ? r & 0x3 | 0x8 : r];\n }\n }\n\n return uuid.join('');\n };\n}();\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/lib/utils/thirdParty.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/lib/utils/tmap": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/lib/utils/tmap",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getSnapshotTitle = exports.getArrayValuesAsHashmapKeys = exports.getLookupTable = exports.keyOfItemWithProperty = exports.keysOfItemsWithProperty = exports.getDublicates = exports.getId = exports.refreshDataSet = exports.drawRaster = exports.getPrettyFilter = exports.groupByProperty = exports.isEdgeTypeMatch = exports.getEdgeTypeMatches = exports.getDataUri = exports.convert = exports.getValues = exports.getIterableCollection = exports.getLabel = undefined;\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/lib/utils/tmap\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\nvar _vis = require('$:/plugins/felixhayashi/vis/vis.js');\n\nvar _vis2 = _interopRequireDefault(_vis);\n\nvar _exception = require('$:/plugins/felixhayashi/tiddlymap/js/exception');\n\nvar _basic = require('$:/plugins/felixhayashi/tiddlymap/js/lib/utils/basic');\n\nvar basicUtils = _interopRequireWildcard(_basic);\n\nvar _wiki = require('$:/plugins/felixhayashi/tiddlymap/js/lib/utils/wiki');\n\nvar wikiUtils = _interopRequireWildcard(_wiki);\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * @param {Tiddler} tiddler\n * @param {string} aliasField - A tiddler field that contains an\n * alternative title (e.g. \"caption\").\n * @return {string|undefined} If the `aliasField` exists and is not\n * empty, the value of the `aliasField` otherwise the tiddler's\n * title or undefined if the tiddler doesn't exist.\n */\nvar getLabel = exports.getLabel = function getLabel(tiddler, aliasField) {\n var tObj = wikiUtils.getTiddler(tiddler);\n return tObj && tObj.fields[aliasField] ? tObj.fields[aliasField] : tObj.fields.title;\n};\n\n/**\n * This function will return a collection object whose data can be\n * via `Object.keys(col)` in a loop.\n *\n * @param {Collection} col - A collection\n * @return {Hashmap} The iterable object.\n */\nvar getIterableCollection = exports.getIterableCollection = function getIterableCollection(col) {\n return col instanceof _vis2.default.DataSet ? col.get() : col;\n};\n\n/**\n * Extract all the values from a collection. If `col` is an object,\n * only properties are considered that are its own and iterable.\n *\n * @param {Collection} col\n * @return {Array} An array\n */\nvar getValues = exports.getValues = function getValues(col) {\n\n if (Array.isArray(col)) {\n\n return col; // bounce back.\n } else if (col instanceof _vis2.default.DataSet) {\n // a dataset\n\n return col.get({ returnType: 'Array' });\n }\n\n var result = [];\n var keys = Object.keys(col);\n for (var i = keys.length; i--;) {\n result.push(col[keys[i]]);\n }\n\n return result;\n};\n\n/**\n * Transforms a collection of a certain type into a collection of\n * another type.\n *\n * **Attention**: When trying to convert an array into a object, the\n * array will be simply bounced back. Let's hope no one added enumerable\n * properties to Array.prototype :)\n *\n * @param {Collection} col - The collection to convert.\n * @param {CollectionTypeString} [outputType=\"dataset\"] - The output type.\n * @return {Collection} A **new** collection of type `outputType`.\n */\nvar convert = exports.convert = function convert(col, outputType) {\n\n if ((typeof col === 'undefined' ? 'undefined' : _typeof(col)) !== 'object') {\n throw new _exception.InvalidArgumentException(col, outputType);\n }\n\n if (outputType === 'object') {\n outputType = 'hashmap';\n }\n\n var mapper = {\n array: function array(col) {\n return getValues(col);\n },\n hashmap: function hashmap(col) {\n return col instanceof _vis2.default.DataSet ? col.get({ returnType: 'Object' }) : col;\n },\n dataset: function dataset(col) {\n return col instanceof _vis2.default.DataSet ? col : !Array.isArray(col) ? getValues(col) : new _vis2.default.DataSet(col);\n }\n };\n\n return mapper[outputType](col);\n};\n\n/**\n * @param {Tiddler} tiddler\n * @param {string} [type]\n * @param {boolean} [isForceBase64]\n * @return {string}\n */\nvar getDataUri = exports.getDataUri = function getDataUri(tiddler, type, isForceBase64) {\n\n var imgTObj = wikiUtils.getTiddler(tiddler);\n type = type || imgTObj.fields.type || 'image/svg+xml';\n var body = imgTObj.fields.text;\n var encoding = $tw.config.contentTypeInfo[type].encoding;\n\n if (type === 'image/svg+xml') {\n\n // see http://stackoverflow.com/questions/10768451/inline-svg-in-css\n body = body.replace(/\\r?\\n|\\r/g, ' ');\n\n if (!basicUtils.hasSubString('xmlns', body)) {\n // @tiddlywiki it is bad to remove the xmlns attribute!\n\n body = body.replace(/<svg/, '<svg xmlns=\"http://www.w3.org/2000/svg\"');\n }\n }\n\n if (isForceBase64 && encoding !== 'base64') {\n encoding = 'base64';\n body = basicUtils.base64(body);\n }\n\n return 'data:' + type + ';' + encoding + ',' + body;\n};\n\n// @todo move this to environment\nvar eTyFiltAutoPrefix = '[all[]] ';\n\n/**\n *\n * @param filter\n * @param titles\n * @return {*}\n */\nvar getEdgeTypeMatches = exports.getEdgeTypeMatches = function getEdgeTypeMatches() {\n var filter = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';\n var titles = arguments[1];\n\n\n if (!titles) {\n titles = wikiUtils.getTiddlersByPrefix($tm.path.edgeTypes + '/', {\n iterator: 'eachTiddlerPlusShadows',\n removePrefix: true\n });\n }\n\n if (titles != null && !Array.isArray(titles)) {\n titles = Object.keys(titles);\n }\n\n return wikiUtils.getMatches(eTyFiltAutoPrefix + filter, titles);\n};\n\nvar isEdgeTypeMatch = exports.isEdgeTypeMatch = function isEdgeTypeMatch(title) {\n var filter = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n return wikiUtils.isMatch(title, eTyFiltAutoPrefix + filter);\n};\n\n/**\n *\n */\nvar groupByProperty = exports.groupByProperty = function groupByProperty(col, prop) {\n\n col = getIterableCollection(col);\n\n var result = basicUtils.makeHashMap();\n var keys = Object.keys(col);\n\n for (var i in keys) {\n\n var item = col[keys[i]];\n var val = item[prop];\n\n if (val == null) {\n // null or undefined\n\n // @todo use exception class\n throw 'Cannot group by property ' + prop;\n } else {\n\n if (!Array.isArray(result[val])) {\n result[val] = [];\n }\n result[val].push(item);\n }\n }\n\n return result;\n};\n\n/**\n * Turns the filter expression in a nicely formatted (but unusable)\n * text, making it easier to edit long filter expressions.\n *\n * @param {string} expr - A valid filter expression.\n * @result {string} A formatted (unusable) filter expression.\n */\nvar getPrettyFilter = exports.getPrettyFilter = function getPrettyFilter(expr) {\n\n // remove outer spaces and separate operands\n expr = expr.trim().replace('][', '] [');\n\n // regex to identify operands\n var re = /[+-]?\\[.+?[\\]\\}\\>]\\]/g;\n\n // get operands\n var operands = expr.match(re);\n\n // replace operands with dummies and trim again to avoid trailing spaces\n expr = expr.replace(re, ' [] ').trim();\n\n // turn it into an array\n var stringsPlusDummies = expr.split(/\\s+/);\n\n var operandIndex = 0;\n var parts = [];\n for (var i = 0, l = stringsPlusDummies.length; i < l; i++) {\n parts[i] = stringsPlusDummies[i] === '[]' ? operands[operandIndex++] : stringsPlusDummies[i];\n }\n\n return parts.join('\\n');\n};\n\n/**\n * This function will draw a raster on the network canvas that will\n * adjust to the network's current scaling factor and viewport offset.\n *\n * @param {CanvasRenderingContext2D} ctx - The canvas's context passed by vis.\n * @param {number} scaleFactor - The current scale factor of the network.\n * @param {Object} viewCenter - Virtual center point of the view.\n * @param {number} rasterSize - The size of the squares that are drawn.\n * @param {string} color - A string parsed as CSS color value.\n */\nvar drawRaster = exports.drawRaster = function drawRaster(ctx, scaleFactor, viewCenter, rasterSize) {\n var color = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : '#D9D9D9';\n\n // from now on the most central raster point\n var _basicUtils$getNeares = basicUtils.getNearestRasterPosition(viewCenter, rasterSize),\n centerX = _basicUtils$getNeares.x,\n centerY = _basicUtils$getNeares.y;\n\n var scaledWidth = ctx.canvas.width / scaleFactor;\n var scaledHeight = ctx.canvas.height / scaleFactor;\n\n // some extra lines to ensure the canvas is completely filled with lines\n var extraLines = rasterSize * 2;\n\n // calculate the space that is required to draw the rasters\n var hSpace = Math.ceil(scaledWidth / rasterSize / 2) * rasterSize + extraLines;\n var vSpace = Math.ceil(scaledHeight / rasterSize / 2) * rasterSize + extraLines;\n\n // align the space to the center points and calculate the offsets\n var left = centerX - hSpace;\n var right = centerX + hSpace;\n var top = centerY - vSpace;\n var bottom = centerY + vSpace;\n\n ctx.beginPath();\n\n // draw vertical lines\n for (var x = left; x < right; x += rasterSize) {\n ctx.moveTo(x, top);\n ctx.lineTo(x, bottom);\n }\n\n // draw horizontal lines\n for (var y = top; y <= bottom; y += rasterSize) {\n ctx.moveTo(left, y);\n ctx.lineTo(right, y);\n }\n\n ctx.strokeStyle = color;\n ctx.fillStyle = color;\n ctx.stroke();\n};\n\n/**\n * Updates a dataset.\n *\n * Note: never use the dataset's update() method, it does not properly remove\n * obsolete properties! – use remove and add instead.\n *\n * @param {vis.DataSet} [ds] - The dataset to be updated\n * @param {Hashmap<id, Node>} ltNew - Lookup table that contains the *new* set of nodes.\n */\nvar refreshDataSet = exports.refreshDataSet = function refreshDataSet(ds, ltNew) {\n\n var ltOld = ds.get({ returnType: 'Object' });\n\n var inserted = [];\n var updated = [];\n var withoutPosition = [];\n var removed = [];\n\n for (var id in ltNew) {\n\n if (ltOld[id]) {\n // element already exists in graph\n\n if (basicUtils.isEqual(ltOld[id], ltNew[id])) {\n // simply keep element\n continue;\n }\n\n updated.push(id);\n ds.remove(id);\n } else {\n\n inserted.push(id);\n }\n\n if (ltNew[id].x === undefined) {\n withoutPosition.push(id);\n }\n\n ds.add(ltNew[id]);\n }\n\n for (var _id in ltOld) {\n if (!ltNew[_id]) {\n removed.push(_id);\n ds.remove(_id);\n }\n }\n\n return {\n withoutPosition: withoutPosition,\n inserted: inserted,\n updated: updated,\n removed: removed\n };\n};\n\n/**\n * Returns the tmap id that is stored in a designated field in the tiddler.\n *\n * @param tiddler\n * @return {string} the tmap id of this tiddler\n */\nvar getId = exports.getId = function getId(tiddler) {\n return wikiUtils.getTiddler(tiddler).fields['tmap.id'];\n};\n\n/**\n * Returns all other tiddlers that have the same tmap.id field entry.\n *\n * Note: typically tiddlers don't have the same id assigned, however,\n * this can happen when tiddlers are imported or cloned.\n *\n * @param {Tiddler} tiddler\n * @return {array<TiddlerReference>} a list of tiddlers with the same id as the\n * provided tiddler (excluding the provided tiddler itself).\n */\nvar getDublicates = exports.getDublicates = function getDublicates(tiddler) {\n\n var id = getId(tiddler);\n\n if (!id) {\n\n return [];\n }\n\n var tiddlers = wikiUtils.getTiddlersWithField('tmap.id', id, { limit: 2 });\n delete tiddlers[wikiUtils.getTiddlerRef(tiddler)];\n\n return Object.keys(tiddlers);\n};\n\n/**\n * Function that searches an array for an object with a property\n * having a certain value.\n *\n * Attention: Not the item itself but the item's key is returned.\n *\n * @param {Collection} col - The collection to search in.\n * @param {string} key - The property name to look for.\n * @param {*} [val] - An optional value that the object's property must have\n * in order to match.\n * @param {number} [limit] - An optional result limit (>0) to stop the search.\n * @return {Array<Id>} An array containing the indeces of matching items.\n */\nvar keysOfItemsWithProperty = exports.keysOfItemsWithProperty = function keysOfItemsWithProperty(col, key, val, limit) {\n\n col = getIterableCollection(col);\n\n var keys = Object.keys(col);\n var result = [];\n\n limit = typeof limit === 'number' ? limit : keys.length;\n\n for (var i = 0, l = keys.length; i < l; i++) {\n var index = keys[i];\n if (_typeof(col[index]) === 'object' && col[index][key]) {\n if (!val || col[index][key] === val) {\n result.push(index);\n if (result.length === limit) {\n break;\n }\n }\n }\n }\n\n return result;\n};\n\n/**\n *\n * @param col\n * @param key\n * @param val\n * @return {*}\n */\nvar keyOfItemWithProperty = exports.keyOfItemWithProperty = function keyOfItemWithProperty(col, key, val) {\n return keysOfItemsWithProperty(col, key, val, 1)[0];\n};\n\n/**\n * In a collection where all elements have a **distinct** property\n * `lookupKey`, use the value of each element's `lookupKey` as key\n * to identify the object. If no property `lookupKey` is specified,\n * the collection's values are used as keys and `true` is used as value,\n * however, if the used keys are not strings, an error is thrown.\n *\n * @param {Collection} col - The collection for which to create a lookup table.\n * @param {string} [lookupKey] - The property name to use as index in\n * the lookup table. If not specified, the collection values are tried\n * to be used as indeces.\n * @return {Hashmap} The lookup table.\n */\nvar getLookupTable = exports.getLookupTable = function getLookupTable(col, lookupKey) {\n\n col = getIterableCollection(col);\n\n var lookupTable = basicUtils.makeHashMap();\n var keys = Object.keys(col);\n\n for (var i = 0, l = keys.length; i < l; i++) {\n\n var key = keys[i];\n var idx = lookupKey ? col[key][lookupKey] : col[key];\n var type = typeof idx === 'undefined' ? 'undefined' : _typeof(idx);\n\n if (type === 'string' && idx !== '' || type === 'number') {\n if (!lookupTable[idx]) {\n // doesn't exist yet!\n lookupTable[idx] = lookupKey ? col[key] : true;\n continue;\n }\n }\n\n // @todo use exception class\n throw new Error('Cannot use \"' + idx + '\" as lookup table index');\n }\n\n return lookupTable;\n};\n\n/**\n * Alias for {@link getLookupTable}\n */\nvar getArrayValuesAsHashmapKeys = exports.getArrayValuesAsHashmapKeys = getLookupTable;\n\n/**\n *\n * @param viewLabel\n * @param type\n */\nvar getSnapshotTitle = exports.getSnapshotTitle = function getSnapshotTitle(viewLabel, type) {\n return 'Snapshot \\u2013 ' + viewLabel + ' (' + new Date().toDateString() + ').' + (type || 'png');\n};\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/lib/utils/tmap.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/utils": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/utils",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.utils = undefined;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/utils\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\nvar _basic = require('$:/plugins/felixhayashi/tiddlymap/js/lib/utils/basic');\n\nvar basicUtils = _interopRequireWildcard(_basic);\n\nvar _thirdParty = require('$:/plugins/felixhayashi/tiddlymap/js/lib/utils/thirdParty');\n\nvar thirdPartyUtils = _interopRequireWildcard(_thirdParty);\n\nvar _wiki = require('$:/plugins/felixhayashi/tiddlymap/js/lib/utils/wiki');\n\nvar wikiUtils = _interopRequireWildcard(_wiki);\n\nvar _tmap = require('$:/plugins/felixhayashi/tiddlymap/js/lib/utils/tmap');\n\nvar tMapUtils = _interopRequireWildcard(_tmap);\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }\n\n/*** Code **********************************************************/\n\n/**\n * A utilities class that contains universally used helper functions\n * to abbreviate code and make my life easier.\n *\n * ATTENTION: This module must not require any other tiddlymap file\n * in order to avoid cyclic dependencies. For the same reason,\n * it must also not access the `$tm.*` object.\n *\n * Exceptions to this restriction:\n * - The utils module may access all `$tm.*` properties\n * defined in startup.environment.\n * - The utils module may require vendor libs or tiddlymap libs\n * that only require vendor libs themselves.\n *\n * @see Dom utilities {@link https://github.com/Jermolene/TiddlyWiki5/blob/master/core/modules/utils/*}\n * @namespace utils\n */\nvar utils = exports.utils = _extends({}, basicUtils, thirdPartyUtils, wikiUtils, tMapUtils);\n\nexports.default = utils;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/lib/utils/utils.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/lib/utils/wiki": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/lib/utils/wiki",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.touch = exports.addTiddler = exports.getTiddlersByPrefix = exports.getTiddlerWithField = exports.getTiddlersWithField = exports.deleteByPrefix = exports.cp = exports.mv = exports.addTWlisteners = exports.getChildWidgetByProperty = exports.getMergedTiddlers = exports.isSystemOrDraft = exports.isDraft = exports.setText = exports.getText = exports.isLeftVersionGreater = exports.getEntry = exports.setEntry = exports.clone = exports.writeFieldData = exports.parseFieldData = exports.isPreviewed = exports.notify = exports.registerTransclude = exports.getElementNode = exports.getTiddlerNode = exports.getTranscludeNode = exports.isMatch = exports.getMatches = exports.moveFieldValues = exports.deleteTiddlers = exports.setField = exports.setSidebarTab = exports.tiddlerExists = exports.getField = exports.getTiddler = exports.getTiddlerRef = undefined;\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nvar _exception = require('$:/plugins/felixhayashi/tiddlymap/js/exception');\n\nvar _basic = require('$:/plugins/felixhayashi/tiddlymap/js/lib/utils/basic');\n\nvar basicUtils = _interopRequireWildcard(_basic);\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/lib/utils/wiki\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\n/**\n * Gets a tiddler reference from a tRef or tObj\n *\n * @param {Tiddler|string} tiddler - A tiddler reference or object.\n * @return {TiddlerReference|null} A tiddler reference (title)\n */\nvar getTiddlerRef = exports.getTiddlerRef = function getTiddlerRef(tiddler) {\n\n if (tiddler instanceof $tw.Tiddler) {\n\n return tiddler.fields.title;\n } else if (typeof tiddler === 'string') {\n\n return tiddler;\n } else {\n\n throw new _exception.InvalidArgumentException(tiddler);\n }\n};\n\n/**\n * Similar to {@code wiki.getTiddler()} but also accepts a tObj as\n * argument, thus, making it unnecessary to always differentiate or remember\n * if we are dealing with an object or a reference.\n *\n * @see https://github.com/Jermolene/TiddlyWiki5/blob/master/boot/boot.js#L866\n * @param {Tiddler} tiddler - A tiddler reference or object.\n * @return {Tiddler} A tiddler object.\n */\nvar getTiddler = exports.getTiddler = function getTiddler(tiddler) {\n return $tw.wiki.getTiddler(tiddler instanceof $tw.Tiddler ? tiddler.fields.title : tiddler);\n};\n\n/**\n * Get a tiddler's field value. If the field does not exist or\n * its value is an empty string, return the default or an empty\n * string.\n */\nvar getField = exports.getField = function getField(tiddler, field) {\n var defValue = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '';\n\n\n var tObj = getTiddler(tiddler);\n return !tObj ? defValue : tObj.fields[field] || defValue;\n};\n\n/**\n * Checks if tiddlers (including shadow tiddlers) exist.\n *\n * @param {Tiddler} tiddler\n * @return {boolean} True if the tiddler exists, false otherwise\n */\nvar tiddlerExists = exports.tiddlerExists = function tiddlerExists(tiddler) {\n\n if (!tiddler) {\n return false;\n }\n\n var tRef = getTiddlerRef(tiddler);\n\n return Boolean(tRef && ($tw.wiki.tiddlerExists(tRef) || $tw.wiki.isShadowTiddler(tRef)));\n};\n\nvar setSidebarTab = exports.setSidebarTab = function setSidebarTab(tRef) {\n\n setText(getTiddlersByPrefix('$:/state/tab/sidebar-')[0], tRef);\n};\n\n/**\n * Set a tiddler field to a given value.\n *\n * Setting the title field to another value will clone the tiddler.\n * In this case, better use @link{clone} as this is\n * semantically stronger.\n *\n * This method is guarded against\n * https://github.com/Jermolene/TiddlyWiki5/issues/2025\n *\n * @return {$tw.Tiddler|undefined} The tiddler object containing\n * the field with the assigned value.\n */\nvar setField = exports.setField = function setField(tiddler, field, value) {\n\n if (!tiddler || !field) {\n return;\n }\n\n var tRef = getTiddlerRef(tiddler);\n var fields = _defineProperty({\n title: tRef\n }, field, value);\n\n // do not use any tObj provided, it may result in a lost update!\n var tObj = $tw.wiki.getTiddler(tRef, true);\n\n if (field !== 'text' && tObj && !tObj.fields.text) {\n fields.text = '';\n }\n\n tObj = new $tw.Tiddler(tObj, fields);\n $tw.wiki.addTiddler(tObj);\n\n return tObj;\n};\n\n/**\n * Pendant to tw native {@code addTiddlers()}.\n *\n * Also removes tiddlers from the river.\n *\n * @param {TiddlerCollection} tiddlers - A collection of tiddlers\n * to be removed.\n */\nvar deleteTiddlers = exports.deleteTiddlers = function deleteTiddlers(tiddlers) {\n\n var keys = Object.keys(tiddlers);\n var storyList = $tw.wiki.getTiddlerList('$:/StoryList');\n\n for (var i = keys.length; i--;) {\n var tRef = getTiddlerRef(tiddlers[keys[i]]);\n if (!$tw.wiki.tiddlerExists(tiddlers[keys[i]])) {\n // this check is important!\n // see https://github.com/Jermolene/TiddlyWiki5/issues/1919\n continue;\n }\n\n var index = storyList.indexOf(tRef);\n if (index !== -1) {\n // tiddler is displayed in river\n storyList.splice(index, 1);\n setField('$:/StoryList', 'list', storyList);\n }\n\n // finally delete the tiddler;\n\n\n $tw.wiki.deleteTiddler(tRef);\n }\n};\n\nvar moveFieldValues = exports.moveFieldValues = function moveFieldValues(oldName, newName, isRemoveOldField, isIncludeSystemTiddlers, tiddlers) {\n\n if (oldName === newName) return;\n\n var allTiddlers = tiddlers || $tw.wiki.allTitles();\n\n for (var i = allTiddlers.length; i--;) {\n\n var tObj = getTiddler(allTiddlers[i]);\n\n if (tObj.isDraft() || !tObj.fields[oldName]) {\n continue;\n }\n\n if (!isIncludeSystemTiddlers && $tw.wiki.isSystemTiddler(allTiddlers[i])) {\n continue;\n }\n\n var fields = _defineProperty({}, newName, tObj.fields[oldName]);\n\n if (isRemoveOldField) {\n fields[oldName] = undefined;\n }\n $tw.wiki.addTiddler(new $tw.Tiddler(tObj, fields));\n }\n};\n\n/**\n * This function returns all tiddlers that match the filter.\n *\n * @Todo: skip drafts! Or not?\n *\n * @param {TiddlyWikiFilter} filter - The filter to use.\n * @param {TiddlerCollection} [tiddlers] - A set of tiddlers used as\n * source. If not defined, all tiddlers and system tiddlers are\n * selected. Shadows are *not* included.\n * @return {Array.<TiddlerReference>}\n */\nvar getMatches = exports.getMatches = function getMatches(filter, tiddlers, widget) {\n\n // use wiki as default source\n var source = undefined;\n\n // shortcuts for performance\n var wiki = $tw.wiki;\n\n if (typeof filter === 'string') {\n filter = wiki.compileFilter(filter);\n }\n\n // if a source is provided, create an iterator callback\n if (tiddlers != null && (typeof tiddlers === 'undefined' ? 'undefined' : _typeof(tiddlers)) === 'object') {\n\n if (!Array.isArray(tiddlers)) {\n tiddlers = Object.keys(tiddlers);\n }\n\n source = function source(callback) {\n for (var i = tiddlers.length; i--;) {\n var tObj = wiki.getTiddler(tiddlers[i]);\n callback(tObj, tiddlers[i]);\n }\n };\n }\n\n return filter.call(wiki, source, widget);\n};\n\n/**\n * Tries to match a single tiddler object against a filter.\n * Returns a boolean value.\n *\n * @param {Tiddler} tiddler - The object to apply the filter to.\n * @param {TiddlyWikiFilter} filter - The filter to use.\n * @return {boolean} True if the tiddler matches the filter, false otherwise.\n */\nvar isMatch = exports.isMatch = function isMatch(tiddler, filter) {\n return getTiddlerRef(tiddler) === getMatches(filter, [getTiddlerRef(tiddler)])[0];\n};\n\n/**\n *\n * @param {Tiddler} tiddler\n * @param {boolean} isBlock\n */\nvar getTranscludeNode = exports.getTranscludeNode = function getTranscludeNode(tiddler, isBlock) {\n return {\n type: 'transclude',\n attributes: {\n tiddler: {\n type: 'string',\n value: getTiddlerRef(tiddler) } },\n children: [],\n isBlock: !!isBlock\n };\n};\n\n/**\n *\n * @param {Tiddler} tiddler\n */\nvar getTiddlerNode = exports.getTiddlerNode = function getTiddlerNode(tiddler) {\n return {\n type: 'tiddler',\n attributes: {\n tiddler: {\n type: 'string', value: getTiddlerRef(tiddler) } },\n children: []\n };\n};\n\n/**\n *\n * @param type\n * @param className\n * @param text\n */\nvar getElementNode = exports.getElementNode = function getElementNode(type, className, text) {\n return {\n type: 'element',\n tag: type,\n attributes: {\n class: {\n type: 'string',\n value: className } },\n children: text ? [{ type: 'text', text: text }] : []\n };\n};\n\n/**\n *\n * @param {Widget} widget\n * @param {string} name\n * @param {Tiddler} tiddler\n * @return {*}\n */\nvar registerTransclude = exports.registerTransclude = function registerTransclude(widget, name, tiddler) {\n\n // if an instance exists, remove it\n basicUtils.removeArrayElement(widget.children, widget[name]);\n\n widget[name] = widget.makeChildWidget(getTranscludeNode(tiddler, true));\n widget.children.push(widget[name]);\n\n return widget[name];\n};\n\n/**\n * This function uses the tw-notification mechanism to display a\n * temporary message.\n *\n * @see https://github.com/Jermolene/TiddlyWiki5/blob/master/core/modules/utils/dom/notifier.js\n * @param {string} message - A short message to display.\n */\nvar notify = exports.notify = function notify(message) {\n\n // @todo add to environment\n var notifyTiddlerRef = '$:/temp/tiddlymap/notify';\n\n $tw.wiki.addTiddler(new $tw.Tiddler({\n title: notifyTiddlerRef,\n text: message\n }));\n\n $tw.notifier.display(notifyTiddlerRef);\n};\n\n/**\n * The function allows to detect whether a widget is displayed\n * in preview or not.\n */\nvar isPreviewed = exports.isPreviewed = function isPreviewed(widget) {\n if (!widget) {\n return false;\n }\n\n // TODO: in the wiki utils we should not know about TiddlyMap domNode property!\n if (widget.domNode.isTiddlyWikiFakeDom) {\n return true;\n }\n\n if (widget.getVariable('tv-tiddler-preview')) {\n return true;\n } else {\n // fallback for < v5.1.9\n var cls = 'tc-tiddler-preview-preview';\n // TODO: in the wiki utils we should not know about TiddlyMap domNode property!\n return !!basicUtils.getAncestorWithClass(widget.parentDomNode, cls);\n }\n};\n\n/**\n * Parse json from field or return default value on error.\n *\n * @param {Tiddler} tiddler - The tiddler containing the json.\n * @param {string} field - The field with the json data.\n * @param {Object} [data] - An optional default value.\n * @return {*} Either the parsed data or the default data.\n */\nvar parseFieldData = exports.parseFieldData = function parseFieldData(tiddler) {\n var field = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'text';\n var data = arguments[2];\n\n\n var tObj = getTiddler(tiddler);\n\n if (!tObj) {\n return data;\n }\n\n return basicUtils.parseJSON(tObj.fields[field], data);\n};\n\n/**\n * Serialize json data and store it in a tiddler's field.\n *\n * @param {Tiddler} tiddler - The tiddler to store the json in.\n * @param {string} field - The field that will store the json.\n * @param {Object} data - The json data.\n * @param {int} [indent = 0] - the indentation\n */\nvar writeFieldData = exports.writeFieldData = function writeFieldData(tiddler, field, data, indent) {\n\n if ((typeof data === 'undefined' ? 'undefined' : _typeof(data)) !== 'object') {\n return;\n }\n\n indent = parseInt(indent);\n indent = indent > 0 && field === 'text' ? indent : 0;\n\n setField(tiddler, field, JSON.stringify(data, null, indent));\n};\n\n/**\n * Clone a tiddler and give it another title.\n * This means the tiddlers are equal except from their titles.\n */\nvar clone = exports.clone = function clone(src, dest) {\n\n setField(src, 'title', dest);\n};\n\n/**\n * Set the value of a data tiddler entry (index) to a given value\n */\nvar setEntry = exports.setEntry = function setEntry(tiddler, prop, value) {\n\n $tw.wiki.setText(getTiddlerRef(tiddler), null, prop, value);\n};\n\n/**\n * Get the value of a data tiddler entry (index)\n */\nvar getEntry = exports.getEntry = function getEntry(tiddler, prop, defValue) {\n\n var data = $tw.wiki.getTiddlerData(getTiddlerRef(tiddler), {});\n return data[prop] == null ? defValue : data[prop];\n};\n\n//~ utils.getNestedProperty = function(obj, propPath) {\n//~\n//~ propPath = propPath.split(\".\");\n//~ for (var i = propPath.length; i--;) {\n//~ if (obj !== null && typeof obj === \"object\") {\n//~ obj = obj[propPath[i]];\n//~ }\n//~\n//~ };\n\n/**\n * Compare versions.\n * @return {boolean} Unlike `$tw.utils.checkVersions`, this function\n * only returns true if the left argument is greater than the right\n * argument.\n */\nvar isLeftVersionGreater = exports.isLeftVersionGreater = function isLeftVersionGreater(v1, v2) {\n return v1 !== v2 && $tw.utils.checkVersions(v1, v2);\n};\n\n/**\n *\n * @param tiddler\n * @param defValue\n */\nvar getText = exports.getText = function getText(tiddler, defValue) {\n return getField(tiddler, 'text', defValue);\n};\n\n/**\n *\n * @param tiddler\n * @param value\n */\nvar setText = exports.setText = function setText(tiddler, value) {\n\n setField(tiddler, 'text', value);\n};\n\n/**\n * Checks whether a tiddler is a draft or not.\n *\n * @param {Tiddler} tiddler - The tiddler to check on.\n */\nvar isDraft = exports.isDraft = function isDraft(tiddler) {\n\n var tObj = getTiddler(tiddler);\n return tObj && tObj.isDraft();\n};\n\n/**\n * Get a tiddler's text or otherwise return a default text.\n */\nvar isSystemOrDraft = exports.isSystemOrDraft = function isSystemOrDraft(tiddler) {\n return $tw.wiki.isSystemTiddler(getTiddlerRef(tiddler)) || isDraft(tiddler);\n};\n\n/**\n * Function to merge an array of tiddlers into a single tiddler.\n *\n * @param {Array<TiddlerReference|Tiddler>} tiddlers - The\n * tiddlers to merge.\n * @param {string} [title=null] - The title where the result is\n * written to. If not specified, the first array item is used\n * as output title.\n */\nvar getMergedTiddlers = exports.getMergedTiddlers = function getMergedTiddlers(tiddlers, title) {\n\n if (!Array.isArray(tiddlers)) {\n return;\n }\n\n // turn all array elements into tiddler objects\n for (var i = tiddlers.length; i--;) {\n tiddlers[i] = getTiddler(tiddlers[i]);\n }\n\n if (!tiddlers.length) {\n return;\n }\n\n tiddlers.push({ title: title || tiddlers[0].fields.title }, $tw.wiki.getModificationFields(), $tw.wiki.getCreationFields());\n\n // add context for `apply()` function\n tiddlers.unshift(null);\n\n return new (Function.prototype.bind.apply($tw.Tiddler, tiddlers))();\n};\n\n/**\n * Depth first search\n */\nvar getChildWidgetByProperty = exports.getChildWidgetByProperty = function getChildWidgetByProperty(widget, prop, val) {\n\n var children = widget.children;\n for (var i = children.length; i--;) {\n var child = children[i];\n if (child[prop] === val) {\n return child;\n } else {\n child = getChildWidgetByProperty(child, prop, val);\n if (child) {\n return child;\n }\n }\n }\n};\n\n/**\n * Register listeners to widget using a hashmap.\n *\n * @param {Hashmap<Key, Function>} listeners - The listeners to attach.\n * @param {Widget} widget - the widget to attach the listeners to.\n * @param {Object} context - The context to bind the listeners to.\n */\nvar addTWlisteners = exports.addTWlisteners = function addTWlisteners(listeners, widget, context) {\n\n for (var id in listeners) {\n widget.addEventListener(id, listeners[id].bind(context));\n }\n};\n\n/**\n * Renames all tiddler titles that are prefixed with `oldPrefix`\n * into titles that are prefixed with `newPrefix` by replacing\n * `oldPrefix` with `newPrefix`.\n *\n * The force option somewhat ensures atomicity.\n *\n * @param {string} oldPrefix - Moves all tiddlers with this prefix.\n * @param {string} newPrefix - All tiddlers moved tiddlers will\n * receive this new prefix.\n * @param {boolean} [isForce=false] - If a new title would override\n * an existing title, and `force` is not set, then nothing will\n * happen and undefined is returned by the function.\n * @param {boolean} [isDelete=true] - True, if the tiddlers with the\n * old prefix should be deleted or false, if they should be kept.\n * @returns {Object<string, string>} - A hashmap that maps the old\n * and the new path.\n */\nvar mv = exports.mv = function mv(oldPrefix, newPrefix, isForce, isDelete) {\n\n if (oldPrefix === newPrefix || !oldPrefix || !newPrefix) {\n return;\n }\n\n isForce = typeof isForce === 'boolean' ? isForce : false;\n isDelete = typeof isDelete === 'boolean' ? isDelete : true;\n\n // prepare\n var targets = getTiddlersByPrefix(oldPrefix);\n var fromToMapper = basicUtils.makeHashMap();\n\n for (var i = targets.length; i--;) {\n\n var oldTRef = targets[i];\n var newTRef = oldTRef.replace(oldPrefix, newPrefix);\n if ($tw.wiki.tiddlerExists(newTRef) && !isForce) {\n return; // undefined\n }\n fromToMapper[oldTRef] = newTRef;\n }\n\n for (var _oldTRef in fromToMapper) {\n\n setField(_oldTRef, 'title', fromToMapper[_oldTRef]);\n if (isDelete) {\n $tw.wiki.deleteTiddler(_oldTRef);\n }\n }\n\n return fromToMapper;\n};\n\n/**\n * Clones all tiddler titles that are prefixed with `oldPrefix`\n * into titles that are instead prefixed with `newPrefix`.\n *\n * The force option somewhat ensures atomicity.\n *\n * @param {string} oldPrefix - Moves all tiddlers with this prefix.\n * @param {string} newPrefix - All tiddlers moved tiddlers will\n * receive this new prefix.\n * @param {boolean} [isForce=false] - If a new title would override\n * an existing title, and `force` is not set, then nothing will\n * happen and undefined is returned by the function.\n * @returns {Object<string, string>} - A hashmap that maps the old\n * and the new path.\n */\nvar cp = exports.cp = function cp(oldPrefix, newPrefix, isForce) {\n return mv(oldPrefix, newPrefix, isForce, false);\n};\n\n/**\n * Delete all tiddlers with a given prefix.\n *\n * @param {string} prefix - The prefix\n */\nvar deleteByPrefix = exports.deleteByPrefix = function deleteByPrefix(prefix, tiddlers) {\n\n if (!prefix) {\n return;\n }\n\n tiddlers = tiddlers || $tw.wiki.allTitles();\n\n var deletedTiddlers = [];\n for (var i = tiddlers.length; i--;) {\n if (basicUtils.startsWith(tiddlers[i], prefix)) {\n $tw.wiki.deleteTiddler(tiddlers[i]);\n deletedTiddlers.push(deletedTiddlers[i]);\n }\n }\n\n return deletedTiddlers;\n};\n\n/**\n * Returns all tiddlers that possess a property with a certain value.\n *\n * @param {string} fieldName - The property name to look for.\n * @param {string} [value] - If provided, the field's value must\n * equal this value in order to match.\n * @param {Hashmap} [options] - Further options.\n * @param {TiddlerCollection} [options.tiddlers=$tw.wiki.allTitles()] - A collection\n * of tiddlers to perform the search on.\n * @param {boolean} [options.isIncludeDrafts=false] - True if drafts of the found\n * tiddlers are also included in the result set.\n * @param {number} [options.limit] - A positive number delimiting the maximum\n * number of results.\n * tiddlers are also included in the result set.\n * @return {Hashmap.<TiddlerReference, Tiddler>} Result\n */\nvar getTiddlersWithField = exports.getTiddlersWithField = function getTiddlersWithField(fieldName, value) {\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n\n\n var tiddlers = options.tiddlers || $tw.wiki.allTitles();\n var isIncludeDrafts = options.isIncludeDrafts === true;\n var result = basicUtils.makeHashMap();\n var keys = Object.keys(tiddlers);\n var hasOwnProp = $tw.utils.hop;\n var limit = options.limit || 0;\n\n for (var i = keys.length; i--;) {\n\n var tObj = getTiddler(tiddlers[keys[i]]);\n var fields = tObj.fields;\n if (hasOwnProp(fields, fieldName) && (!hasOwnProp(fields, 'draft.of') || isIncludeDrafts)) {\n if (!value || fields[fieldName] === value) {\n result[fields.title] = tObj;\n if (--limit === 0) {\n break;\n }\n }\n }\n }\n\n return result;\n};\n\n/**\n *\n * @param name\n * @param value\n */\nvar getTiddlerWithField = exports.getTiddlerWithField = function getTiddlerWithField(name, value) {\n return Object.keys(getTiddlersWithField(name, value, { limit: 1 }))[0];\n};\n\n/**\n * Iterates over all tiddlers in a given way and returns tiddlers\n * whose title matches the prefix string.\n *\n * @param {string} prefix - The prefix to match\n * @param {Hashmap} [options] - An options object.\n * @param {string} [options.iterator=\"each\"] - A tw store iterator\n * function, e.g. \"eachShadow\" or \"ShadowPlusTiddlers\".\n * @param {boolean} [options.removePrefix= false] - Whether to remove\n * the prefix or to leave it.\n * @return {Array<string>} The matches with or without the prefix.\n */\nvar getTiddlersByPrefix = exports.getTiddlersByPrefix = function getTiddlersByPrefix(prefix) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n\n var removePrefix = options.removePrefix === true;\n var result = [];\n var iterator = $tw.wiki[options.iterator || 'each'];\n\n iterator(function (tObj, tRef) {\n if (basicUtils.startsWith(tRef, prefix)) {\n result.push(removePrefix ? basicUtils.getWithoutPrefix(tRef, prefix) : tRef);\n }\n });\n\n return result;\n};\n\n/**\n * Advanced addTiddler method.\n *\n * It adds timestamps and only adds the tiddler if it doesn't exist\n * yet or the force option is used.\n *\n * This method is guarded against\n * https://github.com/Jermolene/TiddlyWiki5/issues/2025\n */\nvar addTiddler = exports.addTiddler = function addTiddler(tiddler, isForce) {\n\n var tObj = getTiddler(tiddler);\n\n if (!isForce && tObj) {\n return tObj;\n }\n\n tObj = new $tw.Tiddler({\n title: tiddler,\n text: ''\n }, $tw.wiki.getModificationFields(), $tw.wiki.getCreationFields());\n\n $tw.wiki.addTiddler(tObj);\n\n return tObj;\n};\n\nvar touch = exports.touch = function touch(tRef) {\n setField(tRef, 'modified', new Date());\n};\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/lib/utils/wiki.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/macro/tmap": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/macro/tmap",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.params = exports.name = exports.run = undefined;\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; // @preserve\n/*\\\ntitle: $:/plugins/felixhayashi/tiddlymap/js/macro/tmap\ntype: application/javascript\nmodule-type: macro\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\nvar _EdgeType = require('$:/plugins/felixhayashi/tiddlymap/js/EdgeType');\n\nvar _EdgeType2 = _interopRequireDefault(_EdgeType);\n\nvar _ViewAbstraction = require('$:/plugins/felixhayashi/tiddlymap/js/ViewAbstraction');\n\nvar _ViewAbstraction2 = _interopRequireDefault(_ViewAbstraction);\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/*** Code **********************************************************/\n\nvar name = 'tmap';\nvar params = getParamSlots(5);\n\n/**\n * @this MacroCallWidget\n * @return {string} the result of the operation or an empty string.\n * @private\n */\nfunction run() {\n\n this.substVarRefs = this.substituteVariableReferences;\n\n var fn = command[arguments[0]];\n var result = null;\n\n if (typeof fn === 'function') {\n var args = Array.prototype.slice.call(arguments, 1);\n result = fn.apply(this, args);\n }\n\n return typeof result === 'string' ? result : '';\n}\n\n/**\n * unfortunately tw forces us to specify params in advance so I\n * will reserve some argument slots here.\n * @private\n */\nfunction getParamSlots(maxArgs) {\n\n var arr = [];\n for (var i = 0; i < maxArgs; i++) {\n arr.push({ name: 'arg' + i });\n }\n\n return arr;\n}\n\n/**\n * In connection with tiddlymap, this macro allows us to access\n * system information from within tiddlers as well as to execute\n * some util functions.\n *\n * Every command will be called with `this` pointing to the current\n * MacroCallWidget instance!\n *\n * @private\n */\nvar command = _utils2.default.makeHashMap();\n\n/**\n * Returns the basename of the string\n *\n * @see {@link utils.basename}\n */\ncommand.basename = function (separator) {\n\n var str = this.getVariable('currentTiddler');\n return _utils2.default.getBasename(str, separator);\n};\n\n/**\n * TW messes with svg urls so we always use base64 encoding when\n * a data uri is requested as macro call\n */\ncommand.datauri = function (tiddler, type) {\n\n return _utils2.default.getDataUri(tiddler, type, true);\n};\n\ncommand.testJSON = function (fieldName) {\n\n var tObj = $tw.wiki.getTiddler(this.getVariable('currentTiddler'));\n\n try {\n JSON.parse(tObj.fields[fieldName]);\n return 'valid';\n } catch (SyntaxError) {\n return 'malformed';\n }\n};\n\ncommand.splitAndSelect = function (separator, index) {\n\n var str = this.getVariable('currentTiddler');\n var result = str.split(separator)[index];\n\n return result != null ? result : str;\n};\n\ncommand.concat = function () {\n\n var str = '';\n for (var i = 1, l = arguments.length; i < l; i++) {\n str += arguments[i];\n }\n return str;\n};\n\ncommand.uuid = function () {\n\n return _utils2.default.genUUID();\n};\n\ncommand.regRepl = function () {\n\n var oldStr = this.substVarRefs(arguments[0]);\n var regStr = arguments[1];\n var newStr = this.substVarRefs(arguments[2]);\n var regFlags = this.substVarRefs(arguments[4]);\n\n return oldStr.replace(new RegExp(regStr, regFlags), newStr);\n};\n\ncommand.halfOfString = function () {\n\n var str = this.substVarRefs(arguments[0]);\n\n if (!str) {\n return '';\n }\n\n return str.substr(0, Math.ceil(str.length / 2));\n};\n\ncommand.isETyVisible = function (view, userInput) {\n\n view = new _ViewAbstraction2.default(view);\n\n var id = command.getETyId.call(this, view, userInput);\n\n return '' + view.isEdgeTypeVisible(id);\n};\n\ncommand.getETyId = function (view, userInput) {\n\n view = new _ViewAbstraction2.default(view);\n\n var type = _EdgeType2.default.getInstance(userInput || this.getVariable('currentTiddler'));\n\n if (!type.namespace) {\n var _EdgeType$getIdParts = _EdgeType2.default.getIdParts(type.id),\n marker = _EdgeType$getIdParts.marker,\n _name = _EdgeType$getIdParts.name;\n\n var namespace = view.getConfig('edge_type_namespace');\n\n type = _EdgeType2.default.getInstance(_EdgeType2.default.getId(marker, namespace, _name));\n }\n\n return type.id;\n};\n\ncommand.scale = function () {\n\n var str = '';\n for (var i = 1, l = parseInt(arguments[0]); i < l; i++) {\n str += '[[' + i + ']]';\n }\n return str;\n};\n\ncommand.mergeFields = function () {\n\n var tObj = _utils2.default.getTiddler(arguments[0]);\n var prefix = arguments[1];\n var separator = arguments[2] || ' ';\n\n if (!tObj) return;\n\n var fields = _utils2.default.getPropertiesByPrefix(tObj.fields, prefix);\n var str = '';\n for (var name in fields) {\n\n if (typeof fields[name] === 'string') {\n\n str += fields[name] + separator;\n }\n }\n return str;\n};\n\ncommand.option = function (path, unit) {\n\n if (typeof $tm == \"undefined\") {\n // this macro is referenced from css which means we cannot\n // expect $tm to exist, e.g when rendering static css\n // @see https://github.com/felixhayashi/TW5-TiddlyMap/issues/257#issuecomment-427343226\n return '';\n }\n\n var prop = $tm;\n var propertyPath = path.split('.');\n\n for (var i = 0; i < propertyPath.length; i++) {\n if ((typeof prop === 'undefined' ? 'undefined' : _typeof(prop)) == 'object' && prop[propertyPath[i]]) {\n prop = prop[propertyPath[i]];\n }\n }\n\n // TODO: ugly, use regex\n if (unit && typeof prop === 'string' && _utils2.default.hasSubString(unit) && prop.lastIndexOf(unit) + unit.length === prop.length) {\n prop = prop + unit;\n }\n\n return prop;\n};\n\n/*** Exports *******************************************************/\n\nexports.run = run;\nexports.name = name;\nexports.params = params;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/macro/MapMacro.js.map\n",
"type": "application/javascript",
"module-type": "macro"
},
"$:/plugins/felixhayashi/tiddlymap/js/Adapter": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/Adapter",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/Adapter\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\nvar _ViewAbstraction = require('$:/plugins/felixhayashi/tiddlymap/js/ViewAbstraction');\n\nvar _ViewAbstraction2 = _interopRequireDefault(_ViewAbstraction);\n\nvar _EdgeType = require('$:/plugins/felixhayashi/tiddlymap/js/EdgeType');\n\nvar _EdgeType2 = _interopRequireDefault(_EdgeType);\n\nvar _NodeType = require('$:/plugins/felixhayashi/tiddlymap/js/NodeType');\n\nvar _NodeType2 = _interopRequireDefault(_NodeType);\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nvar _Edge = require('$:/plugins/felixhayashi/tiddlymap/js/Edge');\n\nvar _Edge2 = _interopRequireDefault(_Edge);\n\nvar _vis = require('$:/plugins/felixhayashi/vis/vis.js');\n\nvar _vis2 = _interopRequireDefault(_vis);\n\nvar _environment = require('$:/plugins/felixhayashi/tiddlymap/js/lib/environment');\n\nvar env = _interopRequireWildcard(_environment);\n\nvar _contrastcolour = require('$:/core/modules/macros/contrastcolour.js');\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/***************************** CODE ********************************/\n\n/**\n * This library acts as an abstraction layer above the tiddlywiki\n * system. All the provided methods give the api-user the chance\n * to interact with tiddlywiki as if it was a simple graph database.\n *\n * Everything that is related to retrieving or inserting nodes and\n * edges is handled by the adapter class.\n *\n * You don't need to create your own instance of this class.\n * The adapter service may be accessed from anywhere using\n * `$tm.apapter`.\n *\n * @constructor\n */\nvar Adapter = function () {\n\n /**\n * @param {Tracker} tracker\n * @param {EdgeTypeSubscriberRegistry} edgeTypeSubscriberRegistry\n */\n function Adapter(tracker, edgeTypeSubscriberRegistry) {\n _classCallCheck(this, Adapter);\n\n this.getTiddlerById = tracker.getTiddlerById.bind(tracker);\n this.getId = tracker.getIdByTiddler.bind(tracker);\n this.assignId = tracker.assignId.bind(tracker);\n\n this.edgeTypeSubscriberRegistry = edgeTypeSubscriberRegistry;\n\n this.indeces = $tm.indeces;\n this.wiki = $tw.wiki;\n\n this.visShapesWithTextInside = _utils2.default.getLookupTable(['ellipse', 'circle', 'database', 'box', 'text']);\n }\n\n /**\n * This function will delete the specified edge object from the system.\n *\n * @param {Edge} edge - The edge to be deleted. The edge necessarily\n * needs to possess an `id` and a `from` property.\n * @return {Edge} The deleted edge is returned.\n */\n\n\n _createClass(Adapter, [{\n key: 'deleteEdge',\n value: function deleteEdge(edge) {\n\n return this._processEdge(edge, 'delete');\n }\n\n /**\n * Persists an edge by storing the vector (from, to, type).\n *\n * @param {Edge} edge - The edge to be saved. The edge necessarily\n * needs to possess a `to` and a `from` property.\n * @return {Edge} The newly inserted edge.\n */\n\n }, {\n key: 'insertEdge',\n value: function insertEdge(edge) {\n\n return this._processEdge(edge, 'insert');\n }\n\n /**\n * Removes multiple edges from several stores.\n *\n * @param {EdgeCollection} edges - The edges to be deleted.\n */\n\n }, {\n key: 'deleteEdges',\n value: function deleteEdges(edges) {\n\n edges = _utils2.default.convert(edges, 'array');\n for (var i = edges.length; i--;) {\n this.deleteEdge(edges[i]);\n }\n }\n\n /**\n * Private function to handle the insertion or deletion of an edge.\n * It prepares the process according to the action type and delegates\n * the task to more specific functions.\n *\n * @private\n * @return {Edge} The processed edge.\n */\n\n }, {\n key: '_processEdge',\n value: function _processEdge(edge, action) {\n\n $tm.logger('debug', 'Edge', action, edge);\n\n // get from-node and corresponding tiddler\n var fromTRef = this.getTiddlerById(edge.from);\n\n if (!fromTRef || !_utils2.default.tiddlerExists(fromTRef)) {\n return;\n }\n\n var tObj = _utils2.default.getTiddler(fromTRef);\n var type = this.indeces.allETy[edge.type] || _EdgeType2.default.getInstance(edge.type);\n var handlers = this.edgeTypeSubscriberRegistry.getAllForType(type);\n var fn = action + 'Edge';\n\n for (var i = handlers.length; i--;) {\n handlers[i][fn](tObj, edge, type);\n }\n\n // if type didn't exist yet, create it\n if (action === 'insert' && !type.exists()) {\n type.save();\n }\n\n return edge;\n }\n\n /**\n * This function will return an adjacency list for the nodes\n * present in the current system. The list may be restricted by\n * optional filters.\n *\n * @param {string} [groupBy='to'] - Specifies by which property the\n * adjacency list is indexed. May be either 'from' or 'to'.\n * @param {Hashmap} [opts] - An optional options object.\n * @param {Hashmap} [opts.typeWL] - A whitelist lookup-table\n * that restricts which edge-types are included.\n * @param {Hashmap} [opts.edges] - A set of edges on which basis\n * the adjacency list is build. If not provided,\n * all edges in the system are considered.\n * @return {Object<Id, Array<Edge>>} For each key (a node id) an\n * array of edges pointing 'from' (or 'to'; depends on `groupBy`)\n * is supplied as value.\n */\n\n }, {\n key: 'getAdjacencyList',\n value: function getAdjacencyList(groupBy) {\n var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n\n $tm.start('Creating adjacency list');\n\n if (!opts.edges) {\n var tRefs = _utils2.default.getMatches(env.selector.allPotentialNodes);\n opts.edges = this.getEdgesForSet(tRefs, opts.toWL, opts.typeWL);\n }\n\n var adjList = _utils2.default.groupByProperty(opts.edges, groupBy || 'to');\n\n $tm.stop('Creating adjacency list');\n\n return adjList;\n }\n\n /**\n * This function will return all neighbours of a graph denoted by\n * a set of tiddlers.\n *\n * @todo parts of this code may be outsourced into a function to\n * prevent repeating code.\n *\n * @param {Array<TiddlerReference>} matches - The original set that\n * defines the starting point for the neighbourhood discovery\n * @param {Hashmap} [opts] - An optional options object.\n * @param {Hashmap} [opts.typeWL] - A whitelist lookup-table\n * that restricts which edges are travelled to reach a neighbour.\n * @param {Hashmap} [opts.edges] - An initial set of edges that is\n * used in the first step to reach immediate neighbours, if no\n * set of edges is specified, all exsisting edges will be considered.\n * @param {number} [opts.steps] - An integer value that specifies\n * the scope of the neighbourhood. A node is considered a neighbour\n * if it can be reached within the given number of steps starting\n * from original set of tiddlers returned by the node filter.\n * @param {Hashmap} [opts.addProperties] - a hashmap\n * containing properties to be added to each node.\n * For example:\n * {\n * group: 'g1',\n * color: 'red'\n * }\n * @return {Object} An object of the form:\n * {\n * nodes: { *all neighbouring nodes* },\n * edges: { *all edges connected to neighbours* },\n * }\n */\n\n }, {\n key: 'getNeighbours',\n value: function getNeighbours(matches) {\n var _this = this;\n\n var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n\n $tm.start('Get neighbours');\n\n var addProperties = opts.addProperties,\n toWL = opts.toWL,\n typeWL = opts.typeWL,\n steps = opts.steps;\n var allETy = this.indeces.allETy;\n\n // index of all tiddlers have already are been visited, either by\n // having been included in the original set, or by having been\n // recorded as neighbour during the discovery.\n\n var visited = _utils2.default.getArrayValuesAsHashmapKeys(matches);\n var view = _ViewAbstraction2.default.exists(opts.view) ? new _ViewAbstraction2.default(opts.view) : null;\n var allEdgesLeadingToNeighbours = _utils2.default.makeHashMap();\n var allNeighbours = _utils2.default.makeHashMap();\n var maxSteps = parseInt(steps) > 0 ? steps : 1;\n var direction = opts.direction || view && view.getConfig('neighbourhood_directions');\n var isWalkBoth = !direction || direction === 'both';\n var isWalkIn = isWalkBoth || direction === 'in';\n var isWalkOut = isWalkBoth || direction === 'out';\n\n // in order to apply the node-filter also to neighbours we need to make it\n // include all tiddlers in the filter's source (e.g. a tiddler and a few neighbours)\n // and then apply the filter – which now has the chance to take away tiddlers\n // a few filters from the set\n var neighFilter = view && '[all[]] ' + view.getNodeFilter('raw');\n\n // adjacency receives whitelists through opts\n var adjList = this.getAdjacencyList('to', opts);\n\n var addAsNeighbour = function addAsNeighbour(edge, role, neighboursOfThisStep) {\n allEdgesLeadingToNeighbours[edge.id] = edge;\n var tRef = _this.getTiddlerById(edge[role]);\n\n if (view && _utils2.default.isTrue($tm.config.sys.nodeFilterNeighbours) && !_utils2.default.isMatch(tRef, neighFilter)) {\n return;\n }\n\n if (!visited[tRef]) {\n visited[tRef] = true;\n var node = _this.makeNode(tRef, addProperties);\n if (node) {\n // saveguard against obsolete edges or other problems\n // record node\n allNeighbours[node.id] = node;\n neighboursOfThisStep.push(tRef);\n }\n }\n };\n\n // needed later\n var step = void 0;\n\n // loop if still steps to be taken and we have a non-empty starting set\n for (step = 0; step < maxSteps && matches.length; step++) {\n\n // neighbours that are discovered in the current step;\n // starting off from the current set of matches;\n var neighboursOfThisStep = [];\n\n // loop over all nodes in the original set\n for (var i = matches.length; i--;) {\n\n if (_utils2.default.isSystemOrDraft(matches[i])) {\n // = this might happen if the user manually created edges\n // that link to a system/draft tiddler or if the original\n // set contained system/draft tiddlers.\n continue;\n }\n\n // get all outgoing edges\n // = edges originating from the starting set and point outwards\n var outgoing = this.getEdges(matches[i], toWL, typeWL);\n for (var id in outgoing) {\n\n var t = allETy[outgoing[id].type];\n if (isWalkBoth || isWalkOut && t.toArrow || isWalkIn && t.invertedArrow) {\n\n addAsNeighbour(outgoing[id], 'to', neighboursOfThisStep);\n }\n }\n\n // get all incoming edges\n // = edges originating from outside pointing to the starting set\n var incoming = adjList[this.getId(matches[i])];\n if (!incoming) {\n continue;\n }\n\n for (var j = incoming.length; j--;) {\n var _t = allETy[incoming[j].type];\n if (isWalkBoth || isWalkIn && _t.toArrow || isWalkOut && _t.invertedArrow) {\n addAsNeighbour(incoming[j], 'from', neighboursOfThisStep);\n }\n }\n }\n\n // the current set of newly discovered neighbours forms the\n // starting point for the next discovery\n matches = neighboursOfThisStep;\n }\n\n var neighbourhood = {\n nodes: allNeighbours,\n edges: allEdgesLeadingToNeighbours\n };\n\n $tm.logger('debug', 'Retrieved neighbourhood', neighbourhood, 'steps', step);\n\n $tm.stop('Get neighbours');\n\n return neighbourhood;\n }\n\n /**\n * This function will assemble a graph object based on the supplied\n * node and edge filters. Optionally, a neighbourhood may be\n * merged into the graph neighbourhood.\n *\n * @param {string|ViewAbstraction} [view] - The view in which\n * the graph will be displayed.\n * @param {string|ViewAbstraction} [filter] - If supplied,\n * this will act as node filter that defines which nodes\n * are to be displayed in the graph; a possible view node filter\n * would be ignored.\n * @param {Hashmap} [edgeTypeWL] - A whitelist lookup-table\n * that restricts which edges are travelled to reach a neighbour.\n * @param {number} [neighbourhoodScope] - An integer value that\n * specifies the scope of the neighbourhood in steps.\n * See {@link Adapter#getNeighbours}\n * @return {Object} An object of the form:\n * {\n * nodes: { *all nodes in the graph* },\n * edges: { *all edges in the graph* },\n * }\n * Neighbours will be receive the 'tmap:neighbour' type.\n */\n\n }, {\n key: 'getGraph',\n value: function getGraph() {\n var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},\n view = _ref.view,\n filter = _ref.filter,\n edgeTypeWL = _ref.edgeTypeWL,\n neighbourhoodScope = _ref.neighbourhoodScope;\n\n $tm.start('Assembling Graph');\n\n view = _ViewAbstraction2.default.exists(view) ? new _ViewAbstraction2.default(view) : null;\n var matches = _utils2.default.getMatches(filter || view && view.getNodeFilter('compiled'));\n var neighScope = parseInt(neighbourhoodScope || view && view.getConfig('neighbourhood_scope'));\n var typeWL = edgeTypeWL || view && view.getEdgeTypeFilter('whitelist');\n var toWL = _utils2.default.getArrayValuesAsHashmapKeys(matches);\n\n var graph = {\n edges: this.getEdgesForSet(matches, toWL, typeWL),\n nodes: this.selectNodesByReferences(matches, {\n view: view,\n outputType: 'hashmap'\n })\n };\n\n if (neighScope) {\n var neighbours = this.getNeighbours(matches, {\n steps: neighScope,\n view: view,\n typeWL: typeWL,\n addProperties: {\n group: 'tmap:neighbour'\n }\n });\n\n // add neighbours (nodes and edges) to graph\n Object.assign(graph.nodes, neighbours.nodes);\n Object.assign(graph.edges, neighbours.edges);\n\n if (view && view.isEnabled('show_inter_neighbour_edges')) {\n var nodeTRefs = this.getTiddlersByIds(neighbours.nodes);\n // this time we need a whitelist based on the nodeTRefs\n var _toWL = _utils2.default.getArrayValuesAsHashmapKeys(nodeTRefs);\n Object.assign(graph.edges, this.getEdgesForSet(nodeTRefs, _toWL));\n }\n }\n\n // this is pure maintainance!\n removeObsoleteViewData(graph.nodes, view);\n\n // add styles to nodes\n this.attachStylesToNodes(graph.nodes, view);\n\n $tm.stop('Assembling Graph');\n\n $tm.logger('debug', 'Assembled graph:', graph);\n\n return graph;\n }\n\n /**\n * Returns all edges stored in a given tiddler. Any edge stored in a\n * tiddler is orginally an outgoing edge. Depending on how the user\n * changes the arrow head (by manipulating the Visjs edge-type style),\n * the edge may change its orientation and become an incoming edge or\n * bi-directional. Therefore, the edges retrieved may be incoming,\n * outgoing or both!\n *\n * Returned edges may be of the following type:\n *\n * - Edges stored in the tiddler text (=links).\n * - Edges stored in fields denoted by magic edge-types.\n * - TiddlyMap edges stored in a json format\n *\n * @param {Tiddler} tiddler - A tiddler reference or object from\n * which to retrieve the edges.\n * @param {Hashmap<TiddlerReference, boolean>} [toWL]\n * A hashmap on which basis it is decided, whether to include\n * an edge that leads to a certain tiddler in the result or not.\n * In this case, all edges stored in the tiddler are treated as\n * outgoing and the arrow head is ignored. If not specified,\n * all edges are included.\n * @param {Hashmap<string, boolean>} [typeWL]\n * A hashmap on which basis it is decided, whether to include\n * an edge of a given type in the result or not. If not\n * specified, all edges are included.\n */\n\n }, {\n key: 'getEdges',\n value: function getEdges(tiddler, toWL, typeWL) {\n\n var tObj = _utils2.default.getTiddler(tiddler);\n\n if (!tObj || _utils2.default.isSystemOrDraft(tObj)) {\n return;\n }\n\n var allETy = this.indeces.allETy;\n\n var edges = _utils2.default.makeHashMap();\n var eTySubscribers = this.edgeTypeSubscriberRegistry.getAll();\n\n for (var i = 0, l = eTySubscribers.length; i < l; i++) {\n Object.assign(edges, eTySubscribers[i].loadEdges(tObj, toWL, typeWL));\n }\n\n for (var id in edges) {\n\n var edge = edges[id];\n\n // check exists for historical reasons...\n if (!edge.from || !edge.to) {\n continue;\n }\n\n var type = allETy[edge.type] || _EdgeType2.default.getInstance(edge.type);\n addStyleToEdge(edges[id], type);\n\n edges[id] = edge;\n }\n\n return edges;\n }\n\n /**\n * The method will return all outgoing edges for a subset of tiddlers.\n *\n * @param {Array<Tiddler>} tiddlers - The set of tiddlers to consider.\n * @param toWL\n * @param typeWL\n * @return {Hashmap<Id, Edge>} An edge collection.\n */\n\n }, {\n key: 'getEdgesForSet',\n value: function getEdgesForSet(tiddlers, toWL, typeWL) {\n\n var edges = _utils2.default.makeHashMap();\n for (var i = tiddlers.length; i--;) {\n Object.assign(edges, this.getEdges(tiddlers[i], toWL, typeWL));\n }\n\n return edges;\n }\n\n /**\n * Select all edges of a given type.\n *\n * @param {string|EdgeType} type - Either the edge type id (name) or an EdgeType object.\n */\n\n }, {\n key: 'selectEdgesByType',\n value: function selectEdgesByType(type) {\n\n var typeWL = _utils2.default.makeHashMap(_defineProperty({}, _EdgeType2.default.getInstance(type).id, true));\n\n return this.getEdgesForSet(this.getAllPotentialNodes(), null, typeWL);\n }\n\n /**\n *\n * @return {*}\n */\n\n }, {\n key: 'getAllPotentialNodes',\n value: function getAllPotentialNodes() {\n\n return _utils2.default.getMatches($tm.selector.allPotentialNodes);\n }\n }, {\n key: '_processEdgesWithType',\n\n\n /**\n * Deletes or renames all edges of a given type.\n *\n * @param {string|EdgeType} type - Either the edge type id (name) or an EdgeType object.\n * @param {('rename'|'delete')} [action='delete']\n * @param {string} [newName]\n */\n value: function _processEdgesWithType(type, _ref2) {\n var action = _ref2.action,\n newName = _ref2.newName;\n\n\n type = _EdgeType2.default.getInstance(type);\n\n $tm.logger('debug', 'Processing edges', type, action);\n\n // get edges\n var edges = this.selectEdgesByType(type);\n\n if (action === 'rename') {\n\n // clone type first to prevent auto-creation\n new _EdgeType2.default(newName, type).save();\n }\n\n for (var id in edges) {\n\n this._processEdge(edges[id], 'delete');\n\n if (action === 'rename') {\n edges[id].type = newName;\n this._processEdge(edges[id], 'insert');\n }\n }\n\n // finally remove the old type\n this.wiki.deleteTiddler(type.fullPath);\n }\n\n /**\n * Returns a set of nodes that corresponds to a set of tiddlers.\n *\n * @param {TiddlerCollection} tiddlers - A collection of tiddlers.\n * @param {Hashmap} [addProperties] - a hashmap\n * @param {CollectionTypeString} [outputType='dataset'] - The result type.\n *\n * @return {NodeCollection} A collection of a type specified in the options.\n */\n\n }, {\n key: 'selectNodesByReferences',\n value: function selectNodesByReferences(tiddlers) {\n var _ref3 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},\n addProperties = _ref3.addProperties,\n outputType = _ref3.outputType;\n\n var result = _utils2.default.makeHashMap();\n var keys = Object.keys(tiddlers);\n\n for (var i = keys.length; i--;) {\n\n var node = this.makeNode(tiddlers[keys[i]], addProperties);\n if (node) {\n result[node.id] = node;\n }\n }\n\n return _utils2.default.convert(result, outputType);\n }\n\n /**\n * Retrieve nodes based on the a list of ids that corrspond to tiddlers\n * id fields.\n *\n * @param {Array.<Id>|Hashmap.<Id, *>|vis.DataSet} nodeIds - The ids of the tiddlers\n * that represent the nodes.\n * @param {Hashmap} [options] - See {@link Adapter#selectNodesByReferences}.\n * @return {NodeCollection} A collection of a type specified in the options.\n */\n\n }, {\n key: 'selectNodesByIds',\n value: function selectNodesByIds(nodeIds, options) {\n\n var tRefs = this.getTiddlersByIds(nodeIds);\n\n return this.selectNodesByReferences(tRefs, options);\n }\n\n /**\n * Select a single node by id.\n *\n * @param {Id} id - A node's id\n * @param {Hashmap} [options]\n * Except from the outputType option, all options\n * are inherited from {@link Adapter#selectNodesByIds}.\n * @return {Node|undefined} A node or nothing.\n */\n\n }, {\n key: 'selectNodeById',\n value: function selectNodeById(id, options) {\n\n options = Object.assign({}, options, { outputType: 'hashmap' });\n var result = this.selectNodesByIds([id], options);\n\n return result[id];\n }\n\n /**\n * Deletes a node type from the system.\n * @param {NodeType|string} type - the node type id or the actual NodeType\n */\n\n }, {\n key: 'removeNodeType',\n value: function removeNodeType(type) {\n\n type = _NodeType2.default.getInstance(type);\n this.wiki.deleteTiddler(type.fullPath);\n }\n\n /**\n * Gets a Node representation for a tiddler.\n *\n * @param {Tiddler} tiddler - the tiddler to represent as node\n * @param {Object} protoNode - default node properties\n *\n * @return {Node|void}\n */\n\n }, {\n key: 'makeNode',\n value: function makeNode(tiddler, protoNode) {\n\n var tObj = _utils2.default.getTiddler(tiddler);\n\n if (!tObj || _utils2.default.isSystemOrDraft(tObj)) return;\n\n // merge(!) so later node manipulations do not affect other nodes\n var node = _utils2.default.merge({}, protoNode);\n\n // note: assignId() will not assign an id if the tiddler already has one\n node.id = this.assignId(tObj);\n\n // add label\n var label = tObj.fields[$tm.field.nodeLabel];\n node.label = label && $tm.field.nodeLabel !== 'title' ? this.wiki.renderText('text/plain', 'text/vnd-tiddlywiki', label) : tObj.fields.title;\n\n return node;\n }\n\n /**\n * Return node styles that are inherited from system styles or node types.\n *\n * @param nodes\n * @return {Object<TiddlerReference, Object>}\n */\n\n }, {\n key: 'getInheritedNodeStyles',\n value: function getInheritedNodeStyles(nodes) {\n\n var src = this.getTiddlersByIds(nodes);\n var protoByTRef = {};\n var glNTy = this.indeces.glNTy;\n\n for (var i = glNTy.length; i--;) {\n var type = glNTy[i];\n\n var inheritors = [];\n if (type.id === 'tmap:neighbour') {\n // special case\n for (var id in nodes) {\n\n if (nodes[id].group === 'tmap:neighbour') {\n\n inheritors.push(this.getTiddlerById(id));\n }\n }\n } else {\n inheritors = type.getInheritors(src);\n }\n\n for (var j = inheritors.length; j--;) {\n var tRef = inheritors[j];\n var proto = protoByTRef[tRef] = protoByTRef[tRef] || {};\n proto.style = _utils2.default.merge(proto.style || {}, type.style);\n\n // ATTENTION: only override proto icons when the type provides\n // an icon since otherwise we might erase previously\n // inherited icons.\n if (type['fa-icon']) {\n proto['fa-icon'] = type['fa-icon'];\n } else if (type['tw-icon']) {\n proto['tw-icon'] = type['tw-icon'];\n }\n }\n }\n\n return protoByTRef;\n }\n\n /**\n * Adds styles to nodes.\n *\n * @param {Object<string, Node>} nodes\n * @param {ViewAbstraction|string} view\n */\n\n }, {\n key: 'attachStylesToNodes',\n value: function attachStylesToNodes(nodes, view) {\n\n view = _ViewAbstraction2.default.exists(view) ? new _ViewAbstraction2.default(view) : null;\n\n var inheritedStyles = this.getInheritedNodeStyles(nodes);\n var viewNodeData = view ? view.getNodeData() : _utils2.default.makeHashMap();\n var isStaticMode = view && !view.isEnabled('physics_mode');\n\n for (var id in nodes) {\n\n var tRef = this.getTiddlerById(id);\n var tObj = this.wiki.getTiddler(tRef);\n var fields = tObj.fields;\n var node = nodes[id];\n var icon = void 0;\n\n // == group styles ==\n\n var inheritedStyle = inheritedStyles[tRef];\n\n if (inheritedStyle) {\n\n _utils2.default.merge(node, inheritedStyle.style);\n icon = getIcon(inheritedStyle['fa-icon'], inheritedStyle['tw-icon']);\n }\n\n // == global node styles ==\n\n // background color\n if (fields.color) {\n node.color = fields.color;\n }\n\n // global node style from vis editor\n if (fields['tmap.style']) {\n _utils2.default.merge(node, _utils2.default.parseJSON(fields['tmap.style']));\n }\n\n icon = getIcon(fields['tmap.fa-icon'], fields['icon']) || icon;\n\n // == local node styles ==\n\n // local node style and positions\n\n var nodeData = viewNodeData[id];\n\n if (nodeData) {\n\n _utils2.default.merge(node, nodeData);\n if (isStaticMode) {\n // fix x if x-position is set; same for y\n node.fixed = {\n x: node.x != null,\n y: node.y != null\n };\n }\n\n icon = getIcon(nodeData['fa-icon'], nodeData['tw-icon']) || icon;\n }\n\n // == tweaks ==\n\n var isColorObject = node.color !== null && _typeof(node.color) === 'object';\n // color/border-color may be undefined\n var color = isColorObject ? node.color.background : node.color;\n\n node.color = {\n background: color,\n border: isColorObject ? node.color.border : undefined\n };\n\n // ATTENTION: this function needs to be called after color is assigned\n addNodeIcon(node, icon);\n\n // determine font color if not defined via a group- or node-style;\n // in case of global and local default styles, the user is responsible\n // him- or herself to adjust the font\n node.font = node.font || {};\n\n if (node.shape && !this.visShapesWithTextInside[node.shape]) {\n node.font.color = 'black'; // force a black color\n } else if (!node.font.color && color) {\n node.font.color = (0, _contrastcolour.run)(color, color, 'black', 'white');\n }\n\n if (node.shape === 'icon' && _typeof(node.icon) === 'object') {\n node.icon.color = color;\n }\n }\n\n if (view) {\n var _node = nodes[view.getConfig('central-topic')];\n if (_node) {\n _utils2.default.merge(_node, this.indeces.glNTyById['tmap:central-topic'].style);\n }\n }\n }\n\n /**\n * This function will remove all tiddlers from the wiki that correspond\n * to a node in the collection. Drafts are also removed. The default\n * storylist is updated eventually.\n * call deleteNode which does the following\n * 1. get id using IdByT\n * 2. remove id using adapter.deleteEdgesByTo(idByT[tRef])\n * 3. remove from all indeces\n *\n * @see: https://github.com/Jermolene/TiddlyWiki5/issues/1550\n *\n * @param {Node|string} node.\n */\n\n }, {\n key: 'deleteNode',\n value: function deleteNode(node) {\n\n if (!node) {\n return;\n }\n\n var id = (typeof node === 'undefined' ? 'undefined' : _typeof(node)) === 'object' ? node.id : node;\n var tRef = this.getTiddlerById(id);\n\n // delete tiddler and remove it from the river; this will\n // automatically remove the global node style and the outgoing edges\n\n if (tRef) {\n // checking for tRef is needed;\n // see: https://github.com/Jermolene/TiddlyWiki5/issues/1919\n _utils2.default.deleteTiddlers([tRef]);\n }\n\n // delete local node-data in views containing the node\n\n var viewRefs = _utils2.default.getMatches(env.selector.allViews);\n for (var i = viewRefs.length; i--;) {\n var view = new _ViewAbstraction2.default(viewRefs[i]);\n view.removeNode(id);\n }\n\n // remove obsolete connected edges\n\n var neighbours = this.getNeighbours([tRef]);\n this.deleteEdges(neighbours.edges);\n\n // -------------------------------------------\n // NEVER DELETE AN INDEX THAT ALREADY EXISTED!\n // -------------------------------------------\n // Some instances may have cached the index and get confused!\n // It does not do harm to leave indeces as is since we do not\n // iterate over them(!) and when a tiddler has the same title or\n // id as a deleted tiddler, which is highly unlikely, then it will\n // simply override the index, which is totally fine. The indeces\n // are refreshed on every boot anyway so it is not a big deal.\n //\n // THEREFORE:\n //\n // DO NOT DO delete this.tById[id];\n // DO NOT DO delete this.idByT[tRef];\n }\n\n /**\n * Delete all nodes from the system.\n *\n * @param {string[]} ids ids\n */\n\n }, {\n key: 'deleteNodes',\n value: function deleteNodes(ids) {\n\n for (var i = ids.length; i--;) {\n this.deleteNode(ids[i]);\n }\n }\n\n /**\n * Create a new tiddler that gets a non-existant title and is opened\n * for edit. If a view is registered, the fields of the tiddler match\n * the current view. If arguments network and position are specified,\n * the node is also inserted directly into the graph at the given\n * position.\n *\n * @TODO: Description is obsolete!\n *\n * @param {object} node A node object to be inserted\n * @param {ViewAbstraction|string} view - used to set positions and register the node to\n * @param {Tiddler} protoTiddler\n */\n\n }, {\n key: 'insertNode',\n value: function insertNode() {\n var node = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var view = arguments[1];\n var protoTiddler = arguments[2];\n\n\n // title might has changed after generateNewTitle()\n node.label = this.wiki.generateNewTitle(node.label || _utils2.default.getRandomLabel());\n\n // add to tiddler store\n var tObj = new $tw.Tiddler({ text: '' }, // https://github.com/Jermolene/TiddlyWiki5/issues/2025\n protoTiddler, {\n title: node.label, // force title\n 'tmap.id': null // force empty id (generated later)\n }, this.wiki.getModificationFields(), this.wiki.getCreationFields());\n\n this.wiki.addTiddler(tObj);\n\n node = this.makeNode(tObj, node);\n\n if (_ViewAbstraction2.default.exists(view)) {\n new _ViewAbstraction2.default(view).addNode(node);\n }\n\n return node;\n }\n\n /**\n * Retrieve tiddlers based on the a list of corresponding ids.\n *\n * @param {Array.<Id>|Hashmap.<Id, *>|vis.DataSet} nodeIds - The ids.\n * @return {Array<TiddlerReference>} The resulting tiddlers.\n */\n\n }, {\n key: 'getTiddlersByIds',\n value: function getTiddlersByIds(nodeIds) {\n\n // transform into a hashmap with all values being true\n if (Array.isArray(nodeIds)) {\n nodeIds = _utils2.default.getArrayValuesAsHashmapKeys(nodeIds);\n } else if (nodeIds instanceof _vis2.default.DataSet) {\n nodeIds = _utils2.default.getLookupTable(nodeIds, 'id'); // use id field as key\n }\n\n var result = [];\n for (var id in nodeIds) {\n var tRef = this.getTiddlerById(id);\n if (tRef) {\n result.push(tRef);\n }\n }\n\n return result;\n }\n }]);\n\n return Adapter;\n}();\n\n/**** Helper *******************************************************/\n\n/**\n * Returns the short symbol identifier (`` → `f206`).\n *\n * @param str FontAwesome id\n * @return {string}\n */\n\n\nvar getFAdigits = function getFAdigits(str) {\n return str.length === 4 ? str : str.substr(3, 4);\n};\n\n/**\n * Adds an icon to the specified node.\n *\n * @param {Node} node\n * @param {Object} icon\n */\nvar addNodeIcon = function addNodeIcon(node, icon) {\n\n if (!icon) {\n return;\n }\n\n // Font Awesome style\n\n if (icon.fa) {\n\n node.shape = 'icon';\n node.icon = {\n shape: 'icon',\n face: 'FontAwesome',\n color: node.color,\n code: String.fromCharCode('0x' + getFAdigits(icon.fa))\n };\n\n if (node.size) {\n node.icon.size = node.size;\n }\n\n return;\n }\n\n // TiddlyWiki stored icons\n\n if (icon.tw) {\n\n var imgTObj = _utils2.default.getTiddler(icon.tw);\n\n if (!imgTObj) {\n return;\n }\n\n if (imgTObj.fields['_canonical_uri']) {\n // image is a url address\n\n node.image = imgTObj.fields['_canonical_uri'];\n node.shape = 'image';\n } else if (imgTObj.fields.text) {\n\n node.image = _utils2.default.getDataUri(imgTObj);\n node.shape = 'image';\n }\n }\n};\n\n/**\n * Garbage collector for obsolete node data.\n *\n * @param {Object<string, Node>} nodes\n * @param {ViewAbstraction|string} view\n */\nvar removeObsoleteViewData = function removeObsoleteViewData(nodes, view) {\n\n if (!_ViewAbstraction2.default.exists(view) || !nodes) {\n return;\n }\n\n view = new _ViewAbstraction2.default(view);\n\n var data = view.getNodeData();\n\n var obsoleteDataItems = 0;\n for (var id in data) {\n if (nodes[id] === undefined && data[id] != null) {\n // we only set this to undefined as deletion would\n // slow down V8, however, this necessarily requires\n // a safeguard agains recursion: data[id] != null\n\n data[id] = undefined;\n obsoleteDataItems++;\n }\n }\n\n if (obsoleteDataItems) {\n $tm.logger('debug', '[Cleanup]', 'Removed obsolete node data:', view.getLabel(), obsoleteDataItems);\n view.saveNodeData(data);\n }\n};\n\n/**\n * Sets up an edge object that is ready to be consumed by vis.\n *\n * @param {Edge} edge\n * @param {EdgeType} type\n */\nvar addStyleToEdge = function addStyleToEdge(edge, type) {\n\n edge = Object.assign(edge, type.style);\n\n if (_utils2.default.isTrue(type['show-label'], true)) {\n edge.label = type.getLabel();\n }\n};\n\nvar getIcon = function getIcon(faIcon, twIcon) {\n return faIcon && { fa: faIcon } || twIcon && { tw: twIcon };\n};\n\n/*** Exports *******************************************************/\n\nexports.default = Adapter;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/services/Adapter.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/CallbackManager": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/CallbackManager",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/CallbackManager\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\n * Makes it possible to register callbacks for tiddler changes.\n */\nvar CallbackManager = function () {\n function CallbackManager() {\n _classCallCheck(this, CallbackManager);\n\n this.callbacks = _utils2.default.makeHashMap();\n this.logger = $tm.logger;\n this.wiki = $tw.wiki;\n }\n\n /**\n * The callback mechanism allows to dynamically listen to tiddler\n * changes without hardcoding a change-check for a tiddler name\n * in the refresh function.\n *\n * @param {TiddlerReference} tRef - A tiddler whose change triggers\n * the callback.\n * @param {function} callback - A function that is called when the\n * tiddler has changed.\n * @param {boolean} [isDeleteOnCall=true] - True if to delete the\n * callback once it has been called, false otherwise.\n */\n\n\n _createClass(CallbackManager, [{\n key: 'add',\n value: function add(tRef, callback) {\n var isDeleteOnCall = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;\n\n\n this.logger('debug', 'A callback was registered for changes of \"' + tRef + '\"');\n this.callbacks[tRef] = {\n execute: callback,\n isDeleteOnCall: isDeleteOnCall\n };\n }\n }, {\n key: 'remove',\n\n\n /**\n * Removes the callback from the list of tiddler callbacks.\n */\n value: function remove(refOrRefList) {\n\n if (!refOrRefList) {\n return;\n }\n\n if (typeof refOrRefList === 'string') {\n refOrRefList = [refOrRefList];\n }\n\n for (var i = refOrRefList.length; i--;) {\n var tRef = refOrRefList[i];\n if (this.callbacks[tRef]) {\n this.logger('debug', 'Deleting callback for \"' + tRef + '\"');\n delete this.callbacks[tRef];\n }\n }\n }\n }, {\n key: 'refresh',\n\n\n /**\n * this method has to be implemented at the top of the refresh method.\n * It checks for changed tiddlers that have\n * registered callbacks. If `deleteOnCall` was specified during\n * registration of the callback, the callback will be deleted\n * automatically.\n */\n value: function refresh(changedTiddlers) {\n\n if (this.callbacks.length == 0) {\n return;\n }\n\n for (var tRef in changedTiddlers) {\n\n if (!this.callbacks[tRef]) {\n continue;\n }\n\n if (this.wiki.getTiddler(tRef)) {\n\n this.logger('debug', 'Executing a callback for: ' + tRef);\n this.callbacks[tRef].execute(tRef);\n\n // a continue prevents deleting the callback\n if (!this.callbacks.isDeleteOnCall) {\n continue;\n }\n }\n\n this.remove(tRef);\n }\n }\n }]);\n\n return CallbackManager;\n}();\n\n/*** Exports *******************************************************/\n\nexports.default = CallbackManager;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/services/CallbackManager.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/startup/caretaker": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/startup/caretaker",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.startup = exports.synchronous = exports.before = exports.after = exports.platforms = exports.name = undefined;\n\nvar _rebuilders;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/startup/caretaker\ntype: application/javascript\nmodule-type: startup\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\nvar _vis = require('$:/plugins/felixhayashi/tiddlymap/js/config/vis');\n\nvar _vis2 = _interopRequireDefault(_vis);\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nvar _Fixer = require('$:/plugins/felixhayashi/tiddlymap/js/Fixer');\n\nvar _Fixer2 = _interopRequireDefault(_Fixer);\n\nvar _Adapter = require('$:/plugins/felixhayashi/tiddlymap/js/Adapter');\n\nvar _Adapter2 = _interopRequireDefault(_Adapter);\n\nvar _tracker = require('$:/plugins/felixhayashi/tiddlymap/js/services/tracker');\n\nvar _tracker2 = _interopRequireDefault(_tracker);\n\nvar _EdgeTypeSubscriberRegistry = require('$:/plugins/felixhayashi/tiddlymap/js/EdgeTypeSubscriberRegistry');\n\nvar _EdgeTypeSubscriberRegistry2 = _interopRequireDefault(_EdgeTypeSubscriberRegistry);\n\nvar _DialogManager = require('$:/plugins/felixhayashi/tiddlymap/js/DialogManager');\n\nvar _DialogManager2 = _interopRequireDefault(_DialogManager);\n\nvar _CallbackManager = require('$:/plugins/felixhayashi/tiddlymap/js/CallbackManager');\n\nvar _CallbackManager2 = _interopRequireDefault(_CallbackManager);\n\nvar _ViewAbstraction = require('$:/plugins/felixhayashi/tiddlymap/js/ViewAbstraction');\n\nvar _ViewAbstraction2 = _interopRequireDefault(_ViewAbstraction);\n\nvar _EdgeType = require('$:/plugins/felixhayashi/tiddlymap/js/EdgeType');\n\nvar _EdgeType2 = _interopRequireDefault(_EdgeType);\n\nvar _NodeType = require('$:/plugins/felixhayashi/tiddlymap/js/NodeType');\n\nvar _NodeType2 = _interopRequireDefault(_NodeType);\n\nvar _vis3 = require('$:/plugins/felixhayashi/vis/vis.js');\n\nvar _vis4 = _interopRequireDefault(_vis3);\n\nvar _environment = require('$:/plugins/felixhayashi/tiddlymap/js/lib/environment');\n\nvar env = _interopRequireWildcard(_environment);\n\nvar _URL = require('$:/plugins/felixhayashi/tiddlymap/js/URL');\n\nvar _URL2 = _interopRequireDefault(_URL);\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/*** Code **********************************************************/\n\n/**\n * This module is responsible for registering a global namespace\n * under $tw and loading (and refreshing) the configuration and services.\n *\n * Attention: Careful with the order of the function calls in this\n * functions body!\n *\n */\nvar init = function init() {\n\n window.$tm = _extends({}, env, { utils: _utils2.default, url: new _URL2.default(window.location.href) });\n\n // cleanup previous session\n cleanup();\n\n registerPublicClasses($tm);\n\n // build and integrate global options\n updateGlobals($tm);\n\n // register meta file (if not done yet)\n createMetaFile($tm.logger);\n\n // create indeces\n var indeces = attachIndeces($tm);\n\n // create services\n var services = getInitializedServices(indeces);\n Object.assign($tm, services);\n\n // load defaults\n loadDefaultView($tm.config.sys.defaultView);\n\n // Run the fixer to update older wikis\n services.fixer.fix();\n\n // all graphs need to register here. @see routineWalk()\n $tm.registry = [];\n setInterval(routineCheck, 5000);\n\n // AT THE VERY END: register change listener with the callback manager\n registerChangeListener($tm.callbackManager);\n\n // register DOM listeners\n registerMousemoveListener();\n registerClickListener();\n\n // check for fullscreen directives\n if ($tm.url.query['tmap-enlarged']) {\n prepareFullscreenStart($tm.url);\n }\n\n // issue notification\n $tm.logger('warn', 'TiddlyMap\\'s caretaker successfully started');\n};\n\n/**\n * Injects dependencies and registers services\n *\n * @param indeces\n * @return Object\n */\nvar getInitializedServices = function getInitializedServices(indeces) {\n\n var tracker = new _tracker2.default(fixer);\n\n // inject modules\n var handler = $tw.modules.applyMethods('tmap.edgetypehandler');\n var edgeTypeSubscriberRegistry = new _EdgeTypeSubscriberRegistry2.default(handler, indeces.allETy, tracker);\n\n // attach the adapter object to the tiddlymap namespace\n var adapter = new _Adapter2.default(tracker, edgeTypeSubscriberRegistry);\n\n var callbackManager = new _CallbackManager2.default();\n var dialogManager = new _DialogManager2.default(callbackManager);\n\n var fixer = new _Fixer2.default(adapter, $tm.logger, indeces.glNTy);\n\n return {\n edgeTypeSubscriberRegistry: edgeTypeSubscriberRegistry,\n tracker: tracker,\n adapter: adapter,\n callbackManager: callbackManager,\n dialogManager: dialogManager,\n fixer: fixer\n };\n};\n\n/**\n * make classes available for console users\n */\nvar registerPublicClasses = function registerPublicClasses(parent) {\n parent.keycharm = _vis4.default.keycharm;\n parent.NodeType = _NodeType2.default;\n parent.EdgeType = _EdgeType2.default;\n parent.ViewAbstraction = _ViewAbstraction2.default;\n};\n\n/**\n * This function will append the global options to the tree. In case\n * this function is called again, only the option leafs are rebuild\n * so a process may safely store a reference to a branch of the option\n * tree as the reference doesn't change.\n *\n * ATTENTION: For the path options, no trailing or double slashes!\n * This is NOT unix where paths are normalized (// is not rewritten to /).\n *\n * @see\n * - [TW5] Is there a designated place for TW plugins to store stuff in the dom?\n * https://groups.google.com/forum/#!topic/tiddlywikidev/MZZ37XiVcvY\n * @param {object} parent The root where to insert the options into\n */\nvar attachOptions = function attachOptions(parent) {\n\n var p = parent;\n\n // default configurations mixed with user config\n if (!p.config) p.config = _utils2.default.makeHashMap();\n\n // Never modify the imported config objects; instead, merge them\n // into a new object\n\n // attention! it is a tw-data-tiddler!\n p.config.sys = _utils2.default.merge(p.config.sys, _utils2.default.unflatten($tw.wiki.getTiddlerData(env.ref.sysUserConf)));\n\n // CAREFUL: Never merge directly into the default vis config object\n p.config.vis = _utils2.default.merge({}, _vis2.default, _utils2.default.parseFieldData(env.ref.visUserConf));\n\n // a shortcut for fields property\n if (!p.field) p.field = _utils2.default.makeHashMap();\n $tw.utils.extend(p.field, p.config.sys.field);\n};\n\n/**\n * This function will cache/index some tiddler properties as javascript\n * objects for faster access.\n */\nvar attachIndeces = function attachIndeces(parent) {\n\n $tm.start('Attaching Indeces');\n\n parent.indeces = parent.indeces || {};\n\n updateNodeTypesIndeces(parent.indeces);\n updateEdgeTypesIndeces(parent.indeces);\n\n $tm.stop('Attaching Indeces');\n\n return parent.indeces;\n};\n\n/**\n * For faster access to node-type styles, we store all node-type\n * objects as indeces in a table.\n *\n * Types without a filter are not indexed since they are either\n * special types that TiddlyMap manually assignes (e.g. tmap:neighbour,\n * or tmap:selected).\n *\n * Indeces added to the indeces chain:\n * 1. glNTy – all global node types\n *\n * @param {Object} [parent] - The global indeces object indeces.\n * If not stated, $tm.indeces is used.\n * @param {Array<TiddlerReference>} [allTiddlers] - The tiddlers to\n * use as basis for this index. If not stated, all tiddlers in\n * the wiki are used.\n */\nvar updateNodeTypesIndeces = function updateNodeTypesIndeces(parent) {\n\n parent = parent || $tm.indeces;\n\n var typePath = $tm.path.nodeTypes;\n var glNTy = parent.glNTy = [];\n var glNTyById = parent.glNTyById = _utils2.default.makeHashMap();\n\n $tw.wiki.eachTiddlerPlusShadows(function (tObj, tRef) {\n if (_utils2.default.startsWith(tRef, typePath)) {\n var type = _NodeType2.default.getInstance(tRef);\n glNTyById[type.id] = type;\n glNTy.push(type);\n }\n });\n\n glNTy.sort(function (a, b) {\n return a.priority - b.priority;\n });\n};\n\nvar updateEdgeTypesIndeces = function updateEdgeTypesIndeces(parent) {\n\n parent = parent || $tm.indeces;\n\n var typePath = $tm.path.edgeTypes;\n var allETy = parent.allETy = _utils2.default.makeHashMap();\n\n $tw.wiki.eachTiddlerPlusShadows(function (tObj, tRef) {\n\n if (_utils2.default.startsWith(tRef, typePath)) {\n\n var et = _EdgeType2.default.getInstance(tRef);\n allETy[et.id] = et;\n }\n });\n\n if ($tm.edgeTypeSubscriberRegistry) {\n $tm.edgeTypeSubscriberRegistry.updateIndex(allETy);\n }\n};\n\n/**\n * This function attaches all the top level functions to the\n * tiddlymap namespace.\n *\n * This will add the\n * 1. global logger method,\n * 2. the notify method\n * 3. the stopwatch methods `start` and `stop`.\n *\n * @param {Hashmap} parent - The parent object to attach the options to.\n */\nvar attachFunctions = function attachFunctions(parent) {\n\n var fn = parent;\n var nirvana = function nirvana() {/* /dev/null */};\n\n if (_utils2.default.isTrue($tm.config.sys.debug, false) && console) {\n\n /**\n * A logging mechanism that uses the first argument as type and\n * passes all consequent arguments as console arguments. The\n * reason for this functions existence is to be able to switch\n * off the logging without redirecting every single console function\n * such as log, debug, warn etc. Plus, we have more control over\n * the logging.\n *\n * @see http://stackoverflow.com/questions/5538972/console-log-apply-not-working-in-ie9\n * @see http://stackoverflow.com/questions/9521921/why-does-console-log-apply-throw-an-illegal-invocation-error\n *\n * @param {string} type - The type of the message (debug, info, warning…)\n * which is exactly the same as in `console[type]`.\n * @param {...*} message - An infinite number of arguments to be printed\n * (just like console).\n */\n fn.logger = function () /* type, [messages,] messages */{\n if (arguments.length < 2) return;\n var args = Array.prototype.slice.call(arguments);\n var arg1 = args.shift(args);\n var type = console.hasOwnProperty(arg1) ? arg1 : 'debug';\n console[type].apply(console, args);\n };\n\n fn.start = function (timerName) {\n console.time('[timer] ' + timerName);\n };\n\n fn.stop = function (timerName) {\n console.timeEnd('[timer] ' + timerName);\n };\n } else {\n\n fn.logger = fn.start = fn.stop = nirvana;\n }\n\n fn.notify = _utils2.default.isTrue($tm.config.sys.notifications) ? _utils2.default.notify : nirvana;\n};\n\n/**\n * This periodic check is needed to trigger a cleanup if a graph is\n * removed since a graph itself cannot react to its destruction.\n * This includes removing listeners that were not attached to the\n * local container or calling the vis destructor.\n *\n * @todo Specify which functions are required for widgets that register\n * themselves in the registry.\n */\nvar routineCheck = function routineCheck() {\n\n for (var i = $tm.registry.length; i--;) {\n var widget = $tm.registry[i];\n\n if (!widget.destruct || !widget.isZombieWidget) return; // no duck!\n\n if (widget.isZombieWidget()) {\n // removed!\n $tm.logger('warn', 'a widget will be removed');\n $tm.registry.splice(i, 1);\n widget.destruct();\n }\n }\n};\n\n/**\n * Every widget that has registered itself in the registry\n * will receive the `updates` object. The `updates` object is a more\n * advanced\n *\n * @param {Updates} updates\n */\nvar dispatchUpdates = function dispatchUpdates(updates) {\n\n var registry = $tm.registry;\n for (var i = registry.length; i--;) {\n\n var widget = registry[i];\n\n if (widget.update && widget.isZombieWidget && !widget.isZombieWidget()) {\n widget.update(updates);\n }\n }\n};\n\n/**\n * We need to do this check as TiddlyWiki does not allow us to hook into the\n * clone process to find out whether a node was cloned.\n *\n * @param tObj\n */\nvar checkForClone = function checkForClone(tObj) {\n\n var tRefs = _utils2.default.getDublicates(tObj);\n\n if (!tRefs.length) {\n return;\n }\n\n // remove any defined edges\n _utils2.default.setField(tObj, 'tmap.edges', undefined);\n\n // force override id\n $tm.tracker.assignId(tObj, true);\n\n // inform the user about what we did\n $tm.dialogManager.open('dublicateIdInfo', {\n param: {\n changedTiddler: tObj.fields.title,\n filter: _utils2.default.joinAndWrap(tRefs, '[[', ']]'),\n id: _utils2.default.getId(tObj)\n }\n });\n};\n\n/**\n * Builds and registers globals and the functions that depend on them.\n */\nvar updateGlobals = function updateGlobals(parent) {\n\n attachOptions($tm);\n attachFunctions($tm);\n\n // attention: logger() cannot be called before functions are rebuild\n $tm.logger('warn', 'Rebuilt globals');\n};\n\nvar lastCurrentTiddler = null;\nvar updateLiveViewTrigger = function updateLiveViewTrigger(changedTiddlers) {\n\n if (changedTiddlers['$:/HistoryList']) {\n var tRef = _utils2.default.getField('$:/HistoryList', 'current-tiddler');\n } else if (changedTiddlers['$:/temp/focussedTiddler']) {\n var tRef = _utils2.default.getField('$:/temp/focussedTiddler', 'text');\n }\n\n if (tRef != null && lastCurrentTiddler !== tRef) {\n lastCurrentTiddler = tRef;\n _utils2.default.setField('$:/temp/tmap/currentTiddler', 'text', tRef);\n }\n};\n\n/**\n * Only for debugging\n */\nvar printChanges = function printChanges(changedTiddlers, loopCount) {\n\n if (!_utils2.default.isTrue($tm.config.sys.debug, false)) return;\n\n $tm.logger('warn', '=== Refresh ' + loopCount + ' ===');\n\n for (var tRef in changedTiddlers) {\n\n var c = changedTiddlers[tRef].deleted ? '[Deleted]' : '[Modified]';\n\n $tm.logger('warn', c, tRef, $tw.wiki.getTiddler(tRef));\n }\n};\n\n/**\n * Saves the last mousemove event under $tm.mouse\n */\nvar registerMousemoveListener = function registerMousemoveListener() {\n\n $tm.mouse = {};\n\n var fn = function fn(evt) {\n $tm.mouse = evt;\n };\n window.addEventListener('mousemove', fn, false);\n};\n\n/**\n * @TODO: suggest this to Jeremy for TW popup handling\n */\nvar registerClickListener = function registerClickListener() {\n\n var tempPopups = $tm.path.tempPopups;\n window.addEventListener('click', function (evt) {\n\n var popupStates = _utils2.default.getTiddlersByPrefix(tempPopups);\n\n for (var i = popupStates.length; i--;) {\n if (_utils2.default.getText(popupStates[i])) break;\n }\n\n if (i === -1) return;\n\n if (!$tw.utils.hasClass(evt.target, 'tc-drop-down') && !_utils2.default.getAncestorWithClass(evt.target, 'tc-drop-down')) {\n // = clicked on an element that isn't a dropdown or inside one\n for (var i = popupStates.length; i--;) {\n _utils2.default.setText(popupStates[i], '');\n }\n }\n }, false);\n};\n\n/**\n * Registers a change listener that will dispatch\n * @param callbackManager\n */\nvar registerChangeListener = function registerChangeListener(callbackManager) {\n\n var loopCount = 0;\n\n $tw.wiki.addEventListener('change', function (changedTiddlers) {\n\n $tm.start('Caretaker handling changes');\n\n printChanges(changedTiddlers, loopCount++);\n callbackManager.refresh(changedTiddlers);\n\n var updates = { changedTiddlers: {} };\n\n for (var tRef in changedTiddlers) {\n\n var tObj = _utils2.default.getTiddler(tRef);\n\n if (tObj && tObj.isDraft()) {\n continue;\n }\n\n var isHandled = handleTiddlerChange(tRef, tObj, updates);\n\n if (isHandled) {\n updates.changedTiddlers[tRef] = changedTiddlers[tRef];\n }\n }\n\n dispatchUpdates(updates);\n\n // NOTE: changes will affect the next refresh cycle\n updateLiveViewTrigger(changedTiddlers);\n\n $tm.stop('Caretaker handling changes');\n });\n};\n\n/**\n * Mapping of paths and callbacks that should be invoked if tiddlers\n * within theses paths change.\n */\nvar rebuilders = (_rebuilders = {}, _defineProperty(_rebuilders, env.path.options, updateGlobals), _defineProperty(_rebuilders, env.path.nodeTypes, updateNodeTypesIndeces), _defineProperty(_rebuilders, env.path.edgeTypes, updateEdgeTypesIndeces), _rebuilders);\n\n/**\n * This function will deal with tiddler changes and will log changes\n * to the provided `updates` object.\n *\n * @param {TiddlerReference} tRef\n * @param {$tw.Tiddler} tObj\n * @param {Updates} updates\n */\nvar handleTiddlerChange = function handleTiddlerChange(tRef, tObj, updates) {\n\n if ($tw.wiki.isSystemTiddler(tRef)) {\n\n for (var path in rebuilders) {\n if (_utils2.default.startsWith(tRef, path) && !updates[path]) {\n $tm.logger('warn', '[System change]', path);\n rebuilders[path]();\n updates[path] = true;\n }\n }\n } else if (tObj) {\n // created or modified\n\n if (tObj.fields.text === undefined) {\n // sic; '' is ok\n // to make sure that the tiddler's body is fully loaded\n // we postpone the handling of the tiddler\n // see https://github.com/felixhayashi/TW5-TiddlyMap/issues/222#issuecomment-268978764\n $tw.wiki.dispatchEvent('lazyLoad', tRef);\n\n return false;\n }\n\n checkForClone(tObj);\n\n // call assignId IN ANY CASE to make sure the index\n // stays intact, also after a renaming operation\n $tm.tracker.assignId(tObj);\n } else {\n // deleted or renamed\n\n var id = $tm.tracker.getIdByTiddler(tRef);\n\n if (!id) {\n // ignore tiddler without id\n return false;\n }\n\n var tRefWithId = _utils2.default.getTiddlerWithField('tmap.id', id);\n\n if (tRefWithId) {\n // only renamed\n\n $tm.logger('warn', '[Renamed]', tRef, 'into', tRefWithId);\n } else {\n // removed\n\n // remove node; any edges pointing in/out; update indeces\n // CAREFUL with recursion here!\n $tm.adapter.deleteNode(id);\n }\n }\n\n return true;\n};\n\n/**\n * Remove temp files from previous session.\n */\nvar cleanup = function cleanup() {\n\n _utils2.default.deleteByPrefix('$:/temp/felixhayashi');\n _utils2.default.deleteByPrefix('$:/temp/tiddlymap');\n _utils2.default.deleteByPrefix('$:/temp/tmap');\n};\n\n/**\n * Register the view that should be displayed at startup.\n */\nvar loadDefaultView = function loadDefaultView(defaultView) {\n\n if (defaultView) {\n _utils2.default.setText(env.ref.defaultViewHolder, $tm.config.sys.defaultView);\n }\n};\n\n/**\n * Init the wiki so we can start the main editor with the specified\n * view in fullscreen mode.\n *\n * @param {ViewAbstraction|string} view\n */\nvar prepareFullscreenStart = function prepareFullscreenStart(view) {\n var _env$ref = env.ref,\n mainEditor = _env$ref.mainEditor,\n defaultViewHolder = _env$ref.defaultViewHolder;\n\n\n _utils2.default.setSidebarTab(mainEditor);\n\n if (_ViewAbstraction2.default.exists(view)) {\n view = new _ViewAbstraction2.default(view);\n _utils2.default.setField(defaultViewHolder, 'text', view.getLabel());\n }\n};\n\n/**\n * The meta file keeps track of installation data.\n */\nvar createMetaFile = function createMetaFile(logger) {\n\n if (_utils2.default.tiddlerExists(env.ref.sysMeta)) {\n return;\n }\n\n logger('warn', 'Creating meta file');\n\n var plugin = $tw.wiki.getTiddler(env.path.pluginRoot);\n\n $tw.wiki.setTiddlerData(env.ref.sysMeta, {\n // the version originally installed\n originalVersion: plugin.fields.version,\n // the data structure in use corresponds to version x\n // if the structure is obsolete, it will be automatically\n // fixed by the fixer module.\n dataStructureState: '0.6.9',\n // whether or not to display a welcome message\n showWelcomeMessage: true\n });\n};\n\n/*** Exports *******************************************************/\n\nvar name = exports.name = 'tmap.caretaker';\nvar platforms = exports.platforms = ['browser'];\nvar after = exports.after = ['startup'];\nvar before = exports.before = ['rootwidget'];\nvar synchronous = exports.synchronous = true;\nvar startup = exports.startup = init;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/services/Caretaker.js.map\n",
"type": "application/javascript",
"module-type": "startup"
},
"$:/plugins/felixhayashi/tiddlymap/js/DialogManager": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/DialogManager",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/DialogManager\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nvar _CallbackManager = require('$:/plugins/felixhayashi/tiddlymap/js/CallbackManager');\n\nvar _CallbackManager2 = _interopRequireDefault(_CallbackManager);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\n * The DialogManager is responsible for preparing, displaying and\n * finalizing all the dialogs.\n */\nvar DialogManager = function () {\n\n /**\n * @param {CallbackManager} callbackManager - A callback manager that\n * is informed about changed tiddlers and keeps track of the\n * various tiddlers produced during the dialog process.\n * @param {Object} [context] - An optional *this*-reference to bind the\n * callback of each called dialog to. Otherwise, the callback of\n * each dialog has to be bound manually to the callback if required.\n */\n function DialogManager(callbackManager, context) {\n _classCallCheck(this, DialogManager);\n\n // create callback registry\n this.callbackManager = callbackManager;\n this.context = context;\n }\n\n /**\n * This function opens a dialog based on a skeleton and some fields and eventually\n * calls a callback once the dialog is closed. The callback contains an indicator\n * whether the dialog subject was confirmed or the operation cancelled. In any\n * case the output tiddler is passed to the callback. Each dialog may write its\n * changes to this tiddler in order to store the dialog result and make it available\n * to the callback.\n *\n * How does it work?\n *\n * The output of the dialog process is stored in a temporary tiddler that is only known\n * to the current instance of the dialog. This way it is ensured that only the dialog process\n * that created the temporary tiddler will retrieve the result. Now we are able to\n * provide unambigous and unique correspondance to dialog callbacks.\n * Any dialog output is stored in a unique output-tiddler. Once there is a result,\n * a new result tiddler is created with indicators how to interpret the output.\n * The result tiddler can be understood as exit code that is independent of the output.\n * It is the result tiddler that triggers the dialog callback that was registered before.\n * the output is then read immediately from the output-tiddler.\n *\n * @param {string} templateId - The dialog id which is the basename of\n * the template title.\n * @param {Hashmap} [param] - All properties (except those with special meanings)\n * of param will be accessible as variables in the modal\n * @param {string} [param.subtitle] -\n * @param {string} [param.cancelButtonLabel] - The label of the cancel button.\n * @param {string} [param.confirmButtonLabel] - The label of the confirm button.\n * @param {function} [callback] - A function with the signature\n * function(isConfirmed, outputTObj). `outputTObj` contains data\n * produced by the dialog (can be undefined even if confirmed!).\n * Be careful: the tiddler that outputTObj represents is deleted immediately.\n * @return {$tw.Tiddler} The dialog tddler object with all its fields.\n */\n\n\n _createClass(DialogManager, [{\n key: 'open',\n value: function open(templateId) {\n var param = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var callback = arguments[2];\n\n\n if (_utils2.default.isTrue($tm.config.sys.suppressedDialogs[templateId], false)) {\n $tm.logger('warning', 'Suppressed dialog', templateId);\n return;\n }\n\n $tm.logger('debug', 'Dialog param object', param);\n\n if (typeof callback === 'function' && this.context) {\n callback = callback.bind(this.context);\n }\n\n // create a temporary tiddler reference for the dialog\n var dialogTRef = $tm.path.tempRoot + '/dialog-' + _utils2.default.genUUID();\n\n // get the dialog template\n var skeleton = _utils2.default.getTiddler($tm.path.dialogs + '/' + templateId);\n\n // fields used to handle the dialog process\n var dialog = {\n title: dialogTRef,\n buttons: skeleton.fields['buttons'] || 'ok_cancel',\n classes: 'tmap-modal-content ' + skeleton.fields['classes'],\n output: dialogTRef + '/output',\n result: dialogTRef + '/result',\n temp: dialogTRef + '/temp',\n template: skeleton.fields.title,\n templateId: templateId,\n currentTiddler: dialogTRef + '/output',\n text: _utils2.default.getText($tm.path.dialogs)\n };\n\n _utils2.default.touch(dialog.output);\n\n if (param.dialog) {\n\n if (param.dialog.preselects) {\n\n // register preselects\n $tw.wiki.addTiddler(new $tw.Tiddler({ title: dialog.output }, _utils2.default.flatten(param.dialog.preselects)));\n\n // remove preselects from param object\n delete param.dialog.preselects;\n }\n\n // extend the dialog object with parameters provided by the user\n _utils2.default.merge(dialog, param.dialog);\n }\n\n // force the footer to be set to the wrapper\n // the footer wrapper will determine the footer from the\n // buttons field/variable\n dialog.footer = _utils2.default.getText($tm.path.footers);\n\n // flatten dialog and param object\n dialog = _utils2.default.flatten(dialog);\n param = _utils2.default.flatten(param);\n\n var fn = function fn(tRef) {\n\n DialogManager.getElement('hidden-close-button').click();\n\n var triggerTObj = $tw.wiki.getTiddler(tRef);\n var isConfirmed = triggerTObj.fields.text;\n\n var outputTObj = null;\n if (isConfirmed) {\n outputTObj = $tw.wiki.getTiddler(dialog.output);\n } else {\n $tm.notify('operation cancelled');\n }\n\n if (typeof callback === 'function') {\n callback(isConfirmed, outputTObj);\n }\n\n // close and remove all tiddlers used by the dialog\n _utils2.default.deleteByPrefix(dialogTRef);\n };\n\n // add trigger\n this.callbackManager.add(dialog.result, fn, true);\n\n // create dialog\n var dialogTiddler = new $tw.Tiddler(skeleton, param, dialog);\n $tw.wiki.addTiddler(dialogTiddler);\n\n $tm.logger('debug', 'Opening dialog', dialogTiddler);\n\n $tw.rootWidget.dispatchEvent({\n type: 'tm-modal',\n param: dialogTiddler.fields.title,\n paramObject: dialogTiddler.fields\n });\n\n DialogManager.addKeyBindings();\n\n return dialogTiddler;\n }\n }], [{\n key: 'getElement',\n value: function getElement(name) {\n\n return _utils2.default.getFirstElementByClassName('tmap-' + name);\n }\n\n /**\n * This method will search for form elements that have the class\n * `tmap-trigger-field` set, which means that TiddlyMap shall\n * perform a button press when a key combo occurs while the field\n * has focus. To know which button to press on what key event,\n * it looks for classes of the form: tmap-triggers-BUTTONNAME-on-KEYCOMBO.\n */\n\n }, {\n key: 'addKeyBindings',\n value: function addKeyBindings() {\n\n var keys = $tm.keycharm({\n container: _utils2.default.getFirstElementByClassName('tc-modal')\n });\n\n var re = /tmap-triggers-(.+?)-on-(.+?)(?:\\s|$)/;\n var triggers = document.getElementsByClassName('tmap-trigger-field');\n\n var _loop = function _loop(i) {\n var classNames = triggers[i].className.split(' ');\n\n var _loop2 = function _loop2(j) {\n var matches = classNames[j].match(re);\n if (!matches) {\n // don't care\n return 'continue';\n }\n var buttonName = matches[1];\n var key = matches[2];\n var buttonElement = DialogManager.getElement(buttonName);\n if (!buttonElement) {\n return 'continue';\n }\n keys.bind(key, function () {\n if (document.getElementsByClassName(classNames[j]).length) {\n // only click button if trigger is active (i.e. still in focus)\n // see https://github.com/felixhayashi/TW5-TiddlyMap/issues/280\n buttonElement.click();\n }\n });\n };\n\n for (var j = classNames.length; j--;) {\n var _ret2 = _loop2(j);\n\n if (_ret2 === 'continue') continue;\n }\n };\n\n for (var i = triggers.length; i--;) {\n _loop(i);\n }\n }\n }]);\n\n return DialogManager;\n}();\n\n/*** Exports *******************************************************/\n\nexports.default = DialogManager;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/services/DialogManager.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/Fixer": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/Fixer",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/Fixer\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nvar _ViewAbstraction = require('$:/plugins/felixhayashi/tiddlymap/js/ViewAbstraction');\n\nvar _ViewAbstraction2 = _interopRequireDefault(_ViewAbstraction);\n\nvar _EdgeType = require('$:/plugins/felixhayashi/tiddlymap/js/EdgeType');\n\nvar _EdgeType2 = _interopRequireDefault(_EdgeType);\n\nvar _NodeType = require('$:/plugins/felixhayashi/tiddlymap/js/NodeType');\n\nvar _NodeType2 = _interopRequireDefault(_NodeType);\n\nvar _environment = require('$:/plugins/felixhayashi/tiddlymap/js/lib/environment');\n\nvar env = _interopRequireWildcard(_environment);\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/*** Code **********************************************************/\n\nvar Fixer = function () {\n\n /**\n * @param {Adapter} adapter\n * @param {Object} logger\n * @param {Object} glNTy\n */\n function Fixer(adapter, logger, glNTy) {\n _classCallCheck(this, Fixer);\n\n this.adapter = adapter;\n this.logger = logger;\n this.wiki = $tw.wiki;\n this.glNTy = glNTy;\n }\n\n _createClass(Fixer, [{\n key: 'moveEdges',\n value: function moveEdges(path, view) {\n\n var matches = _utils2.default.getTiddlersByPrefix(path);\n for (var i = 0; i < matches.length; i++) {\n\n // create edge type\n var type = _utils2.default.getBasename(matches[i]);\n\n if (type === '__noname__') {\n type = 'tmap:unknown';\n }\n\n type = _EdgeType2.default.getInstance(type);\n\n if (!type.exists()) {\n type.save();\n }\n\n // move edges\n var edges = this.wiki.getTiddlerData(matches[i]);\n for (var j = 0; j < edges.length; j++) {\n // prefix formerly private edges with view name as namespace\n edges[j].type = (view ? view + ':' : '') + type.id;\n this.adapter.insertEdge(edges[j]);\n }\n\n // finally remove the store\n this.wiki.deleteTiddler(matches[i]);\n }\n }\n }, {\n key: 'executeUpgrade',\n value: function executeUpgrade(toVersion, curVersion, upgrade) {\n\n if (!_utils2.default.isLeftVersionGreater(toVersion, curVersion)) {\n // = current data structure version is newer than version we want to upgrade to.\n return;\n }\n\n // issue debug message\n this.logger('debug', 'Upgrading data structure to ' + toVersion);\n // execute fix\n var msg = upgrade();\n // update meta\n _utils2.default.setEntry(env.ref.sysMeta, 'dataStructureState', toVersion);\n\n return msg;\n }\n }, {\n key: 'fixId',\n\n\n /**\n * Special fix that is not invoked along with the other fixes but\n * when creating the index (see caretaker code).\n *\n * Changes:\n * 1. The node id field is moved to tmap.id if **original version**\n * is below v0.9.2.\n */\n value: function fixId() {\n\n var meta = this.wiki.getTiddlerData(env.ref.sysMeta, {});\n\n this.executeUpgrade('0.9.2', meta.dataStructureState, function () {\n\n if (_utils2.default.isLeftVersionGreater('0.9.2', meta.originalVersion)) {\n // path of the user conf at least in 0.9.2\n var userConf = '$:/plugins/felixhayashi/tiddlymap/config/sys/user';\n var nodeIdField = _utils2.default.getEntry(userConf, 'field.nodeId', 'tmap.id');\n _utils2.default.moveFieldValues(nodeIdField, 'tmap.id', true, false);\n }\n });\n }\n }, {\n key: 'fix',\n value: function fix() {\n var _this = this;\n\n var meta = this.wiki.getTiddlerData(env.ref.sysMeta, {});\n\n this.logger('debug', 'Fixer is started');\n this.logger('debug', 'Data-structure currently in use: ', meta.dataStructureState);\n\n /**\n * Changes:\n * 1. Edges are stored in tiddlers instead of type based edge stores\n * 2. No more private views\n */\n this.executeUpgrade('0.7.0', meta.dataStructureState, function () {\n\n // move edges that were formerly \"global\"\n _this.moveEdges('$:/plugins/felixhayashi/tiddlymap/graph/edges', null);\n\n // move edges that were formerly bound to view (\"private\")\n var filter = env.selector.allViews;\n var viewRefs = _utils2.default.getMatches(filter);\n for (var i = 0; i < viewRefs.length; i++) {\n var view = new _ViewAbstraction2.default(viewRefs[i]);\n _this.moveEdges(view.getRoot() + '/graph/edges', view);\n }\n });\n\n /**\n * Changes:\n * 1. Changes to the live view filter and refresh trigger field\n */\n this.executeUpgrade('0.7.32', meta.dataStructureState, function () {\n\n if (!_ViewAbstraction2.default.exists('Live View')) {\n\n return;\n }\n\n var liveView = new _ViewAbstraction2.default('Live View');\n\n // Only listen to the current tiddler of the history list\n liveView.setNodeFilter('[field:title{$:/temp/tmap/currentTiddler}]', true);\n\n liveView.setConfig({\n 'refresh-trigger': null, // delete the field (renamed)\n 'refresh-triggers': $tw.utils.stringifyList(['$:/temp/tmap/currentTiddler'])\n });\n });\n\n /**\n * Changes:\n * 1. Group styles for matches and neighbours are now modulized\n * and stored as node-types.\n * 2. vis user configuration is restored unflattened!\n * The user only interacts through the GUI.\n * 3. If the node id field was \"id\" it is moved to tmap.id\n */\n this.executeUpgrade('0.9.0', meta.dataStructureState, function () {\n\n var confRef = env.ref.visUserConf;\n var userConf = _utils2.default.unflatten(_this.wiki.getTiddlerData(confRef, {}));\n\n if (_typeof(userConf.groups) === 'object') {\n\n var type = _NodeType2.default.getInstance('tmap:neighbour');\n type.setStyle(userConf.groups['neighbours']);\n type.save();\n\n delete userConf.groups;\n _this.wiki.setTiddlerData(confRef, userConf);\n }\n });\n\n /**\n * Changes:\n * 1. The node id field is moved to tmap.id if **original version**\n * is below v0.9.2.\n */\n this.fixId();\n\n /**\n * This will ensure that all node types have a prioritization field\n * set.\n */\n this.executeUpgrade('0.9.16', meta.dataStructureState, function () {\n\n for (var i = _this.glNTy.length; i--;) {\n _this.glNTy[i].save(null, true);\n }\n });\n\n /**\n * Fixes the live tab\n */\n this.executeUpgrade('0.10.3', meta.dataStructureState, function () {\n\n var liveTab = env.ref.liveTab;\n if (_utils2.default.getTiddler(liveTab).hasTag('$:/tags/SideBar')) {\n this.wiki.deleteTiddler(liveTab);\n _utils2.default.setField(liveTab, 'tags', '$:/tags/SideBar');\n }\n });\n\n /**\n * 1) Fixes the edge type filter. Before, an empty filter was\n * treated as default filter, i.e. no links and tags shown.\n * Now an empty filter means that we show all edge types.\n *\n * 2) Adds prefix to hide private edges per default\n *\n * 3) Corrects view-namespaces (formerly stored with colon).\n *\n */\n this.executeUpgrade('0.11.0', meta.dataStructureState, function () {\n\n var views = _utils2.default.getMatches(env.selector.allViews);\n\n for (var i = views.length; i--;) {\n\n var view = new _ViewAbstraction2.default(views[i]);\n var eTyFilter = view.getEdgeTypeFilter('raw');\n var confKey = 'edge_type_namespace';\n view.setConfig(confKey, view.getConfig(confKey));\n\n var f = env.filter.defaultEdgeTypeFilter;\n\n if (eTyFilter) {\n\n // remove any occurences of the egde type path prefix\n var edgeTypePath = env.path.edgeTypes;\n eTyFilter = _utils2.default.replaceAll(eTyFilter, '', [edgeTypePath, edgeTypePath + '/', '[prefix[' + edgeTypePath + ']]', '[prefix[' + edgeTypePath + '/]]', ['[suffix[tw-body:link]]', '[[tw-body:link]]'], ['[suffix[tw-list:tags]]', '[[tw-list:tags]]'], ['[suffix[tw-list:list]]', '[[tw-body:list]]'], ['[suffix[tmap:unknown]]', '[[tmap:unknown]]'], ['[suffix[unknown]]', '[[tmap:unknown]]']]);\n\n f = '-[prefix[_]] ' + eTyFilter;\n }\n\n view.setEdgeTypeFilter(f);\n }\n });\n }\n }]);\n\n return Fixer;\n}();\n\n/*** Exports *******************************************************/\n\nexports.default = Fixer;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/services/Fixer.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/startup/listener": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/startup/listener",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.startup = exports.synchronous = exports.before = exports.after = exports.platforms = exports.name = undefined;\n\nvar _NodeType = require('$:/plugins/felixhayashi/tiddlymap/js/NodeType');\n\nvar _NodeType2 = _interopRequireDefault(_NodeType);\n\nvar _EdgeType = require('$:/plugins/felixhayashi/tiddlymap/js/EdgeType');\n\nvar _EdgeType2 = _interopRequireDefault(_EdgeType);\n\nvar _Edge = require('$:/plugins/felixhayashi/tiddlymap/js/Edge');\n\nvar _Edge2 = _interopRequireDefault(_Edge);\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nvar _vis = require('$:/plugins/felixhayashi/tiddlymap/js/config/vis');\n\nvar _vis2 = _interopRequireDefault(_vis);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/*** Code **********************************************************/\n\n/**\n * @param {Object} param - event.param\n */\nvar handleCancelDialog = function handleCancelDialog(_ref) {\n var param = _ref.param;\n\n _utils2.default.setField(param, 'text', '');\n};\n\n/**\n * @param {Object} paramObject - event.paramObject\n */\n// @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/startup/listener\ntype: application/javascript\nmodule-type: startup\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\nvar handleClearTiddler = function handleClearTiddler() {\n var _ref2 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},\n paramObject = _ref2.paramObject;\n\n var title = paramObject.title,\n keep = paramObject.keep;\n\n\n if (!title) return;\n\n var tObj = _utils2.default.getTiddler(title);\n var originalFields = tObj ? tObj.fields : {};\n var fieldsToKeep = keep ? keep.split() : [];\n var cloneFields = {\n title: title,\n text: '' // see https://github.com/Jermolene/TiddlyWiki5/issues/2025\n };\n\n for (var i = fieldsToKeep.length; i--;) {\n var fieldName = fieldsToKeep[i];\n cloneFields[fieldName] = originalFields[fieldName];\n }\n\n $tw.wiki.deleteTiddler(title);\n $tw.wiki.addTiddler(new $tw.Tiddler(cloneFields));\n};\n\n/**\n * @param {Object} paramObject - event.paramObject\n */\nvar handleMixTiddlers = function handleMixTiddlers(_ref3) {\n var _ref3$paramObject = _ref3.paramObject,\n paramObject = _ref3$paramObject === undefined ? {} : _ref3$paramObject;\n var tiddlersStringArray = paramObject.tiddlers,\n output = paramObject.output;\n\n\n if (!tiddlersStringArray || !output) return;\n\n var tiddlers = $tw.utils.parseStringArray(tiddlersStringArray);\n var tObj = _utils2.default.getMergedTiddlers(tiddlers, output);\n\n $tw.wiki.addTiddler(tObj);\n};\n\n/**\n * @param {string} param - event.param\n */\nvar handleConfirmDialog = function handleConfirmDialog(_ref4) {\n var param = _ref4.param;\n\n\n _utils2.default.setField(param, 'text', '1');\n};\n\n/**\n * @param {Object} paramObject - event.paramObject\n */\nvar handleSuppressDialog = function handleSuppressDialog(_ref5) {\n var paramObject = _ref5.paramObject;\n var dialog = paramObject.dialog,\n suppress = paramObject.suppress;\n\n\n if (_utils2.default.isTrue(suppress, false)) {\n _utils2.default.setEntry($tm.ref.sysUserConf, 'suppressedDialogs.' + dialog, true);\n }\n};\n\n/**\n * @param {Object} paramObject - event.paramObject\n */\nvar handleDownloadGraph = function handleDownloadGraph(_ref6) {\n var paramObject = _ref6.paramObject;\n var view = paramObject.view;\n\n var graph = $tm.adapter.getGraph({ view: view });\n\n graph.nodes = _utils2.default.convert(graph.nodes, 'array');\n graph.edges = _utils2.default.convert(graph.edges, 'array');\n\n var tRef = '$:/temp/tmap/export';\n\n _utils2.default.setField(tRef, 'text', JSON.stringify(graph, null, 2));\n\n $tw.rootWidget.dispatchEvent({\n type: 'tm-download-file',\n param: tRef,\n paramObject: {\n filename: view + '.json'\n }\n });\n};\n\n/**\n *\n */\nvar handleConfigureSystem = function handleConfigureSystem() {\n\n var allTiddlers = _utils2.default.getMatches($tm.selector.allPotentialNodes);\n var allEdges = $tm.adapter.getEdgesForSet(allTiddlers);\n var plugin = $tw.wiki.getTiddler($tm.path.pluginRoot).fields;\n var meta = $tw.wiki.getTiddlerData($tm.ref.sysMeta);\n var hasLiveTab = _utils2.default.getTiddler($tm.ref.liveTab).hasTag('$:/tags/SideBar');\n\n var args = {\n numberOfNodes: '' + allTiddlers.length,\n numberOfEdges: '' + Object.keys(allEdges).length,\n pluginVersion: 'v' + plugin.version,\n dataStructureVersion: 'v' + meta.dataStructureState,\n dialog: {\n preselects: {\n 'liveTab': '' + hasLiveTab,\n 'vis-inherited': JSON.stringify(_vis2.default),\n 'config.vis': _utils2.default.getText($tm.ref.visUserConf),\n 'config.sys': $tm.config.sys\n }\n }\n };\n\n $tm.dialogManager.open('globalConfig', args, function (isConfirmed, outTObj) {\n\n if (!isConfirmed) return;\n\n var config = _utils2.default.getPropertiesByPrefix(outTObj.fields, 'config.sys.', true);\n\n // CAREFUL: this is a data tiddler!\n $tw.wiki.setTiddlerData($tm.ref.sysUserConf, config);\n\n // show or hide the live tab; to hide the live tab, we override\n // the shadow tiddler; to show it, we remove the overlay again.\n if (_utils2.default.isTrue(outTObj.fields.liveTab, false)) {\n _utils2.default.setField($tm.ref.liveTab, 'tags', '$:/tags/SideBar');\n } else {\n $tw.wiki.deleteTiddler($tm.ref.liveTab);\n }\n\n // tw doesn't translate the json to an object so this is already a string\n _utils2.default.setField($tm.ref.visUserConf, 'text', outTObj.fields['config.vis']);\n });\n};\n\n/**\n * @param {Object} paramObject - event.paramObject\n */\nvar handleGenerateWidget = function handleGenerateWidget(_ref7) {\n var _ref7$paramObject = _ref7.paramObject,\n paramObject = _ref7$paramObject === undefined ? {} : _ref7$paramObject;\n\n\n var options = {\n dialog: {\n preselects: {\n 'var.view': paramObject.view || $tm.misc.defaultViewLabel\n }\n }\n };\n\n $tm.dialogManager.open('widgetCodeGenerator', options);\n};\n\n/**\n * @param {Object} paramObject - event.paramObject\n */\nvar handleRemoveEdge = function handleRemoveEdge(_ref8) {\n var paramObject = _ref8.paramObject;\n\n\n $tm.adapter.deleteEdge(paramObject);\n};\n\n/**\n * @param {Object} paramObject - event.paramObject\n */\nvar handleCreateEdge = function handleCreateEdge(_ref9) {\n var paramObject = _ref9.paramObject;\n var from = paramObject.from,\n to = paramObject.to,\n isForce = paramObject.force;\n\n\n if (!from || !to) return;\n\n if (_utils2.default.tiddlerExists(from) && _utils2.default.tiddlerExists(to) || isForce) {\n\n // will not override any existing tiddlers…\n _utils2.default.addTiddler(to);\n _utils2.default.addTiddler(from);\n\n var edge = new _Edge2.default($tm.adapter.makeNode(from).id, $tm.adapter.makeNode(to).id, paramObject.label, paramObject.id);\n\n $tm.adapter.insertEdge(edge);\n $tm.notify('Edge inserted');\n }\n};\n\n/**\n * @param {string} type - event.type\n * @param {Object} [paramObject] - event.paramObject\n */\nvar handleOpenTypeManager = function handleOpenTypeManager(_ref10) {\n var type = _ref10.type,\n _ref10$paramObject = _ref10.paramObject,\n paramObject = _ref10$paramObject === undefined ? {} : _ref10$paramObject;\n\n\n // either 'manage-edge-types' or 'manage-node-types'\n var mode = type.match(/tmap:tm-(.*)/)[1];\n\n if (mode === 'manage-edge-types') {\n var topic = 'Edge-Type Manager';\n var allTypesSelector = $tm.selector.allEdgeTypes;\n var typeRootPath = $tm.path.edgeTypes;\n } else {\n var topic = 'Node-Type Manager';\n var allTypesSelector = $tm.selector.allNodeTypes;\n var typeRootPath = $tm.path.nodeTypes;\n }\n\n var args = {\n mode: mode,\n topic: topic,\n searchSelector: allTypesSelector,\n typeRootPath: typeRootPath\n };\n\n var dialogTObj = $tm.dialogManager.open('MapElementTypeManager', args);\n\n if (paramObject.type) {\n handleLoadTypeForm({\n paramObject: {\n mode: mode,\n id: paramObject.type,\n output: dialogTObj.fields['output']\n }\n });\n }\n};\n\n/**\n * @param {string} id - The id of a {@link MapElementType}\n * @param {('manage-edge-types'|'manage-node-types')} mode\n * @param {TiddlerReference} output\n */\nvar handleLoadTypeForm = function handleLoadTypeForm(_ref11) {\n var _ref11$paramObject = _ref11.paramObject,\n mode = _ref11$paramObject.mode,\n id = _ref11$paramObject.id,\n output = _ref11$paramObject.output;\n\n\n var outTRef = output;\n var type = mode === 'manage-edge-types' ? _EdgeType2.default.getInstance(id) : _NodeType2.default.getInstance(id);\n\n // inject all the type data as fields into the dialog output\n type.save(outTRef, true);\n\n // fields that need preprocessing\n\n if (mode === 'manage-edge-types') {\n var usage = $tm.adapter.selectEdgesByType(type);\n var count = Object.keys(usage).length;\n _utils2.default.setField(outTRef, 'temp.usageCount', count);\n }\n\n $tw.wiki.addTiddler(new $tw.Tiddler(_utils2.default.getTiddler(outTRef), {\n 'typeTRef': type.fullPath,\n 'temp.idImmutable': type.isShipped ? 'true' : '',\n 'temp.newId': type.id,\n 'vis-inherited': JSON.stringify($tm.config.vis)\n }));\n\n // reset the tabs to default\n _utils2.default.deleteByPrefix('$:/state/tabs/MapElementTypeManager');\n};\n\n/**\n * @param {Object} paramObject - event.paramObject\n */\nvar handleSaveTypeForm = function handleSaveTypeForm(_ref12) {\n var paramObject = _ref12.paramObject;\n\n\n var tObj = _utils2.default.getTiddler(paramObject.output);\n if (!tObj) return;\n\n var id = tObj.fields.id;\n var mode = paramObject.mode;\n\n if (_utils2.default.isTrue(tObj.fields['temp.deleteType'], false)) {\n deleteType(mode, id, tObj);\n } else {\n saveType(mode, id, tObj);\n }\n};\n\nvar deleteType = function deleteType(mode, id, dialogOutput) {\n\n var type = mode === 'manage-edge-types' ? _EdgeType2.default.getInstance(id) : _NodeType2.default.getInstance(id);\n\n $tm.logger('debug', 'Deleting type', type);\n\n if (mode === 'manage-edge-types') {\n $tm.adapter._processEdgesWithType(type, { action: 'delete' });\n } else {\n $tm.adapter.removeNodeType(type);\n }\n\n $tw.wiki.addTiddler(new $tw.Tiddler({\n title: _utils2.default.getTiddlerRef(dialogOutput)\n }));\n\n $tm.notify('Deleted type');\n};\n\n/**\n * @param {string} id - The id of a {@link MapElementType}\n * @param {('manage-edge-types'|'manage-node-types')} mode\n * @param {TiddlerReference} output\n */\nvar saveType = function saveType(mode, id, output) {\n\n var tObj = _utils2.default.getTiddler(output);\n\n // update the type with the form data\n var Type = mode === 'manage-edge-types' ? _EdgeType2.default : _NodeType2.default;\n var type = new Type(id, tObj);\n type.save();\n\n var newId = tObj.fields['temp.newId'];\n\n if (newId && newId !== tObj.fields['id']) {\n //renamed\n\n if (mode === 'manage-edge-types') {\n\n $tm.adapter._processEdgesWithType(type, {\n action: 'rename',\n newName: newId\n });\n } else {\n\n new _NodeType2.default(newId, type).save();\n $tw.wiki.deleteTiddler(type.fullPath);\n }\n\n _utils2.default.setField(tObj, 'id', newId);\n }\n\n $tm.notify('Saved type data');\n};\n\n/**\n * @param {string} id - The id of a {@link MapElementType}\n * @param {('manage-edge-types'|'manage-node-types')} mode\n * @param {TiddlerReference} output\n */\nvar handleCreateType = function handleCreateType(_ref13) {\n var _ref13$paramObject = _ref13.paramObject,\n mode = _ref13$paramObject.mode,\n _ref13$paramObject$id = _ref13$paramObject.id,\n id = _ref13$paramObject$id === undefined ? 'New type' : _ref13$paramObject$id,\n output = _ref13$paramObject.output;\n\n\n var type = mode === 'manage-edge-types' ? new _EdgeType2.default(id) : new _NodeType2.default(id);\n\n type.save();\n\n handleLoadTypeForm({ paramObject: { id: type.id, mode: mode, output: output } });\n};\n\n/*** Exports *******************************************************/\n\nvar name = exports.name = 'tmap.listener';\nvar platforms = exports.platforms = ['browser'];\nvar after = exports.after = ['rootwidget', 'tmap.caretaker'];\nvar before = exports.before = ['story'];\nvar synchronous = exports.synchronous = true;\nvar startup = exports.startup = function startup() {\n _utils2.default.addTWlisteners({\n 'tmap:tm-remove-edge': handleRemoveEdge,\n 'tmap:tm-load-type-form': handleLoadTypeForm,\n 'tmap:tm-save-type-form': handleSaveTypeForm,\n 'tmap:tm-create-type': handleCreateType,\n 'tmap:tm-create-edge': handleCreateEdge,\n 'tmap:tm-suppress-dialog': handleSuppressDialog,\n 'tmap:tm-generate-widget': handleGenerateWidget,\n 'tmap:tm-download-graph': handleDownloadGraph,\n 'tmap:tm-configure-system': handleConfigureSystem,\n 'tmap:tm-manage-edge-types': handleOpenTypeManager,\n 'tmap:tm-manage-node-types': handleOpenTypeManager,\n 'tmap:tm-cancel-dialog': handleCancelDialog,\n 'tmap:tm-clear-tiddler': handleClearTiddler,\n 'tmap:tm-merge-tiddlers': handleMixTiddlers,\n 'tmap:tm-confirm-dialog': handleConfirmDialog\n }, $tw.rootWidget, undefined);\n};\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/services/Listener.js.map\n",
"type": "application/javascript",
"module-type": "startup"
},
"$:/plugins/felixhayashi/tiddlymap/js/services/tracker": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/services/tracker",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/services/tracker\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/***************************** CODE ********************************/\n\n/**\n *\n */\nvar Tracker = function () {\n function Tracker(fixer) {\n _classCallCheck(this, Tracker);\n\n this.wiki = $tw.wiki;\n this.logger = $tm.logger;\n\n this._createIndex();\n }\n\n /**\n * TiddlyMap uses ids to reference tiddlers. This function creates\n * a table that maps ids to tRefs and vice versa.\n *\n * Two indeces are added to the indeces chain:\n * 1. tById – tiddler references by id\n * 2. idByT – ids by tiddler references\n *\n * @param {Array<TiddlerReference>} [allTiddlers] - The tiddlers to\n * use as basis for this index. If not stated, all tiddlers in\n * the wiki are used.\n */\n\n\n _createClass(Tracker, [{\n key: '_createIndex',\n value: function _createIndex() {\n\n var tById = this.tById = {}; // tiddlerById\n var idByT = this.idByT = {}; // idByTiddler\n\n this.wiki.each(function (tObj, tRef) {\n\n if (_utils2.default.isSystemOrDraft(tObj)) {\n return;\n }\n\n // will create id if not present\n var id = tObj.fields['tmap.id'];\n if (!id) {\n id = _utils2.default.genUUID();\n _utils2.default.setField(tObj, 'tmap.id', id);\n }\n\n tById[id] = tRef; // tiddlerById\n idByT[tRef] = id; // idByTiddler\n });\n }\n\n /**\n * This method will assign an id to an *existing* tiddler that does\n * not already possess and id. Any assigned id will be registered\n * at the id->tiddler index.\n *\n * @param {Tiddler} tiddler - The tiddler to assign the id to.\n * @param {boolean} isForce - True if the id should be overridden,\n * false otherwise. Only works if the id field is not set to title.\n *\n * @return {Id} The assigned or retrieved id.\n */\n\n }, {\n key: 'assignId',\n value: function assignId(tiddler, isForce) {\n\n // Note: always reload from store to avoid setting wrong ids on tiddler\n // being in the role of from and to at the same time.\n var tObj = _utils2.default.getTiddler(tiddler);\n\n if (!tObj) {\n throw new ResourceNotFoundException(tiddler);\n }\n\n var id = tObj.fields['tmap.id'];\n\n if (!id || isForce) {\n id = _utils2.default.genUUID();\n _utils2.default.setField(tObj, 'tmap.id', id);\n this.logger('info', 'Assigning new id to', tObj.fields.title);\n }\n\n // blindly update the index IN ANY CASE because tiddler may have\n // an id but it is not indexed yet (e.g. because of renaming operation)\n this.tById[id] = tObj.fields.title;\n this.idByT[tObj.fields.title] = id;\n\n return id;\n }\n\n /**\n * @param {Tiddler} tiddler\n * @return string\n */\n\n }, {\n key: 'getIdByTiddler',\n value: function getIdByTiddler(tiddler) {\n\n return this.idByT[_utils2.default.getTiddlerRef(tiddler)];\n }\n }, {\n key: 'getIdsByTiddlers',\n value: function getIdsByTiddlers() {\n return this.idByT;\n }\n }, {\n key: 'getTiddlersByIds',\n value: function getTiddlersByIds() {\n return this.tById;\n }\n\n /**\n * @param id\n * @return {TiddlerReference} tiddler\n */\n\n }, {\n key: 'getTiddlerById',\n value: function getTiddlerById(id) {\n\n return this.tById[id];\n }\n }]);\n\n return Tracker;\n}();\n\n/*** Exports *******************************************************/\n\nexports.default = Tracker;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/services/Tracker.js.map\n",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/felixhayashi/tiddlymap/js/widget/MapConfigWidget": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/widget/MapConfigWidget",
"text": "'use strict';\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/widget/MapConfigWidget\ntype: application/javascript\nmodule-type: widget\n\n@preserve\n\n\\*/\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nvar _vis = require('$:/plugins/felixhayashi/vis/vis.js');\n\nvar _vis2 = _interopRequireDefault(_vis);\n\nvar _widget = require('$:/core/modules/widgets/widget.js');\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Wrapper for the Visjs configurator.\n *\n * ```\n * <$tmap-config\n * inherited=\"FIELDNAME FIELDNAME …\"\n * extension=\"FIELDNAME\"\n * changes=\"FIELDNAME\" (default: same field as extension)\n * override=\"true|false\" (default: false)\n * mode=\"manage-*\"\n * refresh-trigger=\"tRef\" />\n * ```\n *\n * @constructor\n */\nfunction MapConfigWidget(parseTreeNode, options) {\n\n // call the parent constructor\n _widget.widget.call(this);\n\n // call initialise on prototype\n this.initialise(parseTreeNode, options);\n\n // make the html attributes available to this widget\n this.computeAttributes();\n}\n\n// !! EXTENSION !!\nMapConfigWidget.prototype = Object.create(_widget.widget.prototype);\n// !! EXTENSION !!\n\n/**\n * Method to render this widget into the DOM.\n *\n * @override\n */\nMapConfigWidget.prototype.render = function (parent, nextSibling) {\n\n // remember our place in the dom\n this.parentDomNode = parent;\n\n if (!this.domNode) {\n this.domNode = this.document.createElement('div');\n $tw.utils.addClass(this.domNode, 'tmap-config-widget');\n parent.insertBefore(this.domNode, nextSibling);\n }\n\n if (this.network) {\n\n // destroy any previous instance\n this.network.destroy();\n }\n\n // create container for vis configurator; destroyed when vis is destroyed\n this.networkContainer = document.createElement('div');\n this.domNode.appendChild(this.networkContainer);\n\n // get environment\n this.refreshTrigger = this.getAttribute('refresh-trigger');\n this.pipeTRef = this.getVariable('currentTiddler');\n this.inheritedFields = $tw.utils.parseStringArray(this.getAttribute('inherited'));\n this.extensionTField = this.getAttribute('extension');\n this.mode = this.getAttribute('mode');\n\n // load inherited options\n for (var i = 0; i < this.inheritedFields.length; i++) {\n var fieldName = this.inheritedFields[i];\n var style = _utils2.default.parseFieldData(this.pipeTRef, fieldName, {});\n\n // maybe the inherited options also come without a top level property\n // so we do the same here to…\n // TODO looks clumsy; do it in a more generic way…\n if (this.mode === 'manage-edge-types') {\n if (!style.edges) {\n style = { edges: style };\n }\n } else if (this.mode === 'manage-node-types') {\n if (!style.nodes) {\n style = { nodes: style };\n }\n }\n\n this.inherited = _utils2.default.merge(this.inherited, style);\n }\n\n // load extension to the inherited options; since we store vis config\n // for nodes and edges without the top level property, we may need to\n // append it again, if not done so already.\n this.extension = _utils2.default.parseFieldData(this.pipeTRef, this.extensionTField, {});\n // TODO looks clumsy; do it in a more generic way…\n if (this.mode === 'manage-edge-types') {\n if (!this.extension.edges) {\n this.extension = { edges: this.extension };\n }\n } else if (this.mode === 'manage-node-types') {\n if (!this.extension.nodes) {\n this.extension = { nodes: this.extension };\n }\n }\n\n // we record all changes in a separate variable\n var isSaveOnlyChanges = _utils2.default.isTrue(this.getAttribute('save-only-changes'));\n this.changes = isSaveOnlyChanges ? {} : this.extension;\n\n var data = { nodes: [], edges: [] };\n var options = _utils2.default.merge({}, this.inherited, this.extension);\n $tw.utils.extend(options, {\n configure: {\n enabled: true,\n showButton: false,\n filter: this.getOptionFilter(this.mode)\n }\n });\n\n this.network = new _vis2.default.Network(this.networkContainer, data, options);\n this.network.on('configChange', this.handleConfigChange.bind(this));\n\n // giving the parent a css height will prevent it from jumping\n // back when the network is destroyed and the network\n // container is removed.\n // fixes https://github.com/almende/vis/issues/1568\n var height = this.parentDomNode.getBoundingClientRect().height;\n this.parentDomNode.style['height'] = height + 'px';\n\n var reset = this.handleResetEvent.bind(this);\n this.networkContainer.addEventListener('reset', reset, false);\n\n // register this graph at the caretaker's graph registry\n $tm.registry.push(this);\n\n this.enhanceConfigurator();\n};\n\n/**\n * I only receive the option that has actually changed\n */\nMapConfigWidget.prototype.handleResetEvent = function (ev) {\n var change = {};\n change[ev.detail.trigger.path] = null;\n this.handleConfigChange(change);\n};\n\n/**\n * I only receive the option that has actually changed\n */\nMapConfigWidget.prototype.handleConfigChange = function (change) {\n\n var flatChanges = _utils2.default.flatten(this.changes);\n var flatChange = _utils2.default.flatten(change);\n var confPath = Object.keys(_utils2.default.flatten(change))[0];\n var isReset = flatChange[confPath] === null;\n\n if (isReset) {\n // we interpret this as delete\n\n flatChanges[confPath] = undefined;\n this.changes = _utils2.default.unflatten(flatChanges);\n } else {\n\n this.changes = _utils2.default.merge(this.changes, change);\n }\n\n // when storing edge- or node-styles we strip the root property\n var options = _utils2.default.merge({}, this.changes);\n if (this.mode === 'manage-node-types') {\n options = options['nodes'];\n }\n if (this.mode === 'manage-edge-types') {\n options = options['edges'];\n }\n\n // save changes\n _utils2.default.writeFieldData(this.pipeTRef, this.extensionTField, options, $tm.config.sys.jsonIndentation);\n\n // hack to ensure vis doesn't scroll\n var cls = 'vis-configuration-wrapper';\n var div = this.networkContainer.getElementsByClassName(cls)[0];\n div.style.height = div.getBoundingClientRect().height + 'px';\n\n if (isReset) {\n\n // we need to use a timeout here, otherwise we cause a vis bug\n // since it is in the middle of storing the value!\n window.setTimeout(this.refresh.bind(this), 0);\n } else {\n\n // add active-config indicators\n window.setTimeout(this.enhanceConfigurator.bind(this), 50);\n }\n};\n\n/**\n * enhanceConfigurator over all config items and add an indicator.\n */\nMapConfigWidget.prototype.enhanceConfigurator = function () {\n\n var cls = 'vis-configuration-wrapper';\n var elements = this.networkContainer.getElementsByClassName(cls)[0].children;\n var list = [];\n var changes = _utils2.default.flatten(this.changes);\n for (var i = 0; i < elements.length; i++) {\n if (!elements[i].classList.contains('vis-config-item')) continue;\n\n var conf = new VisConfElement(elements[i], list, i);\n list.push(conf);\n\n if (conf.level === 0) continue;\n\n conf.setActive(!!changes[conf.path]);\n }\n};\n\n/**\n *\n * @param {DOMElement} The config item element.\n * @param {Array<VisConfElement>} a list of VisConfElements of which\n * this element is also part of.\n * @param {number} the position in the list\n */\nfunction VisConfElement(el, list, pos) {\n\n var getByCls = 'getElementsByClassName';\n\n this.el = el;\n this.labelEl = el[getByCls]('vis-config-label')[0] || el[getByCls]('vis-config-header')[0] || el;\n var labelText = this.labelEl.innerText || this.labelEl.textContent;\n this.label = labelText && labelText.match(/([a-zA-Z0-9]+)/)[1];\n this.level = parseInt(el.className.match(/.*vis-config-s(.).*/)[1]) || 0;\n\n this.path = this.label;\n\n if (this.level > 0) {\n for (var i = pos; i--;) {\n var prev = list[i];\n if (prev.level < this.level) {\n this.path = prev.path + '.' + this.path;\n break;\n }\n }\n }\n}\n\nVisConfElement.prototype.setActive = function (isEnable) {\n\n if (!isEnable) return;\n\n // cannot use utils.hasKeyWithPrefix because some keys start with\n // same value as others\n var cls = 'tmap-vis-config-item-' + (isEnable ? 'active' : 'inactive');\n $tw.utils.addClass(this.el, cls);\n\n if (isEnable) {\n\n var button = document.createElement('button');\n button.innerHTML = 'reset';\n button.className = 'tmap-config-item-reset';\n\n var self = this;\n\n button.addEventListener('click', function (ev) {\n ev.currentTarget.dispatchEvent(new CustomEvent('reset', {\n detail: { trigger: self },\n bubbles: true,\n cancelable: true\n }));\n }, false);\n\n this.el.appendChild(button);\n }\n};\n\n/**\n *\n *\n */\nMapConfigWidget.prototype.getOptionFilter = function (mode) {\n\n var whitelist = {\n nodes: {\n borderWidth: true,\n borderWidthSelected: true,\n color: {\n background: true,\n border: true\n },\n font: {\n color: true,\n size: true\n },\n icon: true,\n labelHighlightBold: false,\n shadow: true,\n shape: true,\n shapeProperties: {\n borderDashes: true\n\n },\n size: true\n },\n edges: {\n arrows: true,\n color: true,\n dashes: true,\n font: true,\n labelHighlightBold: false,\n length: true,\n selfReferenceSize: false,\n shadow: true,\n smooth: true,\n width: true\n },\n interaction: {\n hideEdgesOnDrag: true,\n hideNodesOnDrag: true,\n tooltipDelay: true\n },\n layout: {\n hierarchical: false\n },\n manipulation: {\n initiallyActive: true\n },\n physics: {\n forceAtlas2Based: {\n gravitationalConstant: true,\n springLength: true,\n springConstant: true,\n damping: true,\n centralGravity: true\n }\n }\n };\n\n if (mode === 'manage-edge-types') {\n whitelist = { edges: whitelist.edges };\n } else if (mode === 'manage-node-types') {\n whitelist = { nodes: whitelist.nodes };\n } else {\n whitelist.edges.arrows = false;\n }\n\n return function (option, path) {\n\n // operate on a clone; add option as element\n path = path.concat([option]);\n\n var wlObj = whitelist;\n for (var i = 0, l = path.length; i < l; i++) {\n if (wlObj[path[i]] === true) {\n return true;\n } else if (wlObj[path[i]] == null) {\n return false;\n } // else assume object\n wlObj = wlObj[path[i]];\n }\n\n return false;\n };\n};\n\n/**\n * A zombie widget is a widget that is removed from the dom tree\n * but still referenced or still partly executed -- I mean\n * otherwise you couldn't call this function, right?\n *\n * @TODO Outsource this as interface or common super class\n */\nMapConfigWidget.prototype.isZombieWidget = function () {\n\n return !document.body.contains(this.parentDomNode);\n};\n\n/**\n * called from outside.\n *\n * @TODO Outsource this as interface or common super class\n */\nMapConfigWidget.prototype.destruct = function () {\n\n if (this.network) {\n this.network.destroy();\n }\n};\n\n/**\n * This function is called by the system to notify the widget about\n * tiddler changes.\n *\n * @override\n */\nMapConfigWidget.prototype.refresh = function (changedTiddlers) {\n\n if (this.isZombieWidget() || !this.network) return;\n\n if (!changedTiddlers || changedTiddlers[this.refreshTrigger]) {\n this.refreshSelf();\n return true;\n }\n};\n\nMapConfigWidget.prototype.setNull = function (obj) {\n\n for (var p in obj) {\n\n if (_typeof(obj[p]) == 'object') {\n\n this.setNull(obj[p]);\n } else {\n\n obj[p] = undefined;\n }\n }\n};\n\n/*** Exports *******************************************************/\n\nexports['tmap-config'] = MapConfigWidget;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/widget/ConfigurationWidget.js.map\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/plugins/felixhayashi/tiddlymap/js/widget/EdgeListWidgetItem": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/widget/EdgeListWidgetItem",
"text": "'use strict';\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _widget = require('$:/core/modules/widgets/widget.js');\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/widget/EdgeListWidgetItem\ntype: application/javascript\nmodule-type: widget\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\n/*** Code **********************************************************/\n\nvar EdgeListItemWidget = function (_Widget) {\n _inherits(EdgeListItemWidget, _Widget);\n\n function EdgeListItemWidget(parseTreeNode, options) {\n _classCallCheck(this, EdgeListItemWidget);\n\n var _this = _possibleConstructorReturn(this, (EdgeListItemWidget.__proto__ || Object.getPrototypeOf(EdgeListItemWidget)).call(this, parseTreeNode, options));\n\n _this.arrows = $tm.misc.arrows;\n\n return _this;\n }\n\n _createClass(EdgeListItemWidget, [{\n key: 'execute',\n value: function execute() {\n\n var item = this.parseTreeNode;\n var tRef = $tm.tracker.getTiddlerById(item.neighbour.id);\n\n // make edge properties available as variables\n var edge = _utils2.default.flatten(item.edge);\n\n for (var p in edge) {\n if (typeof edge[p] === 'string') {\n this.setVariable('edge.' + p, edge[p]);\n }\n }\n\n // Perspective: Neighbour\n this.setVariable('currentTiddler', tRef);\n this.setVariable('neighbour', tRef);\n\n var type = $tm.indeces.allETy[edge.type];\n var indexedAs = edge.to === item.neighbour.id ? 'to' : 'from';\n var arrow = indexedAs;\n\n if (type.biArrow) {\n arrow = 'bi';\n } else {\n if (indexedAs === 'to' && type.invertedArrow) {\n arrow = 'from';\n } else if (indexedAs === 'from' && type.invertedArrow) {\n arrow = 'to';\n }\n }\n\n this.setVariable('direction', arrow);\n this.setVariable('directionSymbol', arrow === 'bi' ? this.arrows.bi : arrow === 'from' ? this.arrows.in : this.arrows.out);\n\n // Construct the child widgets\n this.makeChildWidgets();\n }\n }, {\n key: 'refresh',\n value: function refresh(changedTiddlers) {\n\n return this.refreshChildren(changedTiddlers);\n }\n }]);\n\n return EdgeListItemWidget;\n}(_widget.widget);\n\n/*** Exports *******************************************************/\n\nexports['tmap-edgelistitem'] = EdgeListItemWidget;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/widget/EdgeListItemWidget.js.map\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/plugins/felixhayashi/tiddlymap/js/widget/EdgeListWidget": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/widget/EdgeListWidget",
"text": "'use strict';\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _widget = require('$:/core/modules/widgets/widget.js');\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/widget/EdgeListWidget\ntype: application/javascript\nmodule-type: widget\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\n/*** Code **********************************************************/\n\nvar EdgeListWidget = function (_Widget) {\n _inherits(EdgeListWidget, _Widget);\n\n function EdgeListWidget(parseTreeNode, options) {\n _classCallCheck(this, EdgeListWidget);\n\n return _possibleConstructorReturn(this, (EdgeListWidget.__proto__ || Object.getPrototypeOf(EdgeListWidget)).call(this, parseTreeNode, options));\n }\n\n _createClass(EdgeListWidget, [{\n key: 'render',\n value: function render(parent, nextSibling) {\n\n this.parentDomNode = parent;\n this.computeAttributes();\n this.execute();\n this.renderChildren(parent, nextSibling);\n }\n }, {\n key: 'execute',\n value: function execute() {\n\n var nodes = [this.getVariable('currentTiddler')];\n var filter = this.getAttribute('filter', '');\n var direction = this.getAttribute('direction', 'both');\n var allETy = $tm.indeces.allETy;\n var matches = _utils2.default.getEdgeTypeMatches(filter, allETy);\n\n var options = {\n typeWL: _utils2.default.getLookupTable(matches),\n direction: direction\n };\n\n // retrieve nodes and edges\n\n var _$tm$adapter$getNeigh = $tm.adapter.getNeighbours(nodes, options),\n neighbours = _$tm$adapter$getNeigh.nodes,\n edges = _$tm$adapter$getNeigh.edges;\n\n var entries = [];\n for (var id in edges) {\n\n var edge = edges[id];\n var neighbour = neighbours[edge.to] || neighbours[edge.from];\n\n if (!neighbour) {\n // obsolete edge from old times;\n continue;\n }\n\n // make item template\n entries.push({\n type: 'tmap-edgelistitem',\n edge: edge,\n typeWL: options.typeWL,\n neighbour: neighbour,\n // the children of this widget (=what is wrapped inside the\n // widget-element's body) is used as template for the list items\n children: this.parseTreeNode.children\n });\n }\n\n if (!entries.length) {\n\n this.wasEmpty = true;\n entries = this.getEmptyMessage();\n } else if (this.wasEmpty) {\n\n // we need to remove the empty message\n this.removeChildDomNodes();\n }\n\n this.makeChildWidgets(entries);\n }\n }, {\n key: 'getEmptyMessage',\n value: function getEmptyMessage() {\n\n var parser = this.wiki.parseText('text/vnd.tiddlywiki', this.getAttribute('emptyMessage', ''), { parseAsInline: true });\n\n return parser ? parser.tree : [];\n }\n }, {\n key: 'refresh',\n value: function refresh(changedTiddlers) {\n\n var changedAttributes = this.computeAttributes();\n\n if (_utils2.default.hasElements(changedAttributes)) {\n\n this.refreshSelf();\n\n return true;\n }\n\n for (var tRef in changedTiddlers) {\n if (!_utils2.default.isSystemOrDraft(tRef)) {\n\n this.refreshSelf();\n\n return true;\n }\n }\n\n // let children decide for themselves\n return this.refreshChildren(changedTiddlers);\n }\n }]);\n\n return EdgeListWidget;\n}(_widget.widget);\n\n/*** Exports *******************************************************/\n\nexports['tmap-connections'] = EdgeListWidget;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/widget/EdgeListWidget.js.map\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/plugins/felixhayashi/tiddlymap/js/widget/MapWidget": {
"title": "$:/plugins/felixhayashi/tiddlymap/js/widget/MapWidget",
"text": "'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.tiddlymap = exports.tmap = undefined;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _CallbackManager = require('$:/plugins/felixhayashi/tiddlymap/js/CallbackManager');\n\nvar _CallbackManager2 = _interopRequireDefault(_CallbackManager);\n\nvar _ViewAbstraction = require('$:/plugins/felixhayashi/tiddlymap/js/ViewAbstraction');\n\nvar _ViewAbstraction2 = _interopRequireDefault(_ViewAbstraction);\n\nvar _EdgeType = require('$:/plugins/felixhayashi/tiddlymap/js/EdgeType');\n\nvar _EdgeType2 = _interopRequireDefault(_EdgeType);\n\nvar _Popup = require('$:/plugins/felixhayashi/tiddlymap/js/Popup');\n\nvar _Popup2 = _interopRequireDefault(_Popup);\n\nvar _vis = require('$:/plugins/felixhayashi/vis/vis.js');\n\nvar _vis2 = _interopRequireDefault(_vis);\n\nvar _widget = require('$:/core/modules/widgets/widget.js');\n\nvar _utils = require('$:/plugins/felixhayashi/tiddlymap/js/utils');\n\nvar _utils2 = _interopRequireDefault(_utils);\n\nvar _SelectionRectangle = require('$:/plugins/felixhayashi/tiddlymap/js/lib/SelectionRectangle');\n\nvar _SelectionRectangle2 = _interopRequireDefault(_SelectionRectangle);\n\nvar _environment = require('$:/plugins/felixhayashi/tiddlymap/js/lib/environment');\n\nvar env = _interopRequireWildcard(_environment);\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } // @preserve\n/*\\\n\ntitle: $:/plugins/felixhayashi/tiddlymap/js/widget/MapWidget\ntype: application/javascript\nmodule-type: widget\n\n@preserve\n\n\\*/\n\n/*** Imports *******************************************************/\n\n/*** Code **********************************************************/\n\n/**\n * The map widget is responsible for drawing the actual network\n * diagrams.\n *\n * @constructor\n */\nvar MapWidget = function (_Widget) {\n _inherits(MapWidget, _Widget);\n\n function MapWidget(parseTreeNode, options) {\n _classCallCheck(this, MapWidget);\n\n // create shortcuts for services and frequently used vars\n var _this = _possibleConstructorReturn(this, (MapWidget.__proto__ || Object.getPrototypeOf(MapWidget)).call(this, parseTreeNode, options));\n\n _this.getAttr = _this.getAttribute;\n _this.isDebug = _utils2.default.isTrue($tm.config.sys.debug, false);\n\n // force early binding of functions to this context\n _utils2.default.bindTo(_this, ['constructTooltip', 'handleResizeEvent', 'handleClickEvent', 'handleCanvasKeyup', 'handleCanvasKeydown', 'handleCanvasScroll', 'handleCanvasMouseMove', 'handleWidgetKeyup', 'handleWidgetKeydown', 'handleTriggeredRefresh', 'handleContextMenu']);\n\n // instanciate managers\n _this.callbackManager = new _CallbackManager2.default();\n\n // make the html attributes available to this widget\n _this.computeAttributes();\n _this.editorMode = _this.getAttr('editor');\n _this.clickToUse = _utils2.default.isTrue(_this.getAttr('click-to-use'), false);\n\n // who am I? the id is used for debugging and special cases\n _this.id = _this.getAttr('object-id') || _this.getStateQualifier();\n\n _this.widgetPopupsPath = $tm.path.tempPopups + '/' + _this.id;\n\n // register listeners that are available in editor mode\n if (_this.editorMode) {\n _utils2.default.addTWlisteners({\n 'tmap:tm-create-view': _this.handleCreateView,\n 'tmap:tm-rename-view': _this.handleRenameView,\n 'tmap:tm-delete-view': _this.handleDeleteView,\n 'tmap:tm-delete-element': _this.handleDeleteElement,\n 'tmap:tm-edit-view': _this.handleEditView,\n 'tmap:tm-generate-widget': _this.handleGenerateWidget,\n 'tmap:tm-toggle-central-topic': _this.handleSetCentralTopic,\n 'tmap:tm-save-canvas': _this.handleSaveCanvas\n }, _this, _this);\n }\n\n // register listeners that are available in any case\n _utils2.default.addTWlisteners({\n 'tmap:tm-focus-node': _this.handleFocusNode,\n 'tmap:tm-reset-focus': _this.repaintGraph\n }, _this, _this);\n\n // Visjs handlers\n _this.visListeners = {\n 'click': _this.handleVisSingleClickEvent,\n 'doubleClick': _this.handleVisDoubleClickEvent,\n 'stabilized': _this.handleVisStabilizedEvent,\n 'selectNode': _this.handleVisSelectNode,\n 'deselectNode': _this.handleVisDeselectNode,\n 'dragStart': _this.handleVisDragStart,\n 'dragEnd': _this.handleVisDragEnd,\n 'hoverNode': _this.handleVisHoverElement,\n 'hoverEdge': _this.handleVisHoverElement,\n 'blurNode': _this.handleVisBlurElement,\n 'blurEdge': _this.handleVisBlurElement,\n 'beforeDrawing': _this.handleVisBeforeDrawing,\n 'afterDrawing': _this.handleVisAfterDrawing,\n 'stabilizationProgress': _this.handleVisLoading,\n 'stabilizationIterationsDone': _this.handleVisLoadingDone\n };\n\n _this.windowDomListeners = {\n 'resize': [_this.handleResizeEvent, false],\n 'click': [_this.handleClickEvent, false],\n 'mousemove': [_this.handleCanvasMouseMove, true]\n };\n\n _this.canvasDomListeners = {\n 'keyup': [_this.handleCanvasKeyup, true],\n 'keydown': [_this.handleCanvasKeydown, true],\n 'mousewheel': [_this.handleCanvasScroll, true],\n 'DOMMouseScroll': [_this.handleCanvasScroll, true],\n 'contextmenu': [_this.handleContextMenu, true]\n };\n\n _this.widgetDomListeners = {\n 'keyup': [_this.handleWidgetKeyup, true],\n 'keydown': [_this.handleWidgetKeydown, true]\n };\n\n _this.conVector = { from: null, to: null };\n return _this;\n }\n\n /**\n * This handler will open a dialog that allows the user to create a\n * new relation between two edges. This includes, that the user\n * gets a chance to specify the edgetype of the connection.\n *\n * If an edge-type namespace has been declared for the entire view,\n * then add it to the `id` of the specified type…\n * - …if the type doesn't exist yet.\n * - …if the type doesn't contain a namespace already, regardless\n * whether it exists or not.\n *\n * Once the user confirmed the dialog, the edge is persisted.\n *\n * Note: this should not trigger a zoom.\n *\n * @param {Edge} edge - A javascript object that contains at least\n * the properties 'from' and 'to'\n * @param {function} [callback] - A function with the signature\n * function(isConfirmed);\n */\n\n\n _createClass(MapWidget, [{\n key: 'handleConnectionEvent',\n value: function handleConnectionEvent(edge, callback) {\n var _this2 = this;\n\n var eTyFilter = this.view.getEdgeTypeFilter();\n\n var param = {\n fromLabel: $tm.adapter.selectNodeById(edge.from).label,\n toLabel: $tm.adapter.selectNodeById(edge.to).label,\n view: this.view.getLabel(),\n eTyFilter: eTyFilter.raw\n };\n\n $tm.dialogManager.open('getEdgeType', param, function (isConfirmed, outTObj) {\n\n if (isConfirmed) {\n\n var str = _utils2.default.getText(outTObj);\n var type = _EdgeType2.default.getInstance(str);\n\n if (!type.namespace) {\n var _EdgeType$getIdParts = _EdgeType2.default.getIdParts(type.id),\n marker = _EdgeType$getIdParts.marker,\n name = _EdgeType$getIdParts.name;\n\n var namespace = _this2.view.getConfig('edge_type_namespace');\n type = _EdgeType2.default.getInstance(_EdgeType2.default.getId(marker, namespace, name));\n }\n\n // persist the type if it doesn't exist\n if (!type.exists()) {\n type.save();\n }\n\n // add type to edge\n edge.type = type.id;\n $tm.adapter.insertEdge(edge);\n\n // prevent zoom\n _this2.isPreventZoomOnNextUpdate = true;\n\n if (!_this2.view.isEdgeTypeVisible(type)) {\n\n $tm.dialogManager.open('edgeNotVisible', {\n type: type.id,\n view: _this2.view.getLabel(),\n eTyFilter: eTyFilter.pretty\n });\n }\n }\n\n if (typeof callback === 'function') {\n callback(isConfirmed);\n }\n });\n }\n\n /**\n * The first time a map is opened, we want to display a welcome message.\n * Once shown, a flag is set and the message is not displayed again.\n */\n\n }, {\n key: 'checkForFreshInstall',\n value: function checkForFreshInstall() {\n\n if (!_utils2.default.getEntry($tm.ref.sysMeta, 'showWelcomeMessage', true)) {\n return;\n }\n\n _utils2.default.setEntry($tm.ref.sysMeta, 'showWelcomeMessage', false);\n\n var args = {\n dialog: {\n preselects: {\n \"config.storyview\": \"true\",\n \"config.navigation\": \"true\",\n \"config.sidebar\": \"true\",\n \"config.demo\": \"true\"\n }\n }\n };\n\n $tm.dialogManager.open('welcome', args, function (isConfirmed, outTObj) {\n\n var config = _utils2.default.getPropertiesByPrefix(outTObj.fields, 'config.', true);\n\n if (config['storyview'] && _utils2.default.tiddlerExists('$:/plugins/felixhayashi/topstoryview')) {\n _utils2.default.setText('$:/view', 'top');\n }\n\n if (config['navigation']) {\n _utils2.default.setText('$:/config/Navigation/openLinkFromInsideRiver', 'above');\n _utils2.default.setText('$:/config/Navigation/openLinkFromOutsideRiver', 'top');\n }\n\n if (config['sidebar']) {\n _utils2.default.setText('$:/themes/tiddlywiki/vanilla/options/sidebarlayout', 'fixed-fluid');\n }\n\n if (config['demo']) {\n var view = $tm.misc.defaultViewLabel;\n\n var n1 = $tm.adapter.insertNode({ label: 'Have fun with', x: 0, y: 0 }, view);\n var n2 = $tm.adapter.insertNode({ label: 'TiddlyMap!!', x: 100, y: 100 }, view);\n\n $tm.adapter.insertEdge({ from: n1.id, to: n2.id });\n }\n\n if (Object.keys(config).length) {\n // trigger a save and reload message\n _utils2.default.touch('$:/plugins/felixhayashi/tiddlymap');\n }\n });\n }\n\n /**\n * A very basic dialog that will tell the user he/she has to make\n * a choice.\n *\n * @param {function} [callback] - A function with the signature\n * function(isConfirmed).\n * @param {string} [message] - An small optional message to display.\n */\n\n }, {\n key: 'openStandardConfirmDialog',\n value: function openStandardConfirmDialog(callback, message) {\n\n var param = { message: message };\n $tm.dialogManager.open('getConfirmation', param, callback);\n }\n\n /**\n * An extention of the default logger mechanism. It works like\n * `this.logger` but will include the object id of the widget\n * instance.\n *\n * @param {string} type - The type of the message (debug, info, warning…)\n * which is exactly the same as in `console[type]`.\n * @param {...*} message - An infinite number of arguments to be printed\n * (just like console).\n */\n\n }, {\n key: 'logger',\n value: function logger(type, message /*, more stuff*/) {\n\n if (this.isDebug) {\n\n var args = Array.prototype.slice.call(arguments, 1);\n args.unshift('@' + this.id);\n args.unshift(type);\n $tm.logger.apply(this, args);\n }\n }\n\n /**\n * Method to render this widget into the DOM.\n *\n * Note that we do not add this.domNode to the list of domNodes\n * since this widget does never remove itself during a refresh.\n *\n * @override\n */\n\n }, {\n key: 'render',\n value: function render(parent, nextSibling) {\n\n this.parentDomNode = parent;\n\n this.domNode = this.document.createElement('div');\n parent.insertBefore(this.domNode, nextSibling);\n\n // add widget classes\n this.registerClassNames(this.domNode);\n\n // get view and view holder\n this.viewHolderRef = this.getViewHolderRef();\n this.view = this.getView();\n\n // create the header div\n this.graphBarDomNode = this.document.createElement('div');\n $tw.utils.addClass(this.graphBarDomNode, 'tmap-topbar');\n this.domNode.appendChild(this.graphBarDomNode);\n\n // create body div\n this.graphDomNode = this.document.createElement('div');\n this.domNode.appendChild(this.graphDomNode);\n\n $tw.utils.addClass(this.graphDomNode, 'tmap-vis-graph');\n\n if (_utils2.default.isPreviewed(this)) {\n\n $tw.utils.addClass(this.domNode, 'tmap-static-mode');\n this.renderPreview(this.graphBarDomNode, this.graphDomNode);\n } else {\n\n // render the full widget\n this.renderFullWidget(this.domNode, this.graphBarDomNode, this.graphDomNode);\n }\n }\n\n /**\n * When the widget is only previewed we do some alternative rendering.\n */\n\n }, {\n key: 'renderPreview',\n value: function renderPreview(header, body) {\n\n var snapshotTRef = this.view.getRoot() + '/snapshot';\n var snapshotTObj = _utils2.default.getTiddler(snapshotTRef);\n\n var label = this.document.createElement('span');\n label.innerHTML = this.view.getLabel();\n label.className = 'tmap-view-label';\n header.appendChild(label);\n\n if (snapshotTObj) {\n\n // Construct child widget tree\n var placeholder = this.makeChildWidget(_utils2.default.getTranscludeNode(snapshotTRef), true);\n placeholder.renderChildren(body, null);\n } else {\n\n $tw.utils.addClass(body, 'tmap-graph-placeholder');\n }\n }\n\n /**\n * The standard way of rendering.\n * Attention: BE CAREFUL WITH THE ORDER OF FUNCTION CALLS IN THIS FUNCTION.\n */\n\n }, {\n key: 'renderFullWidget',\n value: function renderFullWidget(widget, header, body) {\n\n // add window and widget dom node listeners\n _utils2.default.setDomListeners('add', window, this.windowDomListeners);\n _utils2.default.setDomListeners('add', widget, this.widgetDomListeners);\n\n // add a loading bar\n this.addLoadingBar(this.domNode);\n\n // prepare the tooltip for graph elements\n this.tooltip = new _Popup2.default(this.domNode, {\n className: 'tmap-tooltip',\n showDelay: $tm.config.sys.popups.delay\n });\n\n // prepare the context menu\n this.contextMenu = new _Popup2.default(this.domNode, {\n className: 'tmap-context-menu',\n showDelay: 0,\n hideOnClick: true,\n leavingDelay: 999999\n });\n\n // register\n this.sidebar = _utils2.default.getFirstElementByClassName('tc-sidebar-scrollable');\n this.isInSidebar = this.sidebar && !this.domNode.isTiddlyWikiFakeDom && this.sidebar.contains(this.domNode);\n\n // *first* inject the bar\n this.rebuildEditorBar(header);\n\n // *second* initialise graph variables and render the graph\n this.initAndRenderGraph(body);\n\n // register this graph at the caretaker's graph registry\n $tm.registry.push(this);\n\n // if any refresh-triggers exist, register them\n this.reloadRefreshTriggers();\n\n // maybe display a welcome message\n this.checkForFreshInstall();\n\n if (this.id === $tm.misc.mainEditorId) {\n\n var url = $tm.url;\n if (url && url.query['tmap-enlarged']) {\n\n this.toggleEnlargedMode(url.query['tmap-enlarged']);\n //~ this.setView(url.query['tmap-view']);\n }\n }\n }\n\n /**\n * Add some classes to give the user a chance to apply some css\n * to different graph modes.\n */\n\n }, {\n key: 'registerClassNames',\n value: function registerClassNames(parent) {\n\n var addClass = $tw.utils.addClass;\n\n // add main class\n addClass(parent, 'tmap-widget');\n\n if (this.clickToUse) {\n addClass(parent, 'tmap-click-to-use');\n }\n\n if (this.getAttr('editor') === 'advanced') {\n addClass(parent, 'tmap-advanced-editor');\n }\n\n if (this.getAttr('design') === 'plain') {\n addClass(parent, 'tmap-plain-design');\n }\n\n if (!_utils2.default.isTrue(this.getAttr('show-buttons'), true)) {\n addClass(parent, 'tmap-no-buttons');\n }\n\n if (this.getAttr('class')) {\n addClass(parent, this.getAttr('class'));\n }\n }\n\n /**\n * Adds a loading bar div below the parent.\n */\n\n }, {\n key: 'addLoadingBar',\n value: function addLoadingBar(parent) {\n\n this.graphLoadingBarDomNode = this.document.createElement('progress');\n $tw.utils.addClass(this.graphLoadingBarDomNode, 'tmap-loading-bar');\n parent.appendChild(this.graphLoadingBarDomNode);\n }\n\n /**\n * The editor bar contains a bunch of widgets that allow the user\n * to manipulate the current view.\n *\n * Attention: The Editor bar needs to render *after* the graph\n * because some elements depend on the graph's nodes which are\n * calculated when the network is created.\n *\n * @see https://groups.google.com/forum/#!topic/tiddlywikidev/sJrblP4A0o4\n * @see blob/master/editions/test/tiddlers/tests/test-wikitext-parser.js\n */\n\n }, {\n key: 'rebuildEditorBar',\n value: function rebuildEditorBar() {\n\n this.removeChildDomNodes();\n\n // register dialog variables\n\n var view = this.view;\n\n var unicodeBtnClass = 'tmap-unicode-button';\n var activeUnicodeBtnClass = unicodeBtnClass + ' tmap-active-button';\n var variables = {\n widgetQualifier: this.getStateQualifier(),\n widgetTempPath: this.widgetTempPath,\n widgetPopupsPath: this.widgetPopupsPath,\n isViewBound: String(this.isViewBound()),\n viewRoot: view.getRoot(),\n viewLabel: view.getLabel(),\n viewHolder: this.getViewHolderRef(),\n edgeTypeFilter: view.edgeTypeFilterTRef,\n allEdgesFilter: $tm.selector.allEdgeTypes,\n neighScopeBtnClass: view.isEnabled('neighbourhood_scope') ? activeUnicodeBtnClass : unicodeBtnClass,\n rasterMenuBtnClass: view.isEnabled('raster') ? activeUnicodeBtnClass : unicodeBtnClass\n };\n\n for (var name in variables) {\n this.setVariable(name, variables[name]);\n }\n\n // Construct the child widget tree\n var body = _utils2.default.getTiddlerNode(view.getRoot());\n\n if (this.editorMode === 'advanced') {\n\n body.children.push(_utils2.default.getTranscludeNode($tm.ref.graphBar));\n } else {\n\n var el = _utils2.default.getElementNode('span', 'tmap-view-label', view.getLabel());\n body.children.push(el);\n }\n\n body.children.push(_utils2.default.getTranscludeNode($tm.ref.focusButton));\n\n this.makeChildWidgets([body]);\n this.renderChildren(this.graphBarDomNode, this.graphBarDomNode.firstChild);\n }\n\n /**\n * This function is called by the system to notify the widget about\n * tiddler changes. It is ignored by TiddlyMap.\n *\n * ATTENTION: TiddlyMap doesn't use the refresh mechanism here.\n * The caretaker module dispatches an `updates` object that provides\n * more advanced information, tailored to the needs of TiddlyMap.\n * These updates are picked up by {@link MapWidget#update}.\n *\n * @override\n */\n\n }, {\n key: 'refresh',\n value: function refresh(changedTiddlers) {\n\n // TiddlyMap never needs a full refresh so we return false\n return false;\n }\n\n /**\n * This function is called by the caretaker module to notify the\n * widget about tiddler changes.\n *\n * TiddlyMap is interested in the following changes:\n *\n * - Callbacks have been triggered (e.g. dialog results)\n * - A view has been switched\n * - A view has been modified (= configured)\n * - Global options have changed\n * - Node- or edge-types have changed\n * - Graph elements have changed\n * - Changes to the graph's topbar\n *\n * @override\n * @see https://groups.google.com/d/msg/tiddlywikidev/hwtX59tKsIk/EWSG9glqCnsJ\n */\n\n }, {\n key: 'update',\n value: function update(updates) {\n\n if (!this.network || this.isZombieWidget() || _utils2.default.isPreviewed(this)) {\n return;\n }\n\n var changedTiddlers = updates.changedTiddlers;\n\n // check for callback changes\n\n this.callbackManager.refresh(changedTiddlers);\n\n if (this.isViewSwitched(changedTiddlers) || this.hasChangedAttributes() // widget html code changed\n || updates[env.path.options] // global options changed\n || changedTiddlers[this.view.getRoot()] // view's main config changed\n ) {\n\n this.logger('warn', 'View switched config changed');\n\n this.isPreventZoomOnNextUpdate = false;\n this.view = this.getView(true);\n this.reloadRefreshTriggers();\n this.rebuildEditorBar();\n this.reloadBackgroundImage();\n this.initAndRenderGraph(this.graphDomNode);\n } else {\n // view has not been switched\n\n // give the view a chance to refresh itself\n var isViewUpdated = this.view.update(updates);\n\n if (isViewUpdated) {\n\n this.logger('warn', 'View components modified');\n this.rebuildGraph({ resetFocus: { delay: 1000, duration: 1000 } });\n } else {\n // neither view switch or view modification\n\n if (updates[env.path.nodeTypes] || this.hasChangedElements(changedTiddlers)) {\n this.rebuildGraph();\n }\n\n // give children a chance to update themselves\n this.refreshChildren(changedTiddlers);\n }\n }\n }\n }, {\n key: 'hidePopups',\n value: function hidePopups(delay, isForce) {\n\n this.tooltip.hide(delay, isForce);\n this.contextMenu.hide(0, true);\n }\n\n /**\n * Refresh-triggers are tiddlers whose mere occurrence in the\n * changedTiddlers list forces tiddlymap to reassert\n * whether a filter expression returns the same set of matches as it\n * is currently displayed in the graph.\n *\n * The raison d'etre for refresh-triggers is that a filter may contain\n * implicit text-references or variables that may require a filter to be\n * reasserted even though, the filter expression itself did not change.\n *\n * For example a filter `[field:title{$:/HistoryList!!current-tiddler}]`\n * requires a `$:/HistoryList` refresh trigger to be added to the view so\n * everytime the `$:/HistoryList` tiddler changes, the filter gets\n * reasserted.\n */\n\n }, {\n key: 'reloadRefreshTriggers',\n value: function reloadRefreshTriggers() {\n\n // remove old triggers (if there are any)\n this.callbackManager.remove(this.refreshTriggers);\n\n // load new trigger list either from attribute or view config\n var str = this.getAttr('refresh-triggers') || this.view.getConfig('refresh-triggers');\n this.refreshTriggers = $tw.utils.parseStringArray(str) || [];\n\n this.logger('debug', 'Registering refresh trigger', this.refreshTriggers);\n\n // TODO: not nice, if more than one trigger changed it\n // will cause multiple reassertments\n for (var i = this.refreshTriggers.length; i--;) {\n this.callbackManager.add(this.refreshTriggers[i], this.handleTriggeredRefresh, false);\n }\n }\n\n /**\n * Calling this method will cause the graph to be rebuild, which means\n * the graph data is refreshed. A rebuild of the graph will always\n * cause the network to stabilize again.\n *\n * @param {Hashmap} [resetFocus=null] - If not false or null,\n * this object requires two properties to be set: `delay` (the\n * time to wait before starting the fit), `duration` (the length\n * of the fit animation).\n */\n\n }, {\n key: 'rebuildGraph',\n value: function rebuildGraph() {\n var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},\n resetFocus = _ref.resetFocus;\n\n if (_utils2.default.isPreviewed(this)) {\n\n return;\n }\n\n this.logger('debug', 'Rebuilding graph');\n\n this.hidePopups(0, true);\n\n // always reset to allow handling of stabilized-event!\n this.hasNetworkStabilized = false;\n\n var changes = this.rebuildGraphData();\n\n if (changes.changedNodes.withoutPosition.length) {\n\n // force resetFocus\n resetFocus = resetFocus || { delay: 1000, duration: 1000 };\n\n if (!this.view.isEnabled('physics_mode')) {\n\n // in static mode we need to ensure that objects spawn\n // near center so we need to set physics from\n // zero to something. Yes, we override the users\n // central gravity value… who cares about central\n // gravity in static mode anyways.\n var physics = this.visOptions.physics;\n physics[physics.solver].centralGravity = 0.25;\n this.network.setOptions(this.visOptions);\n }\n }\n\n if (!_utils2.default.hasElements(this.graphData.nodesById)) {\n return;\n }\n\n if (resetFocus) {\n\n if (!this.isPreventZoomOnNextUpdate) {\n\n // see https://github.com/almende/vis/issues/987#issuecomment-113226216\n // see https://github.com/almende/vis/issues/939\n this.network.stabilize();\n this.resetFocus = resetFocus;\n }\n\n this.isPreventZoomOnNextUpdate = false;\n }\n }\n\n /**\n * WARNING: Do not change this functionname as it is used by the\n * caretaker's routinely checkups.\n */\n\n }, {\n key: 'getContainer',\n value: function getContainer() {\n\n return this.domNode;\n }\n\n /**\n *\n */\n\n }, {\n key: 'rebuildGraphData',\n value: function rebuildGraphData() {\n\n $tm.start('Reloading Network');\n\n var graph = $tm.adapter.getGraph({ view: this.view });\n\n var changedNodes = _utils2.default.refreshDataSet(this.graphData.nodes, // dataset\n graph.nodes // new nodes\n );\n\n var changedEdges = _utils2.default.refreshDataSet(this.graphData.edges, // dataset\n graph.edges // new edges\n );\n\n // create lookup tables\n\n this.graphData.nodesById = graph.nodes;\n this.graphData.edgesById = graph.edges;\n\n // TODO: that's a performance killer. this should be loaded when\n // the search is actually used!\n // update: Careful when refactoring, some modules are using this…\n _utils2.default.setField('$:/temp/tmap/nodes/' + this.view.getLabel(), 'list', $tm.adapter.getTiddlersByIds(graph.nodes));\n\n $tm.stop('Reloading Network');\n\n return { changedEdges: changedEdges, changedNodes: changedNodes };\n }\n }, {\n key: 'isViewBound',\n value: function isViewBound() {\n\n return _utils2.default.startsWith(this.getViewHolderRef(), $tm.path.localHolders);\n }\n\n /**\n * A view is switched, if the holder was changed.\n * Also if a view suddenly doesn't exist anymore we consider this\n * a trigger for a view change.\n */\n\n }, {\n key: 'isViewSwitched',\n value: function isViewSwitched(changedTiddlers) {\n\n return !_ViewAbstraction2.default.exists(this.view) || changedTiddlers[this.getViewHolderRef()];\n }\n\n /**\n * A view is switched, if the holder was changed.\n */\n\n }, {\n key: 'hasChangedAttributes',\n value: function hasChangedAttributes() {\n\n return Object.keys(this.computeAttributes()).length;\n }\n\n /**\n * Rebuild or update the graph if one of the following is true:\n *\n * 1. A tiddler currently contained as node in the graph has been\n * deleted or modified. This also includes tiddlers that are\n * represented as neighbours in the graph.\n * 2. The neighbourhood is shown and a non-system tiddler has changed.\n * 3. A tiddler that matches the node filter has been modified\n * (not deleted).\n *\n * Since edges are stored in tiddlers themselves, any edge modification\n * is always accounted for as in this case the tiddler holding the\n * edge would be included as changed tiddler.\n *\n * @param {Hashmap<TiddlerReference, *>} changedTiddlers - A list of\n * tiddler changes.\n *\n * @return {boolean} true if the graph needs a refresh.\n */\n\n }, {\n key: 'hasChangedElements',\n value: function hasChangedElements(changedTiddlers) {\n\n var maybeMatches = [];\n var inGraph = this.graphData.nodesById;\n var isShowNeighbourhood = this.view.isEnabled('neighbourhood_scope');\n\n for (var tRef in changedTiddlers) {\n\n if (_utils2.default.isSystemOrDraft(tRef)) {\n\n continue;\n }\n\n if (inGraph[$tm.adapter.getId(tRef)] || isShowNeighbourhood) {\n\n return true;\n }\n\n if (changedTiddlers[tRef].modified) {\n // may be a match so we store this and process it later\n maybeMatches.push(tRef);\n }\n }\n\n if (maybeMatches.length) {\n\n var nodeFilter = this.view.getNodeFilter('compiled');\n var matches = _utils2.default.getMatches(nodeFilter, maybeMatches);\n\n return !!matches.length;\n }\n }\n\n /**\n * Rebuild the graph\n *\n * @see http://visjs.org/docs/network.html\n * @see http://visjs.org/docs/dataset.html\n */\n\n }, {\n key: 'initAndRenderGraph',\n value: function initAndRenderGraph(parent) {\n var _this3 = this;\n\n // make sure to destroy any previous instance\n if (this.network) {\n this._destructVis();\n }\n\n this.logger('info', 'Initializing and rendering the graph');\n\n if (!this.isInSidebar) {\n this.callbackManager.add('$:/state/sidebar', this.handleResizeEvent);\n }\n\n this.visOptions = this.getVisOptions();\n\n this.graphData = {\n nodes: new _vis2.default.DataSet(),\n edges: new _vis2.default.DataSet(),\n nodesById: _utils2.default.makeHashMap(),\n edgesById: _utils2.default.makeHashMap()\n };\n\n this.tooltip.setEnabled(_utils2.default.isTrue($tm.config.sys.popups.enabled, true));\n\n this.network = new _vis2.default.Network(parent, this.graphData, this.visOptions);\n // after vis.Network has been instantiated, we fetch a reference to\n // the canvas element\n this.canvas = parent.getElementsByTagName('canvas')[0];\n this.networkDomNode = _utils2.default.getFirstElementByClassName('vis-network', parent, true);\n // just to be sure\n this.canvas.tabIndex = 0;\n\n for (var event in this.visListeners) {\n this.network.on(event, this.visListeners[event].bind(this));\n }\n\n this.addGraphButtons({\n 'fullscreen-button': function fullscreenButton() {\n _this3.toggleEnlargedMode('fullscreen');\n },\n 'halfscreen-button': function halfscreenButton() {\n _this3.toggleEnlargedMode('halfscreen');\n }\n });\n\n _utils2.default.setDomListeners('add', this.canvas, this.canvasDomListeners);\n\n this.reloadBackgroundImage();\n this.rebuildGraph({\n resetFocus: { delay: 0, duration: 0 }\n });\n this.handleResizeEvent();\n this.canvas.focus();\n }\n }, {\n key: 'handleCanvasKeyup',\n value: function handleCanvasKeyup(ev) {\n var _this4 = this;\n\n var nodeIds = this.network.getSelectedNodes();\n\n // this.isCtrlKeyDown = ev.ctrlKey;\n\n if (ev.ctrlKey) {\n // ctrl key is hold down\n ev.preventDefault();\n\n if (ev.keyCode === 88) {\n // x\n if (this.editorMode) {\n this.handleAddNodesToClipboard('move');\n } else {\n $tm.notify('Map is read only!');\n }\n } else if (ev.keyCode === 67) {\n // c\n this.handleAddNodesToClipboard('copy');\n } else if (ev.keyCode === 86) {\n // v\n this.handlePasteNodesFromClipboard();\n } else if (ev.keyCode === 65) {\n // a\n var allNodes = Object.keys(this.graphData.nodesById);\n this.network.selectNodes(allNodes);\n } else if (ev.keyCode === 49 || ev.keyCode === 50) {\n // 1 || 2\n if (nodeIds.length !== 1) return;\n\n var role = ev.keyCode === 49 ? 'from' : 'to';\n $tm.notify(_utils2.default.ucFirst(role) + '-part selected');\n\n this.conVector[role] = nodeIds[0];\n if (this.conVector.from && this.conVector.to) {\n // create the edge\n this.handleConnectionEvent(this.conVector, function () {\n // reset both properties, regardless whether confirmed\n _this4.conVector = { from: null, to: null };\n });\n }\n }\n } else {\n // ctrl is not pressed\n\n if (ev.keyCode === 13) {\n // ENTER\n\n if (nodeIds.length !== 1) return;\n\n this.openTiddlerWithId(nodeIds[0]);\n }\n }\n }\n }, {\n key: 'handleCanvasKeydown',\n value: function handleCanvasKeydown(ev) {\n\n if (ev.keyCode === 46) {\n // delete\n ev.preventDefault();\n this.handleRemoveElements(this.network.getSelection());\n }\n }\n }, {\n key: 'handleDeleteElement',\n value: function handleDeleteElement(ev) {\n\n var id = ev.paramObject.id;\n var elements = id ? [id] : this.network.getSelectedNodes();\n\n this.handleRemoveElements({ nodes: elements });\n }\n\n /**\n *\n * @param ev\n */\n\n }, {\n key: 'handleCanvasMouseMove',\n value: function handleCanvasMouseMove(ev) {\n var network = this.network;\n\n\n if (!(ev.ctrlKey && ev.buttons)) {\n\n if (this.selectRect) {\n this.selectRect = null;\n var _selectedNodes = network.getSelectedNodes();\n $tm.notify(_selectedNodes.length + ' nodes selected');\n network.redraw();\n }\n\n return;\n }\n\n // prevent vis' network drag if ctrl key and mouse button is pressed\n ev.preventDefault();\n ev.stopPropagation();\n\n if (!this.domNode.contains(ev.target)) {\n // since we are using a global mouse listener, we need to check whether\n // we are actually inside our widget, so we stop updating the selectRect\n return;\n }\n\n var mouse = network.DOMtoCanvas({ x: ev.offsetX, y: ev.offsetY });\n\n if (!this.selectRect) {\n this.selectRect = new _SelectionRectangle2.default(mouse.x, mouse.y);\n }\n\n // register new coordinates\n this.selectRect.span(mouse.x, mouse.y);\n // retrieve current mouse positions\n var nodePositions = network.getPositions();\n // we include previously selected nodes in the new set\n var selectedNodes = network.getSelectedNodes();\n\n for (var id in nodePositions) {\n\n if (this.selectRect.isPointWithin(nodePositions[id]) && !_utils2.default.inArray(id, selectedNodes)) {\n selectedNodes.push(id);\n }\n }\n\n network.selectNodes(selectedNodes);\n this.assignActiveStyle(selectedNodes);\n\n network.redraw();\n }\n\n //https://github.com/almende/vis/blob/111c9984bc4c1870d42ca96b45d90c13cb92fe0a/lib/network/modules/InteractionHandler.js\n\n }, {\n key: 'handleCanvasScroll',\n value: function handleCanvasScroll(ev) {\n\n var isZoomAllowed = !!(this.isInSidebar || // e.g. the map editor in the sidebar\n ev.ctrlKey || this.enlargedMode || this.clickToUse && this.networkDomNode.classList.contains('vis-active'));\n\n var interaction = this.visOptions.interaction;\n\n var isVisSettingInSync = isZoomAllowed === interaction.zoomView;\n\n if (isZoomAllowed || !isVisSettingInSync) {\n ev.preventDefault();\n }\n\n if (!isVisSettingInSync) {\n // prevent visjs from reacting to this event as we first need to sync states\n ev.stopPropagation();\n\n interaction.zoomView = isZoomAllowed;\n this.network.setOptions({ interaction: { zoomView: isZoomAllowed } });\n\n return false;\n }\n }\n\n /**\n * Called when the user click on the canvas with the right\n * mouse button. A context menu is opened.\n */\n\n }, {\n key: 'handleContextMenu',\n value: function handleContextMenu(ev) {\n var _this5 = this;\n\n ev.preventDefault();\n\n var network = this.network;\n\n\n this.hidePopups(0, true);\n\n var nodeId = network.getNodeAt({ x: ev.offsetX, y: ev.offsetY });\n if (!nodeId) return;\n\n // ids of selected nodes\n var selectedNodes = network.getSelectedNodes();\n\n if (!_utils2.default.inArray(nodeId, selectedNodes)) {\n // unselect other nodes and select this one instead…\n selectedNodes = [nodeId];\n network.selectNodes(selectedNodes);\n }\n\n this.contextMenu.show(selectedNodes, function (selectedNodes, div) {\n\n var mode = selectedNodes.length > 1 ? 'multi' : 'single';\n var tRef = '$:/plugins/felixhayashi/tiddlymap/editor/contextMenu/node';\n\n _utils2.default.registerTransclude(_this5, 'contextMenuWidget', tRef);\n _this5.contextMenuWidget.setVariable('mode', mode);\n _this5.contextMenuWidget.render(div);\n });\n }\n }, {\n key: 'handleWidgetKeyup',\n value: function handleWidgetKeyup(ev) {}\n }, {\n key: 'handleWidgetKeydown',\n value: function handleWidgetKeydown(ev) {\n\n if (ev.ctrlKey) {\n // ctrl key is hold down\n ev.preventDefault();\n\n if (ev.keyCode === 70) {\n // f\n ev.preventDefault();\n\n var focusButtonStateTRef = this.widgetPopupsPath + '/focus';\n _utils2.default.setText(focusButtonStateTRef, _utils2.default.getText(focusButtonStateTRef) ? '' : '1');\n\n // note: it is ok to focus the graph right after this,\n // if the focus button is activated it will steal the focus anyway\n } else {\n\n return;\n }\n } else if (ev.keyCode === 120) {\n // F9\n ev.preventDefault();\n this.toggleEnlargedMode('halfscreen');\n } else if (ev.keyCode === 121) {\n // F10\n ev.preventDefault();\n this.toggleEnlargedMode('fullscreen');\n } else if (ev.keyCode === 27) {\n // ESC\n ev.preventDefault();\n\n _utils2.default.deleteByPrefix(this.widgetPopupsPath);\n } else {\n return;\n }\n\n this.canvas.focus();\n }\n }, {\n key: 'handlePasteNodesFromClipboard',\n value: function handlePasteNodesFromClipboard() {\n\n if (!this.editorMode) {\n $tm.notify('Map is read only!');\n return;\n }\n\n if (!$tm.clipBoard || $tm.clipBoard.type !== 'nodes') {\n $tm.notify('TiddlyMap clipboad is empty!');\n }\n\n var nodes = $tm.clipBoard.nodes;\n var ids = Object.keys(nodes);\n\n for (var i = ids.length; i--;) {\n\n var id = ids[i];\n\n if (this.graphData.nodesById[id]) {\n // node already present in this view\n continue;\n }\n\n this.view.addNode(nodes[id]);\n\n // paste nodes so we can select them!\n this.graphData.nodes.update({ id: id });\n }\n\n this.network.selectNodes(ids);\n\n this.rebuildGraph({ resetFocus: { delay: 0, duration: 0 } });\n\n $tm.notify('pasted ' + ids.length + ' nodes into map.');\n }\n }, {\n key: 'handleAddNodesToClipboard',\n value: function handleAddNodesToClipboard(mode) {\n\n var nodeIds = this.network.getSelectedNodes();\n\n if (!nodeIds.length) {\n return;\n }\n\n $tm.clipBoard = {\n type: 'nodes',\n nodes: this.graphData.nodes.get(nodeIds, { returnType: 'Object' })\n };\n\n $tm.notify('Copied ' + nodeIds.length + ' nodes to clipboard');\n\n if (mode === 'move') {\n for (var i = nodeIds.length; i--;) {\n this.view.removeNode(nodeIds[i]);\n }\n }\n\n // prevent zoom\n this.isPreventZoomOnNextUpdate = true;\n }\n\n /**\n * @todo Instead of redrawing the whole graph when an edge or node is\n * added it may be worth considering only getting the element from the\n * adapter and directly inserting it into the graph and *avoid* a\n * reload of the graph via `rebuildGraph`!\n *\n * @todo: too much recomputation -> outsource\n */\n\n }, {\n key: 'getVisOptions',\n value: function getVisOptions() {\n var _this6 = this;\n\n // merge options\n var globalOptions = $tm.config.vis;\n var localOptions = _utils2.default.parseJSON(this.view.getConfig('vis'));\n var options = _utils2.default.merge({}, globalOptions, localOptions);\n\n options.clickToUse = this.clickToUse;\n options.manipulation.enabled = !!this.editorMode;\n\n options.manipulation.deleteNode = function (data, callback) {\n _this6.handleRemoveElements(data);\n _this6.resetVisManipulationBar(callback);\n };\n\n options.manipulation.deleteEdge = function (data, callback) {\n _this6.handleRemoveElements(data);\n _this6.resetVisManipulationBar(callback);\n };\n\n options.manipulation.addEdge = function (data, callback) {\n _this6.handleConnectionEvent(data);\n _this6.resetVisManipulationBar(callback);\n };\n\n options.manipulation.addNode = function (data, callback) {\n _this6.handleInsertNode(data);\n _this6.resetVisManipulationBar(callback);\n };\n\n options.manipulation.editNode = function (data, callback) {\n _this6.handleEditNode(data);\n _this6.resetVisManipulationBar(callback);\n };\n\n options.interaction.zoomView = !!(this.isInSidebar || this.enlargedMode);\n\n // not allowed\n options.manipulation.editEdge = false;\n\n // make sure the actual solver is an object\n var physics = options.physics;\n physics[physics.solver] = physics[physics.solver] || {};\n\n physics.stabilization.iterations = 1000;\n\n this.logger('debug', 'Loaded graph options', options);\n\n return options;\n }\n }, {\n key: 'resetVisManipulationBar',\n value: function resetVisManipulationBar(visCallback) {\n\n if (visCallback) {\n visCallback(null);\n }\n\n this.network.disableEditMode();\n this.network.enableEditMode();\n }\n }, {\n key: 'isVisInEditMode',\n value: function isVisInEditMode() {\n\n return this.graphDomNode.getElementsByClassName('vis-button vis-back').length > 0;\n }\n\n /**\n * Create an empty view. A dialog is opened that asks the user how to\n * name the view. The view is then registered as current view.\n */\n\n }, {\n key: 'handleCreateView',\n value: function handleCreateView() {\n var _this7 = this;\n\n var args = {\n view: this.view.getLabel()\n };\n\n $tm.dialogManager.open('createView', args, function (isConfirmed, outTObj) {\n\n if (!isConfirmed) return;\n\n var label = _utils2.default.getField(outTObj, 'name');\n var isClone = _utils2.default.getField(outTObj, 'clone', false);\n\n if (_ViewAbstraction2.default.exists(label)) {\n\n $tm.notify('Forbidden! View already exists!');\n\n return;\n }\n\n if (isClone && _this7.view.isLiveView()) {\n $tm.notify('Forbidden to clone the live view!');\n return;\n }\n\n var newView = new _ViewAbstraction2.default(label, {\n isCreate: true,\n protoView: isClone ? _this7.view : null\n });\n\n _this7.setView(newView);\n });\n }\n }, {\n key: 'handleRenameView',\n value: function handleRenameView() {\n var _this8 = this;\n\n if (this.view.isLocked()) {\n\n $tm.notify('Forbidden!');\n return;\n }\n\n var references = this.view.getOccurrences();\n\n var args = {\n count: references.length.toString(),\n refFilter: _utils2.default.joinAndWrap(references, '[[', ']]')\n };\n\n $tm.dialogManager.open('renameView', args, function (isConfirmed, outTObj) {\n\n if (!isConfirmed) {\n return;\n }\n\n var label = _utils2.default.getText(outTObj);\n\n if (!label) {\n\n $tm.notify('Invalid name!');\n } else if (_ViewAbstraction2.default.exists(label)) {\n\n $tm.notify('Forbidden! View already exists!');\n } else {\n\n _this8.view.rename(label);\n _this8.setView(_this8.view);\n }\n });\n }\n }, {\n key: 'handleEditView',\n value: function handleEditView() {\n var _this9 = this;\n\n var visInherited = JSON.stringify($tm.config.vis);\n var data = this.graphData;\n\n var viewConfig = this.view.getConfig();\n\n var preselects = {\n 'filter.prettyNodeFltr': this.view.getNodeFilter('pretty'),\n 'filter.prettyEdgeFltr': this.view.getEdgeTypeFilter('pretty'),\n 'vis-inherited': visInherited\n };\n\n var args = {\n view: this.view.getLabel(),\n createdOn: this.view.getCreationDate(true),\n numberOfNodes: Object.keys(data.nodesById).length.toString(),\n numberOfEdges: Object.keys(data.edgesById).length.toString(),\n dialog: {\n preselects: $tw.utils.extend({}, viewConfig, preselects)\n }\n };\n\n $tm.dialogManager.open('configureView', args, function (isConfirmed, outTObj) {\n\n if (!isConfirmed) {\n return;\n }\n\n var config = _utils2.default.getPropertiesByPrefix(outTObj.fields, 'config.', true);\n\n // ATTENTION: needs to be tested before applying new config!\n var prvBg = _this9.view.getConfig('background_image');\n\n _this9.view.setConfig(config);\n if (config['physics_mode'] && !_this9.view.isEnabled('physics_mode')) {\n // when not in physics mode, store positions\n // to prevent floating afterwards\n _this9.view.saveNodePositions(_this9.network.getPositions());\n }\n\n var curBg = _this9.view.getConfig('background_image');\n if (curBg && curBg !== prvBg) {\n $tm.notify('Background changed! You may need to zoom out a bit.');\n }\n\n var nf = _utils2.default.getField(outTObj, 'filter.prettyNodeFltr', '');\n var eTf = _utils2.default.getField(outTObj, 'filter.prettyEdgeFltr', '');\n\n _this9.view.setNodeFilter(nf);\n _this9.view.setEdgeTypeFilter(eTf);\n });\n }\n\n /**\n * Triggers a download dialog where the user can store the canvas\n * as png on his/her harddrive.\n */\n\n }, {\n key: 'handleSaveCanvas',\n value: function handleSaveCanvas() {\n var _this10 = this;\n\n var tempImagePath = '$:/temp/tmap/snapshot';\n this.createAndSaveSnapshot(tempImagePath);\n var defaultName = _utils2.default.getSnapshotTitle(this.view.getLabel(), 'png');\n\n var args = {\n dialog: {\n snapshot: tempImagePath,\n width: this.canvas.width.toString(),\n height: this.canvas.height.toString(),\n preselects: {\n name: defaultName,\n action: 'download'\n }\n }\n };\n\n $tm.dialogManager.open('saveCanvas', args, function (isConfirmed, outTObj) {\n if (!isConfirmed) return;\n\n // allow the user to override the default name or if name is\n // empty use the original default name\n defaultName = outTObj.fields.name || defaultName;\n\n var action = outTObj.fields.action;\n\n if (action === 'download') {\n _this10.handleDownloadSnapshot(defaultName);\n } else if (action === 'wiki') {\n _utils2.default.cp(tempImagePath, defaultName, true);\n _this10.dispatchEvent({\n type: 'tm-navigate', navigateTo: defaultName\n });\n } else if (action === 'placeholder') {\n _this10.view.addPlaceholder(tempImagePath);\n }\n\n // in any case\n $tw.wiki.deleteTiddler('$:/temp/tmap/snapshot');\n });\n }\n }, {\n key: 'handleDownloadSnapshot',\n value: function handleDownloadSnapshot(title) {\n\n var a = this.document.createElement('a');\n var label = this.view.getLabel();\n a.download = title || _utils2.default.getSnapshotTitle(label, 'png');\n a.href = this.getSnapshot();\n\n // we cannot simply call click() on <a>; chrome is cool with it but\n // firefox requires us to create a mouse event…\n var event = new MouseEvent('click');\n a.dispatchEvent(event);\n }\n }, {\n key: 'createAndSaveSnapshot',\n value: function createAndSaveSnapshot(title) {\n\n var tRef = title || this.view.getRoot() + '/snapshot';\n $tw.wiki.addTiddler(new $tw.Tiddler({\n title: tRef,\n type: 'image/png',\n text: this.getSnapshot(true),\n modified: new Date()\n }));\n\n return tRef;\n }\n }, {\n key: 'getSnapshot',\n value: function getSnapshot(stripPreamble) {\n\n var data = this.canvas.toDataURL('image/png');\n\n return stripPreamble ? _utils2.default.getWithoutPrefix(data, 'data:image/png;base64,') : data;\n }\n }, {\n key: 'handleDeleteView',\n value: function handleDeleteView() {\n var _this11 = this;\n\n var viewname = this.view.getLabel();\n\n if (this.view.isLocked()) {\n\n $tm.notify('Forbidden!');\n return;\n }\n\n // regex is non-greedy\n\n var references = this.view.getOccurrences();\n if (references.length) {\n\n var fields = {\n count: references.length.toString(),\n refFilter: _utils2.default.joinAndWrap(references, '[[', ']]')\n };\n\n $tm.dialogManager.open('cannotDeleteViewDialog', fields);\n\n return;\n }\n\n var message = '\\n You are about to delete the view \\'\\'' + viewname + '\\'\\'\\n (no tiddler currently references this view).\\n ';\n\n this.openStandardConfirmDialog(function (isConfirmed) {\n // TODO: this dialog needs an update\n\n if (!isConfirmed) {\n return;\n }\n\n _this11.view.destroy();\n _this11.setView($tm.misc.defaultViewLabel);\n var msg = 'view \"' + viewname + '\\' deleted';\n _this11.logger('debug', msg);\n $tm.notify(msg);\n }, message);\n }\n\n /**\n * This will rebuild the graph after a trigger has been activated.\n *\n * Prior to TiddlyMap v0.9, an additional check was performed\n * to verify, if the graph had actually changed before rebuilding\n * the graph. This check, however, was an overkill and as such removed.\n */\n\n }, {\n key: 'handleTriggeredRefresh',\n value: function handleTriggeredRefresh(trigger) {\n\n this.logger('log', trigger, 'Triggered a refresh');\n\n // special case for the live tab\n if (this.id === 'live_tab') {\n var curTiddler = _utils2.default.getTiddler(_utils2.default.getText(trigger));\n if (curTiddler) {\n var view = curTiddler.fields['tmap.open-view'] || $tm.config.sys.liveTab.fallbackView;\n if (view && view !== this.view.getLabel()) {\n this.setView(view);\n return;\n }\n }\n }\n\n this.rebuildGraph({\n resetFocus: {\n delay: 1000,\n duration: 1000\n }\n });\n }\n\n /**\n * Called by vis when the user tries to delete nodes or edges.\n * The action is delegated to subhandlers.\n *\n * @param {Array<Id>} nodes - Removed edges.\n * @param {Array<Id>} edges - Removed nodes.\n */\n\n }, {\n key: 'handleRemoveElements',\n value: function handleRemoveElements(_ref2) {\n var nodes = _ref2.nodes,\n edges = _ref2.edges;\n\n\n if (nodes.length) {\n // the adapter also removes edges when nodes are removed.\n this.handleRemoveNodes(nodes);\n } else if (edges.length) {\n this.handleRemoveEdges(edges);\n }\n\n this.resetVisManipulationBar();\n }\n }, {\n key: 'handleRemoveEdges',\n value: function handleRemoveEdges(edgeIds) {\n\n $tm.adapter.deleteEdges(this.graphData.edges.get(edgeIds));\n $tm.notify('edge' + (edgeIds.length > 1 ? 's' : '') + ' removed');\n }\n\n /**\n * Handler that guides the user through the process of deleting a node\n * from the graph. The nodes may be removed from the filter (if possible)\n * or from the system.\n *\n * Note: this should not trigger a zoom.\n */\n\n }, {\n key: 'handleRemoveNodes',\n value: function handleRemoveNodes(nodeIds) {\n var _this12 = this;\n\n var tiddlers = $tm.adapter.getTiddlersByIds(nodeIds);\n var params = {\n 'count': nodeIds.length.toString(),\n 'tiddlers': $tw.utils.stringifyList(tiddlers),\n dialog: {\n preselects: {\n 'delete-from': 'filter'\n }\n }\n };\n\n $tm.dialogManager.open('deleteNodeDialog', params, function (isConfirmed, outTObj) {\n\n if (!isConfirmed) return;\n\n var deletionCount = 0;\n\n for (var i = nodeIds.length; i--;) {\n var success = _this12.view.removeNode(nodeIds[i]);\n if (success) {\n deletionCount++;\n }\n }\n\n if (outTObj.fields['delete-from'] === 'system') {\n\n // will also delete edges\n $tm.adapter.deleteNodes(nodeIds);\n deletionCount = nodeIds.length; // we just say so ;)\n }\n\n // prevent zoom\n _this12.isPreventZoomOnNextUpdate = true;\n\n $tm.notify('\\n Removed ' + deletionCount + '\\n of ' + nodeIds.length + '\\n from ' + outTObj.fields['delete-from'] + '\\n ');\n });\n }\n\n /**\n * Calling this function will toggle the enlargement of the map\n * instance. Markers need to be added at various places to ensure the\n * map stretches properly. This includes marking ancestor dom nodes\n * to be able to shift the stacking context.\n *\n * @param {string} type - either 'halfscreen' or 'fullscreen'.\n */\n\n }, {\n key: 'toggleEnlargedMode',\n value: function toggleEnlargedMode(type) {\n\n if (!this.isInSidebar && type === 'halfscreen') {\n return;\n }\n\n this.logger('log', 'Toggled graph enlargement');\n\n var enlargedMode = this.enlargedMode;\n\n // in any case, exit enlarged mode if active\n if (enlargedMode) {\n\n // reset click to use\n this.network.setOptions({ clickToUse: this.clickToUse });\n\n // remove markers\n _utils2.default.findAndRemoveClassNames(['tmap-has-' + enlargedMode + '-widget', 'tmap-' + enlargedMode]);\n\n // reset flag\n this.enlargedMode = null;\n document.body.scrollTop = this.scrollTop;\n }\n\n if (!enlargedMode || enlargedMode !== type && (type === 'fullscreen' || type === 'halfscreen' && !this.isInSidebar)) {\n\n this.scrollTop = document.body.scrollTop;\n\n this.enlargedMode = type;\n\n var pContainer = this.isInSidebar ? this.sidebar : _utils2.default.getFirstElementByClassName('tc-story-river');\n\n $tw.utils.addClass(this.document.body, 'tmap-has-' + type + '-widget');\n $tw.utils.addClass(pContainer, 'tmap-has-' + type + '-widget');\n $tw.utils.addClass(this.domNode, 'tmap-' + type);\n\n // disable click to use by force\n this.network.setOptions({ clickToUse: false });\n\n $tm.notify('Toggled ' + type + ' mode');\n }\n\n // always do resize\n this.handleResizeEvent();\n }\n }, {\n key: 'handleGenerateWidget',\n value: function handleGenerateWidget(event) {\n\n $tw.rootWidget.dispatchEvent({\n type: 'tmap:tm-generate-widget',\n paramObject: { view: this.view.getLabel() }\n });\n }\n }, {\n key: 'handleSetCentralTopic',\n value: function handleSetCentralTopic(_ref3) {\n var paramObject = _ref3.paramObject;\n\n\n var nodeId = paramObject.id || this.network.getSelectedNodes()[0];\n\n if (nodeId === this.view.getConfig('central-topic')) {\n nodeId = '';\n }\n\n this.view.setCentralTopic(nodeId);\n }\n\n /**\n * Called by vis when the graph has stabilized itself.\n *\n * ATTENTION: never store positions in a view's map during stabilize\n * as this will affect other graphs positions and will cause recursion!\n * Storing positions inside vis' nodes is fine though\n */\n\n }, {\n key: 'handleVisStabilizedEvent',\n value: function handleVisStabilizedEvent(properties) {\n\n if (this.hasNetworkStabilized) {\n return;\n }\n\n this.hasNetworkStabilized = true;\n this.logger('log', 'Network stabilized after', properties.iterations, 'iterations');\n\n if (!this.view.isEnabled('physics_mode')) {\n // static mode\n\n // store positions if new nodes without position were added\n var nodes = this.graphData.nodesById;\n var idsOfNodesWithoutPosition = [];\n\n for (var id in nodes) {\n if (nodes[id].x === undefined) {\n idsOfNodesWithoutPosition.push(id);\n }\n }\n\n if (idsOfNodesWithoutPosition.length) {\n this.setNodesMoveable(idsOfNodesWithoutPosition, false);\n $tm.notify(idsOfNodesWithoutPosition.length + ' nodes were added to the graph');\n }\n\n // after storing positions, set gravity to zero again\n var physics = this.visOptions.physics;\n physics[physics.solver].centralGravity = 0;\n this.network.setOptions(this.visOptions);\n }\n\n if (this.resetFocus) {\n this.fitGraph(this.resetFocus.delay, this.resetFocus.duration);\n this.resetFocus = null;\n }\n }\n\n /**\n * Zooms on a specific node in the graph\n */\n\n }, {\n key: 'handleFocusNode',\n value: function handleFocusNode(_ref4) {\n var tRef = _ref4.param;\n\n\n this.network.focus($tm.adapter.getId(tRef), {\n scale: 1.5,\n animation: true\n });\n }\n\n /**\n * A zombie widget is a widget that is removed from the dom tree\n * but still referenced or still partly executed -- I mean\n * otherwise you couldn't call this function, right?\n *\n * If TiddlyMap is executed in a fake environment, the function\n * always returns true.\n */\n\n }, {\n key: 'isZombieWidget',\n value: function isZombieWidget() {\n\n return this.domNode.isTiddlyWikiFakeDom === true || !this.document.body.contains(this.getContainer());\n }\n\n /**\n * This method allows us to specify after what time and for how long\n * the zoom-to-fit process should be executed for a graph.\n *\n * @param {number} [delay=0] - How long to wait before starting to zoom.\n * @param {number} [duration=0] - After the delay, how long should it\n * take for the graph to be zoomed.\n */\n\n }, {\n key: 'fitGraph',\n value: function fitGraph() {\n var _this13 = this;\n\n var delay = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;\n var duration = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n\n\n // clear any existing fitting attempt\n clearTimeout(this.activeFitTimeout);\n\n var fit = function fit() {\n\n // happens when widget is removed after stabilize but before fit\n if (_this13.isZombieWidget()) {\n return;\n }\n\n // fixes #97\n _this13.network.redraw();\n\n _this13.network.fit({ // v4: formerly zoomExtent\n animation: {\n duration: duration,\n easingFunction: 'easeOutQuart'\n }\n });\n };\n\n this.activeFitTimeout = setTimeout(fit, delay);\n }\n\n /**\n * Spawns a dialog in which the user can specify node attributes.\n * Once the dialog is closed, the node is inserted into the current\n * view, unless the operation was cancelled.\n */\n\n }, {\n key: 'handleInsertNode',\n value: function handleInsertNode(node) {\n var _this14 = this;\n\n $tm.dialogManager.open('addNodeToMap', {}, function (isConfirmed, outTObj) {\n\n if (!isConfirmed) {\n return;\n }\n\n var tRef = _utils2.default.getField(outTObj, 'draft.title');\n\n if (_utils2.default.tiddlerExists(tRef)) {\n\n // Todo: use graphData and test if node is match (!=neighbour)\n if (_utils2.default.isMatch(tRef, _this14.view.getNodeFilter('compiled'))) {\n\n $tm.notify('Node already exists');\n\n return;\n } else {\n\n node = $tm.adapter.makeNode(tRef, node);\n _this14.view.addNode(node);\n }\n } else {\n\n var tObj = new $tw.Tiddler(outTObj, { 'draft.title': null });\n\n node.label = tRef;\n $tm.adapter.insertNode(node, _this14.view, tObj);\n }\n\n // prevent zoom\n _this14.isPreventZoomOnNextUpdate = true;\n });\n }\n\n /**\n * Open the node editor to style the node.\n */\n\n }, {\n key: 'handleEditNode',\n value: function handleEditNode(node) {\n var _this15 = this;\n\n var tRef = $tm.tracker.getTiddlerById(node.id);\n var tObj = _utils2.default.getTiddler(tRef);\n var globalDefaults = JSON.stringify($tm.config.vis);\n var localDefaults = this.view.getConfig('vis');\n var nodes = {};\n nodes[node.id] = node;\n var nodeStylesByTRef = $tm.adapter.getInheritedNodeStyles(nodes);\n var groupStyles = JSON.stringify(nodeStylesByTRef[tRef]);\n var globalNodeStyle = JSON.stringify(_utils2.default.merge({}, { color: tObj.fields['color'] }, _utils2.default.parseJSON(tObj.fields['tmap.style'])));\n\n var viewLabel = this.view.getLabel();\n\n // we copy the object since we intend to modify it.\n // NOTE: A deep copy would be needed if a nested property were modified\n // In that case, use $tw.utils.deepCopy.\n var nodeData = _extends({}, this.view.getNodeData(node.id));\n // we need to delete the positions so they are not reset when a user\n // resets the style…\n delete nodeData.x;\n delete nodeData.y;\n\n var args = {\n 'view': viewLabel,\n 'tiddler': tObj.fields.title,\n 'tidColor': tObj.fields['color'],\n 'tidIcon': tObj.fields[$tm.field.nodeIcon] || tObj.fields['tmap.fa-icon'],\n 'tidLabelField': 'global.' + $tm.field.nodeLabel,\n 'tidIconField': 'global.' + $tm.field.nodeIcon,\n dialog: {\n preselects: {\n 'inherited-global-default-style': globalDefaults,\n 'inherited-local-default-style': localDefaults,\n 'inherited-group-styles': groupStyles,\n 'global.tmap.style': globalNodeStyle,\n 'local-node-style': JSON.stringify(nodeData)\n }\n }\n };\n\n // function to iterate over attributes that shall be available\n // in the dialog.\n var addToPreselects = function addToPreselects(scope, store, keys) {\n for (var i = keys.length; i--;) {\n args.dialog.preselects[scope + '.' + keys[i]] = store[keys[i]] || '';\n }\n };\n\n // local values are retrieved from the view's node data store\n addToPreselects('local', nodeData, ['label', 'tw-icon', 'fa-icon', 'open-view']);\n\n // global values are taken from the tiddler's field object\n addToPreselects('global', tObj.fields, [$tm.field.nodeLabel, $tm.field.nodeIcon, 'tmap.fa-icon', 'tmap.open-view']);\n\n $tm.dialogManager.open('editNode', args, function (isConfirmed, outTObj) {\n\n if (!isConfirmed) return;\n\n var fields = outTObj.fields;\n\n // save or remove global individual style\n var global = _utils2.default.getPropertiesByPrefix(fields, 'global.', true);\n for (var p in global) {\n\n _utils2.default.setField(tRef, p, global[p] || undefined);\n }\n\n // save local individual data (style + config)\n var local = _utils2.default.getPropertiesByPrefix(fields, 'local.', true);\n\n // CAREFUL: Never change 'local-node-style' to 'local.node-style'\n // (with a dot) because it will get included in the loop!\n var data = _utils2.default.parseJSON(fields['local-node-style'], {});\n\n for (var _p in local) {\n data[_p] = local[_p] || undefined;\n }\n\n _this15.view.saveNodeStyle(node.id, data);\n\n _this15.isPreventZoomOnNextUpdate = true;\n });\n }\n\n /**\n * This handler is registered at and called by the vis network event\n * system.\n */\n\n }, {\n key: 'handleVisSingleClickEvent',\n value: function handleVisSingleClickEvent(properties) {\n\n var isActivated = _utils2.default.isTrue($tm.config.sys.singleClickMode);\n if (isActivated && !this.editorMode) {\n this.handleOpenMapElementEvent(properties);\n }\n }\n\n /**\n * This handler is registered at and called by the vis network event\n * system.\n *\n * @see Coordinates not passed on click/tap events within the properties object\n * @see https://github.com/almende/vis/issues/440\n *\n * @properties a list of nodes and/or edges that correspond to the\n * click event.\n */\n\n }, {\n key: 'handleVisDoubleClickEvent',\n value: function handleVisDoubleClickEvent(properties) {\n\n if (properties.nodes.length || properties.edges.length) {\n\n if (this.editorMode || !_utils2.default.isTrue($tm.config.sys.singleClickMode)) {\n\n this.handleOpenMapElementEvent(properties);\n }\n } else {\n // = clicked on an empty spot\n\n if (this.editorMode) {\n this.handleInsertNode(properties.pointer.canvas);\n }\n }\n }\n }, {\n key: 'handleOpenMapElementEvent',\n value: function handleOpenMapElementEvent(_ref5) {\n var nodes = _ref5.nodes,\n edges = _ref5.edges;\n\n\n if (nodes.length) {\n // clicked on a node\n\n var node = this.graphData.nodesById[nodes[0]];\n if (node['open-view']) {\n $tm.notify('Switching view');\n this.setView(node['open-view']);\n } else {\n this.openTiddlerWithId(nodes[0]);\n }\n } else if (edges.length) {\n // clicked on an edge\n\n this.logger('debug', 'Clicked on an Edge');\n var typeId = this.graphData.edgesById[edges[0]].type;\n this.handleEditEdgeType(typeId);\n } else {\n\n return;\n }\n\n this.hidePopups(0, true);\n }\n }, {\n key: 'handleEditEdgeType',\n value: function handleEditEdgeType(type) {\n\n if (!this.editorMode) return;\n\n var behaviour = $tm.config.sys.edgeClickBehaviour;\n if (behaviour !== 'manager') return;\n\n $tw.rootWidget.dispatchEvent({\n type: 'tmap:tm-manage-edge-types',\n paramObject: {\n type: type\n }\n });\n }\n }, {\n key: 'handleResizeEvent',\n\n\n /**\n * Listener will be removed if the parent is not part of the dom anymore\n *\n * @see https://groups.google.com/d/topic/tiddlywikidev/yuQB1KwlKx8/discussion [TW5] Is there a destructor for widgets?\n * @see https://developer.mozilla.org/en-US/docs/Web/API/Node.contains\n */\n value: function handleResizeEvent(event) {\n\n if (this.isZombieWidget()) return;\n\n var height = this.getAttr('height');\n var width = this.getAttr('width');\n\n if (this.isInSidebar) {\n\n var rect = this.domNode.getBoundingClientRect();\n var distRight = 15;\n width = document.body.clientWidth - rect.left - distRight + 'px';\n\n var distBottom = parseInt(this.getAttr('bottom-spacing')) || 15;\n var calculatedHeight = window.innerHeight - rect.top;\n height = calculatedHeight - distBottom + 'px';\n }\n\n this.domNode.style.height = height || '300px';\n this.domNode.style.width = width;\n\n this.repaintGraph(); // redraw graph\n }\n\n /**\n * used to prevent nasty deletion as edges are not unselected when leaving vis\n */\n\n }, {\n key: 'handleClickEvent',\n value: function handleClickEvent(evt) {\n\n if (this.isZombieWidget() || !this.network) return;\n\n if (!this.graphDomNode.contains(evt.target)) {\n // clicked outside\n\n var selected = this.network.getSelection();\n if (selected.nodes.length || selected.edges.length) {\n this.logger('debug', 'Clicked outside; deselecting nodes/edges');\n // upstream bug: this.network.unselectAll() doesn't work\n this.network.selectNodes([]); // deselect nodes and edges\n this.resetVisManipulationBar();\n }\n } else {\n\n this.canvas.focus();\n }\n\n if (evt.button !== 2) {\n // not the right button\n this.contextMenu.hide(0, true);\n }\n }\n }, {\n key: 'handleVisSelectNode',\n value: function handleVisSelectNode(_ref6) {\n var nodes = _ref6.nodes;\n\n\n if (!this.isDraggingAllowed(nodes)) {\n return;\n }\n\n // assign selected style\n this.assignActiveStyle(nodes);\n }\n }, {\n key: 'isDraggingAllowed',\n value: function isDraggingAllowed(_ref7) {\n var nodes = _ref7.nodes;\n\n return this.editorMode || this.view.isEnabled('physics_mode');\n }\n\n /**\n * Assign some styles when the graph element becomes active, i.e.\n * it is selected or hovered over.\n *\n * @param {Id|Array<Id>} nodeIds - A single id or an Array of ids.\n */\n\n }, {\n key: 'assignActiveStyle',\n value: function assignActiveStyle(nodeIds) {\n\n if (!Array.isArray(nodeIds)) nodeIds = [nodeIds];\n\n var defaultColor = this.visOptions.nodes.color;\n\n // iterate over selected nodes\n for (var i = nodeIds.length; i--;) {\n var id = nodeIds[i];\n var node = this.graphData.nodesById[id];\n var colorObj = _utils2.default.merge({}, defaultColor, node.color);\n this.graphData.nodes.update({\n id: id,\n color: {\n highlight: colorObj,\n hover: colorObj\n }\n });\n }\n }\n }, {\n key: 'handleVisDeselectNode',\n value: function handleVisDeselectNode(properties) {}\n\n //~ var prevSelectedNodes = properties.previousSelection.nodes;\n //~ for (var i = prevSelectedNodes.length; i--;) {\n //~ };\n\n /**\n * Called by vis when the dragging of a node(s) has ended.\n * Vis passes an object containing event-related information.\n *\n * @param {Array<Id>} nodes - Array of ids of the nodes\n * that were being dragged.\n */\n\n }, {\n key: 'handleVisDragEnd',\n value: function handleVisDragEnd(_ref8) {\n var nodes = _ref8.nodes;\n\n\n if (!nodes.length) {\n return;\n }\n\n if (nodes.length === 1 && this.view.isEnabled('raster')) {\n var pos = this.network.getPositions()[nodes[0]];\n this.graphData.nodes.update(_extends({\n id: nodes[0]\n }, _utils2.default.getNearestRasterPosition(pos, parseInt(this.view.getConfig('raster')))));\n }\n\n // reset store\n this.draggedNode = null;\n\n // fix node again and store positions\n // if in static mode, fixing will be ignored\n this.setNodesMoveable(nodes, false);\n }\n\n /**\n *\n * @param context2d\n */\n\n }, {\n key: 'handleVisBeforeDrawing',\n value: function handleVisBeforeDrawing(context2d) {\n var view = this.view,\n network = this.network,\n backgroundImage = this.backgroundImage;\n\n\n if (backgroundImage) {\n context2d.drawImage(backgroundImage, 0, 0);\n }\n\n if (view.isEnabled('raster')) {\n _utils2.default.drawRaster(context2d, network.getScale(), network.getViewPosition(), parseInt(view.getConfig('raster')));\n }\n }\n\n /**\n *\n * @param context2d\n */\n\n }, {\n key: 'handleVisAfterDrawing',\n value: function handleVisAfterDrawing(context2d) {\n\n if (this.selectRect) {\n\n var rect = this.selectRect.getRect();\n\n context2d.beginPath();\n context2d.globalAlpha = 0.5;\n context2d.fillStyle = '#EAFFEF';\n context2d.fillRect.apply(context2d, _toConsumableArray(rect));\n\n context2d.beginPath();\n context2d.globalAlpha = 1;\n context2d.strokeStyle = '#B4D9BD';\n context2d.strokeRect.apply(context2d, _toConsumableArray(rect));\n }\n\n if (this.draggedNode && this.view.isEnabled('raster')) {\n\n var pos = this.network.getPositions()[this.draggedNode];\n var rPos = _utils2.default.getNearestRasterPosition(pos, parseInt(this.view.getConfig('raster')));\n\n context2d.strokeStyle = 'green';\n context2d.fillStyle = 'green';\n\n context2d.beginPath();\n context2d.moveTo(pos.x, pos.y);\n context2d.lineTo(rPos.x, rPos.y);\n context2d.stroke();\n context2d.beginPath();\n context2d.arc(rPos.x, rPos.y, 5, 0, Math.PI * 2);\n context2d.fill();\n }\n }\n\n /**\n * called by tooltip class when tooltip is displayed;\n */\n\n }, {\n key: 'constructTooltip',\n value: function constructTooltip(signature, div) {\n\n var ev = _utils2.default.parseJSON(signature);\n var id = ev.node || ev.edge;\n\n var text = null;\n var outType = 'text/html';\n var inType = 'text/vnd-tiddlywiki';\n\n if (ev.node) {\n // node\n\n var tRef = $tm.tracker.getTiddlerById(id);\n var tObj = _utils2.default.getTiddler(tRef);\n\n var descr = tObj.fields[$tm.field.nodeInfo];\n\n if (descr) {\n\n div.innerHTML = $tw.wiki.renderText(outType, inType, descr);\n } else if (tObj.fields.text) {\n\n // simply rendering the text is not sufficient as this prevents\n // us from updating the tooltip content on refresh. So we need\n // to create a temporary widget that is registered to the dom\n // node passed by the tooltip.\n\n _utils2.default.registerTransclude(this, 'tooltipWidget', tRef);\n this.tooltipWidget.setVariable('tv-tiddler-preview', 'yes');\n this.tooltipWidget.render(div);\n } else {\n\n div.innerHTML = tRef;\n }\n } else {\n // edge\n\n var edge = this.graphData.edgesById[id];\n var type = $tm.indeces.allETy[edge.type];\n\n if (type.description) {\n text = $tw.wiki.renderText(outType, inType, type.description);\n }\n\n div.innerHTML = text || type.label || type.id;\n }\n }\n }, {\n key: 'handleVisHoverElement',\n value: function handleVisHoverElement(ev) {\n\n if ($tm.mouse.buttons) return;\n\n //~ this.graphDomNode.style.cursor = 'pointer';\n\n var id = ev.node || ev.edge;\n var signature = JSON.stringify(ev);\n\n if (ev.node) {\n\n // override the hover color\n this.assignActiveStyle(id);\n }\n\n // show tooltip if not in edit mode\n if (!this.isVisInEditMode() && !this.contextMenu.isShown()) {\n var populator = this.constructTooltip;\n this.tooltip.show(signature, populator);\n }\n }\n }, {\n key: 'handleVisBlurElement',\n value: function handleVisBlurElement(ev) {\n\n this.tooltip.hide();\n }\n }, {\n key: 'handleVisLoading',\n value: function handleVisLoading(_ref9) {\n var total = _ref9.total,\n iterations = _ref9.iterations;\n\n\n // we only start to show the progress bar after a while\n //~ if (params.iterations / params.total < 0.05) return;\n\n this.graphLoadingBarDomNode.style.display = 'block';\n this.graphLoadingBarDomNode.setAttribute('max', total);\n this.graphLoadingBarDomNode.setAttribute('value', iterations);\n\n //~ var text = 'Loading ' + Math.round((iterations / total) * 100) + '%';\n //~ this.graphLoadingBarDomNode.innerHTML = text;\n }\n }, {\n key: 'handleVisLoadingDone',\n value: function handleVisLoadingDone(params) {\n\n this.graphLoadingBarDomNode.style.display = 'none';\n }\n\n /**\n * Called by vis when a node is being dragged.\n * Vis passes an object containing event-related information.\n * @param {Array<Id>} nodes - Array of ids of the nodes\n * that were being dragged.\n */\n\n }, {\n key: 'handleVisDragStart',\n value: function handleVisDragStart(_ref10) {\n var nodes = _ref10.nodes;\n\n\n if (!nodes.length ||\n // we do not allow nodes to be dragged if not in editor mode\n // except cases physics is enabled\n !this.isDraggingAllowed(nodes)) {\n return;\n }\n\n this.hidePopups(0, true);\n this.assignActiveStyle(nodes);\n this.setNodesMoveable(nodes, true);\n\n if (nodes.length === 1) {\n this.draggedNode = nodes[0];\n }\n }\n\n /**\n * called from outside.\n */\n\n }, {\n key: 'destruct',\n value: function destruct() {\n\n // while the container should be destroyed and the listeners\n // garbage collected, we remove them manually just to be save\n\n _utils2.default.setDomListeners('remove', window, this.windowDomListeners);\n _utils2.default.setDomListeners('remove', this.domNode, this.widgetDomListeners);\n\n this._destructVis();\n }\n\n /**\n * Only destructs stuff related to vis.\n */\n\n }, {\n key: '_destructVis',\n value: function _destructVis() {\n\n if (!this.network) return;\n\n _utils2.default.setDomListeners('remove', this.canvas, this.canvasDomListeners);\n\n this.network.destroy();\n this.network = null;\n }\n\n /**\n * Opens the tiddler that corresponds to the given id either as\n * modal (when in fullscreen mode) or in the story river.\n */\n\n }, {\n key: 'openTiddlerWithId',\n value: function openTiddlerWithId(id) {\n var _this16 = this;\n\n var tRef = $tm.tracker.getTiddlerById(id);\n\n this.logger('debug', 'Opening tiddler', tRef, 'with id', id);\n\n if (this.enlargedMode === 'fullscreen') {\n\n var draftTRef = $tw.wiki.findDraft(tRef);\n var wasInDraftAlready = !!draftTRef;\n\n if (!wasInDraftAlready) {\n\n var type = 'tm-edit-tiddler';\n this.dispatchEvent({ type: type, tiddlerTitle: tRef });\n draftTRef = $tw.wiki.findDraft(tRef);\n }\n\n var args = { draftTRef: draftTRef, originalTRef: tRef };\n\n $tm.dialogManager.open('fullscreenTiddlerEditor', args, function (isConfirmed, outTObj) {\n\n if (isConfirmed) {\n\n var _type = 'tm-save-tiddler';\n _this16.dispatchEvent({ type: _type, tiddlerTitle: draftTRef });\n } else if (!wasInDraftAlready) {\n\n // also removes the draft from the river before deletion!\n _utils2.default.deleteTiddlers([draftTRef]);\n }\n\n // in any case, remove the original tiddler from the river\n var type = 'tm-close-tiddler';\n _this16.dispatchEvent({ type: type, tiddlerTitle: tRef });\n });\n } else {\n\n var bounds = this.domNode.getBoundingClientRect();\n\n this.dispatchEvent({\n type: 'tm-navigate',\n navigateTo: tRef,\n navigateFromTitle: this.getVariable('storyTiddler'),\n navigateFromNode: this,\n navigateFromClientRect: {\n top: bounds.top,\n left: bounds.left,\n width: bounds.width,\n right: bounds.right,\n bottom: bounds.bottom,\n height: bounds.height\n }\n });\n }\n }\n\n /**\n * The view holder is a tiddler that stores a references to the current\n * view. If the graph is not bound to a view by the user via an\n * attribute, the default view holder is used. Otherwise, a temporary\n * holder is created whose value is set to the view specified by the user.\n * This way, the graph is independent from view changes made in a\n * tiddlymap editor.\n *\n * This function will only calculate a new reference to the holder\n * on first call (that is when no view holder is registered to 'this'.\n *\n */\n\n }, {\n key: 'getViewHolderRef',\n value: function getViewHolderRef() {\n\n // the viewholder is never recalculated once it exists\n if (this.viewHolderRef) {\n return this.viewHolderRef;\n }\n\n this.logger('info', 'Retrieving or generating the view holder reference');\n\n // if given, try to retrieve the viewHolderRef by specified attribute\n var viewName = this.getAttr('view');\n var holderRef = null;\n\n if (viewName) {\n\n this.logger('log', 'User wants to bind view \"' + viewName + '\\' to graph');\n\n var viewRef = $tm.path.views + '/' + viewName;\n\n if ($tw.wiki.getTiddler(viewRef)) {\n\n // create a view holder that is exclusive for this graph\n\n holderRef = $tm.path.localHolders + '/' + _utils2.default.genUUID();\n this.logger('log', 'Created an independent temporary view holder \"' + holderRef + '\"');\n\n // we do not use setView here because it would store and reload the view unnecessarily...\n _utils2.default.setText(holderRef, viewRef);\n\n this.logger('log', 'View \"' + viewRef + '\\' inserted into independend holder');\n } else {\n this.logger('log', 'View \"' + viewName + '\" does not exist');\n }\n }\n\n if (!holderRef) {\n this.logger('log', 'Using default (global) view holder');\n holderRef = $tm.ref.defaultViewHolder;\n }\n\n return holderRef;\n }\n\n /**\n * This function will switch the current view reference of the\n * view holder.\n *\n * NOTE:\n * The changes will be picked up in the next refresh cycle.\n * This function will never update the view object currently\n * held by this widget (this.view)! This would create a race\n * condition where the view has changed, but the graph data hasn't\n * and maybe a stabilization event fires in this moment. At this point\n * it would work with graph data that doesn't relate to the view\n * and do bad things, trust me, big time bad things.\n *\n * @param {ViewAbstraction|string} view – A reference to the view.\n * @param {string} [viewHolderRef] – A reference to the view holder.\n */\n\n }, {\n key: 'setView',\n value: function setView(view, viewHolderRef) {\n\n if (!_ViewAbstraction2.default.exists(view)) {\n\n return;\n }\n\n view = new _ViewAbstraction2.default(view);\n\n var viewLabel = view.getLabel();\n viewHolderRef = viewHolderRef || this.viewHolderRef;\n this.logger('info', 'Inserting view \"' + viewLabel + '\" into holder \"' + viewHolderRef + '\"');\n $tw.wiki.addTiddler(new $tw.Tiddler({\n title: viewHolderRef,\n text: viewLabel\n }));\n\n // we don't wait til next render-cycle (which would leave tiddlymap in\n // a rather undefined state) but update immediately.\n this.update({\n changedTiddlers: _defineProperty({}, viewHolderRef, true)\n });\n }\n\n /**\n * This function will return a view abstraction that is based on the\n * view specified in the view holder of this graph.\n *\n * @param {boolean} noCache - Retrieve the view reference again\n * from the holder and recreate the view abstraction object.\n * @return {ViewAbstraction} the view\n */\n\n }, {\n key: 'getView',\n value: function getView(noCache) {\n\n if (!noCache && this.view) {\n return this.view;\n }\n\n var viewHolderRef = this.getViewHolderRef();\n\n // transform into view object\n var ref = _utils2.default.getText(viewHolderRef);\n\n this.logger('debug', 'Retrieved view from holder');\n\n var view = void 0;\n\n if (_ViewAbstraction2.default.exists(ref)) {\n\n view = new _ViewAbstraction2.default(ref);\n } else {\n\n this.logger('debug', 'Warning: View \"' + ref + '\" doesn\\'t exist. Default is used instead.');\n view = new _ViewAbstraction2.default('Default');\n }\n\n return view;\n }\n }, {\n key: 'reloadBackgroundImage',\n value: function reloadBackgroundImage(msg) {\n var _this17 = this;\n\n this.backgroundImage = null;\n\n var bgFieldValue = this.view.getConfig('background_image');\n var imgTObj = _utils2.default.getTiddler(bgFieldValue);\n if (!imgTObj && !bgFieldValue) return;\n\n var img = new Image();\n var ajaxCallback = function ajaxCallback(b64) {\n img.src = b64;\n };\n img.onload = function () {\n // only now set the backgroundImage to the img object!\n _this17.backgroundImage = img;\n _this17.repaintGraph();\n };\n\n if (imgTObj) {\n // try loading from tiddler\n var urlField = imgTObj.fields['_canonical_uri'];\n if (urlField) {\n // try loading by uri field\n _utils2.default.getImgFromWeb(urlField, ajaxCallback);\n } else if (imgTObj.fields.text) {\n // try loading from base64\n img.src = $tw.utils.makeDataUri(imgTObj.fields.text, imgTObj.fields.type);\n }\n } else if (bgFieldValue) {\n // try loading directly from reference\n _utils2.default.getImgFromWeb(bgFieldValue, ajaxCallback);\n }\n }\n\n /**\n * The graph of this widget is only repainted if the following counts:\n *\n * The network object exists (prerequisit).\n *\n * 1. We are not in fullscreen at all\n * 2. This particular graph instance is currently running fullscreen.\n */\n\n }, {\n key: 'repaintGraph',\n value: function repaintGraph() {\n\n var isInFS = $tw.utils.hasClass(this.document.body, 'tmap-has-fullscreen-widget');\n if (this.network && (!isInFS || isInFS && this.enlargedMode)) {\n\n this.logger('info', 'Repainting the whole graph');\n\n this.network.redraw();\n this.fitGraph(0, 1000);\n }\n }\n\n /**\n * If a button is enabled it means it is displayed on the graph canvas.\n *\n * @param {string} name - The name of the button to enabled. Has to\n * correspond with the css button name.\n * @param {boolean} enable - True if the button should be visible,\n * false otherwise.\n */\n\n }, {\n key: 'setGraphButtonEnabled',\n value: function setGraphButtonEnabled(name, enable) {\n\n var className = 'vis-button tmap-' + name;\n var b = _utils2.default.getFirstElementByClassName(className, this.domNode);\n $tw.utils.toggleClass(b, 'tmap-button-enabled', enable);\n }\n\n /**\n * Allow the given nodes to be moveable.\n *\n * @param {Array<number>} nodeIds - The ids of the nodes for which\n * we allow or disallow the movement.\n * @param {boolean} isMoveable - True, if the nodes are allowed to\n * move or be moved.\n */\n\n }, {\n key: 'setNodesMoveable',\n value: function setNodesMoveable(nodeIds, isMoveable) {\n\n if (!nodeIds || !nodeIds.length || this.view.isEnabled('physics_mode')) {\n // = no ids passed or in floating mode\n return;\n }\n\n var updates = [];\n var isFixed = !isMoveable;\n for (var i = nodeIds.length; i--;) {\n\n updates.push({\n id: nodeIds[i],\n fixed: { x: isFixed, y: isFixed }\n });\n }\n\n this.graphData.nodes.update(updates);\n\n if (isFixed) {\n\n this.logger('debug', 'Fixing', updates.length, 'nodes');\n\n // if we fix nodes in static mode then we also store the positions\n this.view.saveNodePositions(this.network.getPositions());\n // prevent zoom\n this.isPreventZoomOnNextUpdate = true;\n }\n }\n\n /**\n * This function will create the dom elements for all tiddlymap-vis\n * buttons and register the event listeners.\n *\n * @param {Object<string, function>} buttonEvents - The label of the\n * button that is used as css class and the click handler.\n */\n\n }, {\n key: 'addGraphButtons',\n value: function addGraphButtons(buttonEvents) {\n\n var parent = _utils2.default.getFirstElementByClassName('vis-navigation', this.domNode);\n\n for (var name in buttonEvents) {\n var div = this.document.createElement('div');\n div.className = 'vis-button tmap-' + name;\n\n div.addEventListener('click', buttonEvents[name].bind(this), false);\n parent.appendChild(div);\n\n this.setGraphButtonEnabled(name, true);\n }\n }\n }]);\n\n return MapWidget;\n}(_widget.widget);\n\n/*** Exports *******************************************************/\n\nexports.tmap = MapWidget;\nexports.tiddlymap = MapWidget;\n//# sourceMappingURL=./maps/felixhayashi/tiddlymap/js/widget/MapWidget.js.map\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/plugins/felixhayashi/tiddlymap/license": {
"title": "$:/plugins/felixhayashi/tiddlymap/license",
"subtitle": "License",
"caption": "License",
"text": "\\rules except wikilink\n\n!! TiddlyMap\n\nCopyright (c) 2014, Felix Küppers\nAll rights reserved.\n\nTiddlyMap is licensed under the [[BSD 2-Clause License|http://opensource.org/licenses/BSD-2-Clause]]. For the exact license terms, please visit [[https://github.com/felixhayashi/TW5-TiddlyMap/blob/master/LICENSE]]. \n\n!! TiddlyWiki\n\nCreated by Jeremy Ruston, (jeremy [at] jermolene [dot] com)\n\nCopyright © Jeremy Ruston 2004-2007 Copyright © UnaMesa Association 2007-2014\n\nPublished under the following [licenses](https://github.com/Jermolene/TiddlyWiki5/tree/master/licenses):\n\n# BSD 3-clause \"New\" or \"Revised\" License (including any right to adopt any future version of a license if permitted)\n# Creative Commons Attribution 3.0 (including any right to adopt any future version of a license if permitted)\n\n!! Vis.js\n\nCopyright (c) 2014 [Almende B.V.](https://github.com/almende/vis)\n\nPublished under the following licenses:\n\n# Apache License Version 2.0, January 2004 http://www.apache.org/licenses/\n# MIT License (MIT)\n"
},
"$:/plugins/felixhayashi/tiddlymap/readme": {
"title": "$:/plugins/felixhayashi/tiddlymap/readme",
"text": "* Please refer to the project-readme hosted at [[https://github.com/felixhayashi/TW5-TiddlyMap]].\n* A demo with several examples and explanations can be found at [[http://tiddlymap.org]]."
},
"$:/plugins/felixhayashi/tiddlymap/graph/edgeTypes/tmap:unknown": {
"title": "$:/plugins/felixhayashi/tiddlymap/graph/edgeTypes/tmap:unknown",
"description": "Automatically assigned to an edge that does not have a type assigned",
"style": "{\"color\":\"gray\"}",
"show-label": "false"
},
"$:/plugins/felixhayashi/tiddlymap/graph/edgeTypes/tw-body:link": {
"title": "$:/plugins/felixhayashi/tiddlymap/graph/edgeTypes/tw-body:link",
"description": "A link that is contained in the tiddler's body pointing to another resource.",
"style": "{\"color\":\"orange\", \"dashes\":true}",
"label": "links to",
"text": ""
},
"$:/plugins/felixhayashi/tiddlymap/graph/edgeTypes/tw-list:list": {
"title": "$:/plugins/felixhayashi/tiddlymap/graph/edgeTypes/tw-list:list",
"description": "Contained in a list of this tiddler",
"style": "{ \"color\": \"red\", \"dashes\":true}",
"label": "listed in",
"text": ""
},
"$:/plugins/felixhayashi/tiddlymap/graph/edgeTypes/tw-list:tags": {
"title": "$:/plugins/felixhayashi/tiddlymap/graph/edgeTypes/tw-list:tags",
"description": "A tag that refers to a tiddler of the same name.",
"style": "{ \"color\": \"darkslategray\", \"dashes\":true}",
"label": "tagged with"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/globalConfig/default": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/globalConfig/default",
"caption": "Overview",
"text": "\\rules except wikilink\n\n<div class=\"tmap-flash-message tmap-plain\">\n Please visit the [[online docs|http://tiddlymap.org/Documentation]]\n for more information about the available global options.\n</div>\n<table class=\"tmap-key-value-table\">\n <tr>\n <th align=\"left\">Plugin version</th>\n <td><<pluginVersion>></td>\n </tr>\n<!--\n <tr>\n <th align=\"left\">Datastructure version</th>\n <td><<dataStructureVersion>></td>\n </tr>\n-->\n <tr>\n <th align=\"left\">Nodes in system</th>\n <td><<numberOfNodes>></td>\n </tr>\n <tr>\n <th align=\"left\">Edges in system</th>\n <td><<numberOfEdges>></td>\n </tr>\n</table>"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/globalConfig/editor": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/globalConfig/editor",
"caption": "Editor",
"text": "\\rules except wikilink\n\n<table class=\"tmap-config-table\">\n <<tmap-row type:\"input-checkbox\"\n title:\"Show Neighbour­hood menu\"\n field:\"config.sys.editorMenuBar.showNeighScopeButton\"\n descr:\"Show or hide the neighbourhood menu button.\">>\n <<tmap-row type:\"input-checkbox\"\n title:\"Show Screen­shot menu\"\n field:\"config.sys.editorMenuBar.showScreenshotButton\"\n descr:\"Show or hide the screenshot menu button.\">>\n <<tmap-row type:\"input-checkbox\"\n title:\"Show Raster­ menu\"\n field:\"config.sys.editorMenuBar.showRasterMenuButton\"\n descr:\"Show or hide the raster menu button.\">>\n</table>\n"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/globalConfig/fields": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/globalConfig/fields",
"caption": "Field settings",
"text": "\\rules except wikilink\n\n<table class=\"tmap-config-table\">\n <<tmap-row type:\"input-text\"\n title:\"Node-icon field\"\n field:\"config.sys.field.nodeIcon\" \n descr:\"Local image used as node image in the graphs.\">>\n <<tmap-row type:\"input-text\"\n title:\"Node-label field\"\n field:\"config.sys.field.nodeLabel\" \n descr:\"Alternative node label to use instead of the title.\">>\n <<tmap-row type:\"input-text\"\n title:\"Node-info field\"\n field:\"config.sys.field.nodeInfo\" \n descr:\"Field used as tooltip when hovering over a node in a graph.\"\n note:\"It is prohibited to use the text field here.\">>\n</table> \n\n"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/globalConfig/interaction": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/globalConfig/interaction",
"caption": "Interaction & behaviour",
"text": "\\rules except wikilink\n\n<table class=\"tmap-config-table\">\n <$macrocall type=\"input-select\"\n $name=\"tmap-row\"\n title=\"Default startup view\"\n field=\"config.sys.defaultView\"\n nochoice=\"Last view used at startup\"\n selectFilter=<<tmap \"option\" \"selector.allViewsByLabel\">>\n descr=\"The view to display at startup\" />\n <<tmap-row type:\"input-checkbox\"\n title:\"Show popups\"\n field:\"config.sys.popups.enabled\"\n descr:\"Set this to true if you want to see automatic\n popups in the map.\">>\n <$list filter=\"[config.sys.popups.enabled[true]]\">\n <<tmap-row type:\"input-text\"\n title:\"Popup delay\"\n field:\"config.sys.popups.delay\"\n descr:\"The time in miliseconds that needs to pass after\n a tooltip is triggered.\">>\n <<tmap-row type:\"input-text\"\n title:\"Popup width\"\n field:\"config.sys.popups.width\"\n descr:\"The default max-width of the popup.\"\n note:\"Make sure you added the desired unit (e.g. `px`).\n Requires a wiki refresh.\">>\n <<tmap-row type:\"input-text\"\n title:\"Popup height\"\n field:\"config.sys.popups.height\"\n descr:\"The default max-height of the popup.\"\n note:\"Make sure you added desired the unit (e.g. `px`).\n Requires a wiki refresh.\">>\n </$list>\n <<tmap-row type:\"input-checkbox\"\n title:\"Allow single click mode\"\n field:\"config.sys.singleClickMode\"\n descr:\"A single click on a node is sufficient to open the\n corresponding tiddler.\"\n note:\"Drag and drop will still work and does not cause a\n tiddler to be opened. Single click is never active in\n the map editor.\">>\n <<tmap-row type:\"input-select\"\n title:\"Edge click behaviour\"\n field:\"config.sys.edgeClickBehaviour\"\n selectFilter:\"[[nothing|Nothing]]\n [[manager|Open edge-type manager]]\"\n descr:\"What should happen when you click on an edge?\">>\n <<tmap-row type:\"input-select\" title:\"Raster size\" field:\"config.sys.raster\"\n selectFilter:\"[[|disabled]] [[5|5px]] [[10|10px]] [[15|15px]] [[20|20px]] [[30|30px]] [[40|40px]]\"\n descr:\"Snap nodes to an invisible raster of the given size after drag'n'drop.\"\n note:\"Only works when the view is not in floating mode\">>\n <<tmap-row type:\"input-checkbox\"\n title:\"Apply node-filter to neighbours\"\n field:\"config.sys.nodeFilterNeighbours\"\n descr:\"If checked, neighbours displayed in the map will be filtered\n by the view's node-filter. Otherwise the node-filter will only be used\n to filter the original set of nodes in the map\">>\n</table>\n\n!! Suppressed dialogs\n\n<div class=\"tmap-flash-message tmap-plain\">\n Dialogs that you decided to suppress in the past are listed here.\n Remove the checkmark to enable dialogs again.\n</div>\n\n<table class=\"tmap-config-table\">\n <$list\n filter=\"[<output>fields[]prefix[config.sys.suppressedDialogs]]\"\n emptyMessage=\"–\">\n <$set name=\"dialogName\" value=<<tmap basename \".\">>>\n <$macrocall $name=\"tmap-row\"\n type=\"input-checkbox\"\n title=\"Suppress '$(dialogName)$' dialog\"\n field=<<currentTiddler>> />\n </$set>\n <br />\n </$list>\n</table>\n"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/globalConfig/liveTab": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/globalConfig/liveTab",
"caption": "Live tab",
"text": "\\rules except wikilink\n\n<table class=\"tmap-config-table\">\n <<tmap-row type:\"input-checkbox\"\n title:\"Show Live tab\"\n field:\"liveTab\" \n descr:\"Show or hide the live tab in the sidebar.\">>\n <$macrocall type=\"input-select\"\n $name=\"tmap-row\"\n title=\"Fallback view\"\n field=\"config.sys.liveTab.fallbackView\" \n selectFilter=<<tmap \"option\" \"selector.allViewsByLabel\">>\n descr=\"The view to display in the sidebar's live tab in\n case the current tiddler did not specify a view\n to open.\" />\n</table>"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/globalConfig": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/globalConfig",
"subtitle": "{{$:/core/images/options-button}} Global configuration of TiddlyMap",
"classes": "tmap-remove-top-space",
"text": "\\rules except wikilink\n\n<$macrocall $name=\"tabs\"\n default=<<concat \"$(template)$/default\">>\n tabsList=\"[all[shadows]prefix<template>] -[<template>]\"\n/>"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/globalConfig/verbosity": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/globalConfig/verbosity",
"caption": "Verbosity",
"text": "\\rules except wikilink\n\n<div class=\"tmap-flash-message tmap-plain\">\n Here you can restrict the system's talkativeness.\n</div>\n\n<table class=\"tmap-config-table\">\n <<tmap-row type:\"input-checkbox\"\n title:\"Debug output\"\n field:\"config.sys.debug\" \n descr:\"Set this to true if you want debug information to be\n displayed in the browser console.\">>\n <<tmap-row type:\"input-checkbox\"\n title:\"Show notifications\"\n field:\"config.sys.notifications\" \n descr:\"Set this to true if you want to receive fade-out\n notifications for important events.\">>\n</table> "
},
"$:/plugins/felixhayashi/tiddlymap/dialog/globalConfig/vis": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/globalConfig/vis",
"classes": "tmap-remove-top-space",
"caption": "Graph",
"text": "\\rules except wikilink\n\n<div class=\"tmap-flash-message tmap-info\">\n The global vis configurations will affect all views and their\n elements (nodes and edges) unless they are overridden on a lower\n level. All options below are documented at\n [[vis.js.org|http://visjs.org/docs/network]].\n</div>\n<div class=\"tmap-flash-message tmap-info\">\n Only config items that you actually changed have an effect on\n the graph. Other options are visible, yet, inactive.\n</div>\n<$tmap-config\n mode=\"manage-config\"\n inherited=\"vis-inherited\"\n extension=\"config.vis\" />"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/configureView/default": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/configureView/default",
"caption": "Overview",
"text": "\\rules except wikilink\n\n<div class=\"tmap-flash-message tmap-info\">\n All configurations __only__ affect this view.\n</div>\n\n<table class=\"tmap-key-value-table\">\n <tr>\n <th align=\"left\">Created on</th>\n <td><<createdOn>></td>\n </tr>\n <tr>\n <th align=\"left\">Nodes contained in graph</th>\n <td><<numberOfNodes>></td>\n </tr>\n <tr>\n <th align=\"left\">Edges contained in graph</th>\n <td><<numberOfEdges>></td>\n </tr>\n</table>"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/configureView/editFilters": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/configureView/editFilters",
"caption": "Edit filters",
"text": "\\rules except wikilink\n\n<div class=\"tmap-flash-message tmap-info\">\n Completely new to filters? Please read\n [[Introduction to filter notation|http://tiddlywiki.com/#Introduction%20to%20filter%20notation]]\n first.\n</div>\n\n<fieldset>\n <legend>Filters <sup>[1]</sup></legend>\n <table class=\"tmap-config-table tmap-large-input\">\n <<tmap-row type:\"input-textarea\"\n title:\"Node filter\"\n field:\"filter.prettyNodeFltr\"\n descr:\"In the map, only those tiddlers that match this filter\n are shown. Drafts and system tiddlers are automatically\n excluded.\">>\n <<tmap-row type:\"input-textarea\"\n title:\"Edge-type filter\"\n field:\"filter.prettyEdgeFltr\" \n descr:\"Only edges with a type that matches the filter are shown.\">>\n </table> \n</fieldset>\n\n---\n\n<sup>[1]</sup> In the editors above, a new line is equivalent to a space symbol.<br />\n<sup>[2]</sup> It is suggested to read\n[[Node and edge-type filters|http://tiddlymap.org#Node%20and%20edge-type%20filters]]\nand [[Edge-type namespaces|http://tiddlymap.org#Node%20and%20edge-type%20filters]]\nbefore using Tiddlymap's filter editor."
},
"$:/plugins/felixhayashi/tiddlymap/dialog/configureView/layout": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/configureView/layout",
"caption": "Layout",
"text": "\\rules except wikilink\n\n<table class=\"tmap-config-table\">\n <<tmap-row type:\"input-checkbox\"\n title:\"Floating nodes\"\n field:\"config.physics_mode\" \n descr:\"Set this to true if you want your nodes to freely\n swirl around.\">>\n <<tmap-row type:\"input-text\"\n title:\"Background image\"\n field:\"config.background_image\" \n descr:\"The title of an image tiddler to be used as background\n in the view.\"\n note:\"You can also use an image url directly, however, the\n image needs be stored under the same domain as your wiki.\n Otherwise, it won't be displayed!\">>\n</table>"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/configureView/namespace": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/configureView/namespace",
"caption": "Namespace",
"text": "\\rules except wikilink\n\n<table class=\"tmap-config-table tmap-small-input\">\n <<tmap-row type:\"input-text\"\n title:\"Edge-type namespace\"\n field:\"config.edge_type_namespace\" \n descr:\"A namespace (like `foaf` in `foaf:knows`) that will be\n automatically added to all edge types you create in\n this view. The namespace is only added if the types\n do not exist yet and do not have a namespace assigned yet.\n Namespaces are always hidden in the graph.\"\n note:\"Most likely, you don't want the edges created with this\n namespace to leak into other views, moreover, you don't\n want edges that do not possess the namespace ever to be\n shown here. In this case, use a private marker (`_`)\n in front of your namespace, e.g. `_mynamespace` and use\n an appropriate edge type filter, i.e. `+[prefix[_mynamespace]]`\n For further information see:\n \n * [[Edge-type namespaces|http://tiddlymap.org/#Edge-type%20namespaces]]\n * [[Private edge types|http://tiddlymap.org/#Private%20edge%20types]]\n \">>\n</table>\n"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/configureView": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/configureView",
"subtitle": "{{$:/core/images/options-button}} View configuration -- <<view>>",
"text": "\\rules except wikilink\n\n\\define privateEdgeTypes() [[private edge-types|http://tiddlymap.org/#Private%20edge%20types]]\n\n<$macrocall $name=\"tabs\"\n default=<<concat \"$(template)$/default\">>\n tabsList=\"[all[shadows]prefix<template>] -[<template>]\"\n/>"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/configureView/vis": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/configureView/vis",
"caption": "Graph",
"text": "\\rules except wikilink\n\n<div class=\"tmap-flash-message tmap-info\">\n The local vis configurations will affect all\n elements (nodes and edges) of this view, unless they are\n overridden on a lower level. All options below are documented at\n [[vis.js.org|http://visjs.org/docs/network]].\n</div>\n<div class=\"tmap-flash-message tmap-info\">\n Only config items that you actually changed have an effect on the\n graph. Other options are visible, yet, inactive.\n</div>\n<$tmap-config\n mode=\"manage-config\"\n inherited=\"vis-inherited\"\n extension=\"config.vis\" />"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/getEdgeType": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/getEdgeType",
"subtitle": "{{$:/plugins/felixhayashi/tiddlymap/icon}} Edge type specification",
"text": "\\rules except wikilink\n\\rules except underscore\n\n\\define filter() $(allEdgeTypes)$ +[search:title[$(term)$]]\n\n\\define badge(color, label, tooltip)\n<span style=\"background: $color$\" title=\"$tooltip$\">$label$</span>\n\\end\n\n\\define badges()\n<$tiddler tiddler={{!!text}}>\n<$set name=\"id\" value=<<tmap \"getETyId\" \"$(view)$\">>>\n<$set name=\"isVisible\" value=<<tmap \"isETyVisible\" \"$(view)$\">>>\n<div class=\"tmap-badges\">\n <span\n style=\"background: darkslategray\"\n title=\"Your input translates into this id.\">\n <<id>>\n </span>\n <$list filter=\"[<isVisible>regexp[true]]\">\n <<badge \"green\" \"visible\" \"Matches your view's filter\">>\n </$list>\n <$list filter=\"[<isVisible>regexp[false]]\">\n <<badge \"red\" \"not visible\" \"Doesn't match your view's filter\">>\n </$list>\n <$list filter=\"[<id>!regexp[^tmap:unknown$]]\" variable=\"item\">\n <$list filter=\"[<id>regexp[^_]]\">\n <<badge \"purple\" \"private\" \"Not shown in other views per default\">>\n </$list>\n <$list filter=\"[<id>regexp[.+:.+]]\">\n <<badge \"orange\" \"namespace\" \"This type is prefixed with a proper namespace\">>\n </$list>\n </$list>\n</div>\n</$set>\n</$set>\n</$tiddler>\n\\end\n\n\\define search()\n<p>\n You are about to connect \"<$text text=\"$(fromLabel)$\" />\"\n with \"<$text text=\"$(toLabel)$\" />\". Please specify a type.\n</p>\n<table id=\"tmap-search-table\">\n <tr>\n <td><b>Type:</b></td>\n <td>\n <$edit-text\n focus=\"true\"\n field=\"text\"\n type=\"text\"\n tag=\"input\"\n default=\"\"\n class=\"tmap-trigger-field\n tmap-triggers-ok-button-on-enter\n tmap-triggers-cancel-button-on-esc\" />\n <<badges>>\n </td>\n </tr>\n <tr>\n <td></td>\n <td>\n <$set name=\"term\" value={{!!text}}>\n <$set name=\"allEdgeTypes\" value=<<tmap \"option\" \"selector.allEdgeTypesById\">>>\n <ul class=\"tmap-small-list\">\n <$list filter=<<filter>>>\n <li>\n <$button class=\"tc-btn-invisible tmap-link\">\n <$view field=\"title\" />\n <$action-setfield $tiddler=<<output>> text={{!!title}} />\n </$button>\n </li>\n </$list>\n </ul>\n </$set>\n </$set>\n </td>\n </tr>\n</table>\n\\end\n\n<$list filter=\"[<temp>!has[more]]\" variable=\"item\"><<search>></$list>\n"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/addNodeToMap": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/addNodeToMap",
"subtitle": "{{$:/core/images/tag-button}} Add node",
"classes": "tmap-modal-add-node",
"text": "\\rules except wikilink\n\n\\define backButtonText() back to list\n\\define outputAndTemplate() [[$(output)$]] [[$(template)$]]\n\n\\define editor()\n <$button class=\"tmap-go-back tc-btn-invisible\">\n {{$:/core/images/chevron-left}} <<backButtonText>>\n <$action-deletefield $tiddler=<<temp>> more template />\n <$action-sendmessage\n $message=\"tmap:tm-clear-tiddler\"\n keep=\"draft.title\"\n title=<<output>> />\n </$button>\n\n <$list filter=\"[<output>get[draft.title]is[tiddler]]\">\n <div class=\"tmap-flash-message tmap-warning\">\n Tiddler already exists! Use another title or click\n \"<<backButtonText>>\" to cancel your edit.\n </div>\n </$list>\n\n <div class=\"tmap-modal-editor\">\n <table class=\"tmap-config-table\">\n <tr class=\"tmap-template-select\">\n <td>Template</td>\n <td>\n <$select\n tiddler=<<temp>>\n field=\"template\">\n <option value=\"\"></option>\n <$list filter=<<tmap \"option\" \"selector.allPotentialNodes\">>>\n <option><$view field=\"title\" /></option>\n </$list>\n </$select>\n <$button>Load\n <$action-sendmessage\n $message=\"tmap:tm-clear-tiddler\"\n keep=\"draft.title\"\n title=<<output>> />\n <$list filter=\"[<temp>get[template]]\" variable=\"template\">\n <$action-sendmessage\n $message=\"tmap:tm-merge-tiddlers\"\n tiddlers=<<outputAndTemplate>>\n output=<<output>> />\n <$action-deletefield $tiddler=<<output>> tmap.id tmap.edges />\n </$list>\n </$button>\n </td>\n <td>Press the \"load\" button to activate the template.</td>\n </tr>\n </table>\n <$importvariables filter=\"[all[tiddlers+shadows]prefix[$:/core/macros/]]\">\n <$set name=\"currentTiddler\" value=<<output>>>\n <$transclude tiddler=\"$:/core/ui/EditTemplate\" mode=\"block\" />\n </$set>\n </$importvariables>\n </div>\n\\end\n\n\\define search()\n<p>Add an existing tiddler to the map or create a new one.</p>\n<table id=\"tmap-search-table\">\n <tr>\n <td><b>Title:</b></td>\n <td>\n <$edit-text\n tiddler=<<output>>\n field=\"draft.title\"\n focus=\"true\"\n type=\"text\"\n tag=\"input\"\n default=\"\"\n class=\"tmap-trigger-field\n tmap-triggers-ok-button-on-enter\n tmap-triggers-cancel-button-on-esc\" />\n <$list filter=\"[<output>get[draft.title]!is[tiddler]]\">\n <$button\n tooltip=\"The tiddler does not exist yet and you may edit it\n before it is added to the map\">\n {{$:/core/images/edit-button}}\n <$action-setfield $tiddler=<<temp>> more=\"true\" />\n </$button> <sup>[1]</sup>\n </$list>\n </td>\n </tr>\n <tr>\n <td></td>\n <td>\n <$set name=\"term\" value={{!!draft.title}}>\n <ul class=\"tmap-small-list\">\n <$list filter=\"[search:title<term>!is[system]!has[draft.of]]\">\n <li>\n <$button class=\"tc-btn-invisible tmap-link\">\n <$view field=\"title\" />\n <$action-setfield $tiddler=<<output>> draft.title={{!!title}} />\n </$button>\n </li>\n </$list>\n </ul>\n </$set>\n </td>\n </tr>\n</table>\n\n<$list filter=\"[<output>get[draft.title]!is[tiddler]]\">\n<hr />\n<sup>[1]</sup>\n<small>\n The tiddler does not exist yet and you may edit it\n before it is added to the map\n</small>\n</$list>\n\\end\n\n<$list filter=\"[<temp>!has[more]]\" variable=\"item\"><<search>></$list>\n<$list filter=\"[<temp>has[more]]\" variable=\"item\"><<editor>></$list>\n"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/cannotDeleteViewDialog": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/cannotDeleteViewDialog",
"subtitle": "{{$:/core/images/locked-padlock}} You cannot delete this view!",
"buttons": "ok",
"text": "\\rules except wikilink\n\nIt is not possible to delete the current view as ''<<count>>'' tiddlers\nare referencing it. To delete the view you must first remove the tiddlymap\nwidgets in the tiddlers listed below or change their view attributes.\n\n''References''\n\n<ul>\n<$list filter=<<refFilter>> variable=\"item\">\n <li><$link><<item>></$link></li>\n</$list>\n</ul>\n\nAfter the references are removed, you may delete the view.\n"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/getConfirmation": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/getConfirmation",
"subtitle": "{{$:/core/images/import-button}} You must confirm in order to proceed!",
"text": "\\rules except wikilink\n\n<<message>>\n\n''Are you really sure you want to do this?''"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/createView": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/createView",
"subtitle": "{{$:/core/images/new-button}} Creating a new view",
"text": "\\rules except wikilink\n\n<table class=\"tmap-config-table\">\n <<tmap-row type:\"input-text\"\n title:\"View name\"\n field:\"name\"\n focus:\"true\"\n class:\"tmap-trigger-field\n tmap-triggers-ok-button-on-enter\n tmap-triggers-cancel-button-on-esc\"\n descr:\"The name for the new view. If no name is entered,\n the program will invent one for you.\"\n note:\"You cannot override an existing view. In this case,\n you need to delete the old view first! You must no use\n slashes (`/`) in the name.\">>\n <<tmap-row type:\"input-checkbox\"\n title:\"Clone view\"\n field:\"clone\"\n descr:\"Use the view that is currently displayed in the\n editor as blueprint. The view will be an __exact__\n clone of the current one, only with a different\n name.\">>\n</table>\n"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/deleteNodeDialog": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/deleteNodeDialog",
"subtitle": "{{$:/core/images/delete-button}} You are about to delete <<count>> nodes",
"text": "\\rules except wikilink\n\n''Please choose an option or abort:''\n\n<$radio tiddler=<<output>> field=\"delete-from\" value=\"system\">\n Delete nodes from system <sup>[1]</sup>\n</$radio><br />\n<$radio tiddler=<<output>> field=\"delete-from\" value=\"filter\">\n Delete nodes from graph's filter <sup>[2]</sup>\n</$radio>\n\nThe following nodes will be deleted:\n\n<ul>\n<$list filter=<<tiddlers>>>\n <li><$view tiddler={{!!title}} field=\"title\" /></li>\n</$list>\n</ul>\n\n---\n\n<sup>[1]</sup>\n<small>This will delete all nodes, their corresponding tiddlers and all connected edges.</small><br/>\n<sup>[2]</sup>\n<small>''Important:'' Removing a node from the graph's filter only works, if the node has been added in the map editor per double click or via \"Add Node\". If the node hasn't been added as mentioned above, you need to change the underlying tiddler in a way that it doesn't match your filter anymore, if you don't want it to be displayed in the graph.</small>"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/dublicateIdInfo": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/dublicateIdInfo",
"subtitle": "{{$:/core/images/info-button}} Dublicate id detected",
"buttons": "ok_suppress",
"text": "\\rules except wikilink\n\nTiddlyMap requires the value of the id field (\"tmap.id\") to be\nunique in order to correctly identify nodes and tiddlers.\n\nThe id of the \"<<param.changedTiddler>>\" already exists for these tiddlers:\n\n<ul>\n<$list filter=<<param.filter>> variable=\"item\">\n <li><$link><<item>></$link></li>\n</$list>\n</ul>\n\nTherefore TiddlyMap\n\n* assigned a new id to tiddler \"<<param.changedTiddler>>\"\n* removed all edges from \"<<param.changedTiddler>>\"\n"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/edgeNotVisible": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/edgeNotVisible",
"subtitle": "{{$:/core/images/info-button}} Edge will not be visible in view \"<<view>>\"",
"buttons": "ok_suppress",
"text": "\\rules except wikilink\n\nYou just created an edge of type\n<code><$text text=<<type>> /></code> that will not be\nvisible in this view because it doesn't match your\nedge-type filter settings.\n\nThe current edge-type filter of view \"<<view>>\" looks like this:\n\n<pre><code><$text text=<<eTyFilter>> /></code></pre>\n\nTo have the newly added type displayed in your view, adjust your\nedge-type filter accordingly. \n\nSome suggestions:\n\n<ul>\n <li>\n Explicitly add the type to the filter:\n <code><$text text=\"[[\" /><$text text=<<type>> /><$text text=\"]]\" /></code>\n </li>\n <li>\n <$set\n filter=\"[<type>regexp[:]splitbefore[:]]\"\n name=\"prefix\"\n emptyValue=<<tmap halfOfString \"$(type)$\">>>\n Add a filter rule (e.g. a prefix filter) that will match\n your type: <code>[prefix[<<prefix>>]]</code>\n </$set>\n </li>\n <li>Make your current view-filter less restrictive.</li>\n</ul>\n\nFor further information, please see:\n[[Node and edge-type filters|http://tiddlymap.org#Node%20and%20edge-type%20filters]]."
},
"$:/plugins/felixhayashi/tiddlymap/dialog/editNode/default": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/editNode/default",
"caption": "Global node style",
"classes": "tmap-remove-top-space",
"text": "\\rules except wikilink\n\n<div class=\"tmap-flash-message tmap-info\">\n A node's ''global configuration''\n (also referred to as //global individual config//) defines its\n individual appearance and behaviour in all views.\n</div>\n<<maybeShowTidColorWarning>>\n \n<$macrocall $name=\"sharedSettings\"\n twIconField=<<tidIconField>>\n faIconField=\"global.tmap.fa-icon\"\n labelField=<<tidLabelField>> />\n\n<$macrocall $name=\"visConfiguration\"\n mode=\"manage-node-types\"\n extensionField=\"global.tmap.style\"\n styleName=\"node's global style\"\n inheritedList=\"[[inherited-global-default-style]]\n [[inherited-local-default-style]]\n [[inherited-group-styles]]\" />"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/editNode/local": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/editNode/local",
"caption": "Local node style",
"classes": "tmap-remove-top-space",
"text": "\\rules except wikilink\n \n<div class=\"tmap-flash-message tmap-info\">\n The ''local node configuration'' \n (also referred to as //view-specific node configuration//)\n overrides the //global individual configuration// and only affects\n the node's appearance and behaviour in the current view.\n</div>\n<<maybeShowTidColorWarning>>\n\n<fieldset>\n <legend>Behaviour</legend>\n <table class=\"tmap-config-table\">\n <$macrocall type=\"input-select\"\n $name=\"tmap-row\"\n title=\"Open view\"\n field=\"local.open-view\"\n nochoice=\"Disabled\"\n selectFilter=<<tmap \"option\" \"selector.allViewsByLabel\">>\n descr=\"Clicking on this node will open the specified\n view instead of the tiddler represented by this node.\" />\n </table>\n</fieldset>\n\n<$macrocall $name=\"sharedSettings\"\n twIconField=\"local.tw-icon\"\n faIconField=\"local.fa-icon\"\n labelField=\"local.label\" />\n \n<$macrocall $name=\"visConfiguration\"\n mode=\"manage-node-types\"\n extensionField=\"local-node-style\"\n styleName=\"node's local style\"\n inheritedList=\"[[inherited-global-default-style]]\n [[inherited-local-default-style]]\n [[inherited-group-styles]]\n [[global.tmap.style]]\" />"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/editNode": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/editNode",
"subtitle": "{{$:/core/images/edit-button}} Editing style of node \"<<tiddler>>\"",
"classes": "tmap-remove-top-space",
"text": "\\rules except wikilink\n\n\\define maybeShowTidColorWarning()\n <$list filter=\"[<tidColor>regexp[.+]]\">\n <div class=\"tmap-flash-message tmap-warning\">\n You have set the tiddler's color\n field to \"<<tidColor>>\". This value will be completely ignored\n when you change node's color properties in the vis editor below.\n </div>\n </$list>\n\\end\n\n\\define iconSettings(twIconField, faIconField)\n <fieldset>\n <legend>Icon Settings</legend>\n <table class=\"tmap-config-table\">\n <<tmap-row type:\"input-text\"\n title:\"TW-icon\"\n field:\"$twIconField$\"\n descr:\"A tiddlywiki image reference.\n For example '$:/core/icon' for Movotun Jack.\">>\n <<tmap-row type:\"input-text\"\n title:\"FA-icon\"\n field:\"$faIconField$\"\n descr:\"A Font Awesome icon code.\n For example 'f206' for the bicycle symbol.\">>\n </table>\n </fieldset>\n\\end\n\n\\define sharedSettings(twIconField, faIconField, labelField)\n <fieldset>\n <legend>General Settings</legend>\n <table class=\"tmap-config-table\">\n <<tmap-row type:\"input-text\"\n title:\"Label\"\n field:\"$labelField$\"\n descr:\"Use this value as node label.\">>\n </table>\n </fieldset>\n <!-- display icon fieldset -->\n <<iconSettings \"$twIconField$\" \"$faIconField$\">> \n\\end\n\n<$macrocall\n $name=\"tabs\"\n default=<<concat \"$(template)$/default\">>\n tabsList=\"[all[shadows]prefix<template>] -[<template>]\"\n/>"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/fullscreenTiddlerEditor/draft": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/fullscreenTiddlerEditor/draft",
"caption": "Draft",
"text": "\\rules except wikilink\n\n<div class=\"tmap-modal-editor\">\n <$importvariables filter=\"[all[tiddlers+shadows]prefix[$:/core/macros/]]\">\n <$set name=\"currentTiddler\" value=<<draftTRef>> >\n <$transclude tiddler=\"$:/core/ui/EditTemplate\" field=\"text\" mode=\"block\" />\n </$set>\n </$importvariables>\n</div>"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/fullscreenTiddlerEditor/original": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/fullscreenTiddlerEditor/original",
"caption": "Current Version",
"text": "\\rules except wikilink\n\n<div class=\"tmap-modal-editor\">\n <$importvariables filter=\"[all[tiddlers+shadows]prefix[$:/core/macros/]]\">\n <$set name=\"currentTiddler\" value=<<originalTRef>> >\n <$transclude tiddler=\"$:/core/ui/ViewTemplate\" field=\"text\" mode=\"block\" />\n </$set>\n </$importvariables>\n</div>\n"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/fullscreenTiddlerEditor": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/fullscreenTiddlerEditor",
"subtitle": "{{$:/core/images/edit-button}} <<originalTRef>>",
"classes": "tmap-modal-fullscreen-editor tmap-remove-top-space",
"text": "\\rules except wikilink\n\n\\define defaultTab() $:/plugins/felixhayashi/tiddlymap/dialog/fullscreenTiddlerEditor/original\n\n<$macrocall $name=\"tabs\"\n default=<<defaultTab>>\n tabsList=\"[all[shadows]prefix[$:/plugins/felixhayashi/tiddlymap/dialog/fullscreenTiddlerEditor/]]\" />"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/fieldChanged": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/fieldChanged",
"subtitle": "{{$:/core/images/info-button}} The field \"<<name>>\" changed",
"text": "\\rules except wikilink\n\nYou changed the field \"<<name>>\" from \"<<oldValue>>\" to \"<<newValue>>\".\n\nIt is recommended to let TiddlyMap copy all values from the former field \"<<oldValue>>\" to the new field \"<<newValue>>\" so the data stored in \"<<oldValue>>\" is not lost. This operation has to be done now or never.\n\nDo you want to move each tiddler's existing \"<<oldValue>>\" value to \"<<newValue>>\"? Please note that any value currently stored in \"<<newValue>>\" would consequently be overridden and the old field \"<<oldValue>>\" would be eventually removed!"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/fullscreenNotSupported": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/fullscreenNotSupported",
"subtitle": "{{$:/core/images/info-button}} Your machine does not support fullscreen",
"buttons": "ok_suppress",
"text": "\\rules except wikilink\n\nPlease have a look [[here|http://caniuse.com/#feat=fullscreen]] to see a list of supported devices/browsers.\n\nSorry for this :("
},
"$:/plugins/felixhayashi/tiddlymap/dialog/renameView": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/renameView",
"subtitle": "{{$:/core/images/tag-button}} Please specify a view name",
"text": "\\rules except wikilink\n\n''Name:''\n<$edit-text focus=\"true\" tiddler=<<output>> field=\"text\" type=\"text\" tag=\"input\" default=\"\"\n class=\"tmap-trigger-field tmap-triggers-ok-button-on-enter\" />\n\nNote that ''<<count>>'' tiddlers are referencing this view.\n\n<$reveal type=\"nomatch\" text=\"0\" default=<<count>>>\n\nRenaming the view will cause the reference to be invalid.\nIt is recommended to first remove the tiddlymap widgets in\nthe tiddlers listed below or change their view attributes\naccordingly.\n\n''References''\n\n<ul>\n<$list filter=<<refFilter>> variable=\"item\">\n <li><$text text=<<item>> /></li>\n</$list>\n</ul>\n\n</$reveal>\n"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/saveCanvas": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/saveCanvas",
"subtitle": "{{$:/core/images/options-button}} Save a snapshot image of view \"<<view>>\"",
"text": "\\rules except wikilink\n\n\\define preview()\n<div class=\"tmap-save-canvas-preview\">\n <$transclude tiddler=<<snapshot>> /><br />\n Measures: <<width>> × <<height>>\n</div>\n\\end\n\n<table class=\"tmap-config-table\">\n<!--\n <<tmap-row type:\"input-text\"\n title:\"Name\"\n field:\"name\">\n-->\n<$macrocall $name=\"tmap-row\"\n type=\"input-text\"\n title=\"Name\"\n field=\"name\"\n descr=<<preview>> />\n</table>\n\n<fieldset><legend>Options</legend>\n <table class=\"tmap-config-table\">\n <<tmap-row type:\"input-radio\"\n title:\"Action\"\n field:\"action\" \n selectFilter:\"[[download|Download]]\n [[wiki|Save in wiki]]\n [[placeholder|Use as placeholder for this view]]\"\n descr:\"Save the image by downloading it to your computer or\n save it as a tiddler in your wiki.<br /><br />\n A third option is to make TiddlyMap use this image as\n placeholder for the current view. Placeholders are used\n when tiddlers are exported in form of static html\n or when editing a tiddler while having the preview\n shown. In this case the title input is ignored.\">>\n </table>\n</fieldset>"
},
"$:/plugins/felixhayashi/tiddlymap/dialog": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog",
"text": "\\rules except wikilink\n\n<div class=<<classes>>>\n<$importvariables\n filter=\"[[$:/plugins/felixhayashi/tiddlymap/misc/macros]]\n [[$:/core/macros/tabs]]\">\n<$transclude tiddler=<<template>> mode=\"block\" />\n</$importvariables>\n</div>"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/welcome": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/welcome",
"subtitle": "{{$:/core/images/info-button }} Welcome",
"buttons": "ok",
"text": "\\rules except wikilink\n\nIt seems that you freshly installed TiddlyMap.\n\n* In case you need any help, please consult the [[online docs|http://tiddlymap.org#Documentation]] first.\n* You are welcome to create an [[issue|https://github.com/felixhayashi/TW5-TiddlyMap/issues]] at GitHub for any bug you discover.\n* Make sure to revisit the [[demo site|http://tiddlymap.org]] to see whether your version is up-to-date.\n* If you like TiddlyMap, please give it a star at [[GitHub|https://github.com/felixhayashi/TW5-TiddlyMap]] or tell your friends about it :)\n* ''Please note:'' TiddlyMap is distributed under the [[BSD 2-Clause License|http://opensource.org/licenses/BSD-2-Clause]], which belongs to the same license family, as the license used by TiddlyWiki. By using this plugin you agree to the product's [[License Terms|https://github.com/felixhayashi/TW5-TiddlyMap/blob/master/LICENSE]].\n\nEnjoy!\n\n---\n\nTiddlyMap will configure your wiki for optimal use. Everything can be changed back later by you, via the TiddlyWiki configurations panel, so no worries. If you checked some of the options below, please save & restart after closing this dialog.\n\n<table class=\"tmap-config-table\">\n <<tmap-row type:\"input-checkbox\"\n title:\"Optimize storyview\"\n field:\"config.storyview\"\n descr:\"Sets the storyview to 'top' for optimal scrolling.\">>\n <<tmap-row type:\"input-checkbox\"\n title:\"Optimize sidebar\"\n field:\"config.sidebar\"\n descr:\"Sets sidebar layout to 'fixed-fluid' for larger editor.\">>\n <<tmap-row type:\"input-checkbox\"\n title:\"Optimize navigation\"\n field:\"config.navigation\"\n descr:\"Sets navigation style to open tiddlers at top for better map navigation.\">>\n <<tmap-row type:\"input-checkbox\"\n title:\"Create demo welcome map\"\n field:\"config.demo\"\n descr:\"Creates a little hello world welcome map for you.\">>\n</table>\n"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/widgetCodeGenerator": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/widgetCodeGenerator",
"subtitle": "{{$:/core/images/permalink-button}} Widget Code Generator",
"buttons": "close",
"text": "\\rules except wikilink\n\n<div class=\"tmap-flash-message tmap-info\">\n Use the code below to embed a view in a tiddler.\n</div>\n\n<pre style=\"white-space: normal;\">\n<$tmap\n\n<$list filter=\"[<output>has[var.view]]\">\n view=\"<$view field='var.view' />\"</$list>\n<$list filter=\"[<output>field:var.click-to-use[true]]\">\n click-to-use=\"true\"</$list>\n<$list filter=\"[<output>has[var.editor]]\">\n editor=\"<$view field='var.editor' />\"</$list>\n<$list filter=\"[<output>has[var.width]]\">\n width=\"<$view field='var.width' />\"</$list>\n<$list filter=\"[<output>has[var.height]]\">\n height=\"<$view field='var.height' />\"</$list>\n<$list filter=\"[<output>has[var.class]]\">\n class=\"<$view field='var.class' />\"</$list>\n<$list filter=\"[<output>field:var.show-buttons[false]]\">\n show-buttons=\"false\"</$list>\n<$list filter=\"[<output>has[var.design]]\">\n design=\"<$view field='var.design' />\"</$list>></$tmap>\n</pre>\n\n<fieldset>\n <legend>Parameters</legend> \n <table class=\"tmap-config-table\">\n <$macrocall type=\"input-select\"\n $name=\"tmap-row\"\n title=\"View\"\n field=\"var.view\"\n nochoice=\" \"\n selectFilter=<<tmap \"option\" \"selector.allViewsByLabel\">>\n descr=\"The view to bind the wiedget to\" />\n <<tmap-row type:\"input-select\"\n title:\"Editor bar\"\n field:\"var.editor\"\n selectFilter:\"[[|Hidden]]\n [[vis|Simple]]\n [[advanced|Advanced]]\"\n descr:\"Whether the widget should act as an editor or not.\">>\n <<tmap-row type:\"input-select\"\n title:\"Design\"\n field:\"var.design\"\n selectFilter:\"[[|Normal]]\n [[plain|Plain]]\"\n descr:\"Usually a header is displayed and borders. Plain\n design will only show the mere graph.\">>\n <<tmap-row type:\"input-text\"\n title:\"Height\"\n field:\"var.height\"\n descr:\"Graph's height in css units. Defaults to '300px'.\">>\n <<tmap-row type:\"input-text\"\n title:\"Width\"\n field:\"var.width\"\n descr:\"Graph's width in css units. Defaults to '100%'.\">>\n <<tmap-row type:\"input-text\"\n title:\"Class\"\n field:\"var.class\"\n descr:\"A custom class to apply your own css.\">>\n <<tmap-row type:\"input-checkbox\"\n title:\"Click to use\"\n field:\"var.click-to-use\"\n default:\"false\"\n descr:\"A click is needed to enable the graph.\">>\n <<tmap-row type:\"input-checkbox\"\n title:\"Show buttons\"\n field:\"var.show-buttons\"\n default:\"true\"\n descr:\"Show or hide the graph's navigation buttons.\">>\n </table>\n</fieldset>"
},
"$:/plugins/felixhayashi/tiddlymap/dialogFooter/close": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialogFooter/close",
"text": "\\rules except wikilink\n\n<$button class=\"tmap-dialog-button tmap-close-button\" tooltip=\"Close this dialog\">Close\n\n <!-- trigger dialog callback -->\n <$action-setfield $tiddler=<<result>> text=\"1\" />\n \n</$button>\n"
},
"$:/plugins/felixhayashi/tiddlymap/dialogFooter/ok": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialogFooter/ok",
"text": "\\rules except wikilink\n\n<$button class=\"tmap-dialog-button tmap-ok-button\" tooltip=\"Confirm dialog\">OK\n\n <!-- trigger dialog callback -->\n <$action-setfield $tiddler=<<result>> text=\"1\" />\n \n</$button>\n"
},
"$:/plugins/felixhayashi/tiddlymap/dialogFooter/ok_cancel": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialogFooter/ok_cancel",
"text": "\\rules except wikilink\n\n<$transclude tiddler=\"$:/plugins/felixhayashi/tiddlymap/dialogFooter/ok\" mode=\"inline\" />\n<$button class=\"tmap-dialog-button tmap-cancel-button\" tooltip=\"Close dialog without saving\">Cancel\n <!-- trigger dialog callback -->\n <$action-setfield $tiddler=<<result>> text=\"\" />\n</$button>\n"
},
"$:/plugins/felixhayashi/tiddlymap/dialogFooter/ok_suppress": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialogFooter/ok_suppress",
"text": "\\rules except wikilink\n\n<$set name=\"currentTiddler\" value=<<title>> >\n\n<$checkbox field=\"suppress\" checked=\"1\" unchecked=\"0\" default=\"0\"> Do not show this dialog again</$checkbox>\n<$button class=\"tmap-dialog-button tmap-ok-button\" tooltip=\"Confirm this dialog\">OK\n\n <!-- trigger dialog callback -->\n <$action-setfield $tiddler=<<result>> text=\"1\" />\n \n <!-- suppress dialog in the future -->\n <$action-sendmessage $message=\"tmap:tm-suppress-dialog\"\n dialog=<<templateId>>\n suppress={{!!suppress}} />\n \n</$button>\n\n</$set>"
},
"$:/plugins/felixhayashi/tiddlymap/dialogFooter": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialogFooter",
"text": "\\rules except wikilink\n\n\\define footer() $:/plugins/felixhayashi/tiddlymap/dialogFooter/$(buttons)$\n\n<$transclude tiddler=<<footer>> />\n\n<!-- we need this button to be able to close a tiddler from outside programmatically -->\n<$button class=\"tmap-hidden-close-button\" message=\"tm-close-tiddler\" />"
},
"$:/plugins/felixhayashi/tiddlymap/dialogFooter/element_type_manager": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialogFooter/element_type_manager",
"text": "\\rules except wikilink\n\n<$button\n class=\"tmap-dialog-button tmap-save-button\"\n tooltip=\"Save the current changes\">Save\n <$action-sendmessage\n $message=\"tmap:tm-save-type-form\"\n mode=<<mode>>\n output=<<output>> />\n</$button>\n<$button\n class=\"tmap-dialog-button tmap-cancel-button\"\n tooltip=\"Cancel the most resent changes and exit\">Quit\n <$action-setfield $tiddler=<<result>> text=\"1\" />\n</$button>"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/MapElementTypeManager/deleteType": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/MapElementTypeManager/deleteType",
"caption": "Removal",
"text": "\\rules except wikilink\n\n\\define manage-edge-types()\n <$macrocall $name=\"tmap-row\"\n type=\"input-checkbox\"\n title=\"Delete type\"\n field=\"temp.deleteType\"\n default={{!id}}\n readonly={{!!temp.idImmutable}}\n descr=\"If you want to delete this type, set this to true\n and click the save button afterwards. Predefined system\n types cannot be deleted.\" note=\"Consequently, all edges\n of this type will be deleted.\" />\n\\end\n\n\\define manage-node-types()\n <$macrocall $name=\"tmap-row\"\n type=\"input-checkbox\"\n title=\"Delete type\"\n field=\"temp.deleteType\"\n default={{!id}}\n readonly={{!!temp.idImmutable}}\n descr=\"If you want to delete this type, set this to true and\n click the save button afterwards. Predefined system\n types cannot be deleted.\" />\n\\end\n\n<table class=\"tmap-config-table\"><$macrocall $name=<<mode>> /></table>"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/MapElementTypeManager/description": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/MapElementTypeManager/description",
"caption": "Description",
"text": "\\rules except wikilink\n\n\\define manage-edge-types()\n <<tmap-row type:\"input-textarea\"\n title:\"Description\"\n field:\"description\"\n descr:\"An optional description for this type. The\n description will be displayed as tooltip when\n moving the mouse over an edge of this type.\">>\n\\end\n\n\\define manage-node-types()\n <<tmap-row type:\"input-textarea\"\n title:\"Description\"\n field:\"description\" \n descr:\"An optional description for this type.\">>\n\\end\n\n<table class=\"tmap-config-table\">\n <$macrocall $name=<<mode>> />\n</table>\n\n"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/MapElementTypeManager/generalSettings": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/MapElementTypeManager/generalSettings",
"caption": "General",
"text": "\\rules except wikilink\n\n\\define manage-edge-types()\n <<tmap-row type:\"input-text\"\n title:\"Label\"\n field:\"label\" \n descr:\"An optional alias used as edge-label.\">>\n <<tmap-row type:\"input-checkbox\"\n title:\"Show label\"\n field:\"show-label\"\n default:\"true\"\n descr:\"If unchecked, no edge label will be displayed.\">>\n\\end\n\\define manage-node-types()\n <$list filter=\"[<currentTiddler>!regexp:id[tmap:]]\">\n <<tmap-row type:\"input-textarea\"\n title:\"Scope\"\n field:\"scope\" \n descr:\"A filter expression that defines, which nodes inherit\n this node-type and its style.\">>\n </$list>\n <$macrocall type=\"input-select\"\n $name=\"tmap-row\" \n title=\"Priority\"\n field=\"priority\"\n selectFilter=<<tmap \"scale\" \"100\">>\n descr=\"When a type has a a higher priority than another type,\n its style will override the other style\" />\n\\end\n\n<table class=\"tmap-config-table\">\n <$macrocall\n $name=\"tmap-row\"\n title=\"Identifier\"\n field=\"temp.newId\"\n type=\"input-text\"\n default={{!!id}}\n readonly={{!!temp.idImmutable}}\n descr=\"A unique identifier\"\n />\n <$macrocall $name=<<mode>> />\n</table>"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/MapElementTypeManager/overview": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/MapElementTypeManager/overview",
"caption": "Overview",
"text": "\\rules except wikilink\n\n\\define date(f) <$view field=$f$ format=\"date\" template=\"DDth mmm hh:mm:ss\"/>\n\n! <$link to={{!!typeTRef}}><$view field=\"id\" /></$link>\n\n<table class=\"tmap-key-value-table\">\n <tr>\n <th align=\"left\">Created on</th>\n <td>\n <<date \"created\">>\n </td>\n </tr>\n <tr>\n <th align=\"left\">Modified on</th>\n <td><<date \"modified\">></td>\n </tr>\n <tr>\n <th align=\"left\">Usage count</th>\n <td>\n <span class=\"tmap-edge-type-specific\">\n <$view field=\"temp.usageCount\" />\n </span>\n <span class=\"tmap-node-type-specific\">\n <$count filter={{!!scope}}>0</$count>\n </span>\n </td>\n </tr>\n</table>\n\n<$view field=\"description\">//No description available//</$view>"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/MapElementTypeManager/styling": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/MapElementTypeManager/styling",
"caption": "Styling",
"text": "\\rules except wikilink\n\n\\define url()\n <$set\n filter=\"[<mode>prefix[manage-edge-types]]\"\n name=\"module\"\n value=\"edges\"\n emptyValue=\"nodes\">\n [[visjs.org|http://visjs.org/docs/network/$(module)$]]\n </$set>\n\\end\n\n<fieldset class=\"tmap-node-type-specific\">\n <legend>Icon Settings</legend>\n <table class=\"tmap-config-table\">\n <<tmap-row type:\"input-text\"\n title:\"TW-icon\"\n field:\"tw-icon\"\n descr:\"A tiddlywiki image reference.\n For example '$:/core/icon' for Movotun Jack.\">>\n <<tmap-row type:\"input-text\"\n title:\"FA-icon\"\n field:\"fa-icon\"\n descr:\"A Font Awesome icon code.\n For example 'f206' for the bicycle symbol.\">>\n </table>\n</fieldset>\n\n<fieldset><legend>Visjs styles</legend>\n <div class=\"tmap-flash-message tmap-info\">\n All visjs options below are documented at <<url>>.\n </div>\n <div class=\"tmap-flash-message tmap-info\">\n Only config items that you actually changed have an effect on\n the graph. Other options are visible, yet, inactive.\n </div>\n <$tmap-config\n mode=<<mode>>\n inherited=\"vis-inherited\"\n extension=\"style\" />\n</fieldset>"
},
"$:/plugins/felixhayashi/tiddlymap/dialog/MapElementTypeManager": {
"title": "$:/plugins/felixhayashi/tiddlymap/dialog/MapElementTypeManager",
"subtitle": "{{$:/core/images/tag-button}} <<topic>>",
"buttons": "element_type_manager",
"classes": "tmap-remove-top-space",
"text": "\\rules except wikilink\n\n\\define defaultTab()\n$:/plugins/felixhayashi/tiddlymap/dialog/MapElementTypeManager/overview\n\\end\n\n\\define settingsTab()\n$:/plugins/felixhayashi/tiddlymap/dialog/MapElementTypeManager/generalSettings\n\\end\n\n\\define tabsFilter()\n[all[shadows]prefix[$:/plugins/felixhayashi/tiddlymap/dialog/MapElementTypeManager/]]\n\\end\n\n\\define searchFilter()\n$(searchSelector)$\n+[sort[title]nsort[priority]]\n+[removeprefix<typeRootPath>removeprefix[/]]\n+[search:title{$:/temp/tmap/MapElementTypeSearch}]\n\\end\n\n\\define managerClass() tmap-$(mode)$\n\n\\define typePath() $(typeRootPath)$/$(id)$\n\n<div id=\"tmap-element-type-manager\" class=<<managerClass>>>\n <div>\n <div class=\"tmap-searchbar\">\n <$edit-text\n focus=\"true\"\n tiddler=\"$:/temp/tmap/MapElementTypeSearch\"\n type=\"text\"\n tag=\"input\"\n default=\"\" />\n <$list filter=\"[{$:/temp/tmap/MapElementTypeSearch}regexp[.+]]\n +[addprefix[/]]\n +[addprefix<typeRootPath>]\n +[!is[tiddler]!is[shadow]]\">\n <$button tooltip=\"Create a new type of this name\">\n {{$:/core/images/new-button}}\n <$action-sendmessage\n $message=\"tmap:tm-create-type\"\n mode=<<mode>>\n id={{$:/temp/tmap/MapElementTypeSearch}}\n output=<<output>> />\n <$action-setfield $tiddler=\"$:/temp/tmap/MapElementTypeSearch\" text=\"\" />\n </$button>\n </$list>\n\n </div>\n <ul>\n <$list\n filter=<<searchFilter>>\n emptyMessage=<<noTypeFound>>\n variable=\"id\">\n <li>\n <span class=\"tmap-ranking tmap-node-type-specific\">\n # <$view tiddler=<<typePath>> field=\"priority\">1</$view>\n </span>\n <$button class=\"tc-btn-invisible tmap-link\"><<id>>\n <$action-setfield\n $tiddler=<<qualify \"$:/state/tabs/MapElementTypeManager\">>\n text=<<defaultTab>> />\n <$action-sendmessage\n $message=\"tmap:tm-load-type-form\"\n id=<<id>>\n mode=<<mode>>\n output=<<output>> />\n </$button>\n </li>\n </$list>\n </ul>\n </div>\n <div>\n <$reveal type=\"nomatch\" text=\"\" default={{!!id}} >\n <$macrocall\n $name=\"tabs\"\n default=<<defaultTab>>\n state=\"$:/state/tabs/MapElementTypeManager\"\n tabsList=<<tabsFilter>> />\n </$reveal>\n <$reveal type=\"match\" text=\"\" default={{!!id}} >\n <div class=\"tmap-flash-message tmap-info\">\n Please select a type from the list or create a new one by\n entering the type name in the search field on the left.\n </div>\n <div class=\"tmap-flash-message tmap-info tmap-node-type-specific\">\n The number next to the node-type label represents it's priority.\n </div>\n </$reveal>\n </div>\n</div>\n"
},
"$:/plugins/felixhayashi/tiddlymap/editor/contextMenu/node": {
"title": "$:/plugins/felixhayashi/tiddlymap/editor/contextMenu/node",
"text": "\\define single()\n <$list filter=\"\n [[tmap:tm-toggle-central-topic, $:/core/images/star-filled, Toggle central topic]]\n [[tmap:tm-delete-element, $:/core/images/delete-button, Delete node]]\">\n <$button class=\"tc-btn-invisible\">\n <$action-sendmessage $message=<<tmap \"splitAndSelect\" \", \" \"0\">> />\n <$transclude tiddler=<<tmap \"splitAndSelect\" \", \" \"1\">> />\n <<tmap \"splitAndSelect\" \", \" \"2\">>\n </$button>\n </$list>\n\\end\n\n\\define multi()\n <$list filter=\"\n [[tmap:tm-delete-element, $:/core/images/delete-button, Delete selected nodes]]\">\n <$button class=\"tc-btn-invisible\">\n <$action-sendmessage $message=<<tmap \"splitAndSelect\" \", \" \"0\">> />\n <$transclude tiddler=<<tmap \"splitAndSelect\" \", \" \"1\">> />\n <<tmap \"splitAndSelect\" \", \" \"2\">>\n </$button>\n </$list>\n\\end\n\n<div class=\"tc-drop-down\">\n <$macrocall $name=<<mode>> />\n</div>"
},
"$:/plugins/felixhayashi/tiddlymap/misc/advancedEditorBar": {
"title": "$:/plugins/felixhayashi/tiddlymap/misc/advancedEditorBar",
"text": "\\rules except wikilink\n\\define showEdgeField() show-$(curEdgeId)$\n\n<!-- === View Switcher ========================================== -->\n\n<div class=\"tmap-menu-bar\">\n View:\n <$reveal type=\"match\" text=\"false\" default=<<isViewBound>> >\n <$select\n tiddler=<<viewHolder>>\n field=\"text\"\n default=<<viewLabel>> >\n <$list filter=<<tmap \"option\" \"selector.allViewsByLabel\">> >\n <option value={{!!title}}>\n <$view tiddler={{!!title}} field=\"title\" />\n </option>\n </$list>\n </$select>\n </$reveal>\n <$reveal type=\"match\" text=\"true\" default=<<isViewBound>> >\n <b><<viewLabel>></b>\n </$reveal>\n\n<!-- === Menu =================================================== -->\n\n <$button\n popup=<<qualify \"$:/temp/menu\">>\n tooltip=\"Open the Menu\">{{$:/core/images/menu-button}}\n </$button>\n\n <$reveal type=\"popup\" position=\"below\" state=<<qualify \"$:/temp/menu\">> >\n <div class=\"tc-drop-down\">\n <a href=\"http://tiddlymap.org#Documentation\" target=\"_blank\">\n {{$:/core/images/info-button}} Open online help\n </a>\n <$button class=\"tc-btn-invisible\" message=\"tmap:tm-create-view\">\n {{$:/core/images/new-button}} Create new view\n </$button>\n <$button class=\"tc-btn-invisible\" message=\"tmap:tm-generate-widget\">\n {{$:/core/images/permalink-button}} Grab widget code\n </$button>\n <div class=\"tmap-list-separator\">Global configurations:</div>\n <$button class=\"tc-btn-invisible\" message=\"tmap:tm-configure-system\">\n {{$:/core/images/options-button}} Configure TiddlyMap\n </$button>\n <$button class=\"tc-btn-invisible\" message=\"tmap:tm-manage-edge-types\">\n <span class=\"tmap-unicode-icon\">◭</span> Manage edge-types\n </$button>\n <$button class=\"tc-btn-invisible\" message=\"tmap:tm-manage-node-types\">\n <span class=\"tmap-unicode-icon\">▢</span> Manage node-types\n </$button>\n <div class=\"tmap-view-actions\">\n <div class=\"tmap-list-separator\">Actions for this view:</div>\n <$button class=\"tc-btn-invisible\" message=\"tmap:tm-edit-view\">\n {{$:/core/images/options-button}} Configure view\n </$button>\n <$button class=\"tc-btn-invisible\" message=\"tmap:tm-rename-view\">\n {{$:/core/images/tag-button}} Rename view\n </$button>\n <$button class=\"tc-btn-invisible\" message=\"tmap:tm-delete-view\">\n {{$:/core/images/delete-button}} Delete view\n </$button>\n </div>\n </div>\n </$reveal>\n\n<!-- === Neighbourhood menu ===================================== -->\n\n <$reveal\n type=\"match\"\n text=\"true\"\n default=<<tmap \"option\"\n \"config.sys.editorMenuBar.showNeighScopeButton\">>>\n <$button\n class=<<neighScopeBtnClass>>\n tooltip=\"Change the neighbourhood scope\"\n popup=<<qualify \"$:/temp/neighScope\">>>\n ☀\n </$button>\n </$reveal>\n\n <$reveal type=\"popup\" position=\"below\" state=<<qualify \"$:/temp/neighScope\">> >\n <div class=\"tc-drop-down\">\n <div class=\"tmap-list-separator\">Neighbourhood scope</div>\n <$button class=\"tc-btn-invisible\">None\n <$action-setfield\n $tiddler=<<viewRoot>>\n config.neighbourhood_scope=\"\" />\n </$button>\n <$list filter=\"[[1|1 step distance]]\n [[2|2 step distance]]\n [[3|3 step distance]]\n [[4|4 step distance]]\n [[5|5 step distance]]\">\n <$button class=\"tc-btn-invisible\">\n <<tmap \"splitAndSelect\" \"|\" \"1\">>\n <$action-setfield\n $tiddler=<<viewRoot>>\n config.neighbourhood_scope=<<tmap \"splitAndSelect\" \"|\" \"0\">> />\n </$button>\n </$list>\n <$button class=\"tc-btn-invisible\">No limit\n <$action-setfield\n $tiddler=<<viewRoot>>\n config.neighbourhood_scope=\"100\" />\n </$button>\n <div class=\"tmap-list-separator\">Neighbourhood traversal</div>\n <$radio field=\"config.neighbourhood_directions\" value=\"in\"> Incoming</$radio><br />\n <$radio field=\"config.neighbourhood_directions\" value=\"out\"> Outgoing</$radio><br />\n <$radio field=\"config.neighbourhood_directions\" value=\"\"> Both</$radio>\n <div class=\"tmap-list-separator\">Other</div>\n <$checkbox field=\"config.show_inter_neighbour_edges\"\n checked=\"true\" unchecked=\"false\"> Inter-neighbour edges</$checkbox>\n\n </div>\n </$reveal>\n\n<!-- === Export menu ============================================ -->\n\n <$reveal\n type=\"match\"\n text=\"true\"\n default=<<tmap \"option\" \"config.sys.editorMenuBar.showScreenshotButton\">>>\n <$button tooltip=\"Open the map-export menu\" popup=<<qualify \"$:/temp/mapExport\">>>\n {{$:/core/images/download-button}}\n </$button>\n </$reveal>\n\n <$reveal type=\"popup\" position=\"below\" state=<<qualify \"$:/temp/mapExport\">>>\n <div class=\"tc-drop-down\">\n <$button\n class=\"tc-btn-invisible\"\n tooltip=\"Export the graph and all its elements\n in form of a JSON file\">\n {{$:/core/images/permalink-button}} Save as JSON file\n <$action-sendmessage\n $message=\"tmap:tm-download-graph\"\n view=<<viewLabel>> />\n </$button>\n <$button\n class=\"tc-btn-invisible\"\n tooltip=\"Create a png image to download or save it\n as image or view-placeholder in your wiki\">\n {{$:/core/images/palette}} Save as png image\n <$action-sendmessage $message=\"tmap:tm-save-canvas\" />\n </$button>\n </div>\n </$reveal>\n\n<!-- === Raster menu ============================================ -->\n\n <$reveal\n type=\"match\"\n text=\"true\"\n default=<<tmap \"option\" \"config.sys.editorMenuBar.showRasterMenuButton\">>>\n <$button\n tooltip=\"Change the raster of your map\"\n class=<<rasterMenuBtnClass>>\n popup=<<qualify \"$:/temp/rasterMenu\">>>\n ⩩\n </$button>\n </$reveal>\n\n <$reveal type=\"popup\" position=\"below\" state=<<qualify \"$:/temp/rasterMenu\">>>\n <div class=\"tc-drop-down\">\n <$button class=\"tc-btn-invisible\">Disable raster\n <$action-setfield\n $tiddler=<<viewRoot>>\n config.raster=\"\" />\n </$button>\n <div class=\"tmap-list-separator\">Raster sizes</div>\n <$list filter=\"[[50|50px]]\n [[75|75px]]\n [[100|100px]]\n [[150|150px]]\">\n <$button class=\"tc-btn-invisible\">\n <<tmap \"splitAndSelect\" \"|\" \"1\">>\n <$action-setfield\n $tiddler=<<viewRoot>>\n config.raster=<<tmap \"splitAndSelect\" \"|\" \"0\">> />\n </$button>\n </$list>\n </div>\n </$reveal>\n\n</div>\n"
},
"$:/plugins/felixhayashi/tiddlymap/misc/focusButton": {
"title": "$:/plugins/felixhayashi/tiddlymap/misc/focusButton",
"text": "\\define filter() [list[$:/temp/tmap/nodes/$(viewLabel)$]search:title{$:/temp/tmap/bar/search}]\n\\define concat(str) $str$\n\n\\define state() $(widgetPopupsPath)$/focus\n\n<div class=\"tmap-focus-button\">\n <$reveal type=\"match\" state=<<state>> text=\"\">\n <$button\n tooltip=\"Zoom on a specific node\"\n class=<<tv-config-toolbar-class>>>{{$:/core/images/advanced-search-button}}\n <$action-setfield $tiddler=\"$:/temp/tmap/bar/search\" text=\"\" />\n <$action-setfield $tiddler=<<state>> text=\"1\" />\n </$button>\n </$reveal>\n <$reveal type=\"nomatch\" state=<<state>> text=\"\">\n <$button\n tooltip=\"Close zoom popup\"\n class=<<tv-config-toolbar-class>>>{{$:/core/images/advanced-search-button}}\n <$action-setfield $tiddler=<<state>> text=\"\" />\n </$button>\n <div class=\"tmap-search-dropdown\">\n <div class=\"tc-drop-down\">\n <$edit-text\n focus=\"true\"\n tiddler=\"$:/temp/tmap/bar/search\"\n field=\"text\"\n type=\"text\"\n tag=\"input\"\n default=\"\" />\n <small><$count filter=<<filter>> /> results</small>\n <hr />\n <div class=\"tmap-very-small-list\">\n <$list filter=<<filter>>\n variable=\"item\"\n emptyMessage=\"//No results//\">\n <$button\n class=\"tc-btn-invisible\"\n message=\"tmap:tm-focus-node\"\n param=<<item>>>\n <$view tiddler=<<item>> field=\"title\" />\n </$button>\n </$list>\n </div>\n </div>\n </div>\n </$reveal>\n</div>"
},
"$:/plugins/felixhayashi/tiddlymap/hook/editor": {
"title": "$:/plugins/felixhayashi/tiddlymap/hook/editor",
"caption": "Map",
"tags": "$:/tags/SideBar",
"text": "\\define width() calc(100% - 15px)\n\n<div class=\"tmap-mobile-editor\">\n <div class=\"tmap-flash-message tmap-warning\">\n The editor is not displayed in mobile mode.\n </div>\n</div>\n<div class=\"tmap-desktop-editor\">\n <$tiddlymap\n class=\"tmap-sidebar-map-editor\"\n editor=\"advanced\"\n object-id=\"main_editor\"\n click-to-use=\"false\">\n </$tiddlymap>\n</div>"
},
"$:/plugins/felixhayashi/tiddlymap/hook/liveTab": {
"title": "$:/plugins/felixhayashi/tiddlymap/hook/liveTab",
"caption": "Live",
"text": "\\define width() calc(100% - 15px)\n\n<div class=\"tmap-mobile-editor\">\n <div class=\"tmap-flash-message tmap-warning\">\n The live tab is not displayed in mobile mode.\n </div>\n</div>\n<div class=\"tmap-desktop-editor\">\n <$set name=\"view\"\n filter=\"[{$:/temp/tmap/currentTiddler}get[tmap.open-view]]\"\n emptyValue=<<tmap \"option\" \"config.sys.liveTab.fallbackView\">>>\n <div>\n <$tiddlymap\n view=<<view>>\n click-to-use=\"false\"\n refresh-triggers=\"$:/temp/tmap/currentTiddler\"\n object-id=\"live_tab\">\n </$tiddlymap>\n </div>\n </$set> \n</div>"
},
"$:/plugins/felixhayashi/tiddlymap/misc/quickConnectButton": {
"title": "$:/plugins/felixhayashi/tiddlymap/misc/quickConnectButton",
"tags": "$:/tags/ViewToolbar",
"description": "{{$:/language/Buttons/TiddlyMap/Hint}}",
"caption": "{{$:/plugins/felixhayashi/tiddlymap/icon}} {{$:/language/Buttons/TiddlyMap/Caption}}",
"text": "\\define buttonClass() $(tv-config-toolbar-class)$ $(additional-classes)$\n\n\\define nonExistentItem()\n<<item>> <span style=\"color: #9E9E9E\">(will be created)</span>\n\\end\n\n\\define noConnectionsMsg()\n<tr><td colspan=\"4\">//No connections found!//</td></tr>\n\\end\n\n\\define normalSearchFilter()\n[!is[system]!has[draft.of]search:title{$:/temp/quickConnectSearch}sortcs[title]limit[50]]\n\\end\n\n\\define regexSearchFilter()\n[!is[system]!has[draft.of]regexp{$:/temp/quickConnectSearch}sortcs[title]limit[50]]\n\\end\n\n\\define showButton(state)\n<$button set=\"$:/temp/tmap/state/popup/quickConnect\"\n setTo=\"$state$\" tooltip={{$:/language/Buttons/TiddlyMap/Hint}} \n aria-label={{$:/language/Buttons/TiddlyMap/Caption}}\n class=<<buttonClass>>>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">{{$:/plugins/felixhayashi/tiddlymap/icon}}</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/TiddlyMap/Caption}}/></span>\n</$list>\n</$button>\n\\end\n\n\\define searchResults()\n<td>\n <$button tooltip=\"Create incoming edge\">\n <<tmap \"option\" \"misc.arrows.in\">>\n <$action-sendmessage $message=\"tmap:tm-create-edge\"\n from=<<item>>\n to=<<currentTiddler>>\n force=\"true\"\n label={{$:/temp/quickConnectSearch/type}}\n view={{$:/temp/quickConnectSearch/view}} />\n </$button>\n</td>\n<td>\n <$button tooltip=\"Create outgoing edge\">\n <<tmap \"option\" \"misc.arrows.out\">>\n <$action-sendmessage $message=\"tmap:tm-create-edge\"\n from=<<currentTiddler>>\n to=<<item>>\n force=\"true\"\n label={{$:/temp/quickConnectSearch/type}}\n view={{$:/temp/quickConnectSearch/view}} />\n </$button>\n</td>\n<td>\n <$list\n filter=\"[<item>is[tiddler]]\"\n emptyMessage=<<nonExistentItem>>>\n <$view tiddler=<<item>> field=\"title\" />\n </$list>\n</td>\n\\end\n\n\\define hidePopup()\n<$macrocall $name=\"showButton\" state=<<qualify>> />\n\\end\n\n\\define showPopup()\n<$set name=\"additional-classes\" value=\"tmap-active-button\">\n <$macrocall $name=\"showButton\" state=\"\" />\n</$set>\n<$set\n name=\"searchFilter\"\n filter=\"[field:title[$:/state/tmap/tid-toolbar]has[re-filter]]\"\n value=<<regexSearchFilter>>\n emptyValue=<<normalSearchFilter>>>\n<div class=\"tmap-quick-connect tc-reveal tc-popup\">\n <div class=\"tc-drop-down\">\n <div class=\"title\">Create connection</div>\n <table class=\"tmap-quick-connect-search-bar\">\n <tr>\n <td>Type:</td>\n <td>\n <$edit-text\n tiddler=\"$:/temp/quickConnectSearch/type\"\n field=\"text\"\n type=\"text\"\n tag=\"input\"\n default=\"\" />\n <$select tiddler=\"$:/temp/quickConnectSearch/type\" default=\"\">\n <option></option>\n <$list filter=<<tmap \"option\" \"selector.allEdgeTypesById\">>>\n <option>{{!!title}}</option>\n </$list>\n </$select>\n </td>\n </tr>\n <tr>\n <td>Search:</td>\n <td>\n <$edit-text tiddler=\"$:/temp/quickConnectSearch\" type=\"text\" tag=\"input\" default=\"\"></$edit-text>\n <$checkbox\n tiddler=\"$:/state/tmap/tid-toolbar\"\n field=\"re-filter\"\n checked=\"1\"\n unchecked=\"\"\n default=\"\"> regexp\n </$checkbox>\n<!--\n <small>(<$count filter=<<searchFilter>> /> results)</small>\n-->\n </td>\n </tr>\n </table>\n <table class=\"tmap-create-connection-table\">\n <tr>\n <td colspan=\"2\">\n <table class=\"tmap-very-small-list\">\n <$list\n filter=<<searchFilter>>\n variable=\"item\">\n <tr><<searchResults>></tr>\n </$list>\n <tr>\n <$list filter=\"[{$:/temp/quickConnectSearch}regexp[.+]] -[is[tiddler]]\" variable=\"item\">\n <<searchResults>>\n </$list>\n </tr>\n </table>\n </td>\n </tr>\n </table>\n <div class=\"title\">Existing Connections</div>\n <div class=\"tmap-quick-connect-existing-bar\">\n <$select\n tiddler=\"$:/state/tmap/tid-toolbar\"\n field=\"direction\"\n default=\"both\">\n <option value=\"both\">both</option>\n <option value=\"in\">incoming</option>\n <option value=\"out\">outgoing</option>\n </$select>\n <$checkbox\n tiddler=\"$:/state/tmap/tid-toolbar\"\n field=\"filter.links\"\n checked=\"-[[tw-body:link]]\"\n unchecked=\"\"\n default=\"\"> hide links\n </$checkbox>\n </div>\n <table class=\"tmap-connection-table\">\n<!--\n <tr>\n <th></th>\n <th>Tiddler</th>\n <th>Type</th>\n <th></th>\n </tr>\n-->\n \n <$tmap-connections\n filter=<<tmap mergeFields \"$:/state/tmap/tid-toolbar\" \"filter.\">>\n direction={{$:/state/tmap/tid-toolbar!!direction}}\n emptyMessage=<<noConnectionsMsg>>>\n <tr>\n <td title=<<direction>>><<directionSymbol>></td>\n <td><$link to=<<neighbour>>><$view field=\"title\" /></$link></td>\n <td><<edge.type>></td>\n <td>\n <$button\n tooltip=\"Delete this connection\"\n class=\"tc-btn-invisible\">{{$:/core/images/close-button}}\n <$action-sendmessage $message=\"tmap:tm-remove-edge\"\n id=<<edge.id>>\n from=<<edge.from>>\n to=<<edge.to>>\n type=<<edge.type>> />\n </$button>\n </td>\n </tr>\n </$tmap-connections>\n </table> \n </div>\n</div>\n</$set>\n\\end\n\n<$list filter=\"[all[current]is[tiddler]]\"><$list filter=\"[{$:/temp/tmap/state/popup/quickConnect}prefix<qualify>]\" variable=\"item\" emptyMessage=<<hidePopup>>><<showPopup>></$list></$list>"
},
"$:/plugins/felixhayashi/tiddlymap/media/fullscreen.png": {
"title": "$:/plugins/felixhayashi/tiddlymap/media/fullscreen.png",
"type": "image/png",
"text": "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"
},
"$:/plugins/felixhayashi/tiddlymap/media/halfscreen.png": {
"title": "$:/plugins/felixhayashi/tiddlymap/media/halfscreen.png",
"type": "image/png",
"text": "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"
},
"$:/plugins/felixhayashi/tiddlymap/icon": {
"title": "$:/plugins/felixhayashi/tiddlymap/icon",
"tags": "$:/tags/Image",
"text": "<svg\n xmlns:dc=\"http://purl.org/dc/elements/1.1/\"\n xmlns:cc=\"http://creativecommons.org/ns#\"\n xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\"\n xmlns:svg=\"http://www.w3.org/2000/svg\"\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlns:inkscape=\"http://www.inkscape.org/namespaces/inkscape\"\n class=\"tc-image-tiddlymap-button tc-image-button\"\n version=\"1.1\"\n width=\"22pt\"\n height=\"22pt\"\n viewBox=\"0 0 128 128\">\n <defs\n id=\"defs4\">\n <marker\n refX=\"0\"\n refY=\"0\"\n orient=\"auto\"\n id=\"Arrow1Lend\"\n style=\"overflow:visible\">\n <path\n d=\"M 0,0 5,-5 -12.5,0 5,5 0,0 z\"\n transform=\"matrix(-0.8,0,0,-0.8,-10,0)\"\n id=\"path3850\"\n style=\"fill-rule:evenodd;stroke:#000000;stroke-width:1pt\" />\n </marker>\n <marker\n refX=\"0\"\n refY=\"0\"\n orient=\"auto\"\n id=\"Arrow1Lstart\"\n style=\"overflow:visible\">\n <path\n d=\"M 0,0 5,-5 -12.5,0 5,5 0,0 z\"\n transform=\"matrix(0.8,0,0,0.8,10,0)\"\n id=\"path3847\"\n style=\"fill-rule:evenodd;stroke:#000000;stroke-width:1pt\" />\n </marker>\n <inkscape:path-effect\n effect=\"skeletal\"\n id=\"path-effect4329\" />\n <inkscape:path-effect\n effect=\"skeletal\"\n id=\"path-effect4321\" />\n <inkscape:path-effect\n effect=\"skeletal\"\n id=\"path-effect4315\" />\n <inkscape:path-effect\n effect=\"skeletal\"\n id=\"path-effect4307\" />\n <inkscape:path-effect\n effect=\"skeletal\"\n id=\"path-effect4299\" />\n <inkscape:path-effect\n effect=\"skeletal\"\n id=\"path-effect4293\" />\n </defs>\n <g\n transform=\"translate(0,-1024.5289)\"\n id=\"layer1\">\n <path\n d=\"m 17.867073,4.5821643 a 3.7249374,3.7249374 0 1 1 -7.449875,0 3.7249374,3.7249374 0 1 1 7.449875,0 z\"\n transform=\"matrix(-6.3328802,0,0,6.2775831,193.9581,1100.3667)\"\n id=\"path4139-1-14\"\n style=\"fill-opacity:1;fill-rule:nonzero\" />\n <path\n d=\"M 77.450496,1064.5069 C 58.849552,1025.9634 15.704158,1023.3858 2.8821873e-7,1034.558 L 0.02388589,1035.2674 C 24.502636,1022.2072 44.810725,1042.1507 60.163934,1074.112 z\"\n id=\"path4337\"\n style=\"fill-opacity:1;stroke-width:0.58181816;stroke-miterlimit:4;stroke-dasharray:none;marker-start:none;marker-end:none\" />\n <path\n d=\"m 12.878637,11.280739 4.75937,-2.7478243 4.759371,-2.7478236 0,5.4956479 0,5.495648 -4.759371,-2.747824 z\"\n transform=\"matrix(4.6545455,0,0,4.6545455,-13.580429,1027.7638)\"\n id=\"path3004\"\n style=\"fill-opacity:1;fill-rule:nonzero\" />\n </g>\n <metadata\n id=\"metadata3772\">\n <rdf:RDF>\n <cc:Work\n rdf:about=\"\">\n <dc:title></dc:title>\n <dc:format>image/svg+xml</dc:format>\n <dc:type\n rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\" />\n </cc:Work>\n </rdf:RDF>\n </metadata>\n</svg>\n"
},
"$:/plugins/felixhayashi/tiddlymap/media/surface.png": {
"title": "$:/plugins/felixhayashi/tiddlymap/media/surface.png",
"type": "image/png",
"text": "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"
},
"$:/language/Buttons/TiddlyMap/Caption": {
"title": "$:/language/Buttons/TiddlyMap/Caption",
"text": "tiddlymap"
},
"$:/language/Buttons/TiddlyMap/Hint": {
"title": "$:/language/Buttons/TiddlyMap/Hint",
"text": "Toggle TiddlyMap actions"
},
"$:/plugins/felixhayashi/tiddlymap/misc/macros": {
"title": "$:/plugins/felixhayashi/tiddlymap/misc/macros",
"text": "\\define concat(str) $str$\n\n\\define input-text(field, index, default, readonly, class, focus)\n <$reveal type=\"match\" text=\"\" default=\"$readonly$\">\n <$edit-text\n tiddler=<<output>>\n field=\"$field$\"\n index=\"$index$\"\n type=\"text\"\n tag=\"input\"\n default=\"$default$\"\n focus=\"$focus$\"\n class=\"$class$\" />\n </$reveal>\n <$reveal type=\"nomatch\" text=\"\" default=\"$readonly$\">\n <input type=\"text\" value=\"$default$\" readonly=\"true\" disabled=\"true\" />\n </$reveal>\n\\end\n\n\\define input-button(field, index, default, default, label:\"Proceed\")\n <div class=\"tmap-button-wrapper\">\n <$button>$label$\n <$action-setfield $tiddler=<<output>> $field=\"$field$\" index=\"$index$\" $value=\"$default$\" />\n </$button>\n </div>\n\\end\n\n\\define input-textarea(field, index, default, default, class, focus)\n <$edit-text\n tiddler=<<output>>\n field=\"$field$\"\n index=\"$index$\"\n autoHeight=\"no\"\n type=\"text\"\n tag=\"textarea\"\n default=\"$default$\"\n class=\"$class$\"\n focus=\"$focus$\" />\n\\end\n\n\\define input-checkbox(field, index, readonly, default)\n <$reveal type=\"match\" text=\"\" default=\"$readonly$\">\n <$checkbox\n tiddler=<<output>>\n field=\"$field$\"\n index=\"$index$\"\n checked=\"true\"\n unchecked=\"false\"\n default=\"$default$\" />\n </$reveal>\n <$reveal type=\"nomatch\" text=\"\" default=\"$readonly$\">\n <input type=\"checkbox\" value=\"$default$\" readonly=\"true\" disabled=\"true\" />\n </$reveal>\n\\end\n\n\\define input-multi-checkbox(selectFilter, invert:\"no\", default)\n <div class=\"tmap-no-stretch\">\n <$list\n filter=\"$selectFilter$\"\n emptyMessage=\"– This list contains no items –\">\n <$checkbox\n tiddler=<<output>>\n tag=<<tmap \"splitAndSelect\" \"|\" \"0\">>>\n <$view\n tiddler=<<tmap \"splitAndSelect\" \"|\" \"1\">>\n field=\"title\" />\n </$checkbox><br />\n </$list>\n </div>\n\\end\n\n\\define input-select(field, index, selectFilter, default, nochoice)\n <$select\n tiddler=<<output>>\n field=\"$field$\"\n index=\"$index$\"\n default=\"$default$\">\n <$set name=\"nochoice\" value=\"$nochoice$\">\n <$list filter=\"[<nochoice>regexp[.+]]\">\n <option value=\"\"><b><<nochoice>></b></option>\n </$list>\n </$set>\n <$list filter=\"$selectFilter$\">\n <option value=<<tmap \"splitAndSelect\" \"|\" \"0\">> >\n <$view tiddler=<<tmap \"splitAndSelect\" \"|\" \"1\">> field=\"title\" />\n </option>\n </$list>\n </$select>\n\\end\n\n\\define input-radio(field, index, selectFilter, default)\n <$list filter=\"$selectFilter$\">\n <$radio\n tiddler=<<output>>\n field=\"$field$\"\n index=\"$index$\"\n value=<<tmap \"splitAndSelect\" \"|\" \"0\">>>\n <<tmap \"splitAndSelect\" \"|\" \"1\">>\n </$radio><br />\n </$list>\n\\end\n\n\\define tmap-row(title, field, index, type, descr, note, label, default, readonly, reset, selectFilter, nochoice, invert, class, focus)\n <tr>\n <td class=\"tmap-title\">$title$:</td>\n <td>\n <<$type$\n field:\"$field$\"\n index:\"$index$\"\n readonly:\"$readonly$\"\n default:\"$default$\"\n label:\"$label$\"\n invert:\"$invert$\"\n selectFilter:\"$selectFilter$\"\n nochoice:\"$nochoice$\"\n focus:\"$focus$\"\n class:\"$class$\">>\n <$reveal type=\"match\" text=\"true\" default=\"$reset$\">\n <$button>reset\n <$action-setfield $tiddler=<<output>> $field=\"$field$\" $index=\"$index$\" $value=\"$default$\" />\n </$button>\n </$reveal>\n </td>\n <td>\n <span class=\"tmap-description\">$descr$</span>\n <$reveal type=\"nomatch\" text=\"\" default=\"$note$\">\n <div class=\"tmap-note\">''Note:'' $note$</div>\n </$reveal>\n </td>\n </tr>\n\\end\n\n\\define visConfiguration(inheritedList, extensionField, styleName:\"style\")\n <fieldset><legend>Visjs configurations ($styleName$)</legend>\n <div class=\"tmap-flash-message tmap-info\">\n Only config items that you actually changed have an effect on\n the graph. Other options are visible, yet, inactive.\n </div>\n <$tmap-config\n mode=\"manage-node-types\"\n inherited=\"$inheritedList$\"\n extension=\"$extensionField$\" />\n </fieldset>\n\\end\n"
},
"$:/plugins/felixhayashi/tiddlymap/misc/defaultViewHolder": {
"title": "$:/plugins/felixhayashi/tiddlymap/misc/defaultViewHolder",
"text": "Default"
},
"$:/plugins/felixhayashi/tiddlymap/graph/nodeTypes/tmap:central-topic": {
"title": "$:/plugins/felixhayashi/tiddlymap/graph/nodeTypes/tmap:central-topic",
"description": "The style is applied to the node that you marked as central topic in a map.",
"style": "{\"font\":{\"size\":22,\"color\":\"rgba(0,0,0,1)\"},\"shape\":\"star\"}"
},
"$:/plugins/felixhayashi/tiddlymap/graph/nodeTypes/tmap:neighbour": {
"title": "$:/plugins/felixhayashi/tiddlymap/graph/nodeTypes/tmap:neighbour",
"description": "Neighbours are all nodes that are not part of the original set of nodes (\"matches\") but are connected (either outgoing or incoming) to a node of the original set.",
"style": "{\"color\":\"#565656\"}"
},
"$:/plugins/felixhayashi/tiddlymap/graph/views/Default/filter/edges": {
"title": "$:/plugins/felixhayashi/tiddlymap/graph/views/Default/filter/edges"
},
"$:/plugins/felixhayashi/tiddlymap/graph/views/Default/filter/nodes": {
"title": "$:/plugins/felixhayashi/tiddlymap/graph/views/Default/filter/nodes"
},
"$:/plugins/felixhayashi/tiddlymap/graph/views/Default": {
"title": "$:/plugins/felixhayashi/tiddlymap/graph/views/Default",
"config.physics_mode": "false",
"isview": "true"
},
"$:/plugins/felixhayashi/tiddlymap/graph/views/Live View/filter/edges": {
"title": "$:/plugins/felixhayashi/tiddlymap/graph/views/Live View/filter/edges",
"filter": "[prefix[$:/plugins/felixhayashi/tiddlymap/graph/edgeTypes]]",
"text": "\n\n"
},
"$:/plugins/felixhayashi/tiddlymap/graph/views/Live View/filter/nodes": {
"title": "$:/plugins/felixhayashi/tiddlymap/graph/views/Live View/filter/nodes",
"filter": "[field:title{$:/temp/tmap/currentTiddler}]"
},
"$:/plugins/felixhayashi/tiddlymap/graph/views/Live View": {
"title": "$:/plugins/felixhayashi/tiddlymap/graph/views/Live View",
"config.neighbourhood_scope": "1",
"config.refresh-triggers": "$:/temp/tmap/currentTiddler",
"config.physics_mode": "true",
"config.vis": "{\"physics\":{\"forceAtlas2Based\":{\"springLength\":0,\"springConstant\":0.09}}}",
"isview": "true"
},
"$:/plugins/felixhayashi/tiddlymap/graph/views/Graph search/filter/nodes": {
"title": "$:/plugins/felixhayashi/tiddlymap/graph/views/Graph search/filter/nodes",
"filter": "[!is[system]search{$:/temp/search}] [!is[system]search:tags{$:/temp/search}] [!is[system]search:text{$:/temp/search}limit[10]]"
},
"$:/plugins/felixhayashi/tiddlymap/graph/views/Graph search": {
"title": "$:/plugins/felixhayashi/tiddlymap/graph/views/Graph search",
"config.refresh-triggers": "$:/temp/search",
"config.neighbourhood_scope": "1",
"config.physics_mode": "true"
}
}
}
{
"field.nodeLabel": "caption",
"field.nodeIcon": "icon",
"field.nodeInfo": "description",
"field.viewMarker": "isview",
"liveTab.fallbackView": "Live View",
"edgeClickBehaviour": "manager",
"debug": "false",
"notifications": "true",
"popups.enabled": "true",
"popups.delay": "600",
"popups.width": "240px",
"popups.height": "140px",
"jsonIndentation": "1",
"alwaysAddNodeIdToViewFilter": "true",
"editNodeOnCreate": "false",
"singleClickMode": "true",
"nodeFilterNeighbours": "false",
"editorMenuBar.showNeighScopeButton": "true",
"editorMenuBar.showRasterMenuButton": "true",
"editorMenuBar.showScreenshotButton": "true",
"defaultView": "Live View",
"suppressedDialogs.dublicateIdInfo": true
}
\define single()
<$list filter="
[[tmap:tm-toggle-central-topic, $:/core/images/star-filled, Toggle central topic]]
[[tmap:tm-delete-element, $:/core/images/delete-button, Delete node]]">
<$button class="tc-btn-invisible">
<$action-sendmessage $message=<<tmap "splitAndSelect" ", " "0">> />
<$transclude tiddler=<<tmap "splitAndSelect" ", " "1">> />
<<tmap "splitAndSelect" ", " "2">>
</$button>
</$list>
\end
\define multi()
<$list filter="
[[tmap:tm-delete-element, $:/core/images/delete-button, Delete selected nodes]]">
<$button class="tc-btn-invisible">
<$action-sendmessage $message=<<tmap "splitAndSelect" ", " "0">> />
<$transclude tiddler=<<tmap "splitAndSelect" ", " "1">> />
<<tmap "splitAndSelect" ", " "2">>
</$button>
</$list>
\end
<div class="tc-drop-down">
<$macrocall $name=<<mode>> />
</div>
{
"7970a196-d9eb-40ad-8ae2-63c34537068a": {
"x": 0,
"y": 0
}
}
\define width() calc(100% - 15px)
<div class="tmap-mobile-editor">
</div>
<div class="tmap-desktop-editor">
<$tiddlymap
class="tmap-sidebar-map-editor"
editor="advanced"
object-id="main_editor"
click-to-use="false">
</$tiddlymap>
</div>
{
"originalVersion": "0.15.3+9736",
"dataStructureState": "0.11.0",
"showWelcomeMessage": false
}
{
"tiddlers": {
"$:/plugins/felixhayashi/vis/img/network/acceptDeleteIcon.png": {
"title": "$:/plugins/felixhayashi/vis/img/network/acceptDeleteIcon.png",
"type": "image/png",
"text": "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/GMzLdsAAEEOaVRYdFhNTDpjb20uYWRvYmUueG1wAAAAAAA8P3hwYWNrZXQgYmVnaW49Iu+7vyIgaWQ9Ilc1TTBNcENlaGlIenJlU3pOVGN6a2M5ZCI/Pgo8eDp4bXBtZXRhIHhtbG5zOng9ImFkb2JlOm5zOm1ldGEvIiB4OnhtcHRrPSJBZG9iZSBYTVAgQ29yZSA1LjUtYzAyMSA3OS4xNTQ5MTEsIDIwMTMvMTAvMjktMTE6NDc6MTYgICAgICAgICI+CiAgIDxyZGY6UkRGIHhtbG5zOnJkZj0iaHR0cDovL3d3dy53My5vcmcvMTk5OS8wMi8yMi1yZGYtc3ludGF4LW5zIyI+CiAgICAgIDxyZGY6RGVzY3JpcHRpb24gcmRmOmFib3V0PSIiCiAgICAgICAgICAgIHhtbG5zOnhtcD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLyIKICAgICAgICAgICAgeG1sbnM6ZGM9Imh0dHA6Ly9wdXJsLm9yZy9kYy9lbGVtZW50cy8xLjEvIgogICAgICAgICAgICB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIKICAgICAgICAgICAgeG1sbnM6c3RFdnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZUV2ZW50IyIKICAgICAgICAgICAgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiCiAgICAgICAgICAgIHhtbG5zOnBob3Rvc2hvcD0iaHR0cDovL25zLmFkb2JlLmNvbS9waG90b3Nob3AvMS4wLyIKICAgICAgICAgICAgeG1sbnM6dGlmZj0iaHR0cDovL25zLmFkb2JlLmNvbS90aWZmLzEuMC8iCiAgICAgICAgICAgIHhtbG5zOmV4aWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20vZXhpZi8xLjAvIj4KICAgICAgICAgPHhtcDpDcmVhdG9yVG9vbD5BZG9iZSBQaG90b3Nob3AgQ0MgKFdpbmRvd3MpPC94bXA6Q3JlYXRvclRvb2w+CiAgICAgICAgIDx4bXA6Q3JlYXRlRGF0ZT4yMDE0LTAxLTIyVDE5OjI0OjUxKzAxOjAwPC94bXA6Q3JlYXRlRGF0ZT4KICAgICAgICAgPHhtcDpNZXRhZGF0YURhdGU+MjAxNC0wMi0wNVQxNjo0NTowOCswMTowMDwveG1wOk1ldGFkYXRhRGF0ZT4KICAgICAgICAgPHhtcDpNb2RpZnlEYXRlPjIwMTQtMDItMDVUMTY6NDU6MDgrMDE6MDA8L3htcDpNb2RpZnlEYXRlPgogICAgICAgICA8ZGM6Zm9ybWF0PmltYWdlL3BuZzwvZGM6Zm9ybWF0PgogICAgICAgICA8eG1wTU06SW5zdGFuY2VJRD54bXAuaWlkOjBmYzFjNjhhLTcwZTYtMGY0Ni05ZDk4LWFhNDVjNjYxYThjODwveG1wTU06SW5zdGFuY2VJRD4KICAgICAgICAgPHhtcE1NOkRvY3VtZW50SUQ+eG1wLmRpZDpFQTc2MkY5Njc0ODNFMzExOTQ4QkQxM0UyQkU3OTlBMTwveG1wTU06RG9jdW1lbnRJRD4KICAgICAgICAgPHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD54bXAuZGlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC94bXBNTTpPcmlnaW5hbERvY3VtZW50SUQ+CiAgICAgICAgIDx4bXBNTTpIaXN0b3J5PgogICAgICAgICAgICA8cmRmOlNlcT4KICAgICAgICAgICAgICAgPHJkZjpsaSByZGY6cGFyc2VUeXBlPSJSZXNvdXJjZSI+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDphY3Rpb24+Y3JlYXRlZDwvc3RFdnQ6YWN0aW9uPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6aW5zdGFuY2VJRD54bXAuaWlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC9zdEV2dDppbnN0YW5jZUlEPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6d2hlbj4yMDE0LTAxLTIyVDE5OjI0OjUxKzAxOjAwPC9zdEV2dDp3aGVuPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6c29mdHdhcmVBZ2VudD5BZG9iZSBQaG90b3Nob3AgQ1M2IChXaW5kb3dzKTwvc3RFdnQ6c29mdHdhcmVBZ2VudD4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6YWN0aW9uPnNhdmVkPC9zdEV2dDphY3Rpb24+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDppbnN0YW5jZUlEPnhtcC5paWQ6RUE2MEEyNEUxOTg0RTMxMUFEQUZFRkU2RUMzMzNFMDM8L3N0RXZ0Omluc3RhbmNlSUQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDp3aGVuPjIwMTQtMDEtMjNUMTk6MTg6MDcrMDE6MDA8L3N0RXZ0OndoZW4+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpzb2Z0d2FyZUFnZW50PkFkb2JlIFBob3Rvc2hvcCBDUzYgKFdpbmRvd3MpPC9zdEV2dDpzb2Z0d2FyZUFnZW50PgogICAgICAgICAgICAgICAgICA8c3RFdnQ6Y2hhbmdlZD4vPC9zdEV2dDpjaGFuZ2VkPgogICAgICAgICAgICAgICA8L3JkZjpsaT4KICAgICAgICAgICAgICAgPHJkZjpsaSByZGY6cGFyc2VUeXBlPSJSZXNvdXJjZSI+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDphY3Rpb24+c2F2ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0Omluc3RhbmNlSUQ+eG1wLmlpZDpiYzZmYmUxNi1mOTBkLWI1NDQtODUzOC05MjFkNjBiZjU0ZWI8L3N0RXZ0Omluc3RhbmNlSUQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDp3aGVuPjIwMTQtMDItMDVUMTY6NDU6MDgrMDE6MDA8L3N0RXZ0OndoZW4+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpzb2Z0d2FyZUFnZW50PkFkb2JlIFBob3Rvc2hvcCBDQyAoV2luZG93cyk8L3N0RXZ0OnNvZnR3YXJlQWdlbnQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpjaGFuZ2VkPi88L3N0RXZ0OmNoYW5nZWQ+CiAgICAgICAgICAgICAgIDwvcmRmOmxpPgogICAgICAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmFjdGlvbj5jb252ZXJ0ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnBhcmFtZXRlcnM+ZnJvbSBhcHBsaWNhdGlvbi92bmQuYWRvYmUucGhvdG9zaG9wIHRvIGltYWdlL3BuZzwvc3RFdnQ6cGFyYW1ldGVycz4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6YWN0aW9uPmRlcml2ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnBhcmFtZXRlcnM+Y29udmVydGVkIGZyb20gYXBwbGljYXRpb24vdm5kLmFkb2JlLnBob3Rvc2hvcCB0byBpbWFnZS9wbmc8L3N0RXZ0OnBhcmFtZXRlcnM+CiAgICAgICAgICAgICAgIDwvcmRmOmxpPgogICAgICAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmFjdGlvbj5zYXZlZDwvc3RFdnQ6YWN0aW9uPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6aW5zdGFuY2VJRD54bXAuaWlkOjBmYzFjNjhhLTcwZTYtMGY0Ni05ZDk4LWFhNDVjNjYxYThjODwvc3RFdnQ6aW5zdGFuY2VJRD4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OndoZW4+MjAxNC0wMi0wNVQxNjo0NTowOCswMTowMDwvc3RFdnQ6d2hlbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnNvZnR3YXJlQWdlbnQ+QWRvYmUgUGhvdG9zaG9wIENDIChXaW5kb3dzKTwvc3RFdnQ6c29mdHdhcmVBZ2VudD4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmNoYW5nZWQ+Lzwvc3RFdnQ6Y2hhbmdlZD4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgIDwvcmRmOlNlcT4KICAgICAgICAgPC94bXBNTTpIaXN0b3J5PgogICAgICAgICA8eG1wTU06RGVyaXZlZEZyb20gcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICA8c3RSZWY6aW5zdGFuY2VJRD54bXAuaWlkOmJjNmZiZTE2LWY5MGQtYjU0NC04NTM4LTkyMWQ2MGJmNTRlYjwvc3RSZWY6aW5zdGFuY2VJRD4KICAgICAgICAgICAgPHN0UmVmOmRvY3VtZW50SUQ+eG1wLmRpZDpFQTc2MkY5Njc0ODNFMzExOTQ4QkQxM0UyQkU3OTlBMTwvc3RSZWY6ZG9jdW1lbnRJRD4KICAgICAgICAgICAgPHN0UmVmOm9yaWdpbmFsRG9jdW1lbnRJRD54bXAuZGlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC9zdFJlZjpvcmlnaW5hbERvY3VtZW50SUQ+CiAgICAgICAgIDwveG1wTU06RGVyaXZlZEZyb20+CiAgICAgICAgIDxwaG90b3Nob3A6Q29sb3JNb2RlPjM8L3Bob3Rvc2hvcDpDb2xvck1vZGU+CiAgICAgICAgIDxwaG90b3Nob3A6SUNDUHJvZmlsZT5zUkdCIElFQzYxOTY2LTIuMTwvcGhvdG9zaG9wOklDQ1Byb2ZpbGU+CiAgICAgICAgIDx0aWZmOk9yaWVudGF0aW9uPjE8L3RpZmY6T3JpZW50YXRpb24+CiAgICAgICAgIDx0aWZmOlhSZXNvbHV0aW9uPjcyMDA5MC8xMDAwMDwvdGlmZjpYUmVzb2x1dGlvbj4KICAgICAgICAgPHRpZmY6WVJlc29sdXRpb24+NzIwMDkwLzEwMDAwPC90aWZmOllSZXNvbHV0aW9uPgogICAgICAgICA8dGlmZjpSZXNvbHV0aW9uVW5pdD4yPC90aWZmOlJlc29sdXRpb25Vbml0PgogICAgICAgICA8ZXhpZjpDb2xvclNwYWNlPjE8L2V4aWY6Q29sb3JTcGFjZT4KICAgICAgICAgPGV4aWY6UGl4ZWxYRGltZW5zaW9uPjI0PC9leGlmOlBpeGVsWERpbWVuc2lvbj4KICAgICAgICAgPGV4aWY6UGl4ZWxZRGltZW5zaW9uPjI0PC9leGlmOlBpeGVsWURpbWVuc2lvbj4KICAgICAgPC9yZGY6RGVzY3JpcHRpb24+CiAgIDwvcmRmOlJERj4KPC94OnhtcG1ldGE+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgCjw/eHBhY2tldCBlbmQ9InciPz450LuoAAAAIGNIUk0AAHolAACAgwAA+f8AAIDpAAB1MAAA6mAAADqYAAAXb5JfxUYAAATUSURBVHjajJZtTJVlGMd/13U/z+F4sBQOCiovZiMt8YiKZrMtypdh09StbLOtzA1RUmuTkppzIilJOB0Oa21tbaV+6UP5Mlnm5heVkfhyQJ1ONITAkAMqcTDonNOHA6g9qF3b/eF5/vf18r/u676uWwoLC3G73QCoKiICgIhQeGejVw3LMOTIP0xGdRQAFi1E9DyGSkLsKxtWEmAQuXfvHrJlyxZiYmIQkQHjeac/jjfKBsJ8YlnRzQKIgBoIh8ByaRSICAilRCjdk1UeAIhEIogIPT09SFFRER6PZ4DByqr1+WpRoYAquKYuqCPz9SZeeCVA4vggAC2XPVw54eXi0WTOH8yIslIIs+bryTsq+hl0d3cjxcXFuN1uVJVVp9dvEigSwP3iYj9vfV7L6IldPE5uXvZwcKuPsz/7+qLc/I1vexFAMBjEzJ49G9u2WV1TsEaVUhOBmJxVVeR9X8NTI3t5kgxN6GXakia67/bSeC4ZkexprccCZxLnVodCIRRgdU1BgsBuBVzz8qt49yv/oMb2f5TJd7kzBsXeLPHzal4VaiAmZnfupY0JIoKqKqoUGAHX9MV+llf4HxmtMaDyaDZLtvqZushPWEHsAlVFP/3rswSNsEEt4O0v/E9MCebx8PxCP5YNlr3hg7+/TFBEl6mClflGHUl9VdIvGycuJdDgvm/bAtu6j3c0uSmZufQhnRHPBsnIqcOyQGSZAjlEgCkLGh3RDHk6yJWTCQCUZi+gav8Mzh3KpGzeQgCuV3sZEhd06D2f3QgCas9XIuozCjw3q92xMXF8O8218QDM/fAMGLAsmLO2Jnof6rwkpjv10rLaURtEJimWJomtMDLdGUlyRhuBei8AU5Y0M2ZCMyPSW8hc2AxAW4OXUeOdbcKbFsQ2YKwkizCg1uAH9kxWOzU/+ga+X8s/Q/iBKur4w8tL79c69ESiTFXFQvQmyhhu1XsYNeHhW5s2o4OuwDB6ug2uISF8fZED9HQbgh1PM3Zah8PB7UYPGBBalDB+MFB/Kt6x0e0JMSzpDr9XxzmwprNxDB95F9eQkANrrI3HssFQq4hWAnDxaMqgaUoYF6DJ73X8b74Qz/C0Qds016tSUANqVypG92EMnD+SwZ9XPc5KSg/QWu900HotgRHjnA5uN3m4diojmiKzV3cNL25DdTvGwJESn0NhzMR2Ohqc6etoiidpgrNET3zrix6yKf3Bld8WLZ8IZcAG6ip9/LQpyOIt91vG2BltHCwezbbpKzEKYoFodKVO+fUh48f3+Lh20oexIBQqExFk586dxMbGkntp41rELscozFpRxaLN/6Mv/cf4hcMzCYdAzboDKXm7Ozs7MTk5ObhcLs4lzqmeeus4GCublgvJtF61Sc1qxR0beqzh7g4Xx3ZN5/KxaagCsvlASl4pQG9vb5TB0KFDibZtZfmlonxcVgVhAcuGjJxa0l9uImVKO3GpXahA4EYsjbXx3PgtmYbTk1CiKYM1h1LzKvrncmdnJ1JeXo7b7cYYQ9+A4L2r21IJR9ZhXOuxXGAZBvKv/Uui8wELVHYgUn44bdWNfmKRSIRgMIiUlJQQGxs78Krof7oYY8jt2TUCy3oH0XmI+MAejW0gYpoxxg/mF4zu3a8rbvXrPuigq6uLfwcA6IKAIsDf9kIAAAAASUVORK5CYII="
},
"$:/plugins/felixhayashi/vis/img/network/addNodeIcon.png": {
"title": "$:/plugins/felixhayashi/vis/img/network/addNodeIcon.png",
"type": "image/png",
"text": "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/GMzLdsAAEEOaVRYdFhNTDpjb20uYWRvYmUueG1wAAAAAAA8P3hwYWNrZXQgYmVnaW49Iu+7vyIgaWQ9Ilc1TTBNcENlaGlIenJlU3pOVGN6a2M5ZCI/Pgo8eDp4bXBtZXRhIHhtbG5zOng9ImFkb2JlOm5zOm1ldGEvIiB4OnhtcHRrPSJBZG9iZSBYTVAgQ29yZSA1LjUtYzAyMSA3OS4xNTQ5MTEsIDIwMTMvMTAvMjktMTE6NDc6MTYgICAgICAgICI+CiAgIDxyZGY6UkRGIHhtbG5zOnJkZj0iaHR0cDovL3d3dy53My5vcmcvMTk5OS8wMi8yMi1yZGYtc3ludGF4LW5zIyI+CiAgICAgIDxyZGY6RGVzY3JpcHRpb24gcmRmOmFib3V0PSIiCiAgICAgICAgICAgIHhtbG5zOnhtcD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLyIKICAgICAgICAgICAgeG1sbnM6ZGM9Imh0dHA6Ly9wdXJsLm9yZy9kYy9lbGVtZW50cy8xLjEvIgogICAgICAgICAgICB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIKICAgICAgICAgICAgeG1sbnM6c3RFdnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZUV2ZW50IyIKICAgICAgICAgICAgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiCiAgICAgICAgICAgIHhtbG5zOnBob3Rvc2hvcD0iaHR0cDovL25zLmFkb2JlLmNvbS9waG90b3Nob3AvMS4wLyIKICAgICAgICAgICAgeG1sbnM6dGlmZj0iaHR0cDovL25zLmFkb2JlLmNvbS90aWZmLzEuMC8iCiAgICAgICAgICAgIHhtbG5zOmV4aWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20vZXhpZi8xLjAvIj4KICAgICAgICAgPHhtcDpDcmVhdG9yVG9vbD5BZG9iZSBQaG90b3Nob3AgQ0MgKFdpbmRvd3MpPC94bXA6Q3JlYXRvclRvb2w+CiAgICAgICAgIDx4bXA6Q3JlYXRlRGF0ZT4yMDE0LTAxLTIyVDE5OjI0OjUxKzAxOjAwPC94bXA6Q3JlYXRlRGF0ZT4KICAgICAgICAgPHhtcDpNZXRhZGF0YURhdGU+MjAxNC0wMi0wNFQxNDo0MDoyOSswMTowMDwveG1wOk1ldGFkYXRhRGF0ZT4KICAgICAgICAgPHhtcDpNb2RpZnlEYXRlPjIwMTQtMDItMDRUMTQ6NDA6MjkrMDE6MDA8L3htcDpNb2RpZnlEYXRlPgogICAgICAgICA8ZGM6Zm9ybWF0PmltYWdlL3BuZzwvZGM6Zm9ybWF0PgogICAgICAgICA8eG1wTU06SW5zdGFuY2VJRD54bXAuaWlkOjVkNWIwNmQwLTVmMjAtOGE0NC1hMzIwLWZmMTEzMzQwNDc0YjwveG1wTU06SW5zdGFuY2VJRD4KICAgICAgICAgPHhtcE1NOkRvY3VtZW50SUQ+eG1wLmRpZDpFQTc2MkY5Njc0ODNFMzExOTQ4QkQxM0UyQkU3OTlBMTwveG1wTU06RG9jdW1lbnRJRD4KICAgICAgICAgPHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD54bXAuZGlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC94bXBNTTpPcmlnaW5hbERvY3VtZW50SUQ+CiAgICAgICAgIDx4bXBNTTpIaXN0b3J5PgogICAgICAgICAgICA8cmRmOlNlcT4KICAgICAgICAgICAgICAgPHJkZjpsaSByZGY6cGFyc2VUeXBlPSJSZXNvdXJjZSI+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDphY3Rpb24+Y3JlYXRlZDwvc3RFdnQ6YWN0aW9uPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6aW5zdGFuY2VJRD54bXAuaWlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC9zdEV2dDppbnN0YW5jZUlEPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6d2hlbj4yMDE0LTAxLTIyVDE5OjI0OjUxKzAxOjAwPC9zdEV2dDp3aGVuPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6c29mdHdhcmVBZ2VudD5BZG9iZSBQaG90b3Nob3AgQ1M2IChXaW5kb3dzKTwvc3RFdnQ6c29mdHdhcmVBZ2VudD4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6YWN0aW9uPnNhdmVkPC9zdEV2dDphY3Rpb24+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDppbnN0YW5jZUlEPnhtcC5paWQ6RUE2MEEyNEUxOTg0RTMxMUFEQUZFRkU2RUMzMzNFMDM8L3N0RXZ0Omluc3RhbmNlSUQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDp3aGVuPjIwMTQtMDEtMjNUMTk6MTg6MDcrMDE6MDA8L3N0RXZ0OndoZW4+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpzb2Z0d2FyZUFnZW50PkFkb2JlIFBob3Rvc2hvcCBDUzYgKFdpbmRvd3MpPC9zdEV2dDpzb2Z0d2FyZUFnZW50PgogICAgICAgICAgICAgICAgICA8c3RFdnQ6Y2hhbmdlZD4vPC9zdEV2dDpjaGFuZ2VkPgogICAgICAgICAgICAgICA8L3JkZjpsaT4KICAgICAgICAgICAgICAgPHJkZjpsaSByZGY6cGFyc2VUeXBlPSJSZXNvdXJjZSI+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDphY3Rpb24+c2F2ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0Omluc3RhbmNlSUQ+eG1wLmlpZDo2OWVmYWE1NS01ZTI5LTIzNGUtYTUzMy0xNDkxYjM1NDNmYmE8L3N0RXZ0Omluc3RhbmNlSUQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDp3aGVuPjIwMTQtMDItMDRUMTQ6NDA6MjkrMDE6MDA8L3N0RXZ0OndoZW4+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpzb2Z0d2FyZUFnZW50PkFkb2JlIFBob3Rvc2hvcCBDQyAoV2luZG93cyk8L3N0RXZ0OnNvZnR3YXJlQWdlbnQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpjaGFuZ2VkPi88L3N0RXZ0OmNoYW5nZWQ+CiAgICAgICAgICAgICAgIDwvcmRmOmxpPgogICAgICAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmFjdGlvbj5jb252ZXJ0ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnBhcmFtZXRlcnM+ZnJvbSBhcHBsaWNhdGlvbi92bmQuYWRvYmUucGhvdG9zaG9wIHRvIGltYWdlL3BuZzwvc3RFdnQ6cGFyYW1ldGVycz4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6YWN0aW9uPmRlcml2ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnBhcmFtZXRlcnM+Y29udmVydGVkIGZyb20gYXBwbGljYXRpb24vdm5kLmFkb2JlLnBob3Rvc2hvcCB0byBpbWFnZS9wbmc8L3N0RXZ0OnBhcmFtZXRlcnM+CiAgICAgICAgICAgICAgIDwvcmRmOmxpPgogICAgICAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmFjdGlvbj5zYXZlZDwvc3RFdnQ6YWN0aW9uPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6aW5zdGFuY2VJRD54bXAuaWlkOjVkNWIwNmQwLTVmMjAtOGE0NC1hMzIwLWZmMTEzMzQwNDc0Yjwvc3RFdnQ6aW5zdGFuY2VJRD4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OndoZW4+MjAxNC0wMi0wNFQxNDo0MDoyOSswMTowMDwvc3RFdnQ6d2hlbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnNvZnR3YXJlQWdlbnQ+QWRvYmUgUGhvdG9zaG9wIENDIChXaW5kb3dzKTwvc3RFdnQ6c29mdHdhcmVBZ2VudD4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmNoYW5nZWQ+Lzwvc3RFdnQ6Y2hhbmdlZD4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgIDwvcmRmOlNlcT4KICAgICAgICAgPC94bXBNTTpIaXN0b3J5PgogICAgICAgICA8eG1wTU06RGVyaXZlZEZyb20gcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICA8c3RSZWY6aW5zdGFuY2VJRD54bXAuaWlkOjY5ZWZhYTU1LTVlMjktMjM0ZS1hNTMzLTE0OTFiMzU0M2ZiYTwvc3RSZWY6aW5zdGFuY2VJRD4KICAgICAgICAgICAgPHN0UmVmOmRvY3VtZW50SUQ+eG1wLmRpZDpFQTc2MkY5Njc0ODNFMzExOTQ4QkQxM0UyQkU3OTlBMTwvc3RSZWY6ZG9jdW1lbnRJRD4KICAgICAgICAgICAgPHN0UmVmOm9yaWdpbmFsRG9jdW1lbnRJRD54bXAuZGlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC9zdFJlZjpvcmlnaW5hbERvY3VtZW50SUQ+CiAgICAgICAgIDwveG1wTU06RGVyaXZlZEZyb20+CiAgICAgICAgIDxwaG90b3Nob3A6Q29sb3JNb2RlPjM8L3Bob3Rvc2hvcDpDb2xvck1vZGU+CiAgICAgICAgIDxwaG90b3Nob3A6SUNDUHJvZmlsZT5zUkdCIElFQzYxOTY2LTIuMTwvcGhvdG9zaG9wOklDQ1Byb2ZpbGU+CiAgICAgICAgIDx0aWZmOk9yaWVudGF0aW9uPjE8L3RpZmY6T3JpZW50YXRpb24+CiAgICAgICAgIDx0aWZmOlhSZXNvbHV0aW9uPjcyMDA5MC8xMDAwMDwvdGlmZjpYUmVzb2x1dGlvbj4KICAgICAgICAgPHRpZmY6WVJlc29sdXRpb24+NzIwMDkwLzEwMDAwPC90aWZmOllSZXNvbHV0aW9uPgogICAgICAgICA8dGlmZjpSZXNvbHV0aW9uVW5pdD4yPC90aWZmOlJlc29sdXRpb25Vbml0PgogICAgICAgICA8ZXhpZjpDb2xvclNwYWNlPjE8L2V4aWY6Q29sb3JTcGFjZT4KICAgICAgICAgPGV4aWY6UGl4ZWxYRGltZW5zaW9uPjI0PC9leGlmOlBpeGVsWERpbWVuc2lvbj4KICAgICAgICAgPGV4aWY6UGl4ZWxZRGltZW5zaW9uPjI0PC9leGlmOlBpeGVsWURpbWVuc2lvbj4KICAgICAgPC9yZGY6RGVzY3JpcHRpb24+CiAgIDwvcmRmOlJERj4KPC94OnhtcG1ldGE+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgCjw/eHBhY2tldCBlbmQ9InciPz5WKqp9AAAAIGNIUk0AAHolAACAgwAA+f8AAIDpAAB1MAAA6mAAADqYAAAXb5JfxUYAAAYXSURBVHjafFZtUFTXGX7e9z27sveuMCwYV8ElrA7YSFYHtJUPkaaI0aRqG8wP00zUzljDINNSA/2ROtpO24SxnahlxjYd7SSjmUkymcxYlDhQPzHGisEVp8HwYWCVVVgEsrsuLnL74+5uqTF9Z+7cO/d8PO95zvO851BlZSV0XQcAMDOYGQBARDhX3JRmMDYZwLPMWAzGHACYIgwS46oBNBNwtOL8CwE8EkSEUCgE2rJlC2w2G4go8Zwo/bMDgnoG6gxLfAAAYvPDMCCszKTAMIAGAhrWnf15AAAMwwARIRKJgDZv3gy73Q4iAjPjxIr9VVOMRhbAYKB8zvrO0llrfEsdKwLZek6YAPSFvtSu3GtLawu0ZJ6625SHGBQB1T88t6MxvopgMAjaunUrdF0HM+P4yv27DMYeJmB1RqW3Jnf3tQX2p0L4P9EXuqEd7PmDp+XuMU9sRbvXnnt1TxxACgoKYLVacbzsQDUJGkSATe6qi28uPtzusM6Kxie6NHLGUX3lxVUNX9StPHnn4wy3njuUYcu6n2pNi66avcEXnByP/nv8aiaIyrqz2gO5A9+9FI1GIfn5+WhZdTAdjFMkwMvZOy7uWnTAOz3L4Yk71m3t69fdfTDoUGTBeHTUfiHQ6lo7Z2OXJvpDAChKe+aOCdKRKWxZ2+1qb3yyd3GYmRkQ7GQBVs99wfv6on3eR2k4PdTkDEbH7IuS8/svld/561PJS/pDk1/bzwx94pze7xc5v/H+YPY6r5BAkdrJzODTK46lE6PeYEJt7u+8j+OZwCBiEAgAoNgKJoEQf6PvNvdrXgtZoNhSf7q0KZ3B2AQmVMze0Jmt54S/DcDCVig2NcvEUGxJAE4Pl+YOr0iv6BRSIPAmBeBZAmHlE2sH4p1uhrq1s0MnnEQMBsf8wRASAICQQCCITN1X7/sOuc0kgOVp3/fPs2WHv+coG7gQOJUnLGsUCTxEjPzUohEA+NfIWUdtx0+efzA1kSSkIGyBAQNCKgHAEBAJ3u79U7kiAcWoem/gb5Fd33nrH3kp+SMWtuAB+GllMJxMjCx9QRgA3uiqL5kwHiTlpxb3smlfMDGYGPP1hcMAkJvs8ScpfdJspdj+MK6Pf+5+u29vyb4lR4+BGEziVESAkEpw6Av1OhUpHCz4qOXbzFWz4Ncdj/v/o08Lt92ODDgZDCEFJYoUGH4mzugP92puPTf0pD3H7wvfdFZdqSxnMtWjoGAAmG9fOLxjwesdjT2/XzIQ7ks3sycYMSEwGHNtWf5bkX5NkYCJBxUBXiGV0XHvosOt54Zey33j/K+8P33++vjnbiGJbbLE+J9SANAb6nJ2B79wcUwETAwQQ7fMjPzMvfP8ja87HUIKMOiaAqMZhrGmLdAy78eZrwwsTS0eObTs+IdtgVanxBUExqGbb5VzrIISGIoUXsmqbgEhJldCQWqRf27SvPAn/o8XmgLhZsUkR4ll37mhk3n94Z4OlzY/7NLcYZfm7o1z2zT4vsvUNSXqprBCkmiTFbPX90/fh8GIT2sf+zTPdDMf4dVnNg4z+E0ixsGeBs9jd5ViSgLHjCb/peaR+MD3d4/ZJg2llyuG2Vwy7QWAs8PNnn1f7vkGSGxAzE6mk+kxkx/p/4unffSCR0hAoL1EBCYiPNdWNcwkNQTCR7feWX6g+7f/A7I8rcw/U6UEe0Ndrhc/W7mtL9ztmqlSgstSS/zTJ28dalpOpkRryrwbhwBACgsLMWPGDOT4ll3qyeqAkJTdCF7P/CrUY/GkLL1rE+2hTbSH8+0Lb/WEuhzhyaA905blf9Vd/895WnZwLHrPevir/cvOB1oLYpTtLrm6oYGIMDExAaqtrUVKSgqYGSKCk0WHq5ikkWEWtNL0imv5qUW+RclLRjJsrhBAuH1/QL8R7HR4xy5nescuP23E6hOA6mLv+sb4uTw6Ogqqq6uDpmkQkcStorX4XRcM1FjZ+kvFFjCJKU1WpkNJJUqIMtX1RyLeX3JtQ0JRhmGYZ/L27duRnJycuFGISOJ9pqh5lrB6iYgqGOxRrOaa54DcZmKvkJxk8JHC9rKh+KVhOsD4+Dj+MwADIf8n5m4xGwAAAABJRU5ErkJggg=="
},
"$:/plugins/felixhayashi/vis/img/network/backIcon.png": {
"title": "$:/plugins/felixhayashi/vis/img/network/backIcon.png",
"type": "image/png",
"text": "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/GMzLdsAAEEOaVRYdFhNTDpjb20uYWRvYmUueG1wAAAAAAA8P3hwYWNrZXQgYmVnaW49Iu+7vyIgaWQ9Ilc1TTBNcENlaGlIenJlU3pOVGN6a2M5ZCI/Pgo8eDp4bXBtZXRhIHhtbG5zOng9ImFkb2JlOm5zOm1ldGEvIiB4OnhtcHRrPSJBZG9iZSBYTVAgQ29yZSA1LjUtYzAyMSA3OS4xNTQ5MTEsIDIwMTMvMTAvMjktMTE6NDc6MTYgICAgICAgICI+CiAgIDxyZGY6UkRGIHhtbG5zOnJkZj0iaHR0cDovL3d3dy53My5vcmcvMTk5OS8wMi8yMi1yZGYtc3ludGF4LW5zIyI+CiAgICAgIDxyZGY6RGVzY3JpcHRpb24gcmRmOmFib3V0PSIiCiAgICAgICAgICAgIHhtbG5zOnhtcD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLyIKICAgICAgICAgICAgeG1sbnM6ZGM9Imh0dHA6Ly9wdXJsLm9yZy9kYy9lbGVtZW50cy8xLjEvIgogICAgICAgICAgICB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIKICAgICAgICAgICAgeG1sbnM6c3RFdnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZUV2ZW50IyIKICAgICAgICAgICAgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiCiAgICAgICAgICAgIHhtbG5zOnBob3Rvc2hvcD0iaHR0cDovL25zLmFkb2JlLmNvbS9waG90b3Nob3AvMS4wLyIKICAgICAgICAgICAgeG1sbnM6dGlmZj0iaHR0cDovL25zLmFkb2JlLmNvbS90aWZmLzEuMC8iCiAgICAgICAgICAgIHhtbG5zOmV4aWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20vZXhpZi8xLjAvIj4KICAgICAgICAgPHhtcDpDcmVhdG9yVG9vbD5BZG9iZSBQaG90b3Nob3AgQ0MgKFdpbmRvd3MpPC94bXA6Q3JlYXRvclRvb2w+CiAgICAgICAgIDx4bXA6Q3JlYXRlRGF0ZT4yMDE0LTAxLTIyVDE5OjI0OjUxKzAxOjAwPC94bXA6Q3JlYXRlRGF0ZT4KICAgICAgICAgPHhtcDpNZXRhZGF0YURhdGU+MjAxNC0wMi0wNFQxNTowMTowOSswMTowMDwveG1wOk1ldGFkYXRhRGF0ZT4KICAgICAgICAgPHhtcDpNb2RpZnlEYXRlPjIwMTQtMDItMDRUMTU6MDE6MDkrMDE6MDA8L3htcDpNb2RpZnlEYXRlPgogICAgICAgICA8ZGM6Zm9ybWF0PmltYWdlL3BuZzwvZGM6Zm9ybWF0PgogICAgICAgICA8eG1wTU06SW5zdGFuY2VJRD54bXAuaWlkOmI2YjQwMjVkLTAxNjQtMzU0OC1hOTdlLTQ4ZmYxMWM3NTYzMzwveG1wTU06SW5zdGFuY2VJRD4KICAgICAgICAgPHhtcE1NOkRvY3VtZW50SUQ+eG1wLmRpZDpFQTc2MkY5Njc0ODNFMzExOTQ4QkQxM0UyQkU3OTlBMTwveG1wTU06RG9jdW1lbnRJRD4KICAgICAgICAgPHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD54bXAuZGlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC94bXBNTTpPcmlnaW5hbERvY3VtZW50SUQ+CiAgICAgICAgIDx4bXBNTTpIaXN0b3J5PgogICAgICAgICAgICA8cmRmOlNlcT4KICAgICAgICAgICAgICAgPHJkZjpsaSByZGY6cGFyc2VUeXBlPSJSZXNvdXJjZSI+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDphY3Rpb24+Y3JlYXRlZDwvc3RFdnQ6YWN0aW9uPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6aW5zdGFuY2VJRD54bXAuaWlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC9zdEV2dDppbnN0YW5jZUlEPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6d2hlbj4yMDE0LTAxLTIyVDE5OjI0OjUxKzAxOjAwPC9zdEV2dDp3aGVuPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6c29mdHdhcmVBZ2VudD5BZG9iZSBQaG90b3Nob3AgQ1M2IChXaW5kb3dzKTwvc3RFdnQ6c29mdHdhcmVBZ2VudD4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6YWN0aW9uPnNhdmVkPC9zdEV2dDphY3Rpb24+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDppbnN0YW5jZUlEPnhtcC5paWQ6RUE2MEEyNEUxOTg0RTMxMUFEQUZFRkU2RUMzMzNFMDM8L3N0RXZ0Omluc3RhbmNlSUQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDp3aGVuPjIwMTQtMDEtMjNUMTk6MTg6MDcrMDE6MDA8L3N0RXZ0OndoZW4+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpzb2Z0d2FyZUFnZW50PkFkb2JlIFBob3Rvc2hvcCBDUzYgKFdpbmRvd3MpPC9zdEV2dDpzb2Z0d2FyZUFnZW50PgogICAgICAgICAgICAgICAgICA8c3RFdnQ6Y2hhbmdlZD4vPC9zdEV2dDpjaGFuZ2VkPgogICAgICAgICAgICAgICA8L3JkZjpsaT4KICAgICAgICAgICAgICAgPHJkZjpsaSByZGY6cGFyc2VUeXBlPSJSZXNvdXJjZSI+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDphY3Rpb24+c2F2ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0Omluc3RhbmNlSUQ+eG1wLmlpZDpmOWQ3OGY4ZC1lNzY0LTc1NDgtODZiNy1iNmQ1OGMzZDg2OTc8L3N0RXZ0Omluc3RhbmNlSUQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDp3aGVuPjIwMTQtMDItMDRUMTU6MDE6MDkrMDE6MDA8L3N0RXZ0OndoZW4+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpzb2Z0d2FyZUFnZW50PkFkb2JlIFBob3Rvc2hvcCBDQyAoV2luZG93cyk8L3N0RXZ0OnNvZnR3YXJlQWdlbnQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpjaGFuZ2VkPi88L3N0RXZ0OmNoYW5nZWQ+CiAgICAgICAgICAgICAgIDwvcmRmOmxpPgogICAgICAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmFjdGlvbj5jb252ZXJ0ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnBhcmFtZXRlcnM+ZnJvbSBhcHBsaWNhdGlvbi92bmQuYWRvYmUucGhvdG9zaG9wIHRvIGltYWdlL3BuZzwvc3RFdnQ6cGFyYW1ldGVycz4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6YWN0aW9uPmRlcml2ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnBhcmFtZXRlcnM+Y29udmVydGVkIGZyb20gYXBwbGljYXRpb24vdm5kLmFkb2JlLnBob3Rvc2hvcCB0byBpbWFnZS9wbmc8L3N0RXZ0OnBhcmFtZXRlcnM+CiAgICAgICAgICAgICAgIDwvcmRmOmxpPgogICAgICAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmFjdGlvbj5zYXZlZDwvc3RFdnQ6YWN0aW9uPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6aW5zdGFuY2VJRD54bXAuaWlkOmI2YjQwMjVkLTAxNjQtMzU0OC1hOTdlLTQ4ZmYxMWM3NTYzMzwvc3RFdnQ6aW5zdGFuY2VJRD4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OndoZW4+MjAxNC0wMi0wNFQxNTowMTowOSswMTowMDwvc3RFdnQ6d2hlbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnNvZnR3YXJlQWdlbnQ+QWRvYmUgUGhvdG9zaG9wIENDIChXaW5kb3dzKTwvc3RFdnQ6c29mdHdhcmVBZ2VudD4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmNoYW5nZWQ+Lzwvc3RFdnQ6Y2hhbmdlZD4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgIDwvcmRmOlNlcT4KICAgICAgICAgPC94bXBNTTpIaXN0b3J5PgogICAgICAgICA8eG1wTU06RGVyaXZlZEZyb20gcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICA8c3RSZWY6aW5zdGFuY2VJRD54bXAuaWlkOmY5ZDc4ZjhkLWU3NjQtNzU0OC04NmI3LWI2ZDU4YzNkODY5Nzwvc3RSZWY6aW5zdGFuY2VJRD4KICAgICAgICAgICAgPHN0UmVmOmRvY3VtZW50SUQ+eG1wLmRpZDpFQTc2MkY5Njc0ODNFMzExOTQ4QkQxM0UyQkU3OTlBMTwvc3RSZWY6ZG9jdW1lbnRJRD4KICAgICAgICAgICAgPHN0UmVmOm9yaWdpbmFsRG9jdW1lbnRJRD54bXAuZGlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC9zdFJlZjpvcmlnaW5hbERvY3VtZW50SUQ+CiAgICAgICAgIDwveG1wTU06RGVyaXZlZEZyb20+CiAgICAgICAgIDxwaG90b3Nob3A6Q29sb3JNb2RlPjM8L3Bob3Rvc2hvcDpDb2xvck1vZGU+CiAgICAgICAgIDxwaG90b3Nob3A6SUNDUHJvZmlsZT5zUkdCIElFQzYxOTY2LTIuMTwvcGhvdG9zaG9wOklDQ1Byb2ZpbGU+CiAgICAgICAgIDx0aWZmOk9yaWVudGF0aW9uPjE8L3RpZmY6T3JpZW50YXRpb24+CiAgICAgICAgIDx0aWZmOlhSZXNvbHV0aW9uPjcyMDA5MC8xMDAwMDwvdGlmZjpYUmVzb2x1dGlvbj4KICAgICAgICAgPHRpZmY6WVJlc29sdXRpb24+NzIwMDkwLzEwMDAwPC90aWZmOllSZXNvbHV0aW9uPgogICAgICAgICA8dGlmZjpSZXNvbHV0aW9uVW5pdD4yPC90aWZmOlJlc29sdXRpb25Vbml0PgogICAgICAgICA8ZXhpZjpDb2xvclNwYWNlPjE8L2V4aWY6Q29sb3JTcGFjZT4KICAgICAgICAgPGV4aWY6UGl4ZWxYRGltZW5zaW9uPjI0PC9leGlmOlBpeGVsWERpbWVuc2lvbj4KICAgICAgICAgPGV4aWY6UGl4ZWxZRGltZW5zaW9uPjI0PC9leGlmOlBpeGVsWURpbWVuc2lvbj4KICAgICAgPC9yZGY6RGVzY3JpcHRpb24+CiAgIDwvcmRmOlJERj4KPC94OnhtcG1ldGE+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgCjw/eHBhY2tldCBlbmQ9InciPz4jq1U/AAAAIGNIUk0AAHolAACAgwAA+f8AAIDpAAB1MAAA6mAAADqYAAAXb5JfxUYAAAVTSURBVHjanFVfTFNnFP+d77ve8qeVFbBrpcVgRrCRFikFByLxwSAaE32oRCHD6JMxxhhn8G2RxxH3MsOTbyYsmCAxPMmMMYtkIUYmK60OO0qAK23BFlNob0uh3x7WS5jLZPpLbm6+k/P9zrm5v9855PF4UFhYCABgjIExBgAgIqRSqRIi6gDQRkQ1RGTB3wgR0e8AHgH4Sa/XR/EBiAiJRAJ04cIF5Ofng4g2n0gkUkxENwF0c843LzHGQEQQQkCLExEA9ALotVgsUQAQQmgNQhJCbF5kjCEUCl0moj4t5na7fTU1NUpVVVXUYrEkASAcDhe8efOmxOfzWScmJqoBdBNR99LS0hWz2dynNSSEAF28eBGFhYVgjCEcDn9HRD1EhIMHD3o9Hs9kWVlZAh9BKBQqGB4edr58+dKZ+6JbJpOpBwBWV1fB6+rqIMsyIpHIFcZYL2MMra2tY5cuXRrfuXNnBtvAYDBk3G63oqpqZm5uzgrgSDKZjBoMhueZTAbc5XIhFouVEtFTxhiOHTs2dv78eS8+Efv374+oqpqZnZ21cs5PJJPJPlmWkyynnBuMMTQ0NHi7uro+mVyDx+Pxulwu71ZOlkqlSonoJhGhvb39s8k1nDx50ss5hyRJN9PpdKlERB2aWjSVaEilUvzBgwcORVEs5eXloXPnzk1sV8BkMiUdDofP7/dXZ7PZDilnIhw4cGBeS1pbW2P37t1zBwKBikQiUUREWFhYsHHO0d7evm0Ru90+/+rVq2rO+XGJiJxEhMrKyhgAjI6OWoeHh5tWVla+4JzDZrO9bW5unhwcHGzz+/32np4e+xaDbfoHAMxmc6ijo2O0oqIiJkkSNjY2HBIRmRljMJvNyWfPnln7+/tPMMZQXl6+0NbW9qK2tjYcj8floaEhqKpq+HCkbD3PzMwYBgYG0NXV9UuusFna2kEgELAQEQ4dOvSis7PzN41Ar9dnrl27NqCNkv/C3bt3zy4tLVmICJxzEBFJRBQmorLFxcWCqqqq0Pj4eO3Y2JhbUZTdra2tL2pra8OJRGLHnTt3zkqS9K+huHU4EhHMZnMoGo0W5OIh7nK5jjLGKq1W69vDhw8rRqMxMjc3t2t5eXnX5ORklc/nM+fl5SWnpqa+0uv1K/n5+Ws6nW5NluXNd15e3ppOp1uz2WyzZ86cGQ0Gg6ZAIFCZzWZ/lYjokRDiuN/vt7W0tMw3NTUpbrd78P79++5gMFgRiUTKHj58WMYYQ3V19etTp05tq6Lp6Wkb5xxCiEfc7XZPM8a6FxcXTfX19a/1en2Gcy5qamreNjY2/qGq6joRZe12+9Tp06e3JY/FYgWPHz8+mhvr3/CWlpbk+vp6PmOseWVlBS6XS9GSJUkSdrs93NDQ8Oe+ffvC/8fJIyMjddFo9Esi6pVleVjT2m0A8Hq9zqGhIefnjoknT544A4GAM/eDbxMReFNTE0pKSpKqqsaI6Pj8/LxVVdWM3W6PfCr5xMTE1zllXS0uLn6aSqXAGxsbodPpoNfrn6uqCs75EUVRrJFIZMfevXsXdTrdxseIE4mEPDIyUu/3++tynd8yGo29RIR0Og26fv06ioqKwBgD5xzv3r27zBjrIyJIkgSHwzFZWVmp7NmzJ1ZaWpoAgGg0WqgoSvHMzIw1GAw6tvjhitFo7NPW5fv370Hd3d0oKCgA53zTQMvLy+VCiKuSJH0rSdLmztZytIWv5RPRD0T0Y3Fx8dzWfby6ugopHo//w4mcc8iyPMc5v5FOp7/PZrOdQohWInIC2C2EgBBigYi8Qoifs9lsv06nWyIiaFxagXg8jr8GAGxuIe7LBeWhAAAAAElFTkSuQmCC"
},
"$:/plugins/felixhayashi/vis/img/network/connectIcon.png": {
"title": "$:/plugins/felixhayashi/vis/img/network/connectIcon.png",
"type": "image/png",
"text": "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/GMzLdsAAEEOaVRYdFhNTDpjb20uYWRvYmUueG1wAAAAAAA8P3hwYWNrZXQgYmVnaW49Iu+7vyIgaWQ9Ilc1TTBNcENlaGlIenJlU3pOVGN6a2M5ZCI/Pgo8eDp4bXBtZXRhIHhtbG5zOng9ImFkb2JlOm5zOm1ldGEvIiB4OnhtcHRrPSJBZG9iZSBYTVAgQ29yZSA1LjUtYzAyMSA3OS4xNTQ5MTEsIDIwMTMvMTAvMjktMTE6NDc6MTYgICAgICAgICI+CiAgIDxyZGY6UkRGIHhtbG5zOnJkZj0iaHR0cDovL3d3dy53My5vcmcvMTk5OS8wMi8yMi1yZGYtc3ludGF4LW5zIyI+CiAgICAgIDxyZGY6RGVzY3JpcHRpb24gcmRmOmFib3V0PSIiCiAgICAgICAgICAgIHhtbG5zOnhtcD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLyIKICAgICAgICAgICAgeG1sbnM6ZGM9Imh0dHA6Ly9wdXJsLm9yZy9kYy9lbGVtZW50cy8xLjEvIgogICAgICAgICAgICB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIKICAgICAgICAgICAgeG1sbnM6c3RFdnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZUV2ZW50IyIKICAgICAgICAgICAgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiCiAgICAgICAgICAgIHhtbG5zOnBob3Rvc2hvcD0iaHR0cDovL25zLmFkb2JlLmNvbS9waG90b3Nob3AvMS4wLyIKICAgICAgICAgICAgeG1sbnM6dGlmZj0iaHR0cDovL25zLmFkb2JlLmNvbS90aWZmLzEuMC8iCiAgICAgICAgICAgIHhtbG5zOmV4aWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20vZXhpZi8xLjAvIj4KICAgICAgICAgPHhtcDpDcmVhdG9yVG9vbD5BZG9iZSBQaG90b3Nob3AgQ0MgKFdpbmRvd3MpPC94bXA6Q3JlYXRvclRvb2w+CiAgICAgICAgIDx4bXA6Q3JlYXRlRGF0ZT4yMDE0LTAxLTIyVDE5OjI0OjUxKzAxOjAwPC94bXA6Q3JlYXRlRGF0ZT4KICAgICAgICAgPHhtcDpNZXRhZGF0YURhdGU+MjAxNC0wMi0wNFQxNDozODo1NyswMTowMDwveG1wOk1ldGFkYXRhRGF0ZT4KICAgICAgICAgPHhtcDpNb2RpZnlEYXRlPjIwMTQtMDItMDRUMTQ6Mzg6NTcrMDE6MDA8L3htcDpNb2RpZnlEYXRlPgogICAgICAgICA8ZGM6Zm9ybWF0PmltYWdlL3BuZzwvZGM6Zm9ybWF0PgogICAgICAgICA8eG1wTU06SW5zdGFuY2VJRD54bXAuaWlkOjlmYjUwMDU0LWE3ODEtMWQ0OC05ZTllLTU2ZWQ5YzhlYjdjNjwveG1wTU06SW5zdGFuY2VJRD4KICAgICAgICAgPHhtcE1NOkRvY3VtZW50SUQ+eG1wLmRpZDpFQTc2MkY5Njc0ODNFMzExOTQ4QkQxM0UyQkU3OTlBMTwveG1wTU06RG9jdW1lbnRJRD4KICAgICAgICAgPHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD54bXAuZGlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC94bXBNTTpPcmlnaW5hbERvY3VtZW50SUQ+CiAgICAgICAgIDx4bXBNTTpIaXN0b3J5PgogICAgICAgICAgICA8cmRmOlNlcT4KICAgICAgICAgICAgICAgPHJkZjpsaSByZGY6cGFyc2VUeXBlPSJSZXNvdXJjZSI+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDphY3Rpb24+Y3JlYXRlZDwvc3RFdnQ6YWN0aW9uPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6aW5zdGFuY2VJRD54bXAuaWlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC9zdEV2dDppbnN0YW5jZUlEPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6d2hlbj4yMDE0LTAxLTIyVDE5OjI0OjUxKzAxOjAwPC9zdEV2dDp3aGVuPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6c29mdHdhcmVBZ2VudD5BZG9iZSBQaG90b3Nob3AgQ1M2IChXaW5kb3dzKTwvc3RFdnQ6c29mdHdhcmVBZ2VudD4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6YWN0aW9uPnNhdmVkPC9zdEV2dDphY3Rpb24+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDppbnN0YW5jZUlEPnhtcC5paWQ6RUE2MEEyNEUxOTg0RTMxMUFEQUZFRkU2RUMzMzNFMDM8L3N0RXZ0Omluc3RhbmNlSUQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDp3aGVuPjIwMTQtMDEtMjNUMTk6MTg6MDcrMDE6MDA8L3N0RXZ0OndoZW4+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpzb2Z0d2FyZUFnZW50PkFkb2JlIFBob3Rvc2hvcCBDUzYgKFdpbmRvd3MpPC9zdEV2dDpzb2Z0d2FyZUFnZW50PgogICAgICAgICAgICAgICAgICA8c3RFdnQ6Y2hhbmdlZD4vPC9zdEV2dDpjaGFuZ2VkPgogICAgICAgICAgICAgICA8L3JkZjpsaT4KICAgICAgICAgICAgICAgPHJkZjpsaSByZGY6cGFyc2VUeXBlPSJSZXNvdXJjZSI+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDphY3Rpb24+c2F2ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0Omluc3RhbmNlSUQ+eG1wLmlpZDo3ZWRhMjI0MC0yYTQxLTNlNDQtYWM2My1iNzNiYTE5OWI3Y2E8L3N0RXZ0Omluc3RhbmNlSUQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDp3aGVuPjIwMTQtMDItMDRUMTQ6Mzg6NTcrMDE6MDA8L3N0RXZ0OndoZW4+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpzb2Z0d2FyZUFnZW50PkFkb2JlIFBob3Rvc2hvcCBDQyAoV2luZG93cyk8L3N0RXZ0OnNvZnR3YXJlQWdlbnQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpjaGFuZ2VkPi88L3N0RXZ0OmNoYW5nZWQ+CiAgICAgICAgICAgICAgIDwvcmRmOmxpPgogICAgICAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmFjdGlvbj5jb252ZXJ0ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnBhcmFtZXRlcnM+ZnJvbSBhcHBsaWNhdGlvbi92bmQuYWRvYmUucGhvdG9zaG9wIHRvIGltYWdlL3BuZzwvc3RFdnQ6cGFyYW1ldGVycz4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6YWN0aW9uPmRlcml2ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnBhcmFtZXRlcnM+Y29udmVydGVkIGZyb20gYXBwbGljYXRpb24vdm5kLmFkb2JlLnBob3Rvc2hvcCB0byBpbWFnZS9wbmc8L3N0RXZ0OnBhcmFtZXRlcnM+CiAgICAgICAgICAgICAgIDwvcmRmOmxpPgogICAgICAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmFjdGlvbj5zYXZlZDwvc3RFdnQ6YWN0aW9uPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6aW5zdGFuY2VJRD54bXAuaWlkOjlmYjUwMDU0LWE3ODEtMWQ0OC05ZTllLTU2ZWQ5YzhlYjdjNjwvc3RFdnQ6aW5zdGFuY2VJRD4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OndoZW4+MjAxNC0wMi0wNFQxNDozODo1NyswMTowMDwvc3RFdnQ6d2hlbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnNvZnR3YXJlQWdlbnQ+QWRvYmUgUGhvdG9zaG9wIENDIChXaW5kb3dzKTwvc3RFdnQ6c29mdHdhcmVBZ2VudD4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmNoYW5nZWQ+Lzwvc3RFdnQ6Y2hhbmdlZD4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgIDwvcmRmOlNlcT4KICAgICAgICAgPC94bXBNTTpIaXN0b3J5PgogICAgICAgICA8eG1wTU06RGVyaXZlZEZyb20gcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICA8c3RSZWY6aW5zdGFuY2VJRD54bXAuaWlkOjdlZGEyMjQwLTJhNDEtM2U0NC1hYzYzLWI3M2JhMTk5YjdjYTwvc3RSZWY6aW5zdGFuY2VJRD4KICAgICAgICAgICAgPHN0UmVmOmRvY3VtZW50SUQ+eG1wLmRpZDpFQTc2MkY5Njc0ODNFMzExOTQ4QkQxM0UyQkU3OTlBMTwvc3RSZWY6ZG9jdW1lbnRJRD4KICAgICAgICAgICAgPHN0UmVmOm9yaWdpbmFsRG9jdW1lbnRJRD54bXAuZGlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC9zdFJlZjpvcmlnaW5hbERvY3VtZW50SUQ+CiAgICAgICAgIDwveG1wTU06RGVyaXZlZEZyb20+CiAgICAgICAgIDxwaG90b3Nob3A6Q29sb3JNb2RlPjM8L3Bob3Rvc2hvcDpDb2xvck1vZGU+CiAgICAgICAgIDxwaG90b3Nob3A6SUNDUHJvZmlsZT5zUkdCIElFQzYxOTY2LTIuMTwvcGhvdG9zaG9wOklDQ1Byb2ZpbGU+CiAgICAgICAgIDx0aWZmOk9yaWVudGF0aW9uPjE8L3RpZmY6T3JpZW50YXRpb24+CiAgICAgICAgIDx0aWZmOlhSZXNvbHV0aW9uPjcyMDA5MC8xMDAwMDwvdGlmZjpYUmVzb2x1dGlvbj4KICAgICAgICAgPHRpZmY6WVJlc29sdXRpb24+NzIwMDkwLzEwMDAwPC90aWZmOllSZXNvbHV0aW9uPgogICAgICAgICA8dGlmZjpSZXNvbHV0aW9uVW5pdD4yPC90aWZmOlJlc29sdXRpb25Vbml0PgogICAgICAgICA8ZXhpZjpDb2xvclNwYWNlPjE8L2V4aWY6Q29sb3JTcGFjZT4KICAgICAgICAgPGV4aWY6UGl4ZWxYRGltZW5zaW9uPjI0PC9leGlmOlBpeGVsWERpbWVuc2lvbj4KICAgICAgICAgPGV4aWY6UGl4ZWxZRGltZW5zaW9uPjI0PC9leGlmOlBpeGVsWURpbWVuc2lvbj4KICAgICAgPC9yZGY6RGVzY3JpcHRpb24+CiAgIDwvcmRmOlJERj4KPC94OnhtcG1ldGE+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgCjw/eHBhY2tldCBlbmQ9InciPz4ubxs+AAAAIGNIUk0AAHolAACAgwAA+f8AAIDpAAB1MAAA6mAAADqYAAAXb5JfxUYAAAUtSURBVHjajJZ/bNT1Gcdfz/P53PV6B4W7VltLqdAaplIOiMOoyxxJCSs/Gv/yB4gzJroAosmmDklwkYWR0bQsdmkykoojTpcsWYLxD/lRZdMQkTHRtkLZRqG0tIVe7662vTu43n32x/VKZ/jh89cn38/zvN7P5/l88zwf2blzJz6fDwARQUSm1n8s31CM0/VAnbNmsUPuAsDpgEO+Bg4C7//iyv5hvmMiQiqVQpqamvB6vVNwEeG1JZtCBrYi/MrkAwDNgjhwAlbzICBLA0rDb0+/839C6XQaaWxspLCw8Dp86cbNmqVFJQddE6KzdjZ9D89g+B6fSyCOcyn1nxil+O9xKg5HqWFSHGXLjrP7W/ICqVQK2bNnDz6fDxFh65KNvxbHDhF4rJj2bXPo+IGfcW5h5xL4f99P+FCEMIAob75x9t0dAMlkElNXV4e1lteXbNqiQoMaeOFOjrdU868SD2luYyEP6dUh+sYmSHeOU6GO5Z8VLx5+NNZxIpPJ5AS2L3upROCoCvz8Lo7vnkf77cAHhpiz/zIL9vWz8L8p/NvupmM0Q7pjnAoLqz8tDrc8MnQqYVUVhVdF4LEg7b+rvDn8wDDlH0WoPpukLJImSBaMwjcJqmwWts2jPZLG/8kwYVFeVdXXZcFf4yVDc2cNKfBFmD9X+0ncCP58F48eG+Feo2CAUkvs4dl0V/uJvdXLiiV+ut++n7YLSfxPfMMG54ChzB3WIesVWB2i82bw1AR6fJR7C4VsfYiv6u/k3A9nEgP4zXke8DiYHyAOMK+QxPIgnZ9GqSHr1itQJ8DK2fTerDQ+S/bHRXQJaHSCwNIZ2Xh+7+S3VAmwNMBA/tuPZtErgKquUmdMWIFlRURvdamRNEXGwIWrlP47pTMzLiunxghGMwTLvcTWlHAp77s4QNSrYMQtss6ZMgWqCm5cHoDHO1nbk6K8zEN8+3zatv2Hn1b59EqJZdxmYUERg9P9KwpIiAOTdWUWBXuLzB/vZG3P1Un4PNp2d1MbmyD45TWCxuCsQm0x56bHGHFYEZwxok7toAA9Sfw3hCcoL/NOwi9QO5wmWO1j4JEgZxTkodmcWRGkf3pcX0r8xoAaBixKu4U5/xwndM+0tpAvS6mP+PZK2nb1UBvPEKwKMLDvPj4ESGc55lGy303sdJKQdZB2rkMdctAB/4gzN+/Q2ENNd4LyUi/xN+bTtquX2thk5nk4wI3gAF+OMNcA1nFQDfK+BY5GqbkwWabTY5QZhXWlnNx1ntrY1Rz87fuvw29m/Sn8J+PUGAFj5T19baA1IspuBZp7cx1x4SwG1cEf+lgRSROs8jGwb+Ht4QB/GSSsAhYano39LWIBxNEIbP14hPDuiyS2VtJuHXQlKKvxM/jiXDq/D/xPlwifGMkJZB2NIoKpr69nxeiZxLHicFSFVWfGqBidIP3LSjrWltD94CyufF/4kQgPuVz2Lz93+dDRa9eu5QQ8Hg8/iXee+Dy4CKMs7xqn4nwKz9IirhQqmVuB42m8ey+x7LMoD6iAON782eChhqmRuXfvXgKBAKqKqtI0/8nNKrQI4BVYXkzHgzPpC88gWuHL/caXrhLoGiN0apSKr0ZZRBZM7q2w5ZnLR1oAnHOMjY0hra2tFBQUYIyZmstvVT1Z6eDlAuEVq7merxmwueNPDXy9PvybjKP5mctHLk4/XTKZRJqbm/H7/VNw1VyEMYbW4FN3WNWnnchKoy5sHeVGBRX6VWi3ymFx7r11Ix8MTX/y5C2RSPC/AQB61erowbpqSwAAAABJRU5ErkJggg=="
},
"$:/plugins/felixhayashi/vis/img/network/cross.png": {
"title": "$:/plugins/felixhayashi/vis/img/network/cross.png",
"type": "image/png",
"text": "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/GMzLdsAADvGaVRYdFhNTDpjb20uYWRvYmUueG1wAAAAAAA8P3hwYWNrZXQgYmVnaW49Iu+7vyIgaWQ9Ilc1TTBNcENlaGlIenJlU3pOVGN6a2M5ZCI/Pgo8eDp4bXBtZXRhIHhtbG5zOng9ImFkb2JlOm5zOm1ldGEvIiB4OnhtcHRrPSJBZG9iZSBYTVAgQ29yZSA1LjUtYzAyMSA3OS4xNTQ5MTEsIDIwMTMvMTAvMjktMTE6NDc6MTYgICAgICAgICI+CiAgIDxyZGY6UkRGIHhtbG5zOnJkZj0iaHR0cDovL3d3dy53My5vcmcvMTk5OS8wMi8yMi1yZGYtc3ludGF4LW5zIyI+CiAgICAgIDxyZGY6RGVzY3JpcHRpb24gcmRmOmFib3V0PSIiCiAgICAgICAgICAgIHhtbG5zOnhtcD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLyIKICAgICAgICAgICAgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iCiAgICAgICAgICAgIHhtbG5zOnN0RXZ0PSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VFdmVudCMiCiAgICAgICAgICAgIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIKICAgICAgICAgICAgeG1sbnM6cGhvdG9zaG9wPSJodHRwOi8vbnMuYWRvYmUuY29tL3Bob3Rvc2hvcC8xLjAvIgogICAgICAgICAgICB4bWxuczp0aWZmPSJodHRwOi8vbnMuYWRvYmUuY29tL3RpZmYvMS4wLyIKICAgICAgICAgICAgeG1sbnM6ZXhpZj0iaHR0cDovL25zLmFkb2JlLmNvbS9leGlmLzEuMC8iPgogICAgICAgICA8eG1wOkNyZWF0b3JUb29sPkFkb2JlIFBob3Rvc2hvcCBDQyAoV2luZG93cyk8L3htcDpDcmVhdG9yVG9vbD4KICAgICAgICAgPHhtcDpDcmVhdGVEYXRlPjIwMTQtMDItMTRUMTE6NTU6MzUrMDE6MDA8L3htcDpDcmVhdGVEYXRlPgogICAgICAgICA8eG1wOk1ldGFkYXRhRGF0ZT4yMDE0LTAyLTE0VDEyOjA1OjE3KzAxOjAwPC94bXA6TWV0YWRhdGFEYXRlPgogICAgICAgICA8eG1wOk1vZGlmeURhdGU+MjAxNC0wMi0xNFQxMjowNToxNyswMTowMDwveG1wOk1vZGlmeURhdGU+CiAgICAgICAgIDx4bXBNTTpJbnN0YW5jZUlEPnhtcC5paWQ6NjU0YmM5YmQtMWI2Yi1jYjRhLTllOWQtNWY2MzgxNDVjZjk0PC94bXBNTTpJbnN0YW5jZUlEPgogICAgICAgICA8eG1wTU06RG9jdW1lbnRJRD54bXAuZGlkOjk4MmM2MGIwLWUzZjMtMDk0MC04MjU0LTFiZTliNWE0ZTE4MzwveG1wTU06RG9jdW1lbnRJRD4KICAgICAgICAgPHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD54bXAuZGlkOjk4MmM2MGIwLWUzZjMtMDk0MC04MjU0LTFiZTliNWE0ZTE4MzwveG1wTU06T3JpZ2luYWxEb2N1bWVudElEPgogICAgICAgICA8eG1wTU06SGlzdG9yeT4KICAgICAgICAgICAgPHJkZjpTZXE+CiAgICAgICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6YWN0aW9uPmNyZWF0ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0Omluc3RhbmNlSUQ+eG1wLmlpZDo5ODJjNjBiMC1lM2YzLTA5NDAtODI1NC0xYmU5YjVhNGUxODM8L3N0RXZ0Omluc3RhbmNlSUQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDp3aGVuPjIwMTQtMDItMTRUMTE6NTU6MzUrMDE6MDA8L3N0RXZ0OndoZW4+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpzb2Z0d2FyZUFnZW50PkFkb2JlIFBob3Rvc2hvcCBDQyAoV2luZG93cyk8L3N0RXZ0OnNvZnR3YXJlQWdlbnQ+CiAgICAgICAgICAgICAgIDwvcmRmOmxpPgogICAgICAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmFjdGlvbj5zYXZlZDwvc3RFdnQ6YWN0aW9uPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6aW5zdGFuY2VJRD54bXAuaWlkOjIxODYxNmM2LTM1MWMtNDI0OS04YWFkLWJkZDQ2ZTczNWE0NDwvc3RFdnQ6aW5zdGFuY2VJRD4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OndoZW4+MjAxNC0wMi0xNFQxMTo1NTozNSswMTowMDwvc3RFdnQ6d2hlbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnNvZnR3YXJlQWdlbnQ+QWRvYmUgUGhvdG9zaG9wIENDIChXaW5kb3dzKTwvc3RFdnQ6c29mdHdhcmVBZ2VudD4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmNoYW5nZWQ+Lzwvc3RFdnQ6Y2hhbmdlZD4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6YWN0aW9uPnNhdmVkPC9zdEV2dDphY3Rpb24+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDppbnN0YW5jZUlEPnhtcC5paWQ6NjU0YmM5YmQtMWI2Yi1jYjRhLTllOWQtNWY2MzgxNDVjZjk0PC9zdEV2dDppbnN0YW5jZUlEPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6d2hlbj4yMDE0LTAyLTE0VDEyOjA1OjE3KzAxOjAwPC9zdEV2dDp3aGVuPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6c29mdHdhcmVBZ2VudD5BZG9iZSBQaG90b3Nob3AgQ0MgKFdpbmRvd3MpPC9zdEV2dDpzb2Z0d2FyZUFnZW50PgogICAgICAgICAgICAgICAgICA8c3RFdnQ6Y2hhbmdlZD4vPC9zdEV2dDpjaGFuZ2VkPgogICAgICAgICAgICAgICA8L3JkZjpsaT4KICAgICAgICAgICAgPC9yZGY6U2VxPgogICAgICAgICA8L3htcE1NOkhpc3Rvcnk+CiAgICAgICAgIDxkYzpmb3JtYXQ+aW1hZ2UvcG5nPC9kYzpmb3JtYXQ+CiAgICAgICAgIDxwaG90b3Nob3A6Q29sb3JNb2RlPjM8L3Bob3Rvc2hvcDpDb2xvck1vZGU+CiAgICAgICAgIDxwaG90b3Nob3A6SUNDUHJvZmlsZT5zUkdCIElFQzYxOTY2LTIuMTwvcGhvdG9zaG9wOklDQ1Byb2ZpbGU+CiAgICAgICAgIDx0aWZmOk9yaWVudGF0aW9uPjE8L3RpZmY6T3JpZW50YXRpb24+CiAgICAgICAgIDx0aWZmOlhSZXNvbHV0aW9uPjcyMDAwMC8xMDAwMDwvdGlmZjpYUmVzb2x1dGlvbj4KICAgICAgICAgPHRpZmY6WVJlc29sdXRpb24+NzIwMDAwLzEwMDAwPC90aWZmOllSZXNvbHV0aW9uPgogICAgICAgICA8dGlmZjpSZXNvbHV0aW9uVW5pdD4yPC90aWZmOlJlc29sdXRpb25Vbml0PgogICAgICAgICA8ZXhpZjpDb2xvclNwYWNlPjE8L2V4aWY6Q29sb3JTcGFjZT4KICAgICAgICAgPGV4aWY6UGl4ZWxYRGltZW5zaW9uPjc8L2V4aWY6UGl4ZWxYRGltZW5zaW9uPgogICAgICAgICA8ZXhpZjpQaXhlbFlEaW1lbnNpb24+NzwvZXhpZjpQaXhlbFlEaW1lbnNpb24+CiAgICAgIDwvcmRmOkRlc2NyaXB0aW9uPgogICA8L3JkZjpSREY+CjwveDp4bXBtZXRhPgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgIAo8P3hwYWNrZXQgZW5kPSJ3Ij8+cZUZMwAAACBjSFJNAAB6JQAAgIMAAPn/AACA6QAAdTAAAOpgAAA6mAAAF2+SX8VGAAAA2ElEQVR42gDLADT/AS0tLUQFBQUVFxcXtPHx8fPl5eUNCAgITCkpKesEHx8fGgYGBjH+/v4a+Pj4qgQEBFU6OjodMTExzwQUFBSvEBAQEfX19SD19fVqNDQ0CElJSd/9/f2vAwEBAfrn5+fkBwcHLRYWFgsXFxfz29vbo9LS0uwDDQ0NDfPz81orKysXIyMj+ODg4Avh4eEa/f391gMkJCRYPz8/KUhISOMCAgKh8fHxHRsbGx4UFBQQBDk5OeY7Ozv7CAgItPb29vMEBASaJSUlTQ0NDesDAEwpT0Ko8Ri2AAAAAElFTkSuQmCC"
},
"$:/plugins/felixhayashi/vis/img/network/cross2.png": {
"title": "$:/plugins/felixhayashi/vis/img/network/cross2.png",
"type": "image/png",
"text": "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/GMzLdsAADoRaVRYdFhNTDpjb20uYWRvYmUueG1wAAAAAAA8P3hwYWNrZXQgYmVnaW49Iu+7vyIgaWQ9Ilc1TTBNcENlaGlIenJlU3pOVGN6a2M5ZCI/Pgo8eDp4bXBtZXRhIHhtbG5zOng9ImFkb2JlOm5zOm1ldGEvIiB4OnhtcHRrPSJBZG9iZSBYTVAgQ29yZSA1LjUtYzAyMSA3OS4xNTQ5MTEsIDIwMTMvMTAvMjktMTE6NDc6MTYgICAgICAgICI+CiAgIDxyZGY6UkRGIHhtbG5zOnJkZj0iaHR0cDovL3d3dy53My5vcmcvMTk5OS8wMi8yMi1yZGYtc3ludGF4LW5zIyI+CiAgICAgIDxyZGY6RGVzY3JpcHRpb24gcmRmOmFib3V0PSIiCiAgICAgICAgICAgIHhtbG5zOnhtcD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLyIKICAgICAgICAgICAgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iCiAgICAgICAgICAgIHhtbG5zOnN0RXZ0PSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VFdmVudCMiCiAgICAgICAgICAgIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIKICAgICAgICAgICAgeG1sbnM6cGhvdG9zaG9wPSJodHRwOi8vbnMuYWRvYmUuY29tL3Bob3Rvc2hvcC8xLjAvIgogICAgICAgICAgICB4bWxuczp0aWZmPSJodHRwOi8vbnMuYWRvYmUuY29tL3RpZmYvMS4wLyIKICAgICAgICAgICAgeG1sbnM6ZXhpZj0iaHR0cDovL25zLmFkb2JlLmNvbS9leGlmLzEuMC8iPgogICAgICAgICA8eG1wOkNyZWF0b3JUb29sPkFkb2JlIFBob3Rvc2hvcCBDQyAoV2luZG93cyk8L3htcDpDcmVhdG9yVG9vbD4KICAgICAgICAgPHhtcDpDcmVhdGVEYXRlPjIwMTQtMDItMTRUMTE6NTY6MTUrMDE6MDA8L3htcDpDcmVhdGVEYXRlPgogICAgICAgICA8eG1wOk1ldGFkYXRhRGF0ZT4yMDE0LTAyLTE0VDExOjU2OjE1KzAxOjAwPC94bXA6TWV0YWRhdGFEYXRlPgogICAgICAgICA8eG1wOk1vZGlmeURhdGU+MjAxNC0wMi0xNFQxMTo1NjoxNSswMTowMDwveG1wOk1vZGlmeURhdGU+CiAgICAgICAgIDx4bXBNTTpJbnN0YW5jZUlEPnhtcC5paWQ6OWIwNjRhODctYWNlZi1jMjQ5LTg5MWUtNDAxOTVmMWJjMTNkPC94bXBNTTpJbnN0YW5jZUlEPgogICAgICAgICA8eG1wTU06RG9jdW1lbnRJRD54bXAuZGlkOjlmYTI2M2QyLTljOWMtNWY0OC1iYjNiLThmYmQ5NmI5ZTBhMjwveG1wTU06RG9jdW1lbnRJRD4KICAgICAgICAgPHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD54bXAuZGlkOjlmYTI2M2QyLTljOWMtNWY0OC1iYjNiLThmYmQ5NmI5ZTBhMjwveG1wTU06T3JpZ2luYWxEb2N1bWVudElEPgogICAgICAgICA8eG1wTU06SGlzdG9yeT4KICAgICAgICAgICAgPHJkZjpTZXE+CiAgICAgICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6YWN0aW9uPmNyZWF0ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0Omluc3RhbmNlSUQ+eG1wLmlpZDo5ZmEyNjNkMi05YzljLTVmNDgtYmIzYi04ZmJkOTZiOWUwYTI8L3N0RXZ0Omluc3RhbmNlSUQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDp3aGVuPjIwMTQtMDItMTRUMTE6NTY6MTUrMDE6MDA8L3N0RXZ0OndoZW4+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpzb2Z0d2FyZUFnZW50PkFkb2JlIFBob3Rvc2hvcCBDQyAoV2luZG93cyk8L3N0RXZ0OnNvZnR3YXJlQWdlbnQ+CiAgICAgICAgICAgICAgIDwvcmRmOmxpPgogICAgICAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmFjdGlvbj5zYXZlZDwvc3RFdnQ6YWN0aW9uPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6aW5zdGFuY2VJRD54bXAuaWlkOjliMDY0YTg3LWFjZWYtYzI0OS04OTFlLTQwMTk1ZjFiYzEzZDwvc3RFdnQ6aW5zdGFuY2VJRD4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OndoZW4+MjAxNC0wMi0xNFQxMTo1NjoxNSswMTowMDwvc3RFdnQ6d2hlbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnNvZnR3YXJlQWdlbnQ+QWRvYmUgUGhvdG9zaG9wIENDIChXaW5kb3dzKTwvc3RFdnQ6c29mdHdhcmVBZ2VudD4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmNoYW5nZWQ+Lzwvc3RFdnQ6Y2hhbmdlZD4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgIDwvcmRmOlNlcT4KICAgICAgICAgPC94bXBNTTpIaXN0b3J5PgogICAgICAgICA8ZGM6Zm9ybWF0PmltYWdlL3BuZzwvZGM6Zm9ybWF0PgogICAgICAgICA8cGhvdG9zaG9wOkNvbG9yTW9kZT4zPC9waG90b3Nob3A6Q29sb3JNb2RlPgogICAgICAgICA8cGhvdG9zaG9wOklDQ1Byb2ZpbGU+c1JHQiBJRUM2MTk2Ni0yLjE8L3Bob3Rvc2hvcDpJQ0NQcm9maWxlPgogICAgICAgICA8dGlmZjpPcmllbnRhdGlvbj4xPC90aWZmOk9yaWVudGF0aW9uPgogICAgICAgICA8dGlmZjpYUmVzb2x1dGlvbj43MjAwMDAvMTAwMDA8L3RpZmY6WFJlc29sdXRpb24+CiAgICAgICAgIDx0aWZmOllSZXNvbHV0aW9uPjcyMDAwMC8xMDAwMDwvdGlmZjpZUmVzb2x1dGlvbj4KICAgICAgICAgPHRpZmY6UmVzb2x1dGlvblVuaXQ+MjwvdGlmZjpSZXNvbHV0aW9uVW5pdD4KICAgICAgICAgPGV4aWY6Q29sb3JTcGFjZT4xPC9leGlmOkNvbG9yU3BhY2U+CiAgICAgICAgIDxleGlmOlBpeGVsWERpbWVuc2lvbj41PC9leGlmOlBpeGVsWERpbWVuc2lvbj4KICAgICAgICAgPGV4aWY6UGl4ZWxZRGltZW5zaW9uPjU8L2V4aWY6UGl4ZWxZRGltZW5zaW9uPgogICAgICA8L3JkZjpEZXNjcmlwdGlvbj4KICAgPC9yZGY6UkRGPgo8L3g6eG1wbWV0YT4KICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAKPD94cGFja2V0IGVuZD0idyI/PvQ0yV0AAAAgY0hSTQAAeiUAAICDAAD5/wAAgOkAAHUwAADqYAAAOpgAABdvkl/FRgAAAHZJREFUeNoAaQCW/wE1NTWrERER3+3t7Xbp6emKOTk5IgQtLS3kBAQEdfLy8ipOTk5LQ0NDkAE0NDQAEhISxiEhITkTExPH9PT0OgMGBgaPMzMzVS8vL7XU1NRC7+/vEQNfX19lUFBQtfPz82EEBAQMNTU1HwMAMI4nIAoe9RQAAAAASUVORK5CYII="
},
"$:/plugins/felixhayashi/vis/img/network/deleteIcon.png": {
"title": "$:/plugins/felixhayashi/vis/img/network/deleteIcon.png",
"type": "image/png",
"text": "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/GMzLdsAAEEOaVRYdFhNTDpjb20uYWRvYmUueG1wAAAAAAA8P3hwYWNrZXQgYmVnaW49Iu+7vyIgaWQ9Ilc1TTBNcENlaGlIenJlU3pOVGN6a2M5ZCI/Pgo8eDp4bXBtZXRhIHhtbG5zOng9ImFkb2JlOm5zOm1ldGEvIiB4OnhtcHRrPSJBZG9iZSBYTVAgQ29yZSA1LjUtYzAyMSA3OS4xNTQ5MTEsIDIwMTMvMTAvMjktMTE6NDc6MTYgICAgICAgICI+CiAgIDxyZGY6UkRGIHhtbG5zOnJkZj0iaHR0cDovL3d3dy53My5vcmcvMTk5OS8wMi8yMi1yZGYtc3ludGF4LW5zIyI+CiAgICAgIDxyZGY6RGVzY3JpcHRpb24gcmRmOmFib3V0PSIiCiAgICAgICAgICAgIHhtbG5zOnhtcD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLyIKICAgICAgICAgICAgeG1sbnM6ZGM9Imh0dHA6Ly9wdXJsLm9yZy9kYy9lbGVtZW50cy8xLjEvIgogICAgICAgICAgICB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIKICAgICAgICAgICAgeG1sbnM6c3RFdnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZUV2ZW50IyIKICAgICAgICAgICAgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiCiAgICAgICAgICAgIHhtbG5zOnBob3Rvc2hvcD0iaHR0cDovL25zLmFkb2JlLmNvbS9waG90b3Nob3AvMS4wLyIKICAgICAgICAgICAgeG1sbnM6dGlmZj0iaHR0cDovL25zLmFkb2JlLmNvbS90aWZmLzEuMC8iCiAgICAgICAgICAgIHhtbG5zOmV4aWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20vZXhpZi8xLjAvIj4KICAgICAgICAgPHhtcDpDcmVhdG9yVG9vbD5BZG9iZSBQaG90b3Nob3AgQ0MgKFdpbmRvd3MpPC94bXA6Q3JlYXRvclRvb2w+CiAgICAgICAgIDx4bXA6Q3JlYXRlRGF0ZT4yMDE0LTAxLTIyVDE5OjI0OjUxKzAxOjAwPC94bXA6Q3JlYXRlRGF0ZT4KICAgICAgICAgPHhtcDpNZXRhZGF0YURhdGU+MjAxNC0wMi0wNFQxNDo0MTowNCswMTowMDwveG1wOk1ldGFkYXRhRGF0ZT4KICAgICAgICAgPHhtcDpNb2RpZnlEYXRlPjIwMTQtMDItMDRUMTQ6NDE6MDQrMDE6MDA8L3htcDpNb2RpZnlEYXRlPgogICAgICAgICA8ZGM6Zm9ybWF0PmltYWdlL3BuZzwvZGM6Zm9ybWF0PgogICAgICAgICA8eG1wTU06SW5zdGFuY2VJRD54bXAuaWlkOjc3NDkzYmUxLTEyZGItOTg0NC1iNDYyLTg2NGVmNGIzMzM3MTwveG1wTU06SW5zdGFuY2VJRD4KICAgICAgICAgPHhtcE1NOkRvY3VtZW50SUQ+eG1wLmRpZDpFQTc2MkY5Njc0ODNFMzExOTQ4QkQxM0UyQkU3OTlBMTwveG1wTU06RG9jdW1lbnRJRD4KICAgICAgICAgPHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD54bXAuZGlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC94bXBNTTpPcmlnaW5hbERvY3VtZW50SUQ+CiAgICAgICAgIDx4bXBNTTpIaXN0b3J5PgogICAgICAgICAgICA8cmRmOlNlcT4KICAgICAgICAgICAgICAgPHJkZjpsaSByZGY6cGFyc2VUeXBlPSJSZXNvdXJjZSI+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDphY3Rpb24+Y3JlYXRlZDwvc3RFdnQ6YWN0aW9uPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6aW5zdGFuY2VJRD54bXAuaWlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC9zdEV2dDppbnN0YW5jZUlEPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6d2hlbj4yMDE0LTAxLTIyVDE5OjI0OjUxKzAxOjAwPC9zdEV2dDp3aGVuPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6c29mdHdhcmVBZ2VudD5BZG9iZSBQaG90b3Nob3AgQ1M2IChXaW5kb3dzKTwvc3RFdnQ6c29mdHdhcmVBZ2VudD4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6YWN0aW9uPnNhdmVkPC9zdEV2dDphY3Rpb24+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDppbnN0YW5jZUlEPnhtcC5paWQ6RUE2MEEyNEUxOTg0RTMxMUFEQUZFRkU2RUMzMzNFMDM8L3N0RXZ0Omluc3RhbmNlSUQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDp3aGVuPjIwMTQtMDEtMjNUMTk6MTg6MDcrMDE6MDA8L3N0RXZ0OndoZW4+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpzb2Z0d2FyZUFnZW50PkFkb2JlIFBob3Rvc2hvcCBDUzYgKFdpbmRvd3MpPC9zdEV2dDpzb2Z0d2FyZUFnZW50PgogICAgICAgICAgICAgICAgICA8c3RFdnQ6Y2hhbmdlZD4vPC9zdEV2dDpjaGFuZ2VkPgogICAgICAgICAgICAgICA8L3JkZjpsaT4KICAgICAgICAgICAgICAgPHJkZjpsaSByZGY6cGFyc2VUeXBlPSJSZXNvdXJjZSI+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDphY3Rpb24+c2F2ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0Omluc3RhbmNlSUQ+eG1wLmlpZDowNmE3NWYwMy04MDdhLWUzNGYtYjk1Zi1jZGU2MjM0Mzg4OGY8L3N0RXZ0Omluc3RhbmNlSUQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDp3aGVuPjIwMTQtMDItMDRUMTQ6NDE6MDQrMDE6MDA8L3N0RXZ0OndoZW4+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpzb2Z0d2FyZUFnZW50PkFkb2JlIFBob3Rvc2hvcCBDQyAoV2luZG93cyk8L3N0RXZ0OnNvZnR3YXJlQWdlbnQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpjaGFuZ2VkPi88L3N0RXZ0OmNoYW5nZWQ+CiAgICAgICAgICAgICAgIDwvcmRmOmxpPgogICAgICAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmFjdGlvbj5jb252ZXJ0ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnBhcmFtZXRlcnM+ZnJvbSBhcHBsaWNhdGlvbi92bmQuYWRvYmUucGhvdG9zaG9wIHRvIGltYWdlL3BuZzwvc3RFdnQ6cGFyYW1ldGVycz4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6YWN0aW9uPmRlcml2ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnBhcmFtZXRlcnM+Y29udmVydGVkIGZyb20gYXBwbGljYXRpb24vdm5kLmFkb2JlLnBob3Rvc2hvcCB0byBpbWFnZS9wbmc8L3N0RXZ0OnBhcmFtZXRlcnM+CiAgICAgICAgICAgICAgIDwvcmRmOmxpPgogICAgICAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmFjdGlvbj5zYXZlZDwvc3RFdnQ6YWN0aW9uPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6aW5zdGFuY2VJRD54bXAuaWlkOjc3NDkzYmUxLTEyZGItOTg0NC1iNDYyLTg2NGVmNGIzMzM3MTwvc3RFdnQ6aW5zdGFuY2VJRD4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OndoZW4+MjAxNC0wMi0wNFQxNDo0MTowNCswMTowMDwvc3RFdnQ6d2hlbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnNvZnR3YXJlQWdlbnQ+QWRvYmUgUGhvdG9zaG9wIENDIChXaW5kb3dzKTwvc3RFdnQ6c29mdHdhcmVBZ2VudD4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmNoYW5nZWQ+Lzwvc3RFdnQ6Y2hhbmdlZD4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgIDwvcmRmOlNlcT4KICAgICAgICAgPC94bXBNTTpIaXN0b3J5PgogICAgICAgICA8eG1wTU06RGVyaXZlZEZyb20gcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICA8c3RSZWY6aW5zdGFuY2VJRD54bXAuaWlkOjA2YTc1ZjAzLTgwN2EtZTM0Zi1iOTVmLWNkZTYyMzQzODg4Zjwvc3RSZWY6aW5zdGFuY2VJRD4KICAgICAgICAgICAgPHN0UmVmOmRvY3VtZW50SUQ+eG1wLmRpZDpFQTc2MkY5Njc0ODNFMzExOTQ4QkQxM0UyQkU3OTlBMTwvc3RSZWY6ZG9jdW1lbnRJRD4KICAgICAgICAgICAgPHN0UmVmOm9yaWdpbmFsRG9jdW1lbnRJRD54bXAuZGlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC9zdFJlZjpvcmlnaW5hbERvY3VtZW50SUQ+CiAgICAgICAgIDwveG1wTU06RGVyaXZlZEZyb20+CiAgICAgICAgIDxwaG90b3Nob3A6Q29sb3JNb2RlPjM8L3Bob3Rvc2hvcDpDb2xvck1vZGU+CiAgICAgICAgIDxwaG90b3Nob3A6SUNDUHJvZmlsZT5zUkdCIElFQzYxOTY2LTIuMTwvcGhvdG9zaG9wOklDQ1Byb2ZpbGU+CiAgICAgICAgIDx0aWZmOk9yaWVudGF0aW9uPjE8L3RpZmY6T3JpZW50YXRpb24+CiAgICAgICAgIDx0aWZmOlhSZXNvbHV0aW9uPjcyMDA5MC8xMDAwMDwvdGlmZjpYUmVzb2x1dGlvbj4KICAgICAgICAgPHRpZmY6WVJlc29sdXRpb24+NzIwMDkwLzEwMDAwPC90aWZmOllSZXNvbHV0aW9uPgogICAgICAgICA8dGlmZjpSZXNvbHV0aW9uVW5pdD4yPC90aWZmOlJlc29sdXRpb25Vbml0PgogICAgICAgICA8ZXhpZjpDb2xvclNwYWNlPjE8L2V4aWY6Q29sb3JTcGFjZT4KICAgICAgICAgPGV4aWY6UGl4ZWxYRGltZW5zaW9uPjI0PC9leGlmOlBpeGVsWERpbWVuc2lvbj4KICAgICAgICAgPGV4aWY6UGl4ZWxZRGltZW5zaW9uPjI0PC9leGlmOlBpeGVsWURpbWVuc2lvbj4KICAgICAgPC9yZGY6RGVzY3JpcHRpb24+CiAgIDwvcmRmOlJERj4KPC94OnhtcG1ldGE+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgCjw/eHBhY2tldCBlbmQ9InciPz4aYJzYAAAAIGNIUk0AAHolAACAgwAA+f8AAIDpAAB1MAAA6mAAADqYAAAXb5JfxUYAAAYGSURBVHjalJZ7UJTnFcZ/73m/72PdJY1RbhoQp6lkXRAvmIYxdCUadLVOozPNtGObap1JsKipjiShbdoRbeKEiQHpQK3xj0xa03aamTbaTGyAYV1QGeqFi+JyiZFLAlmESBkWRmS3fyzslGkmnZ5/v/M873Oe75zzvqqoqAibzQaAiKCUAkApRdHIK/NFsx2NR91nOSILADDoJyzNaM4xxbtvPHh0iC+JiYkJ1OHDh4mJiUEpFSXPv/ziPC28TIiXDCOSrAClQDSEpsCwJPIhrEBRQpiSytXlQwDhcBilFPfu3UMVFxdjt9ujFTzfcLBADCoEEAFr1ZbrrNjch2vtEImPBgHob7fTcWE+bVXJNJ/NiFQlEGLvieXHKmYqGB8fRx05cgSbzYaIsPvywV8pKFaA7fGtLTzz61YWpo/xVTHQbufsq5lcez9zWuWhk5mvFwMEg0H0+vXrMU2Tn1wp3CtCiQ5DjGd3A/m/v8IDCZP8r4iNmyRrWx/j/5qktykZpXKzAjVDVxPzGqemptDr1q1jX3NRnIJarcDKK2hgR2ULXRfncv7UYv7xpovhnhiW5Mz+kefeSKO6LJ1A1xzEuk/Ojm4mRibpuZaMZW3OCtRUND60NmiICCIUShisx7a2sLMiQn4s77uEQgIabnqdfHIlgT1/qQeg8vs5dHhdCNB1wYn3RIiC995j26stjAbsNH+YiZJCESnS1Y/XxIXu8r4YIPv/VkVs3CTnTy2ms34xro1+sp9po6sxlTu34ultmsPVvy6is86FCHgO+DDs49zpjufBpCG+seYOC9OHaTidieicb9ouVAhKtouAseI710ma7pLuqwmgYfHqAFt+6WdLoQ/LBl11Lm7VudAa8vb72PCin9TlAWIsGGhLACD+kSAZnusYBii1XQAPYWDllt6ov2lrBkDBR2+6Ofuak2//3M+G/T4wAAPW7fPhKfRTVeqk9qQbFKRmDUTxS3N7QYGYmwzCkqklBGlPDEcTNv+sg9tNCbTXuvBWujE0bHrZj9JE1B/wU1Pm5PwJN6YBS9a2kVvQEcWnrh5GTFD3lxkYkqRMgYQlwVldUvDnen73LHTUuqitdKM0eAr9AFQfd1J/yo2aJn+2sn4Wdn5qEFODJskgBIjx5T0uCrQA08pnIjS9PERDjPnfOKXAMEBECUoGEIHBj+2zkt76UQ6dXheGAev3+cg74Kf6uJPqcicbfuond7cPy4SOiy7+tD9nFvZurx00KOk3CNEC+mE+vjSPBc7IWqgqTaPT60IMcO/xsXGa3HfKjRgRdbl7/KDg0jtubje6aHj7c7J3dgLQ2zoPwwQ91SooOQdAW1VKVMHty0kA5Bb48BycJn/LjWFGbLv4thvvb53kFvjJ+XEdWkPfjQVR/CcNKYgGMc8JWt5Fa2j+MIPPuyI2pa4IoHSkt6vLIuRaQ9q32khzt4GCxtNu6k46GeiIR2lIfDQQsafPzq1LGRGL9Gk9d+vrwewvfHPQOoexQVjxdB/auk/zmaUMdsfz6bVUtIalT7bxveP1ZHh6GPDPYeSzeD69kcpIfxymFWLNrka+ljhBTWkWwz2JiJT84YHnz2iPx0P20PkmRF5i6HYiwZFJsn/YzdezbzE3cQibY5xV266z6RfXohakb+xB9CjanCD9qTbW7Grk4WV38VZm0l6dhQiEw9taHSuDqrS0FIfDwXM3X9mHMsvRAk/sauDpQy38P+GtzOTGB9mEpkD0C2dS8n8zOjqK9ng8WJZFU+JTjasGvaCNXPpvJBPoMlm0OoDNMfWVxONfWNSUPUZ7TUQ56tCZlPwSgMnJSVRpaSmxsbFE1raw82ZxAZZRQUiBYUKGp5UlOX2krBzmoUVjiIKhHge9rfPo+Wcy3ZeXIYASgL1/X5RfMXMvj46OosrLy7HZbGitUUohIuzoem0RofALaOsghgWGjky0MiJTL8b0lOvI8hN1DKXKP0jd3TNTWDgcJhgMoo4ePYrD4Yi+KmaeLlprnrtXFo9h/AAlG1AqE8yFmBrC+jO0bgH9EVpO/1F2Dc5g//OAsbEx/j0Af+USsQynL1UAAAAASUVORK5CYII="
},
"$:/plugins/felixhayashi/vis/img/network/downArrow.png": {
"title": "$:/plugins/felixhayashi/vis/img/network/downArrow.png",
"type": "image/png",
"text": "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"
},
"$:/plugins/felixhayashi/vis/img/network/editIcon.png": {
"title": "$:/plugins/felixhayashi/vis/img/network/editIcon.png",
"type": "image/png",
"text": "iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAACXBIWXMAAAsTAAALEwEAmpwYAAAKT2lDQ1BQaG90b3Nob3AgSUNDIHByb2ZpbGUAAHjanVNnVFPpFj333vRCS4iAlEtvUhUIIFJCi4AUkSYqIQkQSoghodkVUcERRUUEG8igiAOOjoCMFVEsDIoK2AfkIaKOg6OIisr74Xuja9a89+bN/rXXPues852zzwfACAyWSDNRNYAMqUIeEeCDx8TG4eQuQIEKJHAAEAizZCFz/SMBAPh+PDwrIsAHvgABeNMLCADATZvAMByH/w/qQplcAYCEAcB0kThLCIAUAEB6jkKmAEBGAYCdmCZTAKAEAGDLY2LjAFAtAGAnf+bTAICd+Jl7AQBblCEVAaCRACATZYhEAGg7AKzPVopFAFgwABRmS8Q5ANgtADBJV2ZIALC3AMDOEAuyAAgMADBRiIUpAAR7AGDIIyN4AISZABRG8lc88SuuEOcqAAB4mbI8uSQ5RYFbCC1xB1dXLh4ozkkXKxQ2YQJhmkAuwnmZGTKBNA/g88wAAKCRFRHgg/P9eM4Ors7ONo62Dl8t6r8G/yJiYuP+5c+rcEAAAOF0ftH+LC+zGoA7BoBt/qIl7gRoXgugdfeLZrIPQLUAoOnaV/Nw+H48PEWhkLnZ2eXk5NhKxEJbYcpXff5nwl/AV/1s+X48/Pf14L7iJIEyXYFHBPjgwsz0TKUcz5IJhGLc5o9H/LcL//wd0yLESWK5WCoU41EScY5EmozzMqUiiUKSKcUl0v9k4t8s+wM+3zUAsGo+AXuRLahdYwP2SycQWHTA4vcAAPK7b8HUKAgDgGiD4c93/+8//UegJQCAZkmScQAAXkQkLlTKsz/HCAAARKCBKrBBG/TBGCzABhzBBdzBC/xgNoRCJMTCQhBCCmSAHHJgKayCQiiGzbAdKmAv1EAdNMBRaIaTcA4uwlW4Dj1wD/phCJ7BKLyBCQRByAgTYSHaiAFiilgjjggXmYX4IcFIBBKLJCDJiBRRIkuRNUgxUopUIFVIHfI9cgI5h1xGupE7yAAygvyGvEcxlIGyUT3UDLVDuag3GoRGogvQZHQxmo8WoJvQcrQaPYw2oefQq2gP2o8+Q8cwwOgYBzPEbDAuxsNCsTgsCZNjy7EirAyrxhqwVqwDu4n1Y8+xdwQSgUXACTYEd0IgYR5BSFhMWE7YSKggHCQ0EdoJNwkDhFHCJyKTqEu0JroR+cQYYjIxh1hILCPWEo8TLxB7iEPENyQSiUMyJ7mQAkmxpFTSEtJG0m5SI+ksqZs0SBojk8naZGuyBzmULCAryIXkneTD5DPkG+Qh8lsKnWJAcaT4U+IoUspqShnlEOU05QZlmDJBVaOaUt2ooVQRNY9aQq2htlKvUYeoEzR1mjnNgxZJS6WtopXTGmgXaPdpr+h0uhHdlR5Ol9BX0svpR+iX6AP0dwwNhhWDx4hnKBmbGAcYZxl3GK+YTKYZ04sZx1QwNzHrmOeZD5lvVVgqtip8FZHKCpVKlSaVGyovVKmqpqreqgtV81XLVI+pXlN9rkZVM1PjqQnUlqtVqp1Q61MbU2epO6iHqmeob1Q/pH5Z/YkGWcNMw09DpFGgsV/jvMYgC2MZs3gsIWsNq4Z1gTXEJrHN2Xx2KruY/R27iz2qqaE5QzNKM1ezUvOUZj8H45hx+Jx0TgnnKKeX836K3hTvKeIpG6Y0TLkxZVxrqpaXllirSKtRq0frvTau7aedpr1Fu1n7gQ5Bx0onXCdHZ4/OBZ3nU9lT3acKpxZNPTr1ri6qa6UbobtEd79up+6Ynr5egJ5Mb6feeb3n+hx9L/1U/W36p/VHDFgGswwkBtsMzhg8xTVxbzwdL8fb8VFDXcNAQ6VhlWGX4YSRudE8o9VGjUYPjGnGXOMk423GbcajJgYmISZLTepN7ppSTbmmKaY7TDtMx83MzaLN1pk1mz0x1zLnm+eb15vft2BaeFostqi2uGVJsuRaplnutrxuhVo5WaVYVVpds0atna0l1rutu6cRp7lOk06rntZnw7Dxtsm2qbcZsOXYBtuutm22fWFnYhdnt8Wuw+6TvZN9un2N/T0HDYfZDqsdWh1+c7RyFDpWOt6azpzuP33F9JbpL2dYzxDP2DPjthPLKcRpnVOb00dnF2e5c4PziIuJS4LLLpc+Lpsbxt3IveRKdPVxXeF60vWdm7Obwu2o26/uNu5p7ofcn8w0nymeWTNz0MPIQ+BR5dE/C5+VMGvfrH5PQ0+BZ7XnIy9jL5FXrdewt6V3qvdh7xc+9j5yn+M+4zw33jLeWV/MN8C3yLfLT8Nvnl+F30N/I/9k/3r/0QCngCUBZwOJgUGBWwL7+Hp8Ib+OPzrbZfay2e1BjKC5QRVBj4KtguXBrSFoyOyQrSH355jOkc5pDoVQfujW0Adh5mGLw34MJ4WHhVeGP45wiFga0TGXNXfR3ENz30T6RJZE3ptnMU85ry1KNSo+qi5qPNo3ujS6P8YuZlnM1VidWElsSxw5LiquNm5svt/87fOH4p3iC+N7F5gvyF1weaHOwvSFpxapLhIsOpZATIhOOJTwQRAqqBaMJfITdyWOCnnCHcJnIi/RNtGI2ENcKh5O8kgqTXqS7JG8NXkkxTOlLOW5hCepkLxMDUzdmzqeFpp2IG0yPTq9MYOSkZBxQqohTZO2Z+pn5mZ2y6xlhbL+xW6Lty8elQfJa7OQrAVZLQq2QqboVFoo1yoHsmdlV2a/zYnKOZarnivN7cyzytuQN5zvn//tEsIS4ZK2pYZLVy0dWOa9rGo5sjxxedsK4xUFK4ZWBqw8uIq2Km3VT6vtV5eufr0mek1rgV7ByoLBtQFr6wtVCuWFfevc1+1dT1gvWd+1YfqGnRs+FYmKrhTbF5cVf9go3HjlG4dvyr+Z3JS0qavEuWTPZtJm6ebeLZ5bDpaql+aXDm4N2dq0Dd9WtO319kXbL5fNKNu7g7ZDuaO/PLi8ZafJzs07P1SkVPRU+lQ27tLdtWHX+G7R7ht7vPY07NXbW7z3/T7JvttVAVVN1WbVZftJ+7P3P66Jqun4lvttXa1ObXHtxwPSA/0HIw6217nU1R3SPVRSj9Yr60cOxx++/p3vdy0NNg1VjZzG4iNwRHnk6fcJ3/ceDTradox7rOEH0x92HWcdL2pCmvKaRptTmvtbYlu6T8w+0dbq3nr8R9sfD5w0PFl5SvNUyWna6YLTk2fyz4ydlZ19fi753GDborZ752PO32oPb++6EHTh0kX/i+c7vDvOXPK4dPKy2+UTV7hXmq86X23qdOo8/pPTT8e7nLuarrlca7nuer21e2b36RueN87d9L158Rb/1tWeOT3dvfN6b/fF9/XfFt1+cif9zsu72Xcn7q28T7xf9EDtQdlD3YfVP1v+3Njv3H9qwHeg89HcR/cGhYPP/pH1jw9DBY+Zj8uGDYbrnjg+OTniP3L96fynQ89kzyaeF/6i/suuFxYvfvjV69fO0ZjRoZfyl5O/bXyl/erA6xmv28bCxh6+yXgzMV70VvvtwXfcdx3vo98PT+R8IH8o/2j5sfVT0Kf7kxmTk/8EA5jz/GMzLdsAAEEOaVRYdFhNTDpjb20uYWRvYmUueG1wAAAAAAA8P3hwYWNrZXQgYmVnaW49Iu+7vyIgaWQ9Ilc1TTBNcENlaGlIenJlU3pOVGN6a2M5ZCI/Pgo8eDp4bXBtZXRhIHhtbG5zOng9ImFkb2JlOm5zOm1ldGEvIiB4OnhtcHRrPSJBZG9iZSBYTVAgQ29yZSA1LjUtYzAyMSA3OS4xNTQ5MTEsIDIwMTMvMTAvMjktMTE6NDc6MTYgICAgICAgICI+CiAgIDxyZGY6UkRGIHhtbG5zOnJkZj0iaHR0cDovL3d3dy53My5vcmcvMTk5OS8wMi8yMi1yZGYtc3ludGF4LW5zIyI+CiAgICAgIDxyZGY6RGVzY3JpcHRpb24gcmRmOmFib3V0PSIiCiAgICAgICAgICAgIHhtbG5zOnhtcD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLyIKICAgICAgICAgICAgeG1sbnM6ZGM9Imh0dHA6Ly9wdXJsLm9yZy9kYy9lbGVtZW50cy8xLjEvIgogICAgICAgICAgICB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIKICAgICAgICAgICAgeG1sbnM6c3RFdnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZUV2ZW50IyIKICAgICAgICAgICAgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiCiAgICAgICAgICAgIHhtbG5zOnBob3Rvc2hvcD0iaHR0cDovL25zLmFkb2JlLmNvbS9waG90b3Nob3AvMS4wLyIKICAgICAgICAgICAgeG1sbnM6dGlmZj0iaHR0cDovL25zLmFkb2JlLmNvbS90aWZmLzEuMC8iCiAgICAgICAgICAgIHhtbG5zOmV4aWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20vZXhpZi8xLjAvIj4KICAgICAgICAgPHhtcDpDcmVhdG9yVG9vbD5BZG9iZSBQaG90b3Nob3AgQ0MgKFdpbmRvd3MpPC94bXA6Q3JlYXRvclRvb2w+CiAgICAgICAgIDx4bXA6Q3JlYXRlRGF0ZT4yMDE0LTAxLTIyVDE5OjI0OjUxKzAxOjAwPC94bXA6Q3JlYXRlRGF0ZT4KICAgICAgICAgPHhtcDpNZXRhZGF0YURhdGU+MjAxNC0wMi0wNVQxNDoxMjoyNSswMTowMDwveG1wOk1ldGFkYXRhRGF0ZT4KICAgICAgICAgPHhtcDpNb2RpZnlEYXRlPjIwMTQtMDItMDVUMTQ6MTI6MjUrMDE6MDA8L3htcDpNb2RpZnlEYXRlPgogICAgICAgICA8ZGM6Zm9ybWF0PmltYWdlL3BuZzwvZGM6Zm9ybWF0PgogICAgICAgICA8eG1wTU06SW5zdGFuY2VJRD54bXAuaWlkOjY5OTM3ZGZjLTJjNzQtYTU0YS05OTIzLTQyMmZhNDNkMjljNDwveG1wTU06SW5zdGFuY2VJRD4KICAgICAgICAgPHhtcE1NOkRvY3VtZW50SUQ+eG1wLmRpZDpFQTc2MkY5Njc0ODNFMzExOTQ4QkQxM0UyQkU3OTlBMTwveG1wTU06RG9jdW1lbnRJRD4KICAgICAgICAgPHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD54bXAuZGlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC94bXBNTTpPcmlnaW5hbERvY3VtZW50SUQ+CiAgICAgICAgIDx4bXBNTTpIaXN0b3J5PgogICAgICAgICAgICA8cmRmOlNlcT4KICAgICAgICAgICAgICAgPHJkZjpsaSByZGY6cGFyc2VUeXBlPSJSZXNvdXJjZSI+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDphY3Rpb24+Y3JlYXRlZDwvc3RFdnQ6YWN0aW9uPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6aW5zdGFuY2VJRD54bXAuaWlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC9zdEV2dDppbnN0YW5jZUlEPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6d2hlbj4yMDE0LTAxLTIyVDE5OjI0OjUxKzAxOjAwPC9zdEV2dDp3aGVuPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6c29mdHdhcmVBZ2VudD5BZG9iZSBQaG90b3Nob3AgQ1M2IChXaW5kb3dzKTwvc3RFdnQ6c29mdHdhcmVBZ2VudD4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6YWN0aW9uPnNhdmVkPC9zdEV2dDphY3Rpb24+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDppbnN0YW5jZUlEPnhtcC5paWQ6RUE2MEEyNEUxOTg0RTMxMUFEQUZFRkU2RUMzMzNFMDM8L3N0RXZ0Omluc3RhbmNlSUQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDp3aGVuPjIwMTQtMDEtMjNUMTk6MTg6MDcrMDE6MDA8L3N0RXZ0OndoZW4+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpzb2Z0d2FyZUFnZW50PkFkb2JlIFBob3Rvc2hvcCBDUzYgKFdpbmRvd3MpPC9zdEV2dDpzb2Z0d2FyZUFnZW50PgogICAgICAgICAgICAgICAgICA8c3RFdnQ6Y2hhbmdlZD4vPC9zdEV2dDpjaGFuZ2VkPgogICAgICAgICAgICAgICA8L3JkZjpsaT4KICAgICAgICAgICAgICAgPHJkZjpsaSByZGY6cGFyc2VUeXBlPSJSZXNvdXJjZSI+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDphY3Rpb24+c2F2ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0Omluc3RhbmNlSUQ+eG1wLmlpZDozOWNhNzE5ZC03YzNlLTUyNGEtYmY1NS03NGVmMmM1MzE0YTc8L3N0RXZ0Omluc3RhbmNlSUQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDp3aGVuPjIwMTQtMDItMDVUMTQ6MTI6MjUrMDE6MDA8L3N0RXZ0OndoZW4+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpzb2Z0d2FyZUFnZW50PkFkb2JlIFBob3Rvc2hvcCBDQyAoV2luZG93cyk8L3N0RXZ0OnNvZnR3YXJlQWdlbnQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpjaGFuZ2VkPi88L3N0RXZ0OmNoYW5nZWQ+CiAgICAgICAgICAgICAgIDwvcmRmOmxpPgogICAgICAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmFjdGlvbj5jb252ZXJ0ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnBhcmFtZXRlcnM+ZnJvbSBhcHBsaWNhdGlvbi92bmQuYWRvYmUucGhvdG9zaG9wIHRvIGltYWdlL3BuZzwvc3RFdnQ6cGFyYW1ldGVycz4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6YWN0aW9uPmRlcml2ZWQ8L3N0RXZ0OmFjdGlvbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnBhcmFtZXRlcnM+Y29udmVydGVkIGZyb20gYXBwbGljYXRpb24vdm5kLmFkb2JlLnBob3Rvc2hvcCB0byBpbWFnZS9wbmc8L3N0RXZ0OnBhcmFtZXRlcnM+CiAgICAgICAgICAgICAgIDwvcmRmOmxpPgogICAgICAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmFjdGlvbj5zYXZlZDwvc3RFdnQ6YWN0aW9uPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6aW5zdGFuY2VJRD54bXAuaWlkOjY5OTM3ZGZjLTJjNzQtYTU0YS05OTIzLTQyMmZhNDNkMjljNDwvc3RFdnQ6aW5zdGFuY2VJRD4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OndoZW4+MjAxNC0wMi0wNVQxNDoxMjoyNSswMTowMDwvc3RFdnQ6d2hlbj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnNvZnR3YXJlQWdlbnQ+QWRvYmUgUGhvdG9zaG9wIENDIChXaW5kb3dzKTwvc3RFdnQ6c29mdHdhcmVBZ2VudD4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OmNoYW5nZWQ+Lzwvc3RFdnQ6Y2hhbmdlZD4KICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgIDwvcmRmOlNlcT4KICAgICAgICAgPC94bXBNTTpIaXN0b3J5PgogICAgICAgICA8eG1wTU06RGVyaXZlZEZyb20gcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICA8c3RSZWY6aW5zdGFuY2VJRD54bXAuaWlkOjM5Y2E3MTlkLTdjM2UtNTI0YS1iZjU1LTc0ZWYyYzUzMTRhNzwvc3RSZWY6aW5zdGFuY2VJRD4KICAgICAgICAgICAgPHN0UmVmOmRvY3VtZW50SUQ+eG1wLmRpZDpFQTc2MkY5Njc0ODNFMzExOTQ4QkQxM0UyQkU3OTlBMTwvc3RSZWY6ZG9jdW1lbnRJRD4KICAgICAgICAgICAgPHN0UmVmOm9yaWdpbmFsRG9jdW1lbnRJRD54bXAuZGlkOjczQjYyQUFEOTE4M0UzMTE5NDhCRDEzRTJCRTc5OUExPC9zdFJlZjpvcmlnaW5hbERvY3VtZW50SUQ+CiAgICAgICAgIDwveG1wTU06RGVyaXZlZEZyb20+CiAgICAgICAgIDxwaG90b3Nob3A6Q29sb3JNb2RlPjM8L3Bob3Rvc2hvcDpDb2xvck1vZGU+CiAgICAgICAgIDxwaG90b3Nob3A6SUNDUHJvZmlsZT5zUkdCIElFQzYxOTY2LTIuMTwvcGhvdG9zaG9wOklDQ1Byb2ZpbGU+CiAgICAgICAgIDx0aWZmOk9yaWVudGF0aW9uPjE8L3RpZmY6T3JpZW50YXRpb24+CiAgICAgICAgIDx0aWZmOlhSZXNvbHV0aW9uPjcyMDA5MC8xMDAwMDwvdGlmZjpYUmVzb2x1dGlvbj4KICAgICAgICAgPHRpZmY6WVJlc29sdXRpb24+NzIwMDkwLzEwMDAwPC90aWZmOllSZXNvbHV0aW9uPgogICAgICAgICA8dGlmZjpSZXNvbHV0aW9uVW5pdD4yPC90aWZmOlJlc29sdXRpb25Vbml0PgogICAgICAgICA8ZXhpZjpDb2xvclNwYWNlPjE8L2V4aWY6Q29sb3JTcGFjZT4KICAgICAgICAgPGV4aWY6UGl4ZWxYRGltZW5zaW9uPjI0PC9leGlmOlBpeGVsWERpbWVuc2lvbj4KICAgICAgICAgPGV4aWY6UGl4ZWxZRGltZW5zaW9uPjI0PC9leGlmOlBpeGVsWURpbWVuc2lvbj4KICAgICAgPC9yZGY6RGVzY3JpcHRpb24+CiAgIDwvcmRmOlJERj4KPC94OnhtcG1ldGE+CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgCjw/eHBhY2tldCBlbmQ9InciPz4ykninAAAAIGNIUk0AAHolAACAgwAA+f8AAIDpAAB1MAAA6mAAADqYAAAXb5JfxUYAAAYpSURBVHjafFZtTFvnFX7Oea+NudiY2Hwam4CBlgQwXdKREDKUoYg0jbRJ29RJ2VZ1mjRFUxSpA3VTfkzJfkQbS7spU6rtx5Z2UtppScjaHxvLuiatWi2jLEoMIUDCh23g2gbj7+tPuPvhOurawPl1dc99n+c55z33fV46ceIEZFkGADAziAgAQERoe/9ZK4GPM/AcgbsIXAcABCgMvkfAqAa89eDoJyF8LogIqqqChoaGYDAYHr8kItS8uc8iIH6iAa9IkAo5EAQX8pqmgUVBCBggYFgDhv0/GAsBgKZpICJkMhnQ4OAgZFkGEYGZUXmp+0cS+CKBwWA0DVRPOg5Zl2q6zaHyJlnVAMQXVTkwHrUqH0Xsvn+tdQAAMQDgpPLS2MViFY8rkGUZzIzaS/t/xqCzGggtz9e697zsnKhoLUtim4jOq/LE6x7X0nsh16dEZ5a/O3a2SCAOHjwInU6Hujd6ThJ4mCDQ+b2G232v7v6vwarPbQn8MGlMr+X0kpE3Wr5Zt5hL5HPhqYSdQIfKJ+yhxDPKWC6Xg+jt7UXD5b5KBt1kCHS85Ljd8/On3NupfnhFaZj4rWff1B98B1R/hnUmKd36bdtCNl4g0en4edNE/cXwLq8qMTMIPAQwmo/WuHvObA8+9c58k/dKtD0TyZWXN5YGA7ej7epKxspM//7SoNOdWc/Jyq2wiwhDzPxT8cP0jys3VMM7OmL0/77zn4Ydui3b8uiK0jD7RrA77c9Wd57cefPpF+2T6bWsFPWkaiPTCWvTsZpHFU+XrS+8G3AR08F6X+1FJvBxQQzHQOWk2SmrW4FPX/U2LVwPuDZj+fJKl2khPpeyAqA9rzR/YqwuiWXX8taN/CabGkrVuq9YJlkQQDjOAJ5jAhz9Vt9W4N5/rNp8I+vtMV/aZm4zLnUNNt0urdYnF68HWoJj4Wo1mLGUNRr8LEgDgNqeCh8xQIKOsgC7iAjVe83rT9zQa8uNM28u70kspessu8q8zq/V3NcZpVzb9+0zmVhOvvvrhaMVzrJg0zeq7xMVCCwdpnWSGBqjUyJwLTFgbvxie3w31uoWR1Y74r60rdxZqrR8q85t2W2MGCp12bm/KC3hyaSTiMhxuGrKcahqpbjOaDOoEhOEoFqJQCCJvqA85I6bfTdDjQlf2lbxVNlS6wt19yy7jRHZZlDnrinNj/6sHMhnNw2Ogco7O79e5fm/xQywRBBCEAuwn4gQ96bkYj4Vyuq9N1Z3Bj4Od5bs0MXt/dZZ21ctiqFan174q985P+Lfp+U1g7XDON/1ctP458WlVjLyJhOISZE0wM0S1QfuRC3lTjkJAKKEtNC9eIOhSh9xHLZOJRZTFuXDsEoStLkR/768ummsaJG9Pb9oe+9J+xaeSVokiQDSJphAo5uaBuWjiKP4QTqS1cUWU7ayesN66wu22frD1vmVW6GW6T8u9eVjGyZzs+w78Nqu0a2mbvVu1KEJQAgeZRL0liQYyx+GOmKeQpu0rMYsAJPNEFGD2dLodLIy6c9Ys7G8yeSUl3tf2/X3rcBVJSOv34l3sCBogi7z1LH/rBHjl4IJ93/ncQFAnjeImJD0Z8zuCwu9q3djDXqTlAKID5xv+9t2R8n8VcUFBljQ8Gyfe40BYBM4DwDLt8Kue79ZcFkbzfEdbUbv+oN4c9KTtsfm1MbYQqqh+2zrVZYKs/7Ef+byimt1POYiJhDhPBFBIiIEXhxfs7/dfYoIF+auBfYTE/pebx/V8hqBP2ODvD34yvuh/WCAmU75Bx6sIgaI/v5+6PV6JLqUsYr7dpDAoehs0h73pHTWrvKgThYbRSt9UmSjef3MpaUvBz4O72UmADgTOPJguGiZor+/HyUlJWBmJFz+D8xTtlUiOpbwpmrmrweeSXrT+g11k4SBN3RGKUcAVCVdFhyP1nreDbY//NPyEXUlU/Pp4XYycGT6V0Ux2WwWdO7cOZSWlkII8diX7SPPNgDaKdbxoNAxwATBAEkEEgSWCEQAqPAMwqvMdCEwMO0tVqZpWsGTT58+DaPR+PhGIYQAAAgh0P7B3ioW/B0iGiCGiwXbCuOHFSJys6AbYFye2T+xWhT3WYJEIoH/DQBMw3kes8OJPgAAAABJRU5ErkJggg=="
},
"$:/plugins/felixhayashi/vis/img/network/leftArrow.png": {
"title": "$:/plugins/felixhayashi/vis/img/network/leftArrow.png",
"type": "image/png",
"text": "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"
},
"$:/plugins/felixhayashi/vis/img/network/minus.png": {
"title": "$:/plugins/felixhayashi/vis/img/network/minus.png",
"type": "image/png",
"text": "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"
},
"$:/plugins/felixhayashi/vis/img/network/plus.png": {
"title": "$:/plugins/felixhayashi/vis/img/network/plus.png",
"type": "image/png",
"text": "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"
},
"$:/plugins/felixhayashi/vis/img/network/rightArrow.png": {
"title": "$:/plugins/felixhayashi/vis/img/network/rightArrow.png",
"type": "image/png",
"text": "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"
},
"$:/plugins/felixhayashi/vis/img/network/upArrow.png": {
"title": "$:/plugins/felixhayashi/vis/img/network/upArrow.png",
"type": "image/png",
"text": "iVBORw0KGgoAAAANSUhEUgAAAB4AAAAeCAYAAAA7MK6iAAAKT2lDQ1BQaG90b3Nob3AgSUNDIHByb2ZpbGUAAHjanVNnVFPpFj333vRCS4iAlEtvUhUIIFJCi4AUkSYqIQkQSoghodkVUcERRUUEG8igiAOOjoCMFVEsDIoK2AfkIaKOg6OIisr74Xuja9a89+bN/rXXPues852zzwfACAyWSDNRNYAMqUIeEeCDx8TG4eQuQIEKJHAAEAizZCFz/SMBAPh+PDwrIsAHvgABeNMLCADATZvAMByH/w/qQplcAYCEAcB0kThLCIAUAEB6jkKmAEBGAYCdmCZTAKAEAGDLY2LjAFAtAGAnf+bTAICd+Jl7AQBblCEVAaCRACATZYhEAGg7AKzPVopFAFgwABRmS8Q5ANgtADBJV2ZIALC3AMDOEAuyAAgMADBRiIUpAAR7AGDIIyN4AISZABRG8lc88SuuEOcqAAB4mbI8uSQ5RYFbCC1xB1dXLh4ozkkXKxQ2YQJhmkAuwnmZGTKBNA/g88wAAKCRFRHgg/P9eM4Ors7ONo62Dl8t6r8G/yJiYuP+5c+rcEAAAOF0ftH+LC+zGoA7BoBt/qIl7gRoXgugdfeLZrIPQLUAoOnaV/Nw+H48PEWhkLnZ2eXk5NhKxEJbYcpXff5nwl/AV/1s+X48/Pf14L7iJIEyXYFHBPjgwsz0TKUcz5IJhGLc5o9H/LcL//wd0yLESWK5WCoU41EScY5EmozzMqUiiUKSKcUl0v9k4t8s+wM+3zUAsGo+AXuRLahdYwP2SycQWHTA4vcAAPK7b8HUKAgDgGiD4c93/+8//UegJQCAZkmScQAAXkQkLlTKsz/HCAAARKCBKrBBG/TBGCzABhzBBdzBC/xgNoRCJMTCQhBCCmSAHHJgKayCQiiGzbAdKmAv1EAdNMBRaIaTcA4uwlW4Dj1wD/phCJ7BKLyBCQRByAgTYSHaiAFiilgjjggXmYX4IcFIBBKLJCDJiBRRIkuRNUgxUopUIFVIHfI9cgI5h1xGupE7yAAygvyGvEcxlIGyUT3UDLVDuag3GoRGogvQZHQxmo8WoJvQcrQaPYw2oefQq2gP2o8+Q8cwwOgYBzPEbDAuxsNCsTgsCZNjy7EirAyrxhqwVqwDu4n1Y8+xdwQSgUXACTYEd0IgYR5BSFhMWE7YSKggHCQ0EdoJNwkDhFHCJyKTqEu0JroR+cQYYjIxh1hILCPWEo8TLxB7iEPENyQSiUMyJ7mQAkmxpFTSEtJG0m5SI+ksqZs0SBojk8naZGuyBzmULCAryIXkneTD5DPkG+Qh8lsKnWJAcaT4U+IoUspqShnlEOU05QZlmDJBVaOaUt2ooVQRNY9aQq2htlKvUYeoEzR1mjnNgxZJS6WtopXTGmgXaPdpr+h0uhHdlR5Ol9BX0svpR+iX6AP0dwwNhhWDx4hnKBmbGAcYZxl3GK+YTKYZ04sZx1QwNzHrmOeZD5lvVVgqtip8FZHKCpVKlSaVGyovVKmqpqreqgtV81XLVI+pXlN9rkZVM1PjqQnUlqtVqp1Q61MbU2epO6iHqmeob1Q/pH5Z/YkGWcNMw09DpFGgsV/jvMYgC2MZs3gsIWsNq4Z1gTXEJrHN2Xx2KruY/R27iz2qqaE5QzNKM1ezUvOUZj8H45hx+Jx0TgnnKKeX836K3hTvKeIpG6Y0TLkxZVxrqpaXllirSKtRq0frvTau7aedpr1Fu1n7gQ5Bx0onXCdHZ4/OBZ3nU9lT3acKpxZNPTr1ri6qa6UbobtEd79up+6Ynr5egJ5Mb6feeb3n+hx9L/1U/W36p/VHDFgGswwkBtsMzhg8xTVxbzwdL8fb8VFDXcNAQ6VhlWGX4YSRudE8o9VGjUYPjGnGXOMk423GbcajJgYmISZLTepN7ppSTbmmKaY7TDtMx83MzaLN1pk1mz0x1zLnm+eb15vft2BaeFostqi2uGVJsuRaplnutrxuhVo5WaVYVVpds0atna0l1rutu6cRp7lOk06rntZnw7Dxtsm2qbcZsOXYBtuutm22fWFnYhdnt8Wuw+6TvZN9un2N/T0HDYfZDqsdWh1+c7RyFDpWOt6azpzuP33F9JbpL2dYzxDP2DPjthPLKcRpnVOb00dnF2e5c4PziIuJS4LLLpc+Lpsbxt3IveRKdPVxXeF60vWdm7Obwu2o26/uNu5p7ofcn8w0nymeWTNz0MPIQ+BR5dE/C5+VMGvfrH5PQ0+BZ7XnIy9jL5FXrdewt6V3qvdh7xc+9j5yn+M+4zw33jLeWV/MN8C3yLfLT8Nvnl+F30N/I/9k/3r/0QCngCUBZwOJgUGBWwL7+Hp8Ib+OPzrbZfay2e1BjKC5QRVBj4KtguXBrSFoyOyQrSH355jOkc5pDoVQfujW0Adh5mGLw34MJ4WHhVeGP45wiFga0TGXNXfR3ENz30T6RJZE3ptnMU85ry1KNSo+qi5qPNo3ujS6P8YuZlnM1VidWElsSxw5LiquNm5svt/87fOH4p3iC+N7F5gvyF1weaHOwvSFpxapLhIsOpZATIhOOJTwQRAqqBaMJfITdyWOCnnCHcJnIi/RNtGI2ENcKh5O8kgqTXqS7JG8NXkkxTOlLOW5hCepkLxMDUzdmzqeFpp2IG0yPTq9MYOSkZBxQqohTZO2Z+pn5mZ2y6xlhbL+xW6Lty8elQfJa7OQrAVZLQq2QqboVFoo1yoHsmdlV2a/zYnKOZarnivN7cyzytuQN5zvn//tEsIS4ZK2pYZLVy0dWOa9rGo5sjxxedsK4xUFK4ZWBqw8uIq2Km3VT6vtV5eufr0mek1rgV7ByoLBtQFr6wtVCuWFfevc1+1dT1gvWd+1YfqGnRs+FYmKrhTbF5cVf9go3HjlG4dvyr+Z3JS0qavEuWTPZtJm6ebeLZ5bDpaql+aXDm4N2dq0Dd9WtO319kXbL5fNKNu7g7ZDuaO/PLi8ZafJzs07P1SkVPRU+lQ27tLdtWHX+G7R7ht7vPY07NXbW7z3/T7JvttVAVVN1WbVZftJ+7P3P66Jqun4lvttXa1ObXHtxwPSA/0HIw6217nU1R3SPVRSj9Yr60cOxx++/p3vdy0NNg1VjZzG4iNwRHnk6fcJ3/ceDTradox7rOEH0x92HWcdL2pCmvKaRptTmvtbYlu6T8w+0dbq3nr8R9sfD5w0PFl5SvNUyWna6YLTk2fyz4ydlZ19fi753GDborZ752PO32oPb++6EHTh0kX/i+c7vDvOXPK4dPKy2+UTV7hXmq86X23qdOo8/pPTT8e7nLuarrlca7nuer21e2b36RueN87d9L158Rb/1tWeOT3dvfN6b/fF9/XfFt1+cif9zsu72Xcn7q28T7xf9EDtQdlD3YfVP1v+3Njv3H9qwHeg89HcR/cGhYPP/pH1jw9DBY+Zj8uGDYbrnjg+OTniP3L96fynQ89kzyaeF/6i/suuFxYvfvjV69fO0ZjRoZfyl5O/bXyl/erA6xmv28bCxh6+yXgzMV70VvvtwXfcdx3vo98PT+R8IH8o/2j5sfVT0Kf7kxmTk/8EA5jz/GMzLdsAAAAGYktHRAD/AP8A/6C9p5MAAAAJcEhZcwAACxMAAAsTAQCanBgAAAAHdElNRQffARwOJTG7oDgaAAAGZUlEQVRIx7WXXWxTVxLHZ+ZcY1mON8li44/GruPrsMT5UElzgSRswEIBOdUSARsZoUioHxIPCKUowBPUyrYv2y5aeOABtMsKJJ5YIaR+qBQwCS1u4zihUVw7DqTE1yFOlObDDmDTEHsfeo1SY1NTaefF8j3/md+5c86ZORehAHO5XBgMBv/MGHsrnU43EZEVAEoBABBxHhHvA4AHAD7jef7r7u7u9G/FxJcNbt26lbRa7fuIeBIRAfEXea5fIlrp2hUOh0/19PSkXhnsdDrfBoDzRASICAaDIWqz2cSqqqpps9kcKy4ufgoAEIvF5OPj48WhUEg7MjJiikajeiKCVCoFiPjO+fPn/1MweO/evX8DgBOICLW1taHt27cH6urqZgpZlqGhIY3b7bYFAoE/SVn68Ny5cx9k61gO6CkAOIaI0NLS0nfo0KE+vV7/ZKUmHo+v8ng8r42PjxevXr06IZfLlzNjOp3uSUNDQ/jx48fPwuFwGSJuEQSh1OfzfZkX7HQ6/05EXYgI+/btu+F0OkeyJxaPx1edOHHirwMDAza/32/1eDzWxsbG0Eo4AEBNTc20XC5fCIVCFkTcJAiC0ufzXX8B7HQ630bEj4kI9u/f/1Vra+uDXKk8c+bM5mg0aigvLxdLS0tjs7OzmomJCcWmTZvC2Vqe5+eVSuVsIBDgGWNNgiCI/f393z8Ht7e3M8bYABGBw+Hw7N69ezQXtL+/X3f9+vUmxtjygQMHvqqurp7o6+urnJ2d1eh0uocGg+FRto/ZbF5IJpNPRVE0ElGbyWT6KBAIpAkAgDHWiYhQU1MT6ujo8OfbONeuXatDRBAEYdhiscQsFkusvr5+mIjgxo0bdfn89uzZ47fZbCOICHq9vhMAgFwuFxLRSQCAHTt2BPI5X758uXpiYqKsqKjokdPpHFyxRIMqlerR5ORk2dWrV6vz+Tc3NwcYY8Bx3EmXy4U0OjraDABgNBqj69evz3lklpaWaHBw0MYYA4fD8Z1SqXyWGVMoFM9aWlq+4zgOhoaGbEtLS5QrRmVl5U96vT5KRBCPx5sJEVsRESorK8V8sz179uzmeDxeYjAYJrdt2/Zj9rjdbv9Rp9NNLi4ully8eHFzvjg8z4tEBDKZrJUQsVECT+cSDw8Pq4PB4DqO41Lt7e2efEF37drl4TguFQqF1gWDQU0ujcVimZbKawMhYgUigtlsjuUSh0IhHRFBbW1tYO3atXP5wFarda6qquoHjuNgbGxMl0tjNBpjUgleyyFiKRFBpvZmm0wmSxERLC8v04ULFzZkandHR4cXAODSpUvPn6XTaYaIIJPJlnPFUqlUT6VmUsplnPKZzWabunXrFgSDQRsRwQq9V1qKNzLPAQCICKxW61S+eBkdl06n54lIG4vF5GvWrElkCysqKuYOHjz439HRUV0ikVjl9Xo3ZAciIhAEwatQKH7meX6K5/mcS7K4uCiXwPMcEd0jIq0oisW5wBl4RUXFHACA1+vdwHHcC+C2trbvf6tzTU5OFkvZGiUi+hYR4d69e9pC2l5Ww3/h/8ssEolopVb5LSHi59LuNf1ecKFwURRNjDEAgC+orKzsNiLC9PS0fnh4WF1IgJWpLvSt79+/r56bm9MTETQ3N39N3d3daUTsAgDo6emx/b9SPTg4aJNORJfdbk/9ssXm509L6V535cqV6lcBIyJI6ctrbre7+sGDB+sAAJLJ5Onn/TgQCKQFQYggYpsoikaVSvWTyWTKWcn8fv9ryWSyqLe3983bt2+/SUSg0Wim6uvrQ7n0d+/eff3OnTt2acLvHT9+fOBXNxCfz3d348aNSkRsGhkZseaDazSamYcPH/4xkUgUMcZArVZPORyOb0pKShK5oG63e4e0kz85duzYx3lvmZ2dnacQsZOIYMuWLZ6dO3f64XdYb29vtc/na5SuuqePHDny/ktvmX19fV82NDQoGWNNkUjEGIlEihQKxRO1Wv2kEODY2Jjm5s2bQjAYXC+l95Ourq6ugi/0R48efRcA/pU5p1qtNsrzfLi8vHxar9fHVSrV00wZnJmZ+UM4HNZGIpHXFxYW9JmvDkR87/Dhw/9+5U8Yl8tFiUTiMGPsH5mzyxj71U7ObhDSkTlSV1f3T7vd/uqfMNkTSKVSmxHxL4jYSEQ8EZVKoHlEHCMiDwB8KgjCNy8DZux/ivJJxnpJh8sAAAAASUVORK5CYII="
},
"$:/plugins/felixhayashi/vis/img/network/zoomExtends.png": {
"title": "$:/plugins/felixhayashi/vis/img/network/zoomExtends.png",
"type": "image/png",
"text": "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"
},
"$:/plugins/felixhayashi/vis/img/timeline/delete.png": {
"title": "$:/plugins/felixhayashi/vis/img/timeline/delete.png",
"type": "image/png",
"text": "iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAl2cEFnAAAAEAAAABAAXMatwwAAAVRJREFUOMt108FKG1EUBuBvYtxbRGwxiGBXeYCW0mVpDSKVvIJ0F/syJsFdn6GCkaZ9gro3G1u0ILQgheJKRUwXPQNnxvTAcGf+c/7/nPvfO8UEKLCFJg5w31aNqGtgG3c4xLSZyP0QgI8Tpu0quQhyPwTgsBnkAVYD3MM9DibVId5GbiW+B+VIt7hJha1IdhPWDayVsBvcFtHlDYZ4mgou8D7e+zXyN/TwuUhjbkSXLHIZ61KNvItxaYyayBDrZsf36DyGdilQE+ngA57UyD+xg08luTSxHvP/wRuRewDm7uV9WJ4hsBy5rczJJm7G/tcS6VesjxN2Hj4c5S10Qj2Tz/AunrOEr0VtB+Z6vMJ+zfkfcVQjnMbRvcRC5B/hBU4auMbVjBFHCRsFdp6wK1yXHjz37xItRuejfFQ1nwb4HXVfs4nPYsQv0p+oKlLgNf7gGP4Cw4ZUK7kMJVEAAAAZdEVYdENvbW1lbnQAQ3JlYXRlZCB3aXRoIEdJTVBXgQ4XAAAAJXRFWHRkYXRlOmNyZWF0ZQAyMDExLTA1LTE2VDExOjM1OjIxKzAyOjAw9uVF5gAAACV0RVh0ZGF0ZTptb2RpZnkAMjAxMS0wNS0xNlQxMTozNToyMSswMjowMIe4/VoAAAAASUVORK5CYII="
},
"$:/plugins/felixhayashi/vis/readme": {
"title": "$:/plugins/felixhayashi/vis/readme",
"text": "! TW5-Vis.js\n\nA tiddlywiki plugin for the vis.js library.\n\n---\n\n! Notes on Copyright\n\n!! TiddlyWiki\n\nCreated by Jeremy Ruston, (jeremy [at] jermolene [dot] com)\n\nCopyright © Jeremy Ruston 2004-2007 Copyright © UnaMesa Association 2007-2014\n\nPublished under the following [licenses](https://github.com/Jermolene/TiddlyWiki5/tree/master/licenses):\n\n1. BSD 3-clause \"New\" or \"Revised\" License (including any right to adopt any future version of a license if permitted)\n2. Creative Commons Attribution 3.0 (including any right to adopt any future version of a license if permitted)\n\n!! The **vis.js** library\n\nCopyright (c) 2014 [Almende B.V.](https://github.com/almende/vis)\n\nPublished under the following licenses:\n\n1. Apache License Version 2.0, January 2004 http://www.apache.org/licenses/\n2. MIT License (MIT)\n"
},
"$:/plugins/felixhayashi/vis/vis.css": {
"title": "$:/plugins/felixhayashi/vis/vis.css",
"type": "text/vnd.tiddlywiki",
"tags": "$:/tags/Stylesheet",
"text": "\\rules except list\n\n\\define datauri(title)\n<$macrocall $name=\"makedatauri\" type={{$title$!!type}} text={{$title$}}/>\n\\end\n\n.vis .overlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:10}.vis-active{box-shadow:0 0 10px #86d5f8}.vis [class*=\"span\"]{min-height:0;width:auto}div.vis-configuration{position:relative;display:block;float:left;font-size:12px}div.vis-configuration-wrapper{display:block;width:700px}div.vis-configuration-wrapper::after{clear:both;content:\"\";display:block}div.vis-configuration.vis-config-option-container{display:block;width:495px;background-color:#fff;border:2px solid #f7f8fa;border-radius:4px;margin-top:20px;left:10px;padding-left:5px}div.vis-configuration.vis-config-button{display:block;width:495px;height:25px;vertical-align:middle;line-height:25px;background-color:#f7f8fa;border:2px solid #ceced0;border-radius:4px;margin-top:20px;left:10px;padding-left:5px;cursor:pointer;margin-bottom:30px}div.vis-configuration.vis-config-button.hover{background-color:#4588e6;border:2px solid #214373;color:#fff}div.vis-configuration.vis-config-item{display:block;float:left;width:495px;height:25px;vertical-align:middle;line-height:25px}div.vis-configuration.vis-config-item.vis-config-s2{left:10px;background-color:#f7f8fa;padding-left:5px;border-radius:3px}div.vis-configuration.vis-config-item.vis-config-s3{left:20px;background-color:#e4e9f0;padding-left:5px;border-radius:3px}div.vis-configuration.vis-config-item.vis-config-s4{left:30px;background-color:#cfd8e6;padding-left:5px;border-radius:3px}div.vis-configuration.vis-config-header{font-size:18px;font-weight:bold}div.vis-configuration.vis-config-label{width:120px;height:25px;line-height:25px}div.vis-configuration.vis-config-label.vis-config-s3{width:110px}div.vis-configuration.vis-config-label.vis-config-s4{width:100px}div.vis-configuration.vis-config-colorBlock{top:1px;width:30px;height:19px;border:1px solid #444;border-radius:2px;padding:0;margin:0;cursor:pointer}input.vis-configuration.vis-config-checkbox{left:-5px}input.vis-configuration.vis-config-rangeinput{position:relative;top:-5px;width:60px;padding:1px;margin:0;pointer-events:none}input.vis-configuration.vis-config-range{-webkit-appearance:none;border:0 solid white;background-color:rgba(0,0,0,0);width:300px;height:20px}input.vis-configuration.vis-config-range::-webkit-slider-runnable-track{width:300px;height:5px;background:#dedede;background:-moz-linear-gradient(top,#dedede 0,#c8c8c8 99%);background:-webkit-gradient(linear,left top,left bottom,color-stop(0,#dedede),color-stop(99%,#c8c8c8));background:-webkit-linear-gradient(top,#dedede 0,#c8c8c8 99%);background:-o-linear-gradient(top,#dedede 0,#c8c8c8 99%);background:-ms-linear-gradient(top,#dedede 0,#c8c8c8 99%);background:linear-gradient(to bottom,#dedede 0,#c8c8c8 99%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#dedede',endColorstr='#c8c8c8',GradientType=0);border:1px solid #999;box-shadow:#aaa 0 0 3px 0;border-radius:3px}input.vis-configuration.vis-config-range::-webkit-slider-thumb{-webkit-appearance:none;border:1px solid #14334b;height:17px;width:17px;border-radius:50%;background:#3876c2;background:-moz-linear-gradient(top,#3876c2 0,#385380 100%);background:-webkit-gradient(linear,left top,left bottom,color-stop(0,#3876c2),color-stop(100%,#385380));background:-webkit-linear-gradient(top,#3876c2 0,#385380 100%);background:-o-linear-gradient(top,#3876c2 0,#385380 100%);background:-ms-linear-gradient(top,#3876c2 0,#385380 100%);background:linear-gradient(to bottom,#3876c2 0,#385380 100%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#3876c2',endColorstr='#385380',GradientType=0);box-shadow:#111927 0 0 1px 0;margin-top:-7px}input.vis-configuration.vis-config-range:focus{outline:0}input.vis-configuration.vis-config-range:focus::-webkit-slider-runnable-track{background:#9d9d9d;background:-moz-linear-gradient(top,#9d9d9d 0,#c8c8c8 99%);background:-webkit-gradient(linear,left top,left bottom,color-stop(0,#9d9d9d),color-stop(99%,#c8c8c8));background:-webkit-linear-gradient(top,#9d9d9d 0,#c8c8c8 99%);background:-o-linear-gradient(top,#9d9d9d 0,#c8c8c8 99%);background:-ms-linear-gradient(top,#9d9d9d 0,#c8c8c8 99%);background:linear-gradient(to bottom,#9d9d9d 0,#c8c8c8 99%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#9d9d9d',endColorstr='#c8c8c8',GradientType=0)}input.vis-configuration.vis-config-range::-moz-range-track{width:300px;height:10px;background:#dedede;background:-moz-linear-gradient(top,#dedede 0,#c8c8c8 99%);background:-webkit-gradient(linear,left top,left bottom,color-stop(0,#dedede),color-stop(99%,#c8c8c8));background:-webkit-linear-gradient(top,#dedede 0,#c8c8c8 99%);background:-o-linear-gradient(top,#dedede 0,#c8c8c8 99%);background:-ms-linear-gradient(top,#dedede 0,#c8c8c8 99%);background:linear-gradient(to bottom,#dedede 0,#c8c8c8 99%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#dedede',endColorstr='#c8c8c8',GradientType=0);border:1px solid #999;box-shadow:#aaa 0 0 3px 0;border-radius:3px}input.vis-configuration.vis-config-range::-moz-range-thumb{border:0;height:16px;width:16px;border-radius:50%;background:#385380}input.vis-configuration.vis-config-range:-moz-focusring{outline:1px solid white;outline-offset:-1px}input.vis-configuration.vis-config-range::-ms-track{width:300px;height:5px;background:transparent;border-color:transparent;border-width:6px 0;color:transparent}input.vis-configuration.vis-config-range::-ms-fill-lower{background:#777;border-radius:10px}input.vis-configuration.vis-config-range::-ms-fill-upper{background:#ddd;border-radius:10px}input.vis-configuration.vis-config-range::-ms-thumb{border:0;height:16px;width:16px;border-radius:50%;background:#385380}input.vis-configuration.vis-config-range:focus::-ms-fill-lower{background:#888}input.vis-configuration.vis-config-range:focus::-ms-fill-upper{background:#ccc}.vis-configuration-popup{position:absolute;background:rgba(57,76,89,0.85);border:2px solid #f2faff;line-height:30px;height:30px;width:150px;text-align:center;color:#fff;font-size:14px;border-radius:4px;-webkit-transition:opacity .3s ease-in-out;-moz-transition:opacity .3s ease-in-out;transition:opacity .3s ease-in-out}.vis-configuration-popup:after,.vis-configuration-popup:before{left:100%;top:50%;border:solid transparent;content:\" \";height:0;width:0;position:absolute;pointer-events:none}.vis-configuration-popup:after{border-color:rgba(136,183,213,0);border-left-color:rgba(57,76,89,0.85);border-width:8px;margin-top:-8px}.vis-configuration-popup:before{border-color:rgba(194,225,245,0);border-left-color:#f2faff;border-width:12px;margin-top:-12px}div.vis-tooltip{position:absolute;visibility:hidden;padding:5px;white-space:nowrap;font-family:verdana;font-size:14px;color:#000;background-color:#f5f4ed;-moz-border-radius:3px;-webkit-border-radius:3px;border-radius:3px;border:1px solid #808074;box-shadow:3px 3px 10px rgba(0,0,0,0.2);pointer-events:none;z-index:5}div.vis-color-picker{position:absolute;top:0;left:30px;margin-top:-140px;margin-left:30px;width:310px;height:444px;z-index:1;padding:10px;border-radius:15px;background-color:#fff;display:none;box-shadow:rgba(0,0,0,0.5) 0 0 10px 0}div.vis-color-picker div.vis-arrow{position:absolute;top:147px;left:5px}div.vis-color-picker div.vis-arrow::after,div.vis-color-picker div.vis-arrow::before{right:100%;top:50%;border:solid transparent;content:\" \";height:0;width:0;position:absolute;pointer-events:none}div.vis-color-picker div.vis-arrow:after{border-color:rgba(255,255,255,0);border-right-color:#fff;border-width:30px;margin-top:-30px}div.vis-color-picker div.vis-color{position:absolute;width:289px;height:289px;cursor:pointer}div.vis-color-picker div.vis-brightness{position:absolute;top:313px}div.vis-color-picker div.vis-opacity{position:absolute;top:350px}div.vis-color-picker div.vis-selector{position:absolute;top:137px;left:137px;width:15px;height:15px;border-radius:15px;border:1px solid #fff;background:#4c4c4c;background:-moz-linear-gradient(top,#4c4c4c 0,#595959 12%,#666 25%,#474747 39%,#2c2c2c 50%,#000 51%,#111 60%,#2b2b2b 76%,#1c1c1c 91%,#131313 100%);background:-webkit-gradient(linear,left top,left bottom,color-stop(0,#4c4c4c),color-stop(12%,#595959),color-stop(25%,#666),color-stop(39%,#474747),color-stop(50%,#2c2c2c),color-stop(51%,#000),color-stop(60%,#111),color-stop(76%,#2b2b2b),color-stop(91%,#1c1c1c),color-stop(100%,#131313));background:-webkit-linear-gradient(top,#4c4c4c 0,#595959 12%,#666 25%,#474747 39%,#2c2c2c 50%,#000 51%,#111 60%,#2b2b2b 76%,#1c1c1c 91%,#131313 100%);background:-o-linear-gradient(top,#4c4c4c 0,#595959 12%,#666 25%,#474747 39%,#2c2c2c 50%,#000 51%,#111 60%,#2b2b2b 76%,#1c1c1c 91%,#131313 100%);background:-ms-linear-gradient(top,#4c4c4c 0,#595959 12%,#666 25%,#474747 39%,#2c2c2c 50%,#000 51%,#111 60%,#2b2b2b 76%,#1c1c1c 91%,#131313 100%);background:linear-gradient(to bottom,#4c4c4c 0,#595959 12%,#666 25%,#474747 39%,#2c2c2c 50%,#000 51%,#111 60%,#2b2b2b 76%,#1c1c1c 91%,#131313 100%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#4c4c4c',endColorstr='#131313',GradientType=0)}div.vis-color-picker div.vis-new-color{position:absolute;width:140px;height:20px;border:1px solid rgba(0,0,0,0.1);border-radius:5px;top:380px;left:159px;text-align:right;padding-right:2px;font-size:10px;color:rgba(0,0,0,0.4);vertical-align:middle;line-height:20px}div.vis-color-picker div.vis-initial-color{position:absolute;width:140px;height:20px;border:1px solid rgba(0,0,0,0.1);border-radius:5px;top:380px;left:10px;text-align:left;padding-left:2px;font-size:10px;color:rgba(0,0,0,0.4);vertical-align:middle;line-height:20px}div.vis-color-picker div.vis-label{position:absolute;width:300px;left:10px}div.vis-color-picker div.vis-label.vis-brightness{top:300px}div.vis-color-picker div.vis-label.vis-opacity{top:338px}div.vis-color-picker div.vis-button{position:absolute;width:68px;height:25px;border-radius:10px;vertical-align:middle;text-align:center;line-height:25px;top:410px;border:2px solid #d9d9d9;background-color:#f7f7f7;cursor:pointer}div.vis-color-picker div.vis-button.vis-cancel{left:5px}div.vis-color-picker div.vis-button.vis-load{left:82px}div.vis-color-picker div.vis-button.vis-apply{left:159px}div.vis-color-picker div.vis-button.vis-save{left:236px}div.vis-color-picker input.vis-range{width:290px;height:20px}div.vis-network div.vis-manipulation{box-sizing:content-box;border-width:0;border-bottom:1px;border-style:solid;border-color:#d6d9d8;background:#fff;background:-moz-linear-gradient(top,#fff 0,#fcfcfc 48%,#fafafa 50%,#fcfcfc 100%);background:-webkit-gradient(linear,left top,left bottom,color-stop(0,#fff),color-stop(48%,#fcfcfc),color-stop(50%,#fafafa),color-stop(100%,#fcfcfc));background:-webkit-linear-gradient(top,#fff 0,#fcfcfc 48%,#fafafa 50%,#fcfcfc 100%);background:-o-linear-gradient(top,#fff 0,#fcfcfc 48%,#fafafa 50%,#fcfcfc 100%);background:-ms-linear-gradient(top,#fff 0,#fcfcfc 48%,#fafafa 50%,#fcfcfc 100%);background:linear-gradient(to bottom,#fff 0,#fcfcfc 48%,#fafafa 50%,#fcfcfc 100%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff',endColorstr='#fcfcfc',GradientType=0);padding-top:4px;position:absolute;left:0;top:0;width:100%;height:28px}div.vis-network div.vis-edit-mode{position:absolute;left:0;top:5px;height:30px}div.vis-network div.vis-close{position:absolute;right:0;top:0;width:30px;height:30px;background-position:20px 3px;background-repeat:no-repeat;background-image:url(<<datauri \"$:/plugins/felixhayashi/vis/img/network/cross.png\">>);cursor:pointer;-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}div.vis-network div.vis-close:hover{opacity:.6}div.vis-network div.vis-manipulation div.vis-button,div.vis-network div.vis-edit-mode div.vis-button{float:left;font-family:verdana;font-size:12px;-moz-border-radius:15px;border-radius:15px;display:inline-block;background-position:0 0;background-repeat:no-repeat;height:24px;margin-left:10px;cursor:pointer;padding:0 8px 0 8px;-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}div.vis-network div.vis-manipulation div.vis-button:hover{box-shadow:1px 1px 8px rgba(0,0,0,0.20)}div.vis-network div.vis-manipulation div.vis-button:active{box-shadow:1px 1px 8px rgba(0,0,0,0.50)}div.vis-network div.vis-manipulation div.vis-button.vis-back{background-image:url(<<datauri \"$:/plugins/felixhayashi/vis/img/network/backIcon.png\">>)}div.vis-network div.vis-manipulation div.vis-button.vis-none:hover{box-shadow:1px 1px 8px rgba(0,0,0,0.0);cursor:default}div.vis-network div.vis-manipulation div.vis-button.vis-none:active{box-shadow:1px 1px 8px rgba(0,0,0,0.0)}div.vis-network div.vis-manipulation div.vis-button.vis-none{padding:0}div.vis-network div.vis-manipulation div.notification{margin:2px;font-weight:bold}div.vis-network div.vis-manipulation div.vis-button.vis-add{background-image:url(<<datauri \"$:/plugins/felixhayashi/vis/img/network/addNodeIcon.png\">>)}div.vis-network div.vis-manipulation div.vis-button.vis-edit,div.vis-network div.vis-edit-mode div.vis-button.vis-edit{background-image:url(<<datauri \"$:/plugins/felixhayashi/vis/img/network/editIcon.png\">>)}div.vis-network div.vis-edit-mode div.vis-button.vis-edit.vis-edit-mode{background-color:#fcfcfc;border:1px solid #ccc}div.vis-network div.vis-manipulation div.vis-button.vis-connect{background-image:url(<<datauri \"$:/plugins/felixhayashi/vis/img/network/connectIcon.png\">>)}div.vis-network div.vis-manipulation div.vis-button.vis-delete{background-image:url(<<datauri \"$:/plugins/felixhayashi/vis/img/network/deleteIcon.png\">>)}div.vis-network div.vis-manipulation div.vis-label,div.vis-network div.vis-edit-mode div.vis-label{margin:0 0 0 23px;line-height:25px}div.vis-network div.vis-manipulation div.vis-separator-line{float:left;display:inline-block;width:1px;height:21px;background-color:#bdbdbd;margin:0 7px 0 15px}div.vis-network div.vis-navigation div.vis-button{width:34px;height:34px;-moz-border-radius:17px;border-radius:17px;position:absolute;display:inline-block;background-position:2px 2px;background-repeat:no-repeat;cursor:pointer;-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}div.vis-network div.vis-navigation div.vis-button:hover{box-shadow:0 0 3px 3px rgba(56,207,21,0.30)}div.vis-network div.vis-navigation div.vis-button:active{box-shadow:0 0 1px 3px rgba(56,207,21,0.95)}div.vis-network div.vis-navigation div.vis-button.vis-up{background-image:url(<<datauri \"$:/plugins/felixhayashi/vis/img/network/upArrow.png\">>);bottom:50px;left:55px}div.vis-network div.vis-navigation div.vis-button.vis-down{background-image:url(<<datauri \"$:/plugins/felixhayashi/vis/img/network/downArrow.png\">>);bottom:10px;left:55px}div.vis-network div.vis-navigation div.vis-button.vis-left{background-image:url(<<datauri \"$:/plugins/felixhayashi/vis/img/network/leftArrow.png\">>);bottom:10px;left:15px}div.vis-network div.vis-navigation div.vis-button.vis-right{background-image:url(<<datauri \"$:/plugins/felixhayashi/vis/img/network/rightArrow.png\">>);bottom:10px;left:95px}div.vis-network div.vis-navigation div.vis-button.vis-zoomIn{background-image:url(<<datauri \"$:/plugins/felixhayashi/vis/img/network/plus.png\">>);bottom:10px;right:15px}div.vis-network div.vis-navigation div.vis-button.vis-zoomOut{background-image:url(<<datauri \"$:/plugins/felixhayashi/vis/img/network/minus.png\">>);bottom:10px;right:55px}div.vis-network div.vis-navigation div.vis-button.vis-zoomExtends{background-image:url(<<datauri \"$:/plugins/felixhayashi/vis/img/network/zoomExtends.png\">>);bottom:50px;right:15px}.vis-current-time{background-color:#ff7f6e;width:2px;z-index:1;pointer-events:none}.vis-rolling-mode-btn{height:40px;width:40px;position:absolute;top:7px;right:20px;border-radius:50%;font-size:28px;cursor:pointer;opacity:.8;color:white;font-weight:bold;text-align:center;background:#3876c2}.vis-rolling-mode-btn:before{content:\"\\26F6\"}.vis-rolling-mode-btn:hover{opacity:1}.vis-custom-time{background-color:#6e94ff;width:2px;cursor:move;z-index:1}.vis-panel.vis-background.vis-horizontal .vis-grid.vis-horizontal{position:absolute;width:100%;height:0;border-bottom:1px solid}.vis-panel.vis-background.vis-horizontal .vis-grid.vis-minor{border-color:#e5e5e5}.vis-panel.vis-background.vis-horizontal .vis-grid.vis-major{border-color:#bfbfbf}.vis-data-axis .vis-y-axis.vis-major{width:100%;position:absolute;color:#4d4d4d;white-space:nowrap}.vis-data-axis .vis-y-axis.vis-major.vis-measure{padding:0;margin:0;border:0;visibility:hidden;width:auto}.vis-data-axis .vis-y-axis.vis-minor{position:absolute;width:100%;color:#bebebe;white-space:nowrap}.vis-data-axis .vis-y-axis.vis-minor.vis-measure{padding:0;margin:0;border:0;visibility:hidden;width:auto}.vis-data-axis .vis-y-axis.vis-title{position:absolute;color:#4d4d4d;white-space:nowrap;bottom:20px;text-align:center}.vis-data-axis .vis-y-axis.vis-title.vis-measure{padding:0;margin:0;visibility:hidden;width:auto}.vis-data-axis .vis-y-axis.vis-title.vis-left{bottom:0;-webkit-transform-origin:left top;-moz-transform-origin:left top;-ms-transform-origin:left top;-o-transform-origin:left top;transform-origin:left bottom;-webkit-transform:rotate(-90deg);-moz-transform:rotate(-90deg);-ms-transform:rotate(-90deg);-o-transform:rotate(-90deg);transform:rotate(-90deg)}.vis-data-axis .vis-y-axis.vis-title.vis-right{bottom:0;-webkit-transform-origin:right bottom;-moz-transform-origin:right bottom;-ms-transform-origin:right bottom;-o-transform-origin:right bottom;transform-origin:right bottom;-webkit-transform:rotate(90deg);-moz-transform:rotate(90deg);-ms-transform:rotate(90deg);-o-transform:rotate(90deg);transform:rotate(90deg)}.vis-legend{background-color:rgba(247,252,255,0.65);padding:5px;border:1px solid #b3b3b3;box-shadow:2px 2px 10px rgba(154,154,154,0.55)}.vis-legend-text{white-space:nowrap;display:inline-block}.vis-item{position:absolute;color:#1a1a1a;border-color:#97b0f8;border-width:1px;background-color:#d5ddf6;display:inline-block;z-index:1}.vis-item.vis-selected{border-color:#ffc200;background-color:#fff785;z-index:2}.vis-editable.vis-selected{cursor:move}.vis-item.vis-point.vis-selected{background-color:#fff785}.vis-item.vis-box{text-align:center;border-style:solid;border-radius:2px}.vis-item.vis-point{background:0}.vis-item.vis-dot{position:absolute;padding:0;border-width:4px;border-style:solid;border-radius:4px}.vis-item.vis-range{border-style:solid;border-radius:2px;box-sizing:border-box}.vis-item.vis-background{border:0;background-color:rgba(213,221,246,0.4);box-sizing:border-box;padding:0;margin:0}.vis-item .vis-item-overflow{position:relative;width:100%;height:100%;padding:0;margin:0;overflow:hidden}.vis-item-visible-frame{white-space:nowrap}.vis-item.vis-range .vis-item-content{position:relative;display:inline-block}.vis-item.vis-background .vis-item-content{position:absolute;display:inline-block}.vis-item.vis-line{padding:0;position:absolute;width:0;border-left-width:1px;border-left-style:solid}.vis-item .vis-item-content{white-space:nowrap;box-sizing:border-box;padding:5px}.vis-item .vis-onUpdateTime-tooltip{position:absolute;background:#4f81bd;color:white;width:200px;text-align:center;white-space:nowrap;padding:5px;border-radius:1px;transition:.4s;-o-transition:.4s;-moz-transition:.4s;-webkit-transition:.4s}.vis-item .vis-delete,.vis-item .vis-delete-rtl{position:absolute;top:0;width:24px;height:24px;box-sizing:border-box;padding:0 5px;cursor:pointer;-webkit-transition:background .2s linear;-moz-transition:background .2s linear;-ms-transition:background .2s linear;-o-transition:background .2s linear;transition:background .2s linear}.vis-item .vis-delete{right:-24px}.vis-item .vis-delete-rtl{left:-24px}.vis-item .vis-delete:after,.vis-item .vis-delete-rtl:after{content:\"\\00D7\";color:red;font-family:arial,sans-serif;font-size:22px;font-weight:bold;-webkit-transition:color .2s linear;-moz-transition:color .2s linear;-ms-transition:color .2s linear;-o-transition:color .2s linear;transition:color .2s linear}.vis-item .vis-delete:hover,.vis-item .vis-delete-rtl:hover{background:red}.vis-item .vis-delete:hover:after,.vis-item .vis-delete-rtl:hover:after{color:white}.vis-item .vis-drag-center{position:absolute;width:100%;height:100%;top:0;left:0;cursor:move}.vis-item.vis-range .vis-drag-left{position:absolute;width:24px;max-width:20%;min-width:2px;height:100%;top:0;left:-4px;cursor:w-resize}.vis-item.vis-range .vis-drag-right{position:absolute;width:24px;max-width:20%;min-width:2px;height:100%;top:0;right:-4px;cursor:e-resize}.vis-range.vis-item.vis-readonly .vis-drag-left,.vis-range.vis-item.vis-readonly .vis-drag-right{cursor:auto}.vis-itemset{position:relative;padding:0;margin:0;box-sizing:border-box}.vis-itemset .vis-background,.vis-itemset .vis-foreground{position:absolute;width:100%;height:100%;overflow:visible}.vis-axis{position:absolute;width:100%;height:0;left:0;z-index:1}.vis-foreground .vis-group{position:relative;box-sizing:border-box;border-bottom:1px solid #bfbfbf}.vis-foreground .vis-group:last-child{border-bottom:0}.vis-nesting-group{cursor:pointer}.vis-nested-group{background:#f5f5f5}.vis-label.vis-nesting-group.expanded:before{content:\"\\25BC\"}.vis-label.vis-nesting-group.collapsed-rtl:before{content:\"\\25C0\"}.vis-label.vis-nesting-group.collapsed:before{content:\"\\25B6\"}.vis-overlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:10}.vis-labelset{position:relative;overflow:hidden;box-sizing:border-box}.vis-labelset .vis-label{position:relative;left:0;top:0;width:100%;color:#4d4d4d;box-sizing:border-box}.vis-labelset .vis-label{border-bottom:1px solid #bfbfbf}.vis-labelset .vis-label.draggable{cursor:pointer}.vis-labelset .vis-label:last-child{border-bottom:0}.vis-labelset .vis-label .vis-inner{display:inline-block;padding:5px}.vis-labelset .vis-label .vis-inner.vis-hidden{padding:0}.vis-panel{position:absolute;padding:0;margin:0;box-sizing:border-box}.vis-panel.vis-center,.vis-panel.vis-left,.vis-panel.vis-right,.vis-panel.vis-top,.vis-panel.vis-bottom{border:1px #bfbfbf}.vis-panel.vis-center,.vis-panel.vis-left,.vis-panel.vis-right{border-top-style:solid;border-bottom-style:solid;overflow:hidden}.vis-left.vis-panel.vis-vertical-scroll,.vis-right.vis-panel.vis-vertical-scroll{height:100%;overflow-x:hidden;overflow-y:scroll}.vis-left.vis-panel.vis-vertical-scroll{direction:rtl}.vis-left.vis-panel.vis-vertical-scroll .vis-content{direction:ltr}.vis-right.vis-panel.vis-vertical-scroll{direction:ltr}.vis-right.vis-panel.vis-vertical-scroll .vis-content{direction:rtl}.vis-panel.vis-center,.vis-panel.vis-top,.vis-panel.vis-bottom{border-left-style:solid;border-right-style:solid}.vis-background{overflow:hidden}.vis-panel>.vis-content{position:relative}.vis-panel .vis-shadow{position:absolute;width:100%;height:1px;box-shadow:0 0 10px rgba(0,0,0,0.8)}.vis-panel .vis-shadow.vis-top{top:-1px;left:0}.vis-panel .vis-shadow.vis-bottom{bottom:-1px;left:0}.vis-graph-group0{fill:#4f81bd;fill-opacity:0;stroke-width:2px;stroke:#4f81bd}.vis-graph-group1{fill:#f79646;fill-opacity:0;stroke-width:2px;stroke:#f79646}.vis-graph-group2{fill:#8c51cf;fill-opacity:0;stroke-width:2px;stroke:#8c51cf}.vis-graph-group3{fill:#75c841;fill-opacity:0;stroke-width:2px;stroke:#75c841}.vis-graph-group4{fill:#ff0100;fill-opacity:0;stroke-width:2px;stroke:#ff0100}.vis-graph-group5{fill:#37d8e6;fill-opacity:0;stroke-width:2px;stroke:#37d8e6}.vis-graph-group6{fill:#042662;fill-opacity:0;stroke-width:2px;stroke:#042662}.vis-graph-group7{fill:#00ff26;fill-opacity:0;stroke-width:2px;stroke:#00ff26}.vis-graph-group8{fill:#f0f;fill-opacity:0;stroke-width:2px;stroke:#f0f}.vis-graph-group9{fill:#8f3938;fill-opacity:0;stroke-width:2px;stroke:#8f3938}.vis-timeline .vis-fill{fill-opacity:.1;stroke:none}.vis-timeline .vis-bar{fill-opacity:.5;stroke-width:1px}.vis-timeline .vis-point{stroke-width:2px;fill-opacity:1.0}.vis-timeline .vis-legend-background{stroke-width:1px;fill-opacity:.9;fill:#fff;stroke:#c2c2c2}.vis-timeline .vis-outline{stroke-width:1px;fill-opacity:1;fill:#fff;stroke:#e5e5e5}.vis-timeline .vis-icon-fill{fill-opacity:.3;stroke:none}.vis-time-axis{position:relative;overflow:hidden}.vis-time-axis.vis-foreground{top:0;left:0;width:100%}.vis-time-axis.vis-background{position:absolute;top:0;left:0;width:100%;height:100%}.vis-time-axis .vis-text{position:absolute;color:#4d4d4d;padding:3px;overflow:hidden;box-sizing:border-box;white-space:nowrap}.vis-time-axis .vis-text.vis-measure{position:absolute;padding-left:0;padding-right:0;margin-left:0;margin-right:0;visibility:hidden}.vis-time-axis .vis-grid.vis-vertical{position:absolute;border-left:1px solid}.vis-time-axis .vis-grid.vis-vertical-rtl{position:absolute;border-right:1px solid}.vis-time-axis .vis-grid.vis-minor{border-color:#e5e5e5}.vis-time-axis .vis-grid.vis-major{border-color:#bfbfbf}.vis-timeline{position:relative;border:1px solid #bfbfbf;overflow:hidden;padding:0;margin:0;box-sizing:border-box}"
},
"$:/plugins/felixhayashi/vis/vis.js": {
"title": "$:/plugins/felixhayashi/vis/vis.js",
"text": "/*\\\ntitle: $:/plugins/felixhayashi/vis/vis.js\ntype: application/javascript\nmodule-type: library\n\n@preserve\n\\*/\n\n/*** TO AVOID STRANGE LIB ERRORS FROM BUBBLING UP *****************/\n\nif($tw.boot.tasks.trapErrors) {\n\n var defaultHandler = window.onerror;\n window.onerror = function(errorMsg, url, lineNumber) {\n \n if(errorMsg.indexOf(\"NS_ERROR_NOT_AVAILABLE\") !== -1\n && url == \"$:/plugins/felixhayashi/vis/vis.js\") {\n \n var text = \"Strange firefox related vis.js error (see #125)\";\n console.error(text, arguments);\n \n } else if(errorMsg.indexOf(\"Permission denied to access property\") !== -1) {\n \n var text = \"Strange firefox related vis.js error (see #163)\";\n console.error(text, arguments);\n \n } else if(defaultHandler) {\n \n defaultHandler.apply(this, arguments);\n \n }\n \n }\n \n}\n\n/******************************************************************/\n\n/**\n * vis.js\n * https://github.com/almende/vis\n *\n * A dynamic, browser-based visualization library.\n *\n * @version 4.21.0\n * @date 2017-10-12\n *\n * @license\n * Copyright (C) 2011-2017 Almende B.V, http://almende.com\n *\n * Vis.js is dual licensed under both\n *\n * * The Apache 2.0 License\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * and\n *\n * * The MIT License\n * http://opensource.org/licenses/MIT\n *\n * Vis.js may be distributed under either license.\n */\n\"use strict\";(function webpackUniversalModuleDefinition(root,factory){if(typeof exports===\"object\"&&typeof module===\"object\")module.exports=factory();else if(typeof define===\"function\"&&define.amd)define([],factory);else if(typeof exports===\"object\")exports[\"vis\"]=factory();else root[\"vis\"]=factory()})(this,function(){return function(modules){var installedModules={};function __webpack_require__(moduleId){if(installedModules[moduleId]){return installedModules[moduleId].exports}var module=installedModules[moduleId]={i:moduleId,l:false,exports:{}};modules[moduleId].call(module.exports,module,module.exports,__webpack_require__);module.l=true;return module.exports}__webpack_require__.m=modules;__webpack_require__.c=installedModules;__webpack_require__.d=function(exports,name,getter){if(!__webpack_require__.o(exports,name)){Object.defineProperty(exports,name,{configurable:false,enumerable:true,get:getter})}};__webpack_require__.n=function(module){var getter=module&&module.__esModule?function getDefault(){return module[\"default\"]}:function getModuleExports(){return module};__webpack_require__.d(getter,\"a\",getter);return getter};__webpack_require__.o=function(object,property){return Object.prototype.hasOwnProperty.call(object,property)};__webpack_require__.p=\"\";return __webpack_require__(__webpack_require__.s=123)}([function(module,exports,__webpack_require__){\"use strict\";exports.__esModule=true;exports.default=function(instance,Constructor){if(!(instance instanceof Constructor)){throw new TypeError(\"Cannot call a class as a function\")}}},function(module,exports,__webpack_require__){\"use strict\";exports.__esModule=true;var _defineProperty=__webpack_require__(169);var _defineProperty2=_interopRequireDefault(_defineProperty);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}exports.default=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||false;descriptor.configurable=true;if(\"value\"in descriptor)descriptor.writable=true;(0,_defineProperty2.default)(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){if(protoProps)defineProperties(Constructor.prototype,protoProps);if(staticProps)defineProperties(Constructor,staticProps);return Constructor}}()},function(module,exports,__webpack_require__){\"use strict\";var _getIterator2=__webpack_require__(77);var _getIterator3=_interopRequireDefault(_getIterator2);var _create=__webpack_require__(29);var _create2=_interopRequireDefault(_create);var _keys=__webpack_require__(8);var _keys2=_interopRequireDefault(_keys);var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var moment=__webpack_require__(9);var uuid=__webpack_require__(157);exports.isNumber=function(object){return object instanceof Number||typeof object==\"number\"};exports.recursiveDOMDelete=function(DOMobject){if(DOMobject){while(DOMobject.hasChildNodes()===true){exports.recursiveDOMDelete(DOMobject.firstChild);DOMobject.removeChild(DOMobject.firstChild)}}};exports.giveRange=function(min,max,total,value){if(max==min){return.5}else{var scale=1/(max-min);return Math.max(0,(value-min)*scale)}};exports.isString=function(object){return object instanceof String||typeof object==\"string\"};exports.isDate=function(object){if(object instanceof Date){return true}else if(exports.isString(object)){var match=ASPDateRegex.exec(object);if(match){return true}else if(!isNaN(Date.parse(object))){return true}}return false};exports.randomUUID=function(){return uuid.v4()};exports.assignAllKeys=function(obj,value){for(var prop in obj){if(obj.hasOwnProperty(prop)){if((0,_typeof3[\"default\"])(obj[prop])!==\"object\"){obj[prop]=value}}}};function copyOrDelete(a,b,prop,allowDeletion){var doDeletion=false;if(allowDeletion===true){doDeletion=b[prop]===null&&a[prop]!==undefined}if(doDeletion){delete a[prop]}else{a[prop]=b[prop]}}exports.fillIfDefined=function(a,b){var allowDeletion=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;for(var prop in a){if(b[prop]!==undefined){if(b[prop]===null||(0,_typeof3[\"default\"])(b[prop])!==\"object\"){copyOrDelete(a,b,prop,allowDeletion)}else{if((0,_typeof3[\"default\"])(a[prop])===\"object\"){exports.fillIfDefined(a[prop],b[prop],allowDeletion)}}}}};exports.extend=function(a,b){for(var i=1;i<arguments.length;i++){var other=arguments[i];for(var prop in other){if(other.hasOwnProperty(prop)){a[prop]=other[prop]}}}return a};exports.selectiveExtend=function(props,a,b){if(!Array.isArray(props)){throw new Error(\"Array with property names expected as first argument\")}for(var i=2;i<arguments.length;i++){var other=arguments[i];for(var p=0;p<props.length;p++){var prop=props[p];if(other&&other.hasOwnProperty(prop)){a[prop]=other[prop]}}}return a};exports.selectiveDeepExtend=function(props,a,b){var allowDeletion=arguments.length>3&&arguments[3]!==undefined?arguments[3]:false;if(Array.isArray(b)){throw new TypeError(\"Arrays are not supported by deepExtend\")}for(var p=0;p<props.length;p++){var prop=props[p];if(b.hasOwnProperty(prop)){if(b[prop]&&b[prop].constructor===Object){if(a[prop]===undefined){a[prop]={}}if(a[prop].constructor===Object){exports.deepExtend(a[prop],b[prop],false,allowDeletion)}else{copyOrDelete(a,b,prop,allowDeletion)}}else if(Array.isArray(b[prop])){throw new TypeError(\"Arrays are not supported by deepExtend\")}else{copyOrDelete(a,b,prop,allowDeletion)}}}return a};exports.selectiveNotDeepExtend=function(propsToExclude,a,b){var allowDeletion=arguments.length>3&&arguments[3]!==undefined?arguments[3]:false;if(Array.isArray(b)){throw new TypeError(\"Arrays are not supported by deepExtend\")}for(var prop in b){if(!b.hasOwnProperty(prop))continue;if(propsToExclude.indexOf(prop)!==-1)continue;if(b[prop]&&b[prop].constructor===Object){if(a[prop]===undefined){a[prop]={}}if(a[prop].constructor===Object){exports.deepExtend(a[prop],b[prop])}else{copyOrDelete(a,b,prop,allowDeletion)}}else if(Array.isArray(b[prop])){a[prop]=[];for(var i=0;i<b[prop].length;i++){a[prop].push(b[prop][i])}}else{copyOrDelete(a,b,prop,allowDeletion)}}return a};exports.deepExtend=function(a,b){var protoExtend=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;var allowDeletion=arguments.length>3&&arguments[3]!==undefined?arguments[3]:false;for(var prop in b){if(b.hasOwnProperty(prop)||protoExtend===true){if(b[prop]&&b[prop].constructor===Object){if(a[prop]===undefined){a[prop]={}}if(a[prop].constructor===Object){exports.deepExtend(a[prop],b[prop],protoExtend)}else{copyOrDelete(a,b,prop,allowDeletion)}}else if(Array.isArray(b[prop])){a[prop]=[];for(var i=0;i<b[prop].length;i++){a[prop].push(b[prop][i])}}else{copyOrDelete(a,b,prop,allowDeletion)}}}return a};exports.equalArray=function(a,b){if(a.length!=b.length)return false;for(var i=0,len=a.length;i<len;i++){if(a[i]!=b[i])return false}return true};exports.convert=function(object,type){var match;if(object===undefined){return undefined}if(object===null){return null}if(!type){return object}if(!(typeof type===\"string\")&&!(type instanceof String)){throw new Error(\"Type must be a string\")}switch(type){case\"boolean\":case\"Boolean\":return Boolean(object);case\"number\":case\"Number\":if(exports.isString(object)&&!isNaN(Date.parse(object))){return moment(object).valueOf()}else{return Number(object.valueOf())}case\"string\":case\"String\":return String(object);case\"Date\":if(exports.isNumber(object)){return new Date(object)}if(object instanceof Date){return new Date(object.valueOf())}else if(moment.isMoment(object)){return new Date(object.valueOf())}if(exports.isString(object)){match=ASPDateRegex.exec(object);if(match){return new Date(Number(match[1]))}else{return moment(new Date(object)).toDate()}}else{throw new Error(\"Cannot convert object of type \"+exports.getType(object)+\" to type Date\")}case\"Moment\":if(exports.isNumber(object)){return moment(object)}if(object instanceof Date){return moment(object.valueOf())}else if(moment.isMoment(object)){return moment(object)}if(exports.isString(object)){match=ASPDateRegex.exec(object);if(match){return moment(Number(match[1]))}else{return moment(object)}}else{throw new Error(\"Cannot convert object of type \"+exports.getType(object)+\" to type Date\")}case\"ISODate\":if(exports.isNumber(object)){return new Date(object)}else if(object instanceof Date){return object.toISOString()}else if(moment.isMoment(object)){return object.toDate().toISOString()}else if(exports.isString(object)){match=ASPDateRegex.exec(object);if(match){return new Date(Number(match[1])).toISOString()}else{return moment(object).format()}}else{throw new Error(\"Cannot convert object of type \"+exports.getType(object)+\" to type ISODate\")}case\"ASPDate\":if(exports.isNumber(object)){return\"/Date(\"+object+\")/\"}else if(object instanceof Date){return\"/Date(\"+object.valueOf()+\")/\"}else if(exports.isString(object)){match=ASPDateRegex.exec(object);var value;if(match){value=new Date(Number(match[1])).valueOf()}else{value=new Date(object).valueOf()}return\"/Date(\"+value+\")/\"}else{throw new Error(\"Cannot convert object of type \"+exports.getType(object)+\" to type ASPDate\")}default:throw new Error('Unknown type \"'+type+'\"')}};var ASPDateRegex=/^\\/?Date\\((\\-?\\d+)/i;exports.getType=function(object){var type=typeof object===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(object);if(type==\"object\"){if(object===null){return\"null\"}if(object instanceof Boolean){return\"Boolean\"}if(object instanceof Number){return\"Number\"}if(object instanceof String){return\"String\"}if(Array.isArray(object)){return\"Array\"}if(object instanceof Date){return\"Date\"}return\"Object\"}else if(type==\"number\"){return\"Number\"}else if(type==\"boolean\"){return\"Boolean\"}else if(type==\"string\"){return\"String\"}else if(type===undefined){return\"undefined\"}return type};exports.copyAndExtendArray=function(arr,newValue){var newArr=[];for(var i=0;i<arr.length;i++){newArr.push(arr[i])}newArr.push(newValue);return newArr};exports.copyArray=function(arr){var newArr=[];for(var i=0;i<arr.length;i++){newArr.push(arr[i])}return newArr};exports.getAbsoluteLeft=function(elem){return elem.getBoundingClientRect().left};exports.getAbsoluteRight=function(elem){return elem.getBoundingClientRect().right};exports.getAbsoluteTop=function(elem){return elem.getBoundingClientRect().top};exports.addClassName=function(elem,classNames){var classes=elem.className.split(\" \");var newClasses=classNames.split(\" \");classes=classes.concat(newClasses.filter(function(className){return classes.indexOf(className)<0}));elem.className=classes.join(\" \")};exports.removeClassName=function(elem,classNames){var classes=elem.className.split(\" \");var oldClasses=classNames.split(\" \");classes=classes.filter(function(className){return oldClasses.indexOf(className)<0});elem.className=classes.join(\" \")};exports.forEach=function(object,callback){var i,len;if(Array.isArray(object)){for(i=0,len=object.length;i<len;i++){callback(object[i],i,object)}}else{for(i in object){if(object.hasOwnProperty(i)){callback(object[i],i,object)}}}};exports.toArray=function(object){var array=[];for(var prop in object){if(object.hasOwnProperty(prop))array.push(object[prop])}return array};exports.updateProperty=function(object,key,value){if(object[key]!==value){object[key]=value;return true}else{return false}};exports.throttle=function(fn){var scheduled=false;return function throttled(){if(!scheduled){scheduled=true;requestAnimationFrame(function(){scheduled=false;fn()})}}};exports.addEventListener=function(element,action,listener,useCapture){if(element.addEventListener){if(useCapture===undefined)useCapture=false;if(action===\"mousewheel\"&&navigator.userAgent.indexOf(\"Firefox\")>=0){action=\"DOMMouseScroll\"}element.addEventListener(action,listener,useCapture)}else{element.attachEvent(\"on\"+action,listener)}};exports.removeEventListener=function(element,action,listener,useCapture){if(element.removeEventListener){if(useCapture===undefined)useCapture=false;if(action===\"mousewheel\"&&navigator.userAgent.indexOf(\"Firefox\")>=0){action=\"DOMMouseScroll\"}element.removeEventListener(action,listener,useCapture)}else{element.detachEvent(\"on\"+action,listener)}};exports.preventDefault=function(event){if(!event)event=window.event;if(event.preventDefault){event.preventDefault()}else{event.returnValue=false}};exports.getTarget=function(event){if(!event){event=window.event}var target;if(event.target){target=event.target}else if(event.srcElement){target=event.srcElement}if(target.nodeType!=undefined&&target.nodeType==3){target=target.parentNode}return target};exports.hasParent=function(element,parent){var e=element;while(e){if(e===parent){return true}e=e.parentNode}return false};exports.option={};exports.option.asBoolean=function(value,defaultValue){if(typeof value==\"function\"){value=value()}if(value!=null){return value!=false}return defaultValue||null};exports.option.asNumber=function(value,defaultValue){if(typeof value==\"function\"){value=value()}if(value!=null){return Number(value)||defaultValue||null}return defaultValue||null};exports.option.asString=function(value,defaultValue){if(typeof value==\"function\"){value=value()}if(value!=null){return String(value)}return defaultValue||null};exports.option.asSize=function(value,defaultValue){if(typeof value==\"function\"){value=value()}if(exports.isString(value)){return value}else if(exports.isNumber(value)){return value+\"px\"}else{return defaultValue||null}};exports.option.asElement=function(value,defaultValue){if(typeof value==\"function\"){value=value()}return value||defaultValue||null};exports.hexToRGB=function(hex){var shorthandRegex=/^#?([a-f\\d])([a-f\\d])([a-f\\d])$/i;hex=hex.replace(shorthandRegex,function(m,r,g,b){return r+r+g+g+b+b});var result=/^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(hex);return result?{r:parseInt(result[1],16),g:parseInt(result[2],16),b:parseInt(result[3],16)}:null};exports.overrideOpacity=function(color,opacity){var rgb;if(color.indexOf(\"rgba\")!=-1){return color}else if(color.indexOf(\"rgb\")!=-1){rgb=color.substr(color.indexOf(\"(\")+1).replace(\")\",\"\").split(\",\");return\"rgba(\"+rgb[0]+\",\"+rgb[1]+\",\"+rgb[2]+\",\"+opacity+\")\"}else{rgb=exports.hexToRGB(color);if(rgb==null){return color}else{return\"rgba(\"+rgb.r+\",\"+rgb.g+\",\"+rgb.b+\",\"+opacity+\")\"}}};exports.RGBToHex=function(red,green,blue){return\"#\"+((1<<24)+(red<<16)+(green<<8)+blue).toString(16).slice(1)};exports.parseColor=function(color){var c;if(exports.isString(color)===true){if(exports.isValidRGB(color)===true){var rgb=color.substr(4).substr(0,color.length-5).split(\",\").map(function(value){return parseInt(value)});color=exports.RGBToHex(rgb[0],rgb[1],rgb[2])}if(exports.isValidHex(color)===true){var hsv=exports.hexToHSV(color);var lighterColorHSV={h:hsv.h,s:hsv.s*.8,v:Math.min(1,hsv.v*1.02)};var darkerColorHSV={h:hsv.h,s:Math.min(1,hsv.s*1.25),v:hsv.v*.8};var darkerColorHex=exports.HSVToHex(darkerColorHSV.h,darkerColorHSV.s,darkerColorHSV.v);var lighterColorHex=exports.HSVToHex(lighterColorHSV.h,lighterColorHSV.s,lighterColorHSV.v);c={background:color,border:darkerColorHex,highlight:{background:lighterColorHex,border:darkerColorHex},hover:{background:lighterColorHex,border:darkerColorHex}}}else{c={background:color,border:color,highlight:{background:color,border:color},hover:{background:color,border:color}}}}else{c={};c.background=color.background||undefined;c.border=color.border||undefined;if(exports.isString(color.highlight)){c.highlight={border:color.highlight,background:color.highlight}}else{c.highlight={};c.highlight.background=color.highlight&&color.highlight.background||undefined;c.highlight.border=color.highlight&&color.highlight.border||undefined}if(exports.isString(color.hover)){c.hover={border:color.hover,background:color.hover}}else{c.hover={};c.hover.background=color.hover&&color.hover.background||undefined;c.hover.border=color.hover&&color.hover.border||undefined}}return c};exports.RGBToHSV=function(red,green,blue){red=red/255;green=green/255;blue=blue/255;var minRGB=Math.min(red,Math.min(green,blue));var maxRGB=Math.max(red,Math.max(green,blue));if(minRGB==maxRGB){return{h:0,s:0,v:minRGB}}var d=red==minRGB?green-blue:blue==minRGB?red-green:blue-red;var h=red==minRGB?3:blue==minRGB?1:5;var hue=60*(h-d/(maxRGB-minRGB))/360;var saturation=(maxRGB-minRGB)/maxRGB;var value=maxRGB;return{h:hue,s:saturation,v:value}};var cssUtil={split:function split(cssText){var styles={};cssText.split(\";\").forEach(function(style){if(style.trim()!=\"\"){var parts=style.split(\":\");var key=parts[0].trim();var value=parts[1].trim();styles[key]=value}});return styles},join:function join(styles){return(0,_keys2[\"default\"])(styles).map(function(key){return key+\": \"+styles[key]}).join(\"; \")}};exports.addCssText=function(element,cssText){var currentStyles=cssUtil.split(element.style.cssText);var newStyles=cssUtil.split(cssText);var styles=exports.extend(currentStyles,newStyles);element.style.cssText=cssUtil.join(styles)};exports.removeCssText=function(element,cssText){var styles=cssUtil.split(element.style.cssText);var removeStyles=cssUtil.split(cssText);for(var key in removeStyles){if(removeStyles.hasOwnProperty(key)){delete styles[key]}}element.style.cssText=cssUtil.join(styles)};exports.HSVToRGB=function(h,s,v){var r,g,b;var i=Math.floor(h*6);var f=h*6-i;var p=v*(1-s);var q=v*(1-f*s);var t=v*(1-(1-f)*s);switch(i%6){case 0:r=v,g=t,b=p;break;case 1:r=q,g=v,b=p;break;case 2:r=p,g=v,b=t;break;case 3:r=p,g=q,b=v;break;case 4:r=t,g=p,b=v;break;case 5:r=v,g=p,b=q;break}return{r:Math.floor(r*255),g:Math.floor(g*255),b:Math.floor(b*255)}};exports.HSVToHex=function(h,s,v){var rgb=exports.HSVToRGB(h,s,v);return exports.RGBToHex(rgb.r,rgb.g,rgb.b)};exports.hexToHSV=function(hex){var rgb=exports.hexToRGB(hex);return exports.RGBToHSV(rgb.r,rgb.g,rgb.b)};exports.isValidHex=function(hex){var isOk=/(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(hex);return isOk};exports.isValidRGB=function(rgb){rgb=rgb.replace(\" \",\"\");var isOk=/rgb\\((\\d{1,3}),(\\d{1,3}),(\\d{1,3})\\)/i.test(rgb);return isOk};exports.isValidRGBA=function(rgba){rgba=rgba.replace(\" \",\"\");var isOk=/rgba\\((\\d{1,3}),(\\d{1,3}),(\\d{1,3}),(.{1,3})\\)/i.test(rgba);return isOk};exports.selectiveBridgeObject=function(fields,referenceObject){if(referenceObject!==null&&(typeof referenceObject===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(referenceObject))===\"object\"){var objectTo=(0,_create2[\"default\"])(referenceObject);for(var i=0;i<fields.length;i++){if(referenceObject.hasOwnProperty(fields[i])){if((0,_typeof3[\"default\"])(referenceObject[fields[i]])==\"object\"){objectTo[fields[i]]=exports.bridgeObject(referenceObject[fields[i]])}}}return objectTo}else{return null}};exports.bridgeObject=function(referenceObject){if(referenceObject!==null&&(typeof referenceObject===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(referenceObject))===\"object\"){var objectTo=(0,_create2[\"default\"])(referenceObject);if(referenceObject instanceof Element){objectTo=referenceObject}else{objectTo=(0,_create2[\"default\"])(referenceObject);for(var i in referenceObject){if(referenceObject.hasOwnProperty(i)){if((0,_typeof3[\"default\"])(referenceObject[i])==\"object\"){objectTo[i]=exports.bridgeObject(referenceObject[i])}}}}return objectTo}else{return null}};exports.insertSort=function(a,compare){for(var i=0;i<a.length;i++){var k=a[i];for(var j=i;j>0&&compare(k,a[j-1])<0;j--){a[j]=a[j-1]}a[j]=k}return a};exports.mergeOptions=function(mergeTarget,options,option){var globalOptions=arguments.length>3&&arguments[3]!==undefined?arguments[3]:{};var isPresent=function isPresent(obj){return obj!==null&&obj!==undefined};var isObject=function isObject(obj){return obj!==null&&(typeof obj===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(obj))===\"object\"};var isEmpty=function isEmpty(obj){for(var x in obj){if(obj.hasOwnProperty(x))return false}return true};if(!isObject(mergeTarget)){throw new Error(\"Parameter mergeTarget must be an object\")}if(!isObject(options)){throw new Error(\"Parameter options must be an object\")}if(!isPresent(option)){throw new Error(\"Parameter option must have a value\")}if(!isObject(globalOptions)){throw new Error(\"Parameter globalOptions must be an object\")}var doMerge=function doMerge(target,options,option){if(!isObject(target[option])){target[option]={}}var src=options[option];var dst=target[option];for(var prop in src){if(src.hasOwnProperty(prop)){dst[prop]=src[prop]}}};var srcOption=options[option];var globalPassed=isObject(globalOptions)&&!isEmpty(globalOptions);var globalOption=globalPassed?globalOptions[option]:undefined;var globalEnabled=globalOption?globalOption.enabled:undefined;if(srcOption===undefined){return}if(typeof srcOption===\"boolean\"){if(!isObject(mergeTarget[option])){mergeTarget[option]={}}mergeTarget[option].enabled=srcOption;return}if(srcOption===null&&!isObject(mergeTarget[option])){if(isPresent(globalOption)){mergeTarget[option]=(0,_create2[\"default\"])(globalOption)}else{return}}if(!isObject(srcOption)){return}var enabled=true;if(srcOption.enabled!==undefined){enabled=srcOption.enabled}else{if(globalEnabled!==undefined){enabled=globalOption.enabled}}doMerge(mergeTarget,options,option);mergeTarget[option].enabled=enabled};exports.binarySearchCustom=function(orderedItems,comparator,field,field2){var maxIterations=1e4;var iteration=0;var low=0;var high=orderedItems.length-1;while(low<=high&&iteration<maxIterations){var middle=Math.floor((low+high)/2);var item=orderedItems[middle];var value=field2===undefined?item[field]:item[field][field2];var searchResult=comparator(value);if(searchResult==0){return middle}else if(searchResult==-1){low=middle+1}else{high=middle-1}iteration++}return-1};exports.binarySearchValue=function(orderedItems,target,field,sidePreference,comparator){var maxIterations=1e4;var iteration=0;var low=0;var high=orderedItems.length-1;var prevValue,value,nextValue,middle;comparator=comparator!=undefined?comparator:function(a,b){return a==b?0:a<b?-1:1};while(low<=high&&iteration<maxIterations){middle=Math.floor(.5*(high+low));prevValue=orderedItems[Math.max(0,middle-1)][field];value=orderedItems[middle][field];nextValue=orderedItems[Math.min(orderedItems.length-1,middle+1)][field];if(comparator(value,target)==0){return middle}else if(comparator(prevValue,target)<0&&comparator(value,target)>0){return sidePreference==\"before\"?Math.max(0,middle-1):middle}else if(comparator(value,target)<0&&comparator(nextValue,target)>0){return sidePreference==\"before\"?middle:Math.min(orderedItems.length-1,middle+1)}else{if(comparator(value,target)<0){low=middle+1}else{high=middle-1}}iteration++}return-1};exports.easingFunctions={linear:function linear(t){return t},easeInQuad:function easeInQuad(t){return t*t},easeOutQuad:function easeOutQuad(t){return t*(2-t)},easeInOutQuad:function easeInOutQuad(t){return t<.5?2*t*t:-1+(4-2*t)*t},easeInCubic:function easeInCubic(t){return t*t*t},easeOutCubic:function easeOutCubic(t){return--t*t*t+1},easeInOutCubic:function easeInOutCubic(t){return t<.5?4*t*t*t:(t-1)*(2*t-2)*(2*t-2)+1},easeInQuart:function easeInQuart(t){return t*t*t*t},easeOutQuart:function easeOutQuart(t){return 1- --t*t*t*t},easeInOutQuart:function easeInOutQuart(t){return t<.5?8*t*t*t*t:1-8*--t*t*t*t},easeInQuint:function easeInQuint(t){return t*t*t*t*t},easeOutQuint:function easeOutQuint(t){return 1+--t*t*t*t*t},easeInOutQuint:function easeInOutQuint(t){return t<.5?16*t*t*t*t*t:1+16*--t*t*t*t*t}};exports.getScrollBarWidth=function(){var inner=document.createElement(\"p\");inner.style.width=\"100%\";inner.style.height=\"200px\";var outer=document.createElement(\"div\");outer.style.position=\"absolute\";outer.style.top=\"0px\";outer.style.left=\"0px\";outer.style.visibility=\"hidden\";outer.style.width=\"200px\";outer.style.height=\"150px\";outer.style.overflow=\"hidden\";outer.appendChild(inner);document.body.appendChild(outer);var w1=inner.offsetWidth;outer.style.overflow=\"scroll\";var w2=inner.offsetWidth;if(w1==w2)w2=outer.clientWidth;document.body.removeChild(outer);return w1-w2};exports.topMost=function(pile,accessors){var candidate=void 0;if(!Array.isArray(accessors)){accessors=[accessors]}var _iteratorNormalCompletion=true;var _didIteratorError=false;var _iteratorError=undefined;try{for(var _iterator=(0,_getIterator3[\"default\"])(pile),_step;!(_iteratorNormalCompletion=(_step=_iterator.next()).done);_iteratorNormalCompletion=true){var member=_step.value;if(member){candidate=member[accessors[0]];for(var i=1;i<accessors.length;i++){if(candidate){candidate=candidate[accessors[i]]}else{continue}}if(typeof candidate!=\"undefined\"){break}}}}catch(err){_didIteratorError=true;_iteratorError=err}finally{try{if(!_iteratorNormalCompletion&&_iterator[\"return\"]){_iterator[\"return\"]()}}finally{if(_didIteratorError){throw _iteratorError}}}return candidate}},function(module,exports,__webpack_require__){module.exports={default:__webpack_require__(194),__esModule:true}},function(module,exports,__webpack_require__){\"use strict\";exports.__esModule=true;var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}exports.default=function(self,call){if(!self){throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\")}return call&&((typeof call===\"undefined\"?\"undefined\":(0,_typeof3.default)(call))===\"object\"||typeof call===\"function\")?call:self}},function(module,exports,__webpack_require__){\"use strict\";exports.__esModule=true;var _setPrototypeOf=__webpack_require__(196);var _setPrototypeOf2=_interopRequireDefault(_setPrototypeOf);var _create=__webpack_require__(29);var _create2=_interopRequireDefault(_create);var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}exports.default=function(subClass,superClass){if(typeof superClass!==\"function\"&&superClass!==null){throw new TypeError(\"Super expression must either be null or a function, not \"+(typeof superClass===\"undefined\"?\"undefined\":(0,_typeof3.default)(superClass)))}subClass.prototype=(0,_create2.default)(superClass&&superClass.prototype,{constructor:{value:subClass,enumerable:false,writable:true,configurable:true}});if(superClass)_setPrototypeOf2.default?(0,_setPrototypeOf2.default)(subClass,superClass):subClass.__proto__=superClass}},function(module,exports,__webpack_require__){\"use strict\";exports.__esModule=true;var _iterator=__webpack_require__(142);var _iterator2=_interopRequireDefault(_iterator);var _symbol=__webpack_require__(144);var _symbol2=_interopRequireDefault(_symbol);var _typeof=typeof _symbol2.default===\"function\"&&typeof _iterator2.default===\"symbol\"?function(obj){return typeof obj}:function(obj){return obj&&typeof _symbol2.default===\"function\"&&obj.constructor===_symbol2.default&&obj!==_symbol2.default.prototype?\"symbol\":typeof obj};function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}exports.default=typeof _symbol2.default===\"function\"&&_typeof(_iterator2.default)===\"symbol\"?function(obj){return typeof obj===\"undefined\"?\"undefined\":_typeof(obj)}:function(obj){return obj&&typeof _symbol2.default===\"function\"&&obj.constructor===_symbol2.default&&obj!==_symbol2.default.prototype?\"symbol\":typeof obj===\"undefined\"?\"undefined\":_typeof(obj)}},function(module,exports){var core=module.exports={version:\"2.5.1\"};if(typeof __e==\"number\")__e=core},function(module,exports,__webpack_require__){module.exports={default:__webpack_require__(140),__esModule:true}},function(module,exports,__webpack_require__){\"use strict\";module.exports=typeof window!==\"undefined\"&&window[\"moment\"]||__webpack_require__(154)},function(module,exports,__webpack_require__){\"use strict\";function hammerMock(){var noop=function noop(){};return{on:noop,off:noop,destroy:noop,emit:noop,get:function get(m){return{set:noop}}}}if(typeof window!==\"undefined\"){var propagating=__webpack_require__(175);var Hammer=window[\"Hammer\"]||__webpack_require__(176);module.exports=propagating(Hammer,{preventDefault:\"mouse\"})}else{module.exports=function(){return hammerMock()}}},function(module,exports,__webpack_require__){\"use strict\";var _stringify=__webpack_require__(19);var _stringify2=_interopRequireDefault(_stringify);var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);var _keys=__webpack_require__(8);var _keys2=_interopRequireDefault(_keys);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var Queue=__webpack_require__(43);function DataSet(data,options){if(data&&!Array.isArray(data)){options=data;data=null}this._options=options||{};this._data={};this.length=0;this._fieldId=this._options.fieldId||\"id\";this._type={};if(this._options.type){var fields=(0,_keys2[\"default\"])(this._options.type);for(var i=0,len=fields.length;i<len;i++){var field=fields[i];var value=this._options.type[field];if(value==\"Date\"||value==\"ISODate\"||value==\"ASPDate\"){this._type[field]=\"Date\"}else{this._type[field]=value}}}this._subscribers={};if(data){this.add(data)}this.setOptions(options)}DataSet.prototype.setOptions=function(options){if(options&&options.queue!==undefined){if(options.queue===false){if(this._queue){this._queue.destroy();delete this._queue}}else{if(!this._queue){this._queue=Queue.extend(this,{replace:[\"add\",\"update\",\"remove\"]})}if((0,_typeof3[\"default\"])(options.queue)===\"object\"){this._queue.setOptions(options.queue)}}}};DataSet.prototype.on=function(event,callback){var subscribers=this._subscribers[event];if(!subscribers){subscribers=[];this._subscribers[event]=subscribers}subscribers.push({callback:callback})};DataSet.prototype.off=function(event,callback){var subscribers=this._subscribers[event];if(subscribers){this._subscribers[event]=subscribers.filter(function(listener){return listener.callback!=callback})}};DataSet.prototype._trigger=function(event,params,senderId){if(event==\"*\"){throw new Error(\"Cannot trigger event *\")}var subscribers=[];if(event in this._subscribers){subscribers=subscribers.concat(this._subscribers[event])}if(\"*\"in this._subscribers){subscribers=subscribers.concat(this._subscribers[\"*\"])}for(var i=0,len=subscribers.length;i<len;i++){var subscriber=subscribers[i];if(subscriber.callback){subscriber.callback(event,params,senderId||null)}}};DataSet.prototype.add=function(data,senderId){var addedIds=[],id,me=this;if(Array.isArray(data)){for(var i=0,len=data.length;i<len;i++){id=me._addItem(data[i]);addedIds.push(id)}}else if(data&&(typeof data===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(data))===\"object\"){id=me._addItem(data);addedIds.push(id)}else{throw new Error(\"Unknown dataType\")}if(addedIds.length){this._trigger(\"add\",{items:addedIds},senderId)}return addedIds};DataSet.prototype.update=function(data,senderId){var addedIds=[];var updatedIds=[];var oldData=[];var updatedData=[];var me=this;var fieldId=me._fieldId;var addOrUpdate=function addOrUpdate(item){var id=item[fieldId];if(me._data[id]){var oldItem=util.extend({},me._data[id]);id=me._updateItem(item);updatedIds.push(id);updatedData.push(item);oldData.push(oldItem)}else{id=me._addItem(item);addedIds.push(id)}};if(Array.isArray(data)){for(var i=0,len=data.length;i<len;i++){if(data[i]&&(0,_typeof3[\"default\"])(data[i])===\"object\"){addOrUpdate(data[i])}else{console.warn(\"Ignoring input item, which is not an object at index \"+i)}}}else if(data&&(typeof data===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(data))===\"object\"){addOrUpdate(data)}else{throw new Error(\"Unknown dataType\")}if(addedIds.length){this._trigger(\"add\",{items:addedIds},senderId)}if(updatedIds.length){var props={items:updatedIds,oldData:oldData,data:updatedData};this._trigger(\"update\",props,senderId)}return addedIds.concat(updatedIds)};DataSet.prototype.get=function(args){var me=this;var id,ids,options;var firstType=util.getType(arguments[0]);if(firstType==\"String\"||firstType==\"Number\"){id=arguments[0];options=arguments[1]}else if(firstType==\"Array\"){\nids=arguments[0];options=arguments[1]}else{options=arguments[0]}var returnType;if(options&&options.returnType){var allowedValues=[\"Array\",\"Object\"];returnType=allowedValues.indexOf(options.returnType)==-1?\"Array\":options.returnType}else{returnType=\"Array\"}var type=options&&options.type||this._options.type;var filter=options&&options.filter;var items=[],item,itemIds,itemId,i,len;if(id!=undefined){item=me._getItem(id,type);if(item&&filter&&!filter(item)){item=null}}else if(ids!=undefined){for(i=0,len=ids.length;i<len;i++){item=me._getItem(ids[i],type);if(!filter||filter(item)){items.push(item)}}}else{itemIds=(0,_keys2[\"default\"])(this._data);for(i=0,len=itemIds.length;i<len;i++){itemId=itemIds[i];item=me._getItem(itemId,type);if(!filter||filter(item)){items.push(item)}}}if(options&&options.order&&id==undefined){this._sort(items,options.order)}if(options&&options.fields){var fields=options.fields;if(id!=undefined){item=this._filterFields(item,fields)}else{for(i=0,len=items.length;i<len;i++){items[i]=this._filterFields(items[i],fields)}}}if(returnType==\"Object\"){var result={},resultant;for(i=0,len=items.length;i<len;i++){resultant=items[i];result[resultant.id]=resultant}return result}else{if(id!=undefined){return item}else{return items}}};DataSet.prototype.getIds=function(options){var data=this._data,filter=options&&options.filter,order=options&&options.order,type=options&&options.type||this._options.type,itemIds=(0,_keys2[\"default\"])(data),i,len,id,item,items,ids=[];if(filter){if(order){items=[];for(i=0,len=itemIds.length;i<len;i++){id=itemIds[i];item=this._getItem(id,type);if(filter(item)){items.push(item)}}this._sort(items,order);for(i=0,len=items.length;i<len;i++){ids.push(items[i][this._fieldId])}}else{for(i=0,len=itemIds.length;i<len;i++){id=itemIds[i];item=this._getItem(id,type);if(filter(item)){ids.push(item[this._fieldId])}}}}else{if(order){items=[];for(i=0,len=itemIds.length;i<len;i++){id=itemIds[i];items.push(data[id])}this._sort(items,order);for(i=0,len=items.length;i<len;i++){ids.push(items[i][this._fieldId])}}else{for(i=0,len=itemIds.length;i<len;i++){id=itemIds[i];item=data[id];ids.push(item[this._fieldId])}}}return ids};DataSet.prototype.getDataSet=function(){return this};DataSet.prototype.forEach=function(callback,options){var filter=options&&options.filter,type=options&&options.type||this._options.type,data=this._data,itemIds=(0,_keys2[\"default\"])(data),i,len,item,id;if(options&&options.order){var items=this.get(options);for(i=0,len=items.length;i<len;i++){item=items[i];id=item[this._fieldId];callback(item,id)}}else{for(i=0,len=itemIds.length;i<len;i++){id=itemIds[i];item=this._getItem(id,type);if(!filter||filter(item)){callback(item,id)}}}};DataSet.prototype.map=function(callback,options){var filter=options&&options.filter,type=options&&options.type||this._options.type,mappedItems=[],data=this._data,itemIds=(0,_keys2[\"default\"])(data),i,len,id,item;for(i=0,len=itemIds.length;i<len;i++){id=itemIds[i];item=this._getItem(id,type);if(!filter||filter(item)){mappedItems.push(callback(item,id))}}if(options&&options.order){this._sort(mappedItems,options.order)}return mappedItems};DataSet.prototype._filterFields=function(item,fields){if(!item){return item}var filteredItem={},itemFields=(0,_keys2[\"default\"])(item),len=itemFields.length,i,field;if(Array.isArray(fields)){for(i=0;i<len;i++){field=itemFields[i];if(fields.indexOf(field)!=-1){filteredItem[field]=item[field]}}}else{for(i=0;i<len;i++){field=itemFields[i];if(fields.hasOwnProperty(field)){filteredItem[fields[field]]=item[field]}}}return filteredItem};DataSet.prototype._sort=function(items,order){if(util.isString(order)){var name=order;items.sort(function(a,b){var av=a[name];var bv=b[name];return av>bv?1:av<bv?-1:0})}else if(typeof order===\"function\"){items.sort(order)}else{throw new TypeError(\"Order must be a function or a string\")}};DataSet.prototype.remove=function(id,senderId){var removedIds=[],removedItems=[],ids=[],i,len,itemId,item;ids=Array.isArray(id)?id:[id];for(i=0,len=ids.length;i<len;i++){item=this._remove(ids[i]);if(item){itemId=item[this._fieldId];if(itemId!=undefined){removedIds.push(itemId);removedItems.push(item)}}}if(removedIds.length){this._trigger(\"remove\",{items:removedIds,oldData:removedItems},senderId)}return removedIds};DataSet.prototype._remove=function(id){var item,ident;if(util.isNumber(id)||util.isString(id)){ident=id}else if(id&&(typeof id===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(id))===\"object\"){ident=id[this._fieldId]}if(ident!==undefined&&this._data[ident]){item=this._data[ident];delete this._data[ident];this.length--;return item}return null};DataSet.prototype.clear=function(senderId){var i,len;var ids=(0,_keys2[\"default\"])(this._data);var items=[];for(i=0,len=ids.length;i<len;i++){items.push(this._data[ids[i]])}this._data={};this.length=0;this._trigger(\"remove\",{items:ids,oldData:items},senderId);return ids};DataSet.prototype.max=function(field){var data=this._data,itemIds=(0,_keys2[\"default\"])(data),max=null,maxField=null,i,len;for(i=0,len=itemIds.length;i<len;i++){var id=itemIds[i];var item=data[id];var itemField=item[field];if(itemField!=null&&(!max||itemField>maxField)){max=item;maxField=itemField}}return max};DataSet.prototype.min=function(field){var data=this._data,itemIds=(0,_keys2[\"default\"])(data),min=null,minField=null,i,len;for(i=0,len=itemIds.length;i<len;i++){var id=itemIds[i];var item=data[id];var itemField=item[field];if(itemField!=null&&(!min||itemField<minField)){min=item;minField=itemField}}return min};DataSet.prototype.distinct=function(field){var data=this._data;var itemIds=(0,_keys2[\"default\"])(data);var values=[];var fieldType=this._options.type&&this._options.type[field]||null;var count=0;var i,j,len;for(i=0,len=itemIds.length;i<len;i++){var id=itemIds[i];var item=data[id];var value=item[field];var exists=false;for(j=0;j<count;j++){if(values[j]==value){exists=true;break}}if(!exists&&value!==undefined){values[count]=value;count++}}if(fieldType){for(i=0,len=values.length;i<len;i++){values[i]=util.convert(values[i],fieldType)}}return values};DataSet.prototype._addItem=function(item){var id=item[this._fieldId];if(id!=undefined){if(this._data[id]){throw new Error(\"Cannot add item: item with id \"+id+\" already exists\")}}else{id=util.randomUUID();item[this._fieldId]=id}var d={},fields=(0,_keys2[\"default\"])(item),i,len;for(i=0,len=fields.length;i<len;i++){var field=fields[i];var fieldType=this._type[field];d[field]=util.convert(item[field],fieldType)}this._data[id]=d;this.length++;return id};DataSet.prototype._getItem=function(id,types){var field,value,i,len;var raw=this._data[id];if(!raw){return null}var converted={},fields=(0,_keys2[\"default\"])(raw);if(types){for(i=0,len=fields.length;i<len;i++){field=fields[i];value=raw[field];converted[field]=util.convert(value,types[field])}}else{for(i=0,len=fields.length;i<len;i++){field=fields[i];value=raw[field];converted[field]=value}}if(!converted[this._fieldId]){converted[this._fieldId]=raw.id}return converted};DataSet.prototype._updateItem=function(item){var id=item[this._fieldId];if(id==undefined){throw new Error(\"Cannot update item: item has no id (item: \"+(0,_stringify2[\"default\"])(item)+\")\")}var d=this._data[id];if(!d){throw new Error(\"Cannot update item: no item with id \"+id+\" found\")}var fields=(0,_keys2[\"default\"])(item);for(var i=0,len=fields.length;i<len;i++){var field=fields[i];var fieldType=this._type[field];d[field]=util.convert(item[field],fieldType)}return id};module.exports=DataSet},function(module,exports,__webpack_require__){\"use strict\";var _keys=__webpack_require__(8);var _keys2=_interopRequireDefault(_keys);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var DataSet=__webpack_require__(11);function DataView(data,options){this._data=null;this._ids={};this.length=0;this._options=options||{};this._fieldId=\"id\";this._subscribers={};var me=this;this.listener=function(){me._onEvent.apply(me,arguments)};this.setData(data)}DataView.prototype.setData=function(data){var ids,id,i,len,items;if(this._data){if(this._data.off){this._data.off(\"*\",this.listener)}ids=this._data.getIds({filter:this._options&&this._options.filter});items=[];for(i=0,len=ids.length;i<len;i++){items.push(this._data._data[ids[i]])}this._ids={};this.length=0;this._trigger(\"remove\",{items:ids,oldData:items})}this._data=data;if(this._data){this._fieldId=this._options.fieldId||this._data&&this._data.options&&this._data.options.fieldId||\"id\";ids=this._data.getIds({filter:this._options&&this._options.filter});for(i=0,len=ids.length;i<len;i++){id=ids[i];this._ids[id]=true}this.length=ids.length;this._trigger(\"add\",{items:ids});if(this._data.on){this._data.on(\"*\",this.listener)}}};DataView.prototype.refresh=function(){var id,i,len;var ids=this._data.getIds({filter:this._options&&this._options.filter}),oldIds=(0,_keys2[\"default\"])(this._ids),newIds={},addedIds=[],removedIds=[],removedItems=[];for(i=0,len=ids.length;i<len;i++){id=ids[i];newIds[id]=true;if(!this._ids[id]){addedIds.push(id);this._ids[id]=true}}for(i=0,len=oldIds.length;i<len;i++){id=oldIds[i];if(!newIds[id]){removedIds.push(id);removedItems.push(this._data._data[id]);delete this._ids[id]}}this.length+=addedIds.length-removedIds.length;if(addedIds.length){this._trigger(\"add\",{items:addedIds})}if(removedIds.length){this._trigger(\"remove\",{items:removedIds,oldData:removedItems})}};DataView.prototype.get=function(args){var me=this;var ids,options,data;var firstType=util.getType(arguments[0]);if(firstType==\"String\"||firstType==\"Number\"||firstType==\"Array\"){ids=arguments[0];options=arguments[1];data=arguments[2]}else{options=arguments[0];data=arguments[1]}var viewOptions=util.extend({},this._options,options);if(this._options.filter&&options&&options.filter){viewOptions.filter=function(item){return me._options.filter(item)&&options.filter(item)}}var getArguments=[];if(ids!=undefined){getArguments.push(ids)}getArguments.push(viewOptions);getArguments.push(data);return this._data&&this._data.get.apply(this._data,getArguments)};DataView.prototype.getIds=function(options){var ids;if(this._data){var defaultFilter=this._options.filter;var filter;if(options&&options.filter){if(defaultFilter){filter=function filter(item){return defaultFilter(item)&&options.filter(item)}}else{filter=options.filter}}else{filter=defaultFilter}ids=this._data.getIds({filter:filter,order:options&&options.order})}else{ids=[]}return ids};DataView.prototype.map=function(callback,options){var mappedItems=[];if(this._data){var defaultFilter=this._options.filter;var filter;if(options&&options.filter){if(defaultFilter){filter=function filter(item){return defaultFilter(item)&&options.filter(item)}}else{filter=options.filter}}else{filter=defaultFilter}mappedItems=this._data.map(callback,{filter:filter,order:options&&options.order})}else{mappedItems=[]}return mappedItems};DataView.prototype.getDataSet=function(){var dataSet=this;while(dataSet instanceof DataView){dataSet=dataSet._data}return dataSet||null};DataView.prototype._onEvent=function(event,params,senderId){var i,len,id,item;var ids=params&¶ms.items;var addedIds=[],updatedIds=[],removedIds=[],oldItems=[],updatedItems=[],removedItems=[];if(ids&&this._data){switch(event){case\"add\":for(i=0,len=ids.length;i<len;i++){id=ids[i];item=this.get(id);if(item){this._ids[id]=true;addedIds.push(id)}}break;case\"update\":for(i=0,len=ids.length;i<len;i++){id=ids[i];item=this.get(id);if(item){if(this._ids[id]){updatedIds.push(id);updatedItems.push(params.data[i]);oldItems.push(params.oldData[i])}else{this._ids[id]=true;addedIds.push(id)}}else{if(this._ids[id]){delete this._ids[id];removedIds.push(id);removedItems.push(params.oldData[i])}else{}}}break;case\"remove\":for(i=0,len=ids.length;i<len;i++){id=ids[i];if(this._ids[id]){delete this._ids[id];removedIds.push(id);removedItems.push(params.oldData[i])}}break}this.length+=addedIds.length-removedIds.length;if(addedIds.length){this._trigger(\"add\",{items:addedIds},senderId)}if(updatedIds.length){this._trigger(\"update\",{items:updatedIds,oldData:oldItems,data:updatedItems},senderId)}if(removedIds.length){this._trigger(\"remove\",{items:removedIds,oldData:removedItems},senderId)}}};DataView.prototype.on=DataSet.prototype.on;DataView.prototype.off=DataSet.prototype.off;DataView.prototype._trigger=DataSet.prototype._trigger;DataView.prototype.subscribe=DataView.prototype.on;DataView.prototype.unsubscribe=DataView.prototype.off;module.exports=DataView},function(module,exports,__webpack_require__){var store=__webpack_require__(57)(\"wks\");var uid=__webpack_require__(40);var Symbol=__webpack_require__(18).Symbol;var USE_SYMBOL=typeof Symbol==\"function\";var $exports=module.exports=function(name){return store[name]||(store[name]=USE_SYMBOL&&Symbol[name]||(USE_SYMBOL?Symbol:uid)(\"Symbol.\"+name))};$exports.store=store},function(module,exports,__webpack_require__){\"use strict\";exports.prepareElements=function(JSONcontainer){for(var elementType in JSONcontainer){if(JSONcontainer.hasOwnProperty(elementType)){JSONcontainer[elementType].redundant=JSONcontainer[elementType].used;JSONcontainer[elementType].used=[]}}};exports.cleanupElements=function(JSONcontainer){for(var elementType in JSONcontainer){if(JSONcontainer.hasOwnProperty(elementType)){if(JSONcontainer[elementType].redundant){for(var i=0;i<JSONcontainer[elementType].redundant.length;i++){JSONcontainer[elementType].redundant[i].parentNode.removeChild(JSONcontainer[elementType].redundant[i])}JSONcontainer[elementType].redundant=[]}}}};exports.resetElements=function(JSONcontainer){exports.prepareElements(JSONcontainer);exports.cleanupElements(JSONcontainer);exports.prepareElements(JSONcontainer)};exports.getSVGElement=function(elementType,JSONcontainer,svgContainer){var element;if(JSONcontainer.hasOwnProperty(elementType)){if(JSONcontainer[elementType].redundant.length>0){element=JSONcontainer[elementType].redundant[0];JSONcontainer[elementType].redundant.shift()}else{element=document.createElementNS(\"http://www.w3.org/2000/svg\",elementType);svgContainer.appendChild(element)}}else{element=document.createElementNS(\"http://www.w3.org/2000/svg\",elementType);JSONcontainer[elementType]={used:[],redundant:[]};svgContainer.appendChild(element)}JSONcontainer[elementType].used.push(element);return element};exports.getDOMElement=function(elementType,JSONcontainer,DOMContainer,insertBefore){var element;if(JSONcontainer.hasOwnProperty(elementType)){if(JSONcontainer[elementType].redundant.length>0){element=JSONcontainer[elementType].redundant[0];JSONcontainer[elementType].redundant.shift()}else{element=document.createElement(elementType);if(insertBefore!==undefined){DOMContainer.insertBefore(element,insertBefore)}else{DOMContainer.appendChild(element)}}}else{element=document.createElement(elementType);JSONcontainer[elementType]={used:[],redundant:[]};if(insertBefore!==undefined){DOMContainer.insertBefore(element,insertBefore)}else{DOMContainer.appendChild(element)}}JSONcontainer[elementType].used.push(element);return element};exports.drawPoint=function(x,y,groupTemplate,JSONcontainer,svgContainer,labelObj){var point;if(groupTemplate.style==\"circle\"){point=exports.getSVGElement(\"circle\",JSONcontainer,svgContainer);point.setAttributeNS(null,\"cx\",x);point.setAttributeNS(null,\"cy\",y);point.setAttributeNS(null,\"r\",.5*groupTemplate.size)}else{point=exports.getSVGElement(\"rect\",JSONcontainer,svgContainer);point.setAttributeNS(null,\"x\",x-.5*groupTemplate.size);point.setAttributeNS(null,\"y\",y-.5*groupTemplate.size);point.setAttributeNS(null,\"width\",groupTemplate.size);point.setAttributeNS(null,\"height\",groupTemplate.size)}if(groupTemplate.styles!==undefined){point.setAttributeNS(null,\"style\",groupTemplate.styles)}point.setAttributeNS(null,\"class\",groupTemplate.className+\" vis-point\");if(labelObj){var label=exports.getSVGElement(\"text\",JSONcontainer,svgContainer);if(labelObj.xOffset){x=x+labelObj.xOffset}if(labelObj.yOffset){y=y+labelObj.yOffset}if(labelObj.content){label.textContent=labelObj.content}if(labelObj.className){label.setAttributeNS(null,\"class\",labelObj.className+\" vis-label\")}label.setAttributeNS(null,\"x\",x);label.setAttributeNS(null,\"y\",y)}return point};exports.drawBar=function(x,y,width,height,className,JSONcontainer,svgContainer,style){if(height!=0){if(height<0){height*=-1;y-=height}var rect=exports.getSVGElement(\"rect\",JSONcontainer,svgContainer);rect.setAttributeNS(null,\"x\",x-.5*width);rect.setAttributeNS(null,\"y\",y);rect.setAttributeNS(null,\"width\",width);rect.setAttributeNS(null,\"height\",height);rect.setAttributeNS(null,\"class\",className);if(style){rect.setAttributeNS(null,\"style\",style)}}}},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});exports.printStyle=undefined;var _stringify=__webpack_require__(19);var _stringify2=_interopRequireDefault(_stringify);var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);var _keys=__webpack_require__(8);var _keys2=_interopRequireDefault(_keys);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var errorFound=false;var allOptions=void 0;var printStyle=\"background: #FFeeee; color: #dd0000\";var Validator=function(){function Validator(){(0,_classCallCheck3[\"default\"])(this,Validator)}(0,_createClass3[\"default\"])(Validator,null,[{key:\"validate\",value:function validate(options,referenceOptions,subObject){errorFound=false;allOptions=referenceOptions;var usedOptions=referenceOptions;if(subObject!==undefined){usedOptions=referenceOptions[subObject]}Validator.parse(options,usedOptions,[]);return errorFound}},{key:\"parse\",value:function parse(options,referenceOptions,path){for(var option in options){if(options.hasOwnProperty(option)){Validator.check(option,options,referenceOptions,path)}}}},{key:\"check\",value:function check(option,options,referenceOptions,path){if(referenceOptions[option]===undefined&&referenceOptions.__any__===undefined){Validator.getSuggestion(option,referenceOptions,path);return}var referenceOption=option;var is_object=true;if(referenceOptions[option]===undefined&&referenceOptions.__any__!==undefined){referenceOption=\"__any__\";is_object=Validator.getType(options[option])===\"object\"}else{}var refOptionObj=referenceOptions[referenceOption];if(is_object&&refOptionObj.__type__!==undefined){refOptionObj=refOptionObj.__type__}Validator.checkFields(option,options,referenceOptions,referenceOption,refOptionObj,path)}},{key:\"checkFields\",value:function checkFields(option,options,referenceOptions,referenceOption,refOptionObj,path){var log=function log(message){console.log(\"%c\"+message+Validator.printLocation(path,option),printStyle)};var optionType=Validator.getType(options[option]);var refOptionType=refOptionObj[optionType];if(refOptionType!==undefined){if(Validator.getType(refOptionType)===\"array\"&&refOptionType.indexOf(options[option])===-1){log('Invalid option detected in \"'+option+'\".'+\" Allowed values are:\"+Validator.print(refOptionType)+' not \"'+options[option]+'\". ');errorFound=true}else if(optionType===\"object\"&&referenceOption!==\"__any__\"){path=util.copyAndExtendArray(path,option);Validator.parse(options[option],referenceOptions[referenceOption],path)}}else if(refOptionObj[\"any\"]===undefined){log('Invalid type received for \"'+option+'\". Expected: '+Validator.print((0,_keys2[\"default\"])(refOptionObj))+\". Received [\"+optionType+'] \"'+options[option]+'\"');errorFound=true}}},{key:\"getType\",value:function getType(object){var type=typeof object===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(object);if(type===\"object\"){if(object===null){return\"null\"}if(object instanceof Boolean){return\"boolean\"}if(object instanceof Number){return\"number\"}if(object instanceof String){return\"string\"}if(Array.isArray(object)){return\"array\"}if(object instanceof Date){return\"date\"}if(object.nodeType!==undefined){return\"dom\"}if(object._isAMomentObject===true){return\"moment\"}return\"object\"}else if(type===\"number\"){return\"number\"}else if(type===\"boolean\"){return\"boolean\"}else if(type===\"string\"){return\"string\"}else if(type===undefined){return\"undefined\"}return type}},{key:\"getSuggestion\",value:function getSuggestion(option,options,path){var localSearch=Validator.findInOptions(option,options,path,false);var globalSearch=Validator.findInOptions(option,allOptions,[],true);var localSearchThreshold=8;var globalSearchThreshold=4;var msg=void 0;if(localSearch.indexMatch!==undefined){msg=\" in \"+Validator.printLocation(localSearch.path,option,\"\")+'Perhaps it was incomplete? Did you mean: \"'+localSearch.indexMatch+'\"?\\n\\n'}else if(globalSearch.distance<=globalSearchThreshold&&localSearch.distance>globalSearch.distance){msg=\" in \"+Validator.printLocation(localSearch.path,option,\"\")+\"Perhaps it was misplaced? Matching option found at: \"+Validator.printLocation(globalSearch.path,globalSearch.closestMatch,\"\")}else if(localSearch.distance<=localSearchThreshold){msg='. Did you mean \"'+localSearch.closestMatch+'\"?'+Validator.printLocation(localSearch.path,option)}else{msg=\". Did you mean one of these: \"+Validator.print((0,_keys2[\"default\"])(options))+Validator.printLocation(path,option)}console.log('%cUnknown option detected: \"'+option+'\"'+msg,printStyle);errorFound=true}},{key:\"findInOptions\",value:function findInOptions(option,options,path){var recursive=arguments.length>3&&arguments[3]!==undefined?arguments[3]:false;var min=1e9;var closestMatch=\"\";var closestMatchPath=[];var lowerCaseOption=option.toLowerCase();var indexMatch=undefined;for(var op in options){var distance=void 0;if(options[op].__type__!==undefined&&recursive===true){var result=Validator.findInOptions(option,options[op],util.copyAndExtendArray(path,op));if(min>result.distance){closestMatch=result.closestMatch;closestMatchPath=result.path;min=result.distance;indexMatch=result.indexMatch}}else{if(op.toLowerCase().indexOf(lowerCaseOption)!==-1){indexMatch=op}distance=Validator.levenshteinDistance(option,op);if(min>distance){closestMatch=op;closestMatchPath=util.copyArray(path);min=distance}}}return{closestMatch:closestMatch,path:closestMatchPath,distance:min,indexMatch:indexMatch}}},{key:\"printLocation\",value:function printLocation(path,option){var prefix=arguments.length>2&&arguments[2]!==undefined?arguments[2]:\"Problem value found at: \\n\";var str=\"\\n\\n\"+prefix+\"options = {\\n\";for(var i=0;i<path.length;i++){for(var j=0;j<i+1;j++){str+=\" \"}str+=path[i]+\": {\\n\"}for(var _j=0;_j<path.length+1;_j++){str+=\" \"}str+=option+\"\\n\";for(var _i=0;_i<path.length+1;_i++){for(var _j2=0;_j2<path.length-_i;_j2++){str+=\" \"}str+=\"}\\n\"}return str+\"\\n\\n\"}},{key:\"print\",value:function print(options){return(0,_stringify2[\"default\"])(options).replace(/(\\\")|(\\[)|(\\])|(,\"__type__\")/g,\"\").replace(/(\\,)/g,\", \")}},{key:\"levenshteinDistance\",value:function levenshteinDistance(a,b){if(a.length===0)return b.length;if(b.length===0)return a.length;var matrix=[];var i;for(i=0;i<=b.length;i++){matrix[i]=[i]}var j;for(j=0;j<=a.length;j++){matrix[0][j]=j}for(i=1;i<=b.length;i++){for(j=1;j<=a.length;j++){if(b.charAt(i-1)==a.charAt(j-1)){matrix[i][j]=matrix[i-1][j-1]}else{matrix[i][j]=Math.min(matrix[i-1][j-1]+1,Math.min(matrix[i][j-1]+1,matrix[i-1][j]+1))}}}return matrix[b.length][a.length]}}]);return Validator}();exports[\"default\"]=Validator;exports.printStyle=printStyle},function(module,exports,__webpack_require__){\"use strict\";var util=__webpack_require__(2);function Component(body,options){this.options=null;this.props=null}Component.prototype.setOptions=function(options){if(options){util.extend(this.options,options)}};Component.prototype.redraw=function(){return false};Component.prototype.destroy=function(){};Component.prototype._isResized=function(){var resized=this.props._previousWidth!==this.props.width||this.props._previousHeight!==this.props.height;this.props._previousWidth=this.props.width;this.props._previousHeight=this.props.height;return resized};module.exports=Component},function(module,exports,__webpack_require__){var global=__webpack_require__(18);var core=__webpack_require__(7);var ctx=__webpack_require__(80);var hide=__webpack_require__(26);var PROTOTYPE=\"prototype\";var $export=function(type,name,source){var IS_FORCED=type&$export.F;var IS_GLOBAL=type&$export.G;var IS_STATIC=type&$export.S;var IS_PROTO=type&$export.P;var IS_BIND=type&$export.B;var IS_WRAP=type&$export.W;var exports=IS_GLOBAL?core:core[name]||(core[name]={});var expProto=exports[PROTOTYPE];var target=IS_GLOBAL?global:IS_STATIC?global[name]:(global[name]||{})[PROTOTYPE];var key,own,out;if(IS_GLOBAL)source=name;for(key in source){own=!IS_FORCED&&target&&target[key]!==undefined;if(own&&key in exports)continue;out=own?target[key]:source[key];exports[key]=IS_GLOBAL&&typeof target[key]!=\"function\"?source[key]:IS_BIND&&own?ctx(out,global):IS_WRAP&&target[key]==out?function(C){var F=function(a,b,c){if(this instanceof C){switch(arguments.length){case 0:return new C;case 1:return new C(a);case 2:return new C(a,b)}return new C(a,b,c)}return C.apply(this,arguments)};F[PROTOTYPE]=C[PROTOTYPE];return F}(out):IS_PROTO&&typeof out==\"function\"?ctx(Function.call,out):out;if(IS_PROTO){(exports.virtual||(exports.virtual={}))[key]=out;if(type&$export.R&&expProto&&!expProto[key])hide(expProto,key,out)}}};$export.F=1;$export.G=2;$export.S=4;$export.P=8;$export.B=16;$export.W=32;$export.U=64;$export.R=128;module.exports=$export},function(module,exports){var global=module.exports=typeof window!=\"undefined\"&&window.Math==Math?window:typeof self!=\"undefined\"&&self.Math==Math?self:Function(\"return this\")();if(typeof __g==\"number\")__g=global},function(module,exports,__webpack_require__){module.exports={default:__webpack_require__(160),__esModule:true}},function(module,exports,__webpack_require__){var anObject=__webpack_require__(27);var IE8_DOM_DEFINE=__webpack_require__(81);var toPrimitive=__webpack_require__(53);var dP=Object.defineProperty;exports.f=__webpack_require__(21)?Object.defineProperty:function defineProperty(O,P,Attributes){anObject(O);P=toPrimitive(P,true);anObject(Attributes);if(IE8_DOM_DEFINE)try{return dP(O,P,Attributes)}catch(e){}if(\"get\"in Attributes||\"set\"in Attributes)throw TypeError(\"Accessors not supported!\");if(\"value\"in Attributes)O[P]=Attributes.value;return O}},function(module,exports,__webpack_require__){module.exports=!__webpack_require__(28)(function(){return Object.defineProperty({},\"a\",{get:function(){return 7}}).a!=7})},function(module,exports){var hasOwnProperty={}.hasOwnProperty;module.exports=function(it,key){return hasOwnProperty.call(it,key)}},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var NodeBase=function(){function NodeBase(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,NodeBase);this.body=body;this.labelModule=labelModule;this.setOptions(options);this.top=undefined;this.left=undefined;this.height=undefined;this.width=undefined;this.radius=undefined;this.margin=undefined;this.refreshNeeded=true;this.boundingBox={top:0,left:0,right:0,bottom:0}}(0,_createClass3[\"default\"])(NodeBase,[{key:\"setOptions\",value:function setOptions(options){this.options=options}},{key:\"_setMargins\",value:function _setMargins(labelModule){this.margin={};if(this.options.margin){if((0,_typeof3[\"default\"])(this.options.margin)==\"object\"){this.margin.top=this.options.margin.top;this.margin.right=this.options.margin.right;this.margin.bottom=this.options.margin.bottom;this.margin.left=this.options.margin.left}else{this.margin.top=this.options.margin;this.margin.right=this.options.margin;this.margin.bottom=this.options.margin;this.margin.left=this.options.margin}}labelModule.adjustSizes(this.margin)}},{key:\"_distanceToBorder\",value:function _distanceToBorder(ctx,angle){var borderWidth=this.options.borderWidth;this.resize(ctx);return Math.min(Math.abs(this.width/2/Math.cos(angle)),Math.abs(this.height/2/Math.sin(angle)))+borderWidth}},{key:\"enableShadow\",value:function enableShadow(ctx,values){if(values.shadow){ctx.shadowColor=values.shadowColor;ctx.shadowBlur=values.shadowSize;ctx.shadowOffsetX=values.shadowX;ctx.shadowOffsetY=values.shadowY}}},{key:\"disableShadow\",value:function disableShadow(ctx,values){if(values.shadow){ctx.shadowColor=\"rgba(0,0,0,0)\";ctx.shadowBlur=0;ctx.shadowOffsetX=0;ctx.shadowOffsetY=0}}},{key:\"enableBorderDashes\",value:function enableBorderDashes(ctx,values){if(values.borderDashes!==false){if(ctx.setLineDash!==undefined){var dashes=values.borderDashes;if(dashes===true){dashes=[5,15]}ctx.setLineDash(dashes)}else{console.warn(\"setLineDash is not supported in this browser. The dashed borders cannot be used.\");this.options.shapeProperties.borderDashes=false;values.borderDashes=false}}}},{key:\"disableBorderDashes\",value:function disableBorderDashes(ctx,values){if(values.borderDashes!==false){if(ctx.setLineDash!==undefined){ctx.setLineDash([0])}else{console.warn(\"setLineDash is not supported in this browser. The dashed borders cannot be used.\");this.options.shapeProperties.borderDashes=false;values.borderDashes=false}}}},{key:\"needsRefresh\",value:function needsRefresh(selected,hover){if(this.refreshNeeded===true){this.refreshNeeded=false;return true}return this.width===undefined||this.labelModule.differentState(selected,hover)}},{key:\"initContextForDraw\",value:function initContextForDraw(ctx,values){var borderWidth=values.borderWidth/this.body.view.scale;ctx.lineWidth=Math.min(this.width,borderWidth);ctx.strokeStyle=values.borderColor;ctx.fillStyle=values.color}},{key:\"performStroke\",value:function performStroke(ctx,values){var borderWidth=values.borderWidth/this.body.view.scale;ctx.save();if(borderWidth>0){this.enableBorderDashes(ctx,values);ctx.stroke();this.disableBorderDashes(ctx,values)}ctx.restore()}},{key:\"performFill\",value:function performFill(ctx,values){this.enableShadow(ctx,values);ctx.fill();this.disableShadow(ctx,values);this.performStroke(ctx,values)}},{key:\"_addBoundingBoxMargin\",value:function _addBoundingBoxMargin(margin){this.boundingBox.left-=margin;this.boundingBox.top-=margin;this.boundingBox.bottom+=margin;this.boundingBox.right+=margin}},{key:\"_updateBoundingBox\",value:function _updateBoundingBox(x,y,ctx,selected,hover){if(ctx!==undefined){this.resize(ctx,selected,hover)}this.left=x-this.width/2;this.top=y-this.height/2;this.boundingBox.left=this.left;this.boundingBox.top=this.top;this.boundingBox.bottom=this.top+this.height;this.boundingBox.right=this.left+this.width}},{key:\"updateBoundingBox\",value:function updateBoundingBox(x,y,ctx,selected,hover){this._updateBoundingBox(x,y,ctx,selected,hover)}},{key:\"getDimensionsFromLabel\",value:function getDimensionsFromLabel(ctx,selected,hover){this.textSize=this.labelModule.getTextSize(ctx,selected,hover);var width=this.textSize.width;var height=this.textSize.height;var DEFAULT_SIZE=14;if(width===0){width=DEFAULT_SIZE;height=DEFAULT_SIZE}return{width:width,height:height}}}]);return NodeBase}();exports[\"default\"]=NodeBase},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2)\n;var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _NodeBase2=__webpack_require__(23);var _NodeBase3=_interopRequireDefault(_NodeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var ShapeBase=function(_NodeBase){(0,_inherits3[\"default\"])(ShapeBase,_NodeBase);function ShapeBase(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,ShapeBase);return(0,_possibleConstructorReturn3[\"default\"])(this,(ShapeBase.__proto__||(0,_getPrototypeOf2[\"default\"])(ShapeBase)).call(this,options,body,labelModule))}(0,_createClass3[\"default\"])(ShapeBase,[{key:\"resize\",value:function resize(ctx){var selected=arguments.length>1&&arguments[1]!==undefined?arguments[1]:this.selected;var hover=arguments.length>2&&arguments[2]!==undefined?arguments[2]:this.hover;var values=arguments.length>3&&arguments[3]!==undefined?arguments[3]:{size:this.options.size};if(this.needsRefresh(selected,hover)){this.labelModule.getTextSize(ctx,selected,hover);var size=2*values.size;this.width=size;this.height=size;this.radius=.5*this.width}}},{key:\"_drawShape\",value:function _drawShape(ctx,shape,sizeMultiplier,x,y,selected,hover,values){this.resize(ctx,selected,hover,values);this.left=x-this.width/2;this.top=y-this.height/2;this.initContextForDraw(ctx,values);ctx[shape](x,y,values.size);this.performFill(ctx,values);if(this.options.label!==undefined){this.labelModule.calculateLabelSize(ctx,selected,hover,x,y,\"hanging\");var yLabel=y+.5*this.height+.5*this.labelModule.size.height;this.labelModule.draw(ctx,x,yLabel,selected,hover,\"hanging\")}this.updateBoundingBox(x,y)}},{key:\"updateBoundingBox\",value:function updateBoundingBox(x,y){this.boundingBox.top=y-this.options.size;this.boundingBox.left=x-this.options.size;this.boundingBox.right=x+this.options.size;this.boundingBox.bottom=y+this.options.size;if(this.options.label!==undefined&&this.labelModule.size.width>0){this.boundingBox.left=Math.min(this.boundingBox.left,this.labelModule.size.left);this.boundingBox.right=Math.max(this.boundingBox.right,this.labelModule.size.left+this.labelModule.size.width);this.boundingBox.bottom=Math.max(this.boundingBox.bottom,this.boundingBox.bottom+this.labelModule.size.height)}}}]);return ShapeBase}(_NodeBase3[\"default\"]);exports[\"default\"]=ShapeBase},function(module,exports,__webpack_require__){var IObject=__webpack_require__(78);var defined=__webpack_require__(51);module.exports=function(it){return IObject(defined(it))}},function(module,exports,__webpack_require__){var dP=__webpack_require__(20);var createDesc=__webpack_require__(39);module.exports=__webpack_require__(21)?function(object,key,value){return dP.f(object,key,createDesc(1,value))}:function(object,key,value){object[key]=value;return object}},function(module,exports,__webpack_require__){var isObject=__webpack_require__(32);module.exports=function(it){if(!isObject(it))throw TypeError(it+\" is not an object!\");return it}},function(module,exports){module.exports=function(exec){try{return!!exec()}catch(e){return true}}},function(module,exports,__webpack_require__){module.exports={default:__webpack_require__(138),__esModule:true}},function(module,exports,__webpack_require__){\"use strict\";exports.__esModule=true;var _isIterable2=__webpack_require__(188);var _isIterable3=_interopRequireDefault(_isIterable2);var _getIterator2=__webpack_require__(77);var _getIterator3=_interopRequireDefault(_getIterator2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}exports.default=function(){function sliceIterator(arr,i){var _arr=[];var _n=true;var _d=false;var _e=undefined;try{for(var _i=(0,_getIterator3.default)(arr),_s;!(_n=(_s=_i.next()).done);_n=true){_arr.push(_s.value);if(i&&_arr.length===i)break}}catch(err){_d=true;_e=err}finally{try{if(!_n&&_i[\"return\"])_i[\"return\"]()}finally{if(_d)throw _e}}return _arr}return function(arr,i){if(Array.isArray(arr)){return arr}else if((0,_isIterable3.default)(Object(arr))){return sliceIterator(arr,i)}else{throw new TypeError(\"Invalid attempt to destructure non-iterable instance\")}}}()},function(module,exports){module.exports={}},function(module,exports){module.exports=function(it){return typeof it===\"object\"?it!==null:typeof it===\"function\"}},function(module,exports,__webpack_require__){var $keys=__webpack_require__(84);var enumBugKeys=__webpack_require__(58);module.exports=Object.keys||function keys(O){return $keys(O,enumBugKeys)}},function(module,exports,__webpack_require__){\"use strict\";function Point3d(x,y,z){this.x=x!==undefined?x:0;this.y=y!==undefined?y:0;this.z=z!==undefined?z:0}Point3d.subtract=function(a,b){var sub=new Point3d;sub.x=a.x-b.x;sub.y=a.y-b.y;sub.z=a.z-b.z;return sub};Point3d.add=function(a,b){var sum=new Point3d;sum.x=a.x+b.x;sum.y=a.y+b.y;sum.z=a.z+b.z;return sum};Point3d.avg=function(a,b){return new Point3d((a.x+b.x)/2,(a.y+b.y)/2,(a.z+b.z)/2)};Point3d.crossProduct=function(a,b){var crossproduct=new Point3d;crossproduct.x=a.y*b.z-a.z*b.y;crossproduct.y=a.z*b.x-a.x*b.z;crossproduct.z=a.x*b.y-a.y*b.x;return crossproduct};Point3d.prototype.length=function(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)};module.exports=Point3d},function(module,exports,__webpack_require__){\"use strict\";var __WEBPACK_AMD_DEFINE_FACTORY__,__WEBPACK_AMD_DEFINE_ARRAY__,__WEBPACK_AMD_DEFINE_RESULT__;(function(root,factory){if(true){!(__WEBPACK_AMD_DEFINE_ARRAY__=[],__WEBPACK_AMD_DEFINE_FACTORY__=factory,__WEBPACK_AMD_DEFINE_RESULT__=typeof __WEBPACK_AMD_DEFINE_FACTORY__===\"function\"?__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports,__WEBPACK_AMD_DEFINE_ARRAY__):__WEBPACK_AMD_DEFINE_FACTORY__,__WEBPACK_AMD_DEFINE_RESULT__!==undefined&&(module.exports=__WEBPACK_AMD_DEFINE_RESULT__))}else if(typeof exports===\"object\"){module.exports=factory()}else{root.keycharm=factory()}})(this,function(){function keycharm(options){var preventDefault=options&&options.preventDefault||false;var container=options&&options.container||window;var _exportFunctions={};var _bound={keydown:{},keyup:{}};var _keys={};var i;for(i=97;i<=122;i++){_keys[String.fromCharCode(i)]={code:65+(i-97),shift:false}}for(i=65;i<=90;i++){_keys[String.fromCharCode(i)]={code:i,shift:true}}for(i=0;i<=9;i++){_keys[\"\"+i]={code:48+i,shift:false}}for(i=1;i<=12;i++){_keys[\"F\"+i]={code:111+i,shift:false}}for(i=0;i<=9;i++){_keys[\"num\"+i]={code:96+i,shift:false}}_keys[\"num*\"]={code:106,shift:false};_keys[\"num+\"]={code:107,shift:false};_keys[\"num-\"]={code:109,shift:false};_keys[\"num/\"]={code:111,shift:false};_keys[\"num.\"]={code:110,shift:false};_keys[\"left\"]={code:37,shift:false};_keys[\"up\"]={code:38,shift:false};_keys[\"right\"]={code:39,shift:false};_keys[\"down\"]={code:40,shift:false};_keys[\"space\"]={code:32,shift:false};_keys[\"enter\"]={code:13,shift:false};_keys[\"shift\"]={code:16,shift:undefined};_keys[\"esc\"]={code:27,shift:false};_keys[\"backspace\"]={code:8,shift:false};_keys[\"tab\"]={code:9,shift:false};_keys[\"ctrl\"]={code:17,shift:false};_keys[\"alt\"]={code:18,shift:false};_keys[\"delete\"]={code:46,shift:false};_keys[\"pageup\"]={code:33,shift:false};_keys[\"pagedown\"]={code:34,shift:false};_keys[\"=\"]={code:187,shift:false};_keys[\"-\"]={code:189,shift:false};_keys[\"]\"]={code:221,shift:false};_keys[\"[\"]={code:219,shift:false};var down=function(event){handleEvent(event,\"keydown\")};var up=function(event){handleEvent(event,\"keyup\")};var handleEvent=function(event,type){if(_bound[type][event.keyCode]!==undefined){var bound=_bound[type][event.keyCode];for(var i=0;i<bound.length;i++){if(bound[i].shift===undefined){bound[i].fn(event)}else if(bound[i].shift==true&&event.shiftKey==true){bound[i].fn(event)}else if(bound[i].shift==false&&event.shiftKey==false){bound[i].fn(event)}}if(preventDefault==true){event.preventDefault()}}};_exportFunctions.bind=function(key,callback,type){if(type===undefined){type=\"keydown\"}if(_keys[key]===undefined){throw new Error(\"unsupported key: \"+key)}if(_bound[type][_keys[key].code]===undefined){_bound[type][_keys[key].code]=[]}_bound[type][_keys[key].code].push({fn:callback,shift:_keys[key].shift})};_exportFunctions.bindAll=function(callback,type){if(type===undefined){type=\"keydown\"}for(var key in _keys){if(_keys.hasOwnProperty(key)){_exportFunctions.bind(key,callback,type)}}};_exportFunctions.getKey=function(event){for(var key in _keys){if(_keys.hasOwnProperty(key)){if(event.shiftKey==true&&_keys[key].shift==true&&event.keyCode==_keys[key].code){return key}else if(event.shiftKey==false&&_keys[key].shift==false&&event.keyCode==_keys[key].code){return key}else if(event.keyCode==_keys[key].code&&key==\"shift\"){return key}}}return\"unknown key, currently not supported\"};_exportFunctions.unbind=function(key,callback,type){if(type===undefined){type=\"keydown\"}if(_keys[key]===undefined){throw new Error(\"unsupported key: \"+key)}if(callback!==undefined){var newBindings=[];var bound=_bound[type][_keys[key].code];if(bound!==undefined){for(var i=0;i<bound.length;i++){if(!(bound[i].fn==callback&&bound[i].shift==_keys[key].shift)){newBindings.push(_bound[type][_keys[key].code][i])}}}_bound[type][_keys[key].code]=newBindings}else{_bound[type][_keys[key].code]=[]}};_exportFunctions.reset=function(){_bound={keydown:{},keyup:{}}};_exportFunctions.destroy=function(){_bound={keydown:{},keyup:{}};container.removeEventListener(\"keydown\",down,true);container.removeEventListener(\"keyup\",up,true)};container.addEventListener(\"keydown\",down,true);container.addEventListener(\"keyup\",up,true);return _exportFunctions}return keycharm})},function(module,exports,__webpack_require__){\"use strict\";exports.convertHiddenOptions=function(moment,body,hiddenDates){if(hiddenDates&&!Array.isArray(hiddenDates)){return exports.convertHiddenOptions(moment,body,[hiddenDates])}body.hiddenDates=[];if(hiddenDates){if(Array.isArray(hiddenDates)==true){for(var i=0;i<hiddenDates.length;i++){if(hiddenDates[i].repeat===undefined){var dateItem={};dateItem.start=moment(hiddenDates[i].start).toDate().valueOf();dateItem.end=moment(hiddenDates[i].end).toDate().valueOf();body.hiddenDates.push(dateItem)}}body.hiddenDates.sort(function(a,b){return a.start-b.start})}}};exports.updateHiddenDates=function(moment,body,hiddenDates){if(hiddenDates&&!Array.isArray(hiddenDates)){return exports.updateHiddenDates(moment,body,[hiddenDates])}if(hiddenDates&&body.domProps.centerContainer.width!==undefined){exports.convertHiddenOptions(moment,body,hiddenDates);var start=moment(body.range.start);var end=moment(body.range.end);var totalRange=body.range.end-body.range.start;var pixelTime=totalRange/body.domProps.centerContainer.width;for(var i=0;i<hiddenDates.length;i++){if(hiddenDates[i].repeat!==undefined){var startDate=moment(hiddenDates[i].start);var endDate=moment(hiddenDates[i].end);if(startDate._d==\"Invalid Date\"){throw new Error(\"Supplied start date is not valid: \"+hiddenDates[i].start)}if(endDate._d==\"Invalid Date\"){throw new Error(\"Supplied end date is not valid: \"+hiddenDates[i].end)}var duration=endDate-startDate;if(duration>=4*pixelTime){var offset=0;var runUntil=end.clone();switch(hiddenDates[i].repeat){case\"daily\":if(startDate.day()!=endDate.day()){offset=1}startDate.dayOfYear(start.dayOfYear());startDate.year(start.year());startDate.subtract(7,\"days\");endDate.dayOfYear(start.dayOfYear());endDate.year(start.year());endDate.subtract(7-offset,\"days\");runUntil.add(1,\"weeks\");break;case\"weekly\":var dayOffset=endDate.diff(startDate,\"days\");var day=startDate.day();startDate.date(start.date());startDate.month(start.month());startDate.year(start.year());endDate=startDate.clone();startDate.day(day);endDate.day(day);endDate.add(dayOffset,\"days\");startDate.subtract(1,\"weeks\");endDate.subtract(1,\"weeks\");runUntil.add(1,\"weeks\");break;case\"monthly\":if(startDate.month()!=endDate.month()){offset=1}startDate.month(start.month());startDate.year(start.year());startDate.subtract(1,\"months\");endDate.month(start.month());endDate.year(start.year());endDate.subtract(1,\"months\");endDate.add(offset,\"months\");runUntil.add(1,\"months\");break;case\"yearly\":if(startDate.year()!=endDate.year()){offset=1}startDate.year(start.year());startDate.subtract(1,\"years\");endDate.year(start.year());endDate.subtract(1,\"years\");endDate.add(offset,\"years\");runUntil.add(1,\"years\");break;default:console.log(\"Wrong repeat format, allowed are: daily, weekly, monthly, yearly. Given:\",hiddenDates[i].repeat);return}while(startDate<runUntil){body.hiddenDates.push({start:startDate.valueOf(),end:endDate.valueOf()});switch(hiddenDates[i].repeat){case\"daily\":startDate.add(1,\"days\");endDate.add(1,\"days\");break;case\"weekly\":startDate.add(1,\"weeks\");endDate.add(1,\"weeks\");break;case\"monthly\":startDate.add(1,\"months\");endDate.add(1,\"months\");break;case\"yearly\":startDate.add(1,\"y\");endDate.add(1,\"y\");break;default:console.log(\"Wrong repeat format, allowed are: daily, weekly, monthly, yearly. Given:\",hiddenDates[i].repeat);return}}body.hiddenDates.push({start:startDate.valueOf(),end:endDate.valueOf()})}}}exports.removeDuplicates(body);var startHidden=exports.isHidden(body.range.start,body.hiddenDates);var endHidden=exports.isHidden(body.range.end,body.hiddenDates);var rangeStart=body.range.start;var rangeEnd=body.range.end;if(startHidden.hidden==true){rangeStart=body.range.startToFront==true?startHidden.startDate-1:startHidden.endDate+1}if(endHidden.hidden==true){rangeEnd=body.range.endToFront==true?endHidden.startDate-1:endHidden.endDate+1}if(startHidden.hidden==true||endHidden.hidden==true){body.range._applyRange(rangeStart,rangeEnd)}}};exports.removeDuplicates=function(body){var hiddenDates=body.hiddenDates;var safeDates=[];for(var i=0;i<hiddenDates.length;i++){for(var j=0;j<hiddenDates.length;j++){if(i!=j&&hiddenDates[j].remove!=true&&hiddenDates[i].remove!=true){if(hiddenDates[j].start>=hiddenDates[i].start&&hiddenDates[j].end<=hiddenDates[i].end){hiddenDates[j].remove=true}else if(hiddenDates[j].start>=hiddenDates[i].start&&hiddenDates[j].start<=hiddenDates[i].end){hiddenDates[i].end=hiddenDates[j].end;hiddenDates[j].remove=true}else if(hiddenDates[j].end>=hiddenDates[i].start&&hiddenDates[j].end<=hiddenDates[i].end){hiddenDates[i].start=hiddenDates[j].start;hiddenDates[j].remove=true}}}}for(i=0;i<hiddenDates.length;i++){if(hiddenDates[i].remove!==true){safeDates.push(hiddenDates[i])}}body.hiddenDates=safeDates;body.hiddenDates.sort(function(a,b){return a.start-b.start})};exports.printDates=function(dates){for(var i=0;i<dates.length;i++){console.log(i,new Date(dates[i].start),new Date(dates[i].end),dates[i].start,dates[i].end,dates[i].remove)}};exports.stepOverHiddenDates=function(moment,timeStep,previousTime){var stepInHidden=false;var currentValue=timeStep.current.valueOf();for(var i=0;i<timeStep.hiddenDates.length;i++){var startDate=timeStep.hiddenDates[i].start;var endDate=timeStep.hiddenDates[i].end;if(currentValue>=startDate&¤tValue<endDate){stepInHidden=true;break}}if(stepInHidden==true&¤tValue<timeStep._end.valueOf()&¤tValue!=previousTime){var prevValue=moment(previousTime);var newValue=moment(endDate);if(prevValue.year()!=newValue.year()){timeStep.switchedYear=true}else if(prevValue.month()!=newValue.month()){timeStep.switchedMonth=true}else if(prevValue.dayOfYear()!=newValue.dayOfYear()){timeStep.switchedDay=true}timeStep.current=newValue}};exports.toScreen=function(Core,time,width){var conversion;if(Core.body.hiddenDates.length==0){conversion=Core.range.conversion(width);return(time.valueOf()-conversion.offset)*conversion.scale}else{var hidden=exports.isHidden(time,Core.body.hiddenDates);if(hidden.hidden==true){time=hidden.startDate}var duration=exports.getHiddenDurationBetween(Core.body.hiddenDates,Core.range.start,Core.range.end);if(time<Core.range.start){conversion=Core.range.conversion(width,duration);var hiddenBeforeStart=exports.getHiddenDurationBeforeStart(Core.body.hiddenDates,time,conversion.offset);time=Core.options.moment(time).toDate().valueOf();time=time+hiddenBeforeStart;return-(conversion.offset-time.valueOf())*conversion.scale}else if(time>Core.range.end){var rangeAfterEnd={start:Core.range.start,end:time};time=exports.correctTimeForHidden(Core.options.moment,Core.body.hiddenDates,rangeAfterEnd,time);conversion=Core.range.conversion(width,duration);return(time.valueOf()-conversion.offset)*conversion.scale}else{time=exports.correctTimeForHidden(Core.options.moment,Core.body.hiddenDates,Core.range,time);conversion=Core.range.conversion(width,duration);return(time.valueOf()-conversion.offset)*conversion.scale}}};exports.toTime=function(Core,x,width){if(Core.body.hiddenDates.length==0){var conversion=Core.range.conversion(width);return new Date(x/conversion.scale+conversion.offset)}else{var hiddenDuration=exports.getHiddenDurationBetween(Core.body.hiddenDates,Core.range.start,Core.range.end);var totalDuration=Core.range.end-Core.range.start-hiddenDuration;var partialDuration=totalDuration*x/width;var accumulatedHiddenDuration=exports.getAccumulatedHiddenDuration(Core.body.hiddenDates,Core.range,partialDuration);return new Date(accumulatedHiddenDuration+partialDuration+Core.range.start)}};exports.getHiddenDurationBetween=function(hiddenDates,start,end){var duration=0;for(var i=0;i<hiddenDates.length;i++){var startDate=hiddenDates[i].start;var endDate=hiddenDates[i].end;if(startDate>=start&&endDate<end){duration+=endDate-startDate}}return duration};exports.getHiddenDurationBeforeStart=function(hiddenDates,start,end){var duration=0;for(var i=0;i<hiddenDates.length;i++){var startDate=hiddenDates[i].start;var endDate=hiddenDates[i].end;if(startDate>=start&&endDate<=end){duration+=endDate-startDate}}return duration};exports.correctTimeForHidden=function(moment,hiddenDates,range,time){time=moment(time).toDate().valueOf();time-=exports.getHiddenDurationBefore(moment,hiddenDates,range,time);return time};exports.getHiddenDurationBefore=function(moment,hiddenDates,range,time){var timeOffset=0;time=moment(time).toDate().valueOf();for(var i=0;i<hiddenDates.length;i++){var startDate=hiddenDates[i].start;var endDate=hiddenDates[i].end;if(startDate>=range.start&&endDate<range.end){if(time>=endDate){timeOffset+=endDate-startDate}}}return timeOffset};exports.getAccumulatedHiddenDuration=function(hiddenDates,range,requiredDuration){var hiddenDuration=0;var duration=0;var previousPoint=range.start;for(var i=0;i<hiddenDates.length;i++){var startDate=hiddenDates[i].start;var endDate=hiddenDates[i].end;if(startDate>=range.start&&endDate<range.end){duration+=startDate-previousPoint;previousPoint=endDate;if(duration>=requiredDuration){break}else{hiddenDuration+=endDate-startDate}}}return hiddenDuration};exports.snapAwayFromHidden=function(hiddenDates,time,direction,correctionEnabled){var isHidden=exports.isHidden(time,hiddenDates);if(isHidden.hidden==true){if(direction<0){if(correctionEnabled==true){return isHidden.startDate-(isHidden.endDate-time)-1}else{return isHidden.startDate-1}}else{if(correctionEnabled==true){return isHidden.endDate+(time-isHidden.startDate)+1}else{return isHidden.endDate+1}}}else{return time}};exports.isHidden=function(time,hiddenDates){for(var i=0;i<hiddenDates.length;i++){var startDate=hiddenDates[i].start;var endDate=hiddenDates[i].end;if(time>=startDate&&time<endDate){return{hidden:true,startDate:startDate,endDate:endDate}}}return{hidden:false,startDate:startDate,endDate:endDate}}},function(module,exports,__webpack_require__){\"use strict\";exports.onTouch=function(hammer,callback){callback.inputHandler=function(event){if(event.isFirst){callback(event)}};hammer.on(\"hammer.input\",callback.inputHandler)};exports.onRelease=function(hammer,callback){callback.inputHandler=function(event){if(event.isFinal){callback(event)}};return hammer.on(\"hammer.input\",callback.inputHandler)};exports.offTouch=function(hammer,callback){hammer.off(\"hammer.input\",callback.inputHandler)};exports.offRelease=exports.offTouch;exports.disablePreventDefaultVertically=function(pinchRecognizer){var TOUCH_ACTION_PAN_Y=\"pan-y\";pinchRecognizer.getTouchAction=function(){return[TOUCH_ACTION_PAN_Y]};return pinchRecognizer}},function(module,exports,__webpack_require__){\"use strict\";var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);var _keys=__webpack_require__(8);var _keys2=_interopRequireDefault(_keys);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Hammer=__webpack_require__(10);var util=__webpack_require__(2);var moment=__webpack_require__(9);function Item(data,conversion,options){this.id=null;this.parent=null;this.data=data;this.dom=null;this.conversion=conversion||{};this.options=options||{};this.selected=false;this.displayed=false;this.groupShowing=true;this.dirty=true;this.top=null;this.right=null;this.left=null;this.width=null;this.height=null;this.editable=null;this._updateEditStatus()}Item.prototype.stack=true;Item.prototype.select=function(){this.selected=true;this.dirty=true;if(this.displayed)this.redraw()};Item.prototype.unselect=function(){this.selected=false;this.dirty=true;if(this.displayed)this.redraw()};Item.prototype.setData=function(data){var groupChanged=data.group!=undefined&&this.data.group!=data.group;if(groupChanged&&this.parent!=null){this.parent.itemSet._moveToGroup(this,data.group)}if(this.parent){this.parent.stackDirty=true}var subGroupChanged=data.subgroup!=undefined&&this.data.subgroup!=data.subgroup;if(subGroupChanged&&this.parent!=null){this.parent.changeSubgroup(this,this.data.subgroup,data.subgroup)}this.data=data;this._updateEditStatus();this.dirty=true;if(this.displayed)this.redraw()};Item.prototype.setParent=function(parent){if(this.displayed){this.hide();this.parent=parent;if(this.parent){this.show()}}else{this.parent=parent}};Item.prototype.isVisible=function(range){return false};Item.prototype.show=function(){return false};Item.prototype.hide=function(){return false};Item.prototype.redraw=function(){};Item.prototype.repositionX=function(){};Item.prototype.repositionY=function(){};Item.prototype._repaintDragCenter=function(){if(this.selected&&this.options.editable.updateTime&&!this.dom.dragCenter){var me=this;var dragCenter=document.createElement(\"div\");dragCenter.className=\"vis-drag-center\";dragCenter.dragCenterItem=this;var hammer=new Hammer(dragCenter);hammer.on(\"tap\",function(event){me.parent.itemSet.body.emitter.emit(\"click\",{event:event,item:me.id})});hammer.on(\"doubletap\",function(event){event.stopPropagation();me.parent.itemSet._onUpdateItem(me);me.parent.itemSet.body.emitter.emit(\"doubleClick\",{event:event,item:me.id})});if(this.dom.box){if(this.dom.dragLeft){this.dom.box.insertBefore(dragCenter,this.dom.dragLeft)}else{this.dom.box.appendChild(dragCenter)}}else if(this.dom.point){this.dom.point.appendChild(dragCenter)}this.dom.dragCenter=dragCenter}else if(!this.selected&&this.dom.dragCenter){if(this.dom.dragCenter.parentNode){this.dom.dragCenter.parentNode.removeChild(this.dom.dragCenter)}this.dom.dragCenter=null}};Item.prototype._repaintDeleteButton=function(anchor){var editable=(this.options.editable.overrideItems||this.editable==null)&&this.options.editable.remove||!this.options.editable.overrideItems&&this.editable!=null&&this.editable.remove;if(this.selected&&editable&&!this.dom.deleteButton){var me=this;var deleteButton=document.createElement(\"div\");if(this.options.rtl){deleteButton.className=\"vis-delete-rtl\"}else{deleteButton.className=\"vis-delete\"}deleteButton.title=\"Delete this item\";new Hammer(deleteButton).on(\"tap\",function(event){event.stopPropagation();me.parent.removeFromDataSet(me)});anchor.appendChild(deleteButton);this.dom.deleteButton=deleteButton}else if(!this.selected&&this.dom.deleteButton){if(this.dom.deleteButton.parentNode){this.dom.deleteButton.parentNode.removeChild(this.dom.deleteButton)}this.dom.deleteButton=null}};Item.prototype._repaintOnItemUpdateTimeTooltip=function(anchor){if(!this.options.tooltipOnItemUpdateTime)return;var editable=(this.options.editable.updateTime||this.data.editable===true)&&this.data.editable!==false;if(this.selected&&editable&&!this.dom.onItemUpdateTimeTooltip){var onItemUpdateTimeTooltip=document.createElement(\"div\");onItemUpdateTimeTooltip.className=\"vis-onUpdateTime-tooltip\";anchor.appendChild(onItemUpdateTimeTooltip);this.dom.onItemUpdateTimeTooltip=onItemUpdateTimeTooltip}else if(!this.selected&&this.dom.onItemUpdateTimeTooltip){if(this.dom.onItemUpdateTimeTooltip.parentNode){this.dom.onItemUpdateTimeTooltip.parentNode.removeChild(this.dom.onItemUpdateTimeTooltip)}this.dom.onItemUpdateTimeTooltip=null}if(this.dom.onItemUpdateTimeTooltip){this.dom.onItemUpdateTimeTooltip.style.visibility=this.parent.itemSet.touchParams.itemIsDragging?\"visible\":\"hidden\";if(this.options.rtl){this.dom.onItemUpdateTimeTooltip.style.right=this.dom.content.style.right}else{this.dom.onItemUpdateTimeTooltip.style.left=this.dom.content.style.left}var tooltipOffset=50;var scrollTop=this.parent.itemSet.body.domProps.scrollTop;var itemDistanceFromTop;if(this.options.orientation.item==\"top\"){itemDistanceFromTop=this.top}else{itemDistanceFromTop=this.parent.height-this.top-this.height}var isCloseToTop=itemDistanceFromTop+this.parent.top-tooltipOffset<-scrollTop;if(isCloseToTop){this.dom.onItemUpdateTimeTooltip.style.bottom=\"\";this.dom.onItemUpdateTimeTooltip.style.top=this.height+2+\"px\"}else{this.dom.onItemUpdateTimeTooltip.style.top=\"\";this.dom.onItemUpdateTimeTooltip.style.bottom=this.height+2+\"px\"}var content;var templateFunction;if(this.options.tooltipOnItemUpdateTime&&this.options.tooltipOnItemUpdateTime.template){templateFunction=this.options.tooltipOnItemUpdateTime.template.bind(this);content=templateFunction(this.data)}else{content=\"start: \"+moment(this.data.start).format(\"MM/DD/YYYY hh:mm\");if(this.data.end){content+=\"<br> end: \"+moment(this.data.end).format(\"MM/DD/YYYY hh:mm\")}}this.dom.onItemUpdateTimeTooltip.innerHTML=content}};Item.prototype._updateContents=function(element){var content;var changed;var templateFunction;var itemVisibleFrameContent;var visibleFrameTemplateFunction;var itemData=this.parent.itemSet.itemsData.get(this.id);var frameElement=this.dom.box||this.dom.point;var itemVisibleFrameContentElement=frameElement.getElementsByClassName(\"vis-item-visible-frame\")[0];if(this.options.visibleFrameTemplate){visibleFrameTemplateFunction=this.options.visibleFrameTemplate.bind(this);itemVisibleFrameContent=visibleFrameTemplateFunction(itemData,frameElement)}else{itemVisibleFrameContent=\"\"}if(itemVisibleFrameContentElement){if(itemVisibleFrameContent instanceof Object&&!(itemVisibleFrameContent instanceof Element)){visibleFrameTemplateFunction(itemData,itemVisibleFrameContentElement)}else{changed=this._contentToString(this.itemVisibleFrameContent)!==this._contentToString(itemVisibleFrameContent);if(changed){if(itemVisibleFrameContent instanceof Element){itemVisibleFrameContentElement.innerHTML=\"\";itemVisibleFrameContentElement.appendChild(itemVisibleFrameContent)}else if(itemVisibleFrameContent!=undefined){itemVisibleFrameContentElement.innerHTML=itemVisibleFrameContent}else{if(!(this.data.type==\"background\"&&this.data.content===undefined)){throw new Error('Property \"content\" missing in item '+this.id)}}this.itemVisibleFrameContent=itemVisibleFrameContent}}}if(this.options.template){templateFunction=this.options.template.bind(this);content=templateFunction(itemData,element,this.data)}else{content=this.data.content}if(content instanceof Object&&!(content instanceof Element)){templateFunction(itemData,element)}else{changed=this._contentToString(this.content)!==this._contentToString(content);if(changed){if(content instanceof Element){element.innerHTML=\"\";element.appendChild(content)}else if(content!=undefined){element.innerHTML=content}else{if(!(this.data.type==\"background\"&&this.data.content===undefined)){throw new Error('Property \"content\" missing in item '+this.id)}}this.content=content}}};Item.prototype._updateDataAttributes=function(element){if(this.options.dataAttributes&&this.options.dataAttributes.length>0){var attributes=[];if(Array.isArray(this.options.dataAttributes)){attributes=this.options.dataAttributes}else if(this.options.dataAttributes==\"all\"){attributes=(0,_keys2[\"default\"])(this.data)}else{return}for(var i=0;i<attributes.length;i++){var name=attributes[i];var value=this.data[name];if(value!=null){element.setAttribute(\"data-\"+name,value)}else{element.removeAttribute(\"data-\"+name)}}}};Item.prototype._updateStyle=function(element){if(this.style){util.removeCssText(element,this.style);this.style=null}if(this.data.style){util.addCssText(element,this.data.style);this.style=this.data.style}};Item.prototype._contentToString=function(content){if(typeof content===\"string\")return content;if(content&&\"outerHTML\"in content)return content.outerHTML;return content};Item.prototype._updateEditStatus=function(){if(this.options){if(typeof this.options.editable===\"boolean\"){this.editable={updateTime:this.options.editable,updateGroup:this.options.editable,remove:this.options.editable}}else if((0,_typeof3[\"default\"])(this.options.editable)===\"object\"){this.editable={};util.selectiveExtend([\"updateTime\",\"updateGroup\",\"remove\"],this.editable,this.options.editable)}}if(!this.options||!this.options.editable||this.options.editable.overrideItems!==true){if(this.data){if(typeof this.data.editable===\"boolean\"){this.editable={updateTime:this.data.editable,updateGroup:this.data.editable,remove:this.data.editable}}else if((0,_typeof3[\"default\"])(this.data.editable)===\"object\"){this.editable={};util.selectiveExtend([\"updateTime\",\"updateGroup\",\"remove\"],this.editable,this.data.editable)}}}};Item.prototype.getWidthLeft=function(){return 0};Item.prototype.getWidthRight=function(){return 0};Item.prototype.getTitle=function(){return this.data.title};module.exports=Item},function(module,exports){module.exports=function(bitmap,value){return{enumerable:!(bitmap&1),configurable:!(bitmap&2),writable:!(bitmap&4),value:value}}},function(module,exports){var id=0;var px=Math.random();module.exports=function(key){return\"Symbol(\".concat(key===undefined?\"\":key,\")_\",(++id+px).toString(36))}},function(module,exports,__webpack_require__){var defined=__webpack_require__(51);module.exports=function(it){return Object(defined(it))}},function(module,exports){exports.f={}.propertyIsEnumerable},function(module,exports,__webpack_require__){\"use strict\";function Queue(options){this.delay=null;this.max=Infinity;this._queue=[];this._timeout=null;this._extended=null;this.setOptions(options)}Queue.prototype.setOptions=function(options){if(options&&typeof options.delay!==\"undefined\"){this.delay=options.delay}if(options&&typeof options.max!==\"undefined\"){this.max=options.max}this._flushIfNeeded()};Queue.extend=function(object,options){var queue=new Queue(options);if(object.flush!==undefined){throw new Error(\"Target object already has a property flush\")}object.flush=function(){queue.flush()};var methods=[{name:\"flush\",original:undefined}];if(options&&options.replace){for(var i=0;i<options.replace.length;i++){var name=options.replace[i];methods.push({name:name,original:object[name]});queue.replace(object,name)}}queue._extended={object:object,methods:methods};return queue};Queue.prototype.destroy=function(){this.flush();if(this._extended){var object=this._extended.object;var methods=this._extended.methods;for(var i=0;i<methods.length;i++){var method=methods[i];if(method.original){object[method.name]=method.original}else{delete object[method.name]}}this._extended=null}};Queue.prototype.replace=function(object,method){var me=this;var original=object[method];if(!original){throw new Error(\"Method \"+method+\" undefined\")}object[method]=function(){var args=[];for(var i=0;i<arguments.length;i++){args[i]=arguments[i]}me.queue({args:args,fn:original,context:this})}};Queue.prototype.queue=function(entry){if(typeof entry===\"function\"){this._queue.push({fn:entry})}else{this._queue.push(entry)}this._flushIfNeeded()};Queue.prototype._flushIfNeeded=function(){\nif(this._queue.length>this.max){this.flush()}clearTimeout(this._timeout);if(this.queue.length>0&&typeof this.delay===\"number\"){var me=this;this._timeout=setTimeout(function(){me.flush()},this.delay)}};Queue.prototype.flush=function(){while(this._queue.length>0){var entry=this._queue.shift();entry.fn.apply(entry.context||entry.fn,entry.args||[])}};module.exports=Queue},function(module,exports){module.exports=Emitter;function Emitter(obj){if(obj)return mixin(obj)}function mixin(obj){for(var key in Emitter.prototype){obj[key]=Emitter.prototype[key]}return obj}Emitter.prototype.on=Emitter.prototype.addEventListener=function(event,fn){this._callbacks=this._callbacks||{};(this._callbacks[event]=this._callbacks[event]||[]).push(fn);return this};Emitter.prototype.once=function(event,fn){var self=this;this._callbacks=this._callbacks||{};function on(){self.off(event,on);fn.apply(this,arguments)}on.fn=fn;this.on(event,on);return this};Emitter.prototype.off=Emitter.prototype.removeListener=Emitter.prototype.removeAllListeners=Emitter.prototype.removeEventListener=function(event,fn){this._callbacks=this._callbacks||{};if(0==arguments.length){this._callbacks={};return this}var callbacks=this._callbacks[event];if(!callbacks)return this;if(1==arguments.length){delete this._callbacks[event];return this}var cb;for(var i=0;i<callbacks.length;i++){cb=callbacks[i];if(cb===fn||cb.fn===fn){callbacks.splice(i,1);break}}return this};Emitter.prototype.emit=function(event){this._callbacks=this._callbacks||{};var args=[].slice.call(arguments,1),callbacks=this._callbacks[event];if(callbacks){callbacks=callbacks.slice(0);for(var i=0,len=callbacks.length;i<len;++i){callbacks[i].apply(this,args)}}return this};Emitter.prototype.listeners=function(event){this._callbacks=this._callbacks||{};return this._callbacks[event]||[]};Emitter.prototype.hasListeners=function(event){return!!this.listeners(event).length}},function(module,exports,__webpack_require__){\"use strict\";var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var Component=__webpack_require__(16);var TimeStep=__webpack_require__(66);var DateUtil=__webpack_require__(36);var moment=__webpack_require__(9);function TimeAxis(body,options){this.dom={foreground:null,lines:[],majorTexts:[],minorTexts:[],redundant:{lines:[],majorTexts:[],minorTexts:[]}};this.props={range:{start:0,end:0,minimumStep:0},lineTop:0};this.defaultOptions={orientation:{axis:\"bottom\"},showMinorLabels:true,showMajorLabels:true,maxMinorChars:7,format:TimeStep.FORMAT,moment:moment,timeAxis:null};this.options=util.extend({},this.defaultOptions);this.body=body;this._create();this.setOptions(options)}TimeAxis.prototype=new Component;TimeAxis.prototype.setOptions=function(options){if(options){util.selectiveExtend([\"showMinorLabels\",\"showMajorLabels\",\"maxMinorChars\",\"hiddenDates\",\"timeAxis\",\"moment\",\"rtl\"],this.options,options);util.selectiveDeepExtend([\"format\"],this.options,options);if(\"orientation\"in options){if(typeof options.orientation===\"string\"){this.options.orientation.axis=options.orientation}else if((0,_typeof3[\"default\"])(options.orientation)===\"object\"&&\"axis\"in options.orientation){this.options.orientation.axis=options.orientation.axis}}if(\"locale\"in options){if(typeof moment.locale===\"function\"){moment.locale(options.locale)}else{moment.lang(options.locale)}}}};TimeAxis.prototype._create=function(){this.dom.foreground=document.createElement(\"div\");this.dom.background=document.createElement(\"div\");this.dom.foreground.className=\"vis-time-axis vis-foreground\";this.dom.background.className=\"vis-time-axis vis-background\"};TimeAxis.prototype.destroy=function(){if(this.dom.foreground.parentNode){this.dom.foreground.parentNode.removeChild(this.dom.foreground)}if(this.dom.background.parentNode){this.dom.background.parentNode.removeChild(this.dom.background)}this.body=null};TimeAxis.prototype.redraw=function(){var props=this.props;var foreground=this.dom.foreground;var background=this.dom.background;var parent=this.options.orientation.axis==\"top\"?this.body.dom.top:this.body.dom.bottom;var parentChanged=foreground.parentNode!==parent;this._calculateCharSize();var showMinorLabels=this.options.showMinorLabels&&this.options.orientation.axis!==\"none\";var showMajorLabels=this.options.showMajorLabels&&this.options.orientation.axis!==\"none\";props.minorLabelHeight=showMinorLabels?props.minorCharHeight:0;props.majorLabelHeight=showMajorLabels?props.majorCharHeight:0;props.height=props.minorLabelHeight+props.majorLabelHeight;props.width=foreground.offsetWidth;props.minorLineHeight=this.body.domProps.root.height-props.majorLabelHeight-(this.options.orientation.axis==\"top\"?this.body.domProps.bottom.height:this.body.domProps.top.height);props.minorLineWidth=1;props.majorLineHeight=props.minorLineHeight+props.majorLabelHeight;props.majorLineWidth=1;var foregroundNextSibling=foreground.nextSibling;var backgroundNextSibling=background.nextSibling;foreground.parentNode&&foreground.parentNode.removeChild(foreground);background.parentNode&&background.parentNode.removeChild(background);foreground.style.height=this.props.height+\"px\";this._repaintLabels();if(foregroundNextSibling){parent.insertBefore(foreground,foregroundNextSibling)}else{parent.appendChild(foreground)}if(backgroundNextSibling){this.body.dom.backgroundVertical.insertBefore(background,backgroundNextSibling)}else{this.body.dom.backgroundVertical.appendChild(background)}return this._isResized()||parentChanged};TimeAxis.prototype._repaintLabels=function(){var orientation=this.options.orientation.axis;var start=util.convert(this.body.range.start,\"Number\");var end=util.convert(this.body.range.end,\"Number\");var timeLabelsize=this.body.util.toTime((this.props.minorCharWidth||10)*this.options.maxMinorChars).valueOf();var minimumStep=timeLabelsize-DateUtil.getHiddenDurationBefore(this.options.moment,this.body.hiddenDates,this.body.range,timeLabelsize);minimumStep-=this.body.util.toTime(0).valueOf();var step=new TimeStep(new Date(start),new Date(end),minimumStep,this.body.hiddenDates,this.options);step.setMoment(this.options.moment);if(this.options.format){step.setFormat(this.options.format)}if(this.options.timeAxis){step.setScale(this.options.timeAxis)}this.step=step;var dom=this.dom;dom.redundant.lines=dom.lines;dom.redundant.majorTexts=dom.majorTexts;dom.redundant.minorTexts=dom.minorTexts;dom.lines=[];dom.majorTexts=[];dom.minorTexts=[];var current;var next;var x;var xNext;var isMajor;var nextIsMajor;var showMinorGrid;var width=0,prevWidth;var line;var labelMinor;var xFirstMajorLabel=undefined;var count=0;var MAX=1e3;var className;step.start();next=step.getCurrent();xNext=this.body.util.toScreen(next);while(step.hasNext()&&count<MAX){count++;isMajor=step.isMajor();className=step.getClassName();labelMinor=step.getLabelMinor();current=next;x=xNext;step.next();next=step.getCurrent();nextIsMajor=step.isMajor();xNext=this.body.util.toScreen(next);prevWidth=width;width=xNext-x;switch(step.scale){case\"week\":showMinorGrid=true;break;default:showMinorGrid=width>=prevWidth*.4;break}if(this.options.showMinorLabels&&showMinorGrid){var label=this._repaintMinorText(x,labelMinor,orientation,className);label.style.width=width+\"px\"}if(isMajor&&this.options.showMajorLabels){if(x>0){if(xFirstMajorLabel==undefined){xFirstMajorLabel=x}label=this._repaintMajorText(x,step.getLabelMajor(),orientation,className)}line=this._repaintMajorLine(x,width,orientation,className)}else{if(showMinorGrid){line=this._repaintMinorLine(x,width,orientation,className)}else{if(line){line.style.width=parseInt(line.style.width)+width+\"px\"}}}}if(count===MAX&&!warnedForOverflow){console.warn(\"Something is wrong with the Timeline scale. Limited drawing of grid lines to \"+MAX+\" lines.\");warnedForOverflow=true}if(this.options.showMajorLabels){var leftTime=this.body.util.toTime(0),leftText=step.getLabelMajor(leftTime),widthText=leftText.length*(this.props.majorCharWidth||10)+10;if(xFirstMajorLabel==undefined||widthText<xFirstMajorLabel){this._repaintMajorText(0,leftText,orientation,className)}}util.forEach(this.dom.redundant,function(arr){while(arr.length){var elem=arr.pop();if(elem&&elem.parentNode){elem.parentNode.removeChild(elem)}}})};TimeAxis.prototype._repaintMinorText=function(x,text,orientation,className){var label=this.dom.redundant.minorTexts.shift();if(!label){var content=document.createTextNode(\"\");label=document.createElement(\"div\");label.appendChild(content);this.dom.foreground.appendChild(label)}this.dom.minorTexts.push(label);label.innerHTML=text;label.style.top=orientation==\"top\"?this.props.majorLabelHeight+\"px\":\"0\";if(this.options.rtl){label.style.left=\"\";label.style.right=x+\"px\"}else{label.style.left=x+\"px\"}label.className=\"vis-text vis-minor \"+className;return label};TimeAxis.prototype._repaintMajorText=function(x,text,orientation,className){var label=this.dom.redundant.majorTexts.shift();if(!label){var content=document.createElement(\"div\");label=document.createElement(\"div\");label.appendChild(content);this.dom.foreground.appendChild(label)}label.childNodes[0].innerHTML=text;label.className=\"vis-text vis-major \"+className;label.style.top=orientation==\"top\"?\"0\":this.props.minorLabelHeight+\"px\";if(this.options.rtl){label.style.left=\"\";label.style.right=x+\"px\"}else{label.style.left=x+\"px\"}this.dom.majorTexts.push(label);return label};TimeAxis.prototype._repaintMinorLine=function(x,width,orientation,className){var line=this.dom.redundant.lines.shift();if(!line){line=document.createElement(\"div\");this.dom.background.appendChild(line)}this.dom.lines.push(line);var props=this.props;if(orientation==\"top\"){line.style.top=props.majorLabelHeight+\"px\"}else{line.style.top=this.body.domProps.top.height+\"px\"}line.style.height=props.minorLineHeight+\"px\";if(this.options.rtl){line.style.left=\"\";line.style.right=x-props.minorLineWidth/2+\"px\";line.className=\"vis-grid vis-vertical-rtl vis-minor \"+className}else{line.style.left=x-props.minorLineWidth/2+\"px\";line.className=\"vis-grid vis-vertical vis-minor \"+className}line.style.width=width+\"px\";return line};TimeAxis.prototype._repaintMajorLine=function(x,width,orientation,className){var line=this.dom.redundant.lines.shift();if(!line){line=document.createElement(\"div\");this.dom.background.appendChild(line)}this.dom.lines.push(line);var props=this.props;if(orientation==\"top\"){line.style.top=\"0\"}else{line.style.top=this.body.domProps.top.height+\"px\"}if(this.options.rtl){line.style.left=\"\";line.style.right=x-props.majorLineWidth/2+\"px\";line.className=\"vis-grid vis-vertical-rtl vis-major \"+className}else{line.style.left=x-props.majorLineWidth/2+\"px\";line.className=\"vis-grid vis-vertical vis-major \"+className}line.style.height=props.majorLineHeight+\"px\";line.style.width=width+\"px\";return line};TimeAxis.prototype._calculateCharSize=function(){if(!this.dom.measureCharMinor){this.dom.measureCharMinor=document.createElement(\"DIV\");this.dom.measureCharMinor.className=\"vis-text vis-minor vis-measure\";this.dom.measureCharMinor.style.position=\"absolute\";this.dom.measureCharMinor.appendChild(document.createTextNode(\"0\"));this.dom.foreground.appendChild(this.dom.measureCharMinor)}this.props.minorCharHeight=this.dom.measureCharMinor.clientHeight;this.props.minorCharWidth=this.dom.measureCharMinor.clientWidth;if(!this.dom.measureCharMajor){this.dom.measureCharMajor=document.createElement(\"DIV\");this.dom.measureCharMajor.className=\"vis-text vis-major vis-measure\";this.dom.measureCharMajor.style.position=\"absolute\";this.dom.measureCharMajor.appendChild(document.createTextNode(\"0\"));this.dom.foreground.appendChild(this.dom.measureCharMajor)}this.props.majorCharHeight=this.dom.measureCharMajor.clientHeight;this.props.majorCharWidth=this.dom.measureCharMajor.clientWidth};var warnedForOverflow=false;module.exports=TimeAxis},function(module,exports,__webpack_require__){\"use strict\";var Hammer=__webpack_require__(10);var util=__webpack_require__(2);var Component=__webpack_require__(16);var moment=__webpack_require__(9);var locales=__webpack_require__(98);function CustomTime(body,options){this.body=body;this.defaultOptions={moment:moment,locales:locales,locale:\"en\",id:undefined,title:undefined};this.options=util.extend({},this.defaultOptions);if(options&&options.time){this.customTime=options.time}else{this.customTime=new Date}this.eventParams={};this.setOptions(options);this._create()}CustomTime.prototype=new Component;CustomTime.prototype.setOptions=function(options){if(options){util.selectiveExtend([\"moment\",\"locale\",\"locales\",\"id\"],this.options,options)}};CustomTime.prototype._create=function(){var bar=document.createElement(\"div\");bar[\"custom-time\"]=this;bar.className=\"vis-custom-time \"+(this.options.id||\"\");bar.style.position=\"absolute\";bar.style.top=\"0px\";bar.style.height=\"100%\";this.bar=bar;var drag=document.createElement(\"div\");drag.style.position=\"relative\";drag.style.top=\"0px\";drag.style.left=\"-10px\";drag.style.height=\"100%\";drag.style.width=\"20px\";function onMouseWheel(e){this.body.range._onMouseWheel(e)}if(drag.addEventListener){drag.addEventListener(\"mousewheel\",onMouseWheel.bind(this),false);drag.addEventListener(\"DOMMouseScroll\",onMouseWheel.bind(this),false)}else{drag.attachEvent(\"onmousewheel\",onMouseWheel.bind(this))}bar.appendChild(drag);this.hammer=new Hammer(drag);this.hammer.on(\"panstart\",this._onDragStart.bind(this));this.hammer.on(\"panmove\",this._onDrag.bind(this));this.hammer.on(\"panend\",this._onDragEnd.bind(this));this.hammer.get(\"pan\").set({threshold:5,direction:Hammer.DIRECTION_HORIZONTAL})};CustomTime.prototype.destroy=function(){this.hide();this.hammer.destroy();this.hammer=null;this.body=null};CustomTime.prototype.redraw=function(){var parent=this.body.dom.backgroundVertical;if(this.bar.parentNode!=parent){if(this.bar.parentNode){this.bar.parentNode.removeChild(this.bar)}parent.appendChild(this.bar)}var x=this.body.util.toScreen(this.customTime);var locale=this.options.locales[this.options.locale];if(!locale){if(!this.warned){console.log(\"WARNING: options.locales['\"+this.options.locale+\"'] not found. See http://visjs.org/docs/timeline/#Localization\");this.warned=true}locale=this.options.locales[\"en\"]}var title=this.options.title;if(title===undefined){title=locale.time+\": \"+this.options.moment(this.customTime).format(\"dddd, MMMM Do YYYY, H:mm:ss\");title=title.charAt(0).toUpperCase()+title.substring(1)}else if(typeof title===\"function\"){title=title.call(this.customTime)}this.bar.style.left=x+\"px\";this.bar.title=title;return false};CustomTime.prototype.hide=function(){if(this.bar.parentNode){this.bar.parentNode.removeChild(this.bar)}};CustomTime.prototype.setCustomTime=function(time){this.customTime=util.convert(time,\"Date\");this.redraw()};CustomTime.prototype.getCustomTime=function(){return new Date(this.customTime.valueOf())};CustomTime.prototype.setCustomTitle=function(title){this.options.title=title};CustomTime.prototype._onDragStart=function(event){this.eventParams.dragging=true;this.eventParams.customTime=this.customTime;event.stopPropagation()};CustomTime.prototype._onDrag=function(event){if(!this.eventParams.dragging)return;var x=this.body.util.toScreen(this.eventParams.customTime)+event.deltaX;var time=this.body.util.toTime(x);this.setCustomTime(time);this.body.emitter.emit(\"timechange\",{id:this.options.id,time:new Date(this.customTime.valueOf()),event:event});event.stopPropagation()};CustomTime.prototype._onDragEnd=function(event){if(!this.eventParams.dragging)return;this.body.emitter.emit(\"timechanged\",{id:this.options.id,time:new Date(this.customTime.valueOf()),event:event});event.stopPropagation()};CustomTime.customTimeFromTarget=function(event){var target=event.target;while(target){if(target.hasOwnProperty(\"custom-time\")){return target[\"custom-time\"]}target=target.parentNode}return null};module.exports=CustomTime},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var Label=__webpack_require__(117)[\"default\"];var ComponentUtil=__webpack_require__(48)[\"default\"];var Box=__webpack_require__(193)[\"default\"];var Circle=__webpack_require__(200)[\"default\"];var CircularImage=__webpack_require__(201)[\"default\"];var Database=__webpack_require__(202)[\"default\"];var Diamond=__webpack_require__(203)[\"default\"];var Dot=__webpack_require__(204)[\"default\"];var Ellipse=__webpack_require__(205)[\"default\"];var Icon=__webpack_require__(206)[\"default\"];var Image=__webpack_require__(207)[\"default\"];var Square=__webpack_require__(208)[\"default\"];var Hexagon=__webpack_require__(209)[\"default\"];var Star=__webpack_require__(210)[\"default\"];var Text=__webpack_require__(211)[\"default\"];var Triangle=__webpack_require__(212)[\"default\"];var TriangleDown=__webpack_require__(213)[\"default\"];var _require=__webpack_require__(15),printStyle=_require.printStyle;var Node=function(){function Node(options,body,imagelist,grouplist,globalOptions,defaultOptions){(0,_classCallCheck3[\"default\"])(this,Node);this.options=util.bridgeObject(globalOptions);this.globalOptions=globalOptions;this.defaultOptions=defaultOptions;this.body=body;this.edges=[];this.id=undefined;this.imagelist=imagelist;this.grouplist=grouplist;this.x=undefined;this.y=undefined;this.baseSize=this.options.size;this.baseFontSize=this.options.font.size;this.predefinedPosition=false;this.selected=false;this.hover=false;this.labelModule=new Label(this.body,this.options,false);this.setOptions(options)}(0,_createClass3[\"default\"])(Node,[{key:\"attachEdge\",value:function attachEdge(edge){if(this.edges.indexOf(edge)===-1){this.edges.push(edge)}}},{key:\"detachEdge\",value:function detachEdge(edge){var index=this.edges.indexOf(edge);if(index!=-1){this.edges.splice(index,1)}}},{key:\"setOptions\",value:function setOptions(options){var currentShape=this.options.shape;if(!options){return}if(options.id!==undefined){this.id=options.id}if(this.id===undefined){throw new Error(\"Node must have an id\")}Node.checkMass(options,this.id);if(options.x!==undefined){if(options.x===null){this.x=undefined;this.predefinedPosition=false}else{this.x=parseInt(options.x);this.predefinedPosition=true}}if(options.y!==undefined){if(options.y===null){this.y=undefined;this.predefinedPosition=false}else{this.y=parseInt(options.y);this.predefinedPosition=true}}if(options.size!==undefined){this.baseSize=options.size}if(options.value!==undefined){options.value=parseFloat(options.value)}Node.parseOptions(this.options,options,true,this.globalOptions,this.grouplist);var pile=[options,this.options,this.defaultOptions];this.chooser=ComponentUtil.choosify(\"node\",pile);this._load_images();this.updateLabelModule(options);this.updateShape(currentShape);return options.hidden!==undefined||options.physics!==undefined}},{key:\"_load_images\",value:function _load_images(){if(this.options.shape!==\"circularImage\"&&this.options.shape!==\"image\"){return}if(this.options.image===undefined){throw new Error(\"Option image must be defined for node type '\"+this.options.shape+\"'\")}if(this.imagelist===undefined){throw new Error(\"Internal Error: No images provided\")}if(typeof this.options.image===\"string\"){this.imageObj=this.imagelist.load(this.options.image,this.options.brokenImage,this.id)}else{if(this.options.image.unselected===undefined){throw new Error(\"No unselected image provided\")}this.imageObj=this.imagelist.load(this.options.image.unselected,this.options.brokenImage,this.id);if(this.options.image.selected!==undefined){this.imageObjAlt=this.imagelist.load(this.options.image.selected,this.options.brokenImage,this.id)}else{this.imageObjAlt=undefined}}}},{key:\"getFormattingValues\",value:function getFormattingValues(){var values={color:this.options.color.background,borderWidth:this.options.borderWidth,borderColor:this.options.color.border,size:this.options.size,borderDashes:this.options.shapeProperties.borderDashes,borderRadius:this.options.shapeProperties.borderRadius,shadow:this.options.shadow.enabled,shadowColor:this.options.shadow.color,shadowSize:this.options.shadow.size,shadowX:this.options.shadow.x,shadowY:this.options.shadow.y};if(this.selected||this.hover){if(this.chooser===true){if(this.selected){values.borderWidth*=2;values.color=this.options.color.highlight.background;values.borderColor=this.options.color.highlight.border;values.shadow=this.options.shadow.enabled}else if(this.hover){values.color=this.options.color.hover.background;values.borderColor=this.options.color.hover.border;values.shadow=this.options.shadow.enabled}}else if(typeof this.chooser===\"function\"){this.chooser(values,this.options.id,this.selected,this.hover);if(values.shadow===false){if(values.shadowColor!==this.options.shadow.color||values.shadowSize!==this.options.shadow.size||values.shadowX!==this.options.shadow.x||values.shadowY!==this.options.shadow.y){values.shadow=true}}}}else{values.shadow=this.options.shadow.enabled}return values}},{key:\"updateLabelModule\",value:function updateLabelModule(options){if(this.options.label===undefined||this.options.label===null){this.options.label=\"\"}Node.updateGroupOptions(this.options,options,this.grouplist);var currentGroup=this.grouplist.get(this.options.group,false);var pile=[options,this.options,currentGroup,this.globalOptions,this.defaultOptions];this.labelModule.update(this.options,pile);if(this.labelModule.baseSize!==undefined){this.baseFontSize=this.labelModule.baseSize}}},{key:\"updateShape\",value:function updateShape(currentShape){if(currentShape===this.options.shape&&this.shape){this.shape.setOptions(this.options,this.imageObj,this.imageObjAlt)}else{switch(this.options.shape){case\"box\":this.shape=new Box(this.options,this.body,this.labelModule);break;case\"circle\":this.shape=new Circle(this.options,this.body,this.labelModule);break;case\"circularImage\":this.shape=new CircularImage(this.options,this.body,this.labelModule,this.imageObj,this.imageObjAlt);break;case\"database\":this.shape=new Database(this.options,this.body,this.labelModule);break;case\"diamond\":this.shape=new Diamond(this.options,this.body,this.labelModule);break;case\"dot\":this.shape=new Dot(this.options,this.body,this.labelModule);break;case\"ellipse\":this.shape=new Ellipse(this.options,this.body,this.labelModule);break;case\"icon\":this.shape=new Icon(this.options,this.body,this.labelModule);break;case\"image\":this.shape=new Image(this.options,this.body,this.labelModule,this.imageObj,this.imageObjAlt);break;case\"square\":this.shape=new Square(this.options,this.body,this.labelModule);break;case\"hexagon\":this.shape=new Hexagon(this.options,this.body,this.labelModule);break;case\"star\":this.shape=new Star(this.options,this.body,this.labelModule);break;case\"text\":this.shape=new Text(this.options,this.body,this.labelModule);break;case\"triangle\":this.shape=new Triangle(this.options,this.body,this.labelModule);break;case\"triangleDown\":this.shape=new TriangleDown(this.options,this.body,this.labelModule);break;default:this.shape=new Ellipse(this.options,this.body,this.labelModule);break}}this.needsRefresh()}},{key:\"select\",value:function select(){this.selected=true;this.needsRefresh()}},{key:\"unselect\",value:function unselect(){this.selected=false;this.needsRefresh()}},{key:\"needsRefresh\",value:function needsRefresh(){this.shape.refreshNeeded=true}},{key:\"getTitle\",value:function getTitle(){return this.options.title}},{key:\"distanceToBorder\",value:function distanceToBorder(ctx,angle){return this.shape.distanceToBorder(ctx,angle)}},{key:\"isFixed\",value:function isFixed(){return this.options.fixed.x&&this.options.fixed.y}},{key:\"isSelected\",value:function isSelected(){return this.selected}},{key:\"getValue\",value:function getValue(){return this.options.value}},{key:\"getLabelSize\",value:function getLabelSize(){return this.labelModule.size()}},{key:\"setValueRange\",value:function setValueRange(min,max,total){if(this.options.value!==undefined){var scale=this.options.scaling.customScalingFunction(min,max,total,this.options.value);var sizeDiff=this.options.scaling.max-this.options.scaling.min;if(this.options.scaling.label.enabled===true){var fontDiff=this.options.scaling.label.max-this.options.scaling.label.min;this.options.font.size=this.options.scaling.label.min+scale*fontDiff}this.options.size=this.options.scaling.min+scale*sizeDiff}else{this.options.size=this.baseSize;this.options.font.size=this.baseFontSize}this.updateLabelModule()}},{key:\"draw\",value:function draw(ctx){var values=this.getFormattingValues();this.shape.draw(ctx,this.x,this.y,this.selected,this.hover,values)}},{key:\"updateBoundingBox\",value:function updateBoundingBox(ctx){this.shape.updateBoundingBox(this.x,this.y,ctx)}},{key:\"resize\",value:function resize(ctx){var values=this.getFormattingValues();this.shape.resize(ctx,this.selected,this.hover,values)}},{key:\"getItemsOnPoint\",value:function getItemsOnPoint(point){var ret=[];if(this.labelModule.visible()){if(ComponentUtil.pointInRect(this.labelModule.getSize(),point)){ret.push({nodeId:this.id,labelId:0})}}if(ComponentUtil.pointInRect(this.shape.boundingBox,point)){ret.push({nodeId:this.id})}return ret}},{key:\"isOverlappingWith\",value:function isOverlappingWith(obj){return this.shape.left<obj.right&&this.shape.left+this.shape.width>obj.left&&this.shape.top<obj.bottom&&this.shape.top+this.shape.height>obj.top}},{key:\"isBoundingBoxOverlappingWith\",value:function isBoundingBoxOverlappingWith(obj){return this.shape.boundingBox.left<obj.right&&this.shape.boundingBox.right>obj.left&&this.shape.boundingBox.top<obj.bottom&&this.shape.boundingBox.bottom>obj.top}}],[{key:\"updateGroupOptions\",value:function updateGroupOptions(parentOptions,newOptions,groupList){if(groupList===undefined)return;var group=parentOptions.group;if(newOptions!==undefined&&newOptions.group!==undefined&&group!==newOptions.group){throw new Error(\"updateGroupOptions: group values in options don't match.\")}var hasGroup=typeof group===\"number\"||typeof group===\"string\"&&group!=\"\";if(!hasGroup)return;var groupObj=groupList.get(group);util.selectiveNotDeepExtend([\"font\"],parentOptions,groupObj);parentOptions.color=util.parseColor(parentOptions.color)}},{key:\"parseOptions\",value:function parseOptions(parentOptions,newOptions){var allowDeletion=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;var globalOptions=arguments.length>3&&arguments[3]!==undefined?arguments[3]:{};var groupList=arguments[4];var fields=[\"color\",\"fixed\",\"shadow\"];util.selectiveNotDeepExtend(fields,parentOptions,newOptions,allowDeletion);Node.checkMass(newOptions);util.mergeOptions(parentOptions,newOptions,\"shadow\",globalOptions);if(newOptions.color!==undefined&&newOptions.color!==null){var parsedColor=util.parseColor(newOptions.color);util.fillIfDefined(parentOptions.color,parsedColor)}else if(allowDeletion===true&&newOptions.color===null){parentOptions.color=util.bridgeObject(globalOptions.color)}if(newOptions.fixed!==undefined&&newOptions.fixed!==null){if(typeof newOptions.fixed===\"boolean\"){parentOptions.fixed.x=newOptions.fixed;parentOptions.fixed.y=newOptions.fixed}else{if(newOptions.fixed.x!==undefined&&typeof newOptions.fixed.x===\"boolean\"){parentOptions.fixed.x=newOptions.fixed.x}if(newOptions.fixed.y!==undefined&&typeof newOptions.fixed.y===\"boolean\"){parentOptions.fixed.y=newOptions.fixed.y}}}if(allowDeletion===true&&newOptions.font===null){parentOptions.font=util.bridgeObject(globalOptions.font)}Node.updateGroupOptions(parentOptions,newOptions,groupList);if(newOptions.scaling!==undefined){util.mergeOptions(parentOptions.scaling,newOptions.scaling,\"label\",globalOptions.scaling)}}},{key:\"checkMass\",value:function checkMass(options,id){if(options.mass!==undefined&&options.mass<=0){var strId=\"\";if(id!==undefined){strId=\" in node id: \"+id}console.log(\"%cNegative or zero mass disallowed\"+strId+\", setting mass to 1.\",printStyle);options.mass=1}}}]);return Node}();exports[\"default\"]=Node},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var ComponentUtil=function(){function ComponentUtil(){(0,_classCallCheck3[\"default\"])(this,ComponentUtil)}(0,_createClass3[\"default\"])(ComponentUtil,null,[{key:\"choosify\",value:function choosify(subOption,pile){var allowed=[\"node\",\"edge\",\"label\"];var value=true;var chosen=util.topMost(pile,\"chosen\");if(typeof chosen===\"boolean\"){value=chosen}else if((typeof chosen===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(chosen))===\"object\"){if(allowed.indexOf(subOption)===-1){throw new Error(\"choosify: subOption '\"+subOption+\"' should be one of \"+\"'\"+allowed.join(\"', '\")+\"'\")}var chosenEdge=util.topMost(pile,[\"chosen\",subOption]);if(typeof chosenEdge===\"boolean\"||typeof chosenEdge===\"function\"){value=chosenEdge}}return value}},{key:\"pointInRect\",value:function pointInRect(rect,point,rotationPoint){if(rect.width<=0||rect.height<=0){return false}if(rotationPoint!==undefined){var tmp={x:point.x-rotationPoint.x,y:point.y-rotationPoint.y};if(rotationPoint.angle!==0){var angle=-rotationPoint.angle;var tmp2={x:Math.cos(angle)*tmp.x-Math.sin(angle)*tmp.y,y:Math.sin(angle)*tmp.x+Math.cos(angle)*tmp.y};point=tmp2}else{point=tmp}}var right=rect.x+rect.width;var bottom=rect.y+rect.width;return rect.left<point.x&&right>point.x&&rect.top<point.y&&bottom>point.y}},{key:\"isValidLabel\",value:function isValidLabel(text){return typeof text===\"string\"&&text!==\"\"}}]);return ComponentUtil}();exports[\"default\"]=ComponentUtil},function(module,exports,__webpack_require__){__webpack_require__(125);var global=__webpack_require__(18);var hide=__webpack_require__(26);var Iterators=__webpack_require__(31);var TO_STRING_TAG=__webpack_require__(13)(\"toStringTag\");var DOMIterables=(\"CSSRuleList,CSSStyleDeclaration,CSSValueList,ClientRectList,DOMRectList,DOMStringList,\"+\"DOMTokenList,DataTransferItemList,FileList,HTMLAllCollection,HTMLCollection,HTMLFormElement,HTMLSelectElement,\"+\"MediaList,MimeTypeArray,NamedNodeMap,NodeList,PaintRequestList,Plugin,PluginArray,SVGLengthList,SVGNumberList,\"+\"SVGPathSegList,SVGPointList,SVGStringList,SVGTransformList,SourceBufferList,StyleSheetList,TextTrackCueList,\"+\"TextTrackList,TouchList\").split(\",\");for(var i=0;i<DOMIterables.length;i++){var NAME=DOMIterables[i];var Collection=global[NAME];var proto=Collection&&Collection.prototype;if(proto&&!proto[TO_STRING_TAG])hide(proto,TO_STRING_TAG,NAME);Iterators[NAME]=Iterators.Array}},function(module,exports){var toString={}.toString;module.exports=function(it){return toString.call(it).slice(8,-1)}},function(module,exports){module.exports=function(it){if(it==undefined)throw TypeError(\"Can't call method on \"+it);return it}},function(module,exports){module.exports=true},function(module,exports,__webpack_require__){var isObject=__webpack_require__(32);module.exports=function(it,S){if(!isObject(it))return it;var fn,val;if(S&&typeof(fn=it.toString)==\"function\"&&!isObject(val=fn.call(it)))return val;if(typeof(fn=it.valueOf)==\"function\"&&!isObject(val=fn.call(it)))return val;if(!S&&typeof(fn=it.toString)==\"function\"&&!isObject(val=fn.call(it)))return val;throw TypeError(\"Can't convert object to primitive value\")}},function(module,exports,__webpack_require__){var anObject=__webpack_require__(27);var dPs=__webpack_require__(130);var enumBugKeys=__webpack_require__(58);var IE_PROTO=__webpack_require__(56)(\"IE_PROTO\")\n;var Empty=function(){};var PROTOTYPE=\"prototype\";var createDict=function(){var iframe=__webpack_require__(82)(\"iframe\");var i=enumBugKeys.length;var lt=\"<\";var gt=\">\";var iframeDocument;iframe.style.display=\"none\";__webpack_require__(134).appendChild(iframe);iframe.src=\"javascript:\";iframeDocument=iframe.contentWindow.document;iframeDocument.open();iframeDocument.write(lt+\"script\"+gt+\"document.F=Object\"+lt+\"/script\"+gt);iframeDocument.close();createDict=iframeDocument.F;while(i--)delete createDict[PROTOTYPE][enumBugKeys[i]];return createDict()};module.exports=Object.create||function create(O,Properties){var result;if(O!==null){Empty[PROTOTYPE]=anObject(O);result=new Empty;Empty[PROTOTYPE]=null;result[IE_PROTO]=O}else result=createDict();return Properties===undefined?result:dPs(result,Properties)}},function(module,exports){var ceil=Math.ceil;var floor=Math.floor;module.exports=function(it){return isNaN(it=+it)?0:(it>0?floor:ceil)(it)}},function(module,exports,__webpack_require__){var shared=__webpack_require__(57)(\"keys\");var uid=__webpack_require__(40);module.exports=function(key){return shared[key]||(shared[key]=uid(key))}},function(module,exports,__webpack_require__){var global=__webpack_require__(18);var SHARED=\"__core-js_shared__\";var store=global[SHARED]||(global[SHARED]={});module.exports=function(key){return store[key]||(store[key]={})}},function(module,exports){module.exports=\"constructor,hasOwnProperty,isPrototypeOf,propertyIsEnumerable,toLocaleString,toString,valueOf\".split(\",\")},function(module,exports,__webpack_require__){var def=__webpack_require__(20).f;var has=__webpack_require__(22);var TAG=__webpack_require__(13)(\"toStringTag\");module.exports=function(it,tag,stat){if(it&&!has(it=stat?it:it.prototype,TAG))def(it,TAG,{configurable:true,value:tag})}},function(module,exports,__webpack_require__){\"use strict\";var $at=__webpack_require__(135)(true);__webpack_require__(79)(String,\"String\",function(iterated){this._t=String(iterated);this._i=0},function(){var O=this._t;var index=this._i;var point;if(index>=O.length)return{value:undefined,done:true};point=$at(O,index);this._i+=point.length;return{value:point,done:false}})},function(module,exports,__webpack_require__){exports.f=__webpack_require__(13)},function(module,exports,__webpack_require__){var global=__webpack_require__(18);var core=__webpack_require__(7);var LIBRARY=__webpack_require__(52);var wksExt=__webpack_require__(61);var defineProperty=__webpack_require__(20).f;module.exports=function(name){var $Symbol=core.Symbol||(core.Symbol=LIBRARY?{}:global.Symbol||{});if(name.charAt(0)!=\"_\"&&!(name in $Symbol))defineProperty($Symbol,name,{value:wksExt.f(name)})}},function(module,exports){exports.f=Object.getOwnPropertySymbols},function(module,exports,__webpack_require__){\"use strict\";var _keys=__webpack_require__(8);var _keys2=_interopRequireDefault(_keys);var _stringify=__webpack_require__(19);var _stringify2=_interopRequireDefault(_stringify);var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var moment=__webpack_require__(9);var Component=__webpack_require__(16);var DateUtil=__webpack_require__(36);function Range(body,options){var now=moment().hours(0).minutes(0).seconds(0).milliseconds(0);var start=now.clone().add(-3,\"days\").valueOf();var end=now.clone().add(3,\"days\").valueOf();this.millisecondsPerPixelCache=undefined;if(options===undefined){this.start=start;this.end=end}else{this.start=options.start||start;this.end=options.end||end}this.rolling=false;this.body=body;this.deltaDifference=0;this.scaleOffset=0;this.startToFront=false;this.endToFront=true;this.defaultOptions={rtl:false,start:null,end:null,moment:moment,direction:\"horizontal\",moveable:true,zoomable:true,min:null,max:null,zoomMin:10,zoomMax:1e3*60*60*24*365*1e4,rollingMode:{follow:false,offset:.5}};this.options=util.extend({},this.defaultOptions);this.props={touch:{}};this.animationTimer=null;this.body.emitter.on(\"panstart\",this._onDragStart.bind(this));this.body.emitter.on(\"panmove\",this._onDrag.bind(this));this.body.emitter.on(\"panend\",this._onDragEnd.bind(this));this.body.emitter.on(\"mousewheel\",this._onMouseWheel.bind(this));this.body.emitter.on(\"touch\",this._onTouch.bind(this));this.body.emitter.on(\"pinch\",this._onPinch.bind(this));this.body.dom.rollingModeBtn.addEventListener(\"click\",this.startRolling.bind(this));this.setOptions(options)}Range.prototype=new Component;Range.prototype.setOptions=function(options){if(options){var fields=[\"animation\",\"direction\",\"min\",\"max\",\"zoomMin\",\"zoomMax\",\"moveable\",\"zoomable\",\"moment\",\"activate\",\"hiddenDates\",\"zoomKey\",\"rtl\",\"showCurrentTime\",\"rollingMode\",\"horizontalScroll\"];util.selectiveExtend(fields,this.options,options);if(options.rollingMode&&options.rollingMode.follow){this.startRolling()}if(\"start\"in options||\"end\"in options){this.setRange(options.start,options.end)}}};function validateDirection(direction){if(direction!=\"horizontal\"&&direction!=\"vertical\"){throw new TypeError('Unknown direction \"'+direction+'\". '+'Choose \"horizontal\" or \"vertical\".')}}Range.prototype.startRolling=function(){var me=this;function update(){me.stopRolling();me.rolling=true;var interval=me.end-me.start;var t=util.convert(new Date,\"Date\").valueOf();var start=t-interval*me.options.rollingMode.offset;var end=t+interval*(1-me.options.rollingMode.offset);var options={animation:false};me.setRange(start,end,options);var scale=me.conversion(me.body.domProps.center.width).scale;interval=1/scale/10;if(interval<30)interval=30;if(interval>1e3)interval=1e3;me.body.dom.rollingModeBtn.style.visibility=\"hidden\";me.currentTimeTimer=setTimeout(update,interval)}update()};Range.prototype.stopRolling=function(){if(this.currentTimeTimer!==undefined){clearTimeout(this.currentTimeTimer);this.rolling=false;this.body.dom.rollingModeBtn.style.visibility=\"visible\"}};Range.prototype.setRange=function(start,end,options,callback,frameCallback){if(!options){options={}}if(options.byUser!==true){options.byUser=false}var me=this;var finalStart=start!=undefined?util.convert(start,\"Date\").valueOf():null;var finalEnd=end!=undefined?util.convert(end,\"Date\").valueOf():null;this._cancelAnimation();this.millisecondsPerPixelCache=undefined;if(options.animation){var initStart=this.start;var initEnd=this.end;var duration=(0,_typeof3[\"default\"])(options.animation)===\"object\"&&\"duration\"in options.animation?options.animation.duration:500;var easingName=(0,_typeof3[\"default\"])(options.animation)===\"object\"&&\"easingFunction\"in options.animation?options.animation.easingFunction:\"easeInOutQuad\";var easingFunction=util.easingFunctions[easingName];if(!easingFunction){throw new Error(\"Unknown easing function \"+(0,_stringify2[\"default\"])(easingName)+\". \"+\"Choose from: \"+(0,_keys2[\"default\"])(util.easingFunctions).join(\", \"))}var initTime=(new Date).valueOf();var anyChanged=false;var next=function next(){if(!me.props.touch.dragging){var now=(new Date).valueOf();var time=now-initTime;var ease=easingFunction(time/duration);var done=time>duration;var s=done||finalStart===null?finalStart:initStart+(finalStart-initStart)*ease;var e=done||finalEnd===null?finalEnd:initEnd+(finalEnd-initEnd)*ease;changed=me._applyRange(s,e);DateUtil.updateHiddenDates(me.options.moment,me.body,me.options.hiddenDates);anyChanged=anyChanged||changed;var params={start:new Date(me.start),end:new Date(me.end),byUser:options.byUser,event:options.event};if(frameCallback){frameCallback(ease,changed,done)}if(changed){me.body.emitter.emit(\"rangechange\",params)}if(done){if(anyChanged){me.body.emitter.emit(\"rangechanged\",params);if(callback){return callback()}}}else{me.animationTimer=setTimeout(next,20)}}};return next()}else{var changed=this._applyRange(finalStart,finalEnd);DateUtil.updateHiddenDates(this.options.moment,this.body,this.options.hiddenDates);if(changed){var params={start:new Date(this.start),end:new Date(this.end),byUser:options.byUser,event:options.event};this.body.emitter.emit(\"rangechange\",params);clearTimeout(me.timeoutID);me.timeoutID=setTimeout(function(){me.body.emitter.emit(\"rangechanged\",params)},200);if(callback){return callback()}}}};Range.prototype.getMillisecondsPerPixel=function(){if(this.millisecondsPerPixelCache===undefined){this.millisecondsPerPixelCache=(this.end-this.start)/this.body.dom.center.clientWidth}return this.millisecondsPerPixelCache};Range.prototype._cancelAnimation=function(){if(this.animationTimer){clearTimeout(this.animationTimer);this.animationTimer=null}};Range.prototype._applyRange=function(start,end){var newStart=start!=null?util.convert(start,\"Date\").valueOf():this.start,newEnd=end!=null?util.convert(end,\"Date\").valueOf():this.end,max=this.options.max!=null?util.convert(this.options.max,\"Date\").valueOf():null,min=this.options.min!=null?util.convert(this.options.min,\"Date\").valueOf():null,diff;if(isNaN(newStart)||newStart===null){throw new Error('Invalid start \"'+start+'\"')}if(isNaN(newEnd)||newEnd===null){throw new Error('Invalid end \"'+end+'\"')}if(newEnd<newStart){newEnd=newStart}if(min!==null){if(newStart<min){diff=min-newStart;newStart+=diff;newEnd+=diff;if(max!=null){if(newEnd>max){newEnd=max}}}}if(max!==null){if(newEnd>max){diff=newEnd-max;newStart-=diff;newEnd-=diff;if(min!=null){if(newStart<min){newStart=min}}}}if(this.options.zoomMin!==null){var zoomMin=parseFloat(this.options.zoomMin);if(zoomMin<0){zoomMin=0}if(newEnd-newStart<zoomMin){var compensation=.5;if(this.end-this.start===zoomMin&&newStart>=this.start-compensation&&newEnd<=this.end){newStart=this.start;newEnd=this.end}else{diff=zoomMin-(newEnd-newStart);newStart-=diff/2;newEnd+=diff/2}}}if(this.options.zoomMax!==null){var zoomMax=parseFloat(this.options.zoomMax);if(zoomMax<0){zoomMax=0}if(newEnd-newStart>zoomMax){if(this.end-this.start===zoomMax&&newStart<this.start&&newEnd>this.end){newStart=this.start;newEnd=this.end}else{diff=newEnd-newStart-zoomMax;newStart+=diff/2;newEnd-=diff/2}}}var changed=this.start!=newStart||this.end!=newEnd;if(!(newStart>=this.start&&newStart<=this.end||newEnd>=this.start&&newEnd<=this.end)&&!(this.start>=newStart&&this.start<=newEnd||this.end>=newStart&&this.end<=newEnd)){this.body.emitter.emit(\"checkRangedItems\")}this.start=newStart;this.end=newEnd;return changed};Range.prototype.getRange=function(){return{start:this.start,end:this.end}};Range.prototype.conversion=function(width,totalHidden){return Range.conversion(this.start,this.end,width,totalHidden)};Range.conversion=function(start,end,width,totalHidden){if(totalHidden===undefined){totalHidden=0}if(width!=0&&end-start!=0){return{offset:start,scale:width/(end-start-totalHidden)}}else{return{offset:0,scale:1}}};Range.prototype._onDragStart=function(event){this.deltaDifference=0;this.previousDelta=0;if(!this.options.moveable)return;if(!this._isInsideRange(event))return;if(!this.props.touch.allowDragging)return;this.stopRolling();this.props.touch.start=this.start;this.props.touch.end=this.end;this.props.touch.dragging=true;if(this.body.dom.root){this.body.dom.root.style.cursor=\"move\"}};Range.prototype._onDrag=function(event){if(!event)return;if(!this.props.touch.dragging)return;if(!this.options.moveable)return;if(!this.props.touch.allowDragging)return;var direction=this.options.direction;validateDirection(direction);var delta=direction==\"horizontal\"?event.deltaX:event.deltaY;delta-=this.deltaDifference;var interval=this.props.touch.end-this.props.touch.start;var duration=DateUtil.getHiddenDurationBetween(this.body.hiddenDates,this.start,this.end);interval-=duration;var width=direction==\"horizontal\"?this.body.domProps.center.width:this.body.domProps.center.height;var diffRange;if(this.options.rtl){diffRange=delta/width*interval}else{diffRange=-delta/width*interval}var newStart=this.props.touch.start+diffRange;var newEnd=this.props.touch.end+diffRange;var safeStart=DateUtil.snapAwayFromHidden(this.body.hiddenDates,newStart,this.previousDelta-delta,true);var safeEnd=DateUtil.snapAwayFromHidden(this.body.hiddenDates,newEnd,this.previousDelta-delta,true);if(safeStart!=newStart||safeEnd!=newEnd){this.deltaDifference+=delta;this.props.touch.start=safeStart;this.props.touch.end=safeEnd;this._onDrag(event);return}this.previousDelta=delta;this._applyRange(newStart,newEnd);var startDate=new Date(this.start);var endDate=new Date(this.end);this.body.emitter.emit(\"rangechange\",{start:startDate,end:endDate,byUser:true,event:event});this.body.emitter.emit(\"panmove\")};Range.prototype._onDragEnd=function(event){if(!this.props.touch.dragging)return;if(!this.options.moveable)return;if(!this.props.touch.allowDragging)return;this.props.touch.dragging=false;if(this.body.dom.root){this.body.dom.root.style.cursor=\"auto\"}this.body.emitter.emit(\"rangechanged\",{start:new Date(this.start),end:new Date(this.end),byUser:true,event:event})};Range.prototype._onMouseWheel=function(event){var delta=0;if(event.wheelDelta){delta=event.wheelDelta/120}else if(event.detail){delta=-event.detail/3}if(this.options.zoomKey&&!event[this.options.zoomKey]&&this.options.zoomable||!this.options.zoomable&&this.options.moveable){return}if(!(this.options.zoomable&&this.options.moveable))return;if(!this._isInsideRange(event))return;if(delta){var scale;if(delta<0){scale=1-delta/5}else{scale=1/(1+delta/5)}var pointerDate;if(this.rolling){pointerDate=this.start+(this.end-this.start)*this.options.rollingMode.offset}else{var pointer=this.getPointer({x:event.clientX,y:event.clientY},this.body.dom.center);pointerDate=this._pointerToDate(pointer)}this.zoom(scale,pointerDate,delta,event);event.preventDefault()}};Range.prototype._onTouch=function(event){this.props.touch.start=this.start;this.props.touch.end=this.end;this.props.touch.allowDragging=true;this.props.touch.center=null;this.scaleOffset=0;this.deltaDifference=0;util.preventDefault(event)};Range.prototype._onPinch=function(event){if(!(this.options.zoomable&&this.options.moveable))return;util.preventDefault(event);this.props.touch.allowDragging=false;if(!this.props.touch.center){this.props.touch.center=this.getPointer(event.center,this.body.dom.center)}this.stopRolling();var scale=1/(event.scale+this.scaleOffset);var centerDate=this._pointerToDate(this.props.touch.center);var hiddenDuration=DateUtil.getHiddenDurationBetween(this.body.hiddenDates,this.start,this.end);var hiddenDurationBefore=DateUtil.getHiddenDurationBefore(this.options.moment,this.body.hiddenDates,this,centerDate);var hiddenDurationAfter=hiddenDuration-hiddenDurationBefore;var newStart=centerDate-hiddenDurationBefore+(this.props.touch.start-(centerDate-hiddenDurationBefore))*scale;var newEnd=centerDate+hiddenDurationAfter+(this.props.touch.end-(centerDate+hiddenDurationAfter))*scale;this.startToFront=1-scale<=0;this.endToFront=scale-1<=0;var safeStart=DateUtil.snapAwayFromHidden(this.body.hiddenDates,newStart,1-scale,true);var safeEnd=DateUtil.snapAwayFromHidden(this.body.hiddenDates,newEnd,scale-1,true);if(safeStart!=newStart||safeEnd!=newEnd){this.props.touch.start=safeStart;this.props.touch.end=safeEnd;this.scaleOffset=1-event.scale;newStart=safeStart;newEnd=safeEnd}var options={animation:false,byUser:true,event:event};this.setRange(newStart,newEnd,options);this.startToFront=false;this.endToFront=true};Range.prototype._isInsideRange=function(event){var clientX=event.center?event.center.x:event.clientX;var x;if(this.options.rtl){x=clientX-util.getAbsoluteLeft(this.body.dom.centerContainer)}else{x=util.getAbsoluteRight(this.body.dom.centerContainer)-clientX}var time=this.body.util.toTime(x);return time>=this.start&&time<=this.end};Range.prototype._pointerToDate=function(pointer){var conversion;var direction=this.options.direction;validateDirection(direction);if(direction==\"horizontal\"){return this.body.util.toTime(pointer.x).valueOf()}else{var height=this.body.domProps.center.height;conversion=this.conversion(height);return pointer.y/conversion.scale+conversion.offset}};Range.prototype.getPointer=function(touch,element){if(this.options.rtl){return{x:util.getAbsoluteRight(element)-touch.x,y:touch.y-util.getAbsoluteTop(element)}}else{return{x:touch.x-util.getAbsoluteLeft(element),y:touch.y-util.getAbsoluteTop(element)}}};Range.prototype.zoom=function(scale,center,delta,event){if(center==null){center=(this.start+this.end)/2}var hiddenDuration=DateUtil.getHiddenDurationBetween(this.body.hiddenDates,this.start,this.end);var hiddenDurationBefore=DateUtil.getHiddenDurationBefore(this.options.moment,this.body.hiddenDates,this,center);var hiddenDurationAfter=hiddenDuration-hiddenDurationBefore;var newStart=center-hiddenDurationBefore+(this.start-(center-hiddenDurationBefore))*scale;var newEnd=center+hiddenDurationAfter+(this.end-(center+hiddenDurationAfter))*scale;this.startToFront=delta>0?false:true;this.endToFront=-delta>0?false:true;var safeStart=DateUtil.snapAwayFromHidden(this.body.hiddenDates,newStart,delta,true);var safeEnd=DateUtil.snapAwayFromHidden(this.body.hiddenDates,newEnd,-delta,true);if(safeStart!=newStart||safeEnd!=newEnd){newStart=safeStart;newEnd=safeEnd}var options={animation:false,byUser:true,event:event};this.setRange(newStart,newEnd,options);this.startToFront=false;this.endToFront=true};Range.prototype.move=function(delta){var diff=this.end-this.start;var newStart=this.start+diff*delta;var newEnd=this.end+diff*delta;this.start=newStart;this.end=newEnd};Range.prototype.moveTo=function(moveTo){var center=(this.start+this.end)/2;var diff=center-moveTo;var newStart=this.start-diff;var newEnd=this.end-diff;var options={animation:false,byUser:true,event:null};this.setRange(newStart,newEnd,options)};module.exports=Range},function(module,exports,__webpack_require__){\"use strict\";var _stringify=__webpack_require__(19);var _stringify2=_interopRequireDefault(_stringify);var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Emitter=__webpack_require__(44);var Hammer=__webpack_require__(10);var hammerUtil=__webpack_require__(37);var util=__webpack_require__(2);var TimeAxis=__webpack_require__(45);var Activator=__webpack_require__(97);var DateUtil=__webpack_require__(36);var CustomTime=__webpack_require__(46);function Core(){}Emitter(Core.prototype);Core.prototype._create=function(container){this.dom={};this.dom.container=container;this.dom.root=document.createElement(\"div\");this.dom.background=document.createElement(\"div\");this.dom.backgroundVertical=document.createElement(\"div\");this.dom.backgroundHorizontal=document.createElement(\"div\");this.dom.centerContainer=document.createElement(\"div\");this.dom.leftContainer=document.createElement(\"div\");this.dom.rightContainer=document.createElement(\"div\");this.dom.center=document.createElement(\"div\");this.dom.left=document.createElement(\"div\");this.dom.right=document.createElement(\"div\");this.dom.top=document.createElement(\"div\");this.dom.bottom=document.createElement(\"div\");this.dom.shadowTop=document.createElement(\"div\");this.dom.shadowBottom=document.createElement(\"div\");this.dom.shadowTopLeft=document.createElement(\"div\");this.dom.shadowBottomLeft=document.createElement(\"div\");this.dom.shadowTopRight=document.createElement(\"div\");this.dom.shadowBottomRight=document.createElement(\"div\");this.dom.rollingModeBtn=document.createElement(\"div\");this.dom.root.className=\"vis-timeline\";this.dom.background.className=\"vis-panel vis-background\";this.dom.backgroundVertical.className=\"vis-panel vis-background vis-vertical\";this.dom.backgroundHorizontal.className=\"vis-panel vis-background vis-horizontal\";this.dom.centerContainer.className=\"vis-panel vis-center\";this.dom.leftContainer.className=\"vis-panel vis-left\";this.dom.rightContainer.className=\"vis-panel vis-right\";this.dom.top.className=\"vis-panel vis-top\";this.dom.bottom.className=\"vis-panel vis-bottom\";this.dom.left.className=\"vis-content\";this.dom.center.className=\"vis-content\";this.dom.right.className=\"vis-content\";this.dom.shadowTop.className=\"vis-shadow vis-top\";this.dom.shadowBottom.className=\"vis-shadow vis-bottom\";this.dom.shadowTopLeft.className=\"vis-shadow vis-top\";this.dom.shadowBottomLeft.className=\"vis-shadow vis-bottom\";this.dom.shadowTopRight.className=\"vis-shadow vis-top\";this.dom.shadowBottomRight.className=\"vis-shadow vis-bottom\";this.dom.rollingModeBtn.className=\"vis-rolling-mode-btn\";this.dom.root.appendChild(this.dom.background);this.dom.root.appendChild(this.dom.backgroundVertical);this.dom.root.appendChild(this.dom.backgroundHorizontal);this.dom.root.appendChild(this.dom.centerContainer);this.dom.root.appendChild(this.dom.leftContainer);this.dom.root.appendChild(this.dom.rightContainer);this.dom.root.appendChild(this.dom.top);this.dom.root.appendChild(this.dom.bottom);this.dom.root.appendChild(this.dom.bottom);this.dom.root.appendChild(this.dom.rollingModeBtn);this.dom.centerContainer.appendChild(this.dom.center);this.dom.leftContainer.appendChild(this.dom.left);this.dom.rightContainer.appendChild(this.dom.right);this.dom.centerContainer.appendChild(this.dom.shadowTop);this.dom.centerContainer.appendChild(this.dom.shadowBottom);this.dom.leftContainer.appendChild(this.dom.shadowTopLeft);this.dom.leftContainer.appendChild(this.dom.shadowBottomLeft);this.dom.rightContainer.appendChild(this.dom.shadowTopRight);this.dom.rightContainer.appendChild(this.dom.shadowBottomRight);this.props={root:{},background:{},centerContainer:{},leftContainer:{},rightContainer:{},center:{},left:{},right:{},top:{},bottom:{},border:{},scrollTop:0,scrollTopMin:0};this.on(\"rangechange\",function(){if(this.initialDrawDone===true){this._redraw()}}.bind(this));this.on(\"rangechanged\",function(){if(!this.initialRangeChangeDone){this.initialRangeChangeDone=true}}.bind(this));this.on(\"touch\",this._onTouch.bind(this));this.on(\"panmove\",this._onDrag.bind(this));var me=this;this._origRedraw=this._redraw.bind(this);this._redraw=util.throttle(this._origRedraw);this.on(\"_change\",function(properties){if(me.itemSet&&me.itemSet.initialItemSetDrawn&&properties&&properties.queue==true){me._redraw()}else{me._origRedraw()}});this.hammer=new Hammer(this.dom.root);var pinchRecognizer=this.hammer.get(\"pinch\").set({enable:true});hammerUtil.disablePreventDefaultVertically(pinchRecognizer);this.hammer.get(\"pan\").set({threshold:5,direction:Hammer.DIRECTION_HORIZONTAL});this.listeners={};var events=[\"tap\",\"doubletap\",\"press\",\"pinch\",\"pan\",\"panstart\",\"panmove\",\"panend\"];events.forEach(function(type){var listener=function listener(event){if(me.isActive()){me.emit(type,event)}};me.hammer.on(type,listener);me.listeners[type]=listener});hammerUtil.onTouch(this.hammer,function(event){me.emit(\"touch\",event)}.bind(this));hammerUtil.onRelease(this.hammer,function(event){me.emit(\"release\",event)}.bind(this));function onMouseWheel(event){if(this.isActive()){this.emit(\"mousewheel\",event)}var deltaX=0;var deltaY=0;if(\"detail\"in event){deltaY=event.detail*-1}if(\"wheelDelta\"in event){deltaY=event.wheelDelta}if(\"wheelDeltaY\"in event){deltaY=event.wheelDeltaY}if(\"wheelDeltaX\"in event){deltaX=event.wheelDeltaX*-1}if(\"axis\"in event&&event.axis===event.HORIZONTAL_AXIS){deltaX=deltaY*-1;deltaY=0}if(\"deltaY\"in event){deltaY=event.deltaY*-1}if(\"deltaX\"in event){deltaX=event.deltaX}if(!this.options.zoomKey||event[this.options.zoomKey])return;event.preventDefault();if(this.options.verticalScroll&&Math.abs(deltaY)>=Math.abs(deltaX)){var current=this.props.scrollTop;var adjusted=current+deltaY;if(this.isActive()){this._setScrollTop(adjusted);this._redraw();this.emit(\"scroll\",event)}}else if(this.options.horizontalScroll){var delta=Math.abs(deltaX)>=Math.abs(deltaY)?deltaX:deltaY;var diff=delta/120*(this.range.end-this.range.start)/20;var newStart=this.range.start+diff;var newEnd=this.range.end+diff;var options={animation:false,byUser:true,event:event};this.range.setRange(newStart,newEnd,options)}}if(this.dom.centerContainer.addEventListener){this.dom.centerContainer.addEventListener(\"mousewheel\",onMouseWheel.bind(this),false);this.dom.centerContainer.addEventListener(\"DOMMouseScroll\",onMouseWheel.bind(this),false)}else{this.dom.centerContainer.attachEvent(\"onmousewheel\",onMouseWheel.bind(this))}function onMouseScrollSide(event){if(!me.options.verticalScroll)return;event.preventDefault();if(me.isActive()){var adjusted=-event.target.scrollTop;me._setScrollTop(adjusted);me._redraw();me.emit(\"scrollSide\",event)}}this.dom.left.parentNode.addEventListener(\"scroll\",onMouseScrollSide.bind(this));this.dom.right.parentNode.addEventListener(\"scroll\",onMouseScrollSide.bind(this));var itemAddedToTimeline=false;function handleDragOver(event){if(event.preventDefault){event.preventDefault()}if(!event.target.className.indexOf(\"vis\")>-1)return;if(itemAddedToTimeline)return;event.dataTransfer.dropEffect=\"move\";itemAddedToTimeline=true;return false}function handleDrop(event){if(event.preventDefault){event.preventDefault()}if(event.stopPropagation){event.stopPropagation()}try{var itemData=JSON.parse(event.dataTransfer.getData(\"text\"));if(!itemData||!itemData.content)return}catch(err){return false}itemAddedToTimeline=false;event.center={x:event.clientX,y:event.clientY};if(itemData.target!==\"item\"){me.itemSet._onAddItem(event)}else{me.itemSet._onDropObjectOnItem(event)}me.emit(\"drop\",me.getEventProperties(event));return false}this.dom.center.addEventListener(\"dragover\",handleDragOver.bind(this),false);this.dom.center.addEventListener(\"drop\",handleDrop.bind(this),false);this.customTimes=[];this.touch={};this.redrawCount=0;this.initialDrawDone=false;this.initialRangeChangeDone=false;if(!container)throw new Error(\"No container provided\");container.appendChild(this.dom.root)};Core.prototype.setOptions=function(options){if(options){var fields=[\"width\",\"height\",\"minHeight\",\"maxHeight\",\"autoResize\",\"start\",\"end\",\"clickToUse\",\"dataAttributes\",\"hiddenDates\",\"locale\",\"locales\",\"moment\",\"rtl\",\"zoomKey\",\"horizontalScroll\",\"verticalScroll\"];util.selectiveExtend(fields,this.options,options);this.dom.rollingModeBtn.style.visibility=\"hidden\";if(this.options.rtl){this.dom.container.style.direction=\"rtl\";this.dom.backgroundVertical.className=\"vis-panel vis-background vis-vertical-rtl\"}if(this.options.verticalScroll){if(this.options.rtl){this.dom.rightContainer.className=\"vis-panel vis-right vis-vertical-scroll\"}else{this.dom.leftContainer.className=\"vis-panel vis-left vis-vertical-scroll\"}}if((0,_typeof3[\"default\"])(this.options.orientation)!==\"object\"){this.options.orientation={item:undefined,axis:undefined}}if(\"orientation\"in options){if(typeof options.orientation===\"string\"){this.options.orientation={item:options.orientation,axis:options.orientation}}else if((0,_typeof3[\"default\"])(options.orientation)===\"object\"){if(\"item\"in options.orientation){this.options.orientation.item=options.orientation.item}if(\"axis\"in options.orientation){this.options.orientation.axis=options.orientation.axis}}}if(this.options.orientation.axis===\"both\"){if(!this.timeAxis2){var timeAxis2=this.timeAxis2=new TimeAxis(this.body);timeAxis2.setOptions=function(options){var _options=options?util.extend({},options):{};_options.orientation=\"top\";TimeAxis.prototype.setOptions.call(timeAxis2,_options)};this.components.push(timeAxis2)}}else{if(this.timeAxis2){var index=this.components.indexOf(this.timeAxis2);if(index!==-1){this.components.splice(index,1)}this.timeAxis2.destroy();this.timeAxis2=null}}if(typeof options.drawPoints==\"function\"){options.drawPoints={onRender:options.drawPoints}}if(\"hiddenDates\"in this.options){DateUtil.convertHiddenOptions(this.options.moment,this.body,this.options.hiddenDates)}if(\"clickToUse\"in options){if(options.clickToUse){if(!this.activator){this.activator=new Activator(this.dom.root)}}else{if(this.activator){this.activator.destroy();delete this.activator}}}if(\"showCustomTime\"in options){throw new Error(\"Option `showCustomTime` is deprecated. Create a custom time bar via timeline.addCustomTime(time [, id])\")}this._initAutoResize()}this.components.forEach(function(component){return component.setOptions(options)});if(\"configure\"in options){if(!this.configurator){this.configurator=this._createConfigurator()}this.configurator.setOptions(options.configure);var appliedOptions=util.deepExtend({},this.options);this.components.forEach(function(component){util.deepExtend(appliedOptions,component.options)});this.configurator.setModuleOptions({global:appliedOptions})}this._redraw()};Core.prototype.isActive=function(){return!this.activator||this.activator.active};Core.prototype.destroy=function(){this.setItems(null);this.setGroups(null);this.off();this._stopAutoResize();if(this.dom.root.parentNode){this.dom.root.parentNode.removeChild(this.dom.root)}this.dom=null;if(this.activator){this.activator.destroy();delete this.activator}for(var event in this.listeners){if(this.listeners.hasOwnProperty(event)){delete this.listeners[event]}}this.listeners=null;this.hammer=null;this.components.forEach(function(component){return component.destroy()});this.body=null};Core.prototype.setCustomTime=function(time,id){var customTimes=this.customTimes.filter(function(component){return id===component.options.id});if(customTimes.length===0){throw new Error(\"No custom time bar found with id \"+(0,_stringify2[\"default\"])(id))}if(customTimes.length>0){customTimes[0].setCustomTime(time)}};Core.prototype.getCustomTime=function(id){var customTimes=this.customTimes.filter(function(component){return component.options.id===id});if(customTimes.length===0){throw new Error(\"No custom time bar found with id \"+(0,_stringify2[\"default\"])(id))}return customTimes[0].getCustomTime()};Core.prototype.setCustomTimeTitle=function(title,id){var customTimes=this.customTimes.filter(function(component){return component.options.id===id});if(customTimes.length===0){throw new Error(\"No custom time bar found with id \"+(0,_stringify2[\"default\"])(id))}if(customTimes.length>0){return customTimes[0].setCustomTitle(title)}};Core.prototype.getEventProperties=function(event){return{event:event}};Core.prototype.addCustomTime=function(time,id){var timestamp=time!==undefined?util.convert(time,\"Date\").valueOf():new Date;var exists=this.customTimes.some(function(customTime){return customTime.options.id===id});if(exists){throw new Error(\"A custom time with id \"+(0,_stringify2[\"default\"])(id)+\" already exists\")}var customTime=new CustomTime(this.body,util.extend({},this.options,{time:timestamp,id:id}));this.customTimes.push(customTime);this.components.push(customTime);this._redraw();return id};Core.prototype.removeCustomTime=function(id){var customTimes=this.customTimes.filter(function(bar){return bar.options.id===id});if(customTimes.length===0){throw new Error(\"No custom time bar found with id \"+(0,_stringify2[\"default\"])(id))}customTimes.forEach(function(customTime){this.customTimes.splice(this.customTimes.indexOf(customTime),1);this.components.splice(this.components.indexOf(customTime),1);customTime.destroy()}.bind(this))};Core.prototype.getVisibleItems=function(){return this.itemSet&&this.itemSet.getVisibleItems()||[]};Core.prototype.fit=function(options,callback){var range=this.getDataRange();if(range.min===null&&range.max===null){return}var interval=range.max-range.min;var min=new Date(range.min.valueOf()-interval*.01);var max=new Date(range.max.valueOf()+interval*.01);var animation=options&&options.animation!==undefined?options.animation:true;this.range.setRange(min,max,{animation:animation},callback)};Core.prototype.getDataRange=function(){throw new Error(\"Cannot invoke abstract method getDataRange\")};Core.prototype.setWindow=function(start,end,options,callback){if(typeof arguments[2]==\"function\"){callback=arguments[2];options={}}var animation;var range;if(arguments.length==1){range=arguments[0];animation=range.animation!==undefined?range.animation:true;this.range.setRange(range.start,range.end,{animation:animation})}else if(arguments.length==2&&typeof arguments[1]==\"function\"){range=arguments[0];callback=arguments[1];animation=range.animation!==undefined?range.animation:true\n;this.range.setRange(range.start,range.end,{animation:animation},callback)}else{animation=options&&options.animation!==undefined?options.animation:true;this.range.setRange(start,end,{animation:animation},callback)}};Core.prototype.moveTo=function(time,options,callback){if(typeof arguments[1]==\"function\"){callback=arguments[1];options={}}var interval=this.range.end-this.range.start;var t=util.convert(time,\"Date\").valueOf();var start=t-interval/2;var end=t+interval/2;var animation=options&&options.animation!==undefined?options.animation:true;this.range.setRange(start,end,{animation:animation},callback)};Core.prototype.getWindow=function(){var range=this.range.getRange();return{start:new Date(range.start),end:new Date(range.end)}};Core.prototype.zoomIn=function(percentage,options,callback){if(!percentage||percentage<0||percentage>1)return;if(typeof arguments[1]==\"function\"){callback=arguments[1];options={}}var range=this.getWindow();var start=range.start.valueOf();var end=range.end.valueOf();var interval=end-start;var newInterval=interval/(1+percentage);var distance=(interval-newInterval)/2;var newStart=start+distance;var newEnd=end-distance;this.setWindow(newStart,newEnd,options,callback)};Core.prototype.zoomOut=function(percentage,options,callback){if(!percentage||percentage<0||percentage>1)return;if(typeof arguments[1]==\"function\"){callback=arguments[1];options={}}var range=this.getWindow();var start=range.start.valueOf();var end=range.end.valueOf();var interval=end-start;var newStart=start-interval*percentage/2;var newEnd=end+interval*percentage/2;this.setWindow(newStart,newEnd,options,callback)};Core.prototype.redraw=function(){this._redraw()};Core.prototype._redraw=function(){this.redrawCount++;var resized=false;var options=this.options;var props=this.props;var dom=this.dom;if(!dom||!dom.container||dom.root.offsetWidth==0)return;DateUtil.updateHiddenDates(this.options.moment,this.body,this.options.hiddenDates);if(options.orientation==\"top\"){util.addClassName(dom.root,\"vis-top\");util.removeClassName(dom.root,\"vis-bottom\")}else{util.removeClassName(dom.root,\"vis-top\");util.addClassName(dom.root,\"vis-bottom\")}dom.root.style.maxHeight=util.option.asSize(options.maxHeight,\"\");dom.root.style.minHeight=util.option.asSize(options.minHeight,\"\");dom.root.style.width=util.option.asSize(options.width,\"\");props.border.left=(dom.centerContainer.offsetWidth-dom.centerContainer.clientWidth)/2;props.border.right=props.border.left;props.border.top=(dom.centerContainer.offsetHeight-dom.centerContainer.clientHeight)/2;props.border.bottom=props.border.top;props.borderRootHeight=dom.root.offsetHeight-dom.root.clientHeight;props.borderRootWidth=dom.root.offsetWidth-dom.root.clientWidth;if(dom.centerContainer.clientHeight===0){props.border.left=props.border.top;props.border.right=props.border.left}if(dom.root.clientHeight===0){props.borderRootWidth=props.borderRootHeight}props.center.height=dom.center.offsetHeight;props.left.height=dom.left.offsetHeight;props.right.height=dom.right.offsetHeight;props.top.height=dom.top.clientHeight||-props.border.top;props.bottom.height=dom.bottom.clientHeight||-props.border.bottom;var contentHeight=Math.max(props.left.height,props.center.height,props.right.height);var autoHeight=props.top.height+contentHeight+props.bottom.height+props.borderRootHeight+props.border.top+props.border.bottom;dom.root.style.height=util.option.asSize(options.height,autoHeight+\"px\");props.root.height=dom.root.offsetHeight;props.background.height=props.root.height-props.borderRootHeight;var containerHeight=props.root.height-props.top.height-props.bottom.height-props.borderRootHeight;props.centerContainer.height=containerHeight;props.leftContainer.height=containerHeight;props.rightContainer.height=props.leftContainer.height;props.root.width=dom.root.offsetWidth;props.background.width=props.root.width-props.borderRootWidth;if(!this.initialDrawDone){props.scrollbarWidth=util.getScrollBarWidth()}if(options.verticalScroll){if(options.rtl){props.left.width=dom.leftContainer.clientWidth||-props.border.left;props.right.width=dom.rightContainer.clientWidth+props.scrollbarWidth||-props.border.right}else{props.left.width=dom.leftContainer.clientWidth+props.scrollbarWidth||-props.border.left;props.right.width=dom.rightContainer.clientWidth||-props.border.right}}else{props.left.width=dom.leftContainer.clientWidth||-props.border.left;props.right.width=dom.rightContainer.clientWidth||-props.border.right}this._setDOM();var offset=this._updateScrollTop();if(options.orientation.item!=\"top\"){offset+=Math.max(props.centerContainer.height-props.center.height-props.border.top-props.border.bottom,0)}dom.center.style.top=offset+\"px\";var visibilityTop=props.scrollTop==0?\"hidden\":\"\";var visibilityBottom=props.scrollTop==props.scrollTopMin?\"hidden\":\"\";dom.shadowTop.style.visibility=visibilityTop;dom.shadowBottom.style.visibility=visibilityBottom;dom.shadowTopLeft.style.visibility=visibilityTop;dom.shadowBottomLeft.style.visibility=visibilityBottom;dom.shadowTopRight.style.visibility=visibilityTop;dom.shadowBottomRight.style.visibility=visibilityBottom;if(options.verticalScroll){dom.rightContainer.className=\"vis-panel vis-right vis-vertical-scroll\";dom.leftContainer.className=\"vis-panel vis-left vis-vertical-scroll\";dom.shadowTopRight.style.visibility=\"hidden\";dom.shadowBottomRight.style.visibility=\"hidden\";dom.shadowTopLeft.style.visibility=\"hidden\";dom.shadowBottomLeft.style.visibility=\"hidden\";dom.left.style.top=\"0px\";dom.right.style.top=\"0px\"}if(!options.verticalScroll||props.center.height<props.centerContainer.height){dom.left.style.top=offset+\"px\";dom.right.style.top=offset+\"px\";dom.rightContainer.className=dom.rightContainer.className.replace(new RegExp(\"(?:^|\\\\s)\"+\"vis-vertical-scroll\"+\"(?:\\\\s|$)\"),\" \");dom.leftContainer.className=dom.leftContainer.className.replace(new RegExp(\"(?:^|\\\\s)\"+\"vis-vertical-scroll\"+\"(?:\\\\s|$)\"),\" \");props.left.width=dom.leftContainer.clientWidth||-props.border.left;props.right.width=dom.rightContainer.clientWidth||-props.border.right;this._setDOM()}var contentsOverflow=props.center.height>props.centerContainer.height;this.hammer.get(\"pan\").set({direction:contentsOverflow?Hammer.DIRECTION_ALL:Hammer.DIRECTION_HORIZONTAL});this.components.forEach(function(component){resized=component.redraw()||resized});var MAX_REDRAW=5;if(resized){if(this.redrawCount<MAX_REDRAW){this.body.emitter.emit(\"_change\");return}else{console.log(\"WARNING: infinite loop in redraw?\")}}else{this.redrawCount=0}this.body.emitter.emit(\"changed\")};Core.prototype._setDOM=function(){var props=this.props;var dom=this.dom;props.leftContainer.width=props.left.width;props.rightContainer.width=props.right.width;var centerWidth=props.root.width-props.left.width-props.right.width-props.borderRootWidth;props.center.width=centerWidth;props.centerContainer.width=centerWidth;props.top.width=centerWidth;props.bottom.width=centerWidth;dom.background.style.height=props.background.height+\"px\";dom.backgroundVertical.style.height=props.background.height+\"px\";dom.backgroundHorizontal.style.height=props.centerContainer.height+\"px\";dom.centerContainer.style.height=props.centerContainer.height+\"px\";dom.leftContainer.style.height=props.leftContainer.height+\"px\";dom.rightContainer.style.height=props.rightContainer.height+\"px\";dom.background.style.width=props.background.width+\"px\";dom.backgroundVertical.style.width=props.centerContainer.width+\"px\";dom.backgroundHorizontal.style.width=props.background.width+\"px\";dom.centerContainer.style.width=props.center.width+\"px\";dom.top.style.width=props.top.width+\"px\";dom.bottom.style.width=props.bottom.width+\"px\";dom.background.style.left=\"0\";dom.background.style.top=\"0\";dom.backgroundVertical.style.left=props.left.width+props.border.left+\"px\";dom.backgroundVertical.style.top=\"0\";dom.backgroundHorizontal.style.left=\"0\";dom.backgroundHorizontal.style.top=props.top.height+\"px\";dom.centerContainer.style.left=props.left.width+\"px\";dom.centerContainer.style.top=props.top.height+\"px\";dom.leftContainer.style.left=\"0\";dom.leftContainer.style.top=props.top.height+\"px\";dom.rightContainer.style.left=props.left.width+props.center.width+\"px\";dom.rightContainer.style.top=props.top.height+\"px\";dom.top.style.left=props.left.width+\"px\";dom.top.style.top=\"0\";dom.bottom.style.left=props.left.width+\"px\";dom.bottom.style.top=props.top.height+props.centerContainer.height+\"px\";dom.center.style.left=\"0\";dom.left.style.left=\"0\";dom.right.style.left=\"0\"};Core.prototype.repaint=function(){throw new Error(\"Function repaint is deprecated. Use redraw instead.\")};Core.prototype.setCurrentTime=function(time){if(!this.currentTime){throw new Error(\"Option showCurrentTime must be true\")}this.currentTime.setCurrentTime(time)};Core.prototype.getCurrentTime=function(){if(!this.currentTime){throw new Error(\"Option showCurrentTime must be true\")}return this.currentTime.getCurrentTime()};Core.prototype._toTime=function(x){return DateUtil.toTime(this,x,this.props.center.width)};Core.prototype._toGlobalTime=function(x){return DateUtil.toTime(this,x,this.props.root.width)};Core.prototype._toScreen=function(time){return DateUtil.toScreen(this,time,this.props.center.width)};Core.prototype._toGlobalScreen=function(time){return DateUtil.toScreen(this,time,this.props.root.width)};Core.prototype._initAutoResize=function(){if(this.options.autoResize==true){this._startAutoResize()}else{this._stopAutoResize()}};Core.prototype._startAutoResize=function(){var me=this;this._stopAutoResize();this._onResize=function(){if(me.options.autoResize!=true){me._stopAutoResize();return}if(me.dom.root){if(me.dom.root.offsetWidth!=me.props.lastWidth||me.dom.root.offsetHeight!=me.props.lastHeight){me.props.lastWidth=me.dom.root.offsetWidth;me.props.lastHeight=me.dom.root.offsetHeight;me.props.scrollbarWidth=util.getScrollBarWidth();me.body.emitter.emit(\"_change\")}}};util.addEventListener(window,\"resize\",this._onResize);if(me.dom.root){me.props.lastWidth=me.dom.root.offsetWidth;me.props.lastHeight=me.dom.root.offsetHeight}this.watchTimer=setInterval(this._onResize,1e3)};Core.prototype._stopAutoResize=function(){if(this.watchTimer){clearInterval(this.watchTimer);this.watchTimer=undefined}if(this._onResize){util.removeEventListener(window,\"resize\",this._onResize);this._onResize=null}};Core.prototype._onTouch=function(event){this.touch.allowDragging=true;this.touch.initialScrollTop=this.props.scrollTop};Core.prototype._onPinch=function(event){this.touch.allowDragging=false};Core.prototype._onDrag=function(event){if(!event)return;if(!this.touch.allowDragging)return;var delta=event.deltaY;var oldScrollTop=this._getScrollTop();var newScrollTop=this._setScrollTop(this.touch.initialScrollTop+delta);if(this.options.verticalScroll){this.dom.left.parentNode.scrollTop=-this.props.scrollTop;this.dom.right.parentNode.scrollTop=-this.props.scrollTop}if(newScrollTop!=oldScrollTop){this.emit(\"verticalDrag\")}};Core.prototype._setScrollTop=function(scrollTop){this.props.scrollTop=scrollTop;this._updateScrollTop();return this.props.scrollTop};Core.prototype._updateScrollTop=function(){var scrollTopMin=Math.min(this.props.centerContainer.height-this.props.center.height,0);if(scrollTopMin!=this.props.scrollTopMin){if(this.options.orientation.item!=\"top\"){this.props.scrollTop+=scrollTopMin-this.props.scrollTopMin}this.props.scrollTopMin=scrollTopMin}if(this.props.scrollTop>0)this.props.scrollTop=0;if(this.props.scrollTop<scrollTopMin)this.props.scrollTop=scrollTopMin;if(this.options.verticalScroll){this.dom.left.parentNode.scrollTop=-this.props.scrollTop;this.dom.right.parentNode.scrollTop=-this.props.scrollTop}return this.props.scrollTop};Core.prototype._getScrollTop=function(){return this.props.scrollTop};Core.prototype._createConfigurator=function(){throw new Error(\"Cannot invoke abstract method _createConfigurator\")};module.exports=Core},function(module,exports,__webpack_require__){\"use strict\";var moment=__webpack_require__(9);var DateUtil=__webpack_require__(36);var util=__webpack_require__(2);function TimeStep(start,end,minimumStep,hiddenDates,options){this.moment=moment;this.current=this.moment();this._start=this.moment();this._end=this.moment();this.autoScale=true;this.scale=\"day\";this.step=1;this.setRange(start,end,minimumStep);this.switchedDay=false;this.switchedMonth=false;this.switchedYear=false;if(Array.isArray(hiddenDates)){this.hiddenDates=hiddenDates}else if(hiddenDates!=undefined){this.hiddenDates=[hiddenDates]}else{this.hiddenDates=[]}this.format=TimeStep.FORMAT;this.options=options?options:{}}TimeStep.FORMAT={minorLabels:{millisecond:\"SSS\",second:\"s\",minute:\"HH:mm\",hour:\"HH:mm\",weekday:\"ddd D\",day:\"D\",week:\"w\",month:\"MMM\",year:\"YYYY\"},majorLabels:{millisecond:\"HH:mm:ss\",second:\"D MMMM HH:mm\",minute:\"ddd D MMMM\",hour:\"ddd D MMMM\",weekday:\"MMMM YYYY\",day:\"MMMM YYYY\",week:\"MMMM YYYY\",month:\"YYYY\",year:\"\"}};TimeStep.prototype.setMoment=function(moment){this.moment=moment;this.current=this.moment(this.current.valueOf());this._start=this.moment(this._start.valueOf());this._end=this.moment(this._end.valueOf())};TimeStep.prototype.setFormat=function(format){var defaultFormat=util.deepExtend({},TimeStep.FORMAT);this.format=util.deepExtend(defaultFormat,format)};TimeStep.prototype.setRange=function(start,end,minimumStep){if(!(start instanceof Date)||!(end instanceof Date)){throw\"No legal start or end date in method setRange\"}this._start=start!=undefined?this.moment(start.valueOf()):new Date;this._end=end!=undefined?this.moment(end.valueOf()):new Date;if(this.autoScale){this.setMinimumStep(minimumStep)}};TimeStep.prototype.start=function(){this.current=this._start.clone();this.roundToMinor()};TimeStep.prototype.roundToMinor=function(){if(this.scale==\"week\"){this.current.weekday(0)}switch(this.scale){case\"year\":this.current.year(this.step*Math.floor(this.current.year()/this.step));this.current.month(0);case\"month\":this.current.date(1);case\"week\":case\"day\":case\"weekday\":this.current.hours(0);case\"hour\":this.current.minutes(0);case\"minute\":this.current.seconds(0);case\"second\":this.current.milliseconds(0)}if(this.step!=1){switch(this.scale){case\"millisecond\":this.current.subtract(this.current.milliseconds()%this.step,\"milliseconds\");break;case\"second\":this.current.subtract(this.current.seconds()%this.step,\"seconds\");break;case\"minute\":this.current.subtract(this.current.minutes()%this.step,\"minutes\");break;case\"hour\":this.current.subtract(this.current.hours()%this.step,\"hours\");break;case\"weekday\":case\"day\":this.current.subtract((this.current.date()-1)%this.step,\"day\");break;case\"week\":this.current.subtract(this.current.week()%this.step,\"week\");break;case\"month\":this.current.subtract(this.current.month()%this.step,\"month\");break;case\"year\":this.current.subtract(this.current.year()%this.step,\"year\");break;default:break}}};TimeStep.prototype.hasNext=function(){return this.current.valueOf()<=this._end.valueOf()};TimeStep.prototype.next=function(){var prev=this.current.valueOf();switch(this.scale){case\"millisecond\":this.current.add(this.step,\"millisecond\");break;case\"second\":this.current.add(this.step,\"second\");break;case\"minute\":this.current.add(this.step,\"minute\");break;case\"hour\":this.current.add(this.step,\"hour\");if(this.current.month()<6){this.current.subtract(this.current.hours()%this.step,\"hour\")}else{if(this.current.hours()%this.step!==0){this.current.add(this.step-this.current.hours()%this.step,\"hour\")}}break;case\"weekday\":case\"day\":this.current.add(this.step,\"day\");break;case\"week\":if(this.current.weekday()!==0){this.current.weekday(0);this.current.add(this.step,\"week\")}else if(this.options.showMajorLabels===false){this.current.add(this.step,\"week\")}else{var nextWeek=this.current.clone();nextWeek.add(1,\"week\");if(nextWeek.isSame(this.current,\"month\")){this.current.add(this.step,\"week\")}else{this.current.add(this.step,\"week\");this.current.date(1)}}break;case\"month\":this.current.add(this.step,\"month\");break;case\"year\":this.current.add(this.step,\"year\");break;default:break}if(this.step!=1){switch(this.scale){case\"millisecond\":if(this.current.milliseconds()>0&&this.current.milliseconds()<this.step)this.current.milliseconds(0);break;case\"second\":if(this.current.seconds()>0&&this.current.seconds()<this.step)this.current.seconds(0);break;case\"minute\":if(this.current.minutes()>0&&this.current.minutes()<this.step)this.current.minutes(0);break;case\"hour\":if(this.current.hours()>0&&this.current.hours()<this.step)this.current.hours(0);break;case\"weekday\":case\"day\":if(this.current.date()<this.step+1)this.current.date(1);break;case\"week\":if(this.current.week()<this.step)this.current.week(1);break;case\"month\":if(this.current.month()<this.step)this.current.month(0);break;case\"year\":break;default:break}}if(this.current.valueOf()==prev){this.current=this._end.clone()}this.switchedDay=false;this.switchedMonth=false;this.switchedYear=false;DateUtil.stepOverHiddenDates(this.moment,this,prev)};TimeStep.prototype.getCurrent=function(){return this.current};TimeStep.prototype.setScale=function(params){if(params&&typeof params.scale==\"string\"){this.scale=params.scale;this.step=params.step>0?params.step:1;this.autoScale=false}};TimeStep.prototype.setAutoScale=function(enable){this.autoScale=enable};TimeStep.prototype.setMinimumStep=function(minimumStep){if(minimumStep==undefined){return}var stepYear=1e3*60*60*24*30*12;var stepMonth=1e3*60*60*24*30;var stepDay=1e3*60*60*24;var stepHour=1e3*60*60;var stepMinute=1e3*60;var stepSecond=1e3;var stepMillisecond=1;if(stepYear*1e3>minimumStep){this.scale=\"year\";this.step=1e3}if(stepYear*500>minimumStep){this.scale=\"year\";this.step=500}if(stepYear*100>minimumStep){this.scale=\"year\";this.step=100}if(stepYear*50>minimumStep){this.scale=\"year\";this.step=50}if(stepYear*10>minimumStep){this.scale=\"year\";this.step=10}if(stepYear*5>minimumStep){this.scale=\"year\";this.step=5}if(stepYear>minimumStep){this.scale=\"year\";this.step=1}if(stepMonth*3>minimumStep){this.scale=\"month\";this.step=3}if(stepMonth>minimumStep){this.scale=\"month\";this.step=1}if(stepDay*5>minimumStep){this.scale=\"day\";this.step=5}if(stepDay*2>minimumStep){this.scale=\"day\";this.step=2}if(stepDay>minimumStep){this.scale=\"day\";this.step=1}if(stepDay/2>minimumStep){this.scale=\"weekday\";this.step=1}if(stepHour*4>minimumStep){this.scale=\"hour\";this.step=4}if(stepHour>minimumStep){this.scale=\"hour\";this.step=1}if(stepMinute*15>minimumStep){this.scale=\"minute\";this.step=15}if(stepMinute*10>minimumStep){this.scale=\"minute\";this.step=10}if(stepMinute*5>minimumStep){this.scale=\"minute\";this.step=5}if(stepMinute>minimumStep){this.scale=\"minute\";this.step=1}if(stepSecond*15>minimumStep){this.scale=\"second\";this.step=15}if(stepSecond*10>minimumStep){this.scale=\"second\";this.step=10}if(stepSecond*5>minimumStep){this.scale=\"second\";this.step=5}if(stepSecond>minimumStep){this.scale=\"second\";this.step=1}if(stepMillisecond*200>minimumStep){this.scale=\"millisecond\";this.step=200}if(stepMillisecond*100>minimumStep){this.scale=\"millisecond\";this.step=100}if(stepMillisecond*50>minimumStep){this.scale=\"millisecond\";this.step=50}if(stepMillisecond*10>minimumStep){this.scale=\"millisecond\";this.step=10}if(stepMillisecond*5>minimumStep){this.scale=\"millisecond\";this.step=5}if(stepMillisecond>minimumStep){this.scale=\"millisecond\";this.step=1}};TimeStep.snap=function(date,scale,step){var clone=moment(date);if(scale==\"year\"){var year=clone.year()+Math.round(clone.month()/12);clone.year(Math.round(year/step)*step);clone.month(0);clone.date(0);clone.hours(0);clone.minutes(0);clone.seconds(0);clone.milliseconds(0)}else if(scale==\"month\"){if(clone.date()>15){clone.date(1);clone.add(1,\"month\")}else{clone.date(1)}clone.hours(0);clone.minutes(0);clone.seconds(0);clone.milliseconds(0)}else if(scale==\"week\"){if(clone.weekday()>2){clone.weekday(0);clone.add(1,\"week\")}else{clone.weekday(0)}clone.hours(0);clone.minutes(0);clone.seconds(0);clone.milliseconds(0)}else if(scale==\"day\"){switch(step){case 5:case 2:clone.hours(Math.round(clone.hours()/24)*24);break;default:clone.hours(Math.round(clone.hours()/12)*12);break}clone.minutes(0);clone.seconds(0);clone.milliseconds(0)}else if(scale==\"weekday\"){switch(step){case 5:case 2:clone.hours(Math.round(clone.hours()/12)*12);break;default:clone.hours(Math.round(clone.hours()/6)*6);break}clone.minutes(0);clone.seconds(0);clone.milliseconds(0)}else if(scale==\"hour\"){switch(step){case 4:clone.minutes(Math.round(clone.minutes()/60)*60);break;default:clone.minutes(Math.round(clone.minutes()/30)*30);break}clone.seconds(0);clone.milliseconds(0)}else if(scale==\"minute\"){switch(step){case 15:case 10:clone.minutes(Math.round(clone.minutes()/5)*5);clone.seconds(0);break;case 5:clone.seconds(Math.round(clone.seconds()/60)*60);break;default:clone.seconds(Math.round(clone.seconds()/30)*30);break}clone.milliseconds(0)}else if(scale==\"second\"){switch(step){case 15:case 10:clone.seconds(Math.round(clone.seconds()/5)*5);clone.milliseconds(0);break;case 5:clone.milliseconds(Math.round(clone.milliseconds()/1e3)*1e3);break;default:clone.milliseconds(Math.round(clone.milliseconds()/500)*500);break}}else if(scale==\"millisecond\"){var _step=step>5?step/2:1;clone.milliseconds(Math.round(clone.milliseconds()/_step)*_step)}return clone};TimeStep.prototype.isMajor=function(){if(this.switchedYear==true){switch(this.scale){case\"year\":case\"month\":case\"week\":case\"weekday\":case\"day\":case\"hour\":case\"minute\":case\"second\":case\"millisecond\":return true;default:return false}}else if(this.switchedMonth==true){switch(this.scale){case\"week\":case\"weekday\":case\"day\":case\"hour\":case\"minute\":case\"second\":case\"millisecond\":return true;default:return false}}else if(this.switchedDay==true){switch(this.scale){case\"millisecond\":case\"second\":case\"minute\":case\"hour\":return true;default:return false}}var date=this.moment(this.current);switch(this.scale){case\"millisecond\":return date.milliseconds()==0;case\"second\":return date.seconds()==0;case\"minute\":return date.hours()==0&&date.minutes()==0;case\"hour\":return date.hours()==0;case\"weekday\":case\"day\":return date.date()==1;case\"week\":return date.date()==1;case\"month\":return date.month()==0;case\"year\":return false;default:return false}};TimeStep.prototype.getLabelMinor=function(date){if(date==undefined){date=this.current}if(date instanceof Date){date=this.moment(date)}if(typeof this.format.minorLabels===\"function\"){return this.format.minorLabels(date,this.scale,this.step)}var format=this.format.minorLabels[this.scale];switch(this.scale){case\"week\":if(this.isMajor()&&date.weekday()!==0){return\"\"}default:return format&&format.length>0?this.moment(date).format(format):\"\"}};TimeStep.prototype.getLabelMajor=function(date){if(date==undefined){date=this.current}if(date instanceof Date){date=this.moment(date)}if(typeof this.format.majorLabels===\"function\"){return this.format.majorLabels(date,this.scale,this.step)}var format=this.format.majorLabels[this.scale];return format&&format.length>0?this.moment(date).format(format):\"\"};TimeStep.prototype.getClassName=function(){var _moment=this.moment;var m=this.moment(this.current);var current=m.locale?m.locale(\"en\"):m.lang(\"en\");var step=this.step;var classNames=[];function even(value){return value/step%2==0?\" vis-even\":\" vis-odd\"}function today(date){if(date.isSame(new Date,\"day\")){return\" vis-today\"}if(date.isSame(_moment().add(1,\"day\"),\"day\")){return\" vis-tomorrow\"}if(date.isSame(_moment().add(-1,\"day\"),\"day\")){return\" vis-yesterday\"}return\"\"}function currentWeek(date){return date.isSame(new Date,\"week\")?\" vis-current-week\":\"\"}function currentMonth(date){return date.isSame(new Date,\"month\")?\" vis-current-month\":\"\"}function currentYear(date){return date.isSame(new Date,\"year\")?\" vis-current-year\":\"\"}switch(this.scale){case\"millisecond\":classNames.push(today(current));classNames.push(even(current.milliseconds()));break;case\"second\":classNames.push(today(current));classNames.push(even(current.seconds()));break;case\"minute\":classNames.push(today(current));classNames.push(even(current.minutes()));break;case\"hour\":classNames.push(\"vis-h\"+current.hours()+(this.step==4?\"-h\"+(current.hours()+4):\"\"));classNames.push(today(current));classNames.push(even(current.hours()));break;case\"weekday\":classNames.push(\"vis-\"+current.format(\"dddd\").toLowerCase());classNames.push(today(current));classNames.push(currentWeek(current));classNames.push(even(current.date()));break;case\"day\":classNames.push(\"vis-day\"+current.date());classNames.push(\"vis-\"+current.format(\"MMMM\").toLowerCase());classNames.push(today(current));classNames.push(currentMonth(current));classNames.push(this.step<=2?today(current):\"\");classNames.push(this.step<=2?\"vis-\"+current.format(\"dddd\").toLowerCase():\"\");classNames.push(even(current.date()-1));break;case\"week\":classNames.push(\"vis-week\"+current.format(\"w\"));classNames.push(currentWeek(current));classNames.push(even(current.week()));break;case\"month\":classNames.push(\"vis-\"+current.format(\"MMMM\").toLowerCase());classNames.push(currentMonth(current));classNames.push(even(current.month()));break;case\"year\":classNames.push(\"vis-year\"+current.year());classNames.push(currentYear(current));classNames.push(even(current.year()));break}return classNames.filter(String).join(\" \")};module.exports=TimeStep},function(module,exports,__webpack_require__){\"use strict\";var util=__webpack_require__(2);var Component=__webpack_require__(16);var moment=__webpack_require__(9);var locales=__webpack_require__(98);function CurrentTime(body,options){this.body=body;this.defaultOptions={rtl:false,showCurrentTime:true,moment:moment,locales:locales,locale:\"en\"};this.options=util.extend({},this.defaultOptions);this.offset=0;this._create();this.setOptions(options)}CurrentTime.prototype=new Component;CurrentTime.prototype._create=function(){var bar=document.createElement(\"div\");bar.className=\"vis-current-time\";bar.style.position=\"absolute\";bar.style.top=\"0px\";bar.style.height=\"100%\";this.bar=bar};CurrentTime.prototype.destroy=function(){this.options.showCurrentTime=false;this.redraw();this.body=null};CurrentTime.prototype.setOptions=function(options){if(options){util.selectiveExtend([\"rtl\",\"showCurrentTime\",\"moment\",\"locale\",\"locales\"],this.options,options)}};CurrentTime.prototype.redraw=function(){if(this.options.showCurrentTime){var parent=this.body.dom.backgroundVertical;if(this.bar.parentNode!=parent){if(this.bar.parentNode){this.bar.parentNode.removeChild(this.bar)}parent.appendChild(this.bar);this.start()}var now=this.options.moment((new Date).valueOf()+this.offset);var x=this.body.util.toScreen(now);var locale=this.options.locales[this.options.locale];if(!locale){if(!this.warned){console.log(\"WARNING: options.locales['\"+this.options.locale+\"'] not found. See http://visjs.org/docs/timeline/#Localization\");this.warned=true}locale=this.options.locales[\"en\"]}var title=locale.current+\" \"+locale.time+\": \"+now.format(\"dddd, MMMM Do YYYY, H:mm:ss\");title=title.charAt(0).toUpperCase()+title.substring(1);if(this.options.rtl){this.bar.style.right=x+\"px\"}else{this.bar.style.left=x+\"px\"}this.bar.title=title}else{if(this.bar.parentNode){this.bar.parentNode.removeChild(this.bar)}this.stop()}return false};CurrentTime.prototype.start=function(){var me=this;function update(){me.stop();var scale=me.body.range.conversion(me.body.domProps.center.width).scale;var interval=1/scale/10;if(interval<30)interval=30;if(interval>1e3)interval=1e3;me.redraw();me.body.emitter.emit(\"currentTimeTick\");me.currentTimeTimer=setTimeout(update,interval)}update()};CurrentTime.prototype.stop=function(){if(this.currentTimeTimer!==undefined){clearTimeout(this.currentTimeTimer);delete this.currentTimeTimer}};CurrentTime.prototype.setCurrentTime=function(time){var t=util.convert(time,\"Date\").valueOf();var now=(new Date).valueOf();this.offset=t-now;this.redraw()};CurrentTime.prototype.getCurrentTime=function(){return new Date((new Date).valueOf()+this.offset)};module.exports=CurrentTime},function(module,exports,__webpack_require__){\"use strict\";var _keys=__webpack_require__(8);var _keys2=_interopRequireDefault(_keys);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var stack=__webpack_require__(100);function Group(groupId,data,itemSet){this.groupId=groupId;this.subgroups={};this.subgroupStack={};this.subgroupStackAll=false;this.doInnerStack=false;this.subgroupIndex=0;this.subgroupOrderer=data&&data.subgroupOrder;this.itemSet=itemSet;this.isVisible=null;this.stackDirty=true;if(data&&data.nestedGroups){this.nestedGroups=data.nestedGroups;if(data.showNested==false){this.showNested=false}else{this.showNested=true}}if(data&&data.subgroupStack){if(typeof data.subgroupStack===\"boolean\"){this.doInnerStack=data.subgroupStack;this.subgroupStackAll=data.subgroupStack}else{for(var key in data.subgroupStack){this.subgroupStack[key]=data.subgroupStack[key];this.doInnerStack=this.doInnerStack||data.subgroupStack[key]}}}this.nestedInGroup=null;this.dom={};this.props={label:{width:0,height:0}};this.className=null;this.items={};this.visibleItems=[];this.itemsInRange=[];this.orderedItems={byStart:[],byEnd:[]};this.checkRangedItems=false;var me=this;this.itemSet.body.emitter.on(\"checkRangedItems\",function(){me.checkRangedItems=true});this._create();this.setData(data)}Group.prototype._create=function(){var label=document.createElement(\"div\");if(this.itemSet.options.groupEditable.order){label.className=\"vis-label draggable\"}else{label.className=\"vis-label\"}this.dom.label=label;var inner=document.createElement(\"div\");inner.className=\"vis-inner\";label.appendChild(inner);this.dom.inner=inner;var foreground=document.createElement(\"div\");foreground.className=\"vis-group\";foreground[\"timeline-group\"]=this;this.dom.foreground=foreground;this.dom.background=document.createElement(\"div\");this.dom.background.className=\"vis-group\";this.dom.axis=document.createElement(\"div\");this.dom.axis.className=\"vis-group\";this.dom.marker=document.createElement(\"div\");this.dom.marker.style.visibility=\"hidden\";this.dom.marker.style.position=\"absolute\";this.dom.marker.innerHTML=\"\";this.dom.background.appendChild(this.dom.marker)};Group.prototype.setData=function(data){var content;var templateFunction;if(this.itemSet.options&&this.itemSet.options.groupTemplate){templateFunction=this.itemSet.options.groupTemplate.bind(this);content=templateFunction(data,this.dom.inner)}else{content=data&&data.content}if(content instanceof Element){this.dom.inner.appendChild(content);while(this.dom.inner.firstChild){this.dom.inner.removeChild(this.dom.inner.firstChild)}this.dom.inner.appendChild(content)}else if(content instanceof Object){templateFunction(data,this.dom.inner)}else if(content!==undefined&&content!==null){this.dom.inner.innerHTML=content}else{this.dom.inner.innerHTML=this.groupId||\"\"}this.dom.label.title=data&&data.title||\"\";if(!this.dom.inner.firstChild){util.addClassName(this.dom.inner,\"vis-hidden\")}else{util.removeClassName(this.dom.inner,\"vis-hidden\")}if(data&&data.nestedGroups){if(!this.nestedGroups||this.nestedGroups!=data.nestedGroups){this.nestedGroups=data.nestedGroups}if(data.showNested!==undefined||this.showNested===undefined){if(data.showNested==false){this.showNested=false}else{this.showNested=true}}util.addClassName(this.dom.label,\"vis-nesting-group\");var collapsedDirClassName=this.itemSet.options.rtl?\"collapsed-rtl\":\"collapsed\";if(this.showNested){util.removeClassName(this.dom.label,collapsedDirClassName);util.addClassName(this.dom.label,\"expanded\")}else{util.removeClassName(this.dom.label,\"expanded\");util.addClassName(this.dom.label,collapsedDirClassName)}}else if(this.nestedGroups){this.nestedGroups=null;collapsedDirClassName=this.itemSet.options.rtl?\"collapsed-rtl\":\"collapsed\";util.removeClassName(this.dom.label,collapsedDirClassName);util.removeClassName(this.dom.label,\"expanded\");util.removeClassName(this.dom.label,\"vis-nesting-group\")}if(data&&data.nestedInGroup){util.addClassName(this.dom.label,\"vis-nested-group\");if(this.itemSet.options&&this.itemSet.options.rtl){this.dom.inner.style.paddingRight=\"30px\"}else{\nthis.dom.inner.style.paddingLeft=\"30px\"}}var className=data&&data.className||null;if(className!=this.className){if(this.className){util.removeClassName(this.dom.label,this.className);util.removeClassName(this.dom.foreground,this.className);util.removeClassName(this.dom.background,this.className);util.removeClassName(this.dom.axis,this.className)}util.addClassName(this.dom.label,className);util.addClassName(this.dom.foreground,className);util.addClassName(this.dom.background,className);util.addClassName(this.dom.axis,className);this.className=className}if(this.style){util.removeCssText(this.dom.label,this.style);this.style=null}if(data&&data.style){util.addCssText(this.dom.label,data.style);this.style=data.style}};Group.prototype.getLabelWidth=function(){return this.props.label.width};Group.prototype._didMarkerHeightChange=function(){var markerHeight=this.dom.marker.clientHeight;if(markerHeight!=this.lastMarkerHeight){this.lastMarkerHeight=markerHeight;var redrawQueue={};var redrawQueueLength=0;util.forEach(this.items,function(item,key){item.dirty=true;if(item.displayed){var returnQueue=true;redrawQueue[key]=item.redraw(returnQueue);redrawQueueLength=redrawQueue[key].length}});var needRedraw=redrawQueueLength>0;if(needRedraw){for(var i=0;i<redrawQueueLength;i++){util.forEach(redrawQueue,function(fns){fns[i]()})}}return true}};Group.prototype._calculateGroupSizeAndPosition=function(){var offsetTop=this.dom.foreground.offsetTop;var offsetLeft=this.dom.foreground.offsetLeft;var offsetWidth=this.dom.foreground.offsetWidth;this.top=offsetTop;this.right=offsetLeft;this.width=offsetWidth};Group.prototype._redrawItems=function(forceRestack,lastIsVisible,margin,range){var restack=forceRestack||this.stackDirty||this.isVisible&&!lastIsVisible;if(restack){var visibleSubgroups={};var subgroup=null;if(typeof this.itemSet.options.order===\"function\"){var me=this;var limitSize=false;var redrawQueue={};var redrawQueueLength=0;util.forEach(this.items,function(item,key){if(!item.displayed){var returnQueue=true;redrawQueue[key]=item.redraw(returnQueue);redrawQueueLength=redrawQueue[key].length;me.visibleItems.push(item)}});var needRedraw=redrawQueueLength>0;if(needRedraw){for(var i=0;i<redrawQueueLength;i++){util.forEach(redrawQueue,function(fns){fns[i]()})}}util.forEach(this.items,function(item){item.repositionX(limitSize)});if(this.doInnerStack&&this.itemSet.options.stackSubgroups){for(subgroup in this.subgroups){visibleSubgroups[subgroup]=this.subgroups[subgroup].items.slice().sort(function(a,b){return me.itemSet.options.order(a.data,b.data)})}stack.stackSubgroupsWithInnerStack(visibleSubgroups,margin,this.subgroups)}else{var customOrderedItems=this.orderedItems.byStart.slice().sort(function(a,b){return me.itemSet.options.order(a.data,b.data)});stack.stack(customOrderedItems,margin,true)}this.visibleItems=this._updateItemsInRange(this.orderedItems,this.visibleItems,range)}else{this.visibleItems=this._updateItemsInRange(this.orderedItems,this.visibleItems,range);if(this.itemSet.options.stack){if(this.doInnerStack&&this.itemSet.options.stackSubgroups){for(subgroup in this.subgroups){visibleSubgroups[subgroup]=this.subgroups[subgroup].items}stack.stackSubgroupsWithInnerStack(visibleSubgroups,margin,this.subgroups)}else{stack.stack(this.visibleItems,margin,true)}}else{stack.nostack(this.visibleItems,margin,this.subgroups,this.itemSet.options.stackSubgroups)}}this.stackDirty=false}};Group.prototype._didResize=function(resized,height){resized=util.updateProperty(this,\"height\",height)||resized;var labelWidth=this.dom.inner.clientWidth;var labelHeight=this.dom.inner.clientHeight;resized=util.updateProperty(this.props.label,\"width\",labelWidth)||resized;resized=util.updateProperty(this.props.label,\"height\",labelHeight)||resized;return resized};Group.prototype._applyGroupHeight=function(height){this.dom.background.style.height=height+\"px\";this.dom.foreground.style.height=height+\"px\";this.dom.label.style.height=height+\"px\"};Group.prototype._updateItemsVerticalPosition=function(margin){for(var i=0,ii=this.visibleItems.length;i<ii;i++){var item=this.visibleItems[i];item.repositionY(margin);if(!this.isVisible&&this.groupId!=\"__background__\"){if(item.displayed)item.hide()}}};Group.prototype.redraw=function(range,margin,forceRestack,returnQueue){var resized=false;var lastIsVisible=this.isVisible;var height;var queue=[function(){forceRestack=this._didMarkerHeightChange.bind(this)}.bind(this),this._updateSubGroupHeights.bind(this,margin),this._calculateGroupSizeAndPosition.bind(this),function(){this.isVisible=this._isGroupVisible.bind(this)(range,margin)}.bind(this),function(){this._redrawItems.bind(this)(forceRestack,lastIsVisible,margin,range)}.bind(this),this._updateSubgroupsSizes.bind(this),function(){height=this._calculateHeight.bind(this)(margin)}.bind(this),this._calculateGroupSizeAndPosition.bind(this),function(){resized=this._didResize.bind(this)(resized,height)}.bind(this),function(){this._applyGroupHeight.bind(this)(height)}.bind(this),function(){this._updateItemsVerticalPosition.bind(this)(margin)}.bind(this),function(){if(!this.isVisible&&this.height){resized=false}return resized}];if(returnQueue){return queue}else{var result;queue.forEach(function(fn){result=fn()});return result}};Group.prototype._updateSubGroupHeights=function(margin){if((0,_keys2[\"default\"])(this.subgroups).length>0){var me=this;this.resetSubgroups();util.forEach(this.visibleItems,function(item){if(item.data.subgroup!==undefined){me.subgroups[item.data.subgroup].height=Math.max(me.subgroups[item.data.subgroup].height,item.height+margin.item.vertical);me.subgroups[item.data.subgroup].visible=true}})}};Group.prototype._isGroupVisible=function(range,margin){return this.top<=range.body.domProps.centerContainer.height-range.body.domProps.scrollTop+margin.axis&&this.top+this.height+margin.axis>=-range.body.domProps.scrollTop};Group.prototype._calculateHeight=function(margin){var height;var itemsInRange=this.visibleItems;if(itemsInRange.length>0){var min=itemsInRange[0].top;var max=itemsInRange[0].top+itemsInRange[0].height;util.forEach(itemsInRange,function(item){min=Math.min(min,item.top);max=Math.max(max,item.top+item.height)});if(min>margin.axis){var offset=min-margin.axis;max-=offset;util.forEach(itemsInRange,function(item){item.top-=offset})}height=max+margin.item.vertical/2}else{height=0}height=Math.max(height,this.props.label.height);return height};Group.prototype.show=function(){if(!this.dom.label.parentNode){this.itemSet.dom.labelSet.appendChild(this.dom.label)}if(!this.dom.foreground.parentNode){this.itemSet.dom.foreground.appendChild(this.dom.foreground)}if(!this.dom.background.parentNode){this.itemSet.dom.background.appendChild(this.dom.background)}if(!this.dom.axis.parentNode){this.itemSet.dom.axis.appendChild(this.dom.axis)}};Group.prototype.hide=function(){var label=this.dom.label;if(label.parentNode){label.parentNode.removeChild(label)}var foreground=this.dom.foreground;if(foreground.parentNode){foreground.parentNode.removeChild(foreground)}var background=this.dom.background;if(background.parentNode){background.parentNode.removeChild(background)}var axis=this.dom.axis;if(axis.parentNode){axis.parentNode.removeChild(axis)}};Group.prototype.add=function(item){this.items[item.id]=item;item.setParent(this);this.stackDirty=true;if(item.data.subgroup!==undefined){this._addToSubgroup(item);this.orderSubgroups()}if(this.visibleItems.indexOf(item)==-1){var range=this.itemSet.body.range;this._checkIfVisible(item,this.visibleItems,range)}};Group.prototype._addToSubgroup=function(item,subgroupId){subgroupId=subgroupId||item.data.subgroup;if(subgroupId!=undefined&&this.subgroups[subgroupId]===undefined){this.subgroups[subgroupId]={height:0,top:0,start:item.data.start,end:item.data.end||item.data.start,visible:false,index:this.subgroupIndex,items:[],stack:this.subgroupStackAll||this.subgroupStack[subgroupId]||false};this.subgroupIndex++}if(new Date(item.data.start)<new Date(this.subgroups[subgroupId].start)){this.subgroups[subgroupId].start=item.data.start}var itemEnd=item.data.end||item.data.start;if(new Date(itemEnd)>new Date(this.subgroups[subgroupId].end)){this.subgroups[subgroupId].end=itemEnd}this.subgroups[subgroupId].items.push(item)};Group.prototype._updateSubgroupsSizes=function(){var me=this;if(me.subgroups){for(var subgroup in me.subgroups){var initialEnd=me.subgroups[subgroup].items[0].data.end||me.subgroups[subgroup].items[0].data.start;var newStart=me.subgroups[subgroup].items[0].data.start;var newEnd=initialEnd-1;me.subgroups[subgroup].items.forEach(function(item){if(new Date(item.data.start)<new Date(newStart)){newStart=item.data.start}var itemEnd=item.data.end||item.data.start;if(new Date(itemEnd)>new Date(newEnd)){newEnd=itemEnd}});me.subgroups[subgroup].start=newStart;me.subgroups[subgroup].end=new Date(newEnd-1)}}};Group.prototype.orderSubgroups=function(){if(this.subgroupOrderer!==undefined){var sortArray=[];var subgroup;if(typeof this.subgroupOrderer==\"string\"){for(subgroup in this.subgroups){sortArray.push({subgroup:subgroup,sortField:this.subgroups[subgroup].items[0].data[this.subgroupOrderer]})}sortArray.sort(function(a,b){return a.sortField-b.sortField})}else if(typeof this.subgroupOrderer==\"function\"){for(subgroup in this.subgroups){sortArray.push(this.subgroups[subgroup].items[0].data)}sortArray.sort(this.subgroupOrderer)}if(sortArray.length>0){for(var i=0;i<sortArray.length;i++){this.subgroups[sortArray[i].subgroup].index=i}}}};Group.prototype.resetSubgroups=function(){for(var subgroup in this.subgroups){if(this.subgroups.hasOwnProperty(subgroup)){this.subgroups[subgroup].visible=false;this.subgroups[subgroup].height=0}}};Group.prototype.remove=function(item){delete this.items[item.id];item.setParent(null);this.stackDirty=true;var index=this.visibleItems.indexOf(item);if(index!=-1)this.visibleItems.splice(index,1);if(item.data.subgroup!==undefined){this._removeFromSubgroup(item);this.orderSubgroups()}};Group.prototype._removeFromSubgroup=function(item,subgroupId){subgroupId=subgroupId||item.data.subgroup;if(subgroupId!=undefined){var subgroup=this.subgroups[subgroupId];if(subgroup){var itemIndex=subgroup.items.indexOf(item);if(itemIndex>=0){subgroup.items.splice(itemIndex,1);if(!subgroup.items.length){delete this.subgroups[subgroupId]}else{this._updateSubgroupsSizes()}}}}};Group.prototype.removeFromDataSet=function(item){this.itemSet.removeItem(item.id)};Group.prototype.order=function(){var array=util.toArray(this.items);var startArray=[];var endArray=[];for(var i=0;i<array.length;i++){if(array[i].data.end!==undefined){endArray.push(array[i])}startArray.push(array[i])}this.orderedItems={byStart:startArray,byEnd:endArray};stack.orderByStart(this.orderedItems.byStart);stack.orderByEnd(this.orderedItems.byEnd)};Group.prototype._updateItemsInRange=function(orderedItems,oldVisibleItems,range){var visibleItems=[];var visibleItemsLookup={};var interval=(range.end-range.start)/4;var lowerBound=range.start-interval;var upperBound=range.end+interval;var searchFunction=function searchFunction(value){if(value<lowerBound){return-1}else if(value<=upperBound){return 0}else{return 1}};if(oldVisibleItems.length>0){for(var i=0;i<oldVisibleItems.length;i++){this._checkIfVisibleWithReference(oldVisibleItems[i],visibleItems,visibleItemsLookup,range)}}var initialPosByStart=util.binarySearchCustom(orderedItems.byStart,searchFunction,\"data\",\"start\");this._traceVisible(initialPosByStart,orderedItems.byStart,visibleItems,visibleItemsLookup,function(item){return item.data.start<lowerBound||item.data.start>upperBound});if(this.checkRangedItems==true){this.checkRangedItems=false;for(i=0;i<orderedItems.byEnd.length;i++){this._checkIfVisibleWithReference(orderedItems.byEnd[i],visibleItems,visibleItemsLookup,range)}}else{var initialPosByEnd=util.binarySearchCustom(orderedItems.byEnd,searchFunction,\"data\",\"end\");this._traceVisible(initialPosByEnd,orderedItems.byEnd,visibleItems,visibleItemsLookup,function(item){return item.data.end<lowerBound||item.data.end>upperBound})}var redrawQueue={};var redrawQueueLength=0;for(i=0;i<visibleItems.length;i++){var item=visibleItems[i];if(!item.displayed){var returnQueue=true;redrawQueue[i]=item.redraw(returnQueue);redrawQueueLength=redrawQueue[i].length}}var needRedraw=redrawQueueLength>0;if(needRedraw){for(var j=0;j<redrawQueueLength;j++){util.forEach(redrawQueue,function(fns){fns[j]()})}}for(i=0;i<visibleItems.length;i++){visibleItems[i].repositionX()}return visibleItems};Group.prototype._traceVisible=function(initialPos,items,visibleItems,visibleItemsLookup,breakCondition){if(initialPos!=-1){var i,item;for(i=initialPos;i>=0;i--){item=items[i];if(breakCondition(item)){break}else{if(visibleItemsLookup[item.id]===undefined){visibleItemsLookup[item.id]=true;visibleItems.push(item)}}}for(i=initialPos+1;i<items.length;i++){item=items[i];if(breakCondition(item)){break}else{if(visibleItemsLookup[item.id]===undefined){visibleItemsLookup[item.id]=true;visibleItems.push(item)}}}}};Group.prototype._checkIfVisible=function(item,visibleItems,range){if(item.isVisible(range)){if(!item.displayed)item.show();item.repositionX();visibleItems.push(item)}else{if(item.displayed)item.hide()}};Group.prototype._checkIfVisibleWithReference=function(item,visibleItems,visibleItemsLookup,range){if(item.isVisible(range)){if(visibleItemsLookup[item.id]===undefined){visibleItemsLookup[item.id]=true;visibleItems.push(item)}}else{if(item.displayed)item.hide()}};Group.prototype.changeSubgroup=function(item,oldSubgroup,newSubgroup){this._removeFromSubgroup(item,oldSubgroup);this._addToSubgroup(item,newSubgroup);this.orderSubgroups()};module.exports=Group},function(module,exports,__webpack_require__){\"use strict\";var _create=__webpack_require__(29);var _create2=_interopRequireDefault(_create);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Group=__webpack_require__(68);function BackgroundGroup(groupId,data,itemSet){Group.call(this,groupId,data,itemSet);this.width=0;this.height=0;this.top=0;this.left=0}BackgroundGroup.prototype=(0,_create2[\"default\"])(Group.prototype);BackgroundGroup.prototype.redraw=function(range,margin,forceRestack){var resized=false;this.visibleItems=this._updateItemsInRange(this.orderedItems,this.visibleItems,range);this.width=this.dom.background.offsetWidth;this.dom.background.style.height=\"0\";for(var i=0,ii=this.visibleItems.length;i<ii;i++){var item=this.visibleItems[i];item.repositionY(margin)}return resized};BackgroundGroup.prototype.show=function(){if(!this.dom.background.parentNode){this.itemSet.dom.background.appendChild(this.dom.background)}};module.exports=BackgroundGroup},function(module,exports,__webpack_require__){\"use strict\";var Item=__webpack_require__(38);function RangeItem(data,conversion,options){this.props={content:{width:0}};this.overflow=false;this.options=options;if(data){if(data.start==undefined){throw new Error('Property \"start\" missing in item '+data.id)}if(data.end==undefined){throw new Error('Property \"end\" missing in item '+data.id)}}Item.call(this,data,conversion,options)}RangeItem.prototype=new Item(null,null,null);RangeItem.prototype.baseClassName=\"vis-item vis-range\";RangeItem.prototype.isVisible=function(range){return this.data.start<range.end&&this.data.end>range.start};RangeItem.prototype._createDomElement=function(){if(!this.dom){this.dom={};this.dom.box=document.createElement(\"div\");this.dom.frame=document.createElement(\"div\");this.dom.frame.className=\"vis-item-overflow\";this.dom.box.appendChild(this.dom.frame);this.dom.visibleFrame=document.createElement(\"div\");this.dom.visibleFrame.className=\"vis-item-visible-frame\";this.dom.box.appendChild(this.dom.visibleFrame);this.dom.content=document.createElement(\"div\");this.dom.content.className=\"vis-item-content\";this.dom.frame.appendChild(this.dom.content);this.dom.box[\"timeline-item\"]=this;this.dirty=true}};RangeItem.prototype._appendDomElement=function(){if(!this.parent){throw new Error(\"Cannot redraw item: no parent attached\")}if(!this.dom.box.parentNode){var foreground=this.parent.dom.foreground;if(!foreground){throw new Error(\"Cannot redraw item: parent has no foreground container element\")}foreground.appendChild(this.dom.box)}this.displayed=true};RangeItem.prototype._updateDirtyDomComponents=function(){if(this.dirty){this._updateContents(this.dom.content);this._updateDataAttributes(this.dom.box);this._updateStyle(this.dom.box);var editable=this.editable.updateTime||this.editable.updateGroup;var className=(this.data.className?\" \"+this.data.className:\"\")+(this.selected?\" vis-selected\":\"\")+(editable?\" vis-editable\":\" vis-readonly\");this.dom.box.className=this.baseClassName+className;this.dom.content.style.maxWidth=\"none\"}};RangeItem.prototype._getDomComponentsSizes=function(){this.overflow=window.getComputedStyle(this.dom.frame).overflow!==\"hidden\";return{content:{width:this.dom.content.offsetWidth},box:{height:this.dom.box.offsetHeight}}};RangeItem.prototype._updateDomComponentsSizes=function(sizes){this.props.content.width=sizes.content.width;this.height=sizes.box.height;this.dom.content.style.maxWidth=\"\";this.dirty=false};RangeItem.prototype._repaintDomAdditionals=function(){this._repaintOnItemUpdateTimeTooltip(this.dom.box);this._repaintDeleteButton(this.dom.box);this._repaintDragCenter();this._repaintDragLeft();this._repaintDragRight()};RangeItem.prototype.redraw=function(returnQueue){var sizes;var queue=[this._createDomElement.bind(this),this._appendDomElement.bind(this),this._updateDirtyDomComponents.bind(this),function(){if(this.dirty){sizes=this._getDomComponentsSizes.bind(this)()}}.bind(this),function(){if(this.dirty){this._updateDomComponentsSizes.bind(this)(sizes)}}.bind(this),this._repaintDomAdditionals.bind(this)];if(returnQueue){return queue}else{var result;queue.forEach(function(fn){result=fn()});return result}};RangeItem.prototype.show=function(){if(!this.displayed){this.redraw()}};RangeItem.prototype.hide=function(){if(this.displayed){var box=this.dom.box;if(box.parentNode){box.parentNode.removeChild(box)}this.displayed=false}};RangeItem.prototype.repositionX=function(limitSize){var parentWidth=this.parent.width;var start=this.conversion.toScreen(this.data.start);var end=this.conversion.toScreen(this.data.end);var align=this.data.align===undefined?this.options.align:this.data.align;var contentStartPosition;var contentWidth;if(this.data.limitSize!==false&&(limitSize===undefined||limitSize===true)){if(start<-parentWidth){start=-parentWidth}if(end>2*parentWidth){end=2*parentWidth}}var boxWidth=Math.max(end-start+.5,1);if(this.overflow){if(this.options.rtl){this.right=start}else{this.left=start}this.width=boxWidth+this.props.content.width;contentWidth=this.props.content.width}else{if(this.options.rtl){this.right=start}else{this.left=start}this.width=boxWidth;contentWidth=Math.min(end-start,this.props.content.width)}if(this.options.rtl){this.dom.box.style.right=this.right+\"px\"}else{this.dom.box.style.left=this.left+\"px\"}this.dom.box.style.width=boxWidth+\"px\";switch(align){case\"left\":if(this.options.rtl){this.dom.content.style.right=\"0\"}else{this.dom.content.style.left=\"0\"}break;case\"right\":if(this.options.rtl){this.dom.content.style.right=Math.max(boxWidth-contentWidth,0)+\"px\"}else{this.dom.content.style.left=Math.max(boxWidth-contentWidth,0)+\"px\"}break;case\"center\":if(this.options.rtl){this.dom.content.style.right=Math.max((boxWidth-contentWidth)/2,0)+\"px\"}else{this.dom.content.style.left=Math.max((boxWidth-contentWidth)/2,0)+\"px\"}break;default:if(this.overflow){if(end>0){contentStartPosition=Math.max(-start,0)}else{contentStartPosition=-contentWidth}}else{if(start<0){contentStartPosition=-start}else{contentStartPosition=0}}if(this.options.rtl){this.dom.content.style.right=contentStartPosition+\"px\"}else{this.dom.content.style.left=contentStartPosition+\"px\";this.dom.content.style.width=\"calc(100% - \"+contentStartPosition+\"px)\"}}};RangeItem.prototype.repositionY=function(){var orientation=this.options.orientation.item;var box=this.dom.box;if(orientation==\"top\"){box.style.top=this.top+\"px\"}else{box.style.top=this.parent.height-this.top-this.height+\"px\"}};RangeItem.prototype._repaintDragLeft=function(){if((this.selected||this.options.itemsAlwaysDraggable.range)&&this.options.editable.updateTime&&!this.dom.dragLeft){var dragLeft=document.createElement(\"div\");dragLeft.className=\"vis-drag-left\";dragLeft.dragLeftItem=this;this.dom.box.appendChild(dragLeft);this.dom.dragLeft=dragLeft}else if(!this.selected&&!this.options.itemsAlwaysDraggable.range&&this.dom.dragLeft){if(this.dom.dragLeft.parentNode){this.dom.dragLeft.parentNode.removeChild(this.dom.dragLeft)}this.dom.dragLeft=null}};RangeItem.prototype._repaintDragRight=function(){if((this.selected||this.options.itemsAlwaysDraggable.range)&&this.options.editable.updateTime&&!this.dom.dragRight){var dragRight=document.createElement(\"div\");dragRight.className=\"vis-drag-right\";dragRight.dragRightItem=this;this.dom.box.appendChild(dragRight);this.dom.dragRight=dragRight}else if(!this.selected&&!this.options.itemsAlwaysDraggable.range&&this.dom.dragRight){if(this.dom.dragRight.parentNode){this.dom.dragRight.parentNode.removeChild(this.dom.dragRight)}this.dom.dragRight=null}};module.exports=RangeItem},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _stringify=__webpack_require__(19);var _stringify2=_interopRequireDefault(_stringify);var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var ColorPicker=__webpack_require__(179)[\"default\"];var Configurator=function(){function Configurator(parentModule,defaultContainer,configureOptions){var pixelRatio=arguments.length>3&&arguments[3]!==undefined?arguments[3]:1;(0,_classCallCheck3[\"default\"])(this,Configurator);this.parent=parentModule;this.changedOptions=[];this.container=defaultContainer;this.allowCreation=false;this.options={};this.initialized=false;this.popupCounter=0;this.defaultOptions={enabled:false,filter:true,container:undefined,showButton:true};util.extend(this.options,this.defaultOptions);this.configureOptions=configureOptions;this.moduleOptions={};this.domElements=[];this.popupDiv={};this.popupLimit=5;this.popupHistory={};this.colorPicker=new ColorPicker(pixelRatio);this.wrapper=undefined}(0,_createClass3[\"default\"])(Configurator,[{key:\"setOptions\",value:function setOptions(options){if(options!==undefined){this.popupHistory={};this._removePopup();var enabled=true;if(typeof options===\"string\"){this.options.filter=options}else if(options instanceof Array){this.options.filter=options.join()}else if((typeof options===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(options))===\"object\"){if(options.container!==undefined){this.options.container=options.container}if(options.filter!==undefined){this.options.filter=options.filter}if(options.showButton!==undefined){this.options.showButton=options.showButton}if(options.enabled!==undefined){enabled=options.enabled}}else if(typeof options===\"boolean\"){this.options.filter=true;enabled=options}else if(typeof options===\"function\"){this.options.filter=options;enabled=true}if(this.options.filter===false){enabled=false}this.options.enabled=enabled}this._clean()}},{key:\"setModuleOptions\",value:function setModuleOptions(moduleOptions){this.moduleOptions=moduleOptions;if(this.options.enabled===true){this._clean();if(this.options.container!==undefined){this.container=this.options.container}this._create()}}},{key:\"_create\",value:function _create(){var _this=this;this._clean();this.changedOptions=[];var filter=this.options.filter;var counter=0;var show=false;for(var option in this.configureOptions){if(this.configureOptions.hasOwnProperty(option)){this.allowCreation=false;show=false;if(typeof filter===\"function\"){show=filter(option,[]);show=show||this._handleObject(this.configureOptions[option],[option],true)}else if(filter===true||filter.indexOf(option)!==-1){show=true}if(show!==false){this.allowCreation=true;if(counter>0){this._makeItem([])}this._makeHeader(option);this._handleObject(this.configureOptions[option],[option])}counter++}}if(this.options.showButton===true){var generateButton=document.createElement(\"div\");generateButton.className=\"vis-configuration vis-config-button\";generateButton.innerHTML=\"generate options\";generateButton.onclick=function(){_this._printOptions()};generateButton.onmouseover=function(){generateButton.className=\"vis-configuration vis-config-button hover\"};generateButton.onmouseout=function(){generateButton.className=\"vis-configuration vis-config-button\"};this.optionsContainer=document.createElement(\"div\");this.optionsContainer.className=\"vis-configuration vis-config-option-container\";this.domElements.push(this.optionsContainer);this.domElements.push(generateButton)}this._push()}},{key:\"_push\",value:function _push(){this.wrapper=document.createElement(\"div\");this.wrapper.className=\"vis-configuration-wrapper\";this.container.appendChild(this.wrapper);for(var i=0;i<this.domElements.length;i++){this.wrapper.appendChild(this.domElements[i])}this._showPopupIfNeeded()}},{key:\"_clean\",value:function _clean(){for(var i=0;i<this.domElements.length;i++){this.wrapper.removeChild(this.domElements[i])}if(this.wrapper!==undefined){this.container.removeChild(this.wrapper);this.wrapper=undefined}this.domElements=[];this._removePopup()}},{key:\"_getValue\",value:function _getValue(path){var base=this.moduleOptions;for(var i=0;i<path.length;i++){if(base[path[i]]!==undefined){base=base[path[i]]}else{base=undefined;break}}return base}},{key:\"_makeItem\",value:function _makeItem(path){if(this.allowCreation===true){var item=document.createElement(\"div\");item.className=\"vis-configuration vis-config-item vis-config-s\"+path.length;for(var _len=arguments.length,domElements=Array(_len>1?_len-1:0),_key=1;_key<_len;_key++){domElements[_key-1]=arguments[_key]}domElements.forEach(function(element){item.appendChild(element)});this.domElements.push(item);return this.domElements.length}return 0}},{key:\"_makeHeader\",value:function _makeHeader(name){var div=document.createElement(\"div\");div.className=\"vis-configuration vis-config-header\";div.innerHTML=name;this._makeItem([],div)}},{key:\"_makeLabel\",value:function _makeLabel(name,path){var objectLabel=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;var div=document.createElement(\"div\");div.className=\"vis-configuration vis-config-label vis-config-s\"+path.length;if(objectLabel===true){div.innerHTML=\"<i><b>\"+name+\":</b></i>\"}else{div.innerHTML=name+\":\"}return div}},{key:\"_makeDropdown\",value:function _makeDropdown(arr,value,path){var select=document.createElement(\"select\");select.className=\"vis-configuration vis-config-select\";var selectedValue=0;if(value!==undefined){if(arr.indexOf(value)!==-1){selectedValue=arr.indexOf(value)}}for(var i=0;i<arr.length;i++){var option=document.createElement(\"option\");option.value=arr[i];if(i===selectedValue){option.selected=\"selected\"}option.innerHTML=arr[i];select.appendChild(option)}var me=this;select.onchange=function(){me._update(this.value,path)};var label=this._makeLabel(path[path.length-1],path);this._makeItem(path,label,select)}},{key:\"_makeRange\",value:function _makeRange(arr,value,path){var defaultValue=arr[0];var min=arr[1];var max=arr[2];var step=arr[3];var range=document.createElement(\"input\");range.className=\"vis-configuration vis-config-range\";try{range.type=\"range\";range.min=min;range.max=max}catch(err){}range.step=step;var popupString=\"\";var popupValue=0;if(value!==undefined){var factor=1.2;if(value<0&&value*factor<min){range.min=Math.ceil(value*factor);popupValue=range.min;popupString=\"range increased\"}else if(value/factor<min){range.min=Math.ceil(value/factor);popupValue=range.min;popupString=\"range increased\"}if(value*factor>max&&max!==1){range.max=Math.ceil(value*factor);popupValue=range.max;popupString=\"range increased\"}range.value=value}else{range.value=defaultValue}var input=document.createElement(\"input\");input.className=\"vis-configuration vis-config-rangeinput\";input.value=range.value;var me=this;range.onchange=function(){input.value=this.value;me._update(Number(this.value),path)};range.oninput=function(){input.value=this.value};var label=this._makeLabel(path[path.length-1],path);var itemIndex=this._makeItem(path,label,range,input);if(popupString!==\"\"&&this.popupHistory[itemIndex]!==popupValue){this.popupHistory[itemIndex]=popupValue;this._setupPopup(popupString,itemIndex)}}},{key:\"_setupPopup\",value:function _setupPopup(string,index){var _this2=this;if(this.initialized===true&&this.allowCreation===true&&this.popupCounter<this.popupLimit){var div=document.createElement(\"div\");div.id=\"vis-configuration-popup\";div.className=\"vis-configuration-popup\";div.innerHTML=string;div.onclick=function(){_this2._removePopup()};this.popupCounter+=1;this.popupDiv={html:div,index:index}}}},{key:\"_removePopup\",value:function _removePopup(){if(this.popupDiv.html!==undefined){this.popupDiv.html.parentNode.removeChild(this.popupDiv.html);clearTimeout(this.popupDiv.hideTimeout);clearTimeout(this.popupDiv.deleteTimeout);this.popupDiv={}}}},{key:\"_showPopupIfNeeded\",value:function _showPopupIfNeeded(){var _this3=this;if(this.popupDiv.html!==undefined){var correspondingElement=this.domElements[this.popupDiv.index];var rect=correspondingElement.getBoundingClientRect();this.popupDiv.html.style.left=rect.left+\"px\";this.popupDiv.html.style.top=rect.top-30+\"px\";document.body.appendChild(this.popupDiv.html);this.popupDiv.hideTimeout=setTimeout(function(){_this3.popupDiv.html.style.opacity=0},1500);this.popupDiv.deleteTimeout=setTimeout(function(){_this3._removePopup()},1800)}}},{key:\"_makeCheckbox\",value:function _makeCheckbox(defaultValue,value,path){var checkbox=document.createElement(\"input\");checkbox.type=\"checkbox\";checkbox.className=\"vis-configuration vis-config-checkbox\";checkbox.checked=defaultValue;if(value!==undefined){checkbox.checked=value;if(value!==defaultValue){if((typeof defaultValue===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(defaultValue))===\"object\"){if(value!==defaultValue.enabled){this.changedOptions.push({path:path,value:value})}}else{this.changedOptions.push({path:path,value:value})}}}var me=this;checkbox.onchange=function(){me._update(this.checked,path)};var label=this._makeLabel(path[path.length-1],path);this._makeItem(path,label,checkbox)}},{key:\"_makeTextInput\",value:function _makeTextInput(defaultValue,value,path){var checkbox=document.createElement(\"input\");checkbox.type=\"text\";checkbox.className=\"vis-configuration vis-config-text\";checkbox.value=value;if(value!==defaultValue){this.changedOptions.push({path:path,value:value})}var me=this;checkbox.onchange=function(){me._update(this.value,path)};var label=this._makeLabel(path[path.length-1],path);this._makeItem(path,label,checkbox)}},{key:\"_makeColorField\",value:function _makeColorField(arr,value,path){var _this4=this;var defaultColor=arr[1];var div=document.createElement(\"div\");value=value===undefined?defaultColor:value;if(value!==\"none\"){div.className=\"vis-configuration vis-config-colorBlock\";div.style.backgroundColor=value}else{div.className=\"vis-configuration vis-config-colorBlock none\"}value=value===undefined?defaultColor:value;div.onclick=function(){_this4._showColorPicker(value,div,path)};var label=this._makeLabel(path[path.length-1],path);this._makeItem(path,label,div)}},{key:\"_showColorPicker\",value:function _showColorPicker(value,div,path){var _this5=this;div.onclick=function(){};this.colorPicker.insertTo(div);this.colorPicker.show();this.colorPicker.setColor(value);this.colorPicker.setUpdateCallback(function(color){\nvar colorString=\"rgba(\"+color.r+\",\"+color.g+\",\"+color.b+\",\"+color.a+\")\";div.style.backgroundColor=colorString;_this5._update(colorString,path)});this.colorPicker.setCloseCallback(function(){div.onclick=function(){_this5._showColorPicker(value,div,path)}})}},{key:\"_handleObject\",value:function _handleObject(obj){var path=arguments.length>1&&arguments[1]!==undefined?arguments[1]:[];var checkOnly=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;var show=false;var filter=this.options.filter;var visibleInSet=false;for(var subObj in obj){if(obj.hasOwnProperty(subObj)){show=true;var item=obj[subObj];var newPath=util.copyAndExtendArray(path,subObj);if(typeof filter===\"function\"){show=filter(subObj,path);if(show===false){if(!(item instanceof Array)&&typeof item!==\"string\"&&typeof item!==\"boolean\"&&item instanceof Object){this.allowCreation=false;show=this._handleObject(item,newPath,true);this.allowCreation=checkOnly===false}}}if(show!==false){visibleInSet=true;var value=this._getValue(newPath);if(item instanceof Array){this._handleArray(item,value,newPath)}else if(typeof item===\"string\"){this._makeTextInput(item,value,newPath)}else if(typeof item===\"boolean\"){this._makeCheckbox(item,value,newPath)}else if(item instanceof Object){var draw=true;if(path.indexOf(\"physics\")!==-1){if(this.moduleOptions.physics.solver!==subObj){draw=false}}if(draw===true){if(item.enabled!==undefined){var enabledPath=util.copyAndExtendArray(newPath,\"enabled\");var enabledValue=this._getValue(enabledPath);if(enabledValue===true){var label=this._makeLabel(subObj,newPath,true);this._makeItem(newPath,label);visibleInSet=this._handleObject(item,newPath)||visibleInSet}else{this._makeCheckbox(item,enabledValue,newPath)}}else{var _label=this._makeLabel(subObj,newPath,true);this._makeItem(newPath,_label);visibleInSet=this._handleObject(item,newPath)||visibleInSet}}}else{console.error(\"dont know how to handle\",item,subObj,newPath)}}}}return visibleInSet}},{key:\"_handleArray\",value:function _handleArray(arr,value,path){if(typeof arr[0]===\"string\"&&arr[0]===\"color\"){this._makeColorField(arr,value,path);if(arr[1]!==value){this.changedOptions.push({path:path,value:value})}}else if(typeof arr[0]===\"string\"){this._makeDropdown(arr,value,path);if(arr[0]!==value){this.changedOptions.push({path:path,value:value})}}else if(typeof arr[0]===\"number\"){this._makeRange(arr,value,path);if(arr[0]!==value){this.changedOptions.push({path:path,value:Number(value)})}}}},{key:\"_update\",value:function _update(value,path){var options=this._constructOptions(value,path);if(this.parent.body&&this.parent.body.emitter&&this.parent.body.emitter.emit){this.parent.body.emitter.emit(\"configChange\",options)}this.initialized=true;this.parent.setOptions(options)}},{key:\"_constructOptions\",value:function _constructOptions(value,path){var optionsObj=arguments.length>2&&arguments[2]!==undefined?arguments[2]:{};var pointer=optionsObj;value=value===\"true\"?true:value;value=value===\"false\"?false:value;for(var i=0;i<path.length;i++){if(path[i]!==\"global\"){if(pointer[path[i]]===undefined){pointer[path[i]]={}}if(i!==path.length-1){pointer=pointer[path[i]]}else{pointer[path[i]]=value}}}return optionsObj}},{key:\"_printOptions\",value:function _printOptions(){var options=this.getOptions();this.optionsContainer.innerHTML=\"<pre>var options = \"+(0,_stringify2[\"default\"])(options,null,2)+\"</pre>\"}},{key:\"getOptions\",value:function getOptions(){var options={};for(var i=0;i<this.changedOptions.length;i++){this._constructOptions(this.changedOptions[i].value,this.changedOptions[i].path,options)}return options}}]);return Configurator}();exports[\"default\"]=Configurator},function(module,exports,__webpack_require__){\"use strict\";var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var DOMutil=__webpack_require__(14);function Points(groupId,options){}Points.draw=function(dataset,group,framework,offset){offset=offset||0;var callback=getCallback(framework,group);for(var i=0;i<dataset.length;i++){if(!callback){DOMutil.drawPoint(dataset[i].screen_x+offset,dataset[i].screen_y,getGroupTemplate(group),framework.svgElements,framework.svg,dataset[i].label)}else{var callbackResult=callback(dataset[i],group);if(callbackResult===true||(typeof callbackResult===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(callbackResult))===\"object\"){DOMutil.drawPoint(dataset[i].screen_x+offset,dataset[i].screen_y,getGroupTemplate(group,callbackResult),framework.svgElements,framework.svg,dataset[i].label)}}}};Points.drawIcon=function(group,x,y,iconWidth,iconHeight,framework){var fillHeight=iconHeight*.5;var outline=DOMutil.getSVGElement(\"rect\",framework.svgElements,framework.svg);outline.setAttributeNS(null,\"x\",x);outline.setAttributeNS(null,\"y\",y-fillHeight);outline.setAttributeNS(null,\"width\",iconWidth);outline.setAttributeNS(null,\"height\",2*fillHeight);outline.setAttributeNS(null,\"class\",\"vis-outline\");DOMutil.drawPoint(x+.5*iconWidth,y,getGroupTemplate(group),framework.svgElements,framework.svg)};function getGroupTemplate(group,callbackResult){callbackResult=typeof callbackResult===\"undefined\"?{}:callbackResult;return{style:callbackResult.style||group.options.drawPoints.style,styles:callbackResult.styles||group.options.drawPoints.styles,size:callbackResult.size||group.options.drawPoints.size,className:callbackResult.className||group.className}}function getCallback(framework,group){var callback=undefined;if(framework.options&&framework.options.drawPoints&&framework.options.drawPoints.onRender&&typeof framework.options.drawPoints.onRender==\"function\"){callback=framework.options.drawPoints.onRender}if(group.group.options&&group.group.options.drawPoints&&group.group.options.drawPoints.onRender&&typeof group.group.options.drawPoints.onRender==\"function\"){callback=group.group.options.drawPoints.onRender}return callback}module.exports=Points},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _NodeBase2=__webpack_require__(23);var _NodeBase3=_interopRequireDefault(_NodeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var CircleImageBase=function(_NodeBase){(0,_inherits3[\"default\"])(CircleImageBase,_NodeBase);function CircleImageBase(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,CircleImageBase);var _this=(0,_possibleConstructorReturn3[\"default\"])(this,(CircleImageBase.__proto__||(0,_getPrototypeOf2[\"default\"])(CircleImageBase)).call(this,options,body,labelModule));_this.labelOffset=0;_this.selected=false;return _this}(0,_createClass3[\"default\"])(CircleImageBase,[{key:\"setOptions\",value:function setOptions(options,imageObj,imageObjAlt){this.options=options;if(!(imageObj===undefined&&imageObjAlt===undefined)){this.setImages(imageObj,imageObjAlt)}}},{key:\"setImages\",value:function setImages(imageObj,imageObjAlt){if(imageObjAlt&&this.selected){this.imageObj=imageObjAlt;this.imageObjAlt=imageObj}else{this.imageObj=imageObj;this.imageObjAlt=imageObjAlt}}},{key:\"switchImages\",value:function switchImages(selected){var selection_changed=selected&&!this.selected||!selected&&this.selected;this.selected=selected;if(this.imageObjAlt!==undefined&&selection_changed){var imageTmp=this.imageObj;this.imageObj=this.imageObjAlt;this.imageObjAlt=imageTmp}}},{key:\"_resizeImage\",value:function _resizeImage(){var width,height;if(this.options.shapeProperties.useImageSize===false){var ratio_width=1;var ratio_height=1;if(this.imageObj.width&&this.imageObj.height){if(this.imageObj.width>this.imageObj.height){ratio_width=this.imageObj.width/this.imageObj.height}else{ratio_height=this.imageObj.height/this.imageObj.width}}width=this.options.size*2*ratio_width;height=this.options.size*2*ratio_height}else{width=this.imageObj.width;height=this.imageObj.height}this.width=width;this.height=height;this.radius=.5*this.width}},{key:\"_drawRawCircle\",value:function _drawRawCircle(ctx,x,y,values){this.initContextForDraw(ctx,values);ctx.circle(x,y,values.size);this.performFill(ctx,values)}},{key:\"_drawImageAtPosition\",value:function _drawImageAtPosition(ctx,values){if(this.imageObj.width!=0){ctx.globalAlpha=1;this.enableShadow(ctx,values);var factor=1;if(this.options.shapeProperties.interpolation===true){factor=this.imageObj.width/this.width/this.body.view.scale}this.imageObj.drawImageAtPosition(ctx,factor,this.left,this.top,this.width,this.height);this.disableShadow(ctx,values)}}},{key:\"_drawImageLabel\",value:function _drawImageLabel(ctx,x,y,selected,hover){var yLabel;var offset=0;if(this.height!==undefined){offset=this.height*.5;var labelDimensions=this.labelModule.getTextSize(ctx,selected,hover);if(labelDimensions.lineCount>=1){offset+=labelDimensions.height/2}}yLabel=y+offset;if(this.options.label){this.labelOffset=offset}this.labelModule.draw(ctx,x,yLabel,selected,hover,\"hanging\")}}]);return CircleImageBase}(_NodeBase3[\"default\"]);exports[\"default\"]=CircleImageBase},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _stringify=__webpack_require__(19);var _stringify2=_interopRequireDefault(_stringify);var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);var _create=__webpack_require__(29);var _create2=_interopRequireDefault(_create);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var Label=__webpack_require__(117)[\"default\"];var ComponentUtil=__webpack_require__(48)[\"default\"];var CubicBezierEdge=__webpack_require__(215)[\"default\"];var BezierEdgeDynamic=__webpack_require__(217)[\"default\"];var BezierEdgeStatic=__webpack_require__(218)[\"default\"];var StraightEdge=__webpack_require__(219)[\"default\"];var Edge=function(){function Edge(options,body,globalOptions,defaultOptions){(0,_classCallCheck3[\"default\"])(this,Edge);if(body===undefined){throw new Error(\"No body provided\")}this.options=util.bridgeObject(globalOptions);this.globalOptions=globalOptions;this.defaultOptions=defaultOptions;this.body=body;this.id=undefined;this.fromId=undefined;this.toId=undefined;this.selected=false;this.hover=false;this.labelDirty=true;this.baseWidth=this.options.width;this.baseFontSize=this.options.font.size;this.from=undefined;this.to=undefined;this.edgeType=undefined;this.connected=false;this.labelModule=new Label(this.body,this.options,true);this.setOptions(options)}(0,_createClass3[\"default\"])(Edge,[{key:\"setOptions\",value:function setOptions(options){if(!options){return}Edge.parseOptions(this.options,options,true,this.globalOptions);if(options.id!==undefined){this.id=options.id}if(options.from!==undefined){this.fromId=options.from}if(options.to!==undefined){this.toId=options.to}if(options.title!==undefined){this.title=options.title}if(options.value!==undefined){options.value=parseFloat(options.value)}var pile=[options,this.options,this.defaultOptions];this.chooser=ComponentUtil.choosify(\"edge\",pile);this.updateLabelModule(options);var dataChanged=this.updateEdgeType();this._setInteractionWidths();this.connect();if(options.hidden!==undefined||options.physics!==undefined){dataChanged=true}return dataChanged}},{key:\"getFormattingValues\",value:function getFormattingValues(){var toArrow=this.options.arrows.to===true||this.options.arrows.to.enabled===true;var fromArrow=this.options.arrows.from===true||this.options.arrows.from.enabled===true;var middleArrow=this.options.arrows.middle===true||this.options.arrows.middle.enabled===true;var inheritsColor=this.options.color.inherit;var values={toArrow:toArrow,toArrowScale:this.options.arrows.to.scaleFactor,toArrowType:this.options.arrows.to.type,middleArrow:middleArrow,middleArrowScale:this.options.arrows.middle.scaleFactor,middleArrowType:this.options.arrows.middle.type,fromArrow:fromArrow,fromArrowScale:this.options.arrows.from.scaleFactor,fromArrowType:this.options.arrows.from.type,arrowStrikethrough:this.options.arrowStrikethrough,color:inheritsColor?undefined:this.options.color.color,inheritsColor:inheritsColor,opacity:this.options.color.opacity,hidden:this.options.hidden,length:this.options.length,shadow:this.options.shadow.enabled,shadowColor:this.options.shadow.color,shadowSize:this.options.shadow.size,shadowX:this.options.shadow.x,shadowY:this.options.shadow.y,dashes:this.options.dashes,width:this.options.width};if(this.selected||this.hover){if(this.chooser===true){if(this.selected){var selectedWidth=this.options.selectionWidth;if(typeof selectedWidth===\"function\"){values.width=selectedWidth(values.width)}else if(typeof selectedWidth===\"number\"){values.width+=selectedWidth}values.width=Math.max(values.width,.3/this.body.view.scale);values.color=this.options.color.highlight;values.shadow=this.options.shadow.enabled}else if(this.hover){var hoverWidth=this.options.hoverWidth;if(typeof hoverWidth===\"function\"){values.width=hoverWidth(values.width)}else if(typeof hoverWidth===\"number\"){values.width+=hoverWidth}values.width=Math.max(values.width,.3/this.body.view.scale);values.color=this.options.color.hover;values.shadow=this.options.shadow.enabled}}else if(typeof this.chooser===\"function\"){this.chooser(values,this.options.id,this.selected,this.hover);if(values.color!==undefined){values.inheritsColor=false}if(values.shadow===false){if(values.shadowColor!==this.options.shadow.color||values.shadowSize!==this.options.shadow.size||values.shadowX!==this.options.shadow.x||values.shadowY!==this.options.shadow.y){values.shadow=true}}}}else{values.shadow=this.options.shadow.enabled;values.width=Math.max(values.width,.3/this.body.view.scale)}return values}},{key:\"updateLabelModule\",value:function updateLabelModule(options){var pile=[options,this.options,this.globalOptions,this.defaultOptions];this.labelModule.update(this.options,pile);if(this.labelModule.baseSize!==undefined){this.baseFontSize=this.labelModule.baseSize}}},{key:\"updateEdgeType\",value:function updateEdgeType(){var smooth=this.options.smooth;var dataChanged=false;var changeInType=true;if(this.edgeType!==undefined){if(this.edgeType instanceof BezierEdgeDynamic&&smooth.enabled===true&&smooth.type===\"dynamic\"||this.edgeType instanceof CubicBezierEdge&&smooth.enabled===true&&smooth.type===\"cubicBezier\"||this.edgeType instanceof BezierEdgeStatic&&smooth.enabled===true&&smooth.type!==\"dynamic\"&&smooth.type!==\"cubicBezier\"||this.edgeType instanceof StraightEdge&&smooth.type.enabled===false){changeInType=false}if(changeInType===true){dataChanged=this.cleanup()}}if(changeInType===true){if(smooth.enabled===true){if(smooth.type===\"dynamic\"){dataChanged=true;this.edgeType=new BezierEdgeDynamic(this.options,this.body,this.labelModule)}else if(smooth.type===\"cubicBezier\"){this.edgeType=new CubicBezierEdge(this.options,this.body,this.labelModule)}else{this.edgeType=new BezierEdgeStatic(this.options,this.body,this.labelModule)}}else{this.edgeType=new StraightEdge(this.options,this.body,this.labelModule)}}else{this.edgeType.setOptions(this.options)}return dataChanged}},{key:\"connect\",value:function connect(){this.disconnect();this.from=this.body.nodes[this.fromId]||undefined;this.to=this.body.nodes[this.toId]||undefined;this.connected=this.from!==undefined&&this.to!==undefined;if(this.connected===true){this.from.attachEdge(this);this.to.attachEdge(this)}else{if(this.from){this.from.detachEdge(this)}if(this.to){this.to.detachEdge(this)}}this.edgeType.connect()}},{key:\"disconnect\",value:function disconnect(){if(this.from){this.from.detachEdge(this);this.from=undefined}if(this.to){this.to.detachEdge(this);this.to=undefined}this.connected=false}},{key:\"getTitle\",value:function getTitle(){return this.title}},{key:\"isSelected\",value:function isSelected(){return this.selected}},{key:\"getValue\",value:function getValue(){return this.options.value}},{key:\"setValueRange\",value:function setValueRange(min,max,total){if(this.options.value!==undefined){var scale=this.options.scaling.customScalingFunction(min,max,total,this.options.value);var widthDiff=this.options.scaling.max-this.options.scaling.min;if(this.options.scaling.label.enabled===true){var fontDiff=this.options.scaling.label.max-this.options.scaling.label.min;this.options.font.size=this.options.scaling.label.min+scale*fontDiff}this.options.width=this.options.scaling.min+scale*widthDiff}else{this.options.width=this.baseWidth;this.options.font.size=this.baseFontSize}this._setInteractionWidths();this.updateLabelModule()}},{key:\"_setInteractionWidths\",value:function _setInteractionWidths(){if(typeof this.options.hoverWidth===\"function\"){this.edgeType.hoverWidth=this.options.hoverWidth(this.options.width)}else{this.edgeType.hoverWidth=this.options.hoverWidth+this.options.width}if(typeof this.options.selectionWidth===\"function\"){this.edgeType.selectionWidth=this.options.selectionWidth(this.options.width)}else{this.edgeType.selectionWidth=this.options.selectionWidth+this.options.width}}},{key:\"draw\",value:function draw(ctx){var values=this.getFormattingValues();if(values.hidden){return}var viaNode=this.edgeType.getViaNode();var arrowData={};this.edgeType.fromPoint=this.edgeType.from;this.edgeType.toPoint=this.edgeType.to;if(values.fromArrow){arrowData.from=this.edgeType.getArrowData(ctx,\"from\",viaNode,this.selected,this.hover,values);if(values.arrowStrikethrough===false)this.edgeType.fromPoint=arrowData.from.core}if(values.toArrow){arrowData.to=this.edgeType.getArrowData(ctx,\"to\",viaNode,this.selected,this.hover,values);if(values.arrowStrikethrough===false)this.edgeType.toPoint=arrowData.to.core}if(values.middleArrow){arrowData.middle=this.edgeType.getArrowData(ctx,\"middle\",viaNode,this.selected,this.hover,values)}this.edgeType.drawLine(ctx,values,this.selected,this.hover,viaNode);this.drawArrows(ctx,arrowData,values);this.drawLabel(ctx,viaNode)}},{key:\"drawArrows\",value:function drawArrows(ctx,arrowData,values){if(values.fromArrow){this.edgeType.drawArrowHead(ctx,values,this.selected,this.hover,arrowData.from)}if(values.middleArrow){this.edgeType.drawArrowHead(ctx,values,this.selected,this.hover,arrowData.middle)}if(values.toArrow){this.edgeType.drawArrowHead(ctx,values,this.selected,this.hover,arrowData.to)}}},{key:\"drawLabel\",value:function drawLabel(ctx,viaNode){if(this.options.label!==undefined){var node1=this.from;var node2=this.to;if(this.labelModule.differentState(this.selected,this.hover)){this.labelModule.getTextSize(ctx,this.selected,this.hover)}if(node1.id!=node2.id){this.labelModule.pointToSelf=false;var point=this.edgeType.getPoint(.5,viaNode);ctx.save();var rotationPoint=this._getRotation(ctx);if(rotationPoint.angle!=0){ctx.translate(rotationPoint.x,rotationPoint.y);ctx.rotate(rotationPoint.angle)}this.labelModule.draw(ctx,point.x,point.y,this.selected,this.hover);ctx.restore()}else{this.labelModule.pointToSelf=true;var x,y;var radius=this.options.selfReferenceSize;if(node1.shape.width>node1.shape.height){x=node1.x+node1.shape.width*.5;y=node1.y-radius}else{x=node1.x+radius;y=node1.y-node1.shape.height*.5}point=this._pointOnCircle(x,y,radius,.125);this.labelModule.draw(ctx,point.x,point.y,this.selected,this.hover)}}}},{key:\"getItemsOnPoint\",value:function getItemsOnPoint(point){var ret=[];if(this.labelModule.visible()){var rotationPoint=this._getRotation();if(ComponentUtil.pointInRect(this.labelModule.getSize(),point,rotationPoint)){ret.push({edgeId:this.id,labelId:0})}}var obj={left:point.x,top:point.y};if(this.isOverlappingWith(obj)){ret.push({edgeId:this.id})}return ret}},{key:\"isOverlappingWith\",value:function isOverlappingWith(obj){if(this.connected){var distMax=10;var xFrom=this.from.x;var yFrom=this.from.y;var xTo=this.to.x;var yTo=this.to.y;var xObj=obj.left;var yObj=obj.top;var dist=this.edgeType.getDistanceToEdge(xFrom,yFrom,xTo,yTo,xObj,yObj);return dist<distMax}else{return false}}},{key:\"_getRotation\",value:function _getRotation(ctx){var viaNode=this.edgeType.getViaNode();var point=this.edgeType.getPoint(.5,viaNode);if(ctx!==undefined){this.labelModule.calculateLabelSize(ctx,this.selected,this.hover,point.x,point.y)}var ret={x:point.x,y:this.labelModule.size.yLine,angle:0};if(!this.labelModule.visible()){return ret}if(this.options.font.align===\"horizontal\"){return ret}var dy=this.from.y-this.to.y;var dx=this.from.x-this.to.x;var angle=Math.atan2(dy,dx);if(angle<-1&&dx<0||angle>0&&dx<0){angle+=Math.PI}ret.angle=angle;return ret}},{key:\"_pointOnCircle\",value:function _pointOnCircle(x,y,radius,percentage){var angle=percentage*2*Math.PI;return{x:x+radius*Math.cos(angle),y:y-radius*Math.sin(angle)}}},{key:\"select\",value:function select(){this.selected=true}},{key:\"unselect\",value:function unselect(){this.selected=false}},{key:\"cleanup\",value:function cleanup(){return this.edgeType.cleanup()}},{key:\"remove\",value:function remove(){this.cleanup();this.disconnect();delete this.body.edges[this.id]}},{key:\"endPointsValid\",value:function endPointsValid(){return this.body.nodes[this.fromId]!==undefined&&this.body.nodes[this.toId]!==undefined}}],[{key:\"parseOptions\",value:function parseOptions(parentOptions,newOptions){var allowDeletion=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;var globalOptions=arguments.length>3&&arguments[3]!==undefined?arguments[3]:{};var copyFromGlobals=arguments.length>4&&arguments[4]!==undefined?arguments[4]:false;var fields=[\"arrowStrikethrough\",\"id\",\"from\",\"hidden\",\"hoverWidth\",\"labelHighlightBold\",\"length\",\"line\",\"opacity\",\"physics\",\"scaling\",\"selectionWidth\",\"selfReferenceSize\",\"to\",\"title\",\"value\",\"width\",\"font\",\"chosen\",\"widthConstraint\"];util.selectiveDeepExtend(fields,parentOptions,newOptions,allowDeletion);if(ComponentUtil.isValidLabel(newOptions.label)){parentOptions.label=newOptions.label}else{parentOptions.label=undefined}util.mergeOptions(parentOptions,newOptions,\"smooth\",globalOptions);util.mergeOptions(parentOptions,newOptions,\"shadow\",globalOptions);if(newOptions.dashes!==undefined&&newOptions.dashes!==null){parentOptions.dashes=newOptions.dashes}else if(allowDeletion===true&&newOptions.dashes===null){parentOptions.dashes=(0,_create2[\"default\"])(globalOptions.dashes)}if(newOptions.scaling!==undefined&&newOptions.scaling!==null){if(newOptions.scaling.min!==undefined){parentOptions.scaling.min=newOptions.scaling.min}if(newOptions.scaling.max!==undefined){parentOptions.scaling.max=newOptions.scaling.max}util.mergeOptions(parentOptions.scaling,newOptions.scaling,\"label\",globalOptions.scaling)}else if(allowDeletion===true&&newOptions.scaling===null){parentOptions.scaling=(0,_create2[\"default\"])(globalOptions.scaling)}if(newOptions.arrows!==undefined&&newOptions.arrows!==null){if(typeof newOptions.arrows===\"string\"){var arrows=newOptions.arrows.toLowerCase();parentOptions.arrows.to.enabled=arrows.indexOf(\"to\")!=-1;parentOptions.arrows.middle.enabled=arrows.indexOf(\"middle\")!=-1;parentOptions.arrows.from.enabled=arrows.indexOf(\"from\")!=-1}else if((0,_typeof3[\"default\"])(newOptions.arrows)===\"object\"){util.mergeOptions(parentOptions.arrows,newOptions.arrows,\"to\",globalOptions.arrows);util.mergeOptions(parentOptions.arrows,newOptions.arrows,\"middle\",globalOptions.arrows);util.mergeOptions(parentOptions.arrows,newOptions.arrows,\"from\",globalOptions.arrows)}else{throw new Error(\"The arrow newOptions can only be an object or a string. Refer to the documentation. You used:\"+(0,_stringify2[\"default\"])(newOptions.arrows))}}else if(allowDeletion===true&&newOptions.arrows===null){parentOptions.arrows=(0,_create2[\"default\"])(globalOptions.arrows)}if(newOptions.color!==undefined&&newOptions.color!==null){var fromColor=newOptions.color;var toColor=parentOptions.color;if(copyFromGlobals){util.deepExtend(toColor,globalOptions.color,false,allowDeletion)}else{for(var i in toColor){if(toColor.hasOwnProperty(i)){delete toColor[i]}}}if(util.isString(toColor)){toColor.color=toColor;toColor.highlight=toColor;toColor.hover=toColor;toColor.inherit=false;if(fromColor.opacity===undefined){toColor.opacity=1}}else{var colorsDefined=false;if(fromColor.color!==undefined){toColor.color=fromColor.color;colorsDefined=true}if(fromColor.highlight!==undefined){toColor.highlight=fromColor.highlight;colorsDefined=true}if(fromColor.hover!==undefined){toColor.hover=fromColor.hover;colorsDefined=true}if(fromColor.inherit!==undefined){toColor.inherit=fromColor.inherit}if(fromColor.opacity!==undefined){toColor.opacity=Math.min(1,Math.max(0,fromColor.opacity))}if(colorsDefined===true){toColor.inherit=false}else{if(toColor.inherit===undefined){toColor.inherit=\"from\"}}}}else if(allowDeletion===true&&newOptions.color===null){parentOptions.color=util.bridgeObject(globalOptions.color)}if(allowDeletion===true&&newOptions.font===null){parentOptions.font=util.bridgeObject(globalOptions.font)}}}]);return Edge}();exports[\"default\"]=Edge},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _EdgeBase2=__webpack_require__(118);var _EdgeBase3=_interopRequireDefault(_EdgeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var BezierEdgeBase=function(_EdgeBase){(0,_inherits3[\"default\"])(BezierEdgeBase,_EdgeBase);function BezierEdgeBase(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,BezierEdgeBase);return(0,_possibleConstructorReturn3[\"default\"])(this,(BezierEdgeBase.__proto__||(0,_getPrototypeOf2[\"default\"])(BezierEdgeBase)).call(this,options,body,labelModule))}(0,_createClass3[\"default\"])(BezierEdgeBase,[{key:\"_findBorderPositionBezier\",value:function _findBorderPositionBezier(nearNode,ctx){var viaNode=arguments.length>2&&arguments[2]!==undefined?arguments[2]:this._getViaCoordinates();var maxIterations=10;var iteration=0;var low=0;var high=1;var pos,angle,distanceToBorder,distanceToPoint,difference;var threshold=.2;var node=this.to;var from=false;if(nearNode.id===this.from.id){node=this.from;from=true}while(low<=high&&iteration<maxIterations){var middle=(low+high)*.5;pos=this.getPoint(middle,viaNode);angle=Math.atan2(node.y-pos.y,node.x-pos.x);distanceToBorder=node.distanceToBorder(ctx,angle);distanceToPoint=Math.sqrt(Math.pow(pos.x-node.x,2)+Math.pow(pos.y-node.y,2));difference=distanceToBorder-distanceToPoint;if(Math.abs(difference)<threshold){break}else if(difference<0){if(from===false){low=middle}else{high=middle}}else{if(from===false){high=middle}else{low=middle}}iteration++}pos.t=middle;return pos}},{key:\"_getDistanceToBezierEdge\",value:function _getDistanceToBezierEdge(x1,y1,x2,y2,x3,y3,via){var minDistance=1e9;var distance=void 0;var i=void 0,t=void 0,x=void 0,y=void 0;var lastX=x1;var lastY=y1;for(i=1;i<10;i++){t=.1*i;x=Math.pow(1-t,2)*x1+2*t*(1-t)*via.x+Math.pow(t,2)*x2;y=Math.pow(1-t,2)*y1+2*t*(1-t)*via.y+Math.pow(t,2)*y2;if(i>0){distance=this._getDistanceToLine(lastX,lastY,x,y,x3,y3);minDistance=distance<minDistance?distance:minDistance}lastX=x;lastY=y}return minDistance}},{key:\"_bezierCurve\",value:function _bezierCurve(ctx,values,viaNode1,viaNode2){var hasNode1=viaNode1!==undefined&&viaNode1.x!==undefined;var hasNode2=viaNode2!==undefined&&viaNode2.x!==undefined;ctx.beginPath();ctx.moveTo(this.fromPoint.x,this.fromPoint.y);if(hasNode1&&hasNode2){ctx.bezierCurveTo(viaNode1.x,viaNode1.y,viaNode2.x,viaNode2.y,this.toPoint.x,this.toPoint.y)}else if(hasNode1){ctx.quadraticCurveTo(viaNode1.x,viaNode1.y,this.toPoint.x,this.toPoint.y)}else{ctx.lineTo(this.toPoint.x,this.toPoint.y)}this.enableShadow(ctx,values);ctx.stroke();this.disableShadow(ctx,values)}},{key:\"getViaNode\",value:function getViaNode(){return this._getViaCoordinates()}}]);return BezierEdgeBase}(_EdgeBase3[\"default\"]);exports[\"default\"]=BezierEdgeBase},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var NetworkUtil=function(){function NetworkUtil(){(0,_classCallCheck3[\"default\"])(this,NetworkUtil)}(0,_createClass3[\"default\"])(NetworkUtil,null,[{key:\"getRange\",value:function getRange(allNodes){var specificNodes=arguments.length>1&&arguments[1]!==undefined?arguments[1]:[];var minY=1e9,maxY=-1e9,minX=1e9,maxX=-1e9,node;if(specificNodes.length>0){for(var i=0;i<specificNodes.length;i++){node=allNodes[specificNodes[i]];if(minX>node.shape.boundingBox.left){minX=node.shape.boundingBox.left}if(maxX<node.shape.boundingBox.right){maxX=node.shape.boundingBox.right}if(minY>node.shape.boundingBox.top){minY=node.shape.boundingBox.top}if(maxY<node.shape.boundingBox.bottom){maxY=node.shape.boundingBox.bottom}}}if(minX===1e9&&maxX===-1e9&&minY===1e9&&maxY===-1e9){minY=0,maxY=0,minX=0,maxX=0}return{minX:minX,maxX:maxX,minY:minY,maxY:maxY}}},{key:\"getRangeCore\",value:function getRangeCore(allNodes){var specificNodes=arguments.length>1&&arguments[1]!==undefined?arguments[1]:[];var minY=1e9,maxY=-1e9,minX=1e9,maxX=-1e9,node;if(specificNodes.length>0){for(var i=0;i<specificNodes.length;i++){node=allNodes[specificNodes[i]];if(minX>node.x){minX=node.x}if(maxX<node.x){maxX=node.x}if(minY>node.y){minY=node.y}if(maxY<node.y){maxY=node.y}}}if(minX===1e9&&maxX===-1e9&&minY===1e9&&maxY===-1e9){minY=0,maxY=0,minX=0,maxX=0}return{minX:minX,maxX:maxX,minY:minY,maxY:maxY}}},{key:\"findCenter\",value:function findCenter(range){return{x:.5*(range.maxX+range.minX),y:.5*(range.maxY+range.minY)}}},{key:\"cloneOptions\",value:function cloneOptions(item,type){var clonedOptions={};if(type===undefined||type===\"node\"){util.deepExtend(clonedOptions,item.options,true);clonedOptions.x=item.x;clonedOptions.y=item.y;clonedOptions.amountOfConnections=item.edges.length}else{util.deepExtend(clonedOptions,item.options,true)}return clonedOptions}}]);return NetworkUtil}();exports[\"default\"]=NetworkUtil},function(module,exports,__webpack_require__){module.exports={default:__webpack_require__(124),__esModule:true}},function(module,exports,__webpack_require__){var cof=__webpack_require__(50);module.exports=Object(\"z\").propertyIsEnumerable(0)?Object:function(it){return cof(it)==\"String\"?it.split(\"\"):Object(it)}},function(module,exports,__webpack_require__){\"use strict\";var LIBRARY=__webpack_require__(52);var $export=__webpack_require__(17);var redefine=__webpack_require__(83);var hide=__webpack_require__(26);var has=__webpack_require__(22);var Iterators=__webpack_require__(31);var $iterCreate=__webpack_require__(129);var setToStringTag=__webpack_require__(59);var getPrototypeOf=__webpack_require__(85);var ITERATOR=__webpack_require__(13)(\"iterator\");var BUGGY=!([].keys&&\"next\"in[].keys())\n;var FF_ITERATOR=\"@@iterator\";var KEYS=\"keys\";var VALUES=\"values\";var returnThis=function(){return this};module.exports=function(Base,NAME,Constructor,next,DEFAULT,IS_SET,FORCED){$iterCreate(Constructor,NAME,next);var getMethod=function(kind){if(!BUGGY&&kind in proto)return proto[kind];switch(kind){case KEYS:return function keys(){return new Constructor(this,kind)};case VALUES:return function values(){return new Constructor(this,kind)}}return function entries(){return new Constructor(this,kind)}};var TAG=NAME+\" Iterator\";var DEF_VALUES=DEFAULT==VALUES;var VALUES_BUG=false;var proto=Base.prototype;var $native=proto[ITERATOR]||proto[FF_ITERATOR]||DEFAULT&&proto[DEFAULT];var $default=$native||getMethod(DEFAULT);var $entries=DEFAULT?!DEF_VALUES?$default:getMethod(\"entries\"):undefined;var $anyNative=NAME==\"Array\"?proto.entries||$native:$native;var methods,key,IteratorPrototype;if($anyNative){IteratorPrototype=getPrototypeOf($anyNative.call(new Base));if(IteratorPrototype!==Object.prototype&&IteratorPrototype.next){setToStringTag(IteratorPrototype,TAG,true);if(!LIBRARY&&!has(IteratorPrototype,ITERATOR))hide(IteratorPrototype,ITERATOR,returnThis)}}if(DEF_VALUES&&$native&&$native.name!==VALUES){VALUES_BUG=true;$default=function values(){return $native.call(this)}}if((!LIBRARY||FORCED)&&(BUGGY||VALUES_BUG||!proto[ITERATOR])){hide(proto,ITERATOR,$default)}Iterators[NAME]=$default;Iterators[TAG]=returnThis;if(DEFAULT){methods={values:DEF_VALUES?$default:getMethod(VALUES),keys:IS_SET?$default:getMethod(KEYS),entries:$entries};if(FORCED)for(key in methods){if(!(key in proto))redefine(proto,key,methods[key])}else $export($export.P+$export.F*(BUGGY||VALUES_BUG),NAME,methods)}return methods}},function(module,exports,__webpack_require__){var aFunction=__webpack_require__(128);module.exports=function(fn,that,length){aFunction(fn);if(that===undefined)return fn;switch(length){case 1:return function(a){return fn.call(that,a)};case 2:return function(a,b){return fn.call(that,a,b)};case 3:return function(a,b,c){return fn.call(that,a,b,c)}}return function(){return fn.apply(that,arguments)}}},function(module,exports,__webpack_require__){module.exports=!__webpack_require__(21)&&!__webpack_require__(28)(function(){return Object.defineProperty(__webpack_require__(82)(\"div\"),\"a\",{get:function(){return 7}}).a!=7})},function(module,exports,__webpack_require__){var isObject=__webpack_require__(32);var document=__webpack_require__(18).document;var is=isObject(document)&&isObject(document.createElement);module.exports=function(it){return is?document.createElement(it):{}}},function(module,exports,__webpack_require__){module.exports=__webpack_require__(26)},function(module,exports,__webpack_require__){var has=__webpack_require__(22);var toIObject=__webpack_require__(25);var arrayIndexOf=__webpack_require__(131)(false);var IE_PROTO=__webpack_require__(56)(\"IE_PROTO\");module.exports=function(object,names){var O=toIObject(object);var i=0;var result=[];var key;for(key in O)if(key!=IE_PROTO)has(O,key)&&result.push(key);while(names.length>i)if(has(O,key=names[i++])){~arrayIndexOf(result,key)||result.push(key)}return result}},function(module,exports,__webpack_require__){var has=__webpack_require__(22);var toObject=__webpack_require__(41);var IE_PROTO=__webpack_require__(56)(\"IE_PROTO\");var ObjectProto=Object.prototype;module.exports=Object.getPrototypeOf||function(O){O=toObject(O);if(has(O,IE_PROTO))return O[IE_PROTO];if(typeof O.constructor==\"function\"&&O instanceof O.constructor){return O.constructor.prototype}return O instanceof Object?ObjectProto:null}},function(module,exports,__webpack_require__){var cof=__webpack_require__(50);var TAG=__webpack_require__(13)(\"toStringTag\");var ARG=cof(function(){return arguments}())==\"Arguments\";var tryGet=function(it,key){try{return it[key]}catch(e){}};module.exports=function(it){var O,T,B;return it===undefined?\"Undefined\":it===null?\"Null\":typeof(T=tryGet(O=Object(it),TAG))==\"string\"?T:ARG?cof(O):(B=cof(O))==\"Object\"&&typeof O.callee==\"function\"?\"Arguments\":B}},function(module,exports,__webpack_require__){var $export=__webpack_require__(17);var core=__webpack_require__(7);var fails=__webpack_require__(28);module.exports=function(KEY,exec){var fn=(core.Object||{})[KEY]||Object[KEY];var exp={};exp[KEY]=exec(fn);$export($export.S+$export.F*fails(function(){fn(1)}),\"Object\",exp)}},function(module,exports,__webpack_require__){var $keys=__webpack_require__(84);var hiddenKeys=__webpack_require__(58).concat(\"length\",\"prototype\");exports.f=Object.getOwnPropertyNames||function getOwnPropertyNames(O){return $keys(O,hiddenKeys)}},function(module,exports,__webpack_require__){var pIE=__webpack_require__(42);var createDesc=__webpack_require__(39);var toIObject=__webpack_require__(25);var toPrimitive=__webpack_require__(53);var has=__webpack_require__(22);var IE8_DOM_DEFINE=__webpack_require__(81);var gOPD=Object.getOwnPropertyDescriptor;exports.f=__webpack_require__(21)?gOPD:function getOwnPropertyDescriptor(O,P){O=toIObject(O);P=toPrimitive(P,true);if(IE8_DOM_DEFINE)try{return gOPD(O,P)}catch(e){}if(has(O,P))return createDesc(!pIE.f.call(O,P),O[P])}},function(module,exports,__webpack_require__){module.exports={default:__webpack_require__(162),__esModule:true}},function(module,exports,__webpack_require__){\"use strict\";function Point2d(x,y){this.x=x!==undefined?x:0;this.y=y!==undefined?y:0}module.exports=Point2d},function(module,exports,__webpack_require__){\"use strict\";var util=__webpack_require__(2);function Slider(container,options){if(container===undefined){throw new Error(\"No container element defined\")}this.container=container;this.visible=options&&options.visible!=undefined?options.visible:true;if(this.visible){this.frame=document.createElement(\"DIV\");this.frame.style.width=\"100%\";this.frame.style.position=\"relative\";this.container.appendChild(this.frame);this.frame.prev=document.createElement(\"INPUT\");this.frame.prev.type=\"BUTTON\";this.frame.prev.value=\"Prev\";this.frame.appendChild(this.frame.prev);this.frame.play=document.createElement(\"INPUT\");this.frame.play.type=\"BUTTON\";this.frame.play.value=\"Play\";this.frame.appendChild(this.frame.play);this.frame.next=document.createElement(\"INPUT\");this.frame.next.type=\"BUTTON\";this.frame.next.value=\"Next\";this.frame.appendChild(this.frame.next);this.frame.bar=document.createElement(\"INPUT\");this.frame.bar.type=\"BUTTON\";this.frame.bar.style.position=\"absolute\";this.frame.bar.style.border=\"1px solid red\";this.frame.bar.style.width=\"100px\";this.frame.bar.style.height=\"6px\";this.frame.bar.style.borderRadius=\"2px\";this.frame.bar.style.MozBorderRadius=\"2px\";this.frame.bar.style.border=\"1px solid #7F7F7F\";this.frame.bar.style.backgroundColor=\"#E5E5E5\";this.frame.appendChild(this.frame.bar);this.frame.slide=document.createElement(\"INPUT\");this.frame.slide.type=\"BUTTON\";this.frame.slide.style.margin=\"0px\";this.frame.slide.value=\" \";this.frame.slide.style.position=\"relative\";this.frame.slide.style.left=\"-100px\";this.frame.appendChild(this.frame.slide);var me=this;this.frame.slide.onmousedown=function(event){me._onMouseDown(event)};this.frame.prev.onclick=function(event){me.prev(event)};this.frame.play.onclick=function(event){me.togglePlay(event)};this.frame.next.onclick=function(event){me.next(event)}}this.onChangeCallback=undefined;this.values=[];this.index=undefined;this.playTimeout=undefined;this.playInterval=1e3;this.playLoop=true}Slider.prototype.prev=function(){var index=this.getIndex();if(index>0){index--;this.setIndex(index)}};Slider.prototype.next=function(){var index=this.getIndex();if(index<this.values.length-1){index++;this.setIndex(index)}};Slider.prototype.playNext=function(){var start=new Date;var index=this.getIndex();if(index<this.values.length-1){index++;this.setIndex(index)}else if(this.playLoop){index=0;this.setIndex(index)}var end=new Date;var diff=end-start;var interval=Math.max(this.playInterval-diff,0);var me=this;this.playTimeout=setTimeout(function(){me.playNext()},interval)};Slider.prototype.togglePlay=function(){if(this.playTimeout===undefined){this.play()}else{this.stop()}};Slider.prototype.play=function(){if(this.playTimeout)return;this.playNext();if(this.frame){this.frame.play.value=\"Stop\"}};Slider.prototype.stop=function(){clearInterval(this.playTimeout);this.playTimeout=undefined;if(this.frame){this.frame.play.value=\"Play\"}};Slider.prototype.setOnChangeCallback=function(callback){this.onChangeCallback=callback};Slider.prototype.setPlayInterval=function(interval){this.playInterval=interval};Slider.prototype.getPlayInterval=function(){return this.playInterval};Slider.prototype.setPlayLoop=function(doLoop){this.playLoop=doLoop};Slider.prototype.onChange=function(){if(this.onChangeCallback!==undefined){this.onChangeCallback()}};Slider.prototype.redraw=function(){if(this.frame){this.frame.bar.style.top=this.frame.clientHeight/2-this.frame.bar.offsetHeight/2+\"px\";this.frame.bar.style.width=this.frame.clientWidth-this.frame.prev.clientWidth-this.frame.play.clientWidth-this.frame.next.clientWidth-30+\"px\";var left=this.indexToLeft(this.index);this.frame.slide.style.left=left+\"px\"}};Slider.prototype.setValues=function(values){this.values=values;if(this.values.length>0)this.setIndex(0);else this.index=undefined};Slider.prototype.setIndex=function(index){if(index<this.values.length){this.index=index;this.redraw();this.onChange()}else{throw new Error(\"Index out of range\")}};Slider.prototype.getIndex=function(){return this.index};Slider.prototype.get=function(){return this.values[this.index]};Slider.prototype._onMouseDown=function(event){var leftButtonDown=event.which?event.which===1:event.button===1;if(!leftButtonDown)return;this.startClientX=event.clientX;this.startSlideX=parseFloat(this.frame.slide.style.left);this.frame.style.cursor=\"move\";var me=this;this.onmousemove=function(event){me._onMouseMove(event)};this.onmouseup=function(event){me._onMouseUp(event)};util.addEventListener(document,\"mousemove\",this.onmousemove);util.addEventListener(document,\"mouseup\",this.onmouseup);util.preventDefault(event)};Slider.prototype.leftToIndex=function(left){var width=parseFloat(this.frame.bar.style.width)-this.frame.slide.clientWidth-10;var x=left-3;var index=Math.round(x/width*(this.values.length-1));if(index<0)index=0;if(index>this.values.length-1)index=this.values.length-1;return index};Slider.prototype.indexToLeft=function(index){var width=parseFloat(this.frame.bar.style.width)-this.frame.slide.clientWidth-10;var x=index/(this.values.length-1)*width;var left=x+3;return left};Slider.prototype._onMouseMove=function(event){var diff=event.clientX-this.startClientX;var x=this.startSlideX+diff;var index=this.leftToIndex(x);this.setIndex(index);util.preventDefault()};Slider.prototype._onMouseUp=function(event){this.frame.style.cursor=\"auto\";util.removeEventListener(document,\"mousemove\",this.onmousemove);util.removeEventListener(document,\"mouseup\",this.onmouseup);util.preventDefault()};module.exports=Slider},function(module,exports,__webpack_require__){\"use strict\";function StepNumber(start,end,step,prettyStep){this._start=0;this._end=0;this._step=1;this.prettyStep=true;this.precision=5;this._current=0;this.setRange(start,end,step,prettyStep)}StepNumber.prototype.isNumeric=function(n){return!isNaN(parseFloat(n))&&isFinite(n)};StepNumber.prototype.setRange=function(start,end,step,prettyStep){if(!this.isNumeric(start)){throw new Error(\"Parameter 'start' is not numeric; value: \"+start)}if(!this.isNumeric(end)){throw new Error(\"Parameter 'end' is not numeric; value: \"+start)}if(!this.isNumeric(step)){throw new Error(\"Parameter 'step' is not numeric; value: \"+start)}this._start=start?start:0;this._end=end?end:0;this.setStep(step,prettyStep)};StepNumber.prototype.setStep=function(step,prettyStep){if(step===undefined||step<=0)return;if(prettyStep!==undefined)this.prettyStep=prettyStep;if(this.prettyStep===true)this._step=StepNumber.calculatePrettyStep(step);else this._step=step};StepNumber.calculatePrettyStep=function(step){var log10=function log10(x){return Math.log(x)/Math.LN10};var step1=Math.pow(10,Math.round(log10(step))),step2=2*Math.pow(10,Math.round(log10(step/2))),step5=5*Math.pow(10,Math.round(log10(step/5)));var prettyStep=step1;if(Math.abs(step2-step)<=Math.abs(prettyStep-step))prettyStep=step2;if(Math.abs(step5-step)<=Math.abs(prettyStep-step))prettyStep=step5;if(prettyStep<=0){prettyStep=1}return prettyStep};StepNumber.prototype.getCurrent=function(){return parseFloat(this._current.toPrecision(this.precision))};StepNumber.prototype.getStep=function(){return this._step};StepNumber.prototype.start=function(checkFirst){if(checkFirst===undefined){checkFirst=false}this._current=this._start-this._start%this._step;if(checkFirst){if(this.getCurrent()<this._start){this.next()}}};StepNumber.prototype.next=function(){this._current+=this._step};StepNumber.prototype.end=function(){return this._current>this._end};module.exports=StepNumber},function(module,exports,__webpack_require__){\"use strict\";var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var Camera=__webpack_require__(95);var Point3d=__webpack_require__(34);var STYLE={BAR:0,BARCOLOR:1,BARSIZE:2,DOT:3,DOTLINE:4,DOTCOLOR:5,DOTSIZE:6,GRID:7,LINE:8,SURFACE:9};var STYLENAME={dot:STYLE.DOT,\"dot-line\":STYLE.DOTLINE,\"dot-color\":STYLE.DOTCOLOR,\"dot-size\":STYLE.DOTSIZE,line:STYLE.LINE,grid:STYLE.GRID,surface:STYLE.SURFACE,bar:STYLE.BAR,\"bar-color\":STYLE.BARCOLOR,\"bar-size\":STYLE.BARSIZE};var OPTIONKEYS=[\"width\",\"height\",\"filterLabel\",\"legendLabel\",\"xLabel\",\"yLabel\",\"zLabel\",\"xValueLabel\",\"yValueLabel\",\"zValueLabel\",\"showXAxis\",\"showYAxis\",\"showZAxis\",\"showGrid\",\"showPerspective\",\"showShadow\",\"keepAspectRatio\",\"verticalRatio\",\"dotSizeRatio\",\"dotSizeMinFraction\",\"dotSizeMaxFraction\",\"showAnimationControls\",\"animationInterval\",\"animationPreload\",\"animationAutoStart\",\"axisColor\",\"gridColor\",\"xCenter\",\"yCenter\"];var PREFIXEDOPTIONKEYS=[\"xBarWidth\",\"yBarWidth\",\"valueMin\",\"valueMax\",\"xMin\",\"xMax\",\"xStep\",\"yMin\",\"yMax\",\"yStep\",\"zMin\",\"zMax\",\"zStep\"];var DEFAULTS=undefined;function isEmpty(obj){for(var prop in obj){if(obj.hasOwnProperty(prop))return false}return true}function capitalize(str){if(str===undefined||str===\"\"||typeof str!=\"string\"){return str}return str.charAt(0).toUpperCase()+str.slice(1)}function prefixFieldName(prefix,fieldName){if(prefix===undefined||prefix===\"\"){return fieldName}return prefix+capitalize(fieldName)}function forceCopy(src,dst,fields,prefix){var srcKey;var dstKey;for(var i=0;i<fields.length;++i){srcKey=fields[i];dstKey=prefixFieldName(prefix,srcKey);dst[dstKey]=src[srcKey]}}function safeCopy(src,dst,fields,prefix){var srcKey;var dstKey;for(var i=0;i<fields.length;++i){srcKey=fields[i];if(src[srcKey]===undefined)continue;dstKey=prefixFieldName(prefix,srcKey);dst[dstKey]=src[srcKey]}}function setDefaults(src,dst){if(src===undefined||isEmpty(src)){throw new Error(\"No DEFAULTS passed\")}if(dst===undefined){throw new Error(\"No dst passed\")}DEFAULTS=src;forceCopy(src,dst,OPTIONKEYS);forceCopy(src,dst,PREFIXEDOPTIONKEYS,\"default\");setSpecialSettings(src,dst);dst.margin=10;dst.showGrayBottom=false;dst.showTooltip=false;dst.onclick_callback=null;dst.eye=new Point3d(0,0,-1)}function setOptions(options,dst){if(options===undefined){return}if(dst===undefined){throw new Error(\"No dst passed\")}if(DEFAULTS===undefined||isEmpty(DEFAULTS)){throw new Error(\"DEFAULTS not set for module Settings\")}safeCopy(options,dst,OPTIONKEYS);safeCopy(options,dst,PREFIXEDOPTIONKEYS,\"default\");setSpecialSettings(options,dst)}function setSpecialSettings(src,dst){if(src.backgroundColor!==undefined){setBackgroundColor(src.backgroundColor,dst)}setDataColor(src.dataColor,dst);setStyle(src.style,dst);setShowLegend(src.showLegend,dst);setCameraPosition(src.cameraPosition,dst);if(src.tooltip!==undefined){dst.showTooltip=src.tooltip}if(src.onclick!=undefined){dst.onclick_callback=src.onclick}if(src.tooltipStyle!==undefined){util.selectiveDeepExtend([\"tooltipStyle\"],dst,src)}}function setShowLegend(showLegend,dst){if(showLegend===undefined){var isAutoByDefault=DEFAULTS.showLegend===undefined;if(isAutoByDefault){var isLegendGraphStyle=dst.style===STYLE.DOTCOLOR||dst.style===STYLE.DOTSIZE;dst.showLegend=isLegendGraphStyle}else{}}else{dst.showLegend=showLegend}}function getStyleNumberByName(styleName){var number=STYLENAME[styleName];if(number===undefined){return-1}return number}function checkStyleNumber(style){var valid=false;for(var n in STYLE){if(STYLE[n]===style){valid=true;break}}return valid}function setStyle(style,dst){if(style===undefined){return}var styleNumber;if(typeof style===\"string\"){styleNumber=getStyleNumberByName(style);if(styleNumber===-1){throw new Error(\"Style '\"+style+\"' is invalid\")}}else{if(!checkStyleNumber(style)){throw new Error(\"Style '\"+style+\"' is invalid\")}styleNumber=style}dst.style=styleNumber}function setBackgroundColor(backgroundColor,dst){var fill=\"white\";var stroke=\"gray\";var strokeWidth=1;if(typeof backgroundColor===\"string\"){fill=backgroundColor;stroke=\"none\";strokeWidth=0}else if((typeof backgroundColor===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(backgroundColor))===\"object\"){if(backgroundColor.fill!==undefined)fill=backgroundColor.fill;if(backgroundColor.stroke!==undefined)stroke=backgroundColor.stroke;if(backgroundColor.strokeWidth!==undefined)strokeWidth=backgroundColor.strokeWidth}else{throw new Error(\"Unsupported type of backgroundColor\")}dst.frame.style.backgroundColor=fill;dst.frame.style.borderColor=stroke;dst.frame.style.borderWidth=strokeWidth+\"px\";dst.frame.style.borderStyle=\"solid\"}function setDataColor(dataColor,dst){if(dataColor===undefined){return}if(dst.dataColor===undefined){dst.dataColor={}}if(typeof dataColor===\"string\"){dst.dataColor.fill=dataColor;dst.dataColor.stroke=dataColor}else{if(dataColor.fill){dst.dataColor.fill=dataColor.fill}if(dataColor.stroke){dst.dataColor.stroke=dataColor.stroke}if(dataColor.strokeWidth!==undefined){dst.dataColor.strokeWidth=dataColor.strokeWidth}}}function setCameraPosition(cameraPosition,dst){var camPos=cameraPosition;if(camPos===undefined){return}if(dst.camera===undefined){dst.camera=new Camera}dst.camera.setArmRotation(camPos.horizontal,camPos.vertical);dst.camera.setArmLength(camPos.distance)}module.exports.STYLE=STYLE;module.exports.setDefaults=setDefaults;module.exports.setOptions=setOptions;module.exports.setCameraPosition=setCameraPosition},function(module,exports,__webpack_require__){\"use strict\";var _sign=__webpack_require__(165);var _sign2=_interopRequireDefault(_sign);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Point3d=__webpack_require__(34);function Camera(){this.armLocation=new Point3d;this.armRotation={};this.armRotation.horizontal=0;this.armRotation.vertical=0;this.armLength=1.7;this.cameraOffset=new Point3d;this.offsetMultiplier=.6;this.cameraLocation=new Point3d;this.cameraRotation=new Point3d(.5*Math.PI,0,0);this.calculateCameraOrientation()}Camera.prototype.setOffset=function(x,y){var abs=Math.abs,sign=_sign2[\"default\"],mul=this.offsetMultiplier,border=this.armLength*mul;if(abs(x)>border){x=sign(x)*border}if(abs(y)>border){y=sign(y)*border}this.cameraOffset.x=x;this.cameraOffset.y=y;this.calculateCameraOrientation()};Camera.prototype.getOffset=function(){return this.cameraOffset};Camera.prototype.setArmLocation=function(x,y,z){this.armLocation.x=x;this.armLocation.y=y;this.armLocation.z=z;this.calculateCameraOrientation()};Camera.prototype.setArmRotation=function(horizontal,vertical){if(horizontal!==undefined){this.armRotation.horizontal=horizontal}if(vertical!==undefined){this.armRotation.vertical=vertical;if(this.armRotation.vertical<0)this.armRotation.vertical=0;if(this.armRotation.vertical>.5*Math.PI)this.armRotation.vertical=.5*Math.PI}if(horizontal!==undefined||vertical!==undefined){this.calculateCameraOrientation()}};Camera.prototype.getArmRotation=function(){var rot={};rot.horizontal=this.armRotation.horizontal;rot.vertical=this.armRotation.vertical;return rot};Camera.prototype.setArmLength=function(length){if(length===undefined)return;this.armLength=length;if(this.armLength<.71)this.armLength=.71;if(this.armLength>5)this.armLength=5;this.setOffset(this.cameraOffset.x,this.cameraOffset.y);this.calculateCameraOrientation()};Camera.prototype.getArmLength=function(){return this.armLength};Camera.prototype.getCameraLocation=function(){return this.cameraLocation};Camera.prototype.getCameraRotation=function(){return this.cameraRotation};Camera.prototype.calculateCameraOrientation=function(){this.cameraLocation.x=this.armLocation.x-this.armLength*Math.sin(this.armRotation.horizontal)*Math.cos(this.armRotation.vertical);this.cameraLocation.y=this.armLocation.y-this.armLength*Math.cos(this.armRotation.horizontal)*Math.cos(this.armRotation.vertical);this.cameraLocation.z=this.armLocation.z+this.armLength*Math.sin(this.armRotation.vertical);this.cameraRotation.x=Math.PI/2-this.armRotation.vertical;this.cameraRotation.y=0;this.cameraRotation.z=-this.armRotation.horizontal;var xa=this.cameraRotation.x;var za=this.cameraRotation.z;var dx=this.cameraOffset.x;var dy=this.cameraOffset.y;var sin=Math.sin,cos=Math.cos;this.cameraLocation.x=this.cameraLocation.x+dx*cos(za)+dy*-sin(za)*cos(xa);this.cameraLocation.y=this.cameraLocation.y+dx*sin(za)+dy*cos(za)*cos(xa);this.cameraLocation.z=this.cameraLocation.z+dy*sin(xa)};module.exports=Camera},function(module,exports,__webpack_require__){\"use strict\";var DataView=__webpack_require__(12);function Filter(dataGroup,column,graph){this.dataGroup=dataGroup;this.column=column;this.graph=graph;this.index=undefined;this.value=undefined;this.values=dataGroup.getDistinctValues(this.column);if(this.values.length>0){this.selectValue(0)}this.dataPoints=[];this.loaded=false;this.onLoadCallback=undefined;if(graph.animationPreload){this.loaded=false;this.loadInBackground()}else{this.loaded=true}}Filter.prototype.isLoaded=function(){return this.loaded};Filter.prototype.getLoadedProgress=function(){var len=this.values.length;var i=0;while(this.dataPoints[i]){i++}return Math.round(i/len*100)};Filter.prototype.getLabel=function(){return this.graph.filterLabel};Filter.prototype.getColumn=function(){return this.column};Filter.prototype.getSelectedValue=function(){if(this.index===undefined)return undefined;return this.values[this.index]};Filter.prototype.getValues=function(){return this.values};Filter.prototype.getValue=function(index){if(index>=this.values.length)throw new Error(\"Index out of range\");return this.values[index]};Filter.prototype._getDataPoints=function(index){if(index===undefined)index=this.index;if(index===undefined)return[];var dataPoints;if(this.dataPoints[index]){dataPoints=this.dataPoints[index]}else{var f={};f.column=this.column;f.value=this.values[index];var dataView=new DataView(this.dataGroup.getDataSet(),{filter:function filter(item){return item[f.column]==f.value}}).get();dataPoints=this.dataGroup._getDataPoints(dataView);this.dataPoints[index]=dataPoints}return dataPoints};Filter.prototype.setOnLoadCallback=function(callback){this.onLoadCallback=callback};Filter.prototype.selectValue=function(index){if(index>=this.values.length)throw new Error(\"Index out of range\");this.index=index;this.value=this.values[index]};Filter.prototype.loadInBackground=function(index){if(index===undefined)index=0;var frame=this.graph.frame;if(index<this.values.length){if(frame.progress===undefined){frame.progress=document.createElement(\"DIV\");frame.progress.style.position=\"absolute\";frame.progress.style.color=\"gray\";frame.appendChild(frame.progress)}var progress=this.getLoadedProgress();frame.progress.innerHTML=\"Loading animation... \"+progress+\"%\";frame.progress.style.bottom=60+\"px\";frame.progress.style.left=10+\"px\";var me=this;setTimeout(function(){me.loadInBackground(index+1)},10);this.loaded=false}else{this.loaded=true;if(frame.progress!==undefined){frame.removeChild(frame.progress);frame.progress=undefined}if(this.onLoadCallback)this.onLoadCallback()}};module.exports=Filter},function(module,exports,__webpack_require__){\"use strict\";var keycharm=__webpack_require__(35);var Emitter=__webpack_require__(44);var Hammer=__webpack_require__(10);var util=__webpack_require__(2);function Activator(container){this.active=false;this.dom={container:container};this.dom.overlay=document.createElement(\"div\");this.dom.overlay.className=\"vis-overlay\";this.dom.container.appendChild(this.dom.overlay);this.hammer=Hammer(this.dom.overlay);this.hammer.on(\"tap\",this._onTapOverlay.bind(this));var me=this;var events=[\"tap\",\"doubletap\",\"press\",\"pinch\",\"pan\",\"panstart\",\"panmove\",\"panend\"];events.forEach(function(event){me.hammer.on(event,function(event){event.stopPropagation()})});if(document&&document.body){this.onClick=function(event){if(!_hasParent(event.target,container)){me.deactivate()}};document.body.addEventListener(\"click\",this.onClick)}if(this.keycharm!==undefined){this.keycharm.destroy()}this.keycharm=keycharm();this.escListener=this.deactivate.bind(this)}Emitter(Activator.prototype);Activator.current=null;Activator.prototype.destroy=function(){this.deactivate();this.dom.overlay.parentNode.removeChild(this.dom.overlay);if(this.onClick){document.body.removeEventListener(\"click\",this.onClick)}this.hammer.destroy();this.hammer=null};Activator.prototype.activate=function(){if(Activator.current){Activator.current.deactivate()}Activator.current=this;this.active=true;this.dom.overlay.style.display=\"none\";util.addClassName(this.dom.container,\"vis-active\");this.emit(\"change\");this.emit(\"activate\");this.keycharm.bind(\"esc\",this.escListener)};Activator.prototype.deactivate=function(){this.active=false;this.dom.overlay.style.display=\"\";util.removeClassName(this.dom.container,\"vis-active\");this.keycharm.unbind(\"esc\",this.escListener);this.emit(\"change\");this.emit(\"deactivate\")};Activator.prototype._onTapOverlay=function(event){this.activate();event.stopPropagation()};function _hasParent(element,parent){while(element){if(element===parent){return true}element=element.parentNode}return false}module.exports=Activator},function(module,exports,__webpack_require__){\"use strict\";exports[\"en\"]={current:\"current\",time:\"time\"};exports[\"en_EN\"]=exports[\"en\"];exports[\"en_US\"]=exports[\"en\"];exports[\"it\"]={current:\"attuale\",time:\"tempo\"};exports[\"it_IT\"]=exports[\"it\"];exports[\"it_CH\"]=exports[\"it\"];exports[\"nl\"]={current:\"huidige\",time:\"tijd\"};exports[\"nl_NL\"]=exports[\"nl\"];exports[\"nl_BE\"]=exports[\"nl\"];exports[\"de\"]={current:\"Aktuelle\",time:\"Zeit\"};exports[\"de_DE\"]=exports[\"de\"];exports[\"fr\"]={current:\"actuel\",time:\"heure\"};exports[\"fr_FR\"]=exports[\"fr\"];exports[\"fr_CA\"]=exports[\"fr\"];exports[\"fr_BE\"]=exports[\"fr\"];exports[\"es\"]={current:\"corriente\",time:\"hora\"};exports[\"es_ES\"]=exports[\"es\"]},function(module,exports,__webpack_require__){\"use strict\";var _create=__webpack_require__(29);var _create2=_interopRequireDefault(_create);var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Hammer=__webpack_require__(10);var util=__webpack_require__(2);var DataSet=__webpack_require__(11);var DataView=__webpack_require__(12);var TimeStep=__webpack_require__(66);var Component=__webpack_require__(16);var Group=__webpack_require__(68);var BackgroundGroup=__webpack_require__(69);var BoxItem=__webpack_require__(101);var PointItem=__webpack_require__(102);var RangeItem=__webpack_require__(70);var BackgroundItem=__webpack_require__(103);var Popup=__webpack_require__(104)[\"default\"];var UNGROUPED=\"__ungrouped__\";var BACKGROUND=\"__background__\";function ItemSet(body,options){this.body=body;this.defaultOptions={type:null,orientation:{item:\"bottom\"},align:\"auto\",stack:true,stackSubgroups:true,groupOrderSwap:function groupOrderSwap(fromGroup,toGroup,groups){var targetOrder=toGroup.order;toGroup.order=fromGroup.order;fromGroup.order=targetOrder},groupOrder:\"order\",selectable:true,multiselect:false,itemsAlwaysDraggable:{item:false,range:false},editable:{updateTime:false,updateGroup:false,add:false,remove:false,overrideItems:false},groupEditable:{order:false,add:false,remove:false},snap:TimeStep.snap,onDropObjectOnItem:function onDropObjectOnItem(objectData,item,callback){callback(item)},onAdd:function onAdd(item,callback){callback(item)},onUpdate:function onUpdate(item,callback){callback(item)},onMove:function onMove(item,callback){callback(item)},onRemove:function onRemove(item,callback){callback(item)},onMoving:function onMoving(item,callback){callback(item)},onAddGroup:function onAddGroup(item,callback){callback(item)},onMoveGroup:function onMoveGroup(item,callback){callback(item)},onRemoveGroup:function onRemoveGroup(item,callback){callback(item)},margin:{item:{horizontal:10,vertical:10},axis:20},showTooltips:true,tooltip:{followMouse:false,overflowMethod:\"flip\"},tooltipOnItemUpdateTime:false};this.options=util.extend({},this.defaultOptions);this.options.rtl=options.rtl;this.itemOptions={type:{start:\"Date\",end:\"Date\"}};this.conversion={toScreen:body.util.toScreen,toTime:body.util.toTime};this.dom={};this.props={};this.hammer=null;var me=this;this.itemsData=null;this.groupsData=null;this.itemListeners={add:function add(event,params,senderId){me._onAdd(params.items)},update:function update(event,params,senderId){me._onUpdate(params.items)},remove:function remove(event,params,senderId){me._onRemove(params.items)}};this.groupListeners={add:function add(event,params,senderId){me._onAddGroups(params.items);if(me.groupsData&&me.groupsData.length>0){var groupsData=me.groupsData.getDataSet();groupsData.get().forEach(function(groupData){if(groupData.nestedGroups){if(groupData.showNested!=false){groupData.showNested=true}var updatedGroups=[];groupData.nestedGroups.forEach(function(nestedGroupId){var updatedNestedGroup=groupsData.get(nestedGroupId);if(!updatedNestedGroup){return}updatedNestedGroup.nestedInGroup=groupData.id;if(groupData.showNested==false){updatedNestedGroup.visible=false}updatedGroups=updatedGroups.concat(updatedNestedGroup)});groupsData.update(updatedGroups,senderId)}})}},update:function update(event,params,senderId){me._onUpdateGroups(params.items)},remove:function remove(event,params,senderId){me._onRemoveGroups(params.items)}};this.items={};this.groups={};this.groupIds=[];this.selection=[];this.popup=null;this.touchParams={};this.groupTouchParams={};this._create();this.setOptions(options)}ItemSet.prototype=new Component;ItemSet.types={background:BackgroundItem,box:BoxItem,range:RangeItem,point:PointItem};ItemSet.prototype._create=function(){var frame=document.createElement(\"div\");frame.className=\"vis-itemset\";frame[\"timeline-itemset\"]=this;this.dom.frame=frame;var background=document.createElement(\"div\");background.className=\"vis-background\";frame.appendChild(background);this.dom.background=background;var foreground=document.createElement(\"div\");foreground.className=\"vis-foreground\";frame.appendChild(foreground);this.dom.foreground=foreground;var axis=document.createElement(\"div\");axis.className=\"vis-axis\";this.dom.axis=axis;var labelSet=document.createElement(\"div\");labelSet.className=\"vis-labelset\";this.dom.labelSet=labelSet;this._updateUngrouped();var backgroundGroup=new BackgroundGroup(BACKGROUND,null,this);backgroundGroup.show();this.groups[BACKGROUND]=backgroundGroup;this.hammer=new Hammer(this.body.dom.centerContainer);this.hammer.on(\"hammer.input\",function(event){if(event.isFirst){this._onTouch(event)}}.bind(this));this.hammer.on(\"panstart\",this._onDragStart.bind(this));this.hammer.on(\"panmove\",this._onDrag.bind(this));this.hammer.on(\"panend\",this._onDragEnd.bind(this));this.hammer.get(\"pan\").set({threshold:5,direction:Hammer.DIRECTION_HORIZONTAL});this.hammer.on(\"tap\",this._onSelectItem.bind(this));this.hammer.on(\"press\",this._onMultiSelectItem.bind(this));this.hammer.on(\"doubletap\",this._onAddItem.bind(this));if(this.options.rtl){\nthis.groupHammer=new Hammer(this.body.dom.rightContainer)}else{this.groupHammer=new Hammer(this.body.dom.leftContainer)}this.groupHammer.on(\"tap\",this._onGroupClick.bind(this));this.groupHammer.on(\"panstart\",this._onGroupDragStart.bind(this));this.groupHammer.on(\"panmove\",this._onGroupDrag.bind(this));this.groupHammer.on(\"panend\",this._onGroupDragEnd.bind(this));this.groupHammer.get(\"pan\").set({threshold:5,direction:Hammer.DIRECTION_VERTICAL});this.body.dom.centerContainer.addEventListener(\"mouseover\",this._onMouseOver.bind(this));this.body.dom.centerContainer.addEventListener(\"mouseout\",this._onMouseOut.bind(this));this.body.dom.centerContainer.addEventListener(\"mousemove\",this._onMouseMove.bind(this));this.body.dom.centerContainer.addEventListener(\"contextmenu\",this._onDragEnd.bind(this));this.body.dom.centerContainer.addEventListener(\"mousewheel\",this._onMouseWheel.bind(this));this.show()};ItemSet.prototype.setOptions=function(options){if(options){var fields=[\"type\",\"rtl\",\"align\",\"order\",\"stack\",\"stackSubgroups\",\"selectable\",\"multiselect\",\"multiselectPerGroup\",\"groupOrder\",\"dataAttributes\",\"template\",\"groupTemplate\",\"visibleFrameTemplate\",\"hide\",\"snap\",\"groupOrderSwap\",\"showTooltips\",\"tooltip\",\"tooltipOnItemUpdateTime\"];util.selectiveExtend(fields,this.options,options);if(\"itemsAlwaysDraggable\"in options){if(typeof options.itemsAlwaysDraggable===\"boolean\"){this.options.itemsAlwaysDraggable.item=options.itemsAlwaysDraggable;this.options.itemsAlwaysDraggable.range=false}else if((0,_typeof3[\"default\"])(options.itemsAlwaysDraggable)===\"object\"){util.selectiveExtend([\"item\",\"range\"],this.options.itemsAlwaysDraggable,options.itemsAlwaysDraggable);if(!this.options.itemsAlwaysDraggable.item){this.options.itemsAlwaysDraggable.range=false}}}if(\"orientation\"in options){if(typeof options.orientation===\"string\"){this.options.orientation.item=options.orientation===\"top\"?\"top\":\"bottom\"}else if((0,_typeof3[\"default\"])(options.orientation)===\"object\"&&\"item\"in options.orientation){this.options.orientation.item=options.orientation.item}}if(\"margin\"in options){if(typeof options.margin===\"number\"){this.options.margin.axis=options.margin;this.options.margin.item.horizontal=options.margin;this.options.margin.item.vertical=options.margin}else if((0,_typeof3[\"default\"])(options.margin)===\"object\"){util.selectiveExtend([\"axis\"],this.options.margin,options.margin);if(\"item\"in options.margin){if(typeof options.margin.item===\"number\"){this.options.margin.item.horizontal=options.margin.item;this.options.margin.item.vertical=options.margin.item}else if((0,_typeof3[\"default\"])(options.margin.item)===\"object\"){util.selectiveExtend([\"horizontal\",\"vertical\"],this.options.margin.item,options.margin.item)}}}}if(\"editable\"in options){if(typeof options.editable===\"boolean\"){this.options.editable.updateTime=options.editable;this.options.editable.updateGroup=options.editable;this.options.editable.add=options.editable;this.options.editable.remove=options.editable;this.options.editable.overrideItems=false}else if((0,_typeof3[\"default\"])(options.editable)===\"object\"){util.selectiveExtend([\"updateTime\",\"updateGroup\",\"add\",\"remove\",\"overrideItems\"],this.options.editable,options.editable)}}if(\"groupEditable\"in options){if(typeof options.groupEditable===\"boolean\"){this.options.groupEditable.order=options.groupEditable;this.options.groupEditable.add=options.groupEditable;this.options.groupEditable.remove=options.groupEditable}else if((0,_typeof3[\"default\"])(options.groupEditable)===\"object\"){util.selectiveExtend([\"order\",\"add\",\"remove\"],this.options.groupEditable,options.groupEditable)}}var addCallback=function(name){var fn=options[name];if(fn){if(!(fn instanceof Function)){throw new Error(\"option \"+name+\" must be a function \"+name+\"(item, callback)\")}this.options[name]=fn}}.bind(this);[\"onDropObjectOnItem\",\"onAdd\",\"onUpdate\",\"onRemove\",\"onMove\",\"onMoving\",\"onAddGroup\",\"onMoveGroup\",\"onRemoveGroup\"].forEach(addCallback);this.markDirty()}};ItemSet.prototype.markDirty=function(options){this.groupIds=[];if(options&&options.refreshItems){util.forEach(this.items,function(item){item.dirty=true;if(item.displayed)item.redraw()})}};ItemSet.prototype.destroy=function(){this.hide();this.setItems(null);this.setGroups(null);this.hammer=null;this.body=null;this.conversion=null};ItemSet.prototype.hide=function(){if(this.dom.frame.parentNode){this.dom.frame.parentNode.removeChild(this.dom.frame)}if(this.dom.axis.parentNode){this.dom.axis.parentNode.removeChild(this.dom.axis)}if(this.dom.labelSet.parentNode){this.dom.labelSet.parentNode.removeChild(this.dom.labelSet)}};ItemSet.prototype.show=function(){if(!this.dom.frame.parentNode){this.body.dom.center.appendChild(this.dom.frame)}if(!this.dom.axis.parentNode){this.body.dom.backgroundVertical.appendChild(this.dom.axis)}if(!this.dom.labelSet.parentNode){if(this.options.rtl){this.body.dom.right.appendChild(this.dom.labelSet)}else{this.body.dom.left.appendChild(this.dom.labelSet)}}};ItemSet.prototype.setSelection=function(ids){var i,ii,id,item;if(ids==undefined)ids=[];if(!Array.isArray(ids))ids=[ids];for(i=0,ii=this.selection.length;i<ii;i++){id=this.selection[i];item=this.items[id];if(item)item.unselect()}this.selection=[];for(i=0,ii=ids.length;i<ii;i++){id=ids[i];item=this.items[id];if(item){this.selection.push(id);item.select()}}};ItemSet.prototype.getSelection=function(){return this.selection.concat([])};ItemSet.prototype.getVisibleItems=function(){var range=this.body.range.getRange();var right,left;if(this.options.rtl){right=this.body.util.toScreen(range.start);left=this.body.util.toScreen(range.end)}else{left=this.body.util.toScreen(range.start);right=this.body.util.toScreen(range.end)}var ids=[];for(var groupId in this.groups){if(this.groups.hasOwnProperty(groupId)){var group=this.groups[groupId];var rawVisibleItems=group.isVisible?group.visibleItems:[];for(var i=0;i<rawVisibleItems.length;i++){var item=rawVisibleItems[i];if(this.options.rtl){if(item.right<left&&item.right+item.width>right){ids.push(item.id)}}else{if(item.left<right&&item.left+item.width>left){ids.push(item.id)}}}}}return ids};ItemSet.prototype._deselect=function(id){var selection=this.selection;for(var i=0,ii=selection.length;i<ii;i++){if(selection[i]==id){selection.splice(i,1);break}}};ItemSet.prototype.redraw=function(){var margin=this.options.margin,range=this.body.range,asSize=util.option.asSize,options=this.options,orientation=options.orientation.item,resized=false,frame=this.dom.frame;this.props.top=this.body.domProps.top.height+this.body.domProps.border.top;if(this.options.rtl){this.props.right=this.body.domProps.right.width+this.body.domProps.border.right}else{this.props.left=this.body.domProps.left.width+this.body.domProps.border.left}frame.className=\"vis-itemset\";resized=this._orderGroups()||resized;var visibleInterval=range.end-range.start;var zoomed=visibleInterval!=this.lastVisibleInterval||this.props.width!=this.props.lastWidth;var scrolled=range.start!=this.lastRangeStart;var changedStackOption=options.stack!=this.lastStack;var changedStackSubgroupsOption=options.stackSubgroups!=this.lastStackSubgroups;var forceRestack=zoomed||scrolled||changedStackOption||changedStackSubgroupsOption;this.lastVisibleInterval=visibleInterval;this.lastRangeStart=range.start;this.lastStack=options.stack;this.lastStackSubgroups=options.stackSubgroups;this.props.lastWidth=this.props.width;var firstGroup=this._firstGroup();var firstMargin={item:margin.item,axis:margin.axis};var nonFirstMargin={item:margin.item,axis:margin.item.vertical/2};var height=0;var minHeight=margin.axis+margin.item.vertical;this.groups[BACKGROUND].redraw(range,nonFirstMargin,forceRestack);var redrawQueue={};var redrawQueueLength=0;util.forEach(this.groups,function(group,key){if(key===BACKGROUND)return;var groupMargin=group==firstGroup?firstMargin:nonFirstMargin;var returnQueue=true;redrawQueue[key]=group.redraw(range,groupMargin,forceRestack,returnQueue);redrawQueueLength=redrawQueue[key].length});var needRedraw=redrawQueueLength>0;if(needRedraw){var redrawResults={};for(var i=0;i<redrawQueueLength;i++){util.forEach(redrawQueue,function(fns,key){redrawResults[key]=fns[i]()})}util.forEach(this.groups,function(group,key){if(key===BACKGROUND)return;var groupResized=redrawResults[key];resized=groupResized||resized;height+=group.height});height=Math.max(height,minHeight)}height=Math.max(height,minHeight);frame.style.height=asSize(height);this.props.width=frame.offsetWidth;this.props.height=height;this.dom.axis.style.top=asSize(orientation==\"top\"?this.body.domProps.top.height+this.body.domProps.border.top:this.body.domProps.top.height+this.body.domProps.centerContainer.height);if(this.options.rtl){this.dom.axis.style.right=\"0\"}else{this.dom.axis.style.left=\"0\"}this.initialItemSetDrawn=true;resized=this._isResized()||resized;return resized};ItemSet.prototype._firstGroup=function(){var firstGroupIndex=this.options.orientation.item==\"top\"?0:this.groupIds.length-1;var firstGroupId=this.groupIds[firstGroupIndex];var firstGroup=this.groups[firstGroupId]||this.groups[UNGROUPED];return firstGroup||null};ItemSet.prototype._updateUngrouped=function(){var ungrouped=this.groups[UNGROUPED];var item,itemId;if(this.groupsData){if(ungrouped){ungrouped.hide();delete this.groups[UNGROUPED];for(itemId in this.items){if(this.items.hasOwnProperty(itemId)){item=this.items[itemId];item.parent&&item.parent.remove(item);var groupId=this._getGroupId(item.data);var group=this.groups[groupId];group&&group.add(item)||item.hide()}}}}else{if(!ungrouped){var id=null;var data=null;ungrouped=new Group(id,data,this);this.groups[UNGROUPED]=ungrouped;for(itemId in this.items){if(this.items.hasOwnProperty(itemId)){item=this.items[itemId];ungrouped.add(item)}}ungrouped.show()}}};ItemSet.prototype.getLabelSet=function(){return this.dom.labelSet};ItemSet.prototype.setItems=function(items){var me=this,ids,oldItemsData=this.itemsData;if(!items){this.itemsData=null}else if(items instanceof DataSet||items instanceof DataView){this.itemsData=items}else{throw new TypeError(\"Data must be an instance of DataSet or DataView\")}if(oldItemsData){util.forEach(this.itemListeners,function(callback,event){oldItemsData.off(event,callback)});ids=oldItemsData.getIds();this._onRemove(ids)}if(this.itemsData){var id=this.id;util.forEach(this.itemListeners,function(callback,event){me.itemsData.on(event,callback,id)});ids=this.itemsData.getIds();this._onAdd(ids);this._updateUngrouped()}this.body.emitter.emit(\"_change\",{queue:true})};ItemSet.prototype.getItems=function(){return this.itemsData};ItemSet.prototype.setGroups=function(groups){var me=this,ids;if(this.groupsData){util.forEach(this.groupListeners,function(callback,event){me.groupsData.off(event,callback)});ids=this.groupsData.getIds();this.groupsData=null;this._onRemoveGroups(ids)}if(!groups){this.groupsData=null}else if(groups instanceof DataSet||groups instanceof DataView){this.groupsData=groups}else{throw new TypeError(\"Data must be an instance of DataSet or DataView\")}if(this.groupsData){var groupsData=this.groupsData;if(this.groupsData instanceof DataView){groupsData=this.groupsData.getDataSet()}groupsData.get().forEach(function(group){if(group.nestedGroups){group.nestedGroups.forEach(function(nestedGroupId){var updatedNestedGroup=groupsData.get(nestedGroupId);updatedNestedGroup.nestedInGroup=group.id;if(group.showNested==false){updatedNestedGroup.visible=false}groupsData.update(updatedNestedGroup)})}});var id=this.id;util.forEach(this.groupListeners,function(callback,event){me.groupsData.on(event,callback,id)});ids=this.groupsData.getIds();this._onAddGroups(ids)}this._updateUngrouped();this._order();this.body.emitter.emit(\"_change\",{queue:true})};ItemSet.prototype.getGroups=function(){return this.groupsData};ItemSet.prototype.removeItem=function(id){var item=this.itemsData.get(id),dataset=this.itemsData.getDataSet();if(item){this.options.onRemove(item,function(item){if(item){dataset.remove(id)}})}};ItemSet.prototype._getType=function(itemData){return itemData.type||this.options.type||(itemData.end?\"range\":\"box\")};ItemSet.prototype._getGroupId=function(itemData){var type=this._getType(itemData);if(type==\"background\"&&itemData.group==undefined){return BACKGROUND}else{return this.groupsData?itemData.group:UNGROUPED}};ItemSet.prototype._onUpdate=function(ids){var me=this;ids.forEach(function(id){var itemData=me.itemsData.get(id,me.itemOptions);var item=me.items[id];var type=itemData?me._getType(itemData):null;var constructor=ItemSet.types[type];var selected;if(item){if(!constructor||!(item instanceof constructor)){selected=item.selected;me._removeItem(item);item=null}else{me._updateItem(item,itemData)}}if(!item&&itemData){if(constructor){item=new constructor(itemData,me.conversion,me.options);item.id=id;me._addItem(item);if(selected){this.selection.push(id);item.select()}}else if(type==\"rangeoverflow\"){throw new TypeError('Item type \"rangeoverflow\" is deprecated. Use css styling instead: '+\".vis-item.vis-range .vis-item-content {overflow: visible;}\")}else{throw new TypeError('Unknown item type \"'+type+'\"')}}}.bind(this));this._order();this.body.emitter.emit(\"_change\",{queue:true})};ItemSet.prototype._onAdd=ItemSet.prototype._onUpdate;ItemSet.prototype._onRemove=function(ids){var count=0;var me=this;ids.forEach(function(id){var item=me.items[id];if(item){count++;me._removeItem(item)}});if(count){this._order();this.body.emitter.emit(\"_change\",{queue:true})}};ItemSet.prototype._order=function(){util.forEach(this.groups,function(group){group.order()})};ItemSet.prototype._onUpdateGroups=function(ids){this._onAddGroups(ids)};ItemSet.prototype._onAddGroups=function(ids){var me=this;ids.forEach(function(id){var groupData=me.groupsData.get(id);var group=me.groups[id];if(!group){if(id==UNGROUPED||id==BACKGROUND){throw new Error(\"Illegal group id. \"+id+\" is a reserved id.\")}var groupOptions=(0,_create2[\"default\"])(me.options);util.extend(groupOptions,{height:null});group=new Group(id,groupData,me);me.groups[id]=group;for(var itemId in me.items){if(me.items.hasOwnProperty(itemId)){var item=me.items[itemId];if(item.data.group==id){group.add(item)}}}group.order();group.show()}else{group.setData(groupData)}});this.body.emitter.emit(\"_change\",{queue:true})};ItemSet.prototype._onRemoveGroups=function(ids){var groups=this.groups;ids.forEach(function(id){var group=groups[id];if(group){group.hide();delete groups[id]}});this.markDirty();this.body.emitter.emit(\"_change\",{queue:true})};ItemSet.prototype._orderGroups=function(){if(this.groupsData){var groupIds=this.groupsData.getIds({order:this.options.groupOrder});groupIds=this._orderNestedGroups(groupIds);var changed=!util.equalArray(groupIds,this.groupIds);if(changed){var groups=this.groups;groupIds.forEach(function(groupId){groups[groupId].hide()});groupIds.forEach(function(groupId){groups[groupId].show()});this.groupIds=groupIds}return changed}else{return false}};ItemSet.prototype._orderNestedGroups=function(groupIds){var newGroupIdsOrder=[];groupIds.forEach(function(groupId){var groupData=this.groupsData.get(groupId);if(!groupData.nestedInGroup){newGroupIdsOrder.push(groupId)}if(groupData.nestedGroups){var nestedGroups=this.groupsData.get({filter:function filter(nestedGroup){return nestedGroup.nestedInGroup==groupId},order:this.options.groupOrder});var nestedGroupIds=nestedGroups.map(function(nestedGroup){return nestedGroup.id});newGroupIdsOrder=newGroupIdsOrder.concat(nestedGroupIds)}},this);return newGroupIdsOrder};ItemSet.prototype._addItem=function(item){this.items[item.id]=item;var groupId=this._getGroupId(item.data);var group=this.groups[groupId];if(!group){item.groupShowing=false}else if(group&&group.data&&group.data.showNested){item.groupShowing=true}if(group)group.add(item)};ItemSet.prototype._updateItem=function(item,itemData){item.setData(itemData);var groupId=this._getGroupId(item.data);var group=this.groups[groupId];if(!group){item.groupShowing=false}else if(group&&group.data&&group.data.showNested){item.groupShowing=true}};ItemSet.prototype._removeItem=function(item){item.hide();delete this.items[item.id];var index=this.selection.indexOf(item.id);if(index!=-1)this.selection.splice(index,1);item.parent&&item.parent.remove(item)};ItemSet.prototype._constructByEndArray=function(array){var endArray=[];for(var i=0;i<array.length;i++){if(array[i]instanceof RangeItem){endArray.push(array[i])}}return endArray};ItemSet.prototype._onTouch=function(event){this.touchParams.item=this.itemFromTarget(event);this.touchParams.dragLeftItem=event.target.dragLeftItem||false;this.touchParams.dragRightItem=event.target.dragRightItem||false;this.touchParams.itemProps=null};ItemSet.prototype._getGroupIndex=function(groupId){for(var i=0;i<this.groupIds.length;i++){if(groupId==this.groupIds[i])return i}};ItemSet.prototype._onDragStart=function(event){if(this.touchParams.itemIsDragging){return}var item=this.touchParams.item||null;var me=this;var props;if(item&&(item.selected||this.options.itemsAlwaysDraggable.item)){if(this.options.editable.overrideItems&&!this.options.editable.updateTime&&!this.options.editable.updateGroup){return}if(item.editable!=null&&!item.editable.updateTime&&!item.editable.updateGroup&&!this.options.editable.overrideItems){return}var dragLeftItem=this.touchParams.dragLeftItem;var dragRightItem=this.touchParams.dragRightItem;this.touchParams.itemIsDragging=true;this.touchParams.selectedItem=item;if(dragLeftItem){props={item:dragLeftItem,initialX:event.center.x,dragLeft:true,data:this._cloneItemData(item.data)};this.touchParams.itemProps=[props]}else if(dragRightItem){props={item:dragRightItem,initialX:event.center.x,dragRight:true,data:this._cloneItemData(item.data)};this.touchParams.itemProps=[props]}else if(this.options.editable.add&&(event.srcEvent.ctrlKey||event.srcEvent.metaKey)){this._onDragStartAddItem(event)}else{if(this.groupIds.length<1){this.redraw()}var baseGroupIndex=this._getGroupIndex(item.data.group);var itemsToDrag=this.options.itemsAlwaysDraggable.item&&!item.selected?[item.id]:this.getSelection();this.touchParams.itemProps=itemsToDrag.map(function(id){var item=me.items[id];var groupIndex=me._getGroupIndex(item.data.group);return{item:item,initialX:event.center.x,groupOffset:baseGroupIndex-groupIndex,data:this._cloneItemData(item.data)}}.bind(this))}event.stopPropagation()}else if(this.options.editable.add&&(event.srcEvent.ctrlKey||event.srcEvent.metaKey)){this._onDragStartAddItem(event)}};ItemSet.prototype._onDragStartAddItem=function(event){var xAbs;var x;var snap=this.options.snap||null;if(this.options.rtl){xAbs=util.getAbsoluteRight(this.dom.frame);x=xAbs-event.center.x+10}else{xAbs=util.getAbsoluteLeft(this.dom.frame);x=event.center.x-xAbs-10}var time=this.body.util.toTime(x);var scale=this.body.util.getScale();var step=this.body.util.getStep();var start=snap?snap(time,scale,step):time;var end=start;var itemData={type:\"range\",start:start,end:end,content:\"new item\"};var id=util.randomUUID();itemData[this.itemsData._fieldId]=id;var group=this.groupFromTarget(event);if(group){itemData.group=group.groupId}var newItem=new RangeItem(itemData,this.conversion,this.options);newItem.id=id;newItem.data=this._cloneItemData(itemData);this._addItem(newItem);this.touchParams.selectedItem=newItem;var props={item:newItem,initialX:event.center.x,data:newItem.data};if(this.options.rtl){props.dragLeft=true}else{props.dragRight=true}this.touchParams.itemProps=[props];event.stopPropagation()};ItemSet.prototype._onDrag=function(event){if(this.touchParams.itemProps){event.stopPropagation();var me=this;var snap=this.options.snap||null;var xOffset;if(this.options.rtl){xOffset=this.body.dom.root.offsetLeft+this.body.domProps.right.width}else{xOffset=this.body.dom.root.offsetLeft+this.body.domProps.left.width}var scale=this.body.util.getScale();var step=this.body.util.getStep();var selectedItem=this.touchParams.selectedItem;var updateGroupAllowed=(this.options.editable.overrideItems||selectedItem.editable==null)&&this.options.editable.updateGroup||!this.options.editable.overrideItems&&selectedItem.editable!=null&&selectedItem.editable.updateGroup;var newGroupBase=null;if(updateGroupAllowed&&selectedItem){if(selectedItem.data.group!=undefined){var group=me.groupFromTarget(event);if(group){newGroupBase=this._getGroupIndex(group.groupId)}}}this.touchParams.itemProps.forEach(function(props){var current=me.body.util.toTime(event.center.x-xOffset);var initial=me.body.util.toTime(props.initialX-xOffset);var offset;var initialStart;var initialEnd;var start;var end;if(this.options.rtl){offset=-(current-initial)}else{offset=current-initial}var itemData=this._cloneItemData(props.item.data);if(props.item.editable!=null&&!props.item.editable.updateTime&&!props.item.editable.updateGroup&&!me.options.editable.overrideItems){return}var updateTimeAllowed=(this.options.editable.overrideItems||selectedItem.editable==null)&&this.options.editable.updateTime||!this.options.editable.overrideItems&&selectedItem.editable!=null&&selectedItem.editable.updateTime;if(updateTimeAllowed){if(props.dragLeft){if(this.options.rtl){if(itemData.end!=undefined){initialEnd=util.convert(props.data.end,\"Date\");end=new Date(initialEnd.valueOf()+offset);itemData.end=snap?snap(end,scale,step):end}}else{if(itemData.start!=undefined){initialStart=util.convert(props.data.start,\"Date\");start=new Date(initialStart.valueOf()+offset);itemData.start=snap?snap(start,scale,step):start}}}else if(props.dragRight){if(this.options.rtl){if(itemData.start!=undefined){initialStart=util.convert(props.data.start,\"Date\");start=new Date(initialStart.valueOf()+offset);itemData.start=snap?snap(start,scale,step):start}}else{if(itemData.end!=undefined){initialEnd=util.convert(props.data.end,\"Date\");end=new Date(initialEnd.valueOf()+offset);itemData.end=snap?snap(end,scale,step):end}}}else{if(itemData.start!=undefined){initialStart=util.convert(props.data.start,\"Date\").valueOf();start=new Date(initialStart+offset);if(itemData.end!=undefined){initialEnd=util.convert(props.data.end,\"Date\");var duration=initialEnd.valueOf()-initialStart.valueOf();itemData.start=snap?snap(start,scale,step):start;itemData.end=new Date(itemData.start.valueOf()+duration)}else{itemData.start=snap?snap(start,scale,step):start}}}}if(updateGroupAllowed&&!props.dragLeft&&!props.dragRight&&newGroupBase!=null){if(itemData.group!=undefined){var newOffset=newGroupBase-props.groupOffset;newOffset=Math.max(0,newOffset);newOffset=Math.min(me.groupIds.length-1,newOffset);itemData.group=me.groupIds[newOffset]}}itemData=this._cloneItemData(itemData);me.options.onMoving(itemData,function(itemData){if(itemData){props.item.setData(this._cloneItemData(itemData,\"Date\"))}}.bind(this))}.bind(this));this.body.emitter.emit(\"_change\")}};ItemSet.prototype._moveToGroup=function(item,groupId){var group=this.groups[groupId];if(group&&group.groupId!=item.data.group){var oldGroup=item.parent;oldGroup.remove(item);oldGroup.order();item.data.group=group.groupId;group.add(item);group.order()}};ItemSet.prototype._onDragEnd=function(event){this.touchParams.itemIsDragging=false;if(this.touchParams.itemProps){event.stopPropagation();var me=this;var dataset=this.itemsData.getDataSet();var itemProps=this.touchParams.itemProps;this.touchParams.itemProps=null;itemProps.forEach(function(props){var id=props.item.id;var exists=me.itemsData.get(id,me.itemOptions)!=null;if(!exists){me.options.onAdd(props.item.data,function(itemData){me._removeItem(props.item);if(itemData){me.itemsData.getDataSet().add(itemData)}me.body.emitter.emit(\"_change\")})}else{var itemData=this._cloneItemData(props.item.data);me.options.onMove(itemData,function(itemData){if(itemData){itemData[dataset._fieldId]=id;dataset.update(itemData)}else{props.item.setData(props.data);me.body.emitter.emit(\"_change\")}})}}.bind(this))}};ItemSet.prototype._onGroupClick=function(event){var group=this.groupFromTarget(event);if(!group||!group.nestedGroups)return;var groupsData=this.groupsData.getDataSet();var nestingGroup=groupsData.get(group.groupId);if(nestingGroup.showNested==undefined){nestingGroup.showNested=true}nestingGroup.showNested=!nestingGroup.showNested;var nestedGroups=groupsData.get(group.nestedGroups).map(function(nestedGroup){nestedGroup.visible=nestingGroup.showNested;return nestedGroup});groupsData.update(nestedGroups.concat(nestingGroup));if(nestingGroup.showNested){util.removeClassName(group.dom.label,\"collapsed\");util.addClassName(group.dom.label,\"expanded\")}else{util.removeClassName(group.dom.label,\"expanded\");var collapsedDirClassName=this.options.rtl?\"collapsed-rtl\":\"collapsed\";util.addClassName(group.dom.label,collapsedDirClassName)}};ItemSet.prototype._onGroupDragStart=function(event){if(this.options.groupEditable.order){this.groupTouchParams.group=this.groupFromTarget(event);if(this.groupTouchParams.group){event.stopPropagation();this.groupTouchParams.originalOrder=this.groupsData.getIds({order:this.options.groupOrder})}}};ItemSet.prototype._onGroupDrag=function(event){if(this.options.groupEditable.order&&this.groupTouchParams.group){event.stopPropagation();var groupsData=this.groupsData;if(this.groupsData instanceof DataView){groupsData=this.groupsData.getDataSet()}var group=this.groupFromTarget(event);if(group&&group.height!=this.groupTouchParams.group.height){var movingUp=group.top<this.groupTouchParams.group.top;var clientY=event.center?event.center.y:event.clientY;var targetGroupTop=util.getAbsoluteTop(group.dom.foreground);var draggedGroupHeight=this.groupTouchParams.group.height;if(movingUp){if(targetGroupTop+draggedGroupHeight<clientY){return}}else{var targetGroupHeight=group.height;if(targetGroupTop+targetGroupHeight-draggedGroupHeight>clientY){return}}}if(group&&group!=this.groupTouchParams.group){var targetGroup=groupsData.get(group.groupId);var draggedGroup=groupsData.get(this.groupTouchParams.group.groupId);if(draggedGroup&&targetGroup){this.options.groupOrderSwap(draggedGroup,targetGroup,groupsData);groupsData.update(draggedGroup);groupsData.update(targetGroup)}var newOrder=groupsData.getIds({order:this.options.groupOrder});if(!util.equalArray(newOrder,this.groupTouchParams.originalOrder)){var origOrder=this.groupTouchParams.originalOrder;var draggedId=this.groupTouchParams.group.groupId;var numGroups=Math.min(origOrder.length,newOrder.length);var curPos=0;var newOffset=0;var orgOffset=0;while(curPos<numGroups){while(curPos+newOffset<numGroups&&curPos+orgOffset<numGroups&&newOrder[curPos+newOffset]==origOrder[curPos+orgOffset]){curPos++}if(curPos+newOffset>=numGroups){break}if(newOrder[curPos+newOffset]==draggedId){newOffset=1}else if(origOrder[curPos+orgOffset]==draggedId){orgOffset=1}else{var slippedPosition=newOrder.indexOf(origOrder[curPos+orgOffset]);var switchGroup=groupsData.get(newOrder[curPos+newOffset]);var shouldBeGroup=groupsData.get(origOrder[curPos+orgOffset]);this.options.groupOrderSwap(switchGroup,shouldBeGroup,groupsData);groupsData.update(switchGroup);groupsData.update(shouldBeGroup);var switchGroupId=newOrder[curPos+newOffset];newOrder[curPos+newOffset]=origOrder[curPos+orgOffset];newOrder[slippedPosition]=switchGroupId;curPos++}}}}}};ItemSet.prototype._onGroupDragEnd=function(event){if(this.options.groupEditable.order&&this.groupTouchParams.group){event.stopPropagation();var me=this;var id=me.groupTouchParams.group.groupId;var dataset=me.groupsData.getDataSet();var groupData=util.extend({},dataset.get(id));me.options.onMoveGroup(groupData,function(groupData){if(groupData){groupData[dataset._fieldId]=id;dataset.update(groupData)}else{var newOrder=dataset.getIds({order:me.options.groupOrder});if(!util.equalArray(newOrder,me.groupTouchParams.originalOrder)){var origOrder=me.groupTouchParams.originalOrder;var numGroups=Math.min(origOrder.length,newOrder.length);var curPos=0;while(curPos<numGroups){while(curPos<numGroups&&newOrder[curPos]==origOrder[curPos]){curPos++}if(curPos>=numGroups){break}var slippedPosition=newOrder.indexOf(origOrder[curPos]);var switchGroup=dataset.get(newOrder[curPos]);var shouldBeGroup=dataset.get(origOrder[curPos]);me.options.groupOrderSwap(switchGroup,shouldBeGroup,dataset);dataset.update(switchGroup);dataset.update(shouldBeGroup);var switchGroupId=newOrder[curPos];newOrder[curPos]=origOrder[curPos];newOrder[slippedPosition]=switchGroupId;curPos++}}}});me.body.emitter.emit(\"groupDragged\",{groupId:id})}};ItemSet.prototype._onSelectItem=function(event){if(!this.options.selectable)return;var ctrlKey=event.srcEvent&&(event.srcEvent.ctrlKey||event.srcEvent.metaKey);var shiftKey=event.srcEvent&&event.srcEvent.shiftKey;if(ctrlKey||shiftKey){this._onMultiSelectItem(event);return}var oldSelection=this.getSelection();var item=this.itemFromTarget(event);var selection=item?[item.id]:[];this.setSelection(selection);var newSelection=this.getSelection();if(newSelection.length>0||oldSelection.length>0){this.body.emitter.emit(\"select\",{items:newSelection,event:event})}};ItemSet.prototype._onMouseOver=function(event){var item=this.itemFromTarget(event);if(!item)return;var related=this.itemFromRelatedTarget(event);if(item===related){return}var title=item.getTitle();if(this.options.showTooltips&&title){if(this.popup==null){this.popup=new Popup(this.body.dom.root,this.options.tooltip.overflowMethod||\"flip\")}this.popup.setText(title);var container=this.body.dom.centerContainer;this.popup.setPosition(event.clientX-util.getAbsoluteLeft(container)+container.offsetLeft,event.clientY-util.getAbsoluteTop(container)+container.offsetTop);this.popup.show()}else{if(this.popup!=null){this.popup.hide()}}this.body.emitter.emit(\"itemover\",{item:item.id,event:event})};ItemSet.prototype._onMouseOut=function(event){var item=this.itemFromTarget(event);if(!item)return;var related=this.itemFromRelatedTarget(event);if(item===related){return}if(this.popup!=null){this.popup.hide()}this.body.emitter.emit(\"itemout\",{item:item.id,event:event})};ItemSet.prototype._onMouseMove=function(event){var item=this.itemFromTarget(event);if(!item)return;if(this.options.showTooltips&&this.options.tooltip.followMouse){if(this.popup){if(!this.popup.hidden){var container=this.body.dom.centerContainer;this.popup.setPosition(event.clientX-util.getAbsoluteLeft(container)+container.offsetLeft,event.clientY-util.getAbsoluteTop(container)+container.offsetTop);this.popup.show()}}}};ItemSet.prototype._onMouseWheel=function(event){if(this.touchParams.itemIsDragging){this._onDragEnd(event)}};ItemSet.prototype._onUpdateItem=function(item){if(!this.options.selectable)return;if(!this.options.editable.add)return;var me=this;if(item){var itemData=me.itemsData.get(item.id);this.options.onUpdate(itemData,function(itemData){if(itemData){me.itemsData.getDataSet().update(itemData)}})}};ItemSet.prototype._onDropObjectOnItem=function(event){var item=this.itemFromTarget(event);var objectData=JSON.parse(event.dataTransfer.getData(\"text\"));this.options.onDropObjectOnItem(objectData,item)};ItemSet.prototype._onAddItem=function(event){if(!this.options.selectable)return;if(!this.options.editable.add)return;var me=this;var snap=this.options.snap||null;var xAbs;var x;if(this.options.rtl){xAbs=util.getAbsoluteRight(this.dom.frame);x=xAbs-event.center.x}else{xAbs=util.getAbsoluteLeft(this.dom.frame);x=event.center.x-xAbs}var start=this.body.util.toTime(x);var scale=this.body.util.getScale();var step=this.body.util.getStep();var end;var newItemData;if(event.type==\"drop\"){newItemData=JSON.parse(event.dataTransfer.getData(\"text\"));newItemData.content=newItemData.content?newItemData.content:\"new item\";newItemData.start=newItemData.start?newItemData.start:snap?snap(start,scale,step):start;newItemData.type=newItemData.type||\"box\";newItemData[this.itemsData._fieldId]=newItemData.id||util.randomUUID();if(newItemData.type==\"range\"&&!newItemData.end){end=this.body.util.toTime(x+this.props.width/5);newItemData.end=snap?snap(end,scale,step):end}}else{newItemData={start:snap?snap(start,scale,step):start,content:\"new item\"};newItemData[this.itemsData._fieldId]=util.randomUUID();if(this.options.type===\"range\"){\nend=this.body.util.toTime(x+this.props.width/5);newItemData.end=snap?snap(end,scale,step):end}}var group=this.groupFromTarget(event);if(group){newItemData.group=group.groupId}newItemData=this._cloneItemData(newItemData);this.options.onAdd(newItemData,function(item){if(item){me.itemsData.getDataSet().add(item);if(event.type==\"drop\"){me.setSelection([item.id])}}})};ItemSet.prototype._onMultiSelectItem=function(event){if(!this.options.selectable)return;var item=this.itemFromTarget(event);if(item){var selection=this.options.multiselect?this.getSelection():[];var shiftKey=event.srcEvent&&event.srcEvent.shiftKey||false;if(shiftKey&&this.options.multiselect){var itemGroup=this.itemsData.get(item.id).group;var lastSelectedGroup=undefined;if(this.options.multiselectPerGroup){if(selection.length>0){lastSelectedGroup=this.itemsData.get(selection[0]).group}}if(!this.options.multiselectPerGroup||lastSelectedGroup==undefined||lastSelectedGroup==itemGroup){selection.push(item.id)}var range=ItemSet._getItemRange(this.itemsData.get(selection,this.itemOptions));if(!this.options.multiselectPerGroup||lastSelectedGroup==itemGroup){selection=[];for(var id in this.items){if(this.items.hasOwnProperty(id)){var _item=this.items[id];var start=_item.data.start;var end=_item.data.end!==undefined?_item.data.end:start;if(start>=range.min&&end<=range.max&&(!this.options.multiselectPerGroup||lastSelectedGroup==this.itemsData.get(_item.id).group)&&!(_item instanceof BackgroundItem)){selection.push(_item.id)}}}}}else{var index=selection.indexOf(item.id);if(index==-1){selection.push(item.id)}else{selection.splice(index,1)}}this.setSelection(selection);this.body.emitter.emit(\"select\",{items:this.getSelection(),event:event})}};ItemSet._getItemRange=function(itemsData){var max=null;var min=null;itemsData.forEach(function(data){if(min==null||data.start<min){min=data.start}if(data.end!=undefined){if(max==null||data.end>max){max=data.end}}else{if(max==null||data.start>max){max=data.start}}});return{min:min,max:max}};ItemSet.prototype.itemFromElement=function(element){var cur=element;while(cur){if(cur.hasOwnProperty(\"timeline-item\")){return cur[\"timeline-item\"]}cur=cur.parentNode}return null};ItemSet.prototype.itemFromTarget=function(event){return this.itemFromElement(event.target)};ItemSet.prototype.itemFromRelatedTarget=function(event){return this.itemFromElement(event.relatedTarget)};ItemSet.prototype.groupFromTarget=function(event){var clientY=event.center?event.center.y:event.clientY;var groupIds=this.groupIds;if(groupIds.length<=0&&this.groupsData){groupIds=this.groupsData.getIds({order:this.options.groupOrder})}for(var i=0;i<groupIds.length;i++){var groupId=groupIds[i];var group=this.groups[groupId];var foreground=group.dom.foreground;var top=util.getAbsoluteTop(foreground);if(clientY>top&&clientY<top+foreground.offsetHeight){return group}if(this.options.orientation.item===\"top\"){if(i===this.groupIds.length-1&&clientY>top){return group}}else{if(i===0&&clientY<top+foreground.offset){return group}}}return null};ItemSet.itemSetFromTarget=function(event){var target=event.target;while(target){if(target.hasOwnProperty(\"timeline-itemset\")){return target[\"timeline-itemset\"]}target=target.parentNode}return null};ItemSet.prototype._cloneItemData=function(itemData,type){var clone=util.extend({},itemData);if(!type){type=this.itemsData.getDataSet()._options.type}if(clone.start!=undefined){clone.start=util.convert(clone.start,type&&type.start||\"Date\")}if(clone.end!=undefined){clone.end=util.convert(clone.end,type&&type.end||\"Date\")}return clone};module.exports=ItemSet},function(module,exports,__webpack_require__){\"use strict\";var EPSILON=.001;exports.orderByStart=function(items){items.sort(function(a,b){return a.data.start-b.data.start})};exports.orderByEnd=function(items){items.sort(function(a,b){var aTime=\"end\"in a.data?a.data.end:a.data.start,bTime=\"end\"in b.data?b.data.end:b.data.start;return aTime-bTime})};exports.stack=function(items,margin,force){if(force){for(var i=0;i<items.length;i++){items[i].top=null}}for(var i=0;i<items.length;i++){var item=items[i];if(item.stack&&item.top===null){item.top=margin.axis;do{var collidingItem=null;for(var j=0,jj=items.length;j<jj;j++){var other=items[j];if(other.top!==null&&other!==item&&other.stack&&exports.collision(item,other,margin.item,other.options.rtl)){collidingItem=other;break}}if(collidingItem!=null){item.top=collidingItem.top+collidingItem.height+margin.item.vertical}}while(collidingItem)}}};exports.substack=function(items,margin,subgroup){for(var i=0;i<items.length;i++){items[i].top=null}var subgroupHeight=subgroup.height;for(i=0;i<items.length;i++){var item=items[i];if(item.stack&&item.top===null){item.top=item.baseTop;do{var collidingItem=null;for(var j=0,jj=items.length;j<jj;j++){var other=items[j];if(other.top!==null&&other!==item&&exports.collision(item,other,margin.item,other.options.rtl)){collidingItem=other;break}}if(collidingItem!=null){item.top=collidingItem.top+collidingItem.height+margin.item.vertical}if(item.top+item.height>subgroupHeight){subgroupHeight=item.top+item.height}}while(collidingItem)}}subgroup.height=subgroupHeight-subgroup.top+.5*margin.item.vertical};exports.nostack=function(items,margin,subgroups,stackSubgroups){for(var i=0;i<items.length;i++){if(items[i].data.subgroup==undefined){items[i].top=margin.item.vertical}else if(items[i].data.subgroup!==undefined&&stackSubgroups){var newTop=0;for(var subgroup in subgroups){if(subgroups.hasOwnProperty(subgroup)){if(subgroups[subgroup].visible==true&&subgroups[subgroup].index<subgroups[items[i].data.subgroup].index){newTop+=subgroups[subgroup].height;subgroups[items[i].data.subgroup].top=newTop}}}items[i].top=newTop+.5*margin.item.vertical}}if(!stackSubgroups){exports.stackSubgroups(items,margin,subgroups)}};exports.stackSubgroups=function(items,margin,subgroups){for(var subgroup in subgroups){if(subgroups.hasOwnProperty(subgroup)){subgroups[subgroup].top=0;do{var collidingItem=null;for(var otherSubgroup in subgroups){if(subgroups[otherSubgroup].top!==null&&otherSubgroup!==subgroup&&subgroups[subgroup].index>subgroups[otherSubgroup].index&&exports.collisionByTimes(subgroups[subgroup],subgroups[otherSubgroup])){collidingItem=subgroups[otherSubgroup];break}}if(collidingItem!=null){subgroups[subgroup].top=collidingItem.top+collidingItem.height}}while(collidingItem)}}for(var i=0;i<items.length;i++){if(items[i].data.subgroup!==undefined){items[i].top=subgroups[items[i].data.subgroup].top+.5*margin.item.vertical}}};exports.stackSubgroupsWithInnerStack=function(subgroupItems,margin,subgroups){var doSubStack=false;var subgroupOrder=[];for(var subgroup in subgroups){if(subgroups[subgroup].hasOwnProperty(\"index\")){subgroupOrder[subgroups[subgroup].index]=subgroup}else{subgroupOrder.push(subgroup)}}for(var j=0;j<subgroupOrder.length;j++){subgroup=subgroupOrder[j];if(subgroups.hasOwnProperty(subgroup)){doSubStack=doSubStack||subgroups[subgroup].stack;subgroups[subgroup].top=0;for(var otherSubgroup in subgroups){if(subgroups[otherSubgroup].visible&&subgroups[subgroup].index>subgroups[otherSubgroup].index){subgroups[subgroup].top+=subgroups[otherSubgroup].height}}var items=subgroupItems[subgroup];for(var i=0;i<items.length;i++){if(items[i].data.subgroup!==undefined){items[i].top=subgroups[items[i].data.subgroup].top+.5*margin.item.vertical;if(subgroups[subgroup].stack){items[i].baseTop=items[i].top}}}if(doSubStack&&subgroups[subgroup].stack){exports.substack(subgroupItems[subgroup],margin,subgroups[subgroup])}}}};exports.collision=function(a,b,margin,rtl){if(rtl){return a.right-margin.horizontal+EPSILON<b.right+b.width&&a.right+a.width+margin.horizontal-EPSILON>b.right&&a.top-margin.vertical+EPSILON<b.top+b.height&&a.top+a.height+margin.vertical-EPSILON>b.top}else{return a.left-margin.horizontal+EPSILON<b.left+b.width&&a.left+a.width+margin.horizontal-EPSILON>b.left&&a.top-margin.vertical+EPSILON<b.top+b.height&&a.top+a.height+margin.vertical-EPSILON>b.top}};exports.collisionByTimes=function(a,b){return a.start<=b.start&&a.end>=b.start&&a.top<b.top+b.height&&a.top+a.height>b.top||b.start<=a.start&&b.end>=a.start&&b.top<a.top+a.height&&b.top+b.height>a.top}},function(module,exports,__webpack_require__){\"use strict\";var Item=__webpack_require__(38);function BoxItem(data,conversion,options){this.props={dot:{width:0,height:0},line:{width:0,height:0}};this.options=options;if(data){if(data.start==undefined){throw new Error('Property \"start\" missing in item '+data)}}Item.call(this,data,conversion,options)}BoxItem.prototype=new Item(null,null,null);BoxItem.prototype.isVisible=function(range){var isVisible;var align=this.options.align;var widthInMs=this.width*range.getMillisecondsPerPixel();if(align==\"right\"){isVisible=this.data.start.getTime()>range.start&&this.data.start.getTime()-widthInMs<range.end}else if(align==\"left\"){isVisible=this.data.start.getTime()+widthInMs>range.start&&this.data.start.getTime()<range.end}else{isVisible=this.data.start.getTime()+widthInMs/2>range.start&&this.data.start.getTime()-widthInMs/2<range.end}return isVisible};BoxItem.prototype._createDomElement=function(){if(!this.dom){this.dom={};this.dom.box=document.createElement(\"DIV\");this.dom.content=document.createElement(\"DIV\");this.dom.content.className=\"vis-item-content\";this.dom.box.appendChild(this.dom.content);this.dom.line=document.createElement(\"DIV\");this.dom.line.className=\"vis-line\";this.dom.dot=document.createElement(\"DIV\");this.dom.dot.className=\"vis-dot\";this.dom.box[\"timeline-item\"]=this;this.dirty=true}};BoxItem.prototype._appendDomElement=function(){if(!this.parent){throw new Error(\"Cannot redraw item: no parent attached\")}if(!this.dom.box.parentNode){var foreground=this.parent.dom.foreground;if(!foreground)throw new Error(\"Cannot redraw item: parent has no foreground container element\");foreground.appendChild(this.dom.box)}if(!this.dom.line.parentNode){var background=this.parent.dom.background;if(!background)throw new Error(\"Cannot redraw item: parent has no background container element\");background.appendChild(this.dom.line)}if(!this.dom.dot.parentNode){var axis=this.parent.dom.axis;if(!background)throw new Error(\"Cannot redraw item: parent has no axis container element\");axis.appendChild(this.dom.dot)}this.displayed=true};BoxItem.prototype._updateDirtyDomComponents=function(){if(this.dirty){this._updateContents(this.dom.content);this._updateDataAttributes(this.dom.box);this._updateStyle(this.dom.box);var editable=this.editable.updateTime||this.editable.updateGroup;var className=(this.data.className?\" \"+this.data.className:\"\")+(this.selected?\" vis-selected\":\"\")+(editable?\" vis-editable\":\" vis-readonly\");this.dom.box.className=\"vis-item vis-box\"+className;this.dom.line.className=\"vis-item vis-line\"+className;this.dom.dot.className=\"vis-item vis-dot\"+className}};BoxItem.prototype._getDomComponentsSizes=function(){return{previous:{right:this.dom.box.style.right,left:this.dom.box.style.left},dot:{height:this.dom.dot.offsetHeight,width:this.dom.dot.offsetWidth},line:{width:this.dom.line.offsetWidth},box:{width:this.dom.box.offsetWidth,height:this.dom.box.offsetHeight}}};BoxItem.prototype._updateDomComponentsSizes=function(sizes){if(this.options.rtl){this.dom.box.style.right=\"0px\"}else{this.dom.box.style.left=\"0px\"}this.props.dot.height=sizes.dot.height;this.props.dot.width=sizes.dot.width;this.props.line.width=sizes.line.width;this.width=sizes.box.width;this.height=sizes.box.height;if(this.options.rtl){this.dom.box.style.right=sizes.previous.right}else{this.dom.box.style.left=sizes.previous.left}this.dirty=false};BoxItem.prototype._repaintDomAdditionals=function(){this._repaintOnItemUpdateTimeTooltip(this.dom.box);this._repaintDragCenter();this._repaintDeleteButton(this.dom.box)};BoxItem.prototype.redraw=function(returnQueue){var sizes;var queue=[this._createDomElement.bind(this),this._appendDomElement.bind(this),this._updateDirtyDomComponents.bind(this),function(){if(this.dirty){sizes=this._getDomComponentsSizes()}}.bind(this),function(){if(this.dirty){this._updateDomComponentsSizes.bind(this)(sizes)}}.bind(this),this._repaintDomAdditionals.bind(this)];if(returnQueue){return queue}else{var result;queue.forEach(function(fn){result=fn()});return result}};BoxItem.prototype.show=function(){if(!this.displayed){this.redraw()}};BoxItem.prototype.hide=function(){if(this.displayed){var dom=this.dom;if(dom.box.parentNode)dom.box.parentNode.removeChild(dom.box);if(dom.line.parentNode)dom.line.parentNode.removeChild(dom.line);if(dom.dot.parentNode)dom.dot.parentNode.removeChild(dom.dot);this.displayed=false}};BoxItem.prototype.repositionX=function(){var start=this.conversion.toScreen(this.data.start);var align=this.options.align;if(align==\"right\"){if(this.options.rtl){this.right=start-this.width;this.dom.box.style.right=this.right+\"px\";this.dom.line.style.right=start-this.props.line.width+\"px\";this.dom.dot.style.right=start-this.props.line.width/2-this.props.dot.width/2+\"px\"}else{this.left=start-this.width;this.dom.box.style.left=this.left+\"px\";this.dom.line.style.left=start-this.props.line.width+\"px\";this.dom.dot.style.left=start-this.props.line.width/2-this.props.dot.width/2+\"px\"}}else if(align==\"left\"){if(this.options.rtl){this.right=start;this.dom.box.style.right=this.right+\"px\";this.dom.line.style.right=start+\"px\";this.dom.dot.style.right=start+this.props.line.width/2-this.props.dot.width/2+\"px\"}else{this.left=start;this.dom.box.style.left=this.left+\"px\";this.dom.line.style.left=start+\"px\";this.dom.dot.style.left=start+this.props.line.width/2-this.props.dot.width/2+\"px\"}}else{if(this.options.rtl){this.right=start-this.width/2;this.dom.box.style.right=this.right+\"px\";this.dom.line.style.right=start-this.props.line.width+\"px\";this.dom.dot.style.right=start-this.props.dot.width/2+\"px\"}else{this.left=start-this.width/2;this.dom.box.style.left=this.left+\"px\";this.dom.line.style.left=start-this.props.line.width/2+\"px\";this.dom.dot.style.left=start-this.props.dot.width/2+\"px\"}}};BoxItem.prototype.repositionY=function(){var orientation=this.options.orientation.item;var box=this.dom.box;var line=this.dom.line;var dot=this.dom.dot;if(orientation==\"top\"){box.style.top=(this.top||0)+\"px\";line.style.top=\"0\";line.style.height=this.parent.top+this.top+1+\"px\";line.style.bottom=\"\"}else{var itemSetHeight=this.parent.itemSet.props.height;var lineHeight=itemSetHeight-this.parent.top-this.parent.height+this.top;box.style.top=(this.parent.height-this.top-this.height||0)+\"px\";line.style.top=itemSetHeight-lineHeight+\"px\";line.style.bottom=\"0\"}dot.style.top=-this.props.dot.height/2+\"px\"};BoxItem.prototype.getWidthLeft=function(){return this.width/2};BoxItem.prototype.getWidthRight=function(){return this.width/2};module.exports=BoxItem},function(module,exports,__webpack_require__){\"use strict\";var Item=__webpack_require__(38);function PointItem(data,conversion,options){this.props={dot:{top:0,width:0,height:0},content:{height:0,marginLeft:0,marginRight:0}};this.options=options;if(data){if(data.start==undefined){throw new Error('Property \"start\" missing in item '+data)}}Item.call(this,data,conversion,options)}PointItem.prototype=new Item(null,null,null);PointItem.prototype.isVisible=function(range){var widthInMs=this.width*range.getMillisecondsPerPixel();return this.data.start.getTime()+widthInMs>range.start&&this.data.start<range.end};PointItem.prototype._createDomElement=function(){if(!this.dom){this.dom={};this.dom.point=document.createElement(\"div\");this.dom.content=document.createElement(\"div\");this.dom.content.className=\"vis-item-content\";this.dom.point.appendChild(this.dom.content);this.dom.dot=document.createElement(\"div\");this.dom.point.appendChild(this.dom.dot);this.dom.point[\"timeline-item\"]=this;this.dirty=true}};PointItem.prototype._appendDomElement=function(){if(!this.parent){throw new Error(\"Cannot redraw item: no parent attached\")}if(!this.dom.point.parentNode){var foreground=this.parent.dom.foreground;if(!foreground){throw new Error(\"Cannot redraw item: parent has no foreground container element\")}foreground.appendChild(this.dom.point)}this.displayed=true};PointItem.prototype._updateDirtyDomComponents=function(){if(this.dirty){this._updateContents(this.dom.content);this._updateDataAttributes(this.dom.point);this._updateStyle(this.dom.point);var editable=this.editable.updateTime||this.editable.updateGroup;var className=(this.data.className?\" \"+this.data.className:\"\")+(this.selected?\" vis-selected\":\"\")+(editable?\" vis-editable\":\" vis-readonly\");this.dom.point.className=\"vis-item vis-point\"+className;this.dom.dot.className=\"vis-item vis-dot\"+className}};PointItem.prototype._getDomComponentsSizes=function(){return{dot:{width:this.dom.dot.offsetWidth,height:this.dom.dot.offsetHeight},content:{width:this.dom.content.offsetWidth,height:this.dom.content.offsetHeight},point:{width:this.dom.point.offsetWidth,height:this.dom.point.offsetHeight}}};PointItem.prototype._updateDomComponentsSizes=function(sizes){this.props.dot.width=sizes.dot.width;this.props.dot.height=sizes.dot.height;this.props.content.height=sizes.content.height;if(this.options.rtl){this.dom.content.style.marginRight=2*this.props.dot.width+\"px\"}else{this.dom.content.style.marginLeft=2*this.props.dot.width+\"px\"}this.width=sizes.point.width;this.height=sizes.point.height;this.dom.dot.style.top=(this.height-this.props.dot.height)/2+\"px\";if(this.options.rtl){this.dom.dot.style.right=this.props.dot.width/2+\"px\"}else{this.dom.dot.style.left=this.props.dot.width/2+\"px\"}this.dirty=false};PointItem.prototype._repaintDomAdditionals=function(){this._repaintOnItemUpdateTimeTooltip(this.dom.point);this._repaintDragCenter();this._repaintDeleteButton(this.dom.point)};PointItem.prototype.redraw=function(returnQueue){var sizes;var queue=[this._createDomElement.bind(this),this._appendDomElement.bind(this),this._updateDirtyDomComponents.bind(this),function(){if(this.dirty){sizes=this._getDomComponentsSizes()}}.bind(this),function(){if(this.dirty){this._updateDomComponentsSizes.bind(this)(sizes)}}.bind(this),this._repaintDomAdditionals.bind(this)];if(returnQueue){return queue}else{var result;queue.forEach(function(fn){result=fn()});return result}};PointItem.prototype.show=function(){if(!this.displayed){this.redraw()}};PointItem.prototype.hide=function(){if(this.displayed){if(this.dom.point.parentNode){this.dom.point.parentNode.removeChild(this.dom.point)}this.displayed=false}};PointItem.prototype.repositionX=function(){var start=this.conversion.toScreen(this.data.start);if(this.options.rtl){this.right=start-this.props.dot.width;this.dom.point.style.right=this.right+\"px\"}else{this.left=start-this.props.dot.width;this.dom.point.style.left=this.left+\"px\"}};PointItem.prototype.repositionY=function(){var orientation=this.options.orientation.item;var point=this.dom.point;if(orientation==\"top\"){point.style.top=this.top+\"px\"}else{point.style.top=this.parent.height-this.top-this.height+\"px\"}};PointItem.prototype.getWidthLeft=function(){return this.props.dot.width};PointItem.prototype.getWidthRight=function(){return this.props.dot.width};module.exports=PointItem},function(module,exports,__webpack_require__){\"use strict\";var Item=__webpack_require__(38);var BackgroundGroup=__webpack_require__(69);var RangeItem=__webpack_require__(70);function BackgroundItem(data,conversion,options){this.props={content:{width:0}};this.overflow=false;if(data){if(data.start==undefined){throw new Error('Property \"start\" missing in item '+data.id)}if(data.end==undefined){throw new Error('Property \"end\" missing in item '+data.id)}}Item.call(this,data,conversion,options)}BackgroundItem.prototype=new Item(null,null,null);BackgroundItem.prototype.baseClassName=\"vis-item vis-background\";BackgroundItem.prototype.stack=false;BackgroundItem.prototype.isVisible=function(range){return this.data.start<range.end&&this.data.end>range.start};BackgroundItem.prototype._createDomElement=function(){if(!this.dom){this.dom={};this.dom.box=document.createElement(\"div\");this.dom.frame=document.createElement(\"div\");this.dom.frame.className=\"vis-item-overflow\";this.dom.box.appendChild(this.dom.frame);this.dom.content=document.createElement(\"div\");this.dom.content.className=\"vis-item-content\";this.dom.frame.appendChild(this.dom.content);this.dirty=true}};BackgroundItem.prototype._appendDomElement=function(){if(!this.parent){throw new Error(\"Cannot redraw item: no parent attached\")}if(!this.dom.box.parentNode){var background=this.parent.dom.background;if(!background){throw new Error(\"Cannot redraw item: parent has no background container element\")}background.appendChild(this.dom.box)}this.displayed=true};BackgroundItem.prototype._updateDirtyDomComponents=function(){if(this.dirty){this._updateContents(this.dom.content);this._updateDataAttributes(this.dom.content);this._updateStyle(this.dom.box);var className=(this.data.className?\" \"+this.data.className:\"\")+(this.selected?\" vis-selected\":\"\");this.dom.box.className=this.baseClassName+className}};BackgroundItem.prototype._getDomComponentsSizes=function(){this.overflow=window.getComputedStyle(this.dom.content).overflow!==\"hidden\";return{content:{width:this.dom.content.offsetWidth}}};BackgroundItem.prototype._updateDomComponentsSizes=function(sizes){this.props.content.width=sizes.content.width;this.height=0;this.dirty=false};BackgroundItem.prototype._repaintDomAdditionals=function(){};BackgroundItem.prototype.redraw=function(returnQueue){var sizes;var queue=[this._createDomElement.bind(this),this._appendDomElement.bind(this),this._updateDirtyDomComponents.bind(this),function(){if(this.dirty){sizes=this._getDomComponentsSizes.bind(this)()}}.bind(this),function(){if(this.dirty){this._updateDomComponentsSizes.bind(this)(sizes)}}.bind(this),this._repaintDomAdditionals.bind(this)];if(returnQueue){return queue}else{var result;queue.forEach(function(fn){result=fn()});return result}};BackgroundItem.prototype.show=RangeItem.prototype.show;BackgroundItem.prototype.hide=RangeItem.prototype.hide;BackgroundItem.prototype.repositionX=RangeItem.prototype.repositionX;BackgroundItem.prototype.repositionY=function(margin){var height;var orientation=this.options.orientation.item;if(this.data.subgroup!==undefined){var itemSubgroup=this.data.subgroup;this.dom.box.style.height=this.parent.subgroups[itemSubgroup].height+\"px\";if(orientation==\"top\"){this.dom.box.style.top=this.parent.top+this.parent.subgroups[itemSubgroup].top+\"px\"}else{this.dom.box.style.top=this.parent.top+this.parent.height-this.parent.subgroups[itemSubgroup].top-this.parent.subgroups[itemSubgroup].height+\"px\"}this.dom.box.style.bottom=\"\"}else{if(this.parent instanceof BackgroundGroup){height=Math.max(this.parent.height,this.parent.itemSet.body.domProps.center.height,this.parent.itemSet.body.domProps.centerContainer.height);this.dom.box.style.bottom=orientation==\"bottom\"?\"0\":\"\";this.dom.box.style.top=orientation==\"top\"?\"0\":\"\"}else{height=this.parent.height;this.dom.box.style.top=this.parent.top+\"px\";this.dom.box.style.bottom=\"\"}}this.dom.box.style.height=height+\"px\"};module.exports=BackgroundItem},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Popup=function(){function Popup(container,overflowMethod){(0,_classCallCheck3[\"default\"])(this,Popup);this.container=container;this.overflowMethod=overflowMethod||\"cap\";this.x=0;this.y=0;this.padding=5;this.hidden=false;this.frame=document.createElement(\"div\");this.frame.className=\"vis-tooltip\";this.container.appendChild(this.frame)}(0,_createClass3[\"default\"])(Popup,[{key:\"setPosition\",value:function setPosition(x,y){this.x=parseInt(x);this.y=parseInt(y)}},{key:\"setText\",value:function setText(content){if(content instanceof Element){this.frame.innerHTML=\"\";this.frame.appendChild(content)}else{this.frame.innerHTML=content}}},{key:\"show\",value:function show(doShow){if(doShow===undefined){doShow=true}if(doShow===true){var height=this.frame.clientHeight;var width=this.frame.clientWidth;var maxHeight=this.frame.parentNode.clientHeight;var maxWidth=this.frame.parentNode.clientWidth;var left=0,top=0;if(this.overflowMethod==\"flip\"){var isLeft=false,isTop=true;if(this.y-height<this.padding){isTop=false}if(this.x+width>maxWidth-this.padding){isLeft=true}if(isLeft){left=this.x-width}else{left=this.x}if(isTop){top=this.y-height}else{top=this.y}}else{top=this.y-height;if(top+height+this.padding>maxHeight){top=maxHeight-height-this.padding}if(top<this.padding){top=this.padding}left=this.x;if(left+width+this.padding>maxWidth){left=maxWidth-width-this.padding}if(left<this.padding){left=this.padding}}this.frame.style.left=left+\"px\";this.frame.style.top=top+\"px\";this.frame.style.visibility=\"visible\";this.hidden=false}else{this.hide()}}},{key:\"hide\",value:function hide(){this.hidden=true;this.frame.style.left=\"0\";this.frame.style.top=\"0\";this.frame.style.visibility=\"hidden\"}},{key:\"destroy\",value:function destroy(){this.frame.parentNode.removeChild(this.frame)}}]);return Popup}();exports[\"default\"]=Popup},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var string=\"string\";var bool=\"boolean\";var number=\"number\";var array=\"array\";var date=\"date\";var object=\"object\";var dom=\"dom\";var moment=\"moment\";var any=\"any\";var allOptions={configure:{enabled:{boolean:bool},filter:{boolean:bool,function:\"function\"},container:{dom:dom},__type__:{object:object,boolean:bool,function:\"function\"}},align:{string:string},rtl:{boolean:bool,undefined:\"undefined\"},rollingMode:{follow:{boolean:bool},offset:{number:number,undefined:\"undefined\"},__type__:{object:object}},verticalScroll:{boolean:bool,undefined:\"undefined\"},horizontalScroll:{boolean:bool,undefined:\"undefined\"},autoResize:{boolean:bool},throttleRedraw:{number:number},clickToUse:{boolean:bool},dataAttributes:{string:string,array:array},editable:{add:{boolean:bool,undefined:\"undefined\"},remove:{boolean:bool,undefined:\"undefined\"},updateGroup:{boolean:bool,undefined:\"undefined\"},updateTime:{boolean:bool,undefined:\"undefined\"},overrideItems:{boolean:bool,undefined:\"undefined\"},__type__:{boolean:bool,object:object}},end:{number:number,date:date,string:string,moment:moment},format:{minorLabels:{millisecond:{string:string,undefined:\"undefined\"},second:{string:string,undefined:\"undefined\"},minute:{string:string,undefined:\"undefined\"},hour:{string:string,undefined:\"undefined\"},weekday:{string:string,undefined:\"undefined\"},day:{string:string,undefined:\"undefined\"},week:{string:string,undefined:\"undefined\"},month:{string:string,undefined:\"undefined\"},year:{string:string,undefined:\"undefined\"},__type__:{object:object,function:\"function\"}},majorLabels:{millisecond:{string:string,undefined:\"undefined\"},second:{string:string,undefined:\"undefined\"},minute:{string:string,undefined:\"undefined\"},hour:{string:string,undefined:\"undefined\"},weekday:{string:string,undefined:\"undefined\"},day:{string:string,undefined:\"undefined\"},week:{string:string,undefined:\"undefined\"},month:{string:string,undefined:\"undefined\"},year:{string:string,undefined:\"undefined\"},__type__:{object:object,function:\"function\"}},__type__:{object:object}},moment:{function:\"function\"},groupOrder:{string:string,function:\"function\"},groupEditable:{add:{boolean:bool,undefined:\"undefined\"},remove:{boolean:bool,undefined:\"undefined\"},order:{boolean:bool,undefined:\"undefined\"},__type__:{boolean:bool,object:object}},groupOrderSwap:{function:\"function\"},height:{string:string,number:number},hiddenDates:{start:{date:date,number:number,string:string,moment:moment},end:{date:date,number:number,string:string,moment:moment},repeat:{string:string},__type__:{object:object,array:array}},itemsAlwaysDraggable:{item:{boolean:bool,undefined:\"undefined\"},range:{boolean:bool,undefined:\"undefined\"},__type__:{boolean:bool,object:object}},limitSize:{boolean:bool},locale:{string:string},locales:{__any__:{any:any},__type__:{object:object}},margin:{axis:{number:number},item:{horizontal:{number:number,undefined:\"undefined\"},vertical:{number:number,undefined:\"undefined\"},__type__:{object:object,number:number}},__type__:{object:object,number:number}},max:{date:date,number:number,string:string,moment:moment},maxHeight:{number:number,string:string},maxMinorChars:{number:number},min:{date:date,number:number,string:string,moment:moment},minHeight:{number:number,string:string},moveable:{boolean:bool},multiselect:{boolean:bool},multiselectPerGroup:{boolean:bool},onAdd:{function:\"function\"},onDropObjectOnItem:{function:\"function\"},onUpdate:{function:\"function\"},onMove:{function:\"function\"},onMoving:{function:\"function\"},onRemove:{function:\"function\"},onAddGroup:{function:\"function\"},onMoveGroup:{function:\"function\"},onRemoveGroup:{function:\"function\"},onInitialDrawComplete:{function:\"function\"},order:{function:\"function\"},orientation:{axis:{string:string,undefined:\"undefined\"},item:{string:string,undefined:\"undefined\"},__type__:{string:string,object:object}},selectable:{boolean:bool},showCurrentTime:{boolean:bool},showMajorLabels:{boolean:bool},showMinorLabels:{boolean:bool},stack:{boolean:bool},stackSubgroups:{boolean:bool},snap:{function:\"function\",null:\"null\"},start:{date:date,number:number,string:string,moment:moment},template:{function:\"function\"},groupTemplate:{function:\"function\"},visibleFrameTemplate:{string:string,function:\"function\"},showTooltips:{boolean:bool},tooltip:{followMouse:{boolean:bool},overflowMethod:{string:[\"cap\",\"flip\"]},__type__:{object:object}},tooltipOnItemUpdateTime:{template:{function:\"function\"},__type__:{boolean:bool,object:object}},timeAxis:{scale:{string:string,undefined:\"undefined\"},step:{number:number,undefined:\"undefined\"},__type__:{object:object}},type:{string:string},width:{string:string,number:number},zoomable:{boolean:bool},zoomKey:{string:[\"ctrlKey\",\"altKey\",\"metaKey\",\"\"]},zoomMax:{number:number},zoomMin:{number:number},__type__:{object:object}};var configureOptions={global:{align:[\"center\",\"left\",\"right\"],direction:false,autoResize:true,clickToUse:false,editable:{add:false,remove:false,updateGroup:false,updateTime:false},end:\"\",format:{minorLabels:{millisecond:\"SSS\",second:\"s\",minute:\"HH:mm\",hour:\"HH:mm\",weekday:\"ddd D\",day:\"D\",week:\"w\",month:\"MMM\",year:\"YYYY\"},majorLabels:{millisecond:\"HH:mm:ss\",second:\"D MMMM HH:mm\",minute:\"ddd D MMMM\",hour:\"ddd D MMMM\",weekday:\"MMMM YYYY\",day:\"MMMM YYYY\",week:\"MMMM YYYY\",month:\"YYYY\",year:\"\"}},groupsDraggable:false,height:\"\",locale:\"\",margin:{axis:[20,0,100,1],item:{horizontal:[10,0,100,1],vertical:[10,0,100,1]}},max:\"\",maxHeight:\"\",maxMinorChars:[7,0,20,1],min:\"\",minHeight:\"\",moveable:false,multiselect:false,multiselectPerGroup:false,orientation:{axis:[\"both\",\"bottom\",\"top\"],item:[\"bottom\",\"top\"]},selectable:true,showCurrentTime:false,showMajorLabels:true,showMinorLabels:true,stack:true,stackSubgroups:true,start:\"\",showTooltips:true,tooltip:{followMouse:false,overflowMethod:\"flip\"},tooltipOnItemUpdateTime:false,type:[\"box\",\"point\",\"range\",\"background\"],width:\"100%\",zoomable:true,zoomKey:[\"ctrlKey\",\"altKey\",\"metaKey\",\"\"],zoomMax:[31536e10,10,31536e10,1],zoomMin:[10,10,31536e10,1]}};exports.allOptions=allOptions;exports.configureOptions=configureOptions},function(module,exports,__webpack_require__){\"use strict\";var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var DOMutil=__webpack_require__(14);var DataSet=__webpack_require__(11);var DataView=__webpack_require__(12);var Component=__webpack_require__(16);var DataAxis=__webpack_require__(107);var GraphGroup=__webpack_require__(109);var Legend=__webpack_require__(112);var Bars=__webpack_require__(110)\n;var Lines=__webpack_require__(111);var Points=__webpack_require__(72);var UNGROUPED=\"__ungrouped__\";function LineGraph(body,options){this.id=util.randomUUID();this.body=body;this.defaultOptions={yAxisOrientation:\"left\",defaultGroup:\"default\",sort:true,sampling:true,stack:false,graphHeight:\"400px\",shaded:{enabled:false,orientation:\"bottom\"},style:\"line\",barChart:{width:50,sideBySide:false,align:\"center\"},interpolation:{enabled:true,parametrization:\"centripetal\",alpha:.5},drawPoints:{enabled:true,size:6,style:\"square\"},dataAxis:{},legend:{},groups:{visibility:{}}};this.options=util.extend({},this.defaultOptions);this.dom={};this.props={};this.hammer=null;this.groups={};this.abortedGraphUpdate=false;this.updateSVGheight=false;this.updateSVGheightOnResize=false;this.forceGraphUpdate=true;var me=this;this.itemsData=null;this.groupsData=null;this.itemListeners={add:function add(event,params,senderId){me._onAdd(params.items)},update:function update(event,params,senderId){me._onUpdate(params.items)},remove:function remove(event,params,senderId){me._onRemove(params.items)}};this.groupListeners={add:function add(event,params,senderId){me._onAddGroups(params.items)},update:function update(event,params,senderId){me._onUpdateGroups(params.items)},remove:function remove(event,params,senderId){me._onRemoveGroups(params.items)}};this.items={};this.selection=[];this.lastStart=this.body.range.start;this.touchParams={};this.svgElements={};this.setOptions(options);this.groupsUsingDefaultStyles=[0];this.body.emitter.on(\"rangechanged\",function(){me.lastStart=me.body.range.start;me.svg.style.left=util.option.asSize(-me.props.width);me.forceGraphUpdate=true;me.redraw.call(me)});this._create();this.framework={svg:this.svg,svgElements:this.svgElements,options:this.options,groups:this.groups}}LineGraph.prototype=new Component;LineGraph.prototype._create=function(){var frame=document.createElement(\"div\");frame.className=\"vis-line-graph\";this.dom.frame=frame;this.svg=document.createElementNS(\"http://www.w3.org/2000/svg\",\"svg\");this.svg.style.position=\"relative\";this.svg.style.height=(\"\"+this.options.graphHeight).replace(\"px\",\"\")+\"px\";this.svg.style.display=\"block\";frame.appendChild(this.svg);this.options.dataAxis.orientation=\"left\";this.yAxisLeft=new DataAxis(this.body,this.options.dataAxis,this.svg,this.options.groups);this.options.dataAxis.orientation=\"right\";this.yAxisRight=new DataAxis(this.body,this.options.dataAxis,this.svg,this.options.groups);delete this.options.dataAxis.orientation;this.legendLeft=new Legend(this.body,this.options.legend,\"left\",this.options.groups);this.legendRight=new Legend(this.body,this.options.legend,\"right\",this.options.groups);this.show()};LineGraph.prototype.setOptions=function(options){if(options){var fields=[\"sampling\",\"defaultGroup\",\"stack\",\"height\",\"graphHeight\",\"yAxisOrientation\",\"style\",\"barChart\",\"dataAxis\",\"sort\",\"groups\"];if(options.graphHeight===undefined&&options.height!==undefined){this.updateSVGheight=true;this.updateSVGheightOnResize=true}else if(this.body.domProps.centerContainer.height!==undefined&&options.graphHeight!==undefined){if(parseInt((options.graphHeight+\"\").replace(\"px\",\"\"))<this.body.domProps.centerContainer.height){this.updateSVGheight=true}}util.selectiveDeepExtend(fields,this.options,options);util.mergeOptions(this.options,options,\"interpolation\");util.mergeOptions(this.options,options,\"drawPoints\");util.mergeOptions(this.options,options,\"shaded\");util.mergeOptions(this.options,options,\"legend\");if(options.interpolation){if((0,_typeof3[\"default\"])(options.interpolation)==\"object\"){if(options.interpolation.parametrization){if(options.interpolation.parametrization==\"uniform\"){this.options.interpolation.alpha=0}else if(options.interpolation.parametrization==\"chordal\"){this.options.interpolation.alpha=1}else{this.options.interpolation.parametrization=\"centripetal\";this.options.interpolation.alpha=.5}}}}if(this.yAxisLeft){if(options.dataAxis!==undefined){this.yAxisLeft.setOptions(this.options.dataAxis);this.yAxisRight.setOptions(this.options.dataAxis)}}if(this.legendLeft){if(options.legend!==undefined){this.legendLeft.setOptions(this.options.legend);this.legendRight.setOptions(this.options.legend)}}if(this.groups.hasOwnProperty(UNGROUPED)){this.groups[UNGROUPED].setOptions(options)}}if(this.dom.frame){this.forceGraphUpdate=true;this.body.emitter.emit(\"_change\",{queue:true})}};LineGraph.prototype.hide=function(){if(this.dom.frame.parentNode){this.dom.frame.parentNode.removeChild(this.dom.frame)}};LineGraph.prototype.show=function(){if(!this.dom.frame.parentNode){this.body.dom.center.appendChild(this.dom.frame)}};LineGraph.prototype.setItems=function(items){var me=this,ids,oldItemsData=this.itemsData;if(!items){this.itemsData=null}else if(items instanceof DataSet||items instanceof DataView){this.itemsData=items}else{throw new TypeError(\"Data must be an instance of DataSet or DataView\")}if(oldItemsData){util.forEach(this.itemListeners,function(callback,event){oldItemsData.off(event,callback)});ids=oldItemsData.getIds();this._onRemove(ids)}if(this.itemsData){var id=this.id;util.forEach(this.itemListeners,function(callback,event){me.itemsData.on(event,callback,id)});ids=this.itemsData.getIds();this._onAdd(ids)}};LineGraph.prototype.setGroups=function(groups){var me=this;var ids;if(this.groupsData){util.forEach(this.groupListeners,function(callback,event){me.groupsData.off(event,callback)});ids=this.groupsData.getIds();this.groupsData=null;for(var i=0;i<ids.length;i++){this._removeGroup(ids[i])}}if(!groups){this.groupsData=null}else if(groups instanceof DataSet||groups instanceof DataView){this.groupsData=groups}else{throw new TypeError(\"Data must be an instance of DataSet or DataView\")}if(this.groupsData){var id=this.id;util.forEach(this.groupListeners,function(callback,event){me.groupsData.on(event,callback,id)});ids=this.groupsData.getIds();this._onAddGroups(ids)}};LineGraph.prototype._onUpdate=function(ids){this._updateAllGroupData(ids)};LineGraph.prototype._onAdd=function(ids){this._onUpdate(ids)};LineGraph.prototype._onRemove=function(ids){this._onUpdate(ids)};LineGraph.prototype._onUpdateGroups=function(groupIds){this._updateAllGroupData(null,groupIds)};LineGraph.prototype._onAddGroups=function(groupIds){this._onUpdateGroups(groupIds)};LineGraph.prototype._onRemoveGroups=function(groupIds){for(var i=0;i<groupIds.length;i++){this._removeGroup(groupIds[i])}this.forceGraphUpdate=true;this.body.emitter.emit(\"_change\",{queue:true})};LineGraph.prototype._removeGroup=function(groupId){if(this.groups.hasOwnProperty(groupId)){if(this.groups[groupId].options.yAxisOrientation==\"right\"){this.yAxisRight.removeGroup(groupId);this.legendRight.removeGroup(groupId);this.legendRight.redraw()}else{this.yAxisLeft.removeGroup(groupId);this.legendLeft.removeGroup(groupId);this.legendLeft.redraw()}delete this.groups[groupId]}};LineGraph.prototype._updateGroup=function(group,groupId){if(!this.groups.hasOwnProperty(groupId)){this.groups[groupId]=new GraphGroup(group,groupId,this.options,this.groupsUsingDefaultStyles);if(this.groups[groupId].options.yAxisOrientation==\"right\"){this.yAxisRight.addGroup(groupId,this.groups[groupId]);this.legendRight.addGroup(groupId,this.groups[groupId])}else{this.yAxisLeft.addGroup(groupId,this.groups[groupId]);this.legendLeft.addGroup(groupId,this.groups[groupId])}}else{this.groups[groupId].update(group);if(this.groups[groupId].options.yAxisOrientation==\"right\"){this.yAxisRight.updateGroup(groupId,this.groups[groupId]);this.legendRight.updateGroup(groupId,this.groups[groupId]);this.yAxisLeft.removeGroup(groupId);this.legendLeft.removeGroup(groupId)}else{this.yAxisLeft.updateGroup(groupId,this.groups[groupId]);this.legendLeft.updateGroup(groupId,this.groups[groupId]);this.yAxisRight.removeGroup(groupId);this.legendRight.removeGroup(groupId)}}this.legendLeft.redraw();this.legendRight.redraw()};LineGraph.prototype._updateAllGroupData=function(ids,groupIds){if(this.itemsData!=null){var groupsContent={};var items=this.itemsData.get();var fieldId=this.itemsData._fieldId;var idMap={};if(ids){ids.map(function(id){idMap[id]=id})}var groupCounts={};for(var i=0;i<items.length;i++){var item=items[i];var groupId=item.group;if(groupId===null||groupId===undefined){groupId=UNGROUPED}groupCounts.hasOwnProperty(groupId)?groupCounts[groupId]++:groupCounts[groupId]=1}var existingItemsMap={};if(!groupIds&&ids){for(groupId in this.groups){if(this.groups.hasOwnProperty(groupId)){group=this.groups[groupId];var existing_items=group.getItems();groupsContent[groupId]=existing_items.filter(function(item){existingItemsMap[item[fieldId]]=item[fieldId];return item[fieldId]!==idMap[item[fieldId]]});var newLength=groupCounts[groupId];groupCounts[groupId]-=groupsContent[groupId].length;if(groupsContent[groupId].length<newLength){groupsContent[groupId][newLength-1]={}}}}}for(i=0;i<items.length;i++){item=items[i];groupId=item.group;if(groupId===null||groupId===undefined){groupId=UNGROUPED}if(!groupIds&&ids&&item[fieldId]!==idMap[item[fieldId]]&&existingItemsMap.hasOwnProperty(item[fieldId])){continue}if(!groupsContent.hasOwnProperty(groupId)){groupsContent[groupId]=new Array(groupCounts[groupId])}var extended=util.bridgeObject(item);extended.x=util.convert(item.x,\"Date\");extended.end=util.convert(item.end,\"Date\");extended.orginalY=item.y;extended.y=Number(item.y);extended[fieldId]=item[fieldId];var index=groupsContent[groupId].length-groupCounts[groupId]--;groupsContent[groupId][index]=extended}for(groupId in this.groups){if(this.groups.hasOwnProperty(groupId)){if(!groupsContent.hasOwnProperty(groupId)){groupsContent[groupId]=new Array(0)}}}for(groupId in groupsContent){if(groupsContent.hasOwnProperty(groupId)){if(groupsContent[groupId].length==0){if(this.groups.hasOwnProperty(groupId)){this._removeGroup(groupId)}}else{var group=undefined;if(this.groupsData!=undefined){group=this.groupsData.get(groupId)}if(group==undefined){group={id:groupId,content:this.options.defaultGroup+groupId}}this._updateGroup(group,groupId);this.groups[groupId].setItems(groupsContent[groupId])}}}this.forceGraphUpdate=true;this.body.emitter.emit(\"_change\",{queue:true})}};LineGraph.prototype.redraw=function(){var resized=false;this.props.width=this.dom.frame.offsetWidth;this.props.height=this.body.domProps.centerContainer.height-this.body.domProps.border.top-this.body.domProps.border.bottom;resized=this._isResized()||resized;var visibleInterval=this.body.range.end-this.body.range.start;var zoomed=visibleInterval!=this.lastVisibleInterval;this.lastVisibleInterval=visibleInterval;if(resized==true){this.svg.style.width=util.option.asSize(3*this.props.width);this.svg.style.left=util.option.asSize(-this.props.width);if((this.options.height+\"\").indexOf(\"%\")!=-1||this.updateSVGheightOnResize==true){this.updateSVGheight=true}}if(this.updateSVGheight==true){if(this.options.graphHeight!=this.props.height+\"px\"){this.options.graphHeight=this.props.height+\"px\";this.svg.style.height=this.props.height+\"px\"}this.updateSVGheight=false}else{this.svg.style.height=(\"\"+this.options.graphHeight).replace(\"px\",\"\")+\"px\"}if(resized==true||zoomed==true||this.abortedGraphUpdate==true||this.forceGraphUpdate==true){resized=this._updateGraph()||resized;this.forceGraphUpdate=false}else{if(this.lastStart!=0){var offset=this.body.range.start-this.lastStart;var range=this.body.range.end-this.body.range.start;if(this.props.width!=0){var rangePerPixelInv=this.props.width/range;var xOffset=offset*rangePerPixelInv;this.svg.style.left=-this.props.width-xOffset+\"px\"}}}this.legendLeft.redraw();this.legendRight.redraw();return resized};LineGraph.prototype._getSortedGroupIds=function(){var grouplist=[];for(var groupId in this.groups){if(this.groups.hasOwnProperty(groupId)){var group=this.groups[groupId];if(group.visible==true&&(this.options.groups.visibility[groupId]===undefined||this.options.groups.visibility[groupId]==true)){grouplist.push({id:groupId,zIndex:group.options.zIndex})}}}util.insertSort(grouplist,function(a,b){var az=a.zIndex;var bz=b.zIndex;if(az===undefined)az=0;if(bz===undefined)bz=0;return az==bz?0:az<bz?-1:1});var groupIds=new Array(grouplist.length);for(var i=0;i<grouplist.length;i++){groupIds[i]=grouplist[i].id}return groupIds};LineGraph.prototype._updateGraph=function(){DOMutil.prepareElements(this.svgElements);if(this.props.width!=0&&this.itemsData!=null){var group,i;var groupRanges={};var changeCalled=false;var minDate=this.body.util.toGlobalTime(-this.body.domProps.root.width);var maxDate=this.body.util.toGlobalTime(2*this.body.domProps.root.width);var groupIds=this._getSortedGroupIds();if(groupIds.length>0){var groupsData={};this._getRelevantData(groupIds,groupsData,minDate,maxDate);this._applySampling(groupIds,groupsData);for(i=0;i<groupIds.length;i++){this._convertXcoordinates(groupsData[groupIds[i]])}this._getYRanges(groupIds,groupsData,groupRanges);changeCalled=this._updateYAxis(groupIds,groupRanges);if(changeCalled==true){DOMutil.cleanupElements(this.svgElements);this.abortedGraphUpdate=true;return true}this.abortedGraphUpdate=false;var below=undefined;for(i=0;i<groupIds.length;i++){group=this.groups[groupIds[i]];if(this.options.stack===true&&this.options.style===\"line\"){if(group.options.excludeFromStacking==undefined||!group.options.excludeFromStacking){if(below!=undefined){this._stack(groupsData[group.id],groupsData[below.id]);if(group.options.shaded.enabled==true&&group.options.shaded.orientation!==\"group\"){if(group.options.shaded.orientation==\"top\"&&below.options.shaded.orientation!==\"group\"){below.options.shaded.orientation=\"group\";below.options.shaded.groupId=group.id}else{group.options.shaded.orientation=\"group\";group.options.shaded.groupId=below.id}}}below=group}}this._convertYcoordinates(groupsData[groupIds[i]],group)}var paths={};for(i=0;i<groupIds.length;i++){group=this.groups[groupIds[i]];if(group.options.style===\"line\"&&group.options.shaded.enabled==true){var dataset=groupsData[groupIds[i]];if(dataset==null||dataset.length==0){continue}if(!paths.hasOwnProperty(groupIds[i])){paths[groupIds[i]]=Lines.calcPath(dataset,group)}if(group.options.shaded.orientation===\"group\"){var subGroupId=group.options.shaded.groupId;if(groupIds.indexOf(subGroupId)===-1){console.log(group.id+\": Unknown shading group target given:\"+subGroupId);continue}if(!paths.hasOwnProperty(subGroupId)){paths[subGroupId]=Lines.calcPath(groupsData[subGroupId],this.groups[subGroupId])}Lines.drawShading(paths[groupIds[i]],group,paths[subGroupId],this.framework)}else{Lines.drawShading(paths[groupIds[i]],group,undefined,this.framework)}}}Bars.draw(groupIds,groupsData,this.framework);for(i=0;i<groupIds.length;i++){group=this.groups[groupIds[i]];if(groupsData[groupIds[i]].length>0){switch(group.options.style){case\"line\":if(!paths.hasOwnProperty(groupIds[i])){paths[groupIds[i]]=Lines.calcPath(groupsData[groupIds[i]],group)}Lines.draw(paths[groupIds[i]],group,this.framework);case\"point\":case\"points\":if(group.options.style==\"point\"||group.options.style==\"points\"||group.options.drawPoints.enabled==true){Points.draw(groupsData[groupIds[i]],group,this.framework)}break;case\"bar\":default:}}}}}DOMutil.cleanupElements(this.svgElements);return false};LineGraph.prototype._stack=function(data,subData){var index,dx,dy,subPrevPoint,subNextPoint;index=0;for(var j=0;j<data.length;j++){subPrevPoint=undefined;subNextPoint=undefined;for(var k=index;k<subData.length;k++){if(subData[k].x===data[j].x){subPrevPoint=subData[k];subNextPoint=subData[k];index=k;break}else if(subData[k].x>data[j].x){subNextPoint=subData[k];if(k==0){subPrevPoint=subNextPoint}else{subPrevPoint=subData[k-1]}index=k;break}}if(subNextPoint===undefined){subPrevPoint=subData[subData.length-1];subNextPoint=subData[subData.length-1]}dx=subNextPoint.x-subPrevPoint.x;dy=subNextPoint.y-subPrevPoint.y;if(dx==0){data[j].y=data[j].orginalY+subNextPoint.y}else{data[j].y=data[j].orginalY+dy/dx*(data[j].x-subPrevPoint.x)+subPrevPoint.y}}};LineGraph.prototype._getRelevantData=function(groupIds,groupsData,minDate,maxDate){var group,i,j,item;if(groupIds.length>0){for(i=0;i<groupIds.length;i++){group=this.groups[groupIds[i]];var itemsData=group.getItems();if(group.options.sort==true){var dateComparator=function dateComparator(a,b){return a.getTime()==b.getTime()?0:a<b?-1:1};var first=Math.max(0,util.binarySearchValue(itemsData,minDate,\"x\",\"before\",dateComparator));var last=Math.min(itemsData.length,util.binarySearchValue(itemsData,maxDate,\"x\",\"after\",dateComparator)+1);if(last<=0){last=itemsData.length}var dataContainer=new Array(last-first);for(j=first;j<last;j++){item=group.itemsData[j];dataContainer[j-first]=item}groupsData[groupIds[i]]=dataContainer}else{groupsData[groupIds[i]]=group.itemsData}}}};LineGraph.prototype._applySampling=function(groupIds,groupsData){var group;if(groupIds.length>0){for(var i=0;i<groupIds.length;i++){group=this.groups[groupIds[i]];if(group.options.sampling==true){var dataContainer=groupsData[groupIds[i]];if(dataContainer.length>0){var increment=1;var amountOfPoints=dataContainer.length;var xDistance=this.body.util.toGlobalScreen(dataContainer[dataContainer.length-1].x)-this.body.util.toGlobalScreen(dataContainer[0].x);var pointsPerPixel=amountOfPoints/xDistance;increment=Math.min(Math.ceil(.2*amountOfPoints),Math.max(1,Math.round(pointsPerPixel)));var sampledData=new Array(amountOfPoints);for(var j=0;j<amountOfPoints;j+=increment){var idx=Math.round(j/increment);sampledData[idx]=dataContainer[j]}groupsData[groupIds[i]]=sampledData.splice(0,Math.round(amountOfPoints/increment))}}}}};LineGraph.prototype._getYRanges=function(groupIds,groupsData,groupRanges){var groupData,group,i;var combinedDataLeft=[];var combinedDataRight=[];var options;if(groupIds.length>0){for(i=0;i<groupIds.length;i++){groupData=groupsData[groupIds[i]];options=this.groups[groupIds[i]].options;if(groupData.length>0){group=this.groups[groupIds[i]];if(options.stack===true&&options.style===\"bar\"){if(options.yAxisOrientation===\"left\"){combinedDataLeft=combinedDataLeft.concat(groupData)}else{combinedDataRight=combinedDataRight.concat(groupData)}}else{groupRanges[groupIds[i]]=group.getYRange(groupData,groupIds[i])}}}Bars.getStackedYRange(combinedDataLeft,groupRanges,groupIds,\"__barStackLeft\",\"left\");Bars.getStackedYRange(combinedDataRight,groupRanges,groupIds,\"__barStackRight\",\"right\")}};LineGraph.prototype._updateYAxis=function(groupIds,groupRanges){var resized=false;var yAxisLeftUsed=false;var yAxisRightUsed=false;var minLeft=1e9,minRight=1e9,maxLeft=-1e9,maxRight=-1e9,minVal,maxVal;if(groupIds.length>0){for(var i=0;i<groupIds.length;i++){var group=this.groups[groupIds[i]];if(group&&group.options.yAxisOrientation!=\"right\"){yAxisLeftUsed=true;minLeft=1e9;maxLeft=-1e9}else if(group&&group.options.yAxisOrientation){yAxisRightUsed=true;minRight=1e9;maxRight=-1e9}}for(i=0;i<groupIds.length;i++){if(groupRanges.hasOwnProperty(groupIds[i])){if(groupRanges[groupIds[i]].ignore!==true){minVal=groupRanges[groupIds[i]].min;maxVal=groupRanges[groupIds[i]].max;if(groupRanges[groupIds[i]].yAxisOrientation!=\"right\"){yAxisLeftUsed=true;minLeft=minLeft>minVal?minVal:minLeft;maxLeft=maxLeft<maxVal?maxVal:maxLeft}else{yAxisRightUsed=true;minRight=minRight>minVal?minVal:minRight;maxRight=maxRight<maxVal?maxVal:maxRight}}}}if(yAxisLeftUsed==true){this.yAxisLeft.setRange(minLeft,maxLeft)}if(yAxisRightUsed==true){this.yAxisRight.setRange(minRight,maxRight)}}resized=this._toggleAxisVisiblity(yAxisLeftUsed,this.yAxisLeft)||resized;resized=this._toggleAxisVisiblity(yAxisRightUsed,this.yAxisRight)||resized;if(yAxisRightUsed==true&&yAxisLeftUsed==true){this.yAxisLeft.drawIcons=true;this.yAxisRight.drawIcons=true}else{this.yAxisLeft.drawIcons=false;this.yAxisRight.drawIcons=false}this.yAxisRight.master=!yAxisLeftUsed;this.yAxisRight.masterAxis=this.yAxisLeft;if(this.yAxisRight.master==false){if(yAxisRightUsed==true){this.yAxisLeft.lineOffset=this.yAxisRight.width}else{this.yAxisLeft.lineOffset=0}resized=this.yAxisLeft.redraw()||resized;resized=this.yAxisRight.redraw()||resized}else{resized=this.yAxisRight.redraw()||resized}var tempGroups=[\"__barStackLeft\",\"__barStackRight\",\"__lineStackLeft\",\"__lineStackRight\"];for(i=0;i<tempGroups.length;i++){if(groupIds.indexOf(tempGroups[i])!=-1){groupIds.splice(groupIds.indexOf(tempGroups[i]),1)}}return resized};LineGraph.prototype._toggleAxisVisiblity=function(axisUsed,axis){var changed=false;if(axisUsed==false){if(axis.dom.frame.parentNode&&axis.hidden==false){axis.hide();changed=true}}else{if(!axis.dom.frame.parentNode&&axis.hidden==true){axis.show();changed=true}}return changed};LineGraph.prototype._convertXcoordinates=function(datapoints){var toScreen=this.body.util.toScreen;for(var i=0;i<datapoints.length;i++){datapoints[i].screen_x=toScreen(datapoints[i].x)+this.props.width;datapoints[i].screen_y=datapoints[i].y;if(datapoints[i].end!=undefined){datapoints[i].screen_end=toScreen(datapoints[i].end)+this.props.width}else{datapoints[i].screen_end=undefined}}};LineGraph.prototype._convertYcoordinates=function(datapoints,group){var axis=this.yAxisLeft;var svgHeight=Number(this.svg.style.height.replace(\"px\",\"\"));if(group.options.yAxisOrientation==\"right\"){axis=this.yAxisRight}for(var i=0;i<datapoints.length;i++){datapoints[i].screen_y=Math.round(axis.convertValue(datapoints[i].y))}group.setZeroPosition(Math.min(svgHeight,axis.convertValue(0)))};module.exports=LineGraph},function(module,exports,__webpack_require__){\"use strict\";var _keys=__webpack_require__(8);var _keys2=_interopRequireDefault(_keys);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var DOMutil=__webpack_require__(14);var Component=__webpack_require__(16);var DataScale=__webpack_require__(108);function DataAxis(body,options,svg,linegraphOptions){this.id=util.randomUUID();this.body=body;this.defaultOptions={orientation:\"left\",showMinorLabels:true,showMajorLabels:true,icons:false,majorLinesOffset:7,minorLinesOffset:4,labelOffsetX:10,labelOffsetY:2,iconWidth:20,width:\"40px\",visible:true,alignZeros:true,left:{range:{min:undefined,max:undefined},format:function format(value){return\"\"+parseFloat(value.toPrecision(3))},title:{text:undefined,style:undefined}},right:{range:{min:undefined,max:undefined},format:function format(value){return\"\"+parseFloat(value.toPrecision(3))},title:{text:undefined,style:undefined}}};this.linegraphOptions=linegraphOptions;this.linegraphSVG=svg;this.props={};this.DOMelements={lines:{},labels:{},title:{}};this.dom={};this.scale=undefined;this.range={start:0,end:0};this.options=util.extend({},this.defaultOptions);this.conversionFactor=1;this.setOptions(options);this.width=Number((\"\"+this.options.width).replace(\"px\",\"\"));this.minWidth=this.width;this.height=this.linegraphSVG.getBoundingClientRect().height;this.hidden=false;this.stepPixels=25;this.zeroCrossing=-1;this.amountOfSteps=-1;this.lineOffset=0;this.master=true;this.masterAxis=null;this.svgElements={};this.iconsRemoved=false;this.groups={};this.amountOfGroups=0;this._create();this.framework={svg:this.svg,svgElements:this.svgElements,options:this.options,groups:this.groups};var me=this;this.body.emitter.on(\"verticalDrag\",function(){me.dom.lineContainer.style.top=me.body.domProps.scrollTop+\"px\"})}DataAxis.prototype=new Component;DataAxis.prototype.addGroup=function(label,graphOptions){if(!this.groups.hasOwnProperty(label)){this.groups[label]=graphOptions}this.amountOfGroups+=1};DataAxis.prototype.updateGroup=function(label,graphOptions){if(!this.groups.hasOwnProperty(label)){this.amountOfGroups+=1}this.groups[label]=graphOptions};DataAxis.prototype.removeGroup=function(label){if(this.groups.hasOwnProperty(label)){delete this.groups[label];this.amountOfGroups-=1}};DataAxis.prototype.setOptions=function(options){if(options){var redraw=false;if(this.options.orientation!=options.orientation&&options.orientation!==undefined){redraw=true}var fields=[\"orientation\",\"showMinorLabels\",\"showMajorLabels\",\"icons\",\"majorLinesOffset\",\"minorLinesOffset\",\"labelOffsetX\",\"labelOffsetY\",\"iconWidth\",\"width\",\"visible\",\"left\",\"right\",\"alignZeros\"];util.selectiveDeepExtend(fields,this.options,options);this.minWidth=Number((\"\"+this.options.width).replace(\"px\",\"\"));if(redraw===true&&this.dom.frame){this.hide();this.show()}}};DataAxis.prototype._create=function(){this.dom.frame=document.createElement(\"div\");this.dom.frame.style.width=this.options.width;this.dom.frame.style.height=this.height;this.dom.lineContainer=document.createElement(\"div\");this.dom.lineContainer.style.width=\"100%\";this.dom.lineContainer.style.height=this.height;this.dom.lineContainer.style.position=\"relative\";this.svg=document.createElementNS(\"http://www.w3.org/2000/svg\",\"svg\");this.svg.style.position=\"absolute\";this.svg.style.top=\"0px\";this.svg.style.height=\"100%\";this.svg.style.width=\"100%\";this.svg.style.display=\"block\";this.dom.frame.appendChild(this.svg)};DataAxis.prototype._redrawGroupIcons=function(){DOMutil.prepareElements(this.svgElements);var x;var iconWidth=this.options.iconWidth;var iconHeight=15;var iconOffset=4;var y=iconOffset+.5*iconHeight;if(this.options.orientation===\"left\"){x=iconOffset}else{x=this.width-iconWidth-iconOffset}var groupArray=(0,_keys2[\"default\"])(this.groups);groupArray.sort(function(a,b){return a<b?-1:1});for(var i=0;i<groupArray.length;i++){var groupId=groupArray[i];if(this.groups[groupId].visible===true&&(this.linegraphOptions.visibility[groupId]===undefined||this.linegraphOptions.visibility[groupId]===true)){this.groups[groupId].getLegend(iconWidth,iconHeight,this.framework,x,y);y+=iconHeight+iconOffset}}DOMutil.cleanupElements(this.svgElements);this.iconsRemoved=false};DataAxis.prototype._cleanupIcons=function(){if(this.iconsRemoved===false){DOMutil.prepareElements(this.svgElements);DOMutil.cleanupElements(this.svgElements);this.iconsRemoved=true}};DataAxis.prototype.show=function(){this.hidden=false;if(!this.dom.frame.parentNode){if(this.options.orientation===\"left\"){this.body.dom.left.appendChild(this.dom.frame)}else{this.body.dom.right.appendChild(this.dom.frame)}}if(!this.dom.lineContainer.parentNode){this.body.dom.backgroundHorizontal.appendChild(this.dom.lineContainer)}};DataAxis.prototype.hide=function(){this.hidden=true;if(this.dom.frame.parentNode){this.dom.frame.parentNode.removeChild(this.dom.frame)}if(this.dom.lineContainer.parentNode){this.dom.lineContainer.parentNode.removeChild(this.dom.lineContainer)}};DataAxis.prototype.setRange=function(start,end){this.range.start=start;this.range.end=end};DataAxis.prototype.redraw=function(){var resized=false;var activeGroups=0;this.dom.lineContainer.style.top=this.body.domProps.scrollTop+\"px\";for(var groupId in this.groups){if(this.groups.hasOwnProperty(groupId)){if(this.groups[groupId].visible===true&&(this.linegraphOptions.visibility[groupId]===undefined||this.linegraphOptions.visibility[groupId]===true)){activeGroups++}}}if(this.amountOfGroups===0||activeGroups===0){this.hide()}else{this.show();this.height=Number(this.linegraphSVG.style.height.replace(\"px\",\"\"));this.dom.lineContainer.style.height=this.height+\"px\";this.width=this.options.visible===true?Number((\"\"+this.options.width).replace(\"px\",\"\")):0;var props=this.props;var frame=this.dom.frame;frame.className=\"vis-data-axis\";this._calculateCharSize();var orientation=this.options.orientation;var showMinorLabels=this.options.showMinorLabels;var showMajorLabels=this.options.showMajorLabels;props.minorLabelHeight=showMinorLabels?props.minorCharHeight:0;props.majorLabelHeight=showMajorLabels?props.majorCharHeight:0;props.minorLineWidth=this.body.dom.backgroundHorizontal.offsetWidth-this.lineOffset-this.width+2*this.options.minorLinesOffset;props.minorLineHeight=1;props.majorLineWidth=this.body.dom.backgroundHorizontal.offsetWidth-this.lineOffset-this.width+2*this.options.majorLinesOffset;props.majorLineHeight=1;if(orientation===\"left\"){frame.style.top=\"0\";frame.style.left=\"0\";frame.style.bottom=\"\";frame.style.width=this.width+\"px\";frame.style.height=this.height+\"px\";this.props.width=this.body.domProps.left.width;this.props.height=this.body.domProps.left.height}else{frame.style.top=\"\";frame.style.bottom=\"0\";frame.style.left=\"0\";frame.style.width=this.width+\"px\";frame.style.height=this.height+\"px\";this.props.width=this.body.domProps.right.width;this.props.height=this.body.domProps.right.height}resized=this._redrawLabels();resized=this._isResized()||resized;if(this.options.icons===true){this._redrawGroupIcons()}else{this._cleanupIcons()}this._redrawTitle(orientation)}return resized};DataAxis.prototype._redrawLabels=function(){var _this=this;var resized=false;DOMutil.prepareElements(this.DOMelements.lines);DOMutil.prepareElements(this.DOMelements.labels);var orientation=this.options[\"orientation\"];var customRange=this.options[orientation].range!=undefined?this.options[orientation].range:{};var autoScaleEnd=true;if(customRange.max!=undefined){this.range.end=customRange.max;autoScaleEnd=false}var autoScaleStart=true;if(customRange.min!=undefined){this.range.start=customRange.min;autoScaleStart=false}this.scale=new DataScale(this.range.start,this.range.end,autoScaleStart,autoScaleEnd,this.dom.frame.offsetHeight,this.props.majorCharHeight,this.options.alignZeros,this.options[orientation].format);if(this.master===false&&this.masterAxis!=undefined){this.scale.followScale(this.masterAxis.scale)}this.maxLabelSize=0;var lines=this.scale.getLines();lines.forEach(function(line){var y=line.y;var isMajor=line.major;if(_this.options[\"showMinorLabels\"]&&isMajor===false){_this._redrawLabel(y-2,line.val,orientation,\"vis-y-axis vis-minor\",_this.props.minorCharHeight)}if(isMajor){if(y>=0){_this._redrawLabel(y-2,line.val,orientation,\"vis-y-axis vis-major\",_this.props.majorCharHeight)}}if(_this.master===true){if(isMajor){_this._redrawLine(y,orientation,\"vis-grid vis-horizontal vis-major\",_this.options.majorLinesOffset,_this.props.majorLineWidth)}else{_this._redrawLine(y,orientation,\"vis-grid vis-horizontal vis-minor\",_this.options.minorLinesOffset,_this.props.minorLineWidth)}}});var titleWidth=0;if(this.options[orientation].title!==undefined&&this.options[orientation].title.text!==undefined){titleWidth=this.props.titleCharHeight}var offset=this.options.icons===true?Math.max(this.options.iconWidth,titleWidth)+this.options.labelOffsetX+15:titleWidth+this.options.labelOffsetX+15;if(this.maxLabelSize>this.width-offset&&this.options.visible===true){this.width=this.maxLabelSize+offset;this.options.width=this.width+\"px\";DOMutil.cleanupElements(this.DOMelements.lines);DOMutil.cleanupElements(this.DOMelements.labels);this.redraw();resized=true}else if(this.maxLabelSize<this.width-offset&&this.options.visible===true&&this.width>this.minWidth){this.width=Math.max(this.minWidth,this.maxLabelSize+offset);this.options.width=this.width+\"px\";DOMutil.cleanupElements(this.DOMelements.lines);DOMutil.cleanupElements(this.DOMelements.labels);this.redraw();resized=true}else{DOMutil.cleanupElements(this.DOMelements.lines);DOMutil.cleanupElements(this.DOMelements.labels);resized=false}return resized};DataAxis.prototype.convertValue=function(value){return this.scale.convertValue(value)};DataAxis.prototype.screenToValue=function(x){return this.scale.screenToValue(x)};DataAxis.prototype._redrawLabel=function(y,text,orientation,className,characterHeight){var label=DOMutil.getDOMElement(\"div\",this.DOMelements.labels,this.dom.frame);label.className=className;label.innerHTML=text;if(orientation===\"left\"){label.style.left=\"-\"+this.options.labelOffsetX+\"px\";label.style.textAlign=\"right\"}else{label.style.right=\"-\"+this.options.labelOffsetX+\"px\";label.style.textAlign=\"left\"}label.style.top=y-.5*characterHeight+this.options.labelOffsetY+\"px\";text+=\"\";var largestWidth=Math.max(this.props.majorCharWidth,this.props.minorCharWidth);if(this.maxLabelSize<text.length*largestWidth){this.maxLabelSize=text.length*largestWidth}};DataAxis.prototype._redrawLine=function(y,orientation,className,offset,width){if(this.master===true){\nvar line=DOMutil.getDOMElement(\"div\",this.DOMelements.lines,this.dom.lineContainer);line.className=className;line.innerHTML=\"\";if(orientation===\"left\"){line.style.left=this.width-offset+\"px\"}else{line.style.right=this.width-offset+\"px\"}line.style.width=width+\"px\";line.style.top=y+\"px\"}};DataAxis.prototype._redrawTitle=function(orientation){DOMutil.prepareElements(this.DOMelements.title);if(this.options[orientation].title!==undefined&&this.options[orientation].title.text!==undefined){var title=DOMutil.getDOMElement(\"div\",this.DOMelements.title,this.dom.frame);title.className=\"vis-y-axis vis-title vis-\"+orientation;title.innerHTML=this.options[orientation].title.text;if(this.options[orientation].title.style!==undefined){util.addCssText(title,this.options[orientation].title.style)}if(orientation===\"left\"){title.style.left=this.props.titleCharHeight+\"px\"}else{title.style.right=this.props.titleCharHeight+\"px\"}title.style.width=this.height+\"px\"}DOMutil.cleanupElements(this.DOMelements.title)};DataAxis.prototype._calculateCharSize=function(){if(!(\"minorCharHeight\"in this.props)){var textMinor=document.createTextNode(\"0\");var measureCharMinor=document.createElement(\"div\");measureCharMinor.className=\"vis-y-axis vis-minor vis-measure\";measureCharMinor.appendChild(textMinor);this.dom.frame.appendChild(measureCharMinor);this.props.minorCharHeight=measureCharMinor.clientHeight;this.props.minorCharWidth=measureCharMinor.clientWidth;this.dom.frame.removeChild(measureCharMinor)}if(!(\"majorCharHeight\"in this.props)){var textMajor=document.createTextNode(\"0\");var measureCharMajor=document.createElement(\"div\");measureCharMajor.className=\"vis-y-axis vis-major vis-measure\";measureCharMajor.appendChild(textMajor);this.dom.frame.appendChild(measureCharMajor);this.props.majorCharHeight=measureCharMajor.clientHeight;this.props.majorCharWidth=measureCharMajor.clientWidth;this.dom.frame.removeChild(measureCharMajor)}if(!(\"titleCharHeight\"in this.props)){var textTitle=document.createTextNode(\"0\");var measureCharTitle=document.createElement(\"div\");measureCharTitle.className=\"vis-y-axis vis-title vis-measure\";measureCharTitle.appendChild(textTitle);this.dom.frame.appendChild(measureCharTitle);this.props.titleCharHeight=measureCharTitle.clientHeight;this.props.titleCharWidth=measureCharTitle.clientWidth;this.dom.frame.removeChild(measureCharTitle)}};module.exports=DataAxis},function(module,exports,__webpack_require__){\"use strict\";function DataScale(start,end,autoScaleStart,autoScaleEnd,containerHeight,majorCharHeight){var zeroAlign=arguments.length>6&&arguments[6]!==undefined?arguments[6]:false;var formattingFunction=arguments.length>7&&arguments[7]!==undefined?arguments[7]:false;this.majorSteps=[1,2,5,10];this.minorSteps=[.25,.5,1,2];this.customLines=null;this.containerHeight=containerHeight;this.majorCharHeight=majorCharHeight;this._start=start;this._end=end;this.scale=1;this.minorStepIdx=-1;this.magnitudefactor=1;this.determineScale();this.zeroAlign=zeroAlign;this.autoScaleStart=autoScaleStart;this.autoScaleEnd=autoScaleEnd;this.formattingFunction=formattingFunction;if(autoScaleStart||autoScaleEnd){var me=this;var roundToMinor=function roundToMinor(value){var rounded=value-value%(me.magnitudefactor*me.minorSteps[me.minorStepIdx]);if(value%(me.magnitudefactor*me.minorSteps[me.minorStepIdx])>.5*(me.magnitudefactor*me.minorSteps[me.minorStepIdx])){return rounded+me.magnitudefactor*me.minorSteps[me.minorStepIdx]}else{return rounded}};if(autoScaleStart){this._start-=this.magnitudefactor*2*this.minorSteps[this.minorStepIdx];this._start=roundToMinor(this._start)}if(autoScaleEnd){this._end+=this.magnitudefactor*this.minorSteps[this.minorStepIdx];this._end=roundToMinor(this._end)}this.determineScale()}}DataScale.prototype.setCharHeight=function(majorCharHeight){this.majorCharHeight=majorCharHeight};DataScale.prototype.setHeight=function(containerHeight){this.containerHeight=containerHeight};DataScale.prototype.determineScale=function(){var range=this._end-this._start;this.scale=this.containerHeight/range;var minimumStepValue=this.majorCharHeight/this.scale;var orderOfMagnitude=range>0?Math.round(Math.log(range)/Math.LN10):0;this.minorStepIdx=-1;this.magnitudefactor=Math.pow(10,orderOfMagnitude);var start=0;if(orderOfMagnitude<0){start=orderOfMagnitude}var solutionFound=false;for(var l=start;Math.abs(l)<=Math.abs(orderOfMagnitude);l++){this.magnitudefactor=Math.pow(10,l);for(var j=0;j<this.minorSteps.length;j++){var stepSize=this.magnitudefactor*this.minorSteps[j];if(stepSize>=minimumStepValue){solutionFound=true;this.minorStepIdx=j;break}}if(solutionFound===true){break}}};DataScale.prototype.is_major=function(value){return value%(this.magnitudefactor*this.majorSteps[this.minorStepIdx])===0};DataScale.prototype.getStep=function(){return this.magnitudefactor*this.minorSteps[this.minorStepIdx]};DataScale.prototype.getFirstMajor=function(){var majorStep=this.magnitudefactor*this.majorSteps[this.minorStepIdx];return this.convertValue(this._start+(majorStep-this._start%majorStep)%majorStep)};DataScale.prototype.formatValue=function(current){var returnValue=current.toPrecision(5);if(typeof this.formattingFunction===\"function\"){returnValue=this.formattingFunction(current)}if(typeof returnValue===\"number\"){return\"\"+returnValue}else if(typeof returnValue===\"string\"){return returnValue}else{return current.toPrecision(5)}};DataScale.prototype.getLines=function(){var lines=[];var step=this.getStep();var bottomOffset=(step-this._start%step)%step;for(var i=this._start+bottomOffset;this._end-i>1e-5;i+=step){if(i!=this._start){lines.push({major:this.is_major(i),y:this.convertValue(i),val:this.formatValue(i)})}}return lines};DataScale.prototype.followScale=function(other){var oldStepIdx=this.minorStepIdx;var oldStart=this._start;var oldEnd=this._end;var me=this;var increaseMagnitude=function increaseMagnitude(){me.magnitudefactor*=2};var decreaseMagnitude=function decreaseMagnitude(){me.magnitudefactor/=2};if(other.minorStepIdx<=1&&this.minorStepIdx<=1||other.minorStepIdx>1&&this.minorStepIdx>1){}else if(other.minorStepIdx<this.minorStepIdx){this.minorStepIdx=1;if(oldStepIdx==2){increaseMagnitude()}else{increaseMagnitude();increaseMagnitude()}}else{this.minorStepIdx=2;if(oldStepIdx==1){decreaseMagnitude()}else{decreaseMagnitude();decreaseMagnitude()}}var otherZero=other.convertValue(0);var otherStep=other.getStep()*other.scale;var done=false;var count=0;while(!done&&count++<5){this.scale=otherStep/(this.minorSteps[this.minorStepIdx]*this.magnitudefactor);var newRange=this.containerHeight/this.scale;this._start=oldStart;this._end=this._start+newRange;var myOriginalZero=this._end*this.scale;var majorStep=this.magnitudefactor*this.majorSteps[this.minorStepIdx];var majorOffset=this.getFirstMajor()-other.getFirstMajor();if(this.zeroAlign){var zeroOffset=otherZero-myOriginalZero;this._end+=zeroOffset/this.scale;this._start=this._end-newRange}else{if(!this.autoScaleStart){this._start+=majorStep-majorOffset/this.scale;this._end=this._start+newRange}else{this._start-=majorOffset/this.scale;this._end=this._start+newRange}}if(!this.autoScaleEnd&&this._end>oldEnd+1e-5){decreaseMagnitude();done=false;continue}if(!this.autoScaleStart&&this._start<oldStart-1e-5){if(this.zeroAlign&&oldStart>=0){console.warn(\"Can't adhere to given 'min' range, due to zeroalign\")}else{decreaseMagnitude();done=false;continue}}if(this.autoScaleStart&&this.autoScaleEnd&&newRange<oldEnd-oldStart){increaseMagnitude();done=false;continue}done=true}};DataScale.prototype.convertValue=function(value){return this.containerHeight-(value-this._start)*this.scale};DataScale.prototype.screenToValue=function(pixels){return(this.containerHeight-pixels)/this.scale+this._start};module.exports=DataScale},function(module,exports,__webpack_require__){\"use strict\";var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var Bars=__webpack_require__(110);var Lines=__webpack_require__(111);var Points=__webpack_require__(72);function GraphGroup(group,groupId,options,groupsUsingDefaultStyles){this.id=groupId;var fields=[\"sampling\",\"style\",\"sort\",\"yAxisOrientation\",\"barChart\",\"drawPoints\",\"shaded\",\"interpolation\",\"zIndex\",\"excludeFromStacking\",\"excludeFromLegend\"];this.options=util.selectiveBridgeObject(fields,options);this.usingDefaultStyle=group.className===undefined;this.groupsUsingDefaultStyles=groupsUsingDefaultStyles;this.zeroPosition=0;this.update(group);if(this.usingDefaultStyle==true){this.groupsUsingDefaultStyles[0]+=1}this.itemsData=[];this.visible=group.visible===undefined?true:group.visible}GraphGroup.prototype.setItems=function(items){if(items!=null){this.itemsData=items;if(this.options.sort==true){util.insertSort(this.itemsData,function(a,b){return a.x>b.x?1:-1})}}else{this.itemsData=[]}};GraphGroup.prototype.getItems=function(){return this.itemsData};GraphGroup.prototype.setZeroPosition=function(pos){this.zeroPosition=pos};GraphGroup.prototype.setOptions=function(options){if(options!==undefined){var fields=[\"sampling\",\"style\",\"sort\",\"yAxisOrientation\",\"barChart\",\"zIndex\",\"excludeFromStacking\",\"excludeFromLegend\"];util.selectiveDeepExtend(fields,this.options,options);if(typeof options.drawPoints==\"function\"){options.drawPoints={onRender:options.drawPoints}}util.mergeOptions(this.options,options,\"interpolation\");util.mergeOptions(this.options,options,\"drawPoints\");util.mergeOptions(this.options,options,\"shaded\");if(options.interpolation){if((0,_typeof3[\"default\"])(options.interpolation)==\"object\"){if(options.interpolation.parametrization){if(options.interpolation.parametrization==\"uniform\"){this.options.interpolation.alpha=0}else if(options.interpolation.parametrization==\"chordal\"){this.options.interpolation.alpha=1}else{this.options.interpolation.parametrization=\"centripetal\";this.options.interpolation.alpha=.5}}}}}};GraphGroup.prototype.update=function(group){this.group=group;this.content=group.content||\"graph\";this.className=group.className||this.className||\"vis-graph-group\"+this.groupsUsingDefaultStyles[0]%10;this.visible=group.visible===undefined?true:group.visible;this.style=group.style;this.setOptions(group.options)};GraphGroup.prototype.getLegend=function(iconWidth,iconHeight,framework,x,y){if(framework==undefined||framework==null){var svg=document.createElementNS(\"http://www.w3.org/2000/svg\",\"svg\");framework={svg:svg,svgElements:{},options:this.options,groups:[this]}}if(x==undefined||x==null){x=0}if(y==undefined||y==null){y=.5*iconHeight}switch(this.options.style){case\"line\":Lines.drawIcon(this,x,y,iconWidth,iconHeight,framework);break;case\"points\":case\"point\":Points.drawIcon(this,x,y,iconWidth,iconHeight,framework);break;case\"bar\":Bars.drawIcon(this,x,y,iconWidth,iconHeight,framework);break}return{icon:framework.svg,label:this.content,orientation:this.options.yAxisOrientation}};GraphGroup.prototype.getYRange=function(groupData){var yMin=groupData[0].y;var yMax=groupData[0].y;for(var j=0;j<groupData.length;j++){yMin=yMin>groupData[j].y?groupData[j].y:yMin;yMax=yMax<groupData[j].y?groupData[j].y:yMax}return{min:yMin,max:yMax,yAxisOrientation:this.options.yAxisOrientation}};module.exports=GraphGroup},function(module,exports,__webpack_require__){\"use strict\";var DOMutil=__webpack_require__(14);var Points=__webpack_require__(72);function Bargraph(groupId,options){}Bargraph.drawIcon=function(group,x,y,iconWidth,iconHeight,framework){var fillHeight=iconHeight*.5;var outline=DOMutil.getSVGElement(\"rect\",framework.svgElements,framework.svg);outline.setAttributeNS(null,\"x\",x);outline.setAttributeNS(null,\"y\",y-fillHeight);outline.setAttributeNS(null,\"width\",iconWidth);outline.setAttributeNS(null,\"height\",2*fillHeight);outline.setAttributeNS(null,\"class\",\"vis-outline\");var barWidth=Math.round(.3*iconWidth);var originalWidth=group.options.barChart.width;var scale=originalWidth/barWidth;var bar1Height=Math.round(.4*iconHeight);var bar2Height=Math.round(.75*iconHeight);var offset=Math.round((iconWidth-2*barWidth)/3);DOMutil.drawBar(x+.5*barWidth+offset,y+fillHeight-bar1Height-1,barWidth,bar1Height,group.className+\" vis-bar\",framework.svgElements,framework.svg,group.style);DOMutil.drawBar(x+1.5*barWidth+offset+2,y+fillHeight-bar2Height-1,barWidth,bar2Height,group.className+\" vis-bar\",framework.svgElements,framework.svg,group.style);if(group.options.drawPoints.enabled==true){var groupTemplate={style:group.options.drawPoints.style,styles:group.options.drawPoints.styles,size:group.options.drawPoints.size/scale,className:group.className};DOMutil.drawPoint(x+.5*barWidth+offset,y+fillHeight-bar1Height-1,groupTemplate,framework.svgElements,framework.svg);DOMutil.drawPoint(x+1.5*barWidth+offset+2,y+fillHeight-bar2Height-1,groupTemplate,framework.svgElements,framework.svg)}};Bargraph.draw=function(groupIds,processedGroupData,framework){var combinedData=[];var intersections={};var coreDistance;var key,drawData;var group;var i,j;var barPoints=0;for(i=0;i<groupIds.length;i++){group=framework.groups[groupIds[i]];if(group.options.style===\"bar\"){if(group.visible===true&&(framework.options.groups.visibility[groupIds[i]]===undefined||framework.options.groups.visibility[groupIds[i]]===true)){for(j=0;j<processedGroupData[groupIds[i]].length;j++){combinedData.push({screen_x:processedGroupData[groupIds[i]][j].screen_x,screen_end:processedGroupData[groupIds[i]][j].screen_end,screen_y:processedGroupData[groupIds[i]][j].screen_y,x:processedGroupData[groupIds[i]][j].x,end:processedGroupData[groupIds[i]][j].end,y:processedGroupData[groupIds[i]][j].y,groupId:groupIds[i],label:processedGroupData[groupIds[i]][j].label});barPoints+=1}}}}if(barPoints===0){return}combinedData.sort(function(a,b){if(a.screen_x===b.screen_x){return a.groupId<b.groupId?-1:1}else{return a.screen_x-b.screen_x}});Bargraph._getDataIntersections(intersections,combinedData);for(i=0;i<combinedData.length;i++){group=framework.groups[combinedData[i].groupId];var minWidth=group.options.barChart.minWidth!=undefined?group.options.barChart.minWidth:.1*group.options.barChart.width;key=combinedData[i].screen_x;var heightOffset=0;if(intersections[key]===undefined){if(i+1<combinedData.length){coreDistance=Math.abs(combinedData[i+1].screen_x-key)}drawData=Bargraph._getSafeDrawData(coreDistance,group,minWidth)}else{var nextKey=i+(intersections[key].amount-intersections[key].resolved);if(nextKey<combinedData.length){coreDistance=Math.abs(combinedData[nextKey].screen_x-key)}drawData=Bargraph._getSafeDrawData(coreDistance,group,minWidth);intersections[key].resolved+=1;if(group.options.stack===true&&group.options.excludeFromStacking!==true){if(combinedData[i].screen_y<group.zeroPosition){heightOffset=intersections[key].accumulatedNegative;intersections[key].accumulatedNegative+=group.zeroPosition-combinedData[i].screen_y}else{heightOffset=intersections[key].accumulatedPositive;intersections[key].accumulatedPositive+=group.zeroPosition-combinedData[i].screen_y}}else if(group.options.barChart.sideBySide===true){drawData.width=drawData.width/intersections[key].amount;drawData.offset+=intersections[key].resolved*drawData.width-.5*drawData.width*(intersections[key].amount+1)}}var dataWidth=drawData.width;var start=combinedData[i].screen_x;if(combinedData[i].screen_end!=undefined){dataWidth=combinedData[i].screen_end-combinedData[i].screen_x;start+=dataWidth*.5}else{start+=drawData.offset}DOMutil.drawBar(start,combinedData[i].screen_y-heightOffset,dataWidth,group.zeroPosition-combinedData[i].screen_y,group.className+\" vis-bar\",framework.svgElements,framework.svg,group.style);if(group.options.drawPoints.enabled===true){var pointData={screen_x:combinedData[i].screen_x,screen_y:combinedData[i].screen_y-heightOffset,x:combinedData[i].x,y:combinedData[i].y,groupId:combinedData[i].groupId,label:combinedData[i].label};Points.draw([pointData],group,framework,drawData.offset)}}};Bargraph._getDataIntersections=function(intersections,combinedData){var coreDistance;for(var i=0;i<combinedData.length;i++){if(i+1<combinedData.length){coreDistance=Math.abs(combinedData[i+1].screen_x-combinedData[i].screen_x)}if(i>0){coreDistance=Math.min(coreDistance,Math.abs(combinedData[i-1].screen_x-combinedData[i].screen_x))}if(coreDistance===0){if(intersections[combinedData[i].screen_x]===undefined){intersections[combinedData[i].screen_x]={amount:0,resolved:0,accumulatedPositive:0,accumulatedNegative:0}}intersections[combinedData[i].screen_x].amount+=1}}};Bargraph._getSafeDrawData=function(coreDistance,group,minWidth){var width,offset;if(coreDistance<group.options.barChart.width&&coreDistance>0){width=coreDistance<minWidth?minWidth:coreDistance;offset=0;if(group.options.barChart.align===\"left\"){offset-=.5*coreDistance}else if(group.options.barChart.align===\"right\"){offset+=.5*coreDistance}}else{width=group.options.barChart.width;offset=0;if(group.options.barChart.align===\"left\"){offset-=.5*group.options.barChart.width}else if(group.options.barChart.align===\"right\"){offset+=.5*group.options.barChart.width}}return{width:width,offset:offset}};Bargraph.getStackedYRange=function(combinedData,groupRanges,groupIds,groupLabel,orientation){if(combinedData.length>0){combinedData.sort(function(a,b){if(a.screen_x===b.screen_x){return a.groupId<b.groupId?-1:1}else{return a.screen_x-b.screen_x}});var intersections={};Bargraph._getDataIntersections(intersections,combinedData);groupRanges[groupLabel]=Bargraph._getStackedYRange(intersections,combinedData);groupRanges[groupLabel].yAxisOrientation=orientation;groupIds.push(groupLabel)}};Bargraph._getStackedYRange=function(intersections,combinedData){var key;var yMin=combinedData[0].screen_y;var yMax=combinedData[0].screen_y;for(var i=0;i<combinedData.length;i++){key=combinedData[i].screen_x;if(intersections[key]===undefined){yMin=yMin>combinedData[i].screen_y?combinedData[i].screen_y:yMin;yMax=yMax<combinedData[i].screen_y?combinedData[i].screen_y:yMax}else{if(combinedData[i].screen_y<0){intersections[key].accumulatedNegative+=combinedData[i].screen_y}else{intersections[key].accumulatedPositive+=combinedData[i].screen_y}}}for(var xpos in intersections){if(intersections.hasOwnProperty(xpos)){yMin=yMin>intersections[xpos].accumulatedNegative?intersections[xpos].accumulatedNegative:yMin;yMin=yMin>intersections[xpos].accumulatedPositive?intersections[xpos].accumulatedPositive:yMin;yMax=yMax<intersections[xpos].accumulatedNegative?intersections[xpos].accumulatedNegative:yMax;yMax=yMax<intersections[xpos].accumulatedPositive?intersections[xpos].accumulatedPositive:yMax}}return{min:yMin,max:yMax}};module.exports=Bargraph},function(module,exports,__webpack_require__){\"use strict\";var DOMutil=__webpack_require__(14);function Line(groupId,options){}Line.calcPath=function(dataset,group){if(dataset!=null){if(dataset.length>0){var d=[];if(group.options.interpolation.enabled==true){d=Line._catmullRom(dataset,group)}else{d=Line._linear(dataset)}return d}}};Line.drawIcon=function(group,x,y,iconWidth,iconHeight,framework){var fillHeight=iconHeight*.5;var path,fillPath;var outline=DOMutil.getSVGElement(\"rect\",framework.svgElements,framework.svg);outline.setAttributeNS(null,\"x\",x);outline.setAttributeNS(null,\"y\",y-fillHeight);outline.setAttributeNS(null,\"width\",iconWidth);outline.setAttributeNS(null,\"height\",2*fillHeight);outline.setAttributeNS(null,\"class\",\"vis-outline\");path=DOMutil.getSVGElement(\"path\",framework.svgElements,framework.svg);path.setAttributeNS(null,\"class\",group.className);if(group.style!==undefined){path.setAttributeNS(null,\"style\",group.style)}path.setAttributeNS(null,\"d\",\"M\"+x+\",\"+y+\" L\"+(x+iconWidth)+\",\"+y+\"\");if(group.options.shaded.enabled==true){fillPath=DOMutil.getSVGElement(\"path\",framework.svgElements,framework.svg);if(group.options.shaded.orientation==\"top\"){fillPath.setAttributeNS(null,\"d\",\"M\"+x+\", \"+(y-fillHeight)+\"L\"+x+\",\"+y+\" L\"+(x+iconWidth)+\",\"+y+\" L\"+(x+iconWidth)+\",\"+(y-fillHeight))}else{fillPath.setAttributeNS(null,\"d\",\"M\"+x+\",\"+y+\" \"+\"L\"+x+\",\"+(y+fillHeight)+\" \"+\"L\"+(x+iconWidth)+\",\"+(y+fillHeight)+\"L\"+(x+iconWidth)+\",\"+y)}fillPath.setAttributeNS(null,\"class\",group.className+\" vis-icon-fill\");if(group.options.shaded.style!==undefined&&group.options.shaded.style!==\"\"){fillPath.setAttributeNS(null,\"style\",group.options.shaded.style)}}if(group.options.drawPoints.enabled==true){var groupTemplate={style:group.options.drawPoints.style,styles:group.options.drawPoints.styles,size:group.options.drawPoints.size,className:group.className};DOMutil.drawPoint(x+.5*iconWidth,y,groupTemplate,framework.svgElements,framework.svg)}};Line.drawShading=function(pathArray,group,subPathArray,framework){if(group.options.shaded.enabled==true){var svgHeight=Number(framework.svg.style.height.replace(\"px\",\"\"));var fillPath=DOMutil.getSVGElement(\"path\",framework.svgElements,framework.svg);var type=\"L\";if(group.options.interpolation.enabled==true){type=\"C\"}var dFill;var zero=0;if(group.options.shaded.orientation==\"top\"){zero=0}else if(group.options.shaded.orientation==\"bottom\"){zero=svgHeight}else{zero=Math.min(Math.max(0,group.zeroPosition),svgHeight)}if(group.options.shaded.orientation==\"group\"&&subPathArray!=null&&subPathArray!=undefined){dFill=\"M\"+pathArray[0][0]+\",\"+pathArray[0][1]+\" \"+this.serializePath(pathArray,type,false)+\" L\"+subPathArray[subPathArray.length-1][0]+\",\"+subPathArray[subPathArray.length-1][1]+\" \"+this.serializePath(subPathArray,type,true)+subPathArray[0][0]+\",\"+subPathArray[0][1]+\" Z\"}else{dFill=\"M\"+pathArray[0][0]+\",\"+pathArray[0][1]+\" \"+this.serializePath(pathArray,type,false)+\" V\"+zero+\" H\"+pathArray[0][0]+\" Z\"}fillPath.setAttributeNS(null,\"class\",group.className+\" vis-fill\");if(group.options.shaded.style!==undefined){fillPath.setAttributeNS(null,\"style\",group.options.shaded.style)}fillPath.setAttributeNS(null,\"d\",dFill)}};Line.draw=function(pathArray,group,framework){if(pathArray!=null&&pathArray!=undefined){var path=DOMutil.getSVGElement(\"path\",framework.svgElements,framework.svg);path.setAttributeNS(null,\"class\",group.className);if(group.style!==undefined){path.setAttributeNS(null,\"style\",group.style)}var type=\"L\";if(group.options.interpolation.enabled==true){type=\"C\"}path.setAttributeNS(null,\"d\",\"M\"+pathArray[0][0]+\",\"+pathArray[0][1]+\" \"+this.serializePath(pathArray,type,false))}};Line.serializePath=function(pathArray,type,inverse){if(pathArray.length<2){return\"\"}var d=type;var i;if(inverse){for(i=pathArray.length-2;i>0;i--){d+=pathArray[i][0]+\",\"+pathArray[i][1]+\" \"}}else{for(i=1;i<pathArray.length;i++){d+=pathArray[i][0]+\",\"+pathArray[i][1]+\" \"}}return d};Line._catmullRomUniform=function(data){var p0,p1,p2,p3,bp1,bp2;var d=[];d.push([Math.round(data[0].screen_x),Math.round(data[0].screen_y)]);var normalization=1/6;var length=data.length;for(var i=0;i<length-1;i++){p0=i==0?data[0]:data[i-1];p1=data[i];p2=data[i+1];p3=i+2<length?data[i+2]:p2;bp1={screen_x:(-p0.screen_x+6*p1.screen_x+p2.screen_x)*normalization,screen_y:(-p0.screen_y+6*p1.screen_y+p2.screen_y)*normalization};bp2={screen_x:(p1.screen_x+6*p2.screen_x-p3.screen_x)*normalization,screen_y:(p1.screen_y+6*p2.screen_y-p3.screen_y)*normalization};d.push([bp1.screen_x,bp1.screen_y]);d.push([bp2.screen_x,bp2.screen_y]);d.push([p2.screen_x,p2.screen_y])}return d};Line._catmullRom=function(data,group){var alpha=group.options.interpolation.alpha;if(alpha==0||alpha===undefined){return this._catmullRomUniform(data)}else{var p0,p1,p2,p3,bp1,bp2,d1,d2,d3,A,B,N,M;var d3powA,d2powA,d3pow2A,d2pow2A,d1pow2A,d1powA;var d=[];d.push([Math.round(data[0].screen_x),Math.round(data[0].screen_y)]);var length=data.length;for(var i=0;i<length-1;i++){p0=i==0?data[0]:data[i-1];p1=data[i];p2=data[i+1];p3=i+2<length?data[i+2]:p2;d1=Math.sqrt(Math.pow(p0.screen_x-p1.screen_x,2)+Math.pow(p0.screen_y-p1.screen_y,2));d2=Math.sqrt(Math.pow(p1.screen_x-p2.screen_x,2)+Math.pow(p1.screen_y-p2.screen_y,2));d3=Math.sqrt(Math.pow(p2.screen_x-p3.screen_x,2)+Math.pow(p2.screen_y-p3.screen_y,2));d3powA=Math.pow(d3,alpha);d3pow2A=Math.pow(d3,2*alpha);d2powA=Math.pow(d2,alpha);d2pow2A=Math.pow(d2,2*alpha);d1powA=Math.pow(d1,alpha);d1pow2A=Math.pow(d1,2*alpha);A=2*d1pow2A+3*d1powA*d2powA+d2pow2A;B=2*d3pow2A+3*d3powA*d2powA+d2pow2A;N=3*d1powA*(d1powA+d2powA);if(N>0){N=1/N}M=3*d3powA*(d3powA+d2powA);if(M>0){M=1/M}bp1={screen_x:(-d2pow2A*p0.screen_x+A*p1.screen_x+d1pow2A*p2.screen_x)*N,screen_y:(-d2pow2A*p0.screen_y+A*p1.screen_y+d1pow2A*p2.screen_y)*N};bp2={screen_x:(d3pow2A*p1.screen_x+B*p2.screen_x-d2pow2A*p3.screen_x)*M,screen_y:(d3pow2A*p1.screen_y+B*p2.screen_y-d2pow2A*p3.screen_y)*M};if(bp1.screen_x==0&&bp1.screen_y==0){bp1=p1}if(bp2.screen_x==0&&bp2.screen_y==0){bp2=p2}d.push([bp1.screen_x,bp1.screen_y]);d.push([bp2.screen_x,bp2.screen_y]);d.push([p2.screen_x,p2.screen_y])}return d}};Line._linear=function(data){var d=[];for(var i=0;i<data.length;i++){d.push([data[i].screen_x,data[i].screen_y])}return d};module.exports=Line},function(module,exports,__webpack_require__){\"use strict\";var _keys=__webpack_require__(8);var _keys2=_interopRequireDefault(_keys);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var DOMutil=__webpack_require__(14);var Component=__webpack_require__(16);function Legend(body,options,side,linegraphOptions){this.body=body;this.defaultOptions={enabled:false,icons:true,iconSize:20,iconSpacing:6,left:{visible:true,position:\"top-left\"},right:{visible:true,position:\"top-right\"}};this.side=side;this.options=util.extend({},this.defaultOptions);this.linegraphOptions=linegraphOptions;this.svgElements={};this.dom={};this.groups={};this.amountOfGroups=0;this._create();this.framework={svg:this.svg,svgElements:this.svgElements,options:this.options,groups:this.groups};this.setOptions(options)}Legend.prototype=new Component;Legend.prototype.clear=function(){this.groups={};this.amountOfGroups=0};Legend.prototype.addGroup=function(label,graphOptions){if(graphOptions.options.excludeFromLegend!=true){if(!this.groups.hasOwnProperty(label)){this.groups[label]=graphOptions}this.amountOfGroups+=1}};Legend.prototype.updateGroup=function(label,graphOptions){this.groups[label]=graphOptions};Legend.prototype.removeGroup=function(label){if(this.groups.hasOwnProperty(label)){delete this.groups[label];this.amountOfGroups-=1}};Legend.prototype._create=function(){this.dom.frame=document.createElement(\"div\");this.dom.frame.className=\"vis-legend\";this.dom.frame.style.position=\"absolute\";this.dom.frame.style.top=\"10px\";this.dom.frame.style.display=\"block\";this.dom.textArea=document.createElement(\"div\");this.dom.textArea.className=\"vis-legend-text\";this.dom.textArea.style.position=\"relative\";this.dom.textArea.style.top=\"0px\";this.svg=document.createElementNS(\"http://www.w3.org/2000/svg\",\"svg\");this.svg.style.position=\"absolute\";this.svg.style.top=0+\"px\";this.svg.style.width=this.options.iconSize+5+\"px\";this.svg.style.height=\"100%\";this.dom.frame.appendChild(this.svg);this.dom.frame.appendChild(this.dom.textArea)};Legend.prototype.hide=function(){if(this.dom.frame.parentNode){this.dom.frame.parentNode.removeChild(this.dom.frame)}};Legend.prototype.show=function(){if(!this.dom.frame.parentNode){this.body.dom.center.appendChild(this.dom.frame)}};Legend.prototype.setOptions=function(options){var fields=[\"enabled\",\"orientation\",\"icons\",\"left\",\"right\"];util.selectiveDeepExtend(fields,this.options,options)};Legend.prototype.redraw=function(){var activeGroups=0;var groupArray=(0,_keys2[\"default\"])(this.groups);groupArray.sort(function(a,b){return a<b?-1:1});for(var i=0;i<groupArray.length;i++){var groupId=groupArray[i];if(this.groups[groupId].visible==true&&(this.linegraphOptions.visibility[groupId]===undefined||this.linegraphOptions.visibility[groupId]==true)){activeGroups++}}if(this.options[this.side].visible==false||this.amountOfGroups==0||this.options.enabled==false||activeGroups==0){this.hide()}else{this.show();if(this.options[this.side].position==\"top-left\"||this.options[this.side].position==\"bottom-left\"){this.dom.frame.style.left=\"4px\";this.dom.frame.style.textAlign=\"left\";this.dom.textArea.style.textAlign=\"left\";this.dom.textArea.style.left=this.options.iconSize+15+\"px\";this.dom.textArea.style.right=\"\";this.svg.style.left=0+\"px\";this.svg.style.right=\"\"}else{this.dom.frame.style.right=\"4px\";this.dom.frame.style.textAlign=\"right\";this.dom.textArea.style.textAlign=\"right\";this.dom.textArea.style.right=this.options.iconSize+15+\"px\";this.dom.textArea.style.left=\"\";this.svg.style.right=0+\"px\";this.svg.style.left=\"\"}if(this.options[this.side].position==\"top-left\"||this.options[this.side].position==\"top-right\"){this.dom.frame.style.top=4-Number(this.body.dom.center.style.top.replace(\"px\",\"\"))+\"px\";this.dom.frame.style.bottom=\"\"}else{var scrollableHeight=this.body.domProps.center.height-this.body.domProps.centerContainer.height;this.dom.frame.style.bottom=4+scrollableHeight+Number(this.body.dom.center.style.top.replace(\"px\",\"\"))+\"px\";this.dom.frame.style.top=\"\"}if(this.options.icons==false){this.dom.frame.style.width=this.dom.textArea.offsetWidth+10+\"px\";this.dom.textArea.style.right=\"\";this.dom.textArea.style.left=\"\";this.svg.style.width=\"0px\"}else{this.dom.frame.style.width=this.options.iconSize+15+this.dom.textArea.offsetWidth+10+\"px\";this.drawLegendIcons()}var content=\"\";for(i=0;i<groupArray.length;i++){groupId=groupArray[i];if(this.groups[groupId].visible==true&&(this.linegraphOptions.visibility[groupId]===undefined||this.linegraphOptions.visibility[groupId]==true)){content+=this.groups[groupId].content+\"<br />\"}}this.dom.textArea.innerHTML=content;this.dom.textArea.style.lineHeight=.75*this.options.iconSize+this.options.iconSpacing+\"px\"}};Legend.prototype.drawLegendIcons=function(){if(this.dom.frame.parentNode){var groupArray=(0,_keys2[\"default\"])(this.groups);groupArray.sort(function(a,b){return a<b?-1:1});DOMutil.resetElements(this.svgElements);var padding=window.getComputedStyle(this.dom.frame).paddingTop;var iconOffset=Number(padding.replace(\"px\",\"\"));var x=iconOffset;var iconWidth=this.options.iconSize;var iconHeight=.75*this.options.iconSize;var y=iconOffset+.5*iconHeight+3;this.svg.style.width=iconWidth+5+iconOffset+\"px\";for(var i=0;i<groupArray.length;i++){var groupId=groupArray[i];if(this.groups[groupId].visible==true&&(this.linegraphOptions.visibility[groupId]===undefined||this.linegraphOptions.visibility[groupId]==true)){this.groups[groupId].getLegend(iconWidth,iconHeight,this.framework,x,y);y+=iconHeight+this.options.iconSpacing}}}};module.exports=Legend},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var string=\"string\";var bool=\"boolean\";var number=\"number\";var array=\"array\";var date=\"date\";var object=\"object\";var dom=\"dom\";var moment=\"moment\";var any=\"any\";var allOptions={configure:{enabled:{boolean:bool},filter:{boolean:bool,function:\"function\"},container:{dom:dom},__type__:{object:object,boolean:bool,function:\"function\"}},yAxisOrientation:{string:[\"left\",\"right\"]},defaultGroup:{string:string},sort:{boolean:bool},sampling:{boolean:bool},stack:{boolean:bool},graphHeight:{string:string,number:number},shaded:{enabled:{boolean:bool},orientation:{string:[\"bottom\",\"top\",\"zero\",\"group\"]},groupId:{object:object},__type__:{boolean:bool,object:object}},style:{string:[\"line\",\"bar\",\"points\"]},barChart:{width:{number:number},minWidth:{number:number},sideBySide:{boolean:bool},align:{string:[\"left\",\"center\",\"right\"]},__type__:{object:object}},interpolation:{enabled:{boolean:bool},parametrization:{string:[\"centripetal\",\"chordal\",\"uniform\"]},alpha:{number:number},__type__:{object:object,boolean:bool}},drawPoints:{enabled:{boolean:bool},onRender:{function:\"function\"},size:{number:number},style:{string:[\"square\",\"circle\"]},__type__:{object:object,boolean:bool,function:\"function\"}},dataAxis:{showMinorLabels:{boolean:bool},showMajorLabels:{boolean:bool},icons:{boolean:bool},width:{string:string,number:number},visible:{boolean:bool},alignZeros:{boolean:bool},left:{range:{min:{\nnumber:number,undefined:\"undefined\"},max:{number:number,undefined:\"undefined\"},__type__:{object:object}},format:{function:\"function\"},title:{text:{string:string,number:number,undefined:\"undefined\"},style:{string:string,undefined:\"undefined\"},__type__:{object:object}},__type__:{object:object}},right:{range:{min:{number:number,undefined:\"undefined\"},max:{number:number,undefined:\"undefined\"},__type__:{object:object}},format:{function:\"function\"},title:{text:{string:string,number:number,undefined:\"undefined\"},style:{string:string,undefined:\"undefined\"},__type__:{object:object}},__type__:{object:object}},__type__:{object:object}},legend:{enabled:{boolean:bool},icons:{boolean:bool},left:{visible:{boolean:bool},position:{string:[\"top-right\",\"bottom-right\",\"top-left\",\"bottom-left\"]},__type__:{object:object}},right:{visible:{boolean:bool},position:{string:[\"top-right\",\"bottom-right\",\"top-left\",\"bottom-left\"]},__type__:{object:object}},__type__:{object:object,boolean:bool}},groups:{visibility:{any:any},__type__:{object:object}},autoResize:{boolean:bool},throttleRedraw:{number:number},clickToUse:{boolean:bool},end:{number:number,date:date,string:string,moment:moment},format:{minorLabels:{millisecond:{string:string,undefined:\"undefined\"},second:{string:string,undefined:\"undefined\"},minute:{string:string,undefined:\"undefined\"},hour:{string:string,undefined:\"undefined\"},weekday:{string:string,undefined:\"undefined\"},day:{string:string,undefined:\"undefined\"},month:{string:string,undefined:\"undefined\"},year:{string:string,undefined:\"undefined\"},__type__:{object:object}},majorLabels:{millisecond:{string:string,undefined:\"undefined\"},second:{string:string,undefined:\"undefined\"},minute:{string:string,undefined:\"undefined\"},hour:{string:string,undefined:\"undefined\"},weekday:{string:string,undefined:\"undefined\"},day:{string:string,undefined:\"undefined\"},month:{string:string,undefined:\"undefined\"},year:{string:string,undefined:\"undefined\"},__type__:{object:object}},__type__:{object:object}},moment:{function:\"function\"},height:{string:string,number:number},hiddenDates:{start:{date:date,number:number,string:string,moment:moment},end:{date:date,number:number,string:string,moment:moment},repeat:{string:string},__type__:{object:object,array:array}},locale:{string:string},locales:{__any__:{any:any},__type__:{object:object}},max:{date:date,number:number,string:string,moment:moment},maxHeight:{number:number,string:string},maxMinorChars:{number:number},min:{date:date,number:number,string:string,moment:moment},minHeight:{number:number,string:string},moveable:{boolean:bool},multiselect:{boolean:bool},orientation:{string:string},showCurrentTime:{boolean:bool},showMajorLabels:{boolean:bool},showMinorLabels:{boolean:bool},start:{date:date,number:number,string:string,moment:moment},timeAxis:{scale:{string:string,undefined:\"undefined\"},step:{number:number,undefined:\"undefined\"},__type__:{object:object}},width:{string:string,number:number},zoomable:{boolean:bool},zoomKey:{string:[\"ctrlKey\",\"altKey\",\"metaKey\",\"\"]},zoomMax:{number:number},zoomMin:{number:number},zIndex:{number:number},__type__:{object:object}};var configureOptions={global:{sort:true,sampling:true,stack:false,shaded:{enabled:false,orientation:[\"zero\",\"top\",\"bottom\",\"group\"]},style:[\"line\",\"bar\",\"points\"],barChart:{width:[50,5,100,5],minWidth:[50,5,100,5],sideBySide:false,align:[\"left\",\"center\",\"right\"]},interpolation:{enabled:true,parametrization:[\"centripetal\",\"chordal\",\"uniform\"]},drawPoints:{enabled:true,size:[6,2,30,1],style:[\"square\",\"circle\"]},dataAxis:{showMinorLabels:true,showMajorLabels:true,icons:false,width:[40,0,200,1],visible:true,alignZeros:true,left:{title:{text:\"\",style:\"\"}},right:{title:{text:\"\",style:\"\"}}},legend:{enabled:false,icons:true,left:{visible:true,position:[\"top-right\",\"bottom-right\",\"top-left\",\"bottom-left\"]},right:{visible:true,position:[\"top-right\",\"bottom-right\",\"top-left\",\"bottom-left\"]}},autoResize:true,clickToUse:false,end:\"\",format:{minorLabels:{millisecond:\"SSS\",second:\"s\",minute:\"HH:mm\",hour:\"HH:mm\",weekday:\"ddd D\",day:\"D\",month:\"MMM\",year:\"YYYY\"},majorLabels:{millisecond:\"HH:mm:ss\",second:\"D MMMM HH:mm\",minute:\"ddd D MMMM\",hour:\"ddd D MMMM\",weekday:\"MMMM YYYY\",day:\"MMMM YYYY\",month:\"YYYY\",year:\"\"}},height:\"\",locale:\"\",max:\"\",maxHeight:\"\",maxMinorChars:[7,0,20,1],min:\"\",minHeight:\"\",moveable:true,orientation:[\"both\",\"bottom\",\"top\"],showCurrentTime:false,showMajorLabels:true,showMinorLabels:true,start:\"\",width:\"100%\",zoomable:true,zoomKey:[\"ctrlKey\",\"altKey\",\"metaKey\",\"\"],zoomMax:[31536e10,10,31536e10,1],zoomMin:[10,10,31536e10,1],zIndex:0}};exports.allOptions=allOptions;exports.configureOptions=configureOptions},function(module,exports,__webpack_require__){\"use strict\";var _create=__webpack_require__(29);var _create2=_interopRequireDefault(_create);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}function parseDOT(data){dot=data;return parseGraph()}var NODE_ATTR_MAPPING={fontsize:\"font.size\",fontcolor:\"font.color\",labelfontcolor:\"font.color\",fontname:\"font.face\",color:[\"color.border\",\"color.background\"],fillcolor:\"color.background\",tooltip:\"title\",labeltooltip:\"title\"};var EDGE_ATTR_MAPPING=(0,_create2[\"default\"])(NODE_ATTR_MAPPING);EDGE_ATTR_MAPPING.color=\"color.color\";EDGE_ATTR_MAPPING.style=\"dashes\";var TOKENTYPE={NULL:0,DELIMITER:1,IDENTIFIER:2,UNKNOWN:3};var DELIMITERS={\"{\":true,\"}\":true,\"[\":true,\"]\":true,\";\":true,\"=\":true,\",\":true,\"->\":true,\"--\":true};var dot=\"\";var index=0;var c=\"\";var token=\"\";var tokenType=TOKENTYPE.NULL;function first(){index=0;c=dot.charAt(0)}function next(){index++;c=dot.charAt(index)}function nextPreview(){return dot.charAt(index+1)}var regexAlphaNumeric=/[a-zA-Z_0-9.:#]/;function isAlphaNumeric(c){return regexAlphaNumeric.test(c)}function merge(a,b){if(!a){a={}}if(b){for(var name in b){if(b.hasOwnProperty(name)){a[name]=b[name]}}}return a}function setValue(obj,path,value){var keys=path.split(\".\");var o=obj;while(keys.length){var key=keys.shift();if(keys.length){if(!o[key]){o[key]={}}o=o[key]}else{o[key]=value}}}function addNode(graph,node){var i,len;var current=null;var graphs=[graph];var root=graph;while(root.parent){graphs.push(root.parent);root=root.parent}if(root.nodes){for(i=0,len=root.nodes.length;i<len;i++){if(node.id===root.nodes[i].id){current=root.nodes[i];break}}}if(!current){current={id:node.id};if(graph.node){current.attr=merge(current.attr,graph.node)}}for(i=graphs.length-1;i>=0;i--){var g=graphs[i];if(!g.nodes){g.nodes=[]}if(g.nodes.indexOf(current)===-1){g.nodes.push(current)}}if(node.attr){current.attr=merge(current.attr,node.attr)}}function addEdge(graph,edge){if(!graph.edges){graph.edges=[]}graph.edges.push(edge);if(graph.edge){var attr=merge({},graph.edge);edge.attr=merge(attr,edge.attr)}}function createEdge(graph,from,to,type,attr){var edge={from:from,to:to,type:type};if(graph.edge){edge.attr=merge({},graph.edge)}edge.attr=merge(edge.attr||{},attr);return edge}function getToken(){tokenType=TOKENTYPE.NULL;token=\"\";while(c===\" \"||c===\"\\t\"||c===\"\\n\"||c===\"\\r\"){next()}do{var isComment=false;if(c===\"#\"){var i=index-1;while(dot.charAt(i)===\" \"||dot.charAt(i)===\"\\t\"){i--}if(dot.charAt(i)===\"\\n\"||dot.charAt(i)===\"\"){while(c!=\"\"&&c!=\"\\n\"){next()}isComment=true}}if(c===\"/\"&&nextPreview()===\"/\"){while(c!=\"\"&&c!=\"\\n\"){next()}isComment=true}if(c===\"/\"&&nextPreview()===\"*\"){while(c!=\"\"){if(c===\"*\"&&nextPreview()===\"/\"){next();next();break}else{next()}}isComment=true}while(c===\" \"||c===\"\\t\"||c===\"\\n\"||c===\"\\r\"){next()}}while(isComment);if(c===\"\"){tokenType=TOKENTYPE.DELIMITER;return}var c2=c+nextPreview();if(DELIMITERS[c2]){tokenType=TOKENTYPE.DELIMITER;token=c2;next();next();return}if(DELIMITERS[c]){tokenType=TOKENTYPE.DELIMITER;token=c;next();return}if(isAlphaNumeric(c)||c===\"-\"){token+=c;next();while(isAlphaNumeric(c)){token+=c;next()}if(token===\"false\"){token=false}else if(token===\"true\"){token=true}else if(!isNaN(Number(token))){token=Number(token)}tokenType=TOKENTYPE.IDENTIFIER;return}if(c==='\"'){next();while(c!=\"\"&&(c!='\"'||c==='\"'&&nextPreview()==='\"')){if(c==='\"'){token+=c;next()}else if(c===\"\\\\\"&&nextPreview()===\"n\"){token+=\"\\n\";next()}else{token+=c}next()}if(c!='\"'){throw newSyntaxError('End of string \" expected')}next();tokenType=TOKENTYPE.IDENTIFIER;return}tokenType=TOKENTYPE.UNKNOWN;while(c!=\"\"){token+=c;next()}throw new SyntaxError('Syntax error in part \"'+chop(token,30)+'\"')}function parseGraph(){var graph={};first();getToken();if(token===\"strict\"){graph.strict=true;getToken()}if(token===\"graph\"||token===\"digraph\"){graph.type=token;getToken()}if(tokenType===TOKENTYPE.IDENTIFIER){graph.id=token;getToken()}if(token!=\"{\"){throw newSyntaxError(\"Angle bracket { expected\")}getToken();parseStatements(graph);if(token!=\"}\"){throw newSyntaxError(\"Angle bracket } expected\")}getToken();if(token!==\"\"){throw newSyntaxError(\"End of file expected\")}getToken();delete graph.node;delete graph.edge;delete graph.graph;return graph}function parseStatements(graph){while(token!==\"\"&&token!=\"}\"){parseStatement(graph);if(token===\";\"){getToken()}}}function parseStatement(graph){var subgraph=parseSubgraph(graph);if(subgraph){parseEdge(graph,subgraph);return}var attr=parseAttributeStatement(graph);if(attr){return}if(tokenType!=TOKENTYPE.IDENTIFIER){throw newSyntaxError(\"Identifier expected\")}var id=token;getToken();if(token===\"=\"){getToken();if(tokenType!=TOKENTYPE.IDENTIFIER){throw newSyntaxError(\"Identifier expected\")}graph[id]=token;getToken()}else{parseNodeStatement(graph,id)}}function parseSubgraph(graph){var subgraph=null;if(token===\"subgraph\"){subgraph={};subgraph.type=\"subgraph\";getToken();if(tokenType===TOKENTYPE.IDENTIFIER){subgraph.id=token;getToken()}}if(token===\"{\"){getToken();if(!subgraph){subgraph={}}subgraph.parent=graph;subgraph.node=graph.node;subgraph.edge=graph.edge;subgraph.graph=graph.graph;parseStatements(subgraph);if(token!=\"}\"){throw newSyntaxError(\"Angle bracket } expected\")}getToken();delete subgraph.node;delete subgraph.edge;delete subgraph.graph;delete subgraph.parent;if(!graph.subgraphs){graph.subgraphs=[]}graph.subgraphs.push(subgraph)}return subgraph}function parseAttributeStatement(graph){if(token===\"node\"){getToken();graph.node=parseAttributeList();return\"node\"}else if(token===\"edge\"){getToken();graph.edge=parseAttributeList();return\"edge\"}else if(token===\"graph\"){getToken();graph.graph=parseAttributeList();return\"graph\"}return null}function parseNodeStatement(graph,id){var node={id:id};var attr=parseAttributeList();if(attr){node.attr=attr}addNode(graph,node);parseEdge(graph,id)}function parseEdge(graph,from){while(token===\"->\"||token===\"--\"){var to;var type=token;getToken();var subgraph=parseSubgraph(graph);if(subgraph){to=subgraph}else{if(tokenType!=TOKENTYPE.IDENTIFIER){throw newSyntaxError(\"Identifier or subgraph expected\")}to=token;addNode(graph,{id:to});getToken()}var attr=parseAttributeList();var edge=createEdge(graph,from,to,type,attr);addEdge(graph,edge);from=to}}function parseAttributeList(){var attr=null;var edgeStyles={dashed:true,solid:false,dotted:[1,5]};while(token===\"[\"){getToken();attr={};while(token!==\"\"&&token!=\"]\"){if(tokenType!=TOKENTYPE.IDENTIFIER){throw newSyntaxError(\"Attribute name expected\")}var name=token;getToken();if(token!=\"=\"){throw newSyntaxError(\"Equal sign = expected\")}getToken();if(tokenType!=TOKENTYPE.IDENTIFIER){throw newSyntaxError(\"Attribute value expected\")}var value=token;if(name===\"style\"){value=edgeStyles[value]}setValue(attr,name,value);getToken();if(token==\",\"){getToken()}}if(token!=\"]\"){throw newSyntaxError(\"Bracket ] expected\")}getToken()}return attr}function newSyntaxError(message){return new SyntaxError(message+', got \"'+chop(token,30)+'\" (char '+index+\")\")}function chop(text,maxLength){return text.length<=maxLength?text:text.substr(0,27)+\"...\"}function forEach2(array1,array2,fn){if(Array.isArray(array1)){array1.forEach(function(elem1){if(Array.isArray(array2)){array2.forEach(function(elem2){fn(elem1,elem2)})}else{fn(elem1,array2)}})}else{if(Array.isArray(array2)){array2.forEach(function(elem2){fn(array1,elem2)})}else{fn(array1,array2)}}}function setProp(object,path,value){var names=path.split(\".\");var prop=names.pop();var obj=object;for(var i=0;i<names.length;i++){var name=names[i];if(!(name in obj)){obj[name]={}}obj=obj[name]}obj[prop]=value;return object}function convertAttr(attr,mapping){var converted={};for(var prop in attr){if(attr.hasOwnProperty(prop)){var visProp=mapping[prop];if(Array.isArray(visProp)){visProp.forEach(function(visPropI){setProp(converted,visPropI,attr[prop])})}else if(typeof visProp===\"string\"){setProp(converted,visProp,attr[prop])}else{setProp(converted,prop,attr[prop])}}}return converted}function DOTToGraph(data){var dotData=parseDOT(data);var graphData={nodes:[],edges:[],options:{}};if(dotData.nodes){dotData.nodes.forEach(function(dotNode){var graphNode={id:dotNode.id,label:String(dotNode.label||dotNode.id)};merge(graphNode,convertAttr(dotNode.attr,NODE_ATTR_MAPPING));if(graphNode.image){graphNode.shape=\"image\"}graphData.nodes.push(graphNode)})}if(dotData.edges){var convertEdge=function convertEdge(dotEdge){var graphEdge={from:dotEdge.from,to:dotEdge.to};merge(graphEdge,convertAttr(dotEdge.attr,EDGE_ATTR_MAPPING));graphEdge.arrows=dotEdge.type===\"->\"?\"to\":undefined;return graphEdge};dotData.edges.forEach(function(dotEdge){var from,to;if(dotEdge.from instanceof Object){from=dotEdge.from.nodes}else{from={id:dotEdge.from}}if(dotEdge.to instanceof Object){to=dotEdge.to.nodes}else{to={id:dotEdge.to}}if(dotEdge.from instanceof Object&&dotEdge.from.edges){dotEdge.from.edges.forEach(function(subEdge){var graphEdge=convertEdge(subEdge);graphData.edges.push(graphEdge)})}forEach2(from,to,function(from,to){var subEdge=createEdge(graphData,from.id,to.id,dotEdge.type,dotEdge.attr);var graphEdge=convertEdge(subEdge);graphData.edges.push(graphEdge)});if(dotEdge.to instanceof Object&&dotEdge.to.edges){dotEdge.to.edges.forEach(function(subEdge){var graphEdge=convertEdge(subEdge);graphData.edges.push(graphEdge)})}})}if(dotData.attr){graphData.options=dotData.attr}return graphData}exports.parseDOT=parseDOT;exports.DOTToGraph=DOTToGraph},function(module,exports,__webpack_require__){\"use strict\";function parseGephi(gephiJSON,optionsObj){var edges=[];var nodes=[];var options={edges:{inheritColor:false},nodes:{fixed:false,parseColor:false}};if(optionsObj!==undefined){if(optionsObj.fixed!==undefined){options.nodes.fixed=optionsObj.fixed}if(optionsObj.parseColor!==undefined){options.nodes.parseColor=optionsObj.parseColor}if(optionsObj.inheritColor!==undefined){options.edges.inheritColor=optionsObj.inheritColor}}var gEdges=gephiJSON.edges;var gNodes=gephiJSON.nodes;for(var i=0;i<gEdges.length;i++){var edge={};var gEdge=gEdges[i];edge[\"id\"]=gEdge.id;edge[\"from\"]=gEdge.source;edge[\"to\"]=gEdge.target;edge[\"attributes\"]=gEdge.attributes;edge[\"label\"]=gEdge.label;edge[\"title\"]=gEdge.attributes!==undefined?gEdge.attributes.title:undefined;if(gEdge[\"type\"]===\"Directed\"){edge[\"arrows\"]=\"to\"}if(gEdge.color&&options.inheritColor===false){edge[\"color\"]=gEdge.color}edges.push(edge)}for(var j=0;j<gNodes.length;j++){var node={};var gNode=gNodes[j];node[\"id\"]=gNode.id;node[\"attributes\"]=gNode.attributes;node[\"x\"]=gNode.x;node[\"y\"]=gNode.y;node[\"label\"]=gNode.label;node[\"title\"]=gNode.attributes!==undefined?gNode.attributes.title:gNode.title;if(options.nodes.parseColor===true){node[\"color\"]=gNode.color}else{node[\"color\"]=gNode.color!==undefined?{background:gNode.color,border:gNode.color,highlight:{background:gNode.color,border:gNode.color},hover:{background:gNode.color,border:gNode.color}}:undefined}node[\"size\"]=gNode.size;node[\"fixed\"]=options.nodes.fixed&&gNode.x!==undefined&&gNode.y!==undefined;nodes.push(node)}return{nodes:nodes,edges:edges}}exports.parseGephi=parseGephi},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _CachedImage=__webpack_require__(185);var _CachedImage2=_interopRequireDefault(_CachedImage);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Images=function(){function Images(callback){(0,_classCallCheck3[\"default\"])(this,Images);this.images={};this.imageBroken={};this.callback=callback}(0,_createClass3[\"default\"])(Images,[{key:\"_tryloadBrokenUrl\",value:function _tryloadBrokenUrl(url,brokenUrl,imageToLoadBrokenUrlOn){if(url===undefined||imageToLoadBrokenUrlOn===undefined)return;if(brokenUrl===undefined){console.warn(\"No broken url image defined\");return}imageToLoadBrokenUrlOn.onerror=function(){console.error(\"Could not load brokenImage:\",brokenUrl)};imageToLoadBrokenUrlOn.image.src=brokenUrl}},{key:\"_redrawWithImage\",value:function _redrawWithImage(imageToRedrawWith){if(this.callback){this.callback(imageToRedrawWith)}}},{key:\"load\",value:function load(url,brokenUrl){var _this=this;var cachedImage=this.images[url];if(cachedImage)return cachedImage;var img=new _CachedImage2[\"default\"];this.images[url]=img;img.image.onload=function(){_this._fixImageCoordinates(img.image);img.init();_this._redrawWithImage(img)};img.image.onerror=function(){console.error(\"Could not load image:\",url);_this._tryloadBrokenUrl(url,brokenUrl,img)};img.image.src=url;return img}},{key:\"_fixImageCoordinates\",value:function _fixImageCoordinates(imageToCache){if(imageToCache.width===0){document.body.appendChild(imageToCache);imageToCache.width=imageToCache.offsetWidth;imageToCache.height=imageToCache.offsetHeight;document.body.removeChild(imageToCache)}}}]);return Images}();exports[\"default\"]=Images},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _slicedToArray2=__webpack_require__(30);var _slicedToArray3=_interopRequireDefault(_slicedToArray2);var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var ComponentUtil=__webpack_require__(48)[\"default\"];var LabelSplitter=__webpack_require__(191)[\"default\"];var multiFontStyle=[\"bold\",\"ital\",\"boldital\",\"mono\"];var Label=function(){function Label(body,options){var edgelabel=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;(0,_classCallCheck3[\"default\"])(this,Label);this.body=body;this.pointToSelf=false;this.baseSize=undefined;this.fontOptions={};this.setOptions(options);this.size={top:0,left:0,width:0,height:0,yLine:0};this.isEdgeLabel=edgelabel}(0,_createClass3[\"default\"])(Label,[{key:\"setOptions\",value:function setOptions(options){this.elementOptions=options;this.initFontOptions(options.font);if(ComponentUtil.isValidLabel(options.label)){this.labelDirty=true}else{options.label=\"\"}if(options.font!==undefined&&options.font!==null){if(typeof options.font===\"string\"){this.baseSize=this.fontOptions.size}else if((0,_typeof3[\"default\"])(options.font)===\"object\"){var size=options.font.size;if(size!==undefined){this.baseSize=size}}}}},{key:\"initFontOptions\",value:function initFontOptions(newFontOptions){var _this=this;util.forEach(multiFontStyle,function(style){_this.fontOptions[style]={}});if(Label.parseFontString(this.fontOptions,newFontOptions)){this.fontOptions.vadjust=0;return}util.forEach(newFontOptions,function(prop,n){if(prop!==undefined&&prop!==null&&(typeof prop===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(prop))!==\"object\"){_this.fontOptions[n]=prop}})}},{key:\"constrain\",value:function constrain(pile){var fontOptions={constrainWidth:false,maxWdt:-1,minWdt:-1,constrainHeight:false,minHgt:-1,valign:\"middle\"};var widthConstraint=util.topMost(pile,\"widthConstraint\");if(typeof widthConstraint===\"number\"){fontOptions.maxWdt=Number(widthConstraint);fontOptions.minWdt=Number(widthConstraint)}else if((typeof widthConstraint===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(widthConstraint))===\"object\"){var widthConstraintMaximum=util.topMost(pile,[\"widthConstraint\",\"maximum\"]);if(typeof widthConstraintMaximum===\"number\"){fontOptions.maxWdt=Number(widthConstraintMaximum)}var widthConstraintMinimum=util.topMost(pile,[\"widthConstraint\",\"minimum\"]);if(typeof widthConstraintMinimum===\"number\"){fontOptions.minWdt=Number(widthConstraintMinimum)}}var heightConstraint=util.topMost(pile,\"heightConstraint\");if(typeof heightConstraint===\"number\"){fontOptions.minHgt=Number(heightConstraint)}else if((typeof heightConstraint===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(heightConstraint))===\"object\"){var heightConstraintMinimum=util.topMost(pile,[\"heightConstraint\",\"minimum\"]);if(typeof heightConstraintMinimum===\"number\"){fontOptions.minHgt=Number(heightConstraintMinimum)}var heightConstraintValign=util.topMost(pile,[\"heightConstraint\",\"valign\"]);if(typeof heightConstraintValign===\"string\"){if(heightConstraintValign===\"top\"||heightConstraintValign===\"bottom\"){fontOptions.valign=heightConstraintValign}}}return fontOptions}},{key:\"update\",value:function update(options,pile){this.setOptions(options,true);this.propagateFonts(pile);util.deepExtend(this.fontOptions,this.constrain(pile));this.fontOptions.chooser=ComponentUtil.choosify(\"label\",pile)}},{key:\"adjustSizes\",value:function adjustSizes(margins){var widthBias=margins?margins.right+margins.left:0;if(this.fontOptions.constrainWidth){this.fontOptions.maxWdt-=widthBias;this.fontOptions.minWdt-=widthBias}var heightBias=margins?margins.top+margins.bottom:0;if(this.fontOptions.constrainHeight){this.fontOptions.minHgt-=heightBias}}},{key:\"addFontOptionsToPile\",value:function addFontOptionsToPile(dstPile,srcPile){for(var i=0;i<srcPile.length;++i){this.addFontToPile(dstPile,srcPile[i])}}},{key:\"addFontToPile\",value:function addFontToPile(pile,options){if(options===undefined)return;if(options.font===undefined||options.font===null)return;var item=options.font;pile.push(item)}},{key:\"getBasicOptions\",value:function getBasicOptions(pile){var ret={};for(var n=0;n<pile.length;++n){var fontOptions=pile[n];var tmpShorthand={};if(Label.parseFontString(tmpShorthand,fontOptions)){fontOptions=tmpShorthand}util.forEach(fontOptions,function(opt,name){if(opt===undefined)return;if(ret.hasOwnProperty(name))return;if(multiFontStyle.indexOf(name)!==-1){ret[name]={}}else{ret[name]=opt}})}return ret}},{key:\"getFontOption\",value:function getFontOption(pile,multiName,option){var multiFont=void 0;for(var n=0;n<pile.length;++n){var fontOptions=pile[n];if(fontOptions.hasOwnProperty(multiName)){multiFont=fontOptions[multiName];if(multiFont===undefined||multiFont===null)continue;var tmpShorthand={};if(Label.parseFontString(tmpShorthand,multiFont)){multiFont=tmpShorthand}if(multiFont.hasOwnProperty(option)){return multiFont[option]}}}if(this.fontOptions.hasOwnProperty(option)){return this.fontOptions[option]}throw new Error(\"Did not find value for multi-font for property: '\"+option+\"'\")}},{key:\"getFontOptions\",value:function getFontOptions(pile,multiName){var result={};var optionNames=[\"color\",\"size\",\"face\",\"mod\",\"vadjust\"];for(var i=0;i<optionNames.length;++i){var mod=optionNames[i];result[mod]=this.getFontOption(pile,multiName,mod)}return result}},{key:\"propagateFonts\",value:function propagateFonts(pile){var _this2=this;var fontPile=[];this.addFontOptionsToPile(fontPile,pile);this.fontOptions=this.getBasicOptions(fontPile);var _loop=function _loop(i){var mod=multiFontStyle[i];var modOptions=_this2.fontOptions[mod];var tmpMultiFontOptions=_this2.getFontOptions(fontPile,mod);util.forEach(tmpMultiFontOptions,function(option,n){modOptions[n]=option});modOptions.size=Number(modOptions.size);modOptions.vadjust=Number(modOptions.vadjust)};for(var i=0;i<multiFontStyle.length;++i){_loop(i)}}},{key:\"draw\",value:function draw(ctx,x,y,selected,hover){var baseline=arguments.length>5&&arguments[5]!==undefined?arguments[5]:\"middle\";if(this.elementOptions.label===undefined)return;var viewFontSize=this.fontOptions.size*this.body.view.scale;if(this.elementOptions.label&&viewFontSize<this.elementOptions.scaling.label.drawThreshold-1)return;if(viewFontSize>=this.elementOptions.scaling.label.maxVisible){viewFontSize=Number(this.elementOptions.scaling.label.maxVisible)/this.body.view.scale}this.calculateLabelSize(ctx,selected,hover,x,y,baseline);this._drawBackground(ctx);this._drawText(ctx,x,this.size.yLine,baseline,viewFontSize)}},{key:\"_drawBackground\",value:function _drawBackground(ctx){if(this.fontOptions.background!==undefined&&this.fontOptions.background!==\"none\"){ctx.fillStyle=this.fontOptions.background;var size=this.getSize();ctx.fillRect(size.left,size.top,size.width,size.height)}}},{key:\"_drawText\",value:function _drawText(ctx,x,y){var baseline=arguments.length>3&&arguments[3]!==undefined?arguments[3]:\"middle\";var viewFontSize=arguments[4];var _setAlignment2=this._setAlignment(ctx,x,y,baseline);var _setAlignment3=(0,_slicedToArray3[\"default\"])(_setAlignment2,2);x=_setAlignment3[0];y=_setAlignment3[1];ctx.textAlign=\"left\";x=x-this.size.width/2;if(this.fontOptions.valign&&this.size.height>this.size.labelHeight){if(this.fontOptions.valign===\"top\"){y-=(this.size.height-this.size.labelHeight)/2}if(this.fontOptions.valign===\"bottom\"){y+=(this.size.height-this.size.labelHeight)/2}}for(var i=0;i<this.lineCount;i++){var line=this.lines[i];if(line&&line.blocks){var width=0;if(this.isEdgeLabel||this.fontOptions.align===\"center\"){width+=(this.size.width-line.width)/2}else if(this.fontOptions.align===\"right\"){width+=this.size.width-line.width}for(var j=0;j<line.blocks.length;j++){var block=line.blocks[j];ctx.font=block.font;var _getColor2=this._getColor(block.color,viewFontSize,block.strokeColor),_getColor3=(0,_slicedToArray3[\"default\"])(_getColor2,2),fontColor=_getColor3[0],strokeColor=_getColor3[1];if(block.strokeWidth>0){ctx.lineWidth=block.strokeWidth;ctx.strokeStyle=strokeColor;ctx.lineJoin=\"round\"}ctx.fillStyle=fontColor;if(block.strokeWidth>0){ctx.strokeText(block.text,x+width,y+block.vadjust)}ctx.fillText(block.text,x+width,y+block.vadjust);width+=block.width}y+=line.height}}}},{key:\"_setAlignment\",value:function _setAlignment(ctx,x,y,baseline){if(this.isEdgeLabel&&this.fontOptions.align!==\"horizontal\"&&this.pointToSelf===false){x=0;y=0;var lineMargin=2;if(this.fontOptions.align===\"top\"){ctx.textBaseline=\"alphabetic\";y-=2*lineMargin}else if(this.fontOptions.align===\"bottom\"){ctx.textBaseline=\"hanging\";y+=2*lineMargin}else{ctx.textBaseline=\"middle\"}}else{ctx.textBaseline=baseline}return[x,y]}},{key:\"_getColor\",value:function _getColor(color,viewFontSize,initialStrokeColor){var fontColor=color||\"#000000\";var strokeColor=initialStrokeColor||\"#ffffff\";if(viewFontSize<=this.elementOptions.scaling.label.drawThreshold){var opacity=Math.max(0,Math.min(1,1-(this.elementOptions.scaling.label.drawThreshold-viewFontSize)));fontColor=util.overrideOpacity(fontColor,opacity);strokeColor=util.overrideOpacity(strokeColor,opacity)}return[fontColor,strokeColor]}},{key:\"getTextSize\",value:function getTextSize(ctx){var selected=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;var hover=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;this._processLabel(ctx,selected,hover);return{width:this.size.width,height:this.size.height,lineCount:this.lineCount}}},{key:\"getSize\",value:function getSize(){var lineMargin=2;var x=this.size.left;var y=this.size.top-.5*lineMargin;if(this.isEdgeLabel){var x2=-this.size.width*.5;switch(this.fontOptions.align){case\"middle\":x=x2;y=-this.size.height*.5;break;case\"top\":x=x2;y=-(this.size.height+lineMargin);break;case\"bottom\":x=x2;y=lineMargin;break}}var ret={left:x,top:y,width:this.size.width,height:this.size.height};return ret}},{key:\"calculateLabelSize\",value:function calculateLabelSize(ctx,selected,hover){var x=arguments.length>3&&arguments[3]!==undefined?arguments[3]:0;var y=arguments.length>4&&arguments[4]!==undefined?arguments[4]:0;var baseline=arguments.length>5&&arguments[5]!==undefined?arguments[5]:\"middle\";this._processLabel(ctx,selected,hover);this.size.left=x-this.size.width*.5;this.size.top=y-this.size.height*.5;this.size.yLine=y+(1-this.lineCount)*.5*this.fontOptions.size;if(baseline===\"hanging\"){this.size.top+=.5*this.fontOptions.size;this.size.top+=4;this.size.yLine+=4}}},{key:\"getFormattingValues\",value:function getFormattingValues(ctx,selected,hover,mod){var getValue=function getValue(fontOptions,mod,option){if(mod===\"normal\"){if(option===\"mod\")return\"\";return fontOptions[option]}if(fontOptions[mod][option]!==undefined){return fontOptions[mod][option]}else{return fontOptions[option]}};var values={color:getValue(this.fontOptions,mod,\"color\"),size:getValue(this.fontOptions,mod,\"size\"),face:getValue(this.fontOptions,mod,\"face\"),mod:getValue(this.fontOptions,mod,\"mod\"),vadjust:getValue(this.fontOptions,mod,\"vadjust\"),strokeWidth:this.fontOptions.strokeWidth,strokeColor:this.fontOptions.strokeColor};if(selected||hover){if(mod===\"normal\"&&this.fontOptions.chooser===true&&this.elementOptions.labelHighlightBold){values.mod=\"bold\"}else{if(typeof this.fontOptions.chooser===\"function\"){this.fontOptions.chooser(values,this.elementOptions.id,selected,hover)}}}var fontString=\"\";if(values.mod!==undefined&&values.mod!==\"\"){fontString+=values.mod+\" \"}fontString+=values.size+\"px \"+values.face;ctx.font=fontString.replace(/\"/g,\"\");values.font=ctx.font;values.height=values.size;return values}},{key:\"differentState\",value:function differentState(selected,hover){return selected!==this.selectedState||hover!==this.hoverState}},{key:\"_processLabelText\",value:function _processLabelText(ctx,selected,hover,inText){var splitter=new LabelSplitter(ctx,this,selected,hover);return splitter.process(inText)}},{key:\"_processLabel\",value:function _processLabel(ctx,selected,hover){if(this.labelDirty===false&&!this.differentState(selected,hover))return;var state=this._processLabelText(ctx,selected,hover,this.elementOptions.label);if(this.fontOptions.minWdt>0&&state.width<this.fontOptions.minWdt){state.width=this.fontOptions.minWdt}this.size.labelHeight=state.height;if(this.fontOptions.minHgt>0&&state.height<this.fontOptions.minHgt){state.height=this.fontOptions.minHgt}this.lines=state.lines;this.lineCount=state.lines.length;this.size.width=state.width;this.size.height=state.height;this.selectedState=selected;this.hoverState=hover;this.labelDirty=false}},{key:\"visible\",value:function visible(){if(this.size.width===0||this.size.height===0||this.elementOptions.label===undefined){return false}var viewFontSize=this.fontOptions.size*this.body.view.scale;if(viewFontSize<this.elementOptions.scaling.label.drawThreshold-1){return false}return true}}],[{key:\"parseFontString\",value:function parseFontString(outOptions,inOptions){if(!inOptions||typeof inOptions!==\"string\")return false;var newOptionsArray=inOptions.split(\" \");outOptions.size=newOptionsArray[0].replace(\"px\",\"\");outOptions.face=newOptionsArray[1];outOptions.color=newOptionsArray[2];return true}}]);return Label}();exports[\"default\"]=Label},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _slicedToArray2=__webpack_require__(30);var _slicedToArray3=_interopRequireDefault(_slicedToArray2);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var EndPoints=__webpack_require__(119)[\"default\"];var EdgeBase=function(){function EdgeBase(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,EdgeBase);this.body=body;this.labelModule=labelModule\n;this.options={};this.setOptions(options);this.colorDirty=true;this.color={};this.selectionWidth=2;this.hoverWidth=1.5;this.fromPoint=this.from;this.toPoint=this.to}(0,_createClass3[\"default\"])(EdgeBase,[{key:\"connect\",value:function connect(){this.from=this.body.nodes[this.options.from];this.to=this.body.nodes[this.options.to]}},{key:\"cleanup\",value:function cleanup(){return false}},{key:\"setOptions\",value:function setOptions(options){this.options=options;this.from=this.body.nodes[this.options.from];this.to=this.body.nodes[this.options.to];this.id=this.options.id}},{key:\"drawLine\",value:function drawLine(ctx,values,selected,hover,viaNode){ctx.strokeStyle=this.getColor(ctx,values,selected,hover);ctx.lineWidth=values.width;if(values.dashes!==false){this._drawDashedLine(ctx,values,viaNode)}else{this._drawLine(ctx,values,viaNode)}}},{key:\"_drawLine\",value:function _drawLine(ctx,values,viaNode,fromPoint,toPoint){if(this.from!=this.to){this._line(ctx,values,viaNode,fromPoint,toPoint)}else{var _getCircleData2=this._getCircleData(ctx),_getCircleData3=(0,_slicedToArray3[\"default\"])(_getCircleData2,3),x=_getCircleData3[0],y=_getCircleData3[1],radius=_getCircleData3[2];this._circle(ctx,values,x,y,radius)}}},{key:\"_drawDashedLine\",value:function _drawDashedLine(ctx,values,viaNode,fromPoint,toPoint){ctx.lineCap=\"round\";var pattern=[5,5];if(Array.isArray(values.dashes)===true){pattern=values.dashes}if(ctx.setLineDash!==undefined){ctx.save();ctx.setLineDash(pattern);ctx.lineDashOffset=0;if(this.from!=this.to){this._line(ctx,values,viaNode)}else{var _getCircleData4=this._getCircleData(ctx),_getCircleData5=(0,_slicedToArray3[\"default\"])(_getCircleData4,3),x=_getCircleData5[0],y=_getCircleData5[1],radius=_getCircleData5[2];this._circle(ctx,values,x,y,radius)}ctx.setLineDash([0]);ctx.lineDashOffset=0;ctx.restore()}else{if(this.from!=this.to){ctx.dashedLine(this.from.x,this.from.y,this.to.x,this.to.y,pattern)}else{var _getCircleData6=this._getCircleData(ctx),_getCircleData7=(0,_slicedToArray3[\"default\"])(_getCircleData6,3),_x=_getCircleData7[0],_y=_getCircleData7[1],_radius=_getCircleData7[2];this._circle(ctx,values,_x,_y,_radius)}this.enableShadow(ctx,values);ctx.stroke();this.disableShadow(ctx,values)}}},{key:\"findBorderPosition\",value:function findBorderPosition(nearNode,ctx,options){if(this.from!=this.to){return this._findBorderPosition(nearNode,ctx,options)}else{return this._findBorderPositionCircle(nearNode,ctx,options)}}},{key:\"findBorderPositions\",value:function findBorderPositions(ctx){var from={};var to={};if(this.from!=this.to){from=this._findBorderPosition(this.from,ctx);to=this._findBorderPosition(this.to,ctx)}else{var _getCircleData$slice=this._getCircleData(ctx).slice(0,2),_getCircleData$slice2=(0,_slicedToArray3[\"default\"])(_getCircleData$slice,2),x=_getCircleData$slice2[0],y=_getCircleData$slice2[1];from=this._findBorderPositionCircle(this.from,ctx,{x:x,y:y,low:.25,high:.6,direction:-1});to=this._findBorderPositionCircle(this.from,ctx,{x:x,y:y,low:.6,high:.8,direction:1})}return{from:from,to:to}}},{key:\"_getCircleData\",value:function _getCircleData(ctx){var x=void 0,y=void 0;var node=this.from;var radius=this.options.selfReferenceSize;if(ctx!==undefined){if(node.shape.width===undefined){node.shape.resize(ctx)}}if(node.shape.width>node.shape.height){x=node.x+node.shape.width*.5;y=node.y-radius}else{x=node.x+radius;y=node.y-node.shape.height*.5}return[x,y,radius]}},{key:\"_pointOnCircle\",value:function _pointOnCircle(x,y,radius,percentage){var angle=percentage*2*Math.PI;return{x:x+radius*Math.cos(angle),y:y-radius*Math.sin(angle)}}},{key:\"_findBorderPositionCircle\",value:function _findBorderPositionCircle(node,ctx,options){var x=options.x;var y=options.y;var low=options.low;var high=options.high;var direction=options.direction;var maxIterations=10;var iteration=0;var radius=this.options.selfReferenceSize;var pos=void 0,angle=void 0,distanceToBorder=void 0,distanceToPoint=void 0,difference=void 0;var threshold=.05;var middle=(low+high)*.5;while(low<=high&&iteration<maxIterations){middle=(low+high)*.5;pos=this._pointOnCircle(x,y,radius,middle);angle=Math.atan2(node.y-pos.y,node.x-pos.x);distanceToBorder=node.distanceToBorder(ctx,angle);distanceToPoint=Math.sqrt(Math.pow(pos.x-node.x,2)+Math.pow(pos.y-node.y,2));difference=distanceToBorder-distanceToPoint;if(Math.abs(difference)<threshold){break}else if(difference>0){if(direction>0){low=middle}else{high=middle}}else{if(direction>0){high=middle}else{low=middle}}iteration++}pos.t=middle;return pos}},{key:\"getLineWidth\",value:function getLineWidth(selected,hover){if(selected===true){return Math.max(this.selectionWidth,.3/this.body.view.scale)}else{if(hover===true){return Math.max(this.hoverWidth,.3/this.body.view.scale)}else{return Math.max(this.options.width,.3/this.body.view.scale)}}}},{key:\"getColor\",value:function getColor(ctx,values,selected,hover){if(values.inheritsColor!==false){if(values.inheritsColor===\"both\"&&this.from.id!==this.to.id){var grd=ctx.createLinearGradient(this.from.x,this.from.y,this.to.x,this.to.y);var fromColor=void 0,toColor=void 0;fromColor=this.from.options.color.highlight.border;toColor=this.to.options.color.highlight.border;if(this.from.selected===false&&this.to.selected===false){fromColor=util.overrideOpacity(this.from.options.color.border,values.opacity);toColor=util.overrideOpacity(this.to.options.color.border,values.opacity)}else if(this.from.selected===true&&this.to.selected===false){toColor=this.to.options.color.border}else if(this.from.selected===false&&this.to.selected===true){fromColor=this.from.options.color.border}grd.addColorStop(0,fromColor);grd.addColorStop(1,toColor);return grd}if(values.inheritsColor===\"to\"){return util.overrideOpacity(this.to.options.color.border,values.opacity)}else{return util.overrideOpacity(this.from.options.color.border,values.opacity)}}else{return util.overrideOpacity(values.color,values.opacity)}}},{key:\"_circle\",value:function _circle(ctx,values,x,y,radius){this.enableShadow(ctx,values);ctx.beginPath();ctx.arc(x,y,radius,0,2*Math.PI,false);ctx.stroke();this.disableShadow(ctx,values)}},{key:\"getDistanceToEdge\",value:function getDistanceToEdge(x1,y1,x2,y2,x3,y3,via,values){var returnValue=0;if(this.from!=this.to){returnValue=this._getDistanceToEdge(x1,y1,x2,y2,x3,y3,via)}else{var _getCircleData8=this._getCircleData(undefined),_getCircleData9=(0,_slicedToArray3[\"default\"])(_getCircleData8,3),x=_getCircleData9[0],y=_getCircleData9[1],radius=_getCircleData9[2];var dx=x-x3;var dy=y-y3;returnValue=Math.abs(Math.sqrt(dx*dx+dy*dy)-radius)}return returnValue}},{key:\"_getDistanceToLine\",value:function _getDistanceToLine(x1,y1,x2,y2,x3,y3){var px=x2-x1;var py=y2-y1;var something=px*px+py*py;var u=((x3-x1)*px+(y3-y1)*py)/something;if(u>1){u=1}else if(u<0){u=0}var x=x1+u*px;var y=y1+u*py;var dx=x-x3;var dy=y-y3;return Math.sqrt(dx*dx+dy*dy)}},{key:\"getArrowData\",value:function getArrowData(ctx,position,viaNode,selected,hover,values){var angle=void 0;var arrowPoint=void 0;var node1=void 0;var node2=void 0;var guideOffset=void 0;var scaleFactor=void 0;var type=void 0;var lineWidth=values.width;if(position===\"from\"){node1=this.from;node2=this.to;guideOffset=.1;scaleFactor=values.fromArrowScale;type=values.fromArrowType}else if(position===\"to\"){node1=this.to;node2=this.from;guideOffset=-.1;scaleFactor=values.toArrowScale;type=values.toArrowType}else{node1=this.to;node2=this.from;scaleFactor=values.middleArrowScale;type=values.middleArrowType}if(node1!=node2){if(position!==\"middle\"){if(this.options.smooth.enabled===true){arrowPoint=this.findBorderPosition(node1,ctx,{via:viaNode});var guidePos=this.getPoint(Math.max(0,Math.min(1,arrowPoint.t+guideOffset)),viaNode);angle=Math.atan2(arrowPoint.y-guidePos.y,arrowPoint.x-guidePos.x)}else{angle=Math.atan2(node1.y-node2.y,node1.x-node2.x);arrowPoint=this.findBorderPosition(node1,ctx)}}else{angle=Math.atan2(node1.y-node2.y,node1.x-node2.x);arrowPoint=this.getPoint(.5,viaNode)}}else{var _getCircleData10=this._getCircleData(ctx),_getCircleData11=(0,_slicedToArray3[\"default\"])(_getCircleData10,3),x=_getCircleData11[0],y=_getCircleData11[1],radius=_getCircleData11[2];if(position===\"from\"){arrowPoint=this.findBorderPosition(this.from,ctx,{x:x,y:y,low:.25,high:.6,direction:-1});angle=arrowPoint.t*-2*Math.PI+1.5*Math.PI+.1*Math.PI}else if(position===\"to\"){arrowPoint=this.findBorderPosition(this.from,ctx,{x:x,y:y,low:.6,high:1,direction:1});angle=arrowPoint.t*-2*Math.PI+1.5*Math.PI-1.1*Math.PI}else{arrowPoint=this._pointOnCircle(x,y,radius,.175);angle=3.9269908169872414}}if(position===\"middle\"&&scaleFactor<0)lineWidth*=-1;var length=15*scaleFactor+3*lineWidth;var xi=arrowPoint.x-length*.9*Math.cos(angle);var yi=arrowPoint.y-length*.9*Math.sin(angle);var arrowCore={x:xi,y:yi};return{point:arrowPoint,core:arrowCore,angle:angle,length:length,type:type}}},{key:\"drawArrowHead\",value:function drawArrowHead(ctx,values,selected,hover,arrowData){ctx.strokeStyle=this.getColor(ctx,values,selected,hover);ctx.fillStyle=ctx.strokeStyle;ctx.lineWidth=values.width;EndPoints.draw(ctx,arrowData);this.enableShadow(ctx,values);ctx.fill();this.disableShadow(ctx,values)}},{key:\"enableShadow\",value:function enableShadow(ctx,values){if(values.shadow===true){ctx.shadowColor=values.shadowColor;ctx.shadowBlur=values.shadowSize;ctx.shadowOffsetX=values.shadowX;ctx.shadowOffsetY=values.shadowY}}},{key:\"disableShadow\",value:function disableShadow(ctx,values){if(values.shadow===true){ctx.shadowColor=\"rgba(0,0,0,0)\";ctx.shadowBlur=0;ctx.shadowOffsetX=0;ctx.shadowOffsetY=0}}}]);return EdgeBase}();exports[\"default\"]=EdgeBase},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var EndPoint=function(){function EndPoint(){(0,_classCallCheck3[\"default\"])(this,EndPoint)}(0,_createClass3[\"default\"])(EndPoint,null,[{key:\"transform\",value:function transform(points,arrowData){if(!(points instanceof Array)){points=[points]}var x=arrowData.point.x;var y=arrowData.point.y;var angle=arrowData.angle;var length=arrowData.length;for(var i=0;i<points.length;++i){var p=points[i];var xt=p.x*Math.cos(angle)-p.y*Math.sin(angle);var yt=p.x*Math.sin(angle)+p.y*Math.cos(angle);p.x=x+length*xt;p.y=y+length*yt}}},{key:\"drawPath\",value:function drawPath(ctx,points){ctx.beginPath();ctx.moveTo(points[0].x,points[0].y);for(var i=1;i<points.length;++i){ctx.lineTo(points[i].x,points[i].y)}ctx.closePath()}}]);return EndPoint}();var Arrow=function(_EndPoint){(0,_inherits3[\"default\"])(Arrow,_EndPoint);function Arrow(){(0,_classCallCheck3[\"default\"])(this,Arrow);return(0,_possibleConstructorReturn3[\"default\"])(this,(Arrow.__proto__||(0,_getPrototypeOf2[\"default\"])(Arrow)).apply(this,arguments))}(0,_createClass3[\"default\"])(Arrow,null,[{key:\"draw\",value:function draw(ctx,arrowData){var points=[{x:0,y:0},{x:-1,y:.3},{x:-.9,y:0},{x:-1,y:-.3}];EndPoint.transform(points,arrowData);EndPoint.drawPath(ctx,points)}}]);return Arrow}(EndPoint);var Circle=function(){function Circle(){(0,_classCallCheck3[\"default\"])(this,Circle)}(0,_createClass3[\"default\"])(Circle,null,[{key:\"draw\",value:function draw(ctx,arrowData){var point={x:-.4,y:0};EndPoint.transform(point,arrowData);ctx.circle(point.x,point.y,arrowData.length*.4)}}]);return Circle}();var Bar=function(){function Bar(){(0,_classCallCheck3[\"default\"])(this,Bar)}(0,_createClass3[\"default\"])(Bar,null,[{key:\"draw\",value:function draw(ctx,arrowData){var points=[{x:0,y:.5},{x:0,y:-.5},{x:-.15,y:-.5},{x:-.15,y:.5}];EndPoint.transform(points,arrowData);EndPoint.drawPath(ctx,points)}}]);return Bar}();var EndPoints=function(){function EndPoints(){(0,_classCallCheck3[\"default\"])(this,EndPoints)}(0,_createClass3[\"default\"])(EndPoints,null,[{key:\"draw\",value:function draw(ctx,arrowData){var type;if(arrowData.type){type=arrowData.type.toLowerCase()}switch(type){case\"circle\":Circle.draw(ctx,arrowData);break;case\"bar\":Bar.draw(ctx,arrowData);break;case\"arrow\":default:Arrow.draw(ctx,arrowData)}}}]);return EndPoints}();exports[\"default\"]=EndPoints},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var BarnesHutSolver=function(){function BarnesHutSolver(body,physicsBody,options){(0,_classCallCheck3[\"default\"])(this,BarnesHutSolver);this.body=body;this.physicsBody=physicsBody;this.barnesHutTree;this.setOptions(options);this.randomSeed=5}(0,_createClass3[\"default\"])(BarnesHutSolver,[{key:\"setOptions\",value:function setOptions(options){this.options=options;this.thetaInversed=1/this.options.theta;this.overlapAvoidanceFactor=1-Math.max(0,Math.min(1,this.options.avoidOverlap))}},{key:\"seededRandom\",value:function seededRandom(){var x=Math.sin(this.randomSeed++)*1e4;return x-Math.floor(x)}},{key:\"solve\",value:function solve(){if(this.options.gravitationalConstant!==0&&this.physicsBody.physicsNodeIndices.length>0){var node=void 0;var nodes=this.body.nodes;var nodeIndices=this.physicsBody.physicsNodeIndices;var nodeCount=nodeIndices.length;var barnesHutTree=this._formBarnesHutTree(nodes,nodeIndices);this.barnesHutTree=barnesHutTree;for(var i=0;i<nodeCount;i++){node=nodes[nodeIndices[i]];if(node.options.mass>0){this._getForceContributions(barnesHutTree.root,node)}}}}},{key:\"_getForceContributions\",value:function _getForceContributions(parentBranch,node){this._getForceContribution(parentBranch.children.NW,node);this._getForceContribution(parentBranch.children.NE,node);this._getForceContribution(parentBranch.children.SW,node);this._getForceContribution(parentBranch.children.SE,node)}},{key:\"_getForceContribution\",value:function _getForceContribution(parentBranch,node){if(parentBranch.childrenCount>0){var dx=void 0,dy=void 0,distance=void 0;dx=parentBranch.centerOfMass.x-node.x;dy=parentBranch.centerOfMass.y-node.y;distance=Math.sqrt(dx*dx+dy*dy);if(distance*parentBranch.calcSize>this.thetaInversed){this._calculateForces(distance,dx,dy,node,parentBranch)}else{if(parentBranch.childrenCount===4){this._getForceContributions(parentBranch,node)}else{if(parentBranch.children.data.id!=node.id){this._calculateForces(distance,dx,dy,node,parentBranch)}}}}}},{key:\"_calculateForces\",value:function _calculateForces(distance,dx,dy,node,parentBranch){if(distance===0){distance=.1;dx=distance}if(this.overlapAvoidanceFactor<1&&node.shape.radius){distance=Math.max(.1+this.overlapAvoidanceFactor*node.shape.radius,distance-node.shape.radius)}var gravityForce=this.options.gravitationalConstant*parentBranch.mass*node.options.mass/Math.pow(distance,3);var fx=dx*gravityForce;var fy=dy*gravityForce;this.physicsBody.forces[node.id].x+=fx;this.physicsBody.forces[node.id].y+=fy}},{key:\"_formBarnesHutTree\",value:function _formBarnesHutTree(nodes,nodeIndices){var node=void 0;var nodeCount=nodeIndices.length;var minX=nodes[nodeIndices[0]].x;var minY=nodes[nodeIndices[0]].y;var maxX=nodes[nodeIndices[0]].x;var maxY=nodes[nodeIndices[0]].y;for(var i=1;i<nodeCount;i++){var _node=nodes[nodeIndices[i]];var x=_node.x;var y=_node.y;if(_node.options.mass>0){if(x<minX){minX=x}if(x>maxX){maxX=x}if(y<minY){minY=y}if(y>maxY){maxY=y}}}var sizeDiff=Math.abs(maxX-minX)-Math.abs(maxY-minY);if(sizeDiff>0){minY-=.5*sizeDiff;maxY+=.5*sizeDiff}else{minX+=.5*sizeDiff;maxX-=.5*sizeDiff}var minimumTreeSize=1e-5;var rootSize=Math.max(minimumTreeSize,Math.abs(maxX-minX));var halfRootSize=.5*rootSize;var centerX=.5*(minX+maxX),centerY=.5*(minY+maxY);var barnesHutTree={root:{centerOfMass:{x:0,y:0},mass:0,range:{minX:centerX-halfRootSize,maxX:centerX+halfRootSize,minY:centerY-halfRootSize,maxY:centerY+halfRootSize},size:rootSize,calcSize:1/rootSize,children:{data:null},maxWidth:0,level:0,childrenCount:4}};this._splitBranch(barnesHutTree.root);for(var _i=0;_i<nodeCount;_i++){node=nodes[nodeIndices[_i]];if(node.options.mass>0){this._placeInTree(barnesHutTree.root,node)}}return barnesHutTree}},{key:\"_updateBranchMass\",value:function _updateBranchMass(parentBranch,node){var centerOfMass=parentBranch.centerOfMass;var totalMass=parentBranch.mass+node.options.mass;var totalMassInv=1/totalMass;centerOfMass.x=centerOfMass.x*parentBranch.mass+node.x*node.options.mass;centerOfMass.x*=totalMassInv;centerOfMass.y=centerOfMass.y*parentBranch.mass+node.y*node.options.mass;centerOfMass.y*=totalMassInv;parentBranch.mass=totalMass;var biggestSize=Math.max(Math.max(node.height,node.radius),node.width);parentBranch.maxWidth=parentBranch.maxWidth<biggestSize?biggestSize:parentBranch.maxWidth}},{key:\"_placeInTree\",value:function _placeInTree(parentBranch,node,skipMassUpdate){if(skipMassUpdate!=true||skipMassUpdate===undefined){this._updateBranchMass(parentBranch,node)}var range=parentBranch.children.NW.range;var region=void 0;if(range.maxX>node.x){if(range.maxY>node.y){region=\"NW\"}else{region=\"SW\"}}else{if(range.maxY>node.y){region=\"NE\"}else{region=\"SE\"}}this._placeInRegion(parentBranch,node,region)}},{key:\"_placeInRegion\",value:function _placeInRegion(parentBranch,node,region){var children=parentBranch.children[region];switch(children.childrenCount){case 0:children.children.data=node;children.childrenCount=1;this._updateBranchMass(children,node);break;case 1:if(children.children.data.x===node.x&&children.children.data.y===node.y){node.x+=this.seededRandom();node.y+=this.seededRandom()}else{this._splitBranch(children);this._placeInTree(children,node)}break;case 4:this._placeInTree(children,node);break}}},{key:\"_splitBranch\",value:function _splitBranch(parentBranch){var containedNode=null;if(parentBranch.childrenCount===1){containedNode=parentBranch.children.data;parentBranch.mass=0;parentBranch.centerOfMass.x=0;parentBranch.centerOfMass.y=0}parentBranch.childrenCount=4;parentBranch.children.data=null;this._insertRegion(parentBranch,\"NW\");this._insertRegion(parentBranch,\"NE\");this._insertRegion(parentBranch,\"SW\");this._insertRegion(parentBranch,\"SE\");if(containedNode!=null){this._placeInTree(parentBranch,containedNode)}}},{key:\"_insertRegion\",value:function _insertRegion(parentBranch,region){var minX=void 0,maxX=void 0,minY=void 0,maxY=void 0;var childSize=.5*parentBranch.size;switch(region){case\"NW\":minX=parentBranch.range.minX;maxX=parentBranch.range.minX+childSize;minY=parentBranch.range.minY;maxY=parentBranch.range.minY+childSize;break;case\"NE\":minX=parentBranch.range.minX+childSize;maxX=parentBranch.range.maxX;minY=parentBranch.range.minY;maxY=parentBranch.range.minY+childSize;break;case\"SW\":minX=parentBranch.range.minX;maxX=parentBranch.range.minX+childSize;minY=parentBranch.range.minY+childSize;maxY=parentBranch.range.maxY;break;case\"SE\":minX=parentBranch.range.minX+childSize;maxX=parentBranch.range.maxX;minY=parentBranch.range.minY+childSize;maxY=parentBranch.range.maxY;break}parentBranch.children[region]={centerOfMass:{x:0,y:0},mass:0,range:{minX:minX,maxX:maxX,minY:minY,maxY:maxY},size:.5*parentBranch.size,calcSize:2*parentBranch.calcSize,children:{data:null},maxWidth:0,level:parentBranch.level+1,childrenCount:0}}},{key:\"_debug\",value:function _debug(ctx,color){if(this.barnesHutTree!==undefined){ctx.lineWidth=1;this._drawBranch(this.barnesHutTree.root,ctx,color)}}},{key:\"_drawBranch\",value:function _drawBranch(branch,ctx,color){if(color===undefined){color=\"#FF0000\"}if(branch.childrenCount===4){this._drawBranch(branch.children.NW,ctx);this._drawBranch(branch.children.NE,ctx);this._drawBranch(branch.children.SE,ctx);this._drawBranch(branch.children.SW,ctx)}ctx.strokeStyle=color;ctx.beginPath();ctx.moveTo(branch.range.minX,branch.range.minY);ctx.lineTo(branch.range.maxX,branch.range.minY);ctx.stroke();ctx.beginPath();ctx.moveTo(branch.range.maxX,branch.range.minY);ctx.lineTo(branch.range.maxX,branch.range.maxY);ctx.stroke();ctx.beginPath();ctx.moveTo(branch.range.maxX,branch.range.maxY);ctx.lineTo(branch.range.minX,branch.range.maxY);ctx.stroke();ctx.beginPath();ctx.moveTo(branch.range.minX,branch.range.maxY);ctx.lineTo(branch.range.minX,branch.range.minY);ctx.stroke()}}]);return BarnesHutSolver}();exports[\"default\"]=BarnesHutSolver},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var CentralGravitySolver=function(){function CentralGravitySolver(body,physicsBody,options){(0,_classCallCheck3[\"default\"])(this,CentralGravitySolver);this.body=body;this.physicsBody=physicsBody;this.setOptions(options)}(0,_createClass3[\"default\"])(CentralGravitySolver,[{key:\"setOptions\",value:function setOptions(options){this.options=options}},{key:\"solve\",value:function solve(){var dx=void 0,dy=void 0,distance=void 0,node=void 0;var nodes=this.body.nodes;var nodeIndices=this.physicsBody.physicsNodeIndices;var forces=this.physicsBody.forces;for(var i=0;i<nodeIndices.length;i++){var nodeId=nodeIndices[i];node=nodes[nodeId];dx=-node.x;dy=-node.y;distance=Math.sqrt(dx*dx+dy*dy);this._calculateForces(distance,dx,dy,forces,node)}}},{key:\"_calculateForces\",value:function _calculateForces(distance,dx,dy,forces,node){var gravityForce=distance===0?0:this.options.centralGravity/distance;forces[node.id].x=dx*gravityForce;forces[node.id].y=dy*gravityForce}}]);return CentralGravitySolver}();exports[\"default\"]=CentralGravitySolver},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var string=\"string\";var bool=\"boolean\";var number=\"number\";var array=\"array\";var object=\"object\";var dom=\"dom\";var any=\"any\";var endPoints=[\"arrow\",\"circle\",\"bar\"];var allOptions={configure:{enabled:{boolean:bool},filter:{boolean:bool,string:string,array:array,function:\"function\"},container:{dom:dom},showButton:{boolean:bool},__type__:{object:object,boolean:bool,string:string,array:array,function:\"function\"}},edges:{arrows:{to:{enabled:{boolean:bool},scaleFactor:{number:number},type:{string:endPoints},__type__:{object:object,boolean:bool}},middle:{enabled:{boolean:bool},scaleFactor:{number:number},type:{string:endPoints},__type__:{object:object,boolean:bool}},from:{enabled:{boolean:bool},scaleFactor:{number:number},type:{string:endPoints},__type__:{object:object,boolean:bool}},__type__:{string:[\"from\",\"to\",\"middle\"],object:object}},arrowStrikethrough:{boolean:bool},chosen:{label:{boolean:bool,function:\"function\"},edge:{boolean:bool,function:\"function\"},__type__:{object:object,boolean:bool}},color:{color:{string:string},highlight:{string:string},hover:{string:string},inherit:{string:[\"from\",\"to\",\"both\"],boolean:bool},opacity:{number:number},__type__:{object:object,string:string}},dashes:{boolean:bool,array:array},font:{color:{string:string},size:{number:number},face:{string:string},background:{string:string},strokeWidth:{number:number},strokeColor:{string:string},align:{string:[\"horizontal\",\"top\",\"middle\",\"bottom\"]},vadjust:{number:number},multi:{boolean:bool,string:string},bold:{color:{string:string},size:{number:number},face:{string:string},mod:{string:string},vadjust:{number:number},__type__:{object:object,string:string}},boldital:{color:{string:string},size:{number:number},face:{string:string},mod:{string:string},vadjust:{number:number},__type__:{object:object,string:string}},ital:{color:{string:string},size:{number:number},face:{string:string},mod:{string:string},vadjust:{number:number},__type__:{object:object,string:string}},mono:{color:{string:string},size:{number:number},face:{string:string},mod:{string:string},vadjust:{number:number},__type__:{object:object,string:string}},__type__:{object:object,string:string}},hidden:{boolean:bool},hoverWidth:{function:\"function\",number:number},label:{string:string,undefined:\"undefined\"},labelHighlightBold:{boolean:bool},length:{number:number,undefined:\"undefined\"},physics:{boolean:bool},scaling:{min:{number:number},max:{number:number},label:{enabled:{boolean:bool},min:{number:number},max:{number:number},maxVisible:{number:number},drawThreshold:{number:number},__type__:{object:object,boolean:bool}},customScalingFunction:{function:\"function\"},__type__:{object:object}},selectionWidth:{function:\"function\",number:number},selfReferenceSize:{number:number},shadow:{enabled:{boolean:bool},color:{string:string},size:{number:number},x:{number:number},y:{number:number},__type__:{object:object,boolean:bool}},smooth:{enabled:{boolean:bool},type:{string:[\"dynamic\",\"continuous\",\"discrete\",\"diagonalCross\",\"straightCross\",\"horizontal\",\"vertical\",\"curvedCW\",\"curvedCCW\",\"cubicBezier\"]},roundness:{number:number},forceDirection:{string:[\"horizontal\",\"vertical\",\"none\"],boolean:bool},__type__:{object:object,boolean:bool}},title:{string:string,undefined:\"undefined\"},width:{number:number},widthConstraint:{maximum:{number:number},__type__:{object:object,boolean:bool,number:number}},value:{number:number,undefined:\"undefined\"},__type__:{object:object}},groups:{useDefaultGroups:{boolean:bool},__any__:\"get from nodes, will be overwritten below\",__type__:{object:object}},interaction:{dragNodes:{boolean:bool},dragView:{boolean:bool},hideEdgesOnDrag:{boolean:bool},hideNodesOnDrag:{boolean:bool},hover:{boolean:bool},keyboard:{enabled:{boolean:bool},speed:{x:{number:number},y:{number:number},zoom:{number:number},__type__:{object:object}},bindToWindow:{boolean:bool},__type__:{object:object,boolean:bool}},multiselect:{boolean:bool},navigationButtons:{boolean:bool},selectable:{boolean:bool},selectConnectedEdges:{boolean:bool},hoverConnectedEdges:{boolean:bool},tooltipDelay:{number:number},zoomView:{boolean:bool},__type__:{object:object}},layout:{randomSeed:{undefined:\"undefined\",number:number},improvedLayout:{boolean:bool},hierarchical:{enabled:{boolean:bool},levelSeparation:{number:number},nodeSpacing:{number:number},treeSpacing:{number:number},blockShifting:{boolean:bool},edgeMinimization:{boolean:bool},parentCentralization:{boolean:bool},direction:{string:[\"UD\",\"DU\",\"LR\",\"RL\"]},sortMethod:{string:[\"hubsize\",\"directed\"]},__type__:{object:object,boolean:bool}},__type__:{object:object}},manipulation:{enabled:{boolean:bool},initiallyActive:{boolean:bool},addNode:{boolean:bool,function:\"function\"},addEdge:{boolean:bool,function:\"function\"},editNode:{function:\"function\"},editEdge:{editWithoutDrag:{function:\"function\"},__type__:{object:object,boolean:bool,function:\"function\"}},deleteNode:{boolean:bool,function:\"function\"},deleteEdge:{boolean:bool,function:\"function\"},controlNodeStyle:\"get from nodes, will be overwritten below\",__type__:{object:object,boolean:bool}},nodes:{borderWidth:{number:number},borderWidthSelected:{number:number,undefined:\"undefined\"},brokenImage:{string:string,undefined:\"undefined\"},chosen:{label:{boolean:bool,function:\"function\"},node:{boolean:bool,function:\"function\"},__type__:{object:object,boolean:bool}},color:{border:{string:string},background:{string:string},highlight:{border:{string:string},background:{string:string},__type__:{object:object,string:string}},hover:{border:{string:string},background:{string:string},__type__:{object:object,string:string}},__type__:{object:object,string:string}},fixed:{x:{boolean:bool},y:{boolean:bool},__type__:{object:object,boolean:bool}},font:{align:{string:string},color:{string:string},size:{number:number},face:{string:string},background:{string:string},strokeWidth:{number:number},strokeColor:{string:string},vadjust:{number:number},multi:{boolean:bool,string:string},bold:{color:{string:string},size:{number:number},face:{string:string},mod:{string:string},vadjust:{number:number},__type__:{object:object,string:string}},boldital:{color:{string:string},size:{number:number},face:{string:string},mod:{string:string},vadjust:{number:number},__type__:{object:object,string:string}},ital:{color:{string:string},size:{number:number},face:{string:string},mod:{string:string},vadjust:{number:number},__type__:{object:object,string:string}},mono:{color:{string:string},size:{number:number},face:{string:string},mod:{string:string},vadjust:{number:number},__type__:{object:object,string:string}},__type__:{object:object,string:string}},group:{string:string,number:number,undefined:\"undefined\"},heightConstraint:{minimum:{number:number},valign:{string:string},__type__:{object:object,boolean:bool,number:number}},hidden:{boolean:bool},icon:{face:{string:string},code:{string:string},size:{number:number},color:{string:string},__type__:{object:object}},id:{string:string,number:number},image:{selected:{string:string,undefined:\"undefined\"},unselected:{string:string,undefined:\"undefined\"},__type__:{object:object,string:string}},label:{string:string,undefined:\"undefined\"},labelHighlightBold:{boolean:bool},level:{number:number,undefined:\"undefined\"},margin:{top:{number:number},right:{number:number},bottom:{number:number},left:{number:number},__type__:{object:object,number:number}},mass:{number:number},physics:{boolean:bool},scaling:{min:{number:number},max:{number:number},label:{enabled:{boolean:bool},min:{number:number},max:{number:number},maxVisible:{number:number},drawThreshold:{number:number},__type__:{object:object,boolean:bool}},customScalingFunction:{function:\"function\"},__type__:{object:object}},shadow:{enabled:{boolean:bool},color:{string:string},size:{number:number},x:{number:number},y:{number:number},__type__:{object:object,boolean:bool}},shape:{string:[\"ellipse\",\"circle\",\"database\",\"box\",\"text\",\"image\",\"circularImage\",\"diamond\",\"dot\",\"star\",\"triangle\",\"triangleDown\",\"square\",\"icon\",\"hexagon\"]},shapeProperties:{borderDashes:{boolean:bool,array:array},borderRadius:{number:number},interpolation:{boolean:bool},useImageSize:{boolean:bool},useBorderWithImage:{boolean:bool},__type__:{object:object}},size:{number:number},title:{string:string,dom:dom,undefined:\"undefined\"},value:{number:number,undefined:\"undefined\"},widthConstraint:{minimum:{number:number},maximum:{number:number},__type__:{object:object,boolean:bool,number:number}},x:{number:number},y:{number:number},__type__:{object:object}},physics:{enabled:{boolean:bool},barnesHut:{gravitationalConstant:{number:number},centralGravity:{number:number},springLength:{number:number},springConstant:{number:number},damping:{number:number},avoidOverlap:{number:number},__type__:{object:object}},forceAtlas2Based:{gravitationalConstant:{number:number},centralGravity:{number:number},springLength:{number:number},springConstant:{number:number},damping:{number:number},avoidOverlap:{number:number},__type__:{object:object}},repulsion:{centralGravity:{number:number},springLength:{number:number},springConstant:{number:number},nodeDistance:{number:number},damping:{number:number},__type__:{object:object}},hierarchicalRepulsion:{centralGravity:{number:number},springLength:{number:number},springConstant:{number:number},nodeDistance:{number:number},damping:{number:number},__type__:{object:object}},maxVelocity:{number:number},minVelocity:{number:number},solver:{string:[\"barnesHut\",\"repulsion\",\"hierarchicalRepulsion\",\"forceAtlas2Based\"]},stabilization:{enabled:{boolean:bool},iterations:{number:number},updateInterval:{number:number},onlyDynamicEdges:{boolean:bool},\nfit:{boolean:bool},__type__:{object:object,boolean:bool}},timestep:{number:number},adaptiveTimestep:{boolean:bool},__type__:{object:object,boolean:bool}},autoResize:{boolean:bool},clickToUse:{boolean:bool},locale:{string:string},locales:{__any__:{any:any},__type__:{object:object}},height:{string:string},width:{string:string},__type__:{object:object}};allOptions.groups.__any__=allOptions.nodes;allOptions.manipulation.controlNodeStyle=allOptions.nodes;var configureOptions={nodes:{borderWidth:[1,0,10,1],borderWidthSelected:[2,0,10,1],color:{border:[\"color\",\"#2B7CE9\"],background:[\"color\",\"#97C2FC\"],highlight:{border:[\"color\",\"#2B7CE9\"],background:[\"color\",\"#D2E5FF\"]},hover:{border:[\"color\",\"#2B7CE9\"],background:[\"color\",\"#D2E5FF\"]}},fixed:{x:false,y:false},font:{color:[\"color\",\"#343434\"],size:[14,0,100,1],face:[\"arial\",\"verdana\",\"tahoma\"],background:[\"color\",\"none\"],strokeWidth:[0,0,50,1],strokeColor:[\"color\",\"#ffffff\"]},hidden:false,labelHighlightBold:true,physics:true,scaling:{min:[10,0,200,1],max:[30,0,200,1],label:{enabled:false,min:[14,0,200,1],max:[30,0,200,1],maxVisible:[30,0,200,1],drawThreshold:[5,0,20,1]}},shadow:{enabled:false,color:\"rgba(0,0,0,0.5)\",size:[10,0,20,1],x:[5,-30,30,1],y:[5,-30,30,1]},shape:[\"ellipse\",\"box\",\"circle\",\"database\",\"diamond\",\"dot\",\"square\",\"star\",\"text\",\"triangle\",\"triangleDown\",\"hexagon\"],shapeProperties:{borderDashes:false,borderRadius:[6,0,20,1],interpolation:true,useImageSize:false},size:[25,0,200,1]},edges:{arrows:{to:{enabled:false,scaleFactor:[1,0,3,.05],type:\"arrow\"},middle:{enabled:false,scaleFactor:[1,0,3,.05],type:\"arrow\"},from:{enabled:false,scaleFactor:[1,0,3,.05],type:\"arrow\"}},arrowStrikethrough:true,color:{color:[\"color\",\"#848484\"],highlight:[\"color\",\"#848484\"],hover:[\"color\",\"#848484\"],inherit:[\"from\",\"to\",\"both\",true,false],opacity:[1,0,1,.05]},dashes:false,font:{color:[\"color\",\"#343434\"],size:[14,0,100,1],face:[\"arial\",\"verdana\",\"tahoma\"],background:[\"color\",\"none\"],strokeWidth:[2,0,50,1],strokeColor:[\"color\",\"#ffffff\"],align:[\"horizontal\",\"top\",\"middle\",\"bottom\"]},hidden:false,hoverWidth:[1.5,0,5,.1],labelHighlightBold:true,physics:true,scaling:{min:[1,0,100,1],max:[15,0,100,1],label:{enabled:true,min:[14,0,200,1],max:[30,0,200,1],maxVisible:[30,0,200,1],drawThreshold:[5,0,20,1]}},selectionWidth:[1.5,0,5,.1],selfReferenceSize:[20,0,200,1],shadow:{enabled:false,color:\"rgba(0,0,0,0.5)\",size:[10,0,20,1],x:[5,-30,30,1],y:[5,-30,30,1]},smooth:{enabled:true,type:[\"dynamic\",\"continuous\",\"discrete\",\"diagonalCross\",\"straightCross\",\"horizontal\",\"vertical\",\"curvedCW\",\"curvedCCW\",\"cubicBezier\"],forceDirection:[\"horizontal\",\"vertical\",\"none\"],roundness:[.5,0,1,.05]},width:[1,0,30,1]},layout:{hierarchical:{enabled:false,levelSeparation:[150,20,500,5],nodeSpacing:[100,20,500,5],treeSpacing:[200,20,500,5],blockShifting:true,edgeMinimization:true,parentCentralization:true,direction:[\"UD\",\"DU\",\"LR\",\"RL\"],sortMethod:[\"hubsize\",\"directed\"]}},interaction:{dragNodes:true,dragView:true,hideEdgesOnDrag:false,hideNodesOnDrag:false,hover:false,keyboard:{enabled:false,speed:{x:[10,0,40,1],y:[10,0,40,1],zoom:[.02,0,.1,.005]},bindToWindow:true},multiselect:false,navigationButtons:false,selectable:true,selectConnectedEdges:true,hoverConnectedEdges:true,tooltipDelay:[300,0,1e3,25],zoomView:true},manipulation:{enabled:false,initiallyActive:false},physics:{enabled:true,barnesHut:{gravitationalConstant:[-2e3,-3e4,0,50],centralGravity:[.3,0,10,.05],springLength:[95,0,500,5],springConstant:[.04,0,1.2,.005],damping:[.09,0,1,.01],avoidOverlap:[0,0,1,.01]},forceAtlas2Based:{gravitationalConstant:[-50,-500,0,1],centralGravity:[.01,0,1,.005],springLength:[95,0,500,5],springConstant:[.08,0,1.2,.005],damping:[.4,0,1,.01],avoidOverlap:[0,0,1,.01]},repulsion:{centralGravity:[.2,0,10,.05],springLength:[200,0,500,5],springConstant:[.05,0,1.2,.005],nodeDistance:[100,0,500,5],damping:[.09,0,1,.01]},hierarchicalRepulsion:{centralGravity:[.2,0,10,.05],springLength:[100,0,500,5],springConstant:[.01,0,1.2,.005],nodeDistance:[120,0,500,5],damping:[.09,0,1,.01]},maxVelocity:[50,0,150,1],minVelocity:[.1,.01,.5,.01],solver:[\"barnesHut\",\"forceAtlas2Based\",\"repulsion\",\"hierarchicalRepulsion\"],timestep:[.5,.01,1,.01]}};exports.allOptions=allOptions;exports.configureOptions=configureOptions},function(module,exports,__webpack_require__){\"use strict\";var util=__webpack_require__(2);util.extend(exports,__webpack_require__(159));util.extend(exports,__webpack_require__(177));util.extend(exports,__webpack_require__(181))},function(module,exports,__webpack_require__){__webpack_require__(49);__webpack_require__(60);module.exports=__webpack_require__(136)},function(module,exports,__webpack_require__){\"use strict\";var addToUnscopables=__webpack_require__(126);var step=__webpack_require__(127);var Iterators=__webpack_require__(31);var toIObject=__webpack_require__(25);module.exports=__webpack_require__(79)(Array,\"Array\",function(iterated,kind){this._t=toIObject(iterated);this._i=0;this._k=kind},function(){var O=this._t;var kind=this._k;var index=this._i++;if(!O||index>=O.length){this._t=undefined;return step(1)}if(kind==\"keys\")return step(0,index);if(kind==\"values\")return step(0,O[index]);return step(0,[index,O[index]])},\"values\");Iterators.Arguments=Iterators.Array;addToUnscopables(\"keys\");addToUnscopables(\"values\");addToUnscopables(\"entries\")},function(module,exports){module.exports=function(){}},function(module,exports){module.exports=function(done,value){return{value:value,done:!!done}}},function(module,exports){module.exports=function(it){if(typeof it!=\"function\")throw TypeError(it+\" is not a function!\");return it}},function(module,exports,__webpack_require__){\"use strict\";var create=__webpack_require__(54);var descriptor=__webpack_require__(39);var setToStringTag=__webpack_require__(59);var IteratorPrototype={};__webpack_require__(26)(IteratorPrototype,__webpack_require__(13)(\"iterator\"),function(){return this});module.exports=function(Constructor,NAME,next){Constructor.prototype=create(IteratorPrototype,{next:descriptor(1,next)});setToStringTag(Constructor,NAME+\" Iterator\")}},function(module,exports,__webpack_require__){var dP=__webpack_require__(20);var anObject=__webpack_require__(27);var getKeys=__webpack_require__(33);module.exports=__webpack_require__(21)?Object.defineProperties:function defineProperties(O,Properties){anObject(O);var keys=getKeys(Properties);var length=keys.length;var i=0;var P;while(length>i)dP.f(O,P=keys[i++],Properties[P]);return O}},function(module,exports,__webpack_require__){var toIObject=__webpack_require__(25);var toLength=__webpack_require__(132);var toAbsoluteIndex=__webpack_require__(133);module.exports=function(IS_INCLUDES){return function($this,el,fromIndex){var O=toIObject($this);var length=toLength(O.length);var index=toAbsoluteIndex(fromIndex,length);var value;if(IS_INCLUDES&&el!=el)while(length>index){value=O[index++];if(value!=value)return true}else for(;length>index;index++)if(IS_INCLUDES||index in O){if(O[index]===el)return IS_INCLUDES||index||0}return!IS_INCLUDES&&-1}}},function(module,exports,__webpack_require__){var toInteger=__webpack_require__(55);var min=Math.min;module.exports=function(it){return it>0?min(toInteger(it),9007199254740991):0}},function(module,exports,__webpack_require__){var toInteger=__webpack_require__(55);var max=Math.max;var min=Math.min;module.exports=function(index,length){index=toInteger(index);return index<0?max(index+length,0):min(index,length)}},function(module,exports,__webpack_require__){var document=__webpack_require__(18).document;module.exports=document&&document.documentElement},function(module,exports,__webpack_require__){var toInteger=__webpack_require__(55);var defined=__webpack_require__(51);module.exports=function(TO_STRING){return function(that,pos){var s=String(defined(that));var i=toInteger(pos);var l=s.length;var a,b;if(i<0||i>=l)return TO_STRING?\"\":undefined;a=s.charCodeAt(i);return a<55296||a>56319||i+1===l||(b=s.charCodeAt(i+1))<56320||b>57343?TO_STRING?s.charAt(i):a:TO_STRING?s.slice(i,i+2):(a-55296<<10)+(b-56320)+65536}}},function(module,exports,__webpack_require__){var anObject=__webpack_require__(27);var get=__webpack_require__(137);module.exports=__webpack_require__(7).getIterator=function(it){var iterFn=get(it);if(typeof iterFn!=\"function\")throw TypeError(it+\" is not iterable!\");return anObject(iterFn.call(it))}},function(module,exports,__webpack_require__){var classof=__webpack_require__(86);var ITERATOR=__webpack_require__(13)(\"iterator\");var Iterators=__webpack_require__(31);module.exports=__webpack_require__(7).getIteratorMethod=function(it){if(it!=undefined)return it[ITERATOR]||it[\"@@iterator\"]||Iterators[classof(it)]}},function(module,exports,__webpack_require__){__webpack_require__(139);var $Object=__webpack_require__(7).Object;module.exports=function create(P,D){return $Object.create(P,D)}},function(module,exports,__webpack_require__){var $export=__webpack_require__(17);$export($export.S,\"Object\",{create:__webpack_require__(54)})},function(module,exports,__webpack_require__){__webpack_require__(141);module.exports=__webpack_require__(7).Object.keys},function(module,exports,__webpack_require__){var toObject=__webpack_require__(41);var $keys=__webpack_require__(33);__webpack_require__(87)(\"keys\",function(){return function keys(it){return $keys(toObject(it))}})},function(module,exports,__webpack_require__){module.exports={default:__webpack_require__(143),__esModule:true}},function(module,exports,__webpack_require__){__webpack_require__(60);__webpack_require__(49);module.exports=__webpack_require__(61).f(\"iterator\")},function(module,exports,__webpack_require__){module.exports={default:__webpack_require__(145),__esModule:true}},function(module,exports,__webpack_require__){__webpack_require__(146);__webpack_require__(151);__webpack_require__(152);__webpack_require__(153);module.exports=__webpack_require__(7).Symbol},function(module,exports,__webpack_require__){\"use strict\";var global=__webpack_require__(18);var has=__webpack_require__(22);var DESCRIPTORS=__webpack_require__(21);var $export=__webpack_require__(17);var redefine=__webpack_require__(83);var META=__webpack_require__(147).KEY;var $fails=__webpack_require__(28);var shared=__webpack_require__(57);var setToStringTag=__webpack_require__(59);var uid=__webpack_require__(40);var wks=__webpack_require__(13);var wksExt=__webpack_require__(61);var wksDefine=__webpack_require__(62);var enumKeys=__webpack_require__(148);var isArray=__webpack_require__(149);var anObject=__webpack_require__(27);var toIObject=__webpack_require__(25);var toPrimitive=__webpack_require__(53);var createDesc=__webpack_require__(39);var _create=__webpack_require__(54);var gOPNExt=__webpack_require__(150);var $GOPD=__webpack_require__(89);var $DP=__webpack_require__(20);var $keys=__webpack_require__(33);var gOPD=$GOPD.f;var dP=$DP.f;var gOPN=gOPNExt.f;var $Symbol=global.Symbol;var $JSON=global.JSON;var _stringify=$JSON&&$JSON.stringify;var PROTOTYPE=\"prototype\";var HIDDEN=wks(\"_hidden\");var TO_PRIMITIVE=wks(\"toPrimitive\");var isEnum={}.propertyIsEnumerable;var SymbolRegistry=shared(\"symbol-registry\");var AllSymbols=shared(\"symbols\");var OPSymbols=shared(\"op-symbols\");var ObjectProto=Object[PROTOTYPE];var USE_NATIVE=typeof $Symbol==\"function\";var QObject=global.QObject;var setter=!QObject||!QObject[PROTOTYPE]||!QObject[PROTOTYPE].findChild;var setSymbolDesc=DESCRIPTORS&&$fails(function(){return _create(dP({},\"a\",{get:function(){return dP(this,\"a\",{value:7}).a}})).a!=7})?function(it,key,D){var protoDesc=gOPD(ObjectProto,key);if(protoDesc)delete ObjectProto[key];dP(it,key,D);if(protoDesc&&it!==ObjectProto)dP(ObjectProto,key,protoDesc)}:dP;var wrap=function(tag){var sym=AllSymbols[tag]=_create($Symbol[PROTOTYPE]);sym._k=tag;return sym};var isSymbol=USE_NATIVE&&typeof $Symbol.iterator==\"symbol\"?function(it){return typeof it==\"symbol\"}:function(it){return it instanceof $Symbol};var $defineProperty=function defineProperty(it,key,D){if(it===ObjectProto)$defineProperty(OPSymbols,key,D);anObject(it);key=toPrimitive(key,true);anObject(D);if(has(AllSymbols,key)){if(!D.enumerable){if(!has(it,HIDDEN))dP(it,HIDDEN,createDesc(1,{}));it[HIDDEN][key]=true}else{if(has(it,HIDDEN)&&it[HIDDEN][key])it[HIDDEN][key]=false;D=_create(D,{enumerable:createDesc(0,false)})}return setSymbolDesc(it,key,D)}return dP(it,key,D)};var $defineProperties=function defineProperties(it,P){anObject(it);var keys=enumKeys(P=toIObject(P));var i=0;var l=keys.length;var key;while(l>i)$defineProperty(it,key=keys[i++],P[key]);return it};var $create=function create(it,P){return P===undefined?_create(it):$defineProperties(_create(it),P)};var $propertyIsEnumerable=function propertyIsEnumerable(key){var E=isEnum.call(this,key=toPrimitive(key,true));if(this===ObjectProto&&has(AllSymbols,key)&&!has(OPSymbols,key))return false;return E||!has(this,key)||!has(AllSymbols,key)||has(this,HIDDEN)&&this[HIDDEN][key]?E:true};var $getOwnPropertyDescriptor=function getOwnPropertyDescriptor(it,key){it=toIObject(it);key=toPrimitive(key,true);if(it===ObjectProto&&has(AllSymbols,key)&&!has(OPSymbols,key))return;var D=gOPD(it,key);if(D&&has(AllSymbols,key)&&!(has(it,HIDDEN)&&it[HIDDEN][key]))D.enumerable=true;return D};var $getOwnPropertyNames=function getOwnPropertyNames(it){var names=gOPN(toIObject(it));var result=[];var i=0;var key;while(names.length>i){if(!has(AllSymbols,key=names[i++])&&key!=HIDDEN&&key!=META)result.push(key)}return result};var $getOwnPropertySymbols=function getOwnPropertySymbols(it){var IS_OP=it===ObjectProto;var names=gOPN(IS_OP?OPSymbols:toIObject(it));var result=[];var i=0;var key;while(names.length>i){if(has(AllSymbols,key=names[i++])&&(IS_OP?has(ObjectProto,key):true))result.push(AllSymbols[key])}return result};if(!USE_NATIVE){$Symbol=function Symbol(){if(this instanceof $Symbol)throw TypeError(\"Symbol is not a constructor!\");var tag=uid(arguments.length>0?arguments[0]:undefined);var $set=function(value){if(this===ObjectProto)$set.call(OPSymbols,value);if(has(this,HIDDEN)&&has(this[HIDDEN],tag))this[HIDDEN][tag]=false;setSymbolDesc(this,tag,createDesc(1,value))};if(DESCRIPTORS&&setter)setSymbolDesc(ObjectProto,tag,{configurable:true,set:$set});return wrap(tag)};redefine($Symbol[PROTOTYPE],\"toString\",function toString(){return this._k});$GOPD.f=$getOwnPropertyDescriptor;$DP.f=$defineProperty;__webpack_require__(88).f=gOPNExt.f=$getOwnPropertyNames;__webpack_require__(42).f=$propertyIsEnumerable;__webpack_require__(63).f=$getOwnPropertySymbols;if(DESCRIPTORS&&!__webpack_require__(52)){redefine(ObjectProto,\"propertyIsEnumerable\",$propertyIsEnumerable,true)}wksExt.f=function(name){return wrap(wks(name))}}$export($export.G+$export.W+$export.F*!USE_NATIVE,{Symbol:$Symbol});for(var es6Symbols=\"hasInstance,isConcatSpreadable,iterator,match,replace,search,species,split,toPrimitive,toStringTag,unscopables\".split(\",\"),j=0;es6Symbols.length>j;)wks(es6Symbols[j++]);for(var wellKnownSymbols=$keys(wks.store),k=0;wellKnownSymbols.length>k;)wksDefine(wellKnownSymbols[k++]);$export($export.S+$export.F*!USE_NATIVE,\"Symbol\",{for:function(key){return has(SymbolRegistry,key+=\"\")?SymbolRegistry[key]:SymbolRegistry[key]=$Symbol(key)},keyFor:function keyFor(sym){if(!isSymbol(sym))throw TypeError(sym+\" is not a symbol!\");for(var key in SymbolRegistry)if(SymbolRegistry[key]===sym)return key},useSetter:function(){setter=true},useSimple:function(){setter=false}});$export($export.S+$export.F*!USE_NATIVE,\"Object\",{create:$create,defineProperty:$defineProperty,defineProperties:$defineProperties,getOwnPropertyDescriptor:$getOwnPropertyDescriptor,getOwnPropertyNames:$getOwnPropertyNames,getOwnPropertySymbols:$getOwnPropertySymbols});$JSON&&$export($export.S+$export.F*(!USE_NATIVE||$fails(function(){var S=$Symbol();return _stringify([S])!=\"[null]\"||_stringify({a:S})!=\"{}\"||_stringify(Object(S))!=\"{}\"})),\"JSON\",{stringify:function stringify(it){if(it===undefined||isSymbol(it))return;var args=[it];var i=1;var replacer,$replacer;while(arguments.length>i)args.push(arguments[i++]);replacer=args[1];if(typeof replacer==\"function\")$replacer=replacer;if($replacer||!isArray(replacer))replacer=function(key,value){if($replacer)value=$replacer.call(this,key,value);if(!isSymbol(value))return value};args[1]=replacer;return _stringify.apply($JSON,args)}});$Symbol[PROTOTYPE][TO_PRIMITIVE]||__webpack_require__(26)($Symbol[PROTOTYPE],TO_PRIMITIVE,$Symbol[PROTOTYPE].valueOf);setToStringTag($Symbol,\"Symbol\");setToStringTag(Math,\"Math\",true);setToStringTag(global.JSON,\"JSON\",true)},function(module,exports,__webpack_require__){var META=__webpack_require__(40)(\"meta\");var isObject=__webpack_require__(32);var has=__webpack_require__(22);var setDesc=__webpack_require__(20).f;var id=0;var isExtensible=Object.isExtensible||function(){return true};var FREEZE=!__webpack_require__(28)(function(){return isExtensible(Object.preventExtensions({}))});var setMeta=function(it){setDesc(it,META,{value:{i:\"O\"+ ++id,w:{}}})};var fastKey=function(it,create){if(!isObject(it))return typeof it==\"symbol\"?it:(typeof it==\"string\"?\"S\":\"P\")+it;if(!has(it,META)){if(!isExtensible(it))return\"F\";if(!create)return\"E\";setMeta(it)}return it[META].i};var getWeak=function(it,create){if(!has(it,META)){if(!isExtensible(it))return true;if(!create)return false;setMeta(it)}return it[META].w};var onFreeze=function(it){if(FREEZE&&meta.NEED&&isExtensible(it)&&!has(it,META))setMeta(it);return it};var meta=module.exports={KEY:META,NEED:false,fastKey:fastKey,getWeak:getWeak,onFreeze:onFreeze}},function(module,exports,__webpack_require__){var getKeys=__webpack_require__(33);var gOPS=__webpack_require__(63);var pIE=__webpack_require__(42);module.exports=function(it){var result=getKeys(it);var getSymbols=gOPS.f;if(getSymbols){var symbols=getSymbols(it);var isEnum=pIE.f;var i=0;var key;while(symbols.length>i)if(isEnum.call(it,key=symbols[i++]))result.push(key)}return result}},function(module,exports,__webpack_require__){var cof=__webpack_require__(50);module.exports=Array.isArray||function isArray(arg){return cof(arg)==\"Array\"}},function(module,exports,__webpack_require__){var toIObject=__webpack_require__(25);var gOPN=__webpack_require__(88).f;var toString={}.toString;var windowNames=typeof window==\"object\"&&window&&Object.getOwnPropertyNames?Object.getOwnPropertyNames(window):[];var getWindowNames=function(it){try{return gOPN(it)}catch(e){return windowNames.slice()}};module.exports.f=function getOwnPropertyNames(it){return windowNames&&toString.call(it)==\"[object Window]\"?getWindowNames(it):gOPN(toIObject(it))}},function(module,exports){},function(module,exports,__webpack_require__){__webpack_require__(62)(\"asyncIterator\")},function(module,exports,__webpack_require__){__webpack_require__(62)(\"observable\")},function(module,exports,__webpack_require__){(function(module){var require;(function(global,factory){true?module.exports=factory():typeof define===\"function\"&&define.amd?define(factory):global.moment=factory()})(this,function(){\"use strict\";var hookCallback;function hooks(){return hookCallback.apply(null,arguments)}function setHookCallback(callback){hookCallback=callback}function isArray(input){return input instanceof Array||Object.prototype.toString.call(input)===\"[object Array]\"}function isObject(input){return input!=null&&Object.prototype.toString.call(input)===\"[object Object]\"}function isObjectEmpty(obj){if(Object.getOwnPropertyNames){return Object.getOwnPropertyNames(obj).length===0}else{var k;for(k in obj){if(obj.hasOwnProperty(k)){return false}}return true}}function isUndefined(input){return input===void 0}function isNumber(input){return typeof input===\"number\"||Object.prototype.toString.call(input)===\"[object Number]\"}function isDate(input){return input instanceof Date||Object.prototype.toString.call(input)===\"[object Date]\"}function map(arr,fn){var res=[],i;for(i=0;i<arr.length;++i){res.push(fn(arr[i],i))}return res}function hasOwnProp(a,b){return Object.prototype.hasOwnProperty.call(a,b)}function extend(a,b){for(var i in b){if(hasOwnProp(b,i)){a[i]=b[i]}}if(hasOwnProp(b,\"toString\")){a.toString=b.toString}if(hasOwnProp(b,\"valueOf\")){a.valueOf=b.valueOf}return a}function createUTC(input,format,locale,strict){return createLocalOrUTC(input,format,locale,strict,true).utc()}function defaultParsingFlags(){return{empty:false,unusedTokens:[],unusedInput:[],overflow:-2,charsLeftOver:0,nullInput:false,invalidMonth:null,invalidFormat:false,userInvalidated:false,iso:false,parsedDateParts:[],meridiem:null,rfc2822:false,weekdayMismatch:false}}function getParsingFlags(m){if(m._pf==null){m._pf=defaultParsingFlags()}return m._pf}var some;if(Array.prototype.some){some=Array.prototype.some}else{some=function(fun){var t=Object(this);var len=t.length>>>0;for(var i=0;i<len;i++){if(i in t&&fun.call(this,t[i],i,t)){return true}}return false}}function isValid(m){if(m._isValid==null){var flags=getParsingFlags(m);var parsedParts=some.call(flags.parsedDateParts,function(i){return i!=null});var isNowValid=!isNaN(m._d.getTime())&&flags.overflow<0&&!flags.empty&&!flags.invalidMonth&&!flags.invalidWeekday&&!flags.weekdayMismatch&&!flags.nullInput&&!flags.invalidFormat&&!flags.userInvalidated&&(!flags.meridiem||flags.meridiem&&parsedParts);if(m._strict){isNowValid=isNowValid&&flags.charsLeftOver===0&&flags.unusedTokens.length===0&&flags.bigHour===undefined}if(Object.isFrozen==null||!Object.isFrozen(m)){m._isValid=isNowValid}else{return isNowValid}}return m._isValid}function createInvalid(flags){var m=createUTC(NaN);if(flags!=null){extend(getParsingFlags(m),flags)}else{getParsingFlags(m).userInvalidated=true}return m}var momentProperties=hooks.momentProperties=[];function copyConfig(to,from){var i,prop,val;if(!isUndefined(from._isAMomentObject)){to._isAMomentObject=from._isAMomentObject}if(!isUndefined(from._i)){to._i=from._i}if(!isUndefined(from._f)){to._f=from._f}if(!isUndefined(from._l)){to._l=from._l}if(!isUndefined(from._strict)){to._strict=from._strict}if(!isUndefined(from._tzm)){to._tzm=from._tzm}if(!isUndefined(from._isUTC)){to._isUTC=from._isUTC}if(!isUndefined(from._offset)){to._offset=from._offset}if(!isUndefined(from._pf)){to._pf=getParsingFlags(from)}if(!isUndefined(from._locale)){to._locale=from._locale}if(momentProperties.length>0){for(i=0;i<momentProperties.length;i++){prop=momentProperties[i];val=from[prop];if(!isUndefined(val)){to[prop]=val}}}return to}var updateInProgress=false;function Moment(config){copyConfig(this,config);this._d=new Date(config._d!=null?config._d.getTime():NaN);if(!this.isValid()){this._d=new Date(NaN)}if(updateInProgress===false){updateInProgress=true;hooks.updateOffset(this);updateInProgress=false}}function isMoment(obj){return obj instanceof Moment||obj!=null&&obj._isAMomentObject!=null}function absFloor(number){if(number<0){return Math.ceil(number)||0}else{return Math.floor(number)}}function toInt(argumentForCoercion){var coercedNumber=+argumentForCoercion,value=0;if(coercedNumber!==0&&isFinite(coercedNumber)){value=absFloor(coercedNumber)}return value}function compareArrays(array1,array2,dontConvert){var len=Math.min(array1.length,array2.length),lengthDiff=Math.abs(array1.length-array2.length),diffs=0,i;for(i=0;i<len;i++){if(dontConvert&&array1[i]!==array2[i]||!dontConvert&&toInt(array1[i])!==toInt(array2[i])){diffs++}}return diffs+lengthDiff}function warn(msg){if(hooks.suppressDeprecationWarnings===false&&typeof console!==\"undefined\"&&console.warn){console.warn(\"Deprecation warning: \"+msg)}}function deprecate(msg,fn){var firstTime=true;return extend(function(){if(hooks.deprecationHandler!=null){hooks.deprecationHandler(null,msg)}if(firstTime){var args=[];var arg;for(var i=0;i<arguments.length;i++){arg=\"\";if(typeof arguments[i]===\"object\"){arg+=\"\\n[\"+i+\"] \";for(var key in arguments[0]){arg+=key+\": \"+arguments[0][key]+\", \"}arg=arg.slice(0,-2)}else{arg=arguments[i]}args.push(arg)}warn(msg+\"\\nArguments: \"+Array.prototype.slice.call(args).join(\"\")+\"\\n\"+(new Error).stack);firstTime=false}return fn.apply(this,arguments)},fn)}var deprecations={};function deprecateSimple(name,msg){if(hooks.deprecationHandler!=null){hooks.deprecationHandler(name,msg)}if(!deprecations[name]){warn(msg);deprecations[name]=true}}hooks.suppressDeprecationWarnings=false;hooks.deprecationHandler=null;function isFunction(input){return input instanceof Function||Object.prototype.toString.call(input)===\"[object Function]\"}function set(config){var prop,i;for(i in config){prop=config[i];if(isFunction(prop)){this[i]=prop}else{this[\"_\"+i]=prop}}this._config=config;this._dayOfMonthOrdinalParseLenient=new RegExp((this._dayOfMonthOrdinalParse.source||this._ordinalParse.source)+\"|\"+/\\d{1,2}/.source)}function mergeConfigs(parentConfig,childConfig){var res=extend({},parentConfig),prop;for(prop in childConfig){if(hasOwnProp(childConfig,prop)){if(isObject(parentConfig[prop])&&isObject(childConfig[prop])){res[prop]={};extend(res[prop],parentConfig[prop]);extend(res[prop],childConfig[prop])}else if(childConfig[prop]!=null){res[prop]=childConfig[prop]}else{delete res[prop]}}}for(prop in parentConfig){if(hasOwnProp(parentConfig,prop)&&!hasOwnProp(childConfig,prop)&&isObject(parentConfig[prop])){res[prop]=extend({},res[prop])}}return res}function Locale(config){if(config!=null){this.set(config)}}var keys;if(Object.keys){keys=Object.keys}else{keys=function(obj){var i,res=[];for(i in obj){if(hasOwnProp(obj,i)){res.push(i)}}return res}}var defaultCalendar={sameDay:\"[Today at] LT\",nextDay:\"[Tomorrow at] LT\",nextWeek:\"dddd [at] LT\",lastDay:\"[Yesterday at] LT\",lastWeek:\"[Last] dddd [at] LT\",sameElse:\"L\"};function calendar(key,mom,now){var output=this._calendar[key]||this._calendar[\"sameElse\"];return isFunction(output)?output.call(mom,now):output}var defaultLongDateFormat={LTS:\"h:mm:ss A\",LT:\"h:mm A\",L:\"MM/DD/YYYY\",LL:\"MMMM D, YYYY\",LLL:\"MMMM D, YYYY h:mm A\",LLLL:\"dddd, MMMM D, YYYY h:mm A\"};function longDateFormat(key){var format=this._longDateFormat[key],formatUpper=this._longDateFormat[key.toUpperCase()];if(format||!formatUpper){return format}this._longDateFormat[key]=formatUpper.replace(/MMMM|MM|DD|dddd/g,function(val){return val.slice(1)});return this._longDateFormat[key]}var defaultInvalidDate=\"Invalid date\";function invalidDate(){return this._invalidDate}var defaultOrdinal=\"%d\";var defaultDayOfMonthOrdinalParse=/\\d{1,2}/;function ordinal(number){return this._ordinal.replace(\"%d\",number)}var defaultRelativeTime={future:\"in %s\",past:\"%s ago\",s:\"a few seconds\",ss:\"%d seconds\",m:\"a minute\",mm:\"%d minutes\",h:\"an hour\",hh:\"%d hours\",d:\"a day\",dd:\"%d days\",M:\"a month\",MM:\"%d months\",y:\"a year\",yy:\"%d years\"};function relativeTime(number,withoutSuffix,string,isFuture){var output=this._relativeTime[string];return isFunction(output)?output(number,withoutSuffix,string,isFuture):output.replace(/%d/i,number)}function pastFuture(diff,output){var format=this._relativeTime[diff>0?\"future\":\"past\"];return isFunction(format)?format(output):format.replace(/%s/i,output)}var aliases={};function addUnitAlias(unit,shorthand){var lowerCase=unit.toLowerCase();aliases[lowerCase]=aliases[lowerCase+\"s\"]=aliases[shorthand]=unit}function normalizeUnits(units){return typeof units===\"string\"?aliases[units]||aliases[units.toLowerCase()]:undefined}function normalizeObjectUnits(inputObject){var normalizedInput={},normalizedProp,prop;for(prop in inputObject){if(hasOwnProp(inputObject,prop)){normalizedProp=normalizeUnits(prop);if(normalizedProp){normalizedInput[normalizedProp]=inputObject[prop]}}}return normalizedInput}var priorities={};function addUnitPriority(unit,priority){priorities[unit]=priority}function getPrioritizedUnits(unitsObj){var units=[];for(var u in unitsObj){units.push({unit:u,priority:priorities[u]})}units.sort(function(a,b){return a.priority-b.priority});return units}function zeroFill(number,targetLength,forceSign){var absNumber=\"\"+Math.abs(number),zerosToFill=targetLength-absNumber.length,sign=number>=0;return(sign?forceSign?\"+\":\"\":\"-\")+Math.pow(10,Math.max(0,zerosToFill)).toString().substr(1)+absNumber}var formattingTokens=/(\\[[^\\[]*\\])|(\\\\)?([Hh]mm(ss)?|Mo|MM?M?M?|Do|DDDo|DD?D?D?|ddd?d?|do?|w[o|w]?|W[o|W]?|Qo?|YYYYYY|YYYYY|YYYY|YY|gg(ggg?)?|GG(GGG?)?|e|E|a|A|hh?|HH?|kk?|mm?|ss?|S{1,9}|x|X|zz?|ZZ?|.)/g;var localFormattingTokens=/(\\[[^\\[]*\\])|(\\\\)?(LTS|LT|LL?L?L?|l{1,4})/g;var formatFunctions={};var formatTokenFunctions={};function addFormatToken(token,padded,ordinal,callback){var func=callback;if(typeof callback===\"string\"){func=function(){return this[callback]()}}if(token){formatTokenFunctions[token]=func}if(padded){formatTokenFunctions[padded[0]]=function(){return zeroFill(func.apply(this,arguments),padded[1],padded[2])}}if(ordinal){formatTokenFunctions[ordinal]=function(){return this.localeData().ordinal(func.apply(this,arguments),token)}}}function removeFormattingTokens(input){if(input.match(/\\[[\\s\\S]/)){return input.replace(/^\\[|\\]$/g,\"\")}return input.replace(/\\\\/g,\"\")}function makeFormatFunction(format){var array=format.match(formattingTokens),i,length;for(i=0,length=array.length;i<length;i++){if(formatTokenFunctions[array[i]]){array[i]=formatTokenFunctions[array[i]]}else{array[i]=removeFormattingTokens(array[i])}}return function(mom){var output=\"\",i;for(i=0;i<length;i++){output+=isFunction(array[i])?array[i].call(mom,format):array[i]}return output}}function formatMoment(m,format){if(!m.isValid()){return m.localeData().invalidDate()}format=expandFormat(format,m.localeData());formatFunctions[format]=formatFunctions[format]||makeFormatFunction(format);return formatFunctions[format](m)}function expandFormat(format,locale){var i=5;function replaceLongDateFormatTokens(input){return locale.longDateFormat(input)||input}localFormattingTokens.lastIndex=0;while(i>=0&&localFormattingTokens.test(format)){format=format.replace(localFormattingTokens,replaceLongDateFormatTokens);localFormattingTokens.lastIndex=0;i-=1}return format}var match1=/\\d/;var match2=/\\d\\d/;var match3=/\\d{3}/;var match4=/\\d{4}/;var match6=/[+-]?\\d{6}/;var match1to2=/\\d\\d?/;var match3to4=/\\d\\d\\d\\d?/;var match5to6=/\\d\\d\\d\\d\\d\\d?/;var match1to3=/\\d{1,3}/;var match1to4=/\\d{1,4}/;var match1to6=/[+-]?\\d{1,6}/;var matchUnsigned=/\\d+/;var matchSigned=/[+-]?\\d+/;var matchOffset=/Z|[+-]\\d\\d:?\\d\\d/gi;var matchShortOffset=/Z|[+-]\\d\\d(?::?\\d\\d)?/gi;var matchTimestamp=/[+-]?\\d+(\\.\\d{1,3})?/;var matchWord=/[0-9]*['a-z\\u00A0-\\u05FF\\u0700-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF]+|[\\u0600-\\u06FF\\/]+(\\s*?[\\u0600-\\u06FF]+){1,2}/i;var regexes={};function addRegexToken(token,regex,strictRegex){regexes[token]=isFunction(regex)?regex:function(isStrict,localeData){return isStrict&&strictRegex?strictRegex:regex}}function getParseRegexForToken(token,config){if(!hasOwnProp(regexes,token)){return new RegExp(unescapeFormat(token))}return regexes[token](config._strict,config._locale)}function unescapeFormat(s){return regexEscape(s.replace(\"\\\\\",\"\").replace(/\\\\(\\[)|\\\\(\\])|\\[([^\\]\\[]*)\\]|\\\\(.)/g,function(matched,p1,p2,p3,p4){return p1||p2||p3||p4}))}function regexEscape(s){return s.replace(/[-\\/\\\\^$*+?.()|[\\]{}]/g,\"\\\\$&\")}var tokens={};function addParseToken(token,callback){var i,func=callback;if(typeof token===\"string\"){token=[token]}if(isNumber(callback)){func=function(input,array){array[callback]=toInt(input)}}for(i=0;i<token.length;i++){tokens[token[i]]=func}}function addWeekParseToken(token,callback){addParseToken(token,function(input,array,config,token){config._w=config._w||{};callback(input,config._w,config,token)})}function addTimeToArrayFromToken(token,input,config){if(input!=null&&hasOwnProp(tokens,token)){tokens[token](input,config._a,config,token)}}var YEAR=0;var MONTH=1;var DATE=2;var HOUR=3;var MINUTE=4;var SECOND=5;var MILLISECOND=6;var WEEK=7;var WEEKDAY=8;addFormatToken(\"Y\",0,0,function(){var y=this.year();return y<=9999?\"\"+y:\"+\"+y});addFormatToken(0,[\"YY\",2],0,function(){return this.year()%100});addFormatToken(0,[\"YYYY\",4],0,\"year\");addFormatToken(0,[\"YYYYY\",5],0,\"year\");addFormatToken(0,[\"YYYYYY\",6,true],0,\"year\");addUnitAlias(\"year\",\"y\");addUnitPriority(\"year\",1);addRegexToken(\"Y\",matchSigned)\n;addRegexToken(\"YY\",match1to2,match2);addRegexToken(\"YYYY\",match1to4,match4);addRegexToken(\"YYYYY\",match1to6,match6);addRegexToken(\"YYYYYY\",match1to6,match6);addParseToken([\"YYYYY\",\"YYYYYY\"],YEAR);addParseToken(\"YYYY\",function(input,array){array[YEAR]=input.length===2?hooks.parseTwoDigitYear(input):toInt(input)});addParseToken(\"YY\",function(input,array){array[YEAR]=hooks.parseTwoDigitYear(input)});addParseToken(\"Y\",function(input,array){array[YEAR]=parseInt(input,10)});function daysInYear(year){return isLeapYear(year)?366:365}function isLeapYear(year){return year%4===0&&year%100!==0||year%400===0}hooks.parseTwoDigitYear=function(input){return toInt(input)+(toInt(input)>68?1900:2e3)};var getSetYear=makeGetSet(\"FullYear\",true);function getIsLeapYear(){return isLeapYear(this.year())}function makeGetSet(unit,keepTime){return function(value){if(value!=null){set$1(this,unit,value);hooks.updateOffset(this,keepTime);return this}else{return get(this,unit)}}}function get(mom,unit){return mom.isValid()?mom._d[\"get\"+(mom._isUTC?\"UTC\":\"\")+unit]():NaN}function set$1(mom,unit,value){if(mom.isValid()&&!isNaN(value)){if(unit===\"FullYear\"&&isLeapYear(mom.year())){mom._d[\"set\"+(mom._isUTC?\"UTC\":\"\")+unit](value,mom.month(),daysInMonth(value,mom.month()))}else{mom._d[\"set\"+(mom._isUTC?\"UTC\":\"\")+unit](value)}}}function stringGet(units){units=normalizeUnits(units);if(isFunction(this[units])){return this[units]()}return this}function stringSet(units,value){if(typeof units===\"object\"){units=normalizeObjectUnits(units);var prioritized=getPrioritizedUnits(units);for(var i=0;i<prioritized.length;i++){this[prioritized[i].unit](units[prioritized[i].unit])}}else{units=normalizeUnits(units);if(isFunction(this[units])){return this[units](value)}}return this}function mod(n,x){return(n%x+x)%x}var indexOf;if(Array.prototype.indexOf){indexOf=Array.prototype.indexOf}else{indexOf=function(o){var i;for(i=0;i<this.length;++i){if(this[i]===o){return i}}return-1}}function daysInMonth(year,month){if(isNaN(year)||isNaN(month)){return NaN}var modMonth=mod(month,12);year+=(month-modMonth)/12;return modMonth===1?isLeapYear(year)?29:28:31-modMonth%7%2}addFormatToken(\"M\",[\"MM\",2],\"Mo\",function(){return this.month()+1});addFormatToken(\"MMM\",0,0,function(format){return this.localeData().monthsShort(this,format)});addFormatToken(\"MMMM\",0,0,function(format){return this.localeData().months(this,format)});addUnitAlias(\"month\",\"M\");addUnitPriority(\"month\",8);addRegexToken(\"M\",match1to2);addRegexToken(\"MM\",match1to2,match2);addRegexToken(\"MMM\",function(isStrict,locale){return locale.monthsShortRegex(isStrict)});addRegexToken(\"MMMM\",function(isStrict,locale){return locale.monthsRegex(isStrict)});addParseToken([\"M\",\"MM\"],function(input,array){array[MONTH]=toInt(input)-1});addParseToken([\"MMM\",\"MMMM\"],function(input,array,config,token){var month=config._locale.monthsParse(input,token,config._strict);if(month!=null){array[MONTH]=month}else{getParsingFlags(config).invalidMonth=input}});var MONTHS_IN_FORMAT=/D[oD]?(\\[[^\\[\\]]*\\]|\\s)+MMMM?/;var defaultLocaleMonths=\"January_February_March_April_May_June_July_August_September_October_November_December\".split(\"_\");function localeMonths(m,format){if(!m){return isArray(this._months)?this._months:this._months[\"standalone\"]}return isArray(this._months)?this._months[m.month()]:this._months[(this._months.isFormat||MONTHS_IN_FORMAT).test(format)?\"format\":\"standalone\"][m.month()]}var defaultLocaleMonthsShort=\"Jan_Feb_Mar_Apr_May_Jun_Jul_Aug_Sep_Oct_Nov_Dec\".split(\"_\");function localeMonthsShort(m,format){if(!m){return isArray(this._monthsShort)?this._monthsShort:this._monthsShort[\"standalone\"]}return isArray(this._monthsShort)?this._monthsShort[m.month()]:this._monthsShort[MONTHS_IN_FORMAT.test(format)?\"format\":\"standalone\"][m.month()]}function handleStrictParse(monthName,format,strict){var i,ii,mom,llc=monthName.toLocaleLowerCase();if(!this._monthsParse){this._monthsParse=[];this._longMonthsParse=[];this._shortMonthsParse=[];for(i=0;i<12;++i){mom=createUTC([2e3,i]);this._shortMonthsParse[i]=this.monthsShort(mom,\"\").toLocaleLowerCase();this._longMonthsParse[i]=this.months(mom,\"\").toLocaleLowerCase()}}if(strict){if(format===\"MMM\"){ii=indexOf.call(this._shortMonthsParse,llc);return ii!==-1?ii:null}else{ii=indexOf.call(this._longMonthsParse,llc);return ii!==-1?ii:null}}else{if(format===\"MMM\"){ii=indexOf.call(this._shortMonthsParse,llc);if(ii!==-1){return ii}ii=indexOf.call(this._longMonthsParse,llc);return ii!==-1?ii:null}else{ii=indexOf.call(this._longMonthsParse,llc);if(ii!==-1){return ii}ii=indexOf.call(this._shortMonthsParse,llc);return ii!==-1?ii:null}}}function localeMonthsParse(monthName,format,strict){var i,mom,regex;if(this._monthsParseExact){return handleStrictParse.call(this,monthName,format,strict)}if(!this._monthsParse){this._monthsParse=[];this._longMonthsParse=[];this._shortMonthsParse=[]}for(i=0;i<12;i++){mom=createUTC([2e3,i]);if(strict&&!this._longMonthsParse[i]){this._longMonthsParse[i]=new RegExp(\"^\"+this.months(mom,\"\").replace(\".\",\"\")+\"$\",\"i\");this._shortMonthsParse[i]=new RegExp(\"^\"+this.monthsShort(mom,\"\").replace(\".\",\"\")+\"$\",\"i\")}if(!strict&&!this._monthsParse[i]){regex=\"^\"+this.months(mom,\"\")+\"|^\"+this.monthsShort(mom,\"\");this._monthsParse[i]=new RegExp(regex.replace(\".\",\"\"),\"i\")}if(strict&&format===\"MMMM\"&&this._longMonthsParse[i].test(monthName)){return i}else if(strict&&format===\"MMM\"&&this._shortMonthsParse[i].test(monthName)){return i}else if(!strict&&this._monthsParse[i].test(monthName)){return i}}}function setMonth(mom,value){var dayOfMonth;if(!mom.isValid()){return mom}if(typeof value===\"string\"){if(/^\\d+$/.test(value)){value=toInt(value)}else{value=mom.localeData().monthsParse(value);if(!isNumber(value)){return mom}}}dayOfMonth=Math.min(mom.date(),daysInMonth(mom.year(),value));mom._d[\"set\"+(mom._isUTC?\"UTC\":\"\")+\"Month\"](value,dayOfMonth);return mom}function getSetMonth(value){if(value!=null){setMonth(this,value);hooks.updateOffset(this,true);return this}else{return get(this,\"Month\")}}function getDaysInMonth(){return daysInMonth(this.year(),this.month())}var defaultMonthsShortRegex=matchWord;function monthsShortRegex(isStrict){if(this._monthsParseExact){if(!hasOwnProp(this,\"_monthsRegex\")){computeMonthsParse.call(this)}if(isStrict){return this._monthsShortStrictRegex}else{return this._monthsShortRegex}}else{if(!hasOwnProp(this,\"_monthsShortRegex\")){this._monthsShortRegex=defaultMonthsShortRegex}return this._monthsShortStrictRegex&&isStrict?this._monthsShortStrictRegex:this._monthsShortRegex}}var defaultMonthsRegex=matchWord;function monthsRegex(isStrict){if(this._monthsParseExact){if(!hasOwnProp(this,\"_monthsRegex\")){computeMonthsParse.call(this)}if(isStrict){return this._monthsStrictRegex}else{return this._monthsRegex}}else{if(!hasOwnProp(this,\"_monthsRegex\")){this._monthsRegex=defaultMonthsRegex}return this._monthsStrictRegex&&isStrict?this._monthsStrictRegex:this._monthsRegex}}function computeMonthsParse(){function cmpLenRev(a,b){return b.length-a.length}var shortPieces=[],longPieces=[],mixedPieces=[],i,mom;for(i=0;i<12;i++){mom=createUTC([2e3,i]);shortPieces.push(this.monthsShort(mom,\"\"));longPieces.push(this.months(mom,\"\"));mixedPieces.push(this.months(mom,\"\"));mixedPieces.push(this.monthsShort(mom,\"\"))}shortPieces.sort(cmpLenRev);longPieces.sort(cmpLenRev);mixedPieces.sort(cmpLenRev);for(i=0;i<12;i++){shortPieces[i]=regexEscape(shortPieces[i]);longPieces[i]=regexEscape(longPieces[i])}for(i=0;i<24;i++){mixedPieces[i]=regexEscape(mixedPieces[i])}this._monthsRegex=new RegExp(\"^(\"+mixedPieces.join(\"|\")+\")\",\"i\");this._monthsShortRegex=this._monthsRegex;this._monthsStrictRegex=new RegExp(\"^(\"+longPieces.join(\"|\")+\")\",\"i\");this._monthsShortStrictRegex=new RegExp(\"^(\"+shortPieces.join(\"|\")+\")\",\"i\")}function createDate(y,m,d,h,M,s,ms){var date=new Date(y,m,d,h,M,s,ms);if(y<100&&y>=0&&isFinite(date.getFullYear())){date.setFullYear(y)}return date}function createUTCDate(y){var date=new Date(Date.UTC.apply(null,arguments));if(y<100&&y>=0&&isFinite(date.getUTCFullYear())){date.setUTCFullYear(y)}return date}function firstWeekOffset(year,dow,doy){var fwd=7+dow-doy,fwdlw=(7+createUTCDate(year,0,fwd).getUTCDay()-dow)%7;return-fwdlw+fwd-1}function dayOfYearFromWeeks(year,week,weekday,dow,doy){var localWeekday=(7+weekday-dow)%7,weekOffset=firstWeekOffset(year,dow,doy),dayOfYear=1+7*(week-1)+localWeekday+weekOffset,resYear,resDayOfYear;if(dayOfYear<=0){resYear=year-1;resDayOfYear=daysInYear(resYear)+dayOfYear}else if(dayOfYear>daysInYear(year)){resYear=year+1;resDayOfYear=dayOfYear-daysInYear(year)}else{resYear=year;resDayOfYear=dayOfYear}return{year:resYear,dayOfYear:resDayOfYear}}function weekOfYear(mom,dow,doy){var weekOffset=firstWeekOffset(mom.year(),dow,doy),week=Math.floor((mom.dayOfYear()-weekOffset-1)/7)+1,resWeek,resYear;if(week<1){resYear=mom.year()-1;resWeek=week+weeksInYear(resYear,dow,doy)}else if(week>weeksInYear(mom.year(),dow,doy)){resWeek=week-weeksInYear(mom.year(),dow,doy);resYear=mom.year()+1}else{resYear=mom.year();resWeek=week}return{week:resWeek,year:resYear}}function weeksInYear(year,dow,doy){var weekOffset=firstWeekOffset(year,dow,doy),weekOffsetNext=firstWeekOffset(year+1,dow,doy);return(daysInYear(year)-weekOffset+weekOffsetNext)/7}addFormatToken(\"w\",[\"ww\",2],\"wo\",\"week\");addFormatToken(\"W\",[\"WW\",2],\"Wo\",\"isoWeek\");addUnitAlias(\"week\",\"w\");addUnitAlias(\"isoWeek\",\"W\");addUnitPriority(\"week\",5);addUnitPriority(\"isoWeek\",5);addRegexToken(\"w\",match1to2);addRegexToken(\"ww\",match1to2,match2);addRegexToken(\"W\",match1to2);addRegexToken(\"WW\",match1to2,match2);addWeekParseToken([\"w\",\"ww\",\"W\",\"WW\"],function(input,week,config,token){week[token.substr(0,1)]=toInt(input)});function localeWeek(mom){return weekOfYear(mom,this._week.dow,this._week.doy).week}var defaultLocaleWeek={dow:0,doy:6};function localeFirstDayOfWeek(){return this._week.dow}function localeFirstDayOfYear(){return this._week.doy}function getSetWeek(input){var week=this.localeData().week(this);return input==null?week:this.add((input-week)*7,\"d\")}function getSetISOWeek(input){var week=weekOfYear(this,1,4).week;return input==null?week:this.add((input-week)*7,\"d\")}addFormatToken(\"d\",0,\"do\",\"day\");addFormatToken(\"dd\",0,0,function(format){return this.localeData().weekdaysMin(this,format)});addFormatToken(\"ddd\",0,0,function(format){return this.localeData().weekdaysShort(this,format)});addFormatToken(\"dddd\",0,0,function(format){return this.localeData().weekdays(this,format)});addFormatToken(\"e\",0,0,\"weekday\");addFormatToken(\"E\",0,0,\"isoWeekday\");addUnitAlias(\"day\",\"d\");addUnitAlias(\"weekday\",\"e\");addUnitAlias(\"isoWeekday\",\"E\");addUnitPriority(\"day\",11);addUnitPriority(\"weekday\",11);addUnitPriority(\"isoWeekday\",11);addRegexToken(\"d\",match1to2);addRegexToken(\"e\",match1to2);addRegexToken(\"E\",match1to2);addRegexToken(\"dd\",function(isStrict,locale){return locale.weekdaysMinRegex(isStrict)});addRegexToken(\"ddd\",function(isStrict,locale){return locale.weekdaysShortRegex(isStrict)});addRegexToken(\"dddd\",function(isStrict,locale){return locale.weekdaysRegex(isStrict)});addWeekParseToken([\"dd\",\"ddd\",\"dddd\"],function(input,week,config,token){var weekday=config._locale.weekdaysParse(input,token,config._strict);if(weekday!=null){week.d=weekday}else{getParsingFlags(config).invalidWeekday=input}});addWeekParseToken([\"d\",\"e\",\"E\"],function(input,week,config,token){week[token]=toInt(input)});function parseWeekday(input,locale){if(typeof input!==\"string\"){return input}if(!isNaN(input)){return parseInt(input,10)}input=locale.weekdaysParse(input);if(typeof input===\"number\"){return input}return null}function parseIsoWeekday(input,locale){if(typeof input===\"string\"){return locale.weekdaysParse(input)%7||7}return isNaN(input)?null:input}var defaultLocaleWeekdays=\"Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday\".split(\"_\");function localeWeekdays(m,format){if(!m){return isArray(this._weekdays)?this._weekdays:this._weekdays[\"standalone\"]}return isArray(this._weekdays)?this._weekdays[m.day()]:this._weekdays[this._weekdays.isFormat.test(format)?\"format\":\"standalone\"][m.day()]}var defaultLocaleWeekdaysShort=\"Sun_Mon_Tue_Wed_Thu_Fri_Sat\".split(\"_\");function localeWeekdaysShort(m){return m?this._weekdaysShort[m.day()]:this._weekdaysShort}var defaultLocaleWeekdaysMin=\"Su_Mo_Tu_We_Th_Fr_Sa\".split(\"_\");function localeWeekdaysMin(m){return m?this._weekdaysMin[m.day()]:this._weekdaysMin}function handleStrictParse$1(weekdayName,format,strict){var i,ii,mom,llc=weekdayName.toLocaleLowerCase();if(!this._weekdaysParse){this._weekdaysParse=[];this._shortWeekdaysParse=[];this._minWeekdaysParse=[];for(i=0;i<7;++i){mom=createUTC([2e3,1]).day(i);this._minWeekdaysParse[i]=this.weekdaysMin(mom,\"\").toLocaleLowerCase();this._shortWeekdaysParse[i]=this.weekdaysShort(mom,\"\").toLocaleLowerCase();this._weekdaysParse[i]=this.weekdays(mom,\"\").toLocaleLowerCase()}}if(strict){if(format===\"dddd\"){ii=indexOf.call(this._weekdaysParse,llc);return ii!==-1?ii:null}else if(format===\"ddd\"){ii=indexOf.call(this._shortWeekdaysParse,llc);return ii!==-1?ii:null}else{ii=indexOf.call(this._minWeekdaysParse,llc);return ii!==-1?ii:null}}else{if(format===\"dddd\"){ii=indexOf.call(this._weekdaysParse,llc);if(ii!==-1){return ii}ii=indexOf.call(this._shortWeekdaysParse,llc);if(ii!==-1){return ii}ii=indexOf.call(this._minWeekdaysParse,llc);return ii!==-1?ii:null}else if(format===\"ddd\"){ii=indexOf.call(this._shortWeekdaysParse,llc);if(ii!==-1){return ii}ii=indexOf.call(this._weekdaysParse,llc);if(ii!==-1){return ii}ii=indexOf.call(this._minWeekdaysParse,llc);return ii!==-1?ii:null}else{ii=indexOf.call(this._minWeekdaysParse,llc);if(ii!==-1){return ii}ii=indexOf.call(this._weekdaysParse,llc);if(ii!==-1){return ii}ii=indexOf.call(this._shortWeekdaysParse,llc);return ii!==-1?ii:null}}}function localeWeekdaysParse(weekdayName,format,strict){var i,mom,regex;if(this._weekdaysParseExact){return handleStrictParse$1.call(this,weekdayName,format,strict)}if(!this._weekdaysParse){this._weekdaysParse=[];this._minWeekdaysParse=[];this._shortWeekdaysParse=[];this._fullWeekdaysParse=[]}for(i=0;i<7;i++){mom=createUTC([2e3,1]).day(i);if(strict&&!this._fullWeekdaysParse[i]){this._fullWeekdaysParse[i]=new RegExp(\"^\"+this.weekdays(mom,\"\").replace(\".\",\".?\")+\"$\",\"i\");this._shortWeekdaysParse[i]=new RegExp(\"^\"+this.weekdaysShort(mom,\"\").replace(\".\",\".?\")+\"$\",\"i\");this._minWeekdaysParse[i]=new RegExp(\"^\"+this.weekdaysMin(mom,\"\").replace(\".\",\".?\")+\"$\",\"i\")}if(!this._weekdaysParse[i]){regex=\"^\"+this.weekdays(mom,\"\")+\"|^\"+this.weekdaysShort(mom,\"\")+\"|^\"+this.weekdaysMin(mom,\"\");this._weekdaysParse[i]=new RegExp(regex.replace(\".\",\"\"),\"i\")}if(strict&&format===\"dddd\"&&this._fullWeekdaysParse[i].test(weekdayName)){return i}else if(strict&&format===\"ddd\"&&this._shortWeekdaysParse[i].test(weekdayName)){return i}else if(strict&&format===\"dd\"&&this._minWeekdaysParse[i].test(weekdayName)){return i}else if(!strict&&this._weekdaysParse[i].test(weekdayName)){return i}}}function getSetDayOfWeek(input){if(!this.isValid()){return input!=null?this:NaN}var day=this._isUTC?this._d.getUTCDay():this._d.getDay();if(input!=null){input=parseWeekday(input,this.localeData());return this.add(input-day,\"d\")}else{return day}}function getSetLocaleDayOfWeek(input){if(!this.isValid()){return input!=null?this:NaN}var weekday=(this.day()+7-this.localeData()._week.dow)%7;return input==null?weekday:this.add(input-weekday,\"d\")}function getSetISODayOfWeek(input){if(!this.isValid()){return input!=null?this:NaN}if(input!=null){var weekday=parseIsoWeekday(input,this.localeData());return this.day(this.day()%7?weekday:weekday-7)}else{return this.day()||7}}var defaultWeekdaysRegex=matchWord;function weekdaysRegex(isStrict){if(this._weekdaysParseExact){if(!hasOwnProp(this,\"_weekdaysRegex\")){computeWeekdaysParse.call(this)}if(isStrict){return this._weekdaysStrictRegex}else{return this._weekdaysRegex}}else{if(!hasOwnProp(this,\"_weekdaysRegex\")){this._weekdaysRegex=defaultWeekdaysRegex}return this._weekdaysStrictRegex&&isStrict?this._weekdaysStrictRegex:this._weekdaysRegex}}var defaultWeekdaysShortRegex=matchWord;function weekdaysShortRegex(isStrict){if(this._weekdaysParseExact){if(!hasOwnProp(this,\"_weekdaysRegex\")){computeWeekdaysParse.call(this)}if(isStrict){return this._weekdaysShortStrictRegex}else{return this._weekdaysShortRegex}}else{if(!hasOwnProp(this,\"_weekdaysShortRegex\")){this._weekdaysShortRegex=defaultWeekdaysShortRegex}return this._weekdaysShortStrictRegex&&isStrict?this._weekdaysShortStrictRegex:this._weekdaysShortRegex}}var defaultWeekdaysMinRegex=matchWord;function weekdaysMinRegex(isStrict){if(this._weekdaysParseExact){if(!hasOwnProp(this,\"_weekdaysRegex\")){computeWeekdaysParse.call(this)}if(isStrict){return this._weekdaysMinStrictRegex}else{return this._weekdaysMinRegex}}else{if(!hasOwnProp(this,\"_weekdaysMinRegex\")){this._weekdaysMinRegex=defaultWeekdaysMinRegex}return this._weekdaysMinStrictRegex&&isStrict?this._weekdaysMinStrictRegex:this._weekdaysMinRegex}}function computeWeekdaysParse(){function cmpLenRev(a,b){return b.length-a.length}var minPieces=[],shortPieces=[],longPieces=[],mixedPieces=[],i,mom,minp,shortp,longp;for(i=0;i<7;i++){mom=createUTC([2e3,1]).day(i);minp=this.weekdaysMin(mom,\"\");shortp=this.weekdaysShort(mom,\"\");longp=this.weekdays(mom,\"\");minPieces.push(minp);shortPieces.push(shortp);longPieces.push(longp);mixedPieces.push(minp);mixedPieces.push(shortp);mixedPieces.push(longp)}minPieces.sort(cmpLenRev);shortPieces.sort(cmpLenRev);longPieces.sort(cmpLenRev);mixedPieces.sort(cmpLenRev);for(i=0;i<7;i++){shortPieces[i]=regexEscape(shortPieces[i]);longPieces[i]=regexEscape(longPieces[i]);mixedPieces[i]=regexEscape(mixedPieces[i])}this._weekdaysRegex=new RegExp(\"^(\"+mixedPieces.join(\"|\")+\")\",\"i\");this._weekdaysShortRegex=this._weekdaysRegex;this._weekdaysMinRegex=this._weekdaysRegex;this._weekdaysStrictRegex=new RegExp(\"^(\"+longPieces.join(\"|\")+\")\",\"i\");this._weekdaysShortStrictRegex=new RegExp(\"^(\"+shortPieces.join(\"|\")+\")\",\"i\");this._weekdaysMinStrictRegex=new RegExp(\"^(\"+minPieces.join(\"|\")+\")\",\"i\")}function hFormat(){return this.hours()%12||12}function kFormat(){return this.hours()||24}addFormatToken(\"H\",[\"HH\",2],0,\"hour\");addFormatToken(\"h\",[\"hh\",2],0,hFormat);addFormatToken(\"k\",[\"kk\",2],0,kFormat);addFormatToken(\"hmm\",0,0,function(){return\"\"+hFormat.apply(this)+zeroFill(this.minutes(),2)});addFormatToken(\"hmmss\",0,0,function(){return\"\"+hFormat.apply(this)+zeroFill(this.minutes(),2)+zeroFill(this.seconds(),2)});addFormatToken(\"Hmm\",0,0,function(){return\"\"+this.hours()+zeroFill(this.minutes(),2)});addFormatToken(\"Hmmss\",0,0,function(){return\"\"+this.hours()+zeroFill(this.minutes(),2)+zeroFill(this.seconds(),2)});function meridiem(token,lowercase){addFormatToken(token,0,0,function(){return this.localeData().meridiem(this.hours(),this.minutes(),lowercase)})}meridiem(\"a\",true);meridiem(\"A\",false);addUnitAlias(\"hour\",\"h\");addUnitPriority(\"hour\",13);function matchMeridiem(isStrict,locale){return locale._meridiemParse}addRegexToken(\"a\",matchMeridiem);addRegexToken(\"A\",matchMeridiem);addRegexToken(\"H\",match1to2);addRegexToken(\"h\",match1to2);addRegexToken(\"k\",match1to2);addRegexToken(\"HH\",match1to2,match2);addRegexToken(\"hh\",match1to2,match2);addRegexToken(\"kk\",match1to2,match2);addRegexToken(\"hmm\",match3to4);addRegexToken(\"hmmss\",match5to6);addRegexToken(\"Hmm\",match3to4);addRegexToken(\"Hmmss\",match5to6);addParseToken([\"H\",\"HH\"],HOUR);addParseToken([\"k\",\"kk\"],function(input,array,config){var kInput=toInt(input);array[HOUR]=kInput===24?0:kInput});addParseToken([\"a\",\"A\"],function(input,array,config){config._isPm=config._locale.isPM(input);config._meridiem=input});addParseToken([\"h\",\"hh\"],function(input,array,config){array[HOUR]=toInt(input);getParsingFlags(config).bigHour=true});addParseToken(\"hmm\",function(input,array,config){var pos=input.length-2;array[HOUR]=toInt(input.substr(0,pos));array[MINUTE]=toInt(input.substr(pos));getParsingFlags(config).bigHour=true});addParseToken(\"hmmss\",function(input,array,config){var pos1=input.length-4;var pos2=input.length-2;array[HOUR]=toInt(input.substr(0,pos1));array[MINUTE]=toInt(input.substr(pos1,2));array[SECOND]=toInt(input.substr(pos2));getParsingFlags(config).bigHour=true});addParseToken(\"Hmm\",function(input,array,config){var pos=input.length-2;array[HOUR]=toInt(input.substr(0,pos));array[MINUTE]=toInt(input.substr(pos))});addParseToken(\"Hmmss\",function(input,array,config){var pos1=input.length-4;var pos2=input.length-2;array[HOUR]=toInt(input.substr(0,pos1));array[MINUTE]=toInt(input.substr(pos1,2));array[SECOND]=toInt(input.substr(pos2))});function localeIsPM(input){return(input+\"\").toLowerCase().charAt(0)===\"p\"}var defaultLocaleMeridiemParse=/[ap]\\.?m?\\.?/i;function localeMeridiem(hours,minutes,isLower){if(hours>11){return isLower?\"pm\":\"PM\"}else{return isLower?\"am\":\"AM\"}}var getSetHour=makeGetSet(\"Hours\",true);var baseConfig={calendar:defaultCalendar,longDateFormat:defaultLongDateFormat,invalidDate:defaultInvalidDate,ordinal:defaultOrdinal,dayOfMonthOrdinalParse:defaultDayOfMonthOrdinalParse,relativeTime:defaultRelativeTime,months:defaultLocaleMonths,monthsShort:defaultLocaleMonthsShort,week:defaultLocaleWeek,weekdays:defaultLocaleWeekdays,weekdaysMin:defaultLocaleWeekdaysMin,weekdaysShort:defaultLocaleWeekdaysShort,meridiemParse:defaultLocaleMeridiemParse};var locales={};var localeFamilies={};var globalLocale;function normalizeLocale(key){return key?key.toLowerCase().replace(\"_\",\"-\"):key}function chooseLocale(names){var i=0,j,next,locale,split;while(i<names.length){split=normalizeLocale(names[i]).split(\"-\");j=split.length;next=normalizeLocale(names[i+1]);next=next?next.split(\"-\"):null;while(j>0){locale=loadLocale(split.slice(0,j).join(\"-\"));if(locale){return locale}if(next&&next.length>=j&&compareArrays(split,next,true)>=j-1){break}j--}i++}return null}function loadLocale(name){var oldLocale=null;if(!locales[name]&&typeof module!==\"undefined\"&&module&&module.exports){try{oldLocale=globalLocale._abbr;var aliasedRequire=require;!function webpackMissingModule(){var e=new Error('Cannot find module \"./locale\"');e.code=\"MODULE_NOT_FOUND\";throw e}();getSetGlobalLocale(oldLocale)}catch(e){}}return locales[name]}function getSetGlobalLocale(key,values){var data;if(key){if(isUndefined(values)){data=getLocale(key)}else{data=defineLocale(key,values)}if(data){globalLocale=data}}return globalLocale._abbr}function defineLocale(name,config){if(config!==null){var parentConfig=baseConfig;config.abbr=name;if(locales[name]!=null){deprecateSimple(\"defineLocaleOverride\",\"use moment.updateLocale(localeName, config) to change \"+\"an existing locale. moment.defineLocale(localeName, \"+\"config) should only be used for creating a new locale \"+\"See http://momentjs.com/guides/#/warnings/define-locale/ for more info.\");parentConfig=locales[name]._config}else if(config.parentLocale!=null){if(locales[config.parentLocale]!=null){parentConfig=locales[config.parentLocale]._config}else{if(!localeFamilies[config.parentLocale]){localeFamilies[config.parentLocale]=[]}localeFamilies[config.parentLocale].push({name:name,config:config});return null}}locales[name]=new Locale(mergeConfigs(parentConfig,config));if(localeFamilies[name]){localeFamilies[name].forEach(function(x){defineLocale(x.name,x.config)})}getSetGlobalLocale(name);return locales[name]}else{delete locales[name];return null}}function updateLocale(name,config){if(config!=null){var locale,parentConfig=baseConfig;if(locales[name]!=null){parentConfig=locales[name]._config}config=mergeConfigs(parentConfig,config);locale=new Locale(config);locale.parentLocale=locales[name];locales[name]=locale;getSetGlobalLocale(name)}else{if(locales[name]!=null){if(locales[name].parentLocale!=null){locales[name]=locales[name].parentLocale}else if(locales[name]!=null){delete locales[name]}}}return locales[name]}function getLocale(key){var locale;if(key&&key._locale&&key._locale._abbr){key=key._locale._abbr}if(!key){return globalLocale}if(!isArray(key)){locale=loadLocale(key);if(locale){return locale}key=[key]}return chooseLocale(key)}function listLocales(){return keys(locales)}function checkOverflow(m){var overflow;var a=m._a;if(a&&getParsingFlags(m).overflow===-2){overflow=a[MONTH]<0||a[MONTH]>11?MONTH:a[DATE]<1||a[DATE]>daysInMonth(a[YEAR],a[MONTH])?DATE:a[HOUR]<0||a[HOUR]>24||a[HOUR]===24&&(a[MINUTE]!==0||a[SECOND]!==0||a[MILLISECOND]!==0)?HOUR:a[MINUTE]<0||a[MINUTE]>59?MINUTE:a[SECOND]<0||a[SECOND]>59?SECOND:a[MILLISECOND]<0||a[MILLISECOND]>999?MILLISECOND:-1;if(getParsingFlags(m)._overflowDayOfYear&&(overflow<YEAR||overflow>DATE)){overflow=DATE}if(getParsingFlags(m)._overflowWeeks&&overflow===-1){overflow=WEEK}if(getParsingFlags(m)._overflowWeekday&&overflow===-1){overflow=WEEKDAY}getParsingFlags(m).overflow=overflow}return m}function defaults(a,b,c){if(a!=null){return a}if(b!=null){return b}return c}function currentDateArray(config){var nowValue=new Date(hooks.now());if(config._useUTC){return[nowValue.getUTCFullYear(),nowValue.getUTCMonth(),nowValue.getUTCDate()]}return[nowValue.getFullYear(),nowValue.getMonth(),nowValue.getDate()]}function configFromArray(config){var i,date,input=[],currentDate,yearToUse;if(config._d){return}currentDate=currentDateArray(config);if(config._w&&config._a[DATE]==null&&config._a[MONTH]==null){dayOfYearFromWeekInfo(config)}if(config._dayOfYear!=null){yearToUse=defaults(config._a[YEAR],currentDate[YEAR]);if(config._dayOfYear>daysInYear(yearToUse)||config._dayOfYear===0){getParsingFlags(config)._overflowDayOfYear=true}date=createUTCDate(yearToUse,0,config._dayOfYear);config._a[MONTH]=date.getUTCMonth();config._a[DATE]=date.getUTCDate()}for(i=0;i<3&&config._a[i]==null;++i){config._a[i]=input[i]=currentDate[i]}for(;i<7;i++){config._a[i]=input[i]=config._a[i]==null?i===2?1:0:config._a[i]}if(config._a[HOUR]===24&&config._a[MINUTE]===0&&config._a[SECOND]===0&&config._a[MILLISECOND]===0){config._nextDay=true;config._a[HOUR]=0}config._d=(config._useUTC?createUTCDate:createDate).apply(null,input);if(config._tzm!=null){config._d.setUTCMinutes(config._d.getUTCMinutes()-config._tzm)}if(config._nextDay){config._a[HOUR]=24}if(config._w&&typeof config._w.d!==\"undefined\"&&config._w.d!==config._d.getDay()){getParsingFlags(config).weekdayMismatch=true}}function dayOfYearFromWeekInfo(config){var w,weekYear,week,weekday,dow,doy,temp,weekdayOverflow;w=config._w;if(w.GG!=null||w.W!=null||w.E!=null){dow=1;doy=4;weekYear=defaults(w.GG,config._a[YEAR],weekOfYear(createLocal(),1,4).year);week=defaults(w.W,1);weekday=defaults(w.E,1);if(weekday<1||weekday>7){weekdayOverflow=true}}else{dow=config._locale._week.dow;doy=config._locale._week.doy;var curWeek=weekOfYear(createLocal(),dow,doy);weekYear=defaults(w.gg,config._a[YEAR],curWeek.year);week=defaults(w.w,curWeek.week);if(w.d!=null){weekday=w.d;if(weekday<0||weekday>6){weekdayOverflow=true}}else if(w.e!=null){weekday=w.e+dow;if(w.e<0||w.e>6){weekdayOverflow=true}}else{weekday=dow}}if(week<1||week>weeksInYear(weekYear,dow,doy)){getParsingFlags(config)._overflowWeeks=true}else if(weekdayOverflow!=null){getParsingFlags(config)._overflowWeekday=true}else{temp=dayOfYearFromWeeks(weekYear,week,weekday,dow,doy);config._a[YEAR]=temp.year;config._dayOfYear=temp.dayOfYear}}var extendedIsoRegex=/^\\s*((?:[+-]\\d{6}|\\d{4})-(?:\\d\\d-\\d\\d|W\\d\\d-\\d|W\\d\\d|\\d\\d\\d|\\d\\d))(?:(T| )(\\d\\d(?::\\d\\d(?::\\d\\d(?:[.,]\\d+)?)?)?)([\\+\\-]\\d\\d(?::?\\d\\d)?|\\s*Z)?)?$/;var basicIsoRegex=/^\\s*((?:[+-]\\d{6}|\\d{4})(?:\\d\\d\\d\\d|W\\d\\d\\d|W\\d\\d|\\d\\d\\d|\\d\\d))(?:(T| )(\\d\\d(?:\\d\\d(?:\\d\\d(?:[.,]\\d+)?)?)?)([\\+\\-]\\d\\d(?::?\\d\\d)?|\\s*Z)?)?$/;var tzRegex=/Z|[+-]\\d\\d(?::?\\d\\d)?/;var isoDates=[[\"YYYYYY-MM-DD\",/[+-]\\d{6}-\\d\\d-\\d\\d/],[\"YYYY-MM-DD\",/\\d{4}-\\d\\d-\\d\\d/],[\"GGGG-[W]WW-E\",/\\d{4}-W\\d\\d-\\d/],[\"GGGG-[W]WW\",/\\d{4}-W\\d\\d/,false],[\"YYYY-DDD\",/\\d{4}-\\d{3}/],[\"YYYY-MM\",/\\d{4}-\\d\\d/,false],[\"YYYYYYMMDD\",/[+-]\\d{10}/],[\"YYYYMMDD\",/\\d{8}/],[\"GGGG[W]WWE\",/\\d{4}W\\d{3}/],[\"GGGG[W]WW\",/\\d{4}W\\d{2}/,false],[\"YYYYDDD\",/\\d{7}/]];var isoTimes=[[\"HH:mm:ss.SSSS\",/\\d\\d:\\d\\d:\\d\\d\\.\\d+/],[\"HH:mm:ss,SSSS\",/\\d\\d:\\d\\d:\\d\\d,\\d+/],[\"HH:mm:ss\",/\\d\\d:\\d\\d:\\d\\d/],[\"HH:mm\",/\\d\\d:\\d\\d/],[\"HHmmss.SSSS\",/\\d\\d\\d\\d\\d\\d\\.\\d+/],[\"HHmmss,SSSS\",/\\d\\d\\d\\d\\d\\d,\\d+/],[\"HHmmss\",/\\d\\d\\d\\d\\d\\d/],[\"HHmm\",/\\d\\d\\d\\d/],[\"HH\",/\\d\\d/]];var aspNetJsonRegex=/^\\/?Date\\((\\-?\\d+)/i;function configFromISO(config){var i,l,string=config._i,match=extendedIsoRegex.exec(string)||basicIsoRegex.exec(string),allowTime,dateFormat,timeFormat,tzFormat;if(match){getParsingFlags(config).iso=true;for(i=0,l=isoDates.length;i<l;i++){if(isoDates[i][1].exec(match[1])){dateFormat=isoDates[i][0];allowTime=isoDates[i][2]!==false;break}}if(dateFormat==null){config._isValid=false;return}if(match[3]){for(i=0,l=isoTimes.length;i<l;i++){if(isoTimes[i][1].exec(match[3])){timeFormat=(match[2]||\" \")+isoTimes[i][0];break}}if(timeFormat==null){config._isValid=false;return}}if(!allowTime&&timeFormat!=null){config._isValid=false;return}if(match[4]){if(tzRegex.exec(match[4])){tzFormat=\"Z\"}else{config._isValid=false;return}}config._f=dateFormat+(timeFormat||\"\")+(tzFormat||\"\");configFromStringAndFormat(config)}else{config._isValid=false}}var rfc2822=/^(?:(Mon|Tue|Wed|Thu|Fri|Sat|Sun),?\\s)?(\\d{1,2})\\s(Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)\\s(\\d{2,4})\\s(\\d\\d):(\\d\\d)(?::(\\d\\d))?\\s(?:(UT|GMT|[ECMP][SD]T)|([Zz])|([+-]\\d{4}))$/;function extractFromRFC2822Strings(yearStr,monthStr,dayStr,hourStr,minuteStr,secondStr){var result=[untruncateYear(yearStr),defaultLocaleMonthsShort.indexOf(monthStr),parseInt(dayStr,10),parseInt(hourStr,10),parseInt(minuteStr,10)];if(secondStr){result.push(parseInt(secondStr,10))}return result}function untruncateYear(yearStr){var year=parseInt(yearStr,10);if(year<=49){return 2e3+year}else if(year<=999){return 1900+year}return year}function preprocessRFC2822(s){return s.replace(/\\([^)]*\\)|[\\n\\t]/g,\" \").replace(/(\\s\\s+)/g,\" \").trim()}function checkWeekday(weekdayStr,parsedInput,config){if(weekdayStr){var weekdayProvided=defaultLocaleWeekdaysShort.indexOf(weekdayStr),weekdayActual=new Date(parsedInput[0],parsedInput[1],parsedInput[2]).getDay();if(weekdayProvided!==weekdayActual){getParsingFlags(config).weekdayMismatch=true;config._isValid=false;return false}}return true}var obsOffsets={UT:0,GMT:0,EDT:-4*60,EST:-5*60,CDT:-5*60,CST:-6*60,MDT:-6*60,MST:-7*60,PDT:-7*60,PST:-8*60};function calculateOffset(obsOffset,militaryOffset,numOffset){if(obsOffset){return obsOffsets[obsOffset]}else if(militaryOffset){return 0}else{var hm=parseInt(numOffset,10);var m=hm%100,h=(hm-m)/100;return h*60+m}}function configFromRFC2822(config){var match=rfc2822.exec(preprocessRFC2822(config._i));if(match){var parsedArray=extractFromRFC2822Strings(match[4],match[3],match[2],match[5],match[6],match[7]);if(!checkWeekday(match[1],parsedArray,config)){return}config._a=parsedArray;config._tzm=calculateOffset(match[8],match[9],match[10]);config._d=createUTCDate.apply(null,config._a);config._d.setUTCMinutes(config._d.getUTCMinutes()-config._tzm);getParsingFlags(config).rfc2822=true}else{config._isValid=false}}function configFromString(config){var matched=aspNetJsonRegex.exec(config._i);if(matched!==null){config._d=new Date(+matched[1]);return}configFromISO(config);if(config._isValid===false){delete config._isValid}else{return}configFromRFC2822(config);if(config._isValid===false){delete config._isValid}else{return}hooks.createFromInputFallback(config)}hooks.createFromInputFallback=deprecate(\"value provided is not in a recognized RFC2822 or ISO format. moment construction falls back to js Date(), \"+\"which is not reliable across all browsers and versions. Non RFC2822/ISO date formats are \"+\"discouraged and will be removed in an upcoming major release. Please refer to \"+\"http://momentjs.com/guides/#/warnings/js-date/ for more info.\",function(config){config._d=new Date(config._i+(config._useUTC?\" UTC\":\"\"))});hooks.ISO_8601=function(){};hooks.RFC_2822=function(){};function configFromStringAndFormat(config){if(config._f===hooks.ISO_8601){configFromISO(config);return}if(config._f===hooks.RFC_2822){configFromRFC2822(config);return}config._a=[];getParsingFlags(config).empty=true\n;var string=\"\"+config._i,i,parsedInput,tokens,token,skipped,stringLength=string.length,totalParsedInputLength=0;tokens=expandFormat(config._f,config._locale).match(formattingTokens)||[];for(i=0;i<tokens.length;i++){token=tokens[i];parsedInput=(string.match(getParseRegexForToken(token,config))||[])[0];if(parsedInput){skipped=string.substr(0,string.indexOf(parsedInput));if(skipped.length>0){getParsingFlags(config).unusedInput.push(skipped)}string=string.slice(string.indexOf(parsedInput)+parsedInput.length);totalParsedInputLength+=parsedInput.length}if(formatTokenFunctions[token]){if(parsedInput){getParsingFlags(config).empty=false}else{getParsingFlags(config).unusedTokens.push(token)}addTimeToArrayFromToken(token,parsedInput,config)}else if(config._strict&&!parsedInput){getParsingFlags(config).unusedTokens.push(token)}}getParsingFlags(config).charsLeftOver=stringLength-totalParsedInputLength;if(string.length>0){getParsingFlags(config).unusedInput.push(string)}if(config._a[HOUR]<=12&&getParsingFlags(config).bigHour===true&&config._a[HOUR]>0){getParsingFlags(config).bigHour=undefined}getParsingFlags(config).parsedDateParts=config._a.slice(0);getParsingFlags(config).meridiem=config._meridiem;config._a[HOUR]=meridiemFixWrap(config._locale,config._a[HOUR],config._meridiem);configFromArray(config);checkOverflow(config)}function meridiemFixWrap(locale,hour,meridiem){var isPm;if(meridiem==null){return hour}if(locale.meridiemHour!=null){return locale.meridiemHour(hour,meridiem)}else if(locale.isPM!=null){isPm=locale.isPM(meridiem);if(isPm&&hour<12){hour+=12}if(!isPm&&hour===12){hour=0}return hour}else{return hour}}function configFromStringAndArray(config){var tempConfig,bestMoment,scoreToBeat,i,currentScore;if(config._f.length===0){getParsingFlags(config).invalidFormat=true;config._d=new Date(NaN);return}for(i=0;i<config._f.length;i++){currentScore=0;tempConfig=copyConfig({},config);if(config._useUTC!=null){tempConfig._useUTC=config._useUTC}tempConfig._f=config._f[i];configFromStringAndFormat(tempConfig);if(!isValid(tempConfig)){continue}currentScore+=getParsingFlags(tempConfig).charsLeftOver;currentScore+=getParsingFlags(tempConfig).unusedTokens.length*10;getParsingFlags(tempConfig).score=currentScore;if(scoreToBeat==null||currentScore<scoreToBeat){scoreToBeat=currentScore;bestMoment=tempConfig}}extend(config,bestMoment||tempConfig)}function configFromObject(config){if(config._d){return}var i=normalizeObjectUnits(config._i);config._a=map([i.year,i.month,i.day||i.date,i.hour,i.minute,i.second,i.millisecond],function(obj){return obj&&parseInt(obj,10)});configFromArray(config)}function createFromConfig(config){var res=new Moment(checkOverflow(prepareConfig(config)));if(res._nextDay){res.add(1,\"d\");res._nextDay=undefined}return res}function prepareConfig(config){var input=config._i,format=config._f;config._locale=config._locale||getLocale(config._l);if(input===null||format===undefined&&input===\"\"){return createInvalid({nullInput:true})}if(typeof input===\"string\"){config._i=input=config._locale.preparse(input)}if(isMoment(input)){return new Moment(checkOverflow(input))}else if(isDate(input)){config._d=input}else if(isArray(format)){configFromStringAndArray(config)}else if(format){configFromStringAndFormat(config)}else{configFromInput(config)}if(!isValid(config)){config._d=null}return config}function configFromInput(config){var input=config._i;if(isUndefined(input)){config._d=new Date(hooks.now())}else if(isDate(input)){config._d=new Date(input.valueOf())}else if(typeof input===\"string\"){configFromString(config)}else if(isArray(input)){config._a=map(input.slice(0),function(obj){return parseInt(obj,10)});configFromArray(config)}else if(isObject(input)){configFromObject(config)}else if(isNumber(input)){config._d=new Date(input)}else{hooks.createFromInputFallback(config)}}function createLocalOrUTC(input,format,locale,strict,isUTC){var c={};if(locale===true||locale===false){strict=locale;locale=undefined}if(isObject(input)&&isObjectEmpty(input)||isArray(input)&&input.length===0){input=undefined}c._isAMomentObject=true;c._useUTC=c._isUTC=isUTC;c._l=locale;c._i=input;c._f=format;c._strict=strict;return createFromConfig(c)}function createLocal(input,format,locale,strict){return createLocalOrUTC(input,format,locale,strict,false)}var prototypeMin=deprecate(\"moment().min is deprecated, use moment.max instead. http://momentjs.com/guides/#/warnings/min-max/\",function(){var other=createLocal.apply(null,arguments);if(this.isValid()&&other.isValid()){return other<this?this:other}else{return createInvalid()}});var prototypeMax=deprecate(\"moment().max is deprecated, use moment.min instead. http://momentjs.com/guides/#/warnings/min-max/\",function(){var other=createLocal.apply(null,arguments);if(this.isValid()&&other.isValid()){return other>this?this:other}else{return createInvalid()}});function pickBy(fn,moments){var res,i;if(moments.length===1&&isArray(moments[0])){moments=moments[0]}if(!moments.length){return createLocal()}res=moments[0];for(i=1;i<moments.length;++i){if(!moments[i].isValid()||moments[i][fn](res)){res=moments[i]}}return res}function min(){var args=[].slice.call(arguments,0);return pickBy(\"isBefore\",args)}function max(){var args=[].slice.call(arguments,0);return pickBy(\"isAfter\",args)}var now=function(){return Date.now?Date.now():+new Date};var ordering=[\"year\",\"quarter\",\"month\",\"week\",\"day\",\"hour\",\"minute\",\"second\",\"millisecond\"];function isDurationValid(m){for(var key in m){if(!(indexOf.call(ordering,key)!==-1&&(m[key]==null||!isNaN(m[key])))){return false}}var unitHasDecimal=false;for(var i=0;i<ordering.length;++i){if(m[ordering[i]]){if(unitHasDecimal){return false}if(parseFloat(m[ordering[i]])!==toInt(m[ordering[i]])){unitHasDecimal=true}}}return true}function isValid$1(){return this._isValid}function createInvalid$1(){return createDuration(NaN)}function Duration(duration){var normalizedInput=normalizeObjectUnits(duration),years=normalizedInput.year||0,quarters=normalizedInput.quarter||0,months=normalizedInput.month||0,weeks=normalizedInput.week||0,days=normalizedInput.day||0,hours=normalizedInput.hour||0,minutes=normalizedInput.minute||0,seconds=normalizedInput.second||0,milliseconds=normalizedInput.millisecond||0;this._isValid=isDurationValid(normalizedInput);this._milliseconds=+milliseconds+seconds*1e3+minutes*6e4+hours*1e3*60*60;this._days=+days+weeks*7;this._months=+months+quarters*3+years*12;this._data={};this._locale=getLocale();this._bubble()}function isDuration(obj){return obj instanceof Duration}function absRound(number){if(number<0){return Math.round(-1*number)*-1}else{return Math.round(number)}}function offset(token,separator){addFormatToken(token,0,0,function(){var offset=this.utcOffset();var sign=\"+\";if(offset<0){offset=-offset;sign=\"-\"}return sign+zeroFill(~~(offset/60),2)+separator+zeroFill(~~offset%60,2)})}offset(\"Z\",\":\");offset(\"ZZ\",\"\");addRegexToken(\"Z\",matchShortOffset);addRegexToken(\"ZZ\",matchShortOffset);addParseToken([\"Z\",\"ZZ\"],function(input,array,config){config._useUTC=true;config._tzm=offsetFromString(matchShortOffset,input)});var chunkOffset=/([\\+\\-]|\\d\\d)/gi;function offsetFromString(matcher,string){var matches=(string||\"\").match(matcher);if(matches===null){return null}var chunk=matches[matches.length-1]||[];var parts=(chunk+\"\").match(chunkOffset)||[\"-\",0,0];var minutes=+(parts[1]*60)+toInt(parts[2]);return minutes===0?0:parts[0]===\"+\"?minutes:-minutes}function cloneWithOffset(input,model){var res,diff;if(model._isUTC){res=model.clone();diff=(isMoment(input)||isDate(input)?input.valueOf():createLocal(input).valueOf())-res.valueOf();res._d.setTime(res._d.valueOf()+diff);hooks.updateOffset(res,false);return res}else{return createLocal(input).local()}}function getDateOffset(m){return-Math.round(m._d.getTimezoneOffset()/15)*15}hooks.updateOffset=function(){};function getSetOffset(input,keepLocalTime,keepMinutes){var offset=this._offset||0,localAdjust;if(!this.isValid()){return input!=null?this:NaN}if(input!=null){if(typeof input===\"string\"){input=offsetFromString(matchShortOffset,input);if(input===null){return this}}else if(Math.abs(input)<16&&!keepMinutes){input=input*60}if(!this._isUTC&&keepLocalTime){localAdjust=getDateOffset(this)}this._offset=input;this._isUTC=true;if(localAdjust!=null){this.add(localAdjust,\"m\")}if(offset!==input){if(!keepLocalTime||this._changeInProgress){addSubtract(this,createDuration(input-offset,\"m\"),1,false)}else if(!this._changeInProgress){this._changeInProgress=true;hooks.updateOffset(this,true);this._changeInProgress=null}}return this}else{return this._isUTC?offset:getDateOffset(this)}}function getSetZone(input,keepLocalTime){if(input!=null){if(typeof input!==\"string\"){input=-input}this.utcOffset(input,keepLocalTime);return this}else{return-this.utcOffset()}}function setOffsetToUTC(keepLocalTime){return this.utcOffset(0,keepLocalTime)}function setOffsetToLocal(keepLocalTime){if(this._isUTC){this.utcOffset(0,keepLocalTime);this._isUTC=false;if(keepLocalTime){this.subtract(getDateOffset(this),\"m\")}}return this}function setOffsetToParsedOffset(){if(this._tzm!=null){this.utcOffset(this._tzm,false,true)}else if(typeof this._i===\"string\"){var tZone=offsetFromString(matchOffset,this._i);if(tZone!=null){this.utcOffset(tZone)}else{this.utcOffset(0,true)}}return this}function hasAlignedHourOffset(input){if(!this.isValid()){return false}input=input?createLocal(input).utcOffset():0;return(this.utcOffset()-input)%60===0}function isDaylightSavingTime(){return this.utcOffset()>this.clone().month(0).utcOffset()||this.utcOffset()>this.clone().month(5).utcOffset()}function isDaylightSavingTimeShifted(){if(!isUndefined(this._isDSTShifted)){return this._isDSTShifted}var c={};copyConfig(c,this);c=prepareConfig(c);if(c._a){var other=c._isUTC?createUTC(c._a):createLocal(c._a);this._isDSTShifted=this.isValid()&&compareArrays(c._a,other.toArray())>0}else{this._isDSTShifted=false}return this._isDSTShifted}function isLocal(){return this.isValid()?!this._isUTC:false}function isUtcOffset(){return this.isValid()?this._isUTC:false}function isUtc(){return this.isValid()?this._isUTC&&this._offset===0:false}var aspNetRegex=/^(\\-|\\+)?(?:(\\d*)[. ])?(\\d+)\\:(\\d+)(?:\\:(\\d+)(\\.\\d*)?)?$/;var isoRegex=/^(-|\\+)?P(?:([-+]?[0-9,.]*)Y)?(?:([-+]?[0-9,.]*)M)?(?:([-+]?[0-9,.]*)W)?(?:([-+]?[0-9,.]*)D)?(?:T(?:([-+]?[0-9,.]*)H)?(?:([-+]?[0-9,.]*)M)?(?:([-+]?[0-9,.]*)S)?)?$/;function createDuration(input,key){var duration=input,match=null,sign,ret,diffRes;if(isDuration(input)){duration={ms:input._milliseconds,d:input._days,M:input._months}}else if(isNumber(input)){duration={};if(key){duration[key]=input}else{duration.milliseconds=input}}else if(!!(match=aspNetRegex.exec(input))){sign=match[1]===\"-\"?-1:1;duration={y:0,d:toInt(match[DATE])*sign,h:toInt(match[HOUR])*sign,m:toInt(match[MINUTE])*sign,s:toInt(match[SECOND])*sign,ms:toInt(absRound(match[MILLISECOND]*1e3))*sign}}else if(!!(match=isoRegex.exec(input))){sign=match[1]===\"-\"?-1:match[1]===\"+\"?1:1;duration={y:parseIso(match[2],sign),M:parseIso(match[3],sign),w:parseIso(match[4],sign),d:parseIso(match[5],sign),h:parseIso(match[6],sign),m:parseIso(match[7],sign),s:parseIso(match[8],sign)}}else if(duration==null){duration={}}else if(typeof duration===\"object\"&&(\"from\"in duration||\"to\"in duration)){diffRes=momentsDifference(createLocal(duration.from),createLocal(duration.to));duration={};duration.ms=diffRes.milliseconds;duration.M=diffRes.months}ret=new Duration(duration);if(isDuration(input)&&hasOwnProp(input,\"_locale\")){ret._locale=input._locale}return ret}createDuration.fn=Duration.prototype;createDuration.invalid=createInvalid$1;function parseIso(inp,sign){var res=inp&&parseFloat(inp.replace(\",\",\".\"));return(isNaN(res)?0:res)*sign}function positiveMomentsDifference(base,other){var res={milliseconds:0,months:0};res.months=other.month()-base.month()+(other.year()-base.year())*12;if(base.clone().add(res.months,\"M\").isAfter(other)){--res.months}res.milliseconds=+other-+base.clone().add(res.months,\"M\");return res}function momentsDifference(base,other){var res;if(!(base.isValid()&&other.isValid())){return{milliseconds:0,months:0}}other=cloneWithOffset(other,base);if(base.isBefore(other)){res=positiveMomentsDifference(base,other)}else{res=positiveMomentsDifference(other,base);res.milliseconds=-res.milliseconds;res.months=-res.months}return res}function createAdder(direction,name){return function(val,period){var dur,tmp;if(period!==null&&!isNaN(+period)){deprecateSimple(name,\"moment().\"+name+\"(period, number) is deprecated. Please use moment().\"+name+\"(number, period). \"+\"See http://momentjs.com/guides/#/warnings/add-inverted-param/ for more info.\");tmp=val;val=period;period=tmp}val=typeof val===\"string\"?+val:val;dur=createDuration(val,period);addSubtract(this,dur,direction);return this}}function addSubtract(mom,duration,isAdding,updateOffset){var milliseconds=duration._milliseconds,days=absRound(duration._days),months=absRound(duration._months);if(!mom.isValid()){return}updateOffset=updateOffset==null?true:updateOffset;if(months){setMonth(mom,get(mom,\"Month\")+months*isAdding)}if(days){set$1(mom,\"Date\",get(mom,\"Date\")+days*isAdding)}if(milliseconds){mom._d.setTime(mom._d.valueOf()+milliseconds*isAdding)}if(updateOffset){hooks.updateOffset(mom,days||months)}}var add=createAdder(1,\"add\");var subtract=createAdder(-1,\"subtract\");function getCalendarFormat(myMoment,now){var diff=myMoment.diff(now,\"days\",true);return diff<-6?\"sameElse\":diff<-1?\"lastWeek\":diff<0?\"lastDay\":diff<1?\"sameDay\":diff<2?\"nextDay\":diff<7?\"nextWeek\":\"sameElse\"}function calendar$1(time,formats){var now=time||createLocal(),sod=cloneWithOffset(now,this).startOf(\"day\"),format=hooks.calendarFormat(this,sod)||\"sameElse\";var output=formats&&(isFunction(formats[format])?formats[format].call(this,now):formats[format]);return this.format(output||this.localeData().calendar(format,this,createLocal(now)))}function clone(){return new Moment(this)}function isAfter(input,units){var localInput=isMoment(input)?input:createLocal(input);if(!(this.isValid()&&localInput.isValid())){return false}units=normalizeUnits(!isUndefined(units)?units:\"millisecond\");if(units===\"millisecond\"){return this.valueOf()>localInput.valueOf()}else{return localInput.valueOf()<this.clone().startOf(units).valueOf()}}function isBefore(input,units){var localInput=isMoment(input)?input:createLocal(input);if(!(this.isValid()&&localInput.isValid())){return false}units=normalizeUnits(!isUndefined(units)?units:\"millisecond\");if(units===\"millisecond\"){return this.valueOf()<localInput.valueOf()}else{return this.clone().endOf(units).valueOf()<localInput.valueOf()}}function isBetween(from,to,units,inclusivity){inclusivity=inclusivity||\"()\";return(inclusivity[0]===\"(\"?this.isAfter(from,units):!this.isBefore(from,units))&&(inclusivity[1]===\")\"?this.isBefore(to,units):!this.isAfter(to,units))}function isSame(input,units){var localInput=isMoment(input)?input:createLocal(input),inputMs;if(!(this.isValid()&&localInput.isValid())){return false}units=normalizeUnits(units||\"millisecond\");if(units===\"millisecond\"){return this.valueOf()===localInput.valueOf()}else{inputMs=localInput.valueOf();return this.clone().startOf(units).valueOf()<=inputMs&&inputMs<=this.clone().endOf(units).valueOf()}}function isSameOrAfter(input,units){return this.isSame(input,units)||this.isAfter(input,units)}function isSameOrBefore(input,units){return this.isSame(input,units)||this.isBefore(input,units)}function diff(input,units,asFloat){var that,zoneDelta,delta,output;if(!this.isValid()){return NaN}that=cloneWithOffset(input,this);if(!that.isValid()){return NaN}zoneDelta=(that.utcOffset()-this.utcOffset())*6e4;units=normalizeUnits(units);switch(units){case\"year\":output=monthDiff(this,that)/12;break;case\"month\":output=monthDiff(this,that);break;case\"quarter\":output=monthDiff(this,that)/3;break;case\"second\":output=(this-that)/1e3;break;case\"minute\":output=(this-that)/6e4;break;case\"hour\":output=(this-that)/36e5;break;case\"day\":output=(this-that-zoneDelta)/864e5;break;case\"week\":output=(this-that-zoneDelta)/6048e5;break;default:output=this-that}return asFloat?output:absFloor(output)}function monthDiff(a,b){var wholeMonthDiff=(b.year()-a.year())*12+(b.month()-a.month()),anchor=a.clone().add(wholeMonthDiff,\"months\"),anchor2,adjust;if(b-anchor<0){anchor2=a.clone().add(wholeMonthDiff-1,\"months\");adjust=(b-anchor)/(anchor-anchor2)}else{anchor2=a.clone().add(wholeMonthDiff+1,\"months\");adjust=(b-anchor)/(anchor2-anchor)}return-(wholeMonthDiff+adjust)||0}hooks.defaultFormat=\"YYYY-MM-DDTHH:mm:ssZ\";hooks.defaultFormatUtc=\"YYYY-MM-DDTHH:mm:ss[Z]\";function toString(){return this.clone().locale(\"en\").format(\"ddd MMM DD YYYY HH:mm:ss [GMT]ZZ\")}function toISOString(){if(!this.isValid()){return null}var m=this.clone().utc();if(m.year()<0||m.year()>9999){return formatMoment(m,\"YYYYYY-MM-DD[T]HH:mm:ss.SSS[Z]\")}if(isFunction(Date.prototype.toISOString)){return this.toDate().toISOString()}return formatMoment(m,\"YYYY-MM-DD[T]HH:mm:ss.SSS[Z]\")}function inspect(){if(!this.isValid()){return\"moment.invalid(/* \"+this._i+\" */)\"}var func=\"moment\";var zone=\"\";if(!this.isLocal()){func=this.utcOffset()===0?\"moment.utc\":\"moment.parseZone\";zone=\"Z\"}var prefix=\"[\"+func+'(\"]';var year=0<=this.year()&&this.year()<=9999?\"YYYY\":\"YYYYYY\";var datetime=\"-MM-DD[T]HH:mm:ss.SSS\";var suffix=zone+'[\")]';return this.format(prefix+year+datetime+suffix)}function format(inputString){if(!inputString){inputString=this.isUtc()?hooks.defaultFormatUtc:hooks.defaultFormat}var output=formatMoment(this,inputString);return this.localeData().postformat(output)}function from(time,withoutSuffix){if(this.isValid()&&(isMoment(time)&&time.isValid()||createLocal(time).isValid())){return createDuration({to:this,from:time}).locale(this.locale()).humanize(!withoutSuffix)}else{return this.localeData().invalidDate()}}function fromNow(withoutSuffix){return this.from(createLocal(),withoutSuffix)}function to(time,withoutSuffix){if(this.isValid()&&(isMoment(time)&&time.isValid()||createLocal(time).isValid())){return createDuration({from:this,to:time}).locale(this.locale()).humanize(!withoutSuffix)}else{return this.localeData().invalidDate()}}function toNow(withoutSuffix){return this.to(createLocal(),withoutSuffix)}function locale(key){var newLocaleData;if(key===undefined){return this._locale._abbr}else{newLocaleData=getLocale(key);if(newLocaleData!=null){this._locale=newLocaleData}return this}}var lang=deprecate(\"moment().lang() is deprecated. Instead, use moment().localeData() to get the language configuration. Use moment().locale() to change languages.\",function(key){if(key===undefined){return this.localeData()}else{return this.locale(key)}});function localeData(){return this._locale}function startOf(units){units=normalizeUnits(units);switch(units){case\"year\":this.month(0);case\"quarter\":case\"month\":this.date(1);case\"week\":case\"isoWeek\":case\"day\":case\"date\":this.hours(0);case\"hour\":this.minutes(0);case\"minute\":this.seconds(0);case\"second\":this.milliseconds(0)}if(units===\"week\"){this.weekday(0)}if(units===\"isoWeek\"){this.isoWeekday(1)}if(units===\"quarter\"){this.month(Math.floor(this.month()/3)*3)}return this}function endOf(units){units=normalizeUnits(units);if(units===undefined||units===\"millisecond\"){return this}if(units===\"date\"){units=\"day\"}return this.startOf(units).add(1,units===\"isoWeek\"?\"week\":units).subtract(1,\"ms\")}function valueOf(){return this._d.valueOf()-(this._offset||0)*6e4}function unix(){return Math.floor(this.valueOf()/1e3)}function toDate(){return new Date(this.valueOf())}function toArray(){var m=this;return[m.year(),m.month(),m.date(),m.hour(),m.minute(),m.second(),m.millisecond()]}function toObject(){var m=this;return{years:m.year(),months:m.month(),date:m.date(),hours:m.hours(),minutes:m.minutes(),seconds:m.seconds(),milliseconds:m.milliseconds()}}function toJSON(){return this.isValid()?this.toISOString():null}function isValid$2(){return isValid(this)}function parsingFlags(){return extend({},getParsingFlags(this))}function invalidAt(){return getParsingFlags(this).overflow}function creationData(){return{input:this._i,format:this._f,locale:this._locale,isUTC:this._isUTC,strict:this._strict}}addFormatToken(0,[\"gg\",2],0,function(){return this.weekYear()%100});addFormatToken(0,[\"GG\",2],0,function(){return this.isoWeekYear()%100});function addWeekYearFormatToken(token,getter){addFormatToken(0,[token,token.length],0,getter)}addWeekYearFormatToken(\"gggg\",\"weekYear\");addWeekYearFormatToken(\"ggggg\",\"weekYear\");addWeekYearFormatToken(\"GGGG\",\"isoWeekYear\");addWeekYearFormatToken(\"GGGGG\",\"isoWeekYear\");addUnitAlias(\"weekYear\",\"gg\");addUnitAlias(\"isoWeekYear\",\"GG\");addUnitPriority(\"weekYear\",1);addUnitPriority(\"isoWeekYear\",1);addRegexToken(\"G\",matchSigned);addRegexToken(\"g\",matchSigned);addRegexToken(\"GG\",match1to2,match2);addRegexToken(\"gg\",match1to2,match2);addRegexToken(\"GGGG\",match1to4,match4);addRegexToken(\"gggg\",match1to4,match4);addRegexToken(\"GGGGG\",match1to6,match6);addRegexToken(\"ggggg\",match1to6,match6);addWeekParseToken([\"gggg\",\"ggggg\",\"GGGG\",\"GGGGG\"],function(input,week,config,token){week[token.substr(0,2)]=toInt(input)});addWeekParseToken([\"gg\",\"GG\"],function(input,week,config,token){week[token]=hooks.parseTwoDigitYear(input)});function getSetWeekYear(input){return getSetWeekYearHelper.call(this,input,this.week(),this.weekday(),this.localeData()._week.dow,this.localeData()._week.doy)}function getSetISOWeekYear(input){return getSetWeekYearHelper.call(this,input,this.isoWeek(),this.isoWeekday(),1,4)}function getISOWeeksInYear(){return weeksInYear(this.year(),1,4)}function getWeeksInYear(){var weekInfo=this.localeData()._week;return weeksInYear(this.year(),weekInfo.dow,weekInfo.doy)}function getSetWeekYearHelper(input,week,weekday,dow,doy){var weeksTarget;if(input==null){return weekOfYear(this,dow,doy).year}else{weeksTarget=weeksInYear(input,dow,doy);if(week>weeksTarget){week=weeksTarget}return setWeekAll.call(this,input,week,weekday,dow,doy)}}function setWeekAll(weekYear,week,weekday,dow,doy){var dayOfYearData=dayOfYearFromWeeks(weekYear,week,weekday,dow,doy),date=createUTCDate(dayOfYearData.year,0,dayOfYearData.dayOfYear);this.year(date.getUTCFullYear());this.month(date.getUTCMonth());this.date(date.getUTCDate());return this}addFormatToken(\"Q\",0,\"Qo\",\"quarter\");addUnitAlias(\"quarter\",\"Q\");addUnitPriority(\"quarter\",7);addRegexToken(\"Q\",match1);addParseToken(\"Q\",function(input,array){array[MONTH]=(toInt(input)-1)*3});function getSetQuarter(input){return input==null?Math.ceil((this.month()+1)/3):this.month((input-1)*3+this.month()%3)}addFormatToken(\"D\",[\"DD\",2],\"Do\",\"date\");addUnitAlias(\"date\",\"D\");addUnitPriority(\"date\",9);addRegexToken(\"D\",match1to2);addRegexToken(\"DD\",match1to2,match2);addRegexToken(\"Do\",function(isStrict,locale){return isStrict?locale._dayOfMonthOrdinalParse||locale._ordinalParse:locale._dayOfMonthOrdinalParseLenient});addParseToken([\"D\",\"DD\"],DATE);addParseToken(\"Do\",function(input,array){array[DATE]=toInt(input.match(match1to2)[0],10)});var getSetDayOfMonth=makeGetSet(\"Date\",true);addFormatToken(\"DDD\",[\"DDDD\",3],\"DDDo\",\"dayOfYear\");addUnitAlias(\"dayOfYear\",\"DDD\");addUnitPriority(\"dayOfYear\",4);addRegexToken(\"DDD\",match1to3);addRegexToken(\"DDDD\",match3);addParseToken([\"DDD\",\"DDDD\"],function(input,array,config){config._dayOfYear=toInt(input)});function getSetDayOfYear(input){var dayOfYear=Math.round((this.clone().startOf(\"day\")-this.clone().startOf(\"year\"))/864e5)+1;return input==null?dayOfYear:this.add(input-dayOfYear,\"d\")}addFormatToken(\"m\",[\"mm\",2],0,\"minute\");addUnitAlias(\"minute\",\"m\");addUnitPriority(\"minute\",14);addRegexToken(\"m\",match1to2);addRegexToken(\"mm\",match1to2,match2);addParseToken([\"m\",\"mm\"],MINUTE);var getSetMinute=makeGetSet(\"Minutes\",false);addFormatToken(\"s\",[\"ss\",2],0,\"second\");addUnitAlias(\"second\",\"s\");addUnitPriority(\"second\",15);addRegexToken(\"s\",match1to2);addRegexToken(\"ss\",match1to2,match2);addParseToken([\"s\",\"ss\"],SECOND);var getSetSecond=makeGetSet(\"Seconds\",false);addFormatToken(\"S\",0,0,function(){return~~(this.millisecond()/100)});addFormatToken(0,[\"SS\",2],0,function(){return~~(this.millisecond()/10)});addFormatToken(0,[\"SSS\",3],0,\"millisecond\");addFormatToken(0,[\"SSSS\",4],0,function(){return this.millisecond()*10});addFormatToken(0,[\"SSSSS\",5],0,function(){return this.millisecond()*100});addFormatToken(0,[\"SSSSSS\",6],0,function(){return this.millisecond()*1e3});addFormatToken(0,[\"SSSSSSS\",7],0,function(){return this.millisecond()*1e4});addFormatToken(0,[\"SSSSSSSS\",8],0,function(){return this.millisecond()*1e5});addFormatToken(0,[\"SSSSSSSSS\",9],0,function(){return this.millisecond()*1e6});addUnitAlias(\"millisecond\",\"ms\");addUnitPriority(\"millisecond\",16);addRegexToken(\"S\",match1to3,match1);addRegexToken(\"SS\",match1to3,match2);addRegexToken(\"SSS\",match1to3,match3);var token;for(token=\"SSSS\";token.length<=9;token+=\"S\"){addRegexToken(token,matchUnsigned)}function parseMs(input,array){array[MILLISECOND]=toInt((\"0.\"+input)*1e3)}for(token=\"S\";token.length<=9;token+=\"S\"){addParseToken(token,parseMs)}var getSetMillisecond=makeGetSet(\"Milliseconds\",false);addFormatToken(\"z\",0,0,\"zoneAbbr\");addFormatToken(\"zz\",0,0,\"zoneName\");function getZoneAbbr(){return this._isUTC?\"UTC\":\"\"}function getZoneName(){return this._isUTC?\"Coordinated Universal Time\":\"\"}var proto=Moment.prototype;proto.add=add;proto.calendar=calendar$1;proto.clone=clone;proto.diff=diff;proto.endOf=endOf;proto.format=format;proto.from=from;proto.fromNow=fromNow;proto.to=to;proto.toNow=toNow;proto.get=stringGet;proto.invalidAt=invalidAt;proto.isAfter=isAfter;proto.isBefore=isBefore;proto.isBetween=isBetween;proto.isSame=isSame;proto.isSameOrAfter=isSameOrAfter;proto.isSameOrBefore=isSameOrBefore;proto.isValid=isValid$2;proto.lang=lang;proto.locale=locale;proto.localeData=localeData;proto.max=prototypeMax;proto.min=prototypeMin;proto.parsingFlags=parsingFlags;proto.set=stringSet;proto.startOf=startOf;proto.subtract=subtract;proto.toArray=toArray;proto.toObject=toObject;proto.toDate=toDate;proto.toISOString=toISOString;proto.inspect=inspect;proto.toJSON=toJSON;proto.toString=toString;proto.unix=unix;proto.valueOf=valueOf;proto.creationData=creationData;proto.year=getSetYear;proto.isLeapYear=getIsLeapYear;proto.weekYear=getSetWeekYear;proto.isoWeekYear=getSetISOWeekYear;proto.quarter=proto.quarters=getSetQuarter;proto.month=getSetMonth;proto.daysInMonth=getDaysInMonth;proto.week=proto.weeks=getSetWeek;proto.isoWeek=proto.isoWeeks=getSetISOWeek;proto.weeksInYear=getWeeksInYear;proto.isoWeeksInYear=getISOWeeksInYear;proto.date=getSetDayOfMonth;proto.day=proto.days=getSetDayOfWeek;proto.weekday=getSetLocaleDayOfWeek;proto.isoWeekday=getSetISODayOfWeek;proto.dayOfYear=getSetDayOfYear;proto.hour=proto.hours=getSetHour;proto.minute=proto.minutes=getSetMinute;proto.second=proto.seconds=getSetSecond;proto.millisecond=proto.milliseconds=getSetMillisecond;proto.utcOffset=getSetOffset;proto.utc=setOffsetToUTC;proto.local=setOffsetToLocal;proto.parseZone=setOffsetToParsedOffset;proto.hasAlignedHourOffset=hasAlignedHourOffset;proto.isDST=isDaylightSavingTime;proto.isLocal=isLocal;proto.isUtcOffset=isUtcOffset;proto.isUtc=isUtc;proto.isUTC=isUtc;proto.zoneAbbr=getZoneAbbr;proto.zoneName=getZoneName;proto.dates=deprecate(\"dates accessor is deprecated. Use date instead.\",getSetDayOfMonth);proto.months=deprecate(\"months accessor is deprecated. Use month instead\",getSetMonth);proto.years=deprecate(\"years accessor is deprecated. Use year instead\",getSetYear);proto.zone=deprecate(\"moment().zone is deprecated, use moment().utcOffset instead. http://momentjs.com/guides/#/warnings/zone/\",getSetZone);proto.isDSTShifted=deprecate(\"isDSTShifted is deprecated. See http://momentjs.com/guides/#/warnings/dst-shifted/ for more information\",isDaylightSavingTimeShifted);function createUnix(input){return createLocal(input*1e3)}function createInZone(){return createLocal.apply(null,arguments).parseZone()}function preParsePostFormat(string){return string}var proto$1=Locale.prototype;proto$1.calendar=calendar;proto$1.longDateFormat=longDateFormat;proto$1.invalidDate=invalidDate;proto$1.ordinal=ordinal;proto$1.preparse=preParsePostFormat;proto$1.postformat=preParsePostFormat;proto$1.relativeTime=relativeTime;proto$1.pastFuture=pastFuture;proto$1.set=set;proto$1.months=localeMonths;proto$1.monthsShort=localeMonthsShort;proto$1.monthsParse=localeMonthsParse;proto$1.monthsRegex=monthsRegex;proto$1.monthsShortRegex=monthsShortRegex;proto$1.week=localeWeek;proto$1.firstDayOfYear=localeFirstDayOfYear;proto$1.firstDayOfWeek=localeFirstDayOfWeek;proto$1.weekdays=localeWeekdays;proto$1.weekdaysMin=localeWeekdaysMin;proto$1.weekdaysShort=localeWeekdaysShort;proto$1.weekdaysParse=localeWeekdaysParse;proto$1.weekdaysRegex=weekdaysRegex;proto$1.weekdaysShortRegex=weekdaysShortRegex;proto$1.weekdaysMinRegex=weekdaysMinRegex;proto$1.isPM=localeIsPM;proto$1.meridiem=localeMeridiem;function get$1(format,index,field,setter){var locale=getLocale();var utc=createUTC().set(setter,index);return locale[field](utc,format)}function listMonthsImpl(format,index,field){if(isNumber(format)){index=format;format=undefined}format=format||\"\";if(index!=null){return get$1(format,index,field,\"month\")}var i;var out=[];for(i=0;i<12;i++){out[i]=get$1(format,i,field,\"month\")}return out}function listWeekdaysImpl(localeSorted,format,index,field){if(typeof localeSorted===\"boolean\"){if(isNumber(format)){index=format;format=undefined}format=format||\"\"}else{format=localeSorted;index=format;localeSorted=false;if(isNumber(format)){index=format;format=undefined}format=format||\"\"}var locale=getLocale(),shift=localeSorted?locale._week.dow:0;if(index!=null){return get$1(format,(index+shift)%7,field,\"day\")}var i;var out=[];for(i=0;i<7;i++){out[i]=get$1(format,(i+shift)%7,field,\"day\")}return out}function listMonths(format,index){return listMonthsImpl(format,index,\"months\")}function listMonthsShort(format,index){return listMonthsImpl(format,index,\"monthsShort\")}function listWeekdays(localeSorted,format,index){return listWeekdaysImpl(localeSorted,format,index,\"weekdays\")}function listWeekdaysShort(localeSorted,format,index){return listWeekdaysImpl(localeSorted,format,index,\"weekdaysShort\")}function listWeekdaysMin(localeSorted,format,index){return listWeekdaysImpl(localeSorted,format,index,\"weekdaysMin\")}getSetGlobalLocale(\"en\",{dayOfMonthOrdinalParse:/\\d{1,2}(th|st|nd|rd)/,ordinal:function(number){var b=number%10,output=toInt(number%100/10)===1?\"th\":b===1?\"st\":b===2?\"nd\":b===3?\"rd\":\"th\";return number+output}});hooks.lang=deprecate(\"moment.lang is deprecated. Use moment.locale instead.\",getSetGlobalLocale);hooks.langData=deprecate(\"moment.langData is deprecated. Use moment.localeData instead.\",getLocale);var mathAbs=Math.abs;function abs(){var data=this._data;this._milliseconds=mathAbs(this._milliseconds);this._days=mathAbs(this._days);this._months=mathAbs(this._months);data.milliseconds=mathAbs(data.milliseconds);data.seconds=mathAbs(data.seconds);data.minutes=mathAbs(data.minutes);data.hours=mathAbs(data.hours);data.months=mathAbs(data.months);data.years=mathAbs(data.years);return this}function addSubtract$1(duration,input,value,direction){var other=createDuration(input,value);duration._milliseconds+=direction*other._milliseconds;duration._days+=direction*other._days;duration._months+=direction*other._months;return duration._bubble()}function add$1(input,value){return addSubtract$1(this,input,value,1)}function subtract$1(input,value){return addSubtract$1(this,input,value,-1)}function absCeil(number){if(number<0){return Math.floor(number)}else{return Math.ceil(number)}}function bubble(){var milliseconds=this._milliseconds;var days=this._days;var months=this._months;var data=this._data;var seconds,minutes,hours,years,monthsFromDays;if(!(milliseconds>=0&&days>=0&&months>=0||milliseconds<=0&&days<=0&&months<=0)){milliseconds+=absCeil(monthsToDays(months)+days)*864e5;days=0;months=0}data.milliseconds=milliseconds%1e3;seconds=absFloor(milliseconds/1e3);data.seconds=seconds%60;minutes=absFloor(seconds/60)\n;data.minutes=minutes%60;hours=absFloor(minutes/60);data.hours=hours%24;days+=absFloor(hours/24);monthsFromDays=absFloor(daysToMonths(days));months+=monthsFromDays;days-=absCeil(monthsToDays(monthsFromDays));years=absFloor(months/12);months%=12;data.days=days;data.months=months;data.years=years;return this}function daysToMonths(days){return days*4800/146097}function monthsToDays(months){return months*146097/4800}function as(units){if(!this.isValid()){return NaN}var days;var months;var milliseconds=this._milliseconds;units=normalizeUnits(units);if(units===\"month\"||units===\"year\"){days=this._days+milliseconds/864e5;months=this._months+daysToMonths(days);return units===\"month\"?months:months/12}else{days=this._days+Math.round(monthsToDays(this._months));switch(units){case\"week\":return days/7+milliseconds/6048e5;case\"day\":return days+milliseconds/864e5;case\"hour\":return days*24+milliseconds/36e5;case\"minute\":return days*1440+milliseconds/6e4;case\"second\":return days*86400+milliseconds/1e3;case\"millisecond\":return Math.floor(days*864e5)+milliseconds;default:throw new Error(\"Unknown unit \"+units)}}}function valueOf$1(){if(!this.isValid()){return NaN}return this._milliseconds+this._days*864e5+this._months%12*2592e6+toInt(this._months/12)*31536e6}function makeAs(alias){return function(){return this.as(alias)}}var asMilliseconds=makeAs(\"ms\");var asSeconds=makeAs(\"s\");var asMinutes=makeAs(\"m\");var asHours=makeAs(\"h\");var asDays=makeAs(\"d\");var asWeeks=makeAs(\"w\");var asMonths=makeAs(\"M\");var asYears=makeAs(\"y\");function clone$1(){return createDuration(this)}function get$2(units){units=normalizeUnits(units);return this.isValid()?this[units+\"s\"]():NaN}function makeGetter(name){return function(){return this.isValid()?this._data[name]:NaN}}var milliseconds=makeGetter(\"milliseconds\");var seconds=makeGetter(\"seconds\");var minutes=makeGetter(\"minutes\");var hours=makeGetter(\"hours\");var days=makeGetter(\"days\");var months=makeGetter(\"months\");var years=makeGetter(\"years\");function weeks(){return absFloor(this.days()/7)}var round=Math.round;var thresholds={ss:44,s:45,m:45,h:22,d:26,M:11};function substituteTimeAgo(string,number,withoutSuffix,isFuture,locale){return locale.relativeTime(number||1,!!withoutSuffix,string,isFuture)}function relativeTime$1(posNegDuration,withoutSuffix,locale){var duration=createDuration(posNegDuration).abs();var seconds=round(duration.as(\"s\"));var minutes=round(duration.as(\"m\"));var hours=round(duration.as(\"h\"));var days=round(duration.as(\"d\"));var months=round(duration.as(\"M\"));var years=round(duration.as(\"y\"));var a=seconds<=thresholds.ss&&[\"s\",seconds]||seconds<thresholds.s&&[\"ss\",seconds]||minutes<=1&&[\"m\"]||minutes<thresholds.m&&[\"mm\",minutes]||hours<=1&&[\"h\"]||hours<thresholds.h&&[\"hh\",hours]||days<=1&&[\"d\"]||days<thresholds.d&&[\"dd\",days]||months<=1&&[\"M\"]||months<thresholds.M&&[\"MM\",months]||years<=1&&[\"y\"]||[\"yy\",years];a[2]=withoutSuffix;a[3]=+posNegDuration>0;a[4]=locale;return substituteTimeAgo.apply(null,a)}function getSetRelativeTimeRounding(roundingFunction){if(roundingFunction===undefined){return round}if(typeof roundingFunction===\"function\"){round=roundingFunction;return true}return false}function getSetRelativeTimeThreshold(threshold,limit){if(thresholds[threshold]===undefined){return false}if(limit===undefined){return thresholds[threshold]}thresholds[threshold]=limit;if(threshold===\"s\"){thresholds.ss=limit-1}return true}function humanize(withSuffix){if(!this.isValid()){return this.localeData().invalidDate()}var locale=this.localeData();var output=relativeTime$1(this,!withSuffix,locale);if(withSuffix){output=locale.pastFuture(+this,output)}return locale.postformat(output)}var abs$1=Math.abs;function sign(x){return(x>0)-(x<0)||+x}function toISOString$1(){if(!this.isValid()){return this.localeData().invalidDate()}var seconds=abs$1(this._milliseconds)/1e3;var days=abs$1(this._days);var months=abs$1(this._months);var minutes,hours,years;minutes=absFloor(seconds/60);hours=absFloor(minutes/60);seconds%=60;minutes%=60;years=absFloor(months/12);months%=12;var Y=years;var M=months;var D=days;var h=hours;var m=minutes;var s=seconds?seconds.toFixed(3).replace(/\\.?0+$/,\"\"):\"\";var total=this.asSeconds();if(!total){return\"P0D\"}var totalSign=total<0?\"-\":\"\";var ymSign=sign(this._months)!==sign(total)?\"-\":\"\";var daysSign=sign(this._days)!==sign(total)?\"-\":\"\";var hmsSign=sign(this._milliseconds)!==sign(total)?\"-\":\"\";return totalSign+\"P\"+(Y?ymSign+Y+\"Y\":\"\")+(M?ymSign+M+\"M\":\"\")+(D?daysSign+D+\"D\":\"\")+(h||m||s?\"T\":\"\")+(h?hmsSign+h+\"H\":\"\")+(m?hmsSign+m+\"M\":\"\")+(s?hmsSign+s+\"S\":\"\")}var proto$2=Duration.prototype;proto$2.isValid=isValid$1;proto$2.abs=abs;proto$2.add=add$1;proto$2.subtract=subtract$1;proto$2.as=as;proto$2.asMilliseconds=asMilliseconds;proto$2.asSeconds=asSeconds;proto$2.asMinutes=asMinutes;proto$2.asHours=asHours;proto$2.asDays=asDays;proto$2.asWeeks=asWeeks;proto$2.asMonths=asMonths;proto$2.asYears=asYears;proto$2.valueOf=valueOf$1;proto$2._bubble=bubble;proto$2.clone=clone$1;proto$2.get=get$2;proto$2.milliseconds=milliseconds;proto$2.seconds=seconds;proto$2.minutes=minutes;proto$2.hours=hours;proto$2.days=days;proto$2.weeks=weeks;proto$2.months=months;proto$2.years=years;proto$2.humanize=humanize;proto$2.toISOString=toISOString$1;proto$2.toString=toISOString$1;proto$2.toJSON=toISOString$1;proto$2.locale=locale;proto$2.localeData=localeData;proto$2.toIsoString=deprecate(\"toIsoString() is deprecated. Please use toISOString() instead (notice the capitals)\",toISOString$1);proto$2.lang=lang;addFormatToken(\"X\",0,0,\"unix\");addFormatToken(\"x\",0,0,\"valueOf\");addRegexToken(\"x\",matchSigned);addRegexToken(\"X\",matchTimestamp);addParseToken(\"X\",function(input,array,config){config._d=new Date(parseFloat(input,10)*1e3)});addParseToken(\"x\",function(input,array,config){config._d=new Date(toInt(input))});hooks.version=\"2.19.1\";setHookCallback(createLocal);hooks.fn=proto;hooks.min=min;hooks.max=max;hooks.now=now;hooks.utc=createUTC;hooks.unix=createUnix;hooks.months=listMonths;hooks.isDate=isDate;hooks.locale=getSetGlobalLocale;hooks.invalid=createInvalid;hooks.duration=createDuration;hooks.isMoment=isMoment;hooks.weekdays=listWeekdays;hooks.parseZone=createInZone;hooks.localeData=getLocale;hooks.isDuration=isDuration;hooks.monthsShort=listMonthsShort;hooks.weekdaysMin=listWeekdaysMin;hooks.defineLocale=defineLocale;hooks.updateLocale=updateLocale;hooks.locales=listLocales;hooks.weekdaysShort=listWeekdaysShort;hooks.normalizeUnits=normalizeUnits;hooks.relativeTimeRounding=getSetRelativeTimeRounding;hooks.relativeTimeThreshold=getSetRelativeTimeThreshold;hooks.calendarFormat=getCalendarFormat;hooks.prototype=proto;return hooks})}).call(exports,__webpack_require__(155)(module))},function(module,exports){module.exports=function(module){if(!module.webpackPolyfill){module.deprecate=function(){};module.paths=[];if(!module.children)module.children=[];Object.defineProperty(module,\"loaded\",{enumerable:true,get:function(){return module.l}});Object.defineProperty(module,\"id\",{enumerable:true,get:function(){return module.i}});module.webpackPolyfill=1}return module}},function(module,exports){function webpackEmptyContext(req){throw new Error(\"Cannot find module '\"+req+\"'.\")}webpackEmptyContext.keys=function(){return[]};webpackEmptyContext.resolve=webpackEmptyContext;module.exports=webpackEmptyContext;webpackEmptyContext.id=156},function(module,exports,__webpack_require__){\"use strict\";(function(global){var _rng;var globalVar=typeof window!==\"undefined\"?window:typeof global!==\"undefined\"?global:null;if(globalVar&&globalVar.crypto&&crypto.getRandomValues){var _rnds8=new Uint8Array(16);_rng=function whatwgRNG(){crypto.getRandomValues(_rnds8);return _rnds8}}if(!_rng){var _rnds=new Array(16);_rng=function _rng(){for(var i=0,r;i<16;i++){if((i&3)===0)r=Math.random()*4294967296;_rnds[i]=r>>>((i&3)<<3)&255}return _rnds}}var _byteToHex=[];var _hexToByte={};for(var i=0;i<256;i++){_byteToHex[i]=(i+256).toString(16).substr(1);_hexToByte[_byteToHex[i]]=i}function parse(s,buf,offset){var i=buf&&offset||0,ii=0;buf=buf||[];s.toLowerCase().replace(/[0-9a-f]{2}/g,function(oct){if(ii<16){buf[i+ii++]=_hexToByte[oct]}});while(ii<16){buf[i+ii++]=0}return buf}function unparse(buf,offset){var i=offset||0,bth=_byteToHex;return bth[buf[i++]]+bth[buf[i++]]+bth[buf[i++]]+bth[buf[i++]]+\"-\"+bth[buf[i++]]+bth[buf[i++]]+\"-\"+bth[buf[i++]]+bth[buf[i++]]+\"-\"+bth[buf[i++]]+bth[buf[i++]]+\"-\"+bth[buf[i++]]+bth[buf[i++]]+bth[buf[i++]]+bth[buf[i++]]+bth[buf[i++]]+bth[buf[i++]]}var _seedBytes=_rng();var _nodeId=[_seedBytes[0]|1,_seedBytes[1],_seedBytes[2],_seedBytes[3],_seedBytes[4],_seedBytes[5]];var _clockseq=(_seedBytes[6]<<8|_seedBytes[7])&16383;var _lastMSecs=0,_lastNSecs=0;function v1(options,buf,offset){var i=buf&&offset||0;var b=buf||[];options=options||{};var clockseq=options.clockseq!==undefined?options.clockseq:_clockseq;var msecs=options.msecs!==undefined?options.msecs:(new Date).getTime();var nsecs=options.nsecs!==undefined?options.nsecs:_lastNSecs+1;var dt=msecs-_lastMSecs+(nsecs-_lastNSecs)/1e4;if(dt<0&&options.clockseq===undefined){clockseq=clockseq+1&16383}if((dt<0||msecs>_lastMSecs)&&options.nsecs===undefined){nsecs=0}if(nsecs>=1e4){throw new Error(\"uuid.v1(): Can't create more than 10M uuids/sec\")}_lastMSecs=msecs;_lastNSecs=nsecs;_clockseq=clockseq;msecs+=122192928e5;var tl=((msecs&268435455)*1e4+nsecs)%4294967296;b[i++]=tl>>>24&255;b[i++]=tl>>>16&255;b[i++]=tl>>>8&255;b[i++]=tl&255;var tmh=msecs/4294967296*1e4&268435455;b[i++]=tmh>>>8&255;b[i++]=tmh&255;b[i++]=tmh>>>24&15|16;b[i++]=tmh>>>16&255;b[i++]=clockseq>>>8|128;b[i++]=clockseq&255;var node=options.node||_nodeId;for(var n=0;n<6;n++){b[i+n]=node[n]}return buf?buf:unparse(b)}function v4(options,buf,offset){var i=buf&&offset||0;if(typeof options==\"string\"){buf=options==\"binary\"?new Array(16):null;options=null}options=options||{};var rnds=options.random||(options.rng||_rng)();rnds[6]=rnds[6]&15|64;rnds[8]=rnds[8]&63|128;if(buf){for(var ii=0;ii<16;ii++){buf[i+ii]=rnds[ii]}}return buf||unparse(rnds)}var uuid=v4;uuid.v1=v1;uuid.v4=v4;uuid.parse=parse;uuid.unparse=unparse;module.exports=uuid}).call(exports,__webpack_require__(158))},function(module,exports){var g;g=function(){return this}();try{g=g||Function(\"return this\")()||(1,eval)(\"this\")}catch(e){if(typeof window===\"object\")g=window}module.exports=g},function(module,exports,__webpack_require__){\"use strict\";exports.util=__webpack_require__(2);exports.DOMutil=__webpack_require__(14);exports.DataSet=__webpack_require__(11);exports.DataView=__webpack_require__(12);exports.Queue=__webpack_require__(43);exports.Graph3d=__webpack_require__(161);exports.graph3d={Camera:__webpack_require__(95),Filter:__webpack_require__(96),Point2d:__webpack_require__(91),Point3d:__webpack_require__(34),Slider:__webpack_require__(92),StepNumber:__webpack_require__(93)};exports.moment=__webpack_require__(9);exports.Hammer=__webpack_require__(10);exports.keycharm=__webpack_require__(35)},function(module,exports,__webpack_require__){var core=__webpack_require__(7);var $JSON=core.JSON||(core.JSON={stringify:JSON.stringify});module.exports=function stringify(it){return $JSON.stringify.apply($JSON,arguments)}},function(module,exports,__webpack_require__){\"use strict\";var _assign=__webpack_require__(90);var _assign2=_interopRequireDefault(_assign);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Emitter=__webpack_require__(44);var util=__webpack_require__(2);var Point3d=__webpack_require__(34);var Point2d=__webpack_require__(91);var Slider=__webpack_require__(92);var StepNumber=__webpack_require__(93);var Settings=__webpack_require__(94);var Validator=__webpack_require__(15)[\"default\"];var _require=__webpack_require__(15),printStyle=_require.printStyle;var _require2=__webpack_require__(172),allOptions=_require2.allOptions;var DataGroup=__webpack_require__(173);Graph3d.STYLE=Settings.STYLE;var autoByDefault=undefined;Graph3d.DEFAULTS={width:\"400px\",height:\"400px\",filterLabel:\"time\",legendLabel:\"value\",xLabel:\"x\",yLabel:\"y\",zLabel:\"z\",xValueLabel:function xValueLabel(v){return v},yValueLabel:function yValueLabel(v){return v},zValueLabel:function zValueLabel(v){return v},showXAxis:true,showYAxis:true,showZAxis:true,showGrid:true,showPerspective:true,showShadow:false,keepAspectRatio:true,verticalRatio:.5,dotSizeRatio:.02,dotSizeMinFraction:.5,dotSizeMaxFraction:2.5,showAnimationControls:autoByDefault,animationInterval:1e3,animationPreload:false,animationAutoStart:autoByDefault,axisColor:\"#4D4D4D\",gridColor:\"#D3D3D3\",xCenter:\"55%\",yCenter:\"50%\",style:Graph3d.STYLE.DOT,tooltip:false,tooltipStyle:{content:{padding:\"10px\",border:\"1px solid #4d4d4d\",color:\"#1a1a1a\",background:\"rgba(255,255,255,0.7)\",borderRadius:\"2px\",boxShadow:\"5px 5px 10px rgba(128,128,128,0.5)\"},line:{height:\"40px\",width:\"0\",borderLeft:\"1px solid #4d4d4d\"},dot:{height:\"0\",width:\"0\",border:\"5px solid #4d4d4d\",borderRadius:\"5px\"}},dataColor:{fill:\"#7DC1FF\",stroke:\"#3267D2\",strokeWidth:1},cameraPosition:{horizontal:1,vertical:.5,distance:1.7},showLegend:autoByDefault,backgroundColor:autoByDefault,xBarWidth:autoByDefault,yBarWidth:autoByDefault,valueMin:autoByDefault,valueMax:autoByDefault,xMin:autoByDefault,xMax:autoByDefault,xStep:autoByDefault,yMin:autoByDefault,yMax:autoByDefault,yStep:autoByDefault,zMin:autoByDefault,zMax:autoByDefault,zStep:autoByDefault};function Graph3d(container,data,options){if(!(this instanceof Graph3d)){throw new SyntaxError(\"Constructor must be called with the new operator\")}this.containerElement=container;this.dataGroup=new DataGroup;this.dataPoints=null;this.create();Settings.setDefaults(Graph3d.DEFAULTS,this);this.colX=undefined;this.colY=undefined;this.colZ=undefined;this.colValue=undefined;this.setOptions(options);this.setData(data)}Emitter(Graph3d.prototype);Graph3d.prototype._setScale=function(){this.scale=new Point3d(1/this.xRange.range(),1/this.yRange.range(),1/this.zRange.range());if(this.keepAspectRatio){if(this.scale.x<this.scale.y){this.scale.y=this.scale.x}else{this.scale.x=this.scale.y}}this.scale.z*=this.verticalRatio;if(this.valueRange!==undefined){this.scale.value=1/this.valueRange.range()}var xCenter=this.xRange.center()*this.scale.x;var yCenter=this.yRange.center()*this.scale.y;var zCenter=this.zRange.center()*this.scale.z;this.camera.setArmLocation(xCenter,yCenter,zCenter)};Graph3d.prototype._convert3Dto2D=function(point3d){var translation=this._convertPointToTranslation(point3d);return this._convertTranslationToScreen(translation)};Graph3d.prototype._convertPointToTranslation=function(point3d){var cameraLocation=this.camera.getCameraLocation(),cameraRotation=this.camera.getCameraRotation(),ax=point3d.x*this.scale.x,ay=point3d.y*this.scale.y,az=point3d.z*this.scale.z,cx=cameraLocation.x,cy=cameraLocation.y,cz=cameraLocation.z,sinTx=Math.sin(cameraRotation.x),cosTx=Math.cos(cameraRotation.x),sinTy=Math.sin(cameraRotation.y),cosTy=Math.cos(cameraRotation.y),sinTz=Math.sin(cameraRotation.z),cosTz=Math.cos(cameraRotation.z),dx=cosTy*(sinTz*(ay-cy)+cosTz*(ax-cx))-sinTy*(az-cz),dy=sinTx*(cosTy*(az-cz)+sinTy*(sinTz*(ay-cy)+cosTz*(ax-cx)))+cosTx*(cosTz*(ay-cy)-sinTz*(ax-cx)),dz=cosTx*(cosTy*(az-cz)+sinTy*(sinTz*(ay-cy)+cosTz*(ax-cx)))-sinTx*(cosTz*(ay-cy)-sinTz*(ax-cx));return new Point3d(dx,dy,dz)};Graph3d.prototype._convertTranslationToScreen=function(translation){var ex=this.eye.x,ey=this.eye.y,ez=this.eye.z,dx=translation.x,dy=translation.y,dz=translation.z;var bx;var by;if(this.showPerspective){bx=(dx-ex)*(ez/dz);by=(dy-ey)*(ez/dz)}else{bx=dx*-(ez/this.camera.getArmLength());by=dy*-(ez/this.camera.getArmLength())}return new Point2d(this.currentXCenter+bx*this.frame.canvas.clientWidth,this.currentYCenter-by*this.frame.canvas.clientWidth)};Graph3d.prototype._calcTranslations=function(points){for(var i=0;i<points.length;i++){var point=points[i];point.trans=this._convertPointToTranslation(point.point);point.screen=this._convertTranslationToScreen(point.trans);var transBottom=this._convertPointToTranslation(point.bottom);point.dist=this.showPerspective?transBottom.length():-transBottom.z}var sortDepth=function sortDepth(a,b){return b.dist-a.dist};points.sort(sortDepth)};Graph3d.prototype._initializeRanges=function(){var dg=this.dataGroup;this.xRange=dg.xRange;this.yRange=dg.yRange;this.zRange=dg.zRange;this.valueRange=dg.valueRange;this.xStep=dg.xStep;this.yStep=dg.yStep;this.zStep=dg.zStep;this.xBarWidth=dg.xBarWidth;this.yBarWidth=dg.yBarWidth;this.colX=dg.colX;this.colY=dg.colY;this.colZ=dg.colZ;this.colValue=dg.colValue;this._setScale()};Graph3d.prototype.getDataPoints=function(data){var dataPoints=[];for(var i=0;i<data.length;i++){var point=new Point3d;point.x=data[i][this.colX]||0;point.y=data[i][this.colY]||0;point.z=data[i][this.colZ]||0;point.data=data[i];if(this.colValue!==undefined){point.value=data[i][this.colValue]||0}var obj={};obj.point=point;obj.bottom=new Point3d(point.x,point.y,this.zRange.min);obj.trans=undefined;obj.screen=undefined;dataPoints.push(obj)}return dataPoints};Graph3d.prototype._getDataPoints=function(data){var x,y,i,obj;var dataPoints=[];if(this.style===Graph3d.STYLE.GRID||this.style===Graph3d.STYLE.SURFACE){var dataX=this.dataGroup.getDistinctValues(this.colX,data);var dataY=this.dataGroup.getDistinctValues(this.colY,data);dataPoints=this.getDataPoints(data);var dataMatrix=[];for(i=0;i<dataPoints.length;i++){obj=dataPoints[i];var xIndex=dataX.indexOf(obj.point.x);var yIndex=dataY.indexOf(obj.point.y);if(dataMatrix[xIndex]===undefined){dataMatrix[xIndex]=[]}dataMatrix[xIndex][yIndex]=obj}for(x=0;x<dataMatrix.length;x++){for(y=0;y<dataMatrix[x].length;y++){if(dataMatrix[x][y]){dataMatrix[x][y].pointRight=x<dataMatrix.length-1?dataMatrix[x+1][y]:undefined;dataMatrix[x][y].pointTop=y<dataMatrix[x].length-1?dataMatrix[x][y+1]:undefined;dataMatrix[x][y].pointCross=x<dataMatrix.length-1&&y<dataMatrix[x].length-1?dataMatrix[x+1][y+1]:undefined}}}}else{this._checkValueField(data);dataPoints=this.getDataPoints(data);if(this.style===Graph3d.STYLE.LINE){for(i=0;i<dataPoints.length;i++){if(i>0){dataPoints[i-1].pointNext=dataPoints[i]}}}}return dataPoints};Graph3d.prototype.create=function(){while(this.containerElement.hasChildNodes()){this.containerElement.removeChild(this.containerElement.firstChild)}this.frame=document.createElement(\"div\");this.frame.style.position=\"relative\";this.frame.style.overflow=\"hidden\";this.frame.canvas=document.createElement(\"canvas\");this.frame.canvas.style.position=\"relative\";this.frame.appendChild(this.frame.canvas);{var noCanvas=document.createElement(\"DIV\");noCanvas.style.color=\"red\";noCanvas.style.fontWeight=\"bold\";noCanvas.style.padding=\"10px\";noCanvas.innerHTML=\"Error: your browser does not support HTML canvas\";this.frame.canvas.appendChild(noCanvas)}this.frame.filter=document.createElement(\"div\");this.frame.filter.style.position=\"absolute\";this.frame.filter.style.bottom=\"0px\";this.frame.filter.style.left=\"0px\";this.frame.filter.style.width=\"100%\";this.frame.appendChild(this.frame.filter);var me=this;var onmousedown=function onmousedown(event){me._onMouseDown(event)};var ontouchstart=function ontouchstart(event){me._onTouchStart(event)};var onmousewheel=function onmousewheel(event){me._onWheel(event)};var ontooltip=function ontooltip(event){me._onTooltip(event)};var onclick=function onclick(event){me._onClick(event)};util.addEventListener(this.frame.canvas,\"mousedown\",onmousedown);util.addEventListener(this.frame.canvas,\"touchstart\",ontouchstart);util.addEventListener(this.frame.canvas,\"mousewheel\",onmousewheel);util.addEventListener(this.frame.canvas,\"mousemove\",ontooltip);util.addEventListener(this.frame.canvas,\"click\",onclick);this.containerElement.appendChild(this.frame)};Graph3d.prototype._setSize=function(width,height){this.frame.style.width=width;this.frame.style.height=height;this._resizeCanvas()};Graph3d.prototype._resizeCanvas=function(){this.frame.canvas.style.width=\"100%\";this.frame.canvas.style.height=\"100%\";this.frame.canvas.width=this.frame.canvas.clientWidth;this.frame.canvas.height=this.frame.canvas.clientHeight;this.frame.filter.style.width=this.frame.canvas.clientWidth-2*10+\"px\"};Graph3d.prototype.animationStart=function(){if(!this.animationAutoStart||!this.dataGroup.dataFilter)return;if(!this.frame.filter||!this.frame.filter.slider)throw new Error(\"No animation available\");this.frame.filter.slider.play()};Graph3d.prototype.animationStop=function(){if(!this.frame.filter||!this.frame.filter.slider)return;this.frame.filter.slider.stop()};Graph3d.prototype._resizeCenter=function(){if(this.xCenter.charAt(this.xCenter.length-1)===\"%\"){this.currentXCenter=parseFloat(this.xCenter)/100*this.frame.canvas.clientWidth}else{this.currentXCenter=parseFloat(this.xCenter)}if(this.yCenter.charAt(this.yCenter.length-1)===\"%\"){this.currentYCenter=parseFloat(this.yCenter)/100*(this.frame.canvas.clientHeight-this.frame.filter.clientHeight)}else{this.currentYCenter=parseFloat(this.yCenter)}};Graph3d.prototype.getCameraPosition=function(){var pos=this.camera.getArmRotation();pos.distance=this.camera.getArmLength();return pos};Graph3d.prototype._readData=function(data){this.dataPoints=this.dataGroup.initializeData(this,data,this.style);this._initializeRanges();this._redrawFilter()};Graph3d.prototype.setData=function(data){if(data===undefined||data===null)return;this._readData(data);this.redraw();this.animationStart()};Graph3d.prototype.setOptions=function(options){if(options===undefined)return;var errorFound=Validator.validate(options,allOptions);if(errorFound===true){console.log(\"%cErrors have been found in the supplied options object.\",printStyle)}this.animationStop();Settings.setOptions(options,this);this.setPointDrawingMethod();this._setSize(this.width,this.height);this.setData(this.dataGroup.getDataTable());this.animationStart()};Graph3d.prototype.setPointDrawingMethod=function(){var method=undefined;switch(this.style){case Graph3d.STYLE.BAR:method=Graph3d.prototype._redrawBarGraphPoint;break;case Graph3d.STYLE.BARCOLOR:method=Graph3d.prototype._redrawBarColorGraphPoint;break;case Graph3d.STYLE.BARSIZE:method=Graph3d.prototype._redrawBarSizeGraphPoint;break;case Graph3d.STYLE.DOT:method=Graph3d.prototype._redrawDotGraphPoint;break;case Graph3d.STYLE.DOTLINE:method=Graph3d.prototype._redrawDotLineGraphPoint;break;case Graph3d.STYLE.DOTCOLOR:method=Graph3d.prototype._redrawDotColorGraphPoint;break;case Graph3d.STYLE.DOTSIZE:method=Graph3d.prototype._redrawDotSizeGraphPoint;break;case Graph3d.STYLE.SURFACE:method=Graph3d.prototype._redrawSurfaceGraphPoint;break;case Graph3d.STYLE.GRID:method=Graph3d.prototype._redrawGridGraphPoint;break;case Graph3d.STYLE.LINE:method=Graph3d.prototype._redrawLineGraphPoint;break;default:throw new Error(\"Can not determine point drawing method \"+\"for graph style '\"+this.style+\"'\")}this._pointDrawingMethod=method};Graph3d.prototype.redraw=function(){if(this.dataPoints===undefined){throw new Error(\"Graph data not initialized\")}this._resizeCanvas();this._resizeCenter();this._redrawSlider();this._redrawClear();this._redrawAxis();this._redrawDataGraph();this._redrawInfo();this._redrawLegend()};Graph3d.prototype._getContext=function(){var canvas=this.frame.canvas;var ctx=canvas.getContext(\"2d\");ctx.lineJoin=\"round\";ctx.lineCap=\"round\";return ctx};Graph3d.prototype._redrawClear=function(){var canvas=this.frame.canvas;var ctx=canvas.getContext(\"2d\");ctx.clearRect(0,0,canvas.width,canvas.height)};Graph3d.prototype._dotSize=function(){return this.frame.clientWidth*this.dotSizeRatio};Graph3d.prototype._getLegendWidth=function(){var width;if(this.style===Graph3d.STYLE.DOTSIZE){var dotSize=this._dotSize();width=dotSize*this.dotSizeMaxFraction}else if(this.style===Graph3d.STYLE.BARSIZE){width=this.xBarWidth}else{width=20}return width};Graph3d.prototype._redrawLegend=function(){if(this.showLegend!==true){return}if(this.style===Graph3d.STYLE.LINE||this.style===Graph3d.STYLE.BARSIZE){return}var isSizeLegend=this.style===Graph3d.STYLE.BARSIZE||this.style===Graph3d.STYLE.DOTSIZE;var isValueLegend=this.style===Graph3d.STYLE.DOTSIZE||this.style===Graph3d.STYLE.DOTCOLOR||this.style===Graph3d.STYLE.BARCOLOR;var height=Math.max(this.frame.clientHeight*.25,100);var top=this.margin;var width=this._getLegendWidth();var right=this.frame.clientWidth-this.margin;var left=right-width;var bottom=top+height;var ctx=this._getContext();ctx.lineWidth=1;ctx.font=\"14px arial\";if(isSizeLegend===false){var ymin=0;var ymax=height;var y;for(y=ymin;y<ymax;y++){var f=(y-ymin)/(ymax-ymin);var hue=f*240;var color=this._hsv2rgb(hue,1,1);ctx.strokeStyle=color;ctx.beginPath();ctx.moveTo(left,top+y);ctx.lineTo(right,top+y);ctx.stroke()}ctx.strokeStyle=this.axisColor;ctx.strokeRect(left,top,width,height)}else{var widthMin;if(this.style===Graph3d.STYLE.DOTSIZE){widthMin=width*(this.dotSizeMinFraction/this.dotSizeMaxFraction)}else if(this.style===Graph3d.STYLE.BARSIZE){}ctx.strokeStyle=this.axisColor;ctx.fillStyle=this.dataColor.fill;ctx.beginPath();ctx.moveTo(left,top);ctx.lineTo(right,top);ctx.lineTo(left+widthMin,bottom);ctx.lineTo(left,bottom);ctx.closePath();ctx.fill();ctx.stroke()}var gridLineLen=5;var legendMin=isValueLegend?this.valueRange.min:this.zRange.min;var legendMax=isValueLegend?this.valueRange.max:this.zRange.max;var step=new StepNumber(legendMin,legendMax,(legendMax-legendMin)/5,true);step.start(true);var from;var to;while(!step.end()){y=bottom-(step.getCurrent()-legendMin)/(legendMax-legendMin)*height;from=new Point2d(left-gridLineLen,y);to=new Point2d(left,y);this._line(ctx,from,to);ctx.textAlign=\"right\";ctx.textBaseline=\"middle\";ctx.fillStyle=this.axisColor;ctx.fillText(step.getCurrent(),left-2*gridLineLen,y);step.next()}ctx.textAlign=\"right\";ctx.textBaseline=\"top\";var label=this.legendLabel;ctx.fillText(label,right,bottom+this.margin)};Graph3d.prototype._redrawFilter=function(){var dataFilter=this.dataGroup.dataFilter;var filter=this.frame.filter;filter.innerHTML=\"\";if(!dataFilter){filter.slider=undefined;return}var options={visible:this.showAnimationControls};var slider=new Slider(filter,options);filter.slider=slider;filter.style.padding=\"10px\";slider.setValues(dataFilter.values);slider.setPlayInterval(this.animationInterval);var me=this;var onchange=function onchange(){var dataFilter=me.dataGroup.dataFilter;var index=slider.getIndex();dataFilter.selectValue(index);me.dataPoints=dataFilter._getDataPoints();me.redraw()};slider.setOnChangeCallback(onchange)};Graph3d.prototype._redrawSlider=function(){if(this.frame.filter.slider!==undefined){this.frame.filter.slider.redraw()}};Graph3d.prototype._redrawInfo=function(){var info=this.dataGroup.getInfo();if(info===undefined)return;var ctx=this._getContext();ctx.font=\"14px arial\";ctx.lineStyle=\"gray\";ctx.fillStyle=\"gray\";ctx.textAlign=\"left\";ctx.textBaseline=\"top\";var x=this.margin;var y=this.margin;ctx.fillText(info,x,y)};Graph3d.prototype._line=function(ctx,from,to,strokeStyle){if(strokeStyle!==undefined){ctx.strokeStyle=strokeStyle}ctx.beginPath();ctx.moveTo(from.x,from.y);ctx.lineTo(to.x,to.y);ctx.stroke()};Graph3d.prototype.drawAxisLabelX=function(ctx,point3d,text,armAngle,yMargin){if(yMargin===undefined){yMargin=0}var point2d=this._convert3Dto2D(point3d);if(Math.cos(armAngle*2)>0){ctx.textAlign=\"center\";ctx.textBaseline=\"top\";point2d.y+=yMargin}else if(Math.sin(armAngle*2)<0){ctx.textAlign=\"right\";ctx.textBaseline=\"middle\"}else{ctx.textAlign=\"left\";ctx.textBaseline=\"middle\"}ctx.fillStyle=this.axisColor;ctx.fillText(text,point2d.x,point2d.y)};Graph3d.prototype.drawAxisLabelY=function(ctx,point3d,text,armAngle,yMargin){if(yMargin===undefined){yMargin=0}var point2d=this._convert3Dto2D(point3d);if(Math.cos(armAngle*2)<0){ctx.textAlign=\"center\";ctx.textBaseline=\"top\";point2d.y+=yMargin}else if(Math.sin(armAngle*2)>0){ctx.textAlign=\"right\";ctx.textBaseline=\"middle\"}else{ctx.textAlign=\"left\";ctx.textBaseline=\"middle\"}ctx.fillStyle=this.axisColor;ctx.fillText(text,point2d.x,point2d.y)};Graph3d.prototype.drawAxisLabelZ=function(ctx,point3d,text,offset){if(offset===undefined){offset=0}var point2d=this._convert3Dto2D(point3d);ctx.textAlign=\"right\";ctx.textBaseline=\"middle\";ctx.fillStyle=this.axisColor;ctx.fillText(text,point2d.x-offset,point2d.y)};Graph3d.prototype._line3d=function(ctx,from,to,strokeStyle){var from2d=this._convert3Dto2D(from);var to2d=this._convert3Dto2D(to);this._line(ctx,from2d,to2d,strokeStyle)};Graph3d.prototype._redrawAxis=function(){var ctx=this._getContext(),from,to,step,prettyStep,text,xText,yText,zText,offset,xOffset,yOffset;ctx.font=24/this.camera.getArmLength()+\"px arial\";var gridLenX=.025/this.scale.x;var gridLenY=.025/this.scale.y;var textMargin=5/this.camera.getArmLength();var armAngle=this.camera.getArmRotation().horizontal;var armVector=new Point2d(Math.cos(armAngle),Math.sin(armAngle));var xRange=this.xRange;var yRange=this.yRange;var zRange=this.zRange;var point3d;ctx.lineWidth=1;prettyStep=this.defaultXStep===undefined;step=new StepNumber(xRange.min,xRange.max,this.xStep,prettyStep);step.start(true);while(!step.end()){var x=step.getCurrent();if(this.showGrid){from=new Point3d(x,yRange.min,zRange.min);to=new Point3d(x,yRange.max,zRange.min);this._line3d(ctx,from,to,this.gridColor)}else if(this.showXAxis){from=new Point3d(x,yRange.min,zRange.min);to=new Point3d(x,yRange.min+gridLenX,zRange.min);this._line3d(ctx,from,to,this.axisColor);from=new Point3d(x,yRange.max,zRange.min);to=new Point3d(x,yRange.max-gridLenX,zRange.min);this._line3d(ctx,from,to,this.axisColor)}if(this.showXAxis){yText=armVector.x>0?yRange.min:yRange.max;point3d=new Point3d(x,yText,zRange.min);var msg=\" \"+this.xValueLabel(x)+\" \";this.drawAxisLabelX(ctx,point3d,msg,armAngle,textMargin)}step.next()}ctx.lineWidth=1;prettyStep=this.defaultYStep===undefined;step=new StepNumber(yRange.min,yRange.max,this.yStep,prettyStep);step.start(true);while(!step.end()){var y=step.getCurrent();if(this.showGrid){from=new Point3d(xRange.min,y,zRange.min);to=new Point3d(xRange.max,y,zRange.min);this._line3d(ctx,from,to,this.gridColor)}else if(this.showYAxis){from=new Point3d(xRange.min,y,zRange.min);to=new Point3d(xRange.min+gridLenY,y,zRange.min);this._line3d(ctx,from,to,this.axisColor);from=new Point3d(xRange.max,y,zRange.min);to=new Point3d(xRange.max-gridLenY,y,zRange.min);this._line3d(ctx,from,to,this.axisColor)}if(this.showYAxis){xText=armVector.y>0?xRange.min:xRange.max;point3d=new Point3d(xText,y,zRange.min);var _msg=\" \"+this.yValueLabel(y)+\" \";this.drawAxisLabelY(ctx,point3d,_msg,armAngle,textMargin)}step.next()}if(this.showZAxis){ctx.lineWidth=1;prettyStep=this.defaultZStep===undefined;step=new StepNumber(zRange.min,zRange.max,this.zStep,prettyStep);step.start(true);xText=armVector.x>0?xRange.min:xRange.max;yText=armVector.y<0?yRange.min:yRange.max;while(!step.end()){var z=step.getCurrent();var from3d=new Point3d(xText,yText,z);var from2d=this._convert3Dto2D(from3d);to=new Point2d(from2d.x-textMargin,from2d.y);this._line(ctx,from2d,to,this.axisColor);var _msg2=this.zValueLabel(z)+\" \";this.drawAxisLabelZ(ctx,from3d,_msg2,5);step.next()}ctx.lineWidth=1;from=new Point3d(xText,yText,zRange.min);to=new Point3d(xText,yText,zRange.max);this._line3d(ctx,from,to,this.axisColor)}if(this.showXAxis){var xMin2d;var xMax2d;ctx.lineWidth=1;xMin2d=new Point3d(xRange.min,yRange.min,zRange.min);xMax2d=new Point3d(xRange.max,yRange.min,zRange.min);this._line3d(ctx,xMin2d,xMax2d,this.axisColor);xMin2d=new Point3d(xRange.min,yRange.max,zRange.min);xMax2d=new Point3d(xRange.max,yRange.max,zRange.min);this._line3d(ctx,xMin2d,xMax2d,this.axisColor)}if(this.showYAxis){ctx.lineWidth=1;from=new Point3d(xRange.min,yRange.min,zRange.min);to=new Point3d(xRange.min,yRange.max,zRange.min);this._line3d(ctx,from,to,this.axisColor);from=new Point3d(xRange.max,yRange.min,zRange.min);to=new Point3d(xRange.max,yRange.max,zRange.min);this._line3d(ctx,from,to,this.axisColor)}var xLabel=this.xLabel;if(xLabel.length>0&&this.showXAxis){yOffset=.1/this.scale.y;xText=(xRange.max+3*xRange.min)/4;yText=armVector.x>0?yRange.min-yOffset:yRange.max+yOffset\n;text=new Point3d(xText,yText,zRange.min);this.drawAxisLabelX(ctx,text,xLabel,armAngle)}var yLabel=this.yLabel;if(yLabel.length>0&&this.showYAxis){xOffset=.1/this.scale.x;xText=armVector.y>0?xRange.min-xOffset:xRange.max+xOffset;yText=(yRange.max+3*yRange.min)/4;text=new Point3d(xText,yText,zRange.min);this.drawAxisLabelY(ctx,text,yLabel,armAngle)}var zLabel=this.zLabel;if(zLabel.length>0&&this.showZAxis){offset=30;xText=armVector.x>0?xRange.min:xRange.max;yText=armVector.y<0?yRange.min:yRange.max;zText=(zRange.max+3*zRange.min)/4;text=new Point3d(xText,yText,zText);this.drawAxisLabelZ(ctx,text,zLabel,offset)}};Graph3d.prototype._hsv2rgb=function(H,S,V){var R,G,B,C,Hi,X;C=V*S;Hi=Math.floor(H/60);X=C*(1-Math.abs(H/60%2-1));switch(Hi){case 0:R=C;G=X;B=0;break;case 1:R=X;G=C;B=0;break;case 2:R=0;G=C;B=X;break;case 3:R=0;G=X;B=C;break;case 4:R=X;G=0;B=C;break;case 5:R=C;G=0;B=X;break;default:R=0;G=0;B=0;break}return\"RGB(\"+parseInt(R*255)+\",\"+parseInt(G*255)+\",\"+parseInt(B*255)+\")\"};Graph3d.prototype._getStrokeWidth=function(point){if(point!==undefined){if(this.showPerspective){return 1/-point.trans.z*this.dataColor.strokeWidth}else{return-(this.eye.z/this.camera.getArmLength())*this.dataColor.strokeWidth}}return this.dataColor.strokeWidth};Graph3d.prototype._redrawBar=function(ctx,point,xWidth,yWidth,color,borderColor){var surface;var me=this;var point3d=point.point;var zMin=this.zRange.min;var top=[{point:new Point3d(point3d.x-xWidth,point3d.y-yWidth,point3d.z)},{point:new Point3d(point3d.x+xWidth,point3d.y-yWidth,point3d.z)},{point:new Point3d(point3d.x+xWidth,point3d.y+yWidth,point3d.z)},{point:new Point3d(point3d.x-xWidth,point3d.y+yWidth,point3d.z)}];var bottom=[{point:new Point3d(point3d.x-xWidth,point3d.y-yWidth,zMin)},{point:new Point3d(point3d.x+xWidth,point3d.y-yWidth,zMin)},{point:new Point3d(point3d.x+xWidth,point3d.y+yWidth,zMin)},{point:new Point3d(point3d.x-xWidth,point3d.y+yWidth,zMin)}];top.forEach(function(obj){obj.screen=me._convert3Dto2D(obj.point)});bottom.forEach(function(obj){obj.screen=me._convert3Dto2D(obj.point)});var surfaces=[{corners:top,center:Point3d.avg(bottom[0].point,bottom[2].point)},{corners:[top[0],top[1],bottom[1],bottom[0]],center:Point3d.avg(bottom[1].point,bottom[0].point)},{corners:[top[1],top[2],bottom[2],bottom[1]],center:Point3d.avg(bottom[2].point,bottom[1].point)},{corners:[top[2],top[3],bottom[3],bottom[2]],center:Point3d.avg(bottom[3].point,bottom[2].point)},{corners:[top[3],top[0],bottom[0],bottom[3]],center:Point3d.avg(bottom[0].point,bottom[3].point)}];point.surfaces=surfaces;for(var j=0;j<surfaces.length;j++){surface=surfaces[j];var transCenter=this._convertPointToTranslation(surface.center);surface.dist=this.showPerspective?transCenter.length():-transCenter.z}surfaces.sort(function(a,b){var diff=b.dist-a.dist;if(diff)return diff;if(a.corners===top)return 1;if(b.corners===top)return-1;return 0});ctx.lineWidth=this._getStrokeWidth(point);ctx.strokeStyle=borderColor;ctx.fillStyle=color;for(var _j=2;_j<surfaces.length;_j++){surface=surfaces[_j];this._polygon(ctx,surface.corners)}};Graph3d.prototype._polygon=function(ctx,points,fillStyle,strokeStyle){if(points.length<2){return}if(fillStyle!==undefined){ctx.fillStyle=fillStyle}if(strokeStyle!==undefined){ctx.strokeStyle=strokeStyle}ctx.beginPath();ctx.moveTo(points[0].screen.x,points[0].screen.y);for(var i=1;i<points.length;++i){var point=points[i];ctx.lineTo(point.screen.x,point.screen.y)}ctx.closePath();ctx.fill();ctx.stroke()};Graph3d.prototype._drawCircle=function(ctx,point,color,borderColor,size){var radius=this._calcRadius(point,size);ctx.lineWidth=this._getStrokeWidth(point);ctx.strokeStyle=borderColor;ctx.fillStyle=color;ctx.beginPath();ctx.arc(point.screen.x,point.screen.y,radius,0,Math.PI*2,true);ctx.fill();ctx.stroke()};Graph3d.prototype._getColorsRegular=function(point){var hue=(1-(point.point.z-this.zRange.min)*this.scale.z/this.verticalRatio)*240;var color=this._hsv2rgb(hue,1,1);var borderColor=this._hsv2rgb(hue,1,.8);return{fill:color,border:borderColor}};Graph3d.prototype._getColorsColor=function(point){var color,borderColor;if(typeof point.point.value===\"string\"){color=point.point.value;borderColor=point.point.value}else{var hue=(1-(point.point.value-this.valueRange.min)*this.scale.value)*240;color=this._hsv2rgb(hue,1,1);borderColor=this._hsv2rgb(hue,1,.8)}return{fill:color,border:borderColor}};Graph3d.prototype._getColorsSize=function(){return{fill:this.dataColor.fill,border:this.dataColor.stroke}};Graph3d.prototype._calcRadius=function(point,size){if(size===undefined){size=this._dotSize()}var radius;if(this.showPerspective){radius=size/-point.trans.z}else{radius=size*-(this.eye.z/this.camera.getArmLength())}if(radius<0){radius=0}return radius};Graph3d.prototype._redrawBarGraphPoint=function(ctx,point){var xWidth=this.xBarWidth/2;var yWidth=this.yBarWidth/2;var colors=this._getColorsRegular(point);this._redrawBar(ctx,point,xWidth,yWidth,colors.fill,colors.border)};Graph3d.prototype._redrawBarColorGraphPoint=function(ctx,point){var xWidth=this.xBarWidth/2;var yWidth=this.yBarWidth/2;var colors=this._getColorsColor(point);this._redrawBar(ctx,point,xWidth,yWidth,colors.fill,colors.border)};Graph3d.prototype._redrawBarSizeGraphPoint=function(ctx,point){var fraction=(point.point.value-this.valueRange.min)/this.valueRange.range();var xWidth=this.xBarWidth/2*(fraction*.8+.2);var yWidth=this.yBarWidth/2*(fraction*.8+.2);var colors=this._getColorsSize();this._redrawBar(ctx,point,xWidth,yWidth,colors.fill,colors.border)};Graph3d.prototype._redrawDotGraphPoint=function(ctx,point){var colors=this._getColorsRegular(point);this._drawCircle(ctx,point,colors.fill,colors.border)};Graph3d.prototype._redrawDotLineGraphPoint=function(ctx,point){var from=this._convert3Dto2D(point.bottom);ctx.lineWidth=1;this._line(ctx,from,point.screen,this.gridColor);this._redrawDotGraphPoint(ctx,point)};Graph3d.prototype._redrawDotColorGraphPoint=function(ctx,point){var colors=this._getColorsColor(point);this._drawCircle(ctx,point,colors.fill,colors.border)};Graph3d.prototype._redrawDotSizeGraphPoint=function(ctx,point){var dotSize=this._dotSize();var fraction=(point.point.value-this.valueRange.min)/this.valueRange.range();var sizeMin=dotSize*this.dotSizeMinFraction;var sizeRange=dotSize*this.dotSizeMaxFraction-sizeMin;var size=sizeMin+sizeRange*fraction;var colors=this._getColorsSize();this._drawCircle(ctx,point,colors.fill,colors.border,size)};Graph3d.prototype._redrawSurfaceGraphPoint=function(ctx,point){var right=point.pointRight;var top=point.pointTop;var cross=point.pointCross;if(point===undefined||right===undefined||top===undefined||cross===undefined){return}var topSideVisible=true;var fillStyle;var strokeStyle;if(this.showGrayBottom||this.showShadow){var aDiff=Point3d.subtract(cross.trans,point.trans);var bDiff=Point3d.subtract(top.trans,right.trans);var crossproduct=Point3d.crossProduct(aDiff,bDiff);var len=crossproduct.length();topSideVisible=crossproduct.z>0}if(topSideVisible){var zAvg=(point.point.z+right.point.z+top.point.z+cross.point.z)/4;var h=(1-(zAvg-this.zRange.min)*this.scale.z/this.verticalRatio)*240;var s=1;var v;if(this.showShadow){v=Math.min(1+crossproduct.x/len/2,1);fillStyle=this._hsv2rgb(h,s,v);strokeStyle=fillStyle}else{v=1;fillStyle=this._hsv2rgb(h,s,v);strokeStyle=this.axisColor}}else{fillStyle=\"gray\";strokeStyle=this.axisColor}ctx.lineWidth=this._getStrokeWidth(point);var points=[point,right,cross,top];this._polygon(ctx,points,fillStyle,strokeStyle)};Graph3d.prototype._drawGridLine=function(ctx,from,to){if(from===undefined||to===undefined){return}var zAvg=(from.point.z+to.point.z)/2;var h=(1-(zAvg-this.zRange.min)*this.scale.z/this.verticalRatio)*240;ctx.lineWidth=this._getStrokeWidth(from)*2;ctx.strokeStyle=this._hsv2rgb(h,1,1);this._line(ctx,from.screen,to.screen)};Graph3d.prototype._redrawGridGraphPoint=function(ctx,point){this._drawGridLine(ctx,point,point.pointRight);this._drawGridLine(ctx,point,point.pointTop)};Graph3d.prototype._redrawLineGraphPoint=function(ctx,point){if(point.pointNext===undefined){return}ctx.lineWidth=this._getStrokeWidth(point);ctx.strokeStyle=this.dataColor.stroke;this._line(ctx,point.screen,point.pointNext.screen)};Graph3d.prototype._redrawDataGraph=function(){var ctx=this._getContext();var i;if(this.dataPoints===undefined||this.dataPoints.length<=0)return;this._calcTranslations(this.dataPoints);for(i=0;i<this.dataPoints.length;i++){var point=this.dataPoints[i];this._pointDrawingMethod.call(this,ctx,point)}};Graph3d.prototype._storeMousePosition=function(event){this.startMouseX=getMouseX(event);this.startMouseY=getMouseY(event);this._startCameraOffset=this.camera.getOffset()};Graph3d.prototype._onMouseDown=function(event){event=event||window.event;if(this.leftButtonDown){this._onMouseUp(event)}this.leftButtonDown=event.which?event.which===1:event.button===1;if(!this.leftButtonDown&&!this.touchDown)return;this._storeMousePosition(event);this.startStart=new Date(this.start);this.startEnd=new Date(this.end);this.startArmRotation=this.camera.getArmRotation();this.frame.style.cursor=\"move\";var me=this;this.onmousemove=function(event){me._onMouseMove(event)};this.onmouseup=function(event){me._onMouseUp(event)};util.addEventListener(document,\"mousemove\",me.onmousemove);util.addEventListener(document,\"mouseup\",me.onmouseup);util.preventDefault(event)};Graph3d.prototype._onMouseMove=function(event){this.moving=true;event=event||window.event;var diffX=parseFloat(getMouseX(event))-this.startMouseX;var diffY=parseFloat(getMouseY(event))-this.startMouseY;if(event&&event.ctrlKey===true){var scaleX=this.frame.clientWidth*.5;var scaleY=this.frame.clientHeight*.5;var offXNew=(this._startCameraOffset.x||0)-diffX/scaleX*this.camera.armLength*.8;var offYNew=(this._startCameraOffset.y||0)+diffY/scaleY*this.camera.armLength*.8;this.camera.setOffset(offXNew,offYNew);this._storeMousePosition(event)}else{var horizontalNew=this.startArmRotation.horizontal+diffX/200;var verticalNew=this.startArmRotation.vertical+diffY/200;var snapAngle=4;var snapValue=Math.sin(snapAngle/360*2*Math.PI);if(Math.abs(Math.sin(horizontalNew))<snapValue){horizontalNew=Math.round(horizontalNew/Math.PI)*Math.PI-.001}if(Math.abs(Math.cos(horizontalNew))<snapValue){horizontalNew=(Math.round(horizontalNew/Math.PI-.5)+.5)*Math.PI-.001}if(Math.abs(Math.sin(verticalNew))<snapValue){verticalNew=Math.round(verticalNew/Math.PI)*Math.PI}if(Math.abs(Math.cos(verticalNew))<snapValue){verticalNew=(Math.round(verticalNew/Math.PI-.5)+.5)*Math.PI}this.camera.setArmRotation(horizontalNew,verticalNew)}this.redraw();var parameters=this.getCameraPosition();this.emit(\"cameraPositionChange\",parameters);util.preventDefault(event)};Graph3d.prototype._onMouseUp=function(event){this.frame.style.cursor=\"auto\";this.leftButtonDown=false;util.removeEventListener(document,\"mousemove\",this.onmousemove);util.removeEventListener(document,\"mouseup\",this.onmouseup);util.preventDefault(event)};Graph3d.prototype._onClick=function(event){if(!this.onclick_callback)return;if(!this.moving){var boundingRect=this.frame.getBoundingClientRect();var mouseX=getMouseX(event)-boundingRect.left;var mouseY=getMouseY(event)-boundingRect.top;var dataPoint=this._dataPointFromXY(mouseX,mouseY);if(dataPoint)this.onclick_callback(dataPoint.point.data)}else{this.moving=false}util.preventDefault(event)};Graph3d.prototype._onTooltip=function(event){var delay=300;var boundingRect=this.frame.getBoundingClientRect();var mouseX=getMouseX(event)-boundingRect.left;var mouseY=getMouseY(event)-boundingRect.top;if(!this.showTooltip){return}if(this.tooltipTimeout){clearTimeout(this.tooltipTimeout)}if(this.leftButtonDown){this._hideTooltip();return}if(this.tooltip&&this.tooltip.dataPoint){var dataPoint=this._dataPointFromXY(mouseX,mouseY);if(dataPoint!==this.tooltip.dataPoint){if(dataPoint){this._showTooltip(dataPoint)}else{this._hideTooltip()}}}else{var me=this;this.tooltipTimeout=setTimeout(function(){me.tooltipTimeout=null;var dataPoint=me._dataPointFromXY(mouseX,mouseY);if(dataPoint){me._showTooltip(dataPoint)}},delay)}};Graph3d.prototype._onTouchStart=function(event){this.touchDown=true;var me=this;this.ontouchmove=function(event){me._onTouchMove(event)};this.ontouchend=function(event){me._onTouchEnd(event)};util.addEventListener(document,\"touchmove\",me.ontouchmove);util.addEventListener(document,\"touchend\",me.ontouchend);this._onMouseDown(event)};Graph3d.prototype._onTouchMove=function(event){this._onMouseMove(event)};Graph3d.prototype._onTouchEnd=function(event){this.touchDown=false;util.removeEventListener(document,\"touchmove\",this.ontouchmove);util.removeEventListener(document,\"touchend\",this.ontouchend);this._onMouseUp(event)};Graph3d.prototype._onWheel=function(event){if(!event)event=window.event;var delta=0;if(event.wheelDelta){delta=event.wheelDelta/120}else if(event.detail){delta=-event.detail/3}if(delta){var oldLength=this.camera.getArmLength();var newLength=oldLength*(1-delta/10);this.camera.setArmLength(newLength);this.redraw();this._hideTooltip()}var parameters=this.getCameraPosition();this.emit(\"cameraPositionChange\",parameters);util.preventDefault(event)};Graph3d.prototype._insideTriangle=function(point,triangle){var a=triangle[0],b=triangle[1],c=triangle[2];function sign(x){return x>0?1:x<0?-1:0}var as=sign((b.x-a.x)*(point.y-a.y)-(b.y-a.y)*(point.x-a.x));var bs=sign((c.x-b.x)*(point.y-b.y)-(c.y-b.y)*(point.x-b.x));var cs=sign((a.x-c.x)*(point.y-c.y)-(a.y-c.y)*(point.x-c.x));return(as==0||bs==0||as==bs)&&(bs==0||cs==0||bs==cs)&&(as==0||cs==0||as==cs)};Graph3d.prototype._dataPointFromXY=function(x,y){var i,distMax=100,dataPoint=null,closestDataPoint=null,closestDist=null,center=new Point2d(x,y);if(this.style===Graph3d.STYLE.BAR||this.style===Graph3d.STYLE.BARCOLOR||this.style===Graph3d.STYLE.BARSIZE){for(i=this.dataPoints.length-1;i>=0;i--){dataPoint=this.dataPoints[i];var surfaces=dataPoint.surfaces;if(surfaces){for(var s=surfaces.length-1;s>=0;s--){var surface=surfaces[s];var corners=surface.corners;var triangle1=[corners[0].screen,corners[1].screen,corners[2].screen];var triangle2=[corners[2].screen,corners[3].screen,corners[0].screen];if(this._insideTriangle(center,triangle1)||this._insideTriangle(center,triangle2)){return dataPoint}}}}}else{for(i=0;i<this.dataPoints.length;i++){dataPoint=this.dataPoints[i];var point=dataPoint.screen;if(point){var distX=Math.abs(x-point.x);var distY=Math.abs(y-point.y);var dist=Math.sqrt(distX*distX+distY*distY);if((closestDist===null||dist<closestDist)&&dist<distMax){closestDist=dist;closestDataPoint=dataPoint}}}}return closestDataPoint};Graph3d.prototype.hasBars=function(style){return style==Graph3d.STYLE.BAR||style==Graph3d.STYLE.BARCOLOR||style==Graph3d.STYLE.BARSIZE};Graph3d.prototype._showTooltip=function(dataPoint){var content,line,dot;if(!this.tooltip){content=document.createElement(\"div\");(0,_assign2[\"default\"])(content.style,{},this.tooltipStyle.content);content.style.position=\"absolute\";line=document.createElement(\"div\");(0,_assign2[\"default\"])(line.style,{},this.tooltipStyle.line);line.style.position=\"absolute\";dot=document.createElement(\"div\");(0,_assign2[\"default\"])(dot.style,{},this.tooltipStyle.dot);dot.style.position=\"absolute\";this.tooltip={dataPoint:null,dom:{content:content,line:line,dot:dot}}}else{content=this.tooltip.dom.content;line=this.tooltip.dom.line;dot=this.tooltip.dom.dot}this._hideTooltip();this.tooltip.dataPoint=dataPoint;if(typeof this.showTooltip===\"function\"){content.innerHTML=this.showTooltip(dataPoint.point)}else{content.innerHTML=\"<table>\"+\"<tr><td>\"+this.xLabel+\":</td><td>\"+dataPoint.point.x+\"</td></tr>\"+\"<tr><td>\"+this.yLabel+\":</td><td>\"+dataPoint.point.y+\"</td></tr>\"+\"<tr><td>\"+this.zLabel+\":</td><td>\"+dataPoint.point.z+\"</td></tr>\"+\"</table>\"}content.style.left=\"0\";content.style.top=\"0\";this.frame.appendChild(content);this.frame.appendChild(line);this.frame.appendChild(dot);var contentWidth=content.offsetWidth;var contentHeight=content.offsetHeight;var lineHeight=line.offsetHeight;var dotWidth=dot.offsetWidth;var dotHeight=dot.offsetHeight;var left=dataPoint.screen.x-contentWidth/2;left=Math.min(Math.max(left,10),this.frame.clientWidth-10-contentWidth);line.style.left=dataPoint.screen.x+\"px\";line.style.top=dataPoint.screen.y-lineHeight+\"px\";content.style.left=left+\"px\";content.style.top=dataPoint.screen.y-lineHeight-contentHeight+\"px\";dot.style.left=dataPoint.screen.x-dotWidth/2+\"px\";dot.style.top=dataPoint.screen.y-dotHeight/2+\"px\"};Graph3d.prototype._hideTooltip=function(){if(this.tooltip){this.tooltip.dataPoint=null;for(var prop in this.tooltip.dom){if(this.tooltip.dom.hasOwnProperty(prop)){var elem=this.tooltip.dom[prop];if(elem&&elem.parentNode){elem.parentNode.removeChild(elem)}}}}};function getMouseX(event){if(\"clientX\"in event)return event.clientX;return event.targetTouches[0]&&event.targetTouches[0].clientX||0}function getMouseY(event){if(\"clientY\"in event)return event.clientY;return event.targetTouches[0]&&event.targetTouches[0].clientY||0}Graph3d.prototype.setCameraPosition=function(pos){Settings.setCameraPosition(pos,this);this.redraw()};Graph3d.prototype.setSize=function(width,height){this._setSize(width,height);this.redraw()};module.exports=Graph3d},function(module,exports,__webpack_require__){__webpack_require__(163);module.exports=__webpack_require__(7).Object.assign},function(module,exports,__webpack_require__){var $export=__webpack_require__(17);$export($export.S+$export.F,\"Object\",{assign:__webpack_require__(164)})},function(module,exports,__webpack_require__){\"use strict\";var getKeys=__webpack_require__(33);var gOPS=__webpack_require__(63);var pIE=__webpack_require__(42);var toObject=__webpack_require__(41);var IObject=__webpack_require__(78);var $assign=Object.assign;module.exports=!$assign||__webpack_require__(28)(function(){var A={};var B={};var S=Symbol();var K=\"abcdefghijklmnopqrst\";A[S]=7;K.split(\"\").forEach(function(k){B[k]=k});return $assign({},A)[S]!=7||Object.keys($assign({},B)).join(\"\")!=K})?function assign(target,source){var T=toObject(target);var aLen=arguments.length;var index=1;var getSymbols=gOPS.f;var isEnum=pIE.f;while(aLen>index){var S=IObject(arguments[index++]);var keys=getSymbols?getKeys(S).concat(getSymbols(S)):getKeys(S);var length=keys.length;var j=0;var key;while(length>j)if(isEnum.call(S,key=keys[j++]))T[key]=S[key]}return T}:$assign},function(module,exports,__webpack_require__){module.exports={default:__webpack_require__(166),__esModule:true}},function(module,exports,__webpack_require__){__webpack_require__(167);module.exports=__webpack_require__(7).Math.sign},function(module,exports,__webpack_require__){var $export=__webpack_require__(17);$export($export.S,\"Math\",{sign:__webpack_require__(168)})},function(module,exports){module.exports=Math.sign||function sign(x){return(x=+x)==0||x!=x?x:x<0?-1:1}},function(module,exports,__webpack_require__){module.exports={default:__webpack_require__(170),__esModule:true}},function(module,exports,__webpack_require__){__webpack_require__(171);var $Object=__webpack_require__(7).Object;module.exports=function defineProperty(it,key,desc){return $Object.defineProperty(it,key,desc)}},function(module,exports,__webpack_require__){var $export=__webpack_require__(17);$export($export.S+$export.F*!__webpack_require__(21),\"Object\",{defineProperty:__webpack_require__(20).f})},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var string=\"string\";var bool=\"boolean\";var number=\"number\";var object=\"object\";var colorOptions={fill:{string:string},stroke:{string:string},strokeWidth:{number:number},__type__:{string:string,object:object,undefined:\"undefined\"}};var allOptions={animationAutoStart:{boolean:bool,undefined:\"undefined\"},animationInterval:{number:number},animationPreload:{boolean:bool},axisColor:{string:string},backgroundColor:colorOptions,xBarWidth:{number:number,undefined:\"undefined\"},yBarWidth:{number:number,undefined:\"undefined\"},cameraPosition:{distance:{number:number},horizontal:{number:number},vertical:{number:number},__type__:{object:object}},xCenter:{string:string},yCenter:{string:string},dataColor:colorOptions,dotSizeMinFraction:{number:number},dotSizeMaxFraction:{number:number},dotSizeRatio:{number:number},filterLabel:{string:string},gridColor:{string:string},onclick:{function:\"function\"},keepAspectRatio:{boolean:bool},xLabel:{string:string},yLabel:{string:string},zLabel:{string:string},legendLabel:{string:string},xMin:{number:number,undefined:\"undefined\"},yMin:{number:number,undefined:\"undefined\"},zMin:{number:number,undefined:\"undefined\"},xMax:{number:number,undefined:\"undefined\"},yMax:{number:number,undefined:\"undefined\"},zMax:{number:number,undefined:\"undefined\"},showAnimationControls:{boolean:bool,undefined:\"undefined\"},showGrid:{boolean:bool},showLegend:{boolean:bool,undefined:\"undefined\"},showPerspective:{boolean:bool},showShadow:{boolean:bool},showXAxis:{boolean:bool},showYAxis:{boolean:bool},showZAxis:{boolean:bool},xStep:{number:number,undefined:\"undefined\"},yStep:{number:number,undefined:\"undefined\"},zStep:{number:number,undefined:\"undefined\"},style:{number:number,string:[\"bar\",\"bar-color\",\"bar-size\",\"dot\",\"dot-line\",\"dot-color\",\"dot-size\",\"line\",\"grid\",\"surface\"]},tooltip:{boolean:bool,function:\"function\"},tooltipStyle:{content:{color:{string:string},background:{string:string},border:{string:string},borderRadius:{string:string},boxShadow:{string:string},padding:{string:string},__type__:{object:object}},line:{borderLeft:{string:string},height:{string:string},width:{string:string},__type__:{object:object}},dot:{border:{string:string},borderRadius:{string:string},height:{string:string},width:{string:string},__type__:{object:object}},__type__:{object:object}},xValueLabel:{function:\"function\"},yValueLabel:{function:\"function\"},zValueLabel:{function:\"function\"},valueMax:{number:number,undefined:\"undefined\"},valueMin:{number:number,undefined:\"undefined\"},verticalRatio:{number:number},height:{string:string},width:{string:string},__type__:{object:object}};exports.allOptions=allOptions},function(module,exports,__webpack_require__){\"use strict\";var DataSet=__webpack_require__(11);var DataView=__webpack_require__(12);var Range=__webpack_require__(174);var Filter=__webpack_require__(96);var Settings=__webpack_require__(94);var Point3d=__webpack_require__(34);function DataGroup(){this.dataTable=null}DataGroup.prototype.initializeData=function(graph3d,rawData,style){if(rawData===undefined)return;if(Array.isArray(rawData)){rawData=new DataSet(rawData)}var data;if(rawData instanceof DataSet||rawData instanceof DataView){data=rawData.get()}else{throw new Error(\"Array, DataSet, or DataView expected\")}if(data.length==0)return;this.style=style;if(this.dataSet){this.dataSet.off(\"*\",this._onChange)}this.dataSet=rawData;this.dataTable=data;var me=this;this._onChange=function(){graph3d.setData(me.dataSet)};this.dataSet.on(\"*\",this._onChange);this.colX=\"x\";this.colY=\"y\";this.colZ=\"z\";var withBars=graph3d.hasBars(style);if(withBars){if(graph3d.defaultXBarWidth!==undefined){this.xBarWidth=graph3d.defaultXBarWidth}else{this.xBarWidth=this.getSmallestDifference(data,this.colX)||1}if(graph3d.defaultYBarWidth!==undefined){this.yBarWidth=graph3d.defaultYBarWidth}else{this.yBarWidth=this.getSmallestDifference(data,this.colY)||1}}this._initializeRange(data,this.colX,graph3d,withBars);this._initializeRange(data,this.colY,graph3d,withBars);this._initializeRange(data,this.colZ,graph3d,false);if(data[0].hasOwnProperty(\"style\")){this.colValue=\"style\";var valueRange=this.getColumnRange(data,this.colValue);this._setRangeDefaults(valueRange,graph3d.defaultValueMin,graph3d.defaultValueMax);this.valueRange=valueRange}var table=this.getDataTable();if(table[0].hasOwnProperty(\"filter\")){if(this.dataFilter===undefined){this.dataFilter=new Filter(this,\"filter\",graph3d);this.dataFilter.setOnLoadCallback(function(){graph3d.redraw()})}}var dataPoints;if(this.dataFilter){dataPoints=this.dataFilter._getDataPoints()}else{dataPoints=this._getDataPoints(this.getDataTable())}return dataPoints};DataGroup.prototype._collectRangeSettings=function(column,graph3d){var index=[\"x\",\"y\",\"z\"].indexOf(column);if(index==-1){throw new Error(\"Column '\"+column+\"' invalid\")}var upper=column.toUpperCase();return{barWidth:this[column+\"BarWidth\"],min:graph3d[\"default\"+upper+\"Min\"],max:graph3d[\"default\"+upper+\"Max\"],step:graph3d[\"default\"+upper+\"Step\"],range_label:column+\"Range\",step_label:column+\"Step\"}};DataGroup.prototype._initializeRange=function(data,column,graph3d,withBars){var NUMSTEPS=5;var settings=this._collectRangeSettings(column,graph3d);var range=this.getColumnRange(data,column);if(withBars&&column!=\"z\"){range.expand(settings.barWidth/2)}this._setRangeDefaults(range,settings.min,settings.max);this[settings.range_label]=range;this[settings.step_label]=settings.step!==undefined?settings.step:range.range()/NUMSTEPS};DataGroup.prototype.getDistinctValues=function(column,data){if(data===undefined){data=this.dataTable}var values=[];for(var i=0;i<data.length;i++){var value=data[i][column]||0;if(values.indexOf(value)===-1){values.push(value)}}return values.sort(function(a,b){return a-b})};DataGroup.prototype.getSmallestDifference=function(data,column){var values=this.getDistinctValues(data,column);var smallest_diff=null;for(var i=1;i<values.length;i++){var diff=values[i]-values[i-1];if(smallest_diff==null||smallest_diff>diff){smallest_diff=diff}}return smallest_diff};DataGroup.prototype.getColumnRange=function(data,column){var range=new Range;for(var i=0;i<data.length;i++){var item=data[i][column];range.adjust(item)}return range};DataGroup.prototype.getNumberOfRows=function(){return this.dataTable.length};DataGroup.prototype._setRangeDefaults=function(range,defaultMin,defaultMax){if(defaultMin!==undefined){range.min=defaultMin}if(defaultMax!==undefined){range.max=defaultMax}if(range.max<=range.min)range.max=range.min+1};DataGroup.prototype.getDataTable=function(){return this.dataTable};DataGroup.prototype.getDataSet=function(){return this.dataSet};DataGroup.prototype.getDataPoints=function(data){var dataPoints=[];for(var i=0;i<data.length;i++){var point=new Point3d;point.x=data[i][this.colX]||0;point.y=data[i][this.colY]||0;point.z=data[i][this.colZ]||0;point.data=data[i];if(this.colValue!==undefined){point.value=data[i][this.colValue]||0}var obj={};obj.point=point;obj.bottom=new Point3d(point.x,point.y,this.zRange.min);obj.trans=undefined;obj.screen=undefined;dataPoints.push(obj)}return dataPoints};DataGroup.prototype.initDataAsMatrix=function(data){var x,y,i,obj;var dataX=this.getDistinctValues(this.colX,data);var dataY=this.getDistinctValues(this.colY,data);var dataPoints=this.getDataPoints(data);var dataMatrix=[];for(i=0;i<dataPoints.length;i++){obj=dataPoints[i];var xIndex=dataX.indexOf(obj.point.x);var yIndex=dataY.indexOf(obj.point.y);if(dataMatrix[xIndex]===undefined){dataMatrix[xIndex]=[]}dataMatrix[xIndex][yIndex]=obj}for(x=0;x<dataMatrix.length;x++){for(y=0;y<dataMatrix[x].length;y++){if(dataMatrix[x][y]){dataMatrix[x][y].pointRight=x<dataMatrix.length-1?dataMatrix[x+1][y]:undefined;dataMatrix[x][y].pointTop=y<dataMatrix[x].length-1?dataMatrix[x][y+1]:undefined;dataMatrix[x][y].pointCross=x<dataMatrix.length-1&&y<dataMatrix[x].length-1?dataMatrix[x+1][y+1]:undefined}}}return dataPoints};DataGroup.prototype.getInfo=function(){var dataFilter=this.dataFilter;if(!dataFilter)return undefined;return dataFilter.getLabel()+\": \"+dataFilter.getSelectedValue()};DataGroup.prototype.reload=function(){if(this.dataTable){this.setData(this.dataTable)}};DataGroup.prototype._getDataPoints=function(data){var dataPoints=[];if(this.style===Settings.STYLE.GRID||this.style===Settings.STYLE.SURFACE){dataPoints=this.initDataAsMatrix(data)}else{this._checkValueField(data);dataPoints=this.getDataPoints(data);if(this.style===Settings.STYLE.LINE){for(var i=0;i<dataPoints.length;i++){if(i>0){dataPoints[i-1].pointNext=dataPoints[i]}}}}return dataPoints};DataGroup.prototype._checkValueField=function(data){var hasValueField=this.style===Settings.STYLE.BARCOLOR||this.style===Settings.STYLE.BARSIZE||this.style===Settings.STYLE.DOTCOLOR||this.style===Settings.STYLE.DOTSIZE;if(!hasValueField){return}if(this.colValue===undefined){throw new Error(\"Expected data to have \"+\" field 'style' \"+\" for graph style '\"+this.style+\"'\")}if(data[0][this.colValue]===undefined){throw new Error(\"Expected data to have \"+\" field '\"+this.colValue+\"' \"+\" for graph style '\"+this.style+\"'\")}};module.exports=DataGroup},function(module,exports,__webpack_require__){\"use strict\";function Range(){this.min=undefined;this.max=undefined}Range.prototype.adjust=function(value){if(value===undefined)return;if(this.min===undefined||this.min>value){this.min=value}if(this.max===undefined||this.max<value){this.max=value}};Range.prototype.combine=function(range){this.add(range.min);this.add(range.max)};Range.prototype.expand=function(val){if(val===undefined){return}var newMin=this.min-val;var newMax=this.max+val;if(newMin>newMax){throw new Error(\"Passed expansion value makes range invalid\")}this.min=newMin;this.max=newMax};Range.prototype.range=function(){return this.max-this.min};Range.prototype.center=function(){return(this.min+this.max)/2};module.exports=Range},function(module,exports,__webpack_require__){\"use strict\";var __WEBPACK_AMD_DEFINE_FACTORY__,__WEBPACK_AMD_DEFINE_ARRAY__,__WEBPACK_AMD_DEFINE_RESULT__;(function(factory){if(true){!(__WEBPACK_AMD_DEFINE_ARRAY__=[],__WEBPACK_AMD_DEFINE_FACTORY__=factory,__WEBPACK_AMD_DEFINE_RESULT__=typeof __WEBPACK_AMD_DEFINE_FACTORY__===\"function\"?__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports,__WEBPACK_AMD_DEFINE_ARRAY__):__WEBPACK_AMD_DEFINE_FACTORY__,__WEBPACK_AMD_DEFINE_RESULT__!==undefined&&(module.exports=__WEBPACK_AMD_DEFINE_RESULT__))}else if(typeof exports===\"object\"){module.exports=factory()}else{window.propagating=factory()}})(function(){var _firstTarget=null;return function propagating(hammer,options){var _options=options||{preventDefault:false};if(hammer.Manager){var Hammer=hammer;var PropagatingHammer=function(element,options){var o=Object.create(_options);if(options)Hammer.assign(o,options);return propagating(new Hammer(element,o),o)};Hammer.assign(PropagatingHammer,Hammer);PropagatingHammer.Manager=function(element,options){var o=Object.create(_options);if(options)Hammer.assign(o,options);return propagating(new Hammer.Manager(element,o),o)};return PropagatingHammer}var wrapper=Object.create(hammer);var element=hammer.element;if(!element.hammer)element.hammer=[];element.hammer.push(wrapper);hammer.on(\"hammer.input\",function(event){if(_options.preventDefault===true||_options.preventDefault===event.pointerType){event.preventDefault()}if(event.isFirst){_firstTarget=event.target}});wrapper._handlers={};wrapper.on=function(events,handler){split(events).forEach(function(event){var _handlers=wrapper._handlers[event];if(!_handlers){wrapper._handlers[event]=_handlers=[];hammer.on(event,propagatedHandler)}_handlers.push(handler)});return wrapper};wrapper.off=function(events,handler){split(events).forEach(function(event){var _handlers=wrapper._handlers[event];if(_handlers){_handlers=handler?_handlers.filter(function(h){return h!==handler}):[];if(_handlers.length>0){wrapper._handlers[event]=_handlers}else{hammer.off(event,propagatedHandler);delete wrapper._handlers[event]}}});return wrapper};wrapper.emit=function(eventType,event){_firstTarget=event.target;hammer.emit(eventType,event)};wrapper.destroy=function(){var hammers=hammer.element.hammer;var idx=hammers.indexOf(wrapper);if(idx!==-1)hammers.splice(idx,1);if(!hammers.length)delete hammer.element.hammer;wrapper._handlers={};hammer.destroy()};function split(events){return events.match(/[^ ]+/g)}function propagatedHandler(event){if(event.type!==\"hammer.input\"){if(!event.srcEvent._handled){event.srcEvent._handled={}}if(event.srcEvent._handled[event.type]){return}else{event.srcEvent._handled[event.type]=true}}var stopped=false\n;event.stopPropagation=function(){stopped=true};var srcStop=event.srcEvent.stopPropagation.bind(event.srcEvent);if(typeof srcStop==\"function\"){event.srcEvent.stopPropagation=function(){srcStop();event.stopPropagation()}}event.firstTarget=_firstTarget;var elem=_firstTarget;while(elem&&!stopped){var elemHammer=elem.hammer;if(elemHammer){var _handlers;for(var k=0;k<elemHammer.length;k++){_handlers=elemHammer[k]._handlers[event.type];if(_handlers)for(var i=0;i<_handlers.length&&!stopped;i++){_handlers[i](event)}}}elem=elem.parentNode}}return wrapper}})},function(module,exports,__webpack_require__){var __WEBPACK_AMD_DEFINE_RESULT__;(function(window,document,exportName,undefined){\"use strict\";var VENDOR_PREFIXES=[\"\",\"webkit\",\"Moz\",\"MS\",\"ms\",\"o\"];var TEST_ELEMENT=document.createElement(\"div\");var TYPE_FUNCTION=\"function\";var round=Math.round;var abs=Math.abs;var now=Date.now;function setTimeoutContext(fn,timeout,context){return setTimeout(bindFn(fn,context),timeout)}function invokeArrayArg(arg,fn,context){if(Array.isArray(arg)){each(arg,context[fn],context);return true}return false}function each(obj,iterator,context){var i;if(!obj){return}if(obj.forEach){obj.forEach(iterator,context)}else if(obj.length!==undefined){i=0;while(i<obj.length){iterator.call(context,obj[i],i,obj);i++}}else{for(i in obj){obj.hasOwnProperty(i)&&iterator.call(context,obj[i],i,obj)}}}function deprecate(method,name,message){var deprecationMessage=\"DEPRECATED METHOD: \"+name+\"\\n\"+message+\" AT \\n\";return function(){var e=new Error(\"get-stack-trace\");var stack=e&&e.stack?e.stack.replace(/^[^\\(]+?[\\n$]/gm,\"\").replace(/^\\s+at\\s+/gm,\"\").replace(/^Object.<anonymous>\\s*\\(/gm,\"{anonymous}()@\"):\"Unknown Stack Trace\";var log=window.console&&(window.console.warn||window.console.log);if(log){log.call(window.console,deprecationMessage,stack)}return method.apply(this,arguments)}}var assign;if(typeof Object.assign!==\"function\"){assign=function assign(target){if(target===undefined||target===null){throw new TypeError(\"Cannot convert undefined or null to object\")}var output=Object(target);for(var index=1;index<arguments.length;index++){var source=arguments[index];if(source!==undefined&&source!==null){for(var nextKey in source){if(source.hasOwnProperty(nextKey)){output[nextKey]=source[nextKey]}}}}return output}}else{assign=Object.assign}var extend=deprecate(function extend(dest,src,merge){var keys=Object.keys(src);var i=0;while(i<keys.length){if(!merge||merge&&dest[keys[i]]===undefined){dest[keys[i]]=src[keys[i]]}i++}return dest},\"extend\",\"Use `assign`.\");var merge=deprecate(function merge(dest,src){return extend(dest,src,true)},\"merge\",\"Use `assign`.\");function inherit(child,base,properties){var baseP=base.prototype,childP;childP=child.prototype=Object.create(baseP);childP.constructor=child;childP._super=baseP;if(properties){assign(childP,properties)}}function bindFn(fn,context){return function boundFn(){return fn.apply(context,arguments)}}function boolOrFn(val,args){if(typeof val==TYPE_FUNCTION){return val.apply(args?args[0]||undefined:undefined,args)}return val}function ifUndefined(val1,val2){return val1===undefined?val2:val1}function addEventListeners(target,types,handler){each(splitStr(types),function(type){target.addEventListener(type,handler,false)})}function removeEventListeners(target,types,handler){each(splitStr(types),function(type){target.removeEventListener(type,handler,false)})}function hasParent(node,parent){while(node){if(node==parent){return true}node=node.parentNode}return false}function inStr(str,find){return str.indexOf(find)>-1}function splitStr(str){return str.trim().split(/\\s+/g)}function inArray(src,find,findByKey){if(src.indexOf&&!findByKey){return src.indexOf(find)}else{var i=0;while(i<src.length){if(findByKey&&src[i][findByKey]==find||!findByKey&&src[i]===find){return i}i++}return-1}}function toArray(obj){return Array.prototype.slice.call(obj,0)}function uniqueArray(src,key,sort){var results=[];var values=[];var i=0;while(i<src.length){var val=key?src[i][key]:src[i];if(inArray(values,val)<0){results.push(src[i])}values[i]=val;i++}if(sort){if(!key){results=results.sort()}else{results=results.sort(function sortUniqueArray(a,b){return a[key]>b[key]})}}return results}function prefixed(obj,property){var prefix,prop;var camelProp=property[0].toUpperCase()+property.slice(1);var i=0;while(i<VENDOR_PREFIXES.length){prefix=VENDOR_PREFIXES[i];prop=prefix?prefix+camelProp:property;if(prop in obj){return prop}i++}return undefined}var _uniqueId=1;function uniqueId(){return _uniqueId++}function getWindowForElement(element){var doc=element.ownerDocument||element;return doc.defaultView||doc.parentWindow||window}var MOBILE_REGEX=/mobile|tablet|ip(ad|hone|od)|android/i;var SUPPORT_TOUCH=\"ontouchstart\"in window;var SUPPORT_POINTER_EVENTS=prefixed(window,\"PointerEvent\")!==undefined;var SUPPORT_ONLY_TOUCH=SUPPORT_TOUCH&&MOBILE_REGEX.test(navigator.userAgent);var INPUT_TYPE_TOUCH=\"touch\";var INPUT_TYPE_PEN=\"pen\";var INPUT_TYPE_MOUSE=\"mouse\";var INPUT_TYPE_KINECT=\"kinect\";var COMPUTE_INTERVAL=25;var INPUT_START=1;var INPUT_MOVE=2;var INPUT_END=4;var INPUT_CANCEL=8;var DIRECTION_NONE=1;var DIRECTION_LEFT=2;var DIRECTION_RIGHT=4;var DIRECTION_UP=8;var DIRECTION_DOWN=16;var DIRECTION_HORIZONTAL=DIRECTION_LEFT|DIRECTION_RIGHT;var DIRECTION_VERTICAL=DIRECTION_UP|DIRECTION_DOWN;var DIRECTION_ALL=DIRECTION_HORIZONTAL|DIRECTION_VERTICAL;var PROPS_XY=[\"x\",\"y\"];var PROPS_CLIENT_XY=[\"clientX\",\"clientY\"];function Input(manager,callback){var self=this;this.manager=manager;this.callback=callback;this.element=manager.element;this.target=manager.options.inputTarget;this.domHandler=function(ev){if(boolOrFn(manager.options.enable,[manager])){self.handler(ev)}};this.init()}Input.prototype={handler:function(){},init:function(){this.evEl&&addEventListeners(this.element,this.evEl,this.domHandler);this.evTarget&&addEventListeners(this.target,this.evTarget,this.domHandler);this.evWin&&addEventListeners(getWindowForElement(this.element),this.evWin,this.domHandler)},destroy:function(){this.evEl&&removeEventListeners(this.element,this.evEl,this.domHandler);this.evTarget&&removeEventListeners(this.target,this.evTarget,this.domHandler);this.evWin&&removeEventListeners(getWindowForElement(this.element),this.evWin,this.domHandler)}};function createInputInstance(manager){var Type;var inputClass=manager.options.inputClass;if(inputClass){Type=inputClass}else if(SUPPORT_POINTER_EVENTS){Type=PointerEventInput}else if(SUPPORT_ONLY_TOUCH){Type=TouchInput}else if(!SUPPORT_TOUCH){Type=MouseInput}else{Type=TouchMouseInput}return new Type(manager,inputHandler)}function inputHandler(manager,eventType,input){var pointersLen=input.pointers.length;var changedPointersLen=input.changedPointers.length;var isFirst=eventType&INPUT_START&&pointersLen-changedPointersLen===0;var isFinal=eventType&(INPUT_END|INPUT_CANCEL)&&pointersLen-changedPointersLen===0;input.isFirst=!!isFirst;input.isFinal=!!isFinal;if(isFirst){manager.session={}}input.eventType=eventType;computeInputData(manager,input);manager.emit(\"hammer.input\",input);manager.recognize(input);manager.session.prevInput=input}function computeInputData(manager,input){var session=manager.session;var pointers=input.pointers;var pointersLength=pointers.length;if(!session.firstInput){session.firstInput=simpleCloneInputData(input)}if(pointersLength>1&&!session.firstMultiple){session.firstMultiple=simpleCloneInputData(input)}else if(pointersLength===1){session.firstMultiple=false}var firstInput=session.firstInput;var firstMultiple=session.firstMultiple;var offsetCenter=firstMultiple?firstMultiple.center:firstInput.center;var center=input.center=getCenter(pointers);input.timeStamp=now();input.deltaTime=input.timeStamp-firstInput.timeStamp;input.angle=getAngle(offsetCenter,center);input.distance=getDistance(offsetCenter,center);computeDeltaXY(session,input);input.offsetDirection=getDirection(input.deltaX,input.deltaY);var overallVelocity=getVelocity(input.deltaTime,input.deltaX,input.deltaY);input.overallVelocityX=overallVelocity.x;input.overallVelocityY=overallVelocity.y;input.overallVelocity=abs(overallVelocity.x)>abs(overallVelocity.y)?overallVelocity.x:overallVelocity.y;input.scale=firstMultiple?getScale(firstMultiple.pointers,pointers):1;input.rotation=firstMultiple?getRotation(firstMultiple.pointers,pointers):0;input.maxPointers=!session.prevInput?input.pointers.length:input.pointers.length>session.prevInput.maxPointers?input.pointers.length:session.prevInput.maxPointers;computeIntervalInputData(session,input);var target=manager.element;if(hasParent(input.srcEvent.target,target)){target=input.srcEvent.target}input.target=target}function computeDeltaXY(session,input){var center=input.center;var offset=session.offsetDelta||{};var prevDelta=session.prevDelta||{};var prevInput=session.prevInput||{};if(input.eventType===INPUT_START||prevInput.eventType===INPUT_END){prevDelta=session.prevDelta={x:prevInput.deltaX||0,y:prevInput.deltaY||0};offset=session.offsetDelta={x:center.x,y:center.y}}input.deltaX=prevDelta.x+(center.x-offset.x);input.deltaY=prevDelta.y+(center.y-offset.y)}function computeIntervalInputData(session,input){var last=session.lastInterval||input,deltaTime=input.timeStamp-last.timeStamp,velocity,velocityX,velocityY,direction;if(input.eventType!=INPUT_CANCEL&&(deltaTime>COMPUTE_INTERVAL||last.velocity===undefined)){var deltaX=input.deltaX-last.deltaX;var deltaY=input.deltaY-last.deltaY;var v=getVelocity(deltaTime,deltaX,deltaY);velocityX=v.x;velocityY=v.y;velocity=abs(v.x)>abs(v.y)?v.x:v.y;direction=getDirection(deltaX,deltaY);session.lastInterval=input}else{velocity=last.velocity;velocityX=last.velocityX;velocityY=last.velocityY;direction=last.direction}input.velocity=velocity;input.velocityX=velocityX;input.velocityY=velocityY;input.direction=direction}function simpleCloneInputData(input){var pointers=[];var i=0;while(i<input.pointers.length){pointers[i]={clientX:round(input.pointers[i].clientX),clientY:round(input.pointers[i].clientY)};i++}return{timeStamp:now(),pointers:pointers,center:getCenter(pointers),deltaX:input.deltaX,deltaY:input.deltaY}}function getCenter(pointers){var pointersLength=pointers.length;if(pointersLength===1){return{x:round(pointers[0].clientX),y:round(pointers[0].clientY)}}var x=0,y=0,i=0;while(i<pointersLength){x+=pointers[i].clientX;y+=pointers[i].clientY;i++}return{x:round(x/pointersLength),y:round(y/pointersLength)}}function getVelocity(deltaTime,x,y){return{x:x/deltaTime||0,y:y/deltaTime||0}}function getDirection(x,y){if(x===y){return DIRECTION_NONE}if(abs(x)>=abs(y)){return x<0?DIRECTION_LEFT:DIRECTION_RIGHT}return y<0?DIRECTION_UP:DIRECTION_DOWN}function getDistance(p1,p2,props){if(!props){props=PROPS_XY}var x=p2[props[0]]-p1[props[0]],y=p2[props[1]]-p1[props[1]];return Math.sqrt(x*x+y*y)}function getAngle(p1,p2,props){if(!props){props=PROPS_XY}var x=p2[props[0]]-p1[props[0]],y=p2[props[1]]-p1[props[1]];return Math.atan2(y,x)*180/Math.PI}function getRotation(start,end){return getAngle(end[1],end[0],PROPS_CLIENT_XY)+getAngle(start[1],start[0],PROPS_CLIENT_XY)}function getScale(start,end){return getDistance(end[0],end[1],PROPS_CLIENT_XY)/getDistance(start[0],start[1],PROPS_CLIENT_XY)}var MOUSE_INPUT_MAP={mousedown:INPUT_START,mousemove:INPUT_MOVE,mouseup:INPUT_END};var MOUSE_ELEMENT_EVENTS=\"mousedown\";var MOUSE_WINDOW_EVENTS=\"mousemove mouseup\";function MouseInput(){this.evEl=MOUSE_ELEMENT_EVENTS;this.evWin=MOUSE_WINDOW_EVENTS;this.pressed=false;Input.apply(this,arguments)}inherit(MouseInput,Input,{handler:function MEhandler(ev){var eventType=MOUSE_INPUT_MAP[ev.type];if(eventType&INPUT_START&&ev.button===0){this.pressed=true}if(eventType&INPUT_MOVE&&ev.which!==1){eventType=INPUT_END}if(!this.pressed){return}if(eventType&INPUT_END){this.pressed=false}this.callback(this.manager,eventType,{pointers:[ev],changedPointers:[ev],pointerType:INPUT_TYPE_MOUSE,srcEvent:ev})}});var POINTER_INPUT_MAP={pointerdown:INPUT_START,pointermove:INPUT_MOVE,pointerup:INPUT_END,pointercancel:INPUT_CANCEL,pointerout:INPUT_CANCEL};var IE10_POINTER_TYPE_ENUM={2:INPUT_TYPE_TOUCH,3:INPUT_TYPE_PEN,4:INPUT_TYPE_MOUSE,5:INPUT_TYPE_KINECT};var POINTER_ELEMENT_EVENTS=\"pointerdown\";var POINTER_WINDOW_EVENTS=\"pointermove pointerup pointercancel\";if(window.MSPointerEvent&&!window.PointerEvent){POINTER_ELEMENT_EVENTS=\"MSPointerDown\";POINTER_WINDOW_EVENTS=\"MSPointerMove MSPointerUp MSPointerCancel\"}function PointerEventInput(){this.evEl=POINTER_ELEMENT_EVENTS;this.evWin=POINTER_WINDOW_EVENTS;Input.apply(this,arguments);this.store=this.manager.session.pointerEvents=[]}inherit(PointerEventInput,Input,{handler:function PEhandler(ev){var store=this.store;var removePointer=false;var eventTypeNormalized=ev.type.toLowerCase().replace(\"ms\",\"\");var eventType=POINTER_INPUT_MAP[eventTypeNormalized];var pointerType=IE10_POINTER_TYPE_ENUM[ev.pointerType]||ev.pointerType;var isTouch=pointerType==INPUT_TYPE_TOUCH;var storeIndex=inArray(store,ev.pointerId,\"pointerId\");if(eventType&INPUT_START&&(ev.button===0||isTouch)){if(storeIndex<0){store.push(ev);storeIndex=store.length-1}}else if(eventType&(INPUT_END|INPUT_CANCEL)){removePointer=true}if(storeIndex<0){return}store[storeIndex]=ev;this.callback(this.manager,eventType,{pointers:store,changedPointers:[ev],pointerType:pointerType,srcEvent:ev});if(removePointer){store.splice(storeIndex,1)}}});var SINGLE_TOUCH_INPUT_MAP={touchstart:INPUT_START,touchmove:INPUT_MOVE,touchend:INPUT_END,touchcancel:INPUT_CANCEL};var SINGLE_TOUCH_TARGET_EVENTS=\"touchstart\";var SINGLE_TOUCH_WINDOW_EVENTS=\"touchstart touchmove touchend touchcancel\";function SingleTouchInput(){this.evTarget=SINGLE_TOUCH_TARGET_EVENTS;this.evWin=SINGLE_TOUCH_WINDOW_EVENTS;this.started=false;Input.apply(this,arguments)}inherit(SingleTouchInput,Input,{handler:function TEhandler(ev){var type=SINGLE_TOUCH_INPUT_MAP[ev.type];if(type===INPUT_START){this.started=true}if(!this.started){return}var touches=normalizeSingleTouches.call(this,ev,type);if(type&(INPUT_END|INPUT_CANCEL)&&touches[0].length-touches[1].length===0){this.started=false}this.callback(this.manager,type,{pointers:touches[0],changedPointers:touches[1],pointerType:INPUT_TYPE_TOUCH,srcEvent:ev})}});function normalizeSingleTouches(ev,type){var all=toArray(ev.touches);var changed=toArray(ev.changedTouches);if(type&(INPUT_END|INPUT_CANCEL)){all=uniqueArray(all.concat(changed),\"identifier\",true)}return[all,changed]}var TOUCH_INPUT_MAP={touchstart:INPUT_START,touchmove:INPUT_MOVE,touchend:INPUT_END,touchcancel:INPUT_CANCEL};var TOUCH_TARGET_EVENTS=\"touchstart touchmove touchend touchcancel\";function TouchInput(){this.evTarget=TOUCH_TARGET_EVENTS;this.targetIds={};Input.apply(this,arguments)}inherit(TouchInput,Input,{handler:function MTEhandler(ev){var type=TOUCH_INPUT_MAP[ev.type];var touches=getTouches.call(this,ev,type);if(!touches){return}this.callback(this.manager,type,{pointers:touches[0],changedPointers:touches[1],pointerType:INPUT_TYPE_TOUCH,srcEvent:ev})}});function getTouches(ev,type){var allTouches=toArray(ev.touches);var targetIds=this.targetIds;if(type&(INPUT_START|INPUT_MOVE)&&allTouches.length===1){targetIds[allTouches[0].identifier]=true;return[allTouches,allTouches]}var i,targetTouches,changedTouches=toArray(ev.changedTouches),changedTargetTouches=[],target=this.target;targetTouches=allTouches.filter(function(touch){return hasParent(touch.target,target)});if(type===INPUT_START){i=0;while(i<targetTouches.length){targetIds[targetTouches[i].identifier]=true;i++}}i=0;while(i<changedTouches.length){if(targetIds[changedTouches[i].identifier]){changedTargetTouches.push(changedTouches[i])}if(type&(INPUT_END|INPUT_CANCEL)){delete targetIds[changedTouches[i].identifier]}i++}if(!changedTargetTouches.length){return}return[uniqueArray(targetTouches.concat(changedTargetTouches),\"identifier\",true),changedTargetTouches]}var DEDUP_TIMEOUT=2500;var DEDUP_DISTANCE=25;function TouchMouseInput(){Input.apply(this,arguments);var handler=bindFn(this.handler,this);this.touch=new TouchInput(this.manager,handler);this.mouse=new MouseInput(this.manager,handler);this.primaryTouch=null;this.lastTouches=[]}inherit(TouchMouseInput,Input,{handler:function TMEhandler(manager,inputEvent,inputData){var isTouch=inputData.pointerType==INPUT_TYPE_TOUCH,isMouse=inputData.pointerType==INPUT_TYPE_MOUSE;if(isMouse&&inputData.sourceCapabilities&&inputData.sourceCapabilities.firesTouchEvents){return}if(isTouch){recordTouches.call(this,inputEvent,inputData)}else if(isMouse&&isSyntheticEvent.call(this,inputData)){return}this.callback(manager,inputEvent,inputData)},destroy:function destroy(){this.touch.destroy();this.mouse.destroy()}});function recordTouches(eventType,eventData){if(eventType&INPUT_START){this.primaryTouch=eventData.changedPointers[0].identifier;setLastTouch.call(this,eventData)}else if(eventType&(INPUT_END|INPUT_CANCEL)){setLastTouch.call(this,eventData)}}function setLastTouch(eventData){var touch=eventData.changedPointers[0];if(touch.identifier===this.primaryTouch){var lastTouch={x:touch.clientX,y:touch.clientY};this.lastTouches.push(lastTouch);var lts=this.lastTouches;var removeLastTouch=function(){var i=lts.indexOf(lastTouch);if(i>-1){lts.splice(i,1)}};setTimeout(removeLastTouch,DEDUP_TIMEOUT)}}function isSyntheticEvent(eventData){var x=eventData.srcEvent.clientX,y=eventData.srcEvent.clientY;for(var i=0;i<this.lastTouches.length;i++){var t=this.lastTouches[i];var dx=Math.abs(x-t.x),dy=Math.abs(y-t.y);if(dx<=DEDUP_DISTANCE&&dy<=DEDUP_DISTANCE){return true}}return false}var PREFIXED_TOUCH_ACTION=prefixed(TEST_ELEMENT.style,\"touchAction\");var NATIVE_TOUCH_ACTION=PREFIXED_TOUCH_ACTION!==undefined;var TOUCH_ACTION_COMPUTE=\"compute\";var TOUCH_ACTION_AUTO=\"auto\";var TOUCH_ACTION_MANIPULATION=\"manipulation\";var TOUCH_ACTION_NONE=\"none\";var TOUCH_ACTION_PAN_X=\"pan-x\";var TOUCH_ACTION_PAN_Y=\"pan-y\";var TOUCH_ACTION_MAP=getTouchActionProps();function TouchAction(manager,value){this.manager=manager;this.set(value)}TouchAction.prototype={set:function(value){if(value==TOUCH_ACTION_COMPUTE){value=this.compute()}if(NATIVE_TOUCH_ACTION&&this.manager.element.style&&TOUCH_ACTION_MAP[value]){this.manager.element.style[PREFIXED_TOUCH_ACTION]=value}this.actions=value.toLowerCase().trim()},update:function(){this.set(this.manager.options.touchAction)},compute:function(){var actions=[];each(this.manager.recognizers,function(recognizer){if(boolOrFn(recognizer.options.enable,[recognizer])){actions=actions.concat(recognizer.getTouchAction())}});return cleanTouchActions(actions.join(\" \"))},preventDefaults:function(input){var srcEvent=input.srcEvent;var direction=input.offsetDirection;if(this.manager.session.prevented){srcEvent.preventDefault();return}var actions=this.actions;var hasNone=inStr(actions,TOUCH_ACTION_NONE)&&!TOUCH_ACTION_MAP[TOUCH_ACTION_NONE];var hasPanY=inStr(actions,TOUCH_ACTION_PAN_Y)&&!TOUCH_ACTION_MAP[TOUCH_ACTION_PAN_Y];var hasPanX=inStr(actions,TOUCH_ACTION_PAN_X)&&!TOUCH_ACTION_MAP[TOUCH_ACTION_PAN_X];if(hasNone){var isTapPointer=input.pointers.length===1;var isTapMovement=input.distance<2;var isTapTouchTime=input.deltaTime<250;if(isTapPointer&&isTapMovement&&isTapTouchTime){return}}if(hasPanX&&hasPanY){return}if(hasNone||hasPanY&&direction&DIRECTION_HORIZONTAL||hasPanX&&direction&DIRECTION_VERTICAL){return this.preventSrc(srcEvent)}},preventSrc:function(srcEvent){this.manager.session.prevented=true;srcEvent.preventDefault()}};function cleanTouchActions(actions){if(inStr(actions,TOUCH_ACTION_NONE)){return TOUCH_ACTION_NONE}var hasPanX=inStr(actions,TOUCH_ACTION_PAN_X);var hasPanY=inStr(actions,TOUCH_ACTION_PAN_Y);if(hasPanX&&hasPanY){return TOUCH_ACTION_NONE}if(hasPanX||hasPanY){return hasPanX?TOUCH_ACTION_PAN_X:TOUCH_ACTION_PAN_Y}if(inStr(actions,TOUCH_ACTION_MANIPULATION)){return TOUCH_ACTION_MANIPULATION}return TOUCH_ACTION_AUTO}function getTouchActionProps(){if(!NATIVE_TOUCH_ACTION){return false}var touchMap={};var cssSupports=window.CSS&&window.CSS.supports;[\"auto\",\"manipulation\",\"pan-y\",\"pan-x\",\"pan-x pan-y\",\"none\"].forEach(function(val){touchMap[val]=cssSupports?window.CSS.supports(\"touch-action\",val):true});return touchMap}var STATE_POSSIBLE=1;var STATE_BEGAN=2;var STATE_CHANGED=4;var STATE_ENDED=8;var STATE_RECOGNIZED=STATE_ENDED;var STATE_CANCELLED=16;var STATE_FAILED=32;function Recognizer(options){this.options=assign({},this.defaults,options||{});this.id=uniqueId();this.manager=null;this.options.enable=ifUndefined(this.options.enable,true);this.state=STATE_POSSIBLE;this.simultaneous={};this.requireFail=[]}Recognizer.prototype={defaults:{},set:function(options){assign(this.options,options);this.manager&&this.manager.touchAction.update();return this},recognizeWith:function(otherRecognizer){if(invokeArrayArg(otherRecognizer,\"recognizeWith\",this)){return this}var simultaneous=this.simultaneous;otherRecognizer=getRecognizerByNameIfManager(otherRecognizer,this);if(!simultaneous[otherRecognizer.id]){simultaneous[otherRecognizer.id]=otherRecognizer;otherRecognizer.recognizeWith(this)}return this},dropRecognizeWith:function(otherRecognizer){if(invokeArrayArg(otherRecognizer,\"dropRecognizeWith\",this)){return this}otherRecognizer=getRecognizerByNameIfManager(otherRecognizer,this);delete this.simultaneous[otherRecognizer.id];return this},requireFailure:function(otherRecognizer){if(invokeArrayArg(otherRecognizer,\"requireFailure\",this)){return this}var requireFail=this.requireFail;otherRecognizer=getRecognizerByNameIfManager(otherRecognizer,this);if(inArray(requireFail,otherRecognizer)===-1){requireFail.push(otherRecognizer);otherRecognizer.requireFailure(this)}return this},dropRequireFailure:function(otherRecognizer){if(invokeArrayArg(otherRecognizer,\"dropRequireFailure\",this)){return this}otherRecognizer=getRecognizerByNameIfManager(otherRecognizer,this);var index=inArray(this.requireFail,otherRecognizer);if(index>-1){this.requireFail.splice(index,1)}return this},hasRequireFailures:function(){return this.requireFail.length>0},canRecognizeWith:function(otherRecognizer){return!!this.simultaneous[otherRecognizer.id]},emit:function(input){var self=this;var state=this.state;function emit(event){self.manager.emit(event,input)}if(state<STATE_ENDED){emit(self.options.event+stateStr(state))}emit(self.options.event);if(input.additionalEvent){emit(input.additionalEvent)}if(state>=STATE_ENDED){emit(self.options.event+stateStr(state))}},tryEmit:function(input){if(this.canEmit()){return this.emit(input)}this.state=STATE_FAILED},canEmit:function(){var i=0;while(i<this.requireFail.length){if(!(this.requireFail[i].state&(STATE_FAILED|STATE_POSSIBLE))){return false}i++}return true},recognize:function(inputData){var inputDataClone=assign({},inputData);if(!boolOrFn(this.options.enable,[this,inputDataClone])){this.reset();this.state=STATE_FAILED;return}if(this.state&(STATE_RECOGNIZED|STATE_CANCELLED|STATE_FAILED)){this.state=STATE_POSSIBLE}this.state=this.process(inputDataClone);if(this.state&(STATE_BEGAN|STATE_CHANGED|STATE_ENDED|STATE_CANCELLED)){this.tryEmit(inputDataClone)}},process:function(inputData){},getTouchAction:function(){},reset:function(){}};function stateStr(state){if(state&STATE_CANCELLED){return\"cancel\"}else if(state&STATE_ENDED){return\"end\"}else if(state&STATE_CHANGED){return\"move\"}else if(state&STATE_BEGAN){return\"start\"}return\"\"}function directionStr(direction){if(direction==DIRECTION_DOWN){return\"down\"}else if(direction==DIRECTION_UP){return\"up\"}else if(direction==DIRECTION_LEFT){return\"left\"}else if(direction==DIRECTION_RIGHT){return\"right\"}return\"\"}function getRecognizerByNameIfManager(otherRecognizer,recognizer){var manager=recognizer.manager;if(manager){return manager.get(otherRecognizer)}return otherRecognizer}function AttrRecognizer(){Recognizer.apply(this,arguments)}inherit(AttrRecognizer,Recognizer,{defaults:{pointers:1},attrTest:function(input){var optionPointers=this.options.pointers;return optionPointers===0||input.pointers.length===optionPointers},process:function(input){var state=this.state;var eventType=input.eventType;var isRecognized=state&(STATE_BEGAN|STATE_CHANGED);var isValid=this.attrTest(input);if(isRecognized&&(eventType&INPUT_CANCEL||!isValid)){return state|STATE_CANCELLED}else if(isRecognized||isValid){if(eventType&INPUT_END){return state|STATE_ENDED}else if(!(state&STATE_BEGAN)){return STATE_BEGAN}return state|STATE_CHANGED}return STATE_FAILED}});function PanRecognizer(){AttrRecognizer.apply(this,arguments);this.pX=null;this.pY=null}inherit(PanRecognizer,AttrRecognizer,{defaults:{event:\"pan\",threshold:10,pointers:1,direction:DIRECTION_ALL},getTouchAction:function(){var direction=this.options.direction;var actions=[];if(direction&DIRECTION_HORIZONTAL){actions.push(TOUCH_ACTION_PAN_Y)}if(direction&DIRECTION_VERTICAL){actions.push(TOUCH_ACTION_PAN_X)}return actions},directionTest:function(input){var options=this.options;var hasMoved=true;var distance=input.distance;var direction=input.direction;var x=input.deltaX;var y=input.deltaY;if(!(direction&options.direction)){if(options.direction&DIRECTION_HORIZONTAL){direction=x===0?DIRECTION_NONE:x<0?DIRECTION_LEFT:DIRECTION_RIGHT;hasMoved=x!=this.pX;distance=Math.abs(input.deltaX)}else{direction=y===0?DIRECTION_NONE:y<0?DIRECTION_UP:DIRECTION_DOWN;hasMoved=y!=this.pY;distance=Math.abs(input.deltaY)}}input.direction=direction;return hasMoved&&distance>options.threshold&&direction&options.direction},attrTest:function(input){return AttrRecognizer.prototype.attrTest.call(this,input)&&(this.state&STATE_BEGAN||!(this.state&STATE_BEGAN)&&this.directionTest(input))},emit:function(input){this.pX=input.deltaX;this.pY=input.deltaY;var direction=directionStr(input.direction);if(direction){input.additionalEvent=this.options.event+direction}this._super.emit.call(this,input)}});function PinchRecognizer(){AttrRecognizer.apply(this,arguments)}inherit(PinchRecognizer,AttrRecognizer,{defaults:{event:\"pinch\",threshold:0,pointers:2},getTouchAction:function(){return[TOUCH_ACTION_NONE]},attrTest:function(input){return this._super.attrTest.call(this,input)&&(Math.abs(input.scale-1)>this.options.threshold||this.state&STATE_BEGAN)},emit:function(input){if(input.scale!==1){var inOut=input.scale<1?\"in\":\"out\";input.additionalEvent=this.options.event+inOut}this._super.emit.call(this,input)}});function PressRecognizer(){Recognizer.apply(this,arguments);this._timer=null;this._input=null}inherit(PressRecognizer,Recognizer,{defaults:{event:\"press\",pointers:1,time:251,threshold:9},getTouchAction:function(){return[TOUCH_ACTION_AUTO]},process:function(input){var options=this.options;var validPointers=input.pointers.length===options.pointers;var validMovement=input.distance<options.threshold;var validTime=input.deltaTime>options.time;this._input=input;if(!validMovement||!validPointers||input.eventType&(INPUT_END|INPUT_CANCEL)&&!validTime){this.reset()}else if(input.eventType&INPUT_START){this.reset();this._timer=setTimeoutContext(function(){this.state=STATE_RECOGNIZED;this.tryEmit()},options.time,this)}else if(input.eventType&INPUT_END){return STATE_RECOGNIZED}return STATE_FAILED},reset:function(){clearTimeout(this._timer)},emit:function(input){if(this.state!==STATE_RECOGNIZED){return}if(input&&input.eventType&INPUT_END){this.manager.emit(this.options.event+\"up\",input)}else{this._input.timeStamp=now();this.manager.emit(this.options.event,this._input)}}});function RotateRecognizer(){AttrRecognizer.apply(this,arguments)}inherit(RotateRecognizer,AttrRecognizer,{defaults:{event:\"rotate\",threshold:0,pointers:2},getTouchAction:function(){return[TOUCH_ACTION_NONE]},attrTest:function(input){return this._super.attrTest.call(this,input)&&(Math.abs(input.rotation)>this.options.threshold||this.state&STATE_BEGAN)}});function SwipeRecognizer(){AttrRecognizer.apply(this,arguments)}inherit(SwipeRecognizer,AttrRecognizer,{defaults:{event:\"swipe\",threshold:10,velocity:.3,direction:DIRECTION_HORIZONTAL|DIRECTION_VERTICAL,pointers:1},getTouchAction:function(){return PanRecognizer.prototype.getTouchAction.call(this)},attrTest:function(input){var direction=this.options.direction;var velocity;if(direction&(DIRECTION_HORIZONTAL|DIRECTION_VERTICAL)){velocity=input.overallVelocity}else if(direction&DIRECTION_HORIZONTAL){velocity=input.overallVelocityX}else if(direction&DIRECTION_VERTICAL){velocity=input.overallVelocityY}return this._super.attrTest.call(this,input)&&direction&input.offsetDirection&&input.distance>this.options.threshold&&input.maxPointers==this.options.pointers&&abs(velocity)>this.options.velocity&&input.eventType&INPUT_END},emit:function(input){var direction=directionStr(input.offsetDirection);if(direction){this.manager.emit(this.options.event+direction,input)}this.manager.emit(this.options.event,input)}});function TapRecognizer(){Recognizer.apply(this,arguments);this.pTime=false;this.pCenter=false;this._timer=null;this._input=null;this.count=0}inherit(TapRecognizer,Recognizer,{defaults:{event:\"tap\",pointers:1,taps:1,interval:300,time:250,threshold:9,posThreshold:10},getTouchAction:function(){return[TOUCH_ACTION_MANIPULATION]},process:function(input){var options=this.options;var validPointers=input.pointers.length===options.pointers;var validMovement=input.distance<options.threshold;var validTouchTime=input.deltaTime<options.time;this.reset();if(input.eventType&INPUT_START&&this.count===0){return this.failTimeout()}if(validMovement&&validTouchTime&&validPointers){if(input.eventType!=INPUT_END){return this.failTimeout()}var validInterval=this.pTime?input.timeStamp-this.pTime<options.interval:true;var validMultiTap=!this.pCenter||getDistance(this.pCenter,input.center)<options.posThreshold;this.pTime=input.timeStamp;this.pCenter=input.center;if(!validMultiTap||!validInterval){this.count=1}else{this.count+=1}this._input=input;var tapCount=this.count%options.taps;if(tapCount===0){if(!this.hasRequireFailures()){return STATE_RECOGNIZED}else{this._timer=setTimeoutContext(function(){this.state=STATE_RECOGNIZED;this.tryEmit()},options.interval,this);return STATE_BEGAN}}}return STATE_FAILED},failTimeout:function(){this._timer=setTimeoutContext(function(){this.state=STATE_FAILED},this.options.interval,this);return STATE_FAILED},reset:function(){clearTimeout(this._timer)},emit:function(){if(this.state==STATE_RECOGNIZED){this._input.tapCount=this.count;this.manager.emit(this.options.event,this._input)}}});function Hammer(element,options){options=options||{};options.recognizers=ifUndefined(options.recognizers,Hammer.defaults.preset);return new Manager(element,options)}Hammer.VERSION=\"2.0.7\";Hammer.defaults={domEvents:false,touchAction:TOUCH_ACTION_COMPUTE,enable:true,inputTarget:null,inputClass:null,preset:[[RotateRecognizer,{enable:false}],[PinchRecognizer,{enable:false},[\"rotate\"]],[SwipeRecognizer,{direction:DIRECTION_HORIZONTAL}],[PanRecognizer,{direction:DIRECTION_HORIZONTAL},[\"swipe\"]],[TapRecognizer],[TapRecognizer,{event:\"doubletap\",taps:2},[\"tap\"]],[PressRecognizer]],cssProps:{userSelect:\"none\",touchSelect:\"none\",touchCallout:\"none\",contentZooming:\"none\",userDrag:\"none\",tapHighlightColor:\"rgba(0,0,0,0)\"}};var STOP=1;var FORCED_STOP=2;function Manager(element,options){this.options=assign({},Hammer.defaults,options||{});this.options.inputTarget=this.options.inputTarget||element;this.handlers={};this.session={};this.recognizers=[];this.oldCssProps={};this.element=element;this.input=createInputInstance(this);this.touchAction=new TouchAction(this,this.options.touchAction);toggleCssProps(this,true);each(this.options.recognizers,function(item){var recognizer=this.add(new item[0](item[1]));item[2]&&recognizer.recognizeWith(item[2]);item[3]&&recognizer.requireFailure(item[3])},this)}Manager.prototype={set:function(options){assign(this.options,options);if(options.touchAction){this.touchAction.update()}if(options.inputTarget){this.input.destroy();this.input.target=options.inputTarget;this.input.init()}return this},stop:function(force){this.session.stopped=force?FORCED_STOP:STOP},recognize:function(inputData){var session=this.session;if(session.stopped){return}this.touchAction.preventDefaults(inputData)\n;var recognizer;var recognizers=this.recognizers;var curRecognizer=session.curRecognizer;if(!curRecognizer||curRecognizer&&curRecognizer.state&STATE_RECOGNIZED){curRecognizer=session.curRecognizer=null}var i=0;while(i<recognizers.length){recognizer=recognizers[i];if(session.stopped!==FORCED_STOP&&(!curRecognizer||recognizer==curRecognizer||recognizer.canRecognizeWith(curRecognizer))){recognizer.recognize(inputData)}else{recognizer.reset()}if(!curRecognizer&&recognizer.state&(STATE_BEGAN|STATE_CHANGED|STATE_ENDED)){curRecognizer=session.curRecognizer=recognizer}i++}},get:function(recognizer){if(recognizer instanceof Recognizer){return recognizer}var recognizers=this.recognizers;for(var i=0;i<recognizers.length;i++){if(recognizers[i].options.event==recognizer){return recognizers[i]}}return null},add:function(recognizer){if(invokeArrayArg(recognizer,\"add\",this)){return this}var existing=this.get(recognizer.options.event);if(existing){this.remove(existing)}this.recognizers.push(recognizer);recognizer.manager=this;this.touchAction.update();return recognizer},remove:function(recognizer){if(invokeArrayArg(recognizer,\"remove\",this)){return this}recognizer=this.get(recognizer);if(recognizer){var recognizers=this.recognizers;var index=inArray(recognizers,recognizer);if(index!==-1){recognizers.splice(index,1);this.touchAction.update()}}return this},on:function(events,handler){if(events===undefined){return}if(handler===undefined){return}var handlers=this.handlers;each(splitStr(events),function(event){handlers[event]=handlers[event]||[];handlers[event].push(handler)});return this},off:function(events,handler){if(events===undefined){return}var handlers=this.handlers;each(splitStr(events),function(event){if(!handler){delete handlers[event]}else{handlers[event]&&handlers[event].splice(inArray(handlers[event],handler),1)}});return this},emit:function(event,data){if(this.options.domEvents){triggerDomEvent(event,data)}var handlers=this.handlers[event]&&this.handlers[event].slice();if(!handlers||!handlers.length){return}data.type=event;data.preventDefault=function(){data.srcEvent.preventDefault()};var i=0;while(i<handlers.length){handlers[i](data);i++}},destroy:function(){this.element&&toggleCssProps(this,false);this.handlers={};this.session={};this.input.destroy();this.element=null}};function toggleCssProps(manager,add){var element=manager.element;if(!element.style){return}var prop;each(manager.options.cssProps,function(value,name){prop=prefixed(element.style,name);if(add){manager.oldCssProps[prop]=element.style[prop];element.style[prop]=value}else{element.style[prop]=manager.oldCssProps[prop]||\"\"}});if(!add){manager.oldCssProps={}}}function triggerDomEvent(event,data){var gestureEvent=document.createEvent(\"Event\");gestureEvent.initEvent(event,true,true);gestureEvent.gesture=data;data.target.dispatchEvent(gestureEvent)}assign(Hammer,{INPUT_START:INPUT_START,INPUT_MOVE:INPUT_MOVE,INPUT_END:INPUT_END,INPUT_CANCEL:INPUT_CANCEL,STATE_POSSIBLE:STATE_POSSIBLE,STATE_BEGAN:STATE_BEGAN,STATE_CHANGED:STATE_CHANGED,STATE_ENDED:STATE_ENDED,STATE_RECOGNIZED:STATE_RECOGNIZED,STATE_CANCELLED:STATE_CANCELLED,STATE_FAILED:STATE_FAILED,DIRECTION_NONE:DIRECTION_NONE,DIRECTION_LEFT:DIRECTION_LEFT,DIRECTION_RIGHT:DIRECTION_RIGHT,DIRECTION_UP:DIRECTION_UP,DIRECTION_DOWN:DIRECTION_DOWN,DIRECTION_HORIZONTAL:DIRECTION_HORIZONTAL,DIRECTION_VERTICAL:DIRECTION_VERTICAL,DIRECTION_ALL:DIRECTION_ALL,Manager:Manager,Input:Input,TouchAction:TouchAction,TouchInput:TouchInput,MouseInput:MouseInput,PointerEventInput:PointerEventInput,TouchMouseInput:TouchMouseInput,SingleTouchInput:SingleTouchInput,Recognizer:Recognizer,AttrRecognizer:AttrRecognizer,Tap:TapRecognizer,Pan:PanRecognizer,Swipe:SwipeRecognizer,Pinch:PinchRecognizer,Rotate:RotateRecognizer,Press:PressRecognizer,on:addEventListeners,off:removeEventListeners,each:each,merge:merge,extend:extend,assign:assign,inherit:inherit,bindFn:bindFn,prefixed:prefixed});var freeGlobal=typeof window!==\"undefined\"?window:typeof self!==\"undefined\"?self:{};freeGlobal.Hammer=Hammer;if(true){!(__WEBPACK_AMD_DEFINE_RESULT__=function(){return Hammer}.call(exports,__webpack_require__,exports,module),__WEBPACK_AMD_DEFINE_RESULT__!==undefined&&(module.exports=__WEBPACK_AMD_DEFINE_RESULT__))}else if(typeof module!=\"undefined\"&&module.exports){module.exports=Hammer}else{window[exportName]=Hammer}})(window,document,\"Hammer\")},function(module,exports,__webpack_require__){\"use strict\";exports.util=__webpack_require__(2);exports.DOMutil=__webpack_require__(14);exports.DataSet=__webpack_require__(11);exports.DataView=__webpack_require__(12);exports.Queue=__webpack_require__(43);exports.Timeline=__webpack_require__(178);exports.Graph2d=__webpack_require__(180);exports.timeline={Core:__webpack_require__(65),DateUtil:__webpack_require__(36),Range:__webpack_require__(64),stack:__webpack_require__(100),TimeStep:__webpack_require__(66),components:{items:{Item:__webpack_require__(38),BackgroundItem:__webpack_require__(103),BoxItem:__webpack_require__(101),PointItem:__webpack_require__(102),RangeItem:__webpack_require__(70)},BackgroundGroup:__webpack_require__(69),Component:__webpack_require__(16),CurrentTime:__webpack_require__(67),CustomTime:__webpack_require__(46),DataAxis:__webpack_require__(107),DataScale:__webpack_require__(108),GraphGroup:__webpack_require__(109),Group:__webpack_require__(68),ItemSet:__webpack_require__(99),Legend:__webpack_require__(112),LineGraph:__webpack_require__(106),TimeAxis:__webpack_require__(45)}};exports.moment=__webpack_require__(9);exports.Hammer=__webpack_require__(10);exports.keycharm=__webpack_require__(35)},function(module,exports,__webpack_require__){\"use strict\";var moment=__webpack_require__(9);var util=__webpack_require__(2);var DataSet=__webpack_require__(11);var DataView=__webpack_require__(12);var Range=__webpack_require__(64);var Core=__webpack_require__(65);var TimeAxis=__webpack_require__(45);var CurrentTime=__webpack_require__(67);var CustomTime=__webpack_require__(46);var ItemSet=__webpack_require__(99);var printStyle=__webpack_require__(15).printStyle;var allOptions=__webpack_require__(105).allOptions;var configureOptions=__webpack_require__(105).configureOptions;var Configurator=__webpack_require__(71)[\"default\"];var Validator=__webpack_require__(15)[\"default\"];function Timeline(container,items,groups,options){if(!(this instanceof Timeline)){throw new SyntaxError(\"Constructor must be called with the new operator\")}if(!(Array.isArray(groups)||groups instanceof DataSet||groups instanceof DataView)&&groups instanceof Object){var forthArgument=options;options=groups;groups=forthArgument}if(options&&options.throttleRedraw){console.warn('Timeline option \"throttleRedraw\" is DEPRICATED and no longer supported. It will be removed in the next MAJOR release.')}var me=this;this.defaultOptions={start:null,end:null,autoResize:true,orientation:{axis:\"bottom\",item:\"bottom\"},moment:moment,width:null,height:null,maxHeight:null,minHeight:null};this.options=util.deepExtend({},this.defaultOptions);this._create(container);if(!options||options&&typeof options.rtl==\"undefined\"){this.dom.root.style.visibility=\"hidden\";var directionFromDom,domNode=this.dom.root;while(!directionFromDom&&domNode){directionFromDom=window.getComputedStyle(domNode,null).direction;domNode=domNode.parentElement}this.options.rtl=directionFromDom&&directionFromDom.toLowerCase()==\"rtl\"}else{this.options.rtl=options.rtl}this.options.rollingMode=options&&options.rollingMode;this.options.onInitialDrawComplete=options&&options.onInitialDrawComplete;this.components=[];this.body={dom:this.dom,domProps:this.props,emitter:{on:this.on.bind(this),off:this.off.bind(this),emit:this.emit.bind(this)},hiddenDates:[],util:{getScale:function getScale(){return me.timeAxis.step.scale},getStep:function getStep(){return me.timeAxis.step.step},toScreen:me._toScreen.bind(me),toGlobalScreen:me._toGlobalScreen.bind(me),toTime:me._toTime.bind(me),toGlobalTime:me._toGlobalTime.bind(me)}};this.range=new Range(this.body,this.options);this.components.push(this.range);this.body.range=this.range;this.timeAxis=new TimeAxis(this.body,this.options);this.timeAxis2=null;this.components.push(this.timeAxis);this.currentTime=new CurrentTime(this.body,this.options);this.components.push(this.currentTime);this.itemSet=new ItemSet(this.body,this.options);this.components.push(this.itemSet);this.itemsData=null;this.groupsData=null;this.dom.root.onclick=function(event){me.emit(\"click\",me.getEventProperties(event))};this.dom.root.ondblclick=function(event){me.emit(\"doubleClick\",me.getEventProperties(event))};this.dom.root.oncontextmenu=function(event){me.emit(\"contextmenu\",me.getEventProperties(event))};this.dom.root.onmouseover=function(event){me.emit(\"mouseOver\",me.getEventProperties(event))};if(window.PointerEvent){this.dom.root.onpointerdown=function(event){me.emit(\"mouseDown\",me.getEventProperties(event))};this.dom.root.onpointermove=function(event){me.emit(\"mouseMove\",me.getEventProperties(event))};this.dom.root.onpointerup=function(event){me.emit(\"mouseUp\",me.getEventProperties(event))}}else{this.dom.root.onmousemove=function(event){me.emit(\"mouseMove\",me.getEventProperties(event))};this.dom.root.onmousedown=function(event){me.emit(\"mouseDown\",me.getEventProperties(event))};this.dom.root.onmouseup=function(event){me.emit(\"mouseUp\",me.getEventProperties(event))}}this.initialFitDone=false;this.on(\"changed\",function(){if(this.itemsData==null||this.options.rollingMode)return;if(!me.initialFitDone){me.initialFitDone=true;if(me.options.start!=undefined||me.options.end!=undefined){if(me.options.start==undefined||me.options.end==undefined){var range=me.getItemRange()}var start=me.options.start!=undefined?me.options.start:range.min;var end=me.options.end!=undefined?me.options.end:range.max;me.setWindow(start,end,{animation:false})}else{me.fit({animation:false})}}if(!me.initialDrawDone&&me.initialRangeChangeDone){me.initialDrawDone=true;me.dom.root.style.visibility=\"visible\";if(me.options.onInitialDrawComplete){setTimeout(function(){return me.options.onInitialDrawComplete()},0)}}});if(options){this.setOptions(options)}if(groups){this.setGroups(groups)}if(items){this.setItems(items)}this._redraw()}Timeline.prototype=new Core;Timeline.prototype._createConfigurator=function(){return new Configurator(this,this.dom.container,configureOptions)};Timeline.prototype.redraw=function(){this.itemSet&&this.itemSet.markDirty({refreshItems:true});this._redraw()};Timeline.prototype.setOptions=function(options){var errorFound=Validator.validate(options,allOptions);if(errorFound===true){console.log(\"%cErrors have been found in the supplied options object.\",printStyle)}Core.prototype.setOptions.call(this,options);if(\"type\"in options){if(options.type!==this.options.type){this.options.type=options.type;var itemsData=this.itemsData;if(itemsData){var selection=this.getSelection();this.setItems(null);this.setItems(itemsData);this.setSelection(selection)}}}};Timeline.prototype.setItems=function(items){var newDataSet;if(!items){newDataSet=null}else if(items instanceof DataSet||items instanceof DataView){newDataSet=items}else{newDataSet=new DataSet(items,{type:{start:\"Date\",end:\"Date\"}})}this.itemsData=newDataSet;this.itemSet&&this.itemSet.setItems(newDataSet)};Timeline.prototype.setGroups=function(groups){var newDataSet;if(!groups){newDataSet=null}else{var filter=function filter(group){return group.visible!==false};if(groups instanceof DataSet||groups instanceof DataView){newDataSet=new DataView(groups,{filter:filter})}else{newDataSet=new DataSet(groups.filter(filter))}}this.groupsData=newDataSet;this.itemSet.setGroups(newDataSet)};Timeline.prototype.setData=function(data){if(data&&data.groups){this.setGroups(data.groups)}if(data&&data.items){this.setItems(data.items)}};Timeline.prototype.setSelection=function(ids,options){this.itemSet&&this.itemSet.setSelection(ids);if(options&&options.focus){this.focus(ids,options)}};Timeline.prototype.getSelection=function(){return this.itemSet&&this.itemSet.getSelection()||[]};Timeline.prototype.focus=function(id,options){if(!this.itemsData||id==undefined)return;var ids=Array.isArray(id)?id:[id];var itemsData=this.itemsData.getDataSet().get(ids,{type:{start:\"Date\",end:\"Date\"}});var start=null;var end=null;itemsData.forEach(function(itemData){var s=itemData.start.valueOf();var e=\"end\"in itemData?itemData.end.valueOf():itemData.start.valueOf();if(start===null||s<start){start=s}if(end===null||e>end){end=e}});if(start!==null&&end!==null){var me=this;var item=this.itemSet.items[ids[0]];var startPos=this._getScrollTop()*-1;var initialVerticalScroll=null;var verticalAnimationFrame=function verticalAnimationFrame(ease,willDraw,done){var verticalScroll=getItemVerticalScroll(me,item);if(!initialVerticalScroll){initialVerticalScroll=verticalScroll}if(initialVerticalScroll.itemTop==verticalScroll.itemTop&&!initialVerticalScroll.shouldScroll){return}else if(initialVerticalScroll.itemTop!=verticalScroll.itemTop&&verticalScroll.shouldScroll){initialVerticalScroll=verticalScroll;startPos=me._getScrollTop()*-1}var from=startPos;var to=initialVerticalScroll.scrollOffset;var scrollTop=done?to:from+(to-from)*ease;me._setScrollTop(-scrollTop);if(!willDraw){me._redraw()}};var setFinalVerticalPosition=function setFinalVerticalPosition(){var finalVerticalScroll=getItemVerticalScroll(me,item);if(finalVerticalScroll.shouldScroll&&finalVerticalScroll.itemTop!=initialVerticalScroll.itemTop){me._setScrollTop(-finalVerticalScroll.scrollOffset);me._redraw()}};var finalVerticalCallback=function finalVerticalCallback(){setFinalVerticalPosition();setTimeout(setFinalVerticalPosition,100)};var middle=(start+end)/2;var interval=Math.max(this.range.end-this.range.start,(end-start)*1.1);var animation=options&&options.animation!==undefined?options.animation:true;if(!animation){initialVerticalScroll={shouldScroll:false,scrollOffset:-1,itemTop:-1}}this.range.setRange(middle-interval/2,middle+interval/2,{animation:animation},finalVerticalCallback,verticalAnimationFrame)}};Timeline.prototype.fit=function(options,callback){var animation=options&&options.animation!==undefined?options.animation:true;var range;var dataset=this.itemsData&&this.itemsData.getDataSet();if(dataset.length===1&&dataset.get()[0].end===undefined){range=this.getDataRange();this.moveTo(range.min.valueOf(),{animation:animation},callback)}else{range=this.getItemRange();this.range.setRange(range.min,range.max,{animation:animation},callback)}};function getStart(item){return util.convert(item.data.start,\"Date\").valueOf()}function getEnd(item){var end=item.data.end!=undefined?item.data.end:item.data.start;return util.convert(end,\"Date\").valueOf()}function getItemVerticalScroll(timeline,item){var leftHeight=timeline.props.leftContainer.height;var contentHeight=timeline.props.left.height;var group=item.parent;var offset=group.top;var shouldScroll=true;var orientation=timeline.timeAxis.options.orientation.axis;var itemTop=function itemTop(){if(orientation==\"bottom\"){return group.height-item.top-item.height}else{return item.top}};var currentScrollHeight=timeline._getScrollTop()*-1;var targetOffset=offset+itemTop();var height=item.height;if(targetOffset<currentScrollHeight){if(offset+leftHeight<=offset+itemTop()+height){offset+=itemTop()-timeline.itemSet.options.margin.item.vertical}}else if(targetOffset+height>currentScrollHeight+leftHeight){offset+=itemTop()+height-leftHeight+timeline.itemSet.options.margin.item.vertical}else{shouldScroll=false}offset=Math.min(offset,contentHeight-leftHeight);return{shouldScroll:shouldScroll,scrollOffset:offset,itemTop:targetOffset}}Timeline.prototype.getItemRange=function(){var range=this.getDataRange();var min=range.min!==null?range.min.valueOf():null;var max=range.max!==null?range.max.valueOf():null;var minItem=null;var maxItem=null;if(min!=null&&max!=null){var interval=max-min;if(interval<=0){interval=10}var factor=interval/this.props.center.width;var redrawQueue={};var redrawQueueLength=0;util.forEach(this.itemSet.items,function(item,key){if(item.groupShowing){var returnQueue=true;redrawQueue[key]=item.redraw(returnQueue);redrawQueueLength=redrawQueue[key].length}});var needRedraw=redrawQueueLength>0;if(needRedraw){for(var i=0;i<redrawQueueLength;i++){util.forEach(redrawQueue,function(fns){fns[i]()})}}util.forEach(this.itemSet.items,function(item){var start=getStart(item);var end=getEnd(item);var startSide;var endSide;if(this.options.rtl){startSide=start-(item.getWidthRight()+10)*factor;endSide=end+(item.getWidthLeft()+10)*factor}else{startSide=start-(item.getWidthLeft()+10)*factor;endSide=end+(item.getWidthRight()+10)*factor}if(startSide<min){min=startSide;minItem=item}if(endSide>max){max=endSide;maxItem=item}}.bind(this));if(minItem&&maxItem){var lhs=minItem.getWidthLeft()+10;var rhs=maxItem.getWidthRight()+10;var delta=this.props.center.width-lhs-rhs;if(delta>0){if(this.options.rtl){min=getStart(minItem)-rhs*interval/delta;max=getEnd(maxItem)+lhs*interval/delta}else{min=getStart(minItem)-lhs*interval/delta;max=getEnd(maxItem)+rhs*interval/delta}}}}return{min:min!=null?new Date(min):null,max:max!=null?new Date(max):null}};Timeline.prototype.getDataRange=function(){var min=null;var max=null;var dataset=this.itemsData&&this.itemsData.getDataSet();if(dataset){dataset.forEach(function(item){var start=util.convert(item.start,\"Date\").valueOf();var end=util.convert(item.end!=undefined?item.end:item.start,\"Date\").valueOf();if(min===null||start<min){min=start}if(max===null||end>max){max=end}})}return{min:min!=null?new Date(min):null,max:max!=null?new Date(max):null}};Timeline.prototype.getEventProperties=function(event){var clientX=event.center?event.center.x:event.clientX;var clientY=event.center?event.center.y:event.clientY;var x;if(this.options.rtl){x=util.getAbsoluteRight(this.dom.centerContainer)-clientX}else{x=clientX-util.getAbsoluteLeft(this.dom.centerContainer)}var y=clientY-util.getAbsoluteTop(this.dom.centerContainer);var item=this.itemSet.itemFromTarget(event);var group=this.itemSet.groupFromTarget(event);var customTime=CustomTime.customTimeFromTarget(event);var snap=this.itemSet.options.snap||null;var scale=this.body.util.getScale();var step=this.body.util.getStep();var time=this._toTime(x);var snappedTime=snap?snap(time,scale,step):time;var element=util.getTarget(event);var what=null;if(item!=null){what=\"item\"}else if(customTime!=null){what=\"custom-time\"}else if(util.hasParent(element,this.timeAxis.dom.foreground)){what=\"axis\"}else if(this.timeAxis2&&util.hasParent(element,this.timeAxis2.dom.foreground)){what=\"axis\"}else if(util.hasParent(element,this.itemSet.dom.labelSet)){what=\"group-label\"}else if(util.hasParent(element,this.currentTime.bar)){what=\"current-time\"}else if(util.hasParent(element,this.dom.center)){what=\"background\"}return{event:event,item:item?item.id:null,group:group?group.groupId:null,what:what,pageX:event.srcEvent?event.srcEvent.pageX:event.pageX,pageY:event.srcEvent?event.srcEvent.pageY:event.pageY,x:x,y:y,time:time,snappedTime:snappedTime}};Timeline.prototype.toggleRollingMode=function(){if(this.range.rolling){this.range.stopRolling()}else{if(this.options.rollingMode==undefined){this.setOptions(this.options)}this.range.startRolling()}};module.exports=Timeline},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _stringify=__webpack_require__(19);var _stringify2=_interopRequireDefault(_stringify);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Hammer=__webpack_require__(10);var hammerUtil=__webpack_require__(37);var util=__webpack_require__(2);var ColorPicker=function(){function ColorPicker(){var pixelRatio=arguments.length>0&&arguments[0]!==undefined?arguments[0]:1;(0,_classCallCheck3[\"default\"])(this,ColorPicker);this.pixelRatio=pixelRatio;this.generated=false;this.centerCoordinates={x:289/2,y:289/2};this.r=289*.49;this.color={r:255,g:255,b:255,a:1};this.hueCircle=undefined;this.initialColor={r:255,g:255,b:255,a:1};this.previousColor=undefined;this.applied=false;this.updateCallback=function(){};this.closeCallback=function(){};this._create()}(0,_createClass3[\"default\"])(ColorPicker,[{key:\"insertTo\",value:function insertTo(container){if(this.hammer!==undefined){this.hammer.destroy();this.hammer=undefined}this.container=container;this.container.appendChild(this.frame);this._bindHammer();this._setSize()}},{key:\"setUpdateCallback\",value:function setUpdateCallback(callback){if(typeof callback===\"function\"){this.updateCallback=callback}else{throw new Error(\"Function attempted to set as colorPicker update callback is not a function.\")}}},{key:\"setCloseCallback\",value:function setCloseCallback(callback){if(typeof callback===\"function\"){this.closeCallback=callback}else{throw new Error(\"Function attempted to set as colorPicker closing callback is not a function.\")}}},{key:\"_isColorString\",value:function _isColorString(color){var htmlColors={black:\"#000000\",navy:\"#000080\",darkblue:\"#00008B\",mediumblue:\"#0000CD\",blue:\"#0000FF\",darkgreen:\"#006400\",green:\"#008000\",teal:\"#008080\",darkcyan:\"#008B8B\",deepskyblue:\"#00BFFF\",darkturquoise:\"#00CED1\",mediumspringgreen:\"#00FA9A\",lime:\"#00FF00\",springgreen:\"#00FF7F\",aqua:\"#00FFFF\",cyan:\"#00FFFF\",midnightblue:\"#191970\",dodgerblue:\"#1E90FF\",lightseagreen:\"#20B2AA\",forestgreen:\"#228B22\",seagreen:\"#2E8B57\",darkslategray:\"#2F4F4F\",limegreen:\"#32CD32\",mediumseagreen:\"#3CB371\",turquoise:\"#40E0D0\",royalblue:\"#4169E1\",steelblue:\"#4682B4\",darkslateblue:\"#483D8B\",mediumturquoise:\"#48D1CC\",indigo:\"#4B0082\",darkolivegreen:\"#556B2F\",cadetblue:\"#5F9EA0\",cornflowerblue:\"#6495ED\",mediumaquamarine:\"#66CDAA\",dimgray:\"#696969\",slateblue:\"#6A5ACD\",olivedrab:\"#6B8E23\",slategray:\"#708090\",lightslategray:\"#778899\",mediumslateblue:\"#7B68EE\",lawngreen:\"#7CFC00\",chartreuse:\"#7FFF00\",aquamarine:\"#7FFFD4\",maroon:\"#800000\",purple:\"#800080\",olive:\"#808000\",gray:\"#808080\",skyblue:\"#87CEEB\",lightskyblue:\"#87CEFA\",blueviolet:\"#8A2BE2\",darkred:\"#8B0000\",darkmagenta:\"#8B008B\",saddlebrown:\"#8B4513\",darkseagreen:\"#8FBC8F\",lightgreen:\"#90EE90\",mediumpurple:\"#9370D8\",darkviolet:\"#9400D3\",palegreen:\"#98FB98\",darkorchid:\"#9932CC\",yellowgreen:\"#9ACD32\",sienna:\"#A0522D\",brown:\"#A52A2A\",darkgray:\"#A9A9A9\",lightblue:\"#ADD8E6\",greenyellow:\"#ADFF2F\",paleturquoise:\"#AFEEEE\",lightsteelblue:\"#B0C4DE\",powderblue:\"#B0E0E6\",firebrick:\"#B22222\",darkgoldenrod:\"#B8860B\",mediumorchid:\"#BA55D3\",rosybrown:\"#BC8F8F\",darkkhaki:\"#BDB76B\",silver:\"#C0C0C0\",mediumvioletred:\"#C71585\",indianred:\"#CD5C5C\",peru:\"#CD853F\",chocolate:\"#D2691E\",tan:\"#D2B48C\",lightgrey:\"#D3D3D3\",palevioletred:\"#D87093\",thistle:\"#D8BFD8\",orchid:\"#DA70D6\",goldenrod:\"#DAA520\",crimson:\"#DC143C\",gainsboro:\"#DCDCDC\",plum:\"#DDA0DD\",burlywood:\"#DEB887\",lightcyan:\"#E0FFFF\",lavender:\"#E6E6FA\",darksalmon:\"#E9967A\",violet:\"#EE82EE\",palegoldenrod:\"#EEE8AA\",lightcoral:\"#F08080\",khaki:\"#F0E68C\",aliceblue:\"#F0F8FF\",honeydew:\"#F0FFF0\",azure:\"#F0FFFF\",sandybrown:\"#F4A460\",wheat:\"#F5DEB3\",beige:\"#F5F5DC\",whitesmoke:\"#F5F5F5\",mintcream:\"#F5FFFA\",ghostwhite:\"#F8F8FF\",salmon:\"#FA8072\",antiquewhite:\"#FAEBD7\",linen:\"#FAF0E6\",lightgoldenrodyellow:\"#FAFAD2\",oldlace:\"#FDF5E6\",red:\"#FF0000\",fuchsia:\"#FF00FF\",magenta:\"#FF00FF\",deeppink:\"#FF1493\",orangered:\"#FF4500\",tomato:\"#FF6347\",hotpink:\"#FF69B4\",coral:\"#FF7F50\",darkorange:\"#FF8C00\",lightsalmon:\"#FFA07A\",orange:\"#FFA500\",lightpink:\"#FFB6C1\",pink:\"#FFC0CB\",gold:\"#FFD700\",peachpuff:\"#FFDAB9\",navajowhite:\"#FFDEAD\",moccasin:\"#FFE4B5\",bisque:\"#FFE4C4\",mistyrose:\"#FFE4E1\",blanchedalmond:\"#FFEBCD\",papayawhip:\"#FFEFD5\",lavenderblush:\"#FFF0F5\",seashell:\"#FFF5EE\",cornsilk:\"#FFF8DC\",lemonchiffon:\"#FFFACD\",floralwhite:\"#FFFAF0\",snow:\"#FFFAFA\",yellow:\"#FFFF00\",lightyellow:\"#FFFFE0\",ivory:\"#FFFFF0\",white:\"#FFFFFF\"};if(typeof color===\"string\"){return htmlColors[color]}}},{key:\"setColor\",value:function setColor(color){var setInitial=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;if(color===\"none\"){return}var rgba=void 0;var htmlColor=this._isColorString(color);if(htmlColor!==undefined){color=htmlColor}if(util.isString(color)===true){if(util.isValidRGB(color)===true){var rgbaArray=color.substr(4).substr(0,color.length-5).split(\",\");rgba={r:rgbaArray[0],g:rgbaArray[1],b:rgbaArray[2],a:1}}else if(util.isValidRGBA(color)===true){var _rgbaArray=color.substr(5).substr(0,color.length-6).split(\",\");rgba={r:_rgbaArray[0],g:_rgbaArray[1],b:_rgbaArray[2],a:_rgbaArray[3]}}else if(util.isValidHex(color)===true){var rgbObj=util.hexToRGB(color);rgba={r:rgbObj.r,g:rgbObj.g,b:rgbObj.b,a:1}}}else{if(color instanceof Object){if(color.r!==undefined&&color.g!==undefined&&color.b!==undefined){var alpha=color.a!==undefined?color.a:\"1.0\";rgba={r:color.r,g:color.g,b:color.b,a:alpha}}}}if(rgba===undefined){throw new Error(\"Unknown color passed to the colorPicker. Supported are strings: rgb, hex, rgba. Object: rgb ({r:r,g:g,b:b,[a:a]}). Supplied: \"+(0,_stringify2[\"default\"])(color))}else{this._setColor(rgba,setInitial)}}},{key:\"show\",value:function show(){if(this.closeCallback!==undefined){this.closeCallback();this.closeCallback=undefined}this.applied=false;this.frame.style.display=\"block\";this._generateHueCircle()}},{key:\"_hide\",value:function _hide(){var _this=this;var storePrevious=arguments.length>0&&arguments[0]!==undefined?arguments[0]:true;if(storePrevious===true){this.previousColor=util.extend({},this.color)}if(this.applied===true){this.updateCallback(this.initialColor)}this.frame.style.display=\"none\";setTimeout(function(){if(_this.closeCallback!==undefined){_this.closeCallback();_this.closeCallback=undefined}},0)}},{key:\"_save\",value:function _save(){this.updateCallback(this.color);this.applied=false;this._hide()}},{key:\"_apply\",value:function _apply(){this.applied=true;this.updateCallback(this.color);this._updatePicker(this.color)}},{key:\"_loadLast\",value:function _loadLast(){if(this.previousColor!==undefined){this.setColor(this.previousColor,false)}else{alert(\"There is no last color to load...\")}}},{key:\"_setColor\",value:function _setColor(rgba){var setInitial=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;if(setInitial===true){this.initialColor=util.extend({},rgba)}this.color=rgba;var hsv=util.RGBToHSV(rgba.r,rgba.g,rgba.b);var angleConvert=2*Math.PI;var radius=this.r*hsv.s;var x=this.centerCoordinates.x+radius*Math.sin(angleConvert*hsv.h);var y=this.centerCoordinates.y+radius*Math.cos(angleConvert*hsv.h);this.colorPickerSelector.style.left=x-.5*this.colorPickerSelector.clientWidth+\"px\";this.colorPickerSelector.style.top=y-.5*this.colorPickerSelector.clientHeight+\"px\";this._updatePicker(rgba)}},{key:\"_setOpacity\",value:function _setOpacity(value){this.color.a=value/100;this._updatePicker(this.color)}},{key:\"_setBrightness\",value:function _setBrightness(value){var hsv=util.RGBToHSV(this.color.r,this.color.g,this.color.b);hsv.v=value/100;var rgba=util.HSVToRGB(hsv.h,hsv.s,hsv.v);rgba[\"a\"]=this.color.a;this.color=rgba;this._updatePicker()}},{key:\"_updatePicker\",value:function _updatePicker(){var rgba=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.color;var hsv=util.RGBToHSV(rgba.r,rgba.g,rgba.b);var ctx=this.colorPickerCanvas.getContext(\"2d\");if(this.pixelRation===undefined){this.pixelRatio=(window.devicePixelRatio||1)/(ctx.webkitBackingStorePixelRatio||ctx.mozBackingStorePixelRatio||ctx.msBackingStorePixelRatio||ctx.oBackingStorePixelRatio||ctx.backingStorePixelRatio||1)}ctx.setTransform(this.pixelRatio,0,0,this.pixelRatio,0,0);var w=this.colorPickerCanvas.clientWidth;var h=this.colorPickerCanvas.clientHeight;ctx.clearRect(0,0,w,h);ctx.putImageData(this.hueCircle,0,0);ctx.fillStyle=\"rgba(0,0,0,\"+(1-hsv.v)+\")\";ctx.circle(this.centerCoordinates.x,this.centerCoordinates.y,this.r);ctx.fill();this.brightnessRange.value=100*hsv.v;this.opacityRange.value=100*rgba.a;this.initialColorDiv.style.backgroundColor=\"rgba(\"+this.initialColor.r+\",\"+this.initialColor.g+\",\"+this.initialColor.b+\",\"+this.initialColor.a+\")\";this.newColorDiv.style.backgroundColor=\"rgba(\"+this.color.r+\",\"+this.color.g+\",\"+this.color.b+\",\"+this.color.a+\")\"}},{key:\"_setSize\",value:function _setSize(){this.colorPickerCanvas.style.width=\"100%\";this.colorPickerCanvas.style.height=\"100%\";this.colorPickerCanvas.width=289*this.pixelRatio;this.colorPickerCanvas.height=289*this.pixelRatio}},{key:\"_create\",value:function _create(){this.frame=document.createElement(\"div\");this.frame.className=\"vis-color-picker\";this.colorPickerDiv=document.createElement(\"div\");this.colorPickerSelector=document.createElement(\"div\");this.colorPickerSelector.className=\"vis-selector\";this.colorPickerDiv.appendChild(this.colorPickerSelector);this.colorPickerCanvas=document.createElement(\"canvas\");this.colorPickerDiv.appendChild(this.colorPickerCanvas);if(!this.colorPickerCanvas.getContext){var noCanvas=document.createElement(\"DIV\");noCanvas.style.color=\"red\";noCanvas.style.fontWeight=\"bold\";noCanvas.style.padding=\"10px\";noCanvas.innerHTML=\"Error: your browser does not support HTML canvas\";this.colorPickerCanvas.appendChild(noCanvas)}else{var ctx=this.colorPickerCanvas.getContext(\"2d\");this.pixelRatio=(window.devicePixelRatio||1)/(ctx.webkitBackingStorePixelRatio||ctx.mozBackingStorePixelRatio||ctx.msBackingStorePixelRatio||ctx.oBackingStorePixelRatio||ctx.backingStorePixelRatio||1);this.colorPickerCanvas.getContext(\"2d\").setTransform(this.pixelRatio,0,0,this.pixelRatio,0,0)}this.colorPickerDiv.className=\"vis-color\";this.opacityDiv=document.createElement(\"div\");this.opacityDiv.className=\"vis-opacity\";this.brightnessDiv=document.createElement(\"div\");this.brightnessDiv.className=\"vis-brightness\";this.arrowDiv=document.createElement(\"div\");this.arrowDiv.className=\"vis-arrow\";this.opacityRange=document.createElement(\"input\");try{this.opacityRange.type=\"range\";this.opacityRange.min=\"0\";this.opacityRange.max=\"100\"}catch(err){}this.opacityRange.value=\"100\";this.opacityRange.className=\"vis-range\";this.brightnessRange=document.createElement(\"input\");try{this.brightnessRange.type=\"range\";this.brightnessRange.min=\"0\";this.brightnessRange.max=\"100\"}catch(err){}this.brightnessRange.value=\"100\";this.brightnessRange.className=\"vis-range\";this.opacityDiv.appendChild(this.opacityRange);this.brightnessDiv.appendChild(this.brightnessRange);var me=this;this.opacityRange.onchange=function(){me._setOpacity(this.value)};this.opacityRange.oninput=function(){me._setOpacity(this.value)};this.brightnessRange.onchange=function(){me._setBrightness(this.value)};this.brightnessRange.oninput=function(){me._setBrightness(this.value)};this.brightnessLabel=document.createElement(\"div\");this.brightnessLabel.className=\"vis-label vis-brightness\";this.brightnessLabel.innerHTML=\"brightness:\";this.opacityLabel=document.createElement(\"div\");this.opacityLabel.className=\"vis-label vis-opacity\";this.opacityLabel.innerHTML=\"opacity:\";this.newColorDiv=document.createElement(\"div\");this.newColorDiv.className=\"vis-new-color\";this.newColorDiv.innerHTML=\"new\";this.initialColorDiv=document.createElement(\"div\");this.initialColorDiv.className=\"vis-initial-color\";this.initialColorDiv.innerHTML=\"initial\";this.cancelButton=document.createElement(\"div\");this.cancelButton.className=\"vis-button vis-cancel\";this.cancelButton.innerHTML=\"cancel\";this.cancelButton.onclick=this._hide.bind(this,false);this.applyButton=document.createElement(\"div\");this.applyButton.className=\"vis-button vis-apply\";this.applyButton.innerHTML=\"apply\";this.applyButton.onclick=this._apply.bind(this);this.saveButton=document.createElement(\"div\");this.saveButton.className=\"vis-button vis-save\";this.saveButton.innerHTML=\"save\";this.saveButton.onclick=this._save.bind(this);this.loadButton=document.createElement(\"div\");this.loadButton.className=\"vis-button vis-load\";this.loadButton.innerHTML=\"load last\";this.loadButton.onclick=this._loadLast.bind(this)\n;this.frame.appendChild(this.colorPickerDiv);this.frame.appendChild(this.arrowDiv);this.frame.appendChild(this.brightnessLabel);this.frame.appendChild(this.brightnessDiv);this.frame.appendChild(this.opacityLabel);this.frame.appendChild(this.opacityDiv);this.frame.appendChild(this.newColorDiv);this.frame.appendChild(this.initialColorDiv);this.frame.appendChild(this.cancelButton);this.frame.appendChild(this.applyButton);this.frame.appendChild(this.saveButton);this.frame.appendChild(this.loadButton)}},{key:\"_bindHammer\",value:function _bindHammer(){var _this2=this;this.drag={};this.pinch={};this.hammer=new Hammer(this.colorPickerCanvas);this.hammer.get(\"pinch\").set({enable:true});hammerUtil.onTouch(this.hammer,function(event){_this2._moveSelector(event)});this.hammer.on(\"tap\",function(event){_this2._moveSelector(event)});this.hammer.on(\"panstart\",function(event){_this2._moveSelector(event)});this.hammer.on(\"panmove\",function(event){_this2._moveSelector(event)});this.hammer.on(\"panend\",function(event){_this2._moveSelector(event)})}},{key:\"_generateHueCircle\",value:function _generateHueCircle(){if(this.generated===false){var ctx=this.colorPickerCanvas.getContext(\"2d\");if(this.pixelRation===undefined){this.pixelRatio=(window.devicePixelRatio||1)/(ctx.webkitBackingStorePixelRatio||ctx.mozBackingStorePixelRatio||ctx.msBackingStorePixelRatio||ctx.oBackingStorePixelRatio||ctx.backingStorePixelRatio||1)}ctx.setTransform(this.pixelRatio,0,0,this.pixelRatio,0,0);var w=this.colorPickerCanvas.clientWidth;var h=this.colorPickerCanvas.clientHeight;ctx.clearRect(0,0,w,h);var x=void 0,y=void 0,hue=void 0,sat=void 0;this.centerCoordinates={x:w*.5,y:h*.5};this.r=.49*w;var angleConvert=2*Math.PI/360;var hfac=1/360;var sfac=1/this.r;var rgb=void 0;for(hue=0;hue<360;hue++){for(sat=0;sat<this.r;sat++){x=this.centerCoordinates.x+sat*Math.sin(angleConvert*hue);y=this.centerCoordinates.y+sat*Math.cos(angleConvert*hue);rgb=util.HSVToRGB(hue*hfac,sat*sfac,1);ctx.fillStyle=\"rgb(\"+rgb.r+\",\"+rgb.g+\",\"+rgb.b+\")\";ctx.fillRect(x-.5,y-.5,2,2)}}ctx.strokeStyle=\"rgba(0,0,0,1)\";ctx.circle(this.centerCoordinates.x,this.centerCoordinates.y,this.r);ctx.stroke();this.hueCircle=ctx.getImageData(0,0,w,h)}this.generated=true}},{key:\"_moveSelector\",value:function _moveSelector(event){var rect=this.colorPickerDiv.getBoundingClientRect();var left=event.center.x-rect.left;var top=event.center.y-rect.top;var centerY=.5*this.colorPickerDiv.clientHeight;var centerX=.5*this.colorPickerDiv.clientWidth;var x=left-centerX;var y=top-centerY;var angle=Math.atan2(x,y);var radius=.98*Math.min(Math.sqrt(x*x+y*y),centerX);var newTop=Math.cos(angle)*radius+centerY;var newLeft=Math.sin(angle)*radius+centerX;this.colorPickerSelector.style.top=newTop-.5*this.colorPickerSelector.clientHeight+\"px\";this.colorPickerSelector.style.left=newLeft-.5*this.colorPickerSelector.clientWidth+\"px\";var h=angle/(2*Math.PI);h=h<0?h+1:h;var s=radius/this.r;var hsv=util.RGBToHSV(this.color.r,this.color.g,this.color.b);hsv.h=h;hsv.s=s;var rgba=util.HSVToRGB(hsv.h,hsv.s,hsv.v);rgba[\"a\"]=this.color.a;this.color=rgba;this.initialColorDiv.style.backgroundColor=\"rgba(\"+this.initialColor.r+\",\"+this.initialColor.g+\",\"+this.initialColor.b+\",\"+this.initialColor.a+\")\";this.newColorDiv.style.backgroundColor=\"rgba(\"+this.color.r+\",\"+this.color.g+\",\"+this.color.b+\",\"+this.color.a+\")\"}}]);return ColorPicker}();exports[\"default\"]=ColorPicker},function(module,exports,__webpack_require__){\"use strict\";var moment=__webpack_require__(9);var util=__webpack_require__(2);var DataSet=__webpack_require__(11);var DataView=__webpack_require__(12);var Range=__webpack_require__(64);var Core=__webpack_require__(65);var TimeAxis=__webpack_require__(45);var CurrentTime=__webpack_require__(67);var CustomTime=__webpack_require__(46);var LineGraph=__webpack_require__(106);var printStyle=__webpack_require__(15).printStyle;var allOptions=__webpack_require__(113).allOptions;var configureOptions=__webpack_require__(113).configureOptions;var Configurator=__webpack_require__(71)[\"default\"];var Validator=__webpack_require__(15)[\"default\"];function Graph2d(container,items,groups,options){if(!(Array.isArray(groups)||groups instanceof DataSet||groups instanceof DataView)&&groups instanceof Object){var forthArgument=options;options=groups;groups=forthArgument}if(options&&options.throttleRedraw){console.warn('Graph2d option \"throttleRedraw\" is DEPRICATED and no longer supported. It will be removed in the next MAJOR release.')}var me=this;this.defaultOptions={start:null,end:null,autoResize:true,orientation:{axis:\"bottom\",item:\"bottom\"},moment:moment,width:null,height:null,maxHeight:null,minHeight:null};this.options=util.deepExtend({},this.defaultOptions);this._create(container);this.components=[];this.body={dom:this.dom,domProps:this.props,emitter:{on:this.on.bind(this),off:this.off.bind(this),emit:this.emit.bind(this)},hiddenDates:[],util:{toScreen:me._toScreen.bind(me),toGlobalScreen:me._toGlobalScreen.bind(me),toTime:me._toTime.bind(me),toGlobalTime:me._toGlobalTime.bind(me)}};this.range=new Range(this.body);this.components.push(this.range);this.body.range=this.range;this.timeAxis=new TimeAxis(this.body);this.components.push(this.timeAxis);this.currentTime=new CurrentTime(this.body);this.components.push(this.currentTime);this.linegraph=new LineGraph(this.body);this.components.push(this.linegraph);this.itemsData=null;this.groupsData=null;this.on(\"tap\",function(event){me.emit(\"click\",me.getEventProperties(event))});this.on(\"doubletap\",function(event){me.emit(\"doubleClick\",me.getEventProperties(event))});this.dom.root.oncontextmenu=function(event){me.emit(\"contextmenu\",me.getEventProperties(event))};if(options){this.setOptions(options)}if(groups){this.setGroups(groups)}if(items){this.setItems(items)}this._redraw()}Graph2d.prototype=new Core;Graph2d.prototype.setOptions=function(options){var errorFound=Validator.validate(options,allOptions);if(errorFound===true){console.log(\"%cErrors have been found in the supplied options object.\",printStyle)}Core.prototype.setOptions.call(this,options)};Graph2d.prototype.setItems=function(items){var initialLoad=this.itemsData==null;var newDataSet;if(!items){newDataSet=null}else if(items instanceof DataSet||items instanceof DataView){newDataSet=items}else{newDataSet=new DataSet(items,{type:{start:\"Date\",end:\"Date\"}})}this.itemsData=newDataSet;this.linegraph&&this.linegraph.setItems(newDataSet);if(initialLoad){if(this.options.start!=undefined||this.options.end!=undefined){var start=this.options.start!=undefined?this.options.start:null;var end=this.options.end!=undefined?this.options.end:null;this.setWindow(start,end,{animation:false})}else{this.fit({animation:false})}}};Graph2d.prototype.setGroups=function(groups){var newDataSet;if(!groups){newDataSet=null}else if(groups instanceof DataSet||groups instanceof DataView){newDataSet=groups}else{newDataSet=new DataSet(groups)}this.groupsData=newDataSet;this.linegraph.setGroups(newDataSet)};Graph2d.prototype.getLegend=function(groupId,width,height){if(width===undefined){width=15}if(height===undefined){height=15}if(this.linegraph.groups[groupId]!==undefined){return this.linegraph.groups[groupId].getLegend(width,height)}else{return\"cannot find group:'\"+groupId+\"'\"}};Graph2d.prototype.isGroupVisible=function(groupId){if(this.linegraph.groups[groupId]!==undefined){return this.linegraph.groups[groupId].visible&&(this.linegraph.options.groups.visibility[groupId]===undefined||this.linegraph.options.groups.visibility[groupId]==true)}else{return false}};Graph2d.prototype.getDataRange=function(){var min=null;var max=null;for(var groupId in this.linegraph.groups){if(this.linegraph.groups.hasOwnProperty(groupId)){if(this.linegraph.groups[groupId].visible==true){for(var i=0;i<this.linegraph.groups[groupId].itemsData.length;i++){var item=this.linegraph.groups[groupId].itemsData[i];var value=util.convert(item.x,\"Date\").valueOf();min=min==null?value:min>value?value:min;max=max==null?value:max<value?value:max}}}}return{min:min!=null?new Date(min):null,max:max!=null?new Date(max):null}};Graph2d.prototype.getEventProperties=function(event){var clientX=event.center?event.center.x:event.clientX;var clientY=event.center?event.center.y:event.clientY;var x=clientX-util.getAbsoluteLeft(this.dom.centerContainer);var y=clientY-util.getAbsoluteTop(this.dom.centerContainer);var time=this._toTime(x);var customTime=CustomTime.customTimeFromTarget(event);var element=util.getTarget(event);var what=null;if(util.hasParent(element,this.timeAxis.dom.foreground)){what=\"axis\"}else if(this.timeAxis2&&util.hasParent(element,this.timeAxis2.dom.foreground)){what=\"axis\"}else if(util.hasParent(element,this.linegraph.yAxisLeft.dom.frame)){what=\"data-axis\"}else if(util.hasParent(element,this.linegraph.yAxisRight.dom.frame)){what=\"data-axis\"}else if(util.hasParent(element,this.linegraph.legendLeft.dom.frame)){what=\"legend\"}else if(util.hasParent(element,this.linegraph.legendRight.dom.frame)){what=\"legend\"}else if(customTime!=null){what=\"custom-time\"}else if(util.hasParent(element,this.currentTime.bar)){what=\"current-time\"}else if(util.hasParent(element,this.dom.center)){what=\"background\"}var value=[];var yAxisLeft=this.linegraph.yAxisLeft;var yAxisRight=this.linegraph.yAxisRight;if(!yAxisLeft.hidden&&this.itemsData.length>0){value.push(yAxisLeft.screenToValue(y))}if(!yAxisRight.hidden&&this.itemsData.length>0){value.push(yAxisRight.screenToValue(y))}return{event:event,what:what,pageX:event.srcEvent?event.srcEvent.pageX:event.pageX,pageY:event.srcEvent?event.srcEvent.pageY:event.pageY,x:x,y:y,time:time,value:value}};Graph2d.prototype._createConfigurator=function(){return new Configurator(this,this.dom.container,configureOptions)};module.exports=Graph2d},function(module,exports,__webpack_require__){\"use strict\";exports.util=__webpack_require__(2);exports.DOMutil=__webpack_require__(14);exports.DataSet=__webpack_require__(11);exports.DataView=__webpack_require__(12);exports.Queue=__webpack_require__(43);exports.Network=__webpack_require__(182);exports.network={Images:__webpack_require__(116),dotparser:__webpack_require__(114),gephiParser:__webpack_require__(115),allOptions:__webpack_require__(122)};exports.network.convertDot=function(input){return exports.network.dotparser.DOTToGraph(input)};exports.network.convertGephi=function(input,options){return exports.network.gephiParser.parseGephi(input,options)};exports.moment=__webpack_require__(9);exports.Hammer=__webpack_require__(10);exports.keycharm=__webpack_require__(35)},function(module,exports,__webpack_require__){\"use strict\";__webpack_require__(183);var Emitter=__webpack_require__(44);var util=__webpack_require__(2);var dotparser=__webpack_require__(114);var gephiParser=__webpack_require__(115);var Activator=__webpack_require__(97);var locales=__webpack_require__(184);var Images=__webpack_require__(116)[\"default\"];var Groups=__webpack_require__(186)[\"default\"];var NodesHandler=__webpack_require__(187)[\"default\"];var EdgesHandler=__webpack_require__(214)[\"default\"];var PhysicsEngine=__webpack_require__(220)[\"default\"];var ClusterEngine=__webpack_require__(227)[\"default\"];var CanvasRenderer=__webpack_require__(229)[\"default\"];var Canvas=__webpack_require__(230)[\"default\"];var View=__webpack_require__(231)[\"default\"];var InteractionHandler=__webpack_require__(232)[\"default\"];var SelectionHandler=__webpack_require__(234)[\"default\"];var LayoutEngine=__webpack_require__(235)[\"default\"];var ManipulationSystem=__webpack_require__(237)[\"default\"];var Configurator=__webpack_require__(71)[\"default\"];var Validator=__webpack_require__(15)[\"default\"];var _require=__webpack_require__(15),printStyle=_require.printStyle;var _require2=__webpack_require__(122),allOptions=_require2.allOptions,configureOptions=_require2.configureOptions;var KamadaKawai=__webpack_require__(238)[\"default\"];function Network(container,data,options){var _this=this;if(!(this instanceof Network)){throw new SyntaxError(\"Constructor must be called with the new operator\")}this.options={};this.defaultOptions={locale:\"en\",locales:locales,clickToUse:false};util.extend(this.options,this.defaultOptions);this.body={container:container,nodes:{},nodeIndices:[],edges:{},edgeIndices:[],emitter:{on:this.on.bind(this),off:this.off.bind(this),emit:this.emit.bind(this),once:this.once.bind(this)},eventListeners:{onTap:function onTap(){},onTouch:function onTouch(){},onDoubleTap:function onDoubleTap(){},onHold:function onHold(){},onDragStart:function onDragStart(){},onDrag:function onDrag(){},onDragEnd:function onDragEnd(){},onMouseWheel:function onMouseWheel(){},onPinch:function onPinch(){},onMouseMove:function onMouseMove(){},onRelease:function onRelease(){},onContext:function onContext(){}},data:{nodes:null,edges:null},functions:{createNode:function createNode(){},createEdge:function createEdge(){},getPointer:function getPointer(){}},modules:{},view:{scale:1,translation:{x:0,y:0}}};this.bindEventListeners();this.images=new Images(function(){return _this.body.emitter.emit(\"_requestRedraw\")});this.groups=new Groups;this.canvas=new Canvas(this.body);this.selectionHandler=new SelectionHandler(this.body,this.canvas);this.interactionHandler=new InteractionHandler(this.body,this.canvas,this.selectionHandler);this.view=new View(this.body,this.canvas);this.renderer=new CanvasRenderer(this.body,this.canvas);this.physics=new PhysicsEngine(this.body);this.layoutEngine=new LayoutEngine(this.body);this.clustering=new ClusterEngine(this.body);this.manipulation=new ManipulationSystem(this.body,this.canvas,this.selectionHandler);this.nodesHandler=new NodesHandler(this.body,this.images,this.groups,this.layoutEngine);this.edgesHandler=new EdgesHandler(this.body,this.images,this.groups);this.body.modules[\"kamadaKawai\"]=new KamadaKawai(this.body,150,.05);this.body.modules[\"clustering\"]=this.clustering;this.canvas._create();this.setOptions(options);this.setData(data)}Emitter(Network.prototype);Network.prototype.setOptions=function(options){var _this2=this;if(options!==undefined){var errorFound=Validator.validate(options,allOptions);if(errorFound===true){console.log(\"%cErrors have been found in the supplied options object.\",printStyle)}var fields=[\"locale\",\"locales\",\"clickToUse\"];util.selectiveDeepExtend(fields,this.options,options);options=this.layoutEngine.setOptions(options.layout,options);this.canvas.setOptions(options);this.groups.setOptions(options.groups);this.nodesHandler.setOptions(options.nodes);this.edgesHandler.setOptions(options.edges);this.physics.setOptions(options.physics);this.manipulation.setOptions(options.manipulation,options,this.options);this.interactionHandler.setOptions(options.interaction);this.renderer.setOptions(options.interaction);this.selectionHandler.setOptions(options.interaction);if(options.groups!==undefined){this.body.emitter.emit(\"refreshNodes\")}if(\"configure\"in options){if(!this.configurator){this.configurator=new Configurator(this,this.body.container,configureOptions,this.canvas.pixelRatio)}this.configurator.setOptions(options.configure)}if(this.configurator&&this.configurator.options.enabled===true){var networkOptions={nodes:{},edges:{},layout:{},interaction:{},manipulation:{},physics:{},global:{}};util.deepExtend(networkOptions.nodes,this.nodesHandler.options);util.deepExtend(networkOptions.edges,this.edgesHandler.options);util.deepExtend(networkOptions.layout,this.layoutEngine.options);util.deepExtend(networkOptions.interaction,this.selectionHandler.options);util.deepExtend(networkOptions.interaction,this.renderer.options);util.deepExtend(networkOptions.interaction,this.interactionHandler.options);util.deepExtend(networkOptions.manipulation,this.manipulation.options);util.deepExtend(networkOptions.physics,this.physics.options);util.deepExtend(networkOptions.global,this.canvas.options);util.deepExtend(networkOptions.global,this.options);this.configurator.setModuleOptions(networkOptions)}if(options.clickToUse!==undefined){if(options.clickToUse===true){if(this.activator===undefined){this.activator=new Activator(this.canvas.frame);this.activator.on(\"change\",function(){_this2.body.emitter.emit(\"activate\")})}}else{if(this.activator!==undefined){this.activator.destroy();delete this.activator}this.body.emitter.emit(\"activate\")}}else{this.body.emitter.emit(\"activate\")}this.canvas.setSize();this.body.emitter.emit(\"startSimulation\")}};Network.prototype._updateVisibleIndices=function(){var nodes=this.body.nodes;var edges=this.body.edges;this.body.nodeIndices=[];this.body.edgeIndices=[];for(var nodeId in nodes){if(nodes.hasOwnProperty(nodeId)){if(!this.clustering._isClusteredNode(nodeId)&&nodes[nodeId].options.hidden===false){this.body.nodeIndices.push(nodes[nodeId].id)}}}for(var edgeId in edges){if(edges.hasOwnProperty(edgeId)){var edge=edges[edgeId];var fromNode=nodes[edge.fromId];var toNode=nodes[edge.toId];var edgeNodesPresent=fromNode!==undefined&&toNode!==undefined;var isVisible=!this.clustering._isClusteredEdge(edgeId)&&edge.options.hidden===false&&edgeNodesPresent&&fromNode.options.hidden===false&&toNode.options.hidden===false;if(isVisible){this.body.edgeIndices.push(edge.id)}}}};Network.prototype.bindEventListeners=function(){var _this3=this;this.body.emitter.on(\"_dataChanged\",function(){_this3.edgesHandler._updateState();_this3.body.emitter.emit(\"_dataUpdated\")});this.body.emitter.on(\"_dataUpdated\",function(){_this3.clustering._updateState();_this3._updateVisibleIndices();_this3._updateValueRange(_this3.body.nodes);_this3._updateValueRange(_this3.body.edges);_this3.body.emitter.emit(\"startSimulation\");_this3.body.emitter.emit(\"_requestRedraw\")})};Network.prototype.setData=function(data){this.body.emitter.emit(\"resetPhysics\");this.body.emitter.emit(\"_resetData\");this.selectionHandler.unselectAll();if(data&&data.dot&&(data.nodes||data.edges)){throw new SyntaxError('Data must contain either parameter \"dot\" or '+' parameter pair \"nodes\" and \"edges\", but not both.')}this.setOptions(data&&data.options);if(data&&data.dot){console.log(\"The dot property has been deprecated. Please use the static convertDot method to convert DOT into vis.network format and use the normal data format with nodes and edges. This converter is used like this: var data = vis.network.convertDot(dotString);\");var dotData=dotparser.DOTToGraph(data.dot);this.setData(dotData);return}else if(data&&data.gephi){console.log(\"The gephi property has been deprecated. Please use the static convertGephi method to convert gephi into vis.network format and use the normal data format with nodes and edges. This converter is used like this: var data = vis.network.convertGephi(gephiJson);\");var gephiData=gephiParser.parseGephi(data.gephi);this.setData(gephiData);return}else{this.nodesHandler.setData(data&&data.nodes,true);this.edgesHandler.setData(data&&data.edges,true)}this.body.emitter.emit(\"_dataChanged\");this.body.emitter.emit(\"_dataLoaded\");this.body.emitter.emit(\"initPhysics\")};Network.prototype.destroy=function(){this.body.emitter.emit(\"destroy\");this.body.emitter.off();this.off();delete this.groups;delete this.canvas;delete this.selectionHandler;delete this.interactionHandler;delete this.view;delete this.renderer;delete this.physics;delete this.layoutEngine;delete this.clustering;delete this.manipulation;delete this.nodesHandler;delete this.edgesHandler;delete this.configurator;delete this.images;for(var nodeId in this.body.nodes){if(!this.body.nodes.hasOwnProperty(nodeId))continue;delete this.body.nodes[nodeId]}for(var edgeId in this.body.edges){if(!this.body.edges.hasOwnProperty(edgeId))continue;delete this.body.edges[edgeId]}util.recursiveDOMDelete(this.body.container)};Network.prototype._updateValueRange=function(obj){var id;var valueMin=undefined;var valueMax=undefined;var valueTotal=0;for(id in obj){if(obj.hasOwnProperty(id)){var value=obj[id].getValue();if(value!==undefined){valueMin=valueMin===undefined?value:Math.min(value,valueMin);valueMax=valueMax===undefined?value:Math.max(value,valueMax);valueTotal+=value}}}if(valueMin!==undefined&&valueMax!==undefined){for(id in obj){if(obj.hasOwnProperty(id)){obj[id].setValueRange(valueMin,valueMax,valueTotal)}}}};Network.prototype.isActive=function(){return!this.activator||this.activator.active};Network.prototype.setSize=function(){return this.canvas.setSize.apply(this.canvas,arguments)};Network.prototype.canvasToDOM=function(){return this.canvas.canvasToDOM.apply(this.canvas,arguments)};Network.prototype.DOMtoCanvas=function(){return this.canvas.DOMtoCanvas.apply(this.canvas,arguments)};Network.prototype.findNode=function(){return this.clustering.findNode.apply(this.clustering,arguments)};Network.prototype.isCluster=function(){return this.clustering.isCluster.apply(this.clustering,arguments)};Network.prototype.openCluster=function(){return this.clustering.openCluster.apply(this.clustering,arguments)};Network.prototype.cluster=function(){return this.clustering.cluster.apply(this.clustering,arguments)};Network.prototype.getNodesInCluster=function(){return this.clustering.getNodesInCluster.apply(this.clustering,arguments)};Network.prototype.clusterByConnection=function(){return this.clustering.clusterByConnection.apply(this.clustering,arguments)};Network.prototype.clusterByHubsize=function(){return this.clustering.clusterByHubsize.apply(this.clustering,arguments)};Network.prototype.clusterOutliers=function(){return this.clustering.clusterOutliers.apply(this.clustering,arguments)};Network.prototype.getSeed=function(){return this.layoutEngine.getSeed.apply(this.layoutEngine,arguments)};Network.prototype.enableEditMode=function(){return this.manipulation.enableEditMode.apply(this.manipulation,arguments)};Network.prototype.disableEditMode=function(){return this.manipulation.disableEditMode.apply(this.manipulation,arguments)};Network.prototype.addNodeMode=function(){return this.manipulation.addNodeMode.apply(this.manipulation,arguments)};Network.prototype.editNode=function(){return this.manipulation.editNode.apply(this.manipulation,arguments)};Network.prototype.editNodeMode=function(){console.log(\"Deprecated: Please use editNode instead of editNodeMode.\");return this.manipulation.editNode.apply(this.manipulation,arguments)};Network.prototype.addEdgeMode=function(){return this.manipulation.addEdgeMode.apply(this.manipulation,arguments)};Network.prototype.editEdgeMode=function(){return this.manipulation.editEdgeMode.apply(this.manipulation,arguments)};Network.prototype.deleteSelected=function(){return this.manipulation.deleteSelected.apply(this.manipulation,arguments)};Network.prototype.getPositions=function(){return this.nodesHandler.getPositions.apply(this.nodesHandler,arguments)};Network.prototype.storePositions=function(){return this.nodesHandler.storePositions.apply(this.nodesHandler,arguments)};Network.prototype.moveNode=function(){return this.nodesHandler.moveNode.apply(this.nodesHandler,arguments)};Network.prototype.getBoundingBox=function(){return this.nodesHandler.getBoundingBox.apply(this.nodesHandler,arguments)};Network.prototype.getConnectedNodes=function(objectId){if(this.body.nodes[objectId]!==undefined){return this.nodesHandler.getConnectedNodes.apply(this.nodesHandler,arguments)}else{return this.edgesHandler.getConnectedNodes.apply(this.edgesHandler,arguments)}};Network.prototype.getConnectedEdges=function(){return this.nodesHandler.getConnectedEdges.apply(this.nodesHandler,arguments)};Network.prototype.startSimulation=function(){return this.physics.startSimulation.apply(this.physics,arguments)};Network.prototype.stopSimulation=function(){return this.physics.stopSimulation.apply(this.physics,arguments)};Network.prototype.stabilize=function(){return this.physics.stabilize.apply(this.physics,arguments)};Network.prototype.getSelection=function(){return this.selectionHandler.getSelection.apply(this.selectionHandler,arguments)};Network.prototype.setSelection=function(){return this.selectionHandler.setSelection.apply(this.selectionHandler,arguments)};Network.prototype.getSelectedNodes=function(){return this.selectionHandler.getSelectedNodes.apply(this.selectionHandler,arguments)};Network.prototype.getSelectedEdges=function(){return this.selectionHandler.getSelectedEdges.apply(this.selectionHandler,arguments)};Network.prototype.getNodeAt=function(){var node=this.selectionHandler.getNodeAt.apply(this.selectionHandler,arguments);if(node!==undefined&&node.id!==undefined){return node.id}return node};Network.prototype.getEdgeAt=function(){var edge=this.selectionHandler.getEdgeAt.apply(this.selectionHandler,arguments);if(edge!==undefined&&edge.id!==undefined){return edge.id}return edge};Network.prototype.selectNodes=function(){return this.selectionHandler.selectNodes.apply(this.selectionHandler,arguments)};Network.prototype.selectEdges=function(){return this.selectionHandler.selectEdges.apply(this.selectionHandler,arguments)};Network.prototype.unselectAll=function(){this.selectionHandler.unselectAll.apply(this.selectionHandler,arguments);this.redraw()};Network.prototype.redraw=function(){return this.renderer.redraw.apply(this.renderer,arguments)};Network.prototype.getScale=function(){return this.view.getScale.apply(this.view,arguments)};Network.prototype.getViewPosition=function(){return this.view.getViewPosition.apply(this.view,arguments)};Network.prototype.fit=function(){return this.view.fit.apply(this.view,arguments)};Network.prototype.moveTo=function(){return this.view.moveTo.apply(this.view,arguments)};Network.prototype.focus=function(){return this.view.focus.apply(this.view,arguments)};Network.prototype.releaseNode=function(){return this.view.releaseNode.apply(this.view,arguments)};Network.prototype.getOptionsFromConfigurator=function(){var options={};if(this.configurator){options=this.configurator.getOptions.apply(this.configurator)}return options};module.exports=Network},function(module,exports,__webpack_require__){\"use strict\";if(typeof CanvasRenderingContext2D!==\"undefined\"){CanvasRenderingContext2D.prototype.circle=function(x,y,r){this.beginPath();this.arc(x,y,r,0,2*Math.PI,false);this.closePath()};CanvasRenderingContext2D.prototype.square=function(x,y,r){this.beginPath();this.rect(x-r,y-r,r*2,r*2);this.closePath()};CanvasRenderingContext2D.prototype.triangle=function(x,y,r){this.beginPath();r*=1.15;y+=.275*r;var s=r*2;var s2=s/2;var ir=Math.sqrt(3)/6*s;var h=Math.sqrt(s*s-s2*s2);this.moveTo(x,y-(h-ir));this.lineTo(x+s2,y+ir);this.lineTo(x-s2,y+ir);this.lineTo(x,y-(h-ir));this.closePath()};CanvasRenderingContext2D.prototype.triangleDown=function(x,y,r){this.beginPath();r*=1.15;y-=.275*r;var s=r*2;var s2=s/2;var ir=Math.sqrt(3)/6*s;var h=Math.sqrt(s*s-s2*s2);this.moveTo(x,y+(h-ir));this.lineTo(x+s2,y-ir);this.lineTo(x-s2,y-ir);this.lineTo(x,y+(h-ir));this.closePath()};CanvasRenderingContext2D.prototype.star=function(x,y,r){this.beginPath();r*=.82;y+=.1*r;for(var n=0;n<10;n++){var radius=n%2===0?r*1.3:r*.5;this.lineTo(x+radius*Math.sin(n*2*Math.PI/10),y-radius*Math.cos(n*2*Math.PI/10))}this.closePath()};CanvasRenderingContext2D.prototype.diamond=function(x,y,r){this.beginPath();this.lineTo(x,y+r);this.lineTo(x+r,y);this.lineTo(x,y-r);this.lineTo(x-r,y);this.closePath()};CanvasRenderingContext2D.prototype.roundRect=function(x,y,w,h,r){var r2d=Math.PI/180;if(w-2*r<0){r=w/2}if(h-2*r<0){r=h/2}this.beginPath();this.moveTo(x+r,y);this.lineTo(x+w-r,y);this.arc(x+w-r,y+r,r,r2d*270,r2d*360,false);this.lineTo(x+w,y+h-r);this.arc(x+w-r,y+h-r,r,0,r2d*90,false);this.lineTo(x+r,y+h);this.arc(x+r,y+h-r,r,r2d*90,r2d*180,false);this.lineTo(x,y+r);this.arc(x+r,y+r,r,r2d*180,r2d*270,false);this.closePath()};CanvasRenderingContext2D.prototype.ellipse_vis=function(x,y,w,h){var kappa=.5522848,ox=w/2*kappa,oy=h/2*kappa,xe=x+w,ye=y+h,xm=x+w/2,ym=y+h/2;this.beginPath();this.moveTo(x,ym);this.bezierCurveTo(x,ym-oy,xm-ox,y,xm,y);this.bezierCurveTo(xm+ox,y,xe,ym-oy,xe,ym);this.bezierCurveTo(xe,ym+oy,xm+ox,ye,xm,ye);this.bezierCurveTo(xm-ox,ye,x,ym+oy,x,ym);this.closePath()};CanvasRenderingContext2D.prototype.database=function(x,y,w,h){var f=1/3;var wEllipse=w;var hEllipse=h*f;var kappa=.5522848,ox=wEllipse/2*kappa,oy=hEllipse/2*kappa,xe=x+wEllipse,ye=y+hEllipse,xm=x+wEllipse/2,ym=y+hEllipse/2,ymb=y+(h-hEllipse/2),yeb=y+h;this.beginPath();this.moveTo(xe,ym);this.bezierCurveTo(xe,ym+oy,xm+ox,ye,xm,ye);this.bezierCurveTo(xm-ox,ye,x,ym+oy,x,ym);this.bezierCurveTo(x,ym-oy,xm-ox,y,xm,y);this.bezierCurveTo(xm+ox,y,xe,ym-oy,xe,ym);this.lineTo(xe,ymb);this.bezierCurveTo(xe,ymb+oy,xm+ox,yeb,xm,yeb);this.bezierCurveTo(xm-ox,yeb,x,ymb+oy,x,ymb);this.lineTo(x,ym)};CanvasRenderingContext2D.prototype.dashedLine=function(x,y,x2,y2,pattern){this.beginPath();this.moveTo(x,y);var patternLength=pattern.length;var dx=x2-x;var dy=y2-y;var slope=dy/dx;var distRemaining=Math.sqrt(dx*dx+dy*dy);var patternIndex=0;var draw=true;var xStep=0;var dashLength=pattern[0];while(distRemaining>=.1){dashLength=pattern[patternIndex++%patternLength];if(dashLength>distRemaining){dashLength=distRemaining}xStep=Math.sqrt(dashLength*dashLength/(1+slope*slope));xStep=dx<0?-xStep:xStep;x+=xStep;y+=slope*xStep;if(draw===true){this.lineTo(x,y)}else{this.moveTo(x,y)}distRemaining-=dashLength;draw=!draw}};CanvasRenderingContext2D.prototype.hexagon=function(x,y,r){this.beginPath();var sides=6;var a=Math.PI*2/sides;this.moveTo(x+r,y);for(var i=1;i<sides;i++){this.lineTo(x+r*Math.cos(a*i),y+r*Math.sin(a*i))}this.closePath()}}},function(module,exports,__webpack_require__){\"use strict\";exports[\"en\"]={edit:\"Edit\",del:\"Delete selected\",back:\"Back\",addNode:\"Add Node\",addEdge:\"Add Edge\",editNode:\"Edit Node\",editEdge:\"Edit Edge\",addDescription:\"Click in an empty space to place a new node.\",edgeDescription:\"Click on a node and drag the edge to another node to connect them.\",editEdgeDescription:\"Click on the control points and drag them to a node to connect to it.\",createEdgeError:\"Cannot link edges to a cluster.\",deleteClusterError:\"Clusters cannot be deleted.\",editClusterError:\"Clusters cannot be edited.\"};exports[\"en_EN\"]=exports[\"en\"];exports[\"en_US\"]=exports[\"en\"];exports[\"de\"]={edit:\"Editieren\",del:\"Lösche Auswahl\",back:\"Zurück\",addNode:\"Knoten hinzufügen\",addEdge:\"Kante hinzufügen\",editNode:\"Knoten editieren\",editEdge:\"Kante editieren\",addDescription:\"Klicke auf eine freie Stelle, um einen neuen Knoten zu plazieren.\",edgeDescription:\"Klicke auf einen Knoten und ziehe die Kante zu einem anderen Knoten, um diese zu verbinden.\",editEdgeDescription:\"Klicke auf die Verbindungspunkte und ziehe diese auf einen Knoten, um sie zu verbinden.\",createEdgeError:\"Es ist nicht möglich, Kanten mit Clustern zu verbinden.\",deleteClusterError:\"Cluster können nicht gelöscht werden.\",editClusterError:\"Cluster können nicht editiert werden.\"};exports[\"de_DE\"]=exports[\"de\"];exports[\"es\"]={edit:\"Editar\",del:\"Eliminar selección\",back:\"Átras\",addNode:\"Añadir nodo\",addEdge:\"Añadir arista\",editNode:\"Editar nodo\",editEdge:\"Editar arista\",addDescription:\"Haga clic en un lugar vacío para colocar un nuevo nodo.\",edgeDescription:\"Haga clic en un nodo y arrastre la arista hacia otro nodo para conectarlos.\",editEdgeDescription:\"Haga clic en un punto de control y arrastrelo a un nodo para conectarlo.\",createEdgeError:\"No se puede conectar una arista a un grupo.\",deleteClusterError:\"No es posible eliminar grupos.\",editClusterError:\"No es posible editar grupos.\"};exports[\"es_ES\"]=exports[\"es\"];exports[\"it\"]={edit:\"Modifica\",del:\"Cancella la selezione\",back:\"Indietro\",addNode:\"Aggiungi un nodo\",addEdge:\"Aggiungi un vertice\",editNode:\"Modifica il nodo\",editEdge:\"Modifica il vertice\",addDescription:\"Clicca per aggiungere un nuovo nodo\",edgeDescription:\"Clicca su un nodo e trascinalo ad un altro nodo per connetterli.\",editEdgeDescription:\"Clicca sui Punti di controllo e trascinali ad un nodo per connetterli.\",createEdgeError:\"Non si possono collegare vertici ad un cluster\",deleteClusterError:\"I cluster non possono essere cancellati\",editClusterError:\"I clusters non possono essere modificati.\"};exports[\"it_IT\"]=exports[\"it\"];exports[\"nl\"]={edit:\"Wijzigen\",del:\"Selectie verwijderen\",\nback:\"Terug\",addNode:\"Node toevoegen\",addEdge:\"Link toevoegen\",editNode:\"Node wijzigen\",editEdge:\"Link wijzigen\",addDescription:\"Klik op een leeg gebied om een nieuwe node te maken.\",edgeDescription:\"Klik op een node en sleep de link naar een andere node om ze te verbinden.\",editEdgeDescription:\"Klik op de verbindingspunten en sleep ze naar een node om daarmee te verbinden.\",createEdgeError:\"Kan geen link maken naar een cluster.\",deleteClusterError:\"Clusters kunnen niet worden verwijderd.\",editClusterError:\"Clusters kunnen niet worden aangepast.\"};exports[\"nl_NL\"]=exports[\"nl\"];exports[\"nl_BE\"]=exports[\"nl\"];exports[\"pt-br\"]={edit:\"Editar\",del:\"Remover selecionado\",back:\"Voltar\",addNode:\"Adicionar nó\",addEdge:\"Adicionar aresta\",editNode:\"Editar nó\",editEdge:\"Editar aresta\",addDescription:\"Clique em um espaço em branco para adicionar um novo nó\",edgeDescription:\"Clique em um nó e arraste a aresta até outro nó para conectá-los\",editEdgeDescription:\"Clique nos pontos de controle e os arraste para um nó para conectá-los\",createEdgeError:\"Não foi possível linkar arestas a um cluster.\",deleteClusterError:\"Clusters não puderam ser removidos.\",editClusterError:\"Clusters não puderam ser editados.\"};exports[\"pt-BR\"]=exports[\"pt-br\"];exports[\"pt_BR\"]=exports[\"pt-br\"];exports[\"pt_br\"]=exports[\"pt-br\"];exports[\"ru\"]={edit:\"Редактировать\",del:\"Удалить выбранное\",back:\"Назад\",addNode:\"Добавить узел\",addEdge:\"Добавить ребро\",editNode:\"Редактировать узел\",editEdge:\"Редактировать ребро\",addDescription:\"Кликните в свободное место, чтобы добавить новый узел.\",edgeDescription:\"Кликните на узел и протяните ребро к другому узлу, чтобы соединить их.\",editEdgeDescription:\"Кликните на контрольные точки и перетащите их в узел, чтобы подключиться к нему.\",createEdgeError:\"Невозможно соединить ребра в кластер.\",deleteClusterError:\"Кластеры не могут быть удалены\",editClusterError:\"Кластеры недоступны для редактирования.\"};exports[\"ru_RU\"]=exports[\"ru\"];exports[\"cn\"]={edit:\"编辑\",del:\"删除选定\",back:\"返回\",addNode:\"添加节点\",addEdge:\"添加连接线\",editNode:\"编辑节点\",editEdge:\"编辑连接线\",addDescription:\"单击空白处放置新节点。\",edgeDescription:\"单击某个节点并将该连接线拖动到另一个节点以连接它们。\",editEdgeDescription:\"单击控制节点并将它们拖到节点上连接。\",createEdgeError:\"无法将连接线连接到群集。\",deleteClusterError:\"无法删除群集。\",editClusterError:\"无法编辑群集。\"};exports[\"zh_CN\"]=exports[\"cn\"]},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var CachedImage=function(){function CachedImage(){(0,_classCallCheck3[\"default\"])(this,CachedImage);this.NUM_ITERATIONS=4;this.image=new Image;this.canvas=document.createElement(\"canvas\")}(0,_createClass3[\"default\"])(CachedImage,[{key:\"init\",value:function init(){if(this.initialized())return;this.src=this.image.src;var w=this.image.width;var h=this.image.height;this.width=w;this.height=h;var h2=Math.floor(h/2);var h4=Math.floor(h/4);var h8=Math.floor(h/8);var h16=Math.floor(h/16);var w2=Math.floor(w/2);var w4=Math.floor(w/4);var w8=Math.floor(w/8);var w16=Math.floor(w/16);this.canvas.width=3*w4;this.canvas.height=h2;this.coordinates=[[0,0,w2,h2],[w2,0,w4,h4],[w2,h4,w8,h8],[5*w8,h4,w16,h16]];this._fillMipMap()}},{key:\"initialized\",value:function initialized(){return this.coordinates!==undefined}},{key:\"_fillMipMap\",value:function _fillMipMap(){var ctx=this.canvas.getContext(\"2d\");var to=this.coordinates[0];ctx.drawImage(this.image,to[0],to[1],to[2],to[3]);for(var iterations=1;iterations<this.NUM_ITERATIONS;iterations++){var from=this.coordinates[iterations-1];var _to=this.coordinates[iterations];ctx.drawImage(this.canvas,from[0],from[1],from[2],from[3],_to[0],_to[1],_to[2],_to[3])}}},{key:\"drawImageAtPosition\",value:function drawImageAtPosition(ctx,factor,left,top,width,height){if(!this.initialized())return;if(factor>2){factor*=.5;var iterations=0;while(factor>2&&iterations<this.NUM_ITERATIONS){factor*=.5;iterations+=1}if(iterations>=this.NUM_ITERATIONS){iterations=this.NUM_ITERATIONS-1}var from=this.coordinates[iterations];ctx.drawImage(this.canvas,from[0],from[1],from[2],from[3],left,top,width,height)}else{ctx.drawImage(this.image,left,top,width,height)}}}]);return CachedImage}();exports[\"default\"]=CachedImage},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var Groups=function(){function Groups(){(0,_classCallCheck3[\"default\"])(this,Groups);this.clear();this.defaultIndex=0;this.groupsArray=[];this.groupIndex=0;this.defaultGroups=[{border:\"#2B7CE9\",background:\"#97C2FC\",highlight:{border:\"#2B7CE9\",background:\"#D2E5FF\"},hover:{border:\"#2B7CE9\",background:\"#D2E5FF\"}},{border:\"#FFA500\",background:\"#FFFF00\",highlight:{border:\"#FFA500\",background:\"#FFFFA3\"},hover:{border:\"#FFA500\",background:\"#FFFFA3\"}},{border:\"#FA0A10\",background:\"#FB7E81\",highlight:{border:\"#FA0A10\",background:\"#FFAFB1\"},hover:{border:\"#FA0A10\",background:\"#FFAFB1\"}},{border:\"#41A906\",background:\"#7BE141\",highlight:{border:\"#41A906\",background:\"#A1EC76\"},hover:{border:\"#41A906\",background:\"#A1EC76\"}},{border:\"#E129F0\",background:\"#EB7DF4\",highlight:{border:\"#E129F0\",background:\"#F0B3F5\"},hover:{border:\"#E129F0\",background:\"#F0B3F5\"}},{border:\"#7C29F0\",background:\"#AD85E4\",highlight:{border:\"#7C29F0\",background:\"#D3BDF0\"},hover:{border:\"#7C29F0\",background:\"#D3BDF0\"}},{border:\"#C37F00\",background:\"#FFA807\",highlight:{border:\"#C37F00\",background:\"#FFCA66\"},hover:{border:\"#C37F00\",background:\"#FFCA66\"}},{border:\"#4220FB\",background:\"#6E6EFD\",highlight:{border:\"#4220FB\",background:\"#9B9BFD\"},hover:{border:\"#4220FB\",background:\"#9B9BFD\"}},{border:\"#FD5A77\",background:\"#FFC0CB\",highlight:{border:\"#FD5A77\",background:\"#FFD1D9\"},hover:{border:\"#FD5A77\",background:\"#FFD1D9\"}},{border:\"#4AD63A\",background:\"#C2FABC\",highlight:{border:\"#4AD63A\",background:\"#E6FFE3\"},hover:{border:\"#4AD63A\",background:\"#E6FFE3\"}},{border:\"#990000\",background:\"#EE0000\",highlight:{border:\"#BB0000\",background:\"#FF3333\"},hover:{border:\"#BB0000\",background:\"#FF3333\"}},{border:\"#FF6000\",background:\"#FF6000\",highlight:{border:\"#FF6000\",background:\"#FF6000\"},hover:{border:\"#FF6000\",background:\"#FF6000\"}},{border:\"#97C2FC\",background:\"#2B7CE9\",highlight:{border:\"#D2E5FF\",background:\"#2B7CE9\"},hover:{border:\"#D2E5FF\",background:\"#2B7CE9\"}},{border:\"#399605\",background:\"#255C03\",highlight:{border:\"#399605\",background:\"#255C03\"},hover:{border:\"#399605\",background:\"#255C03\"}},{border:\"#B70054\",background:\"#FF007E\",highlight:{border:\"#B70054\",background:\"#FF007E\"},hover:{border:\"#B70054\",background:\"#FF007E\"}},{border:\"#AD85E4\",background:\"#7C29F0\",highlight:{border:\"#D3BDF0\",background:\"#7C29F0\"},hover:{border:\"#D3BDF0\",background:\"#7C29F0\"}},{border:\"#4557FA\",background:\"#000EA1\",highlight:{border:\"#6E6EFD\",background:\"#000EA1\"},hover:{border:\"#6E6EFD\",background:\"#000EA1\"}},{border:\"#FFC0CB\",background:\"#FD5A77\",highlight:{border:\"#FFD1D9\",background:\"#FD5A77\"},hover:{border:\"#FFD1D9\",background:\"#FD5A77\"}},{border:\"#C2FABC\",background:\"#74D66A\",highlight:{border:\"#E6FFE3\",background:\"#74D66A\"},hover:{border:\"#E6FFE3\",background:\"#74D66A\"}},{border:\"#EE0000\",background:\"#990000\",highlight:{border:\"#FF3333\",background:\"#BB0000\"},hover:{border:\"#FF3333\",background:\"#BB0000\"}}];this.options={};this.defaultOptions={useDefaultGroups:true};util.extend(this.options,this.defaultOptions)}(0,_createClass3[\"default\"])(Groups,[{key:\"setOptions\",value:function setOptions(options){var optionFields=[\"useDefaultGroups\"];if(options!==undefined){for(var groupName in options){if(options.hasOwnProperty(groupName)){if(optionFields.indexOf(groupName)===-1){var group=options[groupName];this.add(groupName,group)}}}}}},{key:\"clear\",value:function clear(){this.groups={};this.groupsArray=[]}},{key:\"get\",value:function get(groupname){var shouldCreate=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;var group=this.groups[groupname];if(group===undefined&&shouldCreate){if(this.options.useDefaultGroups===false&&this.groupsArray.length>0){var index=this.groupIndex%this.groupsArray.length;this.groupIndex++;group={};group.color=this.groups[this.groupsArray[index]];this.groups[groupname]=group}else{var _index=this.defaultIndex%this.defaultGroups.length;this.defaultIndex++;group={};group.color=this.defaultGroups[_index];this.groups[groupname]=group}}return group}},{key:\"add\",value:function add(groupName,style){this.groups[groupName]=style;this.groupsArray.push(groupName);return style}}]);return Groups}();exports[\"default\"]=Groups},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var DataSet=__webpack_require__(11);var DataView=__webpack_require__(12);var Node=__webpack_require__(47)[\"default\"];var NodesHandler=function(){function NodesHandler(body,images,groups,layoutEngine){var _this=this;(0,_classCallCheck3[\"default\"])(this,NodesHandler);this.body=body;this.images=images;this.groups=groups;this.layoutEngine=layoutEngine;this.body.functions.createNode=this.create.bind(this);this.nodesListeners={add:function add(event,params){_this.add(params.items)},update:function update(event,params){_this.update(params.items,params.data,params.oldData)},remove:function remove(event,params){_this.remove(params.items)}};this.defaultOptions={borderWidth:1,borderWidthSelected:2,brokenImage:undefined,color:{border:\"#2B7CE9\",background:\"#97C2FC\",highlight:{border:\"#2B7CE9\",background:\"#D2E5FF\"},hover:{border:\"#2B7CE9\",background:\"#D2E5FF\"}},fixed:{x:false,y:false},font:{color:\"#343434\",size:14,face:\"arial\",background:\"none\",strokeWidth:0,strokeColor:\"#ffffff\",align:\"center\",vadjust:0,multi:false,bold:{mod:\"bold\"},boldital:{mod:\"bold italic\"},ital:{mod:\"italic\"},mono:{mod:\"\",size:15,face:\"monospace\",vadjust:2}},group:undefined,hidden:false,icon:{face:\"FontAwesome\",code:undefined,size:50,color:\"#2B7CE9\"},image:undefined,label:undefined,labelHighlightBold:true,level:undefined,margin:{top:5,right:5,bottom:5,left:5},mass:1,physics:true,scaling:{min:10,max:30,label:{enabled:false,min:14,max:30,maxVisible:30,drawThreshold:5},customScalingFunction:function customScalingFunction(min,max,total,value){if(max===min){return.5}else{var scale=1/(max-min);return Math.max(0,(value-min)*scale)}}},shadow:{enabled:false,color:\"rgba(0,0,0,0.5)\",size:10,x:5,y:5},shape:\"ellipse\",shapeProperties:{borderDashes:false,borderRadius:6,interpolation:true,useImageSize:false,useBorderWithImage:false},size:25,title:undefined,value:undefined,x:undefined,y:undefined};if(this.defaultOptions.mass<=0){throw\"Internal error: mass in defaultOptions of NodesHandler may not be zero or negative\"}this.options=util.bridgeObject(this.defaultOptions);this.bindEventListeners()}(0,_createClass3[\"default\"])(NodesHandler,[{key:\"bindEventListeners\",value:function bindEventListeners(){var _this2=this;this.body.emitter.on(\"refreshNodes\",this.refresh.bind(this));this.body.emitter.on(\"refresh\",this.refresh.bind(this));this.body.emitter.on(\"destroy\",function(){util.forEach(_this2.nodesListeners,function(callback,event){if(_this2.body.data.nodes)_this2.body.data.nodes.off(event,callback)});delete _this2.body.functions.createNode;delete _this2.nodesListeners.add;delete _this2.nodesListeners.update;delete _this2.nodesListeners.remove;delete _this2.nodesListeners})}},{key:\"setOptions\",value:function setOptions(options){if(options!==undefined){Node.parseOptions(this.options,options);if(options.shape!==undefined){for(var nodeId in this.body.nodes){if(this.body.nodes.hasOwnProperty(nodeId)){this.body.nodes[nodeId].updateShape()}}}if(options.font!==undefined){for(var _nodeId in this.body.nodes){if(this.body.nodes.hasOwnProperty(_nodeId)){this.body.nodes[_nodeId].updateLabelModule();this.body.nodes[_nodeId].needsRefresh()}}}if(options.size!==undefined){for(var _nodeId2 in this.body.nodes){if(this.body.nodes.hasOwnProperty(_nodeId2)){this.body.nodes[_nodeId2].needsRefresh()}}}if(options.hidden!==undefined||options.physics!==undefined){this.body.emitter.emit(\"_dataChanged\")}}}},{key:\"setData\",value:function setData(nodes){var doNotEmit=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;var oldNodesData=this.body.data.nodes;if(nodes instanceof DataSet||nodes instanceof DataView){this.body.data.nodes=nodes}else if(Array.isArray(nodes)){this.body.data.nodes=new DataSet;this.body.data.nodes.add(nodes)}else if(!nodes){this.body.data.nodes=new DataSet}else{throw new TypeError(\"Array or DataSet expected\")}if(oldNodesData){util.forEach(this.nodesListeners,function(callback,event){oldNodesData.off(event,callback)})}this.body.nodes={};if(this.body.data.nodes){var me=this;util.forEach(this.nodesListeners,function(callback,event){me.body.data.nodes.on(event,callback)});var ids=this.body.data.nodes.getIds();this.add(ids,true)}if(doNotEmit===false){this.body.emitter.emit(\"_dataChanged\")}}},{key:\"add\",value:function add(ids){var doNotEmit=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;var id=void 0;var newNodes=[];for(var i=0;i<ids.length;i++){id=ids[i];var properties=this.body.data.nodes.get(id);var node=this.create(properties);newNodes.push(node);this.body.nodes[id]=node}this.layoutEngine.positionInitially(newNodes);if(doNotEmit===false){this.body.emitter.emit(\"_dataChanged\")}}},{key:\"update\",value:function update(ids,changedData,oldData){var nodes=this.body.nodes;var dataChanged=false;for(var i=0;i<ids.length;i++){var id=ids[i];var node=nodes[id];var data=changedData[i];if(node!==undefined){if(node.setOptions(data)){dataChanged=true}}else{dataChanged=true;node=this.create(data);nodes[id]=node}}if(!dataChanged&&oldData!==undefined){dataChanged=changedData.some(function(newValue,index){var oldValue=oldData[index];return oldValue&&oldValue.level!==newValue.level})}if(dataChanged===true){this.body.emitter.emit(\"_dataChanged\")}else{this.body.emitter.emit(\"_dataUpdated\")}}},{key:\"remove\",value:function remove(ids){var nodes=this.body.nodes;for(var i=0;i<ids.length;i++){var id=ids[i];delete nodes[id]}this.body.emitter.emit(\"_dataChanged\")}},{key:\"create\",value:function create(properties){var constructorClass=arguments.length>1&&arguments[1]!==undefined?arguments[1]:Node;return new constructorClass(properties,this.body,this.images,this.groups,this.options,this.defaultOptions)}},{key:\"refresh\",value:function refresh(){var _this3=this;var clearPositions=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;util.forEach(this.body.nodes,function(node,nodeId){var data=_this3.body.data.nodes.get(nodeId);if(data!==undefined){if(clearPositions===true){node.setOptions({x:null,y:null})}node.setOptions({fixed:false});node.setOptions(data)}})}},{key:\"getPositions\",value:function getPositions(ids){var dataArray={};if(ids!==undefined){if(Array.isArray(ids)===true){for(var i=0;i<ids.length;i++){if(this.body.nodes[ids[i]]!==undefined){var node=this.body.nodes[ids[i]];dataArray[ids[i]]={x:Math.round(node.x),y:Math.round(node.y)}}}}else{if(this.body.nodes[ids]!==undefined){var _node=this.body.nodes[ids];dataArray[ids]={x:Math.round(_node.x),y:Math.round(_node.y)}}}}else{for(var _i=0;_i<this.body.nodeIndices.length;_i++){var _node2=this.body.nodes[this.body.nodeIndices[_i]];dataArray[this.body.nodeIndices[_i]]={x:Math.round(_node2.x),y:Math.round(_node2.y)}}}return dataArray}},{key:\"storePositions\",value:function storePositions(){var dataArray=[];var dataset=this.body.data.nodes.getDataSet();for(var nodeId in dataset._data){if(dataset._data.hasOwnProperty(nodeId)){var node=this.body.nodes[nodeId];if(dataset._data[nodeId].x!=Math.round(node.x)||dataset._data[nodeId].y!=Math.round(node.y)){dataArray.push({id:node.id,x:Math.round(node.x),y:Math.round(node.y)})}}}dataset.update(dataArray)}},{key:\"getBoundingBox\",value:function getBoundingBox(nodeId){if(this.body.nodes[nodeId]!==undefined){return this.body.nodes[nodeId].shape.boundingBox}}},{key:\"getConnectedNodes\",value:function getConnectedNodes(nodeId,direction){var nodeList=[];if(this.body.nodes[nodeId]!==undefined){var node=this.body.nodes[nodeId];var nodeObj={};for(var i=0;i<node.edges.length;i++){var edge=node.edges[i];if(direction!==\"to\"&&edge.toId==node.id){if(nodeObj[edge.fromId]===undefined){nodeList.push(edge.fromId);nodeObj[edge.fromId]=true}}else if(direction!==\"from\"&&edge.fromId==node.id){if(nodeObj[edge.toId]===undefined){nodeList.push(edge.toId);nodeObj[edge.toId]=true}}}}return nodeList}},{key:\"getConnectedEdges\",value:function getConnectedEdges(nodeId){var edgeList=[];if(this.body.nodes[nodeId]!==undefined){var node=this.body.nodes[nodeId];for(var i=0;i<node.edges.length;i++){edgeList.push(node.edges[i].id)}}else{console.log(\"NodeId provided for getConnectedEdges does not exist. Provided: \",nodeId)}return edgeList}},{key:\"moveNode\",value:function moveNode(nodeId,x,y){var _this4=this;if(this.body.nodes[nodeId]!==undefined){this.body.nodes[nodeId].x=Number(x);this.body.nodes[nodeId].y=Number(y);setTimeout(function(){_this4.body.emitter.emit(\"startSimulation\")},0)}else{console.log(\"Node id supplied to moveNode does not exist. Provided: \",nodeId)}}}]);return NodesHandler}();exports[\"default\"]=NodesHandler},function(module,exports,__webpack_require__){module.exports={default:__webpack_require__(189),__esModule:true}},function(module,exports,__webpack_require__){__webpack_require__(49);__webpack_require__(60);module.exports=__webpack_require__(190)},function(module,exports,__webpack_require__){var classof=__webpack_require__(86);var ITERATOR=__webpack_require__(13)(\"iterator\");var Iterators=__webpack_require__(31);module.exports=__webpack_require__(7).isIterable=function(it){var O=Object(it);return O[ITERATOR]!==undefined||\"@@iterator\"in O||Iterators.hasOwnProperty(classof(O))}},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var LabelAccumulator=__webpack_require__(192)[\"default\"];var ComponentUtil=__webpack_require__(48)[\"default\"];var LabelSplitter=function(){function LabelSplitter(ctx,parent,selected,hover){var _this=this;(0,_classCallCheck3[\"default\"])(this,LabelSplitter);this.ctx=ctx;this.parent=parent;var textWidth=function textWidth(text,mod){if(text===undefined)return 0;var values=_this.parent.getFormattingValues(ctx,selected,hover,mod);var width=0;if(text!==\"\"){var measure=_this.ctx.measureText(text);width=measure.width}return{width:width,values:values}};this.lines=new LabelAccumulator(textWidth)}(0,_createClass3[\"default\"])(LabelSplitter,[{key:\"process\",value:function process(text){if(!ComponentUtil.isValidLabel(text)){return this.lines.finalize()}var font=this.parent.fontOptions;text=text.replace(/\\r\\n/g,\"\\n\");text=text.replace(/\\r/g,\"\\n\");var nlLines=String(text).split(\"\\n\");var lineCount=nlLines.length;if(font.multi){for(var i=0;i<lineCount;i++){var blocks=this.splitBlocks(nlLines[i],font.multi);if(blocks===undefined)continue;if(blocks.length===0){this.lines.newLine(\"\");continue}if(font.maxWdt>0){for(var j=0;j<blocks.length;j++){var mod=blocks[j].mod;var _text=blocks[j].text;this.splitStringIntoLines(_text,mod,true)}}else{for(var _j=0;_j<blocks.length;_j++){var _mod=blocks[_j].mod;var _text2=blocks[_j].text;this.lines.append(_text2,_mod)}}this.lines.newLine()}}else{if(font.maxWdt>0){for(var _i=0;_i<lineCount;_i++){this.splitStringIntoLines(nlLines[_i])}}else{for(var _i2=0;_i2<lineCount;_i2++){this.lines.newLine(nlLines[_i2])}}}return this.lines.finalize()}},{key:\"decodeMarkupSystem\",value:function decodeMarkupSystem(markupSystem){var system=\"none\";if(markupSystem===\"markdown\"||markupSystem===\"md\"){system=\"markdown\"}else if(markupSystem===true||markupSystem===\"html\"){system=\"html\"}return system}},{key:\"splitHtmlBlocks\",value:function splitHtmlBlocks(text){var blocks=[];var s={bold:false,ital:false,mono:false,spacing:false,position:0,buffer:\"\",modStack:[]};s.mod=function(){return this.modStack.length===0?\"normal\":this.modStack[0]};s.modName=function(){if(this.modStack.length===0)return\"normal\";else if(this.modStack[0]===\"mono\")return\"mono\";else{if(s.bold&&s.ital){return\"boldital\"}else if(s.bold){return\"bold\"}else if(s.ital){return\"ital\"}}};s.emitBlock=function(){var override=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;if(this.spacing){this.add(\" \");this.spacing=false}if(this.buffer.length>0){blocks.push({text:this.buffer,mod:this.modName()});this.buffer=\"\"}};s.add=function(text){if(text===\" \"){s.spacing=true}if(s.spacing){this.buffer+=\" \";this.spacing=false}if(text!=\" \"){this.buffer+=text}};while(s.position<text.length){var ch=text.charAt(s.position);if(/[ \\t]/.test(ch)){if(!s.mono){s.spacing=true}else{s.add(ch)}}else if(/</.test(ch)){if(!s.mono&&!s.bold&&/<b>/.test(text.substr(s.position,3))){s.emitBlock();s.bold=true;s.modStack.unshift(\"bold\");s.position+=2}else if(!s.mono&&!s.ital&&/<i>/.test(text.substr(s.position,3))){s.emitBlock();s.ital=true;s.modStack.unshift(\"ital\");s.position+=2}else if(!s.mono&&/<code>/.test(text.substr(s.position,6))){s.emitBlock();s.mono=true;s.modStack.unshift(\"mono\");s.position+=5}else if(!s.mono&&s.mod()===\"bold\"&&/<\\/b>/.test(text.substr(s.position,4))){s.emitBlock();s.bold=false;s.modStack.shift();s.position+=3}else if(!s.mono&&s.mod()===\"ital\"&&/<\\/i>/.test(text.substr(s.position,4))){s.emitBlock();s.ital=false;s.modStack.shift();s.position+=3}else if(s.mod()===\"mono\"&&/<\\/code>/.test(text.substr(s.position,7))){s.emitBlock();s.mono=false;s.modStack.shift();s.position+=6}else{s.add(ch)}}else if(/&/.test(ch)){if(/</.test(text.substr(s.position,4))){s.add(\"<\");s.position+=3}else if(/&/.test(text.substr(s.position,5))){s.add(\"&\");s.position+=4}else{s.add(\"&\")}}else{s.add(ch)}s.position++}s.emitBlock();return blocks}},{key:\"splitMarkdownBlocks\",value:function splitMarkdownBlocks(text){var blocks=[];var s={bold:false,ital:false,mono:false,beginable:true,spacing:false,position:0,buffer:\"\",modStack:[]};s.mod=function(){return this.modStack.length===0?\"normal\":this.modStack[0]};s.modName=function(){if(this.modStack.length===0)return\"normal\";else if(this.modStack[0]===\"mono\")return\"mono\";else{if(s.bold&&s.ital){return\"boldital\"}else if(s.bold){return\"bold\"}else if(s.ital){return\"ital\"}}};s.emitBlock=function(){var override=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;if(this.spacing){this.add(\" \");this.spacing=false}if(this.buffer.length>0){blocks.push({text:this.buffer,mod:this.modName()});this.buffer=\"\"}};s.add=function(text){if(text===\" \"){s.spacing=true}if(s.spacing){this.buffer+=\" \";this.spacing=false}if(text!=\" \"){this.buffer+=text}};while(s.position<text.length){var ch=text.charAt(s.position);if(/[ \\t]/.test(ch)){if(!s.mono){s.spacing=true}else{s.add(ch)}s.beginable=true}else if(/\\\\/.test(ch)){if(s.position<text.length+1){s.position++;ch=text.charAt(s.position);if(/ \\t/.test(ch)){s.spacing=true}else{s.add(ch);s.beginable=false}}}else if(!s.mono&&!s.bold&&(s.beginable||s.spacing)&&/\\*/.test(ch)){s.emitBlock();s.bold=true;s.modStack.unshift(\"bold\")}else if(!s.mono&&!s.ital&&(s.beginable||s.spacing)&&/\\_/.test(ch)){s.emitBlock();s.ital=true;s.modStack.unshift(\"ital\")}else if(!s.mono&&(s.beginable||s.spacing)&&/`/.test(ch)){s.emitBlock();s.mono=true;s.modStack.unshift(\"mono\")}else if(!s.mono&&s.mod()===\"bold\"&&/\\*/.test(ch)){if(s.position===text.length-1||/[.,_` \\t\\n]/.test(text.charAt(s.position+1))){s.emitBlock();s.bold=false;s.modStack.shift()}else{s.add(ch)}}else if(!s.mono&&s.mod()===\"ital\"&&/\\_/.test(ch)){if(s.position===text.length-1||/[.,*` \\t\\n]/.test(text.charAt(s.position+1))){s.emitBlock();s.ital=false;s.modStack.shift()}else{s.add(ch)}}else if(s.mono&&s.mod()===\"mono\"&&/`/.test(ch)){if(s.position===text.length-1||/[.,*_ \\t\\n]/.test(text.charAt(s.position+1))){s.emitBlock();s.mono=false;s.modStack.shift()}else{s.add(ch)}}else{s.add(ch);s.beginable=false}s.position++}s.emitBlock();return blocks}},{key:\"splitBlocks\",value:function splitBlocks(text,markupSystem){var system=this.decodeMarkupSystem(markupSystem);if(system===\"none\"){return[{text:text,mod:\"normal\"}]}else if(system===\"markdown\"){return this.splitMarkdownBlocks(text)}else if(system===\"html\"){return this.splitHtmlBlocks(text)}}},{key:\"overMaxWidth\",value:function overMaxWidth(text){var width=this.ctx.measureText(text).width;return this.lines.curWidth()+width>this.parent.fontOptions.maxWdt}},{key:\"getLongestFit\",value:function getLongestFit(words){var text=\"\";var w=0;while(w<words.length){var pre=text===\"\"?\"\":\" \";var newText=text+pre+words[w];if(this.overMaxWidth(newText))break;text=newText;w++}return w}},{key:\"getLongestFitWord\",value:function getLongestFitWord(words){var w=0;while(w<words.length){if(this.overMaxWidth(words.slice(0,w)))break;w++}return w}},{key:\"splitStringIntoLines\",value:function splitStringIntoLines(str){var mod=arguments.length>1&&arguments[1]!==undefined?arguments[1]:\"normal\";var appendLast=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;str=str.replace(/^( +)/g,\"$1\\r\");str=str.replace(/([^\\r][^ ]*)( +)/g,\"$1\\r$2\\r\");var words=str.split(\"\\r\");while(words.length>0){var w=this.getLongestFit(words);if(w===0){var word=words[0];var x=this.getLongestFitWord(word);this.lines.newLine(word.slice(0,x),mod);words[0]=word.slice(x)}else{var newW=w;if(words[w-1]===\" \"){w--}else if(words[newW]===\" \"){newW++}var text=words.slice(0,w).join(\"\");if(w==words.length&&appendLast){this.lines.append(text,mod)}else{this.lines.newLine(text,mod)}words=words.slice(newW)}}}}]);return LabelSplitter}();exports[\"default\"]=LabelSplitter},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _assign=__webpack_require__(90);var _assign2=_interopRequireDefault(_assign);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var LabelAccumulator=function(){function LabelAccumulator(measureText){(0,_classCallCheck3[\"default\"])(this,LabelAccumulator);this.measureText=measureText;this.current=0;this.width=0;this.height=0;this.lines=[]}(0,_createClass3[\"default\"])(LabelAccumulator,[{key:\"_add\",value:function _add(l,text){var mod=arguments.length>2&&arguments[2]!==undefined?arguments[2]:\"normal\";if(this.lines[l]===undefined){this.lines[l]={width:0,height:0,blocks:[]}}var tmpText=text;if(text===undefined||text===\"\")tmpText=\" \";var result=this.measureText(tmpText,mod);var block=(0,_assign2[\"default\"])({},result.values);block.text=text;block.width=result.width;block.mod=mod;if(text===undefined||text===\"\"){block.width=0}this.lines[l].blocks.push(block);this.lines[l].width+=block.width}},{key:\"curWidth\",value:function curWidth(){var line=this.lines[this.current];if(line===undefined)return 0;return line.width}},{key:\"append\",value:function append(text){var mod=arguments.length>1&&arguments[1]!==undefined?arguments[1]:\"normal\";this._add(this.current,text,mod)}},{key:\"newLine\",value:function newLine(text){var mod=arguments.length>1&&arguments[1]!==undefined?arguments[1]:\"normal\";this._add(this.current,text,mod);this.current++}},{key:\"determineLineHeights\",value:function determineLineHeights(){for(var k=0;k<this.lines.length;k++){var line=this.lines[k];var height=0;if(line.blocks!==undefined){for(var l=0;l<line.blocks.length;l++){var block=line.blocks[l];if(height<block.height){height=block.height}}}line.height=height}}},{key:\"determineLabelSize\",value:function determineLabelSize(){var width=0;var height=0;for(var k=0;k<this.lines.length;k++){var line=this.lines[k];if(line.width>width){width=line.width}height+=line.height}this.width=width;this.height=height}},{key:\"removeEmptyBlocks\",value:function removeEmptyBlocks(){var tmpLines=[];for(var k=0;k<this.lines.length;k++){var line=this.lines[k];if(line.blocks.length===0)continue;if(k===this.lines.length-1){if(line.width===0)continue}var tmpLine={};(0,_assign2[\"default\"])(tmpLine,line);tmpLine.blocks=[];var firstEmptyBlock=void 0;var tmpBlocks=[];for(var l=0;l<line.blocks.length;l++){var block=line.blocks[l];if(block.width!==0){tmpBlocks.push(block)}else{if(firstEmptyBlock===undefined){firstEmptyBlock=block}}}if(tmpBlocks.length===0&&firstEmptyBlock!==undefined){tmpBlocks.push(firstEmptyBlock)}tmpLine.blocks=tmpBlocks;tmpLines.push(tmpLine)}return tmpLines}},{key:\"finalize\",value:function finalize(){this.determineLineHeights();this.determineLabelSize();var tmpLines=this.removeEmptyBlocks();return{width:this.width,height:this.height,lines:tmpLines}}}]);return LabelAccumulator}();exports[\"default\"]=LabelAccumulator},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _NodeBase2=__webpack_require__(23);var _NodeBase3=_interopRequireDefault(_NodeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Box=function(_NodeBase){(0,_inherits3[\"default\"])(Box,_NodeBase);function Box(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,Box);var _this=(0,_possibleConstructorReturn3[\"default\"])(this,(Box.__proto__||(0,_getPrototypeOf2[\"default\"])(Box)).call(this,options,body,labelModule));_this._setMargins(labelModule);return _this}(0,_createClass3[\"default\"])(Box,[{key:\"resize\",value:function resize(ctx){var selected=arguments.length>1&&arguments[1]!==undefined?arguments[1]:this.selected;var hover=arguments.length>2&&arguments[2]!==undefined?arguments[2]:this.hover;if(this.needsRefresh(selected,hover)){var dimensions=this.getDimensionsFromLabel(ctx,selected,hover);this.width=dimensions.width+this.margin.right+this.margin.left;this.height=dimensions.height+this.margin.top+this.margin.bottom;this.radius=this.width/2}}},{key:\"draw\",value:function draw(ctx,x,y,selected,hover,values){this.resize(ctx,selected,hover);this.left=x-this.width/2;this.top=y-this.height/2;this.initContextForDraw(ctx,values);ctx.roundRect(this.left,this.top,this.width,this.height,values.borderRadius);this.performFill(ctx,values);this.updateBoundingBox(x,y,ctx,selected,hover);this.labelModule.draw(ctx,this.left+this.textSize.width/2+this.margin.left,this.top+this.textSize.height/2+this.margin.top,selected,hover)}},{key:\"updateBoundingBox\",value:function updateBoundingBox(x,y,ctx,selected,hover){this._updateBoundingBox(x,y,ctx,selected,hover)\n;var borderRadius=this.options.shapeProperties.borderRadius;this._addBoundingBoxMargin(borderRadius)}},{key:\"distanceToBorder\",value:function distanceToBorder(ctx,angle){this.resize(ctx);var borderWidth=this.options.borderWidth;return Math.min(Math.abs(this.width/2/Math.cos(angle)),Math.abs(this.height/2/Math.sin(angle)))+borderWidth}}]);return Box}(_NodeBase3[\"default\"]);exports[\"default\"]=Box},function(module,exports,__webpack_require__){__webpack_require__(195);module.exports=__webpack_require__(7).Object.getPrototypeOf},function(module,exports,__webpack_require__){var toObject=__webpack_require__(41);var $getPrototypeOf=__webpack_require__(85);__webpack_require__(87)(\"getPrototypeOf\",function(){return function getPrototypeOf(it){return $getPrototypeOf(toObject(it))}})},function(module,exports,__webpack_require__){module.exports={default:__webpack_require__(197),__esModule:true}},function(module,exports,__webpack_require__){__webpack_require__(198);module.exports=__webpack_require__(7).Object.setPrototypeOf},function(module,exports,__webpack_require__){var $export=__webpack_require__(17);$export($export.S,\"Object\",{setPrototypeOf:__webpack_require__(199).set})},function(module,exports,__webpack_require__){var isObject=__webpack_require__(32);var anObject=__webpack_require__(27);var check=function(O,proto){anObject(O);if(!isObject(proto)&&proto!==null)throw TypeError(proto+\": can't set as prototype!\")};module.exports={set:Object.setPrototypeOf||(\"__proto__\"in{}?function(test,buggy,set){try{set=__webpack_require__(80)(Function.call,__webpack_require__(89).f(Object.prototype,\"__proto__\").set,2);set(test,[]);buggy=!(test instanceof Array)}catch(e){buggy=true}return function setPrototypeOf(O,proto){check(O,proto);if(buggy)O.__proto__=proto;else set(O,proto);return O}}({},false):undefined),check:check}},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _CircleImageBase2=__webpack_require__(73);var _CircleImageBase3=_interopRequireDefault(_CircleImageBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Circle=function(_CircleImageBase){(0,_inherits3[\"default\"])(Circle,_CircleImageBase);function Circle(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,Circle);var _this=(0,_possibleConstructorReturn3[\"default\"])(this,(Circle.__proto__||(0,_getPrototypeOf2[\"default\"])(Circle)).call(this,options,body,labelModule));_this._setMargins(labelModule);return _this}(0,_createClass3[\"default\"])(Circle,[{key:\"resize\",value:function resize(ctx){var selected=arguments.length>1&&arguments[1]!==undefined?arguments[1]:this.selected;var hover=arguments.length>2&&arguments[2]!==undefined?arguments[2]:this.hover;if(this.needsRefresh(selected,hover)){var dimensions=this.getDimensionsFromLabel(ctx,selected,hover);var diameter=Math.max(dimensions.width+this.margin.right+this.margin.left,dimensions.height+this.margin.top+this.margin.bottom);this.options.size=diameter/2;this.width=diameter;this.height=diameter;this.radius=this.width/2}}},{key:\"draw\",value:function draw(ctx,x,y,selected,hover,values){this.resize(ctx,selected,hover);this.left=x-this.width/2;this.top=y-this.height/2;this._drawRawCircle(ctx,x,y,values);this.updateBoundingBox(x,y);this.labelModule.draw(ctx,this.left+this.textSize.width/2+this.margin.left,y,selected,hover)}},{key:\"updateBoundingBox\",value:function updateBoundingBox(x,y){this.boundingBox.top=y-this.options.size;this.boundingBox.left=x-this.options.size;this.boundingBox.right=x+this.options.size;this.boundingBox.bottom=y+this.options.size}},{key:\"distanceToBorder\",value:function distanceToBorder(ctx,angle){this.resize(ctx);return this.width*.5}}]);return Circle}(_CircleImageBase3[\"default\"]);exports[\"default\"]=Circle},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _CircleImageBase2=__webpack_require__(73);var _CircleImageBase3=_interopRequireDefault(_CircleImageBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var CircularImage=function(_CircleImageBase){(0,_inherits3[\"default\"])(CircularImage,_CircleImageBase);function CircularImage(options,body,labelModule,imageObj,imageObjAlt){(0,_classCallCheck3[\"default\"])(this,CircularImage);var _this=(0,_possibleConstructorReturn3[\"default\"])(this,(CircularImage.__proto__||(0,_getPrototypeOf2[\"default\"])(CircularImage)).call(this,options,body,labelModule));_this.setImages(imageObj,imageObjAlt);return _this}(0,_createClass3[\"default\"])(CircularImage,[{key:\"resize\",value:function resize(ctx){var selected=arguments.length>1&&arguments[1]!==undefined?arguments[1]:this.selected;var hover=arguments.length>2&&arguments[2]!==undefined?arguments[2]:this.hover;var imageAbsent=this.imageObj.src===undefined||this.imageObj.width===undefined||this.imageObj.height===undefined;if(imageAbsent){var diameter=this.options.size*2;this.width=diameter;this.height=diameter;this.radius=.5*this.width;return}if(this.needsRefresh(selected,hover)){this._resizeImage()}}},{key:\"draw\",value:function draw(ctx,x,y,selected,hover,values){this.switchImages(selected);this.resize();this.left=x-this.width/2;this.top=y-this.height/2;this._drawRawCircle(ctx,x,y,values);ctx.save();ctx.clip();this._drawImageAtPosition(ctx,values);ctx.restore();this._drawImageLabel(ctx,x,y,selected,hover);this.updateBoundingBox(x,y)}},{key:\"updateBoundingBox\",value:function updateBoundingBox(x,y){this.boundingBox.top=y-this.options.size;this.boundingBox.left=x-this.options.size;this.boundingBox.right=x+this.options.size;this.boundingBox.bottom=y+this.options.size;this.boundingBox.left=Math.min(this.boundingBox.left,this.labelModule.size.left);this.boundingBox.right=Math.max(this.boundingBox.right,this.labelModule.size.left+this.labelModule.size.width);this.boundingBox.bottom=Math.max(this.boundingBox.bottom,this.boundingBox.bottom+this.labelOffset)}},{key:\"distanceToBorder\",value:function distanceToBorder(ctx,angle){this.resize(ctx);return this.width*.5}}]);return CircularImage}(_CircleImageBase3[\"default\"]);exports[\"default\"]=CircularImage},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _NodeBase2=__webpack_require__(23);var _NodeBase3=_interopRequireDefault(_NodeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Database=function(_NodeBase){(0,_inherits3[\"default\"])(Database,_NodeBase);function Database(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,Database);var _this=(0,_possibleConstructorReturn3[\"default\"])(this,(Database.__proto__||(0,_getPrototypeOf2[\"default\"])(Database)).call(this,options,body,labelModule));_this._setMargins(labelModule);return _this}(0,_createClass3[\"default\"])(Database,[{key:\"resize\",value:function resize(ctx,selected,hover){if(this.needsRefresh(selected,hover)){var dimensions=this.getDimensionsFromLabel(ctx,selected,hover);var size=dimensions.width+this.margin.right+this.margin.left;this.width=size;this.height=size;this.radius=this.width/2}}},{key:\"draw\",value:function draw(ctx,x,y,selected,hover,values){this.resize(ctx,selected,hover);this.left=x-this.width/2;this.top=y-this.height/2;this.initContextForDraw(ctx,values);ctx.database(x-this.width/2,y-this.height/2,this.width,this.height);this.performFill(ctx,values);this.updateBoundingBox(x,y,ctx,selected,hover);this.labelModule.draw(ctx,this.left+this.textSize.width/2+this.margin.left,this.top+this.textSize.height/2+this.margin.top,selected,hover)}},{key:\"distanceToBorder\",value:function distanceToBorder(ctx,angle){return this._distanceToBorder(ctx,angle)}}]);return Database}(_NodeBase3[\"default\"]);exports[\"default\"]=Database},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _ShapeBase2=__webpack_require__(24);var _ShapeBase3=_interopRequireDefault(_ShapeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Diamond=function(_ShapeBase){(0,_inherits3[\"default\"])(Diamond,_ShapeBase);function Diamond(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,Diamond);return(0,_possibleConstructorReturn3[\"default\"])(this,(Diamond.__proto__||(0,_getPrototypeOf2[\"default\"])(Diamond)).call(this,options,body,labelModule))}(0,_createClass3[\"default\"])(Diamond,[{key:\"draw\",value:function draw(ctx,x,y,selected,hover,values){this._drawShape(ctx,\"diamond\",4,x,y,selected,hover,values)}},{key:\"distanceToBorder\",value:function distanceToBorder(ctx,angle){return this._distanceToBorder(ctx,angle)}}]);return Diamond}(_ShapeBase3[\"default\"]);exports[\"default\"]=Diamond},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _ShapeBase2=__webpack_require__(24);var _ShapeBase3=_interopRequireDefault(_ShapeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Dot=function(_ShapeBase){(0,_inherits3[\"default\"])(Dot,_ShapeBase);function Dot(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,Dot);return(0,_possibleConstructorReturn3[\"default\"])(this,(Dot.__proto__||(0,_getPrototypeOf2[\"default\"])(Dot)).call(this,options,body,labelModule))}(0,_createClass3[\"default\"])(Dot,[{key:\"draw\",value:function draw(ctx,x,y,selected,hover,values){this._drawShape(ctx,\"circle\",2,x,y,selected,hover,values)}},{key:\"distanceToBorder\",value:function distanceToBorder(ctx,angle){this.resize(ctx);return this.options.size}}]);return Dot}(_ShapeBase3[\"default\"]);exports[\"default\"]=Dot},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _NodeBase2=__webpack_require__(23);var _NodeBase3=_interopRequireDefault(_NodeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Ellipse=function(_NodeBase){(0,_inherits3[\"default\"])(Ellipse,_NodeBase);function Ellipse(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,Ellipse);return(0,_possibleConstructorReturn3[\"default\"])(this,(Ellipse.__proto__||(0,_getPrototypeOf2[\"default\"])(Ellipse)).call(this,options,body,labelModule))}(0,_createClass3[\"default\"])(Ellipse,[{key:\"resize\",value:function resize(ctx){var selected=arguments.length>1&&arguments[1]!==undefined?arguments[1]:this.selected;var hover=arguments.length>2&&arguments[2]!==undefined?arguments[2]:this.hover;if(this.needsRefresh(selected,hover)){var dimensions=this.getDimensionsFromLabel(ctx,selected,hover);this.height=dimensions.height*2;this.width=dimensions.width+dimensions.height;this.radius=.5*this.width}}},{key:\"draw\",value:function draw(ctx,x,y,selected,hover,values){this.resize(ctx,selected,hover);this.left=x-this.width*.5;this.top=y-this.height*.5;this.initContextForDraw(ctx,values);ctx.ellipse_vis(this.left,this.top,this.width,this.height);this.performFill(ctx,values);this.updateBoundingBox(x,y,ctx,selected,hover);this.labelModule.draw(ctx,x,y,selected,hover)}},{key:\"distanceToBorder\",value:function distanceToBorder(ctx,angle){this.resize(ctx);var a=this.width*.5;var b=this.height*.5;var w=Math.sin(angle)*a;var h=Math.cos(angle)*b;return a*b/Math.sqrt(w*w+h*h)}}]);return Ellipse}(_NodeBase3[\"default\"]);exports[\"default\"]=Ellipse},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _NodeBase2=__webpack_require__(23);var _NodeBase3=_interopRequireDefault(_NodeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Icon=function(_NodeBase){(0,_inherits3[\"default\"])(Icon,_NodeBase);function Icon(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,Icon);var _this=(0,_possibleConstructorReturn3[\"default\"])(this,(Icon.__proto__||(0,_getPrototypeOf2[\"default\"])(Icon)).call(this,options,body,labelModule));_this._setMargins(labelModule);return _this}(0,_createClass3[\"default\"])(Icon,[{key:\"resize\",value:function resize(ctx,selected,hover){if(this.needsRefresh(selected,hover)){this.iconSize={width:Number(this.options.icon.size),height:Number(this.options.icon.size)};this.width=this.iconSize.width+this.margin.right+this.margin.left;this.height=this.iconSize.height+this.margin.top+this.margin.bottom;this.radius=.5*this.width}}},{key:\"draw\",value:function draw(ctx,x,y,selected,hover,values){this.resize(ctx,selected,hover);this.options.icon.size=this.options.icon.size||50;this.left=x-this.width/2;this.top=y-this.height/2;this._icon(ctx,x,y,selected,hover,values);if(this.options.label!==undefined){var iconTextSpacing=5;this.labelModule.draw(ctx,this.left+this.iconSize.width/2+this.margin.left,y+this.height/2+iconTextSpacing,selected)}this.updateBoundingBox(x,y)}},{key:\"updateBoundingBox\",value:function updateBoundingBox(x,y){this.boundingBox.top=y-this.options.icon.size*.5;this.boundingBox.left=x-this.options.icon.size*.5;this.boundingBox.right=x+this.options.icon.size*.5;this.boundingBox.bottom=y+this.options.icon.size*.5;if(this.options.label!==undefined&&this.labelModule.size.width>0){var iconTextSpacing=5;this.boundingBox.left=Math.min(this.boundingBox.left,this.labelModule.size.left);this.boundingBox.right=Math.max(this.boundingBox.right,this.labelModule.size.left+this.labelModule.size.width);this.boundingBox.bottom=Math.max(this.boundingBox.bottom,this.boundingBox.bottom+this.labelModule.size.height+iconTextSpacing)}}},{key:\"_icon\",value:function _icon(ctx,x,y,selected,hover,values){var iconSize=Number(this.options.icon.size);if(this.options.icon.code!==undefined){ctx.font=(selected?\"bold \":\"\")+iconSize+\"px \"+this.options.icon.face;ctx.fillStyle=this.options.icon.color||\"black\";ctx.textAlign=\"center\";ctx.textBaseline=\"middle\";this.enableShadow(ctx,values);ctx.fillText(this.options.icon.code,x,y);this.disableShadow(ctx,values)}else{console.error(\"When using the icon shape, you need to define the code in the icon options object. This can be done per node or globally.\")}}},{key:\"distanceToBorder\",value:function distanceToBorder(ctx,angle){return this._distanceToBorder(ctx,angle)}}]);return Icon}(_NodeBase3[\"default\"]);exports[\"default\"]=Icon},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _CircleImageBase2=__webpack_require__(73);var _CircleImageBase3=_interopRequireDefault(_CircleImageBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Image=function(_CircleImageBase){(0,_inherits3[\"default\"])(Image,_CircleImageBase);function Image(options,body,labelModule,imageObj,imageObjAlt){(0,_classCallCheck3[\"default\"])(this,Image);var _this=(0,_possibleConstructorReturn3[\"default\"])(this,(Image.__proto__||(0,_getPrototypeOf2[\"default\"])(Image)).call(this,options,body,labelModule));_this.setImages(imageObj,imageObjAlt);return _this}(0,_createClass3[\"default\"])(Image,[{key:\"resize\",value:function resize(ctx){var selected=arguments.length>1&&arguments[1]!==undefined?arguments[1]:this.selected;var hover=arguments.length>2&&arguments[2]!==undefined?arguments[2]:this.hover;var imageAbsent=this.imageObj.src===undefined||this.imageObj.width===undefined||this.imageObj.height===undefined;if(imageAbsent){var side=this.options.size*2;this.width=side;this.height=side;return}if(this.needsRefresh(selected,hover)){this._resizeImage()}}},{key:\"draw\",value:function draw(ctx,x,y,selected,hover,values){this.switchImages(selected);this.resize();this.left=x-this.width/2;this.top=y-this.height/2;if(this.options.shapeProperties.useBorderWithImage===true){var neutralborderWidth=this.options.borderWidth;var selectionLineWidth=this.options.borderWidthSelected||2*this.options.borderWidth;var borderWidth=(selected?selectionLineWidth:neutralborderWidth)/this.body.view.scale;ctx.lineWidth=Math.min(this.width,borderWidth);ctx.beginPath();ctx.strokeStyle=selected?this.options.color.highlight.border:hover?this.options.color.hover.border:this.options.color.border;ctx.fillStyle=selected?this.options.color.highlight.background:hover?this.options.color.hover.background:this.options.color.background;ctx.rect(this.left-.5*ctx.lineWidth,this.top-.5*ctx.lineWidth,this.width+ctx.lineWidth,this.height+ctx.lineWidth);ctx.fill();this.performStroke(ctx,values);ctx.closePath()}this._drawImageAtPosition(ctx,values);this._drawImageLabel(ctx,x,y,selected,hover);this.updateBoundingBox(x,y)}},{key:\"updateBoundingBox\",value:function updateBoundingBox(x,y){this.resize();this._updateBoundingBox(x,y);if(this.options.label!==undefined&&this.labelModule.size.width>0){this.boundingBox.left=Math.min(this.boundingBox.left,this.labelModule.size.left);this.boundingBox.right=Math.max(this.boundingBox.right,this.labelModule.size.left+this.labelModule.size.width);this.boundingBox.bottom=Math.max(this.boundingBox.bottom,this.boundingBox.bottom+this.labelOffset)}}},{key:\"distanceToBorder\",value:function distanceToBorder(ctx,angle){return this._distanceToBorder(ctx,angle)}}]);return Image}(_CircleImageBase3[\"default\"]);exports[\"default\"]=Image},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _ShapeBase2=__webpack_require__(24);var _ShapeBase3=_interopRequireDefault(_ShapeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Square=function(_ShapeBase){(0,_inherits3[\"default\"])(Square,_ShapeBase);function Square(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,Square);return(0,_possibleConstructorReturn3[\"default\"])(this,(Square.__proto__||(0,_getPrototypeOf2[\"default\"])(Square)).call(this,options,body,labelModule))}(0,_createClass3[\"default\"])(Square,[{key:\"draw\",value:function draw(ctx,x,y,selected,hover,values){this._drawShape(ctx,\"square\",2,x,y,selected,hover,values)}},{key:\"distanceToBorder\",value:function distanceToBorder(ctx,angle){return this._distanceToBorder(ctx,angle)}}]);return Square}(_ShapeBase3[\"default\"]);exports[\"default\"]=Square},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _ShapeBase2=__webpack_require__(24);var _ShapeBase3=_interopRequireDefault(_ShapeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Hexagon=function(_ShapeBase){(0,_inherits3[\"default\"])(Hexagon,_ShapeBase);function Hexagon(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,Hexagon);return(0,_possibleConstructorReturn3[\"default\"])(this,(Hexagon.__proto__||(0,_getPrototypeOf2[\"default\"])(Hexagon)).call(this,options,body,labelModule))}(0,_createClass3[\"default\"])(Hexagon,[{key:\"draw\",value:function draw(ctx,x,y,selected,hover,values){this._drawShape(ctx,\"hexagon\",4,x,y,selected,hover,values)}},{key:\"distanceToBorder\",value:function distanceToBorder(ctx,angle){return this._distanceToBorder(ctx,angle)}}]);return Hexagon}(_ShapeBase3[\"default\"]);exports[\"default\"]=Hexagon},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _ShapeBase2=__webpack_require__(24);var _ShapeBase3=_interopRequireDefault(_ShapeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Star=function(_ShapeBase){(0,_inherits3[\"default\"])(Star,_ShapeBase);function Star(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,Star);return(0,_possibleConstructorReturn3[\"default\"])(this,(Star.__proto__||(0,_getPrototypeOf2[\"default\"])(Star)).call(this,options,body,labelModule))}(0,_createClass3[\"default\"])(Star,[{key:\"draw\",value:function draw(ctx,x,y,selected,hover,values){this._drawShape(ctx,\"star\",4,x,y,selected,hover,values)}},{key:\"distanceToBorder\",value:function distanceToBorder(ctx,angle){return this._distanceToBorder(ctx,angle)}}]);return Star}(_ShapeBase3[\"default\"]);exports[\"default\"]=Star},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _NodeBase2=__webpack_require__(23);var _NodeBase3=_interopRequireDefault(_NodeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Text=function(_NodeBase){(0,_inherits3[\"default\"])(Text,_NodeBase);function Text(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,Text);var _this=(0,_possibleConstructorReturn3[\"default\"])(this,(Text.__proto__||(0,_getPrototypeOf2[\"default\"])(Text)).call(this,options,body,labelModule));_this._setMargins(labelModule);return _this}(0,_createClass3[\"default\"])(Text,[{key:\"resize\",value:function resize(ctx,selected,hover){if(this.needsRefresh(selected,hover)){this.textSize=this.labelModule.getTextSize(ctx,selected,hover);this.width=this.textSize.width+this.margin.right+this.margin.left;this.height=this.textSize.height+this.margin.top+this.margin.bottom;this.radius=.5*this.width}}},{key:\"draw\",value:function draw(ctx,x,y,selected,hover,values){this.resize(ctx,selected,hover);this.left=x-this.width/2;this.top=y-this.height/2;this.enableShadow(ctx,values);this.labelModule.draw(ctx,this.left+this.textSize.width/2+this.margin.left,this.top+this.textSize.height/2+this.margin.top,selected,hover);this.disableShadow(ctx,values);this.updateBoundingBox(x,y,ctx,selected,hover)}},{key:\"distanceToBorder\",value:function distanceToBorder(ctx,angle){return this._distanceToBorder(ctx,angle)}}]);return Text}(_NodeBase3[\"default\"]);exports[\"default\"]=Text},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _ShapeBase2=__webpack_require__(24);var _ShapeBase3=_interopRequireDefault(_ShapeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Triangle=function(_ShapeBase){(0,_inherits3[\"default\"])(Triangle,_ShapeBase);function Triangle(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,Triangle);return(0,_possibleConstructorReturn3[\"default\"])(this,(Triangle.__proto__||(0,_getPrototypeOf2[\"default\"])(Triangle)).call(this,options,body,labelModule))}(0,_createClass3[\"default\"])(Triangle,[{key:\"draw\",value:function draw(ctx,x,y,selected,hover,values){this._drawShape(ctx,\"triangle\",3,x,y,selected,hover,values)}},{key:\"distanceToBorder\",value:function distanceToBorder(ctx,angle){return this._distanceToBorder(ctx,angle)}}]);return Triangle}(_ShapeBase3[\"default\"]);exports[\"default\"]=Triangle},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _ShapeBase2=__webpack_require__(24);var _ShapeBase3=_interopRequireDefault(_ShapeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var TriangleDown=function(_ShapeBase){(0,_inherits3[\"default\"])(TriangleDown,_ShapeBase);function TriangleDown(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,TriangleDown);return(0,_possibleConstructorReturn3[\"default\"])(this,(TriangleDown.__proto__||(0,_getPrototypeOf2[\"default\"])(TriangleDown)).call(this,options,body,labelModule))}(0,_createClass3[\"default\"])(TriangleDown,[{key:\"draw\",value:function draw(ctx,x,y,selected,hover,values){this._drawShape(ctx,\"triangleDown\",3,x,y,selected,hover,values)}},{key:\"distanceToBorder\",value:function distanceToBorder(ctx,angle){return this._distanceToBorder(ctx,angle)}}]);return TriangleDown}(_ShapeBase3[\"default\"]);exports[\"default\"]=TriangleDown},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var DataSet=__webpack_require__(11);var DataView=__webpack_require__(12);var Edge=__webpack_require__(74)[\"default\"];var EdgesHandler=function(){function EdgesHandler(body,images,groups){var _this=this;(0,_classCallCheck3[\"default\"])(this,EdgesHandler);this.body=body;this.images=images;this.groups=groups;this.body.functions.createEdge=this.create.bind(this);this.edgesListeners={add:function add(event,params){_this.add(params.items)},update:function update(event,params){_this.update(params.items)},remove:function remove(event,params){_this.remove(params.items)}};this.options={};this.defaultOptions={arrows:{to:{enabled:false,\nscaleFactor:1,type:\"arrow\"},middle:{enabled:false,scaleFactor:1,type:\"arrow\"},from:{enabled:false,scaleFactor:1,type:\"arrow\"}},arrowStrikethrough:true,color:{color:\"#848484\",highlight:\"#848484\",hover:\"#848484\",inherit:\"from\",opacity:1},dashes:false,font:{color:\"#343434\",size:14,face:\"arial\",background:\"none\",strokeWidth:2,strokeColor:\"#ffffff\",align:\"horizontal\",multi:false,vadjust:0,bold:{mod:\"bold\"},boldital:{mod:\"bold italic\"},ital:{mod:\"italic\"},mono:{mod:\"\",size:15,face:\"courier new\",vadjust:2}},hidden:false,hoverWidth:1.5,label:undefined,labelHighlightBold:true,length:undefined,physics:true,scaling:{min:1,max:15,label:{enabled:true,min:14,max:30,maxVisible:30,drawThreshold:5},customScalingFunction:function customScalingFunction(min,max,total,value){if(max===min){return.5}else{var scale=1/(max-min);return Math.max(0,(value-min)*scale)}}},selectionWidth:1.5,selfReferenceSize:20,shadow:{enabled:false,color:\"rgba(0,0,0,0.5)\",size:10,x:5,y:5},smooth:{enabled:true,type:\"dynamic\",forceDirection:\"none\",roundness:.5},title:undefined,width:1,value:undefined};util.deepExtend(this.options,this.defaultOptions);this.bindEventListeners()}(0,_createClass3[\"default\"])(EdgesHandler,[{key:\"bindEventListeners\",value:function bindEventListeners(){var _this2=this;this.body.emitter.on(\"_forceDisableDynamicCurves\",function(type){var emit=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;if(type===\"dynamic\"){type=\"continuous\"}var dataChanged=false;for(var edgeId in _this2.body.edges){if(_this2.body.edges.hasOwnProperty(edgeId)){var edge=_this2.body.edges[edgeId];var edgeData=_this2.body.data.edges._data[edgeId];if(edgeData!==undefined){var smoothOptions=edgeData.smooth;if(smoothOptions!==undefined){if(smoothOptions.enabled===true&&smoothOptions.type===\"dynamic\"){if(type===undefined){edge.setOptions({smooth:false})}else{edge.setOptions({smooth:{type:type}})}dataChanged=true}}}}}if(emit===true&&dataChanged===true){_this2.body.emitter.emit(\"_dataChanged\")}});this.body.emitter.on(\"_dataUpdated\",function(){_this2.reconnectEdges()});this.body.emitter.on(\"refreshEdges\",this.refresh.bind(this));this.body.emitter.on(\"refresh\",this.refresh.bind(this));this.body.emitter.on(\"destroy\",function(){util.forEach(_this2.edgesListeners,function(callback,event){if(_this2.body.data.edges)_this2.body.data.edges.off(event,callback)});delete _this2.body.functions.createEdge;delete _this2.edgesListeners.add;delete _this2.edgesListeners.update;delete _this2.edgesListeners.remove;delete _this2.edgesListeners})}},{key:\"setOptions\",value:function setOptions(options){if(options!==undefined){Edge.parseOptions(this.options,options,true,this.defaultOptions,true);var dataChanged=false;if(options.smooth!==undefined){for(var edgeId in this.body.edges){if(this.body.edges.hasOwnProperty(edgeId)){dataChanged=this.body.edges[edgeId].updateEdgeType()||dataChanged}}}if(options.font!==undefined){for(var _edgeId in this.body.edges){if(this.body.edges.hasOwnProperty(_edgeId)){this.body.edges[_edgeId].updateLabelModule()}}}if(options.hidden!==undefined||options.physics!==undefined||dataChanged===true){this.body.emitter.emit(\"_dataChanged\")}}}},{key:\"setData\",value:function setData(edges){var _this3=this;var doNotEmit=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;var oldEdgesData=this.body.data.edges;if(edges instanceof DataSet||edges instanceof DataView){this.body.data.edges=edges}else if(Array.isArray(edges)){this.body.data.edges=new DataSet;this.body.data.edges.add(edges)}else if(!edges){this.body.data.edges=new DataSet}else{throw new TypeError(\"Array or DataSet expected\")}if(oldEdgesData){util.forEach(this.edgesListeners,function(callback,event){oldEdgesData.off(event,callback)})}this.body.edges={};if(this.body.data.edges){util.forEach(this.edgesListeners,function(callback,event){_this3.body.data.edges.on(event,callback)});var ids=this.body.data.edges.getIds();this.add(ids,true)}this.body.emitter.emit(\"_adjustEdgesForHierarchicalLayout\");if(doNotEmit===false){this.body.emitter.emit(\"_dataChanged\")}}},{key:\"add\",value:function add(ids){var doNotEmit=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;var edges=this.body.edges;var edgesData=this.body.data.edges;for(var i=0;i<ids.length;i++){var id=ids[i];var oldEdge=edges[id];if(oldEdge){oldEdge.disconnect()}var data=edgesData.get(id,{showInternalIds:true});edges[id]=this.create(data)}this.body.emitter.emit(\"_adjustEdgesForHierarchicalLayout\");if(doNotEmit===false){this.body.emitter.emit(\"_dataChanged\")}}},{key:\"update\",value:function update(ids){var edges=this.body.edges;var edgesData=this.body.data.edges;var dataChanged=false;for(var i=0;i<ids.length;i++){var id=ids[i];var data=edgesData.get(id);var edge=edges[id];if(edge!==undefined){edge.disconnect();dataChanged=edge.setOptions(data)||dataChanged;edge.connect()}else{this.body.edges[id]=this.create(data);dataChanged=true}}if(dataChanged===true){this.body.emitter.emit(\"_adjustEdgesForHierarchicalLayout\");this.body.emitter.emit(\"_dataChanged\")}else{this.body.emitter.emit(\"_dataUpdated\")}}},{key:\"remove\",value:function remove(ids){var emit=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;if(ids.length===0)return;var edges=this.body.edges;util.forEach(ids,function(id){var edge=edges[id];if(edge!==undefined){edge.remove()}});if(emit){this.body.emitter.emit(\"_dataChanged\")}}},{key:\"refresh\",value:function refresh(){var _this4=this;util.forEach(this.body.edges,function(edge,edgeId){var data=_this4.body.data.edges._data[edgeId];if(data!==undefined){edge.setOptions(data)}})}},{key:\"create\",value:function create(properties){return new Edge(properties,this.body,this.options,this.defaultOptions)}},{key:\"reconnectEdges\",value:function reconnectEdges(){var id;var nodes=this.body.nodes;var edges=this.body.edges;for(id in nodes){if(nodes.hasOwnProperty(id)){nodes[id].edges=[]}}for(id in edges){if(edges.hasOwnProperty(id)){var edge=edges[id];edge.from=null;edge.to=null;edge.connect()}}}},{key:\"getConnectedNodes\",value:function getConnectedNodes(edgeId){var nodeList=[];if(this.body.edges[edgeId]!==undefined){var edge=this.body.edges[edgeId];if(edge.fromId!==undefined){nodeList.push(edge.fromId)}if(edge.toId!==undefined){nodeList.push(edge.toId)}}return nodeList}},{key:\"_updateState\",value:function _updateState(){this._addMissingEdges();this._removeInvalidEdges()}},{key:\"_removeInvalidEdges\",value:function _removeInvalidEdges(){var _this5=this;var edgesToDelete=[];util.forEach(this.body.edges,function(edge,id){var toNode=_this5.body.nodes[edge.toId];var fromNode=_this5.body.nodes[edge.fromId];if(toNode!==undefined&&toNode.isCluster===true||fromNode!==undefined&&fromNode.isCluster===true){return}if(toNode===undefined||fromNode===undefined){edgesToDelete.push(id)}});this.remove(edgesToDelete,false)}},{key:\"_addMissingEdges\",value:function _addMissingEdges(){var edges=this.body.edges;var edgesData=this.body.data.edges;var addIds=[];edgesData.forEach(function(edgeData,edgeId){var edge=edges[edgeId];if(edge===undefined){addIds.push(edgeId)}});this.add(addIds,true)}}]);return EdgesHandler}();exports[\"default\"]=EdgesHandler},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _slicedToArray2=__webpack_require__(30);var _slicedToArray3=_interopRequireDefault(_slicedToArray2);var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _CubicBezierEdgeBase2=__webpack_require__(216);var _CubicBezierEdgeBase3=_interopRequireDefault(_CubicBezierEdgeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var CubicBezierEdge=function(_CubicBezierEdgeBase){(0,_inherits3[\"default\"])(CubicBezierEdge,_CubicBezierEdgeBase);function CubicBezierEdge(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,CubicBezierEdge);return(0,_possibleConstructorReturn3[\"default\"])(this,(CubicBezierEdge.__proto__||(0,_getPrototypeOf2[\"default\"])(CubicBezierEdge)).call(this,options,body,labelModule))}(0,_createClass3[\"default\"])(CubicBezierEdge,[{key:\"_line\",value:function _line(ctx,values,viaNodes){var via1=viaNodes[0];var via2=viaNodes[1];this._bezierCurve(ctx,values,via1,via2)}},{key:\"_getViaCoordinates\",value:function _getViaCoordinates(){var dx=this.from.x-this.to.x;var dy=this.from.y-this.to.y;var x1=void 0,y1=void 0,x2=void 0,y2=void 0;var roundness=this.options.smooth.roundness;if((Math.abs(dx)>Math.abs(dy)||this.options.smooth.forceDirection===true||this.options.smooth.forceDirection===\"horizontal\")&&this.options.smooth.forceDirection!==\"vertical\"){y1=this.from.y;y2=this.to.y;x1=this.from.x-roundness*dx;x2=this.to.x+roundness*dx}else{y1=this.from.y-roundness*dy;y2=this.to.y+roundness*dy;x1=this.from.x;x2=this.to.x}return[{x:x1,y:y1},{x:x2,y:y2}]}},{key:\"getViaNode\",value:function getViaNode(){return this._getViaCoordinates()}},{key:\"_findBorderPosition\",value:function _findBorderPosition(nearNode,ctx){return this._findBorderPositionBezier(nearNode,ctx)}},{key:\"_getDistanceToEdge\",value:function _getDistanceToEdge(x1,y1,x2,y2,x3,y3){var _ref=arguments.length>6&&arguments[6]!==undefined?arguments[6]:this._getViaCoordinates(),_ref2=(0,_slicedToArray3[\"default\"])(_ref,2),via1=_ref2[0],via2=_ref2[1];return this._getDistanceToBezierEdge(x1,y1,x2,y2,x3,y3,via1,via2)}},{key:\"getPoint\",value:function getPoint(percentage){var _ref3=arguments.length>1&&arguments[1]!==undefined?arguments[1]:this._getViaCoordinates(),_ref4=(0,_slicedToArray3[\"default\"])(_ref3,2),via1=_ref4[0],via2=_ref4[1];var t=percentage;var vec=[];vec[0]=Math.pow(1-t,3);vec[1]=3*t*Math.pow(1-t,2);vec[2]=3*Math.pow(t,2)*(1-t);vec[3]=Math.pow(t,3);var x=vec[0]*this.fromPoint.x+vec[1]*via1.x+vec[2]*via2.x+vec[3]*this.toPoint.x;var y=vec[0]*this.fromPoint.y+vec[1]*via1.y+vec[2]*via2.y+vec[3]*this.toPoint.y;return{x:x,y:y}}}]);return CubicBezierEdge}(_CubicBezierEdgeBase3[\"default\"]);exports[\"default\"]=CubicBezierEdge},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _BezierEdgeBase2=__webpack_require__(75);var _BezierEdgeBase3=_interopRequireDefault(_BezierEdgeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var CubicBezierEdgeBase=function(_BezierEdgeBase){(0,_inherits3[\"default\"])(CubicBezierEdgeBase,_BezierEdgeBase);function CubicBezierEdgeBase(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,CubicBezierEdgeBase);return(0,_possibleConstructorReturn3[\"default\"])(this,(CubicBezierEdgeBase.__proto__||(0,_getPrototypeOf2[\"default\"])(CubicBezierEdgeBase)).call(this,options,body,labelModule))}(0,_createClass3[\"default\"])(CubicBezierEdgeBase,[{key:\"_getDistanceToBezierEdge\",value:function _getDistanceToBezierEdge(x1,y1,x2,y2,x3,y3,via1,via2){var minDistance=1e9;var distance=void 0;var i=void 0,t=void 0,x=void 0,y=void 0;var lastX=x1;var lastY=y1;var vec=[0,0,0,0];for(i=1;i<10;i++){t=.1*i;vec[0]=Math.pow(1-t,3);vec[1]=3*t*Math.pow(1-t,2);vec[2]=3*Math.pow(t,2)*(1-t);vec[3]=Math.pow(t,3);x=vec[0]*x1+vec[1]*via1.x+vec[2]*via2.x+vec[3]*x2;y=vec[0]*y1+vec[1]*via1.y+vec[2]*via2.y+vec[3]*y2;if(i>0){distance=this._getDistanceToLine(lastX,lastY,x,y,x3,y3);minDistance=distance<minDistance?distance:minDistance}lastX=x;lastY=y}return minDistance}}]);return CubicBezierEdgeBase}(_BezierEdgeBase3[\"default\"]);exports[\"default\"]=CubicBezierEdgeBase},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _slicedToArray2=__webpack_require__(30);var _slicedToArray3=_interopRequireDefault(_slicedToArray2);var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _BezierEdgeBase2=__webpack_require__(75);var _BezierEdgeBase3=_interopRequireDefault(_BezierEdgeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var BezierEdgeDynamic=function(_BezierEdgeBase){(0,_inherits3[\"default\"])(BezierEdgeDynamic,_BezierEdgeBase);function BezierEdgeDynamic(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,BezierEdgeDynamic);var _this=(0,_possibleConstructorReturn3[\"default\"])(this,(BezierEdgeDynamic.__proto__||(0,_getPrototypeOf2[\"default\"])(BezierEdgeDynamic)).call(this,options,body,labelModule));_this._boundFunction=function(){_this.positionBezierNode()};_this.body.emitter.on(\"_repositionBezierNodes\",_this._boundFunction);return _this}(0,_createClass3[\"default\"])(BezierEdgeDynamic,[{key:\"setOptions\",value:function setOptions(options){var physicsChange=false;if(this.options.physics!==options.physics){physicsChange=true}this.options=options;this.id=this.options.id;this.from=this.body.nodes[this.options.from];this.to=this.body.nodes[this.options.to];this.setupSupportNode();this.connect();if(physicsChange===true){this.via.setOptions({physics:this.options.physics});this.positionBezierNode()}}},{key:\"connect\",value:function connect(){this.from=this.body.nodes[this.options.from];this.to=this.body.nodes[this.options.to];if(this.from===undefined||this.to===undefined||this.options.physics===false){this.via.setOptions({physics:false})}else{if(this.from.id===this.to.id){this.via.setOptions({physics:false})}else{this.via.setOptions({physics:true})}}}},{key:\"cleanup\",value:function cleanup(){this.body.emitter.off(\"_repositionBezierNodes\",this._boundFunction);if(this.via!==undefined){delete this.body.nodes[this.via.id];this.via=undefined;return true}return false}},{key:\"setupSupportNode\",value:function setupSupportNode(){if(this.via===undefined){var nodeId=\"edgeId:\"+this.id;var node=this.body.functions.createNode({id:nodeId,shape:\"circle\",physics:true,hidden:true});this.body.nodes[nodeId]=node;this.via=node;this.via.parentEdgeId=this.id;this.positionBezierNode()}}},{key:\"positionBezierNode\",value:function positionBezierNode(){if(this.via!==undefined&&this.from!==undefined&&this.to!==undefined){this.via.x=.5*(this.from.x+this.to.x);this.via.y=.5*(this.from.y+this.to.y)}else if(this.via!==undefined){this.via.x=0;this.via.y=0}}},{key:\"_line\",value:function _line(ctx,values,viaNode){this._bezierCurve(ctx,values,viaNode)}},{key:\"getViaNode\",value:function getViaNode(){return this.via}},{key:\"getPoint\",value:function getPoint(percentage){var viaNode=arguments.length>1&&arguments[1]!==undefined?arguments[1]:this.via;var t=percentage;var x=void 0,y=void 0;if(this.from===this.to){var _getCircleData=this._getCircleData(this.from),_getCircleData2=(0,_slicedToArray3[\"default\"])(_getCircleData,3),cx=_getCircleData2[0],cy=_getCircleData2[1],cr=_getCircleData2[2];var a=2*Math.PI*(1-t);x=cx+cr*Math.sin(a);y=cy+cr-cr*(1-Math.cos(a))}else{x=Math.pow(1-t,2)*this.fromPoint.x+2*t*(1-t)*viaNode.x+Math.pow(t,2)*this.toPoint.x;y=Math.pow(1-t,2)*this.fromPoint.y+2*t*(1-t)*viaNode.y+Math.pow(t,2)*this.toPoint.y}return{x:x,y:y}}},{key:\"_findBorderPosition\",value:function _findBorderPosition(nearNode,ctx){return this._findBorderPositionBezier(nearNode,ctx,this.via)}},{key:\"_getDistanceToEdge\",value:function _getDistanceToEdge(x1,y1,x2,y2,x3,y3){return this._getDistanceToBezierEdge(x1,y1,x2,y2,x3,y3,this.via)}}]);return BezierEdgeDynamic}(_BezierEdgeBase3[\"default\"]);exports[\"default\"]=BezierEdgeDynamic},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _BezierEdgeBase2=__webpack_require__(75);var _BezierEdgeBase3=_interopRequireDefault(_BezierEdgeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var BezierEdgeStatic=function(_BezierEdgeBase){(0,_inherits3[\"default\"])(BezierEdgeStatic,_BezierEdgeBase);function BezierEdgeStatic(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,BezierEdgeStatic);return(0,_possibleConstructorReturn3[\"default\"])(this,(BezierEdgeStatic.__proto__||(0,_getPrototypeOf2[\"default\"])(BezierEdgeStatic)).call(this,options,body,labelModule))}(0,_createClass3[\"default\"])(BezierEdgeStatic,[{key:\"_line\",value:function _line(ctx,values,viaNode){this._bezierCurve(ctx,values,viaNode)}},{key:\"getViaNode\",value:function getViaNode(){return this._getViaCoordinates()}},{key:\"_getViaCoordinates\",value:function _getViaCoordinates(){var xVia=undefined;var yVia=undefined;var factor=this.options.smooth.roundness;var type=this.options.smooth.type;var dx=Math.abs(this.from.x-this.to.x);var dy=Math.abs(this.from.y-this.to.y);if(type===\"discrete\"||type===\"diagonalCross\"){var stepX=void 0;var stepY=void 0;if(dx<=dy){stepX=stepY=factor*dy}else{stepX=stepY=factor*dx}if(this.from.x>this.to.x)stepX=-stepX;if(this.from.y>=this.to.y)stepY=-stepY;xVia=this.from.x+stepX;yVia=this.from.y+stepY;if(type===\"discrete\"){if(dx<=dy){xVia=dx<factor*dy?this.from.x:xVia}else{yVia=dy<factor*dx?this.from.y:yVia}}}else if(type===\"straightCross\"){var _stepX=(1-factor)*dx;var _stepY=(1-factor)*dy;if(dx<=dy){_stepX=0;if(this.from.y<this.to.y)_stepY=-_stepY}else{if(this.from.x<this.to.x)_stepX=-_stepX;_stepY=0}xVia=this.to.x+_stepX;yVia=this.to.y+_stepY}else if(type===\"horizontal\"){var _stepX2=(1-factor)*dx;if(this.from.x<this.to.x)_stepX2=-_stepX2;xVia=this.to.x+_stepX2;yVia=this.from.y}else if(type===\"vertical\"){var _stepY2=(1-factor)*dy;if(this.from.y<this.to.y)_stepY2=-_stepY2;xVia=this.from.x;yVia=this.to.y+_stepY2}else if(type===\"curvedCW\"){dx=this.to.x-this.from.x;dy=this.from.y-this.to.y;var radius=Math.sqrt(dx*dx+dy*dy);var pi=Math.PI;var originalAngle=Math.atan2(dy,dx);var myAngle=(originalAngle+(factor*.5+.5)*pi)%(2*pi);xVia=this.from.x+(factor*.5+.5)*radius*Math.sin(myAngle);yVia=this.from.y+(factor*.5+.5)*radius*Math.cos(myAngle)}else if(type===\"curvedCCW\"){dx=this.to.x-this.from.x;dy=this.from.y-this.to.y;var _radius=Math.sqrt(dx*dx+dy*dy);var _pi=Math.PI;var _originalAngle=Math.atan2(dy,dx);var _myAngle=(_originalAngle+(-factor*.5+.5)*_pi)%(2*_pi);xVia=this.from.x+(factor*.5+.5)*_radius*Math.sin(_myAngle);yVia=this.from.y+(factor*.5+.5)*_radius*Math.cos(_myAngle)}else{var _stepX3=void 0;var _stepY3=void 0;if(dx<=dy){_stepX3=_stepY3=factor*dy}else{_stepX3=_stepY3=factor*dx}if(this.from.x>this.to.x)_stepX3=-_stepX3;if(this.from.y>=this.to.y)_stepY3=-_stepY3;xVia=this.from.x+_stepX3;yVia=this.from.y+_stepY3;if(dx<=dy){if(this.from.x<=this.to.x){xVia=this.to.x<xVia?this.to.x:xVia}else{xVia=this.to.x>xVia?this.to.x:xVia}}else{if(this.from.y>=this.to.y){yVia=this.to.y>yVia?this.to.y:yVia}else{yVia=this.to.y<yVia?this.to.y:yVia}}}return{x:xVia,y:yVia}}},{key:\"_findBorderPosition\",value:function _findBorderPosition(nearNode,ctx){var options=arguments.length>2&&arguments[2]!==undefined?arguments[2]:{};return this._findBorderPositionBezier(nearNode,ctx,options.via)}},{key:\"_getDistanceToEdge\",value:function _getDistanceToEdge(x1,y1,x2,y2,x3,y3){var viaNode=arguments.length>6&&arguments[6]!==undefined?arguments[6]:this._getViaCoordinates();return this._getDistanceToBezierEdge(x1,y1,x2,y2,x3,y3,viaNode)}},{key:\"getPoint\",value:function getPoint(percentage){var viaNode=arguments.length>1&&arguments[1]!==undefined?arguments[1]:this._getViaCoordinates();var t=percentage;var x=Math.pow(1-t,2)*this.fromPoint.x+2*t*(1-t)*viaNode.x+Math.pow(t,2)*this.toPoint.x;var y=Math.pow(1-t,2)*this.fromPoint.y+2*t*(1-t)*viaNode.y+Math.pow(t,2)*this.toPoint.y;return{x:x,y:y}}}]);return BezierEdgeStatic}(_BezierEdgeBase3[\"default\"]);exports[\"default\"]=BezierEdgeStatic},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _EdgeBase2=__webpack_require__(118);var _EdgeBase3=_interopRequireDefault(_EdgeBase2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var StraightEdge=function(_EdgeBase){(0,_inherits3[\"default\"])(StraightEdge,_EdgeBase);function StraightEdge(options,body,labelModule){(0,_classCallCheck3[\"default\"])(this,StraightEdge);return(0,_possibleConstructorReturn3[\"default\"])(this,(StraightEdge.__proto__||(0,_getPrototypeOf2[\"default\"])(StraightEdge)).call(this,options,body,labelModule))}(0,_createClass3[\"default\"])(StraightEdge,[{key:\"_line\",value:function _line(ctx,values){ctx.beginPath();ctx.moveTo(this.fromPoint.x,this.fromPoint.y);ctx.lineTo(this.toPoint.x,this.toPoint.y);this.enableShadow(ctx,values);ctx.stroke();this.disableShadow(ctx,values)}},{key:\"getViaNode\",value:function getViaNode(){return undefined}},{key:\"getPoint\",value:function getPoint(percentage){return{x:(1-percentage)*this.fromPoint.x+percentage*this.toPoint.x,y:(1-percentage)*this.fromPoint.y+percentage*this.toPoint.y}}},{key:\"_findBorderPosition\",value:function _findBorderPosition(nearNode,ctx){var node1=this.to;var node2=this.from;if(nearNode.id===this.from.id){node1=this.from;node2=this.to}var angle=Math.atan2(node1.y-node2.y,node1.x-node2.x);var dx=node1.x-node2.x;var dy=node1.y-node2.y;var edgeSegmentLength=Math.sqrt(dx*dx+dy*dy);var toBorderDist=nearNode.distanceToBorder(ctx,angle);var toBorderPoint=(edgeSegmentLength-toBorderDist)/edgeSegmentLength;var borderPos={};borderPos.x=(1-toBorderPoint)*node2.x+toBorderPoint*node1.x;borderPos.y=(1-toBorderPoint)*node2.y+toBorderPoint*node1.y;return borderPos}},{key:\"_getDistanceToEdge\",value:function _getDistanceToEdge(x1,y1,x2,y2,x3,y3){return this._getDistanceToLine(x1,y1,x2,y2,x3,y3)}}]);return StraightEdge}(_EdgeBase3[\"default\"]);exports[\"default\"]=StraightEdge},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _keys=__webpack_require__(8);var _keys2=_interopRequireDefault(_keys);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var BarnesHutSolver=__webpack_require__(120)[\"default\"];var Repulsion=__webpack_require__(221)[\"default\"];var HierarchicalRepulsion=__webpack_require__(222)[\"default\"];var SpringSolver=__webpack_require__(223)[\"default\"];var HierarchicalSpringSolver=__webpack_require__(224)[\"default\"];var CentralGravitySolver=__webpack_require__(121)[\"default\"];var ForceAtlas2BasedRepulsionSolver=__webpack_require__(225)[\"default\"];var ForceAtlas2BasedCentralGravitySolver=__webpack_require__(226)[\"default\"];var util=__webpack_require__(2);var EndPoints=__webpack_require__(119)[\"default\"];var PhysicsEngine=function(){function PhysicsEngine(body){(0,_classCallCheck3[\"default\"])(this,PhysicsEngine);this.body=body;this.physicsBody={physicsNodeIndices:[],physicsEdgeIndices:[],forces:{},velocities:{}};this.physicsEnabled=true;this.simulationInterval=1e3/60;this.requiresTimeout=true;this.previousStates={};this.referenceState={};this.freezeCache={};this.renderTimer=undefined;this.adaptiveTimestep=false;this.adaptiveTimestepEnabled=false;this.adaptiveCounter=0;this.adaptiveInterval=3;this.stabilized=false;this.startedStabilization=false;this.stabilizationIterations=0;this.ready=false;this.options={};this.defaultOptions={enabled:true,barnesHut:{theta:.5,gravitationalConstant:-2e3,centralGravity:.3,springLength:95,springConstant:.04,damping:.09,avoidOverlap:0},forceAtlas2Based:{theta:.5,gravitationalConstant:-50,centralGravity:.01,springConstant:.08,springLength:100,damping:.4,avoidOverlap:0},repulsion:{centralGravity:.2,springLength:200,springConstant:.05,nodeDistance:100,damping:.09,avoidOverlap:0},hierarchicalRepulsion:{centralGravity:0,springLength:100,springConstant:.01,nodeDistance:120,damping:.09},maxVelocity:50,minVelocity:.75,solver:\"barnesHut\",stabilization:{enabled:true,iterations:1e3,updateInterval:50,onlyDynamicEdges:false,fit:true},timestep:.5,adaptiveTimestep:true};util.extend(this.options,this.defaultOptions);this.timestep=.5;this.layoutFailed=false;this.bindEventListeners()}(0,_createClass3[\"default\"])(PhysicsEngine,[{key:\"bindEventListeners\",value:function bindEventListeners(){var _this=this;this.body.emitter.on(\"initPhysics\",function(){_this.initPhysics()});this.body.emitter.on(\"_layoutFailed\",function(){_this.layoutFailed=true});this.body.emitter.on(\"resetPhysics\",function(){_this.stopSimulation();_this.ready=false});this.body.emitter.on(\"disablePhysics\",function(){_this.physicsEnabled=false;_this.stopSimulation()});this.body.emitter.on(\"restorePhysics\",function(){_this.setOptions(_this.options);if(_this.ready===true){_this.startSimulation()}});this.body.emitter.on(\"startSimulation\",function(){if(_this.ready===true){_this.startSimulation()}});this.body.emitter.on(\"stopSimulation\",function(){_this.stopSimulation()});this.body.emitter.on(\"destroy\",function(){_this.stopSimulation(false);_this.body.emitter.off()});this.body.emitter.on(\"_dataChanged\",function(){_this.updatePhysicsData()})}},{key:\"setOptions\",value:function setOptions(options){if(options!==undefined){if(options===false){this.options.enabled=false;this.physicsEnabled=false;this.stopSimulation()}else if(options===true){this.options.enabled=true;this.physicsEnabled=true;this.startSimulation()}else{this.physicsEnabled=true;util.selectiveNotDeepExtend([\"stabilization\"],this.options,options);util.mergeOptions(this.options,options,\"stabilization\");if(options.enabled===undefined){this.options.enabled=true}if(this.options.enabled===false){this.physicsEnabled=false;this.stopSimulation()}this.timestep=this.options.timestep}}this.init()}},{key:\"init\",value:function init(){var options;if(this.options.solver===\"forceAtlas2Based\"){options=this.options.forceAtlas2Based;this.nodesSolver=new ForceAtlas2BasedRepulsionSolver(this.body,this.physicsBody,options);this.edgesSolver=new SpringSolver(this.body,this.physicsBody,options);this.gravitySolver=new ForceAtlas2BasedCentralGravitySolver(this.body,this.physicsBody,options)}else if(this.options.solver===\"repulsion\"){options=this.options.repulsion;this.nodesSolver=new Repulsion(this.body,this.physicsBody,options);this.edgesSolver=new SpringSolver(this.body,this.physicsBody,options);this.gravitySolver=new CentralGravitySolver(this.body,this.physicsBody,options)}else if(this.options.solver===\"hierarchicalRepulsion\"){options=this.options.hierarchicalRepulsion;this.nodesSolver=new HierarchicalRepulsion(this.body,this.physicsBody,options);this.edgesSolver=new HierarchicalSpringSolver(this.body,this.physicsBody,options);this.gravitySolver=new CentralGravitySolver(this.body,this.physicsBody,options)}else{options=this.options.barnesHut;this.nodesSolver=new BarnesHutSolver(this.body,this.physicsBody,options);this.edgesSolver=new SpringSolver(this.body,this.physicsBody,options);this.gravitySolver=new CentralGravitySolver(this.body,this.physicsBody,options)}this.modelOptions=options}},{key:\"initPhysics\",value:function initPhysics(){if(this.physicsEnabled===true&&this.options.enabled===true){if(this.options.stabilization.enabled===true){this.stabilize()}else{this.stabilized=false;this.ready=true;this.body.emitter.emit(\"fit\",{},this.layoutFailed);this.startSimulation()}}else{this.ready=true;this.body.emitter.emit(\"fit\")}}},{key:\"startSimulation\",value:function startSimulation(){if(this.physicsEnabled===true&&this.options.enabled===true){this.stabilized=false;this.adaptiveTimestep=false;this.body.emitter.emit(\"_resizeNodes\");if(this.viewFunction===undefined){this.viewFunction=this.simulationStep.bind(this);this.body.emitter.on(\"initRedraw\",this.viewFunction);this.body.emitter.emit(\"_startRendering\")}}else{this.body.emitter.emit(\"_redraw\")}}},{key:\"stopSimulation\",value:function stopSimulation(){var emit=arguments.length>0&&arguments[0]!==undefined?arguments[0]:true;this.stabilized=true;if(emit===true){this._emitStabilized()}if(this.viewFunction!==undefined){this.body.emitter.off(\"initRedraw\",this.viewFunction);this.viewFunction=undefined;if(emit===true){this.body.emitter.emit(\"_stopRendering\")}}}},{key:\"simulationStep\",value:function simulationStep(){var startTime=Date.now();this.physicsTick();var physicsTime=Date.now()-startTime;if((physicsTime<.4*this.simulationInterval||this.runDoubleSpeed===true)&&this.stabilized===false){this.physicsTick();this.runDoubleSpeed=true}if(this.stabilized===true){this.stopSimulation()}}},{key:\"_emitStabilized\",value:function _emitStabilized(){var _this2=this;var amountOfIterations=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.stabilizationIterations;if(this.stabilizationIterations>1||this.startedStabilization===true){setTimeout(function(){_this2.body.emitter.emit(\"stabilized\",{iterations:amountOfIterations});_this2.startedStabilization=false;_this2.stabilizationIterations=0},0)}}},{key:\"physicsStep\",value:function physicsStep(){this.gravitySolver.solve();this.nodesSolver.solve();this.edgesSolver.solve();this.moveNodes()}},{key:\"adjustTimeStep\",value:function adjustTimeStep(){var factor=1.2;if(this._evaluateStepQuality()===true){this.timestep=factor*this.timestep}else{if(this.timestep/factor<this.options.timestep){this.timestep=this.options.timestep}else{this.adaptiveCounter=-1;this.timestep=Math.max(this.options.timestep,this.timestep/factor)}}}},{key:\"physicsTick\",value:function physicsTick(){this._startStabilizing();if(this.stabilized===true)return;if(this.adaptiveTimestep===true&&this.adaptiveTimestepEnabled===true){var doAdaptive=this.adaptiveCounter%this.adaptiveInterval===0;if(doAdaptive){this.timestep=2*this.timestep;this.physicsStep();this.revert();this.timestep=.5*this.timestep;this.physicsStep();this.physicsStep();this.adjustTimeStep()}else{this.physicsStep()}this.adaptiveCounter+=1}else{this.timestep=this.options.timestep;this.physicsStep()}\nif(this.stabilized===true)this.revert();this.stabilizationIterations++}},{key:\"updatePhysicsData\",value:function updatePhysicsData(){this.physicsBody.forces={};this.physicsBody.physicsNodeIndices=[];this.physicsBody.physicsEdgeIndices=[];var nodes=this.body.nodes;var edges=this.body.edges;for(var nodeId in nodes){if(nodes.hasOwnProperty(nodeId)){if(nodes[nodeId].options.physics===true){this.physicsBody.physicsNodeIndices.push(nodes[nodeId].id)}}}for(var edgeId in edges){if(edges.hasOwnProperty(edgeId)){if(edges[edgeId].options.physics===true){this.physicsBody.physicsEdgeIndices.push(edges[edgeId].id)}}}for(var i=0;i<this.physicsBody.physicsNodeIndices.length;i++){var _nodeId=this.physicsBody.physicsNodeIndices[i];this.physicsBody.forces[_nodeId]={x:0,y:0};if(this.physicsBody.velocities[_nodeId]===undefined){this.physicsBody.velocities[_nodeId]={x:0,y:0}}}for(var _nodeId2 in this.physicsBody.velocities){if(nodes[_nodeId2]===undefined){delete this.physicsBody.velocities[_nodeId2]}}}},{key:\"revert\",value:function revert(){var nodeIds=(0,_keys2[\"default\"])(this.previousStates);var nodes=this.body.nodes;var velocities=this.physicsBody.velocities;this.referenceState={};for(var i=0;i<nodeIds.length;i++){var nodeId=nodeIds[i];if(nodes[nodeId]!==undefined){if(nodes[nodeId].options.physics===true){this.referenceState[nodeId]={positions:{x:nodes[nodeId].x,y:nodes[nodeId].y}};velocities[nodeId].x=this.previousStates[nodeId].vx;velocities[nodeId].y=this.previousStates[nodeId].vy;nodes[nodeId].x=this.previousStates[nodeId].x;nodes[nodeId].y=this.previousStates[nodeId].y}}else{delete this.previousStates[nodeId]}}}},{key:\"_evaluateStepQuality\",value:function _evaluateStepQuality(){var dx=void 0,dy=void 0,dpos=void 0;var nodes=this.body.nodes;var reference=this.referenceState;var posThreshold=.3;for(var nodeId in this.referenceState){if(this.referenceState.hasOwnProperty(nodeId)&&nodes[nodeId]!==undefined){dx=nodes[nodeId].x-reference[nodeId].positions.x;dy=nodes[nodeId].y-reference[nodeId].positions.y;dpos=Math.sqrt(Math.pow(dx,2)+Math.pow(dy,2));if(dpos>posThreshold){return false}}}return true}},{key:\"moveNodes\",value:function moveNodes(){var nodeIndices=this.physicsBody.physicsNodeIndices;var maxNodeVelocity=0;var averageNodeVelocity=0;var velocityAdaptiveThreshold=5;for(var i=0;i<nodeIndices.length;i++){var nodeId=nodeIndices[i];var nodeVelocity=this._performStep(nodeId);maxNodeVelocity=Math.max(maxNodeVelocity,nodeVelocity);averageNodeVelocity+=nodeVelocity}this.adaptiveTimestepEnabled=averageNodeVelocity/nodeIndices.length<velocityAdaptiveThreshold;this.stabilized=maxNodeVelocity<this.options.minVelocity}},{key:\"calculateComponentVelocity\",value:function calculateComponentVelocity(v,f,m){var df=this.modelOptions.damping*v;var a=(f-df)/m;v+=a*this.timestep;var maxV=this.options.maxVelocity||1e9;if(Math.abs(v)>maxV){v=v>0?maxV:-maxV}return v}},{key:\"_performStep\",value:function _performStep(nodeId){var node=this.body.nodes[nodeId];var force=this.physicsBody.forces[nodeId];var velocity=this.physicsBody.velocities[nodeId];this.previousStates[nodeId]={x:node.x,y:node.y,vx:velocity.x,vy:velocity.y};if(node.options.fixed.x===false){velocity.x=this.calculateComponentVelocity(velocity.x,force.x,node.options.mass);node.x+=velocity.x*this.timestep}else{force.x=0;velocity.x=0}if(node.options.fixed.y===false){velocity.y=this.calculateComponentVelocity(velocity.y,force.y,node.options.mass);node.y+=velocity.y*this.timestep}else{force.y=0;velocity.y=0}var totalVelocity=Math.sqrt(Math.pow(velocity.x,2)+Math.pow(velocity.y,2));return totalVelocity}},{key:\"_freezeNodes\",value:function _freezeNodes(){var nodes=this.body.nodes;for(var id in nodes){if(nodes.hasOwnProperty(id)){if(nodes[id].x&&nodes[id].y){var fixed=nodes[id].options.fixed;this.freezeCache[id]={x:fixed.x,y:fixed.y};fixed.x=true;fixed.y=true}}}}},{key:\"_restoreFrozenNodes\",value:function _restoreFrozenNodes(){var nodes=this.body.nodes;for(var id in nodes){if(nodes.hasOwnProperty(id)){if(this.freezeCache[id]!==undefined){nodes[id].options.fixed.x=this.freezeCache[id].x;nodes[id].options.fixed.y=this.freezeCache[id].y}}}this.freezeCache={}}},{key:\"stabilize\",value:function stabilize(){var _this3=this;var iterations=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.options.stabilization.iterations;if(typeof iterations!==\"number\"){iterations=this.options.stabilization.iterations;console.log(\"The stabilize method needs a numeric amount of iterations. Switching to default: \",iterations)}if(this.physicsBody.physicsNodeIndices.length===0){this.ready=true;return}this.adaptiveTimestep=true&&this.options.adaptiveTimestep;this.body.emitter.emit(\"_resizeNodes\");this.stopSimulation();this.stabilized=false;this.body.emitter.emit(\"_blockRedraw\");this.targetIterations=iterations;if(this.options.stabilization.onlyDynamicEdges===true){this._freezeNodes()}this.stabilizationIterations=0;setTimeout(function(){return _this3._stabilizationBatch()},0)}},{key:\"_startStabilizing\",value:function _startStabilizing(){if(this.startedStabilization===true)return false;this.body.emitter.emit(\"startStabilizing\");this.startedStabilization=true;return true}},{key:\"_stabilizationBatch\",value:function _stabilizationBatch(){var _this4=this;var running=function running(){return _this4.stabilized===false&&_this4.stabilizationIterations<_this4.targetIterations};var sendProgress=function sendProgress(){_this4.body.emitter.emit(\"stabilizationProgress\",{iterations:_this4.stabilizationIterations,total:_this4.targetIterations})};if(this._startStabilizing()){sendProgress()}var count=0;while(running()&&count<this.options.stabilization.updateInterval){this.physicsTick();count++}sendProgress();if(running()){setTimeout(this._stabilizationBatch.bind(this),0)}else{this._finalizeStabilization()}}},{key:\"_finalizeStabilization\",value:function _finalizeStabilization(){this.body.emitter.emit(\"_allowRedraw\");if(this.options.stabilization.fit===true){this.body.emitter.emit(\"fit\")}if(this.options.stabilization.onlyDynamicEdges===true){this._restoreFrozenNodes()}this.body.emitter.emit(\"stabilizationIterationsDone\");this.body.emitter.emit(\"_requestRedraw\");if(this.stabilized===true){this._emitStabilized()}else{this.startSimulation()}this.ready=true}},{key:\"_drawForces\",value:function _drawForces(ctx){for(var i=0;i<this.physicsBody.physicsNodeIndices.length;i++){var index=this.physicsBody.physicsNodeIndices[i];var node=this.body.nodes[index];var force=this.physicsBody.forces[index];var factor=20;var colorFactor=.03;var forceSize=Math.sqrt(Math.pow(force.x,2)+Math.pow(force.x,2));var size=Math.min(Math.max(5,forceSize),15);var arrowSize=3*size;var color=util.HSVToHex((180-Math.min(1,Math.max(0,colorFactor*forceSize))*180)/360,1,1);var point={x:node.x+factor*force.x,y:node.y+factor*force.y};ctx.lineWidth=size;ctx.strokeStyle=color;ctx.beginPath();ctx.moveTo(node.x,node.y);ctx.lineTo(point.x,point.y);ctx.stroke();var angle=Math.atan2(force.y,force.x);ctx.fillStyle=color;EndPoints.draw(ctx,{type:\"arrow\",point:point,angle:angle,length:arrowSize});ctx.fill()}}}]);return PhysicsEngine}();exports[\"default\"]=PhysicsEngine},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var RepulsionSolver=function(){function RepulsionSolver(body,physicsBody,options){(0,_classCallCheck3[\"default\"])(this,RepulsionSolver);this.body=body;this.physicsBody=physicsBody;this.setOptions(options)}(0,_createClass3[\"default\"])(RepulsionSolver,[{key:\"setOptions\",value:function setOptions(options){this.options=options}},{key:\"solve\",value:function solve(){var dx,dy,distance,fx,fy,repulsingForce,node1,node2;var nodes=this.body.nodes;var nodeIndices=this.physicsBody.physicsNodeIndices;var forces=this.physicsBody.forces;var nodeDistance=this.options.nodeDistance;var a=-2/3/nodeDistance;var b=4/3;for(var i=0;i<nodeIndices.length-1;i++){node1=nodes[nodeIndices[i]];for(var j=i+1;j<nodeIndices.length;j++){node2=nodes[nodeIndices[j]];dx=node2.x-node1.x;dy=node2.y-node1.y;distance=Math.sqrt(dx*dx+dy*dy);if(distance===0){distance=.1*Math.random();dx=distance}if(distance<2*nodeDistance){if(distance<.5*nodeDistance){repulsingForce=1}else{repulsingForce=a*distance+b}repulsingForce=repulsingForce/distance;fx=dx*repulsingForce;fy=dy*repulsingForce;forces[node1.id].x-=fx;forces[node1.id].y-=fy;forces[node2.id].x+=fx;forces[node2.id].y+=fy}}}}}]);return RepulsionSolver}();exports[\"default\"]=RepulsionSolver},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var HierarchicalRepulsionSolver=function(){function HierarchicalRepulsionSolver(body,physicsBody,options){(0,_classCallCheck3[\"default\"])(this,HierarchicalRepulsionSolver);this.body=body;this.physicsBody=physicsBody;this.setOptions(options)}(0,_createClass3[\"default\"])(HierarchicalRepulsionSolver,[{key:\"setOptions\",value:function setOptions(options){this.options=options}},{key:\"solve\",value:function solve(){var dx,dy,distance,fx,fy,repulsingForce,node1,node2,i,j;var nodes=this.body.nodes;var nodeIndices=this.physicsBody.physicsNodeIndices;var forces=this.physicsBody.forces;var nodeDistance=this.options.nodeDistance;for(i=0;i<nodeIndices.length-1;i++){node1=nodes[nodeIndices[i]];for(j=i+1;j<nodeIndices.length;j++){node2=nodes[nodeIndices[j]];if(node1.level===node2.level){dx=node2.x-node1.x;dy=node2.y-node1.y;distance=Math.sqrt(dx*dx+dy*dy);var steepness=.05;if(distance<nodeDistance){repulsingForce=-Math.pow(steepness*distance,2)+Math.pow(steepness*nodeDistance,2)}else{repulsingForce=0}if(distance===0){distance=.01}else{repulsingForce=repulsingForce/distance}fx=dx*repulsingForce;fy=dy*repulsingForce;forces[node1.id].x-=fx;forces[node1.id].y-=fy;forces[node2.id].x+=fx;forces[node2.id].y+=fy}}}}}]);return HierarchicalRepulsionSolver}();exports[\"default\"]=HierarchicalRepulsionSolver},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var SpringSolver=function(){function SpringSolver(body,physicsBody,options){(0,_classCallCheck3[\"default\"])(this,SpringSolver);this.body=body;this.physicsBody=physicsBody;this.setOptions(options)}(0,_createClass3[\"default\"])(SpringSolver,[{key:\"setOptions\",value:function setOptions(options){this.options=options}},{key:\"solve\",value:function solve(){var edgeLength=void 0,edge=void 0;var edgeIndices=this.physicsBody.physicsEdgeIndices;var edges=this.body.edges;var node1=void 0,node2=void 0,node3=void 0;for(var i=0;i<edgeIndices.length;i++){edge=edges[edgeIndices[i]];if(edge.connected===true&&edge.toId!==edge.fromId){if(this.body.nodes[edge.toId]!==undefined&&this.body.nodes[edge.fromId]!==undefined){if(edge.edgeType.via!==undefined){edgeLength=edge.options.length===undefined?this.options.springLength:edge.options.length;node1=edge.to;node2=edge.edgeType.via;node3=edge.from;this._calculateSpringForce(node1,node2,.5*edgeLength);this._calculateSpringForce(node2,node3,.5*edgeLength)}else{edgeLength=edge.options.length===undefined?this.options.springLength*1.5:edge.options.length;this._calculateSpringForce(edge.from,edge.to,edgeLength)}}}}}},{key:\"_calculateSpringForce\",value:function _calculateSpringForce(node1,node2,edgeLength){var dx=node1.x-node2.x;var dy=node1.y-node2.y;var distance=Math.max(Math.sqrt(dx*dx+dy*dy),.01);var springForce=this.options.springConstant*(edgeLength-distance)/distance;var fx=dx*springForce;var fy=dy*springForce;if(this.physicsBody.forces[node1.id]!==undefined){this.physicsBody.forces[node1.id].x+=fx;this.physicsBody.forces[node1.id].y+=fy}if(this.physicsBody.forces[node2.id]!==undefined){this.physicsBody.forces[node2.id].x-=fx;this.physicsBody.forces[node2.id].y-=fy}}}]);return SpringSolver}();exports[\"default\"]=SpringSolver},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var HierarchicalSpringSolver=function(){function HierarchicalSpringSolver(body,physicsBody,options){(0,_classCallCheck3[\"default\"])(this,HierarchicalSpringSolver);this.body=body;this.physicsBody=physicsBody;this.setOptions(options)}(0,_createClass3[\"default\"])(HierarchicalSpringSolver,[{key:\"setOptions\",value:function setOptions(options){this.options=options}},{key:\"solve\",value:function solve(){var edgeLength,edge;var dx,dy,fx,fy,springForce,distance;var edges=this.body.edges;var factor=.5;var edgeIndices=this.physicsBody.physicsEdgeIndices;var nodeIndices=this.physicsBody.physicsNodeIndices;var forces=this.physicsBody.forces;for(var i=0;i<nodeIndices.length;i++){var nodeId=nodeIndices[i];forces[nodeId].springFx=0;forces[nodeId].springFy=0}for(var _i=0;_i<edgeIndices.length;_i++){edge=edges[edgeIndices[_i]];if(edge.connected===true){edgeLength=edge.options.length===undefined?this.options.springLength:edge.options.length;dx=edge.from.x-edge.to.x;dy=edge.from.y-edge.to.y;distance=Math.sqrt(dx*dx+dy*dy);distance=distance===0?.01:distance;springForce=this.options.springConstant*(edgeLength-distance)/distance;fx=dx*springForce;fy=dy*springForce;if(edge.to.level!=edge.from.level){if(forces[edge.toId]!==undefined){forces[edge.toId].springFx-=fx;forces[edge.toId].springFy-=fy}if(forces[edge.fromId]!==undefined){forces[edge.fromId].springFx+=fx;forces[edge.fromId].springFy+=fy}}else{if(forces[edge.toId]!==undefined){forces[edge.toId].x-=factor*fx;forces[edge.toId].y-=factor*fy}if(forces[edge.fromId]!==undefined){forces[edge.fromId].x+=factor*fx;forces[edge.fromId].y+=factor*fy}}}}springForce=1;var springFx,springFy;for(var _i2=0;_i2<nodeIndices.length;_i2++){var _nodeId=nodeIndices[_i2];springFx=Math.min(springForce,Math.max(-springForce,forces[_nodeId].springFx));springFy=Math.min(springForce,Math.max(-springForce,forces[_nodeId].springFy));forces[_nodeId].x+=springFx;forces[_nodeId].y+=springFy}var totalFx=0;var totalFy=0;for(var _i3=0;_i3<nodeIndices.length;_i3++){var _nodeId2=nodeIndices[_i3];totalFx+=forces[_nodeId2].x;totalFy+=forces[_nodeId2].y}var correctionFx=totalFx/nodeIndices.length;var correctionFy=totalFy/nodeIndices.length;for(var _i4=0;_i4<nodeIndices.length;_i4++){var _nodeId3=nodeIndices[_i4];forces[_nodeId3].x-=correctionFx;forces[_nodeId3].y-=correctionFy}}}]);return HierarchicalSpringSolver}();exports[\"default\"]=HierarchicalSpringSolver},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _BarnesHutSolver2=__webpack_require__(120);var _BarnesHutSolver3=_interopRequireDefault(_BarnesHutSolver2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var ForceAtlas2BasedRepulsionSolver=function(_BarnesHutSolver){(0,_inherits3[\"default\"])(ForceAtlas2BasedRepulsionSolver,_BarnesHutSolver);function ForceAtlas2BasedRepulsionSolver(body,physicsBody,options){(0,_classCallCheck3[\"default\"])(this,ForceAtlas2BasedRepulsionSolver);return(0,_possibleConstructorReturn3[\"default\"])(this,(ForceAtlas2BasedRepulsionSolver.__proto__||(0,_getPrototypeOf2[\"default\"])(ForceAtlas2BasedRepulsionSolver)).call(this,body,physicsBody,options))}(0,_createClass3[\"default\"])(ForceAtlas2BasedRepulsionSolver,[{key:\"_calculateForces\",value:function _calculateForces(distance,dx,dy,node,parentBranch){if(distance===0){distance=.1*Math.random();dx=distance}if(this.overlapAvoidanceFactor<1&&node.shape.radius){distance=Math.max(.1+this.overlapAvoidanceFactor*node.shape.radius,distance-node.shape.radius)}var degree=node.edges.length+1;var gravityForce=this.options.gravitationalConstant*parentBranch.mass*node.options.mass*degree/Math.pow(distance,2);var fx=dx*gravityForce;var fy=dy*gravityForce;this.physicsBody.forces[node.id].x+=fx;this.physicsBody.forces[node.id].y+=fy}}]);return ForceAtlas2BasedRepulsionSolver}(_BarnesHutSolver3[\"default\"]);exports[\"default\"]=ForceAtlas2BasedRepulsionSolver},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _CentralGravitySolver2=__webpack_require__(121);var _CentralGravitySolver3=_interopRequireDefault(_CentralGravitySolver2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var ForceAtlas2BasedCentralGravitySolver=function(_CentralGravitySolver){(0,_inherits3[\"default\"])(ForceAtlas2BasedCentralGravitySolver,_CentralGravitySolver);function ForceAtlas2BasedCentralGravitySolver(body,physicsBody,options){(0,_classCallCheck3[\"default\"])(this,ForceAtlas2BasedCentralGravitySolver);return(0,_possibleConstructorReturn3[\"default\"])(this,(ForceAtlas2BasedCentralGravitySolver.__proto__||(0,_getPrototypeOf2[\"default\"])(ForceAtlas2BasedCentralGravitySolver)).call(this,body,physicsBody,options))}(0,_createClass3[\"default\"])(ForceAtlas2BasedCentralGravitySolver,[{key:\"_calculateForces\",value:function _calculateForces(distance,dx,dy,forces,node){if(distance>0){var degree=node.edges.length+1;var gravityForce=this.options.centralGravity*degree*node.options.mass;forces[node.id].x=dx*gravityForce;forces[node.id].y=dy*gravityForce}}}]);return ForceAtlas2BasedCentralGravitySolver}(_CentralGravitySolver3[\"default\"]);exports[\"default\"]=ForceAtlas2BasedCentralGravitySolver},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _keys=__webpack_require__(8);var _keys2=_interopRequireDefault(_keys);var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var NetworkUtil=__webpack_require__(76)[\"default\"];var Cluster=__webpack_require__(228)[\"default\"];var Edge=__webpack_require__(74)[\"default\"];var Node=__webpack_require__(47)[\"default\"];var ClusterEngine=function(){function ClusterEngine(body){var _this=this;(0,_classCallCheck3[\"default\"])(this,ClusterEngine);this.body=body;this.clusteredNodes={};this.clusteredEdges={};this.options={};this.defaultOptions={};util.extend(this.options,this.defaultOptions);this.body.emitter.on(\"_resetData\",function(){_this.clusteredNodes={};_this.clusteredEdges={}})}(0,_createClass3[\"default\"])(ClusterEngine,[{key:\"clusterByHubsize\",value:function clusterByHubsize(hubsize,options){if(hubsize===undefined){hubsize=this._getHubSize()}else if((typeof hubsize===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(hubsize))===\"object\"){options=this._checkOptions(hubsize);hubsize=this._getHubSize()}var nodesToCluster=[];for(var i=0;i<this.body.nodeIndices.length;i++){var node=this.body.nodes[this.body.nodeIndices[i]];if(node.edges.length>=hubsize){nodesToCluster.push(node.id)}}for(var _i=0;_i<nodesToCluster.length;_i++){this.clusterByConnection(nodesToCluster[_i],options,true)}this.body.emitter.emit(\"_dataChanged\")}},{key:\"cluster\",value:function cluster(){var _this2=this;var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};var refreshData=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;if(options.joinCondition===undefined){throw new Error(\"Cannot call clusterByNodeData without a joinCondition function in the options.\")}options=this._checkOptions(options);var childNodesObj={};var childEdgesObj={};util.forEach(this.body.nodes,function(node,nodeId){var clonedOptions=NetworkUtil.cloneOptions(node);if(options.joinCondition(clonedOptions)===true){childNodesObj[nodeId]=node;util.forEach(node.edges,function(edge){if(_this2.clusteredEdges[edge.id]===undefined){childEdgesObj[edge.id]=edge}})}});this._cluster(childNodesObj,childEdgesObj,options,refreshData)}},{key:\"clusterByEdgeCount\",value:function clusterByEdgeCount(edgeCount,options){var _this3=this;var refreshData=arguments.length>2&&arguments[2]!==undefined?arguments[2]:true;options=this._checkOptions(options);var clusters=[];var usedNodes={};var edge=void 0,edges=void 0,relevantEdgeCount=void 0;var _loop=function _loop(i){var childNodesObj={};var childEdgesObj={};var nodeId=_this3.body.nodeIndices[i];var node=_this3.body.nodes[nodeId];if(usedNodes[nodeId]===undefined){relevantEdgeCount=0;edges=[];for(var j=0;j<node.edges.length;j++){edge=node.edges[j];if(_this3.clusteredEdges[edge.id]===undefined){if(edge.toId!==edge.fromId){relevantEdgeCount++}edges.push(edge)}}if(relevantEdgeCount===edgeCount){checkJoinCondition=function checkJoinCondition(node){if(options.joinCondition===undefined||options.joinCondition===null){return true}var clonedOptions=NetworkUtil.cloneOptions(node);return options.joinCondition(clonedOptions)};var gatheringSuccessful=true;for(var _j=0;_j<edges.length;_j++){edge=edges[_j];var childNodeId=_this3._getConnectedId(edge,nodeId);if(checkJoinCondition(node)){childEdgesObj[edge.id]=edge;childNodesObj[nodeId]=node;childNodesObj[childNodeId]=_this3.body.nodes[childNodeId];usedNodes[nodeId]=true}else{gatheringSuccessful=false;break}}if((0,_keys2[\"default\"])(childNodesObj).length>0&&(0,_keys2[\"default\"])(childEdgesObj).length>0&&gatheringSuccessful===true){findClusterData=function findClusterData(){for(var n=0;n<clusters.length;++n){for(var m in childNodesObj){if(clusters[n].nodes[m]!==undefined){return clusters[n]}}}return undefined};foundCluster=findClusterData();if(foundCluster!==undefined){for(var m in childNodesObj){if(foundCluster.nodes[m]===undefined){foundCluster.nodes[m]=childNodesObj[m]}}for(var _m in childEdgesObj){if(foundCluster.edges[_m]===undefined){foundCluster.edges[_m]=childEdgesObj[_m]}}}else{clusters.push({nodes:childNodesObj,edges:childEdgesObj})}}}}};for(var i=0;i<this.body.nodeIndices.length;i++){var checkJoinCondition;var findClusterData;var foundCluster;_loop(i)}for(var i=0;i<clusters.length;i++){this._cluster(clusters[i].nodes,clusters[i].edges,options,false)}if(refreshData===true){this.body.emitter.emit(\"_dataChanged\")}}},{key:\"clusterOutliers\",value:function clusterOutliers(options){var refreshData=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;this.clusterByEdgeCount(1,options,refreshData)}},{key:\"clusterBridges\",value:function clusterBridges(options){var refreshData=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;this.clusterByEdgeCount(2,options,refreshData)}},{key:\"clusterByConnection\",value:function clusterByConnection(nodeId,options){var refreshData=arguments.length>2&&arguments[2]!==undefined?arguments[2]:true;if(nodeId===undefined){throw new Error(\"No nodeId supplied to clusterByConnection!\")}if(this.body.nodes[nodeId]===undefined){throw new Error(\"The nodeId given to clusterByConnection does not exist!\")}var node=this.body.nodes[nodeId];options=this._checkOptions(options,node);if(options.clusterNodeProperties.x===undefined){options.clusterNodeProperties.x=node.x}if(options.clusterNodeProperties.y===undefined){options.clusterNodeProperties.y=node.y}if(options.clusterNodeProperties.fixed===undefined){options.clusterNodeProperties.fixed={};options.clusterNodeProperties.fixed.x=node.options.fixed.x;options.clusterNodeProperties.fixed.y=node.options.fixed.y}var childNodesObj={};var childEdgesObj={};var parentNodeId=node.id;var parentClonedOptions=NetworkUtil.cloneOptions(node);childNodesObj[parentNodeId]=node;for(var i=0;i<node.edges.length;i++){var edge=node.edges[i];if(this.clusteredEdges[edge.id]===undefined){var childNodeId=this._getConnectedId(edge,parentNodeId);if(this.clusteredNodes[childNodeId]===undefined){if(childNodeId!==parentNodeId){if(options.joinCondition===undefined){childEdgesObj[edge.id]=edge;childNodesObj[childNodeId]=this.body.nodes[childNodeId]}else{var childClonedOptions=NetworkUtil.cloneOptions(this.body.nodes[childNodeId]);if(options.joinCondition(parentClonedOptions,childClonedOptions)===true){childEdgesObj[edge.id]=edge;childNodesObj[childNodeId]=this.body.nodes[childNodeId]}}}else{childEdgesObj[edge.id]=edge}}}}var childNodeIDs=(0,_keys2[\"default\"])(childNodesObj).map(function(childNode){return childNodesObj[childNode].id});for(childNode in childNodesObj){if(!childNodesObj.hasOwnProperty(childNode))continue;var childNode=childNodesObj[childNode];for(var y=0;y<childNode.edges.length;y++){var childEdge=childNode.edges[y];if(childNodeIDs.indexOf(this._getConnectedId(childEdge,childNode.id))>-1){childEdgesObj[childEdge.id]=childEdge}}}this._cluster(childNodesObj,childEdgesObj,options,refreshData)}},{key:\"_createClusterEdges\",value:function _createClusterEdges(childNodesObj,childEdgesObj,clusterNodeProperties,clusterEdgeProperties){var edge=void 0,childNodeId=void 0,childNode=void 0,toId=void 0,fromId=void 0,otherNodeId=void 0;var childKeys=(0,_keys2[\"default\"])(childNodesObj);var createEdges=[];for(var i=0;i<childKeys.length;i++){childNodeId=childKeys[i];childNode=childNodesObj[childNodeId];for(var j=0;j<childNode.edges.length;j++){edge=childNode.edges[j];if(this.clusteredEdges[edge.id]===undefined){if(edge.toId==edge.fromId){childEdgesObj[edge.id]=edge}else{if(edge.toId==childNodeId){toId=clusterNodeProperties.id;fromId=edge.fromId;otherNodeId=fromId}else{toId=edge.toId;fromId=clusterNodeProperties.id;otherNodeId=toId}}if(childNodesObj[otherNodeId]===undefined){createEdges.push({edge:edge,fromId:fromId,toId:toId})}}}}var newEdges=[];var getNewEdge=function getNewEdge(createdEdge){for(var _j2=0;_j2<newEdges.length;_j2++){var newEdge=newEdges[_j2];var matchToDirection=createdEdge.fromId===newEdge.fromId&&createdEdge.toId===newEdge.toId;var matchFromDirection=createdEdge.fromId===newEdge.toId&&createdEdge.toId===newEdge.fromId;if(matchToDirection||matchFromDirection){return newEdge}}return null};for(var _j3=0;_j3<createEdges.length;_j3++){var createdEdge=createEdges[_j3];var _edge=createdEdge.edge;var newEdge=getNewEdge(createdEdge);if(newEdge===null){newEdge=this._createClusteredEdge(createdEdge.fromId,createdEdge.toId,_edge,clusterEdgeProperties);newEdges.push(newEdge)}else{newEdge.clusteringEdgeReplacingIds.push(_edge.id)}this.body.edges[_edge.id].edgeReplacedById=newEdge.id;this._backupEdgeOptions(_edge);_edge.setOptions({physics:false})}}},{key:\"_checkOptions\",value:function _checkOptions(){var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};if(options.clusterEdgeProperties===undefined){options.clusterEdgeProperties={}}if(options.clusterNodeProperties===undefined){options.clusterNodeProperties={}}return options}},{key:\"_cluster\",value:function _cluster(childNodesObj,childEdgesObj,options){var refreshData=arguments.length>3&&arguments[3]!==undefined?arguments[3]:true;var tmpNodesToRemove=[];for(var _nodeId in childNodesObj){if(childNodesObj.hasOwnProperty(_nodeId)){if(this.clusteredNodes[_nodeId]!==undefined){tmpNodesToRemove.push(_nodeId)}}}for(var n=0;n<tmpNodesToRemove.length;++n){delete childNodesObj[tmpNodesToRemove[n]]}if((0,_keys2[\"default\"])(childNodesObj).length==0){return}if((0,_keys2[\"default\"])(childNodesObj).length==1&&options.clusterNodeProperties.allowSingleNodeCluster!=true){return}var clusterNodeProperties=util.deepExtend({},options.clusterNodeProperties);if(options.processProperties!==undefined){var childNodesOptions=[];for(var _nodeId2 in childNodesObj){if(childNodesObj.hasOwnProperty(_nodeId2)){var clonedOptions=NetworkUtil.cloneOptions(childNodesObj[_nodeId2]);childNodesOptions.push(clonedOptions)}}var childEdgesOptions=[];for(var edgeId in childEdgesObj){if(childEdgesObj.hasOwnProperty(edgeId)){if(edgeId.substr(0,12)!==\"clusterEdge:\"){var _clonedOptions=NetworkUtil.cloneOptions(childEdgesObj[edgeId],\"edge\");childEdgesOptions.push(_clonedOptions)}}}clusterNodeProperties=options.processProperties(clusterNodeProperties,childNodesOptions,childEdgesOptions);if(!clusterNodeProperties){throw new Error(\"The processProperties function does not return properties!\")}}if(clusterNodeProperties.id===undefined){clusterNodeProperties.id=\"cluster:\"+util.randomUUID()}var clusterId=clusterNodeProperties.id;if(clusterNodeProperties.label===undefined){clusterNodeProperties.label=\"cluster\"}var pos=undefined;if(clusterNodeProperties.x===undefined){pos=this._getClusterPosition(childNodesObj);clusterNodeProperties.x=pos.x}if(clusterNodeProperties.y===undefined){if(pos===undefined){pos=this._getClusterPosition(childNodesObj)}clusterNodeProperties.y=pos.y}clusterNodeProperties.id=clusterId;var clusterNode=this.body.functions.createNode(clusterNodeProperties,Cluster);clusterNode.containedNodes=childNodesObj;clusterNode.containedEdges=childEdgesObj;clusterNode.clusterEdgeProperties=options.clusterEdgeProperties;this.body.nodes[clusterNodeProperties.id]=clusterNode;this._clusterEdges(childNodesObj,childEdgesObj,clusterNodeProperties,options.clusterEdgeProperties);clusterNodeProperties.id=undefined;if(refreshData===true){this.body.emitter.emit(\"_dataChanged\")}}},{key:\"_backupEdgeOptions\",value:function _backupEdgeOptions(edge){if(this.clusteredEdges[edge.id]===undefined){this.clusteredEdges[edge.id]={physics:edge.options.physics}}}},{key:\"_restoreEdge\",value:function _restoreEdge(edge){var originalOptions=this.clusteredEdges[edge.id];if(originalOptions!==undefined){edge.setOptions({physics:originalOptions.physics});delete this.clusteredEdges[edge.id]}}},{key:\"isCluster\",value:function isCluster(nodeId){if(this.body.nodes[nodeId]!==undefined){return this.body.nodes[nodeId].isCluster===true}else{console.log(\"Node does not exist.\");return false}}},{key:\"_getClusterPosition\",value:function _getClusterPosition(childNodesObj){var childKeys=(0,_keys2[\"default\"])(childNodesObj);var minX=childNodesObj[childKeys[0]].x;var maxX=childNodesObj[childKeys[0]].x;var minY=childNodesObj[childKeys[0]].y;var maxY=childNodesObj[childKeys[0]].y;var node=void 0;for(var i=1;i<childKeys.length;i++){node=childNodesObj[childKeys[i]];minX=node.x<minX?node.x:minX;maxX=node.x>maxX?node.x:maxX\n;minY=node.y<minY?node.y:minY;maxY=node.y>maxY?node.y:maxY}return{x:.5*(minX+maxX),y:.5*(minY+maxY)}}},{key:\"openCluster\",value:function openCluster(clusterNodeId,options){var refreshData=arguments.length>2&&arguments[2]!==undefined?arguments[2]:true;if(clusterNodeId===undefined){throw new Error(\"No clusterNodeId supplied to openCluster.\")}var clusterNode=this.body.nodes[clusterNodeId];if(clusterNode===undefined){throw new Error(\"The clusterNodeId supplied to openCluster does not exist.\")}if(clusterNode.isCluster!==true||clusterNode.containedNodes===undefined||clusterNode.containedEdges===undefined){throw new Error(\"The node:\"+clusterNodeId+\" is not a valid cluster.\")}var stack=this.findNode(clusterNodeId);var parentIndex=stack.indexOf(clusterNodeId)-1;if(parentIndex>=0){var parentClusterNodeId=stack[parentIndex];var parentClusterNode=this.body.nodes[parentClusterNodeId];parentClusterNode._openChildCluster(clusterNodeId);delete this.body.nodes[clusterNodeId];if(refreshData===true){this.body.emitter.emit(\"_dataChanged\")}return}var containedNodes=clusterNode.containedNodes;var containedEdges=clusterNode.containedEdges;if(options!==undefined&&options.releaseFunction!==undefined&&typeof options.releaseFunction===\"function\"){var positions={};var clusterPosition={x:clusterNode.x,y:clusterNode.y};for(var _nodeId3 in containedNodes){if(containedNodes.hasOwnProperty(_nodeId3)){var containedNode=this.body.nodes[_nodeId3];positions[_nodeId3]={x:containedNode.x,y:containedNode.y}}}var newPositions=options.releaseFunction(clusterPosition,positions);for(var _nodeId4 in containedNodes){if(containedNodes.hasOwnProperty(_nodeId4)){var _containedNode=this.body.nodes[_nodeId4];if(newPositions[_nodeId4]!==undefined){_containedNode.x=newPositions[_nodeId4].x===undefined?clusterNode.x:newPositions[_nodeId4].x;_containedNode.y=newPositions[_nodeId4].y===undefined?clusterNode.y:newPositions[_nodeId4].y}}}}else{util.forEach(containedNodes,function(containedNode){if(containedNode.options.fixed.x===false){containedNode.x=clusterNode.x}if(containedNode.options.fixed.y===false){containedNode.y=clusterNode.y}})}for(var _nodeId5 in containedNodes){if(containedNodes.hasOwnProperty(_nodeId5)){var _containedNode2=this.body.nodes[_nodeId5];_containedNode2.vx=clusterNode.vx;_containedNode2.vy=clusterNode.vy;_containedNode2.setOptions({physics:true});delete this.clusteredNodes[_nodeId5]}}var edgesToBeDeleted=[];for(var i=0;i<clusterNode.edges.length;i++){edgesToBeDeleted.push(clusterNode.edges[i])}for(var _i2=0;_i2<edgesToBeDeleted.length;_i2++){var edge=edgesToBeDeleted[_i2];var otherNodeId=this._getConnectedId(edge,clusterNodeId);var otherNode=this.clusteredNodes[otherNodeId];for(var j=0;j<edge.clusteringEdgeReplacingIds.length;j++){var transferId=edge.clusteringEdgeReplacingIds[j];var transferEdge=this.body.edges[transferId];if(transferEdge===undefined)continue;if(otherNode!==undefined){var otherCluster=this.body.nodes[otherNode.clusterId];otherCluster.containedEdges[transferEdge.id]=transferEdge;delete containedEdges[transferEdge.id];var fromId=transferEdge.fromId;var toId=transferEdge.toId;if(transferEdge.toId==otherNodeId){toId=otherNode.clusterId}else{fromId=otherNode.clusterId}this._createClusteredEdge(fromId,toId,transferEdge,otherCluster.clusterEdgeProperties,{hidden:false,physics:true})}else{this._restoreEdge(transferEdge)}}edge.remove()}for(var edgeId in containedEdges){if(containedEdges.hasOwnProperty(edgeId)){this._restoreEdge(containedEdges[edgeId])}}delete this.body.nodes[clusterNodeId];if(refreshData===true){this.body.emitter.emit(\"_dataChanged\")}}},{key:\"getNodesInCluster\",value:function getNodesInCluster(clusterId){var nodesArray=[];if(this.isCluster(clusterId)===true){var containedNodes=this.body.nodes[clusterId].containedNodes;for(var _nodeId6 in containedNodes){if(containedNodes.hasOwnProperty(_nodeId6)){nodesArray.push(this.body.nodes[_nodeId6].id)}}}return nodesArray}},{key:\"findNode\",value:function findNode(nodeId){var stack=[];var max=100;var counter=0;var node=void 0;while(this.clusteredNodes[nodeId]!==undefined&&counter<max){node=this.body.nodes[nodeId];if(node===undefined)return[];stack.push(node.id);nodeId=this.clusteredNodes[nodeId].clusterId;counter++}node=this.body.nodes[nodeId];if(node===undefined)return[];stack.push(node.id);stack.reverse();return stack}},{key:\"updateClusteredNode\",value:function updateClusteredNode(clusteredNodeId,newOptions){if(clusteredNodeId===undefined){throw new Error(\"No clusteredNodeId supplied to updateClusteredNode.\")}if(newOptions===undefined){throw new Error(\"No newOptions supplied to updateClusteredNode.\")}if(this.body.nodes[clusteredNodeId]===undefined){throw new Error(\"The clusteredNodeId supplied to updateClusteredNode does not exist.\")}this.body.nodes[clusteredNodeId].setOptions(newOptions);this.body.emitter.emit(\"_dataChanged\")}},{key:\"updateEdge\",value:function updateEdge(startEdgeId,newOptions){if(startEdgeId===undefined){throw new Error(\"No startEdgeId supplied to updateEdge.\")}if(newOptions===undefined){throw new Error(\"No newOptions supplied to updateEdge.\")}if(this.body.edges[startEdgeId]===undefined){throw new Error(\"The startEdgeId supplied to updateEdge does not exist.\")}var allEdgeIds=this.getClusteredEdges(startEdgeId);for(var i=0;i<allEdgeIds.length;i++){var edge=this.body.edges[allEdgeIds[i]];edge.setOptions(newOptions)}this.body.emitter.emit(\"_dataChanged\")}},{key:\"getClusteredEdges\",value:function getClusteredEdges(edgeId){var stack=[];var max=100;var counter=0;while(edgeId!==undefined&&this.body.edges[edgeId]!==undefined&&counter<max){stack.push(this.body.edges[edgeId].id);edgeId=this.body.edges[edgeId].edgeReplacedById;counter++}stack.reverse();return stack}},{key:\"getBaseEdge\",value:function getBaseEdge(clusteredEdgeId){return this.getBaseEdges(clusteredEdgeId)[0]}},{key:\"getBaseEdges\",value:function getBaseEdges(clusteredEdgeId){var IdsToHandle=[clusteredEdgeId];var doneIds=[];var foundIds=[];var max=100;var counter=0;while(IdsToHandle.length>0&&counter<max){var nextId=IdsToHandle.pop();if(nextId===undefined)continue;var nextEdge=this.body.edges[nextId];if(nextEdge===undefined)continue;counter++;var replacingIds=nextEdge.clusteringEdgeReplacingIds;if(replacingIds===undefined){foundIds.push(nextId)}else{for(var i=0;i<replacingIds.length;++i){var replacingId=replacingIds[i];if(IdsToHandle.indexOf(replacingIds)!==-1||doneIds.indexOf(replacingIds)!==-1){continue}IdsToHandle.push(replacingId)}}doneIds.push(nextId)}return foundIds}},{key:\"_getConnectedId\",value:function _getConnectedId(edge,nodeId){if(edge.toId!=nodeId){return edge.toId}else if(edge.fromId!=nodeId){return edge.fromId}else{return edge.fromId}}},{key:\"_getHubSize\",value:function _getHubSize(){var average=0;var averageSquared=0;var hubCounter=0;var largestHub=0;for(var i=0;i<this.body.nodeIndices.length;i++){var _node=this.body.nodes[this.body.nodeIndices[i]];if(_node.edges.length>largestHub){largestHub=_node.edges.length}average+=_node.edges.length;averageSquared+=Math.pow(_node.edges.length,2);hubCounter+=1}average=average/hubCounter;averageSquared=averageSquared/hubCounter;var variance=averageSquared-Math.pow(average,2);var standardDeviation=Math.sqrt(variance);var hubThreshold=Math.floor(average+2*standardDeviation);if(hubThreshold>largestHub){hubThreshold=largestHub}return hubThreshold}},{key:\"_createClusteredEdge\",value:function _createClusteredEdge(fromId,toId,baseEdge,clusterEdgeProperties,extraOptions){var clonedOptions=NetworkUtil.cloneOptions(baseEdge,\"edge\");util.deepExtend(clonedOptions,clusterEdgeProperties);clonedOptions.from=fromId;clonedOptions.to=toId;clonedOptions.id=\"clusterEdge:\"+util.randomUUID();if(extraOptions!==undefined){util.deepExtend(clonedOptions,extraOptions)}var newEdge=this.body.functions.createEdge(clonedOptions);newEdge.clusteringEdgeReplacingIds=[baseEdge.id];newEdge.connect();this.body.edges[newEdge.id]=newEdge;return newEdge}},{key:\"_clusterEdges\",value:function _clusterEdges(childNodes,childEdges,clusterNode,clusterEdgeProperties){if(childEdges instanceof Edge){var edge=childEdges;var obj={};obj[edge.id]=edge;childEdges=obj}if(childNodes instanceof Node){var _node2=childNodes;var _obj={};_obj[_node2.id]=_node2;childNodes=_obj}if(clusterNode===undefined||clusterNode===null){throw new Error(\"_clusterEdges: parameter clusterNode required\")}if(clusterEdgeProperties===undefined){clusterEdgeProperties=clusterNode.clusterEdgeProperties}this._createClusterEdges(childNodes,childEdges,clusterNode,clusterEdgeProperties);for(var edgeId in childEdges){if(childEdges.hasOwnProperty(edgeId)){if(this.body.edges[edgeId]!==undefined){var _edge2=this.body.edges[edgeId];this._backupEdgeOptions(_edge2);_edge2.setOptions({physics:false})}}}for(var _nodeId7 in childNodes){if(childNodes.hasOwnProperty(_nodeId7)){this.clusteredNodes[_nodeId7]={clusterId:clusterNode.id,node:this.body.nodes[_nodeId7]};this.body.nodes[_nodeId7].setOptions({physics:false})}}}},{key:\"_getClusterNodeForNode\",value:function _getClusterNodeForNode(nodeId){if(nodeId===undefined)return undefined;var clusteredNode=this.clusteredNodes[nodeId];if(clusteredNode===undefined)return undefined;var clusterId=clusteredNode.clusterId;if(clusterId===undefined)return undefined;return this.body.nodes[clusterId]}},{key:\"_filter\",value:function _filter(arr,callback){var ret=[];util.forEach(arr,function(item){if(callback(item)){ret.push(item)}});return ret}},{key:\"_updateState\",value:function _updateState(){var _this4=this;var nodeId=void 0;var deletedNodeIds=[];var deletedEdgeIds=[];var eachClusterNode=function eachClusterNode(callback){util.forEach(_this4.body.nodes,function(node){if(node.isCluster===true){callback(node)}})};for(nodeId in this.clusteredNodes){if(!this.clusteredNodes.hasOwnProperty(nodeId))continue;var _node3=this.body.nodes[nodeId];if(_node3===undefined){deletedNodeIds.push(nodeId)}}eachClusterNode(function(clusterNode){for(var n=0;n<deletedNodeIds.length;n++){delete clusterNode.containedNodes[deletedNodeIds[n]]}});for(var n=0;n<deletedNodeIds.length;n++){delete this.clusteredNodes[deletedNodeIds[n]]}util.forEach(this.clusteredEdges,function(edgeId){var edge=_this4.body.edges[edgeId];if(edge===undefined||!edge.endPointsValid()){deletedEdgeIds.push(edgeId)}});eachClusterNode(function(clusterNode){util.forEach(clusterNode.containedEdges,function(edge,edgeId){if(!edge.endPointsValid()&&deletedEdgeIds.indexOf(edgeId)===-1){deletedEdgeIds.push(edgeId)}})});util.forEach(this.body.edges,function(edge,edgeId){var isValid=true;var replacedIds=edge.clusteringEdgeReplacingIds;if(replacedIds!==undefined){var numValid=0;util.forEach(replacedIds,function(containedEdgeId){var containedEdge=_this4.body.edges[containedEdgeId];if(containedEdge!==undefined&&containedEdge.endPointsValid()){numValid+=1}});isValid=numValid>0}if(!edge.endPointsValid()||!isValid){deletedEdgeIds.push(edgeId)}});eachClusterNode(function(clusterNode){util.forEach(deletedEdgeIds,function(deletedEdgeId){delete clusterNode.containedEdges[deletedEdgeId];util.forEach(clusterNode.edges,function(edge,m){if(edge.id===deletedEdgeId){clusterNode.edges[m]=null;return}edge.clusteringEdgeReplacingIds=_this4._filter(edge.clusteringEdgeReplacingIds,function(id){return deletedEdgeIds.indexOf(id)===-1})});clusterNode.edges=_this4._filter(clusterNode.edges,function(item){return item!==null})})});util.forEach(deletedEdgeIds,function(edgeId){delete _this4.clusteredEdges[edgeId]});util.forEach(deletedEdgeIds,function(edgeId){delete _this4.body.edges[edgeId]});var ids=(0,_keys2[\"default\"])(this.body.edges);util.forEach(ids,function(edgeId){var edge=_this4.body.edges[edgeId];var shouldBeClustered=_this4._isClusteredNode(edge.fromId)||_this4._isClusteredNode(edge.toId);if(shouldBeClustered===_this4._isClusteredEdge(edge.id)){return}if(shouldBeClustered){var clusterFrom=_this4._getClusterNodeForNode(edge.fromId);if(clusterFrom!==undefined){_this4._clusterEdges(_this4.body.nodes[edge.fromId],edge,clusterFrom)}var clusterTo=_this4._getClusterNodeForNode(edge.toId);if(clusterTo!==undefined){_this4._clusterEdges(_this4.body.nodes[edge.toId],edge,clusterTo)}}else{throw new Error(\"remove edge from clustering not implemented!\")}});var changed=false;var continueLoop=true;var _loop2=function _loop2(){var clustersToOpen=[];eachClusterNode(function(clusterNode){var numNodes=(0,_keys2[\"default\"])(clusterNode.containedNodes).length;var allowSingle=clusterNode.options.allowSingleNodeCluster===true;if(allowSingle&&numNodes<1||!allowSingle&&numNodes<2){clustersToOpen.push(clusterNode.id)}});for(var _n=0;_n<clustersToOpen.length;++_n){_this4.openCluster(clustersToOpen[_n],{},false)}continueLoop=clustersToOpen.length>0;changed=changed||continueLoop};while(continueLoop){_loop2()}if(changed){this._updateState()}}},{key:\"_isClusteredNode\",value:function _isClusteredNode(nodeId){return this.clusteredNodes[nodeId]!==undefined}},{key:\"_isClusteredEdge\",value:function _isClusteredEdge(edgeId){return this.clusteredEdges[edgeId]!==undefined}}]);return ClusterEngine}();exports[\"default\"]=ClusterEngine},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var Node=__webpack_require__(47)[\"default\"];var Cluster=function(_Node){(0,_inherits3[\"default\"])(Cluster,_Node);function Cluster(options,body,imagelist,grouplist,globalOptions,defaultOptions){(0,_classCallCheck3[\"default\"])(this,Cluster);var _this=(0,_possibleConstructorReturn3[\"default\"])(this,(Cluster.__proto__||(0,_getPrototypeOf2[\"default\"])(Cluster)).call(this,options,body,imagelist,grouplist,globalOptions,defaultOptions));_this.isCluster=true;_this.containedNodes={};_this.containedEdges={};return _this}(0,_createClass3[\"default\"])(Cluster,[{key:\"_openChildCluster\",value:function _openChildCluster(childClusterId){var _this2=this;var childCluster=this.body.nodes[childClusterId];if(this.containedNodes[childClusterId]===undefined){throw new Error(\"node with id: \"+childClusterId+\" not in current cluster\")}if(!childCluster.isCluster){throw new Error(\"node with id: \"+childClusterId+\" is not a cluster\")}delete this.containedNodes[childClusterId];util.forEach(childCluster.edges,function(edge){delete _this2.containedEdges[edge.id]});util.forEach(childCluster.containedNodes,function(node,nodeId){_this2.containedNodes[nodeId]=node});childCluster.containedNodes={};util.forEach(childCluster.containedEdges,function(edge,edgeId){_this2.containedEdges[edgeId]=edge});childCluster.containedEdges={};util.forEach(childCluster.edges,function(clusterEdge){util.forEach(_this2.edges,function(parentClusterEdge){var index=parentClusterEdge.clusteringEdgeReplacingIds.indexOf(clusterEdge.id);if(index===-1)return;util.forEach(clusterEdge.clusteringEdgeReplacingIds,function(srcId){parentClusterEdge.clusteringEdgeReplacingIds.push(srcId);_this2.body.edges[srcId].edgeReplacedById=parentClusterEdge.id});parentClusterEdge.clusteringEdgeReplacingIds.splice(index,1)})});childCluster.edges=[]}}]);return Cluster}(Node);exports[\"default\"]=Cluster},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}function _initRequestAnimationFrame(){var func;if(window!==undefined){func=window.requestAnimationFrame||window.mozRequestAnimationFrame||window.webkitRequestAnimationFrame||window.msRequestAnimationFrame}if(func===undefined){window.requestAnimationFrame=function(callback){callback()}}else{window.requestAnimationFrame=func}}var util=__webpack_require__(2);var CanvasRenderer=function(){function CanvasRenderer(body,canvas){(0,_classCallCheck3[\"default\"])(this,CanvasRenderer);_initRequestAnimationFrame();this.body=body;this.canvas=canvas;this.redrawRequested=false;this.renderTimer=undefined;this.requiresTimeout=true;this.renderingActive=false;this.renderRequests=0;this.allowRedraw=true;this.dragging=false;this.options={};this.defaultOptions={hideEdgesOnDrag:false,hideNodesOnDrag:false};util.extend(this.options,this.defaultOptions);this._determineBrowserMethod();this.bindEventListeners()}(0,_createClass3[\"default\"])(CanvasRenderer,[{key:\"bindEventListeners\",value:function bindEventListeners(){var _this=this;this.body.emitter.on(\"dragStart\",function(){_this.dragging=true});this.body.emitter.on(\"dragEnd\",function(){_this.dragging=false});this.body.emitter.on(\"_resizeNodes\",function(){_this._resizeNodes()});this.body.emitter.on(\"_redraw\",function(){if(_this.renderingActive===false){_this._redraw()}});this.body.emitter.on(\"_blockRedraw\",function(){_this.allowRedraw=false});this.body.emitter.on(\"_allowRedraw\",function(){_this.allowRedraw=true;_this.redrawRequested=false});this.body.emitter.on(\"_requestRedraw\",this._requestRedraw.bind(this));this.body.emitter.on(\"_startRendering\",function(){_this.renderRequests+=1;_this.renderingActive=true;_this._startRendering()});this.body.emitter.on(\"_stopRendering\",function(){_this.renderRequests-=1;_this.renderingActive=_this.renderRequests>0;_this.renderTimer=undefined});this.body.emitter.on(\"destroy\",function(){_this.renderRequests=0;_this.allowRedraw=false;_this.renderingActive=false;if(_this.requiresTimeout===true){clearTimeout(_this.renderTimer)}else{window.cancelAnimationFrame(_this.renderTimer)}_this.body.emitter.off()})}},{key:\"setOptions\",value:function setOptions(options){if(options!==undefined){var fields=[\"hideEdgesOnDrag\",\"hideNodesOnDrag\"];util.selectiveDeepExtend(fields,this.options,options)}}},{key:\"_requestNextFrame\",value:function _requestNextFrame(callback,delay){if(typeof window===\"undefined\")return;var timer=void 0;var myWindow=window;if(this.requiresTimeout===true){timer=myWindow.setTimeout(callback,delay)}else{if(myWindow.requestAnimationFrame){timer=myWindow.requestAnimationFrame(callback)}}return timer}},{key:\"_startRendering\",value:function _startRendering(){if(this.renderingActive===true){if(this.renderTimer===undefined){this.renderTimer=this._requestNextFrame(this._renderStep.bind(this),this.simulationInterval)}}}},{key:\"_renderStep\",value:function _renderStep(){if(this.renderingActive===true){this.renderTimer=undefined;if(this.requiresTimeout===true){this._startRendering()}this._redraw();if(this.requiresTimeout===false){this._startRendering()}}}},{key:\"redraw\",value:function redraw(){this.body.emitter.emit(\"setSize\");this._redraw()}},{key:\"_requestRedraw\",value:function _requestRedraw(){var _this2=this;if(this.redrawRequested!==true&&this.renderingActive===false&&this.allowRedraw===true){this.redrawRequested=true;this._requestNextFrame(function(){_this2._redraw(false)},0)}}},{key:\"_redraw\",value:function _redraw(){var hidden=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;if(this.allowRedraw===true){this.body.emitter.emit(\"initRedraw\");this.redrawRequested=false;if(this.canvas.frame.canvas.width===0||this.canvas.frame.canvas.height===0){this.canvas.setSize()}this.canvas.setTransform();var ctx=this.canvas.getContext();var w=this.canvas.frame.canvas.clientWidth;var h=this.canvas.frame.canvas.clientHeight;ctx.clearRect(0,0,w,h);if(this.canvas.frame.clientWidth===0){return}ctx.save();ctx.translate(this.body.view.translation.x,this.body.view.translation.y);ctx.scale(this.body.view.scale,this.body.view.scale);ctx.beginPath();this.body.emitter.emit(\"beforeDrawing\",ctx);ctx.closePath();if(hidden===false){if(this.dragging===false||this.dragging===true&&this.options.hideEdgesOnDrag===false){this._drawEdges(ctx)}}if(this.dragging===false||this.dragging===true&&this.options.hideNodesOnDrag===false){this._drawNodes(ctx,hidden)}ctx.beginPath();this.body.emitter.emit(\"afterDrawing\",ctx);ctx.closePath();ctx.restore();if(hidden===true){ctx.clearRect(0,0,w,h)}}}},{key:\"_resizeNodes\",value:function _resizeNodes(){this.canvas.setTransform();var ctx=this.canvas.getContext();ctx.save();ctx.translate(this.body.view.translation.x,this.body.view.translation.y);ctx.scale(this.body.view.scale,this.body.view.scale);var nodes=this.body.nodes;var node=void 0;for(var nodeId in nodes){if(nodes.hasOwnProperty(nodeId)){node=nodes[nodeId];node.resize(ctx);node.updateBoundingBox(ctx,node.selected)}}ctx.restore()}},{key:\"_drawNodes\",value:function _drawNodes(ctx){var alwaysShow=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;var nodes=this.body.nodes;var nodeIndices=this.body.nodeIndices;var node=void 0;var selected=[];var margin=20;var topLeft=this.canvas.DOMtoCanvas({x:-margin,y:-margin});var bottomRight=this.canvas.DOMtoCanvas({x:this.canvas.frame.canvas.clientWidth+margin,y:this.canvas.frame.canvas.clientHeight+margin});var viewableArea={top:topLeft.y,left:topLeft.x,bottom:bottomRight.y,right:bottomRight.x};for(var i=0;i<nodeIndices.length;i++){node=nodes[nodeIndices[i]];if(node.isSelected()){selected.push(nodeIndices[i])}else{if(alwaysShow===true){node.draw(ctx)}else if(node.isBoundingBoxOverlappingWith(viewableArea)===true){node.draw(ctx)}else{node.updateBoundingBox(ctx,node.selected)}}}for(var _i=0;_i<selected.length;_i++){node=nodes[selected[_i]];node.draw(ctx)}}},{key:\"_drawEdges\",value:function _drawEdges(ctx){var edges=this.body.edges;var edgeIndices=this.body.edgeIndices;var edge=void 0;for(var i=0;i<edgeIndices.length;i++){edge=edges[edgeIndices[i]];if(edge.connected===true){edge.draw(ctx)}}}},{key:\"_determineBrowserMethod\",value:function _determineBrowserMethod(){if(typeof window!==\"undefined\"){var browserType=navigator.userAgent.toLowerCase();this.requiresTimeout=false;if(browserType.indexOf(\"msie 9.0\")!=-1){this.requiresTimeout=true}else if(browserType.indexOf(\"safari\")!=-1){if(browserType.indexOf(\"chrome\")<=-1){this.requiresTimeout=true}}}else{this.requiresTimeout=true}}}]);return CanvasRenderer}();exports[\"default\"]=CanvasRenderer},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Hammer=__webpack_require__(10);var hammerUtil=__webpack_require__(37);var util=__webpack_require__(2);var Canvas=function(){function Canvas(body){(0,_classCallCheck3[\"default\"])(this,Canvas);this.body=body;this.pixelRatio=1;this.resizeTimer=undefined;this.resizeFunction=this._onResize.bind(this);this.cameraState={};this.initialized=false;this.canvasViewCenter={};this.options={};this.defaultOptions={autoResize:true,height:\"100%\",width:\"100%\"};util.extend(this.options,this.defaultOptions);this.bindEventListeners()}(0,_createClass3[\"default\"])(Canvas,[{key:\"bindEventListeners\",value:function bindEventListeners(){var _this=this;this.body.emitter.once(\"resize\",function(obj){if(obj.width!==0){_this.body.view.translation.x=obj.width*.5}if(obj.height!==0){_this.body.view.translation.y=obj.height*.5}});this.body.emitter.on(\"setSize\",this.setSize.bind(this));this.body.emitter.on(\"destroy\",function(){_this.hammerFrame.destroy();_this.hammer.destroy();_this._cleanUp()})}},{key:\"setOptions\",value:function setOptions(options){var _this2=this;if(options!==undefined){var fields=[\"width\",\"height\",\"autoResize\"];util.selectiveDeepExtend(fields,this.options,options)}if(this.options.autoResize===true){this._cleanUp();this.resizeTimer=setInterval(function(){var changed=_this2.setSize();if(changed===true){_this2.body.emitter.emit(\"_requestRedraw\")}},1e3);this.resizeFunction=this._onResize.bind(this);util.addEventListener(window,\"resize\",this.resizeFunction)}}},{key:\"_cleanUp\",value:function _cleanUp(){if(this.resizeTimer!==undefined){clearInterval(this.resizeTimer)}util.removeEventListener(window,\"resize\",this.resizeFunction);this.resizeFunction=undefined}},{key:\"_onResize\",value:function _onResize(){this.setSize();this.body.emitter.emit(\"_redraw\")}},{key:\"_getCameraState\",value:function _getCameraState(){var pixelRatio=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.pixelRatio;if(this.initialized===true){this.cameraState.previousWidth=this.frame.canvas.width/pixelRatio;this.cameraState.previousHeight=this.frame.canvas.height/pixelRatio;this.cameraState.scale=this.body.view.scale;this.cameraState.position=this.DOMtoCanvas({x:.5*this.frame.canvas.width/pixelRatio,y:.5*this.frame.canvas.height/pixelRatio})}}},{key:\"_setCameraState\",value:function _setCameraState(){if(this.cameraState.scale!==undefined&&this.frame.canvas.clientWidth!==0&&this.frame.canvas.clientHeight!==0&&this.pixelRatio!==0&&this.cameraState.previousWidth>0){var widthRatio=this.frame.canvas.width/this.pixelRatio/this.cameraState.previousWidth;var heightRatio=this.frame.canvas.height/this.pixelRatio/this.cameraState.previousHeight;var newScale=this.cameraState.scale;if(widthRatio!=1&&heightRatio!=1){newScale=this.cameraState.scale*.5*(widthRatio+heightRatio)}else if(widthRatio!=1){newScale=this.cameraState.scale*widthRatio}else if(heightRatio!=1){newScale=this.cameraState.scale*heightRatio}this.body.view.scale=newScale;var currentViewCenter=this.DOMtoCanvas({x:.5*this.frame.canvas.clientWidth,y:.5*this.frame.canvas.clientHeight});var distanceFromCenter={x:currentViewCenter.x-this.cameraState.position.x,y:currentViewCenter.y-this.cameraState.position.y};this.body.view.translation.x+=distanceFromCenter.x*this.body.view.scale;this.body.view.translation.y+=distanceFromCenter.y*this.body.view.scale}}},{key:\"_prepareValue\",value:function _prepareValue(value){if(typeof value===\"number\"){return value+\"px\"}else if(typeof value===\"string\"){if(value.indexOf(\"%\")!==-1||value.indexOf(\"px\")!==-1){return value}else if(value.indexOf(\"%\")===-1){return value+\"px\"}}throw new Error(\"Could not use the value supplied for width or height:\"+value)}},{key:\"_create\",value:function _create(){while(this.body.container.hasChildNodes()){this.body.container.removeChild(this.body.container.firstChild)}this.frame=document.createElement(\"div\");this.frame.className=\"vis-network\";this.frame.style.position=\"relative\";this.frame.style.overflow=\"hidden\";this.frame.tabIndex=900;this.frame.canvas=document.createElement(\"canvas\");this.frame.canvas.style.position=\"relative\";this.frame.appendChild(this.frame.canvas);if(!this.frame.canvas.getContext){var noCanvas=document.createElement(\"DIV\");noCanvas.style.color=\"red\";noCanvas.style.fontWeight=\"bold\";noCanvas.style.padding=\"10px\";noCanvas.innerHTML=\"Error: your browser does not support HTML canvas\";this.frame.canvas.appendChild(noCanvas)}else{this._setPixelRatio();this.setTransform()}this.body.container.appendChild(this.frame);this.body.view.scale=1;this.body.view.translation={x:.5*this.frame.canvas.clientWidth,y:.5*this.frame.canvas.clientHeight};this._bindHammer()}},{key:\"_bindHammer\",value:function _bindHammer(){var _this3=this;if(this.hammer!==undefined){this.hammer.destroy()}this.drag={};this.pinch={};this.hammer=new Hammer(this.frame.canvas);this.hammer.get(\"pinch\").set({enable:true});this.hammer.get(\"pan\").set({threshold:5,direction:Hammer.DIRECTION_ALL});hammerUtil.onTouch(this.hammer,function(event){_this3.body.eventListeners.onTouch(event)});this.hammer.on(\"tap\",function(event){_this3.body.eventListeners.onTap(event)});this.hammer.on(\"doubletap\",function(event){_this3.body.eventListeners.onDoubleTap(event)});this.hammer.on(\"press\",function(event){_this3.body.eventListeners.onHold(event)});this.hammer.on(\"panstart\",function(event){_this3.body.eventListeners.onDragStart(event)});this.hammer.on(\"panmove\",function(event){_this3.body.eventListeners.onDrag(event)});this.hammer.on(\"panend\",function(event){_this3.body.eventListeners.onDragEnd(event)});this.hammer.on(\"pinch\",function(event){_this3.body.eventListeners.onPinch(event)});this.frame.canvas.addEventListener(\"mousewheel\",function(event){_this3.body.eventListeners.onMouseWheel(event)});this.frame.canvas.addEventListener(\"DOMMouseScroll\",function(event){_this3.body.eventListeners.onMouseWheel(event)});this.frame.canvas.addEventListener(\"mousemove\",function(event){_this3.body.eventListeners.onMouseMove(event)});this.frame.canvas.addEventListener(\"contextmenu\",function(event){_this3.body.eventListeners.onContext(event)});this.hammerFrame=new Hammer(this.frame);hammerUtil.onRelease(this.hammerFrame,function(event){_this3.body.eventListeners.onRelease(event)})}},{key:\"setSize\",value:function setSize(){var width=arguments.length>0&&arguments[0]!==undefined?arguments[0]:this.options.width;var height=arguments.length>1&&arguments[1]!==undefined?arguments[1]:this.options.height;width=this._prepareValue(width);height=this._prepareValue(height);var emitEvent=false;var oldWidth=this.frame.canvas.width;var oldHeight=this.frame.canvas.height;var previousRatio=this.pixelRatio;this._setPixelRatio();if(width!=this.options.width||height!=this.options.height||this.frame.style.width!=width||this.frame.style.height!=height){this._getCameraState(previousRatio);this.frame.style.width=width;this.frame.style.height=height;this.frame.canvas.style.width=\"100%\";this.frame.canvas.style.height=\"100%\";this.frame.canvas.width=Math.round(this.frame.canvas.clientWidth*this.pixelRatio);this.frame.canvas.height=Math.round(this.frame.canvas.clientHeight*this.pixelRatio);this.options.width=width;this.options.height=height;this.canvasViewCenter={x:.5*this.frame.clientWidth,y:.5*this.frame.clientHeight};emitEvent=true}else{var newWidth=Math.round(this.frame.canvas.clientWidth*this.pixelRatio);var newHeight=Math.round(this.frame.canvas.clientHeight*this.pixelRatio);if(this.frame.canvas.width!==newWidth||this.frame.canvas.height!==newHeight){this._getCameraState(previousRatio)}if(this.frame.canvas.width!==newWidth){this.frame.canvas.width=newWidth;emitEvent=true}if(this.frame.canvas.height!==newHeight){this.frame.canvas.height=newHeight;emitEvent=true}}if(emitEvent===true){this.body.emitter.emit(\"resize\",{width:Math.round(this.frame.canvas.width/this.pixelRatio),height:Math.round(this.frame.canvas.height/this.pixelRatio),oldWidth:Math.round(oldWidth/this.pixelRatio),oldHeight:Math.round(oldHeight/this.pixelRatio)});this._setCameraState()}this.initialized=true;return emitEvent}},{key:\"getContext\",value:function getContext(){return this.frame.canvas.getContext(\"2d\")}},{key:\"_determinePixelRatio\",value:function _determinePixelRatio(){var ctx=this.getContext();if(ctx===undefined){throw new Error(\"Could not get canvax context\")}var numerator=1;if(typeof window!==\"undefined\"){numerator=window.devicePixelRatio||1}var denominator=ctx.webkitBackingStorePixelRatio||ctx.mozBackingStorePixelRatio||ctx.msBackingStorePixelRatio||ctx.oBackingStorePixelRatio||ctx.backingStorePixelRatio||1;return numerator/denominator}},{key:\"_setPixelRatio\",value:function _setPixelRatio(){this.pixelRatio=this._determinePixelRatio()}},{key:\"setTransform\",value:function setTransform(){var ctx=this.getContext();if(ctx===undefined){throw new Error(\"Could not get canvax context\")}ctx.setTransform(this.pixelRatio,0,0,this.pixelRatio,0,0)}},{key:\"_XconvertDOMtoCanvas\",value:function _XconvertDOMtoCanvas(x){return(x-this.body.view.translation.x)/this.body.view.scale}},{\nkey:\"_XconvertCanvasToDOM\",value:function _XconvertCanvasToDOM(x){return x*this.body.view.scale+this.body.view.translation.x}},{key:\"_YconvertDOMtoCanvas\",value:function _YconvertDOMtoCanvas(y){return(y-this.body.view.translation.y)/this.body.view.scale}},{key:\"_YconvertCanvasToDOM\",value:function _YconvertCanvasToDOM(y){return y*this.body.view.scale+this.body.view.translation.y}},{key:\"canvasToDOM\",value:function canvasToDOM(pos){return{x:this._XconvertCanvasToDOM(pos.x),y:this._YconvertCanvasToDOM(pos.y)}}},{key:\"DOMtoCanvas\",value:function DOMtoCanvas(pos){return{x:this._XconvertDOMtoCanvas(pos.x),y:this._YconvertDOMtoCanvas(pos.y)}}}]);return Canvas}();exports[\"default\"]=Canvas},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var NetworkUtil=__webpack_require__(76)[\"default\"];var View=function(){function View(body,canvas){var _this=this;(0,_classCallCheck3[\"default\"])(this,View);this.body=body;this.canvas=canvas;this.animationSpeed=1/this.renderRefreshRate;this.animationEasingFunction=\"easeInOutQuint\";this.easingTime=0;this.sourceScale=0;this.targetScale=0;this.sourceTranslation=0;this.targetTranslation=0;this.lockedOnNodeId=undefined;this.lockedOnNodeOffset=undefined;this.touchTime=0;this.viewFunction=undefined;this.body.emitter.on(\"fit\",this.fit.bind(this));this.body.emitter.on(\"animationFinished\",function(){_this.body.emitter.emit(\"_stopRendering\")});this.body.emitter.on(\"unlockNode\",this.releaseNode.bind(this))}(0,_createClass3[\"default\"])(View,[{key:\"setOptions\",value:function setOptions(){var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{};this.options=options}},{key:\"fit\",value:function fit(){var options=arguments.length>0&&arguments[0]!==undefined?arguments[0]:{nodes:[]};var initialZoom=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;var range=void 0;var zoomLevel=void 0;if(options.nodes===undefined||options.nodes.length===0){options.nodes=this.body.nodeIndices}if(initialZoom===true){var positionDefined=0;for(var nodeId in this.body.nodes){if(this.body.nodes.hasOwnProperty(nodeId)){var node=this.body.nodes[nodeId];if(node.predefinedPosition===true){positionDefined+=1}}}if(positionDefined>.5*this.body.nodeIndices.length){this.fit(options,false);return}range=NetworkUtil.getRange(this.body.nodes,options.nodes);var numberOfNodes=this.body.nodeIndices.length;zoomLevel=12.662/(numberOfNodes+7.4147)+.0964822;var factor=Math.min(this.canvas.frame.canvas.clientWidth/600,this.canvas.frame.canvas.clientHeight/600);zoomLevel*=factor}else{this.body.emitter.emit(\"_resizeNodes\");range=NetworkUtil.getRange(this.body.nodes,options.nodes);var xDistance=Math.abs(range.maxX-range.minX)*1.1;var yDistance=Math.abs(range.maxY-range.minY)*1.1;var xZoomLevel=this.canvas.frame.canvas.clientWidth/xDistance;var yZoomLevel=this.canvas.frame.canvas.clientHeight/yDistance;zoomLevel=xZoomLevel<=yZoomLevel?xZoomLevel:yZoomLevel}if(zoomLevel>1){zoomLevel=1}else if(zoomLevel===0){zoomLevel=1}var center=NetworkUtil.findCenter(range);var animationOptions={position:center,scale:zoomLevel,animation:options.animation};this.moveTo(animationOptions)}},{key:\"focus\",value:function focus(nodeId){var options=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};if(this.body.nodes[nodeId]!==undefined){var nodePosition={x:this.body.nodes[nodeId].x,y:this.body.nodes[nodeId].y};options.position=nodePosition;options.lockedOnNode=nodeId;this.moveTo(options)}else{console.log(\"Node: \"+nodeId+\" cannot be found.\")}}},{key:\"moveTo\",value:function moveTo(options){if(options===undefined){options={};return}if(options.offset===undefined){options.offset={x:0,y:0}}if(options.offset.x===undefined){options.offset.x=0}if(options.offset.y===undefined){options.offset.y=0}if(options.scale===undefined){options.scale=this.body.view.scale}if(options.position===undefined){options.position=this.getViewPosition()}if(options.animation===undefined){options.animation={duration:0}}if(options.animation===false){options.animation={duration:0}}if(options.animation===true){options.animation={}}if(options.animation.duration===undefined){options.animation.duration=1e3}if(options.animation.easingFunction===undefined){options.animation.easingFunction=\"easeInOutQuad\"}this.animateView(options)}},{key:\"animateView\",value:function animateView(options){if(options===undefined){return}this.animationEasingFunction=options.animation.easingFunction;this.releaseNode();if(options.locked===true){this.lockedOnNodeId=options.lockedOnNode;this.lockedOnNodeOffset=options.offset}if(this.easingTime!=0){this._transitionRedraw(true)}this.sourceScale=this.body.view.scale;this.sourceTranslation=this.body.view.translation;this.targetScale=options.scale;this.body.view.scale=this.targetScale;var viewCenter=this.canvas.DOMtoCanvas({x:.5*this.canvas.frame.canvas.clientWidth,y:.5*this.canvas.frame.canvas.clientHeight});var distanceFromCenter={x:viewCenter.x-options.position.x,y:viewCenter.y-options.position.y};this.targetTranslation={x:this.sourceTranslation.x+distanceFromCenter.x*this.targetScale+options.offset.x,y:this.sourceTranslation.y+distanceFromCenter.y*this.targetScale+options.offset.y};if(options.animation.duration===0){if(this.lockedOnNodeId!=undefined){this.viewFunction=this._lockedRedraw.bind(this);this.body.emitter.on(\"initRedraw\",this.viewFunction)}else{this.body.view.scale=this.targetScale;this.body.view.translation=this.targetTranslation;this.body.emitter.emit(\"_requestRedraw\")}}else{this.animationSpeed=1/(60*options.animation.duration*.001)||1/60;this.animationEasingFunction=options.animation.easingFunction;this.viewFunction=this._transitionRedraw.bind(this);this.body.emitter.on(\"initRedraw\",this.viewFunction);this.body.emitter.emit(\"_startRendering\")}}},{key:\"_lockedRedraw\",value:function _lockedRedraw(){var nodePosition={x:this.body.nodes[this.lockedOnNodeId].x,y:this.body.nodes[this.lockedOnNodeId].y};var viewCenter=this.canvas.DOMtoCanvas({x:.5*this.canvas.frame.canvas.clientWidth,y:.5*this.canvas.frame.canvas.clientHeight});var distanceFromCenter={x:viewCenter.x-nodePosition.x,y:viewCenter.y-nodePosition.y};var sourceTranslation=this.body.view.translation;var targetTranslation={x:sourceTranslation.x+distanceFromCenter.x*this.body.view.scale+this.lockedOnNodeOffset.x,y:sourceTranslation.y+distanceFromCenter.y*this.body.view.scale+this.lockedOnNodeOffset.y};this.body.view.translation=targetTranslation}},{key:\"releaseNode\",value:function releaseNode(){if(this.lockedOnNodeId!==undefined&&this.viewFunction!==undefined){this.body.emitter.off(\"initRedraw\",this.viewFunction);this.lockedOnNodeId=undefined;this.lockedOnNodeOffset=undefined}}},{key:\"_transitionRedraw\",value:function _transitionRedraw(){var finished=arguments.length>0&&arguments[0]!==undefined?arguments[0]:false;this.easingTime+=this.animationSpeed;this.easingTime=finished===true?1:this.easingTime;var progress=util.easingFunctions[this.animationEasingFunction](this.easingTime);this.body.view.scale=this.sourceScale+(this.targetScale-this.sourceScale)*progress;this.body.view.translation={x:this.sourceTranslation.x+(this.targetTranslation.x-this.sourceTranslation.x)*progress,y:this.sourceTranslation.y+(this.targetTranslation.y-this.sourceTranslation.y)*progress};if(this.easingTime>=1){this.body.emitter.off(\"initRedraw\",this.viewFunction);this.easingTime=0;if(this.lockedOnNodeId!=undefined){this.viewFunction=this._lockedRedraw.bind(this);this.body.emitter.on(\"initRedraw\",this.viewFunction)}this.body.emitter.emit(\"animationFinished\")}}},{key:\"getScale\",value:function getScale(){return this.body.view.scale}},{key:\"getViewPosition\",value:function getViewPosition(){return this.canvas.DOMtoCanvas({x:.5*this.canvas.frame.canvas.clientWidth,y:.5*this.canvas.frame.canvas.clientHeight})}}]);return View}();exports[\"default\"]=View},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var NavigationHandler=__webpack_require__(233)[\"default\"];var Popup=__webpack_require__(104)[\"default\"];var InteractionHandler=function(){function InteractionHandler(body,canvas,selectionHandler){(0,_classCallCheck3[\"default\"])(this,InteractionHandler);this.body=body;this.canvas=canvas;this.selectionHandler=selectionHandler;this.navigationHandler=new NavigationHandler(body,canvas);this.body.eventListeners.onTap=this.onTap.bind(this);this.body.eventListeners.onTouch=this.onTouch.bind(this);this.body.eventListeners.onDoubleTap=this.onDoubleTap.bind(this);this.body.eventListeners.onHold=this.onHold.bind(this);this.body.eventListeners.onDragStart=this.onDragStart.bind(this);this.body.eventListeners.onDrag=this.onDrag.bind(this);this.body.eventListeners.onDragEnd=this.onDragEnd.bind(this);this.body.eventListeners.onMouseWheel=this.onMouseWheel.bind(this);this.body.eventListeners.onPinch=this.onPinch.bind(this);this.body.eventListeners.onMouseMove=this.onMouseMove.bind(this);this.body.eventListeners.onRelease=this.onRelease.bind(this);this.body.eventListeners.onContext=this.onContext.bind(this);this.touchTime=0;this.drag={};this.pinch={};this.popup=undefined;this.popupObj=undefined;this.popupTimer=undefined;this.body.functions.getPointer=this.getPointer.bind(this);this.options={};this.defaultOptions={dragNodes:true,dragView:true,hover:false,keyboard:{enabled:false,speed:{x:10,y:10,zoom:.02},bindToWindow:true},navigationButtons:false,tooltipDelay:300,zoomView:true};util.extend(this.options,this.defaultOptions);this.bindEventListeners()}(0,_createClass3[\"default\"])(InteractionHandler,[{key:\"bindEventListeners\",value:function bindEventListeners(){var _this=this;this.body.emitter.on(\"destroy\",function(){clearTimeout(_this.popupTimer);delete _this.body.functions.getPointer})}},{key:\"setOptions\",value:function setOptions(options){if(options!==undefined){var fields=[\"hideEdgesOnDrag\",\"hideNodesOnDrag\",\"keyboard\",\"multiselect\",\"selectable\",\"selectConnectedEdges\"];util.selectiveNotDeepExtend(fields,this.options,options);util.mergeOptions(this.options,options,\"keyboard\");if(options.tooltip){util.extend(this.options.tooltip,options.tooltip);if(options.tooltip.color){this.options.tooltip.color=util.parseColor(options.tooltip.color)}}}this.navigationHandler.setOptions(this.options)}},{key:\"getPointer\",value:function getPointer(touch){return{x:touch.x-util.getAbsoluteLeft(this.canvas.frame.canvas),y:touch.y-util.getAbsoluteTop(this.canvas.frame.canvas)}}},{key:\"onTouch\",value:function onTouch(event){if((new Date).valueOf()-this.touchTime>50){this.drag.pointer=this.getPointer(event.center);this.drag.pinched=false;this.pinch.scale=this.body.view.scale;this.touchTime=(new Date).valueOf()}}},{key:\"onTap\",value:function onTap(event){var pointer=this.getPointer(event.center);var multiselect=this.selectionHandler.options.multiselect&&(event.changedPointers[0].ctrlKey||event.changedPointers[0].metaKey);this.checkSelectionChanges(pointer,event,multiselect);this.selectionHandler._generateClickEvent(\"click\",event,pointer)}},{key:\"onDoubleTap\",value:function onDoubleTap(event){var pointer=this.getPointer(event.center);this.selectionHandler._generateClickEvent(\"doubleClick\",event,pointer)}},{key:\"onHold\",value:function onHold(event){var pointer=this.getPointer(event.center);var multiselect=this.selectionHandler.options.multiselect;this.checkSelectionChanges(pointer,event,multiselect);this.selectionHandler._generateClickEvent(\"click\",event,pointer);this.selectionHandler._generateClickEvent(\"hold\",event,pointer)}},{key:\"onRelease\",value:function onRelease(event){if((new Date).valueOf()-this.touchTime>10){var pointer=this.getPointer(event.center);this.selectionHandler._generateClickEvent(\"release\",event,pointer);this.touchTime=(new Date).valueOf()}}},{key:\"onContext\",value:function onContext(event){var pointer=this.getPointer({x:event.clientX,y:event.clientY});this.selectionHandler._generateClickEvent(\"oncontext\",event,pointer)}},{key:\"checkSelectionChanges\",value:function checkSelectionChanges(pointer,event){var add=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;var previousSelection=this.selectionHandler.getSelection();var selected=false;if(add===true){selected=this.selectionHandler.selectAdditionalOnPoint(pointer)}else{selected=this.selectionHandler.selectOnPoint(pointer)}var currentSelection=this.selectionHandler.getSelection();var deselectedItems=this._determineDifference(previousSelection,currentSelection);var selectedItems=this._determineDifference(currentSelection,previousSelection);if(deselectedItems.edges.length>0){this.selectionHandler._generateClickEvent(\"deselectEdge\",event,pointer,previousSelection);selected=true}if(deselectedItems.nodes.length>0){this.selectionHandler._generateClickEvent(\"deselectNode\",event,pointer,previousSelection);selected=true}if(selectedItems.nodes.length>0){this.selectionHandler._generateClickEvent(\"selectNode\",event,pointer);selected=true}if(selectedItems.edges.length>0){this.selectionHandler._generateClickEvent(\"selectEdge\",event,pointer);selected=true}if(selected===true){this.selectionHandler._generateClickEvent(\"select\",event,pointer)}}},{key:\"_determineDifference\",value:function _determineDifference(firstSet,secondSet){var arrayDiff=function arrayDiff(firstArr,secondArr){var result=[];for(var i=0;i<firstArr.length;i++){var value=firstArr[i];if(secondArr.indexOf(value)===-1){result.push(value)}}return result};return{nodes:arrayDiff(firstSet.nodes,secondSet.nodes),edges:arrayDiff(firstSet.edges,secondSet.edges)}}},{key:\"onDragStart\",value:function onDragStart(event){if(this.drag.pointer===undefined){this.onTouch(event)}var node=this.selectionHandler.getNodeAt(this.drag.pointer);this.drag.dragging=true;this.drag.selection=[];this.drag.translation=util.extend({},this.body.view.translation);this.drag.nodeId=undefined;if(node!==undefined&&this.options.dragNodes===true){this.drag.nodeId=node.id;if(node.isSelected()===false){this.selectionHandler.unselectAll();this.selectionHandler.selectObject(node)}this.selectionHandler._generateClickEvent(\"dragStart\",event,this.drag.pointer);var selection=this.selectionHandler.selectionObj.nodes;for(var nodeId in selection){if(selection.hasOwnProperty(nodeId)){var object=selection[nodeId];var s={id:object.id,node:object,x:object.x,y:object.y,xFixed:object.options.fixed.x,yFixed:object.options.fixed.y};object.options.fixed.x=true;object.options.fixed.y=true;this.drag.selection.push(s)}}}else{this.selectionHandler._generateClickEvent(\"dragStart\",event,this.drag.pointer,undefined,true)}}},{key:\"onDrag\",value:function onDrag(event){var _this2=this;if(this.drag.pinched===true){return}this.body.emitter.emit(\"unlockNode\");var pointer=this.getPointer(event.center);var selection=this.drag.selection;if(selection&&selection.length&&this.options.dragNodes===true){this.selectionHandler._generateClickEvent(\"dragging\",event,pointer);var deltaX=pointer.x-this.drag.pointer.x;var deltaY=pointer.y-this.drag.pointer.y;selection.forEach(function(selection){var node=selection.node;if(selection.xFixed===false){node.x=_this2.canvas._XconvertDOMtoCanvas(_this2.canvas._XconvertCanvasToDOM(selection.x)+deltaX)}if(selection.yFixed===false){node.y=_this2.canvas._YconvertDOMtoCanvas(_this2.canvas._YconvertCanvasToDOM(selection.y)+deltaY)}});this.body.emitter.emit(\"startSimulation\")}else{if(this.options.dragView===true){this.selectionHandler._generateClickEvent(\"dragging\",event,pointer,undefined,true);if(this.drag.pointer===undefined){this.onDragStart(event);return}var diffX=pointer.x-this.drag.pointer.x;var diffY=pointer.y-this.drag.pointer.y;this.body.view.translation={x:this.drag.translation.x+diffX,y:this.drag.translation.y+diffY};this.body.emitter.emit(\"_requestRedraw\")}}}},{key:\"onDragEnd\",value:function onDragEnd(event){this.drag.dragging=false;var selection=this.drag.selection;if(selection&&selection.length){selection.forEach(function(s){s.node.options.fixed.x=s.xFixed;s.node.options.fixed.y=s.yFixed});this.selectionHandler._generateClickEvent(\"dragEnd\",event,this.getPointer(event.center));this.body.emitter.emit(\"startSimulation\")}else{this.selectionHandler._generateClickEvent(\"dragEnd\",event,this.getPointer(event.center),undefined,true);this.body.emitter.emit(\"_requestRedraw\")}}},{key:\"onPinch\",value:function onPinch(event){var pointer=this.getPointer(event.center);this.drag.pinched=true;if(this.pinch[\"scale\"]===undefined){this.pinch.scale=1}var scale=this.pinch.scale*event.scale;this.zoom(scale,pointer)}},{key:\"zoom\",value:function zoom(scale,pointer){if(this.options.zoomView===true){var scaleOld=this.body.view.scale;if(scale<1e-5){scale=1e-5}if(scale>10){scale=10}var preScaleDragPointer=undefined;if(this.drag!==undefined){if(this.drag.dragging===true){preScaleDragPointer=this.canvas.DOMtoCanvas(this.drag.pointer)}}var translation=this.body.view.translation;var scaleFrac=scale/scaleOld;var tx=(1-scaleFrac)*pointer.x+translation.x*scaleFrac;var ty=(1-scaleFrac)*pointer.y+translation.y*scaleFrac;this.body.view.scale=scale;this.body.view.translation={x:tx,y:ty};if(preScaleDragPointer!=undefined){var postScaleDragPointer=this.canvas.canvasToDOM(preScaleDragPointer);this.drag.pointer.x=postScaleDragPointer.x;this.drag.pointer.y=postScaleDragPointer.y}this.body.emitter.emit(\"_requestRedraw\");if(scaleOld<scale){this.body.emitter.emit(\"zoom\",{direction:\"+\",scale:this.body.view.scale,pointer:pointer})}else{this.body.emitter.emit(\"zoom\",{direction:\"-\",scale:this.body.view.scale,pointer:pointer})}}}},{key:\"onMouseWheel\",value:function onMouseWheel(event){if(this.options.zoomView===true){var delta=0;if(event.wheelDelta){delta=event.wheelDelta/120}else if(event.detail){delta=-event.detail/3}if(delta!==0){var scale=this.body.view.scale;var zoom=delta/10;if(delta<0){zoom=zoom/(1-zoom)}scale*=1+zoom;var pointer=this.getPointer({x:event.clientX,y:event.clientY});this.zoom(scale,pointer)}event.preventDefault()}}},{key:\"onMouseMove\",value:function onMouseMove(event){var _this3=this;var pointer=this.getPointer({x:event.clientX,y:event.clientY});var popupVisible=false;if(this.popup!==undefined){if(this.popup.hidden===false){this._checkHidePopup(pointer)}if(this.popup.hidden===false){popupVisible=true;this.popup.setPosition(pointer.x+3,pointer.y-5);this.popup.show()}}if(this.options.keyboard.bindToWindow===false&&this.options.keyboard.enabled===true){this.canvas.frame.focus()}if(popupVisible===false){if(this.popupTimer!==undefined){clearInterval(this.popupTimer);this.popupTimer=undefined}if(!this.drag.dragging){this.popupTimer=setTimeout(function(){return _this3._checkShowPopup(pointer)},this.options.tooltipDelay)}}if(this.options.hover===true){this.selectionHandler.hoverObject(event,pointer)}}},{key:\"_checkShowPopup\",value:function _checkShowPopup(pointer){var x=this.canvas._XconvertDOMtoCanvas(pointer.x);var y=this.canvas._YconvertDOMtoCanvas(pointer.y);var pointerObj={left:x,top:y,right:x,bottom:y};var previousPopupObjId=this.popupObj===undefined?undefined:this.popupObj.id;var nodeUnderCursor=false;var popupType=\"node\";if(this.popupObj===undefined){var nodeIndices=this.body.nodeIndices;var nodes=this.body.nodes;var node=void 0;var overlappingNodes=[];for(var i=0;i<nodeIndices.length;i++){node=nodes[nodeIndices[i]];if(node.isOverlappingWith(pointerObj)===true){if(node.getTitle()!==undefined){overlappingNodes.push(nodeIndices[i])}}}if(overlappingNodes.length>0){this.popupObj=nodes[overlappingNodes[overlappingNodes.length-1]];nodeUnderCursor=true}}if(this.popupObj===undefined&&nodeUnderCursor===false){var edgeIndices=this.body.edgeIndices;var edges=this.body.edges;var edge=void 0;var overlappingEdges=[];for(var _i=0;_i<edgeIndices.length;_i++){edge=edges[edgeIndices[_i]];if(edge.isOverlappingWith(pointerObj)===true){if(edge.connected===true&&edge.getTitle()!==undefined){overlappingEdges.push(edgeIndices[_i])}}}if(overlappingEdges.length>0){this.popupObj=edges[overlappingEdges[overlappingEdges.length-1]];popupType=\"edge\"}}if(this.popupObj!==undefined){if(this.popupObj.id!==previousPopupObjId){if(this.popup===undefined){this.popup=new Popup(this.canvas.frame)}this.popup.popupTargetType=popupType;this.popup.popupTargetId=this.popupObj.id;this.popup.setPosition(pointer.x+3,pointer.y-5);this.popup.setText(this.popupObj.getTitle());this.popup.show();this.body.emitter.emit(\"showPopup\",this.popupObj.id)}}else{if(this.popup!==undefined){this.popup.hide();this.body.emitter.emit(\"hidePopup\")}}}},{key:\"_checkHidePopup\",value:function _checkHidePopup(pointer){var pointerObj=this.selectionHandler._pointerToPositionObject(pointer);var stillOnObj=false;if(this.popup.popupTargetType===\"node\"){if(this.body.nodes[this.popup.popupTargetId]!==undefined){stillOnObj=this.body.nodes[this.popup.popupTargetId].isOverlappingWith(pointerObj);if(stillOnObj===true){var overNode=this.selectionHandler.getNodeAt(pointer);stillOnObj=overNode===undefined?false:overNode.id===this.popup.popupTargetId}}}else{if(this.selectionHandler.getNodeAt(pointer)===undefined){if(this.body.edges[this.popup.popupTargetId]!==undefined){stillOnObj=this.body.edges[this.popup.popupTargetId].isOverlappingWith(pointerObj)}}}if(stillOnObj===false){this.popupObj=undefined;this.popup.hide();this.body.emitter.emit(\"hidePopup\")}}}]);return InteractionHandler}();exports[\"default\"]=InteractionHandler},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Hammer=__webpack_require__(10);var hammerUtil=__webpack_require__(37);var keycharm=__webpack_require__(35);var NavigationHandler=function(){function NavigationHandler(body,canvas){var _this=this;(0,_classCallCheck3[\"default\"])(this,NavigationHandler);this.body=body;this.canvas=canvas;this.iconsCreated=false;this.navigationHammers=[];this.boundFunctions={};this.touchTime=0;this.activated=false;this.body.emitter.on(\"activate\",function(){_this.activated=true;_this.configureKeyboardBindings()});this.body.emitter.on(\"deactivate\",function(){_this.activated=false;_this.configureKeyboardBindings()});this.body.emitter.on(\"destroy\",function(){if(_this.keycharm!==undefined){_this.keycharm.destroy()}});this.options={}}(0,_createClass3[\"default\"])(NavigationHandler,[{key:\"setOptions\",value:function setOptions(options){if(options!==undefined){this.options=options;this.create()}}},{key:\"create\",value:function create(){if(this.options.navigationButtons===true){if(this.iconsCreated===false){this.loadNavigationElements()}}else if(this.iconsCreated===true){this.cleanNavigation()}this.configureKeyboardBindings()}},{key:\"cleanNavigation\",value:function cleanNavigation(){if(this.navigationHammers.length!=0){for(var i=0;i<this.navigationHammers.length;i++){this.navigationHammers[i].destroy()}this.navigationHammers=[]}if(this.navigationDOM&&this.navigationDOM[\"wrapper\"]&&this.navigationDOM[\"wrapper\"].parentNode){this.navigationDOM[\"wrapper\"].parentNode.removeChild(this.navigationDOM[\"wrapper\"])}this.iconsCreated=false}},{key:\"loadNavigationElements\",value:function loadNavigationElements(){var _this2=this;this.cleanNavigation();this.navigationDOM={};var navigationDivs=[\"up\",\"down\",\"left\",\"right\",\"zoomIn\",\"zoomOut\",\"zoomExtends\"];var navigationDivActions=[\"_moveUp\",\"_moveDown\",\"_moveLeft\",\"_moveRight\",\"_zoomIn\",\"_zoomOut\",\"_fit\"];this.navigationDOM[\"wrapper\"]=document.createElement(\"div\");this.navigationDOM[\"wrapper\"].className=\"vis-navigation\";this.canvas.frame.appendChild(this.navigationDOM[\"wrapper\"]);for(var i=0;i<navigationDivs.length;i++){this.navigationDOM[navigationDivs[i]]=document.createElement(\"div\");this.navigationDOM[navigationDivs[i]].className=\"vis-button vis-\"+navigationDivs[i];this.navigationDOM[\"wrapper\"].appendChild(this.navigationDOM[navigationDivs[i]]);var hammer=new Hammer(this.navigationDOM[navigationDivs[i]]);if(navigationDivActions[i]===\"_fit\"){hammerUtil.onTouch(hammer,this._fit.bind(this))}else{hammerUtil.onTouch(hammer,this.bindToRedraw.bind(this,navigationDivActions[i]))}this.navigationHammers.push(hammer)}var hammerFrame=new Hammer(this.canvas.frame);hammerUtil.onRelease(hammerFrame,function(){_this2._stopMovement()});this.navigationHammers.push(hammerFrame);this.iconsCreated=true}},{key:\"bindToRedraw\",value:function bindToRedraw(action){if(this.boundFunctions[action]===undefined){this.boundFunctions[action]=this[action].bind(this);this.body.emitter.on(\"initRedraw\",this.boundFunctions[action]);this.body.emitter.emit(\"_startRendering\")}}},{key:\"unbindFromRedraw\",value:function unbindFromRedraw(action){if(this.boundFunctions[action]!==undefined){this.body.emitter.off(\"initRedraw\",this.boundFunctions[action]);this.body.emitter.emit(\"_stopRendering\");delete this.boundFunctions[action]}}},{key:\"_fit\",value:function _fit(){if((new Date).valueOf()-this.touchTime>700){this.body.emitter.emit(\"fit\",{duration:700});this.touchTime=(new Date).valueOf()}}},{key:\"_stopMovement\",value:function _stopMovement(){for(var boundAction in this.boundFunctions){if(this.boundFunctions.hasOwnProperty(boundAction)){this.body.emitter.off(\"initRedraw\",this.boundFunctions[boundAction]);this.body.emitter.emit(\"_stopRendering\")}}this.boundFunctions={}}},{key:\"_moveUp\",value:function _moveUp(){this.body.view.translation.y+=this.options.keyboard.speed.y}},{key:\"_moveDown\",value:function _moveDown(){this.body.view.translation.y-=this.options.keyboard.speed.y}},{key:\"_moveLeft\",value:function _moveLeft(){this.body.view.translation.x+=this.options.keyboard.speed.x}},{key:\"_moveRight\",value:function _moveRight(){this.body.view.translation.x-=this.options.keyboard.speed.x}},{key:\"_zoomIn\",value:function _zoomIn(){var scaleOld=this.body.view.scale;var scale=this.body.view.scale*(1+this.options.keyboard.speed.zoom);var translation=this.body.view.translation;var scaleFrac=scale/scaleOld;var tx=(1-scaleFrac)*this.canvas.canvasViewCenter.x+translation.x*scaleFrac;var ty=(1-scaleFrac)*this.canvas.canvasViewCenter.y+translation.y*scaleFrac;this.body.view.scale=scale;this.body.view.translation={x:tx,y:ty};this.body.emitter.emit(\"zoom\",{direction:\"+\",scale:this.body.view.scale,pointer:null})}},{key:\"_zoomOut\",value:function _zoomOut(){var scaleOld=this.body.view.scale;var scale=this.body.view.scale/(1+this.options.keyboard.speed.zoom);var translation=this.body.view.translation;var scaleFrac=scale/scaleOld;var tx=(1-scaleFrac)*this.canvas.canvasViewCenter.x+translation.x*scaleFrac;var ty=(1-scaleFrac)*this.canvas.canvasViewCenter.y+translation.y*scaleFrac;this.body.view.scale=scale;this.body.view.translation={x:tx,y:ty};this.body.emitter.emit(\"zoom\",{direction:\"-\",scale:this.body.view.scale,pointer:null})}},{key:\"configureKeyboardBindings\",value:function configureKeyboardBindings(){var _this3=this;if(this.keycharm!==undefined){this.keycharm.destroy()}if(this.options.keyboard.enabled===true){if(this.options.keyboard.bindToWindow===true){this.keycharm=keycharm({container:window,preventDefault:true})}else{this.keycharm=keycharm({container:this.canvas.frame,preventDefault:true})}this.keycharm.reset();if(this.activated===true){this.keycharm.bind(\"up\",function(){_this3.bindToRedraw(\"_moveUp\")},\"keydown\");this.keycharm.bind(\"down\",function(){_this3.bindToRedraw(\"_moveDown\")},\"keydown\");this.keycharm.bind(\"left\",function(){_this3.bindToRedraw(\"_moveLeft\")},\"keydown\");this.keycharm.bind(\"right\",function(){_this3.bindToRedraw(\"_moveRight\")},\"keydown\");this.keycharm.bind(\"=\",function(){_this3.bindToRedraw(\"_zoomIn\")},\"keydown\");this.keycharm.bind(\"num+\",function(){_this3.bindToRedraw(\"_zoomIn\")},\"keydown\");this.keycharm.bind(\"num-\",function(){_this3.bindToRedraw(\"_zoomOut\")},\"keydown\");this.keycharm.bind(\"-\",function(){_this3.bindToRedraw(\"_zoomOut\")},\"keydown\");this.keycharm.bind(\"[\",function(){_this3.bindToRedraw(\"_zoomOut\")},\"keydown\");this.keycharm.bind(\"]\",function(){_this3.bindToRedraw(\"_zoomIn\")},\"keydown\");this.keycharm.bind(\"pageup\",function(){_this3.bindToRedraw(\"_zoomIn\")},\"keydown\");this.keycharm.bind(\"pagedown\",function(){_this3.bindToRedraw(\"_zoomOut\")},\"keydown\");this.keycharm.bind(\"up\",function(){_this3.unbindFromRedraw(\"_moveUp\")},\"keyup\");this.keycharm.bind(\"down\",function(){_this3.unbindFromRedraw(\"_moveDown\")},\"keyup\");this.keycharm.bind(\"left\",function(){_this3.unbindFromRedraw(\"_moveLeft\")},\"keyup\");this.keycharm.bind(\"right\",function(){_this3.unbindFromRedraw(\"_moveRight\")},\"keyup\");this.keycharm.bind(\"=\",function(){_this3.unbindFromRedraw(\"_zoomIn\")},\"keyup\");this.keycharm.bind(\"num+\",function(){_this3.unbindFromRedraw(\"_zoomIn\")},\"keyup\");this.keycharm.bind(\"num-\",function(){_this3.unbindFromRedraw(\"_zoomOut\")},\"keyup\");this.keycharm.bind(\"-\",function(){_this3.unbindFromRedraw(\"_zoomOut\")},\"keyup\");this.keycharm.bind(\"[\",function(){_this3.unbindFromRedraw(\"_zoomOut\")},\"keyup\");this.keycharm.bind(\"]\",function(){_this3.unbindFromRedraw(\"_zoomIn\")},\"keyup\");this.keycharm.bind(\"pageup\",function(){_this3.unbindFromRedraw(\"_zoomIn\")},\"keyup\");this.keycharm.bind(\"pagedown\",function(){_this3.unbindFromRedraw(\"_zoomOut\")},\"keyup\")}}}}]);return NavigationHandler}();exports[\"default\"]=NavigationHandler},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Node=__webpack_require__(47)[\"default\"];var Edge=__webpack_require__(74)[\"default\"];var util=__webpack_require__(2);var SelectionHandler=function(){function SelectionHandler(body,canvas){var _this=this;(0,_classCallCheck3[\"default\"])(this,SelectionHandler);this.body=body;this.canvas=canvas;this.selectionObj={nodes:[],edges:[]};this.hoverObj={nodes:{},edges:{}};this.options={};this.defaultOptions={multiselect:false,selectable:true,selectConnectedEdges:true,hoverConnectedEdges:true};util.extend(this.options,this.defaultOptions);this.body.emitter.on(\"_dataChanged\",function(){_this.updateSelection()})}(0,_createClass3[\"default\"])(SelectionHandler,[{key:\"setOptions\",value:function setOptions(options){if(options!==undefined){var fields=[\"multiselect\",\"hoverConnectedEdges\",\"selectable\",\"selectConnectedEdges\"];util.selectiveDeepExtend(fields,this.options,options)}}},{key:\"selectOnPoint\",value:function selectOnPoint(pointer){var selected=false;if(this.options.selectable===true){var obj=this.getNodeAt(pointer)||this.getEdgeAt(pointer);this.unselectAll();if(obj!==undefined){selected=this.selectObject(obj)}this.body.emitter.emit(\"_requestRedraw\")}return selected}},{key:\"selectAdditionalOnPoint\",value:function selectAdditionalOnPoint(pointer){var selectionChanged=false;if(this.options.selectable===true){var obj=this.getNodeAt(pointer)||this.getEdgeAt(pointer);if(obj!==undefined){selectionChanged=true;if(obj.isSelected()===true){this.deselectObject(obj)}else{this.selectObject(obj)}this.body.emitter.emit(\"_requestRedraw\")}}return selectionChanged}},{key:\"_initBaseEvent\",value:function _initBaseEvent(event,pointer){var properties={};properties[\"pointer\"]={DOM:{\nx:pointer.x,y:pointer.y},canvas:this.canvas.DOMtoCanvas(pointer)};properties[\"event\"]=event;return properties}},{key:\"_generateClickEvent\",value:function _generateClickEvent(eventType,event,pointer,oldSelection){var emptySelection=arguments.length>4&&arguments[4]!==undefined?arguments[4]:false;var properties=this._initBaseEvent(event,pointer);if(emptySelection===true){properties.nodes=[];properties.edges=[]}else{var tmp=this.getSelection();properties.nodes=tmp.nodes;properties.edges=tmp.edges}if(oldSelection!==undefined){properties[\"previousSelection\"]=oldSelection}if(eventType==\"click\"){properties.items=this.getClickedItems(pointer)}this.body.emitter.emit(eventType,properties)}},{key:\"selectObject\",value:function selectObject(obj){var highlightEdges=arguments.length>1&&arguments[1]!==undefined?arguments[1]:this.options.selectConnectedEdges;if(obj!==undefined){if(obj instanceof Node){if(highlightEdges===true){this._selectConnectedEdges(obj)}}obj.select();this._addToSelection(obj);return true}return false}},{key:\"deselectObject\",value:function deselectObject(obj){if(obj.isSelected()===true){obj.selected=false;this._removeFromSelection(obj)}}},{key:\"_getAllNodesOverlappingWith\",value:function _getAllNodesOverlappingWith(object){var overlappingNodes=[];var nodes=this.body.nodes;for(var i=0;i<this.body.nodeIndices.length;i++){var nodeId=this.body.nodeIndices[i];if(nodes[nodeId].isOverlappingWith(object)){overlappingNodes.push(nodeId)}}return overlappingNodes}},{key:\"_pointerToPositionObject\",value:function _pointerToPositionObject(pointer){var canvasPos=this.canvas.DOMtoCanvas(pointer);return{left:canvasPos.x-1,top:canvasPos.y+1,right:canvasPos.x+1,bottom:canvasPos.y-1}}},{key:\"getNodeAt\",value:function getNodeAt(pointer){var returnNode=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;var positionObject=this._pointerToPositionObject(pointer);var overlappingNodes=this._getAllNodesOverlappingWith(positionObject);if(overlappingNodes.length>0){if(returnNode===true){return this.body.nodes[overlappingNodes[overlappingNodes.length-1]]}else{return overlappingNodes[overlappingNodes.length-1]}}else{return undefined}}},{key:\"_getEdgesOverlappingWith\",value:function _getEdgesOverlappingWith(object,overlappingEdges){var edges=this.body.edges;for(var i=0;i<this.body.edgeIndices.length;i++){var edgeId=this.body.edgeIndices[i];if(edges[edgeId].isOverlappingWith(object)){overlappingEdges.push(edgeId)}}}},{key:\"_getAllEdgesOverlappingWith\",value:function _getAllEdgesOverlappingWith(object){var overlappingEdges=[];this._getEdgesOverlappingWith(object,overlappingEdges);return overlappingEdges}},{key:\"getEdgeAt\",value:function getEdgeAt(pointer){var returnEdge=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;var canvasPos=this.canvas.DOMtoCanvas(pointer);var mindist=10;var overlappingEdge=null;var edges=this.body.edges;for(var i=0;i<this.body.edgeIndices.length;i++){var edgeId=this.body.edgeIndices[i];var edge=edges[edgeId];if(edge.connected){var xFrom=edge.from.x;var yFrom=edge.from.y;var xTo=edge.to.x;var yTo=edge.to.y;var dist=edge.edgeType.getDistanceToEdge(xFrom,yFrom,xTo,yTo,canvasPos.x,canvasPos.y);if(dist<mindist){overlappingEdge=edgeId;mindist=dist}}}if(overlappingEdge!==null){if(returnEdge===true){return this.body.edges[overlappingEdge]}else{return overlappingEdge}}else{return undefined}}},{key:\"_addToSelection\",value:function _addToSelection(obj){if(obj instanceof Node){this.selectionObj.nodes[obj.id]=obj}else{this.selectionObj.edges[obj.id]=obj}}},{key:\"_addToHover\",value:function _addToHover(obj){if(obj instanceof Node){this.hoverObj.nodes[obj.id]=obj}else{this.hoverObj.edges[obj.id]=obj}}},{key:\"_removeFromSelection\",value:function _removeFromSelection(obj){if(obj instanceof Node){delete this.selectionObj.nodes[obj.id];this._unselectConnectedEdges(obj)}else{delete this.selectionObj.edges[obj.id]}}},{key:\"unselectAll\",value:function unselectAll(){for(var nodeId in this.selectionObj.nodes){if(this.selectionObj.nodes.hasOwnProperty(nodeId)){this.selectionObj.nodes[nodeId].unselect()}}for(var edgeId in this.selectionObj.edges){if(this.selectionObj.edges.hasOwnProperty(edgeId)){this.selectionObj.edges[edgeId].unselect()}}this.selectionObj={nodes:{},edges:{}}}},{key:\"_getSelectedNodeCount\",value:function _getSelectedNodeCount(){var count=0;for(var nodeId in this.selectionObj.nodes){if(this.selectionObj.nodes.hasOwnProperty(nodeId)){count+=1}}return count}},{key:\"_getSelectedNode\",value:function _getSelectedNode(){for(var nodeId in this.selectionObj.nodes){if(this.selectionObj.nodes.hasOwnProperty(nodeId)){return this.selectionObj.nodes[nodeId]}}return undefined}},{key:\"_getSelectedEdge\",value:function _getSelectedEdge(){for(var edgeId in this.selectionObj.edges){if(this.selectionObj.edges.hasOwnProperty(edgeId)){return this.selectionObj.edges[edgeId]}}return undefined}},{key:\"_getSelectedEdgeCount\",value:function _getSelectedEdgeCount(){var count=0;for(var edgeId in this.selectionObj.edges){if(this.selectionObj.edges.hasOwnProperty(edgeId)){count+=1}}return count}},{key:\"_getSelectedObjectCount\",value:function _getSelectedObjectCount(){var count=0;for(var nodeId in this.selectionObj.nodes){if(this.selectionObj.nodes.hasOwnProperty(nodeId)){count+=1}}for(var edgeId in this.selectionObj.edges){if(this.selectionObj.edges.hasOwnProperty(edgeId)){count+=1}}return count}},{key:\"_selectionIsEmpty\",value:function _selectionIsEmpty(){for(var nodeId in this.selectionObj.nodes){if(this.selectionObj.nodes.hasOwnProperty(nodeId)){return false}}for(var edgeId in this.selectionObj.edges){if(this.selectionObj.edges.hasOwnProperty(edgeId)){return false}}return true}},{key:\"_clusterInSelection\",value:function _clusterInSelection(){for(var nodeId in this.selectionObj.nodes){if(this.selectionObj.nodes.hasOwnProperty(nodeId)){if(this.selectionObj.nodes[nodeId].clusterSize>1){return true}}}return false}},{key:\"_selectConnectedEdges\",value:function _selectConnectedEdges(node){for(var i=0;i<node.edges.length;i++){var edge=node.edges[i];edge.select();this._addToSelection(edge)}}},{key:\"_hoverConnectedEdges\",value:function _hoverConnectedEdges(node){for(var i=0;i<node.edges.length;i++){var edge=node.edges[i];edge.hover=true;this._addToHover(edge)}}},{key:\"_unselectConnectedEdges\",value:function _unselectConnectedEdges(node){for(var i=0;i<node.edges.length;i++){var edge=node.edges[i];edge.unselect();this._removeFromSelection(edge)}}},{key:\"emitBlurEvent\",value:function emitBlurEvent(event,pointer,object){var properties=this._initBaseEvent(event,pointer);if(object.hover===true){object.hover=false;if(object instanceof Node){properties.node=object.id;this.body.emitter.emit(\"blurNode\",properties)}else{properties.edge=object.id;this.body.emitter.emit(\"blurEdge\",properties)}}}},{key:\"emitHoverEvent\",value:function emitHoverEvent(event,pointer,object){var properties=this._initBaseEvent(event,pointer);var hoverChanged=false;if(object.hover===false){object.hover=true;this._addToHover(object);hoverChanged=true;if(object instanceof Node){properties.node=object.id;this.body.emitter.emit(\"hoverNode\",properties)}else{properties.edge=object.id;this.body.emitter.emit(\"hoverEdge\",properties)}}return hoverChanged}},{key:\"hoverObject\",value:function hoverObject(event,pointer){var object=this.getNodeAt(pointer);if(object===undefined){object=this.getEdgeAt(pointer)}var hoverChanged=false;for(var nodeId in this.hoverObj.nodes){if(this.hoverObj.nodes.hasOwnProperty(nodeId)){if(object===undefined||object instanceof Node&&object.id!=nodeId||object instanceof Edge){this.emitBlurEvent(event,pointer,this.hoverObj.nodes[nodeId]);delete this.hoverObj.nodes[nodeId];hoverChanged=true}}}for(var edgeId in this.hoverObj.edges){if(this.hoverObj.edges.hasOwnProperty(edgeId)){if(hoverChanged===true){this.hoverObj.edges[edgeId].hover=false;delete this.hoverObj.edges[edgeId]}else if(object===undefined||object instanceof Edge&&object.id!=edgeId||object instanceof Node&&!object.hover){this.emitBlurEvent(event,pointer,this.hoverObj.edges[edgeId]);delete this.hoverObj.edges[edgeId];hoverChanged=true}}}if(object!==undefined){hoverChanged=hoverChanged||this.emitHoverEvent(event,pointer,object);if(object instanceof Node&&this.options.hoverConnectedEdges===true){this._hoverConnectedEdges(object)}}if(hoverChanged===true){this.body.emitter.emit(\"_requestRedraw\")}}},{key:\"getSelection\",value:function getSelection(){var nodeIds=this.getSelectedNodes();var edgeIds=this.getSelectedEdges();return{nodes:nodeIds,edges:edgeIds}}},{key:\"getSelectedNodes\",value:function getSelectedNodes(){var idArray=[];if(this.options.selectable===true){for(var nodeId in this.selectionObj.nodes){if(this.selectionObj.nodes.hasOwnProperty(nodeId)){idArray.push(this.selectionObj.nodes[nodeId].id)}}}return idArray}},{key:\"getSelectedEdges\",value:function getSelectedEdges(){var idArray=[];if(this.options.selectable===true){for(var edgeId in this.selectionObj.edges){if(this.selectionObj.edges.hasOwnProperty(edgeId)){idArray.push(this.selectionObj.edges[edgeId].id)}}}return idArray}},{key:\"setSelection\",value:function setSelection(selection){var options=arguments.length>1&&arguments[1]!==undefined?arguments[1]:{};var i=void 0,id=void 0;if(!selection||!selection.nodes&&!selection.edges)throw\"Selection must be an object with nodes and/or edges properties\";if(options.unselectAll||options.unselectAll===undefined){this.unselectAll()}if(selection.nodes){for(i=0;i<selection.nodes.length;i++){id=selection.nodes[i];var node=this.body.nodes[id];if(!node){throw new RangeError('Node with id \"'+id+'\" not found')}this.selectObject(node,options.highlightEdges)}}if(selection.edges){for(i=0;i<selection.edges.length;i++){id=selection.edges[i];var edge=this.body.edges[id];if(!edge){throw new RangeError('Edge with id \"'+id+'\" not found')}this.selectObject(edge)}}this.body.emitter.emit(\"_requestRedraw\")}},{key:\"selectNodes\",value:function selectNodes(selection){var highlightEdges=arguments.length>1&&arguments[1]!==undefined?arguments[1]:true;if(!selection||selection.length===undefined)throw\"Selection must be an array with ids\";this.setSelection({nodes:selection},{highlightEdges:highlightEdges})}},{key:\"selectEdges\",value:function selectEdges(selection){if(!selection||selection.length===undefined)throw\"Selection must be an array with ids\";this.setSelection({edges:selection})}},{key:\"updateSelection\",value:function updateSelection(){for(var nodeId in this.selectionObj.nodes){if(this.selectionObj.nodes.hasOwnProperty(nodeId)){if(!this.body.nodes.hasOwnProperty(nodeId)){delete this.selectionObj.nodes[nodeId]}}}for(var edgeId in this.selectionObj.edges){if(this.selectionObj.edges.hasOwnProperty(edgeId)){if(!this.body.edges.hasOwnProperty(edgeId)){delete this.selectionObj.edges[edgeId]}}}}},{key:\"getClickedItems\",value:function getClickedItems(pointer){var point=this.canvas.DOMtoCanvas(pointer);var items=[];var nodeIndices=this.body.nodeIndices;var nodes=this.body.nodes;for(var i=nodeIndices.length-1;i>=0;i--){var node=nodes[nodeIndices[i]];var ret=node.getItemsOnPoint(point);items.push.apply(items,ret)}var edgeIndices=this.body.edgeIndices;var edges=this.body.edges;for(var _i=edgeIndices.length-1;_i>=0;_i--){var edge=edges[edgeIndices[_i]];var _ret=edge.getItemsOnPoint(point);items.push.apply(items,_ret)}return items}}]);return SelectionHandler}();exports[\"default\"]=SelectionHandler},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _slicedToArray2=__webpack_require__(30);var _slicedToArray3=_interopRequireDefault(_slicedToArray2);var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);var _keys=__webpack_require__(8);var _keys2=_interopRequireDefault(_keys);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var NetworkUtil=__webpack_require__(76)[\"default\"];var _require=__webpack_require__(236),HorizontalStrategy=_require.HorizontalStrategy,VerticalStrategy=_require.VerticalStrategy;var HierarchicalStatus=function(){function HierarchicalStatus(){(0,_classCallCheck3[\"default\"])(this,HierarchicalStatus);this.childrenReference={};this.parentReference={};this.trees={};this.distributionOrdering={};this.levels={};this.distributionIndex={};this.isTree=false;this.treeIndex=-1}(0,_createClass3[\"default\"])(HierarchicalStatus,[{key:\"addRelation\",value:function addRelation(parentNodeId,childNodeId){if(this.childrenReference[parentNodeId]===undefined){this.childrenReference[parentNodeId]=[]}this.childrenReference[parentNodeId].push(childNodeId);if(this.parentReference[childNodeId]===undefined){this.parentReference[childNodeId]=[]}this.parentReference[childNodeId].push(parentNodeId)}},{key:\"checkIfTree\",value:function checkIfTree(){for(var i in this.parentReference){if(this.parentReference[i].length>1){this.isTree=false;return}}this.isTree=true}},{key:\"numTrees\",value:function numTrees(){return this.treeIndex+1}},{key:\"setTreeIndex\",value:function setTreeIndex(node,treeId){if(treeId===undefined)return;if(this.trees[node.id]===undefined){this.trees[node.id]=treeId;this.treeIndex=Math.max(treeId,this.treeIndex)}}},{key:\"ensureLevel\",value:function ensureLevel(nodeId){if(this.levels[nodeId]===undefined){this.levels[nodeId]=0}}},{key:\"getMaxLevel\",value:function getMaxLevel(nodeId){var _this=this;var accumulator={};var _getMaxLevel=function _getMaxLevel(nodeId){if(accumulator[nodeId]!==undefined){return accumulator[nodeId]}var level=_this.levels[nodeId];if(_this.childrenReference[nodeId]){var children=_this.childrenReference[nodeId];if(children.length>0){for(var i=0;i<children.length;i++){level=Math.max(level,_getMaxLevel(children[i]))}}}accumulator[nodeId]=level;return level};return _getMaxLevel(nodeId)}},{key:\"levelDownstream\",value:function levelDownstream(nodeA,nodeB){if(this.levels[nodeB.id]===undefined){if(this.levels[nodeA.id]===undefined){this.levels[nodeA.id]=0}this.levels[nodeB.id]=this.levels[nodeA.id]+1}}},{key:\"setMinLevelToZero\",value:function setMinLevelToZero(nodes){var minLevel=1e9;for(var nodeId in nodes){if(nodes.hasOwnProperty(nodeId)){if(this.levels[nodeId]!==undefined){minLevel=Math.min(this.levels[nodeId],minLevel)}}}for(var _nodeId in nodes){if(nodes.hasOwnProperty(_nodeId)){if(this.levels[_nodeId]!==undefined){this.levels[_nodeId]-=minLevel}}}}},{key:\"getTreeSize\",value:function getTreeSize(nodes,index){var min_x=1e9;var max_x=-1e9;var min_y=1e9;var max_y=-1e9;for(var nodeId in this.trees){if(this.trees.hasOwnProperty(nodeId)){if(this.trees[nodeId]===index){var node=nodes[nodeId];min_x=Math.min(node.x,min_x);max_x=Math.max(node.x,max_x);min_y=Math.min(node.y,min_y);max_y=Math.max(node.y,max_y)}}}return{min_x:min_x,max_x:max_x,min_y:min_y,max_y:max_y}}},{key:\"hasSameParent\",value:function hasSameParent(node1,node2){var parents1=this.parentReference[node1.id];var parents2=this.parentReference[node2.id];if(parents1===undefined||parents2===undefined){return false}for(var i=0;i<parents1.length;i++){for(var j=0;j<parents2.length;j++){if(parents1[i]==parents2[j]){return true}}}return false}},{key:\"inSameSubNetwork\",value:function inSameSubNetwork(node1,node2){return this.trees[node1.id]===this.trees[node2.id]}},{key:\"getLevels\",value:function getLevels(){return(0,_keys2[\"default\"])(this.distributionOrdering)}},{key:\"addToOrdering\",value:function addToOrdering(node,level){if(this.distributionOrdering[level]===undefined){this.distributionOrdering[level]=[]}var isPresent=false;var curLevel=this.distributionOrdering[level];for(var n in curLevel){if(curLevel[n]===node){isPresent=true;break}}if(!isPresent){this.distributionOrdering[level].push(node);this.distributionIndex[node.id]=this.distributionOrdering[level].length-1}}}]);return HierarchicalStatus}();var LayoutEngine=function(){function LayoutEngine(body){(0,_classCallCheck3[\"default\"])(this,LayoutEngine);this.body=body;this.initialRandomSeed=Math.round(Math.random()*1e6);this.randomSeed=this.initialRandomSeed;this.setPhysics=false;this.options={};this.optionsBackup={physics:{}};this.defaultOptions={randomSeed:undefined,improvedLayout:true,hierarchical:{enabled:false,levelSeparation:150,nodeSpacing:100,treeSpacing:200,blockShifting:true,edgeMinimization:true,parentCentralization:true,direction:\"UD\",sortMethod:\"hubsize\"}};util.extend(this.options,this.defaultOptions);this.bindEventListeners()}(0,_createClass3[\"default\"])(LayoutEngine,[{key:\"bindEventListeners\",value:function bindEventListeners(){var _this2=this;this.body.emitter.on(\"_dataChanged\",function(){_this2.setupHierarchicalLayout()});this.body.emitter.on(\"_dataLoaded\",function(){_this2.layoutNetwork()});this.body.emitter.on(\"_resetHierarchicalLayout\",function(){_this2.setupHierarchicalLayout()});this.body.emitter.on(\"_adjustEdgesForHierarchicalLayout\",function(){if(_this2.options.hierarchical.enabled!==true){return}var type=_this2.direction.curveType();_this2.body.emitter.emit(\"_forceDisableDynamicCurves\",type,false)})}},{key:\"setOptions\",value:function setOptions(options,allOptions){if(options!==undefined){var hierarchical=this.options.hierarchical;var prevHierarchicalState=hierarchical.enabled;util.selectiveDeepExtend([\"randomSeed\",\"improvedLayout\"],this.options,options);util.mergeOptions(this.options,options,\"hierarchical\");if(options.randomSeed!==undefined){this.initialRandomSeed=options.randomSeed}if(hierarchical.enabled===true){if(prevHierarchicalState===true){this.body.emitter.emit(\"refresh\",true)}if(hierarchical.direction===\"RL\"||hierarchical.direction===\"DU\"){if(hierarchical.levelSeparation>0){hierarchical.levelSeparation*=-1}}else{if(hierarchical.levelSeparation<0){hierarchical.levelSeparation*=-1}}this.setDirectionStrategy();this.body.emitter.emit(\"_resetHierarchicalLayout\");return this.adaptAllOptionsForHierarchicalLayout(allOptions)}else{if(prevHierarchicalState===true){this.body.emitter.emit(\"refresh\");return util.deepExtend(allOptions,this.optionsBackup)}}}return allOptions}},{key:\"adaptAllOptionsForHierarchicalLayout\",value:function adaptAllOptionsForHierarchicalLayout(allOptions){if(this.options.hierarchical.enabled===true){var backupPhysics=this.optionsBackup.physics;if(allOptions.physics===undefined||allOptions.physics===true){allOptions.physics={enabled:backupPhysics.enabled===undefined?true:backupPhysics.enabled,solver:\"hierarchicalRepulsion\"};backupPhysics.enabled=backupPhysics.enabled===undefined?true:backupPhysics.enabled;backupPhysics.solver=backupPhysics.solver||\"barnesHut\"}else if((0,_typeof3[\"default\"])(allOptions.physics)===\"object\"){backupPhysics.enabled=allOptions.physics.enabled===undefined?true:allOptions.physics.enabled;backupPhysics.solver=allOptions.physics.solver||\"barnesHut\";allOptions.physics.solver=\"hierarchicalRepulsion\"}else if(allOptions.physics!==false){backupPhysics.solver=\"barnesHut\";allOptions.physics={solver:\"hierarchicalRepulsion\"}}var type=this.direction.curveType();if(allOptions.edges===undefined){this.optionsBackup.edges={smooth:{enabled:true,type:\"dynamic\"}};allOptions.edges={smooth:false}}else if(allOptions.edges.smooth===undefined){this.optionsBackup.edges={smooth:{enabled:true,type:\"dynamic\"}};allOptions.edges.smooth=false}else{if(typeof allOptions.edges.smooth===\"boolean\"){this.optionsBackup.edges={smooth:allOptions.edges.smooth};allOptions.edges.smooth={enabled:allOptions.edges.smooth,type:type}}else{var smooth=allOptions.edges.smooth;if(smooth.type!==undefined&&smooth.type!==\"dynamic\"){type=smooth.type}this.optionsBackup.edges={smooth:smooth.enabled===undefined?true:smooth.enabled,type:smooth.type===undefined?\"dynamic\":smooth.type,roundness:smooth.roundness===undefined?.5:smooth.roundness,forceDirection:smooth.forceDirection===undefined?false:smooth.forceDirection};allOptions.edges.smooth={enabled:smooth.enabled===undefined?true:smooth.enabled,type:type,roundness:smooth.roundness===undefined?.5:smooth.roundness,forceDirection:smooth.forceDirection===undefined?false:smooth.forceDirection}}}this.body.emitter.emit(\"_forceDisableDynamicCurves\",type)}return allOptions}},{key:\"seededRandom\",value:function seededRandom(){var x=Math.sin(this.randomSeed++)*1e4;return x-Math.floor(x)}},{key:\"positionInitially\",value:function positionInitially(nodesArray){if(this.options.hierarchical.enabled!==true){this.randomSeed=this.initialRandomSeed;var radius=nodesArray.length+50;for(var i=0;i<nodesArray.length;i++){var node=nodesArray[i];var angle=2*Math.PI*this.seededRandom();if(node.x===undefined){node.x=radius*Math.cos(angle)}if(node.y===undefined){node.y=radius*Math.sin(angle)}}}}},{key:\"layoutNetwork\",value:function layoutNetwork(){if(this.options.hierarchical.enabled!==true&&this.options.improvedLayout===true){var indices=this.body.nodeIndices;var positionDefined=0;for(var i=0;i<indices.length;i++){var node=this.body.nodes[indices[i]];if(node.predefinedPosition===true){positionDefined+=1}}if(positionDefined<.5*indices.length){var MAX_LEVELS=10;var level=0;var clusterThreshold=150;var clusterOptions={clusterNodeProperties:{shape:\"ellipse\",label:\"\",group:\"\",font:{multi:false}},clusterEdgeProperties:{label:\"\",font:{multi:false},smooth:{enabled:false}}};if(indices.length>clusterThreshold){var startLength=indices.length;while(indices.length>clusterThreshold&&level<=MAX_LEVELS){level+=1;var before=indices.length;if(level%3===0){this.body.modules.clustering.clusterBridges(clusterOptions)}else{this.body.modules.clustering.clusterOutliers(clusterOptions)}var after=indices.length;if(before==after&&level%3!==0){this._declusterAll();this.body.emitter.emit(\"_layoutFailed\");console.info(\"This network could not be positioned by this version of the improved layout algorithm.\"+\" Please disable improvedLayout for better performance.\");return}}this.body.modules.kamadaKawai.setOptions({springLength:Math.max(150,2*startLength)})}if(level>MAX_LEVELS){console.info(\"The clustering didn't succeed within the amount of interations allowed,\"+\" progressing with partial result.\")}this.body.modules.kamadaKawai.solve(indices,this.body.edgeIndices,true);this._shiftToCenter();var offset=70;for(var _i=0;_i<indices.length;_i++){var _node=this.body.nodes[indices[_i]];if(_node.predefinedPosition===false){_node.x+=(.5-this.seededRandom())*offset;_node.y+=(.5-this.seededRandom())*offset}}this._declusterAll();this.body.emitter.emit(\"_repositionBezierNodes\")}}}},{key:\"_shiftToCenter\",value:function _shiftToCenter(){var range=NetworkUtil.getRangeCore(this.body.nodes,this.body.nodeIndices);var center=NetworkUtil.findCenter(range);for(var i=0;i<this.body.nodeIndices.length;i++){var node=this.body.nodes[this.body.nodeIndices[i]];node.x-=center.x;node.y-=center.y}}},{key:\"_declusterAll\",value:function _declusterAll(){var clustersPresent=true;while(clustersPresent===true){clustersPresent=false;for(var i=0;i<this.body.nodeIndices.length;i++){if(this.body.nodes[this.body.nodeIndices[i]].isCluster===true){clustersPresent=true;this.body.modules.clustering.openCluster(this.body.nodeIndices[i],{},false)}}if(clustersPresent===true){this.body.emitter.emit(\"_dataChanged\")}}}},{key:\"getSeed\",value:function getSeed(){return this.initialRandomSeed}},{key:\"setupHierarchicalLayout\",value:function setupHierarchicalLayout(){if(this.options.hierarchical.enabled===true&&this.body.nodeIndices.length>0){var node=void 0,nodeId=void 0;var definedLevel=false;var undefinedLevel=false;this.lastNodeOnLevel={};this.hierarchical=new HierarchicalStatus;for(nodeId in this.body.nodes){if(this.body.nodes.hasOwnProperty(nodeId)){node=this.body.nodes[nodeId];if(node.options.level!==undefined){definedLevel=true;this.hierarchical.levels[nodeId]=node.options.level}else{undefinedLevel=true}}}if(undefinedLevel===true&&definedLevel===true){throw new Error(\"To use the hierarchical layout, nodes require either no predefined levels\"+\" or levels have to be defined for all nodes.\")}else{if(undefinedLevel===true){var sortMethod=this.options.hierarchical.sortMethod;if(sortMethod===\"hubsize\"){this._determineLevelsByHubsize()}else if(sortMethod===\"directed\"){this._determineLevelsDirected()}else if(sortMethod===\"custom\"){this._determineLevelsCustomCallback()}}for(var _nodeId2 in this.body.nodes){if(this.body.nodes.hasOwnProperty(_nodeId2)){this.hierarchical.ensureLevel(_nodeId2)}}var distribution=this._getDistribution();this._generateMap();this._placeNodesByHierarchy(distribution);this._condenseHierarchy();this._shiftToCenter()}}}},{key:\"_condenseHierarchy\",value:function _condenseHierarchy(){var _this3=this;var stillShifting=false;var branches={};var shiftTrees=function shiftTrees(){var treeSizes=getTreeSizes();var shiftBy=0;for(var i=0;i<treeSizes.length-1;i++){var diff=treeSizes[i].max-treeSizes[i+1].min;shiftBy+=diff+_this3.options.hierarchical.treeSpacing;shiftTree(i+1,shiftBy)}};var shiftTree=function shiftTree(index,offset){var trees=_this3.hierarchical.trees;for(var nodeId in trees){if(trees.hasOwnProperty(nodeId)){if(trees[nodeId]===index){_this3.direction.shift(nodeId,offset)}}}};var getTreeSizes=function getTreeSizes(){var treeWidths=[];for(var i=0;i<_this3.hierarchical.numTrees();i++){treeWidths.push(_this3.direction.getTreeSize(i))}return treeWidths};var getBranchNodes=function getBranchNodes(source,map){if(map[source.id]){return}map[source.id]=true;if(_this3.hierarchical.childrenReference[source.id]){var children=_this3.hierarchical.childrenReference[source.id];if(children.length>0){for(var i=0;i<children.length;i++){getBranchNodes(_this3.body.nodes[children[i]],map)}}}};var getBranchBoundary=function getBranchBoundary(branchMap){var maxLevel=arguments.length>1&&arguments[1]!==undefined?arguments[1]:1e9;var minSpace=1e9;var maxSpace=1e9;var min=1e9;var max=-1e9;for(var branchNode in branchMap){if(branchMap.hasOwnProperty(branchNode)){var node=_this3.body.nodes[branchNode];var level=_this3.hierarchical.levels[node.id];var position=_this3.direction.getPosition(node);var _getSpaceAroundNode2=_this3._getSpaceAroundNode(node,branchMap),_getSpaceAroundNode3=(0,_slicedToArray3[\"default\"])(_getSpaceAroundNode2,2),minSpaceNode=_getSpaceAroundNode3[0],maxSpaceNode=_getSpaceAroundNode3[1];minSpace=Math.min(minSpaceNode,minSpace);maxSpace=Math.min(maxSpaceNode,maxSpace);if(level<=maxLevel){min=Math.min(position,min);max=Math.max(position,max)}}}return[min,max,minSpace,maxSpace]};var getCollisionLevel=function getCollisionLevel(node1,node2){var maxLevel1=_this3.hierarchical.getMaxLevel(node1.id);var maxLevel2=_this3.hierarchical.getMaxLevel(node2.id);return Math.min(maxLevel1,maxLevel2)};var shiftElementsCloser=function shiftElementsCloser(callback,levels,centerParents){var hier=_this3.hierarchical;for(var i=0;i<levels.length;i++){var level=levels[i];var levelNodes=hier.distributionOrdering[level];if(levelNodes.length>1){for(var j=0;j<levelNodes.length-1;j++){var node1=levelNodes[j];var node2=levelNodes[j+1];if(hier.hasSameParent(node1,node2)&&hier.inSameSubNetwork(node1,node2)){callback(node1,node2,centerParents)}}}}};var branchShiftCallback=function branchShiftCallback(node1,node2){var centerParent=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;var pos1=_this3.direction.getPosition(node1);var pos2=_this3.direction.getPosition(node2);var diffAbs=Math.abs(pos2-pos1);var nodeSpacing=_this3.options.hierarchical.nodeSpacing;if(diffAbs>nodeSpacing){var branchNodes1={};var branchNodes2={};getBranchNodes(node1,branchNodes1);getBranchNodes(node2,branchNodes2);var maxLevel=getCollisionLevel(node1,node2);var branchNodeBoundary1=getBranchBoundary(branchNodes1,maxLevel);var branchNodeBoundary2=getBranchBoundary(branchNodes2,maxLevel);var max1=branchNodeBoundary1[1];var min2=branchNodeBoundary2[0];var minSpace2=branchNodeBoundary2[2];var diffBranch=Math.abs(max1-min2);if(diffBranch>nodeSpacing){var offset=max1-min2+nodeSpacing;if(offset<-minSpace2+nodeSpacing){offset=-minSpace2+nodeSpacing}if(offset<0){_this3._shiftBlock(node2.id,offset);stillShifting=true;if(centerParent===true)_this3._centerParent(node2)}}}};var minimizeEdgeLength=function minimizeEdgeLength(iterations,node){var nodeId=node.id;var allEdges=node.edges;var nodeLevel=_this3.hierarchical.levels[node.id];var C2=_this3.options.hierarchical.levelSeparation*_this3.options.hierarchical.levelSeparation;var referenceNodes={};var aboveEdges=[];for(var i=0;i<allEdges.length;i++){var edge=allEdges[i];if(edge.toId!=edge.fromId){var otherNode=edge.toId==nodeId?edge.from:edge.to;referenceNodes[allEdges[i].id]=otherNode;if(_this3.hierarchical.levels[otherNode.id]<nodeLevel){aboveEdges.push(edge)}}}var getFx=function getFx(point,edges){var sum=0;for(var _i2=0;_i2<edges.length;_i2++){if(referenceNodes[edges[_i2].id]!==undefined){var a=_this3.direction.getPosition(referenceNodes[edges[_i2].id])-point;sum+=a/Math.sqrt(a*a+C2)}}return sum};var getDFx=function getDFx(point,edges){var sum=0;for(var _i3=0;_i3<edges.length;_i3++){if(referenceNodes[edges[_i3].id]!==undefined){var a=_this3.direction.getPosition(referenceNodes[edges[_i3].id])-point;sum-=C2*Math.pow(a*a+C2,-1.5)}}return sum};var getGuess=function getGuess(iterations,edges){var guess=_this3.direction.getPosition(node);var guessMap={};for(var _i4=0;_i4<iterations;_i4++){var fx=getFx(guess,edges);var dfx=getDFx(guess,edges);var limit=40;var ratio=Math.max(-limit,Math.min(limit,Math.round(fx/dfx)));guess=guess-ratio;if(guessMap[guess]!==undefined){break}guessMap[guess]=_i4}return guess};var moveBranch=function moveBranch(guess){var nodePosition=_this3.direction.getPosition(node);if(branches[node.id]===undefined){var branchNodes={};getBranchNodes(node,branchNodes);branches[node.id]=branchNodes}var branchBoundary=getBranchBoundary(branches[node.id]);var minSpaceBranch=branchBoundary[2];var maxSpaceBranch=branchBoundary[3];var diff=guess-nodePosition;var branchOffset=0;if(diff>0){branchOffset=Math.min(diff,maxSpaceBranch-_this3.options.hierarchical.nodeSpacing)}else if(diff<0){branchOffset=-Math.min(-diff,minSpaceBranch-_this3.options.hierarchical.nodeSpacing)}if(branchOffset!=0){_this3._shiftBlock(node.id,branchOffset);stillShifting=true}};var moveNode=function moveNode(guess){var nodePosition=_this3.direction.getPosition(node);var _getSpaceAroundNode4=_this3._getSpaceAroundNode(node),_getSpaceAroundNode5=(0,_slicedToArray3[\"default\"])(_getSpaceAroundNode4,2),minSpace=_getSpaceAroundNode5[0],maxSpace=_getSpaceAroundNode5[1];var diff=guess-nodePosition;var newPosition=nodePosition;if(diff>0){newPosition=Math.min(nodePosition+(maxSpace-_this3.options.hierarchical.nodeSpacing),guess)}else if(diff<0){newPosition=Math.max(nodePosition-(minSpace-_this3.options.hierarchical.nodeSpacing),guess)}if(newPosition!==nodePosition){_this3.direction.setPosition(node,newPosition);stillShifting=true}};var guess=getGuess(iterations,aboveEdges);moveBranch(guess);guess=getGuess(iterations,allEdges);moveNode(guess)};var minimizeEdgeLengthBottomUp=function minimizeEdgeLengthBottomUp(iterations){var levels=_this3.hierarchical.getLevels();levels=levels.reverse();for(var i=0;i<iterations;i++){stillShifting=false;for(var j=0;j<levels.length;j++){var level=levels[j];var levelNodes=_this3.hierarchical.distributionOrdering[level];for(var k=0;k<levelNodes.length;k++){minimizeEdgeLength(1e3,levelNodes[k])}}if(stillShifting!==true){break}}};var shiftBranchesCloserBottomUp=function shiftBranchesCloserBottomUp(iterations){var levels=_this3.hierarchical.getLevels();levels=levels.reverse();for(var i=0;i<iterations;i++){stillShifting=false;shiftElementsCloser(branchShiftCallback,levels,true);if(stillShifting!==true){break}}};var centerAllParents=function centerAllParents(){for(var nodeId in _this3.body.nodes){if(_this3.body.nodes.hasOwnProperty(nodeId))_this3._centerParent(_this3.body.nodes[nodeId])}};var centerAllParentsBottomUp=function centerAllParentsBottomUp(){var levels=_this3.hierarchical.getLevels()\n;levels=levels.reverse();for(var i=0;i<levels.length;i++){var level=levels[i];var levelNodes=_this3.hierarchical.distributionOrdering[level];for(var j=0;j<levelNodes.length;j++){_this3._centerParent(levelNodes[j])}}};if(this.options.hierarchical.blockShifting===true){shiftBranchesCloserBottomUp(5);centerAllParents()}if(this.options.hierarchical.edgeMinimization===true){minimizeEdgeLengthBottomUp(20)}if(this.options.hierarchical.parentCentralization===true){centerAllParentsBottomUp()}shiftTrees()}},{key:\"_getSpaceAroundNode\",value:function _getSpaceAroundNode(node,map){var useMap=true;if(map===undefined){useMap=false}var level=this.hierarchical.levels[node.id];if(level!==undefined){var index=this.hierarchical.distributionIndex[node.id];var position=this.direction.getPosition(node);var ordering=this.hierarchical.distributionOrdering[level];var minSpace=1e9;var maxSpace=1e9;if(index!==0){var prevNode=ordering[index-1];if(useMap===true&&map[prevNode.id]===undefined||useMap===false){var prevPos=this.direction.getPosition(prevNode);minSpace=position-prevPos}}if(index!=ordering.length-1){var nextNode=ordering[index+1];if(useMap===true&&map[nextNode.id]===undefined||useMap===false){var nextPos=this.direction.getPosition(nextNode);maxSpace=Math.min(maxSpace,nextPos-position)}}return[minSpace,maxSpace]}else{return[0,0]}}},{key:\"_centerParent\",value:function _centerParent(node){if(this.hierarchical.parentReference[node.id]){var parents=this.hierarchical.parentReference[node.id];for(var i=0;i<parents.length;i++){var parentId=parents[i];var parentNode=this.body.nodes[parentId];var children=this.hierarchical.childrenReference[parentId];if(children!==undefined){var newPosition=this._getCenterPosition(children);var position=this.direction.getPosition(parentNode);var _getSpaceAroundNode6=this._getSpaceAroundNode(parentNode),_getSpaceAroundNode7=(0,_slicedToArray3[\"default\"])(_getSpaceAroundNode6,2),minSpace=_getSpaceAroundNode7[0],maxSpace=_getSpaceAroundNode7[1];var diff=position-newPosition;if(diff<0&&Math.abs(diff)<maxSpace-this.options.hierarchical.nodeSpacing||diff>0&&Math.abs(diff)<minSpace-this.options.hierarchical.nodeSpacing){this.direction.setPosition(parentNode,newPosition)}}}}}},{key:\"_placeNodesByHierarchy\",value:function _placeNodesByHierarchy(distribution){this.positionedNodes={};for(var level in distribution){if(distribution.hasOwnProperty(level)){var nodeArray=(0,_keys2[\"default\"])(distribution[level]);nodeArray=this._indexArrayToNodes(nodeArray);this.direction.sort(nodeArray);var handledNodeCount=0;for(var i=0;i<nodeArray.length;i++){var node=nodeArray[i];if(this.positionedNodes[node.id]===undefined){var spacing=this.options.hierarchical.nodeSpacing;var pos=spacing*handledNodeCount;if(handledNodeCount>0){pos=this.direction.getPosition(nodeArray[i-1])+spacing}this.direction.setPosition(node,pos,level);this._validatePositionAndContinue(node,level,pos);handledNodeCount++}}}}}},{key:\"_placeBranchNodes\",value:function _placeBranchNodes(parentId,parentLevel){var childRef=this.hierarchical.childrenReference[parentId];if(childRef===undefined){return}var childNodes=[];for(var i=0;i<childRef.length;i++){childNodes.push(this.body.nodes[childRef[i]])}this.direction.sort(childNodes);for(var _i5=0;_i5<childNodes.length;_i5++){var childNode=childNodes[_i5];var childNodeLevel=this.hierarchical.levels[childNode.id];if(childNodeLevel>parentLevel&&this.positionedNodes[childNode.id]===undefined){var spacing=this.options.hierarchical.nodeSpacing;var pos=void 0;if(_i5===0){pos=this.direction.getPosition(this.body.nodes[parentId])}else{pos=this.direction.getPosition(childNodes[_i5-1])+spacing}this.direction.setPosition(childNode,pos,childNodeLevel);this._validatePositionAndContinue(childNode,childNodeLevel,pos)}else{return}}var center=this._getCenterPosition(childNodes);this.direction.setPosition(this.body.nodes[parentId],center,parentLevel)}},{key:\"_validatePositionAndContinue\",value:function _validatePositionAndContinue(node,level,pos){if(!this.hierarchical.isTree)return;if(this.lastNodeOnLevel[level]!==undefined){var previousPos=this.direction.getPosition(this.body.nodes[this.lastNodeOnLevel[level]]);if(pos-previousPos<this.options.hierarchical.nodeSpacing){var diff=previousPos+this.options.hierarchical.nodeSpacing-pos;var sharedParent=this._findCommonParent(this.lastNodeOnLevel[level],node.id);this._shiftBlock(sharedParent.withChild,diff)}}this.lastNodeOnLevel[level]=node.id;this.positionedNodes[node.id]=true;this._placeBranchNodes(node.id,level)}},{key:\"_indexArrayToNodes\",value:function _indexArrayToNodes(idArray){var array=[];for(var i=0;i<idArray.length;i++){array.push(this.body.nodes[idArray[i]])}return array}},{key:\"_getDistribution\",value:function _getDistribution(){var distribution={};var nodeId=void 0,node=void 0;for(nodeId in this.body.nodes){if(this.body.nodes.hasOwnProperty(nodeId)){node=this.body.nodes[nodeId];var level=this.hierarchical.levels[nodeId]===undefined?0:this.hierarchical.levels[nodeId];this.direction.fix(node,level);if(distribution[level]===undefined){distribution[level]={}}distribution[level][nodeId]=node}}return distribution}},{key:\"_getActiveEdges\",value:function _getActiveEdges(node){var _this4=this;var result=[];util.forEach(node.edges,function(edge){if(_this4.body.edgeIndices.indexOf(edge.id)!==-1){result.push(edge)}});return result}},{key:\"_getHubSizes\",value:function _getHubSizes(){var _this5=this;var hubSizes={};var nodeIds=this.body.nodeIndices;util.forEach(nodeIds,function(nodeId){var node=_this5.body.nodes[nodeId];var hubSize=_this5._getActiveEdges(node).length;hubSizes[hubSize]=true});var result=[];util.forEach(hubSizes,function(size){result.push(Number(size))});result.sort(function(a,b){return b-a});return result}},{key:\"_determineLevelsByHubsize\",value:function _determineLevelsByHubsize(){var _this6=this;var levelDownstream=function levelDownstream(nodeA,nodeB){_this6.hierarchical.levelDownstream(nodeA,nodeB)};var hubSizes=this._getHubSizes();var _loop=function _loop(i){var hubSize=hubSizes[i];if(hubSize===0)return\"break\";util.forEach(_this6.body.nodeIndices,function(nodeId){var node=_this6.body.nodes[nodeId];if(hubSize===_this6._getActiveEdges(node).length){_this6._crawlNetwork(levelDownstream,nodeId)}})};for(var i=0;i<hubSizes.length;++i){var _ret=_loop(i);if(_ret===\"break\")break}}},{key:\"_determineLevelsCustomCallback\",value:function _determineLevelsCustomCallback(){var _this7=this;var minLevel=1e5;var customCallback=function customCallback(nodeA,nodeB,edge){};var levelByDirection=function levelByDirection(nodeA,nodeB,edge){var levelA=_this7.hierarchical.levels[nodeA.id];if(levelA===undefined){levelA=_this7.hierarchical.levels[nodeA.id]=minLevel}var diff=customCallback(NetworkUtil.cloneOptions(nodeA,\"node\"),NetworkUtil.cloneOptions(nodeB,\"node\"),NetworkUtil.cloneOptions(edge,\"edge\"));_this7.hierarchical.levels[nodeB.id]=levelA+diff};this._crawlNetwork(levelByDirection);this.hierarchical.setMinLevelToZero(this.body.nodes)}},{key:\"_determineLevelsDirected\",value:function _determineLevelsDirected(){var _this8=this;var minLevel=1e4;var isBidirectional=function isBidirectional(edge){util.forEach(_this8.body.edges,function(otherEdge){if(otherEdge.toId===edge.fromId&&otherEdge.fromId===edge.toId){return true}});return false};var levelByDirection=function levelByDirection(nodeA,nodeB,edge){var levelA=_this8.hierarchical.levels[nodeA.id];var levelB=_this8.hierarchical.levels[nodeB.id];if(isBidirectional(edge)&&levelA!==undefined&&levelB!==undefined){return}if(levelA===undefined){levelA=_this8.hierarchical.levels[nodeA.id]=minLevel}if(edge.toId==nodeB.id){_this8.hierarchical.levels[nodeB.id]=levelA+1}else{_this8.hierarchical.levels[nodeB.id]=levelA-1}};this._crawlNetwork(levelByDirection);this.hierarchical.setMinLevelToZero(this.body.nodes)}},{key:\"_generateMap\",value:function _generateMap(){var _this9=this;var fillInRelations=function fillInRelations(parentNode,childNode){if(_this9.hierarchical.levels[childNode.id]>_this9.hierarchical.levels[parentNode.id]){_this9.hierarchical.addRelation(parentNode.id,childNode.id)}};this._crawlNetwork(fillInRelations);this.hierarchical.checkIfTree()}},{key:\"_crawlNetwork\",value:function _crawlNetwork(){var _this10=this;var callback=arguments.length>0&&arguments[0]!==undefined?arguments[0]:function(){};var startingNodeId=arguments[1];var progress={};var crawler=function crawler(node,tree){if(progress[node.id]===undefined){_this10.hierarchical.setTreeIndex(node,tree);progress[node.id]=true;var childNode=void 0;var edges=_this10._getActiveEdges(node);for(var i=0;i<edges.length;i++){var edge=edges[i];if(edge.connected===true){if(edge.toId==node.id){childNode=edge.from}else{childNode=edge.to}if(node.id!=childNode.id){callback(node,childNode,edge);crawler(childNode,tree)}}}}};if(startingNodeId===undefined){var treeIndex=0;for(var i=0;i<this.body.nodeIndices.length;i++){var nodeId=this.body.nodeIndices[i];if(progress[nodeId]===undefined){var node=this.body.nodes[nodeId];crawler(node,treeIndex);treeIndex+=1}}}else{var _node2=this.body.nodes[startingNodeId];if(_node2===undefined){console.error(\"Node not found:\",startingNodeId);return}crawler(_node2)}}},{key:\"_shiftBlock\",value:function _shiftBlock(parentId,diff){var _this11=this;var progress={};var shifter=function shifter(parentId){if(progress[parentId]){return}progress[parentId]=true;_this11.direction.shift(parentId,diff);var childRef=_this11.hierarchical.childrenReference[parentId];if(childRef!==undefined){for(var i=0;i<childRef.length;i++){shifter(childRef[i])}}};shifter(parentId)}},{key:\"_findCommonParent\",value:function _findCommonParent(childA,childB){var _this12=this;var parents={};var iterateParents=function iterateParents(parents,child){var parentRef=_this12.hierarchical.parentReference[child];if(parentRef!==undefined){for(var i=0;i<parentRef.length;i++){var parent=parentRef[i];parents[parent]=true;iterateParents(parents,parent)}}};var findParent=function findParent(parents,child){var parentRef=_this12.hierarchical.parentReference[child];if(parentRef!==undefined){for(var i=0;i<parentRef.length;i++){var parent=parentRef[i];if(parents[parent]!==undefined){return{foundParent:parent,withChild:child}}var branch=findParent(parents,parent);if(branch.foundParent!==null){return branch}}}return{foundParent:null,withChild:child}};iterateParents(parents,childA);return findParent(parents,childB)}},{key:\"setDirectionStrategy\",value:function setDirectionStrategy(){var isVertical=this.options.hierarchical.direction===\"UD\"||this.options.hierarchical.direction===\"DU\";if(isVertical){this.direction=new VerticalStrategy(this)}else{this.direction=new HorizontalStrategy(this)}}},{key:\"_getCenterPosition\",value:function _getCenterPosition(childNodes){var minPos=1e9;var maxPos=-1e9;for(var i=0;i<childNodes.length;i++){var childNode=void 0;if(childNodes[i].id!==undefined){childNode=childNodes[i]}else{var childNodeId=childNodes[i];childNode=this.body.nodes[childNodeId]}var position=this.direction.getPosition(childNode);minPos=Math.min(minPos,position);maxPos=Math.max(maxPos,position)}return.5*(minPos+maxPos)}}]);return LayoutEngine}();exports[\"default\"]=LayoutEngine},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});exports.VerticalStrategy=exports.HorizontalStrategy=undefined;var _getPrototypeOf=__webpack_require__(3);var _getPrototypeOf2=_interopRequireDefault(_getPrototypeOf);var _possibleConstructorReturn2=__webpack_require__(4);var _possibleConstructorReturn3=_interopRequireDefault(_possibleConstructorReturn2);var _inherits2=__webpack_require__(5);var _inherits3=_interopRequireDefault(_inherits2);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var DirectionInterface=function(){function DirectionInterface(){(0,_classCallCheck3[\"default\"])(this,DirectionInterface)}(0,_createClass3[\"default\"])(DirectionInterface,[{key:\"abstract\",value:function abstract(){throw new Error(\"Can't instantiate abstract class!\")}},{key:\"fake_use\",value:function fake_use(){}},{key:\"curveType\",value:function curveType(){return this.abstract()}},{key:\"getPosition\",value:function getPosition(node){this.fake_use(node);return this.abstract()}},{key:\"setPosition\",value:function setPosition(node,position){var level=arguments.length>2&&arguments[2]!==undefined?arguments[2]:undefined;this.fake_use(node,position,level);this.abstract()}},{key:\"getTreeSize\",value:function getTreeSize(index){this.fake_use(index);return this.abstract()}},{key:\"sort\",value:function sort(nodeArray){this.fake_use(nodeArray);this.abstract()}},{key:\"fix\",value:function fix(node,level){this.fake_use(node,level);this.abstract()}},{key:\"shift\",value:function shift(nodeId,diff){this.fake_use(nodeId,diff);this.abstract()}}]);return DirectionInterface}();var VerticalStrategy=function(_DirectionInterface){(0,_inherits3[\"default\"])(VerticalStrategy,_DirectionInterface);function VerticalStrategy(layout){(0,_classCallCheck3[\"default\"])(this,VerticalStrategy);var _this=(0,_possibleConstructorReturn3[\"default\"])(this,(VerticalStrategy.__proto__||(0,_getPrototypeOf2[\"default\"])(VerticalStrategy)).call(this));_this.layout=layout;return _this}(0,_createClass3[\"default\"])(VerticalStrategy,[{key:\"curveType\",value:function curveType(){return\"horizontal\"}},{key:\"getPosition\",value:function getPosition(node){return node.x}},{key:\"setPosition\",value:function setPosition(node,position){var level=arguments.length>2&&arguments[2]!==undefined?arguments[2]:undefined;if(level!==undefined){this.layout.hierarchical.addToOrdering(node,level)}node.x=position}},{key:\"getTreeSize\",value:function getTreeSize(index){var res=this.layout.hierarchical.getTreeSize(this.layout.body.nodes,index);return{min:res.min_x,max:res.max_x}}},{key:\"sort\",value:function sort(nodeArray){nodeArray.sort(function(a,b){if(a.x===undefined||b.x===undefined)return 0;return a.x-b.x})}},{key:\"fix\",value:function fix(node,level){node.y=this.layout.options.hierarchical.levelSeparation*level;node.options.fixed.y=true}},{key:\"shift\",value:function shift(nodeId,diff){this.layout.body.nodes[nodeId].x+=diff}}]);return VerticalStrategy}(DirectionInterface);var HorizontalStrategy=function(_DirectionInterface2){(0,_inherits3[\"default\"])(HorizontalStrategy,_DirectionInterface2);function HorizontalStrategy(layout){(0,_classCallCheck3[\"default\"])(this,HorizontalStrategy);var _this2=(0,_possibleConstructorReturn3[\"default\"])(this,(HorizontalStrategy.__proto__||(0,_getPrototypeOf2[\"default\"])(HorizontalStrategy)).call(this));_this2.layout=layout;return _this2}(0,_createClass3[\"default\"])(HorizontalStrategy,[{key:\"curveType\",value:function curveType(){return\"vertical\"}},{key:\"getPosition\",value:function getPosition(node){return node.y}},{key:\"setPosition\",value:function setPosition(node,position){var level=arguments.length>2&&arguments[2]!==undefined?arguments[2]:undefined;if(level!==undefined){this.layout.hierarchical.addToOrdering(node,level)}node.y=position}},{key:\"getTreeSize\",value:function getTreeSize(index){var res=this.layout.hierarchical.getTreeSize(this.layout.body.nodes,index);return{min:res.min_y,max:res.max_y}}},{key:\"sort\",value:function sort(nodeArray){nodeArray.sort(function(a,b){if(a.y===undefined||b.y===undefined)return 0;return a.y-b.y})}},{key:\"fix\",value:function fix(node,level){node.x=this.layout.options.hierarchical.levelSeparation*level;node.options.fixed.x=true}},{key:\"shift\",value:function shift(nodeId,diff){this.layout.body.nodes[nodeId].y+=diff}}]);return HorizontalStrategy}(DirectionInterface);exports.HorizontalStrategy=HorizontalStrategy;exports.VerticalStrategy=VerticalStrategy},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _keys=__webpack_require__(8);var _keys2=_interopRequireDefault(_keys);var _stringify=__webpack_require__(19);var _stringify2=_interopRequireDefault(_stringify);var _typeof2=__webpack_require__(6);var _typeof3=_interopRequireDefault(_typeof2);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var util=__webpack_require__(2);var Hammer=__webpack_require__(10);var hammerUtil=__webpack_require__(37);var ManipulationSystem=function(){function ManipulationSystem(body,canvas,selectionHandler){var _this=this;(0,_classCallCheck3[\"default\"])(this,ManipulationSystem);this.body=body;this.canvas=canvas;this.selectionHandler=selectionHandler;this.editMode=false;this.manipulationDiv=undefined;this.editModeDiv=undefined;this.closeDiv=undefined;this.manipulationHammers=[];this.temporaryUIFunctions={};this.temporaryEventFunctions=[];this.touchTime=0;this.temporaryIds={nodes:[],edges:[]};this.guiEnabled=false;this.inMode=false;this.selectedControlNode=undefined;this.options={};this.defaultOptions={enabled:false,initiallyActive:false,addNode:true,addEdge:true,editNode:undefined,editEdge:true,deleteNode:true,deleteEdge:true,controlNodeStyle:{shape:\"dot\",size:6,color:{background:\"#ff0000\",border:\"#3c3c3c\",highlight:{background:\"#07f968\",border:\"#3c3c3c\"}},borderWidth:2,borderWidthSelected:2}};util.extend(this.options,this.defaultOptions);this.body.emitter.on(\"destroy\",function(){_this._clean()});this.body.emitter.on(\"_dataChanged\",this._restore.bind(this));this.body.emitter.on(\"_resetData\",this._restore.bind(this))}(0,_createClass3[\"default\"])(ManipulationSystem,[{key:\"_restore\",value:function _restore(){if(this.inMode!==false){if(this.options.initiallyActive===true){this.enableEditMode()}else{this.disableEditMode()}}}},{key:\"setOptions\",value:function setOptions(options,allOptions,globalOptions){if(allOptions!==undefined){if(allOptions.locale!==undefined){this.options.locale=allOptions.locale}else{this.options.locale=globalOptions.locale}if(allOptions.locales!==undefined){this.options.locales=allOptions.locales}else{this.options.locales=globalOptions.locales}}if(options!==undefined){if(typeof options===\"boolean\"){this.options.enabled=options}else{this.options.enabled=true;util.deepExtend(this.options,options)}if(this.options.initiallyActive===true){this.editMode=true}this._setup()}}},{key:\"toggleEditMode\",value:function toggleEditMode(){if(this.editMode===true){this.disableEditMode()}else{this.enableEditMode()}}},{key:\"enableEditMode\",value:function enableEditMode(){this.editMode=true;this._clean();if(this.guiEnabled===true){this.manipulationDiv.style.display=\"block\";this.closeDiv.style.display=\"block\";this.editModeDiv.style.display=\"none\";this.showManipulatorToolbar()}}},{key:\"disableEditMode\",value:function disableEditMode(){this.editMode=false;this._clean();if(this.guiEnabled===true){this.manipulationDiv.style.display=\"none\";this.closeDiv.style.display=\"none\";this.editModeDiv.style.display=\"block\";this._createEditButton()}}},{key:\"showManipulatorToolbar\",value:function showManipulatorToolbar(){this._clean();this.manipulationDOM={};if(this.guiEnabled===true){this.editMode=true;this.manipulationDiv.style.display=\"block\";this.closeDiv.style.display=\"block\";var selectedNodeCount=this.selectionHandler._getSelectedNodeCount();var selectedEdgeCount=this.selectionHandler._getSelectedEdgeCount();var selectedTotalCount=selectedNodeCount+selectedEdgeCount;var locale=this.options.locales[this.options.locale];var needSeperator=false;if(this.options.addNode!==false){this._createAddNodeButton(locale);needSeperator=true}if(this.options.addEdge!==false){if(needSeperator===true){this._createSeperator(1)}else{needSeperator=true}this._createAddEdgeButton(locale)}if(selectedNodeCount===1&&typeof this.options.editNode===\"function\"){if(needSeperator===true){this._createSeperator(2)}else{needSeperator=true}this._createEditNodeButton(locale)}else if(selectedEdgeCount===1&&selectedNodeCount===0&&this.options.editEdge!==false){if(needSeperator===true){this._createSeperator(3)}else{needSeperator=true}this._createEditEdgeButton(locale)}if(selectedTotalCount!==0){if(selectedNodeCount>0&&this.options.deleteNode!==false){if(needSeperator===true){this._createSeperator(4)}this._createDeleteButton(locale)}else if(selectedNodeCount===0&&this.options.deleteEdge!==false){if(needSeperator===true){this._createSeperator(4)}this._createDeleteButton(locale)}}this._bindHammerToDiv(this.closeDiv,this.toggleEditMode.bind(this));this._temporaryBindEvent(\"select\",this.showManipulatorToolbar.bind(this))}this.body.emitter.emit(\"_redraw\")}},{key:\"addNodeMode\",value:function addNodeMode(){if(this.editMode!==true){this.enableEditMode()}this._clean();this.inMode=\"addNode\";if(this.guiEnabled===true){var locale=this.options.locales[this.options.locale];this.manipulationDOM={};this._createBackButton(locale);this._createSeperator();this._createDescription(locale[\"addDescription\"]||this.options.locales[\"en\"][\"addDescription\"]);this._bindHammerToDiv(this.closeDiv,this.toggleEditMode.bind(this))}this._temporaryBindEvent(\"click\",this._performAddNode.bind(this))}},{key:\"editNode\",value:function editNode(){var _this2=this;if(this.editMode!==true){this.enableEditMode()}this._clean();var node=this.selectionHandler._getSelectedNode();if(node!==undefined){this.inMode=\"editNode\";if(typeof this.options.editNode===\"function\"){if(node.isCluster!==true){var data=util.deepExtend({},node.options,false);data.x=node.x;data.y=node.y;if(this.options.editNode.length===2){this.options.editNode(data,function(finalizedData){if(finalizedData!==null&&finalizedData!==undefined&&_this2.inMode===\"editNode\"){_this2.body.data.nodes.getDataSet().update(finalizedData)}_this2.showManipulatorToolbar()})}else{throw new Error(\"The function for edit does not support two arguments (data, callback)\")}}else{alert(this.options.locales[this.options.locale][\"editClusterError\"]||this.options.locales[\"en\"][\"editClusterError\"])}}else{throw new Error(\"No function has been configured to handle the editing of nodes.\")}}else{this.showManipulatorToolbar()}}},{key:\"addEdgeMode\",value:function addEdgeMode(){if(this.editMode!==true){this.enableEditMode()}this._clean();this.inMode=\"addEdge\";if(this.guiEnabled===true){var locale=this.options.locales[this.options.locale];this.manipulationDOM={};this._createBackButton(locale);this._createSeperator();this._createDescription(locale[\"edgeDescription\"]||this.options.locales[\"en\"][\"edgeDescription\"]);this._bindHammerToDiv(this.closeDiv,this.toggleEditMode.bind(this))}this._temporaryBindUI(\"onTouch\",this._handleConnect.bind(this));this._temporaryBindUI(\"onDragEnd\",this._finishConnect.bind(this));this._temporaryBindUI(\"onDrag\",this._dragControlNode.bind(this));this._temporaryBindUI(\"onRelease\",this._finishConnect.bind(this));this._temporaryBindUI(\"onDragStart\",this._dragStartEdge.bind(this));this._temporaryBindUI(\"onHold\",function(){})}},{key:\"editEdgeMode\",value:function editEdgeMode(){if(this.editMode!==true){this.enableEditMode()}this._clean();this.inMode=\"editEdge\";if((0,_typeof3[\"default\"])(this.options.editEdge)===\"object\"&&typeof this.options.editEdge.editWithoutDrag===\"function\"){this.edgeBeingEditedId=this.selectionHandler.getSelectedEdges()[0];if(this.edgeBeingEditedId!==undefined){var edge=this.body.edges[this.edgeBeingEditedId];this._performEditEdge(edge.from,edge.to);return}}if(this.guiEnabled===true){var locale=this.options.locales[this.options.locale];this.manipulationDOM={};this._createBackButton(locale);this._createSeperator();this._createDescription(locale[\"editEdgeDescription\"]||this.options.locales[\"en\"][\"editEdgeDescription\"]);this._bindHammerToDiv(this.closeDiv,this.toggleEditMode.bind(this))}this.edgeBeingEditedId=this.selectionHandler.getSelectedEdges()[0];if(this.edgeBeingEditedId!==undefined){var _edge=this.body.edges[this.edgeBeingEditedId];var controlNodeFrom=this._getNewTargetNode(_edge.from.x,_edge.from.y);var controlNodeTo=this._getNewTargetNode(_edge.to.x,_edge.to.y);this.temporaryIds.nodes.push(controlNodeFrom.id);this.temporaryIds.nodes.push(controlNodeTo.id);this.body.nodes[controlNodeFrom.id]=controlNodeFrom;this.body.nodeIndices.push(controlNodeFrom.id);this.body.nodes[controlNodeTo.id]=controlNodeTo;this.body.nodeIndices.push(controlNodeTo.id);this._temporaryBindUI(\"onTouch\",this._controlNodeTouch.bind(this));this._temporaryBindUI(\"onTap\",function(){});this._temporaryBindUI(\"onHold\",function(){});this._temporaryBindUI(\"onDragStart\",this._controlNodeDragStart.bind(this));this._temporaryBindUI(\"onDrag\",this._controlNodeDrag.bind(this));this._temporaryBindUI(\"onDragEnd\",this._controlNodeDragEnd.bind(this));this._temporaryBindUI(\"onMouseMove\",function(){});this._temporaryBindEvent(\"beforeDrawing\",function(ctx){var positions=_edge.edgeType.findBorderPositions(ctx);if(controlNodeFrom.selected===false){controlNodeFrom.x=positions.from.x;controlNodeFrom.y=positions.from.y}if(controlNodeTo.selected===false){controlNodeTo.x=positions.to.x;controlNodeTo.y=positions.to.y}});this.body.emitter.emit(\"_redraw\")}else{this.showManipulatorToolbar()}}},{key:\"deleteSelected\",value:function deleteSelected(){var _this3=this;if(this.editMode!==true){this.enableEditMode()}this._clean();this.inMode=\"delete\";var selectedNodes=this.selectionHandler.getSelectedNodes();var selectedEdges=this.selectionHandler.getSelectedEdges();var deleteFunction=undefined;if(selectedNodes.length>0){for(var i=0;i<selectedNodes.length;i++){if(this.body.nodes[selectedNodes[i]].isCluster===true){alert(this.options.locales[this.options.locale][\"deleteClusterError\"]||this.options.locales[\"en\"][\"deleteClusterError\"]);return}}if(typeof this.options.deleteNode===\"function\"){deleteFunction=this.options.deleteNode}}else if(selectedEdges.length>0){if(typeof this.options.deleteEdge===\"function\"){deleteFunction=this.options.deleteEdge}}if(typeof deleteFunction===\"function\"){var data={nodes:selectedNodes,edges:selectedEdges};if(deleteFunction.length===2){deleteFunction(data,function(finalizedData){if(finalizedData!==null&&finalizedData!==undefined&&_this3.inMode===\"delete\"){_this3.body.data.edges.getDataSet().remove(finalizedData.edges);_this3.body.data.nodes.getDataSet().remove(finalizedData.nodes);_this3.body.emitter.emit(\"startSimulation\");_this3.showManipulatorToolbar()}else{_this3.body.emitter.emit(\"startSimulation\");_this3.showManipulatorToolbar()}})}else{throw new Error(\"The function for delete does not support two arguments (data, callback)\")}}else{this.body.data.edges.getDataSet().remove(selectedEdges);this.body.data.nodes.getDataSet().remove(selectedNodes);this.body.emitter.emit(\"startSimulation\");this.showManipulatorToolbar()}}},{key:\"_setup\",value:function _setup(){if(this.options.enabled===true){this.guiEnabled=true;this._createWrappers();if(this.editMode===false){this._createEditButton()}else{this.showManipulatorToolbar()}}else{this._removeManipulationDOM();this.guiEnabled=false}}},{key:\"_createWrappers\",value:function _createWrappers(){if(this.manipulationDiv===undefined){this.manipulationDiv=document.createElement(\"div\");this.manipulationDiv.className=\"vis-manipulation\";if(this.editMode===true){this.manipulationDiv.style.display=\"block\"}else{this.manipulationDiv.style.display=\"none\"}this.canvas.frame.appendChild(this.manipulationDiv)}if(this.editModeDiv===undefined){this.editModeDiv=document.createElement(\"div\");this.editModeDiv.className=\"vis-edit-mode\";if(this.editMode===true){this.editModeDiv.style.display=\"none\"}else{this.editModeDiv.style.display=\"block\"}this.canvas.frame.appendChild(this.editModeDiv)}if(this.closeDiv===undefined){this.closeDiv=document.createElement(\"div\");this.closeDiv.className=\"vis-close\";this.closeDiv.style.display=this.manipulationDiv.style.display;this.canvas.frame.appendChild(this.closeDiv)}}},{key:\"_getNewTargetNode\",value:function _getNewTargetNode(x,y){var controlNodeStyle=util.deepExtend({},this.options.controlNodeStyle);controlNodeStyle.id=\"targetNode\"+util.randomUUID();controlNodeStyle.hidden=false;controlNodeStyle.physics=false;controlNodeStyle.x=x;controlNodeStyle.y=y;var node=this.body.functions.createNode(controlNodeStyle);node.shape.boundingBox={left:x,right:x,top:y,bottom:y};return node}},{key:\"_createEditButton\",value:function _createEditButton(){this._clean();this.manipulationDOM={};util.recursiveDOMDelete(this.editModeDiv);var locale=this.options.locales[this.options.locale];var button=this._createButton(\"editMode\",\"vis-button vis-edit vis-edit-mode\",locale[\"edit\"]||this.options.locales[\"en\"][\"edit\"]);this.editModeDiv.appendChild(button);this._bindHammerToDiv(button,this.toggleEditMode.bind(this))}},{key:\"_clean\",value:function _clean(){this.inMode=false;if(this.guiEnabled===true){util.recursiveDOMDelete(this.editModeDiv);util.recursiveDOMDelete(this.manipulationDiv);this._cleanManipulatorHammers()}this._cleanupTemporaryNodesAndEdges();this._unbindTemporaryUIs();this._unbindTemporaryEvents();this.body.emitter.emit(\"restorePhysics\")}},{key:\"_cleanManipulatorHammers\",value:function _cleanManipulatorHammers(){if(this.manipulationHammers.length!=0){for(var i=0;i<this.manipulationHammers.length;i++){this.manipulationHammers[i].destroy()}this.manipulationHammers=[]}}},{key:\"_removeManipulationDOM\",value:function _removeManipulationDOM(){this._clean();util.recursiveDOMDelete(this.manipulationDiv);util.recursiveDOMDelete(this.editModeDiv);util.recursiveDOMDelete(this.closeDiv);if(this.manipulationDiv){this.canvas.frame.removeChild(this.manipulationDiv)}if(this.editModeDiv){this.canvas.frame.removeChild(this.editModeDiv)}if(this.closeDiv){this.canvas.frame.removeChild(this.closeDiv)}this.manipulationDiv=undefined;this.editModeDiv=undefined;this.closeDiv=undefined}},{key:\"_createSeperator\",value:function _createSeperator(){var index=arguments.length>0&&arguments[0]!==undefined?arguments[0]:1;this.manipulationDOM[\"seperatorLineDiv\"+index]=document.createElement(\"div\");this.manipulationDOM[\"seperatorLineDiv\"+index].className=\"vis-separator-line\";this.manipulationDiv.appendChild(this.manipulationDOM[\"seperatorLineDiv\"+index])}},{key:\"_createAddNodeButton\",value:function _createAddNodeButton(locale){var button=this._createButton(\"addNode\",\"vis-button vis-add\",locale[\"addNode\"]||this.options.locales[\"en\"][\"addNode\"]);this.manipulationDiv.appendChild(button);this._bindHammerToDiv(button,this.addNodeMode.bind(this))}},{key:\"_createAddEdgeButton\",value:function _createAddEdgeButton(locale){var button=this._createButton(\"addEdge\",\"vis-button vis-connect\",locale[\"addEdge\"]||this.options.locales[\"en\"][\"addEdge\"]);this.manipulationDiv.appendChild(button);this._bindHammerToDiv(button,this.addEdgeMode.bind(this))}},{key:\"_createEditNodeButton\",value:function _createEditNodeButton(locale){var button=this._createButton(\"editNode\",\"vis-button vis-edit\",locale[\"editNode\"]||this.options.locales[\"en\"][\"editNode\"]);this.manipulationDiv.appendChild(button);this._bindHammerToDiv(button,this.editNode.bind(this))}},{key:\"_createEditEdgeButton\",value:function _createEditEdgeButton(locale){var button=this._createButton(\"editEdge\",\"vis-button vis-edit\",locale[\"editEdge\"]||this.options.locales[\"en\"][\"editEdge\"]);this.manipulationDiv.appendChild(button);this._bindHammerToDiv(button,this.editEdgeMode.bind(this))}},{key:\"_createDeleteButton\",value:function _createDeleteButton(locale){var deleteBtnClass;if(this.options.rtl){deleteBtnClass=\"vis-button vis-delete-rtl\"}else{deleteBtnClass=\"vis-button vis-delete\"}var button=this._createButton(\"delete\",deleteBtnClass,locale[\"del\"]||this.options.locales[\"en\"][\"del\"]);this.manipulationDiv.appendChild(button);this._bindHammerToDiv(button,this.deleteSelected.bind(this))}},{key:\"_createBackButton\",value:function _createBackButton(locale){\nvar button=this._createButton(\"back\",\"vis-button vis-back\",locale[\"back\"]||this.options.locales[\"en\"][\"back\"]);this.manipulationDiv.appendChild(button);this._bindHammerToDiv(button,this.showManipulatorToolbar.bind(this))}},{key:\"_createButton\",value:function _createButton(id,className,label){var labelClassName=arguments.length>3&&arguments[3]!==undefined?arguments[3]:\"vis-label\";this.manipulationDOM[id+\"Div\"]=document.createElement(\"div\");this.manipulationDOM[id+\"Div\"].className=className;this.manipulationDOM[id+\"Label\"]=document.createElement(\"div\");this.manipulationDOM[id+\"Label\"].className=labelClassName;this.manipulationDOM[id+\"Label\"].innerHTML=label;this.manipulationDOM[id+\"Div\"].appendChild(this.manipulationDOM[id+\"Label\"]);return this.manipulationDOM[id+\"Div\"]}},{key:\"_createDescription\",value:function _createDescription(label){this.manipulationDiv.appendChild(this._createButton(\"description\",\"vis-button vis-none\",label))}},{key:\"_temporaryBindEvent\",value:function _temporaryBindEvent(event,newFunction){this.temporaryEventFunctions.push({event:event,boundFunction:newFunction});this.body.emitter.on(event,newFunction)}},{key:\"_temporaryBindUI\",value:function _temporaryBindUI(UIfunctionName,newFunction){if(this.body.eventListeners[UIfunctionName]!==undefined){this.temporaryUIFunctions[UIfunctionName]=this.body.eventListeners[UIfunctionName];this.body.eventListeners[UIfunctionName]=newFunction}else{throw new Error(\"This UI function does not exist. Typo? You tried: \"+UIfunctionName+\" possible are: \"+(0,_stringify2[\"default\"])((0,_keys2[\"default\"])(this.body.eventListeners)))}}},{key:\"_unbindTemporaryUIs\",value:function _unbindTemporaryUIs(){for(var functionName in this.temporaryUIFunctions){if(this.temporaryUIFunctions.hasOwnProperty(functionName)){this.body.eventListeners[functionName]=this.temporaryUIFunctions[functionName];delete this.temporaryUIFunctions[functionName]}}this.temporaryUIFunctions={}}},{key:\"_unbindTemporaryEvents\",value:function _unbindTemporaryEvents(){for(var i=0;i<this.temporaryEventFunctions.length;i++){var eventName=this.temporaryEventFunctions[i].event;var boundFunction=this.temporaryEventFunctions[i].boundFunction;this.body.emitter.off(eventName,boundFunction)}this.temporaryEventFunctions=[]}},{key:\"_bindHammerToDiv\",value:function _bindHammerToDiv(domElement,boundFunction){var hammer=new Hammer(domElement,{});hammerUtil.onTouch(hammer,boundFunction);this.manipulationHammers.push(hammer)}},{key:\"_cleanupTemporaryNodesAndEdges\",value:function _cleanupTemporaryNodesAndEdges(){for(var i=0;i<this.temporaryIds.edges.length;i++){this.body.edges[this.temporaryIds.edges[i]].disconnect();delete this.body.edges[this.temporaryIds.edges[i]];var indexTempEdge=this.body.edgeIndices.indexOf(this.temporaryIds.edges[i]);if(indexTempEdge!==-1){this.body.edgeIndices.splice(indexTempEdge,1)}}for(var _i=0;_i<this.temporaryIds.nodes.length;_i++){delete this.body.nodes[this.temporaryIds.nodes[_i]];var indexTempNode=this.body.nodeIndices.indexOf(this.temporaryIds.nodes[_i]);if(indexTempNode!==-1){this.body.nodeIndices.splice(indexTempNode,1)}}this.temporaryIds={nodes:[],edges:[]}}},{key:\"_controlNodeTouch\",value:function _controlNodeTouch(event){this.selectionHandler.unselectAll();this.lastTouch=this.body.functions.getPointer(event.center);this.lastTouch.translation=util.extend({},this.body.view.translation)}},{key:\"_controlNodeDragStart\",value:function _controlNodeDragStart(event){var pointer=this.lastTouch;var pointerObj=this.selectionHandler._pointerToPositionObject(pointer);var from=this.body.nodes[this.temporaryIds.nodes[0]];var to=this.body.nodes[this.temporaryIds.nodes[1]];var edge=this.body.edges[this.edgeBeingEditedId];this.selectedControlNode=undefined;var fromSelect=from.isOverlappingWith(pointerObj);var toSelect=to.isOverlappingWith(pointerObj);if(fromSelect===true){this.selectedControlNode=from;edge.edgeType.from=from}else if(toSelect===true){this.selectedControlNode=to;edge.edgeType.to=to}if(this.selectedControlNode!==undefined){this.selectionHandler.selectObject(this.selectedControlNode)}this.body.emitter.emit(\"_redraw\")}},{key:\"_controlNodeDrag\",value:function _controlNodeDrag(event){this.body.emitter.emit(\"disablePhysics\");var pointer=this.body.functions.getPointer(event.center);var pos=this.canvas.DOMtoCanvas(pointer);if(this.selectedControlNode!==undefined){this.selectedControlNode.x=pos.x;this.selectedControlNode.y=pos.y}else{var diffX=pointer.x-this.lastTouch.x;var diffY=pointer.y-this.lastTouch.y;this.body.view.translation={x:this.lastTouch.translation.x+diffX,y:this.lastTouch.translation.y+diffY}}this.body.emitter.emit(\"_redraw\")}},{key:\"_controlNodeDragEnd\",value:function _controlNodeDragEnd(event){var pointer=this.body.functions.getPointer(event.center);var pointerObj=this.selectionHandler._pointerToPositionObject(pointer);var edge=this.body.edges[this.edgeBeingEditedId];if(this.selectedControlNode===undefined){return}this.selectionHandler.unselectAll();var overlappingNodeIds=this.selectionHandler._getAllNodesOverlappingWith(pointerObj);var node=undefined;for(var i=overlappingNodeIds.length-1;i>=0;i--){if(overlappingNodeIds[i]!==this.selectedControlNode.id){node=this.body.nodes[overlappingNodeIds[i]];break}}if(node!==undefined&&this.selectedControlNode!==undefined){if(node.isCluster===true){alert(this.options.locales[this.options.locale][\"createEdgeError\"]||this.options.locales[\"en\"][\"createEdgeError\"])}else{var from=this.body.nodes[this.temporaryIds.nodes[0]];if(this.selectedControlNode.id===from.id){this._performEditEdge(node.id,edge.to.id)}else{this._performEditEdge(edge.from.id,node.id)}}}else{edge.updateEdgeType();this.body.emitter.emit(\"restorePhysics\")}this.body.emitter.emit(\"_redraw\")}},{key:\"_handleConnect\",value:function _handleConnect(event){if((new Date).valueOf()-this.touchTime>100){this.lastTouch=this.body.functions.getPointer(event.center);this.lastTouch.translation=util.extend({},this.body.view.translation);var pointer=this.lastTouch;var node=this.selectionHandler.getNodeAt(pointer);if(node!==undefined){if(node.isCluster===true){alert(this.options.locales[this.options.locale][\"createEdgeError\"]||this.options.locales[\"en\"][\"createEdgeError\"])}else{var targetNode=this._getNewTargetNode(node.x,node.y);this.body.nodes[targetNode.id]=targetNode;this.body.nodeIndices.push(targetNode.id);var connectionEdge=this.body.functions.createEdge({id:\"connectionEdge\"+util.randomUUID(),from:node.id,to:targetNode.id,physics:false,smooth:{enabled:true,type:\"continuous\",roundness:.5}});this.body.edges[connectionEdge.id]=connectionEdge;this.body.edgeIndices.push(connectionEdge.id);this.temporaryIds.nodes.push(targetNode.id);this.temporaryIds.edges.push(connectionEdge.id)}}this.touchTime=(new Date).valueOf()}}},{key:\"_dragControlNode\",value:function _dragControlNode(event){var pointer=this.body.functions.getPointer(event.center);if(this.temporaryIds.nodes[0]!==undefined){var targetNode=this.body.nodes[this.temporaryIds.nodes[0]];targetNode.x=this.canvas._XconvertDOMtoCanvas(pointer.x);targetNode.y=this.canvas._YconvertDOMtoCanvas(pointer.y);this.body.emitter.emit(\"_redraw\")}else{var diffX=pointer.x-this.lastTouch.x;var diffY=pointer.y-this.lastTouch.y;this.body.view.translation={x:this.lastTouch.translation.x+diffX,y:this.lastTouch.translation.y+diffY}}}},{key:\"_finishConnect\",value:function _finishConnect(event){var pointer=this.body.functions.getPointer(event.center);var pointerObj=this.selectionHandler._pointerToPositionObject(pointer);var connectFromId=undefined;if(this.temporaryIds.edges[0]!==undefined){connectFromId=this.body.edges[this.temporaryIds.edges[0]].fromId}var overlappingNodeIds=this.selectionHandler._getAllNodesOverlappingWith(pointerObj);var node=undefined;for(var i=overlappingNodeIds.length-1;i>=0;i--){if(this.temporaryIds.nodes.indexOf(overlappingNodeIds[i])===-1){node=this.body.nodes[overlappingNodeIds[i]];break}}this._cleanupTemporaryNodesAndEdges();if(node!==undefined){if(node.isCluster===true){alert(this.options.locales[this.options.locale][\"createEdgeError\"]||this.options.locales[\"en\"][\"createEdgeError\"])}else{if(this.body.nodes[connectFromId]!==undefined&&this.body.nodes[node.id]!==undefined){this._performAddEdge(connectFromId,node.id)}}}this.body.emitter.emit(\"_redraw\")}},{key:\"_dragStartEdge\",value:function _dragStartEdge(event){var pointer=this.lastTouch;this.selectionHandler._generateClickEvent(\"dragStart\",event,pointer,undefined,true)}},{key:\"_performAddNode\",value:function _performAddNode(clickData){var _this4=this;var defaultData={id:util.randomUUID(),x:clickData.pointer.canvas.x,y:clickData.pointer.canvas.y,label:\"new\"};if(typeof this.options.addNode===\"function\"){if(this.options.addNode.length===2){this.options.addNode(defaultData,function(finalizedData){if(finalizedData!==null&&finalizedData!==undefined&&_this4.inMode===\"addNode\"){_this4.body.data.nodes.getDataSet().add(finalizedData);_this4.showManipulatorToolbar()}})}else{this.showManipulatorToolbar();throw new Error(\"The function for add does not support two arguments (data,callback)\")}}else{this.body.data.nodes.getDataSet().add(defaultData);this.showManipulatorToolbar()}}},{key:\"_performAddEdge\",value:function _performAddEdge(sourceNodeId,targetNodeId){var _this5=this;var defaultData={from:sourceNodeId,to:targetNodeId};if(typeof this.options.addEdge===\"function\"){if(this.options.addEdge.length===2){this.options.addEdge(defaultData,function(finalizedData){if(finalizedData!==null&&finalizedData!==undefined&&_this5.inMode===\"addEdge\"){_this5.body.data.edges.getDataSet().add(finalizedData);_this5.selectionHandler.unselectAll();_this5.showManipulatorToolbar()}})}else{throw new Error(\"The function for connect does not support two arguments (data,callback)\")}}else{this.body.data.edges.getDataSet().add(defaultData);this.selectionHandler.unselectAll();this.showManipulatorToolbar()}}},{key:\"_performEditEdge\",value:function _performEditEdge(sourceNodeId,targetNodeId){var _this6=this;var defaultData={id:this.edgeBeingEditedId,from:sourceNodeId,to:targetNodeId,label:this.body.data.edges._data[this.edgeBeingEditedId].label};var eeFunct=this.options.editEdge;if((typeof eeFunct===\"undefined\"?\"undefined\":(0,_typeof3[\"default\"])(eeFunct))===\"object\"){eeFunct=eeFunct.editWithoutDrag}if(typeof eeFunct===\"function\"){if(eeFunct.length===2){eeFunct(defaultData,function(finalizedData){if(finalizedData===null||finalizedData===undefined||_this6.inMode!==\"editEdge\"){_this6.body.edges[defaultData.id].updateEdgeType();_this6.body.emitter.emit(\"_redraw\");_this6.showManipulatorToolbar()}else{_this6.body.data.edges.getDataSet().update(finalizedData);_this6.selectionHandler.unselectAll();_this6.showManipulatorToolbar()}})}else{throw new Error(\"The function for edit does not support two arguments (data, callback)\")}}else{this.body.data.edges.getDataSet().update(defaultData);this.selectionHandler.unselectAll();this.showManipulatorToolbar()}}}]);return ManipulationSystem}();exports[\"default\"]=ManipulationSystem},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _slicedToArray2=__webpack_require__(30);var _slicedToArray3=_interopRequireDefault(_slicedToArray2);var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);var _FloydWarshall=__webpack_require__(239);var _FloydWarshall2=_interopRequireDefault(_FloydWarshall);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var KamadaKawai=function(){function KamadaKawai(body,edgeLength,edgeStrength){(0,_classCallCheck3[\"default\"])(this,KamadaKawai);this.body=body;this.springLength=edgeLength;this.springConstant=edgeStrength;this.distanceSolver=new _FloydWarshall2[\"default\"]}(0,_createClass3[\"default\"])(KamadaKawai,[{key:\"setOptions\",value:function setOptions(options){if(options){if(options.springLength){this.springLength=options.springLength}if(options.springConstant){this.springConstant=options.springConstant}}}},{key:\"solve\",value:function solve(nodesArray,edgesArray){var ignoreClusters=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;var D_matrix=this.distanceSolver.getDistances(this.body,nodesArray,edgesArray);this._createL_matrix(D_matrix);this._createK_matrix(D_matrix);this._createE_matrix();var threshold=.01;var innerThreshold=1;var iterations=0;var maxIterations=Math.max(1e3,Math.min(10*this.body.nodeIndices.length,6e3));var maxInnerIterations=5;var maxEnergy=1e9;var highE_nodeId=0,dE_dx=0,dE_dy=0,delta_m=0,subIterations=0;while(maxEnergy>threshold&&iterations<maxIterations){iterations+=1;var _getHighestEnergyNode2=this._getHighestEnergyNode(ignoreClusters);var _getHighestEnergyNode3=(0,_slicedToArray3[\"default\"])(_getHighestEnergyNode2,4);highE_nodeId=_getHighestEnergyNode3[0];maxEnergy=_getHighestEnergyNode3[1];dE_dx=_getHighestEnergyNode3[2];dE_dy=_getHighestEnergyNode3[3];delta_m=maxEnergy;subIterations=0;while(delta_m>innerThreshold&&subIterations<maxInnerIterations){subIterations+=1;this._moveNode(highE_nodeId,dE_dx,dE_dy);var _getEnergy2=this._getEnergy(highE_nodeId);var _getEnergy3=(0,_slicedToArray3[\"default\"])(_getEnergy2,3);delta_m=_getEnergy3[0];dE_dx=_getEnergy3[1];dE_dy=_getEnergy3[2]}}}},{key:\"_getHighestEnergyNode\",value:function _getHighestEnergyNode(ignoreClusters){var nodesArray=this.body.nodeIndices;var nodes=this.body.nodes;var maxEnergy=0;var maxEnergyNodeId=nodesArray[0];var dE_dx_max=0,dE_dy_max=0;for(var nodeIdx=0;nodeIdx<nodesArray.length;nodeIdx++){var m=nodesArray[nodeIdx];if(nodes[m].predefinedPosition===false||nodes[m].isCluster===true&&ignoreClusters===true||nodes[m].options.fixed.x===true||nodes[m].options.fixed.y===true){var _getEnergy4=this._getEnergy(m),_getEnergy5=(0,_slicedToArray3[\"default\"])(_getEnergy4,3),delta_m=_getEnergy5[0],dE_dx=_getEnergy5[1],dE_dy=_getEnergy5[2];if(maxEnergy<delta_m){maxEnergy=delta_m;maxEnergyNodeId=m;dE_dx_max=dE_dx;dE_dy_max=dE_dy}}}return[maxEnergyNodeId,maxEnergy,dE_dx_max,dE_dy_max]}},{key:\"_getEnergy\",value:function _getEnergy(m){var _E_sums$m=(0,_slicedToArray3[\"default\"])(this.E_sums[m],2),dE_dx=_E_sums$m[0],dE_dy=_E_sums$m[1];var delta_m=Math.sqrt(Math.pow(dE_dx,2)+Math.pow(dE_dy,2));return[delta_m,dE_dx,dE_dy]}},{key:\"_moveNode\",value:function _moveNode(m,dE_dx,dE_dy){var nodesArray=this.body.nodeIndices;var nodes=this.body.nodes;var d2E_dx2=0;var d2E_dxdy=0;var d2E_dy2=0;var x_m=nodes[m].x;var y_m=nodes[m].y;var km=this.K_matrix[m];var lm=this.L_matrix[m];for(var iIdx=0;iIdx<nodesArray.length;iIdx++){var i=nodesArray[iIdx];if(i!==m){var x_i=nodes[i].x;var y_i=nodes[i].y;var kmat=km[i];var lmat=lm[i];var denominator=1/Math.pow(Math.pow(x_m-x_i,2)+Math.pow(y_m-y_i,2),1.5);d2E_dx2+=kmat*(1-lmat*Math.pow(y_m-y_i,2)*denominator);d2E_dxdy+=kmat*(lmat*(x_m-x_i)*(y_m-y_i)*denominator);d2E_dy2+=kmat*(1-lmat*Math.pow(x_m-x_i,2)*denominator)}}var A=d2E_dx2,B=d2E_dxdy,C=dE_dx,D=d2E_dy2,E=dE_dy;var dy=(C/A+E/B)/(B/A-D/B);var dx=-(B*dy+C)/A;nodes[m].x+=dx;nodes[m].y+=dy;this._updateE_matrix(m)}},{key:\"_createL_matrix\",value:function _createL_matrix(D_matrix){var nodesArray=this.body.nodeIndices;var edgeLength=this.springLength;this.L_matrix=[];for(var i=0;i<nodesArray.length;i++){this.L_matrix[nodesArray[i]]={};for(var j=0;j<nodesArray.length;j++){this.L_matrix[nodesArray[i]][nodesArray[j]]=edgeLength*D_matrix[nodesArray[i]][nodesArray[j]]}}}},{key:\"_createK_matrix\",value:function _createK_matrix(D_matrix){var nodesArray=this.body.nodeIndices;var edgeStrength=this.springConstant;this.K_matrix=[];for(var i=0;i<nodesArray.length;i++){this.K_matrix[nodesArray[i]]={};for(var j=0;j<nodesArray.length;j++){this.K_matrix[nodesArray[i]][nodesArray[j]]=edgeStrength*Math.pow(D_matrix[nodesArray[i]][nodesArray[j]],-2)}}}},{key:\"_createE_matrix\",value:function _createE_matrix(){var nodesArray=this.body.nodeIndices;var nodes=this.body.nodes;this.E_matrix={};this.E_sums={};for(var mIdx=0;mIdx<nodesArray.length;mIdx++){this.E_matrix[nodesArray[mIdx]]=[]}for(var _mIdx=0;_mIdx<nodesArray.length;_mIdx++){var m=nodesArray[_mIdx];var x_m=nodes[m].x;var y_m=nodes[m].y;var dE_dx=0;var dE_dy=0;for(var iIdx=_mIdx;iIdx<nodesArray.length;iIdx++){var i=nodesArray[iIdx];if(i!==m){var x_i=nodes[i].x;var y_i=nodes[i].y;var denominator=1/Math.sqrt(Math.pow(x_m-x_i,2)+Math.pow(y_m-y_i,2));this.E_matrix[m][iIdx]=[this.K_matrix[m][i]*(x_m-x_i-this.L_matrix[m][i]*(x_m-x_i)*denominator),this.K_matrix[m][i]*(y_m-y_i-this.L_matrix[m][i]*(y_m-y_i)*denominator)];this.E_matrix[i][_mIdx]=this.E_matrix[m][iIdx];dE_dx+=this.E_matrix[m][iIdx][0];dE_dy+=this.E_matrix[m][iIdx][1]}}this.E_sums[m]=[dE_dx,dE_dy]}}},{key:\"_updateE_matrix\",value:function _updateE_matrix(m){var nodesArray=this.body.nodeIndices;var nodes=this.body.nodes;var colm=this.E_matrix[m];var kcolm=this.K_matrix[m];var lcolm=this.L_matrix[m];var x_m=nodes[m].x;var y_m=nodes[m].y;var dE_dx=0;var dE_dy=0;for(var iIdx=0;iIdx<nodesArray.length;iIdx++){var i=nodesArray[iIdx];if(i!==m){var cell=colm[iIdx];var oldDx=cell[0];var oldDy=cell[1];var x_i=nodes[i].x;var y_i=nodes[i].y;var denominator=1/Math.sqrt(Math.pow(x_m-x_i,2)+Math.pow(y_m-y_i,2));var dx=kcolm[i]*(x_m-x_i-lcolm[i]*(x_m-x_i)*denominator);var dy=kcolm[i]*(y_m-y_i-lcolm[i]*(y_m-y_i)*denominator);colm[iIdx]=[dx,dy];dE_dx+=dx;dE_dy+=dy;var sum=this.E_sums[i];sum[0]+=dx-oldDx;sum[1]+=dy-oldDy}}this.E_sums[m]=[dE_dx,dE_dy]}}]);return KamadaKawai}();exports[\"default\"]=KamadaKawai},function(module,exports,__webpack_require__){\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:true});var _classCallCheck2=__webpack_require__(0);var _classCallCheck3=_interopRequireDefault(_classCallCheck2);var _createClass2=__webpack_require__(1);var _createClass3=_interopRequireDefault(_createClass2);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var FloydWarshall=function(){function FloydWarshall(){(0,_classCallCheck3[\"default\"])(this,FloydWarshall)}(0,_createClass3[\"default\"])(FloydWarshall,[{key:\"getDistances\",value:function getDistances(body,nodesArray,edgesArray){var D_matrix={};var edges=body.edges;for(var i=0;i<nodesArray.length;i++){var node=nodesArray[i];var cell={};D_matrix[node]=cell;for(var j=0;j<nodesArray.length;j++){cell[nodesArray[j]]=i==j?0:1e9}}for(var _i=0;_i<edgesArray.length;_i++){var edge=edges[edgesArray[_i]];if(edge.connected===true&&D_matrix[edge.fromId]!==undefined&&D_matrix[edge.toId]!==undefined){D_matrix[edge.fromId][edge.toId]=1;D_matrix[edge.toId][edge.fromId]=1}}var nodeCount=nodesArray.length;for(var k=0;k<nodeCount;k++){var knode=nodesArray[k];var kcolm=D_matrix[knode];for(var _i2=0;_i2<nodeCount-1;_i2++){var inode=nodesArray[_i2];var icolm=D_matrix[inode];for(var _j=_i2+1;_j<nodeCount;_j++){var jnode=nodesArray[_j];var jcolm=D_matrix[jnode];var val=Math.min(icolm[jnode],icolm[knode]+kcolm[jnode]);icolm[jnode]=val;jcolm[inode]=val}}}return D_matrix}}]);return FloydWarshall}();exports[\"default\"]=FloydWarshall}])});\n",
"type": "application/javascript",
"module-type": "library"
}
}
}
{
"tiddlers": {
"$:/plugins/ihm/tidgraph/changelog": {
"created": "20151024161547099",
"creator": "ihm4u",
"modified": "20151031061347109",
"modifier": "ihm4u",
"tags": "",
"title": "$:/plugins/ihm/tidgraph/changelog",
"text": "For the complete changelog see\n\nhttps://ihm4u.github.io/tw5plugs/#Tidgraph%20-%20Changelog\n"
},
"$:/plugins/ihm/tidgraph/documentation": {
"title": "$:/plugins/ihm/tidgraph/documentation",
"text": "!!Example\nThe following example shows a tiddler which tags 7 children:\n\n``<$tidgraph start=\"Virtues\" />``\n\nlooks like this:\n\n{{$:/plugins/ihm/tidgraph/tidgraph.png}}\n\n!!Usage\nSimple usage:\n\n``<$tidgraph start=\"MyRootTiddler\" />``\n\nThe map will start with MyRootTiddler on the left, and show all its children recursively. The default maximum depth is 10 levels, it can be changed with the `maxdepth` attribute.\n\nAll options:\n\n|!Attribute |!Description|!Default |\n|`start` |Initial tiddler that starts the map | none |\n|`startat` |First level to display. 0 is the root tiddler named in the `start` attribute. 1 is the next level, etc. | 0 |\n|`maxdepth` |Maximum depth to display.| 10 |\n|`mode` |//tagging// or //linking// or custom. This is how to identify the children of a node. With //tagging// Tiddlers that tag other tiddlers become their parent. With //linking// tiddlers that link to other tiddlers become their parent. A custom mode can be specified by a `$:/config/tidgraph/modes/MyMode` tiddler where `MyMode` is the name of the mode. The subfilter can be also specified directly; e.g. `mode=\"fields[]\"`. See [[Custom Mode Demo|https://ihm4u.github.io/tw5plugs/#Custom%20Mode%20Demo]] for an example | //tagging// |\n|`nodetitle` |Field to use as title for the node. | //title// (or //caption// if present) |\n|`tooltip` |List of fields to use for node tooltip. The first field with a non empty value is used. | //summary// |\n|`filter` |Only tiddlers matching filter will be used | none |\n|`nocollapse` |Disable ability to collapse nodes. The graph allows node collapsing by default. | false |\n|`nodetemplate` |One or mode node templates to make node look like you want. See the [[Node Templates Demo|https://ihm4u.github.io/tw5plugs/#Node%20Templates%20Demo]] for examples of how to use them. | none |\n|`layout` |`E` for East (Vertical) or `S` for south (Horizontal) layout. | E |\n\n!CSS classes\nYou can also change colors, and other styles with the following CSS classes.\n\n|!Class |!Description |\n|tgr-node |Style for each node. If you want to change the color of the links inside the node use the `.tgr-node a` selector. |\n|tgr-edge |Style for the SVG path that connects the nodes. The old name was tgr-link. |\n|tgr-arrow |Style for the SVG polyline that draws the arrow at the end of the link |\n"
},
"$:/plugins/ihm/tidgraph/readme": {
"created": "20151024054526558",
"modified": "20151024065317719",
"tags": "",
"title": "$:/plugins/ihm/tidgraph/readme",
"text": "!!How\nSimply put this in your tiddler:\n\n``<$tidgraph start=\"MyRootTiddler\" />``\n\nThere are other options covered in the [[documentation|$:/plugins/ihm/tidgraph/documentation]].\n\n!!Features\n* No third-party libraries\n* Light weight\n* Rendering of map/graph with HTML5 and SVG (no heavy png or jpg images)\n* Automatic map/graph creation, no need for dragging/connecting/etc\n* Figures out tree-graph by means of tags or links, or custom modes \n* Collapse/expand nodes\n* User defined Node Templates!!\n\n!!Limitations\n* Layout is horizontal from left to right, if needed a vertical layout will be added later\n"
},
"$:/plugins/ihm/tidgraph/stylesheet": {
"tags": "$:/tags/Stylesheet",
"title": "$:/plugins/ihm/tidgraph/stylesheet",
"type": "text/css",
"text": "/*Eliminate border in table and cells*/\n.ihm-tgr-table {\n border-collapse: collapse;\n border: none;\n background-color: transparent;\n padding: 0;\n margin: 0;\n}\n\n.ihm-tgr-tablediv {\n /* We need this margin to prevent spurius vertical scroll\n * in tgr-container. It needs to have the SAME pixel value\n * as top and left in tgr-svg-int class so that the SVG\n * arrows match properly (this assures same origin coordinates\n * for table and svg)\n */\n margin: 10px; \n}\n\n.tgr-container table td {\n border: none;\n background-color: transparent;\n}\n\n/*nice round box around tiddlers*/\n.tgr-container td a {\n \n}\n\n.tgr-container {\n position:relative; \n left:0px; \n top:0px; \n background-color: transparent;\n overflow: auto; /* This is needed to scroll on big maps */\n z-index:1;\n}\n.tgr-svg-int { \n\tz-index: -1;\n\tposition:absolute;\n\tbackground-color:transparent;\n\topacity: 1;\n left: 10px;\n top: 10px;\n}\n\n/* SVG arrows */\n.ihm-tgr-link {\n fill: none;\n stroke-width: 2;\n stroke: #aeb0b5;\n}\n\n.tgr-edge-weak {\n stroke-dasharray: 3,5;\n}\n\n.tgr-arrow {\n fill: #aeb0b5;\n stroke-width: 0;\n}\n\n.ihm-tgr-node-container {\n position: relative;\n}\n\n.ihm-tgr-node-container-east {\n margin: 6px 10px;\n}\n\n.ihm-tgr-node-container-south {\n margin: 16px 4px;\n display: inline-block; /*FIXME*/\n}\n\n.ihm-tgr-node-container p {\n margin-top: 0px;\n margin-bottom: 0px;\n}\n\n.ihm-tgr-node {\n background-color: #dce4ef;\n border-radius: 15px;\n padding: 0.1em 0.4em;\n /* border: 0px dashed #cd2026; */\n box-shadow: 4px 4px 5px #888888;\n text-align: center;\n vertical-align: middle;\n font-size: 1em;\n color: #0071bc;\n}\n\n/* Collapse feature */\n.ihm-tgr-collapse {\n position: absolute;\n cursor: pointer;\n width: 14px;\n height: 14px;\n right: -14px;\n}\n\n.ihm-tgr-collapse-east {\n top: 50%;\n transform: translateY(-50%);\n -ms-transform: translateY(-50%);\n -webkit-transform: translateY(-50%);\n}\n\n.ihm-tgr-collapse-south {\n left: 50%;\n transform: translateX(-50%);\n -ms-transform: translateX(-50%);\n -webkit-transform: translateX(-50%);\n}\n\na.ihm-tgr-collapse:hover {\n text-decoration: none;\n background: #999999;\n}\n\n/* Vertical layout divs */\n.ihm-tgr-divtable {\n display: table;\n}\n\n.ihm-tgr-node-group {\n display: table-row;\n}\n\n.ihm-tgr-node-cell {\n display: table-cell;\n vertical-align: top;\n text-align: center;\n}\n"
},
"$:/plugins/ihm/templates/collapse": {
"created": "20151120174133063",
"modified": "20151120180705805",
"tags": "",
"title": "$:/plugins/ihm/templates/collapse",
"type": "text/vnd.tiddlywiki",
"text": "<svg version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" x=\"0px\"\n\t y=\"0px\" width=\"14px\" height=\"14px\" >\n<circle cx=\"7\" cy=\"7\" r=\"6\" stroke=\"#aeb0b5\" stroke-width=\"1\" fill=\"#aeb0b5\"/>\n<polyline points=\"4,7 10,7\" fill=\"none\" stroke=\"white\"/>\n</svg>\n"
},
"$:/plugins/ihm/templates/expand": {
"created": "20151120174133063",
"modified": "20151120180705805",
"tags": "",
"title": "$:/plugins/ihm/templates/expand",
"type": "text/vnd.tiddlywiki",
"text": "<svg version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" x=\"0px\"\n\t y=\"0px\" width=\"14px\" height=\"14px\" >\n<circle cx=\"7\" cy=\"7\" r=\"6\" stroke=\"#aeb0b5\" stroke-width=\"1\" fill=\"#aeb0b5\"/>\n<polyline points=\"4,7 10,7 7,7 7,10 7,4\" fill=\"none\" stroke=\"white\"/>\n</svg>\n"
},
"$:/plugins/ihm/tidgraph/utils.js": {
"text": "/*\\\ntitle: $:/plugins/ihm/tidgraph/utils.js\ntype: application/javascript\nmodule-type: library\n\nInternal utility functions for tidgraph plugin.\n\n\\*/\n(function(){function u(a){var c=a.getBoundingClientRect(),b=document.body,e=document.documentElement,g=c.top-(a.scrollTop||window.pageYOffset||e.scrollTop||b.scrollTop)-(e.clientTop||b.clientTop||0);a=c.left-(a.scrollLeft||window.pageXOffset||e.scrollLeft||b.scrollLeft)-(e.clientLeft||b.clientLeft||0);return{top:g,left:a,width:c.width,height:c.height,right:a+c.width,bottom:g+c.height}}function q(a,c,b){b=b||function(a,b,c){if(a)return!0};a=$tw.utils.parseStringArray(a);for(var e=a.length,g=c.length,\nf=0;f<g;f++)for(var h=0;h<e;h++){var d=$tw.wiki.getTiddler(c[f]);if(d&&(d=d.getFieldString(a[h]),b(d,a[h],c[f])))return d}return\"\"}function x(a){var c=!1;return(a=q(\"_tgr_node_class _tgr_node_class_add\",[a.id,a.template],function(a,e,g){if(a)return c=\"_tgr_node_class_add\"===e?!0:!1,!0}))&&\"tgr-default\"!==a?c?\"ihm-tgr-node tgr-node \"+a:a:\"ihm-tgr-node tgr-node\"}function w(a,c,b){var e;a=u(a);if(\"string\"===typeof b){if(e=document.querySelector(b),null==e)return null}else b instanceof HTMLElement&&(e=\nb);var g=u(e);b=g.bottom-a.top;e=g.left-a.left;var f=g.right-a.left;a=g.top-a.top;g=\"\";switch(c.toUpperCase()){case \"L\":g=[Math.round(e),Math.round(b/2+a/2)];break;case \"R\":g=[Math.round(f),Math.round(b/2+a/2)];break;case \"T\":g=[Math.round(f/2+e/2),Math.round(a)];break;case \"B\":g=[Math.round(f/2+e/2),Math.round(b)]}return g}function y(a,c,b,e,g){var f;a:{var h=u(c),d=u(b);f=h.left+h.width/2;var h=h.top+h.height/2,n=d.left+d.width/2,d=d.top+d.height/2;switch(e){case \"E\":f=4>n-f?[\"R\",\"R\"]:[\"R\",\"L\"];\nbreak a;case \"S\":f=4>d-h?[\"B\",\"B\"]:[\"B\",\"T\"];break a}f=void 0}d=w(a,f[0],c);a=w(a,f[1],b);var m,l,h=10,n=\"\";g&&(n=' class=\"tgr-edge-weak\"');if(null==c||null==b)return error(\"can't connect null element\");if(null==d)return error(\"port not found for \"+c.tagName+\" - \"+c.innerHTML);if(null==a)return error(\"port not found for \"+b.tagName+\" - \"+b.innerHTML);c=Math.abs(a[1]-d[1]);b=Math.abs(a[0]-d[0]);switch(e){case \"E\":return a[1]>d[1]&&(m=c/2),a[1]<d[1]&&(m=-c/2),5>c&&(m=0),\"L\"==f[1]&&(l=-10),\"R\"==f[1]&&\n(l=10,h=20),'<path d=\"M'+d[0]+\",\"+d[1]+\" Q\"+(d[0]+h)+\",\"+d[1]+\" \"+(d[0]+h)+\",\"+(d[1]+m)+\" Q\"+(d[0]+h)+\",\"+a[1]+\" \"+(a[0]+l)+\",\"+a[1]+'\"'+n+' marker-end=\"url(#tgr-arrow)\"/>';case \"S\":return a[0]>d[0]&&(l=b/2),a[0]<d[0]&&(l=-b/2),5>b&&(l=0),\"T\"==f[1]&&(m=-10,h=10),\"B\"==f[1]&&(m=10,h=20),'<path d=\"M'+d[0]+\",\"+d[1]+\" Q\"+d[0]+\",\"+(d[1]+h)+\" \"+(d[0]+l)+\",\"+(d[1]+h)+\" Q\"+a[0]+\",\"+(d[1]+h)+\" \"+a[0]+\",\"+(a[1]+m)+'\"'+n+' marker-end=\"url(#tgr-arrow)\"/>'}}function v(a,c){var b;switch(c.mode){case \"tagging\":b=\n\"[[\"+a+\"]tagging[]]+\"+c.filter;break;case \"linking\":b=\"[[\"+a+\"]links[]!is[missing]]+\"+c.filter;break;default:b=\"[[\"+a+\"]\"+c.mode+\"]+\"+c.filter}return $tw.wiki.filterTiddlers(b)}function z(a,c,b){switch(b.mode.toLowerCase()){case \"tagging\":return(b=$tw.wiki.getTiddler(a))?b.hasTag(c):!1;default:return b=v(c,b),-1!==b.indexOf(a)}}function A(a,c){function b(b,l,k){h=l;d=b;n=encodeURIComponent(h);m=encodeURIComponent(d);g=document.getElementById(c.id+\"-\"+n);f=document.getElementById(c.id+\"-\"+m);g&&f&&\ne.push(y(a,g,f,c.layout,k))}var e=[],g,f,h,d,n,m;p(c.root,function(a,c,d){(c=a.parent)&&b(a.id,c.id)},{},{skipvisited:!0});for(var l=c.outliers.length,k=0;k<l;k++)b(c.outliers[k][0],c.outliers[k][1],!0);return e.join(\" \")}function p(a,c,b,e){e=e||{};var g=e.done||[],f=e.getCh||function(a){return a.collapse?[]:a.children},h=e.lvl||0,d=void 0===e.skipvisited?!0:e.skipvisited;e.leave=e.leave||!1;if(d&&-1!==g.indexOf(a))return b;g.push(a);f=f(a);d=f.length;b=b||{};e.lvl=h+1;e.done=g;if(!1===c(a,b,h))return e.leave=\n!0,b;for(a=0;a<d;a++)if(b=p(f[a],c,b,e),e.leave)return b;e.lvl--;return b}function B(a,c,b,e){e=e||{};var g=e.getCh||function(a){return a.collapse?[]:a.children},f=e.getId||function(a){return a.id},h=void 0===e.skipvisited?!0:e.skipvisited,d=e.maxdepth||Number.MAX_VALUE;b=b||{};var n=[],m=[],l=[],k=0;n.push(a);l[f(a)]=void 0;do{a=n.length;for(var q=0;q<a;q++){var r=n.shift(),p;p=h?-1===m.indexOf(r)?!1:!0:!1;if(!p&&!1===c(r,l[f(r)],b,k))return b;m.push(r);p=g(r);n=n.concat(p);p&&p.forEach(function(a){var b=\nl[f(a)];b?f(b)!==f(r)&&e.outlier&&e.outlier(a,r):l[f(a)]=r})}k++}while(0!==n.length&&k<=d);return b}function C(a,c){return p(a,function(a,c){c.cnt++;return!0},{cnt:0},{skipvisited:c}).cnt-1}function D(a,c,b){function e(a,b){if(-1!==$tw.utils.parseStringArray(b).indexOf(c.toString()))return!0}b=$tw.utils.parseStringArray(b);var g=q(\"_tgr_node_template\",[a]),f=[];$tw.utils.each(b,function(b){var c=$tw.wiki.getTiddler(b),c=c?c.getFieldString(\"_tgr_node_filter\"):\"\",d=$tw.wiki.filterTiddlers(c);c&&-1===\nd.indexOf(a)&&f.push(b)});0<f.length&&$tw.utils.removeArrayEntries(b,f);g||q(\"_tgr_node_filter\",b,function(b,c,d){c=$tw.wiki.filterTiddlers(b);if(b&&-1!==c.indexOf(a))if(b=$tw.wiki.getTiddler(d).getFieldString(\"_tgr_node_level\")){if(e(d,b))return g=d,!0}else return g=d,!0});g||q(\"_tgr_node_level\",b,function(a,b,c){if(e(c,a))return g=c,!0});if(!g)for(var h=b.length,d=0;d<h;d++){var n=$tw.wiki.getTiddler(b[d]);if(n&&!n.hasField(\"_tgr_node_level\")&&!n.hasField(\"_tgr_node_filter\")){g=b[d];break}}g||(g=\n\"tgr-default\");return g}function t(a,c,b,e){if(!(this instanceof t))throw\"Error: call new tnode(id=\"+c+\")\";this.parent=a;this.id=c;this.children=[];this.collapse=!1;this.widget=e;this.template=void 0;a=D(c,b,e.nodetemplate);\"tgr-default\"!==a&&(this.transcluder=b=\"$:/temp/tidgraph/\"+e.tidtree.id+\"/\"+c,this.template=a,$tw.wiki.addTiddler(new $tw.Tiddler({title:b,text:\"{{\"+c+\"||\"+a+\"}}\"})),-1===e.templatesInUse.indexOf(a)&&e.templatesInUse.push(a))}exports.buildTable=function(a,c){function b(a,b){return $tw.utils.domMaker(a,\n$tw.utils.extend(b,{document:c.document}))}function e(a){var d=encodeURIComponent(a.id),e;var f=a.id;e=$tw.wiki.tiddlerExists(f)?c.nodetitle?q(c.nodetitle,[f]):q(\"caption title\",[f]):f;var g=$tw.wiki.tiddlerExists(a.id)?\"tc-tiddlylink-resolves\":\"tc-tiddlylink-missing\",g=\"tc-tiddlylink \"+g,f=x(a);a.template?a=b(\"div\",{\"class\":f,innerHTML:$tw.wiki.renderTiddler(\"text/html\",a.transcluder)}):(a=b(\"a\",{\"class\":g,text:e,attributes:{href:\"#\"+d}}),a=b(\"div\",{\"class\":f,children:[a]}));return a}function g(a,\nd){var e=1+C(a,!0),f=encodeURIComponent(a.id),g=q(c.tooltip,[a.id]),k;!1===c.nocollapse&&a.children&&0<a.children.length?(k=$tw.wiki.renderTiddler(\"text/html\",\"$:/plugins/ihm/templates/\"+(a.collapse?\"expand\":\"collapse\")).replace(/^<p>/,\"<span>\").replace(/<\\/p>$/,\"</span>\"),k=b(\"span\",{\"class\":\"ihm-tgr-collapse \"+(\"E\"==a.widget.tidtree.layout?\"ihm-tgr-collapse-east\":\"ihm-tgr-collapse-south\")+\" tc-tiddlylink\",innerHTML:k}),$tw.utils.addEventListeners(k,[{name:\"click\",handlerObject:a,handlerMethod:\"collapseClickEvent\"}]),\nk=[d,k]):k=[d];f=b(\"div\",{\"class\":\"ihm-tgr-node-container \"+(\"E\"==a.widget.tidtree.layout?\"ihm-tgr-node-container-east\":\"ihm-tgr-node-container-south\"),children:k,attributes:{id:c.id+\"-\"+f,title:g}});return\"E\"===c.layout?b(\"td\",{attributes:{rowspan:e},children:[f]}):b(\"div\",{attributes:{\"class\":\"ihm-tgr-node-cell\"},children:[f]})}var f;f=\"E\"==c.layout?b(\"table\",{\"class\":\"ihm-tgr-table\",attributes:{id:c.id+\"-table\"}}):b(\"div\",{\"class\":\"ihm-tgr-divtable\",attributes:{id:c.id+\"-table\"}});(function(a){switch(c.layout){case \"E\":p(c.root,\nfunction(d,f,m){m>=c.startat&&(f=e(d),d=g(d,f),d=b(\"tr\",{children:[d]}),a.appendChild(d));return!0},{},{skipvisited:!0});break;case \"S\":p(c.root,function(d,f,m){if(m>=c.startat){var l=e(d),l=g(d,l),k=f.nodegroup[f.nodegroup.length-1];k?m>=f.lastdepth?k.appendChild(l):m<f.lastdepth&&(f.nodegroup.pop(),k=f.nodegroup[f.nodegroup.length-1],k.appendChild(l)):a.appendChild(l);!d.collapse&&0<d.children.length&&(d=b(\"div\",{\"class\":\"ihm-tgr-node-group\"}),f.nodegroup.push(d),l.appendChild(d))}f.lastdepth=m;\nreturn!0},{nodegroup:[],lastdepth:-1},{skipvisited:!0})}})(f);return f};exports.error=function(a){return'<span style=\"color:green; font-size:1.5em\">\\u26a0 Tidgraph: </span><span style=\"color:red\">'+a+\"</span>\"};exports.buildSVG=function(a,c){var b=document.getElementById(c.id+\"-table\");if(b)return getComputedStyle(b),'<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"'+a.offsetHeight+'px\" width=\"'+a.offsetWidth+'px\" style=\"overflow: visible\"><g class=\"ihm-tgr-link tgr-link tgr-edge\" style=\"overflow: visible\"> <defs> <marker id=\"tgr-arrow\" viewBox=\"0 0 10 10\" refX=\"1\" refY=\"5\" markerUnits=\"strokeWidth\" orient=\"auto\" markerWidth=\"8\" markerHeight=\"6\"> <polyline class=\"ihm-tgr-arrow tgr-arrow\" points=\"0,0 10,5 0,10 0,5\" style=\"opacity:1;\" /></marker></defs> '+\nA(a,c)+\"</g> </svg>\"};exports.isDescendant=function(a,c,b){if(z(a,c,b))return!0;var e=!1;p(c,function(b,c,h){if(b===a)return e=!0,!1},{},{skipvisited:!0,getCh:function(a){return v(a,b)}});return e};exports.makeTidTree=function(a,c,b){b=b||{};var e=!1;c.outliers=[];var g=new t(void 0,a,0,b.widget);B(a,function(a,c,d,e){if(c){a:{for(var g=d.visited,l=g.length,k=0;k<l;k++)if(g[k].id===c){c=g[k];break a}c=void 0}a=c.addChild(a,e,b.widget);d.visited.push(a)}return!0},{visited:[g]},{getId:function(a){return a},\ngetCh:function(a){return v(a,c)},maxdepth:c.maxdepth,skipvisited:!0,outlier:function(a,b){e=!1;$tw.utils.each(c.outliers,function(c){c[0]===a&&c[1]===b&&(e=!0)});e||c.outliers.push([a,b])}});return g};t.prototype.addChild=function(a,c,b){a=new t(this,a,c,b);this.children.push(a);return a};t.prototype.toString=function(){return\"tnode(id=\"+this.id+\")\"};t.prototype.collapseClickEvent=function(a){this.collapse=!this.collapse;this.widget.paint()}})();\n",
"title": "$:/plugins/ihm/tidgraph/utils.js",
"type": "application/javascript",
"module-type": "library"
},
"$:/plugins/ihm/tidgraph/tidgraph.png": {
"created": "20151024064703806",
"modified": "20151024064720670",
"title": "$:/plugins/ihm/tidgraph/tidgraph.png",
"type": "image/png",
"text": "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\n"
},
"$:/plugins/ihm/widgets/tidgraph.js": {
"text": "/*\\\ntitle: $:/plugins/ihm/widgets/tidgraph.js\ntype: application/javascript\nmodule-type: widget\n\nTidgraph widget to render HTML5/SVG graph of tiddlers\n\n\\*/\n(function(){var e=require(\"$:/core/modules/widgets/widget.js\").widget,c=function(b,f){this.initialise(b,f)},d=require(\"$:/plugins/ihm/tidgraph/utils.js\");c.prototype=new e;c.prototype.render=function(b,f){this.tidtree&&this.delTempTiddlers();this.parentDomNode=b;this.nextSiblingDomNode=f;this.computeAttributes();this.execute();-1===[\"tagging\",\"linking\"].indexOf(this.mode)&&(this.mode=$tw.wiki.getTiddlerText(\"$:/config/tidgraph/modes/\"+this.mode)||this.mode);this.tidtree=[];this.tidtree.mode=this.mode;\nthis.tidtree.maxdepth=this.maxdepth;this.tidtree.startat=this.startat;this.tidtree.nodetitle=this.nodetitle;this.tidtree.tooltip=this.tooltip;this.tidtree.filter=this.filter;this.tidtree.nocollapse=this.nocollapse;this.tidtree.document=this.document;this.tidtree.nodetemplate=this.nodetemplate;this.tidtree.layout=this.layout;this.templatesInUse=$tw.utils.parseStringArray(this.nodetemplate);this.tidtree.id=(new Date).valueOf();if($tw.wiki.getTiddler(this.startTid)){this.div=this.document.createElement(\"div\");\nthis.div.className=\"tgr-container tgr\";this.tablediv=this.document.createElement(\"div\");this.tablediv.className=\"ihm-tgr-tablediv\";this.table=void 0;this.div.appendChild(this.tablediv);this.svgdiv=this.document.createElement(\"div\");this.svgdiv.className=\"tgr-svg-int\";this.div.appendChild(this.svgdiv);this.parentDomNode.insertBefore(this.div,this.nextSiblingDomNode);this.domNodes.push(this.div);this.tidtree.root=d.makeTidTree(this.startTid,this.tidtree,{widget:this});this.paint();var a=this,c=function(){a.svgdiv.innerHTML=\nd.buildSVG(a.tablediv,a.tidtree);a.oldresize&&a.oldresize()},e=function(){a.svgdiv.innerHTML=d.buildSVG(a.tablediv,a.tidtree)};this.div.onscroll=function(){a.scroll_to||clearTimeout(a.scroll_to);a.scroll_to=setTimeout(e,100)};this.onresize_updated||(window.onresize&&void 0==this.oldresize&&(this.oldresize=window.onresize),window.onresize=function(){a.resize_to||clearTimeout(a.resize_to);a.resize_to=setTimeout(c,100)},this.onresize_updated=!0)}};c.prototype.delTempTiddlers=function(){var b=$tw.wiki.filterTiddlers(\"[prefix[$:/temp/tidgraph/\"+\nthis.tidtree.id+\"]]\");$tw.utils.each(b,function(b){$tw.wiki.deleteTiddler(b)})};c.prototype.paint=function(){this.sidebar=$tw.wiki.getTiddlerText(\"$:/state/sidebar\");var b=d.buildTable(this.startTid,this.tidtree);this.table?this.tablediv.replaceChild(b,this.table):this.tablediv.appendChild(b);this.svgdiv.innerHTML=d.buildSVG(this.tablediv,this.tidtree);this.table=b};c.prototype.execute=function(){this.startTid=this.getAttribute(\"start\");this.mode=this.getAttribute(\"mode\",\"tagging\");this.maxdepth=\nparseInt(this.getAttribute(\"maxdepth\",\"10\"));this.startat=this.getAttribute(\"startat\",\"0\");this.nodetitle=this.getAttribute(\"nodetitle\");this.tooltip=this.getAttribute(\"tooltip\",\"summary\");this.filter=this.getAttribute(\"filter\",\"[!is[system]]\");this.nocollapse=this.hasAttribute(\"nocollapse\");this.nodetemplate=this.getAttribute(\"nodetemplate\",\"\");this.layout=this.getAttribute(\"layout\",\"E\");-1==[\"E\",\"S\"].indexOf(this.layout)&&(this.layout=\"E\")};c.prototype.refresh=function(b){var c=!1,a;this.computeAttributes();\nthis.execute();for(a in b)if((b=document.getElementById(this.tidtree.id+\"-\"+encodeURIComponent(a))||d.isDescendant(a,this.startTid,this.tidtree)||-1!==this.templatesInUse.indexOf(a))||(b=(b=$tw.wiki.getTiddler(a))&&b.hasTag(\"$:/tags/Stylesheet\")?!0:!1),b||-1!==a.indexOf(\"$:/config/tidgraph/modes\")){c=!0;break}$tw.wiki.getTiddlerText(\"$:/state/sidebar\")!==this.sidebar&&(c=!0);return c?(this.refreshSelf(),!0):!1};exports.tidgraph=c})();\n",
"title": "$:/plugins/ihm/widgets/tidgraph.js",
"type": "application/javascript",
"module-type": "widget"
}
}
}
{
"tiddlers": {
"$:/plugins/inmysocks/CategoryLists/CategoryLists": {
"tags": "$:/tags/Macro",
"title": "$:/plugins/inmysocks/CategoryLists/CategoryLists",
"true": "True",
"task": "Task",
"event": "Event",
"text": "\\define inmysocksCategoryListsMakeSubCategorySelect()\nSubcategory: <$select tiddler='$:/state/$(ListType)$List/SelectedSubCategory'>\n\t<option value=''>Show All</option>\n\t<$list filter='[[$:/data/$(ListType)$ListCategories/$(CurrentCategory)$/SubCategories]indexes[]]'>\n\t\t<$set name=CurrentSubCategory value=<<currentTiddler>>>\n\t\t\t<option><$view field='title'/></option>\n\t\t</$set>\n\t</$list>\n</$select>\n\\end\n\n\\define inmysocksCategoryListsMakeSubSubCategorySelect()\n<$list filter='[[$:/data/$(ListType)$ListCategories/$(CurrentCategory)$/SubCategories]indexes[]]'>\n\t<$list filter='[[$:/state/$(ListType)$List/SelectedSubCategory]text<currentTiddler>limit[1]]'>\n\t\tSubsubcategory:\n\t\t<$select tiddler='$:/state/$(ListType)$List/SelectedSubSubCategory'>\n\t\t\t<option value=''>Show All</option>\n\t\t\t<$list filter='[[$:/data/$(ListType)$ListCategories/$(CurrentCategory)$/$(CurrentSubCategory)$/subsubcategories]indexes[]]'>\n\t\t\t\t<$set name=CurrentSubSubCategory value=<<currentTiddler>>>\n\t\t\t\t\t<option><$view field='title'/></option>\n\t\t\t\t</$set>\n\t\t\t</$list>\n\t\t</$select>\n\t</$list>\n</$list>\n\\end\n\n\\define inmysocksCategoryListsSelectCategorySearch()\nTag:\n<$select tiddler='$:/state/$(ListType)$List/search/SelectedTag'>\n\t<option value=''>Show All</option>\n\t<$list filter=\"\"\"[tag[$(Tag)$]!has[draft.of]tags[]sort[title]]-[[$(Tag)$]]-[[$(FinishedTag)$]]\"\"\">\n\t\t<option><$view field='title'/></option>\n\t</$list>\n</$select>\n\\end\n\n\\define inmysocksCategoryListsSearchTag()\ntag{$:/state/$(ListType)$List/search/SelectedTag}\n\\end\n\n\\define inmysocksCategoryListsExpandAllButton()\n<$button>Expand All\n\t<$list filter='[prefix[$:/state/$(ListType)$List/ShowCategory/]!text[show]]'>\n\t\t<$action-setfield $tiddler=<<currentTiddler>> text=show/>\n\t</$list>\n</$button>\n\\end\n\n\\define inmysocksCategoryListsCollapseAllButton()\n<$button>Collapse All\n\t<$list filter='[prefix[$:/state/$(ListType)$List/ShowCategory/]text[show]]'>\n\t\t<$action-setfield $tiddler=<<currentTiddler>> text=hide/>\n\t</$list>\n</$button>\n\\end\n\n\\define inmysocksCategoryListsMainBody()\n<$reveal type='match' state='$:/plugins/inmysocks/CategoryLists/CategoryLists!!true' text=$(ShowSearch)$>\n\tSearch: <$edit-text tiddler='$:/temp/$(ListType)$List/Search' field='search_text' placeholder='Title Search' class='tc-edit-texteditor'/>\n\n\tCategory:\n\t<$select tiddler='$:/state/$(ListType)$List/SelectedCategory'>\n\t\t<option value=''>Show All</option>\n\t\t<$list filter='[[$:/data/$(ListType)$ListCategories]indexes[]]'>\n\t\t\t<$set name=CurrentCategory value=<<currentTiddler>>>\n\t\t\t\t<option><$view field='title'/></option>\n\t\t\t</$set>\n\t\t</$list>\n\t</$select>\n\t<br>\n\t<$set name=CurrentCategory value={{$:/state/$(ListType)$List/SelectedCategory}}>\n\t\t<$reveal type='nomatch' state='$:/state/$(ListType)$List/SelectedCategory' text=''>\n\t\t\t<<inmysocksCategoryListsMakeSubCategorySelect>>\n\t\t</$reveal>\n\t\t<br>\n\t\t<$set name=CurrentSubCategory value={{$:/state/$(ListType)$List/SelectedSubCategory}}>\n\t\t\t<<inmysocksCategoryListsMakeSubSubCategorySelect>>\n\t\t</$set>\n\t</$set>\n\t<br>\n\t<<inmysocksCategoryListsSelectCategorySearch>>\n\n</$reveal>\n\n<<inmysocksCategoryListsExpandAllButton>> <<inmysocksCategoryListsCollapseAllButton>>\n\n<$reveal type='match' state='$:/state/$(ListType)$List/search/SelectedTag' text=''>\n\t<$reveal type='match' state='$:/plugins/inmysocks/CategoryLists/CategoryLists!!true' text=$(ShowFinished)$>\n\t\t<<tabs \"[[$:/plugins/inmysocks/CategoryLists/Unfinished Items]][[$:/plugins/inmysocks/CategoryLists/Finished Items]]\">>\n\t</$reveal>\n\t<$reveal type='nomatch' state='$:/plugins/inmysocks/CategoryLists/CategoryLists!!true' text=$(ShowFinished)$>\n\t\t<$transclude tiddler='$:/plugins/inmysocks/CategoryLists/Unfinished Items' mode=block/>\n\t</$reveal>\n</$reveal>\n<$reveal type='nomatch' state='$:/state/$(ListType)$List/search/SelectedTag' text=''>\n\t<$set name=SearchTag value=<<inmysocksCategoryListsSearchTag>>>\n\t\t<$reveal type='match' state='$:/plugins/inmysocks/CategoryLists/CategoryLists!!true' text=$(ShowFinished)$>\n\t\t\t<<tabs \"[[$:/plugins/inmysocks/CategoryLists/Unfinished Items]][[$:/plugins/inmysocks/CategoryLists/Finished Items]]\">>\n\t\t</$reveal>\n\t\t<$reveal type='nomatch' state='$:/plugins/inmysocks/CategoryLists/CategoryLists!!true' text=$(ShowFinished)$>\n\t\t\t<$transclude tiddler='$:/plugins/inmysocks/CategoryLists/Unfinished Items' mode=block/>\n\t\t</$reveal>\n\t</$set>\n</$reveal>\n\\end\n\n\\define CategoryList(Tag:\"Task\" FinishedTag:\"Done\" ListType:\"Task\" ShowAddItem:\"True\" ShowSearch:\"True\" ShowFinished:\"True\")\n<$set name=ListType value=$ListType$>\n\t<$set name=Tag value=\"\"\"$Tag$\"\"\">\n\t\t<$set name=FinishedTag value=\"\"\"$FinishedTag$\"\"\">\n\t\t\t<$set name=ShowSearch value=$ShowSearch$>\n\t\t\t\t<$set name=ShowFinished value=$ShowFinished$>\n\n\t\t\t\t\t<$reveal type='match' state='$:/plugins/inmysocks/CategoryLists/CategoryLists!!true' text=$ShowAddItem$>\n\t\t\t\t\t\t<$set name=Tag value=\"\"\"$Tag$\"\"\">\n\t\t\t\t\t\t\t<$button popup='$:/state/Items/MakeItemPopup'>\n\t\t\t\t\t\t\t\tNew $ListType$\n\t\t\t\t\t\t\t</$button>\n\t\t\t\t\t\t\t<$reveal type='popup' state='$:/state/Items/MakeItemPopup'>\n\t\t\t\t\t\t\t\t<div class='tc-popup-keep' style='border:solid;border-color:grey;border-width:1px;background-color:white;width:80vw;padding:1em'>\n\t\t\t\t\t\t\t\t\t<$transclude tiddler='$:/plugins/inmysocks/CategoryLists/Make Entry' mode=block/>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t</$reveal>\n\t\t\t\t\t\t</$set>\n\t\t\t\t\t</$reveal>\n\n\t\t\t\t\t<<inmysocksCategoryListsMainBody>>\n\n\t\t\t\t</$set>\n\t\t\t</$set>\n\t\t</$set>\n\t</$set>\n</$set>\n\\end"
},
"$:/plugins/inmysocks/CategoryLists/EditEntryTemplate": {
"tags": "Templates",
"title": "$:/plugins/inmysocks/CategoryLists/EditEntryTemplate",
"text": "\\define SelectSubcategory()\n<$select tiddler=<<currentTiddler>> field='subcategory'>\n\t<option value=''>--</option>\n\t<$list filter='[[$:/data/$(ListType)$ListCategories/$(ThisCategory)$/SubCategories]indexes[]]'>\n\t\t<option>\n\t\t\t<$view tiddler=<<currentTiddler>> field=title/>\n\t\t</option>\n\t</$list>\n</$select>\n(<$button popup='$:/state/Edit$(ListType)$/AddSubcategoryPopup'>New Subcategory\n</$button>)\n<$reveal type=popup state='$:/state/Edit$(ListType)$/AddSubcategoryPopup'>\n\t<div class='tc-drop-down tc-popup-keep'>\n\t\tSubcategory Name:\n\t\t<$edit-text tiddler=\"$:/temp/Edit$(ListType)$\" field='new_subcategory_name' placeholder='New Subcategory Name'/> \n\t\t<$button>\n\t\t\tCreate Subcategory\n\t\t\t<$action-setfield $tiddler='$:/data/$(ListType)$ListCategories/$(ThisCategory)$/SubCategories' $index={{$:/temp/Edit$(ListType)$!!new_subcategory_name}} $value=1/>\n\t\t\t<$action-setfield $tiddler='$:/temp/Edit$(ListType)$' $field='new_subcategory_name' $value=''/>\n\t\t</$button>\n\t</div>\n</$reveal>\n\\end\n\n\\define SelectSubSubCategory()\n<$select tiddler=<<currentTiddler>> field='subsubcategory'>\n\t<option value=''>--</option>\n\t<$list filter='[[$:/data/$(ListType)$ListCategories/$(ThisCategory)$/$(ThisSubCategory)$/subsubcategories]indexes[]]'>\n\t\t<option>\n\t\t\t<$view tiddler=<<currentTiddler>> field=title/>\n\t\t</option>\n\t</$list>\n</$select>\n(<$button popup='$:/state/Edit$(ListType)$/AddSubSubcategoryPopup'>New Subsubcategory\n</$button>)\n<$reveal type=popup state='$:/state/Edit$(ListType)$/AddSubSubcategoryPopup'>\n\t<div class='tc-drop-down tc-popup-keep'>\n\t\tSubsubcategory Name:\n\t\t<$edit-text tiddler='$:/state/Edit$(ListType)$' field='new_subsubcategory_name' placeholder='New Subsubcategory Name'/> \n\t\t<$button>\n\t\t\tCreate Subcategory\n\t\t\t<$action-setfield $tiddler='$:/data/$(ListType)$ListCategories/$(ThisCategory)$/$(ThisSubCategory)$/subsubcategories' $index={{$:/temp/Edit$(ListType)$!!new_subsubcategory_name}} $value=1/>\n\t\t\t<$action-setfield $tiddler='$:/state/Edit$(ListType)$' $field='new_subsubcategory_name' $value=''/>\n\t\t</$button>\n\t</div>\n</$reveal>\n\\end\n\n\\define thisSelectSubCategoryAndSubSubCategory()\n<$reveal type='nomatch' state='!!category' text=''>\n\t$(ListType)$ Subcategory:\n\t<<SelectSubcategory>>\n\t<br>\n\t<$reveal type='nomatch' state='!!subcategory' text=''>\n\t\t$(ListType)$ Subsubcategory:\n\t\t<<SelectSubSubCategory>>\n\t</$reveal>\n</$reveal>\n\\end\n\n\\define thisMainBody()\n<div mode=block>\n\n$(ListType)$ Name: ''__<$view field='title'/>__''\n\n$(ListType)$ Category: \n<$select tiddler=<<currentTiddler>> field='category'>\n\t<option value=''>--</option>\n\t<$list filter='[[$:/data/$(ListType)$ListCategories]indexes[]]'>\n\t\t<option>\n\t\t\t<$view tiddler=<<currentTiddler>> field=title/>\n\t\t</option>\n\t</$list>\n</$select>\n(<$button popup='$:/state/Edit$(ListType)$/AddCategoryPopup'>New Category</$button>)\n<$reveal type=popup state='$:/state/Edit$(ListType)$/AddCategoryPopup'>\n\t<div class='tc-drop-down tc-popup-keep' style='position:absolute'>\n\t\tCategory Name:\n\t\t<$edit-text tiddler=$:/temp/Edit$(ListType)$' field='new_category_name' placeholder='New Category Name'/> \n\t\t<$button>\n\t\t\tCreate Category\n\t\t\t<$action-setfield $tiddler='$:/data/$(ListType)$ListCategories' $index={{$:/temp/Edit$(ListType)$!!new_category_name}} $value=1/>\n\t\t\t<$action-setfield $tiddler='$:/temp/Edit$(ListType)$' $field='new_category_name' $value=''/>\n\t\t</$button>\n\t</div>\n</$reveal>\n<br>\n<$set name=ThisCategory value={{!!category}}>\n\t<$set name=ThisSubCategory value={{!!subcategory}}>\n\t\t<<thisSelectSubCategoryAndSubSubCategory>>\n\t</$set>\n</$set>\n\nShort Description: \n<$edit-text field='description' class='tc-edit-texteditor' placeholder='Short Description'/>\n\nDetails: \n<$edit-text field='text' class='tc-edit-texteditor' placeholder='Details'/>\n\n\nTags:\n\nAdd tag: <$select tiddler='$:/state/Edit$(ListType)$' field='selected_tag'>\n\t<$list filter='[[$:/data/$(ListType)$ListTags]indexes[]]'>\n\t\t<option>\n\t\t\t<<currentTiddler>>\n\t\t</option>\n\t</$list>\n</$select>\n<$fieldmangler tiddler=<<currentTiddler>>>\n\t<$button>Add Tag\n\t\t<$action-sendmessage $message='tm-add-tag' $param={{$:/state/Edit$(ListType)$!!selected_tag}}/>\n\t</$button>\n</$fieldmangler> (<$button popup='$:/state/Edit$(ListType)$/AddTagPopup'>New Tag</$button>)\n<$reveal type='popup' state='$:/state/Edit$(ListType)$/AddTagPopup'>\n\t<div class='tc-drop-down tc-popup-keep'>\n\t\tTag Name: <$edit-text tiddler='$:/temp/Edit$(ListType)$' field='new_tag_name' placeholder='New Tag Name'/>\n\t\t<$button>Create Tag\n\t\t\t<$action-setfield $tiddler='$:/data/$(ListType)$ListTags' $index={{$:/temp/Edit$(ListType)$!!new_tag_name}} $value=1/>\n\t\t\t<$action-setfield $tiddler='$:/temp/Edit$(ListType)$' $field='new_tag_name' $value=''/>\n\t\t</$button>\n\t</div>\n</$reveal>\n\nCurrent Tags:\n\n<$list filter='[is[current]tags[]]-[[$(Tag)$]]-[[$(FinishedTag)$]]' variable=ThisTag>\n<$fieldmangler tiddler=<<currentTiddler>>>\n<<ThisTag>> <$button>Remove<$action-sendmessage $message='tm-remove-tag' $param=<<ThisTag>>/></$button>\n</$fieldmangler><br>\n</$list>\n</div>\n\\end\n\n<<thisMainBody>>"
},
"$:/plugins/inmysocks/CategoryLists/Finished Items": {
"caption": "Finished Items",
"tags": "",
"title": "$:/plugins/inmysocks/CategoryLists/Finished Items",
"text": "\\define thisListTemplate()\n<$reveal type='match' state='$:/plugins/inmysocks/CategoryLists/CategoryLists!!task' text=$(ListType)$ tag=tr>\n\t<td style=\"\"\"position:relative;width:5%;\"\"\">\n\t\t<$button class=\"\"\"tc-btn-invisible\"\"\" popup=\"\"\"$:/state/popup/$(ListType)$list/$(CurrentEntry)$\"\"\" tooltip='$(ListType)$ Info'>{{$:/core/images/info-button}}\n\t\t</$button>\n\t\t<<thisEntryPopup>>\n\t</td>\n\t<td style='width:5%;'>\n\t\t<$checkbox tiddler=<<CurrentEntry>> tag=\"\"\"$(FinishedTag)$\"\"\"/>\n\t</td>\n\t<td style=\"\"\"width:50%\"\"\">\n\t\t<$link to=<<CurrentEntry>>>\n\t\t\t<$view tiddler=<<CurrentEntry>> field=\"\"\"title\"\"\"/>\n\t\t</$link>\n\t</td>\n\t<td style=\"\"\"width:40%\"\"\">\n\t\t<$view tiddler=<<CurrentEntry>> field=\"\"\"description\"\"\"/>\n\t</td>\n\t<td style='position:relative;'>\n\t\t<$button class='tc-btn-invisible' tooltip='Edit $(ListType)$' popup=\"\"\"$:/state/Edit$(ListType)$/popup/$(CurrentEntry)$\"\"\">\n\t\t\t{{$:/core/images/edit-button}}\n\t\t</$button>\n\t</td>\n\t<td style=\"\"\"text-align:right;width:10%\"\"\">\n\t\t<$fieldmangler tiddler=<<CurrentEntry>>>\n\t\t\t<$button class='tc-btn-invisible' tooltip='Remove $(ListType)$'>{{$:/core/images/cancel-button}}\n\t\t\t\t<$action-sendmessage $message=\"\"\"tm-remove-tag\"\"\" $param=\"\"\"$(Tag)$\"\"\"/>\n\t\t\t\t<$action-sendmessage $message=\"\"\"tm-remove-tag\"\"\" $param=\"\"\"$(FinishedTag)$\"\"\"/>\n\t\t\t</$button>\n\t\t</$fieldmangler>\n\t</td>\n</$reveal>\n<$reveal type='match' state='$:/plugins/inmysocks/CategoryLists/CategoryLists!!event' text=$(ListType)$ tag=tr>\n\t<td style=\"\"\"position:relative;width:5%;\"\"\">\n\t\t<$button class=\"\"\"tc-btn-invisible\"\"\" popup=\"\"\"$:/state/popup/$(ListType)$list/$(CurrentEntry)$\"\"\" tooltip='$(ListType)$ Info'>{{$:/core/images/info-button}}\n\t\t</$button>\n\t\t<<thisEntryPopup>>\n\t</td>\n\t<td style='position:relative;'>\n\t\t<$button class='tc-btn-invisible' tooltip='Edit $(ListType)$' popup=\"\"\"$:/state/Edit$(ListType)$/popup/$(CurrentEntry)$\"\"\">\n\t\t\t{{$:/core/images/edit-button}}\n\t\t</$button>\n\t</td>\n\t<td style=\"\"\"width:50%\"\"\">\n\t\t<$link to=<<CurrentEntry>>>\n\t\t\t<$view tiddler=<<CurrentEntry>> field=\"\"\"title\"\"\"/>\n\t\t</$link>\n\t</td>\n\t<td style=\"\"\"width:40%\"\"\">\n\t\t<$view tiddler=<<CurrentEntry>> field=\"\"\"description\"\"\"/>\n\t</td>\n\t<td style=\"\"\"text-align:right;width:20%\"\"\">\n\t\t<$view tiddler=<<CurrentEntry>> field='start_day'/>/<$view tiddler=<<CurrentEntry>> field='start_month'/>/<$view tiddler=<<CurrentEntry>> field='start_year'/>\n\t</td>\n</$reveal>\n<tr>\n\t<td colspan=6 style='position:relative;top:100%'>\n\t\t<$reveal type='popup' state=\"\"\"$:/state/Edit$(ListType)$/popup/$(CurrentEntry)$\"\"\">\n\t\t\t<div class='tc-popup-keep' style='border:solid;border-color:grey;border-width:1px;background-color:white;max-width:800px;padding:1em;width:95vw;top:1em;position:absolute;max-width:700px;top:-1em'>\n\n\t\t\t\t<$tiddler tiddler=<<CurrentEntry>>>\n\n\t\t\t\t\t<$transclude tiddler='$:/plugins/inmysocks/CategoryLists/EditEntryTemplate' mode=block/>\n\n\t\t\t\t</$tiddler>\n\n\t\t\t</div>\n\t\t</$reveal>\n\t</td>\n</tr>\n\\end\n\n\\define thisEntryPopup()\n<$reveal type=\"\"\"popup\"\"\" state=\"\"\"$:/state/popup/$(ListType)$list/$(CurrentEntry)$\"\"\">\n\t<div class=\"\"\"tc-popup-keep tc-drop-down\"\"\">\n\n\t\t<$transclude tiddler=<<CurrentEntry>> mode=block/>\n\n\t</div>\n</$reveal>\n\\end\n\n\\define thisMakeShowCategoryButton()\n<$list filter='[[$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$]!text[show]]'>\n\t<$button class='tc-btn-invisible' style='width:100%;height:100%;' set=\"\"\"$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$\"\"\" setTo=show>\n\t\t<div style='width:100%;text-align:left;position:absolute;'>\n\t\t\t{{$:/core/images/right-arrow}}\n\t\t</div>\n\t\t<div style='width:100%;position:absolute;text-align:center;'>\n\t\t\t<$view tiddler=<<CurrentCategory>> field=\"\"\"title\"\"\"/>\n\t\t</div>\n\t\t<div style='width:100%;text-align:right;'>\n\t\t\t{{$:/core/images/left-arrow}}\n\t\t</div>\n\t</$button>\n</$list>\n<$list filter='[[$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$]text[show]]'>\n\t<$button class='tc-btn-invisible' style='width:100%;height:100%;' set=\"\"\"$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$\"\"\" setTo=hide>\n\t\t<div style='width:100%;text-align:left;position:absolute;'>\n\t\t\t{{$:/core/images/down-arrow}}\n\t\t</div>\n\t\t<div style='width:100%;position:absolute;text-align:center;'>\n\t\t\t<$view tiddler=<<CurrentCategory>> field=\"\"\"title\"\"\"/>\n\t\t</div>\n\t\t<div style='width:100%;text-align:right;'>\n\t\t\t{{$:/core/images/down-arrow}}\n\t\t</div>\n\t</$button>\n</$list>\n\\end\n\n\\define thisMakeCurrentCategoryDisplayState()\n$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$\n\\end\n\n\\define thisMakeShowSubCategoryButton()\n<$list filter='[[$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$]!text[show]]'>\n\t<$button class='tc-btn-invisible' style='width:100%;height:100%;position:relative;' set=\"\"\"$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$\"\"\" setTo=show>\n\t\t<div style='width:100%;text-align:left;position:absolute'>\n\t\t\t{{$:/core/images/right-arrow}}\n\t\t</div>\n\t\t<div style='width:100%;text-align:center;position:absolute'>\n\t\t\t<$view tiddler=\"\"\"$(CurrentCategory)$\"\"\" field=\"\"\"title\"\"\"/> : <$view tiddler=\"\"\"$(CurrentSubCategory)$\"\"\" field=\"\"\"title\"\"\"/>\n\t\t</div>\n\t\t<div style='width:100%;text-align:right;position:relative;'>\n\t\t\t{{$:/core/images/left-arrow}}\n\t\t</div>\n\t</$button>\n</$list>\n<$list filter='[[$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$]text[show]]'>\n\t<$button class='tc-btn-invisible' style='width:100%;height:100%;position:relative;' set=\"\"\"$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$\"\"\" setTo=hide>\n\t\t<div style='width:100%;text-align:left;position:absolute;'>\n\t\t\t{{$:/core/images/down-arrow}}\n\t\t</div>\n\t\t<div style='width:100%;text-align:center;position:absolute;'>\n\t\t\t<$view tiddler=\"\"\"$(CurrentCategory)$\"\"\" field=\"\"\"title\"\"\"/> : <$view tiddler=\"\"\"$(CurrentSubCategory)$\"\"\" field=\"\"\"title\"\"\"/>\n\t\t</div>\n\t\t<div style='width:100%;text-align:right;position:relative;'>\n\t\t\t{{$:/core/images/down-arrow}}\n\t\t</div>\n\t</$button>\n</$list>\n\\end\n\n\\define thisMakeCurrentSubCategoryDisplayState()\n$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$\n\\end\n\n\\define thisMakeShowSubSubCategoryButton()\n<$list filter='[[$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$/$(CurrentSubSubCategory)$]!text[show]]'>\n\t<$button class='tc-btn-invisible' style='width:100%;height:100%;position:relative;background-color:beige;' set=\"\"\"$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$/$(CurrentSubSubCategory)$\"\"\" setTo=show>\n\t\t<div style='width:100%;text-align:center;'>\n\t\t\t{{$:/core/images/right-arrow}} <$view tiddler=\"\"\"$(CurrentCategory)$\"\"\" field=\"\"\"title\"\"\"/> : <$view tiddler=\"\"\"$(CurrentSubCategory)$\"\"\" field=\"\"\"title\"\"\"/> :<$view tiddler=\"\"\"$(CurrentSubSubCategory)$\"\"\" field=\"\"\"title\"\"\"/> {{$:/core/images/left-arrow}}\n\t\t</div>\n\t</$button>\n</$list>\n<$list filter='[[$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$/$(CurrentSubSubCategory)$]text[show]]'>\n\t<$button class='tc-btn-invisible' style='width:100%;height:100%;position:relative;background-color:beige;' set=\"\"\"$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$/$(CurrentSubSubCategory)$\"\"\" setTo=hide>\n\t\t<div style='width:100%;text-align:center;'>\n\t\t\t{{$:/core/images/down-arrow}} <$view tiddler=\"\"\"$(CurrentCategory)$\"\"\" field=\"\"\"title\"\"\"/> : <$view tiddler=\"\"\"$(CurrentSubCategory)$\"\"\" field=\"\"\"title\"\"\"/> : <$view tiddler=\"\"\"$(CurrentSubSubCategory)$\"\"\" field=\"\"\"title\"\"\"/> {{$:/core/images/down-arrow}}\n\t\t</div>\n\t</$button>\n</$list>\n\\end\n\n\\define thisMakeCurrentSubSubCategoryDisplayState()\n$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$/$(CurrentSubSubCategory)$\n\\end\n\n\\define thisMakeTable()\n<table style=\"\"\"position:relative;width:100%\"\"\">\n\t<$set name=CurrentCategory value='No Category'>\n\t\t<$list filter=\"\"\"[tag[$(Tag)$]tag[$(FinishedTag)$]$(SearchTag)$$(SelectedCategory)$$(SelectedSubCategory)$$(SelectedSubSubCategory)$regexp[(?i)$(RegExpSearch)$]!has[category]!has[draft.of]limit[1]]\"\"\">\n\t\t\t<tr>\n\t\t\t\t<th colspan=6 style=\"\"\"background-color:grey\"\"\">\n\t\t\t\t\t<<thisMakeShowCategoryButton>>\n\t\t\t\t</th>\n\t\t\t</tr>\n\t\t</$list>\n\t\t<$list filter='[<thisMakeCurrentCategoryDisplayState>text[show]]'>\n\t\t\t<$list filter=\"\"\"[tag[$(Tag)$]tag[$(FinishedTag)$]$(SearchTag)$$(SelectedCategory)$$(SelectedSubCategory)$$(SelectedSubSubCategory)$regexp[(?i)$(RegExpSearch)$]!has[category]!has[draft.of]sort[title]]\"\"\" variable=CurrentEntry>\n\t\t\t\t<<thisListTemplate>>\n\t\t\t</$list>\n\t\t</$list>\n\t</$set>\n\t<$list filter=\"\"\"[tag[$(Tag)$]tag[$(FinishedTag)$]$(SearchTag)$$(SelectedCategory)$$(SelectedSubCategory)$$(SelectedSubSubCategory)$regexp[(?i)$(RegExpSearch)$]has[category]each[category]get[category]!has[draft.of]sort[title]]\"\"\" variable=\"\"\"CurrentCategory\"\"\">\n\t\t<tr style='width:100%;'>\n\t\t\t<th colspan=6 style=\"\"\"background-color:grey\"\"\">\n\t\t\t\t<<thisMakeShowCategoryButton>>\n\t\t\t</th>\n\t\t</tr>\n\t\t<$list filter='[<thisMakeCurrentCategoryDisplayState>text[show]]'>\n\t\t\t<$list filter=\"\"\"[tag[$(Tag)$]tag[$(FinishedTag)$]$(SearchTag)$$(SelectedCategory)$$(SelectedSubCategory)$$(SelectedSubSubCategory)$regexp[(?i)$(RegExpSearch)$]category<CurrentCategory>!has[subcategory]!has[draft.of]sort[title]]\"\"\" variable=CurrentEntry>\n\t\t\t\t<<thisListTemplate>>\n\t\t\t</$list>\n\t\t\t<$list filter=\"\"\"[tag[$(Tag)$]tag[$(FinishedTag)$]$(SearchTag)$$(SelectedCategory)$$(SelectedSubCategory)$$(SelectedSubSubCategory)$regexp[(?i)$(RegExpSearch)$]category<CurrentCategory>has[subcategory]each[subcategory]get[subcategory]!has[draft.of]sort[title]]\"\"\" variable=\"\"\"CurrentSubCategory\"\"\">\n\t\t\t\t<tr style='width:100%;position:relative;background-color:lightgrey'>\n\t\t\t\t\t<td colspan=2 style='width:10%'>\n\t\t\t\t\t</td>\n\t\t\t\t\t<th colspan=2 style=\"\"\"position:relative;width:80%;background-color:lightgrey\"\"\">\n\t\t\t\t\t\t<<thisMakeShowSubCategoryButton>>\n\t\t\t\t\t</th>\n\t\t\t\t\t<td colspan=2 style='width:10%'>\n\t\t\t\t\t</td>\n\t\t\t\t</tr>\n\t\t\t\t<$list filter='[<thisMakeCurrentSubCategoryDisplayState>text[show]]'>\n\t\t\t\t\t<$list filter=\"\"\"[tag[$(Tag)$]tag[$(FinishedTag)$]$(SearchTag)$$(SelectedCategory)$$(SelectedSubCategory)$$(SelectedSubSubCategory)$regexp[(?i)$(RegExpSearch)$]!has[subsubcategory]category<CurrentCategory>subcategory<CurrentSubCategory>!has[draft.of]sort[title]]\"\"\" variable=CurrentEntry>\n\t\t\t\t\t\t<<thisListTemplate>>\n\t\t\t\t\t</$list>\n\t\t\t\t\t<$list filter=\"\"\"[tag[$(Tag)$]tag[$(FinishedTag)$]$(SearchTag)$$(SelectedCategory)$$(SelectedSubCategory)$$(SelectedSubSubCategory)$regexp[(?i)$(RegExpSearch)$]category<CurrentCategory>subcategory<CurrentSubCategory>has[subsubcategory]each[subsubcategory]get[subsubcategory]!has[draft.of]sort[title]]\"\"\" variable=\"\"\"CurrentSubSubCategory\"\"\">\n\t\t\t\t\t\t<tr style='width:100%;background-color:beige'>\n\t\t\t\t\t\t\t<td colspan=2 style='width:10%;'>\n\t\t\t\t\t\t\t</td>\n\t\t\t\t\t\t\t<th colspan=2 style=\"\"\"position:relative;width:80%;background-color:beige;\"\"\">\n\t\t\t\t\t\t\t\t<<thisMakeShowSubSubCategoryButton>>\n\t\t\t\t\t\t\t</th>\n\t\t\t\t\t\t\t<td colspan=2 style='width:10%;'>\n\t\t\t\t\t\t\t</td>\n\t\t\t\t\t\t</tr>\n\t\t\t\t\t\t<$list filter='[<thisMakeCurrentSubSubCategoryDisplayState>text[show]]'>\n\t\t\t\t\t\t\t<$list filter=\"\"\"[tag[$(Tag)$]tag[$(FinishedTag)$]$(SearchTag)$$(SelectedCategory)$$(SelectedSubCategory)$$(SelectedSubSubCategory)$regexp[(?i)$(RegExpSearch)$]category<CurrentCategory>subcategory<CurrentSubCategory>subsubcategory<CurrentSubSubCategory>!has[draft.of]sort[title]]\"\"\" variable=CurrentEntry>\n\t\t\t\t\t\t\t\t<<thisListTemplate>>\n\t\t\t\t\t\t\t</$list>\n\t\t\t\t\t\t</$list>\n\t\t\t\t\t</$list>\n\t\t\t\t</$list>\n\t\t\t</$list>\n\t\t</$list>\n\t</$list>\n</table>\n\\end\n\n\\define thisMakeSelectedCategory()\ncategory[$(CurrentCategory)$]\n\\end\n\n\\define thisMakeSelectedSubCategory()\nsubcategory[$(CurrentSubCategory)$]\n\\end\n\n\\define thisMakeSelectedSubSubCategory()\nsubsubcategory[$(CurrentSubSubCategory)$]\n\\end\n\n\\define thisMainBody()\n<$set name=RegExpSearch value={{$:/temp/$(ListType)$List/Search!!search_text}}>\n\t<!-- Category Selected -->\n\t<$reveal type='nomatch' state='$:/state/$(ListType)$List/SelectedCategory' text=''>\n\t\t<!-- Subcategory Selected -->\n\t\t<$reveal type='nomatch' state='$:/state/$(ListType)$List/SelectedSubCategory' text=''>\n\t\t\t<!-- Subsubcategory Selected -->\n\t\t\t<$reveal type='nomatch' state='$:/state/$(ListType)$List/SelectedSubSubCategory' text=''>\n\t\t\t\t<$set name=CurrentCategory value={{$:/state/$(ListType)$List/SelectedCategory}}>\n\t\t\t\t\t<$set name=SelectedCategory value=<<thisMakeSelectedCategory>>>\n\t\t\t\t\t\t<$set name=CurrentSubCategory value={{$:/state/$(ListType)$List/SelectedSubCategory}}>\n\t\t\t\t\t\t\t<$set name=SelectedSubCategory value=<<thisMakeSelectedSubCategory>>>\n\t\t\t\t\t\t\t\t<$set name=CurrentSubSubCategory value={{$:/state/$(ListType)$List/SelectedSubSubCategory}}>\n\t\t\t\t\t\t\t\t\t<$set name=SelectedSubSubCategory value=<<thisMakeSelectedSubSubCategory>>>\n\t\t\t\t\t\t\t\t\t\t<<thisMakeTable>>\n\t\t\t\t\t\t\t\t\t</$set>\n\t\t\t\t\t\t\t\t</$set>\n\t\t\t\t\t\t\t</$set>\n\t\t\t\t\t\t</$set>\n\t\t\t\t\t</$set>\n\t\t\t\t</$set>\n\t\t\t</$reveal>\n\t\t\t<!-- No Subsubcategory Selected -->\n\t\t\t<$reveal type='match' state='$:/state/$(ListType)$List/SelectedSubSubCategory' text=''>\n\t\t\t\t<$set name=CurrentCategory value={{$:/state/$(ListType)$List/SelectedCategory}}>\n\t\t\t\t\t<$set name=SelectedCategory value=<<thisMakeSelectedCategory>>>\n\t\t\t\t\t\t<$set name=CurrentSubCategory value={{$:/state/$(ListType)$List/SelectedSubCategory}}>\n\t\t\t\t\t\t\t<$set name=SelectedSubCategory value=<<thisMakeSelectedSubCategory>>>\n\t\t\t\t\t\t\t\t<<thisMakeTable>>\n\t\t\t\t\t\t\t</$set>\n\t\t\t\t\t\t</$set>\n\t\t\t\t\t</$set>\n\t\t\t\t</$set>\n\t\t\t</$reveal>\n\t\t</$reveal>\n\t\t<!-- No Subcategory Selected -->\n\t\t<$reveal type='match' state='$:/state/$(ListType)$List/SelectedSubCategory' text=''>\n\t\t\t<$set name=CurrentCategory value={{$:/state/$(ListType)$List/SelectedCategory}}>\n\t\t\t\t<$set name=SelectedCategory value=<<thisMakeSelectedCategory>>>\n\t\t\t\t\t<<thisMakeTable>>\n\t\t\t\t</$set>\n\t\t\t</$set>\n\t\t</$reveal>\n\t</$reveal>\n\t<!-- No Selected Category -->\n\t<$reveal type='match' state='$:/state/$(ListType)$List/SelectedCategory' text=''>\n\t\t<<thisMakeTable>>\n\t</$reveal>\n</$set>\n\\end\n\n<<thisMainBody>>"
},
"$:/plugins/inmysocks/CategoryLists/Make Entry": {
"caption": "Make Entry",
"tags": "",
"title": "$:/plugins/inmysocks/CategoryLists/Make Entry",
"text": "\\define CreateEntryButton()\n<$fieldmangler tiddler={{$:/temp/Make$(ListType)$!!task_name}}>\n\t<$button>Create $(ListType)$\n\t\t<$reveal type='nomatch' state='$:/temp/Make$(ListType)$!!category' text=''>\n\t\t\t<$action-setfield $tiddler={{$:/temp/Make$(ListType)$!!task_name}} $field=category $value={{$:/temp/Make$(ListType)$!!category}}/>\n\t\t\t<$list filter='[[$:/data/$(ListType)$ListCategories/$(ThisCategory)$/SubCategories]indexes[]]'>\n\t\t\t\t<$list filter='[[$:/temp/Make$(ListType)$]has[category]subcategory<currentTiddler>limit[1]]'>\n\t\t\t\t\t<$action-setfield $tiddler={{$:/temp/Make$(ListType)$!!task_name}} $field=subcategory $value={{$:/temp/Make$(ListType)$!!subcategory}}/>\n\t\t\t\t\t<$list filter='[[$:/data/$(ListType)$ListCategories/$(ThisCategory)$/$(ThisSubCategory)$/subsubcategories]indexes[]]'>\n\t\t\t\t\t\t<$list filter='[[$:/temp/Make$(ListType)$]has[subsubcategory]subsubcategory<currentTiddler>limit[1]]'>\n\t\t\t\t\t\t\t<$action-setfield $tiddler={{$:/temp/Make$(ListType)$!!task_name}} $field=subsubcategory $value={{$:/temp/Make$(ListType)$!!subsubcategory}}/>\n\t\t\t\t\t\t</$list>\n\t\t\t\t\t</$list>\n\t\t\t\t</$list>\n\t\t\t</$list>\n\t\t</$reveal>\n\t\t<$action-setfield $tiddler={{$:/temp/Make$(ListType)$!!task_name}} $field=description $value={{$:/temp/Make$(ListType)$!!short_description}}/>\n\t\t<$action-setfield $tiddler={{$:/temp/Make$(ListType)$!!task_name}} $field=text $value={{$:/temp/Make$(ListType)$!!text}}/>\n\t\t<$action-setfield $tiddler={{$:/temp/Make$(ListType)$!!task_name}} $field=tags $value={{$:/temp/Make$(ListType)$!!tags}}/>\n\t\t<$action-setfield $tiddler={{$:/temp/Make$(ListType)$!!task_name}} $field=start_day $value={{$:/temp/Make$(ListType)$!!start_day}}/>\n\t\t<$action-setfield $tiddler={{$:/temp/Make$(ListType)$!!task_name}} $field=start_month $value={{$:/temp/Make$(ListType)$!!start_month}}/>\n\t\t<$action-setfield $tiddler={{$:/temp/Make$(ListType)$!!task_name}} $field=start_year $value={{$:/temp/Make$(ListType)$!!start_year}}/>\n\t\t<$action-setfield $tiddler={{$:/temp/Make$(ListType)$!!task_name}} $field=due_day $value={{$:/temp/Make$(ListType)$!!due_day}}/>\n\t\t<$action-setfield $tiddler={{$:/temp/Make$(ListType)$!!task_name}} $field=due_month $value={{$:/temp/Make$(ListType)$!!due_month}}/>\n\t\t<$action-setfield $tiddler={{$:/temp/Make$(ListType)$!!task_name}} $field=due_year $value={{$:/temp/Make$(ListType)$!!due_year}}/>\n\t\t<$action-setfield $tiddler={{$:/temp/Make$(ListType)$!!task_name}} $field=created_day $value=<<now 0DD>>/>\n\t\t<$action-setfield $tiddler={{$:/temp/Make$(ListType)$!!task_name}} $field=created_month $value=<<now 0MM>>/>\n\t\t<$action-setfield $tiddler={{$:/temp/Make$(ListType)$!!task_name}} $field=created_year $value=<<now YYYY>>/>\n\t\t<$action-setfield $tiddler='$:/temp/Make$(ListType)$' $field=short_description $value=''/>\n\t\t<$action-setfield $tiddler='$:/temp/Make$(ListType)$' $field=text $value=''/>\n\t\t<$action-setfield $tiddler='$:/temp/Make$(ListType)$' $field=task_name $value=''/>\n\t\t<$action-setfield $tiddler='$:/temp/Make$(ListType)$' $field=tags $value=''/>\n\t\t<$action-sendmessage $message=tm-add-tag $param=\"\"\"$(Tag)$\"\"\"/>\n\t</$button>\n</$fieldmangler>\n\\end\n\n\\define SelectSubcategory()\n<$select tiddler='$:/temp/Make$(ListType)$' field='subcategory'>\n\t<option value=''>--</option>\n\t<$list filter='[[$:/data/$(ListType)$ListCategories/$(ThisCategory)$/SubCategories]indexes[]]'>\n\t\t<option>\n\t\t\t<$view tiddler=<<currentTiddler>> field=title/>\n\t\t</option>\n\t</$list>\n</$select>\n(<$button popup='$:/state/Make$(ListType)$/AddSubcategoryPopup'>New Subcategory\n</$button>)\n<$reveal type=popup state='$:/state/Make$(ListType)$/AddSubcategoryPopup'>\n\t<div class='tc-drop-down tc-popup-keep'>\n\t\tSubcategory Name:\n\t\t<$edit-text tiddler='$:/temp/Make$(ListType)$' field='new_subcategory_name' placeholder='New Subcategory Name'/> \n\t\t<$button>\n\t\t\tCreate Subcategory\n\t\t\t<$action-setfield $tiddler='$:/data/$(ListType)$ListCategories/$(ThisCategory)$/SubCategories' $index={{$:/temp/Make$(ListType)$!!new_subcategory_name}} $value=1/>\n\t\t\t<$action-setfield $tiddler='$:/temp/Make$(ListType)$' $field='new_subcategory_name' $value=''/>\n\t\t</$button>\n\t</div>\n</$reveal>\n\\end\n\n\\define SelectSubSubCategory()\n<$select tiddler='$:/temp/Make$(ListType)$' field='subsubcategory'>\n\t<option value=''>--</option>\n\t<$list filter='[[$:/data/$(ListType)$ListCategories/$(ThisCategory)$/$(ThisSubCategory)$/subsubcategories]indexes[]]'>\n\t\t<option>\n\t\t\t<$view tiddler=<<currentTiddler>> field=title/>\n\t\t</option>\n\t</$list>\n</$select>\n(<$button popup='$:/state/Make$(ListType)$/AddSubSubcategoryPopup'>New Subsubcategory\n</$button>)\n<$reveal type=popup state='$:/state/Make$(ListType)$/AddSubSubcategoryPopup'>\n\t<div class='tc-drop-down tc-popup-keep'>\n\t\tSubsubcategory Name:\n\t\t<$edit-text tiddler='$:/temp/Make$(ListType)$' field='new_subsubcategory_name' placeholder='New Subsubcategory Name'/> \n\t\t<$button>\n\t\t\tCreate Subsubcategory\n\t\t\t<$action-setfield $tiddler='$:/data/$(ListType)$ListCategories/$(ThisCategory)$/$(ThisSubCategory)$/subsubcategories' $index={{$:/temp/Make$(ListType)$!!new_subsubcategory_name}} $value=1/>\n\t\t\t<$action-setfield $tiddler='$:/temp/Make$(ListType)$' $field='new_subsubcategory_name' $value=''/>\n\t\t</$button>\n\t</div>\n</$reveal>\n\\end\n\n\\define thisSelectSubCategoryAndSubSubCategory()\n<$reveal type='nomatch' state='$:/temp/Make$(ListType)$!!category' text=''>\n\t$(ListType)$ Subcategory:\n\t<<SelectSubcategory>>\n\t<br>\n\t<$list filter='[[$:/data/$(ListType)$ListCategories/$(ThisCategory)$/SubCategories]indexes[]]'>\n\t\t<$reveal type='match' state='$:/temp/Make$(ListType)$!!subcategory' text=<<currentTiddler>>>\n\t\t\t$(ListType)$ Subsubcategory:\n\t\t\t<<SelectSubSubCategory>>\n\t\t</$reveal>\n\t</$list>\n</$reveal>\n\\end\n\n\\define thisSetStartDate()\nDay: <$select tiddler='$:/temp/Make$(ListType)$' field='start_day'><option value=''>--</option><$list filter='1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31'><option><<currentTiddler>></option></$list></$select>\nMonth: <$select tiddler='$:/temp/Make$(ListType)$' field='start_month'><option value=''>--</option><$list filter='1 2 3 4 5 6 7 8 9 10 11 12'><option><<currentTiddler>></option></$list></$select>\nYear: <$select tiddler='$:/temp/Make$(ListType)$' field='start_year'><option value=''>--</option><$list filter='2015 2016 2017 2018 2019 2020'><option><<currentTiddler>></option></$list></$select>\n\\end\n\n\\define thisSetDueDate()\nDay: <$select tiddler='$:/temp/Make$(ListType)$' field='due_day'><option value=''>--</option><$list filter='1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31'><option><<currentTiddler>></option></$list></$select>\nMonth: <$select tiddler='$:/temp/Make$(ListType)$' field='due_month'><option value=''>--</option><$list filter='1 2 3 4 5 6 7 8 9 10 11 12'><option><<currentTiddler>></option></$list></$select>\nYear: <$select tiddler='$:/temp/Make$(ListType)$' field='due_year'><option value=''>--</option><$list filter='2015 2016 2017 2018 2019 2020'><option><<currentTiddler>></option></$list></$select>\n\\end\n\n\\define thisMainBody()\n$(ListType)$ Name: <$edit-text tiddler='$:/temp/Make$(ListType)$' field='task_name' class='tc-edit-texteditor' placeholder='$(ListType)$ Name'/>\n\n$(ListType)$ Category: \n<$select tiddler='$:/temp/Make$(ListType)$' field='category'>\n\t<option value=''>--</option>\n\t<$list filter='[[$:/data/$(ListType)$ListCategories]indexes[]]'>\n\t\t<option>\n\t\t\t<$view tiddler=<<currentTiddler>> field=title/>\n\t\t</option>\n\t</$list>\n</$select>\n(<$button popup='$:/state/Make$(ListType)$/AddCategoryPopup'>New Category</$button>)\n<$reveal type=popup state='$:/state/Make$(ListType)$/AddCategoryPopup'>\n\t<div class='tc-drop-down tc-popup-keep'>\n\t\tCategory Name:\n\t\t<$edit-text tiddler='$:/temp/Make$(ListType)$' field='new_category_name' placeholder='New Category Name'/> \n\t\t<$button>\n\t\t\tCreate Category\n\t\t\t<$action-setfield $tiddler='$:/data/$(ListType)$ListCategories' $index={{$:/temp/Make$(ListType)$!!new_category_name}} $value=1/>\n\t\t\t<$action-setfield $tiddler='$:/temp/Make$(ListType)$' $field='new_category_name' $value=''/>\n\t\t</$button>\n\t</div>\n</$reveal>\n<br>\n<$set name=ThisCategory value={{$:/temp/Make$(ListType)$!!category}}>\n\t<$set name=ThisSubCategory value={{$:/temp/Make$(ListType)$!!subcategory}}>\n\t\t<<thisSelectSubCategoryAndSubSubCategory>>\n\t</$set>\n</$set>\n\nShort Description: \n<$edit-text tiddler='$:/temp/Make$(ListType)$' field='short_description' class='tc-edit-texteditor' placeholder='Short Description'/>\n\nDetails: \n<$edit-text tiddler='$:/temp/Make$(ListType)$' field='text' class='tc-edit-texteditor' placeholder='Details'/>\n\nStart Date:<br>\n<<thisSetStartDate>>\n\nDue Date:<br>\n<<thisSetDueDate>>\n\nTags:\n\nAdd tag: <$select tiddler='$:/temp/Make$(ListType)$' field='selected_tag'>\n\t<$list filter='[[$:/data/$(ListType)$ListTags]indexes[]]'>\n\t\t<option>\n\t\t\t<<currentTiddler>>\n\t\t</option>\n\t</$list>\n</$select>\n<$fieldmangler tiddler='$:/temp/Make$(ListType)$'>\n\t<$button>Add Tag\n\t\t<$action-sendmessage $message='tm-add-tag' $param={{$:/temp/Make$(ListType)$!!selected_tag}}/>\n\t</$button>\n</$fieldmangler> (<$button popup='$:/state/Make$(ListType)$/AddTagPopup'>New Tag</$button>)\n<$reveal type='popup' state='$:/state/Make$(ListType)$/AddTagPopup'>\n\t<div class='tc-drop-down tc-popup-keep'>\n\t\tTag Name: <$edit-text tiddler='$:/temp/Make$(ListType)$' field='new_tag_name' placeholder='New Tag Name'/>\n\t\t<$button>Create Tag\n\t\t\t<$action-setfield $tiddler='$:/data/$(ListType)$ListTags' $index={{$:/temp/Make$(ListType)$!!new_tag_name}} $value=1/>\n\t\t\t<$action-setfield $tiddler='$:/temp/Make$(ListType)$' $field='new_tag_name' $value=''/>\n\t\t</$button>\n\t</div>\n</$reveal>\n\nCurrent Tags:\n\n<$list filter='[[$:/temp/Make$(ListType)$]tags[]]'>\n<$fieldmangler tiddler='$:/temp/Make$(ListType)$'>\n<$view field='title'/> <$button>Remove<$action-sendmessage $message='tm-remove-tag' $param=<<currentTiddler>>/></$button>\n</$fieldmangler><br>\n</$list>\n\n<$set name=ThisCategory value={{$:/temp/Make$(ListType)$!!category}}>\n\t<$set name=ThisSubCategory value={{$:/temp/Make$(ListType)$!!subcategory}}>\n\t\t<$list filter='[{$:/temp/Make$(ListType)$!!task_name}has[title]]' emptyMessage=<<CreateEntryButton>>>\n\t\t\t''Your task has the same name as another tiddler, change the task name. You can edit tasks using the [[task editor]]''\n\t\t</$list>\n\t</$set>\n</$set>\n\\end\n\n<<thisMainBody>>"
},
"$:/plugins/inmysocks/CategoryLists/Unfinished Items": {
"caption": "Unfinished Items",
"tags": "",
"title": "$:/plugins/inmysocks/CategoryLists/Unfinished Items",
"text": "\\define thisListTemplate()\n<$reveal type='match' state='$:/plugins/inmysocks/CategoryLists/CategoryLists!!task' text=$(ListType)$ tag=tr>\n\t<td style=\"\"\"position:relative;width:5%;\"\"\">\n\t\t<$button class=\"\"\"tc-btn-invisible\"\"\" popup=\"\"\"$:/state/popup/$(ListType)$list/$(CurrentEntry)$\"\"\" tooltip='$(ListType)$ Info'>{{$:/core/images/info-button}}\n\t\t</$button>\n\t\t<<thisEntryPopup>>\n\t</td>\n\t<td style='width:5%;'>\n\t\t<$checkbox tiddler=<<CurrentEntry>> tag=\"\"\"$(FinishedTag)$\"\"\"/>\n\t</td>\n\t<td style=\"\"\"width:50%\"\"\">\n\t\t<$link to=<<CurrentEntry>>>\n\t\t\t<$view tiddler=<<CurrentEntry>> field=\"\"\"title\"\"\"/>\n\t\t</$link>\n\t</td>\n\t<td style=\"\"\"width:40%\"\"\">\n\t\t<$view tiddler=<<CurrentEntry>> field=\"\"\"description\"\"\"/>\n\t</td>\n\t<td style='position:relative;'>\n\t\t<$button class='tc-btn-invisible' tooltip='Edit $(ListType)$' popup=\"\"\"$:/state/Edit$(ListType)$/popup/$(CurrentEntry)$\"\"\">\n\t\t\t{{$:/core/images/edit-button}}\n\t\t</$button>\n\t</td>\n\t<td style=\"\"\"text-align:right;width:10%\"\"\">\n\t\t<$fieldmangler tiddler=<<CurrentEntry>>>\n\t\t\t<$button class='tc-btn-invisible' tooltip='Remove $(ListType)$'>{{$:/core/images/cancel-button}}\n\t\t\t\t<$action-sendmessage $message=\"\"\"tm-remove-tag\"\"\" $param=\"\"\"$(Tag)$\"\"\"/>\n\t\t\t\t<$action-sendmessage $message=\"\"\"tm-remove-tag\"\"\" $param=\"\"\"$(FinishedTag)$\"\"\"/>\n\t\t\t</$button>\n\t\t</$fieldmangler>\n\t</td>\n</$reveal>\n<$reveal type='match' state='$:/plugins/inmysocks/CategoryLists/CategoryLists!!event' text=$(ListType)$ tag=tr>\n\t<td style=\"\"\"position:relative;width:5%;\"\"\">\n\t\t<$button class=\"\"\"tc-btn-invisible\"\"\" popup=\"\"\"$:/state/popup/$(ListType)$list/$(CurrentEntry)$\"\"\" tooltip='$(ListType)$ Info'>{{$:/core/images/info-button}}\n\t\t</$button>\n\t\t<<thisEntryPopup>>\n\t</td>\n\t<td style='position:relative;'>\n\t\t<$button class='tc-btn-invisible' tooltip='Edit $(ListType)$' popup=\"\"\"$:/state/Edit$(ListType)$/popup/$(CurrentEntry)$\"\"\">\n\t\t\t{{$:/core/images/edit-button}}\n\t\t</$button>\n\t</td>\n\t<td style=\"\"\"width:50%\"\"\">\n\t\t<$link to=<<CurrentEntry>>>\n\t\t\t<$view tiddler=<<CurrentEntry>> field=\"\"\"title\"\"\"/>\n\t\t</$link>\n\t</td>\n\t<td style=\"\"\"width:40%\"\"\">\n\t\t<$view tiddler=<<CurrentEntry>> field=\"\"\"description\"\"\"/>\n\t</td>\n\t<td style=\"\"\"text-align:right;width:20%\"\"\">\n\t\t<$view tiddler=<<CurrentEntry>> field='start_day'/>/<$view tiddler=<<CurrentEntry>> field='start_month'/>/<$view tiddler=<<CurrentEntry>> field='start_year'/>\n\t</td>\n</$reveal>\n<tr>\n\t<td colspan=6 style='position:relative;top:100%'>\n\t\t<$reveal type='popup' state=\"\"\"$:/state/Edit$(ListType)$/popup/$(CurrentEntry)$\"\"\">\n\t\t\t<div class='tc-popup-keep' style='border:solid;border-color:grey;border-width:1px;background-color:white;max-width:800px;padding:1em;width:95vw;top:1em;position:absolute;max-width:700px;top:-1em'>\n\n\t\t\t\t<$tiddler tiddler=<<CurrentEntry>>>\n\n\t\t\t\t\t<$transclude tiddler='$:/plugins/inmysocks/CategoryLists/EditEntryTemplate' mode=block/>\n\n\t\t\t\t</$tiddler>\n\n\t\t\t</div>\n\t\t</$reveal>\n\t</td>\n</tr>\n\\end\n\n\\define thisEntryPopup()\n<$reveal type=\"\"\"popup\"\"\" state=\"\"\"$:/state/popup/$(ListType)$list/$(CurrentEntry)$\"\"\">\n\t<div class=\"\"\"tc-popup-keep tc-drop-down\"\"\">\n\n\t\t<$transclude tiddler=<<CurrentEntry>> mode=block/>\n\n\t</div>\n</$reveal>\n\\end\n\n\\define thisMakeShowCategoryButton()\n<$list filter='[[$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$]!text[show]]'>\n\t<$button class='tc-btn-invisible' style='width:100%;height:100%;' set=\"\"\"$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$\"\"\" setTo=show>\n\t\t<div style='width:100%;text-align:left;position:absolute;'>\n\t\t\t{{$:/core/images/right-arrow}}\n\t\t</div>\n\t\t<div style='width:100%;position:absolute;text-align:center;'>\n\t\t\t<$view tiddler=<<CurrentCategory>> field=\"\"\"title\"\"\"/>\n\t\t</div>\n\t\t<div style='width:100%;text-align:right;'>\n\t\t\t{{$:/core/images/left-arrow}}\n\t\t</div>\n\t</$button>\n</$list>\n<$list filter='[[$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$]text[show]]'>\n\t<$button class='tc-btn-invisible' style='width:100%;height:100%;' set=\"\"\"$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$\"\"\" setTo=hide>\n\t\t<div style='width:100%;text-align:left;position:absolute;'>\n\t\t\t{{$:/core/images/down-arrow}}\n\t\t</div>\n\t\t<div style='width:100%;position:absolute;text-align:center;'>\n\t\t\t<$view tiddler=<<CurrentCategory>> field=\"\"\"title\"\"\"/>\n\t\t</div>\n\t\t<div style='width:100%;text-align:right;'>\n\t\t\t{{$:/core/images/down-arrow}}\n\t\t</div>\n\t</$button>\n</$list>\n\\end\n\n\\define thisMakeCurrentCategoryDisplayState()\n$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$\n\\end\n\n\\define thisMakeShowSubCategoryButton()\n<$list filter='[[$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$]!text[show]]'>\n\t<$button class='tc-btn-invisible' style='width:100%;height:100%;position:relative;' set=\"\"\"$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$\"\"\" setTo=show>\n\t\t<div style='width:100%;text-align:left;position:absolute'>\n\t\t\t{{$:/core/images/right-arrow}}\n\t\t</div>\n\t\t<div style='width:100%;text-align:center;position:absolute'>\n\t\t\t<$view tiddler=\"\"\"$(CurrentCategory)$\"\"\" field=\"\"\"title\"\"\"/> : <$view tiddler=\"\"\"$(CurrentSubCategory)$\"\"\" field=\"\"\"title\"\"\"/>\n\t\t</div>\n\t\t<div style='width:100%;text-align:right;position:relative;'>\n\t\t\t{{$:/core/images/left-arrow}}\n\t\t</div>\n\t</$button>\n</$list>\n<$list filter='[[$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$]text[show]]'>\n\t<$button class='tc-btn-invisible' style='width:100%;height:100%;position:relative;' set=\"\"\"$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$\"\"\" setTo=hide>\n\t\t<div style='width:100%;text-align:left;position:absolute;'>\n\t\t\t{{$:/core/images/down-arrow}}\n\t\t</div>\n\t\t<div style='width:100%;text-align:center;position:absolute;'>\n\t\t\t<$view tiddler=\"\"\"$(CurrentCategory)$\"\"\" field=\"\"\"title\"\"\"/> : <$view tiddler=\"\"\"$(CurrentSubCategory)$\"\"\" field=\"\"\"title\"\"\"/>\n\t\t</div>\n\t\t<div style='width:100%;text-align:right;position:relative;'>\n\t\t\t{{$:/core/images/down-arrow}}\n\t\t</div>\n\t</$button>\n</$list>\n\\end\n\n\\define thisMakeCurrentSubCategoryDisplayState()\n$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$\n\\end\n\n\\define thisMakeShowSubSubCategoryButton()\n<$list filter='[[$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$/$(CurrentSubSubCategory)$]!text[show]]'>\n\t<$button class='tc-btn-invisible' style='width:100%;height:100%;position:relative;background-color:beige;' set=\"\"\"$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$/$(CurrentSubSubCategory)$\"\"\" setTo=show>\n\t\t<div style='width:100%;text-align:center;'>\n\t\t\t{{$:/core/images/right-arrow}} <$view tiddler=\"\"\"$(CurrentCategory)$\"\"\" field=\"\"\"title\"\"\"/> : <$view tiddler=\"\"\"$(CurrentSubCategory)$\"\"\" field=\"\"\"title\"\"\"/> :<$view tiddler=\"\"\"$(CurrentSubSubCategory)$\"\"\" field=\"\"\"title\"\"\"/> {{$:/core/images/left-arrow}}\n\t\t</div>\n\t</$button>\n</$list>\n<$list filter='[[$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$/$(CurrentSubSubCategory)$]text[show]]'>\n\t<$button class='tc-btn-invisible' style='width:100%;height:100%;position:relative;background-color:beige;' set=\"\"\"$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$/$(CurrentSubSubCategory)$\"\"\" setTo=hide>\n\t\t<div style='width:100%;text-align:center;'>\n\t\t\t{{$:/core/images/down-arrow}} <$view tiddler=\"\"\"$(CurrentCategory)$\"\"\" field=\"\"\"title\"\"\"/> : <$view tiddler=\"\"\"$(CurrentSubCategory)$\"\"\" field=\"\"\"title\"\"\"/> : <$view tiddler=\"\"\"$(CurrentSubSubCategory)$\"\"\" field=\"\"\"title\"\"\"/> {{$:/core/images/down-arrow}}\n\t\t</div>\n\t</$button>\n</$list>\n\\end\n\n\\define thisMakeCurrentSubSubCategoryDisplayState()\n$:/state/$(ListType)$List/ShowCategory/$(CurrentCategory)$/$(CurrentSubCategory)$/$(CurrentSubSubCategory)$\n\\end\n\n\\define thisMakeTable()\n<table style=\"\"\"position:relative;width:100%\"\"\">\n\t<$set name=CurrentCategory value='No Category'>\n\t\t<$list filter=\"\"\"[tag[$(Tag)$]!tag[$(FinishedTag)$]$(SearchTag)$$(SelectedCategory)$$(SelectedSubCategory)$$(SelectedSubSubCategory)$regexp[(?i)$(RegExpSearch)$]!has[category]!has[draft.of]limit[1]]\"\"\">\n\t\t\t<tr>\n\t\t\t\t<th colspan=6 style=\"\"\"background-color:grey\"\"\">\n\t\t\t\t\t<<thisMakeShowCategoryButton>>\n\t\t\t\t</th>\n\t\t\t</tr>\n\t\t</$list>\n\t\t<$list filter='[<thisMakeCurrentCategoryDisplayState>text[show]]'>\n\t\t\t<$list filter=\"\"\"[tag[$(Tag)$]!tag[$(FinishedTag)$]$(SearchTag)$$(SelectedCategory)$$(SelectedSubCategory)$$(SelectedSubSubCategory)$regexp[(?i)$(RegExpSearch)$]!has[category]!has[draft.of]sort[title]]\"\"\" variable=CurrentEntry>\n\t\t\t\t<<thisListTemplate>>\n\t\t\t</$list>\n\t\t</$list>\n\t</$set>\n\t<$list filter=\"\"\"[tag[$(Tag)$]!tag[$(FinishedTag)$]$(SearchTag)$$(SelectedCategory)$$(SelectedSubCategory)$$(SelectedSubSubCategory)$regexp[(?i)$(RegExpSearch)$]has[category]each[category]get[category]!has[draft.of]sort[title]]\"\"\" variable=\"\"\"CurrentCategory\"\"\">\n\t\t<tr style='width:100%;'>\n\t\t\t<th colspan=6 style=\"\"\"background-color:grey\"\"\">\n\t\t\t\t<<thisMakeShowCategoryButton>>\n\t\t\t</th>\n\t\t</tr>\n\t\t<$list filter='[<thisMakeCurrentCategoryDisplayState>text[show]]'>\n\t\t\t<$list filter=\"\"\"[tag[$(Tag)$]!tag[$(FinishedTag)$]$(SearchTag)$$(SelectedCategory)$$(SelectedSubCategory)$$(SelectedSubSubCategory)$regexp[(?i)$(RegExpSearch)$]category<CurrentCategory>!has[subcategory]!has[draft.of]sort[title]]\"\"\" variable=CurrentEntry>\n\t\t\t\t<<thisListTemplate>>\n\t\t\t</$list>\n\t\t\t<$list filter=\"\"\"[tag[$(Tag)$]!tag[$(FinishedTag)$]$(SearchTag)$$(SelectedCategory)$$(SelectedSubCategory)$$(SelectedSubSubCategory)$regexp[(?i)$(RegExpSearch)$]category<CurrentCategory>has[subcategory]each[subcategory]get[subcategory]!has[draft.of]sort[title]]\"\"\" variable=\"\"\"CurrentSubCategory\"\"\">\n\t\t\t\t<tr style='width:100%;position:relative;background-color:lightgrey'>\n\t\t\t\t\t<td colspan=2 style='width:10%'>\n\t\t\t\t\t</td>\n\t\t\t\t\t<th colspan=2 style=\"\"\"position:relative;width:80%;background-color:lightgrey\"\"\">\n\t\t\t\t\t\t<<thisMakeShowSubCategoryButton>>\n\t\t\t\t\t</th>\n\t\t\t\t\t<td colspan=2 style='width:10%'>\n\t\t\t\t\t</td>\n\t\t\t\t</tr>\n\t\t\t\t<$list filter='[<thisMakeCurrentSubCategoryDisplayState>text[show]]'>\n\t\t\t\t\t<$list filter=\"\"\"[tag[$(Tag)$]!tag[$(FinishedTag)$]$(SearchTag)$$(SelectedCategory)$$(SelectedSubCategory)$$(SelectedSubSubCategory)$regexp[(?i)$(RegExpSearch)$]!has[subsubcategory]category<CurrentCategory>subcategory<CurrentSubCategory>!has[draft.of]sort[title]]\"\"\" variable=CurrentEntry>\n\t\t\t\t\t\t<<thisListTemplate>>\n\t\t\t\t\t</$list>\n\t\t\t\t\t<$list filter=\"\"\"[tag[$(Tag)$]!tag[$(FinishedTag)$]$(SearchTag)$$(SelectedCategory)$$(SelectedSubCategory)$$(SelectedSubSubCategory)$regexp[(?i)$(RegExpSearch)$]category<CurrentCategory>subcategory<CurrentSubCategory>has[subsubcategory]each[subsubcategory]get[subsubcategory]!has[draft.of]sort[title]]\"\"\" variable=\"\"\"CurrentSubSubCategory\"\"\">\n\t\t\t\t\t\t<tr style='width:100%;background-color:beige'>\n\t\t\t\t\t\t\t<td colspan=2 style='width:10%;'>\n\t\t\t\t\t\t\t</td>\n\t\t\t\t\t\t\t<th colspan=2 style=\"\"\"position:relative;width:80%;background-color:beige;\"\"\">\n\t\t\t\t\t\t\t\t<<thisMakeShowSubSubCategoryButton>>\n\t\t\t\t\t\t\t</th>\n\t\t\t\t\t\t\t<td colspan=2 style='width:10%;'>\n\t\t\t\t\t\t\t</td>\n\t\t\t\t\t\t</tr>\n\t\t\t\t\t\t<$list filter='[<thisMakeCurrentSubSubCategoryDisplayState>text[show]]'>\n\t\t\t\t\t\t\t<$list filter=\"\"\"[tag[$(Tag)$]!tag[$(FinishedTag)$]$(SearchTag)$$(SelectedCategory)$$(SelectedSubCategory)$$(SelectedSubSubCategory)$regexp[(?i)$(RegExpSearch)$]category<CurrentCategory>subcategory<CurrentSubCategory>subsubcategory<CurrentSubSubCategory>!has[draft.of]sort[title]]\"\"\" variable=CurrentEntry>\n\t\t\t\t\t\t\t\t<<thisListTemplate>>\n\t\t\t\t\t\t\t</$list>\n\t\t\t\t\t\t</$list>\n\t\t\t\t\t</$list>\n\t\t\t\t</$list>\n\t\t\t</$list>\n\t\t</$list>\n\t</$list>\n</table>\n\\end\n\n\\define thisMakeSelectedCategory()\ncategory[$(CurrentCategory)$]\n\\end\n\n\\define thisMakeSelectedSubCategory()\nsubcategory[$(CurrentSubCategory)$]\n\\end\n\n\\define thisMakeSelectedSubSubCategory()\nsubsubcategory[$(CurrentSubSubCategory)$]\n\\end\n\n\\define thisMainBody()\n<$set name=RegExpSearch value={{$:/temp/$(ListType)$List/Search!!search_text}}>\n\t<!-- Category Selected -->\n\t<$reveal type='nomatch' state='$:/state/$(ListType)$List/SelectedCategory' text=''>\n\t\t<!-- Subcategory Selected -->\n\t\t<$reveal type='nomatch' state='$:/state/$(ListType)$List/SelectedSubCategory' text=''>\n\t\t\t<!-- Subsubcategory Selected -->\n\t\t\t<$reveal type='nomatch' state='$:/state/$(ListType)$List/SelectedSubSubCategory' text=''>\n\t\t\t\t<$set name=CurrentCategory value={{$:/state/$(ListType)$List/SelectedCategory}}>\n\t\t\t\t\t<$set name=SelectedCategory value=<<thisMakeSelectedCategory>>>\n\t\t\t\t\t\t<$set name=CurrentSubCategory value={{$:/state/$(ListType)$List/SelectedSubCategory}}>\n\t\t\t\t\t\t\t<$set name=SelectedSubCategory value=<<thisMakeSelectedSubCategory>>>\n\t\t\t\t\t\t\t\t<$set name=CurrentSubSubCategory value={{$:/state/$(ListType)$List/SelectedSubSubCategory}}>\n\t\t\t\t\t\t\t\t\t<$set name=SelectedSubSubCategory value=<<thisMakeSelectedSubSubCategory>>>\n\t\t\t\t\t\t\t\t\t\t<<thisMakeTable>>\n\t\t\t\t\t\t\t\t\t</$set>\n\t\t\t\t\t\t\t\t</$set>\n\t\t\t\t\t\t\t</$set>\n\t\t\t\t\t\t</$set>\n\t\t\t\t\t</$set>\n\t\t\t\t</$set>\n\t\t\t</$reveal>\n\t\t\t<!-- No Subsubcategory Selected -->\n\t\t\t<$reveal type='match' state='$:/state/$(ListType)$List/SelectedSubSubCategory' text=''>\n\t\t\t\t<$set name=CurrentCategory value={{$:/state/$(ListType)$List/SelectedCategory}}>\n\t\t\t\t\t<$set name=SelectedCategory value=<<thisMakeSelectedCategory>>>\n\t\t\t\t\t\t<$set name=CurrentSubCategory value={{$:/state/$(ListType)$List/SelectedSubCategory}}>\n\t\t\t\t\t\t\t<$set name=SelectedSubCategory value=<<thisMakeSelectedSubCategory>>>\n\t\t\t\t\t\t\t\t<<thisMakeTable>>\n\t\t\t\t\t\t\t</$set>\n\t\t\t\t\t\t</$set>\n\t\t\t\t\t</$set>\n\t\t\t\t</$set>\n\t\t\t</$reveal>\n\t\t</$reveal>\n\t\t<!-- No Subcategory Selected -->\n\t\t<$reveal type='match' state='$:/state/$(ListType)$List/SelectedSubCategory' text=''>\n\t\t\t<$set name=CurrentCategory value={{$:/state/$(ListType)$List/SelectedCategory}}>\n\t\t\t\t<$set name=SelectedCategory value=<<thisMakeSelectedCategory>>>\n\t\t\t\t\t<<thisMakeTable>>\n\t\t\t\t</$set>\n\t\t\t</$set>\n\t\t</$reveal>\n\t</$reveal>\n\t<!-- No Selected Category -->\n\t<$reveal type='match' state='$:/state/$(ListType)$List/SelectedCategory' text=''>\n\t\t<<thisMakeTable>>\n\t</$reveal>\n</$set>\n\\end\n\n<<thisMainBody>>"
},
"$:/plugins/inmysocks/CategoryLists/readme": {
"title": "$:/plugins/inmysocks/CategoryLists/readme",
"text": "At the moment this is presented as a task list, but it can be used for other things. I am currently using it as an [[issue tracker and change log|http://inmysocks.tiddlyspot.com/#Change%20Log]] for the work I do with TiddlyWiki.\n\n__Description:__\n\nA list split into categories. You can see an example [[here|http://inmysocks.tiddlyspot.com/#Change%20Log]]. Clicking on a section title collapses that section, clicking on the {{$:/core/images/info-button}} icon gives information about the task, the checkbox marks the task as finished, the {{$:/core/images/edit-button}} lets you edit a task and the {{$:/core/images/cancel-button}} removes the task from the list, if you are using a task list.\n\n__Features:__\n\n*multiple independent lists are possibly by changing the `Tag` and `FinishedTag` parameters\n*task list or event list\n*collapsible categories\n*collapse all/expand all\n*searchable by title\n*searchable by category\n*searchable by tag\n*task creation interface\n*remove old entries (this just removes the tags that label it for the list, it doesn't delete the tiddler)\n*start dates\n*due dates*\n*task creation date*\n@@font-size:12px; *At the moment these values aren't used by the list, but I am planning on integrating the task list with my [[calendar plugin|http://inmysocks.tiddlyspot.com/#Calendar%20Plugin]] so that tasks entered on the list can be made to appear on the calendar. @@\n\n__Planned features:__\n\n*add sorting options\n*making more lists types (the display options will be different, there may not be other differences)\n*integration with the [[calendar plugin|http://inmysocks.tiddlyspot.com/#Calendar%20Plugin]]\n*searchable by due, start and creation dates\n*set events as finished once their date has passed\n*(possibly) allow an infinite number of nested categories, this may not be practical\n\n__Usage:__\n\n```\n<<CategoryList Tag:\"Task\" FinishedTag:\"Done\" ListType:\"Task\" ShowAddItem:\"True\" ShowSearch:\"True\" ShowFinished:\"True\">>\n```\n\n__Parameters:__\n\n|!Name |!Description |\n|~Tag |The tag used to indicate that a tiddler should be on the list (Default: Task) |\n|~FinishedTag |The tag added to finished tasks (Default: Done) |\n|~ListType |The type of list to make, options are Task and Event (Default:Task) |\n|~ShowAddItem |If this is set to anything other than `True` the `New Task` button doesn't appear. (Default: True) |\n|~ShowSearch |If this is set to anything other than `True` than the search interface is hidden. (Default: True) |\n|~ShowFinished |If this is set to anything other than `True` than the finished tasks/events are hidden. (Default: True) |\n\n__Notes:__\n\nIf you only want to have a single task list using the tags `Task` and `Done` than simply using `<<CategoryList>>` will work. If you want to have another list that is independent of the first list you can just put `<<CategoryList Tag:\"School Task\">>`. You can have as many lists as you want by changing the `TaskTag`, and if you want the `FinishedTag`."
}
}
}
\define td-state() $:/state/todo/$(currentTiddler)$
\define td-kbd-state() $:/state/todo/kbd/$(currentTiddler)$
\define td-temp() $:/temp/todo/$(currentTiddler)$
\define td-new-actions()
<$list filter="[<td-temp>!is[missing]]" variable="stateCheck">
<$list filter="[<td-temp>!text[]]" variable="stateCheck">
<$action-createtiddler $basetitle="New Task" $savetitle="$:/temp/NewTid" tags="[[$(currentTiddler)$]]" task-title={{{ [<td-temp>get[text]] }}}/>
<$action-listops $tiddler="$(currentTiddler)$" $filter="[{$:/temp/NewTid}][list[$(currentTiddler)$]]"/>
<$action-deletetiddler $tiddler=<<td-temp>>/>
<$set name="currentTiddler" value="$(currentTiddler)$">
<$action-setfield $tiddler=<<td-state>> text="show"/>
</$set>
<$action-deletetiddler $tiddler="$:/temp/NewTid"/>
</$list>
</$list>
\end
\define td-drop-actions()
<$fieldmangler tiddler=<<actionTiddler>>>
<$vars motherTag={{{ [<currentTiddler>tags[]] }}}>
<$list filter="[<currentTiddler>!tag<actionTiddler>]" variable="checker">
<$list filter="[<currentTiddler>!tag<topmost>]" variable="checker">
<$action-setfield $tiddler=<<actionTiddler>> tags=""/>
<$action-listops $tiddler=<<motherTag>> $subfilter="+[insertbefore:currentTiddler<actionTiddler>]"/>
<$set name="currentTiddler" value={{{ [<currentTiddler>get[tags]] }}}>
<$action-setfield $tiddler=<<actionTiddler>> tags=<<currentTiddler>>/>
<$action-setfield $tiddler=<<td-state>> text="show"/>
</$set>
</$list>
<$list filter="[<currentTiddler>tag<topmost>]" variable="checker">
<$action-setfield $tiddler=<<actionTiddler>> tags=""/>
<$action-listops $tiddler=<<topmost>> $subfilter="+[insertbefore:currentTiddler<actionTiddler>]"/>
<$action-sendmessage $message="tm-add-tag" $param=<<topmost>>/>
<$set name="currentTiddler" value=<<topmost>>>
<$action-setfield $tiddler=<<td-state>> text="show"/>
</$set>
</$list>
</$list>
</$vars>
</$fieldmangler>
\end
\define td-drop-new-actions()
<$wikify name="curAsTag" text="""<$text text="[["/><<currentTiddler>><$text text="]]"/>""">
<$fieldmangler tiddler=<<actionTiddler>>>
<$vars motherTag={{{ [<currentTiddler>tags[]] }}}>
<$list filter="[<currentTiddler>!<actionTiddler>]" variable="checker">
<$action-setfield $tiddler=<<actionTiddler>> tags=""/>
<$action-listops $tiddler=<<currentTiddler>> $subfilter="+[prepend<actionTiddler>]"/>
<$action-setfield $tiddler=<<actionTiddler>> tags=<<curAsTag>>/>
<$action-setfield $tiddler=<<td-state>> text="show"/>
</$list>
</$vars>
</$fieldmangler>
</$wikify>
\end
\define td-check-actions-loop()
<$list filter="[all[shadows+tiddlers]tag<currentTiddler>]">
<$action-setfield task-finished="yes" task-finished-date=<<now [UTC]YYYY0MM0DD0hh0mm0ssXXX>>/>
<<td-check-actions-loop>>
</$list>
\end
\define td-check-actions(filter)
<$action-setfield task-finished="yes" task-finished-date=<<now [UTC]YYYY0MM0DD0hh0mm0ssXXX>>/>
<$action-listops $tiddler="$filter$" $filter="[list[$filter$]!<currentTiddler>!has[task-finished]][<currentTiddler>][list[$filter$]has[task-finished]]"/>
<$list filter="[all[shadows+tiddlers]tag<currentTiddler>]">
<$action-setfield task-finished="yes" task-finished-date=<<now [UTC]YYYY0MM0DD0hh0mm0ssXXX>>/>
<<td-check-actions-loop>>
</$list>
\end
\define td-uncheck-actions(filter)
<$action-deletefield task-finished task-finished-date/>
<$action-listops $tiddler="$filter$" $filter="[list[$filter$]!has[task-finished]][<currentTiddler>][list[$filter$]has[task-finished]]"/>
\end
\define td-purge-loop()
<$list filter="[all[shadows+tiddlers]tag<currentTiddler>task-finished[yes]]">
<$action-deletetiddler $tiddler=<<td-temp>>/>
<$action-deletetiddler $tiddler=<<td-state>>/>
<$navigator story=<<topmost>>>
<$action-sendmessage $message="tm-delete-tiddler" $param=<<currentTiddler>>/>
</$navigator>
<$list filter="[all[shadows+tiddlers]tag<currentTiddler>!task-finished[yes]]">
<$wikify name="curAsTag" text="""<$text text="[["/><<topmost>><$text text="]]"/>""">
<$action-setfield $tiddler=<<actionTiddler>> tags=<<curAsTag>>/>
</$wikify>
</$list>
<<td-purge-loop>>
</$list>
<$list filter="[all[shadows+tiddlers]tag<currentTiddler>!task-finished[yes]]">
<<td-purge-loop>>
</$list>
\end
\define td-purge-btn()
<$button class="tc-btn-invisible" tooltip="Purge done items (unfinished children will be brought out)">
{{$:/core/images/delete-button}}
<<td-purge-loop>>
</$button>
\end
\define td-delete-loop()
<$list filter="[all[shadows+tiddlers]tag<currentTiddler>]">
<$action-deletetiddler $tiddler=<<td-temp>>/>
<$action-deletetiddler $tiddler=<<td-state>>/>
<<td-delete-loop>>
<$navigator story={{{ [<currentTiddler>get[tags]] }}}>
<$action-sendmessage $message="tm-delete-tiddler" $param=<<currentTiddler>>/>
</$navigator>
</$list>
\end
\define td-delete-btn()
<$button class="tc-btn-invisible" tooltip="Delete item and its children">
{{$:/core/images/delete-button}}
<<td-delete-loop>>
<$action-deletetiddler $tiddler=<<td-temp>>/>
<$action-deletetiddler $tiddler=<<td-state>>/>
<$navigator story=<<topmost>>>
<$action-sendmessage $message="tm-delete-tiddler" $param=<<currentTiddler>>/>
</$navigator>
</$button>
\end
\define td-badge-color-btn()
<$wikify name="style" text="""
<$list filter="[<currentTiddler>!color[]]" variable="checkColor">
border: 1px solid {{!!color}};
</$list>
<$list filter="[<currentTiddler>color[]]" variable="checkColor">
border: 1px solid <<colour tiddler-controls-foreground>>;
</$list>
""">
<$button class="tc-btn-invisible td-count-badge" tooltip="Badge color" popup={{{ [<currentTiddler>addprefix[$:/state/badge/]] }}} style=<<style>>>
</$button>
</$wikify>
<$reveal type="popup" state={{{ [<currentTiddler>addprefix[$:/state/badge/]] }}} position="belowleft" animate="yes" retain="yes">
<div class="tc-drop-down td-count-badge-color" style="min-width: 6em; padding: 0;">
<$button class="tc-btn-invisible" style="background: Crimson;" set="!!color" setTo="Crimson">
</$button>
<$button class="tc-btn-invisible" style="background: LimeGreen;" set="!!color" setTo="LimeGreen">
</$button>
<$button class="tc-btn-invisible" style="background: MediumBlue;" set="!!color" setTo="MediumBlue">
</$button>
<$button class="tc-btn-invisible" style="background: Gold;" set="!!color" setTo="Gold">
</$button>
<$button class="tc-btn-invisible" set="!!color" setTo="">
remove color
</$button>
</div>
</$reveal>
\end
\define td-toggle-children-btn()
<$wikify name="style" text="""
<$list filter="[<currentTiddler>!color[]]" variable="checkColor">
border: 1px solid {{!!color}};
<$list filter="[all[shadows+tiddlers]tag<currentTiddler>count[]]" variable="count">
<$list filter="[<count>prefix[0]]" variable="counted">
background: transparent !important;
</$list>
</$list>
<$list filter="[<td-state>!text[show]]" variable="checker">
background: {{!!color}};
color: rgba(255,255,255,.8);
</$list>
<$list filter="[<td-state>text[show]]" variable="checker">
color: {{!!color}};
</$list>
</$list>
<$list filter="[<currentTiddler>color[]]" variable="checkColor">
border: 1px solid <<colour tiddler-controls-foreground>>;
<$list filter="[all[shadows+tiddlers]tag<currentTiddler>count[]]" variable="count">
<$list filter="[<count>prefix[0]]" variable="counted">
background: transparent !important;
</$list>
</$list>
<$list filter="[<td-state>!text[show]]" variable="checker">
background: <<colour tiddler-controls-foreground>>;
color: rgba(255,255,255,.8);
</$list>
<$list filter="[<td-state>text[show]]" variable="checker">
color: <<colour tiddler-controls-foreground>>;
</$list>
</$list>
""">
<$button class="tc-btn-invisible td-count-badge" style=<<style>> tooltip="Toggle children">
<$list filter="[<currentTiddler>tagging[]has[task-finished]limit[1]]" variable="count">
<$text text={{{ [<currentTiddler>tagging[]has[task-finished]count[]addsuffix[ / ]] }}}/>
</$list>
<$list filter="[<currentTiddler>tagging[]limit[1]]" variable="count">
<$text text={{{ [<currentTiddler>tagging[]count[]] }}}/>
</$list>
<$list filter="[<td-state>!text[show]]" variable="stateCheck" emptyMessage="""
<$action-deletetiddler $tiddler=<<td-state>>/>
""">
<$action-setfield $tiddler=<<td-state>> text="show"/>
</$list>
</$button>
</$wikify>
\end
\define td-toggle-kbd-btn()
<$list filter="[<td-kbd-state>!text[yes]]" variable="stateCheck">
<$button class="tc-btn-invisible" tooltip="Add new child">
<$action-setfield $tiddler=<<td-kbd-state>> text="yes"/>
<$action-setfield $tiddler=<<td-state>> text="show"/>
{{$:/core/images/new-button}}
</$button>
</$list>
\end
\define td-kbd(filter)
<$list filter="[<td-kbd-state>text[yes]]" variable="stateCheck">
<div class="td-edit-wrapper-outer">
<$keyboard tag="div" class="td-texteditor-outer" key="escape" actions="""
<$action-deletetiddler $tiddler=<<td-temp>>/>
<$action-deletetiddler $tiddler=<<td-kbd-state>>/>
""">
<$keyboard tag="div" class="td-texteditor-outer" key="enter" actions=<<td-new-actions>>>
<div style="margin-left: -1em; width: 1em;">
↳
</div>
<$edit-text tiddler=<<td-temp>> tag="textarea" class="tc-edit-texteditor" placeholder="(cancel) to discard, (enter) to save" default="" minHeight="1em" rows="1" focus="yes"/>
</$keyboard>
</$keyboard>
<$list filter="[<currentTiddler>!has[draft.of]]" variable="stateCheck">
<div class="td-edit-buttons tc-tiddler-controls" style="align-items: flex-end; padding-bottom: .1em;">
<$button class="tc-btn-invisible" tooltip="Cancel">
<$action-deletetiddler $tiddler=<<td-temp>>/>
<$action-deletetiddler $tiddler=<<td-kbd-state>>/>
{{$:/core/images/cancel-button}}
</$button>
<$list filter="[<td-temp>!is[missing]]" variable="stateCheck">
<$list filter="[<td-temp>!text[]]" variable="stateCheck">
<$button class="tc-btn-invisible" tooltip="Save" actions=<<td-new-actions>>>
{{$:/core/images/save-button}}
</$button>
</$list>
</$list>
</div>
</$list>
</div>
</$list>
\end
\define td-inner(filter)
<$reveal type="match" state=<<td-state>> text="show" animate="yes" retain="yes" tag="div">
<$list filter="[all[shadows+tiddlers]tag<currentTiddler>]">
<$list filter="[draft.title<currentTiddler>!is[missing]]" variable="stateCheck" emptyMessage="""
<div class="td-wrapper">
<!-- view mode -->
<$list filter="[is[current]!has[draft.of]]" variable="stateCheck">
<$droppable actions=<<td-drop-actions>> tag="div">
<div class="tc-droppable-placeholder">
</div>
<div class="td-header-wrapper">
<div class="td-title-wrapper">
<div class="td-checkbox-container">
<$list filter="[<currentTiddler>task-finished[yes]]">
<$button actions=<<td-uncheck-actions "$filter$">> class="td-checkbox-done">
✔
</$button>
</$list>
<$list filter="[<currentTiddler>!task-finished[yes]]">
<$button actions=<<td-check-actions "$filter$">> class="td-checkbox">
</$button>
</$list>
</div>
<$droppable actions=<<td-drop-new-actions>> tag="div">
<$list filter="[<currentTiddler>has:field[task-finished]]">
<span class="tc-muted" style="text-decoration: line-through;">
<$transclude field="task-title"/>
</span>
<span class="tc-muted" style="margin-left: .5em;">
<$view field="task-finished-date" format="date" template="(MM/DD)"/>
</span>
</$list>
<$list filter="[<currentTiddler>!has:field[task-finished]]">
<$transclude field="task-title"/>
</$list>
<div class="tc-droppable-placeholder" style="margin-left: 1em;">
</div>
</$droppable>
</div>
<$navigator story="$filter$">
<$draggable tiddler=<<currentTiddler>> tag="div" class="td-edit-buttons tc-tiddler-controls">
<<td-toggle-kbd-btn>>
<$list filter="[all[shadows+tiddlers]tag<currentTiddler>limit[1]]" variable="checkState" emptyMessage=<<td-badge-color-btn>>>
<<td-toggle-children-btn>>
</$list>
<$set name="tv-config-toolbar-text" value="no">
{{||$:/core/ui/Buttons/edit}}
<<td-delete-btn>>
</$set>
</$draggable>
</$navigator>
</div>
</$droppable>
</$list>
<!-- view mode edit mode -->
<$reveal type="nomatch" state="!!draft.title" text="" animate="yes" retain="yes" tag="div">
<div class="td-edit-wrapper">
<$navigator story="$filter$">
<$keyboard tag="div" class="td-texteditor" style="margin: 0; padding: 0;" key="escape" message="tm-cancel-tiddler">
<$keyboard tag="div" style="margin-top: 1px;" key="enter" message="tm-save-tiddler">
<$edit-text field="task-title" tag="textarea" class="tc-edit-texteditor" placeholder="(cancel) to discard, (enter) to save" default="" minHeight="1em" rows="1" focus="yes"/>
</$keyboard>
</$keyboard>
<div class="td-edit-buttons tc-tiddler-controls">
<$set name="tv-config-toolbar-text" value="no">
{{||$:/core/ui/Buttons/save}}
<<td-badge-color-btn>>
{{||$:/core/ui/Buttons/cancel}}
<$button class="tc-btn-invisible" tooltip="Delete item and its children">
{{$:/core/images/delete-button}}
<$set name="currentTiddler" value={{!!draft.title}}>
<<td-delete-loop>>
</$set>
<$action-deletetiddler $tiddler=<<td-temp>>/>
<$action-deletetiddler $tiddler=<<td-state>>/>
<$navigator story=<<topmost>>>
<$action-sendmessage $message="tm-delete-tiddler" $param=<<currentTiddler>>/>
</$navigator>
</$button>
</$set>
</div>
</$navigator>
</div>
</$reveal>
<!-- edit mode -->
<$list filter="[<currentTiddler>has[draft.of]get[draft.title]]" variable="currentTiddler">
<<td-kbd>>
<$reveal type="match" state=<<td-state>> text="show" animate="yes" retain="yes" tag="div">
<$macrocall $name="td-inner" filter=<<currentTiddler>>/>
</$reveal>
</$list>
<$list filter="[<currentTiddler>!has[draft.of]]" variable="stateCheck">
<<td-kbd>>
<$reveal type="match" state=<<td-state>> text="show" animate="yes" retain="yes" tag="div">
<$macrocall $name="td-inner" filter=<<currentTiddler>>/>
</$reveal>
</$list>
</div>
""">
</$list>
</$list>
</$reveal>
\end
\define todo(filter)
<$vars currentTiddler="$filter$" motherTag="" topmost="$filter$">
<div class="td-main-wrapper">
<div class="td-header-wrapper">
<$view field="title"/>
<div class="td-edit-buttons tc-tiddler-controls" style="display: flex;">
<<td-toggle-kbd-btn>>
<$list filter="[all[shadows+tiddlers]tag<currentTiddler>limit[1]]" variable="checker">
<<td-toggle-children-btn>>
<<td-purge-btn>>
</$list>
</div>
</div>
<<td-kbd>>
<<td-inner "$filter$">>
</div>
</$vars>
\end
<style>
@media (max-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {
.demo-wrapper { font-size: 1.5em; } }
@media (min-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {
.tc-sidebar-lists .demo-wrapper { padding-right: 2em; } }
</style>
<div class="demo-wrapper">
<<todo "To Do">>
</div>
<pre>
.td-checkbox-container {
position: absolute;
top: 0;
left: 0;
width: 1em;
height: 1.2em;
display: flex;
align-items: center;
justify-content: flex-start;
}
.td-checkbox,
.td-checkbox-done {
display: flex;
align-items: center;
justify-content: center;
margin: 0;
margin-bottom: -.1em;
padding: 0;
line-height: 0;
width: 70%;
height: calc(70% - .1em);
font-size: .5em;
border: .5px solid rgba(0,0,0,.87);
background: rgba(255,255,255,.54);
}
.td-checkbox-done svg.tc-image-button {
line-height: 0;
width: 100%;
height: 100%;
}
.td-title-wrapper {
position: relative;
padding-left: 1em;
word-break: break-word;
}
.td-count-badge {
min-width: 1.4em;
min-height: 1.4em;
color: white;
display: flex;
align-items: center;
justify-content: center;
margin-right: .5em;
margin-left: .5em;
padding-left: .25em;
padding-right: .25em;
line-height: 1;
font-size: .5em;
border-radius: .7em;
transition: border-color {{$:/config/AnimationDuration}}ms, color {{$:/config/AnimationDuration}}ms;
}
.td-count-badge:hover {
border-color: <<colour tiddler-controls-foreground-hover>> !important;
color: <<colour tiddler-controls-foreground-hover>> !important;
}
.tc-btn-invisible.td-has-child svg {
fill: <<colour primary>>;
}
.td-count-badge.td-has-child {
background: <<colour tiddler-controls-foreground>>;
border: 1px solid <<colour tiddler-controls-foreground>>;
}
.td-count-badge.td-has-child-collapsed {
background: <<colour primary>>;
border: 1px solid <<colour primary>>;
}
.td-texteditor,
.td-texteditor-outer {
display: flex;
flex: 1 1 auto;
}
.td-texteditor .tc-keyboard {
width: 100%;
}
.td-main-wrapper ::placeholder,
.td-wrapper ::placeholder {
font-size: .5em;
vertical-align: bottom;
padding-left: .25em;
line-height: 2.4;
}
.td-texteditor textarea.tc-edit-texteditor,
.td-texteditor-outer textarea.tc-edit-texteditor {
width: 100%;
border: none;
border-bottom: 1px solid transparent;
font-weight: normal;
padding: .2em 0 .1em 0;
outline: none;
background: transparent;
<<box-shadow none>>
overflow-x: hidden; /* for firefox */
}
.td-texteditor textarea.tc-edit-texteditor {
margin: -.2em 0 -.1em 0;
}
.td-texteditor-outer textarea.tc-edit-texteditor {
margin: 0;
}
.td-texteditor textarea.tc-edit-texteditor,
.td-texteditor-outer textarea.tc-edit-texteditor:focus {
border-bottom: 1px solid <<colour primary>>;
}
div.td-edit-buttons.tc-tiddler-controls {
position: relative;
float: unset;
cursor: default;
font-size: 1.2em;
}
div.td-edit-buttons.tc-tiddler-controls .tc-reveal.tc-popup {
left: -2.5em !important;
top: 1em !important;
}
.td-wrapper {
padding-left: 1em;
margin: .1em 0;
line-height: 1.2;
}
.td-header-wrapper {
display: flex;
align-items: center;
justify-content: space-between;
}
.td-header-wrapper:hover .td-edit-buttons {
opacity: 1;
}
.td-edit-wrapper {
display: flex;
margin-left: 1em;
}
.td-edit-wrapper-outer {
display: flex;
margin-left: 2em;
}
.td-edit-wrapper-outer .td-edit-buttons,
.td-edit-wrapper .td-edit-buttons,
.td-wrapper .td-edit-buttons {
display: flex;
align-items: center;
align-self: flex-start;
flex: 0 0 auto;
min-height: 1.2em;
margin-left: .5em;
}
.td-edit-buttons button {
display: flex;
align-items: center;
justify-content: center;
}
</pre>
{
"tiddlers": {
"$:/plugins/kookma/shiraz/macro/alerts": {
"created": "20180821095049685",
"creator": "Mohammad",
"text": "\\define alert(type:\"primary\" text:\"\", width:\"100%\", class:\"\")\n<div class=\"alert alert-$type$ $class$\" style=\"width:$width$;\">\n$text$\n</div>\n\\end\n\n\\define alert-leftbar(type:\"primary\" text:\"\", width:\"100%\")\n<div class=\"alert bg-transparent leftbar border-$type$\" style=\"width:$width$;\">\n$text$\n</div>\n\\end\n<pre><$view/></pre>",
"title": "$:/plugins/kookma/shiraz/macro/alerts",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190109075227088"
},
"$:/plugins/kookma/shiraz/stylesheet/bs/alerts": {
"text": "/*Was taken from bootstrap 4.1.3*/\n.alert {\n position: relative;\n padding: 0.75rem 1.25rem;\n margin-bottom: 1rem;\n border: 1px solid transparent;\n border-radius: 0.25rem;\n}\n.alert-primary {\n color: #004085;\n background-color: #cce5ff;\n border-color: #b8daff;\n}\n\n.alert-primary hr {\n border-top-color: #9fcdff;\n}\n.alert-secondary {\n color: #383d41;\n background-color: #e2e3e5;\n border-color: #d6d8db;\n}\n\n.alert-secondary hr {\n border-top-color: #c8cbcf;\n}\n\n.alert-success {\n color: #155724;\n background-color: #d4edda;\n border-color: #c3e6cb;\n}\n\n.alert-success hr {\n border-top-color: #b1dfbb;\n}\n.alert-info {\n color: #0c5460;\n background-color: #d1ecf1;\n border-color: #bee5eb;\n}\n\n.alert-info hr {\n border-top-color: #abdde5;\n}\n.alert-warning {\n color: #856404;\n background-color: #fff3cd;\n border-color: #ffeeba;\n}\n\n.alert-warning hr {\n border-top-color: #ffe8a1;\n}\n\n.alert-danger {\n color: #721c24;\n background-color: #f8d7da;\n border-color: #f5c6cb;\n}\n\n.alert-danger hr {\n border-top-color: #f1b0b7;\n}\n.alert-light {\n color: #818182;\n background-color: #fefefe;\n border-color: #fdfdfe;\n}\n\n.alert-light hr {\n border-top-color: #ececf6;\n}\n.alert-dark {\n color: #1b1e21;\n background-color: #d6d8d9;\n border-color: #c6c8ca;\n}\n\n.alert-dark hr {\n border-top-color: #b9bbbe;\n}\n",
"type": "text/css",
"title": "$:/plugins/kookma/shiraz/stylesheet/bs/alerts",
"tags": "$:/tags/Stylesheet",
"modifier": "Mohammad",
"modified": "20181129200105625",
"creator": "Mohammad",
"created": "20180820171551129"
},
"$:/Commander": {
"text": "{{$:/plugins/kookma/commander/ui/search}}\n<<slider-ii title:\"$:/plugins/kookma/commander/ui/tiddler-selection\">>\n\n<<tabs \"[all[shadows+tiddlers]tag[$:/tags/Commander]!has[draft.of]]\" default:\"$:/plugins/kookma/commander/ui/tiddler-operation\" class:\"cm-tab-colorful\">>\n\n---\n<<slider-ii title:\"$:/plugins/kookma/commander/ui/log-status\">>\n",
"title": "$:/Commander",
"modifier": "Mohammad",
"modified": "20190314211552990",
"icon": "$:/core/images/list",
"creator": "Mohammad",
"created": "20190212051316149"
},
"$:/plugins/kookma/commander/authors": {
"created": "20190212051153468",
"creator": "Mohammad",
"text": "!! Author\n* [[Mohammad Rahmani|https://github.com/kookma]]\n\n!! Contributors\n* [[@MarxSal|https://github.com/Marxsal]]\n* [[@BurningTreeC|https://github.com/BurningTreeC]]\n\n!! Acknowledgement\n* Jeremy Ruston\n* Rob Hoelz\n* Ton Gerner\n* Jed Carty\n* Tobias Beer\n* Anthony Muscio\n* Birthe C\n* Thomas Elmiger\n* Diego Messa\n* ~TiddlyTweeter\n* Watt",
"title": "$:/plugins/kookma/commander/authors",
"tags": "",
"modifier": "Mohammad",
"modified": "20190315092739958"
},
"$:/plugins/kookma/commander/readme": {
"created": "20190212050942506",
"creator": "Mohammad",
"text": "!! What is Commander?\n{{$:/plugins/kookma/commander/help/what-is-commander}}\n\nFor help and instruction on usage, open [[Commander|$:/Commander]] help tab.\n\n!! References\n; Project code and demo\n* [[GitHub demo page|https://github.com/kookma/TW-Commander]]\n* [[GitHub code page|https://github.com/kookma/TW-Commander]]\n\n;Tiddler Commander at Tiddlywiki Google forum\n* [[Initial announcement|https://groups.google.com/d/msg/tiddlywiki/BxJsWuae-Uc/JapAx4mtBgAJ]]\n* [[Beta releases|https://groups.google.com/d/msg/tiddlywiki/w9Bv-WulKw8/CYf9D4H6BgAJ]]\n* [[Release candidate|https://groups.google.com/d/msg/tiddlywiki/Zw3F3iRtggA/qX2uWiBJBgAJ]]",
"title": "$:/plugins/kookma/commander/readme",
"tags": "",
"modifier": "Mohammad",
"modified": "20190315082415101"
},
"$:/plugins/kookma/commander/license": {
"text": "Distributed under an MIT license.\n\nCopyright (c) 2018-2019 [[Mohammad Rahmani|https://github.com/kookma]]\n\n<<<\nPermission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the \"Software\"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n<<<\n",
"type": "application/x-tiddler",
"title": "$:/plugins/kookma/commander/license",
"modifier": "Mohammad",
"modified": "20190214042147396",
"creator": "Mohammad",
"created": "20181101134530634"
},
"$:/plugins/kookma/commander/config/AutoFocus": {
"text": "yes",
"title": "$:/plugins/kookma/commander/config/AutoFocus",
"tags": "",
"modified": "20190212055450610",
"created": "20190212055413944"
},
"$:/plugins/kookma/commander/empty-tiddler": {
"text": "Dont delete. \nThis EMPTY tiddler is part of Tiddler Commander.",
"title": "$:/plugins/kookma/commander/empty-tiddler",
"tags": "",
"modifier": "Mohammad",
"modified": "20190309033535073",
"creator": "Mohammad",
"created": "20190309033436758"
},
"$:/plugins/kookma/commander/filters/Drafts": {
"text": "",
"title": "$:/plugins/kookma/commander/filters/Drafts",
"tags": "$:/tags/Commander/Filter",
"modified": "20190214135559126",
"filter": "[has[draft.of]sort[title]]",
"description": "{{$:/language/Filters/Drafts}}",
"created": "20190214135512125"
},
"$:/plugins/kookma/commander/filters/Missing": {
"text": "",
"title": "$:/plugins/kookma/commander/filters/Missing",
"tags": "$:/tags/Commander/Filter",
"modified": "20190214140051631",
"filter": "[all[missing]sort[title]]",
"description": "{{$:/language/Filters/Missing}}",
"created": "20190214140029091"
},
"$:/plugins/kookma/commander/filters/Orphans": {
"text": "",
"title": "$:/plugins/kookma/commander/filters/Orphans",
"tags": "$:/tags/Commander/Filter",
"modified": "20190214135606070",
"filter": "[all[orphans]sort[title]]",
"description": "{{$:/language/Filters/Orphans}}",
"created": "20190214135426497"
},
"$:/plugins/kookma/commander/filters/RecentSystemTiddlers": {
"text": "",
"title": "$:/plugins/kookma/commander/filters/RecentSystemTiddlers",
"tags": "$:/tags/Commander/Filter",
"modified": "20190214140014615",
"filter": "[has[modified]!sort[modified]limit[50]]",
"description": "{{$:/language/Filters/RecentSystemTiddlers}}",
"created": "20190214135950458"
},
"$:/plugins/kookma/commander/filters/RecentTiddlers": {
"text": "",
"title": "$:/plugins/kookma/commander/filters/RecentTiddlers",
"tags": "$:/tags/Commander/Filter",
"modified": "20190214135935814",
"filter": "[!is[system]has[modified]!sort[modified]limit[50]]",
"description": "{{$:/language/Filters/RecentTiddlers}}",
"created": "20190214135912493"
},
"$:/plugins/kookma/commander/filters/SessionTiddlers": {
"text": "",
"title": "$:/plugins/kookma/commander/filters/SessionTiddlers",
"tags": "$:/tags/Commander/Filter",
"modified": "20190214135859202",
"filter": "[haschanged[]]",
"description": "{{$:/language/Filters/SessionTiddlers}}",
"created": "20190214135831279"
},
"$:/plugins/kookma/commander/filters/StoryList": {
"text": "",
"title": "$:/plugins/kookma/commander/filters/StoryList",
"tags": "$:/tags/Commander/Filter",
"modified": "20190214135611326",
"filter": "[list[$:/StoryList]] -$:/AdvancedSearch",
"description": "{{$:/language/Filters/StoryList}}",
"created": "20190214135246552"
},
"$:/plugins/kookma/commander/filters/Test": {
"text": "",
"title": "$:/plugins/kookma/commander/filters/Test",
"tags": "$:/tags/Commander/Filter",
"modifier": "Mohammad",
"modified": "20190214141525226",
"filter": "[tag[xx]]",
"description": "Trial",
"creator": "Mohammad",
"created": "20190214141452091"
},
"$:/plugins/kookma/commander/filters/yourFilter": {
"text": "",
"title": "$:/plugins/kookma/commander/filters/yourFilter",
"tags": "$:/tags/Commander/Filter",
"modifier": "Mohammad",
"modified": "20190214155144617",
"filter": "[search:title[filters/your]]",
"description": "Mohammad Filter",
"creator": "Mohammad",
"created": "20190214155104262"
},
"$:/plugins/kookma/commander/help/batch-operation": {
"text": "Making the same changes to large numbers of tiddlers in TW5 can be repetetive and time consuming.\n\n* Batch operations work on groups of tiddlers at the same time and make changes 'in bulk', in one go.\n\n* Batch operations operate on groups of tiddlers that share matching criteria.\n\n* Tiddlers which share a common tag, a common field, a word in their title, or were created on the same day, month or year are all candidates for batch operations.\n\nAs a result batch operations can save users a great deal of time but, because they work on several tiddlers at once, the price of a mistake is multiplied! Back-up your wiki!\n\n!! Types of Batch operations :\n# Rename tiddlers\n#* use a totally new name\n#* add a suffix/prefix to title\n#* add prefix to title\n#* replace part of title\n#* add ordinal number to title \n#* Copy tiddlers (make duplicates)\n# Add/remove tag or any field\n# Change/replace the content of any field\n# Create multiple empty tiddlers (for lectures or a slideshow) with common properties (tag, field, part of text,...)\n# Capability to undo an operation at least one step back\n# Capability to get user confirmation before doing an operation\n",
"title": "$:/plugins/kookma/commander/help/batch-operation",
"tags": "$:/tags/Commander/Help",
"modifier": "Mohammad",
"modified": "20190315083628349",
"creator": "Mohammad",
"created": "20190315083511735",
"caption": "Batch operation"
},
"$:/plugins/kookma/commander/help/quick-tutorial": {
"text": "*Use ''Search via filter'' to list possible tiddlers\n*Use ''Select tiddlers'' for the resulting list to identify which specific tiddlers to do a batch operation on\n*From ''Batch operations tabs'' select the batch Operation you wish to perform on selected tiddlers\n\n*Notes:\n**Multiple batch operations can be done on the same set (unless you change something in the search criteria)\n**Sometimes it is useful to use an intermediate batch to help, like tag tiddlers with a \"working\" tag, using multiple searches, then then use the \"working\" tag to apply a batch operation to\n\n!!! Footenote\n# [[Use filter expression|https://tiddlywiki.com/prerelease/#Filters:Filters%20%5B%5BFilter%20Expression%5D%5D%20%5B%5BFilter%20Syntax%5D%5D%20%5B%5BFilter%20Operators%5D%5D%20%5B%5BFilter%20Parameter%5D%5D%20%5B%5BFilter%20Run%5D%5D%20%5B%5BFilter%20Step%5D%5D%20%5B%5BFilter%20Whitespace%5D%5D]]",
"title": "$:/plugins/kookma/commander/help/quick-tutorial",
"tags": "$:/tags/Commander/Help",
"modifier": "Mohammad",
"modified": "20190314113605333",
"creator": "Mohammad",
"created": "20190314050138754",
"caption": "Quick tutorial"
},
"$:/plugins/kookma/commander/help/snr": {
"text": "!! Regular Expressions Quick Reference\n\n|''FLAGS'' |<|<|h\n| i |ignore case|case insensitive matching|\n| |whole words|match strings of a-z, 0-9 and _|\n| g |global|field start=^, field end=$, all matches|\n| m |multi-line|line start=^, line end=$, first match|\n| |first match|field start=^, field end=$, first match|\n|''MATCH'' |<|<|h\n|''Anchors''|<|<|\n| ^ |start of scope|see Flags, match is zero length|\n| $ |end of scope|see Flags, match is zero length|\n| \\b |word boundary|anchor to edge of word, zero length|\n| \\B |not word boundary|anchor inside word, zero length|\n|''Character Classes''|<|<|\n| [c] |class of characters|any one matches, e.g. [abc123]|\n| [^c] |negated class of characters|any one doesn't match, e.g. [^abc123]|\n|''Shorthand Character Classes''|<|<|\n| . |any character except newline|same as [^\\n]|\n| \\d |decimal|same as [0-9]|\n| \\D |not decimal|same as [^0-9]|\n| \\s |white-space|same as [\\ \\t\\n]|\n| \\S |not white-space|same as [^\\ \\t\\n]|\n| \\t |tab|same as [\\t]|\n| \\n |newline|same as [\\n]|\n| \\w |word character|same as [a-zA-Z0-9_]|\n| \\W |not word character|same as [^a-zA-Z0-9_]|\n|''Capturing Groups''|<|<|\n| (match) |match placed in variable $x|can be used in Replace|\n| (\\x) |repeats match pattern of $x|can be used in Replace|\n|''Quantifiers''|<|<|\n| ? |single match|match 0 or 1 time|\n| * |greedy match 0+|match 0 or as many times as possible|\n| *? |lazy match 0+|match 0 or as few times as possible|\n| + |greedy match 1+|match 1 or as many times as possible|\n| +? |lazy match 1+|match 1 or as few times as possible|\n| {x} |match x times|match x times|\n| {x,y} |match x to y times|match x times to exactly y times|\n| {x,} |match x or more times|match x times or as many as possible|\n|''Escapes''|<|<|\n| \\ |escape special characters|add to \\ [ ] ( ) { } ^ $ . ? * + for literals|\n|''REPLACE'' |<|<|h\n| $& |return the full match|<|\n| $x |return $x where x is the numeric index of a Capturing Group|<|\n|''NOTE'' |<|<|h\n|This Reference supports most ordinary uses of regular expressions.<br> For advanced options: [[MDN Reference|https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#Using_simple_patterns]]; examples: [[regular-expressions.info|https://www.regular-expressions.info/tutorial.html]].|<|<|\n\n",
"title": "$:/plugins/kookma/commander/help/snr",
"tags": "$:/tags/Commander/Help",
"modifier": "Mohammad",
"modified": "20190314124141076",
"creator": "Mohammad",
"created": "20190314084511720",
"caption": "Search-n-Replace"
},
"$:/plugins/kookma/commander/macro/compInspect": {
"text": "\\define compInspect(filter, stateTiddler:\"thisTiddler\")\n<$set name=\"state\" \n value={{{ [[$:/state/compInspect/]addsuffix<__stateTiddler__>] }}}\n>\n<$vars\n slStateTid={{{ [<state>addsuffix[/]addsuffix[selectState-tiddler]] }}}\n rvStateTid={{{ [<state>addsuffix[/]addsuffix[revealState-tiddler]] }}}\n chStateTid={{{ [<state>addsuffix[/]addsuffix[checkboxState-tiddler]] }}}\n>\n\nSelect tiddler <$macrocall $name=compSelect filter=<<__filter__>> stateTiddler=<<slStateTid>> />\n \n<$macrocall $name=\"check-common-fields\" stateTiddler=<<chStateTid>> />\n \n<$reveal stateTitle=<<rvStateTid>> type=\"nomatch\" text=\"edit\">\n<$button class=\"tc-btn-invisible\" setTitle=<<rvStateTid>> setTo=\"edit\" tooltip=\"edit tiddler\">{{$:/core/images/edit-button}}</$button>\n<$macrocall $name=compInspect-show-preview tiddler={{{ [<slStateTid>get[text]] }}} commonFields={{{ [<chStateTid>get[text]] }}}/>\n</$reveal>\n<$reveal stateTitle=<<rvStateTid>> type=\"match\" text=\"edit\">\n<$button class=\"tc-btn-invisible\" setTitle=<<rvStateTid>> setTo=\"\" tooltip=\"confirm changes\">{{$:/core/images/done-button}}</$button>\n<$macrocall $name=compInspect-edit-preview tiddler={{{ [<slStateTid>get[text]] }}} commonFields={{{ [<chStateTid>get[text]] }}}/>\n</$reveal>\n\n</$vars>\n</$set>\n\\end\n\n\\define check-common-fields(stateTiddler)\n<$checkbox \n tiddler=<<__stateTiddler__>>\n field=\"text\" \n checked=\"\" \n unchecked=\"created creator modified modifier\"\n> Include common fields?</$checkbox>\n\\end",
"title": "$:/plugins/kookma/commander/macro/compInspect",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190314145449116",
"creator": "Mohammad",
"created": "20190308151331101"
},
"$:/plugins/kookma/commander/macro/compInspect/edit-preview": {
"text": "\\define compInspect-edit-preview(tiddler, commonFields:\"\")\n<div class=\"tc-edit-fields\">\n<table class=\"tc-edit-fields\">\n<tbody>\n<tr class=\"tc-edit-field\"><td class=\"tc-edit-field-name\">title:</td>\n<td class=\"tc-edit-field-value\"><$link to=<<__tiddler__>> ><$text text=<<__tiddler__>> /></$link></td>\n</tr>\n<tr class=\"tc-edit-field\"><td class=\"tc-edit-field-name\">tags:</td>\n<td class=\"tc-edit-field-value\"><$macrocall $name=compInspect-get-field tiddler=<<__tiddler__>> field=\"tags\" /></td>\n</tr>\n<tr class=\"tc-edit-field\"><td class=\"tc-edit-field-name\">text:</td>\n<td class=\"tc-edit-field-value\"><$macrocall $name=compInspect-get-field tiddler=<<__tiddler__>> field=\"text\" tag=\"textarea\" /></td>\n</tr>\n</tbody>\n</table>\n</div>\n\n<$tiddler tiddler=<<__tiddler__>> >\n<$macrocall $name=\"compInspect-edit-fileds\" commonFields=<<__commonFields__>> />\n</$tiddler>\n\\end\n\n\\define compInspect-get-field(tiddler, field, tag:\"input\") \n<$edit-text class=\"tc-edit-texteditor\" tiddler=<<__tiddler__>> field=<<__field__>> tag=<<__tag__>> default=\"\" placeholder={{$:/language/EditTemplate/Body/Placeholder}}/>\n\\end",
"title": "$:/plugins/kookma/commander/macro/compInspect/edit-preview",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190314145449120",
"creator": "Mohammad",
"created": "20190308144706094"
},
"$:/plugins/kookma/commander/macro/compInspect/show-preview": {
"text": "\\define compInspect-show-preview(tiddler, commonFields:\"\")\n<$vars mainFields=\"title tags text\">\n<table class=\"ci-table\">\n<tr><td class=\"leftcol\">title</td>\n<td class=\"rightcol\"><$link to=<<__tiddler__>> ><$text text=<<__tiddler__>> /></$link></td>\n</tr>\n\n<tr><td class=\"leftcol\">tags</td>\n<td style=\"padding:3px;\"><$macrocall $name=showTags tiddler=<<__tiddler__>> /></td>\n</tr>\n<tr><td class=\"leftcol\">text</td>\n<td><$transclude tiddler=<<__tiddler__>> field=\"text\" mode=\"block\"/></td>\n</tr>\n<$list filter=\"[<__tiddler__>fields[]] -[enlist<mainFields>] -[enlist<__commonFields__>]\" variable=\"otherFld\">\n<tr><td class=\"leftcol\"><<otherFld>></td>\n<td class=\"rightcol\"><$transclude tiddler=<<__tiddler__>> field=<<otherFld>> mode=\"inline\"/></td>\n</tr>\n</$list>\n</table>\n</$vars>\n\\end\n\n\\define showTags(tiddler)\n<$list filter=\"[<__tiddler__>tags[]]\" variable=tagItem >\n<$macrocall $name=tag tag=<<tagItem>> />\n</$list>\n\\end\n",
"title": "$:/plugins/kookma/commander/macro/compInspect/show-preview",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190314145449121",
"creator": "Mohammad",
"created": "20190308070953891"
},
"$:/plugins/kookma/commander/macro/compSelective": {
"text": "\\define compSelective(filter,tiddler)\n<$vars stateTid=<<state-tiddler-title \"\"\"$tiddler$\"\"\">> >\n<$reveal type=\"nomatch\" state=<<stateTid>> text=\"hide\">\n<$button set=<<stateTid>> setTo=\"hide\"> Select all\n<$action-setfield $tiddler=<<__tiddler__>> $field=\"text\" $value=\"{}\"/>\n<$list filter=<<__filter__>> variable=\"Item\">\n<$action-setfield $tiddler=<<__tiddler__>> $index=<<Item>> $value=\"selected\"/>\n</$list>\n</$button>\n</$reveal>\n\n<$reveal type=\"match\" state=<<stateTid>> text=\"hide\">\n<$button set=<<stateTid>> setTo=\"show\"> Select none\n<$action-setfield $tiddler=<<__tiddler__>> $field=\"text\" $value=\"{}\"/>\n<!-- Clear SNR selection -->\n<$action-setfield $tiddler=\"$:/state/commander/snr/select-tiddler\" $field=\"text\" $value=\"\"/>\n<!-- Clear Inspect selection -->\n<$action-setfield $tiddler=\"$:/state/compInspect/temp/commander/selectState-tiddler\" $field=\"text\" $value=\"\"/>\n</$button>\n</$reveal>\n</$vars>\n<br>\n<i><$count filter=\"[<__tiddler__>indexes[]]\" /> selected</i> <$macrocall $name=\"display\" label=\"Show filter in use\" text={{$:/temp/commander}} />\n<br>\n<$list filter=\"[subfilter<__filter__>] +[sort[title]]\" variable=\"Item\">\n<$checkbox tiddler=<<__tiddler__>> index=<<Item>> checked=\"selected\"> <$link to=<<Item>>><$text text=<<Item>> /></$link></$checkbox><br>\n</$list>\n\n\n\\end\n\n\\define state-tiddler-title(tiddler) $tiddler$-comp-selective\n\n\\define compSelective-reset(filter, tiddler)\n<$action-setfield $tiddler=<<__tiddler__>> $field=\"text\" $value=\"{}\"/>\n<$action-setfield $tiddler=<<state-tiddler-title \"\"\"$tiddler$\"\"\">> $field=\"text\" $value=\"\"/>\n\\end",
"title": "$:/plugins/kookma/commander/macro/compSelective",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190315112134222",
"creator": "Mohammad",
"created": "20190301133121124"
},
"$:/plugins/kookma/commander/macro/field-operation": {
"text": "\\define add-new-field-bulk(newField:\"Empty\")\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[count[]] -0\" variable=\"ignore\">\n<$list filter=\"[<__newField__>] -Empty\">\n<<create-log-tiddler \"add-new-field-bulk\">>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[!is[missing]] -[has:field[$newField$]]\">\n<$fieldmangler>\n<$action-sendmessage $message=\"tm-add-field\" $param=<<__newField__>> />\n</$fieldmangler>\n<$macrocall $name=\"log-add-single-operation\" msg=\"\"\"new field `$newField$` added\"\"\" tidItem=<<currentTiddler>> />\n</$list>\n<<title-selection-reset>>\n</$list>\n</$list>\n\\end\n\n\\define remove-old-field-bulk(oldField:\"Empty\")\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[count[]] -0\" variable=\"ignore\">\n<$list filter=\"[<__oldField__>] -Empty\">\n<<create-log-tiddler \"remove-old-field-bulk\">>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[!is[missing]] +[has:field[$oldField$]]\">\n<$fieldmangler>\n<$action-sendmessage $message=\"tm-remove-field\" $param=<<__oldField__>> />\n</$fieldmangler>\n<$macrocall $name=\"log-add-single-operation\" msg=\"\"\"old field `$oldField$` removed\"\"\" tidItem=<<currentTiddler>> />\n</$list>\n<<title-selection-reset>>\n</$list>\n</$list>\n\\end\n\n\\define set-field-value-bulk(fieldName:\"Empty\", fieldValue:\"Empty\")\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[count[]] -0\" variable=\"ignore\">\n<$list filter=\"[<__fieldName__>] -Empty\">\n<$list filter=\"[<__fieldValue__>] -Empty\">\n<<create-log-tiddler \"set-field-value-create-bulk\">>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[!is[missing]] -[$fieldName$[$fieldValue$]]\">\n<$action-setfield $field=<<__fieldName__>> $value=<<__fieldValue__>> />\n<$macrocall $name=\"log-add-single-operation\" msg=\"\"\"field `$fieldName$` got a value\"\"\" tidItem=<<currentTiddler>> />\n</$list>\n<<title-selection-reset>>\n</$list>\n</$list>\n</$list>\n\\end\n\n",
"title": "$:/plugins/kookma/commander/macro/field-operation",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190314084019712",
"creator": "Mohammad",
"created": "20190212101155537"
},
"$:/plugins/kookma/commander/macro/filters": {
"text": "\\define create-new-filter(description:\"Empty\")\n<$list filter=\"[<__description__>] -Empty\" variable=\"ignore\">\n<$action-createtiddler \n $basetitle=\"$:/plugins/kookma/commander/filters/yourFilter\"\n tags=\"$:/tags/Commander/Filter\"\n description=<<__description__>>\n filter={{$:/temp/commander/search-box}}\n /> \n</$list>\n\\end\n",
"title": "$:/plugins/kookma/commander/macro/filters",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190314115033530",
"creator": "Mohammad",
"created": "20190214142032323"
},
"$:/plugins/kookma/commander/macro/logging": {
"text": "\\define set-title() $:/temp/commander/logs/tid-{{{[tag[$:/tags/Commander/LogOps]count[]add[1]]}}}\n\n\\define create-log-tiddler(msg)\n<$wikify name=\"myTitle\" text=\"\"\"<<set-title>>\"\"\">\n<$wikify name=\"myCaption\" text=\"\"\"<$macrocall $name=\"set-caption\" msg=<<__msg__>> />\"\"\">\n<$action-createtiddler $basetitle=<<myTitle>>\n$savetitle=\"$:/state/commander/log-tiddler\"\ntags=\"$:/tags/Commander/LogOps\"\ntype=\"application/json\"\ncaption=<<__msg__>>\n/>\n</$wikify>\n</$wikify>\n\\end\n\n\\define log-add-single-operation(msg:\"commander operation\", tidItem:\"no item\")\n<$action-setfield $tiddler={{$:/state/commander/log-tiddler}} $index=<<__tidItem__>> $value=\"\"\"$msg$\"\"\" />\n\\end\n\n\n\\define delete-all-log-tiddlers()\n<$action-deletetiddler $filter=\"[tag[$:/tags/Commander/LogOps]]\" />\n\\end",
"title": "$:/plugins/kookma/commander/macro/logging",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190222054547204",
"creator": "Mohammad",
"created": "20190221163406469"
},
"$:/plugins/kookma/commander/macro/selection": {
"text": "\\define title-selection-reset()\n<$macrocall $name=\"compSelective-reset\" \ntiddler=\"$:/temp/commander/selected-titles\" \nfilter=\"[subfilter{$:/temp/commander}] +[!is[missing]]\" />\n\\end",
"title": "$:/plugins/kookma/commander/macro/selection",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190303055421039",
"creator": "Mohammad",
"created": "20190303055230230"
},
"$:/plugins/kookma/commander/macro/slider": {
"text": "\\define slider-ii(title)\n<$set name=\"revealState\" value=<<qualify \"$:/state-reveal-$title$\">>>\n<h2>\n <$reveal type=\"nomatch\" state=<<revealState>> text=\"yes\">\n <$button class=\"tc-btn-invisible tc-tiddlylink\" set=<<revealState>> setTo=\"yes\">\n {{$:/core/images/right-arrow}}\n </$button>\n </$reveal>\n <$reveal type=\"match\" state=<<revealState>> text=\"yes\">\n <$button class=\"tc-btn-invisible tc-tiddlylink\" set=<<revealState>> setTo=\"no\">\n {{$:/core/images/down-arrow}}\n </$button>\n </$reveal>\n <$view tiddler=\"$title$\" field=\"caption\">\n <$view tiddler=\"$title$\" field=\"title\"></$view>\n </$view>\n \n</h2>\n\n<$reveal type=\"match\" state=<<revealState>> text=\"yes\">\n<$transclude tiddler=\"$title$\" mode=\"block\" />\n</$reveal>\n</$set>\n\\end",
"title": "$:/plugins/kookma/commander/macro/slider",
"tags": "$:/tags/Macro",
"modified": "20190212061921249",
"created": "20190212061854110"
},
"$:/plugins/kookma/commander/macro/snr/ui/inputs": {
"text": "\\define snr-ui-inputs()\n<form class=\"snr-form\">\n <fieldset>\n <legend>Search and Replace</legend>\n\n<div class=\"item\">\n<label>Tiddler title</label>\n<$select tiddler=\"$:/state/commander/snr/select-tiddler\" default=\"\" class=\"snr-textbox\">\n<option value=\"\">None</option>\n\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]sort[]]\" >\n<option value=<<currentTiddler>>><$text text=<<currentTiddler>>/></option>\n</$list>\n</$select>\n</div>\n\n<div class=\"item\">\n<label>Field name</label>\n<$select tiddler=\"$:/state/commander/snr/select-tiddler/field\" default=\"text\">\n<$list filter=\"[{$:/state/commander/snr/select-tiddler}fields[]]\">\n<option value=<<currentTiddler>>>field: <$text text=<<currentTiddler>>/></option>\n</$list>\n</$select>\n</div>\n\n<div class=\"item\">\n<label>Search text</label>\n<$edit-text \n tiddler=\"$:/state/commander/snr/replace-text\" \n tag=\"input\" \n default=\"\" \n placeholder=\" text to replace\"\n class=\"snr-textbox\"/>\n</div>\n<div class=\"item\">\n<label>Replace with </label>\n<$edit-text \n tiddler=\"$:/state/commander/snr/replace-text-with\" \n tag=\"input\" \n default=\"\" \n placeholder=\" new text\"\n class=\"snr-textbox\"/>\n</div>\n</fieldset>\n</form>\n\\end",
"title": "$:/plugins/kookma/commander/macro/snr/ui/inputs",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190314084019713",
"creator": "Mohammad",
"created": "20190306203626597"
},
"$:/plugins/kookma/commander/macro/snr/ui/regexp-flags": {
"text": "\\define snr-regexp-flags()\n\n<form class=\"snr-form\">\n<fieldset>\n<legend>Search flags</legend>\n\n<$checkbox \n tiddler=\"$:/state/commander/snr/case-sensitive\" \n field=\"text\" \n checked=\"i\" \n unchecked=\"\"\n/> ignore case<br>\n\n<$checkbox \n tiddler=\"$:/state/commander/snr/whole-words\" \n field=\"text\" \n checked=\"words\" \n unchecked=\"characters\"\n/> whole words<br>\n\n<br>\n\n<$radio\n tiddler=\"$:/state/commander/snr/gm\" \n field=\"text\" \n value=\"g\"> global match\n</$radio><br>\n\n<$radio\n tiddler=\"$:/state/commander/snr/gm\" \n field=\"text\" \n value=\"m\"> multiline mode\n</$radio><br>\n\n<$radio\n tiddler=\"$:/state/commander/snr/gm\" \n field=\"text\" \n value=\"\"> first match \n</$radio>\n\n</fieldset>\n</form>\n\\end",
"title": "$:/plugins/kookma/commander/macro/snr/ui/regexp-flags",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190314200302824",
"creator": "Mohammad",
"created": "20190306182052441"
},
"$:/plugins/kookma/commander/macro/tag-operation": {
"text": "\\define add-new-tag-bulk(newTag:\"Empty\")\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[count[]] -0\" variable=\"ignore\">\n<$list filter=\"[<__newTag__>] -Empty\" variable=null>\n<<create-log-tiddler \"add-new-tag-bulk\">>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[!is[missing]] -[<__newTag__>tagging[]]\">\n<$fieldmangler>\n<$action-sendmessage $message=\"tm-add-tag\" $param=<<__newTag__>> />\n</$fieldmangler>\n<$macrocall $name=\"log-add-single-operation\" msg=\"\"\"new tag `$newTag$` added\"\"\" tidItem=<<currentTiddler>> />\n</$list>\n<<title-selection-reset>>\n</$list>\n</$list>\n\\end\n\n\\define remove-old-tag-bulk(oldTag:\"Empty\")\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[count[]] -0\" variable=ignore>\n<$list filter=\"[<__oldTag__>] -Empty\" variable=null>\n<<create-log-tiddler \"remove-old-tag-bulk\">>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[!is[missing]] +[tag<__oldTag__>]\">\n<$fieldmangler>\n<$action-sendmessage $message=\"tm-remove-tag\" $param=<<__oldTag__>> />\n</$fieldmangler>\n<$macrocall $name=\"log-add-single-operation\" msg=\"\"\"old tag `$oldTag$` removed\"\"\" tidItem=<<currentTiddler>> />\n</$list>\n<<title-selection-reset>>\n</$list>\n</$list>\n\\end\n\n\n\\define replace-tag-bulk(oldTag:\"Empty\", newTag:\"Empty\")\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[count[]] -0\" variable=\"ignore\">\n<$list filter=\"[<__oldTag__>] -Empty\" variable=null>\n<$list filter=\"[<__newTag__>] -Empty\" variable=null>\n<<create-log-tiddler \"replace-tag-bulk\">>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[!is[missing]] +[<__oldTag__>tagging[]]\">\n<$fieldmangler>\n<$action-sendmessage $message=\"tm-add-tag\" $param=<<__newTag__>> />\n<$action-sendmessage $message=\"tm-remove-tag\" $param=<<__oldTag__>> />\n</$fieldmangler>\n<$macrocall $name=\"log-add-single-operation\" msg=\"\"\"tag `$oldTag$` replaced with `$newTag$`\"\"\" tidItem=<<currentTiddler>> />\n</$list>\n<<title-selection-reset>>\n</$list>\n</$list>\n</$list>\n\\end\n\n",
"title": "$:/plugins/kookma/commander/macro/tag-operation",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190314084019714",
"creator": "Mohammad",
"created": "20190212063435548"
},
"$:/plugins/kookma/commander/macro/tiddler-operation/create": {
"text": "\\define log-create(msg:\"Tiddler existed, operation ignored\")\n<$action-setfield $tiddler={{$:/state/commander/log-tiddler}} $index=\"$(newTitle)$\" $value=\"$msg$\" />\n\\end\n\n\\define bulk-tiddler-creator(baseTitle, baseTags, numberTiddler)\n<<create-log-tiddler \"bulk-tiddler-creator\">>\n<$list filter=\"[range[9]addprefix[00]] [range[10,99]addprefix[0]] [range[100,500]] +[limit<__numberTiddler__>]\" variable=\"L1\">\n<$list filter=\"[<__baseTitle__>addsuffix<L1>]\" variable=\"newTitle\">\n<$list filter=\"[<newTitle>] -[has[title]]\" variable=\"ignore\" emptyMessage=<<log-create>> >\n<$action-createtiddler $basetitle=<<newTitle>> tags=<<__baseTags__>> /> \n<<log-create \"Tiddler created\">>\n</$list>\n</$list>\n</$list>\n\\end\n\n\\define oneTid-with-template(myTitle, myTags, myTemplate)\n<$tiddler tiddler=<<__myTitle__>> >\n <$action-setfield \n $tiddler=<<__myTemplate__>> \n title=<<currentTiddler>> /> \n <$fieldmangler>\n <$list filter=\"[enlist<__myTags__>]\" variable=newTag>\n <$action-sendmessage $message=\"tm-add-tag\" $param=<<newTag>> />\n </$list>\n <$action-sendmessage $message=\"tm-remove-tag\" $param=\"$:/tags/Commander/Template\" />\n</$fieldmangler>\n</$tiddler>\n\\end\n\n\n\\define bulk-tiddler-with-template-creator(baseTitle, baseTags, numberTiddler, template)\n<<create-log-tiddler \"bulk-tiddler-creator with template\">>\n<$list filter=\"[range[9]addprefix[00]] [range[10,99]addprefix[0]] [range[100,500]] +[limit<__numberTiddler__>]\" variable=\"L1\">\n<$list filter=\"[<__baseTitle__>addsuffix<L1>]\" variable=\"newTitle\">\n<$list filter=\"[<newTitle>] -[has[title]]\" variable=\"ignore\" emptyMessage=<<log-create>>>\n<$macrocall $name=\"oneTid-with-template\" \n myTitle=<<newTitle>> \n myTags=<<__baseTags__>> \n myTemplate=<<__template__>>\n />\n <<log-create \"Tiddler created\">>\n</$list>\n</$list>\n</$list>\n\\end\n\n",
"title": "$:/plugins/kookma/commander/macro/tiddler-operation/create",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190309153848588",
"creator": "Mohammad",
"created": "20190212125920722"
},
"$:/plugins/kookma/commander/macro/tiddler-operation/delete": {
"text": "\\define log-delete-selectively(item, msg:\"Tiddler deleted\")\n<$action-setfield $tiddler={{$:/state/commander/log-tiddler}} $index=<<__item__>> $value=\"$msg$\" />\n\\end\n\n\\define delete-tiddlers-selective-bulk()\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[count[]] -0\" variable=\"ignore\">\n<<create-log-tiddler \"delete-tiddler-selectively\">>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]]\" variable=\"Item\">\n<$action-deletetiddler $tiddler=<<Item>> />\n<$macrocall $name=\"log-delete-selectively\" item=<<Item>> />\n</$list>\n<<title-selection-reset>>\n</$list>\n\\end",
"title": "$:/plugins/kookma/commander/macro/tiddler-operation/delete",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190314084019714",
"creator": "Mohammad",
"created": "20190215195221625"
},
"$:/plugins/kookma/commander/macro/title-operation/prefix": {
"text": "\\define log-changePrefix(message, oldTitle, newTitle)\n<$macrocall $name=\"log-add-single-operation\" msg=\"\"\"$message$. New title [[$newTitle$]]\"\"\" tidItem=<<__oldTitle__>> />\n\\end\n\n\\define addPrefix-to-tiltle-bulk(prefix:\"Empty\")\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[count[]] -0\" variable=\"ignore\">\n<$list filter=\"[<__prefix__>] -Empty\" variable=null>\n<<create-log-tiddler \"addPrefix-to-tiltle-bulk\">>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[!is[missing]]\">\n<$list filter=\"\"\"[<currentTiddler>addprefix[$prefix$]] -[<currentTiddler>]\"\"\" variable=\"newTitle\">\n<$list filter=\"[<newTitle>] -[has[title]]\" variable=\"ignore\">\n <$action-setfield $tiddler=<<currentTiddler>> title=<<newTitle>> />\n <$action-deletetiddler $tiddler=<<currentTiddler>> />\n <$macrocall $name=log-changePrefix message=\"title prefix: `$prefix$` added\" oldTitle=<<currentTiddler>> newTitle=<<newTitle>> />\n</$list>\n</$list>\n<<title-selection-reset>>\n</$list>\n</$list>\n</$list>\n\\end\n\n\\define removePrefix-from-tiltle-bulk(prefix:\"Empty\")\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[count[]] -0\" variable=\"ignore\">\n<$list filter=\"[<__prefix__>] -Empty\" variable=null>\n<<create-log-tiddler \"removePrefix-from-tiltle-bulk\">>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[!is[missing]]\">\n<$list filter=\"\"\"[<currentTiddler>removeprefix[$prefix$]] -[<currentTiddler>]\"\"\" variable=\"newTitle\">\n<$list filter=\"[<newTitle>] -[has[title]]\" variable=\"ignore\">\n <$action-setfield $tiddler=<<currentTiddler>> title=<<newTitle>> />\n <$action-deletetiddler $tiddler=<<currentTiddler>> />\n <$macrocall $name=log-changePrefix message=\"title prefix: `$prefix$` removed\" oldTitle=<<currentTiddler>> newTitle=<<newTitle>> />\n</$list> \n</$list>\n<<title-selection-reset>>\n</$list>\n</$list>\n</$list>\n\\end\n",
"title": "$:/plugins/kookma/commander/macro/title-operation/prefix",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190314084019715",
"creator": "Mohammad",
"created": "20190212122742891"
},
"$:/plugins/kookma/commander/macro/title-operation/remove-cahrs-end": {
"text": "\\define suffix-actions2()\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[prefix<sfx>]\" variable=\"item\">\n <$action-setfield $tiddler=<<item>> title=<<sfx>> />\n <$action-deletetiddler $tiddler=<<item>> />\n <$macrocall $name=\"log-add-single-operation\" msg=\"\"\"characters removed from end. New title [[$(sfx)$]]\"\"\" tidItem=<<item>> />\n</$list>\n\\end\n\n\n\\define makelink2() [[$(newTitle)$]]\n\n\\define generate-suffixes2(n:\"0\")\n<$list filter=\"[<__n__>] -0\" variable=null>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[!is[missing]]\" variable=\"item\">\n<$list filter=\"\"\"[<item>split[]butlast[$n$]join[]trim[]]\"\"\" variable=\"newTitle\">\n<$text text=<<makelink2>>/>\n</$list>\n</$list>\n</$list>\n\\end\n\n\\define remove-chars-from-end-tiltle-bulk(num:\"0\")\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[count[]] -0\" variable=\"ignore\">\n<$list filter=\"[<__num__>] -0\" variable=null>\n<<create-log-tiddler \"remove-chars-from-end-tiltle-bulk\">>\n<$vars n=<<__num__>> >\n<$wikify text=\"\"\"<<generate-suffixes2 n:\"$num$\">>\"\"\" name=\"outputs\">\n <$list filter=\"[subfilter<outputs>]\" variable=\"sfx\">\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[prefix<sfx>limit[2]count[]regexp[2]]\" emptyMessage=<<suffix-actions2>> variable=\"cnt\">\n</$list>\n</$list>\n</$wikify>\n</$vars>\n<<title-selection-reset>>\n</$list>\n</$list>\n\\end\n",
"title": "$:/plugins/kookma/commander/macro/title-operation/remove-cahrs-end",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190314084019715",
"creator": "Mohammad",
"created": "20190218190318901"
},
"$:/plugins/kookma/commander/macro/title-operation/remove-cahrs-start": {
"text": "\\define suffix-actions()\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[suffix<sfx>]\" variable=\"item\">\n <$action-setfield $tiddler=<<item>> title=<<sfx>> />\n <$action-deletetiddler $tiddler=<<item>> />\n <$macrocall $name=\"log-add-single-operation\" msg=\"\"\"characters removed from start. New title [[$(sfx)$]]\"\"\" tidItem=<<item>> />\n</$list>\n\\end\n\n\n\\define makelink() [[$(newTitle)$]]\n\n\\define generate-suffixes(n:\"0\")\n<$list filter=\"[<__n__>] -0\" variable=null>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[has[title]]\" variable=\"item\">\n<$list filter=\"\"\"[<item>split[]rest[$n$]join[]trim[]]\"\"\" variable=\"newTitle\">\n<$text text=<<makelink>>/>\n</$list>\n</$list>\n</$list>\n\\end\n\n\\define remove-chars-from-begining-tiltle-bulk(num:\"0\")\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[count[]] -0\" variable=\"ignore\">\n<$list filter=\"[<__num__>] -0\" variable=null>\n<<create-log-tiddler \"remove-chars-from-begining-tiltle-bulk\">>\n<$vars n=<<__num__>> >\n<$wikify text=\"\"\"<<generate-suffixes n:\"$num$\">>\"\"\" name=\"outputs\">\n <$list filter=\"[subfilter<outputs>]\" variable=\"sfx\">\n <$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[suffix<sfx>limit[2]count[]regexp[2]]\" \n emptyMessage=<<suffix-actions>> variable=\"cnt\">\n </$list>\n </$list>\n</$wikify>\n</$vars>\n<<title-selection-reset>>\n</$list>\n</$list>\n\\end\n",
"title": "$:/plugins/kookma/commander/macro/title-operation/remove-cahrs-start",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190314084019716",
"creator": "Mohammad",
"created": "20190218214608685"
},
"$:/plugins/kookma/commander/macro/title-operation/suffix": {
"text": "\\define log-changeSuffix(message, oldTitle, newTitle)\n<$macrocall $name=\"log-add-single-operation\" msg=\"\"\"$message$. New title [[$newTitle$]]\"\"\" tidItem=<<__oldTitle__>> />\n\\end\n\n\\define addSuffix-to-tiltle-bulk(suffix:\"Empty\")\n<$list filter=\"[<__suffix__>] -Empty\" variable=null>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[count[]] -0\" variable=\"ignore\">\n<<create-log-tiddler \"addSufffix-to-tiltle-bulk\">>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[!is[missing]]\">\n<$list filter=\"\"\"[<currentTiddler>addsuffix[$suffix$]] -[<currentTiddler>]\"\"\" variable=\"newTitle\">\n<$list filter=\"[<newTitle>] -[has[title]]\" variable=\"ignore\">\n <$action-setfield $tiddler=<<currentTiddler>> title=<<newTitle>> />\n <$action-deletetiddler $tiddler=<<currentTiddler>> />\n <$macrocall $name=log-changeSuffix message=\"title suffix: `$suffix$` added\" oldTitle=<<currentTiddler>> newTitle=<<newTitle>> />\n</$list>\n</$list>\n<$macrocall $name=\"compSelective-reset\" tiddler=\"$:/temp/commander/selected-titles\" filter=\"[subfilter{$:/temp/commander}] +[!is[missing]]\" />\n</$list>\n</$list>\n</$list>\n\\end\n\n\\define removeSuffix-from-tiltle-bulk(suffix:\"Empty\")\n<$list filter=\"[<__suffix__>] -Empty\" variable=null>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[count[]] -0\" variable=\"ignore\">\n<<create-log-tiddler \"removeSuffix-from-tiltle-bulk\">>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[!is[missing]]\">\n<$list filter=\"\"\"[<currentTiddler>removesuffix[$suffix$]] -[<currentTiddler>]\"\"\" variable=\"newTitle\">\n<$list filter=\"[<newTitle>] -[has[title]]\" variable=\"ignore\">\n <$action-setfield $tiddler=<<currentTiddler>> title=<<newTitle>> />\n <$action-deletetiddler $tiddler=<<currentTiddler>> />\n <$macrocall $name=log-changeSuffix message=\"title suffix: `$suffix$` removed\" oldTitle=<<currentTiddler>> newTitle=<<newTitle>> />\n</$list>\n</$list>\n<$macrocall $name=\"compSelective-reset\" tiddler=\"$:/temp/commander/selected-titles\" filter=\"[subfilter{$:/temp/commander}] +[!is[missing]]\" />\n</$list>\n</$list>\n</$list>\n\\end\n",
"title": "$:/plugins/kookma/commander/macro/title-operation/suffix",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190314084019716",
"creator": "Mohammad",
"created": "20190212143639636"
},
"$:/plugins/kookma/commander/setting/delete-all-temp-tiddlers": {
"text": "\\define delete-all-temps()\n<$action-deletetiddler $filter=\"[search:title[$:/temp/commander/]]\" />\n\\end\n\n<$set name=numTids value={{{ [search:title[$:/temp/commander/]count[]] }}}>\n<$reveal type=\"match\" text=\"0\" default=<<numTids>> >\nNo temporary tiddlers is existed to delete!\n</$reveal>\n<$reveal type=\"gt\" text=\"0\" default=<<numTids>> >\nNumber of temporary tiddlers (including log tiddlers): <<numTids>><br>\n</$reveal>\n</$set>\n\n<$macrocall $name=\"compConfirmDelete\"\nbtnLabel=\"Delete temp tiddlers\" \nconfirmMessage=\"Are you sure you wish to delete\"\nstateTiddler=\"$:/state/commander/setting/delete-temps\"\ncountFilter=\"[search:title[$:/temp/commander/]]\"\nactionMacro=\"delete-all-temps\"/>",
"title": "$:/plugins/kookma/commander/setting/delete-all-temp-tiddlers",
"tags": "$:/tags/Commander/Setting",
"modifier": "Mohammad",
"modified": "20190315065343256",
"creator": "Mohammad",
"created": "20190301184304348",
"caption": "Temporary tiddlers"
},
"$:/plugins/kookma/commander/snr/usage": {
"text": "!! Setup UI\n<<<\nSimply put the below command inside an empty tiddler\n\n```\n<<replace-text-ui>>\n```\n<<<\n\n!! How to use?\n<<<\n* Enter a search filter in ''Filter search'' box like `[tag[myTag]]`\n* From ''Filter title'' drop down menu select a tiddler\n* From ''Field name'' drop down menu select a tiddler field like `text`\n* In the ''Search text'' type the search term for example `this`\n* In the ''Replace with'' type the term you want to replace with like `that`\n*Check the ''Differences'' and if you are satisfied with the result, press the `Replace?` button\n<<<\n\n!! Special characters\n<<<\nAs `SNR` uses ''regexp'' pattern to make search and replace, when special characters are used in the ''Search text'' box, they shall be escaped among them are `*`, `+`, `[`, ...\nTo use these characters do like below\n\n```\n\\[ \\* \\+\n```\n<<<\n\n!! Warning\n<<<\n* SNR replace the contents of tiddlers. //The action can not be undone//. So always make a backup before performing any replace action\n* It is not possible to selectively replace some occurrences and ignore some others in one run! That means you cannot skip some occurrences. \n<<<",
"title": "$:/plugins/kookma/commander/snr/usage",
"tags": "",
"modifier": "Mohammad",
"modified": "20190307113435934",
"creator": "Mohammad",
"created": "20190307104654008"
},
"$:/plugins/kookma/commander/stylesheet/compInspect/table": {
"text": "/*compInspect table*/\n.ci-table\n{border-collapse: collapse;}\n\n.ci-table .leftcol{\nwidth:20%;\nvertical-align: top;\ntext-align: right;\nbackground-color:#f0f0f0;\n}\n.ci-table .rightcol{\nwidth:650px;\n}\n",
"type": "text/css",
"title": "$:/plugins/kookma/commander/stylesheet/compInspect/table",
"tags": "$:/tags/Stylesheet",
"modifier": "Mohammad",
"modified": "20190314145449123",
"creator": "Mohammad",
"created": "20190308134702363"
},
"$:/plugins/kookma/commander/stylesheet/snr/flexbox": {
"text": ".snr-row {\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n width: 100%;\n}\n.snr-column {\n display: flex;\n flex-direction: column;\n flex-basis: 100%;\n flex: 1\n}\n\n.snr-double-column {\n display: flex;\n flex-direction: column;\n flex-basis: 100%;\n flex: 2\n}\n\n@media screen and (min-width: 800px) {\n .snr-column {\n flex: 1\n }\n\n .snr-double-column {\n flex: 2\n }\n}",
"type": "text/css",
"title": "$:/plugins/kookma/commander/stylesheet/snr/flexbox",
"tags": "$:/tags/Stylesheet",
"modifier": "Mohammad",
"modified": "20190307151712610",
"creator": "Mohammad",
"created": "20190306203517655"
},
"$:/plugins/kookma/commander/stylesheet/snr/form": {
"text": ".snr-form{\n width:100%;\n}\n\n.snr-textbox {\n width:100%;\n box-sizing: border-box;\n max-width:40ch;\n }\n\n.snr-form select, .snr-form input{\n margin: 0.2rem;\n}\n.snr-form legend{\n background: #f5f5f5;\n padding: 3px 6px;\n}\n\n.snr-form { padding:20px; }\n.snr-form .item { padding: 2px; margin:2px; }\n.snr-form .item label { display:inline-block; width:100px; margin-left:5px; }\n.snr-form .item input { display:inline-block; }\n.snr-form .item select { display:inline-block; }\n\n\n\n ",
"type": "text/css",
"title": "$:/plugins/kookma/commander/stylesheet/snr/form",
"tags": "$:/tags/Stylesheet",
"modifier": "Mohammad",
"modified": "20190307151724333",
"creator": "Mohammad",
"created": "20190306191714819"
},
"$:/plugins/kookma/commander/stylesheet/tabs": {
"text": "/* .cm-tab-colorful .tc-tab-buttons button {color:blue;} */\n.cm-tab-colorful .tc-tab-buttons button.tc-tab-selected {\n background: none;\n border: none;\n border-bottom: solid 1px #737373 !important;\n font-weight: bold;\n color: #DB4C3F !important;\n}\n\n.cm-tab-wd .tc-tab-buttons button{\n width:140px;\n}",
"type": "text/css",
"title": "$:/plugins/kookma/commander/stylesheet/tabs",
"tags": "$:/tags/Stylesheet",
"modifier": "Mohammad",
"modified": "20190314214724200",
"creator": "Mohammad",
"created": "20190212114811859"
},
"$:/plugins/kookma/commander/stylesheet/text-area": {
"text": ".cm-txt-area{\n width:30ch !important;\n}\n.cm-small-txt-area{\n width:10ch !important;\n}",
"type": "text/css",
"title": "$:/plugins/kookma/commander/stylesheet/text-area",
"tags": "$:/tags/Stylesheet",
"modifier": "Mohammad",
"modified": "20190213153154659",
"creator": "Mohammad",
"created": "20190212071143632"
},
"$:/plugins/kookma/commander/ui/field-operation": {
"text": "<<tabs \"[all[shadows+tiddlers]tag[$:/tags/Commander/FieldOps]!has[draft.of]]\" \"$:/plugins/kookma/commander/ui/title-operation\" class:\"tc-vertical cm-tab-colorful cm-tab-wd\">>\n\n",
"title": "$:/plugins/kookma/commander/ui/field-operation",
"tags": "$:/tags/Commander",
"modifier": "Mohammad",
"modified": "20190309032149130",
"creator": "Mohammad",
"created": "20190212061551615",
"caption": "Field"
},
"$:/plugins/kookma/commander/ui/help": {
"text": "<<tabs \"[all[shadows+tiddlers]tag[$:/tags/Commander/Help]!has[draft.of]]\" class:\"tc-vertical cm-tab-colorful cm-tab-wd\">>\n\n\n",
"title": "$:/plugins/kookma/commander/ui/help",
"tags": "$:/tags/Commander",
"modifier": "Mohammad",
"modified": "20190314050125065",
"icon": "$:/core/images/help",
"creator": "Mohammad",
"created": "20190314050052494",
"caption": "Help"
},
"$:/plugins/kookma/commander/ui/inspection": {
"text": "<<tabs \"[all[shadows+tiddlers]tag[$:/tags/Commander/InspectOps]!has[draft.of]]\" class:\"tc-vertical cm-tab-colorful cm-tab-wd\">>\n",
"title": "$:/plugins/kookma/commander/ui/inspection",
"tags": "$:/tags/Commander",
"modifier": "Mohammad",
"modified": "20190313075927970",
"creator": "Mohammad",
"created": "20190313075823496",
"caption": "Inspect"
},
"$:/plugins/kookma/commander/ui/inspectops/Inspection": {
"text": "<$macrocall \n $name=compInspect\n filter=\"[[$:/temp/commander/selected-titles]indexes[]sort[]]\"\n stateTiddler=\"temp/commander\"\n/>",
"title": "$:/plugins/kookma/commander/ui/inspectops/Inspection",
"tags": "$:/tags/Commander/InspectOps",
"modifier": "Mohammad",
"modified": "20190314121603117",
"creator": "Mohammad",
"created": "20190313080119081",
"caption": "Inspect"
},
"$:/plugins/kookma/commander/ui/log-status": {
"text": "<div class=\"alert-info\" style=\"padding:5px;font-size:0.90em;\">\n<$button class=\"tc-btn-invisible tc-tiddlylink\" actions=<<delete-all-log-tiddlers>>>Clear log</$button>\n<$set name=\"resultCount\" value=\"\"\"<$count filter=\"[tag[$:/tags/Commander/LogOps]]\" />\"\"\">\n<div class=\"tc-search-results\">\n<span style=\"font-style:italic; font-size:small;\">Recent number of operations: <<resultCount>></span><br>\n<$list filter=\"[tag[$:/tags/Commander/LogOps]] +[!sort[created]]\" variable=\"logTid\">\n<b><$view tiddler=<<logTid>> field=\"created\" format=\"date\" template=\"YYYY-0MM-0DD 0hh:0mm:0ss\"/> \n<$view tiddler=<<logTid>> field=\"caption\">\n <$view tiddler=<<logTid>> field=\"title\"></$view>\n</$view>\n</b>\n<ol><$list filter=\"[<logTid>indexes[]]\" variable=\"item\">\n<li><$link to=<<item>>><<item>></$link>\n<$set name=\"myItem\" tiddler=<<logTid>> index=<<item>> >\n<$list filter=\"[<myItem>!search[existed]]\" variable=\"ignore\" \n emptyMessage=\"\"\"<span style=\"color:red;\"><<myItem>></span>\"\"\" >\n<span style=\"color:green;\"><<myItem>></span>\n</$list>\n</$set>\n</li>\n</$list></ol>\n</$list>\n</div>\n</$set>\n</div>",
"title": "$:/plugins/kookma/commander/ui/log-status",
"tags": "",
"modifier": "Mohammad",
"modified": "20190315064616026",
"creator": "Mohammad",
"created": "20190221152805807",
"caption": "Log status"
},
"$:/plugins/kookma/commander/ui/search": {
"text": "<div class=\"tc-search tc-advanced-search\">\nSearch via filter <$edit-text tiddler=\"$:/temp/commander/search-box\" type=\"search\" tag=\"input\" default=\"\" placeholder=\"filter search\" focus={{$:/plugins/kookma/commander/config/AutoFocus}}/>\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/Commander/Search/FilterButton]]\">\n<$transclude/>\n</$list>\n<br>\n<small style=\"margin-left:17ch;\"><i><$count filter=\"[subfilter{$:/temp/commander/search-box}]\"/> matches \n<span style=\"color:red;\">\n<$macrocall $name=is-filterSeearch-newer-than-selectedTitles\nTidB=\"$:/temp/commander/search-box\"\nTidA=\"$:/temp/commander\"/></span>\n</i></small>\n</div>\n",
"title": "$:/plugins/kookma/commander/ui/search",
"tags": "",
"modifier": "Mohammad",
"modified": "20190315113802092",
"creator": "Mohammad",
"created": "20190212055219117",
"caption": "Commander filter search"
},
"$:/plugins/kookma/commander/ui/search/filter-button/clear": {
"text": "<$reveal state=\"$:/temp/commander/search-box\" type=\"nomatch\" text=\"\">\n<$button class=\"tc-btn-invisible\" tooltip=\"clear search box and selected tiddlers\">\n<$action-setfield $tiddler=\"$:/temp/commander/search-box\" $field=\"text\" $value=\"\"/>\n<$action-setfield $tiddler=\"$:/temp/commander\" $field=\"text\" $value=\"\"/>\n<$action-setfield $tiddler=\"$:/temp/commander/selected-titles\" $field=\"text\" $value=\"{}\"/>\n<$action-setfield $tiddler=\"$:/state/commander/snr/select-tiddler\" $field=\"text\" $value=\"\"/><!-- SNR selection -->\n<$action-setfield $tiddler=\"$:/state/compInspect/temp/commander/selectState-tiddler\" $field=\"text\" $value=\"\"/> <!-- Inspect selection -->\n{{$:/core/images/close-button}}\n</$button>\n</$reveal>",
"title": "$:/plugins/kookma/commander/ui/search/filter-button/clear",
"tags": "$:/tags/Commander/Search/FilterButton",
"modifier": "Mohammad",
"modified": "20190315113214388",
"creator": "Mohammad",
"created": "20190214132946159"
},
"$:/plugins/kookma/commander/ui/search/filter-button/dropdown": {
"text": "<span class=\"tc-popup-keep\">\n<$button popup=<<qualify \"$:/state/commander/filterDropdown\">> class=\"tc-btn-invisible\" tooltip=\"select a search filter\">\n{{$:/core/images/down-arrow}}\n</$button>\n</span>\n\n<$reveal state=<<qualify \"$:/state/commander/filterDropdown\">> type=\"popup\" position=\"belowleft\" animate=\"yes\">\n<$set name=\"tv-show-missing-links\" value=\"yes\">\n<$linkcatcher to=\"$:/temp/commander/search-box\">\n<div class=\"tc-block-dropdown-wrapper\">\n<div class=\"tc-block-dropdown tc-edit-type-dropdown\">\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/Commander/Filter]]\"><$link to={{!!filter}}><$transclude field=\"description\"/></$link>\n</$list>\n</div>\n</div>\n</$linkcatcher>\n</$set>\n</$reveal>\n",
"title": "$:/plugins/kookma/commander/ui/search/filter-button/dropdown",
"tags": "$:/tags/Commander/Search/FilterButton",
"modifier": "Mohammad",
"modified": "20190314114652123",
"creator": "Mohammad",
"created": "20190214133424013"
},
"$:/plugins/kookma/commander/ui/search/filter-button/save": {
"text": "<$reveal state=\"$:/temp/commander/search-box\" type=\"nomatch\" text=\"\">\n<$button class=\"tc-btn-invisible\" tooltip=\"save current search\" popup=<<qualify \"$:/state/commander/SaveDropdown\">> >\n{{$:/core/images/file}}\n</$button>\n</$reveal>\n\n<$reveal state=<<qualify \"$:/state/commander/SaveDropdown\">> type=\"popup\" class=\"tc-popup-keep\" position=\"belowleft\" animate=\"yes\">\n<div class=\"tc-block-dropdown-wrapper\">\n<div class=\"tc-block-dropdown tc-edit-type-dropdown\">\n<div class=\"tc-dropdown-item-plain\">\nSave new search filter<br><br>\n<$edit-text\ntiddler=\"$:/temp/commander/save-new-filter\"\ntag=\"input\"\ndefault=\"\"\nclass=\"cm-txt-area\"\nplaceholder=\"description for new filter\"\n/> \n\n<$button class=\"tc-btn\"> Save new filter\n<$macrocall $name=\"create-new-filter\" description={{$:/temp/commander/save-new-filter}} />\n<$action-deletetiddler $tiddler=\"$:/temp/commander/save-new-filter\"/>\n</$button>\n</div>\n</div>\n</$reveal>",
"title": "$:/plugins/kookma/commander/ui/search/filter-button/save",
"tags": "$:/tags/Commander/Search/FilterButton",
"modifier": "Mohammad",
"modified": "20190314115119075",
"creator": "Mohammad",
"created": "20190214141644228"
},
"$:/plugins/kookma/commander/ui/search/filter-button/search": {
"text": "<$reveal state=\"$:/temp/commander/search-box\" type=\"nomatch\" text=\"\">\n<$button class=\"tc-btn-invisible\" tooltip=\"apply filter search\">\n<$action-setfield $tiddler=\"$:/temp/commander\" $field=\"text\" $value={{$:/temp/commander/search-box}} />\n<$action-setfield $tiddler=\"$:/temp/commander/selected-titles\" $field=\"text\" $value=\"{}\"/>\n{{$:/core/images/advanced-search-button}}\n</$button>\n</$reveal>",
"title": "$:/plugins/kookma/commander/ui/search/filter-button/search",
"tags": "$:/tags/Commander/Search/FilterButton",
"modifier": "Mohammad",
"modified": "20190315062520107",
"creator": "Mohammad",
"created": "20190314111817036"
},
"$:/plugins/kookma/commander/ui/setting": {
"text": "<<tabs \"[all[shadows+tiddlers]tag[$:/tags/Commander/Setting]!has[draft.of]]\" class:\"tc-vertical cm-tab-colorful cm-tab-wd\">>\n",
"title": "$:/plugins/kookma/commander/ui/setting",
"tags": "$:/tags/Commander",
"modifier": "Mohammad",
"modified": "20190314215944671",
"icon": "$:/core/images/options-button",
"creator": "Mohammad",
"created": "20190214140835173",
"caption": "Setting"
},
"$:/plugins/kookma/commander/ui/tag-operation": {
"text": "<<tabs \"[all[shadows+tiddlers]tag[$:/tags/Commander/TagOps]!has[draft.of]]\" \"$:/plugins/kookma/commander/ui/title-operation\" class:\"tc-vertical cm-tab-colorful cm-tab-wd\">>\n\n",
"title": "$:/plugins/kookma/commander/ui/tag-operation",
"tags": "$:/tags/Commander",
"modifier": "Mohammad",
"modified": "20190309032133992",
"creator": "Mohammad",
"created": "20190212051852003",
"caption": "Tag"
},
"$:/plugins/kookma/commander/ui/tiddler-operation": {
"text": "<<tabs \"[all[shadows+tiddlers]tag[$:/tags/Commander/TiddlerOps]!has[draft.of]]\" class:\"tc-vertical cm-tab-colorful cm-tab-wd\">>\n",
"title": "$:/plugins/kookma/commander/ui/tiddler-operation",
"tags": "$:/tags/Commander",
"modifier": "Mohammad",
"modified": "20190314211439469",
"creator": "Mohammad",
"created": "20190212125319261",
"caption": "Tiddler"
},
"$:/plugins/kookma/commander/ui/tiddler-selection": {
"text": "<div style=\"font-size:small; border-left:0.5px solid grey;padding-left:10px;\">\n<$list filter=\"[subfilter{$:/temp/commander}] +[!is[missing]] +[limit[1]]\" variable=\"null\">\n<$macrocall $name=compSelective\nfilter=\"[subfilter{$:/temp/commander}] +[!is[missing]]\"\ntiddler=\"$:/temp/commander/selected-titles\"\n/>\n</$list>\n</div>\n\n",
"title": "$:/plugins/kookma/commander/ui/tiddler-selection",
"tags": "",
"modifier": "Mohammad",
"modified": "20190315100538446",
"creator": "Mohammad",
"created": "20190301203327739",
"caption": "Select tiddlers"
},
"$:/plugins/kookma/commander/ui/tiddlerops/delete-tiddlers": {
"text": "<$set name=numTids value={{{[[$:/temp/commander/selected-titles]indexes[]count[]] }}}>\n<$reveal type=\"match\" text=\"0\" default=<<numTids>> >\nNo tiddlers is selected for deleteion!\n</$reveal>\n<$reveal type=\"gt\" text=\"0\" default=<<numTids>> >\nNumber of tiddlers selected for deletion: <<numTids>><br>\nNote that, the delete operation cannot be undone!!\n</$reveal>\n</$set>\n\n<$macrocall $name=\"compConfirmDelete\"\ncountFilter=\"[[$:/temp/commander/selected-titles]indexes[]]\"\nactionMacro=\"delete-tiddlers-selective-bulk\"\nstateTiddler=\"$:/state/commander/SelectiveDeleteDropdown\"\n/>\n",
"title": "$:/plugins/kookma/commander/ui/tiddlerops/delete-tiddlers",
"tags": "$:/tags/Commander/TiddlerOps",
"modifier": "Mohammad",
"modified": "20190309041431651",
"creator": "Mohammad",
"created": "20190301144408502",
"caption": "Delete tiddlers"
},
"$:/plugins/kookma/commander/ui/title-operation": {
"text": "Warning: These operation may overwritte existing tiddlers\n\n<<tabs \"[all[shadows+tiddlers]tag[$:/tags/Commander/TitleOps]!has[draft.of]]\" class:\"tc-vertical cm-tab-colorful cm-tab-wd\">>\n\n",
"title": "$:/plugins/kookma/commander/ui/title-operation",
"tags": "$:/tags/Commander",
"modifier": "Mohammad",
"modified": "20190309032112441",
"creator": "Mohammad",
"created": "20190212051704536",
"caption": "Title"
},
"$:/plugins/kookma/commander/utility": {
"text": "\\define display(label,text)\n<$set name=\"stateTid\" value=\"$:/temp/commander/display/popup/$label$\" >\n<$button popup=<<stateTid>> class=\"tc-btn-invisible\"><span style=\"text-decoration: underline\">$label$</span></$button>\n<$reveal type=\"nomatch\" text=\"\" default=\"\" state=<<stateTid>> animate=\"yes\">\n<span style=\"color:blue;\"><$text text=<<__text__>> /></span></$reveal>\n</$set>\n\\end\n\n\\define is-filterSeearch-newer-than-selectedTitles(TidA, TidB)\n<$set name=\"tidAMod\" value={{{ [[$TidA$]get[modified]] }}}>\n<$set name=\"tidBMod\" value={{{ [[$TidB$]get[modified]] }}}>\n<$set name=\"tidAText\" value={{{ [[$TidA$]get[text]] }}}>\n<$set name=\"tidBText\" value={{{ [[$TidB$]get[text]] }}}>\n<$list filter=\"[<__TidB__>get[text]minlength[1]]\" variable=ignore>\n<$reveal type=\"nomatch\" default=<<tidAText>> text=<<tidBText>>>\n<$list filter=\"[<tidAMod>] [<tidBMod>] +[nsort[]last[1]removesuffix<tidBMod>]\">\nA new filter search has been detected, click on the search button to apply it.\n</$list>\n</$reveal>\n</$list>\n</$set>\n</$set>\n</$set>\n</$set>\n\\end\n\n!!Remarks\n;is-filterSeearch-newer-than-selectedTitles\n* Checks `TidA` and `TidB` for modified date and text\n* If They are not empty, then\n** checks if the text of two are equal, if not\n** checks to see if `TidB` is newer or not\n** if newer shows a message, to apply the new search filter\n* Note\n** `TidA=\"$:/temp/commander\"`\n** `TidB=\"$:/temp/commander/search-box\"`\n* is-filterSeearch-newer-than-selectedTitles is called from $:/plugins/kookma/commander/ui/search\n\n;display\n* gets a label and a text\n* create an inline label\n* on click label, the text is displayed as temporary popup\n* losing focus, the text goes hidden\n* this macro is used in customized compSelective to show the active filter",
"title": "$:/plugins/kookma/commander/utility",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190315113946756",
"creator": "Mohammad",
"created": "20190315092752816"
},
"$:/tags/Commander/Help": {
"created": "20190315122040568",
"creator": "Mohammad",
"title": "$:/tags/Commander/Help",
"list": "$:/plugins/kookma/commander/help/what-is-commander $:/plugins/kookma/commander/help/quick-tutorial $:/plugins/kookma/commander/help/snr $:/plugins/kookma/commander/help/batch-operation $:/plugins/kookma/commander/help/warning",
"modified": "20190315122106223",
"modifier": "Mohammad"
},
"$:/tags/Commander/Search/FilterButton": {
"created": "20190315122445955",
"creator": "Mohammad",
"title": "$:/tags/Commander/Search/FilterButton",
"list": "$:/plugins/kookma/commander/ui/search/filter-button/dropdown $:/plugins/kookma/commander/ui/search/filter-button/search $:/plugins/kookma/commander/ui/search/filter-button/clear $:/plugins/kookma/commander/ui/search/filter-button/save",
"modified": "20190315122451135",
"modifier": "Mohammad"
},
"$:/tags/Commander": {
"created": "20190315121802750",
"creator": "Mohammad",
"title": "$:/tags/Commander",
"list": "$:/plugins/kookma/commander/ui/tiddler-operation $:/plugins/kookma/commander/ui/title-operation $:/plugins/kookma/commander/ui/tag-operation $:/plugins/kookma/commander/ui/field-operation $:/plugins/kookma/commander/ui/snr-operation $:/plugins/kookma/commander/ui/inspection $:/plugins/kookma/commander/ui/setting $:/plugins/kookma/commander/ui/help",
"modified": "20190315123201675",
"modifier": "Mohammad"
},
"$:/plugins/kookma/commander/template/base": {
"text": "This is a simple one!",
"title": "$:/plugins/kookma/commander/template/base",
"tags": "$:/tags/Commander/Template",
"modifier": "Mohammad",
"modified": "20190220161727636",
"creator": "Mohammad",
"created": "20190213200622605",
"caption": "Base"
},
"$:/plugins/kookma/commander/template/elegant": {
"text": "! Heading one\nHere you go\n\n!! Heading two\n\n* one\n* two\n* three\n\n!!! Heading three\n\n|Heading one|Heading Two|Heading Three|h\n|r1|100|200|\n|r2|02|03|\n|r3|-1|-2|\n",
"version": "beta",
"title": "$:/plugins/kookma/commander/template/elegant",
"tags": "$:/tags/Commander/Template",
"modifier": "Mohammad",
"modified": "20190220161116039",
"creator": "Mohammad",
"created": "20190213200258460",
"caption": "Elagant"
},
"$:/plugins/kookma/commander/template/pretty": {
"text": "! Heading\nThis is pretty\n\n```\nsample code\n```\n\n!!! Footnotes\n# one\n# two",
"version": "beta",
"title": "$:/plugins/kookma/commander/template/pretty",
"tags": "$:/tags/Commander/Template",
"modifier": "Mohammad",
"modified": "20190220161101463",
"creator": "Mohammad",
"created": "20190213200338381",
"caption": "Pouri"
},
"$:/plugins/kookma/commander/ui/snr-operation": {
"created": "20190220210055713",
"creator": "Mohammad",
"text": "Search and replcae in tiddler fields!\n\n<<tabs \"[all[shadows+tiddlers]tag[$:/tags/Commander/SnrOps]!has[draft.of]]\" class:\"tc-vertical cm-tab-colorful cm-tab-wd\">>\n\n",
"title": "$:/plugins/kookma/commander/ui/snr-operation",
"tags": "$:/tags/Commander",
"modifier": "Mohammad",
"modified": "20190315180102502",
"caption": "Snr",
"icon": "$:/core/images/gitter"
},
"$:/tags/Commander/TiddlerOps": {
"created": "20190315175806394",
"creator": "Mohammad",
"title": "$:/tags/Commander/TiddlerOps",
"list": "$:/plugins/kookma/commander/ui/tiddlerops/create-tiddlers $:/plugins/kookma/commander/ui/tiddlerops/delete-tiddlers",
"modified": "20190315175806394",
"modifier": "Mohammad"
},
"$:/plugins/kookma/commander/stylesheet/select-width": {
"created": "20190218214027079",
"creator": "Mohammad",
"text": ".cm-sl{\n width:8ch;\n}\n\n.cm-select-wd{\n min-width:15ch;\n}\n",
"type": "text/css",
"title": "$:/plugins/kookma/commander/stylesheet/select-width",
"tags": "$:/tags/Stylesheet",
"modifier": "Mohammad",
"modified": "20190317075458285"
},
"$:/plugins/kookma/commander/macro/snr-operation": {
"created": "20190307164924193",
"creator": "Mohammad",
"text": "\\define regexp-flags()\n{{$:/state/commander/snr/gm}}{{$:/state/commander/snr/case-sensitive}}\n\\end\n\n\\define snr-ui-show-diffs()\n<form class=\"snr-form\" style=\"width:100%;\">\n <fieldset>\n <legend style=\"color:#FF0000;\">Differences</legend>\nTiddler: <$link to={{$:/state/commander/snr/select-tiddler}}><$text text={{$:/state/commander/snr/select-tiddler}}/></$link>\n\n<$wikify name=flags text=<<regexp-flags>> >\n\n<$macrocall $name=\"replace-text-diff\" \n tiddler={{$:/state/commander/snr/select-tiddler}} \n field={{$:/state/commander/snr/select-tiddler/field}} \n replace={{$:/state/commander/snr/replace-text}} \n replaceWith={{$:/state/commander/snr/replace-text-with}} \n flags=<<flags>> \n wholeWords={{$:/state/commander/snr/whole-words}}\n/>\n\n</$wikify>\n</fieldset>\n</form>\n\\end\n\n\n\n\n\\define snr-check-diffs(tiddler:\"\", field:\"\")\n\\whitespace trim\n<$wikify name=flags text=<<regexp-flags>> >\n<$wikify name=\"result\" text=\"\"\"\n<$macrocall $name=\"replace-text\" \n tiddler=<<__tiddler__>>\n field=<<__field__>>\n replace={{$:/state/commander/snr/replace-text}} \n replaceWith={{$:/state/commander/snr/replace-text-with}} \n flags=<<flags>> \n wholeWords={{$:/state/commander/snr/whole-words}}\n/>\"\"\">\n<$reveal type=\"match\" text={{{ [<__tiddler__>get<__field__>] }}} default=<<result>> >\nsame\n</$reveal>\n<$reveal type=\"nomatch\" text={{{ [<__tiddler__>get<__field__>] }}} default=<<result>> >\ndifferent\n</$reveal>\n</$wikify>\n</$wikify>\n\\end\n\n\n\\define search-replace-in-tiddler-field(tiddler:\"\",field:\"\",replace:\"\",replaceWith:\"\")\n<$wikify name=ss text=<<snr-check-diffs \"\"\"$tiddler$\"\"\" \"\"\"$field$\"\"\">> >\n<$list filter=\"[<ss>] -same\" variable=ignore>\n\n<$wikify name=flags text=<<regexp-flags>> >\n<$macrocall $name=\"replace-text-button\" \n tiddler=<<__tiddler__>> \n field=<<__field__>>\n replace=<<__replace__>>\n replaceWith=<<__replaceWith__>> \n flags=<<flags>> \n wholeWords={{$:/state/commander/snr/whole-words}}\n/>\n<$macrocall $name=\"log-add-single-operation\" msg=\"\"\"`$field$` field has been changed\"\"\" tidItem=<<__tiddler__>> />\n\n</$wikify>\n</$list>\n</$wikify>\n\\end\n\n\n\\define search-replace-in-field-bulk()\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[count[]] -0\" variable=\"ignore\">\n<<create-log-tiddler \"SNR operation\">>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[!is[missing]]\">\n <$macrocall \n $name=\"search-replace-in-tiddler-field\"\n tiddler=<<currentTiddler>> \n field={{$:/state/commander/snr/select-tiddler/field}} \n replace={{$:/state/commander/snr/replace-text}} \n replaceWith={{$:/state/commander/snr/replace-text-with}} \n />\n</$list>\n</$list>\n\\end\n\n\\define search-replace-in-field-single-tiddler()\n<<create-log-tiddler \"SNR operation\">>\n <$macrocall \n $name=\"search-replace-in-tiddler-field\"\n tiddler={{$:/state/commander/snr/select-tiddler}}\n field={{$:/state/commander/snr/select-tiddler/field}} \n replace={{$:/state/commander/snr/replace-text}} \n replaceWith={{$:/state/commander/snr/replace-text-with}} \n />\n\\end\n\n\\define snr-actions()\n<$button actions=<<search-replace-in-field-single-tiddler>> tooltip=\"search and replace in a single tiddler\" class=\"cm-btn\">\nReplace?\n</$button> \n<$button actions=<<search-replace-in-field-bulk>> tooltip=\"search and replace in all selected tiddlers\" class=\"cm-btn\">\nReplace all?\n</$button>\n\\end",
"title": "$:/plugins/kookma/commander/macro/snr-operation",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190317081731019"
},
"$:/plugins/kookma/commander/ui/fieldops/set-field-value": {
"created": "20190212120609737",
"creator": "Mohammad",
"text": "Field name \n<$select class=\"cm-select-wd\" tiddler=\"$:/temp/commander/field-name\" default=<<dummy>>>\n<$list filter=\"[subfilter{$:/state/commander/set-field-value/fields}]\" >\n<option><$view field=\"title\"/></option>\n</$list>\n</$select> \n<$checkbox \n tiddler=\"$:/state/commander/set-field-value/fields\" \n field=\"text\" \n checked=\"[[$:/temp/commander/selected-titles]indexes[]fields[]sort[]] -tags -title\" \n unchecked=\"[[$:/temp/commander/selected-titles]indexes[]fields[]sort[]] -[[$:/plugins/kookma/commander/empty-tiddler]fields[]]\"\n> Include system fields?</$checkbox>\n\nField value <$edit-text\ntiddler=\"$:/temp/commander/field-value\"\ntag=\"input\"\ndefault=\"\"\nclass=\"cm-txt-area\"\nplaceholder=\" field value\"\n/> \n<$button class=\"cm-btn\"> Set field value\n<$macrocall \n $name=\"set-field-value-bulk\" \n fieldName={{$:/temp/commander/field-name}} \n fieldValue={{$:/temp/commander/field-value}} \n/>\n</$button>",
"title": "$:/plugins/kookma/commander/ui/fieldops/set-field-value",
"tags": "$:/tags/Commander/FieldOps",
"modifier": "Mohammad",
"modified": "20190317081439306",
"caption": "Set field value"
},
"$:/plugins/kookma/commander/ui/fieldops/add-remove-fields": {
"created": "20190314051054548",
"creator": "Mohammad",
"text": "<$edit-text\ntiddler=\"$:/temp/commander/field-add\"\ntag=\"input\"\ndefault=\"\"\nclass=\"cm-txt-area\"\nplaceholder=\" new field\"\n/> \n<$button class=\"cm-btn\"> Add new field\n<$macrocall $name=\"add-new-field-bulk\" newField={{$:/temp/commander/field-add}} />\n</$button>\n\n<$button class=\"cm-btn\"> Remove old field\n<$macrocall $name=\"remove-old-field-bulk\" oldField={{$:/temp/commander/field-remove}} />\n</$button>\n<$select class=\"cm-select-wd\" tiddler=\"$:/temp/commander/field-remove\" default=<<dummy>>>\n<$list filter=\"[subfilter{$:/state/commander/add-remove-fields/fields}]\" >\n<option><$view field=\"title\"/></option>\n</$list>\n</$select> \n<$checkbox \n tiddler=\"$:/state/commander/add-remove-fields/fields\" \n field=\"text\" \n checked=\"[[$:/temp/commander/selected-titles]indexes[]fields[]sort[]] -title -tags\" \n unchecked=\"[[$:/temp/commander/selected-titles]indexes[]fields[]sort[]] -[[$:/plugins/kookma/commander/empty-tiddler]fields[]]\"\n> Include system fields?</$checkbox>\n\n\n",
"title": "$:/plugins/kookma/commander/ui/fieldops/add-remove-fields",
"tags": "$:/tags/Commander/FieldOps",
"modifier": "Mohammad",
"modified": "20190317081419411",
"caption": "Add remove fields"
},
"$:/plugins/kookma/commander/ui/tagops/replace-tags": {
"created": "20190212080523588",
"creator": "Mohammad",
"text": "<span style=\"display:inline-block;width:8ch;\">Old tag </span>\n<$select class=\"cm-select-wd\" tiddler=\"$:/temp/commander/replace-tags/old\" default=<<dummy>>>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]tags[]sort[]]\" >\n<option><$view field=\"title\"/></option>\n</$list>\n</$select>\n\n<span style=\"display:inline-block;width:8ch;\">New tag </span>\n<$edit-text\ntiddler=\"$:/temp/commander/replace-tags/new\"\ntag=\"input\"\ndefault=\"\"\nclass=\"cm-txt-area\"\nplaceholder=\" new tag\"\n/>\n\n<$button class=\"cm-btn\"> Replace tags\n<$macrocall $name=\"replace-tag-bulk\" \noldTag={{$:/temp/commander/replace-tags/old}} \nnewTag={{$:/temp/commander/replace-tags/new}} />\n</$button>\n\n",
"title": "$:/plugins/kookma/commander/ui/tagops/replace-tags",
"tags": "$:/tags/Commander/TagOps",
"modifier": "Mohammad",
"modified": "20190317081345762",
"caption": "Replace tags"
},
"$:/plugins/kookma/commander/ui/tagops/add-remove-tags": {
"created": "20190212063924640",
"creator": "Mohammad",
"text": "<$edit-text\ntiddler=\"$:/temp/commander/tag-add-remove/new\"\ntag=\"input\"\ndefault=\"\"\nclass=\"cm-txt-area\"\nplaceholder=\" new tag\"\n/> \n<$button class=\"cm-btn\"> Add new tag\n<$macrocall $name=\"add-new-tag-bulk\" newTag={{$:/temp/commander/tag-add-remove/new}} />\n</$button>\n\n<$button class=\"cm-btn\"> Remove old tag\n<$macrocall $name=\"remove-old-tag-bulk\" oldTag={{$:/temp/commander/tag-add-remove/old}} />\n</$button>\n \n<$select class=\"cm-select-wd\" tiddler=\"$:/temp/commander/tag-add-remove/old\" default=<<dummy>>>\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]tags[]sort[]]\" >\n<option><$view field=\"title\"/></option>\n</$list>\n</$select>\n\n",
"title": "$:/plugins/kookma/commander/ui/tagops/add-remove-tags",
"tags": "$:/tags/Commander/TagOps",
"modifier": "Mohammad",
"modified": "20190317081325667",
"caption": "Add remove tags"
},
"$:/plugins/kookma/commander/ui/titleops/add-remove-suffix": {
"created": "20190212143434676",
"creator": "Mohammad",
"text": "<$edit-text\ntiddler=\"$:/temp/commander/title-suffix\"\ntag=\"input\"\ndefault=\"\"\nclass=\"cm-txt-area\"\nplaceholder=\" suffix\"\n/> \n<$button class=\"cm-btn\"> Add suffix\n<$macrocall \n $name=\"addSuffix-to-tiltle-bulk\" \n suffix={{$:/temp/commander/title-suffix}} \n/>\n</$button>\n<$button class=\"cm-btn\"> Remove suffix\n<$macrocall \n $name=\"removeSuffix-from-tiltle-bulk\" \n suffix={{$:/temp/commander/title-suffix}} \n/>\n</$button>\n\n",
"title": "$:/plugins/kookma/commander/ui/titleops/add-remove-suffix",
"tags": "$:/tags/Commander/TitleOps",
"modifier": "Mohammad",
"modified": "20190317081300595",
"caption": "Add remove suffix"
},
"$:/plugins/kookma/commander/ui/titleops/add-remove-prefix": {
"created": "20190212141758567",
"creator": "Mohammad",
"text": "<$edit-text\ntiddler=\"$:/temp/commander/title-prefix\"\ntag=\"input\"\ndefault=\"\"\nclass=\"cm-txt-area\"\nplaceholder=\" prefix\"\n/> \n<$button class=\"cm-btn\"> Add prefix\n<$macrocall \n $name=\"addPrefix-to-tiltle-bulk\" \n prefix={{$:/temp/commander/title-prefix}} \n/>\n</$button>\n<$button class=\"cm-btn\"> Remove prefix\n<$macrocall \n $name=\"removePrefix-from-tiltle-bulk\" \n prefix={{$:/temp/commander/title-prefix}} \n/>\n</$button>\n\n",
"title": "$:/plugins/kookma/commander/ui/titleops/add-remove-prefix",
"tags": "$:/tags/Commander/TitleOps",
"modifier": "Mohammad",
"modified": "20190317081240691",
"caption": "Add remove prefix"
},
"$:/plugins/kookma/commander/ui/titleops/add-remove-chars": {
"created": "20190217092719245",
"creator": "Mohammad",
"text": "\\define rngcat() [range[0,$(minchars)$]] -0 \n\nNumber of characters\n<$select tiddler=\"$:/temp/commander/title-remove-chars\" default=\"0\" class=\"cm-sl\">\n<$list filter=\"[[$:/temp/commander/selected-titles]indexes[]] +[!is[missing]] +[length[]] +[minall[]] +[subtract[1]] -Infinity\" variable=\"minchars\">\n<$list filter=<<rngcat>> >\n<option value=<<currentTiddler>>><$view field='title'/></option>\n</$list>\n</$list>\n</$select> \n\n<$button class=\"cm-btn\"> First n chars\n<$macrocall \n $name=\"remove-chars-from-begining-tiltle-bulk\" \n num={{$:/temp/commander/title-remove-chars}} \n/>\n</$button>\n<$button class=\"cm-btn\"> Last n chars\n<$macrocall \n $name=\"remove-chars-from-end-tiltle-bulk\" \n num={{$:/temp/commander/title-remove-chars}} \n/>\n</$button>\n\n\n",
"title": "$:/plugins/kookma/commander/ui/titleops/add-remove-chars",
"tags": "$:/tags/Commander/TitleOps",
"modifier": "Mohammad",
"modified": "20190317081216442",
"caption": "Remove chars"
},
"$:/plugins/kookma/commander/macro/compConfirmDelete": {
"created": "20190301145916990",
"creator": "Mohammad",
"text": "\\define compConfirmDelete(\nbtnLabel:\"Delete these tiddlers\", \nconfirmMessage:\"Are you sure you wish to delete\", \nstateTiddler:\"\"\ncountFilter:\"\", \nactionMacro:\"\")\n<$set name=resultCount value={{{ [subfilter<__countFilter__>count[]] }}} >\n<$reveal type=\"gt\" text=\"0\" default=<<resultCount>> >\n<$button popup=<<qualify \"\"\"$stateTiddler$\"\"\">> class=\"cm-btn\">$btnLabel$</$button>\n</$reveal>\n\n<$reveal state=<<qualify \"\"\"$stateTiddler$\"\"\">> type=\"popup\" position=\"belowleft\" animate=\"yes\">\n<div class=\"tc-block-dropdown-wrapper\">\n<div class=\"tc-block-dropdown tc-edit-type-dropdown\">\n<div class=\"tc-dropdown-item-plain\">\n$confirmMessage$ <<resultCount>> tiddler(s)?\n\n</div>\n<div class=\"tc-dropdown-item-plain\">\n<$button class=\"cm-btn\">\n<$macrocall $name=<<__actionMacro__>> />\n$btnLabel$\n</$button>\n</div>\n</div>\n</div>\n</$reveal>\n</$set>\n\\end",
"title": "$:/plugins/kookma/commander/macro/compConfirmDelete",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190317081030129"
},
"$:/plugins/kookma/commander/ui/tiddlerops/create-tiddlers": {
"created": "20190213193004029",
"creator": "Mohammad",
"text": "Base title \n<$edit-text \n tiddler=\"$:/temp/commander/tiddler-base-title\" \n tag=\"input\" \n default=\"\"\n placeholder=\" base title\" \n class=\"cm-txt-area\"/> \nTags \n<$edit-text \n tiddler=\"$:/temp/commander/tiddler-base-tags\" \n tag=\"input\" \n default=\"\"\n placeholder=\" tags\" \n class=\"cm-txt-area\"\n/> \n\n \n<$checkbox \n tiddler=\"$:/state/commander/tiddler-template-status\" \n field=\"text\" \n checked=\"use-template\" \n unchecked=\"no-template\"\n> Use template?</$checkbox> \n<$reveal type=\"match\" text=\"use-template\" default={{$:/state/commander/tiddler-template-status}}>\nTemplate\n<$select tiddler=\"$:/temp/commander/template-newtiddler\" default='base'>\n<$list filter='[all[shadows+tiddlers]tag[$:/tags/Commander/Template]]'>\n<option value=<<currentTiddler>> >\n<$view field=\"caption\"><$view field=\"title\"/></$view>\n</option>\n</$list>\n</$select>\n</$reveal>\n\nNumber of tiddlers \n<$select tiddler=\"$:/temp/commander/tiddler-base-number\" default='1'>\n<$list filter='[range[1,19, 1]] [range[20,50, 5]] [range[60,100,10]]'>\n<option value=<<currentTiddler>>><$view field='title'/></option>\n</$list>\n</$select>\n\n<$reveal type=\"match\" text=\"use-template\" default={{$:/state/commander/tiddler-template-status}}>\n<$button class=\"cm-btn\"> Create tiddlers\n<$macrocall $name=\"bulk-tiddler-with-template-creator\"\nbaseTitle={{$:/temp/commander/tiddler-base-title}}\nbaseTags={{$:/temp/commander/tiddler-base-tags}}\nnumberTiddler={{$:/temp/commander/tiddler-base-number}}\ntemplate={{$:/temp/commander/template-newtiddler}}\n/> </$button>\n</$reveal>\n\n<$reveal type=\"match\" text=\"no-template\" default={{$:/state/commander/tiddler-template-status}}>\n<$button class=\"cm-btn\"> Create tiddlers\n<$macrocall $name=\"bulk-tiddler-creator\"\nbaseTitle={{$:/temp/commander/tiddler-base-title}}\nbaseTags={{$:/temp/commander/tiddler-base-tags}}\nnumberTiddler={{$:/temp/commander/tiddler-base-number}}\n/>\n</$button>\n</$reveal>\n",
"title": "$:/plugins/kookma/commander/ui/tiddlerops/create-tiddlers",
"tags": "$:/tags/Commander/TiddlerOps",
"modifier": "Mohammad",
"modified": "20190317081102849",
"caption": "Create tiddlers"
},
"$:/plugins/kookma/commander/macro/compInspect/edit-fileds": {
"created": "20190313061511585",
"creator": "Mohammad",
"text": "\\define lingo-base() $:/language/EditTemplate/\n\\define config-title()\n$:/config/EditTemplateFields/Visibility/$(currentField)$\n\\end\n\n\\define config-filter()\n[[hide]] -[title{$(config-title)$}] \n\\end\n\n\\define new-field()\n<$vars name={{$:/temp/newfieldname}}>\n<$reveal type=\"nomatch\" text=\"\" default=<<name>>>\n<$button class=\"cm-btn\">\n<$action-sendmessage $message=\"tm-add-field\"\n$name=<<name>>\n$value={{$:/temp/newfieldvalue}}/>\n<$action-deletetiddler $tiddler=\"$:/temp/newfieldname\"/>\n<$action-deletetiddler $tiddler=\"$:/temp/newfieldvalue\"/>\n<<lingo Fields/Add/Button>>\n</$button>\n</$reveal>\n<$reveal type=\"match\" text=\"\" default=<<name>>>\n<$button class=\"cm-btn\">\n<<lingo Fields/Add/Button>>\n</$button>\n</$reveal>\n</$vars>\n\\end\n\n\\define compInspect-edit-fileds(commonFields:\"\")\n\n<div class=\"tc-edit-fields\">\n<table class=\"tc-edit-fields\">\n<tbody>\n<$list filter=\"[all[current]fields[]] +[sort[title]]\" variable=\"currentField\">\n<$list filter=<<config-filter>> variable=\"temp\">\n<tr class=\"tc-edit-field\">\n<td class=\"tc-edit-field-name\">\n<$text text=<<currentField>>/>:</td>\n<td class=\"tc-edit-field-value\">\n<$edit-text tiddler=<<currentTiddler>> field=<<currentField>> placeholder={{$:/language/EditTemplate/Fields/Add/Value/Placeholder}}/>\n</td>\n<td class=\"tc-edit-field-remove\">\n<$button class=\"tc-btn-invisible\" tooltip={{$:/language/EditTemplate/Field/Remove/Hint}} aria-label={{$:/language/EditTemplate/Field/Remove/Caption}}>\n<$action-deletefield $field=<<currentField>>/>\n{{$:/core/images/delete-button}}\n</$button>\n</td>\n</tr>\n</$list>\n</$list>\n\n\n<$list filter=\"created creator modified modifier -[enlist<__commonFields__>]\" variable=\"currentField\">\n<tr class=\"tc-edit-field\">\n<td class=\"tc-edit-field-name\">\n<$text text=<<currentField>>/>:</td>\n<td class=\"tc-edit-field-value\">\n<$edit-text tiddler=<<currentTiddler>> field=<<currentField>> placeholder={{$:/language/EditTemplate/Fields/Add/Value/Placeholder}}/>\n</td>\n<td class=\"tc-edit-field-remove\">\n<$button class=\"tc-btn-invisible\" tooltip={{$:/language/EditTemplate/Field/Remove/Hint}} aria-label={{$:/language/EditTemplate/Field/Remove/Caption}}>\n<$action-deletefield $field=<<currentField>>/>\n{{$:/core/images/delete-button}}\n</$button>\n</td>\n</tr>\n</$list>\n\n\n\n\n</tbody>\n</table>\n</div>\n\n<$fieldmangler>\n<div class=\"tc-edit-field-add\">\n<em class=\"tc-edit\">\n<<lingo Fields/Add/Prompt>>\n</em>\n<span class=\"tc-edit-field-add-name\">\n<$edit-text tiddler=\"$:/temp/newfieldname\" tag=\"input\" default=\"\" placeholder={{$:/language/EditTemplate/Fields/Add/Name/Placeholder}} focusPopup=<<qualify \"$:/state/popup/field-dropdown\">> class=\"tc-edit-texteditor tc-popup-handle\"/>\n</span>\n<$button popup=<<qualify \"$:/state/popup/field-dropdown\">> class=\"tc-btn-invisible tc-btn-dropdown\" tooltip={{$:/language/EditTemplate/Field/Dropdown/Hint}} aria-label={{$:/language/EditTemplate/Field/Dropdown/Caption}}>{{$:/core/images/down-arrow}}</$button>\n<$reveal state=<<qualify \"$:/state/popup/field-dropdown\">> type=\"nomatch\" text=\"\" default=\"\">\n<div class=\"tc-block-dropdown tc-edit-type-dropdown\">\n<$linkcatcher to=\"$:/temp/newfieldname\">\n<div class=\"tc-dropdown-item\">\n<<lingo Fields/Add/Dropdown/User>>\n</div>\n<$list filter=\"[!is[shadow]!is[system]fields[]search:title{$:/temp/newfieldname}sort[]] -created -creator -draft.of -draft.title -modified -modifier -tags -text -title -type\" variable=\"currentField\">\n<$link to=<<currentField>>>\n<<currentField>>\n</$link>\n</$list>\n<div class=\"tc-dropdown-item\">\n<<lingo Fields/Add/Dropdown/System>>\n</div>\n<$list filter=\"[fields[]search:title{$:/temp/newfieldname}sort[]] -[!is[shadow]!is[system]fields[]]\" variable=\"currentField\">\n<$link to=<<currentField>>>\n<<currentField>>\n</$link>\n</$list>\n</$linkcatcher>\n</div>\n</$reveal>\n<span class=\"tc-edit-field-add-value\">\n<$edit-text tiddler=\"$:/temp/newfieldvalue\" tag=\"input\" default=\"\" placeholder={{$:/language/EditTemplate/Fields/Add/Value/Placeholder}} class=\"tc-edit-texteditor\"/>\n</span>\n<span class=\"tc-edit-field-add-button\">\n<$macrocall $name=\"new-field\"/>\n</span>\n</div>\n</$fieldmangler>\n\\end",
"title": "$:/plugins/kookma/commander/macro/compInspect/edit-fileds",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190317085037429"
},
"$:/plugins/kookma/commander/macro/compSelect": {
"created": "20190308070713468",
"creator": "Mohammad",
"text": "\\define compSelect(filter:\"\", stateTiddler:\"\", default:\"\", class:\"\", showButtons:\"show\")\n<$select tiddler=<<__stateTiddler__>> default=<<__default__>> class=<<__class__>> >\n<option value=\"\">None</option>\n<$list filter=<<__filter__>> variable=item>\n<option value=<<item>>><$text text=<<item>> /></option>\n</$list>\n</$select>\n<$reveal type=\"match\" text=\"show\" default=<<__showButtons__>> >\n<$vars myfilter=<<__filter__>> mystateTiddler=<<__stateTiddler__>> myitem={{{ [<__stateTiddler__>get[text]] }}} >\n<$button actions=<<cs-prev-item>> class=\"cm-btn\"> prev </$button>\n<$button actions=<<cs-next-item>> class=\"cm-btn\"> next </$button>\n</$vars>\n</$reveal>\n\\end\n\n\\define cs-prev-item()\n<$list filter=\"[subfilter<myfilter>] +[before<myitem>]\" variable=\"prev-item\" >\n<$action-setfield $tiddler=<<mystateTiddler>> text=<<prev-item>> />\n</$list>\n\\end\n\n\\define cs-next-item()\n<$list filter=\"[subfilter<myfilter>] +[after<myitem>]\" variable=\"next-item\" >\n<$action-setfield $tiddler=<<mystateTiddler>> text=<<next-item>> />\n</$list>\n\\end",
"title": "$:/plugins/kookma/commander/macro/compSelect",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190317084203286"
},
"$:/plugins/kookma/commander/stylesheet/buttons": {
"created": "20190317080436103",
"creator": "Mohammad",
"text": ".cm-btn{\n font-size:0.85em;\n font-size:300;\n color: #666666;\n background-color: #d8d8d8;\n padding: 3px 8px 3px 8px;\n border: 1px solid #a1a1a1;\n}\n",
"type": "text/css",
"title": "$:/plugins/kookma/commander/stylesheet/buttons",
"tags": "$:/tags/Stylesheet",
"modifier": "Mohammad",
"modified": "20190317085149339"
},
"$:/plugins/kookma/commander/macro/snr/regexpsub.js": {
"created": "20190214160253135",
"creator": "Mohammad",
"text": "/*\\\ntitle: $:/plugins/kookma/commander/macro/snr/regexpsub.js\ntype: application/javascript\nmodule-type: macro\n\nMake regular expression substitutions\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"regexpsub\";\n\nexports.params = [\n\t{name: \"searchValue\"},\n\t{name: \"replaceValue\"},\n\t{name: \"sourceText\"},\n\t{name: \"flags\"},\n {name: \"wholeWords\"}\n];\n\n/*\nRun the macro\n*/\nexports.run = function(searchValue, replaceValue, sourceText, flags = \"gi\", wholeWords = \"characters\") {\n \n try {\n \n\tvar searchText;\n if(wholeWords.toLowerCase() === 'words'){\n searchText = \"\\\\b\" + searchValue + \"\\\\b\";\n } else{\n searchText = searchValue;\n }\n searchText = new RegExp(searchText, flags);\n\n\t\n\treturn sourceText.replace(searchText,replaceValue);\n\n } \n catch(err) { \n return \"ERROR IN REG EXPRESSION. YOU MAY NEED TO ESCAPE VALUES\"; \n }\n \n };\n\n})();\n",
"type": "application/javascript",
"title": "$:/plugins/kookma/commander/macro/snr/regexpsub.js",
"tags": "snr",
"module-type": "macro",
"modifier": "Mohammad",
"modified": "20190317171519161",
"description": "Developed by Mark S"
},
"$:/plugins/kookma/commander/help/warning": {
"text": "<<alert primary \"\"\"''Note i:''\nTiddler Commander is a very powerful tool, it can change any field in any tiddler. Make sure what you are doing!\n\"\"\">>\n\n<<alert warning \"\"\"''Note ii''\nTiddler Commander uses two steps tiddler selection. It uses a search box to filter possible tiddlers and then uses a selective list of fitered tiddlers for batch operation!\n\"\"\">>\n\n<<alert info \"\"\"''Note iii''\n//Commander do not perform operation on shadow tiddlers//, unless they are overriden. Because shadow tiddlers aren’t stored as ''real'' tiddlers. They are intentionally excluded from most operations by default so that they don’t clutter filters made by users unless explicitly required. \n\"\"\">>\n\n<<alert danger \"\"\"''Warning''\nThis tool is still being developed. It is for demonstration purposes only. Before this tool, `Tiddler Commander`, on your own valuable, irreplaceable data, backup them.\n\"\"\">>\n\n",
"title": "$:/plugins/kookma/commander/help/warning",
"tags": "$:/tags/Commander/Help",
"modifier": "Mohammad",
"modified": "20190323203452964",
"creator": "Mohammad",
"created": "20190314050138754",
"caption": "Warning"
},
"$:/plugins/kookma/commander/help/what-is-commander": {
"text": "Tiddler Commander, in short ''Commander'' is a unique tool for batch operations on tiddlers. Commander has the below features\n\n* Bulk tiddler creation/deletion\n* Tag operation: add, remove, replace\n* Field operation: add, remove, set field value\n* ''SNR'', search and replace in all fields including text, tags, title, and common fields\n* ''Inspect'', to review and inspect tiddlers in one place, scroll among them and edit all fields (including common fields), tags, text (title is an exception!)\n* log, create logs of all operations\n* Search, //save and load// any combination of filter search\n\n<<alert warning \"''Note'': //Commander will not work on shadow tiddlers//, unless they are overriden! Because shadow tiddlers aren’t stored as ''real'' tiddlers. They are intentionally excluded from most operations by default so that they don’t clutter filters made by users unless explicitly required.\">>",
"title": "$:/plugins/kookma/commander/help/what-is-commander",
"tags": "$:/tags/Commander/Help",
"modifier": "Mohammad",
"modified": "20190323203625811",
"creator": "Mohammad",
"created": "20190314134238047",
"caption": "What is Commander"
},
"$:/plugins/kookma/commander/macro/snr/ui": {
"text": "\\define snr-ui()\n\n<div class=\"snr-row\">\n<div class=\"snr-double-column\">\n<<snr-ui-inputs>>\n</div>\n<div class=\"snr-column\">\n<<snr-regexp-flags>> \n</div>\n</div>\n<<snr-ui-show-diffs>>\n<<snr-actions>>\n\\end\n",
"title": "$:/plugins/kookma/commander/macro/snr/ui",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190307185104618",
"creator": "Mohammad",
"created": "20190306133310512"
},
"$:/plugins/kookma/commander/setting/snr": {
"created": "20190324051157188",
"creator": "Mohammad",
"text": "<<snr-difftext-cleanup>>\n<div style=\"padding-left:25px;font-size:0.9em\">\n\nThe cleanup attribute determines which optional post-processing should be applied to the diffs:\n\n* none: no cleanup is performed\n* semantic (default): rewrites the diffs for human readability\n* efficient: rewrites the diffs to minimise the number of operations for subsequent processing\n</div>",
"title": "$:/plugins/kookma/commander/setting/snr",
"tags": "$:/tags/Commander/Setting",
"modifier": "Mohammad",
"modified": "20190324053417842",
"caption": "Snr setting"
},
"$:/plugins/kookma/commander/ui/textops/replace-text": {
"text": "<<snr-ui>>",
"title": "$:/plugins/kookma/commander/ui/textops/replace-text",
"tags": "$:/tags/Commander/SnrOps",
"modifier": "Mohammad",
"modified": "20190324052012224",
"icon": "$:/core/images/gitter",
"creator": "Mohammad",
"created": "20190220211138573",
"caption": "Search and replace"
},
"$:/plugins/kookma/commander/macro/snr/ui/setting": {
"created": "20190324052145002",
"creator": "Mohammad",
"text": "\\define snr-difftext-cleanup()\n\n<form class=\"snr-form\">\n<fieldset>\n<legend>Difftext cleanup</legend>\n\n<$radio\n tiddler=\"$:/state/commander/snr/setting/cleanup\" \n field=\"text\" \n value=\"none\"> none\n</$radio><br>\n\n<$radio\n tiddler=\"$:/state/commander/snr/setting/cleanup\" \n field=\"text\" \n value=\"semantic\"> semantic\n</$radio><br>\n\n<$radio\n tiddler=\"$:/state/commander/snr/setting/cleanup\" \n field=\"text\" \n value=\"efficient\"> efficient \n</$radio>\n\n</fieldset>\n</form>\n\\end",
"title": "$:/plugins/kookma/commander/macro/snr/ui/setting",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190324053838682"
},
"$:/plugins/kookma/commander/macro/snr/replace-text": {
"created": "20190227134610136",
"creator": "Mohammad",
"text": "\\define nothing-to-replace(tiddler, field) \n<$diff-text source={{{ [<__tiddler__>get<__field__>] }}} dest={{{ [<__tiddler__>get<__field__>] }}} />\n\\end\n\n\\define replace-text(tiddler:\"\",field:\"text\",replace:\"\",replaceWith:\"\",flags:\"\", wholeWords:\"\")\n\\whitespace trim\n<$wikify name=\"source\" text=\"\"\"<$view tiddler=<<__tiddler__>> field=<<__field__>> mode=\"block\" format=\"text\"/>\"\"\">\n<$wikify name=\"result\" \n text=\"\"\"<$macrocall $name=\"regexpsub\" $type=\"text/plain\" \n sourceText=<<source>> \n searchValue=<<__replace__>> \n replaceValue=<<__replaceWith__>> \n flags=<<__flags__>> \n wholeWords=<<__wholeWords__>> />\"\"\" \n >\n<$text text=<<result>>/>\n</$wikify>\n</$wikify>\n\\end\n\n\\define replace-text-diff(tiddler:\"\", field:\"text\", replace, replaceWith, flags:\"\", wholeWords:\"\")\n<$list filter=\"[<__tiddler__>get<__field__>minlength[1]]\" variable=null emptyMessage=\"No tiddler selected\">\n<$list filter=\"[<__replace__>minlength[1]]\" variable=null emptyMessage=<<nothing-to-replace \"\"\"$tiddler$\"\"\" \"\"\"$field$\"\"\">> >\n\n<$wikify name=\"result\" \n text=\"\"\"<$macrocall $name=\"replace-text\" \n tiddler=<<__tiddler__>> field=<<__field__>> \n replace=<<__replace__>> \n replaceWith=<<__replaceWith__>> \n flags=<<__flags__>>\n wholeWords=<<__wholeWords__>> />\"\"\"\n >\n<$diff-text source={{{ [<__tiddler__>get<__field__>] }}} dest=<<result>> cleanup={{$:/state/commander/snr/setting/cleanup}}/>\n</$wikify>\n\n</$list>\n</$list>\n\\end\n\n\\define replace-text-button(tiddler:\"\", field:\"text\", replace:\"\", replaceWith:\"\", flags:\"\", wholeWords:\"\")\n\\whitespace trim\n<$list filter=\"[<__tiddler__>get<__field__>minlength[1]]\" variable=null>\n<$list filter=\"[<__replace__>minlength[1]]\" variable=null>\n<$wikify name=\"result\" \n text=\"\"\"<$macrocall $name=\"replace-text\" \n tiddler=<<__tiddler__>> \n field=<<__field__>> \n replace=<<__replace__>> \n replaceWith=<<__replaceWith__>> \n flags=<<__flags__>>\n wholeWords=<<__wholeWords__>> />\"\"\"\n >\n<$reveal type=\"nomatch\" default=\"title\" text=<<__field__>> >\n <$action-setfield $tiddler=<<__tiddler__>> $field=<<__field__>> $value=<<result>>/>\n</$reveal>\n<$reveal type=\"match\" default=\"title\" text=<<__field__>> >\n <$action-setfield $tiddler=<<__tiddler__>> $field=<<__field__>> $value=<<result>>/>\n <$action-deletetiddler $tiddler=<<__tiddler__>> />\n</$reveal>\n</$wikify>\n</$list>\n</$list>\n\\end\n",
"title": "$:/plugins/kookma/commander/macro/snr/replace-text",
"tags": "$:/tags/Macro",
"modifier": "Mohammad",
"modified": "20190324053727065"
}
}
}
{
"tiddlers": {
"$:/plugins/matabele/makelist.js": {
"text": "/*\\\ntitle: $:/plugins/matabele/makelist.js\ntype: application/javascript\nmodule-type: widget\n\nMakeListWidget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar MakeListWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n\tthis.addEventListeners([\n\t\t{type: \"tw-make-list\", handler: \"handleMakeList\"}\n\t]);\n};\n\n/*\nInherit from the base widget class\n*/\nMakeListWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nMakeListWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tthis.renderChildren(parent,nextSibling);\n};\n\n/*\nCompute the internal state of the widget\n*/\nMakeListWidget.prototype.execute = function() {\n\t// Get our parameters\n\tthis.catchTiddler = this.getAttribute(\"tiddler\");\n\tthis.catchSet = this.getAttribute(\"set\",\"!!list\");\n\tthis.catchFilter = this.getAttribute(\"filter\");\n\tthis.catchMessage = this.getAttribute(\"message\");\n\tthis.catchParam = this.getAttribute(\"param\");\n\t// Construct the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nMakeListWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.tiddler || changedAttributes.message || changedAttributes.param || changedAttributes.set || changedAttributes.filter) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\telse {\n\t\treturn this.refreshChildren(changedTiddlers);\t\t\n\t}\n};\n\n/*\nHandle a tw-set-field event\n*/\nMakeListWidget.prototype.handleMakeList = function(event) { \n\t// Set defaults\n\tthis.targetTiddler = this.getVariable(\"currentTiddler\");\n\tif(event.param) {\n\t\tthis.sendParam = event.param;\n\t\tthis.targetTiddler = event.param;\n\t} \n\tif(this.catchTiddler) {\n\t\t// new modification\n\t\tthis.sendParam = this.catchTiddler;\n\t\t// end\n\t\tthis.targetTiddler = this.catchTiddler;\n\t}\n\tif(this.catchParam) {\n\t\tthis.sendParam = this.catchParam;\n\t}\n\t// Set the value of the text-reference\n\tvar listTiddlers=$tw.wiki.filterTiddlers(this.catchFilter);\n\tvar stringTiddlers=$tw.utils.stringifyList(listTiddlers); \n\tif(this.catchSet) {\n\t\tthis.wiki.setTextReference(this.catchSet,stringTiddlers,\n\t\tthis.targetTiddler);\n\t}\n\t// Send another message or return true\n\tif(this.catchMessage && (this.catchMessage != \"tw-make-list\")) {\n\t\tthis.dispatchEvent({type: this.catchMessage,param: this.sendParam});\n\t}\n\telse {\n\t\treturn true;\n\t}\n};\n\nexports.makelist = MakeListWidget;\n\n})();\n",
"type": "application/javascript",
"title": "$:/plugins/matabele/makelist.js",
"revision": "2",
"module-type": "widget",
"modifier": "Matabele",
"modified": "20140622094047319",
"creator": "Matabele",
"created": "20140607174148675",
"bag": "default"
}
}
}
/*\
title: $:/plugins/skeeve/let.js
type: application/javascript
module-type: widget
Set variables widget
```
<$let name=value …>
:
</$let>
```
Example:
```
<$let a="1" b="2" c="3" d="4">
<<someMacro>>
</$let>
```
\*/
(function(){
/*jslint node: true, browser: true */
/*global $tw: false */
"use strict";
var Widget = require("$:/core/modules/widgets/widget.js").widget;
var LetWidget = function(parseTreeNode,options) {
this.initialise(parseTreeNode,options);
};
/*
Inherit from the base widget class
*/
LetWidget.prototype = new Widget();
/*
Render this widget into the DOM
*/
LetWidget.prototype.render = function(parent,nextSibling) {
this.parentDomNode = parent;
this.computeAttributes();
this.execute();
this.renderChildren(parent,nextSibling);
};
/*
Compute the internal state of the widget
*/
LetWidget.prototype.execute = function() {
// Get our parameters
// As there is nothing which will give me the attributes,
// I have to access the object myself…
for(var name in this.attributes) {
this.setVariable(name, this.attributes[name], this.parseTreeNode.params);
}
// Construct the child widgets
this.makeChildWidgets();
};
/*
Selectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering
*/
LetWidget.prototype.refresh = function(changedTiddlers) {
var changedAttributes = this.computeAttributes();
for(var attr in changedAttributes) {
if(changedAttributes[attr]) {
this.refreshSelf();
return true;
}
}
return this.refreshChildren(changedTiddlers);
};
exports.let = LetWidget;
})();
{
"tiddlers": {
"$:/help/skeeve/ListselectWidget": {
"created": "20140227194654308",
"creator": "Stephan Hradek",
"modified": "20140228194813263",
"modifier": "Stephan Hradek",
"my_color": "#8bbec7",
"tags": "$:/HELP",
"title": "$:/help/skeeve/ListselectWidget",
"type": "text/vnd.tiddlywiki",
"text": "\\define colorbox()\n<div style=\"display:inline-block; width:16px; height:16px; background-color:$(color)$\"/>\n\\end\n\nThe [[ListselecWidget|$:/plugins/skeeve/listselect.js]] widgets creates an HTML ``<select>`` element, which allows to set a field value.\n\nTo be most flexible, the list of options is created using [[TiddlerFilters]]. This allows you to create options:\n\n* based on existing tiddlers and their fields\n* from fixed strings\n\nOption labels and values need not be identical, as you can see in the first example below. It searches for all tiddlers having a \"color\" field. The label of the option is the title of the tiddler, the value is taken from the tiddler's color field:\n\n```\n<$listselect\n filter=\"[!field:color[]!has[draft.of]sort[title]]\"\n value=\"color\"\n tiddler=\"$:/temp/search\"\n field=\"my_color\"/>\n```\nSelect a tag's color <$listselect filter=\"[!field:color[]!has[draft.of]sort[title]]\" value=\"color\" tiddler=\"$:/temp/search\" field=\"my_color\"/> <$set name=\"color\" value={{$:/temp/search!!my_color}}><<colorbox>></$set>\n\nIn that example, the option's value was taken from a field. But it is also possible to take the option's label from a field by setting ``label=\"fieldname\"``.\n\nThe next example shows how to create a list of options based on fixed strings:\n\n```\n<$listselect filter=\"[[Apple:218 kj]] [[Apricot:201 kj]] …\n labelvalue=\":\">\n```\nThe attribute ``labelvalue=\":\"`` defines the ``:`` to seperate labels from values. If you happen to have labels and values the other way around, use ``valuelabel=\":\"``. You can use any character in place of the ``;``.\n\n<$listselect filter=\"[[Apple:218 kj]] [[Apricot:201 kj]] [[Avocado:670 kj]] [[Banana:393 kj]] [[Boysenberries:312 kj]] [[Blueberries:339 kj]] [[Dates:2047 kj]] [[Grapefruit:343 kj]] [[Grapes:475 kj]] [[Kiwi fruit:194 kj]] [[Lemon:70 kj]] [[Melon:101 kj]] [[Nectarine:279 kj]] [[Oranges:361 kj]] [[Peaches:176 kj]] [[Pear:410 kj]] [[Pineapple:318 kj]] [[Plums:152 kj]] [[Raspberries:252 kj]] [[Strawberries:190 kj]] [[Watermelon:383 kj]]\" labelvalue=\":\" field=\"my_calories\" tiddler=\"$:/temp/search\"/> <$view field=\"my_calories\" tiddler=\"$:/temp/search\"/>\n\n|Parameter |Description |h\n|tiddler |Name of the tiddler in which the field should be set. Defaults to current tiddler |\n|field |The name of the field to be set |\n|filter |A filter expression which should give the list of possible values |\n|label |The name of a field in the currentTiddler which holds the label of the option. Default \"title\" |\n|value |The name of a field in the currentTiddler which holds the value of the option. Default \"title\" |\n|labelvalue |defines the character (or string) which seperates label and value |\n|valuelabel |defines the character (or string) which seperates value and label |\n|class |Optional class name(s) |"
},
"$:/plugins/skeeve/listselect.js": {
"text": "/*\\\ntitle: $:/plugins/skeeve/listselect.js\ntype: application/javascript\nmodule-type: widget\n\nlistselect widget\n\nWill set a field to the selected value:\n\n```\n\t<$listselect field=\"myfield\" filter=\"filter...\"/>\n```\n\n|Parameter |Description |h\n|tiddler |Name of the tiddler in which the field should be set. Defaults to current tiddler |\n|field |The name of the field to be set |\n|filter |A filter expression which should give the list of possible values |\n|label |The name of a field in the currentTiddler which holds the label of the option. Default \"title\" |\n|value |The name of a field in the currentTiddler which holds the value of the option. Default \"title\" |\n|labelvalue |defines the character (or string) which seperates label and value |\n|valuelabel |defines the character (or string) which seperates value and label |\n|class |Optional class name(s) |\n\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar ListselectWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nListselectWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nListselectWidget.prototype.render = function(parent,nextSibling) {\n\t// Save the parent dom node\n\tthis.parentDomNode = parent;\n\t// Compute our attributes\n\tthis.computeAttributes();\n\t// Execute our logic\n\tthis.execute();\n\t// Create our elements\n\tthis.inputDomNode = this.document.createElement(\"select\");\n\t\n\tthis.optionlist = this.getOptionList();\n\tthis.newOptions();\n\t\n\t// Add a click event handler\n\t$tw.utils.addEventListeners(this.inputDomNode,[\n\t\t{name: \"change\", handlerObject: this, handlerMethod: \"handleChangeEvent\"}\n\t]);\n\t// Insert into the DOM and render any children\n\tparent.insertBefore(this.inputDomNode,nextSibling);\n\tthis.renderChildren(this.inputDomNode,null);\n\tthis.domNodes.push(this.inputDomNode);\n};\n\n/*\nCompute the internal state of the widget\n*/\nListselectWidget.prototype.execute = function() {\n\t// Get the parameters from the attributes\n\tthis.selectTitle = this.getAttribute(\"tiddler\",this.getVariable(\"currentTiddler\"));\n\tthis.selectField = this.getAttribute(\"field\");\n\tthis.selectLabel = this.getAttribute(\"label\");\n\tthis.selectValue = this.getAttribute(\"value\");\n\tthis.selectLVSep = this.getAttribute(\"labelvalue\");\n\tthis.selectVLSep = this.getAttribute(\"valuelabel\");\n\tthis.selectedIndex = null;\n\tthis.getOptionLabel = function(title) {\n\t\treturn title;\n\t};\n\tthis.getOptionValue = function(title) {\n\t\treturn title;\n\t};\n\tif(this.selectLabel || this.selectValue) {\n\t\tif(this.selectLabel && this.selectLabel !== \"title\") {\n\t\t\tthis.getOptionLabel = function(title) {\n\t\t\t\tvar tiddler = this.wiki.getTiddler(title); \n\t\t\t\treturn tiddler && tiddler.getFieldString(this.selectLabel) || title;\n\t\t\t};\n\t\t}\n\t\tif(this.selectValue && this.selectValue !== \"title\") {\n\t\t\tthis.getOptionValue = function(title) {\n\t\t\t\tvar tiddler = this.wiki.getTiddler(title); \n\t\t\t\treturn tiddler && tiddler.getFieldString(this.selectValue) || title;\n\t\t\t};\n\t\t}\n\t}\n\telse if(this.selectLVSep) {\n\t\tthis.getOptionLabel = function(title) {\n\t\t\treturn (title.split(this.selectLVSep,2))[0];\n\t\t};\n\t\tthis.getOptionValue = function(title) {\n\t\t\treturn (title.split(this.selectLVSep,2))[1];\n\t\t};\n\t}\n\telse if(this.selevtVLSep) {\n\t\tthis.getOptionLabel = function(title) {\n\t\t\treturn (title.split(this.selevtVLSep,2))[1];\n\t\t};\n\t\tthis.getOptionValue = function(title) {\n\t\t\treturn (title.split(this.selevtVLSep,2))[0];\n\t\t};\n\t}\n\tthis.selectClass = this.getAttribute(\"class\",\"\");\n\tif(this.selectClass !== \"\") {\n\t\tthis.selectClass += \" \";\n\t}\n\tthis.selectClass += \"tw-listselect\";\n\t// Compose the list elements\n\tthis.selectOptions = this.getOptionList();\n\t// this.makeChildWidgets();\n};\n\n/*\nCreate the list of options\n*/\nListselectWidget.prototype.newOptions = function() {\n\tfor( var i = 0 ; i < this.optionlist.label.length ; ++i) {\n\t var option = this.document.createElement(\"option\");\n\t option.setAttribute(\"value\",this.optionlist.value[i]);\n\t var optiontext = this.document.createTextNode(this.optionlist.label[i]);\n\t option.appendChild(optiontext);\n\t this.inputDomNode.options[i] = option;\n\t}\n\tthis.inputDomNode.options.length = this.optionlist.label.length;\n\tthis.setSelectedIndex(this.getValue());\n};\n\n/*\nFind the first option, matching the current value - or create an option\n*/\nListselectWidget.prototype.setSelectedIndex = function(val) {\n\tvar i = this.optionlist.value.indexOf(val);\n\tif(i < 0) {\n\t\ti = this.optionlist.label.length;\n\t\tvar option = this.document.createElement(\"option\");\n\t\toption.setAttribute(\"value\",val);\n\t\tvar optiontext = this.document.createTextNode(val);\n\t\toption.appendChild(optiontext);\n\t\tthis.inputDomNode.options[i]= option;\n\t}\n\tthis.selectedIndex = i;\n\tthis.inputDomNode.selectedIndex = i;\n};\n\n/*\nget our list of options\n*/\nListselectWidget.prototype.getOptionList = function() {\n\t//console.log(\"ListselectWidget.prototype.getOptionList\");\n\tvar defaultFilter = \"[!is[system]sort[title]]\";\n\tvar tiddlers = this.wiki.filterTiddlers(this.getAttribute(\"filter\",defaultFilter),this.getVariable(\"currentTiddler\"));\n\tvar optionlist = { label:[\"\"], value:[\"\"] };\n\tfor( var i = 0 ; i < tiddlers.length ; ++i) {\n\t\toptionlist.label.push(this.getOptionLabel(tiddlers[i]));\n\t\toptionlist.value.push(this.getOptionValue(tiddlers[i]));\n\t}\n\treturn optionlist;\n};\n\n/*\nretrieve the current value\n*/\nListselectWidget.prototype.getValue = function() {\n\tvar tiddler = this.wiki.getTiddler(this.selectTitle);\n\treturn tiddler && tiddler.getFieldString(this.selectField) || \"\";\n};\n\n/*\nset the current value\n*/\nListselectWidget.prototype.setValue = function(val) {\n\tif(this.selectField) {\n\t\tvar tiddler = this.wiki.getTiddler(this.selectTitle),\n\t\t\taddition = {};\n\t\taddition[this.selectField] = val;\n\t\tthis.wiki.addTiddler(new $tw.Tiddler(tiddler,addition));\n\t}\n};\n\n/*\nset the newly selected value\n*/\nListselectWidget.prototype.handleChangeEvent = function(event) {\n\tthis.selectedIndex = event.target.selectedIndex;\n \tthis.setValue(event.target.value);\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nListselectWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.tiddler || changedAttributes.field || changedAttributes.filter\n\t\t|| changedAttributes.label || changedAttributes.value\n\t\t|| changedAttributes.labelvalue || changedAttributes.valuelabel\n\t\t|| changedAttributes[\"class\"]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\t// did the list of options change?\n\t\tvar newoptionlist = this.getOptionList();\n\t\tidentical:\n\t\tif (newoptionlist.label.length === this.optionlist.label.length) {\n\t\t\t// same length, compare elements\n\t\t\tfor(var i=0 ; i < newoptionlist.label.length ; ++i) {\n\t\t\t\tif(newoptionlist.label[i] !== this.optionlist.label[i]) break identical;\n\t\t\t\tif(newoptionlist.value[i] !== this.optionlist.value[i]) break identical;\n\t\t\t}\n\t\t\t// so both lists are identical. But what about the value?\n\t\t\tvar currentValue = this.getValue();\n\t\t\tif( this.selectedIndex > this.optionlist.value.length || currentValue != this.optionlist.value[this.selectedIndex] ) {\n\t\t\t\tthis.setSelectedIndex(currentValue);\n\t\t\t}\n\t\t\treturn true\n\t\t}\n\t\t// The list changed - create a new one.\n\t\tthis.optionlist = newoptionlist;\n\t\tthis.newOptions();\n\t\treturn true;\n\t}\n};\n\nexports.listselect = ListselectWidget;\n\n})();\n",
"title": "$:/plugins/skeeve/listselect.js",
"type": "application/javascript",
"module-type": "widget"
}
}
}
{
"tiddlers": {
"$:/help/skeeve/NewtiddlerWidget": {
"created": "20131219134809679",
"creator": "Stephan Hradek",
"modified": "20140303191836454",
"modifier": "Stephan Hradek",
"tags": "$:/HELP",
"title": "$:/help/skeeve/NewtiddlerWidget",
"type": "text/vnd.tiddlywiki",
"text": "This is a test for the highly experimental New-Tiddler-Button which allows to pre fill a skeleton tiddler with variable data.\n\nThe New-Tiddler-Button expects 2 parameters:\n\n|Parameter |Mandatory |Explanation |h\n|title |yes |the title of the new tiddler. Will get numbers appended |\n|skeleton |yes |an existing tiddler which may contain variable placeholders |\n|edit |no |This defines wether to open the new tiddler in edit mode. Must be one of \"yes\", \"no\", \"show\" or (not implemented yet) \"inline\". Defaults to \"yes\". |\n\nThe most important part lies in the skeleton! TiddlyWiki already can clone tiddlers, but you can't really prefill data of the newly created tiddler.\n\nWith `<$newtiddler>` you can put placeholders of the form `$(variable)$` ''anywhere'' in the tiddler and they will be replaced by the values of the variables set with the `<$set>` or `<$let>` widget. Please note: The placeholders can be ''anywhere''! In the tiddlers body, in fields, types, you name it…\n\nThe example skeleton used here looks like this:\n\n|Property |Content |h\n|title |skeleton 1 |\n|text |This is some test: $(placeholder)$ |\n|tags |$(tag1}$ |\n|field1 |$(f1)$ |\n|field2 |$(f2)$ |\n\nIf we now put this into our tiddler:\n\n```\n<$set name=\"f1\" value=<<qualify \"unique\">> >\n<$set name=\"f2\" value=\"field-2\">\n<$set name=\"placeholder\" value=\"pl1\">\n<$set name=\"tag1\" value=\"testtag\">\n<$newtiddler title=\"test\" skeleton=\"$:/plugins/skeeve/newtiddler/SkeletonExample\">Create</$newtiddler>\n</$set>\n</$set>\n</$set>\n</$set>\n```\n\nWe get a <$set name=\"f1\" value=<<qualify \"unique\">> ><$set name=\"f2\" value=\"field-2\"><$set name=\"placeholder\" value=\"pl1\"><$set name=\"tag1\" value=\"testtag\"><$newtiddler title=\"test\" skeleton=\"$:/plugins/skeeve/newtiddler/SkeletonExample\">Create</$newtiddler></$set></$set></$set></$set> button.\n\nClicking it, will open a new tiddler with some values pre-filled."
},
"$:/plugins/skeeve/newtiddler/SkeletonExample": {
"created": "20131218133637784",
"creator": "Stephan Hradek",
"field1": "$(f1)$",
"field2": "$(f2)$",
"modified": "20140303191730416",
"modifier": "Stephan Hradek",
"tags": "$(tag1)$",
"title": "$:/plugins/skeeve/newtiddler/SkeletonExample",
"type": "text/vnd.tiddlywiki",
"text": "This is some test: $(placeholder)$"
},
"$:/plugins/skeeve/newtiddler.js": {
"text": "/*\\\ntitle: $:/plugins/skeeve/newtiddler.js\ntype: application/javascript\nmodule-type: widget\n\nnewtiddler widget\n\n```\n<$newtiddler title=\"name\" skeleton=\"name\">Buttontext</$newtiddler>\n```\n\nThe skeleton tiddler may contain variables which are replaced during creation\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar NewtiddlerWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nNewtiddlerWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nNewtiddlerWidget.prototype.render = function(parent,nextSibling) {\n\tvar self = this;\n\t// Remember parent\n\tthis.parentDomNode = parent;\n\t// Compute attributes and execute state\n\tthis.computeAttributes();\n\tthis.execute();\n\t// Create element\n\tvar domNode = this.document.createElement(\"button\");\n\t// Assign classes\n\tdomNode.className = this.newtiddlerClass;\n\t// Assign styles\n\tif(this.style) {\n\t\tdomNode.setAttribute(\"style\",this.style);\n\t}\n\t// Add a click event handler\n\t$tw.utils.addEventListeners(domNode,[\n\t\t{name: \"click\", handlerObject: this, handlerMethod: \"handleClickEvent\"}\n\t]);\n\t// Insert element\n\tparent.insertBefore(domNode,nextSibling);\n\tthis.renderChildren(domNode,null);\n\tthis.domNodes.push(domNode);\n};\n\nNewtiddlerWidget.prototype.handleClickEvent = function(event) {\n\tvar skeleton = this.wiki.getTiddlerAsJson(this.newtiddlerSkeleton);\n\tvar skeletonClone = JSON.parse(this.substituteVariableReferences(skeleton));\n\tvar basetitle = this.newtiddlerTitle;\n\tvar title = basetitle;\n\tfor(var t=1; this.wiki.tiddlerExists(title); t++) {\n\t\ttitle = basetitle + \" \" + t;\n\t}\n\tskeletonClone.title = title;\n\tvar created = this.wiki.getCreationFields();\n\tfor(var creationField in created) {\n\t\tskeletonClone[creationField] = created[creationField];\n\t}\n\tvar modified = this.wiki.getModificationFields();\n\tfor(var modificationField in modified) {\n\t\tskeletonClone[modificationField] = modified[modificationField];\n\t}\n\tthis.wiki.addTiddler(skeletonClone);\n\tswitch(this.newtiddlerEdit) {\n\tcase \"show\":\n\tcase \"yes\":\n\t\tvar bounds = this.domNodes[0].getBoundingClientRect();\n\t\tthis.dispatchEvent({\n\t\t\ttype: \"tw-navigate\",\n\t\t\tnavigateTo: title,\n\t\t\tnavigateFromTitle: this.getVariable(\"currentTiddler\"),\n\t\t\tnavigateFromNode: this,\n\t\t\tnavigateFromClientRect: { top: bounds.top, left: bounds.left, width: bounds.width, right: bounds.right, bottom: bounds.bottom, height: bounds.height\n\t\t\t}\n\t\t});\n\t\tif(this.newtiddlerEdit === \"yes\") {\n\t\t\tthis.dispatchEvent({type: \"tw-edit-tiddler\", tiddlerTitle: title});\n\t\t}\n\t\tbreak;\n\tcase \"no\":\n\t\tbreak;\n\tcase \"inline\":\n\t\t// not implemented yet\n\t\tbreak;\n\t}\n};\n\n\n/*\nCompute the internal state of the widget\n*/\nNewtiddlerWidget.prototype.execute = function() {\n\t// Get attributes\n\tthis.newtiddlerTitle = this.getAttribute(\"title\");\n\tthis.newtiddlerSkeleton = this.getAttribute(\"skeleton\");\n\tthis.newtiddlerEdit = this.getAttribute(\"edit\", \"yes\");\n\tthis.newtiddlerClass = this.getAttribute(\"class\",\"\");\n\tthis.newtiddlerStyle = this.getAttribute(\"style\");\n\tif(this.newtiddlerClass != \"\") {\n\t\tthis.newtiddlerClass = \" \" + this.newtiddlerClass;\n\t}\n\tthis.newtiddlerClass = \"tw-newtiddler-button\" + this.newtiddlerClass;\n\t// Make child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nNewtiddlerWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.title || changedAttributes.skeleton || changedAttributes.class || changedAttributes.style) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t}\n\treturn this.refreshChildren(changedTiddlers);\n};\n\nexports.newtiddler = NewtiddlerWidget;\n\n})();\n",
"title": "$:/plugins/skeeve/newtiddler.js",
"type": "application/javascript",
"module-type": "widget"
}
}
}
/*\
title: $:/plugins/skeeve/newtiddler.js
type: application/javascript
module-type: widget
newtiddler widget
```
<$newtiddler title="name" skeleton="name">Buttontext</$newtiddler>
```
The skeleton tiddler may contain variables which are replaced during creation
\*/
(function(){
/*jslint node: true, browser: true */
/*global $tw: false */
"use strict";
var Widget = require("$:/core/modules/widgets/widget.js").widget;
var NewtiddlerWidget = function(parseTreeNode,options) {
this.initialise(parseTreeNode,options);
};
/*
Inherit from the base widget class
*/
NewtiddlerWidget.prototype = new Widget();
/*
Render this widget into the DOM
*/
NewtiddlerWidget.prototype.render = function(parent,nextSibling) {
var self = this;
// Remember parent
this.parentDomNode = parent;
// Compute attributes and execute state
this.computeAttributes();
this.execute();
// Create element
var domNode = this.document.createElement("button");
// Assign classes
domNode.className = this.newtiddlerClass;
// Assign styles
if(this.style) {
domNode.setAttribute("style",this.style);
}
// Add a click event handler
$tw.utils.addEventListeners(domNode,[
{name: "click", handlerObject: this, handlerMethod: "handleClickEvent"}
]);
// Insert element
parent.insertBefore(domNode,nextSibling);
this.renderChildren(domNode,null);
this.domNodes.push(domNode);
};
NewtiddlerWidget.prototype.handleClickEvent = function(event) {
var skeleton = this.wiki.getTiddlerAsJson(this.newtiddlerSkeleton);
var skeletonClone = JSON.parse(this.substituteVariableReferences(skeleton));
var basetitle = this.newtiddlerTitle;
var title = basetitle;
for(var t=1; this.wiki.tiddlerExists(title); t++) {
title = basetitle + " " + t;
}
skeletonClone.title = title;
for(var modificationField in this.wiki.getModificationFields()) {
delete skeletonClone[modificationField];
}
var created = this.wiki.getCreationFields();
for(var creationField in created) {
skeletonClone[modificationField] = created[creationField];
}
this.wiki.addTiddler(skeletonClone);
switch(this.newtiddlerEdit) {
case "show":
case "yes":
var bounds = this.domNodes[0].getBoundingClientRect();
this.dispatchEvent({
type: "tw-navigate",
navigateTo: title,
navigateFromTitle: this.getVariable("currentTiddler"),
navigateFromNode: this,
navigateFromClientRect: { top: bounds.top, left: bounds.left, width: bounds.width, right: bounds.right, bottom: bounds.bottom, height: bounds.height
}
});
if(this.newtiddlerEdit === "yes") {
this.dispatchEvent({type: "tw-edit-tiddler", tiddlerTitle: title});
}
break;
case "no":
break;
case "inline":
// not implemented yet
break;
}
};
/*
Compute the internal state of the widget
*/
NewtiddlerWidget.prototype.execute = function() {
// Get attributes
this.newtiddlerTitle = this.getAttribute("title");
this.newtiddlerSkeleton = this.getAttribute("skeleton");
this.newtiddlerEdit = this.getAttribute("edit", "yes");
this.newtiddlerClass = this.getAttribute("class","");
this.newtiddlerStyle = this.getAttribute("style");
if(this.newtiddlerClass != "") {
this.newtiddlerClass = " " + this.newtiddlerClass;
}
this.newtiddlerClass = "tw-newtiddler-button" + this.newtiddlerClass;
// Make child widgets
this.makeChildWidgets();
};
/*
Selectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering
*/
NewtiddlerWidget.prototype.refresh = function(changedTiddlers) {
var changedAttributes = this.computeAttributes();
if(changedAttributes.title || changedAttributes.skeleton || changedAttributes.class || changedAttributes.style) {
this.refreshSelf();
return true;
}
return this.refreshChildren(changedTiddlers);
};
exports.newtiddler = NewtiddlerWidget;
})();
This is some test: $(placeholder)$
{
"tiddlers": {
"$:/plugins/telmiger/details/details.css": {
"text": "/* details and summary */\n\ndetails {\n transition: height 1s ease;\n padding: 0 0.5em 0 0.66em;\n margin-top: 0.66em;\n margin-bottom: 0.66em;\n}\n\ndetails + details {\n margin-top: -0.46em;\n}\n\ndetails[open] {\n padding-bottom: 1em;\n}\n\ndetails:not([open]) { \n cursor: pointer;\n}\n\ndetails > summary {\n display: list-item;\n margin: 0 -0.5em 0 -0.66em;\n padding: 0.2em 0.5em 0.2em 0.66em;\n padding-left: 1.76em; /* adjust for indentation */\n text-indent: -1.1em;\n cursor: pointer;\n}\n\ndetails[open] > summary {\n margin-bottom: 1em;\n}\n\ndetails[open] > *:first-child:not(summary) {\n margin-top: 1em;\n}\n",
"title": "$:/plugins/telmiger/details/details.css",
"tags": "$:/tags/Stylesheet",
"modifier": "Thomas Elmiger",
"modified": "20180929131615369",
"creator": "Thomas Elmiger",
"created": "20170122140815442"
},
"$:/plugins/telmiger/details/details.js": {
"text": "/*\\\ntitle: $:/plugins/telmiger/details/details.js\ntype: application/javascript\nmodule-type: widget\n\nDetails widget v 0.8\n\nWill output an HTML 5 <details> section including a <summary>\n\n```\n\t<details>\n\t\t<summary>This sums it up</summary> \n\t\tAll the details follow here.\n\t</details>\n```\n\n|Parameter |Description |h\n|summary |Optional text to display as summary. Wins over field (see below). |\n|open |Optional initial state, set to \"open\" to show details on load. Defaults to \"\". |\n|state |An optional TextReference containing the state. Wins over open. |\n|field |Optionally, the summary is taken from the field with this name in a given tiddler. Defaults to \"title\". |\n|tiddler |Optional title of a tiddler to watch, connected to field. Defaults to current tiddler. |\n|class |Optional CSS classes to be assigned to the details tag. |\n\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar DetailsWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nDetailsWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nDetailsWidget.prototype.render = function(parent,nextSibling) {\n\t// Save the parent dom node\n\tthis.parentDomNode = parent;\n\t// Compute attributes\n\tthis.computeAttributes();\n\t// Execute logic\n\tthis.execute();\n\t// Create elements\n\tthis.detailsDomNode = this.document.createElement(\"details\");\n\tif(this.detailsClass !== \"\") {\n\t\t// this.detailsClass += \" \";\n\t\t// this.detailsClass += \"tc-details\";\n\t\tthis.detailsDomNode.setAttribute(\"class\",this.detailsClass);\n\t}\n\tif(this.detailsOpen == \"open\") {\n\t\tthis.detailsDomNode.setAttribute(\"open\",\"open\");\n\t}\n\tif(this.detailsSummary !== \"\") {\n\t\tthis.summaryDomNode = this.document.createElement(\"summary\");\n\t\t// this.summaryDomNode.setAttribute(\"class\",\"tc-summary\");\n\t\tthis.detailsDomNode.appendChild(this.summaryDomNode);\n\t\tthis.summaryDomNode.appendChild(this.document.createTextNode(this.detailsSummary));\n\t}\n// register an event listener\n/* Maybe this can be reactivated later, see below.\n\tif(this.detailsStateTitle) {\n\t\t$tw.utils.addEventListeners(this.detailsDomNode,[\n\t\t\t{name: \"toggle\", handlerObject: this, handlerMethod: \"handleToggleEvent\"},\n\t\t]);\n\t}\n*/\n// As iOS mobile browsers lack support of toggle events on details \n// we emulate the toggle event using click\n\tif(this.detailsStateTitle && this.summaryDomNode) {\n\t\t$tw.utils.addEventListeners(this.summaryDomNode,[\n\t\t\t{name: \"click\", handlerObject: this, handlerMethod: \"handleToggleEvent\"},\n\t\t]);\n\t} else {\n\t\tif(this.detailsStateTitle) {\n\t\t\t$tw.utils.addEventListeners(this.detailsDomNode,[\n\t\t\t\t{name: \"click\", handlerObject: this, handlerMethod: \"handleToggleEvent\"},\n\t\t\t]);\n\t\t}\n\t}\n\t// Insert the details into the DOM and render any children\n\tthis.parentDomNode.insertBefore(this.detailsDomNode,nextSibling);\n\tthis.renderChildren(this.detailsDomNode,null);\n\tthis.domNodes.push(this.detailsDomNode);\n};\n\n/*\nRetrieve the value of the summary\n*/\nDetailsWidget.prototype.getSummary = function() {\n\tvar summary = \"\";\n\tif(this.summaryTitle === \"Tiddler not found\" && this.summaryField === \"\") {\n\t// nothing defined: leave empty \n\t\tsummary = \"\";\n\t} else {\n\t\t// tiddler defined? use defined field or title\n\t\tif(this.myTiddler) {\n\t\t\tif(this.summaryField === \"title\" || this.summaryField === \"\") {\n\t\t\t\tsummary = this.summaryTitle;\n\t\t\t} else {\n\t\t\t\tif(this.summaryField === \"text\") {\n \t\t// getTiddlerText() triggers lazy loading of skinny tiddlers\n\t\t\t\t\tsummary = this.wiki.getTiddlerText(this.summaryTitle);\n\t\t\t\t} else {\n\t\t\t\t\tsummary = this.myTiddler.fields[this.summaryField];\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tif(this.summaryField !== \"\" && this.summaryField !== \"text\") {\n\t\t\t\t// try defined field in current tiddler\n\t\t\t\tvar tiddler = this.wiki.getTiddler(this.getVariable(\"currentTiddler\"));\n\t\t\t\tsummary = tiddler.fields[this.summaryField];\n\t\t\t} else {\n\t\t\t\tsummary = \"\";\n\t\t\t}\n\t\t}\n\t}\n return summary;\n};\n\n/*\nRetrieve the value of the state text reference\n*/\nDetailsWidget.prototype.getStateFromReference = function() {\n var state = this.detailsStateTitle ? this.wiki.getTextReference(this.detailsStateTitle,\"\",this.getVariable(\"currentTiddler\")) : \"\";\n return state;\n};\n\n/*\nCheck all open signals, state fields/tiddlers get priority\n*/\nDetailsWidget.prototype.getOpenState = function() {\n\tvar result = \"\";\n\tif((this.detailsOpenDefault !== \"\" && this.detailsOpenDefault !== \"no\") \n\t || this.detailsState === \"open\") {\n\t\tresult = \"open\";\n\t } \n\tif(this.detailsStateTitle !==\"\" && this.detailsState !== \"open\") {\n\t\tresult = \"\";\n\t}\n\treturn result;\n};\n\n/*\nUpdate the state text reference after click event\n*/\nDetailsWidget.prototype.updateState = function(openState) {\n\tvar fieldValue = \"false\";\n\tvar currentTiddler = this.getVariable(\"currentTiddler\");\n // get the title for the (existing/new) tiddler\n\tvar tr = $tw.utils.parseTextReference(this.detailsStateTitle);\n\tvar tidTitle = tr.title || currentTiddler;\n // is it an existing state tiddler?\n\tvar isStateTiddler = (tr.title === this.detailsStateTitle);\n\tvar hasStateTiddler = this.wiki.tiddlerExists(tr.title);\n\tvar currentStateTiddler = (tr.title === currentTiddler);\n\tif(isStateTiddler || hasStateTiddler || (currentStateTiddler && tr.field !== \"text\")) { \n\t\t// Set the state field (but never overwrite the current tiddler’s text field\n\t\tthis.wiki.setText(tidTitle,tr.field,tr.index,openState);\n\t} else {\n\t\tif(!hasStateTiddler && tidTitle !== currentTiddler) {\n\t\t\tthis.createTiddler(tidTitle);\n\t\t\tthis.wiki.setText(tidTitle,tr.field,tr.index,openState);\n\t\t} else {\n\t\t\tconsole.log (\"Something went wrong in updateState\");\n\t\t}\n\t}\n};\n\n/*\nCreate a tiddler with a title only\n*/\nDetailsWidget.prototype.createTiddler = function(tidTitle) {\n\tthis.wiki.addTiddler(new $tw.Tiddler(\n\t\tthis.wiki.getCreationFields(),\n\t\tthis.wiki.getModificationFields(),\n\t\t{\n\t\t\ttitle: tidTitle,\n\t\t\ttags: []\n\t\t}\n\t));\n};\n\n/*\nSet openState according to click\n*/\nDetailsWidget.prototype.handleToggleEvent = function(event) {\n\t// check if an open attribute is present\n\tvar newState = this.detailsDomNode.open ? \"\" : \"open\";\n\t// update only, if the node has a new state\n\tif(newState !== this.detailsState) {\n\t\tthis.updateState(newState);\n\t}\n};\n\n/*\nCompute the internal state of the widget\n*/\nDetailsWidget.prototype.execute = function() {\n\t// Get the parameters from the attributes \n\tvar tryTiddler = this.getAttribute(\"tiddler\");\n\tthis.myTiddler = this.wiki.getTiddler(tryTiddler);\n\tthis.summaryTitle = this.myTiddler ? tryTiddler : \"Tiddler not found\";\n\tthis.summaryField = this.getAttribute(\"field\",\"\");\n\tthis.detailsSummary = this.getAttribute(\"summary\") || this.getSummary();\n\tthis.detailsStateTitle = this.getAttribute(\"state\",\"\");\n\tthis.detailsState = this.getStateFromReference();\n\tthis.detailsOpenDefault = this.getAttribute(\"open\",\"\");\n\tthis.detailsOpen = this.getOpenState();\n\tthis.detailsClass = this.getAttribute(\"class\",\"\");\n\t// Construct the child widgets\n\tthis.makeChildWidgets();\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nDetailsWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.tiddler || changedAttributes.field || changedAttributes.summary || changedAttributes.state || changedAttributes.open || changedAttributes[\"class\"]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\tvar refreshed = false;\n\t\tvar testState = this.getStateFromReference();\n\t\tif(testState !== this.detailsState) {\n\t\t\t// state change\n\t\t\tthis.refreshSelf();\n\t\t\trefreshed = true;\n\t\t} \n\t\treturn this.refreshChildren(changedTiddlers) || refreshed;\n\t}\n};\n\nexports.details = DetailsWidget;\n\n})();",
"type": "application/javascript",
"title": "$:/plugins/telmiger/details/details.js",
"tags": "Plugins",
"module-type": "widget",
"modifier": "Thomas Elmiger",
"modified": "20180929212032187",
"creator": "Thomas Elmiger",
"created": "20170124173619910"
},
"$:/plugins/telmiger/details/icon": {
"created": "20170205205314072",
"text": "<svg class=\"tc-image-button telmiger-icon\" viewBox=\"0 0 128 128\" xmlns=\"http://www.w3.org/2000/svg\" fill-rule=\"evenodd\" viewBox=\"0 0 128 128\" role=\"img\" aria-labelledby=\"title\"><title id=\"title\">T</title><path class=\"circle\" d=\"M64 2C30 2 2 29.753 2 64c0 34.235 27.753 62 62 62s62-27.752 62-62C126 29.753 98.221 2 64 2z\"/><path class=\"t\" d=\"M100.41 63.254c-2.886 1.92-7.544 2.883-13.979 2.883h-8.008c-4.246 0-7.331.845-9.254 2.536-1.922 1.69-3.449 5.086-4.576 10.19 0 0-.181 1.481-.503 1.481s-.369-.877-.518-1.586a37.897 37.897 0 0 0-.721-2.754c-.631-2.137-1.262-3.753-1.894-4.847-.764-1.359-1.727-2.452-2.889-3.28-1.162-.83-2.49-1.326-3.985-1.492l-2.092-.248H41.73c-6.144 0-10.711-.962-13.7-2.884-4.976-3.159-7.649-9.129-8.02-17.91-.03-.706.003-1.351.132-2.171h.585c.399 3.975 3.679 7.048 6.086 9.219 2.408 2.172 6.269 3.258 11.581 3.258h9.313c5.347 0 9.257 1.226 11.731 3.68 2.231 2.213 3.701 5.68 4.406 10.4.076.511.03.736.178.736.149 0 .11-.256.17-.783.713-6.122 3.085-10.219 7.117-12.294 2.487-1.292 6.434-1.906 11.841-1.839l6.368.1c4.311.066 7.942-.788 10.893-2.56 2.953-1.773 6.447-5.079 6.844-9.917h.595c.183.478.16 1.576.127 2.333-.371 8.752-2.894 14.668-7.567 17.749z\"/></svg>\n<style>\n.telmiger-icon .circle { fill: #e2001a }\n.telmiger-icon .t { fill: #fff }\n</style>",
"title": "$:/plugins/telmiger/details/icon",
"tags": "",
"modified": "20171219183752113"
},
"$:/plugins/telmiger/details/license": {
"text": "!! Plugin license\n!!!The MIT License (MIT)\n\n```\nCopyright © 2017/2018 Thomas Elmiger – thomas-elmiger.ch\n\nPermission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n```",
"title": "$:/plugins/telmiger/details/license",
"tags": "",
"modified": "20170205214435064",
"created": "20170205213335455"
},
"$:/plugins/telmiger/details/readme": {
"created": "20170205212323032",
"text": "! ~DetailsWidget\n\nA plugin for [[TiddlyWiki|http://tiddlywiki.com]] 5 containing a script and some styles to create an HTML 5 `<details>` section including a `<summary>`. Here’s an example:\n\n<$details summary=\"W3C definition\">\n\n<<<\nThe [[details|http://w3c.github.io/html/interactive-elements.html#elementdef-details]] element represents a disclosure widget from which the user can obtain additional information or controls.\n<<< W3C\n\n</$details>\n\nDocumentation can be found at http://tid.li/tw5/plugins.html#DetailsWidget\n",
"title": "$:/plugins/telmiger/details/readme",
"tags": "",
"modified": "20171219183752113"
},
"$:/plugins/telmiger/details/colours.css": {
"text": "/* details and summary colours */\n\ndetails {\n background-color: <<colour tiddler-info-tab-background>>;\n color: <<colour foreground>>;\n}\n\ndetails summary {\n background-color: <<colour dropdown-tab-background>>;\n}\n\ndetails.notification summary {\n background-color: <<colour notification-background>>;\n /* TW leaves color undefined/uses foreground */\n}\n\ndetails.warning summary {\n background-color: #ffbbaf;\n color: #000;\n}\n\ndetails.success summary {\n background-color: #88edc5;\n color: #000;\n}\n",
"title": "$:/plugins/telmiger/details/colours.css",
"tags": "$:/tags/Stylesheet",
"modifier": "Thomas Elmiger",
"modified": "20180926204140772",
"creator": "Thomas Elmiger",
"created": "20180925155320737"
},
"$:/plugins/telmiger/details/accordion": {
"text": "\\define accordion(filter:\"_no_\",open:\"no\",class:\"\")\n<$vars accordion-filter=\"\"\"$filter$\"\"\" open=\"\"\"$open$\"\"\" class=\"\"\"$class$\"\"\">\n<$list filter=<<accordion-filter>>>\n<$details summary=<<currentTiddler>> open=<<open>> class=<<class>>>\n\n<$transclude tiddler=<<currentTiddler>>/>\n\n</$details>\n</$list>\n</$vars>\n\\end\n\n<!-- !!! Accordion Macro for Details\n\nList tiddlers and open them in a details-summary structure\n\n!!!! Attributes\n* filter: filter to select tiddlers\n* open: set to \"open\" to display details on load\n* class: set a class for the details tag\n\n-->",
"title": "$:/plugins/telmiger/details/accordion",
"tags": "$:/tags/Macro",
"modifier": "Thomas Elmiger",
"modified": "20180929065014252",
"creator": "Thomas Elmiger",
"created": "20180928194557274"
}
}
}
\define teBtnSave(class:"te-btn-big")
<$wikify name="myclass" text="te-btn-save $class$ <<tv-config-toolbar-class>>">
<span>
<$button message="tm-save-wiki" param={{$:/config/SaveWikiButton/Template}} tooltip={{$:/language/Buttons/SaveWiki/Hint}} aria-label={{$:/language/Buttons/SaveWiki/Caption}} class=<<myclass>>>
<span class="tc-dirty-indicator">
{{$:/core/images/save-button}}
</span>
</$button>
</span>
</$wikify>
\end
\define teBtnDelete(class:"")
<$vars btnclass="te-btn-action te-btn-delete $class$">
<$button message="tm-delete-tiddler" tooltip={{$:/language/Buttons/Delete/Hint}} aria-label={{$:/language/Buttons/Delete/Caption}} class=<<btnclass>>>
{{$:/core/images/delete-button}}
</$button>
</$vars>
\end
\define teBtnHint(btntext,message,tooltip,tip,class:"")
<$set name="btnclass" value="te-hint $class$">
<$button class=<<btnclass>> tooltip="""$tooltip$""" message="$message$">
$btntext$
<span class="te-tip">$tip$</span>
</$button>
</$set>
\end
\define teBtnTagListops(btntext,add-remove,tooltip,tip:"_false_",class:"")
<$vars tip="""$tip$""" btnclass="te-btn-action te-tag-listops $class$">
<$set name="mytip" filter="[<tip>removeprefix[_false_]]" emptyValue="""<span class="te-tip">$tip$</span>""">
<$button class=<<btnclass>> tooltip="""$tooltip$""">
<<teTimestampPause>>
<$action-listops $tags="$add-remove$" />
<<teTimestampResume>>
$btntext$
<<mytip>>
</$button>
</$set>
</$vars>
\end
\define teBtnEdit(sendmessage:"tm-edit-tiddler",class:"")
<$wikify name="tt" text=<<telang Edit>>>
<$button tooltip=<<tt>> class="te-btn-action te-edit $class$">
<$action-sendmessage $message="$sendmessage$" $param=<<currentTiddler>> />
{{$:/core/images/edit-button}}
</$button>
</$wikify>
\end
\define teBtnEditShowModified(sendmessage:"tm-edit-tiddler",class:"")
<$wikify name="tt" text=<<telang Edit>>>
<$button tooltip=<<tt>> class="te-btn-action te-edit $class$">
<$action-sendmessage $message="$sendmessage$" $param=<<currentTiddler>> />
{{$:/core/images/edit-button}}<span class="te-tip"><$view tiddler=<<currentTiddler>> field="modified" format="date" template="YYYY-0MM-0DD 0hh:0mm"/></span>
</$button>
</$wikify>
\end
\define tePrioBtnContent() <span class="te-prionr">$(priority)$</span>$(btntext)$
\define teBtnPrio(btntext,priority,prioritylist:"$:/plugins/telmiger/lib/telements/buttons",tooltip,class:"")
<$vars btntext="""$btntext$""" priority="""$priority$""">
<$set name="nextprio" filter="""[list[$prioritylist$]nth[$priority$]]""">
<$wikify name="next" text="$tooltip$ <<nextprio>>">
<$button tooltip=<<next>> class="te-btn-action te-prio prio$priority$ $class$">
<$action-listops $field="priority" $filter=<<nextprio>>/>
<<tePrioBtnContent>>
</$button>
</$wikify>
</$set>
</$vars>
\end
\define teBtnPrioPopup(tiddler,btntext,priority,prioritylist:"$:/plugins/telmiger/lib/telements/buttons",tooltip:"change priority",class:"")
<$vars btntext="""$btntext$""" priority="""$priority$""">
<$set name="qualstate" value=<<qualify """$:/state/reveal_priopop_$tiddler$_""">> >
<$reveal type="nomatch" state=<<qualstate>> text="show" class="te-btn-reveal">
<$button tooltip="""$tooltip$""" set=<<qualstate>> setTo="show" class="te-btn-action te-prio prio$priority$ $class$">
<<tePrioBtnContent>>
</$button>
</$reveal>
<$reveal type="match" state=<<qualstate>> text="show" class="te-btn-reveal">
<$button tooltip="close popup" class="te-btn-action te-prio prio$priority$ $class$">
<$action-deletetiddler $tiddler=<<qualstate>>/>
<<tePrioBtnContent>>
</$button>
</$reveal>
<$reveal type="match" state=<<qualstate>> text="show">
<$wikify name="tt" text="set prio">
<$macrocall $name="tePrioList" tiddler="""$tiddler$""" icon="{{$:/core/images/star-filled}}" priorityfield="priority" prioritylist="""$prioritylist$""" tooltip=<<tt>> class="" state=<<qualstate>>/>
</$wikify>
</$reveal>
</$set>
</$vars>
\end
\define tePrioList(tiddler,prioritylist:"_false_",priorityfield:"_false_",icon:"{{$:/core/images/star-filled}}",state)
<$vars priotid="""$prioritylist$""" tid="""$tiddler$""">
<$set name="prioOld" filter="[<currentTiddler>get[$priorityfield$]]">
<div class="te-prio-popup">
<ul class="te-prio-list">
<$list filter="[list<priotid>sort[]] -[<prioOld>]" variable="prio" emptyValue="error: no priorities in list field of $tiddler$">
<li>
<$macrocall $name="teBtnPrioSet" tiddler=<<tid>> priority=<<prio>> priorityfield="""$priorityfield$""" tooltip="set as prio" icon="""$icon$""" class="" state="""$state$"""/>
</li>
</$list>
</ul>
</div>
</$set>
</$vars>
\end
\define teBtnPrioSet(tiddler,priority,priorityfield,tooltip,icon,class:"",state)
<$vars prio="""$priority$""" qualstate="""$state$""">
<$button tooltip="""$tooltip$""" class="te-btn-action te-prio prio$priority$ $class$">
<<teTimestampPause>>
<$action-listops $tiddler="""$tiddler$""" $field=$priorityfield$ $filter=<<prio>>/>
<<teTimestampResume>>
<$action-deletetiddler $tiddler=<<qualstate>>/>
<span class="te-prionr"><<prio>></span>$icon$
</$button>
</$vars>
\end
\define teBtnClone(tiddler,class:"")
<$button message="tm-new-tiddler" param="""$tiddler$""" tooltip={{$:/language/Buttons/Clone/Hint}} aria-label={{$:/language/Buttons/Clone/Caption}} class="te-btn-action te-clone $class$">
{{$:/core/images/clone-button}}
</$button>
\end
\define teBtnIcons(label,icon,hovericon)
<span class="te-btn-label">"""$label$"""</span>
<span class="te-btn-icon"><$transclude tiddler="""$icon$"""/></span>
<span class="te-btn-hovericon"><$transclude tiddler="""$hovericon$"""/></span>
\end
\define teTimestampPause()
<$action-setfield $tiddler="$:/temp/te/TimestampBefore" $value={{$:/config/TimestampDisable}}/>
<$action-setfield $tiddler="$:/config/TimestampDisable" $value="yes"/>
\end
\define teTimestampResume()
<$action-setfield $tiddler="$:/config/TimestampDisable" $value={{$:/temp/te/TimestampBefore}}/>
\end
<!-- !! Macros to produce nice buttons
Optimize: Rewire field "priority" to a variable $saveto$?
* teBtnSave
* teBtnDelete
** delete a given tiddler – show a confirmation request first
* teBtnHint(btntext,message,tooltip,tip,class:"")
** add a message
* teBtnTagListops(btntext,add-remove,tooltip,tip,class:"")
** add-remove: add and remove tags in one statement "addthis -removethat"
** does not update the modification date as of TW 5.1.14
* teBtnEdit(sendmessage:"tm-edit-tiddler",class:"")
** tiddler is currentTiddler
* teBtnEditShowModified(sendmessage:"tm-edit-tiddler",class:"") – used in $:/plugins/telmiger/listreveal/readme
** shows modified timestamp on hover
** tiddler is currentTiddler
* teBtnPrio(btntext,priority,prioritylist:"$:/plugins/telmiger/lib/telements/buttons",tooltip,class:"")
** let the user cycle through a list of choices (priorities) from the //list// field of a tiddler
* teBtnPrioPopup(tiddler,btntext,priority,prioritylist:"$:/plugins/telmiger/lib/telements/buttons",tooltip:"change priority",class:"")
** let the user select a priority from a list of choices saved in the //list// field of a tiddler
* tePrioList – a helper macro for teBtnPrioPopup
* teBtnPrioSet – a helper macro for teBtnPrioPopup
* teBtnClone(tiddler,class:"") – a button to clone a tiddler from the list
* teBtnIcons(label,icon,hovericon) – create a set of spans for buttons with icons
* teTimestampPause() and teTimestampResume()
** put these before and after e.g. tag manipulations to stop/restart timestamp updates
-->
{
"tiddlers": {
"$:/plugins/telmiger/lib/language": {
"text": "$:/plugins/telmiger/lib/languages/en-GB",
"todo-done": "20160820234641 20160821004547",
"todo-deadline": "",
"title": "$:/plugins/telmiger/lib/language",
"tags": "ToDoDone ToDoComponents",
"priority": "2",
"modifier": "Thomas Elmiger",
"modified": "20180425210135022",
"creator": "Thomas Elmiger",
"created": "20160820133735127"
},
"$:/plugins/telmiger/lib/languages/en-GB": {
"created": "20160820190056478",
"creator": "Thomas Elmiger",
"text": "ID:English\n<!-- date formats: date formats start here -->\ndate-created-tmpl: {{$:/language/Tiddler/DateFormat}}\ndate-created-tmpl-info: DDth MMM YYYY at hh12:0mmpm\ndate-deadline-tmpl: YYYY-0MM-0DD\n<!-- titles: titles start here -->\ntitle-Do: Do\ntitle-Waiting: Waiting\ntitle-Done: Done\n<!-- motivation: motivating slogans start here -->\nMotivation-Don’t-do-it: Don’t have to do it? – Say it’s done!\nMotivation-single-task: Do the right ''one'' thing. – Then check & save.\n<!-- strings: strigs start here -->\nAdd-tag: Add tag\nAdd-tags-from-the-list: Add tags from the list\nall: all\nall-projects: all projects\narchive: archive\nAre-you-sure?: Are you sure?\nChange-deadline: Change deadline\nchange-priority: Change priority\nchange-priority-to: set priority to\nClick-to-edit-title: Click the title to edit!\nclose: Close\nClose: Close\ndays-back: days back\nDetails: Show details\nDo-it-again: Do it again\nDo-now: Do now\nDone: Done\nEdit: Edit\nHide-list: Hide list\nlate: late\nManage-tags: Manage tags\nMove-down: Move down\nMove-up: Move up\nNew-ToDo-Item: New ToDo Item\nNext week: Next week\nno.: no.\nOpen-all: Open all\nNothing-to-do-?: Nothing to do? Create a task using this button\nPick-a-task-: Pick a task from the list below using this button\nPrint-window-hint: Open in new window to print\nProject: Project\nRecycle: Recycle\nRelax-Nothing-to-do: Relax. Nothing to do.\nRemove-deadline: Remove deadline\nRemove-tags?: Remove tags?\nReset: Reset\nsearch: search …\nSend-it-down: Send it down\nSet-deadline: Set deadline\nShow-list: Show list\nSort-by-deadline: Sort by deadline\nSort-by-modification: Sort by last modification\nSort-by-priority: Sort all by priority\nSort-by-title: Sort all by title\nsorted-by-deadline: sorted by deadline\nsorted-by-modification: sorted by last modification\nsorted-by-priority: sorted by priority\nsorted-by-title: sorted by title\nSwitch-to-edit-mode: Switch to edit mode\nSwitch-to-safe-mode: Switch to save mode\nTake-it-up: Take it up!\nThis-is-done: This is done\nThis-week: This week\ntoday: today\nToday: Today\nToDo: ToDo\nToDo-template-title: ToDo Item\nToDo-template-text: Motivation: Description * Tests/Acceptance criteria\nTomorrow: Tomorrow\nUuups: Uuups!\n<!-- comments: comments -->\n<!-- translation requires: $:/plugins/telmiger/lib/telang -->\n<!-- use translated term: <<telang term>> -->",
"type": "application/x-tiddler-dictionary",
"todo-done": "20160821121501",
"title": "$:/plugins/telmiger/lib/languages/en-GB",
"tags": "Translation ToDoComponents",
"modifier": "Thomas Elmiger",
"modified": "20180316065039068"
},
"$:/plugins/telmiger/lib/telang": {
"text": "\\define telang(term)\n<$transclude tiddler={{$:/plugins/telmiger/lib/language}} index=\"$term$\"><$transclude tiddler=\"$:/plugins/telmiger/lib/languages/en-GB\" index=\"$term$\"/></$transclude>\n\\end\n",
"created": "20160917153627850",
"creator": "Thomas Elmiger",
"modified": "20160917160018287",
"modifier": "Thomas Elmiger",
"priority": "2",
"tags": "ToDoDone ToDoComponents $:/tags/Macro",
"title": "$:/plugins/telmiger/lib/telang",
"todo-deadline": "",
"todo-done": "20160820234641 20160821004547"
},
"$:/plugins/telmiger/lib/telements/buttons": {
"created": "20160816192735231",
"creator": "Thomas Elmiger",
"text": "\\define teBtnSave(class:\"te-btn-big\")\n<$wikify name=\"myclass\" text=\"te-btn-save $class$ <<tv-config-toolbar-class>>\">\n<span>\n<$button message=\"tm-save-wiki\" param={{$:/config/SaveWikiButton/Template}} tooltip={{$:/language/Buttons/SaveWiki/Hint}} aria-label={{$:/language/Buttons/SaveWiki/Caption}} class=<<myclass>>>\n<span class=\"tc-dirty-indicator\">\n{{$:/core/images/save-button}}\n</span>\n</$button>\n</span>\n</$wikify>\n\\end\n\n\\define teBtnDelete(class:\"\")\n<$vars btnclass=\"te-btn-action te-btn-delete $class$\">\n<$button message=\"tm-delete-tiddler\" tooltip={{$:/language/Buttons/Delete/Hint}} aria-label={{$:/language/Buttons/Delete/Caption}} class=<<btnclass>>>\n{{$:/core/images/delete-button}}\n</$button>\n</$vars>\n\\end\n\n\\define teBtnHint(btntext,message,tooltip,tip,class:\"\")\n<$set name=\"btnclass\" value=\"te-hint $class$\">\n<$button class=<<btnclass>> tooltip=\"\"\"$tooltip$\"\"\" message=\"$message$\">\n$btntext$\n<span class=\"te-tip\">$tip$</span>\n</$button>\n</$set>\n\\end\n\n\\define teBtnTagListops(btntext,add-remove,tooltip,tip:\"_false_\",class:\"\")\n<$vars tip=\"\"\"$tip$\"\"\" btnclass=\"te-btn-action te-tag-listops $class$\">\n<$set name=\"mytip\" filter=\"[<tip>removeprefix[_false_]]\" emptyValue=\"\"\"<span class=\"te-tip\">$tip$</span>\"\"\">\n<$button class=<<btnclass>> tooltip=\"\"\"$tooltip$\"\"\">\n<<teTimestampPause>>\n<$action-listops $tags=\"$add-remove$\" />\n<<teTimestampResume>>\n$btntext$\n<<mytip>>\n</$button>\n</$set>\n</$vars>\n\\end\n\n\\define teBtnEdit(sendmessage:\"tm-edit-tiddler\",class:\"\")\n<$wikify name=\"tt\" text=<<telang Edit>>>\n <$button tooltip=<<tt>> class=\"te-btn-action te-edit $class$\">\n<$action-sendmessage $message=\"$sendmessage$\" $param=<<currentTiddler>> />\n{{$:/core/images/edit-button}}\n</$button>\n</$wikify>\n\\end\n\n\\define teBtnEditShowModified(sendmessage:\"tm-edit-tiddler\",class:\"\")\n<$wikify name=\"tt\" text=<<telang Edit>>>\n <$button tooltip=<<tt>> class=\"te-btn-action te-edit $class$\">\n<$action-sendmessage $message=\"$sendmessage$\" $param=<<currentTiddler>> />\n{{$:/core/images/edit-button}}<span class=\"te-tip\"><$view tiddler=<<currentTiddler>> field=\"modified\" format=\"date\" template=\"YYYY-0MM-0DD 0hh:0mm\"/></span>\n</$button>\n</$wikify>\n\\end\n\n\\define tePrioBtnContent() <span class=\"te-prionr\">$(priority)$</span>$(btntext)$\n\n\\define teBtnPrio(btntext,priority,prioritylist:\"$:/plugins/telmiger/lib/telements/buttons\",tooltip,class:\"\")\n<$vars btntext=\"\"\"$btntext$\"\"\" priority=\"\"\"$priority$\"\"\">\n<$set name=\"nextprio\" filter=\"\"\"[list[$prioritylist$]nth[$priority$]]\"\"\">\n<$wikify name=\"next\" text=\"$tooltip$ <<nextprio>>\">\n<$button tooltip=<<next>> class=\"te-btn-action te-prio prio$priority$ $class$\">\n<$action-listops $field=\"priority\" $filter=<<nextprio>>/>\n<<tePrioBtnContent>>\n</$button>\n</$wikify>\n</$set>\n</$vars>\n\\end\n\n\\define teBtnPrioPopup(tiddler,btntext,priority,prioritylist:\"$:/plugins/telmiger/lib/telements/buttons\",tooltip:\"change priority\",class:\"\")\n<$vars btntext=\"\"\"$btntext$\"\"\" priority=\"\"\"$priority$\"\"\">\n<$set name=\"qualstate\" value=<<qualify \"\"\"$:/state/reveal_priopop_$tiddler$_\"\"\">> >\n<$reveal type=\"nomatch\" state=<<qualstate>> text=\"show\" class=\"te-btn-reveal\">\n<$button tooltip=\"\"\"$tooltip$\"\"\" set=<<qualstate>> setTo=\"show\" class=\"te-btn-action te-prio prio$priority$ $class$\">\n<<tePrioBtnContent>>\n</$button>\n</$reveal>\n<$reveal type=\"match\" state=<<qualstate>> text=\"show\" class=\"te-btn-reveal\">\n<$button tooltip=\"close popup\" class=\"te-btn-action te-prio prio$priority$ $class$\">\n<$action-deletetiddler $tiddler=<<qualstate>>/>\n<<tePrioBtnContent>>\n</$button>\n</$reveal>\n<$reveal type=\"match\" state=<<qualstate>> text=\"show\">\n<$wikify name=\"tt\" text=\"set prio\">\n <$macrocall $name=\"tePrioList\" tiddler=\"\"\"$tiddler$\"\"\" icon=\"{{$:/core/images/star-filled}}\" priorityfield=\"priority\" prioritylist=\"\"\"$prioritylist$\"\"\" tooltip=<<tt>> class=\"\" state=<<qualstate>>/>\n</$wikify>\n</$reveal>\n</$set>\n</$vars>\n\\end\n\n\\define tePrioList(tiddler,prioritylist:\"_false_\",priorityfield:\"_false_\",icon:\"{{$:/core/images/star-filled}}\",state)\n<$vars priotid=\"\"\"$prioritylist$\"\"\" tid=\"\"\"$tiddler$\"\"\">\n<$set name=\"prioOld\" filter=\"[<currentTiddler>get[$priorityfield$]]\">\n<div class=\"te-prio-popup\">\n<ul class=\"te-prio-list\">\n<$list filter=\"[list<priotid>sort[]] -[<prioOld>]\" variable=\"prio\" emptyValue=\"error: no priorities in list field of $tiddler$\">\n<li>\n <$macrocall $name=\"teBtnPrioSet\" tiddler=<<tid>> priority=<<prio>> priorityfield=\"\"\"$priorityfield$\"\"\" tooltip=\"set as prio\" icon=\"\"\"$icon$\"\"\" class=\"\" state=\"\"\"$state$\"\"\"/>\n</li>\n</$list>\n</ul>\n</div>\n</$set>\n</$vars>\n\\end\n\n\\define teBtnPrioSet(tiddler,priority,priorityfield,tooltip,icon,class:\"\",state)\n<$vars prio=\"\"\"$priority$\"\"\" qualstate=\"\"\"$state$\"\"\">\n<$button tooltip=\"\"\"$tooltip$\"\"\" class=\"te-btn-action te-prio prio$priority$ $class$\">\n<<teTimestampPause>>\n<$action-listops $tiddler=\"\"\"$tiddler$\"\"\" $field=$priorityfield$ $filter=<<prio>>/>\n<<teTimestampResume>>\n<$action-deletetiddler $tiddler=<<qualstate>>/>\n<span class=\"te-prionr\"><<prio>></span>$icon$\n</$button>\n</$vars>\n\\end\n\n\\define teBtnClone(tiddler,class:\"\")\n<$button message=\"tm-new-tiddler\" param=\"\"\"$tiddler$\"\"\" tooltip={{$:/language/Buttons/Clone/Hint}} aria-label={{$:/language/Buttons/Clone/Caption}} class=\"te-btn-action te-clone $class$\">\n{{$:/core/images/clone-button}}\n</$button>\n\\end\n\n\\define teBtnIcons(label,icon,hovericon)\n<span class=\"te-btn-label\">\"\"\"$label$\"\"\"</span>\n<span class=\"te-btn-icon\"><$transclude tiddler=\"\"\"$icon$\"\"\"/></span>\n<span class=\"te-btn-hovericon\"><$transclude tiddler=\"\"\"$hovericon$\"\"\"/></span>\n\\end\n\n\\define teTimestampPause()\n<$action-setfield $tiddler=\"$:/temp/te/TimestampBefore\" $value={{$:/config/TimestampDisable}}/>\n<$action-setfield $tiddler=\"$:/config/TimestampDisable\" $value=\"yes\"/>\n\\end\n\n\\define teTimestampResume()\n<$action-setfield $tiddler=\"$:/config/TimestampDisable\" $value={{$:/temp/te/TimestampBefore}}/>\n\\end\n\n\n<!-- !! Macros to produce nice buttons\n\nOptimize: Rewire field \"priority\" to a variable $saveto$?\n\n* teBtnSave\n* teBtnDelete\n** delete a given tiddler – show a confirmation request first\n* teBtnHint(btntext,message,tooltip,tip,class:\"\")\n** add a message\n* teBtnTagListops(btntext,add-remove,tooltip,tip,class:\"\")\n** add-remove: add and remove tags in one statement \"addthis -removethat\"\n** does not update the modification date as of TW 5.1.14\n* teBtnEdit(sendmessage:\"tm-edit-tiddler\",class:\"\") \n** tiddler is currentTiddler\n* teBtnEditShowModified(sendmessage:\"tm-edit-tiddler\",class:\"\") – used in $:/plugins/telmiger/listreveal/readme \n** shows modified timestamp on hover\n** tiddler is currentTiddler\n* teBtnPrio(btntext,priority,prioritylist:\"$:/plugins/telmiger/lib/telements/buttons\",tooltip,class:\"\")\n** let the user cycle through a list of choices (priorities) from the //list// field of a tiddler \n* teBtnPrioPopup(tiddler,btntext,priority,prioritylist:\"$:/plugins/telmiger/lib/telements/buttons\",tooltip:\"change priority\",class:\"\")\n** let the user select a priority from a list of choices saved in the //list// field of a tiddler \n* tePrioList – a helper macro for teBtnPrioPopup\n* teBtnPrioSet – a helper macro for teBtnPrioPopup\n* teBtnClone(tiddler,class:\"\") – a button to clone a tiddler from the list\n* teBtnIcons(label,icon,hovericon) – create a set of spans for buttons with icons\n* teTimestampPause() and teTimestampResume()\n** put these before and after e.g. tag manipulations to stop/restart timestamp updates\n-->\n",
"title": "$:/plugins/telmiger/lib/telements/buttons",
"tags": "ToDoComponents $:/tags/Macro MyMacros Listreveal",
"prio": "",
"modifier": "Thomas Elmiger",
"modified": "20181014055743234",
"list": "3 1 2"
},
"01 Listreveal List Setup": {
"created": "20170222232934553",
"creator": "Thomas Elmiger",
"text": "Explanations for the code of $:/plugins/telmiger/listreveal/readme – you can clone the linked tiddler and adapt it step by step to create your own listreveal project. The filter statement is a good point to start:\n\n```\n<$set name=\"listfilter\" \n value=\"\"\"[tag[Listreveal]!is[system]sort[title]]\"\"\">\n<ul class=\"te-list\">\n<$list filter=<<listfilter>>>\n```\nAlways use a variable called //listfilter// to create your list. The list-based tag manager (see [[03 Context Tagging]]) is depending on this convention.\n\nIt is recommended to use the CSS classes you see in this example – add your own to change the looks.\n\n```\n<$set name=\"tidTitle\" value={{!!title}}>\n <li class=\"todo-item te-flex-item\">\n <span class=\"te-flex-item te-flex-half-full\">\n <span class=\"te-flex-item te-flex-content te-flex-left\">\n <$link to={{!!title}}><$view field=\"title\"/></$link>\n </span>\n </span>\n```\nThe styling relies on [[CSS3 flexbox|https://scotch.io/tutorials/a-visual-guide-to-css3-flexbox-properties]]. These spans help to make your list as mobile friendly as possible.\n\n```\n <span class=\"te-flex-item te-flex-half-full\">\n <span class=\"te-flex-item te-flex-content te-flex-right\">\n <<teBtnEditShowModified>>\n```\nThis macro produces an edit button. It shows the tiddler’s modified date when the mouse hovers over it.\n\n```\n<$wikify name=\"cl\" text=<<telang close>> >\n<$wikify name=\"tt\" text=<<telang Details>> >\n <$macrocall $name=\"listrevealButton\" title=<<tidTitle>> tooltip=<<tt>> close=<<cl>>/>\n</$wikify>\n</$wikify>\n```\nThis macrocall produces the button on the right side that opens and closes the tiddlers.\n\nThe variables //cl// and //tt// get predefined translations from the language tiddlers that are part of this plugin. You can replace the tooltip for opening (attribute //tooltip//) and closing (attribute //close//) with your own texts.\n\n```\n </span>\n </span>\n<$wikify name=\"tpl\" text=<<telang date-created-tmpl>> >\n <$macrocall $name=\"listrevealContent\" title=<<tidTitle>> datetime=<<tpl>>/>\n</$wikify>\n```\nThis macrocall produces the text content and some details of your tiddler.\n\nAgain the variable //tpl// gets a predefined translation from the integrated language tiddlers. It is used as a [[date format template|http://tiddlywiki.com/#DateFormat]] when the created and modified timestamps of the tiddler are displayed. This attribute is optional.\n\n//tidTitle// is the variable for the title of your list elements (your tiddlers). It is set at the beginning (see second snippet).\n\n```\n </li>\n</$set>\n</$list>\n</ul>\n</$set>\n```\nThe whole list is presented as an unordered HTML list `<ul>` with tiddlers as list items `<li>`.",
"title": "01 Listreveal List Setup",
"tags": "Listreveal",
"modified": "20170224201650800",
"modifier": "Thomas Elmiger"
},
"02 Edit Button": {
"created": "20170222233632994",
"creator": "Thomas Elmiger",
"text": "Optionally you can add a lock/unlock button to switch your list into edit mode (all listreveal lists in your wiki to be precise). This presents the tiddler content in an editor field where you can change it using wikitext formatting. \n\n```\nUse this button to enable editing: <<listrevealBtnEdit>>\n```\nAdd your own parameter `class:\"your-class\"` for styling and positioning via CSS. The icon has a so called dirty indicator implemented: it turns red if you have unsaved changes.",
"title": "02 Edit Button",
"tags": "Listreveal",
"modified": "20170224192922331",
"modifier": "Thomas Elmiger"
},
"03 Context Tagging": {
"created": "20170224195102124",
"creator": "Thomas Elmiger",
"text": "When you look inside a tiddler in the list using the ellipsis (…) button on the right, you see the tiddler’s tags, text and timestamps. \n\n{{$:/core/images/tag-button}}\n\nThe tags can be changed using the tag label icon. A unique feature called context tagging or list-based tagging appears in a popup. From there you are able to add suggested tags based on the other tiddlers in your list or remove single tags from the tiddler. ",
"title": "03 Context Tagging",
"tags": "Listreveal",
"modified": "20170224195644691",
"modifier": "Thomas Elmiger"
},
"04 Checklists": {
"created": "20170224200058192",
"creator": "Thomas Elmiger",
"text": "This plugin comes with CSS to support checklists generated via a plugin by Tony Grosinger – indentation and the display of user interface elements to add and delete items should be optimized for use inside of listreveal lists.\n\n[ ] Install the plugin from https://grosinger.net/tw5-checklist/\n[ ] Make your first checklist\n[x] Read these hints on checklists",
"todo-done": "20160917214708",
"todo-deadline": "20160912220000000",
"title": "04 Checklists",
"tags": "Listreveal Usability Plugins",
"priority": "2",
"modifier": "Thomas Elmiger",
"modified": "20170224201034767"
},
"05 Translations": {
"text": "The following language tiddlers are shipped with this plugin: \n\n<ul>\n<$list filter=\"\"\"[all[tiddlers+shadows]prefix[$:/plugins/telmiger/lib/languages/]sort[]]\"\"\">\n<li>\n{{##ID}}: <$link to={{!!title}}><$view field=\"title\"/></$link>\n</li>\n</$list>\n</ul>\n\nSet your language in $:/plugins/telmiger/lib/language (I hope I will find a way to use the language from the TW settings in the future).\n\nTo implement a new language you could clone and adapt one of them. They are used for other plugins too, this is why they contain way more text than needed for listreveal.\n",
"title": "05 Translations",
"tags": "Listreveal Translation",
"modifier": "Thomas Elmiger",
"modified": "20170714214826478",
"creator": "Thomas Elmiger",
"created": "20170224202239839"
},
"$:/plugins/telmiger/lib/languages/de-DE": {
"created": "20160823202222125",
"creator": "Thomas Elmiger",
"text": "ID:Deutsch (Deutschland)\n<!-- date formats: Datums-Formatierung startet hier -->\ndate-created-tmpl: {{$:/language/Tiddler/DateFormat}}\ndate-created-tmpl-info: DD. MMM YYYY, 0hh:0mm Uhr\ndate-deadline-tmpl: 0DD.0MM.YYYY\n<!-- titles: Titel starten hier -->\ntitle-Do: Jetzt\ntitle-Waiting: Später\ntitle-Done: Erledigt\n<!-- motivation: Motivierende slogans starten hier -->\nMotivation-Don’t-do-it: Don’t have to do it? – Say it’s done!\nMotivation-single-task: Do the right ''one'' thing. – Then check & save.\n<!-- strings: Text-Schnippsel starten hier -->\nAdd-tag: Tag hinzufügen\nAdd-tags-from-the-list: Tags aus der Liste hinzufügen\nall: alle\nall-projects: alle Projekte\narchive: archivieren\nAre-you-sure?: Bist du sicher?\nChange-deadline: Fälligkeit ändern\nchange-priority: Priorität ändern\nchange-priority-to: Priorität ändern auf\nClick-to-edit-title: Auf Titel klicken zum Bearbeiten!\nclose: Schließen\nClose: Schließe\ndays-back: Tage\nDetails: Details\nDo-it-again: Mach’s nochmal\nDo-now: Jetzt erledigen\nDone: Erledigt\nEdit: bearbeiten\nHide-list: Liste ausblenden\nlate: später\nManage-tags: Tag-Manager\nMove-down: Nach unten\nMove-up: Nach oben\nNew-ToDo-Item: Neue Aufgabe\nno.: Anz.\nOpen-all: Alle öffnen\nNothing-to-do-?: Nichts zu tun? Erstelle eine Aufgabe mit diesem Knopf\nPick-a-task-: Wähle eine Aufgabe aus der Liste unten mit diesem Knopf\nPrint-window-hint: In neuem Fenster öffnen zum Drucken\nProject: Projekt:\nRecycle: Nochmals verwenden\nRelax-Nothing-to-do: Schön. Es gibt nichts zu tun.\nRemove-deadline: Fälligkeit löschen\nRemove-tags?: Tags entfernen?\nReset: Zurücksetzen\nsearch: Suche\nSend-it-down: doch nicht jetzt\nSet-deadline: Termin festlegen\nShow-list: Liste anzeigen\nSort-by-deadline: Nach Termin sortieren\nSort-by-modification: Nach letzter Änderung sortieren\nSort-by-priority: Alle nach Priorität sortieren\nSort-by-title: Alle nach Titel sortieren\nsorted-by-deadline: sortiert nach Enddatum\nsorted-by-modification: sortiert nach letzter Änderung\nsorted-by-priority: sortiert nach Priorität\nsorted-by-title: sortiert nach Titel\nSwitch-to-edit-mode: Bearbeiten ermöglichen\nSwitch-to-safe-mode: Bearbeiten ausschalten\nTake-it-up: Rauf damit!\nThis-is-done: Das ist erledigt\nThis-week: Diese Woche\ntoday: heute\nToday: Heute\nToDo: ToDo\nToDo-template-title: Neue Aufgabe\nToDo-template-text: Motivation: Beschreibung * Tests/Abnahmekriterien\nTomorrow: Morgen\nUuups: Hoppla!\n<!-- comments: Kommentare -->\n<!-- translation requires: $:/plugins/telmiger/lib/telang -->\n<!-- use translated term: <<telang term>> -->",
"type": "application/x-tiddler-dictionary",
"todo-done": "20160821121525",
"title": "$:/plugins/telmiger/lib/languages/de-DE",
"tags": "Translation ToDoComponents",
"modifier": "Thomas Elmiger",
"modified": "20180316064856476"
},
"$:/plugins/telmiger/lib/languages/de-CH": {
"created": "20160821100821036",
"creator": "Thomas Elmiger",
"text": "ID:Deutsch (Schweiz)\n<!-- date formats: Datums-Formatierung startet hier -->\ndate-created-tmpl: {{$:/language/Tiddler/DateFormat}}\ndate-created-tmpl-info: DD. MMM YYYY, 0hh:0mm Uhr\ndate-deadline-tmpl: 0DD.0MM.YYYY\n<!-- titles: Titel starten hier -->\ntitle-Do: Jetzt\ntitle-Waiting: Später\ntitle-Done: Erledigt\n<!-- motivation: Motivationstexte starten hier -->\nMotivation-Don’t-do-it: Don’t have to do it? – Say it’s done!\nMotivation-single-task: Do the right ''one'' thing. – Then check & save.\n<!-- strings: Text-Schnippsel starten hier -->\nAdd-tag: Tag hinzufügen\nAdd-tags-from-the-list: Tags aus der Liste hinzufügen\nall-projects: alle Projekte\narchive: archivieren\nAre-you-sure?: Bist du sicher?\nChange-deadline: Fälligkeit ändern\nchange-priority: Priorität ändern\nchange-priority-to: Priorität ändern auf\nClick-to-edit-title: Auf Titel klicken zum Bearbeiten!\nclose: Schliessen\nClose: Schliesse\ndays-back: Tage zurück\nDetails: Details\nDo-it-again: Mach’s nochmal\nDo-now: Jetzt erledigen\nDone: Erledigt\nEdit: bearbeiten\nHide-list: Liste ausblenden\nlate: später\nManage-tags: Tag-Manager\nMove-down: Nach unten\nMove-up: Nach oben\nNew-ToDo-Item: Neue Aufgabe\nno.: Anz.\nNothing-to-do-?: Nichts zu tun? Erstelle eine Aufgabe mit diesem Knopf\nOpen-all: alle öffnen\nPick-a-task-: Wähle eine Aufgabe aus der Liste unten mit diesem Knopf\nPrint-window-hint: In neuem Fenster öffnen für Druck\nProject: Projekt:\nRecycle: Nochmals verwenden\nRelax-Nothing-to-do: Schön. Es gibt nichts zu tun.\nRemove-deadline: Fälligkeit löschen\nRemove-tags?: Tags entfernen?\nReset: Zurücksetzen\nsearch: Suche …\nSend-it-down: doch nicht jetzt\nSet-deadline: Termin festlegen\nShow-list: Liste anzeigen\nSort-by-deadline: Nach Termin sortieren\nSort-by-modification: Nach letzter Änderung sortieren\nSort-by-priority: Alle nach Priorität sortieren\nSort-by-title: Alle nach Titel sortieren\nsorted-by-deadline: sortiert nach Enddatum\nsorted-by-modification: sortiert nach letzter Änderung\nsorted-by-priority: sortiert nach Priorität\nsorted-by-title: sortiert nach Titel\nSwitch-to-edit-mode: Bearbeiten ermöglichen\nSwitch-to-safe-mode: Bearbeiten ausschalten\nTake-it-up: Rauf damit!\nThis-is-done: Das ist erledigt\ntoday: heute\nToday: Heute\nToDo: ToDo\nToDo-template-title: ToDo Item\nToDo-template-text: Motivation: Description * Tests/Acceptance criteria\nThis-week: Diese Woche\nTomorrow: Morgen\nUuups: Hoppla!\n<!-- comments: Kommentare -->\n<!-- translation requires: $:/plugins/telmiger/lib/telang -->\n<!-- use translated term: <<telang term>> -->",
"type": "application/x-tiddler-dictionary",
"todo-done": "20160821121525",
"title": "$:/plugins/telmiger/lib/languages/de-CH",
"tags": "Translation ToDoComponents",
"modifier": "Thomas Elmiger",
"modified": "20180316064456612"
},
"$:/plugins/telmiger/listreveal/icon": {
"created": "20170224201850969",
"text": "<svg class=\"tc-image-button telmiger-icon\" viewBox=\"0 0 128 128\" xmlns=\"http://www.w3.org/2000/svg\" fill-rule=\"evenodd\" aria-labelledby=\"title\"><path class=\"circle\" d=\"M64 2C30 2 2 29.753 2 64c0 34.235 27.753 62 62 62s62-27.752 62-62c0-34.247-27.779-62-62-62z\"/><path class=\"t\" d=\"M100.41 63.254c-2.886 1.92-7.544 2.883-13.979 2.883h-8.008c-4.246 0-7.331.845-9.254 2.536-1.922 1.69-3.449 5.086-4.576 10.19 0 0-.181 1.481-.503 1.481s-.369-.877-.518-1.586a37.897 37.897 0 0 0-.721-2.754c-.631-2.137-1.262-3.753-1.894-4.847-.764-1.359-1.727-2.452-2.889-3.28-1.162-.83-2.49-1.326-3.985-1.492l-2.092-.248H41.73c-6.144 0-10.711-.962-13.7-2.884-4.976-3.159-7.649-9.129-8.02-17.91-.03-.706.003-1.351.132-2.171h.585c.399 3.975 3.679 7.048 6.086 9.219 2.408 2.172 6.269 3.258 11.581 3.258h9.313c5.347 0 9.257 1.226 11.731 3.68 2.231 2.213 3.701 5.68 4.406 10.4.076.511.03.736.178.736.149 0 .11-.256.17-.783.713-6.122 3.085-10.219 7.117-12.294 2.487-1.292 6.434-1.906 11.841-1.839l6.368.1c4.311.066 7.942-.788 10.893-2.56 2.953-1.773 6.447-5.079 6.844-9.917h.595c.183.478.16 1.576.127 2.333-.371 8.752-2.894 14.668-7.567 17.749z\"/></svg>\n<style>\n.telmiger-icon .circle { fill: #e2001a }\n.telmiger-icon .t { fill: #fff }\n</style>",
"title": "$:/plugins/telmiger/listreveal/icon",
"tags": "",
"modified": "20180303181038673"
},
"$:/plugins/telmiger/listreveal/readme": {
"created": "20170222172249206",
"creator": "Thomas Elmiger",
"text": "!! Good to Know\n\nA list of things you should know about this plugin. Click the ellipsis button on the right […] to see more.\n\nUse this button to enable editing: <<listrevealBtnEdit>>\n\n---\n\n<$set name=\"listfilter\" value=\"\"\"[all[shadows]prefix[0]sort[title]]\"\"\">\n<ul class=\"te-list\">\n<$list filter=<<listfilter>>>\n<$set name=\"tidTitle\" value={{!!title}}>\n <li class=\"todo-item te-flex-item\">\n <span class=\"te-flex-item te-flex-half-full\">\n <span class=\"te-flex-item te-flex-content te-flex-left\">\n <$link to={{!!title}}><$view field=\"title\"/></$link>\n </span>\n </span>\n <span class=\"te-flex-item te-flex-half-full\">\n <span class=\"te-flex-item te-flex-content te-flex-right\">\n <<teBtnEditShowModified>>\n<$wikify name=\"cl\" text=<<telang close>> >\n<$wikify name=\"tt\" text=<<telang Details>> >\n <$macrocall $name=\"listrevealButton\" title=<<tidTitle>> tooltip=<<tt>> close=<<cl>>/>\n</$wikify>\n</$wikify>\n </span>\n </span>\n<$wikify name=\"tpl\" text=<<telang date-created-tmpl>> >\n <$macrocall $name=\"listrevealContent\" title=<<tidTitle>> datetime=<<tpl>>/>\n</$wikify>\n </li>\n</$set>\n</$list>\n</ul>\n</$set>",
"title": "$:/plugins/telmiger/listreveal/readme",
"tags": "Listreveal",
"modified": "20170224210736677",
"modifier": "Thomas Elmiger"
},
"$:/plugins/telmiger/listreveal/tags": {
"created": "20160915193628399",
"creator": "Thomas Elmiger",
"text": "\\define lrTaglist(tiddler:\"_false_\")\n<$vars target=\"\"\"$tiddler$\"\"\">\n<div class=\"lr-tag-popup\">\n<$set name=\"add-tags-filter\" value=\"\"\"[list[$:/temp/lr-tags-$tiddler$!!lr-tagsinlist]sort[]] -[list[$:/temp/lr-tags-$tiddler$!!lr-tagstoremove]]\"\"\">\n<$set name=\"has-add-tags\" value=\"\"\"[list[$:/temp/lr-tags-$tiddler$!!lr-tagsinlist]sort[]] -[list[$:/temp/lr-tags-$tiddler$!!lr-tagstoremove]] +[limit[1]]\"\"\">\n<$list filter=<<has-add-tags>>>\n<<telang Add-tags-from-the-list>>\n<$wikify name=\"tt\" text=<<telang Add-tag>>>\n<ul class=\"lr-tags-add\">\n<$list filter=<<add-tags-filter>> variable=\"tag\">\n<li>\n <$macrocall $name=\"teBtnTagAddRemove\" btntext=<<tag>> add=<<tag>> tiddler=<<target>> tooltip=<<tt>>/> \n</li>\n</$list>\n</ul>\n</$wikify>\n</$list>\n</$set>\n</$set>\n<$set name=\"remove-tags-filter\" value=\"\"\"[list[$:/temp/lr-tags-$tiddler$!!lr-tagstoremove]sort[]] -[[$(exclude)$]]\"\"\">\n<$set name=\"has-remove-tags\" value=\"\"\"[list[$:/temp/lr-tags-$tiddler$!!lr-tagstoremove]sort[]] -[[$(exclude)$]] +[limit[1]]\"\"\">\n<$list filter=<<has-remove-tags>>>\n<<telang Remove-tags?>> \n<$wikify name=\"tt\" text=<<telang Are-you-sure?>>>\n<ul class=\"lr-tags-remove\">\n<$list filter=<<remove-tags-filter>> variable=\"tag\">\n<li>\n <$macrocall $name=\"teBtnTagAddRemove\" btntext=<<tag>> remove=<<tag>> tiddler=<<target>> tooltip=<<tt>>/> \n</li>\n</$list>\n</ul>\n</$wikify>\n</$list>\n</$set>\n</$set>\n<hr/>\n<<lrTagPicker \"\"\"$tiddler$\"\"\">>\n</div>\n</$vars>\n\\end\n\n\\define lrTagPicker(target)\n<div class=\"tc-edit-tags\">\n<$vars lr-tag-picker-actions=\"\"\"<$action-listops\n\t$tiddler=<<currentTiddler>>\n\t$field=\"tags\"\n\t$subfilter=\"[<tag>]\"\n/>\n<$action-setfield $tiddler=\"$(popstate)$\" $field=\"text\" $value=\"\"/>\n\"\"\">\n<$tiddler tiddler=\"\"\"$target$\"\"\">\n<$macrocall $name=\"tag-picker\" actions=<<lr-tag-picker-actions>>/>\n</$tiddler>\n</$vars>\n</div>\n\\end\n\n\\define teBtnTagAddRemove(btntext,add:\"_false_\",remove:\"_false_\",tooltip,class:\"\",tiddler:\"_false_\")\n<$vars tip=\"\"\"$tip$\"\"\" tiddler=\"\"\"$tiddler$\"\"\" btnclass=\"te-popup-action $class$\" add=\"\"\"$add$\"\"\" remove=\"\"\"$remove$\"\"\">\n<$set name=\"actiontid\" filter=\"[<tiddler>!prefix[_false_]]\" value=<<tiddler>> emptyValue=<<currentTiddler>>>\n<$set name=\"subfilter\" filter=\"[<add>!prefix[_false_]]\" value=\"[[$add$]]\" emptyValue=\"-[[$remove$]]\">\n<$wikify name=\"at\" text=<<actiontid>>>\n<$button class=<<btnclass>> tooltip=\"\"\"$tooltip$\"\"\">\n<<teTimestampPause>>\n<$action-listops $tiddler=<<at>> $field=\"tags\" $subfilter=<<subfilter>>/>\n<<teTimestampResume>>\n<$action-setfield $tiddler=\"\"\"$(popstate)$\"\"\" $field=\"text\" $value=\"\"/>\n <$text text=\"\"\"$btntext$\"\"\">\n</$button>\n</$wikify>\n</$set>\n</$set>\n</$vars>\n\\end\n\n\\define lrBtnAddTags(tiddler,class:\"\")\n<$vars tiddler=\"\"\"$tiddler$\"\"\" temptags=\"$:/temp/lr-tags-$tiddler$\">\n<$wikify name=\"tt\" text=<<telang Manage-tags>>>\n<$wikify name=\"tagfilter\" text=\"<<listfilter>> +[tags[]sort[]]\">\n<$button popup=<<qualify \"$:/state/popup/lr-tags-$tiddler$\">> class=\"\"\"te-btn-action addtag $class$\"\"\" tooltip=<<tt>> >\n<$action-listops $tiddler=<<temptags>> $field=\"lr-tagsinlist\" $filter=<<tagfilter>>/>\n<$action-listops $tiddler=<<temptags>> $field=\"lr-tagstoremove\" $filter=\"[<tiddler>tags[]]\"/>\n<$action-setfield $tiddler=<<temptags>> text=<<lrTaglist \"\"\"$tiddler$\"\"\">>/>\n{{$:/core/images/tag-button}}\n</$button>\n</$wikify>\n</$wikify>\n\\end\n\n\\define lrTagsPopup(tiddler)\n<$set name=\"popstate\" value=<<qualify \"$:/state/popup/lr-tags-$tiddler$\">>>\n<$reveal tag=\"div\" class=\"tc-block-dropdown tc-popup-handle\" state=<<popstate>> type=\"nomatch\" text=\"\" default=\"\">\n{{$:/temp/lr-tags-$tiddler$}}\n</$reveal>\n</$set>\n\\end\n\n\\define lrBtnTags(class:\"\")\n<span class=\"lr-flex-wrapper\">\n<$wikify name=\"tiddler\" text=<<currentTiddler>>>\n <$macrocall $name=\"lrBtnAddTags\" tiddler=<<tiddler>> class=\"\"\"$class$\"\"\"/>\n <$macrocall $name=\"lrTagsPopup\" tiddler=<<tiddler>>/>\n</$wikify>\n</span>\n\\end\n\n\\define listreveal-tags(exclude:\"\")\n<$vars exclude=\"\"\"$exclude$\"\"\">\n<span class=\"listreveal-tags te-flex-item\">\n<<lrBtnTags muted>>\n<span class=\"te-tags\">\n<div class=\"tc-tags-listreveal\"><$list filter=\"[all[current]tags[]sort[title]]\" storyview=\"pop\" template=\"$:/plugins/telmiger/listreveal/templates/tag\"/>\n</div>\n</span>\n</span>\n</$vars>\n\\end\n\n<!-- !! Listreveal Tags\n\n* lrTaglist\n** show a popup where tags can be added or removed\n** exclude one tag (e.g. master tag of your list)\n* lrTagPicker(tiddler)\n** add tags directly to a target tiddler (e.g. from view mode)\n* teBtnTagAddRemove\n** show a button to add/remove a tag from a tiddler \n** does not update the modification date as of TW 5.1.14\n* lrBtnTags\n** lrBtnAddTags: show the button (and save the tags that could be added/removed)\n** lrTagsPopup: reveal or hide the popup\n* listreveal-tags\n** put this in your revealed section to show the button and the existing tags\n** muted tag design\n** open-all button\n\n-->",
"title": "$:/plugins/telmiger/listreveal/tags",
"tags": "$:/tags/Macro ToDoComponents Listreveal",
"modifier": "Thomas Elmiger",
"modified": "20181014062117274",
"datetime": ""
},
"$:/plugins/telmiger/lib/telements.css": {
"text": "/* library of reusable (t)elements */\n\n/* header */\n\nheader {\n\tbackground-color: <<colour notification-background>>;\n\tpadding: 10px;\n\tmargin: 0 0 0 -10px;\n}\n\n/* te-summary as seen in extract macro */\n\n.te-summary {\n\twidth: 100%;\n\tbackground-color: <<colour code-background>>;\n}\n\n/* flexbox layout */\n\n.te-flex-content {\n\twidth: 100%;\n}\n\n.te-flex-item {\n\tdisplay: flex;\n\tflex-direction: row;\n\tflex-wrap: wrap;\n\tjustify-content: space-between;\n\talign-items: flex-start;\n\theight: auto;\n}\n\n.te-flex-half-full {\n\tflex-grow: 1;\n}\n\n.te-flex-left {\n\tjustify-content: flex-start;\n}\n\n.te-flex-right {\n\tjustify-content: flex-end;\n}\n\nh2 .te-flex-right, h2 .te-flex-right, h3 .te-flex-right {\n\tjustify-content: flex-end;\n\twidth: 33%;\n\tmax-width: 66%;\n}\n\n.te-tiddler-info {\n\torder: 90;\n\tmargin-top: 2rem;\n}\n\n\n/* lists */\n\n.te-list {\n\tlist-style: outside none none;\n\tmargin: 0 0 1rem 0;\n\tpadding: 0;\n\twidth: 100%;\n\tmax-width: 100%;\n}\n\n.te-list li {\n\tline-height: 1.5;\n}\n\n.te-list > li {\n\tborder-top: 1px solid; \n\tborder-color: <<colour tab-border>>;\n}\n\n.te-list > li:last-of-type {\n\tborder-bottom: 1px solid; \n}\n\n\n.te-list .te-flex-item a.tc-tiddlylink-resolves {\n\tflex-grow: 3;\n\tmax-width: 100%;\n}\n\n.te-list-icon {\n\twidth: 1em;\n\theight: 1em;\n\tmargin-right: .5rem;\n}\n\n\n/* buttons */\n/* big buttons */\n\nbutton.te-btn-big, .te-btn-big button {\n\tborder-radius: 0;\n\tmargin: 0;\n\tpadding: 0;\n\tbackground: none;\n\tdisplay: inline-block;\n\tposition: relative;\n vertical-align: middle;\n\ttop: -4px;\n\twidth: 3rem;\n\theight: 2rem;\n\tmargin-left: .5rem;\n\tborder-radius: .25rem;\n\tborder: 1px solid;\n\tborder-color: rgba(0, 0, 0, 0.4);\n\tbackground-color: rgba(0, 0, 0, 0.05);\n\tfont-size: 1.25rem;\n\ttext-align: center;\n}\n\nbutton.te-btn-big:hover,\nspan.te-btn-big button:hover {\n background-color: rgba(0, 0, 0, 0.1);\n}\n\n/* standard save button */\n\nbutton.te-btn-save svg {\n\theight: 1.25rem;\n top: -1px;\n position: relative;\n}\n\n/* color overlay hack */\n\nbutton.te-btn-big.te-create::before {\n background-color: <<colour download-background>>;\n content: \"\";\n position: absolute;\n top: 0; \n left: 0;\n width: 100%; \n height: 100%; \n opacity: 0.33; \n}\nbutton:hover.te-btn-big.te-create::before {\n opacity: 0.66; \n}\n\n.te-btn-big.unlocked {\n background-color: rgba(0, 0, 0, 0.1);\n}\n.te-btn-big.unlocked:hover {\n background-color: rgba(0, 0, 0, 0.05);\n}\n.te-btn-big.te-create {\n background-color: unset;\n}\n.te-btn-big .tc-image-locked-padlock, \n.te-btn-big .tc-image-unlocked-padlock {\n margin-bottom: 3px;\n}\n.te-btn-big .tc-image-new-button {\n margin-bottom: 2px;\n margin-top: 1px;\n}\n.te-btn-big .tc-image-unfold, \n.te-btn-big .tc-image-fold {\n margin-top: 3px;\n}\n\n\n/* action buttons */\n\nbutton.te-btn-action {\n\tborder: none;\n\tmargin: 0;\n\tpadding: 0;\n\tbackground: none;\n\tfont-size: 1em;\n\tborder-radius: .25rem;\n\theight: 1.66rem;\n\twidth: 1.66rem;\n\tmargin-right: .25rem;\n}\n.te-btn-action svg {\n fill: <<colour page-controls-foreground>>;\n}\n.te-btn-action.muted svg {\n opacity:0.4;\n}\n.te-list .te-btn-action.muted svg {\n opacity:0.4;\n}\n\n.te-list .te-btn-action:hover svg {\n opacity:0.6;\n}\n\n.te-btn-action.addtag svg {\n height: 1.5em;\n width: 1.5em;\n}\n\n.te-btn-action.te-edit svg {\n height: 1.25em;\n width: 1.25em;\n margin-bottom: -2px;\n}\n\n.te-btn-action.te-filter {\n\tposition: absolute;\n\tleft: calc(50% - 1rem);\n}\n\n.te-btn-action.te-filter:not(.muted) svg {\n\tfill: <<colour dirty-indicator>>;\n}\n\n.te-btn-action.te-prio {\n background-color: #777;\n width: calc(1.66rem - 6px);\n height: calc(1.66rem - 6px);\n border: 3px solid white;\n box-sizing: content-box;\n border-radius: .25rem;\n line-height: 1;\n}\n.te-btn-action.te-prio.prio2 {\n background-color: #999;\n}\n.te-btn-action.te-prio.prio3 {\n background-color: #bbb;\n}\n.te-btn-action.te-prio.prio4 {\n background-color: #ddd;\n}\n\n\n/* action button in te-tip */\n\n.te-tip .te-btn-action {\n margin-left: 0.4em;\n padding-bottom: 25px;\n}\n\n\n/* delete button and delete popup */\n\n.te-btn-delete svg.tc-image-delete-button {\n width: 1.1em;\n height: 1.45em;\n}\n\n\n/* popup action buttons */\n\n.te-popup-action {\n background: none;\n border: none;\n padding: 0;\n}\n\n/* date picker button */\n\n.te-btn-action.todo-deadline {\n\tdisplay: inline-block;\n\ttext-align: center;\n\twidth: 1.66rem;\n\theight: 1.66rem;\n\tmargin-right: .25rem;\n\tborder-radius: .25rem;\n}\n\n.te-btn-action.todo-deadline:hover {\n\tcursor: pointer;\n}\n.te-btn-action.todo-deadline span svg {\n\theight: 1.25rem;\n\twidth: 1.25rem;\n\tmargin-top: 3px;\n\topacity: 0.6;\n}\n\n/* label and icons */\n.te-btn-label {\n font-size: 0;\n height: 1px;\n overflow: hidden;\n display: block;\n}\n.te-btn-icon {\n display: block;\n}\nbutton:hover .te-btn-icon {\n display: none;\n}\n.te-btn-hovericon {\n display: none;\n}\nbutton:hover .te-btn-hovericon {\n display: block;\n}\n\n/* urgent indicators */\n\n.te-btn-action .urgent {\n display: table-cell;\n position: relative;\n margin-left: 0;\n left: 0em;\n top: -10px;\n font-size: 0.75em;\n line-height: 1.25;\n padding: 0 0.1em 0 0.1em;\n max-width: 3.25em;\n}\n\n.urgent.late {\n background-color: red;\n color: white;\n}\n.urgent.today {\n background-color: yellow;\n color: red;\n}\n\n\n/* priority buttons */\n\n.te-btn-action.te-prio svg {\n position: relative;\n height: 1.65rem;\n width: 1.5rem;\n opacity: 0;\n margin-top: -2.25rem;\n}\n.te-btn-action.te-prio:hover svg {\n opacity: 0.1;\n}\n.te-btn-action .te-prionr {\n\tposition: relative;\n\tcolor: #fefefe;\n\tfont-size: 1.25rem;\n\tfont-weight: 600;\n}\n.te-btn-action.te-prio.prio1 .te-prionr, .te-btn-action.te-prio.prio2 .te-prionr,\n.te-btn-action.te-prio.prio3 .te-prionr {\n color: #eee;\n}\n\n.te-prio-list {\n\tlist-style: none;\n\tposition: absolute;\n\tz-index: 25;\n\tborder: 1px solid;\n\tborder-radius: 4px;\n\tborder-color: <<colour tab-border>>;\n\tbackground-color: <<colour tab-background>>;\n}\n.te-list .te-prio-list {\n\twidth: 2.75rem;\n\tmargin: 1.55rem 0 0 -2.5rem;\n\tpadding: .5rem .5rem .25rem .5rem;\n}\n.te-list .te-prio-list li {\n\tline-height: 1;\n margin-top: 0;\n margin-bottom: 0;\n padding-top: 0;\n padding-bottom: 0;\n}\n\n.te-btn-reveal.tc-reveal {\n height: 1em;\n}\n\n.te-linkbutton {\n color: <<colour tiddler-link-foreground>>;\n background-color: transparent;\n border: 0;\n}\n\n/* checked icon */\n\n.te-item-checked svg {\n position: relative;\n top: .25rem;\n margin-right: .5rem;\n}\n\n\n/* text */\n\n.te-text {\n margin: 0 0.5rem 0 0.5rem;\n}\n.te-text.right {\n margin-left: 1em;\n margin-right: 0.5em;\n right: 6em;\n}\n\n\n/* popup tip */\n\n.te-tip {\n position: absolute;\n display: none;\n font-size: 0.875rem;\n line-height: 1.5;\n white-space: nowrap;\n padding: 0.1rem 0.5rem 0.2rem 0.5rem;\n border-radius: 3px;\n\tcolor: <<colour notification-border>>;\n\tborder-color: <<colour notification-border>>;\n\tbackground-color: <<colour notification-background>>;\n}\n\n.te-btn-big:hover .te-tip {\n margin-left: -8em;\n margin-top: -1.66em;\n z-index: 500;\n display: unset;\n}\n\n.te-btn-action:hover .te-tip,\n.te-created:hover .te-tip,\n.te-modified:hover .te-tip {\n margin-left: -0.4em;\n margin-top: -1.66rem;\n z-index: 500;\n display: unset;\n}\n\na:hover .te-tip,\n.te-text:hover .te-tip {\n display: inline-grid;\n margin-left: -0.8em;\n margin-top: -0.75em;\n z-index: 100;\n text-align: center;\n}\n\n.te-tip:hover span .te-tip, \n.te-text:hover .te-tip button .te-tip, \n.te-tip:hover button .te-tip {\n display: none;\n}\n.te-tip:hover span:hover .te-tip, \n.te-tip:hover button:hover .te-tip {\n margin-top: -1.25em;\n z-index: 101;\n display: unset;\n}\n.te-tip span span svg {\n margin-top: 0.25em;\n}\n\n/* meta info */\n\n.te-created, .te-modified {\n position: relative;\n}\n\n/* images */\n\n.te-created svg, .te-modified svg {\n max-height: 1.25em;\n opacity: 0.6;\n margin-bottom: -0.2em;\n}\n\n/* very small screens */\n\n@media (max-width: 500px) {\n .te-btn-action {\n margin: 0.3em 0.8em 0 0.5em;\n }\n}",
"title": "$:/plugins/telmiger/lib/telements.css",
"tags": "$:/tags/Stylesheet ToDoComponents ToDoArchive Listreveal",
"modifier": "Thomas Elmiger",
"modified": "20181013182824002",
"creator": "Thomas Elmiger",
"created": "20160816210925818"
},
"$:/plugins/telmiger/lib/telements-print.css": {
"text": "/* print optimisation for (t)elements */\n\n@media print {\n\n.te-noprint, \n.te-btn-action, .te-btn-action.muted, \n.te-btn-big,\n.te-edit, .te-to-top { \n display: none;\n}\n\n/* header */\n\nheader {\n background-color: transparent;\n}\n\n/* show buttons? reset display */\n/* big buttons */\n\n/* action buttons */\n\n.te-btn-action.todo-deadline, .te-btn-action.te-prio {\n display: initial;\n}\n\n.te-btn-action.te-prio.prio1 span.te-prionr, \n.te-btn-action.te-prio.prio1 {\n color: #efefef;\n}\n\n.te-btn-action.te-prio span.te-prionr, .te-btn-action.te-prio.prio2 span.te-prionr, \n.te-btn-action.te-prio.prio3 span.te-prionr, .te-btn-action.te-prio.prio4 span.te-prionr {\n color: #ddd;\n}\n\n.te-btn-action.te-prio {\n background-color: #ddd;\n border: 3px solid black;\n}\n.te-btn-action.te-prio.prio2 {\n background-color: #bbb;\n}\n.te-btn-action.te-prio.prio3 {\n background-color: #999;\n}\n.te-btn-action.te-prio.prio4 {\n background-color: #777;\n}\n\n/* date picker button */\n\n.te-btn-action.deadline span svg {\n opacity: 0.66;\n}\n\n/* text */\n\n/* meta info */\n\n/* images */\n\n.te-created svg, .te-modified svg {\n opacity: 0.6;\n}\n\n\n/* **** END of print optimisation **** */\n}\n",
"title": "$:/plugins/telmiger/lib/telements-print.css",
"tags": "$:/tags/Stylesheet Listreveal ToDoComponents",
"modifier": "Thomas Elmiger",
"modified": "20171105202618688",
"creator": "Thomas Elmiger",
"created": "20170201215840974"
},
"$:/plugins/telmiger/listreveal/lr": {
"text": "\\define listrevealButton(title,tooltip:\"Details\",close:\"Close\",class:\"\")\n<$vars showclass=\"\"\"listreveal-btn-show te-noprint $class$\"\"\" hideclass=\"\"\"listreveal-btn-hide te-noprint $class$\"\"\">\n<$set name=\"qualstate\" value=<<qualify \"\"\"$:/state/listreveal_$title$_\"\"\">> >\n<$reveal type=\"nomatch\" state=<<qualstate>> text=\"visible\" animate=\"yes\" class=\"listreveal\">\n <$button set=<<qualstate>> setTo=\"visible\" class=<<showclass>> tooltip=\"$tooltip$\">…</$button></$reveal>\n<$reveal type=\"match\" state=<<qualstate>> text=\"visible\" animate=\"yes\" class=\"listreveal\">\n <$button class=<<hideclass>> tooltip=\"$close$\">×<$action-deletetiddler $tiddler=<<qualstate>> />\n </$button></$reveal>\n</$set>\n</$vars>\n\\end\n\n\\define listrevealContent(title,mode:\"block\",datetime:\"YYYY-MM-DD\",state:\"_false_\",tagExclude:\"\")\n<$vars state=\"\"\"$state$\"\"\">\n<$set name=\"qualstate\" filter=\"[<state>!prefix[_false_]]\" value=<<state>> emptyValue=<<qualify \"\"\"$:/state/listreveal_$title$_\"\"\">> >\n<$reveal type=\"match\" state=<<qualstate>> text=\"visible\" animate=\"yes\" class=\"listreveal-open\">\n<<listreveal-tags $tagExclude$>>\n<span class=\"listreveal-content\">\n<$reveal type=\"nomatch\" state=\"$:/state/listreveal-mode\" text=\"edit\">\n <$transclude tiddler=\"\"\"$title$\"\"\" mode=\"$mode$\"/>\n</$reveal>\n<$reveal type=\"match\" state=\"$:/state/listreveal-mode\" text=\"edit\">\n <$edit tiddler=\"\"\"$title$\"\"\" class=\"listreveal-edit-text\"/>\n</$reveal>\n</span>\n <$macrocall $name=\"listreveal-meta\" tiddler=\"\"\"$title$\"\"\" datetime=\"\"\"$datetime$\"\"\"/>\n</$reveal>\n</$set>\n</$vars>\n\\end\n\n\\define listreveal-meta(tiddler,datetime)\n<span class=\"listreveal-meta te-flex-item\">\n <span class=\"te-created\">{{$:/core/images/file}}<span class=\"te-tip\"><$view tiddler=\"\"\"$tiddler$\"\"\" field=\"creator\"/></span><$view tiddler=\"\"\"$tiddler$\"\"\" field=\"created\" format=\"date\" template=\"\"\"$datetime$\"\"\"/></span>\n <span class=\"te-separator\"></span>\n<<listreveal-showmodified \"\"\"$tiddler$\"\"\" \"\"\"$datetime$\"\"\">>\n\\end\n\n\\define listreveal-showmodified(tiddler,datetime)\n<span class=\"te-modified\">{{$:/core/images/edit-button}}<span class=\"te-tip\"><$view tiddler=\"\"\"$tiddler$\"\"\" field=\"modifier\"/></span><$view tiddler=\"\"\"$tiddler$\"\"\" field=\"modified\" format=\"date\" template=\"\"\"$datetime$\"\"\"/></span>\n\\end\n\n\\define listrevealBtnEdit(class:\"\")\n<$reveal type=\"nomatch\" state=\"$:/state/listreveal-mode\" text=\"edit\">\n<$wikify name=\"tt\" text=<<telang Switch-to-edit-mode>>>\n<$button set=\"$:/state/listreveal-mode\" setTo=\"edit\" tooltip=<<tt>> class=\"te-btn-big locked $class$\">{{$:/core/images/locked-padlock}}</$button>\n</$wikify>\n</$reveal><$reveal type=\"match\" state=\"$:/state/listreveal-mode\" text=\"edit\">\n<$wikify name=\"tt\" text=<<telang Switch-to-safe-mode>>>\n<$button set=\"$:/state/listreveal-mode\" setTo=\"locked\" tooltip=<<tt>> class=\"te-btn-big unlocked $class$\"><$action-sendmessage $message=\"tm-auto-save-wiki\"/><span class=\"tc-dirty-indicator\">{{$:/core/images/unlocked-padlock}}</span></$button>\n</$wikify>\n</$reveal>\n\\end\n\n\n<!-- !! Listreveal Plugin Macros\n\n!!! Macros to reveal listed tiddlers\n* listrevealButton(title,tooltip:\"Details\",close:\"Close\",class:\"\")\n** produce a button to show/hide tiddler content\n*** parameters: tooltips for show/hide actions and a CSS-class\n* listrevealContent(title,mode:\"block\",datetime:\"YYYY-MM-DD\",state:\"_false_\")\n** show the content of a listed tiddler\n** use the state parameter if you don’t want tu use the standard button\n*** set the state to //visible// to show tiddler content \n\n!!! Optional macro\n* listrevealBtnEdit(class:\"\")\n** produce a button to \n*** put all listed tiddlers in edit mode (wikitext editor)\n*** lock the tiddlers and auto-save the wiki after editing\n\n!!! Helper macros for listrevealContent\n* listreveal-meta(tiddler,datetime)\n** show meta information of a tiddler: dates for created/modified and creator/modifier (on hover)\n*** datetime: a [[date format|http://tiddlywiki.com/#DateFormat]] string \n* listreveal-showmodified(tiddler,datetime)\n** show modified timestamp and modifier name (on hover)\n*** datetime: a [[date format|http://tiddlywiki.com/#DateFormat]] string \n\n-->",
"title": "$:/plugins/telmiger/listreveal/lr",
"tags": "$:/tags/Macro Listreveal",
"modifier": "Thomas Elmiger",
"modified": "20180429102515960",
"datetime": "",
"creator": "Thomas Elmiger",
"created": "20160811053433681"
},
"$:/plugins/telmiger/listreveal/lr.css": {
"text": "/* listreveal styles */\n/* === optimised for: ul class=\"te-list\" and li class=\"te-flex-item\" === */\n\n/* list RENAME listreveal-list? */\n\nul.te-list > li {\n\tpadding-top: calc(.125rem + 1px);\n\tpadding-left: .5rem;\n\tpadding-right: .25rem;\n\tpadding-bottom: 0;\n\tcolor: <<colour foreground>>;\n\tbackground-color: transparent;\n}\n\nul.te-list > li > * {\n\tpadding-bottom: 1px;\n}\n\nul.te-list > li:hover {\n\tbackground-color: rgba(0, 0, 0, 0.05);\n}\n\n\n/* link hack for Safari Mobile: */\n\n.te-list .te-flex-item a.tc-tiddlylink-resolves { \n\tword-break: break-all;\n}\n\n@media (min-width: 28rem) {\n\t.te-list .te-flex-item a.tc-tiddlylink-resolves { \n\t\tword-break: inherit;\n\t}\n}\n\n\n/* buttons */\n\n.te-list .listreveal-btn-show {\n\tborder: 1px solid;\n\tborder-radius: 0;\n\tborder-color: rgba(0, 0, 0, 0.5);\n\tpadding: 0;\n\tbackground: none;\n\tmargin: 0 0.125rem 0.1rem 0.5rem;\n\theight: 1.5rem;\n\twidth: 2.35rem;\n\tcolor: <<colour foreground>>;\n\tbackground-color: rgba(0, 0, 0, 0.05);\n}\n\n.listreveal-btn-show:hover {\n\tbackground-color: rgba(0, 0, 0, 0.1);\n}\n\n.te-list .listreveal-btn-hide {\n\tborder: 1px solid;\n\tborder-bottom-width: 0;\n\tborder-radius: 0;\n\tborder-color: rgba(0, 0, 0, 0.5);\n\tpadding: 0;\n\tbackground: none;\n\tmargin: 0 0.125rem 0 0.25rem;\n\twidth: 2.60rem;\n\theight: 1.66rem;\n\tcolor: <<colour foreground>>;\n\tbackground-color: rgba(0, 0, 0, 0.03);\n}\n\n.listreveal-btn-hide:hover {\n\tbackground-color: <<colour tiddler-background>>;\n}\n\n\n/* tiddler content */\n\n.listreveal-open {\n\tmargin-left: -.5rem;\n\tmargin-right: -.25rem;\n\twidth: calc(100% + .75rem);\n\theight: auto; \n\tmargin-bottom: -1px;\n\ttransition: none 0s ease 0s;\n}\n\n.listreveal-content {\n\tdisplay: block;\n\tcolor: <<colour foreground>>;\n\tborder: none;\n\tline-height: 1.5;\n padding: 1rem;\n\t-webkit-animation: expanditem 1s ease-in-out 0s running;\n\tanimation-name: expanditem;\n\tanimation-duration: 1s;\n\tanimation-timing-function: ease-in-out;\n\tanimation-delay: 0s;\n\tanimation-iteration-count: 1;\n\tanimation-direction: normal;\n}\n\n\n/* edit mode */\n\n.listreveal-edit-text {\n\twidth: 100%;\n\tborder: 1px solid gray;\n\tpadding: 1em;\n}\n\n\n/* meta info */\n\n.listreveal-tags, .listreveal-meta {\n font-size: 0.875rem;\n\tborder-top: 0;\n\tborder-bottom: 0;\n\tcolor: <<--black .5>>;\n\tfill: <<--black .5>>;\n\tmargin-top: 0;\n\tmargin-bottom: 0;\n\tpadding: .25rem;\n}\n.listreveal-tags {\n\tborder-top: 1px solid;\n\tborder-bottom: 1px solid;\n\tborder-color: rgba(0, 0, 0, 0.5);\n\tpadding-bottom: 0;\n}\n.listreveal-meta {\n\tborder-top: 1px solid;\n\tborder-bottom: none;\n\tborder-color: rgba(0, 0, 0, 0.5);\n\tpadding-right: 0.5rem;\n}\n.listreveal-meta svg {\n\tmargin-right: 0.25rem;\n}\n\n\n/* tags info */\n\n.listreveal-tags .te-tags span.tc-tag-label:hover {\n\t\n}\n\n.listreveal-tags .te-tags span.tc-tag-label {\n\n}\n\n.listreveal-tags .tc-block-dropdown {\n position: absolute;\n padding: .75rem .5rem 0 .5rem;\n margin-top: -.25rem;\n margin-right: 1rem;\n max-width: 100%;\n}\n\n.lr-tag-popup {\n margin-left: 1em;\n}\n.lr-tag-popup ul {\n margin: 0;\n padding: 0 1em 1em 0;\n line-height: 1.75;\n list-style: none;\n font-weight: 600;\n}\n.lr-tag-popup ul li:hover{\n color: <<colour tiddler-link-foreground>>;\n}\n.lr-tag-popup ul.lr-tags-remove li:hover{\n color: <<colour dirty-indicator>>;\n}\n.lr-tags-add li button::before {\n content: \"+ \";\n font-size: 1.2em;\n color: <<colour tiddler-link-foreground>>;\n}\n.lr-tags-remove li button::before {\n content: \"×  \";\n font-size: 1.2em;\n color: <<colour dirty-indicator>>;\n}\n\n@media (max-width: 960px) {\n}\n\n\n/* listreveal animation */\n\n@keyframes expanditem {\n 0% { \n height: 0;\n opacity: 0;\n }\n 80.0% {\n height: 60%;\n opacity: 0.9;\n }\n 100.0% {\n height: 100%;\n opacity: 1;\n }\n}\n\n@-webkit-keyframes expanditem {\n 0% { \n height: 0;\n opacity: 0;\n }\n 100.0% {\n height: 100%;\n opacity: 1;\n }\n}",
"type": "text/vnd.tiddlywiki",
"title": "$:/plugins/telmiger/listreveal/lr.css",
"tags": "$:/tags/Stylesheet Listreveal ToDoComponents ToDoArchive",
"modifier": "Thomas Elmiger",
"modified": "20181009203725889",
"creator": "Thomas Elmiger",
"created": "20160816052415397"
},
"$:/plugins/telmiger/lib/icons/stopwatch-empty.svg": {
"text": "<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 128 128\" fill=\"currentColor\" class=\"te-stopwatch-button tc-image-button\">\n<path d=\"M64.075 11.522c-32.17 0-58.25 26.082-58.25 58.25s26.08 58.25 58.25 58.25c32.175 0 58.25-26.082 58.25-58.25S96.25 11.52 64.076 11.52zm0 100.5c-23.336 0-42.25-18.914-42.25-42.25 0-23.33 18.914-42.25 42.25-42.25 23.337 0 42.25 18.92 42.25 42.25 0 23.336-18.913 42.25-42.25 42.25zM55.53 10.022c-2.763 0-5-2.24-5.002-5-.003-2.756 2.24-5 5-5h16.988c2.76 0 5 2.24 5 5 .005 2.757-2.24 5-5 5H55.53z\"/>\n<path fill=\"#000\" d=\"M55 60h18v18H55z\"/>\n</svg>",
"title": "$:/plugins/telmiger/lib/icons/stopwatch-empty.svg",
"tags": "$:/tags/Image",
"modifier": "Thomas Elmiger",
"modified": "20180208225232301",
"creator": "Thomas Elmiger",
"created": "20170506112920842"
},
"$:/plugins/telmiger/lib/icons/stopwatch-stop.svg": {
"text": "<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 128 128\" fill=\"currentColor\" class=\"te-stopwatch-button tc-image-button\">\n<path d=\"M64.075 11.522c-32.17 0-58.25 26.082-58.25 58.25s26.08 58.25 58.25 58.25c32.175 0 58.25-26.082 58.25-58.25S96.25 11.52 64.076 11.52zm0 100.5c-23.336 0-42.25-18.914-42.25-42.25 0-23.33 18.914-42.25 42.25-42.25 23.337 0 42.25 18.92 42.25 42.25 0 23.336-18.913 42.25-42.25 42.25zM55.53 10.022c-2.763 0-5-2.24-5.002-5-.003-2.756 2.24-5 5-5h16.988c2.76 0 5 2.24 5 5 .005 2.757-2.24 5-5 5H55.53z\"/>\n<path d=\"M64.075 35.902c-18.777 0-33.998 15.224-33.998 33.998 0 18.773 15.22 34.002 33.998 34.002 18.784 0 34.002-15.23 34.002-34.002 0-18.774-15.218-33.998-34.002-33.998z\"/>\n<path fill=\"#FFF\" d=\"M49 54h30v30H49z\"/>\n</svg>",
"title": "$:/plugins/telmiger/lib/icons/stopwatch-stop.svg",
"tags": "$:/tags/Image",
"modifier": "Thomas Elmiger",
"modified": "20180209212231631",
"creator": "Thomas Elmiger",
"created": "20170507053913584"
},
"$:/plugins/telmiger/lib/icons/stopwatch.svg": {
"text": "<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 128 128\" fill=\"currentColor\" class=\"te-stopwatch-button tc-image-button\">\n<path d=\"M64.075 11.522c-32.17 0-58.25 26.082-58.25 58.25s26.08 58.25 58.25 58.25c32.175 0 58.25-26.082 58.25-58.25S96.25 11.52 64.076 11.52zm0 100.5c-23.336 0-42.25-18.914-42.25-42.25 0-23.33 18.914-42.25 42.25-42.25 23.337 0 42.25 18.92 42.25 42.25 0 23.336-18.913 42.25-42.25 42.25zM55.53 10.022c-2.763 0-5-2.24-5.002-5-.003-2.756 2.24-5 5-5h16.988c2.76 0 5 2.24 5 5 .005 2.757-2.24 5-5 5H55.53z\"/>\n<path d=\"M19.41 27.178c-2.116 1.775-5.27 1.498-7.045-.613-1.772-2.11-1.498-5.27.616-7.047l9.95-8.348c2.115-1.774 5.27-1.5 7.045.618 1.775 2.108 1.498 5.27-.616 7.043l-9.95 8.348zM108.983 27.178c2.116 1.775 5.27 1.498 7.045-.613 1.772-2.11 1.498-5.27-.616-7.047l-9.95-8.348c-2.114-1.774-5.27-1.5-7.044.618-1.775 2.108-1.498 5.27.616 7.043l9.95 8.348zM71.097 71.072c0 3.826-3.09 6.928-6.897 6.928-3.804.006-6.9-3.102-6.903-6.928 0 0 4.76-39.072 6.903-39.072s6.897 39.072 6.897 39.072z\"/>\n</svg>",
"title": "$:/plugins/telmiger/lib/icons/stopwatch.svg",
"tags": "$:/tags/Image",
"modifier": "Thomas Elmiger",
"modified": "20180209065510293",
"creator": "Thomas Elmiger",
"created": "20180209065020276"
},
"$:/plugins/telmiger/lib/entities": {
"text": "\\define ldsbra() [[\n\\define rdsbra() ]]\n\n<!-- !! Entities as Macro Definitions\n\n!!! Very short macros for use in other macros\n* ldsbra and rdsbra – left double square brackets and right //dsbra//\n\n-->",
"todo-done": "20160819011650",
"title": "$:/plugins/telmiger/lib/entities",
"tags": "$:/tags/Macro ToDoComponents",
"modifier": "Thomas Elmiger",
"modified": "20170702091256635",
"creator": "Thomas Elmiger",
"created": "20170629183744936"
},
"$:/plugins/telmiger/lib/languages/da-DK": {
"created": "20170530162200369",
"creator": "BC",
"text": "ID:Dansk\n<!-- date formats: dato format starter her -->\ndate-created-tmpl: {{$:/language/Tiddler/DateFormat}}\ndate-created-tmpl: DD. MMM YYYY, kl. 0hh:0mm\ndate-deadline-tmpl: 0DD.0MM.YYYY\n<!-- titles: titler starter her -->\ntitle-Do: Nu\ntitle-Waiting: Senere\ntitle-Done: Udført\n<!-- motivation: motiverende slogans starter her -->\nMotivation-Don’t-do-it: Don’t have to do it? – Say it’s done!\nMotivation-single-task: Do the right ''one'' thing. – Then check & save.\n<!-- strings: texter starter her -->\nAdd-tag: Tilføj tag\nAdd-tags-from-the-list: Tilføj tags fra listen\nall: alle\nall-projects: alle projekter\narchive: arkiv\nAre-you-sure?: Er du sikker?\nChange-deadline: Ændre slutdato\nchange-priority: Ændre prioritet\nchange-priority-to: sæt prioritet til\nClick-to-edit-title: Klik på titlen for at redigere!\nclose: luk\nClose: Luk\ndays-back: dage tilbage\nDetails: Vis detaljer\nDo-it-again: Gør det igen\nDo-now: Udfør nu\nDone: Udført\nEdit: Redigér\nHide-list: Skjul liste\nlate: senere\nManage-tags: Tag-Manager\nMove-down: Flyt ned\nMove-up: Flyt op\nNew-ToDo-Item: Ny opgave\nno.: nr.\nNothing-to-do-?: Intet at lave? Beskriv en ny opgave med denne knap\nOpen-all: Åbn alle\nPick-a-task-: Vælg en opgave fra listen nedenunder med denne knap\nPrint-window-hint: Åbn i nyt vindue for at printe ud\nProject: Projekt\nRecycle: Genbrug\nRelax-Nothing-to-do: Slap af. Der er ikke noget at lave.\nRemove-deadline: Fjern slutdato\nRemove-tags?: Fjern tags?\nReset: Reset\nsearch: søg …\nSend-it-down: ikke endnu\nSet-deadline: Sæt slutdato\nShow-list: Vis liste\nSort-by-deadline: Sortér efter slutdato\nSort-by-modification: Sortér efter sidste ændring\nSort-by-priority: Sortér alle efter prioritet\nSort-by-title: Sortér alle efter titel\nsorted-by-deadline: sorteret efter slutdato\nsorted-by-modification: sorteret efter sidste ændring\nsorted-by-priority: sorteret efter prioritet\nsorted-by-title: sorteret efter titel\nSwitch-to-edit-mode: Slå redigering til\nSwitch-to-safe-mode: Slå redigering fra\nTake-it-up: Tag det op!\nThis-is-done: Dette er udført\nThis-week: I denne uge\ntoday: i dag\nToday: I dag\nToDo: ToDo\nToDo-template-title: Ny opgave\nToDo-template-text: Motivation: Beskrivelse * Tests/Accept kriterier\nTomorrow: I morgen\nUuups: Uuups!\n<!-- comments: Kommentarer -->\n<!-- credits: Tusind tak til Birthe for den oprindelige oversættelse! -->\n<!-- translation requires: $:/plugins/telmiger/lib/telang -->\n<!-- use translated term: <<telang term>> -->\n",
"type": "application/x-tiddler-dictionary",
"todo-done": "20160821121501",
"title": "$:/plugins/telmiger/lib/languages/da-DK",
"tags": "ToDoComponents Translation",
"modifier": "Thomas Elmiger",
"modified": "20180316064737492"
},
"$:/plugins/telmiger/lib/dates": {
"created": "20170627092117795",
"creator": "Thomas Elmiger",
"text": "\\define yearsSince(date-field:\"modified\",tiddler)\n<<yearsDiff \"\"\"$date-field$\"\"\" \"\"\"$tiddler$\"\"\">>\n\\end\n\n\\define monthsSince(date-field:\"modified\",tiddler)\n<$vars df=\"\"\"$date-field$\"\"\" tid=\"\"\"$tiddler$\"\"\"><$wikify name=\"years\" text=\"\"\"<$macrocall $name=\"yearsDiff\" date-field=<<df>> tiddler=<<tid>>/>\"\"\">\n<$wikify name=\"yearsM\" text='<$macrocall $name=\"rpn\" a=<<years>> b=12 operation=\"*\"/>'>\n<$wikify name=\"months\" text=\"\"\"<$macrocall $name=\"monthsDiff\"date-field=<<df>> tiddler=<<tid>>/>\"\"\">\n<$macrocall $name=\"rpn\" a=<<yearsM>> b=<<months>>/>\n</$wikify></$wikify></$wikify></$vars>\n\\end\n\n\\define daysSince(date-field:\"modified\",tiddler)\n<<daysDiff $date-field$ \"\"\"$tiddler$\"\"\">>\n\\end\n\n\\define hoursSince(date-field:\"modified\",tiddler)\n<$vars df=\"\"\"$date-field$\"\"\" tid=\"\"\"$tiddler$\"\"\"><$wikify name=\"days\" text=\"\"\"<$macrocall $name=\"daysSince\" date-field=<<df>> tiddler=<<tid>>/>\"\"\">\n<$wikify name=\"daysH\" text='<$macrocall $name=\"rpn\" a=<<days>> b=\"24\" operation=\"*\"/>'>\n<$wikify name=\"hours\" text=\"\"\"<$macrocall $name=\"hoursDiff\" date-field=<<df>> tiddler=<<tid>>/>\"\"\">\n<$macrocall $name=\"rpn\" a=<<daysH>> b=<<hours>>/>\n</$wikify></$wikify></$wikify></$vars>\n\\end\n\n\\define minutesSince(date-field:\"modified\",tiddler)\n<$vars df=\"\"\"$date-field$\"\"\" tid=\"\"\"$tiddler$\"\"\"><$wikify name=\"hours\" text=\"\"\"<$macrocall $name=\"hoursSince\" date-field=<<df>> tiddler=<<tid>>/>\"\"\"><$wikify name=\"hoursM\" text='<$macrocall $name=\"rpn\" a=<<hours>> b=\"60\" operation=\"*\"/>'><$wikify name=\"minutes\" text=\"\"\"<$macrocall $name=\"minutesDiff\" date-field=<<df>> tiddler=<<tid>>/>\"\"\"><$macrocall $name=\"rpn\" a=<<hoursM>> b=<<minutes>>/></$wikify></$wikify></$wikify></$vars>\n\\end\n\n\\define hoursMinutesSince(date-field:\"modified\",tiddler)\n<$vars df=\"\"\"$date-field$\"\"\" tid=\"\"\"$tiddler$\"\"\"><$wikify name=\"minutes\" text=\"\"\"<$macrocall $name=\"minutesSince\" date-field=<<df>> tiddler=<<tid>>/>\"\"\"><$macrocall $name=\"rpn\" a=<<minutes>> b=60 operation=\"/\" precision=\"f\"/> h <$macrocall $name=\"rpn\" a=<<minutes>> b=60 operation=\"%\"/> m</$wikify></$vars>\n\\end\n\n\\define minutesTo(date-field:\"modified\",tiddler)\n<$vars df=\"\"\"$date-field$\"\"\" tid=\"\"\"$tiddler$\"\"\"><$wikify name=\"minutes\" text=\"\"\"<$macrocall $name=\"minutesSince\" date-field=<<df>> tiddler=<<tid>>/>\"\"\"><$wikify name=\"result\" text='<$macrocall $name=\"rpn\" a=<<minutes>> b=\"-1\" operation=\"*\"/>'><<result>></$wikify></$wikify></$vars>\n\\end\n\n\\define hoursTo(date-field:\"modified\",tiddler)\n<$vars df=\"\"\"$date-field$\"\"\" tid=\"\"\"$tiddler$\"\"\"><$wikify name=\"hours\" text=\"\"\"<$macrocall $name=\"hoursSince\" date-field=<<df>> tiddler=<<tid>>/>\"\"\"><$wikify name=\"result\" text='<$macrocall $name=\"rpn\" a=<<hours>> b=\"-1\" operation=\"*\"/>'><<result>></$wikify></$wikify></$vars>\n\\end\n\n\\define yearsDiff(date-field:\"modified\",tiddler)\n<$vars df=\"\"\"$date-field$\"\"\" tid=\"\"\"$tiddler$\"\"\"><$wikify name=\"a\" text='<<now YYYY>>'><$wikify name=\"b\" text=\"\"\"<$macrocall $name=\"yearValue\" field=<<df>> tiddler=<<tid>>/>\"\"\"><$macrocall $name=\"rpn\" a=<<a>> b=<<b>> operation=\"-\"/></$wikify></$wikify></$vars>\n\\end\n\n\\define monthsDiff(date-field:\"modified\",tiddler)\n<$vars df=\"\"\"$date-field$\"\"\" tid=\"\"\"$tiddler$\"\"\"><$wikify name=\"a\" text='<<now MM>>'><$wikify name=\"b\" text=\"\"\"<$macrocall $name=\"monthValue\" field=<<df>> tiddler=<<tid>>/>\"\"\"><$macrocall $name=\"rpn\" a=<<a>> b=<<b>> operation=\"-\"/></$wikify></$wikify></$vars>\n\\end\n\n\\define daysDiff(date-field:\"modified\",tiddler)\n<$vars df=\"\"\"$date-field$\"\"\" tid=\"\"\"$tiddler$\"\"\"><$wikify name=\"a\" text='<<now DD>>'><$wikify name=\"b\" text=\"\"\"<$macrocall $name=\"dayValue\" field=<<df>> tiddler=<<tid>>/>\"\"\"><$macrocall $name=\"rpn\" a=<<a>> b=<<b>> operation=\"-\"/></$wikify></$wikify></$vars>\n\\end\n\n\\define hoursDiff(date-field:\"modified\",tiddler)\n<$vars df=\"\"\"$date-field$\"\"\" tid=\"\"\"$tiddler$\"\"\"><$wikify name=\"a\" text='<<now 0hh>>'><$wikify name=\"b\" text=\"\"\"<$macrocall $name=\"hoursValue\" field=<<df>> tiddler=<<tid>>/>\"\"\"><$macrocall $name=\"rpn\" a=<<a>> b=<<b>> operation=\"-\"/></$wikify></$wikify></$vars>\n\\end\n\n\\define minutesDiff(date-field:\"modified\",tiddler)\n<$vars df=\"\"\"$date-field$\"\"\" tid=\"\"\"$tiddler$\"\"\"><$set name=\"update-everything-now\" value=<<now 0mm>>><$wikify name=\"a\" text=\"<<update-everything-now>>\"><$wikify name=\"b\" text=\"<$macrocall $name=minutesValue field=<<df>> tiddler=<<tid>>/>\"><$macrocall $name=\"rpn\" a=<<a>> b=<<b>> operation=\"-\"/></$wikify></$wikify></$set></$vars>\n\\end\n\n<!-- !! Calculations with dates\nTransform dates in TW [[Date Field Format|http://tiddlywiki.com/#Date%20Fields]]\n\nTODO: Jed Carty has better macros for similar things – build a new version based on these http://ooktech.com/jed/ExampleWikis/DateMacros/\n\nWe compare the date string in a given field with the result of the `<<now>>` macro combined with one of the selectors YYYY for years, MM for months, DD for Days, 0hh …, 0mm …, 0ss. Note the 0-prefix for values that could be zero! (They disappear and return nothing when this is missing).\n\nThis was developped for use with due dates. The macros are good enough to check if a deadline was missed or if it will be reached soon.\n\n* time since the given timestamp\n** yearsSince(date-field:\"modified\",tiddler) – tiddler defaults to current\n** monthsSince (counts also the year difference)\n** daysSince – does NOT take the month into account\n*** this would be complicated because of differing number of days in each month\n** hoursSince (counts also the days)\n*** this can result in errors when the days are in different monts\n*** we recommend to filter for days in the same month first\n** minutesSince (counts also the hours and days)\n** hoursMinutesSince – turn minutes from minutesSince back into hours and minutes \n* time to the given datestamp … – time since inverted (* -1)\n** minutesTo\n** hoursTo\n** missing: daysTo, monthsTo, yearsTo\n* Diff macros\n** yearsDiff(date-field:\"modified\",tiddler)\n** … and so on for months, days, hours, minutes\n\n\nSyntax: `<<yearsSince created>>`\n\nResult: <<yearsSince created>>\n\n-->\n",
"title": "$:/plugins/telmiger/lib/dates",
"tags": "[[ToDo Addons]] $:/tags/Macro",
"modifier": "Thomas Elmiger",
"modified": "20170913183802528"
},
"$:/plugins/telmiger/lib/dates-then": {
"created": "20170705203414697",
"creator": "Thomas Elmiger",
"text": "\\define yearValue(field,tiddler) <<dateValue YYYY $field$ \"\"\"$tiddler$\"\"\">>\n\\define monthValue(field,tiddler) <<dateValue MM $field$ \"\"\"$tiddler$\"\"\">>\n\\define dayValue(field,tiddler) <<dateValue DD $field$ \"\"\"$tiddler$\"\"\">>\n\\define hoursValue(field,tiddler) <<dateValue 0hh $field$ \"\"\"$tiddler$\"\"\">>\n\\define minutesValue(field,tiddler) <<dateValue 0mm $field$ \"\"\"$tiddler$\"\"\">>\n\\define secondsValue(field,tiddler) <<dateValue 0ss $field$ \"\"\"$tiddler$\"\"\">>\n\n\\define dateValue(template:\"YYYY-0MM-0DD\",field:\"modified\",tiddler) \n<$set name=\"tid\" filter=\"\"\"[field:title[$tiddler$]]\"\"\" value=\"\"\"$tiddler$\"\"\" emptyValue=<<currentTiddler>>><$view tiddler=<<tid>> field=\"\"\"$field$\"\"\" format=\"date\" template=\"\"\"$template$\"\"\"/></$set>\n\\end\n\n\n<!-- !! Macros for Dates from fields\nOutput dates from fields in TW [[Date Field Format|http://tiddlywiki.com/#Date%20Fields]]\n\n* dateValue(template:\"YYYY-0MM-0DD\",field:\"modified\",tiddler) – return a value from a date string via the view widget\n** field: where the date string is stored\n** tiddler: where the date string is stored, defaults to currentTiddler\n* yearValue(field,tiddler) – return the year\n** monthValue, dayValue, hoursValue, minutesValue, secondsValue – guess what ;–)\n\n-->\n\nSyntax: `<<hoursValue example-1>>`\n\nResult: <<hoursValue example-1>>\n\n",
"title": "$:/plugins/telmiger/lib/dates-then",
"tags": "[[ToDo Addons]] $:/tags/Macro",
"modifier": "Thomas Elmiger",
"modified": "20170913170219153",
"example-1": "20001231230000000"
},
"$:/plugins/telmiger/listreveal/templates/tag": {
"created": "20180315065904040",
"creator": "Thomas Elmiger",
"text": "<span class=\"tc-tag-list-item\">\n<$set name=\"transclusion\" value=<<currentTiddler>>>\n<$wikify name=\"bg-color\" text=\"<<colour sidebar-tab-background-selected>>\">\n<$wikify name=\"fg-color\" text=\"<<colour sidebar-tab-foreground-selected>>\">\n<$macrocall $name=\"tag-pill-inner\" tag=<<currentTiddler>> icon={{!!icon}} colour=<<bg-color>> fallbackTarget={{$palette$##tag-background}} colourA=<<fg-color>> colourB=<<bg-color>> element-tag=\"$button\" element-attributes=\"\"\"popup=<<qualify \"$:/state/popup/tag\">> dragFilter='[all[current]tagging[]]' tag='span'\"\"\" actions=\"\"/>\n<$reveal state=<<qualify \"$:/state/popup/tag\">> type=\"popup\" position=\"below\" animate=\"yes\" class=\"tc-drop-down\">\n<$transclude tiddler=\"$:/core/ui/ListItemTemplate\"/>\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/TagDropdown]!has[draft.of]]\" variable=\"listItem\"> \n<$transclude tiddler=<<listItem>>/> \n</$list>\n<hr>\n<$macrocall $name=\"list-tagged-draggable\" tag=<<currentTiddler>>/>\n<!-- open-all -->\n<hr>\n<div class=\"tc-menu-list-item\">\n<$button class=\"tc-btn-invisible tc-tiddlylink tc-tiddlylink-resolves\"><$list filter=\"[all[current]tagging[]]\"><$action-navigate $to=<<currentTiddler>> /></$list><<telang Open-all>></$button>\n</div>\n<!-- /open-all -->\n</$reveal>\n</$wikify>\n</$wikify>\n</$set>\n</span>\n",
"title": "$:/plugins/telmiger/listreveal/templates/tag",
"tags": "",
"modified": "20180316210120658",
"modifier": "Thomas Elmiger"
},
"$:/plugins/telmiger/listreveal/configuration": {
"created": "20180423195037840",
"creator": "Thomas Elmiger",
"text": "!! Configuration\n\n!!! Language\n\n<table>\n <tr>\n <th align=\"left\">Choose your language</th>\n <td>\n<$select tiddler=\"$:/plugins/telmiger/lib/language\" field=\"text\">\n<$list filter=\"\"\"[all[shadows+tiddlers]removeprefix[$:/plugins/telmiger/lib/languages/]sort[]]\"\"\" variable=\"code\">\n<$wikify name=\"lang\" text=\"$:/plugins/telmiger/lib/languages/<<code>>\">\n<option value=<<lang>>><<code>></option>\n</$wikify>\n</$list>\n</$select>\n </td>\n <td>\n \tISO code (language-country)\n </td>\n </tr>\n</table>\n\nActive: {{$:/plugins/telmiger/lib/language}}\n\n---\n\n!!! Translations, date and time format\n\n# Clone one of the following language tiddlers, set a new ending for the title, e.g. …/de-foo (do not change the rest of the title): <ul>\n<$list filter=\"[all[shadows+tiddlers]prefix[$:/plugins/telmiger/lib/languages/]]\">\n<li><<currentTiddler>></li>\n</$list>\n</ul>\n\n# Adapt the [[formatting of dates and time|http://tiddlywiki.com/#DateFormat]], translate terms if desired.\n\n# Select your newly created language in the dropdown above.\n",
"title": "$:/plugins/telmiger/listreveal/configuration",
"tags": "ToDoComponents",
"modifier": "Thomas Elmiger",
"modified": "20180423200822702"
},
"$:/plugins/telmiger/listreveal/lr-search": {
"text": "\\define listrevealSearch(id:\"search\")\n<$vars tagsearchTiddler=\"$:/state/listreveal/Search/$id$\">\n<$wikify name=\"placeholder\" text=<<telang search>> >\n<div class=\"tc-search\">\n<$edit-text tiddler=<<tagsearchTiddler>> type=\"search\" tag=\"input\" focus=\"true\" placeholder=<<placeholder>> default=\"\"/>\n<$reveal state=<<tagsearchTiddler>> type=\"nomatch\" text=\"\">\n<$wikify name=\"reset\" text=<<telang Reset>> >\n<$button tooltip=<<reset>> class=\"tc-btn-invisible\">\n<$action-setfield $tiddler=<<tagsearchTiddler>> text=\"\" />\n{{$:/core/images/close-button}}\n</$button>\n</$wikify>\n</$reveal>\n</div>\n</$wikify>\n</$vars>\n\\end\n\n\\define listrevealProjectSelect(mastertag:\"ToDo\")\n<$wikify name=\"tagfilter\" text=\"\"\"<<listfilter>> +[tags[]sort[title]] -[[$mastertag$]]\"\"\">\n<div class=\"lr-project-search\">\n<$select tiddler='$:/state/listreveal/ProjectSelect/$mastertag$'>\n<option value='$mastertag$'><<telang all-projects>></option>\n<$list filter=<<tagfilter>>>\n <option><$view field='title'/></option>\n</$list>\n</$select>\n</div>\n</$wikify>\n\\end\n\n\\define resultCounter(textafter:\"\")\n<$set name=\"resultCount\" value='<$count filter=\"\"\"$(listfilter)$\"\"\"/>'>\n<span class=\"lr-search-counter\">\n{{$:/language/Search/Matches}} <small>$textafter$</small>\n</span>\n</$set>\n\\end\n\n<!-- !! Listreveal Plugin Macros\n\n!!! Helper macros for searching the list\n* listrevealProjectSelect(mastertag:\"ToDo\")\n** show a select with all other tags from all tiddlers tagged with the mastertag\n* listrevealSearch(state:\"search\",id:\"lr\")\n** state: if you generate more than one list, use e.g. \"active\" and \"inactive\" here\n** id: an identifier for the list you want to search in\n* listrevealCounter(textafter:\"\")\n\n-->",
"title": "$:/plugins/telmiger/listreveal/lr-search",
"tags": "$:/tags/Macro Listreveal",
"modifier": "Thomas Elmiger",
"modified": "20181013190110603",
"datetime": "",
"creator": "Thomas Elmiger",
"created": "20180429101307450"
},
"$:/plugins/telmiger/lib/telements/story-nav": {
"text": "<div class=\"te-story-controls\">\n<$list filter=\"[all[current]next[$:/StoryList]]\">\n<span class=\"story-next\">\n<$button to={{!!title}} tooltip=\"next\">{{$:/core/images/down-arrow}}</$button>\n</span>\n</$list>\n<$list filter=\"[all[current]previous[$:/StoryList]]\">\n<span class=\"story-prev\">\n<$button to={{!!title}} tooltip=\"previous\">{{$:/core/images/up-arrow}}</$button>\n</span>\n</$list>\n</div>",
"title": "$:/plugins/telmiger/lib/telements/story-nav",
"tags": "",
"modifier": "Thomas Elmiger",
"modified": "20180505200055700",
"creator": "Thomas Elmiger",
"created": "20180505155058918"
}
}
}
\define lrTaglist(tiddler:"_false_")
<$vars target="""$tiddler$""">
<div class="lr-tag-popup">
<$set name="add-tags-filter" value="""[list[$:/temp/lr-tags-$tiddler$!!lr-tagsinlist]sort[]] -[list[$:/temp/lr-tags-$tiddler$!!lr-tagstoremove]]""">
<$set name="has-add-tags" value="""[list[$:/temp/lr-tags-$tiddler$!!lr-tagsinlist]sort[]] -[list[$:/temp/lr-tags-$tiddler$!!lr-tagstoremove]] +[limit[1]]""">
<$list filter=<<has-add-tags>>>
<<telang Add-tags-from-the-list>>
<$wikify name="tt" text=<<telang Add-tag>>>
<ul class="lr-tags-add">
<$list filter=<<add-tags-filter>> variable="tag">
<li>
<$macrocall $name="teBtnTagAddRemove" btntext=<<tag>> add=<<tag>> tiddler=<<target>> tooltip=<<tt>>/>
</li>
</$list>
</ul>
</$wikify>
</$list>
</$set>
</$set>
<$set name="remove-tags-filter" value="""[list[$:/temp/lr-tags-$tiddler$!!lr-tagstoremove]sort[]] -[[$(exclude)$]]""">
<$set name="has-remove-tags" value="""[list[$:/temp/lr-tags-$tiddler$!!lr-tagstoremove]sort[]] -[[$(exclude)$]] +[limit[1]]""">
<$list filter=<<has-remove-tags>>>
<<telang Remove-tags?>>
<$wikify name="tt" text=<<telang Are-you-sure?>>>
<ul class="lr-tags-remove">
<$list filter=<<remove-tags-filter>> variable="tag">
<li>
<$macrocall $name="teBtnTagAddRemove" btntext=<<tag>> remove=<<tag>> tiddler=<<target>> tooltip=<<tt>>/>
</li>
</$list>
</ul>
</$wikify>
</$list>
</$set>
</$set>
<hr/>
<<lrTagPicker """$tiddler$""">>
</div>
</$vars>
\end
\define lrTagPicker(target)
<div class="tc-edit-tags">
<$vars lr-tag-picker-actions="""<$action-listops
$tiddler=<<currentTiddler>>
$field="tags"
$subfilter="[<tag>]"
/>
<$action-setfield $tiddler="$(popstate)$" $field="text" $value=""/>
""">
<$tiddler tiddler="""$target$""">
<$macrocall $name="tag-picker" actions=<<lr-tag-picker-actions>>/>
</$tiddler>
</$vars>
</div>
\end
\define teBtnTagAddRemove(btntext,add:"_false_",remove:"_false_",tooltip,class:"",tiddler:"_false_")
<$vars tip="""$tip$""" tiddler="""$tiddler$""" btnclass="te-popup-action $class$" add="""$add$""" remove="""$remove$""">
<$set name="actiontid" filter="[<tiddler>!prefix[_false_]]" value=<<tiddler>> emptyValue=<<currentTiddler>>>
<$set name="subfilter" filter="[<add>!prefix[_false_]]" value="[[$add$]]" emptyValue="-[[$remove$]]">
<$wikify name="at" text=<<actiontid>>>
<$button class=<<btnclass>> tooltip="""$tooltip$""">
<<teTimestampPause>>
<$action-listops $tiddler=<<at>> $field="tags" $subfilter=<<subfilter>>/>
<<teTimestampResume>>
<$action-setfield $tiddler="""$(popstate)$""" $field="text" $value=""/>
<$text text="""$btntext$""">
</$button>
</$wikify>
</$set>
</$set>
</$vars>
\end
\define lrBtnAddTags(tiddler,class:"")
<$vars tiddler="""$tiddler$""" temptags="$:/temp/lr-tags-$tiddler$">
<$wikify name="tt" text=<<telang Manage-tags>>>
<$wikify name="tagfilter" text="<<listfilter>> +[tags[]sort[]]">
<$button popup=<<qualify "$:/state/popup/lr-tags-$tiddler$">> class="""te-btn-action addtag $class$""" tooltip=<<tt>> >
<$action-listops $tiddler=<<temptags>> $field="lr-tagsinlist" $filter=<<tagfilter>>/>
<$action-listops $tiddler=<<temptags>> $field="lr-tagstoremove" $filter="[<tiddler>tags[]]"/>
<$action-setfield $tiddler=<<temptags>> text=<<lrTaglist """$tiddler$""">>/>
{{$:/core/images/tag-button}}
</$button>
</$wikify>
</$wikify>
\end
\define lrTagsPopup(tiddler)
<$set name="popstate" value=<<qualify "$:/state/popup/lr-tags-$tiddler$">>>
<$reveal tag="div" class="tc-block-dropdown tc-popup-handle" state=<<popstate>> type="nomatch" text="" default="">
{{$:/temp/lr-tags-$tiddler$}}
</$reveal>
</$set>
\end
\define lrBtnTags(class:"")
<span class="lr-flex-wrapper">
<$wikify name="tiddler" text=<<currentTiddler>>>
<$macrocall $name="lrBtnAddTags" tiddler=<<tiddler>> class="""$class$"""/>
<$macrocall $name="lrTagsPopup" tiddler=<<tiddler>>/>
</$wikify>
</span>
\end
\define listreveal-tags(exclude:"")
<$vars exclude="""$exclude$""">
<span class="listreveal-tags te-flex-item">
<<lrBtnTags muted>>
<span class="te-tags">
<div class="tc-tags-listreveal"><$list filter="[all[current]tags[]sort[title]]" storyview="pop" template="$:/plugins/telmiger/listreveal/templates/tag"/>
</div>
</span>
</span>
</$vars>
\end
<!-- !! Listreveal Tags
* lrTaglist
** show a popup where tags can be added or removed
** exclude one tag (e.g. master tag of your list)
* lrTagPicker(tiddler)
** add tags directly to a target tiddler (e.g. from view mode)
* teBtnTagAddRemove
** show a button to add/remove a tag from a tiddler
** does not update the modification date as of TW 5.1.14
* lrBtnTags
** lrBtnAddTags: show the button (and save the tags that could be added/removed)
** lrTagsPopup: reveal or hide the popup
* listreveal-tags
** put this in your revealed section to show the button and the existing tags
** muted tag design
** open-all button
-->
{
"tiddlers": {
"$:/plugins/telmiger/WMR/plugin-macros": {
"created": "20181124191802720",
"text": "\\define wt(wikitext:\"example\")\n<$wikify name=\"in\" text=\"\"\"$wikitext$\"\"\" type=\"text/plain\">\n<$set name=\"out\" value=\"\"\"\n\n$wikitext$\n\n\"\"\">\n<$macrocall $name=\"renderWT\" input=<<in>> output=<<out>>/>\n</$set>\n</$wikify>\n\\end\n\n\\define renderWT(input,output)\n<div class=\"wmr-input\">\n\n```\n$input$\n```\n</div>\n<div class=\"wmr-output\">$output$</div>\n\\end\n\n\\define revealstate(tiddler,stateID)\n<$set name=\"qualstate\" value=<<qualify \"$:/state/wiki-markup/$stateID$\">> >\n<$reveal type=\"nomatch\" state=<<qualstate>> text=\"visible\" animate=\"yes\">\n <$button set=<<qualstate>> setTo=\"visible\" class=\"btnClosed\">Show</$button>\n</$reveal>\n<$reveal type=\"match\" state=<<qualstate>> text=\"visible\" animate=\"yes\">\n <$button set=<<qualstate>> setTo=\"hidden\" class=\"btnOpen\">Hide section</$button>\n<article class=\"wikitext-examples\">\n<$transclude tiddler=\"$tiddler$\" mode=\"block\"/>\n<footer>\n<$list filter=\"[{$tiddler$!!wmr-source-link}prefix[https://tiddlywiki.com]]\">\n<a href={{$tiddler$!!wmr-source-link}}>More on tiddlywiki.com</a> | </$list>\n<$link to=\"$tiddler$\">Open separately</$link>\n</footer>\n</article>\n</$reveal>\n</$set>\n\\end\n",
"title": "$:/plugins/telmiger/WMR/plugin-macros",
"tags": "$:/tags/Macro",
"modified": "20181125091902187"
},
"$:/plugins/telmiger/WMR/styles.css": {
"created": "20181124215313762",
"text": ".wikitext-examples .wmr-input {\n margin-top: 2rem;\n max-width: 28rem;\n}\n\n.wikitext-examples footer {\n background-color: #e9e9e9;\n padding: 0.25rem;\n border-bottom: 1px solid #999;\n}\n\n.wmr-output .red {\n color: red;\n fill: red;\n}\n\n\n/* Buttons */\n\n.wikitext-examples .btnClosed,\n.wikitext-examples .btnOpen {\n width: 100%;\n text-align: left;\n background: #e9e9e9;\n border: none;\n padding: 0.25rem;\n}\n\n.wikitext-examples .btnClosed:before {\n content: \"▶\";\n margin-right: 0.5rem;\n}\n\n.wikitext-examples .btnOpen:before {\n content: \"▼\";\n margin-right: 0.5rem;\n}",
"title": "$:/plugins/telmiger/WMR/styles.css",
"tags": "$:/tags/Stylesheet",
"modified": "20181125100726086"
},
"$:/plugins/telmiger/WMR/about": {
"created": "20181125122609022",
"modified": "20181125122609022",
"title": "$:/plugins/telmiger/WMR/about",
"text": "!!! About the Wikitext Markup Reference \n\nExamples are copied from or inspired by\n\n* [[Tobi Beer's Markup Reference|http://tobibeer.github.io/tb5/#Markup%20Reference]]\n** try the [[searchable version|http://tobibeer.github.io/tb5/#Markup]] too!\n\nA great idea found via [[Greg Davis' Begin plugin|http://gdplugins.tiddlyspot.com/#%24%3A%2Fplugins%2Fgdavis%2Ftwbegin]].",
"tags": ""
},
"CircleJack.svg": {
"text": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"256\" height=\"256\" viewBox=\"0 0 256 256\"><circle cx=\"128\" cy=\"128\" r=\"128\"/><path fill=\"#FFF\" d=\"M181.035 228.486c-9.88 0-14.08-.336-19.035-8.486 0 0-6.002.148-9 0-5.014-.193-6-4.928-6-8 0-8.04 3.104-16.455 3-25-.035-3.04-4.467-14.16-6-18-4.81.906-9.5 2-18 2s-19.914-2.254-31-4c-2.16 8.926-8.31 21.928-3 31 6.442 9.383 10.992 11.436 18 12s8.695 8.174 7 11c-2.125 3.375-4.883 3-9 3s-8.858-1.53-12-3c-5.25-2.932-7.973-6.625-12-11 .938 1.748-.3 4.807-2 6-3.47 2.434-13.328 2.62-17 1-5.358-2.383-19-19.477-21-32 5.325-10.074 13.074-18.03 17-29-8.556-5.46-13.674-16.99-11.993-25.143.89-4.324 1.993-6.84-3.007-9.857-22.066-10.832-18.714-46.676-11-65 6.706-15.934 22.39-23.95 31-16 7.623 7.04 7.375 13 4 13-3.376 0-5.01-6.266-8-8-8.052-4.676-16.65 6.92-20 17-4.586 13.797-8.236 47.324 14 48 4.284-.146 6.647-.51 10-2 5.48-2.434 13.572-3.895 18-4 15.02-.48 33.03 5.746 42 6 8.967.252 21.168-2.508 29-2 5.68.26 11.518 1.54 17 3 3.55-17.297 3.586-30.05 12-33 4.936.78 9.184 7.406 12 11 5.746-.23 10.574 1.387 16 3 9.824-1.395 18.324-6.707 27-11-8.79 7.18-10.004 18.2-9 29 .373 5.605-1.045 12.26-3 18-3.664 9.352-10.79 19.504-19 19-3.105-.1-5.693-2.123-8-4-.447 3.8-2.303 7.637-4 11-3.914 7.453-13.527 10.04-23 18s2.97 36.82 6 42c3.033 5.18 11.195 6.176 9 11-.71 2.1-2.812 3.486-6.965 3.486zm-109.03-23.59c2.187.862 6.98.556 8.995 1.104-3.707-3.51-8.977-8.752-13-12-1.32-3.93-1-12-1-12-1.584 3.215-3.918 6.62-5 10-1.137 3.71 5.34 11.053 10.006 12.895z\"/></svg>",
"type": "image/svg+xml",
"title": "CircleJack.svg",
"tags": "picture",
"modifier": "Thomas Elmiger",
"modified": "20170918220236294",
"creator": "Thomas Elmiger",
"created": "20170918060138058"
},
"$:/plugins/telmiger/WMR/icon": {
"created": "20181125123109958",
"text": "{{CircleJack.svg}}",
"title": "$:/plugins/telmiger/WMR/icon",
"tags": "$:/tags/Macro",
"modified": "20181125123135913"
},
"$:/plugins/telmiger/WMR/bar": {
"created": "20181129205651711",
"creator": "Thomas",
"text": "He ordered another beer.",
"title": "$:/plugins/telmiger/WMR/bar",
"tags": "Bar",
"modifier": "Thomas Elmiger",
"modified": "20181130195238270",
"caption": "Bar"
},
"$:/plugins/telmiger/WMR/code": {
"created": "20181124200421812",
"creator": "Thomas",
"text": "<<wt \"Display `code` via backticks.\">> \n\nUse double backticks ... <<wt \"``for `embedded` backticks`` in code.\">>\n\nFor longer code use a [[code block|https://tiddlywiki.com/#Code%20Blocks%20in%20WikiText]]:\n\n<div class=\"wmr-input\">\n<pre>```\nmonospaced\ncodeblock\n```</pre>\n</div>\n\n```\nmonospaced\ncodeblock\n```",
"title": "$:/plugins/telmiger/WMR/code",
"tags": "ShortReference",
"modifier": "Thomas",
"modified": "20181129172414626"
},
"$:/plugins/telmiger/WMR/filters": {
"created": "20181128065322406",
"creator": "Thomas",
"title": "$:/plugins/telmiger/WMR/filters",
"modified": "20181130200642067",
"modifier": "Thomas Elmiger",
"tags": "ShortReference",
"text": "\n!!! Display the result of a filter expression\n\nUse [[filter operators|https://tiddlywiki.com/#Filter%20Operators]] like `tag` to select tiddlers.\n\nList tiddlers tagged `Foo`:\n\n<<wt \"{{{ [tag[Foo]] }}}\n\">>\n\nList tiddlers tagged `Foo` OR `Bar`:\n\n<<wt \"{{{ [tag[Foo]][tag[Bar]] }}}\n\">>\n\nList tiddlers tagged `Foo` AND `Bar`:\n\n<<wt \"{{{ [tag[Foo]] +[tag[Bar]] }}}\n\">>\n\nList tiddlers tagged `Foo` NOT `Bar`:\n\n<<wt \"{{{ [tag[Foo]] -[tag[Bar]] }}}\n\">>\n\n---\n\n!!! Limit results\n\n<<wt \"{{{ [tag[Foo]limit[1]] }}}\n\">>\n\n---\n\n!!! Sorting\n\nSort titles:\n\n<<wt \"{{{ [tag[Foo]][tag[Bar]] +[sort[]] }}}\n\">>\n\nSort reverse:\n\n<<wt \"{{{ [tag[Foo]][tag[Bar]] +[!sort[]] }}}\n\">>\n\nSort numbers:\n\n<<wt \"{{{ [[1]][[10]][[2]][[3]] +[nsort[]] }}}\n\">>\n\nFirst created:\n\n<<wt \"{{{ [tag[Foo]][tag[Bar]] +[sort[created]] }}}\n\">>\n\nLast modified:\n\n<<wt \"{{{ [tag[Foo]][tag[Bar]] +[!sort[modified]] }}}\n\">>\n\n---\n\n!!! Special effects\n\n!!!! If empty ... aka Else ~\n\nSince TW version 5.1.18\n\n<<wt \"{{{ [tag[foo]] ~[[no foo]] }}}\n\">>\n\n!!!! Range\n\n<<wt \"{{{ [range[3,1,0.5]] }}}\n\">>\n\nSee https://tiddlywiki.com/#range%20Operator",
"wmr-source-link": "https://tiddlywiki.com/#Filter%20Expression"
},
"$:/plugins/telmiger/WMR/font-variants": {
"created": "20181124191306552",
"creator": "Thomas",
"text": "<<wt \"Normal text: We don’t serve their kind here! What? Your droids. They’ll have to wait outside. We don’t want them here. Listen, why don’t you wait out by the speeder. We don’t want any trouble. I heartily agree with you sir. Negola dewaghi wooldugger?!? He doesn’t like you. I’m sorry.\">>\n\n<<wt \"''bold'' \">>\n\n\n<<wt //italics//>>\n\n\n<<wt \"''//bold italics//'' \">>\n\n\n<<wt __underline__>>\n\n\n<<wt ~~strikethrough~~>>\n\n\n<<wt super^^script^^>>\n\n\n<<wt sub,,script,,>>\n\n\n<<wt \"! Heading 1\n\n!! Heading 2\n\n!!! Heading 3\n\n!!!! Heading 4\n\n!!!!! Heading 5\n\n!!!!!! Heading 6\n\">>",
"title": "$:/plugins/telmiger/WMR/font-variants",
"tags": "ShortReference",
"modified": "20181128063401100",
"modifier": "Thomas"
},
"$:/plugins/telmiger/WMR/foo": {
"created": "20181127222534567",
"creator": "Thomas",
"text": "A man went into a ''bar''.\n\nHe ordered a beer.",
"title": "$:/plugins/telmiger/WMR/foo",
"tags": "Foo Dummy",
"modifier": "Thomas Elmiger",
"modified": "20181130210029401",
"caption": "Foo",
"wmr-example": "54rem"
},
"$:/plugins/telmiger/WMR/foo-bar": {
"created": "20181130170447615",
"creator": "Thomas Elmiger",
"text": "Dummy text",
"title": "$:/plugins/telmiger/WMR/foo-bar",
"tags": "Bar Foo Dummy",
"modifier": "Thomas Elmiger",
"modified": "20181130193831647",
"caption": "Foo Bar"
},
"$:/plugins/telmiger/WMR/html": {
"created": "20181124205849430",
"creator": "Thomas",
"text": "<div class=\"wmr-input\">\n\n```\n<article class=\"hello\">\nHTML tags work like that.\n<!-- even comments -->\n</article>\n```\n</div>\n\n<article class=\"hello\">\nHTML tags work like that.\n<!-- even comments -->\n</article>\n\n\n<div class=\"wmr-input\">\n\n```\n<a href={{TiddlerWithURL}}>link</a>\n<b class=<<getClass>>>bold</b>\n```\n</div>\n\n<a href={{TiddlerWithURL}}>link</a>\n<b class=<<version>>>bold</b>\n\nset attributes via transclusion or macro\n\n\n<div class=\"wmr-input\">\n\n```\n<div address=\"\"\"attribute,\n\"quoted\",\nwith,\nlinebreaks.\"\"\">inspect me!</div>\n```\n</div>\n\n<div address=\"\"\"attribute,\n\"quoted\",\nwith,\nlinebreaks.\"\"\">inspect me!</div>\n\n\n<div class=\"wmr-input\">\n\n```\n* nest<div>\n\n; via\n: html\n</div>\n```\n</div>\n\n*nest <div>\n\n;via\n:html\n</div>\n",
"title": "$:/plugins/telmiger/WMR/html",
"tags": "ShortReference",
"modified": "20181128063415521",
"modifier": "Thomas"
},
"$:/plugins/telmiger/WMR/images": {
"created": "20181124203347203",
"creator": "Thomas",
"text": "!!! Internal images\n\nImages saved in the wiki:\n\n<<wt \"\"\"[img width=128 [CircleJack.svg]]\n[img width=64 [title/tooltip|CircleJack.svg]]\n[img width=32 [CircleJack.svg]]\n[img width=32 class=\"red\" [CircleJack.svg]]\n\"\"\">>\n\n\n!!! Images from the web\n\n<<wt \"\"\"[img[https://tiddlywiki.com/favicon.ico]]\n\"\"\">>\n\n\n!!! Images in separate files\n\n<<wt \"\"\"[img[path/image.jpg]]\n\"\"\">>\n\nSolutions can be found in the user group ...\n",
"title": "$:/plugins/telmiger/WMR/images",
"tags": "ShortReference",
"modified": "20181201150622535",
"wmr-source-link": "https://tiddlywiki.com/#Images%20in%20WikiText",
"modifier": "Thomas Elmiger"
},
"$:/plugins/telmiger/WMR/links": {
"created": "20181124191601375",
"creator": "Thomas",
"text": "!!! Internal Wiki Links\n\n<<wt \"[[Wikitext Markup Reference]]\n\n[[Missing Tiddler]] – italic\n\n$:/AdvancedSearch\n\n[[shadow tiddler|$:/AdvancedSearch]] – bold\n\">>\n\n\n<<wt \"CamelCaseLink\n\n~SuppressedLink\n\">>\n\n\n!!! External Links\n\n<<wt \"https://tiddlywiki.com\n\n[[web link|https://tiddlywiki.com]]\n\n~https://not.alink.com\n\">>\n\n\n!!! File Links\n\nLinks to local/external files: see [[tiddlywiki.com|https://tiddlywiki.com/#Linking%20in%20WikiText]]\n",
"wmr-source-link": "https://tiddlywiki.com/#Linking%20in%20WikiText",
"title": "$:/plugins/telmiger/WMR/links",
"tags": "ShortReference",
"modifier": "Thomas",
"modified": "20181129172442346"
},
"$:/plugins/telmiger/WMR/lists": {
"created": "20181124191350660",
"creator": "Thomas",
"text": "!! Wikitext lists\n\n!!! Unordered list\n\n<<wt \"* list item\n** list in list\n*** list in list in list\n\">>\n\n!!! Ordered list\n\n<<wt \"# list item\n#* list in list\n#** list in list in list\n# list item\n## numbered list in list\n\">>\n\n!!! [[Definition list|https://tiddlywiki.com/#Definitions%20in%20WikiText]]\n\n<<wt \"; term\n: definition of the term\n\">>\n\n---\n\n!! [[List widget|https://tiddlywiki.com/prerelease/#ListWidget]]\n\n<<wt \"\"\"<$list filter=\"[tag[Foo]sort[title]]\"/>\n\"\"\">>\n\n<<wt \"{{{ [tag[Foo]!sort[title]] }}}\"\n\"\"\">>\n\n\n!!! List format\n\n```\n<ul>\n<$list filter=\"[tag[Foo]sort[title]]\">\n<li><<currentTiddler>></li>\n</$list>\n</ul>\n```\n\n<ul>\n<$list filter=\"[tag[Foo]sort[title]]\">\n<li><<currentTiddler>></li>\n</$list>\n</ul>\n\n!!! Store list item in variable\n\nBy default, the title of the list item is stored in the Current Tiddler variable:\n\n\n```\n<$list filter=\"[tag[Bar]]\">\n<<currentTiddler>>\n{{||$:/core/ui/ViewTemplate/tags}}\n</$list>\n```\n\n<$list filter=\"[tag[Bar]]\">\n<<currentTiddler>>\n{{||$:/core/ui/ViewTemplate/tags}}\n</$list>\n\n\nWhen we store the title in our own variable, the Current Tiddler remains unchanged. In the following example, the tags of the displaying tiddler will be shown:\n\n```\n<$list filter=\"[tag[Bar]]\" variable=\"tiddler\">\n<<tiddler>>\n{{||$:/core/ui/ViewTemplate/tags}}\n</$list>\n```\n\n<$list filter=\"[tag[Bar]]\" variable=\"tiddler\">\n<<tiddler>>\n{{||$:/core/ui/ViewTemplate/tags}}\n</$list>\n\n!!! Empty message\n\n\n```\n<$list filter=\"[tag[foo]limit[1]]\" emptyMessage=\"No `foo` tagged tiddlers available.\">\n`foo` tagged tiddlers exist\n</$list>\n\n```\n\n<$list filter=\"[tag[foo]limit[1]]\" emptyMessage=\"No `foo` tagged tiddlers available.\">\n`foo` tagged tiddlers exist\n</$list>\n\n```\n<$list filter=\"[tag[Foo]limit[1]]\" emptyMessage=\"no `Foo` tagged tiddlers available\">\n`Foo` tagged tiddlers exist.\n</$list>\n```\n\n<$list filter=\"[tag[Foo]limit[1]]\" emptyMessage=\"no `Foo` tagged tiddlers available\">\n`Foo` tagged tiddlers exist.\n</$list>\n",
"title": "$:/plugins/telmiger/WMR/lists",
"tags": "ShortReference",
"modifier": "Thomas Elmiger",
"modified": "20181129231942492"
},
"$:/plugins/telmiger/WMR/macros": {
"created": "20181124210017691",
"creator": "Thomas",
"text": "<div class=\"wikitext-examples\">\n\n<div class=\"wmr-input\">\n\n```\n\\define run(foo:'bar') [[$foo$]]\n\n<<run \"foo bar\">>\n```\n</div>\n\n» defines macro `run`<br>\n» with parameter `foo`<br>\n» whose value defaults to `bar`<br>\n» outputs a link to value of param:<br>\n [[foo bar]]\n\n<div class=\"wmr-input\">\n\n```\n\\define test()\nI am $(x)$.\n\\end\n\n<$set name=\"x\" value=\"y\nof z\">\n<<test>>\n</$set>\n```\n</div>\n\n» defines macro test which<br>\n» outputs value of variable x<br><br>\n\n» sets variable x to: \"y<br>\n of z\" //(multiline allowed)//<br>\n» runs macro test which outputs:<br>\n \"I am y of z.\"\n\n<div class=\"wmr-input\">\n\n```\n\\define test(x, y, z:'0')\n$x$ $y$ $z$\n\\end\n\n<$macrocall\n$name=\"test\"\nx=<<version>>\ny={{!!title}}/>\n```\n</div>\n\n» defines macro test<br>\n» outputs 3 params<br><br>\n\n» calls test via macrocall widget<br>\n» using macro version as param x<br>\n» and transclusion as param y<br><br>\n\n» output: <<version>> {{!!title}} 0\n\n</div>",
"title": "$:/plugins/telmiger/WMR/macros",
"tags": "ShortReference",
"modified": "20181128065443126",
"modifier": "Thomas"
},
"$:/plugins/telmiger/WMR/new-lines": {
"created": "20181124200219330",
"creator": "Thomas",
"text": "<<wt \"Since\nnew paragraphs\nneed two linebreaks in TW5 ...\n\nYou can also use:\n\">>\n\n<div class=\"wmr-input\">\n\n```\n\"\"\"\ntripple quotes to \nforce hard linebreaks\nlike this.\n\"\"\"\n```\n</div>\n\n\"\"\"\ntripple quotes to \nforce hard linebreaks\nlike this.\n\"\"\"\n\n<<wt \"HTML tags: <br>\nas well as <br/> are accepted\n\">>\n\nBoth result in a `<br>` when rendered.\n",
"title": "$:/plugins/telmiger/WMR/new-lines",
"tags": "ShortReference",
"modifier": "Thomas",
"modified": "20181128063152165"
},
"$:/plugins/telmiger/WMR/quotes": {
"created": "20181129204618410",
"creator": "Thomas",
"text": "!!! [[Quotes and citations|https://tiddlywiki.com/#Block%20Quotes%20in%20WikiText]]\n\n<<wt \"<<<\nWe are the ones we have been waiting for. \n<<< Hopi wisdom\n\">>\n\n<<wt \"<<<.tc-big-quote\nWe are the ones we have been waiting for. \n<<< Hopi wisdom\n\">>\n",
"title": "$:/plugins/telmiger/WMR/quotes",
"tags": "ShortReference",
"modifier": "Thomas",
"modified": "20181129204700838"
},
"$:/plugins/telmiger/WMR/reference": {
"created": "20181125111047842",
"creator": "Thomas",
"text": "<div class=\"wikitext-examples\">\n\n!! Font Variants\n\n<<revealstate \"$:/plugins/telmiger/WMR/font-variants\" \"font-variants\">>\n\n\n!! Lists, Definitions\n\n<<revealstate \"$:/plugins/telmiger/WMR/lists\" \"lists\">>\n\n\n!! Links\n\n<<revealstate \"$:/plugins/telmiger/WMR/links\" \"links\">>\n\n\n!! Special Characters, Lines, Ruler\n\n<<revealstate \"$:/plugins/telmiger/WMR/special-chars\" \"special-chars\">>\n\n\n!! New Lines\n\n<<revealstate \"$:/plugins/telmiger/WMR/new-lines\" \"new-lines\">>\n\n\n!! Quotes\n\n<<revealstate \"$:/plugins/telmiger/WMR/quotes\" \"quotes\">>\n\n\n!! Styles\n\n<<revealstate \"$:/plugins/telmiger/WMR/styles\" \"styles\">>\n\n\n!! Images\n\n<<revealstate \"$:/plugins/telmiger/WMR/images\" \"images\">>\n\n\n!! Tables\n\n<<revealstate \"$:/plugins/telmiger/WMR/tables\" \"tables\">>\n\n\n!! Code\n\n<<revealstate \"$:/plugins/telmiger/WMR/code\" \"code\">>\n\n\n!! Plain HTML\n\n<<revealstate \"$:/plugins/telmiger/WMR/html\" \"html\">>\n\n\n!! Transclusion\n\n<<revealstate \"$:/plugins/telmiger/WMR/transclusion\" \"transclusion\">>\n\n\n!! Tabs\n\n<<revealstate \"$:/plugins/telmiger/WMR/tabs\" \"tabs\">>\n\n\n!! Special Cases\n\n<<revealstate \"$:/plugins/telmiger/WMR/special\" \"special\">>\n\n\n!! Variables\n\n<<revealstate \"$:/plugins/telmiger/WMR/variables\" \"variables\">>\n\n\n!! Macros\n\n<<revealstate \"$:/plugins/telmiger/WMR/macros\" \"macros\">>\n\n\n!! Filters\n\n<<revealstate \"$:/plugins/telmiger/WMR/filters\" \"filters\">>\n\n\n!! Templates\n\n<<revealstate \"$:/plugins/telmiger/WMR/templates\" \"templates\">>\n\n\n!! Typed Elements\n\n<<revealstate \"$:/plugins/telmiger/WMR/typed-elements\" \"typed-elements\">>\n\n</div>\n",
"title": "$:/plugins/telmiger/WMR/reference",
"tags": "ShortReference",
"modified": "20181130210006750",
"modifier": "Thomas Elmiger"
},
"$:/plugins/telmiger/WMR/special": {
"created": "20181124200507179",
"creator": "Thomas",
"text": "<div class=\"wmr-input\">\n\n```\n> block\n>> quotes\n>>> are easy\n```\n</div>\n\n> block\n>> quotes\n>>> are <br>easy\n\n\n<<wt \"# mixed\n#* lists\n#; you\n#: know\n#> like so\n\">>\n",
"title": "$:/plugins/telmiger/WMR/special",
"tags": "ShortReference",
"modified": "20181128065512504",
"modifier": "Thomas"
},
"$:/plugins/telmiger/WMR/special-chars": {
"created": "20181124191754197",
"creator": "Thomas",
"text": "<<wt \"Dashes come in two sizes---the longer is the em dash (HTML: —).\n\nThe en dash (HTML: –) is for ranges (2000--2018) and connections (London--New York) \n\">>\n\n<<wt \"---\nhorizontal rules: line with `---` only or HTML:\n<hr>\n\">>\n\n\n<<wt \"2 × 5 m = 10 m\n\næ – å – œ – ø – Æ – Å – Œ – Ø\n\">>\n\n<<wt \"* a non breaking space: entity\n* a narrow no-break space: (no entity available)\n* a en space: entity\n* a em space: entity\n* a 3-per-em space: entity\n* a 4-per-em space: entity\n* a 6-per-em space: (no entity available)\n* a figure space entity\n* a punctuation space: entity\n* a thin space: entity\n* a hair space: entity\n\">>\n\n[[More Unicode characters and HTML entities|https://www.key-shortcut.com/en/character-tables/unicode-2000-2fff/]]",
"title": "$:/plugins/telmiger/WMR/special-chars",
"tags": "ShortReference",
"modified": "20181128065614974",
"modifier": "Thomas"
},
"$:/plugins/telmiger/WMR/styles": {
"created": "20181124200539896",
"creator": "Thomas",
"text": "<<wt \"!.red CSS\n#.red classes can be\n;.red assigned\n:.red like\n>.red this\n\">>\n\n\n<<wt \"@@.myClass.red\nassign classes using double @\n@@\n\">>\n\n\n<<wt \"@@color:darkorange; apply styles directly @@\n\">>\n\n\n<<wt \"@@.red\n@@border:1px solid blue;\ncombine classes and styles \n@@\n\">>\n\n\n<<wt \"@@.purple Use style tags. @@ – Is it purple?\n\n<style>\n.purple{color:purple;}\n</style>\n\">>",
"title": "$:/plugins/telmiger/WMR/styles",
"tags": "ShortReference",
"modified": "20181128065714950",
"wmr-source-link": "https://tiddlywiki.com/#How%20to%20apply%20custom%20styles",
"modifier": "Thomas"
},
"$:/plugins/telmiger/WMR/tables": {
"created": "20181124205512397",
"creator": "Thomas",
"text": "!!! Positioning\n\n<<wt \"\"\"| highClass |k\n|!Left | !Center | !Right|\n|^NW |^ N |^ NE|\n|W | ✦ | E|\n|,SW |, S |, SE|\n\"\"\">>\n\n!!! Cells\n\n<<wt \"\"\"|!merge cells|<|<|\n| 1 | 2 | 3 |\n|to the |< left |<|\n|and|also| vertical <br>~ (up) |\n|>| right >|~|\n\n\"\"\">>\n\n!!! Header, Footer, Caption, Style\n<<wt \"\"\"|!header 1 |!header 2|\n| Footer |<|f\n| cell 1 | cell 2 |\n|This is a caption |c\n| red |k\n\"\"\">>\n\n<style>\n.highClass td {\n height: 2.75rem;\n min-width: 3.75rem; \n}\n</style>",
"title": "$:/plugins/telmiger/WMR/tables",
"tags": "ShortReference",
"modified": "20181128063215976",
"modifier": "Thomas"
},
"$:/plugins/telmiger/WMR/tabs": {
"created": "20181130193703180",
"creator": "Thomas Elmiger",
"text": "!!! Filter tiddlers for tabs\n\n<$macrocall $name=\"wt\" wikitext=\"\"\"<<tabs \"[tag[Foo]][tag[Bar]]\" default:\"$:/plugins/telmiger/WMR/foo\">>\"\"\"/>\n\n\n\n!!! Vertical tabs\n\n<$macrocall $name=\"wt\" wikitext=\"\"\"<<tabs \"[tag[Foo]][tag[Bar]]\" \"$:/plugins/telmiger/WMR/foo\" class:\"tc-vertical\">>\"\"\"/>",
"title": "$:/plugins/telmiger/WMR/tabs",
"modified": "20181130195012073",
"modifier": "Thomas Elmiger",
"tags": "ShortReference",
"wmr-source-link": "https://tiddlywiki.com/#tabs%20Macro"
},
"$:/plugins/telmiger/WMR/templates": {
"created": "20181129173332986",
"creator": "Thomas",
"text": "[[Transclude|https://tiddlywiki.com/#Transclusion%20in%20WikiText]] tiddler `.../foo` applying [[template|https://tiddlywiki.com/#TemplateTiddlers]] `.../tmpl-code`:\n\n<<wt \"{{$:/plugins/telmiger/WMR/foo||$:/plugins/telmiger/WMR/tmpl-code}}\">>\n\nUse template `Bar` for the [[Current Tiddler|https://tiddlywiki.com/#Current%20Tiddler]] (default):\n\n<div class=\"wmr-input\">\n\n```\n{{||Bar}}\n```\n</div>\n\n---\n\nA template can show different fields of a tiddler. While the list of tiddlers tagged `Foo` shows the content of the field `title` ...\n\n<<wt \"{{{ [tag[Foo]] }}}\n\">>\n\n... the same for tag `Bar` displayed through the template $:/core/ui/ViewTemplate/subtitle shows the content of the fields `modifier` and `modified`:\n\n<<wt \"{{{ [tag[Bar]]||$:/core/ui/ViewTemplate/subtitle }}}\n\">>",
"title": "$:/plugins/telmiger/WMR/templates",
"modified": "20181201142137043",
"modifier": "Thomas Elmiger",
"tags": "ShortReference",
"wmr-source-link": "https://tiddlywiki.com/#Transclusion%20with%20Templates"
},
"$:/plugins/telmiger/WMR/tmpl-code": {
"created": "20181130195051148",
"creator": "Thomas Elmiger",
"text": "<pre><code>{{!!text}}</code></pre>",
"title": "$:/plugins/telmiger/WMR/tmpl-code",
"modifier": "Thomas Elmiger",
"modified": "20181130195148774",
"caption": "Bar"
},
"$:/plugins/telmiger/WMR/transclusion": {
"created": "20181124205928499",
"creator": "Thomas",
"text": "!!! Display content from other tiddlers\n\nTransclude [[text|$:/plugins/telmiger/WMR/foo]] and [[images|$:/core/images/home-button]] from the main content (text field): \n\n<<wt \"{{$:/plugins/telmiger/WMR/foo}}\">>\n\n<<wt \"{{$:/core/images/home-button}}\">>\n\n\n!!! Content of tiddler fields\n\n<div class=\"wmr-input\">\n\n```\n{{Foo!!bar}}\n{{!!bar}}\n```\n</div>\n\n* field `bar` of tiddler `Foo`\n* field `bar` of the Current Tiddler\n\n!!! Data tiddler entries\n\n<div class=\"wmr-input\">\n\n```\n{{Foo##index}}\n{{##index}}\n```\n</div>\n\n* `index` of [[datatiddler|https://tiddlywiki.com/#DataTiddlers]] titled `Foo`\n* `index` of `CurrentTiddler`\n\n---\n\n!!! Transclude widget\n\nTry the [[transclude widget|https://tiddlywiki.com/#TranscludeWidget]] if you have to set the parsing mode manually.\n\n<<wt 'Story: <$transclude tiddler=\"$:/plugins/telmiger/WMR/foo\" mode=\"block\"/>'>>\n\n<<wt 'Story: <$transclude tiddler=\"$:/plugins/telmiger/WMR/foo\" mode=\"inline\"/>'>>",
"title": "$:/plugins/telmiger/WMR/transclusion",
"tags": "ShortReference",
"modifier": "Thomas Elmiger",
"modified": "20181130201019473",
"wmr-source-link": "http://tiddlywiki.com/#Transclusion%20in%20WikiText"
},
"$:/plugins/telmiger/WMR/typed-elements": {
"created": "20181124210140010",
"creator": "Thomas",
"text": "<div class=\"wmr-input\">\n\n```\n$$$text/unknown\nplain text, not //formatted//\n$$$\n```\n</div>\n\n$$$text/unknown\nplain text, not //formatted//\n$$$\n\n<br>\nThese are [[Typed Blocks|https://tiddlywiki.com/#Typed%20Blocks%20in%20WikiText]]\n\n<div class=\"wmr-input\">\n\n```\n$$$image/svg+xml\n<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"150\" height=\"100\">\n <circle cx=\"100\" cy=\"50\" r=\"40\" stroke-width=\"0\" fill=\"green\" />\n</svg>\n$$$\n```\n</div>\n\n\n$$$image/svg+xml\n<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"150\" height=\"100\">\n <circle cx=\"100\" cy=\"50\" r=\"40\" stroke-width=\"0\" fill=\"green\" />\n</svg>\n$$$\n\n<div class=\"wmr-input\">\n\n```\n$$$.svg\n<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"150\" height=\"100\">\n <circle cx=\"100\" cy=\"50\" r=\"40\" stroke=\"black\" stroke-width=\"2\" fill=\"blue\" />\n</svg>\n$$$\n```\n</div>\n\n\n$$$.svg\n<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"150\" height=\"100\">\n <circle cx=\"100\" cy=\"50\" r=\"40\" stroke=\"black\" stroke-width=\"2\" fill=\"blue\" />\n</svg>\n$$$\n\n\n<div class=\"wmr-input\">\n\n```\n$$$text/vnd.tiddlywiki>text/html\nThis is ''some'' wikitext\n$$$\n```\n</div>\n\n$$$text/vnd.tiddlywiki>text/html\nThis is ''some'' wikitext\n$$$\n\n<div class=\"wmr-input\">\n\n```\n$$$text/vnd.tiddlywiki>text/plain\nThis is ''some'' wikitext\n$$$\n```\n</div>\n\n$$$text/vnd.tiddlywiki>text/plain\nThis is ''some'' wikitext\n$$$\n",
"title": "$:/plugins/telmiger/WMR/typed-elements",
"tags": "ShortReference",
"modified": "20181201143104715",
"modifier": "Thomas Elmiger"
},
"$:/plugins/telmiger/WMR/variables": {
"created": "20181128064053957",
"creator": "Thomas",
"title": "$:/plugins/telmiger/WMR/variables",
"modified": "20181130211541726",
"modifier": "Thomas Elmiger",
"text": "\\define animal1() lion\n\\define animals1()\nseal <br>\npenguin\n\\end\n\n\n!!! Set the value of a variable\n\nTo use a local variable in a single tiddler, insert a definition at the very top of the tiddler:\n\n`\\define animal1() lion`\n\nTo use a variable in a limited part of a tiddler, use the [[set widget|https://tiddlywiki.com/#SetWidget]]: \n\n<$macrocall $name=\"wt\" wikitext=\"\"\"<$set name=\"animal2\" value=\"zebra\">\n<<animal1>> eats <<animal2>>\n</$set>\n\"\"\"/>\n\n!!! Multi-line variables\n\n```\n\\define animals1()\nseal <br>\npenguin\n\\end\n\n<<animals1>>\n```\n\n<<animals1>>\n\n<$macrocall $name=\"wt\" wikitext=\"\"\"<$set name=\"animals2\" value=\"\n* zebra\n* gnu\n* antelope\n\">\n\n<<animals2>>\n</$set>\n\"\"\"/>\n\n\n!!! Variables as parameters\n\n<$tiddler tiddler=\"$:/plugins/telmiger/WMR/foo\">\n\n<$macrocall $name=\"wt\" wikitext=\"\"\"<$set name=\"mywidth\" value={{!!wmr-example}}>\n[img width=<<mywidth>> [CircleJack.svg]]\n</$set>\n\"\"\"/>\n\n</$tiddler>\n\n!!!! Change the value\n\n<$macrocall $name=\"wt\" wikitext=\"\"\"<$edit-text tiddler=\"$:/plugins/telmiger/WMR/foo\" field=\"wmr-example\"/>\n\"\"\"/>\n\nHint: We also use the [[tiddler widget|https://tiddlywiki.com/#TiddlerWidget]] above to set $:/plugins/telmiger/WMR/foo as the current tiddler in the context of the image. This makes sure that the [[text reference|https://tiddlywiki.com/#TextReference]] `!!wmr-example` points to the right field.\n\nThe edit text widget should ''not'' be used to edit a field of the tiddler that contains it to ommit unwanted side effects. ",
"tags": "ShortReference"
}
}
}
{
"tiddlers": {
"$:/plugins/telmiger/x-tag/readme": {
"created": "20190105133632079",
"creator": "Thomas Elmiger",
"text": "!! Tags with Superpowers: x-tag\n\nUse the contents of a field to label your tags.\n\n<label>Default field name: <$edit-text tiddler=\"$:/plugins/telmiger/x-tag/settings\" index=\"default-label\" size=\"20\" tag=\"input\"/></label> – `caption` might be a good choice to start. (The field //title// is used if this is left empty.)\n\n\n!!! Usage\n\nDefault label: `<<x-tag \"Tag\">>`\n\nDifferent label: `<<x-tag \"Tag\" label:\"field-name\">>`\n\n\n!!! Styling\n\nExample (label: //caption//) <<x-tag \"$:/tags/SideBar\" \"caption\">> vs. the normal tag macro <<tag \"$:/tags/SideBar\">>\n\n<$checkbox tiddler=\"$:/plugins/telmiger/x-tag/styles.css\" tag=\"$:/tags/Stylesheet\"> activate special styling for x-tags</$checkbox> via $:/plugins/telmiger/x-tag/styles.css\n\n\n!!! Display on tiddlers\n\nActivate desired tag types here:\n\n<$checkbox tiddler=\"$:/plugins/telmiger/x-tag/ui/ViewTemplate/tags\" tag=\"$:/tags/ViewTemplate\"> activate ''x-tag'' display</$checkbox>\n\n<$checkbox tiddler=\"$:/core/ui/ViewTemplate/tags\" tag=\"$:/tags/ViewTemplate\"> activate ''standard tag'' display </$checkbox>\n\n\n!!! Editing\n\nWould you like to see x-tags when editing tiddlers? The //x-tag picker// finds and shows tags labeled by your default field. \n\nActivate desired elements here:\n\n<$checkbox tiddler=\"$:/plugins/telmiger/x-tag/ui/EditTemplate/x-tags\" tag=\"$:/tags/EditTemplate\"> activate ''x-tag'' picker</$checkbox>\n\n<$checkbox tiddler=\"$:/core/ui/EditTemplate/tags\" tag=\"$:/tags/EditTemplate\"> activate ''standard tag'' picker</$checkbox>\n\n",
"title": "$:/plugins/telmiger/x-tag/readme",
"modifier": "Thomas Elmiger",
"modified": "20190107230031708",
"tags": "",
"caption": "x-tag Readme"
},
"$:/plugins/telmiger/x-tag/styles.css": {
"text": ".x-tag span.tc-tag-label {\n border-radius: 0 1em 1em 0;\n padding-left: 0.43em;\n}\n\n.x-tag.tc-tag-list-item {\n margin-right: 2px;\n}\n",
"title": "$:/plugins/telmiger/x-tag/styles.css",
"tags": "$:/tags/Stylesheet",
"modifier": "Thomas Elmiger",
"modified": "20190107223123542",
"creator": "Thomas Elmiger",
"created": "20190105131552219",
"caption": "x-tag Styles"
},
"$:/plugins/telmiger/x-tag/ui/EditTemplate/x-tags": {
"created": "20190105140133932",
"creator": "Thomas Elmiger",
"text": "\\whitespace trim\n\n\\define lingo-base() $:/language/EditTemplate/\n\n\\define tag-styles()\nbackground-color:$(backgroundColor)$;\nfill:$(foregroundColor)$;\ncolor:$(foregroundColor)$;\n\\end\n\n\\define x-tag-body-inner(colour,fallbackTarget,colourA,colourB,icon)\n\\whitespace trim\n<$vars foregroundColor=<<contrastcolour target:\"\"\"$colour$\"\"\" fallbackTarget:\"\"\"$fallbackTarget$\"\"\" colourA:\"\"\"$colourA$\"\"\" colourB:\"\"\"$colourB$\"\"\">> backgroundColor=\"\"\"$colour$\"\"\">\n<span style=<<tag-styles>> class=\"tc-tag-label tc-tag-list-item x-tag\">\n<$set name=\"tv-show-missing-links\" value=\"no\">\n<$transclude tiddler=\"\"\"$icon$\"\"\"/> <$transclude field=$(field)$><$view field=\"title\" format=\"text\"/></$transclude>\n</$set>\n<$button message=\"tm-remove-tag\" param={{!!title}} class=\"tc-btn-invisible tc-remove-tag-button\">×</$button>\n</span>\n</$vars>\n\\end\n\n\\define x-tag-body(colour,palette,icon)\n<$macrocall $name=\"x-tag-body-inner\" colour=\"\"\"$colour$\"\"\" fallbackTarget={{$palette$##tag-background}} colourA={{$palette$##foreground}} colourB={{$palette$##background}} icon=\"\"\"$icon$\"\"\"/>\n\\end\n\n\\define x-tag-picker-actions()\n<$action-listops\n\t$tiddler=<<currentTiddler>>\n\t$field=\"tags\"\n\t$subfilter=\"[<tag>] [all[current]tags[]]\"\n/>\n\\end\n\n<div class=\"tc-edit-tags x-tag\">\n<$fieldmangler>\n<$list filter=\"[all[current]tags[]sort[title]]\" storyview=\"pop\">\n<$macrocall $name=\"x-tag-body\" colour={{!!color}} palette={{$:/palette}} icon={{!!icon}}/>\n</$list>\n</$fieldmangler>\n<$macrocall $name=\"x-tag-picker\" actions=<<x-tag-picker-actions>>/>\n</div>\n",
"title": "$:/plugins/telmiger/x-tag/ui/EditTemplate/x-tags",
"modifier": "Thomas Elmiger",
"modified": "20190107225238748",
"list-after": "$:/core/ui/EditTemplate/title",
"caption": "x-tag Editor Template"
},
"$:/plugins/telmiger/x-tag/ui/ListItemTemplate": {
"created": "20190104063500385",
"creator": "Thomas Elmiger",
"text": "<div class=\"tc-menu-list-item\">\n<$link tooltip={{!!title}}><$set name=\"tv-show-missing-links\" value=\"no\"><$transclude field=<<field>>><$view field=\"title\"/></$transclude></$set> </$link>\n</div>",
"title": "$:/plugins/telmiger/x-tag/ui/ListItemTemplate",
"tags": "",
"modifier": "Thomas Elmiger",
"modified": "20190105101724831",
"caption": "x-tag ListItemTemplate"
},
"$:/plugins/telmiger/x-tag/ui/TagTemplate": {
"created": "20190104065201990",
"creator": "Thomas Elmiger",
"text": "\\whitespace trim\n<span class=\"tc-tag-list-item x-tag\">\n<$set name=\"transclusion\" value=<<currentTiddler>>>\n<$macrocall $name=\"x-tag-pill-body\" tag=<<currentTiddler>> icon={{!!icon}} colour={{!!color}} palette={{$:/palette}} element-tag=\"\"\"$button\"\"\" element-attributes=\"\"\"popup=<<qualify \"$:/state/popup/tag\">> dragFilter='[all[current]tagging[]]' tag='span'\"\"\"/>\n<$reveal state=<<qualify \"$:/state/popup/tag\">> type=\"popup\" position=\"below\" animate=\"yes\" class=\"tc-drop-down\">\n<$set name=\"tv-show-missing-links\" value=\"yes\">\n<$transclude tiddler=\"$:/plugins/telmiger/x-tag/ui/ListItemTemplate\"/>\n</$set>\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/TagDropdown]!has[draft.of]]\" variable=\"listItem\"> \nxxx <$transclude tiddler=<<listItem>>/> \n</$list>\n<hr>\n<$macrocall $name=\"list-tagged-draggable\" tag=<<currentTiddler>> itemTemplate=\"$:/plugins/telmiger/x-tag/ui/ListItemTemplate\"/>\n<!-- open all -->\n<hr>\n<div class=\"tc-menu-list-item\">\n<$button class=\"tc-btn-invisible\"><$list filter=\"[all[current]tagging[]reverse[]]\"><$action-navigate $to=<<currentTiddler>> /></$list>Open All</$button>\n</div>\n<!-- /open all -->\n</$reveal>\n</$set>\n</span>\n",
"title": "$:/plugins/telmiger/x-tag/ui/TagTemplate",
"tags": "",
"modifier": "Thomas Elmiger",
"modified": "20190105131850148",
"caption": "x-tag TagTemplate"
},
"$:/plugins/telmiger/x-tag/x-tag": {
"created": "20190104063037271",
"creator": "Thomas Elmiger",
"text": "\\define x-tag(tag,label:{{$:/plugins/telmiger/x-tag/settings##default-label}})\n<$vars field=$label$>\n{{$tag$||$:/plugins/telmiger/x-tag/ui/TagTemplate}}\n</$vars>\n\\end\n",
"title": "$:/plugins/telmiger/x-tag/x-tag",
"tags": "$:/tags/Macro",
"modifier": "Thomas Elmiger",
"modified": "20190105134834816",
"caption": "x-tag macro"
},
"$:/plugins/telmiger/x-tag/x-tag-picker": {
"created": "20190105140021052",
"creator": "Thomas Elmiger",
"text": "\\define x-tag-button()\n<$set name=\"field\" filter=\"[{$:/plugins/telmiger/x-tag/settings##default-label}minlength[1]] ~[[title]]\">\n<$button class=\"tc-btn-invisible\" tag=\"a\">\n$(actions)$\n<$action-deletetiddler $tiddler=\"$:/temp/NewTagName\"/>\n<$macrocall $name=\"x-tag-pill\" tag=<<tag>>/>\n</$button>\n</$set>\n\\end\n\n\\define x-tag-picker(actions)\n<$set name=\"actions\" value=\"\"\"$actions$\"\"\">\n<div class=\"tc-edit-add-tag x-tag\">\n<span class=\"tc-add-tag-name\">\n<$keyboard key=\"ENTER\" actions=<<add-tag-actions>>>\n<$edit-text tiddler=\"$:/temp/NewTagName\" tag=\"input\" default=\"\" placeholder={{$:/language/EditTemplate/Tags/Add/Placeholder}} focusPopup=<<qualify \"$:/state/popup/tags-auto-complete\">> class=\"tc-edit-texteditor tc-popup-handle x-tag\"/>\n</$keyboard>\n</span> <$button popup=<<qualify \"$:/state/popup/tags-auto-complete\">> class=\"tc-btn-invisible\" tooltip={{$:/language/EditTemplate/Tags/Dropdown/Hint}} aria-label={{$:/language/EditTemplate/Tags/Dropdown/Caption}}>{{$:/core/images/down-arrow}}</$button> <span class=\"tc-add-tag-button\">\n<$set name=\"tag\" value={{$:/temp/NewTagName}}>\n<$button set=\"$:/temp/NewTagName\" setTo=\"\" class=\"\">\n$actions$\n<$action-deletetiddler $tiddler=\"$:/temp/NewTagName\"/>\n{{$:/language/EditTemplate/Tags/Add/Button}}\n</$button>\n</$set>\n</span>\n</div>\n<div class=\"tc-block-dropdown-wrapper\">\n<$reveal state=<<qualify \"$:/state/popup/tags-auto-complete\">> type=\"nomatch\" text=\"\" default=\"\">\n<div class=\"tc-block-dropdown x-tag\">\n<$wikify name=\"x-search\" text=\"[search:{{$:/plugins/telmiger/x-tag/settings##default-label}}[{{$:/temp/NewTagName}}]]\">\n<$list filter=\"[{$:/temp/NewTagName}minlength{$:/config/Tags/MinLength}limit[1]]\" emptyMessage=\"\"\"<div class=\"tc-search-results\">{{$:/language/Search/Search/TooShort}}</div>\"\"\" variable=\"listItem\">\n<$list filter=\"[tags[]!is[system]subfilter<x-search>sort[]] [tags[]is[system]subfilter<x-search>sort[]]\" variable=\"tag\">\n<<x-tag-button>>\n</$list></$list>\n</$wikify>\n<hr>\n<$list filter=\"[{$:/temp/NewTagName}minlength{$:/config/Tags/MinLength}limit[1]]\" emptyMessage=\"\"\"<div class=\"tc-search-results\">{{$:/language/Search/Search/TooShort}}</div>\"\"\" variable=\"listItem\">\n<$list filter=\"[tags[]is[system]search:title{$:/temp/NewTagName}sort[]]\" variable=\"tag\">\n<<x-tag-button>>\n</$list></$list>\n</div>\n</$reveal>\n</div>\n</$set>\n\\end\n",
"title": "$:/plugins/telmiger/x-tag/x-tag-picker",
"tags": "$:/tags/Macro",
"modified": "20190107224608604",
"modifier": "Thomas Elmiger",
"caption": "x-tag Editor tag picker"
},
"$:/plugins/telmiger/x-tag/x-tag-pill": {
"created": "20190104065441583",
"creator": "Thomas Elmiger",
"text": "\\define x-tag-pill-inner(tag,icon,colour,fallbackTarget,colourA,colourB,element-tag,element-attributes,actions)\n<$vars foregroundColor=<<contrastcolour target:\"\"\"$colour$\"\"\" fallbackTarget:\"\"\"$fallbackTarget$\"\"\" colourA:\"\"\"$colourA$\"\"\" colourB:\"\"\"$colourB$\"\"\">> backgroundColor=\"\"\"$colour$\"\"\">\n<$element-tag$ $element-attributes$ class=\"tc-tag-label tc-btn-invisible\" style=<<tag-pill-styles>>>\n$actions$<$transclude tiddler=\"\"\"$icon$\"\"\"/> <$view tiddler=<<__tag__>> field=$(field)$ format=\"plainwikified\"><$view tiddler=<<__tag__>> field=\"title\" format=\"text\" /></$view>\n</$element-tag$>\n</$vars>\n\\end\n\n\\define x-tag-pill-body(tag,icon,colour,palette,element-tag,element-attributes,actions)\n<$macrocall $name=\"x-tag-pill-inner\" tag=<<__tag__>> icon=\"\"\"$icon$\"\"\" colour=\"\"\"$colour$\"\"\" fallbackTarget={{$palette$##tag-background}} colourA={{$palette$##foreground}} colourB={{$palette$##background}} element-tag=\"\"\"$element-tag$\"\"\" element-attributes=\"\"\"$element-attributes$\"\"\" actions=\"\"\"$actions$\"\"\"/>\n\\end\n\n\\define x-tag-pill(tag,element-tag:\"span\",element-attributes:\"\",actions:\"\")\n<span class=\"tc-tag-list-item x-tag\">\n<$macrocall $name=\"x-tag-pill-body\" tag=<<__tag__>> icon={{{ [<__tag__>get[icon]] }}} colour={{{ [<__tag__>get[color]] }}} palette={{$:/palette}} element-tag=\"\"\"$element-tag$\"\"\" element-attributes=\"\"\"$element-attributes$\"\"\" actions=\"\"\"$actions$\"\"\"/>\n</span>\n\\end",
"title": "$:/plugins/telmiger/x-tag/x-tag-pill",
"tags": "$:/tags/Macro",
"modifier": "Thomas Elmiger",
"modified": "20190105131947330",
"caption": "x-tag pill macro"
},
"$:/plugins/telmiger/x-tag/icon": {
"created": "20190105155944201",
"text": "{{$:/core/images/tag-button}}",
"title": "$:/plugins/telmiger/x-tag/icon",
"tags": "",
"modified": "20190105160035936"
},
"$:/plugins/telmiger/x-tag/settings": {
"created": "20190106093650765",
"text": "{\n \"default-label\": \"caption\"\n}",
"type": "application/json",
"title": "$:/plugins/telmiger/x-tag/settings",
"modified": "20190107220556400"
},
"$:/plugins/telmiger/x-tag/ui/ViewTemplate/tags": {
"created": "20181231143101362",
"creator": "Thomas Elmiger",
"text": "<$reveal type=\"nomatch\" stateTitle=<<folded-state>> text=\"hide\" tag=\"div\" retain=\"yes\" animate=\"yes\">\n<$set name=\"field\" filter=\"[{$:/plugins/telmiger/x-tag/settings##default-label}minlength[1]] ~[[title]]\">\n<div class=\"tc-tags-wrapper\"><$list filter=\"[all[current]tags[]sort[title]]\" template=\"$:/plugins/telmiger/x-tag/ui/TagTemplate\" storyview=\"pop\"/></div>\n</$set>\n</$reveal>\n",
"title": "$:/plugins/telmiger/x-tag/ui/ViewTemplate/tags",
"modifier": "Thomas Elmiger",
"modified": "20190107224453970",
"list-before": "$:/core/ui/ViewTemplate/body"
}
}
}
{
"default-label": "caption"
}
\whitespace trim
\define lingo-base() $:/language/EditTemplate/
\define tag-styles()
background-color:$(backgroundColor)$;
fill:$(foregroundColor)$;
color:$(foregroundColor)$;
\end
\define x-tag-body-inner(colour,fallbackTarget,colourA,colourB,icon)
\whitespace trim
<$vars foregroundColor=<<contrastcolour target:"""$colour$""" fallbackTarget:"""$fallbackTarget$""" colourA:"""$colourA$""" colourB:"""$colourB$""">> backgroundColor="""$colour$""">
<span style=<<tag-styles>> class="tc-tag-label tc-tag-list-item x-tag">
<$set name="tv-show-missing-links" value="no">
<$transclude tiddler="""$icon$"""/> <$transclude field={{$:/plugins/telmiger/x-tag/settings##default-label}}><$view field="title" format="text"/></$transclude>
</$set>
<$button message="tm-remove-tag" param={{!!title}} class="tc-btn-invisible tc-remove-tag-button">×</$button>
</span>
</$vars>
\end
\define x-tag-body(colour,palette,icon)
<$macrocall $name="x-tag-body-inner" colour="""$colour$""" fallbackTarget={{$palette$##tag-background}} colourA={{$palette$##foreground}} colourB={{$palette$##background}} icon="""$icon$"""/>
\end
\define x-tag-picker-actions()
<$action-listops
$tiddler=<<currentTiddler>>
$field="tags"
$subfilter="[<tag>] [all[current]tags[]]"
/>
\end
<div class="tc-edit-tags x-tag">
<$fieldmangler>
<$list filter="[all[current]tags[]sort[title]]" storyview="pop">
<$macrocall $name="x-tag-body" colour={{!!color}} palette={{$:/palette}} icon={{!!icon}}/>
</$list>
</$fieldmangler>
<$macrocall $name="x-tag-picker" actions=<<x-tag-picker-actions>>/>
</div>
<div class="tc-menu-list-item">
<$link tooltip={{!!title}}><$set name="tv-show-missing-links" value="no"><$transclude field=<<field>>><$view field="title"/></$transclude></$set> </$link>
</div>
{
"tiddlers": {
"$:/core/ui/Buttons/save": {
"created": "20161224130219684",
"title": "$:/core/ui/Buttons/save",
"tags": "$:/tags/EditToolbar",
"caption": "{{$:/core/images/done-button}} {{$:/language/Buttons/Save/Caption}}",
"description": "{{$:/language/Buttons/Save/Hint}}",
"text": "<$set name=test filter=\"[list[!!text]prefix{$:/_state/tesseract/hashtag2tag}] +[removeprefix{$:/_state/tesseract/hashtag2tag}]\">\n<$fieldmangler><$button tooltip={{$:/language/Buttons/Save/Hint}} aria-label={{$:/language/Buttons/Save/Caption}} class=<<tv-config-toolbar-class>>>\n<$action-sendmessage $message=\"tm-add-tag\" $param={{$:/temp/NewTagName}}/>\n<$action-listops $tags=<<test>>/>\n<$action-deletetiddler $tiddler=\"$:/temp/NewTagName\"/>\n<$action-sendmessage $message=\"tm-add-field\" $name={{$:/temp/newfieldname}} $value={{$:/temp/newfieldvalue}}/>\n<$action-deletetiddler $tiddler=\"$:/temp/newfieldname\"/>\n<$action-deletetiddler $tiddler=\"$:/temp/newfieldvalue\"/>\n<$action-sendmessage $message=\"tm-save-tiddler\"/>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/done-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/Save/Caption}}/></span>\n</$list>\n</$button>\n</$fieldmangler>\n</$set>\n",
"modified": "20161224135026842"
},
"$:/plugins/tesseract/hashtag2tag/readme": {
"created": "20161224133116441",
"text": "Adds every word that starts with a particular symbol to tag. Go to Control Panel > Appearance > Hashtag2tag and indicate which symbol you want to use to indicate a tag. For eg: \"#\". Thereafter whenever you save a tiddler, TW will scan that tiddler for words starting with # and add them as tags",
"title": "$:/plugins/tesseract/hashtag2tag/readme",
"tags": "",
"modified": "20161224140314563"
},
"$:/plugins/tesseract/hashtag2tag/settings": {
"created": "20161224133517542",
"text": "Save words starting with this symbol to tags <$edit-text tiddler=\"$:/_state/tesseract/hashtag2tag\" tag=\"input\" placeholder=\"Your symbol here\"/>",
"title": "$:/plugins/tesseract/hashtag2tag/settings",
"tags": "$:/tags/ControlPanel/Appearance",
"modified": "20161224135801232",
"caption": "Hashtag2tag"
}
}
}
/*!
* Font Awesome 4.2.0 by @davegandy - http://fontawesome.io - @fontawesome
* License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License)
*/
/* FONT PATH
* -------------------------- */
@font-face {
font-family: 'FontAwesome';
src: local("FontAwesome"), url(data:application/font-woff;base64,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) format("woff");
font-weight: normal;
font-style: normal;
}
.fa {
display: inline-block;
font: normal normal normal 14px/1 FontAwesome;
font-size: inherit;
text-rendering: auto;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
/* makes the font 33% larger relative to the icon container */
.fa-lg {
font-size: 1.33333333em;
line-height: 0.75em;
vertical-align: -15%;
}
.fa-2x {
font-size: 2em;
}
.fa-3x {
font-size: 3em;
}
.fa-4x {
font-size: 4em;
}
.fa-5x {
font-size: 5em;
}
.fa-fw {
width: 1.28571429em;
text-align: center;
}
.fa-ul {
padding-left: 0;
margin-left: 2.14285714em;
list-style-type: none;
}
.fa-ul > li {
position: relative;
}
.fa-li {
position: absolute;
left: -2.14285714em;
width: 2.14285714em;
top: 0.14285714em;
text-align: center;
}
.fa-li.fa-lg {
left: -1.85714286em;
}
.fa-border {
padding: .2em .25em .15em;
border: solid 0.08em #eeeeee;
border-radius: .1em;
}
.pull-right {
float: right;
}
.pull-left {
float: left;
}
.fa.pull-left {
margin-right: .3em;
}
.fa.pull-right {
margin-left: .3em;
}
.fa-spin {
-webkit-animation: fa-spin 2s infinite linear;
animation: fa-spin 2s infinite linear;
}
@-webkit-keyframes fa-spin {
0% {
-webkit-transform: rotate(0deg);
transform: rotate(0deg);
}
100% {
-webkit-transform: rotate(359deg);
transform: rotate(359deg);
}
}
@keyframes fa-spin {
0% {
-webkit-transform: rotate(0deg);
transform: rotate(0deg);
}
100% {
-webkit-transform: rotate(359deg);
transform: rotate(359deg);
}
}
.fa-rotate-90 {
filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=1);
-webkit-transform: rotate(90deg);
-ms-transform: rotate(90deg);
transform: rotate(90deg);
}
.fa-rotate-180 {
filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=2);
-webkit-transform: rotate(180deg);
-ms-transform: rotate(180deg);
transform: rotate(180deg);
}
.fa-rotate-270 {
filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=3);
-webkit-transform: rotate(270deg);
-ms-transform: rotate(270deg);
transform: rotate(270deg);
}
.fa-flip-horizontal {
filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1);
-webkit-transform: scale(-1, 1);
-ms-transform: scale(-1, 1);
transform: scale(-1, 1);
}
.fa-flip-vertical {
filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1);
-webkit-transform: scale(1, -1);
-ms-transform: scale(1, -1);
transform: scale(1, -1);
}
:root .fa-rotate-90,
:root .fa-rotate-180,
:root .fa-rotate-270,
:root .fa-flip-horizontal,
:root .fa-flip-vertical {
filter: none;
}
.fa-stack {
position: relative;
display: inline-block;
width: 2em;
height: 2em;
line-height: 2em;
vertical-align: middle;
}
.fa-stack-1x,
.fa-stack-2x {
position: absolute;
left: 0;
width: 100%;
text-align: center;
}
.fa-stack-1x {
line-height: inherit;
}
.fa-stack-2x {
font-size: 2em;
}
.fa-inverse {
color: #ffffff;
}
/* Font Awesome uses the Unicode Private Use Area (PUA) to ensure screen
readers do not read off random characters that represent icons */
.fa-glass:before {
content: "\f000";
}
.fa-music:before {
content: "\f001";
}
.fa-search:before {
content: "\f002";
}
.fa-envelope-o:before {
content: "\f003";
}
.fa-heart:before {
content: "\f004";
}
.fa-star:before {
content: "\f005";
}
.fa-star-o:before {
content: "\f006";
}
.fa-user:before {
content: "\f007";
}
.fa-film:before {
content: "\f008";
}
.fa-th-large:before {
content: "\f009";
}
.fa-th:before {
content: "\f00a";
}
.fa-th-list:before {
content: "\f00b";
}
.fa-check:before {
content: "\f00c";
}
.fa-remove:before,
.fa-close:before,
.fa-times:before {
content: "\f00d";
}
.fa-search-plus:before {
content: "\f00e";
}
.fa-search-minus:before {
content: "\f010";
}
.fa-power-off:before {
content: "\f011";
}
.fa-signal:before {
content: "\f012";
}
.fa-gear:before,
.fa-cog:before {
content: "\f013";
}
.fa-trash-o:before {
content: "\f014";
}
.fa-home:before {
content: "\f015";
}
.fa-file-o:before {
content: "\f016";
}
.fa-clock-o:before {
content: "\f017";
}
.fa-road:before {
content: "\f018";
}
.fa-download:before {
content: "\f019";
}
.fa-arrow-circle-o-down:before {
content: "\f01a";
}
.fa-arrow-circle-o-up:before {
content: "\f01b";
}
.fa-inbox:before {
content: "\f01c";
}
.fa-play-circle-o:before {
content: "\f01d";
}
.fa-rotate-right:before,
.fa-repeat:before {
content: "\f01e";
}
.fa-refresh:before {
content: "\f021";
}
.fa-list-alt:before {
content: "\f022";
}
.fa-lock:before {
content: "\f023";
}
.fa-flag:before {
content: "\f024";
}
.fa-headphones:before {
content: "\f025";
}
.fa-volume-off:before {
content: "\f026";
}
.fa-volume-down:before {
content: "\f027";
}
.fa-volume-up:before {
content: "\f028";
}
.fa-qrcode:before {
content: "\f029";
}
.fa-barcode:before {
content: "\f02a";
}
.fa-tag:before {
content: "\f02b";
}
.fa-tags:before {
content: "\f02c";
}
.fa-book:before {
content: "\f02d";
}
.fa-bookmark:before {
content: "\f02e";
}
.fa-print:before {
content: "\f02f";
}
.fa-camera:before {
content: "\f030";
}
.fa-font:before {
content: "\f031";
}
.fa-bold:before {
content: "\f032";
}
.fa-italic:before {
content: "\f033";
}
.fa-text-height:before {
content: "\f034";
}
.fa-text-width:before {
content: "\f035";
}
.fa-align-left:before {
content: "\f036";
}
.fa-align-center:before {
content: "\f037";
}
.fa-align-right:before {
content: "\f038";
}
.fa-align-justify:before {
content: "\f039";
}
.fa-list:before {
content: "\f03a";
}
.fa-dedent:before,
.fa-outdent:before {
content: "\f03b";
}
.fa-indent:before {
content: "\f03c";
}
.fa-video-camera:before {
content: "\f03d";
}
.fa-photo:before,
.fa-image:before,
.fa-picture-o:before {
content: "\f03e";
}
.fa-pencil:before {
content: "\f040";
}
.fa-map-marker:before {
content: "\f041";
}
.fa-adjust:before {
content: "\f042";
}
.fa-tint:before {
content: "\f043";
}
.fa-edit:before,
.fa-pencil-square-o:before {
content: "\f044";
}
.fa-share-square-o:before {
content: "\f045";
}
.fa-check-square-o:before {
content: "\f046";
}
.fa-arrows:before {
content: "\f047";
}
.fa-step-backward:before {
content: "\f048";
}
.fa-fast-backward:before {
content: "\f049";
}
.fa-backward:before {
content: "\f04a";
}
.fa-play:before {
content: "\f04b";
}
.fa-pause:before {
content: "\f04c";
}
.fa-stop:before {
content: "\f04d";
}
.fa-forward:before {
content: "\f04e";
}
.fa-fast-forward:before {
content: "\f050";
}
.fa-step-forward:before {
content: "\f051";
}
.fa-eject:before {
content: "\f052";
}
.fa-chevron-left:before {
content: "\f053";
}
.fa-chevron-right:before {
content: "\f054";
}
.fa-plus-circle:before {
content: "\f055";
}
.fa-minus-circle:before {
content: "\f056";
}
.fa-times-circle:before {
content: "\f057";
}
.fa-check-circle:before {
content: "\f058";
}
.fa-question-circle:before {
content: "\f059";
}
.fa-info-circle:before {
content: "\f05a";
}
.fa-crosshairs:before {
content: "\f05b";
}
.fa-times-circle-o:before {
content: "\f05c";
}
.fa-check-circle-o:before {
content: "\f05d";
}
.fa-ban:before {
content: "\f05e";
}
.fa-arrow-left:before {
content: "\f060";
}
.fa-arrow-right:before {
content: "\f061";
}
.fa-arrow-up:before {
content: "\f062";
}
.fa-arrow-down:before {
content: "\f063";
}
.fa-mail-forward:before,
.fa-share:before {
content: "\f064";
}
.fa-expand:before {
content: "\f065";
}
.fa-compress:before {
content: "\f066";
}
.fa-plus:before {
content: "\f067";
}
.fa-minus:before {
content: "\f068";
}
.fa-asterisk:before {
content: "\f069";
}
.fa-exclamation-circle:before {
content: "\f06a";
}
.fa-gift:before {
content: "\f06b";
}
.fa-leaf:before {
content: "\f06c";
}
.fa-fire:before {
content: "\f06d";
}
.fa-eye:before {
content: "\f06e";
}
.fa-eye-slash:before {
content: "\f070";
}
.fa-warning:before,
.fa-exclamation-triangle:before {
content: "\f071";
}
.fa-plane:before {
content: "\f072";
}
.fa-calendar:before {
content: "\f073";
}
.fa-random:before {
content: "\f074";
}
.fa-comment:before {
content: "\f075";
}
.fa-magnet:before {
content: "\f076";
}
.fa-chevron-up:before {
content: "\f077";
}
.fa-chevron-down:before {
content: "\f078";
}
.fa-retweet:before {
content: "\f079";
}
.fa-shopping-cart:before {
content: "\f07a";
}
.fa-folder:before {
content: "\f07b";
}
.fa-folder-open:before {
content: "\f07c";
}
.fa-arrows-v:before {
content: "\f07d";
}
.fa-arrows-h:before {
content: "\f07e";
}
.fa-bar-chart-o:before,
.fa-bar-chart:before {
content: "\f080";
}
.fa-twitter-square:before {
content: "\f081";
}
.fa-facebook-square:before {
content: "\f082";
}
.fa-camera-retro:before {
content: "\f083";
}
.fa-key:before {
content: "\f084";
}
.fa-gears:before,
.fa-cogs:before {
content: "\f085";
}
.fa-comments:before {
content: "\f086";
}
.fa-thumbs-o-up:before {
content: "\f087";
}
.fa-thumbs-o-down:before {
content: "\f088";
}
.fa-star-half:before {
content: "\f089";
}
.fa-heart-o:before {
content: "\f08a";
}
.fa-sign-out:before {
content: "\f08b";
}
.fa-linkedin-square:before {
content: "\f08c";
}
.fa-thumb-tack:before {
content: "\f08d";
}
.fa-external-link:before {
content: "\f08e";
}
.fa-sign-in:before {
content: "\f090";
}
.fa-trophy:before {
content: "\f091";
}
.fa-github-square:before {
content: "\f092";
}
.fa-upload:before {
content: "\f093";
}
.fa-lemon-o:before {
content: "\f094";
}
.fa-phone:before {
content: "\f095";
}
.fa-square-o:before {
content: "\f096";
}
.fa-bookmark-o:before {
content: "\f097";
}
.fa-phone-square:before {
content: "\f098";
}
.fa-twitter:before {
content: "\f099";
}
.fa-facebook:before {
content: "\f09a";
}
.fa-github:before {
content: "\f09b";
}
.fa-unlock:before {
content: "\f09c";
}
.fa-credit-card:before {
content: "\f09d";
}
.fa-rss:before {
content: "\f09e";
}
.fa-hdd-o:before {
content: "\f0a0";
}
.fa-bullhorn:before {
content: "\f0a1";
}
.fa-bell:before {
content: "\f0f3";
}
.fa-certificate:before {
content: "\f0a3";
}
.fa-hand-o-right:before {
content: "\f0a4";
}
.fa-hand-o-left:before {
content: "\f0a5";
}
.fa-hand-o-up:before {
content: "\f0a6";
}
.fa-hand-o-down:before {
content: "\f0a7";
}
.fa-arrow-circle-left:before {
content: "\f0a8";
}
.fa-arrow-circle-right:before {
content: "\f0a9";
}
.fa-arrow-circle-up:before {
content: "\f0aa";
}
.fa-arrow-circle-down:before {
content: "\f0ab";
}
.fa-globe:before {
content: "\f0ac";
}
.fa-wrench:before {
content: "\f0ad";
}
.fa-tasks:before {
content: "\f0ae";
}
.fa-filter:before {
content: "\f0b0";
}
.fa-briefcase:before {
content: "\f0b1";
}
.fa-arrows-alt:before {
content: "\f0b2";
}
.fa-group:before,
.fa-users:before {
content: "\f0c0";
}
.fa-chain:before,
.fa-link:before {
content: "\f0c1";
}
.fa-cloud:before {
content: "\f0c2";
}
.fa-flask:before {
content: "\f0c3";
}
.fa-cut:before,
.fa-scissors:before {
content: "\f0c4";
}
.fa-copy:before,
.fa-files-o:before {
content: "\f0c5";
}
.fa-paperclip:before {
content: "\f0c6";
}
.fa-save:before,
.fa-floppy-o:before {
content: "\f0c7";
}
.fa-square:before {
content: "\f0c8";
}
.fa-navicon:before,
.fa-reorder:before,
.fa-bars:before {
content: "\f0c9";
}
.fa-list-ul:before {
content: "\f0ca";
}
.fa-list-ol:before {
content: "\f0cb";
}
.fa-strikethrough:before {
content: "\f0cc";
}
.fa-underline:before {
content: "\f0cd";
}
.fa-table:before {
content: "\f0ce";
}
.fa-magic:before {
content: "\f0d0";
}
.fa-truck:before {
content: "\f0d1";
}
.fa-pinterest:before {
content: "\f0d2";
}
.fa-pinterest-square:before {
content: "\f0d3";
}
.fa-google-plus-square:before {
content: "\f0d4";
}
.fa-google-plus:before {
content: "\f0d5";
}
.fa-money:before {
content: "\f0d6";
}
.fa-caret-down:before {
content: "\f0d7";
}
.fa-caret-up:before {
content: "\f0d8";
}
.fa-caret-left:before {
content: "\f0d9";
}
.fa-caret-right:before {
content: "\f0da";
}
.fa-columns:before {
content: "\f0db";
}
.fa-unsorted:before,
.fa-sort:before {
content: "\f0dc";
}
.fa-sort-down:before,
.fa-sort-desc:before {
content: "\f0dd";
}
.fa-sort-up:before,
.fa-sort-asc:before {
content: "\f0de";
}
.fa-envelope:before {
content: "\f0e0";
}
.fa-linkedin:before {
content: "\f0e1";
}
.fa-rotate-left:before,
.fa-undo:before {
content: "\f0e2";
}
.fa-legal:before,
.fa-gavel:before {
content: "\f0e3";
}
.fa-dashboard:before,
.fa-tachometer:before {
content: "\f0e4";
}
.fa-comment-o:before {
content: "\f0e5";
}
.fa-comments-o:before {
content: "\f0e6";
}
.fa-flash:before,
.fa-bolt:before {
content: "\f0e7";
}
.fa-sitemap:before {
content: "\f0e8";
}
.fa-umbrella:before {
content: "\f0e9";
}
.fa-paste:before,
.fa-clipboard:before {
content: "\f0ea";
}
.fa-lightbulb-o:before {
content: "\f0eb";
}
.fa-exchange:before {
content: "\f0ec";
}
.fa-cloud-download:before {
content: "\f0ed";
}
.fa-cloud-upload:before {
content: "\f0ee";
}
.fa-user-md:before {
content: "\f0f0";
}
.fa-stethoscope:before {
content: "\f0f1";
}
.fa-suitcase:before {
content: "\f0f2";
}
.fa-bell-o:before {
content: "\f0a2";
}
.fa-coffee:before {
content: "\f0f4";
}
.fa-cutlery:before {
content: "\f0f5";
}
.fa-file-text-o:before {
content: "\f0f6";
}
.fa-building-o:before {
content: "\f0f7";
}
.fa-hospital-o:before {
content: "\f0f8";
}
.fa-ambulance:before {
content: "\f0f9";
}
.fa-medkit:before {
content: "\f0fa";
}
.fa-fighter-jet:before {
content: "\f0fb";
}
.fa-beer:before {
content: "\f0fc";
}
.fa-h-square:before {
content: "\f0fd";
}
.fa-plus-square:before {
content: "\f0fe";
}
.fa-angle-double-left:before {
content: "\f100";
}
.fa-angle-double-right:before {
content: "\f101";
}
.fa-angle-double-up:before {
content: "\f102";
}
.fa-angle-double-down:before {
content: "\f103";
}
.fa-angle-left:before {
content: "\f104";
}
.fa-angle-right:before {
content: "\f105";
}
.fa-angle-up:before {
content: "\f106";
}
.fa-angle-down:before {
content: "\f107";
}
.fa-desktop:before {
content: "\f108";
}
.fa-laptop:before {
content: "\f109";
}
.fa-tablet:before {
content: "\f10a";
}
.fa-mobile-phone:before,
.fa-mobile:before {
content: "\f10b";
}
.fa-circle-o:before {
content: "\f10c";
}
.fa-quote-left:before {
content: "\f10d";
}
.fa-quote-right:before {
content: "\f10e";
}
.fa-spinner:before {
content: "\f110";
}
.fa-circle:before {
content: "\f111";
}
.fa-mail-reply:before,
.fa-reply:before {
content: "\f112";
}
.fa-github-alt:before {
content: "\f113";
}
.fa-folder-o:before {
content: "\f114";
}
.fa-folder-open-o:before {
content: "\f115";
}
.fa-smile-o:before {
content: "\f118";
}
.fa-frown-o:before {
content: "\f119";
}
.fa-meh-o:before {
content: "\f11a";
}
.fa-gamepad:before {
content: "\f11b";
}
.fa-keyboard-o:before {
content: "\f11c";
}
.fa-flag-o:before {
content: "\f11d";
}
.fa-flag-checkered:before {
content: "\f11e";
}
.fa-terminal:before {
content: "\f120";
}
.fa-code:before {
content: "\f121";
}
.fa-mail-reply-all:before,
.fa-reply-all:before {
content: "\f122";
}
.fa-star-half-empty:before,
.fa-star-half-full:before,
.fa-star-half-o:before {
content: "\f123";
}
.fa-location-arrow:before {
content: "\f124";
}
.fa-crop:before {
content: "\f125";
}
.fa-code-fork:before {
content: "\f126";
}
.fa-unlink:before,
.fa-chain-broken:before {
content: "\f127";
}
.fa-question:before {
content: "\f128";
}
.fa-info:before {
content: "\f129";
}
.fa-exclamation:before {
content: "\f12a";
}
.fa-superscript:before {
content: "\f12b";
}
.fa-subscript:before {
content: "\f12c";
}
.fa-eraser:before {
content: "\f12d";
}
.fa-puzzle-piece:before {
content: "\f12e";
}
.fa-microphone:before {
content: "\f130";
}
.fa-microphone-slash:before {
content: "\f131";
}
.fa-shield:before {
content: "\f132";
}
.fa-calendar-o:before {
content: "\f133";
}
.fa-fire-extinguisher:before {
content: "\f134";
}
.fa-rocket:before {
content: "\f135";
}
.fa-maxcdn:before {
content: "\f136";
}
.fa-chevron-circle-left:before {
content: "\f137";
}
.fa-chevron-circle-right:before {
content: "\f138";
}
.fa-chevron-circle-up:before {
content: "\f139";
}
.fa-chevron-circle-down:before {
content: "\f13a";
}
.fa-html5:before {
content: "\f13b";
}
.fa-css3:before {
content: "\f13c";
}
.fa-anchor:before {
content: "\f13d";
}
.fa-unlock-alt:before {
content: "\f13e";
}
.fa-bullseye:before {
content: "\f140";
}
.fa-ellipsis-h:before {
content: "\f141";
}
.fa-ellipsis-v:before {
content: "\f142";
}
.fa-rss-square:before {
content: "\f143";
}
.fa-play-circle:before {
content: "\f144";
}
.fa-ticket:before {
content: "\f145";
}
.fa-minus-square:before {
content: "\f146";
}
.fa-minus-square-o:before {
content: "\f147";
}
.fa-level-up:before {
content: "\f148";
}
.fa-level-down:before {
content: "\f149";
}
.fa-check-square:before {
content: "\f14a";
}
.fa-pencil-square:before {
content: "\f14b";
}
.fa-external-link-square:before {
content: "\f14c";
}
.fa-share-square:before {
content: "\f14d";
}
.fa-compass:before {
content: "\f14e";
}
.fa-toggle-down:before,
.fa-caret-square-o-down:before {
content: "\f150";
}
.fa-toggle-up:before,
.fa-caret-square-o-up:before {
content: "\f151";
}
.fa-toggle-right:before,
.fa-caret-square-o-right:before {
content: "\f152";
}
.fa-euro:before,
.fa-eur:before {
content: "\f153";
}
.fa-gbp:before {
content: "\f154";
}
.fa-dollar:before,
.fa-usd:before {
content: "\f155";
}
.fa-rupee:before,
.fa-inr:before {
content: "\f156";
}
.fa-cny:before,
.fa-rmb:before,
.fa-yen:before,
.fa-jpy:before {
content: "\f157";
}
.fa-ruble:before,
.fa-rouble:before,
.fa-rub:before {
content: "\f158";
}
.fa-won:before,
.fa-krw:before {
content: "\f159";
}
.fa-bitcoin:before,
.fa-btc:before {
content: "\f15a";
}
.fa-file:before {
content: "\f15b";
}
.fa-file-text:before {
content: "\f15c";
}
.fa-sort-alpha-asc:before {
content: "\f15d";
}
.fa-sort-alpha-desc:before {
content: "\f15e";
}
.fa-sort-amount-asc:before {
content: "\f160";
}
.fa-sort-amount-desc:before {
content: "\f161";
}
.fa-sort-numeric-asc:before {
content: "\f162";
}
.fa-sort-numeric-desc:before {
content: "\f163";
}
.fa-thumbs-up:before {
content: "\f164";
}
.fa-thumbs-down:before {
content: "\f165";
}
.fa-youtube-square:before {
content: "\f166";
}
.fa-youtube:before {
content: "\f167";
}
.fa-xing:before {
content: "\f168";
}
.fa-xing-square:before {
content: "\f169";
}
.fa-youtube-play:before {
content: "\f16a";
}
.fa-dropbox:before {
content: "\f16b";
}
.fa-stack-overflow:before {
content: "\f16c";
}
.fa-instagram:before {
content: "\f16d";
}
.fa-flickr:before {
content: "\f16e";
}
.fa-adn:before {
content: "\f170";
}
.fa-bitbucket:before {
content: "\f171";
}
.fa-bitbucket-square:before {
content: "\f172";
}
.fa-tumblr:before {
content: "\f173";
}
.fa-tumblr-square:before {
content: "\f174";
}
.fa-long-arrow-down:before {
content: "\f175";
}
.fa-long-arrow-up:before {
content: "\f176";
}
.fa-long-arrow-left:before {
content: "\f177";
}
.fa-long-arrow-right:before {
content: "\f178";
}
.fa-apple:before {
content: "\f179";
}
.fa-windows:before {
content: "\f17a";
}
.fa-android:before {
content: "\f17b";
}
.fa-linux:before {
content: "\f17c";
}
.fa-dribbble:before {
content: "\f17d";
}
.fa-skype:before {
content: "\f17e";
}
.fa-foursquare:before {
content: "\f180";
}
.fa-trello:before {
content: "\f181";
}
.fa-female:before {
content: "\f182";
}
.fa-male:before {
content: "\f183";
}
.fa-gittip:before {
content: "\f184";
}
.fa-sun-o:before {
content: "\f185";
}
.fa-moon-o:before {
content: "\f186";
}
.fa-archive:before {
content: "\f187";
}
.fa-bug:before {
content: "\f188";
}
.fa-vk:before {
content: "\f189";
}
.fa-weibo:before {
content: "\f18a";
}
.fa-renren:before {
content: "\f18b";
}
.fa-pagelines:before {
content: "\f18c";
}
.fa-stack-exchange:before {
content: "\f18d";
}
.fa-arrow-circle-o-right:before {
content: "\f18e";
}
.fa-arrow-circle-o-left:before {
content: "\f190";
}
.fa-toggle-left:before,
.fa-caret-square-o-left:before {
content: "\f191";
}
.fa-dot-circle-o:before {
content: "\f192";
}
.fa-wheelchair:before {
content: "\f193";
}
.fa-vimeo-square:before {
content: "\f194";
}
.fa-turkish-lira:before,
.fa-try:before {
content: "\f195";
}
.fa-plus-square-o:before {
content: "\f196";
}
.fa-space-shuttle:before {
content: "\f197";
}
.fa-slack:before {
content: "\f198";
}
.fa-envelope-square:before {
content: "\f199";
}
.fa-wordpress:before {
content: "\f19a";
}
.fa-openid:before {
content: "\f19b";
}
.fa-institution:before,
.fa-bank:before,
.fa-university:before {
content: "\f19c";
}
.fa-mortar-board:before,
.fa-graduation-cap:before {
content: "\f19d";
}
.fa-yahoo:before {
content: "\f19e";
}
.fa-google:before {
content: "\f1a0";
}
.fa-reddit:before {
content: "\f1a1";
}
.fa-reddit-square:before {
content: "\f1a2";
}
.fa-stumbleupon-circle:before {
content: "\f1a3";
}
.fa-stumbleupon:before {
content: "\f1a4";
}
.fa-delicious:before {
content: "\f1a5";
}
.fa-digg:before {
content: "\f1a6";
}
.fa-pied-piper:before {
content: "\f1a7";
}
.fa-pied-piper-alt:before {
content: "\f1a8";
}
.fa-drupal:before {
content: "\f1a9";
}
.fa-joomla:before {
content: "\f1aa";
}
.fa-language:before {
content: "\f1ab";
}
.fa-fax:before {
content: "\f1ac";
}
.fa-building:before {
content: "\f1ad";
}
.fa-child:before {
content: "\f1ae";
}
.fa-paw:before {
content: "\f1b0";
}
.fa-spoon:before {
content: "\f1b1";
}
.fa-cube:before {
content: "\f1b2";
}
.fa-cubes:before {
content: "\f1b3";
}
.fa-behance:before {
content: "\f1b4";
}
.fa-behance-square:before {
content: "\f1b5";
}
.fa-steam:before {
content: "\f1b6";
}
.fa-steam-square:before {
content: "\f1b7";
}
.fa-recycle:before {
content: "\f1b8";
}
.fa-automobile:before,
.fa-car:before {
content: "\f1b9";
}
.fa-cab:before,
.fa-taxi:before {
content: "\f1ba";
}
.fa-tree:before {
content: "\f1bb";
}
.fa-spotify:before {
content: "\f1bc";
}
.fa-deviantart:before {
content: "\f1bd";
}
.fa-soundcloud:before {
content: "\f1be";
}
.fa-database:before {
content: "\f1c0";
}
.fa-file-pdf-o:before {
content: "\f1c1";
}
.fa-file-word-o:before {
content: "\f1c2";
}
.fa-file-excel-o:before {
content: "\f1c3";
}
.fa-file-powerpoint-o:before {
content: "\f1c4";
}
.fa-file-photo-o:before,
.fa-file-picture-o:before,
.fa-file-image-o:before {
content: "\f1c5";
}
.fa-file-zip-o:before,
.fa-file-archive-o:before {
content: "\f1c6";
}
.fa-file-sound-o:before,
.fa-file-audio-o:before {
content: "\f1c7";
}
.fa-file-movie-o:before,
.fa-file-video-o:before {
content: "\f1c8";
}
.fa-file-code-o:before {
content: "\f1c9";
}
.fa-vine:before {
content: "\f1ca";
}
.fa-codepen:before {
content: "\f1cb";
}
.fa-jsfiddle:before {
content: "\f1cc";
}
.fa-life-bouy:before,
.fa-life-buoy:before,
.fa-life-saver:before,
.fa-support:before,
.fa-life-ring:before {
content: "\f1cd";
}
.fa-circle-o-notch:before {
content: "\f1ce";
}
.fa-ra:before,
.fa-rebel:before {
content: "\f1d0";
}
.fa-ge:before,
.fa-empire:before {
content: "\f1d1";
}
.fa-git-square:before {
content: "\f1d2";
}
.fa-git:before {
content: "\f1d3";
}
.fa-hacker-news:before {
content: "\f1d4";
}
.fa-tencent-weibo:before {
content: "\f1d5";
}
.fa-qq:before {
content: "\f1d6";
}
.fa-wechat:before,
.fa-weixin:before {
content: "\f1d7";
}
.fa-send:before,
.fa-paper-plane:before {
content: "\f1d8";
}
.fa-send-o:before,
.fa-paper-plane-o:before {
content: "\f1d9";
}
.fa-history:before {
content: "\f1da";
}
.fa-circle-thin:before {
content: "\f1db";
}
.fa-header:before {
content: "\f1dc";
}
.fa-paragraph:before {
content: "\f1dd";
}
.fa-sliders:before {
content: "\f1de";
}
.fa-share-alt:before {
content: "\f1e0";
}
.fa-share-alt-square:before {
content: "\f1e1";
}
.fa-bomb:before {
content: "\f1e2";
}
.fa-soccer-ball-o:before,
.fa-futbol-o:before {
content: "\f1e3";
}
.fa-tty:before {
content: "\f1e4";
}
.fa-binoculars:before {
content: "\f1e5";
}
.fa-plug:before {
content: "\f1e6";
}
.fa-slideshare:before {
content: "\f1e7";
}
.fa-twitch:before {
content: "\f1e8";
}
.fa-yelp:before {
content: "\f1e9";
}
.fa-newspaper-o:before {
content: "\f1ea";
}
.fa-wifi:before {
content: "\f1eb";
}
.fa-calculator:before {
content: "\f1ec";
}
.fa-paypal:before {
content: "\f1ed";
}
.fa-google-wallet:before {
content: "\f1ee";
}
.fa-cc-visa:before {
content: "\f1f0";
}
.fa-cc-mastercard:before {
content: "\f1f1";
}
.fa-cc-discover:before {
content: "\f1f2";
}
.fa-cc-amex:before {
content: "\f1f3";
}
.fa-cc-paypal:before {
content: "\f1f4";
}
.fa-cc-stripe:before {
content: "\f1f5";
}
.fa-bell-slash:before {
content: "\f1f6";
}
.fa-bell-slash-o:before {
content: "\f1f7";
}
.fa-trash:before {
content: "\f1f8";
}
.fa-copyright:before {
content: "\f1f9";
}
.fa-at:before {
content: "\f1fa";
}
.fa-eyedropper:before {
content: "\f1fb";
}
.fa-paint-brush:before {
content: "\f1fc";
}
.fa-birthday-cake:before {
content: "\f1fd";
}
.fa-area-chart:before {
content: "\f1fe";
}
.fa-pie-chart:before {
content: "\f200";
}
.fa-line-chart:before {
content: "\f201";
}
.fa-lastfm:before {
content: "\f202";
}
.fa-lastfm-square:before {
content: "\f203";
}
.fa-toggle-off:before {
content: "\f204";
}
.fa-toggle-on:before {
content: "\f205";
}
.fa-bicycle:before {
content: "\f206";
}
.fa-bus:before {
content: "\f207";
}
.fa-ioxhost:before {
content: "\f208";
}
.fa-angellist:before {
content: "\f209";
}
.fa-cc:before {
content: "\f20a";
}
.fa-shekel:before,
.fa-sheqel:before,
.fa-ils:before {
content: "\f20b";
}
.fa-meanpath:before {
content: "\f20c";
}
{"tiddlers":{"$:/plugins/TheDiveO/TW5Roboto/history":{"title":"$:/plugins/TheDiveO/TW5Roboto/history","created":"20140902083720188","modified":"20171226180044583","type":"text/vnd.tiddlywiki","text":"* ''1.0.0'' -- first stable release of the Google Roboto font family plugin.\n\n"},"$:/plugins/TheDiveO/TW5Roboto/license":{"title":"$:/plugins/TheDiveO/TW5Roboto/license","created":"20140902084022063","modified":"20171226180008649","type":"text/vnd.tiddlywiki","text":"The //TW5Roboto// plugin is licensed as follows:\n\n* Roboto font license: [[Apache 2.0|http://www.apache.org/licenses/LICENSE-2.0]].\n* everything else in this plugin is (c) by TheDiveO and licensed under the [[MIT License|http://opensource.org/licenses/mit-license.html]]."},"$:/plugins/TheDiveO/TW5Roboto/readme":{"title":"$:/plugins/TheDiveO/TW5Roboto/readme","created":"20140902083641711","modified":"20171226183320988","type":"text/vnd.tiddlywiki","text":"! About\n\nThe //TW5Roboto// plugin provides Google's [[Roboto font family|https://fonts.google.com/specimen/Roboto]] in an easy-to-use plugin for TiddlyWiki 5. Simply drop this plugin into your own TiddlyWiki(s) and off you go...!\n\n! Thanks To...\n\n* Google for their free and open Roboto font family.\n\n* [[Transfonter|https://transfonter.org/]] for the Roboto font conversion to WOFF and CSS Base64 embedding code. According to its own description, Transfonter is a \"modern and simple css @font-face generator\".\n\n! Notes\n\n* At this time, this plugin doesn't use WOFF2 in order to achieve a better browser coverage with [[WOFF|https://caniuse.com/#feat=woff]] compared to [[WOFF2|https://caniuse.com/#feat=woff2]].\n\n* This plugin will always use its embedded Roboto font family, even if Roboto is installed locally. Learning from my experience with Font Awesome, this ensures that users always experience a consistent Roboto appearance as intended by the plugin and specific Wiki creators."},"$:/plugins/TheDiveO/TW5Roboto/styles/Roboto Embedded.css":{"title":"$:/plugins/TheDiveO/TW5Roboto/styles/Roboto Embedded.css","created":"20171226180813150","modified":"20171226195346930","tags":"$:/tags/Stylesheet","type":"text/css","text":"@font-face {\n font-family: 'Roboto';\n src: url(data:application/font-woff;charset=utf-8;base64,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) format('woff');\n font-weight: 500;\n font-style: normal;\n}\n\n@font-face {\n font-family: 'Roboto';\n src: url(data:application/font-woff;charset=utf-8;base64,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) format('woff');\n font-weight: bold;\n font-style: italic;\n}\n\n@font-face {\n font-family: 'Roboto';\n src: url(data:application/font-woff;charset=utf-8;base64,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) format('woff');\n font-weight: bold;\n font-style: normal;\n}\n\n@font-face {\n font-family: 'Roboto';\n src: url(data:application/font-woff;charset=utf-8;base64,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) format('woff');\n font-weight: normal;\n font-style: italic;\n}\n\n@font-face {\n font-family: 'Roboto';\n src: url(data:application/font-woff;charset=utf-8;base64,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) format('woff');\n font-weight: 300;\n font-style: normal;\n}\n\n@font-face {\n font-family: 'Roboto';\n src: url(data:application/font-woff;charset=utf-8;base64,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) format('woff');\n font-weight: 500;\n font-style: italic;\n}\n\n@font-face {\n font-family: 'Roboto';\n src: url(data:application/font-woff;charset=utf-8;base64,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) format('woff');\n font-weight: 100;\n font-style: italic;\n}\n\n@font-face {\n font-family: 'Roboto';\n src: url(data:application/font-woff;charset=utf-8;base64,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) format('woff');\n font-weight: 100;\n font-style: normal;\n}\n\n@font-face {\n font-family: 'Roboto';\n src: url(data:application/font-woff;charset=utf-8;base64,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) format('woff');\n font-weight: 900;\n font-style: italic;\n}\n\n@font-face {\n font-family: 'Roboto';\n src: url(data:application/font-woff;charset=utf-8;base64,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) format('woff');\n font-weight: normal;\n font-style: normal;\n}\n\n@font-face {\n font-family: 'Roboto';\n src: url(data:application/font-woff;charset=utf-8;base64,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) format('woff');\n font-weight: 300;\n font-style: italic;\n}\n\n@font-face {\n font-family: 'Roboto';\n src: url(data:application/font-woff;charset=utf-8;base64,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) format('woff');\n font-weight: 900;\n font-style: normal;\n}\n"},"$:/plugins/TheDiveO/TW5Roboto/styles/Roboto.css":{"title":"$:/plugins/TheDiveO/TW5Roboto/styles/Roboto.css","created":"20171226181401344","modified":"20171226200130310","tags":"$:/tags/Stylesheet","type":"text/css","text":"html body.tc-body {\n\tfont-family: Roboto;\n font-weight: 300;\n}"}}}
{
"tiddlers": {
"$:/plugins/tiddlywiki/hammerjs/hammer.js": {
"text": "/*! Hammer.JS - v2.0.8 - 2016-04-23\n * http://hammerjs.github.io/\n *\n * Copyright (c) 2016 Jorik Tangelder;\n * Licensed under the MIT license */\n!function(a,b,c,d){\"use strict\";function e(a,b,c){return setTimeout(j(a,c),b)}function f(a,b,c){return Array.isArray(a)?(g(a,c[b],c),!0):!1}function g(a,b,c){var e;if(a)if(a.forEach)a.forEach(b,c);else if(a.length!==d)for(e=0;e<a.length;)b.call(c,a[e],e,a),e++;else for(e in a)a.hasOwnProperty(e)&&b.call(c,a[e],e,a)}function h(b,c,d){var e=\"DEPRECATED METHOD: \"+c+\"\\n\"+d+\" AT \\n\";return function(){var c=new Error(\"get-stack-trace\"),d=c&&c.stack?c.stack.replace(/^[^\\(]+?[\\n$]/gm,\"\").replace(/^\\s+at\\s+/gm,\"\").replace(/^Object.<anonymous>\\s*\\(/gm,\"{anonymous}()@\"):\"Unknown Stack Trace\",f=a.console&&(a.console.warn||a.console.log);return f&&f.call(a.console,e,d),b.apply(this,arguments)}}function i(a,b,c){var d,e=b.prototype;d=a.prototype=Object.create(e),d.constructor=a,d._super=e,c&&la(d,c)}function j(a,b){return function(){return a.apply(b,arguments)}}function k(a,b){return typeof a==oa?a.apply(b?b[0]||d:d,b):a}function l(a,b){return a===d?b:a}function m(a,b,c){g(q(b),function(b){a.addEventListener(b,c,!1)})}function n(a,b,c){g(q(b),function(b){a.removeEventListener(b,c,!1)})}function o(a,b){for(;a;){if(a==b)return!0;a=a.parentNode}return!1}function p(a,b){return a.indexOf(b)>-1}function q(a){return a.trim().split(/\\s+/g)}function r(a,b,c){if(a.indexOf&&!c)return a.indexOf(b);for(var d=0;d<a.length;){if(c&&a[d][c]==b||!c&&a[d]===b)return d;d++}return-1}function s(a){return Array.prototype.slice.call(a,0)}function t(a,b,c){for(var d=[],e=[],f=0;f<a.length;){var g=b?a[f][b]:a[f];r(e,g)<0&&d.push(a[f]),e[f]=g,f++}return c&&(d=b?d.sort(function(a,c){return a[b]>c[b]}):d.sort()),d}function u(a,b){for(var c,e,f=b[0].toUpperCase()+b.slice(1),g=0;g<ma.length;){if(c=ma[g],e=c?c+f:b,e in a)return e;g++}return d}function v(){return ua++}function w(b){var c=b.ownerDocument||b;return c.defaultView||c.parentWindow||a}function x(a,b){var c=this;this.manager=a,this.callback=b,this.element=a.element,this.target=a.options.inputTarget,this.domHandler=function(b){k(a.options.enable,[a])&&c.handler(b)},this.init()}function y(a){var b,c=a.options.inputClass;return new(b=c?c:xa?M:ya?P:wa?R:L)(a,z)}function z(a,b,c){var d=c.pointers.length,e=c.changedPointers.length,f=b&Ea&&d-e===0,g=b&(Ga|Ha)&&d-e===0;c.isFirst=!!f,c.isFinal=!!g,f&&(a.session={}),c.eventType=b,A(a,c),a.emit(\"hammer.input\",c),a.recognize(c),a.session.prevInput=c}function A(a,b){var c=a.session,d=b.pointers,e=d.length;c.firstInput||(c.firstInput=D(b)),e>1&&!c.firstMultiple?c.firstMultiple=D(b):1===e&&(c.firstMultiple=!1);var f=c.firstInput,g=c.firstMultiple,h=g?g.center:f.center,i=b.center=E(d);b.timeStamp=ra(),b.deltaTime=b.timeStamp-f.timeStamp,b.angle=I(h,i),b.distance=H(h,i),B(c,b),b.offsetDirection=G(b.deltaX,b.deltaY);var j=F(b.deltaTime,b.deltaX,b.deltaY);b.overallVelocityX=j.x,b.overallVelocityY=j.y,b.overallVelocity=qa(j.x)>qa(j.y)?j.x:j.y,b.scale=g?K(g.pointers,d):1,b.rotation=g?J(g.pointers,d):0,b.maxPointers=c.prevInput?b.pointers.length>c.prevInput.maxPointers?b.pointers.length:c.prevInput.maxPointers:b.pointers.length,C(c,b);var k=a.element;o(b.srcEvent.target,k)&&(k=b.srcEvent.target),b.target=k}function B(a,b){var c=b.center,d=a.offsetDelta||{},e=a.prevDelta||{},f=a.prevInput||{};b.eventType!==Ea&&f.eventType!==Ga||(e=a.prevDelta={x:f.deltaX||0,y:f.deltaY||0},d=a.offsetDelta={x:c.x,y:c.y}),b.deltaX=e.x+(c.x-d.x),b.deltaY=e.y+(c.y-d.y)}function C(a,b){var c,e,f,g,h=a.lastInterval||b,i=b.timeStamp-h.timeStamp;if(b.eventType!=Ha&&(i>Da||h.velocity===d)){var j=b.deltaX-h.deltaX,k=b.deltaY-h.deltaY,l=F(i,j,k);e=l.x,f=l.y,c=qa(l.x)>qa(l.y)?l.x:l.y,g=G(j,k),a.lastInterval=b}else c=h.velocity,e=h.velocityX,f=h.velocityY,g=h.direction;b.velocity=c,b.velocityX=e,b.velocityY=f,b.direction=g}function D(a){for(var b=[],c=0;c<a.pointers.length;)b[c]={clientX:pa(a.pointers[c].clientX),clientY:pa(a.pointers[c].clientY)},c++;return{timeStamp:ra(),pointers:b,center:E(b),deltaX:a.deltaX,deltaY:a.deltaY}}function E(a){var b=a.length;if(1===b)return{x:pa(a[0].clientX),y:pa(a[0].clientY)};for(var c=0,d=0,e=0;b>e;)c+=a[e].clientX,d+=a[e].clientY,e++;return{x:pa(c/b),y:pa(d/b)}}function F(a,b,c){return{x:b/a||0,y:c/a||0}}function G(a,b){return a===b?Ia:qa(a)>=qa(b)?0>a?Ja:Ka:0>b?La:Ma}function H(a,b,c){c||(c=Qa);var d=b[c[0]]-a[c[0]],e=b[c[1]]-a[c[1]];return Math.sqrt(d*d+e*e)}function I(a,b,c){c||(c=Qa);var d=b[c[0]]-a[c[0]],e=b[c[1]]-a[c[1]];return 180*Math.atan2(e,d)/Math.PI}function J(a,b){return I(b[1],b[0],Ra)+I(a[1],a[0],Ra)}function K(a,b){return H(b[0],b[1],Ra)/H(a[0],a[1],Ra)}function L(){this.evEl=Ta,this.evWin=Ua,this.pressed=!1,x.apply(this,arguments)}function M(){this.evEl=Xa,this.evWin=Ya,x.apply(this,arguments),this.store=this.manager.session.pointerEvents=[]}function N(){this.evTarget=$a,this.evWin=_a,this.started=!1,x.apply(this,arguments)}function O(a,b){var c=s(a.touches),d=s(a.changedTouches);return b&(Ga|Ha)&&(c=t(c.concat(d),\"identifier\",!0)),[c,d]}function P(){this.evTarget=bb,this.targetIds={},x.apply(this,arguments)}function Q(a,b){var c=s(a.touches),d=this.targetIds;if(b&(Ea|Fa)&&1===c.length)return d[c[0].identifier]=!0,[c,c];var e,f,g=s(a.changedTouches),h=[],i=this.target;if(f=c.filter(function(a){return o(a.target,i)}),b===Ea)for(e=0;e<f.length;)d[f[e].identifier]=!0,e++;for(e=0;e<g.length;)d[g[e].identifier]&&h.push(g[e]),b&(Ga|Ha)&&delete d[g[e].identifier],e++;return h.length?[t(f.concat(h),\"identifier\",!0),h]:void 0}function R(){x.apply(this,arguments);var a=j(this.handler,this);this.touch=new P(this.manager,a),this.mouse=new L(this.manager,a),this.primaryTouch=null,this.lastTouches=[]}function S(a,b){a&Ea?(this.primaryTouch=b.changedPointers[0].identifier,T.call(this,b)):a&(Ga|Ha)&&T.call(this,b)}function T(a){var b=a.changedPointers[0];if(b.identifier===this.primaryTouch){var c={x:b.clientX,y:b.clientY};this.lastTouches.push(c);var d=this.lastTouches,e=function(){var a=d.indexOf(c);a>-1&&d.splice(a,1)};setTimeout(e,cb)}}function U(a){for(var b=a.srcEvent.clientX,c=a.srcEvent.clientY,d=0;d<this.lastTouches.length;d++){var e=this.lastTouches[d],f=Math.abs(b-e.x),g=Math.abs(c-e.y);if(db>=f&&db>=g)return!0}return!1}function V(a,b){this.manager=a,this.set(b)}function W(a){if(p(a,jb))return jb;var b=p(a,kb),c=p(a,lb);return b&&c?jb:b||c?b?kb:lb:p(a,ib)?ib:hb}function X(){if(!fb)return!1;var b={},c=a.CSS&&a.CSS.supports;return[\"auto\",\"manipulation\",\"pan-y\",\"pan-x\",\"pan-x pan-y\",\"none\"].forEach(function(d){b[d]=c?a.CSS.supports(\"touch-action\",d):!0}),b}function Y(a){this.options=la({},this.defaults,a||{}),this.id=v(),this.manager=null,this.options.enable=l(this.options.enable,!0),this.state=nb,this.simultaneous={},this.requireFail=[]}function Z(a){return a&sb?\"cancel\":a&qb?\"end\":a&pb?\"move\":a&ob?\"start\":\"\"}function $(a){return a==Ma?\"down\":a==La?\"up\":a==Ja?\"left\":a==Ka?\"right\":\"\"}function _(a,b){var c=b.manager;return c?c.get(a):a}function aa(){Y.apply(this,arguments)}function ba(){aa.apply(this,arguments),this.pX=null,this.pY=null}function ca(){aa.apply(this,arguments)}function da(){Y.apply(this,arguments),this._timer=null,this._input=null}function ea(){aa.apply(this,arguments)}function fa(){aa.apply(this,arguments)}function ga(){Y.apply(this,arguments),this.pTime=!1,this.pCenter=!1,this._timer=null,this._input=null,this.count=0}function ha(a,b){return b=b||{},b.recognizers=l(b.recognizers,ha.defaults.preset),new ia(a,b)}function ia(a,b){this.options=la({},ha.defaults,b||{}),this.options.inputTarget=this.options.inputTarget||a,this.handlers={},this.session={},this.recognizers=[],this.oldCssProps={},this.element=a,this.input=y(this),this.touchAction=new V(this,this.options.touchAction),ja(this,!0),g(this.options.recognizers,function(a){var b=this.add(new a[0](a[1]));a[2]&&b.recognizeWith(a[2]),a[3]&&b.requireFailure(a[3])},this)}function ja(a,b){var c=a.element;if(c.style){var d;g(a.options.cssProps,function(e,f){d=u(c.style,f),b?(a.oldCssProps[d]=c.style[d],c.style[d]=e):c.style[d]=a.oldCssProps[d]||\"\"}),b||(a.oldCssProps={})}}function ka(a,c){var d=b.createEvent(\"Event\");d.initEvent(a,!0,!0),d.gesture=c,c.target.dispatchEvent(d)}var la,ma=[\"\",\"webkit\",\"Moz\",\"MS\",\"ms\",\"o\"],na=b.createElement(\"div\"),oa=\"function\",pa=Math.round,qa=Math.abs,ra=Date.now;la=\"function\"!=typeof Object.assign?function(a){if(a===d||null===a)throw new TypeError(\"Cannot convert undefined or null to object\");for(var b=Object(a),c=1;c<arguments.length;c++){var e=arguments[c];if(e!==d&&null!==e)for(var f in e)e.hasOwnProperty(f)&&(b[f]=e[f])}return b}:Object.assign;var sa=h(function(a,b,c){for(var e=Object.keys(b),f=0;f<e.length;)(!c||c&&a[e[f]]===d)&&(a[e[f]]=b[e[f]]),f++;return a},\"extend\",\"Use `assign`.\"),ta=h(function(a,b){return sa(a,b,!0)},\"merge\",\"Use `assign`.\"),ua=1,va=/mobile|tablet|ip(ad|hone|od)|android/i,wa=\"ontouchstart\"in a,xa=u(a,\"PointerEvent\")!==d,ya=wa&&va.test(navigator.userAgent),za=\"touch\",Aa=\"pen\",Ba=\"mouse\",Ca=\"kinect\",Da=25,Ea=1,Fa=2,Ga=4,Ha=8,Ia=1,Ja=2,Ka=4,La=8,Ma=16,Na=Ja|Ka,Oa=La|Ma,Pa=Na|Oa,Qa=[\"x\",\"y\"],Ra=[\"clientX\",\"clientY\"];x.prototype={handler:function(){},init:function(){this.evEl&&m(this.element,this.evEl,this.domHandler),this.evTarget&&m(this.target,this.evTarget,this.domHandler),this.evWin&&m(w(this.element),this.evWin,this.domHandler)},destroy:function(){this.evEl&&n(this.element,this.evEl,this.domHandler),this.evTarget&&n(this.target,this.evTarget,this.domHandler),this.evWin&&n(w(this.element),this.evWin,this.domHandler)}};var Sa={mousedown:Ea,mousemove:Fa,mouseup:Ga},Ta=\"mousedown\",Ua=\"mousemove mouseup\";i(L,x,{handler:function(a){var b=Sa[a.type];b&Ea&&0===a.button&&(this.pressed=!0),b&Fa&&1!==a.which&&(b=Ga),this.pressed&&(b&Ga&&(this.pressed=!1),this.callback(this.manager,b,{pointers:[a],changedPointers:[a],pointerType:Ba,srcEvent:a}))}});var Va={pointerdown:Ea,pointermove:Fa,pointerup:Ga,pointercancel:Ha,pointerout:Ha},Wa={2:za,3:Aa,4:Ba,5:Ca},Xa=\"pointerdown\",Ya=\"pointermove pointerup pointercancel\";a.MSPointerEvent&&!a.PointerEvent&&(Xa=\"MSPointerDown\",Ya=\"MSPointerMove MSPointerUp MSPointerCancel\"),i(M,x,{handler:function(a){var b=this.store,c=!1,d=a.type.toLowerCase().replace(\"ms\",\"\"),e=Va[d],f=Wa[a.pointerType]||a.pointerType,g=f==za,h=r(b,a.pointerId,\"pointerId\");e&Ea&&(0===a.button||g)?0>h&&(b.push(a),h=b.length-1):e&(Ga|Ha)&&(c=!0),0>h||(b[h]=a,this.callback(this.manager,e,{pointers:b,changedPointers:[a],pointerType:f,srcEvent:a}),c&&b.splice(h,1))}});var Za={touchstart:Ea,touchmove:Fa,touchend:Ga,touchcancel:Ha},$a=\"touchstart\",_a=\"touchstart touchmove touchend touchcancel\";i(N,x,{handler:function(a){var b=Za[a.type];if(b===Ea&&(this.started=!0),this.started){var c=O.call(this,a,b);b&(Ga|Ha)&&c[0].length-c[1].length===0&&(this.started=!1),this.callback(this.manager,b,{pointers:c[0],changedPointers:c[1],pointerType:za,srcEvent:a})}}});var ab={touchstart:Ea,touchmove:Fa,touchend:Ga,touchcancel:Ha},bb=\"touchstart touchmove touchend touchcancel\";i(P,x,{handler:function(a){var b=ab[a.type],c=Q.call(this,a,b);c&&this.callback(this.manager,b,{pointers:c[0],changedPointers:c[1],pointerType:za,srcEvent:a})}});var cb=2500,db=25;i(R,x,{handler:function(a,b,c){var d=c.pointerType==za,e=c.pointerType==Ba;if(!(e&&c.sourceCapabilities&&c.sourceCapabilities.firesTouchEvents)){if(d)S.call(this,b,c);else if(e&&U.call(this,c))return;this.callback(a,b,c)}},destroy:function(){this.touch.destroy(),this.mouse.destroy()}});var eb=u(na.style,\"touchAction\"),fb=eb!==d,gb=\"compute\",hb=\"auto\",ib=\"manipulation\",jb=\"none\",kb=\"pan-x\",lb=\"pan-y\",mb=X();V.prototype={set:function(a){a==gb&&(a=this.compute()),fb&&this.manager.element.style&&mb[a]&&(this.manager.element.style[eb]=a),this.actions=a.toLowerCase().trim()},update:function(){this.set(this.manager.options.touchAction)},compute:function(){var a=[];return g(this.manager.recognizers,function(b){k(b.options.enable,[b])&&(a=a.concat(b.getTouchAction()))}),W(a.join(\" \"))},preventDefaults:function(a){var b=a.srcEvent,c=a.offsetDirection;if(this.manager.session.prevented)return void b.preventDefault();var d=this.actions,e=p(d,jb)&&!mb[jb],f=p(d,lb)&&!mb[lb],g=p(d,kb)&&!mb[kb];if(e){var h=1===a.pointers.length,i=a.distance<2,j=a.deltaTime<250;if(h&&i&&j)return}return g&&f?void 0:e||f&&c&Na||g&&c&Oa?this.preventSrc(b):void 0},preventSrc:function(a){this.manager.session.prevented=!0,a.preventDefault()}};var nb=1,ob=2,pb=4,qb=8,rb=qb,sb=16,tb=32;Y.prototype={defaults:{},set:function(a){return la(this.options,a),this.manager&&this.manager.touchAction.update(),this},recognizeWith:function(a){if(f(a,\"recognizeWith\",this))return this;var b=this.simultaneous;return a=_(a,this),b[a.id]||(b[a.id]=a,a.recognizeWith(this)),this},dropRecognizeWith:function(a){return f(a,\"dropRecognizeWith\",this)?this:(a=_(a,this),delete this.simultaneous[a.id],this)},requireFailure:function(a){if(f(a,\"requireFailure\",this))return this;var b=this.requireFail;return a=_(a,this),-1===r(b,a)&&(b.push(a),a.requireFailure(this)),this},dropRequireFailure:function(a){if(f(a,\"dropRequireFailure\",this))return this;a=_(a,this);var b=r(this.requireFail,a);return b>-1&&this.requireFail.splice(b,1),this},hasRequireFailures:function(){return this.requireFail.length>0},canRecognizeWith:function(a){return!!this.simultaneous[a.id]},emit:function(a){function b(b){c.manager.emit(b,a)}var c=this,d=this.state;qb>d&&b(c.options.event+Z(d)),b(c.options.event),a.additionalEvent&&b(a.additionalEvent),d>=qb&&b(c.options.event+Z(d))},tryEmit:function(a){return this.canEmit()?this.emit(a):void(this.state=tb)},canEmit:function(){for(var a=0;a<this.requireFail.length;){if(!(this.requireFail[a].state&(tb|nb)))return!1;a++}return!0},recognize:function(a){var b=la({},a);return k(this.options.enable,[this,b])?(this.state&(rb|sb|tb)&&(this.state=nb),this.state=this.process(b),void(this.state&(ob|pb|qb|sb)&&this.tryEmit(b))):(this.reset(),void(this.state=tb))},process:function(a){},getTouchAction:function(){},reset:function(){}},i(aa,Y,{defaults:{pointers:1},attrTest:function(a){var b=this.options.pointers;return 0===b||a.pointers.length===b},process:function(a){var b=this.state,c=a.eventType,d=b&(ob|pb),e=this.attrTest(a);return d&&(c&Ha||!e)?b|sb:d||e?c&Ga?b|qb:b&ob?b|pb:ob:tb}}),i(ba,aa,{defaults:{event:\"pan\",threshold:10,pointers:1,direction:Pa},getTouchAction:function(){var a=this.options.direction,b=[];return a&Na&&b.push(lb),a&Oa&&b.push(kb),b},directionTest:function(a){var b=this.options,c=!0,d=a.distance,e=a.direction,f=a.deltaX,g=a.deltaY;return e&b.direction||(b.direction&Na?(e=0===f?Ia:0>f?Ja:Ka,c=f!=this.pX,d=Math.abs(a.deltaX)):(e=0===g?Ia:0>g?La:Ma,c=g!=this.pY,d=Math.abs(a.deltaY))),a.direction=e,c&&d>b.threshold&&e&b.direction},attrTest:function(a){return aa.prototype.attrTest.call(this,a)&&(this.state&ob||!(this.state&ob)&&this.directionTest(a))},emit:function(a){this.pX=a.deltaX,this.pY=a.deltaY;var b=$(a.direction);b&&(a.additionalEvent=this.options.event+b),this._super.emit.call(this,a)}}),i(ca,aa,{defaults:{event:\"pinch\",threshold:0,pointers:2},getTouchAction:function(){return[jb]},attrTest:function(a){return this._super.attrTest.call(this,a)&&(Math.abs(a.scale-1)>this.options.threshold||this.state&ob)},emit:function(a){if(1!==a.scale){var b=a.scale<1?\"in\":\"out\";a.additionalEvent=this.options.event+b}this._super.emit.call(this,a)}}),i(da,Y,{defaults:{event:\"press\",pointers:1,time:251,threshold:9},getTouchAction:function(){return[hb]},process:function(a){var b=this.options,c=a.pointers.length===b.pointers,d=a.distance<b.threshold,f=a.deltaTime>b.time;if(this._input=a,!d||!c||a.eventType&(Ga|Ha)&&!f)this.reset();else if(a.eventType&Ea)this.reset(),this._timer=e(function(){this.state=rb,this.tryEmit()},b.time,this);else if(a.eventType&Ga)return rb;return tb},reset:function(){clearTimeout(this._timer)},emit:function(a){this.state===rb&&(a&&a.eventType&Ga?this.manager.emit(this.options.event+\"up\",a):(this._input.timeStamp=ra(),this.manager.emit(this.options.event,this._input)))}}),i(ea,aa,{defaults:{event:\"rotate\",threshold:0,pointers:2},getTouchAction:function(){return[jb]},attrTest:function(a){return this._super.attrTest.call(this,a)&&(Math.abs(a.rotation)>this.options.threshold||this.state&ob)}}),i(fa,aa,{defaults:{event:\"swipe\",threshold:10,velocity:.3,direction:Na|Oa,pointers:1},getTouchAction:function(){return ba.prototype.getTouchAction.call(this)},attrTest:function(a){var b,c=this.options.direction;return c&(Na|Oa)?b=a.overallVelocity:c&Na?b=a.overallVelocityX:c&Oa&&(b=a.overallVelocityY),this._super.attrTest.call(this,a)&&c&a.offsetDirection&&a.distance>this.options.threshold&&a.maxPointers==this.options.pointers&&qa(b)>this.options.velocity&&a.eventType&Ga},emit:function(a){var b=$(a.offsetDirection);b&&this.manager.emit(this.options.event+b,a),this.manager.emit(this.options.event,a)}}),i(ga,Y,{defaults:{event:\"tap\",pointers:1,taps:1,interval:300,time:250,threshold:9,posThreshold:10},getTouchAction:function(){return[ib]},process:function(a){var b=this.options,c=a.pointers.length===b.pointers,d=a.distance<b.threshold,f=a.deltaTime<b.time;if(this.reset(),a.eventType&Ea&&0===this.count)return this.failTimeout();if(d&&f&&c){if(a.eventType!=Ga)return this.failTimeout();var g=this.pTime?a.timeStamp-this.pTime<b.interval:!0,h=!this.pCenter||H(this.pCenter,a.center)<b.posThreshold;this.pTime=a.timeStamp,this.pCenter=a.center,h&&g?this.count+=1:this.count=1,this._input=a;var i=this.count%b.taps;if(0===i)return this.hasRequireFailures()?(this._timer=e(function(){this.state=rb,this.tryEmit()},b.interval,this),ob):rb}return tb},failTimeout:function(){return this._timer=e(function(){this.state=tb},this.options.interval,this),tb},reset:function(){clearTimeout(this._timer)},emit:function(){this.state==rb&&(this._input.tapCount=this.count,this.manager.emit(this.options.event,this._input))}}),ha.VERSION=\"2.0.8\",ha.defaults={domEvents:!1,touchAction:gb,enable:!0,inputTarget:null,inputClass:null,preset:[[ea,{enable:!1}],[ca,{enable:!1},[\"rotate\"]],[fa,{direction:Na}],[ba,{direction:Na},[\"swipe\"]],[ga],[ga,{event:\"doubletap\",taps:2},[\"tap\"]],[da]],cssProps:{userSelect:\"none\",touchSelect:\"none\",touchCallout:\"none\",contentZooming:\"none\",userDrag:\"none\",tapHighlightColor:\"rgba(0,0,0,0)\"}};var ub=1,vb=2;ia.prototype={set:function(a){return la(this.options,a),a.touchAction&&this.touchAction.update(),a.inputTarget&&(this.input.destroy(),this.input.target=a.inputTarget,this.input.init()),this},stop:function(a){this.session.stopped=a?vb:ub},recognize:function(a){var b=this.session;if(!b.stopped){this.touchAction.preventDefaults(a);var c,d=this.recognizers,e=b.curRecognizer;(!e||e&&e.state&rb)&&(e=b.curRecognizer=null);for(var f=0;f<d.length;)c=d[f],b.stopped===vb||e&&c!=e&&!c.canRecognizeWith(e)?c.reset():c.recognize(a),!e&&c.state&(ob|pb|qb)&&(e=b.curRecognizer=c),f++}},get:function(a){if(a instanceof Y)return a;for(var b=this.recognizers,c=0;c<b.length;c++)if(b[c].options.event==a)return b[c];return null},add:function(a){if(f(a,\"add\",this))return this;var b=this.get(a.options.event);return b&&this.remove(b),this.recognizers.push(a),a.manager=this,this.touchAction.update(),a},remove:function(a){if(f(a,\"remove\",this))return this;if(a=this.get(a)){var b=this.recognizers,c=r(b,a);-1!==c&&(b.splice(c,1),this.touchAction.update())}return this},on:function(a,b){if(a!==d&&b!==d){var c=this.handlers;return g(q(a),function(a){c[a]=c[a]||[],c[a].push(b)}),this}},off:function(a,b){if(a!==d){var c=this.handlers;return g(q(a),function(a){b?c[a]&&c[a].splice(r(c[a],b),1):delete c[a]}),this}},emit:function(a,b){this.options.domEvents&&ka(a,b);var c=this.handlers[a]&&this.handlers[a].slice();if(c&&c.length){b.type=a,b.preventDefault=function(){b.srcEvent.preventDefault()};for(var d=0;d<c.length;)c[d](b),d++}},destroy:function(){this.element&&ja(this,!1),this.handlers={},this.session={},this.input.destroy(),this.element=null}},la(ha,{INPUT_START:Ea,INPUT_MOVE:Fa,INPUT_END:Ga,INPUT_CANCEL:Ha,STATE_POSSIBLE:nb,STATE_BEGAN:ob,STATE_CHANGED:pb,STATE_ENDED:qb,STATE_RECOGNIZED:rb,STATE_CANCELLED:sb,STATE_FAILED:tb,DIRECTION_NONE:Ia,DIRECTION_LEFT:Ja,DIRECTION_RIGHT:Ka,DIRECTION_UP:La,DIRECTION_DOWN:Ma,DIRECTION_HORIZONTAL:Na,DIRECTION_VERTICAL:Oa,DIRECTION_ALL:Pa,Manager:ia,Input:x,TouchAction:V,TouchInput:P,MouseInput:L,PointerEventInput:M,TouchMouseInput:R,SingleTouchInput:N,Recognizer:Y,AttrRecognizer:aa,Tap:ga,Pan:ba,Swipe:fa,Pinch:ca,Rotate:ea,Press:da,on:m,off:n,each:g,merge:ta,extend:sa,assign:la,inherit:i,bindFn:j,prefixed:u});var wb=\"undefined\"!=typeof a?a:\"undefined\"!=typeof self?self:{};wb.Hammer=ha,\"function\"==typeof define&&define.amd?define(function(){return ha}):\"undefined\"!=typeof module&&module.exports?module.exports=ha:a[c]=ha}(window,document,\"Hammer\");\n",
"type": "application/javascript",
"title": "$:/plugins/tiddlywiki/hammerjs/hammer.js",
"module-type": "library"
},
"$:/plugins/tiddlywiki/hammerjs/license": {
"text": "The MIT License (MIT)\n\nCopyright (C) 2011-2017 by Jorik Tangelder (Eight Media)\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE.\n",
"type": "text/plain",
"title": "$:/plugins/tiddlywiki/hammerjs/license"
},
"$:/plugins/tiddlywiki/hammerjs/readme": {
"title": "$:/plugins/tiddlywiki/hammerjs/readme",
"text": "This plugin packages [[HammerJS|https://hammerjs.github.io]] for use by other plugins. It does not provide any end-user visible features.\n"
}
}
}
{
"tiddlers": {
"$:/plugins/tobibeer/appear/widget.js": {
"title": "$:/plugins/tobibeer/appear/widget.js",
"text": "/*\\\r\ntitle: $:/plugins/tobibeer/appear/widget.js\r\ntype: application/javascript\r\nmodule-type: widget\r\n\r\nUse the appear widget for popups, sliders, accordion menus\r\n\r\n@preserve\r\n\\*/\n(function(){\"use strict\";var t=require(\"$:/core/modules/widgets/widget.js\").widget,e=function(t,e){this.initialise(t,e)},i={};e.prototype=new t;e.prototype.render=function(t,e){this.parentDomNode=t;this.nextSibling=e;this.computeAttributes();this.execute();var i,s,r,a,h,n,l=[];if(this.handle){this.getHandlerCache(this.handle,1);this.refreshHandler()}else{s={type:\"button\"};s.attributes=this.setAttributes(s,\"button\");i=s.attributes[\"class\"].value.trim();s.attributes[\"class\"].value=i+\" appear-show\"+(this.handler?\" tc-popup-absolute\":\"\");s.children=this.wiki.parseText(\"text/vnd.tiddlywiki\",this.show,{parseAsInline:true}).tree;h={type:\"reveal\",children:this.parseTreeNode.children};h.attributes=this.setAttributes(h,\"reveal\");h.isBlock=!(this.mode&&this.mode===\"inline\");if(h.attributes.type&&h.attributes.type.value===\"popup\"){s.attributes.popup=h.attributes.state;l.push(s);if(!this.handler){l.push(h)}else{s.attributes.handler=this.handler}}else{h.attributes.type={type:\"string\",value:\"match\"};h.attributes.text={type:\"string\",value:this.currentTiddler};s.attributes.set=h.attributes.state;s.attributes.setTo={type:\"string\",value:this.currentTiddler};a={type:\"reveal\",isBlock:this.block,children:[s],attributes:{type:{type:\"string\",value:\"nomatch\"},state:h.attributes.state,text:{type:\"string\",value:this.currentTiddler}}};if(!this.once){r=$tw.utils.deepCopy(s);r.attributes[\"class\"].value=i+\" appear-hide \"+(this.attr.button.selectedClass?this.attr.button.selectedClass:\"\");r.attributes.setTo={type:\"string\",value:\"\"};r.children=this.wiki.parseText(\"text/vnd.tiddlywiki\",this.hide,{parseAsInline:true}).tree}n=$tw.utils.deepCopy(a);n.children=[];if(!this.once){n.children.push(r)}if(!this.handler){n.children.push(h)}n.attributes.type.value=\"match\";l.push(a,n)}this.makeChildWidgets(l);this.renderChildren(this.parentDomNode,e);if(this.handler){this.addToHandlerCache(h)}}};e.prototype.execute=function(){var t=this;this.attr={map:{reveal:{\"class\":1,position:1,retain:1,state:1,style:1,tag:1,type:1},button:{\"button-class\":1,\"button-style\":1,\"button-tag\":1,tooltip:1,selectedClass:1}},rename:{\"button-class\":\"class\",\"button-style\":\"style\",\"button-tag\":\"tag\"},button:{},reveal:{}};$tw.utils.each(this.attributes,function(e,i){var s;$tw.utils.each(t.attr.map,function(r,a){$tw.utils.each(Object.keys(r),function(r){if(r==i){t.attr[a][i]=e;s=false;return false}});return s})});this.currentTiddler=this.getVariable(\"currentTiddler\");this.show=this.getValue(this.attributes.show,\"show\");this.hide=this.getValue(this.attributes.hide,\"hide\");if(!this.hide){this.hide=this.show}this.once=this.attributes.once&&this.attributes.once!==\"false\";this.$state=this.attributes.$state;this.mode=this.getValue(this.attributes.mode,\"mode\");this.handle=this.attributes.handle;this.handler=this.attributes.handler;this.handlerVariables=(this.attributes.variables||\"\")+\" currentTiddler\";this.keep=[\"yes\",\"true\"].indexOf((this.getValue(this.attributes.keep,\"keep\")||\"\").toLocaleLowerCase())>-1;if(!this.attr.reveal.state){this.attr.reveal.state=this.getValue(undefined,\"default-state\")+this.currentTiddler+this.getStateQualifier()+\"/\"+(this.attr.reveal.type?this.attr.reveal.type+\"/\":\"\")+(this.mode?this.mode+\"/\":\"\")+(this.once?\"once/\":\"\")+(this.$state?\"/\"+this.$state:\"\")}};e.prototype.refresh=function(t){var e=this.computeAttributes();if(Object.keys(e).length){this.refreshSelf();return true}if(this.handle){this.refreshHandler()}return this.refreshChildren(t)};e.prototype.getValue=function(t,e){var i,s,r={show:\"»\",\"default-state\":\"$:/temp/appear/\"};if(t===undefined){i=this.wiki.getTiddler(\"$:/plugins/tobibeer/appear/defaults/\"+e);if(i){s=i.getFieldString(\"undefined\");if(!s||s===\"false\"){t=i.getFieldString(\"text\")}}}if(t===undefined){t=r[e]}return t};e.prototype.setAttributes=function(t,e){var i=this,s={};$tw.utils.each(Object.keys(this.attr.map[e]),function(r){var a,h=i.attr.rename[r];if(!h){h=r}a=i.getValue(i.attr[e][r],r);if(h===\"class\"){a=[\"appear\",\"appear-\"+e,e===\"reveal\"&&i.keep?\"tc-popup-keep\":\"\",i.mode?\"appear-\"+i.mode:\"\",i.once?\"appear-once\":\"\",a||\"\"].join(\" \")}if(a!==undefined){if(h===\"tag\"){t.tag=a}else{s[h]={type:\"string\",value:a}}}});return s};e.prototype.getHandlerCache=function(t,e){var s=i[t];if(!s||e){i[t]={handled:{},handle:{}};s=i[t]}return s};e.prototype.refreshHandler=function(){var t=this,e=this.getHandlerCache(this.handle),s=e.handle;if(Object.keys(s).length){$tw.utils.each(s,function(e,i){t.removeChildNode(i);t.children.push(t.makeChildWidget(e));t.children[t.children.length-1].render(t.parentDomNode,t.nextSibling)});i[this.handle].handle={}}};e.prototype.removeChildNode=function(t){var e=this;$tw.utils.each(this.children,function(i,s){if(i.children[0].state===t){i.removeChildDomNodes();e.children.splice(s);return false}})};e.prototype.addToHandlerCache=function(t){var e=this,i=t.attributes.state.value,s=this.getHandlerCache(this.handler),r=s.handled[i],a={type:\"vars\",children:[t],attributes:{}};$tw.utils.each((this.handlerVariables||\"\").split(\" \"),function(t){t=t.trim();if(t){a.attributes[t]={type:\"string\",value:(e.getVariable(t)||\"\").toString()}}});if(a!==r){s.handle[i]=a;this.wiki.setText(\"$:/temp/appear-handler/\"+this.handler,\"text\",undefined,i)}};exports.appear=e})();",
"type": "application/javascript",
"module-type": "widget"
},
"$:/plugins/tobibeer/appear/defaults/show": {
"title": "$:/plugins/tobibeer/appear/defaults/show",
"text": "»"
},
"$:/plugins/tobibeer/appear/defaults/mode": {
"title": "$:/plugins/tobibeer/appear/defaults/mode",
"text": "block"
},
"$:/plugins/tobibeer/appear/defaults/keep": {
"title": "$:/plugins/tobibeer/appear/defaults/keep",
"text": "yes"
},
"$:/plugins/tobibeer/appear/defaults/button-class": {
"title": "$:/plugins/tobibeer/appear/defaults/button-class",
"text": "tc-btn-invisible tc-tiddlylink"
},
"$:/plugins/tobibeer/appear/defaults/default-state": {
"title": "$:/plugins/tobibeer/appear/defaults/default-state",
"text": "$:/temp/appear/"
},
"$:/plugins/tobibeer/appear/popup.js": {
"title": "$:/plugins/tobibeer/appear/popup.js",
"text": "/*\\\r\ntitle: $:/plugins/tobibeer/appear/popup.js\r\ntype: application/javascript\r\nmodule-type: utils\r\n\r\nAn enhanced version of the core Popup to support:\r\n* absolute popups\r\n* preview popups\r\n* popup z-index\r\n\r\n@preserve\r\n\\*/\n(function(){\"use strict\";var t=require(\"$:/core/modules/utils/dom/popup.js\").Popup,e=require(\"$:/core/modules/widgets/reveal.js\").reveal,s=e.prototype.refresh;t.prototype.show=function(t){var e,s=t.domNode,p=$tw.utils.hasClass(s,\"tc-popup-absolute\"),o=this.popupInfo(s),i=function(t){var e=t,s=0,p=0;do{s+=e.offsetLeft||0;p+=e.offsetTop||0;e=e.offsetParent}while(e);return{left:s,top:p}},l={left:s.offsetLeft,top:s.offsetTop};e=o.popupLevel;if(o.isHandle){e++}this.cancel(e);if(this.findPopup(t.title)===-1){this.popups.push({title:t.title,wiki:t.wiki,domNode:s})}l=p?i(s):l;t.wiki.setTextReference(t.title,\"(\"+l.left+\",\"+l.top+\",\"+s.offsetWidth+\",\"+s.offsetHeight+\")\");if(this.popups.length>0){this.rootElement.addEventListener(\"click\",this,true)}};t.prototype.popupInfo=function(t){var e,s=false,p=t;while(p&&e===undefined){if($tw.utils.hasClass(p,\"tc-popup-handle\")||$tw.utils.hasClass(p,\"tc-popup-keep\")){s=true}if($tw.utils.hasClass(p,\"tc-reveal\")&&($tw.utils.hasClass(p,\"tc-popup\")||$tw.utils.hasClass(p,\"tc-popup-handle\"))){e=parseInt(p.style.zIndex)-1e3}p=p.parentNode}var o={popupLevel:e||0,isHandle:s};return o};t.prototype.handleEvent=function(t){if(t.type===\"click\"){var e=this.popupInfo(t.target),s=e.popupLevel-1;if(e.isHandle){if(s<0){s=1}else{s++}}this.cancel(s)}};e.prototype.refresh=function(){var t,e,p=this.isOpen;e=s.apply(this,arguments);t=this.domNodes[0];if(this.isOpen&&(p!==this.isOpen||!t.style.zIndex)&&t&&(this.type===\"popup\"||$tw.utils.hasClass(t,\"tc-block-dropdown\")&&$tw.utils.hasClass(t,\"tc-reveal\"))){t.style.zIndex=1e3+$tw.popup.popups.length}return e}})();",
"type": "application/javascript",
"module-type": "utils"
},
"$:/plugins/tobibeer/appear/readme": {
"title": "$:/plugins/tobibeer/appear/readme",
"text": "This plugin provides the ''$appear'' widget that can render popups and sliders (inline or block) as well as accordion menus.\n\n!! Attributes\r\n; type\r\n: set to `popup` to have the content appear as a popup\r\n; show\r\n: the button label\r\n; hide\r\n: the hide button label\r\n; mode\r\n: either `block` or `inline`, with respect to the inner content\r\n: any other mode is interpreted as block mode, without the default styles applying, e.g. drop-shadows\r\n; once\r\n: allows to click the button once, then hides it (unless the state is deleted)\r\n; $state\r\n: the widget calculates a state for you, use this to append a simple id\r\n; state\r\n: alternatively, specify a fully qualified state\r\n; keep\r\n: make popups sticky when `yes` or `true`\r\n; handle / handler / variables\r\n: allows to take the popup contents out of the flow and render them elsewhere on the page\r\n: required to properly create popups in table cells and other constained elements\r\n: specify variables to take along\n\n<br>\n\n; documentation / examples / demos...\r\n: http://tobibeer.github.io/tw5-plugins#appear\r\n"
},
"$:/plugins/tobibeer/appear/styles": {
"title": "$:/plugins/tobibeer/appear/styles",
"tags": "$:/tags/Stylesheet",
"text": "\\rules only filteredtranscludeinline transcludeinline macrodef macrocallinline html\n\n<pre>.tc-reveal.appear-block,\r\n.tc-popup.appear {\r\n\tborder-radius: 5px;\r\n\tpadding: 1px 1em;\r\n\t<<box-shadow \"2px 2px 4px rgba(0,0,0,0.3)\">>;\r\n}\r\n.tc-popup.appear {\r\n\tpadding: 0 1em;\r\n\tbackground: <<colour background>>;\r\n}\r\n.appear-reveal.appear-inline{\r\nmargin-left:5px;\r\n}\r\n.appear-reveal.appear-inline.appear-once{\r\nmargin-left:0;\r\n}</pre>"
}
}
}
{
"tiddlers": {
"$:/plugins/tobibeer/xlist/readme": {
"title": "$:/plugins/tobibeer/xlist/readme",
"text": "Provides the macro `<<xlist>>`, which outputs cross tables for tiddlers."
},
"$:/plugins/tobibeer/xlist/styles": {
"title": "$:/plugins/tobibeer/xlist/styles",
"tags": "$:/tags/Stylesheet",
"type": "text/css",
"text": ".xlist{\r\nmargin:0;\r\n}\n\n.xlist dt{\r\nfont-size:1.2em;\r\n}\n\n.xlist dd{\r\nmargin-left:14px;\r\n}\n\n.xlist dd:before{\r\ncontent: \"»\";padding-right:7px;\r\n}"
},
"$:/plugins/tobibeer/xlist/macro": {
"title": "$:/plugins/tobibeer/xlist/macro",
"tags": "$:/tags/Macro",
"text": "\\define xlist-groups-each()\r\n[has[$(each)$]each[$(each)$]sort[$(each)$]]\r\n\\end\n\n\\define xlist-group()\r\n{$(groupTiddler)$!!$(each)$}\r\n\\end\n\n\\define xlist-group-title()\r\n[title$(currentGroup)$]\r\n\\end\n\n\\define xlist-one()\r\n$(filter)$+[tag<currentGroup>]+[limit[1]]\r\n\\end\n\n\\define xlist-items()\r\n$(filter)$+[tag<currentGroup>]+$(sort)$\r\n\\end\n\n\\define xlist-group-one()\r\n$(filter)$+[field:$(each)$$(currentGroup)$]+[limit[1]]\r\n\\end\n\n\\define xlist-group-items()\r\n$(filter)$+[field:$(each)$$(currentGroup)$]+$(sort)$\r\n\\end\n\n\\define xlist(\r\nfilter:\"[all[current]tagging[]]\",\r\ngroups:\"[list[]]\",\r\ntemplate,\r\nsort:\"[sort[]]\",\r\neach,\r\nlink:\"yes\"\r\n)\r\n<$set name=filter value=\"$filter$\">\r\n<$set name=sort value=\"$sort$\">\r\n<$set name=each value=\"$each$\">\r\n<dl class=\"xlist\">\r\n<!--BY TAGS-->\r\n<$reveal type=match default=\"\" text=\"$each$\">\r\n<$list filter=\"$groups$\" variable=currentGroup>\r\n<$list filter=<<xlist-one>> variable=none>\r\n<dt><$reveal type=\"match\" default=\"$link$\" text=\"yes\"><$link to=<<currentGroup>>><$view tiddler=<<currentGroup>> field=title/></$link></$reveal><$reveal type=\"nomatch\" default=\"$link$\" text=\"yes\"><$view tiddler=<<currentGroup>> field=title/></$reveal></dt>\r\n<$list filter=<<xlist-items>> template=\"$template$\">\r\n<dd><$link><$view field=title/></$link></dd>\r\n</$list>\r\n</$list>\r\n</$list>\r\n</$reveal>\r\n<!--EACH FIELD-->\r\n<$reveal type=nomatch default=\"\" text=\"$each$\">\r\n<$list filter=<<xlist-groups-each>> variable=groupTiddler>\r\n<$set name=currentGroup value=<<xlist-group>>>\r\n<$list filter=<<xlist-group-one>> variable=\"none\">\r\n<dt><$list filter=<<xlist-group-title>>><$reveal type=\"match\" default=\"$link$\" text=\"yes\"><$link ><<currentTiddler>></$link></$reveal><$reveal type=\"nomatch\" default=\"$link$\" text=\"yes\"><$view field=title/></$reveal></$list></dt>\r\n<$list filter=<<xlist-group-items>> template=\"$template$\">\r\n<dd><$link><$view field=title/></$link></dd>\r\n</$list>\r\n</$list>\r\n</$set>\r\n</$list>\r\n</$reveal>\r\n</dl>\r\n</$set>\r\n</$set>\r\n</$set>\r\n\\end"
}
}
}
{
"tiddlers": {
"$:/plugins/tongerner/layout_adjustment/icon": {
"text": "<svg width=\"22pt\" height=\"22pt\" viewBox=\"0 0 100 100\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:svg=\"http://www.w3.org/2000/svg\">\n <metadata id=\"metadata7\">image/svg+xml</metadata>\n <g>\n <title>Layer 1</title>\n <g id=\"layer1\">\n <path d=\"m48.98237,97.8691l-41.98313,-24.239l0,-48.47796l41.98313,-24.23897l41.98313,24.23897l0,48.47796l-41.98313,24.239z\" id=\"path4142\" stroke-miterlimit=\"4\" stroke-width=\"1.2218\" stroke=\"#a0a0ff\" fill=\"#a0a0ff\"/>\n <path id=\"svg_3\" d=\"m73.1813,28.26401l-15.55706,15.81597c0.61319,0.6247 0.61206,1.63724 0,2.25944c-0.61371,0.62398 -1.60823,0.62448 -2.22362,0l-6.66496,-6.77579c-0.61439,-0.62462 -0.61363,-1.63801 0,-2.26065c0.61329,-0.62358 1.60695,-0.62444 2.22244,0l0,0l15.55707,-15.81609c1.84112,-1.87179 4.8262,-1.87179 6.66732,0c1.84113,1.87178 1.84112,4.90654 -0.00001,6.77832l-0.00118,-0.0012zm-50.00484,46.31849l-2.22244,-2.2595l3.30621,-5.6205l3.36112,-1.1578l23.33557,-23.72413l2.22243,2.25941l-23.33556,23.72422l-1.13868,3.417l-5.52865,3.3613z\" fill-rule=\"evenodd\"/>\n </g>\n </g>\n</svg>",
"type": "image/svg+xml",
"title": "$:/plugins/tongerner/layout_adjustment/icon",
"modifier": "TonGerner",
"modified": "20170725155035239",
"creator": "TonGerner",
"created": "20160109160239631"
},
"$:/plugins/tongerner/layout_adjustment/macros": {
"created": "20150801122014492",
"text": "\\define inputBox() <$edit-text tiddler=\"$(reftarget)$\" field=\"$(reffield)$\" class=\"$(refclass)$\"/>\n\n\\define tableRow(header,target,field,class)\n<$set name=\"reftarget\" value=\"$target$\">\n<$set name=\"reffield\" value=\"$field$\">\n<$set name=\"refclass\" value=\"settings\">\n<tr><th>$header$ </th><td><<inputBox>></td></tr>\n</$set>\n</$set>\n</$set>\n\\end\n",
"title": "$:/plugins/tongerner/layout_adjustment/macros",
"tags": "$:/tags/Macro",
"modifier": "TonGerner",
"modified": "20170103121557249",
"creator": "TonGerner"
},
"$:/plugins/tongerner/layout_adjustment/readme": {
"text": "''Note:''<br>This plugin contains 'general' settings for the layout and is additionally required for my following plugins: ^^1^^\n\n* Top menu\n* Top-left menu (top + left menu)\n* Left menu\n* Toolbar (on top)\n* Tiddlersbar\n* ~TabStory (alternative tiddlersbar at top of story)\n* Uptoolbar (toolbar above title)\n* Tristate (tristate sidebar)\n\nThis plugin contains layout code common to the mentioned plugins and let you adjust:\n\n!! Theme tweaks\n* Scroll offset (thanks to [[Tobias Beer|https://tobibeer.github.io/tb5/#%24%3A%2Fhack-142-scroll-pagescroller.js]])\n* Sidebar layout\n* Story left position\n* Story top position\n* Story right\n* Story width\n* Tiddler width\n* Sidebar top position (new)\n* Sidebar width\n\n!! Other layout settings\n* Search above story\n* Color and height of the top bar (as a boundary for top menu, toolbar, tiddlersbar, etc.)\n* Top padding of a tiddler\n* Color for displaying the 'active' state of some toggle buttons\n* Vertical position of 'sticky titles'\n* Vertical position 'sticky editor toolbar'\n\nSettings for the layout can be found in ''~ControlPanel > Appearance > [[Plugin tweaks|$:/plugins/tongerner/layout_adjustment/tweaks]]'', also available via the 'Adjust layout' button ({{$:/plugins/tongerner/layout_adjustment/image/layout}}) in the Toprightbar.\n\n|borderless|k\n|^^^1^^ | |All these plugins contain a 'Settings' tiddler tagged with $:/tags/plugin-tweaks and will display - when installed - a tab under 'Plugin tweaks'.|\n\n<<<\n''Note:''<br>@@color:red;A sticky editor toolbar works ''only'' in non-preview mode!.@@\n<<<",
"title": "$:/plugins/tongerner/layout_adjustment/readme",
"modifier": "TonGerner",
"modified": "20181228202846912",
"creator": "TonGerner",
"created": "20150731184044439"
},
"$:/plugins/tongerner/layout_adjustment/settings": {
"text": "!!Layout settings\n@@.brown ''Search above story''@@<br>\n<$checkbox tiddler=\"$:/plugins/tongerner/layout_adjustment/search\" tag=\"$:/tags/AboveStory\"> 'Search above story' active</$checkbox>\n<table class=\"tablestyle\">\n@@.brown ''Top bar''@@\n<<tableRow \"Background color 'Top bar'\" \"$:/plugins/tongerner/layout_adjustment/styles\" \"topbar-background-color\">>\n<<tableRow \"Height 'Top bar'\" \"$:/plugins/tongerner/layout_adjustment/styles\" \"topbar-height\">>\n@@.brown ''Tiddler''@@\n<<tableRow \"Top padding\" \"$:/plugins/tongerner/layout_adjustment/styles\" \"tiddler-padding-top\">>\n@@.brown ''Button color''@@\n<<tableRow \"Active button color\" \"$:/plugins/tongerner/layout_adjustment/styles\" \"active-state-color\">>\n@@.brown ''Sticky''@@<br>{{$:/plugins/tongerner/layout_adjustment/pin-buttons}}\n<<tableRow \"Top 'sticky title'\" \"$:/plugins/tongerner/layout_adjustment/styles\" \"top-sticky-title\">>\n<<tableRow \"Top 'sticky editor toolbar'\" \"$:/plugins/tongerner/layout_adjustment/styles\" \"top-sticky-editor-toolbar\">>\n</table>\n\n<<<\n''Note:''\n\n* @@color:red;For a 'Top bar' to become visible, a color and a height > 0px need to be entered!@@\n* The 'Sticky general' button ({{$:/plugins/tongerner/layout_adjustment/pin-icon}}/{{$:/plugins/tongerner/layout_adjustment/unpin-icon}}) acts the same as the setting in ''Control panel > Appearance > Theme tweaks > Sticky titles''\n*The 'Sticky editor toolbar' button (also {{$:/plugins/tongerner/layout_adjustment/pin-icon}}/{{$:/plugins/tongerner/layout_adjustment/unpin-icon}}) adds stickyness to the editor toolbar\n** Both 'Top' settings are ''only'' active when the toolbar is sticky!\n* @@color:red;A sticky editor toolbar works ''only'' in non-preview mode!@@\n<<<\n\n<$button tooltip=\"Help\">\n<$action-sendmessage $message=\"tm-open-window\" $param=\"$:/plugins/tongerner/layout_adjustment/settings-help\" height=\"530px\" width=\"720px\"/>Help</$button>",
"title": "$:/plugins/tongerner/layout_adjustment/settings",
"tags": "$:/tags/plugin-tweaks",
"order": "2",
"modifier": "TonGerner",
"modified": "20181229102553324",
"creator": "TonGerner",
"created": "20150729190109349",
"caption": "Layout"
},
"$:/plugins/tongerner/layout_adjustment/settings-help": {
"text": "<<<\n''Note:''<br>You can enter values in allowed CSS units, e.g. `%`, `px`, `em`...\n<<<\n\n|Item|Entry |Description |Default |h\n|Search |<$checkbox></$checkbox>|Search above story ^^''1''^^|inactive|\n|Topbar |Background color 'Top bar'|Background color of the top bar<br>Transparent when left 'blank'''!''| ^^''2''^^ |\n|~|Height 'Top bar'|Height of the top bar| 0px ^^''3''^^ |\n|Tiddler |Top padding |Top padding of tiddler | 30px |\n|Button color|Active button color |Color indicating 'active' state of toggle button | #0044BB |\n|Sticky ^^''4''^^|Top 'sticky title' |Position sticky title from top | 0px |\n|~|Top 'sticky editor toolbar'|Position sticky editor toolbar from top| 35px ^^''4''^^ |\n\n<br>\n\n|borderless|k\n|^''@@font-size: 0.8em;1@@'' ||In classic storyview: scroll up to reach search<br>In zoomin view always visible|\n|^''@@font-size: 0.8em;2@@'' | |Default left blank; `#F4F4F4` is the Page background color for the Snow White theme|\n|^''@@font-size: 0.8em;3@@'' | |A ''height > 0px'' is required to 'see' the top bar!|\n|^''@@font-size: 0.8em;4@@'' | |Both 'Sticky Top' settings are ''only'' active when the toolbar is sticky!|\n|^''@@font-size: 0.8em;5@@'' | |About 35px higher than Top 'sticky title' to prevent hiding the tiddler control buttons|\n\n\n\n",
"title": "$:/plugins/tongerner/layout_adjustment/settings-help",
"tags": "",
"modifier": "TonGerner",
"modified": "20181229102124899",
"creator": "TonGerner",
"created": "20150801124528672"
},
"$:/plugins/tongerner/layout_adjustment/sidebar-top": {
"text": "0px",
"title": "$:/plugins/tongerner/layout_adjustment/sidebar-top",
"tags": "",
"modified": "20170317105358712",
"created": "20161213115930178"
},
"$:/plugins/tongerner/layout_adjustment/styles": {
"text": "<pre>/* LAYOUT SETTINGS */\n\n/* VERTICAL OFFSET FOR TOP OF SIDEBAR */\nhtml .tc-sidebar-scrollable {\n top: {{$:/plugins/tongerner/layout_adjustment/sidebar-top}};\n}\n\n* BACKGROUND COLOR TOPRIGHTBAR (with double chevron) */\n.tc-topbar {\n background-color: {{!!topbar-background-color}};\n}\n\n/* TOPBAR */\n.tgc-toolbar {\n display:block;\n position:fixed;\n left:0px;\n top:0px;\n width:100%;\n height: {{!!topbar-height}};\n background-color: {{!!topbar-background-color}};\n z-index: 600;\n}\n\n/* TOP PADDING TIDDLER */\nbody.tc-body .tc-tiddler-frame {\n padding-top: {{!!tiddler-padding-top}};\n}\n\n/* COLOR ACTIVE STATE TOGGLE BUTTON */\nbody.tc-body .tgc-active-indicator {\n color: {{!!active-state-color}};\n}\nbody.tc-body .tgc-active-indicator svg {\n fill: {{!!active-state-color}};\n}\n\nbody.tc-body .tgc-active-indicator:hover svg {\n fill: <<colour \"foreground\">>;\n}\n\n/* SETTINGS TABLE */\n/* WIDTH SETTINGS TABLE */\ninput[type='text'].settings {\n width: 120px;\n}\ntable.tablestyle {\n font-size: 0.9em;\n border-width: 0px;\n border-style: solid;\n padding: 2px;\n border-color: #DDD;\n border-collapse: collapse;\n}\ntable.tablestyle th {\n background-color: #F0F0F0;\n border-color: #DDD;\n text-align: left;\n vertical-align: top;\n border-style: solid;\n border-width: 1px;\n padding: 5px;\n}\ntable.tablestyle tr {\n background-color: #F0F0F0;\n padding: 0px;\n}\ntable.tablestyle td {\n border-color: #DDD;\n border-style: solid;\n border-width: 1px;\n padding:2px;\n}\n/* COLOR HEADINGS TABLE */\n.brown {\n color: #884411;\n font-weight: bold;\n}\n/* BORDERLESS TABLES */\n.borderless, .borderless table, .borderless td, .borderless tr, .borderless th, .borderless tbody {\n border:0 !important;\n margin:0 !important;\n padding:0 !important;\n}\n</pre>",
"topbar-height": "0px",
"topbar-background-color": "",
"top-sticky-title": "0px",
"top-sticky-editor-toolbar": "35px",
"title": "$:/plugins/tongerner/layout_adjustment/styles",
"tiddler-padding-top": "30px",
"tags": "$:/tags/Stylesheet",
"story-river-top": "0px",
"sidebar-top": "0px",
"modifier": "TonGerner",
"modified": "20181229102401101",
"list-after": "$:/themes/tiddlywiki/vanilla/base",
"creator": "TonGerner",
"created": "20161212103011213",
"active-state-color": "#0044BB"
},
"$:/plugins/tongerner/layout_adjustment/themetweaks": {
"created": "20161212090056554",
"text": "!! Theme tweaks\n\n@@.brown '''Adjust layout' button''@@<br>\n<$checkbox tiddler=\"$:/plugins/tongerner/layout_adjustment/configuration-button\" tag=\"$:/tags/TopRightBar\"> 'Adjust layout' button ({{$:/plugins/tongerner/layout_adjustment/image/layout}}) visible in Toprightbar?</$checkbox>\n\n@@.brown ''Scroll hack''@@<br>\n<$checkbox tiddler=\"$:/scrollhack-pagescroller.js\" field=\"module-type\" checked=\"macro\" unchecked=\"\" default=\"macro\"> Scroll hack active?</$checkbox> (needs save & refresh)\n\n|tablestyle|k\n|<$link to=\"$:/plugins/tongerner/layout_adjustment/offsetY\">''Scroll offset''     </$link> |<$edit-text tiddler=\"$:/plugins/tongerner/layout_adjustment/offsetY\" default=\"\" tag=\"input\"/> |\n\n@@.brown ''Theme tweaks''@@<br>\nexcerpt from 'Theme Tweaks' tab\n\n|tablestyle|k\n|<$link to=\"$:/themes/tiddlywiki/vanilla/options/sidebarlayout\">Sidebar layout</$link> |<$select tiddler=\"$:/themes/tiddlywiki/vanilla/options/sidebarlayout\"><option value=\"fixed-fluid\">Fixed story, Fluid sidebar</option><option value=\"fluid-fixed\">Fluid story, Fixed sidebar</option></$select> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/storyleft\">Story left position</$link>|^<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/storyleft\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/storytop\">Story top position</$link>|^<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/storytop\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/storyright\">Story right</$link>|^<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/storyright\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/storywidth\">Story width</$link>|^<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/storywidth\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/tiddlerwidth\">Tiddler width</$link>|^<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/tiddlerwidth\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/plugins/tongerner/layout_adjustment/sidebar-top\">Sidebar top position</$link> |^<$edit-text tiddler=\"$:/plugins/tongerner/layout_adjustment/sidebar-top\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/sidebarwidth\">Sidebar width</$link> |^<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/sidebarwidth\" default=\"\" tag=\"input\"/> |\n<$button tooltip=\"Help\">\n<$action-sendmessage $message=\"tm-open-window\" $param=\"$:/plugins/tongerner/layout_adjustment/themetweaks-help\" height=\"700px\" width=\"700px\"/>Help</$button>\n",
"title": "$:/plugins/tongerner/layout_adjustment/themetweaks",
"tags": "$:/tags/plugin-tweaks",
"order": "1",
"modified": "20180222204708661",
"caption": "Theme tweaks"
},
"$:/plugins/tongerner/layout_adjustment/themetweaks-help": {
"created": "20161212130221042",
"text": "|Item |Entry |Description |Default |h\n|'Adjust layout' button |<input type=\"checkbox\" /> / <input type=\"checkbox\" checked />|Toggle button in Toprightbar on/off| <input type=\"checkbox\" checked /> |\n|Scroll hack |<input type=\"checkbox\" /> / <input type=\"checkbox\" checked />|Scroll hack active?<br>(needs save & refresh)| <input type=\"checkbox\" checked /> |\n|~|Scroll offset |Shifts standard scroll top position downwards| 42px ^^1^^|\n|Theme tweaks |^Sidebar layout |^Choice between Fluid story, fixed sidebar and Fixed story, fluid sidebar|Fluid story, fixed sidebar ^^2^^|\n|~|^Story left position |^How far the left margin of the story river (tiddler area) is from the left of the page| 0px|\n|~|^Story top position |^How far the top margin of the story river is from the top of the page| 0px ^^3^^|\n|~|^Story right |^How far the left margin of the sidebar is from the left of the page| 770px|\n|~|^Story width |^The overall width of the story river| 770px|\n|~|^Tiddler width |^Within the story river| 686px|\n|~|^Sidebar top position |^Start of the sidebar<br>(from the top)| 0px ^^3^^|\n|~|^Sidebar width |^The width of the sidebar in fluid-fixed layout| 350px|\n\n|borderless|k\n|^''@@font-size: 0.8em;1@@'' ||To fix the tiddler scrolling underneath the top bar when opening TW. Default 42px. Adjust as required but use the minimum value needed (to prevent scroll problems at the bottom).|\n|^''@@font-size: 0.8em;2@@'' ||''Fluid story, fixed sidebar interferes with Tristate plugin'' => select Fixed story, fluid sidebar for Tristate plugin |\n|^''@@font-size: 0.8em;3@@'' | |Default values; ''need to be adjusted (increased) in case of adding a top menu, toolbar, tiddlersbar, ... to the wiki!''|",
"title": "$:/plugins/tongerner/layout_adjustment/themetweaks-help",
"tags": "",
"modified": "20180222204547275"
},
"$:/plugins/tongerner/layout_adjustment/topbar": {
"created": "20150731184520854",
"text": "<div class=\"tgc-toolbar\"></div>\n<<scrollhack>>",
"creator": "TonGerner",
"modified": "20171224115711436",
"modifier": "TonGerner",
"tags": "$:/tags/PageTemplate",
"title": "$:/plugins/tongerner/layout_adjustment/topbar"
},
"$:/plugins/tongerner/layout_adjustment/tweaks": {
"created": "20150801100456266",
"creator": "TonGerner",
"text": "The general layout adjustments can be found under the 'Themes tweak' and 'Layout' tabs. Dependent on installed plugins other tabs are available ('Top menu', 'Top-left menu', 'Toolbar', 'Tiddlersbar, '~TabStory', 'Uptoolbar', 'Tristate').\n<<tabs \"[all[shadows+tiddlers]tag[$:/tags/plugin-tweaks]nsort[order]]\" \"$:/plugins/tongerner/layout_adjustment/settings\" \"\" \"tc-vertical\">>",
"caption": "Plugin tweaks",
"modified": "20171204115305512",
"modifier": "TonGerner",
"tags": "$:/tags/ControlPanel/Appearance",
"title": "$:/plugins/tongerner/layout_adjustment/tweaks"
},
"$:/themes/tiddlywiki/vanilla/sticky_": {
"created": "20170330150510113",
"text": "<$reveal state=\"$:/themes/tiddlywiki/vanilla/options/stickytitles\" type=\"match\" text=\"yes\">\n``\n.tc-tiddler-title {\n position: -webkit-sticky;\n position: -moz-sticky;\n position: -o-sticky;\n position: -ms-sticky;\n position: sticky;\n top: ``{{$:/plugins/tongerner/layout_adjustment/styles!!top-sticky-title}}``;\n background: ``<<colour tiddler-background>>``;\n z-index: 500;\n}\n.tc-editor-toolbar {\n position: -webkit-sticky;\n position: -moz-sticky;\n position: -o-sticky;\n position: -ms-sticky;\n position: sticky;\n top: ``{{$:/plugins/tongerner/layout_adjustment/styles!!top-sticky-editor-toolbar}}``;\n background: ``<<colour tiddler-background>>``;\n z-index: 500;\n}\n``\n</$reveal>\n",
"type": "text/vnd.tiddlywiki",
"title": "$:/themes/tiddlywiki/vanilla/sticky_",
"tags": "",
"modified": "20180201194034940"
},
"$:/plugins/tongerner/layout_adjustment/configuration-button": {
"text": "<$button class=\"tc-btn-invisible\" tooltip=\"Adjust layout\">\n<$action-sendmessage $message=\"tm-open-window\" $param=\"$:/plugins/tongerner/layout_adjustment/tweaks\" height=\"760px\" width=\"720px\"/>\n{{$:/plugins/tongerner/layout_adjustment/image/layout}}\n</$button>\n\n\n",
"title": "$:/plugins/tongerner/layout_adjustment/configuration-button",
"tags": "$:/tags/TopRightBar",
"modified": "20181229101028066",
"list-before": "$:/core/ui/TopBar/menu",
"description": "Adjust layout",
"created": "20171203165317769",
"caption": "{{$:/plugins/tongerner/layout_adjustment/icon}} adjust layout"
},
"$:/plugins/tongerner/layout_adjustment/image/layout": {
"text": "<svg class=\"tgc-layout-button tc-image-button\" height=\"22pt\" width=\"22pt\" viewBox=\"0 0 22 22\">\n<path d=\"m19.84313,0.21698l-17.65497,0c-1.08334,0 -1.96191,0.9235 -1.96191,2.0571l0,17.48416c0,1.1359 0.87857,2.0571 1.96191,2.0571l17.65497,0c1.08334,0 1.96191,-0.92119 1.96191,-2.0571l0,-17.48416c0,-1.1336 -0.87857,-2.0571 -1.96191,-2.0571zm-17.65497,7.80127l5.71838,0l0,11.73768l-5.71838,0l0,-11.73768zm7.67809,11.73768l0,-11.73768l9.97689,0l0,-2.0571l-17.65497,0l0,-3.68707l17.65497,0l0.0022,17.48416l-9.97909,0l0,-0.00231z\"/>\n</svg>",
"created": "20171203171851124",
"modified": "20171203173424044",
"tags": "",
"title": "$:/plugins/tongerner/layout_adjustment/image/layout"
},
"$:/plugins/tongerner/layout_adjustment/offsetY": {
"created": "20171203173818558",
"text": "42px",
"title": "$:/plugins/tongerner/layout_adjustment/offsetY",
"tags": "",
"modified": "20171225094534779"
},
"$:/scrollhack-pagescroller.js": {
"created": "20171203173540819",
"text": "/*\\\ntitle: $:/scrollhack-pagescroller.js\ntype: application/javascript\nmodule-type: macro\nsummary: overwrites $tw.pageScroller.scrollIntoView to introduce an offset [[$:/plugins/tongerner/layout_adjustment/offsetY]]\n\n<<scrollhack>>\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"scrollhack\";\nexports.params = [{}];\n\n/*\nRun the macro\n*/\nexports.run = function() {\n\n\tif(!this.hackOnce){\n\t\tthis.hackOnce = true;\n\n\t\t//SCROLLHACK: get offsetY\n\t\tvar offsetY = parseInt($tw.wiki.getTiddlerText(\"$:/plugins/tongerner/layout_adjustment/offsetY\"));\n\t\toffsetY = isNaN(offsetY) ? 0 : offsetY;\n\n\t\t/*\n\t\tHandle a scroll event DIFFERENTLY hitting the page document\n\t\t*/\n\t\t$tw.pageScroller.scrollIntoView = function(element) {\n\t\t\tvar duration = $tw.utils.getAnimationDuration();\n\t\t\t// Now get ready to scroll the body\n\t\t\tthis.cancelScroll();\n\t\t\tthis.startTime = Date.now();\n\t\t\tvar scrollPosition = $tw.utils.getScrollPosition();\n\t\t\t// Get the client bounds of the element and adjust by the scroll position\n\t\t\tvar clientBounds = element.getBoundingClientRect(),\n\t\t\t\tbounds = {\n\t\t\t\t\tleft: clientBounds.left + scrollPosition.x,\n\t\t\t\t\ttop: clientBounds.top + scrollPosition.y,\n\t\t\t\t\twidth: clientBounds.width,\n\t\t\t\t\theight: clientBounds.height\n\t\t\t\t};\n\t\t\t// We'll consider the horizontal and vertical scroll directions separately via this function\n\t\t\tvar getEndPos = function(targetPos,targetSize,currentPos,currentSize) {\n\t\t\t\t\t// If the target is above/left of the current view, then scroll to it's top/left\n\t\t\t\t\tif(targetPos <= currentPos) {\n\t\t\t\t\t\treturn targetPos;\n\t\t\t\t\t// If the target is smaller than the window and the scroll position is too far up, then scroll till the target is at the bottom of the window\n\t\t\t\t\t} else if(targetSize < currentSize && currentPos < (targetPos + targetSize - currentSize)) {\n\t\t\t\t\t\treturn targetPos + targetSize - currentSize;\n\t\t\t\t\t// If the target is big, then just scroll to the top\n\t\t\t\t\t} else if(currentPos < targetPos) {\n\t\t\t\treturn targetPos;\n\t\t\t\t\t// Otherwise, stay where we are\n\t\t\t\t\t} else {\n\t\t\t\t\t\treturn currentPos;\n\t\t\t\t\t}\n\t\t\t\t},\n\t\t\t\tendX = getEndPos(bounds.left,bounds.width,scrollPosition.x,window.innerWidth),\n\t\t\t\tendY = getEndPos(bounds.top,bounds.height,scrollPosition.y,window.innerHeight);\n\n\t\t\t// Only scroll if necessary\n\t\t\tif(endX !== scrollPosition.x || endY !== scrollPosition.y) {\n\n\t\t\t\t//HACK-142: fix endY via offsetY\n\t\t\t\tendY = (endY - offsetY) || 0;\n\n\t\t\t\tvar self = this,\n\t\t\t\t\tdrawFrame;\n\t\t\t\tdrawFrame = function () {\n\t\t\t\t\tvar t;\n\t\t\t\t\tif(duration <= 0) {\n\t\t\t\t\t\tt = 1;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tt = ((Date.now()) - self.startTime) / duration;\t\n\t\t\t\t\t}\n\t\t\t\t\tif(t >= 1) {\n\n\t\t\t\t\t\tself.cancelScroll();\n\t\t\t\t\t\tt = 1;\n\t\t\t\t\t}\n\t\t\t\t\tt = $tw.utils.slowInSlowOut(t);\n\n\t\t\t\t\twindow.scrollTo(\n\t\t\t\t\t\tscrollPosition.x + (endX - scrollPosition.x) * t,\n\t\t\t\t\t\tscrollPosition.y + (endY - scrollPosition.y) * t);\n\n\t\t\t\t\tif(t < 1) {\n\t\t\t\t\t\tself.idRequestFrame = self.requestAnimationFrame.call(window,drawFrame);\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t\tdrawFrame();\n\t\t\t}\n\t\t};\n\n\n\t};\n\treturn \"\";\n\n}\n\n})();",
"type": "application/javascript",
"title": "$:/scrollhack-pagescroller.js",
"tags": "",
"module-type": "macro",
"modified": "20171225094433841"
},
"$:/plugins/tongerner/layout_adjustment/license": {
"text": "[[Layout adjustment plugin|http://tongerner.tiddlyspot.com/#Layout%20adjustment%20plugin]] © Ton Gerner — 2018\n\nMIT License: https://opensource.org/licenses/MIT\n",
"title": "$:/plugins/tongerner/layout_adjustment/license",
"tags": "",
"modified": "20180130092116257",
"created": "20180124162829244"
},
"$:/plugins/tongerner/layout_adjustment/pin-buttons": {
"created": "20180131170419120",
"text": "<$reveal state=\"$:/themes/tiddlywiki/vanilla/options/stickytitles\" type=\"nomatch\" text=\"no\">\n<$button set=\"$:/themes/tiddlywiki/vanilla/options/stickytitles\" setTo=\"no\" tooltip=\"Activate sticky\" class=\"tc-btn-invisible\">{{$:/plugins/tongerner/layout_adjustment/pin-icon}}\n</$button>\n</$reveal>\n<$reveal state=\"$:/themes/tiddlywiki/vanilla/options/stickytitles\" type=\"match\" text=\"no\">\n<$button set=\"$:/themes/tiddlywiki/vanilla/options/stickytitles\" setTo=\"yes\" tooltip=\"Deactivate sticky\" class=\"tc-btn-invisible\">{{$:/plugins/tongerner/layout_adjustment/unpin-icon}}\n</$button>\n</$reveal>Sticky general: {{$:/themes/tiddlywiki/vanilla/options/stickytitles}} —\n<$reveal state=\"$:/state/sticky-toolbar\" type=\"nomatch\" text=\"yes\">\n<$button set=\"$:/state/sticky-toolbar\" setTo=\"yes\" tooltip=\"Activate sticky editor toolbar\" class=\"tc-btn-invisible\">{{$:/plugins/tongerner/layout_adjustment/unpin-icon}}\n<$action-setfield $tiddler=\"$:/themes/tiddlywiki/vanilla/sticky_\" title=\"$:/themes/tiddlywiki/vanilla/sticky\"/>\n</$button>\n</$reveal>\n<$reveal state=\"$:/state/sticky-toolbar\" type=\"match\" text=\"yes\">\n<$button set=\"$:/state/sticky-toolbar\" setTo=\"no\" tooltip=\"Deactivate sticky editor toolbar\" class=\"tc-btn-invisible\">{{$:/plugins/tongerner/layout_adjustment/pin-icon}}\n<$action-deletetiddler $tiddler=\"$:/themes/tiddlywiki/vanilla/sticky\"/>\n</$button>\n</$reveal>Sticky editor toolbar: {{$:/state/sticky-toolbar}}",
"title": "$:/plugins/tongerner/layout_adjustment/pin-buttons",
"tags": "",
"modified": "20180131170949454"
},
"$:/plugins/tongerner/layout_adjustment/pin-icon": {
"created": "20180131170610630",
"text": "<svg class=\"tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 8 8\">\n <path d=\"m1.85672,0.03562a0.5,0.49555 0 0 0 0.16,0.99109l0.5,0l0,1.98219l-1,0c-0.55,0 -1,0.44599 -1,0.99109l3,0l0,2.97328l0.44,0.99109l0.56,-0.99109l0,-2.97328l3,0c0,-0.5451 -0.45,-0.99109 -1,-0.99109l-1,0l0,-1.98219l0.5,0a0.5,0.49555 0 1 0 0,-0.99109l-4,0a0.5,0.49555 0 0 0 -0.09,0a0.5,0.49555 0 0 0 -0.06,0l-0.01,0z\"/>\n</svg>",
"title": "$:/plugins/tongerner/layout_adjustment/pin-icon",
"tags": "",
"modified": "20180131170621663"
},
"$:/plugins/tongerner/layout_adjustment/unpin-icon": {
"created": "20180130174200638",
"text": "<svg class=\"tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 8 8\">\n <path transform=\"rotate(89.90647888183594 4.016719818115234,3.998984575271606) \" d=\"m1.85672,0.03562a0.5,0.49555 0 0 0 0.16,0.99109l0.5,0l0,1.98219l-1,0c-0.55,0 -1,0.44599 -1,0.99109l3,0l0,2.97328l0.44,0.99109l0.56,-0.99109l0,-2.97328l3,0c0,-0.5451 -0.45,-0.99109 -1,-0.99109l-1,0l0,-1.98219l0.5,0a0.5,0.49555 0 1 0 0,-0.99109l-4,0a0.5,0.49555 0 0 0 -0.09,0a0.5,0.49555 0 0 0 -0.06,0l-0.01,0z\"/>\n</svg>",
"title": "$:/plugins/tongerner/layout_adjustment/unpin-icon",
"tags": "",
"modified": "20180131170641913"
},
"$:/plugins/tongerner/layout_adjustment/combination": {
"created": "20180316161209354",
"text": "In case two or three of the following plugins:\n\n* Top menu ^^1^^\n* Top toolbar ^^1^^\n* Tiddlerbar ^^1^^\n\nare to be combined, some adjustments to the layout are necessary to prevent overlapping parts. The following gives the general procedure.\n\n# Click the ''Adjust layout'' button {{$:/plugins/tongerner/layout_adjustment/image/layout}} in the top right bar or click [[Plugin tweaks|$:/plugins/tongerner/layout_adjustment/tweaks]] and select the Theme tweaks tab\n## To create extra room on top, increase ''Story top position''\n# Select the Layout tab and increase ''Height topbar''\n# If required, adjust the 'Top' settings of<div>\n\n* 'Top menu' (tab Top menu, setting ''Top 'Top menu''')\n* 'Toolbar' (tab Toolbar, setting ''Top 'Toolbar''')\n* 'Tiddlersbar (tab Tiddlersbar, setting ''Top 'Tiddlersbar''')\n</div>\n# Some tweaking of the above values\n# Adjust ''Sidebar top position'' in Theme tweaks tab\n# If required, adjust the scroll offset.\n\n\n^^''1''^^ Available at http://tongerner.tiddlyspot.com/\n\n<<<\n''Note:''<br>http://tongerner.tiddlyspot.com/ shows the combination of 'Top menu', 'Toolbar' and 'Tiddlersbar'.\n<<<\n\n",
"title": "$:/plugins/tongerner/layout_adjustment/combination",
"tags": "",
"modified": "20181228193509539"
},
"$:/plugins/tongerner/layout_adjustment/search": {
"created": "20181228194403881",
"text": "{{$:/AdvancedSearch}}",
"title": "$:/plugins/tongerner/layout_adjustment/search",
"tags": "",
"modified": "20181229103632074"
}
}
}
{
"tiddlers": {
"$:/plugins/tongerner/topmenu/menu-template": {
"created": "20150630194215349",
"text": "<span class=\"tc-tag-list-item\">\n<$set name=\"transclusion\" value=<<currentTiddler>>>\n<$macrocall $name=\"tag-pill-body\" tag=<<currentTiddler>> icon={{!!icon}} colour={{!!color}} palette={{$:/palette}} element-tag=\"\"\"$button\"\"\" element-attributes=\"\"\"popup=<<qualify \"$:/state/popup/tag\">> dragFilter='[all[current]tagging[]]' tag='span'\"\"\"/>\n<$reveal state=<<qualify \"$:/state/popup/tag\">> type=\"popup\" position=\"below\" animate=\"yes\" class=\"tc-drop-down tgc-menu-drop-down\">\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/TagDropdown]!has[draft.of]]\" variable=\"listItem\"> \n<$transclude tiddler=<<listItem>>/> \n</$list>\n<$macrocall $name=\"list-tagged-draggable\" tag=<<currentTiddler>>/>\n</$reveal>\n</$set>\n</span>\n",
"creator": "TonGerner",
"modified": "20170615115042473",
"modifier": "TonGerner",
"tags": "",
"title": "$:/plugins/tongerner/topmenu/menu-template"
},
"$:/plugins/tongerner/topmenu/settings": {
"text": "!!Top menu settings\n<table class=\"tablestyle\">\n<<tableRow \"Top 'Top menu'\" \"$:/plugins/tongerner/topmenu/styles\" \"topmenu-top\">>\n<<tableRow \"Left 'Top menu'\" \"$:/plugins/tongerner/topmenu/styles\" \"topmenu-left\">>\n<<tableRow \"Rounded corners menu\" \"$:/plugins/tongerner/topmenu/styles\" \"button-border-radius\">>\n<<tableRow \"Font-size menu\" \"$:/plugins/tongerner/topmenu/styles\" \"menu-font-size\">>\n<<tableRow \"Font-size menu entries\" \"$:/plugins/tongerner/topmenu/styles\" \"menu-entry-font-size\">>\n</table>\n<$button tooltip=\"Help\">\n<$action-sendmessage $message=\"tm-open-window\" $param=\"$:/plugins/tongerner/topmenu/settings-help\" height=\"250px\" width=\"700px\"/>Help</$button>",
"title": "$:/plugins/tongerner/topmenu/settings",
"tags": "$:/tags/plugin-tweaks",
"order": "2",
"modifier": "TonGerner",
"modified": "20171222163226768",
"creator": "TonGerner",
"created": "20160111185911104",
"caption": "Top menu"
},
"$:/plugins/tongerner/topmenu/settings-help": {
"created": "20150701110844646",
"text": "<<<\n''Note:''<br>You can enter values in allowed CSS units, e.g. `%`, `px`, `em`...\n<<<\n\n|Entry |Description |Default |h\n|Top 'Top menu' |Start (from the top) of the top menu| 0px |\n|Left 'Top menu' |Start (from the left) of the top menu | 42px |\n|Rounded corners menu |Rounded corners of main menu 'tagpills' | 3px |\n|Font-size menu |Font-size of menu | 16px |\n|Font-size menu entries |Font-size of menu entries | 0.8em |\n",
"creator": "TonGerner",
"modified": "20160112193658905",
"modifier": "TonGerner",
"tags": "",
"title": "$:/plugins/tongerner/topmenu/settings-help"
},
"$:/plugins/tongerner/topmenu/styles": {
"created": "20160112193603578",
"text": "<pre>/* TOP MENU */\n.tgc-topmenu {\n display: block;\n position: fixed;\n left: 0;\n top: 0px;\n margin-left: {{!!topmenu-left}};\n margin-top: {{!!topmenu-top}};\n font-size: {{!!menu-font-size}};\n z-index: 1500;\n}\n\n/* TOP MENU BUTTON */\n/* html needed; otherwise tc-topbar button interferes */\nhtml .tgc-topmenu button {\n padding: 1px 5px 3px 5px;\n}\n\n/* TOP MENU TAG PILL ENTRIES */\n/* html needed */\nhtml .tgc-topmenu .tc-tag-label {\n border-radius: {{!!button-border-radius}};\n}\n\n.tgc-menu-drop-down {\n min-width: 120px;\n border: none;\n margin: 1px;\n font-size: {{!!menu-entry-font-size}};\n}\n</pre>",
"button-border-radius": "3px",
"creator": "TonGerner",
"list-after": "$:/themes/tiddlywiki/vanilla/base",
"menu-entry-font-size": "0.8em",
"menu-font-size": "16px",
"modified": "20171224155313118",
"modifier": "TonGerner",
"tags": "$:/tags/Stylesheet",
"title": "$:/plugins/tongerner/topmenu/styles",
"topmenu-left": "42px",
"topmenu-top": "0px"
},
"$:/plugins/tongerner/topmenu/topmenu": {
"created": "20150630194341608",
"text": "<div class=\"tgc-topmenu\">\n{{tagpill1||$:/plugins/tongerner/topmenu/menu-template}}\n{{tagpill2||$:/plugins/tongerner/topmenu/menu-template}}\n</div>\n<!--\nA top menu with 2 'dummy' tag pills is shown above.\nReplace the dummy tags with your own tags and add more lines if needed.\n-->",
"creator": "TonGerner",
"modified": "20171223211136702",
"modifier": "TonGerner",
"tags": "$:/tags/TopLeftBar",
"title": "$:/plugins/tongerner/topmenu/topmenu",
"caption": "{{$:/core/images/menu-button}} top menu",
"description": "Menu on top"
},
"$:/plugins/tongerner/topmenu/icon": {
"created": "20160109210345621",
"text": "<svg width=\"22pt\" height=\"22pt\" viewBox=\"0 0 100 100\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:svg=\"http://www.w3.org/2000/svg\">\n<path fill=\"#a0a0ff\" stroke=\"#a0a0ff\" stroke-width=\"1.2218\" stroke-miterlimit=\"4\" id=\"path4142\" d=\"m48.98237,97.8691l-41.98313,-24.239l0,-48.47796l41.98313,-24.23897l41.98313,24.23897l0,48.47796l-41.98313,24.239z\"/>\n<path id=\"path5447\" d=\"m20.63027,34.25617l56.7551,0c2.61074,0 4.72959,-2.11886 4.72959,-4.72959c0,-2.61073 -2.11885,-4.72959 -4.72959,-4.72959l-56.7551,0c-2.61073,0 -4.72959,2.11886 -4.72959,4.72959c0,2.61073 2.11886,4.72959 4.72959,4.72959zm56.7551,9.45914l-56.7551,0c-2.61073,0 -4.72959,2.1189 -4.72959,4.72959c0,2.6108 2.11886,4.7296 4.72959,4.7296l56.7551,0c2.61074,0 4.72959,-2.1188 4.72959,-4.7296c0,-2.61069 -2.11885,-4.72959 -4.72959,-4.72959zm0,18.91839l-56.7551,0c-2.61073,0 -4.72959,2.1189 -4.72959,4.7296c0,2.6107 2.11886,4.7296 4.72959,4.7296l56.7551,0c2.61074,0 4.72959,-2.1189 4.72959,-4.7296c0,-2.6107 -2.11885,-4.7296 -4.72959,-4.7296z\"/>\n</svg>",
"type": "image/svg+xml",
"title": "$:/plugins/tongerner/topmenu/icon",
"modified": "20170726092557105"
},
"$:/plugins/tongerner/topmenu/readme": {
"created": "20150701112855953",
"text": "This plugin adds a top menu with tag pill based menu entries.\n\n<<<\n''Note:''<br>''This plugin needs my $:/plugins/tongerner/layout_adjustment plugin for general layout settings (available at http://tongerner.tiddlyspot.com/).''\n<<<\n\nSettings for the layout can be found in ''~ControlPanel > Appearance > [[Plugin tweaks|$:/plugins/tongerner/layout_adjustment/tweaks]]''.\n",
"title": "$:/plugins/tongerner/topmenu/readme",
"tags": "",
"modifier": "TonGerner",
"modified": "20170615111650845",
"creator": "TonGerner"
},
"$:/plugins/tongerner/topmenu/help": {
"text": "\\define source(tiddler)\n<pre><$view tiddler=\"$tiddler$\" format=\"text\"/></pre>\n\\end\n\nThe [[top menu|$:/plugins/tongerner/topmenu/topmenu]] needs to be populated with tag based entries. The [[top menu|$:/plugins/tongerner/topmenu/topmenu]] contains:\n\n<<source $:/plugins/tongerner/topmenu/topmenu>>\n\nMenu entries need to te tagged with `tagpill1`, `tagpill2`, ...\n\n<<<\n''Note:''<br>The order of the menu entries can be changed by drag & drop.\n<<<",
"title": "$:/plugins/tongerner/topmenu/help",
"tags": "",
"modified": "20170615155809059",
"created": "20170615111129252"
},
"$:/plugins/tongerner/topmenu/license": {
"text": "[[Top menu plugin|http://tongerner.tiddlyspot.com/#Top%20menu%20plugin]] © Ton Gerner — 2018\n\nMIT License: https://opensource.org/licenses/MIT",
"title": "$:/plugins/tongerner/topmenu/license",
"tags": "",
"modified": "20180129133934063",
"created": "20180124185811291"
}
}
}
This plugin adds a top menu with tag pill based menu entries.
<<<
''Note:''<br>''This plugin needs my $:/plugins/tongerner/layout_adjustment plugin for general layout settings (available at http://tongerner.tiddlyspot.com/).''
<<<
Settings for the layout can be found in ''~ControlPanel > Appearance > [[Plugin tweaks|$:/plugins/tongerner/layout_adjustment/tweaks]]''.
!!Top menu settings
<table class="tablestyle">
<<tableRow "Top 'Top menu'" "$:/plugins/tongerner/topmenu/styles" "topmenu-top">>
<<tableRow "Left 'Top menu'" "$:/plugins/tongerner/topmenu/styles" "topmenu-left">>
<<tableRow "Rounded corners menu" "$:/plugins/tongerner/topmenu/styles" "button-border-radius">>
<<tableRow "Font-size menu" "$:/plugins/tongerner/topmenu/styles" "menu-font-size">>
<<tableRow "Font-size menu entries" "$:/plugins/tongerner/topmenu/styles" "menu-entry-font-size">>
</table>
<$button tooltip="Help">
<$action-sendmessage $message="tm-open-window" $param="$:/plugins/tongerner/topmenu/settings-help" height="250px" width="700px"/>Help</$button>
<pre>/* TOP MENU */
.tgc-topmenu {
display: block;
position: fixed;
left: 0;
top: 0px;
margin-left: {{!!topmenu-left}};
margin-top: {{!!topmenu-top}};
font-size: {{!!menu-font-size}};
z-index: 1500;
}
/* TOP MENU BUTTON */
/* html needed; otherwise tc-topbar button interferes */
html .tgc-topmenu button {
padding: 1px 5px 3px 5px;
}
/* TOP MENU TAG PILL ENTRIES */
/* html needed */
html .tgc-topmenu .tc-tag-label {
border-radius: {{!!button-border-radius}};
}
.tgc-menu-drop-down {
min-width: 120px;
border: none;
margin: 1px;
font-size: {{!!menu-entry-font-size}};
}
</pre>
<div class="tgc-topmenu">
{{Topmenu1||$:/plugins/tongerner/topmenu/menu-template}}
{{Topmenu2||$:/plugins/tongerner/topmenu/menu-template}}
</div>
<!--
A top menu with 2 'dummy' tag pills is shown above.
Replace the dummy tags with your own tags and add more lines if needed.
-->
/* See http://plaintabs.tiddlyspot.com */
<pre>
.tc-tab-buttons {
margin-bottom:0px;
padding-left:.5vw;
}
.tc-tab-divider {
margin-top:-1px;
}
.tc-tab-buttons button {
opacity:.9;
}
.tc-tab-buttons button.tc-tab-selected {
border-bottom:1px solid <<colour background>>;
opacity:1;
}
.tc-tab-buttons.tc-vertical button {
background-image:none;
border: 1px solid transparent;
opacity:.9;
}
.tc-tab-buttons.tc-vertical button.tc-tab-selected {
background:inherit;
border:1px solid <<colour tab-border-selected>>;
border-right: 1px solid <<colour background>>;
opacity:1;
}
.tc-sidebar-lists .tc-tab-buttons button {
border:0;
}
.tc-sidebar-lists .tc-tab-buttons button.tc-tab-selected {
border-bottom: 1px solid <<colour page-background>>;
}
.tc-tab-content.tc-vertical {
border-left:1px solid <<colour tab-divider>>;
}
.tc-more-sidebar .tc-tab-buttons button.tc-tab-selected {
border: 1px solid <<colour sidebar-tab-border-selected>>;
border-right: 1px solid <<colour page-background>>;
}
</pre>
{
"tiddlers": {
"$:/plugins/ValdikSS/neocities/neocities.js": {
"created": "20190818174123991",
"text": "/*\\\ntitle: $:/plugins/ValdikSS/neocities/neocities.js\ntype: application/javascript\nmodule-type: saver\n\nSaves changes on Neocities websites via API.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nSelect the appropriate saver module and set it up\n*/\nvar NeocitiesSaver = function(wiki) {\n this.wiki = wiki;\n};\n\nNeocitiesSaver.prototype.save = function(text, method, callback) {\n // Get the various parameters we need\n var apikey = $tw.utils.getPassword(\"neocities\"),\n uploadDir = this.wiki.getTextReference(\"$:/NeocitiesUploadDir\") || \"\",\n uploadFilename = this.wiki.getTextReference(\"$:/NeocitiesFilename\") || \"index.html\",\n // Neocities does not support CORS to API. CORS proxy is required for now.\n //url = \"https://neocities.org/api/upload\";\n url = \"https://cors-anywhere.herokuapp.com/https://neocities.org/api/upload\";\n // Bail out if we don't have the bits we need\n if(!apikey || apikey.toString().trim() === \"\") {\n return false;\n }\n\n // Assemble the header\n var boundary = \"---------------------------\" + \"AaB03x\";\n var head = [];\n head.push(\"--\" + boundary);\n head.push(\"Content-Disposition: form-data; name=\\\"\" + uploadDir + \"/\" + uploadFilename + \"\\\"; filename=\\\"tiddlywiki.html\\\"\");\n head.push(\"Content-Type: text/html;charset=UTF-8\");\n head.push(\"Content-Length: \" + text.length + \"\\r\\n\");\n head.push(\"\");\n // Assemble the tail and the data itself\n var tail = \"\\r\\n--\" + boundary + \"--\\r\\n\",\n data = head.join(\"\\r\\n\") + text + tail;\n // Do the HTTP post\n var http = new XMLHttpRequest();\n http.open(\"POST\", url, true);\n http.setRequestHeader(\"Content-Type\", \"multipart/form-data; boundary=\" + boundary);\n http.setRequestHeader(\"Authorization\", \"Bearer \" + apikey);\n http.onreadystatechange = function() {\n if (http.readyState == 4) {\n if (http.status == 200) {\n if (JSON.parse(http.responseText).result == \"success\") {\n callback(null, \"Saved to Neocities\");\n }\n else {\n callback(\"Neocities ERROR: \" + http.responseText);\n }\n }\n else {\n try {\n var jsonparsed = JSON.parse(http.responseText);\n var message = jsonparsed.message;\n } catch(ex) {\n var message = http.responseText;\n }\n callback(\"Neocities ERROR: \" + http.status + \"\\r\\n\" + message);\n }\n }\n };\n try {\n http.send(data);\n } catch(ex) {\n callback($tw.language.getString(\"Error/Caption\") + \":\" + ex);\n return false;\n }\n $tw.notifier.display(\"$:/language/Notifications/Save/Starting\");\n return true;\n};\n\n/*\nInformation about this saver\n*/\nNeocitiesSaver.prototype.info = {\n name: \"neocities\",\n priority: 2000,\n capabilities: [\"save\", \"autosave\"]\n};\n\n/*\nStatic method that returns true if this saver is capable of working\n*/\nexports.canSave = function(wiki) {\n return true;\n};\n\n/*\nCreate an instance of this saver\n*/\nexports.create = function(wiki) {\n return new NeocitiesSaver(wiki);\n};\n\n})();\n",
"type": "application/javascript",
"title": "$:/plugins/ValdikSS/neocities/neocities.js",
"module-type": "saver",
"modified": "20190818194238663"
},
"$:/plugins/ValdikSS/neocities/readme": {
"created": "20190818160322200",
"text": "This plugin provides a ''saver'' module for saving changes of Tiddlywikis hosted on [[Neocities|https://neocities.com/]].\n\n''WARNING:'' this plugin uses third-party service `cors-anywhere.herokuapp.com` provided by [[Rob Wu|https://robwu.nl/]] to bypass API security to allow it to be used from browser (CORS). Your API key would be transmitted over this service.",
"title": "$:/plugins/ValdikSS/neocities/readme",
"modified": "20190818193443966"
},
"$:/plugins/ValdikSS/neocities/interface": {
"text": "Go to [[Neocities settings page|https://neocities.org/settings/]], press \"Manage Site Settings\" → API Key.\n\n|Neocities API key|<$password name=\"neocities\"/>|\n|File name|<$edit-text tiddler=\"$:/NeocitiesFilename\" default=\"index.html\" tag=\"input\"/> |\n|Upload Directory|<$edit-text tiddler=\"$:/NeocitiesUploadDir\" default=\"\" tag=\"input\"/> |",
"title": "$:/plugins/ValdikSS/neocities/interface",
"tags": "$:/tags/ControlPanel/Saving",
"modified": "20190818185124593",
"created": "20190818160743004",
"caption": "Neocities Saver"
}
}
}
{
"tiddlers": {
"$:/plugins/wikilabs/bundler/doc/table-all-filters": {
"title": "$:/plugins/wikilabs/bundler/doc/table-all-filters",
"created": "20170602150722531",
"modified": "20170609084521849",
"tags": "",
"type": "text/vnd.tiddlywiki",
"text": "!! Default Filters\n\n<table>\n<tbody>\n<th>Description</th><th>Filter</th><th>Test</th>\n<$list filter=\"[all[shadows]tag[$:/tags/Filter]]\">\n <tr>\n <td>{{!!description}}</td>\n <td><$view field=filter/></td>\n <td>{{||$:/plugins/wikilabs/bundler/ui/Buttons/test-filter}}</td>\n </tr>\n</$list>\n</tbody>\n</table>\n\n!! This Wiki\n\n<table>\n<tbody>\n<th>Description</th><th>Filter</th><th>Test</th>\n<$list filter=\"[all[tiddlers]tag[$:/tags/Filter]]\">\n <tr>\n <td>{{!!description}}</td>\n <td><$view field=filter/></td>\n <td>{{||$:/plugins/wikilabs/bundler/ui/Buttons/test-filter}}</td>\n </tr>\n</$list>\n</tbody>\n</table>\n\n"
},
"$:/plugins/wikilabs/bundler/ui/Bundles": {
"title": "$:/plugins/wikilabs/bundler/ui/Bundles",
"caption": "Bundles",
"created": "20170601134806876",
"modified": "20170609084521847",
"tags": "$:/tags/SideBar",
"type": "text/vnd.tiddlywiki",
"text": "{{$:/plugins/wikilabs/bundler/ui/BundlesList}}\n\n---\n\n<$reveal type=\"match\" state=\"$:/config/wikilabs/enableBundles\" text=\"enabled\">\n\n{{$:/plugins/wikilabs/bundler/ui/BundlesFiltered}}\n\n</$reveal>\n\n<$reveal type=\"nomatch\" state=\"$:/config/wikilabs/enableBundles\" text=\"enabled\">\n\n[[Enable Filtered Bundles|$:/plugins/wikilabs/bundler/ui/ControlPanel/bundler-config]]\n\n</$reveal>\n"
},
"$:/plugins/wikilabs/bundler/ui/BundlesFiltered": {
"title": "$:/plugins/wikilabs/bundler/ui/BundlesFiltered",
"created": "20170604154246985",
"modified": "20170609084521844",
"type": "text/vnd.tiddlywiki",
"text": "\\define filter-exist() [enlist{$(currentTiddler)$}] +[has[title]]\n\\define filter-list() [enlist{$(currentTiddler)$}]\n\\define get-info() <$count filter=<<filter-exist>> />/<$count filter=<<filter-list>> />\n\\define get-tooltip() <$count filter=<<filter-exist>> />, out of <$count filter=<<filter-list>> /> tiddlers will be exported. Check for typos!\n\\define count-filter() <$count filter={{$(currentTiddler)$!!filter}} /> \n\\define get-filter-tooltip() <<count-filter>> tiddlers will be exported\n\n\\define go-advanced-search-filter()\n<$action-setfield $tiddler=\"$:/state/tab--1498284803\" $value=\"$:/core/ui/AdvancedSearch/Filter\"/>\n<$action-setfield $tiddler=\"$:/temp/advancedsearch\" $value={{$(currentTiddler)$!!filter}}/>\n\\end\n\\define test-filter()\n<$button to=\"$:/AdvancedSearch\" actions=<<go-advanced-search-filter>> class=\"tc-btn-invisible\" tooltip=\"Test the filter\" style=\"cursor:help\">\n <<count-filter>> \n</$button>\n\\end\n\n<$button>\n<$action-sendmessage $message=\"tm-new-tiddler\" \ntitle=\"new-filtered.bundle\" \ntags=\"$:/tags/Filter\" \ndescription=\"provide a meaningful description to display in AdvancedSearch: Filter!\"\nfilter=\"adjust this filter: [list[$:/StoryList]]\" \ntext=\"<pre>{{!!filter}}</pre>\"/>\nFilter Bundle\n</$button><$list\nfilter=\"[tag[$:/tags/Filter]]\">\n<$link to=<<currentTiddler>> tooltip=<<get-filter-tooltip>> >\n\n{{||$:/plugins/wikilabs/bundler/ui/Buttons/export-bundle-filter}} <<test-filter>> <<currentTiddler>>\n</$link> </$list>\n"
},
"$:/plugins/wikilabs/bundler/ui/BundlesList": {
"title": "$:/plugins/wikilabs/bundler/ui/BundlesList",
"created": "20170604154146106",
"modified": "20170609084521841",
"type": "text/vnd.tiddlywiki",
"text": "\\define filter-exist() [enlist{$(currentTiddler)$}] +[has[title]]\n\\define filter-list() [enlist{$(currentTiddler)$}]\n\\define get-info() <$count filter=<<filter-exist>> />/<$count filter=<<filter-list>> />\n\\define get-tooltip() <$count filter=<<filter-exist>> />, out of <$count filter=<<filter-list>> /> tiddlers will be exported. Check for typos!\n\\define count-filter() <$count filter={{$(currentTiddler)$!!filter}} /> \n\\define get-filter-tooltip() <<count-filter>> tiddlers will be exported\n\n\\define go-advanced-search-filter()\n<$action-setfield $tiddler=\"$:/state/tab--1498284803\" $value=\"$:/core/ui/AdvancedSearch/Filter\"/>\n<$action-setfield $tiddler=\"$:/temp/advancedsearch\" $value={{$(currentTiddler)$!!filter}}/>\n\\end\n\\define test-filter()\n<$button to=\"$:/AdvancedSearch\" actions=<<go-advanced-search-filter>> class=\"tc-btn-invisible\" tooltip=\"Test the filter\" style=\"cursor:help\">\n <<count-filter>> \n</$button>\n\\end\n\n<$button>\n<$action-sendmessage $message=\"tm-new-tiddler\" \ntitle=\"new.bundle\" \ntags=\"$:/tags/Bundle\" \ntype=\"text/plain\" \ntext=\"tiddlerName\n[[tiddler with spaces]]\"/>\nNew Bundle List\n</$button>\n<$list filter=\"[tag[$:/tags/Bundle]]\">\n\n<$link to=<<currentTiddler>> tooltip=<<get-tooltip>> >\n{{||$:/plugins/wikilabs/bundler/ui/Buttons/export-bundle}} <<get-info>> <<currentTiddler>>\n</$link>\n</$list>\n"
},
"$:/plugins/wikilabs/bundler/ui/Buttons/export-bundle-filter": {
"title": "$:/plugins/wikilabs/bundler/ui/Buttons/export-bundle-filter",
"caption": "{{$:/core/images/export-button}} {{$:/language/Buttons/ExportTiddler/Caption}}",
"created": "20170602112538007",
"description": "export bundle",
"modified": "20170609084521879",
"tags": "",
"type": "text/vnd.tiddlywiki",
"text": "<$macrocall $name=\"exportButton\" exportFilter={{!!filter}} lingoBase=\"$:/language/Buttons/ExportTiddlers/\" baseFilename=<<currentTiddler>>/>"
},
"$:/plugins/wikilabs/bundler/ui/Buttons/export-bundle": {
"title": "$:/plugins/wikilabs/bundler/ui/Buttons/export-bundle",
"caption": "{{$:/core/images/export-button}} {{$:/language/Buttons/ExportTiddler/Caption}}",
"created": "20170601135455476",
"description": "export bundle",
"modified": "20170609084521882",
"type": "text/vnd.tiddlywiki",
"text": "\\define makeExportFilter()\n[enlist{$(currentTiddler)$}]\n\\end\n<$macrocall $name=\"exportButton\" exportFilter=<<makeExportFilter>> lingoBase=\"$:/language/Buttons/ExportTiddler/\" baseFilename=<<currentTiddler>>/>\n"
},
"$:/plugins/wikilabs/bundler/ui/Buttons/test-filter": {
"title": "$:/plugins/wikilabs/bundler/ui/Buttons/test-filter",
"created": "20170602135926983",
"modified": "20170609084521834",
"tags": "",
"type": "text/vnd.tiddlywiki",
"text": "\\define go-advanced-search-filter()\n<$action-setfield $tiddler=\"$:/state/tab--1498284803\" $value=\"$:/core/ui/AdvancedSearch/Filter\"/>\n<$action-setfield $tiddler=\"$:/temp/advancedsearch\" $value={{$(currentTiddler)$!!filter}}/>\n\\end\n\\define test-filter()\n<$button to=\"$:/AdvancedSearch\" actions=<<go-advanced-search-filter>> class=\"tc-btn-invisible\" tooltip=\"Test the filter\">\n{{$:/core/images/info-button}}\n</$button>\n\\end\n\n<<test-filter>>"
},
"$:/plugins/wikilabs/bundler/ui/ControlPanel/bundler-config": {
"title": "$:/plugins/wikilabs/bundler/ui/ControlPanel/bundler-config",
"caption": "Bundles",
"created": "20170602132707785",
"modified": "20170612095528115",
"tags": "$:/tags/ControlPanel",
"type": "text/vnd.tiddlywiki",
"text": "!! Wikilabs [[Bundle Settings|$:/plugins/wikilabs/bundler/ui/ControlPanel/bundler-config]]\n\n<<<\n\nSelect the position of the bundle tab:\n\n<$tiddler tiddler=\"$:/plugins/wikilabs/bundler/ui/Bundles\">\n<$radio field=tags value=\"$:/tags/MoreSideBar\"> \"$:/tags/MoreSideBar\"</$radio><br>\n<$radio field=tags value=\"$:/tags/SideBar\"> \"$:/tags/SideBar\"</$radio>\n</$tiddler>\n\n<<<\n\n!! Enable Overwrite Check\n\n<<<\n<$checkbox tiddler=\"$:/config/wikilabs/enableOverwriteCheck\" field=\"text\" checked=\"yes\" unchecked=\"no\" default=\"no\"> Enable Overwrite Check</$checkbox>\n\nBy default, the import mechanism overwrites existing tiddlers. By enabling this option, you can activate a mechanism, that creates a new tiddler name. By default this option is off.\n<<<\n\n!! Enable Import Bundle\n\n<<<\n\n<$checkbox tiddler=\"$:/config/wikilabs/enableImportBundle\" field=\"text\" checked=\"yes\" unchecked=\"no\" default=\"no\"> Enable Import Bundle</$checkbox>\n\nEverytime you import content, an [[import.bundle]] tiddler will be created. If the tiddler already exists, the new imported titles will be appended. \n\nYou can rename or delete the tiddler, to store the setting or get rid of it. \n\n<<<\n\n!! Enable Filtered Bundles\n\n<<<\n\n<$checkbox tiddler=\"$:/config/wikilabs/enableBundles\" field=\"text\" checked=\"enabled\" unchecked=\"disabled\" default=\"disabled\"> Enable Filtered Bundles</$checkbox>\n\nBundle filters are already used by the \"More\" dropdown in the $:/AdvancedSearch - Filter tab. The filtered bundle settings provide a slightly different UI to export sets of tiddlers, configured by the user. \n\nThe \"Filter Bundle\" button creates compatible configurations. So user created filtered bundles show up in the advanced search panel too! Existing filters can be seen here: $:/plugins/wikilabs/bundler/doc/table-all-filters\n\n<<<\n\n!! Filter Format\n\n<<<\n\n;text\n:contains the documentation text if needed\n\n;filter\n:filter to use eg: `[tag[test]]`\n\n;description\n:descriptive text, that shows up in the AdvancedSearch: Filter: More dropdown\n\n<<<"
},
"$:/plugins/wikilabs/bundler/importhook.js": {
"title": "$:/plugins/wikilabs/bundler/importhook.js",
"text": "/*\\\ntitle: $:/plugins/wikilabs/bundler/importhook.js\ntype: application/javascript\nmodule-type: startup\n\nA startup module to log imported tiddlers to the import.bundle tiddler.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n// Export name and synchronous status\nexports.name = \"bundlerimporthook\";\nexports.platforms = [\"browser\"];\nexports.after = [\"startup\"];\nexports.synchronous = true;\n\n// Favicon tiddler\nvar ENABLE_LOG_TITLE = \"$:/config/wikilabs/enableImportBundle\",\n\tIMPORT_LOG_TITLE = \"import.bundle\";\n\nexports.startup = function() {\n\t$tw.hooks.addHook(\"th-importing-tiddler\",function(tiddler) {\n\t\tvar logTiddler,\n\t\t\ttidTitle = tiddler.fields.title;\n\n\t\tif($tw.wiki.checkTiddlerText(ENABLE_LOG_TITLE,\"yes\")) {\n\t\t\tlogTiddler = $tw.wiki.getTiddler(IMPORT_LOG_TITLE) || new $tw.Tiddler($tw.wiki.getCreationFields(), $tw.wiki.getModificationFields(), {title: IMPORT_LOG_TITLE, text: \"\", type: \"text/plain\", tags: [\"$:/tags/Bundle\"]});\n\n\t\t\tif (tidTitle.indexOf(\" \") !== -1) {\n\t\t\t\t$tw.wiki.addTiddler( new $tw.Tiddler( logTiddler, {text: logTiddler.fields.text + \"[[\" + tidTitle + \"]]\\n\"}));\n\t\t\t} else {\n\t\t\t\t$tw.wiki.addTiddler( new $tw.Tiddler( logTiddler, {text: logTiddler.fields.text + tidTitle + \"\\n\"}));\n\t\t\t}\n\t\t}\n\t\treturn tiddler;\n\t});\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "startup"
},
"$:/plugins/wikilabs/bundler/upgrade.js": {
"title": "$:/plugins/wikilabs/bundler/upgrade.js",
"text": "/*\\\ntitle: $:/plugins/wikilabs/bundler/upgrade.js\ntype: application/javascript\nmodule-type: upgrader\n\nThis module checks, if tiddlers, that are imported already exist. If they do, they are disabled and a tiddler with a new name will be created. ge: \"New Tiddler (1)\". This option is configurable.\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar ENABLE_OVERWRITE_CHECK = \"$:/config/wikilabs/enableOverwriteCheck\";\n\nexports.upgrade = function(wiki,titles,tiddlers) {\n\tvar self = this,\n\t\tmessages = {},\n\t\toverwriteCheck = $tw.wiki.checkTiddlerText(ENABLE_OVERWRITE_CHECK,\"yes\");\n\n\t$tw.utils.each(titles,function(title) {\n\t\tvar tiddler = {},\n\t\t\ttiddlerData = wiki.getTiddler(title);\n\t\t// Check for tiddlers on our list. Atm, we check for names only, since 5.1.14 allows modification date to be supressed.\n\t\t// Creating a hash, would be a better option. ToDo\n\t\tif (wiki.tiddlerExists(title)) {\n\t\t\tmessages[title] = \"Existing tiddler will be overwritten!\";\n\t\t\t// create new tiddler with a new name\n\t\t\tif (overwriteCheck) {\n\t\t\t\tmessages[title] = \"A tiddler with that name exists. A new name will be used!\";\n\t\t\t\ttiddler = new $tw.Tiddler(tiddlers[title], {\"title\": wiki.generateNewTitle(title) });\n\t\t\t\ttiddlers[tiddler.fields.title] = tiddler.fields;\n\t\t\t\t// remove the original tiddler\n\t\t\t\ttiddlers[title] = Object.create(null);\n\t\t\t}\n\t\t}\n\t});\n\treturn messages;\n\t}\n\n})();\n",
"type": "application/javascript",
"module-type": "upgrader"
},
"$:/plugins/wikilabs/bundler/history": {
"title": "$:/plugins/wikilabs/bundler/history",
"text": "* V0.1.1 - beta 2017.06.18\n** improve license links and readme\n** fix upgrade.js title\n\n* V0.1.0 - beta\n** new name: bundler\n** this name change makes it incompatible to older settings!\n\n** new \"Enable Overwrite Check\" option. default = no\n\n* V0.0.1 - beta\n** initial release\n** name: bundles\n"
},
"$:/plugins/wikilabs/bundler/license": {
"title": "$:/plugins/wikilabs/bundler/license",
"text": "[[Bundler-Plugin|https://wikilabs.github.io/#bundler]] (C) Mario Pietsch - 2017-2018\n\nhttps://opensource.org/licenses/BSD-3-Clause\n"
},
"$:/plugins/wikilabs/bundler/readme": {
"title": "$:/plugins/wikilabs/bundler/readme",
"text": "\n* Documentation and more can be found at: https://wikilabs.github.io/#bundler\n* The position of the \"Bundles\" tab can be selected in the $:/ControlPanel\n* There are 2 version of bundles\n** Bundle lists\n** Filtered Bundles ... which have to be activated by the user\n* The filter examples can be live tested, clicking on the number besides the \"export button\"\n* The Bundler can bundle itself into a bundle :-).\n* You can create several \"selections\". Those combinations are persistently stored for reuse. \n* Bundle lists can be built up, over time. Just as the TW evolves. \n* The \"Enable Import Bundle\" option lets you collect / log imported tiddlers and create a new bundle, for future use.\n* This plugin only works with TW >= 5.1.14 since we use the \"enlist\" operator which has been added in 5.1.14\n* It's easy to add the bundle configuration to the bundle itself eg: \n** If the bundle is named: `tagged-test.bundle`, the filter can look like this: `[tag[test]] tagged-test.bundle`\n* Have a closer look at the ~$:/ControlPanel: Bundles tab for more [[settings|$:/plugins/wikilabs/bundler/ui/ControlPanel/bundler-config]]. \n"
}
}
}
{{$:/plugins/wikilabs/bundler/ui/BundlesList}}
---
<$reveal type="match" state="$:/config/wikilabs/enableBundles" text="enabled">
{{$:/plugins/wikilabs/bundler/ui/BundlesFiltered}}
</$reveal>
<$reveal type="nomatch" state="$:/config/wikilabs/enableBundles" text="enabled">
[[Enable Filtered Bundles|$:/plugins/wikilabs/bundler/ui/ControlPanel/bundler-config]]
</$reveal>
{
"tiddlers": {
"$:/core/macros/tabs": {
"title": "$:/core/macros/tabs",
"tags": "$:/tags/Macro",
"text": "\\define tabs(tabsList,default,state:\"$:/state/tab\",class,template)\n<div class=\"tc-tab-set $class$\">\n<div class=\"tc-tab-buttons $class$\">\n<$list filter=\"$tabsList$\" variable=\"currentTab\"><$set name=\"save-currentTiddler\" value=<<currentTiddler>>><$tiddler tiddler=<<currentTab>>><$button set=<<qualify \"$state$\">> setTo=<<currentTab>> default=\"$default$\" selectedClass=\"tc-tab-selected\" tooltip={{!!tooltip}}>\n<$transclude tiddler={{!!icon}}/>\n<$tiddler tiddler=<<save-currentTiddler>>>\n<$set name=\"tv-wikilinks\" value=\"no\">\n<$transclude tiddler=<<currentTab>> field=\"caption\">\n<$macrocall $name=\"currentTab\" $type=\"text/plain\" $output=\"text/plain\"/>\n</$transclude>\n</$set></$tiddler></$button><span class=\"wltc-link-to-tab\"><$link to=<<currentTiddler>> >{{$:/core/images/link}}</$link></span></$tiddler></$set></$list>\n</div>\n<div class=\"tc-tab-divider $class$\"/>\n<div class=\"tc-tab-content $class$\">\n<$list filter=\"$tabsList$\" variable=\"currentTab\">\n\n<$reveal type=\"match\" state=<<qualify \"$state$\">> text=<<currentTab>> default=\"$default$\">\n\n<$transclude tiddler=\"$template$\" mode=\"block\">\n\n<$transclude tiddler=<<currentTab>> mode=\"block\"/>\n\n</$transclude>\n\n</$reveal>\n\n</$list>\n</div>\n</div>\n\\end"
},
"$:/core/ui/ControlPanel/Settings/link-to-tabs": {
"title": "$:/core/ui/ControlPanel/Settings/link-to-tabs",
"caption": "Link-to-Tabs plugin",
"tags": "$:/tags/ControlPanel/Settings",
"text": "<$checkbox tiddler=\"$:/plugins/wikilabs/link-to-tabs/config\" field=\"show-all-links\" checked=\"inline\" unchecked=\"none\" default=\"none\"> Show internal tab link for ''all tabs''</$checkbox>\n\n<$checkbox tiddler=\"$:/plugins/wikilabs/link-to-tabs/config\" field=\"show-single-link\" checked=\"inline\" unchecked=\"none\" default=\"inline\"> Show internal tab link for ''selected tabs''</$checkbox>\n"
},
"$:/plugins/wikilabs/link-to-tabs/config": {
"title": "$:/plugins/wikilabs/link-to-tabs/config",
"show-all-links": "none",
"show-single-link": "inline",
"text": "This tiddler is used to configure the \"Link-to-tabs\" plugin behaviour. \n\nThere are 2 fields, which are used by [[$:/plugins/wikilabs/link-to-tabs/styles]] enable and disable the internal links. \n\n* show-all-links: {{!!show-all-links}}\n* show-single-link: {{!!show-single-link}}\n"
},
"$:/plugins/wikilabs/link-to-tabs/license": {
"title": "$:/plugins/wikilabs/link-to-tabs/license",
"text": "Link-to-Tabs-Macro (c) Mario Pietsch - 2016-2018\n\nhttps://opensource.org/licenses/BSD-3-Clause"
},
"$:/plugins/wikilabs/link-to-tabs/styles": {
"title": "$:/plugins/wikilabs/link-to-tabs/styles",
"tags": "$:/tags/Stylesheet",
"text": "<pre>\n\n.wltc-link-to-tab {\n display: {{$:/plugins/wikilabs/link-to-tabs/config!!show-all-links}};\n position: relative;\n top: -1em;\n left: -1.3em;\n font-size: 0.7em;\n opacity: 0.7;\n margin-right: -1em;\n}\n\n.wltc-link-to-tab svg{\n width: 1.4em;\n height: 1.4em;\n}\n\n.wltc-link-to-tab:hover {\n opacity: 1;\n}\n\n.tc-tab-selected + .wltc-link-to-tab {\n display: {{$:/plugins/wikilabs/link-to-tabs/config!!show-single-link}};\n}\n\n.tc-vertical > .wltc-link-to-tab {\n top: -1.9em;\n left: 0;\n height: 0;\n float: right;\n}\n\n</pre>"
},
"$:/plugins/wikilabs/link-to-tabs/readme": {
"title": "$:/plugins/wikilabs/link-to-tabs/readme",
"text": "This plugin adds a little link icon to every tab. \n\n''Important:'' This plugin changes the core tabs macro.\n\n! Lint-to-Tabs Settings\n\n{{$:/core/ui/ControlPanel/Settings/link-to-tabs}}"
}
}
}
{
"tiddlers": {
"$:/plugins/wikilabs/tocP/Stylesheet": {
"created": "20170201173552575",
"modified": "20170201214003877",
"tags": "$:/tags/Stylesheet",
"title": "$:/plugins/wikilabs/tocP/Stylesheet",
"type": "text/css",
"text": ".tc-tabbed-table-of-contents .wltc-btn-new-child {\n display: none;\n}\n\n.tocp .tc-tiddlylink {\n color: green;\n}"
},
"$:/plugins/wikilabs/tocP/macros": {
"created": "20170127103951869",
"modified": "20170202134116229",
"tags": "$:/tags/Macro",
"title": "$:/plugins/wikilabs/tocP/macros",
"type": "text/vnd.tiddlywiki",
"text": "\\define tocP-caption()\n<$set name=\"tv-wikilinks\" value=\"no\">\n <$transclude field=\"caption\">\n <span title={{!!tooltip}}><$view field=\"title\"/></span>\n </$transclude>\n</$set>\n\\end\n\n\\define tocP-body(tag,sort:\"\",itemClassFilter,exclude,path,field:\"parent\")\n<ol class=\"tc-toc\">\n <$list filter=\"\"\"[has[$field$]$field$[$tag$]!has[draft.of]$sort$] $exclude$\"\"\">\n <$vars item=<<currentTiddler>> path=\"\"\"$path$/$tag$\"\"\" excluded=\"\"\"$exclude$ -[[$tag$]]\"\"\" field=\"\"\"$field$\"\"\">\n <$set name=\"toc-item-class\" filter=\"\"\"$itemClassFilter$\"\"\" emptyValue=\"toc-item\" value=\"toc-item-selected\">\n <li class=<<toc-item-class>>>\n <$list filter=\"[all[current]toc-link[no]]\" emptyMessage=\"<$link tooltip={{!!tooltip}}><$view field='caption'><$view field='title'/></$view></$link>\">\n <<tocP-caption>>\n </$list>\n <$transclude tiddler='$:/config/wikilabs/tocP/newChild'></$transclude>\n <$macrocall $name=\"tocP-body\" tag=<<item>> sort=\"\"\"$sort$\"\"\" itemClassFilter=\"\"\"$itemClassFilter$\"\"\" exclude=<<excluded>> path=<<path>> field=<<field>>/>\n </li>\n </$set>\n </$vars>\n </$list>\n</ol>\n\\end\n\n\\define tocP(tag,sort:\"\",itemClassFilter:\" \",field:\"parent\")\n<<tocP-body tag:\"\"\"$tag$\"\"\" sort:\"\"\"$sort$\"\"\" itemClassFilter:\"\"\"$itemClassFilter$\"\"\" field:\"\"\"$field$\"\"\">>\n\\end\n\n\\define tocP-linked-expandable-body(tag,sort:\"\",itemClassFilter,exclude,path,field:\"parent\")\n<!-- helper function -->\n<$set name=\"toc-state\" value=<<qualify \"\"\"$:/state/toc$path$-$(currentTiddler)$\"\"\">>>\n <$set name=\"toc-item-class\" filter=\"\"\"$itemClassFilter$\"\"\" emptyValue=\"toc-item\" value=\"toc-item-selected\">\n <li class=<<toc-item-class>>>\n <$link>\n <$reveal type=\"nomatch\" state=<<toc-state>> text=\"open\">\n <$button set=<<toc-state>> setTo=\"open\" class=\"tc-btn-invisible\">\n {{$:/core/images/right-arrow}}\n </$button>\n </$reveal>\n <$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n <$button set=<<toc-state>> setTo=\"close\" class=\"tc-btn-invisible\">\n {{$:/core/images/down-arrow}}\n </$button>\n </$reveal>\n <<tocP-caption>>\n </$link>\n <$transclude tiddler='$:/config/wikilabs/tocP/newChild'></$transclude>\n <$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n <$macrocall $name=\"tocP-expandable\" tag=<<currentTiddler>> sort=\"\"\"$sort$\"\"\" itemClassFilter=\"\"\"$itemClassFilter$\"\"\" exclude=\"\"\"$exclude$\"\"\" path=\"\"\"$path$\"\"\" field=\"\"\"$field$\"\"\"/>\n </$reveal>\n </li>\n </$set>\n</$set>\n\\end\n\n\\define tocP-unlinked-expandable-body(tag,sort:\"\",itemClassFilter:\" \",exclude,path,field:\"parent\")\n<!-- helper function -->\n<$set name=\"toc-state\" value=<<qualify \"\"\"$:/state/toc$path$-$(currentTiddler)$\"\"\">>>\n <$set name=\"toc-item-class\" filter=\"\"\"$itemClassFilter$\"\"\" emptyValue=\"toc-item\" value=\"toc-item-selected\">\n <li class=<<toc-item-class>>>\n <$reveal type=\"nomatch\" state=<<toc-state>> text=\"open\">\n <$button set=<<toc-state>> setTo=\"open\" class=\"tc-btn-invisible\" tooltip={{!!tooltip}}>\n {{$:/core/images/right-arrow}}\n <<tocP-caption>>\n </$button>\n </$reveal>\n <$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n <$button set=<<toc-state>> setTo=\"close\" class=\"tc-btn-invisible\" tooltip={{!!tooltip}}>\n {{$:/core/images/down-arrow}}\n <<tocP-caption>>\n </$button>\n </$reveal> \n <$transclude tiddler='$:/config/wikilabs/tocP/newChild'></$transclude>\n <$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n <$macrocall $name=\"tocP-expandable\" tag=<<currentTiddler>> sort=\"\"\"$sort$\"\"\" itemClassFilter=\"\"\"$itemClassFilter$\"\"\" exclude=\"\"\"$exclude$\"\"\" path=\"\"\"$path$\"\"\" field=\"\"\"$field$\"\"\"/>\n </$reveal>\n </li>\n </$set>\n</$set>\n\\end\n\n\\define tocP-expandable-empty-message()\n<<tocP-linked-expandable-body tag:\"\"\"$(tag)$\"\"\" sort:\"\"\"$(sort)$\"\"\" itemClassFilter:\"\"\"$(itemClassFilter)$\"\"\" exclude:\"\"\"$(excluded)$\"\"\" path:\"\"\"$(path)$\"\"\" field:\"\"\"$(field)$\"\"\">>\n\\end\n\n\\define tocP-expandable(tag,sort:\"\",itemClassFilter:\" \",exclude,path,field:\"parent\")\n<$vars tag=\"\"\"$tag$\"\"\" sort=\"\"\"$sort$\"\"\" itemClassFilter=\"\"\"$itemClassFilter$\"\"\" excluded=\"\"\"$exclude$ -[[$tag$]]\"\"\" path=\"\"\"$path$/$tag$\"\"\" field=\"\"\"$field$\"\"\">\n <ol class=\"tc-toc toc-expandable\">\n <$list filter=\"\"\"[has[$field$]$field$[$tag$]!has[draft.of]$sort$] $exclude$\"\"\">\n <$list filter=\"[all[current]toc-link[no]]\" emptyMessage=<<tocP-expandable-empty-message>> >\n <$macrocall $name=\"tocP-unlinked-expandable-body\" tag=\"\"\"$tag$\"\"\" sort=\"\"\"$sort$\"\"\" itemClassFilter=\"\"\"$itemClassFilter$\"\"\" exclude=<<excluded>> path=<<path>> field=<<field>> />\n </$list>\n </$list>\n </ol>\n</$vars>\n\\end\n\n\\define tocP-linked-selective-expandable-body(tag,sort:\"\",itemClassFilter:\" \",exclude,path,field:\"parent\")\n<$set name=\"toc-state\" value=<<qualify \"\"\"$:/state/toc$path$-$(currentTiddler)$\"\"\">>>\n <$set name=\"toc-item-class\" filter=\"\"\"$itemClassFilter$\"\"\" emptyValue=\"toc-item\" value=\"toc-item-selected\">\n <li class=<<toc-item-class>>>\n <$link>\n <$list filter=\"\"\"[has[$field$]$field$<currentTiddler>limit[1]]\"\"\" variable=\"ignore\" emptyMessage=\"<$button class='tc-btn-invisible'>{{$:/core/images/blank}}</$button>\">\n <$reveal type=\"nomatch\" state=<<toc-state>> text=\"open\">\n <$button set=<<toc-state>> setTo=\"open\" class=\"tc-btn-invisible\">\n {{$:/core/images/right-arrow}}\n </$button>\n </$reveal>\n <$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n <$button set=<<toc-state>> setTo=\"close\" class=\"tc-btn-invisible\">\n {{$:/core/images/down-arrow}}\n </$button>\n </$reveal>\n </$list>\n <<tocP-caption>> \n </$link>\n <$transclude tiddler='$:/config/wikilabs/tocP/newChild'></$transclude>\n <$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n <$macrocall $name=\"tocP-selective-expandable\" tag=<<currentTiddler>> sort=\"\"\"$sort$\"\"\" itemClassFilter=\"\"\"$itemClassFilter$\"\"\" exclude=\"\"\"$exclude$\"\"\" path=\"\"\"$path$\"\"\" field=\"\"\"$field$\"\"\"/>\n </$reveal>\n </li>\n </$set>\n</$set>\n\\end\n\n\\define tocP-unlinked-selective-expandable-body(tag,sort:\"\",itemClassFilter:\" \",exclude,path,field:\"parent\")\n<$set name=\"toc-state\" value=<<qualify \"\"\"$:/state/toc$path$-$(currentTiddler)$\"\"\">>>\n <$set name=\"toc-item-class\" filter=\"\"\"$itemClassFilter$\"\"\" emptyValue=\"toc-item\" value=\"toc-item-selected\">\n <li class=<<toc-item-class>>>\n <$list filter=\"\"\"[has[$field$]$field$<currentTiddler>limit[1]]\"\"\" variable=\"ignore\" emptyMessage=\"<$button class='tc-btn-invisible'>{{$:/core/images/blank}}</$button> <$view field='caption'><$view field='title'/></$view>\">\n <$reveal type=\"nomatch\" state=<<toc-state>> text=\"open\">\n <$button set=<<toc-state>> setTo=\"open\" class=\"tc-btn-invisible\" tooltip={{!!tooltip}}>\n {{$:/core/images/right-arrow}}\n <<tocP-caption>>\n </$button>\n </$reveal>\n <$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n <$button set=<<toc-state>> setTo=\"close\" class=\"tc-btn-invisible\" tooltip={{!!tooltip}}>\n {{$:/core/images/down-arrow}}\n <<tocP-caption>>\n </$button> \n </$reveal> \n </$list>\n <$transclude tiddler='$:/config/wikilabs/tocP/newChild'></$transclude>\n <$reveal type=\"match\" state=<<toc-state>> text=\"open\">\n <$macrocall $name=\"\"\"tocP-selective-expandable\"\"\" tag=<<currentTiddler>> sort=\"\"\"$sort$\"\"\" itemClassFilter=\"\"\"$itemClassFilter$\"\"\" exclude=\"\"\"$exclude$\"\"\" path=\"\"\"$path$\"\"\" field=\"\"\"$field$\"\"\"/>\n </$reveal>\n </li>\n </$set>\n</$set>\n\\end\n\n\\define tocP-selective-expandable-empty-message()\n<<tocP-linked-selective-expandable-body tag:\"\"\"$(tag)$\"\"\" sort:\"\"\"$(sort)$\"\"\" itemClassFilter:\"\"\"$(itemClassFilter)$\"\"\" exclude:\"\"\"$(excluded)$\"\"\" path:\"\"\"$(path)$\"\"\" field:\"\"\"$(field)$\"\"\">>\n\\end\n\n\\define tocP-selective-expandable(tag,sort:\"\",itemClassFilter,exclude,path,field:\"parent\")\n<$vars tag=\"\"\"$tag$\"\"\" sort=\"\"\"$sort$\"\"\" itemClassFilter=\"\"\"$itemClassFilter$\"\"\" excluded=\"\"\"$exclude$ -[[$tag$]]\"\"\" path=\"\"\"$path$/$tag$\"\"\" field=\"\"\"$field$\"\"\">\n <ol class=\"tc-toc toc-selective-expandable\">\n <$list filter=\"\"\"[has[$field$]$field$[$tag$]!has[draft.of]$sort$] $exclude$\"\"\">\n <$list filter=\"[all[current]toc-link[no]]\" variable=\"ignore\" emptyMessage=<<tocP-selective-expandable-empty-message>> >\n <$macrocall $name=tocP-unlinked-selective-expandable-body tag=\"\"\"$tag$\"\"\" sort=\"\"\"$sort$\"\"\" itemClassFilter=\"\"\"$itemClassFilter$\"\"\" exclude=<<excluded>> path=<<path>> field=<<field>> >\n </$list>\n </$list>\n </ol>\n</$vars>\n\\end\n\n\\define tocP-tabbed-selected-item-filter(selectedTiddler)\n[all[current]field:title{$selectedTiddler$}]\n\\end\n\n\\define tocP-tabbed-external-nav(tag,sort:\"\",selectedTiddler:\"$:/temp/toc/selectedTiddler\",unselectedText,missingText,template:\"\")\n<$tiddler tiddler={{$selectedTiddler$}}>\n <div class=\"tc-tabbed-table-of-contents\">\n <$linkcatcher to=\"$selectedTiddler$\">\n <div class=\"tc-table-of-contents\">\n <$macrocall $name=\"tocP-selective-expandable\" tag=\"\"\"$tag$\"\"\" sort=\"\"\"$sort$\"\"\" itemClassFilter=<<toc-tabbed-selected-item-filter selectedTiddler:\"\"\"$selectedTiddler$\"\"\">>/>\n </div>\n </$linkcatcher>\n <div class=\"tc-tabbed-table-of-contents-content\">\n <$reveal state=\"\"\"$selectedTiddler$\"\"\" type=\"nomatch\" text=\"\">\n <$transclude mode=\"block\" tiddler=\"$template$\">\n <h1><<tocP-caption>></h1>\n <$transclude mode=\"block\">$missingText$</$transclude>\n </$transclude>\n </$reveal>\n <$reveal state=\"\"\"$selectedTiddler$\"\"\" type=\"match\" text=\"\">\n $unselectedText$\n </$reveal>\n </div>\n </div>\n</$tiddler>\n\\end\n\n\\define tocP-tabbed-internal-nav(tag,sort:\"\",selectedTiddler:\"$:/temp/toc/selectedTiddler\",unselectedText,missingText,template:\"\")\n<$linkcatcher to=\"\"\"$selectedTiddler$\"\"\">\n <$macrocall $name=\"tocP-tabbed-external-nav\" tag=\"\"\"$tag$\"\"\" sort=\"\"\"$sort$\"\"\" selectedTiddler=\"\"\"$selectedTiddler$\"\"\" unselectedText=\"\"\"$unselectedText$\"\"\" missingText=\"\"\"$missingText$\"\"\" template=\"\"\"$template$\"\"\"/>\n</$linkcatcher>\n\\end\n\n"
},
"$:/plugins/wikilabs/tocP/toggle-new-child-button": {
"created": "20170127145849380",
"modified": "20170201213725315",
"tags": "",
"title": "$:/plugins/wikilabs/tocP/toggle-new-child-button",
"type": "text/vnd.tiddlywiki",
"text": "<$button>\n<$action-setfield $tiddler=\"$:/config/wikilabs/tocP/newChild\" text=\"<span class='wltc-btn-new-child'>{{||$:/wikilabs/ui/buttons/new-child-alone}}</span>\"/>\nEnable \"New Child\" buttons\n</$button>\n<$button>\n<$action-deletetiddler $tiddler=\"$:/config/wikilabs/tocP/newChild\"/>\nDisable \"New Child\" buttons\n</$button>"
},
"$:/wikilabs/images/new-child-alone": {
"created": "20170127140027445",
"modified": "20170201213725304",
"tags": "",
"title": "$:/wikilabs/images/new-child-alone",
"type": "text/vnd.tiddlywiki",
"text": "<svg class=\"tc-image-edit-button tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\">\n\t<path d=\"m6.9,28a6.7,7,0,1,0,0,14h41a6.7,7,0,1,0,0,-14h-41z\"/>\n\t<path d=\"m27,4.6a6.7,7,0,0,0,-6.6,7v47a6.7,7,0,1,0,13,0v-47a6.7,7,0,0,0,-6,-7.4z\"/>\n\t<path d=\"m78,39c-12,0-22,10-22,22s10,22,22,22,22-10,22-22-10-22-22-22zm0,12c5.9,0,11,4.7,11,11,0,5.9-4.7,11-11,11-5.9,0-11-4.7-11-11,0-5.9,4.7-11,11-11z\"/>\n\t<path d=\"m78,79c-6.7,0-13,1.5-18,4.4s-9.2,7.9-9.2,14v24a6.6,6.6,0,1,0,13,0v-24c0-0.36,0.3-1.5,2.7-2.9s6.5-2.6,11-2.6c4.6,0,8.7,1.2,11,2.6,2.4,1.4,2.7,2.5,2.7,2.9v24a6.6,6.6,0,1,0,13,0v-24c0-6.3-4.3-11-9.2-14-5-2.9-11-4.4-18-4.4z\"/>\n</svg>\n\n"
},
"$:/wikilabs/images/new-child": {
"created": "20170127121332632",
"modified": "20170201213725300",
"tags": "$:/tags/Image",
"title": "$:/wikilabs/images/new-child",
"type": "text/vnd.tiddlywiki",
"text": "<svg class=\"tc-image-edit-button tc-image-button\" viewBox=\"0 0 128 128\" width=\"22pt\" height=\"22pt\">\n\t<path d=\"m86,21a5.8,6,0,1,0,0,12h36a5.8,6,0,1,0,0,-12h-36z\"/>\n\t<path d=\"M100,0.33a5.8,6,0,0,0,-2,6.1v40a5.8,6,0,1,0,12,0v-40a5.8,6,0,0,0,-5.9,-6.1z\"/>\n\t<path d=\"m-0.0099,62c2,0.41,4.1,0.66,6.2,0.66,17,0,31-14,31-31s-14-31-31-31c-2.1,0-4.2,0.22-6.2,0.62v15c1.9-0.74,4-1.2,6.2-1.2,9.5,0,17,7.6,17,17,0,9.5-7.6,17-17,17-2.2,0-4.3-0.45-6.2-1.2v15z\"/>\n\t<path d=\"M-0.0099,76h6.2c6.3,0,12,1.7,15,4,3.4,2.2,4.4,4.3,4.4,5.8v35a7.6,8,0,0,0,15,0v-35c0-8.4-5.2-15-12-19-6.4-4.2-14-6.4-23-6.4-2.1,0-4.2,0.12-6.2,0.38v16z\"/>\n\t<path d=\"m73,39c-12,0-22,10-22,22s10,22,22,22,22-10,22-22-10-22-22-22zm0,12c5.9,0,11,4.7,11,11,0,5.9-4.7,11-11,11-5.9,0-11-4.7-11-11,0-5.9,4.7-11,11-11z\"/>\n\t<path d=\"m73,79c-6.7,0-13,1.5-18,4.4s-9.2,7.9-9.2,14v24a6.6,6.6,0,1,0,13,0v-24c0-0.36,0.3-1.5,2.7-2.9s6.5-2.6,11-2.6c4.6,0,8.7,1.2,11,2.6,2.4,1.4,2.7,2.5,2.7,2.9v24a6.6,6.6,0,1,0,13,0v-24c0-6.3-4.3-11-9.2-14-5-2.9-11-4.4-18-4.4z\"/>\n</svg>\n"
},
"$:/wikilabs/ui/buttons/new-child-alone": {
"caption": "{{$:/wikilabs/images/new-child-alone}} NewChildHere",
"created": "20170127140235853",
"description": "NewChildHere & add parent field",
"modified": "20170202134649899",
"tags": "$:/tags/ViewToolbar",
"title": "$:/wikilabs/ui/buttons/new-child-alone",
"type": "text/vnd.tiddlywiki",
"text": "\\define newHereValue()\n$(currentTiddler)$\n\\end\n\n\\define newChildButton(field:\"parent\")\n<$button tooltip=\"\"\"New Child -> \"$field$: $(currentTiddler)$\" \"\"\" aria-label=\"new child here\" class=<<tv-config-toolbar-class>>>\n<$action-sendmessage $message=\"tm-new-tiddler\" $field$=<<newHereValue>>/>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/wikilabs/images/new-child-alone}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text=\"New Child Here\"/></span>\n</$list>\n</$button>\n\\end\n<$macrocall $name=newChildButton field=<<field>> />"
},
"$:/wikilabs/ui/buttons/new-child-here": {
"caption": "{{$:/wikilabs/images/new-child}} NewChildHere",
"created": "20170127114258607",
"description": "NewChildHere & add parent field",
"modified": "20170201213725310",
"tags": "$:/tags/ViewToolbar",
"title": "$:/wikilabs/ui/buttons/new-child-here",
"type": "text/vnd.tiddlywiki",
"text": "\\define newHereValue()\n$(currentTiddler)$\n\\end\n\\define newChildButton()\n<$button tooltip=\"Create a new Child tiddler & add 'parent' field\" aria-label=\"create a new child\" class=<<tv-config-toolbar-class>>>\n<$action-sendmessage $message=\"tm-new-tiddler\" parent=<<newHereValue>>/>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/wikilabs/images/new-child}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text=\"New Child Here\"/></span>\n</$list>\n</$button>\n\\end\n<<newChildButton>>"
},
"$:/plugins/wikilabs/tocP/license": {
"title": "$:/plugins/wikilabs/tocP/license",
"text": "Parent Based TOC Plugin (c) Mario Pietsch - 2017\n\nhttps://opensource.org/licenses/BSD-3-Clause"
},
"$:/plugins/wikilabs/tocP/readme": {
"title": "$:/plugins/wikilabs/tocP/readme",
"text": "This plugin contains several \"Table of Content\" macros, that have the same parameters as the core toc macro. The main difference is, that it doesn't use tags to create the TOC scructure. It uses a \"parent\" field in so called \"child - tiddlers\".\n\n''Detailed Documentation''\n\nMore details about this plugin can be found at: https://wikilabs.github.io/editions/tocP\nMore plugins, themes and editions can be found at: https://wikilabs.github.io/\n\n''Important''\n\nThese macros are intended to be \"drop in replacement\" of the core macros. ... They have the exact same parameter names. Instead of \"parent\" it still uses \"tag\" as the first parameter. \n\n''Usage''\n\n```\n<div class=\"tocp tc-table-of-contents\">\n<<tocP root>>\n</div>\n\n<div class=\"tocp tc-table-of-contents\">\n<<tocP-expandable root>>\n</div>\n\n<div class=\"tocp tc-table-of-contents\">\n<<tocP-selective-expandable root field:\"any-name\">>\n</div>\n\n<div class=\"tc-table-of-contents\">\n<<tocP-tabbed-internal-nav root>>\n</div>\n\n<div class=\"tc-table-of-contents\">\n<<tocP-tabbed-external-nav root>>\n</div>\n\n```\n\n''Simple Configuration''\n\n* Enable / Disable the inline \"New Child\" button\n** {{$:/plugins/wikilabs/tocP/toggle-new-child-button}}\n\n''Known Problems''\n\n* The \"tabbed\" versions don't show the \"New Child\" buttons\n* Color customisation isn't possible atm"
}
}
}
{
"tiddlers": {
"$:/plugins/wikilabs/uni-link/aka-footer/template": {
"title": "$:/plugins/wikilabs/uni-link/aka-footer/template",
"type": "text/vnd.tiddlywiki",
"text": "''Note'': This tiddler has the following aliases || <<showAliases delim:\" ||\">>"
},
"$:/plugins/wikilabs/uni-link/aka-footer": {
"title": "$:/plugins/wikilabs/uni-link/aka-footer",
"tags": "$:/tags/ViewTemplate",
"type": "text/vnd.tiddlywiki",
"text": "<$list filter=\"[all[current]has[aliases]]\">\n<br/>\n<hr>\n\n{{||$:/plugins/wikilabs/uni-link/aka-footer/template}}\n</$list>"
},
"$:/plugins/wikilabs/uni-link/aka-macros": {
"title": "$:/plugins/wikilabs/uni-link/aka-macros",
"tags": "$:/tags/Macro",
"type": "text/vnd.tiddlywiki",
"text": "\\define tooltip() Alias: <<currentTiddler>>\n\\define aka(target)\n\\whitespace trim\n<$list filter=\"[[$target$]is[alias]]\" variable=ali emptyMessage=\"\"\"<$link tooltip=\"Alias not defined!\" to=\"?\"><span class=\"uni-alias-missing\">$target$</span></$link>\"\"\">\n<$list filter=\"[has[aliases]!has[draft.of]]\">\n <$list filter=\"[enlist{!!aliases}regexp[^$target$$(?i)]]\" variable=\"dummy\">\n <$link tooltip=<<tooltip>> >\n\t\t<span class=\"uni-alias\">\n\t\t\t<$set name=\"tv-wikilinks\" value=\"no\">$target$</$set>\n\t\t</span></$link>\n </$list>\n</$list>\n</$list>\n\\end\n\n\\define aka-no-links(target)\n\\whitespace trim\n<$list filter=\"[[$target$]is[alias]]\" variable=ali emptyMessage=\"\"\"<$link tooltip=\"Alias not defined!\" to=\"?\">$target$</$link>\"\"\">\n<$list filter=\"[has[aliases]!has[draft.of]]\">\n <$list filter=\"[enlist{!!aliases}regexp[^$target$$(?i)]]\" variable=\"dummy\">\n <span><<currentTiddler>></span>\n </$list>\n</$list>\n</$list>\n\\end\n\n\\define showAliases(delim:\",\")\n<$list filter=\"[list[!!aliases]butlast[]]\"><$view field=title/>$delim$ </$list><$list filter=\"[list[!!aliases]last[]]\"><$view field=title/></$list>\n\\end\n\n\\define listAliases()\n<$list filter=\"[has[aliases]]\"><$link to=<<currentTiddler>> ><<currentTiddler>></$link> - <<showAliases>><br/></$list>\n\\end\n\n<pre><$view field=\"text\"/></pre>"
},
"$:/plugins/wikilabs/uni-link/alias-list": {
"title": "$:/plugins/wikilabs/uni-link/alias-list",
"type": "text/vnd.tiddlywiki",
"text": "<<listAliases>>"
},
"$:/plugins/wikilabs/uni-link/backlinks-template": {
"title": "$:/plugins/wikilabs/uni-link/backlinks-template",
"text": "!!! Uni-links\n\n| Link | Result |h\n|`[[default prettylink|tiddler-with-caption]]` |[[default prettylink|tiddler-with-caption]] |\n|`[[tiddler-with-caption]]` |[[tiddler-with-caption]] |\n|`[[tiddler-with-subtitle]]` |[[tiddler-with-subtitle]] |\n|`[[tiddler-with-subtitle-and-caption]]` |[[tiddler-with-subtitle-and-caption]] |\n|`[[tiddler-with-subtitle-and-caption|]]` |[[tiddler-with-subtitle-and-caption|]] ... but don't use them!|\n|`[[tiddler doesn't exist]]` |[[tiddler doesn't exist]] |\n\n!!! Alias Links\n\n| Link | Result |h\n|`[[alias|?]]` |[[alias|?]] |\n"
},
"$:/plugins/wikilabs/uni-link/filters/aliasbacklinks.js": {
"title": "$:/plugins/wikilabs/uni-link/filters/aliasbacklinks.js",
"text": "/*\\\ntitle: $:/plugins/wikilabs/uni-link/filters/aliasbacklinks.js\ntype: application/javascript\nmodule-type: filteroperator\n\nFilter operator for returning all the backlinks from a tiddler\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.aliasbacklinks = function(source,operator,options) {\n\tvar results = [];\n\tsource(function(tiddler,title) {\n\t\t$tw.utils.pushTop(results,options.wiki.getTiddlerAliasBacklinks(title));\n\t});\n\treturn results;\n};\n\n})();\n\n\n\n///*\\\n//title: $:/core/modules/filters/aliases.js\n//type: application/javascript\n//module-type: filteroperator\n//\n//Filter operator for returning all the alias-backlinks from a tiddler\n//\n//\\*/\n//(function(){\n//\n///*jslint node: true, browser: true */\n///*global $tw: false */\n//\"use strict\";\n//\n///*\n//Export our filter function\n//*/\n//exports.aliases = function(source,operator,options) {\n//\tvar results = [],\n//\t\tfield = operator.operand || \"aliases\";\n//\n//\t\tsource(function(tiddler,title) {\n//\t\t\tif(tiddler) {\n//\t\t\t\tvalue = (field === \"title\") ? title : tiddler.getFieldString(field);\n//\t\t\t\tif(!$tw.utils.hop(values,value)) {\n//\t\t\t\t\tvalues[value] = true;\n//\t\t\t\t\tresults.push(title);\n//\t\t\t\t}\n//\t\t\t}\n//\t\t});\n//\n//\tsource(function(tiddler,title) {\n//\t\t$tw.utils.pushTop(results,options.wiki.getTiddlerAliases(title));\n//\t});\n//\treturn results;\n//};\n//\n//})();\n//\n//\n\n///*\\\n//title: $:/core/modules/filters/each.js\n//type: application/javascript\n//module-type: filteroperator\n//\n//Filter operator that selects one tiddler for each unique value of the specified field.\n//With suffix \"list\", selects all tiddlers that are values in a specified list field.\n//\n//\\*/\n//(function(){\n//\n///*jslint node: true, browser: true */\n///*global $tw: false */\n//\"use strict\";\n//\n///*\n//Export our filter function\n//*/\n//exports.each = function(source,operator,options) {\n//\tvar results =[] ,\n//\t\tvalue,values = {},\n//\t\tfield = operator.operand || \"title\";\n//\tif(operator.suffix !== \"list-item\") {\n//\t\tsource(function(tiddler,title) {\n//\t\t\tif(tiddler) {\n//\t\t\t\tvalue = (field === \"title\") ? title : tiddler.getFieldString(field);\n//\t\t\t\tif(!$tw.utils.hop(values,value)) {\n//\t\t\t\t\tvalues[value] = true;\n//\t\t\t\t\tresults.push(title);\n//\t\t\t\t}\n//\t\t\t}\n//\t\t});\n//\t} else {\n//\t\tsource(function(tiddler,title) {\n//\t\t\tif(tiddler) {\n//\t\t\t\t$tw.utils.each(\n//\t\t\t\t\toptions.wiki.getTiddlerList(title,field),\n//\t\t\t\t\tfunction(value) {\n//\t\t\t\t\t\tif(!$tw.utils.hop(values,value)) {\n//\t\t\t\t\t\t\tvalues[value] = true;\n//\t\t\t\t\t\t\tresults.push(value);\n//\t\t\t\t\t\t}\n//\t\t\t\t\t}\n//\t\t\t\t);\n//\t\t\t}\n//\t\t});\n//\t}\n//\treturn results;\n//};\n//\n//})();\n",
"type": "application/javascript",
"module-type": "filteroperator"
},
"$:/plugins/wikilabs/uni-link/filters/all/aliases.js": {
"title": "$:/plugins/wikilabs/uni-link/filters/all/aliases.js",
"text": "/*\\\ntitle: $:/plugins/wikilabs/uni-link/filters/all/aliases.js\ntype: application/javascript\nmodule-type: allfilteroperator\n\nFilter function for [all[aliases]]\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.aliases = function(source,prefix,options) {\n\treturn options.wiki.getAllAliases();\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "allfilteroperator"
},
"$:/plugins/wikilabs/uni-link/filters/is/alias.js": {
"title": "$:/plugins/wikilabs/uni-link/filters/is/alias.js",
"text": "/*\\\ntitle: $:/plugins/wikilabs/uni-link/filters/is/alias.js\ntype: application/javascript\nmodule-type: isfilteroperator\n\nFilter function for [is[alias]]\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nExport our filter function\n*/\nexports.alias = function(source,prefix,options) {\n\tvar results = [],\n\t\taliases = options.wiki.getAllAliases();\n\n\tif(prefix === \"!\") {\n\t\tsource(function(tiddler,title) {\n\t\t\ttitle = title.toLowerCase();\n\t\t\tif (aliases.indexOf(title) === -1) results.push(title);\n\t\t});\n\t} else {\n\t\tsource(function(tiddler,title) {\n\t\t\ttitle = title.toLowerCase();\n\t\t\tif (aliases.indexOf(title) !== -1) results.push(title);\n\t\t});\n\t}\n\treturn results;\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "isfilteroperator"
},
"$:/plugins/wikilabs/uni-link/history": {
"title": "$:/plugins/wikilabs/uni-link/history",
"text": "V 0.3.3 - 2018.08.06\n\n* fix [[issue 19|https://github.com/wikilabs/plugins/issues/19]] Alias References behaviour\n\nV 0.3.2 - 2018.02.02\n\n* new Undefined Aliases Sidebar tab under More: Aliases\n* `[[?]aliasbacklinks[]sort[title]]` shows a list of tiddlers that contain undefined alias links\n\nV 0.3.1 - 2018.01.31\n\n* fixed: [[CamelCase]] or [[$:/system]] tiddler \"double linking\"\n* [[NaturaL sElEcTiOn|?]] .. is a valid alias now. Same problem as above!\n\nV 0.3.0 - 2018.01.27\n\n* add: styling possibility for missing aliases\n* improve: history and copyright\n\nV 0.2.1 - 2018.01.27\n\n* fix: uni-link creates an unused a-element\n\nV 0.2.0 - 2017.12.15\n\n* added: [[alias|?]] link syntax\n** using aka-makros for tiddler alias handling\n\n* added: Alias backlinks\n** open the tiddler (i)nfo area: References\n\n* added filter operators:\n** is[alias] ... extends the core is operator see: https://tiddlywiki.com/#is Operator\n** all[aliases] ... extends the core all operator see: https://tiddlywiki.com/#all Operator\n\n* added: Right-Sidebar: More tab: \"Aliases\"\n** Sorted by Alias\n** Sorted by Tiddler Title\n\n* added: uni-link $:/ControlPanel setting\n* added: different colors for title, caption, subtitle and alias links\n\nV0.1.0 - 2017.07.25\n\n* fix \"backlink\" and \"missing\" issue\n\nV0.0.1 - 2017.07.23\n\n* initial release\n\nalso see: https://wikilabs.github.io/editions/uni-link/#History\n"
},
"$:/plugins/wikilabs/uni-link/license": {
"title": "$:/plugins/wikilabs/uni-link/license",
"text": "[[Uni-Link Plugin|https://wikilabs.github.io/#uni-link]] (C) Mario Pietsch - 2017-2018\n\nhttps://opensource.org/licenses/BSD-3-Clause"
},
"$:/plugins/wikilabs/uni-link/readme": {
"title": "$:/plugins/wikilabs/uni-link/readme",
"subtitle": "\"uni-link\" readme",
"text": "\\define createExampleTiddlers()\n<$button>\n<$action-sendmessage $message=\"tm-new-tiddler\" title=\"tiddler-with-caption\" caption=\"Short Caption\"/>\n<$action-sendmessage $message=\"tm-new-tiddler\" title=\"tiddler-with-subtitle\" subtitle=\"Tiddler With Subtitle Only Defined\"/>\n<$action-sendmessage $message=\"tm-new-tiddler\" title=\"tiddler-with-subtitle-and-caption\" subtitle=\"Tiddler With Subtitle And Caption - using subtitle\" caption=\"capt.ion\"/>\n<$action-sendmessage $message=\"tm-new-tiddler\" title=\"tiddler-with-alias\" aliases=\"alias\"/>\n<$action-sendmessage $message=\"tm-new-tiddler\" title=\"test-links\" text={{$:/plugins/wikilabs/uni-link/backlinks-template!!text}}/>\nCreate \"uni-link\" example tiddlers!\n</$button>\n\\end\n\\define deleteExampleTiddlers()\n<$button>\n<$action-deletetiddler $tiddler=\"tiddler-with-caption\"/>\n<$action-deletetiddler $tiddler=\"tiddler-with-subtitle\"/>\n<$action-deletetiddler $tiddler=\"tiddler-with-subtitle-and-caption\"/>\n<$action-deletetiddler $tiddler=\"tiddler-with-alias\"/>\n<$action-deletetiddler $tiddler=\"test-links\"/>\nDelete example tiddlers!\n</$button>\n\\end\n\n!! Important\n\nThis plugin overwrites the core tiddler: $:/core/ui/TiddlerInfo/References\n\n!! Video\n\n* https://youtu.be/V9l-vipAoNw\n\n!! Examples\n\nYou can use the following buttons to create example tiddlers!\n\n<<createExampleTiddlers>>\n\n!! Uni-link\n\n* A new wikitext parsing rule, that calls the global [[\"uni-link\" macro|$:/plugins/wikilabs/uni-link/uni-link-macro]], instead of referencing the tiddler name. \n\n* It substitues the following tiddler fields: ''subtitle'', ''caption'' and ''title''. From left to right, the first field it finds is shown.\n\n!! Alias\n\n* Alias Link Syntax\n** `[[alias|?]]`\n** using [[aka-makros|$:/plugins/wikilabs/uni-link/aka-macros]] for tiddler alias handling\n\n* Alias Backlinks\n** open the tiddler (i)nfo area: References\n\n* Filter Operators:\n** `is[alias]` ... extends the core `is` operator see: [[https://tiddlywiki.com/#is Operator]]\n** `all[aliases]` ... extends the core `all` operator see: [ext[https://tiddlywiki.com/#all Operator]]\n** `[aliasbacklinks[]]` ... shows a list of all tiddlers that contain alias links\n** `[[?]aliasbacklinks[]sort[title]]` ... shows a list of tiddlers that contain undefined alias links\n\n* Right-Sidebar: More tab: [[Aliases|$:/plugins/wikilabs/uni-link/ui/MoreSideBar/Aliases]]\n** [[Sorted by Alias|$:/plugins/wikilabs/uni-link/ui/MoreSideBar/Aliases/byAlias]]\n** [[Sorted by Tiddler Title|$:/plugins/wikilabs/uni-link/ui/MoreSideBar/Aliases/byTitle]]\n** [[Undefined Aliases|$:/plugins/wikilabs/uni-link/ui/MoreSideBar/Aliases/undefined]]\n\n* uni-link $:/ControlPanel setting\n\n* [[uni-fields|$:/plugins/wikilabs/uni-link/uni-fields.js]] widget, that allows us to assign CSS classes based on tiddler fields existence.\n\n!! Installation\n\n* You can drag & drop import this link: $:/plugins/wikilabs/uni-link<br>\n\n!! Link Styling\n\n* Uni-links are styled like this: $:/plugins/wikilabs/uni-link/styles\n\n!! Examples\n\n<<createExampleTiddlers>> -- <<deleteExampleTiddlers>>\n\n{{$:/plugins/wikilabs/uni-link/backlinks-template}}\n"
},
"$:/config/ShortcutInfo/aliasify": {
"title": "$:/config/ShortcutInfo/aliasify",
"created": "20180909092707749",
"modified": "20180909092719567",
"type": "text/vnd.tiddlywiki",
"text": "{{$:/language/Buttons/Aliasify/Hint}}"
},
"$:/config/shortcuts/aliasify": {
"title": "$:/config/shortcuts/aliasify",
"created": "20180909085336000",
"modified": "20180909091537816",
"tags": "",
"type": "text/vnd.tiddlywiki",
"text": "ctrl-K"
},
"$:/core/images/aliasify": {
"title": "$:/core/images/aliasify",
"created": "20180909082646243",
"modified": "20180909091537847",
"tags": "$:/tags/Image",
"type": "text/vnd.tiddlywiki",
"text": "<svg class=\"tc-linkify-button tc-image-button\" width=\"22pt\" height=\"22pt\" viewBox=\"0 0 128 128\">\n<path d=\"m17.031 31.919h-7.983v64.931h7.983v6.92h-17.031v-78.77h17.031zm24.66 0h-7.983v64.931h7.983v6.92h-17.031v-78.77h17.03v6.919zm44.619 64.931h7.982v-64.93h-7.982v-6.92h17.031v78.77h-17.031zm24.659 0h7.983v-64.93h-7.983v-6.92h17.031v78.77h-17.031z\" fill-rule=\"evenodd\"/>\n <path d=\"m45.188 34.74v62.668h7.3507c-0.02998-28.03 0.06401-32 0.04791-62.668zm28.464 2.6834c-2.6133 0-5.1484 0.36297-7.6094 1.0734-2.4357 0.7104-4.8412 1.7835-7.2261 3.2297v7.159c2.461-1.6999 4.8147-2.9934 7.0728-3.8814 2.2834-0.88801 4.4263-1.3321 6.4306-1.3321 2.7401 0 4.9348 0.69381 6.584 2.0892 1.6745 1.3954 2.5205 3.2238 2.5205 5.4819 0 1.2432-0.33704 2.4589-0.9967 3.6514-0.63429 1.1925-1.6685 2.46-3.1147 3.8047l-3.431 3.3926c-2.2834 2.182-3.7748 4.0915-4.4852 5.7406-0.71039 1.6491-1.0638 3.7627-1.0638 6.3252v5.8556h7.2644v-4.6768c0-1.3193 0.03891-2.3631 0.115-3.1243 0.07613-0.76115 0.19278-1.4031 0.34501-1.9359 0.20297-0.63429 0.5434-1.2858 1.0255-1.9455 0.50744-0.68504 1.3568-1.6251 2.5493-2.8176l3.3447-3.268c2.2834-2.182 3.888-4.1399 4.8014-5.8652 0.91338-1.7506 1.3705-3.592 1.3705-5.5202 0-4.0341-1.4231-7.276-4.2647-9.737-2.8162-2.461-6.5637-3.6993-11.232-3.6993zm-5.5489 48.187v9.6604h7.7244v-9.6604z\" fill-rule=\"evenodd\" stroke-width=\"1.1245\"/>\n</svg>\n"
},
"$:/core/ui/EditorToolbar/aliasify": {
"title": "$:/core/ui/EditorToolbar/aliasify",
"caption": "{{$:/language/Buttons/Aliasify/Caption}}",
"condition": "[<targetTiddler>!has[type]] [<targetTiddler>type[text/vnd.tiddlywiki]]",
"created": "20180909082308073",
"description": "{{$:/language/Buttons/Aliasify/Hint}}",
"icon": "$:/core/images/aliasify",
"list-before": "$:/core/ui/EditorToolbar/mono-block",
"modified": "20180909091537847",
"shortcuts": "((aliasify))",
"tags": "$:/tags/EditorToolbar",
"type": "text/vnd.tiddlywiki",
"text": "<$action-sendmessage\n\t$message=\"tm-edit-text-operation\"\n\t$param=\"wrap-selection\"\n\tprefix=\"[[\"\n\tsuffix=\"|?]]\"\n/>\n"
},
"$:/core/ui/TiddlerInfo/References": {
"title": "$:/core/ui/TiddlerInfo/References",
"caption": "{{$:/language/TiddlerInfo/References/Caption}}",
"tags": "$:/tags/TiddlerInfo",
"type": "text/vnd.tiddlywiki",
"text": "\\define lingo-base() $:/language/TiddlerInfo/\n<$list filter=\"[all[current]backlinks[]sort[title]]\" emptyMessage=<<lingo References/Empty>> template=\"$:/core/ui/ListItemTemplate\"></$list>\n<hr>\n<$list filter=\"[all[current]aliasbacklinks[]sort[title]]\" emptyMessage=<<lingo References/Empty>> template=\"$:/core/ui/ListItemTemplate\"></$list>\n"
},
"$:/language/Buttons/Aliasify/Caption": {
"title": "$:/language/Buttons/Aliasify/Caption",
"created": "20180909082422201",
"modified": "20180909091537832",
"tags": "",
"type": "text/vnd.tiddlywiki",
"text": "alias-link"
},
"$:/language/Buttons/Aliasify/Hint": {
"title": "$:/language/Buttons/Aliasify/Hint",
"created": "20180909082514412",
"modified": "20180909091537832",
"tags": "",
"type": "text/vnd.tiddlywiki",
"text": "Wrap selection in square brackets and add alias postfix"
},
"$:/plugins/wikilabs/uni-link/ui/ControlPanel/settings": {
"title": "$:/plugins/wikilabs/uni-link/ui/ControlPanel/settings",
"caption": "uni-link",
"created": "20171205224905238",
"modified": "20171205230149750",
"tags": "$:/tags/ControlPanel",
"type": "text/vnd.tiddlywiki",
"text": "!! [[Enable Aliases Footer|$:/plugins/wikilabs/uni-link/aka-footer]]\n\n<<<\n<$checkbox tiddler=\"$:/plugins/wikilabs/uni-link/aka-footer\" tag=\"$:/tags/ViewTemplate\"> Enable Aliases Footer</$checkbox>\n<<<\n\n!! Additional Info\n\nSee: [[$:/plugins/wikilabs/uni-link/readme]]\n"
},
"$:/plugins/wikilabs/uni-link/ui/MoreSideBar/Aliases": {
"title": "$:/plugins/wikilabs/uni-link/ui/MoreSideBar/Aliases",
"caption": "Aliases",
"created": "20171214213808142",
"list-before": "$:/core/ui/MoreSideBar/Recent",
"modified": "20171214215245931",
"tags": "$:/tags/MoreSideBar",
"type": "text/vnd.tiddlywiki",
"text": "<div class=\"uni-link-sidebar tc-sidebar-lists\">\n<<tabs \"[all[shadows+tiddlers]tag[$:/plugins/wikilabs/uni-link/ui/MoreSideBar/Aliases]!has[draft.of]]\" \"$:/plugins/wikilabs/uni-link/ui/MoreSideBar/Aliases/byAlias\" \"$:/state/tab/Aliases\" >>\n</div>"
},
"$:/plugins/wikilabs/uni-link/ui/MoreSideBar/Aliases/byAlias": {
"title": "$:/plugins/wikilabs/uni-link/ui/MoreSideBar/Aliases/byAlias",
"caption": "Alias",
"created": "20171214203739053",
"list-before": "$:/core/ui/MoreSideBar/Recent",
"modified": "20171214213743140",
"tags": "$:/plugins/wikilabs/uni-link/ui/MoreSideBar/Aliases",
"type": "text/vnd.tiddlywiki",
"text": "\\whitespace trim\n<$list filter=\"[all[aliases]sort[title]]\" variable=alias>\n <div class=\"tc-menu-list-item\">\n <$macrocall $name=\"aka\" target=<<alias>> />\n <div class=\"tc-menu-list-subitem\">\n <$macrocall $name=\"aka-no-links\" target=<<alias>> />\n </div>\n </div>\n</$list>\n"
},
"$:/plugins/wikilabs/uni-link/ui/MoreSideBar/Aliases/byTitle": {
"title": "$:/plugins/wikilabs/uni-link/ui/MoreSideBar/Aliases/byTitle",
"caption": "Title",
"created": "20171214201333460",
"list-before": "$:/core/ui/MoreSideBar/Recent",
"modified": "20171214213745643",
"tags": "$:/plugins/wikilabs/uni-link/ui/MoreSideBar/Aliases",
"type": "text/vnd.tiddlywiki",
"text": "\\whitespace trim\n<$list filter=\"[has[aliases]sort[title]]\">\n <div class=\"tc-menu-list-item\">\n <$link to=<<currentTiddler>> ><<currentTiddler>></$link>\n <$list filter=\"[list[!!aliases]]\">\n <div class=\"tc-menu-list-subitem\">\n <$view field=title/>\n </div>\n </$list>\n </div>\n</$list>\n"
},
"$:/plugins/wikilabs/uni-link/ui/MoreSideBar/Aliases/undefined": {
"title": "$:/plugins/wikilabs/uni-link/ui/MoreSideBar/Aliases/undefined",
"caption": "Undefined",
"created": "20180202150804918",
"list-before": "$:/core/ui/MoreSideBar/Recent",
"modified": "20180202151517364",
"tags": "$:/plugins/wikilabs/uni-link/ui/MoreSideBar/Aliases",
"type": "text/vnd.tiddlywiki",
"text": "<$list filter=\"[[?]aliasbacklinks[]sort[title]]\" template=\"$:/core/ui/ListItemTemplate\" emptyMessage=\"No undefined Aliases\"/>\n\n---\n\nYou'll need to reload the page, to update this list!\n"
},
"$:/plugins/wikilabs/uni-link/uni-fields.js": {
"title": "$:/plugins/wikilabs/uni-link/uni-fields.js",
"text": "/*\\\ntitle: $:/plugins/wikilabs/uni-link/uni-fields.js\ntype: application/javascript\nmodule-type: widget\n\nunifields widget, derived from Fields Widget\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nvar Widget = require(\"$:/core/modules/widgets/widget.js\").widget;\n\nvar FieldsWidget = function(parseTreeNode,options) {\n\tthis.initialise(parseTreeNode,options);\n};\n\n/*\nInherit from the base widget class\n*/\nFieldsWidget.prototype = new Widget();\n\n/*\nRender this widget into the DOM\n*/\nFieldsWidget.prototype.render = function(parent,nextSibling) {\n\tthis.parentDomNode = parent;\n\tthis.computeAttributes();\n\tthis.execute();\n\tvar textNode = this.document.createTextNode(this.text);\n\tparent.insertBefore(textNode,nextSibling);\n\tthis.domNodes.push(textNode);\n};\n\n/*\nCompute the internal state of the widget\n*/\nFieldsWidget.prototype.execute = function() {\n\t// Get parameters from our attributes\n\tthis.tiddlerTitle = this.getAttribute(\"tiddler\",this.getVariable(\"currentTiddler\"));\n\tthis.template = this.getAttribute(\"template\");\n\tthis.sort = this.getAttribute(\"sort\",\"yes\") === \"yes\";\n\tthis.exclude = this.getAttribute(\"exclude\");\n\tthis.include = this.getAttribute(\"include\",null);\n\tthis.stripTitlePrefix = this.getAttribute(\"stripTitlePrefix\",\"no\") === \"yes\";\n\tthis.sortReverse = this.getAttribute(\"sortReverse\",\"no\") === \"yes\";\n\t// Get the value to display\n\tvar tiddler = this.wiki.getTiddler(this.tiddlerTitle);\n\n\t// Get the inclusion and exclusion list\n\tvar exclude = (this.exclude) ? this.exclude.split(\" \") : [\"text\"];\n\t// If inclusion is defined, everything else is auto excluded\n\tvar include = (this.include) ? this.include.split(\" \") : null;\n\n\t// Compose the template\n\tvar text = [];\n\tif(this.template && tiddler) {\n\t\tvar fields = [];\n\t\tif (include) {\n\t\t\tfor(var i=0; i<include.length; i++) {\n\t\t\t\tif(tiddler.fields[include[i]]) {\n\t\t\t\t\tfields.push(include[i]);\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tfor(var fieldName in tiddler.fields) {\n\t\t\t\tif(exclude.indexOf(fieldName) === -1) {\n\t\t\t\t\tfields.push(fieldName);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tif (this.sort) fields.sort();\n\t\tif (this.sortReverse) fields.reverse();\n\t\tfor(var f=0, fmax=fields.length; f<fmax; f++) {\n\t\t\tfieldName = fields[f];\n//\t\t\tif(exclude.indexOf(fieldName) === -1) {\n\t\t\tvar row = this.template,\n\t\t\t\tvalue = tiddler.getFieldString(fieldName);\n\t\t\tif(this.stripTitlePrefix && fieldName === \"title\") {\n\t\t\t\tvar reStrip = /^\\{[^\\}]+\\}(.+)/mg,\n\t\t\t\t\treMatch = reStrip.exec(value);\n\t\t\t\tif(reMatch) {\n\t\t\t\t\tvalue = reMatch[1];\n\t\t\t\t}\n\t\t\t}\n\t\t\trow = $tw.utils.replaceString(row,\"$name$\",fieldName);\n\t\t\trow = $tw.utils.replaceString(row,\"$value$\",value);\n\t\t\trow = $tw.utils.replaceString(row,\"$encoded_value$\",$tw.utils.htmlEncode(value));\n\t\t\ttext.push(row);\n//\t\t\t}\n\t\t}\n\t}\n\tthis.text = text.join(\"\");\n};\n\n/*\nSelectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering\n*/\nFieldsWidget.prototype.refresh = function(changedTiddlers) {\n\tvar changedAttributes = this.computeAttributes();\n\tif(changedAttributes.tiddler || changedAttributes.template || changedAttributes.exclude || changedAttributes.stripTitlePrefix || changedTiddlers[this.tiddlerTitle]) {\n\t\tthis.refreshSelf();\n\t\treturn true;\n\t} else {\n\t\treturn false;\n\t}\n};\n\nexports[\"uni-fields\"] = FieldsWidget;\n\n})();\n",
"type": "application/javascript",
"module-type": "widget"
},
"$:/plugins/wikilabs/uni-link/uni-link-macro": {
"title": "$:/plugins/wikilabs/uni-link/uni-link-macro",
"tags": "$:/tags/Macro",
"text": "\\define getClass()\n<$uni-fields template=\"uni-$name$ \" include=\"subtitle caption\" sort=\"no\"/> uni-link\n\\end\n\n\\define returnText()\n\\whitespace trim\n<$set name=\"tv-wikilinks\" value=\"no\">\n<span class=<<class>> >\n <$transclude field=subtitle><$transclude field=caption><$transclude field=title/></$transclude></$transclude>\n</span>\n</$set>\n\\end\n\n\\define uni-link(tid)\n\\whitespace trim\n<$tiddler tiddler=\"\"\"$tid$\"\"\">\n <$wikify name=class text=<<getClass>> >\n <$link to=\"\"\"$tid$\"\"\" tooltip=\"\"\"uni-link to: $tid$\"\"\"><<returnText>></$link>\n </$wikify>\n</$tiddler>\n\\end\n\n<pre><$view field=\"text\"/></pre>"
},
"$:/plugins/wikilabs/uni-link/styles": {
"title": "$:/plugins/wikilabs/uni-link/styles",
"tags": "$:/tags/Stylesheet",
"text": ".uni-link {\n color: navy;\n}\n\n.uni-caption {\n color: #2a699f;\n}\n\n.uni-subtitle {\n color: #0e8446;\n}\n\n.uni-alias {\n color: #7557d8;\n}\n\n.uni-alias-missing {\n color: red;\n}\n\n.uni-link-sidebar .tc-tab-buttons {\n padding-top: 0;\n}\n"
},
"$:/plugins/wikilabs/uni-link/uni-link.js": {
"title": "$:/plugins/wikilabs/uni-link/uni-link.js",
"text": "/*\\\ntitle: $:/plugins/wikilabs/uni-link/uni-link.js\ntype: application/javascript\nmodule-type: wikirule\n\nWiki text inline rule for uni link macros. For example:\n\n```\n[[Introduction]] ... uni-link\n\n[[Link description|?]] ... alias-link\n```\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\nexports.name = \"unilink\";\nexports.types = {inline: true};\n\nexports.init = function(parser) {\n\tthis.parser = parser;\n\t// Regexp to match\n\tthis.matchRegExp = /\\[\\[(.*?)(?:\\|(.*?))?\\]\\]/mg;\n};\n\nexports.parse = function() {\n\t// Move past the match\n\tthis.parser.pos = this.matchRegExp.lastIndex;\n\t// Process the link\n\tvar text = this.match[1],\n\t\tlink = this.match[2] || text,\n\t\tcheckAlias = this.match[2] === \"?\",\n\t\tuseUniLink = !(this.match[2] === \"\");\n\n\tif($tw.utils.isLinkExternal(link)) {\n\t\treturn [{\n\t\t\ttype: \"element\",\n\t\t\ttag: \"a\",\n\t\t\tattributes: {\n\t\t\t\thref: {type: \"string\", value: link},\n\t\t\t\t\"class\": {type: \"string\", value: \"tc-tiddlylink-external\"},\n\t\t\t\ttarget: {type: \"string\", value: \"_blank\"},\n\t\t\t\trel: {type: \"string\", value: \"noopener noreferrer\"}\n\t\t\t},\n\t\t\tchildren: [{\n\t\t\t\ttype: \"text\", text: text\n\t\t\t}]\n\t\t}];\n\t} else if(checkAlias) {\n\t\treturn [{\n\t\t\ttype: \"macrocall\",\n\t\t\tname: \"aka\",\n\t\t\tparams: [\n\t\t\t\t{name: \"target\", value: text}\n\t\t\t\t]\n\t\t\t}\n\t\t];\n\t} else if((text == link) && useUniLink) {\n\t\t// we need to add the type: \"link\" element, since the core needs it to find \"backlinks\" and \"missing links\" ...\n\t\treturn [{\n\t\t\ttype: \"link\",\n\t\t\tattributes: {\n\t\t\t\tto: {type: \"string\", value: text},\n\t\t\t\ttag: {type: \"string\", value: \"x\"},\n\t\t\t\toverrideClass: {type: \"string\", value: \"\"},\n\t\t\t\tdraggable: {type: \"string\", value: \"false\"}\n\t\t\t\t}\n\t\t\t},\n\t\t\t{\n\t\t\ttype: \"macrocall\",\n\t\t\tname: \"uni-link\",\n\t\t\tparams: [\n\t\t\t\t{name: \"tid\", value: text}\n\t\t\t\t]\n\t\t\t}\n\t\t];\n\t} else {\n\t\treturn [{\n\t\t\ttype: \"link\",\n\t\t\tattributes: {\n\t\t\t\tto: {type: \"string\", value: link}\n\t\t\t},\n\t\t\tchildren: [{\n\t\t\t\ttype: \"text\", text: text\n\t\t\t}]\n\t\t}];\n\t}\n};\n\n})();\n",
"type": "application/javascript",
"module-type": "wikirule"
},
"$:/plugins/wikilabs/uni-link/wiki-ext.js": {
"title": "$:/plugins/wikilabs/uni-link/wiki-ext.js",
"text": "/*\\\ntitle: $:/plugins/wikilabs/uni-link/wiki-ext.js\ntype: application/javascript\nmodule-type: wikimethod\n\nExtension methods for the $tw.Wiki object\n\nAdds the following properties to the wiki object:\n\nexports.getTiddlerAliasLinks = function(title) {\nexports.getTiddlerAliasBacklinks = function(targetTitle) {\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n//var widget = require(\"$:/core/modules/widgets/widget.js\");\n\nfunction aliasInit(title) {\n\t// Parse the tiddler\n\tvar parser = this.parseTiddler(title);\n\t// Count up the links\n\tvar links = [],\n\t\tcheckParseTree = function(parseTree) {\n\t\t\tfor(var t=0; t<parseTree.length; t++) {\n\t\t\t\tvar parseTreeNode = parseTree[t];\n\t\t\t\tif(parseTreeNode.type === \"macrocall\" && parseTreeNode.name === \"aka\") {\n\t\t\t\t\tvar value = parseTreeNode.params[0].value;\n\t\t\t\t\tif(links.indexOf(value) === -1) {\n\t\t\t\t\t\tlinks.push(value);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif(parseTreeNode.children) {\n\t\t\t\t\tcheckParseTree(parseTreeNode.children);\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\tif(parser) {\n\t\tcheckParseTree(parser.tree);\n\t}\n\t/*\n\tFor every tiddler invoke a callback(title,tiddler) with `this` set to the wiki object. Options include:\n\tsortField: field to sort by\n\texcludeTag: tag to exclude\n\tincludeSystem: whether to include system tiddlers (defaults to false)\n\t*/\n\tvar backlinks = []\n\tthis.forEachTiddler({includeSystem:true}, function(ttl,tiddler) {\n\t\tif (tiddler.fields[\"aliases\"]) {\n\t\t\t// var fields = tiddler.fields[\"aliases\"];\n\t\t\tvar fields = $tw.utils.parseStringArray(tiddler.fields[\"aliases\"]);\n\t\t\tlinks.map( function (el) {\n\t\t\t\tif (fields.indexOf(el) != -1) backlinks.push(ttl);\n\t\t\t})\n\t\t} // if tiddler aliases\n\t});\n\n\tif ((backlinks.length === 0) && (links.length > 0)) {\n\t\tbacklinks[0] = \"?\";\n\t}\n\n\treturn backlinks;\n}\n\nexports.getAllAliases = function() {\n\tvar self = this,\n\t\taliases = \"\";\n\t/*\n\tFor every tiddler invoke a callback(title,tiddler) with `this` set to the wiki object. Options include:\n\tsortField: field to sort by\n\texcludeTag: tag to exclude\n\tincludeSystem: whether to include system tiddlers (defaults to false)\n\t*/\n\tself.forEachTiddler({includeSystem:true}, function(title,tiddler) {\n\t\tif (tiddler.fields[\"aliases\"]) {\n//\t\t\t$tw.utils.pushTop(aliases, this.getCacheForTiddler(title,\"alias\",aliasInit.bind(this, title)));\n\t\t\taliases = aliases + ` ${tiddler.fields.aliases}`;\n\t\t} // if tiddler aliases\n\t});\n\taliases = aliases.toLowerCase();\n\treturn $tw.utils.parseStringArray(aliases);\n};\n\n\n/*\nReturn an array of tiddler titles that are alias linked from the specified tiddler\n*/\nexports.getTiddlerAliasLinks = function(title) {\n\tvar self = this;\n\n\t// We'll cache the links so they only get computed if the tiddler changes\n\treturn this.getCacheForTiddler(title,\"alias\",aliasInit.bind(this, title));\n};\n\n/*\nReturn an array of tiddler titles that link to the specified tiddler\n*/\nexports.getTiddlerAliasBacklinks = function(targetTitle) {\n\tvar self = this,\n\t\tbacklinks = [];\n\tthis.forEachTiddler(function(title,tiddler) {\n\t\tvar links = self.getTiddlerAliasLinks(title);\n\t\tif(links.indexOf(targetTitle) !== -1) {\n\t\t\tbacklinks.push(title);\n\t\t}\n\t});\n\treturn backlinks;\n};\n\n})();\n\n",
"type": "application/javascript",
"module-type": "wikimethod"
}
}
}
;Provides the ability to list field names in the edit-fields-list of each tiddler,
:The Listed fields will be editable in tiddler view mode
:With the macro `<<edit-fields-list>>` placed in $:/PSaT/EditFields/ViewTemplate and Tagged {{$:/tags/ViewTemplate||$:/core/ui/TagTemplate}} you can use to change where the edit fields appear in tiddler view mode.
;If a matching tiddler exists at ~$:/PSaT/EditFields/fields/ //fieldname//
:as listed in the first table below, the tiddler will be used to display the Edit column for that field.
:(the tiddler is transcluded into the table cell)
:the following field definitions exist now;
<table style="width:100%">
<tr>
<th style="width:20%">Fieldname</th>
<th style="width:25%">Edit Field tiddler</th>
<th>Description</th>
</tr>
<$list filter="[prefix[$:/PSaT/EditFields/fields/]sort[]]" variable="EditFieldTiddler">
<$list filter="[<EditFieldTiddler>removeprefix[$:/PSaT/EditFields/fields/]]" variable="fieldname">
<tr>
<td><<fieldname>></td><td><<EditFieldTiddler>></td><td><$view tiddler=<<EditFieldTiddler>> field="description"/></td>
</tr>
</$list>
</$list>
</table>
If not defined in the above the default Edit text field [[textfield|$:/PSaT/EditFields/fieldDefault/textfield]] will be used.
<<rojo "For any field not already in the above table,
you can create a new field definition from one of the following templates, or an existing field.
simply by adding the fieldname to the edit-lists-field it will appear in the edit lists from where you can define it">>
<table style="width:100%">
<tr>
<th style="width:20%">Fieldname</th>
<th style="width:25%">Edit Field definition tiddler</th>
<th>Description</th>
</tr>
<$list filter="[prefix[$:/PSaT/EditFields/fieldDefault]sort[]]" variable="EditFieldTiddler">
<$list filter="[<EditFieldTiddler>removeprefix[$:/PSaT/EditFields/fieldDefault/]]" variable="fieldname">
<tr>
<td><<fieldname>></td><td><<EditFieldTiddler>></td><td><$view tiddler=<<EditFieldTiddler>> field="description"/></td>
</tr>
</$list>
</$list>
</table>
;This solution consists of the above tiddlers (plus any you have added) and the following
<table style="width:100%">
<tr>
<th style="width:20%">Tiddler name</th>
<th>Description</th>
</tr>
<$list filter="[prefix[$:/PSaT/EditFields]sort[]] -[prefix[$:/PSaT/EditFields/fieldDefault]] -[prefix[$:/PSaT/EditFields/fields/]]" variable="EditFieldTiddler">
<tr>
<td><<EditFieldTiddler>></td><td><$view tiddler=<<EditFieldTiddler>> field="description"/></td>
</tr>
</$list>
</table>
;The following macros are defined in this solution
<table style="width:100%">
<tr>
<th style="width:20%">Macro</th>
<th>Description</th>
<th>Defined in</th>
</tr>
<$list filter="[prefix[$:/PSaT/EditFields]]" variable="EditFields-tiddler">
<$list filter="[<EditFields-tiddler>fields[]prefix[macro-]sort[]]" variable="macrofield">
<$list filter="[<macrofield>removeprefix[macro-]]" variable="macroname">
<tr>
<td><<macroname>></td><td><$view tiddler=<<EditFields-tiddler>> field=<<macrofield>>/></td><td><<EditFields-tiddler>></td>
</tr>
</$list>
</$list>
</$list>
</table>
Note: All the above macros operate on the current tiddler so can be embedded in any tiddler, if you want to reference an alternate tiddler, embed it in a listWidget or other widget that changes the currentTiddler value or use the TiddlerWidget.
;Fix
:See [[Test EditFields macros stand alone]]
:Provide edit-fields-list sets? eg task
;Additional design
:Allow caption populated from title
:Promiscuous edit-fields (all fields not just listed)
:Allow remove fieldname from ?
:matching view fields
:Add to edit view? for all fields
:Drop content? eg new url on fieldname?
:Add tooltip relative date to date fields
:Allow copy filter equivalent of current field eg that led to this? or would find this value, perhaps only in $:/PSaT/EditFields with toggle?
:Allow dragable with content of field with {{$:/PSaT/EditFields/icons/drag.svg}}
:Provide drop zone [img width="16px" [$:/PSaT/EditFields/icons/drop.svg]] for each field to drop and replace contents (allow enlarge)
:use range widget to create multiple fields like menu-item-1 ....
<td><$wikify name="choice-filter" text="{{$:/PSaT/EditFields/fields/art!!field-choice-filter}}">
<$select field="multiple" multiple>
<$list filter=<<choice-filter>>>
<option value={{!!title}}>{{!!title}}</option>
</$list>
</$select>
</$wikify></td>
<td> Please select 0, 1 or more values,<br>selected items are highlighted<br>,,//use ctrl-click to select multiple//,,</td>
<td><$wikify name="choice-filter" text="{{$:/PSaT/EditFields/fields/multiple!!field-choice-filter}}">
<$select field="multiple" multiple>
<$list filter=<<choice-filter>>>
<option value={{!!title}}>{{!!title}}</option>
</$list>
</$select>
</$wikify></td>
<td> Please select 0, 1 or more values,<br>selected items are highlighted<br>,,//use ctrl-click to select multiple//,,</td>
<$list filter="[is[current]!has:field[unique-id]]">
<<edit-fields-unique-stamp unique-id "$:/PSaT/EditFields/icons/id-notset.svg">>
</$list>
<$list filter="[is[current]has:field[unique-id]get[unique-id]]" variable="unique-id">
<$list filter="[search:unique-id<unique-id>limit[2]count[]]" variable="numberfound">
<$list filter="[<numberfound>]-[[2]]" variable="null">
<$image source="$:/PSaT/EditFields/icons/id-set.svg" width="32px"/> <<unique-id>>
</$list>
<$list filter="[<numberfound>]-[[1]]" variable="null">
<<edit-fields-unique-stamp unique-id "$:/PSaT/EditFields/icons/id-error.svg">> <<unique-id>>
</$list>
</$list>
</$list>
---
Use limit 2 and detect when only 1 or not 2?
Use count
;Get ID from Created on first click?
;List all tiddlers with unique id and show status and allow click, also list offenders
;Deal with cloning
<$list filter="[is[current]!has:field[unique-id]]">
<<edit-fields-unique-stamp unique-id "$:/PSaT/EditFields/icons/id-notset.svg">>
</$list>
<$list filter="[is[current]has:field[unique-id]get[unique-id]]" variable="unique-id">
<$set name=image value="$:/PSaT/EditFields/icons/id-set.svg">
<$list filter="[search:unique-id<unique-id>]-[is[current]]" variable="numberfound">
<<numberfound>>
<<edit-fields-unique-id unique-id "$:/PSaT/EditFields/icons/id-error.svg">> ''//click again//'' same ID (<<unique-id>>) in "<<tiddlername>>"<br>
</$list>
<<edit-fields-unique-stamp unique-id "$:/PSaT/EditFields/icons/id-set.svg">>
</$set>
</$list>
---
Use limit 2 and detect when only 1 or not 2?
Use count
List all tiddlers with unique id and show status and allow click, also list offenders
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M413.1 222.5l22.2 22.2c9.4 9.4 9.4 24.6 0 33.9L241 473c-9.4 9.4-24.6 9.4-33.9 0L12.7 278.6c-9.4-9.4-9.4-24.6 0-33.9l22.2-22.2c9.5-9.5 25-9.3 34.3.4L184 343.4V56c0-13.3 10.7-24 24-24h32c13.3 0 24 10.7 24 24v287.4l114.8-120.5c9.3-9.8 24.8-10 34.3-.4z"/></svg>
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M34.9 289.5l-22.2-22.2c-9.4-9.4-9.4-24.6 0-33.9L207 39c9.4-9.4 24.6-9.4 33.9 0l194.3 194.3c9.4 9.4 9.4 24.6 0 33.9L413 289.4c-9.5 9.5-25 9.3-34.3-.4L264 168.6V456c0 13.3-10.7 24-24 24h-32c-13.3 0-24-10.7-24-24V168.6L69.2 289.1c-9.3 9.8-24.8 10-34.3.4z"/></svg>
<?xml version="1.0" encoding="utf-8"?>
<!-- Generator: Adobe Illustrator 16.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
width="14px" height="14px" viewBox="0 0 128 128" enable-background="new 0 0 128 128" xml:space="preserve">
<g>
<g>
<path fill="#546E7A" d="M108,8h-8V4c0-2.211-1.789-4-4-4s-4,1.789-4,4v4h-8V4c0-2.211-1.789-4-4-4s-4,1.789-4,4v4h-8V4
c0-2.211-1.789-4-4-4s-4,1.789-4,4v4h-8V4c0-2.211-1.789-4-4-4s-4,1.789-4,4v4h-8V4c0-2.211-1.789-4-4-4s-4,1.789-4,4v4h-8
C11.164,8,4,15.164,4,24v88c0,8.836,7.164,16,16,16h88c8.836,0,16-7.164,16-16V24C124,15.164,116.836,8,108,8z M116,112
c0,4.414-3.59,8-8,8H20c-4.412,0-8-3.586-8-8V24c0-4.416,3.588-8,8-8h8v4c0,2.211,1.789,4,4,4s4-1.789,4-4v-4h8v4
c0,2.211,1.789,4,4,4s4-1.789,4-4v-4h8v4c0,2.211,1.789,4,4,4s4-1.789,4-4v-4h8v4c0,2.211,1.789,4,4,4s4-1.789,4-4v-4h8v4
c0,2.211,1.789,4,4,4s4-1.789,4-4v-4h8c4.41,0,8,3.584,8,8V112z"/>
</g>
</g>
<path fill="#B0BEC5" d="M20,40v72h88V40H20z M84,48v8h-8v-8H84z M52,72h-8v-8h8V72z M60,64h8v8h-8V64z M52,80v8h-8v-8H52z M60,80h8
v8h-8V80z M76,80h8v8h-8V80z M76,72v-8h8v8H76z M68,48v8h-8v-8H68z M52,48v8h-8v-8H52z M28,48h8v8h-8V48z M28,64h8v8h-8V64z M28,80
h8v8h-8V80z M28,104v-8h8v8H28z M44,104v-8h8v8H44z M60,104v-8h8v8H60z M76,104v-8h8v8H76z M100,104h-8v-8h8V104z M100,88h-8v-8h8
V88z M100,72h-8v-8h8V72z M100,56h-8v-8h8V56z"/>
</svg>
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!-- Generator: Adobe Illustrator 17.0.1, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
version="1.1"
id="Layer_1"
x="0px"
y="0px"
width="14px"
height="14px"
viewBox="0 0 50 50"
enable-background="new 0 0 50 50"
xml:space="preserve"
sodipodi:docname="Clock-stamp.svg"
inkscape:version="0.92.2 (5c3e80d, 2017-08-06)"><metadata
id="metadata43"><rdf:RDF><cc:Work
rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title></dc:title></cc:Work></rdf:RDF></metadata><defs
id="defs41" /><sodipodi:namedview
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1"
objecttolerance="10"
gridtolerance="10"
guidetolerance="10"
inkscape:pageopacity="0"
inkscape:pageshadow="2"
inkscape:window-width="2400"
inkscape:window-height="1471"
id="namedview39"
showgrid="false"
inkscape:zoom="4.72"
inkscape:cx="25"
inkscape:cy="25"
inkscape:window-x="-9"
inkscape:window-y="-9"
inkscape:window-maximized="1"
inkscape:current-layer="Layer_1" /><path
fill="#FFFFFF"
d="M22.83,4.372C17.124,4.974,12.221,7.82,8.877,11.951c-3.345,4.134-5.106,9.52-4.508,15.227 c0.604,5.703,3.449,10.604,7.581,13.949c4.134,3.346,9.52,5.109,15.222,4.509c5.705-0.601,10.606-3.451,13.955-7.581 c3.34-4.132,5.106-9.519,4.505-15.225c-0.608-5.751-3.528-10.669-7.724-14.064c-3.531-2.859-8.032-4.51-12.856-4.51 C24.319,4.256,23.578,4.294,22.83,4.372"
id="path2" /><path
fill="#3999C6"
d="M49.859,22.385c-0.728-6.937-4.271-12.883-9.273-16.928c-0.971-0.786-2.018-1.472-3.1-2.1l-1.963,3.777 c0.83,0.493,1.636,1.024,2.385,1.632c4.196,3.395,7.116,8.312,7.723,14.063c0.602,5.706-1.165,11.093-4.504,15.226 c-3.349,4.131-8.25,6.98-13.955,7.581c-3.82,0.4-7.489-0.277-10.744-1.761l-1.961,3.774c3.976,1.851,8.479,2.708,13.151,2.214 c6.862-0.719,12.796-4.164,16.814-9.133C48.453,35.767,50.587,29.243,49.859,22.385"
id="path4" /><path
fill="#A0A1A2"
d="M11.951,41.127c-4.133-3.346-6.978-8.247-7.581-13.949c-0.599-5.708,1.162-11.094,4.508-15.228 c3.343-4.13,8.246-6.977,13.951-7.578c4.613-0.484,9.016,0.574,12.694,2.76l1.963-3.776C33.07,0.793,27.824-0.43,22.381,0.143 C15.522,0.865,9.588,4.309,5.569,9.274L5.562,9.283c-4.018,4.965-6.144,11.484-5.423,18.338c0.723,6.859,4.164,12.796,9.135,16.815 c1.582,1.282,3.335,2.346,5.194,3.212l1.961-3.774C14.826,43.144,13.315,42.231,11.951,41.127"
id="path6" /><path
fill="#59B4D9"
d="M11.951,41.127c-4.133-3.346-6.978-8.247-7.581-13.949c-0.599-5.708,1.162-11.094,4.508-15.228 c3.343-4.13,8.246-6.977,13.951-7.578c4.613-0.484,9.016,0.574,12.694,2.76l1.963-3.776C33.07,0.793,27.824-0.43,22.381,0.143 C15.522,0.865,9.588,4.309,5.569,9.274L5.562,9.283c-4.018,4.965-6.144,11.484-5.423,18.338c0.723,6.859,4.164,12.796,9.135,16.815 c1.582,1.282,3.335,2.346,5.194,3.212l1.961-3.774C14.826,43.144,13.315,42.231,11.951,41.127"
id="path8" /><path
fill="#7A7A7A"
d="M35.497,31.558l-9.601-3.414c-1.041-0.37-1.584-1.514-1.214-2.554c0.37-1.041,1.514-1.584,2.554-1.214 l9.601,3.414c1.041,0.37,1.584,1.514,1.214,2.554C37.682,31.384,36.538,31.928,35.497,31.558z"
id="path10" /><path
fill="#7A7A7A"
d="M24.801,27.773c-1.104,0-2-0.896-2-2V8.755c0-1.104,0.896-2,2-2s2,0.896,2,2v17.018 C26.801,26.878,25.906,27.773,24.801,27.773z"
id="path12" /><circle
fill="#1E1E1E"
cx="24.801"
cy="25.773"
r="2.921"
id="circle14" /><rect
x="11.79"
y="12.992"
transform="matrix(0.7071 0.7071 -0.7071 0.7071 13.566 -5.6206)"
fill="#7A7A7A"
width="3.556"
height="1.147"
id="rect16" /><rect
x="24.418"
y="7.087"
fill="#7A7A7A"
width="1.146"
height="3.556"
id="rect18" /><rect
x="35.725"
y="11.902"
transform="matrix(0.7071 0.7071 -0.7071 0.7071 20.3048 -21.6604)"
fill="#7A7A7A"
width="1.147"
height="3.556"
id="rect20" /><rect
x="39.055"
y="24.415"
fill="#7A7A7A"
width="3.556"
height="1.147"
id="rect22" /><rect
x="34.358"
y="35.56"
transform="matrix(0.7071 0.7071 -0.7071 0.7071 36.134 -14.9688)"
fill="#7A7A7A"
width="3.556"
height="1.147"
id="rect24" /><rect
x="34.358"
y="35.56"
transform="matrix(0.7071 0.7071 -0.7071 0.7071 36.134 -14.9688)"
fill="#7A7A7A"
width="3.556"
height="1.147"
id="rect26" /><rect
x="24.418"
y="38.996"
fill="#7A7A7A"
width="1.146"
height="3.556"
id="rect28" /><rect
x="11.79"
y="12.992"
transform="matrix(0.7071 0.7071 -0.7071 0.7071 13.566 -5.6206)"
fill="#7A7A7A"
width="3.556"
height="1.147"
id="rect30" /><rect
x="13.168"
y="34.459"
transform="matrix(0.7071 0.7071 -0.7071 0.7071 29.6485 0.8972)"
fill="#7A7A7A"
width="1.147"
height="3.556"
id="rect32" /><rect
x="13.168"
y="34.459"
transform="matrix(0.7071 0.7071 -0.7071 0.7071 29.6485 0.8972)"
fill="#7A7A7A"
width="1.147"
height="3.556"
id="rect34" /><rect
x="7.151"
y="24.415"
fill="#7A7A7A"
width="3.557"
height="1.147"
id="rect36" /></svg>
<?xml version="1.0" ?><!DOCTYPE svg PUBLIC '-//W3C//DTD SVG 1.1//EN' 'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd'><svg height="32px" id="Layer_1" style="enable-background:new 0 0 32 32;" version="1.1" viewBox="0 0 32 32" width="32px" xml:space="preserve" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><path d="M31.338,14.538L27.38,10.58C26.994,10.193,26.531,10,26,10c-1.188,0-2,1.016-2,2c0,0.516,0.186,0.986,0.58,1.38L25.2,14H18 V6.8l0.62,0.62C19.014,7.814,19.484,8,20,8c0.984,0,2-0.813,2-2c0-0.531-0.193-0.994-0.58-1.38l-3.973-3.974 C17.08,0.279,16.729,0,16,0s-1.135,0.334-1.463,0.662L10.58,4.62C10.193,5.006,10,5.469,10,6c0,1.188,1.016,2,2,2 c0.516,0,0.986-0.186,1.38-0.58L14,6.8V14H6.8l0.62-0.62C7.814,12.986,8,12.516,8,12c0-0.984-0.813-2-2-2 c-0.531,0-0.994,0.193-1.38,0.58l-3.958,3.958C0.334,14.866,0,15.271,0,16s0.279,1.08,0.646,1.447L4.62,21.42 C5.006,21.807,5.469,22,6,22c1.188,0,2-1.016,2-2c0-0.516-0.186-0.986-0.58-1.38L6.8,18H14v7.2l-0.62-0.62 C12.986,24.186,12.516,24,12,24c-0.984,0-2,0.813-2,2c0,0.531,0.193,0.994,0.58,1.38l3.957,3.958C14.865,31.666,15.271,32,16,32 s1.08-0.279,1.447-0.646l3.973-3.974C21.807,26.994,22,26.531,22,26c0-1.188-1.016-2-2-2c-0.516,0-0.986,0.186-1.38,0.58L18,25.2V18 h7.2l-0.62,0.62C24.186,19.014,24,19.484,24,20c0,0.984,0.813,2,2,2c0.531,0,0.994-0.193,1.38-0.58l3.974-3.973 C31.721,17.08,32,16.729,32,16S31.666,14.866,31.338,14.538z"/></svg>
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 90 90"><defs><style>.cls-1{fill:#43a6dd;}.cls-2{fill:#4cbefc;}</style></defs><title>water-drop</title><g id="water-drop"><path class="cls-1" d="M45,85A26.57,26.57,0,0,0,71.67,58.53C71.67,43.92,45,5,45,5S18.33,43.92,18.33,58.53A26.57,26.57,0,0,0,45,85Z"/><path class="cls-2" d="M42.87,14.53s-10,25.54-9.67,36.65c.19,6,1.54,11.39,3,13.55,7.41,10.72-5.24,6.57-8.18.48a22.93,22.93,0,0,1-2.22-10C25.84,44.14,42.87,14.53,42.87,14.53Z"/></g></svg>
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!-- Generator: Adobe Illustrator 17.0.1, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
version="1.1"
id="Layer_1"
x="0px"
y="0px"
width="50px"
height="50px"
viewBox="0 0 50 50"
enable-background="new 0 0 50 50"
xml:space="preserve"
sodipodi:docname="id-red.svg"
inkscape:version="0.92.2 (5c3e80d, 2017-08-06)"><metadata
id="metadata43"><rdf:RDF><cc:Work
rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title></dc:title></cc:Work></rdf:RDF></metadata><defs
id="defs41" /><sodipodi:namedview
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1"
objecttolerance="10"
gridtolerance="10"
guidetolerance="10"
inkscape:pageopacity="0"
inkscape:pageshadow="2"
inkscape:window-width="1920"
inkscape:window-height="974"
id="namedview39"
showgrid="false"
inkscape:zoom="13.350176"
inkscape:cx="45.327353"
inkscape:cy="14.347921"
inkscape:window-x="2391"
inkscape:window-y="-9"
inkscape:window-maximized="1"
inkscape:current-layer="Layer_1" /><path
fill="#FFFFFF"
d="M22.83,4.372C17.124,4.974,12.221,7.82,8.877,11.951c-3.345,4.134-5.106,9.52-4.508,15.227 c0.604,5.703,3.449,10.604,7.581,13.949c4.134,3.346,9.52,5.109,15.222,4.509c5.705-0.601,10.606-3.451,13.955-7.581 c3.34-4.132,5.106-9.519,4.505-15.225c-0.608-5.751-3.528-10.669-7.724-14.064c-3.531-2.859-8.032-4.51-12.856-4.51 C24.319,4.256,23.578,4.294,22.83,4.372"
id="path2" /><path
fill="#3999C6"
d="M49.859,22.385c-0.728-6.937-4.271-12.883-9.273-16.928c-0.971-0.786-2.018-1.472-3.1-2.1l-1.963,3.777 c0.83,0.493,1.636,1.024,2.385,1.632c4.196,3.395,7.116,8.312,7.723,14.063c0.602,5.706-1.165,11.093-4.504,15.226 c-3.349,4.131-8.25,6.98-13.955,7.581c-3.82,0.4-7.489-0.277-10.744-1.761l-1.961,3.774c3.976,1.851,8.479,2.708,13.151,2.214 c6.862-0.719,12.796-4.164,16.814-9.133C48.453,35.767,50.587,29.243,49.859,22.385"
id="path4" /><path
fill="#A0A1A2"
d="M11.951,41.127c-4.133-3.346-6.978-8.247-7.581-13.949c-0.599-5.708,1.162-11.094,4.508-15.228 c3.343-4.13,8.246-6.977,13.951-7.578c4.613-0.484,9.016,0.574,12.694,2.76l1.963-3.776C33.07,0.793,27.824-0.43,22.381,0.143 C15.522,0.865,9.588,4.309,5.569,9.274L5.562,9.283c-4.018,4.965-6.144,11.484-5.423,18.338c0.723,6.859,4.164,12.796,9.135,16.815 c1.582,1.282,3.335,2.346,5.194,3.212l1.961-3.774C14.826,43.144,13.315,42.231,11.951,41.127"
id="path6" /><path
fill="#59B4D9"
d="M11.951,41.127c-4.133-3.346-6.978-8.247-7.581-13.949c-0.599-5.708,1.162-11.094,4.508-15.228 c3.343-4.13,8.246-6.977,13.951-7.578c4.613-0.484,9.016,0.574,12.694,2.76l1.963-3.776C33.07,0.793,27.824-0.43,22.381,0.143 C15.522,0.865,9.588,4.309,5.569,9.274L5.562,9.283c-4.018,4.965-6.144,11.484-5.423,18.338c0.723,6.859,4.164,12.796,9.135,16.815 c1.582,1.282,3.335,2.346,5.194,3.212l1.961-3.774C14.826,43.144,13.315,42.231,11.951,41.127"
id="path8" /><text
xml:space="preserve"
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:31.19429779px;line-height:4.25;font-family:'MS UI Gothic';-inkscape-font-specification:'MS UI Gothic';letter-spacing:0px;word-spacing:0px;fill:#ff2a2a;fill-opacity:1;stroke:none;stroke-width:0.1624703;"
x="13.425205"
y="35.473938"
id="text817"
transform="scale(0.99003194,1.0100684)"><tspan
sodipodi:role="line"
id="tspan815"
x="13.425205"
y="35.473938"
style="stroke-width:0.1624703;fill:#ff2a2a;">ID</tspan></text>
</svg>
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!-- Generator: Adobe Illustrator 17.0.1, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
version="1.1"
id="Layer_1"
x="0px"
y="0px"
width="50px"
height="50px"
viewBox="0 0 50 50"
enable-background="new 0 0 50 50"
xml:space="preserve"
sodipodi:docname="id-dim.svg"
inkscape:version="0.92.2 (5c3e80d, 2017-08-06)"><metadata
id="metadata43"><rdf:RDF><cc:Work
rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title></dc:title></cc:Work></rdf:RDF></metadata><defs
id="defs41" /><sodipodi:namedview
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1"
objecttolerance="10"
gridtolerance="10"
guidetolerance="10"
inkscape:pageopacity="0"
inkscape:pageshadow="2"
inkscape:window-width="2400"
inkscape:window-height="1471"
id="namedview39"
showgrid="false"
inkscape:zoom="13.350176"
inkscape:cx="57.948909"
inkscape:cy="14.347921"
inkscape:window-x="-9"
inkscape:window-y="-9"
inkscape:window-maximized="1"
inkscape:current-layer="Layer_1" /><path
fill="#FFFFFF"
d="M22.83,4.372C17.124,4.974,12.221,7.82,8.877,11.951c-3.345,4.134-5.106,9.52-4.508,15.227 c0.604,5.703,3.449,10.604,7.581,13.949c4.134,3.346,9.52,5.109,15.222,4.509c5.705-0.601,10.606-3.451,13.955-7.581 c3.34-4.132,5.106-9.519,4.505-15.225c-0.608-5.751-3.528-10.669-7.724-14.064c-3.531-2.859-8.032-4.51-12.856-4.51 C24.319,4.256,23.578,4.294,22.83,4.372"
id="path2" /><path
fill="#3999C6"
d="M49.859,22.385c-0.728-6.937-4.271-12.883-9.273-16.928c-0.971-0.786-2.018-1.472-3.1-2.1l-1.963,3.777 c0.83,0.493,1.636,1.024,2.385,1.632c4.196,3.395,7.116,8.312,7.723,14.063c0.602,5.706-1.165,11.093-4.504,15.226 c-3.349,4.131-8.25,6.98-13.955,7.581c-3.82,0.4-7.489-0.277-10.744-1.761l-1.961,3.774c3.976,1.851,8.479,2.708,13.151,2.214 c6.862-0.719,12.796-4.164,16.814-9.133C48.453,35.767,50.587,29.243,49.859,22.385"
id="path4" /><path
fill="#A0A1A2"
d="M11.951,41.127c-4.133-3.346-6.978-8.247-7.581-13.949c-0.599-5.708,1.162-11.094,4.508-15.228 c3.343-4.13,8.246-6.977,13.951-7.578c4.613-0.484,9.016,0.574,12.694,2.76l1.963-3.776C33.07,0.793,27.824-0.43,22.381,0.143 C15.522,0.865,9.588,4.309,5.569,9.274L5.562,9.283c-4.018,4.965-6.144,11.484-5.423,18.338c0.723,6.859,4.164,12.796,9.135,16.815 c1.582,1.282,3.335,2.346,5.194,3.212l1.961-3.774C14.826,43.144,13.315,42.231,11.951,41.127"
id="path6" /><path
fill="#59B4D9"
d="M11.951,41.127c-4.133-3.346-6.978-8.247-7.581-13.949c-0.599-5.708,1.162-11.094,4.508-15.228 c3.343-4.13,8.246-6.977,13.951-7.578c4.613-0.484,9.016,0.574,12.694,2.76l1.963-3.776C33.07,0.793,27.824-0.43,22.381,0.143 C15.522,0.865,9.588,4.309,5.569,9.274L5.562,9.283c-4.018,4.965-6.144,11.484-5.423,18.338c0.723,6.859,4.164,12.796,9.135,16.815 c1.582,1.282,3.335,2.346,5.194,3.212l1.961-3.774C14.826,43.144,13.315,42.231,11.951,41.127"
id="path8" /><text
xml:space="preserve"
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:31.19429779px;line-height:4.25;font-family:'MS UI Gothic';-inkscape-font-specification:'MS UI Gothic';letter-spacing:0px;word-spacing:0px;fill:#999999;fill-opacity:1;stroke:none;stroke-width:0.1624703;"
x="13.425205"
y="35.473938"
id="text817"
transform="scale(0.99003194,1.0100684)"><tspan
sodipodi:role="line"
id="tspan815"
x="13.425205"
y="35.473938"
style="stroke-width:0.1624703;fill:#999999;">ID</tspan></text>
</svg>
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!-- Generator: Adobe Illustrator 17.0.1, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
version="1.1"
id="Layer_1"
x="0px"
y="0px"
width="50px"
height="50px"
viewBox="0 0 50 50"
enable-background="new 0 0 50 50"
xml:space="preserve"
sodipodi:docname="id-lightgreen.svg"
inkscape:version="0.92.2 (5c3e80d, 2017-08-06)"><metadata
id="metadata43"><rdf:RDF><cc:Work
rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title></dc:title></cc:Work></rdf:RDF></metadata><defs
id="defs41" /><sodipodi:namedview
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1"
objecttolerance="10"
gridtolerance="10"
guidetolerance="10"
inkscape:pageopacity="0"
inkscape:pageshadow="2"
inkscape:window-width="1920"
inkscape:window-height="974"
id="namedview39"
showgrid="false"
inkscape:zoom="13.350176"
inkscape:cx="45.327353"
inkscape:cy="14.347921"
inkscape:window-x="2391"
inkscape:window-y="-9"
inkscape:window-maximized="1"
inkscape:current-layer="Layer_1" /><path
fill="#FFFFFF"
d="M22.83,4.372C17.124,4.974,12.221,7.82,8.877,11.951c-3.345,4.134-5.106,9.52-4.508,15.227 c0.604,5.703,3.449,10.604,7.581,13.949c4.134,3.346,9.52,5.109,15.222,4.509c5.705-0.601,10.606-3.451,13.955-7.581 c3.34-4.132,5.106-9.519,4.505-15.225c-0.608-5.751-3.528-10.669-7.724-14.064c-3.531-2.859-8.032-4.51-12.856-4.51 C24.319,4.256,23.578,4.294,22.83,4.372"
id="path2" /><path
fill="#3999C6"
d="M49.859,22.385c-0.728-6.937-4.271-12.883-9.273-16.928c-0.971-0.786-2.018-1.472-3.1-2.1l-1.963,3.777 c0.83,0.493,1.636,1.024,2.385,1.632c4.196,3.395,7.116,8.312,7.723,14.063c0.602,5.706-1.165,11.093-4.504,15.226 c-3.349,4.131-8.25,6.98-13.955,7.581c-3.82,0.4-7.489-0.277-10.744-1.761l-1.961,3.774c3.976,1.851,8.479,2.708,13.151,2.214 c6.862-0.719,12.796-4.164,16.814-9.133C48.453,35.767,50.587,29.243,49.859,22.385"
id="path4" /><path
fill="#A0A1A2"
d="M11.951,41.127c-4.133-3.346-6.978-8.247-7.581-13.949c-0.599-5.708,1.162-11.094,4.508-15.228 c3.343-4.13,8.246-6.977,13.951-7.578c4.613-0.484,9.016,0.574,12.694,2.76l1.963-3.776C33.07,0.793,27.824-0.43,22.381,0.143 C15.522,0.865,9.588,4.309,5.569,9.274L5.562,9.283c-4.018,4.965-6.144,11.484-5.423,18.338c0.723,6.859,4.164,12.796,9.135,16.815 c1.582,1.282,3.335,2.346,5.194,3.212l1.961-3.774C14.826,43.144,13.315,42.231,11.951,41.127"
id="path6" /><path
fill="#59B4D9"
d="M11.951,41.127c-4.133-3.346-6.978-8.247-7.581-13.949c-0.599-5.708,1.162-11.094,4.508-15.228 c3.343-4.13,8.246-6.977,13.951-7.578c4.613-0.484,9.016,0.574,12.694,2.76l1.963-3.776C33.07,0.793,27.824-0.43,22.381,0.143 C15.522,0.865,9.588,4.309,5.569,9.274L5.562,9.283c-4.018,4.965-6.144,11.484-5.423,18.338c0.723,6.859,4.164,12.796,9.135,16.815 c1.582,1.282,3.335,2.346,5.194,3.212l1.961-3.774C14.826,43.144,13.315,42.231,11.951,41.127"
id="path8" /><text
xml:space="preserve"
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:31.19429779px;line-height:4.25;font-family:'MS UI Gothic';-inkscape-font-specification:'MS UI Gothic';letter-spacing:0px;word-spacing:0px;fill:#00ff00;fill-opacity:1;stroke:none;stroke-width:0.1624703;"
x="13.425205"
y="35.473938"
id="text817"
transform="scale(0.99003194,1.0100684)"><tspan
sodipodi:role="line"
id="tspan815"
x="13.425205"
y="35.473938"
style="stroke-width:0.1624703;fill:#00ff00;">ID</tspan></text>
</svg>
\define edit-fields-clear(fieldname)
<$list filter="[is[current]has[$fieldname$]]" variable=null>
<$wikify name=tooltip text="""Clear $fieldname$ field on this tiddler""">
<$button tooltip=<<tooltip>> class="tc-btn-invisible">
<$action-setfield $field="$fieldname$" $value=""/>
{{$:/core/images/close-button}}
</$button>
</$wikify>
</$list>
\end
\define edit-fields-delete(fieldname)
<$list filter="[is[current]has[$fieldname$]]" variable=null>
<$wikify name=tooltip text="""Delete $fieldname$ field on this tiddler""">
<$button tooltip=<<tooltip>> class="tc-btn-invisible">
<$action-deletefield $field="$fieldname$"/>
{{$:/core/images/delete-button}}
</$button>
</$wikify>
</$list>
\end
\define edit-fields-list()
<$list filter="[is[current]has:field[edit-fields-list]]" variable="null">
<$wikify name="editTiddler" text="""<<currentTiddler>>""">
<table>
<tr>
<th>Field <$button tooltip="Fieldname listed in edit-fields-list" class="tc-btn-invisible">{{$:/core/images/info-button}}</$button><<edit-fields-all>></th>
<th>Edit Field <$button tooltip="Edit field according to its field definition - if available" class="tc-btn-invisible">{{$:/core/images/info-button}}</$button></th>
<th></th>
<th>Field Actions <$button tooltip="Standard actions for any defined field, or define the field" class="tc-btn-invisible">{{$:/core/images/info-button}}</$button></th>
<th> Drag and Drop <$button tooltip="Drag field content somewhere, or drop content to replace field " class="tc-btn-invisible">{{$:/core/images/info-button}}</$button></th>
</tr>
<$list filter="[enlist{!!edit-fields-list}sort[]]" variable=fieldname>
<tr>
<$wikify name="fieldTiddler" text="""$:/PSaT/EditFields/fields/<<fieldname>>""">
<$wikify name="info" text="""<$transclude tiddler=<<fieldTiddler>> field=description>""">
<$list filter="[<fieldTiddler>has:field[text]]" variable=null>
<td><<fieldname>></td>
<td><$transclude tiddler=<<fieldTiddler>>/></td>
<td><$button class="tc-btn-invisible" tooltip=<<info>> > {{$:/core/images/info-button}}</$button></td>
<td> <$macrocall $name="edit-fields-clear" fieldname=<<fieldname>>/> <$macrocall $name="edit-fields-delete" fieldname=<<fieldname>>/><$button class="tc-btn-invisible" tooltip="Open Field Edit definition"> <$action-navigate $to=<<fieldTiddler>>/> {{$:/core/images/options-button}}</$button><$macrocall $name="edit-fields-copy-to-clipboard" fieldname=<<fieldname>>/></td>
<td><td><$macrocall $name="edit-fields-drag-content" fieldname=<<fieldname>>/></td><td><$macrocall $name="edit-fields-drop-content" fieldname=<<fieldname>>/></td></td>
</$list>
<$list filter="[<fieldTiddler>!has:field[text]]" variable=null>
<td><<fieldname>></td>
<td><$edit-text tiddler=<<editTiddler>> field=<<fieldname>> size="80"/></td>
<td><$button class="tc-btn-invisible" tooltip="Field not yet defined" > {{$:/core/images/info-button}}</$button></td>
<td>,,''No field definition exists, please create'',,<br><$macrocall $name="edit-fields-clear" fieldname=<<fieldname>>/> <$macrocall $name="edit-fields-delete" fieldname=<<fieldname>>/> <$macrocall $name="edit-fields-define" fieldname=<<fieldname>>/><br><$macrocall $name="edit-fields-define-from-existing" fieldname=<<fieldname>>/></td>
<td><td></td><td><$macrocall $name="edit-fields-drop-content" fieldname=<<fieldname>>/></td></td>
</$list>
</$wikify>
</$wikify>
</tr>
</$list>
<tr>
<td colspan="4">^^//This table lists for editing, all fields in this tiddlers <<edit-fields-show-list>> (field)//^^</td>
</tr>
</table>
<$button tooltip="Slide from left to right to set size of drag and drop icons below" class="tc-btn-invisible">{{$:/core/images/info-button}}</$button> Drag and Drop Icons: <<edit-fields-draganddropsize>>
</$wikify>
</$list>
\end
\define edit-fields-define(fieldname)
<$button tooltip="Select from field definition template" class="tc-btn-invisible">{{$:/core/images/storyview-classic}}</$button>
<$select tiddler="$:/temp/selectDefaultFieldType" default='$:/PSaT/EditFields/fieldDefault/TextField'>
<$list filter="[prefix[$:/PSaT/EditFields/fieldDefault/]]" variable="fieldDefault">
<$list filter="[<fieldDefault>removeprefix[$:/PSaT/EditFields/fieldDefault/]]" variable="fieldSuffix">
<option value=<<fieldDefault>> ><<fieldSuffix>></option>
</$list>
</$list>
</$select>
<$wikify name=tooltip text="""Define $fieldname$ field based on selection""">
<$wikify name=content text="""<$view tiddler={{$:/temp/selectDefaultFieldType}} field="text"/>""">
<$wikify name=new-name text="""$:/PSaT/EditFields/fields/$fieldname$""">
<$button class="tc-btn-invisible" tooltip=<<tooltip>> >
<$action-createtiddler $basetitle=<<new-name>> text=<<content>> caption="Edit $fieldname$ tiddler" description="Describe $fieldname$" field-choice-filter="" message-popup=""/>
<$action-navigate $to=<<new-name>>/>
{{$:/core/images/new-button}}
</$button>
</$wikify>
</$wikify>
</$wikify>
\end
\define edit-fields-define-from-existing(fieldname)
<$button tooltip="Select from an existing field definition" class="tc-btn-invisible">{{$:/core/images/storyview-pop}}</$button>
<$select tiddler="$:/temp/selectExistingField">
<$list filter="[prefix[$:/PSaT/EditFields/fields/]]" variable="fieldExist">
<$list filter="[<fieldExist>removeprefix[$:/PSaT/EditFields/fields/]]" variable="fieldSuffix">
<option value=<<fieldExist>> ><<fieldSuffix>></option>
</$list>
</$list>
</$select>
<$wikify name=tooltip text="""Define $fieldname$ field based on selection""">
<$wikify name=content text="""<$view tiddler={{$:/temp/selectExistingField}} field="text"/>""">
<$wikify name=new-name text="""$:/PSaT/EditFields/fields/$fieldname$""">
<$button class="tc-btn-invisible" tooltip=<<tooltip>> >
<$action-createtiddler $basetitle=<<new-name>> text=<<content>> caption="Edit $fieldname$ tiddler" description="Describe $fieldname$" field-choice-filter="" message-popup=""/>
<$action-navigate $to=<<new-name>>/>
{{$:/core/images/new-button}}
</$button>
</$wikify>
</$wikify>
</$wikify>
\end
\define edit-fields-image-picker(actions,filter:"[all[shadows+tiddlers]is[image]] [all[shadows+tiddlers]tag[$:/tags/Image]] -[type[application/pdf]] +[!has[draft.of]sort[title]]",subfilter:"")
<div class="tc-image-chooser">
<$vars state-system=<<qualify "$:/state/editFields-image-picker">>>
<$checkbox tiddler=<<state-system>> field="text" checked="show" unchecked="hide" default="hide"> Select Image</$checkbox>
<$reveal state=<<state-system>> type="nomatch" text="hide" default="hide" tag="div"><$macrocall $name="image-picker-list" filter="""$filter$""" actions="""$actions$"""/></$reveal>
</$vars>
</div>
\end
\define edit-fields-copy-to-clipboard(fieldname)
<$set name=field-content value={{!!$fieldname$}}>
<$button class="tc-btn-invisible" message="tm-copy-to-clipboard" param=<<field-content>> tooltip="Copy fieldname $fieldname$ contents to clipboard">
<$image width="14" source="$:/PSaT/EditFields/Clipboard.png"/>
</$button>
</$set>
\end
\define edit-fields-all()
<$button tooltip="Show unlisted fields on this tiddler" class="tc-btn-invisible" >
{{$:/core/images/storyview-pop}}
</$button>
<$button tooltip="Hide unlisted fields on this tiddler" class="tc-btn-invisible" >
{{$:/core/images/storyview-classic}}
</$button>
\end
\define edit-fields-show-list()
<$button tooltip="Toggle to show or hide edit-fields-list and re-order them" class="tc-btn-invisible tc-tiddlylink" >
edit-fields-list
</$button>
\end
\define edit-fields-time-stamp(fieldname)
<$button class="tc-btn-invisible" tooltip="Time stamp Field $fieldname$ with now">
<$action-setfield $field=$fieldname$ $value=<<now YYYY0MM0DD0hh0mm0ssXXX>>/>
{{$:/core/images/timestamp-on}}
</$button>
\end
\define edit-fields-date(fieldname)
<$edit-date field="$fieldname$"
icon="$:/PSaT/EditFields/icons/calendar.svg"
firstday="1"
tag="div"
placeholder="Use stamp or click to select a date"
fieldFormat="YYYY0MM0DD0hh0mm0ssxxx +0000"/>
\end
\define edit-fields-datetime(fieldname)
<$edit-date field="$fieldname$"
showTime use24hour
icon="$:/PSaT/EditFields/icons/Clock.svg"
firstday="1"
tag="div"
placeholder="Use stamp or click to select a date and time"
fieldFormat="YYYY0MM0DD0hh0mm0ssxxx +0000"/>
\end
\define edit-fields-drag-content(fieldname)
<<dragonfield $fieldname$ "{{$$:/PSaT/EditFields/icons/drag.svg}}">>
<$image width={{$:/temp/editfields/draganddropsize}} source="$:/PSaT/EditFields/icons/drag.svg"/>
\end
\define edit-fields-drop-content(fieldname)
<$image width={{$:/temp/editfields/draganddropsize}} source="$:/PSaT/EditFields/icons/drop.svg"/>
\end
\define edit-fields-reorder-list(fieldname:"list")
{{$:/PSaT/EditFields/draggablefields}}
\end
\define edit-fields-draganddropsize()
<$image width="8" source="$:/PSaT/EditFields/icons/arrow-down.svg"/> <$range tiddler="$:/temp/editfields/draganddropsize" min="16" max="96" default="16" increment="4"/> <$image width="12" source="$:/PSaT/EditFields/icons/arrow-up.svg"/>
\end
\define edit-fields-unique-stamp(fieldname,icon)
<$button class="tc-btn-invisible" tooltip="stamp field $fieldname$ with now">
<$action-setfield $field=$fieldname$ $value=<<now "ID:YYYY0MM0DD0hh0mm0ssXXX">>/>
<$image source="$icon$" width="32px"/>
</$button>
\end
<$list filter="[is[current]prefix[$:/PSaT/EditFields/fieldDefault/]]">This tiddler is a ''default field definition'' for use in the [[EditFields tool|$:/PSaT/EditFields]]<br>Description: {{!!description}} Change to view-fields-list once available</$list>
<$list filter="[is[current]prefix[$:/PSaT/EditFields/fields/]]">This tiddler is a ''field definition'' for use in the [[EditFields tool|$:/PSaT/EditFields]]<br>Description: {{!!description}} Change to view-fields-list once available</$list>
<<edit-fields-list>>
@@.purple Ontologie und Klassifizierung@@<style>.purple{color:red;}</style>
$:/plugins/amp/MagicTabs/tabs/parts
$:/plugins/amp/MagicTabs/dashboard/configuration
$:/plugins/amp/MagicTabs/dashboard/configuration
$:/core/ui/AdvancedSearch/Standard
$:/plugins/amp/MagicTabs/tabs/parts
$:/plugins/amp/MagicTabs/tabs/notes
$:/plugins/amp/MagicTabs/tabs/parts
$:/plugins/amp/MagicTabs/tabs/parts
$:/plugins/amp/MagicTabs/tabs/parts
$:/plugins/amp/MagicTabs/tabs/parts
$:/plugins/amp/MagicTabs/tabs/parts
$:/plugins/amp/MagicTabs/config/noSysTags
$:/plugins/amp/MagicTabs/config/appearance
$:/plugins/amp/MagicTabs/config/TabManager
$:/plugins/amp/MagicTabs/tabs/comments
$:/core/ui/ControlPanel/Palette
$:/core/ui/ControlPanel/Basics
$:/plugins/felixhayashi/tiddlymap/dialog/globalConfig/vis
$:/plugins/amp/MagicTabs/tabs/comments
$:/plugins/amp/MagicTabs/tabs/parts
$:/plugins/inmysocks/CategoryLists/Finished Items
$:/plugins/amp/MagicTabs/tabs/info
$:/core/ui/ControlPanel/Plugins/Installed/Themes
$:/plugins/amp/MagicTabs/tabs/info
$:/core/ui/ControlPanel/Info
$:/plugins/amp/MagicTabs/tabs/parts
$:/plugins/amp/MagicTabs/config/MagicTabs
$:/plugins/amp/MagicTabs/tabs/notes
$:/plugins/amp/MagicTabs/tabs/parts
$:/plugins/tongerner/topmenu/settings
$:/plugins/amp/MagicTabs/config/TypeManager
$:/core/ui/MoreSideBar/Recent
$:/plugins/ajh/favorites/SideBar
custom fields of current tiddler
\define lingo-base() $:/language/TagManager/
\define iconEditorTab(type)
<$list filter="[all[shadows+tiddlers]is[image]] [all[shadows+tiddlers]tag[$:/tags/Image]] -[type[application/pdf]] +[sort[title]] +[$type$is[system]]">
<$link to={{!!title}}>
<$transclude/> <$view field="title"/>
</$link>
</$list>
\end
\define iconEditor(title)
<div class="tc-drop-down-wrapper">
<$button popupTitle={{{ [[$:/state/popup/icon/]addsuffix<__title__>] }}} class="tc-btn-invisible tc-btn-dropdown">{{$:/core/images/down-arrow}}</$button>
<$reveal stateTitle={{{ [[$:/state/popup/icon/]addsuffix<__title__>] }}} type="popup" position="belowleft" text="" default="">
<div class="tc-drop-down">
<$linkcatcher actions="""<$action-setfield $tiddler=<<__title__>> icon=<<navigateTo>>/>""">
<<iconEditorTab type:"!">>
<hr/>
<<iconEditorTab type:"">>
</$linkcatcher>
</div>
</$reveal>
</div>
\end
\define toggleButton(state)
<$reveal stateTitle=<<__state__>> type="match" text="closed" default="closed">
<$button setTitle=<<__state__>> setTo="open" class="tc-btn-invisible tc-btn-dropdown" selectedClass="tc-selected">
{{$:/core/images/info-button}}
</$button>
</$reveal>
<$reveal stateTitle=<<__state__>> type="match" text="open" default="closed">
<$button setTitle=<<__state__>> setTo="closed" class="tc-btn-invisible tc-btn-dropdown" selectedClass="tc-selected">
{{$:/core/images/info-button}}
</$button>
</$reveal>
\end
<table class="tc-tag-manager-table">
<tbody>
<tr>
<th><<lingo Colour/Heading>></th>
<th class="tc-tag-manager-tag"><<lingo Tag/Heading>></th>
<th><<lingo Count/Heading>></th>
<th><<lingo Icon/Heading>></th>
<th><<lingo Info/Heading>></th>
</tr>
<$list filter="[tags[]!is[system]sort[title]]">
<tr>
<td><$edit-text field="color" tag="input" type="color"/></td>
<td>{{||$:/core/ui/TagTemplate}}</td>
<td><$count filter="[all[current]tagging[]]"/></td>
<td>
<$macrocall $name="iconEditor" title={{!!title}}/>
</td>
<td>
<$macrocall $name="toggleButton" state={{{ [[$:/state/tag-manager/]addsuffix<currentTiddler>] }}} />
</td>
</tr>
<tr>
<td></td>
<td colspan="4">
<$reveal stateTitle={{{ [[$:/state/tag-manager/]addsuffix<currentTiddler>] }}} type="match" text="open" default="">
<table>
<tbody>
<tr><td><<lingo Colour/Heading>></td><td><$edit-text field="color" tag="input" type="text" size="9"/></td></tr>
<tr><td><<lingo Icon/Heading>></td><td><$edit-text field="icon" tag="input" size="45"/></td></tr>
</tbody>
</table>
</$reveal>
</td>
</tr>
</$list>
<tr>
<td></td>
<td style="position:relative;">
{{$:/core/ui/UntaggedTemplate}}
</td>
<td>
<small class="tc-menu-list-count"><$count filter="[untagged[]!is[system]] -[tags[]]"/></small>
</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
$:/temp/appear/Anwendungen1658401645/popup/block/
{
"tiddlers": {
"$:/info/browser": {
"title": "$:/info/browser",
"text": "yes"
},
"$:/info/node": {
"title": "$:/info/node",
"text": "no"
},
"$:/info/url/full": {
"title": "$:/info/url/full",
"text": "file:///C:/Users/Cyrill/Dropbox/Public/SRI/Vorlagen/materialClean.html"
},
"$:/info/url/host": {
"title": "$:/info/url/host",
"text": ""
},
"$:/info/url/hostname": {
"title": "$:/info/url/hostname",
"text": ""
},
"$:/info/url/protocol": {
"title": "$:/info/url/protocol",
"text": "file:"
},
"$:/info/url/port": {
"title": "$:/info/url/port",
"text": ""
},
"$:/info/url/pathname": {
"title": "$:/info/url/pathname",
"text": "/C:/Users/Cyrill/Dropbox/Public/SRI/Vorlagen/materialClean.html"
},
"$:/info/url/search": {
"title": "$:/info/url/search",
"text": ""
},
"$:/info/url/origin": {
"title": "$:/info/url/origin",
"text": "file://"
},
"$:/info/browser/screen/width": {
"title": "$:/info/browser/screen/width",
"text": "2048"
},
"$:/info/browser/screen/height": {
"title": "$:/info/browser/screen/height",
"text": "1152"
}
}
}
[has[gesetz]search:gesetz{$:/temp/search}]
\define remover() $(currentTiddler)$$(delim)$
<$set name="delim" value={{$:/config/NameSpaceDelimiter}}>
<$list filter="[prefix<currentTiddler>sort[title]]-[<currentTiddler>]" variable="sub">
<$list filter="[<sub>removeprefix<remover>]" variable="truncated">
<$link to=<<sub>>><<truncated>></$link><br>
</$list>
</$list>
</$set>
{
"tiddlers": {
"$:/themes/jd/Material/Stylesheet": {
"created": "20180324031356243",
"creator": "jd",
"text": "\\define dur() 300ms\n\n<pre>\n\n/* TAB BUTTONS */\n\n.tc-tab-buttons button {\n padding: 8px;\n}\n\n.tc-tab-buttons {\n margin-bottom: -3px;\n}\n\n.tc-more-sidebar > .tc-tab-set > .tc-tab-buttons > button,\n.tc-tab-buttons.tc-vertical button {\n margin-bottom: -1px;\n background-color: <<colour tab-background>>;\n border-top: 1px solid <<colour tab-border>>;\n border-right: 1px solid <<colour tab-border>>;\n border-bottom: 1px solid <<colour tab-border>>;\n border-left: 1px solid <<colour tab-border>>;\n}\n\ndiv.tc-tab-content.tc-vertical .tc-tab-buttons button {\n margin-bottom: 0;\n}\n\n.tc-more-sidebar > .tc-tab-set > .tc-tab-buttons > button.tc-tab-selected,\n.tc-tab-buttons.tc-vertical button.tc-tab-selected {\n background-color: <<colour tab-background-selected>>;\n border-top: 1px solid <<colour tab-border-selected>>;\n border-right: 1px solid <<colour tab-background-selected>>;\n border-bottom: 1px solid <<colour tab-border-selected>>;\n border-left: 1px solid <<colour tab-border-selected>>;\n}\n\n.tc-more-sidebar > .tc-tab-set > .tc-tab-buttons,\n.tc-tab-buttons.tc-vertical {\n margin-right: -0.5px;\n}\n\ndiv.tc-tab-content.tc-vertical .tc-tab-buttons {\n margin-bottom: -1px;\n}\n\ndiv.tc-tab-content.tc-vertical .tc-tab-buttons button {\n border-bottom: 1px solid <<colour tab-border>>;\n}\n\ndiv.tc-tab-content.tc-vertical .tc-tab-buttons button.tc-tab-selected {\n border-bottom: 1px solid <<colour tab-background-selected>>;\n}\n\n.tc-tab-content.tc-vertical {\n margin-left: 1px;\n border-left: 1px solid <<colour tab-divider>>;\n}\n\n\n/* FAB BUTTONS */\n\n.FAB-wrapper {\n position: fixed;\n bottom: {{$:/themes/jd/Material/ConfigDB##fabxy}};\n right: {{$:/themes/jd/Material/ConfigDB##fabxy}};\n overflow: hidden;\n z-index: 800;\n}\n\n.FABs-wrapper {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-orient: vertical;\n -webkit-box-direction: reverse;\n -ms-flex-direction: column-reverse;\n flex-direction: column-reverse;\n}\n<$list filter=\"[[$:/plugins/tiddlywiki/hammerjs][$:/plugins/BurningTree/hammerwidgets]is[missing]]\">\n.FABs-wrapper {\n opacity: 0;\n height: {{$:/themes/jd/Material/ConfigDB##fabsize}};\n position: fixed;\n bottom: calc({{$:/themes/jd/Material/ConfigDB##fabxy}} + {{$:/themes/jd/Material/ConfigDB##fabsize}} + {{$:/themes/jd/Material/ConfigDB##fabmargin}} + {{$:/themes/jd/Material/ConfigDB##fabmargin}});\n right: {{$:/themes/jd/Material/ConfigDB##fabxy}};\n overflow: hidden;\n z-index: 800;\n}\n.FABs-wrapper:hover {\n opacity: 1;\n height: auto;\n}\n</$list>\n\nbutton.FABitem {\n<$list filter=\"[{$:/palette}prefix[$:/themes/jd/Material/Palette/]]\">\n background: <<colour button-background>>;\n fill: <<colour button-foreground>>;\n</$list>\n<$list filter=\"[{$:/palette}!prefix[$:/themes/jd/Material/Palette/]]\">\n background: <<colour primary>>;\n fill: white;\n</$list>\n margin: {{$:/themes/jd/Material/ConfigDB##fabmargin}};\n height: {{$:/themes/jd/Material/ConfigDB##fabsize}};\n width: {{$:/themes/jd/Material/ConfigDB##fabsize}};\n font-size: {{$:/themes/jd/Material/ConfigDB##fabiconsize}};\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n -webkit-box-pack: center;\n -ms-flex-pack: center;\n justify-content: center;\n border-radius: 50%;\n <<box-shadow \"0 1px 1.5px 0 rgba(0, 0, 0, 0.12), 0 1px 1px 0 rgba(0, 0, 0, 0.24)\">>\n <<transition \"background $(dur)$, fill $(dur)$\">>\n}\n\n.FABitem svg.tc-image-button {\n margin: 0;\n padding: 0;\n}\n\nbutton.FABitem:hover {\n background: <<colour tag-background>>;\n fill: rgba(0, 0, 0, 0.87);\n}\n\n@media (min-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n.FAB-wrapper .tc-drop-down,\n.FAB-wrapper .tc-block-dropdown,\n.FABs-wrapper .tc-drop-down,\n.FABs-wrapper .tc-block-dropdown {\n position: fixed;\n bottom: {{$:/themes/jd/Material/ConfigDB##fabxy}};\n right: calc(20px + {{$:/themes/jd/Material/ConfigDB##fabxy}} + {{$:/themes/jd/Material/ConfigDB##fabsize}});\n max-height: calc(100% - {{$:/themes/jd/Material/ConfigDB##fabxy}} - 56px - 42px);\n}\n}\n\n\n/* HEADER */\n\n.header-back {\n background: <<colour primary>>;\n <<box-shadow \"0 2px 4px -1px rgba(0, 0, 0, 0.2), 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12)\">>\n z-index: 700;\n}\n\n.header-back,\n.header-wrapper {\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 56px;\n}\n\n.header-wrapper {\n z-index: 1000;\n}\n\n.header-type-wrapper {\n width: 100%;\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-flex: 0;\n -ms-flex: 0 0 auto;\n flex: 0 0 auto;\n -webkit-box-pack: justify;\n -ms-flex-pack: justify;\n justify-content: space-between;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n line-height: 20px;\n}\n\n.header-type-wrapper .tc-btn-invisible {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-pack: start;\n -ms-flex-pack: start;\n justify-content: flex-start;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n font-size: 22px;\n fill: white;\n <<transition \"background $(dur)$, border-radius $(dur)$\">>\n}\n\n.header-type-wrapper .header-btn:hover {\n background: rgba(0, 0, 0, 0.12);\n border-radius: 50%;\n}\n\n.header-title {\n font-size: 22px;\n color: white;\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-pack: start;\n -ms-flex-pack: start;\n justify-content: flex-start;\n width: 100%;\n}\n\n.header-title .tc-tiddlylink { color: white; }\n\n\n/* SEARCHBAR */\n\n.jd-search-header { \n width: 100%;\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-flex: 0;\n -ms-flex: 0 0 auto;\n flex: 0 0 auto;\n -webkit-box-pack: center;\n -ms-flex-pack: center;\n justify-content: center;\n}\n\n.jd-search-bar input { \n width:100%;\n border: 0;\n border-bottom: 1px solid white;\n color: white;\n background: transparent;\n}\n\n.jd-search-header ::placeholder { color: rgba(255, 255, 255, 0.7); }\n\n.jd-search-bar { flex: 1 }\n\n.jd-search-buttons {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex; \n -webkit-box-align: center; \n -ms-flex-align: center; \n align-items: center;\n -webkit-box-orient: horizontal;\n -webkit-box-direction: normal;\n -ms-flex-direction: row;\n flex-direction: row;\n}\n\n.jd-search-buttons button { margin-left: 10px; fill: black; }\n\n\n/* LISTS */\n\n.tc-more-sidebar { width: 100%; }\n\n.tc-drop-down button { display: block; }\n\n\n\n/* BODY WRAPPER */\n\ndiv.tc-tab-set.jd-lists-body {\n min-height: calc(100vh - 56px);\n max-height: calc(100vh - 56px);\n}\n\n@media (min-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n\ndiv.tc-tab-set.jd-lists-body {\n <<box-shadow \"0 3px 4px -1px rgba(0, 0, 0, 0.2), 0 5px 5px 0 rgba(0, 0, 0, 0.14), 0 5px 10px 0 rgba(0, 0, 0, 0.12)\">>\n}\n\ndiv.jd-search-body {\n left: 50%; \n -webkit-transform: translateX(-50%); \n -ms-transform: translateX(-50%); \n transform: translateX(-50%);\n width: 600px;\n max-height: calc(100% - 156px);\n <<box-shadow \"0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 1px 5px 0 rgba(0, 0, 0, 0.12)\">>\n}\n\n.jd-search-bar, .jd-search-bar input { width:400px; }\n\n.jd-search-bar {\n -webkit-box-flex: 0; \n -ms-flex: 0; \n flex: 0; \n}\n}\n\n\ndiv.tc-tab-set.jd-lists-body,\n.jd-search-body {\n background: <<colour background>>;\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n -ms-flex-direction: column;\n flex-direction: column;\n z-index: 800;\n}\n\n.jd-search-body {\n position: fixed; \n top: 56px; \n}\n\n.jd-search-body > .tc-tab-set {\n display: flex;\n flex-direction: column;\n}\n\n.jd-search-body > .tc-tab-set > .tc-tab-content {\n padding: 0 16px 16px 16px;\n margin: 0;\n display: flex;\n flex: 1 1 auto;\n overflow: auto;\n}\n\n.jd-search-body > .tc-tab-set > .tc-tab-divider {\n display: none;\n}\n\n.jd-search-body .tc-tab-set .tc-tab-content .tc-search { display: none; }\n\ndiv.tc-tab-content.jd-lists-body .tc-tab-content.tc-vertical {\n margin-top: 0;\n}\n\ndiv.tc-tab-content.jd-lists-body .tc-tab-buttons.tc-vertical {\n padding-top: 0;\n}\n\ndiv.tc-tab-content.jd-lists-body div,\ndiv.tc-tab-content.jd-lists-body li {\n margin-bottom: 4px;\n}\n\ndiv.tc-tab-content.jd-lists-body .tc-tag-label {\n margin: 4px 0;\n}\n\ndiv.tc-tab-content.jd-lists-body ul {\n padding-left: 16px;\n margin: 0;\n}\n\ndiv.tc-tab-content.jd-lists-body p {\n -webkit-margin-before: 0;\n -webkit-margin-after: 0;\n}\n\n@media (max-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n.jd-search-body {\n max-height: calc(100% - 56px);\n <<box-shadow \"0 2px 4px -1px rgba(0, 0, 0, 0.2), 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12)\">>\n}\n.jd-search-body {\n left: 0; \n width: 100%;\n}\n}\n\ndiv.tc-tab-buttons.jd-lists-body,\n.jd-search-body .tc-tab-buttons {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-flex: 0;\n -ms-flex: 0 0 auto;\n flex: 0 0 auto;\n width: 100%; \n margin: 0;\n padding: 0;\n background: <<colour sidebar-tab-background>>; \n overflow-x: auto;\n overflow-y: hidden;\n}\n\n@media (max-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n.jd-search-body .tc-tab-buttons,\ndiv.tc-tab-buttons.jd-lists-body {\n <<box-shadow \"0 4px 4px -1px rgba(0, 0, 0, 0.2), 0 5px 5px 0 rgba(0, 0, 0, 0.1)\">>\n z-index: 900;\n}\n}\n\ndiv.tc-tab-divider.jd-lists-body { display: none; }\n\ndiv.tc-tab-buttons.jd-lists-body .tc-tab-selected,\n.jd-search-body .tc-tab-buttons button.tc-tab-selected {\n border-bottom: 2px solid <<colour sidebar-tab-border-selected>> !important;\n}\n\ndiv.tc-tab-buttons.jd-lists-body button,\n.jd-search-body .tc-tab-buttons button {\n min-width: calc(100% / {{$:/themes/jd/Material/ConfigDB##headerbtns}});\n max-width: calc(100% / {{$:/themes/jd/Material/ConfigDB##headerbtns}});\n background: <<colour sidebar-tab-background>>;\n color: <<colour sidebar-tab-foreground>>;\n margin: 0;\n border: 0;\n border-bottom: 2px solid transparent;\n padding: 8px 8px;\n border-radius: 0;\n white-space: nowrap; \n overflow: hidden;\n -o-text-overflow: ellipsis;\n text-overflow: ellipsis;\n font-size: {{$:/themes/tiddlywiki/vanilla/metrics/bodyfontsize}};\n}\n\ndiv.tc-tab-buttons.jd-lists-body button.tc-tab-selected,\n.jd-search-body .tc-tab-buttons button.tc-tab-selected {\n background: <<colour sidebar-tab-background-selected>>;\n color: <<colour sidebar-tab-foreground-selected>>;\n border-bottom: 2px solid <<colour sidebar-tab-border-selected>>;\n}\n\n.jd-search-body button.jd-search-btn {\n min-width: 25%;\n max-width: 25%;\n}\n\ndiv.tc-tab-content.jd-lists-body {\n background: <<colour background>>;\n padding: 16px;\n margin: 0;\n display: block;\n -webkit-box-flex: 1;\n -ms-flex: 1 1 auto;\n flex: 1 1 auto;\n overflow-y: auto;\n}\n\ndiv.tc-tab-content.jd-lists-body button { fill: <<colour button-foreground>> }\n\n<$reveal type=\"match\" state=\"$:/themes/jd/Material/ConfigDB##styledframes\" text=\"yes\">\n\n/* VIEW & EDIT FRAME */\n\n.tc-tiddler-edit-frame .tc-tiddler-title, \n.tc-tiddler-view-frame .tc-titlebar h2.tc-title {\n font-size: {{$:/themes/tiddlywiki/vanilla/metrics/bodyfontsize}}; \n}\n\n\n/* VIEW FRAME */\n\n.tc-tiddler-view-frame .tc-title {\n font-weight: bold;\n}\n\n.tc-tiddler-view-frame .tc-tiddler-title-icon svg {\n height: {{$:/themes/tiddlywiki/vanilla/metrics/bodyfontsize}}; \n}\n\n.tc-tiddler-view-frame .tc-titlebar > span:nth-child(2),\nspan.tc-tiddler-title-icon {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n height: 1.4em;\n white-space: normal;\n word-break: break-all;\n}\n\n\n/* EDIT FRAME */\n\n.tc-tiddler-edit-frame .tc-tiddler-edit-title {\n color: transparent;\n line-height: 0;\n}\n\n.tc-tiddler-edit-frame .tc-message-box { margin: 0; }\n\n.tc-tiddler-edit-frame iframe.tc-edit-texteditor { margin-top: 0 !important; }\n\n.tc-tiddler-edit-frame .tc-editor-toolbar { background: <<colour tiddler-editor-border>>; }\n\n.tc-tiddler-edit-frame .tc-editor-toolbar .tc-btn-invisible { background: transparent; }\n\n.tc-tiddler-edit-frame .tc-editor-toolbar .tc-btn-invisible:hover {\n background: transparent;\n fill: <<colour primary>>;\n}\n\ninput::placeholder {\n font-size: 0.9em; \n}\n\n.tc-tiddler-edit-frame input.tc-titlebar.tc-edit-texteditor, \n.tc-tiddler-edit-frame .tc-edit-tags, \n.tc-tiddler-edit-frame .tc-edit-field-add-name input.tc-edit-texteditor, \n.tc-tiddler-edit-frame .tc-edit-field-add-value input.tc-edit-texteditor, \n.tc-tiddler-edit-frame input.tc-edit-typeeditor.tc-popup-handle, \n.tc-tiddler-edit-frame input.tc-edit-texteditor.tc-popup-handle {\n border: 1px solid <<colour background>>; \n border-bottom: 1px solid <<colour tiddler-editor-border>>;\n <<box-shadow \"none\">>\n} \n\n.tc-tiddler-edit-frame textarea { \n border: 1px solid <<colour tiddler-editor-border>>;\n <<box-shadow \"none\">>\n} \n\n.tc-tiddler-edit-frame input,\n.tc-tiddler-edit-frame textarea,\n.tc-tiddler-edit-frame iframe.tc-edit-texteditor {\n font-size: {{$:/themes/tiddlywiki/vanilla/metrics/bodyfontsize}};\n font-family: {{$:/themes/tiddlywiki/vanilla/settings/fontfamily}};\n border: 1px solid <<colour background>>; \n <<box-shadow \"none\">>\n}\n\n.tc-tiddler-edit-frame input.tc-titlebar.tc-edit-texteditor {\n font-weight: bold;\n}\n\n.tc-tiddler-edit-frame .tc-type-selector {\n padding-bottom: 10px;\n border-bottom: 1px solid <<colour tiddler-editor-border>>;\n}\n\n</$reveal>\n\n\n/* LIST ITEMS */\n\n.tc-menu-list-item {\n padding-left: 5px;\n text-indent: -5px;\n white-space: normal;\n word-wrap: break-word;\n -webkit-word-break: break-all;\n -moz-word-break: break-all;\n -ms-word-break: break-all;\n -o-word-break: break-all;\n word-break: break-all;\n}\n\n\n/* POPUPS */\n\n.tc-drop-down,\n.tc-block-dropdown {\n font-size: 18px;\n line-height: 1.8;\n font-weight: normal;\n white-space: normal;\n border-radius: 2px;\n max-height: 400px;\n min-width: 250px;\n max-width: 300px;\n overflow: auto;\n <<box-shadow \"0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 1px 5px 0 rgba(0, 0, 0, 0.12)\">>\n}\n\ndiv.header-type-wrapper.tc-reveal > div > div.tc-reveal > div.tc-reveal.tc-popup > div.tc-drop-down, \ndiv.header-type-wrapper.tc-reveal > div > div.tc-reveal > span.tc-reveal.tc-popup > div.tc-drop-down,\n.jd-search-buttons .tc-drop-down,\n.jd-search-buttons .tc-block-dropdown { position: absolute; right: 0; }\n\n.tc-drop-down .tc-btn-invisible,\n.tc-block-dropdown .tc-btn-invisible,\n.tc-drop-down a, .tc-drop-down button {\n font-size: 18px;\n line-height: 1.8;\n font-weight: normal;\n margin: 0;\n}\n\n.tc-drop-down a, .tc-drop-down button {\n display: block !important;\n text-align: left !important;\n}\n\n.tc-drop-down .tc-btn-invisible {\n display: block !important;\n text-align: left !important;\n margin: 0 !important;\n}\n\n\n\n<$reveal state=\"$:/palette\" type=\"match\" text=\"$:/themes/jd/Material/Palette/MaterialLightBase\">\n\n.tc-drop-down button.tc-btn-invisible:hover,\n.tc-drop-down button.tc-btn-invisible:hover span.tc-dirty-indicator {\n color: <<colour background>>;\n}\n\n.tc-drop-down button.tc-btn-invisible:hover svg,\n.tc-drop-down button.tc-btn-invisible:hover span.tc-dirty-indicator svg,\n.tc-file-input-wrapper:hover button svg {\n fill: <<colour background>>;\n}\n\n</$reveal>\n\n<$reveal state=\"$:/palette\" type=\"match\" text=\"$:/themes/jd/Material/Palette/MaterialDarkBase\">\n\n.tc-drop-down button.tc-btn-invisible:hover,\n.tc-drop-down button.tc-btn-invisible:hover span.tc-dirty-indicator {\n color: <<colour button-foreground>>;\n}\n\n.tc-drop-down button.tc-btn-invisible:hover svg,\n.tc-drop-down button.tc-btn-invisible:hover span.tc-dirty-indicator svg,\n.tc-file-input-wrapper:hover button svg {\n fill: <<colour button-foreground>>;\n}\n\n</$reveal>\n\n@media (max-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n\n<$reveal type=\"nomatch\" state=\"$:/view\" text=\"zoomin\">\n<$reveal type=\"match\" state=\"$:/themes/jd/Material/ConfigDB##mobilepopups\" text=\"yes\">\n.tc-drop-down,\n.tc-block-dropdown {\n position: fixed !important;\n top: 48% !important;\n left: {{$:/themes/jd/Material/ConfigDB##fabxy}} !important;\n max-height: calc(100% - 200px);\n min-width: calc(100% - {{$:/themes/jd/Material/ConfigDB##fabxy}}*2);\n max-width: calc(100% - {{$:/themes/jd/Material/ConfigDB##fabxy}}*2);\n -webkit-transform: translateY(-50%);\n -moz-transform: translateY(-50%);\n -ms-transform: translateY(-50%);\n -o-transform: translateY(-50%);\n transform: translateY(-50%);\n text-align: left;\n overflow: auto;\n z-index: 1000;\n}\n</$reveal>\n</$reveal>\n\n.tc-tiddler-frame {\n padding: 16px;\n margin: 0;\n <<box-shadow \"none\">>\n}\n\n.tc-story-river .tc-tiddler-frame:nth-last-child(2) {\n border-bottom: 0;\n}\n\ninput:focus, textarea:focus, button:focus, select:focus { outline: 0; }\n\ninput:focus, textarea:focus {\n outline: 0;\n border-bottom: 1px solid <<colour tag-background>>; \n}\n\n}\n\n\n<$reveal type=\"match\" state=\"$:/themes/jd/Material/ConfigDB##outlinenone\" text=\"yes\">\n@media (min-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\ninput:focus, textarea:focus, button:focus, select:focus { outline: 0; }\n}\n</$reveal>\n\n\n/* STORY RIVER, TIDDLER FRAME */\n\n@media (min-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n.tc-story-river { padding: 42px; }\n<$reveal type=\"nomatch\" state=\"$:/state/sidebar\" text=\"no\" default={{$:/themes/jd/Material/ConfigDB##listsdefon}}>\n.tc-story-river { padding-left: calc({{$:/themes/tiddlywiki/vanilla/metrics/sidebarwidth}} + 42px); }\n</$reveal>\n<$reveal type=\"match\" state=\"$:/view\" text=\"zoomin\">\n<$reveal type=\"match\" state=\"$:/state/sidebar\" text=\"no\" default={{$:/themes/jd/Material/ConfigDB##listsdefon}}>\nbody.tc-body .tc-storyview-zoomin-tiddler { \nwidth: calc(100% - 42px - 42px);\n}\n</$reveal>\n<$reveal type=\"nomatch\" state=\"$:/state/sidebar\" text=\"no\" default={{$:/themes/jd/Material/ConfigDB##listsdefon}}>\nbody.tc-body .tc-storyview-zoomin-tiddler { \nwidth: calc(100% - {{$:/themes/tiddlywiki/vanilla/metrics/sidebarwidth}} - 42px - 42px);\n}\n</$reveal>\n</$reveal>\n<$reveal type=\"match\" state=\"$:/state/sidebar\" text=\"no\" default={{$:/themes/jd/Material/ConfigDB##listsdefon}}>\n.tc-tiddler-frame {\n width: {{$:/themes/jd/Material/ConfigDB##tiddler-width}};\n margin-left: auto;\n margin-right: auto;\n}\n</$reveal>\n<$reveal type=\"nomatch\" state=\"$:/state/sidebar\" text=\"no\" default={{$:/themes/jd/Material/ConfigDB##listsdefon}}>\n.tc-tiddler-frame { width: 100%; }\n</$reveal>\n.tc-tiddler-frame {\n padding: 28px 42px;\n border: 0;\n}\n}\n\n.tc-sidebar-scrollable, .tc-topbar { display: none; }\n\n\n@media (min-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n.tc-story-river { padding-top: calc(56px + 42px); }\n}\n\n@media (max-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n.tc-story-river { padding-top: 56px; }\n}\n\n.tc-tiddler-frame {\n <<box-shadow \"0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 1px 5px 0 rgba(0, 0, 0, 0.12)\">>\n}\n\n\n/* VANILLA TWEAKS */\n\n.tc-story-river { width: 100%; }\n\n.tc-btn-mini { color: <<colour muted-foreground>>; }\n\n<$list filter=\"[{$:/palette}prefix[$:/themes/jd/Material/Palette/]]\">\nbody.tc-dirty div.header-wrapper span.tc-dirty-indicator,\nbody.tc-dirty div.header-wrapper span.tc-dirty-indicator svg {\n fill: <<colour button-background>>;\n color: <<colour button-background>>;\n}\n</$list>\n\nbutton.tc-btn-invisible.header-btn .tc-dirty-indicator {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n}\n\n.tc-notification {\n text-shadow: none;\n border-radius: 2px;\n <<box-shadow \"0 3px 4px 0 rgba(0, 0, 0, 0.14), 0 3px 3px -2px rgba(0, 0, 0, 0.2), 0 1px 8px 0 rgba(0, 0, 0, 0.12)\">>\n}\n\n.tc-modal { left: {{$:/themes/jd/Material/ConfigDB##fabxy}}; width: calc(100% - {{$:/themes/jd/Material/ConfigDB##fabxy}}*2); top: calc(56px + 42px); }\n\n.tc-modal-backdrop { overflow: hidden; }\n\n.tc-modal-footer {\n -webkit-box-shadow: inset 0 1px 0 <<colour modal-border>>;\n -moz-box-shadow: inset 0 1px 0 <<colour modal-border>>;\n box-shadow: inset 0 1px 0 <<colour modal-border>>;\n}\n\n.tc-modal-wrapper { z-index: 1000; }\n\n.tc-plugin-info-dropdown,\n.tc-plugin-info { border: 1px solid <<colour table-border>>; }\n\n<$reveal type=\"match\" state=\"$:/themes/tiddlywiki/vanilla/options/stickytitles\" text=\"yes\" default =\"no\">\n.tc-tiddler-title {\n top: 55px;\n z-index: 700;\n}\n</$reveal>\n\n.tc-plugin-reload-warning { z-index: 2000; }\n\n\n/* HTML TWEAKS */\n\nhr,\nhr.tc-untagged-separator {\n color: <<colour table-border>>;\n background-color: <<colour table-border>>;\n height: 1px;\n border: 0;\n}\n\ninput, input[type=\"password\"] { \n background: <<colour background>>;\n border: 1px solid <<colour tiddler-editor-border>>;\n}\n\ninput[type=\"color\"] {\n background: <<colour dropdown-background>>;\n border: 1px solid <<colour tiddler-editor-border>>;\n}\n\nbutton {\n border: 0;\n border-radius: 2px;\n padding: 6px 16px;\n margin: 2px;\n}\n\n.tc-btn-invisible {\n color: inherit;\n}\n\nselect {\n max-width: 100%;\n background: <<colour dropdown-background>>;\n border: 1px solid <<colour tiddler-editor-border>>;\n}\n\n\n/* FOR COLOR PICKER */\n\n.color-prev {\n width: 30px; \n height: 30px; \n border: 1px solid white;\n border-radius: 15px;\n display: inline-block;\n margin-right: 10px;\n}\n.edit-color {\n padding: 10px;\n margin: 10px 0;\n border: 1px solid <<colour tiddler-editor-border>>;\n border-radius: 2px;\n} \n@media (max-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n.edit-color { width: 100%; } \n}\n\n@media (min-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n\n/* SCROLLBARS */\n\ndiv::-webkit-scrollbar { background: rgba(0, 0, 0, 0.12); }\ndiv::-webkit-scrollbar-thumb { background: rgba(0, 0, 0, 0.12); }\n}\n\n\n\n/*! * animate.css -http://daneden.me/animate * Version - 3.6.0 * Licensed under the MIT license - http://opensource.org/licenses/MIT * * Copyright (c) 2018 Daniel Eden */\n\n/* customized for TW5 Material theme by jd */\n\n .animated{\n -webkit-animation-duration: <<dur>>;\n animation-duration: <<dur>>;\n -webkit-animation-fill-mode:both;\n animation-fill-mode:both\n -webkit-animation-timing-function:cubic-bezier(.215,.61,.355,1);\n animation-timing-function:cubic-bezier(.215,.61,.355,1);\n}\n\n@-webkit-keyframes slideInLeft{\n 0%{\n -webkit-transform:translate3d(-100%,0,0);\n transform:translate3d(-100%,0,0);\n visibility:visible\n }\n to{\n -webkit-transform:translateZ(0);\n transform:translateZ(0)\n }\n}\n@keyframes slideInLeft{\n 0%{\n -webkit-transform:translate3d(-100%,0,0);\n transform:translate3d(-100%,0,0);\n visibility:visible\n }\n to{\n -webkit-transform:translateZ(0);\n transform:translateZ(0)\n }\n}\n.slideInLeft{\n -webkit-animation-name:slideInLeft;\n animation-name:slideInLeft\n}\n\n<$list filter=\"[[$:/plugins/tiddlywiki/hammerjs][$:/plugins/BurningTree/hammerwidgets]!is[missing]]\">\n@-webkit-keyframes slideInUp {\n from {\n -webkit-transform: translate3d(0, 100%, 0);\n transform: translate3d(0, 100%, 0);\n visibility: visible;\n }\n\n to {\n -webkit-transform: translate3d(0, 0, 0);\n transform: translate3d(0, 0, 0);\n }\n}\n\n@keyframes slideInUp {\n from {\n -webkit-transform: translate3d(0, 100%, 0);\n transform: translate3d(0, 100%, 0);\n visibility: visible;\n }\n\n to {\n -webkit-transform: translate3d(0, 0, 0);\n transform: translate3d(0, 0, 0);\n }\n}\n\n.slideInUp {\n -webkit-animation-name: slideInUp;\n animation-name: slideInUp;\n}\n\ndiv.animated.slideInUp {\n position: fixed;\n bottom: calc({{$:/themes/jd/Material/ConfigDB##fabxy}} + {{$:/themes/jd/Material/ConfigDB##fabsize}} + {{$:/themes/jd/Material/ConfigDB##fabmargin}} + {{$:/themes/jd/Material/ConfigDB##fabmargin}});\n right: {{$:/themes/jd/Material/ConfigDB##fabxy}};\n overflow: hidden;\n z-index: 800;\n}\n\n.jd-swipearea {\n position: fixed;\n bottom: 0;\n opacity: 0;\n width: 15px;\n height: calc(100% - 56px);\n z-index: 1100;\n}\n.jd-swipearea-on {\n left: 0;\n background: green;\n}\n.jd-swipearea-off {\n right: 0;\n background: red;\n}\n</$list>\n\ndiv.animated.slideInLeft {\n position: fixed;\n top: 56px;\n left: 0;\n min-height: 100%;\n z-index: 1000;\n}\n\n@media (min-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\ndiv.animated.slideInLeft {\n width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarwidth}};\n}\n}\n@media (max-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\ndiv.animated.slideInLeft {\n width: 100%;\n}\n}\n\n\n\n\n\n\n</pre>",
"title": "$:/themes/jd/Material/Stylesheet",
"tags": "$:/tags/Stylesheet",
"modifier": "jd",
"modified": "20180727121130707",
"list-after": "$:/themes/tiddlywiki/vanilla/base"
},
"$:/themes/jd/Material/Palette/MaterialLightBase": {
"created": "20180324091659091",
"creator": "jd",
"text": "alert-background: <<colour background>>\nalert-border: <<colour very-muted-foreground>>\nalert-highlight: <<colour very-muted-foreground>>\nalert-muted-foreground: <<colour muted-foreground>>\nbackground: #FAFAFA\nblockquote-bar: <<colour page-background>>\nbutton-background: {{$:/themes/jd/Material/ConfigDB##color-button-background}}\nbutton-foreground: \nbutton-border: <<colour button-background>>\ncode-background: #ececec\ncode-border: transparent\ncode-foreground: rgba(0, 0, 0, 0.54)\ndirty-indicator: <<colour sidebar-tab-background>>\ndownload-background: <<colour primary>>\ndownload-foreground: <<colour background>>\ndragger-background: <<colour foreground>>\ndragger-foreground: <<colour background>>\ndropdown-background: #FFFFFF\ndropdown-border: <<colour dropdown-background>>\ndropdown-tab-background-selected: <<colour dropdown-background>>\ndropdown-tab-background: #F5F5F5\ndropzone-background: <<colour tag-background>>\nexternal-link-background-hover: transparent\nexternal-link-background-visited: transparent\nexternal-link-background: transparent\nexternal-link-foreground-hover: <<colour sidebar-tab-background>>\nexternal-link-foreground-visited: <<colour tag-background>>\nexternal-link-foreground: <<colour sidebar-tab-background>>\nforeground: rgba(0, 0, 0, 0.87)\nmessage-background: <<colour background>>\nmessage-border: <<colour very-muted-foreground>>\nmessage-foreground: rgba(0, 0, 0, 0.54)\nmodal-backdrop: <<colour foreground>>\nmodal-background: <<colour background>>\nmodal-border: <<colour very-muted-foreground>>\nmodal-footer-background: <<colour background>>\nmodal-footer-border: <<colour very-muted-foreground>>\nmodal-header-border: <<colour very-muted-foreground>>\nmuted-foreground: rgba(0, 0, 0, 0.54)\nnotification-background: <<colour dropdown-background>>\nnotification-border: <<colour dropdown-background>>\npage-background: #E0E0E0\npre-background: <<colour code-background>>\npre-border: transparent\nprimary: {{$:/themes/jd/Material/ConfigDB##color-primary}}\nsidebar-button-foreground: <<colour foreground>>\nsidebar-controls-foreground-hover: #000000\nsidebar-controls-foreground: #aaaaaa\nsidebar-foreground-shadow: transparent\nsidebar-foreground: rgba(0, 0, 0, 0.54)\nsidebar-muted-foreground-hover: rgba(0, 0, 0, 0.54)\nsidebar-muted-foreground: rgba(0, 0, 0, 0.38)\nsidebar-tab-background-selected: transparent\nsidebar-tab-background: {{$:/themes/jd/Material/ConfigDB##color-sidebar-tab-background}}\nsidebar-tab-border-selected: <<colour button-background>>\nsidebar-tab-border: transparent\nsidebar-tab-divider: transparent\nsidebar-tab-foreground-selected: white\nsidebar-tab-foreground: white\nsidebar-tiddler-link-foreground-hover: rgba(0, 0, 0, 0.87)\nsidebar-tiddler-link-foreground: rgba(0, 0, 0, 0.54)\nsite-title-foreground: rgba(0, 0, 0, 0.87)\nstatic-alert-foreground: #aaaaaa\ntab-background-selected: <<colour background>>\ntab-background: transparent\ntab-border-selected: #dadada\ntab-border: transparent\ntab-divider: #dadada\ntab-foreground-selected: rgba(0, 0, 0, 0.87)\ntab-foreground: rgba(0, 0, 0, 0.54)\ntable-border: #dadada\ntable-footer-background: <<colour tiddler-editor-fields-odd>>\ntable-header-background: <<colour tiddler-editor-fields-even>>\ntag-background: {{$:/themes/jd/Material/ConfigDB##color-tag-background}}\ntag-foreground: <<colour button-foreground>>\ntiddler-background: <<colour background>>\ntiddler-border: transparent\ntiddler-controls-foreground-hover: #a0a0a0\ntiddler-controls-foreground-selected: #a0a0a0\ntiddler-controls-foreground: #c5c5c5\ntiddler-editor-background: transparent\ntiddler-editor-border-image: \ntiddler-editor-border: <<colour very-muted-foreground>>\ntiddler-editor-fields-even: rgba(0, 0, 0, 0.1)\ntiddler-editor-fields-odd: rgba(0, 0, 0, 0.04)\ntiddler-info-background: #F5F5F5\ntiddler-info-border: #F5F5F5\ntiddler-info-tab-background: <<colour tiddler-editor-fields-odd>>\ntiddler-link-background: <<colour background>>\ntiddler-link-foreground: <<colour primary>>\ntiddler-subtitle-foreground: <<colour muted-foreground>>\ntiddler-title-foreground: #000000\ntoolbar-new-button: \ntoolbar-options-button: \ntoolbar-save-button: \ntoolbar-info-button: \ntoolbar-edit-button: \ntoolbar-close-button: \ntoolbar-delete-button: \ntoolbar-cancel-button: \ntoolbar-done-button: \nuntagged-background: <<colour very-muted-foreground>>\nvery-muted-foreground: rgba(0, 0, 0, 0.12)",
"type": "application/x-tiddler-dictionary",
"title": "$:/themes/jd/Material/Palette/MaterialLightBase",
"revision": "16-1f6eabb9816382603cfa899327890536",
"name": "Material Light Base",
"modifier": "jd",
"modified": "20180720144801444",
"description": "Bright material base"
},
"$:/themes/jd/Material/Palette/MaterialDarkBase": {
"created": "20180325092158840",
"creator": "jd",
"text": "alert-background: <<colour background>>\nalert-border: <<colour very-muted-foreground>>\nalert-highlight: <<colour very-muted-foreground>>\nalert-muted-foreground: <<colour muted-foreground>>\nbackground: #303030\nblockquote-bar: <<colour page-background>>\nbutton-background: {{$:/themes/jd/Material/ConfigDB##color-button-background}}\nbutton-foreground: <<colour background>>\nbutton-border: <<colour button-background>>\ncode-background: #383838\ncode-border: <<colour code-background>>\ncode-foreground: rgba(255, 255, 255, 0.54)\ndirty-indicator: <<colour sidebar-tab-background>>\ndownload-background: <<colour primary>>\ndownload-foreground: <<colour foreground>>\ndragger-background: <<colour foreground>>\ndragger-foreground: <<colour background>>\ndropdown-background: #424242\ndropdown-border: <<colour dropdown-background>>\ndropdown-tab-background-selected: <<colour dropdown-background>>\ndropdown-tab-background: #050505\ndropzone-background: <<colour tag-background>>\nexternal-link-background-hover: transparent\nexternal-link-background-visited: transparent\nexternal-link-background: transparent\nexternal-link-foreground-hover: <<colour sidebar-tab-background>>\nexternal-link-foreground-visited: <<colour tag-background>>\nexternal-link-foreground: <<colour sidebar-tab-background>>\nforeground: rgba(255, 255, 255, 0.7)\nmessage-background: <<colour background>>\nmessage-border: <<colour very-muted-foreground>>\nmessage-foreground: rgba(255, 255, 255, 0.54)\nmodal-backdrop: <<colour page-background>>\nmodal-background: <<colour background>>\nmodal-border: <<colour very-muted-foreground>>\nmodal-footer-background: <<colour background>>\nmodal-footer-border: <<colour background>>\nmodal-header-border: <<colour very-muted-foreground>>\nmuted-foreground: rgba(255, 255, 255, 0.54)\nnotification-background: <<colour dropdown-background>>\nnotification-border: <<colour dropdown-background>>\npage-background: #212121\npre-background: <<colour code-background>>\npre-border: <<colour code-background>>\nprimary: {{$:/themes/jd/Material/ConfigDB##color-primary}}\nsidebar-button-foreground: <<colour foreground>>\nsidebar-controls-foreground-hover: #FFFFFF\nsidebar-controls-foreground: #aaaaaa\nsidebar-foreground-shadow: transparent\nsidebar-foreground: rgba(255, 255, 255, 0.54)\nsidebar-muted-foreground-hover: rgba(255, 255, 255, 0.54)\nsidebar-muted-foreground: rgba(255, 255, 255, 0.38)\nsidebar-tab-background-selected: transparent\nsidebar-tab-background: {{$:/themes/jd/Material/ConfigDB##color-sidebar-tab-background}}\nsidebar-tab-border-selected: <<colour button-background>>\nsidebar-tab-border: transparent\nsidebar-tab-divider: transparent\nsidebar-tab-foreground-selected: white\nsidebar-tab-foreground: rgba(255, 255, 255, 0.87)\nsidebar-tiddler-link-foreground-hover: rgba(255, 255, 255, 0.7)\nsidebar-tiddler-link-foreground: rgba(255, 255, 255, 0.54)\nsite-title-foreground: rgba(255, 255, 255, 0.7)\nstatic-alert-foreground: #aaaaaa\ntab-background-selected: <<colour background>>\ntab-background: transparent\ntab-border-selected: #585858\ntab-border: transparent\ntab-divider: #585858\ntab-foreground-selected: rgba(255, 255, 255, 0.87)\ntab-foreground: rgba(255, 255, 255, 0.54)\ntable-border: rgba(255, 255, 255, 0.12)\ntable-footer-background: <<colour tiddler-editor-fields-odd>>\ntable-header-background: <<colour tiddler-editor-fields-even>>\ntag-background: {{$:/themes/jd/Material/ConfigDB##color-tag-background}}\ntag-foreground: <<colour button-foreground>>\ntiddler-background: <<colour background>>\ntiddler-border: transparent\ntiddler-controls-foreground-hover: #797979\ntiddler-controls-foreground-selected: #797979\ntiddler-controls-foreground: #636363\ntiddler-editor-background: transparent\ntiddler-editor-border-image: \ntiddler-editor-border: <<colour very-muted-foreground>>\ntiddler-editor-fields-even: rgba(255, 255, 255, 0.1)\ntiddler-editor-fields-odd: rgba(255, 255, 255, 0.04)\ntiddler-info-background: #454545\ntiddler-info-border: #454545\ntiddler-info-tab-background: <<colour tiddler-editor-fields-odd>>\ntiddler-link-background: <<colour background>>\ntiddler-link-foreground: <<colour button-background>>\ntiddler-subtitle-foreground: <<colour muted-foreground>>\ntiddler-title-foreground: #FFFFFF\ntoolbar-new-button: \ntoolbar-options-button: \ntoolbar-save-button: \ntoolbar-info-button: \ntoolbar-edit-button: \ntoolbar-close-button: \ntoolbar-delete-button: \ntoolbar-cancel-button: \ntoolbar-done-button: \nuntagged-background: <<colour very-muted-foreground>>\nvery-muted-foreground: rgba(255, 255, 255, 0.12)\ntiddler-link-foreground-visited: #aeaeae",
"type": "application/x-tiddler-dictionary",
"title": "$:/themes/jd/Material/Palette/MaterialDarkBase",
"revision": "16-bb276562b7c93c8ace69907892d92eed",
"name": "Material Dark Base",
"modifier": "jd",
"modified": "20180720145138316",
"description": "Grim material base"
},
"$:/themes/jd/Material/ConfigDB": {
"created": "20180327133017293",
"creator": "jd",
"text": "{\n \"fabmargin\": \"5px\",\n \"fabsize\": \"56px\",\n \"fabxy\": \"30px\",\n \"fab\": \"$:/core/ui/Buttons/new-tiddler\",\n \"fab1\": \"$:/core/ui/Buttons/control-panel\",\n \"fab2\": \"$:/core/ui/Buttons/save-wiki\",\n \"fab3\": \"\",\n \"fab4\": \"\",\n \"fab5\": \"\",\n \"fab6\": \"\",\n \"headerbtns\": \"4\",\n \"icon\": \"{{$:/core/images/menu-button}}\",\n \"statelists\": \"yes\",\n \"mobilepopups\": \"yes\",\n \"outlinenone\": \"no\",\n \"fabiconsize\": \"26px\",\n \"listsdefon\": \"yes\",\n \"color-primary\": \"#01579B\",\n \"color-sidebar-tab-background\": \"#0288D1\",\n \"color-button-background\": \"#cfd8dc\",\n \"color-tag-background\": \"#cfd8dc\",\n \"styledframes\": \"yes\",\n \"tiddler-width\": \"100%\"\n}",
"type": "application/json",
"title": "$:/themes/jd/Material/ConfigDB",
"tags": "",
"modifier": "jd",
"modified": "20180727131000723"
},
"$:/themes/jd/Material/Tweaks/Colors": {
"created": "20180324100034128",
"creator": "jd",
"text": "\\define paletteBase(theme:Light) $:/themes/jd/Material/Palette/Material$theme$Base\n\n\\define swColor(color) <div class=\"color-prev\" style=\"background: $color$;\"/>\n\n\\define setColor(name,v2,v3,v4,v5,theme,icon:\"{{$:/core/images/menu-button}}\") \n<$button class=\"tc-btn-invisible\" style=\"text-align: left;\"> $name$\n<$action-setfield $tiddler=\"$:/palette\" text=<<paletteBase $theme$>>/>\n<$action-setfield $tiddler=\"$:/themes/jd/Material/ConfigDB\" $index=\"color-primary\" $value=$v2$/>\n<$action-setfield $tiddler=\"$:/themes/jd/Material/ConfigDB\" $index=\"color-sidebar-tab-background\" $value=$v3$/>\n<$action-setfield $tiddler=\"$:/themes/jd/Material/ConfigDB\" $index=\"color-button-background\" $value=$v4$/>\n<$action-setfield $tiddler=\"$:/themes/jd/Material/ConfigDB\" $index=\"color-tag-background\" $value=$v5$/>\n<$action-setfield $tiddler=\"$:/themes/jd/Material/ConfigDB\" $index=\"icon\" $value=\"$icon$\"/>\n<div>\n<$macrocall $name=\"swColor\" color=$v2$/>\n<$macrocall $name=\"swColor\" color=$v3$/>\n<$macrocall $name=\"swColor\" color=$v4$/>\n<$macrocall $name=\"swColor\" color=$v5$/>\n</div>\n</$button> \n\\end\n\n\\define materialPalette(theme)\n<<setColor \"Colored chalk\" #52366c #644a7d #00a9c7 #FFC107 $theme$>>\n<<setColor \"Zombie\" #a00000 #b40000 #00a0a0 #00a0a0 $theme$>>\n<<setColor \"Mahvanilla\" #01579B #0288D1 #cfd8dc #cfd8dc $theme$>>\n<<setColor \"Red sun\" #d50000 #ff5131 #fbc02d #ffab91 $theme$>>\n<<setColor \"The woods\" #004d40 #39796b #9e9e9e #66bb6a $theme$>>\n<<setColor \"Bonfire\" #880e4f #bc477b #ff5722 #ff616f $theme$>>\n<<setColor \"Lumpy space princess\" #7b1fa2 #ae52d4 #e57373 #fdd835 $theme$>>\n<<setColor \"The bends\" #37474f #62727b #bdbdbd #bdbdbd $theme$>>\n<<setColor \"BMNoir\" #212121 #424242 #aeaeae #aeaeae $theme$ \"{{$:/themes/jd/Material/images/bmnoir}}\">>\n<<setColor \"Pet sounds\" #f9a825 #fbc02d #4dd0e1 #4dd0e1 $theme$>>\n<<setColor \"Tomatoes\" #b71c1c #f05545 #8BC34A #CDDC39 $theme$>>\n<<setColor \"Most material\" #303f9f #3f51b5 #e91e63 #e91e63 $theme$>>\n\\end\n\n\\define editColor(description,index)\n<div class=\"edit-color\">\n<div style=\"margin-bottom: 5px;\">\n<i class=\"tc-muted\">\n$description$\n</i>\n</div>\n<div>\n<$reveal state=\"$:/palette\" type=\"match\" text=<<paletteBase Light>>>\n<$edit-text tiddler=\"$:/themes/jd/Material/ConfigDB\" index=$index$ tag=\"input\"/> \n<$edit-text tiddler=\"$:/themes/jd/Material/ConfigDB\" index=$index$ tag=\"input\" type=\"color\"/>\n</$reveal>\n<$reveal state=\"$:/palette\" type=\"match\" text=<<paletteBase Dark>>>\n<$edit-text tiddler=\"$:/themes/jd/Material/ConfigDB\" index=$index$ tag=\"input\"/> \n<$edit-text tiddler=\"$:/themes/jd/Material/ConfigDB\" index=$index$ tag=\"input\" type=\"color\"/>\n</$reveal>\n</div>\n</div>\n\\end\n\n<$button popup=<<qualify \"$:/state/popup/colorschemeLight\">>> Light theme (popup selection)</$button>\n<$button popup=<<qualify \"$:/state/popup/colorschemeDark\">>> Dark theme (popup selection)</$button>\n<$reveal state=\"$:/state/edit/MaterialPalette\" type=\"nomatch\" text=\"yes\">\n<$button set=\"$:/state/edit/MaterialPalette\" setTo=\"yes\"> Show color editor</$button>\n</$reveal>\n<$reveal state=\"$:/state/edit/MaterialPalette\" type=\"match\" text=\"yes\">\n<$button set=\"$:/state/edit/MaterialPalette\" setTo=\"no\"> Hide color editor</$button>\n</$reveal>\n\n<$reveal state=<<qualify \"$:/state/popup/colorschemeLight\">> type=\"popup\" position=\"below\" animate=\"yes\">\n<div class=\"tc-drop-down\">\n<<materialPalette Light>>\n</div>\n</$reveal>\n\n<$reveal state=<<qualify \"$:/state/popup/colorschemeDark\">> type=\"popup\" position=\"below\" animate=\"yes\">\n<div class=\"tc-drop-down\">\n<<materialPalette Dark>>\n</div>\n</$reveal>\n\n<$reveal state=\"$:/state/edit/MaterialPalette\" type=\"match\" text=\"yes\">\n<$list filter=\"[prefix[$:/palette]search[$:/themes/jd/Material/Palette]]\">\n\n<<editColor \"header, internal links\" \"color-primary\">>\n<<editColor \"header tabs, unvisited external links, save-wiki dirty indicator on Tools sidebar\" \"color-sidebar-tab-background\">>\n<<editColor \"default button and FAB background, border for selected header tab, save-wiki dirty indicator on header\" \"color-button-background\">>\n<<editColor \"default tags, visited external links\" \"color-tag-background\">>\n</$list>\n</$reveal>\n",
"type": "text/vnd.tiddlywiki",
"title": "$:/themes/jd/Material/Tweaks/Colors",
"tags": "",
"revision": "9-db2ad17dc6729615095d5196ee9f4d0a",
"modifier": "jd",
"modified": "20180623074749214"
},
"$:/themes/jd/Material/Tweaks": {
"created": "20180324164501795",
"creator": "jd",
"text": "\\define configDB(caption,index)\n<tr><td>$caption$: </td><td><$edit-text tiddler=\"$:/themes/jd/Material/ConfigDB\" index=$index$ tag=\"input\"/></td></tr>\n\\end\n\n\\define selectFAB(fab)\n<$select tiddler=\"$:/themes/jd/Material/ConfigDB\" index=\"$fab$\">\n<option value=\"\"> none </option>\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/PageControls]!has[draft.of]sort[title]]-[{$:/themes/jd/Material/ConfigDB##fab}]-[{$:/themes/jd/Material/ConfigDB##fab1}]-[{$:/themes/jd/Material/ConfigDB##fab2}]-[{$:/themes/jd/Material/ConfigDB##fab3}]-[{$:/themes/jd/Material/ConfigDB##fab4}]-[{$:/themes/jd/Material/ConfigDB##fab5}]-[{$:/themes/jd/Material/ConfigDB##fab6}][{$:/themes/jd/Material/ConfigDB##$fab$}]\">\n<option>\n<$view field=\"title\"/>\n</option>\n</$list>\n</$select>\n<$button class=\"tc-btn-invisible tc-tiddlylink\"> remove\n<$action-setfield $tiddler=\"$:/themes/jd/Material/ConfigDB\" $index=$fab$ $value=\"\"/>\n</$button>\n\\end\n\n!! Sidebar & tiddlers\n\n|State of sidebar when $:/state/sidebar is missing |<$select tiddler=\"$:/themes/jd/Material/ConfigDB\" index=\"listsdefon\"><option value=\"yes\">open</option><option value=\"no\">close</option></$select>|\n|Number of sidebar tabs visible without scrolling |<$select tiddler=\"$:/themes/jd/Material/ConfigDB\" index=\"headerbtns\"><option>3</option><option>4</option><option>5</option><option>6</option></$select> |\n|Tiddler width when sidebar is closed |<$edit-text tiddler=\"$:/themes/jd/Material/ConfigDB\" index=\"tiddler-width\" tag=\"input\" class=\"tc-edit-texteditor\"/> |\n\n<hr>\n\n!! Colors\n\n{{$:/themes/jd/Material/Tweaks/Colors}}\n\n<hr>\n\n!! FAB buttons\n\n''Primary FAB button''\n\n<<selectFAB fab>>\n\n''Secondary FAB buttons''\n\n<<selectFAB fab1>>\n<<selectFAB fab2>>\n<<selectFAB fab3>>\n<<selectFAB fab4>>\n<<selectFAB fab5>>\n<<selectFAB fab6>>\n\n''FAB Size''\n\n<table>\n<<configDB \"Button Size\" fabsize>>\n<<configDB \"Button icon size\" fabiconsize>>\n<<configDB \"Offset from bottom right corner\" fabxy>>\n<<configDB \"Margin\" fabmargin>>\n</table>\n\n<hr>\n\n!! Miscellaneous\n\n<$checkbox tiddler=\"$:/themes/jd/Material/ConfigDB\" index=\"mobilepopups\" checked=\"yes\" unchecked=\"no\"> Center popups and dropdowns in mobile view (will not apply in Zoomin view)</$checkbox>\n\n<$checkbox tiddler=\"$:/themes/jd/Material/ConfigDB\" index=\"styledframes\" checked=\"yes\" unchecked=\"no\"> Style the tiddler frames</$checkbox>\n\n<$checkbox tiddler=\"$:/themes/jd/Material/ConfigDB\" index=\"outlinenone\" checked=\"yes\" unchecked=\"no\"> Don't show outline on buttons and input areas even on desktop (for your reference: [[Outlinenone|http://www.outlinenone.com/]])</$checkbox>\n\nYou can install Roboto font as a plugin by following this link (plugin by ~TheDiveO): [[TW5Roboto|https://github.com/TheDiveO/TW5Roboto/releases/tag/v0.9.0]]\n\nGet [[swipe/tap capabilities|http://j.d.material.tiddlyspot.com/#Make%20it%20swipable%20%2F%20tappable]]\n\nGet [[Material icons|http://j.d.material.tiddlyspot.com/#Make%20it%20more%20Material]]\n\n<hr>\n\n!! Vanilla tweaks\n\n{{$:/themes/jd/Material/Tweaks/VanillaExtract}}\n\n<hr>\n\n!! References\n\nhttps://material.io/\n\nhttps://material.io/icons/\n\nhttps://material.io/color/",
"type": "text/vnd.tiddlywiki",
"title": "$:/themes/jd/Material/Tweaks",
"tags": "$:/tags/ControlPanel/Appearance",
"revision": "4-958d85408a4b3265a91b3b01483187c6",
"modifier": "jd",
"modified": "20180729063315199",
"caption": "Material Tweaks"
},
"$:/themes/jd/Material/Buttons/advanced-search": {
"created": "20180331111734954",
"creator": "jd",
"text": "\\define control-panel-button(class)\n<$button tooltip={{$:/language/Buttons/AdvancedSearch/Hint}} aria-label={{$:/language/Buttons/AdvancedSearch/Caption}} class=\"\"\"$(tv-config-toolbar-class)$ $class$\"\"\">\n<$action-setfield $tiddler=\"$:/state/header-searchbar\" text=\"open\"/>\n<$action-setfield $tiddler=\"$:/state/sidebar\" text=\"no\"/>\n<$list filter=\"[<tv-config-toolbar-icons>prefix[yes]]\">\n{{$:/core/images/advanced-search-button}}\n</$list>\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\"><$text text={{$:/language/Buttons/AdvancedSearch/Caption}}/></span>\n</$list>\n</$button>\n\\end\n\n<$list filter=\"[list[$:/StoryList]] +[field:title[$:/AdvancedSearch]]\" emptyMessage=<<control-panel-button>>>\n<<control-panel-button \"tc-selected\">>\n</$list>\n",
"title": "$:/themes/jd/Material/Buttons/advanced-search",
"modifier": "jd",
"modified": "20180405104412302",
"description": "{{$:/language/Buttons/AdvancedSearch/Hint}}",
"caption": "{{$:/core/images/advanced-search-button}} {{$:/language/Buttons/AdvancedSearch/Caption}}"
},
"$:/themes/jd/Material/Tweaks/VanillaExtract": {
"text": "\\define lingo-base() $:/language/ThemeTweaks/\n\n\\define replacement-text()\n[img[$(imageTitle)$]]\n\\end\n\n\\define backgroundimage-dropdown()\n<div class=\"tc-drop-down-wrapper\">\n<$button popup=<<qualify \"$:/state/popup/themetweaks/backgroundimage\">> class=\"tc-btn-invisible tc-btn-dropdown\">{{$:/core/images/down-arrow}}</$button>\n<$reveal state=<<qualify \"$:/state/popup/themetweaks/backgroundimage\">> type=\"popup\" position=\"belowleft\" text=\"\" default=\"\">\n<div class=\"tc-drop-down\">\n<$macrocall $name=\"image-picker\" actions=\"\"\"\n\n<$action-setfield\n\t$tiddler=\"$:/themes/tiddlywiki/vanilla/settings/backgroundimage\"\n\t$value=<<imageTitle>>\n/>\n\n\"\"\"/>\n</div>\n</$reveal>\n</div>\n\\end\n\n\\define backgroundimageattachment-dropdown()\n<$select tiddler=\"$:/themes/tiddlywiki/vanilla/settings/backgroundimageattachment\" default=\"scroll\">\n<option value=\"scroll\"><<lingo Settings/BackgroundImageAttachment/Scroll>></option>\n<option value=\"fixed\"><<lingo Settings/BackgroundImageAttachment/Fixed>></option>\n</$select>\n\\end\n\n\\define backgroundimagesize-dropdown()\n<$select tiddler=\"$:/themes/tiddlywiki/vanilla/settings/backgroundimagesize\" default=\"scroll\">\n<option value=\"auto\"><<lingo Settings/BackgroundImageSize/Auto>></option>\n<option value=\"cover\"><<lingo Settings/BackgroundImageSize/Cover>></option>\n<option value=\"contain\"><<lingo Settings/BackgroundImageSize/Contain>></option>\n</$select>\n\\end\n\nThe following are the only inherited tweaks from Vanilla theme (others found in [[Theme Tweaks|$:/themes/tiddlywiki/vanilla/themetweaks]] do not apply):\n\n''<<lingo Options>>''\n\n|<$link to=\"$:/themes/tiddlywiki/vanilla/options/stickytitles\"><<lingo Options/StickyTitles>></$link><br>//Causes tiddler titles to \"stick\" to the top of the browser window. Caution: Not compatible with all browsers// |<$select tiddler=\"$:/themes/tiddlywiki/vanilla/options/stickytitles\"><option value=\"no\">{{$:/language/No}}</option><option value=\"yes\">{{$:/language/Yes}}</option></$select> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/options/codewrapping\"><<lingo Options/CodeWrapping>></$link> |<$select tiddler=\"$:/themes/tiddlywiki/vanilla/options/codewrapping\"><option value=\"pre\">{{$:/language/No}}</option><option value=\"pre-wrap\">{{$:/language/Yes}}</option></$select> |\n\n''<<lingo Settings>>''\n\n|<$link to=\"$:/themes/tiddlywiki/vanilla/settings/fontfamily\"><<lingo Settings/FontFamily>></$link> |<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/settings/fontfamily\" default=\"\" tag=\"input\"/> | |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/settings/codefontfamily\"><<lingo Settings/CodeFontFamily>></$link> |<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/settings/codefontfamily\" default=\"\" tag=\"input\"/> | |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/settings/editorfontfamily\"><<lingo Settings/EditorFontFamily>></$link> |<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/settings/editorfontfamily\" default=\"\" tag=\"input\"/> | |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/settings/backgroundimage\"><<lingo Settings/BackgroundImage>></$link> |<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/settings/backgroundimage\" default=\"\" tag=\"input\"/> |<<backgroundimage-dropdown>> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/settings/backgroundimageattachment\"><<lingo Settings/BackgroundImageAttachment>></$link> |<<backgroundimageattachment-dropdown>> | |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/settings/backgroundimagesize\"><<lingo Settings/BackgroundImageSize>></$link> |<<backgroundimagesize-dropdown>> | |\n\n''<<lingo Metrics>>''\n\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/fontsize\"><<lingo Metrics/FontSize>></$link> |<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/fontsize\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/lineheight\"><<lingo Metrics/LineHeight>></$link> |<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/lineheight\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/bodyfontsize\"><<lingo Metrics/BodyFontSize>></$link> |<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/bodyfontsize\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/bodylineheight\"><<lingo Metrics/BodyLineHeight>></$link> |<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/bodylineheight\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint\"><<lingo Metrics/SidebarBreakpoint>></$link><br>//<<lingo Metrics/SidebarBreakpoint/Hint>>// |^<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/sidebarwidth\"><<lingo Metrics/SidebarWidth>></$link><br>//<<lingo Metrics/SidebarWidth/Hint>>// |^<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/sidebarwidth\" default=\"\" tag=\"input\"/> |\n",
"title": "$:/themes/jd/Material/Tweaks/VanillaExtract",
"modifier": "jd",
"modified": "20180402152332643",
"creator": "jd",
"created": "20180402133727759",
"caption": "{{$:/language/ThemeTweaks/ThemeTweaks}}"
},
"$:/themes/jd/Material/images/bmnoir": {
"text": "<!-- Generator: Adobe Illustrator 17.1.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->\n<svg height=\"24\" viewBox=\"0 0 24 24\" width=\"24\" version=\"1.1\" id=\"Capa_1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" x=\"0px\" y=\"0px\"\n\t viewBox=\"0 0 213.167 213.167\" style=\"enable-background:new 0 0 213.167 213.167;\" xml:space=\"preserve\">\n<path d=\"M106.583,167.873c-28.275,0-54.889-6.26-74.938-17.625C11.239,138.678,0,123.172,0,106.583s11.239-32.095,31.646-43.664\n\tc20.049-11.366,46.663-17.625,74.938-17.625c28.276,0,54.889,6.26,74.938,17.625c20.407,11.569,31.646,27.076,31.646,43.664\n\ts-11.238,32.095-31.646,43.664C161.473,161.614,134.859,167.873,106.583,167.873z M106.583,49.294C50.019,49.294,4,74.994,4,106.583\n\tc0,31.59,46.019,57.29,102.583,57.29s102.583-25.7,102.583-57.29C209.167,74.994,163.148,49.294,106.583,49.294z M106.584,152.017\n\tc-0.857,0-1.619-0.546-1.895-1.357c-1.904-5.609-8.217-20.886-14.479-24.175c-2.021-1.062-3.857-1.6-5.457-1.6\n\tc-2.834,0-4.435,1.683-5.604,2.911l-0.326,0.34c-1.648,1.688-4.735,5.793-4.766,5.834c-0.359,0.479-0.915,0.77-1.512,0.796\n\tc-0.599,0.031-1.177-0.217-1.576-0.663c-0.088-0.097-8.854-9.76-17.168-9.835l-0.137,0c-2.721,0-4.726,0.75-5.958,2.23\n\tc-2.114,2.539-1.581,6.52-1.367,7.68c0.81,4.398,4.182,10.027,4.216,10.083c0.44,0.73,0.369,1.658-0.176,2.313\n\tc-0.545,0.655-1.445,0.892-2.243,0.591c-1.285-0.485-31.527-12.151-35.551-36.035c-2.75-16.321,8.916-31.372,32.849-42.38\n\tc8.49-3.906,22.902-7.795,23.512-7.958c0.855-0.23,1.764,0.133,2.226,0.89c0.462,0.758,0.37,1.73-0.228,2.387\n\tc-0.463,0.513-11.284,12.715-2.284,22.52c2.735,2.98,6.157,4.555,9.895,4.555c7.319,0,13.888-5.828,14.655-10.842\n\tc1.396-9.113,1.578-21.362,1.58-21.485c0.013-0.902,0.627-1.685,1.501-1.91c0.876-0.226,1.79,0.164,2.237,0.948l4.979,8.75\n\tl3.035-0.061l3.115,0.061l4.979-8.75c0.446-0.783,1.361-1.171,2.236-0.948c0.874,0.225,1.489,1.007,1.502,1.91\n\tc0.002,0.123,0.184,12.372,1.579,21.485c0.769,5.014,7.338,10.842,14.656,10.842c3.739,0,7.161-1.575,9.896-4.555\n\tc9.035-9.842-1.817-22.007-2.283-22.52c-0.598-0.657-0.69-1.629-0.228-2.387c0.461-0.758,1.368-1.122,2.226-0.89\n\tc0.609,0.164,15.021,4.053,23.511,7.958c23.934,11.008,35.6,26.059,32.85,42.38c-4.025,23.884-34.267,35.55-35.552,36.035\n\tc-0.798,0.3-1.697,0.063-2.242-0.591s-0.616-1.583-0.177-2.313c0.034-0.056,3.409-5.699,4.217-10.084\n\tc0.213-1.16,0.745-5.141-1.368-7.68c-1.232-1.479-3.236-2.229-5.957-2.229l-0.136,0c-8.315,0.075-17.081,9.737-17.169,9.835\n\tc-0.399,0.444-0.969,0.692-1.576,0.663c-0.598-0.026-1.153-0.318-1.513-0.796c-0.03-0.042-3.119-4.148-4.766-5.834l-0.325-0.338\n\tc-1.169-1.229-2.77-2.913-5.604-2.913c-1.599,0-3.435,0.538-5.457,1.6c-6.269,3.293-12.577,18.567-14.479,24.174\n\tC108.202,151.471,107.441,152.017,106.584,152.017z M84.753,120.885c2.254,0,4.716,0.692,7.317,2.059\n\tc6.336,3.328,11.771,14.738,14.513,21.439c2.743-6.701,8.176-18.111,14.513-21.439c2.601-1.367,5.063-2.059,7.316-2.059\n\tc4.552,0,7.122,2.704,8.504,4.156l0.288,0.301c1.066,1.092,2.583,2.972,3.686,4.382c3.24-3.12,10.702-9.386,18.438-9.456l0.173,0\n\tc3.964,0,7.002,1.235,9.03,3.67c3.139,3.77,2.604,8.923,2.229,10.964c-0.379,2.059-1.195,4.272-2.045,6.198\n\tc8.579-4.322,25.225-14.637,27.92-30.635c3.104-18.423-14.914-30.877-30.576-38.081c-5-2.3-12.379-4.661-17.395-6.159\n\tc3.579,6.26,5.8,15.43-1.212,23.068c-3.513,3.827-7.954,5.85-12.843,5.85c-8.752,0-17.448-6.653-18.609-14.237\n\tc-0.753-4.914-1.161-10.578-1.38-14.936l-2.074,3.646c-0.363,0.637-1.05,1.051-1.778,1.01l-4.225-0.084l-4.145,0.084\n\tc-0.754,0.033-1.416-0.373-1.778-1.01l-2.074-3.646c-0.219,4.357-0.627,10.022-1.38,14.936c-1.162,7.584-9.857,14.237-18.609,14.237\n\tc-4.889,0-9.329-2.023-12.842-5.85c-7.012-7.639-4.791-16.808-1.211-23.068c-5.016,1.497-12.396,3.858-17.396,6.159\n\tc-15.662,7.204-33.68,19.659-30.576,38.081c2.696,15.998,19.341,26.313,27.92,30.635c-0.849-1.926-1.665-4.14-2.044-6.198\n\tc-0.376-2.041-0.912-7.194,2.227-10.963c2.028-2.436,5.067-3.671,9.032-3.671l0.173,0c7.736,0.07,15.198,6.336,18.438,9.456\n\tc1.103-1.41,2.619-3.29,3.686-4.383l0.29-0.302C77.633,123.588,80.204,120.885,84.753,120.885z\"/>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n<g>\n</g>\n</svg>\n",
"title": "$:/themes/jd/Material/images/bmnoir",
"tags": "$:/tags/Image",
"reference": "https://www.svgrepo.com/svg/27924/batman",
"modifier": "jd",
"modified": "20180402145004759",
"creator": "jd",
"created": "20180402144419317"
},
"$:/themes/jd/Material/Template/Header-Sidebar": {
"created": "20180324031529092",
"creator": "jd",
"text": "\\define config-title() $:/config/PageControlButtons/Visibility/$(listItem)$\n<div class=\"header-back\"></div>\n<div class=\"header-wrapper\">\n<div style=\"padding: 16px; width: 100%; display: flex; flex-direction: column; flex: 0 0 auto;\">\n<$reveal state=\"$:/state/header-searchbar\" type=\"match\" text=\"close\" default=\"close\" animate=\"yes\" tag=\"div\" class=\"header-type-wrapper\">\n<$reveal state=\"$:/state/sidebar\" type=\"nomatch\" text=\"no\" default={{$:/themes/jd/Material/ConfigDB##listsdefon}}>\n<$button set=\"$:/state/sidebar\" setTo=\"no\" tooltip={{$:/language/Buttons/HideSideBar/Hint}} aria-label={{$:/language/Buttons/HideSideBar/Caption}} class=\"tc-btn-invisible header-btn\" style=\"margin-right: 16px;\">\n<$action-setfield $tiddler=\"$:/themes/jd/Material/ConfigDB\" $index=\"statelists\" $value=\"no\"/>\n{{$:/themes/jd/Material/ConfigDB##icon}}\n</$button>\n</$reveal>\n<$reveal state=\"$:/state/sidebar\" type=\"match\" text=\"no\" default={{$:/themes/jd/Material/ConfigDB##listsdefon}}>\n<$button set=\"$:/state/sidebar\" setTo=\"yes\" tooltip={{$:/language/Buttons/ShowSideBar/Hint}} aria-label={{$:/language/Buttons/ShowSideBar/Caption}} class=\"tc-btn-invisible header-btn\" style=\"margin-right: 16px;\">\n<$action-setfield $tiddler=\"$:/themes/jd/Material/ConfigDB\" $index=\"statelists\" $value=\"yes\"/>\n{{$:/themes/jd/Material/ConfigDB##icon}}\n</$button>\n</$reveal>\n<div class=\"header-title\">{{$:/SiteTitle}}</div>\n<div style=\"display: flex; justify-content: space-between; align-items: center;\">\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/PageControls]!has[draft.of]][[$:/themes/jd/Material/Buttons/advanced-search]][[$:/core/ui/Buttons/more-page-actions]]\" variable=\"listItem\">\n<$reveal type=\"nomatch\" state=<<config-title>> text=\"hide\" tag=\"div\" style=\"margin-left: 16px;\">\n<$set name=\"tv-config-toolbar-class\" value=\"tc-btn-invisible header-btn\">\n<$transclude tiddler=<<listItem>> mode=\"inline\"/>\n</$set>\n</$reveal>\n</$list>\n</div>\n</$reveal>\n<$reveal state=\"$:/state/header-searchbar\" type=\"match\" text=\"open\" default=\"close\" animate=\"yes\" tag=\"div\" class=\"header-type-wrapper\">\n<div class=\"jd-search-header\">\n<$keyboard tag=\"div\" class=\"jd-search-bar\" key=\"escape\" actions=\"\"\"\n<$action-setfield $tiddler=\"$:/temp/advancedsearch\" $field=\"text\" $value=\"\"/>\n<$action-setfield $tiddler=\"$:/state/header-searchbar\" text=\"close\"/>\n<$action-setfield $tiddler=\"$:/state/sidebar\" text={{$:/themes/jd/Material/ConfigDB##statelists}}/>\n\"\"\">\n<$edit-text tiddler=\"$:/temp/advancedsearch\" type=\"search\" tag=\"input\" focus=\"yes\" placeholder=\"Search\" default=\"Search\"/>\n</$keyboard>\n<$list filter=\"[[$:/temp/advancedsearch]!text[]]\" variable=\"stateCheck\">\n<div class=\"jd-search-body\">\n<$list filter=\"[{$:/temp/advancedsearch}minlength{$:/config/Search/MinLength}limit[1]]\" emptyMessage=\"\"\"<div style=\"padding: 16px 28px;\">\n{{$:/language/Search/Search/TooShort}}. Adjust minimum search length [[here|$:/config/Search/MinLength]]\n</div>\"\"\" variable=\"listItem\">\n<$macrocall $name=\"tabs\" tabsList=\"[all[shadows+tiddlers]tag[$:/tags/AdvancedSearch]!has[draft.of]]\" default=\"$:/core/ui/AdvancedSearch/Standard\" state=\"$:/state/searchtab\"/>\n</$list>\n</div>\n</$list>\n<div class=\"jd-search-buttons\">\n<$button class=\"tc-btn-invisible\">\n<$action-setfield $tiddler=\"$:/temp/advancedsearch\" $field=\"text\" $value=\"\"/>\n<$action-setfield $tiddler=\"$:/state/header-searchbar\" text=\"close\"/>\n<$action-setfield $tiddler=\"$:/state/sidebar\" text={{$:/themes/jd/Material/ConfigDB##statelists}}/>\n{{$:/core/images/close-button}}\n</$button>\n<$set filter=\"[search:title[$:/state/searchtab-]!sort[modified]limit[1]]\" name=\"searchTabState\">\n<$list filter=\"[<searchTabState>text[$:/core/ui/AdvancedSearch/Filter]]\" variable=\"stateCheck\">\n<$list filter=\"[all[shadows+tiddlers]tag[$:/tags/AdvancedSearch/FilterButton]!has[draft.of]]-[[$:/core/ui/AdvancedSearch/Filter/FilterButtons/clear]]-[[$:/core/ui/AdvancedSearch/Filter/FilterButtons/dropdown]]\"><$transclude/>\n</$list>\n</$list>\n</$set>\n{{$:/core/ui/AdvancedSearch/Filter/FilterButtons/dropdown}}\n</div>\n</div>\n</$reveal>\n</div>\n</div>\n<$reveal state=\"$:/state/sidebar\" type=\"nomatch\" text=\"no\" retain=\"yes\" animate=\"yes\" tag=\"div\" class=\"animated slideInLeft\" default={{$:/themes/jd/Material/ConfigDB##listsdefon}}>\n<$macrocall $name=\"tabs\" tabsList=\"[all[shadows+tiddlers]tag[$:/tags/SideBar]!has[draft.of]]\" default={{$:/config/DefaultSidebarTab}} state=\"$:/state/tab/sidebar\" class=\"jd-lists-body\"/>\n</$reveal>\n<$list filter=\"[[$:/plugins/tiddlywiki/hammerjs][$:/plugins/BurningTree/hammerwidgets]!is[missing]]\">\n<$swipe class=\"jd-swipearea jd-swipearea-on\" velocity=\"0.5\" rightactions=\"\"\"<$action-setfield $tiddler=\"$:/state/sidebar\" $value=\"yes\"/><$action-setfield $tiddler=\"$:/themes/jd/Material/ConfigDB\" $index=\"statelists\" $value=\"yes\"/>\"\"\">\n</$swipe>\n<$swipe class=\"jd-swipearea jd-swipearea-off\" velocity=\"0.5\" leftactions=\"\"\"<$action-setfield $tiddler=\"$:/state/sidebar\" $value=\"no\"/><$action-setfield $tiddler=\"$:/themes/jd/Material/ConfigDB\" $index=\"statelists\" $value=\"no\"/>\"\"\">\n</$swipe>\n</$list>\n<$set name=\"tv-config-toolbar-class\" value=\"tc-btn-invisible FABitem\">\n<$list filter=\"[[$:/plugins/tiddlywiki/hammerjs][$:/plugins/BurningTree/hammerwidgets]!is[missing]]\" variable =\"checker\">\n<$swipe class=\"FAB-wrapper\" velocity=\"0.1\" upactions=\"\"\"<$action-setfield $tiddler=\"$:/state/FABs\" $value=\"yes\"/>\"\"\">\n<$tap actions=\"\"\"<$action-setfield $tiddler=\"$:/state/FABs\" $value=\"no\"/>\"\"\">\n<div class=\"FAB-wrapper\">\n<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab}}/>\n</div>\n</$tap>\n</$swipe>\n<$reveal type=\"match\" state=\"$:/state/FABs\" text=\"yes\" animate=\"yes\" retain=\"yes\" tag=\"div\" class=\"animated slideInUp\">\n<$swipe class=\"FABs-wrapper\" velocity=\"0.1\" downactions=\"\"\"<$action-setfield $tiddler=\"$:/state/FABs\" $value=\"no\"/>\"\"\">\n<$tap actions=\"\"\"<$action-setfield $tiddler=\"$:/state/FABs\" $value=\"no\"/>\"\"\">\n<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab1}}/>\n<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab2}}/>\n<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab3}}/>\n<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab4}}/>\n<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab5}}/>\n<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab6}}/>\n</$tap>\n</$swipe>\n</$reveal>\n</$list>\n<$list filter=\"[[$:/plugins/tiddlywiki/hammerjs][$:/plugins/BurningTree/hammerwidgets]is[missing]]\" variable =\"checker\">\n<div class=\"FAB-wrapper\">\n<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab}}/>\n</div>\n<div class=\"FABs-wrapper\">\n<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab1}}/>\n<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab2}}/>\n<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab3}}/>\n<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab4}}/>\n<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab5}}/>\n<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab6}}/>\n</div>\n</$list>\n</$set>",
"title": "$:/themes/jd/Material/Template/Header-Sidebar",
"tags": "$:/tags/PageTemplate",
"modifier": "jd",
"modified": "20180727122430818"
},
"$:/themes/jd/Material/readme": {
"created": "20180331123050873",
"creator": "jd",
"text": "Hello, this [[TW5|https://tiddlywiki.com/]] theme is inspired by Google's ''Material Design''\n\nWhen updating, you might want to delete this config tiddler first: $:/themes/jd/Material/ConfigDB\n<br><em class=\"tc-muted\">the above shadow tiddler gets overwritten when tweaking this theme at the control panel</em>\n\nYou can always get the latest updates here:\n\nhttp://j.d.material.tiddlyspot.com/\n\nPlease report bugs / suggest anything here:\n\nhttps://github.com/jdjdjdjdjdjd/TW5-Material\n\nGoogle Groups discussion:\n\nhttps://groups.google.com/forum/#!topic/TiddlyWiki/qiS1Vs46EQw%5B1-25%5D\n\nMy other TW5 stuff:\n\nhttp://j.d.tiddlyspot.com/",
"title": "$:/themes/jd/Material/readme",
"modifier": "jd",
"modified": "20180727131317409",
"extra": "hammerwidgets"
}
}
}
{
"fabmargin": "5px",
"fabsize": "30px",
"fabxy": "30px",
"fab": "$:/core/ui/Buttons/new-tiddler",
"fab1": "$:/core/ui/Buttons/control-panel",
"fab2": "$:/core/ui/Buttons/save-wiki",
"fab3": "",
"fab4": "",
"fab5": "",
"fab6": "",
"headerbtns": "5",
"icon": "{{$:/core/images/menu-button}}",
"statelists": "yes",
"mobilepopups": "yes",
"outlinenone": "no",
"fabiconsize": "25px",
"listsdefon": "yes",
"color-primary": "#405429",
"color-sidebar-tab-background": "#c1dc05",
"color-button-background": "#9e9e9e",
"color-tag-background": "#eb9d74",
"styledframes": "yes",
"tiddler-width": "100%"
}
<svg class="tc-overflow-button tc-image-button" viewBox="0 0 24 24" width="22pt" height="22pt" xmlns="http://www.w3.org/2000/svg">
<path d="M0 0h24v24H0z" fill="none"/>
<path d="M12 8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm0 2c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z"/>
</svg>
alert-background: <<colour background>>
alert-border: <<colour very-muted-foreground>>
alert-highlight: <<colour very-muted-foreground>>
alert-muted-foreground: <<colour muted-foreground>>
background: #303030
blockquote-bar: <<colour page-background>>
button-background: {{$:/themes/jd/Material/ConfigDB##color-button-background}}
button-foreground: <<colour background>>
button-border: <<colour button-background>>
code-background: #383838
code-border: <<colour code-background>>
code-foreground: rgba(255, 255, 255, 0.54)
dirty-indicator: <<colour sidebar-tab-background>>
download-background: <<colour primary>>
download-foreground: <<colour foreground>>
dragger-background: <<colour foreground>>
dragger-foreground: <<colour background>>
dropdown-background: #424242
dropdown-border: <<colour dropdown-background>>
dropdown-tab-background-selected: <<colour dropdown-background>>
dropdown-tab-background: #050505
dropzone-background: <<colour tag-background>>
external-link-background-hover: transparent
external-link-background-visited: transparent
external-link-background: transparent
external-link-foreground-hover: <<colour sidebar-tab-background>>
external-link-foreground-visited: <<colour tag-background>>
external-link-foreground: #c0c0c0
foreground: rgba(255, 255, 255, 0.7)
message-background: <<colour background>>
message-border: <<colour very-muted-foreground>>
message-foreground: rgba(255, 255, 255, 0.54)
modal-backdrop: <<colour page-background>>
modal-background: <<colour background>>
modal-border: <<colour very-muted-foreground>>
modal-footer-background: <<colour background>>
modal-footer-border: <<colour background>>
modal-header-border: <<colour very-muted-foreground>>
muted-foreground: rgba(255, 255, 255, 0.54)
notification-background: <<colour dropdown-background>>
notification-border: <<colour dropdown-background>>
page-background: #212121
pre-background: <<colour code-background>>
pre-border: <<colour code-background>>
primary: {{$:/themes/jd/Material/ConfigDB##color-primary}}
sidebar-button-foreground: <<colour foreground>>
sidebar-controls-foreground-hover: #FFFFFF
sidebar-controls-foreground: #aaaaaa
sidebar-foreground-shadow: transparent
sidebar-foreground: rgba(255, 255, 255, 0.54)
sidebar-muted-foreground-hover: rgba(255, 255, 255, 0.54)
sidebar-muted-foreground: rgba(255, 255, 255, 0.38)
sidebar-tab-background-selected: transparent
sidebar-tab-background: {{$:/themes/jd/Material/ConfigDB##color-sidebar-tab-background}}
sidebar-tab-border-selected: <<colour button-background>>
sidebar-tab-border: transparent
sidebar-tab-divider: transparent
sidebar-tab-foreground-selected: white
sidebar-tab-foreground: rgba(255, 255, 255, 0.87)
sidebar-tiddler-link-foreground-hover: rgba(255, 255, 255, 0.7)
sidebar-tiddler-link-foreground: rgba(255, 255, 255, 0.54)
site-title-foreground: rgba(255, 255, 255, 0.7)
static-alert-foreground: #aaaaaa
tab-background-selected: <<colour background>>
tab-background: transparent
tab-border-selected: #585858
tab-border: transparent
tab-divider: #585858
tab-foreground-selected: rgba(255, 255, 255, 0.87)
tab-foreground: rgba(255, 255, 255, 0.54)
table-border: rgba(255, 255, 255, 0.12)
table-footer-background: <<colour tiddler-editor-fields-odd>>
table-header-background: <<colour tiddler-editor-fields-even>>
tag-background: {{$:/themes/jd/Material/ConfigDB##color-tag-background}}
tag-foreground: <<colour button-foreground>>
tiddler-background: <<colour background>>
tiddler-border: transparent
tiddler-controls-foreground-hover: #797979
tiddler-controls-foreground-selected: #797979
tiddler-controls-foreground: #636363
tiddler-editor-background: transparent
tiddler-editor-border-image:
tiddler-editor-border: <<colour very-muted-foreground>>
tiddler-editor-fields-even: rgba(255, 255, 255, 0.1)
tiddler-editor-fields-odd: rgba(255, 255, 255, 0.04)
tiddler-info-background: #454545
tiddler-info-border: #454545
tiddler-info-tab-background: <<colour tiddler-editor-fields-odd>>
tiddler-link-background: <<colour background>>
tiddler-link-foreground: <<colour button-background>>
tiddler-subtitle-foreground: <<colour muted-foreground>>
tiddler-title-foreground: #FFFFFF
toolbar-new-button:
toolbar-options-button:
toolbar-save-button:
toolbar-info-button:
toolbar-edit-button:
toolbar-close-button:
toolbar-delete-button:
toolbar-cancel-button:
toolbar-done-button:
untagged-background: <<colour very-muted-foreground>>
very-muted-foreground: rgba(255, 255, 255, 0.12)
tiddler-link-foreground-visited: #aeaeae
\define config-title() $:/config/PageControlButtons/Visibility/$(listItem)$
<div class="tc-adjust-top-of-scroll" style="height: calc(56px + 42px);"></div>
<div class="header-back"></div>
<div class="header-wrapper">
<div style="padding: 16px; width: 100%; display: flex; flex-direction: column; flex: 0 0 auto;">
<$reveal state="$:/state/header-searchbar" type="match" text="close" default="close" animate="yes" tag="div" class="header-type-wrapper">
<$reveal state="$:/state/sidebar" type="nomatch" text="no" default={{$:/themes/jd/Material/ConfigDB##listsdefon}}>
<$button set="$:/state/sidebar" setTo="no" tooltip={{$:/language/Buttons/HideSideBar/Hint}} aria-label={{$:/language/Buttons/HideSideBar/Caption}} class="tc-btn-invisible header-btn" style="margin-right: 16px;">
<$action-setfield $tiddler="$:/themes/jd/Material/ConfigDB" $index="statelists" $value="no"/>
{{$:/themes/jd/Material/ConfigDB##icon}}
</$button>
</$reveal>
<$reveal state="$:/state/sidebar" type="match" text="no" default={{$:/themes/jd/Material/ConfigDB##listsdefon}}>
<$button set="$:/state/sidebar" setTo="yes" tooltip={{$:/language/Buttons/ShowSideBar/Hint}} aria-label={{$:/language/Buttons/ShowSideBar/Caption}} class="tc-btn-invisible header-btn" style="margin-right: 16px;">
<$action-setfield $tiddler="$:/themes/jd/Material/ConfigDB" $index="statelists" $value="yes"/>
{{$:/themes/jd/Material/ConfigDB##icon}}
</$button>
</$reveal>
<div class="header-title">{{$:/SiteTitle}}</div>
<div style="display: flex; justify-content: space-between; align-items: center;">
<$list filter="[all[shadows+tiddlers]tag[$:/tags/PageControls]!has[draft.of]][[$:/themes/jd/Material/Buttons/advanced-search]][[$:/core/ui/Buttons/more-page-actions]]" variable="listItem">
<$reveal type="nomatch" state=<<config-title>> text="hide" tag="div" style="margin-left: 16px;">
<$set name="tv-config-toolbar-class" value="tc-btn-invisible header-btn">
<$transclude tiddler=<<listItem>> mode="inline"/>
</$set>
</$reveal>
</$list>
</div>
</$reveal>
<$reveal state="$:/state/header-searchbar" type="match" text="open" default="close" animate="yes" tag="div" class="header-type-wrapper">
<div class="jd-search-header">
<$keyboard tag="div" class="jd-search-bar" key="escape" actions="""
<$action-setfield $tiddler="$:/temp/advancedsearch" $field="text" $value=""/>
<$action-setfield $tiddler="$:/state/header-searchbar" text="close"/>
<$action-setfield $tiddler="$:/state/sidebar" text={{$:/themes/jd/Material/ConfigDB##statelists}}/>
""">
<$edit-text tiddler="$:/temp/advancedsearch" type="search" tag="input" focus="yes" placeholder="Search" default="Search"/>
</$keyboard>
<$list filter="[[$:/temp/advancedsearch]!text[]]" variable="stateCheck">
<div class="jd-search-body">
<$list filter="[{$:/temp/advancedsearch}minlength{$:/config/Search/MinLength}limit[1]]" emptyMessage="""<div style="padding: 16px 28px;">
{{$:/language/Search/Search/TooShort}}. Adjust minimum search length [[here|$:/config/Search/MinLength]]
</div>""" variable="listItem">
<$macrocall $name="tabs" tabsList="[all[shadows+tiddlers]tag[$:/tags/AdvancedSearch]!has[draft.of]]" default="$:/core/ui/AdvancedSearch/Standard" state="$:/state/searchtab"/>
</$list>
</div>
</$list>
<div class="jd-search-buttons">
<$button class="tc-btn-invisible">
<$action-setfield $tiddler="$:/temp/advancedsearch" $field="text" $value=""/>
<$action-setfield $tiddler="$:/state/header-searchbar" text="close"/>
<$action-setfield $tiddler="$:/state/sidebar" text={{$:/themes/jd/Material/ConfigDB##statelists}}/>
{{$:/core/images/close-button}}
</$button>
<$set filter="[search:title[$:/state/searchtab-]!sort[modified]limit[1]]" name="searchTabState">
<$list filter="[<searchTabState>text[$:/core/ui/AdvancedSearch/Filter]]" variable="stateCheck">
<$list filter="[all[shadows+tiddlers]tag[$:/tags/AdvancedSearch/FilterButton]!has[draft.of]]-[[$:/core/ui/AdvancedSearch/Filter/FilterButtons/clear]]-[[$:/core/ui/AdvancedSearch/Filter/FilterButtons/dropdown]]"><$transclude/>
</$list>
</$list>
</$set>
{{$:/core/ui/AdvancedSearch/Filter/FilterButtons/dropdown}}
</div>
</div>
</$reveal>
</div>
</div>
<$reveal state="$:/state/sidebar" type="nomatch" text="no" retain="yes" animate="yes" tag="div" class="animated slideInLeft" default={{$:/themes/jd/Material/ConfigDB##listsdefon}}>
<$macrocall $name="tabs" tabsList="[all[shadows+tiddlers]tag[$:/tags/SideBar]!has[draft.of]]" default={{$:/config/DefaultSidebarTab}} state="$:/state/tab/sidebar" class="jd-lists-body"/>
</$reveal>
<$list filter="[[$:/plugins/tiddlywiki/hammerjs][$:/plugins/BurningTree/hammerwidgets]!is[missing]]">
<$swipe class="jd-swipearea jd-swipearea-on" velocity="0.5" rightactions="""<$action-setfield $tiddler="$:/state/sidebar" $value="yes"/><$action-setfield $tiddler="$:/themes/jd/Material/ConfigDB" $index="statelists" $value="yes"/>""">
</$swipe>
<$swipe class="jd-swipearea jd-swipearea-off" velocity="0.5" leftactions="""<$action-setfield $tiddler="$:/state/sidebar" $value="no"/><$action-setfield $tiddler="$:/themes/jd/Material/ConfigDB" $index="statelists" $value="no"/>""">
</$swipe>
</$list>
<$set name="tv-config-toolbar-class" value="tc-btn-invisible FABitem">
<$list filter="[[$:/plugins/tiddlywiki/hammerjs][$:/plugins/BurningTree/hammerwidgets]!is[missing]]" variable ="checker">
<$swipe class="FAB-wrapper" velocity="0.1" upactions="""<$action-setfield $tiddler="$:/state/FABs" $value="yes"/>""">
<$tap actions="""<$action-setfield $tiddler="$:/state/FABs" $value="no"/>""">
<div class="FAB-wrapper">
<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab}}/>
</div>
</$tap>
</$swipe>
<$reveal type="match" state="$:/state/FABs" text="yes" animate="yes" retain="yes" tag="div" class="animated slideInUp">
<$swipe class="FABs-wrapper" velocity="0.1" downactions="""<$action-setfield $tiddler="$:/state/FABs" $value="no"/>""">
<$tap actions="""<$action-setfield $tiddler="$:/state/FABs" $value="no"/>""">
<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab1}}/>
<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab2}}/>
<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab3}}/>
<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab4}}/>
<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab5}}/>
<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab6}}/>
</$tap>
</$swipe>
</$reveal>
</$list>
<$list filter="[[$:/plugins/tiddlywiki/hammerjs][$:/plugins/BurningTree/hammerwidgets]is[missing]]" variable ="checker">
<div class="FAB-wrapper">
<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab}}/>
</div>
<div class="FABs-wrapper">
<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab1}}/>
<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab2}}/>
<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab3}}/>
<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab4}}/>
<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab5}}/>
<$transclude tiddler={{$:/themes/jd/Material/ConfigDB##fab6}}/>
</div>
</$list>
</$set>
{
"tiddlers": {
"$:/themes/tiddlywiki/snowwhite/base": {
"title": "$:/themes/tiddlywiki/snowwhite/base",
"tags": "[[$:/tags/Stylesheet]]",
"text": "\\rules only filteredtranscludeinline transcludeinline macrodef macrocallinline\n\n.tc-sidebar-header {\n\ttext-shadow: 0 1px 0 <<colour sidebar-foreground-shadow>>;\n}\n\n.tc-tiddler-info {\n\t<<box-shadow \"inset 1px 2px 3px rgba(0,0,0,0.1)\">>\n}\n\n@media screen {\n\t.tc-tiddler-frame {\n\t\t<<box-shadow \"1px 1px 5px rgba(0, 0, 0, 0.3)\">>\n\t}\n}\n\n@media (max-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n\t.tc-tiddler-frame {\n\t\t<<box-shadow none>>\n\t}\n}\n\n.tc-page-controls button svg, .tc-tiddler-controls button svg, .tc-topbar button svg {\n\t<<transition \"fill 150ms ease-in-out\">>\n}\n\n.tc-tiddler-controls button.tc-selected,\n.tc-page-controls button.tc-selected {\n\t<<filter \"drop-shadow(0px -1px 2px rgba(0,0,0,0.25))\">>\n}\n\n.tc-tiddler-frame input.tc-edit-texteditor {\n\t<<box-shadow \"inset 0 1px 8px rgba(0, 0, 0, 0.15)\">>\n}\n\n.tc-edit-tags {\n\t<<box-shadow \"inset 0 1px 8px rgba(0, 0, 0, 0.15)\">>\n}\n\n.tc-tiddler-frame .tc-edit-tags input.tc-edit-texteditor {\n\t<<box-shadow \"none\">>\n\tborder: none;\n\toutline: none;\n}\n\ntextarea.tc-edit-texteditor {\n\tfont-family: {{$:/themes/tiddlywiki/vanilla/settings/editorfontfamily}};\n}\n\ncanvas.tc-edit-bitmapeditor {\n\t<<box-shadow \"2px 2px 5px rgba(0, 0, 0, 0.5)\">>\n}\n\n.tc-drop-down {\n\tborder-radius: 4px;\n\t<<box-shadow \"2px 2px 10px rgba(0, 0, 0, 0.5)\">>\n}\n\n.tc-block-dropdown {\n\tborder-radius: 4px;\n\t<<box-shadow \"2px 2px 10px rgba(0, 0, 0, 0.5)\">>\n}\n\n.tc-modal {\n\tborder-radius: 6px;\n\t<<box-shadow \"0 3px 7px rgba(0,0,0,0.3)\">>\n}\n\n.tc-modal-footer {\n\tborder-radius: 0 0 6px 6px;\n\t<<box-shadow \"inset 0 1px 0 #fff\">>;\n}\n\n\n.tc-alert {\n\tborder-radius: 6px;\n\t<<box-shadow \"0 3px 7px rgba(0,0,0,0.6)\">>\n}\n\n.tc-notification {\n\tborder-radius: 6px;\n\t<<box-shadow \"0 3px 7px rgba(0,0,0,0.3)\">>\n\ttext-shadow: 0 1px 0 rgba(255,255,255, 0.8);\n}\n\n.tc-sidebar-lists .tc-tab-set .tc-tab-divider {\n\tborder-top: none;\n\theight: 1px;\n\t<<background-linear-gradient \"left, rgba(0,0,0,0.15) 0%, rgba(0,0,0,0.0) 100%\">>\n}\n\n.tc-more-sidebar > .tc-tab-set > .tc-tab-buttons > button {\n\t<<background-linear-gradient \"left, rgba(0,0,0,0.01) 0%, rgba(0,0,0,0.1) 100%\">>\n}\n\n.tc-more-sidebar > .tc-tab-set > .tc-tab-buttons > button.tc-tab-selected {\n\t<<background-linear-gradient \"left, rgba(0,0,0,0.05) 0%, rgba(255,255,255,0.05) 100%\">>\n}\n\n.tc-message-box img {\n\t<<box-shadow \"1px 1px 3px rgba(0,0,0,0.5)\">>\n}\n\n.tc-plugin-info {\n\t<<box-shadow \"1px 1px 3px rgba(0,0,0,0.5)\">>\n}\n"
}
}
}
{
"tiddlers": {
"$:/themes/tiddlywiki/vanilla/themetweaks": {
"title": "$:/themes/tiddlywiki/vanilla/themetweaks",
"tags": "$:/tags/ControlPanel/Appearance",
"caption": "{{$:/language/ThemeTweaks/ThemeTweaks}}",
"text": "\\define lingo-base() $:/language/ThemeTweaks/\n\n\\define replacement-text()\n[img[$(imageTitle)$]]\n\\end\n\n\\define backgroundimage-dropdown()\n<div class=\"tc-drop-down-wrapper\">\n<$button popup=<<qualify \"$:/state/popup/themetweaks/backgroundimage\">> class=\"tc-btn-invisible tc-btn-dropdown\">{{$:/core/images/down-arrow}}</$button>\n<$reveal state=<<qualify \"$:/state/popup/themetweaks/backgroundimage\">> type=\"popup\" position=\"belowleft\" text=\"\" default=\"\">\n<div class=\"tc-drop-down\">\n<$macrocall $name=\"image-picker\" actions=\"\"\"\n\n<$action-setfield\n\t$tiddler=\"$:/themes/tiddlywiki/vanilla/settings/backgroundimage\"\n\t$value=<<imageTitle>>\n/>\n\n\"\"\"/>\n</div>\n</$reveal>\n</div>\n\\end\n\n\\define backgroundimageattachment-dropdown()\n<$select tiddler=\"$:/themes/tiddlywiki/vanilla/settings/backgroundimageattachment\" default=\"scroll\">\n<option value=\"scroll\"><<lingo Settings/BackgroundImageAttachment/Scroll>></option>\n<option value=\"fixed\"><<lingo Settings/BackgroundImageAttachment/Fixed>></option>\n</$select>\n\\end\n\n\\define backgroundimagesize-dropdown()\n<$select tiddler=\"$:/themes/tiddlywiki/vanilla/settings/backgroundimagesize\" default=\"scroll\">\n<option value=\"auto\"><<lingo Settings/BackgroundImageSize/Auto>></option>\n<option value=\"cover\"><<lingo Settings/BackgroundImageSize/Cover>></option>\n<option value=\"contain\"><<lingo Settings/BackgroundImageSize/Contain>></option>\n</$select>\n\\end\n\n<<lingo ThemeTweaks/Hint>>\n\n! <<lingo Options>>\n\n|<$link to=\"$:/themes/tiddlywiki/vanilla/options/sidebarlayout\"><<lingo Options/SidebarLayout>></$link> |<$select tiddler=\"$:/themes/tiddlywiki/vanilla/options/sidebarlayout\"><option value=\"fixed-fluid\"><<lingo Options/SidebarLayout/Fixed-Fluid>></option><option value=\"fluid-fixed\"><<lingo Options/SidebarLayout/Fluid-Fixed>></option></$select> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/options/stickytitles\"><<lingo Options/StickyTitles>></$link><br>//<<lingo Options/StickyTitles/Hint>>// |<$select tiddler=\"$:/themes/tiddlywiki/vanilla/options/stickytitles\"><option value=\"no\">{{$:/language/No}}</option><option value=\"yes\">{{$:/language/Yes}}</option></$select> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/options/codewrapping\"><<lingo Options/CodeWrapping>></$link> |<$select tiddler=\"$:/themes/tiddlywiki/vanilla/options/codewrapping\"><option value=\"pre\">{{$:/language/No}}</option><option value=\"pre-wrap\">{{$:/language/Yes}}</option></$select> |\n\n! <<lingo Settings>>\n\n|<$link to=\"$:/themes/tiddlywiki/vanilla/settings/fontfamily\"><<lingo Settings/FontFamily>></$link> |<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/settings/fontfamily\" default=\"\" tag=\"input\"/> | |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/settings/codefontfamily\"><<lingo Settings/CodeFontFamily>></$link> |<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/settings/codefontfamily\" default=\"\" tag=\"input\"/> | |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/settings/editorfontfamily\"><<lingo Settings/EditorFontFamily>></$link> |<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/settings/editorfontfamily\" default=\"\" tag=\"input\"/> | |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/settings/backgroundimage\"><<lingo Settings/BackgroundImage>></$link> |<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/settings/backgroundimage\" default=\"\" tag=\"input\"/> |<<backgroundimage-dropdown>> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/settings/backgroundimageattachment\"><<lingo Settings/BackgroundImageAttachment>></$link> |<<backgroundimageattachment-dropdown>> | |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/settings/backgroundimagesize\"><<lingo Settings/BackgroundImageSize>></$link> |<<backgroundimagesize-dropdown>> | |\n\n! <<lingo Metrics>>\n\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/fontsize\"><<lingo Metrics/FontSize>></$link> |<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/fontsize\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/lineheight\"><<lingo Metrics/LineHeight>></$link> |<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/lineheight\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/bodyfontsize\"><<lingo Metrics/BodyFontSize>></$link> |<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/bodyfontsize\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/bodylineheight\"><<lingo Metrics/BodyLineHeight>></$link> |<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/bodylineheight\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/storyleft\"><<lingo Metrics/StoryLeft>></$link><br>//<<lingo Metrics/StoryLeft/Hint>>// |^<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/storyleft\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/storytop\"><<lingo Metrics/StoryTop>></$link><br>//<<lingo Metrics/StoryTop/Hint>>// |^<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/storytop\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/storyright\"><<lingo Metrics/StoryRight>></$link><br>//<<lingo Metrics/StoryRight/Hint>>// |^<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/storyright\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/storywidth\"><<lingo Metrics/StoryWidth>></$link><br>//<<lingo Metrics/StoryWidth/Hint>>// |^<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/storywidth\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/tiddlerwidth\"><<lingo Metrics/TiddlerWidth>></$link><br>//<<lingo Metrics/TiddlerWidth/Hint>>//<br> |^<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/tiddlerwidth\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint\"><<lingo Metrics/SidebarBreakpoint>></$link><br>//<<lingo Metrics/SidebarBreakpoint/Hint>>// |^<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint\" default=\"\" tag=\"input\"/> |\n|<$link to=\"$:/themes/tiddlywiki/vanilla/metrics/sidebarwidth\"><<lingo Metrics/SidebarWidth>></$link><br>//<<lingo Metrics/SidebarWidth/Hint>>// |^<$edit-text tiddler=\"$:/themes/tiddlywiki/vanilla/metrics/sidebarwidth\" default=\"\" tag=\"input\"/> |\n"
},
"$:/themes/tiddlywiki/vanilla/base": {
"title": "$:/themes/tiddlywiki/vanilla/base",
"tags": "[[$:/tags/Stylesheet]]",
"text": "\\define custom-background-datauri()\n<$set name=\"background\" value={{$:/themes/tiddlywiki/vanilla/settings/backgroundimage}}>\n<$list filter=\"[<background>is[image]]\">\n`background: url(`\n<$list filter=\"[<background>!has[_canonical_uri]]\">\n`\"`<$macrocall $name=\"datauri\" title={{$:/themes/tiddlywiki/vanilla/settings/backgroundimage}}/>`\"`\n</$list>\n<$list filter=\"[<background>has[_canonical_uri]]\">\n`\"`<$view tiddler={{$:/themes/tiddlywiki/vanilla/settings/backgroundimage}} field=\"_canonical_uri\"/>`\"`\n</$list>\n`) center center;`\n`background-attachment: `{{$:/themes/tiddlywiki/vanilla/settings/backgroundimageattachment}}`;\n-webkit-background-size:` {{$:/themes/tiddlywiki/vanilla/settings/backgroundimagesize}}`;\n-moz-background-size:` {{$:/themes/tiddlywiki/vanilla/settings/backgroundimagesize}}`;\n-o-background-size:` {{$:/themes/tiddlywiki/vanilla/settings/backgroundimagesize}}`;\nbackground-size:` {{$:/themes/tiddlywiki/vanilla/settings/backgroundimagesize}}`;`\n</$list>\n</$set>\n\\end\n\n\\define if-fluid-fixed(text,hiddenSidebarText)\n<$reveal state=\"$:/themes/tiddlywiki/vanilla/options/sidebarlayout\" type=\"match\" text=\"fluid-fixed\">\n$text$\n<$reveal state=\"$:/state/sidebar\" type=\"nomatch\" text=\"yes\" default=\"yes\">\n$hiddenSidebarText$\n</$reveal>\n</$reveal>\n\\end\n\n\\define if-editor-height-fixed(then,else)\n<$reveal state=\"$:/config/TextEditor/EditorHeight/Mode\" type=\"match\" text=\"fixed\">\n$then$\n</$reveal>\n<$reveal state=\"$:/config/TextEditor/EditorHeight/Mode\" type=\"match\" text=\"auto\">\n$else$\n</$reveal>\n\\end\n\n\\rules only filteredtranscludeinline transcludeinline macrodef macrocallinline macrocallblock\n\n/*\n** Start with the normalize CSS reset, and then belay some of its effects\n*/\n\n{{$:/themes/tiddlywiki/vanilla/reset}}\n\n*, input[type=\"search\"] {\n\tbox-sizing: border-box;\n\t-moz-box-sizing: border-box;\n\t-webkit-box-sizing: border-box;\n}\n\nhtml button {\n\tline-height: 1.2;\n\tcolor: <<colour button-foreground>>;\n\tbackground: <<colour button-background>>;\n\tborder-color: <<colour button-border>>;\n}\n\n/*\n** Basic element styles\n*/\n\nhtml {\n\tfont-family: {{$:/themes/tiddlywiki/vanilla/settings/fontfamily}};\n\ttext-rendering: optimizeLegibility; /* Enables kerning and ligatures etc. */\n\t-webkit-font-smoothing: antialiased;\n\t-moz-osx-font-smoothing: grayscale;\n}\n\nhtml:-webkit-full-screen {\n\tbackground-color: <<colour page-background>>;\n}\n\nbody.tc-body {\n\tfont-size: {{$:/themes/tiddlywiki/vanilla/metrics/fontsize}};\n\tline-height: {{$:/themes/tiddlywiki/vanilla/metrics/lineheight}};\n\tword-wrap: break-word;\n\t<<custom-background-datauri>>\n\tcolor: <<colour foreground>>;\n\tbackground-color: <<colour page-background>>;\n\tfill: <<colour foreground>>;\n}\n\n<<if-background-attachment \"\"\"\n\nbody.tc-body {\n background-color: transparent;\n}\n\n\"\"\">>\n\nh1, h2, h3, h4, h5, h6 {\n\tline-height: 1.2;\n\tfont-weight: 300;\n}\n\npre {\n\tdisplay: block;\n\tpadding: 14px;\n\tmargin-top: 1em;\n\tmargin-bottom: 1em;\n\tword-break: normal;\n\tword-wrap: break-word;\n\twhite-space: {{$:/themes/tiddlywiki/vanilla/options/codewrapping}};\n\tbackground-color: <<colour pre-background>>;\n\tborder: 1px solid <<colour pre-border>>;\n\tpadding: 0 3px 2px;\n\tborder-radius: 3px;\n\tfont-family: {{$:/themes/tiddlywiki/vanilla/settings/codefontfamily}};\n}\n\ncode {\n\tcolor: <<colour code-foreground>>;\n\tbackground-color: <<colour code-background>>;\n\tborder: 1px solid <<colour code-border>>;\n\twhite-space: {{$:/themes/tiddlywiki/vanilla/options/codewrapping}};\n\tpadding: 0 3px 2px;\n\tborder-radius: 3px;\n\tfont-family: {{$:/themes/tiddlywiki/vanilla/settings/codefontfamily}};\n}\n\nblockquote {\n\tborder-left: 5px solid <<colour blockquote-bar>>;\n\tmargin-left: 25px;\n\tpadding-left: 10px;\n\tquotes: \"\\201C\"\"\\201D\"\"\\2018\"\"\\2019\";\n}\n\nblockquote.tc-big-quote {\n\tfont-family: Georgia, serif;\n\tposition: relative;\n\tbackground: <<colour pre-background>>;\n\tborder-left: none;\n\tmargin-left: 50px;\n\tmargin-right: 50px;\n\tpadding: 10px;\n border-radius: 8px;\n}\n\nblockquote.tc-big-quote cite:before {\n\tcontent: \"\\2014 \\2009\";\n}\n\nblockquote.tc-big-quote:before {\n\tfont-family: Georgia, serif;\n\tcolor: <<colour blockquote-bar>>;\n\tcontent: open-quote;\n\tfont-size: 8em;\n\tline-height: 0.1em;\n\tmargin-right: 0.25em;\n\tvertical-align: -0.4em;\n\tposition: absolute;\n left: -50px;\n top: 42px;\n}\n\nblockquote.tc-big-quote:after {\n\tfont-family: Georgia, serif;\n\tcolor: <<colour blockquote-bar>>;\n\tcontent: close-quote;\n\tfont-size: 8em;\n\tline-height: 0.1em;\n\tmargin-right: 0.25em;\n\tvertical-align: -0.4em;\n\tposition: absolute;\n right: -80px;\n bottom: -20px;\n}\n\ndl dt {\n\tfont-weight: bold;\n\tmargin-top: 6px;\n}\n\ntextarea,\ninput[type=text],\ninput[type=search],\ninput[type=\"\"],\ninput:not([type]) {\n\tcolor: <<colour foreground>>;\n\tbackground: <<colour background>>;\n}\n\ninput[type=\"checkbox\"] {\n vertical-align: middle;\n}\n\n.tc-muted {\n\tcolor: <<colour muted-foreground>>;\n}\n\nsvg.tc-image-button {\n\tpadding: 0px 1px 1px 0px;\n}\n\n.tc-icon-wrapper > svg {\n\twidth: 1em;\n\theight: 1em;\n}\n\nkbd {\n\tdisplay: inline-block;\n\tpadding: 3px 5px;\n\tfont-size: 0.8em;\n\tline-height: 1.2;\n\tcolor: <<colour foreground>>;\n\tvertical-align: middle;\n\tbackground-color: <<colour background>>;\n\tborder: solid 1px <<colour muted-foreground>>;\n\tborder-bottom-color: <<colour muted-foreground>>;\n\tborder-radius: 3px;\n\tbox-shadow: inset 0 -1px 0 <<colour muted-foreground>>;\n}\n\n/*\nMarkdown likes putting code elements inside pre elements\n*/\npre > code {\n\tpadding: 0;\n\tborder: none;\n\tbackground-color: inherit;\n\tcolor: inherit;\n}\n\ntable {\n\tborder: 1px solid <<colour table-border>>;\n\twidth: auto;\n\tmax-width: 100%;\n\tcaption-side: bottom;\n\tmargin-top: 1em;\n\tmargin-bottom: 1em;\n}\n\ntable th, table td {\n\tpadding: 0 7px 0 7px;\n\tborder-top: 1px solid <<colour table-border>>;\n\tborder-left: 1px solid <<colour table-border>>;\n}\n\ntable thead tr td, table th {\n\tbackground-color: <<colour table-header-background>>;\n\tfont-weight: bold;\n}\n\ntable tfoot tr td {\n\tbackground-color: <<colour table-footer-background>>;\n}\n\n.tc-csv-table {\n\twhite-space: nowrap;\n}\n\n.tc-tiddler-frame img,\n.tc-tiddler-frame svg,\n.tc-tiddler-frame canvas,\n.tc-tiddler-frame embed,\n.tc-tiddler-frame iframe {\n\tmax-width: 100%;\n}\n\n.tc-tiddler-body > embed,\n.tc-tiddler-body > iframe {\n\twidth: 100%;\n\theight: 600px;\n}\n\n/*\n** Links\n*/\n\nbutton.tc-tiddlylink,\na.tc-tiddlylink {\n\ttext-decoration: none;\n\tfont-weight: 500;\n\tcolor: <<colour tiddler-link-foreground>>;\n\t-webkit-user-select: inherit; /* Otherwise the draggable attribute makes links impossible to select */\n}\n\n.tc-sidebar-lists a.tc-tiddlylink {\n\tcolor: <<colour sidebar-tiddler-link-foreground>>;\n}\n\n.tc-sidebar-lists a.tc-tiddlylink:hover {\n\tcolor: <<colour sidebar-tiddler-link-foreground-hover>>;\n}\n\nbutton.tc-tiddlylink:hover,\na.tc-tiddlylink:hover {\n\ttext-decoration: underline;\n}\n\na.tc-tiddlylink-resolves {\n}\n\na.tc-tiddlylink-shadow {\n\tfont-weight: bold;\n}\n\na.tc-tiddlylink-shadow.tc-tiddlylink-resolves {\n\tfont-weight: normal;\n}\n\na.tc-tiddlylink-missing {\n\tfont-style: italic;\n}\n\na.tc-tiddlylink-external {\n\ttext-decoration: underline;\n\tcolor: <<colour external-link-foreground>>;\n\tbackground-color: <<colour external-link-background>>;\n}\n\na.tc-tiddlylink-external:visited {\n\tcolor: <<colour external-link-foreground-visited>>;\n\tbackground-color: <<colour external-link-background-visited>>;\n}\n\na.tc-tiddlylink-external:hover {\n\tcolor: <<colour external-link-foreground-hover>>;\n\tbackground-color: <<colour external-link-background-hover>>;\n}\n\n/*\n** Drag and drop styles\n*/\n\n.tc-tiddler-dragger {\n\tposition: relative;\n\tz-index: -10000;\n}\n\n.tc-tiddler-dragger-inner {\n\tposition: absolute;\n\ttop: -1000px;\n\tleft: -1000px;\n\tdisplay: inline-block;\n\tpadding: 8px 20px;\n\tfont-size: 16.9px;\n\tfont-weight: bold;\n\tline-height: 20px;\n\tcolor: <<colour dragger-foreground>>;\n\ttext-shadow: 0 1px 0 rgba(0, 0, 0, 1);\n\twhite-space: nowrap;\n\tvertical-align: baseline;\n\tbackground-color: <<colour dragger-background>>;\n\tborder-radius: 20px;\n}\n\n.tc-tiddler-dragger-cover {\n\tposition: absolute;\n\tbackground-color: <<colour page-background>>;\n}\n\n.tc-dropzone {\n\tposition: relative;\n}\n\n.tc-dropzone.tc-dragover:before {\n\tz-index: 10000;\n\tdisplay: block;\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbackground: <<colour dropzone-background>>;\n\ttext-align: center;\n\tcontent: \"<<lingo DropMessage>>\";\n}\n\n.tc-droppable > .tc-droppable-placeholder {\n\tdisplay: none;\n}\n\n.tc-droppable.tc-dragover > .tc-droppable-placeholder {\n\tdisplay: block;\n\tborder: 2px dashed <<colour dropzone-background>>;\n}\n\n.tc-draggable {\n\tcursor: move;\n}\n\n/*\n** Plugin reload warning\n*/\n\n.tc-plugin-reload-warning {\n\tz-index: 1000;\n\tdisplay: block;\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbackground: <<colour alert-background>>;\n\ttext-align: center;\n}\n\n/*\n** Buttons\n*/\n\nbutton svg, button img, label svg, label img {\n\tvertical-align: middle;\n}\n\n.tc-btn-invisible {\n\tpadding: 0;\n\tmargin: 0;\n\tbackground: none;\n\tborder: none;\n cursor: pointer;\n}\n\n.tc-btn-boxed {\n\tfont-size: 0.6em;\n\tpadding: 0.2em;\n\tmargin: 1px;\n\tbackground: none;\n\tborder: 1px solid <<colour tiddler-controls-foreground>>;\n\tborder-radius: 0.25em;\n}\n\nhtml body.tc-body .tc-btn-boxed svg {\n\tfont-size: 1.6666em;\n}\n\n.tc-btn-boxed:hover {\n\tbackground: <<colour muted-foreground>>;\n\tcolor: <<colour background>>;\n}\n\nhtml body.tc-body .tc-btn-boxed:hover svg {\n\tfill: <<colour background>>;\n}\n\n.tc-btn-rounded {\n\tfont-size: 0.5em;\n\tline-height: 2;\n\tpadding: 0em 0.3em 0.2em 0.4em;\n\tmargin: 1px;\n\tborder: 1px solid <<colour muted-foreground>>;\n\tbackground: <<colour muted-foreground>>;\n\tcolor: <<colour background>>;\n\tborder-radius: 2em;\n}\n\nhtml body.tc-body .tc-btn-rounded svg {\n\tfont-size: 1.6666em;\n\tfill: <<colour background>>;\n}\n\n.tc-btn-rounded:hover {\n\tborder: 1px solid <<colour muted-foreground>>;\n\tbackground: <<colour background>>;\n\tcolor: <<colour muted-foreground>>;\n}\n\nhtml body.tc-body .tc-btn-rounded:hover svg {\n\tfill: <<colour muted-foreground>>;\n}\n\n.tc-btn-icon svg {\n\theight: 1em;\n\twidth: 1em;\n\tfill: <<colour muted-foreground>>;\n}\n\n.tc-btn-text {\n\tpadding: 0;\n\tmargin: 0;\n}\n\n/* used for documentation \"fake\" buttons */\n.tc-btn-standard {\n\tline-height: 1.8;\n\tcolor: #667;\n\tbackground-color: #e0e0e0;\n\tborder: 1px solid #888;\n\tpadding: 2px 1px 2px 1px;\n\tmargin: 1px 4px 1px 4px;\n}\n\n.tc-btn-big-green {\n\tdisplay: inline-block;\n\tpadding: 8px;\n\tmargin: 4px 8px 4px 8px;\n\tbackground: <<colour download-background>>;\n\tcolor: <<colour download-foreground>>;\n\tfill: <<colour download-foreground>>;\n\tborder: none;\n\tfont-size: 1.2em;\n\tline-height: 1.4em;\n\ttext-decoration: none;\n}\n\n.tc-btn-big-green svg,\n.tc-btn-big-green img {\n\theight: 2em;\n\twidth: 2em;\n\tvertical-align: middle;\n\tfill: <<colour download-foreground>>;\n}\n\n.tc-sidebar-lists input {\n\tcolor: <<colour foreground>>;\n}\n\n.tc-sidebar-lists button {\n\tcolor: <<colour sidebar-button-foreground>>;\n\tfill: <<colour sidebar-button-foreground>>;\n}\n\n.tc-sidebar-lists button.tc-btn-mini {\n\tcolor: <<colour sidebar-muted-foreground>>;\n}\n\n.tc-sidebar-lists button.tc-btn-mini:hover {\n\tcolor: <<colour sidebar-muted-foreground-hover>>;\n}\n\nbutton svg.tc-image-button, button .tc-image-button img {\n\theight: 1em;\n\twidth: 1em;\n}\n\n.tc-unfold-banner {\n\tposition: absolute;\n\tpadding: 0;\n\tmargin: 0;\n\tbackground: none;\n\tborder: none;\n\twidth: 100%;\n\twidth: calc(100% + 2px);\n\tmargin-left: -43px;\n\ttext-align: center;\n\tborder-top: 2px solid <<colour tiddler-info-background>>;\n\tmargin-top: 4px;\n}\n\n.tc-unfold-banner:hover {\n\tbackground: <<colour tiddler-info-background>>;\n\tborder-top: 2px solid <<colour tiddler-info-border>>;\n}\n\n.tc-unfold-banner svg, .tc-fold-banner svg {\n\theight: 0.75em;\n\tfill: <<colour tiddler-controls-foreground>>;\n}\n\n.tc-unfold-banner:hover svg, .tc-fold-banner:hover svg {\n\tfill: <<colour tiddler-controls-foreground-hover>>;\n}\n\n.tc-fold-banner {\n\tposition: absolute;\n\tpadding: 0;\n\tmargin: 0;\n\tbackground: none;\n\tborder: none;\n\twidth: 23px;\n\ttext-align: center;\n\tmargin-left: -35px;\n\ttop: 6px;\n\tbottom: 6px;\n}\n\n.tc-fold-banner:hover {\n\tbackground: <<colour tiddler-info-background>>;\n}\n\n@media (max-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n\n\t.tc-unfold-banner {\n\t\tposition: static;\n\t\twidth: calc(100% + 59px);\n\t}\n\n\t.tc-fold-banner {\n\t\twidth: 16px;\n\t\tmargin-left: -16px;\n\t\tfont-size: 0.75em;\n\t}\n\n}\n\n/*\n** Tags and missing tiddlers\n*/\n\n.tc-tag-list-item {\n\tposition: relative;\n\tdisplay: inline-block;\n\tmargin-right: 7px;\n}\n\n.tc-tags-wrapper {\n\tmargin: 4px 0 14px 0;\n}\n\n.tc-missing-tiddler-label {\n\tfont-style: italic;\n\tfont-weight: normal;\n\tdisplay: inline-block;\n\tfont-size: 11.844px;\n\tline-height: 14px;\n\twhite-space: nowrap;\n\tvertical-align: baseline;\n}\n\nbutton.tc-tag-label, span.tc-tag-label {\n\tdisplay: inline-block;\n\tpadding: 0.16em 0.7em;\n\tfont-size: 0.9em;\n\tfont-weight: 400;\n\tline-height: 1.2em;\n\tcolor: <<colour tag-foreground>>;\n\twhite-space: nowrap;\n\tvertical-align: baseline;\n\tbackground-color: <<colour tag-background>>;\n\tborder-radius: 1em;\n}\n\n.tc-untagged-separator {\n\twidth: 10em;\n\tleft: 0;\n\tmargin-left: 0;\n\tborder: 0;\n\theight: 1px;\n\tbackground: <<colour tab-divider>>;\n}\n\nbutton.tc-untagged-label {\n\tbackground-color: <<colour untagged-background>>;\n}\n\n.tc-tag-label svg, .tc-tag-label img {\n\theight: 1em;\n\twidth: 1em;\n\tvertical-align: text-bottom;\n}\n\n.tc-tag-manager-table .tc-tag-label {\n\twhite-space: normal;\n}\n\n.tc-tag-manager-tag {\n\twidth: 100%;\n}\n\nbutton.tc-btn-invisible.tc-remove-tag-button {\n\toutline: none;\n}\n\n/*\n** Page layout\n*/\n\n.tc-topbar {\n\tposition: fixed;\n\tz-index: 1200;\n}\n\n.tc-topbar-left {\n\tleft: 29px;\n\ttop: 5px;\n}\n\n.tc-topbar-right {\n\ttop: 5px;\n\tright: 29px;\n}\n\n.tc-topbar button {\n\tpadding: 8px;\n}\n\n.tc-topbar svg {\n\tfill: <<colour muted-foreground>>;\n}\n\n.tc-topbar button:hover svg {\n\tfill: <<colour foreground>>;\n}\n\n.tc-sidebar-header {\n\tcolor: <<colour sidebar-foreground>>;\n\tfill: <<colour sidebar-foreground>>;\n}\n\n.tc-sidebar-header .tc-title a.tc-tiddlylink-resolves {\n\tfont-weight: 300;\n}\n\n.tc-sidebar-header .tc-sidebar-lists p {\n\tmargin-top: 3px;\n\tmargin-bottom: 3px;\n}\n\n.tc-sidebar-header .tc-missing-tiddler-label {\n\tcolor: <<colour sidebar-foreground>>;\n}\n\n.tc-advanced-search input {\n\twidth: 60%;\n}\n\n.tc-search a svg {\n\twidth: 1.2em;\n\theight: 1.2em;\n\tvertical-align: middle;\n}\n\n.tc-page-controls {\n\tmargin-top: 14px;\n\tfont-size: 1.5em;\n}\n\n.tc-page-controls .tc-drop-down {\n font-size: 1rem;\n}\n\n.tc-page-controls button {\n\tmargin-right: 0.5em;\n}\n\n.tc-page-controls a.tc-tiddlylink:hover {\n\ttext-decoration: none;\n}\n\n.tc-page-controls img {\n\twidth: 1em;\n}\n\n.tc-page-controls svg {\n\tfill: <<colour sidebar-controls-foreground>>;\n}\n\n.tc-page-controls button:hover svg, .tc-page-controls a:hover svg {\n\tfill: <<colour sidebar-controls-foreground-hover>>;\n}\n\n.tc-menu-list-item {\n\twhite-space: nowrap;\n}\n\n.tc-menu-list-count {\n\tfont-weight: bold;\n}\n\n.tc-menu-list-subitem {\n\tpadding-left: 7px;\n}\n\n.tc-story-river {\n\tposition: relative;\n}\n\n@media (max-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n\n\t.tc-sidebar-header {\n\t\tpadding: 14px;\n\t\tmin-height: 32px;\n\t\tmargin-top: {{$:/themes/tiddlywiki/vanilla/metrics/storytop}};\n\t}\n\n\t.tc-story-river {\n\t\tposition: relative;\n\t\tpadding: 0;\n\t}\n}\n\n@media (min-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n\n\t.tc-message-box {\n\t\tmargin: 21px -21px 21px -21px;\n\t}\n\n\t.tc-sidebar-scrollable {\n\t\tposition: fixed;\n\t\ttop: {{$:/themes/tiddlywiki/vanilla/metrics/storytop}};\n\t\tleft: {{$:/themes/tiddlywiki/vanilla/metrics/storyright}};\n\t\tbottom: 0;\n\t\tright: 0;\n\t\toverflow-y: auto;\n\t\toverflow-x: auto;\n\t\t-webkit-overflow-scrolling: touch;\n\t\tmargin: 0 0 0 -42px;\n\t\tpadding: 71px 0 28px 42px;\n\t}\n\n\thtml[dir=\"rtl\"] .tc-sidebar-scrollable {\n\t\tleft: auto;\n\t\tright: {{$:/themes/tiddlywiki/vanilla/metrics/storyright}};\n\t}\n\n\t.tc-story-river {\n\t\tposition: relative;\n\t\tleft: {{$:/themes/tiddlywiki/vanilla/metrics/storyleft}};\n\t\ttop: {{$:/themes/tiddlywiki/vanilla/metrics/storytop}};\n\t\twidth: {{$:/themes/tiddlywiki/vanilla/metrics/storywidth}};\n\t\tpadding: 42px 42px 42px 42px;\n\t}\n\n<<if-no-sidebar \"\n\n\t.tc-story-river {\n\t\twidth: calc(100% - {{$:/themes/tiddlywiki/vanilla/metrics/storyleft}});\n\t}\n\n\">>\n\n}\n\n@media print {\n\n\tbody.tc-body {\n\t\tbackground-color: transparent;\n\t}\n\n\t.tc-sidebar-header, .tc-topbar {\n\t\tdisplay: none;\n\t}\n\n\t.tc-story-river {\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t}\n\n\t.tc-story-river .tc-tiddler-frame {\n\t\tmargin: 0;\n\t\tborder: none;\n\t\tpadding: 0;\n\t}\n}\n\n/*\n** Tiddler styles\n*/\n\n.tc-tiddler-frame {\n\tposition: relative;\n\tmargin-bottom: 28px;\n\tbackground-color: <<colour tiddler-background>>;\n\tborder: 1px solid <<colour tiddler-border>>;\n}\n\n{{$:/themes/tiddlywiki/vanilla/sticky}}\n\n.tc-tiddler-info {\n\tpadding: 14px 42px 14px 42px;\n\tbackground-color: <<colour tiddler-info-background>>;\n\tborder-top: 1px solid <<colour tiddler-info-border>>;\n\tborder-bottom: 1px solid <<colour tiddler-info-border>>;\n}\n\n.tc-tiddler-info p {\n\tmargin-top: 3px;\n\tmargin-bottom: 3px;\n}\n\n.tc-tiddler-info .tc-tab-buttons button.tc-tab-selected {\n\tbackground-color: <<colour tiddler-info-tab-background>>;\n\tborder-bottom: 1px solid <<colour tiddler-info-tab-background>>;\n}\n\n.tc-view-field-table {\n\twidth: 100%;\n}\n\n.tc-view-field-name {\n\twidth: 1%; /* Makes this column be as narrow as possible */\n\ttext-align: right;\n\tfont-style: italic;\n\tfont-weight: 200;\n}\n\n.tc-view-field-value {\n}\n\n@media (max-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n\t.tc-tiddler-frame {\n\t\tpadding: 14px 14px 14px 14px;\n\t}\n\n\t.tc-tiddler-info {\n\t\tmargin: 0 -14px 0 -14px;\n\t}\n}\n\n@media (min-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n\t.tc-tiddler-frame {\n\t\tpadding: 28px 42px 42px 42px;\n\t\twidth: {{$:/themes/tiddlywiki/vanilla/metrics/tiddlerwidth}};\n\t\tborder-radius: 2px;\n\t}\n\n<<if-no-sidebar \"\n\n\t.tc-tiddler-frame {\n\t\twidth: 100%;\n\t}\n\n\">>\n\n\t.tc-tiddler-info {\n\t\tmargin: 0 -42px 0 -42px;\n\t}\n}\n\n.tc-site-title,\n.tc-titlebar {\n\tfont-weight: 300;\n\tfont-size: 2.35em;\n\tline-height: 1.2em;\n\tcolor: <<colour tiddler-title-foreground>>;\n\tmargin: 0;\n}\n\n.tc-site-title {\n\tcolor: <<colour site-title-foreground>>;\n}\n\n.tc-tiddler-title-icon {\n\tvertical-align: middle;\n}\n\n.tc-system-title-prefix {\n\tcolor: <<colour muted-foreground>>;\n}\n\n.tc-titlebar h2 {\n\tfont-size: 1em;\n\tdisplay: inline;\n}\n\n.tc-titlebar img {\n\theight: 1em;\n}\n\n.tc-subtitle {\n\tfont-size: 0.9em;\n\tcolor: <<colour tiddler-subtitle-foreground>>;\n\tfont-weight: 300;\n}\n\n.tc-tiddler-missing .tc-title {\n font-style: italic;\n font-weight: normal;\n}\n\n.tc-tiddler-frame .tc-tiddler-controls {\n\tfloat: right;\n}\n\n.tc-tiddler-controls .tc-drop-down {\n\tfont-size: 0.6em;\n}\n\n.tc-tiddler-controls .tc-drop-down .tc-drop-down {\n\tfont-size: 1em;\n}\n\n.tc-tiddler-controls > span > button,\n.tc-tiddler-controls > span > span > button,\n.tc-tiddler-controls > span > span > span > button {\n\tvertical-align: baseline;\n\tmargin-left:5px;\n}\n\n.tc-tiddler-controls button svg, .tc-tiddler-controls button img,\n.tc-search button svg, .tc-search a svg {\n\tfill: <<colour tiddler-controls-foreground>>;\n}\n\n.tc-tiddler-controls button svg, .tc-tiddler-controls button img {\n\theight: 0.75em;\n}\n\n.tc-search button svg, .tc-search a svg {\n height: 1.2em;\n width: 1.2em;\n margin: 0 0.25em;\n}\n\n.tc-tiddler-controls button.tc-selected svg,\n.tc-page-controls button.tc-selected svg {\n\tfill: <<colour tiddler-controls-foreground-selected>>;\n}\n\n.tc-tiddler-controls button.tc-btn-invisible:hover svg,\n.tc-search button:hover svg, .tc-search a:hover svg {\n\tfill: <<colour tiddler-controls-foreground-hover>>;\n}\n\n@media print {\n\t.tc-tiddler-controls {\n\t\tdisplay: none;\n\t}\n}\n\n.tc-tiddler-help { /* Help prompts within tiddler template */\n\tcolor: <<colour muted-foreground>>;\n\tmargin-top: 14px;\n}\n\n.tc-tiddler-help a.tc-tiddlylink {\n\tcolor: <<colour very-muted-foreground>>;\n}\n\n.tc-tiddler-frame .tc-edit-texteditor {\n\twidth: 100%;\n\tmargin: 4px 0 4px 0;\n}\n\n.tc-tiddler-frame input.tc-edit-texteditor,\n.tc-tiddler-frame textarea.tc-edit-texteditor,\n.tc-tiddler-frame iframe.tc-edit-texteditor {\n\tpadding: 3px 3px 3px 3px;\n\tborder: 1px solid <<colour tiddler-editor-border>>;\n\tbackground-color: <<colour tiddler-editor-background>>;\n\tline-height: 1.3em;\n\t-webkit-appearance: none;\n\tfont-family: {{$:/themes/tiddlywiki/vanilla/settings/editorfontfamily}};\n}\n\n.tc-tiddler-frame .tc-binary-warning {\n\twidth: 100%;\n\theight: 5em;\n\ttext-align: center;\n\tpadding: 3em 3em 6em 3em;\n\tbackground: <<colour alert-background>>;\n\tborder: 1px solid <<colour alert-border>>;\n}\n\ncanvas.tc-edit-bitmapeditor {\n\tborder: 6px solid <<colour tiddler-editor-border-image>>;\n\tcursor: crosshair;\n\t-moz-user-select: none;\n\t-webkit-user-select: none;\n\t-ms-user-select: none;\n\tmargin-top: 6px;\n\tmargin-bottom: 6px;\n}\n\n.tc-edit-bitmapeditor-width {\n\tdisplay: block;\n}\n\n.tc-edit-bitmapeditor-height {\n\tdisplay: block;\n}\n\n.tc-tiddler-body {\n\tclear: both;\n}\n\n.tc-tiddler-frame .tc-tiddler-body {\n\tfont-size: {{$:/themes/tiddlywiki/vanilla/metrics/bodyfontsize}};\n\tline-height: {{$:/themes/tiddlywiki/vanilla/metrics/bodylineheight}};\n}\n\n.tc-titlebar, .tc-tiddler-edit-title {\n\toverflow: hidden; /* https://github.com/Jermolene/TiddlyWiki5/issues/282 */\n}\n\nhtml body.tc-body.tc-single-tiddler-window {\n\tmargin: 1em;\n\tbackground: <<colour tiddler-background>>;\n}\n\n.tc-single-tiddler-window img,\n.tc-single-tiddler-window svg,\n.tc-single-tiddler-window canvas,\n.tc-single-tiddler-window embed,\n.tc-single-tiddler-window iframe {\n\tmax-width: 100%;\n}\n\n/*\n** Editor\n*/\n\n.tc-editor-toolbar {\n\tmargin-top: 8px;\n}\n\n.tc-editor-toolbar button {\n\tvertical-align: middle;\n\tbackground-color: <<colour tiddler-controls-foreground>>;\n\tfill: <<colour tiddler-controls-foreground-selected>>;\n\tborder-radius: 4px;\n\tpadding: 3px;\n\tmargin: 2px 0 2px 4px;\n}\n\n.tc-editor-toolbar button.tc-text-editor-toolbar-item-adjunct {\n\tmargin-left: 1px;\n\twidth: 1em;\n\tborder-radius: 8px;\n}\n\n.tc-editor-toolbar button.tc-text-editor-toolbar-item-start-group {\n\tmargin-left: 11px;\n}\n\n.tc-editor-toolbar button.tc-selected {\n\tbackground-color: <<colour primary>>;\n}\n\n.tc-editor-toolbar button svg {\n\twidth: 1.6em;\n\theight: 1.2em;\n}\n\n.tc-editor-toolbar button:hover {\n\tbackground-color: <<colour tiddler-controls-foreground-selected>>;\n\tfill: <<colour background>>;\n\tcolor: <<colour background>>;\n}\n\n.tc-editor-toolbar .tc-text-editor-toolbar-more {\n\twhite-space: normal;\n}\n\n.tc-editor-toolbar .tc-text-editor-toolbar-more button {\n\tdisplay: inline-block;\n\tpadding: 3px;\n\twidth: auto;\n}\n\n.tc-editor-toolbar .tc-search-results {\n\tpadding: 0;\n}\n\n/*\n** Adjustments for fluid-fixed mode\n*/\n\n@media (min-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n\n<<if-fluid-fixed text:\"\"\"\n\n\t.tc-story-river {\n\t\tpadding-right: 0;\n\t\tposition: relative;\n\t\twidth: auto;\n\t\tleft: 0;\n\t\tmargin-left: {{$:/themes/tiddlywiki/vanilla/metrics/storyleft}};\n\t\tmargin-right: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarwidth}};\n\t}\n\n\t.tc-tiddler-frame {\n\t\twidth: 100%;\n\t}\n\n\t.tc-sidebar-scrollable {\n\t\tleft: auto;\n\t\tbottom: 0;\n\t\tright: 0;\n\t\twidth: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarwidth}};\n\t}\n\n\tbody.tc-body .tc-storyview-zoomin-tiddler {\n\t\twidth: 100%;\n\t\twidth: calc(100% - 42px);\n\t}\n\n\"\"\" hiddenSidebarText:\"\"\"\n\n\t.tc-story-river {\n\t\tpadding-right: 3em;\n\t\tmargin-right: 0;\n\t}\n\n\tbody.tc-body .tc-storyview-zoomin-tiddler {\n\t\twidth: 100%;\n\t\twidth: calc(100% - 84px);\n\t}\n\n\"\"\">>\n\n}\n\n/*\n** Toolbar buttons\n*/\n\n.tc-page-controls svg.tc-image-new-button {\n fill: <<colour toolbar-new-button>>;\n}\n\n.tc-page-controls svg.tc-image-options-button {\n fill: <<colour toolbar-options-button>>;\n}\n\n.tc-page-controls svg.tc-image-save-button {\n fill: <<colour toolbar-save-button>>;\n}\n\n.tc-tiddler-controls button svg.tc-image-info-button {\n fill: <<colour toolbar-info-button>>;\n}\n\n.tc-tiddler-controls button svg.tc-image-edit-button {\n fill: <<colour toolbar-edit-button>>;\n}\n\n.tc-tiddler-controls button svg.tc-image-close-button {\n fill: <<colour toolbar-close-button>>;\n}\n\n.tc-tiddler-controls button svg.tc-image-delete-button {\n fill: <<colour toolbar-delete-button>>;\n}\n\n.tc-tiddler-controls button svg.tc-image-cancel-button {\n fill: <<colour toolbar-cancel-button>>;\n}\n\n.tc-tiddler-controls button svg.tc-image-done-button {\n fill: <<colour toolbar-done-button>>;\n}\n\n/*\n** Tiddler edit mode\n*/\n\n.tc-tiddler-edit-frame em.tc-edit {\n\tcolor: <<colour muted-foreground>>;\n\tfont-style: normal;\n}\n\n.tc-edit-type-dropdown a.tc-tiddlylink-missing {\n\tfont-style: normal;\n}\n\n.tc-edit-tags {\n\tborder: 1px solid <<colour tiddler-editor-border>>;\n\tpadding: 4px 8px 4px 8px;\n}\n\n.tc-edit-add-tag {\n\tdisplay: inline-block;\n}\n\n.tc-edit-add-tag .tc-add-tag-name input {\n\twidth: 50%;\n}\n\n.tc-edit-add-tag .tc-keyboard {\n\tdisplay:inline;\n}\n\n.tc-edit-tags .tc-tag-label {\n\tdisplay: inline-block;\n}\n\n.tc-edit-tags-list {\n\tmargin: 14px 0 14px 0;\n}\n\n.tc-remove-tag-button {\n\tpadding-left: 4px;\n}\n\n.tc-tiddler-preview {\n\toverflow: auto;\n}\n\n.tc-tiddler-preview-preview {\n\tfloat: right;\n\twidth: 49%;\n\tborder: 1px solid <<colour tiddler-editor-border>>;\n\tmargin: 4px 0 3px 3px;\n\tpadding: 3px 3px 3px 3px;\n}\n\n<<if-editor-height-fixed then:\"\"\"\n\n.tc-tiddler-preview-preview {\n\toverflow-y: scroll;\n\theight: {{$:/config/TextEditor/EditorHeight/Height}};\n}\n\n\"\"\">>\n\n.tc-tiddler-frame .tc-tiddler-preview .tc-edit-texteditor {\n\twidth: 49%;\n}\n\n.tc-tiddler-frame .tc-tiddler-preview canvas.tc-edit-bitmapeditor {\n\tmax-width: 49%;\n}\n\n.tc-edit-fields {\n\twidth: 100%;\n}\n\n\n.tc-edit-fields table, .tc-edit-fields tr, .tc-edit-fields td {\n\tborder: none;\n\tpadding: 4px;\n}\n\n.tc-edit-fields > tbody > .tc-edit-field:nth-child(odd) {\n\tbackground-color: <<colour tiddler-editor-fields-odd>>;\n}\n\n.tc-edit-fields > tbody > .tc-edit-field:nth-child(even) {\n\tbackground-color: <<colour tiddler-editor-fields-even>>;\n}\n\n.tc-edit-field-name {\n\ttext-align: right;\n}\n\n.tc-edit-field-value input {\n\twidth: 100%;\n}\n\n.tc-edit-field-remove {\n}\n\n.tc-edit-field-remove svg {\n\theight: 1em;\n\twidth: 1em;\n\tfill: <<colour muted-foreground>>;\n\tvertical-align: middle;\n}\n\n.tc-edit-field-add-name {\n\tdisplay: inline-block;\n\twidth: 15%;\n}\n\n.tc-edit-field-add-value {\n\tdisplay: inline-block;\n\twidth: 40%;\n}\n\n.tc-edit-field-add-button {\n\tdisplay: inline-block;\n\twidth: 10%;\n}\n\n/*\n** Storyview Classes\n*/\n\n.tc-storyview-zoomin-tiddler {\n\tposition: absolute;\n\tdisplay: block;\n\twidth: 100%;\n}\n\n@media (min-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n\n\t.tc-storyview-zoomin-tiddler {\n\t\twidth: calc(100% - 84px);\n\t}\n\n}\n\n/*\n** Dropdowns\n*/\n\n.tc-btn-dropdown {\n\ttext-align: left;\n}\n\n.tc-btn-dropdown svg, .tc-btn-dropdown img {\n\theight: 1em;\n\twidth: 1em;\n\tfill: <<colour muted-foreground>>;\n}\n\n.tc-drop-down-wrapper {\n\tposition: relative;\n}\n\n.tc-drop-down {\n\tmin-width: 380px;\n\tborder: 1px solid <<colour dropdown-border>>;\n\tbackground-color: <<colour dropdown-background>>;\n\tpadding: 7px 0 7px 0;\n\tmargin: 4px 0 0 0;\n\twhite-space: nowrap;\n\ttext-shadow: none;\n\tline-height: 1.4;\n}\n\n.tc-drop-down .tc-drop-down {\n\tmargin-left: 14px;\n}\n\n.tc-drop-down button svg, .tc-drop-down a svg {\n\tfill: <<colour foreground>>;\n}\n\n.tc-drop-down button.tc-btn-invisible:hover svg {\n\tfill: <<colour foreground>>;\n}\n\n.tc-drop-down p {\n\tpadding: 0 14px 0 14px;\n}\n\n.tc-drop-down svg {\n\twidth: 1em;\n\theight: 1em;\n}\n\n.tc-drop-down img {\n\twidth: 1em;\n}\n\n.tc-drop-down a, .tc-drop-down button {\n\tdisplay: block;\n\tpadding: 0 14px 0 14px;\n\twidth: 100%;\n\ttext-align: left;\n\tcolor: <<colour foreground>>;\n\tline-height: 1.4;\n}\n\n.tc-drop-down .tc-tab-set .tc-tab-buttons button {\n\tdisplay: inline-block;\n width: auto;\n margin-bottom: 0px;\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n}\n\n.tc-drop-down .tc-prompt {\n\tpadding: 0 14px;\n}\n\n.tc-drop-down .tc-chooser {\n\tborder: none;\n}\n\n.tc-drop-down .tc-chooser .tc-swatches-horiz {\n\tfont-size: 0.4em;\n\tpadding-left: 1.2em;\n}\n\n.tc-drop-down .tc-file-input-wrapper {\n\twidth: 100%;\n}\n\n.tc-drop-down .tc-file-input-wrapper button {\n\tcolor: <<colour foreground>>;\n}\n\n.tc-drop-down a:hover, .tc-drop-down button:hover, .tc-drop-down .tc-file-input-wrapper:hover button {\n\tcolor: <<colour tiddler-link-background>>;\n\tbackground-color: <<colour tiddler-link-foreground>>;\n\ttext-decoration: none;\n}\n\n.tc-drop-down .tc-tab-buttons button {\n\tbackground-color: <<colour dropdown-tab-background>>;\n}\n\n.tc-drop-down .tc-tab-buttons button.tc-tab-selected {\n\tbackground-color: <<colour dropdown-tab-background-selected>>;\n\tborder-bottom: 1px solid <<colour dropdown-tab-background-selected>>;\n}\n\n.tc-drop-down-bullet {\n\tdisplay: inline-block;\n\twidth: 0.5em;\n}\n\n.tc-drop-down .tc-tab-contents a {\n\tpadding: 0 0.5em 0 0.5em;\n}\n\n.tc-block-dropdown-wrapper {\n\tposition: relative;\n}\n\n.tc-block-dropdown {\n\tposition: absolute;\n\tmin-width: 220px;\n\tborder: 1px solid <<colour dropdown-border>>;\n\tbackground-color: <<colour dropdown-background>>;\n\tpadding: 7px 0;\n\tmargin: 4px 0 0 0;\n\twhite-space: nowrap;\n\tz-index: 1000;\n\ttext-shadow: none;\n}\n\n.tc-block-dropdown.tc-search-drop-down {\n\tmargin-left: -12px;\n}\n\n.tc-block-dropdown a {\n\tdisplay: block;\n\tpadding: 4px 14px 4px 14px;\n}\n\n.tc-block-dropdown.tc-search-drop-down a {\n\tdisplay: block;\n\tpadding: 0px 10px 0px 10px;\n}\n\n.tc-drop-down .tc-dropdown-item-plain,\n.tc-block-dropdown .tc-dropdown-item-plain {\n\tpadding: 4px 14px 4px 7px;\n}\n\n.tc-drop-down .tc-dropdown-item,\n.tc-block-dropdown .tc-dropdown-item {\n\tpadding: 4px 14px 4px 7px;\n\tcolor: <<colour muted-foreground>>;\n}\n\n.tc-block-dropdown a:hover {\n\tcolor: <<colour tiddler-link-background>>;\n\tbackground-color: <<colour tiddler-link-foreground>>;\n\ttext-decoration: none;\n}\n\n.tc-search-results {\n\tpadding: 0 7px 0 7px;\n}\n\n.tc-image-chooser, .tc-colour-chooser {\n\twhite-space: normal;\n}\n\n.tc-image-chooser a,\n.tc-colour-chooser a {\n\tdisplay: inline-block;\n\tvertical-align: top;\n\ttext-align: center;\n\tposition: relative;\n}\n\n.tc-image-chooser a {\n\tborder: 1px solid <<colour muted-foreground>>;\n\tpadding: 2px;\n\tmargin: 2px;\n\twidth: 4em;\n\theight: 4em;\n}\n\n.tc-colour-chooser a {\n\tpadding: 3px;\n\twidth: 2em;\n\theight: 2em;\n\tvertical-align: middle;\n}\n\n.tc-image-chooser a:hover,\n.tc-colour-chooser a:hover {\n\tbackground: <<colour primary>>;\n\tpadding: 0px;\n\tborder: 3px solid <<colour primary>>;\n}\n\n.tc-image-chooser a svg,\n.tc-image-chooser a img {\n\tdisplay: inline-block;\n\twidth: auto;\n\theight: auto;\n\tmax-width: 3.5em;\n\tmax-height: 3.5em;\n\tposition: absolute;\n\ttop: 0;\n\tbottom: 0;\n\tleft: 0;\n\tright: 0;\n\tmargin: auto;\n}\n\n/*\n** Modals\n*/\n\n.tc-modal-wrapper {\n\tposition: fixed;\n\toverflow: auto;\n\toverflow-y: scroll;\n\ttop: 0;\n\tright: 0;\n\tbottom: 0;\n\tleft: 0;\n\tz-index: 900;\n}\n\n.tc-modal-backdrop {\n\tposition: fixed;\n\ttop: 0;\n\tright: 0;\n\tbottom: 0;\n\tleft: 0;\n\tz-index: 1000;\n\tbackground-color: <<colour modal-backdrop>>;\n}\n\n.tc-modal {\n\tz-index: 1100;\n\tbackground-color: <<colour modal-background>>;\n\tborder: 1px solid <<colour modal-border>>;\n}\n\n@media (max-width: 55em) {\n\t.tc-modal {\n\t\tposition: fixed;\n\t\ttop: 1em;\n\t\tleft: 1em;\n\t\tright: 1em;\n\t}\n\n\t.tc-modal-body {\n\t\toverflow-y: auto;\n\t\tmax-height: 400px;\n\t\tmax-height: 60vh;\n\t}\n}\n\n@media (min-width: 55em) {\n\t.tc-modal {\n\t\tposition: fixed;\n\t\ttop: 2em;\n\t\tleft: 25%;\n\t\twidth: 50%;\n\t}\n\n\t.tc-modal-body {\n\t\toverflow-y: auto;\n\t\tmax-height: 400px;\n\t\tmax-height: 60vh;\n\t}\n}\n\n.tc-modal-header {\n\tpadding: 9px 15px;\n\tborder-bottom: 1px solid <<colour modal-header-border>>;\n}\n\n.tc-modal-header h3 {\n\tmargin: 0;\n\tline-height: 30px;\n}\n\n.tc-modal-header img, .tc-modal-header svg {\n\twidth: 1em;\n\theight: 1em;\n}\n\n.tc-modal-body {\n\tpadding: 15px;\n}\n\n.tc-modal-footer {\n\tpadding: 14px 15px 15px;\n\tmargin-bottom: 0;\n\ttext-align: right;\n\tbackground-color: <<colour modal-footer-background>>;\n\tborder-top: 1px solid <<colour modal-footer-border>>;\n}\n\n/*\n** Notifications\n*/\n\n.tc-notification {\n\tposition: fixed;\n\ttop: 14px;\n\tright: 42px;\n\tz-index: 1300;\n\tmax-width: 280px;\n\tpadding: 0 14px 0 14px;\n\tbackground-color: <<colour notification-background>>;\n\tborder: 1px solid <<colour notification-border>>;\n}\n\n/*\n** Tabs\n*/\n\n.tc-tab-set.tc-vertical {\n\tdisplay: -webkit-flex;\n\tdisplay: flex;\n}\n\n.tc-tab-buttons {\n\tfont-size: 0.85em;\n\tpadding-top: 1em;\n\tmargin-bottom: -2px;\n}\n\n.tc-tab-buttons.tc-vertical {\n\tz-index: 100;\n\tdisplay: block;\n\tpadding-top: 14px;\n\tvertical-align: top;\n\ttext-align: right;\n\tmargin-bottom: inherit;\n\tmargin-right: -1px;\n\tmax-width: 33%;\n\t-webkit-flex: 0 0 auto;\n\tflex: 0 0 auto;\n}\n\n.tc-tab-buttons button.tc-tab-selected {\n\tcolor: <<colour tab-foreground-selected>>;\n\tbackground-color: <<colour tab-background-selected>>;\n\tborder-left: 1px solid <<colour tab-border-selected>>;\n\tborder-top: 1px solid <<colour tab-border-selected>>;\n\tborder-right: 1px solid <<colour tab-border-selected>>;\n}\n\n.tc-tab-buttons button {\n\tcolor: <<colour tab-foreground>>;\n\tpadding: 3px 5px 3px 5px;\n\tmargin-right: 0.3em;\n\tfont-weight: 300;\n\tborder: none;\n\tbackground: inherit;\n\tbackground-color: <<colour tab-background>>;\n\tborder-left: 1px solid <<colour tab-border>>;\n\tborder-top: 1px solid <<colour tab-border>>;\n\tborder-right: 1px solid <<colour tab-border>>;\n\tborder-top-left-radius: 2px;\n\tborder-top-right-radius: 2px;\n\tborder-bottom-left-radius: 0;\n\tborder-bottom-right-radius: 0;\n}\n\n.tc-tab-buttons.tc-vertical button {\n\tdisplay: block;\n\twidth: 100%;\n\tmargin-top: 3px;\n\tmargin-right: 0;\n\ttext-align: right;\n\tbackground-color: <<colour tab-background>>;\n\tborder-left: 1px solid <<colour tab-border>>;\n\tborder-bottom: 1px solid <<colour tab-border>>;\n\tborder-right: none;\n\tborder-top-left-radius: 2px;\n\tborder-bottom-left-radius: 2px;\n\tborder-top-right-radius: 0;\n\tborder-bottom-right-radius: 0;\n}\n\n.tc-tab-buttons.tc-vertical button.tc-tab-selected {\n\tbackground-color: <<colour tab-background-selected>>;\n\tborder-right: 1px solid <<colour tab-background-selected>>;\n}\n\n.tc-tab-divider {\n\tborder-top: 1px solid <<colour tab-divider>>;\n}\n\n.tc-tab-divider.tc-vertical {\n\tdisplay: none;\n}\n\n.tc-tab-content {\n\tmargin-top: 14px;\n}\n\n.tc-tab-content.tc-vertical {\n word-break: break-word;\n\tdisplay: inline-block;\n\tvertical-align: top;\n\tpadding-top: 0;\n\tpadding-left: 14px;\n\tborder-left: 1px solid <<colour tab-border>>;\n\t-webkit-flex: 1 0 70%;\n\tflex: 1 0 70%;\n}\n\n.tc-sidebar-lists .tc-tab-buttons {\n\tmargin-bottom: -1px;\n}\n\n.tc-sidebar-lists .tc-tab-buttons button.tc-tab-selected {\n\tbackground-color: <<colour sidebar-tab-background-selected>>;\n\tcolor: <<colour sidebar-tab-foreground-selected>>;\n\tborder-left: 1px solid <<colour sidebar-tab-border-selected>>;\n\tborder-top: 1px solid <<colour sidebar-tab-border-selected>>;\n\tborder-right: 1px solid <<colour sidebar-tab-border-selected>>;\n}\n\n.tc-sidebar-lists .tc-tab-buttons button {\n\tbackground-color: <<colour sidebar-tab-background>>;\n\tcolor: <<colour sidebar-tab-foreground>>;\n\tborder-left: 1px solid <<colour sidebar-tab-border>>;\n\tborder-top: 1px solid <<colour sidebar-tab-border>>;\n\tborder-right: 1px solid <<colour sidebar-tab-border>>;\n}\n\n.tc-sidebar-lists .tc-tab-divider {\n\tborder-top: 1px solid <<colour sidebar-tab-divider>>;\n}\n\n.tc-more-sidebar > .tc-tab-set > .tc-tab-buttons > button {\n\tdisplay: block;\n\twidth: 100%;\n\tbackground-color: <<colour sidebar-tab-background>>;\n\tborder-top: none;\n\tborder-left: none;\n\tborder-bottom: none;\n\tborder-right: 1px solid #ccc;\n\tmargin-bottom: inherit;\n}\n\n.tc-more-sidebar > .tc-tab-set > .tc-tab-buttons > button.tc-tab-selected {\n\tbackground-color: <<colour sidebar-tab-background-selected>>;\n\tborder: none;\n}\n\n/*\n** Manager\n*/\n\n.tc-manager-wrapper {\n\t\n}\n\n.tc-manager-controls {\n\t\n}\n\n.tc-manager-control {\n\tmargin: 0.5em 0;\n}\n\n.tc-manager-list {\n\twidth: 100%;\n\tborder-top: 1px solid <<colour muted-foreground>>;\n\tborder-left: 1px solid <<colour muted-foreground>>;\n\tborder-right: 1px solid <<colour muted-foreground>>;\n}\n\n.tc-manager-list-item {\n\n}\n\n.tc-manager-list-item-heading {\n display: block;\n width: 100%;\n text-align: left;\t\n\tborder-bottom: 1px solid <<colour muted-foreground>>;\n\tpadding: 3px;\n}\n\n.tc-manager-list-item-heading-selected {\n\tfont-weight: bold;\n\tcolor: <<colour background>>;\n\tfill: <<colour background>>;\n\tbackground-color: <<colour foreground>>;\n}\n\n.tc-manager-list-item-heading:hover {\n\tbackground: <<colour primary>>;\n\tcolor: <<colour background>>;\n}\n\n.tc-manager-list-item-content {\n\tdisplay: flex;\n}\n\n.tc-manager-list-item-content-sidebar {\n flex: 1 0;\n background: <<colour tiddler-editor-background>>;\n border-right: 0.5em solid <<colour muted-foreground>>;\n border-bottom: 0.5em solid <<colour muted-foreground>>;\n white-space: nowrap;\n}\n\n.tc-manager-list-item-content-item-heading {\n\tdisplay: block;\n\twidth: 100%;\n\ttext-align: left;\n background: <<colour muted-foreground>>;\n\ttext-transform: uppercase;\n\tfont-size: 0.6em;\n\tfont-weight: bold;\n padding: 0.5em 0 0.5em 0;\n}\n\n.tc-manager-list-item-content-item-body {\n\tpadding: 0 0.5em 0 0.5em;\n}\n\n.tc-manager-list-item-content-item-body > pre {\n\tmargin: 0.5em 0 0.5em 0;\n\tborder: none;\n\tbackground: inherit;\n}\n\n.tc-manager-list-item-content-tiddler {\n flex: 3 1;\n border-left: 0.5em solid <<colour muted-foreground>>;\n border-right: 0.5em solid <<colour muted-foreground>>;\n border-bottom: 0.5em solid <<colour muted-foreground>>;\n}\n\n.tc-manager-list-item-content-item-body > table {\n\tborder: none;\n\tpadding: 0;\n\tmargin: 0;\n}\n\n.tc-manager-list-item-content-item-body > table td {\n\tborder: none;\n}\n\n.tc-manager-icon-editor > button {\n\twidth: 100%;\n}\n\n.tc-manager-icon-editor > button > svg,\n.tc-manager-icon-editor > button > button {\n\twidth: 100%;\n\theight: auto;\n}\n\n/*\n** Alerts\n*/\n\n.tc-alerts {\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tmax-width: 500px;\n\tz-index: 20000;\n}\n\n.tc-alert {\n\tposition: relative;\n\tmargin: 28px;\n\tpadding: 14px 14px 14px 14px;\n\tborder: 2px solid <<colour alert-border>>;\n\tbackground-color: <<colour alert-background>>;\n}\n\n.tc-alert-toolbar {\n\tposition: absolute;\n\ttop: 14px;\n\tright: 14px;\n}\n\n.tc-alert-toolbar svg {\n\tfill: <<colour alert-muted-foreground>>;\n}\n\n.tc-alert-subtitle {\n\tcolor: <<colour alert-muted-foreground>>;\n\tfont-weight: bold;\n}\n\n.tc-alert-highlight {\n\tcolor: <<colour alert-highlight>>;\n}\n\n@media (min-width: {{$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint}}) {\n\n\t.tc-static-alert {\n\t\tposition: relative;\n\t}\n\n\t.tc-static-alert-inner {\n\t\tposition: absolute;\n\t\tz-index: 100;\n\t}\n\n}\n\n.tc-static-alert-inner {\n\tpadding: 0 2px 2px 42px;\n\tcolor: <<colour static-alert-foreground>>;\n}\n\n/*\n** Floating drafts list\n*/\n\n.tc-drafts-list {\n\tz-index: 2000;\n\tposition: fixed;\n\tfont-size: 0.8em;\n\tleft: 0;\n\tbottom: 0;\n}\n\n.tc-drafts-list a {\n\tmargin: 0 0.5em;\n\tpadding: 4px 4px;\n\tborder-top-left-radius: 4px;\n\tborder-top-right-radius: 4px;\n\tborder: 1px solid <<colour background>>;\n\tborder-bottom-none;\n\tbackground: <<colour dirty-indicator>>;\n\tcolor: <<colour background>>;\n\tfill: <<colour background>>;\n}\n\n.tc-drafts-list a:hover {\n\ttext-decoration: none;\n\tbackground: <<colour foreground>>;\n\tcolor: <<colour background>>;\n\tfill: <<colour background>>;\n}\n\n.tc-drafts-list a svg {\n\twidth: 1em;\n\theight: 1em;\n\tvertical-align: text-bottom;\n}\n\n/*\n** Control panel\n*/\n\n.tc-control-panel td {\n\tpadding: 4px;\n}\n\n.tc-control-panel table, .tc-control-panel table input, .tc-control-panel table textarea {\n\twidth: 100%;\n}\n\n.tc-plugin-info {\n\tdisplay: block;\n\tborder: 1px solid <<colour muted-foreground>>;\n\tbackground-colour: <<colour background>>;\n\tmargin: 0.5em 0 0.5em 0;\n\tpadding: 4px;\n}\n\n.tc-plugin-info-disabled {\n\tbackground: -webkit-repeating-linear-gradient(45deg, #ff0, #ff0 10px, #eee 10px, #eee 20px);\n\tbackground: repeating-linear-gradient(45deg, #ff0, #ff0 10px, #eee 10px, #eee 20px);\n}\n\n.tc-plugin-info-disabled:hover {\n\tbackground: -webkit-repeating-linear-gradient(45deg, #aa0, #aa0 10px, #888 10px, #888 20px);\n\tbackground: repeating-linear-gradient(45deg, #aa0, #aa0 10px, #888 10px, #888 20px);\n}\n\na.tc-tiddlylink.tc-plugin-info:hover {\n\ttext-decoration: none;\n\tbackground-color: <<colour primary>>;\n\tcolor: <<colour background>>;\n\tfill: <<colour foreground>>;\n}\n\na.tc-tiddlylink.tc-plugin-info:hover .tc-plugin-info > .tc-plugin-info-chunk > svg {\n\tfill: <<colour foreground>>;\n}\n\n.tc-plugin-info-chunk {\n\tdisplay: inline-block;\n\tvertical-align: middle;\n}\n\n.tc-plugin-info-chunk h1 {\n\tfont-size: 1em;\n\tmargin: 2px 0 2px 0;\n}\n\n.tc-plugin-info-chunk h2 {\n\tfont-size: 0.8em;\n\tmargin: 2px 0 2px 0;\n}\n\n.tc-plugin-info-chunk div {\n\tfont-size: 0.7em;\n\tmargin: 2px 0 2px 0;\n}\n\n.tc-plugin-info:hover > .tc-plugin-info-chunk > img, .tc-plugin-info:hover > .tc-plugin-info-chunk > svg {\n\twidth: 2em;\n\theight: 2em;\n\tfill: <<colour foreground>>;\n}\n\n.tc-plugin-info > .tc-plugin-info-chunk > img, .tc-plugin-info > .tc-plugin-info-chunk > svg {\n\twidth: 2em;\n\theight: 2em;\n\tfill: <<colour muted-foreground>>;\n}\n\n.tc-plugin-info.tc-small-icon > .tc-plugin-info-chunk > img, .tc-plugin-info.tc-small-icon > .tc-plugin-info-chunk > svg {\n\twidth: 1em;\n\theight: 1em;\n}\n\n.tc-plugin-info-dropdown {\n\tborder: 1px solid <<colour muted-foreground>>;\n\tmargin-top: -8px;\n}\n\n.tc-plugin-info-dropdown-message {\n\tbackground: <<colour message-background>>;\n\tpadding: 0.5em 1em 0.5em 1em;\n\tfont-weight: bold;\n\tfont-size: 0.8em;\n}\n\n.tc-plugin-info-dropdown-body {\n\tpadding: 1em 1em 1em 1em;\n}\n\n.tc-check-list {\n\tline-height: 2em;\n}\n\n.tc-check-list .tc-image-button {\n\theight: 1.5em;\n}\n\n/*\n** Message boxes\n*/\n\n.tc-message-box {\n\tborder: 1px solid <<colour message-border>>;\n\tbackground: <<colour message-background>>;\n\tpadding: 0px 21px 0px 21px;\n\tfont-size: 12px;\n\tline-height: 18px;\n\tcolor: <<colour message-foreground>>;\n}\n\n.tc-message-box svg {\n\twidth: 1em;\n\theight: 1em;\n vertical-align: text-bottom;\n}\n\n/*\n** Pictures\n*/\n\n.tc-bordered-image {\n\tborder: 1px solid <<colour muted-foreground>>;\n\tpadding: 5px;\n\tmargin: 5px;\n}\n\n/*\n** Floats\n*/\n\n.tc-float-right {\n\tfloat: right;\n}\n\n/*\n** Chooser\n*/\n\n.tc-chooser {\n\tborder-right: 1px solid <<colour table-header-background>>;\n\tborder-left: 1px solid <<colour table-header-background>>;\n}\n\n\n.tc-chooser-item {\n\tborder-bottom: 1px solid <<colour table-header-background>>;\n\tborder-top: 1px solid <<colour table-header-background>>;\n\tpadding: 2px 4px 2px 14px;\n}\n\n.tc-drop-down .tc-chooser-item {\n\tpadding: 2px;\n}\n\n.tc-chosen,\n.tc-chooser-item:hover {\n\tbackground-color: <<colour table-header-background>>;\n\tborder-color: <<colour table-footer-background>>;\n}\n\n.tc-chosen .tc-tiddlylink {\n\tcursor:default;\n}\n\n.tc-chooser-item .tc-tiddlylink {\n\tdisplay: block;\n\ttext-decoration: none;\n\tbackground-color: transparent;\n}\n\n.tc-chooser-item:hover .tc-tiddlylink:hover {\n\ttext-decoration: none;\n}\n\n.tc-drop-down .tc-chosen .tc-tiddlylink,\n.tc-drop-down .tc-chooser-item .tc-tiddlylink:hover {\n\tcolor: <<colour foreground>>;\n}\n\n.tc-chosen > .tc-tiddlylink:before {\n\tmargin-left: -10px;\n\tposition: relative;\n\tcontent: \"» \";\n}\n\n.tc-chooser-item svg,\n.tc-chooser-item img{\n\twidth: 1em;\n\theight: 1em;\n\tvertical-align: middle;\n}\n\n.tc-language-chooser .tc-image-button img {\n\twidth: 2em;\n\tvertical-align: -0.15em;\n}\n\n/*\n** Palette swatches\n*/\n\n.tc-swatches-horiz {\n}\n\n.tc-swatches-horiz .tc-swatch {\n\tdisplay: inline-block;\n}\n\n.tc-swatch {\n\twidth: 2em;\n\theight: 2em;\n\tmargin: 0.4em;\n\tborder: 1px solid #888;\n}\n\n/*\n** Table of contents\n*/\n\n.tc-sidebar-lists .tc-table-of-contents {\n\twhite-space: nowrap;\n}\n\n.tc-table-of-contents button {\n\tcolor: <<colour sidebar-foreground>>;\n}\n\n.tc-table-of-contents svg {\n\twidth: 0.7em;\n\theight: 0.7em;\n\tvertical-align: middle;\n\tfill: <<colour sidebar-foreground>>;\n}\n\n.tc-table-of-contents ol {\n\tlist-style-type: none;\n\tpadding-left: 0;\n}\n\n.tc-table-of-contents ol ol {\n\tpadding-left: 1em;\n}\n\n.tc-table-of-contents li {\n\tfont-size: 1.0em;\n\tfont-weight: bold;\n}\n\n.tc-table-of-contents li a {\n\tfont-weight: bold;\n}\n\n.tc-table-of-contents li li {\n\tfont-size: 0.95em;\n\tfont-weight: normal;\n\tline-height: 1.4;\n}\n\n.tc-table-of-contents li li a {\n\tfont-weight: normal;\n}\n\n.tc-table-of-contents li li li {\n\tfont-size: 0.95em;\n\tfont-weight: 200;\n\tline-height: 1.5;\n}\n\n.tc-table-of-contents li li li li {\n\tfont-size: 0.95em;\n\tfont-weight: 200;\n}\n\n.tc-tabbed-table-of-contents {\n\tdisplay: -webkit-flex;\n\tdisplay: flex;\n}\n\n.tc-tabbed-table-of-contents .tc-table-of-contents {\n\tz-index: 100;\n\tdisplay: inline-block;\n\tpadding-left: 1em;\n\tmax-width: 50%;\n\t-webkit-flex: 0 0 auto;\n\tflex: 0 0 auto;\n\tbackground: <<colour tab-background>>;\n\tborder-left: 1px solid <<colour tab-border>>;\n\tborder-top: 1px solid <<colour tab-border>>;\n\tborder-bottom: 1px solid <<colour tab-border>>;\n}\n\n.tc-tabbed-table-of-contents .tc-table-of-contents .toc-item > a,\n.tc-tabbed-table-of-contents .tc-table-of-contents .toc-item-selected > a {\n\tdisplay: block;\n\tpadding: 0.12em 1em 0.12em 0.25em;\n}\n\n.tc-tabbed-table-of-contents .tc-table-of-contents .toc-item > a {\n\tborder-top: 1px solid <<colour tab-background>>;\n\tborder-left: 1px solid <<colour tab-background>>;\n\tborder-bottom: 1px solid <<colour tab-background>>;\n}\n\n.tc-tabbed-table-of-contents .tc-table-of-contents .toc-item > a:hover {\n\ttext-decoration: none;\n\tborder-top: 1px solid <<colour tab-border>>;\n\tborder-left: 1px solid <<colour tab-border>>;\n\tborder-bottom: 1px solid <<colour tab-border>>;\n\tbackground: <<colour tab-border>>;\n}\n\n.tc-tabbed-table-of-contents .tc-table-of-contents .toc-item-selected > a {\n\tborder-top: 1px solid <<colour tab-border>>;\n\tborder-left: 1px solid <<colour tab-border>>;\n\tborder-bottom: 1px solid <<colour tab-border>>;\n\tbackground: <<colour background>>;\n\tmargin-right: -1px;\n}\n\n.tc-tabbed-table-of-contents .tc-table-of-contents .toc-item-selected > a:hover {\n\ttext-decoration: none;\n}\n\n.tc-tabbed-table-of-contents .tc-tabbed-table-of-contents-content {\n\tdisplay: inline-block;\n\tvertical-align: top;\n\tpadding-left: 1.5em;\n\tpadding-right: 1.5em;\n\tborder: 1px solid <<colour tab-border>>;\n\t-webkit-flex: 1 0 50%;\n\tflex: 1 0 50%;\n}\n\n/*\n** Dirty indicator\n*/\n\nbody.tc-dirty span.tc-dirty-indicator, body.tc-dirty span.tc-dirty-indicator svg {\n\tfill: <<colour dirty-indicator>>;\n\tcolor: <<colour dirty-indicator>>;\n}\n\n/*\n** File inputs\n*/\n\n.tc-file-input-wrapper {\n\tposition: relative;\n\toverflow: hidden;\n\tdisplay: inline-block;\n\tvertical-align: middle;\n}\n\n.tc-file-input-wrapper input[type=file] {\n\tposition: absolute;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\tfont-size: 999px;\n\tmax-width: 100%;\n\tmax-height: 100%;\n\tfilter: alpha(opacity=0);\n\topacity: 0;\n\toutline: none;\n\tbackground: white;\n\tcursor: pointer;\n\tdisplay: inline-block;\n}\n\n/*\n** Thumbnail macros\n*/\n\n.tc-thumbnail-wrapper {\n\tposition: relative;\n\tdisplay: inline-block;\n\tmargin: 6px;\n\tvertical-align: top;\n}\n\n.tc-thumbnail-right-wrapper {\n\tfloat:right;\n\tmargin: 0.5em 0 0.5em 0.5em;\n}\n\n.tc-thumbnail-image {\n\ttext-align: center;\n\toverflow: hidden;\n\tborder-radius: 3px;\n}\n\n.tc-thumbnail-image svg,\n.tc-thumbnail-image img {\n\tfilter: alpha(opacity=1);\n\topacity: 1;\n\tmin-width: 100%;\n\tmin-height: 100%;\n\tmax-width: 100%;\n}\n\n.tc-thumbnail-wrapper:hover .tc-thumbnail-image svg,\n.tc-thumbnail-wrapper:hover .tc-thumbnail-image img {\n\tfilter: alpha(opacity=0.8);\n\topacity: 0.8;\n}\n\n.tc-thumbnail-background {\n\tposition: absolute;\n\tborder-radius: 3px;\n}\n\n.tc-thumbnail-icon svg,\n.tc-thumbnail-icon img {\n\twidth: 3em;\n\theight: 3em;\n\t<<filter \"drop-shadow(2px 2px 4px rgba(0,0,0,0.3))\">>\n}\n\n.tc-thumbnail-wrapper:hover .tc-thumbnail-icon svg,\n.tc-thumbnail-wrapper:hover .tc-thumbnail-icon img {\n\tfill: #fff;\n\t<<filter \"drop-shadow(3px 3px 4px rgba(0,0,0,0.6))\">>\n}\n\n.tc-thumbnail-icon {\n\tposition: absolute;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\tdisplay: -webkit-flex;\n\t-webkit-align-items: center;\n\t-webkit-justify-content: center;\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n}\n\n.tc-thumbnail-caption {\n\tposition: absolute;\n\tbackground-color: #777;\n\tcolor: #fff;\n\ttext-align: center;\n\tbottom: 0;\n\twidth: 100%;\n\tfilter: alpha(opacity=0.9);\n\topacity: 0.9;\n\tline-height: 1.4;\n\tborder-bottom-left-radius: 3px;\n\tborder-bottom-right-radius: 3px;\n}\n\n.tc-thumbnail-wrapper:hover .tc-thumbnail-caption {\n\tfilter: alpha(opacity=1);\n\topacity: 1;\n}\n\n/*\n** Diffs\n*/\n\n.tc-diff-equal {\n\tbackground-color: <<colour diff-equal-background>>;\n\tcolor: <<colour diff-equal-foreground>>;\n}\n\n.tc-diff-insert {\n\tbackground-color: <<colour diff-insert-background>>;\n\tcolor: <<colour diff-insert-foreground>>;\n}\n\n.tc-diff-delete {\n\tbackground-color: <<colour diff-delete-background>>;\n\tcolor: <<colour diff-delete-foreground>>;\n}\n\n.tc-diff-invisible {\n\tbackground-color: <<colour diff-invisible-background>>;\n\tcolor: <<colour diff-invisible-foreground>>;\n}\n\n.tc-diff-tiddlers th {\n\ttext-align: right;\n\tbackground: <<colour background>>;\n\tfont-weight: normal;\n\tfont-style: italic;\n}\n\n.tc-diff-tiddlers pre {\n margin: 0;\n padding: 0;\n border: none;\n background: none;\n}\n\n/*\n** Errors\n*/\n\n.tc-error {\n\tbackground: #f00;\n\tcolor: #fff;\n}\n\n/*\n** Tree macro\n*/\n\n.tc-tree div {\n \tpadding-left: 14px;\n}\n\n.tc-tree ol {\n \tlist-style-type: none;\n \tpadding-left: 0;\n \tmargin-top: 0;\n}\n\n.tc-tree ol ol {\n \tpadding-left: 1em; \n}\n\n.tc-tree button { \n \tcolor: #acacac;\n}\n\n.tc-tree svg {\n \tfill: #acacac;\n}\n\n.tc-tree span svg {\n \twidth: 1em;\n \theight: 1em;\n \tvertical-align: baseline;\n}\n\n.tc-tree li span {\n \tcolor: lightgray;\n}\n\nselect {\n color: <<colour select-tag-foreground>>;\n background: <<colour select-tag-background>>;\n}\n\n"
},
"$:/themes/tiddlywiki/vanilla/metrics/bodyfontsize": {
"title": "$:/themes/tiddlywiki/vanilla/metrics/bodyfontsize",
"text": "15px"
},
"$:/themes/tiddlywiki/vanilla/metrics/bodylineheight": {
"title": "$:/themes/tiddlywiki/vanilla/metrics/bodylineheight",
"text": "22px"
},
"$:/themes/tiddlywiki/vanilla/metrics/fontsize": {
"title": "$:/themes/tiddlywiki/vanilla/metrics/fontsize",
"text": "14px"
},
"$:/themes/tiddlywiki/vanilla/metrics/lineheight": {
"title": "$:/themes/tiddlywiki/vanilla/metrics/lineheight",
"text": "20px"
},
"$:/themes/tiddlywiki/vanilla/metrics/storyleft": {
"title": "$:/themes/tiddlywiki/vanilla/metrics/storyleft",
"text": "0px"
},
"$:/themes/tiddlywiki/vanilla/metrics/storytop": {
"title": "$:/themes/tiddlywiki/vanilla/metrics/storytop",
"text": "0px"
},
"$:/themes/tiddlywiki/vanilla/metrics/storyright": {
"title": "$:/themes/tiddlywiki/vanilla/metrics/storyright",
"text": "770px"
},
"$:/themes/tiddlywiki/vanilla/metrics/storywidth": {
"title": "$:/themes/tiddlywiki/vanilla/metrics/storywidth",
"text": "770px"
},
"$:/themes/tiddlywiki/vanilla/metrics/tiddlerwidth": {
"title": "$:/themes/tiddlywiki/vanilla/metrics/tiddlerwidth",
"text": "686px"
},
"$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint": {
"title": "$:/themes/tiddlywiki/vanilla/metrics/sidebarbreakpoint",
"text": "960px"
},
"$:/themes/tiddlywiki/vanilla/metrics/sidebarwidth": {
"title": "$:/themes/tiddlywiki/vanilla/metrics/sidebarwidth",
"text": "350px"
},
"$:/themes/tiddlywiki/vanilla/options/stickytitles": {
"title": "$:/themes/tiddlywiki/vanilla/options/stickytitles",
"text": "no"
},
"$:/themes/tiddlywiki/vanilla/options/sidebarlayout": {
"title": "$:/themes/tiddlywiki/vanilla/options/sidebarlayout",
"text": "fixed-fluid"
},
"$:/themes/tiddlywiki/vanilla/options/codewrapping": {
"title": "$:/themes/tiddlywiki/vanilla/options/codewrapping",
"text": "pre-wrap"
},
"$:/themes/tiddlywiki/vanilla/reset": {
"title": "$:/themes/tiddlywiki/vanilla/reset",
"type": "text/plain",
"text": "/*! normalize.css v3.0.0 | MIT License | git.io/normalize */\n\n/**\n * 1. Set default font family to sans-serif.\n * 2. Prevent iOS text size adjust after orientation change, without disabling\n * user zoom.\n */\n\nhtml {\n font-family: sans-serif; /* 1 */\n -ms-text-size-adjust: 100%; /* 2 */\n -webkit-text-size-adjust: 100%; /* 2 */\n}\n\n/**\n * Remove default margin.\n */\n\nbody {\n margin: 0;\n}\n\n/* HTML5 display definitions\n ========================================================================== */\n\n/**\n * Correct `block` display not defined in IE 8/9.\n */\n\narticle,\naside,\ndetails,\nfigcaption,\nfigure,\nfooter,\nheader,\nhgroup,\nmain,\nnav,\nsection,\nsummary {\n display: block;\n}\n\n/**\n * 1. Correct `inline-block` display not defined in IE 8/9.\n * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.\n */\n\naudio,\ncanvas,\nprogress,\nvideo {\n display: inline-block; /* 1 */\n vertical-align: baseline; /* 2 */\n}\n\n/**\n * Prevent modern browsers from displaying `audio` without controls.\n * Remove excess height in iOS 5 devices.\n */\n\naudio:not([controls]) {\n display: none;\n height: 0;\n}\n\n/**\n * Address `[hidden]` styling not present in IE 8/9.\n * Hide the `template` element in IE, Safari, and Firefox < 22.\n */\n\n[hidden],\ntemplate {\n display: none;\n}\n\n/* Links\n ========================================================================== */\n\n/**\n * Remove the gray background color from active links in IE 10.\n */\n\na {\n background: transparent;\n}\n\n/**\n * Improve readability when focused and also mouse hovered in all browsers.\n */\n\na:active,\na:hover {\n outline: 0;\n}\n\n/* Text-level semantics\n ========================================================================== */\n\n/**\n * Address styling not present in IE 8/9, Safari 5, and Chrome.\n */\n\nabbr[title] {\n border-bottom: 1px dotted;\n}\n\n/**\n * Address style set to `bolder` in Firefox 4+, Safari 5, and Chrome.\n */\n\nb,\nstrong {\n font-weight: bold;\n}\n\n/**\n * Address styling not present in Safari 5 and Chrome.\n */\n\ndfn {\n font-style: italic;\n}\n\n/**\n * Address variable `h1` font-size and margin within `section` and `article`\n * contexts in Firefox 4+, Safari 5, and Chrome.\n */\n\nh1 {\n font-size: 2em;\n margin: 0.67em 0;\n}\n\n/**\n * Address styling not present in IE 8/9.\n */\n\nmark {\n background: #ff0;\n color: #000;\n}\n\n/**\n * Address inconsistent and variable font size in all browsers.\n */\n\nsmall {\n font-size: 80%;\n}\n\n/**\n * Prevent `sub` and `sup` affecting `line-height` in all browsers.\n */\n\nsub,\nsup {\n font-size: 75%;\n line-height: 0;\n position: relative;\n vertical-align: baseline;\n}\n\nsup {\n top: -0.5em;\n}\n\nsub {\n bottom: -0.25em;\n}\n\n/* Embedded content\n ========================================================================== */\n\n/**\n * Remove border when inside `a` element in IE 8/9.\n */\n\nimg {\n border: 0;\n}\n\n/**\n * Correct overflow displayed oddly in IE 9.\n */\n\nsvg:not(:root) {\n overflow: hidden;\n}\n\n/* Grouping content\n ========================================================================== */\n\n/**\n * Address margin not present in IE 8/9 and Safari 5.\n */\n\nfigure {\n margin: 1em 40px;\n}\n\n/**\n * Address differences between Firefox and other browsers.\n */\n\nhr {\n -moz-box-sizing: content-box;\n box-sizing: content-box;\n height: 0;\n}\n\n/**\n * Contain overflow in all browsers.\n */\n\npre {\n overflow: auto;\n}\n\n/**\n * Address odd `em`-unit font size rendering in all browsers.\n */\n\ncode,\nkbd,\npre,\nsamp {\n font-family: monospace, monospace;\n font-size: 1em;\n}\n\n/* Forms\n ========================================================================== */\n\n/**\n * Known limitation: by default, Chrome and Safari on OS X allow very limited\n * styling of `select`, unless a `border` property is set.\n */\n\n/**\n * 1. Correct color not being inherited.\n * Known issue: affects color of disabled elements.\n * 2. Correct font properties not being inherited.\n * 3. Address margins set differently in Firefox 4+, Safari 5, and Chrome.\n */\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n color: inherit; /* 1 */\n font: inherit; /* 2 */\n margin: 0; /* 3 */\n}\n\n/**\n * Address `overflow` set to `hidden` in IE 8/9/10.\n */\n\nbutton {\n overflow: visible;\n}\n\n/**\n * Address inconsistent `text-transform` inheritance for `button` and `select`.\n * All other form control elements do not inherit `text-transform` values.\n * Correct `button` style inheritance in Firefox, IE 8+, and Opera\n * Correct `select` style inheritance in Firefox.\n */\n\nbutton,\nselect {\n text-transform: none;\n}\n\n/**\n * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`\n * and `video` controls.\n * 2. Correct inability to style clickable `input` types in iOS.\n * 3. Improve usability and consistency of cursor style between image-type\n * `input` and others.\n */\n\nbutton,\nhtml input[type=\"button\"], /* 1 */\ninput[type=\"reset\"],\ninput[type=\"submit\"] {\n -webkit-appearance: button; /* 2 */\n cursor: pointer; /* 3 */\n}\n\n/**\n * Re-set default cursor for disabled elements.\n */\n\nbutton[disabled],\nhtml input[disabled] {\n cursor: default;\n}\n\n/**\n * Remove inner padding and border in Firefox 4+.\n */\n\nbutton::-moz-focus-inner,\ninput::-moz-focus-inner {\n border: 0;\n padding: 0;\n}\n\n/**\n * Address Firefox 4+ setting `line-height` on `input` using `!important` in\n * the UA stylesheet.\n */\n\ninput {\n line-height: normal;\n}\n\n/**\n * It's recommended that you don't attempt to style these elements.\n * Firefox's implementation doesn't respect box-sizing, padding, or width.\n *\n * 1. Address box sizing set to `content-box` in IE 8/9/10.\n * 2. Remove excess padding in IE 8/9/10.\n */\n\ninput[type=\"checkbox\"],\ninput[type=\"radio\"] {\n box-sizing: border-box; /* 1 */\n padding: 0; /* 2 */\n}\n\n/**\n * Fix the cursor style for Chrome's increment/decrement buttons. For certain\n * `font-size` values of the `input`, it causes the cursor style of the\n * decrement button to change from `default` to `text`.\n */\n\ninput[type=\"number\"]::-webkit-inner-spin-button,\ninput[type=\"number\"]::-webkit-outer-spin-button {\n height: auto;\n}\n\n/**\n * 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome.\n * 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome\n * (include `-moz` to future-proof).\n */\n\ninput[type=\"search\"] {\n -webkit-appearance: textfield; /* 1 */\n -moz-box-sizing: content-box;\n -webkit-box-sizing: content-box; /* 2 */\n box-sizing: content-box;\n}\n\n/**\n * Remove inner padding and search cancel button in Safari and Chrome on OS X.\n * Safari (but not Chrome) clips the cancel button when the search input has\n * padding (and `textfield` appearance).\n */\n\ninput[type=\"search\"]::-webkit-search-cancel-button,\ninput[type=\"search\"]::-webkit-search-decoration {\n -webkit-appearance: none;\n}\n\n/**\n * Define consistent border, margin, and padding.\n */\n\nfieldset {\n border: 1px solid #c0c0c0;\n margin: 0 2px;\n padding: 0.35em 0.625em 0.75em;\n}\n\n/**\n * 1. Correct `color` not being inherited in IE 8/9.\n * 2. Remove padding so people aren't caught out if they zero out fieldsets.\n */\n\nlegend {\n border: 0; /* 1 */\n padding: 0; /* 2 */\n}\n\n/**\n * Remove default vertical scrollbar in IE 8/9.\n */\n\ntextarea {\n overflow: auto;\n}\n\n/**\n * Don't inherit the `font-weight` (applied by a rule above).\n * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.\n */\n\noptgroup {\n font-weight: bold;\n}\n\n/* Tables\n ========================================================================== */\n\n/**\n * Remove most spacing between table cells.\n */\n\ntable {\n border-collapse: collapse;\n border-spacing: 0;\n}\n\ntd,\nth {\n padding: 0;\n}\n"
},
"$:/themes/tiddlywiki/vanilla/settings/fontfamily": {
"title": "$:/themes/tiddlywiki/vanilla/settings/fontfamily",
"text": "-apple-system, BlinkMacSystemFont, \"Segoe UI\", Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\""
},
"$:/themes/tiddlywiki/vanilla/settings/codefontfamily": {
"title": "$:/themes/tiddlywiki/vanilla/settings/codefontfamily",
"text": "\"SFMono-Regular\",Consolas,\"Liberation Mono\",Menlo,Courier,monospace"
},
"$:/themes/tiddlywiki/vanilla/settings/backgroundimageattachment": {
"title": "$:/themes/tiddlywiki/vanilla/settings/backgroundimageattachment",
"text": "fixed"
},
"$:/themes/tiddlywiki/vanilla/settings/backgroundimagesize": {
"title": "$:/themes/tiddlywiki/vanilla/settings/backgroundimagesize",
"text": "auto"
},
"$:/themes/tiddlywiki/vanilla/sticky": {
"title": "$:/themes/tiddlywiki/vanilla/sticky",
"text": "<$reveal state=\"$:/themes/tiddlywiki/vanilla/options/stickytitles\" type=\"match\" text=\"yes\">\n``\n.tc-tiddler-title {\n\tposition: -webkit-sticky;\n\tposition: -moz-sticky;\n\tposition: -o-sticky;\n\tposition: -ms-sticky;\n\tposition: sticky;\n\ttop: 0px;\n\tbackground: ``<<colour tiddler-background>>``;\n\tz-index: 500;\n}\n``\n</$reveal>\n"
}
}
}
Explanations for the code of $:/plugins/telmiger/listreveal/readme – you can clone the linked tiddler and adapt it step by step to create your own listreveal project. The filter statement is a good point to start:
```
<$set name="listfilter"
value="""[tag[Listreveal]!is[system]sort[title]]""">
<ul class="te-list">
<$list filter=<<listfilter>>>
```
Always use a variable called //listfilter// to create your list. The list-based tag manager (see [[03 Context Tagging]]) is depending on this convention.
It is recommended to use the CSS classes you see in this example – add your own to change the looks.
```
<$set name="tidTitle" value={{!!title}}>
<li class="todo-item te-flex-item">
<span class="te-flex-item te-flex-half-full">
<span class="te-flex-item te-flex-content te-flex-left">
<$link to={{!!title}}><$view field="title"/></$link>
</span>
</span>
```
The styling relies on [[CSS3 flexbox|https://scotch.io/tutorials/a-visual-guide-to-css3-flexbox-properties]]. These spans help to make your list as mobile friendly as possible.
```
<span class="te-flex-item te-flex-half-full">
<span class="te-flex-item te-flex-content te-flex-right">
<<teBtnEditShowModified>>
```
This macro produces an edit button. It shows the tiddler’s modified date when the mouse hovers over it.
```
<$wikify name="cl" text=<<telang close>> >
<$wikify name="tt" text=<<telang Details>> >
<$macrocall $name="listrevealButton" title=<<tidTitle>> tooltip=<<tt>> close=<<cl>>/>
</$wikify>
</$wikify>
```
This macrocall produces the button on the right side that opens and closes the tiddlers.
The variables //cl// and //tt// get predefined translations from the language tiddlers that are part of this plugin. You can replace the tooltip for opening (attribute //tooltip//) and closing (attribute //close//) with your own texts.
```
</span>
</span>
<$wikify name="tpl" text=<<telang date-created-tmpl>> >
<$macrocall $name="listrevealContent" title=<<tidTitle>> datetime=<<tpl>>/>
</$wikify>
```
This macrocall produces the text content and some details of your tiddler.
Again the variable //tpl// gets a predefined translation from the integrated language tiddlers. It is used as a [[date format template|http://tiddlywiki.com/#DateFormat]] when the created and modified timestamps of the tiddler are displayed. This attribute is optional.
//tidTitle// is the variable for the title of your list elements (your tiddlers). It is set at the beginning (see second snippet).
```
</li>
</$set>
</$list>
</ul>
</$set>
```
The whole list is presented as an unordered HTML list `<ul>` with tiddlers as list items `<li>`.
When you look inside a tiddler in the list using the ellipsis (…) button on the right, you see the tiddler’s tags, text and timestamps.
{{$:/core/images/tag-button}}
The tags can be changed using the tag label icon. A unique feature called context tagging or list-based tagging appears in a popup. From there you are able to add suggested tags based on the other tiddlers in your list or remove single tags from the tiddler.
This plugin comes with CSS to support checklists generated via a plugin by Tony Grosinger – indentation and the display of user interface elements to add and delete items should be optimized for use inside of listreveal lists.
[ ] Install the plugin from https://grosinger.net/tw5-checklist/
[ ] Make your first checklist
[x] Read these hints on checklists
Im Idealfall ist die Schuldfrage eindeutig und Sie sind am Unfall vollkommen unschuldig.
Hier muss Ihr Unfallgegner, beziehungsweise dessen Haftpflichtversicherung, sämtliche Kosten übernehmen, die Ihnen durch den Unfall entstehen.
Das betrifft Reparatur und auch Anwaltskosten sowie gegebenenfalls ein Ersatzfahrzeug oder eine Ausfallentschädigung für die Dauer der Reparatur.
Doch ein Unfallschaden senkt automatisch den Wert des Fahrzeugs, auch wenn nach einer Reparatur äußerlich nichts mehr zu sehen ist.
Wenn die Kfz-Finanzierung noch läuft und Sie den Wagen am Ende der Ratenzahlung zurückgeben oder verkaufen wollten, kann dies ein Problem sein. Unter bestimmten Bedingungen muss der Unfallgegner bei einem erheblichen Schaden aber auch für den Wertverlust gerade stehen.
Voraussetzung ist, dass das Auto nicht älter als fünf Jahre ist (Tag der Erstzulassung) und nicht mehr als 100.000 Kilometer auf dem Tacho hat. Ausgeglichen wird die Differenz zum Wert, den der Wagen vor dem Unfall hatte. Diesen ermittelt ein Gutachter.
In bestimmten Fällen, zum Beispiel bei einem nahezu neuen Wagen, kann der Wertverlust auch höher als die Reparaturkosten ausfallen. Beides muss der Unfallgegner begleichen.
Entry. - @@.source <$transclude field="authortitle"/>, <$view field="page"/>.@@
!Scenes
Drag the scenes on the right side of the wiki to this draggable zone (under this text):
<$vars actual=<<currentTiddler>> >
<$macrocall $name="list-tagged-draggable" tag=<<currentTiddler>> itemTemplate="scene_template"/>
</$vars>
To delete a scene to this story unckeck the ckeckbox.
! A
* [[Agrarrecht]]
* [[Arbeitsrecht]]
* [[Asyl- und Ausländerrecht]]
! B
* [[Bank- und Kapitalmarktrecht]]
* [[Bau- und Architektenrecht]]
* [[Beamtenrecht]]
* [[Berufs- und Standesrecht]]
! C
* [[Compliance]]
! D
* [[Datenschutz]]
! E
* [[Energierecht]]
* [[Erbrecht]]
* [[Europa- und Völkerrecht]]
! F
* [[Familienrecht]]
! G
* [[Gewerblicher Rechtsschutz]]
! H
* [[Handels- und Gesellschaftsrecht]]
! I
* [[Immobilienwirtschaftsrecht]]
* [[Informationstechnologierecht]]
* [[Insolvenzrecht]]
! K
* [[Kartellrecht]]
* [[Kirchenrecht]]
* [[Kosten- und Vergütungsrecht]]
! L
* [[Lebensmittelrecht]]
* [[Litigation]]
* [[Litigation & Dispute Resolution]]
! M
* [[Medizinrecht]]
* [[Mergers & Acquisitions (M&A)]]
* [[Miet- und WEG-Recht]]
! O
* [[Öffentliches Recht]]
! P
* [[Polizei- und Ordnungsrecht]]
* [[Private Equity]]
! R
* [[Reiserecht]]
* [[Restrukturierung]]
! S
* [[Sozialrecht]]
* [[Sportrecht]]
* [[Staatsrecht und Staatsorganisationsrecht]]
* [[Steuerrecht]]
* [[Strafrecht]]
! T
* [[Transport- und Speditionsrecht]]
! U
* [[Umweltrecht]]
* [[Urheber- und Medienrecht]]
! V
* [[Vergaberecht]]
* [[Verkehrsrecht]]
* [[Versicherungsrecht]]
* [[Verwaltungsrecht]]
! W
* [[Waffenrecht]]
* [[Wirtschaftsrecht]]
! Z
* [[Zivil- und Zivilverfahrensrecht]]
Bei der Abgrenzung zwischen Selbstständigkeit oder freien Mitarbeit zur abhängigen Beschäftigung erfordert die Einordnung letztlich im Rahmen einer Gesamtschau die Gewichtung für und wider sprechender Anhaltspunkte.
[[Abgrenzungstabs]]
[[Batch Manipulator|batchmanipulator]] simplifies setting/removing tags, fields and field values for multiple tiddlers.
`relations` view makes it relatively easy to investigate which tiddlers are related by tags or fields. Its table shows the filtered tiddlers //total// set of tags or fields.
`single data` view focuses on one bit of meta-data such as a tag or a field value and displays a table with tools to manipulate this.
''sometitle'' @@color:blue; 3⤴@@ means that there are 3 tiddlers tagged with //sometitle// and the arrow indicates that you can click to //add this to the filter//. In the upper table the arrows similarly mean... ah, you'll understand.
@@color:lightgreen; green links@@ - this feature is not perfected yet ...but it is intended as a fast way to create a filter centering around that title.
<<tag ALL>> is for drag'n dropping the filtered tiddlers into some other TW.
!!!Install
by dragging this into your TW: <<tag batchmanipulator>>
@@color:crimson; Note@@ - If you have many tiddlers with many tags etc, the relations table can get very big and it can take a long time to generate it - possibly causing a crash! The prevention is to first backup before and use a `limit[...]` in the filter.
!!!Workflow tips
*Most easily enter e.g `[tag[foo]]` into the filter by merely typing `foo` in the value field and click the [!] and then ⤴
*..or, instead of typing into the value field, //drag// the title from a sidebar list
*..or, drag'n drop ''tag pills'' from // sidebar > More > Tags// straight into the filter field.
<span style="color:crimson; border: 1px solid;padding:0 5px;">
BETA - quite a few [[Issues]]</span>
[[CherryPicker]] - apply "natural markers", made up as you type, to mark out segments ("cherries") in one or several tiddler texts. Call the cherrypicker macro to get the cherries extracted and presented as a list.
!!!Quick demo
<$transclude tiddler="Quick demo" mode="block"/>
...call `<<cherrypicker "HEY">>` to get...<br>
<div style="border:2px solid lightgreen; padding:0 0 30px 20px;;">
{{Example result}}
</div>
<span style="float:right;margin:-3.5em 1em 0 0;font-size:80%;">(click{{cherrybullet.png}}to go to tid)</span>
Go to [[Demo]] to try it out.
!!!Installation
Drag all components tagged <<tag CherryPickerComponent>> into your TW.
!!!Extending the concept
<$reveal type="nomatch" state="$:/state/Extending" text="show">
<$button set="$:/state/Extending" setTo="show" class="tc-btn-invisible tc-tiddlylink button-border">...just to wet your appetite ;-) </$button><br><br>
</$reveal>
<$reveal type="match" state="$:/state/Extending" text="show" >
<$button set="$:/state/Extending" setTo="hide" class="tc-btn-invisible tc-tiddlylink button-border">close Extending</$button>
<$transclude tiddler="Extending the concept" mode="block"/>
</$reveal>
!!!More
*[[Issues]]
*[[Stress testing]] - for bug search...
*[[Future Ideas]]
*[[CherryPicker/Syntax thoughts]]
*[[Concept Background]]
<div class="family-tree">
</div>
<div class="family-tree">
*[[Automatically style]]
**bullet lists
**Into family-trees
*[[Parent]]
**[[Child 1]]
***[[GrandChild 1.1]]
**[[Child 2]]
***[[GrandChild 2.1]]
</div>
x
@@color:crimson; CRED@@ Other than a few tweaks, this is fully based on [[thecodeplayer|http://thecodeplayer.com/walkthrough/css3-family-tree]].
[[Simple case]]
{{Simple case}}
!!!Other cases
*[[Simple, using html markup]]
*[[Overflowed]]
*[[Overflow contained in tiddler]]
The ''newtids'' macro lets you easily convert plain text lists into tiddlers. For example, copy-paste a list of items from some excel sheet or whatever.
Each item - i.e each row - that you then click becomes a tiddler. Extra tags and a (single) field can be added in the process.
!!!Install
by dragging this into our TW: <<tag $:/newtids>>
<br><br>
!!!Demo<br>
<<newtids "
foo
bar bar
Baz is really cool!
frotz
">>
<br><br><br>
''NO''. It is not complicated. I promise. <br>
That @@background:#f4f4f4;border:1px solid silver;padding:0 3px; box@@ to the right just shows the syntax.<br>
Write that "code" and you get the whole full display:
Set tags etc and then click a blue links at a time which creates(!) that corresponding new tiddler.
!!!Notes
When "navigate to tiddler" is not checked, the tiddler is created silently, but the title is no longer in italics. Click it again to go to the tiddler - it's just a regular link.
If you want //content// in your resulting tiddlers, you can use the field value "text" but note that the content looses all formatting, including `[[brackets for links]]`.
...tags, however, can and should use brackets for `[[spaced tags]]`
@@color:silver; //Mat von TWaddle//@@
!!!Demo
<<tabs "one two three four" "two" "$:/state/tab2">>
<<tabs "one two three " "two" "$:/state/tab3" "tc-vertical">>
<div style="position:absolute; margin:-5em 10em; text-align:center;">
''note also the tabs in the //sidebar//''<br> incl. the vertical tabs under //More//
</div>
!!!Install
Drag these into your TW:
*$:/plugins/TWaddle/PlainTabs/Stylesheet<br>This is a common stylesheet tiddler
*[[PlainTabs/settings]]<br>This has a quick button to set some //palette// colour values.<br>You can delete this tiddler after use.
!!!Demo
<<tabs "one two three four" "two" "$:/state/tab2">>
<<tabs "one two three " "two" "$:/state/tab3" "tc-vertical">>
<div style="position:absolute; margin:-5em 10em; text-align:center;">
''note also the tabs in the //sidebar//''<br> incl. the vertical tabs under //More//
</div>
!!!Install
Drag these into your TW:
*$:/plugins/TWaddle/PlainTabs/Stylesheet<br>This is a common stylesheet tiddler
*[[PlainTabs/settings]]<br>This has a quick button to set some //palette// colour values.<br>You can delete this tiddler after use.
⇦ The ''~TiddlerSidebar'' is what you see if you ''hover'' over the left tiddler gutter here.
It is a "generic container" that can show anything you want but by default it contains a few items specific for the tiddler you're triggering it in.
<$list filter="[tag[$:/TiddlerSidebar]]"><dd><li><$link to={{!!title}}><$view tiddler={{!!title}} field="title" format="text">{{!!title}}</$view></$link> - {{!!summary}}</li></dd></$list><dd><li> ''+'' add any other tiddler tagged `$:/TiddlerSidebar`</li></dd>
[[Meta]]
<br>The code for ~TiddlerSidebar is in [[$:/_TWaddle/TiddlerSidebar]]
Einzelfallbeurteilung. Kommt bei Arbeitnehmern ohnehin nur
selten in Betracht (ausnahmsweise z.B.
für beruflich benötigtes Auto oder wichtige
Arbeitsmittel). AfA für die Abnutzung
von Gebäuden (-).Gilt auch für Abschreibung
nach § 7 b EStG. Bei Selbständigen grundsät
zlich (+), allerdings keine Bindung an
die steuerlichen Abschreibungssätze im
Zweifel nachzuweisen, ob Investition
betriebsnotwendig und sinnvoll war.
{{||$:/plugins/btheado/ftlist/tagged-list}}
I made such and such saving with this great idea
I presented to an audience who gave me a standing ovation
\define slider-label(prefix,suffix)
@@.grey-svg $prefix$<$text text="$(currentTiddler)$"/>$suffix$@@
\end
@@.note
''Note:'' The key to implementing an accordion menu is to define the same ''state'' tiddler for all list items.
@@
Uses a helper macro for slider buttons to create a list of tiddlers opening as sliders:
```
\define slider-label(prefix,suffix)
@@.grey-svg $prefix$<$text text="$(currentTiddler)$"/>$suffix$@@
\end
```
<$macrocall $name="`" text="""<$list filter="[all[shadows]prefix[$:/plugins/tobibeer/appear/]sort[title]]">
<$appear
show=<<slider-label suffix:"{{$:/core/images/chevron-right}}">>
tooltip="show/hide tiddler"
state="$:/state/menu/accordion">
<$transclude mode="block"/>
</$appear><br>
</$list>"""/>
´´´
ActionListopsWidget
can be used to add items to a list.
The delete widget can be used to delete tiddlers.
Your outer template (overall template) might look like:
<$vars person=<<currentTiddler>>>
<$list filter=[enlist{!!contacts}] >
{{||contactTemplate}}
</$list>
</$vars>
and the contact template might look like:
<$button>
<$action-deletetiddler $tiddler=<<currentTiddler>> />
<$action-listops $tiddler=<<person>> $field="contacts" $subfilter="+[remove<currentTiddler>]"/>
Delete <<currentTiddler>> which supports <<person>>
</$button>
Phone: <$edit-text tiddler=<<person>> field="phone1" size=20 tag="input"/>
Then a button would appear in each contact section allowing you to remove that tiddler and remove it's entry in the contact list.
´´´
\define my-actions()
<$action-navigate $to="$:/ControlPanel"/>
<$action-setfield $tiddler="$:/SiteTitle" $value={{{ [{$:/SiteTitle}addsuffix[!]] }}}/>
\end
<$button actions=<<my-actions>>>
Click me to open control panel and add an exclamation mark to the site title
</$button>
Anspruchsgrundlage oder Rechtsgrundlage
hat meist eine Referenz im Gesetz
`<$set name=tiddler-title value={{!!caption}}>`
`{{{ [tag<tiddler-title>] +[tag[Voraussetzungen]] }}}`
---
<$set name=tiddler-title value={{!!caption}}>
<$list filter='[subfilter<tiddler-title>] +[field[parent]]'>
<$transclude field="title" />
</$list>
---
<$list filter='[tag[AGL]]'>
<h1><$transclude field="parent" /></h1>
<h3><$transclude field="title" /></h3>
<$transclude display="block" />
</$list>
http://juraeinmaleins.de/anspruchsgrundlagen/
§ 12 BGB, Namensrecht
§§ 31 i. V. m. 823 BGB,
§ 122 BGB, Schadensersatzpflicht des Anfechtenden
§ 160 BGB, Haftung während der Schwebezeit
§ 179 BGB, Haftung des Vertreters ohne Vertretungsmacht
§ 228 S. 2 BGB, Notstand
§ 241 I BGB, § 311 I BGB,
§ 253 I BGB, § 823 BGB,
§ 280 I BGB, Schadensersatz wegen Pflichtverletzung
§ 284 BGB, Ersatz vergeblicher Aufwendungen
§ 304 BGB, Ersatz von Mehraufwendungen
§ 311 Abs. 2 1. Alt BGB, Rechtsgeschäftliche und rechtsgeschäftsähnliche Schuldverhältnisse
§ 346 BGB, Wirkungen des Rücktritts
§ 347 II BGB, Nutzungen und Verwendungen nach Rücktritt
§ 402 BGB, Auskunftspflicht; Urkundenauslieferung
§ 426 I BGB, Ausgleichungspflicht, Forderungsübergang
§ 426 II BGB, Ausgleichungspflicht, Forderungsübergang
§ 433 I BGB, Vertragstypische Pflichten beim Kaufvertrag
§ 433 II BGB, Vertragstypische Pflichten beim Kaufvertrag
§ 439 IV BGB, Nacherfüllung
§ 441 IV BGB, Minderung
§ 459 BGB, Ersatz von Verwendungen
§ 468 BGB, Stundung des Kaufpreises
§ 478 II BGB, Rückgriff des Unternehmers
§ 488 S.1 BGB, Vertragstypische Pflichten beim Darlehensvertrag
§ 516 I BGB, Begriff der Schenkung
§ 523 I BGB, Haftung für Rechtsmängel
§ 535 I BGB, Inhalt und Hauptpflichten des Mietvertrags
§ 535 II BGB (§ 549 I BGB), Auf Wohnraummietverhältnisse anwendbare Vorschriften), Inhalt und Hauptpflichten des Mietvertrags
§ 536a I BGB, Schadens- und Aufwendungsersatzanspruch des Mieters wegen eines Mangels
§ 536a II BGB (§ 257 BGB, Befreiungsanspruch), Schadens- und Aufwendungsersatzanspruch des Mieters wegen eines Mangels
§ 539 I BGB, Ersatz sonstiger Aufwendungen und Wegnahmerecht des Mieters
§ 546 BGB, Rückgabepflicht des Mieters
§ 546a I BGB, Entschädigung des Vermieters bei verspäteter Rückgabe
§ 547 BGB, Erstattung von im Voraus entrichteter Miete
§ 581 I BGB, Vertragstypische Pflichten beim Pachtvertrag
§ 590b BGB, Notwendige Verwendungen
§ 591 BGB, Wertverbessernde Verwendungen
§ 596 I BGB, Rückgabe der Pachtsache
§ 598 BGB, Vertragstypische Pflichten bei der Leihe
§ 601 II BGB, Verwendungsersatz
§ 604 I BGB, Rückgabepflicht
§ 604 IV BGB, Rückgabepflicht
§ 607 I S. 1 BGB, Vertragstypische Pflichten beim Sachdarlehensvertrag
§ 607 I S. 2 BGB, Vertragstypische Pflichten beim Sachdarlehensvertrag
§ 611 I BGB, Vertragstypische Pflichten beim Dienstvertrag
§ 628 II BGB, Teilvergütung und Schadensersatz bei fristloser Kündigung
§ 630a I Alt. 1 BGB, Vertragstypische Pflichten beim Behandlungsvertrag
§ 630a I Alt. 2 BGB, Vertragstypische Pflichten beim Behandlungsvertrag
§ 631 I BGB, Vertragstypische Pflichten beim Werkvertrag
§ 637 I BGB, Selbstvornahme
§ 640 BGB, Abnahme
§ 642 I BGB, Mitwirkung des Bestellers
§ 645 I BGB, Verantwortlichkeit des Bestellers
§ 651a I S.1 BGB, Vertragstypische Pflichten beim Reisevertrag
§ 651a I S.2 BGB, Vertragstypische Pflichten beim Reisevertrag
§ 651c I S.1 BGB, Abhilfe
§ 651f BGB, Schadensersatz
§ 652 I BGB, Entstehung des Lohnanspruchs
§ 652 II BGB, Entstehung des Lohnanspruchs
§ 661a BGB, Gewinnzusagen
§ 662 BGB, Vertragstypische Pflichten beim Auftrag
§ 666 BGB, Auskunfts- und Rechenschaftspflicht
§ 667 BGB, Herausgabepflicht
§ 670 BGB, Ersatz von Aufwendungen
§ 675 BGB, Entgeltliche Geschäftsbesorgung
§ 677 BGB, Pflichten des Geschäftsführers
§ 678 BGB, Geschäftsführung gegen den Willen des Geschäftsherrn
§ 681 BGB, Nebenpflichten des Geschäftsführers
§ 684 BGB, Herausgabe der Bereicherung
§ 687 II BGB, Unechte Geschäftsführung
§ 688 BGB, Vertragstypische Pflichten bei der Verwahrung
§ 689 BGB, Vergütung
§ 693 BGB, Ersatz von Aufwendungen
§ 694 BGB, Schadensersatzpflicht des Hinterlegers
§ 695 S.1 BGB, Rückforderungsrecht des Hinterlegers
§ 696 BGB, Rücknahmeanspruch des Verwahrers
§ 713 BGB, Rechte und Pflichten der geschäftsführenden Gesellschafter
§ 732 BGB, Rückgabe von Gegenständen
§ 740 II BGB, Beteiligung am Ergebnis schwebender Geschäfte
§ 765 BGB, Vertragstypische Pflichten bei der Bürgschaft
§ 780 BGB, Schuldversprechen
§ 781 BGB, Schuldanerkenntnis
§ 812 I S.1 1. Alt. BGB, Herausgabeanspruch
§ 812 I S.1 2. Alt. BGB, Herausgabeanspruch
§ 812 I S.2 1. Alt. BGB, Herausgabeanspruch
§ 812 I S.2 2. Alt. BGB, Herausgabeanspruch
§ 813 I BGB, Erfüllung trotz Einrede
§ 816 I S.2 BGB, Verfügung eines Nichtberechtigten
§ 817 BGB, Verstoß gegen Gesetz oder gute Sitten
§ 822 BGB, Herausgabepflicht Dritter
§ 823 BGB, Schadensersatzpflicht
§ 826 BGB, Sittenwidrige vorsätzliche Schädigung
§ 831 I BGB, Haftung für den Verrichtungsgehilfen
§ 832 I BGB, Haftung des Aufsichtspflichtigen
§ 833 S.1 BGB, Haftung des Tierhalters
§ 833 S.2 BGB, Haftung des Tierhalters
§ 836 I BGB, Haftung des Grundstücksbesitzers
§ 844 I BGB, Ersatzansprüche Dritter bei Tötung
§ 845 BGB, Ersatzansprüche wegen entgangener Dienste
§ 850 BGB, Ersatz von Verwendungen
§ 852 BGB, Herausgabeanspruch nach Eintritt der Verjährung
§ 859 BGB, Selbsthilfe des Besitzers
§ 861 I BGB, Anspruch wegen Besitzentziehung
§ 862 I BGB, Anspruch wegen Besitzstörung
§ 876 BGB, Aufhebung eines belasteten Rechts
§ 886 BGB, Beseitigungsanspruch
§ 888 I BGB, Anspruch des Vormerkungsberechtigten auf Zustimmung
§ 894 BGB, Berichtigung des Grundbuchs
§ 904 S.2 BGB, Notstand
§ 951 BGB, Entschädigung für Rechtsverlust
§ 970 BGB, Ersatz von Aufwendungen
§ 985 BGB, Herausgabeanspruch
§ 988 BGB, Nutzungen des unentgeltlichen Besitzers
§ 989 BGB, Schadensersatz nach Rechtshängigkeit
§ 990 I BGB, Haftung des Besitzers bei Kenntnis
§ 993 I BGB, Haftung des redlichen Besitzers
§ 994 ff. BGB, Notwendige Verwendungen
§ 996 BGB, Nützliche Verwendungen
§ 997 I BGB, Wegnahmerecht
§ 999 I BGB, Ersatz von Verwendungen des Rechtsvorgängers
§ 1004 I BGB, Beseitigungs- und Unterlassungsanspruch
§ 1007 I BGB, Ansprüche des früheren Besitzers, Ausschluss bei Kenntnis
§ 1007 II BGB, Ansprüche des früheren Besitzers, Ausschluss bei Kenntnis
§ 1065 BGB, Beeinträchtigung des Nießbrauchsrechts
§ 1223 I BGB, Rückgabepflicht; Einlösungsrecht
§ 1227 BGB, Schutz des Pfandrechts
§ 1231 BGB, Herausgabe des Pfandes zum Verkauf
§ 1298 I BGB, Ersatzpflicht bei Rücktritt
§ 1301 BGB, Rückgabe der Geschenke
§ 1310 I S.2 BGB, Zuständigkeit des Standesbeamten, Heilung fehlerhafter Ehen
§ 1353 BGB, Eheliche Lebensgemeinschaft
§ 1360 BGB, Verpflichtung zum Familienunterhalt
§ 1361 BGB, Unterhalt bei Getrenntleben
§ 1378 BGB, Ausgleichsforderung
§ 1379 BGB, Auskunftspflicht
§ 1569 BGB, Grundsatz der Eigenverantwortung
§ 1601 BGB, Unterhaltsverpflichtete
§ 1607 II, III BGB, Ersatzhaftung und gesetzlicher Forderungsübergang
§ 1648 BGB, Ersatz von Aufwendungen
§ 1835 BGB, Aufwendungsersatz
§ 1967 I BGB (§ 2058 BGB, Gesamtschuldnerische Haftung), Erbenhaftung, Nachlassverbindlichkeiten
§ 2018 BGB, Herausgabepflicht des Erbschaftsbesitzers
§ 2042 BGB, Auseinandersetzung
§ 2174 BGB, Vermächtnisanspruch
§ 2303 I BGB, Pflichtteilsberechtigte; Höhe des Pflichtteils
§ 2305 BGB, Zusatzpflichtteil
§ 2314 BGB, Auskunftspflicht des Erben
§ 2325 BGB, Pflichtteilsergänzungsanspruch bei Schenkungen
§ 2329 BGB, Anspruch gegen den Beschenkten
AGL
Tags
Unique ID
Transclusion of Voraussetzungen
`{{Voraussetzungen - über Listreveal}}`
{{Voraussetzungen - über Listreveal}}
!Rechtsfolge
`{{!!rechtfolge}}`
{{!!rechtfolge}}
<<tabs "Intro [[Voraussetzungen - visuel]] Rechtfolge " "Intro" "$:/state/tab3" >>
!AGL Kaufpreis
Drag the scenes on the right side of the wiki to this draggable zone (under this text):
<$vars actual=<<currentTiddler>> >
<$macrocall $name="list-tagged-draggable" tag=<<currentTiddler>> itemTemplate="voraus_template"/>
</$vars>
To delete a scene to this story unckeck the ckeckbox.
<$set name="listfilter"
value="""[tag{!!title}tag[Voraussetzungen]!is[system]sort[title]]""">
<ul class="te-list">
<$list filter=<<listfilter>>>
<$set name="tidTitle" value={{!!title}}>
<li class="todo-item te-flex-item">
<span class="te-flex-item te-flex-half-full">
<span class="te-flex-item te-flex-content te-flex-left">
<$link to={{!!title}}><$view field="title"/></$link>
</span>
</span>
<span class="te-flex-item te-flex-half-full">
<span class="te-flex-item te-flex-content te-flex-right">
<<teBtnEditShowModified>>
<$wikify name="cl" text=<<telang close>> >
<$wikify name="tt" text=<<telang Details>> >
<$macrocall $name="listrevealButton" title=<<tidTitle>> tooltip=<<tt>> close=<<cl>>/>
</$wikify>
</$wikify>
</span>
</span>
<$wikify name="tpl" text=<<telang date-created-tmpl>> >
<$macrocall $name="listrevealContent" title=<<tidTitle>> datetime=<<tpl>>/>
</$wikify>
</li>
</$set>
</$list>
</ul>
</$set>
<$set name=tiddler-title value={{!!title}}>
<$list filter="[tag<tiddler-title>]" variable="current-story">
<$transclude tiddler=<<current-story>>/>
<$list filter="[tags<current-story>regexp[Vor]]" template="$:/core/ui/TagTemplate"/>
</$list>
Getestet wird hier hier der Tag "OK"
<$list filter="[tag[OK]sort[title]]">
<h1><$link><$view field="title"/></$link></h1>
<$transclude mode="block"/>
</$list>
(1) Anwendbarkeit des KSchG
#(a) Persönlicher Anwendungsbereich, [[§ 1 I KSchG|KSchG / 01]]
#(b) Sachlicher Anwendungsbereich, § 23 I S. 2, 3 KSchG
#(c) Alternativ: Bei Unanwendbarkeit KSchG, allgemeine Kontrolle nach §§ 138, 242 BGB ( dann Punkt (2) weglassen)
(2) Soziale Rechtfertigung der Kündigung
#(a) Verhaltensbedingter Kündigungsgrund i.S.v. § 1 II KSchG
##(aa) Abmahnung erforderlich
##(bb) Einzelfallbezogene Interessenabwägung
oder
#(b) Personenbedingter Kündigungsgrund, i.S.v. § 1 II KschG
##(aa) Möglicherweise Versetzung an anderen Arbeitsplatz
##(bb) Einzelfallbezogene Interessenabwägung
oder
#(c)Betriebsbedingter Kündigungsgrund i.S.v. § 1 II KSchG
##(aa) Dringendes betriebliches Erfordernis
##(bb) Keine Möglichkeit den Arbeitnehmer weiterhin zu beschäftigen
##(cc) Sozialauswahl gemäß § 1 III KSchG
(3) Klagefrist nach KSchG, §§ 4,5,7 KSchG
Das nach der Einigung vorausgesetzte Angebot ist eine empfangsbedürftige Willenserklärung, die alle vertragswesentlichen Bestandteile enthält.
Weiterhin verlangt die Einigung nach den §§ 145 ff. BGB eine Annahme. Annahme ist eine grundsätzlich empfangsbedürftige Willenserklärung, welche die Zustimmung zum Angebot enthält.
Wenn man einen Anspruch ausfindig gemacht hat, ist beim Anspruchsaufbau zu berücksichtigen, ob der Anspruch entstanden, nicht erloschen und durchsetzbar ist.
I. Anspruch entstanden
Zunächst ist im Anspruchsaufbau zu prüfen, ob der Anspruch entstanden ist. Hierbei ist im Anspruchsaufbau zwischen vertraglichen und gesetzlichen Ansprüchen zu unterscheiden.
1. Vertragliche Ansprüche
Vertragliche Ansprüche kommen zustande, indem sich die Parteien einigen und diese Einigung auch wirksam ist.
a) Einigung, §§ 145 ff. BGB
Eine Einigung kommt durch zwei übereinstimmende Willenserklärungen, Angebot und Annahme, zustande.
b) Wirksamkeit
Die Wirksamkeit liegt vor, wenn keine rechtshindernden Einwendungen bestehen. Das sind Einwendungen, die dazu führen, dass der Anspruch nicht einmal entsteht (Nichtigkeitsgründe). Beispiel: A verkauft dem B sein Fahrzeug und A ist während des Vertrags unerkannt geisteskrank und damit nach den §§ 104, 105 BGB geschäftsunfähig. Dann haben sich A und B zwar geeinigt, diese Einigung ist jedoch aufgrund der unerkannten Geisteskrankheit nach den §§ 104, 105 BGB unwirksam.
2. Gesetzliche Ansprüche
Bei den gesetzlichen Ansprüchen ist im Anspruchsaufbau bei dem Punkt Anspruch entstanden keine Einigung zu prüfen. Vielmehr müssen für einen gesetzlichen Anspruch die Tatbestandsvoraussetzungen der betreffenden Norm vorliegen. Beispiel: A fährt dem B eine Beule in sein Auto. B hat folglich einen Schadensersatzanspruch gegen den A aus § 823 I BGB, wenn die Voraussetzungen des § 823 I BGB vorliegen. Diese sind Rechtsgutsverletzung, Verletzungsverhalten, Zurechnung, Rechtswidrigkeit und Verschulden.
II. Anspruch nicht erloschen
Im Anspruchsaufbau folgt sodann die Prüfung, ob der Anspruch auch nicht erloschen ist (Kein Erlöschen des Anspruchs/ Anspruch nicht untergegangen). Hier sind rechtsvernichtende Einwendungen zu prüfen. Dies sind Einwendungen, die dazu führen, dass ein bereits entstandener Anspruch wieder vernichtet wird, also erlischt. Beispiel1: Erfüllung gemäß § 362 BGB. A verkauft dem B sein Auto und übereignet es auch. Damit tritt nach § 362 BGB Erfüllung ein, sodass A dem B, wenn B noch einmal kommen und Erfüllung verlangen würde, die rechtsvernichtende Einwendung der Erfüllung entgegenhalten kann. Der Anspruch ist zwar wirksam entstanden, jedoch nach § 362 BGB erloschen. Beispiel2: Unmöglichkeit gemäß § 275 BGB. A verkauft dem B ein Auto und nach Abschluss des Kaufvertrags und vor Übereignung entsteht aufgrund eines Unfalls ein Totalschaden. Somit ist der Anspruch zwar wirksam entstanden, jedoch aufgrund von Unmöglichkeit nach § 275 I BGB nicht mehr erfüllbar und damit erloschen. Beispiel3: Anfechtung gemäß den §§ 142 I, 119 ff. BGB. A verkauft dem B ein Fahrzeug. B hat sich bei dieser Gelegenheit beispielsweise über den Fahrzeugtyp geirrt und erklärt die Anfechtung. Dann kann B nicht mehr die Übereignung des Fahrzeugs verlangen, wie auch A nicht die Zahlung des Kaufpreises verlangen kann. Hierbei ist zwar strittig, ob die Anfechtung eine rechtsvernichtende oder eine bereits rechtshindernde Einwendung darstellt, da im Falle der Anfechtung aufgrund der ex tunc Wirkung das Rechtsgeschäft als von Anfang an nichtig anzusehen ist. Wichtig ist jedoch nur, dass die Anfechtung an einer der beiden Stellen im Anspruchsaufbau geprüft wird.
III. Anspruch durchsetzbar
Zuletzt schließt sich im Anspruchsaufbau die Prüfung an, ob der Anspruch durchsetzbar ist. Hier sind rechtshemmende Einreden zu prüfen. Der Unterschiede zwischen den Einwendungen und den Einreden besteht darin, dass man über Einreden reden muss, diese also geltend gemacht werden müssen. Das bedeutet, dass Einwendungen von Amts wegen zu prüfen sind, und zwar selbst dann, wenn sich die betroffene Partei nicht auf die Einwendung beruft. Einreden sind hingegen nur dann zu prüfen, wenn sich die Beteiligten auf sie berufen. Ist Letzteres nicht der Fall, ist die Einrede zu ignorieren oder darauf hinzuweisen, dass sich die betreffende Partei nicht darauf berufen hat. Im Anspruchsaufbau sind sowohl dauerhafte (peremptorische) als auch vorübergehende Einreden zu prüfen.
1. Dauerhafte Einreden
Eine dauerhafte Einrede ist beispielsweise die Verjährung gemäß den §§ 194 ff. BGB. Beispiel: Wenn A gegen B einen Anspruch auf Kaufpreiszahlung hat und Jahre später zu B kommt, um das Geld von ihm zu verlangen, dann ist der Anspruch zwar entstanden und auch nicht erloschen. A kann ihn aber aufgrund der Verjährung nicht mehr durchsetzen.
2. Vorübergehende Einreden
Vorübergehende Einreden sind beispielsweise das Zurückbehaltungsrecht nach § 273 BGB und die Einrede des nicht erfüllten Vertrags gemäß § 320 BGB. Beispiel § 320 BGB: A verkauft dem B seinen Wagen und fährt zu B und verlangt den Kaufpreis. B hält dem A entgegen, dass er dann auch Übereignung des Fahrzeugs möchte. Solange A dem B nicht zumindest das Auto angeboten hat, ist B nicht verpflichtet, dem A den Kaufpreis zu zahlen und umgekehrt. Allerdings betrifft § 320 BGB nur die im Gegenseitigkeitsverhältnis stehenden Pflichten. § 273 BGB regelt hingegen das Zurückbehaltungsrecht bei Pflichten, die nicht im Gegenseitigkeitsverhältnis stehen. Beispiel. Wenn der Vermieter am Ende der Mietzeit die Kaution nicht herausgibt, weil der Mieter die erforderlichen Schönheitsreparaturen noch nicht vorgenommen hat, dann sind dies nicht die Hauptleistungspflichten im Mietvertrag, sondern Pflichten, die anlässlich des Mietvertrags aneinander gegenübergestellt werden.
https://www.jurawiki.de/AnwaltsSoftware
[[KSchG / 14]]
[[KSchG / 23]]
This tutorial is intended to help build an initial set-up of the Apache HTTPD server software. In the end you should have a working HTTP server.
!Before We Begin
Before you can start, you will need:
# A working computer with the operating system installed (these instructions assume FreeBSD but will highlight differences for Windows and Debian Linux). Suitable computers include:
## A desktop running Windows x64 (7 or 10)
## A computer running FreeBSD or Linux (including those tiny Intel NUC, Zotac ZBox computers)
## A Raspberry Pi 2 or 3 running Raspbian
## A Virtual Machine (KVM, ~VirtualBox, Xen, or VMware) with at least 1GB of RAM and 4GB of available storage.
# Connectivity to the Internet to download the software.
!Step 1: Installing Apache HTTPD
TBD
!Step 2: Basic Apache HTTPD Setup (static content over http only)
TBD
Technically you could enable WebDAV before setting up authentication or TLS but if you did that then anyone who can make a network connection to your computer can use it as a network disk without any authentication or authorization at all. So, be sure to complete both [[Apache HTTPD with Basic Auth]] and [[Apache HTTPD with TLS]] first.
! HTTPD Config File for ~WebDAV
This is a brief summary of the settings needed in the Apache httpd.conf file.
Load the WebDAV specific modules:
```
LoadModule dav_module libexec/apache24/mod_dav.so
LoadModule autoindex_module libexec/apache24/mod_autoindex.so
LoadModule dav_fs_module libexec/apache24/mod_dav_fs.so
LoadModule dav_lock_module libexec/apache24/mod_dav_lock.so
```
The autoindex_module is optional, but without it you don't get a directory listing when you try to access your server with a web browser. Technically dav_lock_module is also optional but that makes it very easy for people to overwrite eachother's work.
Load the SSL specific modules:
```
LoadModule ssl_module libexec/apache24/mod_ssl.so
```
Load the Authentication specific modules:
```
LoadModule authn_file_module libexec/apache24/mod_authn_file.so
LoadModule authn_core_module libexec/apache24/mod_authn_core.so
LoadModule authz_host_module libexec/apache24/mod_authz_host.so
LoadModule authz_groupfile_module libexec/apache24/mod_authz_groupfile.so
LoadModule authz_user_module libexec/apache24/mod_authz_user.so
LoadModule authz_core_module libexec/apache24/mod_authz_core.so
LoadModule auth_basic_module libexec/apache24/mod_auth_basic.so
```
Setup a virtual host. Technically you don't need a virtual host and could simply put everything in the main Apache HTTPD config file.
```
<VirtualHost *:443>
ServerName dav.example.com
DocumentRoot /www/davroot
<Directory /www/davroot>
Options Indexes FollowSymLinks
AllowOverride None
Require all granted
</Directory>
```
Enable SSL on this virtual host. Strictly speaking this is optional, but you probably want to protect your data from being intercepted.
```
SSLEngine On
SSLCertificateChainFile /path/to/fullchain.pem
SSLCertificateFile /path/to/cert.pem
SSLCertificateKeyFile /path/to/privkey.pem
```
Enable DAV. This example makes the entire web server into a big DAV server. You could make only a subset of your server accessible via WebDAV if you change the location to a sub-directory.
```
DavLockDB "/var/db/DavLock/davlock"
<Location />
DAV On
Options +Indexes
IndexOptions FancyIndexing
DirectoryIndex disabled
```
//Note the ``<Location ...>`` directive is based on the path part of the URL used in the web browser, the ``<Directory ...>`` directive is based on your filesystem. //
Add authentication. Also optional, but if you don't do this, how do you stop everyone from using your server? If you don't use SSL, you really should change __AuthType__ to __Digest__.
```
AuthType Basic
AuthName "Whatever you want"
AuthBasicProvider file
AuthUserFile "/path/to/htpasswd.txt"
AuthGroupFile "/path/to/htgroup.txt"
require valid-user
</Location>
</VirtualHost>
```
An der Entwicklung von Applikationen sind zahlreiche Parteien beteiligt, in ihrem Vortrag auf der Social Week in Hamburg hat Rechtsanwältin Andrea Schlotfeldt jedoch insbesondere die rechtlichen Beziehungen zwischen Entwickler und Auftraggeber sowie Entwickler und Urheber behandelt.
Die Ausgangssituation ist durch „umfassende Verträge mit AppStores“, „nicht verhandelbare Nutzungsbedingungen“ und den bei Apple gängigen Review-Prozess bedingt, erklärt Schlotfeldt. Eine Teilnehmerin rät wegen der möglichen Ablehnung einer Applikation davon ab, in Verträgen mit Auftraggebern harte Deadlines zu setzen. Wichtig sei hier außerdem eine intensive Beratung, ergänzt ein zweiter Teilnehmer.
Aufgrund der sich möglicherweise ändernden Rahmenbedingungen, rät Schlotfeldt stets zu schriftlichen Verträgen zwischen Entwickler und Auftraggeber. Sie sollten unter anderem folgende Kapitel beinhalten:
• Präambel über Vertragsgegenstand
• Planung und Entwicklung
• Vorgehen bei Änderungen
• Mitwirkungspflicht des App-Anbieters
• Abnahme
• Nutzungsrechte und Urhebernennung
• Vergütung
• Rechte Dritter
• Verzug
• Gewährleistung sowie Haftung
• Wartung/Pflege
• Gerichtsstand/Sonstiges
• Lasten- und Pflichtenheft als Anhang
Sie beinhalten den Liefer- und Leistungsumfang, alle rechtlichen Fallstricke sowie die Muss-, Soll- und Wunschkriterien. Letztere beinhalten alle Bestandteile der Entwicklung, von Konzept und Zweck bis zu Verkauf und Fristen.
Mitwirkungspflicht und Abnahmepflicht
Gesonderte Erwähnung findet im Rahmen des Vortrags die Mitwirkungspflicht der Anbieter. Schlotfeldt zählt hierzu beispielsweise die Angabe bestimmter Funktionen und die Lieferung von Inhalten. Bei Nichteinhaltung sollten Entwickler in Verträgen auf ein Kündigungsrecht sowie einen Vergütungsanspruch bestehen.
Die „Abnahme“ sollte die finale Präsentation durch den Entwickler und die Prüfung des App-Anbieters beinhalten. Damit einhergehend unter anderem den Vergütungsanspruch und den Verjährungsbeginn. Schlotfeldt rät dazu, eine Pflicht zur Abnahme festzulegen und sich diese nach Abschluss des Projekts schriftlich bestätigen zu lassen.
Urheberrecht bei der App-Entwicklung
Wie bei einem Text oder Foto, haben Entwickler auch auf Applikationen ein Urheberrecht. Sie haben dadurch das alleinige Verwertungsrecht, solange es keine Miturheber gibt oder zum Zeitpunkt der Entwicklung in einem Angestelltenverhältnis stehen. Das Urheberrecht beinhaltet zustimmungsbedürftige Handlungen, beispielsweise bei nachträglicher Vervielfältigung oder Bearbeitung einer entwickelten Applikation.
Alle im Kontext des Urheberrechts relevanten Punkte sollten Entwickler im Vertrag schriftlich festhalten, erklärt Schlotfeldt. Eine Angabe wie „Recht zur Nutzung im Internet“ sei nicht ausreichend, erforderlich ist hingegen eine konkretere Regelung. Wenn es keine Absprache gibt, erhält der App-Anbieter (beispielsweise Apple-App-Store) nur so viele Rechte wie er zum Anbieten der Applikation benötigt.
Verträge bei App-Entwicklung: Nutzungsrechte und Dritt-Inhalte
Schlotfeldt rät dazu, die Einräumung von Nutzungsrechten so genau wie möglich festzuhalten. Dies gilt nicht nur für die räumlichen, zeitlichen und inhaltlichen Kriterien, sondern auch für Nutzungsarten. Betroffen sind davon seit einigen Jahren auch „zukünftige, bislang unbekannte Nutzungsarten“, so Schlotfeldt. Eine neue Technologie ist davon also nicht länger ausgeschlossen.
Die Angaben zu Dritt-Inhalten legen fest, welche der beiden Parteien die verwendeten Inhalte (beispielsweise Bilder oder Texte) zur Verfügung stellt und die rechtliche Haftung der Integration übernimmt. Der Verstoß gegen Nutzungsbedingungen könne schließlich auch zum Ausschluss aus einem AppStore führen, so Schlotfeldt.
Wichtig: die Vergütung und Abnahme
Die Vergütung ist mit Abnahme der App fällig. Entwickler können hier zwischen verschiedenen Varianten wählen: Möglich sind Stundensätze, Pauschalhonorare und Staffelhonorare. Letztere erfolgen beispielsweise nach der Anzahl an Downloads, ähnlich wie auch in der Buchbranche. Gängig ist laut den meisten Teilnehmern klar das Pauschalhonorar beziehungsweise der Stundensatz.
Für Urheber ist die nachträgliche Anpassung der Vergütung bei unpassender Bezahlung und überdurchschnittlichem Erfolg besonders spannend. Hier greift Paragraf 32 des Urheberrechtsgesetz zur „Angemessenen Vergütung“. Laut Schlotfeld können Entwickler – in diesem Fall die Urheber – bei durchschlagendem Erfolg nachträglich eine Anpassung der Bezahlung verlangen.
Gewährleistung und Haftung
Im Bereich „Gewährleistung“ müssen beide Parteien genau festlegen, in welchem Fall welche Partei haftet. Hier ist zwischen Sachmängeln und Rechtsmängeln zu unterschieden: Erstgenannte betreffen beispielsweise fehlende Funktionen oder mangelnde Leistungen, letztgenannte betreffen vor allem Verstöße gegen Urheberrechte bei Dritt-Anbietern.
Schlotfeldt empfiehlt in jedem Fall eine Haftungsbegrenzung, gängig sind hier Prozentsätze nach Auftragswert. Laut eines Teilnehmers lassen sich diese aber nicht immer durchsetzen. Seine Kunden bestätigen Verträge oftmals mit Verweis auf die eigenen Geschäftsbedingungen, die wiederum andere Angaben zur Haftung geltend machen.
Illegal ist die Arbeitnehmerüberlassung, wenn der Verleiher nicht über die nach § 1 AÜG erforderliche Erlaubnis verfügt. Als Rechtsfolge sieht das Gesetz in diesem Fall die Unwirksamkeit des Überlassungsvertrags vor und ordnet an, dass in einem solchen Fall ein Arbeitsverhältnis zwischen dem Entleiher und dem Leiharbeitnehmer zustande kommt.
Zum Schutz des Entleihers schreibt § 12 Absatz 1 Satz 2 AÜG vor, dass der Verleiher im Überlassungsvertrag zu erklären hat, ob er die nach § 1 AÜG erforderliche Erlaubnis besitzt. Daher sind in den Vertragstext Informationspflichten. des Verleihers gegenüber dem Entleiher für den Fall aufzunehmen, dass eine ihm erteilte Erlaubnis zurückgenommen, widerrufen oder bei Auslaufen nicht erneut erteilt wird.
Die entsprechende Klausel könnte ei etwa wie folgt lauten:
//Dieser Überlassungsvertrag endet, ohne dass es einer Kündigung bedarf, mit Wegfall, Nichtverlängerung, Rücknahme oder Widerruf der Erlaubnis zur Arbeitnehmerüberlassung. Soll zwischen Entleiher und einem überlassenen Arbeitnehmern kraft Gesetzes ein Arbeitsverhältnis entstehen, stellt der Verleiher den Entleiher von sämtlichen Kosten, die aufgrund und im Zusammenhang mit der Durchführung und Beteiligung eines solchen fingierten Arbeitsverhältnisses entstehen. Dies umfasst Lohn- und Lohnnebenkosten, Abfindungszahlungen sowie auch Gerichts- und Anwaltskosten.//
Bei der Arbeitnehmerüberlassung ist neben dem Arbeitsvertrag zwischen dem Leiharbeitnehmer und dem Verleiher auch das Rechtsverhältnis zwischen Verleiher und Entleiher vertraglich auszugestalten.
§ 12 AÜG schreibt hier die zwingende Schriftform vor. Das bedeutet, dass der Vertrag von beiden Parteien eigenhändig zu unterschreiben ist und der gesamte Vertragsinhalt sich aus der Vertragsurkunde selbst ergeben muss.
<<tabs "[tag[Klausel]] +[tag[ANÜ]]" "[[Gesetzliche Klauselvorgaben]]" "$:/state/tab2">>
* [[Individualarbeitsrecht]]
* [[Kollektives Arbeitsrecht]]
* [[Sozialversicherungsrecht]]
http://www.meub.de/indiv_ar.htm
Beendigung statbestand AV - 3 Monatsbruttogehalt
Abmahnung, Zeugnis - 1 Monatsgehalt
Anwaltsrecht
#Arbeitsrecht
Architektenrecht
Archivrecht
Auftragsrecht
Ausländerrecht
Bankrecht
Baurecht
Bergrecht
Berufsrecht
Betäubungsmittelrecht
Bibliotheksrecht
Börsenrecht
Bürgschaftsrecht
Datenschutzrecht
#Deliktsrecht
Denkmalrecht
Domainrecht
EDV-Recht
Enteignungsrecht
#Erbrecht
Europarecht
Familienrecht
Fracht-/Speditionsrecht
Gesellschaftsrecht
Gesundheitsrecht
Gewerberecht
Gewerblicher Rechtsschutz
Grundrechte
Grundstücksrecht
Handelsrecht
Haushaltsrecht
Individualarbeitsrecht
Informationsrecht
Insolvenzrecht
Internationale Gerichtsbarkeit
Internationales Privatrecht
Internationales Strafrecht
Internationales Wirtschaftsrecht
Jugendrecht
Jugendstrafrecht
Kartellrecht
Kaufrecht
Kirchenrecht
Kollektives Arbeitsrecht
Kommunalrecht
Kriegsrecht
Landesrecht
Landwirtschaftsrecht
Maklerrecht
Marken- und Kennzeichnungsrecht
Medienrecht
Medizinrecht
Menschenrechte
Mietrecht
Naturschutzrecht
[[Öffentliches Recht]]
Patentrecht
Pferderecht
Polizeirecht
Produkthaftungsrecht
Prozessrecht
Raumordnungsrecht
Recht der internationalen Organisationen
Recht des Öffentlichen Dienstes
Reiserecht
Sachenrecht
Schenkungsrecht
Schulrecht
Schuldrecht
Sozialrecht
Sozialhilferecht
Sozialversicherungsrecht
Staatshaftungsrecht
Staatsrecht
Steuerrecht
Stiftungsrecht
[[Strafrecht]]
Strafprozessrecht
Strafvollzugsrecht
Straßenrecht
Telekommunikationsrecht
Umweltrecht
[[Urheberrecht]]
Vereinsrecht
Vergaberecht
Verkehrsrecht
Versicherungsrecht
Verwaltungsrecht
Verwaltungsorganisationsrecht
Verwaltungsprozessrecht
Völkerrecht
Wehrrecht
Werkvertragsrecht
Wettbewerbsrecht
Wirtschaftsrecht
Wohnungseigentumsrecht
Zivilprozessrecht
[[Zivilrecht]]
Zwangsvollstreckungsrecht
abzüglich berufsbedingter Aufwendungen
Je nach Vereinbarung hat der Verleiher für die gesamte Überlassungsdauer die durchgängige Besetzung des Arbeitsplatzes zu gewährleisten.
Wenn also der Leiharbeitnehmer (vorübergehend) nicht zur Verfügung steht, ist der Verleiher verpflichtet, einen dem vereinbarten Anforderungsprofil entsprechenden Ersatz zu stellen. Insbesondere wenn die Überlassung eines konkreten, namentlich benannten Arbeitnehmers vereinbart wird, sollte vertraglich geregelt werden, ob der Verleiher auch dann einen geeigneten Ersatzes stellen muss.
Aus Verleihersicht wird in Überlassungsverträgen in der Regel eine darüber hinausgehende Haftung ausgeschlossen und lediglich eine Haftung entsprechend den allgemeinen zivilrechtlichen Regelungen vereinbart, die etwa wie folgt formuliert werden kann:
//Über die Auswahl der überlassenen Arbeitnehmer hinaus trifft den Verleiher keine Haftung für die Ausführung der Tätigkeiten durch die überlassenen Arbeitnehmer oder für etwaige von diesen bei Gelegenheit ihrer Tätigkeiten für den Entleiher verursachte Schäden. Der Verleiher haftet insoweit nur nach Maßgabe der gesetzlichen Bestimmungen.//
Hintergrund ist, dass der Entleiher die Leiharbeitnehmer in seinem Betrieb wie eigene Mitarbeiter einsetzt und die Möglichkeit hat, deren Tätigkeit zu überwachen und diesbezüglich Anweisungen zu erteilen.
Sofern Ausgleichsansprüche aufgrund gesellschaftsvertraglicher Regelungen nicht in Betracht kommen, besteht noch die Möglichkeit, einen Ausgleichsanspruch nach den Grundsätzen des Wegfalls der Geschäftsgrundlage in Betracht zu ziehen, da es sich bei der Arbeitsleistung um sogenannte ausgleichspflichtige ehebezogene Zuwendungen handeln könnte. Ehebezogene Zuwendungen liegen vor, wenn ein Ehegatte dem anderen einen Vermögenswert um der Ehe willen und als Beitrag zur Verwirklichung und Ausgestaltung, Erhaltung oder Sicherung der ehelichen Lebensgemeinschaft zukommen lässt. Diesbezüglich ist die Rechtsprechung sehr vielfältig und gerade in der jüngeren Zeit sind hierzu auch vom Bundesgerichtshof neue Urteile ergangen.
Die gesetzlich normierten Zugewinnausgleichsregeln sind zwar eigentlich vorrangiges Recht, jedoch lässt die Rechtsprechung die Anwendung des Regeln über den Wegfall der Geschäftsgrundlage nach § 313 BGB mitunter als Korrektiv gegen krass ungerechte Ergebnisse in Ausnahmefällen zu (BGH FamRZ 2005, S. 1974 und BGH FamRZ 1994, S. 503). Dafür muss allerdings das Ergebnis der Durchführung des Zugewinnausgleichs zu einer schlechthin unzumutbare Vermögenslage für den zuwendenden Ehegatten führen. Die Anpassung nach § 313 BGB ist dann von dem zuwendenden Ehegatten zu beantragen und ergibt sich gerade nicht mehr kraft Gesetz.
So wurde in der Rechtsprechung eine Anpassung nach § 313 BGB vorgenommen, wenn Leistungen (teilweise) an den anderen Ehegatten zugewendet wurden, die ein Ehegatte aufgrund einer schweren Verletzung erhalten hat oder aber auch Fälle in denen ein Ehegatten dem anderen während der Verlobungszeit für die Bebauung von dessen Grundstück erhebliche Zuwendungen gemacht hat bzw. ein Ehegatte dem anderen unter Vorsorgegesichtspunkten ein Wertpapierdepot übertragen und die Ehe dann nach kurzer Zeit geschieden wurde (BGH FamRZ 1994, S. 503).
Ein Anwendung der Grundsätze des Wegfalls der Geschäftsgrundlage wurde hingegen für den Fall abgelehnt, dass die Zugewinnausgleichsansprüche verjährt sind (OLG Düsseldorf NJW-R 2003, S. 793).
Das reine Erbringen von Arbeitsleistungen im Betrieb des anderen Ehegatten ist jedoch kein Fall für Ausgleichsansprüche aufgrund des Wegfalls der Geschäftsgrundlage. Dies gilt insbesondere dann, wenn der Ehegatte teilweise ein entsprechendes Gehalt erhalten hat. Darüber hinaus lassen sich Arbeitsleistungen nicht unter den vom Bundesgerichtshof geformten Begriff der unbenannten Zuwendungen subsumieren, um deren Rückabwicklung es im Rahmen der Billigkeitserwägungen, die zur Anwendung des § 313 BGB führen, ursprünglich ging. Arbeitsleistungen, die ein Ehegatte zugunsten seines Ehepartners erbringt und mit denen er dessen Vermögen steigert, können schon begrifflich nicht als Zuwendungen verstanden werden, da das Gesetz unter einer Zuwendung nur die Übertragung von Vermögenssubstanz und nicht das Zur-Verfügung-Stellen von Arbeitskraft versteht. Denn während eine Zuwendung (beispielsweise in geldlicher Form) das Vermögen des Empfängers in gleicher Weise mehrt, wie es das Vermögen des Gebers mindert, ist dies bei Arbeitsleistungen gerade nicht der Fall, da keine entsprechende, unmittelbare Vermögensminderung stattfindet.
Ausgleichsansprüche aus eigengearteter familienrechtlicher Vereinbarung nach den Grundsätzen des Wegfalls der Geschäftsgrundlage (familienrechtlicher Vertrag besonderer Art)
Liegen die Voraussetzungen der BGB-Innengesellschaft nicht vor, wenn beispielsweise die Mitarbeit des Ehepartners nicht auf einer gleichberechtigten Mitarbeit beruht und/oder keine eheüberschreitender Zweck gegeben ist, so kann ausnahmsweise durch schlichte Mitarbeit ein Ausgleichsanspruch begründet werden. Denn auch wenn der Bundesgerichtshof Arbeitsleistungen nicht unter den Begriff der unbenannten Zuwendungen subsumiert, so stellen Arbeitsleistungen nichtsdestotrotz wirtschaftlich betrachtet durchaus eine geldwerte Leistung dar, ebenso wie die Übertragung von Vermögenssubstanz. Der Bundesgerichtshof hat in diesen Fällen bereits einige Male das Vorliegen eines familienrechtlichen Vertrags besonderer Art aufgrund der konkreten Einzelfallumstände angenommen (BGH FuR 1994, S. 201). Auf diesen (stillschweigend) geschlossenen Vertrag wendet der BGH ebenfalls die Grundsätze des Wegfalls der Geschäftsgrundlage an.
Die Rechtsprechung hat dafür eine Reihe von Voraussetzungen entwickelt (BGH FamRZ 1994, S. 1167). Es bedarf zunächst einer Vergrößerung des Vermögens auf Seiten des einen Ehegatten, hervorgerufen durch die Arbeitsleistung des anderen, wobei das erhöhte Vermögen auch beim begünstigen Ehegatten noch vorhanden sein muss. Zudem muss die Arbeitsleistung ganz erheblich über ehetypische Gefälligkeiten hinausgehen und von einer gewissen Dauer und Regelmäßigkeit sein. Ein Ausgleichsanspruch aufgrund des besonders gearteten familienrechtlichen Vertrages besteht nur, wenn die Arbeitsleistung ganz wesentlich über die Unterhaltspflicht oder die im Rahmen der Ehe geschuldete Beistandspflicht hinausgeht und es keine entsprechende Gegenleistung gegeben hat. Darüber hinaus gilt auch hier, dass die Aufrechterhaltung des bestehenden Vermögensstandes für den zuwendenden Ehegatten unzumutbar bzw. untragbar sein muss (BGH FamRZ 2003, S. 230).
Sofern diese Voraussetzungen vorliegen, kann ein sogenannter eigengearteter familienrechtlicher Vertrag gegeben sein. Allerdings können aus einem familienrechtlichen Vertrag eigener Art nur Ansprüche erwachsen, wenn kein hinreichender bzw. vorrangig zu beachtender güterrechtlicher Ausgleich erfolgt. Daneben ist auch jede die entsprechenden Leistungen betreffende Parteiabrede vorrangig zu bewerten.
Haben die Ehegatten eine vertragliche Vereinbarung über eine gemeinsame Unternehmensgründung oder Unternehmensführung oder ist diese zumindest für die Eheleute eine gelebte Praxis, kann ein Ausgleichsanspruch entstehen, wenn die Eheleute sich trennen und die Unternehmung nicht weiter fortführen. Dabei ist nicht entscheidend, ob die Firma oder das Unternehmen formal nur einen Ehegatten als Inhaber ausweist. Es kann sich um eine sogenannte BGB-Innengesellschaft handeln, die aufgrund der Auflösung zu Ausgleichsansprüchen führen kann.
Mit Urteil des Bundesgerichtshofes vom 28.09.2005 (AZ: XII ZR 189/02) hat dieser entschieden, dass ein gesellschaftsrechtlicher Ausgleichsanspruch auch neben dem Zugewinnausgleichsanspruch bestehen kann und nicht erst dann zum Tragen kommt, wenn ein Zugewinnausgleich zu einem unbilligen Ergebnis führt oder ausgeschlossen ist.
Nach Beendigung einer Innengesellschaft kommt ein schuldrechtlicher Anspruch auf Zahlung eines Auseinandersetzungsguthabens nach den §§ 738 ff. BGB in Betracht. Dabei ist vom Bundesgerichtshof mittlerweile auch die voreheliche BGB-Innengesellschaft anerkannt, sofern zumindest durch schlüssiges Verhalten ein Gesellschaftsvertrag im Innenverhältnis vor der Ehe begründet worden ist (BGH Urteil vom 28.09.2005, AZ: XII ZR 189/02 und BGH Urteil vom 06.07.2011, AZ: XII ZR 190/08). Auch sind solche Ausgleichsansprüche für die nichteheliche Lebensgemeinschaft vom Bundesgerichtshof anerkannt worden (Urteil vom 09.07.2008 AZ: XII ZR 39/06).
In letzter Zeit wurde aus Praktikabilitätsgründen verstärkt und aufgrund der Feststellung, dass der Interessenlage oftmals mit der Auseinandersetzung in Anwendung gesellschaftlicher Grundsätze besser gedient ist (BGH FamRZ 1999 S. 1583), auf einen Ausgleich über die BGB-Innengesellschaft zurückgegriffen, obwohl dies nur schwerlich mit dem Erfordernis eines schlüssig zustande gekommenen Vertrages zu vereinbaren ist.
Grundsätzlich dient die Schaffung der Ausgleichsansprüche im Rahmen einer BGB-Innengesellschaft im weitesten Sinne einem Billigkeitsaustausch. Diese Regelungen sind aber dann nicht heranzuziehen, wenn andere, insbesondere arbeitsvertragliche Regelungen in Betracht kommen. Dementsprechend können Ansprüche nach den Grundsätzen der BGB-Innengesellschaft nicht für die Zeit eines bestehenden Arbeitsvertrages zwischen den Ehegatten begründet werden. Hat beispielsweise die Ehefrau auf der Basis eines Arbeitsvertrages im Unternehmen ihres Mannes mitgearbeitet und hierfür einen Ausgleich durch die Zahlung von Arbeitslohn erhalten, kommen gesellschaftsrechtliche Ausgleichsansprüche nicht mehr in Betracht. Etwas anderes ist nur denkbar, wenn die Vergütung für die geleistete Arbeitstätigkeit gemessen am Arbeitsvertrag unbillig und unangemessen ist.
Nach der Entscheidung des Bundesgerichtshofes vom 28.09.2005 (AZ: XII ZR 189/02) hat der Umstand, dass die Ehegatten im Rahmen des Ehevertrages den Zugewinn im Scheidungsfall ausgeschlossen oder eine Gütertrennung vereinbart haben, zunächst keine Auswirkungen auf das Bestehen gesellschaftsrechtlicher Ansprüche. Denn in seiner Entscheidung hat der BGH festgestellt, dass ein gesellschaftsrechtlicher Ausgleichsanspruch auch grundsätzlich neben einem Zugewinnanspruch in Betracht kommen kann (BGH NJW 2006, S. 1268). Mithin schließt der Verzicht auf einen Zugewinnausgleich im Scheidungsfall, auch im Rahmen einer notariellen Urkunde, das Bestehen eines gesellschaftsrechtlichen Ausgleichsanspruchs nicht aus.
Erforderlich ist aber immer, dass eine BGB-Innengesellschaft vorliegt. Notwendig dafür ist, dass entweder der eine Ehegatte nach außen hin als alleiniger Inhaber auftritt, im Innenverhältnis jedoch die Ehegatte das Unternehmen gemeinsam führen oder tatsächlich auch nach außen das Unternehmen oder die Firma von beiden Ehegatten geführt und vertreten wird. Voraussetzung dafür ist, dass beide Ehegatten gleichberechtigte im Betrieb mitwirken und ebenfalls beide Ehegatten ihre berufliche Tätigkeit auch als gemeinschaftliche, gleichrangige Tätigkeit empfunden haben (BGH FamRZ 1990, S. 1219). Folglich setzt dies in subjektiver Hinsicht eine dementsprechende Willensbildung beider Ehepartner voraus, die ihrem Zweck nach über die Verwirklichung der Ehegemeinschaft hinausgeht. Beide Ehegatten müssen gemeinschaftlich nicht nur den Aufbau eines Unternehmens beabsichtigt, sondern auch eine Vermögensbildung betrieben haben, die über die Verwirklichung der reinen Ehegemeinschaft hinausgeht.
Nach Rechtsprechung des Bundesgerichtshofes ist die Begründung einer BGB-Innengesellschaft auch dann möglich, wenn zwar keine gemeinschaftlichen oder gleichberechtigten Arbeitsleistungen vorliegen, jedoch langfristige Investitionen in das Vermögen des anderen Ehegatten vorgenommen wurden (BGH FamRZ 1999, S. 1580 ff; OLG Karlsruhe FamRZ 2008, S. 1080).
a) Abschluss eines schuldrechtlichen Vertrags
b) Ehegatteninnengesellschaft
c) Gesamtschuldnerausgleich
d) Miteigentümergemeinschaft
e) Freistellungsanspruch
f) Gesamtgläubigerausgleich
g) Unbenannte Zuwendungen
4. Ausgleichsansprüche neben dem Zugewinnausgleich
Für schuldrechtliche Rückabwicklungsansprüche sind die güterrechtlichen Sonderregelungen über den Zugewinn grundsätzlich abschließend.
Daneben sind Ausgleichsansprüche nur in folgenden Fällen möglich:
a) Abschluss eines schuldrechtlichen Vertrags
Haben die Ehegatten ausdrücklich einen Arbeits-, Dienst-, Werk- oder Gesellschaftsvertrag geschlossen, so erfolgt die Abwicklung nach den allgemeinen Regelungen. Ansprüche aus solchen Verträgen sind im Endvermögen der Ehegatten als Aktiva bzw. als Passiva zu berücksichtigen.
b) Ehegatteninnengesellschaft
Expertentipp
Lesen Sie dazu auch noch einmal die Rn. 40 oben!
Die vermögensrechtlichen Beziehungen der Ehegatten können sich auch nach dem Gesellschaftsrecht richten, wenn eine Ehegatteninnengesellschaft vorliegt.
Beispiel
Die Ehegatten errichten ein Mehrfamilienhaus zur Vermietung.
Ein über die eheliche Lebensgemeinschaft hinausgehender Zweck kann dagegen nicht in der Anschaffung eines Einfamilienhauses der Ehegatten gesehen werden.
Die Ehegatteninnengesellschaft ist eine BGB-Gesellschaft nach §§ 705 ff. ohne Gesamthandsvermögen und ohne Außenwirkung. Mit der Trennung bzw. mit der Scheidung wird die Gesellschaft aufgelöst. Für die von dem mitarbeitenden Ehegatten erbrachten Leistungen (§ 706 Abs. 2) ist nach § 733 Abs. 2 Wertersatz zu leisten, wobei sich die Dienste als bleibender Wert im Gesellschaftsvermögen niedergeschlagen haben müssen.
Die Höhe des Ausgleichs beträgt nach § 722 Abs. 1 die Hälfte des Wertes.
c) Gesamtschuldnerausgleich
Erfüllt während der Ehe ein Ehegatte eine Verbindlichkeit, für deren Erfüllung die Ehegatten als Gesamtschuldner haften, ist ein Gesamtschuldnerausgleich nach § 426 in der Regel ausgeschlossen, wenn ein Ehegatte die Haushaltsführung übernommen hat. In diesem Fall haben die Ehegatten etwas anderes i.S.v. § 426 Abs. 1 S. 1 bestimmt, da die Haushaltsführung des einen Ehegatten nach § 1360 S. 2 dem finanziellen Beitrag des erwerbstätigen Ehegatten gleichsteht. Für die Annahme einer anderen Bestimmung i.S.v. § 426 Abs. 1 S. 1 ist der Abschluss einer besonderen Vereinbarung der Ehegatten nicht erforderlich. Eine dem § 745 Abs. 2 entsprechende Regelung enthält § 426 gerade nicht. Im Rahmen dieser Vorschrift hat nach Auffassung des BGH
„die besondere Gestaltung des tatsächlichen Geschehens“ von vornherein einen unmittelbaren Einfluss auf die Rechtsbeziehungen der Gesamtschuldner zueinander, ohne dass es in irgendeiner Weise auf eine gestaltende Handlung der Gesamtschuldner ankäme. Deshalb kann sich diese Vereinbarung aus dem Inhalt und Zweck des zwischen den Gesamtschuldnern bestehenden Rechtsverhältnisses oder aus der Natur der Sache ergeben.
Mit dem Scheitern der Ehe bzw. mit der Aufhebung der ehelichen Lebensgemeinschaft kann jeder Ehegatte eine Neuregelung verlangen. Dazu bedarf es keiner besonderen Handlung des Ehegatten, der den Ausgleichsanspruch verlangt, da durch die Beendigung der ehelichen Lebensgemeinschaft eine „andere Bestimmung“ i.S.v. § 426 Abs. 1 S. 1 nicht mehr gegeben ist. Durch die Trennung lebt der Anspruch auf den Gesamtschuldnerausgleich wieder auf.
Die Haftung im Innenverhältnis richtet sich nach der Trennung nach den Miteigentumsanteilen.
Die Gesamtschuld wird als Verbindlichkeit in dem Endvermögen der Ehegatten jeweils berücksichtigt.
Hinweis
Etwas anderes gilt allerdings dann, wenn die finanziellen Belastungen bereits in die Berechnung des Ehegattenunterhalts eingestellt worden sind. In diesem Fall stellt die Berücksichtigung der Verbindlichkeiten bei der Berechnung des Unterhalts eine anderweitige Bestimmung i.S.v. § 426 Abs. S. 1 dar und verdrängt insoweit den Gesamtschuldnerausgleich.
d) Miteigentümergemeinschaft
Haben die Ehegatten Miteigentum an einem gemeinsam genutzten Haus oder einer Wohnung, so besteht zwischen Ihnen ein Gemeinschaftsverhältnis i.S.v. §§ 1008, 741 ff. Im Falle des Auszugs eines Ehegatten kann der andere Ehegatte nach § 1361b Abs. 3 S. 2 von dem nutzungsberechtigten Ehegatten eine Vergütung für die Nutzung verlangen, soweit dies der Billigkeit entspricht.
e) Freistellungsanspruch
Hat ein Ehegatte während intakter Ehe dem anderen die Aufnahme von Bankkrediten durch Übernahme einer persönlichen Haftung oder durch die Einräumung von dinglichen Sicherheiten ermöglicht, kann er nach Scheitern der Ehe Befreiung von solchen Verbindlichkeiten nach den Regeln des Auftragsrechts verlangen, wenn vertraglich nicht etwas anderes bestimmt ist. Die Geltendmachung des Befreiungsanspruchs unterliegt jedoch Einschränkungen, die sich als Nachwirkung der Ehe sowie nach Treu und Glauben aus den Umständen ergeben können, die zur Begründung der Verbindlichkeiten geführt haben.
f) Gesamtgläubigerausgleich
Waren die Ehegatten Inhaber eines Oder-Konto, über das sie jeweils einzeln verfügen konnten, besteht nach dem BGH
eine Ausgleichspflicht, wenn ein Ehegatte nach der Trennung mehr als die Hälfte des Guthabens für sich verwendet hat. Die Ehegatten als Inhaber des Oder-Kontos sind Gesamtgläubiger im Sinne des § 428 mit der Folge, dass nach § 430 ein Ausgleichsanspruch hinsichtlich der Hälfte besteht.
Hinweis
Bei Oder-Konten kommt es weder auf die Herkunft der Mittel an, noch darauf, aus welchen Gründen das Gemeinschaftskonto überhaupt errichtet worden ist. Gerade bei Ehegatten sind viele Motive denkbar, die einem außen stehenden Dritten unbekannt bleiben. Auch sind nicht die Fälle selten, in denen lediglich die Absicht verfolgt wird, für den Fall der Verhinderung oder des Todes des einen Ehegatten dem anderen die Legitimation zu erleichtern. Im Prozess braucht der Ehegatte daher nur darlegen, dass dem anderen Ehegatten mehr zugeflossen ist, als seinem hälftigen Anteil entspricht. Sache des in Anspruch Genommenen ist es dann, eine Gestaltung des Innenverhältnisses darzulegen und notfalls zu beweisen, die eine andere als die vom Gesetz vermutete hälftige Beteiligung oder einen Ausschluss der Ausgleichspflicht ergibt.
Ist ein Ehegatte Inhaber eines Einzelkontos ist er alleiniger Gläubiger einer Guthabensforderung gegenüber der Bank und damit Berechtigter im Außenverhältnis. Ihm steht im Regelfall das Guthaben auch im Innenverhältnis der Ehegatten alleine zu.
g) Unbenannte Zuwendungen
Unentgeltliche Zuwendungen unter Ehegatten kommen vor allem in Form der Übertragung von Vermögensgegenständen in Betracht. In bestimmten Fällen werden diese Zuwendungen nach der Rechtsprechung des BGH
mangels „Unentgeltlichkeit“ i.S.d. §§ 516 ff. nicht als Schenkungen, sondern als unbenannte Zuwendungen behandelt.
Unbenannte Zuwendungen unter Ehegatten werden nicht „unentgeltlich“ i.S.d. §§ 516 ff. erbracht, weil sie nach der übereinstimmenden Vorstellung der Ehegatten um der Ehe willen und als Beitrag zur Verwirklichung oder Ausgestaltung bzw. zur Erhaltung oder Sicherung der ehelichen Lebensgemeinschaft erbracht werden und darin ihre Geschäftsgrundlage haben. Eine Rückforderung nach Bereicherungsrecht scheidet aus, weil der Bewirkung der Zuwendung ein familienrechtlicher Vertrag zugrunde liegt, der mit dem Scheitern der Ehe nicht rückwirkend weggefallen ist. Aus diesem Grund ist die Zuwendung mit Rechtsgrund bewirkt worden. Ein Ausgleichsanspruch nach den Grundsätzen über den Wegfall der Geschäftsgrundlage kommt in der Regel nur bei Gütertrennung der Ehegatten in Betracht, da die Vorschriften über den Ausgleich des Zugewinns als Sonderbestimmungen den allgemeinen schuldrechtlichen Regeln, insbesondere über den Wegfall der Geschäftsgrundlage, vorgehen.
Ein Rückgriff auf die Grundsätze des Wegfalls der Geschäftsgrundlage ist im Rahmen der Zugewinngemeinschaft auf extreme Ausnahmefälle beschränkt und kommt im allgemeinen nur dort in Betracht, wo die güterrechtlichen Ausgleichsregelungen nicht ausreichen, um schlechthin unangemessene und untragbare Ergebnisse zu vermeiden. Die Grenze der Unangemessenheit und Untragbarkeit wird nicht überschritten, solange der Zuwender einen Ausgleich in Höhe des halben Wertes der Zuwendung erhält. Aber auch wenn sein Ausgleichsanspruch dahinter zurückbleibt, ist eine Korrektur nicht ohne weiteres geboten. In gewissen Abweichungen von der hälftigen Beteiligung verwirklicht sich ein noch normal zu nennendes Risiko, wie es im Zugewinnausgleich angelegt ist und vor dem auch der Ehegatte, der die Zuwendung gemacht hat, nicht völlig bewahrt bleiben kann. Um die Unabweisbarkeit einer Korrektur durch die Anwendung von § 242 zu begründen, müssen weitere Gründe hinzutreten, die den Rückgriff auf die verdrängten Regeln über den Wegfall der Geschäftsgrundlage unter Berücksichtigung der übrigen konkreten Umstände des Einzelfalles zwingend gebieten. Derartige Gründe kommen in Betracht, wenn der Zuwendungsempfänger keinen Zugewinn aufzuweisen hat, weil die Zuwendung der Erhaltung des Anfangsvermögens gedient hat und dadurch eine Zugewinnausgleichsverpflichtung nicht entstanden ist. Gleiches gilt, wenn der Zuwendende in seinem Auskommen beeinträchtigt ist, weil er mit den ihm verbliebenen Mitteln seinen angemessenen Unterhalt nicht bestreiten kann (Notbedarfsfall).
Beispiel
Beide Ehegatten haben keinen Zugewinn erzielt. Der Ehemann hat der Ehefrau während der Ehe 40 000 € geschenkt. In diesem Fall kann er die 40 000 € nach den Grundsätzen über den Wegfall der Geschäftsgrundlage zurückverlangen. Das führt dazu, dass der Anspruch auf Rückzahlung im Aktivvermögen seines Zugewinns zu berücksichtigen ist. Seine Ehefrau erhält im Rahmen des Zugewinnausgleichs davon 20 000 € wieder zurück.
Ein Ausnahmefall, in dem eine Ausgleichung nach den Grundsätzen über den Wegfall der Geschäftsgrundlage verlangt werden kann, ist in der Rechtsprechung
auch dann angenommen worden, wenn neben dem finanziellen Interesse des Zuwendenden an einem wertmäßigen Ausgleich besondere Umstände hinzutraten, die ein schutzwürdiges Interesse an der Rückübertragung des Eigentums an dem zugewendeten Vermögensgegenstand begründeten.
Für Streitigkeiten der Ehegatten, die unbenannte Zuwendungen betreffen, sind nach §§ 23a, 23b GVG, §§ 111 Nr. 10, 266 Abs. 1 Nr. 3 FamFG die Familiengerichte zuständig, da es sich um eine sonstige Familiensache handelt.
Hinweis
Zuwendungen der Eltern, die um der Ehe ihres Kindes willen an das Schwiegerkind erfolgen, sind nach der neueren Rechtsprechung des BGH
nicht als unbenannte Zuwendungen, sondern als Schenkung zu qualifizieren, auf die die Grundsätze des Wegfalls der Geschäftsgrundlage anzuwenden sind. Geschäftsgrundlage muss dabei die für das Schwiegerkind erkennbare Erwartung sein, dass die Ehe Bestand haben werde, in deren Rahmen die Schenkung seinem Ehegatten auf Dauer zu Gute kommt. Diese Geschäftsgrundlage entfällt mit dem Auszug dieses Ehegatten aus dem im Alleineigentum des anderen stehenden Hauses und der Ehescheidung. Da schwiegerelterliche Schenkungen unter § 1374 Abs. 2 fallen, sind sie nicht nur im Endvermögen, sondern auch im Anfangsvermögen zu berücksichtigen und wirken sich daher im Zugewinnausgleich nicht aus. Rückforderungsansprüche der Schwiegereltern nach den Grundsätzen des Wegfalls der Geschäftsgrundlage können daher nicht mit der Begründung verneint werden, dass das beschenkte Schwiegerkind mit dem eigenen Kind der Schwiegereltern in gesetzlichem Güterstand gelebt hat und das eigene Kind über den Zugewinnausgleich teilweise von der Schenkung profitiert. Daneben kommen nach dem BGH auch Ansprüche nach § 812 Abs. 1 Alt. 2 in Betracht. Dafür ist eine Zweckvereinbarung erforderlich, wobei eine positive Kenntnis von der Zweckvorstellung des anderen Teiles notwendig ist, ein bloßes „Kennenmüssen“ genügt nicht.
Ausgleichsansprüche zwischen Eheleuten neben dem Zugewinn
(6)
Neben dem Zugewinnausgleichsanspruch, oder falls dieser durch Ehevertrag ausgeschlossen worden ist, wird familiengerichtlich auch häufig die Frage diskutiert, ob ein Ehegatte (häufig die Ehefrau), der im Betrieb des anderen Ehegatten mitgearbeitet hat, einen Ausgleichsanspruch hat, wenn der andere Ehegatte durch die Mitarbeit Vermögen geschaffen hat. Ähnliches gilt bei nichtehelichen Lebensgemeinschaften oder wenn nicht in einem Unternehmen mitgearbeitet wird, sondern beispielsweise gemeinsam ein Haus oder sonstiges Vermögen angeschafft wird.
Fraglich ist dann, inwieweit ein Ehegatte, der im Betrieb des anderen Ehegatten mitgearbeitet hat, Ausgleichsansprüche neben den familienrechtlichen Ansprüchen hat und auch Ansprüche aus den gesetzlichen Regelungen zur BGB-Gesellschaft, den Grundsätzen des Wegfalls der Geschäftsgrundlage oder aus ungerechtfertigter Bereicherung geltend machen kann.
Unterscheidung zwischen den Ansprüchen
Sind Ehepartner für den Betrieb des anderen Ehegatten tätig, so kann dies entweder auf vertraglicher Grundlage oder aufgrund besonderer Absprache erfolgen. Regelmäßig liegen schon aus steuerrechtlichen Erwägungen Arbeitsverträge vor. Gelegentlich werden auch gesellschaftsrechtliche Vereinbarungen getroffen, die dann vorrangig für spätere Auseinandersetzungen gelten. In aller Regel handelt es sich im Rahmen von gesellschaftsrechtlichen Vereinbarungen um die Einräumung von Minderheitsbeteiligungen an der Firma des jeweils anderen Ehegatten. Häufig gibt es jedoch auf gar keine schriftliche oder mündliche Vereinbarung zwischen den Ehegatten. Entsprechend dieser unterschiedlichen rechtlichen Bewertungsgrundlagen ist für das Bestehen von Ausgleichsansprüchen zu differenzieren.
Fehlen vertragliche Regelungen, erfolgte jedoch die Mitwirkung eines Ehegatten durch Arbeitsleistung, so können Ausgleichsansprüche nach dem Scheitern der Ehe aus unterschiedlichen Gründen entstehen. Besteht allerdings eine vertragliche Vereinbarung, ist fraglich, ob darüber hinaus noch Ansprüche in Betracht kommen.
§ 2057 BGB stellt einen Auskunftsanspruch unter den jeweiligen Miterben dar. Danach ist nach § 2057 Abs. 1 BGB jeder Miterbe verpflichtet, den übrigen Erben auf Verlangen Auskunft über die Zuwendungen zu erteilen, die er nach den §§ 2050 bis 2053 BGB zur Ausgleichung zu bringen hat. Voraussetzung für dieses Recht auf Auskunft über § 2057 BGB ist dabei, dass sowohl der Miterbe, der die Auskunft verlangt, als auch derjenige von dem er diese fordert, zu den Abkömmlingen bzw. den Ersatzerben zählt, die über die §§ 2050 bis 2053 BGB ausgleichungspflichtig- und berechtigt sein können.
Nach § 2050 Abs. 1 BGB sind Abkömmlinge, die über das gesetzliche Erbe zur Erbschaft gelangen, verpflichtet, das was sie vom Erblasser zu dessen Lebzeiten als Ausstattung erhalten haben, bei der Auseinandersetzung untereinander zum Ausgleich zu bringen, es sei denn, der Erblasser hat bei der Zuwendung etwas anderes bestimmt.
Zur Ausgleichung dabei zu bringen sind grundsätzlich Ausstattungen, Zuschüsse oder Aufwendungen für die Vorbildung zu einem Beruf sowie gegebenenfalls andere Zuwendungen nach § 2050 Abs. 3 BGB und somit auch gelegentliche Geschenke.
Eine besondere Form der Auskunft nach § 2057 BGB ist hierbei nicht vorgesehen. Wie bei § 2028 BGB kann der Auskunftspflichtige jedoch zur Abgabe einer eidesstattlichen Versicherung angehalten werden.
§ 2027 BGB
Auskunftsberechtigter nach § 2027 BGB ist derjenige, dem ein Erbschaftsanspruch zusteht, also der wahre Erbe.
Weitere Anspruchsinhaber können bspw. der Testamentsvollstrecker, der Nachlassinsolvenzverwalter und der Nachlassverwalter sein.
Nach § 2018 BGB ist der Erbschaftsbesitzer verpflichtet, die Erbschaft als Ganzes herauszugeben. Über § 2027 BGB ist er jedoch auch zur Auskunft darüber verpflichtet, wo die Erbschaftsgegenstände verblieben sind.
Dazu hat der Erbschaftsbesitzer nach § 260 BGB Gegenstände, die nicht mehr auffindbar sind oder nicht mehr vorhanden sind, in einem Verzeichnis vorzulegen. Dies kann unter Umständen dazu führen, dass der Erbschaftsbesitzer dazu verpflichtet ist, Rechenschaft über die Nachlassverwaltung zu schulden.
, § 2028 BGB
Grundgedanke des § 2028 BGB ist, dass die Personen, die mit dem Erblasser in häuslicher Gemeinschaft lebten, einen Überblick über den Verbleib von Nachlassgegenständen haben. Daher soll der Auskunftsanspruch nach § 2028 BGB gegenüber dem Hausgenossen dazu dienen, dem Auskunftsberechtigten einen Überblick über den Nachlass verschaffen zu können. Die Auskunftsverpflichtung der „häuslichen Gemeinschaft“ aus § 2028 BGB wird von der Rechtsprechung weit aufgefasst. Es setzt weder eine „Zugehörigkeit zum Hausstand“ noch „Familienzugehörigkeit“ voraus. Nach der Auffassung der Rechtsprechung ist derjenige nach § 2028 BGB auskunftsverpflichtet, der zur Zeit des Erbfalls aufgrund seiner räumlichen und persönlichen Beziehung zum Erblasser die Möglichkeit dazu hatte, sich Kenntnis vom Aufenthalt der Erbschaftsgegenstände zu verschaffen.
Im Unterschied zu § 2027 BGB ist der Hausgenosse nach § 2028 BGB jedoch nicht verpflichtet ein Verzeichnis über den Verbleib der Nachlassgegenstände vorzulegen.
Die Auskunft über § 2028 BGB ist aber nicht nur auf körperliche Gegenstände beschränkt. Auch Nachlassforderungen sind Gegenstand der Auskunftspflicht. Ebenfalls umfasst von dem Anspruch sind Gegenstände, die schon zu Lebzeiten des Erblassers aus dessen Vermögen, rechtlich einwandfrei, ausgeschieden sind (z.B. bei wirksamen Schenkungen an den Hausgenossen).
Nach § 2028 Abs. 2 BGB kann auch die Abgabe einer eidesstattlichen Versicherung des Hausgenossen verlangt werden, wenn bei der Auskunft Grund zu der Annahme besteht, dass der Hausgenosse diese nicht mit der erforderlichen Sorgfalt ausgeführt hat. Hierbei muss der Erbe aber Umstände vorbringen, aus denen sich ergibt, dass die Auskunft unrichtig oder unsorgfältig wegen mangelnder Sorgfalt des Auskunftsverpflichteten erteilt wurde.
Normen, aufgrund derer ein Miterbe Auskunft über den Nachlass verlangen kann sind im BGB vielfach enthalten. Zwischen diesen Auskunftspflichten bestehen jedoch jeweils einige Differenzierungen bezüglich Schutzwirkung und Reichweite der Pflichten.
Einen Anspruch auf Auskunft ohne konkrete gesetzliche Grundlage durchzusetzen stellt sich dabei als schwierig dar. Eine solche Möglichkeit bietet sich nur über den Grundsatz von Treu und Glauben aus § 242 BGB.
Welche konkreten Auskunftsansprüche über den Nachlass das BGB normiert und welche Reichweite diesen zukommt soll im Folgenden erörtert werden.
I. Auskunftsrechte in einer Erbengemeinschaft
Dadurch, dass der [[Miterbe]] grundsätzlich durch seine Stellung als Erbe persönlich sich Informationen über den Wert und Bestand des Nachlasses verschaffen kann, sind bei diesem nur ergänzende Auskunftsrechte in den §§ 2027, 2028 und 2057 BGB enthalten, die sein Interesse an der Richtigkeit der Berechnung seines Erbteils befriedigen sollen.
So kann nach § 2027 BGB der Erbe vom [[Erbschaftsbesitzer]] Auskunft über den Bestand und Verbleib der Erbschaftsgegenstände verlangen. Ebenso kann dies von demjenigen verlangt werden, der, bevor der Erbe einen Nachlassgegenstand in Besitz genommen hat, diesen genommen hat.
Über § 2028 BGB kann der Erbe von demjenigen, der zur Zeit des Erbfalls mit dem Erblasser in häuslicher Gemeinschaft lebte, Auskunft darüber verlangen, welche Geschäfte er getätigt hat, die den Nachlass betreffen und was ihm über den Verbleib der Erbschaftsgegenstände bekannt ist.
1. [[Auskunftspflicht des Erbschaftsbesitzers]]
2. [[Auskunftspflicht des Hausgenossen]]
3. [[Auskunftsanspruch aus § 2057 BGB]]
II. Auskunftsrechte der Pflichtteilsberechtigten
1. Auskunftsanspruch des pflichtteilsberechtigten Nichterben
Der Auskunftsanspruch eines pflichtteilsberechtigten Nichterben ergibt sich aus § 2314 BGB. Danach hat der Erbe dem Pflichtteilsberechtigten der nicht Erbe ist, auf Verlangen Auskunft über den Bestand des Nachlasses zu erteilen. Auskunftsberechtigt nach § 2314 BGB kann aber auch ein Miterbe sein, der seine Erbschaft nach § 2306 Abs. 1 BGB ausschlägt und so den Status eines pflichtteilsberechtigten Nichterben erlangt.
Der auskunftsverpflichtete Erbe muss nach § 2314 BGB über den gesamten Bestand des Nachlasses Auskunft geben. Dies bedeutet, dass er auch das Wissen weitergeben muss das er hat oder das er sich beschaffen kann.
Zum Bestand des Nachlasses gehören dabei neben den Nachlassverbindlichkeiten auch die Zuwendungen des Erblassers nach den §§ 2050 ff. BGB, die bei der Pflichtteilsberechnung nach § 2016 BGB auszugleichen sind.
Wichtig für die Pflichtteilsberechnung ist dabei auch die Auskunft über Schenkungen des Erblassers an Dritte. Bezüglich eines Nachweises solcher Schenkungen wird vom Pflichtteilsberechtigen gefordert, dass er gegenüber dem Erben darlegt, dass Schenkungen des Erblassers naheliegend sind.
2. Auskunftsanspruch des pflichtteilsberechtigten Miterben
Fraglich ist, ob dem pflichtteilsberechtigten Miterben ebenfalls der Auskunftsanspruch aus § 2314 BGB zusteht, da sich der Miterbe aufgrund seiner Stellung als Erbe selbst die notwendigen Informationen verschaffen kann. In der Literatur und der Rechtsprechung wird dem Miterben ebenfalls ein Auskunftsanspruch nach § 2314 BGB zugebilligt. Anerkannt ist dies jedoch nur für Fälle, in denen der Erblasser zu seinen Lebzeiten Zuwendungen an einen Miterben getätigt hat, an einen nicht als Erben eingesetzten Dritten oder wenn er ausgleichspflichtig Zuwendungen an den pflichtteilsberechtigten Nichterben erbracht hat.
Die Rechtsprechung lässt diesen Anspruch des pflichtteilsberechtigten Miterben dabei nicht direkt oder analog nach § 2314 BGB zu, sondern über den allgemeinen Auskunftsanspruch nach § 242 BGB.
III. Allgemeines Auskunftsrecht nach § 242 BGB
Beim allgemeinen Auskunftsanspruch nach § 242 BGB muss der Berechtigte dieses Anspruches darlegen, dass zwischen den Parteien eine Sonderrechtbeziehung vorliegt. Anzeichen für die Annahme einer Sonderrechtsbeziehung ist dabei, wenn gewissen Anhaltspunkte für eine unentgeltliche Verfügung vorliegen. Des Weiteren muss der Berechtigte des Anspruches entschuldbar im Unklaren über das Bestehen sein und daher auf die Auskunft durch den Verpflichteten angewiesen sein. Als letzte Voraussetzung muss der Auskunftspflichtige die Auskunft unschwer erteilen können.
IV. Rechte des pflichtteilsberechtigten Vertragserben
Dem pflichtteilsberechtigten Vertragserben steht unmittelbar kein Auskunftsanspruch zu. Nach § 2287 Abs. 1 BGB kann er aber, nachdem die Erbschaft angefallen ist, in dem Fall, dass der Erblasser eine Schenkung getätigt hat in der Absicht, den Vertragserben zu beeinträchtigen, von dem Beschenkten die Herausgabe des Geschenkes nach den Vorschriften über eine ungerechtfertigte Bereicherung verlangen.
Der Vertragserbe hat dafür ein gesteigertes Interesse im Wege der Durchsetzung des § 2287 Abs. 1 BGB Auskunft zu erlangen, welche Schenkungen im Sinne des § 2287 BGB erfolgt sind. In Folge dessen gesteht die Rechtsprechung diesem ebenfalls einen Auskunftsanspruch über § 242 BGB zu.
Problematisch für den Vertragserben stellt sich nur dar, dass er etwaige Schenkungen meistens nicht nachweisen kann.
* [[Auslegungsmethoden]]
* [[Auslegung von Willlenserklärungen]]
* [[Auslegung nach Wortlaut]]
* [[Systematische Auslegung]]
* [[Historische Auslegung]]
* [[Teleologische Auslegung]]
''Argumentationsformen''
* [[extensive und restriktive Auslegung]]
* [[Analogie]]
* [[Umkehrschluss]]
* [[Teleologische Reduktion]]
* [[argumentum a majore ad minus]]
* [[Ausfüllen einer Gesetzeslücke]]
Abhängig von der Finanzierungsform kann ein Unfall erhebliche Folgen haben – oder gar keine. Beim normalen Ratenkredit, den Sie bei einer Bank abschließen, laufen die Zahlungen einfach weiter. Dabei spielt es keine Rolle, ob das Auto nur eine Schramme hat oder Sie es verschrotten mussten. Sie zahlen also im Extremfall für etwas, das Sie schon nicht mehr besitzen. Der Bank ist das egal.
Etwas komplizierter ist es beim Autokredit. Auch diesen müssen Sie in jedem Fall weiter bedienen.
Diese Kreditform ist jedoch zweckgebunden und der Fahrzeugbrief in der Regel bei der Bank als Sicherheit hinterlegt. Bei einem Totalschaden haben Sie daher ein Problem.
Denn um den Wagen abzumelden, benötigen Sie den Fahrzeugbrief. Um diesen zu bekommen, müssen Sie der Bank einen Ersatz bieten. In der Regel verfährt man so, dass ein ungefähr gleichwertiges Fahrzeug, etwa das des Ehepartners oder der Eltern, als Sicherheit dient. Dessen Fahrzeugbrief wird jetzt bei der Bank hinterlegt. Die Bank schickt ihrerseits den alten Fahrzeugbrief mit einem entsprechenden Vermerk direkt ans Verkehrsamt, wo Sie das Fahrzeug abmelden. Danach zahlen Sie den Kredit weiter ab.
Bei einem Ballonkredit oder der Drei-Wege-Finanzierung bleibt am Ende der Kreditphase noch eine hohe Schlussrate. Wenn Sie diese nicht begleichen können oder wollen, müssen Sie das Auto zurückgeben oder verkaufen. Auf die Wertminderung durch einen Unfall wurde bereits hingewiesen. Hier haben Sie also ein Problem. Ja nachdem, wie lange der Kredit noch läuft und wie hoch die vereinbarte Schlussrate ist, können hier erhebliche Kosten auf Sie zukommen, je nachdem wie groß die Differenz zwischen Schlussrate und dem Restwert des Autos ist. Unter Umständen erklärt sich die Bank bereit, den bestehenden Vertrag aufzulösen und durch einen Ratenkredit zu ersetzen. Eventuell fahren Sie damit günstiger.
Unfallregulierung bei Beschädigung eines finanzierten oder geleasten Kfz
Immer wieder stellt sich die Frage, wer eigentlich genau Anspruchsinhaber ist – Eigentümer oder Halter. Hier muss beachtet werden, dass sowohl der Eigentümer als auch der Halter und der Versicherungsnehmer drei verschiedene Personen sein können. Der Eigentümer muss nicht zwangsläufig der Halter oder/und der Versicherungsnehmer sein und umgekehrt.
Anspruchsinhaber ist immer nur der Eigentümer. Eigentümer ist derjenige, der im Kaufvertrag steht. Nur derjenige, der im Kaufvertrag steht, kann im Fall der Fälle Klage gegen die Versicherung erheben, sollte diese nicht oder nicht vollständig regulieren. Der Halter steht zwar in der Zulassung, ist mangels der Eigentümerstellung jedoch nicht in seinen Rechten verletzt, wenn das Fahrzeug einen Schaden erlitten hat.
Hier herunterladen: Checkliste Abrechnung von Sachschäden
Tipp: Hier Gratis-Download anfordern
Nutzen Sie auch unsere „Checkliste: Abrechnung von Sachschäden“, um Ihre lückenlose Schadensbegründung gegenüber der Versicherung zu erstellen – praktische Hilfe für die Unfallregulierung.
Hier klicken und Checkliste gratis anfordern!
Unfallregulierung beim finanzierten Kfz
Wurde das Fahrzeug finanziert, ist grundsätzlich derjenige, der im Kaufvertrag steht der Eigentümer und damit Anspruchsinhaber. Denn das Eigentum wurde lediglich zu Sicherungszwecken an die Bank sicherungsübereignet. Das bedeutet, dass die Bank das Fahrzeug veräußern kann, wenn der Finanzierungsvertrag nicht bedient wird.
Sie wird aber in aller Regel keine Rechte aus einem Verkehrsunfall herleiten. Das gilt jedoch nicht grundsätzlich. Um die Frage im Einzelfall zutreffend zu beantworten, muss man sich die Finanzierungsbedingungen genau ansehen. Dort findet sich die Ermächtigung des Eigentümers den Anspruch im eigenen Namen geltend machen zu können.
Doch auch hier gibt es Ausnahmen. So muss, wenn das Fahrzeug z.B. über die BMW Bank finanziert wurde, dort immer der Schaden gemeldet und eine Freigabeerklärung eingeholt werden. Die BMW Bank unterscheidet streng nach der Höhe des Schadens. So darf der Reparaturschaden nur dann an den Eigentümer ausgezahlt werden, wenn dieser unter 2.000,00 € liegt. Alle höheren Schäden lässt sich die BMW Bank auszahlen und verrechnet diese mit dem Kreditbetrag, wenn der Geschädigte nicht reparieren lässt. Liegt der Schaden über 2.000,00 € und der Geschädigte lässt in einer Werkstatt auf Rechnung reparieren, erklärt sich die Bank mit der Auszahlung an die Werkstatt einverstanden. Die Wertminderung lässt sich die BMW Bank in jedem Fall ausbezahlen.
Unfallregulierung bei Leasing
Ähnlich ist es, wenn das Fahrzeug geleast ist. Der Unterschied ist hierbei, dass der Leasinggeber, in aller Regel das Autohaus, auch der Eigentümer ist und der Leasingnehmer, der Nutzer des Fahrzeugs, nie Ansprüche in eigenem Namen geltend machen kann. Hier muss immer der Leasinggeber eine Ermächtigung erteilen, damit der geschädigte Leasingnehmer die Ansprüche außergerichtlich und ggf. auch gerichtlich geltend machen kann.
Der Umstand, dass ein Fahrzeug geleast ist, hat auch Auswirkungen auf die Frage, wem welche Schadenposition zusteht.
Während der Fahrzeugschaden (Reparaturkosten und Wertminderung) immer dem Leasinggeber zustehen, werden die Kostenpauschale und der Nutzungsausfall an den Leasingnehmer ausgezahlt.
Nadja Wollangk, Rechtsanwältin & Fachanwältin für Verkehrsrecht in Berlin
Verkehrsunfall mit Finanzierung/ Leasing-Fahrzeug
Wenn Ihr Fahrzeug zum Unfallzeitpunkt finanziert oder geleast ist, sind einige Besonderheiten bei der Schadensregulierung zu beachten:
Finanziertes Fahrzeug
Wenn eine Sache beschädigt wird, erhält nach deutschem Recht derjenige Schadenersatz, der auch Eigentümer der Sache ist.
Eigentümer eines finanzierten Fahrzeugs ist in der Regel die darlehensgebende Bank, da das Fahrzeug dieser laut den allgemeinen Vertragsbedingungen als (Sicherungs-) Eigentum abgetreten wird, bis die letzte Finanzierungsrate bezahlt ist.
Der Finanzierungsvertrag enthält genaue Vorgaben dazu, wie Sie sich im Schadenfall zu verhalten haben. Grundsätzlich wird immer gefordert, dass der Unfall sofort an die Bank gemeldet wird. In der Regel ist man laut den Vertragsbedingungen aber dazu ermächtigt, den Schaden gegenüber der gegnerischen Versicherung selbst geltend zu machen. Andernfalls muss die Ermächtigung schriftlich von der Bank eingeholt werden.
In der Regel sind Sie auch vertraglich verpflichtet, den Schaden an dem Fahrzeug vollständig und fachgerecht reparieren zu lassen, sodass eine fiktive Abrechnung auf Gutachtenbasis oft ausscheidet. Die Reparaturkosten müssen dann vollumfänglich in die Reparatur investiert werden.
Sollte eine fiktive Abrechnung vertraglich möglich sein, verlangt die Bank die Auszahlung des Schadenbetrags an sich selbst. Nach dem Reparaturnachweis muss die Bank aber anschließend für die Reparaturkosten aufkommen.
Eine möglicherweise anfallende Wertminderung steht ebenfalls der Bank zu, muss aber auf den Restfinanzierungsbetrag angerechnet werden. In der Regel haben Sie hier die Möglichkeit zwischen der Anrechnung auf die Finanzierungsrate, oder auf die Restlaufzeit des Darlehensvertrages. Was günstiger ist, muss in jedem Einzelfall individuell berechnet werden.
Die Kostenpauschale, eine etwaige Nutzungsausfallentschädigung und das Schmerzensgeld stehen jedoch auch in diesem Fall Ihnen persönlich zu, da hinsichtlich dieser Positionen Sie als Person der tatsächlich Geschädigte sind. Die Unfallregulierung bei finanzierten Fahrzeugen birgt viele rechtliche Besonderheiten und sollte daher erfahrenen Experten überlassen werden. Hier setzen wir uns für Sie als Verkehrsrechtsexperten ein und übernehmen alle notwendigen Schritte, um Ihr Recht durchzusetzen. Darüber hinaus nehmen wir für Sie Kontakt mit Ihrer Bank auf und klären alles Notwendige für die Schadensregulierung mit der gegnerischen Versicherung. Sie müssen sich um nichts mehr kümmern und können sich entspannt zurücklehnen.
Leasingfahrzeug
Bei einem Leasingfahrzeug verhält es sich sehr ähnlich. Hier bleibt der Eigentümer des Fahrzeugs stets die Leasinggesellschaft (Leasinggeber):
Die Leasing-Gesellschaft sollte über den Unfall sofort benachrichtigt werden. Auch der Leasingvertrag enthält genaue Vorgaben dazu, wie Sie sich im Schadenfall zu verhalten haben. Hinsichtlich der Schadensregulierung kann vereinbart sein, dass Sie den Schaden selbst gegenüber der Versicherung geltend machen dürfen. Andernfalls muss eine Ermächtigung von der Leasinggesellschaft eingeholt werden.
Fast immer besteht laut den AGB des Leasingvertrags die Verpflichtung, sämtliche Schäden am Leasingfahrzeug vollständig und fachgerecht reparieren zu lassen, sodass eine Abrechnung auf Gutachtenbasis (fiktive Abrechnung) regelmäßig nicht möglich ist.
Ebenso steht eine etwaig anfallende Wertminderung ausschließlich der Leasinggesellschaft zu. Diese ist allerdings bei der Rückgabe des Fahrzeugs zu berücksichtigen. Die Kostenpauschale, eine etwaige Nutzungsausfallentschädigung und das Schmerzensgeld stehen auch bei einem Leasingfahrzeug Ihnen persönlich zu.
Ohne das rechtliche Know-How kommt ein Laie hier nicht weiter. Mit unserem Wissen und unserer Rechtsexpertise verhelfen wir Unfallgeschädigten zu ihrem Recht und nehmen ihnen dafür gerne jede Mühe ab.
{{ Tiddlers by Tag }}
While this works, it would be nicer if we didn't "hard code" the button label, tag to match and the prefix to be added. To do this we can move the ``<$button>`` definition into a macro, and then invoke the macro, passing in the desired values, like this:
``\define newTitle(prefix) $prefix$$(currentTiddler)$
\define addPrefix(label,tag,prefix)
<$button>
$label$
<$list filter="[tag[$tag$]]">
<$action-setfield $tiddler=<<currentTiddler>> title=<<newTitle "$prefix$">> />
<$action-deletetiddler $tiddler=<<currentTiddler>> />
</$list>
</$button>
\end
<<addPrefix "Clickme" "sometag" "SomePrefix">>``
\define bm-addtofilter(tooltip, class)
<$button class="tc-btn-invisible bm-btn-addtofilter $class$"
tooltip="""$tooltip$""">
$(label)$⤴
<$action-setfield $tiddler=batchmanipulator
bm-filter-previous={{batchmanipulator!!bm-filter}} />
<$action-listops $tiddler="batchmanipulator" $field="bm-filter"
$subfilter="""[enlist<fieldselection>]""" />
</$button>
\end
\define concat() $(append2me)$ -[[$(tid)$]]
\define bm-removefromfilter()
<$vars append2me={{batchmanipulator!!bm-filter}} >
<$button class="tc-btn-invisible bm-btn-addtofilter bm-fontsmall bm-btn-tooltip bm-center">
{{$:/core/images/close-button}}
<div class="bm-tooltip">Remove from list</div>
<$action-setfield $tiddler=batchmanipulator
bm-filter-previous={{batchmanipulator!!bm-filter}} />
<$action-setfield $tiddler=batchmanipulator
bm-filter=<<concat>> />
</$button>
</$vars>
\end
\define addremove-btn(field, val, list)
<$set name=list value="""$list$""">
<$set name=addremove-this filter="""[[batchmanipulator]bm-field[tag]]"""
value="""$val$""" emptyValue="""$field$""">
<$vars field="""$field$""">
<$button class="bm-btn bm-btn-$(add-or-remove)$ tc-btn-invisible bm-btn-tooltip" >
<div class="bm-tooltip">$(add-or-remove)$ $field$ : $val$</div>
<$list filter="""[enlist<list>]""">
<$fieldmangler>
<$action-sendmessage
$message="tm-$(add-or-remove)$-$(tag-or-field)$"
$param=<<addremove-this>>
/>
<$macrocall $name="$(add-or-remove)$-$(tag-or-field)$" val="""$val$"""/>
</$fieldmangler>
</$list>
</$button>
</$vars>
</$set>
</$set>
<br>
\end
\define addremove-field-all(field, val)
<$wikify name=field text="$field$" >
<$wikify name=val text="""$val$""" >
<$set name=add-or-remove
filter="""[enlist<thetids>!$field$<val>] [enlist<thetids>is[missing]]"""
value=add emptyValue=remove >
<$macrocall $name=addremove-btn
field=<<field>>
val=<<val>>
list=<<thetids>>
/>
</$set>
</$wikify>
</$wikify>
\end
\define addremove-tag-single()
<$set name=add-or-remove filter="""[[$(tid)$]!tag[$(val)$]] [[$(tid)$]is[missing]]"""
value=add emptyValue=remove >
<$set name=t filter="""[[$(tid)$]]""">
<$macrocall $name=addremove-btn
field=tag
val=<<val>>
list=<<t>> />
</$set>
</$set>
\end
\define addremove-field-single()
<$list filter="""[[$(tid)$]!$(thefield)$[$(val)$]] [[$(tid)$]is[missing]!is[shadow]]""">
<$button class="bm-btn bm-btn-add tc-btn-invisible bm-btn-tooltip">
<div class="bm-tooltip">Set $(thefield)$ to $(val)$ (currently:
<$transclude tiddler=<<tid>> field=<<thefield>> />)
</div>
<$action-setfield $tiddler="""$(tid)$""" $(thefield)$="""$(val)$""" />
</$button>
</$list>
<$list filter="""[[$(tid)$]$(thefield)$[$(val)$]]""">
<$button class="bm-btn bm-btn-remove tc-btn-invisible bm-btn-tooltip">
<div class="bm-tooltip">Keep the field ($(thefield)$) but remove value $(val)$
</div>
<$action-setfield $tiddler="""$(tid)$""" $(thefield)$="" />
</$button>
</$list>
\end
\define delete-tid-btn()
<$button class="tc-btn-invisible bm-btn bm-fontsmall" tooltip="Delete this tiddler">
<$action-deletetiddler $tiddler="""$(tid)$"""/>
{{$:/core/images/delete-button}}
</$button>
\end
\define bm-relations-table-row()
<tr>
<td style="text-align:center">
<$list filter="""[[$(tid)$]is[tiddler]]"""><<delete-tid-btn>></$list>
</td>
<td style="padding:0"><<bm-removefromfilter>></td>
<td class="peek-hover">
<$link to="""$(tid)$""">$(tid)$</$link>
<div class="peek"><$transclude tiddler=<<tid>>/></div>
<$set name=label filter="""[tag<tid>count[]]""">
<$wikify name=fieldselection text="""[tag[<<tid>>]]""">
<$macrocall $name=bm-addtofilter
tooltip="Add as tag to filter"
class="bm-fontsmall"
/>
</$wikify>
</$set>
</td>
<$list filter="""[[batchmanipulator]bm-field[tag]]""">
<$list filter="""[enlist<thetids>tags[]sort[]reverse[]] [[$(val)$]] +[reverse[]]"""
variable="val">
<td><<addremove-tag-single>></td>
</$list>
</$list>
<$list filter="$(thefield)$ -tag">
<$list filter="""[enlist<thetids>fields[]] -created -creator -modified -modifier -tags -text -title +[sort[]reverse[]] [[$(thefield)$]] +[reverse[]]""" variable="thefield">
<td><<addremove-field-single>></td>
</$list>
</$list>
</tr>
\end
\define delete-all-items(items)
<$button popup=<<qualify "$:/state/batchDelete/$items$">>
tooltip="Delete $items$"
class="tc-btn-invisible">
{{$:/core/images/delete-button}}
</$button>
<$reveal state=<<qualify "$:/state/batchDelete/$items$">>
type="popup" position="belowleft" animate="yes">
<div class="tc-block-dropdown-wrapper foo">
<div class="tc-block-dropdown tc-edit-type-dropdown">
<div class="tc-dropdown-item-plain">
Are you sure you wish to delete all these $items$?
</div>
<div class="tc-dropdown-item-plain">
<$button class="tc-btn">
Delete all these $items$
<$list filter=""" $items$ +[suffix[tiddlers]]""">
<$action-deletetiddler $filter=<<thetids>>/>
</$list>
<$list filter=""" $items$ +[suffix[tags]]""">
<$list filter="""$(thetids)$""">
<$action-setfield $tiddler={{!!title}} tags=""/>
</$list>
</$list>
<$list filter=""" $items$ +[suffix[fields]]""">
<$list filter="""$(thetids)$""" >
<$action-deletefield $(thefield)$ />
</$list>
</$list>
</$button>
</div>
</div>
</div>
</$reveal>
\end
\define bm-dragpill()
<$draggable filter={{batchmanipulator!!bm-filter}} class="bm-drag">ALL</$draggable>
\end
\define head-tags-1(val)
<$list filter="""[enlist<thetids>$(tag-or-field)$s[]] +[sort[]reverse[]] [[$(val)$]] +[reverse[]]""">
<$wikify name=newfilter text="""[tag[{{!!title}}]tags[]tagging[]] $(limit)$""">
<th class="rotate"><div><span>
<$button set="batchmanipulator!!bm-filter"
setTo=<<newfilter>>
class="tc-btn-invisible tc-tiddlylink green-link bm-btn-tooltip">
<$view field="title"/>
<div class="bm-tooltip">Apply relations filter</div>
<$action-setfield $tiddler="$:/batchmanipulator/temp" text=""/>
</$button>
</span></div></th>
</$wikify>
</$list>
\end
\define head-tags-2()
<$list filter="""[enlist<thetids>$(tag-or-field)$s[]] +[sort[]reverse[]] -[[$(val)$]] [[$(val)$]] +[reverse[]]""">
<th><div><span>
<$macrocall $name=addremove-field-all field=tag val="{{!!title}}" />
</span></div>
</th>
</$list>
\end
\define head-fields-1()
<$list filter="""[enlist<thetids>$(tag-or-field)$s[]] -created -creator -modified -modifier -tags -text -title +[sort[]reverse[]] [[$(thefield)$]] +[reverse[]]""">
<$wikify name=newfilter text="""[has[{{!!title}}]get[{{!!title}}]tagging[]] $(limit)$""">
<th class="rotate"><div><span>
<$button set="batchmanipulator!!bm-filter"
setTo=<<newfilter>>
class="tc-btn-invisible tc-tiddlylink green-link bm-btn-tooltip">
<$view field="title"/>
<div class="bm-tooltip">Apply relations filter</div>
<$action-setfield $tiddler="$:/batchmanipulator/temp" text=""/>
</$button>
</span></div>
</th>
</$wikify>
</$list>
\end
\define head-fields-2()
<$list filter="""[enlist<thetids>$(tag-or-field)$s[]] -created -creator -modified -modifier -tags -text -title +[sort[]reverse[]] [[$(thefield)$]] +[reverse[]]""">
<th><div><span>
<$macrocall $name=addremove-field-all field={{!!title}} val="""$(val)$""" />
</span></div>
</th>
</$list>
\end
\define bm-relations-table-head()
<tr style="border-bottom:1px solid silver;">
<td colspan=3 style="text-align:right;">
<$list filter="""[[batchmanipulator]bm-field[tag]]""">
Apply tag to tiddler
</$list>
<$list filter="[[batchmanipulator]bm-display[relations]!bm-field[tag]]">
Set ''$(val)$'' as value for:
</$list>
</td>
<<head-$(tag-or-field)$s-1>>
</tr>
<tr style="border-bottom:2px solid silver ">
<td style="text-align:center;position:relative"><<delete-all-items tiddlers>></td>
<td></td>
<td style="text-align:center;"><<bm-dragpill>></td>
<<head-$(tag-or-field)$s-2>>
</tr>
\end
\define bm-relations-table()
<table class="bm-table bm-relations-table">
<<bm-relations-table-head>>
<$list filter=<<thetids>> variable="tid">
<<bm-relations-table-row>>
</$list>
</table>
\end
\define remove-btn(item)
<$button class="tc-btn-invisible bm-fontsmall " tooltip="Delete field $(thefield)$ and its value">
{{$:/core/images/delete-button}}
<$fieldmangler tiddler=<<tid>>>
<$action-sendmessage
$message=tm-remove-$(tag-or-field)$
$param="""$item$""" />
</$fieldmangler>
</$button>
\end
\define set-or-clear()
<$list filter="""[[$(tq)$]has[$(thefield)$]]""">
<$button tooltip="Set $(thefield)$">
''!''
<$action-setfield $tiddler="""$(tid)$""" $(thefield)$={{$(tq)$!!$(thefield)$}} />
<$action-deletetiddler $tiddler='$(tq)$' />
</$button>
</$list>
<$list filter="""[[$(tid)$]has[$(thefield)$]]""">
<$list filter="""[[$(tq)$]!has[$(thefield)$]]""">
<$button class="bm-btn tc-btn-invisible" tooltip="Clear $(thefield)$">
{{$:/core/images/close-button}}
<$action-setfield $tiddler="""$(tid)$""" $(thefield)$="" />
</$button>
</$list>
</$list>
\end
\define tid-qualify()
temp/bm/<<qualify """$(tid)$""">>
\end
\define bm-singledata-table()
<table class="bm-table">
<tr class="bm-singledata-table-head">
<td style="position:relative;"><<delete-all-items tiddlers>></td>
<td></td>
<td style="text-align:center;"><<bm-dragpill>></td>
<td style="text-align:center;">
<<addremove-field-all "$(thefield)$" """$(val)$""">>
</td>
<td style="position:relative;text-align:center;">
<$list filter="""[enlist<thetids>has:field[$(thefield)$]first[]] [[batchmanipulator]bm-field[tag]]""">
<<delete-all-items "$(tag-or-field)$s">>
</$list>
</td>
<$list filter="[[batchmanipulator]!bm-field[tag]]">
<td style="text-align:center;">,,$(thefield)$,,<br>^^value^^</td>
<td style="text-align:center;">
<$button class="tc-btn-invisible"
tooltip="Clear all $(thefield)$ fields">
{{$:/core/images/close-button}}
<$list filter="""$(thetids)$""">
<$action-setfield $(thefield)$="" />
</$list>
</$button>
</td>
</$list>
</tr>
<$list filter="""$(thetids)$""" variable="tid">
<tr>
<td><<delete-tid-btn>>
</td>
<td style="padding:0"><<bm-removefromfilter>></td>
<td class="peek-hover">
<$link to=<<tid>>><<tid>></$link>
<$set name=label filter="""[tag<tid>count[]]""">
<$wikify name=fieldselection text="[tag[<<tid>>]]">
<$macrocall $name=bm-addtofilter
tooltip="Add as tag to filter"
class="bm-fontsmall"
/>
</$wikify>
</$set>
<div class="peek"><$transclude tiddler=<<tid>>/></div>
</td>
<$list filter="[[batchmanipulator]!bm-field[tag]]">
<td style="white-space:nowrap">
<<addremove-$(tag-or-field)$-single>>
</td>
<td>
<$list filter="""[<tid>has:field[$(thefield)$]]""">
<<remove-btn $(thefield)$>>
</$list>
</td>
<$wikify name=tq text=<<tid-qualify>>>
<td style="padding-right:0; padding:0">
<$set name=placeholder filter="""[<tid>get[$(thefield)$]]""">
<$edit-text tag=input size=8
tiddler=<<tq>> field="$(thefield)$"
placeholder=<<placeholder>>
/>
</$set>
</td>
<td class="bm-fontsmall bm-center">
<<set-or-clear>>
</td>
</$wikify>
</$list>
<$list filter="""[[batchmanipulator]bm-field[tag]]""">
<td style="white-space:nowrap; text-align:center;">
<<addremove-$(tag-or-field)$-single>>
</td>
<td style="padding-top:0px;">
<$set name=tgs value={{{ [<tid>get[tags]] }}}>
<div class="bm-fontsmall">
<$list filter="""[enlist<tgs>]""">
<$checkbox
tiddler=<<tid>>
tag={{!!title}}
/>
<$wikify name=newfilter text="""[tag[{{!!title}}]tags[]tagging[]] $(limit)$""">
<$button set="batchmanipulator!!bm-filter"
setTo=<<newfilter>>
class="tc-btn-invisible tc-tiddlylink green-link bm-btn-tooltip">
<$view field="title"/>
<div class="bm-tooltip">Apply relations filter</div>
<$action-setfield $tiddler="$:/batchmanipulator/temp" text=""/>
</$button>
<$set name=label filter="""[tag{!!title}count[]]""">
<$wikify name=fieldselection text="[tag[{{!!title}}]]">
<$macrocall $name=bm-addtofilter
tooltip="Add as tag to filter"
/>
</$wikify>
</$set>
</$wikify>
</$list>
</div>
</$set>
</td>
</$list>
</tr>
</$list>
</table>
\end
\define bm-input-table()
<table class="bm-table bm-input-table" >
<tr>
<td style="text-align:center; vertical-align:bottom">^^Back. Up. First. !^^<br>
<$button>
<$list filter="[[batchmanipulator]bm-display[singledata]]">
single data
<$action-setfield $tiddler=batchmanipulator bm-display=relations/>
</$list>
<$list filter="[[batchmanipulator]!bm-display[singledata]]">
relations
<$action-setfield $tiddler=batchmanipulator bm-display=singledata />
</$list>
</$button>
</td>
<td style="white-space:nowrap;">
,,Select / type titles or 'filter'. Note [[space brackets]].,,<br>
<$edit-text class='tc-edit-texteditor' tag=input
default={{batchmanipulator!!bm-filter}}
tiddler="$:/batchmanipulator/temp/filter"
placeholder={{batchmanipulator!!bm-filter}}
/>
</td>
<td style="vertical-align:bottom;padding:0;padding-bottom:5px;white-space:nowrap;">
<$list filter="[[$:/batchmanipulator/temp/filter]has[text]] [[batchmanipulator]get[bm-filter]] +[first[]]">
<$button class="bm-btn tc-btn-invisible" tooltip="Clear filter">
{{$:/core/images/close-button}}
<$action-setfield $tiddler="batchmanipulator" bm-filter="" />
<$action-setfield $tiddler="$:/batchmanipulator/temp/filter" text="" />
<$action-navigate $to="batchmanipulator"/>
</$button>
</$list>
<$list filter="[[$:/batchmanipulator/temp/filter]has[text]]">
<$button class="bm-alert bm-btn-tooltip">
!
<div class="bm-tooltip">Click to apply filter</div>
<$action-setfield $tiddler=batchmanipulator
bm-filter-previous={{batchmanipulator!!bm-filter}} />
<$action-setfield $tiddler=batchmanipulator
bm-filter={{$:/batchmanipulator/temp/filter}} />
<$action-deletetiddler $tiddler="$:/batchmanipulator/temp/filter"/>
</$button>
</$list>
</td>
</tr>
<tr>
<td style="text-align:center; vertical-align:top;">
^^Current view^^
</td>
<td style="white-space:nowrap">
<$select tiddler="batchmanipulator" field="bm-filter" default="""{{!!bm-filter}}""" >
<option value={{batchmanipulator!!bm-filter-previous}}>back to last filter</option>
<optgroup label='Filters based on user set values (i.e set them first)'>
<$list filter="""[[batchmanipulator]bm-field[tag]]""">
<option value="[tag[$(val)$]] $(limit)$">$(val)$ tag siblings</option>
<option value="[tag[$(val)$]tags[]tagging[]] $(limit)$">$(val)$ tag cousins</option>
</$list>
<$list filter="$(tag-or-field)$ -tag">
<option value="[has:field[$(thefield)$]] $(limit)$">field siblings: $(thefield)$</option>
<option value="[has:field[$(thefield)$]$(thefield)$[$(val)$]] $(limit)$">field+value siblings: $(thefield)$:$(val)$</option>
</$list>
</optgroup>
<optgroup label='custom - Locate "XXX" in editmode to customize'>
<option value="[type[text/x-tiddlywiki]] $(limit)$">TWC to TW5 - remove type & changecount </option>
<option value="aa [[bb bb]] cc dd ee">titles for testing</option>
<option value="">...</option>
</optgroup>
</$select><$select tiddler="batchmanipulator" field="bm-filterlimit" default="limit[10]" >
<option value="+[limit[5]]">5</option>
<option value="+[limit[10]]">10</option>
<option value="+[limit[20]]">20</option>
<option value="+[limit[50]]">50</option>
<option value="+[limit[100]]">100</option>
<option value="">no.l</option>
</$select>
<$wikify name=fieldselection text="{{batchmanipulator!!bm-filterlimit}}">
<$macrocall $name=bm-addtofilter
tooltip="(Optional) Add limit to filter"
/>
</$wikify>
</td>
<td></td>
</tr>
<tr>
<td style="white-space:nowrap;">
,,Select or create what to manipulate:,,</td>
<td>
,,New or existing field value or tag to use:,,
</td>
<td>
</td>
</tr>
<tr>
<td style="white-space:nowrap; text-align:right;">
<$select tiddler="batchmanipulator" field="bm-field" default="tag">
<option value="tag"> tags</option>
<option value="bm-new-field"> [create new field]</option>
<optgroup label='fields'>
<$list variable="field"
filter="""[{!!bm-field}] [!is[shadow]!is[system]fields[]sort[]] -title -text -field-filter
-bm-filter -bm-filter-previous -bm-filterlimit -bm-value -bm-field -bm-tag -bm-display -bm-message""" >
<option value=<<field>>><<field>></option>
</$list>
</optgroup>
</$select>
<$list filter="$(thefield)$ -tag">
<$set name=label filter="""[has[$(thefield)$]count[]]""">
<$wikify name=fieldselection text="""[has[$(thefield)$]]""">
<$macrocall $name=bm-addtofilter
tooltip="""(Optional) Add [has[$(thefield)$]] to filter"""
class="bm-fontsmall"
/>
</$wikify>
</$set>
</$list>
<$list filter="[[batchmanipulator]bm-field[bm-new-field]]"><br>
<$set name=placeholder
filter="[[batchmanipulator]get[bm-field]] -bm-new-field"
value={{batchmanipulator!!bm-name}}
emptyValue=" new field name"
>
<$edit-text tag=input size=15
tiddler="$:/batchmanipulator/temp" field="bm-field"
placeholder=<<placeholder>>
/>
</$set>
<$button class="bm-alert bm-btn-tooltip">
!
<div class="bm-tooltip">Click to create field name</div>
<$action-setfield $tiddler=batchmanipulator
bm-field={{$:/batchmanipulator/temp!!bm-field}} />
<$action-setfield $tiddler="$:/batchmanipulator/temp" bm-field="" />
</$button>
</$list>
</td>
<$list filter="[[$(tag-or-field)$]prefix[field]]">
</$list>
<td style="white-space:nowrap">
<$set name=placeholder filter="""[[batchmanipulator]get[bm-value]]"""
value="""$(val)$"""
emptyValue="(new value)"
>
<$edit-text class='tc-edit-texteditor bm-fieldeditor' tag=input
tiddler="$:/batchmanipulator/temp" field="bm-value"
placeholder=<<placeholder>>
/>
</$set>
<$list filter="[[$:/batchmanipulator/temp]!has[bm-value]]">
<$set name=label filter="""[$(thefield)$[$(val)$]count[]]""">
<$wikify name=fieldselection
text="""[{{batchmanipulator!!bm-field}}[{{batchmanipulator!!bm-value}}]]""">
<$macrocall $name=bm-addtofilter
tooltip="(Optional) Add to filter"
class="bm-fontsmall"
/>
</$wikify>
</$set>
</$list>
<$list filter="""[[$:/batchmanipulator/temp]get[bm-value]]""">
<$button class="bm-alert bm-btn-tooltip">
!
<div class="bm-tooltip">Click to apply value</div>
<$action-setfield $tiddler=batchmanipulator
bm-value={{$:/batchmanipulator/temp!!bm-value}}
/>
<$action-setfield $tiddler="$:/batchmanipulator/temp"
$field="bm-value"
$value=""
/>
</$button></$list>
</td>
<td>
</td>
</tr>
</table>
\end
\define singledata() <<bm-singledata-table>>
\define relations() <<bm-relations-table>>
\define bm-inner()
<$set name=tag-or-field filter="""[[batchmanipulator]get[bm-field]] -tag"""
value=field emptyValue=tag >
<$set name=val value={{batchmanipulator!!bm-value}}>
{{Xbatchmanipulator/peek}}
<<bm-input-table>>
<br>
<$list filter="[[batchmanipulator]has[bm-filter]!bm-field[bm-new-field]]">
<$macrocall $name={{!!bm-display}} />
</$list>
</$set>
</$set>
\end
<$set name=thetids filter={{batchmanipulator!!bm-filter}} >
<$wikify name=limit text={{batchmanipulator!!bm-filterlimit}} >
<$set name=thefield filter={{batchmanipulator!!bm-field}} >
<<bm-inner>>
</$set>
</$wikify>
</$set>
.bm-table {margin:0 auto;}
.bm-table, .bm-table th, .bm-table td {
border:0; background:white;
}
.bm-input-table {width:100%;}
.bm-input-table > tr > td:nth-child(2) {max-width:300px;}
.bm-input-table select {max-width:calc(100% - 50px - 1.2em);}
.bm-fieldeditor {max-width:calc(100% - 1.2em);}
.bm-relations-table {margin-top:4em;}
.bm-table th.rotate {
white-space: nowrap;
vertical-align:bottom;
}
.bm-table th.rotate > div {
transform: translate(27px, -.5em) rotate(315deg);
width: 1em;
margin-left:-1em;
}
.bm-table th.rotate > div > span {
border-bottom: 1px solid #ccc;
padding: 0px 10px 2px 0;
margin-left:-.6em;
background:white;
}
.bm-table ::-webkit-input-placeholder { color: #a6a6a6; }
.bm-table :-ms-input-placeholder { color: #a6a6a6; }
.bm-table ::-ms-input-placeholder { color: #a6a6a6; }
.bm-table ::-moz-placeholder { color: #a6a6a6; }
.bm-singledata-table-head {border-bottom:2px solid silver}
.bm-btn {width:1em;}
.bm-btn-addtofilter {color:blue; }
.bm-btn-add, .tm-add-tag, .tm-add-field { background:lightgray;}
.bm-btn-remove, .tm-remove-tag, .tm-remove-field {background:lightgreen;}
.peek {display:none;z-index:2;background-color:lightgray;position:absolute;}
.peek-hover:hover .peek {display:block; background:lightgray;}
.bm-tooltip {position:absolute; display:none; z-index:2;background:white; margin:-2.6em -1em; border:1px solid silver; padding:0 5px; color:black;white-space:nowrap;}
.bm-btn-tooltip:hover .bm-tooltip {display:block;}
.bm-fontsmall {font-size:.8em; fill:gray;}
.bm-center {text-align:center; vertical-align:text-bottom;}
.bm-fontsmall svg,
.bm-fontsmall input[type="checkbox"] {vertical-align:text-top}
.bm-alert {border-color:red;}
.bm-drag {background:#ec6; border-radius:1em; padding:0; line-height:1.1em; width:3em; display:inline-block;}
button.green-link {color:#00cc00;}
<div class="family-tree">
<ul>
<li>
[[Parent]]
<ul>
<li>
[[Child 1]]
<ul>
<li>
[[Grand Child 1.1]]
</li>
</ul>
</li>
<li>
[[Child 2]]
<ul>
<li>[[Grand Child 2.1]]</li>
<li>
[[Grand Child 2.2]]
<ul>
<li>
[[Great Grand Child 2.2.1]]
</li>
<li>
[[Great Grand Child 2.2.2]]
</li>
<li>
[[Great Grand Child 2.2.3]]
</li>
</ul>
</li>
<li>[[Grand Child 3]]</li>
</ul>
</li>
</ul>
</li>
</ul>
</div>
<div class="family-tree">
*[[Rechtssubjekt]]
**[[Willenserklärung]] Abgrenzung zu anderen Verträgen
***[[einseitige WE]] [[empfangsbedürftige WE]]
****[[Abgabe]] [[Zugang]]
****[[Vertragspartner]]
*****[[Vertrag]]
</div>
Befreiungsanspruch nach Scheitern der Ehe
Easy Contact
Sofern ein Ehegatten während intakter Ehe für die Zwecke des anderen Ehegatten eine Verbindlichkeit übernommen hat, kann ihm nach Scheitern der Ehe aus Auftragsrecht ein Anspruch auf Freistellung hiervon gem. § 670 BGB i.V.m. § 257 BGB zustehen.
Dies sind vor allem Fälle der gemeinsamen Kreditaufnahme zum Bau eines Familienheims oder auch zur Verbesserung der Erwerbschancen eines Ehegatten. Die Mithaftung bei einem Darlehen beruht beispielsweise auf einer persönlichen Haftungsübernahme oder auch durch die Einräumung anderweitig persönlicher oder dinglicher Sicherheiten (FPR 2003, 502). Grundlage hierfür ist ein familienrechtlich begründetes Schuldverhältnis.
Mit Scheitern der Ehe besteht ein wichtiger Grund i.S.d. § 671 Abs. 3 BGB, wonach der Beauftragte kündigen kann. Daneben sind jedoch Einschränkungen dieses Anspruchs zu berücksichtigen. Zu beachten ist hier das Gebot der Rücksichtnahme, welches gesetzlich in § 1353 Abs. 1 S. 2 BGB verankert ist und vorliegend entsprechend der Nachwirkung der Ehe einzubeziehen ist. Darüber hinaus ist das Gebot von Treu und Glauben gem. § 242 BGB zu bewahren. Schließlich wurzelt das Rechtsverhältnis auf der ehelichen Lebensgemeinschaft (NJW-RR BGH 2015, 641 (642)).
Ein Freistellungsanspruch wird hier nicht durch die Regelungen des Zugewinnausgleichs verdrängt. Dieser vermag nur eine Korrektur bei unbenannten Zuwendungen unter Ehegatten. Beabsichtig ist hier nur eine für die Zukunft. Ein solcher Befreiungsanspruch resultiert dagegen zusätzlich auf einer schuldrechtlichen Sonderbeziehung der Parteien. Neben dem Anspruch auf Auftragsrecht kommt in gewissen Konstellationen sogar ein Anspruch auf gesellschaftsrechtlicher Basis in Betracht. Eine Auseinandersetzung erfolgt dann gem. §§ 738, 739 BGB (BGH: Freistellung von Verbindlichkeiten nach Scheitern der Ehe, NJW, 1989, 1920, 1921 f.).
Ob eine Sonderbeziehung vorliegt, kann durch das Vorliegen eines schriftlichen Vertrages bestätigt werden oder aus den tatsächlichen Verhalten und Umständen geschlossen werden. Die Finanzierung eines Familienheims geht grundsätzlich nicht über die Verwirklichung der ehelichen Lebensgemeinschaft hinaus (FPR 2003, 502). Jedoch ist dies anders zu bewerten, wenn das Darlehen nur für im Alleineigentum eines Ehegatten stehendes Grundstücks verwendet wird. Gerade dann ist es nicht unbillig dem Auftraggeber die alleinige Haftungsübernahme aufzubürden (BGH: Freistellung von Verbindlichkeiten nach Scheitern der Ehe, NJW, 1989, 1920, 1921). Schließlich soll die Freistellung für die Zukunft erfolgen. Der Beauftragte partizipiert hieran nicht mehr. Der Befreiungsanspruch ist auf die Zukunft gerichtet, im Gegensatz zu § 812 BGB, welcher eine Abschöpfung in der Vergangenheit vornimmt (vgl. hierzu BGH: Ausgleichspflicht zwischen geschiedenen Ehegatten, NJW 1967, 1275, 1276; Schulze/Volker Wiese/Reiner Schulze: § 671 BGB, Rn. 5).
Ein Freistellungsanspruch besteht folglich, wenn das Darlehen nur einseitig dem Vermögen eines Ehegatten dient. Der Auftraggeber hat daher dafür zu sorgen, dass für die Zukunft nur noch er allein für das Darlehen haftet. Dies kann nun nach Wahl des Freistellungschuldners durch Freistellungserklärung gegenüber der Bank, Zahlung, Umschuldung, oder auch Schuldübernahme erfolgen. Schließlich muss allerdings weiter einschränken berücksichtigt werden, dass der Freistellungsschuldner auch gem. § 671 Abs. 2 S. 1 BGB in der Lage ist, alleine für die Besorgung des Geschäfts Fürsorge treffen zu können.
Für die Kündigung zur Unzeit i.S.d. § 671 Abs. 2 S. 1 BGB ist relevant, ob es dem Auftraggeber unter zumutbaren Anstrengungen möglich ist, den Auftrag selbst anderweitig oder mit Hilfe eines Ersatzmannes fortzuführen (MüKo/Seiler: § 671 BGB, Rn. 12). Versetzt die Kündigung den Auftraggeber aber gerade in die Lage, die Besorgung des Geschäfts nicht anderweitig Sorge tragen zu können, so erfolgte die Kündigung zur Unzeit (Schulze/Volker Wiese/Reiner Schulze: § 671 BGB, Rn. 4). Dieser Gedanke des Auftragsrechts muss sich im Gebot von Treu und Glauben und der besonderen Verbindung von Auftraggeber und Beauftragten durch das Ehebündnis wieder finden, da er bei Kündigung aus gewichtigem Grunde gem. § 671 Abs. 3 BGB ausgeschlossen ist (vgl. hierzu: BGH: Freistellung von Verbindlichkeiten nach Scheitern der Ehe, NJW 1989, 1920, 1922).
Es ist daher angezeigt, sofern das Rechtsverhältnis zum Zwecke des familiären Allgemeinwohls diente, dies auch bei der Geltendmachung des Befreiungsanspruchs zu berücksichtigen. Die Rückführung der Verbindlichkeit ist daher nur in einem für den Auftraggeber zumutbaren und möglichen Rahmen, z.B. Tilgungsplanes, vorzunehmen (vgl. hierzu: BGH: Freistellung von Verbindlichkeiten nach Scheitern der Ehe, NJW 1989, 1920,1922).
<<tabs "[tag[Beispiele]]" "" "" "tc-vertical">>
'':)''
Zuletzt schließen sich in der Prüfungsreihenfolge der Anspruchsgrundlagen die bereicherungsrechtlichen Ansprüche an. Diese liegen vor, wenn jemand etwas ohne Rechtsgrund erlangt hat, vgl. §§ 812 ff. BGB. Beispiel1: A verkauft und übereignet dem B sein Auto. Später stellt sich heraus, dass A beim Abschluss des Kaufvertrags, nicht jedoch bei der Übereignung, unerkannt geisteskrank war. A hat somit wirksam das Eigentum und den Besitz an dem Fahrzeug erlangt. Dies geschah jedoch ohne wirksamen Rechtsgrund, da der Kaufvertrag wegen der unerkannten Geisteskrankheit gemäß §§ 104, 105 BGB nichtig war. Deshalb kann A von B gemäß § 812 I 1 1. Fall BGB die Herausgabe des Fahrzeugs verlangen. Beispiel2: B klaut dem A sein Auto. Nun hat A neben den dinglichen Ansprüchen auch einen Anspruch aus § 812 I 1 2. Fall BGB. Hierbei macht es keinen Unterschied, dass A nicht geleistet hat, sondern B sich das Fahrzeug unberechtigterweise genommen hat.
entweder Pauschale von in der Regel 5 % des Nettoeinkommens (z.B. Süddeutsche Leitlinien 10 b) oder in tatsächlicher Höhe gegen konkreten Nachweis. Beispiele: Fahrtkosten zur Arbeitstätte, Arbeitsmittel, Bewerbungskosten etc. Gilt nicht beim Selbständigen, da hier die berufsbedingten Aufwendungen bereits bei den Ausgaben
seiner Einnahmen-Überschuss-Rechnung voll berücksichtigt sind.
(Z.B. §§ 9 MUSCHG, 85 FF. SGB IX, 15 FF. KSCHG)
Grundsätzlich hat jede Partei die für sie günstigen Tatsachen zu behaupten
* Kläger die Anspruchsvoraussetzungen
* Beklagter die Einwendungen und Einreden
<ul>
<$list filter="[kin:gesetz[BGB]]" variable="title">
<li><<title>></li>
</$list>
</ul>
(1) Der Reisende kann unbeschadet der Minderung oder der Kündigung Schadensersatz wegen Nichterfüllung verlangen, es sei denn, der Mangel der Reise beruht auf einem Umstand, den der Reiseveranstalter nicht zu vertreten hat.
(2) Wird die Reise vereitelt oder erheblich beeinträchtigt, so kann der Reisende auch wegen nutzlos aufgewendeter Urlaubszeit eine angemessene Entschädigung in Geld verlangen.
Ein Rechtsgeschäft, welches der durch Gesetz vorgeschriebenen Form ermangelt, ist nichtig. Der Mangel der durch Rechtsgeschäft bestimmten Form hat im Zweifel gleichfalls Nichtigkeit zur Folge.
(1) Durch den Kaufvertrag wird der Verkäufer einer Sache verpflichtet, dem Käufer die Sache zu übergeben und das [[Eigentum|AGL Eigentum an Kaufsache]] an der Sache zu verschaffen. Der Verkäufer hat dem Käufer die Sache frei von Sach- und Rechtsmängeln zu verschaffen.
(2) Der Käufer ist verpflichtet, dem Verkäufer den vereinbarten [[Kaufpreis|AGL Kaufpreis]] zu zahlen und die gekaufte Sache abzunehmen.
[[Auslegungsmethoden]]
§ 3 Das Rechtssubjekt
Übersicht: Das Rechtssubjekt
Übersicht: Definitionen Verbraucher und Unternehmer
Übersicht: Verbraucherschutzziele der EU
Fälle zu § 3
§ 4 Das Rechtsobjekt
Übersicht: Das Rechtsobjekt
Fälle zu § 4
§ 5 Die Willenserklärung
Übersicht: Die Abgabe einer Willenserklärung
Übersicht: Die Übermittlung einer Willenserklärung
Übersicht: Der Zugang einer empfangsbedürftigen Willenserklärung
Übersicht: Äußerer Erklärungstatbestand einer Willenserklärung
Übersicht: Innerer Erklärungstatbestand einer Willenserklärung
Übungsfall: "Die Zustellung per Einschreiben"
Fälle zu § 5
§ 6 Abschluss eines Vertrages
Übersicht: Das kaufmännische Bestätigungsschreiben
Übungsfall: "Das Buch"
Fälle zu § 6
§ 7 Methodenlehre: Rechtsgeschäfte
Übersicht: Arten der Rechtsgeschäfte
Übersicht: Formen der Rechtsgeschäfte
§ 8 Die Auslegung einer Willenserklärung sowie der Dissens
Übersicht: Die Auslegung einer Willenserklärung
Fälle zu § 8
§ 9 Mängel beim Abschluss eines Rechtsgeschäftes
Übersicht: Mängel beim Abschluss eines Rechtsgeschäftes
Übersicht: Grundbegriffe Schuldverhältnisse / Leistung
§ 10 Mängel in der Person
Übersicht: Geschäftsfähigkeit
§ 11 Anfechtung einer Willenserklärung, Irrtum, Arglist, Verstoß gegen ein gesetzliches Verbot, Sittenwidrigkeit und Nichtigkeit
Übersicht: Irrtum
Übersicht: Anfechtung
Übungsfall: "Das gemeinsam gekaufte Bild"
Übungsfall: "Der falsche Preis"
Fälle zu § 11
§ 12 Methodenlehre: Ansprüche und Einwände
Übersicht: Ansprüche und Einwände
Übersicht: Einwände
§ 13 Methodenlehre: Subsumtionstechnik
Übersicht: Subsumtionstechnik-Schema
Übersicht: Musterlösung zu Fall "Das unbezahlte Haus"
Fälle zu § 13
§ 14 Methodenlehre: Fallbearbeitung
Übersicht: Fallbearbeitung
Fälle zu § 14
§ 15 Stellvertretung und Vollmacht
Übersicht: Grundlagen der unmittelbaren Stellvertretung
Übersicht: Abgrenzungen sowie die Beziehung zw. Grundverhältnis und Vollmacht
Übersicht: Duldungs- und Anscheinsvollmacht
Übersicht: Handeln ohne Vertretungsmacht / Missbrauch der Vertretungsmacht
Übersicht: Unterscheidung zwischen unmittelbarer und mittelbarer Stellvertretung
Übungsfall: "Drachenfliegen"
§ 16 Fristen und Termine
Übersicht: Fristen
§ 17
Die Verjährung
Übersicht: Voraussetzungen für den Eintritt der Verjährung
Übersicht: Das System der Verjährung
Übersicht: Unregelmäßige Verjährung
Übersicht: Verjährung von Mängelansprüchen
https://bimlas.gitlab.io/
This update is focused on improving the fetching interface and the plugin server functionality.
You can now add plugins to the plugin library from inside the wiki and you can use any plugins that are available in the plugin library in any of the served wikis. You can drag and drop a plugin into a wiki and then use the interface in the control panel to save the plugin on the server. Then in the control panel you can select which plugins you want to include in the wiki.
Both features work but I haven't had a chance to thoroughly test them or to figure out what would be a good interface. Which is why we have the prerelease version here.
I am sure that as soon as anyone else touches it there will be many bugs that need to be fixed so have at it.
Some more documentation about the plugin library features is here:
https://github.com/OokTech/TW5-Bob/blob/master/Documentation/Plugin%20Library.tid
Documentation about the individual components is in the documentation included with Bob.
The plugin version is available here: https://github.com/OokTech/TW5-Bob
The BobEXE version is available here: https://github.com/OokTech/TW5-BobEXE/releases/tag/1.0.7
!! Version 1.0.7 (ongoing)
- Add `savePluginFolder` web socket message to save packaged plugins as folders
on a server. These plugins can then be available to other served wikis and in
the plugin library, if it is enabled.
- Add the `import` borwser message handler to make fetching nicer
- Add options for how to handle conflicts for `internalFetch`
- `internalFetch` now displays a list of imported tiddlers
- Added a way to change which plugins a wiki uses from inside the wiki
- Added an interface to save plugins to the server and to select which plugins
from the server should be used in the current wiki
<$list
filter='[<currentTiddler>tag[Book]]'
>
<h1
style='text-align:center;font-size:3em;'
>
<$view
field='caption'
>
<$view
field='title'
/>
</$view>
</h1>
<div
style='text-align:center'
>
Jump to chapter:
<$list
filter='[book<currentTiddler>tag[Chapter]nsort[order]]'
variable=thisChapter
>
<$list
filter='[<thisChapter>!field:title{$:/settings!!chapter}]'
variable=dummy
emptyMessage="""<$count filter='[[dummy]][book<currentTiddler>tag[Chapter]nsort[order]allbefore<thisChapter>]'/>"""
>
<$button
class='tc-btn-invisible tc-tiddlylink'
>
<$count
filter='[[dummy]][book<currentTiddler>tag[Chapter]nsort[order]allbefore<thisChapter>]'
/>
<$macrocall
$name=OpenChapter
Chapter=<<thisChapter>>
/>
</$button>
</$list>
</$list>
</div>
<$list
variable=FirstChapter
filter='[book<currentTiddler>tag[Chapter]nsort[order]first[]]'
>
<$list
variable=CurrentChapter
filter='[list[$:/StoryList]after<currentTiddler>get[title]][[dummy]]+[limit[1]]'
>
<$list
variable=NextChapter
filter='[book<currentTiddler>tag[Chapter]nsort[order]after<CurrentChapter>][[dummy]]+[limit[1]]'
>
<$list
variable=PreviousChapter
filter='[book<currentTiddler>tag[Chapter]nsort[order]before<CurrentChapter>][[dummy]]+[limit[1]]'
>
<div
style='text-align:center'
>
<$list
filter='[<PreviousChapter>has[book]]'
variable=dummy
>
<$button>
{{$:/core/images/chevron-left}}
Previous
<$macrocall
$name=OpenChapter
Chapter=<<PreviousChapter>>
/>
</$button>
</$list>
<$list
filter='[[$:/settings]!book<currentTiddler>]'
variable=dummy
>
<$button>
Open Book
<$macrocall
$name=OpenChapter
Chapter=<<FirstChapter>>
/>
</$button>
</$list>
<$list
filter='[<NextChapter>has[book]]'
variable=dummy
>
<$button>
Next
{{$:/core/images/chevron-right}}
<$macrocall
$name=OpenChapter
Chapter=<<NextChapter>>
/>
</$button>
</$list>
</div>
</$list>
</$list>
</$list>
</$list>
</$list>
\define ChapterTitleThingy() [[$(Chapter)$]]
\define BookTitleThingy() [[$(Book)$]]
\define OpenChapter(Chapter)
<$vars
Chapter="""$Chapter$"""
>
<$list
filter="""[[$Chapter$]get[book]]"""
variable=Book
>
<<InnerOpenChapter>>
</$list>
</$vars>
\end
\define InnerOpenChapter()
<$action-setfield
$tiddler='$:/settings'
book=<<Book>>
/>
<$action-setfield
$tiddler='$:/settings'
chapter=<<Chapter>>
/>
<$action-setfield
$tiddler='$:/StoryList'
list=''
/>
<$action-listops
$tiddler='$:/StoryList'
$subfilter='+[append<BookTitleThingy>]'
/>
<$action-listops
$tiddler='$:/StoryList'
$subfilter='+[append<ChapterTitleThingy>]'
/>
<$set
name=ParagraphList
filter='[book<Book>chapter<Chapter>tag[Paragraph]nsort[order]]'
>
<$action-listops
$tiddler='$:/StoryList'
$subfilter='+[append<ParagraphList>]'
/>
</$set>
\end
\define OpenParagraph(Paragraph)
<$list
filter="""[[$Paragraph$]get[book]]"""
variable=Book
>
<$list
filter="""[[$Paragraph$]get[chapter]]"""
variable=Chapter
>
<<InnerOpenChapter>>
<$action-navigate
$to="""$Paragraph$"""
/>
</$list>
</$list>
\end
\define OpenBook(Book)
<$vars
Book="""$Book$"""
>
<$list
filter='[book<Book>tag[Chapter]nsort[order]first[]]'
variable=Chapter
>
<<InnerOpenChapter>>
</$list>
</$vars>
\end
!Macros:
Each macro can be put inside a button to open a book to a specific location
!!`OpenBook`
This macro opens up a book to its first chapter
Usage: `<<OpenBook Book>>`
|!Parameter |!Description |
|Book |The title of the book you want to open |
!!`OpenChapter`
This macro opens a book to the given chapter
Usage: `<<OpenChapter Chapter>>`
|!Parameter |!Description |
|Chapter |The title of the tiddler for the chapter you want to open |
!!`OpenParagraph`
This macro opens a book to a specific paragarph
Usage: `<<OpenParagraph Paragraph>>`
|!Parameter |!Description |
|Paragraph | The title of the paragraph tiddler you want to navigate to |
\define chapter-title(r)
$r$ <$view field="!!caption">{{!!title}}</$view>
\end
\define chapter-body(tag,sort:"",itemClassFilter,exclude,path,rank:"")
<$set name=rank value="!$rank$">
<$list filter="""[all[tiddlers]tag<__tag__>!has[draft.of]$sort$] -[<__tag__>] -[enlist<__exclude__>]""">
<$vars item=<<currentTiddler>> path={{{ [<__path__>addsuffix[/]addsuffix<__tag__>] }}} excluded="""[enlist<__exclude__>] -[<__tag__>]""">
<$list filter="[all[current]]" emptyMessage="<$link><$view field='caption'><$view field='title'/></$view></$link>">
<$macrocall $name="chapter-title" r=<<rank>> />
{{!!text}}
</$list>
</$vars>
<$macrocall $name="chapter-body" tag=<<item>> sort=<<__sort__>> itemClassFilter=<<__itemClassFilter__>> exclude=<<excluded>> path=<<path>> rank=<<rank>>/>
</$list>
</$set>
\end
\define book(tag,sort:"",itemClassFilter:" ")
<$macrocall $name="chapter-body" tag=<<__tag__>> sort=<<__sort__>> itemClassFilter=<<__itemClassFilter__>> />
\end
!! Semantic border colors
These are four border colors.
# <<colorize Orange beginner>>: ''Beginner level''
# <<colorize Yellow elementary>>: ''Elementary level''
# <<colorize Green intermediate>>: ''Intermediate level''
# <<colorize Blue advanced>>: ''Advanced level''
!! How to use
Simply add one of the above colorized tags (//beginner//, //elementary//, //intermediate//, //advanced//) to your tiddler and save it. For example if you a wish to categorize a tiddler in beginner category, add tag `beginner` to it.
!! Demo
Click on the below button to close all tiddlers and open sample tiddlers colorized with border colors.
<<open-all filter:"[tag[demo]] +[search:title[bordered colors]]" label:"Open colored border examples">>
Hey guys,
as I tried various ways for storing a big amount of wikis on my limited hardware I came across the WebDAV capabilities and gave them a try as well.
Mario's videos were great but since I do not own any Microsoft license whatsoever this was no option. However I tried it with my favourite open source webserver Caddy which I tell you is an awesome peace of software by itself. But combining it with TW makes using TWs over network a child's play since Caddy has WebDAV build in already.
Here are the steps to follow:
Go to Caddy download page
Select the webdav plugin (documentation) and personal license and hit download
Unzip the archive we only need the executable which we put in the same directory as the wikis we want to serve
Create a text file called "Caddyfile" with capital "C" and write these two lines in it:
:8000
webdav
That's it, just execute the caddy file via a terminal and you are set. No configuration or anything else.
A wiki called mywiki.html is available via http://[IP_OF_THE_SERVER]:8000/mywiki.html.
I hope this helps some of you, I will play around with it for a while now and see how it compares to the other solutions I am testing.
Cheers,
Tristan
\define title() <$view field="title"/>
\define toc-caption()
<$set name="tv-wikilinks" value="no">
<$set name="display" tiddler=<<currentTiddler>> field="caption" emptyValue=<<title>>>
<<display>>
</$set>
</$set>
\end
<div class="nr">
Titles numbered using CSS counters. See [[TitlesWithNumbers.css]].
! Warning: Experimental Stuff! [h1]
Use at your own risk. <<ref "No strings attached: This Wiki was made with a prerelease of TiddlyWiki 5.1.14">> I encountered several browser freezes while setting this test […] up.
!! Hints [h2]
<!-- sli1 -->
This test is based on http://tid.li/tw5/hacks.html#TextStretch. There was no time for proper documentation, but it seems to work – let’s say as a proof of concept.
<!-- end sli1 -->
!!! Prerequisites [h3]
* TextStretch including the //ref// shorthand macro <<ref "this handy macro can be found under $:/_telmiger/ref">>
* the //extract macro//, which can be found here: $:/_telmiger/extract – tests and test results for other extractions this can do (more or less) can be found in the macro tiddler itself. <<ref "You could try to extract the docs from the macro using the macro. Just do it ;–)">>
! Test Content
<article>
!! Numbered Hints/Notes
This paragraph is built using the `<<ref>>` shorthand <<ref "Firstly: A longer note can be helpful to illustrate facts and findings or to promote a link to http://thomas-elmiger.ch">> and more text after the example. <<ref "test footnote 2">> – more text <<ref "3rd footnote">> and more text after the example. Even more text <<ref "A tale of horror and CSS (4)">> and more text after the example. <<ref "test footnote 5">> – more text <<ref "6th footnote">> and more text after the example. <<ref "My footnote number 7">><<ref "My footnote number 8">>
<sli2>
The second paragraph works as well as the first one <<ref "My footnote number 9">> even when the footnote-numbers go as high as 10 or more. <<ref "The styling of the footnote summary does now also cover numbers with more than one digit, like in 10.">>
</sli2>
</article>
! Title h2
!! Title h2
!! Title h2
!!! Title h3
!!! Title h3
And so on …
</div>
<div class="nr">
Titles numbered using CSS counters. See [[TitlesWithNumbers.css]].
! Title h1
!! Title h2
---
<<slice "TestContent" 1>>
---
<<slice "Chapter 1" 2>>
---
!!! Title h3
! Title h1
!! Title h2
!! Title h2
!!! Title h3
!!! Title h3
!! Title h2
! DWYWBDBM-Licence
Do what you want, but don’t blame me ;–)
Please [[drop me a link|FollowMe]] if you made something cool! <<ref "Even if you think you made nothing special: Please let me know!">> Thank you for your interest.
</div>
<div class="nr">
! Even More Test Content
<article>
!! Numbered Hints/Notes
This paragraph is built using the `<<ref>>` shorthand <<ref "Firstly: A longer note can be helpful to illustrate facts and findings or to promote a link to http://thomas-elmiger.ch">> and more text after the example. <<ref "test footnote 2">> – more text <<ref "3rd footnote">> and more text after the example. Even more text <<ref "A tale of horror and CSS (4)">> and more text after the example. <<ref "test footnote 5">> – more text <<ref "6th footnote">> and more text after the example. <<ref "My footnote number 7">><<ref "My footnote number 8">>
The second paragraph works as well as the first one <<ref "My footnote number 9">> except when the footnote-numbers go as high as 10 or more. <<ref "The styling of the footnote summary does not cover numbers with more than one digit, like in 10.">>
</article>
And so on …
</div>
<$list
filter='[<currentTiddler>tag[Chapter]]'
>
<h2
style='font-size:2em;'
>
<$view
field='caption'
>
<$view
field='title'
/>
</$view>
</h2>
</$list>
<$set name=tiddler-title value={{!!title}}>
<$list filter="[tag<tiddler-title>]" variable="current-story">
<$transclude tiddler=<<current-story>>/>
<$list filter="[tags<current-story>regexp[sk:]]" template="$:/core/ui/TagTemplate"/>
</$list>
\define cherrypicker(mark)
@@.cherryheading $mark$@@
<div style="margin: -0px 0 0 22px;">
<$list filter="[!is[system]regexp:text[$mark$]!prefix[Draft]!title[About]!tag[About]!regexp:text[cherrypicker ]] -[prefix[CherryPicker]] -[prefix[codeCherry]]" emptyMessage="NO" variable="tid">
<$list variable="fulltext" emptyMessage="NOpfx"
filter="""[<tid>get[text]]""">
<$macrocall $name="scrubprefix" txt=<<fulltext>> mark="$mark$"/>
</$list>
</$list>
</div>
\end
\define scrubprefix(txt, mark)
<$list variable="pfx"
filter="[[$txt$]regexp[$mark$\S]splitbefore[$mark$]]" >
@@.pfx ''pfx'':<<pfx>><br>@@
<$list variable="txt" emptyMessage="NOtxt"
filter="[[$txt$]removeprefix<pfx>]">@@.txt ''txt:'' """<<txt>>"""<br>@@
<$macrocall $name="pick" txt=<<txt>> mark="$mark$"/>
</$list>
</$list>
\end
\define pick(txt, mark)
<$list variable="cherry" emptyMessage="NOcherry"
filter="[[$txt$]regexp[\S$mark$]splitbefore[$mark$]removesuffix[$mark$]]
[[$txt$]!regexp[$mark$]splitbefore[ ]]
[[$txt$]!regexp[\S$mark$\s]splitbefore[$mark$]]
+[first[]]">
<span class="cherrybullet" tooltip=<<tid>>>
<$link to=<<tid>>>{{cherrybullet.png}}</$link>
</span><<cherry>> <br>
<$list variable="rest" emptyMessage="NO3"
filter="[[$txt$]removeprefix<cherry>removeprefix[$mark$ ]]
[[$txt$]removeprefix<cherry>] +[first[]]">
@@.rest ''rest'':<<rest>><br>@@
<$list filter="[<rest>regexp[$mark$]]">
<$macrocall $name="scrubprefix" txt=<<rest>> mark="$mark$"/>
</$list>
</$list>
</$list>
\end
\define conc() comment on {{!!title}}
\define create-commentTid()
<$wikify name="ctitle" text=<<conc>> >
<$action-createtiddler
$basetitle=<<ctitle>>
$savetitle="$:/temp/commentName"
relationship="comment"
parent=<<currentTiddler>>
/>
<$action-navigate
$to= {{$:/temp/commentName}}
/>
</$wikify>
\end
<$button actions=<<create-commentTid>> >
Click to make a comment
</$button>
https://www.jurawiki.de/KategorieComputerF%C3%BCrJuristen
https://www.niederle-media.de/Kostenlos-Jura-MP3-Skripte-Klausuren-Podcast-Mindmaps
It's a frequent use case in ~TiddlyWiki that you will want to put the results of variables together with various bits of strings of text. This process in some programming languages is often referred to as "concatenating" text.
You might, for instance want to set up a template for your customer database, where links will automatically refer to additional contact information about your customer. Inside your tiddler, you might try something like this:
|warning|k
|@@font-size:1.5em;⚠@@ Warning:<br/> Don't do it this way!| `[[Additional Info|<<currentTiddler>>-Contact]]` |
But that won't work. If you try this, the link will be interpreted very literally, and will attempt to take you to:
```
<<currentTiddler>>-Contact
```
The solution is to use a macro to put the rendered value of `<<currentTiddler>>` together with the bit of additional text, `-Contact`.
Create a macro at the top of the tiddler like this:
```
\define linkup(link) [[Additional Info|$link$-Contact]]
```
You might be tempted to invoke the new macro like this:
|warning|k
|@@font-size:1.5em;⚠@@ Warning:<br/> Don't do it this way!| `<<linkup <<currentTiddler>> >>` |
But if you do, you will find that `<<currentTiddler>>` doesn't get rendered, but instead gets passed literally.
Instead, you could use the [[MacroCallWidget]] widget, like this:
```
<$macrocall $name="linkup" link=<<currentTiddler>> />
```
In this case, we passed the value of a variable directly to our macro. This is often a general way to go about this task. If you wanted to create more links based on other variables you could re-use the macro for each situation.
If, as in this case, the only variable you are using is `currentTiddler` then you could write a simple macro, like this:
```
\define linkup() [[Additional Info|$(currentTiddler)$-Contact]]
```
Notice that in this case we don't pass an argument. Instead, we reference the variable using the special syntax `$(variable)$`. Since we don't pass an argument, we can invoke it without the `<$macrocall>` widget more simply, like this:
```
<<linkup>>
```
<style>
.warning code {background-color:#ffff80}
table.warning {background-color:#ffff80;}
</style>
TiddlyWiki (as I know) does not have conditional block (`if ... then ...`) but you can use `filter` with `limit` to achieve the same behaviour as using `SELECT` in SQL: TiddlyWiki is basically a [[note database similar to SQL|https://tiddlywiki.com/#Filters]].
For example show a sentence only if this tiddler has tags:
<$macrocall $name="wikitext-example-without-html" src='<$list filter=[all[current]tags[]limit[1]]>
This tiddler is tagged with:
</$list>
<<list-links filter:"[all[current]tags[]]">>'/>
\define title() <$view field="title"/>
\define caption()
<$set name="tv-wikilinks" value="no">
<$set name="display" tiddler=<<currentTiddler>> field="caption" emptyValue=<<title>>>
<<display>>
</$set>
</$set>
\end
\define my-template()
<$list filter="[all[current]tag[Content]]">| $(caption)$ </$list>
<$list filter="[all[current]tag[Content]]">
| <$list filter="[tag[Content]!has[draft.of]] -[<currentTiddler>]"><$link to={{!!title}}>$(caption)$</$link> | </$list>
</$list>
\end
<<my-template>>
<div class="tc-table-of-contents">
<<tocP-selective-expandable root field:"rechtsgebiet">>
</div>
<div class="tc-table-of-contents">
<<tocP-selective-expandable root field:"parent">>
</div>
<$set name="me" value=<<currentTiddler>>>
<div class="tc-timeline">
<$list filter="[tag<me>] [<me>tags[]] [title<me>backlinks[]] +[has[modified]!sort[modified]limit[10]eachday[modified]]">
<div class="tc-menu-list-item">
<$view field="modified" format="date" template="DDth MMM YYYY"/>
<$list filter="[tag<me>] [<me>tags[]] [title<me>backlinks[]] +[sameday:modified{!!modified}!is[system]!sort[modified]]">
<div class="tc-menu-list-subitem">
<$link to={{!!title}}><$view field="title"/></$link>
</div>
</$list>
</div>
</$list>
</div>
</$set>
<br><br>
En vertu de l'article 2011 du Code civil, la fiducie est un contrat dans lequel un ou plusieurs constituants transfèrent des biens, des droits appréciables en argent ou des sûretés à un fiduciaire qui se chargera de les gérer dans l'intérêt d'un bénéficiaire. Le bénéficiaire peut parfaitement être le constituant.
Après avoir vérifié si le fiduciaire sélectionné est totalement digne de confiance, il faut donc rédiger un contrat garantissant bien les intérêts du constituant et du bénéficiaire.
Notice : Contrat de fiducie
Ce contrat doit toujours contenir les clauses suivantes :
la désignation du constituant, du fiduciaire et du bénéficiaire s'il n'est pas le constituant,
un rappel de la profession du fiduciaire et du fait qu'il est autorisé à exercer le rôle de fiduciaire en vertu de sa profession,
la désignation d'un tiers chargé de contrôler l'exécution du contrat,
une clause indiquant que la propriété intégrale de tous les biens confiés sera transférée de plein droit au bénéficiaire à l'échéance du contrat ou lors de sa résiliation,
une clause indiquant les causes de résiliation du contrat,
une clause interdisant au fiduciaire de procéder à la vente des biens confiés sans l'autorisation du constituant,
une clause indiquant les conditions à respecter pour le placement des sommes confiées,
un rappel des références du contrat d'assurance garantissant la responsabilité civile professionnelle du fiduciaire,
la désignation des biens confiés dans le cadre du contrat de fiducie,
la détermination de la rémunération du fiduciaire.
@@color:#999;//see below for the code//@@
{{$:/.tb/template/fields-core}}
Rendered via...
<pre><$view tiddler="$:/.tb/template/fields-core"/></pre>
To showcase what's possible with my [[newtiddler widget|$:/plugins/skeeve/newtiddler.js]] (search for "~NewtiddlerWidget" on my [[tiddlystuff wiki|http://tiddlystuff.tiddlyspot.com]]), I created a [[small Contacts DB|Person DB]].
A contact in this case is a tiddler having the tag {{person||showtag}} and containing some contact detail fields. The contact's name is the tiddler's name.
First we need to create a [[skeleton|personSkeleton]] for a ''person'' tiddler. This is how I sat it up:
|!title |"[[personSkeleton]]" |
|!tags |"$(tags)$" |
|!fields |"phone", "street", "town" |
Please note that this skeleton does not have the {{person||showtag}} tag yet, but a placeholder. This has the advantage
# that the skeleton does not need to be filtered when using the list widget
# that the skeleton can also be used with other tags
The disadvantage at the moment is that the tags placeholder can not be properly viewed as long as the placeholder is not replaced.
Now that we have a skeleton for the data, we can create a view template for it. I choose to simply add the contact details to the bottom of the standard TiddlyWiki viewtemplate. This way a contact's text field can be used for taking notes about the contact.
The view template is just a normal tiddler named [[viewPerson]]. It gets automatically transcluded when we give it the tag {{$:/tags/ViewTemplate||showtag}}. This is the content of the viewPerson tiddler:
{{viewPerson||code}}
The list widget simply selects the current tiddler and checks whether or not it has the {{person||showtag}} tag. If so, a table with the details is displayed.
Next we need an edit template. This template is also quite simple. It's called [[editPerson]] and has no special features at all:
{{editPerson||code}}
I also created a template for displaying a person's entry with a button which allows inline editing of it:
{{personEntry||code}}
In order to be able to create or edit an entry, we need a place to store the entries title (i.e. the person's name). I choose the temp tiddler "[[$:/temp/PersonDBeditPerson]]".
The macro (''editbutton'') defines a button which, when clicked, simply stores the current tiddler's title in my temp tiddler.
The ''editfield'' macro contains a reveal widget. It compares the current tiddler's name to the content of the temp tiddler. If they match, we get the current tiddler transcluded, using the editPerson template.
Next in the ''editfield'' 2 buttons are defined. One for closing the editor, the other for deleting the tiddler. The editor is simply closed by setting the temp tiddler to the empty string. The entry is deleted by sending a delete message.
As the final part of the [[personEntry]] template we display the title as a link, followed by the edit button and the editfields.
Finally we need the contacts list:
{{Person DB||code}}
At the top of the list, we have an input field for a new contact's name. It is simply a field allowing to edit the temp tiddler's text. Behind that we have a button which is creating the new entry, using the newtiddler macro. The surrunding set widget sets the value of the tags of the newly created tiddler. The title is taken from the temp tiddler's text. Setting the edit attribute to "no" means that the newly created tiddler is not displayd as a tiddler. It's simply created.
At last the list is defined which retrieves all tiddlers tagged with {{person||showtag}} and transcluding them using the [[personEntry]] template.
See [[Person DB]] in action.
See also [[Persons by town]]…
{{$:/.tb/template/fields-non-standard}}
Rendered via <<source "$:/.tb/template/fields-non-standard">>
{{||$:/.tb/template/fields-custom-current}}
Rendered via template <<source "$:/.tb/template/fields-custom-current">>
Einzelfallbeurteilung, Rückzahlung ehrebedingter Verbindlichkeiten, also bis zur Trennung begründeter Schulden, in der Regel (+).
Ansonsten von Zweck der Verbindlichkeit, Zeitpunkt und Art ihrer Entstehung,
Dringlichkeit der beiderseitigen Bedürfnisse, Kenntnis des Unterhalts-verpflichteten
von Grund und Höhe der Unterhaltsschuld, Möglichkeit des Unterhaltsschuldners, die
Leistungsfähigkeit in zumutbarer Weise ganz oder teilweise wiederherzustellen und ggf. auch schutzwürdigen Belangen des Drittgläubigers abhängig. Berücksichtigung
nur in angemessenen Tilgungsraten und wenn tatsächlich Zahlung erfolgt.
Berücksichtigung von Zinsen und Tilgung beim Unterhalt
Easy Contact
Bei der Festlegung der Höhe eines Unterhaltsanspruches wird zuerst das unterhaltsrechtlich maßgebende Einkommen des Unterhaltsschuldners ermittelt. Das unterhaltsrechtliche Einkommen ist nicht immer identisch mit dem steuerrechtlichem Einkommen..
Grundsätzlich ist vom Bruttoeinkommen, der Summe aller Einkünfte, auszugehen. Vom Bruttoeinkommen sind Steuern und Sozialabgaben abzuziehen. Des Weiteren wird ein pauschaler Abzug berufsbedingter Aufwendungen in Höhe von 5 % vorgenommen.
Erst dann können berücksichtigungswürdige Schulden als Abzugsposten in Betracht kommen und das unterhaltsrechtliche Einkommen mindern.
Bei der Frage der Berücksichtigungswürdigkeit ist beim Ehegattenunterhalt dabei zu unterscheiden, ob es sich um nicht vermögensbildende Schulden (Konsumkredite, Schulden aus Überziehungskrediten, etc) oder um Verbindlichkeiten zur Vermögensbildung handelt. Zu unterscheiden ist ebenfalls, ob es sich um Schulden aus der Ehezeit oder nach Trennung/Scheidung entstandene neue Verbindlichkeiten handelt. Schulden, soweit diese berücksichtigungswürdig sind, sind im Rahmen eines vernünftigen Tilgungsplanes an in angemessenen Raten abzuzahlen. Auch eine Streckung von Schulden kann im Einzelfall verlangt werden, wenn sich das Kreditinstitut hierauf einlässt.
Bei einseitig vermögensbildenden Schulden ist immer zwischen Zins und Tilgung zu differenzieren.
Schulden aus der Ehezeit, die der einseitigen Vermögensbildung dienen, sind ab Rechtshängigkeit der Scheidung nur noch mit den Zinsen, nicht mehr mit der Tilgung zu berücksichtigen. Außer es handelt sich um eine zulässige Altersvorsorge (z.B.Tilgung von Immobiliendarlehen). In einem solchen Fall können 4 % vom Bruttoeinkommen als zweite Säule der Altersvorsorge ebenfalls berücksichtigt werden.
#Ipso iure
Ohne weitere rechtsgeschäftliche
Akte
Ex tunc
„von damals an“; von Anfang an
Ex nunc „von jetzt an“
Lex specialis Sondergesetz, das Vorrang hat
vor der Lex generalis => vorrangige
Prüfung!
Lex generalis Allgemeines Gesetz
Erläuternde Vertragsauslegung Mit ihr wird der Inhalt des Vertrages
bzw. seine Vertragsbestandteile
ermittelt => Kriterien:
Wortlaut, verfolgter Zweck, Verkehrssitte,
Treu u. Glauben
Ergänzende Vertragsauslegung Mit ihr werden Lücken rechtsgeschäftlicher
Vereinbarungen geschlossen
=> Eine ausfüllungsbedürftige
Lücke liegt dann vor,
wenn beim Vetragsschluss beide
Parteien einen bestimmten Umstand
nicht oder in falscher Weise
berücksichtigt haben. Dann
gilt es zu ermitteln, was bei dem
Vertrag beide Parteien gewollt
hätten, wenn sie den nicht bedachten
Umstand berücksichtigt
hätten (= Ermittlung des hypothetischen
Willens der Vertragsparteien)
#Analogie
Ausdehnung von Rechtssätzen
auf einen im Gesetz nicht geregelten
oder vom Gesetzeswortlaut
nicht mehr erfassten Fall =>
In der Praxis: Übertragung einer
im Gesetz enthaltenen Regelung
auf einen nicht geregelten Fall,
sofern 1. eine Regelungslücke
besteht, 2. die Regelungs-/Gesetzeslücke
vom Gesetzgeber
nicht beabsichtigt war u. 3. es
die Interessenlage gebietet, die
Lücke i. S. d. vorhandenen Regelung
zu schließen (Interessengleichheit)
Vereine (§§ 21 ff.) 1) Auf Dauer angelegte Verbindung
2) mehrerer 3) natürlicher
oder juristischer Personen 4) zur
Erreichung eines gemeinsamen
Zwecks, 5) die körperschaftlich
organisiert ist, 6) einen Gesamtnamen
führt u. 7) auf wechselnden
Mitgliederbestand angelegt
ist => BGB unterscheidet zwischen
ideellen, d. h. nichtwirtschaftlichen
(§ 21) u. wirtschaftlichen
(§ 22) Vereinen
Stiftungen (§§ 80 ff.) Vermögensmassen mit eigener
Rechtspersönlichkeit. Der Stifter
bestimmt den Zweck der Stiftung
=> Im Gegensatz zum Verein ist
sie keine Personenvereinigung,
hat keine Mitglieder, sondern lediglich
die von ihr begünstigten
Personen (Destinatäre)
Sachen Alle körperlichen Gegenstände
(Rechtsobjekte), § 90 => Beispiele
für „Nichtsachen“: Forderungen,
Daten. Tiere stehen gemäß
§ 90a im Ergebnis weitgehend
den Sachen gleich, da die
für Sachen geltenden Vorschriften
entsprechend angewendet
werden
Privatautonomie Recht des Einzelnen, seine Lebensverhältnisse
im Rahmen der
Rechtsordnung eigenverantwortlich
zu gestalten => Bspe.:
Vertrags-, Vereinigungs-, Eigentums-,
Testierfreiheit
Vertragsfreiheit Freie Entscheidung des Einzelnen,
ob und mit wem er einen
Vertrag schließt (Abschlussfreiheit)
und was dessen Inhalt
sein soll (Gestaltungsfreiheit)
Kontrahierungszwang Abschlusspflicht/ -zwang.
Rechtssatz, nach dem der Empfänger
eines Antrags nicht ablehnen
darf. Er muss den Antrag
annehmen => Der Kontrahierungszwang
ergibt sich unmittelbar
aus Gesetz, z. B. § 22 PBefG
für Beförderungsunternehmen
oder besteht bei Unternehmen
mit monopolartiger Stellung, z. B.
Post, Telekom, Stadtwerke. Bsp.:
Lokalzeitungen haben oft eine
Monopolstellung u. dürfen dann
die Annahme unpolitischer Anzeigen
nicht ablehnen. Falls dennoch
Ablehnung, Schadensersatzanspruch
prüfen (§§ 826, 249
S. 1). Aus § 826 könnte dann ein
Kontrahierungszwang folgen
Vereinigungsfreiheit Recht, Vereine und Gesellschaften
zu gründen (Art. 9 I GG),
auch Vereinsfreiheit
Eigentumsfreiheit Berechtigung des Einzelnen, Ei.-
gentum zu haben u. mit diesem
nach seinem Belieben zu verfahren
u. andere von jeder Einwirkung
auszuschließen (Art. 14 I
GG, § 903)
Testierfreiheit Recht des Einzelnen, durch Testament
zu bestimmen, an wen
nach seinem Tode sein Vermögen
fallen soll (§ 1937)
Rechtsgeschäft Besteht aus einer oder mehreren
Willenserklärungen, die allein
oder in Verbindung mit anderen
Tatbestandsmerkmalen eine
Rechtsfolge herbeiführen, weil
sie gewollt ist => Das Rechtsgeschäft
unterscheidet sich von den
geschäftsähnlichen Handlungen
u. von den Realakten. Des
Weiteren unterscheidet man zwischen
einseitigen u. mehrseitig-
5
en Rechtsgeschäften. Wegen
des im Zivilrecht geltenden Trennungs-
u. Abstraktionsprinzips
ist bei Rechtsgeschäften
weiter zu unterscheiden zwischen
Verpflichtungs- u. Verfügungsgeschäften
Geschäftsähnliche Handlungen Auf tatsächlichen Erfolg gerichtete
Erklärungen, deren RFen unabhängig
vom Willen kraft Gesetzes
eintreten => Bspe.: Androhung
(z. B. § 384 I), Mahnung
(§ 286 I, II), Fristsetzung (z. B.
§ 286 I), Aufforderung (z. B.
§ 108 II), Anzeige (z. B. § 170).
Die Erklärungen richten sich nicht
auf eine bestimmte gewollte RF,
sondern auf eine gesetzlich vorgesehene.
Bei den geschäftsähnlichen
Handlungen gelten die
Vorschriften für Rechtsgeschäfte
i. d. R. analog, wobei
dies jedes Mal ausdrücklich zu
begründen ist!
Realakte Tathandlungen. Willentliche Tathandlungen,
deren RFen unabhängig
vom Willen kraft Gesetzes
eintreten => Bspe.: Verbindung
(§§ 946, 947), Vermischung
(§ 948), Verarbeitung
(§ 950). Da diese Handlungen
nicht durch Erklärungen vorgenommen
werden, sind die Vorschriften
für Rechtsgeschäfte
auf Realakte nicht anwendbar u.
zwar auch nicht analog!
Einseitiges Rechtsgeschäft Die WE bereits einer Person
reicht aus, um eine bestimmte
rechtsgeschäftliche Folge auszulösen
=> Bspe.: Testament
(§ 2247), Auslobung (§ 657), Anfechtung
(§ 142), Rücktritt (§ 349)
Mehrseitiges Rechtsgeschäft Liegt vor, wenn es die WEen
mehrerer, mind. zweier, Personen
enthält => Bspe.: Vertrag (z.
B. Kaufvertrag § 433), Beschluss
Vertrag Rechtsgeschäft, das aus inhaltlich
übereinstimmenden, mit
Bezug aufeinander abgegebenen
WEen von mind. 2 Personen
besteht (Angebot u. Annahme)
Angebot Antrag/Offerte. Ist eine empfangsbedürftige
WE, durch die einem
anderen ein Vertragsschluss
so angetragen wird, dass
nur von dessen Einverständnis
das Zustandekommen des Vertrages
abhängt (u. zwar durch ein
schlichtes „ja“) => Abgrenzung
zur invitatio ad offerendum! Der
Antrag muss die sog. „essentialia
negotii“ zumindest erkennen lassen
Essentialia negotii Wesentliche Vertragspunkte
müssen bestimmt oder bestimmbar
sein: Vertragspartner, Geschäftstyp,
Geschäftsgegenstand
Annahme Ist eine empfangsbedürftige WE,
durch die der Antragsempfänger
dem Antragenden sein Einverständnis
mit dem angebotenen
Vertragsschluss zu verstehen
gibt => Kurzform: Vorbehaltloses
Einverständnis mit dem Antrag.
Lässt sich auf ein bloßes „ja“
beschränken, ansonsten neuer
Antrag, § 150 II. Annahme auch
durch schlüssiges Verhalten
möglich, z. B. durch Zahlung,
oder auch durch Schweigen bei
§ 362 HGB oder Schweigen auf
ein kaufmännisches Bestätigungsschreiben.
Beachte die Annahmefrist,
§ 147
Kaufmännisches Bestätigungs- Wiedergabe vorangegangener
schreiben Vertragsverhandlungen, die
noch nicht zum Vertragsschluss
geführt haben => Voraussetzungen:
a) Beide Parteien sind
Unternehmer (§ 14), nicht notwendig
Kaufleute; b) Parteien haben
Vertragsverhandlungen geführt;
c) Wiedergabe des wesentlichen
Vertragsinhalts =>
Schreiben darf nur soweit vom
Stand der Verhandlungen abweichen,
als aus objektiver Sicht die
Zustimmung des Empfängers zu
erwarten ist; d) Absender darf
nicht arglistig sein, d. h. er darf
nicht bewusst unrichtig oder
entstellt das Verhandlungsergebnis
wiedergeben (=> sonst: kein
Bestätigungsschreiben); e) Zugang
des Schreibens innerhalb
angemessener Frist; f) Kein
unverzüglicher Widerspruch des
Empfängers
Synallagmatische Verträge Gegenseitig verpflichtende
Verträge. Jede Partei verpflichtet
sich, weil und damit sich auch
die andere verpflichtet => Bspe.:
Dienst-, Werk-, Mietvertrag.
Exemplarisch am KV: Pflicht zur
Übergabe u. Übereignung einer
Sache, § 433 I 1; Pflicht zur Zahlung
des Kaufpreises, § 433 II.
Nur die vertragstypbestimmenden
Pflichten stehen immer im
Synallagma (z. B. § 535: Überlassung
der Mietsache Zahlung
der vereinbarten Miete), die
nicht vertragstypbestimmenden
Pflichten nur dann, wenn alle
Vertragsparteien dies ausdrücklich
bzw. konkludent bestimmen
oder dies die ergänzende
Vertragsauslegung ergibt
(§ 157). Beachte den Unterschied
zu zweiseitigen Schuldverhält-
8
nissen: Hier haben beide Parteien
Pflichten, allerdings stehen
diese nicht im Synallagma =>
Bsp.: Leihe (§§ 598, 604)
Genetisches Synallagma Keine synallagmatische Pflicht
entsteht ohne die andere
Funktionelles Synallagma Jede Partei braucht nur zu leisten,
wenn auch die andere leistet
(„Zug um Zug“), § 320. Diese Abhängigkeit
in der Erfüllung nennt
man das funktionelle Synallagma
Konditionelles Synallagma Wer nach § 275 I, II, III nicht zu
leisten braucht, verliert den Anspruch
auf die Gegenleistung
Beschluss WEen werden gebündelt dem
Empfänger gegenüber abgegeben
=> Dient der Willensbildung
im Gesellschafts- u. Vereinsrecht,
wobei für den Beschluss nicht
das Prinzip der Willensübereinstimmung,
sondern das Mehrheitsprinzip
gilt. Auch derjenige,
der sich nicht an der Abstimmung
beteiligt oder dagegen gestimmt
hat, wird an den Beschluss gebunden!
Verpflichtungsgeschäft Rechtsgeschäft, durch das die
Verpflichtung zu einer Leistung
begründet wird => Meistens ein
Vertrag, Bsp.: KV (§ 433). Gem.
§ 241 I begründet das Schuldverhältnis
lediglich eine Verpflichtung
gegenüber dem Vertragspartner,
das in einem Handeln,
Unterlassen oder Dulden bestehen
kann. D. h. im konkreten Bsp.
des § 433 I 1: Der Käufer erwirbt
durch den KV den Anspruch auf
Übergabe u. Übereignung der
Kaufsache, wobei sich durch das
Verpflichtungsgeschäft (hier: der
KV) unmittelbar nichts an der
9
Rechtslage der Kaufsache ändert,
d. h. allein durch das Verpflichtungsgeschäft
wird noch
keine Änderung der Eigentumslage
herbeigeführt, es bildet
lediglich den Rechtsgrund für
das Verfügungsgeschäft
Verfügungsgeschäft Rechtsgeschäft, das unmittelbar
auf ein Recht durch Übertragung,
Aufhebung, Belastung oder Inhaltsänderung
einwirkt => Bspe.:
Übertragung (z. B. § 929 S. 1),
Aufhebung (§ 875 I), Inhaltsänderung
(§ 877). Voraussetzungen
für ein wirksames Verfügungsgeschäft:
A) Verfügender
muss Verfügungsmacht über
die Sache besitzen. Diese steht
regelmäßig dem Inhaber des
Rechts zu. Bsp.: Eigentümer einer
Sache ist ermächtigt, durch
Übereignung der Sache nach
§ 929 darüber zu verfügen. Verfügungen
von einem Nichtberechtigten
sind unwirksam, es sei
denn in folgenden Fällen: 1) Einverständnis
des Rechtsinhabers
führt zur Wirksamkeit (§ 185 I); 2)
Genehmigung des Rechtsinhabers
(§ 185 II 1); 3) Guter Glaube
des Erwerbenden an das
Bestehen der Rechtsinhaberschaft
(z. B. § 932, aber beachte
§ 935); B) Wahrung des Bestimmtheitsgrundsatzes,
d. h.
die Verfügung muss sich auf
einen konkreten Gegenstand beziehen;
C) Wahrung des Publizitätsprinzips:
Rechtsgeschäfte
des Sachenrechts wirken gegenüber
jedermann, d.h. wirken absolut;
D) Geschäftsfähigkeit des
Verfügenden
10
Trennungsprinzip Trennung der schuldrechtlichen
Verträge von sachenrechtlichen
Übertragungsgeschäften
=> So bewirken schuldrechtliche
Geschäfte (Verpflichtungsgeschäfte)
keinerlei Gütertransfer.
Der erfolgt getrennt vom
Verpflichtungsgeschäft durch
Verfügungsgeschäfte!
Abstraktionsprinzip Das Verpflichtungsgeschäft u.
das Verfügungsgeschäft (dingliches
Erfüllungsgeschäft) existieren
rechtlich selbstständig u.
unabhängig voneinander =>
Bsp.: KV ist ungültig. Trotzdem
wirkt sich diese Ungültigkeit i. d.
R. nicht auf die Übereignung aus.
Der Käufer wird trotzdem Eigentümer,
allerdings muss er die
Sache nach den §§ 812 ff. an
den Verkäufer zurückübereignen.
Vorsicht: In diesen Fällen besteht
kein Herausgabeanspruch
nach § 985, sondern ein Bereicherungsanspruch
nach § 812
I 1
Willenserklärung Willensäußerung einer Person,
die auf die Herbeiführung einer
bestimmten RF gerichtet ist =>
Da der innerlich gebildete Wille
nach außen erklärt wird, besteht
eine WE aus dem subj. u. aus
dem obj. Tatbestand. Dabei ist
rechtlich nur der erklärte Wille u.
die aus obj. Sicht gewollte Erklärung
relevant. Der Wille kann dabei
ausdrücklich oder konkludent,
d. h. durch schlüssiges
Verhalten oder in seltenen Fällen
durch Schweigen erklärt werden.
Grundsatz: Schweigen ist keine
WE. Ausnahme: Schweigen
kann die Bedeutung einer WE
haben, wenn der andere unter
den konkreten Umständen nach
11
Treu u. Glauben unter Berücksichtigung
der Verkehrssitte (§§
133, 157) auf die Abgabe einer
WE schließen durfte. „Beredtes
Schweigen“ bei Parteivereinbarung.
Beachte bei AGB § 308 Nr.
5 BGB! „Normiertes Schweigen“
(gesetzlich geregelte WEen): z.
B. §§ 108 II2, 177 II 2, 416 I 2,
455 S. 2, 516 II 2
Konkludentes Verhalten Der Handelnde nimmt Handlungen
vor, die mittelbar einen
Schluss darauf zulassen, dass
ein bestimmter rechtlich gesicherter
wirtschaftlicher Erfolg
gewollt ist => Bspe.: Schlichte
Inanspruchnahme einer entgeltlich
angebotenen Leistung: Besteigen
der Straßenbahn, des
Busses; Annahme eines Vertragsangebots
durch Kopfnicken;
unkommentiertes Bezahlen des
Eintrittsgeldes
Subjektiver Tatbestand der WE Innerer Erklärungstatbestand der
WE. Dieser umfasst 4 Bestandteile:
Handlungswille, Erklärungsbewusstsein,
Geschäftswille,
Rechtsbindungswille
Handlungswille Wille, überhaupt etwas zu tun
oder bewusst zu unterlassen =>
Fehlt nur bei unbewussten Bewegungen
(z. B. Reflexe) u. vis absoluta,
d. h. bei unmittelbarer willlensausschließender
körperlicher
Gewalt. Fehlt der Handlungswille,
liegt grundsätzlich keine
WE vor (Mindestvoraussetzung
einer WE)!
Erklärungsbewusstsein Bewusstsein, etwas rechtlich Erhebliches
zu erklären => Rechtliche
Behandlung bei Fehlen des
Erklärungsbewusstseins: 1) Willlenstheorie:
Es liegt keine gültige
12
WE vor. 2) Erklärungstheorie (h.
M.): Hätte der Erklärende bei
pflichtgemäßer Sorgfalt erkennen
können u. müssen, dass sein
Verhalten als WE aufgefasst werden
könnte, wird ihm seine Erklärung
als WE zugerechnet.
Allerdings besteht ein Anfechtungsrecht
analog § 119 I 2. Fall.
Kannte der Erklärungsempfänger
das Fehlen des Erklärungsbewusstseins
oder durfte er aus
anderen Gründen nicht auf das
Geschäft vertrauen, ist eine Zurechnung
ausgeschlossen! Bsp.:
„Trierer Weinversteigerung“.
Hier winkt der ortsfremde Z bei
der Versteigerung durch Erheben
der Hand seinem Freund Y zu. Z
weiß nicht, dass hier das Handheben
die Abgabe eines um 50 €
höheren Kaufangebots bedeutet.
Der Versteigerer schlägt dem Z
das Fass Wein zu
Geschäftswille Wille des Erklärenden, eine ganz
bestimmte RF herbeizuführen,
z.B. ob eine Sache gekauft oder
gemietet werden soll. Das Fehlen
des Geschäftswillens ist stets unbeachtlich.
I. Z. gilt die WE so,
wie sie obj. zu verstehen ist, also
von einem vernünftigen Dritten
verstanden worden wäre. Aber:
Anfechtung nach den §§ 119 ff.
möglich, wobei der Erklärende
dann gem. § 122 auf Schadensersatz
haftet
Rechtsbindungswille Wille, sich rechtlich binden zu
wollen. Fehlt i.d.R. bei Gefälligkeiten,
Erteilen von Auskünften/
Ratschlägen/Empfehlungen und
der invitatio ad offerendum
Gefälligkeit Versprechen einer unentgeltlichen
Hilfe oder Annehmlichkeit.
13
Jemand wird also für einen anderen
tätig, überlässt ihm Sachen
oder bewahrt dessen Sachen auf,
ohne dafür ein Entgelt zu erhalten!
=> 3 Fallgruppen sind zu unterscheiden:
Gefälligkeitsvertrag;
Gefälligkeitsverhältnis; Alltägliche
Gefälligkeit
Gefälligkeitsvertrag Unentgeltlicher Vertrag, bei dem
keine Verpflichtung zur Gegenleistung
besteht. Eine echte vertragliche
Einigung liegt vor, die
nur einen der Vertragspartner zur
Leistung verpflichtet => Beteiligte
wollen sich vertraglich verpflichten,
haben also Rechtsbindungswillen!
Bspe.: §§ 516, 598, 662,
688. Bei Verletzung: Haftung
nach § 280 bzw. nach den entsprechenden
Haftungsprivilegierungen,
z. B. § 521
Gefälligkeitsverhältnis Gefälligkeitszusage. Bedeutet
die (oft unentgeltl.) Erbringung
einer Leistung, ohne dass dem
eine rechtliche Verpflichtung des
Leistenden zugrunde liegt. Die
Beziehungen der Beteiligten sind
nicht von einem gemeinsamen
Rechtsbindungswillen getragen,
sie handeln damit nicht auf vertraglicher
Grundlage, sondern
aus Gefälligkeit. => Entscheidendes
Abgrenzungskriterium zum
Gefälligkeitsvertrag ist also, ob
die Leistungszusage mit Rechtsbindungswillen
erfolgt (ermitteln
durch Auslegung der Erklärung,
§ 133). Liegt dieser den Erklärungen
erkennbar zugrunde, dann
Gefälligkeitsvertrag! Bei schuldhafter
Verletzung: Ansprüche aus
§§ 280 I, 241 II, 311 II; Verschuldensmaßstab
ist streitig: Analoge
Anwendung der Haftungsprivilegierungen,
d. h. Haftung auf Vorsatz
u. grobe Fahrlässigkeit
14
(BGH: normaler Haftungsmaßstab,
§ 276, d. h. Haftg. f. Vorsatz
u. jede Form von Fahrlässigkeit)
Alltägliche / reine Gefälligkeit Abreden, bei denen sich die Beteiligten
rechtlich nicht binden
u. damit keine WE abgeben u.
keine vertraglichen Pflichten eingehen
wollen => Es fehlt folglich
der Rechtsbindungswille! Bsp.:
Einladung zu einer Geburtstagsparty.
Bei Verletzung keine Haftung
des Betroffenen, weder auf
Erfüllung noch auf Schadensersatz!
Invitatio ad offerendum Aufforderung zur Abgabe einer
WE u. damit Aufforderung zur
Abgabe eines Angebots zu einem
Vertragsschluss => Hier fehlt
also der Rechtsbindungswille!
Bspe.: Zeitungsanzeigen, Schaufensterauslagen.
Würden dies
Angebote sein, könnte eine unbegrenzte
Anzahl von Personen
durch Annahme einen Vertragsschluss
zustande bringen. Dem
Anbieter wird das bei der invitatio
ad offerendum erspart. Die anderen
machen das Angebot, das
er dann annehmen oder ablehnen
kann, z. B. wenn diese zahlungsunfähig
sind
Freibleibendes Angebot 2 Auffassungen: 1) invitatio ad offerendum;
2) Verbindliches Angebot,
das aber noch unverzüglich
nach Zugang der Annahmeerklärung
widerrufen werden kann
(h.M.) => Bspe.: Angebot „freibleibend“,
„unverbindlich“
Objektiver Tatbestand der WE Äußerer Erklärungstatbestand
der WE => Gedankliche Hilfsfrage:
Wie ist das Verhalten aus der
Sicht eines obj. Dritten bzw. eines
vernünftigen Empfängers zu
15
würdigen (§ 133)? Für diesen obj.
Dritten (in der Rolle des Erklärungsempfängers)
muss sich das
Verhalten des Erklärenden als
die Äußerung eines Rechtsbindungswillen
darstellen. Für den
äußeren Erklärungstatbestand
spielt es also keine Rolle, ob der
Erklärende den zum Ausdruck
gekommenen Willen tatsächlich
hatte!
Empfangsbedürftige Willenserklärung WE, die einem anderen gegenüber
abzugeben ist (§ 130 I 1)
=> Wird nur mit Abgabe u. Zugang
der Erklärung wirksam;
Bspe.: Kauf-, Werk-, Dienstvertrag,
Kündigung, Anfechtung wegen
arglistiger Täuschung/Irrtums
(§ 143)
Nicht empfangsbedürftige WE Liegt vor, wenn sich aus dem Regelungszusammenhang
oder einer
ausdrücklichen Vorschrift ergibt,
dass ihre Wirksamkeit nicht
vom Zugang abhängt => § 130
gilt deshalb nicht! Bspe.: Testament
wird mit Abgabe wirksam;
Auslobung (§ 657); Eigentumsaufgabe
(§ 959)
Abgabe einer Willenserklärung Abgabe einer empfangsbedürf-
(unter Abwesenden) § 130 tigen WE liegt vor, wenn die Erklärung
vom Erklärenden willentlich
so in Verkehr gebracht wird,
dass ohne sein weiteres Zutun
der Zugang der Erklärung eintreten
kann => Bsp.: X lässt ein unterschriebenes
Schriftstück auf
seinem Schreibtisch liegen, das
seine Putzfrau findet u. es in den
Briefkasten wirft. Hilfsfrage: Hätte
der Erklärende damit rechnen
müssen? Wenn ja, dann gilt die
Erklärung als abgegeben! Im Fall
hätte X nicht damit rechnen müssen!
Abgabe einer nicht empfangsbedürftigen
WE ist die end-
16
gültige willentliche Entäußerung,
d. h. diese WEen werden bereits
in dem Zeitpunkt wirksam, in dem
sie formuliert werden
Zugang einer empfangsbedürftigen Zugegangen ist eine WE, wenn
Willenserklärung (unter Abwesenden) sie so in den Machtbereich des
Empfängers gelangt ist, dass mit
ihrer Kenntnisnahme durch den
Adressaten zu rechnen ist (§ 130
I 1) => Sowohl bei der Abgabe
als auch beim Zugang können
auf beiden Seiten Hilfspersonen
(Stellvertreter, Boten) zur Übermittlung
bzw. Entgegennahme
eingeschaltet werden. Zugang erfolgt
auch bei beschränkter Geschäftsfähigkeit
/ Geschäftsunfähigkeit
des Empfängers, § 131 I
u. II, jedoch erst wirksam, wenn
sie dem gesetzlichen Vertreter
zugeht! Ebenso erfolgt Zugang
bei unberechtigter Annahmeverweigerung.
Hier geht die Erklärung
in dem Moment zu, in dem
der Empfänger die Erklärung hätte
entgegennehmen können (=
Zugangsfiktion)
Abgabe einer Willenserklärung Schriftliche Erklärung: Abgege-
(unter Anwesenden) ben, wenn sie dem Anwesenden
zur Entgegennahme überreicht
wird; Mündliche Erklärung: Abgegeben,
wenn der Erklärende
sie ausgesprochen hat
Zugang einer Willenserklärung Schriftliche Erklärung: Zuge-
(unter Anwesenden) gangen, wenn sie dem Anwesenden
übergeben, d.h. ausgehändigt
wird u. somit in seinen Herrschaftsbereich
gelangt. Mündliche
Erklärung: Nach der eingeschränkten
Vernehmungstheorie
(h. M.) geht die Erklärung zu,
wenn der Empfänger sie akustisch
vernommen hat bzw. wenn
der Erklärende damit rechnen
17
konnte, dass der Empfänger seine
Erklärung richtig u. vollständig
verstanden hat
Erklärungsbote Derjenige, der nach der Verkehrsanschauung
als nicht ermächtigt
anzusehen ist, z.B. Kinder
oder Nachbarn. Mögliche
Fehler des Boten gehen zu Lasten
des Erklärenden (aber: Anfechtung
bei unbewusst falscher
Übermittlung nach § 120 möglich).
Erklärung ist zugegangen,
wenn sie an den Empfänger tatsächlich
übermittelt worden ist.
Empfangsbote Derjenige, der vom Empfänger
zur Empfangnahme bestellt bzw.
ermächtigt ist oder nach der
Verkehrsanschauung als ermächtigt
gilt u. hierzu bereit u.
geeignet ist => Bspe.: Ehepartner,
Oma, Opa, Haus-, Büroangestellte;
Keine Empfangsboten:
Der im Haus zufällig arbeitende
Handwerker, Nachbarn, 3jähriges
Kind. Erklärung ist dann zugegangen,
wenn mit der Weiterleitung
an den Empfänger unter
normalen Umständen zu rechnen
ist. Mögliche Übermittlungsfehler
des Boten gehen zu Lasten
des Empfängers. Beachte: Eine
Person, die vom Empfänger nicht
bestellt ist u. auch keine Vertretungsmacht
für ihn hat, ist dann
als Bote des Erklärenden anzusehen.
Die Erklärung von diesem
Boten geht dann erst zu, wenn
sie tatsächlich in den Herrschaftsbereich
des Empfängers
gelangt ist (beachte § 150 I)!
Widerruf Empfangsbedürftige WE, die dem
Empfänger zu erkennen gibt,
dass eine gültige WE nicht
wirksam werden soll (§ 130 I 2)
18
=> Nur wirksam, wenn der Widerruf
spätestens gleichzeitig mit
der ursprünglichen WE zugeht.
Unerheblich, welches Schriftstück
der Empfänger zuerst gelesen
hat!
Falsa demonstratio non nocet Falschbezeichnung schadet
nicht. Die Parteien erklären obj.
etwas anderes, als sie subj.
übereinstimmend wollten => Gemeinsames/r
missverstandenes/r
Wort/ganzer Satz/Vertrag. Bsp.:
Parteien verwenden einen einzelnen
Ausdruck übereinstimmend
falsch. 2 Deutsche schlossen einen
KV über „Haakjöringsköd“,
was auf norwegisch „Haifleisch“
bedeutet, verstanden aber beide
darunter Walfleisch. Gegenstand
des KV war trotz der falschen Bezeichnung
Walfleisch!
Dissens Einigungsmangel. Zwischen
den rechtlich relevanten Inhalten
der WEen der Parteien besteht
keine vollständige Übereinstimmung
Totaldissens Ohne Einigung über die wesentlichen
Vertragsbestandteile
kommt ein Vertrag nicht zustande
=> Auf §§ 154, 155 darf nicht
zurückgegriffen werden!
Offener Dissens § 154. Einigung über vertragliche
Nebenpunkte konnte nicht erzielt
werden u. diese mangelnde Einigung
ist den Parteien bekannt
=> „Im Zweifel“ ist der Vertrag
nicht zustande gekommen (§ 154
I 1). Den Parteien steht es somit
frei, den Vertrag als geschlossen
anzusehen, d. h. § 154 enthält lediglich
eine Auslegungsregel!
19
Versteckter Dissens § 155. Der Einigungsmangel ist
den Parteien unbekannt geblieben,
weil 1) ein regelungsbedürftiger
Punkt vergessen oder übersehen
wurde, 2) die WEen bereits
äußerlich voneinander abweichen,
die Parteien ihre Erklärungen
aber wechselseitig mißverstehen
u. an das Zustandekommen
eines Vertrages glauben
(= Erklärungsdissens), 3) das
Erklärte obj. mehrdeutig ist u.
sich im Wege der Auslegung kein
eindeutiger Sinn ermitteln lässt (=
Scheinkonsens). Es ist dann zu
fragen, ob die Parteien den Vertrag
auch ohne die entsprechende
Vereinbarung geschlossen
hätten. Wenn ja, so ist der Vertrag
zustande gekommen! Bspe.:
zu 1): Kaufvertragsschluss ohne
Einigung über den Preis; zu 2): X
u. Y verhandeln telegraphisch in
Kürzeln über eine Ware u. werden
sich „einig“. Als X Erfüllung
verlangt, stellt sich heraus, dass
beide verkaufen wollten; zu 3):
Vor Euroeinführung: Vertragsschluss
zwischen einem Belgier
u. einem Franzosen in einem dritten
Land über „Francs“, wenn jeder
seine Heimatwährung gemeint
hat, belgische / franz.
Francs => Versteckter Dissens.
Durch Auslegung nicht festzustellen,
welche Währung gelten soll,
d. h. Vertrag ist unwirksam!
Geschäftsunfähigkeit § 104 Nr. 1. Wer das 7. Lebensjahr
noch nicht vollendet hat =>
Fristberechnung: § 187 II S. 2, d.
h. Geschäftsunfähigkeit dauert
bis zum Beginn (0.00 Uhr) des
Geburtstags, an dem das Kind 7
Jahre alt wird => RF: § 105 I.
Nach § 104 Nr. 2 bezieht sich die
Geschäftsunfähigkeit auf alle
20
Rechtsgeschäfte. Anerkannt ist
aber auch eine partielle Geschäftsunfähigkeit
Partielle Geschäftsunfähigkeit Die krankhafte Störung der Geistestätigkeit
kann auf einen bestimmten
Lebensbereich begrenzt
sein. Für alle übrigen Geschäfte
besteht dann weiter volle
Geschäftsfähigkeit => Bspe.:
Kann bei krankhafter Querulanz
in Rechtsstreitigkeiten, bei krankhafter
Eifersucht für Fragen der
Ehe vorliegen
Relative Geschäftsunfähigkeit Auf schwierige Rechtsgeschäfte
begrenzte Geschäftsunfähigkeit,
da fehlendes Verständnis => Für
jene Personen von Bedeutung,
die aufgrund des Geisteszustandes
nur die einfachen Geschäfte
des täglichen Lebens zu besorgen
vermögen. Bsp.: Versicherungsverträge.
H. M. lehnte dies
ab. Streit nicht mehr relevant, da
seit August 2002 § 105a existiert!
Beachte: § 105a bezieht sich nur
auf volljährige Geschäftsunfähige,
Leistung u. ggf. Gegenleistung
müssen bewirkt sein. Vertragliche
Sekundäransprüche,
wie Schadensersatz, können gegen
den Geschäftsunfähigen
nicht begründet werden! Dagegen
können vertragliche Folgeansprüche
zugunsten des Geschäftsunfähigen
bestehen!
Ausschließender Zustand der freien § 104 Nr. 2. Person muss aufWillensbestimmung
grund ihres Geisteszustandes
außerstande sein, ihre Entscheidungen
von vernünftigen Erwägungen
abhängig zu machen =>
Zustand muss von Dauer sein
(Abgrenzung zur vorübergehenden
Störung, wie z. B. bei Voll-
21
trunkenheit, § 104 Nr. 2 nicht einschlägig!)
Bewusstlosigkeit (§ 105 II) Hochgradige Bewusstseinstrübung,
die das Erkennen von Inhalt
u. Wesen der Handlung ganz
oder in bestimmter Richtung ausschließt
=> Bsp.: Volltrunkenheit.
Entscheidender Unterschied zu
§ 104 Nr. 2, § 105 I: dem Bewusstlosen/Volltrunkenen
kann
eine WE wirksam zugehen!
Beschränkte Geschäftsfähigkeit § 106. Minderjähriger, der das 7.,
aber noch nicht das 18. Lebensjahr
vollendet hat => Fristberechnung
wie bei § 104 Nr. 1 nach
§ 187 II S. 2: Beginn der Geschäftsfähigkeit
an dem 7. Geb.
0.00 Uhr u. endet an dem 18. um
0.00 Uhr! Zentrale Norm: § 107.
Einwilligung (§ 107) Vorherige Zustimmung, § 183 S.
1
Genehmigung (§ 108) Nachträgliche Zustimmung,
§ 184 I
Lediglich rechtlich vorteilhaft (§ 107) Sind nur solche Rechtsgeschäfte
oder Zuwendungen, die die
Rechtsstellung eines beschränkt
Geschäftsfähigen ausschließlich
verbessern => Beachtung des
Abstraktionsprinzips: getrennte
Prüfung von Verpflichtungs- u.
Verfügungsgeschäft! Bei der Beurteilung
kommt es nicht auf den
wirtschaftlichen Vor- oder Nachteil
für den Minderjährigen an.
Bsp.: X bietet dem 15jährigen Y
ein kaum gebrauchtes Mountainbike
zum Freundschaftspreis von
20 € an. Y kauft ohne Wissen seiner
Eltern das Rad. Hier ist der
KV (Verpflichtungsgeschäft) für Y
aber nicht lediglich rechtlich vorteilhaft,
weil er für ihn die Pflicht
22
zur Kaufpreiszahlung (§ 433 II)
mit sich bringt. Beachte: Ein Verpflichtungsgeschäft
ist nur
dann zustimmungsfrei, wenn der
Minderjährige daraus nur einen
Anspruch erwirbt, jedoch selbst
keine Verpflichtung eingeht.
Bspe.: Schenkungsversprechen
(§ 518 I), Annahme eines Schuldversprechen
(§ 780), Schuldanerkenntnis
(§ 781). Rechtlich nachteilig
ist die Entgegennahme einer
Leistung als Erfüllung (§ 362
I). Hierdurch verliert nämlich der
Minderjährige seinen Anspruch.
Begründung: Dem Minderjährigen
fehlt die Empfangszuständigkeit,
die sich nach den Grundsätzen
der Verfügung (nach §
107) beurteilt. Bsp.: 16jähriger X
hat sein Mountainbike für 30 € an
den 20jährigen Y verkauft, der X
gleich das Geld gab. X verprasst
das Geld. Seine Eltern erfahren
am Abend von dem "Geschäft“ u.
verlangen von Y erneut Bezahlung
=> Für die Entgegennahme
des Kaufpreises fehlte X die
Empfangszuständigkeit, Folge:
trotz Eigentumsübergangs ist die
Forderung des X gegen Y nicht
gem. § 362 I erloschen. Allerdings:
Anspruch des Y aus
§§ 812 ff. auf Rückforderung des
Geleisteten. Beachte aber § 818
III. Stimmen also die gesetzlichen
Vertreter nicht zu, erwirbt der
Minderjährige die geleistete
Sache bzw. das geleistete Recht,
ohne dass sein Erfüllungsanspruch
erlischt! Dagegen sind
Verfügungsgeschäfte für den
Minderjährigen lediglich rechtlich
vorteilhaft, wenn zu seinen Gunsten
ein Recht übertragen, aufgehoben,
verändert oder belastet
wird. Zum 1. Bsp. (15jähriger Y):
23
Die Aushändigung des Rads ist
als Übereignung nach § 929 S. 1
zu werten. Dieses Rechtsgeschäft
ist für Y lediglich rechtlich
vorteilhaft, weil er dadurch das
Eigentum am Rad erwirbt, ohne
Rechtsnachteile zu erleiden! Y ist
also Eigentümer des Rads geworden.
Jedoch muss er es nach
§ 812 I wegen unwirksamen KV
an X zurückgeben. Weiterer Fall:
Verfügungen des Minderjährigen
über fremde Rechte: Nach h. M.
liegt hier bei der Verfügung als
Nichtberechtigter ein neutrales
Rechtsgeschäft vor, dass der
Minderjährige ohne Mitwirkung
seines gesetzlichen Vertreters
vornehmen kann. Beachte: Zuwendung
belasteter Gegenstände.
Bsp.: Tante X übereignet
ihrer 15jähr. Nichte ein Grundstück
im Wert von 150000 €, auf
dem eine Hypothek in Höhe von
400.000
€ lastet. Hier haftet der
beschränkt Geschäftsfähige nicht
persönlich, sondern kann
schlimmstenfalls das Grundstück
im Wege der Zwangsversteigerung
verlieren (Steuern oder
kommunale Abgaben bleiben
außer Betracht). Folglich ist eine
Übertragung des Grundstücks
ohne Zustimmung der Eltern
möglich! Gleicher Fall z. B. auch
bei Grundschuld (§ 1191), Nießbrauch
(§ 1030). Nachteilig: z. B.
Erwerb eines Grundstücks, das
mit einer Reallast belastet ist!
Indifferente Geschäfte Neutrale Rechtsgeschäfte, die
für den beschränkt Geschäftsfähigen
weder rechtlich vorteilhaft
noch nachteilig sind, kann dieser
auch selbst wirksam vornehmen
=> Bsp.: Rechtsgeschäfte, die ein
24
Minderjähriger als Vertreter eines
anderen tätigt
Einzeleinwilligung Spezialeinwilligung. Einwilligung
kann für ein bestimmtes
Rechtsgeschäft erteilt werden =>
Bsp.: Vater gibt seinem 17jährigen
Sohn Geld, damit er das Niederle-BGB-Skript
kaufen kann
Beschränkter Generalkonsens / General- Einwilligung des gesetzlichen
einwilligung Vertreters kann sich auch auf eine
bestimmte Art oder einen bestimmten,
abgrenzbaren Kreis
noch nicht individualisierter
Rechtsgeschäfte beziehen => Allerdings
kann sich der Generalkonsens
nur auf solche Geschäfte
erstrecken, die üblicherweise
mit dem Vorhaben des Minderjährigen
verbunden sind (i. Z.:
enge Auslegung!). Bsp.: Erlaubnis
der Eltern zu einer Ferienreise
ihres 16jährigen Sohnes enthält
auch die Einwilligung in die
dazu erforderlichen Rechtsgeschäfte,
z. B. Kauf von Speisen
u. Getränke, nicht jedoch von Zigaretten
u. Alkohol! Problem:
Schwarzfahrten. Bsp.: Vater gibt
regelmäßig seinem Sohn (14 J.)
2,50 € für die Bahn zur Schule.
Sohn löst keinen Fahrschein, um
das Geld zu behalten. Er wird erwischt
u. ein Beförderungsgeld i.
H. v. 50 € erhoben. Liegt ein beschränkter
Generalkonsens vor,
der sich auf sämtliche Bahnfahrten
zur Schule bezog u. damit
auch auf die Schwarzfahrt? Die
Einwilligung des gesetzlichen
Vertreters zur Benutzung öffentl.
Verkehrsmittel gilt i. Z. nicht für
Schwarzfahrten (h. M.) => Beförderungsvertrag
schwebend unwirksam;
Verweigerung der Genehmigung
der Schwarzfahrt sei-
25
tens des Vaters; Vertrag unwirksam.
Aber: Anspruch der Bahn
AG auf Zahlung des normalen
Fahrpreises gem. §§ 812 I S. 1 1.
Fall, 818 II (nur Sohn ist bösgläubig,
nicht jedoch der Vater)
Taschengeldparagraph § 110. Konkludente Einwilligung
der gesetzlichen Vertreter durch
Überlassen von Mitteln, z. B. Taschengeld
=> Umfang ergibt sich
aus der mit der Überlassung der
Mittel verbundenen Zweckbestimmung.
Geschäft wird erst wirksam,
wenn der Minderjährige die
vertragsgemäße Leistung bewirkt
hat. Teilzahlungsgeschäfte werden
folglich erst mit Bezahlung
der letzten Rate wirksam! Durch
Auslegung ist zu ermitteln, ob u.
wie der Minderjährige mit den
Gegenständen verfahren darf, die
er mit den Mitteln erworben hat
(Zweckbestimmung). Bsp.: Lottogewinn
Ermächtigung Der Ermächtigte handelt im eigenen
Namen, mit der Folge, dass
das Rechtsgeschäft in seiner
Person zustande kommt
Erwerbsgeschäft (§ 112) Jede erlaubte, selbstständig, berufsmäßig
ausgeübte u. auf Gewinn
gerichtete Tätigkeit
Dienst oder Arbeit (§ 113) Jede Tätigkeit selbstständiger
oder unselbstständiger Art => Berufsausbildungsverhältnisse
fallen nicht unter § 113 (h. M.),
hier steht nicht die Dienst- oder
Arbeitsleistung im Vordergrund!
Ermächtigung erfasst nur Rechtsgeschäfte,
die verkehrsüblich
sind!
26
Bedingung Eine durch den Parteiwillen in
ein Rechtsgeschäft eingefügte
Bestimmung, welche die Rechtswirkungen
des Geschäfts von einem
zukünftigen ungewissen
Ereignis abhängig macht =>
§§ 158 ff. Zwei Arten der Bedingung:
die aufschiebende (§ 158
I) u. die auflösende (§ 158 II).
Bsp.: Schenkung unter der Bedingung,
dass der Beschenkte etwas
tut. Bspe. für keine Bedingung:
sog. Rechtsbedingung;
Vergangenes oder gegenwärtiges
Ereignis (sog. uneigentliche
Bedingung), Bsp.: Jurastudent
verkauft seinen Schönfelder unter
der Bedingung, dass er das Examen
bestanden hat. Wenn das
Ergebnis bereits im Zeitpunkt des
Vertragsschlusses feststeht, liegt
eine uneigentliche Bedingung
vor. Teilweise wird dann vertreten,
§ 158 analog anzuwenden
Rechtsbedingung Wenn die Parteien ein gesetzliches
Wirksamkeitserfordernis
zur Bedingung des Rechtsgeschäfts
machen => Bsp.: Minderjähriger
kauft unter der Bedingung
ein Fahrrad, dass seine Eltern
nachträglich zustimmen
Aufschiebende Bedingung Die gewollten Rechtswirkungen
treten erst mit Eintritt der Bedingung,
d. h. des zukünftigen ungewissen
Ereignisses, ein (§ 158
I) => Bsp.: Veräußerung unter Eigentumsvorbehalt,
d. h. Übereignung
einer beweglichen Sache
unter der aufschiebenden Bedingung
der vollständigen Bezahlung
des Kaufpreises. Für Verfügungsbefugnis,
Geschäftsfähigkeit
u.s.w. des Veräußerers
kommt es allein auf den Zeitpunkt
der Vornahme des Rechtsge-
27
schäfts an, sodass ein Erwerb
vom Nichtberechtigten möglich ist
(jedoch Voraussetzung: gutgläubiger
Vorbehaltserwerber)!
Auflösende Bedingung Die Rechtswirkungen entfallen
mit Eintritt der Bedingung (§ 158
II) => Bsp.: X übereignet dem Y
sein Auto. Das Eigentum soll automatisch
wieder an X zurückfallen,
wenn X das ihm von Y gewährte
Darlehen zurückzahlt
Bedingungsfeindliche Rechtsgeschäfte Rechtsgeschäfte, die einen
Schwebezustand nicht vertragen
u. die deshalb nur unbedingt
vorgenommen werden dürfen =>
Bspe.: Aufrechnungserklärung (§
388 S. 2), Auflassung (§ 925 II),
Eheschließung (§ 1311 S. 2). Bedingung
ist aber ausnahmsweise
dann zulässig, wenn der Erklärungsgegner
damit einverstanden
oder der Bedingungseintritt
vom Verhalten des Empfängers
abhängig ist!
Befristung Wenn für die Wirkungen eines
Rechtsgeschäfts ein Anfangsoder
ein Endtermin vorgesehen
ist (§ 163) => Gegensatz zur Bedingung:
Die Wirkung eines
Rechtsgeschäfts hängt bei der
Befristung von einem zukünftigen
gewissen Ereignis ab (Maßgebend:
Auslegung!) => Bsp.: Abschluss
eines Arbeitsvertrages
für die Zeit vom 1.7. bis zum
31.7. Bedingungsfeindl. Rechtsgeschäfte
sind grundsätzlich
auch befristungsfeindlich!
Fernabsatzvertrag Legaldefinition in § 312b I
Rechtshindernde Einwendung Hier entsteht erst gar nicht ein
Anspruch => RF: Grundsätzlich
Nichtigkeit des Rechtsgeschäfts
28
(ex tunc). Bspe.: §§ 104 ff, §§
116-118, §§ 125 ff., § 134, § 138
Rechtsvernichtende Einwendung Zunächst entstandener Anspruch
wird rückwirkend zerstört =>
Bspe.: Anspruch kann nachträglich
durch Erfüllung (§ 362), Aufrechnung
(§ 389), Anfechtung (a.
A.: Anfechtung ist eine rechtshindernde
Einwendung) erlöschen
Einrede Geltendmachung eines Leistungsverweigerungsrechts
durch den Schuldner => Schuldner
kann dieses Recht geltend
machen, er muss es aber nicht.
Sofern er davon Gebrauch
macht, geht der Anspruch nicht
unter, sondern wird nur in seiner
Durchsetzung gehemmt. 2 Arten
von „Hemmungen“: dilatorische
und peremptorische Einrede
Dilatorische Einrede Aufschiebende Einrede. Hemmt
die Durchsetzung eines Anspruchs
nur zeitweilig => Bspe.:
Zurückbehaltungsrecht (§ 273),
Nichterfüllter Vertrag (§ 320),
Stundung, Vorausklage (§ 771)
gewähren dem Schuldner das
Recht, die Leistung vorübergehend
zu verweigern
Peremptorische Einrede Dauernde Einrede. Hemmt die
Durchsetzung eines Anspruchs
dauernd => Bsp.: Einrede der
Verjährung (§§ 214 ff.)
Mentalreservation Geheimer Vorbehalt, § 116
Scheingeschäft Simuliertes Geschäft, § 117 =>
Kennzeichen: Einverständlicher
Mangel eines Rechtsbindungswillens.
Unterschied zu § 116 u.
§ 118: Einverständnis des Er-
29
klärenden u. des Erklärungsempfängers,
dass das Geschäft nicht
gelten soll. Bsp.: X gibt bei einer
Auktion im Einverständnis mit
dem Auktionator Y ein Gebot ab,
um zum Höherbieten zu animieren.
Keine Scheingeschäfte sind:
Treuhand-, Strohmann- u. Umgehungsgeschäfte
Treuhandgeschäft Liegt vor, wenn jemand einen anderen
(den Treuhänder) juristisch
zum Inhaber eines Rechts macht,
obwohl dieser das Recht, wirtschaftlich
gesehen, nur verwalten
soll => Bsp.: Da X überschuldet
ist, übereignet er seinen Jaguar
an seine Freundin Y, um ihn vor
dem Gerichtsvollzieher in Sicherheit
zu bringen. Wirksame Übereignung,
kein Scheingeschäft!
Strohmanngeschäft Der an dem Rechtsgeschäft Interessierte
möchte nicht selbst
als Geschäftspartner auftreten u.
schiebt daher einen anderen (den
sog. Strohmann) als Vertragspartei
vor. Dieser schließt das erstrebte
Rechtsgeschäft im eigenen
Namen, aber für Rechnung
seines „Hintermanns“ ab => Bsp.:
Autohändler X will neue AudiFahrzeuge
anbieten, wird jedoch
von Audi nicht beliefert. Deswegen
bedient er sich zum Ankauf
eines Strohmannes
Umgehungsgeschäft Liegt vor, wenn die Beteiligten ein
Rechtsgeschäft tätigen, das nur
der Umgehung der für das wirklich
gewollte Rechtsgeschäft geltenden
Vorschriften dient =>
Bsp.: Der überschuldete X will die
bevorstehende Lohnpfändung
abwenden u. vereinbart arbeitsvertraglich
mit seinem Arbeitgeber
Y, dass X kein Gehalt mehr
30
bezieht u. dass stattdessen Frau
X Zahlungsansprüche gegen Y
zustehen sollen. Kein Scheingeschäft,
beachte jedoch: Umgehungsgeschäft
eventuell aus einem
anderen Grund (z. B. nach
§ 134, § 138) nichtig
Scherzerklärung § 118 => Erklärender geht davon
aus, der andere wird die Nichternstlichkeit
der Erklärung erkennen
(„guter Scherz“); Motiv
(z. B. Prahlerei) des Erklärenden
spielt keine Rolle! Entscheidend
ist nur, dass der Erklärende ohne
Täuschungsabsicht handelt, d. h.
es spielt keine Rolle, ob der andere
die Nichternstlichkeit überhaupt
erkennt oder wenigstens
erkennen kann. Bsp.: Wegen einer
Reifenpanne an seinem nagelneuen
Jaguar lässt sich X darüber
am Abend am Stammtisch
aus u. bietet ihn seinem Freund Y
für 500 € an. Der willigt sofort ein
u. will ihn am nächsten Tag abholen,
worauf X kopfschüttelnd
meint, dass das Angebot doch
nicht ernst gemeint war. Hier darf
X davon ausgehen, dass die
Nichternstlichkeit seines Angebots
erkannt wurde (krasses
Missverhältnis zwischen den
Werten!). Y hat keinen Anspruch
auf Übereignung und Schadensersatz
(da § 122 II: „fahrlässig“)
Urkunde (§§ 126 ff.) Jede schriftlich verkörperte WE,
die geeignet u. bestimmt ist, im
Rechtsverkehr Beweis zu erbringen,
u. den Aussteller erkennen
lässt. Kurz: Jedes Schriftstück
=> Bspe.: Kopie, Fax, Telegramm,
Vordrucke
31
Auf andere zur dauerhaften Wiedergabe § 126b. Erklärungen, die vor alin
Schriftzeichen geeignete Weise lem auf elektronischen Medien
gespeichert sind => Bspe.: USBStick,
CD, Festplatte
Unterzeichnet (§ 126) Unterschrift muss unter dem Text
der Urkunde stehen, sie also
räumlich abschließen => Nachträge,
anders als eingefügte Änderungen,
müssen erneut unterschrieben
werden
Unterschrift (§ 126) Individueller Schriftzug =>
Braucht nicht lesbar sein, muss
jedoch zumindest einzelne Buchstaben
erkennen lassen. I. d. R.
Unterzeichnung mit dem Familiennamen,
nur der Vornamen genügt
nicht! Auch reichen Kürzel
oder Handzeichen nicht aus!
Pseudonym nur, wenn es im Melderegister
eingetragen ist
Eigenhändig (§ 126) Handschriftlich => Nicht ausreichend:
Stempelaufdruck, eingescannte
Unterschrift, unterschriebenes
Telefax (da nur
Fernkopie, kein Original!)
Notarielle Beurkundung (§ 128) Notar bestätigt in einer Urkunde,
dass jemand in seiner Gegenwart
eine bestimmte, wörtlich wiedergegebene
WE abgegeben hat =>
Für die sachliche Richtigkeit
übernimmt der Notar aber keine
Gewähr!
Beglaubigung (§ 129) Bestätigung / Zeugnis eines Notars,
dass eine Unterschrift in
seiner Gegenwart vollzogen bzw.
anerkannt wurde (§ 40 I BeurkG)
=> Beglaubigung sichert also nur
gegen Unterschriftsfälschung
u. bezieht sich nicht auf den Text,
wie es bei der Beurkundung der
Fall ist. Bsp.: Vorgesehen in § 29
I GBO
32
Gesetzliche Vertretung Geschäftsunfähige u. juristische
Personen können nicht
selbst rechtsgeschäftlich handeln.
Ihnen ist daher ein gesetzlicher
Vertreter zur Seite gestellt
=> Bspe.: gesetzliche Vertreter
des Minderjährigen sind seine Eltern
(§ 1629); Verein wird durch
Vorstand (§ 26 II 1) vertreten
Gewillkürte Vertretung Wer nicht selbst rechtsgeschäftlich
handeln will, kann andere
Personen bevollmächtigen, für
ihn tätig zu werden => Fall des
§ 164! Bsp.: X möchte ein Auto
beim Händler Y kaufen, muss
aber verreisen. Er bevollmächtigt
deshalb seinen Freund Z, für ihn
den Kauf zu tätigen
Mittelbare Stellvertretung Wenn jemand ein Rechtsgeschäft
im eigenen Namen, aber im Interesse
u. für Rechnung des
Geschäftsherrn vornimmt. Kein
Fall der in §§ 164 ff. geregelten
unmittelbaren Stellvertretung! =>
Schließt er einen Vertrag, wird er
selbst Vertragspartei, nicht sein
Auftraggeber. Die Rechte des
mittelbaren Vertreters werden nur
durch ein weiteres Rechtsgeschäft
an den Geschäftsherrn
übertragen. Bsp.: Tätigkeit des
Kommissionärs (§ 383 ff. HGB)
Repräsentationsprinzip Der Vertretene wird durch den
Vertreter, der für ihn handelt, repräsentiert
Stellvertretung Rechtsgeschäftliches Handeln im
Namen des Vertretenen mit der
Wirkung, dass die Rechtsfolgen
unmittelbar in der Person des
Vertretenen eintreten (= unmittelbare
Stellvertretung) => Geregelt
in den §§ 164 ff. Vorauss.
des § 164 I 1: 1) Zulässigkeit der
33
Stellvertretung, 2) Eigene WE
des Vertreters, 3) Handeln im
fremden Namen (Offenkundigkeitsprinzip),
4) Bestehen einer
Vertretungsmacht
Aktiv-Vertretung § 164 I. Wenn es sich um die Abgabe
einer WE handelt, spricht
man von aktiver Vertretung
Passiv-Vertretung § 164 III. Wenn es sich um den
Empfang einer WE handelt,
spricht man von passiver Vertretung
Zulässigkeit der Stellvertretung Vertretung ist nicht nur bei
Rechtsgeschäften, sondern
auch bei rechtsgeschäftsähnlichen
Handlungen, wie z. B.
Mahnung, möglich, allerdings unter
analoger Anwendung der §§
164 ff. Dagegen ist sie bei Realakten
nicht anwendbar! Auch ist
sie bei höchstpersönlichen
Rechtsgeschäften ausgeschlossen
=> Bspe.: Erbvertrag (§
2274), Eheschließung (§ 1311),
Testamentserrichtung (§ 2064)
Eigene WE des Vertreters Abgrenzung zur Botenschaft:
Vertreter gibt eine eigene WE ab,
während der Bote nur eine fremde
WE überbringt => Abgrenzung
problematisch, dann durch
Auslegung (§§ 133, 157) ermitteln!
Entscheidend für die Abgrenzung
ist das äußere Auftreten
(obj. Empfängerhorizont).
Stellvertretung verlangt zumindest
eine beschränkte Geschäftsfähigkeit
(§ 165) des Vertreters,
Botenstellung kann auch von einem
Geschäftsunfähigen vorgenommen
werden! Bei Willensmängeln:
Über § 164 I werden
WEen zugerechnet, über § 166 I
erfolgt eine Wissenszurechnung.
34
Regel: Abzustellen ist hier einzig
auf den Vertreter. Beachte auch
§ 166 II!
Vertreter mit gebundener Marschroute Vertreter ist der Handelnde auch
dann, wenn er das ihm vom Geschäftsherrn
aufgetragene, inhaltlich
bestimmte Rechtsgeschäft
genauso tätigt, aber als Vertreter
auftritt => Trotz sehr geringem
Maß an Entscheidungsfreiheit
dennoch Vertreter!
Offenkundigkeitsprinzip Vertreter muss seine WE im Namen
des Vertretenen abgeben,
d. h. er muss kundtun, dass die
RFen nicht ihn, sondern einen
anderen treffen => Dies kann in
ausdrücklicher Form geschehen.
Bsp.: X sagt dem Y, er wolle das
Buch für Z erwerben. Aber es
kann auch in schlüssiger Weise
offenkundig gehandelt werden.
Bsp.: Bei der Kassiererin A im
Supermarkt des B ergibt sich aus
dem Umstand, dass sie für B
handelt, weil sie eben dort an der
Kasse sitzt. Richtet sich der Wille
des Handelnden nicht erkennbar
auf ein Fremdgeschäft, wird das
Geschäft als Eigengeschäft behandelt.
Handelnder kann gemäß
§ 164 II nicht nach § 119 I 1. Fall
anfechten! Einschränkungen des
Offenkundigkeitsprinzips beim
verdeckten Geschäft für den, den
es angeht u. beim Handeln unter
fremdem Namen (Identitätstäuschung)
Unternehmensbezogene Geschäfte Wenn eine Person im Tätigkeitsbereich
eines Unternehmens
oder Freiberuflers auftritt, deutet
dies i. d. R. auf ein Handeln „im
Namen“ des Unternehmens hin
=> Unternehmensinhaber wird
dann aus dem Rechtsgeschäft
35
berechtigt u. verpflichtet. Bsp.:
Jeder weiß, dass i. d. R. die Kassiererin
im Supermarkt nicht Geschäftsinhaberin
u. damit nicht
Vertragspartnerin ist, sondern als
Vertreterin handelt
Offenes Geschäft für den, den es angeht 2 Fallgruppen: 1) Handelnder tritt
im Namen eines anderen auf, ohne
dass für den Dritten erkennbar
ist, wer der Vertretene ist; 2)
Vertreter behält sich die Benennung
des Vertretenen vor. Findet
der Vertreter einen Vertretenen,
wird das Geschäft mit der Benennung
des Vertretenen gültig,
sonst greift § 179 analog ein! =>
Bspe.: zu 1): Beim Kauf eines
Gemäldes erklärt X, dass er es
für einen anderen erwerbe. Dieser
ist Kunstsammler u. will ungenannt
bleiben, weil er befürchtet,
der Verkäufer würde sonst einen
wesentlich höheren Preis verlangen.
Zu 2): X will von Y ein Gemälde
kaufen, wobei er deutlich
macht, dass er es nicht für sich
kaufen will, sondern für einen von
ihm noch zu benennenden Geschäftsherrn.
Y ist einverstanden,
Übereignung u. Übergabe sollen
in 3 Wochen stattfinden. Schon
nach 2 Wochen findet X einen Interessenten
Z u. bittet Y, das Gemälde
an Z zu übereignen
Verdecktes Geschäft für den, den es Erklärender macht dem Dritten
angeht nicht klar, dass er für einen anderen
auftritt, so dass das Offenkundigkeitprinzip
nicht gewahrt ist
=> Ein solches Geschäft ist i. d.
R. ein Eigengeschäft. Ausnahme:
Ist es dem Geschäftspartner
gleichgültig, mit wem er kontrahiert,
bedarf er nicht des Schutzes
durch das Offenkundigkeitprinzip.
Dann treffen die Wirkungen
36
des Geschäfts den Vertretenen!
Vor allem bei Bargeschäften des
täglichen Lebens anzutreffen.
Bsp.: X bittet den Y, der mit ihm
in der WG wohnt, die Tageszeitung
vom Kiosk mitzubringen u.
gibt ihm gleich das Geld mit. Y
kauft am Kiosk seine Fernsehzeitschrift
u. die Tageszeitung.
Hier liegt ein Geschäft für den,
den es angeht vor, fehlende Offenkundigkeit
ist unschädlich!
Identitätstäuschung Handelnder benutzt einen fremden
Namen als eigenen => 2
RFen: 1) Ist dem Geschäftspartner
der Namensträger unbekannt
oder gleichgültig, so kann
nur der Handelnde Vertragspartner
sein => Eigengeschäft des
Handelnden (Handeln unter falscher
Namensangabe, Namenstäuschung).
Bsp.: Verheirateter
X will mit seiner Geliebten ungestört
ein paar Stunden im Hotel
verbringen. Um keine Spuren zu
hinterlassen, checkt er unter dem
Namen „Ehepaar Mayer“ ein u.
zahlt sofort bar; 2) Kein Eigengeschäft
des Handelnden liegt vor,
wenn es dem Erklärungsempfänger
darauf ankommt, dass er
mit dem wirklichen Namensträger
abschließt => Hier liegt ein
Fremdgeschäft vor, dessen Wirkungen
nur den Namensträger
treffen können. Bsp.: Zahlungsunfähiger
X kauft unter dem Namen
des Y bei Z auf Kredit. Z
glaubt, den ihn bekannten kreditwürdigen
Y vor sich zu haben.
Hier sollen die Regeln der §§ 164
ff. analoge Anwendung finden.
Das Geschäft ist schwebend unwirksam,
sofern der Handelnde
ohne Vertretungsmacht gehandelt
hat. Heilung durch Genehmi-
37
gung des „Vertretenen“, §§ 177,
184 I analog. Bei Verweigerung
der Zustimmung: Haftung des
Handelnden gem. § 179 I analog!
Vertretungsmacht Fähigkeit, im Namen eines anderen
WEen abzugeben u. zu
empfangen => Sie kann beruhen
auf: Rechtsgeschäft (Bevollmächtigung
§ 167 I, Unterfälle
der Vollmacht: Prokura §§ 48 ff
HGB, Handlungsvollmacht §§ 54
ff. HGB), Verfassung einer juristischen
Person (z. B. Vorstand
eines Vereins § 26 II 1, einer
AG § 78 AktG), Gesetz (z. B.
Eltern § 1629, Ehegatten §
1357), Staatsakt (z. B. Vormund
§ 1793, Betreuer § 1902),
Rechtsschein (z. B. §§ 170 ff.,
Duldungs-, Anscheinsvollmacht).
Die Vertretungsmacht betrifft das
Außenverhältnis zu Dritten, die
Geschäftsführungsbefugnis dagegen
das Innenverhältnis Vertreter/Vertretener,
z. B. Auftrag
(§ 662). Die Vollmacht ist gegenüber
diesem Innenverhältnis abstrakt,
d. h. unabhängig! D. h.
trotz Nichtigkeit des Grundgeschäfts
zwischen Vertreter/
Vertretener bleibt die wirksam erteilte
Vollmacht bestehen! Umfang
der Vertretungsmacht: Bestimmung
durch den Vollmachtgeber;
i. Z.: Umfang zu
ermitteln im Wege der Auslegung
der Bevollmächtigung.
Bei der Außenvollmacht kommt
es darauf an, wie ein unbefangener
Dritter in der Position
des Geschäftspartners die Erklärung
des Vollmachtgebers
verstehen durfte; bei der Innenvollmacht
kommt es auf die
objektivierte Sicht des Bevollmächtigten
an
38
Vollmacht Die durch Rechtsgeschäft erteilte
Vertretungsmacht (§ 166 II 1) =>
Die Erteilung erfolgt durch eine
einseitige, empfangs-, aber nicht
annahmebedürftige WE (Bevollmächtigung),
§ 167 I gegenüber
1) dem zu Bevollmächtigenden (=
Innenvollmacht, § 167 I 1. Fall),
2) gegenüber dem Geschäftspartner
(= Außenvollmacht,
§ 167 I 2. Fall). Die Erteilung ist
grundsätzlich formfrei (§ 167 II)
u. kann auch konkludent erfolgen,
z. B. wenn Mitarbeitern
Aufgaben übertragen werden, die
nur durch Abschluss von Rechtsgeschäften
erfüllt werden können.
Ausnahme: Erteilung ist
formbedürftig, wenn die Parteien
eine besondere Form vereinbart
haben oder wenn das Gesetz
eine besondere Form vorschreibt,
z. B. § 1945 III 1. Handelt der
Vertreter ohne Vollmacht, ist
das Rechtsgeschäft schwebend
unwirksam u. hängt dann von
der Genehmigung ab, §§ 177 ff.
Erlöschen der Vollmacht:
Richtet sich nach deren Inhalt
oder nach gesetzlichen Vorschriften.
Soweit die Vollmacht
selbst keine Regelungen enthält,
gilt § 168!
Nach außen kundgetane Innenvollmacht Betrifft die Fälle, in denen zur Innenvollmacht
die Kundgabe der
Vollmacht an den Geschäftsgegner
hinzutritt (§ 171)
Spezialvollmacht Sie berechtigt nur zu Vornahme
eines ganz bestimmten Geschäfts
=> Bsp.: X beauftragt Y,
für ihn einen Fernseher zu kaufen
Generalvollmacht Sie berechtigt zur Vornahme aller
Rechtsgeschäfte, bei denen
eine Vertretung zulässig ist =>
39
Bsp.: 90jährige Oma bittet ihre
Tochter, den gesamten Rechtsverkehr
für sie zu erledigen
Gattungsvollmacht Sie gilt für eine bestimmte Art
von Rechtsgeschäften => Bsp.:
Vollmachten eines Kaufmanns für
den Wareneinkauf
Gesamtvollmacht Mehrere Personen sind bevollmächtigt
u. dürfen nur gemeinsam
den Geschäftsherrn vertreten
(Legaldefinition in § 125 II 1
HGB) => Erklärungen einzelner
Vertreter sind schwebend unwirksam!
Zur Entgegennahme von
WEen ist jeder Gesamtvertreter
allein berechtigt!
Untervollmacht Vollmacht, die nicht der Vertretene,
sondern sein Vertreter
(Hauptvertreter) einem Dritten
(Untervertreter) erteilt => Sie befugt
den Untervertreter seinerseits
nur im Namen des Vertretenen
WEen abzugeben u. zu
empfangen. Er muss dabei nicht
deutlich machen, dass er nur Untervertreter
ist. Ob der Hauptvertreter
einem Dritten Untervollmacht
erteilen darf, ist eine Auslegungsfrage
(§§ 133, 157);
Stichwort: Interesse des Geschäftsherrn!
Untervollmacht
fehlerhaft: Genehmigung des
Geschäfts vom Hauptvertreter
oder vom Vertretenen, sonst: §
179; Hauptvollmacht fehlerhaft:
Genehmigung des Geschäfts nur
vom Vertretenen, sonst haftet
Unterbevollmächtigter nach
§ 179, sofern dieser nicht die Unterbevollmächtigung
offengelegt
hat. Wurde sie offengelegt, dann
Haftung des Hauptvertreters
nach § 179! (Literaturauffassung:
Untervertreter haftet unabhängig
40
von einer Offenlegung nach
§ 179, Vorauss.: Untervollmacht
bestand! Der aus § 179 II in Anspruch
genommene gutgläubige
Untervertreter hat einen entsprechenden
Rückgriffsanspruch
gegen den Hauptvertreter aus
dem zugrunde liegenden Rechtsverhältnis)
Vollmacht kraft Rechtsscheins §§ 170-173. In diesen gesetzlich
geregelten Fällen geht es um den
Schutz des guten Glaubens des
Dritten an den Fortbestand einer
einmal wirksam erteilten, inzwischen
aber erloschenen Vollmacht.
So soll der Dritte auf den
Rechtsschein, dass die in
Wirklichkeit nicht mehr bestehende
Vollmacht noch wieterbesteht,
vertrauen dürfen! =>
Ausnahme: § 173, „wenn der
Dritte das Erlöschen... kennt oder
kennen muss“. § 170 betrifft die
Außenvollmacht. Vorauss.:
Widerruf gegenüber dem Bevollmächtigten
(§ 168 S. 3). Anzeige
des Erlöschens muss dem Dritten
zugehen, damit sie ihre Wirkung
auslöscht. Sie ist eine geschäftsähnliche
Handlung, auf die die
Vorschriften über WEen analoge
Anwendung finden. § 171 betrifft
die nach außen kund-getane
Innenvollmacht. Bei der Kundgabe
handelt es sich auch um
eine geschäftsähnliche Handlung!
§ 172: Vorlage einer Vollmachtsurkunde
(siehe Def.) =>
Nur das Original, keine Fotokopien
oder beglaubigte Abschriften,
dann eventuell Rechtsscheinhaftung
nach den Grundsätzen
der Anscheins-/Duldungsvollmacht!
Vorgelegt ist sie,
wenn sie dem Geschäftspartner
zur sinnlichen Wahrnehmung
41
unmittelbar zugänglich gemacht
wurde. Nicht erforderlich ist, dass
Geschäftspartner tatsächlich Einsicht
nimmt. §§ 170-173 sind
auch auf eine vornherein nicht
erteilte Vollmacht analog anwendbar,
sodass der Rechtsschein
erst zerstört ist, wenn die
Kundgabe widerrufen wird
Vollmachtsurkunde Unterzeichnetes Schriftstück, das
den Aussteller, den Bevollmächtigten
u. den Umfang der
Vollmacht erkennen lässt
Duldungsvollmacht Vertretungsmacht kraft Rechtsscheins.
Von Rspr. u. Lit. entwickelter,
gesetzlich nicht geregelter
Rechtsscheintatbestand.
Liegt vor, wenn 1) jemand sich
benimmt, als habe er Vertretungsmacht,
2) der angeblich
Vertretene dies weiß, aber trotz
entsprechender Verhinderungsmöglichkeit
nichts dagegen
unternimmt, 3) der Geschäftspartner
dieses Dulden nach Treu
u. Glauben dahin verstehen darf,
dass der als Vertreter Handelnde
bevollmächtigt ist u. deswegen
das Rechtsgeschäft abschließt.
RF: Der Duldende muss sich so
behandeln lassen, als habe er
wirksam eine Vollmacht erteilt!
Anfechtung nach h. M. nicht
möglich, in der Duldung liegt
keine WE! Nur diese können aber
angefochten werden, nicht jedoch
Rechtsscheintatbestände!
Ausnahme: Kein Rückgriff auf
die Duldungsvollmacht, wenn das
Verhalten des angeblich Vertretenen
bereits als konkludente
Bevollmächtigung angesehen
werden kann, dann regulär § 164!
42
Konkludente Bevollmächtigung Liegt vor, wenn dem „angeblich
Vertretenen“ das Auftreten des
nicht ausdrücklich Bevollmächtigten
zur Kenntnis kommt u. er
dieses Auftreten mit rechtsgeschäftlichem
Willen (Bevollmächtigungswille)
billigt => Im
Wege der Auslegung (§§ 133,
157) zu ermitteln (Empfängerhorizont)!
Anscheinsvollmacht Vertretungsmacht kraft Rechtsscheins.
Auch von Rspr. u. Literatur
entwickelt. Liegt vor, wenn
1) der Vertretene keine Vollmacht
erteilt hat, 2) das Handeln
des Vertreters auch nicht kennt
u. duldet, 3) aber es bei pflichtgemäßer
Sorgfalt hätte kennen
u. verhindern können, u. 4) der
Geschäftspartner wegen der Untätigkeit
auf das Bestehen der
Vollmacht vertraut u. deswegen
das Rechtsgeschäft abschließt
=> Voraus.: Ein wiederholtes,
sich über einen gewissen Zeitraum
erstreckendes Auftreten
des unbefugten Vertreters! Leicht
fahrlässige Unkenntnis genügt!
=> Unterschied zur Duldungsvollmacht:
Der angeblich Vertretene
kennt nicht das Auftreten
des Scheinvertreters. Anfechtung
wie bei Duldungsvollmacht
nicht möglich!
Insichgeschäft § 181. Rechtsgeschäft, das eine
Person gegenüber sich selbst
vornimmt => 2 Fälle: Selbstkontrahieren,
Mehrvertretung. RF:
Das Rechtsgeschäft ist keineswegs
nichtig, sondern schwebend
unwirksam, § 177 I analog.
Wirksamkeit kann durch Genehmigung
eintreten. Wenn keine
erfolgt, dann handelt der Vertreter
ohne Vertretungsmacht, Haf-
43
tung § 179 analog. Bsp.: Prokurist
X des Y schließt in dessen
Namen mit sich einen Vertrag,
wonach sein Monatsgehalt um
300
€ erhöht wird. Ist Y mit der
Erhöhung einverstanden, kann er
genehmigen u. der Vertrag ist
gültig! Ausnahmsweise ist das
Insichgeschäft gültig, wenn 1)
dem Vertreter die Mitwirkung auf
beiden Seiten des Geschäfts gestattet
ist, 2) der Vertreter zum
Zwecke der Erfüllung einer Verbindlichkeit
gehandelt hat oder 3)
wenn das Rechtsgeschäft für den
Vertreter lediglich einen rechtlichen
Vorteil bringt. Bsp. zu 2):
Geschäftsherr X hat von seinem
Prokuristen Y einen Computer
gekauft. Y erfüllt die Pflicht des X
zur Kaufpreiszahlung, indem er
den von X geschuldeten Betrag
aus der Kasse des X nimmt. Bsp.
zu 3): Ein Vater schließt mit seinem
14jährigen Sohn einen
Schenkungsvertrag über einen
Teppich, wobei er zugleich als
Vertreter des beschenkten Sohnes
u. als Schenker im eigenen
Namen auftritt. Sohn entsteht
kein Nachteil, folglich greift der
Normzweck des § 181 nicht ein.
§ 181 wird auch analog angewendet,
wenn der Vertreter einen
Untervertreter bestellt u. mit diesem
das Rechtsgeschäft vornimmt,
um so die RF des § 181
zu umgehen. D. h. § 181 findet
analoge Anwendung, wenn trotz
Personenverschiedenheit ein Interessenkonflikt
droht u. der Vertreter
selbst als Partei an dem
Rechtsgeschäft beteiligt ist!
Selbstkontrahieren § 181 1. Fall. Vertreter nimmt im
Namen des Vertretenen mit sich
selbst im eigenen Namen ein
44
Rechtsgeschäft vor => Bsp.: X
hat Vollmacht des Y, dessen Wagen
nicht unter 3000 € zu verkaufen.
Er kauft selbst den Wagen
zu diesem Preis.
Mehrvertretung § 181 2. Fall. Wenn jemand auf
beiden Seiten eines Rechtsgeschäfts
als Stellvertreter für die
jeweiligen Vertragsparteien auftritt
=> Bsp.: X hat Vollmacht des
Y, ein Auto zu verkaufen u.
gleichzeitig Vollmacht des Z, ein
Auto zu kaufen. X verkauft das
Auto des Y an den Z.
Falsus procurator Vertreter ohne Vertretungsmacht
=> Vertrag ist zunächst schwebend
unwirksam, kann aber
durch Genehmigung des Vertretenen
wirksam werden (§ 177 I).
Genehmigung macht dann den
Vertrag rückwirkend wirksam (§§
182, 184 I). Bei Verweigerung der
Genehmigung wird der Vertrag
endgültig unwirksam. Das Interesse
des Geschäftsgegners an
der schnellen Beseitigung des
Schwebezustandes wird durch
die §§ 177 II, 178 geschützt (Aufforderung
zur Erklärung/ Widerruf).
Aufforderung stellt eine
geschäftsähnliche Handlung dar,
auf die die §§ 104 ff., 145 ff. analoge
Anwendung finden. Widerruf,
der als WE den allg. Vorschriften
der §§ 104 ff., 145 ff. u.
119 ff. unterliegt, muss nicht ausdrücklich
erfolgen. Auch ein konkludenter
Widerruf ist zulässig u.
kann in der Geltendmachung eines
Anspruchs aus § 179 gegen
den Vertreter zu erblicken sein.
Die Erklärung muss jedoch erkennen
lassen, dass der Vertrag
gerade wegen des Vertretungsmangels
nicht gelten soll! Bei
45
einseitigen Rechtsgeschäften
ist eine Vertretung ohne Vertretungsmacht
unzulässig u. damit
auch eine Genehmigung ausgeschlossen
(§ 180 S. 1), keine
Haftung gem. § 179, sondern ggf.
gem. §§ 823 ff. Ausnahme: § 180
S. 2 empfangsbedürftige Rechtsgeschäfte,
z. B. Kündigung,
Rücktritt, Anfechtung. Beachte:
Vertretung ohne Vertretungsmacht
(=> § 164 I greift nicht ein!)
ist vom Missbrauch der Vertretungsmacht
zu trennen!
Missbrauch der Vertretungsmacht Hier hat der Vertreter eine
rechtswirksame Vertretungsmacht.
Voraus. des Missbrauchs:
Vertreter handelt im Rahmen seiner
Vertretungsmacht (rechtliches
Können), überschreitet jedoch
seine Befugnisse aus dem
Innenverhältnis (rechtliches
Dürfen) u. der Vertragspartner
weiß dies oder hätte dies ohne
weiteres erkennen können (Evidenz)!
RF: Rspr.: Wenn der Vertragspartner
den Vertretenen aus
dem Rechtsgeschäft in Anspruch
nimmt, kann ihm dieser den Einwand
der unzulässigen Rechtsausübung
(§ 242) entgegenhalten
(Lit.: Der Geschäftsgegner
muss sich so behandeln lassen,
als hätte keine ausreichende Vertretungsmacht
vorgelegen. Es
gelten die §§ 177 ff.). Wenn der
Vertreter u. Geschäftspartner bewusst
zum Nachteil des Vertretenen
zusammenarbeiten, liegt
eine Kollusion vor, mit der Folge,
dass das Rechtsgeschäft
gem. § 138 nichtig ist. Ggf. Ansprüche
des Vertretenen aus
§§ 823 II i. V. m. § 266 StGB u.
aus § 826!
46
Kollusion Siehe Missbrauch der Vertretungsmacht
Anfechtung Prüfungsaufbau: 1) Anfechtung
muss zulässig sein; 2) Anfechtungsgrund:
§§ 119, 120, 123; 3)
Anfechtungserklärung muss 1.
fristgerecht und 2. gegenüber
dem Anfechtungsgegner erfolgt
sein; 4) Anfechtung darf nicht
ausgeschlossen sein durch Bestätigung
des Rechtsgeschäfts
(§ 144). RFn: 1) Vertrag ist ex
tunc nichtig; 2) Nach § 119 oder
§ 120 angefochten: Anfechtender
ist zum Ersatz des Vertrauensschadens
verpflichtet (§ 122) =>
Zur Zulässigkeit: Grundsätzlich
ist jede WE nach §§ 119 ff.
anfechtbar! Soweit einem
Schweigen Erklärungswirkung
zukommt, ist dieses ebenfalls
anfechtbar. Nicht jedoch, soweit
sich der Irrtum auf die rechtliche
Bedeutung des Schweigens bezieht!
Anfechtung ist auch von
vornherein ausgeschlossen, soweit
gesetzliche Sonderregelungen
bestehen. Bspe.: §§ 1313
ff., §§ 1600 ff. Bei in Vollzug
gesetzten Arbeits-/ Personengesellschaftsverträgen:
RF der
Anfechtung ist modifiziert, d. h.
Nichtigkeit tritt nur mit Wirkung
für die Zukunft (ex nunc) ein, da
andernfalls untragbare Ergebnisse!
Irrtum Unbewusstes Auseinanderfallen
von obj. Erklärtem u. subj. Gewolltem
=> Durch Auslegung
(§§ 133, 157) zu ermitteln! Hat
der Gegner die Erklärung so verstanden
oder musste er sie so
verstehen, wie sie der Erklärende
verstanden wissen wollte, gilt die
Erklärung auch mit dieser Bedeu-
47
tung. Beachte daher: Auslegung
geht vor Anfechtung!
Motivirrtum Irrtum, der dem Erklärenden bei
seinem Motiv (Beweggrund), also
bei der Willensbildung, nicht bei
der Willensäußerung unterläuft
=> Bsp.: X erwirbt von Y einen
Gegenstand, weil er glaubt, diesen
gewinnbringend wieder veräußern
zu können. Dies gelingt
aber nicht: Unbeachtlicher Motivirrtum!
Anfechtung ausgeschlossen!
Inhaltsirrtum (§ 119 I 1. Fall) Bedeutungsirrtum. Erklärender
irrt sich über die Bedeutung oder
Tragweite seiner Erklärung, d. h.
er verbindet mit dem Erklärten einen
anderen Sinn als ihm nach
der Auslegung zukommt. Es besteht
daher eine Diskrepanz zwischen
der obj. Bedeutung der
fraglichen WE u. der subj. Vorstellung
des Erklärenden. Bsp.:
Leiterin X einer Realschule unterschrieb
eine von einem Vertreter
für Toilettenpapier ausgefüllte
Bestellung über „25 Gros Rollen“,
die Rolle zu je 1000 Blatt. Sie
wusste nicht, dass die Bezeichnung
„Gros“ zwölf Dutzend Stück
bedeutete u. nahm an, lediglich
25 große Rollen Toilettenpapier
bestellt zu haben
Erklärungsirrtum (§ 119 I 2. Fall) Irrtum beim Erklärungsakt. Der
Erklärende setzt ein anderes als
das gewollte Erklärungszeichen
=> Bspe.: Versprechen, Vertippen,
Verschreiben, Vergreifen
Rechtsfolgenirrtum Irrt sich der Erklärende über RFn,
die mittels der Erklärung unmittelbar
herbeigeführt werden sollten,
liegt ein Inhaltsirrtum (§ 119 I
1. Fall) vor. Bezieht sich der Irr-
48
tum dagegen auf gesetzliche
Nebenfolgen des Rechtsgeschäfts,
die vom Erklärenden
nicht erkannt u. nicht gewollt
sind, so ist eine Anfechtung ausgeschlossen!
=> Bsp. zum 1.
Fall: Ergibt die Auslegung des
zwischen X u. Y geschlossenen
Vertrags, dass es sich nicht um
einen Dienst-, sondern Werkvertrag
handelt, kann Y anfechten,
sofern er irrtümlich glaubte, nur
zur Leistung von Diensten, nicht
aber zur Herbeiführung des Erfolgs
verpflichtet zu sein. Bsp.
zum 2. Fall: Bauunternehmer X
übereignet schenkungsweise ein
Grundstück an seine Ehefrau, irrt
sich dabei aber über die steuerlichen
Folgen einer Schenkung.
Unbeachtlicher Motivirrtum!
Kalkulationsirrtum Wenn sich der Erklärende über
einen Umstand (z. B. Größe, Gewicht),
den er seiner Berechnung
zugrunde gelegt hat, irrt, er
sich also verkalkuliert => 2 Arten:
Verdeckter u. offener Kalkulationsirrtum
Verdeckter Kalkulationsirrtum Wenn der Anbieter seine Kalkulation
nicht offengelegt hat, d. h.
die interne Kalkulation war nicht
in die WE aufgenommen, berechtigt
ihn eine vergessene Position
nicht zur Anfechtung. Unbeachtlicher
Motivirrtum! => Bsp.: Ein
Fabrikant bietet auf eine Ausschreibung
Elektromaterial an,
hat dabei aber versehentlich bei
mehreren Positionen zu niedrige
Beträge eingesetzt. Beachte: Anfechtungsrecht
ist nach h. M.
auch dann ausgeschlossen,
wenn der Gegner den Irrtum
hätte erkennen können oder sogar
kannte. Eventuelle Unbillig-
49
keiten können ggf. über § 242
(unzulässige Rechtsausübung)
korrigiert werden, wenn der Ausschluss
der Anfechtung für den
Erklärenden ruinöse Folgen hat
u. der Gegner -trotz Kenntnis des
Irrtums- Vertragsdurchführung
verlangt (M. M.: Anfechtung gem.
§ 119 I 1. Fall analog)
Offener Kalkulationsirrtum Beide Parteien gehen gemeinsam
von einer bestimmten Kalkulationsgrundlage
aus u. haben
diese zur Grundlage ihrer Verhandlungen
gemacht => Bsp.: X
sagt zu Y: „Ein Kilo Birnen kostet
2 €. Das macht bei 4 Kilo 6 €.“
Bei evidenten Fehlern kann der
rechtlich relevante Wille durch
Auslegung ermittelt werden.
Auslegungsgrundsatz: falsa demonstratio
non nocet! Wenn aber
die Vertragsauslegung nicht zum
Ziel führt, kommt eine Anpassung
des Vertrags nach den
Grundsätzen der Störung der Geschäftsgrundlage
(§ 313) in Betracht.
Sachgerechtere Lösung
als die Anfechtung, da Vertrauensschaden
wegfällt! Wenn
keine Möglichkeit besteht, das zu
Ergänzende als sinngemäß miterklärt
anzusehen oder eine Vertragsanpassung
vorzunehmen,
ist die Erklärung (WE) perplex, d.
h. in sich widersprüchlich u. nichtig.
Z. B.: Auslegung nach dem
obj. Empfängerhorizont ergibt,
dass der erste Teil Vorrang haben
soll, d. h. KV ist über 8 €
zustande gekommen
Unterschriftsirrtum Jemand unterschreibt eine Urkunde,
wobei er deren Inhalt
nicht oder nicht richtig erfasst hat
=> Grund: 1) Er hat die Urkunde
nicht (vollständig) gelesen; 2) Er
50
hat ihren Inhalt nicht (vollständig)
verstanden. Lösung dieser Fälle:
Wenn der Unterzeichnende verschiedene
Urkunden verwechselt
hat, liegt ein Erklärungsirrtum
vor (§ 119 I 2. Fall); wenn
der Inhalt der Urkunde falsch
verstanden wurde, liegt ein Inhaltsirrtum
vor (§ 119 I 1. Fall);
Wenn die Urkunde ungelesen
unterschrieben wurde u. der Unterzeichnende
keinerlei Vorstellung
von deren Inhalt hat, ist
keine Anfechtung möglich!
Eigenschaftsirrtum (§ 119 II) Irrtum über eine wesentliche Eigenschaft
einer Person oder einer
Sache => Wenn es um einen
Irrtum über verkehrswesentliche
Eigenschaften geht, die gleichzeitig
eine Sachmängelhaftung nach
den §§ 434 ff. begründen, ist eine
Anfechtung des Käufers gemäß
§ 119 II nach Gefahrübergang
(§ 446) ausgeschlossen (ansonsten
würde die kaufrechtl. Verjährung
umgangen). Anfechtung
auch vor Gefahrübergang möglich?
H. M.: Keine Anfechtung
möglich (=> Entziehung der Verantwortung,
§ 442), sondern auf
Sachmängelgewährleistungsrech
-te angewiesen. Verkäufer kann
nach § 119 II nur dann anfechten,
wenn dadurch die
Rechte des Käufers auf Geltendmachung
seiner Gewährleistungsansprüche
nicht eingeschränkt
werden!
Eigenschaft (§ 119 II) Alle tatsächlichen oder rechtlichen
Verhältnisse, die dauerhaft
sind u. die Sache oder Person
unmittelbar kennzeichnen
=> Eigenschaften einer Sache:
alle wertbildenden Faktoren (z.
B. Material, Echtheit, Herkunft,
51
Größe, Fahrleistung), nicht jedoch
der Wert (Preis) selbst (z.
B.: X kauft bei Y eine Flasche
Wodka, weil er irrtümlich glaubt,
der Preis sei herabgesetzt. Keine
Anfechtung möglich). Eigenschaften
einer Person (Geschäftspartner
oder auch Dritter): Alter, Geschlecht,
Zahlungsfähigkeit, Zuverlässigkeit,
Vorstrafen
Verkehrswesentlichkeit (§ 119 II) Verkehrswesentlich ist eine Eigenschaft,
wenn sie nach der
Verkehrsauffassung (also obj.)
als wesentlich für das konkrete
Rechtsgeschäft zu erachten, d. h.
wenn sie ausschlaggebend für
seinen Abschluss ist
Doppelirrtum / Beidseitiger Eigen- Bei Vertragsschluss irren sich
schaftsirrtum beide Parteien über ein dem Vertrag
zugrunde liegendes Motiv =>
Unbeachtlicher Motivirrtum. Immer:
Anwendungsbereich des
§ 313. Bei beidseitigem Irrtum
über verkehrswesentliche Eigenschaft:
H. M.: Lösung über
die Grundsätze der Störung der
Geschäftsgrundlage (§ 313). Keine
Anfechtung, da § 119 II nur
den einseitigen Eigenschaftsirrtum
regelt. Argument: Schadensersatzpflicht
des zuerst Anfechtenden
nach § 122 ist angesichts
des beidseitigen Irrtums unbillig.
M. M.: Anfechtungsregelungen
der §§ 119 ff. sind anwendbar.
Argument: Nur derjenige wird anfechten,
für den das Geschäft
nachteilig ist, d. h. zu dessen
Nachteil die Wirklichkeit von der
gemeinsamen Vorstellung abweicht.
Nicht unbillig, dem Anfechtenden
die Schadensersatzpflicht
aufzuerlegen
52
Übermittlungsirrtum (§ 120) Erklärender muss sich die unrichtig
übermittelte Erklärung zurechnen
lassen, kann sich aber
von ihr durch Anfechtung befreien
=> Beachte: Überbringt der
Bote die Erklärung bewusst
falsch, liegt nach h. M. keine
Übermittlung i. S. d. § 120 vor.
Die Erklärung ist dem Geschäftsherrn
erst gar nicht zuzurechnen,
so dass es keiner Anfechtung bedarf.
Ggf. Haftung des Auftraggebers
aus c.i.c. (§§ 280 I, 311 II,
241 II) auf Ersatz des Vertrauensschadens
Täuschung (§ 123 I 1. Fall) Ein Irrtum über Tatsachen wird
hervorgerufen, bestärkt oder
aufrechterhalten => Bloße Anpreisungen
u. subj. Werturteile
reichen nicht aus! Bsp.: Verkäuferin
zur Kundin: „Der Rock steht
ihnen ausgezeichnet“. Zuhause
meint ihr Sohn jedoch, dass der
Rock unmöglich an ihr aussieht.
Täuschungshandlung kann entweder
durch positives Tun (Vorspiegeln
von Tatsachen) oder
Unterlassen (Verschweigen von
Tatsachen), wenn eine Rechtspflicht
zur Aufklärung besteht, erfolgen.
Beachte: Sowohl ausdrückliche
als auch konkludente
Täuschung möglich! Die Aufklärungs-
u. Offenbarungspflicht
beim Unterlassen ist nach der
Verkehrsauffassung unter Berücksichtigung
von Treu u. Glauben
(§ 242) u. den Umständen
des Einzelfalls zu entscheiden.
Rechtspflicht zur Aufklärung besteht
z. B. kraft gesonderter Vereinbarung,
kraft Ingerenz u. kraft
Treu u. Glauben (Vertrauen des
Geschäftspartners auf die Fachkunde
der anderen Seite; bei
langjährigen Geschäftsbezie-
53
hungen). Beachte: Eine unzulässige
Frage darf wahrheitswidrig
oder überhaupt nicht
beantwortet werden. Kein
Anfechtungsrecht desjenigen, der
durch die Falschangabe getäuscht
wurde. Vor allem im
Arbeitsrecht relevant. Bsp.: Fraugen
des Arbeitgebers bei der
Einstellung nach Bestehen einer
Schwangerschaft oder nach der
politischen Einstellung. Irrtum
muss für die Abgabe der WE
kausal gewesen sein (Mitursächlichkeit
genügt!). Liegt
nicht vor, wenn der Erklärende
von vornherein den wahren SV
kannte oder mit der Täuschung
rechnete, er also die Erklärung
auf alle Fälle abgegeben hätte.
Beachte: Es spielt dagegen keine
Rolle, ob der Erklärende die
Täuschung ohne weiteres hätte
durchschauen können oder ob er
bei verständiger Würdigung die
Erklärung auch bei Kenntnis von
der Täuschung abgegeben hätte.
Anfechtung möglich! Verhältnis
§ 123 zu § 119: Neben § 123
kann zugleich eine Anfechtung
wegen Irrtums in Betracht kommen.
Anfechtungsberechtigter
kann dann wählen, auf welchen
Grund er sich berufen will! Beachte:
Bei § 123 scheidet § 122 I
aus, also i. d. R. günstiger!
Tatsachen Dem Beweis zugängliche Ereignisse
oder Zustände der Gegenwart
oder Vergangenheit
Offenbarungspflicht Umfasst alle Umstände, die für
die Entscheidung des Vertragspartners
zum Vertragsschluss
offensichtlich von Bedeutung sind
u. deren Mitteilung nach der Verkehrsauffassung
erwartet werden
54
kann => Bsp.: Beim Gebrauchtwagenkauf:
Offenlegung, dass es
sich um einen wiederhergestellten
Unfallwagen handelt
Arglist (§ 123) 1) Der Täuschende muss die
Unrichtigkeit seiner Angaben
kennen oder die Angaben „ins
Blaue hinein“ gemacht haben
(dolus eventualis ausreichend!).
2) Bewusstsein, dass der andere
ohne Täuschung die WE
möglicherweise nicht oder nicht
mit dem vereinbarten Inhalt abgegeben
hätte (dolus eventualis
ausreichend!). => Bsp.: Obwohl
der Gebrauchtwagenhändler den
Wagen nicht überprüft hat, behauptet
er beim Verkauf, dass
der Wagen keinen Unfall gehabt
habe. Beachte: Für die Arglist ist
kein Schädigungsvorsatz erforderlich!
Dritte (§ 123 II 1) Dritte i. S. d. § 123 II 1 sind nur
am Rechtsgeschäft gänzlich Unbeteiligte,
nicht aber diejenigen,
die im Lager des Erklärungsempfängers
stehen => Nicht-Dritte
sind Vertreter, Verhandlungsgehilfen,
-führer oder Personen, die
in sonstiger besonders enger Beziehung
zum Geschäftsherrn stehen.
Bsp.: Wer einen Vertragsabschluss
lediglich vermittelt, z. B.
als Makler, ist Dritter
Drohung (§ 123 I 2. Fall) Ist das (auch konkludente) Inaussichtstellen
eines künftigen
Übels, auf dessen Eintritt der
Drohende Einfluss hat oder zu
haben vorgibt. Als Übel genügt
jeder Nachteil => Bspe.: Drohung
mit Strafanzeige, Verprügeln.
Durch das Inaussichtstellen des
Übels soll in dem Bedrohten
Furcht vor dem künftigen Übel
55
erregt werden (psychische
Zwangslage). Bei Anwendung
von physischem Zwang liegt bereits
tatbestandlich keine WE vor,
so dass es auch keiner Anfechtung
bedarf! Eine Willensbeeinflussung
ist auch gegeben, wenn
die Drohung gar nicht ernst
gemeint ist, der Bedrohte sie
aber für ernst gemeint hält!
Beachte: Das künftige Übel
muss aus der Sicht des Bedrohten
vom Willen des Drohenden
abhängig sein
Widerrechtlichkeit der Drohung Drohung ist widerrechtlich, wenn
das Mittel, der Zweck oder die
Mittel-Zweck-Relation verwerflich
ist => Mittel: Drohung mit
einer widerrechtlichen Handlung,
z. B. Drohung mit Körperverletzung.
Zweck: Bestimmung zur Abgabe
einer WE ist widerrechtlich,
wenn der damit erstrebte Erfolg
widerrechtlich ist. Gilt auch dann,
wenn das eingesetzte Mittel nicht
zu beanstanden ist. Bsp.: X hat Y
bei einem Diebstahl beobachtet.
X droht Y, er werde ihn anzeigen,
wenn er nicht 200 € bekomme.
Hier ist die angedrohte Handlung
(Strafanzeige) rechtmäßig, nicht
aber der erstrebte Erfolg! MittelZweck-Relation:
Widerrechtlichkeit
ist zu bejahen, wenn Mittel u.
Zweck zwar für sich allein betrachtet
nicht widerrechtlich sind,
aber ihre Verbindung, nämlich
die Benutzung dieses Mittels zu
diesem Zweck, gegen die guten
Sitten oder gegen Treu u. Glauben
verstößt. Gesamtwürdigung
aller Umstände unter besonderer
Berücksichtigung der Belange
nicht nur des Bedrohten, sondern
auch des Drohenden! Bsp.: X hat
Y bei einem Diebstahl beobach-
56
tet. X droht dem Y mit einer Anzeige,
falls Y nicht eine fällige
Kaufpreisforderung des X erfüllt.
Widerrechtlichkeit der MittelZweck-Relation,
da zwischen
dem Kaufpreisanspruch und der
Straftat keinerlei Zusammenhang
besteht. Anders: Drohung
mit Strafanzeige zulässig, wenn
die aus einer Straftat erwachsenen
Schadensersatzansprüche
durchgesetzt werden sollen. Drohung
mit einer Zivilklage ist i. d.
R. stets zulässig, weil sie das von
der Rechtsordnung vorgesehene
Mittel der Anspruchsdurchsetzung
ist
Unverzüglich (§ 121) Angemessene Überlegungsfrist
des Anfechtungsberechtigten.
Was angemessen ist, beurteilt
sich nach den Umständen des
Einzelfalls, insbes. nach der Bedeutung
u. Komplexität des
Rechtsgeschäfts => I. d. R. Entscheidung
binnen weniger Tage
zumutbar. Frist beginnt mit
Kenntniserlangung des Irrtums
u. nicht schon bei bloßen Zweifeln
o. unbestimmten Vermutungen
oder fahrlässiger Unkenntnis
Vertrauensschaden / Negatives Der Anfechtende hat dem GegInteresse
(§ 122) ner (Anspruchsberechtigten) den
Schaden zu ersetzen, den dieser
dadurch erleidet, dass er auf die
Gültigkeit der Erklärung vertraut.
Der Anspruchsberechtigte muss
so gestellt werden, als hätte er
nicht auf die Gültigkeit der WE
vertraut, also nie etwas von dem
Geschäft gehört => Ersatzpflicht
umfasst: nutzlose Aufwendungen
für das Geschäft, z. B. Telefon-,
Portokosten, aber auch den
dadurch entgangenen Gewinn.
Grenze des Schadenersatzan-
57
spruchs ist das Erfüllungsinteresse.
Diese Begrenzung soll verhindern,
dass der Berechtigte durch
die Anfechtung besser gestellt
wird als bei Erfüllung des Vertrags!
Bsp.: X kauft u. erwirbt von
Y einen Hamster für 2 €. Der
Hamster hat einen Wert von 10 €.
X kauft sich einen Käfig für 50 €,
doch Y ficht den KV wirksam an.
X erhält die 2 € zurück und Y den
Hamster. Negatives Interesse:
Wenn X nicht auf die Gültigkeit
der Erklärung vertraut hätte, hätte
er die 50 € nicht ausgegeben, d.
h. negatives Interesse in Höhe
von 50 €. Trifft den Anfechtenden
ein Verschulden, tritt neben die
Schadensersatzpflicht nach §
122 I auch eine aus c.i.c. (§ 280
I, 311 II, 241 II) auf Ersatz des
negativen Interesses. Der Vorteil
gegenüber § 122 I ist, dass keine
Begrenzung des negativen Interesses
durch das positive Interesse
besteht (str.). Jedoch § 280 I 2
beachten: Anfechtender kann
sich „von Schuld befreien“. Dies
ist bei § 122 I nicht möglich! Auch
ist § 122 II nicht anwendbar, es
gilt hier § 254
Erfüllungsinteresse / Positives Wer zum Ersatz des positiven InInteresse
(§ 122 I a. E.) teresses verpflichtet ist, hat den
Zustand herzustellen, der bestehen
würde, wenn ordnungsgemäß
erfüllt worden wäre => Bsp.:
Hamster-Fall siehe neg. Interesse.
Erfüllungsinteresse: Wenn die
WE des Y gültig gewesen wäre,
hätte X einen Gewinn in Höhe
von 8 € gehabt, d. h. positives Interesse:
8 €. Somit hat X aus §
122 I nur einen Anspruch auf 8 €
Gesetzliches Verbot (§ 134) Verbot muss sich aus einem
Gesetz ergeben. Gesetz i. S. d.
58
BGB sind alle Rechtsnormen, d.
h. nicht nur Gesetze im formellen
Sinne, sondern auch Rechtsverordnungen
u. Gewohnheitsrecht.
Verbotsgesetze sind Gesetze,
die sich gegen die Vornahme eines
Rechtsgeschäftes richten.
Bsp.: Schwarzarbeitsvertrag ist
nach § 134 nichtig, wenn beide
Parteien gegen das Gesetz verstoßen
haben
Begriff der guten Sitten (§ 138 I) Bestimmen sich nach dem Anstandsgefühl
aller billig u. gerecht
Denkender => Verstöße
sind unter Berücksichtigung aller
Umstände festzustellen: Inhalt/
Zweck des Rechtsgeschäfts, Beweggründe
(Absichten, Motive)
zur Vornahme des Rechtsgeschäfts,
Verhalten vor Abschluss
des Rechtsgeschäfts. Maßgeblicher
Zeitpunkt der Beurteilung
der Sittenwidrigkeit: Verhältnisse
im Zeitpunkt der Vornahme des
Rechtsgeschäfts! RF: Sittenwidriges
Rechtsgeschäft ist ex tunc
unwirksam. Ist ein Verpflichtungsgeschäft
sittenwidrig, dann bleibt
das abstrakte Verfügungsgeschäft
von dieser Sittenwidrigkeit
unberührt. Wenn aber der Sittenverstoß
gerade in der Veränderung
der Güterzuordnung liegt,
dann ist auch das Verfügungsgeschäft
nichtig. Rückgewährung
der erbrachten Leistung nach
Kondiktionsrecht! Fallgruppen:
Wucherähnliches Geschäft (Kausalgeschäft
ist unwirksam, nicht
aber das dingliche Erfüllungsgeschäft!
=> Unterschied zu § 138
II!); Knebelungsverträge/ Bürgschaftsübernahmen;
Verstöße
gegen die Sexualmoral (Beachte:
Seit 1.1.02 ist die Prostitution
selbst nicht mehr sittenwidrig);
59
Gläubigergefährdung; Missbrauch
einer Macht- oder Monopolstellung;
anstößige Kommerzialisierung
(Bsp.: Entgeltlicher
Vertrag über die Verschaffung eines
Ehrendoktortitels)
Wucher (§ 138 II) Auffälliges Missverhältnis von
Leistung u. Gegenleistung => Es
muss eine Schwächesituation
des Bewucherten vorliegen, die
der Wucherer bewusst ausnutzt.
Auffälliges Missverhältnis ist
dann anzunehmen, wenn die Gegenleistung
den Wert der Leistung
um 100 % über- bzw. unterschreitet.
Es ist jedoch immer eine
Gesamtwürdigung des Einzelfalls
vorzunehmen, so dass
auch eine kleinere Differenz für
den Wuchervorwurf genügt bzw.
bei hohen Risiken eine größere
Differenz berechtigt ist. Bsp.:
Beim Mietvertrag ist eine Überschreitung
der angemessenen
Miete bereits um 50 % wucherisch.
§ 138 II ist nur auf Verträge
anwendbar, die einen Leistungsaustausch
zum Gegenstand haben.
Bspe.: Darlehens-, Miet-,
Kaufvertrag. § 138 II ist gegenüber
§ 138 I lex specialis, d. h.
vor diesem zu prüfen. Bezüglich
§ 134: zuerst § 134, dann § 138 II
u. schließlich § 138 I prüfen! RF
von § 138 II: Verpflichtungsgeschäft
ist nichtig! Erfüllungsgeschäft
des Bewucherten ist nichtig,
während umgekehrt das Erfüllungsgeschäft
des Wucherers
wirksam ist. Bewucherter kann
seine Leistung nach § 985 sowie
nach § 812 I S. 1 1. Fall u. ggf.
nach § 817 S. 1 zurückfordern.
Anspruch des Wucherers nach
§ 812 I S. 1 1. Fall, eventuell
nach § 817 S. 2 ausgeschlossen!
60
Zwangslage (§ 138 II) Zwingendes Bedürfnis nach der
vom Wucherer versprochenen
Leistung
Unerfahrenheit (§ 138 II) Mangel an Lebens- u. Geschäftserfahrung
=> I. d. R. nur bei Jugendlichen
oder geistig beschränkten
Personen anzunehmen
Mangel an Urteilsvermögen (§ 138 II) Betroffener ist im konkreten Fall
nicht in der Lage, die beiderseitigen
Leistungen richtig zu bewerten
=> Bloße Unkenntnis von
Nachteilen eines Vertrages reicht
nicht aus! Fähigkeit zur Beurteilung,
z. B. aufgrund von Verstandesschwäche,
muss fehlen!
Erhebliche Willensschwäche (§ 138 II) Betroffener ist wegen verminderter
psychischer Widerstandsfähigkeit
nicht in der Lage, die zutreffende
Beurteilung des Geschäftes
in die Tat umzusetzen
=> Insbesondere bei Drogenoder
Alkoholabhängigkeit gegeben,
nicht bei Labilität gegenüber
geschickter Werbung, da Willensschwäche
erheblich sein muss!
Konversion Umdeutung, § 140
Allgemeine Geschäftsbedingungen Legaldefinition in § 305 I 1
(AGB)
Vertragsbedingung (§ 305 I 1) Regelung, die sich auf den Abschluss
oder Inhalt eines Vertrags
bezieht
Vorformuliert (§ 305 I 1) Bedingungen müssen bereits vor
Vertragsschluss vollständig formuliert
u. abrufbar sein
Für eine Vielzahl Auch dann erfüllt, wenn der Verwender
die Bedingungen zum ersten
Mal verwendet => BGH verlangt,
dass mindestens eine
dreimalige Verwendung beabsichtigt
wird!
3. Staatsorganisationsrecht
Staatsrecht Das Staatsrecht befasst sich mit
einem konkreten Staat, hier mit
dem Staat der BRD (Geschichte
u. gegenwärtige Saatsorganisation)
Staatslehre Die Staatslehre untersucht ganz
abstrakt den Begriff u. das Wesen
des demokratischen Verfassungsstaates
allgemein, ausgehend
von den unterschiedlichen
Erscheinungsformen in der Vergangenheit
u. Gegenwart
Drei-Elemente-Lehre Nach dieser auf Georg Jellinek
zurückgehenden Lehre konstituieren
den Staat drei Elemente:
a) Staatsgebiet, b) Staatsvolk,
c) Staatsgewalt (siehe jeweils
Def.)
Staatsgebiet Darunter versteht man einen abgegrenzten
Teil der Erdoberfläche,
der zum dauernden Aufenthalt
von Menschen geeignet
ist u. damit einen räumlichen
Herrschaftsbereich gegenüber
anderen Staaten abgrenzt =>
Bestimmung der Grenzen eines
Staatsgebiets durch den Grundsatz
der tatsächlichen Beherrschbarkeit;
Bsp.: Luftraum
endet an der Stelle, an der die
effektive Beherrschung aufhört,
Grenze bei ca. 80 bis 100 km, str.
Staatsvolk Hierzu gehören alle einem Staat
zugehörigen Menschen => Dauerhafter
Personenverband =
rechtliche u. politische „Schicksalsgemeinschaft“;
Bestimmung
des Staatsvolkes durch das
Merkmal der Staatsangehörigkeit.
Beachte: a) Def. „deutscher
Staatsbürger“ in Art. 116 GG; b)
§ 4 I StAG (Abstammungsprin-
97
zip, siehe Def.), § 4 III StAG
(Territorialprinzip, siehe Def.)
Abstammungsprinzip Erwerb der Staatsbürgerschaft
durch Geburt => Staatsangehörigkeit
richtet sich nach derjenigen
der Eltern/eines Elternteils,
d. h. Kind erwirbt durch
Geburt die Staatsangehörigkeit,
wenn mindestens ein Elternteil
Staatsbürger des betreffenden
Landes ist; dieses Prinzip gilt in
der BRD
Territorialprinzip Nach diesem Prinzip erwirbt jemand
die Staatsangehörigkeit
des Staates, in dessen Staatsgebiet
er geboren wird => Beachte:
Ohne Rücksicht der Staatsangehörigkeit
der Eltern!
Staatsgewalt Originäre Herrschaftsmacht des
Staates über sein Gebiet und die
auf ihm befindlichen Personen
=> Gebiets- u. Personalhoheit; In
der BRD wird die Staatsgewalt
auf drei Schultern verteilt: a)
Legislative (gesetzgebende Gewalt),
b) Exekutive (ausführende
Gewalt), c) Judikative
(rechtsprechende Gewalt)
Gebietshoheit Herrschaft über das Staatsgebiet
Personalhoheit Herrschaft über das Staatsvolk
bzw. rechtliche Unterworfenheit
des Staatsvolkes unter die
Staatsgewalt
Staatszielbestimmungen Verfassungsnormen, die dem
Staat die fortwährende Erfüllung
bestimmter Aufgaben oder die
Verfolgung bestimmter Ziele
vorschreiben => Beachte:
Staatszielbestimmungen sind für
die staatlichen Organe verbindlich,
allerdings bezieht sich die
Bindungswirkung nur auf die
98
Zielvorgaben. Die Wahl der
Mittel u. Wege sowie die nähere
Konkretisierung der Ziele bleibt
den staatlichen Organen überlassen!
Bspe. für Staatszielbestimmungen
des GG: Sozialstaat
(Art. 20 I, 28 I GG), Umwelt/-Tierschutz
(Art. 20a GG)
=> siehe jeweils Def.;
Strukturprinzipien Neben den Staatszielen gibt es
die (Staats-)Strukturprinzipien
des Art. 20 GG: Republik,
Demokratie, Sozial-, Bundesund
Rechtsstaatsprinzip (i.V.m.
Art 28 I). Diese Strukturprinzipien
sind nach Art. 79 III GG
unabänderlich (= Ewigkeitsgarantie).
Folge des Art. 79 III
GG ist damit, dass sämtliche
Verfassungsänderungen mit Art.
1 u. 20 GG vereinbar sein
müssen.
Republik Art. 20 I GG. Der Staat ist eine
Republik, wenn er keine Monarchie
(siehe Def.) ist => Wesentlicher
Inhalt: a) Periodisch
wiederkehrende Wahl des
Staatsoberhauptes (Bundespräsident),
b) Wahl auf begrenzte
Zeit (Bundespräsident wird für 5
Jahre gewählt, Art. 54 I, II GG);
Bspe. für Republik: BRD, Frankreich,
USA
Monarchie Staatswesen, in dem das Staatsoberhaupt
nach familien- u. erbrechtlichen
Regelungen bestimmt
u. auf Lebenszeit bestellt
wird (sog. Erbmonarchie; vgl.
dagegen die Wahlmonarchie im
Heiligen Römischen Reich Deutscher
Nation bis 1806); gegenwärtige
Bspe. für Monarchie:
Großbritannien, Niederlande
99
Demokratie Art. 20 I, II GG. Herrschaft des
Volkes => Grundsatz: Alle
Staatsgewalt geht vom Volke aus
(Art. 20 II 1 GG). Unterscheide
unmittelbare von mittelbarer
Demokratie (=> siehe jeweils
Def.). Elemente des Demokratieprinzips:
a) Volkssouveränität,
b) Repräsentative Demokratie
(mittelbare Demokratie), c)
Pluralistische Demokratie, d)
Mehrheitsprinzip, e) Parlamentarische
Demokratie (=> siehe
jeweils Def.)
Unmittelbare Demokratie Direkte Demokratie. Das Volk
selbst trifft die maßgeblichen
Sach- u. Personalentscheidungen,
d. h. die Bürger üben die
Staatsgewalt weitgehend selbst
aus => Keine Aufspaltung der
Staatsgewalt in verschiedene,
voneinander unabhängige
Staatsorgane; diese Staatsform
ist heute nur noch in einigen
Schweizer „Ur-Kantonen“ zu
finden.
Volkssouveränität Grundsatz der Volkssouveränität:
Art. 20 II 1 GG => Das Volk
(=> siehe Def.) bildet die Grundlage
der Staatsgewalt, die Ausübung
der Staatsgewalt geht vom
Volk aus u. muss wiederum dem
Volk gegenüber verantwortet
werden. Die Ausübung jeglicher
staatlicher Macht bedarf daher
der Legitimation durch das Volk
u. muss in einer ununterbrochenen
demokratischen Legitimationskette
auf das Volk zurückführbar
sein. Beachte: Es gibt
unmittelbare u. mittelbare demokratische
Legitimationen. Bsp.:
Das Volk kann nicht direkt den
Bundeskanzler wählen, sondern
nur das Parlament (Parlament =
vom Volk unmittelbar legit-
100
imiert). Dieses wählt dann den
Bundeskanzler (Bundeskanzler =
vom Volk mittelbar legitimiert).
Volk Das deutsche Staatsvolk => Die
Gesamtheit der Personen, die die
deutsche Staatsangehörigkeit besitzen;
Beachte: Art. 116 GG.
Repräsentative Demokratie Das Volk wählt ein Parlament
als Repräsentationsorgan, das
seinerseits für das Volk handelt
(Art. 20 II 2 GG) => Die Ausübung
der Staatsgewalt wird von
Repräsentanten (Abgeordneten),
die vom Volk durch (freie)
Wahlen dazu legitimiert sind,
wahrgenommen; Beachte: Es
gibt zwei Formen der repräsentativen
Demokratie: a) Parlamentarische
Demokratie, b) Präsidialdemokratie.
Parlamentarische Demokratie Die Regierung, der Regierungschef,
wird nicht direkt vom Volk,
sondern vom Parlament gewählt /
bestimmt u. ist vom Vertrauen
des Parlaments abhängig (Art.
63 I, 64, 67, 68, 69 II GG) => Die
BRD ist eine parlamentarische
Demokratie (Art. 20 II 2 GG).
Präsidialdemokratie Die Regierung, der Staatspräsident,
wird vom Volk direkt gewählt
u. ist deshalb weitgehend
dem Einfluss des Parlaments
entzogen => Meist sind die
Ämter des Staatspräsidenten u.
des Regierungschefs in einer
Person vereint; Bspe. für Präsidialdemokratie:
USA, Frankreich.
Pluralistische Demokratie Art. 20 I GG => Es wirken vielfältige
weltanschauliche, politische,
soziale u. kulturelle Interessen
nebeneinander; Gegenteil:
Einheitsdemokratie (wie
in den ehemaligen Ostblockstaaten).
101
Mehrheitsprinzip „Herrschaft der Volksmehrheit“
=> Alle Handlungen des
Staates müssen mit der Mehrheit
des Volkswillens übereinstimmen
=> Beachte: a) Nur demokratisch
zustande gekommene
Mehrheiten legitimieren staatliche
Machtausübung!; b) Das GG
kennt verschiedene Mehrheitsbegriffe:
1) Abstimmungsmehrheit,
2) Anwesenheitsmehrheit, 3)
Mitgliedermehrheit (=> siehe jeweils
Def.). Des Weiteren erfolgt
eine Unterscheidung nach der
erforderlichen Mehrheit, dem sog.
Quorum (=> siehe Def.)
Abstimmungsmehrheit Einfache Mehrheit. Der zur Entscheidung
gestellte Antrag bedarf
der Mehrheit der sich an der Abstimmung
beteiligenden Personen
=> Die Zahl der abgegebenen
Ja-Stimmen muss die Zahl der
abgegebenen Nein-Stimmen
überwiegen. Beachte: Ungültige
Stimmen oder Stimmenthaltungen
werden nicht mitgezählt (h.
M.); Bsp.: Abstimmungsmehrheit
bei Beschlüssen des Bundestags,
es sei denn, das GG bestimmt
etwas anderes (Art. 42 II
GG).
Anwesenheitsmehrheit Erforderlich ist die Mehrheit der
Anwesenden => Sie ist im GG
nicht genannt, sondern nur in der
GO BT vorgesehen, z. B. in § 80
II GO BT oder in § 126 GO BT.
Beachte: Enthaltungen u. ungültige
Stimmen zählen als Ablehnung!
Mitgliedermehrheit Kanzlermehrheit = absolute
Mehrheit. Erforderlich ist die
Mehrheit der gesetzlich vorgeschriebenen
Zahl der Mitglieder
des jeweiligen Gremiums (vgl.
102
Art. 121 GG). Beachte: Zu den
598 Sitzen im Bundestag müssen
die Überhangmandate (=> siehe
Def.) hinzugezählt werden! Enthaltungen,
ungültige Stimmen u.
Stimmen der abwesenden Mitglieder
werden mitgezählt u. wirken
sich als Ablehnung aus!
Bsp.: Absolute Mehrheit ist bei
der Kanzlerwahl (Art. 63 GG)
oder bei der Vertrauensfrage des
Bundeskanzlers (Art. 68 GG)
erforderlich.
Quorum Das Quorum stellt auf die erforderliche
Zahl der Stimmen ab,
die bei der Abstimmung erreicht
werden muss => Unterscheide:
a) einfache Mehrheit, b) qualifizierte
Mehrheit (=> siehe jeweils
Def.).
Einfache Mehrheit Rechnerische Mehrheit, d. h. 50
% plus mindestens 1 Stimme =>
Bei Stimmengleichheit ist der
Antrag abgelehnt.
Qualifizierte Mehrheit 2/3 der Mitglieder des Bundestags
u. ggf. 2/3 der Stimmen des
Bundesrats => Bsp.: Verfassungsänderungen
bedürfen
nach Art. 79 II einer qualifizierten
Mitgliedermehrheit von Bundesrat
u. Bundestag.
Wahlsystem Es gibt zwei Möglichkeiten, das
Wahlsystem zu organisieren: a)
Als Mehrheitswahl oder b) als
Verhältniswahl (=> siehe jeweils
Def.).
Mehrheitswahl Das gesamte Wahlgebiet ist in
Wahlkreise eingeteilt, aus denen
i. d. R. je ein Abgeordneter zu
entsenden ist => Direkt gewählt
ist derjenige, der im Wahlkreis
mehr Stimmen als seine Konkurrenten
erhält (= relative Mehr-
103
heitswahl) oder der über 50 %
der abgegebenen Stimmen erreicht
(= absolute Mehrheitswahl).
Merke: Mehrheitswahl =
Persönlichkeitswahl
Verhältniswahl Hier stellen sich die Kandidaten
im gesamten Wahlgebiet zur
Wahl. Die Kandidaten sind auf
Parteilisten vereint => Verhältniswahl
ist nur bei der Wahl von
Vertretungskörperschaften (Parlamenten)
anwendbar. Die Abgeordnetensitze
werden auf die
einzelnen Parteien entsprechend
dem Verhältnis der im Wahlgebiet
auf ihre Listen abgegebenen
Stimmen verteilt. Merke: Verhältniswahl
= Parteien-/Listenwahl;
In der BRD gilt das sog. personalisierte
Verhältniswahlrecht
Personalisierte Verhältniswahl § 1 I 2 BWahlG. Bei der Bundestagswahl
hat jeder Wahlberechtigte
zwei Stimmen, wobei er mit
der Erststimme einen Kandidaten
aus dem Wahlkreis wählt (=
realtive Mehrheitswahl) u. mit der
Zweitstimme für eine Partei
stimmt (= reine Verhältniswahl)
=> Vorteil dieser Wahl: Wähler
haben es in der Hand, Kandidaten
direkt in den Bundestag zu
wählen, ferner können auch kleine
Parteien im Parlament vertreten
sein, auch wenn sie keine
Wahlkreise gewonnen haben;
Kritik: Stimmensplitting des
Wählers, d. h. durch Überhangmandate
(=> siehe Def.) können
mehr Abgeordnete einer Partei in
den Bundestag kommen, als der
betreffenden Partei über die Liste
zustehen.
104
Überhangmandat Es entsteht dadurch, dass eine
Partei in einem Bundesland mehr
Direktmandate erlangt, als ihr
nach der Zweitstimmenauszählung
Sitze im Bundestag zustehen.
Diese zusätzlichen Mandate
verbleiben gem. § 6 V BWahlG
den einzelnen Parteien => Folge:
Erhöhung der Gesamtzahl der
Abgeordneten im Bundestag.
Bsp.: Erhält eine Partei etwa 245
Direktmandate, obwohl ihr nach
der Gesamtzahl der abgegebenen
Zweitstimmen lediglich 240
Sitze zustehen würden, so hätte
diese Partei 5 Überhangmandate.
Folglich erhöht sich die Gesamtzahl
der Bundestagsabgeordneten
von 598 auf 603 Abgeordnete.
Wahlrechtsgrundsätze Art. 38 I 1 GG u. Art. 28 I 2 GG
=> Die Wahlen sind gem. Art. 38
I 1 GG allgemein, unmittelbar,
frei, gleich u. geheim (=> siehe
jeweils Def.).
Allgemeine Wahl Allgemein ist eine Wahl, wenn
alle deutschen Staatsbürger aktiv
(= wählen) oder passiv (=
sich wählen lassen) teilnehmen
dürfen => Ausschlüsse aus politischen,
wirtschaftlichen oder sozialen
Gründen sind unzulässig!
Beachte: Gewisse Mindestvor.
sind aber zulässig, z. B. das Alter
(Art. 38 II GG: Mindestalter von
18 Jahren bzgl. des aktiven
Wahlrechts auf Bundesebene)
oder die deutsche Staatsangehörigkeit.
Unmittelbare Wahl Die Abgeordneten werden durch
die Stimmabgabe der Wahlberechtigten
bestimmt. Es ist daher
nicht zulässig, dass ein zwischengeschaltetes
Gremium
(Wahlmänner) existiert, welches
105
die Abgeordneten wählen würde
(= mittelbare Wahl) => Merke:
Zwischen Wahlentscheidung u.
Wahlergebnis dürfen keine weitere
Personen (wie z. B. die
Wahlmänner bei der Wahl des
Präsidenten der USA) oder Entscheidungen
treten. Zulässig ist
aber die Wahl über eine Liste,
wobei die Reihenfolge der Kandidaten
nach der Wahl nicht mehr
abgeändert werden darf!
Geheime Wahl Der Grundsatz der geheimen
Wahl erfordert, dass die Wahl so
durchgeführt wird, dass andere
Personen nicht in Erfahrung
bringen können, wie der einzelne
Wähler abgestimmt hat => Stimme
muss unbeeinflusst u. unbeobachtet
abgegeben werden
können (durch Wahlzellen, verdeckte
Stimmabgabe, versiegelte
Wahlurne). Der Wähler soll
sichergehen können, dass er
wegen seiner Wahl nicht mit
Nachteilen oder Repressionen
rechnen muss. Aber: Der Wähler
kann jedoch vor oder nach der
Wahlhandlung außerhalb des
Wahllokals nicht gehindert
werden, seine Stimmabgabe zu
offenbaren; Nach Entscheidung
des BVerfG verletzt die Briefwahl
nicht das Wahlgeheimnis
bzw. die Wahlfreiheit.
Freie Wahl Der Grundsatz der freien Wahl
verlangt, dass keinerlei Zwang
zur Wahlausübung u. keine
unzulässige Wahlbeeinflussung
stattfindet => Im Wahllokal ist
Wahlwerbung unzulässig!
Gleiche Wahl Gleichheit der Wahl verlangt,
dass bei der Wahlvorbereitung
u. Durchführung, z. B. Aufstel-
106
lung der Kandidaten, Auswertung
der Stimmen, alle gleich behandelt
werden => Bezogen auf die
Wähler bedeutet dies, dass alle
in gleicher Weise wählen dürfen,
d. h. keine Differenzierung des
Stimmschwergewichtes nach z.
B. Vermögen (vgl. Zensuswahlrecht,
das für Wahlen zum Preußischen
Landtag bis 1918 galt),
Rasse oder Religion . Beachte:
Es ist zwischen Zählwert u.
Erfolgswert zu unter-scheiden
(=> siehe jeweils Def.).
Zählwert Wert der einzelnen Stimme bei
der Auszählung => Zählwertgleichheit
bedeutet, dass alle
Stimmen gleich viel zählen.
Erfolgswert Beschreibt den Wert einer abgegebenen
gültigen Stimme im
Vergleich zu den anderen abgegebenen
gültigen Stimmen =>
Beachte: a) Erfolgswertgleichheit
verlangt, dass alle Stimmen den
gleichen Einfluss bei der Zusammensetzung
des Parlaments
ausüben; b) Es ist aber zwischen
der Mehrheitswahl (=> siehe
Def.) u. der Verhältniswahl (=>
siehe Def.) zu unterscheiden.
Hier kann der Erfolgswert nämlich
unterschiedlich sein: Bei der
Mehrheitswahl erlangen die für
den unterlegenen Kandidaten
abgegebenen Stimmen keine
Bedeutung. Bei der Verhältniswahl
fehlt den Stimmen, die für
Parteien abgegeben werden, die
unter 5 % liegen, der Erfolgswert.
Diese Stimmen bleiben also im
Erfolg unberücksichtigt. Die Fünfprozentklausel
verstößt aber
nicht gegen den Grundsatz der
gleichen Wahl, weil sie eine Zersplitterung
des Parlaments ver-
107
hindert u. sie damit zur Sicherung
der Handlungs- u. Entscheidungsfähigkeit
des Parlaments
beiträgt.
Fünfprozentklausel § 6 VI BWahlG => Parteien, die
weniger als 5 % der Stimmen
erhalten, werden bei der Sitzverteilung
nicht berücksichtigt. Siehe
auch Def. Erfolgswert. Beachte:
Erzielt aber eine Partei mindestens
drei Direktmandate (=
Kandidaten in drei Wahlkreisen
können auf sich die höchste
Stimmenzahl vereinigen), so
kann die Fünfprozentklausel umgangen
werden (= sog. Grundmandatsklausel,
siehe Def.).
Dann ziehen neben den drei
erfolgreichen Bewerbern auch die
Kandidaten der Landeslisten
dieser Partei ein (Anzahl der
Kandidaten hängt vom Ergebnis
der Zweitstimme ab, bei deren
Berechnung nun die Fünfprozentklausel
nicht gilt!)
Grundmandatsklausel § 6 VI 1 BWahlG => Parteien
ziehen auch dann in den Bundestag
ein u. nehmen entspr. ihrem
Stimmanteil an der Sitzverteilung
teil, wenn sie zwar weniger als 5
% der Stimmen, dafür aber mindestens
3 Direktmandate erzielt
haben. Ist die Grundmandatsklausel
verfassungsrechtlich zulässig?
a) H. L.: Sie ist verfassungswidrig,
Argument: Ungleiche
Zweitstimmenbehandlung,
weil den auf Schwerpunktparteien
entfallenen Zweitstimmen
im Gegensatz zu den Zweitstimmen
anderer Splitterparteien
ein Erfolgswert zukommt. Es
kann nicht sein, dass Schwerpunktparteien
eher in den Bundestag
kommen als Splitterpar-
108
teien; b) BVerfG/Teil der Literatur:
Sie ist verfassungskonform,
Argument: Abschwächung
der Fünfprozentklausel ist gerechtfertigt,
da in der Erringung
von drei Direktmandaten ein
besonderes Maß an Zustimmung
zu der hinter den Kandidaten
stehenden Partei liegt
Abstimmungen (Art. 20 II 2 GG) Gem. Art. 20 II 2 GG finden nicht
nur Wahlen, sondern auch Abstimmungen
statt => Es existieren
drei Modelle: a) Volksbefragung,
b) Volksbegehren, c)
Volksentscheid (=> siehe jeweils
Def.).
Volksbefragung Referendum. Der Staat stellt
dem Volk eine präzise formulierte
Frage zu einem Sachverhalt,
d. h. das Volk wird nach
seiner Meinung zu einem Thema
befragt => Das Ergebnis der
Volksbefragung ist für die Staatsorgane
nicht bindend. Die Entscheidung
treffen letztlich die
vom Volk gewählten Abgeordneten.
Merke: Volksbefragungen
dienen häufig der Vorbereitung
einer staatlichen Maßnahme.
Volksbegehren Volksbegehren ist der aus dem
Volk kommende Antrag auf
Durchführung einer Volksabstimmung
=> Vor. ist die Unterstützung
durch eine hinreichend
große Zahl von Wahlberechtigten.
Volksentscheid Volksabstimmung. Es ist die
rechtlich verbindliche Entscheidung
des Volkes (der stimmberechtigten
Bürger) über eine
Sachfrage => Beachte: a) Der
Volksentscheid ist für die staatlichen
Organe bindend; b) Be-
109
schränken sich Abstimmungen
auf den Komplex des Art. 29 GG
oder kommen sie darüber hinaus
auch auf Bundesebene in Betracht?
Problematisch ist, dass
Art. 20 II 2 GG zwar von Abstimmungen
spricht, im Folgenden
jedoch keinerlei weitere Vorschriften
nennt, wie eine solche
Befragung des Volkes durchzuführen
wäre. Die h. M. hält aufgrund
dieser Zurückhaltung plebiszitäre
Akte nach geltendem
Verfassungsrecht für unzulässig.
Sie ist der Ansicht, dass mit dem
Begriff „Abstimmungen“ nur der
Fall der Neugliederung des Bundesgebiets
(Art. 29 II GG) gemeint
sei, nicht jedoch eine Abstimmung
über Sachfragen. Möglich
wäre aber eine entspr. Verfassungsänderung;
Gegenmeinung:
Berufung auf das Demokratieprinzip
u. den Begriff der
„Abstimmungen“ in Art. 20 II GG,
Argument gegen diese Auffassung:
Das Abstimmungsverfahren
bleibt unklar, es sind also
weitere Regelungen notwendig.
Rechtsstaat Art. 1, 19 IV, 20 II 2, III, 23 I 1, 28
I 1 GG. In einem Rechtsstaat
sind nicht nur die Beziehungen
der Bürger untereinander gesetzlich
geregelt, sondern auch das
Verhältnis zwischen Staat u.
Bürgern sowie der rein innerstaatliche
Bereich => Elemente
des Rechtsstaatsprinzips: a)
Gewaltenteilung, Art. 20 II 2 GG
(=> siehe Def.), b) Gesetzmäßigkeit
staatlichen Handelns, Art.
20 III GG (=> siehe Def.), c)
Grundsatz der Rechtssicherheit
u. -klarheit, insbes. der Vertrauensschutz
u. das Bestimmtheitsgebot
(=> siehe Def.), d)
Effektiver u. fairer Rechtsschutz,
Art. 19 IV GG, e) Gewährleistung
elementarer Freiheits-
u. Gleichheitsgrundrechte
(=> siehe Def.), f) Verhältnismäßigkeitsgrundsatz
(=> siehe Def.)
(Horizontale) Gewaltenteilung Art. 20 II 2 GG. Die Staatsgewalt
wird durch besondere Organe
der Gesetzgebung (Legislative),
der vollziehenden Gewalt
(Exekutive) u. der Rechtsprechung
(Judikative) ausgeübt
=> Ziel der Verteilung der staatlichen
Macht auf verschiedene,
sich gegenseitig begrenzende u.
kontrollierende Staatsorgane: a)
Machtbegrenzung u. Vorbeugung
des Machtmissbrauchs, b)
Freiheitssicherung des Bürgers,
c) Effiziente u. sachgerechte
Aufgabenerfüllung; Beachte: a)
Keine strikte Gewaltenteilung in
der BRD, sondern es besteht
eine Gewaltenverschränkung im
Sinne einer gegenseitigen
Kontrolle u. Einflußnahme der
Teilgewalten (Stichwort: „checks
and balances“ nach John Locke).
Das bedeutet, dass sich die Zuständigkeiten
der Staats-organe
nicht immer auf die ihnen entspr.
materielle Staatsfunktion beschränken,
sondern zudem in
andere hineinreichen. Diese
Überschneidungen von Organ u.
Funktion werden vom BVerfG
insoweit für verfassungsgemäß
gehalten, als eine Gewalt nicht in
den Kernbereich der anderen
eingreift (= Kernbereichslehre,
siehe Def.); b) Unterscheide
horizontale von vertikaler
Gewaltenteilung (=> siehe Def.).
111
Legislative Gesetzgebende Gewalt => Parlament:
Bundestag, Bundesrat;
Grundsatz: Rechtsetzung durch
die Legislative => Formelle Gesetze
(=> siehe Def.); Beachte:
Unterscheide Gesetz im materiellen
Sinn (=> siehe Def.), nurmaterielle
Gesetze (=> siehe
Def.), nur-formelle Gesetze (=>
siehe Def.), formell-materielle
Gesetze (=> siehe Def.).
Formelles Gesetz Parlamentsgesetze. Regelung,
die von einem verfassungsrechtlich
vorgesehenen demokratisch
legitimierten Gesetzgebungsorgan
in einem Gesetzgebungsverfahren
erlassen wurde.
Materielles Gesetz Jede vom Staat erlassene verbindliche
abstrakt-generelle Regelung,
die gegenüber Bürgern
Außenwirkung entfaltet => Abstrakt
ist eine Regelung, wenn
sie unbestimmt viele Sachverhalte
regelt. Generell ist eine Regelung,
wenn sie an eine unbestimmte
Zahl von unmittelbaren
Adressaten gerichtet ist; Beachte:
Formelle Gesetze sind in aller
Regel zugleich Gesetze im materiellen
Sinn (= formell-materielles
Gesetz, siehe Def.).
Nur-materielles Gesetz Gesetz, das nicht von einem Parlament,
sondern von der Exekutive
erlassen wurde => Gesetze
im nur-materiellen Sinn bedürfen
keines förmlichen Gesetzgebungsverfahrens.
Bspe.: a)
Rechtsverordnung (=> siehe
Def.), z. B. die Straßenverkehrsordnung
(StVO), b) Satzung (=>
siehe Def.), z. B. ein Bebauungsplan.
112
Nur-formelles Gesetz Gesetz, das sich auf den Innenbereich
des Hoheitsträgers beschränkt
=> Nur-formellen Gesetzen
fehlt der allgemeinverbindliche,
abstrakt-generelle Charakter
bzw. die Außenwirkung, d.
h. ihnen kommt nur eine staatsinterne
Wirkung zu. Bspe.: Feststellung
des Haushaltsplans (Art.
110 II 1 GG), Zustimmung zu völkerrechtlichen
Verträgen (Art. 59
II GG).
Formell-materielles Gesetz Das formell-materielle Gesetz
enthält Regelungen im Außenverhältnis,
also gegenüber den
Bürgern, die eine bestimmte
Handlungs- oder Unterlassungspflicht
mit sich bringen.
Einzelfallgesetz Gesetz, das von vornherein nur
auf einen bestimmten Einzelfall
Anwendung findet => Beachte:
a) Es kann sich auch dann um
ein Einzelfallgesetz handeln,
wenn der Tatbestand abstraktgenerell
formuliert ist, das Gesetz
aber nur auf einen Einzelfall Anwendung
finden kann; b) Es liegt
kein Einzelfallgesetz vor, wenn
1) zwar das Gesetz tatsächlich
nur in einem Fall zur Anwendung
kommt, es aber rechtlich für viele
Fälle formuliert war, 2) das Gesetz
aus Anlass eines Einzelfalles
getroffen wird, aber abstraktgenerell
ist (= Maßnahmegesetz,
z. B. Gesetz zur Reduzierung
der Arbeitslosigkeit); c) Ein
Einzelfallgesetz kann gegen Art.
19 I 1 GG u. gegen Art. 3 I GG
verstoßen.
Maßnahmegesetz Siehe bei Def. Einzelfallgesetz.
Rechtsverordnung Rechtsnormen, die von der Exekutive
(Regierung, Minister, Ver-
113
waltungsbehörde) erlassen wurden
=> Durchbrechung des Prinzips
der Gewaltenteilung, da der
Erlass von Rechtsnormen die
Aufgabe der Legislative ist. Aber
es bestehen keine verfassungsrechtliche
Bedenken, da die Exekutive
nur aufgrund einer Ermächtigung
der Legislative tätig
werden darf (Art. 80 GG). Beachte:
a) Art. 80 I 2 GG, Inhalt,
Zweck u. Ausmaß der Ermächtigung
müssen in der Ermächtigungsnorm
bestimmt sein =
dreifacher Delegationsfilter; b)
Darüber hinaus muss die Wesentlichkeitstheorie
(=> siehe
Def.) des BVerfG beachtet werden;
c) Vor. für den Erlass einer
Rechtsverordnung: 1. Gesetzliche
Ermächtigung (Art. 80 I 1
GG): a) Delegationsmöglichkeit
des Gesetzgebers, beachte hier
u. a. die Wesentlichkeitstheorie,
b) Bestimmtheit der Verordnungsermächtigung
(Art. 80 I 2
GG), d. h. der parlamentarische
Gesetzgeber muss das Ziel der
Regelung (= Normzweck), die zu
regelnden Bereiche und die
äußere Grenzen des Regelungsbereichs
festlegen, c) Adressaten
der Verordnungsermächtigung:
Bundesregierung, -minister,
Landesregierungen (Keine
einzelnen Landesminister!); 2. Zitiergebot
(Art. 80 I GG), 3. Bei
Weiterübertragung der Ermächtigung:
Art. 80 I 4 GG (wiederum
durch Rechtsverordnung), 4.
Liegen die Art. 80 II, III GG vor,
ist die Zustimmung des Bundesrates
erforderlich.
Satzung Rechtsnormen, die von einer
öffentlich-rechtlichen Selbstverwaltungskörperschaft
114
(Bspe.: Gemeinde, Landkreis)
aufgrund der ihr verliehenen Autonomie
(z. B. Art. 28 II GG) zur
Regelung eigener Angelegenheiten
erlassen werden => Durch
die Satzung werden die Aufgaben
des Autonomieträgers, seine
Verwaltung u. die Rechtsbeziehungen
zu den Mitgliedern
normiert; Merke: a) Rechtsverordnungen
u. Satzungen unterscheiden
sich i. d. R. nur nach
ihrem Normgeber u. nach ihrer
Funktion; b) Die Anforderungen
des Art. 80 GG gelten nicht
(str.)! Der Unterschied zur
Rechtsverordnung besteht darin,
dass Satzungen von demokratisch
gewählten Organen erlassen
werden.
Wesentlichkeitstheorie Für die Grundrechtsausübung
wesentliche Fragen sind vom
Parlament selbst zu regeln, weil
nur dieses durch Wahlen unmittelbar
demokratisch legitimiert ist
=> In grundlegenden normativen
Bereichen muss also der parlamentarische
Gesetzgeber alle
wesentlichen Regelungen selbst
treffen. Er darf diese Aufgabe
nicht Regierung u. Verwaltung
(=> siehe Def.) überlassen, d. h.
er darf wesentliche Regelungen
nicht über Ermächtigungen an die
Exekutive delegieren. Die Delegation
an die Exekutive ist nur
zulässig, wenn vorhersehbar
ist, in welchen Fällen u. mit
welcher Tendenz von der Ermächtigung
Gebrauch gemacht
werden u. welchen Inhalt die zu
erlassende Rechtsverordnung
haben kann. Dies ist ein wichtiger
Punkt, da das Parlament nicht jedes
Detail selbst regeln kann.
Beachte: In der Klausur ist im-
115
mer zu prüfen, ob die Rechtsverordnung
mit Art. 80 I 2 GG vereinbar
ist, d. h. a) Prüfung der
Vereinbarkeit der Ermächtigungsgrundlage
mit den Vorgaben des
Art. 80 GG, b) Prüfung, ob sich
die Rechtsverordnung an die
Vorgaben der Ermächtigungsgrundlage
hält.
Judikative Rechtsprechende Gewalt, Art.
92 ff. GG => Unabhängige Gerichte
Exekutive Ausführende/Vollziehende Gewalt
=> Bundesregierung, Verwaltung;
a) Ausführung der Gesetze
durch Verwaltung (=> siehe
Def.) u. b) Staatsleitung u. -führung
durch Regierung
Verwaltung Tätigkeit des Staates bzw. eines
sonstigen Trägers öffentlicher
Gewalt außerhalb von formeller
Rechtsetzung u. Rechtsprechung
=> Sie dient in erster Linie dem
Vollzug der Gesetze u. der
Verwirklichung der staatlichen
Aufgaben im Einzelfall, d. h. im
Alltag. Ferner dient sie der Unterstützung
der Minister bei der
Wahrnehmung ihrer Regierungsaufgaben,
z. B. bei der Gesetzesvorbereitung
oder der Konzeption
der Regierungsprojekte.
Kernbereichslehre Jeder der drei Gewalten (Exekutive,
Legislative, Judikative)
muss ein Kernbereich eigener
Entscheidungskompetenzen u.
Eigenverantwortung verbleiben
=> Welches der Kernbereich ist,
lässt sich nicht leicht beantworten.
Es existiert keine glatte Formel.
Der Kernbereich ist dahin
umschrieben worden, dass seine
Verletzung ein Übergewicht der
116
einen über die anderen Gewalten
bedeuten würde.
Vertikale Gewaltenteilung Diese betrifft die Gewaltenteilung
zwischen Bund u. Ländern einerseits
u. zwischen Bund/Ländern
u. Gemeinden andererseits.
Gesetzmäßigkeit staatlichen Handelns Art. 20 III GG => Das bedeutet:
1) Vorrang der Verfassung (=>
siehe Def.), 2) Vorrang des Gesetzes
(=> siehe Def.), 3) Vorbehalt
des Gesetzes (=> siehe
Def.).
Vorrang der Verfassung Staatliche Organe müssen die
Verfassung beachten => Kein
staatlicher Akt darf gegen die
Verfassung verstoßen! Jedes Gesetz,
das gegen die Verfassung
(das GG) verstößt, ist nichtig, es
sei denn, es ist einer verfassungskonformen
Auslegung zugänglich.
Vorrang des Gesetzes Unter dem Prinzip des Vorrangs
des Gesetzes versteht man, dass
staatliche Maßnahmen nicht gegen
höherrangige Rechtssätze
verstoßen dürfen => Dieses Prinzip
gilt ausnahmslos für alle
staatlichen Bereiche. Bsp.: Liegen
die Vor. für eine Gaststättenerlaubnis
(§ 3 GastG) vor, dann
muss die Behörde die Erlaubnis
erteilen. Erteilt sie diese nicht,
dann liegt ein Verstoß gegen den
Vorrang des Gesetzes vor; Merksatz
für den Vorrang des Gesetzes:
Kein Handeln gegen das
Gesetz!
Vorbehalt des Gesetzes / Gesetzes- Die Verwaltung darf nur dann
vorbehalt tätig werden, wenn sie durch ein
Gesetz zu einem bestimmten
Handeln ermächtigt wird =>
117
Bsp.: Der Gesetzesvorbehalt ergibt
sich im Bereich der Grundrechte
unmittelbar aus ihnen, da
sie nur durch oder aufgrund eines
Gesetzes eingeschränkt werden
können. Beachte: Der Gesetzesvorbehalt
gilt nicht uneingeschränkt!
Unterscheide zwischen
Eingriffsverwaltung u. Leistungsverwaltung
(=> siehe jeweils
Def.); Merksatz für den
Vorbehalt des Gesetzes: Kein
Handeln ohne das Gesetz!
Eingriffsverwaltung Liegt vor, wenn die Verwaltung
durch belastende Maßnahmen,
insbes. durch Ge- u. Verbote in
die Freiheitssphäre oder in das
Eigentum des Bürgers eingreift
=> Diese Eingriffe bedürfen einer
formell-gesetzlichen Grundlage!
Hauptanwendungsfall im Gefahrenabwehrrecht
(z. B. im
Gaststätten-, Gewerbe-, Polizeiu.
Ordnungsrecht). Hier verlangt
der Gesetzesvorbehalt für den
Rechtseingriff eine gesetzliche
Ermächtigung (= Rechtsgrundlage),
Bsp.: § 15 VersG verleiht
den Behörden die Befugnis, die
öffentliche Versammlung im Freien
zu verbieten oder aufzulösen.
Leistungsverwaltung Verwaltung greift nicht freiheitsverkürzend
in die Rechtssphäre
des Bürgers ein, sondern gewährt
ihm Leistungen, d. h. es
wird nicht zum Nachteil des Bürgers
in seine Grundrechte eingegriffen,
sondern es werden vielmehr
Leistungen (z. B. Subventionen)
„verteilt“ => Umstritten
ist, ob u. inwieweit der Vorbehalt
des Gesetzes auch im Rahmen
der Leistungsverwaltung eingreift,
ob also z. B. die Vergabe von
Subventionen einer gesetzlichen
118
Grundlage bedarf. Ein genereller
Gesetzesvorbehalt ist aus Gründen
der Effektivität u. Flexibilität
des Verwaltungshandelns abzulehnen.
Folgende Differenzierung
muss beachtet werden:
Weitgehend besteht Einigkeit
darüber, dass nur das „Ob“ der
Leistung im Haushaltsgesetz
geregelt sein muss, d. h., ob z. B.
die Subvention überhaupt gewährt
wird. Die konkrete Vergabe,
also das „Wie“ erfogt dann
nach Richtlinien (i. S. v. Verwaltungsvorschriften)
der Verwaltung.
Ausnahmen: 1) Der Gesetzesvorbehalt
umfasst i. d. R.
dann die Leistungsverwaltung,
wenn mit der Zuweisung einer
Leistung an den Begünstigten
eine untrennbare Wechselwirkung
mit einem Eingriff in die
Rechte Dritter besteht. So kann
z. B. ein nicht begünstigter Konkurrent
des Subventionsempfängers
im wirtschaftlichen Wettbewerb
benachteiligt werden. Bei
zielgerichtetem Eingriff des
Staates in die Rechtssphäre des
(Dritt-)Betroffenen bedarf es einer
Rechtsgrundlage. Str. bei einem
nur mittelbaren Eingriff:
Rechtsgrundlage ist auf jeden
Fall erforderlich, wenn es zu
einer unzumutbaren Grundrechtsbeeinträchtigung
kommt.
Das wäre z. B. bei einer groben
Verzerrung des Wettbewerbs der
Fall; 2) Am Erfordernis einer gesetzlichen
Grundlage ist weiter
festzuhalten, wenn durch die bereit
gestellten Gelder in das
Grundrecht der Pressefreiheit
(Art. 5 GG) oder in die Religionsfreiheit
(Art. 4 GG) eingegriffen
wird. Bsp.: Vergabe von Subventionen
an einen privaten Verein
119
oder an eine Zeitung, der/die vor
Sekten warnt. Hier besteht die
Gefahr einer unkontrollierten
staatlichen Einflussnahme auf die
Pressefreiheit bzw. den weltanschaulich-religiösen
Bereich.
Rechtssicherheit Bestimmtheit, Klarheit (=> siehe
Def.) u. Verlässlichkeit der
Rechtsordnung u. damit der
Rechtsnormen => Der einzelne
Bürger muss nicht nur wissen,
welches Recht jetzt gerade maßgebend
ist, sondern er muss sich
gleichsam darauf verlassen
können, dass die staatlichen
Regelungen, an die er seine
Erwartungen u. Dispositionen
anknüpft, Bestand haben (=
Vertrauensschutz). Der geforderte
Grad an Bestimmtheit ist u.
a. auch von der Intensität der
Grundrechtsbeeinträchtigung abhängig.
Dies macht verständlich,
warum im StrafR, das zu besonders
schweren Eingriffen
ermächtigt, nach Art. 103 II GG
außerordentliche hohe Anforderungen
an die Bestimmtheit von
Normen gestellt werden! Im
StrafR gilt daher gem. Art. 103 II
GG die Unzulässigkeit rückwirkender
Strafgesetze! Eine
Änderung des materiellen StrafR
mit belastender Rückwirkung ist
also mit dem Rechtsstaatsprinzip
unvereinbar. Bei den sonstigen
belastenden rückwirkenden Gesetzen
ist zwischen echter u. unechter
Rückwirkung zu unterscheiden
(=> siehe jeweils Def.).
Vertrauensschutz Siehe bei Def. von Rechtssicherheit.
Rechtsklarheit Setzt voraus, dass die das gesellschaftliche
Zusammenleben re-
120
gelnden Normen hinreichend
bestimmt sind => Nach der
Rspr. des BVerfG muss daher
eine Norm in ihren Vor. u. in
ihrem Inhalt so formuliert sein,
dass die von ihr Betroffenen die
Rechtslage erkennen u. ihr Verhalten
danach einrichten können,
um rechtsstaatlichen Grundsätzen
zu genügen. Beachte: Zulässig
sind i. d. R. a) die Verwendung
von Generalklauseln
(wenn Zielrichtung u. Rahmen
der Regelung erkennbar bleiben),
b) die Verwendung von unbestimmten
Rechtsbegriffen (z. B.
„Zuverlässigkeit“ in § 35 GewO),
c) die Einräumung von Ermessen
(z. B. im PolG)
Echte Rückwirkung Liegt vor, wenn ein Gesetz nachträglich
ändernd in abgeschlossene,
der Vergangenheit angehörende
Tatbestände eingreift =>
Bsp.: Am 07.06.2005 schreibt Y
das Abitur in zwei Leistungsfächern.
Am 01.01.2006 ergeht ein
Gesetz, das vorsieht, dass mit
Wirkung vom 01.01.2005 nur
Abiturprüfungen als bestanden
gelten, wenn die Prüfung in drei
Leistungsfächern abgelegt wurde.
Zulässigkeit von echter
Rückwirkung: Die echte Rückwirkung
von belastenden Gesetzen
ist grundsätzlich unzulässig.
Ausnahmen: 1) wenn kein
schutzwürdiges Vertrauen des
Bürgers besteht oder wenn 2)
ausnahmsweise zwingende
Gründe des öffentlichen Wohls
überwiegen, 3) wenn ein Bagatellfall
vorliegt (= entstehender
Schaden ist unerheblich). Bspe.:
Mit der Rechtsänderung war zu
rechnen oder die bisherige
Rechtslage war unklar u. verwor-
ren, so dass der Bürger auch
nicht auf den Bestand des geltenden
Rechts vertrauen kann.
Maßgeblicher Zeitpunkt für den
Vertrauensschutz: Der Bürger
braucht grundsätzlich mit einer
Rechtsänderung erst ab der Beschlussfassung
(Gesetzesbeschluss)
im Bundestag rechnen,
Regierungsentwurf reicht nicht
aus. Ausnahme: Wird eine Gesetzesänderung
angekündigt,
bevor der von ihr betroffene Tatbestand
abgeschlossen ist, so ist
es dem von der Neuregelung Betroffenen
zuzumuten, vom Zeitpunkt
der Ankündigung an sein
Verhalten auf die Gesetzesänderung
einzustellen. Hier fehlt es
also an einem schutzwürdigen
Vertrauen, wenn der Adressat die
Intention der Neuregelung durch
Dispositionen während des Gesetzgebungsverfahrens
zu unterlaufen
versucht!
Unechte Rückwirkung Liegt vor, wenn der Gesetzgeber
in Sachverhalte eingreift, die in
der Vergangenheit begonnen
haben, jedoch noch nicht
abgeschlossen sind => M. a.
W.: Das Gesetz bestimmt für
einen in der Vergangenheit begonnenen,
aber noch nicht
abgeschlossenen Tatbestand die
Rechtsfolgen für die Zukunft neu
u. verändert dadurch die Rechtsposition
des Bürgers zu dessen
Nachteil. Bsp.: Veranlagungszeitraum
für das Steuerrecht ist
das Kalenderjahr. Mit Ablauf
eines Veranlagungszeitraumes
ist also der Tatbestand des Gesetzes
abgeschlossen. Am
28.02.07 wird ein Steuergesetz
mit Wirkung zum 01.01.07
geändert. Der maßgebliche Ver-
122
anlagungszeitraum 2007 ist also
noch nicht abgeschlossen. Maßgeblicher
Zeitpunkt für den Vertrauensschutz:
wie bei echter
Rückwirkung, ab der Beschlussfassung
im Bundestag. Zulässigkeit
von unechter Rückwirkung:
Sie ist grundsätzlich zulässig.
Ausnahme: Wenn ein
schutzwürdiges Vertrauen beim
Bürger besteht u. dieses gegenüber
dem Allgemeinwohl Vorrang
hat, also überwiegt. Bestimmung
durch Abwägung: Abwägung
des Vertrauens des Einzelnen
auf den Fortbestand der Regelung
gegenüber dem Wohl der
Allgemeinheit auf Änderung der
Regelung.
Gewährleistung elementarer Freiheits- Bestimmte grundrechtliche Geu.
Gleichheitsgrundrechte währleistungen werden als Ausprägungen
des Rechtsstaatsprinzips
verstanden: die Menschenwürde
(Art. 1 I GG), die Rechtsgleichheit
(Art. 3 GG) u. allgemein
die Grundrechtsbindung aller
öffentlichen Gewalt (Art. 1 III
GG).
Verhältnismäßigkeitsgrundsatz / Dieser Grundsatz sagt, dass eine
Übermaßverbot staatliche Maßnahme/ein Gesetz,
die/das in die Grundrechte eingreift,
nur dann verhältnismäßig
ist, wenn der vom Staat verfolgte
Zweck legitim (=> siehe Def.) ist
u. der Einsatz des Mittels zur Erreichung
des Ziels geeignet, erforderlich
u. angemessen ist
(=> siehe jeweils Def.).
Legitimer Zweck des Gesetzes / der Ein Zweck ist legitim, wenn er als
staatlichen Maßnahme solcher verfolgt werden darf =>
Das gesetzgeberische Ziel muss
auf das Wohl der Allgemeinheit
gerichtet sein. Beachte: Weiter
123
Beurteilungsspielraum des Gesetzgebers!
Geeignetheit des Gesetzes / der Geeignet ist die staatliche Maßstaatlichen
Maßnahme nahme, wenn mit ihrer Hilfe das
angestrebte Ziel gefördert bzw.
erreicht werden kann => Es
kommt allein auf die Zwecktauglichkeit
des Mittels u. nicht auf
die Effektivität der Maßnahme an!
Beachte: Auch hier wird dem
Gesetzgeber hinsichtlich der
Tauglichkeit der Maßnahme ein
weiter Beurteilungs- u. Prognosespielraum
zugebilligt!
Erforderlichkeit des Gesetzes / der Die staatliche Maßnahme muss
staatlichen Maßnahme erforderlich sein, d. h. es darf
kein milderes (= weniger eingreifendes)
Mittel geben, das den
gleichen Erfolg erzielt (mit vergleichbarem
Aufwand!) => Merke:
3 Fragen sind hier also zu
beantworten: 1) Gibt es ein anderes
Mittel?, 2) Ist dieses in
gleicher Weise geeignet, den
Zweck zu erreichen?, 3) Ist es
auch ein milderes, also weniger
belastenderes Mittel?
Angemessenheit des Gesetzes / der Die Intensität des Eingriffs muss
staatlichen Maßnahme (Übermaß- noch in einem angemessenen
verbot i. e. S.) Verhältnis zur Bedeutung u.
Dringlichkeit des gesetzgeberischen
Ziels stehen u. es muss
die Grenze der Zumutbarkeit
gewahrt bleiben => M. a. W.: Das
angestrebte Ziel u. die dafür in
Kauf genommene Belastung des
Bürgers dürfen nicht außer Verhältnis
zueinander stehen (Ermittlung
durch Abwägung zwischen
den betroffenen Interessen).
Beachte: Je intensiver das
Gesetz in das Grundrecht eingreift,
umso höhere Anforderungen
sind an die Dringlichkeit
124
des gesetzgeberischen Ziels zu
stellen. Gedankliche Überlegungen:
1) Welcher Nachteil
entsteht dem Grundrechtsträger?
Rang des beeinträchtigten
Rechtsguts? Bedeutsam oder
weniger bedeutsames Rechtsgut?
Intensität des Eingriffs?
Schwerer oder weniger schwerwiegender
Eingriff?, 2) Welchen
Vorteil will der Gesetzgeber erreichen?
Welche Rechtsgüter
sollen geschützt bzw. gefördert
werden? Rang des geschützten /
geförderten Rechtsguts? Bedeutsam
für die Allgemeinheit?
Bundesstaat Art. 20 I GG => Das Bundesstaatsprinzip
betrifft die Gliederung
des Staatsaufbaus der BRD
in einen Gesamtstaat (= Bund)
u. Gliedstaaten (= Länder).
Dabei besitzen sowohl der Bund
als auch die Länder jeweils eine
eigene Staatsqualität. Beachte:
a) Abgrenzung zum Staatenbund
(=> siehe Def.); b) Wichtiges
Merkmal des Bundesstaatsprinzips:
Eigenstaatlichkeit von
Bund u. Ländern: Trennung der
Ebenen (= vertikale Gewaltenteilung,
siehe Def.) u. eigenverantwortliche
Gestaltung der eigenen
Rechtsordnung (= Verfassungsautonomie).
Die sich
daraus ergebenen Konflikte
werden begrenzt durch: 1) das
Homogenitätsprinzip, Art. 28 I 1
GG (=> siehe Def.), 2) Gegenseitige
Einwirkungsrechte, z. B.
Art. 50, 76, 77, 84 GG u. insbes.
das Recht zum Bundeszwang,
Art. 37 GG (=> siehe Def.), 3) die
Bundestreue (=> siehe Def.), 4)
durch Kompetenz- u. Kollisionsregelungen,
z. B. Art. 30,
70, 83 GG u. Art. 31 GG. Gem.
125
Art. 31 GG bricht Bundesrecht
das entgegenstehende Landesrecht!;
c) Unterscheide: Theorie
des zweigliedrigen Bundesstaats
von der Theorie des dreigliedrigen
Bundesstaats (=>
siehe jeweils Def.)
Staatenbund Loser völkerrechtlicher Zusammenschluss
selbständiger Staaten,
die gemeinsame Organe zur
Besorgung bestimmter Angelegenheiten
haben => Hier haben
nur die Gliedstaaten Staatsqualität,
das gesamte Bündnis aber
nicht! Bsp.: Deutscher Bund
(1815-1866). Gegenteil: Zentralstaat.
Hier hat nur der Gesamtstaat
Staatsqualität.
Zentralstaat Siehe bei Def. von Staatenbund
Homogenitätsprinzip Art. 28 I 1 GG. Länderverfassungen
müssen den Grundsätzen
des republikanischen,
demokratischen u. sozialen
Rechtsstaates im Sinne des GG
entsprechen => Beachte: Abweichungen
von der Bundesverfassung
sind aber zulässig,
soweit die wesentlichen Elemente
der in Art. 28 I 1 GG
genannten Grundsätze gewahrt
bleiben!
Bundeszwang Art. 37 GG => Wenn ein Land
seinen Verpflichtungen gegenüber
dem Bund nicht nachkommt,
dann greift Art. 37 GG ein.
Danach kann der Bund das Land
im Wege des Bundeszwangs zur
Erfüllung seiner Pflichten anhalten.
Beachte: Zustimmung
des Bundesrates ist erforderlich!
Bsp. für Maßnahmen des Bundes:
Sperrung der Finanzmittel.
126
Bundestreue Pflicht zur wechselseitigen
Rücksichtnahme im Verhältnis
Bund – Länder, aber auch der
Länder untereinander => Die
Länder sind also gehalten, auf
die Interessen des Bundes Rücksicht
zu nehmen, während der
Bund bei seinem Handeln stets
auch die Interessen der Länder
berücksichtigen muss. Beachte:
Bundestreue ist in der Verfassung
zwar selbst nicht normiert,
ergibt sich aber aus dem Bundesstaatsprinzip.
Zweigliedriger Bundesstaat In einem Bundesstaat existieren
lediglich der Bundesstaat u. die
Gliedstaaten (= Länder) =>
BVerfG hat sich dieser Theorie
angeschlossen!
Dreigliedriger Bundesstaat Danach werden die Gliedstaaten
(Länder) u. der Zentralstaat
(Bund) von einem Gesamtstaat
(BRD) umschlossen => Beim
zweigliedrigen Bundesstaat bildet
also der Zentralstaat zugleich
den Gesamtstaat.
Kooperativer Föderalismus Neben den im GG selbst kooperativen
Einrichtungen (z. B. Art.
91a, 91b GG) sind weitere Kooperationsformen
im Bund-Länder-Verhältnis
u. zwischen den
Ländern geschaffen worden =>
1) Vertragliche Regelungen, 2)
Gemeinsame Ländereinrichtungen,
z. B. ZDF, ZVS, 3) Informelle
Kontakte, z. B. Anfragen,
4) Konferenzen u. Ausschüsse,
z. B. Konferenz der Kultusminister
der Länder, 5) Musterentwürfe
für Landesgesetze: Bundes- u.
Ländervertreter erarbeiten gemeinsam
einen Gesetzesentwurf.
127
Sozialstaat Art. 20 I, Art. 28 I GG => Das
Sozialstaatsprinzip verpflichtet
den Staat zur Herstellung u. Erhaltung
sozialer Sicherheit u.
sozialer Gerechtigkeit (u. zwar
in allen Rechtsbereichen!). Bspe.:
Sozialhilfe, Kranken-, Renten-,
Arbeitslosenversicherung, Abbau
von sozialen Gegensätzen u. Ungleichheiten,
Schutz des sozial
Schwachen. Aus Art. 20 I GG ergibt
sich der Auftrag an Legislative,
Exekutive u. Judikative, das
Sozialstaatsprinzip zu konkretisieren
u. zu verwirklichen. So
ist das Prinzip vor allem von der
Exekutive bei der Anwendung
von Normen (bei Ermessensentscheidungen)
u. von den Gerichten
bei der Auslegung u. Prüfung
von Normen zu beachten! Beachte:
a) Das Sozialstaatsprinzip
richtet sich als Staatszielbestimmung
in erster Linie an den Gesetzgeber,
dem bei der Umsetzung
ein weiter Gestaltungsspielraum
zugebilligt wird. Folgende
Rahmenbedingungen lassen sich
für den Gesetzgeber herleiten: 1)
Sozialgestaltung, d. h. der Staat
ist verpflichtet, im sozialen u.
wirtschaftlichen Bereich tätig zu
werden, 2) Leistungserbringung,
d. h. der Staat muss soziale
Mindeststandards absichern (z.
B. durch Sozialhilfe), 3) Sozialer
Ausgleich zwischen den einzelnen
Bevölkerungsgruppen, um
soziale Gerechtigkeit herbeizuführen;
b) Als obj. Verfassungsnorm
begründet das Prinzip keinerlei
subjektive Rechte des
einzelnen Bürgers gegen den
Staat, z. B. keinen Anspruch auf
Schaffung von zusätzlichen Studienplätzen.
Enge Ausnahme:
Der Bürger hat einen Anspruch
128
auf Gewährung des Existenzminimums
(Herleitung aus dem
Sozialstaatsprinzip i. V. m. Art. 1
I, 2 II GG). Aber: Die Sicherung
des Existenzminimums ist seit
dem 1.1.2005 im Sozialgesetzbuch
integriert u. damit bedarf es
keines Rückgriffs auf das Sozialstaatsprinzip!
Umwelt-/Tierschutz Art. 20a GG => Der Gesetzgeber
muss den Umweltschutz bei den
gesetzgeberischen Tätigkeiten
berücksichtigen u. muss sich dabei
gem. Art. 20a GG im Rahmen
der verfassungsmäßigen Ordnung
bewegen. Beachte: Auch
hier existiert ein weiter Gestaltungsspielraum
des Gesetzgebers!
Partei Legaldef. in § 2 I ParteiG =>
Merke: 1) Vereinigung von Bürgern,
2) Feste u. dauerhafte Organisation
dieser Vereinigung, 3)
Ziel, im Bundestag u./oder Landtag
mitzuwirken, 4) Ernsthaftigkeit
dieser Zielsetzung. Beachte:
a) Zentrale Norm bzgl. der Parteien
ist Art. 21 GG; b) Politische
Parteien zählen selbst nicht zu
den Staatsorganen, nehmen aber
im Hinblick auf Art. 21 GG den
Rang einer verfassungsrechtlichen
Institution ein; c) Aufgabe der
politischen Partei: Als Vermittlungs-
u. Transformationsinstanz
den politischen Willen der Bürger
formen, kollektivieren u. in
die Staatsorganisation einbringen.
Gründungsfreiheit der politischen Art. 21 I 2 GG. Die Gründung eiPartei
ner Partei darf weder von formellen
noch von materiellen Vor.
abhängig gemacht werden =>
Umfasst wird dabei auch das
129
Recht, die Organisation u. das
Programm selbst festzulegen sowie
die Freiheit, einer Partei beizutreten
oder aus ihr auszutreten.
Chancengleichheit der politischen Aus Art. 21 I 1 GG i. V. m. Art. 3
Partei I GG folgt das Recht aller Parteien
auf Gleichbehandlung =>
Der Staat muss, wenn er den
Parteien Einrichtungen zur Verfügung
stellt oder andere öffentliche
Leistungen gewährt, alle
Parteien gleich behandeln. Beachte:
Mit dem Grundsatz der
Chancengleichheit ist es jedoch
vereinbar, den Umfang der Leistungen
an die Parteien entspr.
ihrer unterschiedlichen Größe u.
Bedeutung abzustufen (vgl. § 5 I
2 - 4 ParteiG).
Parteienprivileg Das BVerfG hat gem. Art. 21 II 2
GG die ausschließliche Kompetenz,
ein Parteienverbot auszusprechen
=> Solange eine Partei
nicht vom BVerfG für verfassungswidrig
erklärt worden ist,
darf sie von keiner staatlichen
Stelle wegen ihrer Zielsetzung
benachteiligt werden. Bsp.:
Während eines Wahlkampfes
darf nicht die Bereitstellung der
Stadthalle mit der Begründung
versagt werden, die Partei sei
verfassungswidrig.
Unmittelbare Parteienfinanzierung Parteien werden direkt vom
Staat durch Geldbeträge bezuschusst
=> Maßgebend sind die
§§ 18 ff. ParteiG. Allerdings soll
nur eine Teilfinanzierung ermöglicht
werden. Für die Höhe
ist 1) der Erfolg entscheidend,
den eine Partei bei den Wählern
bei Europa-, Bundestags- u.
Landtagswahlen erzielt, 2) die
130
Summe ihrer Mitgliedsbeiträge u.
3) der Umfang der von ihr eingeworbenen
Spenden (vgl. § 18 I 2
ParteiG). Beachte: Eine vollständige
Parteienfinanzierung
durch den Staat wird als unzulässig
angesehen, da dies die
Gefahr einer Verstaatlichung beinhalten
würde. Aus diesem
Grund dürfen die Parteien nur
das vom Staat erhalten, was für
die Aufrechterhaltung ihrer Funktionsfähigkeit
unerlässlich ist u.
von ihnen selbst nicht aufgebracht
werden kann.
Mittelbare Parteienfinanzierung Hier werden nur die steuerliche
Absetzbarkeit von Mitgliedsbeiträgen
u. Spenden für Parteien
erfasst.
Parteiverbotsverfahren Dies richtet sich nach Art. 21 II 2
GG, §§ 13 Nr. 2, 43 ff. BVerfGG
=> Aufbauschema: A) Zulässigkeit
des Antrags: 1) Antragsberechtigung
gem. § 43 I
BVerfGG, 2) Antragsgegenstand:
Feststellung der Verfassungswidrigkeit
der Partei, 3) Antragsgegner:
Politische Partei
(Prozessführungsbefugnis u.
passive Legitimation gem. § 3
ParteiG), wobei sich ihre Vertretung
nach § 44 BVerfGG richtet,
4) Vorverfahren gem. § 45
BVerfGG, 5) Schriftliche Einreichung
u. Begründung des
Antrags gem. § 23 I BVerfGG; B)
Begründetheit des Antrags:
Hierzu müssen die Vor. des § 21
II 1 GG (lesen!) vorliegen. RF:
BVerfG stellt gem. § 46 I
BVerfGG die Verfassungswidrigkeit
der politischen Partei
fest u. damit greift § 46 III 1
BVerfGG ein.
131
Freiheitliche demokratische Grund- Art. 21 II 1 => Es ist die Umordnung
schreibung derjenigen Elemente
u. Mechanismen, die den Prozess
freier Demokratie im Gemeinwesen
wirksam organisieren
u. sichern sollen. Bspe.: Achtung
vor den im GG konkretisierten
Menschenrechten; Gewaltenteilung;
Volkssouveränität; Unabhängigkeit
der Gerichte.
Bundestag Das Parlament => Beachte: a)
Wahl des Bundestages: Nach
Art. 38 I GG werden die Abgeordneten
des Bundestages in allgemeiner,
unmittelbarer, freier,
gleicher u. geheimer Wahl gewählt
(=> siehe jeweils Def.); b)
Wahlperiode: Der Bundestag
wird auf vier Jahre gewählt (Art.
39 I 1 GG), seine Legislaturperiode
beginnt mit seinem ersten Zusammentritt
u. endet mit dem Zusammentritt
eines neuen Bundestages
(Art. 39 I 2 GG), Ausnahme:
außerordentliches Ende
nach Art. 63 IV 3, 68 I GG; c)
Hauptaufgaben u. Befugnisse:
1) Gesetzgebung (vgl. Art. 76 ff.
GG), 2) Kontrollfunktion (vgl. z.
B. Art. 43 I, 44, 45b u. c, 67 GG),
3) Wahlfunktion (vgl. z. B. Art.
54, 63, 94 I GG), 4) Budgetrecht
(vgl. Art. 110 GG); d) Unterscheide
echte von schlichten Parlamentsbeschlüssen
(=> siehe
jeweils Def.); e) Beachte den
Grundsatz der Diskontinuität
(=> siehe Def.); f) Art. 40 I 2 GG:
Der Bundestag gibt sich eine Geschäftsordnung
(=> siehe Def.);
g) Rechtsstellung der Abgeordneten:
Art. 38 I 2 GG (= freies
Mandat, siehe Def.).
132
Echter Parlamentsbeschluss Verbindlicher Beschluss des
Bundestags => Gesetzesbeschluss
Schlichter Parlamentsbeschluss Beschluss des Bundestags ohne
rechtliche Verbindlichkeit
Grundsatz der Diskontinuität Dieser Grundsatz bestimmt für
den Fall der Auflösung oder
Beendigung des Bundestages
RFn in persönlicher u. sachlicher
Hinsicht = Persönliche u. sachliche
Diskontinuität (=> siehe jeweils
Def.)
Persönliche Diskontinuität Mit dem Ende einer Legislaturperiode
verlieren alle Mitglieder
des Bundestages ihr Abgeordnetenmandat.
Sachliche Diskontinuität Mit dem Ende einer Legislaturperiode
gelten grundsätzlich alle
Beschlussvorlagen als erledigt
=> Mit dem Ende der Legislaturperiode
entfällt nämlich die demokratische
Legitimation des alten
Bundestages u. der neue
Bundestag soll dann nicht die politische
Verantwortung für die Arbeit
des alten tragen! Beachte:
Der Grundsatz der sachlichen
Diskontinuität gilt nur für den
Bundestag u. nicht für Bundesrat
u. -regierung. Ausnahme: Handlungen
des Bundesrates bzw. der
-regierung, die eine erneute Beschlussfassung
im Bundestag erfordern,
gelten auch als erledigt!
Geschäftsordnung des Bundestags Diese ist eine autonome Satzung
(h. M.), die dem GG u. formellen
Gesetz im Rang nachsteht
=> Beachte: a) Die GO BT
stellt das Innenrecht bzw. die innere
Ordnung des Bundestags
dar u. entfaltet deswegen nur dort
ihre Wirkung!; b) Verstöße ge-
133
gen die GO BT führen nicht
grundsätzlich zur Verfassungswidrigkeit
des Gesetzes. Argument:
Art. 82 GG: „...dieses Grundgesetzes...“.
Die Vorschriften der
GO BT gehören eben nicht zu
diesem GG. Ausnahme: Wenn
die verletzte Vorschrift der GO
einen verfassungsrelevanten
Inhalt besitzt, indem sie etwa eine
Bestimmung des GG wiederholt
oder einen wesentlichen
Verfassungsinhalt konkretisiert.
Untersuchungsausschuss Art. 44 I GG => Aufgabe: Aufklärung
von Tatsachen bei öffentlichem
Interesse (d. h. Untersuchung
der Sachverhalte u.
Berichterstattung gegenüber dem
Bundestag), z. B. Skandale einer
Partei; Beachte: Bei Einsetzung
von Untersuchungsausschüssen
gilt die Unterscheidung zwischen
sog. Mehrheitsenquete u. Minderheitsenquete
(=> siehe jeweils
Def.)
Mehrheitsenquete Beruht auf einem Mehrheitsbeschluss
des Bundestags (Art. 42
II 1 GG)
Minderheitsenquete Antrag auf Einsetzung eines Untersuchungsausschusses
muss
von mindestens ¼ der Mitglieder
des Bundestags gestellt werden
=> Beachte: Die Mehrheit des
Bundestags darf die Einsetzung
nur aus rechtlichen Gründen ablehnen,
z. B. wegen Unzulässigkeit
des Untersuchungsgegenstandes.
Ein Recht, den Untersuchungsgegenstand
zu erweitern
oder zu verkürzen, kommt ihr
nicht zu!
134
Freies Mandat Gem. Art. 38 I 2 GG sind die Abgeordneten
Vertreter des ganzen
Volkes, an Aufträge u. Weisungen
nicht gebunden u. nur ihrem
Gewissen unterworfen => Unterschied
zu imperativen Mandat
(=> siehe Def.); Beachte: Wichtige
Befugnisse der Abgeordneten:
Rede- u. Stimmrecht; Antrags-
u. Initiativrecht; Frage- u.
Informationsrecht gegenüber der
Regierung; Mitwirkung in Ausschüssen;
Recht auf Teilnahme
an den Abstimmungen u. Wahlen;
Recht auf Teilnahme an den
Sitzungen des Bundestags; ferner
genießen die Abgeordneten
das Recht auf Indemnität u. Immunität
(=> siehe jeweils Def.);
Sie haben einen Anspruch auf
eine angemessene Entschädigung
(Art. 48 III GG, §§ 11 ff.
AbgG).
Indemnität des Abgeordneten Art. 46 I GG => Der Abgeordnete
darf zu keiner Zeit, d. h. also
auch dann nicht, wenn er sein
Mandat nicht mehr ausübt, wegen
einer Stimmabgabe oder
Äußerung im Bundestag bzw. in
einer Ausschuss- oder Fraktionssitzung
zur Verantwortung gezogen
werden. Ausnahme: Die
Indemnität gilt nicht für Verleumdungen
(Art. 46 I 2 GG).
Immunität des Abgeordneten Art. 46 II GG => Diese schützt
den Abgeordneten insgesamt für
alle Tätigkeiten vor strafrechtlicher
Verfolgung. Allerdings
kann der Bundestag die Immunität
des Abgeordneten aufheben,
d. h. ohne diese Aufhebung besteht
für die Strafverfolgung ein
Verfahrenshindernis. Beachte: a)
Die Immunität ist auf die Zeit als
Abgeordneter beschränkt, greift
135
jedoch auch für Straftaten, die
außerhalb des Plenums (=> siehe
Def.) begangen werden; b)
Die Immunität bietet keinen
Schutz vor zivilrechtlichen Ansprüchen!
Plenum des Bundesrates Das ist die Versammlung aller 69
Mitglieder.
Imperatives Mandat Hier hat der Abgeordnete die
Weisungen seiner Wähler zu befolgen
u. kann jederzeit abgewählt
werden, wenn er diesen
nicht entspricht => Bsp.: Imperatives
Mandat bei der Stimmabgabe
im Bundesrat (vgl. Art. 51 III 2
GG, einheitliche Stimmabgabe
durch Weisungen der Landesregierungen
an ihre Bundesratsmitglieder);
verwandt mit dem
imperativen Mandat ist der Fraktionszwang
(=> siehe Def.).
Fraktionszwang Bedeutet die Verpflichtung eines
Abgeordneten zur Abstimmung
im Sinne eines vorher
durch Beschluss herbeigeführten
Ergebnisses => Beachte: a) Ein
für die Abgeordneten verbindlicher
Fraktionszwang ist verfassungswidrig
u. damit unwirksam.
Grund: Abgeordneter ist
nur seinem Gewissen unterworfen
(Art. 38 I 2 GG). Widerspricht
eine Weisung seinem Gewissen,
dann muss er anders abstimmen,
als die Fraktion es von ihm
verlangt! Die Partei hat dann nur
noch die Möglichkeit, einen Parteiausschluss
gegen diesen Abgeordneten
einzuleiten. Allerdings
müssen hierbei die Vor.
des § 10 IV ParteiG vorliegen!; b)
Anders verhält es sich bei der
sog. Fraktionsdisziplin (=> siehe
Def.).
136
Fraktionsdisziplin Bestreben der Fraktion, ein einheitliches
Auftreten in der Parlamentsarbeit
zu erreichen => Diese
rechtlich unverbindliche Einwirkung
ist zulässig. Denn bei
wichtigen Entscheidungen, bei
denen aus politischen Gründen
eine Geschlossenheit der Fraktion
notwendig ist, muss der
Fraktionsmehrheit das Recht
eingeräumt werden, eine loyale
Entscheidung ihrer übrigen Mitglieder
erwarten zu dürfen!
Fraktion Legaldef. in § 10 I 1 GO BT =>
Weitere Regelungen finden sich
in den §§ 45 ff. AbgG.
Bundesrat Der Bundesrat ist ein Bundesorgan
u. besteht aus Mitgliedern
der Regierungen der Länder, die
sie bestellen u. abberufen (Art.
51 I 1 GG) => Die Länder haben
je nach Einwohnerzahl drei bis
sechs Stimmen im Bundesrat u.
können demnach drei bis sechs
Mitglieder in den Bundesrat entsenden
(Art. 51 II, III 1 GG). Insgesamt
ergeben sich 69 Mitglieder/Stimmen;
Beachte: Die Stimmen
eines jeden Landes im Bundesrat
müssen einheitlich abgegeben
werden. Dies setzt eine
vorhergehende Festlegung der
Stimmabgabe voraus. Beachte
hierbei, dass die Mitglieder im
Bundesrat weisungsgebunden
sind (= imperatives Mandat, siehe
Def.). Konsequenzen einer uneinheitlichen
Stimmabgabe: 3
Meinungen: 1) Es zählt die Stimme
des Stimmführers, also die
des Ministerpräsidenten. Die abweichenden
Stimmen werden
dann im Sinne der Stimme des
Stimmführers mitgezählt. 2) Die
Bundesratsabstimmung ist insge-
137
samt unwirksam u. muss wiederholt
werden. 3) H. M.: Ungültigkeit
der uneinheitlich abgegebenen
Stimmen des Landes. Die
Abstimmung insgesamt bleibt
aber davon unberührt u. muss
nicht wiederholt werden. Ausnahme:
Wiederholung dann,
wenn durch die Ungültigkeit die
absolute Mehrheit nicht erreicht
wird, d. h. es müssen mindestens
35 Ja-Stimmen vorhanden sein,
damit der Bundesrat einen Beschluss
fassen kann; Argument
für die h. M.: Für die erste u.
zweite Auffassung finden sich
keine Stützen bzw. Anhaltspunkte
im GG; Bsp.: Uneinheitliche
Stimmabgabe bei dem Zuwanderungsgesetz
2002, bei dem der
Ministerpräsident des Landes
Brandenburg mit „Ja“ u. der Innenminister
mit „Nein“ votierte.
Bundesratspräsident hat die
Stimmen des Landes gleichwohl
als gültige Ja-Stimmen gewertet,
d. h. das Zuwanderungsgesetz ist
formell verfassungswidrig zustande
gekommen; Aufgaben des
Bundesrates: 1) Mitwirkung bei
der Gesetzgebung des Bundes
(vgl. Art. 76 I, II, 77 GG); 2) Mitwirkung
im Bereich der Exekutive
(vgl. Art. 50, 80 II, 84 II, 85 II
GG); 3) Mitwirkung in Angelegenheiten
der EU (vgl. Art. 23 GG);
4) Mitwirkung im Bereich der
Judikative (vgl. Art. 94 I GG).
Bundesregierung Sie setzt sich aus dem Bundeskanzler
(=> siehe Def.) u. den
Bundesministern zusammen (Art. 62 GG) = Kabinett =>
Kompetenzen innerhalb der
Bundesregierung (Art. 65 GG): 1)
Kanzlerprinzip (= Richtlinienkompetenz),
2) Ressortprinzip,
138
3) Kollegialprinzip (=> siehe jeweils
Def.); Rangverhältnis:
Kanzlerprinzip hat stets Vorrang!
Bundeskanzler Art. 63 GG => Wahl des Bundeskanzlers:
Er wird auf Vorschlag
des Bundespräsidenten
vom Bundestag ohne Aussprache
gewählt (Art. 63 I GG).
Der Bundespräsident schlägt i. d.
R. den Kandidaten der Mehrheitspartei
bzw. -koalition vor.
Der Bundeskanzler benötigt eine
absolute Mehrheit der Stimmen
der Mitglieder des Bundestages
(Art. 63 II). Hat er diese erreicht,
so ist der Bundespräsident zur
Ernennung des Bundeskanzlers
verpflichtet. Wenn der Vorgeschlagene
nicht die absolute
Mehrheit erreicht, so kann der
Bundestag binnen 14 Tagen
nach dem Wahlgang mit mehr als
der Hälfte seiner Mitglieder einen
Bundeskanzler wählen, ohne
dass hierzu ein Vorschlag des
Bundespräsidenten vorliegen
müsste (Art. 63 III). Kommt keine
Wahl innerhalb dieser Frist zustande,
gilt Art. 63 IV GG; Amtsdauer:
Bis zum Zusammentritt
eines neuen Bundestages, Art.
69 II GG, Ausnahme: Konstruktives
Misstrauensvotum (Art. 67
GG), Vertrauensfrage (Art. 68 I
GG); Beachte: Der Bundeskanzler
hat das Recht, die Zahl u. die
Aufgaben der einzelnen Bundesminister
festzulegen (= Bestimmung
der personellen Besetzung
des Kabinetts): Außerdem muss
er die Arbeit der einzelnen Minister
koordinieren (=> siehe Kanzlerprinzip).
139
Kanzlerprinzip / Richtlinienkompetenz Art. 65 S. 1 GG => Der Bundeskanzler
bestimmt die Richtlinien
der Politik u. trägt dafür
Verantwortung. Was noch unter
die Richtlinien fällt, ist im Einzelfall
schwer zu bestimmen. Eine
enge Auslegung ist jedoch zu
bevorzugen, um die anderen
Prinzipien nicht völlig leerlaufen
zu lassen. Bei den Richtlinien
geht es um die grundlegenden
politischen Leitentscheidungen,
z. B. Ausstieg aus der Kernenergie.
Beachte: a) Die Richtlinien
binden die Einzelminister als
Leiter ihres Ministeriums, jedoch
nicht andere Verfassungsorgane!;
b) Nach h. M. können auch
Einzelfallentscheidungen unter
den Begriff der Richtlinie fallen.
Argument: Der Bundeskanzler
ist nach dem GG die Führung der
Regierung übertragen, d. h. er
trägt die volle Verantwortung gegenüber
dem Parlament. Aber:
Der Bundeskanzler darf nicht die
Kompetenz eines einzelnen Ministers
völlig aushöhlen, d. h. die
Einzelfallentscheidung muss eine
Frage von besonderer Bedeutung
für die Staatslehre betreffen.
Ressortprinzip Art. 65 S. 2 GG => Jeder Minister
leitet seinen Geschäftsbereich
innerhalb der durch die Richtlinien
vorgegebenen Grenzen
selbstständig u. unter eigener
Verantwortung; Beachte: Die
Bundesminister sind an die Weisungen
des Bundeskanzlers gebunden!
Kollegialprinzip Art. 65 S. 3, 4 GG => Über Streitigkeiten
zwischen den Bundesministern
entscheidet die Regierung
als Gesamtheit. Findet nur
in ressortübergreifenden Ange-
140
legenheiten Anwendung, die
nicht von Richtlinien des Bundeskanzlers
erfasst werden!
Bundespräsident Staatsoberhaupt der BRD =>
Aufgaben: 1) In erster Linie Repräsentationsfunktion
nach
innen u. außen (vgl. Art. 59 I
GG); 2) Integrationsfunktion im
staatlichen u. gesellschaftlichen
Bereich (partei- u. länderübergreifend);
3) Reservefunktion.
So versucht der Bundespräsident
z. B. bei Krisen der Regierung
wieder eine stabile Regierung
herzustellen, vgl. Art. 68 I 1, 63
IV 3, 68 I 1, 69 III GG; Beachte:
Der Bundespräsident ist von eigenständiger
politischer Staatsleitung
ausgeschlossen (Art. 58
S. 1 GG, siehe Def. „Anordnungen
u. Verfügungen“) u. darf keinen
Einfluss auf die politische Willensbildung
der Staatsleitung
ausüben; Wahl: Er wird durch die
Bundesversammlung (Art. 54 III
GG) gewählt (Art. 54 I GG), die
Amtszeit beträgt
5 Jahre (Art. 54
II GG); Besonderheiten: a) Prüfungsbefugnis
bei der Ausfertigung
von Gesetzen (Art. 82 I
GG)? 1) Unstreitig ist, dass er
eine formelle Prüfungsbefugnis
besitzt. Sie betrifft die Frage, ob
das Gesetz unter der Beachtung
der Zuständigkeits-, Verfahrensu.
Formvorschriften zustande gekommen
ist („Staatsnotar“). Prüfungsbefugnis
ergibt sich aus
dem Wortlaut des Art. 82 I GG;
2) Materielles Prüfungsrecht?
Dies betrifft die Frage, ob das
Gesetz inhaltlich mit der Verfassung,
insbes. mit den Grundrechten
u. den Verfassungsprinzipien,
vereinbar ist: 1. A.: Dem
Bundespräsident steht nur ein
141
formelles Prüfungsrecht zu. 2.
A.: Dem Bundespräsident steht
auch ein materielles Prüfungsrecht
zu. 3. H. M.: Prüfungsrecht
beschränkt auf eine Evidenzkontrolle,
d. h. materielles Prüfungsrecht
besteht nur bei offensichtlichen
Verstößen gegen die
Verfassung. b) Rechtliche Prüfungsbefugnis
bei der Ernennung
u. Entlassung von Ministern?:
1) H. M.: Allein rechtliche
Prüfungsbefugnis, die sich
auf die Voraussetzungen für die
Ernennung beschränkt. 2) Eingeschränktes
politisches Prüfungsrecht.
Danach soll der Bundespräsident
das Recht haben, bei
einer Gefährdung des Staatswohls
die Ernennung zu verweigern.
Argument gegen diese
Ansicht: Würde der Bundespräsident
aufgrund seiner politischen
Überzeugung die Ernennung
verweigern, dann würde
er an der Gestaltung der Politik
teilhaben. Genau das verwehrt
ihm aber die Verfassung!
Anordnungen u. Verfügungen Darunter fallen alle rechtlich ver-
(Art. 58 S. 1 GG) bindlichen Akte des Bundespräsidenten
(also nur rechtsförmliches
Handeln) => Mit der Abzeichnung
durch die Bundesregierung
übernimmt diese die
politische Verantwortung; M.M.:
Auch alle anderen amtlichen u.
politisch bedeutsamen Erklärungen
u. Handlungen des Bundespräsidenten
fallen darunter, z.
B. Reden oder Stellungnahmen
des Bundespräsidenten.
Gesetzgebungskompetenz Die Grundregel für die Verteilung
der Gesetzgebungskompetenzen
zwischen Bund u. Ländern
enthält die Vorschrift des
142
Art. 70 I GG: Hiernach haben
grundsätzlich die Länder das
Recht zur Gesetzgebung, soweit
nicht das GG dem Bund Gesetzgebungsbefugnisse
verleiht =>
Beachte: Unterscheide folgende
geschriebene Gesetzgebungskompetenzen:
a) Ausschließliche
Gesetzgebungskompetenz
des Bundes, b) Konkurrierende
Gesetzgebung, c) Grundsatzgesetzgebung;
Ungeschriebene
Gesetzgebungskompetenzen: d)
Bundeskompetenz kraft Sachzusammenhangs,
e) Annexkompetenz
des Bundes, f) Bundeskompetenz
kraft Natur der
Sache (=> siehe jeweils Def.)
Ausschließliche Gesetzgebungs- Art. 71 GG => Bedeutet, dass die
kompetenz davon erfassten Materien dem
Bundesgesetzgeber vorbehalten
sind. Die Länder sind nur bei
ausdrücklicher Ermächtigung
durch ein Bundesgesetz zuständig.
Gegenstände der ausschließlichen
Gesetzgebung des
Bundes werden in Art. 73 GG
enumerativ aufgelistet. Beachte:
Katalog des Art. 73 GG ist nicht
abschließend (vgl. z. B. Art. 105 I
GG). Bund hat ebenfalls in den
Fällen die ausschließliche Gesetzgebungsbefugnis,
in denen
das GG eine Regelung „durch
Bundesgesetz“ vorsieht. Bspe.:
Art. 4 III 2, 21 III, 38 III GG
Konkurrierende Gesetzgebung Art. 72 GG => Hier sind Bund u.
Länder grundsätzlich gleichermaßen
zur Gesetzgebung befugt.
Aber: Gem. Art. 72 I GG
haben die Länder die Befugnis
zur Gesetzgebung grds. nur,
solange u. soweit der Bundesgesetzgeber
von seiner Zuständigkeit
nicht Gebrauch gemacht hat
143
(Vorrang des Bundes). Die
Bereiche, in denen eine konkurrierende
Gesetzgebungskompetenz
besteht, sind in Art. 74
GG katalogartig aufgeführt. Beachte:
Nach Art. 72 II GG darf
der Bund in den Fällen des Art.
74 I Nr. 4, 7, 11, 13, 15, 19a, 20,
22, 25 und 26 GG nur tätig
werden, wenn u. soweit dies zur
Herstellung gleichwertiger Lebensverhältnisse
im Bundesgebiet
oder zur Wahrung der
Rechts- oder Wirtschaftseinheit
im gesamtstaatlichen Interesse
erforderlich ist (=> restriktive
Auslegung!, siehe jeweils Def.).
Herstellung gleichwertiger Lebensver- Eine Regelung ist zur Herstellung
hältnisse (Art. 72 II GG) gleichwertiger Lebensverhältnisse
erst dann erforderlich, wenn
sich die Lebensverhältnisse in
den Ländern in erheblicher, das
bundesstaatliche Sozialgefüge
beeinträchtigender Weise auseinander
entwickelt haben.
Wahrung der Rechtseinheit Eine Regelung ist zur Wahrung
(Art. 72 II GG) der Rechtseinheit erforderlich,
wenn eine Rechtszersplitterung
droht, die im Interesse sowohl
des Bundes als auch der Länder
nicht hingenommen werden
kann.
Wahrung der Wirtschaftseinheit Eine Regelung ist zur Wahrung
(Art. 72 II GG) der Wirtschaftseinheit erforderlich,
wenn Landesregelungen oder
das Untätigbleiben der Länder
erhebliche Nachteile für die Gesamtwirtschaft
mit sich bringen
kann.
Rahmengesetzgebung Achtung! Die Rahmengesetzgebung
ist aufgrund der Föderalismusreform
ersatzlos gestrichen
worden!
144
Zur bisherigen Rechtslage:
Art. 75 I GG aF => Bund hatte
das Recht zur Gesetzgebung,
wenn eine Sachmaterie des Art.
75 I GG aF u. das Bedürfnis nach
bundesgesetzlicher Regelung i.
S. v. Art. 72 II GG aF vorlagen.
Beachte: Der Bund konnte nur
Rahmenvorschriften (=> siehe
Def.) erlassen.
Rahmenvorschriften Normen, die allgemeine Grundsätze
u. Regelungen enthalten,
aber noch der Ausführung u.
Konkretisierung durch die Länder
bedürfen (=> Abschaffung
der Rahmengesetzgebung).
Grundsatzgesetzgebung Hat der Bund die Befugnis, auf
einem bestimmten Gebiet Grundsätze
zu erlassen, darf er keine
abschließende Regelung treffen,
sondern lediglich ausfüllungsfähige
u. -bedürftige Richtlinien
aufstellen => Die Grundsatzgesetzgebung
deckt sich im Wesentlichen
mit der Rahmengesetzgebung.
Aber wichtiger Unterschied:
Anders als Rahmenvorschriften
binden Grundsätze
regelmäßig nicht nur den Landes-,
sondern auch den Bundesgesetzgeber.
Bsp. für eine
Grundsatzgesetzgebungskompetenz
des Bundes: Art. 109 III GG.
Bundeskompetenz kraft Sachzusam- Liegt vor, wenn der Bund ein ihm
menhangs ausdrücklich zugewiesenes
Sachgebiet vernünftigerweise
nicht sinnvoll regeln kann, ohne
gleichzeitig eine ihm nicht zugewiesene
Materie mitzuregeln (=
„Ausdehnung in die Breite“) =>
Beachte: Diese Kompetenz
kommt sowohl für den Bereich
der ausschließlichen als auch der
145
konkurrierenden Gesetzgebung
in Betracht!
Annexkompetenz des Bundes Hier bleibt der Bund zwar in seinem
Zuständigkeitsbereich, er regelt
dabei aber bestimmte Fragenkomplexe,
die generell in
den Bereich der Landeskompetenzen
fallen => Es geht hier um
eine Ausdehnung einer ausdrücklich
zugeteilten Kompetenz in das
Stadium der Vorbereitung u.
Durchführung von Vorschriften
(= „Ausdehnung in die Tiefe“).
Bsp.: Bund kann im Bereich des
Gewerberechts einzelne Vorschriften
mit gefahrenabwehrendem
Charakter erlassen, obwohl
dies eigentlich in die Kompetenz
der Länder fällt. Beachte: Diese
Kompetenz kommt sowohl für
den Bereich der ausschließlichen
als auch der konkurrierenden Gesetzgebung
in Betracht!
Bundeskompetenz kraft Natur Liegt vor, wenn eine Angelegender
Sache heit schon aus sachlogischen
Gründen nur vom Bund geregelt
werden kann => Regelung kann
also nur bundeseinheitlich erfolgen,
z. B. die Festlegung der
Bundeshauptstadt. Beachte: Diese
Kompetenz kommt nur für den
Bereich der ausschließlichen Gesetzgebung
in Betracht.
Aus der Mitte des BT (Art. 76 I GG) Was hierunter zu verstehen ist,
sagt das GG nicht. Aber: § 76
GO BT konkretisiert dies u. fordert,
dass der Gesetzentwurf von
einer Fraktion oder mindestens 5
% der Mitglieder des BT unterzeichnet
ist. Dies stellt eine Konkretisierung
des Art. 76 I GG dar
(h. M.). Demnach kann ein einzelner
Abgeordneter nicht die
Gesetzesinitiative ergreifen. Be-
146
achte: Befasst sich der BT aber
mit dem Gesetz, das ein einzelner
Abgeordneter in den BT eingebracht
hat, u. der BT beschließt
es dann auch, ist das
Gesetz nicht nichtig! Durch die
Beschlussfassung des BT hat
sich dieser die Gesetzesvorlage
des Abgeordneten mehrheitlich
zu Eigen gemacht; damit wird der
anfängliche Formmangel geheilt!
Gesetzesberatungen §§ 78 ff. GO BT => Art. 77 I GG
beschränkt sich nur auf die Feststellung,
dass die Bundesgesetze
durch den BT beschlossen werden.
Das nähere Verfahren ist in
der GO BT geregelt. Es finden
drei Lesungen statt (siehe §§ 78
ff. GO BT). Beachte: Ein Verstoß
gegen die §§ 78 ff. GO BT führt
nicht zur Verfassungswidrigkeit
des Gesetzes, da sie nicht einen
wesentlichen Verfassungsinhalt
konkretisieren.
Einspruchsgesetz Gesetz, das auch ohne eine
Handlung des BR zustande
kommt => Beachte: a) Alle Gesetze,
die nicht Zustimmungsgesetze
sind, sind Einspruchsgesetze!;
b) BR besitzt lediglich ein
relatives Vetorecht. Der BR kann
gegen das vom BT beschlossene
Gesetz einen Einspruch einlegen,
den der BT aber zurückzuweisen
berechtigt ist. Dazu ist ein
Beschluss der Mehrheit der Mitglieder
des BT erforderlich (Art.
77 IV 1 GG). Hat der BR den Einspruch
mit einer Mehrheit von
mindestens 2/3 seiner Stimmen
beschlossen, dann bedarf die
Zurückweisung durch den BT
sogar eines Beschlusses einer
Mehrheit von 2/3 bzw. mindes-
147
tens der Mehrheit der Mitglieder
des BT (Art. 77 IV 2 GG).
Zustimmungsgesetz Gesetz, das nur durch die Zustimmung
des BR zustande
kommt (Art. 78 Alt. 1 GG) => Beachte:
a) BR hat also ein absolutes
Vetorecht; b) Zustimmungsbedürftige
Gesetze sind im
GG ausdrücklich gekennzeichnet.
Bspe.: Art. 84 I, 85 I, 105 III
GG. Diese Gesetze betreffen die
Bereiche Verfassung, Verwaltung
u. Finanzen; c) Begründet nur eine
einzige Vorschrift des Gesetzes
die Zustimmungsbedürftigkeit,
dann ist das ganze Gesetz zustimmungsbedürftig
(h. M., str.).
Der BR wäre also auch in der Lage,
seine Zustimmung zu verweigern,
wenn er eine Regelung
missbilligt, die eigentlich nicht zustimmungsbedürftig
wäre. A. A.:
Zustimmungspflicht bezieht sich
allein auf die zustimmungsbegründende
Norm; d) Problem:
Zustimmungsbedürftigkeit von
Änderungsgesetzen? Macht also
jede Änderung eines Zustimmungsgesetzes
eine Zustimmung
notwendig? Wird ein ursprünglich
zustimmungsbedürftiges Gesetz
geändert, bedarf das Änderungsgesetz
der Zustimmung des BR,
wenn es 1) selbst zustimmungsbedürftige
Vorschriften enthält,
2) Vorschriften des ursprünglichen
Gesetzes betrifft, die die Zustimmungsbedürftigkeit
ausgelöst
haben, oder 3) das Änderungsgesetz
den ursprünglich zustimmungsbedürftigen
Vorschriften
eine wesentlich andere
Tragweite u. Bedeutung verleiht,
auch wenn sie nicht ausdrücklich
geändert wurden.
148
Bundesverfassungsgericht Es ist ein Gericht i. S. v. Art. 92
GG u. ein oberstes Verfassungsorgan
=> Man bezeichnet das
BVerfG auch als „Hüter der Verfassung“.
Es ist nämlich befugt,
auf Antrag die verfassungsrechtlichen
Grenzen der politischen
Staatsleitung aufzuzeigen u. damit
die Legislative u. Exekutive in
ihre Schranken zu weisen. Die
Zuständigkeit des BVerfG bestimmt
sich nach dem sog. Enumerationsprinzip.
Regelungen
hierzu finden sich insbes. in Art.
93 GG, aber auch in Art. 18, 21 II
2 , 41 II, 61, 98 II, V, 100, 126
GG. Wichtige Verfahrensarten
vor dem BVerfG: 1) Organstreitverfahren,
2) Bund-LänderStreit,
3) abstrakte Normenkontrolle,
4) konkrete Normenkontrolle,
5) Verfassungsbeschwerde
(=> siehe jeweils Def.)
Enumerationsprinzip Siehe bei Def. Bundesverfassungsgericht.
Organstreitverfahren Art. 93 I Nr. 1 GG, §§ 13 Nr. 5,
63 ff. BVerfGG => Es muss sich
um verfassungsrechtliche Streitigkeiten
zwischen Bundesorganen
oder anderen Beteiligten handeln,
die durch das GG oder in
der GO eines obersten Bundesorgans
mit eigenen Rechten ausgestattet
sind. Prüfungsschema:
Der Antrag auf Durchführung eines
Organstreitverfahrens hat Erfolg,
wenn er zulässig u. begründet
ist. A) Zulässigkeit: a) Zuständigkeit
des BVerfG gem.
Art. 93 I Nr. 1 GG, § 13 Nr. 5
BVerfGG; b) Parteifähigkeit
(auch Beteiligtenfähigkeit oder
Antragsberechtigung genannt):
§ 63 BVerfGG, d. h. Bundespräsident,
Bundestag, Bundesrat,
149
Bundesregierung, sowie Organteile
i. S. v. § 63 BVerfGG, soweit
sie mit eigenen Rechten ausgestattet
sind (z. B. Bundesminister,
Fraktionen, Ausschüsse, Bundeskanzler),
„andere Beteiligte“ i. S.
v. Art. 93 I Nr. 1 GG: z. B. politische
Parteien (Ausstattung mit
eigenen Rechten durch Art. 21
GG, jedoch muss es um die Verletzung
ihres verfassungsrechtlichen
Status gehen!), der einzelne
Abgeordnete oder die Bundesversammlung;
c) Streitgegenstand:
§ 64 I BVerfGG: Jede
verfassungsrechlich erhebliche
Maßnahme bzw. jedes Unterlassen
des Antragsgegners; d) Antragsbefugnis:
§ 64 I BVerfGG:
Möglichkeit einer Verletzung
oder unmittelbaren Gefährdung
eigener Rechte, die sich aus dem
GG ergeben (= Möglichkeitstheorie).
Beachte: Die Prozessstandschaft
ist gem. § 64 I
BVerfGG für Organteile zulässig.
Somit können Organteile die verfassungsrechtlichen
Rechte des
Organs selbst im eigenen Namen
geltend machen u. zwar
auch dann, wenn dieses Organ in
der Mehrheit seine Rechte als
nicht verletzt ansieht. Bsp.: Bundestagsfraktion
macht eine Verletzung
der Rechte des Bundestags
(in seiner Gesamtheit) geltend;
e) Frist: § 64 III BVerfGG; f)
Form: § 64 II BVerfGG; B) Begründetheit:
Der Antrag ist begründet,
wenn die beanstandete
Maßnahme bzw. Unterlassung
gegen das GG verstößt u. dadurch
Rechte bzw. Pflichten des
Antragsstellers verletzt.
150
Bund-Länder-Streit Art. 93 I Nr. 3 GG, §§ 13 Nr. 7,
68 ff. BVerfGG => Es muss sich
um Streitigkeiten zwischen dem
Bund u. einem Land oder von
Ländern untereinander handeln.
Prüfungsschema: Der Antrag
auf Durchführung eines BundLänder-Streits
hat Erfolg, wenn er
zulässig u. begründet ist. A) Zulässigkeit:
a) Zuständigkeit des
BVerfG: Art. 93 I Nr. 3 GG, §§ 13
Nr. 7 BVerfGG; b) Parteifähigkeit:
§ 68 BVerfGG: Bundesregierung,
Landesregierung, nicht
Parlamente; c) Streitgegenstand:
Art. 93 I Nr. 3 GG; d) Antragsbefugnis:
§§ 69 i. V. m. 64
I BVerfGG; e) Frist: §§ 69 , 64 III
BVerfGG; f) Form: § 23 I
BVerfGG; B) Begründetheit:
Der Antrag ist begründet, wenn
die beanstandete Maßnahme
bzw. Unterlassung gegen das
GG verstößt u. dadurch Rechte
bzw. Pflichten des Antragsstellers
verletzt.
Abstrakte Normenkontrolle Art. 93 I Nr. 2 GG, §§ 13 Nr. 6,
76 ff. BVerfGG => Überprüft wird
in diesem Verfahren die Vereinbarkeit
von Bundesrecht mit dem
GG oder die Vereinbarkeit von
Landesrecht mit dem GG oder
mit sonstigem Bundesrecht. Prüfungsschema:
Der Antrag auf
Durchführung einer abstrakten
Normenkontrolle hat Erfolg, wenn
er zulässig u. begründet ist. A)
Zulässigkeit: a) Zuständigkeit
des BVerfG: Art. 93 I Nr. 2 GG,
§ 13 Nr. 6 BVerfGG; b) Antragsberechtigung:
Art. 93 I Nr. 2
GG, § 76 BVerfGG: Bundesregierung,
Landesregierung oder
1/4 der Mitglieder des Bundestags;
c) Antragsgegenstand: 1.
Vereinbarkeit von Bundesrecht
151
mit dem GG, 2. Vereinbarkeit von
Landesrecht mit GG u. sonstigem
Bundesrecht. Es kann jede
Rechtsnorm mit Außenwirkung
überprüft werden, z. B. Rechtsverordnung,
Satzung. Beachte:
Eine vorbeugende Normenkontrolle
ist unzulässig; d) Antragsbefugnis:
aa) Der Antragsteller
hält das Recht für nichtig bzw.
gültig, wobei nach dem vorrangigen
Art. 93 I Nr. 2 GG
Zweifel oder Meinungsverschiedenheiten
an der Vereinbarkeit
ausreichen, bb) Obj. Klarstellungsinteresse:
obj. Interesse
an der Klarstellung der Gültigkeit
bzw. Ungültigkeit der Norm; e)
Form: § 23 I BVerfGG, eine Frist
ist nicht vorgesehen; B) Begründetheit:
Der Antrag ist begründet,
wenn Bundesrecht mit dem
GG oder Landesrecht mit dem
GG oder dem sonstigen Bundesrecht
unvereinbar ist (es folgt
also die formelle u. materielle
Rechtmäßigkeitsprüfung der
Norm).
Konkrete Normenkontrolle Art. 100 I GG, §§ 13 Nr. 11, 80
ff. BVerfGG => Prüfungsschema:
Der Antrag auf Durchführung
einer konkreten Normenkontrolle
hat Erfolg, wenn er zulässig u.
begründet ist. A) Zulässigkeit: a)
Zuständigkeit des BVerfG: Art.
100 I GG, § 13 Nr. 11 BVerfGG;
b) Vorlageberechtigung: Art.
100 I GG: ein Gericht. Beachte:
Alle Gerichte!; c) Kontrollgegenstand:
Art. 100 I GG: formelle
Bundes- bzw. Landesgesetze.
Beachte: Beschränkung auf
nachkonstitutionelle Gesetze,
d. h. auf Gesetze, die nach dem
Inkrafttreten des GG verkündet
worden sind; d) Gericht muss von
152
der Verfassungswidrigkeit des
Gesetzes überzeugt sein, d. h.
bloße Zweifel genügen nicht; e)
Entscheidungserheblichkeit
des Gesetzes: Art. 100 I GG. Diese
liegt vor, wenn das vorlegende
Gericht bei Ungültigkeit des Gesetzes
anders entscheiden würde
als bei dessen Gültigkeit; f)
Form: § 80 I, II 1 BVerfGG; B)
Begründetheit: Die Vorlage ist
begründet, wenn der Prüfungsgegenstand
nicht mit dem GG vereinbar
ist (es folgt also die formelle
u. materielle Rechtmäßigkeitsprüfung
des Gesetzes bzw.
der Norm).
Verfassungsbeschwerde Art. 93 I Nr. 4a GG, §§ 13 Nr. 8a,
90 ff. BVerfGG => Prüfungsschema:
A) Zulässigkeit: a) Zuständigkeit
des BVerfG: Art. 93 I
Nr. 4a GG, § 13 Nr. 8a BVerfGG;
b) Parteifähigkeit: Art. 93 I Nr.
4a GG, § 90 I BVerfGG: „Jedermann“,
der grundrechtsfähig ist.
Beachte: 1) Unterscheide Jedermann-
u. Deutschengrundrechte
(z. B. Art. 8 I, Art. 9 I GG). Ausländer
können sich nicht auf die
Deutschengrundrechte berufen!
Ihnen wird nur über das Auffanggrundrecht
des Art. 2 I (Allgemeine
Handlungsfreiheit) Grundrechtsschutz
gewährt; 2) Juristische
Personen: Art. 19 III GG,
d. h. Parteifähigkeit liegt vor,
wenn das Grundrecht seinem
Wesen nach auf juristische Personen
anwendbar ist. Problem:
Grundrechtsfähigkeit bei Vereinigungen
ohne Rechtsfähigkeit (z.
B. KG, Skatgruppe)? Rechtsfähigkeit
ist nicht Vor. für die
Grundrechtsfähigkeit (h. M., str.),
allerdings müssen den Personenmehrheiten
dann von der Rechts-
153
ordnung Rechte zugewiesen werden
(Bei der KG ist dies der Fall,
bei der Skatgruppe ist dies nicht
der Fall, d. h. im Bsp. ist die Skatgruppe
nicht grundrechtsfähig; 3)
Juristische Personen des öffentlichen
Rechts (z. B. Gemeinden):
Grundsatz: Sie sind
nicht grundrechtsfähig (h. M.,
str.). Ausnahmen: aa) Im Bereich
der Verfahrensgrundrechte
(z. B. Art. 19 IV, 101 I 2, 103 I
GG). Diese gelten auch für juristische
Personen des öffentlichen
Rechts; bb) Grundrechtsfähigkeit
gegeben bei: Rundfunkanstalten
(Art. 5 I 2 GG), Universitäten u.
Fakultäten (Art. 5 III 1 GG), Religionsgemeinschaften
u. Kirchen
(Art. 4 I, 140 GG). c) Prozessfähigkeit:
Fähigkeit, Verfahrenshandlungen
wirksam vorzunehmen.
Nur bei Minderjährigen relevant.
Diese sollen dann prozessfähig
sein, wenn sie grundrechtsmündig
sind, d. h. wenn
sie über eine hinreichende Einsichtsfähigkeit
zur Ausübung des
Grundrechts verfügen (=> ggf.
durch Auslegung ermitteln). Liegt
dies nicht vor, dann muss die
Klage des Minderjährigen durch
den gesetzlichen Vertreter eingelegt
werden! Beachte: Juristische
Personen sind nicht prozessfähig,
d. h. sie müssen ihre
Grundrechte durch ihre Vertreter
geltend machen; d) Beschwerdegegenstand:
Art. 93 I Nr. 4a
GG, § 90 I BVerfGG: Akte der
öffentlichen Gewalt (= Handlungen,
Duldungen, Unterlassungen),
d. h. Akte der Exekutive (z. B.
VAe), der Judikative (z. B.
Urteile, Beschlüsse) u. der Legislative
(z. B. formelle Gesetze).
Beachte: aa) Es werden bei
154
mehreren Akten zur gleichen
Sache gleichzeitig alle Akte angegriffen,
d. h. es liegt nur eine
VB vor, bb) Auch die mittelbare
Staatsgewalt, d. h. juristische
Personen des Privatrechts, sofern
sie i. R. d. Verwaltungsprivatrechts
(=> siehe Def.) tätig
werden u. Beliehene (=> siehe
Def.), gehört zur Exekutive; e)
Beschwerdebefugnis: Art. 93 I
Nr. 4a GG, § 90 I BVerfGG: aa)
Beschwerdeführer muss behaupten,
durch den angegriffenen Akt
der öffentlichen Gewalt in einem
seiner Grundrechte bzw. grundrechtsgleichen
Rechte verletzt zu
sein. Es genügt die Möglichkeit
der Grundrechtsverletzung. Diese
liegt vor, wenn sie nach keiner
Betrachtungsweise ausgeschlossen
werden kann, bb) Betroffenheit
des Beschwerdeführers: Beschwerdeführer
muss selbst, gegenwärtig
u. unmittelbar betroffen
sein. 1) Selbstbetroffenheit:
Beschwerdeführer muss in eigenen
Grundrechten verletzt
sein. Beschwerdeführer ist also
selbst Adressat der staatlichen
Maßnahme! Ist er Drittbetroffener
u. wird ebenfalls in seinen
Grundrechten berührt, dann gilt:
Hier liegt dann Selbstbetroffenheit
vor, wenn er in seinen rechtlichen
Handlungsmöglichkeiten
beschränkt wird. Bsp.: Das Ladenschlussgesetz
richtet sich nur
gegen die Ladeninhaber, aber
beschränkt auch andererseits die
Kunden; 2) Gegenwärtige Betroffenheit:
Liegt vor, wenn der
Beschwerdeführer schon oder
noch betroffen ist. Beachte: Eine
VB gegen ein Gesetz, das irgendwann
einmal in Zukunft in
Kraft tritt, ist demnach unzuläs-
155
sig. Die gegenwärtige Betroffenheit
liegt aber vor, wenn ein Gesetz
die Normadressaten bereits
gegenwärtig zu später nicht mehr
korrigierbaren Entscheidungen
zwingt oder schon jetzt zu Dispositionen
veranlasst, die sich
nach dem späteren Gesetzesvollzug
nicht mehr nachholen lassen.
Bsp.: Der 25jährige Jurastudent
X ist von dem Gesetz, das eine
Altersgrenze von 27 Jahren für
die Zulassung als Rechtsanwalt
festsetzt, schon gegenwärtig betroffen,
obwohl er die Altersgrenze
noch nicht erreicht hat; 3) Unmittelbare
Betroffenheit: Liegt
vor, wenn die angegriffene Vorschrift
ohne einen weiteren Vollzugsakt
in den Rechtskreis des
Beschwerdeführers eingreift.
Dies ist häufig nicht der Fall bei
Gesetzen, auf deren Grundlage
erst ein VA ergehen muss. Ermächtigt
also erst das Gesetz die
Verwaltung zum Eingriff, so fehlt
es an einer hinreichenden Betroffenheit,
solange das Verbot nicht
ergangen ist. Ausnahmen, bei
denen die Zulässigkeit vorliegt,
obwohl die gegenwärtige oder
unmittelbare Betroffenheit fehlt:
aa) Bei Strafgesetzen: Hier kann
nicht erwartet werden, dass der
Beschwerdeführer ein letztinstanzliches
Urteil gegen sich ergehen
lässt, bevor er die Norm
angreifen kann, bb) Gesetz
zwingt den Normadressaten zu
nicht mehr korrigierbaren Entscheidungen,
cc) Gesetz veranlasst
den Normadressaten zu
Dispositionen, die er nach dem
späteren Gesetzesvollzug nicht
mehr nachholen kann; f) Erschöpfung
des Rechtswegs:
§ 90 II 1 BVerfGG: Die VB kann
156
erst nach Erschöpfung des
Rechtswegs erhoben werden,
wenn gegen die Verletzung ein
Rechtsweg zulässig ist. Grundsatz
der Subsidiarität: Die VB
ist subsidiär, d. h. der Beschwerdeführer
muss erst alle möglichen
Gerichtsinstanzen durchlaufen
haben. Ausnahmen: aa)
Nicht erforderlich bei Beschwerden
gegen ein Gesetz, da
es hier keinen Rechtsweg gibt;
bb) Fälle des § 90 II 2 BVerfGG:
Sache ist von allgemeiner Bedeutung
oder dem Beschwerdeführer
droht ein schwerer u. unabwendbarer
Nachteil; cc) Anerkannte
ungeschriebene Ausnahmen:
Fälle, in denen dem Beschwerdeführer
die Erschöpfung
des Rechtswegs unzumutbar ist.
Bsp.: Bei gefestigter Rechtsprechung.
Hier ist klar, dass der
Beschwerdeführer vor den Fachgerichten
keinen Erfolg haben
wird. Weiteres Bsp.: Erfolglosigkeit
in zwei Instanzen u. eine eindeutige
gesetzliche Regelung,
bei der im weiteren Instanzenzug
kein anderes Ergebnis zu erwarten
ist; g) Rechtsschutzbedürfnis:
Beschwerdeführer muss ein
schutzwürdiges Interesse an
der gerichtlichen Feststellung
haben. Liegt nicht in den Fällen
vor, in denen sich der Hoheitsakt
zum Zeitpunkt der Entscheidung
erledigt hat. Ausnahmen:
Rechtsschutzbedürfnis liegt vor,
wenn aa) Wiederholungsgefahr
besteht, bb) ein bedeutendes
Grundrecht betroffen oder cc) die
Frage von grundsätzlicher Bedeutung
ist, d. h. es besteht Interesse
an Klärung der verfassungsrechtlichen
Frage; h) Form u.
Frist: §§ 23 I, 92, 93 I BVerfGG:
157
Antrag muss schriftlich u. mit Begründung
eingereicht werden. VB
gegen Entscheidungen, § 93 I 1
BVerfGG: 1 Monat. Fristbeginn:
§ 93 I 2, 3 BVerfGG. VB gegen
Gesetze, § 93 III BVerfGG: 1
Jahr. Fristbeginn: Inkraften des
Gesetzes (Art. 82 II GG). Beachte:
Für die Fristberechnung gelten
die §§ 187, 188 BGB; B) Begründetheit:
VB ist begründet,
wenn der Beschwerdeführer
durch den angegriffenen Akt der
öffentlichen Gewalt in einem
seiner Grundrechte oder grundrechtsgleichen
Rechte verletzt ist.
Es folgt eine Grundrechtsprüfung
(I. Schutzbereich, II. Eingriff, III.
Verfassungsrechtliche Rechtfertigung
=> siehe bei den jeweiligen
Grundrechten, Kapitel 2). Beachte:
Bei VB gegen Gesetze gilt:
Überprüfung des angegriffenen
Gesetzes anhand der gesamten
Verfassung. Bei VB gegen Urteile:
Hier darf das BVerfG nur prüfen,
ob spezifisches Verfassungsrecht
verletzt ist, d. h. ob
die Gerichte bei der Anwendung
u. Auslegung des einfachen
Rechts Verfassungsrecht verletzt,
insbes. das Willkürverbot (Art. 3 I
GG) missachtet haben (=
Heck`sche Formel). BVerfG prüft
demnach, ob die Gerichte ein
Grundrecht ganz übersehen oder
grundsätzlich falsch angewendet
oder eine unhaltbare u. willkürliche
Entscheidung getroffen
haben.
2. Strafrecht BT: § 185
Ehre Achtungsanspruch, der einem
Menschen kraft seiner Persönlichkeit
und zugleich
seines sittlich-sozialen Verhaltens
in der Gesellschaft zukommt
Beleidigung Kundgabe der Nichtachtung,
Missachtung oder Geringschätzung
einer Person, die
geeignet ist, den Betroffenen
verächtlich zu machen oder
in der öffentlichen Meinung
herabzuwürdigen => durch
Tatsachenbehauptungen,
Werturteile, symbolische Gesten,
ehrverletzende Behandlung
(Anspucken)
Tatsachenbehauptung Äußerung über konkrete Vorgänge
oder Zustände der Vergangenheit
oder Gegenwart,
die dem Beweis zugänglich
sind
Werturteil Ist eine subjektive Einschätzung,
deren Richtigkeit
oder Unrichtigkeit als Sache
persönlicher Überzeugung
dargestellt wird
Mittelbare Beleidigung Wenn außer dem unmittelbar
Betroffenen auch Dritte in ihrem
Achtungsanspruch verletzt
sind
§§ 186, 187
Tatsachen Siehe Tatsachenbehauptung
bei § 185
Behaupten Etwas nach eigener Überzeugung
gegenüber einem
63
Dritten als richtig hinstellen,
auch wenn man es von Dritten
erfahren und nicht selbst
gesehen hat
Verbreiten Eine Tatsache als Gegenstand
fremden Wissens weitergeben,
ohne sich diese
Tatsache zu eigen zu machen
§ 189
Verunglimpfen Besonders schwere Ehrenkränkung.
Es muss schwere
Beleidigung, üble Nachrede
von Gewicht oder Verleumdung
vorliegen
§ 203
Fremdes Geheimnis Tatsache, die nur einem begrenzten
Personenkreis bekannt
ist und an deren Geheimhaltung
derjenige, den
sie betrifft, ein schutzwürdiges
Interesse hat
§ 211
Tod Das endgültige (irreversible)
Erlöschen aller Gehirnfunktionen
(Hirntod)
§ 211 II 1. Gruppe
Mordlust Tötung, die ausschließlich dadurch
motiviert ist, dass der
Täter Freude am Töten empfindet,
sei es aus Mutwillen,
aus Angeberei, zum Zeitvertreib
oder aus sportlichem
Ehrgeiz => Dem Täter kommt
es einzig darauf an, einen
Menschen sterben zu sehen
64
(alle weiteren Definitionen zu § 211 im Skript „Definitionen für die
Strafrechtsklausur“)
§ 212
Mensch Beginn des menschlichen
Lebens: Beginn der Geburt,
d. h. mit den Eröffnungswehen
(bei Kaiserschnitt ab Öffnen
des Uterus) => Auf Lebensfähigkeit
des Kindes
kommt es nicht an. Ende
des menschlichen Lebens:
Hirntod (siehe bei § 211)
§ 216
Verlangen Tötung muss durch autonomen
Willen des Opfers ernstlich
begehrt und unmissverständlich
kundgetan worden
sein, d. h. im Tatzeitpunkt
noch vorliegen
Ernstlichkeit Setzt voraus, dass der Verlangende
imstande ist, die
Tragweite seiner Entscheidung
zu erfassen, und dass
er sie frei von Zwang und frei
von anderen wesentlichen
Willensmängeln trifft
Aktive Euthanasie Aktive Sterbehilfe. Lebensverkürzung
durch aktives Tun
(Verabreichung einer Todesspritze)
=> grundsätzlich
gem. § 216 strafbar, wenn
dessen Voraussetzungen vorliegen
65
Passive Euthanasie Passive Sterbehilfe durch
Sterben-Lassen. Unterlassung
lebenserhaltender Maßnahmen,
wodurch der Sterbevorgang
beschleunigt wird =>
zulässig, wenn ein tatsächlicher
oder mutmaßlicher Wille
des Patienten feststellbar ist
(Einverständlicher Behandlungsverzicht
durch Einwilligung/Verlangen)
oder wenn
das Schmerzlinderungsinteresse
überwiegt (einseitiger
Behandlungsabbruch). Sonst
ist Sterbehilfe nur zulässig,
wenn Lebensverlängerungsmaßnahmen
faktisch unmöglich
oder normativ unzumutbar
sind
§ 221
Hilflose Lage Situation, in der der Betreffende
sich nicht aus eigener
Kraft vor einer ihm drohenden
Gefahr schützen kann =>
konkrete Gefahr des Todes
(Lebensgefahr) / konkrete
Gefahr einer schweren Gesundheitsschädigung
Versetzen Zustandsveränderung beim
Opfer vornehmen, deren Folge
eine hilflose Lage ist, in
der dann das Opfer allein gelassen
wird => Versetzen ist
auch durch Unterlassen bei
bestehender Garantenstellung
i. S. d. § 13 I möglich
Im-Stich-lassen Unterlassen der zur Gefahrabwendung
gebotenen und
66
nach den Umständen auch
möglichen und zumutbaren
Hilfeleistung, wodurch eine
bestehende Gefahr entweder
nicht beseitigt oder erhöht
wird => Täter kann nur sein,
wer gegenüber der hilflosen
Person eine Obhuts- oder
Beistandspflicht hat. Ob so
eine Pflicht für das Opfer besteht,
ist nach den Grundsätzen
über die Entstehung
einer Garantenstellung zu beurteilen
(siehe wie bei Beschützer-/Überwachungsgaranten)
Obhut Bereits tatsächlich bestehendes
Schutz- oder Betreuungsverhältnis
Beistandspflicht Besondere Pflicht erforderlich,
dass der Im-Stich-Gelassene
nicht in Gesundheitsgefahr
gerät
Schwere Gesundheitsschädigung Besteht in einem physischen
oder psychischen Krankheitszustand,
der die Gesundheit
des Betroffenen ernstlich,
einschneidend und nachhaltig,
d. h. langwierig, qualvoll
oder lebensbedrohend,
beeinträchtigt => beinhaltet
auch erhebliche Herabsetzung
der Arbeitskraft
67
§ 223
Körperliche Misshandlung Umfasst alle substanzverletzenden
Einwirkungen auf
den Körper des Opfers sowie
jede üble, unangemessene
Behandlung, durch die das
körperliche Wohlbefinden
oder die körperliche Unversehrtheit
mehr als nur unerheblich
beeinträchtigt wird
=> notwendig ist eine Beeinträchtigung
des physischen
Wohlbefindens. Seelische
Beeinträchtigungen reichen
dann aus, wenn sie körperliche
Auswirkungen nach sich
ziehen, z.B. Angstschweiß
oder Herzrasen
Gesundheitsschädigung Hervorrufen oder Steigern
eines vom Normalzustand
nachteilig abweichenden
krankhaften Zustandes körperlicher
oder psychischer
Art
§ 224
§ 224 I Nr. 1
Gift Jeder anorganische oder organische
Stoff, der unter bestimmten
Bedingungen durch
chemische oder chemischphysikalische
Wirkungen die
Gesundheit zu schädigen vermag
=> z. B. Salzsäure,
Rauschmittel, Arsen. Gift ist
hier nur ein Unterfall der gesundheitsschädlichen
Stoffe
68
Gesundheitsschädliche Stoffe Stoffe, die mechanisch oder
thermisch wirken => z. B. heißes
Wasser, gestoßenes Glas
Beibringen Sobald Stoffe in den Körper
des anderen eingeführt
werden, so dass diese ihre
gesundheitsschädlichen Wirkungen
entfalten können
§ 224 I Nr. 2
Waffe Gebrauchsbereiter Gegenstand,
der seiner Natur nach
dazu bestimmt ist, auf mechanischem
oder chemischem
Wege einem Menschen Verletzungen
beizufügen (Waffe
ist nur ein Unterfall eines
gefährlichen Werkzeuges)
Gefährliches Werkzeug,
§ 224 I Nr. 2 Jeder Gegenstand, der nach
seiner Beschaffenheit und der
Art seiner Verwendung als
Angriffs- oder Verteidigungsmittel
im konkreten Fall geeignet
ist, erhebliche Verletzungen
zuzufügen => Nach
Auffassung des BGH muss
das Werkzeug auf das Opfer
zubewegt werden, sprich
„beweglich“ sein
§ 224 I Nr. 3
Überfall Jeder plötzliche, unerwartete
Angriff auf einen Ahnungslosen
69
Hinterlistig Wenn der Täter seine wahre
Absicht planmäßig berechnend
verdeckt, um gerade dadurch
die Abwehr zu erschweren
§ 224 I Nr. 4
Mit einem anderen Beteiligten Mindestens zwei Personen
gemeinschaftlich begangen müssen unmittelbar am Tatort
als Angreifer zusammenwirken;
erfasst sind nach h.
M. auch Teilnehmer
§ 224 I Nr. 5
Lebensgefährdende Behandlung Verletzungshandlung muss
nach den konkreten Umständen
geeignet sein, das
Leben des Opfers in eine abstrakte
Gefahr zu bringen =>
d. h. eine konkrete Lebensgefahr
ist nicht erforderlich
(h.M.)! A.A.: Lebensgefahr
muss konkret sein
§ 225
Quälen Verursachung länger andauernder
oder sich wiederholender
erheblicher Schmerzen
oder Leiden körperlicher
oder seelischer Art
Rohe Misshandlung Erhebliche Beeinträchtigung
des körperlichen Wohlbefindens
infolge gefühlloser, fremdes
Leiden missachtender
Gesinnung
Böswillige Vernachlässigung Unterlassung der dem Täter
möglichen, erforderlichen und
ihm zumutbaren Sorgemaßnahmen
aus einem beson-
70
ders verwerflichen Motiv
heraus (=> z. B. Hass, Bosheit),
nicht jedoch aus Gleichgültigkeit
oder Charakterschwäche
Schwere Gesundheitsschädigung Siehe bei § 221
(§ 225 III Nr. 1)
§ 226
§ 226 I Nr. 2
Glied In sich abgeschlossener Körperteil
mit Eigenaufgaben im
Gesamtorganismus => z. B.
Nase, eine Hand, Zeigefinger;
nach einer Ansicht auch
innere Organe
Wichtigkeit Wesentliche Bedeutung des
Gliedes für den Menschen
(objektive Gesamtfunktion) =>
h.Lit. berücksichtigt im Gegensatz
zur Rspr. auch die
individuellen Verhältnisse des
Tatopfers, wie z. B. dessen
Beruf
Verlust / Gebrauchsunfähigkeit Abtrennen des wichtigen
Gliedes begründet den Verlust.
Gebrauchsunfähigkeit
liegt vor, wenn der Verletzte
das Glied dauerhaft nicht
mehr seiner Funktion entsprechend
einsetzen kann,
z.B. Versteifung eines Gliedes
§ 226 I Nr. 3
Erheblich entstellt Erheblich entstellt ist eine
Person, wenn ihr äußeres Erscheinungsbild
durch eine
71
körperliche Verunstaltung
wesentlich beeinträchtigt wird
Dauernd Dauernd ist eine Entstellung,
wenn sie mit einer bleibenden
oder unbestimmt langwierigen
Beeinträchtigung
des Aussehens verbunden ist
=> Allerdings: Realisierbarkeit
und Zumutbarkeit von kosmetischen
Operationen berücksichtigen!
Lähmung Erhebliche Beeinträchtigung
der Bewegungsfreiheit
eines Körperteils, die den
ganzen Körper in Mitleidenschaft
zieht
Geistige Behinderung Jede Gehirnverletzung, die
körperliche Auswirkungen
nicht unerheblichen Maßes
hat
§ 231
Schlägerei Tätlicher Streit mit gegenseitigen
Körperverletzungen
zwischen mindestens drei
Personen => Schlägerei endet
in dem Moment, in dem
sich die dritte Person entfernt
und somit nur noch zwei
Personen übrig bleiben
Von mehreren verübter Angriff Feindselige, unmittelbar auf
den Körper des bzw. der
Opfer abzielende Einwirkung
durch mindestens zwei
Personen => Angreifer müssen
nicht mittäterschaftlich zusammenwirken!
72
Beteiligt Jede am Tatort stattfindende
physische oder psychische
Mitwirkung an einer gegen
eine andere Person gerichteten
Tätlichkeit => jede
aktive Teilnahme genügt, z. B.
Abhalten von Hilfe, Anfeuern
§ 239
Fortbewegungsfreiheit Freiheit, sich vom derzeitigen
Aufenthaltsort jederzeit ohne
Beeinträchtigung fortzubewegen,
sofern man es wollte
Einsperren Festhalten in einem umschlossenen
Raum durch
äußere Vorrichtungen, so
dass der Betroffene daran gehindert
ist, sich frei von der
Stelle fortzubewegen =>
Auch in einem beweglichen
Gegenstand möglich, z. B.
fahrendes Auto
Auf andere Weise der Freiheit Eingriff in die persönliche
beraubt Bewegungsfreiheit eines Menschen
durch Gewalt, List
oder Drohung, so dass diesem
- auch nur vorübergehend-
die Möglichkeit genommen
wird, sich frei fortzubewegen
§ 239a / § 239b
Entführen Die vom Täter vorgenommene
oder veranlasste Änderung
des Aufenthaltsortes
einer Person gegen oder
ohne den Willen des Opfers
73
Sich-Bemächtigen Begründung eigener physischer
Herrschaft über den
Körper eines anderen Menschen
=> Ortsveränderung ist
nicht notwendig!
§ 240
Nötigen Das Opfer gegen seinen Willen
zu einem Handeln, Dulden
oder Unterlassen zwingen
Gewalt Laut BGH der durch körperliche
Kraftentfaltung vermittelte
(zumindest auch) physisch
beim Opfer wirkende
Zwang zur Überwindung von
geleistetem oder erwarteten
Widerstand. Der sog. vergeistigte
Gewaltbegriff, der
bereits bei psychisch wirkendem
Zwang „Gewalt“ bejahte,
ist wegen Verstoßes gegen
das Analogieverbot (Art. 103
II GG) nach einer Entscheidung
des BVerfG nicht mehr
haltbar. Eine bloße Sitzblockade
als solche stellt also noch
keine Gewalt dar
Drohung Das ausdrückliche oder konkludente
Inaussichtstellen eines
künftigen Übels, auf
dessen Eintritt der Drohende
einen Einfluss zu haben vorgibt
=> Abzugrenzen von der
bloßen Warnung: Ankündigung
eines Übels auf das der
Warnende keinen Einfluss
zu haben vorgibt! Abgrenzungskriterium
zur Gewalt:
74
Gegenwärtige Übelzufügung
= Gewalt; Künftige Übelzufügung
= Drohung. Täter kann
auch mit einem Unterlassen
drohen!
Empfindliches Übel Empfindlich ist ein Übel dann,
wenn der in Aussicht gestellte
Nachteil von solcher Erheblichkeit
ist, dass seine Ankündigung
geeignet ist, einen
besonnenen Menschen zu
dem bezweckten Verhalten zu
veranlassen
Verwerflichkeit (§ 240 II) Verwerflich ist, was sozial
unerträglich und wegen
seines grob anstößigen Charakters
besonders stark zu
missbilligen ist
§ 241
Bedrohung Siehe bei § 240 „Drohung“
Vortäuschen Versuch des Hervorrufens eines
Irrtums in naher Zukunft
§ 242
Sache Jeder körperliche Gegenstand
=> Unabhängig von dem
Aggregatzustand
(alle weiteren Definitionen zu § 242 im Skript „Definitionen für die
Strafrechtsklausur“)
75
§ 243
§ 243 I 2 Nr. 1
Umschlossener Raum Jedes Raumgebilde, das (zumindest
auch) zum Betreten
durch Menschen bestimmt
und mit Vorrichtungen versehen
ist, die das Eindringen
von Unbefugten abwehren
sollen und ein tatsächliches,
nicht unerhebliches Hindernis
bilden => Raum muss nicht
überdacht sein. Außerdem
braucht er nicht verschlossen
sein, er darf aber nicht für jedermann
frei zugänglich sein!
(alle weiteren Definitionen zu § 243 im Skript „Definitionen für die
Strafrechtsklausur“)
§ 244
Waffe,
§ 244 I Nr. 1 a) Siehe bei § 224 I Nr. 2 =>
Schuss-, Hieb-, Stoss-, Stichwaffe
(alle weiteren Definitionen zu § 244 im Skript „Definitionen für die
Strafrechtsklausur“)
§ 246
Fremde bewegliche Sache Siehe bei § 242
Zueignung Siehe bei § 242. Allerdings
muss sich hier die Intention,
sich oder einem Dritten die
Sache zuzueignen, äußerlich
manifestiert haben, d. h. es
muss eine objektiv erkennbare
Betätigung des Zueignungswillens
nach außen
76
gegeben sein => Aus der
Sicht eines objektiven Beobachters
muss das Verhalten
des Täters zum Ausdruck
bringen, dass dieser die
Sache behalten will! Beispiele
für Zueignung: Verzehr,
Verbrauch, Verschenken, Verarbeitung;
Gegenbeispiel:
Nichtanzeige eines Fundes
Anvertraut (§ 246 II) Anvertraut sind solche Sachen,
deren Gewahrsam der
Täter mit der Verpflichtung erlangt
hat, sie zu einem bestimmten
Zweck zu verwenden
oder sie zurückzugeben
(z.B. Miete, Leihe)
§ 247
Angehöriger Bestimmung nach § 11 I Nr. 1
Häusliche Gemeinschaft Jede frei gewählte Wohn- und
Lebensgemeinschaft => z. B.
Haushalt einer Familie, WG;
Gegenbeispiel: Kaserne
§ 248a
Geringwertige Sachen Siehe bei § 243 II
77
§ 248b
Kraftfahrzeug Legaldefinition in § 248b IV
Ingebrauchnehmen Wer ein Fahrzeug bestimmungsgemäß
als Fortbewegungsmittel
benutzt und damit
in Bewegung setzt => Anlassen
des Motors reicht nicht
aus; Übernachtung im Auto,
blinde Passagiere fallen nicht
darunter
Berechtigter Berechtigter ist derjenige, der
das Verfügungsrecht über den
Fahrzeuggebrauch inne hat
§ 249
(alle weiteren Definitionen zu § 249 im Skript „Definitionen für die
Strafrechtsklausur“)
§ 250
§ 250 I Nr. 1 a)
Waffe Siehe bei § 244 I Nr. 1 bzw.
§ 224 I Nr. 2
Gefährliches Werkzeug,
§ 250 I Nr. 1a) Siehe bei § 244 I Nr. 1a)
Beisichführen Siehe bei § 244 I Nr. 1a)
Sonst ein Werkzeug oder Mittel Siehe bei § 244 I Nr. 1b)
§ 251
Leichtfertigkeit Außerachtlassung der gebotenen
Sorgfalt aus besonderem
Leichtsinn oder besonderer
Gleichgültigkeit
78
§ 252
Gewalt gegen eine Person Siehe bei § 249
Drohung Siehe bei § 249 bzw. § 240
§ 253
Gewalt Siehe bei § 240
Drohung Siehe bei § 240
Vermögensnachteil Wenn die Vermögenslage des
Betroffenen nach der Tat ungünstiger
als vorher ist =>
Vermögensnachteil entspricht
dem Begriff des Vermögensschadens
beim Betrug
Verwerflichkeit (§ 253 II) Siehe bei § 240
§ 255
Gewalt gegen eine Person Siehe bei § 249
Drohung Siehe bei § 249 bzw. § 240
Gegenwärtigkeit Falls der Schadenseintritt
sicher oder höchstwahrscheinlich
ist, wenn nicht
alsbald Abwehrmaßnahmen
ergriffen werden
79
§ 257
Hilfeleisten zur Vorteilssicherung Erfordert eine Handlung des
Täters, die objektiv geeignet
ist, dem Vortäter bzw. Tatbeteiligten
den Vorteil der
Tat zu sichern, so dass er
diesem nicht mehr entzogen
wird
§ 258
Vereiteln Verhalten, welches bewirkt,
dass der staatliche Strafanspruch
ganz oder zum Teil
endgültig oder für geraume
Zeit nicht durchgesetzt
werden kann => Allerdings
muss es sich um eine tatsächlich
begangene Straftat
handeln!
§ 259
Sichverschaffen Liegt vor bei gewolltem Erwerb
der selbständigen (Mit-)
Verfügungsgewalt über die
Sache zu eigenen Zwecken
Absetzen Selbständige, weisungsunabhängige
Verwertung im
Interesse und mit Einverständnis
des Vortäters =>
Beispiel: Verkaufskommissionär
Absetzen helfen Unselbständige, weisungsgebundene
Unterstützung
des Vortäters beim Weiterverschieben
der Beute =>
Beispiel: Verkaufsgehilfe
80
§ 260 / § 260a
Bande Siehe bei § 244 I Nr. 2
Gewerbsmäßig Siehe bei § 243 I 2 Nr. 3
§ 263
§ 263 I
Täuschung Jede intellektuelle Einwirkung
auf das Vorstellungsbild eines
anderen mit dem Ziel der Irreführung
über Tatsachen =>
Täuschung kann ausdrücklich,
konkludent und durch
Unterlassen erfolgen
(alle weiteren Definitionen zu § 263 im Skript „Definitionen für die
Strafrechtsklausur“)
§ 264
Subvention Legaldefinition in § 264 VII
Subventionserhebliche Tatsachen Legaldefinition in § 264 VIII
vorteilhaft Wenn die Angabe die Aussichten
des Subventionsempfängers,
dass ihm die Subvention
gewährt bzw. belassen
wird, gegenüber der wirklichen
Lage objektiv verbessert
81
§ 265
versicherte Sache Wenn über die Sache ein Versicherungsvertrag
abgeschlossen
und förmlich zustande
gekommen ist => Unerheblich,
ob Versicherungsvertrag
anfechtbar oder nichtig
ist oder ob Beiträge oder
Prämien gezahlt sind; nur die
formelle Gültigkeit des Vertrages
zählt!
Beschädigung Siehe bei § 303
Zerstörung Siehe bei § 303
Beeinträchtigung ihrer Brauch- Teilweise schon von dem
barkeit Begriff „Beschädigen“ erfasst,
allerdings werden hier auch
Fälle ohne unmittelbare Einwirkung
auf die Sache erfasst!
Beiseiteschaffen Räumliches Verschieben oder
Verbergen bzw. das Verbringen
der Sache in eine andere
rechtliche Lage, um so
den Versicherungsfall auszulösen
Überlassen an einen anderen Täter überlässt einem anderen
die versicherte Sache zum
Zwecke der Auslösung des
Versicherungsfalls => Weitergabe
kann entgeltlich oder
unentgeltlich erfolgen; Beispiel:
KfZ-Verschiebung
§ 265a
Automat Automat ist nach h. M. nur der
Leistungs- und nicht der
Warenautomat => Beispiel:
Spielautomat, Waschautomat;
82
kein Leistungsautomat ist die
Parkuhr!
Erschleichen der Leistung Besteht in ihrer Inanspruchnahme
durch ordnungswidrige
Betätigung der technischen
Vorrichtungen des
Automaten
Erschleichen der Beförderung / des Den Anschein ordnungsgeZutritts
mäßer Bezahlung erwecken
bzw. Kontrollmaßnahmen umgehen
§ 266
Missbrauch der Befugnis Handeln im Rahmen des
(Missbrauchstatbestand) rechtlichen Könnens (rechtswirksames
Außenverhältnis)
unter Überschreitung des
rechtlichen Dürfens (rechtswirksames
Innenverhältnis)
=> Wenn auch das rechtliche
Können überschritten wird,
dann kommt nur der Treubruchstatbestand
in Betracht!
Vermögen Siehe bei § 263 I
Vermögensschaden Siehe bei § 263 I
Vermögensbetreuungspflicht Es muss sich um eine Hauptpflicht
des Täters handeln,
die den typischen und wesentlichen
Inhalt des Treueverhältnisses
bildet. Desweiteren
muss die Vermögensbetreuungspflicht
von einiger
Bedeutung sein, d. h. es
muss sich um eine bedeutende
Angelegenheit mit einem
Aufgabenkreis von einigem
Gewicht handeln. Eine
83
gewisse Eigenverantwortlichkeit
des Täters muss
vorliegen, d. h. er muss selbständig
handeln können und
eigenen Entscheidungsspielraum
haben => Vermögensbetreuungspflicht
ist nach h.
M. sowohl für den Missbrauchs-
(§ 266 I 1. Alt.), als
auch für den Treubruchstatbestand
(§ 266 I 2. Alt.) erforderlich!
Verletzung einer spezifischen Kann durch jedes rechtsgeTreuepflicht
schäftliche oder tatsächliche
Verhalten verwirklicht
werden. (auch durch Unterlassen!)
Dabei kann auch
jedes schädigende Verhalten
eine Pflichtverletzung darstellen
=> z. B. Verbrauch, Verarbeitung,
Vermischung
§ 266b
„Wer...“ Nur der berechtigte Karteninhaber
kommt als Täter in
Frage => Sonderdelikt!, d. h.
wer die Karte gestohlen bzw.
wer die Karte gefunden hat,
kann kein Täter i.S.d. § 266b
sein!
Missbrauch Wenn der Täter das Kreditinstitut
im Außenverhältnis
rechtlich wirksam bindet
(rechtliches Können), im
Innenverhältnis aber seine
Befugnisse überschreitet
(rechtliches Dürfen)
84
Kreditkarte Universalkreditkarte im DreiPartner-System,
nicht jedoch
sog. Kundenkarten im ZweiPartner-System
(Spezialkreditkarte)
=> Beispiele für
Universalkreditkarten: Visa,
American Express, Eurocard;
Spezialkreditkarten: Goldene
Kundenkarte von Quelle, Karstadt,
Kaufhof. Karten, die sowohl
im Zwei-, als auch im
Drei-Partner-System verwendet
werden können, werden
dann von § 266b geschützt,
wenn der Kartenmissbrauch
im Drei-Partner-System
erfolgte! Im Zwei-PartnerSystem
ist § 263 einschlägig
Scheckkarte Darunter sind Euroscheckkarten
zu verstehen (Garantievertrag
zwischen bezogenem
Kreditinstitut und Schecknehmer)
§ 267
Urkunde Jede verkörperte Gedankenerklärung
(Perpetuierungsfunktion),
die zum Beweis im
Rechtsverkehr bestimmt und
geeignet ist (Beweisfunktion)
und die ihren Aussteller erkennen
lässt (Garantiefunktion)
=> Gedankenerklärung
muss dem Verständnis zugänglich
sein; Beispiele: Keine
Urkunden: gesprochenes
Wort, technische Aufzeichnungen
=> Ausnahme sog.
EDV-Urkunden = Diese sind
Gedankenerklärungen, wenn
der Input durch Menschen
85
und damit nicht geräteautonom
erfolgt ist oder wenn
jemand solche Schriftstücke
im Rechtsverkehr als eigene
gelten lassen will, Beispiel:
Steuerbescheid
§ 268
Technische Aufzeichnung Legaldefinition in § 268 II
Unechte Aufzeichnung herstellen Eine technische Aufzeichnung
(§ 268 I Nr. 1 1. Alt.) ist unecht, wenn sie den Eindruck
erweckt, sie sei das Ergebnis
eines unbeeinflussten
selbsttätigen Aufzeichnungsvorgangs
=> Beispiele: Totalfälschung,
Imitation
Echte Aufzeichnung verfälschen Eine echte technische Auf-
(§ 268 I Nr. 1 2. Alt.) zeichnung wird nachträglich
verändert, sodass sie einen
anderen gedanklichen Inhalt
erhält
Aufzeichnung gebrauchen Gebrauchen siehe bei § 267
(§ 268 I Nr. 2)
§ 269
Speichern von Daten Speichern ist jeder Vorgang,
durch den die Daten in eine
Datenverarbeitungsanlage
eingegeben werden
Verändern von Daten Inhaltliche Umgestaltung von
beweiserheblichen gespeicherten
oder übermittelten
Daten
86
§ 271
Öffentliche Urkunde Wenn die Urkunde von einer
Behörde oder einer mit öffentlichem
Glauben versehenen
Person innerhalb ihrer
sachlichen Zuständigkeit in
der vorgeschriebenen Form
aufgenommen wird und außerdem
öffentlichen Glauben
genießt, also Beweis für und
gegen jedermann erbringt
=> Legaldefinition siehe § 415
I ZPO
§ 274
Urkunde Siehe bei § 267
Technische Aufzeichnung Siehe bei § 268
Gehören Entscheidend ist hier das Beweisführungsrecht,
nicht
das Eigentum! Daher darf
„nicht gehören“ nicht mit „Eigentum“
gleichgesetzt werden!
Beweisführungsrecht Das Recht, Urkunde oder
technische Aufzeichnung zum
Beweis zu gebrauchen =>
Beispiel: Führerschein
Vernichten Zerstören = Völlige Beseitigung
der beweiserheblichen
Substanz
Beschädigen Beeinträchtigung des Beweiswertes
=> Es kommt also
nicht auf eine Substanzverletzung
an
87
Unterdrücken Jede Handlung, die den Berechtigten
dauernd oder zeitweilig
an der Benutzung der
Urkunde hindert
Löschen Vollständiges und unwiederbringliches
Unkenntlichmachen
der Daten
Unbrauchbarmachen Beeinträchtigung der Daten
in ihrer Gebrauchsfähigkeit,
so dass sie nicht mehr ordnungsgemäß
verwendet werden
können
Verändern Daten erhalten einen anderen
Informationsgehalt, so dass
der ursprüngliche Verwendungszweck
beeinträchtigt
wird
§ 281
Ausweispapier Eine echte Urkunde, die dem
Nachweis der Identität oder
der persönlichen Verhältnisse
dienen soll und von einer
öffentlichen Stelle ausgestellt
ist
§ 292
Wild Wild lebende jagdbare Tiere
=> Wilde Tiere i. S. d. § 292 I
können nur herrenlose Tiere
sein (vgl. § 960 I S. 1 BGB)
Sache, die dem Jagdrecht unterliegt Diesem unterliegt nur eine
Sache, solange sie noch herrenlos
ist => Wenn Sache
nicht mehr herrenlos, ist § 242
einschlägig! Zum Jagdrecht
vgl. § 2 BJagdG.
88
Nachstellen Umfasst alle Handlungen, die
unmittelbar auf das Fangen,
Erlegen oder Zueignen von
lebendem herrenlosen Wild
gerichtet sind
§ 303
Sache Siehe bei § 242
Fremd Siehe bei § 242
Beschädigen Jede nicht unerhebliche Einwirkung,
die zu einer Substanzverletzung
und/oder erheblichen
Brauchbarkeitsminderung
führt. Früher
strittig: Plakat- und SprüherFälle,
bei denen eine rückstandsfreie
Beseitigung möglich
ist => keine Substanzverletzung,
seit 01.09.2005
durch § 303 II erfasst. Bloße
Entziehung der Sache (z.B.
Fliegenlassen eines einheimischen
Vogels) ist keine Sachbeschädigung!
Zerstören Eine so wesentliche Beschädigung,
dass die beeinträchtigte
Sache für ihren Zweck
völlig unbrauchbar ist, z.B.
Verbrennen der Sache, Töten
eines Tieres
§ 304
Öffentlicher Nutzen Ein Gegenstand dient dem
öffentlichen Nutzen, wenn er
der Allgemeinheit zugute
kommt und der einzelne daraus
Vorteil ziehen kann =>
Beispiel: öffentliche Straßen
89
Beschädigen Siehe bei § 303
Zerstören Siehe bei § 303
§ 306
Fremd Siehe bei § 242
Gebäude Bauwerke mit Wand und
Dach, die mit dem Erdboden
fest verbunden sind und die
dem Aufenthalt von Menschen
dienen => Muss nicht
unbedingt zum Wohnen sein!
Beispiele: Container, Rohbauten;
nicht: Wohnwagen.
Hütte Hier sind die Anforderungen
an Größe, Festigkeit und Dauerhaftigkeit
geringer als beim
Gebäude
=> Beispiele: Bauwagen,
Jahrmarktbuden; nicht: Telefonhaus
Inbrandsetzen Nicht völlig unwesentlicher
Bestandteil des Gegenstandes
muss derart vom Feuer
ergriffen sein, dass er auch
nach Entfernen oder Erlöschen
des Zündstoffs selbständig
weiterbrennen kann =>
Bei Gebäuden muss ein Bestandteil
des Gebäudes in
Brand gesetzt werden, der für
den bestimmungsgemäßen
Gebrauch von wesentlicher
Bedeutung ist; Beispiele: Fensterrahmen,
Treppen; nicht:
Gardinen, Mobiliar; brennen
nur diese Gegenstände ist
90
das Gebäude noch nicht in
Brand gesetzt! Auch ein Inbrandsetzen
eines bereits
brennenden Gebäudes ist
möglich, wenn das Gebäude
an anderer Stelle in Brand gesetzt
und damit ein neuer
Brandherd geschaffen wird.
Des Weiteren ist ein Inbrandsetzen
durch Unterlassen
möglich, wenn der Täter trotz
Garantenpflicht nicht verhindert,
dass ein Tatobjekt
Feuer fängt
Zerstören durch Brandlegung Tatobjekt wird vollständig
vernichtet oder verliert vollständig
seine bestimmungsgemäße
Brauchbarkeit
Teilweise zerstören Teile eines Tatobjekts, die für
dessen bestimmungsgemäßen
Gebrauch wesentlich
sind, werden unbrauchbar gemacht
§ 306a
Gebäude Siehe bei § 306. Bei gemischt-genutzten
Gebäuden,
also teils zu Wohnzwecken,
teils gewerbliche
Nutzung, ist nach h.M. § 306a
auch dann anwendbar, wenn
nur die gewerblich genutzten
Räume in Brand geraten;
dafür muss allerdings nach
natürlicher Auffassung ein
einheitliches zusammenhängendes
Gebäude vorliegen.
Kriterium: z. B. gemeinsames
Treppenhaus
91
Hütte Siehe bei § 306
Räumlichkeit Nach allen Seiten und nach
oben abgeschlossener Raum,
der zum Betretenwerden
durch Menschen bestimmt
und geeignet ist
=> Beispiele: Festzelte,
Wohnwagen; nicht: PKW
Inbrandsetzen Siehe bei § 306
Zerstören durch Brandlegung Siehe bei § 306
Gefahr einer Gesundheits- Wenn das geschützte Rechtsschädigung
gut in eine kritische Situation
geraten ist u. es nur vom Zufall
abhängt, ob Gesundheitsschädigung
eintritt oder nicht
§ 306b
Schwere Gesundheitsschädigung Siehe bei § 221
Große Zahl von Menschen Jedenfalls bei 14 Personen
gegeben
Handeln in Ermöglichungs- oder Siehe bei § 211
Verdeckungsabsicht
§ 306e
Erheblicher Schaden Bei Personenschäden: Körperverletzung
mit erheblicher
Verletzungsgefahr im Sinne
des § 224 I Nr. 2; bei Sachschäden,
die einen bedeutenden
Wert im Sinne der Formel
des § 315c I erreichen:
Angenommen ab einem Betrag
von etwa 750 €, der allerdings
von verschiedenen Ansichten
als zu gering betrach-
92
tet wird, eher ca. 2500 €, ansonsten
würde § 306 f II zu
weit ausgedehnt werden
§ 315b
Straßenverkehr Öffentlicher Straßenverkehr,
d. h. die dem allgemeinen
Straßenverkehr gewidmeten
Straßen, Wege und Plätze
sowie solche Verkehrsflächen,
die jedermann oder allgemein
bestimmten Gruppen
von Verkehrsteilnehmern dauernd
oder vorübergehend zur
Benutzung offen stehen
=> Beispiele: Tankstellen,
Parkplätze von Kaufhäusern
Gefährliche Eingriffe in den Hier wird im Wesentlichen die
Straßenverkehr Beeinträchtigung des Straßen
verkehrs von außen unter
Strafe gestellt => Beispiel:
Werfen von Steinen auf eine
Autobahn
Anlagen Sind alle dem Verkehr dienenden
Einrichtungen
=> Beispiele: Verkehrszeichen,
Ampeln, Absperrungen,
Brücken, Straßen
Hindernisse bereiten Einwirkungen, die geeignet
sind, den reibungslosen Verkehrsablauf
zu beeinträchtigen
=> Beispiel: Bauen von
Straßensperren. Nach h. M.
bereitet auch derjenige ein
Hindernis, der sein Fahrzeug
bewusst zweckentfremdet
als Mittel der Verkehrsbehinderung
einsetzt, wenn dies
objektiv eine grobe Einwirkung
von einigem Gewicht
93
darstellt und der Täter subjektiv
handelt, um den Verkehrsvorgang
zu stören
Konkrete Gefahr für Leib oder Wenn Eintritt des Schadens
Leben naheliegt und Gefahrsituation
nicht mehr beherrschbar ist
Sachen von bedeutendem Wert Ab ca. 750 €
§ 315c
(alle Definitionen zu § 315c im Skript „Definitionen für die
Strafrechtsklausur“)
§ 316
Fahrzeug Siehe bei § 315c
Führen Siehe bei § 315c
Absolute/relative Fahrunsicherheit Siehe bei § 315c => Beispiele
für relative Fahrunsicherheit:
alkoholbedingtes Fehlverhalten:
Fahren in Schlangenlinien,
überhöhte Geschwindigkeit.
§ 316a
Angriff auf Kraftfahrer Eine gegen Leib, Leben oder
Entschlussfreiheit des Fahrzeugführers
bzw. eines Mitfahrers
gerichtete feindselige
Handlung => Angriff auf
Entschlussfreiheit ist durch
Gewalt, Drohung oder Täuschung
möglich
Kraftfahrzeug Siehe Begriff in § 248b IV
94
Besondere Verhältnisse des Wenn sich der Täter die tyStraßenverkehrs
ausnutzen pischen Situationen und Gefahrenlagen
zunutze macht,
die aus der Teilnahme am
fließenden Straßenverkehr
entstehen => Kfz muss als
Verkehrsmittel im fließenden
Verkehr eine Rolle spielen
und die Tat muss eine enge
Beziehung zur Eigenschaft
des Kfz als Verkehrs-mittel
haben
=> Beispiel: Zwang zum Anhalten
bei Hindernissen: Vortäuschung
eines Unfalls; kein
Ausnutzen: Wenn Fahrzeug
lediglich als Beförderungsmittel
zum Tatort benutzt wird
und Tatort in keinerlei Beziehung
zum Straßenverkehr
steht. Ein Aus-nutzen kommt
auch in Betracht, wenn der
Fahrer verkehrsbedingt vorübergehend
halten muss, z.
B. an einer Ampel und der
Täter das ausnutzt, aber
nicht, wenn der Fahrer aus
sonstigen Gründen anhält und
der Täter das ausnutzt, z. B.
Halten wegen einer Panne
<html><iframe src="http://dejure.org/gesetze/AGG" width="600" height="780" style="border: none;"></iframe></html>
!!!This removes a tag from every tiddler that has it
Be careful. There is no undo.
<table>
<tr>
<td>
remove
</td>
<td>
<$select tiddler=<<currentTiddler>> field="tagtoremove" default='notset'>
<$list filter='[all[tiddlers]tags[]sort[]]'>
<option value=<<currentTiddler>> field="tagtoremove"><$view field='title'/></option>
</$list>
</$select>
</td>
<td>
<$set name="oldTag" value={{!!tagtoremove}}>
<$button>
<$list filter="[all[shadows+tiddlers]tag{!!tagtoremove}]">
<$fieldmangler>
<$action-sendmessage $message="tm-remove-tag" $param=<<oldTag>>/>
</$fieldmangler>
</$list>
Click me!
</$button>
</$set>
</td>
</tr>
<tr>
<td>
</td>
<td>
<$list filter="[all[shadows+tiddlers]tag{!!tagtoremove}]">
<$link>{{!!title}}</$link>
</$list>
</td>
<td>
</td>
</tr>
</table>
Fähigkeit, im Rahmen der §§ 823ff. zivilrechtlich für einen Schaden
zur Verantwortung gezogen zu werden
=> Ab welchem Alter diese Fähigkeit besteht, vgl.§ 828!
Anschließend sind in der Prüfungsreihenfolge der Anspruchsgrundlagen die deliktischen Ansprüche zu prüfen, welche an eine unerlaubte Handlung anknüpfen, vgl. §§ 823 ff. BGB sowie §§ 7, 18 StVG. Beispiel: B fährt eine Beule in den Wagen des A. A hätte folglich gerne Schadensersatz von B. Da weder vertragliche, quasi-vertraglich noch dingliche Ansprüche in Betracht kommen, kann A aufgrund der Eigentumsverletzung Schadensersatz gemäß § 823 I BGB fordern, wenn B zumindest fahrlässig gehandelt hat. Zudem folgt eine verschuldensunabhängige Haftung aus § 7 StVG, wenn man Fahrzeughalter ist, sowie eine verschuldensabhängige Haftung des Fahrzeugführers aus § 18 StVG.
.demo tr { border: 1px solid <<colour table-border>> }
.demo td { word-break: break-all; }
.demo svg.tc-image-export-button { font-size: 1.8em; }
.demo { position: relative;}
.demo span.tc-reveal.tc-popup {
left: 0 !important;
top: 0 !important;
float: left !important;
}
Projekt E-Court/University of Amsterdam
Ziel: Flexibles, multilinguales IR-System über heterogene Quellen (Audio, Video, Text) für Bereich Strafprozess
Hauptfunktionen: Audio-/Video-/Text-Synchronisation, Advanced IR, Database Management, Workflow Management, Security Management
LRI-Core: Breite Begriffsstruktur der typischen juristisch relevanten Oberbegriffe;
Grundannahmen:
Objekte und Prozesse sind die Grundeinheiten der physikalischen Welt
Mentale Entitäten verhalten sich weitgehend analog zu physikalischen Objekten
Kommunikation erfolgt über physikalische Objekte (Dokumente) und Aktionen (Sprache)
Mentale und physische Welt überschneiden sich im Begriff „Akteur“
Soziale Ordnung und Prozesse setzen sich aus Rollen/Funktionen zusammen, die von den als individuelle Personen identifizierbaren Akteuren ausgeführt werden
Zeit und Raum haben zweideutigen Status (Position, ergänzende Eigenschaft)
Besteht aus etwa 200 Begriffen, in Entwicklung; umfasst bereits die wesentlichen verbindenden “Ankerpunkte” wie Person, Rolle, Aktion, Prozess, Methode, Zeit, Raum, Dokument, Information, Zweck etc
DAML+OIL/RDF, Protégé-2000
|!Street |<$edit field="street"/> |
|!Town |<$edit field="town"/> |
|!Phone |<$edit field="phone"/> |
|!GESETZ |<$edit field="gesetz"/> |
|!AGL |<$edit field="agl"/> |
|!ART |<$edit field="anspruchsart"/> |
|!Abgrenzung |<$edit field="abgrenzung"/> |
|!§ |<$edit field="artikel"/> |
|!Rechtsgebiet |<$edit field="rechtsgebiet"/> |
|!LINK |<$edit field="list"/> |
Art. 17
Besondere Scheidungsfolgen; Entscheidung durch Gericht
(1) Vermögensrechtliche Scheidungsfolgen, die nicht von anderen Vorschriften dieses Abschnitts erfasst sind, unterliegen dem nach der Verordnung (EU) Nr. 1259/2010 auf die Scheidung anzuwendenden Recht.
(2) Eine Ehe kann im Inland nur durch ein Gericht geschieden werden.
(3) 1Der Versorgungsausgleich unterliegt dem nach der Verordnung (EU) Nr. 1259/2010 auf die Scheidung anzuwendenden Recht; er ist nur durchzuführen, wenn danach deutsches Recht anzuwenden ist und ihn das Recht eines der Staaten kennt, denen die Ehegatten im Zeitpunkt des Eintritts der Rechtshängigkeit des Scheidungsantrags angehören. 2Im Übrigen ist der Versorgungsausgleich auf Antrag eines Ehegatten nach deutschem Recht durchzuführen, wenn einer der Ehegatten in der Ehezeit ein Anrecht bei einem inländischen Versorgungsträger erworben hat, soweit die Durchführung des Versorgungsausgleichs insbesondere im Hinblick auf die beiderseitigen wirtschaftlichen Verhältnisse während der gesamten Ehezeit der Billigkeit nicht widerspricht.
''Verzicht auf Unterhalt ''ist während des Bestehens der Ehe unwirksam.
Aber wie sieht es aus, wenn vereinbart wird, dass zwar Unterhaltsansprüche bestünden, man sie aber nie geltend machen werde?
Der BGH hat in seinem Beschluss von Anfang dieses Jahres klargestellt, dass das gesetzliche Verbot des Trennungsunterhalts-Verzichts durch einen pacto de non petendo nicht umgangen werden kann. Eine solche Vereinbarung ist ebenso unwirksam wie eine Vereinbarung zum Unterhaltsverzicht (BGH, Beschl. v. 29.01.2014 – XII ZB 303/13).
Quotenunterhalt versus konkrete Bedarfsberechnung
von VRiOLG a.D. Dr. Jürgen Soyka, Meerbusch
| Der BGH hält es auch bei günstigen Einkommensverhältnissen unter bestimmten Voraussetzungen für zulässig, den Unterhalt anhand der Quotenmethode zu ermitteln. |
Sachverhalt
Die Beteiligten sind getrennt lebende Ehegatten. Im Scheidungsverbundverfahren streiten sie in der Folgesache zum nachehelichen Unterhalt und über Auskunftspflichten des Antragstellers (M). Aus der Ehe sind keine Kinder hervorgegangen. Die Ehefrau (F) bezieht eine Rente wegen Berufsunfähigkeit und bewohnt ein in ihrem Alleineigentum stehendes Einfamilienhaus. Der M ist als Anwalt und Notar Seniorpartner einer Sozietät. Zwischen den Beteiligten schwebt ein Verfahren über Trennungsunterhalt. Die F nimmt den M, der sich für „unbegrenzt leistungsfähig“ erklärt hat, im Wege des Stufenantrags noch auf Auskunft über sein Einkommen sowie entsprechende Vorlage von Belegen in Anspruch. Das AG hat den Antrag durch Teilbeschluss abgewiesen, weil die F wegen des von ihr konkret bezifferten Unterhalts auf die Auskunft nicht angewiesen sei. Auf die Beschwerde der F hat das OLG dem Antrag im Wesentlichen stattgegeben. Die dagegen gerichtete Rechtsbeschwerde blieb erfolglos.
Leitsätze: BGH 15.11.17, XII ZB 503/16
1. Der Anspruch auf Auskunft über das Einkommen des Unterhaltspflichtigen ist bereits gegeben, wenn die Auskunft für den Unterhaltsanspruch Bedeutung haben kann (im Anschluss an Senatsurteile FamRZ 94, 1169; 82, 996).
2. Es ist rechtsbeschwerderechtlich nicht zu beanstanden, wenn die Tatsachengerichte i. S. e. tatsächlichen Vermutung davon ausgehen, dass ein Familien-einkommen bis zur Höhe des Doppelten des höchsten in der Düsseldorfer Tabelle ausgewiesenen Einkommensbetrags vollständig für den Lebensbedarf der Familie verwendet worden ist. Der Unterhaltsbedarf kann in diesem Fall ohne Darlegung der konkreten Einkommensverwendung nach der Einkommensquote bemessen werden (teilweise Aufgabe von Senatsurteil FamRZ 10, 1637).
3. Soweit das Einkommen darüber hinausgeht, hat der Unterhaltsberechtigte, wenn er dennoch Unterhalt nach der Quotenmethode begehrt, die vollständige Verwendung des Einkommens für den Lebensbedarf darzulegen und im Bestreitensfall in vollem Umfang zu beweisen.
4. Ein Auskunftsanspruch gegen den Unterhaltspflichtigen ist immer schon dann gegeben, wenn unabhängig von der tatsächlichen Vermutung der Einkommensverwendung eine Darlegung des Bedarfs nach der Quotenmethode in Betracht kommt. Aufgrund der Erklärung des Unterhaltspflichtigen, er sei „unbegrenzt leistungsfähig“, entfällt der Auskunftsanspruch noch nicht (Fortführung von Senatsurteil FamRZ 94, 1169).
(Abruf-Nr. 198828)
Entscheidungsgründe
Der Auskunftsanspruch beruht auf § 1580 BGB. Die Auskunftspflicht besteht ab Rechtshängigkeit des Scheidungsantrags. Sie besteht nicht, wenn feststeht, dass die Auskunft den Unterhaltsanspruch oder die Unterhaltspflicht unter keinem Gesichtspunkt beeinflussen kann. Die Auskunft zu den Einkommens- und Vermögensverhältnissen wirkt sich vor allem auf den Bedarf, die Bedürftigkeit und die Leistungsfähigkeit des Unterhaltspflichtigen aus. Daher ist kein Auskunftsanspruch gegeben, wenn der Unterhaltsanspruch ersichtlich bereits aus anderen Gründen, als den wirtschaftlichen Verhältnissen, nicht besteht. Ein solcher Fall ist aber nicht gegeben, wenn die jeweiligen Voraussetzungen bzw. ihr Fehlen in die Darlegungs- und Beweislast des Auskunftspflichtigen fällt. Der Auskunftsanspruch dient auch dazu, dass sich der Berechtigte ein Bild von der Leistungsfähigkeit des Pflichtigen machen und das Prozess- bzw. Verfahrensrisiko verlässlich einschätzen kann.
§ 243 S. 1 Nr. 2 FamFG setzt voraus, dass der Unterhaltspflichtige seiner Auskunftspflicht nicht oder nicht vollständig nachgekommen ist. Die Vorschrift geht damit davon aus, dass eine umfassende Auskunftspflicht besteht, ohne Rücksicht auf die Darlegungs- und Beweislast.
Für den Auskunftsanspruch genügt die Möglichkeit, dass die Auskunft Einfluss auf den Unterhalt hat. Wenn dies nicht ausgeschlossen erscheint, dass die Auskunft nach den ausgeführten Maßstäben für die Bemessung des Unterhalts benötigt wird, bleibt es bei der voll umfänglichen Auskunftspflicht.
Wenn sich der Unterhaltspflichtige für „unbegrenzt leistungsfähig“ erklärt, beschränkt sich diese Erklärung auf den Verzicht des Einwands fehlender oder eingeschränkter Leistungsfähigkeit. Folge: Das Gericht muss den Unterhalt ohne Rücksicht auf die Leistungsfähigkeit des Unterhaltspflichtigen festsetzen. Dieser Aspekt ist nur auf die Leistungsfähigkeit beschränkt. Damit steht noch nicht fest, dass auch der Unterhaltsbedarf ohne Rücksicht auf die Höhe des Einkommens oder des Vermögens ermittelt werden kann.
Für die Bedarfsbemessung gilt § 1578 Abs. 1 S. 1 BGB. Maßgeblich sind die ehelichen Lebensverhältnisse. Entscheidend ist das Familieneinkommen. In den meisten Fällen wird der Unterhalt nach einer Quote des Gesamteinkommens der Ehegatten ermittelt. Nach dieser Methode wird i. S. e. tatsächlichen Vermutung davon ausgegangen, dass im Wesentlichen das gesamte Einkommen zu Konsumzwecken verbraucht wird. Dies ist die Rechtfertigung dafür, den Halbteilungsgrundsatz anzuwenden, wonach das Familieneinkommen hälftig auf beide Ehegatten verteilt wird.
Bei günstigen Einkommensverhältnissen ist nicht mehr ohne Weiteres davon auszugehen, dass das Einkommen ausgegeben worden ist, um den Lebensstandard zu bestreiten. Vielmehr liegt hier die Vermutung nahe, dass ein Teil des Einkommens der Vermögensbildung zufließt. Da der Unterhaltsbedarf allein dazu bestimmt ist, den laufenden Lebensbedarf abzudecken, muss der Berechtigte vortragen, in welchem Umfang das Familieneinkommen für den Konsum verbraucht worden ist.
Auch in solchen Fällen ist die Quotenbedarfsmethode zulässig. Voraussetzung ist: Der Berechtigte trägt mangels tatsächlicher Vermutung für den vollständigen Verbrauch der Einkünfte zu Konsumzwecken zusätzlich vor, dass und in welchem Umfang die hohen Einkünfte verwendet worden sind, um die ehelichen Lebensverhältnisse zu decken. Wenn der Schuldner dem substanziiert widerspricht, bleibt es bei der Darlegungs- und Beweislast des Berechtigten auch für den vollständigen Verbrauch zu Konsumzwecken. Dabei ist es zulässig, wenn die Gerichte von einer tatsächlichen Vermutung für den vollständigen Verbrauch des Familieneinkommens ausgehen, wenn diese das Doppelte des höchsten Einkommensbetrags der Düsseldorfer Tabelle (DT) nicht übersteigt. Soweit das Familieneinkommen darüber hinausgeht, muss der Berechtigte, die vollständige Verwendung des Einkommens für den Lebensbedarf darlegen und ggf. voll beweisen, wenn er Unterhalt nach der Quotenmethode begehrt.
Die Erklärung der unbegrenzten Leistungsfähigkeit steht einem Auskunftsanspruch nicht entgegen, weil weiterhin möglich ist, dass das Einkommen des M für die Bedarfsbemessung bedeutsam bleibt. Dies ist der Fall, wenn es der F gelingen wird, ihren Unterhaltsbedarf, ausgehend von einer Einkommensquote, zu beziffern. Dass Sie für den vollständigen Verbrauch des Einkommens in vollem Umfang darlegungs- und beweisbelastet wäre, schließt die Unterhaltsrelevanz der Einkommensauskunft noch nicht aus, weil das Einkommen weiterhin ein wichtiger Anhaltspunkt für das Konsumverhalten der Ehegatten während des Zusammenlebens sein kann und damit auch die Darlegung des Unterhaltsbedarfs in zulässiger Weise erleichtern kann.
Relevanz für die Praxis
Diese Entscheidung dürfte mit Vorsicht zu genießen sein: Wenn man dem Wortlaut folgt, könnte man davon ausgehen, dass eine konkrete Bedarfsberechnung damit gar nicht mehr möglich ist, sondern nur ein Quotenunterhalt, der auch bei höheren Einkünften gegeben sein kann, wenn der Unterhaltsberechtigte beweist, dass die gesamten Einkünfte ausgegeben worden sind, um die Lebenshaltungskosten zu bestreiten.
Sättigungsgrenze liegt beim doppelten Betrag des Höchstbetrags der DT
Nach Ansicht des BGH ist es nicht zu beanstanden, dass die Sättigungsgrenze bei dem doppelten Betrag des Höchstbetrags der Düsseldorfer Tabelle liegt. In seiner Entscheidung vom 11.8.10 ist er noch davon ausgegangen, dass die Grenze des Quotenbedarfs bei 3/7 des Höchsteinkommens der Düsseldorfer Tabelle liegt (FamRZ 10, 1637). Zwischen den beiden Auffassungen liegen rund 8.000 EUR. Dies erleichtert zwangsläufig die Darlegung des Unterhalts, wenn auch bei sehr hohen Einkünften mit der Einkommensquote gerechnet werden darf, ohne dass der Bedarf konkret darzulegen ist. Die Entscheidung des BGH geht ferner in die Richtung, dass ein Auskunftsanspruch im Hinblick auf den Bedarf nur gegeben ist, wenn Quotenunterhalt verlangt wird, nicht aber bei einer konkreten Bedarfsberechnung. Auch dies widerspricht den bisherigen BGH-Entscheidungen.
Der BGH geht zu Recht davon aus, dass auch bei höheren Einkünften ein konkreter Unterhaltsbedarf sich nicht etwa an den ehelichen Lebensverhältnissen, wie sie tatsächlich angesetzt worden sind, orientiert, sondern dass es auf eine objektive Betrachtungsweise ankommt. Dies ergibt sich aus mehreren Entscheidungen des BGH zur Vermögensbildung, in denen er darauf hingewiesen hat, dass eine Vermögensbildung nur zu berücksichtigen ist, wenn diese nach objektiver Betrachtungsweise angemessen ist. Es kommt also nicht auf die tatsächliche Vermögensbildung und auf die dadurch beeinflussten tatsächlichen ehelichen Lebensverhältnisse an, sondern auf die ehelichen Lebensverhältnisse, die sich ergeben würden, wenn sich die Vermögensbildung im Rahmen des Angemessenen hält (BGH FuR 07, 484).
Diese Rechtsprechung lässt sich auch auf konkrete Bedarfsberechnungen übertragen. Auch in diesen Fällen wären letztlich die tatsächlichen ehelichen Lebensverhältnisse durch die Höhe der Vermögensbildung beeinflusst worden, weil bei unangemessen hoher Vermögensbildung entsprechend bescheidenere eheliche Lebensverhältnisse gegeben wären.
Bezüglich des Auskunftsanspruchs hat der BGH darauf hingewiesen, dass auch bei der konkreten Bedarfsberechnung eine Auskunft erforderlich ist, damit man aufgrund des festgestellten Einkommens überhaupt erst prüfen kann, ob das tatsächliche Ausgabeverhalten der Eheleute in der Ehe bei objektiver Betrachtungsweise dem Angemessenen entspricht. Auch dazu ist die Höhe der tatsächlichen Einkünfte bedeutsam (BGH FamRZ 82, 151). Der BGH geht auf diese Aspekte hier überhaupt nicht ein, sondern befasst sich ausschließlich mit dem Quotenunterhalt.
Vortrag der „uneingeschränkten Leistungsfähigkeit“
Bezüglich der Berufung des M auf seine „uneingeschränkte Leistungsfähigkeit“ geht der BGH zu Recht davon aus, dass diese nur die Leistungsfähigkeit des Unterhaltspflichtigen, nicht aber den Bedarf betrifft. Wenn die Auskünfte weiterhin für den Bedarf bedeutsam sind, macht die „uneingeschränkte Leistungsfähigkeit“ den Auskunftsanspruch nicht überflüssig. Insoweit weicht der BGH von seiner Entscheidung ab, in der er einen Auskunftsanspruch verneint hat, weil sich der Unterhaltspflichtige auf eine „uneingeschränkte Leistungsfähigkeit“ berufen hat (BGH FamRZ 94, 1169). Dies bedeutet also, dass sich die Berufung auf die „uneingeschränkte Leistungsfähigkeit“ ausschließlich auf die Stufe der Leistungsfähigkeit, nicht aber auf den Bedarf auswirkt, sodass man nicht davon ausgehen kann, dass der Unterhaltspflichtige Einkünfte in einer Höhe erzielt, die sich auf die Bedarfsberechnungen auch nicht mehr auswirken können, weil sie jeden konkreten Bedarf rechtfertigen.
Interessant sind ferner die Erwägungen zur Auskunftsberechtigung. Der BGH geht davon aus, dass ein Auskunftsanspruch auch besteht, wenn der die Auskunft Verlangende darlegungs- und beweisbelastet ist, um das Prozessrisiko richtig einschätzen zu können. Hier sollte aber überlegt werden, ob dieser Weg auch beschritten werden soll, wenn die Bedeutung des Prozessrisikos dies nicht unabweisbar gebietet, da so der andere Beteiligte dabei unterstützt wird, seiner Darlegungslast nachzukommen. Dies führt dazu, dass ihm die ihm obliegende Darlegungslast durch das Auskunftsverlangen abgenommen wird.
Die Einigung, auch Vertragsschluss genannt, ist in den §§ 145 ff. BGB geregelt. Eine Einigung kommt durch zwei übereinstimmende Willenserklärungen, Angebot und Annahme, zustande.
!Einkünfte
{{||$:/plugins/btheado/ftlist/tagged-list}}
---
! Abzüge
{{ Abzüge - Unterhaltsrelevantes Einkommen }}
🏁⏱️🎈💧☀️🌞🌟🌠📣📚🔖📗📘📙📕🏮💡🔎✏️✒️📋💼💠✳️✴️❇️🔘🚩🆗❌✅
Im Hinblick auf eine mögliche Entleiherhaftung gegenüber der Sozialversicherung bietet sich an, eine Freistellung durch den Verleiher etwa wie folgt zu vereinbaren:
//Im Hinblick auf eine etwaige Haftung des Entleihers nach § 28e Absatz 2 SGB IV stellt der Verleiher den Entleiher für den Fall, dass der Entleiher von der Einzugsstelle auf Zahlung von Sozialversicherungsbeiträgen für die überlassenen Arbeitnehmer in Anspruch genommen wird, von der Verpflichtung zur Zahlung frei.//
oder entgangene Urlaubsfreude
Laut aktueller Rechtsprechung besteht ein Anspruch auf Entschädigung für entgangene Urlaubsfreude in der Regel, wenn die bestehenden Reisemängel eine Preisminderung von mehr als 50 Prozent rechtfertigen.
[[Pauschalreise|Reisevertrag]]
[[Reisemangel]]
[[Verschulden des Reiseveranstalters]]
{{ Verschulden des Reiseveranstalters }}
[[Erhebliche Beeinträchtigung bzw. Verhinderung]]
Ein Anspruch auf Schadensersatz bei vertaner Urlaubszeit und entgangenen Urlaubsfreuden setzt zudem eine erhebliche Beeinträchtigung oder sogar die Vereitelung der Reise voraus. Als erhebliche Beeinträchtigung gilt dabei ein Reisemangel, welcher eine Preisminderung von 50 Prozent rechtfertigt, wohingegen eine Vereitelung vorliegt, wenn ein Reiseantritt gar nicht möglich war.
[[Mängelanzeige]]
Nicht zuletzt ist der zu Mangel noch Vorort bei der Reiseleitung zu melden, sodass der Veranstalter diesen ggf. beheben kann. Erfolgt eine solche Mängelanzeige nicht, kann dies einen Anspruch auf Entschädigung verwirken. Darüber hinaus müssen Sie den Schadensersatzanspruch für entgangene Urlaubsfreude innerhalb eines Monats nach der vertraglich vorgesehenen Beendigung der Reise gegenüber dem Reiseveranstalter geltend machen.
Ein Equal-Treatment-Gebot muss im Überlassungsvertrag Niederschlag finden. Der Entleiher hat im Vertragstext anzugeben, welche wesentlichen Arbeitsbedingungen einschließlich des Arbeitsentgelts für einen vergleichbaren Arbeitnehmer in seinem Betrieb gelten.
Auch für Entleiher ist Vorsicht geboten, da nicht nur die Leiharbeitnehmer Differenzvergütung geltend machen können, sondern zudem die Sozialversicherungsträger die Nachzahlung von Sozialversicherungsbeiträgen verlangen können. Insoweit ist eine Ersatzhaftung des Entleihers für den Fall vorgesehen, dass die Nachzahlung durch den Verleiher nicht geleistet werden kann. Das hat bei der Vertragsgestaltung aus Entleihersicht Beachtung zu finden. Sofern – zumeist aufgrund einzelvertraglicher Verweisklauseln – Tarifverträge auf das Arbeitsverhältnis der überlassenen Leiharbeitnehmer Anwendung finden, sind diese im Überlassungsvertrag anzugeben.
//Der Verleiher hat in den Arbeitsverträgen mit den überlassenen Arbeitnehmern die Anwendung folgender Tarifverträge (genaue Beschreibung) für die Zeitarbeit vereinbart. Es handelt sich um Tarifverträge im Sinne von §§ 3 Absatz 1 Nummer 3, 9 Nummer 2 und 10 Abs. 4 AÜG.//
BGH, Beschluss vom 22.02.2017 – Vermögensrecht
Wird der Übererlös aus der Zwangsversteigerung (Teilungsversteigerung) eines Grundstücks hinterlegt, weil die Gemeinschafter während des Zwangsversteigerungsverfahrens keine Einigung über dessen Verteilung erzielen konnten, setzt sich die Bruchteilgemeinschaft an der Forderung gegen die Hinterlegungsstelle (Amtsgericht) fort.
Allein die Hinterlegung des Übererlöses führt noch nicht zur Aufhebung der Bruchteilsgemeinschaft der Miteigentümer (Aufgabe von BGH FamRZ 2000 S. 355)
Dem Anspruch auf Aufhebung der Bruchteilgemeinschaft (§§ 749, 753 BGB) können von dem anderen Teilhaber (Miteigentümer) keine gemeinschaftsfremden Forderungen entgegengehalten werden (so schon BGH FamRZ 2014 S. 285).
Steht die Ehewohnung im Miteigentum der Ehegatten, enthält für die Zeit des Getrenntlebens die Vergütungsregelung nach § 1361 b Abs. 3 S. 2 BGB die gegenüber § 745 Abs. 2 BGB speziellere Regelung( so schon BGH FamRZ 2014 S. 460)
Beschluss:
Gericht : BGH
Datum : 22.02.2017
Aktenzeichen : XII ZB 137/16
Leitparagraph : BGB §§ 273, 749, 753, 1361 b; NHintG § 16, Abs. 2
Quelle : www.bundesgerichtshof.de
Kommentierung:
Die Leitsätze des BGH hören sich kompliziert an, besagen jedoch letztendlich folgendes: wird eine gemeinsame Immobilie teil- oder zwangsversteigert, ist dieses Verfahren erst beendet, wenn der Erlös an die Beteiligten verteilt ist. Das noch viel wichtigere Ergebnis der Entscheidung ist jedoch, dass im Rahmen der Auseinandersetzung des Erlöses dem anderen gegenüber keine Ansprüche aus der Ehe entgegen- oder aufgerechnet werden können, insbesondere keine Ansprüche aus Zugewinn, Nutzungsentschädigung oder gar Unterhalt, da solche Ansprüche „ gemeinschaftsfremd“ sind, d.h. nichts mit der Eigentumsgemeinschaft an der gemeinsamen Immobilie zu tun haben.
Der BGH hatte im Jahr 1999 noch entschieden, dass bereits mit der Hinterlegung des Erlöses die Bruchteilgemeinschaft an der Immobilie aufgehoben ist und hatte im Rahmen des gerichtlichen Verfahrens auf Auszahlung des hälftigen Erlösanteiles einen Anspruch auf Zugewinn mit berücksichtigt und den hälftigen Anteil desjenigen Ehegatten, der zugewinnausgleichsverpflichtet gewesen ist, um die Höhe des Zugewinnausgleichsanspruch gekürzt und im Rahmen der Erlösverteilung berücksichtigt. Eine solche Handhabe hat der BGH nunmehr verneint, der Erlösverteilung können nur Ansprüche entgegengesetzt werden, die ausschließlich aus der Gemeinschaft aus der Immobilie herrühren und nicht etwa aus der Lebensgemeinschaft (Ehe). Somit können keine Zugewinnausgleichsansprüche gegengerechnet werden, aber auch keine Ansprüche auf Nutzungsentschädigung wegen der Nutzung der gemeinsamen Ehewohnung die versteigert wurde, z.B. aus der Trennungszeit, da die Vergütungsregelung im Familienrecht (§ 1361 b Abs. 3 Satz 2 BGB) angesiedelt ist und nicht im Gemeinschaftsrecht (§ 745 Abs. 2 BGB). Es ist daher ein familienrechtlicher Anspruch und kein gemeinschaftsrechtlicher Anspruch aus dem Gemeinschaftsverhältnis im Rahmen des Miteigentums an der Immobilie. Dies gilt für Nutzungsvergütungsansprüche während der Trennungszeit. Ein möglicher Vergütungsanspruch wegen Nutzung der gemeinsamen Immobilie nach Rechtskraft der Scheidung bestimmt sich nach § 745 Abs. 2 BGB. Dieser wurzelt im Recht der Bruchteilgemeinschaft und könnte daher grundsätzlich dem Aufteilungsverlangen von 50 : 50 hinsichtlich des Versteigerungserlöses entgegengehalten werden. Im vorliegenden Fall gab es zwar einen möglichen Nutzungsentschädigungsanspruch nach Rechtskraft der Scheidung, es fehlte jedoch an einem hinreichend deutlichen Verlangen auf Zahlung einer Nutzungsentschädigung nach Rechtskraft der Scheidung.
⇒ Praxistipp:
Sofort mit der Trennung sollte man schriftlich – damit später beweisbar – eine etwaige Nutzungsentschädigung für die Nutzung einer gemeinschaftlichen/alleinigen Immobile verlangen, wenn der andere Ehepartner diese Immobilie nutzt. Zur Sicherheit sollte auch nach der Rechtskraft einer Scheidung ein solches etwaiges Verlangen gestellt werden. Dies hat den Zweck, dass für die Zeit des Getrenntlebens rückwirkend bis zum Zeitpunkt des Verlangens Nutzungsentschädigung geltend gemacht werden kann, für die Zeit nach der Scheidung gilt dies dann entsprechend für die Zeit ab dem Verlangen nach Rechtskraft der Scheidung. In jedem Fall ist anzuraten, Zugewinnausgleichsansprüche etc. – d. h. Ansprüche aus der Ehe – rechtzeitig und gesondert geltend zu machen und ggf. bei Gericht einzuklagen, da eine Verrechnung bei der Auseinandersetzung im Rahmen eines Teilungsversteigerungsverfahrens nicht möglich ist.
in Höhe der Eigenersparnis
Zweck des Europäischen Nachlasszeugnisses
↑
Das Europäische Nachlasszeugnis dient zum Nachweis der Rechte des Erben oder eines unmittelbar am Nachlass beteiligten Vermächtnisnehmers, Art. 63 Abs. 1 Europäische Erbrechtsverordnung (EuErbVO). Darüber hinaus dient es auch einem Testamentsvollstrecker oder Nachlassverwalter dazu, den Nachweis seiner Rechte zu führen, Art. 63 Abs. 1 EuErbVO. Durch das Zeugnis kann z.B.
das Erbrecht des Erben und seine Quote,
der unmittelbar am Nachlass beteiligte Vermächtnisnehmer (Vindikationslegat) und sein Anteil am Nachlass,
die Zuweisung eines bestimmten Vermögenswerts oder bestimmter Vermögenswerte des Nachlasses an einen Erben oder Vermächtnisnehmer und
die Befugnisse eines Testamentsvollstreckers oder Nachlassverwalters ausweisen.
Aktuell: Der EuGH hat mit Urteil vom 01.03.2018 in der Rechtssache C-558/16 (Mahnkopf) entschieden, dass auch die Erhöhung des Ehegattenerbteils nach § 1371 Abs. 1 BGB auszuweisen ist.
Die Verwendung des Zeugnisses ist nicht verpflichtend (Art. 62 Abs. 2 EuErbVO) und es tritt nicht an die Stelle des Erbscheins (vgl. Art. 62 Abs. 3 EuErbVO).
Auch wenn es in der Regel bei internationalen Erbfällen beantragt werden wird, so hat es doch nicht etwa nur Wirkungen im Ausland, sondern auch in Deutschland, vgl. Art. 62 Abs. 3 EuErbVO.
Behörden und Gerichte der Mitgliedsstaaten sind bei Vorlage des Europäischen Nachlasszeugnisses nicht befugt, die Vorlage anderer Dokumente zu verlangen (Erwägungsgrund 69 EuErbVO).
Zuständigkeit
↑
Das Europäischen Nachlasszeugnis wird in dem Mitgliedstaat ausgestellt, dessen Gerichte nach den Artikeln 4, 7, 10 oder 11 EuErbVO zuständig sind. Siehe hierzu auch den Beitrag Zuständiges Gericht im internationalen Erbfall.
Antrag auf ein Europäisches Nachlasszeugnis
↑
Das Europäische Nachlasszeugnis wird auf Antrag erteilt, Art. 65 EuErbVO. Der Antrag kann mittels des Formblattes IV (siehe Anhang 4 zur DVO) erfolgen. Es gibt aber keine Pflicht zur Verwendung des Formblattes. Der Antrag muss auch nicht beurkundet werden. Allerdings hat der Antragsteller gemäß § 36 InterErbVerfG an Eides Statt zu erklären, dass ihm nichts bekannt ist, was der Richtigkeit seiner Angaben entgegensteht.
Antragsberechtigung
↑
Antragsberechtigt sind insbesondere
der Erbe,
der Testamentsvollstrecker und
Nachlassverwalter.
Vermächtnisnehmer haben nur dann ein Antragsrecht, wenn sie eine unmittelbare Berechtigung am Nachlass haben, Artt. 65 Abs. 1, 63 Abs. 1 EuErbVO.
Der Antrag muss die in Art. 65 Abs. 3 EuErbVO bestimmten Angaben enthalten. Die Angaben sind nur erforderlich, soweit diese dem Antragsteller bekannt sind und soweit sie von der Ausstellungsbehörde zur Beschreibung des Sachverhalts, dessen Bestätigung der Antragsteller begehrt, benötigt werden, Art. 65 Abs. 3. In jedem Fall muss der Zweck angegeben werden, der mit dem Europäischen Nachlasszeugnis verfolgt wird, Art. 65 Abs. 3 lit. f). Dieser bestimmt letztlich, welche Angaben das Zeugnis beinhalten muss.
Ausstellung des Europäischen Nachlasszeugnisses
↑
Die Ausstellungsbehörde stellt das Europäische Nachlasszeugnis aus, wenn der zu bescheinigende Sachverhalt feststeht. Die Ausstellungsbehörde stellt das Zeugnis insbesondere nicht aus,
wenn Einwände gegen den zu bescheinigenden Sachverhalt anhängig sind oder
wenn das Zeugnis mit einer Entscheidung zum selben Sachverhalt nicht vereinbar wäre.
Hinweis: Wenn Einwände von einem Beteiligten (z.B. Miterben) zu erwarten sind, sollte daher kein Europäisches Nachlasszeugnis beantragt werden. Stattdessen ist entweder ein Erbschein/Testamentsvollstreckerzeugnis zu beantragen oder Klage (z.B. auf Feststellung der Erben) zu erheben.
Wirkungen des Europäischen Nachlasszeugnisses
↑
Das Europäische Nachlasszeugnis entfaltet seine Wirkungen in allen Mitgliedsstaaten, ohne dass es eines besonderen Verfahrens bedarf, Artikel 69 Abs. 1 EuErbVO. Es wird vermutet, dass das Zeugnis richtig ist, Art. 69 Abs. 2 EuErbVO (Richtigkeitsvermutung). Insbesondere wird vermutet, dass
die im Nachlasszeugnis als solche bezeichnete Person Erbe bzw. Vermächtnisnehmer ist,
die Befugnisse eines Testamentsvollstreckers oder Nachlassverwalters nur den im Zeugnis aufgeführten Bedingungen und/oder Beschränkungen unterliegen.
Die Vermutung ist widerlegbar (Dutta FamRZ 2013, 4, 15; Janzen DNotZ 2012, 484, 493).
Leistungen an eine im Zeugnis als Empfangsbefugt ausgewiesene Person haben schuldbefreiende Wirkung, Art. 69 Abs. 3 EuErbVO.
Eine gutgläubige Person kann auf das Nachlasszeugnis vertrauen. Bösgläubig ist, wer Kenntnis von der Unrichtigkeit des Zeugnisses hatte oder infolge grober Fahrlässigkeit keine Kenntnis hat.
Das Zeugnis stellt ein wirksames Schriftstück für die Eintragung des Nachlassvermögens in das einschlägige Register eines Mitgliedstaats dar, Art. 69 Abs. 5 EuErbVO.
Hinweis: Die Eintragung von Rechten an beweglichen oder unbeweglichen Vermögensgegenständen in einem Register kann aber von weiteren Voraussetzungen abhängig gemacht werden, vgl. Artikels 1 Absatz 2 Buchstaben l EuErbVO. Daher kann z.B. für die Eintragung ins das spanische Grundbuch (registro de la propriedad) weiterhin eine notarielle Erbschaftsannahme nach spanischem Recht (aceptación de herencia) und Zuweisung (adjudicación) verlangt werden.
Wirkungsdauer
↑
Die Wirkungen treten nur bei Vorlage einer wirksamen Abschrift des Nachlasszeugnisses ein. Diese sind nur 6 Monate gültig, wenn nicht ausnahmsweise eine längere Wirkung angeordnet wurde, Art. 70 Nr. 3 EuErbVO. Nach Ablauf dieses Zeitraums muss eine Verlängerung der Gültigkeitsfrist beantragt werden.
For excluding all tiddlers has test in their title
``sort: "!search:title[test]"``
<header>
The extract macro retreives content from tiddlers based on common markup, comments or your own tags. Start and end markers can be the same, e.g. wiki styles `''` or `//` or they can be different like `{{` and `}}`. When extracting the beginning or the end of a tiddler, only one marker is needed, so `~~~~` is enough. The macro can be set to collect //one// or //all// matching snippets from the same tiddler.
</header>
<<tweet "Extract content from tiddlers based on common markup, comments or own tags. tid.li/tw5/hacks.html#Extract%20Macro #TiddlyWiki #Macro – via @telmiger">>
!! Hints
!!! New in Version 0.9
* ''mode parameter for block, inline or link output in 0.9.2''
* prefix parameter for tuning results (see list examples)
* class="summary $class$" was changed to class="te-summary $class$"
** use your own class as a parameter to be safe
* documentation update ''with additional examples in 0.9.1''
!!! Extract Macro Components
* $:/_telmiger/extract
!!! Examples: What Extract Can Do
* List all suggested tweets from this wiki: [[Tweeting]]
* The [[Work-Report]] shows the first `<header>` of tiddlers I worked on (where available)
* [[TextStretch Footnotes Extracted as List]] collects footnotes from the text in a tiddler.
** see also the Documentation by Jan about his usage: http://slidesnstories.tiddlyspot.com/#About%20Footnotes – Jan also made an editor button for footnotes. Thank you Jan!
** or my demo at http://tid.li/tw5/numbers.html
* Show the comments in system tiddlers, when a tiddler ist displayed using conditional view templates:
** for macros $:/_telmiger/ui/ViewTemplate/macro-comments
*** result: $:/_telmiger/tweet
** TO RETHINK: do the same for view templates: $:/_telmiger/ui/ViewTemplate/template-comments – //this is not working yet.//
---
{{!!internalsummary}}
.family-tree * {margin: 0; padding: 0;
}
.family-tree ul {
padding-top: 20px; position: relative;
transition: all 0.5s;
-webkit-transition: all 0.5s;
-moz-transition: all 0.5s;
display: flex;
xxflex-wrap: nowrap;
}
.family-tree li {
float: left; text-align: center;
list-style-type: none;
position: relative;
padding: 20px 5px 0 5px;
transition: all 0.5s;
-webkit-transition: all 0.5s;
-moz-transition: all 0.5s;
}
/*We will use ::before and ::after to draw the connectors*/
.family-tree li::before, .family-tree li::after{
content: '';
position: absolute; top: 0; right: 50%;
border-top: 1px solid #ccc;
width: 50%; height: 20px;
}
.family-tree li::after{
right: auto; left: 50%;
border-left: 1px solid #ccc;
}
/*We need to remove left-right connectors from elements without any siblings*/
.family-tree li:only-child::after, .family-tree li:only-child::before {
display: none;
}
/*Remove space from the top of single children*/
.family-tree li:only-child{ padding-top: 0;}
/*Remove left connector from first child and
right connector from last child*/
.family-tree li:first-child::before, .family-tree li:last-child::after{
border: 0 none;
}
/*Adding back the vertical connector to the last nodes*/
.family-tree li:last-child::before{
border-right: 1px solid #ccc;
border-radius: 0 5px 0 0;
-webkit-border-radius: 0 5px 0 0;
-moz-border-radius: 0 5px 0 0;
}
.family-tree li:first-child::after{
border-radius: 5px 0 0 0;
-webkit-border-radius: 5px 0 0 0;
-moz-border-radius: 5px 0 0 0;
}
/*Time to add downward connectors from parents*/
.family-tree ul ul::before{
content: '';
position: absolute; top: 0; left: 50%;
border-left: 1px solid #ccc;
width: 0; height: 20px;
}
.family-tree li a {
border: 1px solid #ccc;
padding: 5px 10px;
xtext-decoration: none;
color: #666;
font-family: arial, verdana, tahoma;
font-size: 11px;
display: inline-block;
border-radius: 5px;
-webkit-border-radius: 5px;
-moz-border-radius: 5px;
transition: all 0.5s;
-webkit-transition: all 0.5s;
-moz-transition: all 0.5s;
}
/*Time for some hover effects*/
/*We will apply the hover effect the the lineage of the element also*/
.family-tree li a:hover, .family-tree li a:hover+ul li a {
background: #c8e4f8; color: #000; border: 1px solid #94a0b4;
}
/*Connector styles on hover*/
.family-tree li a:hover+ul li::after,
.family-tree li a:hover+ul li::before,
.family-tree li a:hover+ul::before,
.family-tree li a:hover+ul ul::before{
border-color: #94a0b4;
}
.family-tree * {margin: 0; padding: 0;
}
.family-tree ul {
padding-top: 20px; position: relative;
transition: all 0.5s;
-webkit-transition: all 0.5s;
-moz-transition: all 0.5s;
display: flex;
xxflex-wrap: nowrap;
}
.family-tree li {
float: left; text-align: center;
list-style-type: none;
position: relative;
padding: 20px 5px 0 5px;
transition: all 0.5s;
-webkit-transition: all 0.5s;
-moz-transition: all 0.5s;
}
/*We will use ::before and ::after to draw the connectors*/
.family-tree li::before, .family-tree li::after{
content: '';
position: absolute; top: 0; right: 50%;
border-top: 1px solid #ccc;
width: 50%; height: 20px;
}
.family-tree li::after{
right: auto; left: 50%;
border-left: 1px solid #ccc;
}
/*We need to remove left-right connectors from elements without any siblings*/
.family-tree li:only-child::after, .family-tree li:only-child::before {
display: none;
}
/*Remove space from the top of single children*/
.family-tree li:only-child{ padding-top: 0;}
/*Remove left connector from first child and
right connector from last child*/
.family-tree li:first-child::before, .family-tree li:last-child::after{
border: 0 none;
}
/*Adding back the vertical connector to the last nodes*/
.family-tree li:last-child::before{
border-right: 1px solid #ccc;
border-radius: 0 5px 0 0;
-webkit-border-radius: 0 5px 0 0;
-moz-border-radius: 0 5px 0 0;
}
.family-tree li:first-child::after{
border-radius: 5px 0 0 0;
-webkit-border-radius: 5px 0 0 0;
-moz-border-radius: 5px 0 0 0;
}
/*Time to add downward connectors from parents*/
.family-tree ul ul::before{
content: '';
position: absolute; top: 0; left: 50%;
border-left: 1px solid #ccc;
width: 0; height: 20px;
}
.family-tree li a {
border: 1px solid #ccc;
padding: 5px 10px;
xtext-decoration: none;
color: #666;
font-family: arial, verdana, tahoma;
font-size: 11px;
display: inline-block;
border-radius: 5px;
-webkit-border-radius: 5px;
-moz-border-radius: 5px;
transition: all 0.5s;
-webkit-transition: all 0.5s;
-moz-transition: all 0.5s;
}
/*Time for some hover effects*/
/*We will apply the hover effect the the lineage of the element also*/
.family-tree li a:hover, .family-tree li a:hover+ul li a {
background: #c8e4f8; color: #000; border: 1px solid #94a0b4;
}
/*Connector styles on hover*/
.family-tree li a:hover+ul li::after,
.family-tree li a:hover+ul li::before,
.family-tree li a:hover+ul::before,
.family-tree li a:hover+ul ul::before{
border-color: #94a0b4;
}
Ziel: Entwicklungstechniken für juristische Wissenssysteme zu verbessern; Wiederverwendung von Wissensspezifikationen
''Aufbau:''
Allgemeine juristische Ontologie, wieder verwendbar, 3 Klassen von Modellierungsprimitiven, für jede Einheit ist eine Framestruktur mit allen relevanten Attributen definiert:
''Normen: ''8 Elemente (Regelnamen, Regeltyp, Kundmachung, Betätigungsfeld, Bedingungen der Anwendung, Normadressat, rechtliche Modalität, Namen von Akten)
''
Aktionen:'' 14 Elemente (Name der Aktion, Kundmachung, Regelungsgebiet, Agent, Typ der Aktion, Modalität der Mittel, Art der Aktion, zeitliche Aspekte, örtliche Aspekte, Umstände des Stattfindens einer Aktion, Grund für Aktionsdurchführung, Ziel der Aktion, Absicht der Aktion, Konsequenz der Aktion)
''Begriffsbeschreibung:'' 7 Elemente (zu beschreibender Begriff, Art des Begriffs, Gewicht eines Faktors, Kundmachung, Regelungsgebiet, Bedingungen zur Anwendung des Begriffs, Beispiele für den Begriff)
''Normspezifische Ontologie: ''muss für jede Sub-Domäne neu angelegt werden (Vokabular)
Einsatz: Darstellung des niederländischen Arbeitslosenversicherungsgesetzes (Bemessung, Planung)
* RECHTSGEBIET
* GESETZ
REFILTERING
Eindimensional Parent Child Beziehung
doch auch speziellere übergeordnete Information aus PARENTS
List basierte Menus für die Inhalte der FIELDS
{{||$:/core/ui/TiddlerFields}}
rendered via <<source "$:/core/ui/TiddlerFields">>
This tiddler is tagged with {{Fields||$:/core/ui/TagTemplate}}
In Fields sollte [[Rechtsgebiete]] und [[Gesetze]].
The following wiki markup examples use filters to list implemented fields types and related information...
<<tabs "[[standard fields]] [[core fields]] [[custom fields]] [[fields of current tiddler]] [[custom fields of current tiddler]]" default:"standard" "$:/state/tabs-fields">>
Lässt ein Versicherter den Schaden an seinem Auto nicht reparieren, kann er dann die Kosten einer teuren Vertragswerkstatt oder nur die einer günstigen freien ersetzt verlangen? Der BGH meint: Es kommt drauf an. Von Gunnar Semrau.
Der BGH hat am Mittwoch die Voraussetzungen konkretisiert, die bei der Abrechnung von fiktiven Reparaturkosten gegenüber dem eigenen Kaskoversicherer zu Grunde zu legen sind. Dabei ging es zentral um die Frage, ob der Versicherte die Kosten der Reparatur bei einer (teuren) Vertragswerkstatt, oder lediglich bei einer (günstigen) freien Werkstatt fordern kann (Urt. v. 11.11.2015, Az. IV ZR 426/14).
Lässt der Geschädigte vollständig und fachgerecht reparieren, erhält er die Kfz-Reparaturkosten von seinem Kaskoversicherer erstattet. Problematisch wird es dann, wenn die Reparaturkosten lediglich fiktiv, also auf Basis eines Gutachtens oder eines Kostenvoranschlages abgerechnet werden sollen. In diesen Fällen verweisen Kaskoversicherer oftmals auf anderweitige günstigere Reparaturmöglichkeiten unterhalb der bisherigen Schadenkalkulation.
In dem BGH-Verfahren hatte der Versicherungsnehmer von seinem Kaskoversicherer den Ersatz der notwendigen Kfz-Reparaturkosten auf Gutachtenbasis verlangt. Das Gutachten berücksichtigte die Stundenverrechnungssätze einer markengebundenen Fachwerkstatt. Der Kaskoversicherer berief sich auf eine eigene Schadenkalkulation, welche die Lohnkosten einer ortsansässigen, nicht markengebundenen Fachwerkstatt beinhaltete, und knapp 3.000 Euro günstiger ausfiel.
Bereicherungsverbot vs. Vertragsleistung
Ausgehend von dem Grundsatz, dass sich der Kaskoversicherte an dem Schaden nicht bereichern darf, hatten in der Vergangenheit einige Instanzgerichte den Versicherern zugebilligt, bei der Schadensabrechnung auf günstigere Reparaturmöglichkeiten zu verweisen. Insbesondere sollte danach der Verweis auf günstigere Stundenverrechnungssätze in freien Werkstätten möglich sein. Teilweise wurden Stundenverrechnungssätze auf der Basis eines Durchschnittes zugesprochen. Die sonstigen Voraussetzungen, unter denen ein Geschädigter von seinem Kaskoversicherer die fiktive Abrechnung auf Basis markengebundener Fachwerkstatts-Löhne verlangen können soll, war im Einzelnen streitig.
Diese Uneinheitlichkeit spiegelte sich auch in dem Verfahren, über welches der BGH zu befinden hatte: Das Amtsgericht hatte der Klage in erster Instanz stattgegeben, das Berufungsgericht hingegen hatte sie abgewiesen. Der BGH beschreibt nunmehr die Voraussetzungen der Regulierungspflichten näher. Da er allerdings weitere Sachaufklärung für Erforderlich hält, hat er den Rechtsstreit wieder zurückverwiesen.
Er führt aus, dass in der Kaskoversicherung allein die vertraglichen Vereinbarungen der Parteien maßgeblich sind. Die für den Schadensersatz geltenden allgemeinen Regelungen (Stichwort: Schadenminderungspflicht) können daher nicht angewandt werden. Einschränkungen der Versicherungsleistung können sich vor allem aus den Versicherungsbedingungen ergeben. Diese entsprachen im Streitfall der Musterformulierung in den Allgemeinen Bedingungen für die Kraftfahrtversicherung (AKB) des GDV, Ziffer A.2.7.1 AKB 2008 bzw. der neuen Ziffer A.2.5.2.1b AKB 2015, und verpflichteten den Versicherer, soweit hier relevant, zum Ersatz der "erforderlichen" Kosten.
Wann ist die Fachwerkstatt "erforderlich"?
Ob die kalkulierten Reparaturkosten "erforderlich" sind oder nicht, soll sich aus den jeweiligen Umständen des Einzelfalles ergeben. Nach Auffassung des BGH soll der Versicherungsnehmer die Aufwendungen für die Reparatur in einer markengebundenen Werkstatt grundsätzlich dann ersetzt verlangen können, wenn nur in der Markenwerkstatt eine vollständige und fachgerechte Instandsetzung seines Fahrzeugs möglich ist. Maßgeblich kann aber auch sein, wenn es sich um ein neueres Fahrzeug oder um ein solches handelt, das der Versicherungsnehmer bisher stets in einer markengebundenen Fachwerkstatt hat warten und reparieren lassen.
Die Darlegungs- und Beweislast für diese Umstände liegt beim Versicherungsnehmer. Da die Vorinstanz hierzu keine Feststellungen getroffen hatte, hat der BGH den Rechtsstreit wieder zurückverwiesen. Bislang hat der BGH sein Urteil noch nicht schriftlich begründet. Möglicherweise werden sich aus dem Volltext der Entscheidung weitere Kriterien dafür ergeben, wann die Reparatur bei einer Fachwerkstatt im Einzelnen als erforderlich gelten kann.
Im Rahmen der Haftpflichtschaden-Abrechnung wird dies von den Gerichten mitunter sehr unterschiedlich gesehen. So soll der Verweis auf günstigere Reparaturmöglichkeiten teilweise etwa nur dann möglich sein, wenn ein konkretes anderweitiges Reparaturangebot unterbreitet wird oder wenn die andere Reparaturmöglichkeit am Wohnort des Geschädigten liegt. Die Frage, ob nur deshalb günstiger repariert werden kann, weil eine Sondervereinbarung mit dem Versicherer besteht, kann ebenfalls relevant sein. Und auch die Grundsätze zur Beibehaltung von Qualitätsstandards, die der BGH bereits in seinem "VW-Urteil" (v. 20.10.2009, Az. VI ZR 53/09) aufgestellt hat, könnten eine Rolle spielen.
Die aktuelle BGH-Entscheidung bezieht sich in erster Linie auf den Verweis auf günstigere Stundenverrechnungssätze. Daneben verbleiben natürlich die sonstigen Abzüge gemäß den zugrunde liegenden Versicherungsbedingungen. Zum Beispiel sehen Kasko-Versicherungsbedingungen regelmäßig einen Abzug Neu-für-Alt vor, wenn der Geschädigte durch den Einbau neuer Ersatzteile Aufwendung erspart hat, die er früher oder später ohnehin hätte machen müssen, um Verschleißteile zu ersetzen.
auf Gutachtenbasis (ohne Vorlage einer Rechnung) auch nach Ausübung des Wahlrechts
Abrechnung nach Gutachten
Einen Unfall nach Gutachten abzurechnen nennt man auch fiktive Abrechnung. Dies kommt immer dann in Betracht, wenn Sie als Geschädigter den Schaden nicht reparieren lassen wollen, sondern sich die Schadenssumme auszahlen lassen wollen. Die Auszahlung kann dann sinnvoll sein, wenn Ihr Fahrzeug z.,B. schon älter ist oder aber wenn es sich um einen kleinen Blechschaden handelt. Eine Delle kann insoweit einen nicht unerheblichen Schadensersatzbetrag zur Folge haben. Die fiktive Abrechnung kann sich also lohnen.
Wann ist die Abrechnung nach Gutachten sinnvoll
Abrechnung nach Gutachten, sprich fiktiv abzurechnen, ist immer dann sinnvoll, wenn es sich um einen Haftpflichtschaden handelt. Dies bedeutet, dass Sie selbst keine Unfallschuld an dem Verkehrsunfall tragen, sondern die Versicherung des Unfallgegners und des anderen Beteiligten einstandspflichtig ist und bezahlen muss.
Wenn Sie selbst den Schaden verursacht haben, dann spricht man insoweit von einem Kaskoschaden. Nach der Rechtsprechung des BGH ist die fiktive Abrechnung problemlos möglich, d.h. Sie können sich die Schadensumme vom Versicherer auszahlen lassen ohne dass das Fahrzeug repariert werden muss.
Abrechnung nach Gutachten in der Kaskoversicherung
Ist der Unfallschaden ein Kaskoschaden, dann haben Sie auch die Möglichkeit, nach Gutachten abzurechnen. Dies hat jedoch einen Nachteil, nämlich den, dass Sie in der Regel mit einer Rückstufung in der Schadensfreiheitsklasse zu rechnen haben. Dies liegt daran, dass Sie ja Ihre eigene Versicherung in Anspruch nehmen.
Die Schadensermittlung als Grundlage für die Abrechnung nach Gutachten
Vor der Abrechnung nach Gutachten liegt die Schadensermittlung. Es steht also im ersten Schritt der Schaden dem Grunde nach und dann der Höhe nach im Raum. Wenn geklärt ist, ob es sich um einen Haftpflichtschaden oder um einen Kaskoschaden handelt dann steht die Schadenhöhe im Raum.
Im Haftpflichtschadenbereich haben Sie die Möglichkeit nach Gutachten oder aber nach Kostenvoranschlag abzurechnen. Ein KFZ-Gutachten ist immer dann sinnvoll, wenn der Reparaturschaden höher als € 750,00 ist. In diesem Fall ist die Versicherung zu dazu verpflichtet, die KFZ-Sachverständigenkosten zu bezahlen. Hierfür wird ein KFZ-Sachverständiger mit der Begutachtung des Fahrzeugschadens beauftragt. Dieser ermittelt die Reparaturkosten anhand des Schadenbildes. Es empfiehlt sich, einen freien KFZ-Sachverständigen zu beauftragen und nicht einen Gutachter der gegnerischen Versicherung, denn dieser wird den Schaden klein rechnen.
Kürzungen bei der fiktiven Abrechnung
Bei der Abrechnung nach Gutachten kommt es immer wieder zu Kürzungen. Sie müssen Sie damit rechnen, dass die Versicherung s.g. Prüfberichte zu dem Kostenvoranschlag oder aber dem KFZ-Sachverständigengutachten einholt. Diese Kürzungsberichte haben in der Regel jedoch keine weitere Aussagekraft vor Gericht. Dies folgt daraus, dass es sich nicht um Sachverständigengutachten handelt, sondern um s.g. technische Prüfberichte. Es ist nämlich Aufgabe des KFZ-Sachverständigen die Schadenshöhe zu beziffern. Regelmäßig werden jedoch Verbringungskosten und Ersatzteilzuschläge sowie Stundenverrechnungssätze einer Markenwerkstatt gekürzt. In einem solchen Fall sollten Sie unbedingt/verbringungskosten-bei-fiktiver-abrechnung Kontakt aufnehmen, da viele Versicherungen auf ein erstes anwaltliches Forderungsschreiben nachregulieren.
Bekannt sind insoweit die Krüzungsberichte der Firmen CarExpert und Controlexpert.
Die Abrechnung nach Gutachten bei einem Totalschaden
Wenn Ihr Fahrzeug ein wirtschaftlicher Totalschaden ist, dann ist die Abrechnung wie folgt vorzunehmen. Der KFZ-Sachverständige ermittelt den Wiederbeschaffungsaufwand des Fahrzeuges. Gleichzeitig ermittelt er den Restwert des Fahrzeuges unter Berücksichtigung von drei regionalen Restwertangeboten. Die Totalschadensabrechnung erfolgt dann auf Grundlage des Wiederbeschaffungswertes abzüglich des Restwertes. Der Wiederbeschaffungsaufwand ist der Aufwand, der von der Versicherung als Schadensersatzsumme, als Schadensersatz, zu zahlen ist. Neben diesem Schadensersatz, dem Wiederbeschaffungsaufwand bestehen jedoch noch weitergehende Ansprüche.
Fiktive Abrechnung
Der Geschädigte kann gemäß § 249 BGB frei wählen, ob er das Fahrzeug instand setzen lässt oder ob er sich die ermittelten Reparaturkosten auszahlen lässt (fiktive Abrechnung).
Der Geschädigte darf in diesen Fällen sein beschädigtes Fahrzeug zu dem Wert veräußern, den der Sachverständige als Wert auf dem allgemeinen regionalen Markt ermittelt hat. Auf höhere Restwertangebote des Versicherers muss er sich nur dann einlassen, falls er sein Fahrzeug noch nicht veräußert hat (BGH, Urteil vom 06. 04. 1993, AZ VI ZR 181/92 - und BGH, Urteil vom 30. 11. 1999, AZ VI ZR 219/98).
Fiktive Abrechnung
Abrechnung nach Gutachten
Sofern der Geschädigte sein Fahrzeug bei einem Kfz-
Moment nicht reparieren (lassen) möchte, kann er sich den Schaden von der
eintrittspflichtigen Versicherung "auszahlen" lassen.
Diesen Vorgang bezeichnet man als fiktive Abrechnung oder Abrechnung nach Gutachten,
da zur genauen Schadenskalkulation ein Gutachten erforderlich ist und nach diesem dann
abgerechnet wird.
Die Grenzen für die Berechnungsverfahren hat der BGH mit seinem Urteil
folgt festgelegt:
1.) Der Geschädigte hat Anspruch auf Erstattung der Reparaturkosten (Netto), wenn die
Reparaturkosten den Wiederbeschaffungswert nicht übersteigen und er das Fahrzeug
innerhalb der folgenden 6 Monate nach dem Schadensereignis weiter nutzt bzw. das
Fahrzeug innerhalb dieser 6-Monatsfrist nicht veräußert.
2.) Wird das verunfallte Fahrzeug innerhalb von 6 Monaten veräußert, so hat der
Geschädigte nur Anspruch auf Erstattung des Wiederbeschaffungsaufwandes
(=Wiederbeschaffungswert - Restwert).
Bei der fiktiven Abrechnung der Reparaturkosten zu 1.) gibt es jedoch eine weitere
Einschränkung mit erheblichem finanziellen Nachteil.
Bei einem Schadenseintritt bis zum 31.07.2002 erfolgte die Auszahlung des Schadens
einschließlich der gesetzlichen Mehrwertsteuer.
Der Schaden wurde also "Brutto" ausbezahlt.
Zum 01.08.2002 trat eine Gesetzesänderung in Kraft, nach der bei der fiktiven Abrechnung
nur noch der Nettoschaden ohne gesetzliche Mehrwertsteuer (z. Zt. 19%) erstattet wird.
Hierzu ist folgendes anzumerken.
Sollte das Fahrzeug nach Erstattung der Nettoreparaturkosten doch noch vollständig oder
teilweise repariert werden, so ist die Mehrwerststeuer fällig, sofern ein entsprechender
Nachweis erbracht wird.
Ein geeigneter Nachweis kann eine Rechnung über die Instandsetzung des
Gesamtschadens sein oder Materialrechnungen, sofern eine Eigenreparatur vorgenommen
wurde.
Bei Teilerechnungen wird natürlich nur die Mehrwertsteuer aus der Teilerechnung erstattet.
Dies gilt auch für Rechnungen zu Lohnkosten oder Rechnungen für Reparaturanteile wie
z.B. die Kosten für die Lackierung.
Die Einsparung aufgrund der Gesetzesänderung in Höhe der Mehrwertsteuer war den
Versicherern offensichtlich nicht weitreichend genug, wie die momentane Praxis der
Schadensabwicklung zeigt.
Bei der fiktiven Abrechnung werden die Positionen
Ersatzteilzuschläge und
Verbringungskosten
dass diese Kosten nur erstattet werden, wenn der entsprechende Nachweis erbracht wird.
Zu der Position Ersatzteilzuschläge gibt es eindeutige
Ersatzteilzuschläge bei der fiktiven Abrechnung zu erstatten sind, sofern die örtlichen
Vertragshändler diese Zuschläge berechnen.
Auch zur Position Verbringungskosten gibt es reichlich
Verbringungskosten als Teil des Gesamtschadens fiktiv erstattet werden müssen.
Des weiteren werden dann noch die Stundenverrechnungssätze der jeweiligen
markengebundenen Vertragswerkstatt auf willkürliche "ortsübliche"
Stundenverrechnungssätze gekürzt.
Zum Teil mit dem Hinweis, dass diese Sätze durch renomierte Unternehmen ermittelt
worden seien.
Dieser Praxis hat der BGH bereits am 29.04.2003 mit dem legendären Porsche-Urteil
VI ZR 398/02)
Nachdem die Kürzerei aufgrund es "Porsche-Urteils" mittelweile nicht mehr zum Erfolg
führt, versucht man nunmehr die Stundensätze der markengebundenen
Vertragswerkstätten zu kürzen auf Stundenverrechnungssätze "freier Werkstätten" bzw. auf
das Lohnnieveau von Partnerwerkstätten = Vertragswerkstätten der Versicherer.
Auch dies widerspricht dem o.a. BGH-Urteil, wie man der weiteren BGH Rechtsprechung
entnehmen kann (
Durch das Schadensmanagement, zu dem u.a. die o.a. Kürzungen gehören, "spart" die
Versicherungswirtschaft pro Jahr 3-stellige Millionenbeträge.
Einige Schätzungen gehen von mehr als 1 Milliarde Euro / Jahr aus.
Diese "Einsparungen" gehen zu Lasten des Geschädigten, der mit dem Verzicht auf
Schadenspositionen, die ihm rechtlich zustehen, letztendlich die Zusatzgewinne der
Versicherer subventioniert.
Die o.a. Kürzungen werden seitens der meisten Versicherer wider besseres Wissen und
vorsätzlich gegen geltendes Recht vorgenommen.
Die Positionen sind in der Regel nur mit Hilfe eines versierten Rechtsanwaltes realisierbar.
There are two kinds of filter operators.
Some filters require an input, but others can generate an output even if they have no input.
The 'tag' is one of the latter types. You need to put 'is[current]' in front of each of the tag filter operators in your template, or it will generate the list of all tags that match from your entire tiddlywiki.
Filtering is very powerful and it can be used for logical operations. This is some notes about logic operations using filtering in tiddlywiki. Most of what is here isn't all that useful generally, but hopefully it can be used to simplify filtering problems in tiddlywiki.
Filter operators that this applies to the operators `days`, `field`, `has`, `haschanged`, `is`, `regexp`, `sameday`, `search`, `prefix`, `suffix`, `tag` and `untagged`
I am going to use the following notation:
|!Operation |!Symbol |
|`A` and `B` |`A.B` |
|`A` or `B` |`A+B` |
|not `A` |`¬A` |
|`A` xor `B` |`A⊕B` |
|`A` iff `B` |`A⇔B` |
Some rules to remember:
```
A+B ⇔ ¬(¬A.¬B)
¬(A+B) ⇔ ¬A.¬B
A.B ⇔ ¬(¬A+¬B)
¬(A.B) ⇔ ¬A+¬B
A ⇔ A.B+A.¬B
A ⇔ A+A.B
A ⇔¬(¬A)
```
It occurs to me that it may be better to use set notation for this...
Check the checkboxes to filter the list to the related tags, click on a tag to show the list of filtered tiddlers of that. For example, click on Linux without filters, than filter to FileManager and see it again - it will list FileManager for Linux.
The list is respecting the search entry: try to look for `filtered`.
To try out on another wiki, just drag-n-drop these tiddlers and one of the examples to it.
<<list-links filter:"[is[system]tag[FilteredTag]]">>
Examples:
* [[FilteredTag example]]
* [[FilteredTag example: Grouped tags]]
[tag[Vegetarian]!tag[soup]serving[4]]
oder
[field:serving[4]]
<<tabs "[tag[Filter]]" "SampleTabTwo" "$:/state/tab2" "tc-vertical">>
// This first example returns all tags of tiddlers prefixed `filter` using a subfilter retrieved from a text-reference, replacing the __default__ variable ''inputTitle'' with each input title in turn: //
<<` """; subfilter
: <$text text={{filter-Examples!!test}}/>
{{{ [prefix[filter]filter{filter-Examples!!test}] }}}""">>
@@.note
''Note:'' By default, the subfilter is given only the currently processed input title as its source. To pass all input titles to the subfilter, use the suffix ''input''; see further down. To access all tiddlers in a subfilter, start it by using the <<x "all Operator" "all[] filter operator">>, e.g.:<br/>
`[all[tiddlers]!is[system]tag<inputTitle>]`
@@
!! Using Context Variables
// In this example a lot of context variables are replaced in the subfilter://
<$macrocall $name="`" text="""<$vars
prefix="!"
filter="field"
suffix="title"
operand="filter"
subfilter="[%prefix%%filter%:%suffix%[%operand%]]">
{{{ [prefix[filter]filter<subfilter>] }}}
vs:
{{{ [prefix[filter]] }}}
</$vars>"""/>
<hr/>
<$vars
filter-listed="[list[!!tabs]]"
filter-backlinks="[backlinks[]]"
filter-tag="[tag<inputTitle>]" >
// The next examples use the variable ''filter-backlinks'' as their subfilter: //
> <code><<filter-backlinks>></code>
// For verification, let's fetch all tiddlers that are backlinks to any prefixed `filter`://
<<` """{{{ [prefix[filter]backlinks[]] }}}""">>
!! Simple Subfilter
// Evaluates a subfilter to retrieve backlinks of tiddlers prefixed `filter`: //
<<` """{{{ [prefix[filter]filter<filter-backlinks>] }}}""">>
!! Subfilter $
// Retrieves the tiddlers for which the subfilter has matches, those with backlinks: //
<<` """{{{ [prefix[filter]filter:$<filter-backlinks>] }}}""">>
!! Subfilter $all
// Checks te subfilter against all prefixed `filter`, however returning all input titles, should any have backlinks: //
<<` """{{{ [prefix[filter]filter:$all<filter-backlinks>] }}}""">>
<hr/>
// The next examples use the variable ''filter-listed'' as their subfilter: //
> <code><$text text=<<filter-listed>>/></code>
!! Subfilter Variable
// When evaluating the subfilter, the variable ''currentTiddler'' is set to each input title in turn, fetching all titles listed in the ''tabs'' field of any tiddler prefixed `filter`://
<<` """{{{ [prefix[filter]filter: var:currentTiddler<filter-listed>] }}}""">>
@@.note
''Note:'' By setting ''currentTiddler'' we define a different context for the list filter operator.
@@
!! Subfilter Variable $
// Instead of titles listed in the ''tabs'' field, returns those input titles that have titles listed in it: //
<<` """{{{ [prefix[filter]filter:$ var:currentTiddler<filter-listed>] }}}""">>
!! Subfilter Variable $all
// Finally, returns all prefixed `filter` if any has titles listed in a ''tabs'' field: //
<<` """{{{ [prefix[filter]filter:$all var:currentTiddler<filter-listed>] }}}""">>
<hr/>
// The next examples use the variable ''filter-tag'' as their subfilter: //
> <code><$text text=<<filter-tag>>/></code>
!! Subfilter Source Titles
// Below, using the suffix ''input'', the subfilter is evaluated against all input titles, not just the currently iterated one. In the subfilter, the __default__ variable ''inputTitle'' is replaced with each input title in turn, fetching all input titles that are prefixed `contains` and have any other titles thus prefixed as a tag://
<<` """{{{ [prefix[contains]filter:input<filter-tag>] }}}""">>
!! Subfilter Source Titles $
// Instead of the tagged tiddlers, returns those input titles where the filter had matches, i.e. titles that have other tiddlers prefixed `contains` tagging to them: //
<<` """{{{ [prefix[contains]filter:$ input<filter-tag>] }}}""">>
!! Subfilter Source Titles $all
// Finally, rather than matches, returns all input titles if any had matches: //
<<` """{{{ [prefix[contains]filter:$all input<filter-tag>] }}}""">>
</$vars>
\define list_hits()
<$list filter="[!is[shadow]!is[system]field:$(fieldname)$/$(regexp)$/]">
</$list>
\end
<$listselect filter="[fields[]sort[title]]" tiddler="$:/temp/FlexibleSearch" field="fieldname"/> <$edit-text tag="input" type="text" tiddler="$:/temp/FlexibleSearch"/>
<$set name="fieldname" value={{$:/temp/FlexibleSearch!!fieldname}}>
<$set name="regexp" value={{$:/temp/FlexibleSearch}}>
<<list_hits>>
</$set>
</$set>
Fluchtwege aus der Verspätungsfalle
von Benedikt Windau
In einem Beitrag vor einigen Wochen hatte ich hier die Voraussetzungen der Präklusionstatbestände des § 296 Abs. 1 und 2 ZPO (anhand einer „Checkliste“) dargestellt und darauf hingewiesen, dass eine (berechtigte) Zurückweisung wegen Verspätung in der Praxis eher die Regel als die Ausnahme sein dürfte.
Der „sicherste Weg“ wird es aus anwaltlicher Sicht trotzdem in vielen Fällen gebieten, eine drohende Präklusion wichtiger Angriffs- und Verteidigungsmittel zu vermeiden. Dazu stehen mehrere mehr oder weniger bekannte Wege zur Verfügung, die im Folgenden insbesondere im Hinblick auf die jeweiligen Vor- und Nachteile näher dargestellt werden sollen. Die Flucht in die Berufung bleibt dabei außen vor, da diese wegen §§ 529, 531 ZPO seit 2001 kaum einen Anwendungsbereich haben dürfte.
Allen „Fluchtwegen“ gemein ist dabei, dass das Vorbringen zwar formal verspätet bleibt, sie das Gericht zu einem weiteren Verhandlungstermin zwingen. Und diesen neuen Termin muss das Gericht vorbereiten (insbesondere durch Ladung benannter Zeugen) so dass sich die vorangegangene Verspätung in vielen – aber nicht allen (!) – Fällen nicht mehr auswirkt.
Flucht in die Säumnis
Praktisch am weitaus verbreitetsten ist die Flucht in die Säumnis, bei der die Partei keinen Antrag stellt, ein Versäumnisurteil gegen sich ergehen lässt und die möglicherweise verspäteten Angriffs- und Verteidigungsmittel dann im Rahmen der Einspruchsbegründung (§ 340 ZPO) vorbringt.
So verbreitet die Flucht in die Säumnis ist – wirkliche sinnvoll und zweckmäßig dürfte sie nur in wenigen Fällen sein. Und sie hat allenfalls den Vorteil, dass sie in der mündlichen Verhandlung wenig Kreativität erfordert.
Denn die Nachteile einer Flucht in die Säumnis sind erheblich. Insbesondere für die beklagte Partei dürfte es in der Regel nachteilig sein, dass ein – ohne Sicherheitsleistung (§ 708 Nr. 2 ZPO) – vorläufig vollstreckbares Versäumnisurteil ergeht und die Zwangsvollstreckung nur gegen Sicherheitsleistung eingestellt werden kann (§ 719 Abs. 1 Satz 2 ZPO). Hinzu kommen Kostennachteile: Die „fliehende“ Partei hat zwingend die Kosten des Säumnisverfahrens zu tragen (§ 344 ZPO), zusätzlich kommt die Erhebung einer Verzögerungsgebühr gem. § 38 GKG in Betracht (s. dazu ausführlich hier). Eine Flucht in die Säumnis ist außerdem nur einmal möglich; bei der zweiten „Flucht“ in Folge ergeht ein zweites Versäumnisurteil (§ 345 ZPO). Und eine Flucht in die Säumnis ist nicht mehr möglich, wenn die Partei zu Beginn der Verhandlung bereits einen Antrag gestellt hat, da eine Rücknahme oder ein Widerruf des Sachantrages ausscheidet (s. nur OLG München, Urteil vom 26.10.2010 – 5 U 2320/10).
Am nachteiligsten ist jedoch – was vielfach nicht bekannt ist – dass eine Flucht in die Säumnis überhaupt nicht in jedem Fall sicherstellt, dass das Vorbringen tatsächlich Berücksichtigung findet. Denn das Gericht ist nicht gehalten, den Einspruchstermin so weit herauszuschieben, dass vorher beispielsweise ein schriftliches Sachverständigengutachten eingeholt werden kann (BGH, Urteil vom 23.10.1980 – VII ZR 307/79; OLG Zweibrücken, Urteil vom 28.06.2001 – 4 U 69/00). Gerade wenn das verspätete Vorbringen eine aufwendige Beweisaufnahme erfordert, ist eine Flucht in die Säumnis deshalb äußerst riskant.
Und die Flucht in die Säumnis hat noch einen weiteren Nachteil: Ergeht auf Antrag der Gegenseite ein Versäumnisurteil und wird nicht vertagt, führt ein späterer Vergleich (oder Klagerücknahme/Anerkenntnis) nicht mehr zu einer Gebührenreduzierung, es fallen stets 3 Gerichtsgebühren an. (Deshalb kann es als Gegner ratsam sein, in solchen Fällen statt eines Versäumnisurteils nur Vertagung zu beantragen, wenn eine Vollstreckung aus dem Versäumnisuteil ohnehin nicht beabsichtigt ist.)
Flucht in die Klageerweiterung/Widerklage
Deutlich seltener ist die Flucht in die Klageerweiterung bzw. die Flucht in die Widerklage.
Dabei macht sich die „fliehende“ Partei zu eigen, dass nach der Rechtsprechung des Bundesgerichtshofs (Urteil vom 23. April 1986 – VIII ZR 93/85) nur Angriffs- und Verteidigungsmittel, nicht aber ein Angriff oder eine Verteidigung an sich verspätet sein können. Erweitert der Kläger daher seine Klage so oder erhebt der Beklagte eine Widerklage, und kommt es für die Entscheidung über die erweiterte Klage oder die Widerklage ebenfalls auf die eigentlich verspäteten Angriffs- und Verteidigungsmittel an, muss das Gericht diese Angriffs- und Verteidigungsmittel berücksichtigen. Denn es darf den Angriff oder die Verteidigung an sich nicht als verspätet zurückweisen. Und es darf auch nicht über die ursprünglichen Anträge durch Teilurteil entscheiden und insoweit die verspäteten Angriffs- und Verteidigungsmittel zurückweisen, weil sonst ersichtlich die Gefahr widersprüchlicher Entscheidungen besteht. Und vor allem darf das Gericht die Klageerweiterung oder Widerklage auch nicht als rechtsmissbräuchlich abweisen, weil sie lediglich „zur Flucht“ dient.
Vorteilhaft ist die Flucht in die Klageerweiterung und Widerklage insbesondere, weil sie sämtliche Nachteile der Flucht in die Säumnis vermeidet: Das Gericht muss das Vorbringen definitiv berücksichtigen, gegen die „fliehende“ Partei ergeht kein vorläufig vollstreckbares Urteil und Kostennachteile entstehen allenfalls in sehr geringem Umfang, wenn keine Gebührenstufe überschritten wird u.U. gar nicht. Und eine Flucht in die Klageerweiterung oder Widerklage ist grundsätzlich auch mehrfach möglich (irgendwann wird allerdings möglicherweise doch die Schwelle des Rechtsmissbrauchs erreicht sein).
Nachteile hat eine Flucht in die Klageerweiterung/Widerklage nicht (sie erfordert allerdings im Termin u.U. etwas Kreativität). Die Flucht in die Klageerweiterung oder Widerklage ist deshalb der sicherste Fluchtweg.
Flucht in den Befangenheitsantrag
Teilweise bekannt ist auch eine Flucht in den Befangenheitsantrag. Dabei macht sich die „fliehende“ Partei zu Nutze, dass das Gericht bei einem anhängigen Ablehnungsgesuch grundsätzlich nicht verhandeln, keinen Verkündungstermin anberaumen oder keine Entscheidung verkünden kann und deshalb ein neuer Termin zur mündlichen Verhandlung erforderlich ist.
Die Flucht in den Befangenheitsantrag hat aber nur (noch) einen sehr eng begrenzten Anwendungsbereich: Denn nach Beginn der Verhandlung kann das Gericht bekanntlich gem. § 47 Abs. 2 ZPO weiterverhandeln, einen Verkündungstermin anberaumen und – wenn das Ablehnungsgesuch rechtskräftig für unbegründet erklärt ist – auch eine Entscheidung verkünden. Ein Ablehnungsgesuch im Termin ist deshalb kein sicheres Fluchtmittel.
Ein Ablehnungsgesuch unmittelbar vor dem Verkündungstermin mit dem Ziel, dass dieser aufgehoben wird bzw. ohne Verkündung verstreicht und deshalb ein weiterer Termin erforderlich ist (die Bestimmung eines neuen Verkündungstermins ohne unmittelbar vorangegangene Verhandlung ist bekanntlich unzulässig), dürfte ebenfalls wenig sicher sein. Denn der abgelehnte Richter ist trotz anhängigen Anlehnungsgesuchs gem. § 47 Abs. 1 ZPO berechtigt, diesen zu verlegen (so überzeugend OLG Hamburg, Beschluss vom 30.06.2017 – 3 U 130/16).
Ein Anwendungsbereich ist deshalb nur dann ersichtlich, wenn die Verspätung vor dem Termin auffällt und das Ablehnungsgesuch noch vor Aufruf der Sache (§ 220 Abs. 1 ZPO) angebracht wird (wie es z.B. hier der Fall war). Auch dann gilt aber wie bei der Flucht in die Säumnis, dass das Gericht bei seiner Terminierung nicht zuwarten muss, um eine aufwändige Beweisaufnahme zu ermöglichen. Es ist also nicht sichergestellt, dass das verspätete Vobringen tatsächlich Berücksichtigung findet. Außerdem kann das Ablehnungsgesuch auch rechtsmissbräuchlich und damit schon unzulässig sein und ist auch deswegen kein zuverlässiger Fluchtweg. Und zuletzt droht auch hier die Erhebung einer Verzögerungsgebühr gem. § 38 GKG (s. OLG Düsseldorf, Beschluss v. 21.5.2015 – 6 W 46/15).
Und zuletzt sollte nicht unerwähnt bleiben, dass Ablehnungsgesuche in Zivilsachen doch häufig als eher „unfreundlicher Akt“ wahrgenommen werden und deshalb wenig geeignet sein dürften, das Gericht für den Mandanten (und seinen Anwalt) einzunehmen.
Flucht in die Klagerücknahme
Solange der Kläger die Klage noch ohne Zustimmung des Beklagten zurücknehmen kann (§ 269 Abs. 1 ZPO), kommt auch eine Flucht in die Klagerücknahme in Betracht. Das dürfte aber kaum jemals sinnvoll sein, weil der Kläger dann gem. § 269 Abs. 3 Satz 2 ZPO zwingend verpflichtet ist, die bis dahin entstandenen Kosten des Rechtsstreits zu tragen.
tl;dr: Am sichersten ist stets die Flucht in die Klageerweiterung oder Widerklage. Demgegenüber scheint die verbreitete Flucht in die Säumnis nicht ratsam und dürfte insbesondere kaum jemals der „sicherste Weg“ sein.
Ziel: Organisation und Vernetzung von Rechtwissen, insb in Hinblick auf konzeptionelles IR
Grundkategorien des Rechtswissens
Normatives Wissen, Weltwissen, Haftungswissen, Sanktionswissen, Rechtschöpfungswissen, Metawissen
Einsatz/Folgeprojekte:
ON-LINE (Architektur für künstliche juristische Falllösung)
CLIME/MILE (Ziel: juristischer Informationsserver für größte Textmengen; Testanwendungen: Schiffsklassifikation, Seerecht; konzeptionelles IR, Dialogsystem, abstrakte Fallbeschreibung)
PROSA (Trainingssystem zur juristischen Falllösung)
Problem: Modellierung des “Weltwissens”
<footer class="footnotes">
!! Footnotes from tiddlers
<$list filter="""[list[$:/StoryList]search[<ref ]] -[[Footnotes]] -[is[system]] -[has[draft.of]] -[[$:/AdvancedSearch]]""">
!!! <$link to={{!!title}}><$view field="title"/></$link>
<ol>
<$list filter="[<currentTiddler>![Footnotes]]">
<<extract start:"ref " end:">" limit:"no" rmQuotes:"y" prefix:"<li>" suffix:"</li>" mode:"inline">>
</$list>
</ol>
</$list>
</footer>
Weiterentwicklung von Thesauri, Vokabulare, Klassifikationen
Brücke von realer Welt zur Rechtsordnung
Sprachlich, nicht-sprachlich
Verschiedene Thesaurusniveaus
Juristen
Laien
Bibliothekare, Dokumentare
Intellektuelle Leistung
Reduktion der Wortkomplexität
Beschreibung der Wortstruktur: Synonyme, Homonyme, Polyseme, Gegensätze, Ober- und Unterbegriffe
Vernetzung unterschiedlicher Sprachniveaus
Vernetzung unterschiedlicher Sprachen (Wörterbücher)
Bei den rechtshindernden Einwendungen ist die Formunwirksamkeit nach § 125 BGB zu berücksichtigen. Für eine Formunwirksamkeit muss entweder ein Verstoß gegen gesetzliche Formvorschriften (S. 1) oder ein Verstoß gegen vertraglich vereinbarte Formvorschriften vorliegen (S.2).
I. § 125 S. 1 BGB
Die Formunwirksamkeit nach § 125 S. 1 BGB wird üblicherweise in drei Schritten geprüft.
1. Verstoß gegen gesetzliche Formvorschrift
Zunächst muss ein Verstoß gegen eine gesetzliche Formvorschrift vorliegen. Beispiele: Nach § 766 S. 1 BGB bedarf die Bürgschaftserklärung der Schriftform. Gemäß § 518 I BGB ist für das Schenkungsversprechen eine notarielle Beurkundung erforderlich. Gleiches gilt für den Grundstückskaufvertrag. Auch hier muss nach § 311b I 1 BGB eine notarielle Beurkundung erfolgen.
2. Heilung
Weiterhin dürfte für eine Formunwirksamkeit § 125 S.1 BGB keine Heilung eingetreten sein. Eine Heilung der unterlassenen Schriftform tritt bei der Bürgschaft gemäß § 766 S. 3 BGB dann ein, wenn der in Anspruch genommene Bürge bereits gezahlt hat. Ebenso tritt Heilung der unterlassenen notariellen Beurkundung nach § 518 II BGB ein, wenn die Leistung bewirkt wird, und nach § 311b I 2 BGB, wenn das Grundstück bereits aufgelassen wurde.
(3. § 242 BGB)
Weiterhin kann es ausnahmsweise nach § 242 BGB gegen die Grundsätze von Treu und Glauben sprechen, sich auf eine Formunwirksamkeit zu berufen. Dies ist jedoch nur zu prüfen, wenn der Fall hierzu Veranlassung gibt. Beispiel: Gezielte Täuschung über die Formbedürftigkeit. A betreibt eine Grundstücksverwaltung und verkauft ein Grundstück an B und sagt, es bedürfe ausnahmsweise keiner Beurkundung, da er ein Kaufmann sei. A täuscht über die Formbedürftigkeit, um sich später auf die Formunwirksamkeit zu berufen, weil er der Meinung ist, dass er später eventuell einen höheren Kaufpreis bei anderen Interessenten erzielen könne. B verlangt nun Übereignung, A beruft sich jedoch auf Formunwirksamkeit nach § 125 S. 1 BGB. Es liegt zwar ein Verstoß gegen eine gesetzliche Formvorschrift, nämlich § 311b I 1 BGB vor. Es ist mangels Auflassung des Grundstücks auch noch keine Heilung, eingetreten. Aufgrund der gezielten Täuschung verstößt das Pochen auf die Formunwirksamkeit aber gegen Treu und Glauben gemäß § 242 BGB. Etwas anderes gilt jedoch in folgendem Edelmann-Fall des Reichsgerichts: A und B schließen einen Kaufvertrag über ein Grundstück und A spricht die Formbedürftigkeit an und sagt, sie könnten den Vertrag auch nur schriftlich abfassen und sich die Notargebühren sparen, und durch die Auflassung würde ohnehin Heilung eintreten. Er, A, sei schließlich ein Edelmann, ein Ehrenmann. Das Versprechen eines Edelmannes sei Gesetz. So geschieht es auch, und B möchte nun die Auflassung des Grundstücks von A. A beruft sich jedoch auf die Formunwirksamkeit. Nun liegt eine Einigung vor, die wegen Formunwirksamkeit unwirksam sein könnte. Es liegt wiederum ein Verstoß gegen § 311 I 1 BGB vor. Eine Heilung ist auch nicht eingetreten. Das Pochen auf die Formunwirksamkeit könnte jedoch gegen Treu und Glauben verstoßen, da A insbesondere versprochen hatte, sein Wort zu halten. Allerdings wurde in diesem Fall nicht über die Formbedürftigkeit getäuscht. Vielmehr wusste B, dass es der Form des § 311b I 1 BGB bedurfte. In diesem Fall gilt: Wer sein Vertrauen beim Edelmann lässt, der soll auch dort sein Recht finden. Man kann nicht darauf vertrauen, dass die Rechtsordnung über den Grundsatz von Treu und Glauben interveniert, um die Wirksamkeit herzustellen. Dies gilt erst recht, wenn die Parteien auf die Form verzichten, um Notarkosten zu sparen.
II. § 125 S. 2 BGB
Die Formunwirksamkeit gemäß § 125 S. 2 BGB sieht hingegen einen Verstoß gegen eine vertraglich vereinbarte Form vor. Nach Satz 2 der Norm ist das Rechtsgeschäft bei Verstoß gegen die vereinbarte Form im Zweifel nichtig, liegt also eine Formunwirksamkeit vor. Es ist somit durch Auslegung zu ermitteln, ob der Verstoß gegen die vertraglich vereinbarte Form zur Nichtigkeit, also zur Formunwirksamkeit führen soll. Beispiel: A und B schließen einen Vertrag und vereinbaren, dass sämtliche weitere Vereinbarungen, welche dieses Rechtsgeschäft betreffen, der Schriftform bedürfen. Danach schließen A und B mündlich eine Vereinbarung. Diese kann wegen der rechtsgeschäftlich beschlossenen Formbedürftigkeit nichtig sein. Sie kann aber auch für den Fall wirksam sein, dass A und B mit der mündlichen Vereinbarung zugleich eine Vereinbarung darüber getroffen haben, dass die frühere Vereinbarung mit dem Schriftlichkeitserfordernis außer Kraft gesetzt werden soll
!![[Fakten]]
Abraham : mann.
Penelope : frau
Homer : mann[vater->abraham, mutter->penelope].
Bart : mann[vater->homer, mutter->marge : frau].
Lisa : frau[vater->homer, mutter->marge].
Maggie : frau[vater->homer, mutter->marge].
!![[Regeln]]
X[sohn->{Y}] :-Y : mann, Y[vater->X].
X[sohn->{Y}] :-Y : mann, Y[mutter->X].
X[tochter->{Y}] :-Y : frau, Y[vater->X].
X[tochter->{Y}] :-Y : frau, Y[mutter->X].
<<list-links "[parent[Frankfurter Tabelle]sort[title]]">>
Die Frankfurter Richter haben verschiedene Punkte der Tabelle mit ergänzenden Erläuterungen versehen. Wir listen im Folgenden die wichtigsten Hinweise in leicht gekürzter Fassung auf:
Geringfügige Beeinträchtigungen bleiben außer Betracht.
Die Höhe des Prozentsatzes richtet sich danach, wie groß die Beeinträchtigung war. Diese ist in der Regel unabhängig von den Eigenschaften des einzelnen Reisenden (Alter, Geschlecht, besondere Empfindlichkeit).
Der Prozentsatz wird grundsätzlich vom Gesamtreisepreis (also einschließlich Transportkosten) erhoben. Dabei werden die vom Reisenden gezahlten Beiträge für Versicherungen und Zuschläge für erhöhten Flugkomfort abgezogen. Soweit Beeinträchtigungen während der Reisedauer nur zeitweilig auftreten, wird eine Minderung nur auf den entsprechenden Anteil (Tage) zugestanden.
Liegen mehrere Mängel vor, werden die Prozentsätze addiert.
Ist die Reise in ihrer Gesamtheit durch Mängel einzelner Reiseleistungen oder durch Pflichtverletzungen des Reiseveranstalters erheblich beeinträchtigt, können Sie sogar eine Entschädigung für entgangene Urlaubstage verlangen (§ 651f Abs. 2 a. F. BGB für Buchungen bis zum 1. Juli 2018; § 651n Abs. 2 BGB).
Kündigen dürfen Sie Reisevertrags in der Regel nur, wenn Mängel von mindestens 20 Prozent vorliegen (§ 651e Abs. 1 a. F. BGB für Buchungen bis zum 1. Juli 2018, § 651l Abs. 1 BGB). Wenn Sie die Reise mit dieser Begründung abbrechen, ist der Veranstalter unter anderem verpflichtet, Sie auf seine Kosten nach Hause zu bringen. Er hat keinen Anspruch mehr darauf, dass Sie ihm Reiseleistungen bezahlen – auch nicht die, die er erbracht hat, bevor Sie den Reisevertrag gekündigt haben.
I Die Vorschriften dieses Abschnitts gelten nicht
1 in Betrieben einer juristischen Person für die Mitglieder des Organs, das zur gesetzlichen Vertretung der juristischen Person berufen ist,
2 in Betrieben einer Personengesamtheit für die durch Gesetz, Satzung oder Gesellschaftsvertrag xxxzur Vertretung der Personengesamtheit berufenen Personenxxx .
II Auf xxxGeschäftsführer, Betriebsleiter und ähnliche leitende Angestelltexxx, soweit diese zur selbständigen Einstellung oder Entlassung von Arbeitnehmern berechtigt sind, finden die Vorschriften dieses Abschnitts mit Ausnahme des § 3 Anwendung. § 9 Abs. 1 Satz 2 findet mit der Maßgabe Anwendung, daß der Antrag des Arbeitgebers auf Auflösung des Arbeitsverhältnisses keiner Begründung bedarf.
!Demo
See the [[ftlist demo]] for live examples which illustrate most of the functionality. Or play with this list right here:
<<<
{{||$:/plugins/btheado/ftlist/main}}
<<<
{{$:/plugins/btheado/ftlist/readme}}
<<list-links filter:"[tag[Gegenstandswert]]">>
<span style="border:1px solid silver; padding-right:2em; display:block;">
*This demos ''three different methods'' for displaying the paragraph tiddlers (see [[Use|Use + Install]] for info)
*{{ToggleTiddlerTitles}}
</span>
...so, this is tiddler [[GenericArticle]].
[[GenericArticle]] has a field ''paragraphs: {{!!paragraphs}}''
Fähigkeit, Rechtsgeschäfte vorzunehmen
=> Tritt mit Erreichen des 18. Lebensjahres ein.
Vor Erreichen der Volljährigkeit besteht entweder eine beschränkte Geschäftsfähigkeit
(§ 106) oder eine Geschäftsunfähigkeit (§ 104) =>
<<mt-slider-input>>
<<mt-tab-contents>>
Im Hinblick auf den notwendigen Inhalt von Überlassungsverträgen enthält das AÜG nur geringe Vorgaben.
Insbesondere sind die vertraglichen Hauptpflichten von Verleiher und Entleiher nicht näher spezifiziert.
Im Regelfall wird die Basis-Pflicht im Vertrag selbst nur allgemein umschrieben und die nähere Spezifizierung der zu überlassenden Arbeitnehmer als Anlage beigefügt. Eine entsprechende allgemeine Überlassungsklausel könnte wie folgt formuliert werden:
//Der Verleiher verpflichtet sich, dem Entleiher die in der Anlage x aufgeführten Arbeitnehmer zur Arbeitsleistung in dessen Betrieb vorübergehend zu überlassen. In Anlage x sind die Tätigkeiten, welche die zu überlassenden Arbeitnehmer beim Entleiher ausüben sollen, und Informationen enthalten, welche besonderen Merkmale die für die Arbeitnehmer vorgesehene Tätigkeit hat und welche beruflichen Qualifikationen dafür erforderlich sind. Der Verleiher tritt dem Entleiher seine Ansprüche auf Arbeitsleistung gegen die überlassenen Arbeitnehmer mit deren Einverständnis ab. Zwischen Entleiher und überlassenem Arbeitnehmer entsteht durch die Überlassung kein Arbeitsverhältnis.//
* [[Pandektensystem]]
* [[Institutionensystem]]
* [[Sonderprivatrecht]]
* [[IPR]]
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
größere Beträge auf angemessenen Zeitraum zu
verteilen
I. Die Grundrechte
Artikel 1
(1) Die Würde des Menschen ist unantastbar. Sie zu achten und zu schützen ist Verpflichtung aller staatlichen Gewalt.
(2) Das Deutsche Volk bekennt sich darum zu unverletzlichen und unveräußerlichen Menschenrechten als Grundlage jeder menschlichen Gemeinschaft, des Friedens und der Gerechtigkeit in der Welt.
(3) Die nachfolgenden Grundrechte binden Gesetzgebung, vollziehende Gewalt und Rechtsprechung als unmittelbar geltendes Recht.
Artikel 2
(1) Jeder hat das Recht auf die freie Entfaltung seiner Persönlichkeit, soweit er nicht die Rechte anderer verletzt und nicht gegen die verfassungsmäßige Ordnung oder das Sittengesetz verstößt.
(2) Jeder hat das Recht auf Leben und körperliche Unversehrtheit. Die Freiheit der Person ist unverletzlich. In diese Rechte darf nur auf Grund eines Gesetzes eingegriffen werden.
Artikel 3
(1) Alle Menschen sind vor dem Gesetz gleich.
(2) Männer und Frauen sind gleichberechtigt. Der Staat fördert die tatsächliche Durchsetzung der Gleichberechtigung von Frauen und Männern und wirkt auf die Beseitigung bestehender Nachteile hin.
(3) Niemand darf wegen seines Geschlechtes, seiner Abstammung, seiner Rasse, seiner Sprache, seiner Heimat und Herkunft, seines Glaubens, seiner religiösen oder politischen Anschauungen benachteiligt oder bevorzugt werden. Niemand darf wegen seiner Behinderung benachteiligt werden.
Artikel 4
(1) Die Freiheit des Glaubens, des Gewissens und die Freiheit des religiösen und weltanschaulichen Bekenntnisses sind unverletzlich.
(2) Die ungestörte Religionsausübung wird gewährleistet.
(3) Niemand darf gegen sein Gewissen zum Kriegsdienst mit der Waffe gezwungen werden. Das Nähere regelt ein Bundesgesetz.
Artikel 5
(1) Jeder hat das Recht, seine Meinung in Wort, Schrift und Bild frei zu äußern und zu verbreiten und sich aus allgemein zugänglichen Quellen ungehindert zu unterrichten. Die Pressefreiheit und die Freiheit der Berichterstattung durch Rundfunk und Film werden gewährleistet. Eine Zensur findet nicht statt.
(2) Diese Rechte finden ihre Schranken in den Vorschriften der allgemeinen Gesetze, den gesetzlichen Bestimmungen zum Schutze der Jugend und in dem Recht der persönlichen Ehre.
(3) Kunst und Wissenschaft, Forschung und Lehre sind frei. Die Freiheit der Lehre entbindet nicht von der Treue zur Verfassung.
Artikel 6
(1) Ehe und Familie stehen unter dem besonderen Schutze der staatlichen Ordnung.
(2) Pflege und Erziehung der Kinder sind das natürliche Recht der Eltern und die zuvörderst ihnen obliegende Pflicht. Über ihre Betätigung wacht die staatliche Gemeinschaft.
(3) Gegen den Willen der Erziehungsberechtigten dürfen Kinder nur auf Grund eines Gesetzes von der Familie getrennt werden, wenn die Erziehungsberechtigten versagen oder wenn die Kinder aus anderen Gründen zu verwahrlosen drohen.
(4) Jede Mutter hat Anspruch auf den Schutz und die Fürsorge der Gemeinschaft.
(5) Den unehelichen Kindern sind durch die Gesetzgebung die gleichen Bedingungen für ihre leibliche und seelische Entwicklung und ihre Stellung in der Gesellschaft zu schaffen wie den ehelichen Kindern.
Artikel 7
(1) Das gesamte Schulwesen steht unter der Aufsicht des Staates.
(2) Die Erziehungsberechtigten haben das Recht, über die Teilnahme des Kindes am Religionsunterricht zu bestimmen.
(3) Der Religionsunterricht ist in den öffentlichen Schulen mit Ausnahme der bekenntnisfreien Schulen ordentliches Lehrfach. Unbeschadet des staatlichen Aufsichtsrechtes wird der Religionsunterricht in Übereinstimmung mit den Grundsätzen der Religionsgemeinschaften erteilt. Kein Lehrer darf gegen seinen Willen verpflichtet werden, Religionsunterricht zu erteilen.
(4) Das Recht zur Errichtung von privaten Schulen wird gewährleistet. Private Schulen als Ersatz für öffentliche Schulen bedürfen der Genehmigung des Staates und unterstehen den Landesgesetzen. Die Genehmigung ist zu erteilen, wenn die privaten Schulen in ihren Lehrzielen und Einrichtungen sowie in der wissenschaftlichen Ausbildung ihrer Lehrkräfte nicht hinter den öffentlichen Schulen zurückstehen und eine Sonderung der Schüler nach den Besitzverhältnissen der Eltern nicht gefördert wird. Die Genehmigung ist zu versagen, wenn die wirtschaftliche und rechtliche Stellung der Lehrkräfte nicht genügend gesichert ist.
(5) Eine private Volksschule ist nur zuzulassen, wenn die Unterrichtsverwaltung ein besonderes pädagogisches Interesse anerkennt oder, auf Antrag von Erziehungsberechtigten, wenn sie als Gemeinschaftsschule, als Bekenntnis- oder Weltanschauungsschule errichtet werden soll und eine öffentliche Volksschule dieser Art in der Gemeinde nicht besteht.
(6) Vorschulen bleiben aufgehoben.
Artikel 8
(1) Alle Deutschen haben das Recht, sich ohne Anmeldung oder Erlaubnis friedlich und ohne Waffen zu versammeln.
(2) Für Versammlungen unter freiem Himmel kann dieses Recht durch Gesetz oder auf Grund eines Gesetzes beschränkt werden.
Artikel 9
(1) Alle Deutschen haben das Recht, Vereine und Gesellschaften zu bilden.
(2) Vereinigungen, deren Zwecke oder deren Tätigkeit den Strafgesetzen zuwiderlaufen oder die sich gegen die verfassungsmäßige Ordnung oder gegen den Gedanken der Völkerverständigung richten, sind verboten.
(3) Das Recht, zur Wahrung und Förderung der Arbeits- und Wirtschaftsbedingungen Vereinigungen zu bilden, ist für jedermann und für alle Berufe gewährleistet. Abreden, die dieses Recht einschränken oder zu behindern suchen, sind nichtig, hierauf gerichtete Maßnahmen sind rechtswidrig. Maßnahmen nach den Artikeln 12a, 35 Abs. 2 und 3, Artikel 87a Abs. 4 und Artikel 91 dürfen sich nicht gegen Arbeitskämpfe richten, die zur Wahrung und Förderung der Arbeits- und Wirtschaftsbedingungen von Vereinigungen im Sinne des Satzes 1 geführt werden.
Artikel 10
(1) Das Briefgeheimnis sowie das Post- und Fernmeldegeheimnis sind unverletzlich.
(2) Beschränkungen dürfen nur auf Grund eines Gesetzes angeordnet werden. Dient die Beschränkung dem Schutze der freiheitlichen demokratischen Grundordnung oder des Bestandes oder der Sicherung des Bundes oder eines Landes, so kann das Gesetz bestimmen, daß sie dem Betroffenen nicht mitgeteilt wird und daß an die Stelle des Rechtsweges die Nachprüfung durch von der Volksvertretung bestellte Organe und Hilfsorgane tritt.
Artikel 11
(1) Alle Deutschen genießen Freizügigkeit im ganzen Bundesgebiet.
(2) Dieses Recht darf nur durch Gesetz oder auf Grund eines Gesetzes und nur für die Fälle eingeschränkt werden, in denen eine ausreichende Lebensgrundlage nicht vorhanden ist und der Allgemeinheit daraus besondere Lasten entstehen würden oder in denen es zur Abwehr einer drohenden Gefahr für den Bestand oder die freiheitliche demokratische Grundordnung des Bundes oder eines Landes, zur Bekämpfung von Seuchengefahr, Naturkatastrophen oder besonders schweren Unglücksfällen, zum Schutze der Jugend vor Verwahrlosung oder um strafbaren Handlungen vorzubeugen, erforderlich ist.
Artikel 12
(1) Alle Deutschen haben das Recht, Beruf, Arbeitsplatz und Ausbildungsstätte frei zu wählen. Die Berufsausübung kann durch Gesetz oder auf Grund eines Gesetzes geregelt werden.
(2) Niemand darf zu einer bestimmten Arbeit gezwungen werden, außer im Rahmen einer herkömmlichen allgemeinen, für alle gleichen öffentlichen Dienstleistungspflicht.
(3) Zwangsarbeit ist nur bei einer gerichtlich angeordneten Freiheitsentziehung zulässig.
Artikel 12a
(1) Männer können vom vollendeten achtzehnten Lebensjahr an zum Dienst in den Streitkräften, im Bundesgrenzschutz oder in einem Zivilschutzverband verpflichtet werden.
(2) Wer aus Gewissensgründen den Kriegsdienst mit der Waffe verweigert, kann zu einem Ersatzdienst verpflichtet werden. Die Dauer des Ersatzdienstes darf die Dauer des Wehrdienstes nicht übersteigen. Das Nähere regelt ein Gesetz, das die Freiheit der Gewissensentscheidung nicht beeinträchtigen darf und auch eine Möglichkeit des Ersatzdienstes vorsehen muß, die in keinem Zusammenhang mit den Verbänden der Streitkräfte und des Bundesgrenzschutzes steht.
(3) Wehrpflichtige, die nicht zu einem Dienst nach Absatz 1 oder 2 herangezogen sind, können im Verteidigungsfalle durch Gesetz oder auf Grund eines Gesetzes zu zivilen Dienstleistungen für Zwecke der Verteidigung einschließlich des Schutzes der Zivilbevölkerung in Arbeitsverhältnisse verpflichtet werden; Verpflichtungen in öffentlich-rechtliche Dienstverhältnisse sind nur zur Wahrnehmung polizeilicher Aufgaben oder solcher hoheitlichen Aufgaben der öffentlichen Verwaltung, die nur in einem öffentlich-rechtlichen Dienstverhältnis erfüllt werden können, zulässig. Arbeitsverhältnisse nach Satz 1 können bei den Streitkräften, im Bereich ihrer Versorgung sowie bei der öffentlichen Verwaltung begründet werden; Verpflichtungen in Arbeitsverhältnisse im Bereiche der Versorgung der Zivilbevölkerung sind nur zulässig, um ihren lebensnotwendigen Bedarf zu decken oder ihren Schutz sicherzustellen.
(4) Kann im Verteidigungsfalle der Bedarf an zivilen Dienstleistungen im zivilen Sanitäts- und Heilwesen sowie in der ortsfesten militärischen Lazarettorganisation nicht auf freiwilliger Grundlage gedeckt werden, so können Frauen vom vollendeten achtzehnten bis zum vollendeten fünfundfünfzigsten Lebensjahr durch Gesetz oder auf Grund eines Gesetzes zu derartigen Dienstleistungen herangezogen werden. Sie dürfen auf keinen Fall zum Dienst mit der Waffe verpflichtet werden.
(5) Für die Zeit vor dem Verteidigungsfalle können Verpflichtungen nach Absatz 3 nur nach Maßgabe des Artikels 80a Abs. 1 begründet werden. Zur Vorbereitung auf Dienstleistungen nach Absatz 3, für die besondere Kenntnisse oder Fertigkeiten erforderlich sind, kann durch Gesetz oder auf Grund eines Gesetzes die Teilnahme an Ausbildungsveranstaltungen zur Pflicht gemacht werden. Satz 1 findet insoweit keine Anwendung.
(6) Kann im Verteidigungsfalle der Bedarf an Arbeitskräften für die in Absatz 3 Satz 2 genannten Bereiche auf freiwilliger Grundlage nicht gedeckt werden, so kann zur Sicherung dieses Bedarfs die Freiheit der Deutschen, die Ausübung eines Berufs oder den Arbeitsplatz aufzugeben, durch Gesetz oder auf Grund eines Gesetzes eingeschränkt werden. Vor Eintritt des Verteidigungsfalles gilt Absatz 5 Satz 1 entsprechend.
Artikel 13
(1) Die Wohnung ist unverletzlich.
(2) Durchsuchungen dürfen nur durch den Richter, bei Gefahr im Verzuge auch durch die in den Gesetzen vorgesehenen anderen Organe angeordnet und nur in der dort vorgeschriebenen Form durchgeführt werden.
(3) Begründen bestimmte Tatsachen den Verdacht, daß jemand eine durch Gesetz einzeln bestimmte besonders schwere Straftat begangen hat, so dürfen zur Verfolgung der Tat auf Grund richterlicher Anordnung technische Mittel zur akustischen Überwachung von Wohnungen, in denen der Beschuldigte sich vermutlich aufhält, eingesetzt werden, wenn die Erforschung des Sachverhalts auf andere Weise unverhältnismäßig erschwert oder aussichtslos wäre. Die Maßnahme ist zu befristen. Die Anordnung erfolgt durch einen mit drei Richtern besetzten Spruchkörper. Bei Gefahr im Verzuge kann sie auch durch einen einzelnen Richter getroffen werden.
(4) Zur Abwehr dringender Gefahren für die öffentliche Sicherheit, insbesondere einer gemeinen Gefahr oder einer Lebensgefahr, dürfen technische Mittel zur Überwachung von Wohnungen nur auf Grund richterlicher Anordnung eingesetzt werden. Bei Gefahr im Verzuge kann die Maßnahme auch durch eine andere gesetzlich bestimmte Stelle angeordnet werden; eine richterliche Entscheidung ist unverzüglich nachzuholen.
(5) Sind technische Mittel ausschließlich zum Schutze der bei einem Einsatz in Wohnungen tätigen Personen vorgesehen, kann die Maßnahme durch eine gesetzlich bestimmte Stelle angeordnet werden. Eine anderweitige Verwertung der hierbei erlangten Erkenntnisse ist nur zum Zwecke der Strafverfolgung oder der Gefahrenabwehr und nur zulässig, wenn zuvor die Rechtmäßigkeit der Maßnahme richterlich festgestellt ist; bei Gefahr im Verzuge ist die richterliche Entscheidung unverzüglich nachzuholen.
(6) Die Bundesregierung unterrichtet den Bundestag jährlich über den nach Absatz 3 sowie über den im Zuständigkeitsbereich des Bundes nach Absatz 4 und, soweit richterlich überprüfungsbedürftig, nach Absatz 5 erfolgten Einsatz technischer Mittel. Ein vom Bundestag gewähltes Gremium übt auf der Grundlage dieses Berichts die parlamentarische Kontrolle aus. Die Länder gewährleisten eine gleichwertige parlamentarische Kontrolle.
(7) Eingriffe und Beschränkungen dürfen im übrigen nur zur Abwehr einer gemeinen Gefahr oder einer Lebensgefahr für einzelne Personen, auf Grund eines Gesetzes auch zur Verhütung dringender Gefahren für die öffentliche Sicherheit und Ordnung, insbesondere zur Behebung der Raumnot, zur Bekämpfung von Seuchengefahr oder zum Schutze gefährdeter Jugendlicher vorgenommen werden.
Artikel 14
(1) Das Eigentum und das Erbrecht werden gewährleistet. Inhalt und Schranken werden durch die Gesetze bestimmt.
(2) Eigentum verpflichtet. Sein Gebrauch soll zugleich dem Wohle der Allgemeinheit dienen.
(3) Eine Enteignung ist nur zum Wohle der Allgemeinheit zulässig. Sie darf nur durch Gesetz oder auf Grund eines Gesetzes erfolgen, das Art und Ausmaß der Entschädigung regelt. Die Entschädigung ist unter gerechter Abwägung der Interessen der Allgemeinheit und der Beteiligten zu bestimmen. Wegen der Höhe der Entschädigung steht im Streitfalle der Rechtsweg vor den ordentlichen Gerichten offen.
Artikel 15
Grund und Boden, Naturschätze und Produktionsmittel können zum Zwecke der Vergesellschaftung durch ein Gesetz, das Art und Ausmaß der Entschädigung regelt, in Gemeineigentum oder in andere Formen der Gemeinwirtschaft überführt werden. Für die Entschädigung gilt Artikel 14 Abs. 3 Satz 3 und 4 entsprechend.
Artikel 16
(1) Die deutsche Staatsangehörigkeit darf nicht entzogen werden. Der Verlust der Staatsangehörigkeit darf nur auf Grund eines Gesetzes und gegen den Willen des Betroffenen nur dann eintreten, wenn der Betroffene dadurch nicht staatenlos wird.
(2) Kein Deutscher darf an das Ausland ausgeliefert werden. Durch Gesetz kann eine abweichende Regelung für Auslieferungen an einen Mitgliedstaat der Europäischen Union oder an einen internationalen Gerichtshof getroffen werden, soweit rechtsstaatliche Grundsätze gewahrt sind.
Artikel 16a
(1) Politisch Verfolgte genießen Asylrecht.
(2) Auf Absatz 1 kann sich nicht berufen, wer aus einem Mitgliedstaat der Europäischen Gemeinschaften oder aus einem anderen Drittstaat einreist, in dem die Anwendung des Abkommens über die Rechtsstellung der Flüchtlinge und der Konvention zum Schutze der Menschenrechte und Grundfreiheiten sichergestellt ist. Die Staaten außerhalb der Europäischen Gemeinschaften, auf die die Voraussetzungen des Satzes 1 zutreffen, werden durch Gesetz, das der Zustimmung des Bundesrates bedarf, bestimmt. In den Fällen des Satzes 1 können aufenthaltsbeendende Maßnahmen unabhängig von einem hiergegen eingelegten Rechtsbehelf vollzogen werden.
(3) Durch Gesetz, das der Zustimmung des Bundesrates bedarf, können Staaten bestimmt werden, bei denen auf Grund der Rechtslage, der Rechtsanwendung und der allgemeinen politischen Verhältnisse gewährleistet erscheint, daß dort weder politische Verfolgung noch unmenschliche oder erniedrigende Bestrafung oder Behandlung stattfindet. Es wird vermutet, daß ein Ausländer aus einem solchen Staat nicht verfolgt wird, solange er nicht Tatsachen vorträgt, die die Annahme begründen, daß er entgegen dieser Vermutung politisch verfolgt wird.
(4) Die Vollziehung aufenthaltsbeendender Maßnahmen wird in den Fällen des Absatzes 3 und in anderen Fällen, die offensichtlich unbegründet sind oder als offensichtlich unbegründet gelten, durch das Gericht nur ausgesetzt, wenn ernstliche Zweifel an der Rechtmäßigkeit der Maßnahme bestehen; der Prüfungsumfang kann eingeschränkt werden und verspätetes Vorbringen unberücksichtigt bleiben. Das Nähere ist durch Gesetz zu bestimmen.
(5) Die Absätze 1 bis 4 stehen völkerrechtlichen Verträgen von Mitgliedstaaten der Europäischen Gemeinschaften untereinander und mit dritten Staaten nicht entgegen, die unter Beachtung der Verpflichtungen aus dem Abkommen über die Rechtsstellung der Flüchtlinge und der Konvention zum Schutze der Menschenrechte und Grundfreiheiten, deren Anwendung in den Vertragsstaaten sichergestellt sein muß, Zuständigkeitsregelungen für die Prüfung von Asylbegehren einschließlich der gegenseitigen Anerkennung von Asylentscheidungen treffen.
Artikel 17
Jedermann hat das Recht, sich einzeln oder in Gemeinschaft mit anderen schriftlich mit Bitten oder Beschwerden an die zuständigen Stellen und an die Volksvertretung zu wenden.
Artikel 17a
(1) Gesetze über Wehrdienst und Ersatzdienst können bestimmen, daß für die Angehörigen der Streitkräfte und des Ersatzdienstes während der Zeit des Wehr- oder Ersatzdienstes das Grundrecht, seine Meinung in Wort, Schrift und Bild frei zu äußern und zu verbreiten (Artikel 5 Abs. 1 Satz 1 erster Halbsatz), das Grundrecht der Versammlungsfreiheit (Artikel 8) und das Petitionsrecht (Artikel 17), soweit es das Recht gewährt, Bitten oder Beschwerden in Gemeinschaft mit anderen vorzubringen, eingeschränkt werden.
(2) Gesetze, die der Verteidigung einschließlich des Schutzes der Zivilbevölkerung dienen, können bestimmen, daß die Grundrechte der Freizügigkeit (Artikel 11) und der Unverletzlichkeit der Wohnung (Artikel 13) eingeschränkt werden.
Artikel 18
Wer die Freiheit der Meinungsäußerung, insbesondere die Pressefreiheit (Artikel 5 Abs. 1), die Lehrfreiheit (Artikel 5 Abs. 3), die Versammlungsfreiheit (Artikel 8), die Vereinigungsfreiheit (Artikel 9), das Brief-, Post- und Fernmeldegeheimnis (Artikel 10), das Eigentum (Artikel 14) oder das Asylrecht (Artikel 16a) zum Kampfe gegen die freiheitliche demokratische Grundordnung mißbraucht, verwirkt diese Grundrechte. Die Verwirkung und ihr Ausmaß werden durch das Bundesverfassungsgericht ausgesprochen.
Artikel 19
(1) Soweit nach diesem Grundgesetz ein Grundrecht durch Gesetz oder auf Grund eines Gesetzes eingeschränkt werden kann, muß das Gesetz allgemein und nicht nur für den Einzelfall gelten. Außerdem muß das Gesetz das Grundrecht unter Angabe des Artikels nennen.
(2) In keinem Falle darf ein Grundrecht in seinem Wesensgehalt angetastet werden.
(3) Die Grundrechte gelten auch für inländische juristische Personen, soweit sie ihrem Wesen nach auf diese anwendbar sind.
(4) Wird jemand durch die öffentliche Gewalt in seinen Rechten verletzt, so steht ihm der Rechtsweg offen. Soweit eine andere Zuständigkeit nicht begründet ist, ist der ordentliche Rechtsweg gegeben. Artikel 10 Abs. 2 Satz 2 bleibt unberührt.
I) Schutzbereich
1) Begriff
a) Definition
b) Streit
c) Konkurrenzen
2) persönliche Einschränkungen
a) Deutsche
b) Jur. Pers
c) Jur. Pers. des ö.R.
3) sachliche Einschränkungen
II) Eingriff
1) Benennen des Eingriffsakts
2) Wesentlichkeit
3) funktionaler Schutzbereich
III) Schranke
1) formelle Verfassungsmäßigkeit
a) Gesetzgebungskompetenz
b) Gesetzgebungsverfahren
c) eventuell 19 I GG
2) materielle Verfassungsmäßigkeit im übrigen (Bestimmtheit, Willkür usw.)
3) Subsumtion unter Schranke
(etwa Begriff "allgemeines Gesetz")
IV) Schranken - Schranke
1) Begründung der Wechselwirkung
2) Gesetz im Lichte des Grundrechts
a) Verhältnismäßigkeit
b) Wesensgehalt
3) Anwendung im Lichte des Grundrechts
a) Verhältnismäßigkeit
b) Wesensgehalt
A Complete Guide to Tagging for Personal Knowledge Management
Posted by Tiago Forte | Jan 9, 2019 | Building a Second Brain, Design & Culture, Free, How-To Guides |
Personal Knowledge Management (PKM) is the practice of capturing the ideas and insights we encounter in our daily life, whether from personal experience, from books and articles, or from our work, and cultivating them over time to produce more creative, higher quality work. I teach people how to master PKM in my online course Building a Second Brain.
By collecting our knowledge in a centralized place outside of our own heads, we can create an engine of creative output – a “second brain” – to advance a career, build a business, or pursue a passion. By making this knowledge digital, we can reap the benefits of searchability, backups, syncing between devices, sharing with others, and more.
But there’s one aspect of personal knowledge management I haven’t fully addressed, which is tags. In the past, I criticized tags harshly as being too taxing, overly complicated, and low value for the effort required. I advised people not to use tags to manage their knowledge, favoring notebooks or folders instead.
But I’ve changed my mind since then. Over several years of observations, findings, and experiments, I’ve come to believe that tags could be the missing link in making our knowledge collections truly adaptable – able to reorient and reconfigure themselves on the fly to enable any goal we wish to pursue.
Let me tell you what I believe is required to unlock the immense potential of tagging for personal knowledge management.
Hierarchies vs. networks
There are two kinds of basic structures that permeate reality: hierarchies and networks.
We currently live in a “network age,” as the internet and digital technology have given people the ability to connect and collaborate directly with each other across the world. Organizational charts are flattening, social movements rise and fall without central direction, and borders of all kinds are becoming more porous as the internet flows across them.
Our infatuation with networks has led to a widely held belief that the era of hierarchies is over. That we now live in a golden age of individual self-expression and autonomy, uniquely enabled by networks. In this view, hierarchies are inherently restrictive, oppressive tools of control that we should abolish whenever possible, and networks are inherently open, democratic tools of personal liberation.
The history of information revolutions tells quite a different story. Networked information is not an exclusively modern invention, and hierarchies are not necessarily doomed. The tension and the balance between them has existed for millennia. Today we’re witnessing only the latest chapter in this history.
Definitions
But first, let’s settle on definitions.
A hierarchy is a system of nested groups. A standard organizational chart is a hierarchy, with employees grouped into business units and departments reporting to a centralized authority. Other kinds of hierarchies include government bureaucracies, biological taxonomies, and a system of menus in a software program. Hierarchies are inherently “top-down,” in that they are designed to enable centralized control from a single, privileged position.
A network, by contrast, has no “correct” orientation, and thus no bottom and no top. Each individual, or “node,” in a network functions autonomously, negotiating its own relationships and coalescing into groups. Examples of networks include a flock of birds, the World Wide Web, and the social ties in a neighborhood. Networks are inherently “bottom-up,” in that the structure emerges organically from small interactions without direction from a central authority.
These two structures are not mutually exclusive – in fact, they coexist everywhere. A company might have a formal organizational chart that is hierarchical, but at the same time, it is permeated by a network of “influence relationships” between employees that don’t respect official boundaries.
There is a network in the hierarchy.
Even the internet, the most prototypical example of a pure network, requires hierarchies to function. The servers that send us data are organized hierarchically, as are the packets of data they send. The web browsers that allow us to view webpages are designed hierarchically, as are the menus we navigate to find what we’re looking for.
There is a hierarchy in the network.
Hierarchies and networks are constantly giving rise to each other
Not only do networks and hierarchies peacefully coexist, they are constantly giving rise to each other. They are like symbiotic organisms, each one balancing and complementing the other.
One theory of the origins of life on Earth envisions the first multicellular life forms as self-organizing networks of simpler, single-cell organisms. First coming together to exchange byproducts and for mutual protection, over time a hierarchy emerged: a complex nervous system. These complex organisms in turn coalesced into even higher-order social networks, which provided even more survival benefits.
The online encyclopedia Wikipedia has long been praised for its crowdsourced, populist approach to gathering knowledge. But in recent years, Wikipedia’s rapid growth has forced it to develop a series of hierarchical control systems, such as a governance body and approval process. Networks can self-organize and spawn novel ideas and connections, but a hierarchy is required to give it form and structure to survive in the long term.
As John Seely Brown and Paul Duguid write in The Social Life of Information, “While it’s clear that self-organization is extraordinarily productive, so too is formal organization. Indeed, the two perform an intricate (and dynamic) balancing act, each compensating for the other’s failings. Self-organization overcomes formal organizing’s rigidity. Formal organization keeps at bay self-organization’s tendency to self-destruct.”
Hierarchies are effective for large-scale, slow-moving efforts in relatively predictable environments. They enable centralized direction and tight synchronization between many moving parts. In times of command and control warfare, mass producing a standardized product, or managing a vast bureaucracy, only a hierarchy will work.
Networks are good in small-scale, quickly changing situations in unpredictable environments. They favor adaptability, flexibility, and individual autonomy. In times of guerrilla warfare, revolutionary innovation, or open-ended creativity, networks are indispensable.
Hierarchies and networks balance each other
Throughout history, every time we reach the limits of one form, the other emerges as a counter-balance.
Francis Bacon’s scientific method, first introduced in the 17th century, was a bottom-up, networked approach to building scientific understanding. Scientists were expected to reach their own conclusions and then verify each others’ work directly through scholarly networks. This approach contrasted with the tradition of receiving knowledge from hierarchical authorities like the church and state without questioning.
In the 18th century, the encyclopedia movement promoted most famously by Denis Diderot moved in the opposite direction. So much knowledge was being produced from so many sources that people sought a top-down categorization to make sense of it all. Thus the modern encyclopedia was born.
In modern times we face a similar dilemma. The explosion of digital information on the internet has overwhelmed every tool we have for classifying and categorizing it. Only a bottom-up, automated tool is capable of making sense of so much data. Google’s PageRank algorithm made it possible to assign importance and meaning to a webpage not through human judgment, but by analyzing keywords and hyperlinks. It is a bottom-up, algorithmic approach to making meaning out of the network.
Hierarchies are resilient
Despite the popularity of networks in the Information Age, the hierarchy persists as a simple, consistent way to organize knowledge.
Numerous studies (Bergman et al. 2008; Fitchett and Cockburn 2015; Teevan et al. 2004) have found that people strongly prefer to navigate their file systems manually, scanning for the file they’re looking for, as opposed to searching. Manual navigation gives people a concrete structure to navigate, with folders and labels giving them visual feedback and control in incremental steps (Jones and Dumais 1986).
Searching relies on declarative memory – remembering and entering the precise contents of a file – which is a higher-level brain function that consumes a lot of energy. Manual navigation, on the other hand, relies on procedural memory (Barreau 1995) – specifying partial information, recognizing clues and context, and receiving feedback (Teevan et al. 2004; Jones 2013). This kind of memory uses “older” parts of the brain that developed to navigate spatial environments, and thus comes to us more naturally.
In other words, it’s clear that hierarchies aren’t going away, even as our search tools become ever more sophisticated.
But the weakness of hierarchical systems is that knowledge remains siloed from other ideas that could spark interesting connections. Adding a network to our file systems can help us preserve the benefits of hierarchy, while infusing it with cross-connections and associations.
This is the true purpose of tagging in the modern digital age. Not to replace the hierarchy, but to complement it. Tags allow us to create alternative pathways that tunnel through the walls of our siloed folders, while leaving them just as we left them.
The intelligent use of space – tags as virtual spaces
Thinking of tags as “tunnels” through our knowledge connection allows us to make use of our rich understanding of humans’ relationship to physical space. Tunnels have a beginning and an end, a top and a bottom. We are comfortable navigating tunnels.
By adding a label to a collection of related notes, you can more easily think of them as a coherent group. They occupy a “space” in your notes (and in your mind) that makes them easier to examine, connect, share, and refer to. In this way, tags act like real spatial organization, without having to move anything from one place to another.
In his classic paper The Intelligent Use of Space, David Kirsh described three basic ways in which physical space can be utilized:
To simplify perception: such as putting the washed mushrooms on the right of the chopping board and the unwashed ones on the left
To simplify choice: such as laying out cooking ingredients in the order you will need them
To simplify thinking: such as repeatedly reordering the Scrabble pieces so as to prompt new ideas for words
These are the same capabilities that tags provide: they help us to perceive, to choose, and to think about novel groupings of data on the fly. But crucially, to do these things to facilitate action, not just abstract thought.
Tagging notes across different notebooks allows us to perceive cross-disciplinary themes and patterns that defy simple categorization. Tagging all the notes we want to review for a project could make our choices easier, by creating a boundary around the information we’ll consider before taking action. And tagging notes according to which stage of a project they are best suited for can improve our thinking by allowing us to focus on only the most relevant information for the given moment.
In his book Supersizing the Mind, Andy Clark describes “simple labeling” (or tags) as a kind of “augmented reality trick.” With the simple act of assigning labels to things, we invite the brain’s pattern recognition ability to identify their similarities and thereby predict what other items would fit the label too. We are essentially tuning the informational environment of our notes to highlight or suppress the features most relevant to the task at hand. Our mind shapes the environment, and then the environment shapes our mind.
By thinking of tags as virtual spaces that we can create on the fly, we recruit our intuitive sense of spatial navigation to make sense of complex, abstract topics. We are able to create more concrete conceptual structures, and use our procedural memory to navigate them.
The next question is, “What do we want to use these spaces for?”
Information mapping – tagging for the knowledge lifecycle
As useful as it is to think of tags as “virtual spaces,” this still leaves us with overwhelming complexity. Conceptual spaces are vast, ever-changing, and complex. The failure of every attempt throughout history to create a “universal taxonomy” for all human knowledge is a testament to how incredibly difficult (or impossible) this task is.
I believe that what is needed for tagging to fulfill its potential while remaining feasible is to change its function: from labeling the “conceptual meaning” of bits of knowledge (which is labor-intensive, time-consuming, and fragile), to tracking its lifecycle.
What is a “knowledge lifecycle”?
It is the series of stages that knowledge moves through on its way to becoming a finished product. The stages vary based on what exactly that finished product is, but can include:
Identifying knowledge
Capturing knowledge
Verifying knowledge
Interpreting knowledge
Organizing knowledge
Categorizing knowledge
Disseminating knowledge
Combining knowledge
Creating knowledge
Using knowledge
Re-evaluating knowledge
The key feature of these stages is that there are relatively few of them, and they change slowly. The products of creativity are constantly evolving and in flux, but the creative process is ancient and unchanging. By tagging according to the stages of this process, we can facilitate creativity without having to constantly redesign our organizational systems.
This idea is anything but new. In 1969, Robert Horn first published a paper outlining “information mapping” as a new approach to creating technical reference books. It was a system of principles for identifying, categorizing, and interrelating information to make learning easier in complex, information-rich environments. It was first applied to the military and to computer instruction, and has since been applied to dozens of other fields and scenarios.
At the heart of information mapping is a project lifecycle methodology. It assumes that the overarching goal of knowledge collection is to put it to use in real projects. But there is not one fixed, predetermined use. The same chunk of knowledge might be used in different ways at different times. For example:
Initial learning
Relearning or review
Reference
Briefing and browsing
Updating with changes
Using as job aids (preparing checklists, menus, or protocols)
All these activities may use the same bits of knowledge, but in different ways and at different levels of detail. A training manual has to be able to adapt and reorganize itself according to the needs of different kinds of readers, instead of offering a “one size fits all” version. Horn’s solution to this challenge was “information blocks” – organizing knowledge into standardized “chunks” that could be mixed and matched to suit a specific need.
Information blocks replaced paragraphs as the fundamental unit of meaning and presentation. Unstructured information was “clustered” into information blocks with clear labels, which were linked together and further refined in the writing process.
Horn and his collaborators identified 40 types of information blocks that could be categorized as one of seven types:
Procedure
Process
Concept
Structure
Classification
Principle
Fact
These types were standardized across all kinds of topics and projects. Research by Horn and others indicated that about 80% of virtually any subject matter could be classified using this system. It was found that by chunking a body of information in this way early on in a project, there were tremendous benefits at every subsequent stage.
Information mapping was, on the surface, designed to make writers’ jobs easier, specifying standardized ways of gathering and presenting the right information for a given document. But it also made the readers’ job easier. With each information block labeled according to its type and purpose, readers were able to scan a block and quickly understand its content and structure. This allowed them to customize the learning process: they could read from beginning to end if it was their first pass, or go directly to the block most relevant to their needs if they were already familiar with the subject. The labels made it easier to manage the intermediate stages of what they were reading, increasing reader’s confidence in their ability to understand and make use of the text.
Information mapping was an important step toward “Just-in-Time Learning.” Instead of giving readers a massive text and expecting them to hold it all in their mind until some future, unspecified date, information was structured so that it could be retrieved quickly and efficiently just as it was needed.
What can information mapping teach us about tagging? Decades of research in this field have shown that the best use for labels is as an output mechanism, not an input mechanism. Horn’s breakthrough was distinguishing two very different functions of information – learning and reference – and recognizing that we needed to enable flexible, dynamic ways of re-organizing blocks of information to suit these different needs.
By labeling our notes when they are being used, instead of when they are created, we move the work of tagging as close as possible to the problem it is meant to solve. And by making that work conditional on the execution of a project, we ensure that every bit of effort spent in tagging is put to use.
How to use tags effectively for personal knowledge management
Building on that foundation, these are my four recommendations for how to use tags effectively in personal knowledge management.
#1 Tag notes according to the actions taken or deliverables created with them
My first recommendation is to change the function of tags from trying to describe broad themes like “psychology” and “investing” to tracking the use or function of a piece of information. This could include tagging the note:
By action – What actions have you taken (or will you take) with this note?
By deliverable – What have you used (or will you use) this note to deliver?
By stage of your knowledge lifecycle – Which stage is this note currently in (or does it best belong to)?
Tags should answer the question “Is this relevant to my current need?” just enough to make the next action clear. Don’t let your ideas get bogged down in layers of categories and classifications. Speed them through your creative process and out into the real world.
Here are a few examples of tags that have been applied according to the use or function of a chunk of knowledge:
Tags for [reviewed] and [added], for tracking which notes have been reviewed for a deliverable, and which have been incorporated into it
Tags that designate the kind of information a note contains, such as [content], [admin], and [meeting notes]
Tags that track the status of notes through a workflow, such as [inactive], [active], [next], and [completed]
Here is an example of notes collected over the course of a year related to my online course Building a Second Brain. In the right-hand column you can see a few different kinds of tags that I use to segment this stream of notes into distinct types:
[reviewed] means that I’ve looked it over and considered it for use in the course; [added] means I’ve incorporated it into the course in some way
[admin] designates notes that don’t contain subject matter content, but are used for planning or technical information
[PARA,] [PS], and [JITPM] refer to the three main parts of the course, allowing me to only consider notes for one at a time
[basb] designates notes that I’d like to consider for the book I’m writing on the same topic; this allows me to “extract” a subset of notes for a different project, without removing them from this notebook
Notice that these tags don’t tell me what each note contains, or try to label them with every possible association. All they do is facilitate their incorporation into a concrete project, which is my online course. Because there are so few tags needed, I can use a few different kinds of tags at once without cluttering the notebook.
I can perform a search for one of these tags, and click this button to show only results from this notebook:
I am shown only notes with the [admin] tag within this notebook:
This use of tags is reminiscent of the “kanban” cards in Toyota’s just-in-time manufacturing system. Instead of long, complex forms detailing every part in a bin, a simple card reveals at a glance the most important things: what it is and where it goes.
Why did Toyota create such a system of cards? Why couldn’t each part simply be placed on the assembly line in the correct order?
In post-war Japan, there were not enough factories and not enough demand to justify dedicating an entire line to one model of car, as was done in the U.S. with Ford’s Model T. The small batches of different kinds of cars that the market demanded required them to create networks of production, with different lines overlapping and sharing the same machines. One of the uses of kanban cards was to track an item through the factory regardless of which machines it passed through, in what order, and at what speed. Each item was “tagged” with its current state, so there was never any doubt as to how it should be handled
This is much the same situation we face today as knowledge workers. We rarely have enough demand for a single activity to dedicate ourselves solely to it, but instead work on an ever-changing mix of different projects and activities that wax and wane unpredictably. And these activities use the same scarce resources – our intellect, time, energy, and skills.
We should use tags in the same way that Toyota used kanban cards: to create intertwined networks in which the right “part” (or note) can be pulled from our “inventory” (or knowledge collection) at just the right moment. I should be able to capture a note today while reading a book on financial planning, and know that it will show up when I need an insight into that subject, whether that is next week, next month, or next year. The tags should remember exactly where I left off, so I don’t have to.
With tags, we have the opportunity to network our knowledge. But these networks shouldn’t be merely conceptual. They should be networks of production, pushing our ideas through our creative process and into the hands of people who can benefit from them.
This approach to tagging addresses each of the pitfalls of tagging I identified in Tagging is Broken:
Tags should be easy to remember: since there is a limited number of actions you take with your notes, you have only a small number of options to remember
Tags should be easy to decide on: it is usually easier to decide how a note is going to be used, rather than what it means or what it’s about
Tags should be concrete: tagging according to actions and deliverables is far more concrete than theoretical categories
Tags should enable the right behaviors: in this case, using tags to manage the stages of a workflow enables the productive use of knowledge, instead of mere cataloguing
Tags should be forgiving: by maintaining tags as a supplement to a hierarchical organizational system, we reap most of their benefits without having to adhere to them perfectly
#2 Add structure slowly, in stages and only as needed, using accumulated material to guide you in what structures are needed
It is very tempting when organizing knowledge to decide on one kind of structure upfront, and then stick to it no matter what. Although there are benefits to consistency, when it comes to personal knowledge management, the most important priority is that it suits your day to day needs. Even the perfect organizational system, if you stop using it, is not perfect.
One of the most valuable features of digital information is that it is highly malleable. It can change form almost instantaneously, with nothing more than a few clicks or taps. We can take advantage of this malleability by adding structure incrementally, in small steps, as our knowledge of a subject accumulates and our needs change.
For example, if I become interested in learning Spanish for a vacation, I might save some useful Spanish words I learn to my “Travel” notebook. No structure is needed at this point, because everything I know about the topic is contained in one note.
But let’s say that I have such a good trip, I decide I want to explore the possibility of moving to Mexico. I start collecting notes with travel gear, blog posts explaining how to rent an apartment, options for cell phone plans, visa application forms, and guides on which credit cards to apply for, among other things. That original “Spanish vocab” note is now just one among many notes. The usage of that knowledge has changed. At this point, it makes sense to create a new notebook called “Move to Mexico” (a “project” according to my PARA methodology) and move these notes into it.
After a few months of research, I may have gathered several dozen notes, and the notebook might be starting to get too cluttered to find what I’m looking for. At this point I can easily “segment” the notebook by tagging notes according to broad types like [apartment], [language], [logistics], [financial], [gear], [research], [writing], etc. I suggest using a small number of types so you can see your options at a glance just by looking at the Tags column.
Clicking the “Tags” header at the top of the right-hand column will sort the notes according to type, which allows you to see related notes in one place while keeping them in the same notebook:
Let’s say a few months pass, and now I’m actually living and working in Mexico City. At this point, a single notebook no longer covers the many facets of life in a new city. I’ll need to create several new notebooks, including projects like “Find gym” and “Activate cell phone service,” areas of responsibility such as “Apartment,” and resources like “Mexican food” and “Spanish language.”
It wouldn’t make sense to have created all these notebooks upfront, when I had so little to store in them. It is effortless, once the relevant categories have revealed themselves, to move notes into these new notebooks (right click > Move notes to…):
With this approach, I’m only adding as much structure as is needed for a given stage of my learning journey. This helps ensure that I’m spending most of my time engaging with the content, instead of maintaining a complex organizational system. You would think that adding the structure later is more difficult, but in fact it is easier: instead of trying to guess which categories will be needed, I can look at what I’ve already collected and pick the categories that perfectly suit it.
How do you know which divisions or categories to use? Again, instead of trying to guess that upfront, start with the laziest approach: simply collect whatever seems interesting on a given topic. When the time comes, and only when the time comes, look at what you’ve already captured organically and look for patterns. The best time to do this is when starting a project that might draw on these notes, because often the divisions will come from the project itself.
For example, let’s say you’re hired by a company to improve their hiring process. You might have dozens or even hundreds of notes related to hiring if that is a service you provide. But the way the project is organized will often tell you what parts or stages are most relevant. Perhaps the contract is split between “Résumé collection” and “Interviewing.” By reviewing your notes retrospectively and tagging them with these two labels, you can very quickly re-orient your notes related to hiring along these lines. Using an organizational scheme that matches the structure of the project will make that project much easier to execute.
I’m constantly surprised at how clearly divisions appear, as long as I’m starting with a batch of real notes. If I try to theorize about the correct tags before I’ve actually collected anything, it’s always off the mark. The magic of digital information is that it is easy and frictionless to make such retrospective changes. This kind of backward-looking reorganization also allows us to jump into new topics much faster: instead of spending my precious energy getting set up when I’m excited about something, I plunge directly into the heart of the subject, capturing whatever seems interesting and trusting that I can sort it out later.
There is another benefit to this method: it is perfectly okay to not tag a note at all. So long as you’re not using tags as your primary organizational system, there is no chance that a note left untagged will completely fall through the cracks. It will always be right there in the notebook where you left it. This avoids the frustrating experience of trying to force yourself to think of a tag for a note, even when nothing comes to mind, because otherwise it will be lost completely.
The lesson here is to not create structure before it’s needed. By adding just enough structure, at just the right moment, the work required to maintain it will always feel like a welcome relief, instead of a heavy burden.
#3 Tag notes according to their internal, external, and social context, and status
In their book The Science of Managing Our Digital Stuff, from which all the studies in this article are drawn, Ofer Bergman and Steve Whittaker identify the four attributes of a piece of information that can be used to describe its “context.”
Internal context includes the thoughts, feelings, associations, concerns, and considerations you have about a note
External context includes the other items that you are dealing with while interacting with a note, such as other notes, documents, folders, or apps
Social context refers to other people who are related to the note, such as project collaborators, the person who recommended the source, or who it was shared with
Current status refers to any actions taken with the note, or any deliverables it was used in
These attributes are universal in that they apply to any kind of note from any source, yet are also easy to apply. They don’t try to describe the content of the note; only its context. These aren’t abstract labels requiring intensive thinking. They are simple questions that can be answered by looking around at what you’re doing. They can be added incrementally and as needed. They will enable you to more easily return to the state of mind you were in the last time you interacted with a note, using contextual clues that our minds are made to understand.
Here is an Evernote note template that can be used to add these four kinds of context at the top of any note, including a short video I created on how to save the note as a template to your account. Here’s an example of the template filled out:
#4 Develop customized, profession-specific taxonomies
The history of organizing information is largely concerned with “taxonomies” – hierarchical systems for categorizing information in one all-encompassing model.
Passionate debates about which is the “correct” taxonomy go back millennia. Aristotle believed that knowledge could be classified according to its substance, quantity, quality, relation, place, time, position, state, action, & passion. Francis Bacon categorized all human knowledge into memory (i.e. history), reason (i.e. philosophy), and imagination (i.e. fine arts). The 20th century Indian librarian Shiyali Ramamrita Ranganathan argued that any document could be defined according to its personality, matter, energy, space, and time.
The goal has always been to create a single, completely comprehensive ordering of knowledge that any future idea can be placed into. But over many hundreds of years, as our knowledge has exploded in size and complexity, the possibility of a universal taxonomy has faded. It is now quite clear that any such taxonomy will either be too broad to be useful, or too narrow to be universal. The dream of a universal taxonomy is dead.
But for specific fields and professions, it is clear that taxonomies have tremendous value. Biology would be a hopeless tangle of overlapping specialties without the Linnaean taxonomy. Chemistry would be futile without the periodic table. Trends in art would be impossible to make sense of without schools and periods. As long as you can rely on a “controlled vocabulary” of agreed upon terms, it makes a lot of sense to put everything into a category.
A student in one of my courses explained his system for writing scripts (emphasis mine):
“If you know what the constituent parts are of your particular art form, you can collect “snippets” of evocative ideas for any one of them in a single notebook and use tags to label them. So, for example, I have a “Film Ideas” folder where I store ideas and then tag them with one of the following labels:
C = description of Characters who could be used in a story.
L = interesting and visual Location.
O= curious or evocative Object.
S = loaded or revealing Situation.
A = unusual or revealing Act.
T = any Theme that intrigues you or that you see embodied in life
Then I can see all of these notes side by side and if any particular combination of elements sticks out to me, I have the beginnings of a story idea.”
Such a taxonomy can be even more specific than your field or profession, since you are the same person recording and retrieving this knowledge. They can be “personomies,” or personal tag vocabularies, containing the terms that you use to refer to the parts of your work. This personomy is something you will have to develop yourself, but your profession or industry is a good place to start.
The scalability of tagging
In my experience, it is only necessary to use tags when your collection becomes formidable. After nearly 10 years of note-taking and more than 8,000 notes created, I am just starting to seriously run up against the limits of a no-tagging system.
This finding has been echoed in the research. In the 1960s and 1970s, IBM conducted a series of experiments with their new Storage and Information Retrieval System (STAIRS), one of the first systems in which the computer could search the entire text of documents. They found that search accuracy could run as high as 75 to 80%. They happily proclaimed the “death of meta-data.” Why spend time and money having humans index documents when the computer could just search everything?
But there was a fatal flaw in the experiments. They used small collections containing only a few hundred documents. It was assumed that these results would apply equally well to large collections, as long as they had enough computer power. But it was a language problem, not a computer problem.
In the 1980s, researchers David C. Blair and M.E. Maron tested a full-text litigation support system containing about 40,000 documents with 350,000 pages of text. The lawyers depended on this system to retrieve all the documents that might help them win their cases. But Blair and Maron showed that recall averaged only about 20%. The system was retrieving only about 1 in every 5 relevant documents! And this was with trained researchers.
The trouble is that language has numerous, often vague, overlapping mappings to ideas. As David Blair recounts from a real example, a system with 1,000 documents contained 100 that contain the word “computer,” with the word being used 10 different ways. But in a system with 100,000 documents, 7,100 contained the word, and it was used in 84 different ways. The number of possible meanings and interpretations explodes almost as fast as the information itself.
This is where tags come in. They can provide the essential missing piece of data that computers still cannot determine: what a note is about. As long as you follow the recommendations in this article – using tags to track where a chunk of knowledge is in the knowledge lifecycle, adding structure and tags slowly and incrementally, and adding contextual data to notes – you can create paths of action for your future self to follow, without being burdened by rigid bureaucracy.
In the context of personal knowledge management, we need both hierarchies and networks. Notebooks allow us to gather a batch of related material in one place, and look for patterns and associations between the things we’ve collected. Tags add a network to this hierarchy – a distribution network for more efficiently exporting our ideas into the external world.
Ambient findability
“Ambient findability” is a term coined by information architect Peter Morville in a book of the same name. It describes the practice of creating environments where relevant information can be found and used, whether that is a library or a smartphone. When an item is “findable,” it means that it is easy to discover and locate.
The key skill in navigating such an environment is wayfinding, which refers to “the series of things people know and do in order to get from one place to another, inside or outside.” It is a skill we developed to navigate physical environments that we’ve since adapted to virtual environments. But the virtual worlds we’ve created lack the natural landmarks we rely on in the natural world. They lack trees, rivers, seashores, and paths. In the digital world, we have to create them ourselves, out of words.
But the way we’ve used tags in the past comes from a different era. Morville recounts his memories of “online searching” at the University of Michigan’s School of Information and Library Studies, in the ancient epoch of 1993:
“We searched through databases via dumb terminals connected to the Dialog company’s mainframe. Results were output to a dot matrix printer. And Dialog charged by the minute. This made searching quite stressful. Mistakes were costly in time and money. So, we’d spend an hour or more in the library beforehand, consulting printed thesauri for descriptors, considering how to combine Boolean operators most efficiently, and plotting our overall search strategy. A computer’s time was more precious than a human’s, so we sweated every keyword.”
Elaborate, precise tagging systems made sense at that time, when every operation cost money. But the challenge today is not to conserve computer power, but to spend it. Instead of wasting hours of precious human time with laborious tagging just to make a computer’s job easier, we should generously spend the computer’s power to make our job easier.
Thanks to Andrew Brož, Chris Harris, Sachin Rekhi, and Jessica Malnik for their feedback and contributions
Der Verleiher schuldet grundsätzlich lediglich die Auswahl und Überlassung eines für die vorgesehene Tätigkeit geeigneten, durchschnittlichen Arbeitnehmers. Es steht dem Entleiher aber frei, die erforderlichen Fähigkeiten, Kenntnisse und Qualifikationen seinen Anforderungen entsprechend vertraglich festzulegen. Ebenso ist es möglich, ganz konkret die Überlassung bestimmter Arbeitnehmer zu vereinbaren.
Diese Verpflichtung sollte aus Entleihersicht etwa wie folgt abgesichert werden:
//Der Verleiher übernimmt die Gewähr, dass die überlassenen Arbeitnehmer für die Ausübung der in diesem Überlassungsvertrag be-zeichneten Aufgaben und Tätigkeiten geeignet sind und die erforderlichen, in diesem Überlassungsvertrag näher spezifizierten Qualifikationen besitzen. Der Verleiher verpflichtet sich zur Vorlage entsprechender Qualifikationsnachweise.//
`#agl`
entweder über Numbers oder CherryPicker
use marks for `@@background:PapayaWhip ; highlighting@@`for @@background:PapayaWhip ; highlighting@@ in text
This is the demo site for my Material design-inspired theme for [[Tiddlywiki|https://tiddlywiki.com/]]
<hr>
!! Install
Drag the following tag pill into your TW if you want to use it, or use the export button:
<$tiddler tiddler="material-base.bundle">
<span class="tc-tag-label tc-btn-invisible" style="cursor: move;">
<$draggable filter={{!!filter}}>
Material Theme
</$draggable>
</span>
{{||$:/plugins/wikilabs/bundler/ui/Buttons/export-bundle-filter}}
</$tiddler>
Drag the following tag pill into your TW if you want to use it + [[the icons|Make it more Material]] + [[swipe/tap capabilities|Make it swipable / tappable]], or use the export button:
<$tiddler tiddler="material-all.bundle">
<span class="tc-tag-label tc-btn-invisible" style="cursor: move;">
<$draggable filter={{!!filter}}>
Material Theme + icons + ~HammerWidgets
</$draggable>
</span>
{{||$:/plugins/wikilabs/bundler/ui/Buttons/export-bundle-filter}}
</$tiddler>
[[Click here|KeeBoordPlugin]] to see how this theme could work with BTC's ~KeeBoord plugin ( <kbd>ctrl</kbd> + <kbd>space</kbd> to open searchbar)
<hr>
!! Demo palettes
Please take a look at the built-in color palettes:
{{$:/themes/jd/Material/Tweaks/Colors}}
See ''Control Panel'' > ''Appearance'' > ''Material Tweaks'' for other available options
<hr>
Shoutout and huge thanks to ~BurningTreeC for his [[HammerWidgets|http://hammerwidgets.tiddlyspot.com/]] !
!!My other TW Things
http://j.d.tiddlyspot.com/
If you want to hide special tiddlers from the search results (TableOfContents for example), then you can move it to a dedicated place in the system: use your name as the main directory and group your specials under it in to separate directories ($:/yourname/sidebar/Contents).
``$:/core/macros/tag-picker``
Go down to the line:
``<$list filter="[tags[]!is[system]search:title{$:/temp/NewTagName}sort[]]" variable="tag">``
and change to:
``
<$list filter="[tags[]!is[system]!prefix{$:/config/Tags/hide/myprefix}search:title{$:/temp/NewTagName}sort[]]" variable="tag">
``
and then make a tiddler:
``$:/config/Tags/hide/myprefix``
and put whatever prefix you wish to prevent showing (in the editor)
This way if you have a series of structural tiddlers (one's that you use to create a TOC tree, for instance) then you could put
``toc_``
So that you would see tags that had actual meaning (contacts, personal, locations, etc.).
To create a new tab in the sidebar menu:
# Create a tiddler and tag it with the [[SystemTag|SystemTags]] tag [[$:/tags/SideBar]]
#* To create a table of contents you can populate the new tab tiddler using the [[table-of-contents macros|Table-of-Contents Macros]]. For example, see the [[TableOfContents]] used here
# By default, the tiddler title is used as the tab title but you can override it using the `caption` field
# To define the tab ordering, use the `list-after` or `list-before` fields as discussed in [[Tagging]]
#* For example: set `list-after` to [[$:/core/ui/SideBar/Open]] to place a sidebar tab immediately after the "Open" tab
Note that you can create new tabs under the "More" tab in the same way by using the tag `$:/tags/MoreSideBar`.
This ~TiddlyWiki adaptation is for quickly indexing short descriptions of items in books and other sources, organized by topic and subtopic. [[Instructions|$:/.Instructions]]. Currently reading:
<$edit-text tiddler="$:/.giffmex/currently.reading" placeholder="Insert author and title, or full bib. data. Wrap title with diagonal slashes: //Title//." default="" tag="input" size="75"/>
Search main topics:
<<list-search
"[!is[system]tag[.topiclist]sort[title]]"
"search"
"$:/temp/list-search-example"
"$:/core/ui/ListItemTemplate"
placeholder:"Filter by topic..." >>
<div class="tc-table-of-contents">
<<toc-expandable "HQ">>
</div>
<div class="tc-table-of-contents">
<<tocP-expandable "HQ2">>
</div>
''Topics''
<span class="indent1">
<<list-search "[!is[system]tags[]sort[title]]" "search" "$:/temp/list-search-currenttagging" "$:/core/ui/ListItemTemplate" placeholder:"" >>
</span>
<hr>
Jede Tiddler sollte mindestens über drei Informationseinheiten eindeutig definiert werden können (Tag, Key, Fields)
Informationsredudanzen vermeiden in verschiedenen ToCs
Die Gliederung des Zivilrechtes nach dem Institutionensystem, das nach dem Hauptwerk des klassischen römischen Juristen Gaius benannt ist, ist eine Einteilung nach römischem Recht, die in der Zeit der ersten großen Kodifikationswelle – französischer Code civil, österreichisches Allgemeines Bürgerliches Gesetzbuch (ABGB) – aufgenommen wurde.
Die Einteilung gliedert sich grundsätzlich folgendermaßen:
personae: Personen- und Familienrecht
res: Sachenrecht, Schuldrecht, Erbrecht
actiones: (wörtlich) Klagen; gemeint sind indes zumeist Ansprüche, Anspruchsgrundlagen[1] aber auch Klagformeln im Rahmen des Legisaktionenverfahrens.
Das österreichische ABGB folgt diesem Schema, jedoch ohne das Prozessrecht einzubeziehen:
Einleitung
Personenrecht: Personenrecht (vgl. allgemeiner Teil), Familienrecht
Sachenrecht
Dingliches Sachenrecht: Sachenrecht, Erbrecht
Persönliches Sachenrecht: Schuldrecht (vgl. auch allgemeiner Teil)
Gemeinsame Bestimmungen der Personen- und Sachenrechte
All of the macros are in [[Table Macros]], so you should only have to import that tiddler.
!Simple Row/Column Tables
Row table:
```
<<RowTable "row tiddler filter" "field filter">>
```
Column table:
```
<<ColumnTable "column tiddler filter" "field filter">>
```
The two macros `ColumnTable` and `RowTable` each take a filter listing tiddlers as input, with an optional second filter listing fields.
The tiddler filter defines which tiddlers are the columns for the `ColumnTable` macro and the rows for the `RowTable` macro.
If the second filter is left out, the rows of the `ColumnTable` macro are defined by the fields in each tiddler returned by the tiddler filter, the columns for the`RowTable` macro are defined by the fields in the returned tiddlers.
For row tables you can click on a column header and sort the table by that column, for column tables you can click on the row label and sort the columns by that row. Unfortunately sorting column tables by the columns or row tables by the rows is probably going to take some javascript that I don't feel like dealing with right now. It requires sorting the fields of a tiddler by their contents.
Examples: [[Simpler Table Macros]]
!Table Wizard
The macro `<<MakeTableWizard>>` will display the table creation tool. It doesn't take any arguments. You set the name of a configuration tiddler that holds the information for a table.
The macro `<<DisplayTable ConfigurationTiddler>>` will display a table made using the creation tool where `ConfiguartionTiddler` is the name of the tiddler given in the creation tool.
Enter a configuration tiddler name, each configuration tiddler will be associated with one table. You can make as many as you want.
Put in subcolumns, or not as you will.
Enter a tag that will be on the tiddler named with your dataset, you can create a new data set using the button. Note that if you try to make one with the same name as an existing tiddler it will overwrite the tag field of that tiddler.
Same for columns, subcolumns and rows. Subcolumns per column should be set to be equal to the number of columns you are using.
Row, column and subcolumn names can be any valid tiddler name.
If you check 'Allow Inline Editing' you can click on a cell in the table to edit the contents of that cell. For the moment this is probably the best way to enter data.
Data is stored it tiddlers using the naming convention:
For tables without subcolumns:
$:/Data/(Row Name)/(Column Name)/(Dataset Name)
The value is stored in the field `column_data`
For tables with subcolumns:
$:/Data/(Row Name)/(Column Name)/(Subcolumn Name)/(Dataset Name)
The value is stored in the field `subcolumn_data`
Yes, this means that you have a tiddler for each cell in the table. To do this any other way I would have had to drop support for subcolumns and use data tiddlers.
Demo of "anchor links inside a tiddler". This works because
$:/core/ui/PageTemplate/story and $:/core/ui/SideBar/Open have been modified to not show (missing-)tiddlers with prefix tw-href so the scroll first goes to the anchor but then does not go to the (missing-) tiddler.<br>
A problem is that the address url is changed to show the link name. [[Here|Maybe ways to prevent url update]] might be potential methods to prevent this.
<div id="tw-hreftoc"><h2>Demo of Table of Contents using internal anchors</h2></div>
*<a href="#tw-href1">Chapter 1</a>
*<a href="#tw-href2">Chapter 2</a>
*<a href="#tw-href3">Chapter 3</a>
*<a href="#tw-href4">Chapter 4</a>
*<a href="#tw-href5">Chapter 5 in another tiddler</a> (that must be open)
Here comes the epic saga:
<div id="tw-href1"/>
!!!Chapter 1
My son, I have discovered the secret to happiness...
<a href="#tw-hreftoc">back to TOC</a>
<br><br>
<div id="tw-href2"/>
!!!Chapter 2
And will reveal it to you now...
<a href="#tw-hreftoc">back to TOC</a>
<br><br>
<div id="tw-href3"/>
!!!Chapter 3
Just always remember this one thing....
<a href="#tw-hreftoc">back to TOC</a>
<br><br>
<div id="tw-href4"/>
!!!Chapter 4
[To be continued in next book]
<a href="#tw-hreftoc">back to TOC</a>
Bei privatrechtlichen Fällen mit Auslandsbezug (z. B. bei Eheschließung von zwei Personen unterschiedlicher Staatsbürgerschaft, bei einem Schadensfall im Ausland oder bei internationalen Verträgen) bestehen besondere Kollisionsnormen, die bestimmen, welches Privatrecht anzuwenden ist. Dieser Rechtsbereich wird – etwas missverständlich – als Internationales Privatrecht bezeichnet.
Einzelne Rechtsmaterien haben völkerrechtliche Regelungen erhalten, die dann den nationalen Regelungen vorangehen, so insbesondere der internationale Warenkauf durch das Übereinkommen der Vereinten Nationen über Verträge über den internationalen Warenverkauf vom 11. April 1980, dem auch Deutschland, Österreich und die Schweiz beigetreten sind.
Die weltweit einzigartige Möglichkeit, privatrechtliche Ansprüche aus jedem Land der Welt vor einem US-Gericht einzuklagen, wird durch den US-amerikanischen Alien Tort Claims Act geregelt.
\define drop-values() $:/config/EditTemplateFields/Visibility/$(field)$
In the below example, the output of the macro `drop-values` is used as a variable to construct a reference to the following tiddler...
; [[$:/config/EditTemplateFields/Visibility/exercise]]
: sets the gobal visibility of the field `exercise` to hidden
: also defines `values` to be used for the select box in a `values` field
Subequently, the field `values` is extracted using the [[get]] FilterOperator. Another nested list then uses the thus retrieved values to evaluate them as a filter expression...
```
\define drop-values() $:/config/EditTemplateFields/Visibility/$(field)$
<$set name=field value=exercise>
<$select field=<<field>>>
<$list filter="[<drop-values>get[values]]">
<$list filter=<<currentTiddler>>>
<option value=<<currentTiddler>>><$text text=<<currentTiddler>>/></option>
</$list>
</$list>
</$select>
</$set>
```
Renders as...
<<<
<$set name=field value=exercise>
<$select field=<<field>>>
<$list filter="[<drop-values>get[values]]">
<$list filter=<<currentTiddler>>>
<option value=<<currentTiddler>>><$text text=<<currentTiddler>>/></option>
</$list>
</$list>
</$select>
</$set>
<<<
''proof''
```
{{!!exercise}}
```
<<<
{{!!exercise}}
<<<
For the full example, see [[Conditional EditTemplate Fields]]...
''iterates the list field of ExampleTiddler''
```
<$list filter="[list[ExampleTiddler]]">
<<currentTiddler>><br>
</$list>
```
<<<
<$list filter="[list[ExampleTiddler]]">
<<currentTiddler>><br>
</$list>
<<<
''proof''
```
{{ExampleTiddler!!list}}
```
<<<
{{ExampleTiddler!!list}}
<<<
''iterates the list field called `reverse` of ExampleTiddler''
```
<$list filter="[list[ExampleTiddler!!reverse]]">
<<currentTiddler>><br>
</$list>
```
<<<
<$list filter="[list[ExampleTiddler!!reverse]]">
<<currentTiddler>><br>
</$list>
<<<
''proof''
```
{{ExampleTiddler!!reverse}}
```
<<<
{{ExampleTiddler!!reverse}}
<<<
\define join(label,tag,target)
<$button> $label$
<$wikify name="out" text="""<$list filter="[tag[$tag$]]"><$text text={{!!text}}/></$list>""">
<$action-setfield $tiddler="$target$" text=<<out>> />
</$wikify>
</$button>
\end
<<join "CLICK ME" "AGL-Template" "JoinedOutput">>
<<list-tagged-draggable tag:"Anwendungen">>
<<join "CLICK ME" "Anwendungen" "JoinedOutput">>
https://www.jurawiki.de/AnwaltsSoftwarehttps://www.jurawiki.de/KategorieComputerF%C3%BCrJuristen
https://www.niederle-media.de/Kostenlos-Jura-MP3-Skripte-Klausuren-Podcast-Mindmapshttps://noteself.github.io/
Begriff des Rechtsinformationssystems und der Ontologie
* Modell der Schweighofer‘schen Ontologie
* Beitrag der Rechtsinformationssysteme zur Ontologieforschung
* Weitere Forschungen ...: LOIS
[[Rechtsinformationssysteme]]
[[Ontologie]]
''Warum Ontologien?''
Gemeinsame Nutzung von Wissen, Überprüfung einer Wissensbasis, Notwendigkeiten des Software Engineering, Wissensakquisition, Repräsentation und Wiederverwendung des Wissens
Klassische Logik in den Rechtswissenschaften / Formale Logik in der Informatik: Ontologien als Verbindung/missing link zwischen AI & Recht und Rechtstheorie
Besonderheiten/Problematik des Rechts: Unbestimmte Begriffe, Dynamik, systematischer Zusammenhang, syntaktische Mehrdeutigkeiten
Entwicklung eines elektronischen Kommentars
[[FBO Frames-basierte Ontologie]]
[[FOLaw 1 Funktionale Ontologie]]
[[E-Court, LRI-Core 1]]
Weitere praktische Möglichkeiten:
''E-Power''
Projekt der NL Steuer- und Zollverwaltung
Anwendungsorientiertes Wissenssystem;
Formalisierung von Gesetzen und Verordnung als begriffliche Modelle
Automatische Aufgabenerledigung (zB Subsumtion, Berechnung, Ausfertigung); Umfangreiche Unterstützung von Gesetzgebung bis Rechtsanwendung;
Unified Modeling Language (UML)/Object Contraint Model (OCL)
Prototyp: niederländisches Einkommensteuergesetz; Einsatz: Fortis Bank/Belgien, Rentenverwaltungsabteilung des niederländischen Finanzministeriums
''Automatische Textanalyse''
Begriffliche Indexierung
KONTERM (Schweighofer )
FLEXICON (Smith ), University of British Columbia
SALOMON (Moens 1997 ff)
SMILE (Brünninghaus/Ashley 1997 ff)
Dokumentbeschreibung durch Extrahierung und Interpretation von Textmustern
Bisher gute Erfolge, aber (leider) nicht sehr gute!
[[WordNet]]
[[Vorarbeiten zu Ontologien ]]
[[Modell der Schweighofer‘schen Ontologie]]
Beitrag der Rechtsinformationssysteme zur Thesaurusforschung
Textarchiv = Wissensarchiv?
Ja! - gute Enzyklopädie
Begriff, Zugang über Volltextsuche oder „Google“-Suche?
Textforschungen
FLEXICON
KONTERM I, II und III
Begriffsausprägungen im Kontext
Cluster ähnlicher Dokumente
Beschreibung der Cluster ähnlicher Dokumente
Extrahierung wichtiger Begriffe und Sätze der Dokumente
FLEXICON, KONTERM, SALOMON, SMILE
ARI Arbeitsgruppe Rechtsinformatik, Universität Wien WZRI Wiener Zentrum für Rechtsinformatik
'' Konklusionen''
Ontologien sind der Schlüssel zur computergerechten Formalisierung der Welt und des Rechtssystems
Integration aller bestehenden Ontologien notwendig
Reine formale Beschreibung einer Norm zuwenig, weil Rechtsinformationssystem + Jurist bessere Ergebnisse erzielen
Zwischenschritte notwendig
Rechtsinformationssystem
Hybrides wissensbasiertes System
Weiterentwicklung von Thesauri
Endziel: Ontologie als neue Form eines wissenschaftliches juristischen Kommentars
Ontologie muss umfassendes Analyseinstrument der Rechtsordnung sein; Risikominimierung ist zentrales Element der Effizienzbewertung!
ARI Arbeitsgruppe Rechtsinformatik, Universität Wien WZRI Wiener Zentrum für Rechtsinformatik
Weitere Forschungen [[LOIS-Projekt]]
Zweckgebundene Organisation,der die Rechtsordnung Rechtsfähigkeit
verliehen hat
=> Das BGB enthält 2 Formen der juristischen Person des Privatrechts:
Verein (§§ 21 ff.),Stiftung (§§ 80 ff.). Bspe. für Sonderformen desVereins: AG, GmbH, Genossenschaft
BEGEHREN
AGL in TABS
<<tabs "[tag[Kauf-Hund]]" "" "" "">>
ERGEBNIS
<$tiddler tiddler="material-KeeBoord.bundle">
~KeeBoord shortcut specific to Material Theme:
<kbd>ctrl</kbd> + <kbd>space</kbd> : return focus to searchbar
<<<
Click to export this set:
{{||$:/plugins/wikilabs/bundler/ui/Buttons/export-bundle-filter}}
Or drag this into your TW: <span class="tc-tag-label tc-btn-invisible" style="cursor: move;">
<$draggable filter={{!!filter}}>
<<currentTiddler>>
</$draggable>
</span>
//note:// backup, save, and reload for these to take effect
<<<
<hr>
''Thanks to!'' http://keeboord.tiddlyspot.com/
</$tiddler>
<div class="tc-table-of-contents">
<<tocP-selective-expandable root field:"keys">>
</div>
<$set name="me" value=<<currentTiddler>>>
<div class="tc-timeline">
<$list filter="[kin<me>] +[has[modified]!sort[modified]limit[10]eachday[modified]]">
<div class="tc-menu-list-item">
<$view field="modified" format="date" template="DDth MMM YYYY"/>
<$list filter="[kin<me>] +[sameday:modified{!!modified}!is[system]!sort[modified]]">
<div class="tc-menu-list-subitem">
<$link to={{!!title}}><$view field="title"/></$link>
</div>
</$list>
</div>
</$list>
</div>
</$set>
<br><br>
The purpose of the <<.op {{!!caption}}>> operator with examples:
* Finds out where base tiddler originates and what other elements originate from it
* Finds the ancestors and successors of a family member
* Finds the "leaves" of the branch of the base tiddler in a tree-like structure (where the base tiddler is a leaf)
* Finds the super- and subsets / groups of a mathematical set (where the base tiddler is a set)
[img[kin Operator.svg]]
The <<.op {{!!caption}}>> operator uses an extended syntax that permits multiple fields and flags to be passed:
```
[kin:<field>:<direction>:<depth>[<operand>]]
```
* ''field'': name of the [[field|TiddlerFields]] which connecting tiddlers (assumed to be a [[title list|Title List]], defaulting to <<.field tags>>)
* ''direction'': collect the tiddler titles in this direction relative to the base tiddler
** ''from'': collect kins of base tiddler pointing from it (including the base tiddler title itself)
** ''to'': collect kins of base tiddler pointing to it (including the base tiddler title itself)
** ''with'': (the default) union of the aboves
* ''depth'': maximum depth of the collected labels in the tree structure relative to the base tiddler (a positive number, not limited by default)
* ''operand'': filter operand, the base tiddler
<<.op {{!!caption}}>> is a [[modifier|Selection Constructors]], but without <<.place B>> parameter is a [[constructor|Selection Constructors]].
<<.operator-examples "kin">>
\define item-class(highlightfilter) <$list filter="""[$highlightfilter$is[current]first[]]""">highlighted-toc-item</$list>
\define each-level(tiddlername, highlightfilter)
<li>
<$wikify name="transcluded-item-class" text=<<item-class """$highlightfilter$""">> >
<$link class=<<transcluded-item-class """$highlightfilter$""">> >[[$(currentTiddler)$]]</$link>
</$wikify>
<ul>
<$list filter="""$tiddlername$ +[kin[]tag[$(currentTiddler)$]]""">
<<each-level """$tiddlername$""" """$highlightfilter$""">>
</$list>
</ul>
</li>
\end
\define kin-toc(highlightfilter)
<div class="tc-table-of-contents">
<$tiddler tiddler="TableOfContents">
<ul>
<<each-level "[[Filter Syntax]] [[kin Operator]]" """$highlightfilter$""">>
</ul>
</$tiddler>
</div>
\end
\define kin-example-with-toc(number filter comment)
<<.operator-example """$number$""" """[$filter$]""" """$comment$""">>
<$reveal type="nomatch" state="""$:/state/kin-example-with-toc-$number$""" text="show">
<$button set="""$:/state/kin-example-with-toc-$number$""" setTo="show">Show tree</$button>
</$reveal>
<$reveal type="match" state="""$:/state/kin-example-with-toc-$number$""" text="show">
<$button set="""$:/state/kin-example-with-toc-$number$""" setTo="hide">Hide tree</$button>
<<kin-toc """$filter$""">>
</$reveal>
\end
<style>
.highlighted-toc-item a {
color: red !important;
}
</style>
Family tree of [[Filter Syntax]] and [[kin Operator]] (to really understand, look at the [[TableOfContents]])
<<kin-toc "!is[current]">>
''The "Show tree" button below the examples only helps in understanding the filter, it's not part of the output.''
<<kin-example-with-toc 1 "kin[Filter Syntax]" "input titles which are family members of the parameter title">>
<<kin-example-with-toc 2 "kin[Filter Syntax]kin[kin Operator]" "common family members of each of the specified titles (intersection)">>
<<kin-example-with-toc 3 "[Filter Syntax]] [[kin Operator]] +[kin[]" "collected titles which are family members of any of the input tiddlers">>
<<kin-example-with-toc 4 "kin::to[Filters]" "successors of the given tiddler">>
<<kin-example-with-toc 5 "kin::from[Filter Expression]kin::to[Filters]" "subset of the family tree">>
<<kin-example-with-toc 6 "kin::from:2[Filter Expression]" "ancestors of the given tiddler until the given depth">>
<<kin-example-with-toc 7 "kin:tags:from[Filter Syntax]" "ancestors of tiddler based on `tags` field (`tags` points to parents)">>
<<kin-example-with-toc 8 "kin:list:to[Filter Syntax]" "ancestors of tiddler based on `list` field (`list` points to children)<br>[[Reference]] listing [[Concepts]], but [[Concepts]] does not listing [[Filters]] so they do not belong to the same family based on `list`">>
<<.operator-example 9 "[!is[system]type[text/vnd.tiddlywiki]!kin[TableOfContents]first[10]]" "first 10 tiddlers which are not related to [[TableOfContents]] (by `tags`)">>
<$list filter="[[Ontologie]] [[Anwendungen]] +[kin[]]"><$view field="title"/><br/></$list>
``[[Ontologie]] [[Anwendungen]] +[kin[]]``
<<list-links "[!is[system]type[text/vnd.tiddlywiki]!kin[TableOfContents]first[10]]">>
``[!is[system]type[text/vnd.tiddlywiki]!kin[TableOfContents]first[10]]``
Kosten für die Hortbetreuung. Ist die Hortbetreuung nur Ersatz für die eigentlich dem Betreuenden zukommende Aufgabe, gehören die Kosten zum laufenden Bedarf.
Anders kann es aber aussehen, wenn der Hortbesuch über die eigentliche Betreuung hinaus pädagogische Zwecke verfolgt – beispielsweise bei einem Hort mit pädagogischer Förderung. Hierdurch kann durchaus ein Mehrbedarf entstehen.
Die Kosten für den Besuch eines „pädagogischen Mittagstischs“ wiederum wurden nicht als Mehrbedarf angesehen. (OLG Bremen, Beschl. vom 23.11.2017 – 5 UF 54/17)
Eine Klassifikation versucht, tatsächlich das Wissen eines Gebietes oder auch
insgesamt „der Welt“ systematisch zu repräsentieren, sie benutzt zur Darstellung oft
eine künstliche Notationssprache, mit der die Klassenbegriffe bezeichnet und in Relation
gesetzt werden und die durch natürlichsprachige Erläuterungen ergänzt wird.
Alternativ kann auch eine bestimmte natürlichsprachige Bezeichnung für die Begriffe
gewählt werden. Bei Klassifikationen geht es weniger darum, einen konsensualen
Sprachgebrauch zu reflektieren, wie es für Thesauri gilt. Der Inhalt einer Klassifikation,
die zur Inhaltserschließung benutzt wird, richtet sich auch nicht nach den Inhalten
der zu dokumentierenden Dokumente – ausschlaggebend ist v.a. das in einem
bestimmten Bereich vorhandene Wissen (vgl. Manecke:146). Dies ist, was auch
Ontologien für sich beanspruchen: das in einem Bereich (oder auch der ganzen Welt)
vorhandene Wissen zu erfassen und systematisch zu reflektieren.
<div class="family-tree" >
*[[Gesetz]]
**contains
***[[AGL]]
****setzt voraus
*****[[Voraussetzungen]]
******nur dann
*******[[Rechtsfolgen]]
***[[Voraussetzungen]]
***[[Rechtsfolgen]]
</div>
01.03.2007 | Unfallschadensregulierung
Kombinierte Abrechnung mit Kasko und Haftpflicht bei Quotenunfällen
In Haftpflichtfällen mit Quotenhaftung aufgrund Mitverschuldens oder Betriebsgefahr rechnen viele Geschädigte den Schaden lieber (nur) mit ihrer Vollkaskoversicherung ab. Sie übersehen dabei, dass im Rahmen des „Quotenvorrechts“ weiterer Schadenersatz bei der gegnerischen Haftpflichtversicherung geltend gemacht werden kann, z.B. die Wertminderung.
Nachfolgend zeigen wir Ihnen anhand eines Falles, wie Sie als Anwalt des Geschädigten solche Fälle geschickt und pragmatisch mit der Kaskoversicherung des Geschädigten und der Haftpflichtversicherung des Schädigers regulieren können.
Der rechtliche Hintergrund ergibt sich aus § 67 VVG: Nimmt der Geschädigte seine Vollkasko in Anspruch, geht sein Schadenersatzanspruch gegen den Schädiger nur insoweit auf den Vollkaskoversicherer über, wie dieser auch leistet. Hier wirkt sich das „Quotenvorrecht“ zugunsten des Versicherungsnehmers (= Geschädigten) aus. Er kann den nichtregulierten kongruenten Schaden gegenüber dem Schädiger und dessen Versicherung weiterhin geltend machen (Einzelheiten dazu auf S. 46unter „3. kombinierte Abrechnung“).
Musterfall
Der Geschädigte hat eine Vollkaskoversicherung (Selbstbeteiligung: 1.000 EUR). Er war in einen Verkehrsunfall verwickelt (Mitverschulden 50 %). Ihm ist folgender Schaden entstanden:
Reparaturkosten
10.000 EUR
Wertminderung
1.000 EUR
Sachverständigenkosten
1.000 EUR
Abschleppkosten
1.000 EUR
Nutzungsausfallentschädigung
800 EUR
Schadenpauschale
20 EUR
Gesamt
13.820 EUR
1. Abrechnung „nur Haftpflicht“
Hätte der Mandant keine Vollkaskoversicherung, könnte er nur 50 % seines Schadens bei der gegnerischen Haftpflichtversicherung geltend machen. Dann gäbe es nur 6.910 EUR (13.820 EUR : 2).
2. Abrechnung „nur Vollkasko“
Würde der Mandant seine Vollkaskoversicherung in Anspruch nehmen, wäre wie folgt abzurechnen:
Reparaturkosten abzgl. SB (10.000 EUR ./. 1.000 EUR)
9.000 EUR
Wertminderung
0 EUR
Sachverständigenkosten
0 EUR
Abschleppkosten
1.000 EUR
Nutzungsausfallentschädigung
0 EUR
Schadenpauschale
0 EUR
Gesamt
10.000 EUR
Ob die Kaskoversicherung die Zahlung der Gutachtenkosten verweigern darf, weil sie den Sachverständigen nicht selbst ausgewählt hat, hängt davon ab, welche Versicherungsbedingungen anzuwenden sind:
Der BGH hat am 5.11.97 entschieden, dass die Gutachtenkosten auch beim Kaskoschaden vom Versicherer zu tragen sind (VersR 98, 179): „Aufwendungen für ein SV-Gutachten zur Ermittlung des Schadenumfangs gehören zu den erforderlichen Kosten der Wiederherstellung nach § 13 Abs. 5 AKB, sofern es sich nicht um einen Bagatellschaden handelt ... Dass die erforderlichen Kosten der Wiederherstellung nach § 13 Abs. 5 AKB etwas anderes meinen, ist für den durchschnittlichen VN nicht ersichtlich. Das Gegenteil ergibt sich vielmehr aus § 13 Abs. 6 AKB.“
Viele Versicherer haben auf die BGH-Entscheidung reagiert. In § 13 Abs. 6 AKB heißt es jetzt: Der VR ersetzt Sachverständigenkosten nur, wenn er ihn beauftragt hat oder die Beauftragung mit ihm vereinbart war. Achtung: Im neuesten Prölss/Martin stehen noch die alten Bedingungen!
Dass die Selbstbeteiligung von den Reparaturkosten abgezogen wurde, ist bei strenger Betrachtungsweise nicht ganz korrekt. Sie gehört quasi „unter den Strich“. Dieser Kniff ist der unten angewendeten Eselsbrücke geschuldet und darüber hinaus auch im Ergebnis richtig, weil die Selbstbeteiligung eine kongruente Schadensposition ist.
So bleibt der Mandant „nur“ auf 3.820 EUR (13.820 EUR ./. 10.000 EUR) sitzen, zusätzlich auch auf seinem Rückstufungsschaden aus dem Schadenfreiheitsrabattverlust. Das ist ein erfreulicheres Zwischenergebnis als bei der ausschließlichen Abrechnung mit der gegnerischen Haftpflichtversicherung. Am besten ist allerdings die 3. Lösung:
3. Kombinierte Abrechnung mit (eigener) Kasko- und (gegnerischer) Haftpflichtversicherung
Die Abrechnung mit der Vollkaskoversicherung hat nicht das Ziel, den Schädiger zu entlasten. Deshalb wird der Restschaden so weit wie möglich der Haftpflichtversicherung des Schädigers belastet.
Falsch wäre es aber jetzt, nur vom Restschaden den 50-Prozent-Anteil einzufordern. Bezüglich der offen gebliebenen Schadenpositionen ist nach der BGH-Rspr. (VersR 82, 283; 82, 383) zu unterscheiden:
Alle unmittelbaren Sachschäden (= kongruente Schäden) muss der Haftpflichtversicherer in voller Höhe übernehmen – (also über die Quote hinaus). Dazu zählen:
Reparaturkosten (auch fiktiv, dann aber § 249 Abs. 2 S. 2 BGB beachten)
Abschleppkosten,
Sachverständigenkosten,
technische und merkantile Wertminderung,
Wiederbeschaffungswert abzgl. Restwert.
Sachfolgeschäden (= inkongruente Schäden) muss er nur quotenmäßig ausgleichen:
Mietwagenkosten,
Nutzungsausfall,
Auslagen / Unkostenpauschale,
Ab- und Anmeldekosten,
Behandlungskosten,
Schmerzensgeld,
Verdienstausfall,
Rückstufungsschaden (BGH VA 06, 153, Abruf-Nr. 062146 ; BGH VA 07, 4, Abruf-Nr. 063352).
Um zu sortieren, welche der Positionen quotenbevorrechtigt sind und welche nicht, haben sich folgende Merksätze als Eselsbrücke bewährt:
Schadenpositionen, die das Blech berührt haben, sind quotenbevorrechtigt.
Schadenpositionen, die das Blech nicht berührt haben, sind nur nach Quote zu erstatten.
Soll heißen: Die Wertminderung ist die Angst vor einer verbliebenen versteckten „Falte im Blech“; der Sachverständige fasst das Blech an, um die Haube zu öffnen und nach der Vin-Nummer (Fahrzeug-Identifikations-Nummer) zu schauen; der Abschlepper befestigt den Haken „am Blech“. Nutzungsausfallentschädigung ist ein Trostpflaster, und das ist nicht „aus Blech“. Schadenpauschale ist Briefmarken„papier“ und Rennerei-„Sohlenleder“ usw.
Im Musterfall ist somit gegenüber der Haftpflichtversicherung wie folgt abzurechnen:
Selbstbeteiligung voll
1.000 EUR
Wertminderung voll
1.000 EUR
Gutachten voll
1.000 EUR
Nutzungsausfallentschädigung nach Quote
400 EUR
Schadenpauschale nach Quote
10 EUR
Gesamt
3.410 EUR
Die verbleibende Lücke ist jetzt bis auf „fehlende“ 410 EUR (halber Nutzungsausfall, halbe Schadenpauschale) geschlossen. Erhalten hat der Geschädigte nämlich:
von der eigenen Vollkaskoversicherung 10.000 EUR
von der Haftpflichtversicherung des Schädigers 3.410 EUR
Der Rückstufungsschaden in der Vollkaskoversicherung
Zu regeln ist jetzt im Musterfall noch der Rückstufungsschaden im Schadenfreiheitsrabatt der Vollkaskoversicherung. Den Streit um die Frage, ob der Rabattverlust überhaupt zu erstatten ist, hat der BGH inzwischen beendet (25.4.06, VI ZR 36/05, Abruf-Nr. 062146). Der Rabattverlust findet – bildhaft gesprochen – „blechlos“ im Rechner der Versicherung statt und ist folglich von der Gegenseite nur nach Quote zu erstatten (Achtung: Es geht nur um den Rabattverlust in der Vollkaskoversicherung, nicht auch um den aus der eigenen an den Gegner nach Quote zahlenden Haftpflichtversicherung!).
Auch die Ansicht, erst müsse der Haftpflichtversicherer auch in solchen Fällen, in denen die Quotenhaftung offensichtlich ist, zur vollständigen Regulierung aufgefordert werden, damit der Anspruch auf den Rabattverlustersatz ausgelöst wird, hat der BGH zurückgewiesen (26.9.06, VI ZR 247/05, Abruf-Nr. 063352).
Problematisch ist die Berechnung des Rückstufungsschadens. Er schleppt sich ja wirtschaftlich über Jahre. Die gegnerische Versicherung wird ggf. einwenden, dass der Kaskovertrag eventuell gar nicht so lange aufrechterhalten bliebe oder dass der Geschädigte später vielleicht ein Auto einer niedrigeren Typklasse fahre.
In der Regulierungspraxis hat sich daher eingebürgert, dass man die Schadenhöhe schätzt und sich vernünftig einigt. Ist der Versicherer zu einer solchen vernünftigen Einigung nicht bereit, kann der Rabattverlust aus dem laufenden Jahr beziffert werden. Für die Folgejahre bedarf es entweder einer Erklärung des Haftpflichtversicherers, dass er dem Grunde nach anerkennt. Oder es muss auf Feststellung geklagt werden.
Immer erforderlich: Kontrollrechnung wegen Kappungsgrenze
Am Ende ist immer noch eine Kontrollrechnung zu machen: Der gegnerische Haftpflichtversicherer darf nämlich nicht höher belastet werden, als es bei einer ausschließlichen Haftpflichtschadenabrechnung nach Quote der Fall wäre. Soll heißen:
Im obigen Beispielsfall beträgt der Gesamtschaden 13.820 EUR.
Unterstellt, der Gegner müsse nur mit 20 Prozent haften, der eigene Mandant also mit 80 Prozent, fielen dem Haftpflichtversicherer 20 Prozent von 13.820 EUR, folglich nur 2.764 EUR, zur Last. Die Summe aus den bei der kombinierten Abrechnung vom Haftpflichtversicherer voll zu übernehmenden Positionen Selbstbeteiligung, Wertminderung und Gutachterkosten beträgt im Beispielsfall aber bereits 3.000 EUR. Dann wird bei der Obergrenze von 2.674 EUR gekappt.
Einige taktische Hinweise
In Fällen offensichtlicher Mithaftung wird oft über Instanzen und Jahre um die Haftungsquote gestritten. Wenn Körperverletzungen mit im Spiel sind, mag das sinnvoll sein. Beschränkt sich der Schaden jedoch auf den Sach- und Sachfolgeschaden, lässt sich mit der obigen Abrechnungsweise solch lästiger Streit gut vermeiden. Wenn nämlich nicht die Kappungsgrenze berührt wird, bewegen sich die Differenzen bei dieser oder jener Quotenverteilung nur in den Positionen Rabattverlust, Schadenpauschale und Nutzungsausfallentschädigung bzw. Mietwagen. Ob nun die Schadenpauschale mit 30 % oder mit 70 % ausgezahlt wird, selbst ob die Nutzungsausfallentschädigung mit 30 % oder 70 % beansprucht werden kann, ist wirtschaftlich im Verhältnis zur Belastung eines Streites durch die Instanzen jedenfalls für vernunftbegabte Mandanten nicht allzu bedeutend. Das gleiche gilt für den Versicherer. Auf dieser Basis lassen sich dann oft Vergleiche bezüglich der Haftungsquote erzielen.
Wenn Körperverletzungen im Spiel sind, ist sogar ein Teilvergleich über den Sach- und Sachfolgeschaden im obigen Sinne denkbar. Dabei muss dann aber unmissverständlich klargemacht werden, dass die insoweit einvernehmlich gefundene Quote ausschließlich der Erledigung des Teilschadens dient.
Der Vorzug liegt darin, dass die oftmals hinter dem Mandanten auf Geld wartende Werkstatt zügig befriedigt werden kann. Zwischenfinanzierungen oder sogar Inkassomaßnahmen der Werkstatt gegenüber dem Mandanten werden damit vermieden.
Wenn Anwälte diese Abrechnungstechnik beherrschen, ist das aus diesem Grunde gegenüber Werkstätten ein Ausweis gesteigerter Kompetenz. Sie ist für die Werkstätten ein gutes Motiv, in solchen Fällen dringend die Einschaltung anwaltlicher Inanspruchnahme zu empfehlen. Damit hat der Anwalt einen Fuß in der Tür des Marketings.
Gebühren
Der Gegenstandswert für die Gebührenabrechnung mit der gegnerischen Haftpflichtversicherung ist der Betrag, der bei einer ausschließlich mit ihr vorgenommenen Abrechnung durchsetzbar gewesen wäre. Im obigen Beispielsfall wären das also die 6.910 EUR.
Umstritten ist, ob auch die Anwaltsgebühren für die Abrechnung mit der Vollkaskoversicherung von der gegnerischen Haftpflichtversicherung zu übernehmen sind. Die Kaskoversicherung muss diese jedenfalls nicht tragen. Rechtsverfolgungskosten sind nämlich kein versicherter Schaden im Rahmen der Fahrzeugversicherung. Hier greifen nur die allgemeinen Regeln zu den Rechtsverfolgungskosten bei Verzug. Eine Rechtschutzversicherung des Mandanten ist ebenfalls nicht eintrittspflichtig, solange die Kaskoversicherung sauber reguliert. So lange ist die Tätigkeit für den Mandanten nur eine wirtschaftliche Unterstützung. Es fehlt insoweit am rechtsschutzversicherungsrechtlichen Versicherungsfall. Denn dann liegt kein Rechtsverstoß und damit kein Versicherungsfall in der Rechtschutzversicherung vor.
Der BGH hat in anderem Zusammenhang entschieden, dass die Kosten für die anwaltliche Abwicklung von Schäden mit der privaten Unfallversicherung auch dem Schädiger belastet werden können (VA 06, 56, Abruf-Nr. 060630). Das müsste auf die Abrechnung mit der Vollkaskoversicherung übertragbar sein.
<$navigator story="AT:story" history="PE:history">
{{$:/core/ui/Buttons/new-tiddler}}
<$list filter="[list[AT:story]]" template="PE:view" editTemplate="PE:edit" emptyMessage={{AT:empty}} />
</$navigator>
---
<!--
<<list-links "[prefix[AT:]]">>
<<list-links "[list[AT:story]]">>
<<list-links "[all[shadows]prefix[$:/core/ui/Buttons/]] +[limit[0]]">>-->
OLG Düsseldorf, Beschluss vom 11.03.2016 – Ehegattenunterhalt
Eine konkrete Bedarfsberechnung bestimmt sich nach den für den allgemeinen Lebensbedarf – nicht Vermögensbildung – genutzten Einkünften. Eine solche Bedarfsberechnung ist möglich bei Einkommen oberhalb der höchste Einkommensgruppe der Düsseldorfer Tabelle, somit über 5100 €. Der Unterhaltsberechtigte muss nicht sämtliche Positionen des Lebensbedarfs belegen, sondern plausibel vortragen. Das Gericht kann auf Grundlage der Lebensverhältnisse der Ehegatten Schätzungen bezüglich der Angemessenheit vornehmen. Dabei ist ein objektiver Maßstab anzulegen, der ein Festhalten an einer zu dürftigen oder zu aufwendigen Lebensführung ausschließt.
Beschluss:
Gericht : OLG Düsseldorf
Datum : 11.03.2016
Aktenzeichen : 3 UF 141/14
Leitparagraph : BGB § 1361
Quelle : NZFam 2016, Seite 659
Kommentierung:
Dieser Entscheidung ging eine Entscheidung des OLG Düsseldorf voraus, welche einer Ehefrau knapp 3370 € an Unterhalt zugesprochen hat, weil in einem Ehevertrag ein Trennungsunterhaltsanspruch in dieser Höhe – mit Wertsicherungsklausel – festgelegt war. Aufgrund der Lebensumstände und aufgrund des konkret dargelegten Bedarfs hat die Frau über die 3370 € weitere knapp 6000 € pro Monat verlangt, mit dem Argument, in der ehevertraglichen Vereinbarung läge ein unwirksamer Verzicht auf Getrenntlebendunterhalt und sie hätte den entsprechenden Bedarf. Das OLG hatte der Frau nur 3370 € zugesprochen, sie ging in die zugelassene Rechtsbeschwerde, der BGH hat die Einwendungen der Frau zur Grundlage genommen, die Entscheidung an das OLG Düsseldorf zurückzuverweisen, da es nicht ausgeschlossen war, dass ein unwirksamer Verzicht auf Trennungsunterhalt vorliegt, was dann der Fall ist, wenn der gesetzliche Unterhaltsanspruch um mehr als 1/3 unterschritten wird (BGH, NJW 2015, Seite 3715). Das OLG hatte daher zu prüfen, wie hoch die ehelichen Lebensverhältnisse tatsächlich sind, hatte zu prüfen, wie hoch der konkrete Bedarf der Ehefrau tatsächlich ist und ob die 3370 € eine Unterschreitung von mehr als 1/3 des Unterhaltsanspruches darstellt.
Das OLG kam zu dem Ergebnis, dass ein Unterhaltsbedarf von ca. 8000 € vorliegt. Damit war die ehevertragliche Vereinbarung zum Trennungsunterhalt unwirksam und das OLG hat der Frau einen derart hohen Unterhaltsbedarf zugesprochen. Weiterhin hat das OLG den Verwirkungseinwand des Mannes nicht bestätigt. Dieser hatte die Verwirkung begehrt wegen Ausbrechens der Frau aus der Ehe. Die Verwirkung hat das OLG verneint mit dem Hinweis darauf, dass die Hinwendung der Frau zu einem neuen Partner keinen Ausbruch darstelle, die Ehe sich in einer Krise befunden habe und nicht mehr intakt gewesen sei.
Das OLG hat die konkrete Bedarfsberechnung bereits bejaht bei einem bereinigten Einkommen der Eheleute von über 5100 €. In vielen OLG-Bezirken wird dies anders gehandhabt, so wird eine konkrete Bedarfsberechnung erst angenommen bei einem Bedarf von 5100 € oder bei einem Einkommen vom doppelten Betrag von 5100 €, mithin erst bei 10200 €. Dies wird von den OLGs sehr unterschiedlich gehandhabt, hierauf sei ausdrücklich hingewiesen. Auf der anderen Seite kennt z. B. das OLG Frankfurt eine absolute Sättigungsgrenze, was die anderen Oberlandesgerichte in Deutschland so nicht kennen. Dass ein Gericht aufgrund eines substantiierten Sachvortrages den Lebensbedarf auch in Einzelpositionen schätzen kann und darf ist nichts Neues (BGH, NJW 2012, Seite 1144). Die Schätzgrundlage, z. B. Lebensstil der Eheleute, statusprägende Ausgaben wie Kfz, Urlaube etc. müssen jedoch genannt werden.
Zuletzt setzt die Einigung einen Konsens, also die Übereinstimmung von Angebot und Annahme voraus. Konsens liegt vor, wenn zwei bereits ausgelegte Willenserklärung bezüglich aller vertragswesentlicher Bestandteile übereinstimmen.
Zwei Arten von Konzepten:
*Das Konzept beschreibt eine Klasse oder eine Menge von
individuellen Objekte der Welt.
*Das Konzept beschreibt nur ein ganz bestimmtes Objekt der Welt
<<tabs "[[Kündigung - Anwendungsbereich]] [[Ordentliche Kündigung]] [[Kündigung - Praxis]]" "[[Ordentliche Kündigung]]" "$:/state/tab2">>
(1) Die Kündigung des Arbeitsverhältnisses gegenüber einem Arbeitnehmer, dessen Arbeitsverhältnis in demselben Betrieb oder Unternehmen ohne Unterbrechung länger als sechs Monate bestanden hat, ist rechtsunwirksam, wenn sie sozial ungerechtfertigt ist.
(2) Sozial ungerechtfertigt ist die Kündigung, wenn sie nicht durch Gründe, die in der Person oder in dem Verhalten des Arbeitnehmers liegen, oder durch dringende betriebliche Erfordernisse, die einer Weiterbeschäftigung des Arbeitnehmers in diesem Betrieb entgegenstehen, bedingt ist. Die Kündigung ist auch sozial ungerechtfertigt, wenn
1.
in Betrieben des privaten Rechts
a)
die Kündigung gegen eine Richtlinie nach § 95 des Betriebsverfassungsgesetzes verstößt,
b)
der Arbeitnehmer an einem anderen Arbeitsplatz in demselben Betrieb oder in einem anderen Betrieb des Unternehmens weiterbeschäftigt werden kann
und der Betriebsrat oder eine andere nach dem Betriebsverfassungsgesetz insoweit zuständige Vertretung der Arbeitnehmer aus einem dieser Gründe der Kündigung innerhalb der Frist des § 102 Abs. 2 Satz 1 des Betriebsverfassungsgesetzes schriftlich widersprochen hat,
2.
in Betrieben und Verwaltungen des öffentlichen Rechts
a)
die Kündigung gegen eine Richtlinie über die personelle Auswahl bei Kündigungen verstößt,
b)
der Arbeitnehmer an einem anderen Arbeitsplatz in derselben Dienststelle oder in einer anderen Dienststelle desselben Verwaltungszweigs an demselben Dienstort einschließlich seines Einzugsgebiets weiterbeschäftigt werden kann
und die zuständige Personalvertretung aus einem dieser Gründe fristgerecht gegen die Kündigung Einwendungen erhoben hat, es sei denn, daß die Stufenvertretung in der Verhandlung mit der übergeordneten Dienststelle die Einwendungen nicht aufrechterhalten hat.
Satz 2 gilt entsprechend, wenn die Weiterbeschäftigung des Arbeitnehmers nach zumutbaren Umschulungs- oder Fortbildungsmaßnahmen oder eine Weiterbeschäftigung des Arbeitnehmers unter geänderten Arbeitsbedingungen möglich ist und der Arbeitnehmer sein Einverständnis hiermit erklärt hat. Der Arbeitgeber hat die Tatsachen zu beweisen, die die Kündigung bedingen.
(3) Ist einem Arbeitnehmer aus dringenden betrieblichen Erfordernissen im Sinne des Absatzes 2 gekündigt worden, so ist die Kündigung trotzdem sozial ungerechtfertigt, wenn der Arbeitgeber bei der Auswahl des Arbeitnehmers die Dauer der Betriebszugehörigkeit, das Lebensalter, die Unterhaltspflichten und die Schwerbehinderung des Arbeitnehmers nicht oder nicht ausreichend berücksichtigt hat; auf Verlangen des Arbeitnehmers hat der Arbeitgeber dem Arbeitnehmer die Gründe anzugeben, die zu der getroffenen sozialen Auswahl geführt haben. In die soziale Auswahl nach Satz 1 sind Arbeitnehmer nicht einzubeziehen, deren Weiterbeschäftigung, insbesondere wegen ihrer Kenntnisse, Fähigkeiten und Leistungen oder zur Sicherung einer ausgewogenen Personalstruktur des Betriebes, im berechtigten betrieblichen Interesse liegt. Der Arbeitnehmer hat die Tatsachen zu beweisen, die die Kündigung als sozial ungerechtfertigt im Sinne des Satzes 1 erscheinen lassen.
(4) Ist in einem Tarifvertrag, in einer Betriebsvereinbarung nach § 95 des Betriebsverfassungsgesetzes oder in einer entsprechenden Richtlinie nach den Personalvertretungsgesetzen festgelegt, wie die sozialen Gesichtspunkte nach Absatz 3 Satz 1 im Verhältnis zueinander zu bewerten sind, so kann die Bewertung nur auf grobe Fehlerhaftigkeit überprüft werden.
(5) Sind bei einer Kündigung auf Grund einer Betriebsänderung nach § 111 des Betriebsverfassungsgesetzes die Arbeitnehmer, denen gekündigt werden soll, in einem Interessenausgleich zwischen Arbeitgeber und Betriebsrat namentlich bezeichnet, so wird vermutet, dass die Kündigung durch dringende betriebliche Erfordernisse im Sinne des Absatzes 2 bedingt ist. Die soziale Auswahl der Arbeitnehmer kann nur auf grobe Fehlerhaftigkeit überprüft werden. Die Sätze 1 und 2 gelten nicht, soweit sich die Sachlage nach Zustandekommen des Interessenausgleichs wesentlich geändert hat. Der Interessenausgleich nach Satz 1 ersetzt die Stellungnahme des Betriebsrates nach § 17 Abs. 3 Satz 2.
(1) Kündigt der Arbeitgeber wegen dringender betrieblicher Erfordernisse nach § 1 Abs. 2 Satz 1 und erhebt der Arbeitnehmer bis zum Ablauf der Frist des § 4 Satz 1 keine Klage auf Feststellung, dass das Arbeitsverhältnis durch die Kündigung nicht aufgelöst ist, hat der Arbeitnehmer mit dem Ablauf der Kündigungsfrist Anspruch auf eine Abfindung. Der Anspruch setzt den Hinweis des Arbeitgebers in der Kündigungserklärung voraus, dass die Kündigung auf dringende betriebliche Erfordernisse gestützt ist und der Arbeitnehmer bei Verstreichenlassen der Klagefrist die Abfindung beanspruchen kann.
(2) Die Höhe der Abfindung beträgt 0,5 Monatsverdienste für jedes Jahr des Bestehens des Arbeitsverhältnisses. § 10 Abs. 3 gilt entsprechend. Bei der Ermittlung der Dauer des Arbeitsverhältnisses ist ein Zeitraum von mehr als sechs Monaten auf ein volles Jahr aufzurunden.
Kündigt der Arbeitgeber das Arbeitsverhältnis und bietet er dem Arbeitnehmer im Zusammenhang mit der Kündigung die Fortsetzung des Arbeitsverhältnisses zu geänderten Arbeitsbedingungen an, so kann der Arbeitnehmer dieses Angebot unter dem Vorbehalt annehmen, daß die Änderung der Arbeitsbedingungen nicht sozial ungerechtfertigt ist (§ 1 Abs. 2 Satz 1 bis 3, Abs. 3 Satz 1 und 2). Diesen Vorbehalt muß der Arbeitnehmer dem Arbeitgeber innerhalb der Kündigungsfrist, spätestens jedoch innerhalb von drei Wochen nach Zugang der Kündigung erklären.
Hält der Arbeitnehmer eine Kündigung für sozial ungerechtfertigt, so kann er binnen einer Woche nach der Kündigung Einspruch beim Betriebsrat einlegen. Erachtet der Betriebsrat den Einspruch für begründet, so hat er zu versuchen, eine Verständigung mit dem Arbeitgeber herbeizuführen. Er hat seine Stellungnahme zu dem Einspruch dem Arbeitnehmer und dem Arbeitgeber auf Verlangen schriftlich mitzuteilen.
Will ein Arbeitnehmer geltend machen, dass eine Kündigung sozial ungerechtfertigt oder aus anderen Gründen rechtsunwirksam ist, so muss er innerhalb von drei Wochen nach Zugang der schriftlichen Kündigung Klage beim Arbeitsgericht auf Feststellung erheben, dass das Arbeitsverhältnis durch die Kündigung nicht aufgelöst ist. Im Falle des § 2 ist die Klage auf Feststellung zu erheben, daß die Änderung der Arbeitsbedingungen sozial ungerechtfertigt oder aus anderen Gründen rechtsunwirksam ist. Hat der Arbeitnehmer Einspruch beim Betriebsrat eingelegt (§ 3), so soll er der Klage die Stellungnahme des Betriebsrats beifügen. Soweit die Kündigung der Zustimmung einer Behörde bedarf, läuft die Frist zur Anrufung des Arbeitsgerichts erst von der Bekanntgabe der Entscheidung der Behörde an den Arbeitnehmer ab.
(1) War ein Arbeitnehmer nach erfolgter Kündigung trotz Anwendung aller ihm nach Lage der Umstände zuzumutenden Sorgfalt verhindert, die Klage innerhalb von drei Wochen nach Zugang der schriftlichen Kündigung zu erheben, so ist auf seinen Antrag die Klage nachträglich zuzulassen. Gleiches gilt, wenn eine Frau von ihrer Schwangerschaft aus einem von ihr nicht zu vertretenden Grund erst nach Ablauf der Frist des § 4 Satz 1 Kenntnis erlangt hat.
(2) Mit dem Antrag ist die Klageerhebung zu verbinden; ist die Klage bereits eingereicht, so ist auf sie im Antrag Bezug zu nehmen. Der Antrag muß ferner die Angabe der die nachträgliche Zulassung begründenden Tatsachen und der Mittel für deren Glaubhaftmachung enthalten.
(3) Der Antrag ist nur innerhalb von zwei Wochen nach Behebung des Hindernisses zulässig. Nach Ablauf von sechs Monaten, vom Ende der versäumten Frist an gerechnet, kann der Antrag nicht mehr gestellt werden.
(4) Das Verfahren über den Antrag auf nachträgliche Zulassung ist mit dem Verfahren über die Klage zu verbinden. Das Arbeitsgericht kann das Verfahren zunächst auf die Verhandlung und Entscheidung über den Antrag beschränken. In diesem Fall ergeht die Entscheidung durch Zwischenurteil, das wie ein Endurteil angefochten werden kann.
(5) Hat das Arbeitsgericht über einen Antrag auf nachträgliche Klagezulassung nicht entschieden oder wird ein solcher Antrag erstmals vor dem Landesarbeitsgericht gestellt, entscheidet hierüber die Kammer des Landesarbeitsgerichts. Absatz 4 gilt entsprechend.
Hat ein Arbeitnehmer innerhalb von drei Wochen nach Zugang der schriftlichen Kündigung im Klagewege geltend gemacht, dass eine rechtswirksame Kündigung nicht vorliege, so kann er sich in diesem Verfahren bis zum Schluss der mündlichen Verhandlung erster Instanz zur Begründung der Unwirksamkeit der Kündigung auch auf innerhalb der Klagefrist nicht geltend gemachte Gründe berufen. Das Arbeitsgericht soll ihn hierauf hinweisen.
Wird die Rechtsunwirksamkeit einer Kündigung nicht rechtzeitig geltend gemacht (§ 4 Satz 1, §§ 5 und 6), so gilt die Kündigung als von Anfang an rechtswirksam; ein vom Arbeitnehmer nach § 2 erklärter Vorbehalt erlischt.
Stellt das Gericht im Falle des § 2 fest, daß die Änderung der Arbeitsbedingungen sozial ungerechtfertigt ist, so gilt die Änderungskündigung als von Anfang an rechtsunwirksam.
(1) Stellt das Gericht fest, daß das Arbeitsverhältnis durch die Kündigung nicht aufgelöst ist, ist jedoch dem Arbeitnehmer die Fortsetzung des Arbeitsverhältnisses nicht zuzumuten, so hat das Gericht auf Antrag des Arbeitnehmers das Arbeitsverhältnis aufzulösen und den Arbeitgeber zur Zahlung einer angemessenen Abfindung zu verurteilen. Die gleiche Entscheidung hat das Gericht auf Antrag des Arbeitgebers zu treffen, wenn Gründe vorliegen, die eine den Betriebszwecken dienliche weitere Zusammenarbeit zwischen Arbeitgeber und Arbeitnehmer nicht erwarten lassen. Arbeitnehmer und Arbeitgeber können den Antrag auf Auflösung des Arbeitsverhältnisses bis zum Schluß der letzten mündlichen Verhandlung in der Berufungsinstanz stellen.
(2) Das Gericht hat für die Auflösung des Arbeitsverhältnisses den Zeitpunkt festzusetzen, an dem es bei sozial gerechtfertigter Kündigung geendet hätte.
1) Als Abfindung ist ein Betrag bis zu zwölf Monatsverdiensten festzusetzen.
(2) Hat der Arbeitnehmer das fünfzigste Lebensjahr vollendet und hat das Arbeitsverhältnis mindestens fünfzehn Jahre bestanden, so ist ein Betrag bis zu fünfzehn Monatsverdiensten, hat der Arbeitnehmer das fünfundfünfzigste Lebensjahr vollendet und hat das Arbeitsverhältnis mindestens zwanzig Jahre bestanden, so ist ein Betrag bis zu achtzehn Monatsverdiensten festzusetzen. Dies gilt nicht, wenn der Arbeitnehmer in dem Zeitpunkt, den das Gericht nach § 9 Abs. 2 für die Auflösung des Arbeitsverhältnisses festsetzt, das in der Vorschrift des Sechsten Buches Sozialgesetzbuch über die Regelaltersrente bezeichnete Lebensalter erreicht hat.
(3) Als Monatsverdienst gilt, was dem Arbeitnehmer bei der für ihn maßgebenden regelmäßigen Arbeitszeit in dem Monat, in dem das Arbeitsverhältnis endet (§ 9 Abs. 2), an Geld und Sachbezügen zusteht.
Besteht nach der Entscheidung des Gerichts das Arbeitsverhältnis fort, so muß sich der Arbeitnehmer auf das Arbeitsentgelt, das ihm der Arbeitgeber für die Zeit nach der Entlassung schuldet, anrechnen lassen,
1.
was er durch anderweitige Arbeit verdient hat,
2.
was er hätte verdienen können, wenn er es nicht böswillig unterlassen hätte, eine ihm zumutbare Arbeit anzunehmen,
3.
was ihm an öffentlich-rechtlichen Leistungen infolge Arbeitslosigkeit aus der Sozialversicherung, der Arbeitslosenversicherung, der Sicherung des Lebensunterhalts nach dem Zweiten Buch Sozialgesetzbuch oder der Sozialhilfe für die Zwischenzeit gezahlt worden ist. Diese Beträge hat der Arbeitgeber der Stelle zu erstatten, die sie geleistet hat.
Besteht nach der Entscheidung des Gerichts das Arbeitsverhältnis fort, ist jedoch der Arbeitnehmer inzwischen ein neues Arbeitsverhältnis eingegangen, so kann er binnen einer Woche nach der Rechtskraft des Urteils durch Erklärung gegenüber dem alten Arbeitgeber die Fortsetzung des Arbeitsverhältnisses bei diesem verweigern. Die Frist wird auch durch eine vor ihrem Ablauf zur Post gegebene schriftliche Erklärung gewahrt. Mit dem Zugang der Erklärung erlischt das Arbeitsverhältnis. Macht der Arbeitnehmer von seinem Verweigerungsrecht Gebrauch, so ist ihm entgangener Verdienst nur für die Zeit zwischen der Entlassung und dem Tag des Eintritts in das neue Arbeitsverhältnis zu gewähren. § 11 findet entsprechende Anwendung.
(1) Die Vorschriften über das Recht zur außerordentlichen Kündigung eines Arbeitsverhältnisses werden durch das vorliegende Gesetz nicht berührt. Die Rechtsunwirksamkeit einer außerordentlichen Kündigung kann jedoch nur nach Maßgabe des § 4 Satz 1 und der §§ 5 bis 7 geltend gemacht werden. Stellt das Gericht fest, dass die außerordentliche Kündigung unbegründet ist, ist jedoch dem Arbeitnehmer die Fortsetzung des Arbeitsverhältnisses nicht zuzumuten, so hat auf seinen Antrag das Gericht das Arbeitsverhältnis aufzulösen und den Arbeitgeber zur Zahlung einer angemessenen Abfindung zu verurteilen. Das Gericht hat für die Auflösung des Arbeitsverhältnisses den Zeitpunkt festzulegen, zu dem die außerordentliche Kündigung ausgesprochen wurde. Die Vorschriften der §§ 10 bis 12 gelten entsprechend.
(2) Verstößt eine Kündigung gegen die guten Sitten, so finden die Vorschriften des § 9 Abs. 1 Satz 1 und Abs. 2 und der §§ 10 bis 12 entsprechende Anwendung.
(3) Im Übrigen finden die Vorschriften dieses Abschnitts mit Ausnahme der §§ 4 bis 7 auf eine Kündigung, die bereits aus anderen als den in § 1 Abs. 2 und 3 bezeichneten Gründen rechtsunwirksam ist, keine Anwendung.
(1) Die Vorschriften dieses Abschnitts gelten nicht
1. in Betrieben einer juristischen Person für die Mitglieder des Organs, das zur gesetzlichen Vertretung der juristischen Person berufen ist,
2. in Betrieben einer Personengesamtheit für die durch Gesetz, Satzung oder Gesellschaftsvertrag zur Vertretung der Personengesamtheit berufenen Personen .
(2) Auf Geschäftsführer, Betriebsleiter und ähnliche leitende Angestellte, soweit diese zur selbständigen Einstellung oder Entlassung von Arbeitnehmern berechtigt sind, finden die Vorschriften dieses Abschnitts mit Ausnahme des § 3 Anwendung. § 9 Abs. 1 Satz 2 findet mit der Maßgabe Anwendung, daß der Antrag des Arbeitgebers auf Auflösung des Arbeitsverhältnisses keiner Begründung bedarf.
(1) Die Kündigung eines Mitglieds eines Betriebsrats, einer Jugend- und Auszubildendenvertretung, einer Bordvertretung oder eines Seebetriebsrats ist unzulässig, es sei denn, daß Tatsachen vorliegen, die den Arbeitgeber zur Kündigung aus wichtigem Grund ohne Einhaltung einer Kündigungsfrist berechtigen, und daß die nach § 103 des Betriebsverfassungsgesetzes erforderliche Zustimmung vorliegt oder durch gerichtliche Entscheidung ersetzt ist. Nach Beendigung der Amtszeit ist die Kündigung eines Mitglieds eines Betriebsrats, einer Jugend- und Auszubildendenvertretung oder eines Seebetriebsrats innerhalb eines Jahres, die Kündigung eines Mitglieds einer Bordvertretung innerhalb von sechs Monaten, jeweils vom Zeitpunkt der Beendigung der Amtszeit an gerechnet, unzulässig, es sei denn, daß Tatsachen vorliegen, die den Arbeitgeber zur Kündigung aus wichtigem Grund ohne Einhaltung einer Kündigungsfrist berechtigen; dies gilt nicht, wenn die Beendigung der Mitgliedschaft auf einer gerichtlichen Entscheidung beruht.
(2) Die Kündigung eines Mitglieds einer Personalvertretung, einer Jugend- und Auszubildendenvertretung oder einer Jugendvertretung ist unzulässig, es sei denn, daß Tatsachen vorliegen, die den Arbeitgeber zur Kündigung aus wichtigem Grund ohne Einhaltung einer Kündigungsfrist berechtigen, und daß die nach dem Personalvertretungsrecht erforderliche Zustimmung vorliegt oder durch gerichtliche Entscheidung ersetzt ist. Nach Beendigung der Amtszeit der in Satz 1 genannten Personen ist ihre Kündigung innerhalb eines Jahres, vom Zeitpunkt der Beendigung der Amtszeit an gerechnet, unzulässig, es sei denn, daß Tatsachen vorliegen, die den Arbeitgeber zur Kündigung aus wichtigem Grund ohne Einhaltung einer Kündigungsfrist berechtigen; dies gilt nicht, wenn die Beendigung der Mitgliedschaft auf einer gerichtlichen Entscheidung beruht.
(3) Die Kündigung eines Mitglieds eines Wahlvorstands ist vom Zeitpunkt seiner Bestellung an, die Kündigung eines Wahlbewerbers vom Zeitpunkt der Aufstellung des Wahlvorschlags an, jeweils bis zur Bekanntgabe des Wahlergebnisses unzulässig, es sei denn, daß Tatsachen vorliegen, die den Arbeitgeber zur Kündigung aus wichtigem Grund ohne Einhaltung einer Kündigungsfrist berechtigen, und daß die nach § 103 des Betriebsverfassungsgesetzes oder nach dem Personalvertretungsrecht erforderliche Zustimmung vorliegt oder durch eine gerichtliche Entscheidung ersetzt ist. Innerhalb von sechs Monaten nach Bekanntgabe des Wahlergebnisses ist die Kündigung unzulässig, es sei denn, daß Tatsachen vorliegen, die den Arbeitgeber zur Kündigung aus wichtigem Grund ohne Einhaltung einer Kündigungsfrist berechtigen; dies gilt nicht für Mitglieder des Wahlvorstands, wenn dieser durch gerichtliche Entscheidung durch einen anderen Wahlvorstand ersetzt worden ist.
(3a) Die Kündigung eines Arbeitnehmers, der zu einer Betriebs-, Wahl- oder Bordversammlung nach § 17 Abs. 3, § 17a Nr. 3 Satz 2, § 115 Abs. 2 Nr. 8 Satz 1 des Betriebsverfassungsgesetzes einlädt oder die Bestellung eines Wahlvorstands nach § 16 Abs. 2 Satz 1, § 17 Abs. 4, § 17a Nr. 4, § 63 Abs. 3, § 115 Abs. 2 Nr. 8 Satz 2 oder § 116 Abs. 2 Nr. 7 Satz 5 des Betriebsverfassungsgesetzes beantragt, ist vom Zeitpunkt der Einladung oder Antragstellung an bis zur Bekanntgabe des Wahlergebnisses unzulässig, es sei denn, dass Tatsachen vorliegen, die den Arbeitgeber zur Kündigung aus wichtigem Grund ohne Einhaltung einer Kündigungsfrist berechtigen; der Kündigungsschutz gilt für die ersten drei in der Einladung oder Antragstellung aufgeführten Arbeitnehmer. Wird ein Betriebsrat, eine Jugend- und Auszubildendenvertretung, eine Bordvertretung oder ein Seebetriebsrat nicht gewählt, besteht der Kündigungsschutz nach Satz 1 vom Zeitpunkt der Einladung oder Antragstellung an drei Monate.
(4) Wird der Betrieb stillgelegt, so ist die Kündigung der in den Absätzen 1 bis 3 genannten Personen frühestens zum Zeitpunkt der Stillegung zulässig, es sei denn, daß ihre Kündigung zu einem früheren Zeitpunkt durch zwingende betriebliche Erfordernisse bedingt ist.
(5) Wird eine der in den Absätzen 1 bis 3 genannten Personen in einer Betriebsabteilung beschäftigt, die stillgelegt wird, so ist sie in eine andere Betriebsabteilung zu übernehmen. Ist dies aus betrieblichen Gründen nicht möglich, so findet auf ihre Kündigung die Vorschrift des Absatzes 4 über die Kündigung bei Stillegung des Betriebs sinngemäß Anwendung.
Stellt das Gericht die Unwirksamkeit der Kündigung einer der in § 15 Abs. 1 bis 3a genannten Personen fest, so kann diese Person, falls sie inzwischen ein neues Arbeitsverhältnis eingegangen ist, binnen einer Woche nach Rechtskraft des Urteils durch Erklärung gegenüber dem alten Arbeitgeber die Weiterbeschäftigung bei diesem verweigern. Im übrigen finden die Vorschriften des § 11 und des § 12 Satz 2 bis 4 entsprechende Anwendung.
(1) Der Arbeitgeber ist verpflichtet, der Agentur für Arbeit Anzeige zu erstatten, bevor er
1.
in Betrieben mit in der Regel mehr als 20 und weniger als 60 Arbeitnehmern mehr als 5 Arbeitnehmer,
2.
in Betrieben mit in der Regel mindestens 60 und weniger als 500 Arbeitnehmern 10 vom Hundert der im Betrieb regelmäßig beschäftigten Arbeitnehmer oder aber mehr als 25 Arbeitnehmer,
3.
in Betrieben mit in der Regel mindestens 500 Arbeitnehmern mindestens 30 Arbeitnehmer
innerhalb von 30 Kalendertagen entläßt. Den Entlassungen stehen andere Beendigungen des Arbeitsverhältnisses gleich, die vom Arbeitgeber veranlaßt werden.
(2) Beabsichtigt der Arbeitgeber, nach Absatz 1 anzeigepflichtige Entlassungen vorzunehmen, hat er dem Betriebsrat rechtzeitig die zweckdienlichen Auskünfte zu erteilen und ihn schriftlich insbesondere zu unterrichten über
1.
die Gründe für die geplanten Entlassungen,
2.
die Zahl und die Berufsgruppen der zu entlassenden Arbeitnehmer,
3.
die Zahl und die Berufsgruppen der in der Regel beschäftigten Arbeitnehmer,
4.
den Zeitraum, in dem die Entlassungen vorgenommen werden sollen,
5.
die vorgesehenen Kriterien für die Auswahl der zu entlassenden Arbeitnehmer,
6.
die für die Berechnung etwaiger Abfindungen vorgesehenen Kriterien.
Arbeitgeber und Betriebsrat haben insbesondere die Möglichkeiten zu beraten, Entlassungen zu vermeiden oder einzuschränken und ihre Folgen zu mildern.
(3) Der Arbeitgeber hat gleichzeitig der Agentur für Arbeit eine Abschrift der Mitteilung an den Betriebsrat zuzuleiten; sie muß zumindest die in Absatz 2 Satz 1 Nr. 1 bis 5 vorgeschriebenen Angaben enthalten. Die Anzeige nach Absatz 1 ist schriftlich unter Beifügung der Stellungnahme des Betriebsrats zu den Entlassungen zu erstatten. Liegt eine Stellungnahme des Betriebsrats nicht vor, so ist die Anzeige wirksam, wenn der Arbeitgeber glaubhaft macht, daß er den Betriebsrat mindestens zwei Wochen vor Erstattung der Anzeige nach Absatz 2 Satz 1 unterrichtet hat, und er den Stand der Beratungen darlegt. Die Anzeige muß Angaben über den Namen des Arbeitgebers, den Sitz und die Art des Betriebes enthalten, ferner die Gründe für die geplanten Entlassungen, die Zahl und die Berufsgruppen der zu entlassenden und der in der Regel beschäftigten Arbeitnehmer, den Zeitraum, in dem die Entlassungen vorgenommen werden sollen und die vorgesehenen Kriteren für die Auswahl der zu entlassenden Arbeitnehmer. In der Anzeige sollen ferner im Einvernehmen mit dem Betriebsrat für die Arbeitsvermittlung Angaben über Geschlecht, Alter, Beruf und Staatsangehörigkeit der zu entlassenden Arbeitnehmer gemacht werden. Der Arbeitgeber hat dem Betriebsrat eine Abschrift der Anzeige zuzuleiten. Der Betriebsrat kann gegenüber der Agentur für Arbeit weitere Stellungnahmen abgeben. Er hat dem Arbeitgeber eine Abschrift der Stellungnahme zuzuleiten.
(3a) Die Auskunfts-, Beratungs- und Anzeigepflichten nach den Absätzen 1 bis 3 gelten auch dann, wenn die Entscheidung über die Entlassungen von einem den Arbeitgeber beherrschenden Unternehmen getroffen wurde. Der Arbeitgeber kann sich nicht darauf berufen, daß das für die Entlassungen verantwortliche Unternehmen die notwendigen Auskünfte nicht übermittelt hat.
(4) Das Recht zur fristlosen Entlassung bleibt unberührt. Fristlose Entlassungen werden bei Berechnung der Mindestzahl der Entlassungen nach Absatz 1 nicht mitgerechnet.
(5) Als Arbeitnehmer im Sinne dieser Vorschrift gelten nicht
1.
in Betrieben einer juristischen Person die Mitglieder des Organs, das zur gesetzlichen Vertretung der juristischen Person berufen ist,
2.
in Betrieben einer Personengesamtheit die durch Gesetz, Satzung oder Gesellschaftsvertrag zur Vertretung der Personengesamtheit berufenen Personen,
3.
Geschäftsführer, Betriebsleiter und ähnliche leitende Personen, soweit diese zur selbständigen Einstellung oder Entlassung von Arbeitnehmern berechtigt sind.
(1) Entlassungen, die nach § 17 anzuzeigen sind, werden vor Ablauf eines Monats nach Eingang der Anzeige bei der Agentur für Arbeit nur mit deren Zustimmung wirksam; die Zustimmung kann auch rückwirkend bis zum Tage der Antragstellung erteilt werden.
(2) Die Agentur für Arbeit kann im Einzelfall bestimmen, daß die Entlassungen nicht vor Ablauf von längstens zwei Monaten nach Eingang der Anzeige wirksam werden.
(3) (weggefallen)
(4) Soweit die Entlassungen nicht innerhalb von 90 Tagen nach dem Zeitpunkt, zu dem sie nach den Absätzen 1 und 2 zulässig sind, durchgeführt werden, bedarf es unter den Voraussetzungen des § 17 Abs. 1 einer erneuten Anzeige.
(1) Ist der Arbeitgeber nicht in der Lage, die Arbeitnehmer bis zu dem in § 18 Abs. 1 und 2 bezeichneten Zeitpunkt voll zu beschäftigen, so kann die Bundesagentur für Arbeit zulassen, daß der Arbeitgeber für die Zwischenzeit Kurzarbeit einführt.
(2) Der Arbeitgeber ist im Falle der Kurzarbeit berechtigt, Lohn oder Gehalt der mit verkürzter Arbeitszeit beschäftigten Arbeitnehmer entsprechend zu kürzen; die Kürzung des Arbeitsentgelts wird jedoch erst von dem Zeitpunkt an wirksam, an dem das Arbeitsverhältnis nach den allgemeinen gesetzlichen oder den vereinbarten Bestimmungen enden würde.
(3) Tarifvertragliche Bestimmungen über die Einführung, das Ausmaß und die Bezahlung von Kurzarbeit werden durch die Absätze 1 und 2 nicht berührt.
(1) Die Entscheidungen der Agentur für Arbeit nach § 18 Abs. 1 und 2 trifft deren Geschäftsführung oder ein Ausschuß (Entscheidungsträger). Die Geschäftsführung darf nur dann entscheiden, wenn die Zahl der Entlassungen weniger als 50 beträgt.
(2) Der Ausschuß setzt sich aus dem Geschäftsführer, der Geschäftsführerin oder dem oder der Vorsitzenden der Geschäftsführung der Agentur für Arbeit oder einem von ihm oder ihr beauftragten Angehörigen der Agentur für Arbeit als Vorsitzenden und je zwei Vertretern der Arbeitnehmer, der Arbeitgeber und der öffentlichen Körperschaften zusammen, die von dem Verwaltungsausschuss der Agentur für Arbeit benannt werden. Er trifft seine Entscheidungen mit Stimmenmehrheit.
(3) Der Entscheidungsträger hat vor seiner Entscheidung von Arbeitgeber und den Betriebsrat anzuhören. Dem Entscheidungsträger sind, insbesondere vom Arbeitgeber und Betriebsrat, die von ihm für die Beurteilung des Falles erforderlich gehaltenen Auskünfte zu erteilen.
(4) Der Entscheidungsträger hat sowohl das Interesse des Arbeitgebers als auch das der zu entlassenden Arbeitnehmer, das öffentliche Interesse und die Lage des gesamten Arbeitsmarktes unter besonderer Beachtung des Wirtschaftszweiges, dem der Betrieb angehört, zu berücksichtigen.
Für Betriebe, die zum Geschäftsbereich des Bundesministers für Verkehr oder des Bundesministers für Post und Telekommunikation gehören, trifft, wenn mehr als 500 Arbeitnehmer entlassen werden sollen, ein gemäß § 20 Abs. 1 bei der Zentrale der Bundesagentur für Arbeit zu bildender Ausschuß die Entscheidungen nach § 18 Abs. 1 und 2. Der zuständige Bundesminister kann zwei Vertreter mit beratender Stimme in den Ausschuß entsenden. Die Anzeigen nach § 17 sind in diesem Falle an die Zentrale der Bundesagentur für Arbeit zu erstatten. Im übrigen gilt § 20 Abs. 1 bis 3 entsprechend.
(1) Auf Saisonbetriebe und Kampagne-Betriebe finden die Vorschriften dieses Abschnitts bei Entlassungen, die durch diese Eigenart der Betriebe bedingt sind, keine Anwendung.
(2) Keine Saisonbetriebe oder Kampagne-Betriebe sind Betriebe des Baugewerbes, in denen die ganzjährige Beschäftigung nach dem Dritten Buch Sozialgesetzbuch gefördert wird. Das Bundesministerium für Arbeit und Soziales wird ermächtigt, durch Rechtsverordnung Vorschriften zu erlassen, welche Betriebe als Saisonbetriebe oder Kampagne-Betriebe im Sinne des Absatzes 1 gelten.
(1) Die Vorschriften des Ersten und Zweiten Abschnitts gelten für Betriebe und Verwaltungen des privaten und des öffentlichen Rechts, vorbehaltlich der Vorschriften des § 24 für die Seeschiffahrts-, Binnenschiffahrts- und Luftverkehrsbetriebe.
Die Vorschriften des Ersten Abschnitts gelten mit Ausnahme der §§ 4 bis 7 und des § 13 Abs. 1 Satz 1 und 2 nicht für Betriebe und Verwaltungen, in denen in der Regel fünf oder weniger Arbeitnehmer ausschließlich der zu ihrer Berufsbildung Beschäftigten beschäftigt werden.
In Betrieben und Verwaltungen, in denen XXXin der Regel zehn oder weniger Arbeitnehmer ausschließlich der zu ihrer Berufsbildung Beschäftigten beschäftigt werden,XXX gelten die Vorschriften des Ersten Abschnitts mit Ausnahme der §§ 4 bis 7 und des § 13 Abs. 1 Satz 1 und 2 nicht für Arbeitnehmer, deren Arbeitsverhältnis nach dem 31. Dezember 2003 begonnen hat; diese Arbeitnehmer sind bei der Feststellung der Zahl der beschäftigten Arbeitnehmer nach Satz 2 bis zur Beschäftigung von in der Regel zehn Arbeitnehmern nicht zu berücksichtigen. Bei der Feststellung der Zahl der beschäftigten Arbeitnehmer nach den Sätzen 2 und 3 sind teilzeitbeschäftigte Arbeitnehmer mit einer regelmäßigen wöchentlichen Arbeitszeit von nicht mehr als 20 Stunden mit 0,5 und nicht mehr als 30 Stunden mit 0,75 zu berücksichtigen.
(2) Die Vorschriften des Dritten Abschnitts gelten für Betriebe und Verwaltungen des privaten Rechts sowie für Betriebe, die von einer öffentlichen Verwaltung geführt werden, soweit sie wirtschaftliche Zwecke verfolgen.
(1) Die Vorschriften des Ersten und Zweiten Abschnitts finden nach Maßgabe der Absätze 2 bis 4 auf Arbeitsverhältnisse der Besatzung von Seeschiffen, Binnenschiffen und Luftfahrzeugen Anwendung.
(2) Als Betrieb im Sinne dieses Gesetzes gilt jeweils die Gesamtheit der Seeschiffe oder der Binnenschiffe eines Schifffahrtsbetriebs oder der Luftfahrzeuge eines Luftverkehrsbetriebs.
(3) Dauert die erste Reise eines Besatzungsmitglieds eines Seeschiffes oder eines Binnenschiffes länger als sechs Monate, so verlängert sich die Sechsmonatsfrist des § 1 Absatz 1 bis drei Tage nach Beendigung dieser Reise.
(4) Die Klage nach § 4 ist binnen drei Wochen zu erheben, nachdem die Kündigung dem Besatzungsmitglied an Land zugegangen ist. Geht dem Besatzungsmitglied eines Seeschiffes oder eines Binnenschiffes die Kündigung während der Fahrt des Schiffes zu, ist die Klage innerhalb von sechs Wochen nach dem Dienstende an Bord zu erheben. An die Stelle der Dreiwochenfrist in § 5 Absatz 1 und § 6 treten die hier in den Sätzen 1 und 2 genannten Fristen.
(5) Die Vorschriften des Dritten Abschnitts finden nach Maßgabe der folgenden Sätze Anwendung auf die Besatzungen von Seeschiffen. Bei Schiffen nach § 114 Absatz 4 Satz 1 des Betriebsverfassungsgesetzes tritt, soweit sie nicht als Teil des Landbetriebs gelten, an die Stelle des Betriebsrats der Seebetriebsrat. Betrifft eine anzeigepflichtige Entlassung die Besatzung eines Seeschiffes, welches unter der Flagge eines anderen Mitgliedstaates der Europäischen Union fährt, so ist die Anzeige an die Behörde des Staates zu richten, unter dessen Flagge das Schiff fährt.
Die Vorschriften dieses Gesetzes finden keine Anwendung auf Kündigungen und Entlassungen, die lediglich als Maßnahmen in wirtschaftlichen Kämpfen zwischen Arbeitgebern und Arbeitnehmern vorgenommen werden.
Dieses Gesetz gilt nach Maßgabe des § 13 Abs. 1 des Dritten Überleitungsgesetzes auch im Land Berlin. Rechtsverordnungen, die auf Grund dieses Gesetzes erlassen werden, gelten im Land Berlin nach § 14 des Dritten Überleitungsgesetzes.
Dieses Gesetz tritt am Tag nach seiner Verkündung in Kraft.
BEGEHREN
Unterscheidung
Gewerbemietverhältnis oder Mietverhältnis über Wohnraum
Unterscheidung zwischen kündigendem Mieter oder Vermieter
Mietverhältnis auf bestimmte Zeit oder unbestimmte Zeit
AGL in TABS
gemeinsaman sind immer
Kündigungsgrund, Kündigungserklärung, Kündigungsfrist und kein Ausschluss
<<tabs "[tag[Wohnungskündigung]]" "" "" "">>
ERGEBNIS
Kündigung wegen vorgetäuschter Krankheit
Landesarbeitsgericht hält fristlose Kündigung für wirksam: Hessisches Landesarbeitsgericht, Urteil vom 01.04.2009, 6 Sa 1593/08
Rechte Hand mit roter Karte (fristlose) Kündigung wegen vorgetäuschter Krankheit
04.02.2010. Wer sich arbeitsunfähig krank meldet, tatsächlich aber nicht krank ist, riskiert seine (fristlose) Kündigung.
Allerdings gilt die ärztliche Arbeitsunfähigkeitsbescheinigung ("Krankschreibung") nach der Rechtsprechung der Arbeitsgerichte als Beweis, dass der Arbeitnehmer tatsächlich arbeitsunfähig erkrankt ist.
Arbeitgeber scheitern deshalb meistens mit der Behauptung, der Arbeitnehmer sei gar nicht krank.
Dass der Nachweis einer vorgetäuschten Erkrankung ausnahmsweise doch gelingen kann, zeigt die folgende Entscheidung des Hessischen Landesarbeitsgerichts (LAG): Hessisches LAG, Urteil vom 01.04.2009, 6 Sa 1593/08.
Arbeitsunfähigkeit und Beweiswert der Krankschreibung
Der Fall des Hessischen Landesarbeitsgerichts: Arbeitnehmer täuscht Arbeitsunfähigkeit vor und läßt sich von Detektiv täuschen
Hessisches Landesarbeitsgericht: Beweiswert der Krankschreibung erschüttert. Fristlose Kündigung wirksam
Arbeitsunfähigkeit und Beweiswert der Krankschreibung
Wird ein Arbeitnehmer durch Arbeitsunfähigkeit infolge Krankheit an seiner Arbeitsleistung gehindert, ohne dass ihn ein Verschulden trifft, so hat er Anspruch auf Entgeltfortzahlung im Krankheitsfall durch den Arbeitgeber für die Zeit der Arbeitsunfähigkeit bis zur Dauer von sechs Wochen (§ 3 Abs.1 Satz 1 Entgeltfortzahlungsgesetz - EFZG).
Dementsprechend ist er nicht nur wegen des arbeitgeberseitigen Interesses an einer effektiven Personalplanung verpflichtet, dem Arbeitgeber die Arbeitsunfähigkeit und deren voraussichtliche Dauer unverzüglich mitzuteilen.
Dauert die Arbeitsunfähigkeit länger als drei Kalendertage, hat der Arbeitnehmer eine ärztliche Bescheinigung über das Bestehen der Arbeitsunfähigkeit ("AU-Bescheinigung") sowie deren voraussichtliche Dauer spätestens an dem darauf folgenden Arbeitstag vorzulegen, sofern der Arbeitgeber sie nicht früher verlangt (§ 5 Abs.1 EFZG).
Täuscht der Arbeitnehmer seine Erkrankung nur vor, liegt hierin in der Regel eine schwerwiegende Pflichtverletzung sowie Störung des Vertrauensverhältnisses, die zur ordentlichen oder außerordentlichen Kündigung berechtigt.
Problematisch ist allerdings, unter welchen Umständen dem Arbeitnehmer, der eine Arbeitsunfähigkeitsbescheinigung vorgelegt hat, die Vortäuschung einer Krankheit nachgewiesen werden kann. Denn die für Kassenärzte verbindlichen Arbeitsunfähigkeits-Richtlinien stellen formal hohe Anforderungen an die Ausstellung einer AU-Bescheinigung.
So muss der Arzt den Arbeitnehmer zur aktuell ausgeübten Tätigkeit und den damit verbundenen Anforderungen und Belastungen befragen, da Arbeitsunfähigkeit voraussetzt, dass der Arbeitnehmer seine derzeitige Tätigkeit wegen seiner Krankheit nicht mehr ausüben kann oder dies absehbarer Zeit der Fall sein wird.
Bei zumindest grob fahrlässigen Falschdiagnosen steht eine Schadensersatzpflicht des Arztes gegenüber Arbeitgeber und Krankenkasse und bei Vorsatz zudem noch eine Strafbarkeit wegen des Ausstellens unrichtiger Gesundheitszeugnisse (§ 278 Strafgesetzbuch - StGB) im Raum.
Aus diesen Gründen ist es nicht verwunderlich, dass die arbeitsrechtliche Rechtsprechung AU-Bescheinigungen einen so hohen Beweiswert zugesteht, dass fraglich ist, wie der Beweis erschüttert werden kann. Einen Fall, in dem der Arbeitgeber damit erfolgreich war, entschied vor kurzem das Hessisches LAG (Urteil vom 01.04.2009, 6 Sa 1593/08).
Der Fall des Hessischen Landesarbeitsgerichts: Arbeitnehmer täuscht Arbeitsunfähigkeit vor und läßt sich von Detektiv täuschen
Ein Schweißer, der mehreren Kindern zum Unterhalt verpflichtet war, arbeitete seit mehr als zwanzig Jahren bei einem Metallunternehmen. Nachdem dieses ihm eine betriebsbedingte Kündigung ausgesprochen hatte, stieg dessen Krankenstand innerhalb der siebenmonatigen Kündigungsfrist deutlich an. Der Arbeitgeber schaltete deshalb einen Detektiv ein.
Nachdem der Arbeitnehmer nach Vorlage einer AU-Bescheinung länger als sechs Wochen krank geschrieben war, rief der Ermittler bei ihm unter einem Vorwand an und teilte mit, er suche jemanden für schwere körperliche Arbeiten wie Wände einreißen, Mauern und Malerarbeiten.
Der weitere Verlauf des Gesprächs ist streitig. Während der Detektiv im Wesentlichen behauptete, der Schweißer habe das Angebot freudig aufgegriffen und sich sofort bereit erklärt, trug der Schweißer vor, er habe nur angeboten, Verwandte und Kollegen zu fragen.
Der Arbeitgeber schenkte naturgemäß eher seinem "Lockvogel" Glauben und kündigte das Arbeitsverhältnis mit dem Vorwurf der vorgetäuschten Arbeitsunfähigkeit fristlos.
Mit seiner daraufhin erhobenen Kündigungsschutzklage war der Schweißer zunächst erfolgreich. Doch der Arbeitgeber legte Berufung ein.
Hessisches Landesarbeitsgericht: Beweiswert der Krankschreibung erschüttert. Fristlose Kündigung wirksam
Das Landesarbeitsgericht (LAG) hörte den Detektiv als Zeugen an, glaubte seiner Aussage und wies die Kündigungsschutzklage daher als unbegründet ab. Zur Begründung heißt es in der derzeit allein vorliegenden Pressemeldung des Gerichts:
Schon die angekündigte Arbeitsbereitschaft erschüttert nach Auffassung des Gerichtes den an sich hohen Beweiswert eines Arbeitsunfähigkeits-Attestes.
Da der sechswöchige Entgeltfortzahlungszeitraum des § 3 EFZG bereits abgelaufen war, hatte sich der Schweißer zwar keine Entgeltfortzahlungen des Arbeitgebers erschlichen, ihm aber sehr wohl seine vertraglich geschuldete Arbeitsleistung vorenthalten. Dies sei, so argumentiert das Gericht nachvollziehbar weiter, eine schwerwiegende Verletzung sowohl der Hauptleistungspflicht als auch der Vertrauensbasis zwischen den Parteien.
Dem Arbeitnehmer müsse in einer solchen Situation klar sein, dass ihm auch ohne vorherige Abmahnung gekündigt werden könne. Dies gelte selbst dann, wenn es sich nur um einen Einzelfall handle.
Auch die Interessenabwägung ging nicht zu Gunsten des klagenden Arbeitnehmers aus. Zwar sprachen für ihn die lange Dauer seines Arbeitsverhältnisses sowie die bestehenden Unterhaltspflichten. Gleichwohl überwog nach Auffassung des Gerichtes das Auflösungsinteresse des Arbeitgebers. Dieser müsse nämlich berücksichtigen, wie sich das Verhalten auf das der übrigen Arbeitnehmer auswirke, wenn er von einer Kündigung absieht. Insoweit handle es sich um Folgen des Fehlverhaltens, für das der Arbeitnehmer einzustehen habe.
Fazit: Die vorliegende Konstellation ist einer der wenigen Fälle, in dem dem Arbeitgeber der Nachweis einer vorgetäuschten Krankheit gelang.
Denn die von Arbeitgebern oft vorgebrachte Behauptung, der Arbeitnehmer sei trotz Vorliegen einer Arbeitsunfähigkeitsbescheinigung in Wirklichkeit nicht krank, hilft meist nicht, da nach der Rechtsprechung die Krankschreibung ein zunächst ausreichender "Beweis" für die Arbeitsunfähigkeit ist und der Arbeitgeber deshalb den Beweiswert der Krankschreibung mit stichhaltigen Gegenbeweisen entkräften muss. Dazu reicht z.B. nicht die Behauptung, der krankgeschriebene Arbeitnehmer sei "putzmunter" spazieren gegangen, denn nicht jede Erkrankung führt zur Bettlägerigkeit.
Aber auch dann, wenn der Arbeitgeber - wie hier im Streitfall - Tatsachen vortragen kann, die den Beweiswert der Krankschreibung erschüttern, muss sich das Gericht mit den Attesten inhaltlich auseinandersetzen und die Ärzte als Zeugen zu ihrer Krankschreibung vernehmen. Denn auch in Fällen wie dem hier entschiedenen kann es ja sein, dass die ärztlichen Bescheinigungen der Arbeitsunfähigkeit in der Sache richtig sind. Dann hätte sich der Arbeitnehmer zwar verdächtig gemacht, vielleicht auch eine Täuschungsabsicht gehabt, wäre aber objektiv trotzdem krank gewesen. Dann kann von einem Vortäuschen einer Arbeitsunfähigkeit keine Rede sein.
<$navigator story="Kündigungserklärung:story" history="Kündigungserklärung:history">
Erklärung mit dem Inhalt einer Kündigung des Arbeitsverhältnisses mit einer bestimmten Frist
<$list filter="[list[Kündigungserklärung:story]]" template="PE:view" editTemplate="PE:edit" emptyMessage={{PE:empty}} />
</$navigator>
---
<!--
<<list-links "[prefix[Kündigungserklärung:]]">>
<<list-links "[list[Kündigungserklärung:story]]">>
<<list-links "[all[shadows]prefix[$:/core/ui/Buttons/]] +[limit[0]]">>-->
[
{
"title": "Draft of 'New Tiddler'"
},
{
"title": "Draft of 'New Tiddler 1'"
},
{
"title": "Draft of 'New Tiddler 1'"
},
{
"title": "Draft of 'New Tiddler'"
},
{
"title": "Schriftform"
},
{
"title": "Draft of 'Schriftform'"
},
{
"title": "Schriftform"
},
{
"title": "Draft of 'New Tiddler'"
},
{
"title": "Wirksamkeit"
},
{
"title": "Draft 2 of 'New Tiddler 1' by cyrill"
},
{
"title": "Draft of 'New Tiddler 2' by cyrill"
}
]
* [[Personenbedingte Kündigung]]
* [[Verhaltenbedingte Kündigung]]
* [[Betriebsbedingte Kündigung]]
BGH: Ladung eines Sachverständigen zur mündlichen Erläuterung auf Parteiantrag
GG Art. 103 I; ZPO §§ 397, 402
1. Für die Frage, ob die Ladung eines Sachverständigen zur mündlichen Erläuterung des von ihm erstatteten Gutachtens geboten ist, kommt es nicht darauf an, ob das Gericht noch Erläuterungsbedarf sieht oder ob ein solcher von einer Partei nachvollziehbar dargetan worden ist. Jede Partei hat einen Anspruch darauf, dass sie dem Sachverständigen die Fragen, die sie zur Aufklärung der Sache für erforderlich hält, zur mündlichen Beantwortung vorlegen kann (§§ 397, 402 ZPO).
2. Hat das Erstgericht einem rechtzeitig gestellten Antrag auf Ladung eines Sachverständigen zur mündlichen Erläuterung seines schriftlichen Gutachtens nicht entsprochen, so muss das Berufungsgericht dem im zweiten Rechtszug wiederholten Antrag stattgeben. (Leitsätze des Gerichts)
BGH, Beschluss vom 30.05.2017 - VI ZR 439/16, BeckRS 2017, 121826
Anmerkung von
Rechtsanwalt beim BGH Dr. Guido Toussaint, Toussaint & Schmitt, Karlsruhe
Aus beck-fachdienst Zivilverfahrensrecht 17/2017 vom 01.09.2017
Diese Urteilsbesprechung ist Teil des zweiwöchentlich erscheinenden Fachdienstes Zivilverfahrensrecht. Neben weiteren ausführlichen Besprechungen der entscheidenden aktuellen Urteile im Zivilverfahrensrecht beinhaltet er ergänzende Leitsatzübersichten und einen Überblick über die relevanten neu erschienenen Aufsätze. Zudem informiert er Sie in einem Nachrichtenblock über die wichtigen Entwicklungen in Gesetzgebung und Praxis des Zivilverfahrensrechts. Weitere Informationen und eine Schnellbestellmöglichkeit finden Sie unter www.beck-online.de
Sachverhalt
Die Klägerin nimmt die Beklagte auf materiellen und immateriellen Schadensersatz nach ärztlicher Behandlung in Anspruch. Das LG hat die Klage auf der Grundlage eines schriftlichen orthopädisch-unfallchirurgischen Fachgutachtens samt Ergänzungsgutachten abgewiesen. Von einer mündlichen Anhörung des Sachverständigen hat das LG trotz entsprechenden Antrags der Klägerin abgesehen. Die Berufung der Klägerin hat das OLG im Beschlusswege (§ 522 II ZPO) zurückgewiesen. Eine Anhörung des Sachverständigen sei nicht erforderlich. Anhaltspunkte für eine Verwechslung der bei den Akten befindlichen intraoperativen Röntgenbilder oder für deren unzureichende Aussagekraft wegen Fehlens der zweiten Ebene bestünden entgegen der Auffassung der Klägerin nicht. Im Übrigen fehle es an einer haftungsbegründenden Kausalität, weil die Kniebeschwerden der Klägerin nicht auf die behaupteten Behandlungsfehler, sondern auf eine unabhängig hiervon vorliegende Fehlstellung und auf Verschleiß zurückzuführen seien. Die Revision hat das OLG nicht zugelassen.
Entscheidung
Auf die (der Sache nach auf Ansprüche aus einer von mehreren ärztlichen Behandlungen beschränkte) Nichtzulassungsbeschwerde der Klägerin hat der BGH den Beschluss des OLG (im Umfang der Anfechtung) – wie von § 544 VII ZPO bei Vorliegen einer Gehörsverletzung als Zulassungs- und Revisionsgrund ermöglicht – sogleich aufgehoben und die Sache (im Umfang der Aufhebung) zur neuen Verhandlung und Entscheidung an das Berufungsgericht zurückverwiesen. Die Klägerin sei durch die Zurückweisung ihres Antrags auf mündliche Anhörung des Sachverständigen in ihrem verfassungsrechtlich geschützten Anspruch auf Gewährung rechtlichen Gehörs (Art. 103 I GG) verletzt worden. Für die Frage, ob die Ladung eines Sachverständigen zur mündlichen Erläuterung des von ihm erstatteten Gutachtens geboten sei, komme es nicht darauf an, ob das Gericht noch Erläuterungsbedarf sehe oder ob ein solcher von einer Partei nachvollziehbar dargetan worden sei. Vielmehr habe die Partei zur Gewährleistung des rechtlichen Gehörs nach §§ 397, 402 ZPO einen Anspruch darauf, dass sie dem Sachverständigen die Fragen, die sie zur Aufklärung der Sache für erforderlich halte, zur mündlichen Beantwortung vorlegen könne. Dieses Antragsrecht bestehe unabhängig von § 411 III ZPO. Habe das Erstgericht einem rechtzeitig gestellten Antrag auf Ladung eines Sachverständigen zur mündlichen Erläuterung seines schriftlichen Gutachtens nicht entsprochen, so müsse das Berufungsgericht dem im zweiten Rechtszug wiederholten Antrag stattgeben. Dies zugrunde legend, reiche die Begründung des Berufungsgerichts, die schriftlichen Ausführungen des Gutachters ließen eine klare Beurteilung zu, für eine Ablehnung des Antrags der Klägerin auf Anhörung des gerichtlichen Sachverständigen nicht aus. Die Klägerin habe bereits im ersten Rechtszug die Anhörung des Sachverständigen beantragt. Darauf habe sie in ihrer Berufungsbegründung hingewiesen und den Antrag auf Anhörung des Sachverständigen wiederholt. Sie habe dabei und der Sache nach auch in ihrer Stellungnahme auf den Hinweis des Berufungsgerichts nach § 522 II 2 ZPO konkrete Gegenstände der Anhörung, insbesondere die Möglichkeit einer Verwechslung der intraoperativen Röntgenaufnahmen sowie die Frage von deren Geeignetheit trotz Fehlens einer zweiten Ebene benannt. Unter diesen Umständen habe das Berufungsgericht den Sachverständigen anhören müssen, um dem Anspruch der Klägerin auf Gewährung rechtlichen Gehörs zu genügen. Die Gehörsverletzung sei auch erheblich. Es könne – wie weiter ausgeführt wird – nicht ausgeschlossen werden, dass das Berufungsgericht bei der gebotenen Anhörung zu einer anderen Beurteilung des Falles gekommen wäre.
Praxishinweis
Die Rechtslage ist eindeutig: Da die Partei zur Gewährleistung des rechtlichen Gehörs nach §§ 397, 402 ZPO einen Anspruch darauf hat, dass sie dem Sachverständigen die Fragen, die sie zur Erläuterung der Sache für erforderlich hält, zur mündlichen Beantwortung vorlegen kann, ist ihrem Antrag auf Ladung des Sachverständigen zur Erläuterung seines schriftlichen Gutachtens grundsätzlich zu entsprechen, auch wenn das Gericht das schriftliche Gutachten für überzeugend hält und selbst keinen weiteren Erläuterungsbedarf sieht; Beschränkungen des Antragsrechts können sich allenfalls aus dem Gesichtspunkt des Rechtsmissbrauchs oder der Prozessverschleppung ergeben (vgl. BGH NJW-RR 2003, 208). Erstaunlich ist, dass – wie eine Vielzahl einschlägiger Entscheidungen des BGH belegt – Gerichte dies immer wieder verkennen.
bei Arbeitnehmern in der Regel (-)
Andere Beurteilung bei sehr hohen Einkünfte
n oder bei Prägung der ehelichen Lebensverhältnisse möglich. Bei Selbständigen (+) im Rahmen einer angemessenen Altersvorsorge.
Beiträge für eine Risikolebensversicherung das anzurechnende Einkommen reduzieren können.
Der BGH entschieden, dass es sich im tatrichterlichen Ermessen hält, wenn Beiträge für eine Risikolebensversicherung nach den Umständen des Einzelfalls einkommensmindernd berücksichtigt werden.
Dies ist beispielsweise dann geboten, wenn die Beiträge wegen der Höhe eine besondere Belastung darstellen, bereits über einen längeren Zeitraum aufgewandt werden oder ein spezifisches Risiko des Unterhaltspflichtigen abdecken sollen. (BGH, Beschl. v. 18.01.2017 – XII ZB 118)
[[Displayed Link Title|Tiddler Title]]
<$list filter='[enlist{!!my_list}]'>
<<currentTiddler>><br>
</$list>
For the first pass I am just going to say `A` is `has[a]`, that the tiddler has a field called `a`, and `B` is `has[b]`. All of these are also done using a single filter. If you use nested filters or the `emptyMessage` parameter of the list widget you can do further operations.
Order matters. This may be one thing to find a way around to allow for all the logical operations. Order mattering means that you can't have two negations of complex statements like `¬(A+B)+¬(B+C)` which would be something like `[all[]]-[has[a]]-[has[b]][all[]]-[has[b]]-[has[c]]` because to make the negation you need to use `[all[]]` which ignores anything to the right of that part of the filter.
If you start the statement with something like `¬(A.B)` or `¬(A+B)` you need to start with `[all[]]` and remove things from that.
You can replace `has` with some of the other operators, I may make a full list at some point. The easiest is `tag` and `field`. You can mix together operators, so `A` could be `has[a]` and `B` could be `field:b[foo]` and so on.
You can't do `A+¬x` for any `x` where `x` isn't a single operator that supports negation. So you can do `[has[a]][!has[b]]` which is `A+¬B`, but you can't do `A+¬(B.C)` directly, you have to change it to `A+¬B+¬C`. The same thing for `A+¬(B+C)` and `A.¬(B+C)`.
!Identity
This returns true when the input is true
The most basic thing building block, just one thing by itself. In filters the simplest form is single filter operators like `[has[a]]`, `[tag[a]]`, `[is[current]]`
```
A ⇔ [has[a]]
⇔ ¬(¬A)
⇔ [all[]]-[!has[a]]
```
!Not
This returns true when the input is false
The negation of a thing. In the simplest form it is negated filter operators like `[!has[a]]`, `[!tag[a]]`, `[!is[current]]`
```
¬A ⇔ [!has[a]]
⇔ ¬(A)
⇔ [all[]]-[has[a]]
```
!And
This returns true when all of the inputs are true
Two things simultaneously! In filters this is done like `[has[a]has[b]]`
```
A.B ⇔ [has[a]has[b]]
⇔ ¬(¬A+¬B)
⇔ [all[]]-[!has[a]]-[!has[b]]
```
!Nand
This returns true unless all of the inputs are true
This is the negation of and, so anything other than the two things at the same time. In filters this is done like `[all[]]-[has[a]has[b]]`
```
¬(A.B) ⇔ [all[]]-[has[a]has[b]]
⇔ ¬A+¬B
⇔ [!has[a]][!has[b]]
```
!Or
This returns true when any of the inputs are true
This is the logical or, it is true when at least one of the inputs is true. Unlike or in spoken language this can be true when there are multiple true inputs.
In filters this is done like `[has[a]][has[b]]`
```
A+B ⇔ [has[a]][has[b]]
⇔ ¬(¬A.¬B)
⇔ [all[]]-[!has[a]!has[b]]
```
!Nor
This returns true when exactly zero inputs are true
This is the negation of or, so it is true when exactly zero of the inputs are true. In filters this is done like `[all[]]-[has[a]]-[has[b]]`
```
¬(A+B) ⇔ [all[]]-[has[a]]-[has[b]]
⇔ ¬A.¬B
⇔ [!has[a]!has[b]]
```
!Xor
This returns true when exactly one of the inputs is true
This is closer to or in spoken english
```
A⊕B ⇔ ??? (We can't do this directly, so substitute in the definition!)
⇔ (A.¬B)+(¬A.B)
⇔ [has[a]!has[b]][!has[a]has[b]]
```
!More Complex Statements
```
A+(B.C) ⇔ [has[a]][has[b]has[c]]
⇔ A+¬(¬B+¬C) (You can not make this filter directly because filters are evaluated left to right and [all[]] replaces the input list, so commutative property!!)
⇔ ¬(¬B+¬C)+A
⇔ [all[]]-[!has[b]]-[!has[c]][has[a]]
```
```
A+¬(B.C) ⇔ ??? (You can't do this in this order... So commutative property thingy.)
⇔ ¬(B.C)+A
⇔ [all[]]-[has[b]has[c]][has[a]]
⇔ A+¬B+¬C
⇔ [has[a]][!has[b]][!has[c]]
⇔ ¬(¬A.B.C) (Another De Morgan's law, because I said so.)
⇔ [all[]]-[!has[a]has[b]has[c]]
```
Note that `A+¬(B.C)` is not the same as `[has[a]]-[has[b]has[c]]`, which is `A.¬(B.C)`
```
A.¬(B.C) ⇔ [has[a]]-[has[b]has[c]]
⇔ A.(¬B+¬C) (After De Morgan's law, This one can't be done directly, so we distribute A)
⇔ A.¬B+A.¬C
⇔ [has[a]!has[b]][has[a]!has[c]]
⇔ ¬(¬A+B)+¬(¬A+C) (Another De Morgan's law, just for fun...)
⇔ This one can't be done because you can't or a negation using filters
```
```
A.¬(B+C) ⇔ ??? (Can't do this directly and commutative property won't save us here... De Morgan's law!)
⇔ A.¬B.¬C
⇔ [has[a]!has[b]!has[c]]
⇔ ¬(¬A+B+C) (Another De Morgan's law, just for fun...)
⇔ [all[]]-[!has[a]has[b]has[c]]
```
```
¬(A+B)+¬(B+C) ⇔ ??? (Can't do this directly because there are two negations of non-trivial things)
⇔ ¬((A+B).(B+C)) (can't do this, try De Morgan's again?)
⇔ (¬A.¬B)+(¬B.¬C) (we can work with this)
⇔ [!has[a]!has[b]][!has[b]!has[c]]
```
```
¬(A.B)+¬(C.D) ⇔ ??? (Can't do this directly because it has two negations again)
⇔ ¬((A.B).(C.D))
⇔ ¬(A.B.C.D)
⇔ [all[]]-[has[a]has[b]has[c]has[d]]
```
```
¬(A.B).¬(C.D) ⇔ ???
⇔ ¬((A.B)+(C.D))
⇔ ¬(A.B).¬(C.D)
⇔ [all[]]-[has[a]has[b]]-[has[c]has[d]]
```
```
¬(A+B).¬(C+D) ⇔ ???
⇔ ¬((A+B)+(C+D))
⇔ ¬(A+B+C+D)
⇔ ¬A.¬B.¬C.¬D
⇔ [!has[a]!has[b]!has[c]!has[d]]
⇔ ¬(A+B+C+D)
⇔ [all[]]-[has[a]]-[has[b]]-[has[c]]-[has[d]]
```
```
¬(A+B).¬(C.D) ⇔ ???
⇔ ¬((A+B)+(C.D))
⇔ ¬(A+B+(C.D))
⇔ [all[]]-[has[a]]-[has[b]]-[has[c][has[d]]
⇔ ¬A.¬B.¬(C.D)
⇔ [!has[a]!has[b]]-[has[c]has[d]]
```
```
(A+B).¬(C.D) ⇔ ???
⇔ ¬(¬(A+B)+(C.D))
⇔ ¬((¬A.¬B)+(C.D))
⇔ ¬(¬A.¬B).¬(C.D)
⇔ [all[]]-[!has[a]!has[b]]-[has[c]has[d]]
```
```
A.¬((B.C)+¬(D.E)) ⇔ ???
⇔ A.(¬(B.C).(D.E))
⇔ A.¬(B.C).D.E
⇔ A.D.E.¬(B.C)
⇔ [has[a]has[d]has[e]]-[has[b]has[c]]
```
\define kindfilter() [kind[$(currentValue)$]]
Related:
* http://tobibeer.github.io/tb5/#A%20Hierarchy%20Without%20Tags
If you add `kind` field to a tag, then it will be listed under the value of it.
<ul>
<$list filter="[get[kind]] +[each:value[]]" variable="currentValue">
<li><<currentValue>>
<ul>
<$list filter="[kind<currentValue>]" variable="title">
<li><<title>></li>
</$list>
</ul>
</li>
</$list>
</ul>
\define fieldfilter() [$(currentField)$[$(currentValue)$]] -[is[system]]
Related:
* http://tobibeer.github.io/tb5/#A%20Hierarchy%20Without%20Tags
* http://tobibeer.github.io/tb5/#Grouped%20List
* http://tobibeer.github.io/tb5/#Searching%20In%20Tiddler%20Fields
List of all tiddlers grouped by type field (field name starts with `type`):
<ul>
<$list filter="[fields[]prefix[type]sort[title]]" variable="currentField">
<li><<currentField>>
<ul>
<$list filter="[get<currentField>] +[each:value[]]" variable="currentValue">
<li><<currentValue>>
<ul>
<$list filter=<<fieldfilter>> variable="title">
<li><<title>></li>
</$list>
</ul>
</li>
</$list>
</ul>
</li>
</$list>
</ul>
a solution that suites my way of thinking.
This is working with a different prefix and suffix
```
\define tags-here-filter(prefix suffix) $prefix$<$list filter={{!!tags}} variable=tag-here>tag[<<tag-here>>]</$list>$suffix$
<$wikify name=filter text="""<<tags-here-filter "[!is[system]" "has[uw-inf]] +[sort[uw-inf]]">>""">
<$list filter=<<filter>> >
</$list>
</$wikify>
```
```
First, we need some wiki syntax for generating the desired output
```
<$list filter="[tag[AGL-Template]]"><$text text={{!!text}}/></$list>
```
Next, we can capture that output to a variable, using the ``<$wikify>`` widget
```
<$wikify name="out" text="""<$list filter="[tag[AGL-Template]]"><$text text={{!!text}}/></$list>""">
<<out>>
</$wikify>
```
Then, wrap that in a button so we can trigger an action to save the output to a tiddler instead of directly rendering the output
```
<$button> CLICK ME
<$wikify name="out" text="""<$list filter="[tag[AGL-Template]]"><$text text={{!!text}}/></$list>""">
<$action-setfield $tiddler="JoinedOutput" text=<<out>> />
</$wikify>
</$button>
```
look further in [[Join Macro]]
```
''lists all tiddlers where `foo` listed in the list field''
```
<$list filter="[[foo]listed[]]">
<<currentTiddler>><br>
</$list>
```
<<<
<$list filter="[[foo]listed[]]">
<<currentTiddler>><br>
</$list>
<<<
''proof''
```
{{ExampleTiddler!!list}}
```
<<<
{{ExampleTiddler!!list}}
<<<
<<locator-view "TableOfContents">>
LOIS Projekt mit europäischen Partnern (Universitäten und Wirtschafts-unternehmen)
Universität Wien/Arbeitsgruppe Rechtsinformatik (Gruppe Schweighofer + Wiener Zentrum für Rechtsinformatik)
Entwicklung eines komplexen Thesaurus für den deutschen Rechtskreises
Elektronischer Kommentar für Agrarstaatsbeihilfen
LOIS LOIS Lexical Ontologies for legal Information Serving
Projekt mit 10 europäischen Partnern (Universitäten und Wirtschafts-unternehmen)
Ziel: Multilingualer Zugang zu europäischen Rechtsdatenbanken;
Mittel: Formale Repräsentationen juristischer Begriffe in allen Sprachen auf Grundlage der WordNet Technik; ähnliche Konzepte 6 verschiedenen Sprachen (Synsets, EWN) sollen verlinkt werden
Sprachen: Italienisch, Holländisch, Portugiesisch, Deutsch, Tschechisch, Englisch
Projektdauer: 24 Monate; Ergebnis: 5000 Synsets in jeder Sprache
Weitere Forschungsbereiche im Rahmen von LOIS:
Information Retrieval: Verbesserte Information Retrieval Techniken
Document Standards: Gemeinsamer XML-Standard für die Repräsentation juristischer Dokumente
Business-Plan: Kommerzielle Nutzung von Public Sector Information
Showcase Applications: Test- und Demonstrationszwecke
Produktintegration: Integration in kommerzielle Anwendungen
\define maketagitem() tag[$(tag)$]
Macros has to be defined in the top of the tiddler. To let it available globally, add the $:/tags/Macro tag to the tiddler.
Definition of the macro:
```
\define maketagitem() tag[$(tag)$]
```
Usage:
<$macrocall $name="wikitext-example-without-html" src='<$list filter="[all[current]tags[]]" variable="tag"><<maketagitem>></$list>'/>
For more details, see https://tiddlywiki.com/#Macro%20Definitions%20in%20WikiText
{{$:/plugins/amp/MagicTabs/dashboard}}
We all love tags. They are easy to add, easy to remove and cool to see. I saw many times people claiming that they want this coolnes into other fields. Currently on TW versions higher than 5.1.0 this is already possible with the help of some smal macros and some smart tiddlywiki code.
!!How does this looks like
Here do you have a live example. Cliking on an element will remove it from the list. Hitting add will add a new element to the list. Just try it out:
<<tokeneditor>><<appendTokenButton>>
<$transclude tiddler="$:/danielo515/ui/item-button"/>
!! How to install:
You need the following tiddlers (drag each link into your own wiki)
* [[$:/danielo515/macros/ui/Buttons/addToken]]
* [[$:/danielo515/macros/ui/controls/addTokenEditor]]
* [[$:/danielo515/macros/remove_from_list.js]]
* [[$:/danielo515/ui/item-button]]
!!How to use it:
There are 3 elements involved, two macros and a tiddler.
!!!Macros
* `<<tokeneditor>>` this adds the input field where you write the "elements" you want to add to the list.
* `<<appendTokenButton>>` This is the button that actually adds the current element to the list. Usually you want to use this two macros together. It accepts ''two optional arguments:'' <span>
|!Parameter|!what is it|!default value|
|field|which field you want to use as list to store the elements|`tokens`|
|caption|the caption you want to display on the button|`add`|
</span>
!!!Tiddler
* `<$transclude tiddler="$:/danielo515/ui/item-button"/>` Basically you have to write that where you want your list to be displayed. Basically is a transclusion of a tiddler template.
!!BUGS
The mechanism used to clear the input box can cause problems on node version. This is because the linkcatcher sets the temporary tiddler to an undefined value instead of an empty string.
{{Material Icons}}
You might want to use this custom "more page options" button (so it won't list your selected FAB buttons):
{{Overwritten buttons}}
You can install Roboto font as a plugin by following this link (plugin by ~TheDiveO): [[TW5Roboto|https://github.com/TheDiveO/TW5Roboto/releases/tag/v0.9.0]]
<$tiddler tiddler="material-hammered.bundle">
*Swipe from the left edge of the screen to open the sidebar (and from the right edge of the screen to close it)
*Swipe up on the FAB button to reveal the secondary FAB buttons, whereby tapping on any of them (or swiping down) will hide them
<<<
Click to export this set:
{{||$:/plugins/wikilabs/bundler/ui/Buttons/export-bundle-filter}}
Or drag this into your TW: <span class="tc-tag-label tc-btn-invisible" style="cursor: move;">
<$draggable filter={{!!filter}}>
<<currentTiddler>>
</$draggable>
</span>
//note:// backup, save, and reload for these to take effect
<<<
<hr>
''Thanks to!'' http://hammerwidgets.tiddlyspot.com/
</$tiddler>
\define ParagraphTiddlerTitle() $(Book)$ - $(Chapter)$ - $(UniqueBit)$
TODO: Add in some checks to make sure that a book and chapter are selected before entering the paragraph text
Also use the action-increment widget to automatically set the unique bit.
Select Book:
<$select
tiddler='$:/temp/NewParagraph'
field='book'
>
<option
value=''
>
--
</option>
<$list
filter='[tag[Book]]'
>
<option>
<$view
field='title'
/>
</option>
</$list>
</$select>
Select Chapter:
<$select
tiddler='$:/temp/NewParagraph'
field='chapter'
>
<option
value=''
>
--
</option>
<$list
filter='[book{$:/temp/NewParagraph!!book}tag[Chapter]nsort[order]]'
>
<option>
<$view
field='title'
/>
</option>
</$list>
</$select>
Paragraph Contents:
Unique bit:
<$edit-text
tiddler='$:/temp/NewParagraph'
field=unique_bit
/>
<$edit-text
tiddler='$:/temp/NewParagraph'
class='tc-edit-texteditor'
/>
<$vars
Book={{$:/temp/NewParagraph!!book}}
Chapter={{$:/temp/NewParagraph!!chapter}}
UniqueBit={{$:/temp/NewParagraph!!unique_bit}}
>
<$button>
Make Paragraph
<$action-setfield
$tiddler=<<ParagraphTiddlerTitle>>
book={{$:/temp/NewParagraph!!book}}
chapter={{$:/temp/NewParagraph!!chapter}}
text={{$:/temp/NewParagraph!!text}}
tags=Paragraph
/>
<$action-setfield
$tiddler='$:/temp/NewParagraph'
text=''
unique_bit=''
/>
</$button>
</$vars>
In this demo -- I have used the ~MakeList widget in combination with the Select widget to display all of the tiddlers with a given tag in a substory of this tiddler.
<$select field="target" default='(none)'>
<option value="null">(none)</option>
<$list filter="[all[tiddlers]tags[]sort[title]]">
<option value=<<currentTiddler>>><$view field="title"/></option>
</$list>
</$select>
<$makelist tiddler="$:/SubStoryList" filter="[tag{MakeList Demo!!target}]">
<$button message="tw-make-list">Show Tagged</$button>
</$makelist>
<$navigator story="$:/SubStoryList" history="$:/SubHistoryList">
<$list filter="[list[$:/SubStoryList]]" history="$:/SubHistoryList">
<div>
!<$view field="title"/>
<$transclude/>
</div>
</$list>
</$navigator>
{
"created": "20180715032127696",
"title": "$:/PSaT/Button/OpenManagerHere",
"type": "application/x-tiddler",
"description": "Open tiddler manager Here",
"icon": "$:/core/images/list",
"modified": "20180715042637083",
"text": "<$list filter=\"[tag<currentTiddler>]+[limit[1]]\" variable=\"null\">\n<$button class=\"tc-btn-invisible\" tooltip=\"open Tiddler Manager for items tagged here\">\n<$action-setfield $tiddler=\"$:/config/Manager/Tag\" text=<<currentTiddler>>/>\n<$action-navigate $to=\"$:/Manager\"/>\n{{$:/core/images/list}}\n</$button>\n</$list>",
"tags": "$:/tags/ViewToolbar"
}
Wichtig! Zum 01. Juli 2018 wird das Reiserecht reformiert. Dies bedeutet unter anderem, dass sich die Frist zur Abgabe einer Mängelanzeige von einem Monat auf zwei Jahre verlängert.
Nicht zuletzt ist der zu Mangel noch Vorort bei der Reiseleitung zu melden, sodass der Veranstalter diesen ggf. beheben kann. Erfolgt eine solche Mängelanzeige nicht, kann dies einen Anspruch auf Entschädigung verwirken.
<dl class="tb5-markup">
<dt>
```
''bold''
```
</dt>
<dd>''bold''</dd>
<dt>
```
//italics//
```
</dt>
<dd>//italics//</dd>
<dt>
```
''//bold italics//''
```
</dt>
<dd>''//bold italics//''</dd>
<dt>
```
__underline__
```
</dt>
<dd>__underline__</dd>
<dt>
```
~~strikethrough~~
```
</dt>
<dd>~~strikethrough~~</dd>
<dt>
```
super^^script^^
```
</dt>
<dd>super^^script^^</dd>
<dt>
```
sub,,script,,
```
</dt>
<dd>sub,,script,,</dd>
<dt>
```
foo -- bar
foo --- bar
```
</dt>
<dd>foo -- bar (En dash)<br>foo --- bar (Em dash)<br></dd>
<dt>
```
!Heading 1
!!Heading 2
!!!Heading 3
```
</dt>
<dd>
!Heading 1
!!Heading 2
!!!Heading 3
</dd>
<dt>
```
---
horizontal rules
<hr>
```
</dt>
<dd>
---
horizontal rules
<hr>
</dd>
<dt><pre>`code`</pre></dt>
<dd>`code` ...via backticks</dd>
<dt><pre>``with `backticks` ``</pre></dt>
<dd>``with `backticks` ``</dd>
<dt>
<pre>```
monospaced
codeblock
```</pre>
</dt>
<dd>
```
monospaced
codeblock
```
</dd>
<dt>
```
"""
force
hard
linebreaks
like
this...
"""
```
</dt>
<dd>
"""
force
hard
linebreaks
like
this...
"""
</dd>
<dt>
```
...since
new paragraphs
need two linebreaks
in tw5
```
</dt>
<dd>
...since
new paragraphs
need two linebreaks
in tw5
</dd>
<dt>
```
> block
>> quotes
>>> are </dd>easy
```
</dt>
<dd>
> block
>> quotes
>>> are <br>easy
</dd>
<dt>
```
<<<
real
easy
<<<
```
</dt>
<dd>
<<<
real
easy
<<<
</dd>
<dt>
```
* unordered
** list
```
</dt>
<dd>
* unordered
** list
</dd>
<dt>
```
# ordered
## list
```
</dt>
<dd>
# ordered
## list
</dd>
<dt>
```
;definition
:term
```
</dt>
<dd>
;definition
:term
</dd>
<dt>
```
# mixed
#* lists
#;you
#:know
#>like so
```
</dt>
<dd>
# mixed
#* lists
#;you
#:know
#>like so
</dd>
<dt>
```
!.h1-class.red CSS
#.li-class.red classes
*.li-class.red can be
;.dt-class.red assigned
:.dd-class.red like
>.blockquote-class.red this
```
</dt>
<dd>
!.h1-class.red CSS
#.li-class.red classes
*.li-class.red can be
;.dt-class.red assigned
:.dd-class.red like
>.blockquote-class.red this
</dd>
<dt>
```
[[The Tiddler]]
[[pretty title|The Tiddler]]
```
</dt>
<dd>
[[The Tiddler]]<br>
[[pretty title|The Tiddler]]
</dd>
<dt>
```
CamelCase
~SuppressedCamelCase
```
</dt>
<dd>
CamelCase<br>
~SuppressedWikiLink
</dd>
<dt>
```
http://tiddlywiki.com
[[pretty|http://pretty.com]]
~http://not.alink.com
```
</dt>
<dd>
http://tiddlywiki.com<br>
[[google|http://google.com]]<br>
~http://not.alink.com
</dd>
<dt>
```
file://///windows/network<br>
file:///c:/Windows/foo<br>
file:///linux/local<br>
```
</dt>
<dd>
file://///windows/network<br>
file:///c:/Windows/foo<br>
file:///linux/local<br>
`file:///` only via local tw!
</dd>
<dt>
```
[ext[forced.link.com]]
[ext[tw|tiddlywiki.com]]
[ext[foo|file:///c:/foo]]
[ext[relative/path]]
```
</dt>
<dd>
[ext[forced.link.com]]<br>
[ext[tw|tiddlywiki.com]]<br>
[ext[foo|file:///c:/foo]]<br>
[ext[relative/path]]
</dd>
<dt>
```
[img[example.jpg]]
[img[tooltip|example.jpg]]
[img width=16 [example.jpg]]
[img class="tc-image" [example.jpg]]
```
</dt>
<dd>
[img[http://www.tiddlywiki.com/favicon.ico]]<br>
[img[tooltip|http://www.tiddlywiki.com/favicon.ico]]<br>
[img width=16 [http://www.tiddlywiki.com/favicon.ico]]<br>
[img class="tc-image" [http://www.tiddlywiki.com/favicon.ico]]
</dd>
<dt>
```
[img[http://www.tiddlywiki.com/favicon.ico]]
[img[path/image.jpg]]
```
</dt>
<dd>
[img[http://www.tiddlywiki.com/favicon.ico]]
</dd>
<dt>
```
[img width={{!!mywidth}} class=<<image-classes>> [example.jpg]]
{{example.jpg}}
```
</dt>
<dd>
params via
[[transclusion|http://tiddlywiki.com/#Transclusion%20in%20WikiText]] or
[[macro|http://tiddlywiki.com/#Macros%20in%20WikiText]]<br><br><br>
embed via transclusion
</dd>
<dt>
```
@@.myStyleClass.red
;term
:definition
@@
```
</dt>
<dd>
@@.myStyleClass.red
;term
:definition
@@
</dd>
<dt>
```
@@color:red;
;css styles
:apply directly like this
@@
@@color:red; or this @@
```
</dt>
<dd>
@@color:red;
;css styles
:apply directly like this
@@
@@color:red; or this @@
</dd>
<dt>
```
@@.tc-tiddler-frame
@@width:200px;height:50px;
or combine both
@@
```
</dt>
<dd>
@@.tc-tiddler-frame
@@width:200px;height:50px;
or combine both
@@
</dd>
<dt>
```
@@.purple Am I purple?@@
<style>
.purple{color:purple;}
</style>
```
</dt>
<dd>
@@.purple Am I purple?@@
<style>
.purple{color:purple;}
</style>
</dd>
<dt style="font-size:80%;">
```
| !Header | !Header | Mhhh ?!? |
|^NE |^ N |^ NW|
|W | ✦ | E|
|,SW |, S |, SE|
|merge|left|<|
|and|now| vertical |
|>| right|~|
```
</dt>
<dd style="font-size:80%;">
| !Header | !Header | Mhhh ?!? |
|^NW |^ @@padding:0 7px 14px 7px;display:block; N@@ |^ NE|
|W | ✦ | @@padding:7px 0;display:block; E@@|
|,SW |, @@padding:14px 7px 0 7px;display:block; S@@ |, SE|
|merge|left|<|
|and|now| vertical |
|>| right|~|
</dd>
<dt>
```
<article class="hello">
HTML tags work like that.
<!-- even comments -->
</article>
```
</dt>
<dd>
<article class="hello">
HTML tags work like that.
<!-- even comments -->
</article>
</dd>
<dt>
```
<a href={{TiddlerWithURL}}>link</a>
<b class=<<getClass>>>bold</b>
```
</dt>
<dd>
<a href={{TiddlerWithURL}}>link</a>
<b class=<<version>>>bold</b>
set attributes via transclusion or macro
</dd>
<dt>
```
<div address="""attribute,
"quoted",
with,
linebreaks.""">inspect me!</div>
```
</dt>
<dd>
<div address="""attribute,
"quoted",
with,
linebreaks.""">inspect me!</div>
</dd>
<dt>
```
*nest<div>
;via
:html
</div>
```
</dt>
<dd>
*nest <div>
;via
:html
</div>
</dd>
<dt>
```
{{Foo}}
{{Foo||Bar}}
{{||Foo}}
{{Foo!!bar}}
{{!!bar}}
{{Foo##index}}
{{##index}}
{{{ [tag[Foo]] }}}
{{{ [tag[Foo]] ||Bar}}}
```
</dt>
<dd>
» [[transcludes|http://tiddlywiki.com/#Transclusion%20in%20WikiText]] tiddler `Foo`<br>
» `Foo` with template `Bar`<br>
» template `Foo` for `CurrentTiddler`<br>
» field `bar` of `Foo`<br>
» field `bar` of `CurrentTiddler`<br>
» `index` of datatiddler `Foo`<br>
» `index` of `CurrentTiddler` (=data)<br>
» list of tiddlers tagged `Foo`<br>
» same using template `Bar`
</dd>
<dt>
```
\define run(foo:'bar') [[$foo$]]
<<run "foo bar">>
```
</dt>
<dd>
» defines macro `run`<br>
» with parameter `foo`<br>
» whose value defaults to `bar`<br>
» outputs a link to value of param:<br>
[[foo bar]]
</dd>
<dt>
```
\define test()
I am $(x)$.
\end
<$set name="x" value="y
of z">
<<test>>
</$set>
```
</dt>
<dd>
» defines macro test which<br>
» outputs value of variable x<br><br>
» sets variable x to: "y<br>
of z" //(multiline allowed)//<br>
» runs macro test which outputs:<br>
"I am y of z."
</dd>
<dt>
```
\define test(x, y, z:'0')
$x$ $y$ $z$
\end
<$macrocall
$name="test"
x=<<version>>
y={{!!title}}/>
```
</dt>
<dd>
» defines macro test<br>
» outputs 3 params<br><br>
» calls test via macrocall widget<br>
» using macro version as param x<br>
» and transclusion as param y<br><br>
» outputs:<br>
<<version>> Markup 0
</dd>
<dt>
```
$$$text/unknown
plain text, not //formatted//
$$$
```
</dt>
<dd>
$$$text/unknown
plain text, not //formatted//
$$$
<br>
These are [[Typed Blocks|http://tiddlywiki.com/#Typed%20Blocks%20in%20WikiText]]
</dd>
<dt>
```
$$$image/svg+xml
<svg xmlns="http://www.w3.org/2000/svg" width="150" height="100">
<circle cx="100" cy="50" r="40" stroke="black" stroke-width="2" fill="green" />
</svg>
$$$
```
</dt>
<dd>
$$$image/svg+xml
<svg xmlns="http://www.w3.org/2000/svg" width="150" height="100">
<circle cx="100" cy="50" r="40" stroke="black" stroke-width="2" fill="green" />
</svg>
$$$
</dd>
<dt>
```
$$$.svg
<svg xmlns="http://www.w3.org/2000/svg" width="150" height="100">
<circle cx="100" cy="50" r="40" stroke="black" stroke-width="2" fill="red" />
</svg>
$$$
```
</dt>
<dd>
$$$.svg
<svg xmlns="http://www.w3.org/2000/svg" width="150" height="100">
<circle cx="100" cy="50" r="40" stroke="black" stroke-width="2" fill="red" />
</svg>
$$$
</dd>
<dt>
```
$$$text/vnd.tiddlywiki>text/html
This is ''some'' wikitext
$$$
```
</dt>
<dd>
$$$text/vnd.tiddlywiki>text/html
This is ''some'' wikitext
$$$
</dd>
<dt>
```
$$$text/vnd.tiddlywiki>text/plain
This is ''some'' wikitext
$$$
```
</dt>
<dd>
$$$text/vnd.tiddlywiki>text/plain
This is ''some'' wikitext
$$$
</dd>
</dl>
<style>
dl.tb5-markup{
overflow:hidden;
}
dl.tb5-markup .red{
color:red;
}
.tb5-markup > dt{
display:block;
float:left;
clear:left;
margin:2% 1em 0 0;
padding;
font-weight:normal;
width:48%;
}
.tb5-markup > dt > pre{
margin:0;
}
.tb5-markup > dd{
display:block;
float:left;
width:48%;
margin:1em 0 0 0;
padding:0;
}
.tb5-markup > dd > p,
.tb5-markup > dd > h1,
.tb5-markup > dd > pre,
.tb5-markup > dd > ul,
.tb5-markup > dd > ol,
.tb5-markup > dd > dl,
.tb5-markup > dd > table,
.tb5-markup > dd > blockquote,
.tb5-markup > dd > blockquote >p{
margin:0;
}
.tb5-markup .tc-image{
width:16px;
}
</style>
<div class="demo">
<table style="width:100%;">
<tr>
<td rowspan="2" style="width:220px;">
Click to export this set:
<$macrocall $name="exportButton"exportFilter={{material-icons.bundle!!filter}} lingoBase="$:/language/Buttons/ExportTiddler/" baseFilename="Material_icons"/><br>
Or drag this into your TW: <span class="tc-tag-label tc-btn-invisible" style="cursor: move;">
<$draggable filter={{material-icons.bundle!!filter}}>
Material Icons
</$draggable>
</span>
</td>
<td style="padding-top: 5px;">
<$list filter={{material-icons.bundle!!filter}} variable="matlIcon">
<$draggable tiddler=<<matlIcon>> tag="span"><$transclude tiddler=<<matlIcon>>/></$draggable>
</$list>
</td>
</tr>
</table>
</div>
''Search words'', a compliment to //tags// to find the current tiddler in //Search//<br>
<$edit-text tag="textarea" tiddler={{!!title}} field="searchwords" class="tc-edit-texteditor"/><br><br>''Personal notes'' about this tiddler:<br>
<$edit-text tag="textarea" tiddler={{!!title}} field="metanotes" class="tc-edit-texteditor"/>
das mietkostenfreie Wohnen kann zur Anrechnung eines fiktiven Einkommens führen Als Regel ist beim mietfreien Wohnen als Wohnwert die objektive Marktmiete anzusetzen). Dies gilt insbesondere beim nachehelichen Unterhalt.
In der Trennungszeit ist aber nur ein angemessener Wohnwert anzusetzen, da der
Ehegatte, der in der Wohnung zurückbleibt, von der Alleinnutzung zunächst keinen
wirtschaftlichen Vorteil hat. Dieser bemisst sich in der Regel nach den Mietkosten für
eine entsprechend kleinere Wohnung. Beim Kindesunterhalt ist mietfreies W
ohnen nur einkommenserhöhend zu berücksichtigen, wenn der barunterhaltspflichtige Elternteil im Eigenheim lebt.
B. Mietwagenkosten
Mietet der Geschädigte nach dem Verkehrsunfall ein Ersatzfahrzeug an, hat er dabei Anspruch auf ein gleichwertiges Fahrzeug. Autovermietungen berechnen jedoch gerne den deutlich teureren Unfallersatztarif für diese Zeit, begründet durch den erhöhten Verwaltungsaufwand. Wird ein Fahrzeug über diesen Tarif vermietet, muss der Geschädigte über die erhöhten Mietwagenkosten aufgeklärt werden. Eine Information über andere, günstigere Vermieter muss jedoch nicht erfolgen.
Häufig übernimmt die Versicherung der Gegenseite nur die normalen Mietwagenkosten (LG Leipzig 05.03.2010 Az. 6 S 391/09). Der Geschädigte würde dann auf den erhöhten Mietwagenkosten „sitzen bleiben“. Das muss sich der Geschädigte nicht gefallen lassen. Wurde der Geschädigte nicht über die erhöhten Mietwagenkosten aufgeklärt und übernimmt die Gegenseite am Ende nicht die Mehrkosten, muss der Vermieter für diese Kosten aufkommen (BGH 21.11.2007, Az. XII ZR 128/05).
1. Anspruch auf Ersatz der Mietwagenkosten
Entstehen nach einem Verkehrsunfall Mietwagenkosten, werden diese in der Regel im Wege des Geldersatzes gemäß § 249 Abs. 2 S. 1 BGB vom Schädiger ersetzt verlangt (AG Leipzig 11.10.2000 Az. 13 C 3210/00). Eine Ersatzpflicht besteht jedoch nur dann im Verkehrsrecht, wenn die angefallenen Mietwagenkosten für das Ersatzfahrzeug „erforderlich“ waren (BGH 12.04.11, Az. VI ZR 300/09). Hat der Geschädigte nur einen geringen Fahrbedarf, so ist die Anmietung eines Mietwagens nicht erforderlich. Begründet wird dies damit, dass die Kosten für Taxi und öffentliche Verkehrsmittel in der Regel günstiger sind, als die Mietwagenkosten.
Die zusätzlichen Mehrkosten für Taxi etc. müssen ebenfalls vom Schädiger ersetzt werden. Die Grenze hierfür liegt bei 20 km pro Tag (AG Leipzig 18.11.1999 Az. 49 C 10931/99). Diese Grenze ist jedoch nicht starr zu behandeln. Es kommt immer auf die Betrachtung des Einzelfalles an. Zum Beispiel können Nachtdienste und Ruf- oder Einsatzbereitschaftsdienste die Anmietung eines Mietwagens erforderlich machen, auch wenn nicht 20 km am Tag gefahren werden. Ein Rentner, der auf dem Land lebt und für notwendige Arztbesuche ein Auto braucht, kann ebenfalls trotz geringem Fahrbedarf ein Auto anmieten und die Mietwagenkosten ersetzt verlangen (AG HB, Az. 9 C 330/11).
Ein Ersatz der Mietwagenkosten ist dann nicht möglich, wenn dem Geschädigten neben dem beschädigten Pkw ein Zweitfahrzeug zur Verfügung steht, denn ihm ist zuzumuten, auf das Zweitfahrzeug zurückzugreifen (BGH, Az. VI ZR 255/74).
2. Höhe der Mietwagenkosten und Fahrzeugtyp des Mietwagens
Der Geschädigte hat die Pflicht die Mietwagenkosten insgesamt niedrig zu halten (AG Leipzig 23.10.1998 Az. 4 C 5755/98). Dies bedeutet nicht, dass er verpflichtet ist, den günstigsten Tarif zu wählen (LG Leipzig 18.12.2014 Az. 05 S 245/14). Auch wenn das Fahrzeug schon älter ist, kann trotzdem ein Fahrzeug der gleichen Wagenklasse oder zumindest ein klassengleiches Fahrzeug gewählt werden (BGH, Az.VI ZR 35/80). Eine Herabstufung des Wagentyps wie bei der Nutzungsausfallentschädigung findet nicht statt, denn Autovermietungen bieten keine älteren Fahrzeuge an. Das bedeutet auch, dass der Geschädigte sich bei der Beschädigung eines Sportwagens Ersatz besorgen könnte. Bei Luxusfahrzeugen der obersten Klasse kann es dem Geschädigten aber zumutbar sein ein Fahrzeugtyp zu wählen, welches weniger komfortabel ist. Dies aber auch nur, wenn ein baugleiches Fahrzeug nur zu erheblich höheren Mietwagenkosten zur Verfügung steht, z. B. bei einem Porsche Panamera als Ersatzfahrzeug für einen Porsche Cayenne (LG Mü. 08.05.12, Az. 2 S 4044/11).
a) Schwacke-Liste und Fraunhofer Liste
Zur Ermittlung des Normaltarifs zur Anmietung eines Mietwagens muss nicht zwingend ein Sachverständigengutachten eingeholt werden. Ausreichend soll der „Schwacke-Mietpreisspiegel“ sein (BGH 09.05.06, Az. VI ZR 117/05). Dabei soll jedoch das Preisniveau an dem Ort, wo der Mietwagen angemietet und übernommen wird, maßgeblich sein (BGH 11.03.08, Az. VI ZR 164/07).
Jedoch wurde die „Schwacke-Liste“ kritisiert. Sie solle seit 2006 überhöhte Werte haben und nicht mehr den Gegebenheiten angepasst sein. Der BGH und auch die Gerichte in Leipzig nutzen jedoch für ihre Berechnungen weiterhin die „Schwacke-Liste“ (BGH 17.05.11, Az.VI ZR 142/10; LG Leipzig 04.04.2014 Az. 8 S 330/13; AG Leipzig 17.09.2013, Az. 115 C 9980/11).
Gleichwohl wurde im Auftrag der Versicherungswirtschaft (GDV) die „Fraunhofer-Liste“ angefertigt, um die Nachteile der „Schwacke-Liste“ auszugleichen. Die „Fraunhofer-Liste“ wird auch von verschiedenen Gerichten und Rechtsanwälten als Berechnungsgrundlage genutzt. Allerdings bestehen auch gegen die „Fraunhofer-Liste“ Bedenken, weil dort die Regionalbereiche wesentlich gröber eingeteilt werden und auch ausschließlich über das Internet buchbare Angebote berücksichtigt werden, obwohl eine generelle Möglichkeit der Internetnutzung kaum unterstellt werden kann.
Wir empfehlen als Rechtsanwälte auch für Leipzig die „Schwacke-Liste“ weiterhin als Berechnungsgrundlage zu verwenden. Zum einen benutzt der BGH selbst die Liste und auch das AG und LG Leipzig erkennen diese vollständig an und zum anderen bietet sie für unsere Mandanten einen erhöhten Tarif.
b) Interimsfahrzeug
Bei einer langen Reparaturdauer oder Ersatzbeschaffung von z.B. Ersatzteilen, droht dem ersatzpflichtigen Schädiger für eine lange Zeit Ausfallentschädigung (Mietwagenkosten oder Nutzungsausfall) zahlen zu müssen. Deshalb kann es dem Geschädigten zumutbar sein, ein „Interimsfahrzeug“ anzuschaffen (BGH, Az. VI ZR 35/80). Das bedeutet, dass sich der Geschädigte für die Zwischenzeit ein Ersatzfahrzeug anschaffen muss, wenn die Kosten des vorläufigen Ersatzfahrzeuges niedriger sind, als die Mietwagenkosten oder die Nutzungsausfallentschädigung. Ein solches Interimsfahrzeug muss z. B. angeschafft werden, wenn der Geschädigte Anspruch auf einen Neuwagen hat und der Ersatzwagen eine sehr lange Lieferzeit hat. Aber auch dann, wenn sich der Geschädigte unmittelbar nach dem Verkehrsunfall vor dem Antritt einer besonders weiten Urlaubsreise mit dem PKW befindet, kann es dem Geschädigten zumutbar sein, ein Interimsfahrzeug zu kaufen.
3. Dauer der Mietwageninanspruchnahme
In erster Linie richtet sich die Dauer der Mietwageninanspruchnahme nach den Angaben im Sachverständigengutachten. Der Geschädigte muss unverzüglich nach Kenntnis des Gutachtens einen Reparaturauftrag erteilen. Der Geschädigte kann aber je nach Ausmaß des Schadens, ggf. nach einer Konsultation bei einem Rechtsanwalt überlegen, ob sein Fahrzeug repariert oder ein Ersatzfahrzeug angeschafft werden soll. Die Überlegungszeit ist auf drei Tage ab Kenntnis des Sachverständigengutachtens begrenzt.
Auch wenn die Reparatur „schwarz“ oder durch Inanspruchnahme einer „Billigwerkstatt“ erfolgt und sich deshalb die Reparaturzeit in die Länge zieht, sind die dadurch entstandenen zusätzlichen Kosten der längeren Mietwageninanspruchnahme nicht zu ersetzen. Auch in diesem Fall ist der Geschädigte an die festgestellte fiktive Dauer der Inanspruchnahme eines Mietwagens auf der Basis des Sachverständigengutachtens gebunden (BGH 15.07.2003, Az. VI ZR 361/02).
<<tabs "[tag[Schweighofer]]" "" "" "tc-vertical">>
Links <$appear type="popup">
* [[Reale Welt]]
* [[Prinzipien|Schweighofer Prinzipien]]
* [[UMSETZUNG|Weiterentwicklung und Umsetzung als Ontologie]]
* [[Ziel der Rechtsordnung]]
* [[Notwendiger Zwischenschritt|Forecast Schweighofer]]
</$appear>
\define drop-at-end()
<$action-listops $tiddler="$:/StoryList" $subfilter="-[<actionTiddler>]"/>
<$action-listops $tiddler="$:/StoryList" $subfilter="[<actionTiddler>]"/>
\end
{
"Public": "Heres a comment ",
"About the TiddlerSidebar": "This is a incredibly informative tiddler. I recommend it to everyone!",
"Context": "Contextual",
"MyCom": "huppp im commenting my own com tid"
}
Jeder lebende Mensch
Verbraucher Legaldefinition in § 13
Unternehmer Legaldefinition in § 14 I
Widget zeigt bestimmten Output an, je nach Verschlagwortung der Ergebnisse
<$list filter="[tag[V]]">
<$link><$text text=<<currentTiddler>>/></$link>
<$list filter="[<currentTiddler>tag[AGL]]"> done </$list>
<$list filter="[<currentTiddler>tag[started]]"> started </$list>
</$list>
<$button message="tm-new-tiddler" param="Template_AGL">Create New AGL</$button>
<$button tooltip="Create a new contact">Create a new contact
<$action-createtiddler $basetitle='New Contact'
tags='contact'
firstname=''
lastname=''
phone=''
email=''
/>
<$action-sendmessage $message="tm-edit-tiddler" />
</$button>
<$list filter="[tag[Anwendungen]tags[]]"/>
<$button tooltip="Create a new contact">Create a new contact
<$action-createtiddler $basetitle='New Contact'
tags='contact'
firstname=''
lastname=''
phone=''
email=''
/>
<$action-sendmessage $message="tm-edit-tiddler" />
</$button>
\define newTid(param:"", btn-caption:"New project", color:"#8058A5")
<$button style="color:$color$; fill:$color$; margin-bottom:5px;">
{{$:/core/images/new-button}} $btn-caption$
<$wikify name="newTitle" text="""{{!!title}}: <<now "YYYY-0MM-0DD hh12:0mmpm">>""">
<$action-sendmessage $message="tm-new-tiddler"
title=<<newTitle>>
text="..."
tags="[[$param$]]"
/>
</$wikify>
</$button>
\end
<<newtids "
Kündigungserklärung
Anhörung Betriebsrat
Besonderer Kündigungsschutz
Allgemeiner Kündigungsschtuz
Kündigungsfrist
">>
https://noteself.github.io/
Nutzungsausfall entschädigen lassen statt Mietwagen nehmen
Zuletzt aktualisiert: 26. Juli 2016 Von: Dr. Britta Beate Schön
facebook
google+
twitter
drucken
Das Wichtigste in Kürze
Wer unverschuldet in einen Autounfall verwickelt wird, kann sich für die Dauer der Reparatur einen Mietwagen nehmen und die Kosten vom Verursacher zurückverlangen.
Alternativ können Sie auch eine sogenannte Nutzungsausfallentschädigung einfordern.
Die Höhe der Entschädigung wird in aller Regel anhand des Werts Ihres Autos berechnet – mithilfe der Schwacke-Liste. Sie bekommen danach zwischen 23 und 175 Euro pro Tag.
Wäre ein Mietwagen billiger gewesen, darf die Versicherung die Entschädigung trotzdem nicht kürzen.
Mit der Entschädung fahren Sie meist besser – insbesondere wenn die Schuldfrage beim Unfall nicht eindeutig geklärt ist. Sonst laufen Sie Gefahr, die Mietwagenkosten teilweise selbst zahlen zu müssen.
Unser Tipp: Bleiben Sie zu Rechtsthemen immer auf dem Laufenden - mit unserem kostenlosen Newsletter!
Auf dem Weg zum Einkaufen nimmt Ihnen jemand die Vorfahrt. Das Auto ist kaputt und muss erstmal repariert werden. Dann können Sie sich einen Mietwagen bezahlen lassen oder aber auf öffentliche Verkehrsmittel umsteigen und eine sogenannte Nutzungsausfallentschädigung verlangen. Viele Geschädigte verschenken oft mehrere Hundert Euro, weil sie ihren Anspruch auf Nutzungsentschädigung gar nicht oder in viel zu geringem Umfang geltend machen. In vielen Fällen ist die Entschädigung die bessere Variante – doch dabei gibt es einiges zu beachten. Die gegnerische Haftpflicht hat nämlich ein Interesse daran, die Kosten so gering wie möglich zu halten.
Bares statt Mietwagen
Während die Mietwagenpreise von 2010 bis 2014 laut Fraunhofer Institut fast ausschließlich gesunken sind, wurden die Tagespauschalen für die Entschädigung nicht reduziert. Sie sollten daher prüfen, ob Sie mit einer Nutzungsausfallentschädigung besser gestellt sind als mit einem Mietwagen.
Beispiel: Handelt es sich bei dem beschädigten Fahrzeug um einen Alfa Giulietta 2.0 JTDM 16V , 1 Jahr alt, haben Sie einen Anspruch auf Nutzungsausfallentschädigung nach Schwacke-Tabelle 2013, Gruppe F, von 50 Euro pro Tag. Bei zehn Tagen Reparatur bekommen Sie von der Versicherung 500 Euro Entschädigung.
Mieten Sie stattdessen einen Mittelklassewagen an, muss die Versicherung deutlich weniger zahlen. Sie finden einen Mietwagen für 10 Tage in der entsprechenden Klasse auf den Mietwagenportalen Check24*, billiger-mietwagen.de* oder happycar.de* schon für weniger als 300 Euro.
Sie können sich die Entschädigung auszahlen lassen und sind völlig frei in der Verwendung des Geldes. Benötigen Sie das Auto nicht jeden Tag oder können Sie problemlos mit den öffentlichen Verkehrsmitteln zur Arbeit kommen, ist die Nutzungsentschädigung immer sinnvoller.
Ist die Schuldfrage beim Unfall nicht eindeutig geklärt, sollten Sie sich auf jeden Fall für die Nutzungsentschädigung entscheiden. Dann übernimmt die gegnerische Haftpflichtversicherung die Kosten für den Mietwagen nämlich eventuell nicht oder nur teilweise. Bei einem Mitverschulden zahlt die Autoversicherung des Unfallgegners zumindest den entsprechenden Anteil der Nutzungsausfallentschädigung. Insoweit erhalten Sie nur weniger Geld, brauchen aber selbst nichts zusätzlich zu zahlen.
Tipp: Lassen Sie sich von einem Fachanwalt für Verkehrsrecht vertreten. Der regelt die ganzen Formalitäten mit der gegnerischen Versicherung und stellt sicher, dass all Ihre Rechte und Ansprüche eingefordert werden. Die Anwaltskosten übernimmt die gegnerische Versicherung. Wie Sie einen Anwalt finden, lesen Sie in unserem Ratgeber. Eine Rechtsschutzversicherung kann sich durchaus lohnen. Dabei gibt es auch Versicherer, bei denen Sie nur einen Verkehrsrechtsschutzversicherung abschließen können.
Mehr dazu im Ratgeber Rechtsschutzversicherung
Julia Rieder
von Finanztip,
Expertin für Versicherungen
Ein Rechtsstreit kann teuer werden
Rechtsschutz ist sinnvoll, aber kein Muss.
Viele Fälle, etwa rund um Hausbau oder Scheidung, sind nicht versichert.
Wir zeigen gute Tarife zu einem fairen Preis.
» Zum Ratgeber
Von uns empfohlene Tarife:
Arag Aktiv Komfort*
Auxilia Jurprivat*
Huk24 PBV Plus*
Voraussetzung für Entschädigung
Als Geschädigter müssen Sie darlegen, dass Sie Ihr Fahrzeug während der Reparatur auch tatsächlich benutzt hätten, etwa weil Sie jeden Morgen mit dem Auto zur Arbeitsstelle fahren.
Ferner müssen Sie auch in der Lage gewesen sein, Ihr Auto zu benutzen. Falls Sie wegen des Unfalls krankgeschrieben sind oder gar im Krankenhaus liegen, wird das schwierig. Es genügt in diesen Fällen aber auch, wenn Sie zum Beispiel Familienangehörigen zugesagt hatten, das Auto auch benutzen zu können (KG Berlin, Urteil vom 29. September 2005, Az. 12 U 235/04).
Dauer der Zahlung
Die Entschädigung wegen Nutzungsausfall wird für die Dauer der Reparatur des Autos oder bei Totalschaden für die Zeit der Ersatzbeschaffung gezahlt. Meist bestimmt das ein Gutachter. Gewöhnlich geht er dabei von einer Dauer von 14 Tagen aus, danach gibt es nur in Ausnahmefällen noch Geld von der Versicherung. Aber: Auch für die Dauer der Schadensfeststellung und während Sie überlegen, ob und wo Sie den Wagen reparieren lassen, bekommen Sie die Entschädigung (BGH, Urteil vom 5. Februar 2013, Az. VI ZR 263/11).
Lassen Sie sich von der Werkstatt oder dem Verkäufer unbedingt bestätigen, wie lange die Reparatur oder die Ersatzbeschaffung dauern wird oder gedauert hat.
Höhe der Entschädigung
Was Sie von der gegnerischen Versicherung für den Nutzungsausfall gezahlt bekommen, richtet sich nach der Fahrzeugkategorie, Leistung und Ausstattung Ihres Unfallwagens. Bei der Berechnung der Entschädigung richten sich die Versicherungen und die Gerichte meist nach der Schwacke-Liste für Nutzungsausfallentschädigungen.
Gruppen Entschädigung pro Tag
Gruppe A 23 €
Gruppe B 29 €
Gruppe C 35 €
Gruppe D 38 €
Gruppe E 43 €
Gruppe F 50 €
Gruppe G 59 €
Gruppe H 65 €
Gruppe J 79 €
Gruppe K 119 €
Gruppe L 175 €
Quelle: Schwacke-Liste Nutzungsausfallentschädigung 2013
Die Liste, die auch nach den Autoren „Sander-Danner/Küppersbusch“ benannt wird, wird jährlich aktualisiert und ist kostenpflichtig. In dem Tabellenwerk sind sämtliche gängigen Fahrzeugtypen aufgelistet und in Gruppen mit unterschiedlichen Tagessätzen eingeteilt.
Herabstufung bei älteren Autos – Fahrzeuge, die älter als 5 Jahre sind, werden der Einfachheit halber in die nächst niedrigere Ausfallgruppe eingestuft. Bei einem Fahrzeugalter ab 10 Jahren erfolgt eine Abstufung um zwei Klassen. Ganz einheitlich wird das allerdings nicht gehandhabt. Im Einzelfall gewähren die Richter auch bei älteren Fahrzeugen die volle Entschädigung (OLG Düsseldorf, Beschluss vom 2. Juli 2008, Az. I-1 W 24/08).
Dann darf die Versicherung die Entschädigung kürzen
In einigen Fällen darf die Versicherung die Entschädigung reduzieren. Aber nicht jede Kürzung sollten Sie sich gefallen lassen.
Zweitwageneinwand - Versicherer versuchen sich die Entschädigung zu sparen, wenn in der Familie des Geschädigten ein Zweitwagen vorhanden ist. Die Rechtsprechung gewährt auch in diesen Fällen eine Nutzungsausfallentschädigung, falls das zweite Fahrzeug von einem Angehörigen ständig genutzt wird und es dem Geschädigten nicht zur Verfügung steht (AG Geldern, Urteil vom 22. Juli 2013, Az. 3 C 27/13). Aber: Ist das Unfallfahrzeug etwa ein Kombi und der Zweitwagen ein kleiner Smart, ist dem Geschädigten die Nutzung des anderen Fahrzeugs nicht zumutbar.
Niedrigere Mietwagenkosten führen nicht zur Kürzung – Dauert die Reparatur länger, ist für die Versicherung ein Mietwagen oft günstiger als die Entschädigung. Je länger Sie mieten, desto günstiger ist nämlich der Tagessatz. Sie sind aber nicht dazu verpflichtet, immer die für die Versicherung günstigere Variante zu wählen. Selbst wenn die Versicherung einen Mietwagen zu einem niedrigeren Preis angeboten hat, darf sie die Nutzungsentschädigung nicht einfach auf den Mietwagenpreis kürzen (OLG Koblenz, Urteil vom 13. Februar 2012, Az. 12 U 1265/10).
Keine Entschädigung bei gewerblich genutztem Fahrzeug - Für gewerblich genutzte Fahrzeuge ist die Entschädigung grundsätzlich ausgeschlossen (BGH, Beschluss vom 21, Januar 2014, Az. VI ZR 366/13). Sie bekommen dann Ihren Verdienstausfall ersetzt, in dessen Berechnung die Kosten für einen Mietwagen einfließen. Ausnahme: Sie haben das Fahrzeug sowohl privat als auch gewerblich genutzt. Hier können Sie die private Nutzung anteilig geltend machen.
Unser Tipp: Bleiben Sie zu Rechtsthemen immer auf dem Laufenden - mit unserem kostenlosen Newsletter!
Das müssen Sie bei den Mietwagenkosten beachten
Auch wenn Sie sich nach dem Unfall für einen Mietwagen entscheiden, müssen Sie ein paar Dinge beachten, damit Sie nicht bei Vorlage der Rechnung an die gegnerische Versicherung Schwierigkeiten bekommen.
Tarifvergleich - Sie haben die Pflicht, den Schaden so gering wie möglich zu halten. So verlangt die Rechtsprechung, dass der durch einen Verkehrsunfall Geschädigte zum Beispiel die Mietwagentarife vergleichen muss und nicht den teuersten Tarif wählen darf. Den Tarifvergleich müssen Sie dem Gericht auch nachweisen. Haben Sie ein Fahrzeug ohne Vergleich angemietet, kann es passieren, dass die Versicherung Ihnen nicht die gesamten Kosten ersetzt, sondern nur die erforderlichen. Der Bundesgerichtshof lässt eine Schätzung sowohl anhand der Schwacke-Liste Mietwagenpreise als auch mit dem Fraunhofer-Mietpreisspiegel zu (BGH, Urteil vom 12. April 2011, Az. VI ZR 300/09). Die erstattungsfähigen Beträge nach der Schwacke-Liste sind im Regelfall deutlich höher als die der Fraunhofer-Tabelle.
Die Fraunhofer-Liste beruht im Wesentlichen auf einer anonymen Internetabfrage, die Schwacke-Liste auf einer nicht anonymisierten, örtlich genaueren Anbieterabfrage. Das Oberlandesgericht Hamm hat keine der Listen isoliert angewendet, sondern einen Mittelwert gebildet. In dem Sachverhalt, den das Gericht zu klären hatte, ergab die Fraunhofer-Liste einen Mietpreis von rund 490 Euro, die Schwacke-Liste hingegen auf einen Preis von 1.140 Euro. Das Gericht hielt einen Mittelwert von rund 816 Euro für angemessen (OLG Hamm, Urteil vom 18. April 2016, Az. 9 U 142/15).
Tipp: Zahlt die gegnerische Versicherung nur einen Teil der Mietwagenkosten, müssen Sie nicht draufzahlen, wenn Sie von der Autovermietung nicht darüber aufgeklärt wurden, dass der höhere Mietpreis von der Versicherung eventuell nicht in voller Höhe erstattet wird. Der Vermieter bleibt dann auf den Kosten sitzen (BGH, Urteil vom 10. Januar 2007, Az. XII ZR 72/04).
Keine Herabstufung in der Mietwagenklasse – Auch wenn Ihr Auto schon einige Jahre alt war, können Sie ein Fahrzeug der gleichen Mietwagenklasse wählen. Eine Herabstufung des Wagentyps wie bei der Nutzungsausfallentschädigung findet nicht statt, denn Autovermietungen bieten keine älteren Fahrzeuge an.
Nur geringer Fahrbedarf - Bei geringem Bedarf zur Nutzung eines Autos besteht in der Regel kein Anspruch auf Ersatz von Mietwagenkosten. Die Grenze wird bei 20 km pro Tag angesetzt. Dann kann sich der Geschädigte mit Taxis oder öffentlichen Verkehrsmitteln behelfen. Er kann dann nur den dafür erforderlichen Betrag verlangen. Einziger Ausweg: Der Geschädigte weist nach, dass er auf die ständige Verfügbarkeit eines Autos angewiesen ist (BGH, Urteil vom 5. Februar 2013, Az. VI ZR 290/11). Ein Rentner, der auf dem Land lebt und für notwendige Arztbesuche ein Auto braucht, kann zum Beispiel trotz geringem Fahrbedarf ein Auto anmieten, urteilte das Amtsgericht Bremen (Urteil vom 13. Dezember 2012, Az. 9 C 330/11).
Ersparte Abnutzung des eigenen Wagens – Auch wenn es auf den ersten Blick schwer einzusehen ist, kann es sein, dass die gegnerische Versicherung einen Teil der Mietwagenkosten abzieht, weil Sie wegen des Mietwagens Ihren Wagen gewissermaßen geschont haben. Es kommt hier immer auf den Einzelfall an. Obwohl Ihr Auto mittlerweile ein Unfallwagen ist, haben die Gerichte Abzüge zwischen 3 und 20 Prozent der Mietwagenkosten zugestanden. (OLG Köln, Urteil vom 8. Januar 1993, Az. 19 U 99/92: 20 %; OLG Nürnberg, Urteil vom 10. Mai 2000, Az. 9 U 672/00: 3%).
A. Nutzungsausfallentschädigung nach einem Verkehrsunfall
Der Geschädigte hat nach einem Verkehrsunfall Anspruch auf Nutzungsausfallentschädigung, das heißt auf Zahlung eines Geldbetrages, der sich wiederum nach der Zeit bemisst, in der er sein Fahrzeug nicht nutzen kann. Eine Nutzungsausfallentschädigung kann im Verkehrsrecht nur verlangt werden, wenn die im Folgenden beschriebenen Voraussetzungen erfüllt sind.
1. Fehlende Gebrauchsmöglichkeit
Der Anspruch auf Nutzungsausfallentschädigung kann nur gefordert werden, wenn durch den Geschädigten oder seinen Rechtsanwalt nachgewiesen wird, dass das Unfallfahrzeug auch tatsächlich ausgefallen ist (BGH, Az.VI ZR 41/71). Die Nutzung des Fahrzeugs darf für den Geschädigten nach dem Verkehrsunfall nicht möglich sein. Sollte ein Fahrzeug nach einem kleinerem Verkehrsunfall (z.B. lediglich Schramme im Autolack) noch verkehrssicher sein, kann in der Regel keine Nutzungsausfallentschädigung verlangt werden. Der Nutzungsausfall richtet sich nach der Zeit, in der das Fahrzeug nicht genutzt werden kann, weil es sich z. B. zur Reparatur in einer Werkstatt befindet.
2. Nutzungswille
Unter Nutzungswillen versteht man den Willen bzw. die Bereitschaft, das Fahrzeug nach dem Verkehrsunfall weiterhin nutzen zu wollen. Das kann zum Beispiel durch eine Reparatur des Fahrzeugs geschehen. Dadurch zeigt der Geschädigte, dass er das beschädigte Fahrzeug nach der Reparatur weiterhin benutzen will. Der Nutzungswille kann aber auch entfallen, wenn der Geschädigte nach dem Unfall durch ein Trauma nicht mehr in der Lage ist, künftig wieder Auto zu fahren oder wenn er das Fahrzeug nicht reparieren lässt (AG Leipzig 24.05.2002 Az. 49 C 1061/02). Ein Nutzungswilllen ist auch dann nicht anzunehmen, wenn kein Ersatzfahrzeug angeschafft wird (LG Leipzig 11.01.2002 Az. 14 S 6672/01).
a) Nutzungswille von Dritten
Der Nutzungswille muss nicht in der Person des Fahrers auftreten. Ausreichend ist es auch, wenn die Fahrten sonst nur auf Wunsch des Beifahrers angetreten werden. Dieser Mitbenutzungswillen reicht für den generellen Nutzungswillen aus, sodass Nutzungsausfallentschädigung beansprucht werden kann.
b) Eingeschränkte Nutzungswille
Es kann passieren, dass der Geschädigte sein Fahrzeug nicht jeden Tag nutzt, sondern nur an bestimmten Tagen oder Jahreszeiten.
Bei sogenannten „Sonntagsfahrern“, also jemandem der sein Fahrzeug nur an Wochenenden oder Feiertagen nutzt, kann auch nur für solche Tage Nutzungsausfallentschädigung beansprucht werden. Das begründet sich damit, dass sich sein Wille das Fahrzeug zu nutzen, nur auf diese Tage beschränkt.
Ähnlich ist es bei reinen Sommerfahrzeugen, wie Cabrios oder Motorrädern. Auch hier beschränkt sich der Nutzungswille auf einen bestimmten Zeitraum. Wird das Fahrzeug im Spätherbst beschädigt und im kommenden Frühjahr erst wieder angemeldet, so ist für die Zwischenzeit kein Nutzungswille erkennbar und es kann keine Nutzungsausfallentschädigung verlangt werden.
3. Nutzungsmöglichkeit
Zudem muss die Nutzungsmöglichkeit gegeben sein. Dies ist die Fähigkeit des Geschädigten das Fahrzeug nach dem Verkehrsunfall nutzen zu können. Es wird also überprüft, ob der Geschädigte überhaupt in der Lage war das Fahrzeug zu benutzen. Die Nutzungsmöglichkeit entfällt, wenn der Geschädigte durch den Verkehrsunfall derart verletzt ist, dass er ein Kraftfahrzeug vorübergehend oder auf längere Dauer nicht mehr führen kann. Dies gilt auch bei unfallunabhängiger, aber unmittelbar nach dem Verkehrsunfall eingetretener Erkrankung (OLG Mü. VersR 1991, 324).
Ist der Geschädigte nicht in der Lage das Fahrzeug zu nutzen, so kann die Nutzungsmöglichkeit dann gegeben sein, wenn der Geschädigte sein Fahrzeug einem Dritten wie, z. B. dem Ehepartner, Kind oder Verlobten zur Verfügung stellt. Jedoch muss bereits vor dem Verkehrsunfall eine entsprechende Vereinbarung zwischen dem Geschädigten und dem Dritten getroffen worden sein. Die reine theoretische Möglichkeit, das Dritte das Fahrzeug hätten nutzen können, ist für eine Nutzungsausfallentschädigung nicht ausreichend (BGH, Az. VI ZR 143/73).
Auch in den Fällen, in denen dem Geschädigten ständig ein Zweitfahrzeug zur Verfügung steht, kann Nutzungsausfallentschädigung geltend gemacht werden. Voraussetzung ist jedoch, dass die Nutzwerte der beiden Fahrzeuge nicht gleichzusetzen sind. Ein solcher Umstand ist z.B. dann gegeben, wenn sich im Eigentum des Geschädigten ein Motorrad der Luxusklasse und ein Mittelklassewagen befindet und das Motorrad durch einen Verkehrsunfall beschädigt wird (OLG D.-dorf, 10.03.2008, Az. I 1 U 198/07). Die Nutzungsausfallentschädigung wird in diesen Fällen jedoch gemindert.
4. Dauer des Nutzungsausfalls
In der Praxis stellen wir als Rechtsanwälte immer wieder fest, dass der Schaden, der dadurch entsteht, dass das Fahrzeug für die Dauer der Reparatur nicht genutzt werden konnte, nicht geltend gemacht wird. Hier muss durch den Rechtsanwalt darauf geachtet werden, dass Nutzungsausfallentschädigung nicht nur für die Tage der tatsächlichen Reparatur verlangt werden kann, sondern auch für die Zeit, in der das Fahrzeug lediglich auf dem Werkstatthof stand und auch für Samstage, Sonntage und Feiertage.
a) Zeitraum der Nutzungsausfallentschädigung
Nutzungsausfallentschädigung ist grundsätzlich vom Zeitpunkt des Verkehrsunfalls bis zur Reparatur zu leisten. Der Geschädigte hat aber auch eine Schadensminderungspflicht. Er darf die Reparatur des Fahrzeuges nicht schuldhaft verzögern. Die Dauer des Nutzungsausfalls unterteilt sich deshalb in drei Phasen, in denen folgende Obhutspflichten bestehen:
aa) Schadensermittlung
Der Geschädigte muss schnellstmöglich nach dem Verkehrsunfall den Schaden ermitteln lassen. Hierzu gehört auch die Beauftragung eines Anwalts und eines Sachverständigen. Bleibt das Gutachten des Sachverständigen aus, muss ggf. durch den Geschädigten oder einem beauftragten Rechtsanwalt, nachgefragt werden.
bb) Überlegungsphase
Der Geschädigte muss sich ohne schuldhaftes Zögern entscheiden, ob das Fahrzeug repariert werden soll, oder ein neues Fahrzeug angeschafft werden soll. Der Überlegungszeitraum kann drei bis zehn Tage (LG WI, Az. 2 O 409/93) betragen. In der Regel dürfte daher eine Überlegungsphase von fünf Tagen angemessen sein.
cc) Reparaturdauer bzw. Wiederbeschaffungszeit
Die Reparatur muss unverzüglich beauftragt werden oder ein Ersatzfahrzeug angeschafft werden. Üblicherweise ergeben sich die Reparaturdauer und die Wiederbeschaffungszeit aus dem Schadensgutachten. Dabei muss jedoch berücksichtigt werden, dass der Gutachter nur eine Prognose abgibt. Sollte es also zu einer Überschreitung der prognostizierten Zeit kommen und sind die Gründe hierfür nicht auf ein Verschulden des Geschädigten zurückzuführen, dann ist die tatsächliche Reparaturdauer und Wiederbeschaffungszeit zu berücksichtigen.
b) Nachweis der Dauer des Nutzungsausfalls
Die Dauer des Nutzugsausfalls des Fahrzeuges muss nachgewiesen werden. Die Versicherungen haben das Recht, von dem Geschädigten oder dem beauftragten Rechtsanwalt, einen entsprechenden Nachweis zu verlangen. Die Versicherungen können bis dahin die Zahlung der Nutzungsausfallentschädigung und auch der Mietwagenkosten verweigern.
aa) Werkstattreparatur
Bei einer Reparatur, die in der Werkstatt durchgeführt wird, kann der Nachweis entweder durch eine isolierte Bescheinigung erfolgen oder mittels einer Reparaturdauerbescheinigung.
bb) Eigenreparatur
Es steht dem Geschädigten zu, die Schäden am Fahrzeug selber zu beheben. Dabei kann sich der Geschädigte jedoch nicht unendlich viel Zeit lassen um dadurch eine höhere Nutzungsausfallentschädigung erhalten zu können. Die angemessene Reparaturzeit wird mittels Sachverständigengutachten ermittelt.
Der Beweis der Selbstreparatur durch den Geschädigten gestaltet sich problematischer. Zum einen könnte er ein Foto anfertigen, welches das Fahrzeug im reparierten Zustand zeigt (zum Nachweis der Aktualität des Fotos sollte eine entsprechende Tageszeitung mit abgebildet sein). Zum anderen kann ein Sachverständiger mittels Nachbesichtigung eine entsprechende Reparaturbescheinigung ausfüllen (AG AC 28.04.05, Az. 80 C 110/05).
5. Höhe der Nutzungsausfallentschädigung
Die Höhe der Nutzungsausfallentschädigung bestimmt sich zum einen nach der Dauer des Ausfalles. Zum anderen ist für die Höhe maßgebend, um was für ein Fahrzeug es sich konkret handelt. Anhand von Nutzungsausfallentschädigungstabellen wie die von Sanden/Danner/Küppersbusch oder auch die Schwacke-Liste, wird die Höhe der Nutzungsausfallentschädigung im Verkehrsrecht bestimmt. Hierzu wird das Fahrzeug aufgrund der Marke und des Typs einer in der Tabelle vorhandenen Gruppe (A – L) zugeordnet. Aus der Zuordnung ergibt sich wiederum, welcher Nutzungsausfall pro Tag verlangt werden kann. Die Höhe der Nutzungsausfallentschädigung ergibt sich also aus Dauer des Ausfalls mal Tagessatz.
Fahrzeuge, die älter als 5 Jahre sind, werden in der Regel in die nächste niedrigere Ausfallgruppe eingestuft. Bei einem Fahrzeugalter von 10 Jahren erfolgt in der Regel eine Abstufung um 2 Klassen. War das Fahrzeug völlig verbraucht, so richtet sich die Nutzungsausfallentschädigung nach den Vorhaltekosten für den entsprechenden Fahrzeugtyp. Diese Richtwerte sind jedoch nicht immer starr zu befolgen.
Der BGH entschied, dass das Gesamttabellenwerk von Sanden/Danner/Küppersbusch eine geeignete Schätzungsgrundlage für die Höhe der Nutzungsausfallentschädigung darstellt. Zudem bestätigte der BGH seine Ansicht, dass ältere Fahrzeuge in niedrigere Ausfallgruppen eingestuft werden. Ungeklärt war die Höhe der Nutzungsentschädigung für ein gut gepflegtes Fahrzeug, das zum Unfallzeitpunkt 16 Jahre alt war und das eine Laufleistung von 164.000 km aufwies. Für ein solches Fahrzeug wollte die Versicherung statt der Nutzungsausfallentschädigung lediglich die niedrigen Vorhaltekosten zahlen. Dem folgte der BGH nicht. Das Alter eines Fahrzeugs muss berücksichtigt werden, „wenn dessen Nutzungswert mit demjenigen eines neueren Fahrzeugs des gleichen Typs schlechterdings nicht mehr vergleichbar“ ist. Ist das Fahrzeug jedoch gut gepflegt, so stehen dem Geschädigten für die entgangene Nutzung nicht nur die Vorhaltekosten, sondern die Nutzungsentschädigung nach der Tabelle von Sanden/Danner/Küppersbusch zu (BGH 23.11.2004, Az. VI ZR 357/03).
Die „Schwacke-Liste“, wird jährlich aktualisiert und ist kostenpflichtig. In dem Tabellenwerk sind sämtliche gängigen Fahrzeugtypen (ca. 41.000) aufgelistet und in Gruppen mit unterschiedlichen Tagessätzen eingeteilt.
– Beschädigtes Fahrzeug: A3 1.8 Ambiente, 4 Jahre alt
– Nutzungsausfallentschädigung für dieses Fahrzeug bis 5 Jahre: Gruppe E
– gelisteter Nutzwert des Fahrzeugs bis 5 Jahre: 43,00 €
– älter als 5 Jahre: Gruppe D = 38,00 €
– älter als 10 Jahre: Gruppe C = 35,00 €
– Vorhaltekosten: 11,54 €
Beträgt die Nutzungsausfalldauer 10 Tage, ergibt sich eine Nutzungsausfallentschädigung des PKW von 10 Tagen mal 43,00 € Nutzwert/Tag, also 430,00 €.
Ist das Fahrzeug jedoch 6 Jahre alt (Gruppe D), ergibt sich eine Nutzungsausfallentschädigung von 10 x 38 € = 380,00 €.
Bei einem Fahrzeugalter von 11 Jahren (Gruppe C) ergeben sich 10 x 35,00 € = 350,00 €.
War das Fahrzeug völlig verbraucht, kommt eine Reduzierung auf die Vorhaltekosten in Betracht.
* Verwaltungsrecht AT inkl. Prozessrecht
* Europarecht
Drei Aspekte einer Ontologie:
*Eine Ontologie soll einen formalen Aufbau haben, um auch von Maschinen gelesen werden zu können.
*Das durch sie ausgedrückte Wissen ist explizit anzugeben.
*''Specification of a shared conceptualisation'' drückt aus , dass eine Ontlogie mit (abstrakten) Konzepten (Dingen) die Welt beschreibensoll.
''Glossar schafft Brücke zwischen Beteiligten''
Das in der nächsten Phase aufzubauende Glossar beschreibt die in einem Unternehmen verwendeten Begriffe, stellt Referenzen zu Prozessen her und erfüllt wichtige Dokumentationsaufgaben. Im besagten Projekt wurde hierfür das Semantic MediaWiki genutzt, um die Begriffsanforderungen der Ontologie zu identifizieren und informell zu beschreiben.
Die Wiki-Technik bietet sich einerseits an, weil sie für den möglichst kollaborativen Aufbau des Glossars die Einbeziehung der Fachseite erlaubt. Dabei lassen sich Diskussionen über Aufgaben einzelner Glossarobjekte wie zum Beispiel Kunde, Auftrag oder Produktkatalog nachvollziehbar im Wiki-Kontext führen. Andererseits erlaubt der Einsatz semantischer Techniken den Export der erfassten Begriffe in die Modellierungsumgebung, ohne den Bezug zwischen den Begriffen der Fachseite und den modellierten Klassen und Attributen zu verlieren.
Einsatzgebiete von Ontologien
Derzeit sind Ontologien auszugsweise vor allem in den folgenden Bereichen einsatzfähig:
• Das Semantic MediaWiki wird neben der Pflege von Glossaren teilweise auch für Projekt- und Wissens-Management in Organisationen eingesetzt.
• Twine und Tripit sind Web-Portale, die semantische Techniken nutzen, um wissensbasierende Social Networks oder die Organisation von Reisen zu erstellen beziehungsweise zu vereinfachen.
''
Ontologien in Rechtsinformationssystemen''
Ontologien sind explizite und computergerechte Formalisierungen
Nicht Textarchiv, sondern computergerechtes Wissensarchiv
Speicherung von Wissensbausteinen, nicht von Zeichenketten
Textarchive: leichtes Updaten durch Beobachtung objektiver Rechtsinformationsprozesse (dh Publikation von Rechtsnormen)
Beschränkte Verwendbarkeit
Ontologien: schwieriger Aufbau und mühsames Updaten
Für Automatisierungen nutzbar
Problem: Nutzung von (semi)automatischen Werkzeugen
''Forecast''
Explizite Formalisierung des Rechts
Formales Modell des Rechts
Computergerechte Verarbeitung
Vernetzung mit existierenden Weltbeschreibungen (Ontologien der Informatik)
Wiederverwendung
Umsetzung in IT-Anwendungen
Juristische Kommentare and Systeme: umfassende aber sprachliche Beschreibung des Rechts
Elektronische Kommentare: Ziel jeder besseren Ontologie
Wesentlicher Vorteil: Automatisierung der Rechtsanwendung
Begriff
Philosophie
ontos, griech., „das Seiende“
Ontologie: „Seinslehre“, die Lehre dessen was ist; von den Möglichkeiten und Bedingungen des Seienden (Paramenides von Elea)
Wissensrepräsentation
Beschreibung dessen, was in einem definierten Teilbereich des Wissens existiert; Gruber: „explizite formale Spezifikation einer Formalisierung“ Uschold: „shared understanding of some domain of interests“
Formale Festlegung von Begriffshierarchien, Relationen und Attributen
*[[Klassifikation]]
*[[Klassifizierung]]
*[[Ontologie]]
<div class="family-tree" style="overflow-x:scroll;">
*[[Ontology]]
**[[Klassifizierung]]
**[[Indentifizierung]]
***[[Tags-Ident]]
***[[Gesetz-Ident]]
***[[Field-Ident]]
**[[Prüffolge]]
***[[AGL]] und weitere [[anwendbare AGL]]
***[[Voraussetzungen]]
***[[Rechtsfolgen]]
**[[Filter]]
***[[direkter Pfad]]
***[[Generelle Heranführung]]
</div>
<$list filter="[tag[Check]tag[Kündigung]sort[list]]">
<<currentTiddler>>
{{||$:/core/ui/ViewTemplate/title}}
</$list>
This family is neatly held in custody so you can manipulate it.
```
<div class="family-tree" style="overflow-x:scroll;">
*[[Parent]]
**[[Child 1]]
...
```
<div class="family-tree" style="overflow-x:scroll;">
*[[Parent]]
**[[Child 1]]
***[[GrandChild 1.1]]
**[[Child 2]] [[Child 2a]]
***[[GrandChild 2.1]]
***[[GrandChild 2.2]]
****[[Great GrandChild 2.2.1]]
****[[Great GrandChild] 2.2.2]]
***[[GrandChild j2.3 jjjj jjj jjjj mmm mmm mmmm and this is even mibberk]]
***[[GrandChild 2.1]]
***[[GrandChild 2.2]]
****[[Great GrandChild 2.2.1]]
****[[Great GrandChild] 2.2.2]]
***[[GrandChild j2.3 jjjj jjj jjjj mmm mmm mmmm and this is even mibberk]]
</div>
This is what happens to a family when there are no contraceptives.
See also [[Overflow contained in tiddler]]
```
<div class="family-tree">
*[[Parent]]
**[[Child 1]]
...
```
<div class="family-tree">
*[[Parent]]
**[[Child 1]]
***[[GrandChild 1.1]]
**[[Child 2]]
***[[GrandChild 2.1]]
***[[GrandChild 2.2]]
****[[Great GrandChild 2.2.1]]
****[[Great GrandChild] 2.2.2]]
***[[GrandChild j2.3 jjjj jjj jjjj mmm mmm mmmm and this is even mibberk]]
***[[GrandChild 2.1]]
***[[GrandChild 2.2]]
****[[Great GrandChild 2.2.1]]
****[[Great GrandChild] 2.2.2]]
***[[GrandChild j2.3 jjjj jjj jjjj mmm mmm mmmm and this is even mibberk]]
</div>
<div class="demo">
<table style="width:100%;">
<tr>
<td rowspan="2" style="width:220px;">
Click to export:<$macrocall $name="exportButton" exportFilter="[prefix[$:/core/ui/Buttons/]] $:/themes/jd/Material/images/overflow-button" lingoBase="$:/language/Buttons/ExportTiddler/" baseFilename="More_actions_button"/>
<br>
(or drag into your TW)
</td>
<td>
<$list filter="[prefix[$:/core/ui/Buttons/]]">
<$transclude field="title"/><br>
</$list>
$:/themes/jd/Material/images/overflow-button
</td>
</tr>
</table>
</div>
Die Gliederung nach dem Pandektensystem teilt das Zivilrecht in fünf (beziehungsweise sechs, mit eigenständigem Personenrecht) Teilbereiche ein: Allgemeiner Teil (in der Regel mit Personenrecht), Schuldrecht, Sachenrecht, Erbrecht, Familienrecht. Diesem pandektistischen Schema folgt neben dem deutschen Bürgerlichen Gesetzbuch (BGB) das schweizerische Zivilgesetzbuch (ZGB).
Allgemeiner Teil
Grundlagen (Privatrecht; objektives und subjektives Recht)
Personenrecht (natürliche Personen; juristische Personen)
Lehre vom Rechtsgeschäft (Willenserklärung und Rechtsgeschäft; Vertrag; Geltungsvoraussetzungen des Rechtsgeschäfts)
Stellvertretung
Zeit (Fristen, Termine; Verjährung)
Schuldrecht
Sachenrecht
Familienrecht
Erbrecht
<$list
filter='[<currentTiddler>tag[Paragraph]]'
>
<$list
filter='[[$:/settings]has[paragraph_info]get[paragraph_info]prefix[True]]'
variable=dummy
>
Book:
<$link
to={{!!book}}
>
<$view
tiddler={{!!book}}
field='caption'
/>
</$link>
<br>
Chapter:
<$link
to={{!!chapter}}
>
<$view
tiddler={{!!chapter}}
field='caption'
/>
</$link>
<br>
Paragraph #:
<$count
filter='[[dummy]][book{!!book}chapter{!!chapter}tag[Paragraph]nsort[order]allbefore<currentTiddler>]'
/>
</$list>
<div
style='float:left;position:relative;left:-10'
>
<$button
class='tc-btn-invisible'
tooltip='Bookmark Paragraph'
>
{{$:/core/images/spiral}}
<$action-setfield
$tiddler='$:/data/Bookmarks'
$index=<<currentTiddler>>
$value=Bookmark
/>
</$button>
</div>
</$list>
This is tiddler [[Paragraph1]]. It is a paragraph in [[GenericArticle]]
*Has a field ''paragraphs: {{!!paragraphs}}''
It is styled with a colored background, which also affects it's sections.
<$navigator story="PE:story" history="PE:history">
{{$:/core/ui/Buttons/new-tiddler}}
<$list filter="[list[PE:story]]" template="PE:view" editTemplate="PE:edit" emptyMessage={{PE:empty}} />
</$navigator>
---
<!--
<<list-links "[prefix[PE:]]">>
<<list-links "[list[PE:story]]">>
<<list-links "[all[shadows]prefix[$:/core/ui/Buttons/]] +[limit[0]]">>-->
Edit and rearrange sub tiddlers. I created this in part in response to a [[post|https://groups.google.com/forum/#!topic/tiddlywiki/RNqJR1s6ysk]] in the TW Google Group.
---
<$navigator story="PE:story" history="PE:history">
{{$:/core/ui/Buttons/new-tiddler}}
<$list filter="[list[PE:story]]" template="PE:view" editTemplate="PE:edit" emptyMessage={{PE:empty}} />
</$navigator>
---
<!--
<<list-links "[prefix[PE:]]">>
<<list-links "[list[PE:story]]">>
<<list-links "[all[shadows]prefix[$:/core/ui/Buttons/]] +[limit[0]]">>-->
<$edit-text tiddler="$:/temp/PersonDBeditPerson" tag="input" type="text"/> <$set name="tags" value="person"><$newtiddler title={{$:/temp/PersonDBeditPerson}} skeleton="personSkeleton" edit="no" class="btn-invisible">{{$:/core/images/new-button}}</$newtiddler></$set>
<ul><$list filter="[tag[person]sort[title]]"><li>{{!!title||personEntry}}</li></$list></ul>
\define editbutton()
<span title="edit details"><$button set="$:/temp/PersonDBeditPerson" setTo={{!!title}} class="btn-invisible">{{$:/core/images/edit-button}}</$button></span>
\end
\define editfield()
<$reveal state="$:/temp/PersonDBeditPerson" text={{!!title}} type="match">
{{!!title||editPerson}}
<$button set="$:/temp/PersonDBeditPerson" setTo="" class="btn-invisible">{{$:/core/images/done-button}}</$button> <$button param={{$:/temp/PersonDBeditPerson}} message="tw-delete-tiddler" class="btn-invisible">{{$:/core/images/delete-button}}</$button>
</$reveal>
\end
<$link><$view field="title"/></$link> <<editbutton>> <<editfield>>
<$list filter="[tag[person]!town[]each[town]sort[town]]">
! <$view field="town"/>
<ul><$list filter="[town{!!town}]"><li>{{!!title||personEntry}}</li></$list></ul>
</$list>
\define plaintabspalette()
tab-background:transparent
tab-background-selected:inherit
tab-border:transparent
tab-border-selected:#a8a8a8
tab-divider:#d8d8d8
sidebar-tab-background:inherit
sidebar-tab-background-selected:inherit
\end
\define describePaletteColour(colour)
<$transclude tiddler="$:/language/Docs/PaletteColours/$colour$"><$text text="$colour$"/></$transclude>
\end
<br>
<$set name="currentTiddler" value={{$:/palette}}>
<$list filter="[all[current]is[shadow]!is[tiddler]]" variable="listItem">
<$set name="currentTiddler" value={{$:/palette}}>
<$button>
<$list variable="item" filter=<<plaintabspalette>> variable="item">
<$set name=pos filter="[<item>splitbefore[:]removesuffix[:]]">
<$set name=val filter="[<item>removeprefix<pos>removeprefix[:]]">
<$action-setfield $index=<<pos>> $value=<<val>>/>
</$set>
</$set>
</$list>
<$action-setfield $tiddler="$:/plugins/TWaddle/PlainTabs/Stylesheet"
$field="tags" $value="$:/tags/Stylesheet"/>
ACTIVATE
</$button> Plain Tabs.<br><br>
● Activation sets some color values in the active palette <$link to={{$:/palette}}><$macrocall $name="currentTiddler" $output="text/plain"/></$link> <br>
● and, if not already, applies a `$:/tags/Stylesheet` tag to the Plain Tabs [[stylesheet|$:/plugins/TWaddle/PlainTabs/Stylesheet]]
</$set>
</$list>
<$list filter="[all[current]is[shadow]is[tiddler]]" variable="listItem">
<$button>
<$action-deletetiddler $tiddler={{$:/palette}}/>
<$action-setfield $tiddler="$:/plugins/TWaddle/PlainTabs/Stylesheet"
$field="tags" $value=""/>
DEACTIVATE
</$button> Plain Tabs.<br><br>
● Deactivation //restores// the active palette <$link to={{$:/palette}}><$macrocall $name="currentTiddler" $output="text/plain"/></$link> to its default shadow state <br>
● and it removes the `$:/tags/Stylesheet` tag from the Plain Tabs [[stylesheet|$:/plugins/TWaddle/PlainTabs/Stylesheet]]
</$list>
When happy, delete this particular tiddler as it serves no further purpose <$button><$action-deletetiddler $tiddler="PlainTabs/settings"/>Delete</$button>
</$set>
Current values in {{$:/palette}} for colors concerning tabs:
<$set name="currentTiddler" value={{$:/palette}}>
<table>
<tbody>
<$list filter=<<plaintabspalette>> variable="item">
<$set name=colourName filter="[<item>splitbefore[:]removesuffix[:]]">
<tr>
<td>
''<$macrocall $name="describePaletteColour" colour=<<colourName>>/>''<br/>
<$macrocall $name="colourName" $output="text/plain"/>
</td>
<td>
<$edit-text index=<<colourName>> tag="input"/>
<br>
<$edit-text index=<<colourName>> type="color" tag="input" />
</td>
</tr>
</$set>
</$list>
</tbody>
</table>
</$set>
<$button message="tm-home" tooltip={{$:/language/Buttons/Home/Hint}} aria-label={{$:/language/Buttons/Home/Caption}} class=<<tv-config-toolbar-class>>>
<$list filter="[<tv-config-toolbar-icons>]">
</$list>
<$appear show="📕" type=popup $state="popup-button">
<$tiddlymap
class="tmap-sidebar-map-editor"
editor="advanced"
object-id="main_editor"
click-to-use="false">
</$tiddlymap>
</$appear>
</$button>
It has been discussed in the TW google group how to footnotes should be implemented<<footnote "note1" "https://groups.google.com/forum/#!searchin/tiddlywiki/footnotes%7Csort:date/tiddlywiki/u5A6qK7CmrY/DekPDREpQJgJ">>. This is just my vision of how footnotes should be in a modern browser environment. If you click in the footnote label you will see a popup with the footnote. Try it out in the previous one.
This implementation has several advantages:
* It is built with TW5 native elements. You need nothing but TW5 to make it work.
* It doesn't interrupt the reading flow.
* In case you want to read the plain text it is perfectly readable.
If you want it you have two ways to make it work:
! Install
!! Style
To prevent the very long notes going out of the screen grab this style sheet tiddler to your wiki:
[[popupStyle]]
,,Thanks to UBi,,
!! For a global scope
Copy the following code into any tiddler and tag it as $:/tags/Macro or grab this tiddler to your TW: [[$:/macros/danielo/footNote]]
{{$:/macros/danielo/footNote||code}}
!!For a local scope
Copy the same code into any tiddler you want to use the macro.
!Usage
!!Single reference
It's fairy simple
```
<<footnote "label" "text of the footnote">>
```
Wich renders as <<footnote "label" "text of the footnote">>
!!Multiple reference
Once defined you can use the same annotation multiple times. Use the `ref` macro and the same label of the note you want to reference again.
```
<<ref "label">>
```
Wich renders as <<ref "label">>
!! Botom definition.
Maybe you want to stick to classic footnotes but you like the popup thing. This means that you want to have all your definitions at the bottom of the page and reference them later like this <<ref "Note2">>. In that case use the same `ref` notation than in multiple reference but make your footnotes definitions at the bottom of the page. This way you cold maintain a page-wise formatting <<ref "Note3">> as Eric Shulman suggested.
```
---
<<footnotes "2" "You can see this footnote at the bottom of the page or inside a popup">>
```
Wich will render as:
---
<<footnotes "Note2" "You can see this footnote at the bottom of the page or inside a popup">>
<<footnotes "Note3" "although popup footnotes are useful for onscreen display, printed documents would need to have footnotes placed at the bottom of the page on which the footnote occurs.">>
.tc-drop-down dd
{
max-width:300px;
word-break: break;
white-space:normal;
padding :0;
padding-left: 5px;}
.tc-drop-down dl
{
padding: 5px;
}
tc-drop-down a {display:inline;padding:0}
<<list-links "[prefix[C]]">>
* Überbuchung
* Schimmel im Hotel
* Baulärm im Hotel
* Ungeziefer im Hotelzimmer
Die Prüfungsreihenfolge der Anspruchsgrundlagen regelt die Reihenfolge der zu prüfenden Ansprüche.
A. [[Vertragliche Ansprüche]]
B. [[Quasivertragliche Ansprüche ]]
C. [[Dingliche Ansprüche]]
D. [[Deliktsiche Ansprüche]]
E. [[Bereicherungsrechtliche Ansprüche]]
Beachte: Diese Prüfungsreihenfolge der Anspruchsgrundlagen ist zwingend zu berücksichtigen. Diese Prüfungsreihenfolge der Anspruchsgrundlage ist deshalb zwingend, weil bestimmte Ansprüche andere Ansprüche ausschließen. Beispiel: A schließt mit B einen Vertrag, dass B den Brand des A löscht. Dieser Vertrag würde Ansprüche aus der GoA ausschließen, denn diese setzt gerade voraus, dass kein Auftrag vorliegt. Ebenso setzen bestimmte dingliche Ansprüche voraus, dass kein Recht zum Besitz besteht. Ein solches Recht kann jedoch aus einem Vertrag folgen, sodass es sinnvoll ist, diesen bereits zuvor geprüft zu haben. Weiterhin ist zu beachten, dass, wenn EBV-Ansprüche nicht in Betracht kommen, auch deliktische Ansprüche nicht mehr zu prüfen sind, da diese nach § 993 a.E. BGB ausgeschlossen sind. Im Übrigen besteht zwischen diesen Ansprüchen Anspruchskonkurrenz. Sie bestehen somit nebeneinander, wenn sie sich nicht denklogisch ausschließen.
\define source()
http://communitycomments.tiddlyspot.com/#:[[$(tid)$]]
\end
\define concat() CommunityComments/$(username)$
\define mycom()
<$vars username={{$:/status/UserName}}>
<$vars tid=<<concat>> >
<$link to=<<tid>>><$view tiddler=<<tid>> field="title" format="text"><<tid>></$view></$link>
</$vars>
</$vars>
\end
''Your public comments'' about tiddler //<$view tiddler={{!!title}} field="title" format="text">{{!!title}}</$view>// get stored in [[MyCom]].<br>When satisfied, please send it to ... and it'll be published on [[CommunityComments|http://communitycomments.tiddlyspot.com/]].
<$edit-text tag="textarea" tiddler="MyCom" field="text" index={{!!title}} placeholder="Type some notes of general interest about this specific tiddler" class="tc-edit-texteditor"/><br><br>''Community comments'' on tiddler //<$view tiddler={{!!title}} field="title" format="text">{{!!title}}</$view>// (iframe fetching from [[CommunityComments|http://communitycomments.tiddlyspot.com/]]):
<$vars tid={{!!title}}>
<iframe src=<<source>> frameborder="0" width="100%" height="300px" style="overflow-x:hidden; overflow-y:auto; ">Loading Community Comments....</iframe>
</$vars>
Die Prüfung der Anspruchsgrundlagen setzt sich sodann mit der Prüfung der quasi-vertraglichen Ansprüche fort. Dies sind vertragsähnliche Ansprüche, die bei dem Schadensersatz nach Irrtumsanfechtung, der Vertretung ohne Vertretungsmacht, culpa in contrahendo (cic) und der Geschäftsführung ohne Auftrag (GoA) in Betracht kommen. Bei der Irrtumsanfechtung entsteht ein Schadensersatzanspruch anlässlich des aufgrund der Anfechtung gescheiterten Vertrags gemäß § 122 BGB. Der Vertreter ohne Vertretungsmacht ist in § 179 BGB geregelt. Beispiel: A erteilt dem B die Vollmacht, ihm ein Auto für 10.000 Euro zu kaufen. B schließt jedoch einen Kaufvertrag über ein Auto, das 100.000 Euro kostet und hat damit nach außen ohne Vertretungsmacht gehandelt, sodass A nicht Vertragspartner und damit nicht verpflichtet wird, den Betrag zu zahlen. Allerdings hat der Verkäufer des Wagens gemäß § 179 BGB gegen B einen Anspruch, als wäre B selbst der Vertragspartner gewesen. Culpa in contrahendo ist in den §§ 280 I, 311 II, 241 II BGB geregelt und meint das Verschulden bei Vertragsschluss. Beispiel: A kommt anlässlich einer Probestunde in ein Repetitorium und rutscht dort aus, weil nicht ordentlich gewienert worden ist. Folglich steht dem A unabhängig davon, ob später ein Vertragsschluss zustande kommt, ein Schadensersatzanspruch gegen das Repetitorium zu. Mithin kommen bereits in der Anbahnung des Vertrag Schadensersatzansprüche in Betracht. Die GoA ist in den §§ 677 ff. BGB normiert. Beispiel: Das Haus des A brennt und B sieht als Passant den Brand und löscht ihn mit seinen Mitteln. Dem B steht danach ein Anspruch auf Aufwendungsersatz gemäß §§ 683 S. 1, 670, 677 BGB zu, so als wenn er von A beauftragt worden wäre.
Personen - Subjekte (Agenten)
Sachen - Objekte
Handlungen und Unterlassungen (vorsätzlich, fahrlässig) - Prozesse
Beschreibung durch existierende Ontologien (zB WordNet)
Rechtssystem als (gewollte, akzeptierte und erzwungene) Normenordnung: Idee der sozioökonomischen Gestaltung durch Recht bei Risikominimierungsziel
Informationssystem (Textarchiv)
Publizierte, kommunizierte und dokumentierte Rechtsordnung
Texte + Zeichen + Bilder
Früher: Gesetzesblätter, heute: Rechtsdokumentations- und Rechtssuchmaschine
Analyse und Beschreibung - wissensbasiertes System
Kommentar und System (konventionelle Methode); IT-gestütztes System (AI Forschungen)
Fähigkeit, Träger von Rechten u. Pflichten zu sein
=> Beginnt beinatürlichen Personen mit der
Vollendung der Geburt (§ 1) u. endet mit dem Tod (Hirntod)
Handlungsfähigkeit Fähigkeit des Menschen, rechtlichbedeutsame Handlungenvorzunehmen
=> Man unterscheidet
zwischen
* [[Geschäftsfähigkeit]]
* [[Testierfähigkeit]]
* [[Deliktsfähigkeit]]
Ein Rechtsgebiet ist ein Teilgebiet des Rechtes. Rechtsgebiete ergeben sich aus der Notwendigkeit das Recht in Teilgebiete zu strukturieren.
Dies ist (wie immer im Recht) natürlich nicht mit mathematischer Genauigkeit möglich. Die Grenzen zwischen Rechtsgebieten sind notwendigerweise unscharf.
Es gibt zwei Sorten von Rechtsgebieten:
Solche, deren Gemeinsamkeit eine rechtssystematische Gemeinsamkeit ist (z. B. Allgemeines Schuldrecht oder Deliktsrecht) und
solche, deren Gemeinsamkeit rein rechtstatsächlicher Natur ist (Medizinrecht, Computerrecht, Anwaltsrecht).
Sollte den ''Fields'' zugeordnet werden
<<tabs "[tag[_Rechtsgebiete]]" "" "" >>
<div class="family-tree" >
*[[Zivilrecht]] - Kategorie
**[[Allgemeines Schuldrecht]]- Fields
**[[Besonderes Schuldrecht]]- Fields
***[[Kaufrecht]] - SubKategorie
***[[Schadensersatzrecht]] - Subkategorie
</div>
''Textspeicher der Rechtsordnungen''
Techniken: Speicherung, Retrieval, Dateiorganisation
Sehr leicht verfügbar (mit Mausklick innerhalb von Minuten am Bildschirm/ausgedrucktes Exemplar)
''Verbesserte Suche''
Suchkriterien = Beschreibungen der Inhalte, Rechtsprobleme etc.
Identitätssuche
Volltextsuche: sehr umfangreich, schwer beherrschbar
Assoziationssuche: Verweise, Zeit, Dokumentkategorien, Indices (Klassifikationscodes, Schlagwortlisten, Thesauri)
Volle sprachliche Beschreibung der Rechtsordnung, aber für Computer nicht verständlich
Nutzer muss aus Textarchiv intelligentes Werkzeug machen
Jemand, der Träger von Rechten sein kann
<<rojo "text to put in red color">>
This is a single macro to put any text in red color.
Usage:
```
<<rojo "text to put in red color">>.This is not in red color
```
<<rojo "text to put in red color">>. This is not in red color.
The macro name is rojo instead of red for two reasons:
* Spanish is my native languaje.
* red is a very common word in english, so I choosed rojo to avoid possible collisions.
If you want this macro just grab this link to your TW5:
[[$:/macros/danielo/rojo.js]]
''Note that after installing this macro you have to reload the browser in order to make it work.'' This is because the core have to load the javascript code.
Special thanks to ''StephanHradek'' to make the basic javascript macro example. ( [[TW5Magick|http://tw5magick.tiddlyspot.com/]] )
Link in Wikitext
[[Markup Reference]]
[[Scripts|https://tw-scripts.github.io/TW-Scripts/#Conditionally%20Display%20The%20Tiddler%20Contents]]
The following optional parameters can be specified for the ''xlist'' macro:
<table class="td-top">
<tr>
<th>#</th>
<th>Field</th>
<th>Description</th>
<th>Default</th>
</tr>
<$list filter="[list[]]">
<tr>
<td><<iterator>></td>
<td><$link to=<<currentTiddler>>><$view field=title/></$link></td>
<td>{{!!parent}}</td>
<td>{{!!gesetz}}</td>
</tr>
</$list>
</table>
<<tokeneditor>><<appendTokenButton>>
<$transclude tiddler="$:/danielo515/ui/item-button"/>
\define mylist(filter)
''Filter is:'' `$filter$`
<ul><$list filter="[$filter$]"><li><$link><$view field="title"/></$link></li></$list></ul>
\end
''Note:'' {{!!title}} is part of TiddlyWiki {{!!part-of}}.
search modules-used containing "core"
<<mylist "modules-used/core/">>
search tiddlers containing "~FireFox" or "jEdit"
<<mylist "text/FireFox|jEdit/">>
search tiddlers having "Widget" in the title, igoring the case
<<mylist "field:title/widget/(i)">>
Read the [[TiddlerFilters]] documentation for a full explanation about RegExp in filters.
\define min-per-group() 10
\define ABC() A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
\define xABC() A B C D E F
\define regexpABC() (?i)^$(letr1)$$(letr2)$$(letr3)$
\define glueABC() $(letr1)$$(letr2)$$(letr3)$
<$button> Create alphabetical TOC structure
<$list filter="[enlist<ABC>]" variable=letr1>
<$list filter="[enlist<ABC>]" variable=letr2>
<$list filter="[enlist<ABC>]" variable=letr3>
<$list filter="[all[tiddlers]!has[draft.of]regexp<regexpABC>rest<min-per-group>limit[1]]" variable="dummy">
<$action-setfield $tiddler=<<glueABC>> tags=<<letr1>> />
<$list filter="[all[tiddlers]regexp<regexpABC>]" >
<$fieldmangler>
<$action-sendmessage $message="tm-remove-tag" $param=<<letr1>>/>
<$action-sendmessage $message="tm-add-tag" $param=<<glueABC>>/>
</$fieldmangler>
</$list>
</$list>
</$list>
</$list>
</$list>
</$button>
[[Pauschalreise|Reisevertrag]]
[[Reisemangel]]
[[Verschulden des Reiseveranstalters]]
{{ Verschulden des Reiseveranstalters }}
[[Erhebliche Beeinträchtigung bzw. Verhinderung]]
erhebliche Beeinträchtigung oder sogar die Vereitelung der Reise
Als erhebliche Beeinträchtigung gilt dabei ein Reisemangel, welcher eine Preisminderung von 50 Prozent rechtfertigt, wohingegen eine Vereitelung vorliegt, wenn ein Reiseantritt gar nicht möglich war.
[[Mängelanzeige]]
[[BGB - 651m]]
* Mängelanzeige oder Abhilfeverlangen
* Vertretenmüssen
* Erheblichkeit
Rechtsfolge [[Mangelschaden]] oder [[Mangelfolgeschaden]]
Eine Entschädigung ist nur möglich, wenn die Reise mit einem Mangel behaftet ist. Dabei handelt es sich grundsätzlich um jede Art von Abweichung gegenüber den vereinbarten Vertragsbedingungen.
* Fehler oder
* Fehlen einer zugesicherten Eigenschaft (nur aus Prospekt, weil es meist die einzige Informationsquelle ist)
Abrenzung zur bloßen Unannehmlichkeit
* gestörte Einzelleistung hat immer Nutzen der ganzen Reise zu mindern
kein Ausschluss
* Schimmel im Hotel
* erhebliche Flugverspätung
| __Differenzierung__ |
| Reisender | Reiseveranstalter |
| <<list-links "[partei[Reisender]sort[title]]">> | <<list-links "[partei[Reiseveranstalter]sort[title]]">> |
! Problemkreise
* [[Probleme mit dem Hotel]]
* [[Insolvenz Fluggesellschaft oder Hotel oder Reiseveranstalter]]
* [[Entgangene Urlaubsfreude]]
* Reisepreisminderung
* Reiserecht bei einer Kreuzfahrt
* Hotelbeschreibung und Katalogsprache
* Grundsatz zu Prospektwahrheit und -klarheit
* Reisesicherungsschein
* Höhere Gewalt
* Klimaanlage defekt
* Lärm im Urlaub
<<x-tag "Tag" label:"rechtsgebiet">>
{{||$:/plugins/btheado/ftlist/tagbar}}
---
<$set name="showItemTags" filter="[all[current]addprefix[$:/state/]addsuffix[/showItemTags]]">
{{||$:/plugins/btheado/ftlist/tagged-tiddler-creator}} {{$:/plugins/btheado/ftlist/toggle-tag-display}}
<$set name="currentListTiddler" value=<<currentTiddler>>>
<$list filter="[<currentTiddler>tagging[]]" emptyMessage="<div>No items in the list. New items entered above will be displayed here.</div>">
{{||$:/plugins/btheado/ftlist/tagged-list-item}}
</$list>
</$set>
</$set>
* Mangelschaden und Mangelfolgeschaden
* Entschädigung für nutzlose Urlaubszeit
Dabei handelt es sich um ein Paket des Reiseveranstalters, welches sowohl die Anreise als auch die Übernachtung beinhaltet und zu einem Gesamtpreis angeboten wird.
''Gesamtheit von Reiseleistungen''
Problem bei Ferienunterkunft, da nur eine Reiseleistung angeboten wird - analoge Anwendung
auch für am Urlaubsort hinzuguchte Leistungen
\define related-footer()
<h5><$list filter=[all[current]has[related]]>
//Related// |
<$list filter=[all[current]list[!!related]] variable="name">
<$set name="tv-wikilink-tooltip" value="{{!!title}} - {{!!description}}">
<$link to=<<name>> > <<name>>
</$link> |
</$set>
</$list></$list></h5>
\end
\define set-field(PL) <$action-setfield $tiddler="$(WT)$" $field ="related" $value="$(PL)$">
\define related()
<$list filter="[has[draft.of]]">
<$set name =TT value={{!!draft.title}}>
<$set name =RL value={{!!related}}>
<$set name=FL filter="[enlist<RL>][<TT>]">
<$button>
<$list filter="[enlist<RL>]" variable="WT">
<$set name=PL filter="[enlist<FL>]-[<WT>]">
<$macrocall $name="set-field"/>
</$set>
</$list>
Set Related Tiddlers<br>
as shown below:<br>
</$button>
<$list filter="[enlist<RL>]" variable="WT">
<$set name=PL filter="[enlist<FL>]-[<WT>]">
Tid: <<WT>> - Set Related: <<PL>>
</$set></$list></$set></$set></$set></$list>
\end
Man kann zwei Klassen an Beziehungen unterscheiden:
*Relationen, welche [[Konzepte]] hierarchisch ordnen
*Relationen, welche [[Konzepte]] untereinander in beliebiger Beziehung
setzen
<table id="noborders">
<tr><td width="40%">
''Regelfall'' //<$view tiddler={{!!title}} field="title" format="text">{{!!title}}</$view>//
<$list filter="[tag{!!title}fall[Regel]]">
<li><$link to={{!!title}}><$view tiddler={{!!title}} field="title" format="text">{{!!title}}</$view></$link></li>
</$list>
</td><td width="40%">
''Ausnahme'' //<$view tiddler={{!!title}} field="title" format="text">{{!!title}}</$view>//
<$list filter="[tag{!!title}fall[Ausnahme]]">
<li><$link to={{!!title}}><$view tiddler={{!!title}} field="title" format="text">{{!!title}}</$view></$link></li>
</$list>
</td></tr>
</table>
<style>
#noborders, #noborders th, #noborders tr, #noborders td {border:0; }
#noborders td {vertical-align:top; }
#noborders td.special { padding-left:15px; border-left:1px solid lightgray }
</style>
{{||$:/plugins/btheado/ftlist/tagbar}}
---
<$set name="showItemTags" filter="[all[current]addprefix[$:/state/]addsuffix[/showItemTags]]">
{{||$:/plugins/btheado/ftlist/tagged-tiddler-creator}} {{$:/plugins/btheado/ftlist/toggle-tag-display}}
<$set name="currentListTiddler" value=<<currentTiddler>>>
<$list filter="[<currentTiddler>tagging[]]" emptyMessage="<div>No items in the list. New items entered above will be displayed here.</div>">
{{||$:/plugins/btheado/ftlist/tagged-list-item}}
</$list>
</$set>
</$set>
Modification of the ftlist functionality so new items are displayed at the bottom rather than at the top of the list. The modified code in [[reverse ftlist]] is transcluded here instead of [[$:/plugins/btheado/ftlist/main]]. Written in response to email discussion at https://groups.google.com/d/msg/tiddlywiki/MRDxtQFrkfw/xPU7cdCICQAJ.
---
{{||reverse ftlist}}
title: "right" -- named the same as the tag used to define rights
text:"""
Right: {{!!title}}
Edit Right: <$edit field="title" />
<br/>
Rechtsgebiet: <<crazyListHere "zivilrecht" "arbeitsrecht">>
<br/>
Publisher: <$select field="gesetz"><option value=""> -- </option><$list filter="[tag[gesetz]]"><option value=<<currentTiddler>> > <<currentTiddler>> </option></$list></$select>
<br/>
Edit Right: <$edit field="text" />
<br/>
"""
title: "Book Dashboard"
text: """
Add a book: <$edit-text tag="input" tiddler="$:/temp/newright" />
<$button>
Add book
<$action-setfield $field="currentright" $value={{$:/temp/newright}} />
<$action-setfield $tiddler={{$:/temp/newright}} $field="tags" $value="right" />
<$action-setfield $tiddler="$:/temp/newright" $field="text" $value="" />
</$button>
Select a book to edit:
<$select field="currentbook">
<option value=""> -- </option>
<$list filter="[tag[right]]" variable="Current_Right" emptyMessage="""
<option value=""> There are no rights available </option>
""">
<option value=<<Current_Right>> >
<<Current_Right>>
</option>
</$list>
</$select>
<$tiddler tiddler={{!!currentright}} >
<$transclude tiddler="right" />
</$tiddler>
"""
<$edit-text tiddler="$:/temp/PersonDBeditRight" tag="input" type="text"/> <$set name="tags" value="right"><$newtiddler title={{$:/temp/PersonDBeditRight}} skeleton="rightSkeleton" edit="no" class="btn-invisible">{{$:/core/images/new-button}}</$newtiddler></$set>
<ul><$list filter="[tag[right]sort[title]]"><li>{{!!title||rightEntry}}</li></$list></ul>
\define editbutton()
<span title="edit details"><$button set="$:/temp/PersonDBeditRight" setTo={{!!title}} class="btn-invisible">{{$:/core/images/edit-button}}</$button></span>
\end
\define editfield()
<$reveal state="$:/temp/PersonDBeditRight" text={{!!title}} type="match">
{{!!title||editRight}}
<$button set="$:/temp/PersonDBeditRight" setTo="" class="btn-invisible">{{$:/core/images/done-button}}</$button> <$button param={{$:/temp/PersonDBeditRight}} message="tw-delete-tiddler" class="btn-invisible">{{$:/core/images/delete-button}}</$button>
</$reveal>
\end
<$link><$view field="title"/></$link> <<editbutton>> <<editfield>>
Eine unbenannte Zuwendung ist als eine Leistung anzusehen ist, welche unter dem Vertrauen auf den Fortbestand der Ehe erfolgt ist. Somit kann die Ehe als deren Geschäftsgrundlage angesehen werden. Grundsätzlich verbleiben Zuwendungen auch beim Scheitern einer Ehe bei demjenigen, an den sie gemacht worden sind. Kommt es nun zum Scheitern einer Ehe, können gegebenenfalls Rückforderungsansprüche entstehen, da der Wegfall der Geschäftsgrundlage gemäß § 313 BGB angenommen wird. Dabei ist zu beachten, dass nicht die Zuwendung an sich zurückgefordert werden kann, sondern ein entsprechender Geldbetrag. Dieser wiederum ist nicht unbegrenzt möglich. In der Praxis kommt es allerdings selten zu einer derartigen Rückforderung, da diese wiederum nur unter den Aspekten der Zumutbarkeit erfolgen kann.
Generell ist bei Rückforderungen von unbenannten Zuwendungen beim Scheitern einer Ehe zu beachten, in welchem Güterstand diese bestanden hat.
Lebten die Ehepartner im gesetzlichen Güterstand der Zugewinngemeinschaft, hat die Rückerstattung der unbenannten Zuwendung über den Zugewinnausgleich zu erfolgen.
Bei Ehepartnern, welche im Güterstand der Gütertrennung lebten, kann die Rückforderung der unbenannten Zuwendungen aufgrund des Wegfalls der Geschäftsgrundlage nur unter bestimmten Bedingungen erfolgen:
Der Ehepartner, welcher die Zuwendung erhalten hat, muss ein noch messbares Vermögen vorliegen
Die Höhe des Ausgleichs muss angemessen sein
Die Beibehaltung der bisherigen Vermögensverhältnisse muss – unter Berücksichtigung der Dauer der Ehe sowie der Einkommens- und Vermögensverhältnisse beider Ehepartner – unzumutbar sein.
Unbenannte Zuwendungen können sich aber nicht nur Eheleute untereinander machen, sondern auch andere Personen, beispielsweise die Schwiegereltern. Ist dies der Fall und kommt es zu einem Scheitern der Ehe, wurden derartige Zuwendungen ebenso behandelt wie jene von Eheleuten untereinander. Seit einigen Jahren ist dies nicht mehr der Fall: unbenannte Zuwendungen, welche von Schwiegereltern gemacht wurden, werden fortan als Schenkungen betrachtet [BGH, 03.02.2010, XII ZR 189/06]. Durch dieses Grundsatzurteil ist es nunmehr für Schwiegereltern wesentlich leichter, im Falle einer Scheidung an ihr Schwiegerkind geleistete Zuwendungen zurückzufordern.
Rückforderung von Vermögenszuwendungen unter Ehegatten
Die Unterstützung des anderen Ehegatten durch den wirtschaftlich stärkeren Ehegatten ist der Normalfall. Welche Rechte bei demjenigen verbleiben, der schenkt, gibt, ist Gegenstand der Betrachtung der vorliegenden Abhandlung:
Erst kürzlich urteilte der BGH wieder in diesem schon klassisch sehr umstrittenen Themengebiet und stellte in einem seiner Leitsätze fest: „Die Übertragung des Hälfteanteils eines zuvor je zur Hälfte im Eigentum beider Ehegatten stehenden Grundstücks an den anderen Ehegatten ist unentgeltlich, wenn die gleichzeitig getroffene Vereinbarung über einen Zugewinnausgleich im Falle der Durchführung dem übertragenden Ehegatten keinen Vorteil verschafft." (vgl. BGH Urteil vom 8. Dezember 2011, Aktenzeichen: - IX ZR 33/11)
Bezug genommen wurde insoweit auch auf Folgenden Leitsatz eines früheren BGH Urteils:
„Eine Zuwendung unter Ehegatten, die um der Ehe willen oder als Beitrag zur Verwirklichung oder Ausgestaltung der ehelichen Lebensgemeinschaft erbracht wird und darin ihre Geschäftsgrundlage hat, stellt keine Schenkung dar, sondern eine ehebedingte Zuwendung (BGH, Urteil vom 9. Juli 2008 - XII ZR 179/05, BGHZ 177, 193 Rn. 15 mwN).
Grund genug die historisch bedeutsamen Grundlagen dieser Rechtsprechung zu - wenigstens in Ihren Grundzügen zu betrachten:
1. Die Schenkung ohne Gegenleistung:
Wird Vermögen oder Geld übertragen steht meist keine konkrete Gegenleistung gegenüber. Folglich eine Schenkung als unentgeltliche Zuwendung gem. § 518 BGB anzunehmen wäre. Dies wäre aber nach der Rechtsprechung nur anzunehmen, - wenn der andere Ehegatte mit dem zugewendeten Gegenstand oder Geld tun und lassen darf was er will,- diese Verwendung also nicht an die Lebensgemeinschaft selbst „gekoppelt" ist. Nur im ersten Fall liegt tatsächlich eine Schenkung vor. Im zweiten Fall ist es hingegen der Willen des Zuwendenden die Leistung nicht zu einer allein den Empfänger einseitig begünstigenden und frei disponiblen Bereicherung zuzuführen. Die Bereicherung ist soll im zweiten Fall die eheliche Lebensgemeinschaft selbst prägen.
2. Ehebedingte Zuwendungen und Ausgleich über das eheliche Güterrecht der Zugewinngemeinschaft:
Dient die Zuwendung jedoch der ehelichen Lebensgemeinschaft und erfolgt die Zuwendung unter der Annahme, dass die Ehe Bestand hat kann nicht ohne weiteres Schenkungsrecht Anwendung finden. Es wird dann von der Rechtsprechungspraxis eine kausale Verknüpfung der Zuwendung angenommen. Der BGH nimmt an, dass es an der Einigkeit über die Unentgeltlichkeit fehlt. Dies hat zur Konsequenz, dass nicht eine Schenkung vorliegt. Der BGH geht von einem gesetzlich nicht geregelten Vertrag "sui generis" aus, dessen Geschäftsgrundlage die eheliche Lebensgemeinschaft ist. Der BGH differenziert in Abgrenzung zu einer Schenkung wie folgt: „Eine Schenkung setzt Einigkeit beider Teile darüber voraus, dass die Zuwendung unentgeltlich erfolgt. Unentgeltlich ist eine Zuwendung nur, wenn sie nach dem Inhalt des Rechtsgeschäftes von keiner Gegenleistung abhängt. Unentgeltlichkeit fehlt nicht nur dann, wenn der Zuwendung eine Leistung des Empfängers gegenübersteht, die zu ihr in einem Gegenseitigkeitsverhältnis steht, sondern auch, wenn die Zuwendung rechtlich die Geschäftsgrundlage hat, dass dafür eine Verpflichtung eingegangen oder eine Leistung bewirkt wird. Dabei braucht diese Leistung nicht geldwerter oder vermögensrechtlicher Art zu sein; sie kann auch immateriellen Charakter haben. Hieraus ergibt sich, dass eine Zuwendung unter Ehegatten, der die Vorstellung oder Erwartung zugrunde liegt, dass die eheliche Lebensgemeinschaft Bestand haben werde, oder die sonst um der Ehe willen und als Beitrag zur Verwirklichung oder Ausgestaltung, Erhaltung oder Sicherung der ehelichen Lebensgemeinschaft erbracht wird, und die hierin ihre Geschäftsgrundlage hat, keine Schenkung, sondern eine ehebedingte Zuwendung ist (BGH, Entscheidung vom 02.10.1991 - Aktenzeichen XII ZR 132/90).
3. Beispiele für typische Zuwendungen unter Ehegatten:
Zuwendungen unter Eheleuten werden i.d.R. über den Ausgleich des Zugewinns abgerechnet, wenn der gesetzliche Güterstand der Zugewinngemeinschaft gegeben ist
a) Schenkungen zum Aufbau der beruflichen Existenz:
b) In der Praxis kommt es häufig vor, dass zum Ausbau der beruflichen Existenz eines Ehepartners, Verlagerungen von Vermögensteilen in der Form stattfinden, das Vermögensteile von dem in vollem Umfang haftenden Ehegatten auf den nicht haftenden Ehegatten zum Zwecke der Erhaltung des Familienvermögens vorgenommen werden (vgl. BGH wie vor).
c) Schenkungen betreffend die gemeinschaftliche Ehewohnung:
Eine nach der Eheschließung veranlasste Übertragung des hälftigen Miteigentumsanteils an einem Grundstück fällt ebenso hierunter, falls z.B. auf diesem Grundstück später ein Familienheim errichtet wird soll (OLG Bamberg - 2 W 5/95 - FamRZ 1996, 1221 f.).
4. Ausnahmen im Einzelfall Rückforderung des Geschenkten wegen Wegfalls der Geschäftsgrundlage:
a) Voraussetzungen für die Annahme eines Ausnahmefalles:
Über „Treu und Glauben „ (§ 242 BGB) kann es dann zu einer anderen Beurteilung im Einzelfall kommen, wenn - im Einzelfall dem zuwendenden Ehegatten die Beibehaltung der herbeigeführten Vermögensverhältnisse nach Treu und Glauben nicht zugemutet werden kann (BGH NJW 1997, 2747 - XII ZR 20/95), oder - ansonsten der Einzelfall zu unangemessenen und schlechthin unzumutbaren Ergebnissen führt, (BGH FamRZ 1991, 1169 - XII ZR 114/89) etwa zu einem Notbedarfsfall beim Zuwendenden (BGH NJW 1993, 385 ff. - XII ZR 182/90).
b) Kriterien für die Abwägung:
Folgende Kriterien sind in die entsprechende Einzelfallprüfung einzustellen:
- die Dauer der Ehe,
- das Alter der Ehegatten,
- Art und Höhe der erbrachten Leistung,
- die Höhe der dadurch bedingten und noch vorhandenen Vermögensmehrung,
- die Höhe der beiderseitigen Einkommens- und
- Vermögensverhältnisse und der Einfluss möglicher Vereinbarungen.
c) Funktion des Ausnahmefalles im Gegensatz zur güterrechtlichen Lösung des Zugewinnausgleiches:
Während der Anspruch auf Ausgleich des Zugewinns auf einen pauschalen Ausgleich für die während der Ehe bei einem Partner eingetretene Vermögensmehrung abzielt geht es bei diesen Ausnahmefällen um die isolierte Betrachtung einzelner Zuwendungen. Im Rahmen der güterrechtlichen Lösung über den Ausgleich des Zugewinns soll bei der Vermögensauseinandersetzung im Interesse der Rechtsklarheit Streit darüber ausgeschlossen werden soll, ob und in welchem Maße ein Ehegatte an dem Vermögenserwerb des anderen wirtschaftlich beteiligt war, was zu einer quasi Bilanzierung der Vermögensverhältnisse zum Zeitpunkt der Heirat und der Beendigung des gesetzlichen Güterstandes und einer entsprechenden Ausgleich - nach Saldierung - führt. Und zwar ohne nähere Betrachtung der Beweggründe. In den Ausnahmefällen der Rückforderung einzelner Vermögenszuwendungen hingegen geht es um den konkreten Ausgleich einer solchen Zuwendung. Also um die Art der Beteiligung die der andere zum Zeitpunkt der Zuwendung an der Vermögensbildung bzw. den Vermögenserwerb des anderen hatte. Mehrere Zuwendungen bilden bei diesen Ausnahmefällen dabei keine Gesamtleistung, selbst wenn ihre Zweckrichtung identisch sein sollte.
d) Zugewinnausgleichsgemeinschaft: Ausnahmefälle: sehr selten in der Rechtsprechung zu finden:
Eine unbenannte Zuwendung unter Ehegatten kann nach erfolgter Scheidung im Ausnahmefall trotz des Vorrangs der güterrechtlichen Vorschriften nach den Grundsätzen des Wegfalls der Geschäftsgrundlage ausgeglichen werden. Dies gilt zumindest dann, wenn ein güterrechtlicher Ausgleich nach den Umständen des Einzelfalls als grob unbillig erscheint und außerdem der Zweckbestimmung der erfolgten Zahlung widerspricht. Hat die Ehe keine lange Dauer gehabt, so spricht dies eher für die Annahme einer ausgleichspflichtigen unbenannten Zuwendung.
e) Gütertrennung: Ausnahmefall ggf. leichter anzunehmen:
Im Falle der Gütertrennung gibt es grundsätzlich keinen Ausgleich über eine geschlossene Vereinbarung hinaus. Dennoch ist die höchstrichterliche Rechtsprechung eher bereit, bei diesem Güterstand einen Anspruch aus unbenannter Zuwendung zu gewähren. Die Kriterien sind dieselben wie bei der Zugewinngemeinschaft, eine unangemessene Benachteiligung kann aber wegen der nicht immer vorhersehbaren Entwicklung schneller vorliegen.
f) Darlegungs- und Beweislast:
Die Rückforderung solcher Zuwendungen nach den Regeln über den Wegfall der Geschäftsgrundlage setzt voraus, dass jede einzelne Zuwendung konkret dargelegt und gegebenenfalls nachgewiesen wird. MJH Rechtsanwälte, Herr Rechtsanwalt Martin J. Haas meint: Die Abgrenzung kann im Einzelfall sehr schwer sein. Hier muss ausführlich geprüft, aber auch der Sachverhalt sehr genau recherchiert werden. Da es häufig um sehr bedeutende Zuwendungen geht wünschen wir allen die von dieser Thematik betroffen sind viel Erfolg.
<div class="family-tree">
*[[Begehren]]
**[[Kaufvertrag]] Abgrenzung zu anderen Verträgen
***[[Kaufpreis bezahlt]]
****[[Sache übergeben]]
*****[[vereinbahrte Beschaffenheit]]
*****oder [[Mangel]]
******[[nicht unerhbeblich]]
***[[Nachbesserungsverlangen]]
</div>
This is the text of the entry. When viewing from [[Sample topic]], click the blue diamond to the left to edit the entry. When viewing [[Sample entry]] itself, click the pen icon at the top to edit. - @@.source <$transclude field="authortitle"/>, <$view field="page"/>.@@
<<xlist filter:"[topic1{!!title}] +[sort[title]]" each:topic2>>
<<xlist filter:"[topic1{!!title}] +[sort[title]]" each:topic2>>
Created a new plugin to handle saving the wiki to a PHP based server.
This can replace legacy store.php usage. The plugin is a bit more streamlined, updated code base, and adds some security enhancements to the process.
It also has a fairly thorough debug test that can be run during setup to help squash environment/server problems
Project page here:
https://github.com/sendwheel/tw-receiver
Comments and contributions welcome.
Security wise offers:
- Challenge Digest Authentication (enhanced security)
-- This simple mechanism avoids passing the password in plain text. Instead the server is queried for a challenge token and that token is then combined with the password to form a new string that is both unique and temporary.
- Data Integrity Signing (enhanced security)
-- This practice creates a unique signature of the wiki text with the secret key. Checking the validity of this signature ensures the integrity of the wiki data and helps prevent tampering in transit.
<$checkbox tag=<<actual>> > <$link><<currentTiddler>> </$link>
</$checkbox>
Haben Mängel eine Reise erheblich beeinträchtigt oder fiel diese sogar vollständig aus, steht den geschädigten Urlaubern gemäß § 651f Abs. 2 BGB „eine angemessene Entschädigung in Geld“ zu.
Für entgangene Urlaubsfreude kann die Höhe des Schadensersatzes grundsätzlich auf verschiedenen Weisen ermittelt werden.
Im deutschen Reiserecht finden unter anderem folgende Berechnungsmethoden Anwendung:
! Arbeitseinkommenmethode
Bei der Schadensersatzhöhe für entgangene Urlaubsfreude kann das Einkommen als Orientierung dienen. Dabei werden die anteiligen Einbußen beim Gehalt zugrunde gelegt, welche für das Nehmen von unbezahlten Urlaubstagen notwendig wären, sodass der Geschädigte die Reise ggf. nachholen könnte.
! Reisepreismethode
Es besteht ebenfalls die Möglichkeit, bei der Berechnung ausschließlich den gezahlten Reisepreis zu berücksichtigen. Diese Methode findet insbesondere dann Anwendung, wenn der Schadensersatzberechtigte über kein Einkommen verfügt. Dabei kann es sich zum Beispiel um Kinder oder Hausfrauen handeln. Auch in dem Falle, dass der Veranstalter noch kurz vor der Reise auf erhebliche Mängel hinweist, der Urlauber von dieser daraufhin zurücktritt, kann ein Anspruch auf Erstattung des vollen Reisepreises bestehen.
! Mischsatzeinkommen
Bei dieser Berechnungsmethode werden sowohl das Nettoeinkommen, als auch der Reisepreis berücksichtigt. Der Grundbetrag von 25 Euro wird dabei entsprechend erhöht.
! Pauschalmethode
Die wohl einfachste Methode für die Bemessung des Schadensersatzes für entgangene Urlaubsfreude bedient sich einer pauschalen Summe. Gemäß dem Landgericht Frankfurt am Main liegt dieser bei 65 Euro.
Die neuen Kosten nach dem FamGKG: Scheidung und Versorgungsausgleich
VON DIPL.RPFL.IN (FH) KARIN SCHEUNGRAB, LEIPZIG
Zum 1.9.09 ändern sich durch das FamFG nicht nur die Verfahrensabläufe in Familien-, Familienstreit- und Kindschaftssachen. Durch das FamGKG werden auch die Streitwerte dieser Verfahren teilweise grundlegend geändert. In diesem und folgenden Beiträgen werden die einzelnen Werte mit Berechnungsbeispielen dargestellt und am Ende der Beitragsreihe als Synopse zusammengefasst.
Wert der Scheidung
Bislang war die Berechnung des Werts der Scheidung in § 48 Abs. 2, 3 S. 1 und S. 2 GKG geregelt. Dies wird in § 43 FamGKG unverändert übernommen; d.h. für die Berechnung werden Umfang und Bedeutung der Sache und die Vermögens- und Einkommensverhältnisse der Ehegatten zugrunde gelegt. Der Wert darf - auch in PKH- bzw. Verfahrenskostenhilfe-Verfahren - nicht unter 2.000 EUR angesetzt werden (BVerfG RVG prof. 09, 73, Abruf-Nr. 091321).
Praxishinweis: Oftmals bleiben die Argumente „Vermögen“, „Bedeutung“, „Umfang“ unberücksichtigt. Vermögen ist nach Abzug der Verbindlichkeiten und Freibeträge für jeden Ehegatten mit 5 bis 10 Prozent zum Wert der Ehesache zu addieren. Bei Scheidung nach langer Ehedauer ist, genauso wie bei herausragender Stellung der Parteien, der Wert wegen der „Bedeutung“ der Sache zu erhöhen; z.B. bei erhöhtem Arbeitsaufwand im Fall einer Härtefallscheidung oder in Fällen mit Auslandsberührung wegen des „Umfangs“ der Sache.
Wert des Versorgungsausgleichs
Bislang war die Berechnung des Gegenstandswerts des Versorgungsausgleichs (VA) in § 49 GKG geregelt. Künftig sind nicht mehr der Jahreswert der zu übertragenden Anwartschaften maßgeblich, sondern Festwerte, die sich nach der Art der Anrechte berechnen.
Noch vor dem Inkrafttreten wurde § 50 FamFG durch das Gesetz zur Strukturreform des VA, das ebenfalls am 1.9.09 in Kraft tritt, bereits wieder geändert. Demnach soll künftig jedes auszugleichende Anrecht den Streitwert beeinflussen. Die bisherigen Festwerte von 1.000 EUR bzw. 2.000 EUR entfallen.
Künftig wird der Wert für die Folgesache VA für jedes zu übertragende Anrecht 10 Prozent des in drei Monaten erzielten Nettoeinkommens der Ehegatten betragen. Bei Ausgleichsansprüchen nach der Scheidung erhöht sich der Prozentsatz auf 20 Prozent. In beiden Fällen ist ein Mindestwert von 1.000 EUR vorgesehen. Die im Gesetzesentwurf vorgesehene Obergrenze von 5.000 EUR ist nicht realisiert.
Für Verfahren über einen Auskunftsanspruch oder über die Abtretung von Versorgungsansprüchen bleibt es beim Festwert von 500 EUR; § 50 Abs. 2 FamGKG.
Hält das Gericht diese Gegenstandswerte nach den besonderen Umständen des Einzelfalls für unbillig, kann es gemäß § 50 Abs. 3 FamGKG einen höheren oder niedrigeren Wert festsetzen.
Beispiel 1
Sowohl der Ehemann als auch die Ehefrau haben Anwartschaften aus der gesetzlichen Rentenversicherung, der Ehemann noch aus einer Betriebsrente, die Ehefrau „riestert“. Das durchschnittliche statistische Haushaltsnettoeinkommen bei kinderlosen Paaren liegt bei 3.150 EUR. Wie sind die Streitwerte für Scheidung und Versorgungsausgleich (VA) bei einem Haushaltsnettoeinkommen von 3.150 EUR?
Wert der Scheidung (§ 43 FamGKG):
3.150 EUR x 3
9.450 EUR
Wert des Versorgungsausgleichs (§ 50 FamGKG)
Ehemann: Zwei Anwartschaftsrechte = 2 x 10 % aus 9.450 EUR
1.890 EUR
Ehefrau: Zwei Anwartschaftsrechte = 2 x 10 % aus 9.450 EUR
1.890 EUR
3.780 EUR
Fazit: Gegenüber der bisherigen Rechtslage, bei der der Wert des VA mit 2.000 EUR angesetzt worden wäre, eine eindeutige Erhöhung.
Beispiel 2
Den Parteien wird Verfahrenskostenhilfe bewilligt, beide verdienen zusammen 1.800 EUR. Beide haben Anwartschaften aus der gesetzlichen Rentenversicherung. Wie sind die Streitwerte für Scheidung und VA?
Wert der Scheidung:
1.800 EUR x 3
5.400 EUR
Wert des Versorgungsausgleichs:
Zwei Anwartschaftsrechte = 2 x 10 % aus 5.400 EUR
1.080 EUR
Fazit: Bisher wäre der Wert mit 1000 EUR angesetzt worden, künftig also eine geringe Erhöhung.
Soweit der Wert der Ehesache auf bis zu 5.000 EUR festgesetzt wird und beide Ehegatten Anwartschaften aus der gesetzlichen Rente haben - im Ergebnis also wenigstens zwei Anwartschaften auszugleichen sind - greift der gesetzliche Mindestwert von 1.000 EUR und es verbleibt bei den bisherigen Werten. Ab einem Gegenstandswert von mehr als 5.000 EUR ist nach neuem Recht ein höherer Wert als bislang festzusetzen.
Praxishinweis: Der Wert der Scheidung muss genau berechnet werden, denn er wirkt sich auch bei der Folgesache Versorgungsausgleich aus.
Hier wäre gut eine direkt angezeigte mögliche Abgrenzungsproblematik zur [[abhängigen Beschäftigung]]
Umfassender hier :
http://www.juraindividuell.de/pruefungsschemata/
http://www.jura-schemata.de/
§ 623 BGB Schriftform zwingend
* Schuldrecht BT: Vertragsrecht
* Schuldrecht BT: Deliktsrecht
* Schuldrecht BT: Bereicherungsrecht
Bei der Einigung ist ferner der Sonderfall des Schweigens zu beachten. Fraglich ist somit, ob ein Vertrag auch durch Schweigen zustande kommen, insbesondere eine Annahmeerklärung durch Schweigen erfolgen kann. Beispiel: A bietet dem B den Kauf einer Sache schriftlich an und erwähnt in diesem Schreiben, dass, wenn A innerhalb von zwei Tagen nichts von dem B höre, davon ausgehe, dass B den Vertrag annimmt. Dieses Problem wird in einem gesonderten Exkurs erläutert. Es ist jedoch festzuhalten, dass Schweigen grundsätzlich nichts bedeutet.
Materielle Regeln
Formelle Regeln
Rechtsanwendung
Verfahrensordnungen
Exekutionsordnungen
Rechtsschaffung und –fortbildung
Begriffsstruktur des Rechtsgebiets
Konventionelle Methode:
Lehrbuch, Handbuch, Kommentar, System
//menschliche Denkleistung, unzureichend in Papier abgebildet//
IT Methode: elektronischer Kommentar; Automatisierung der Erfassung, pervasive computing zwischen verschiedenen wissensbasierten Systemen, aber ungelöste Probleme: Formalisierung, Normenquantität, Effizienz
hybrides wissensbasiertes System (Schweighofer 1996/1999)
Ausgangspunkt einer Formalisierung ist nicht mehr das Informationssystem, sondern ein (mehr oder weniger) effizientes hybrides wissensbasiertes System
Sämtliche Analysen werden (semi)automatisch erstellt
Normen als logische Sätze (materielle Regeln) oder Prozessdiagramme (zB SoftLaw)
Klassifikation (zB GHSOM, LabelSOM)
Verweisungen (zB AustLII, SiteSeer)
Begriffsanalyse (zB KONTERM)
Zusammenfassungen (zB KONTERM, FLEXICON)
Textanalyse (zB die Forschungen in Leuven, Wien, Pittsburgh, Amherst etc.)
\define tags() <$list filter=<<taglist>> variable=tag ><$checkbox tag=<<tag>> > <<tag>></$checkbox></$list>
\define fields()
<$list filter="[all[]!is[system]fields[]sort[]] -title -text -creator -modifier -created -modified -draft.of -draft.title -list-before -list-after -tags">
<$checkbox tiddler="$:/temp/scratch/fieldlist" tag={{!!title}}> {{!!title}}</$checkbox>
</$list>
\end
\define icon()
<$button class="tc-btn-invisible"><$transclude tiddler={{!!icon}} /></$button>
\end
<style>
table.input {
border: solid thin;
width: 100%;
}
table.input input[type=text], table.input textarea {
width: 100%;
}
</style>
I use this to try to [re]organize many of the tiddlers of this wiki.
|input|k
| !filter|<$edit-text tiddler="$:/temp/scratch/filter" default="" /> |Which tiddlers to manipulate|
| !tags|<$edit-text tiddler="$:/temp/scratch/tags" tag=input default="" type=text /> |Tags listed in the checklist|
| !fields|<<fields>> |Fields to display|
<$vars
taglist={{$:/temp/scratch/tags}}
filter={{$:/temp/scratch/filter}}
>
count: <$count filter= <<filter>> />
<table class=input>
<$list filter=<<filter>> >
<tr><th colspan=2><<icon>> <$link><$view field=title /></$link></th></tr>
<tr><td>tags</td><td><<tags>></td></tr>
<$list filter="[[$:/temp/scratch/fieldlist]tags[]]" variable=field><tr><td><<field>></td><td><$edit-text field=<<field>> default="" /></td></tr></$list>
</$list>
</table>
Below, the variable ''find'' defines a subfilter to be searched using the filter operator ''filter'' to search for the word `evaluate` in both the ''title'' or ''summary'' fields, replaced in the ''find'' subfilter in turn using the placeholder `%inputTitle%`:
<$macrocall $name="`" text="""<$vars term="evaluate"
find="[all[tiddlers]!is[system]search:%inputTitle%<term>]">
<$count filter="title summary +[filter<find>]"/>:
{{{ title summary +[filter<find>] }}}
</$vars>"""/>
You can also feed a number of fields using a variable and the [[split]] filter like so:
<$macrocall $name="`" text="""<$vars term="evaluate"
fields="title summary"
find="[all[tiddlers]!is[system]search:%inputTitle%<term>]">
<$count filter="[<fields>split[ ]filter<find>]"/>:
{{{ [<fields>split[ ]filter<find>] }}}
</$vars>"""/>
Here's the same using a named variable:
<$macrocall $name="`" text="""<$vars term="evaluate"
fields="title summary"
find="[all[tiddlers]!is[system]search:%field%<term>]">
<$count filter="[<fields>split[ ]filter:var:field<find>]"/>:
{{{ [<fields>split[ ]filter:var:field<find>] }}}
</$vars>"""/>
Here's the equivalent output using OR syntax:
<$macrocall $name="`" text="""<$vars term="evaluate">
<$count filter="
[!is[system]search:title<term>]
[!is[system]search:summary<term>]"/>:
{{{
[!is[system]search:title<term>]
[!is[system]search:summary<term>]
}}}
</$vars>"""/>
This example returns the actual fields where the search term could be found in the fields ''title'', ''tags'', ''summary'' and ''doesnt-exist'':
<$macrocall $name="`" text="""<$vars term="evaluate"
fields="title tags summary doesnt-exist"
find="[all[tiddlers]!is[system]search:%inputTitle%<term>]">
<$count filter="[<fields>split[ ]filter:$<find>]"/>:
{{{ [<fields>split[ ]filter:$<find>] }}}
</$vars>"""/>
<$select tiddler="$:/temp/searchfilter" default="Choose">
<option value="Choose">-Choose one-</option>
<option value="[has[gesetz]search:gesetz{$:/temp/search}]">Gesetz</option>
<option value="[has[rechtsgebiet]search:rechtsgebiet{$:/temp/search}]">Rechtsgebiete</option>
<option value="[has[parent]search:parent{$:/temp/search}]">parent</option>
</$select>
<$macrocall $name="list-links" filter={{$:/temp/searchfilter}} />
<$select tiddler="$:/temp/searchfilter" default="Choose">
<option value="Choose">-Choose one-</option>
<option value="[has[rechtsgebiet]search:intelligence{$:/temp/search}]">Rechtsgebiet</option>
<option value="[has[parent]search:climate_terrain{$:/temp/search}]">Parent</option>
<option value="[has[is_subclass_of]search:hd{$:/temp/search}]">SubClassHD</option>
</$select>
<$macrocall $name="list-links" filter={{$:/temp/searchfilter}} />
Content of second tiddler
<a id="#s000"></a><small> <a href="##s006">Please don't click here yet</a></small>
!! Showing internal links within a tiddler.
# <a href="##s001" class="tc-tiddlylink-internal tc-tiddlylink-resolves">Lorem</a>
# <a href="##s002">Funny Quotes</a>
# <a href="##s003">Humour</a>
# <a href="##s004">The End</a>
!! Now how can we access them from outside a tiddler?
!!!1. <a id="#s001">''Lorem''</a><small> <a href="##s002">Next</a> <a href="##s000">Top</a></small>
<<.lorem>>
<<.lorem>>
!!!2. <a id="#s002">''Funny Quotes''</a><small> <a href="##s003">Next</a> <a href="##s001">Previous</a> <a href="##s000">Top</a></small>
There
really
isn't
a
funny
quote
here!
Too
Bad!
!!!3. <a id="#s003">''Humour''</a> <small> <a href="##s004">Next</a> <a href="##s002">Previous</a> <a href="##s000">Top</a></small>
There
isn't
any
Humour
Either.
This
is
just
a
demo.
!!!4. <a id="#s004">''The End''</a><small> <a href="##s005">Next</a> <a href="##s003">Previous</a> <a href="##s000">Top</a></small>
Yes.
This
is
really
THE
END
<a id="#s005">''Well, almost.''</a>
I'm glad you got this far. Here is the issue. When a link is created using:<br> `<a class="tc-tiddlylink tc-tiddlylink-missing" href="##somewhere">Somewhere</a>`<br>
the HTML produced is:
```
<a class="tc-tiddlylink tc-tiddlylink-missing" href="##somewhere">Somewhere</a>
```
Giving: <a class="tc-tiddlylink tc-tiddlylink-missing" href="##somewhere">Somewhere</a>
Not exactly rocket science.
However when a link is produced using:<br>
`<$link to="##somewhere">Somewhere</$link>`<br>
The HTML produced is:
```
<a class="tc-tiddlylink tc-tiddlylink-missing" href="#%23%23somewhere">Somewhere</a>
```
Giving what may LOOK similar: <$link to="##somewhere">Somewhere</$link>
''But it isn't !!!'' - It has an extra `#`
When you click the link made using `<a href ...` it correctly scrolls the tiddler to the proper `<a id=#somewhere></a>` defined in the tiddler.
But when you click the link made using `<$link ... ` it tries to open the missing tiddler: `##somewhere` because it changed the leading `##` into uri coded `%23%23` and it added another `#` infront of the link.
Now how exciting would it be to be able to tweak the `<$link>` widget to accept for example:
```
<$link to="SomeTiddler" id="#somewhere">SomeTiddler's somewhere section</$link>
```
And its actions would be to:
# Open tiddler [[SomeTiddler]]
# Do the same action within the tiddler as clicking: `<a href="##somewhere">Somewhere</a>` which would be to scroll to the HTML tag within the tiddler defined as: `<a id="#somewhere">`
And YES - that `##` used in the `href` attribute just above is the correct syntax, as well as the single `#` used in the `id` attribute.
!!<a id="#s006">''The Very End''</a>
<a href="##s005">Previous</a><br><a href="##s000"> Back to the Top!</a>
\define normal() [all[tiddlers]!is[current]!prefix[$:/]!prefix[Draft of ']!nsort{!!list-field}limit{$:/range/See Recent Tiddlers/range}]
\define system() [is[system]prefix[$:/]!is[current]!prefix[Draft of ']$(exclude-temp)$$(exclude-state)$$(exclude-config)$$(exclude-range)$!nsort{!!list-field}limit{$:/range/See Recent Tiddlers/range}]
\define shadow() [all[shadows]!is[current]!prefix[Draft of ']$(exclude-temp)$$(exclude-state)$$(exclude-config)$$(exclude-range)$!nsort{!!list-field}limit{$:/range/See Recent Tiddlers/range}]
\define all() [all[tiddlers+shadows]!is[current]!prefix[Draft of ']$(exclude-temp)$$(exclude-state)$$(exclude-config)$$(exclude-range)$!nsort{!!list-field}limit{$:/range/See Recent Tiddlers/range}]
\define delete-settings-tiddlers()
<$button class="tc-btn-invisible tc-tiddlylink">
<$action-deletetiddler $tiddler="$:/range/See Recent Tiddlers/range"/>
<$action-deletetiddler $tiddler="$:/range/See Recent Tiddlers/max"/>
<small>Delete Settings Tiddlers</small>
</$button>
\end
\define tiddler-list(filter:"" type:"normal")
<$list filter=<<$filter$>>>
<small> (<$view field="created" format="date" template="YYYY-0MM-0DD - 0hh:0mm"/>)</small> <$link tooltip={{!!description}}><$text text=<<currentTiddler>>/></$link><br>
</$list>
\end
|''Field''|>| <$radio field="list-field" value="created"> Created</$radio> | <$radio field="list-field" value="modified"> Modified</$radio> |<|
|| <$text text="$:/temp/"/> | <$text text="$:/state/"/> | <$text text="$:/config/"/> | <$text text="$:/range/"/> |
|''Exclude''<br>''Include''| <$radio field="exclude-temp" value="!prefix[$:/temp/]"></$radio> | <$radio field="exclude-state" value="!prefix[$:/state/]"></$radio> | <$radio field="exclude-config" value="!prefix[$:/config/]"></$radio> | <$radio field="exclude-range" value="!prefix[$:/range/]"></$radio> |
|~| <$radio field="exclude-temp" value=""></$radio> | <$radio field="exclude-state" value=""> </$radio> | <$radio field="exclude-config" value=""></$radio> | <$radio field="exclude-range" value=""></$radio> |
|''Tiddlers''|<$radio field="list-type" value="normal"> Normal tiddlers</$radio> |<$radio field="list-type" value="system"> System tiddlers</$radio> |
|~|<$radio field="list-type" value="all"> All tiddlers</$radio> |<$radio field="list-type" value="shadow"> Shadow tiddlers</$radio> |
<$set name="max" value={{$:/range/See Recent Tiddlers/max}} emptyValue={{!!max-default}}>
<$vars exclude-temp={{!!exclude-temp}} exclude-state={{!!exclude-state}} exclude-config={{!!exclude-config}} exclude-range={{!!exclude-range}}>
Below are the last : {{$:/range/See Recent Tiddlers/range}} : ''{{!!list-type}}'' tiddlers that were ''{{!!list-field}}'' in this TiddlyWiki. <br>
Use the slider below to show less or more tiddlers (max. : <$edit-text tiddler="$:/range/See Recent Tiddlers/max" default={{!!max-default}} placeholder={{!!max-placeholder}} tag="input" size="5"/> ) <<delete-settings-tiddlers>>
<$range tiddler="$:/range/See Recent Tiddlers/range" min="1" max=<<max>> default={{!!range-default}} increment={{!!range-increment}}/>
<$reveal default={{$:/range/See Recent Tiddlers/range}} type="lt" text="1">
<big>''Move the Slider to begin''</big>
</$reveal>
<$macrocall $name="tiddler-list" filter={{!!list-type}} type={{!!list-type}}/>
</$vars>
</$set>
<div class="family-tree" >
*[[Gesetz]]
**contains
***[[AGL]]
****setzt voraus
*****[[Voraussetzungen]]
******nur dann
*******[[Rechtsfolgen]]
***[[Voraussetzungen]]
***[[Rechtsfolgen]]
</div>
I did a fresh install from scratch with the following commands
``
git clone --depth=1 --branch v5.1.18 https://github.com/Jermolene/TiddlyWiki5.git
git clone --depth=1 https://github.com/OokTech/TW5-Bob.git TiddlyWiki5/plugins/OokTech/Bob
mkdir TiddlyWiki5/Wikis
cp -r TiddlyWiki5/plugins/OokTech/Bob/MultiUserWiki TiddlyWiki5/Wikis/BobWiki/
cd TiddlyWiki5 node ./tiddlywiki.js Wikis/BobWiki --wsserver``
<$button> set demo
<$action-setfield $tiddler="$:/state/tab/sidebar-2092865413" text="$:/core/ui/SideBar/More"/>
<$action-setfield $tiddler="$:/state/tab--1923984049" text="$:/core/ui/MoreSideBar/Plugins/Theme"/>
<$action-setfield $tiddler="$:/state/tab-1749438307" text="$:/core/ui/ControlPanel/Appearance"/>
<$action-setfield $tiddler="$:/state/tab--1963855381" text="$:/themes/jd/Material/Tweaks"/>
</$button>
<$checkbox tiddler='$:/settings' field=paragraph_info checked=True unchecked=false>Toggle Paragraph Info
</$checkbox>
<$list filter="[all[current]get[parent]]" variable=parent>
<$list filter="[<parent>get[parent]]" variable=grand-parent>
The current Tiddler is <<currentTiddler>>, its parent is <<parent>>, its grand-parent is <<grand-parent>> <br>
</$list>
</$list>
*Note that links work
*See what happens when hovering
*Note in code that empty row is required between div tag and the list
<div class="family-tree">
*[[Parent]]
**[[Child 1]]
***[[GrandChild 1.1]]
**[[Child 2]]
***[[GrandChild 2.1]]
***[[GrandChild 2.2]]
****[[Great GrandChild 2.2.1]]
****[[Great GrandChild 2.2.2]]
***[[GrandChild 2.3]]
</div>
<<list-links "[tag[Example]]">>
<div class="family-tree">
<ul>
<li>
[[Parent]]
<ul>
<li>
[[Child 1]]
<ul>
<li>
[[Grand Child 1.1]]
</li>
</ul>
</li>
<li>
[[Child 2]]
<ul>
<li>[[Grand Child 2.1]]</li>
<li>
[[Grand Child 2.2]]
<ul>
<li>
[[Great Grand Child 2.2.1]]
</li>
<li>
[[Great Grand Child 2.2.2]]
</li>
<li>
[[Great Grand Child 2.2.3]]
</li>
</ul>
</li>
<li>[[Grand Child 3]]</li>
</ul>
</li>
</ul>
</li>
</ul>
</div>
Si lo quieres a nivel globlal incluye este pedazo de código en [[$:/core/ui/PageMacros]]
```
\define slider(label,text)
<$button popup="$:/state/$label$" class="btn-invisible tw-slider"><$list filter="[[$label$]]"><$view field="title"/></$list></$button>
<$reveal type="nomatch" text="" default="" state="$:/state/$label$" animate="yes">
$text$
</$reveal>
\end
```
before <$appear type="popup">
! I Am Sticky
Clicking anywhere outside will close me.</$appear> after
Handelsrecht
→ Hauptartikel: Handelsrecht (Deutschland)
Für Österreich:
→ Hauptartikel: Unternehmensrecht
Das Handelsrecht wird als „Sonderprivatrecht der Kaufleute“ bezeichnet.[2] Es beinhaltet Rechtsnormen, die für Kaufleute gelten, mithin Bestimmungen zu Handelsgeschäften, zur Firmierung des Kaufmannes, zu kaufmännischen Hilfspersonen (Handelsmakler, Handelsvertreter, Kommissionäre, Spediteure, Lagerhalter) sowie weiter im Bereich des Gesellschaftsrechts und Regeln über Personen- und Kapitalgesellschaften.
Für all diese Rechtsgebiete gilt, dass die Normen des allgemeinen Privatrechts subsidiär gelten, sodass z. B. für Handelsgeschäfte grundsätzlich allgemeines Privatrecht gilt, jedoch modifiziert und erweitert durch die Normen des Handelsrechts.
Dieses subsidiäre Verhältnis findet in Deutschland seine Kodifizierung in Art. 2 Abs. 1 EGHGB. In der schweizerischen Rechtstradition wurde ein eigenständiges kaufmännisches Handelsrecht seit jeher abgelehnt, dies mit der Begründung einer demokratischen Gleichheit aller Personen, die eine besondere Behandlung der Kaufleute nicht rechtfertige. Trotzdem finden sich im OR vereinzelt Sonderregeln für den kaufmännischen Verkehr (z. B. Art. 190 OR), die sachgerechte Differenzierungen ermöglichen sollen.
Arbeitsrecht
Das Arbeitsrecht regelt die Rechtsbeziehungen zwischen einzelnen Arbeitnehmern und Arbeitgebern (Individualarbeitsrecht) sowie zwischen den Koalitionen der Arbeitnehmer und Arbeitgeber und zwischen Vertretungsorganen der Arbeitnehmer und dem Arbeitgeber (kollektives Arbeitsrecht).
Die Normen des Arbeitsrechtes enthalten vielfach (einseitig) zwingende Vorschriften zugunsten des Arbeitnehmers. Auch hier gelten die Normen des allgemeinen Privatrechts subsidiär.
\define sort-selection(sort: sort sortby: '"title modified created"' )
<$select field=$sort$>
<option></option>
<$list filter=$sortby$>
<option>{{!!title}}</option>
</$list>
</$select>
\end
* Create a `sortby` field containing a filter with fields to sort by, e.g. `title modified create order`
** or perhaps: `[tag[TiddlyWiki Tips]!is[system]fields[]sort[]]`
* Create a `$select` widget with `field=sort`
** Optionally include an empty default option: `<option></option>`
** Create a `$list` widget with `filter={{!!sortby}}`
*** Create an option tag inside the `$list`: `<option>{{!!title}}</option>`
* Use the `sort` field in a `$list` filter to sort like this: `+[sort{!!sort}]`
** or `+[nsort{!!sort}]` for numerical sort
** or `+[sortcs{!!sort}]` for case sensitive sort
* Use the `$list` to build a table or list
So, there you have it:
```
<$select field=sort>
<option></option>
<$list filter={{!!sortby}}>
<option>{{!!title}}</option>
</$list>
</$select>
```
Actually, that's so boilerplate it could be a macro:
```
<<sort-selection sort: [sort field] sortby: [sort by filter] >>
```
<pre><code><$text text=<<sort-selection>> /></code></pre>
Obgleich durch eine Tarifklausel die Angabe der wesentlichen Arbeitsbedingungen vergleichbarer Arbeitnehmer im Entleiherbetrieb entbehrlich wäre, ist es ratsam, eine entsprechende Erklärung in den Überlassungsvertrag aufzunehmen. Sollte sich – wie im Falle der CGZP Tarife – nachträglich die Unwirksamkeit der Tarifverträge herausstellen, wird hierdurch eine schwierige Klärung und zeitaufwendige Recherche der in der Vergangenheit geltenden Arbeitsbedingungen vermieden.
Der Entleiher kann so einer möglichen Haftung wegen eines Verstoßes gegen seine Informationspflicht von vornherein entgehen.
//Gleichwohl macht der Entleiher in der Anlage y die nach § 12 Absatz 1 Satz 3 AÜG erforderlichen Angaben, welche wesentlichen Arbeitsbedingungen einschließlich des Arbeitsentgelts in seinem Betrieb für einen vergleichbaren Arbeitnehmer gelten.//
|''X-Tags'' | https://tid.li/tw5/plugins.html#%24%3A%2Fplugins%2Ftelmiger%2Fx-tag:%24%3A%2Fplugins%2Ftelmiger%2Fx-tag%20%24%3A%2Fplugins%2Ftelmiger%2Fx-tag%2Fui%2FTagTemplate | |
|''Dbadge-Status'' | https://kookma.github.io/status-badge/ | |
|''Parts'' | http:/// | |
|''MagicTabs'' | http:/// | |
[[About the TiddlerSidebar]]
Ausgleich vorehelicher und ehelicher "unbenannter Zuwendungen" nach den Grundsätzen des Wegfalls der Geschäftsgrundlage (§ 313 BGB); Anforderungen an eine Innengesellschaft zwischen Ehegatten
BGH, Urteil vom 19. September 2012 - XII ZR 136/10 - OLG Hamm
Fundstelle:
NJW 2012, 3374
Amtl. Leitsatz:
Zum Ausgleich unbenannter Zuwendungen, die im Hinblick auf die künftige Ehe und während der bestehenden Ehe mit Gütertrennung dem anderen Ehegatten geleistet wurden.
Zentrale Probleme:
Die Entscheidung gibt den derzeitigen Stand der Rechtsprechung zu den "unbenannten Zuwendungen" bei der Beendigung von ehelichen und nichtehelichen Lebensgemeinschaften sehr gut wieder. Vgl. im Übrigen die Anm. zu BGH NJW 2008, 3282 sowie BGHZ v. 25.11.2009 - XII ZR 92/06 und BGH v. 6.7.2011 - XII ZR 190/08.
©sl 2012
Tatbestand:
1 Die Parteien schlossen am 27. Juli 1999 die Ehe. Zuvor hatten sie mit notariellem Vertrag vom 22. Juli 1999 Gütertrennung vereinbart. Am 16. Oktober 2004 trennten sie sich; ihre Ehe wurde am 26. Februar 2007 geschieden.
2 Mit der Klage verlangt der Ehemann - soweit für das Revisionsverfahren von Bedeutung - den Ausgleich geleisteter Zuwendungen an die beklagte Ehefrau. Diese hatte am 9. Juli 1998 - vor Eingehung der Ehe - ein bebautes Grundstück zu einem Kaufpreis von 750.000 DM erworben. Den Kaufpreis brachte sie in Höhe von 290.000 DM oder 300.000 DM aus eigenen Mitteln auf; im Übrigen nahmen beide Parteien am 27. September 1998 ein gemeinsames Darlehen in Höhe von 495.000 DM auf. Die monatlich fälligen Darlehensraten wurden vom Konto des Klägers abgebucht. Die Beklagte ließ das Grundstück teilen. Den bebauten Teil veräußerte sie am 28. Februar 1999. Mit dem erzielten Kaufpreis von 490.000 DM löste sie das zuvor aufgenommene Darlehen ab; ein Teilbetrag von 64.436,90 DM wurde außerdem an die Beklagte ausgezahlt.
3 Auf dem der Beklagten verbliebenen, unbebauten Teil des Grundstücks errichteten die Parteien ein Familienheim. Hierzu unterzeichneten sie am 29. Juni 1999 einen weiteren Darlehensvertrag über 600.000 DM, dessen Annuitäten in der Folgezeit wiederum der Kläger aus seinen laufenden Einkünften bediente. Diese geleisteten Raten und weitere behauptete Aufwendungen für die Errichtung des Familienheims verlangt der Ehemann als ehebedingte Zuwendung von der Beklagten ersetzt. Die nach der Trennung vom Ehemann erbrachten Raten wurden bei der Bemessung des Trennungsunterhalts der Beklagten einkommensmindernd berücksichtigt.
4 Das Landgericht hat der auf Zahlung von 145.000 € gerichteten Teilklage stattgegeben. Auf die Berufung der Beklagten hat das Oberlandesgericht die Klage abgewiesen. Hiergegen richtet sich die zugelassene Revision des Klägers, mit der er die Wiederherstellung des landgerichtlichen Urteils verfolgt.
Entscheidungsgründe:
5 Die zulässige Revision führt zur Aufhebung des angefochtenen Urteils und zur Zurückverweisung der Sache an das Berufungsgericht.
I.
6 1. Für das Verfahren ist gemäß Art. 111 Abs. 1 FGG-RG noch das bis Ende August 2009 geltende Prozessrecht anzuwenden, weil der Rechtsstreit vor diesem Zeitpunkt eingeleitet wurde (vgl. Senatsbeschluss vom 3. November 2010 - XII ZB 197/10 - FamRZ 2011, 100).
7 2. Die Revision ist uneingeschränkt zulässig. Das Berufungsgericht hat die Revision zwar bezogen auf die Rechtsfrage zugelassen, ob für die Bestimmung des Ausgleichsanspruchs wegen Wegfalls der Geschäftsgrundlage auf den Zeitpunkt der Trennung oder der Ehescheidung abzustellen ist. Eine dahingehende Beschränkung der Zulassung wäre aber unzulässig.
8 Die Zulässigkeit der Revision kann nach ständiger Rechtsprechung des Bundesgerichtshofs nur auf einen tatsächlich und rechtlich selbständigen Teil des Streitstoffs beschränkt werden, der Gegenstand eines Teilurteils sein könnte oder auf den der Revisionskläger selbst seine Revision beschränken könnte. Unzulässig ist es, die Zulassung auf einzelne von mehreren Anspruchsgrundlagen oder auf bestimmte Rechtsfragen zu beschränken (BGHZ 101, 276, 278; 111, 158, 166; BGH Urteil vom 20. April 2004 - XI ZR 164/03 - NJW 2004, 2745, 2746).
9 Danach scheidet hier die Beschränkung der Zulassung auf die vom Berufungsgericht angeführte Rechtsfrage aus. Abgesehen davon bildet der Rückgewähranspruch aus Wegfall der Geschäftsgrundlage als einheitlicher Anspruch einen jedenfalls im Grundsatz unteilbaren Streitgegenstand, der dem Revisionsgericht deshalb nur insgesamt anfallen kann.
10 Bei einer unzulässigen Beschränkung der Revisionszulassung muss das angefochtene Urteil in vollem Umfang überprüft werden (BGH Urteil vom 20. April 2004 - XI ZR 164/03 - NJW 2004, 2745, 2746).
II.
11 Das Berufungsgericht hat zur Begründung seiner Entscheidung im Wesentlichen ausgeführt: Zwischen den Ehegatten habe keine Innengesellschaft bestanden, weil das Zusammenwirken der Parteien nicht über die Errichtung eines Familienheims zum Zwecke der Verwirklichung der ehelichen Lebensgemeinschaft und gegebenenfalls der Alterssicherung durch mietfreies Wohnen hinausgegangen sei.
12 Auch auf §§ 346, 313 Abs. 1 BGB könne der Ehemann einen Ausgleichsanspruch nicht stützen, da sich nicht feststellen lasse, dass die Beibehaltung einer durch unbenannte Zuwendungen des Ehemanns geschaffene Vermögenslage für ihn unzumutbar sei. Zwar lägen unbenannte Zuwendungen vor, die der Ehemann im Vertrauen auf den Fortbestand der Ehe erbracht habe. Denn eine Einigung darüber, dass das Hausgrundstück oder dessen Wert auf Dauer unabhängig von dem Bestand der Ehe der Beklagten zufließen sollte, lasse sich nicht feststellen. Auch könnten sich nach Scheitern der Ehe entsprechend den Regeln über den Wegfall der Geschäftsgrundlage Ausgleichsansprüche ergeben, wenn die Beibehaltung der durch die Zuwendung herbeigeführten Vermögenslage dem benachteiligten Ehegatten nicht zumutbar sei.
13 Aufwendungen des Klägers für den Grundstückserwerb und für die anschließende Bebauung des im Alleineigentum der Beklagten stehenden Grundstücks ließen sich jedoch nicht in dem von ihm vorgetragenen Ausmaß feststellen. Feststellbar seien nur Gesamtaufwendungen einschließlich Zinsen in Höhe von 1.354.404,04 DM, die in Höhe von 490.000 DM durch den Verkauf des Teilgrundstücks, in Höhe von 600.000 DM durch gemeinsame Darlehensaufnahme und in Höhe von mindestens 410.563,10 DM aus eigenen Mitteln der Ehefrau bestritten worden seien, woraus sich ein Überschuss an Finanzmitteln in Höhe von mindestens 146.159,06 DM (= 74.729,94 €) errechne. Mit dem Fi-nanzmittelüberschuss haben die vom Ehemann bis zum maßgeblichen Trennungszeitpunkt erbrachten weiteren Zins- und Tilgungsaufwendungen sowie sein zusätzlicher Finanzierungsaufwand in Höhe von insgesamt 187.029,82 € teilweise gedeckt werden können, so dass letztlich ein Betrag von höchstens 112.299,88 € aus seinen Mitteln bedient worden sei. Hierauf müsse sich der Ehemann den hälftigen Wert der Wohnnutzung bis zum Trennungszeitpunkt in Höhe von 600 € x 60 Monate = 36.000 € anrechnen lassen, so dass Aufwendungen für den Vermögenszuwachs der Beklagten höchstens in Höhe von 76.299,88 € verblieben. Die Beibehaltung der so geschaffenen Vermögenslage sei für den Kläger nicht unzumutbar, zumal die Aufwendungen nicht aus einem vom Kläger in die Ehe eingebrachten Vermögen, sondern aus gemeinsam erwirtschafteten Mitteln aufgebracht worden seien, an denen die Ehefrau ohnehin zur Hälfte teilhabe. Auch in Anbetracht seines eigenen Vermögensaufbaus mindestens in Form von Bankeinlagen über 140.000 € und einer nicht zurückzuzahlenden Zuwendung der Beklagten an den Kläger in Höhe von 25.000 € sei ein Fortbestand der deutlich dahinter zurückbleibenden Zuwendung an die Ehefrau nicht unzumutbar.
14 Der Kläger habe auch keinen Anspruch auf einen Gesamtschuldnerausgleich der von ihm nach dem Trennungszeitpunkt weiter geleisteten Darlehensraten, weil die Parteien eine anderweitige Bestimmung getroffen hätten. Eine solche sei anzunehmen, wenn ein Ehegatte die Darlehensraten nach der endgültigen Trennung allein übernehme und im Gegenzug dafür die Aufwendungen bei der Bemessung des Unterhalts berücksichtigt würden. So seien die Parteien hier verfahren, indem der Ehemann die Darlehensraten weiterhin bedient habe und diese Aufwendungen unterhaltsmindernd berücksichtigt worden seien.
III.
15 Diese Ausführungen halten der rechtlichen Nachprüfung nicht in allen Punkten stand.
16 1. Zutreffend hat das Berufungsgericht einen Ausgleichsanspruch nach den Vorschriften über die bürgerlich-rechtliche Gesellschaft verneint.
17 a) Nach der Rechtsprechung des Senats kann ein Ausgleich nach den §§ 730 ff. BGB in Betracht kommen, wenn die Parteien ausdrücklich oder durch schlüssiges Verhalten einen Gesellschaftsvertrag geschlossen haben (Senatsurteil vom 6. Juli 2011 - XII ZR 190/08 - FamRZ 2011, 1563 Rn. 14 ff. mwN). Die Anwendung gesellschaftsrechtlicher Regelungen kann in Frage kommen, wenn die Partner die Absicht verfolgt haben, mit dem Erwerb eines Vermögensgegenstandes, etwa einer Immobilie, einen - wenn auch nur wirtschaftlich -gemeinschaftlichen Wert zu schaffen, der von ihnen für die Dauer ihrer Lebensgemeinschaft nicht nur gemeinsam genutzt werden, sondern ihnen nach ihrer Vorstellung auch gemeinsam gehören sollte. Eine rein faktische Willensübereinstimmung reicht für eine nach gesellschaftsrechtlichen Grundsätzen zu beurteilende Zusammenarbeit dagegen nicht aus (Senatsurteile BGHZ 165, 1, 10 = FamRZ 2006, 607, 609 zur Ehegatteninnengesellschaft und BGHZ 177, 193 = FamRZ 2008, 1822 Rn. 18 zur nichtehelichen Lebensgemeinschaft).
18 Der konkludente Abschluss eines Gesellschaftsvertrages kann allerdings dann nicht angenommen werden, wenn die Parteien einen Zweck verfolgen, der nicht über die Verwirklichung der zunächst nichtehelichen und später ehelichen Lebensgemeinschaft hinausgeht. Dann bestehen grundsätzlich Zweifel an dem erforderlichen Rechtsbindungswillen. Denn in diesem Punkt haben die Partner regelmäßig keine über die Ausgestaltung ihrer Gemeinschaft hinausgehenden rechtlichen Vorstellungen (Senatsurteile BGHZ 165, 1, 6 = FamRZ 2006, 607, 608 und BGHZ 142, 137, 144 f. = FamRZ 1999, 1580, 1581 zur Ehegatteninnengesellschaft sowie BGHZ 177, 193 = FamRZ 2008, 1822 Rn. 20 ff. zur nichtehelichen Lebensgemeinschaft).
19 b) Nach den getroffenen Feststellungen sind die Vorinstanzen zutreffend davon ausgegangen, dass die Voraussetzungen, unter denen ein gesellschaftsrechtliches Zusammenwirken der Partner in Betracht zu ziehen ist, hier nicht vorliegen.
20 2. Revisionsrechtlich ebenfalls nicht zu beanstanden ist die vom Berufungsgericht getroffene Feststellung, dass es sich bei den hier streitigen Vermögensdispositionen um sogenannte ehebedingte oder unbenannte Zuwendungen handelt.
21 a) Nach der Senatsrechtsprechung fallen unter dieses Rechtsinstitut solche Zuwendungen unter Ehegatten, denen die Vorstellung oder Erwartung zugrunde liegt, dass die eheliche Lebensgemeinschaft Bestand haben werde, oder die sonst um der Ehe willen und als Beitrag zur Verwirklichung oder Ausgestaltung, Erhaltung oder Sicherung der ehelichen Lebensgemeinschaft erbracht werden und die darin ihre Geschäftsgrundlage haben (vgl. Senatsurteile vom 30. Juni 1996 - XII ZR 230/96 - FamRZ 1999, 1580 und vom 17. Januar 1990 - XII ZR 1/89 - FamRZ 1990, 600 mwN).
22 b) Das Berufungsgericht leitet die Annahme, dass die Zuwendungen des Klägers an die Beklagte im Vertrauen auf den Fortbestand der Ehe erbracht wurden, daraus her, dass die aufgebrachten Mittel der Finanzierung des Familienheims dienen sollten. Das ist als tatrichterliche Feststellung revisionsrechtlich jedenfalls im Ergebnis nicht zu beanstanden, wenngleich die maßgeblichen Vereinbarungen der Parteien nicht während bestehender Ehe getroffen wurden, sondern einem bereits vor der Eheschließung gefassten Gesamtplan folgten.
23 Denn einerseits kommt ein Ausgleichsanspruch nach den Grundsätzen über den Wegfall der Geschäftsgrundlage (§ 313 BGB) auch unter nichtehelichen Partnern in Betracht, soweit den gemeinschaftsbezogenen Zuwendungen die Vorstellung oder Erwartung zugrunde lag, die Lebensgemeinschaft werde Bestand haben (Senatsurteile vom 6. Juli 2011 - XII ZR 190/08 - FamRZ 2011, 1563 Rn. 14; BGHZ 177, 193 = FamRZ 2008, 1822 Rn. 31 ff.; BGHZ 183, 242 = FamRZ 2010, 277 Rn.
25). Es entspricht deswegen der Rechtsprechung des Bundesgerichtshofs, dass Rückgewähransprüche nach den Grundsätzen über den Wegfall der Geschäftsgrundlage - sei es entweder nach Scheitern einer Ehe oder nach Scheitern einer sonstigen Lebensgemeinschaft - grundsätzlich vergleichbaren Regeln folgen (Senatsurteil BGHZ 177, 193 = FamRZ 2008, 1822). Andererseits ist nicht ausgeschlossen, dass Nichtverheiratete in Erwartung ihrer bevorstehenden Eheschließung besondere Vermögensdispositionen treffen, als deren Geschäftsgrundlage sowohl die Gründung als auch der Fortbestand der ehelichen Lebensgemeinschaft angesehen werden kann. Daher begegnet es keinen Bedenken, die im vorliegenden Fall unmittelbar vor Eheschließung geschehene gemeinsame Darlehensaufnahme über 600.000 DM und die ganz überwiegend während der Ehezeit vom Ehemann geleisteten Annuitäten auf dieses Darlehen einheitlich nach den Grundsätzen einer ehebedingten Zuwendung zu behandeln.
24 3. Das Berufungsgericht hat jedoch keine hinreichenden Feststellungen zu den Voraussetzungen getroffen, unter denen eine ehebedingte Zuwendung nach Scheitern der Ehe und Wegfall der Geschäftsgrundlage zurückverlangt werden kann.
25 a) Bei der Abwägung, ob und gegebenenfalls in welchem Umfang Zuwendungen wegen Wegfalls der Geschäftsgrundlage zurückerstattet werden müssen, ist auch zu berücksichtigen, dass der Partner es einmal für richtig erachtet hat, dem anderen diese Leistungen zu gewähren. Ein korrigierender Eingriff ist grundsätzlich nur gerechtfertigt, wenn dem Leistenden die Beibehaltung der durch die Leistung geschaffenen Vermögensverhältnisse nach Treu und Glauben nicht zuzumuten und deshalb unbillig ist. Das Merkmal der Unbilligkeit impliziert zugleich, dass ein Ausgleich nur wegen solcher Leistungen in Betracht kommt, denen nach den jeweiligen Verhältnissen erhebliche Bedeutung zukommt. Maßgebend ist eine Gesamtabwägung der Umstände des Einzelfalls (Senatsurteile vom 6. Juli 2011 - XII ZR 190/08 - FamRZ 2011, 1563 Rn. 23 ff. und BGHZ 177, 193 = FamRZ 2008, 1822 Rn. 44).
26 Ob und gegebenenfalls inwieweit ein Anspruch besteht, hängt mithin insbesondere von der Dauer der Lebensgemeinschaft, dem Alter der Parteien, Art und Umfang der erbrachten Leistungen, der Höhe der dadurch bedingten und noch vorhandenen Vermögensmehrung sowie von den Einkommens- und Vermögensverhältnissen ab (Senatsurteil vom 6. Juli 2011 - FamRZ 2011, 1563 Rn. 24 und BGHZ 84, 361, 368 = FamRZ 1982, 910). Dabei ist zu beachten, dass auch im Fall der Gütertrennung eine angemessene Beteiligung beider Ehegatten an dem gemeinsam erarbeiteten Vermögen dem Charakter der ehelichen Lebensgemeinschaft als einer Schicksals- und Risikogemeinschaft entspricht (Senatsurteil BGHZ 142, 137, 148 = FamRZ 1999, 1580, 1583 und BGH Urteil vom 4. April 1990 - IV ZR 42/89 - FamRZ 1990, 855, 856).
27 Die Einkommens- und Vermögensverhältnisse der Partner können sich während des Bestehens einer Ehe dahin auswirken, dass der Partner mit dem höheren Einkommen in größerem Umfang als der andere zu den Kosten der gemeinsamen Lebensführung beiträgt. Soweit er damit aber einen Vermögenszuwachs des anderen bewirkt hat und die Geschäftsgrundlage hierfür weggefallen ist, gebieten es Treu und Glauben nicht zwangsläufig, die Vermögenszuordnung mit dem Hinweis auf die während der Zeit des Zusammenlebens günstigeren Einkommensverhältnisse des Zuwendenden beizubehalten. Wesentliche Bedeutung kommt vielmehr auch dem Umstand zu, inwieweit eine Vermögensmehrung noch vorhanden ist (Senatsurteil vom 6. Juli 2011 - XII ZR 190/08 - FamRZ 2011, 1563 Rn. 25 zur nichtehelichen Lebensgemeinschaft).
28 b) Hinreichende Feststellungen zu diesen Beurteilungskriterien hat das Berufungsgericht nicht getroffen.
29 Der Kläger betrachtet als rückzuerstattende Zuwendung an die Beklagte einen Betrag in Höhe von 8.706,72 € an Zinsen für das am 27. September 1998 aufgenommene Darlehen, weitere Zins- und Tilgungsleistungen bis zur Trennung in Höhe von 159.593,04 € auf das am 29. Juni 1999 aufgenommene zweite Darlehen, einen Finanzierungsaufwand in Höhe von umgerechneten 35.790,43 € sowie weitere Zins- und Tilgungsleistungen in Höhe von 11.534,76 € und 6.102,61 € nach der Trennung (im Jahre 2005). Soweit sich diese Beträge aus Zinszahlungen oder einem Finanzierungsaufwand zusammensetzen, dürfte es allerdings bereits an einer noch vorhandenen Vermögensmehrung der Beklagten fehlen. Der Zinsanteil spiegelt die laufenden Wohnkosten im täglichen Zusammenleben der Parteien wider und scheidet schon deshalb vom Ausgleich aus, soweit er nicht mit einem Wertzuwachs der erworbenen Immobilie einhergeht (vgl. Senatsurteil vom 6. Juli 2011 - XII ZR 190/08 - FamRZ 2011, 1563 Rn. 25 ff.).
30 Auszugleichen könnten dann allenfalls die Tilgungsanteile sein, um die das Vermögen der Beklagten über den Trennungszeitpunkt hinaus vermehrt sein könnte, sowie die sonstigen werterhöhenden Aufwendungen. Auch insoweit kann eine Vermögensmehrung allerdings nur angenommen werden, soweit der bei der Beklagten verbliebene Gebäudewert die ebenfalls bei ihr verbleibende Restvaluta aus dem dafür aufgenommenen Darlehen übersteigt. Hierzu fehlt es ebenso an Feststellungen wie zu den Einkommens- und Vermögensverhältnissen der Parteien. Zwar hat das Berufungsurteil Einkünfte des Klägers von monatlich rd. 9.000 € sowie bei ihm vorhandene Bankeinlagen in Höhe von insgesamt 140.000 € aufgeführt. Ausreichende Feststellungen zu den Einkommens- und Vermögensverhältnissen der Beklagten hat es hingegen nicht getroffen.
31 Das Berufungsurteil kann daher keinen Bestand haben. Die Sache ist an das Berufungsgericht zurückzuverweisen, um diesem Gelegenheit zu geben, die für eine Rückgewähr nach den Grundsätzen über den Wegfall der Geschäftsgrundlage maßgebenden Kriterien vollständig aufzuklären, wobei der Kläger die Darlegungslast sämtlicher Voraussetzungen des von ihm geltend gemachten Rückgewähranspruchs trägt (vgl. Senatsurteil BGHZ 177, 193, 204 = FamRZ 2008, 1822 Rn. 39).
{{$:/.tb/template/fields-standard}}
Rendered via...
<pre><$view tiddler="$:/.tb/template/fields-standard"/></pre>
; tw version
: <<version>>
; macro
: [[$:/.tb/macros/tagfilter]]
; requires
: `[all[current[]tags[]]tagging:all[]]`
;demo
:`<<tagfilter>>`<div>
> <<tagfilter>>
</div>
; depends on
: [[pull/1385|https://github.com/Jermolene/TiddlyWiki5/pull/1385]] — @@color:red;not yet part of the core!@@
:extended tagging.js to get all tagged to the current list
:: [[$:/core/modules/filters/tagging.js]]
:: [[$:/core/modules/utils/utils.js]]
: [[pull/1379|https://github.com/Jermolene/TiddlyWiki5/pull/1379]] — @@color:red;not yet part of the core!@@
: fixes edit-mode tags and consolidates tag macro
:: [[$:/core/macros/tag]]
:: [[$:/core/ui/EditTemplate/tags]]
:: [[$:/core/ui/TagTemplate]]
<<dbadge Tiddlywiki 5.1.19 type:info>> <<dbadge "[[sriTemplates]]" Fine type:success>>
<$list filter="Rechtsgebiete Gesetze Keys Anwendungen">
<div class="tb-taglist-item">
<small class="tc-menu-list-count"><$count filter="[all[current]tagging[]]"/></small>
<$transclude tiddler="$:/.tb/templates/TagTemplate"/>
</div>
</$list>
* Grundsätzlich sollte die Trennung von INHALTEN und fallbezogenen CLIENTS und Tickets eingehalten werden. ONLINE
* Veränderungsrechte bleiben grundsätzlich Experten vorbehalten.
* Inhalte sollten Benutzerbezogen nach Fall oder Rechtsgebieten gefiltert werden
* [[KLASSIFIKATION]]
----
* [[sriDashboard]] [[sriFILTER]]
* [[sriTOOLS]]
----
<<x-tag "Gesetz" label:"gesetz">>
----
last 10 modified ...
<<list-links "[has[modified]!sort[modified]limit[10]]" type:"ol">>
----
<$list filter="[[Startbaum]] +[kin[]]"><$view field="title"/><br/></$list>
``[[Startbaum]] +[kin[]]``
* Strafrecht Allgemeiner Teil
* Strafrecht BT: Höchstpersönliche Rechtsgüter
* Strafrecht BT: Vermögensdelikte
* Strafrecht BT: Sonstige Delikte
* Strafprozessrecht
TiddlyWiki5 provides several features to help you structure information as [[tiddlers|Tiddlers]], and model the relationships between them:
* TiddlerLinks
* [[Tagging]]
* [[Transclusion in WikiText]]
<!--
Styling for book tiddlers
-->
.tc-tagged-Book {
margin:0px;
}
.tc-tagged-Book .tc-tiddler-title {
<$list filter='[[$:/settings]!edit_mode[true]]'>
display:none;
</$list>
}
.tc-tagged-Book .tc-subtitle {
display:none;
}
.tc-tagged-Book .tc-tiddler-controls {
<$list filter='[[$:/settings]!edit_mode[true]]'>
display:none;
</$list>
}
.tc-tagged-Book .tc-tags-wrapper {
display:none;
}
<!--
Styling for chapter tiddlers
-->
.tc-tagged-Chapter {
}
.tc-tagged-Chapter .tc-tags-wrapper{
display:none;
}
.tc-tagged-Chapter .tc-subtitle {
display:none;
}
.tc-tagged-Chapter .tc-title {
<$list filter='[[$:/settings]!edit_mode[true]]'>
display:none;
</$list>
}
.tc-tagged-Chapter .tc-tiddler-controls {
<$list filter='[[$:/settings]!edit_mode[true]]'>
display:none;
</$list>
}
<!--
Styling for paragraph tiddlers
-->
.tc-tagged-Paragraph {
margin: 0px;
}
.tc-tagged-Paragraph .tc-tiddler-controls {
<$list filter='[[$:/settings]!edit_mode[true]]'>
display:none;
</$list>
}
.tc-tagged-Paragraph .tc-tiddler-title {
<$list filter='[[$:/settings]!edit_mode[true]]'>
display:none;
</$list>
}
.tc-tagged-Paragraph .tc-tags-wrapper {
display:none;
}
.tc-tagged-Paragraph .tc-subtitle {
display:none;
}
.tc-tagged-Paragraph .tc-tiddler-controls:hover {
fill:inherit;
}
Tiddler specific CSS style settings, e.g title font, background image, number of text columns, etc.
(Not implemented.)
Imagine you want to dynamically create filters. You can obviously use macro definitions and use them like
``filter=<<mymacro>>``
Issue arises when you want to add steps to the filter. You cannot go
``filter="<<mymacro>> +[tag[mytag]]"``
Subfilter solves this issue. You can go like
``filter="[subfilter<mymacro>] +[tag[mytag]]"``
And in another tiddler you can go like
``filter="[subfilter<mymacro>append[!]]"``
Basically it enables you to define dynamic filters and reuse them.
<<.from-version "5.1.18">> Note that the subfilter operator was introduced in version 5.1.18 and is not available in earlier versions.
<<.tip " Literal filter operands cannot contain square brackets but you can work around the issue by using a variable:">>
```
<$set name="myFilter" value="[tag[one]]">
<$list filter="[all[tiddlers]subfilter<myFilter>]">
...
```
<<.operator-examples "subfilter">>
<<.operator-example 1 "[subfilter[one two three]addsuffix[!]]">>
<<.operator-example 2 "[subfilter{$:/StoryList!!list}]">>
[
{
"title": "Draft of 'New Tiddler'"
},
{
"title": "New ITem in Substory"
},
{
"title": "Draft of 'New ITem in Substory'"
},
{
"title": "New Item in Substory"
},
{
"title": "Draft of 'New Tiddler'"
},
{
"title": "Draft of 'New Item in Substory'"
},
{
"title": "New Item in Substory"
},
{
"title": "$:/ControlPanel",
"fromPageRect": {
"top": 207.046875,
"left": 473.21875,
"width": 22.5,
"right": 495.71875,
"bottom": 234.046875,
"height": 27
}
},
{
"title": "DropzoneWidget",
"fromPageRect": {
"top": 258.234375,
"left": 617.609375,
"width": 108.75,
"right": 726.359375,
"bottom": 276.234375,
"height": 18
}
},
{
"title": "DropzoneWidget",
"fromPageRect": {
"top": 258.578125,
"left": 617.609375,
"width": 108.75,
"right": 726.359375,
"bottom": 276.578125,
"height": 18
}
},
{
"title": "DropzoneWidget",
"fromPageRect": {
"top": 322.390625,
"left": 617.609375,
"width": 108.75,
"right": 726.359375,
"bottom": 340.390625,
"height": 18
}
},
{
"title": "$:/ControlPanel",
"fromPageRect": {
"top": 109.046875,
"left": 473.21875,
"width": 22.5,
"right": 495.71875,
"bottom": 136.046875,
"height": 27
}
},
{
"title": "Draft of 'New Item in Substory'"
},
{
"title": "New Item in Substory"
},
{
"title": "New Item in Substory",
"fromPageRect": {
"top": 273.046875,
"left": 436,
"width": 172.515625,
"right": 608.515625,
"bottom": 303.046875,
"height": 30
}
},
{
"title": "Draft 2 of 'New Tiddler' by cyrill"
},
{
"title": "Draft 2 of 'New Tiddler' by cyrill",
"fromPageRect": {
"top": 273.046875,
"left": 436,
"width": 233.375,
"right": 669.375,
"bottom": 303.046875,
"height": 30
}
},
{
"title": "Draft 2 of 'New Tiddler' by cyrill",
"fromPageRect": {
"top": 273.046875,
"left": 436,
"width": 233.375,
"right": 669.375,
"bottom": 303.046875,
"height": 30
}
},
{
"title": "Draft 2 of 'New Tiddler' by cyrill",
"fromPageRect": {
"top": 273.046875,
"left": 436,
"width": 233.375,
"right": 669.375,
"bottom": 303.046875,
"height": 30
}
},
{
"title": "Draft of 'New Tiddler 1' by cyrill"
},
{
"title": "Draft of 'New Tiddler 2' by cyrill"
},
{
"title": "Draft of 'New Tiddler 2' by cyrill",
"fromPageRect": {
"top": 273.046875,
"left": 436,
"width": 233.265625,
"right": 669.265625,
"bottom": 303.046875,
"height": 30
}
},
{
"title": "New Item in Substory",
"fromPageRect": {
"top": 331.0625,
"left": 436,
"width": 172.515625,
"right": 608.515625,
"bottom": 361.0625,
"height": 30
}
},
{
"title": "New Item in Substory",
"fromPageRect": {
"top": 297.0625,
"left": 436,
"width": 172.515625,
"right": 608.515625,
"bottom": 327.0625,
"height": 30
}
},
{
"title": "Draft of 'New Tiddler 2' by cyrill"
},
{
"title": "Draft of 'New Tiddler 3' by cyrill"
},
{
"title": "$:/ControlPanel",
"fromPageRect": {
"top": 231.0625,
"left": 473.21875,
"width": 22.5,
"right": 495.71875,
"bottom": 258.0625,
"height": 27
}
},
{
"title": "$:/ControlPanel",
"fromPageRect": {
"top": 297.0625,
"left": 436,
"width": 133.828125,
"right": 569.828125,
"bottom": 327.0625,
"height": 30
}
},
{
"title": "Draft of 'New Tiddler 4' by cyrill"
},
{
"title": "Draft of 'New Tiddler 5' by cyrill"
},
{
"title": "Draft of 'New Tiddler 6' by cyrill"
},
{
"title": "Draft of 'New Tiddler 6' by cyrill",
"fromPageRect": {
"top": 297.0625,
"left": 436,
"width": 233.265625,
"right": 669.265625,
"bottom": 327.0625,
"height": 30
}
},
{
"title": "Draft of 'New Tiddler 6' by cyrill",
"fromPageRect": {
"top": 297.0625,
"left": 436,
"width": 233.265625,
"right": 669.265625,
"bottom": 327.0625,
"height": 30
}
},
{
"title": "Draft of 'New Tiddler 6' by cyrill",
"fromPageRect": {
"top": 297.0625,
"left": 436,
"width": 233.265625,
"right": 669.265625,
"bottom": 327.0625,
"height": 30
}
},
{
"title": "Draft of 'New Tiddler 7' by cyrill"
},
{
"title": "Draft of 'New Tiddler 7' by cyrill",
"fromPageRect": {
"top": 297.0625,
"left": 436,
"width": 233.265625,
"right": 669.265625,
"bottom": 327.0625,
"height": 30
}
},
{
"title": "Draft of 'New Tiddler 8' by cyrill"
},
{
"title": "Draft of 'New Tiddler 9' by cyrill"
}
]
<$navigator story="$:/SubStoryList" history="SubHistoryList">
{{$:/core/ui/PageTemplate/pagecontrols}}
<div class="browser-tab-buttons">
<$transclude tiddler="$:/core/ui/Buttons/new-tiddler" mode="inline"/>
<$list filter="[list[$:/SubStoryList]]" history="$:/SubHistoryList" variable="currentTab">
<$reveal type="match" state="$:/SubHistoryList!!current-tiddler" text=<<currentTab>>>
<div class="browser-tab">
<$button to=<<currentTab>> class="browser-tab-button browser-tab-selected" tooltip=<<currentTab>>>
<$macrocall $name="currentTab" $type="text/plain" $output="text/plain"/>
</$button>
<$button message="tm-close-tiddler" param=<<currentTab>> class="browser-tab-close browser-tab-selected" tooltip=<<currentTab>>>×</$button></div></$reveal>
<$reveal type="nomatch" state="$:/SubHistoryList!!current-tiddler" text=<<currentTab>>>
<div class="browser-tab">
<$button class="browser-tab-button" to=<<currentTab>> tooltip=<<currentTab>>>
<$macrocall $name="currentTab" $type="text/plain" $output="text/plain"/>
</$button><$button class="browser-tab-close" message="tm-close-tiddler" param=<<currentTab>> tooltip=<<currentTab>>>
×</$button></div></$reveal>
</$list>
</div>
<section class="substory-window" style="position: relative;width: 100%;">
<$list filter="[list[$:/SubStoryList]]" storyview="zoomin" template="$:/core/ui/ViewTemplate" editTemplate="$:/core/ui/EditTemplate"/>
</section>
</$navigator>
<$navigator story="$:/SubStoryList" history="SubHistoryList">
{{$:/core/ui/PageTemplate/pagecontrols}}
<section style="position: relative;width: 100%;">
<$list filter="[list[$:/SubStoryList]]" storyview="classic" template="$:/core/ui/ViewTemplate" editTemplate="$:/core/ui/EditTemplate"/>
</section>
</$navigator>
<<ColumnTable '[tag[_Rechtsgebiete]]'>>
\define TableWizardDisplayTableDummyMacro()
<<DisplayTable """$(ConfigTiddler)$""">>
\end
\define TableWizardColumnSelectCheckbox()
<$checkbox tiddler='$:/state/$(ConfigTiddler)$/Display Columns/$(ThisDisplayColumn)$' field='show' checked='$(ThisDisplayColumn)$' unchecked=''>
<$view tiddler="""$(ThisDisplayColumn)$""" field=caption>
$(ThisDisplayColumn)$
</$view>
</$checkbox>
\end
\define TableWizardSubcolumnSelectCheckbox()
<$checkbox tiddler='$:/state/$(ConfigTiddler)$/Display Subcolumns/$(ThisDisplaySubcolumn)$' field='show' checked='$(ThisDisplaySubcolumn)$' unchecked=''>
<$view tiddler="""$(ThisDisplaySubcolumn)$""" field=caption>
$(ThisDisplaySubcolumn)$
</$view>
</$checkbox>
\end
\define TableWizardRowSelectCheckbox()
<$checkbox tiddler='$:/state/$(ConfigTiddler)$/Display Rows/$(ThisDisplayRow)$' field='show' checked='$(ThisDisplayRow)$' unchecked=''>
<$view tiddler="""$(ThisDisplayRow)$""" field=caption>
$(ThisDisplayRow)$
</$view>
</$checkbox>
\end
\define TableWizardMakeColumnSelectCheckbox()
<$list filter='[tag{$(ConfigTiddler)$!!column_tag}]' variable=ThisDisplayColumn>
<<TableWizardColumnSelectCheckbox>>
</$list>
\end
\define TableWizardMakeSubcolumnSelectCheckbox()
<$list filter='[tag{$(ConfigTiddler)$!!subcolumn_tag}]' variable=ThisDisplaySubcolumn>
<<TableWizardSubcolumnSelectCheckbox>>
</$list>
\end
\define TableWizardMakeRowSelectCheckbox()
<$list filter='[tag{$(ConfigTiddler)$!!row_tag}]' variable=ThisDisplayRow>
<<TableWizardRowSelectCheckbox>>
</$list>
\end
\define TableWizardButtonSubcolumn()
<$reveal type='nomatch' state="""$:/state/$(ConfigTiddler)$/$(ThisRow)$/$(ThisColumn)$/$(ThisSubcolumn)$""" text='edit'>
<div style='height:100%;width:100%;'>
<$button class='tc-btn-invisible' style='height:100%;width:100%;'>
<$view tiddler="""$:/Data/$(ThisRow)$/$(ThisColumn)$/$(ThisSubcolumn)$/$(ThisItem)$""" field=subcolumn_data>
<<MissingMessage>>
</$view>
<$action-setfield $tiddler="""$:/state/$(ConfigTiddler)$/$(ThisRow)$/$(ThisColumn)$/$(ThisSubcolumn)$""" $value=edit/>
</$button>
</div>
</$reveal>
<$reveal type='match' state="""$:/state/$(ConfigTiddler)$/$(ThisRow)$/$(ThisColumn)$/$(ThisSubcolumn)$""" text='edit'>
<$button>
{{$:/core/images/done-button}}
<$action-setfield $tiddler="""$:/state/$(ConfigTiddler)$/$(ThisRow)$/$(ThisColumn)$/$(ThisSubcolumn)$""" $value=''/>
</$button>
<$edit-text tiddler="""$:/Data/$(ThisRow)$/$(ThisColumn)$/$(ThisSubcolumn)$/$(ThisItem)$""" field=subcolumn_data size=1/>
</$reveal>
\end
\define TableWizardSubcolumnDisplayEntry()
<td>
<$reveal type='nomatch' state="""$(ConfigTiddler)$!!allow_edit""" text='yes'>
<$view tiddler="""$:/Data/$(ThisRow)$/$(ThisColumn)$/$(ThisSubcolumn)$/$(ThisItem)$""" field=subcolumn_data>
<<MissingMessage>>
</$view>
</$reveal>
<$reveal type='match' state="""$(ConfigTiddler)$!!allow_edit""" text='yes'>
<<TableWizardButtonSubcolumn>>
</$reveal>
</td>
\end
\define TableWizardButtonColumn()
<$reveal type='nomatch' state="""$:/state/$(ConfigTiddler)$/$(ThisRow)$/$(ThisColumn)$!!$(ThisColumn)$""" text='edit'>
<div style='height:100%;width:100%;'>
<$button class='tc-btn-invisible' style='height:100%;width:100%;'>
<$view tiddler="""$:/Data/$(ThisRow)$/$(ThisColumn)$/$(ThisItem)$""" field='column_data'>
<<MissingMessage>>
</$view>
<$action-setfield $tiddler="""$:/state/$(ConfigTiddler)$/$(ThisRow)$/$(ThisColumn)$""" $field=$(ThisColumn)$ $value=edit/>
</$button>
</div>
</$reveal>
<$reveal type='match' state="""$:/state/$(ConfigTiddler)$/$(ThisRow)$/$(ThisColumn)$!!$(ThisColumn)$""" text='edit'>
<$button>
{{$:/core/images/done-button}}
<$action-setfield $tiddler="""$:/state/$(ConfigTiddler)$/$(ThisRow)$/$(ThisColumn)$""" $field=$(ThisColumn)$ $value=''/>
</$button>
<$edit-text tiddler="""$:/Data/$(ThisRow)$/$(ThisColumn)$/$(ThisItem)$""" field=column_data size=1/>
</$reveal>
\end
\define TableWizardColumnDisplayEntry()
<td>
<$reveal type='nomatch' state="""$(ConfigTiddler)$!!allow_edit""" text='yes'>
<$view tiddler="""$:/Data/$(ThisRow)$/$(ThisColumn)$/$(ThisItem)$""" field='column_data'>
<<MissingMessage>>
</$view>
</$reveal>
<$reveal type='match' state="""$(ConfigTiddler)$!!allow_edit""" text='yes'>
<<TableWizardButtonColumn>>
</$reveal>
</td>
\end
\define TableWizardDisplayTableWithSubcolumns(DataTag ColumnTag SubcolumnTag RowTag SubcolumnPerColumn EmptyMessage)
@@text-align:center;
<$set name='ColumnList' filter='[prefix[$:/state/$(ConfigTiddler)$/Display Columns]has[show]get[show]tag[$ColumnTag$]sort[title]]-[[text]]-[[title]]-[[modified]]-[[created]]'>
<$set name='SubcolumnList' filter='[prefix[$:/state/$(ConfigTiddler)$/Display Subcolumns]has[show]get[show]tag[$SubcolumnTag$]sort[title]]-[[text]]-[[title]]-[[modified]]-[[created]]'>
<$set name='RowList' filter='[prefix[$:/state/$(ConfigTiddler)$/Display Rows]has[show]get[show]tag[$RowTag$]sort[title]]-[[text]]-[[title]]-[[modified]]-[[created]]'>
<$set name=MissingMessage value='$EmptyMessage$'>
<$set name=ThisItem value={{$(ConfigTiddler)$!!selected_data}}>
<table style='width:100%;border-color:black;'>
<tr>
<td style='background-color:lightgrey;border-color:black;'>
</td>
<$list filter=<<ColumnList>>>
<td colspan="$SubcolumnPerColumn$" style='background-color:lightgrey;border-color:black;'>
<$link to=<<currentTiddler>>>
<$view field='caption'>
<<currentTiddler>>
</$view>
</$link>
</td>
</$list>
</tr>
<tr style='width:100%;bordor-color:black;'>
<td style='border-left-color:black;'>
</td>
<$list filter=<<ColumnList>>>
<$list filter=<<SubcolumnList>> variable=ThisSubcolumn>
<td>
<$link to=<<ThisSubcolumn>>>
<$view tiddler=<<ThisSubcolumn>> field=caption>
<<ThisSubcolumn>>
</$view>
</$link>
</td>
</$list>
</$list>
</tr>
<$list filter=<<RowList>> variable=ThisRow>
<tr>
<td style='border-left:0px;'>
<$link to=<<ThisRow>>>
<$view tiddler=<<ThisRow>> field=caption>
<<ThisRow>>
</$view>
</$link>
</td>
<$list filter=<<ColumnList>> variable=ThisColumn>
<$list filter=<<SubcolumnList>> variable=ThisSubcolumn>
<<TableWizardSubcolumnDisplayEntry>>
</$list>
</$list>
</tr>
</$list>
</table>
</$set>
</$set>
</$set>
</$set>
</$set>
@@
\end
\define TableWizardDisplayTableMacro(DataTag ColumnTag RowTag EmptyMessage)
@@text-align:center;
<$set name='ColumnList' filter='[prefix[$:/state/$(ConfigTiddler)$/Display Columns]has[show]get[show]tag[$ColumnTag$]sort[title]]-[[text]]-[[title]]-[[modified]]-[[created]]'>
<$set name='RowList' filter='[prefix[$:/state/$(ConfigTiddler)$/Display Rows]has[show]get[show]tag[$RowTag$]sort[title]]-[[text]]-[[title]]-[[modified]]-[[created]]'>
<$set name=ThisItem value={{$(ConfigTiddler)$!!selected_data}}>
<$set name=MissingMessage value='$EmptyMessage$'>
<table style='width:100%;border-color:black;'>
<tr>
<td style='background-color:lightgrey;border-color:black;'>
</td>
<$list filter=<<ColumnList>>>
<td style='background-color:lightgrey;border-color:black;'>
<$link to=<<currentTiddler>>>
<$view field='caption'>
<<currentTiddler>>
</$view>
</$link>
</td>
</$list>
</tr>
<$list filter=<<RowList>> variable=ThisRow>
<tr>
<td style='border-left:0px;'>
<$link to=<<ThisRow>>>
<$view tiddler=<<ThisRow>> field=caption>
<<ThisRow>>
</$view>
</$link>
</td>
<$list filter=<<ColumnList>> variable=ThisColumn>
<<TableWizardColumnDisplayEntry>>
</$list>
</tr>
</$list>
</table>
</$set>
</$set>
</$set>
</$set>
@@
\end
\define MakeTableWizard()
Enter the name of the configuration tiddler to create:
<$edit-text tiddler='$:/temp/MakeTableWizard' field='config_tiddler_name' class='tc-edit-texteditor' placeholder='Configuration Tiddler Name'/>
<$reveal type='match' state='$:/temp/MakeTableWizard!!config_tiddler_name' text=''>
You have to enter a configuration tiddler name first.
</$reveal>
<$reveal type='nomatch' state='$:/temp/MakeTableWizard!!config_tiddler_name' text=''>
<$set name=ConfigTiddler value={{$:/temp/MakeTableWizard!!config_tiddler_name}}>
<$checkbox tiddler=<<ConfigTiddler>> field='include_subcolumns' checked='yes' unchecked='no'>Include Subcolumns</$checkbox><br>
<$tiddler tiddler=<<ConfigTiddler>>>
Data tag:
<$edit-text field='dataset_tag' class='tc-edit-texteditor'/>
Select Dataset Name <$reveal type='nomatch' state='!!show_new_dataset' text='true'>(<$button>Create New Datasets<$action-setfield show_new_dataset=true/></$button>):<br><br></$reveal>
<$reveal type='match' state='!!show_new_dataset' text='true'>(<$button>Done Creating Datasets<$action-setfield show_new_dataset=false/></$button>):<br><br>
<$edit-text tiddler='$:/temp/MakeTableWizard' field='new_dataset_name' class='tc-edit-texteditor' placeholder='New Dataset Name'/>
<$button>Create Dataset<$action-setfield $tiddler={{$:/temp/MakeTableWizard!!new_dataset_name}} tags={{!!dataset_tag}}/><$action-setfield $tiddler='$:/temp/MakeTableWizard' new_dataset_name=''/></$button><br><br>
</$reveal>
<$select field='selected_data'><$list filter='[tag{!!dataset_tag}]'><option><<currentTiddler>></option></$list></$select>
<br>
<$set name=SelectedData value={{!!selected_data}}>
Column tag:
<$edit-text field='column_tag' class='tc-edit-texteditor'/><br><br>
Select Columns to display <$reveal type='nomatch' state='!!show_new_column' text='true'>(<$button>Create New Columns<$action-setfield show_new_column=true/></$button>):<br><br></$reveal>
<$reveal type='match' state='!!show_new_column' text='true'>(<$button>Done Creating Columns<$action-setfield show_new_column=false/></$button>):<br><br>
<$edit-text tiddler='$:/temp/MakeTableWizard' field='new_column_name' class='tc-edit-texteditor' placeholder='New Column Name'/>
<$button>Create Column<$action-setfield $tiddler={{$:/temp/MakeTableWizard!!new_column_name}} tags={{!!column_tag}}/><$action-setfield $tiddler='$:/temp/MakeTableWizard' new_column_name=''/></$button><br><br>
</$reveal>
<<TableWizardMakeColumnSelectCheckbox>><br><br>
<$reveal type='match' state='!!include_subcolumns' text='yes'>
Subcolumn tag:
<$edit-text field='subcolumn_tag' class='tc-edit-texteditor'/>
Subcolumns per column:
<$edit-text field='subcolumn_per_column' class='tc-edit-texteditor'/>
Select subcolumns to display <$reveal type='nomatch' state='!!show_new_subcolumn' text='true'>(<$button>Create New Subcolmun<$action-setfield show_new_subcolumn=true/></$button>):<br><br></$reveal>
<$reveal type='match' state='!!show_new_subcolumn' text='true'>(<$button>Done Creating Subcolumns<$action-setfield show_new_subcolumn=false/></$button>):<br><br>
<$edit-text tiddler='$:/temp/MakeTableWizard' field='new_subcolumn_name' class='tc-edit-texteditor' placeholder='New Subcolumn Name'/>
<$button>Create Subcolumn<$action-setfield $tiddler={{$:/temp/MakeTableWizard!!new_subcolumn_name}} tags={{!!subcolumn_tag}}/><$action-setfield $tiddler='$:/temp/MakeTableWizard' new_subcolumn_name=''/></$button><br><br>
</$reveal>
<<TableWizardMakeSubcolumnSelectCheckbox>><br>
</$reveal>
Row tag:
<$edit-text field='row_tag' class='tc-edit-texteditor'/><br><br>
Select rows to display <$reveal type='nomatch' state='!!show_new_row' text='true'>(<$button>Create New Rows<$action-setfield show_new_row=true/></$button>):<br><br></$reveal>
<$reveal type='match' state='!!show_new_row' text='true'>(<$button>Done Creating Rows<$action-setfield show_new_row=false/></$button>):<br><br>
<$edit-text tiddler='$:/temp/MakeTableWizard' field='new_row_name' class='tc-edit-texteditor' placeholder='New Row Name'/>
<$button>Create Row<$action-setfield $tiddler={{$:/temp/MakeTableWizard!!new_row_name}} tags={{!!row_tag}}/><$action-setfield $tiddler='$:/temp/MakeTableWizard' new_row_name=''/></$button><br><br>
</$reveal>
<<TableWizardMakeRowSelectCheckbox>><br><br>
Empty cell message:
<$edit-text field='empty_message' class='tc-edit-texteditor'/>
<$checkbox field='allow_edit' checked='yes' unchecked='no'>Allow Inline Editing</$checkbox><br>
<$reveal type='match' state='!!show_table' text='yes'>
</$reveal>
</$set>
</$tiddler>
<$button>Refresh Table
<$action-setfield dummy=1/>
</$button>
<<TableWizardDisplayTableDummyMacro>>
</$set>
</$reveal>
\end
\define TableWizardDisplayTableInside()
<$reveal type='nomatch' state="""$(ConfigTiddler)$!!include_subcolumns""" text='yes'>
<$macrocall $name=TableWizardDisplayTableMacro DataTag={{$(ConfigTiddler)$!!dataset_tag}} ColumnTag={{$(ConfigTiddler)$!!column_tag}} RowTag={{$(ConfigTiddler)$!!row_tag}} EmptyMessage={{$(ConfigTiddler)$!!empty_message}}/>
</$reveal>
<$reveal type='match' state="""$(ConfigTiddler)$!!include_subcolumns""" text='yes'>
<$macrocall $name=TableWizardDisplayTableWithSubcolumns DataTag={{$(ConfigTiddler)$!!dataset_tag}} ColumnTag={{$(ConfigTiddler)$!!column_tag}} RowTag={{$(ConfigTiddler)$!!row_tag}} EmptyMessage={{$(ConfigTiddler)$!!empty_message}} SubcolumnTag={{$(ConfigTiddler)$!!subcolumn_tag}} SubcolumnPerColumn={{$(ConfigTiddler)$!!subcolumn_per_column}}/>
</$reveal>
\end
\define DisplayTable(ConfigTiddler)
<$set name=ConfigTiddler value="""$ConfigTiddler$""">
<<TableWizardDisplayTableInside>>
</$set>
\end
\define TableMacrosColumnInnerInnerRows()
<tr>
<th>
</th>
<$list filter='$(ColumnList)$+[sort{$(TableMacrosMakeTableSortStateTiddler)$}]'>
<th>
<<currentTiddler>>
</th>
</$list>
</tr>
<$list filter=<<FieldsList>> variable=ThisField>
<tr>
<th>
<$button class='tc-btn-invisible' set=<<TableMacrosMakeTableSortStateTiddler>> setTo=<<ThisField>>><<ThisField>></$button>
</th>
<$list filter='$(ColumnList)$+[sort{$(TableMacrosMakeTableSortStateTiddler)$}]' variable=ThisTiddler>
<td>
<<TableMacrosInlineEditButton>>
</td>
</$list>
</tr>
</$list>
\end
\define TableMacrosInnerColumnTable()
<$set name=FieldsList1 filter='$(ColumnList)$+[fields[]]-[[text]]-[[title]]-[[modified]]-[[created]]-[[tags]]'>
<$set name=FieldsList filter='[is[system]!is[system]]$(FieldsUsed)$' emptyValue=<<FieldsList1>>>
<$set name=RowOrColumn value=Column>
<$set name=TableSortState value=<<TableMacrosMakeTableSortState>>>
<table>
<<TableMacrosColumnInnerInnerRows>>
</table>
</$set>
</$set>
</$set>
</$set>
\end
\define TableMacrosMakeTableSortState()
{{$:/state/tables/Sort/$(RowOrColumn)$/$(FieldsList)$}}
\end
\define TableMacrosMakeTableSortStateTiddler()
$:/state/tables/Sort/$(RowOrColumn)$/$(FieldsList)$
\end
\define TableMacrosRowTableInnerInnerRows()
<$list filter='$(RowList)$+[sort{$(TableMacrosMakeTableSortStateTiddler)$}]' variable=ThisTiddler>
<tr>
<th>
<<ThisTiddler>>
</th>
<$list filter=<<FieldsList>> variable=ThisField>
<td>
<<TableMacrosInlineEditButton>>
</td>
</$list>
</tr>
</$list>
\end
\define TableMacrosInnerRowTable()
<$set name=FieldsList1 filter='$(RowList)$+[fields[]]-[[text]]-[[title]]-[[modified]]-[[created]]-[[tags]]'>
<$set name=FieldsList filter='[is[system]!is[system]]$(FieldsUsed)$' emptyValue=<<FieldsList1>>>
<$set name=RowOrColumn value=Row>
<$set name=TableSortState value=<<TableMacrosMakeTableSortState>>>
<table>
<tr>
<th>
<$button class='tc-btn-invisible' style='width:100%;height:100%' set=<<TableMacrosMakeTableSortStateTiddler>> setTo=title>Title</$button>
</th>
<$list filter=<<FieldsList>>>
<th>
<$button class='tc-btn-invisible' set=<<TableMacrosMakeTableSortStateTiddler>> setTo=<<currentTiddler>>><<currentTiddler>></$button>
</th>
</$list>
</tr>
<<TableMacrosRowTableInnerInnerRows>>
</table>
</$set>
</$set>
</$set>
</$set>
\end
\define ColumnTable(filter fields)
<$set name='ColumnList' value='$filter$'>
<$set name='FieldsUsed' value='$fields$'>
<<TableMacrosInnerColumnTable>>
</$set>
</$set>
\end
\define RowTable(filter fields)
<$set name='RowList' value='$filter$'>
<$set name='FieldsUsed' value='$fields$'>
<<TableMacrosInnerRowTable>>
</$set>
</$set>
\end
\define TableMacrosInlineEditButton()
<$reveal type='nomatch' state="""$:/temp/edit/$(ThisTiddler)$/$(ThisField)$""" text='edit'>
<$button set="""$:/temp/edit/$(ThisTiddler)$/$(ThisField)$""" setTo=edit class='tc-btn-invisible' style='width:100%;hegiht:100%'>
<$view tiddler=<<ThisTiddler>> field=<<ThisField>>>--</$view>
</$button>
</$reveal>
<$reveal type='match' state="""$:/temp/edit/$(ThisTiddler)$/$(ThisField)$""" text='edit'>
<$button set="""$:/temp/edit/$(ThisTiddler)$/$(ThisField)$""" setTo=noedit>{{$:/core/images/done-button}}</$button>
<$edit-text tiddler=<<ThisTiddler>> field=<<ThisField>> size=1/>
</$reveal>
\end
| !A table |
|This is an index of all the tiddlers in <<tv-story-list>>|c
|<<list-links "[list[PE:story]]">>|
<div class="tc-table-of-contents">
<<toc-selective-expandable 'TableOfContents'>>
</div>
<<tabs "[tag[Anwendungen]]" "" "" "tc-vertical">>
<$set name="tag" value={{!!subtitle}}>
<$list filter="[tag<tag>tag[]] -[tag<tag>] -[<tag>]">
</$list>
</$set>
\define calcFontSize() font-size:calc(0.5em + (0.2em * ($(count)$ / 2) ) );
<$list filter="[tags[]]" variable="thistag">
<$vars count={{{ [<thistag>tagging[]count[]] }}}>
<span style=<<calcFontSize>>>
<$link to=<<thistag>> tooltip=<<count>>>
<$text text=<<thistag>> />
</$link>
</span>
</$vars>
</$list>
Tagging is a way of organising tiddlers into categories. For example, if you had tiddlers representing various individuals, you could tag them as ''friend'', ''family'', ''colleague'' etc to indicate these people's relationships to you.
A tag is in fact just a tiddler (or a potential tiddler), and it can have tags of its own. You can add any number of tags to the same tiddler.
See [[Creating and editing tiddlers]] for instructions on how to tag.
By tagging your tiddlers, you can view, navigate and organise your information in numerous additional ways:
* The coloured tag pills on a tiddler give you quick access to all the other tiddlers with the same tag, as well as to the tiddler that represents the tag itself.
* If a tiddler is serving as a tag, then the ''Tagging'' tab in its InfoPanel will show you which tiddlers are currently tagged with it.
* The ''More'' tab of the sidebar has a ''Tags'' tab that presents an overview of all your tags and lets you access all your tagged tiddlers.
* You can use [[filters|Filters]] to create lists of tiddlers based on their tags. You can then display any combination of the [[fields|TiddlerFields]] of those tiddlers. For example, you could build a glossary by listing the title and text of all tiddlers tagged ''Glossary''. Such lists can be formatted in any way you wish: e.g. bulleted, numbered or comma-separated.
* There are a number of special ''system tags'' that control the layout of tiddlers and the entire ~TiddlyWiki page. See [[Page and tiddler layout customisation]] for instructions.
There are two more things you can do with tags:
! Set a tag's colour and icon
You can use the {{$:/core/images/tag-button}} [[tag manager|$:/TagManager]], found on the ''Tags'' tab under ''More'' in the sidebar, to change the colour of a tag's pill or add an icon to the pill.
* To change the colour, click the button in the ''Colour'' column to select from a colour picker. Alternatively, click the icon in the ''Info'' column, then type a [[CSS]] colour value in the ''Colour'' field
* To change the icon, click the {{$:/core/images/down-arrow}} button in the ''Icon'' column and choose from the list of available icons
! Change the order in which tags are listed
By default, tagged tiddlers are listed in alphabetical order.
If you want any other order, add a <<.flink ListField>> field to the tag tiddler, and set its value to be a [[list of the tiddlers|Title List]] in that order.
The ''list'' field doesn't have to mention all of the tiddlers. See the [[precise rules|Order of Tagged Tiddlers]] ~TiddlyWiki uses to order tagged tiddlers.
`<td><$list filter="[all[current]tag[something-else]]">{{something-else||$:/core/ui/TagTemplate}}</$list></td>`
To show the tag pill you can click on to see what else has the tag
or
`<td><$checkbox tag="something-else"></$checkbox></td>`
\define thisDisplayChangeLogEntry()
{{$:/data/Change Log##$(ThisEntry)$}} - <$view tiddler=<<ThisEntry>> field='title'><br>
\end
This is my new changelog using my category lists plugin, you can get the plugin from my plugin library. Unfinished Tasks are things I am planning on doing, including updates to plugins and bugfixes. Finished Tasks are things that I have done. Clicking on a section title collapses that section, clicking on the {{$:/core/images/info-button}} icon gives information about the task, the checkbox marks the task as finished, the {{$:/core/images/edit-button}} lets you edit a task and the {{$:/core/images/cancel-button}} removes the task from the list.
<<CategoryList Tag:"Planned Update" FinishedTag:"Change Log">>
---
<$reveal type='nomatch' state='$:/state/ChangeLog/showoldlog' text='show'>
<$button set='$:/state/ChangeLog/showoldlog' setTo='show'>Show Old Change Log</$button>
</$reveal>
<$reveal type='match' state='$:/state/ChangeLog/showoldlog' text='show'>
<$button set='$:/state/ChangeLog/showoldlog' setTo='hide'>Show Old Change Log</$button>
This was started on 10-03-2015, so anything older than that isn't listed.
Change:
<$edit-text tiddler='$:/temp/Change Log' field='change' class='tc-edit-texteditor'/>
<$button>Add Entry
<$action-setfield $tiddler='$:/data/Change Log' $index={{$:/temp/Change Log!!change}} $value=<<now "0DDth MMM YYYY">>/>
<$action-setfield $tiddler='$:/temp/Change Log' change=''/>
</$button>
<$list filter='[[$:/data/Change Log]indexes[]]' variable=ThisEntry>
<<thisDisplayChangeLogEntry>><br>
</$list>
</$reveal>
<div class="family-tree" >
*[[Rechtsgrundlage]] - Variable
**[[Art]] -Fields
***[[Form]]
****[[Inhalt]]- oder Voraussetzungen
*****[[Verletzungen]] - Verstoß
******[[Ausschluss]] - Einreden
</div>
;Rechtsgrundlage Gesetz
:{{!!RGL_Gesetz}}
;Rechtsgrundlage Artikel
:{{!!RGL_Artikel}}
;Rechtsfolge
:{{!!rechtsfolge}}
\define fhere()
<table class="tc-view-field-table">
<tbody>
<$list filter="[all[current]fields[gesetz] +[parent]sort[title]] -text -tags -title" template="$:/core/ui/TiddlerFieldTemplate" variable="listItem"/>
</tbody>
</table>
\end
<$list filter="[all[current]tagging[]tagging[]sort[title]]" variable="item">
<$tiddler tiddler=<<item>>>
<h3><$link><$view field=title/></$link></h3>
</$tiddler>
<blockquote><b><<currentTiddler>>:</b>
<$list filter="[<item>tags[]] +[tag<currentTiddler>]">
<$link><$view field=title/></$link>
</$list>
</blockquote>
</$list>
<dl class="overview">
<<list-search
"[all[]tagging[]!sort[modified]]"
"search"
"$:/temp/list-search-list-examples"
"$:/.tb/template/list-examples"
placeholder:"Ergebnisse einschränken..." >>
</dl>
{{|Test Macro fhere(fhere)}}
AddNote some text und http://tiddlersidebar.tiddlyspot.com/
<$list filter="[all[current]get[parent]]" variable=parent>
<$list filter="[<parent>get[parent]]" variable=grand-parent>
<$list filter="[<grand-parent>get[parent]]" variable=great-grand-parent>
The current Tiddler is <<currentTiddler>>, its parent is <<parent>>, its grand-parent is <<grand-parent>> its great-grand-parent is <<great-grand-parent>><br>
</$list>
</$list>
</$list>
<<newTid param:"$(currentTiddler)$">>
<$tiddler tiddler=Referenzxlist>
<<xlist filter:"[[Anwendungsbereich]tagging[]]-[!tag[sort]]">>
</$tiddler>
<$list filter=<<NotExistedMacro>> >
</$list>
A TextReference is a general purpose way to describe a fragment of text as either a field of a tiddler, or an index within a [[data tiddler|DataTiddlers]].
In different situations, text references can be used to retrieve values, or to specify a value that should be modified.
A TextReference consists of several parts:
* The title of the target tiddler. If omitted, it defaults to the [[Current Tiddler]]
* Either one of:
** The name of a field (marked with `!!`)
** The name of an index within a [[data tiddler|DataTiddlers]] (marked with `##`)
* If both the field and index are omitted, the text field is used as the default
Most of the parts of a text reference can be optional:
* `tiddlerTitle` - the text [[field|TiddlerFields]] of the specified tiddler
* `tiddlerTitle!!field` - a [[tiddler field|TiddlerFields]] (eg, `modified`, `modifier`, `type` etc)
* `!!field` - a [[field|TiddlerFields]] of the current tiddler
* `tiddlerTitle##propertyIndex` - extracts a named property from DataTiddlers
Text references can be used in several places:
* As [[indirect parameters|Filter Parameter]] within [[Filters]] (eg, `<$list filter="[tag{MyTag!!name}]"/>`)
* As [[indirect attributes|HTML in WikiText]] of an element or widget (eg, `<$widget attrib={{Title!!description}}/>`)
* As the operand of a shortcut transclusion (eg, `{{MyTiddler!!title}}`)
* As the `state` attribute of the RevealWidget and the LinkCatcherWidget
<$macrocall $name=".tip" _="""Note the distinction between a text reference such as `foo!!bar` and a transclusion of a text reference such as `{{foo!!bar}}`"""/>
@@border:1px solid crimson;padding:7px 15px;float:right;margin:0;
[[Version 0.8.4|TextStretch Versions]]
@@
!! ''Make text short and expandable''
The ''TextStretch'' macro is a great tool <<strex "for you as an author of hypertext">> to keep the message short. Your readers can discover more details easily.
{{TextStretch Tweet}}
!! Features and Syntax
''Compact and powerful.'' Want to hide some content? `<<strex magic>>` will stretch it out when the dots are clicked: <<strex magic>>. Use presets for simplicity or define your own styles and flavors. Tell stories using complex [[nested structures|TextStretch Transclusion Examples]] and transclusion.
!!! Full Syntax
`<<strex "content" "label" "start" "end" "class" "id">>`
Try it: <<strex "content" "label" "start" "end" "class" "id">>
!!! Default Values
The first line of the [[macro|$:/_telmiger/strex]] reads
```
\define strex(content:"TextStretch", label:"…", start:"[", end:"]", class:"", id="_false_")
```
If you prefer other <<strex """''presets:'' you can see the default values above, enclosed in "quotation marks" """ presets>>, I recommend to call strex from your own macro or adapt your copy of the `<<ref>>` shorthand in [[$:/_telmiger/ref]].<<ref "''ref'' could be your within-tiddler-reference standard. If you use this shorthand only, you can change your configuration in one single place anytime. You could even switch the ’motor‘ if you find a better macro than strex in the future.">><<ref "For more information on ''ref'' see [[TextStretch Variant Footnote]].">>
!! Parameters
Use quotation marks, if your parameter contains whitespace <<strex "e.g. "your text" or 'long label'">>. If you want to use the default value, you write "" or nothing.
; content
: Text you want to hide – you can use <<strex {{!!example-1}} transclusion>> and HTML <<strex "~HyperText Markup Language can help you to display <ul><li>characters like "</li><li>lists</li><li>other elements …</li></ul>that otherwise are difficult to transclude." "(?)" "x" "?" "hint">>
; label
: Text on the button that <<strex "disappears after opening" opens>> the element.
; start //and// end
: Texts on the buttons which close the element <<strex "and are placed at the beginning/end of the //content//" … ^ $>>.
; class
: Classes can be appended here. There are [[examples|TextStretch Examples]] for predefined classes.
; id
: Control the activation of TextStretch elements defined in the same tiddler.<<strex "(hidden)" * * "" "nocontent noend" "id_1">> Elements with identical //id// open and close <<strex "at the same time" together "" "" "" "id_2">> which can be useful <<strex "or funny in rare cases." "…" "" "" "" "id_2">> Elements with identical //content// open together too. You can separate them using unique id’s. <<strex "An element that was transcluded or which is displayed in another open tiddler, will ''always'' open and close independently. Even if it has the same id. The reason is TiddlyWiki’s ''state handling:'' we use the standard [[qualify macro|http://tiddlywiki.com/#qualify%20Macro]] here." " * " "*" "close *" "blockinner" "id_1">>
!! Installation
Backup your TiddliWiki <<strex "Version 5.1.9 or higher as it needs the VarsWidget that came with 5.1.9" "(5.1.9 +)" "x" "5.1.9 +" "hint">>. Drag the links from the following list to your Wiki, import, save and ''reload''.
* macro: $:/_telmiger/strex
* shorthand macro: $:/_telmiger/ref
* styling: $:/_telmiger/strex.css
* macro for hashing: $:/_telmiger/utils/HashStr.js
Drag the link TextStretch over too, if you want to keep <<strex "or improve a copy of" (…) ( )>> these explanations. Have fun!
New [[TextStretch Versions]] might be published on: http://tid.li/tw5/hacks.html#TextStretch
!! Inspiration
This [[thread in the TiddliWiki Google Group|https://groups.google.com/d/msg/tiddlywiki/biymRJTDWxY/5Vh-PxYvAQAJ]] was the ignition which made me develop my own version of a tool similar to
* http://stretchtext.tiddlyspot.com/ or
* http://www.telescopictext.com/
<<strex {{!!example-2}}>> My initial goal was to detect [text], show only […] and expand on click. I was not able to master the detection part, but I think the result is much better anyway.
!!! Thank You
I am very greatful for Mat <<strex "from [[twaddle.tiddlyspot.com|http://twaddle.tiddlyspot.com/]], who appears in the Google group as the smiling man with the hat," "<:-)" "(-:>" "<:-)">> – his example [[StretchText|http://stretchtext.tiddlyspot.com/]] showed me how something like TextStretch can be done.
At the same time I would like to thank all other members of the friendly TiddlyWiki community for <<strex "their contributions to not only the aforementioned thread, but also many, many other">>inspiring examples, tips and tricks they share. Thank you all!
{{DWYWBDBM-Licence}}
!Scenes
Drag the scenes on the right side of the wiki to this draggable zone (under this text):
<$vars actual=<<currentTiddler>> >
<$macrocall $name="list-tagged-draggable" tag=<<currentTiddler>> itemTemplate="scene_template"/>
</$vars>
To delete a scene to this story unckeck the ckeckbox.
Ein Thesaurus wird in der DIN 1463 folgendermaßen definiert:
//Ein Thesaurus im Bereich der Information und Dokumentation ist eine
geordnete Zusammenstellung von Begriffen und ihren (vorwiegend natürlichsprachigen)
Bezeichnungen, die in einem Dokumentationsgebiet zum
Indexieren, Speichern und Wiederauffinden dient.//
Er ist durch folgende Merkmale gekennzeichnet:
a) Begriffe und Bezeichnungen werden eindeutig aufeinander bezogen
(„terminologische Kontrolle“), indem
- Synonyme möglichst vollständig erfasst werden,
- Homonyme und Polyseme besonders gekennzeichnet werden,
- für jeden Begriff eine Bezeichnung (Vorzugsbenennung, Begriffsnummer
oder Notation) festgelegt wird, die den Begriff eindeutig vertritt,
b) Beziehungen zwischen den Begriffen (repräsentiert durch ihre Bezeichnungen)
werden dargestellt.“
''Juristische Verwendung''
Alias und Synomyme (Laiensspähre) und letztlich auch Abgrenzungen
''Anwendungen''
''uni-link Plugin'' und ''Alias Plugin''
Arbeitgeber
Arbeitnehmer
Arbeitnehmerschutz
Arbeitsgericht
Arbeitskampf
Arbeitsvergütung
Arbeitsverhältnis
Arbeitsverhältnisbegründung
Arbeitsvertrag
Betrieb
Betriebliche Altersversorgung
Betriebsverfassung
Datenschutz
Europäisches Arbeitsrecht
Freier Mitarbeiter
Insolvenz
Kündigung
Mitbestimmung
Sozialrecht
Tarifvertrag
Unternehmen
Verband
Öffentlicher Dienst
Type the text for the [[Internal link demo]]tiddler 'Third Right'
!!Step 1 - ''Give the tiddler a name''
---
Name of the information
<$edit-text class='tc-edit-texteditor' tiddler='$:/state/NewTiddlerForm' field='name_temp' placeholder='Tiddler Name'/><br>
!!Step 2 - ''Caption''
---
A little bit of text or details ....
<$edit-text class='tc-edit-texteditor' tiddler='$:/state/NewTiddlerForm' field='caption' placeholder='Tiddler Text'/><br>
!!Step 3 the Information - ''Gesetz''
----
Remember to put it between double dollar signs e.g.:
<$edit-text class='tc-edit-texteditor' tiddler='$:/state/NewTiddlerForm' field='gesetz' placeholder='Gesetz'/><br>
---
!!Step 4 - ''Add a tag or tags to the tiddler'' (optional)
---
Tags are used for the table of contents, so it may be advisable to add tags to new tiddlers. For example, if you wanted to add a tiddler that would be displayed under 'Tools' in the table of contents you would add the 'Tools' tag to the tiddler.
<$select tiddler='$:/state/NewTiddlerForm' field='add_or_create_tag'>
<option value='existing'>Add existing tag</option>
<option value='create'>Add a new tag</option>
</$select>
<$reveal type=match state='$:/state/NewTiddlerForm!!add_or_create_tag' text='create'>
New Tag Name: <$edit-text tiddler='$:/state/NewTiddlerForm' field='tag_temp' placeholder='New Tag'/><$fieldmangler tiddler='$:/state/NewTiddlerForm'>
<$button>
<$action-sendmessage $message='tm-add-tag' $param={{$:/state/NewTiddlerForm!!tag_temp}}/>
<$action-setfield $tiddler='$:/state/NewTiddlerForm' $field='tag_temp' $value=''/>Add Tag
</$button>
</$fieldmangler><br>
</$reveal>
<$reveal type='match' state='$:/state/NewTiddlerForm!!add_or_create_tag' text='existing'>
Tag to add: <$select tiddler='$:/state/NewTiddlerForm' field='tag_temp'>
<$list filter='[tags[]sort[title]]'>
<option><$view field='title'/></option>
</$list>
</$select>
<$fieldmangler tiddler='$:/state/NewTiddlerForm'>
<$button>
<$action-sendmessage $message='tm-add-tag' $param={{$:/state/NewTiddlerForm!!tag_temp}}/>Add Tag
</$button>
</$fieldmangler>
<br>
</$reveal>
List of current tags:<br>
<$fieldmangler tiddler='$:/state/NewTiddlerForm'>
<$set name=tiddlerEditing value='$:/state/NewTiddlerForm'>
<$list filter='[[$:/state/NewTiddlerForm]tags[]]'><$view field='title'/> <$button>Remove Tag<$action-sendmessage $message='tm-remove-tag' $param=<<currentTiddler>>/></$button><br> </$list>
</$set>
</$fieldmangler>
!!Step 5 - ''Create the tiddler''
---
Press this button and the tiddler will be created and opened so you can view it.
<$button>Create Tiddler
<$action-setfield $tiddler={{$:/state/NewTiddlerForm!!name_temp}} text={{$:/state/NewTiddlerForm!!text}} caption={{$:/state/NewTiddlerForm!!caption}} gesetz={{$:/state/NewTiddlerForm!!gesetz}} tags={{$:/state/NewTiddlerForm!!tags}}/>
<$action-navigate $to={{$:/state/NewTiddlerForm!!name_temp}}/>
<$action-setfield $tiddler='$:/state/NewTiddlerForm' name_temp='' text='' description='' gesetz='' tags=''/>
</$button>
<$button>Clear Form
<$action-setfield $tiddler='$:/state/NewTiddlerForm' name_temp='' text='' description='' gesetz='' tags=''/>
</$button>
[
{
"created": "20180803003552614",
"text": "{{$:/PSaT/newTiddler/info}}\n",
"title": "$:/PSaT/newTiddler",
"temp-tiddler-template": "$:/New order/template",
"modified": "20180812071235116",
"icon": "$:/PSaT/newTiddler/icon.svg",
"description": "Create new tiddlers by cloning those with a tiddler-template-caption field (on Current Tiddler)",
"caption": "NewTiddler from Template"
},
{
"created": "20180803034422051",
"text": "\\define is-template()\n<$list filter=\"[is[current]has:field[tiddler-template-caption]]\" variable=null emptyMessage=\"no\">yes</$list>\n\\end\n\\define no-template()\n<$button set=\"!!tiddler-template-caption\" setTo={{!!title}} class=\"tc-btn-invisible\" tooltip=\"Click to flag as a template tiddler\" aria-label=\"Use as a template tiddler\" description=\"Toggle a tiddler as a template tiddler\">\n{{$:/PSaT/newTiddler/icon.svg}}\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\">\n<$text text=\" \"/>\nToggle tiddler as a Template\n</span>\n</$list>\n</$button>\n\\end\n\\define has-template()\n<$fieldmangler>\n<$button message=\"tm-remove-field\" param=\"tiddler-template-caption\" class=\"tc-btn-invisible\" tooltip=\"Click to un-flag as a template tiddler\" aria-label=\"No longer a template a template tiddler\">\n{{$:/PSaT/newTiddler/template-yes.svg}}\n<$list filter=\"[<tv-config-toolbar-text>prefix[yes]]\">\n<span class=\"tc-btn-text\">\n<$text text=\" \"/>\nToggle tiddler as a not a Template\n</span>\n</$list>\n</$button>\n</$fieldmangler>\n\\end\n<$list filter=\"[is[current]has:field[tiddler-template-caption]]\" variable=null emptyMessage=<<no-template>> >\n<<has-template>>\n</$list>",
"title": "$:/PSaT/newTiddler/Buttons/template-toggle",
"tags": "$:/tags/ViewToolbar",
"modified": "20180812071046341",
"description": "Toggle a tiddler as a template tiddler",
"caption": "{{$:/PSaT/newTiddler/icon.svg}} Tiddler Template"
},
{
"text": "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\n<svg width=\"16px\" height=\"16px\" viewBox=\"0 0 16 16\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n <defs></defs>\n <g stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n <g stroke=\"#4A4A4A\">\n <rect x=\"0\" y=\"5\" width=\"11\" height=\"11\"></rect>\n <rect x=\"5\" y=\"0\" width=\"11\" height=\"11\"></rect>\n <path d=\"M1.5,6.5 L9.5,6.5\" stroke-linecap=\"square\"></path>\n <path d=\"M6.5,1.5 L14.5,1.5\" stroke-linecap=\"square\"></path>\n </g>\n </g>\n</svg>",
"type": "image/svg+xml",
"title": "$:/PSaT/newTiddler/icon.svg",
"modified": "20180803052358159",
"created": "20180803033035777"
},
{
"created": "20180803025023118",
"text": "!!!Quick instructions\n;Create a template\n*Use any tiddler you wish as a template. \n**Tags, Fields, and text will be copied to the new tiddlers\n**Name it how you would like it to appear for new tiddlers \n:eg; \"New Task\" will result in \"New Task N\"\n*You do not need to flag a tiddler as a template, if you ''Create tiddlers from a template elsewhere''<br>using either\n** `<<clone-tiddler [tiddlername]>>` the tiddler need not contain and instance-of field. Default current Tiddler\n** `<<new-template-instance [tiddlername]>>` the tiddler must contain and \"instance-of\" field. Default current Tiddler\n\n;To add a template to the List of templates\n*From the View Template toolbar click {{$:/PSaT/newTiddler/icon.svg}} to flag the tiddler as a template.<br>Tiddlers acting as templates will be indicated with {{$:/PSaT/newTiddler/template-yes.svg}}<br> Alternately create a ''tiddler-template-caption'' field in your template tiddler.\n\n;Use a template to create new tiddlers from the ~SideBar \"New\" tab\n*In the sidebar tab \"New\" you can select from the available template tiddlers and click {{$:/PSaT/newTiddler/icon.svg}} to copy the template to a new tiddler.\n*{{$:/core/images/info-button}} will display the description on the selected \"templateTiddler/template\" tiddler. \n*{{$:/core/images/options-button}} will open the selected template tiddler.\n*You can hide the sideBar new tab with the checkbox therein or here <$checkbox tiddler=\"$:/PSaT/newTiddler/sideBar\" tag=\"$:/tags/SideBar\"> Show New Tiddler tab in ~SideBar?</$checkbox>\n*You can use the following macro in any tiddler to access the templates dropdown <<newTiddlerSelect>>\n```\n<<newTiddlerSelect>>\n```\n\n<details><summary>The following macros are defined in this solution</summary>\n\n<table style=\"width:100%\">\n<tr>\n<th style=\"width:20%\">Macro</th>\n<th>Description</th>\n<th>Defined in</th>\n</tr>\n<$list filter=\"[prefix[$:/PSaT/newTiddler]]\" variable=\"NewTiddler-tiddler\">\n<$list filter=\"[<NewTiddler-tiddler>fields[]prefix[macro-]sort[]]\" variable=\"macrofield\">\n<$list filter=\"[<macrofield>removeprefix[macro-]]\" variable=\"macroname\">\n<tr>\n<td><<macroname>></td><td><$view tiddler=<<NewTiddler-tiddler>> field=<<macrofield>>/></td><td><<NewTiddler-tiddler>></td>\n</tr>\n</$list>\n</$list>\n</$list>\n</table>\n</details>\n<details><summary>This tool Includes the following tiddlers</summary>\n<$list filter=\"[prefix[$:/PSaT/newTiddler]]\">\n\n</$list>\n</details>",
"title": "$:/PSaT/newTiddler/info",
"tags": "",
"modified": "20180812063057898",
"icon": "$:/PSaT/newTiddler/icon.svg"
},
{
"created": "20180803025920121",
"text": "\\define newTiddlerSelect()\n<$select tiddler=\"$:/PSaT/newTiddler\" field=\"temp-tiddler-template\">\n<$list filter='[all[]has:field[tiddler-template-caption]sort[]]'>\n<option value=<<currentTiddler>>><<tiddler-template-caption-then-title>></option>\n</$list>\n</$select>\n<$list filter=\"[{$:/PSaT/newTiddler!!temp-tiddler-template}]\">\n<<new-template-instance>> \n<$wikify name=tooltip text=\"New tiddler from template {{!!description}}\">\n<$button tooltip=<<tooltip>> class=\"tc-btn-invisible\">\n{{$:/core/images/info-button}}\n</$button>\n</$wikify>\n<$button tooltip=\"Open template tiddler\" class=\"tc-btn-invisible\" to=<<currentTiddler>> >\n{{$:/core/images/options-button}}\n</$button>\n<$button tooltip=\"Icon on these tiddlers\" class=\"tc-btn-invisible\">\n<$transclude tiddler={{!!icon}}/>\n</$button>\n</$list>\n\\end\n\\define tiddler-template-caption-then-title(tiddlername)\n<$set name=tiddlername value=\"$tiddlername$\" emptyValue=\"$(currentTiddler)$\">\n<$tiddler tiddler=<<tiddlername>> >\n<$set name=display value={{!!tiddler-template-caption}} emptyValue={{!!title}}>\n<<display>></$set>\n</$tiddler>\n</$set>\n\\end\n\\define fieldname-value() <$text text=\"\"\"$(fieldname-value-temp)$\"\"\"/>\n\\define fieldsvalues()\n<$list filter=\"[all[current]fields[]] -[[tiddler-template-caption]] -[[text]] -[[title]] -[[created]] -[[modified]] -[[tiddler-template-caption]]\" variable=\"field\"><$set name=\"fieldname-value-temp\" tiddler=<<currentTiddler>> field=<<field>> emptyValue=\"\"><<field>>=\"<<fieldname-value>>\" </$set> </$list>\n\\end\n\\define clone-current-actions() \n<$action-createtiddler $basetitle={{!!title}} $savetitle=\"$:/temp/clone-current-title\" $(attribs)$ text={{!!text}} />\n<$action-sendmessage $message=\"tm-edit-tiddler\" $param={{$:/temp/clone-current-title}}/>\n\\end\n\\define clone-template-actions() \n<$action-createtiddler $basetitle={{!!instance-of}} $savetitle=\"$:/temp/clone-template-title\" $(attribs)$ text={{!!text}} />\n<$action-sendmessage $message=\"tm-edit-tiddler\" $param={{$:/temp/clone-template-title}}/>\n\\end\n\\define clone-tiddler(tiddlername)\n<$set name=tiddlername value=\"$tiddlername$\" emptyValue=<<currentTiddler>> >\n<$tiddler tiddler=<<tiddlername>> >\n<$wikify name=\"attribs\" text=<<fieldsvalues>> >\n<$button actions=<<clone-current-actions>>class=<<tv-config-toolbar-class>> tooltip=\"Clone tiddler\">{{$:/PSaT/newTiddler/icon.svg}}\n</$button>\n</$wikify>\n</$tiddler>\n</$set>\n\\end\n\\define new-template-instance(tiddlername)\n<$set name=tiddlername value=\"$tiddlername$\" emptyValue=<<currentTiddler>> >\n<$tiddler tiddler=<<tiddlername>> >\n<$wikify name=\"attribs\" text=<<fieldsvalues>> >\n<$button actions=<<clone-template-actions>> class=<<tv-config-toolbar-class>> tooltip=\"New instance of template tiddler\">{{$:/PSaT/newTiddler/icon.svg}}\n</$button>\n</$wikify>\n</$tiddler>\n</$set>\n\\end",
"title": "$:/PSaT/newTiddler/macros",
"tags": "$:/tags/Macro",
"modified": "20180812063036857",
"macro-newtiddlerselect": "<<newTiddlerSelect>> to create new tiddlers from templates that have a tiddler-template-caption field",
"icon": "$:/PSaT/newTiddler/icon.svg",
"macro-new-template-instance": "<<new-template-instance [templatename]>> the template tiddler must contain and \"instance-of\" field with the New Tiddler title.",
"macro-clone-tiddler": "<<clone-tiddler [tiddlername]>> Clone tiddlername or current tiddler (except selected fields) will use the tiddlername",
"macro-fieldsvalues": "<<fieldsvalues>> lists all fields (except selected fields) on the current tiddlerand their contents in the form fieldname=\"value\""
},
{
"created": "20180811044829152",
"text": "[[New Tiddler from Template|$:/PSaT/newTiddler/info]]<br><br>\n<<newTiddlerSelect>><br>\n<small>\n//Create a new tiddler from tiddlers that have a tiddler-template-caption field//</small>\n <$button tooltip=\"Learn more about the new Tiddler macros\" to=\"$:/PSaT/newTiddler/info\" class=<<tv-config-toolbar-class>> >more...{{$:/core/images/info-button}}</$button>\n\n\nDefault ~NewTiddlers: {{$:/core/ui/Buttons/new-tiddler}} {{$:/core/ui/Buttons/new-journal}} {{$:/core/ui/Buttons/new-image}}\n\n<$checkbox tiddler=\"$:/PSaT/newTiddler/sideBar\" tag=\"$:/tags/SideBar\"> ~SideBar Tab?</$checkbox>\n",
"title": "$:/PSaT/newTiddler/sideBar",
"tags": "$:/tags/SideBar",
"modified": "20180812063205135",
"caption": "New"
},
{
"text": "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\n<svg\n xmlns:dc=\"http://purl.org/dc/elements/1.1/\"\n xmlns:cc=\"http://creativecommons.org/ns#\"\n xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\"\n xmlns:svg=\"http://www.w3.org/2000/svg\"\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlns:sodipodi=\"http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd\"\n xmlns:inkscape=\"http://www.inkscape.org/namespaces/inkscape\"\n width=\"16px\"\n height=\"16px\"\n viewBox=\"0 0 16 16\"\n version=\"1.1\"\n id=\"svg16\"\n sodipodi:docname=\"template-yes.svg\"\n inkscape:version=\"0.92.2 (5c3e80d, 2017-08-06)\">\n <metadata\n id=\"metadata20\">\n <rdf:RDF>\n <cc:Work\n rdf:about=\"\">\n <dc:format>image/svg+xml</dc:format>\n <dc:type\n rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\" />\n <dc:title></dc:title>\n </cc:Work>\n </rdf:RDF>\n </metadata>\n <sodipodi:namedview\n pagecolor=\"#ffffff\"\n bordercolor=\"#666666\"\n borderopacity=\"1\"\n objecttolerance=\"10\"\n gridtolerance=\"10\"\n guidetolerance=\"10\"\n inkscape:pageopacity=\"0\"\n inkscape:pageshadow=\"2\"\n inkscape:window-width=\"2400\"\n inkscape:window-height=\"1471\"\n id=\"namedview18\"\n showgrid=\"false\"\n inkscape:zoom=\"14.75\"\n inkscape:cx=\"8\"\n inkscape:cy=\"32.40678\"\n inkscape:window-x=\"-9\"\n inkscape:window-y=\"-9\"\n inkscape:window-maximized=\"1\"\n inkscape:current-layer=\"svg16\" />\n <defs\n id=\"defs2\" />\n <g\n stroke=\"none\"\n stroke-width=\"1\"\n fill=\"none\"\n fill-rule=\"evenodd\"\n id=\"g14\">\n <g\n stroke=\"#4A4A4A\"\n id=\"g12\">\n <rect\n x=\"0\"\n y=\"5\"\n width=\"11\"\n height=\"11\"\n id=\"rect4\" />\n <rect\n x=\"5\"\n y=\"0\"\n width=\"11\"\n height=\"11\"\n id=\"rect6\" />\n <path\n d=\"M1.5,6.5 L9.5,6.5\"\n stroke-linecap=\"square\"\n id=\"path8\" />\n <path\n d=\"M6.5,1.5 L14.5,1.5\"\n stroke-linecap=\"square\"\n id=\"path10\" />\n </g>\n </g>\n <text\n xml:space=\"preserve\"\n style=\"font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:33.33333206px;line-height:4.25;font-family:'MS UI Gothic';-inkscape-font-specification:'MS UI Gothic, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;text-align:start;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none\"\n x=\"-35.59322\"\n y=\"-29.491526\"\n id=\"text829\"><tspan\n sodipodi:role=\"line\"\n id=\"tspan827\"\n x=\"-35.59322\"\n y=\"-29.491526\">+</tspan></text>\n <text\n xml:space=\"preserve\"\n style=\"font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:12.11584663px;line-height:4.25;font-family:'MS UI Gothic';-inkscape-font-specification:'MS UI Gothic, Normal';font-variant-ligatures:normal;font-variant-caps:normal;font-variant-numeric:normal;text-align:start;letter-spacing:0px;word-spacing:0px;writing-mode:lr-tb;text-anchor:start;fill:#00ff00;fill-opacity:1;stroke:none;stroke-width:0.36347541\"\n x=\"-0.84113294\"\n y=\"14.778245\"\n id=\"text833\"\n transform=\"scale(0.97094505,1.0299244)\"><tspan\n sodipodi:role=\"line\"\n id=\"tspan831\"\n x=\"-0.84113294\"\n y=\"14.778245\"\n style=\"stroke-width:0.36347541\">✓</tspan></text>\n</svg>\n",
"type": "image/svg+xml",
"title": "$:/PSaT/newTiddler/template-yes.svg",
"modified": "20180803062812440",
"created": "20180803053123545"
},
{
"created": "20180812053250204",
"text": "",
"modified": "20180812053744430",
"title": "$:/PSaT/newTiddler/Tiddler Template",
"instance-of": "Tiddler Template",
"tiddler-source": "reference $:/PSaT/newTiddler",
"tiddler-template-caption": "New Tiddler Template",
"note": "Please add a tiddler-template-caption field with \"new templatename\" to this tiddler if you want it to apear in the new tiddler from template dropdown",
"tags": ""
},
{
"created": "20180812055250366",
"title": "$:/PSaT/newTiddler/more-2.svg",
"type": "image/svg+xml",
"text": "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\n<!-- Generator: Adobe Illustrator 19.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->\n\n<svg\n xmlns:dc=\"http://purl.org/dc/elements/1.1/\"\n xmlns:cc=\"http://creativecommons.org/ns#\"\n xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\"\n xmlns:svg=\"http://www.w3.org/2000/svg\"\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlns:sodipodi=\"http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd\"\n xmlns:inkscape=\"http://www.inkscape.org/namespaces/inkscape\"\n version=\"1.1\"\n id=\"Capa_1\"\n x=\"0px\"\n y=\"0px\"\n viewBox=\"0 0 640 300\"\n xml:space=\"preserve\"\n sodipodi:docname=\"more-2.svg\"\n width=\"32\"\n height=\"15\"\n inkscape:version=\"0.92.2 (5c3e80d, 2017-08-06)\"><metadata\n id=\"metadata12988\"><rdf:RDF><cc:Work\n rdf:about=\"\"><dc:format>image/svg+xml</dc:format><dc:type\n rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\" /><dc:title></dc:title></cc:Work></rdf:RDF></metadata><defs\n id=\"defs12986\" /><sodipodi:namedview\n pagecolor=\"#ffffff\"\n bordercolor=\"#666666\"\n borderopacity=\"1\"\n objecttolerance=\"10\"\n gridtolerance=\"10\"\n guidetolerance=\"10\"\n inkscape:pageopacity=\"0\"\n inkscape:pageshadow=\"2\"\n inkscape:window-width=\"2400\"\n inkscape:window-height=\"1471\"\n id=\"namedview12984\"\n showgrid=\"false\"\n inkscape:zoom=\"1.3906433\"\n inkscape:cx=\"320.12813\"\n inkscape:cy=\"67.50976\"\n inkscape:window-x=\"-9\"\n inkscape:window-y=\"-9\"\n inkscape:window-maximized=\"1\"\n inkscape:current-layer=\"g17490\" /><g\n id=\"g17490\"><g\n id=\"g17501\"\n transform=\"matrix(10.524993,0,0,9.8129651,4.0078418,-2497.7912)\"><circle\n style=\"fill:#7383bf\"\n cx=\"42\"\n cy=\"270\"\n r=\"3\"\n id=\"circle12943\" /><g\n id=\"g17479\"><line\n id=\"line12947\"\n y2=\"284\"\n x2=\"15\"\n y1=\"270\"\n x1=\"1\"\n style=\"fill:none;stroke:#556080;stroke-width:2;stroke-linecap:round;stroke-miterlimit:10\" /><g\n id=\"g17470\"><circle\n style=\"fill:#7383bf\"\n cx=\"18\"\n cy=\"270\"\n r=\"3\"\n id=\"circle12939\" /><circle\n style=\"fill:#7383bf\"\n cx=\"30\"\n cy=\"270\"\n r=\"3\"\n id=\"circle12941\" /><line\n style=\"fill:none;stroke:#556080;stroke-width:2;stroke-linecap:round;stroke-miterlimit:10\"\n x1=\"1\"\n y1=\"270\"\n x2=\"15\"\n y2=\"256\"\n id=\"line12945\" /><line\n style=\"fill:none;stroke:#556080;stroke-width:2;stroke-linecap:round;stroke-miterlimit:10\"\n x1=\"59\"\n y1=\"270\"\n x2=\"45\"\n y2=\"284\"\n id=\"line12949\" /><line\n style=\"fill:none;stroke:#556080;stroke-width:2;stroke-linecap:round;stroke-miterlimit:10\"\n x1=\"59\"\n y1=\"270\"\n x2=\"45\"\n y2=\"256\"\n id=\"line12951\" /></g></g></g></g><g\n id=\"g12953\"\n transform=\"translate(0,240)\" /><g\n id=\"g12955\"\n transform=\"translate(0,240)\" /><g\n id=\"g12957\"\n transform=\"translate(0,240)\" /><g\n id=\"g12959\"\n transform=\"translate(0,240)\" /><g\n id=\"g12961\"\n transform=\"translate(0,240)\" /><g\n id=\"g12963\"\n transform=\"translate(0,240)\" /><g\n id=\"g12965\"\n transform=\"translate(0,240)\" /><g\n id=\"g12967\"\n transform=\"translate(0,240)\" /><g\n id=\"g12969\"\n transform=\"translate(0,240)\" /><g\n id=\"g12971\"\n transform=\"translate(0,240)\" /><g\n id=\"g12973\"\n transform=\"translate(0,240)\" /><g\n id=\"g12975\"\n transform=\"translate(0,240)\" /><g\n id=\"g12977\"\n transform=\"translate(0,240)\" /><g\n id=\"g12979\"\n transform=\"translate(0,240)\" /><g\n id=\"g12981\"\n transform=\"translate(0,240)\" /></svg>",
"modified": "20180812055720484"
},
{
"created": "20180812071915764",
"text": "hide",
"title": "$:/config/ViewToolbarButtons/Visibility/$:/PSaT/newTiddler/Buttons/template-toggle",
"tags": "",
"modified": "20180812072258937"
}
]
Lists all node commands and opens the help tiddlers as sticky popups rendered into the global popup handler so as to not cut the popups off at the right tiddler margin:
```
; Node Commands
: <$list filter="[all[shadows]prefix[$:/language/Help]sort[title]]">
<$appear
type="popup"
class="tc-popup-keep max800"
show="""<$list filter"[all[current]removeprefix[$:/language/Help/]]">{{!!title}}</$list>""">
<$transclude mode="block"/>
</$appear>
</$list><style>.max800 {max-width:800px;}</style>
```
<<<
; Node Commands
: <$list filter="[all[shadows]prefix[$:/language/Help]sort[title]]">
<$appear
type="popup"
handler="popups"
class="tc-popup-keep max600"
show="""<$set name="title" filter="[all[current]removeprefix[$:/language/Help/]]"><<title>></$set>""">
<$transclude mode="block"/>
</$appear>
</$list><style>.max600 {max-width:600px;}</style>
<<<
Implements custom arrows with a helper macro, wrapped using the <<x TiddlerWidget>> to set a different context:
```
\define slider-label(prefix,suffix)
@@.grey-svg $prefix$<$text text="$(currentTiddler)$"/>$suffix$@@
\end
```
<$macrocall $name=`
text="""<$tiddler tiddler="GettingStarted">
<$appear
show=<<slider-label "" " {{$:/core/images/chevron-right}}">>
hide=<<slider-label "" " {{$:/core/images/chevron-down}}">>
$state="tiddler-widget-slider">
<$transclude mode="block"/>
</$tiddler>"""/>
\define lingo-base() $:/language/Docs/Fields/
TiddlerFields are name:value pairs that make up a [[tiddler|Tiddlers]]. Field names must be lowercase letters, digits or the characters `-` (dash), `_` (underscore) and `.` (period).
The standard fields are:
|!Field Name |!Reference |!Description |
|`title` |TitleField |<<lingo title>> |
|`text` |TextField |<<lingo text>> |
|`modified` |ModifiedField |<<lingo modified>> |
|`modifier` |ModifierField |<<lingo modifier>> |
|`created` |CreatedField |<<lingo created>> |
|`creator` |CreatorField |<<lingo creator>> |
|`tags` |TagsField |<<lingo tags>> |
|`type` |TypeField |<<lingo type>> |
|`list` |ListField |<<lingo list>> |
|`caption` |CaptionField |<<lingo caption>> |
Other fields used by the core are:
|!Field Name |!Reference |!Description |
|`class` |ClassField |<<lingo class>> |
|`color` |ColorField |<<lingo color>> |
|`description` |DescriptionField |<<lingo description>> |
|`draft.of` |DraftOfField |<<lingo draft.of>> |
|`draft.title` |DraftTitleField |<<lingo draft.title>> |
|`footer` |FooterField |<<lingo footer>> |
|`icon` |IconField |<<lingo icon>> |
|`library` |LibraryField |<<lingo library>> |
|`list-after` |ListAfterField |<<lingo list-after>> |
|`list-before` |ListBeforeField |<<lingo list-before>> |
|`name` |NameField |<<lingo name>> |
|`plugin-priority` |PluginPriorityField |<<lingo plugin-priority>> |
|`plugin-type` |PluginTypeField |<<lingo plugin-type>> |
|`source` |SourceField |<<lingo source>> |
|`subtitle` |SubtitleField |<<lingo subtitle>> |
The TiddlyWebAdaptor uses a few more fields:
|!Field Name |!Reference |!Description |
|`bag` |BagField |<<lingo bag>> |
|`revision` |RevisionField |<<lingo revision>> |
See the ''Advanced > Tiddler Fields'' tab of the [[control panel|$:/ControlPanel]] {{$:/core/images/options-button}} for details of the fields used in this wiki.
Links are regions of a tiddler that can be clicked to cause navigation to a different tiddler. The navigation behaviour is determined by the current StoryView; the classic TiddlyWiki view displays the story as a linear sequence of tiddlers.
Holding the ''control'' or ''command'' key while clicking on a tiddler link opens the target tiddler but doesn't navigate to it. This can be a useful way of queueing up tiddlers to be read later.
Links are useful for modelling organic relationships between tiddlers, and particularly for expressing the navigational paths between tiddlers.
The InfoPanel lists incoming links to a tiddler in the tab ''References''.
[[Filters]] can include the following filter operators that work with links:
* `[links[]]` - returns the titles of the tiddlers that are linked from the currently selected tiddler(s)
* `[backlinks[]]` - returns the titles of the tiddlers that link to the currently selected tiddler(s)
TiddlyWiki5 alters the appearance of tiddler links to convey additional information about the target of the link:
|!Link description |!Link appearance |
|To a tiddler that exists |[[LikeThis|TiddlerLinks]] |
|To a tiddler that doesn't exist |[[LikeThis|ATiddlerThatDoesntExist]] |
|To a shadow tiddler that has not been overridden |[[LikeThis|$:/core/copyright.txt]] |
|To a shadow tiddler that has been overridden by an ordinary tiddler |[[LikeThis|$:/SiteTitle]] |
External links are shown like this: https://tiddlywiki.com/ or [[like this|https://tiddlywiki.com/]].
Jede Tiddler sollte mindestens über drei Informationseinheiten eindeutig definiert werden können (Tag, Key, Fields)
To filter ''tiddlers by tag'', use the ``<$list>`` widget, like this:
``<$list filter="[tag[sometag]]">
</$list>
``
https://www.ooktech.xyz:8443/Public#Federation%20Demo
Plugins unter
https://www.ooktech.xyz:8443/Public#%24%3A%2Fplugins%2FOokTech%2FTWederBob
div.modules-used-footer {
margin-top: 0.5em;
border-top: solid 1px;
text-align: right;
font-size: 70%;
}
div.modules-used-footer::before {
content: "Modules used: ";
}
p {
text-indent:1em;
}
pre {
text-indent:0;
}
.IMPORTANT {
border: solid 2px red;
background-color: pink;
color: red;
}
;I will try and show if then else while until etc.. in the long run
;1. Sequence
:One step following another
:With sequence it commonly stops when you reach the bottom of a tiddler
*1.1 Left to right, Top then down the wiki text, the first item is displayed above the next etc... down the page
:Note new line vs paragraphs
*1.2 Using list and a filter to get a sequence of items displayed or acted on
:Using a list for sequence it commonly stops when the members of the list finish/are exhausted, it then moves to the next line of the current tiddler until you reach the bottom of a tiddler
:This can be impacted by "Includes" see below.
;2. Iteration
:Repeat for each item in a set, ending when no more items are in the set or some condition is true/false
*2.1 Using the list widget with a filter that has 0 or more members
*2.2 An iteration can be ordered using sorting
*2.3 There are many ways to re-iterate, and you can re-iterate Macros, with transclusions and a lot more, most iterations will end with no more members in a list or some other condition.
;3. Sorting
:Choosing the order in which more than one item is listed
*3.1 Filtered lists permit the addition of the sort[fieldname] filter operator which can be used to sort the final list
:Default is title or for tagged items the order in which they appear in the tags list field
:!sort[fieldname] will reverse the order
*3.2 Used with iteration to support the order in which the items are acted on
;4. Selection/Decision
:using some condition to determine whether to display something or not
*4.1 A list field will list is membership if there are members. otherwise will not
*4.2 If you need to determine if there are one or more (not Zero members), or any other number of something
:You can use the limit[n] filter operator so that limit[1] will display only once if there is one or more members
:?Limit[0] works?
:?Use ? starting line for a different class
*4.3 If you want to test there is no members?
:The emptyMessage is available on the list widget and emptyValue on the set widget
*4.4 What if you want to list the non-members
:Using the ! with the filter operators
:Note default set all regular tiddlers so perhaps filter based on another condition first
*4.5 The reveal widget allows a section to be displayed according to a match including comparisons
:Reveal widgets can also be nested
*4.6 Simple Comparisons
*4.7 Inclusion/exclusion and other selection tests
*The do nothing case or filter but exclude
*A tiddler but not those it is the prefix of
:`[prefix[tiddlername]suffix[tiddlername]]` is both its prefix and its suffix
*4.8 Selection and decisions can be made based on values that are in variables, Tiddlers, fields and more
:so review ''Using Values and variables'' or ''Setting Values and variables''
;5. Nesting
:This is the process where one set of actions occur within another set of actions, With tiddlywiki nesting can occur for many levels "deep"
:This is how Case and Recursion below, amongst other structures are possible.
*5.1 One implicit example of nesting is a Single ListWidget in a particular tiddler, it is in fact nesting its result in the existing tiddler
*5.2 In most cases anything you write can be nested within something else, and as many deep as you choose.
:However if you nest your current tiddler in the current tiddler you __may__ face infinite recursion (like between two mirrors)
:See 7.x Recursion for intentional use of this ability
*5.3 Example Nesting list widgets
```
<$list filter="filter1">
Do this for each filter1 case
<$list filter="filter2">
Do this for each filter2 case
<$list filter="filter3">
Do this for each filter3 case
<$list filter="filter4">
Do this for each filter4 case
</$list>
</$list>
</$list>
</$list>
```
:''Notes:''
*If the number of levels of nesting can vary or is large or unknown using ''recursion'' may be a better solution.
*If transclusion or macro are used to ''include'' additional content these are in effect nested where they are included, and may contain other nesting themselves.
*Each filter applies to the CurrentTiddler as determined by the previous ListWidget unless a variable=//variablename// is set.
*Each filter starts with an assumption you are filtering from all tiddlers, so use a variable or currentTiddler value from the previous List widget for logically nested lists.
;6. Case
:When you want something to occur differently for each case or member in a set
:6.1 A simple list allows you to do something for each member in a list which is a simple example of the "Case" structure.
:In the following example each member of the set becomes the current tiddler and everything in "Do this for this case" will be applied to each tiddler.
```
<$list filter="yourfilter">
Do this for each case
</$list>
```
:6.2 Treating specific cases differently
:note in the below skeleton that the "specific case" tests are nested at the same level within the "yourfilter" outer listWidget
```
<$list filter="yourfilter">
Do this for each case
<$list filter="specificcase1filter">
Do this for each specificcase
</$list>
<$list filter="specificcase2filter">
Do this for each specificcase2
</$list>
</$list>
```
:very sophisticated case structures can be built with the power of each list filter, emptyMessage
:examples to follow
*One statement for a subgroup or list of values
*Multiple actions for each case
;7. Recursion
:A process calling itself
*7.1 Using ListWidgets in a tiddler or macro to call itself allows you to perform recursive loops
:For example building a TableOfContents which list the tiddlers tagging the top tiddler, then all tiddlers tagging those, then all tiddlers tagging those...
:The advantage of the list widget is it typically finishes after the last item in the list is processed, ensuring you eventually exit all recursion levels
:See [[WikiPedia on Recursion|http://en.wikipedia.org/wiki/Recursion]]
;8. Includes
:including content in one location that is found in another
*8.1 Macros
*8.2 Transclusion
;9. Using Values and variables
:Set/Vars/Params
:EmptyValue/EmptyMessage
:Auto seting in lists
:titles of tiddlers vs pseudo titles from lists
;10 Setting Values and variables
:Often values and variables can be set in the context they are used as seen in ''Using Values and variables'', however we often want the user to supply information for our Values and Variables
*Select
*Checkbox
*Edit
*
;11. Accessing last or previous values
<<book HelloThere>>
<<book Learning>>
<<book "Working with TiddlyWiki">>
<<book "Customise TiddlyWiki">>
<<book Features>>
<<book Languages>>
<<book Editions>>
<<book Plugins>>
<<book Platforms>>
<<book Reference>>
<<book Community>>
<<book About>>
So gelingt deine Klageschrift, Klageerwiderung oder Replik
Das Wort ist des Juristen Schwert.Willst du in der Anwaltsstation Deines Rechtsreferendariats oder nach dem Berufseinstieg mit richtig guten Schriftsätzen glänzen? In diesem Artikel zeige ich dir, wie du das schaffst.
(Anm.: Eine ältere Version dieses Artikels ist in der JURA zweit-veröffentlicht. Ich habe den Artikel seitdem aktualisiert und weiter bearbeitet.)
Tipps für alle Arten anwaltlicher Schriftsätze
Egal ob vorprozessualer oder prozessualer Schriftsatz, ob Klageschrift, Replik oder Klageerwiderung: Die folgenden einleitenden Tipps gelten für alle Arten von anwaltlichen Schriftsätzen.
Erst planen, dann Feedback holen, dann schreiben
Jeder anwaltliche Schriftsatz steht und fällt mit dem Aufbau. Überlege dir deshalb zuerst eine Gliederung und Schwerpunktsetzung für deinen Schriftsatz. Wie willst du den Sachverhalt darstellen? Welche rechtlichen Argumente wirst du in welcher Reihenfolge und Ausführlichkeit ins Feld führen? Erstelle dir eine Gliederungsskizze und besprich sie mit deinem Ausbilder oder Vorgesetzten. Optimiere deinen Schriftsatzaufbau so lange, bis ihr beide vollauf zufrieden damit seid. Mache dich erst danach ans Ausformulieren.
Wenn du nämlich zuerst ausformulierst und anschließend den Aufbau grundlegend änderst, entsteht leicht ein Patchwork-Schriftsatz, dem man auf den ersten Blick ansieht, dass er nach dem ersten Entwurf auseinander gepuzzelt und in neuer Reihenfolge wieder zusammengesetzt wurde. Das lässt sich zwar beheben, kostet aber Zeit.
Wenn du hingegen zuerst einen grundsoliden Aufbau sicherstellst, kannst du danach einen Schriftsatz aus einem Guss schreiben, dessen Formulierungen sich an seine innere Struktur anschmiegen und den Leser ohne Stolpersteine zu deinem Ergebnis führen.
Dieser Grundsatz gilt allerdings mit gewissen Einschränkungen. Inwieweit dein erster Aufbauansatz es tatsächlich bis in die finale Version schafft, wird auch von der Komplexität des Verfahrens und der Dynamik des Sachverhalts abhängen. Vor allem in großen Verfahren bekommst du während des Verfassens eines Schriftsatzes hin und wieder noch weitere Sachverhaltsinformationen.
Das zwingt teilweise zum Überdenken des Aufbaus. Im Übrigen kommen einem gerade bei komplexeren Fällen während des Ausformulierens oft noch Ideen zur Optimierung der Struktur. Natürlich ist es sinnvoll, diesen nachzugehen.
Die Darstellungsregie übernehmen
ke7-fg4In den meisten Verfahren gibt es einen Schriftsatz, der das Geschehen und die Rechtsausführungen so schlüssig darstellt, dass er sich für den Richter als Ausgangspunkt seiner Arbeit anbietet. Der Richter liest diesen Schriftsatz und prüft dann, inwieweit die Darstellungen in anderen Schriftsätzen davon abweichen. Psychologisch sind damit letztere Schriftsätze mit den abweichenden Darstellungen automatisch in der Defensive.
Der renommierte Rechtsanwalt und Honorarprofessor Benno Heussen spricht deshalb in seinem Buch „Time Management für Anwälte“ (3. Auflage 2009, S. 179) von der Übernahme der Darstellungsregie. Den Schriftsatz, mit dem man die Darstellungsregie übernimmt, nenne ich den Referenzschriftsatz.
Zur Veranschaulichung hier ein vereinfachtes Beispiel, indem der Kläger Zahlung von 5.000 € Schadensersatz für eine Uhr verlangt.
In der Klageschrift schreibt der klägerische Anwalt:
„Der Beklagte ist der Bruder des Klägers. Am Abend des 13.04.2014 war der Kläger außer Haus. Dies wusste der Beklagte, da es sich um den wöchentlichen Skatabend des Klägers handelte.
Deshalb begab sich der Beklagte gegen 22 Uhr mit seinem Zweitschlüssel in die Wohnung des Klägers. Dort nahm er die goldene Taschenuhr des Klägers im Wert von 5.000 € aus der Nachttischschublade. Dann verließ der Beklagte die Wohnung wieder. Einige Tage später verkaufte er die Uhr auf dem Schwarzmarkt.“
(Beweisangebote und weitere Details spare ich zur Vereinfachung aus)
In der Klageerwiderung schreibt der Beklagtenanwalt:
„Der klägerische Vortrag ist nicht korrekt. Die Uhr stand nicht im Eigentum des Klägers. Der Beklagte hat sie nämlich von ihrem gemeinsamen Vater geerbt. Weiterhin war die Uhr auch nur 1.000€ Wert, da sie nicht aus Gold, sondern aus Silber war.“
(Beweisangebote und weitere Details spare ich zur Vereinfachung auch hier aus)
Wenn der Richter hier versucht, sich den Sachverhalt bildlich vorzustellen, kann er kaum anders, als dabei die „Story“ des Klägers vor Augen zu haben. Denn der Beklagte hat gar keine eigene Geschichte erzählt, sondern nur die des Klägers an einzelnen Stellen angegriffen.
Um sich ein besseres Bild machen zu können, wird der Richter den Beklagten bitten, seinen Vortrag zu substantiieren. Dann aber muss sich der Richter die Story des Beklagten aus mehreren Schriftsätzen zusammenpuzzeln. Der Referenzschriftsatz bleibt also beim Kläger.
Wie der Beklagte mit seinem Sachvortrag stattdessen um die Darstellungsregie kämpfen könnte, werde ich weiter unten bei den Ausführungen zur Klageerwiderung darstellen.
Tausende Referendare sind Dir gegenüber im Vorteil.
Sie nehmen an meinen kostenlosen Ref-Hacks teil. Die Ref-Hacks helfen Dir, entspannter durchs Referendariat zu gehen, ein besseres Examen zu schreiben und Deinen Traumjob zu finden. Bleib nicht außen vor, melde Dich kostenlos an.
Oder willst Du es Dir lieber schwer machen und das gut sein anderen Referendaren überlassen? Das wär doch Quatsch, klick lieber hier.
Der Take-away an dieser Stelle ist: Du solltest mit deinen Schriftsätzen um die Darstellungsregie kämpfen. Das gilt sowohl für die Sachverhaltsdarstellung als auch für die Rechtsausführungen. Damit sicherst du deiner Partei einen psychologischen Vorteil.
So einfach wie möglich schreiben
Wenn ein Richter eine Akte aufarbeitet, liest er sie in der Regel von hinten nach vorne, also den letzten Schriftsatz zuerst. Außerdem hat er einen Riesenstapel weiterer Akten zu bearbeiten und deshalb wenig Zeit. Er liest deine Schriftsätze also in der „falschen“ Reihenfolge und dann auch noch so schnell er kann.
Die Konsequenz für dich: Du musst so einfach, verständlich und übersichtlich wie möglich schreiben. Dazu folgende Tipps:
Schreibe kurze Sätze.
Kurze Sätze lesen sich gut. Lange Sätze lesen sich schlecht. Komplizierte Gedanken kann man in viele kurze Sätze zerteilen. Dann versteht der Leser sie sofort.
Demgegenüber lesen sich lange Sätze im Verhältnis zu kurzen Sätzen tendenziell schlechter, weil sich komplizierte Gedanken, vor allem wenn man schnell liest und sie in einem Satz mit komplexer Satzstruktur zu einem einheitlichen Ganzen verbunden werden, dem Leser nicht schon beim ersten Lesen erschließen, da sie ihm anders als dem Verfasser des Textes bis dato nicht bekannt sind und er deshalb nicht nur den Satzbau, sondern auch den Inhalt des Geschriebenen und dessen logische Struktur erfassen und verstehen muss.
Siehst du, was ich meine?
Schreibe grundsätzlich im Aktiv.
Das Passiv ist oft umständlich und ungenau.
Die goldene Uhr des Klägers wurde gestohlen.
Der Beklagte stahl die goldene Uhr des Klägers.
Von dieser Grundregel gibt es allerdings Ausnahmen:
Manchmal willst oder musst du bewusst offenlassen, wer etwas getan hat. Das lässt sich mit dem Passiv leicht umsetzen.
Manchmal kannst Du mit dem Passiv auch eine bessere Betonung setzen. Baker McKenzie Partner Prof. Dr. Jörg Risse gibt in einem Artikel auf Lto.de dafür ein gutes Beispiel, welches ich hier minimal abgewandelt habe:
Würdest du schreiben „Ein Hund jagt die Katze.“ oder „Die Katze wird von einem Hund gejagt.“?
Das Passiv betont hier die Katze als Subjekt. Wenn du zu Katzenliebhabern sprichst und zeigen willst, was für ein armes Kätzchen das doch ist, wäre das Passiv deshalb besser geeignet.
Alternativ könntest du durch eine andere Formulierung zurück zum Aktiv finden, beispielsweise „Die Katze flüchtet vor einem Hund“. Damit stellst du die Katze aber aktiver und mächtiger dar. Sie flüchtet, handelt also. Mit dem eben gezeigten Passiv-Satz positionierst du sie hingegen stärker als Opfer, das nicht selbst aktiv wird, sondern dem etwas geschieht.
Verwende keine unnötigen Substantive
Der Diebstahl der Uhr des Klägers durch den Beklagten hatte einen Schaden des Ersteren zur Folge.
Indem der Beklagte die Uhr des Klägers stahl, schädigte er diesen.
Bilde viele aussagekräftige Überschriften
Dann findet der Richter schneller, was er sucht. Umso besser sich der Richter in deinem Schriftsatz zu Recht findet, desto eher wird er ihn als Referenzschriftsatz verwenden.
So viel nötig, so wenig wie möglich
Kurze Schriftsätze werden gelesen. Wenige zitierte Urteile werden auch gelesen.
Wenn du an unwichtigen Stellen zu viel schreibst, gehen die wichtigsten Punkte vielleicht unter. Wenn du viel halbrelevante Rechtsprechung zitierst, lenkst du von den entscheidenden Urteilen ab.
Du willst mit deinen Schriftsätzen also die Darstellungsregie übernehmen, aber auch nur das schreiben und zitieren, was dafür erforderlich ist.
Spezielle Tipps für das Verfassen einer Klageschrift
Mit der Klageschrift kannst du gleich zu Beginn die Darstellungsregie übernehmen. Diese Chance solltest du in der Regel wahrnehmen. Dazu ein paar Tipps:
Aufbau
Sachverhaltsdarstellung und Rechtsausführungen solltest du in der Klageschrift immer trennen. Den Sachverhalt solltest du in der Regel chronologisch aufbauen. Als Alternative kann es sich in Einzelfällen anbieten, verschiedene Handlungsstränge nacheinander darzustellen. Allerdings ist es dann oft schwer, die Verknüpfungen der Handlungsstränge gut abzubilden.
Einleitung bilden
Bei umfangreichen Sachverhalten ist es oft sinnvoll, vor der Sachverhaltsdarstellung einen Gesamtüberblick über Sachverhalt und Rechtslage zu geben. Dadurch kann der Richter später beim Lesen die Details gleich in den Gesamtkontext einordnen.
Umgang mit vorprozessualen Einreden
Wenn du vorprozessuale Einwände des Gegners vorweg nimmst, wird es dir oft leichter fallen, die Darstellungsregie im Laufe des Prozesses zu verteidigen. Denn in diesem Fall schaffst du mit der Klageschrift schon ein vollständiges „Nachschlagewerk“ für den Richter.
Außerdem kannst du die gegnerischen Einwände dann so darstellen, wie du es möchtest. Auf der anderen Seite riskierst du aber, dich mit den Einwänden selbst unschlüssig zu machen. Diese wichtige Weichenstellung solltest du unbedingt mit deinem Ausbilder oder Vorgesetzten besprechen, bevor du die Klageschrift ausformulierst!
Grafische Hilfsmittel
Manchmal ist es klug, in der Klageschrift grafische Hilfsmittel wie Zeitleisten, Tabellen oder Organigramme zur Veranschaulichung einzusetzen.
Fazit geben
Häufig geben Anwälte auch am Ende der Sachverhaltsdarstellungen noch einmal eine Art Zusammenfassung oder ein Fazit. Dort solltest du konzentriert diejenigen Fakten wiedergeben, die für die rechtliche Bewertung am wichtigsten sind.
Spezielle Tipps für das Verfassen einer Klageerwiderung
Entreiße dem Kläger die Darstellungsregie
Die Klageerwiderung birgt eine besondere Herausforderung: Der klägerische Anwalt hat mit der Klageschrift die Darstellungsregie übernommen. Du musst jetzt versuchen, sie ihm mit der Klageerwiderung wieder zu entreißen.
Deshalb solltest du dich in der Regel nicht der Struktur der Klageschrift fügen, sondern für deine Klageerwiderung eine eigene Struktur entwickeln.
Allerdings ist das leichter gesagt als getan. Man rutscht erstaunlich leicht in die Struktur der Gegenseite hinein. Hier daher ein paar Tipps, um deine eigene, unabhängige Schriftsatzstruktur zu entwickeln:
Aufbau
Unterteile auch die Klageerwiderung nach Sachverhaltsdarstellung und Rechtsausführungen. Nur so kannst du in der Sachverhaltsdarstellung eine eigene, zusammenhängende Geschichte erzählen und deine rechtlichen Ausführungen mit der notwendigen Freiheit strukturieren.
Einleitung bilden
Gib auch in der Klageerwiderung zunächst einen Überblick über Sachverhalt und Rechtslage, wie sie sich aus Beklagtensicht darstellen.
Vorgehensweise: Die Zettelmethode
Bevor du dich an den Aufbau deiner Klageerwiderung machst, zerstückele den Fall in seine Einzelteile. Öffne dazu Powerpoint und erstelle dir eine Folie für jeden Problemkreis. Fasse die Problemkreise möglichst klein. Notiere dir auf jede Folie die entsprechenden Argumente zu diesem Problemkreis.
Nun kannst du die Folien beliebig schieben und tauschen, oder auch Argumente zwischen Folien hin- und her bewegen. Dadurch stellst du sicher, dass dein Aufbau auf deinen eigenen Überlegungen und nicht auf der gegnerischen Struktur beruht.
Statt Powerpoint Folien kannst du natürlich auch Papierzettel nehmen. (Diese Zettelmethode habe ich ebenfalls von Prof. Dr. Benno Heussen in „Time Management für Anwälte“. Dort stellte er eine noch ausdifferenzierte Version vor. Ich habe das für mich etwas vereinfacht und mit Powerpoint digitalisiert.)
Soll ich Dich gratis Durch Referendariat und 2. Examen begleiten? Mache ich gerne! Melde Dich einfach für meine kostenlosen Ref-Hacks an.
Tausende Referendare haben schon teilgenommen. Bleib nicht außen vor. Mach es Dir leicht.
Grafische Hilfsmittel
Wie bei der Klageschrift kann auch bei der Klageerwiderung der Einsatz grafischer Hilfsmittel sinnvoll sein.
Fazit geben
Ebenfalls wie bei der Klageschrift kann es auch bei der Klageerwiderung klug sein, den Sachverhalt aus Beklagtensicht vor Beginn der Rechtsausführungen noch einmal zusammenzufassen.
Beispiel: Der Streit um die Uhr
Um dem Kläger die Darstellungsregie in unserem Uhrenfall von oben wieder zu entreißen, könnte der Beklagte den Sachverhalt beispielsweise wie folgt darstellen:
„Anders als der klägerische Vortrag suggeriert, liegt dem Sachverhalt kein Einbruchsdiebstahl, sondern eine Erbstreitigkeit zwischen Brüdern zu Grunde.
Der Vater der Parteien war Eigentümer einer silbernen Taschenuhr, welche er stets in seinem Nachtschrank aufbewahrte. Er hatte zu Lebzeiten immer gesagt, dass er die Uhr seinem liebsten Sohn vermachen werde.
Im Januar 2014 ist der Vater der Parteien verstorben. In seinem Testament hat er die silberne Taschenuhr dem Beklagten vermacht. Dies hat den Kläger schwer getroffen. Er hat gegenüber dem Beklagten mehrfach geäußert, dass die Uhr eigentlich ihm zustehe, weil er den Vater in der Zeit vor dessen Tot gepflegt habe.
Im Februar 2014 ging der Beklagte in die Wohnung seines Vaters, um die Uhr an sich zu nehmen. Die Uhr befand sich jedoch nicht mehr in dem Nachtschrank, obwohl der Vater sie dort zu Lebzeiten nie herausgenommen hatte.
(…)“
Man kann sich schon denken, wie es weitergeht. Der Anwalt müsste eigentlich gar nicht mehr schreiben, dass der Kläger die Uhr aus Eifersucht an sich genommen hat und der Beklagte sich nur zurückgeholt hat, was ihm zusteht. Der Kläger ist nun wieder in der Defensive. Die Darstellungsregie ist zurückerobert.
Eine Ausnahme
Vor allem bei einfachen, im Wesentlichen unstreitigen und von dem Kläger auch aus Beklagtensicht schon ziemlich vollständig dargestellten Sachverhalten kann es sich auch anbieten, nur streitige Punkte aufzugreifen.
Spezialtaktik: Zerstören und Verschleiern
Manchmal bekommt man eine Klage und ist so eindeutig in der schwächeren Position, dass der Aufbau einer stabilen eigenen Struktur ausscheidet. Wenn der Mandant sich trotzdem gegen die Klage verteidigen möchte, greifen manche Anwälte in die Trickkiste:
Sie fahren mit ihrer Klageerwiderung eine rein destruktive Strategie. Das primäre Ziel ist dabei nicht mehr, eine eigene schlüssige Argumentation aufzubauen. Stattdessen versucht der Anwalt einfach nur, den gegnerischen Vortrag zu zerstören.
Er bestreitet in der Klageerwiderung umfangreich, trägt teilweise neben der Sache vor, zitiert tonnenweise halbrelevante Rechtsprechung und wirft die Argumente aus der Klageschrift heillos durcheinander. Dann hofft er, dass die Schwachstellen der eigenen Position in diesem Wirrwarr untergehen.
Die Klageerwiderung fungiert hier also als Rauchbombe, in deren Schutz der Anwalt seinen Mandanten in Sicherheit bringen will.
Falls du eine solche Taktik tatsächlich anwenden willst, solltest du das natürlich unbedingt vorher mit deinem Ausbilder oder Vorgesetzten besprechen.
Spezielle Tipps für die Replik
Wie man die Replik aufbaut, hängt erstens vom vorangegangenen Schriftwechsel ab und ist zweitens Geschmackssache. So trennen manche Anwälte in der Replik Tatsachenvortrag und Rechtsausführungen, andere hingegen nicht.
Oft wird man nur noch auf einzelne Punkte eingehen müssen. Wenn die Klageschrift aber schwach und die Klageerwiderung stark ist, musst du unter Umständen mit der Replik noch einmal um die Darstellungsregie kämpfen.
Schlusswort
Gute Schriftsätze muss man üben. Lies deshalb alle guten Schriftsätze, die du in die Finger bekommen kannst. Schreibe möglichst viele Schriftsätze selber. Arbeite mit guten Prozessanwälten zusammen. Von ihnen kannst du viel lernen. Und, ganz wichtig, bitte deine Ausbilder und Vorgesetzten immer um Feedback.
div.tc-tiddler-body .nr, div.tc-tiddler-preview-preview .nr {
counter-reset: h1counter;
}
div.tc-tiddler-body .nr h1, div.tc-tiddler-preview-preview .nr h1 {
counter-increment: h1counter;
counter-reset: h2counter;
}
div.tc-tiddler-body .nr h2, div.tc-tiddler-preview-preview .nr h2 {
counter-increment: h2counter;
counter-reset: h3counter;
}
div.tc-tiddler-body .nr h1::before, div.tc-tiddler-preview-preview .nr h1::before {
content: counter(h1counter) ".\0000a0\0000a0";
}
div.tc-tiddler-body .nr h2::before, div.tc-tiddler-preview-preview .nr h2::before {
content: counter(h1counter)"."counter(h2counter) ".\0000a0\0000a0";
}
div.tc-tiddler-body .nr h3::before, div.tc-tiddler-preview-preview .nr h3::before {
content: counter(h1counter)"."counter(h2counter) "." counter(h3counter) ".\0000a0\0000a0";
counter-increment: h3counter;
}
<<tabs "[tag[ToDoSideBar]]" "" "">>
<<tabs "[tag[TableofContents]]" "" "">>
<<tiddler CategoryListDemo>>
<<CategoryList Tag:"Planned Update" FinishedTag:"Change Log">>
<$checkbox tiddler='$:/settings' field=edit_mode checked=true unchecked=false>Toggle Edit Mode
</$checkbox>
! Introduction
You can incorporate the content of one tiddler within another using the [[Transclusion]] notation:
* `{{MyTiddler}}` transcludes a single tiddler
* `{{MyTiddler||TemplateTitle}}` displays the tiddler through a specified [[TemplateTiddler|TemplateTiddlers]]
* `{{||TemplateTitle}}` displays the specified template tiddler without altering the [[current tiddler|Current Tiddler]]
!! Transcluding Text References
You can also use a TextReference instead of a tiddler title:
* `{{MyTiddler!!field}}` transcludes a specified field of a tiddler
* `{{!!field}}` transcludes a specified field of the current tiddler
* `{{MyTiddler##index}}` transcludes a specified indexed property of a [[DataTiddler|DataTiddlers]]
* `{{##index}}` transcludes a specified indexed property of the current [[DataTiddler|DataTiddlers]]
!! Filtered Transclusion
A similar syntax can be used to transclude a list of tiddlers matching a specified [[filter|Filters]]:
```
{{{ [tag[mechanism]] }}}
{{{ [tag[mechanism]] ||TemplateTitle}}}
```
! Generated Widgets
The WikiText transclusion syntax generates a TiddlerWidget wrapped around a TranscludeWidget. For example, `{{MyTiddler||MyTemplate!!myField}}` generates the following pair of widgets:
```
<$tiddler tiddler="MyTiddler">
<$transclude tiddler="MyTemplate" field="myField"/>
</$tiddler>
```
See also:
* [[Transclusion Basic Usage]]
* [[Transclusion with Templates]]
* TemplateTiddlers
* TranscludeWidget
* [[Transclusion and Substitution]]
! Simple Transclusion
To include some content from [[TiddlerA]] into [[TiddlerB]], edit the latter to include the following text:
```
This is the content of TiddlerA: {{TiddlerA}}
```
The result is that the content of the ''text'' field (i.e. the main content) of [[TiddlerA]] is rendered within [[TiddlerB]].
! Usage
The notation ``{{TiddlerA}}`` is a shortcut for ``{{TiddlerA!!text}}``. This is because the default field for transclusion is ''text'', but any other [[field|TiddlerFields]] can be used explicitly. For example, you can print the last time TiddlerA was modified using:
```
TiddlerA was modified on {{TiddlerA!!modified}}
```
By omitting the tiddler title, the transclusion notation can also be used to display the content of a field from the current tiddler, for example:
```
The current tiddler was modified on {{!!modified}}
```
! Recursion Errors
Notice that using ``{{!!text}}`` or ``{{}}`` causes an error (//Recursive transclusion error in transclude widget//), because it does not make sense to include the content of the current tiddler into the content of the current tiddler (that is, into itself). Whenever you encouter this error message, it means that you are trying to include something into itself, directly or indirectly (for example if tiddler A transcludes tiddler B which transcludes tiddler C which, in turn, transcludes tiddler A).
! Learning More
In TiddlyWiki, transclusions are not limited to including raw content like the above. To learn about more advanced uses of transclusion, see [[Transclusion with Templates]].
See also:
* [[Transclusion]]
* [[Transclusion with Templates]]
* [[Transclusion in WikiText]]
* TextReference
* TiddlerFields.
! Introduction
In [[Transclusion Basic Usage]] we have seen how to include the content of a tiddler A into a tiddler B. Now suppose that tiddler A contains:
```
@@background-color:yellow;
Hello, my title is {{!!title}}
@@
```
This makes tiddler A display its title with a yellow background (see [[Styles and Classes in WikiText]] to learn about CSS style). Imagine that you want to display the title in the same way in tiddler B. But you don't want to copy/paste the style instructions, because you might want to change the background colour later and you want to keep it consistent among tiddlers. This looks like a typical case of transclusion, so let's try to transclude tiddler A in tiddler B the usual way with ``{{A}}``. You should see the following content in tiddler B:
<<<
@@background-color:yellow;
Hello, my title is A
@@
<<<
The style is applied as expected, but the title is wrong: we want ``{{!!title}}`` to refer to the target tiddler B, and not the source tiddler A.
The solution is to use a //template//. In this case, the source tiddler A is called the [[TemplateTiddler|TemplateTiddlers]], and it is //applied// to tiddler B using the notation ``{{||A}}``. The difference is that any TextReference which does not refer explicitly to a specific tiddler is applied to the [[current tiddler|Current Tiddler]], that is, the target tiddler. As a result, tiddler B now looks as expected:
<<<
@@background-color:yellow;
Hello, my title is B
@@
<<<
! Usage
Transcluding via a template is like applying a mask: assuming that the source tiddler contains generic references (like eye holes in a mask), these will be replaced with the target tiddlers values (like the eyes of the person who wears the mask).
A template can be applied to any tiddler, not necessarily the current one. This is achieved using the full notation ``{{<target>||<template>}}``. The default ``<target>`` is the [[current tiddler|Current Tiddler]] (this is what we used in the above example).
! Examples
!! A predefined template to render tags nicely
You can apply the system template ``$:/core/ui/TagTemplate`` to a tag in order to see it as a tag pill with a drop-down menu:
```
{{Transclusion||$:/core/ui/TagTemplate}}
```
is rendered as {{Transclusion||$:/core/ui/TagTemplate}}
See also:
* [[Transclusion in WikiText]]
* [[Transclusion Basic Usage]]
* TextReference
* TemplateTiddlers
* TranscludeWidget
* [[Current Tiddler]]
''Begriff''
Über ein Treuhandverhältnis ist es möglich, eine Person wirtschaftlich an einem Unternehmen zu beteiligen bzw. ihr wirtschaftlich eine Gesellschaftsbeteiligung zu übertragen, ohne dass diese Person formell Gesellschafter wird. Diese wirtschaftlich beteiligte Person wird Treugeber genannt. Vermittelt wird dem Treugeber die Beteiligung durch den formellen Gesellschafter, dem Treuhänder - erhält die Beteiligung zu treuen Händen.
Im Außenverhältnis tritt der Treuhänder als Gesellschafter auf, während er im Innenverhältnis die Interessen des Treugebers wahrnimmt. Über solche „Strohmanngeschäfte“ können die wahren Beteiligungsverhältnisse in GmbHs, AGs und GmbH & Co. KG verdeckt werden. Konkurrenten und andere Dritte erhalten keine Kenntnis von den wahren Beteiligungsverhältnissen.
Der Treuhandvertrag regelt Rechte und Pflichten von Treugeber und Treuhänder.
''Rechtliche Einordnung''
I.d.R. Auftrag (§ 662 BGB) oder Geschäftsbesorgungsvertrag (§ 675 I BGB). Zu beachten sind die BGB-Bestimmungen des Auftragsrechts (§§ 662–674 BGB) und des allg. Vertragsrechts, bes. § 242 BGB (Treu und Glauben), die regelmäßig aber dispositiv sind.
''Form''
Grundsätzlich keine bestimmte Form vorgeschrieben; anders nur in Ausnahmefällen (z.B. notarielle Beurkundung beim Erwerb von Grundstücken durch den Treuhänder). Schriftform aber auch bei Fehlen spezieller Vorschriften empfehlenswert.
Der Abschluss von Treuhandverträgen wird sehr oft notariell zu beurkunden sein, wenn sich das Treuhandverhältnis auf GmbH-Geschäftsanteile bezieht. Eine notarielle Beurkundung ist bei einer Abtretung von GmbH-Geschäftsanteilen erforderlich (§ 15 Abs. 3 GmbHG). Damit werden auch der Abschluss eines Treuhandvertrags sowie die Rückabtretung der Anteile bei der Beendigung des Treuhandverhältnisses einer notariellen Beurkundung unterfallen. Von einer notariellen Beurkundung des Treuhandverhältnisses kann grundsätzlich abgesehen werden, wenn der Treuhänder an der GmbH-Gründung beteiligt wird; der Treuhandvertrag also vor Gründung der GmbH abgeschlossen wurde. Zu berücksichtigen ist aber, dass mit einer notariellen Beurkundung die Risiken der steuerlichen Anerkennung von Treuhandverhältnissen reduziert werden können.
Treuhandverhältnisse an KG-Gesellschaftsanteilen (GmbH & Co. KG) unterfallen grundsätzlich keinen notariellen Beurkundungspflichten. Aber auch bei GmbH & Co. KG-Treuhandgeschäften gibt es viele Konstellationen, die einen Gang zum Notar erforderlich machen.
In der Praxis wird man die notarielle Beurkundung von Treuhandverhältnissen sowohl im Vorfeld von GmbH-Gründungen als auch bei vielen GmbH & Co. KG-Beteiligungen schon allein aus Rechtssicherheitserwägungen und wegen der steuerlichen Anerkennung empfehlen. Entsprechendes gilt für Vereinbarungen, welche Verpflichtungen zur Begründung von Treuhandverhältnissen enthalten.
''Inhalt''
Wirtschaftlicher Zweck, Beginn und Ende der Treuhandschaft, Abgrenzung und Verwahrung des Treuguts, Aufgaben und Pflichten des Treuhänders, Rechtsstellung des Treuhänders im Innen- und Außenverhältnis, Weisungsrechte des Treugebers, Vergütung und Aufwendungsersatz, Art und Umfang der Rechenschaftslegung, Haftung.
Geschlossen wird eine Treuhandvereinbarung zwischen einem Auftraggeber, dem Treugeber, und einem Treuhänder, der in der Regel einer bestimmten Berufsgruppe angehört, wie zum Beispiel Notare, Rechtsanwälte oder auch Steuerberater. Der schriftlich zu fixierende Treuhandvertrag regelt die Pflichten des Treuhänders, um das Vermögen des Treugebers zu schützen und auch vor absehbarem Schaden zu bewahren.
Wichtig sind folgende Punkte:
* Nennung von Treugeber und Treuhänder
* exakte Höhe des Geldbetrages, der zu treuen Händen gegeben wird
* genaue Beschreibung der Vermögensverwaltung, ergo in welcher Art das Geld verwaltet werden soll
* Fristen und Kündigung des Treuhandvertrages
* Rechte und Pflichten des Treugebers
* Vergütungshöhe und Vergütungsart des Treuhänders
* Rechte und Pflichten des Treuhänders
Ein Treuhandverhältnis kann bei der Gründung einer Gesellschaft oder auch bei einer späteren Anteilsübertragung entstehen. Dabei kann das Treuhandverhältnis offen oder verdeckt begründet werden. Bei einer offenen Treuhand erhalten die Mitgesellschafter Kenntnis und billigen das Treuhandverhältnis in aller Regel. Dagegen bleiben bei einer verdeckten Treuhand die Existenz und der Inhalt des Treuhandvertrags gegenüber den Mitgesellschaftern geheim.
Gegenüber der Finanzverwaltung muss das Treuhandverhältnis offen gelegt werden: Wenn das Treuhandverhältnis wirksam begründet und auf der Grundlage einer eindeutigen Vereinbarung auch tatsächlich durchgeführt wird, wird der Treugeber aus steuerlicher Sicht vom Finanzamt als Gesellschafter angesehen. Insoweit werden Gewinnausschüttungen nicht beim Treuhänder, sondern beim Treugeber versteuert.
Der Treuhandvertrag muss die Interessenverteilung zwischen Treuhänder und Treugeber genauestens regeln. Detaillierte Regelungen hinsichtlich diverser Einzelfragen sind sehr wichtig, damit das Auseinanderfallen von zivilrechtlichem Eigentum und wirtschaftlicher Zuordnung richtig justiert wird. Typischerweise wird der Treuhänder verpflichtet, die erhaltenen Gewinne an den Treugeber weiterzureichen und in Gesellschafterversammlungen entsprechend den Weisungen des Treugebers abzustimmen. Dem Treugeber wird sicherheitshalber oft auch eine Stimmrechtsvollmacht übertragen. Der Treuhänder erhält gegen den Treugeber üblicherweise Ansprüche auf Vergütung, Aufwendungsersatz und Freistellung (Haftung, Kosten). Zugunsten des Treugebers werden spezielle Vereinbarungen zur Kündigung des Treuhandverhältnisses und ggf. zum Wettbewerbsverbot getroffen.
Bei der Begründung eines Treuhandverhältnisses ist darauf zu achten, dass die Treuhand nicht mit den Veräußerungsbeschränkungen im Gesellschaftsvertrag (Vinkulierungsklauseln) kollidiert. Anderenfalls droht – möglicherweise nach Jahren – ein gerichtlicher Streit und die Einsicht, dass das Treuhandverhältnis zivilrechtlich nie wirksam geworden ist. In dem Fall werden auch angestrebte steuerliche Zuordnungen mit ggf. hohen finanziellen Folgen versagt werden. Nicht selten führt eine Verletzung von Veräußerungsbeschränkungen (durch Abschluss eines Treuhandvertrages) auch zu einem Ausschluss aus der Gesellschaft.
\define thisMakeMaintainerField()
maintainer[$(ThisMaintainer)$]
\end
\define thisMakeCategoryField()
category[$(ThisCategory)$]
\end
\define thisMakeList()
<table>
<$list filter='[$(CategoryEntry)$$(MaintainerEntry)$tag[Plugin twCard]has[category]sort[category]each[category]]'>
<$set name=currentCategory value={{!!category}}>
<$list filter='[$(MaintainerEntry)$tag[Plugin twCard]category<currentCategory>regexp[(?i)$(SearchString)$]limit[1]]'>
<tr><th>{{!!category}} Plugins</th><th></th><th></th><th></th><th></th><th></th></tr>
<tr><th>Name</th><th>Version</th><th>Date (DD-MM-YYYY)</th><th>Maintainer</th><th>Description</th><th>Wiki</th></tr>
<$list filter='[$(MaintainerEntry)$tag[Plugin twCard]category<currentCategory>sort[title]regexp[(?i)$(SearchString)$]]' template=PluginTWcardDisplayTemplate>
</$list>
</$list>
</$set>
</$list>
</table>
\end
Select maintainer: <$select field='maintainer'>
<option value=''>All</option>
<$list filter='[!is[current]tag[Plugin twCard]each[maintainer]get[maintainer]sort[title]]-[[twCard Listing - Plugins]]' variable=ThisMaintainer>
<option value=<<thisMakeMaintainerField>>><$view tiddler=<<ThisMaintainer>> field='title'/></option>
</$list>
</$select>
Select category: <$select field='category'>
<option value=''>All</option>
<$list filter='[!is[current]tag[Plugin twCard]each[category]get[category]sort[title]]-[[twCard Listing - Plugins]]' variable=ThisCategory>
<option value=<<thisMakeCategoryField>>><$view tiddler=<<ThisCategory>> field='title'/></option>
</$list>
</$select>
Search by title:
<$edit-text tiddler='$:/temp/twCard Listing - Plugins/Title Search' field='search_string' class='tc-edit-texteditor'/>
<$set name=MaintainerEntry value={{!!maintainer}}>
<$set name=CategoryEntry value={{!!category}}>
<$set name=SearchString value={{$:/temp/twCard Listing - Plugins/Title Search!!search_string}}>
<<thisMakeList>>
</$set>
</$set>
</$set>
This is an example to show what can be done with the [[Extract Macro]]. We can see some weeknesses of it too:
* Some characters (?) like in TextStretch cause troubles. This is the reason, why the tweet for this tiddler is transcluded from another tiddler – this way it can be listed here.
* Lists need to be constructed carefully according to the example below, macro calls from lists with the param `tiddler=<<tiddler>>` and similar work only for titles without spaces at the moment.
---
!! Tweets from tiddlers
This list shows suggested tweets from this wiki – always the first per tiddler.
<$list filter="""[regexp:text[<tweet ]sort[]] -[[Tweeting]] -[is[system]] -[has[draft.of]]""">
!!! <$link to={{!!title}}><$view field="title"/></$link>
<$list filter="[<currentTiddler>![Tweeting]]">
<<extract start:"<tweet " end:">" limit:"yes" rmQuotes:"yes">>
</$list>
</$list>
Charakteristisch für die Arbeitnehmerüberlassung ist, dass der Verleiher auf den Entleiher das fachliche Direktions-recht überträgt. Das bedeutet, dass der Entleiher ermächtigt sein muss, den Leiharbeitnehmern gegenüber Weisungen hinsichtlich der Art und Weise der Erbringung der Arbeitsleistungen zu erteilen, während das disziplinarische Weisungsrecht (Verwarnungen, Abmah¬nungen, Kündigungen) beim Verleiher verbleibt.
Dies könnte in folgender Klausel geregelt werden.
Weisungsklausel:
//Der Entleiher ist berechtigt, den überlassenen Arbeitnehmern alle Weisungen zu erteilen, die nach Art und Umfang in deren Tätigkeitsbereich fallen.//
Durch die Übertragung des fachlichen Weisungsrechts unterscheidet sich die Arbeitnehmerüberlassung von anderen Formen des drittbezogenen Personaleinsatzes, insbesondere von der Personalgestellung kraft Dienst- oder Werkvertrags.
Bei Dienst- oder Werkverträgen kümmert sich der Auftragnehmer selbst um die zur Erreichung eines wirtschaftlichen Erfolgs notwendigen Handlungen und ist für die Erfüllung der im Vertrag vorgesehenen Dienste oder für die Erstellung des geschuldeten Werks gegenüber dem Drittunternehmen verantwortlich. Das fachliche wie das disziplinarische Weisungsrecht verbleiben komplett beim Vertragsarbeitgeber. Dieser Unterschied zwischen Arbeitnehmerüberlassung und Dienst- oder Werkvertrag ist sehr wichtig.
Entscheidend ist, dass die Vertragsformulierung allein nicht vor den Folgen einer verdeckten, möglicherweise illegalen Arbeitnehmerüberlassung schützt. Es kommt entscheidend auf die tatsächliche Vertragsdurchführung an.
Einzelfallbeurteilung. In der Regel (-), bei üblichen Umgangskosten, auch bei Ferienaufenthalt im Rahmen des Besuchsrechts. Bei hohen Kosten (z.B.
bedingt durch Wegzug der Mutter) allerdings Berücksichtigung z.B. der Fahrtkosten
als trennungsbedingter Mehrbedarf.
Zuwendungen, welche von einem Ehepartner an den andren fließen, werden als unbenannte Zuwendungen bezeichnet. Derartige Übertragungen von Vermögen erfordern keine finanzielle Gegenleistung des anderen.
Sie unterscheiden sich von Schenkungen dadurch, dass sie unter dem Vorbehalt des Fortbestands der Ehe gemacht worden sind [BGH, 28.03.2006, X ZR 85/04,9; das Schenkungsrecht ist somit auf unbenannte Zuwendungen nicht anwendbar. Unbenannte Zuwendungen werden auch als „ehebedingte Zuwendungen bezeichnet. In der Praxis kommen sie häufig vor in Form von Übertragungen von Miteigentum an Immobilien oder die Übernahme einer Finanzierung.
Eine unbenannte Zuwendung liegt hingegen nicht vor, wenn diese aus anderen Gründen als der Aufrechterhaltung des ehelichen Zusammenlebens dient, wie beispielsweise die Schaffung gemeinsamer Vermögenswerte. Wenn also ein Ehepartner Geld oder Arbeitskraft beispielsweise in den Bau einer gemeinsamen Immobilie steckt, so wird dies nicht als eine unbenannte Zuwendung gewertet.
Unbenannte Zuwendungen sind als ein familienrechtliches Rechtsverhältnis anzusehen.
''Abgrenzung'' Schenkung – Unbenannte Zuwendung Ehegatteninnengesellschaft
Als Schenkung wird die Übertragung eines Vermögenswertes von einer Person auf eine andere bezeichnet, wobei sich beide Parteien darüber einig sind, dass diese Zuwendung unentgeltlich erfolgt. Gesetzlich definiert wird sie gemäß § 516 BGB:
„Eine Zuwendung, durch die jemand aus seinem Vermögen einen anderen bereichert, ist Schenkung, wenn beide Teile darüber einig sind, dass die Zuwendung unentgeltlich erfolgt.
Ist die Zuwendung ohne den Willen des anderen erfolgt, so kann ihn der Zuwendende unter Bestimmung einer angemessenen Frist zur Erklärung über die Annahme auffordern. Nach dem Ablauf der Frist gilt die Schenkung als angenommen, wenn nicht der andere sie vorher abgelehnt hat. Im Falle der Ablehnung kann die Herausgabe des Zugewendeten nach den Vorschriften über die Herausgabe einer ungerechtfertigten Bereicherung gefordert werden.“
Im Zuge einer Ehe liegt eine „echte“ Schenkung dann vor, wenn diese Zuwendung auch dann erfolgt, wenn der Fortbestand der Ehe in Gefahr ist. Liegt eine notarielle Beurkundung der Schenkung vor, so kann diese Zuwendung im Falle einer Trennung nicht zum Zugewinn hinzugezogen werden.
Eine Rückforderung einer Schenkung ist hingegen in jenen Fällen möglich, in denen die Gefahr besteht, dass der Schenkende verarmt oder sich der Beschenkte als grob undankbar erweist. Auf diese Regelungen kann sich ein Ehepartner in Fällen, bei denen es sich um eine unbenannte Zuwendung handelte, nicht berufen, da diese nicht mit einer Schenkung gleichzusetzen ist.
Bei einer Ehegatteninnengesellschaft hingegen verfolgen beide Ehepartner einen gemeinsamen Zweck. Um diesen zu erfüllen, erbringen sie Leistungen, welche über den üblichen ehelichen Rahmen hinausgehen, wie beispielsweise die Mitarbeit eines der Ehepartner im geschäftlichen Betrieb des anderen. Eine derartige Beteiligung erfolgt aus geschäftlichem Interesse und nicht um der Ehe willen. Demzufolge sind Leitungen, welche im Rahmen der Ehegatteninnengesellschaft erbracht werde, nicht als unbenannte Zuwendungen anzusehen.
Um Schenkungen von unbenannten Zuwendungen abgrenzen zu können, bedarf es zunächst einer Klärung der Ausgangssituation: aus welchem Grund wurden die Zuwendungen gemacht? darf der Beschenkte mit dieser Zuwendung machen, was er möchte, oder diente sie einem bestimmten Zweck? Erfolgte die Zuwendung aus Gründen, die dem Fortbestand der Ehe dienen sollten?
So ist anzunehmen, dass es sich in der Regel bei Weihnacht- oder Geburtstagsgeschenken um „Schenkungen“ handelt, welche nicht dem Zweck dienen sollen, die Ehe aufrecht zu erhalten. Eine teilweise Übertragung eines Grundstücks an einen Ehepartner ist nicht als eine Schenkung anzusehen, wenn der Beschenkte dieses Grundstück nicht zu seiner freien Verfügung hat und somit auch nicht damit machen kann, was er möchte.
[[Rückforderung]]
[[Rückforderung - Schwiegereltern]]
<<<
{{||$:/plugins/btheado/ftlist/main}}
<<<
{{||$:/plugins/btheado/ftlist/main}}
\define unicode-table(base high: "0 1 2 3 4 5 6 7 8 9 A B C D E F" low: "0 1 2 3 4 5 6 7 8 9 A B C D E F" code saved)
<table>
<tr>
<th>$base$</th>
<$list filter="$low$" variable=low>
<th><<low>></th>
</$list></tr>
<$list filter="$high$" variable=high>
<tr>
<th><<high>></th>
<$list filter="$low$" variable=low>
<td><$wikify name=code text="&#x$base$<<high>><<low>>;"><$button class="tc-btn-invisible" set="$code$" setTo=<<code>> actions=<<add-code "$saved$">> >
<<code>></$button></$wikify></td>
</$list></tr>
</$list>
</table>
\end
\define unicode(base:"$:/state/unicode/base" code:"$:/state/unicode/code" saved:"$:/state/unicode/saved" pages:"$:/state/unicode/pages")
<div>
| <h1>{{$code$}}</h1> | <$edit-text tiddler="$code$" tag=input default="" size=12/> copy: <$button message=tm-copy-to-clipboard class="tc-btn-invisible" param={{$code$}} tooltip="Click to copy Unicode entity to clipboard">{{$:/core/images/copy-clipboard}} entity </$button> <$wikify name=char text={{$code$}}><$button message=tm-copy-to-clipboard class="tc-btn-invisible" param=<<char>> tooltip="Click to copy Unicode character to clipboard">{{$:/core/images/copy-clipboard}} character</$button></$wikify>| <$keyboard key="enter" actions=<<add-page "$pages$" "$base$">> ><$edit-text tiddler="$base$" tag=input default="" placeholder="00" size=6/></$keyboard> <$select tiddler="$base$"><option></option><$list filter={{$pages$}} variable=base><option value=<<base>>><<base>></option></$list></$select> <$button class=tc-btn-invisible actions=<<add-page "$pages$" "$base$">> >{{$:/core/images/new-button}}</$button> |
|<h1><$list filter={{$saved$}} variable=code><$button class="tc-btn-invisible" set="$code$" setTo=<<code>> actions=<<add-code "$saved$">> ><<code>></$button> </$list></h1>|<|<|<|
|<$macrocall $name=unicode-table base={{$base$}} code="$code$" saved="$saved$"/>|<|<|<|
</div>
\end
\define add-page(pages base) <$action-listops $tiddler="$pages$" $field=text $subfilter="+[reverse[]] [{$base$}] +[reverse[]limit{$:/config/Unicode/Pages/limit}]"/>
\define add-code(saved) <$action-listops $tiddler="$saved$" $field=text $subfilter="+[reverse[]] [<code>] +[reverse[]limit{$:/config/Unicode/Codes/limit}]" />
<<unicode>>
https://en.wikipedia.org/wiki/Unicode
<<tree $:/state/unicode >>
<<tree $:/config/Unicode >>
{{{
[prefix[$:/config/Unicode]]
[prefix[$:/state/unicode]]
[!is[system]search[unicode]]
+[sort[]]
}}}
* [[Kindesunterhalt]]
* [[Elternunterhalt]]
* [[Ehegattenunterhalt]]
Unterhaltsgrundsätze des OLG Frankfurt am Main
Stand: 01.01.(07.)2019
Präambel
Die von den Richtern der Familiensenate des für ganz Hessen zuständigen OLG Frankfurt am Main erarbeiteten Grundsätze beruhen auf der Rechtsprechung des Bundesgerichtshofs und sollen im Interesse der Einheitlichkeit und Überschaubarkeit Orientierungslinien für die Praxis geben. Sie orientieren sich an der bundeseinheitlichen Leitlinienstruktur.
Sie binden den Richter nicht; dieser wird in eigener Verantwortung die angemessenen Lösungen des Einzelfalls finden müssen.
Das Tabellenwerk der Düsseldorfer Tabelle ist eingearbeitet. Die Erläuterungen werden durch nachfolgende Grundsätze ersetzt.
Unterhaltsrechtlich maßgebendes Einkommen
1. Geldeinnahmen
1.1 Regelmäßiges Bruttoeinkommen einschließlich Renten und Pensionen
Auszugehen ist vom Bruttoeinkommen als Summe aller Einkünfte, regelmäßig bezogen auf das Kalenderjahr.
Der Splittingvorteil aus einer zweiten Ehe ist beim Kindesunterhalt zu berücksichtigen, soweit er auf dem Einkommen des Pflichtigen beruht (BGH FamRZ 2008, 2189, Tz. 16, 33), beim Ehegattenunterhalt für einen ersten Ehegatten jedoch nur, wenn auf der Leistungsebene die Berücksichtigung aller Ansprüche erfolgt, etwa im Wege der Dreiteilung (BGH FamRZ 2012, 281, Tz.. 26, 47, 52), während er bei Vorrang des ersten Ehegatten der neuen Ehe verbleibt.
BGH am 2008-09-17 (XII ZR 72/06) in FamRZ 2008, 2189; NJW 2008,3562 == Zum Splittingvorteil beim Kindesunterhalt
BGH am 2010-06-02 (XII ZR 160/08) in FamRZ 2010, 1318; NJW 2010, 2515 == Zum Splittingvorteil beim Kindesunterhalt.
BGH am 2011-12-07 (XII ZR 151/09) in FamRZ 2012, 281; NJW 2012, 384, Tz. 26, 47, 52 == Verteilung des Splittingvorteils u. a. beim Ehegattenunterhalt
BGH am 2014-05-07 (XII ZB 258/13) in FamRZ 2014, 1183; NJW 2014, 2109, Tz. 30 == Splittingvorteil und Familienzuschlag als Einkommen bei der Dreiteilung auf der Leistungsebene
BGH am 2014-07-09 (XII ZB 661/12) in FamRZ 2014, 1536; NJW 2014, 2785 == Zur Ermittlung des Kaufkraftunterschieds mit Eurostat bei im Ausland lebendem Pflichtigen.
BGH am 2015-06-17 (XII ZB 458/14) in Rn. 50, 51 == Fiktive Steuerlast eines Ehegatten nach § 270 AO bei Verpfl. zum Elternunterhalt..
BGH am 2018-02-07 (XII ZB 338/17) in FamRZ 2018, 681 == Erhöhung des Beihilfebemessungssatzes als Einkommen des betreuenden Elternteils
1.2 Unregelmäßige Einkommen (z.B. Abfindungen etc.)
Soweit Leistungen nicht monatlich anfallen (z.B. Weihnachts- und Urlaubsgeld), werden sie auf ein Jahr umgelegt. Einmalige Zahlungen (z.B. Abfindungen) sind auf einen angemessenen Zeitraum (in der Regel mehrere Jahre) zu verteilen.
In der Regel sind Abfindungen bei der Aufnahme einer neuen Arbeitsstelle mit dauerhaft geringerem Einkommen bis zur Höchstgrenze des Bedarfs aufgrund des früheren Einkommens sowohl beim Kindes- als auch beim Ehegattenunterhalt für den Unterhalt zu verwenden; ob eine Aufstockung bis zum bisherigen Einkommen unter vollständiger Aufrechterhaltung des bisherigen Lebensstandards geboten ist, beurteilt sich nach den Umständen des Einzelfalls, insbesondere der beim Pflichtigen zu erwartenden weiteren Einkommensentwicklung. Eine Doppelberücksichtigung der Abfindung beim Ehegattenunterhalt und im Güterrecht ist zu vermeiden.
BGH am 2010-06-02 (XII ZR 138/08) in FamRZ 2010, 1311; NJW 2010, 2582 == Zur Nichtberücksichtigung einer Abfindung neben normalem Einkommen nach Scheidung beim Ehegattenunterhalt.
BGH am 2012-04-18 (XII ZR 65/10) in FamRZ 2012, 1040; NJW 2012, 1868 == Zur Berücksichtigung einer Abfindung bis zur Höhe des bisherigen Bedarfs.
BGH am 2012-04-18 (XII ZR 66/10) in FamRZ 2012, 1048; NJW 2012, 1873 == Zur Berücksichtigung einer Abfindung beim Kindesunterhalt.
1.3 Überstunden
Überstundenvergütungen werden voll angerechnet, soweit sie berufstypisch sind oder in geringem Umfang anfallen oder der Mindestbedarf der Kinder nicht gedeckt ist. Im Übrigen ist der Anrechnungsteil nach Zumutbarkeit zu ermitteln. Die Weiterführung überobligationsmäßiger Überstundenleistungen kann regelmäßig nicht verlangt werden. Dies gilt entsprechend auch für Nebentätigkeiten. Zur Obliegenheit einer Nebentätigkeit zur Deckung des Mindestbedarfs minderjähriger Kinder vgl. BVerfG FamRZ 2003, 661.
BVerfG am 2003-03-05 (1 BvR 752/02) in FamRZ 2003, 661 == Art. 2 I GG: Verletzende Berücksichtigung fiktiver Nebentätigkeitseinkünfte
BGH am 2003-06-25 (XII ZR 63/00) in FamRZ 2004, 186 ff., 187 unter 2. b == Zu Überstundenvergütungen.
BGH am 2008-12-03 (XII ZR 182/06) in FamRZ 2009, 314; NJW 2009, 1410 == Voraussetzungen für Zurechnung fiktiver Einkünfte, besondere Prüfung der Zumutbarkeit und des erzielbaren Einkommens einer etwaigen Nebentätigkeit. Siehe weiter bei Nr. 9
BVerfG am 2012-06-18 (1 BvR 774/10) in NJW 2012, 2420; ZKJ 2012, 396 == Art. 2 I GG: Zur Zumutbarkeit von Nebentätigkeiten
BGH am 2014-09-24 (XII ZB 111/13) in FamRZ 2014, 1992; NJW 2014, 3784 == Zur Zumutbarkeit einer Nebenbeschäftigung trotz voller Erwerbstätigkeit.
1.4 Spesen und Auslösungen
Über die Anrechenbarkeit von Spesen und Auslösungen ist nach Maßgabe des Einzelfalls zu entscheiden. Als Anhaltspunkt kann eine anzurechnende häusliche Ersparnis (also nicht für reine Übernachtungskosten oder Fahrtkosten bis zu der in Nr. 10.2.2 definierten Höhe) von einem Drittel in Betracht kommen.
1.5 Einkommen aus selbständiger Tätigkeit
Bei Einkünften aus selbständiger Tätigkeit oder aus Gewerbebetrieb wird regelmäßig an den Gewinn (§ 4 Abs. 1, Abs. 3 EStG) aus einem zeitnahen Dreijahreszeitraum angeknüpft. Mit der Vorlage der ESt-Bescheide und der entsprechenden Bilanzen mit G+V-Rechnung oder den Einnahme/Überschuss-Rechnungen wird der besonderen Darlegungslast (BGH FamRZ 93, 789, 792) in der Regel genügt. Auf substanziierten Einwand sind gegebenenfalls weitere Erläuterungen vorzunehmen oder Belege vorzulegen. Zu Ansparabschreibungen / Investitionsabzugsbeträgen und zur Beachtung von Besonderheiten der Einkommensentwicklung siehe BGH FamRZ 2004, 1177 - 1179.
Zur Berechnung des Einkommens für vergangene Zeiträume vgl. BGH FamRZ 2007, 1532 ff. ( 1534, Tz. 23).
BGH am 2004-06-02 (XII ZR 217/01) in FamRZ 2004, 1177 ff., 1178 unter 2. a == Zu Ansparabschreibungen.
BGH am 2007-07-04 (XII ZR 141/05) in FamRZ 2007, 1532, Tz. 23 == Einkommensberechnung aufgrund tatsächlicher Einkünfte für vergangene Zeiträume
BGH am 2011-09-21 (XII ZR 121/09) in FamRZ 2011, 1851; NJW 2011, 3577 == Steuer-In-Prinzip und Dreijahreszeitraum im Einzelfall kein Dogma.
1.6 Einkommen aus Vermietung und Verpachtung sowie Kapitalvermögen
Einkommen aus Vermietung und Verpachtung sowie Kapitalvermögen ist der Überschuss der Bruttoeinkünfte über die Werbungskosten und notwendige Instandhaltungsrücklagen. Für Wohngebäude ist keine AfA anzusetzen; im Einzelfall kommt stattdessen die Berücksichtigung angemessener Tilgungsleistungen in Betracht.
BGH am 2007-07-04 (XII ZR 141/05) in FamRZ 2007, 1532, Tz. 23 == Einkommensberechnung aufgrund tatsächlicher Einkünfte für vergangene Zeiträume
1.7 Steuererstattungen
Steuererstattungen sind grundsätzlich im Kalenderjahr der tatsächlichen Leistung zu berücksichtigen. Steuervorteile, die auf unterhaltsrechtlich nicht zu berücksichtigenden Aufwendungen beruhen, bleiben in der Regel außer Betracht. Vgl. BGH FamRZ 2005, 1159 ff. und 1817 ff.
BGH am 2004-12-01 (XII ZR 75/02) in FamRZ 2005, 1159 == Zur Berücksichtigung steuerrechtlicher Verluste aus Grundbesitz.
BGH am 2005-05-11 (XII ZR 211/02) in FamRZ 2005, 1817 == Splittingvorteil aus neuer Ehe bei Ehegattenunterhalt irrelevant
BGH am 2006-05-31 (XII ZR 111/03) in NJW 2006, 2623; FamRZ 2006, 1178 == Fiktive getrennte Veranlagung als Berechnungsgrundlage für Steuerschuld
Barbara Schramm am 2006-10-16 in NJWSpezial 2006, 439 == Anmerkung zu BGH XII ZR 111/03 - Steuerstattungsanspruch und Nachzahlungspflicht getrennt lebender Ehegatten
BGH am 2007-05-23 (XII ZR 245/04) in FamRZ 2007, 1232; NJW 2007, 2628 == Fiktives Einkommen und Splittingvorteil bei Wiederverheiratung
BGH am 2007-05-23 (XII ZR 250/04) in FamRZ 2007, 1229; NJW 2007, 2554 == Zur Zustimmungspflicht gemeinsamer Veranlagung
1.8 Sonstige Einnahmen
Sonstige Einnahmen sind z.B. Trinkgelder.
BGH am 2012-04-18 (XII ZR 73/10) in NJW 2012, 2190 == Auslandsverwendungszuschlag für Einsatz in Risikogebieten nur teilw. Einkommen (1/3 bis 1/2).
BGH am 2015-07-01 (XII ZB 240/14) in Rn. 13 == Eigengeld des Strafgefangenen .
2. Sozialleistungen
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
2.1 Arbeitslosengeld (§§ 136 ff. SGB III) und Krankengeld
Arbeitslosengeld (§§ 136 ff. SGB III) und Krankengeld sind Einkommen.
OLG Ffm am 2005-10-06 (5 WF 146/05) == Steuervorteil aus neuer Ehe bei Arbeitslosengeld
2.2 Leistungen nach dem SGB II
Leistungen nach dem SGB II sind auf Seiten des Verpflichteten wie Einkommen zu behandeln, weshalb anrechnungsfrei belassener Hinzuverdienst zu einer teilweisen Leistungsfähigkeit des Verpflichteten führen kann. Durch die Titulierung von Unterhalt und den dadurch ermöglichten Abzug nach § 11b Abs. 1 S. 1 Nr. 7 SGB II kann die unterhaltsrechtliche Leistungsfähigkeit aber nicht erhöht werden (vgl. BGH v. 19.6.2013, XII ZB 39/11). Auf Seiten des Berechtigten sind Leistungen zur Sicherung des Lebensbedarfes nach §§ 19ff SGB II kein Einkommen, es sei denn die Nichtberücksichtigung der Leistungen ist in Ausnahmefällen treuwidrig (vgl. BGH FamRZ 1999, 843; 2001, 619); nicht subsidiäre Leistungen nach dem SGB II sind Einkommen, insbesondere Einstiegsgeld (§ 16 b SGB II) und Entschädigung für Mehraufwendungen "1 Eurojob" (§ 16 d SGB II).
BGH am 2000-09-27 (XII ZR 174/98) in FamRZ 2001, 619 ff., 620 f. unter 5., 6. == Zur ausnahmsweisen Beschränkung des Unterhaltsanspruchs nach Gewährung von Sozialhilfe u. a.
BGH am 2013-06-19 (XII ZB 39/11) in FamRZ 2013, 1378; NJW 2013, 2595 == Abzug vom Einkommen nach § 11 b SGB II erhöht nicht die Leistungsfähigkeit für Unterhalt.
2.3 Wohngeld
Wohngeld gleicht in der Regel erhöhten Wohnbedarf aus und ist deshalb grundsätzlich nicht als Einkommen zu behandeln. Nur mit einem dafür nicht verbrauchten Teilbetrag, zu dem substantiiert vorzutragen hat, wer sich darauf beruft, ist das Wohngeld als Einkommen zu berücksichtigen (vgl. BGH FamRZ 2012, 1201, Tz.15)
BGH am 2012-04-18 (XII ZR 73/10) in FamRZ 2012, 1201; NJW 2012, 2190 == Rdn. 15: Nur nicht für erhöhten Wohnbedarf verbrauchtes Wohngeld ist (teilw.) Einkommen.
2.4 BAföG-Leistungen
BAföG-Leistungen sind Einkommen, auch soweit sie als Darlehen gewährt werden, mit Ausnahme von Vorausleistungen nach §§ 36, 37 BAföG.
BGH am 2013-07-17 (XII ZR 49/12) in FamRZ 2013, 1644 == Höhe des Anspruchsübergangs auf BAföG gewährendes Land
2.5 Elterngeld
Elterngeld ist, soweit es je Kind über den Sockelbetrag i. H. v. 300,-- €, bei verlängertem Bezug über 150,-- €, hinausgeht, Einkommen. Der Sockelbetrag des Elterngeldes und Betreuungsgeld nach § 4a BEEG, soweit es trotz Nichtigkeit des Gesetzes aus Gründen des Vertrauensschutzes übergangsweise weitergewährt wird (vgl. BVerfG, Urteil vom 21.7.2015, 1 BvF 2/13, Rn. 73), sind kein Einkommen, es sei denn, es liegt einer der Ausnahmefälle des § 11 Satz 4 BEEG vor.
BGH am 2006-04-12 (XII ZR 31/04) in FamRZ 2006, 1010 == Erziehungsgeld als Einkommen beim Unterhalt minderjähriger Kinder
BGH am 2012-04-18 (XII ZR 73/10) in FamRZ 2012, 1201; NJW 2012, 2190, Tz. 14 == Grundsätzlich nur Elterngeld über 300 EUR als Einkommen.
BGH am 2014-05-07 (XII ZB 258/13) in FamRZ 2014, 1183; NJW 2014, 2109, Tz. 39 == Sockelbetrag von 300 EUR des Elterngeldes auch bei Dreiteilung außen vor.
BGH am 2015-02-11 (XII ZB 181/14) in FamRZ 2015, 738; NJW 2015, 1178, Rn. 19 == Verdoppelung der Bezugsdauer des Elterngeldes auch bei Unterhaltsverpfl. ggü. Mdj.
2.6 Unfall- und Versorgungsrenten
Unfall- und Versorgungsrenten (z.B. nach dem Bundesversorgungsgesetz) sind nach Abzug des Betrages für tatsächliche Mehraufwendungen zu berücksichtigen (§§ 1610a, 1578a BGB).
BGH am 2018-07-04 (XII ZB 448/17) in FamRZ 2018, 1506; NJW 2018, 2638 Rn. 11-21 == Kein Unterhalt aus Leistungen nach § 16 Abs. 1 HIVHG u. aus Conterganrente.
2.7 Leistungen aus der Pflegeversicherung, Blindengeld und Ähnliches
Leistungen aus der Pflegeversicherung an den Pflegling, Blindengeld, Schwerbeschädigten- und Pflegezulagen sind jeweils nach Abzug des Betrages für tatsächliche Mehraufwendungen zu berücksichtigen (§§ 1610a, 1578a BGB).
BGH am 2015-06-17 (XII ZB 458/14) in Rn. 31 == Fiktives Pflegegeld zum Elternunterhalt bei fehlender Pflegeversicherung.
2.8 Pflegegeld
Der Anteil des Pflegegeldes bei der Pflegeperson, durch den ihre Bemühungen abgegolten werden, ist als Einkommen zu betrachten; bei Pflegegeld aus der Pflegeversicherung gilt dies nach Maßgabe des § 13 Abs. 6 SGB XI.
BGH am 2006-03-01 (XII ZR 157/03) in FamRZ 2006, 846; NJW 2006, 2182 == Keine Minderung des Ehegattenunterhalts, wenn die geschiedene Ehefrau für die Pflege des gemeinsamen behinderten pflegebedürftigen Kindes Pflegegeld erhält.
2.9 Grundsicherungsleistungen
Die Leistungen gemäß §§ 41 - 43 SGB XII sind beim Berechtigten im Rahmen von Verwandtenunterhaltsansprüchen in der Regel als Einkommen zu berücksichtigen.
Im Rahmen von Ehegattenunterhaltsansprüchen sind sie im Regelfall nicht als Einkommen zu bewerten.
BGH am 2006-12-20 (XII ZR 84/04) in FamRZ 2007, 1158 == Zur Anrechnung der Leistungen der Grundsicherung.
OLG Ffm am 2008-01-23 (5 UF 146/07) == Zu den Unterhaltsbedarf mindernden Leistungen der Grundsicherung.
BGH am 2015-07-08 (XII ZB 56/14) in Rn. 11 == Obliegenheit zur Inanspruchnahme von Leistungen der Grundsicherung im Alter und bei Erwerbsminderung.
2.10 Sonstige Leistungen nach dem SGB XII
Leistungen nach dem SGB XII zur Sicherung des Lebensunterhalts sind auf Seiten des Verpflichteten wie Einkommen zu behandeln, weshalb anrechnungsfrei belassener Hinzuverdienst zu einer teilweisen Leistungsfähigkeit des Verpflichteten führen kann. Sonstige Leistungen nach dem SGB XII sind auf Seiten des Berechtigten nicht als Einkommen zu bewerten; siehe aber Nr. 2.11 für treuwidrige Unterhaltsforderungen.
2.11 Leistungen nach dem Unterhaltsvorschussgesetz
Diese Leistungen sind nicht als Einkommen zu bewerten. Die Unterhaltsforderung eines Empfängers dieser Leistungen kann aber in Ausnahmefällen treuwidrig sein, vgl. BGH FamRZ 1999, 843 (847); 2001, 619 (620). Dies gilt vor allem bei der Geltendmachung von Kindesunterhalt gegen Großeltern sowie in den Fällen des § 7a UVG.
BGH am 2000-09-27 (XII ZR 174/98) in FamRZ 2001, 619 ff., 620 f. unter 5., 6. == Zur ausnahmsweisen Beschränkung des Unterhaltsanspruchs nach Gewährung von Unterhaltsvorschuss.
BGH am 2012-03-14 (XII ZR 164/09) in FamRZ 2012, 785 == Zur Bedarfsdeckung der UVG-Leistungen bei Unterhaltspflicht der Großeltern.
2.12 Leistungen nach den Vermögensbildungsgesetzen
Leistungen nach den Vermögensbildungsgesetzen beeinflussen das Einkommen nicht, d.h. der vermögenswirksame Anlagebetrag mindert das Einkommen nicht; andererseits erhöhen vermögenswirksame Beiträge des Arbeitgebers und die Sparzulage nicht das Einkommen.
3. Kindergeld
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
Kindergeld wird nicht zum Einkommen der Eltern gerechnet (vgl. Nr. 14).
OLG Ffm am 2005-09-19 (5 WF 136/05) == Kindergeld als weiteres Einkommen für Prozesskostenhilfe
OLG Ffm am 2013-04-19 (6 WF 55/13) in FamRB 2013, 384; FamFR 2013, 441 == Zum Kindergeld als weiterem Einkommen für Prozesskostenhilfe
BGH am 2016-04-20 (XII ZB 45/15) in FamRZ 2016, 1053; NJW 2016, 1956 == Zum isolierten Kindergeldausgleich beim Wechselmodell.
BGH am 2016-12-14 (XII ZB 207/15) in FamRZ 2017, 633; NJW 2017, 962, Rn. 7 ff. == Kindergeld als Einkommen bei Verfahrenskostenhilfe.
BGH am 2017-01-11 (XII ZB 565/15) in FamRZ 2017, 437; NJW 2017, 1676, Rn. 47 ff. == Kindergeldausgleich durch Verrechnung mit Kindesunterhalt beim Wechselmodell.
BGH am 2017-02-15 (XII ZB 201/16) in FamRZ 2017, 711, NJW 2017, 1881, Rn. 15 ff. == Betreuungsanteil des Kindergeldes kein unterhaltsrelevantes Einkommen.
4. Geldwerte Zuwendungen des Arbeitgebers
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
Geldwerte Zuwendungen aller Art des Arbeitgebers, z.B. Firmenwagen oder freie Kost und Logis, sind Einkommen, soweit sie entsprechende Eigenaufwendungen ersparen.
5. Wohnwert
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
Der Wohnvorteil durch mietfreies Wohnen im eigenen Heim ist als wirtschaftliche Nutzung des Vermögens unterhaltsrechtlich wie Einkommen zu behandeln. Neben dem Wohnwert sind auch Zahlungen nach dem Eigenheimzulagengesetz anzusetzen.
Ein Wohnvorteil liegt nur vor, soweit der Wohnwert die berücksichtigungsfähigen Finanzierungslasten, erforderliche Instandhaltungskosten und die verbrauchsunabhängigen Kosten, mit denen ein Mieter gem. § 556 Abs. 1 BGB iVm § 1 Abs. 2 BetrKV nicht belastet werden kann (vgl. dazu BGH, FamRZ 2009, 1300 ff., 1303), übersteigt. Auszugehen ist vom vollen Mietwert (objektiver Wohnwert). Wenn es nicht möglich oder nicht zumutbar ist, die Wohnung aufzugeben und das Objekt zu vermieten oder zu veräußern, kann stattdessen die ersparte Miete angesetzt werden, die angesichts der wirtschaftlichen Verhältnisse angemessen wäre (subjektiver Wohnwert). Dies kommt insbesondere für die Zeit bis zum endgültigen Scheitern der Ehe in Betracht, wenn ein Ehegatte das Eigenheim allein bewohnt. Als Untergrenze für den subjektiven Wohnwert ist der Kaltmietanteil im kleinen Selbstbehalt anzusetzen. Bei höherem Einkommen ist der Wohnwert angemessen zu erhöhen.
Finanzierungslasten mindern den Wohnwert, soweit sie tatsächlich durch Ratenzahlungen bedient werden. Tilgungsleistungen sind bei der Berechnung des Ehegattenunterhalts solange zu berücksichtigen, wie der berechtigte Ehegatte am Vermögenszuwachs teilhat. Nach diesem Zeitpunkt mindern neben den Zinszahlungen die Tilgungsleistungen den Wohnwert nur dann, wenn weder Veräußerung noch Tilgungsaussetzung oder Tilgungsstreckung möglich sind.
Soweit Tilgungsleistungen danach unberücksichtigt bleiben, können sie als zusätzliche angemessene Altersvorsorge berücksichtigt werden (bis zu 4 % bei Ehegatten- und Kindesunterhalt, bis zu 5 % bei Elternunterhalt).
Beim Kindesunterhalt gilt im Rahmen des § 1603 Abs. 1 BGB ein großzügigerer, im Anwendungsbereich des § 1603 Abs. 2 BGB hingegen ein strengerer Maßstab für die Berücksichtigung von Tilgungsleistungen und zusätzlicher Altersvorsorge. Im absoluten Mangelfall sind Tilgungsleistungen und zusätzliche Altersvorsorge in der Regel nicht zu berücksichtigen.
Insbesondere beim Elternunterhalt sind Tilgungsleistungen bis zur Höhe des Wohnvorteils abzuziehen (BGH vom 18.01.2017, XII ZB 118/17, FamRZ 2017, 519, Rn 33f).
OLG Ffm am 1999-08-23 (1 UF 106/99) == Objektiver Wohnwert wenn Fremdvermietung möglich ist.
BGH am 2004-12-01 (XII ZR 75/02) in FamRZ 2005, 1159 == Wohnvorteil bei Übernahme des Miteigentumsanteils vom anderen Ehegatten.
BGH am 2005-05-11 (XII ZR 211/02) in FamRZ 2005, 1817 == Wohnwert - zunächst Miteigentum, dann Alleineigentum durch Teilungsversteigerung
BGH am 2008-03-05 (XII ZR 22/06) in FamRZ 2008, 963; NJW 2008, 1946 == Keine einseitige Vermögensbildung des Unterhaltspflichtigen zu Lasten des Unterhaltsberechtigten
BGH am 2008-10-01 (XII ZR 62/07) in FamRZ 2009, 23; NJW 2009, 145 == Wohnvorteil bei Kauf eines Hausgrundstücks aus dem Erlös des verkauften Familienheims und unter Aufnahme neuer Darlehen.
BGH am 2009-05-27 (XII ZR 78/08) in FamRZ 2009, 1300; NJW 2009, 2523 == Abzug verbrauchsunabhängiger Kosten grundsätzlich nur für nicht umlagefähige Kosten.
BGH am 2012-01-18 (XII ZR 177/09) in FamRZ 2012, 514 == Zur Frage geringeren Wohnbedarfs als tatsächl. Wohnvorteil bei alleiniger Nutzung des Einfamilienhauses beim Trennungsunterhalt.
BGH am 2012-01-18 (XII ZR 178/09) in FamRZ 2012, 517; NJW 2012, 1144 == Regelm. geringerer Wohnbedarf als tatsächl. Wohnvorteil bei alleiniger Nutzung des Einfamilienhauses nach Scheidung.
BGH am 2012-10-31 (XII ZR 30/10) in FamRZ 2013, 191, Tz. 26 == Zur Berücksichtigung des Wohnwerts für ein mit dem Unterhaltspflichtigen im Eigenheim zusammen wohnendes unterhaltsberechtigtes Kind.
BGH am 2014-02-05 (XII ZB 25/13) in FamRZ 2014, 538; NJW 2014, 1173, Tz. 33, 34 == Wohnvorteil nur auf der Grundlage ersparter Miete beim Elternunterhalt
BGH am 2014-03-19 (XII ZB 367/12) in FamRZ 2014, 923, NJW 2014, 1531, Tz. 19, 20 == Zur Bemessung des Wohnwerts für den Nutzer einer Immobilie beim Kindesunterhalt.
BGH am 2014-04-09 (XII ZB 721/12) in NJW 2014, 1733, Tz. 12 == Wohnvorteil aus neuer Wohnung anstelle Zinsvorteil aus Verkaufserlös des Miteigentums an Ehewohnung
BGH am 2017-01-18 (XII ZB 118/16) in FamRZ 2017, 519, NJW 2017, 1169, Tz. 33, 34 == Zum Verhältnis von Wohnwert und Tilgungsleistungen.
6. Haushaltsführung
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
Führt jemand einem leistungsfähigen Dritten den Haushalt, so ist hierfür ein Einkommen anzusetzen, vgl. BGH FamRZ 1995, 343 f. (344); bei Haushaltsführung durch einen nicht Erwerbstätigen geschieht das in der Regel mit einem Betrag von 450,-- €.
BGH am 1995-01-11 (XII ZR 236/93) in FamRZ 1995, 343 f. == Vergütung für Versorgungsleistungen, die der getrenntlebende Ehegatte neben einer Vollzeitbeschäftigung einem neuen Partner erbringt.
BGH am 2012-04-18 (XII ZR 73/10) in NJW 2012, 2190 == Haushälterische Versorgungsleistungen als Einkommen.
7. Einkommen aus unzumutbarer Erwerbstätigkeit
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
Einkommen aus unzumutbarer Erwerbstätigkeit kann nach Billigkeit ganz oder teilweise unberücksichtigt bleiben.
BGH am 2010-04-21 (XII ZR 134/08) in FamRZ 2010, 1050 == Zur Berücksichtigung von Einkommen nach § 1577 II BGB.
BGH am 2011-01-12 (XII ZR 83/08) in FamRZ 2011, 454; NJW 2011, 670 == Zur Berücksichtigung von Einkommen nach Erreichen der Regelaltersgrenze (§ 1577 II BGB).
BGH am 2015-11-11 (XII ZB 7/15) in FamRZ 2016, 199; NJW 2016, 322, Rn. 17 == Teilw. Nichtberücksichtigung überobligatorischen Einkommens d. kinderbetreuenden Gatten.
8. Freiwillige Zuwendungen Dritter
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
Freiwillige Zuwendungen Dritter (z.B. Geldleistungen, kostenloses Wohnen) sind als Einkommen zu berücksichtigen, wenn dies dem Willen des Dritten entspricht.
Keine freiwilligen Zuwendungen Dritter sind Leistungen, die einem Ehegatten im Rahmen des Familienunterhalts zufließen.
Zum Wohnen im Haus seines Ehegatten, mit dem die Lebensgemeinschaft besteht, vgl. BGH FamRZ 2008, 968 ff. (974, Tz. 57).
BGH am 2008-02-06 (XII ZR 14/06) in FamRZ 2008, 968 ff.,974, Tz. 57 == Zum Wohnen im Haus seines Ehegatten.
9. Erwerbsobliegenheit und Einkommensfiktion
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
Einkommen können im Fall einer eingeschränkten oder fehlenden Leistungsfähigkeit auch aufgrund einer unterhaltsrechtlichen Obliegenheit erzielbare Einkünfte sein (fiktives Einkommen), wenn der Unterhaltsverpflichtete eine ihm mögliche und zumutbare Erwerbstätigkeit unterlässt.
Im Rahmen dieser nach den Umständen des Einzelfalls zu bestimmenden Erwerbsobliegenheit, die gegenüber minderjährigen oder ihnen gleichgestellten Kindern nach Maßgabe des § 1603 Abs. 2 S. 1 BGB gesteigert ist, bedarf es bei Ausübung einer Erwerbstätigkeit der Darlegung, dass die Arbeitskraft entsprechend den persönlichen Eigenschaften und Fähigkeiten und der Arbeitsmarktlage in zumutbarer Weise selbst unter Berücksichtigung zumutbarer Arbeitsplatz-, Berufs- oder Ortswechsel bestmöglich eingesetzt wird. Zum Umfang der Obliegenheit im Einzelnen vgl. BGH FamRZ 2009, 314 (317).
Bei Arbeitslosigkeit sind hinreichende Bemühungen um eine Arbeitsstelle und etwaige Tatsachen zur berechtigten Beendigung eines bisher bestehenden Arbeitsverhältnisses darzulegen; dabei bedarf es über die Meldung bei der Agentur für Arbeit hinaus einer nachprüfbaren und belegten Darstellung der ohne Erfolg gebliebenen Bemühungen unter Angabe zu Zeitpunkt, Inhalt und Ergebnis der erfolgten Bewerbungen, die sich im Zweifel auch auf nicht der eigenen Berufsausbildung entsprechende Stellen zu erstrecken haben; der Hinweis auf die Arbeitsmarktlage macht den Nachweis dieser Bemühungen regelmäßig nicht entbehrlich. Zweifel an der Ernsthaftigkeit der Arbeitsbemühungen gehen zu Lasten des Arbeitssuchenden.
Bei unzureichenden Bemühungen um einen Arbeitsplatz können bei einer objektiv feststellbaren realen Beschäftigungschance fiktive Einkünfte nach den Umständen des Einzelfalls unter Berücksichtigung der jeweiligen Verhältnisse auf dem Arbeitsmarkt, insbesondere auch Lohnstruktur und Mindestlöhne, und der persönlichen Eigenschaften des Arbeitssuchenden, insbesondere Alter, Ausbildung, Berufserfahrung, Gesundheitszustand, Geschlecht u. ä., zugrunde gelegt werden; die Feststellung der realen Beschäftigungschance ist auch bei Inanspruchnahme auf den Mindestunterhalt eines minderjährigen Kindes nicht entbehrlich (vgl. BVerfG vom 18. Juni 2012, 1 BvR 774/10, NJW 2012, 2420-2422).
OLG Ffm am 2006-09-29 (5 UF 171/06) in NJW 2007, 382 == Zur notwendigen Berücksichtigung der realen Beschäftigungschancen ungelernter Arbeitskräfte.
BVerfG am 2008-03-18 (1 BvR 125/06) in FamRZ 2008, 1145 == Art. 3 I GG: Verfassungswidrige Zurechnung fiktiver Einkünfte
BGH am 2008-07-30 (XII ZR 126/06) in FamRZ 2008, 2104; NJW 2008, 3635 == Gesonderte Beurteilung für jedes Unterhaltsverhältnis bei Zurechnung fiktiven Einkommens und unterschiedliche Ausgestaltung der Erwerbsobliegenheiten beim Ehegattenunterhalt und beim Kindesunterhalt.
BGH am 2008-12-03 (XII ZR 182/06) in FamRZ 2009, 314; NJW 2009, 1410 == Voraussetzungen für Zurechnung fiktiver Einkünfte, besondere Prüfung der Zumutbarkeit und des erzielbaren Einkommens einer etwaigen Nebentätigkeit
BVerfG am 2010-02-15 (1 BvR 2236/09) in FamRZ 2010, 626 m. Anm. Borth 629 == Prüfungsumfang bei Ansatz fiktiver Einkünfte
BVerfG am 2010-03-11 (1 BvR 3031/08) in FamRZ 2010, 793 == Individuelle Prüfung bei Ansatz fiktiver Einkünfte
BGH am 2011-09-21 (XII ZR 121/09) in FamRZ 2011, 1851; NJW 2011, 3577 == Zahl d. Bewerbungen nur Indiz für ausr. Erwerbsbemühungen. Zur realistischen Erwerbschance.
BGH am 2012-01-18 (XII ZR 178/09) in FamRZ 2012, 517; NJW 2012, 1144 == Darl.- und Beweislast des Berechtigten für fehlende Erwerbschancen.
BVerfG am 2012-06-18 (1 BvR 774/10) in NJW 2012, 2420; ZKJ 2012, 396 == Art. 2 I GG: Unzureichende Begründung für Erzielbarkeit von mtl. 1740 EUR brutto
BVerfG am 2012-06-18 (1 BvR 1530/11) in FamRZ 2012, 1283 == Art. 2 I GG: Unzureichende Begründung für Erzielbarkeit von mtl. 2000 EUR brutto
BVerfG am 2012-06-18 (1 BvR 2867/11) in JAmt 2012, 417 == Art. 2 I GG: Unzureichende Begründung für Erzielbarkeit von mtl. 1800 EUR brutto
BGH am 2014-01-22 (XII ZB 185/12) in FamRZ 2014, 637; NJW 2014, 932 == Zu den (strengen) Maßstäben für die Annahme einer fehlenden realen Beschäftigungschance.
BGH am 2014-09-24 (XII ZB 111/13) in FamRZ 2014, 1992; NJW 2014, 3784 == Zur Zumutbarkeit einer Nebenbeschäftigung trotz voller Erwerbstätigkeit.
BGH am 2015-06-17 (XII ZB 458/14) in Rn. 31 == Fiktives Pflegegeld als Einkommen bei fehlender Pflegeversicherung .
BGH am 2015-07-08 (XII ZB 56/14) in Rn. 12 == Obliegenheit zur Inanspruchnahme von Leistungen der Grundsicherung im Alter und bei Erwerbsminderung.
BGH am 2016-11-09 (XII ZB 227/15) in FamRZ 2017, 109; NZFam 2017, 61 == Zur Erwerbsobliegenheit des Rentenbeziehers wegen Erwerbsunfähigkeit ggü. mdj. Kind.
10. Bereinigung des Einkommens
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
BGH am 2014-07-09 (XII ZB 661/12) in FamRZ 2014, 1536; NJW 2014, 2785 == Zur Ermittlung des Kaufkraftunterschieds mit Eurostat bei im Ausland lebendem Pflichtigen.
10.1 Steuern und Vorsorgeaufwendungen
Vom Bruttoeinkommen sind Steuern und Vorsorgeaufwendungen abzuziehen. Zu den Vorsorgeaufwendungen zählen Aufwendungen für die gesetzliche Kranken- und Pflegeversicherung, Rentenversicherung und Arbeitslosenversicherung und/oder eine angemessene private Kranken- und Altersvorsorge.
Es besteht die Obliegenheit, Steuervorteile in zumutbarem Rahmen in Anspruch zu nehmen. Zur Obliegenheit, das Realsplitting geltend zu machen, siehe BGH FamRZ 2007, 793 ff. und BGH FamRZ 2007, 882 ff.
Aufwendungen für die Altersvorsorge sind bis zu 23% des Bruttoeinkommens, beim Elternunterhalt bis zu 24 % des Bruttoeinkommens (je einschließlich der Gesamtbeiträge von Arbeitnehmern und Arbeitgebern zur gesetzlichen Rentenversicherung, bei Beamten, Richtern, Soldaten deshalb abzüglich des gültigen Rentenbeitragssatzes) abzusetzen. Die darin enthaltene freiwillige, den Beitragssatz der gesetzlichen Rentenversicherung übersteigende, zusätzliche Altersvorsorge kann minderjährigen und privilegiert volljährigen Kindern bei der Geltendmachung von Mindestunterhalt nicht entgegengehalten werden.
Als zusätzliche Altersvorsorge sind neben den zertifizierten Riester- oder Rürupverträgen auch andere Vermögensbildungsmaßnahmen anzusehen, die einer Absicherung im Alter dienen können, insbesondere die Tilgungsleistungen auf Kredite für Immobilien.
Beim Elternunterhalt sind Tilgungsleistungen bis zur Höhe des Wohnvorteils vom Einkommen abzuziehen, ohne dass dies die Befugnis zur Bildung eines zusätzlichen Altersvorsorgevermögens schmälert. Der den Wohnvorteil dann noch übersteigende Tilgungsanteil ist als Vermögensbildung zu Lasten des Unterhaltsberechtigten im Rahmen der sekundären Altersvorsorge auf die Altersvorsorgequote von 5% des Bruttoeinkommens des Elternunterhaltspflichtigen anzurechnen (vgl. BGH vom 18.01.2017, XII ZB 118/16, FamRZ 2017, 519, Rn. 33f).
Altersvorsorge, die unter Beachtung der jeweiligen Unterhaltsgrundsätze, abzugsfähig war, kommt unter Umständen Bestandsschutz zu.
OLG Ffm am 2000-00-00 (3 WF 132/00) == Keine Pflicht zu begrenztem Realsplitting, wenn kein Steuerbescheid als Grundlage vorhanden ist.
BGH am 2004-12-01 (XII ZR 75/02) in FamRZ 2005, 1159 == Zur Berücksichtigung steuerrechtlicher Verluste aus Grundbesitz.
BGH am 2005-05-11 (XII ZR 211/02) in FamRZ 2005, 1817 == Aufwendungen für zusätzliche Altersversorgung abhängig vom Gesamtbruttoeinkommen.
BGH am 2005-05-11 (XII ZR 211/02) in FamRZ 2005, 1817 == Splittingvorteil aus neuer Ehe bei Ehegattenunterhalt irrelevant
OLG Ffm am 2005-10-06 (5 WF 146/05) == Steuervorteil aus neuer Ehe bei Arbeitslosengeld
OLG Ffm am 2006-07-20 (1 UF 180/05) in NJW-RR 2007, 219 = OLG-Report Frankfurt 2006,957 == Zur Erstattungsfähigkeit von Steuervorauszahlungen des Unterhaltsberechtigten wegen Realsplitting
BGH am 2007-02-28 (XII ZR 37/05) in FamRZ 2007, 793; NJW 2007, 1961 == Obliegenheit zur Geltendmachung des Realsplittings nur soweit Unterhaltsanspruch anerkannt ist,rechtskräftig feststeht oder freiwillig erfüllt wird.
BGH am 2007-02-28 (XII ZR 37/05) in FamRZ 2007, 793; NJW 2007, 1961 == Kein fiktiver Abzug von Beiträgen für eine zusätzliche Altersversorgung.
BGH am 2007-05-23 (XII ZR 245/04) in FamRZ 2007, 1232; NJW 2007, 2628 == Fiktives Einkommen und Splittingvorteil bei Wiederverheiratung
BGH am 2007-05-23 (XII ZR 250/04) in FamRZ 2007, 1229; NJW 2007, 2554 == Zur Zustimmungspflicht gemeinsamer Veranlagung.
BGH am 2008-02-06 (XII ZR 14/06) in FamRZ 2008, 968 == Zur Berücksichtigung des Splittingvorteils bei zweiter Ehe und (fiktiver) Berechnung des Realsplittings für die geschiedene Ehe
BGH am 2008-07-30 (XII ZR 177/06) in FamRZ 2008, 1911 ff.,1915 f.; NJW 2008, 3213 ff. == Bei Dreiteilung des Gesamteinkommens ist es mit dem Splittingvorteil aus neuer Ehe zugrunde zu legen (siehe aber BVerfG v. 25.1.2011 bei Nr. 15.5)
BGH am 2008-09-17 (XII ZR 72/06) in FamRZ 2008, 2198; NJW 2008, 3562 == Berücksichtigung des Splittingvorteils für Unterhalt minderjähriger Kinder, soweit auf alleinigem Einkommen des Pflichtigen beruhend.
OLG Ffm am 2009-04-03 (1 UF 218/08) == Nachteilsausgleich beim Realsplitting.
BGH am 2009-05-27 (XII ZR 111/08) in FamRZ 2009, 1207; NJW 2009, 2450 == Zusätzliche Altersvorsorge bis zu 4 % des Bruttoeinkommens
BGH am 2010-06-02 (XII ZR 160/08) in FamRZ 2010, 1318; NJW 2010, 2515 == Zum Splittingvorteil beim Kindesunterhalt.
BGH am 2010-07-28 (XII ZR 140/07) in FamRZ 2010, 1535; NJW 2010, 3161 == Zusätzliche Altersvorsorge bei Eintritt in den Ruhestand vor Erreichung der Altersgrenze
BGH am 2013-01-30 (XII ZR 158/10) in FamRZ 2013, 616; NJW 2013, 1005 == Keine Berücksichtigung zusätzlicher AV/KV, wenn Mindestunterhalt f. mdj. Kind nicht aufgebracht wird
BGH am 2017-01-18 (XII ZB 118/16) in FamRZ 2017, 519, NJW 2017, 1169, Tz. 33, 34 == Abzugsfähigkeit von Tilgungsleistungen bis zu Wohnwert und 5% Altersvorsorgequote beim Elternunterhalt
10.2 Berufsbedingte Aufwendungen
Berufsbedingte Aufwendungen, die sich von den privaten Lebenshaltungskosten nach objektiven Merkmalen eindeutig abgrenzen lassen, sind im Rahmen des Angemessenen vom Nettoeinkommen aus unselbständiger Arbeit abzuziehen.
OLG Bamberg am 2007-01-04 (2 UF 182/06) in FamRZ 2007, 1818 == § 1578 BGB: Nutzung eines Firmenfahrzeugs - Zukünftige Steuererstattung - Erwerb einer neuen Immobilie [LSe]
10.2.1 Pauschale/konkrete Aufwendungen
Bei Vorliegen entsprechender Anhaltspunkte kann eine Pauschale von 5 % des Nettoeinkommens (maximal 150,-- €) abgesetzt werden. Diese Pauschale wird vom Nettoeinkommen vor Abzug von Schulden und besonderen Belastungen abgezogen. Die Pauschale erfasst alle berufsbedingten Aufwendungen einschließlich der Fahrtkosten. Übersteigen die berufsbedingten Aufwendungen diese Pauschale, so sind sie im Einzelnen darzulegen.
10.2.2 Fahrtkosten
Werden berufsbedingte Aufwendungen konkret berechnet, erfolgt ein Abzug von Fahrtkosten zur Arbeitsstätte mit dem eigenen PKW grundsätzlich nur in Höhe der Fahrtkosten öffentlicher Verkehrsmittel, wenn deren Benutzung zumutbar ist. Ist wegen schwieriger öffentlicher Verkehrsverbindungen oder aus sonstigen Gründen die Benutzung eines PKW als angemessen anzuerkennen, so wird eine Kilometerpauschale in Höhe des Betrages nach § 5 Abs. 2 Nr. 2 JVEG (zurzeit 0,30 € für jeden gefahrenen Kilometer) berücksichtigt. Anhaltspunkte für die Bestimmung der Angemessenheit können einerseits die ehelichen Lebensverhältnisse und andererseits das Verhältnis der Fahrtkosten zu dem Einkommen sein.
Die Fahrtkostenpauschale deckt in der Regel sowohl die laufenden Betriebskosten als auch die Anschaffungskosten des PKW ab.
Bei hoher Fahrleistung ist, da die Fahrtkosten nicht gleichmäßig ansteigen, eine abweichende Bewertung veranlasst. In der Regel kann bei einer Entfernung von mehr als 30 km (einfach) und einer PKW-Nutzung an ca. 220 Tagen im Jahr für jeden Mehrkilometer die Pauschale auf die Hälfte des Satzes herabgesetzt werden.
Bei unverhältnismäßig hohen Fahrtkosten infolge weiter Entfernung zum Arbeitsplatz kommt auch eine Obliegenheit zu einem Wohnortwechsel in Betracht (BGH FamRZ 1998, 1501, 1502).
Schwamb == Fahrtkostenrechner
BGH am 2008-12-17 (XII ZR 63/07) in FamRZ 2009, 404; NJW-RR 2009, 649 == Anforderungen an die Darlegungs- und Beweislast bei berufsbedingten Fahrten zur Arbeitsstätte.
BGH am 2012-06-13 (XII ZB 658/11) in FamRZ 2012, 1374 == Unterhaltsrechtliche Fahrtkostenberechnung nicht mehr auf Verfahrenskostenhilfe übertragbar.
BGH am 2012-08-08 (XII ZB 291/11) in FamRZ 2012, 1629 == Fahrtkostenpauschale bei VKH nur für Betriebskosten, keine 40 km-Begrenzung.
10.2.3 Ausbildungsaufwand
Bei Vorliegen entsprechender Anhaltspunkte kann eine Pauschale von 5 % der Ausbildungsvergütung abgesetzt werden. Übersteigen die Aufwendungen diese Pauschale, so sind sie im Einzelnen darzulegen (vgl. Nr. 10.2.1).
10.3 Kinderbetreuung
Kinderbetreuungskosten sind abzugsfähig, soweit die Betreuung durch Dritte infolge der Berufstätigkeit erforderlich ist. Geht ein Ehegatte einer Erwerbstätigkeit nach, obwohl er eines oder mehrere minderjährige Kinder betreut, so kann ihm - auch neben den in Satz 1 genannten konkreten Kosten - noch ein Ausgleich für Aufwendungen bis zu 200 € zugebilligt werden, wenn er darlegt, dass er oder Dritte zusätzliche Aufwendungen durch die Betreuung der Kinder haben (wie z.B. Großeltern, Nachbarn oder Freunde betreuen die Kinder unentgeltlich, ohne dadurch den Unterhaltspflichtigen entlasten zu wollen; Fahrtkosten zu Betreuungsstellen etc.). Für die Höhe dieses Betrags sind u.a. folgende Faktoren von Bedeutung: Zahl und Alter der Kinder; Umfang der Berufstätigkeit; Umfang der Fremdbetreuung, deren Kosten nicht im Rahmen der in S.1 genannten konkreten Kosten geltend gemacht werden; Höhe der konkreten Kosten.
Zum Aufwand für die Betreuung des Kindes zählen nicht die Kosten einer Kindertagesstätte (Kinderkrippe, Kindergarten, Schülerhort); diese sind Mehrbedarf des Kindes und nach dem Verhältnis der beiderseitigen Einkünfte zwischen den Eltern aufzuteilen (siehe Nr. 12.4). Die auf jeden Elternteil entfallenden Anteile bzw. tatsächlich gezahlten Beträge sind als Kindesunterhalt vom Einkommen vorweg abzuziehen.
BGH am 2010-04-21 (XII ZR 134/08) in FamRZ 2010, 1050 == Keine Berücksichtigung eines pauschalen "Betreuungsbonus" bei Kinderbetreuung und Berufstätigkeit.
BGH am 2017-02-15 (XII ZB 201/16) in FamRZ 2017, 711, NJW 2017, 1881, Rn. 19 == Kein Betreuungsbonus bei Erwerbstätigkeit neben Betreuungstätigkeit.
BGH am 2017-10-04 (XII ZB 55/17) in FamRZ 2018, 23, NJW 2017, 3786, Rn. 18, 19 == Betreuungskosten des betreuenden Elternteils.
10.4 Schulden
Berücksichtigungswürdige Schulden (Zins und Tilgung) sind abzuziehen; die Abzahlung soll im Rahmen eines vernünftigen Tilgungsplanes in angemessenen Raten erfolgen. Zur Obliegenheit, im Einzelfall ein Verbraucherinsolvenzverfahren einzuleiten, um für Kindesunterhalt leistungsfähig zu werden, vgl. BGH FamRZ 2005, 608 f.; beim Ehegattenunterhalt besteht eine solche Obliegenheit nicht (BGH FamRZ 2008, 497). Bei der Bedarfsermittlung für den Ehegattenunterhalt sind unterhaltsrechtlich nicht vorwerfbar eingegangene Verbindlichkeiten grundsätzlich abzusetzen. Sowohl beim Verwandten- als auch beim Ehegattenunterhalt erfolgt noch eine Abwägung nach den Umständen des Einzelfalls. Bei der Zumutbarkeitsabwägung sind Interessen des Unterhaltsschuldners, des Drittgläubigers und des Unterhaltsgläubigers, vor allem minderjähriger Kinder, mit zu berücksichtigen. Bei der Unterhaltsbemessung nach einem fiktiven Einkommen ist auch ein fiktiver Schuldendienst berücksichtigungsfähig.
BGH am 2005-02-23 (XII ZR 114/03) in FamRZ 2005, 608 == Grundsätzl. Obliegenheit zur Verbraucherinsolvenz, falls geeignet für Erhöhung der Leistungsfähigkeit zum Kindesunterhalt.
BGH am 2007-12-12 (XII ZR 23/06) in FamRZ 2008, 497; NJW 2008, 851 == Keine zur Obliegenheit Einleitung der Verbraucherinsolvenz für Trennungsunterhalt.
BGH am 2010-06-02 (XII ZR 138/08) in FamRZ 2010, 1311; NJW 2010, 2582 == Keine Verpflichtung zur Verbraucherinsolvenz für Ehegattenunterhaltsschuldner.
BGH am 2010-07-28 (XII ZR 140/07) in FamRZ 2010, 1535; NJW 2010, 3161 == Keine Abzugsfähigkeit von Hausrat- und Haftpflichtversicherungsbeiträgen.
BGH am 2014-03-19 (XII ZB 367/12) in FamRZ 2014, 923, NJW 2014, 1531, Tz. 23, 24 - 26, 29 == Zu Nachteilen der Einl. eines Insolvenzverfahrens sowie zur Abzugsfähigkeit von Hausdarlehen und PKW-Kredit beim Kindesunterhalt.
BGH am 2017-01-18 (XII ZB 118/16) in FamRZ 2017, 519, NJW 2017, 1169, Tz. 33, 34 == Abzugsfähigkeit von Tilgungsleistungen bis zum Wohnwert bei Elternunterhalt.
10.5 Unterhaltsleistungen (bleibt unbesetzt)
10.6 Vermögensbildung
Vermögensbildende Aufwendungen sind bei guten Einkommensverhältnissen im angemessenen Rahmen abzugsfähig.
BGH am 2008-03-05 (XII ZR 22/06) in FamRZ 2008, 963; NJW 2008, 1946 == Keine einseitige Vermögensbildung des Unterhaltspflichtigen zu Lasten des Unterhaltsberechtigten.
10.7 Umgangskosten
Notwendige Kosten des Umgangs, die über den dem Umgangsberechtigten verbleibenden Anteil am Kindergeld erheblich hinausgehen, können sich einkommensmindernd auswirken.
BGH am 2009-06-17 (XII ZR 102/08) in FamRZ 2009, 1391; NJW 2009, 2592 == Zu berücksichtigende Kosten der Ausübung des Umgangsrechts, die deutlich über den verbleibenden Anteil der Entlastung durch das hälftige Kindergeld hinausgehen
BGH am 2014-03-12 (XII ZB 234/13) in FamRZ 2014, 917, Tz. 37, 38 == Bedarfsminderung eines KIndes bei erhöhten Aufwendungen eines Elternteils infolge Ausübung erweiterten Umgangsrechts
BGH am 2014-11-05 (XII ZB 599/13) in FamRZ 2015, 236; NJW 2015, 331; Rn. 22 == Zur Berücksichtigung erhöhter Aufwendungen infolge Ausübung erweiterten Umgangsrechts.
Kindesunterhalt
11. Bemessungsgrundlage (Tabellenunterhalt)
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
Der Barunterhalt minderjähriger und noch im elterlichen Haushalt lebender volljähriger unverheirateter Kinder bestimmt sich nach den Sätzen der Düsseldorfer Tabelle ohne Bedarfskontrollbeträge (Anhang 1). Bei minderjährigen Kindern kann er als Festbetrag oder als Prozentsatz des jeweiligen Mindestunterhalts geltend gemacht werden.
BGH am 2008-09-17 (XII ZR 72/06) in FamRZ 2008, 2198; NJW 2008, 3562 == Kindesunterhalt nur in Höhe des Existenzminimums beim Mangelfall (auch im Verhältnis zu nur nachrangig Berechtigten)
BGH am 2010-06-02 (XII ZR 160/08) in FamRZ 2010, 1318; NJW 2010, 2515 == KIndesunterhalt nur in Höhe der Zahlbeträge des Mindestunterhalts im Mangelfall.
BGH am 2015-09-23 (XII ZR 99/14) in FamRZ 2015, 2134; NJW 2015, 3434, Rn. 23 == Höhe d. vertraglichen KIndesunterhalts bei Einwilligung zur heterologen künstl. Befruchtung.
BGH am 2018-09-19 (XII ZB 385/17) in NJW 2018, 3648 == Mindestunterhalt Mdj. auch beim Scheinvaterregress nicht darlegungsbedürftig.
11.1 Kranken- und Pflegeversicherungsbeiträge
Die Tabellensätze der Düsseldorfer Tabelle enthalten keine Kranken- und Pflegeversicherungsbeiträge für das Kind, wenn dieses nicht in einer gesetzlichen Familienversicherung mitversichert ist. Dieser Aufwand gehört jedoch zum Grundbedarf und ist von dem/den Barunterhaltspflichtigen zu tragen.
Besteht für das Kind eine freiwillige Krankenversicherung, so sind die hierfür erforderlichen Beiträge von dem/den Barunterhaltspflichtigen zusätzlich zu zahlen, zur Ermittlung des Tabellenunterhalts jedoch in Höhe des jeweiligen Anteils vom Einkommen abzusetzen.
BGH am 2018-02-07 (XII ZB 338/17) in FamRZ 2018, 681 Rn. 28 == Beiträge zur Kranken-/Pflegeversicherung Mdj. vom Barunterhaltspfl. zu tragen
11.2 Eingruppierung
Die Tabellensätze sind auf den Fall zugeschnitten, dass der Unterhaltspflichtige zwei Unterhaltsberechtigten (ohne Rücksicht auf den Rang, soweit für den Nachrangigen Mittel vorhanden sind) Unterhalt zu gewähren hat. Bei einer größeren oder geringeren Anzahl Unterhaltsberechtigter sind in der Regel Ab- oder Zuschläge durch Einstufung in niedrigere oder höhere Einkommensgruppen vorzunehmen. Liegt insoweit das verfügbare Einkommen des Unterhaltspflichtigen im Bereich bis 1.500,- €, ist für die Aufstufung eine besondere Prüfung notwendig.
BGH am 2005-05-11 (XII ZR 211/02) in FamRZ 2005, 1817 == Aufwendungen für Stiefkind (neue Ehe) bleiben außer Betracht.
BGH am 2013-01-30 (XII ZR 158/10) in FamRZ 2013, 616; NJW 2013, 1005 == Keine Berücksichtigung zusätzlicher AV/KV, wenn Mindestunterhalt f. mdj. Kind nicht aufgebracht wird
12. Minderjährige Kinder
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
12.1 Betreuungs-/Barunterhalt
Der sorgeberechtigte Elternteil, der ein minderjähriges Kind betreut, leistet in der Regel hierdurch seinen Beitrag zum Kindesunterhalt (§ 1606 Abs. 3 S. 2 BGB).
BGH am 2014-10-29 (XII ZB 250/14) in FamRZ 2015, 130; NJW 2015, 232; FamRB 2015, 5 (Anm. Schwamb) == Zulässigkeit der Vertretung des Kindes getrenntlebender Eltern durch das Jugendamt als Beistand zur Geltendmachung von Unterhalt.
BGH am 2017-03-01 (XII ZB 2/16) in FamRZ 2017, 816, Rn. 17 == Zur Fortsetzung vereinf. Verfahrens der UV-Kasse nach Obhutswechsel.
BGH am 2018-02-07 (XII ZB 338/17) in FamRZ 2018, 681 == Kein familienrechtl. Ausgleichsanspruch mit Drittwiderantrag im Kindesunterhaltsverfahren
12.2 Einkommen des Kindes
Einkommen des Kindes wird bei beiden Eltern hälftig angerechnet. Zum Kindergeld vgl. Nr. 14.
12.3. Beiderseitige Barunterhaltspflicht / Haftungsanteil
Der betreuende Elternteil braucht neben dem anderen Elternteil in der Regel keinen Barunterhalt zu leisten (§ 1606 Abs. 3 Satz 2 BGB), es sei denn a) der angemessene Selbstbehalt des nicht betreuenden Elternteils wäre durch den Barbedarf des Kindes gefährdet und der betreuende Elternteil wäre insoweit leistungsfähig, ohne dass sein eigener angemessener Selbstbehalt gefährdet würde (§ 1603 Abs.2 Satz 3 BGB, vgl. BGH FamRZ 2011, 1041),
oder b) der angemessene Selbstbehalt des nicht betreuenden Elternteils wäre durch den Barbedarf des Kindes zwar nicht gefährdet, die Leistungsfähigkeit des betreuenden Elternteils ist aber bedeutend höher als diejenige des nicht betreuenden Elternteils, etwa bei dreifach höherem verfügbaren Einkommen oder guten Vermögensverhältnissen (vgl. BGH vom 10.07.2013, XII ZB 297/12 = FamRZ 2013, 1558). Fall a) führt dazu, dass das Einkommen des nicht betreuenden Elternteils nur bis zur Grenze seines angemessenen Selbstbehalts für Unterhaltszahlungen einzusetzen ist und dass im Übrigen der betreuende Elternteil im Rahmen seiner Ausfallhaftung für den Barunterhalt des Kindes haftet. Fall b) führt zur Kürzung bis hin zum völligen Wegfall der Barunterhaltspflicht des nicht betreuenden Elternteils.
Sind bei auswärtiger Unterbringung des Kindes beide Eltern zum Barunterhalt verpflichtet, haften sie anteilig nach § 1606 Abs. 3 Satz 1 BGB für den Gesamtbedarf (vgl. Nr. 13.3). Der Verteilungsschlüssel kann unter Berücksichtigung des Betreuungsaufwandes wertend verändert werden.
BGH am 2005-12-21 (XII ZR 126/03) in FamRZ 2006, 1015; NJW 2006, 2258 == Anteilige Barunterhaltspflicht bei Wechselmodell
BGH am 2006-10-05 (XII ZR 197/02) in FamRZ 2006, 1827; NJW 2007, 139 == Klage auf Kindesunterhalt gegen wiederverheirateten Hausmann
BGH am 2007-02-28 (XII ZR 161/04) in FamRZ 2007, 707; NJW 2007, 1882 == Barunterhaltspflicht bei abwechselnder Betreuung
BGH am 2011-05-04 (XII ZR 70/09) in FamRZ 2011, 1041 == Zum ausnahmsweise angemessenen Selbstbehalt für barunterhaltspflichtigen Elternteil
BGH am 2013-07-10 (XII ZB 297/12) in NJW 2013, 2897 == Ausnahmsweise Barunterhaltspflicht des betreuenden Elternteils
BGH am 2014-03-12 (XII ZB 234/13) in FamRZ 2014, 917, Tz. 16, 17 == Barunterhaltspflicht bei weit über das übliche Maß hinausgehendem Umgangsrecht; Abgrenzung zum Wechselmodell
BGH am 2014-11-05 (XII ZB 599/13) in FamRZ 2015, 236; NJW 2015, 331 == Zur beiderseitigen Barunterhaltspflicht beim Wechselmodell; Abgrenzung zum Wechselmodell
BGH am 2015-02-11 (XII ZB 181/14) in FamRZ 2015, 738; NJW 2015, 1178, Rn. 19 == Keine Erwerbsverpfl. bei zu akz. Kindesbetreuung in dessen beiden ersten Lebensjahren auch bei Unterhaltsverpfl. ggü. Mdj.
BGH am 2016-04-20 (XII ZB 45/15) in FamRZ 2016, 1053; NJW 2016, 1956, Rn. 15, 16 == Beiderseitige Barunterhaltspflicht beim Wechselmodell.
OLG Ffm am 2016-10-17 (6 UF 242/16) in FamRZ 2017, 289, NJW 2017, 336 == Übertragung der Entscheidungsbefugnis zur Geltendmachung von Kindesunterhalt bei paritätischer Betreuung
OLG Ffm am 2016-12-08 (1 UF 68/16) in FamRZ 2017, 889 == Kindesunterhalt bei erweitertem Umgang; Abgrenzung zum Wechselmodell
BGH am 2017-01-11 (XII ZB 565/15) in FamRZ 2017, 437; NJW 2017, 1676, Rn. 23, 41 ff. == Beiderseitige Barunterhaltspflicht und Geltendmachung der Unterhaltsspitze beim Wechselmodell.
BGH am 2017-02-01 (XII ZB 601/15) in FamRZ 2017, 532, NJW 2017, 1815, Rn. 19; NZFam 2017, 253, 254 (Anm. Schwamb) == Übertragung der Entscheidungsbefugnis bei paritätischer Betreuung
BGH am 2017-02-08 (XII ZB 116/16) in FamRZ 2017, 611, NJW 2017, 1108 == Familienrechtlicher Ausgleich nach Abänderung eines Vergleichs bei beiderseitiger Unterhaltspflicht.
BGH am 2017-02-15 (XII ZB 201/16) in FamRZ 2017, 711, NJW 2017, 1881, Rn. 14; Anm. Niepmann/Schwamb NJW 2017, 1854 Sp. 2 == Abzugsfähigkeit von Kindesunterhalt einschließlich Naturalunterhalt des Betreuenden.
12.4 Zusatzbedarf
Bei Zusatzbedarf (Verfahrenskostenvorschuss, Mehrbedarf, Sonderbedarf) gilt § 1606 Abs. 3 Satz 1 BGB (vgl. Nr.13.3). Zum Mehrbedarf des Kindes zählen die Kosten für den Besuch einer Kindertagesstätte (Kinderkrippe, Kindergarten, Schülerhort) abzüglich des ersparten Verpflegungsmehraufwandes. Schulpaket und Bildungspaket ergeben keinen Zusatzbedarf.
OLG Ffm am 2006-01-11 (1 UF 189/05) in NJW-RR 2006, 1303=OLG Report 2006, 590 == Mehrbedarf bei Kosten eines Ganztagskindergartens
BGH am 2006-02-15 (XII ZR 4/04) in FamRZ 2006, 612 == Konfirmationskosten sind kein Sonderbedarf.
BGH am 2008-11-26 (XII ZR 65/07) in FamRZ 2009, 962; NJW 2009, 1816 == Kindergartenbeiträge u. ä. sind nicht in Unterhaltstabellenbeträgen enthalten (Aufgabe der bish. Rspr.). Verpflegungskosten sind mit dem Tabellenunterhalt abgegolten.
BGH am 2013-07-10 (XII ZB 298/12) in NJW 2013, 2900, Tz. 7, 12 == Mehrbedarf des Kindes infolge Förderunterricht bei einem privaten Lehrinstitut
BGH am 2017-10-04 (XII ZB 55/17) in FamRZ 2018, 23, NJW 2017, 3786, Rn. 18, 19 == Kein Mehrbedarf des Kindes wegen Betreuungskosten des betreuenden Elternteils.
13. Volljährige Kinder
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
13.1 Bedarf
Beim Bedarf volljähriger Kinder ist zu unterscheiden, ob sie noch im Haushalt der Eltern / eines Elternteils leben oder einen eigenen Hausstand haben.
13.1.1
Für volljährige Kinder, die noch im Haushalt der Eltern oder eines Elternteils wohnen, gilt die Altersstufe 4 der Düsseldorfer Tabelle. Sind beide Elternteile leistungsfähig (vgl. Nr. 21.3.1), ist der Bedarf des Kindes in der Regel nach dem zusammengerechneten Einkommen zu bemessen. Hierbei findet bei einer Unterhaltsverpflichtung gegenüber nur einem Kind eine Höherstufung um eine Einkommensgruppe nicht statt ((vgl. entsprechend beim früheren Zuschnitt der Tabelle auf drei Unterhaltsberechtigte OLG Hamm FamRZ 1993, 353, 355, bestätigt durch BGH FamRZ 1994, 696, 697). Für die Haftungsquote gilt Nr.13.3. Ein Elternteil hat jedoch höchstens den Unterhalt zu leisten, der sich allein aus seinem Einkommen aus der Düsseldorfer Tabelle ergibt.
Dies gilt auch für ein Kind im Sinne des § 1603 Abs. 2 Satz 2 BGB.
Erzielt das volljährige Kind eigenes Einkommen, beträgt der Unterhaltsbedarf (ohne Kranken-/Pflegeversicherungsbedarf) mindestens monatlich 610 €.
13.1.2
Der angemessene Bedarf eines volljährigen Kindes mit eigenem Hausstand beträgt in der Regel monatlich 735 € (darin sind enthalten Kosten für Unterkunft und Heizung bis zu 300 €), ohne Beiträge zur Kranken- und Pflegeversicherung sowie ohne Studiengebühren. Von diesem Betrag kann bei erhöhtem Bedarf oder mit Rücksicht auf die Lebensstellung der Eltern abgewichen werden.
OLG Ffm am 2007-06-20 == In den Unterhaltsbeträgen sind Beiträge zur Kranken- und Pflegeversicherung sowie Studiengebühren nicht enthalten
13.2 Einkommen des Kindes
Auf den Unterhaltsbedarf werden Einkünfte des Kindes, auch das Kindergeld (siehe Nr. 14), BAföG-Darlehen und Ausbildungsbeihilfen (gekürzt um ausbildungsbedingte Aufwendungen, vgl. Nr. 10.2.3) angerechnet. Bei Einkünften aus unzumutbarer Erwerbstätigkeit gilt § 1577 Abs. 2 BGB entsprechend.
BGH am 2005-10-26 (XII ZR 34/03) in FamRZ 2006, 99; NJW 2006, 57 == Bei vollj. Kind volle Anrechnung des Kindergeldes und der um die Ausbildungspauschale verminderten Ausbildungsvergütung.
BGH am 2011-06-29 (XII ZR 127/09) in FamRZ 2011, 1560; NJW 2011, 2884 == Ausbildungsunterhalt auch bei Verzögerung d. Ausb. wegen Schwangerschaft u. Kindesbetreuung; Keine Anrechnung von Vorausleistungen nach § 36 BAföG.
BGH am 2013-07-03 (XII ZB 220/12) in NJW 2013, 2751 == Unterhalt für eine drei Jahre nach Schulabschluss beginnende Ausbildung
BGH am 2013-07-17 (XII ZR 49/12) in FamRZ 2013, 1644 == Ausbildungsunterhalt aus übergegangenem Recht wegen BAföG-Bezugs
BGH am 2017-03-08 (XII ZB 192/16) in FamRZ 2017, 799, NJW 2017, 1478 == Zur Einheitlichkeit des Ausbildungsgangs bei Abitur-Lehre-Studium.
BGH am 2017-05-03 (XII ZB 415/16) in FamRZ 2017, 1132; NJW 2017, 2278 == Zur Zumutbarkeit von Ausbildungsunterhalt bei Abitur-Lehre-Studium.
13.3 Beiderseitige Barunterhaltspflicht / Haftungsanteil
Für den Bedarf des Volljährigen haften die Eltern anteilig nach dem Verhältnis ihrer verfügbaren Einkommen. Vor der Bildung der Haftungsquote sind der angemessene Selbstbehalt jedes Elternteils (1.300 €, siehe Nr. 21.3.1) und der Unterhalt vorrangig Berechtigter abzusetzen (vgl. zur Berechnungsmethode BGH FamRZ 1986, 151 = NJW-RR 1986, 426; FamRZ 1986, 153 = NJW-RR 1986, 293). Die Haftung ist auf den Tabellenbetrag nach Maßgabe des eigenen Einkommens des jeweils Verpflichteten begrenzt.
Diese Berechnung findet für den Bedarf des volljährigen Schülers im Sinne des § 1603 Abs.2 Satz 2 BGB entsprechende Anwendung: Zur Bildung der Haftungsquote ist vorab der angemessene Selbstbehalt jedes Elternteils und der Barbedarf weiterer jetzt gleichrangiger Kinder abzusetzen, wenn der verbleibende Betrag zur Bedarfsdeckung aller Kinder ausreicht. Ist dies nicht der Fall (Mangelfall) wird der Selbstbehalt auf den notwendigen Selbstbehalt herabgesetzt. Außerdem ist statt eines Vorwegabzugs des Bedarfs der anderen Kinder der Bedarf des volljährigen Kindes aus dem nach Abzug des eigenen Selbstbehalts der Eltern verbleibenden Betrag anteilig zu befriedigen. Zur Berechnungsweise im Übrigen vgl. BGH FamRZ 2002, 815, (818).
BGH am 2002-01-09 (XII ZR 34/00) in FamRZ 2002, 815, 818 == Barunterhaltspflicht beider Elternteile beim Unterhalt privilegiert Volljähriger.
BGH am 2011-01-12 (XII ZR 83/08) in FamRZ 2011, 454; NJW 2011, 670 == Haftungsanteile der Eltern beim Unterhalt privilegiert Volljähriger.
BGH am 2016-12-07 (XII ZB 422/15) in FamRZ 2017, 370; NZFam 2017, 111 == Darlegungs- und Beweislast des vollj. Kindes für Haftungsanteile bei Abänderung.
14. Verrechnung des Kindergeldes
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
Es wird nach § 1612 b BGB ausgeglichen.
Für das gesamte Jahr 2015, d. h. auch für die Zeit vom 01.08.2015 bis 31.12.2015, bleiben dabei die bis 2014 geltenden Kindergeldbeträge (monatlich 184 EUR für erste und zweite Kinder, 190 EUR für dritte Kinder und 215 EUR für das vierte und jedes weitere Kind ) maßgeblich.
BGH am 2005-10-26 (XII ZR 34/03) in FamRZ 2006, 99; NJW 2006, 57 == Bei vollj. Kind volle Anrechnung des Kindergeldes
BGH am 2010-06-23 (XII ZR 170/08) in NJW 2010, 2957 == Kindergeld keine Voraussetzung für Anspruchsübergang nach § 94 II SGB XII
BVerfG am 2011-07-14 (1 BvR 932/10) in FamRZ 2011, 1490; NJW 2011, 3215 == 1612b BGB: Kindergeld jetzt Eink. des Kindes
BGH am 2016-04-20 (XII ZB 45/15) in FamRZ 2016, 1053; NJW 2016, 1956 == Zum isolierten Kindergeldausgleich beim Wechselmodell.
BGH am 2017-01-11 (XII ZB 565/15) in FamRZ 2017, 437; NJW 2017, 1676, Rn. 47 ff. == Kindergeldausgleich durch Verrechnung mit Kindesunterhalt beim Wechselmodell.
BGH am 2017-02-15 (XII ZB 201/16) in FamRZ 2017, 711, NJW 2017, 1881, Tz. 15 ff. == Betreuungsanteil des Kindergeldes kein unterhaltsrelevantes Einkommen.
Ehegattenunterhalt
15. Unterhaltsbedarf
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
Der Unterhaltsanspruch eines bedürftigen Ehegatten (§§ 1361, 1569 ff. BGB) besteht in dem Unterschiedsbetrag zwischen seinem eheangemessenen Bedarf und seinen tatsächlich erzielten oder zurechenbaren Einkünften im Rahmen der Leistungsfähigkeit des Verpflichteten.
15.1 Bedarf nach ehelichen Lebensverhältnissen
Bei der Bedarfsbemessung ist das eheprägende Einkommen zu berücksichtigen (Stichtag: Rechtskraft der Scheidung).
Umstände, die auch bei fortbestehender Ehe eingetreten wären, und Umstände, die bereits in anderer Weise in der Ehe angelegt und mit hoher Wahrscheinlichkeit zu erwarten waren, sind zu berücksichtigen. Dies gilt für normale absehbare weitere Entwicklungen von Einkünften aus derselben Einkommensquelle, wie für übliche Lohnerhöhungen, sowie einen nicht vorwerfbaren nachehelichen Einkommensrückgang, etwa durch Arbeitslosigkeit, Eintritt in das gesetzliche Rentenalter oder Krankheit. Ist der Pflichtige wieder verheiratet, berechnet sich der Bedarf des früheren Ehegatten aufgrund einer fiktiven Besteuerung der Einkünfte des Pflichtigen nach der Grundtabelle, also ohne den Splittingvorteil. Unterhaltsleistungen, die während der Ehe für Kinder erbracht worden sind, prägen die Ehe und sind daher bei der Bedarfsberechnung grundsätzlich vorweg in Abzug zu bringen. Zu den bei der Bedarfsberechnung zu beachtenden Umständen gehört auch das Hinzutreten weiterer Unterhaltsberechtigter bis zur rechtskräftigen Ehescheidung. Auch ein Unterhaltsanspruch aus § 1615l BGB, den ein betreuender Elternteil eines vor der Rechtskraft der Scheidung geborenen Kindes hat, prägt die ehelichen Lebensverhältnisse. Dagegen sind die Unterhaltspflichten für ein nach Rechtskraft der Scheidung geborenes Kind, gegenüber dessen betreuenden Elternteil nach § 1615l BGB sowie gegenüber einem späteren Ehegatten bei der Bemessung des Unterhaltsbedarfs nach § 1578 Abs. 1 S.1 BGB (anders als bei der Leistungsfähigkeit) nicht zu berücksichtigen (siehe Nr. 15.5).
Das Unterhaltsrecht will den geschiedenen Ehegatten nicht besser stellen, als er während der Ehe stand oder aufgrund einer absehbaren Entwicklung ohne die Scheidung stehen würde. Daher sind nur solche Steigerungen des verfügbaren Einkommens zu berücksichtigen, die schon in der Ehe angelegt waren, nicht aber z. B. ein Einkommenszuwachs infolge eines Karrieresprungs.
Soweit ein nachehelicher Karrieresprung lediglich einen neu hinzugetretenen Unterhaltsbedarf auffängt und nicht zu einer Erhöhung des Unterhalts nach den während der Ehe absehbaren Verhältnissen führt, ist das daraus resultierende Einkommen aber in die Unterhaltsbemessung einzubeziehen.
Einkünfte, die aus einer überobligationsmäßig ausgeübten Erwerbstätigkeit erzielt werden, prägen die ehelichen Lebensverhältnisse nicht (BGH FamRZ 2003, 518).
Der Mindestbedarf eines Ehegatten liegt aber nicht unter 880,- Euro, ggf. abzüglich etwa zu berücksichtigender Synergieeffekte durch Zusammenleben mit einem leistungsfähigen Partner.
BGH am 2003-01-22 (XII ZR 186/01) in FamRZ 2003, 518 == Zur Anrechnung eines überobligationsmäßigen Einkommensanteils
BGH am 2005-05-11 (XII ZR 211/02) in FamRZ 2005, 1817 == Zum Einsatzzeitunkt für Aufstockungsunterhalt
BGH am 2007-02-28 (XII ZR 37/05) in FamRZ 2007, 793; NJW 2007, 1961 == Einkommensverminderung durch Eintritt in Religionsgemeinschaft
BGH am 2007-02-28 (XII ZR 37/05) in FamRZ 2007, 793; NJW 2007, 1961 == nachehelicher Karrieresprung nicht eheprägend
BGH am 2008-02-06 (XII ZR 14/06) in FamRZ 2008, 968 == Zur Berücksichtigung späterer Änderungen des verfügbaren Einkommens.
BGH am 2008-07-30 (XII ZR 126/06) in FamRZ 2008, 2104; NJW 2008, 3635 == Berücksichtigung anteiliger Haftung beider Eltern für den Volljährigenunterhalt bei Bemessung des Ehegattenunterhalts
BGH am 2008-10-01 (XII ZR 62/07) in FamRZ 2009, 23; NJW 2009, 145 == Verpflichtung gegenüber adoptiertem Kind ist zu berücksichtigen (§ 1578 Abs. 1 S. 1 BGB).
BGH am 2008-12-17 (XII ZR 9/07) in FamRZ 2009, 411; NJW 2009, 588 == Keine Besserstellung des unterhaltsberechtigten Ehegatten durch nachehelichen Karrieresprung des Verpflichteten.
BGH am 2009-10-14 (XII ZR 146/08) in FamRZ 2009, 1990; NJW 2009, 3783 == Angemessener Lebensbedarf (als Untergrenze nach § 1578 b BGB) muss wenigstens das Existenzminimum erreichen.
BGH am 2010-06-02 (XII ZR 138/08) in FamRZ 2010, 1311; NJW 2010, 2582 == Zur Nichtberücksichtigung einer Abfindung neben normalem Einkommen nach Scheidung beim Ehegattenunterhalt.
BGH am 2014-02-26 (XII ZB 235/12) in FamRZ 2014, 823; NJW 2014, 1302, Tz. 10 == Abgrenzung zwischen §§ 1570 - 1572 BGB (UE wegen Erwerbshindernis) und Aufstockungsunterhalt (§ 1573 I BGB).
BGH am 2014-05-14 (XII ZB 301/12) in FamRZ 2014, 1276; NJW 2014, 2192, Tz. 20 ff. == Zum Bedarf nach ehel. Lebensverh im Alter (keine Auswirkung von VA für zweite Ehefrau; Bezug von Kapitalrente) .
BGH am 2015-09-30 (XII ZB 1/15) in FamRZ 2015, 2131; NJW 2015, 3715 == Bedarfsermittlung vor Feststellung unwirksamen Verzichts auf künftigen Trennungsunterhalt.
BGH am 2015-11-04 (XII ZR 6/15) in FamRZ 2016, 203; NJW 2016, 153, Rn. 18 == Keine Unterbrechung der Unterhaltskette b. Aufstockungsunterhalt durch vorübergehende Arbeitslosigk. d. Unterhaltspfl.
BGH am 2015-11-11 (XII ZB 7/15) in FamRZ 2016, 199; NJW 2016, 322, Rn. 16 == Aufstockungsunterhaltsanspruch entsteht erst durch Vorwegabzug d. Kindesunterhalts.
15.2 Halbteilung und Erwerbstätigenbonus
Der eheangemessene Bedarf eines Ehegatten (ohne Vorsorgebedarf) beträgt (ungeachtet eines etwaigen Erwerbstätigenbonus) 1/2 des den ehelichen Lebensverhältnissen entsprechenden Einkommens eines oder beider Ehegatten, bereinigt um die berücksichtigungsfähigen Lasten und den Zahlbetrag des Kindesunterhalts (Quotenunterhalt).
Erbringt der Verpflichtete sowohl Bar- als auch Betreuungsunterhalt, so gilt Nr. 10.3 (BGH FamRZ 2001, 350).
Auf Erwerbstätigkeit beruhendes Einkommen der Ehegatten wird bei quotaler Bedarfsberechnung vorab um einen Bonus von 1/7 bereinigt. Dieser wird jeweils nach Abzug der mit der Erzielung des Erwerbseinkommens verbundenen Aufwendungen (Werbungskosten) sowie grundsätzlich der ehelichen Lasten und des von dem Erwerbstätigen zu leistenden Kindesunterhalts berechnet.
Bei der Prüfung der Leistungsfähigkeit des Unterhaltspflichtigen ist ein Erwerbstätigkeitsbonus nicht zu berücksichtigen, siehe Ziffer 21.4.
Sind mit der Erzielung von Nichterwerbseinkommen (insbes. Wohnvorteil, Kapitaleinkünfte pp.) besondere Aufwendungen verbunden, werden diese von der jeweiligen Einkunftsart abgezogen.
Nach der Anrechnungsmethode sind Einkünfte des Berechtigten aus Vermögen, das in der Ehe nicht für den Lebensunterhalt zur Verfügung stand, * zu berücksichtigen.
[* "... sowie Einkünfte aus dem vom Pflichtigen geleisteten Altersvorsorgeunterhalt ..." wurde im Hinblick auf BGH FamRZ 2014, 1276, Rn. 21 f., gestrichen.]
BGH am 2000-11-29 (XII ZR 212/98) in FamRZ 2001, 350 == Verpflichteter erbringt Bar- und Betreuungsunterhalt
OLG Ffm am 2005-02-02 (4 WF 136/04) == Erweiterter Umgang kann Unterhaltsanspruch reduzieren
Knoche am 2008-02-19 == Vorwegabzug des Tabellen- oder Zahlbetrages
OLG Ffm am 2008-04-30 (5 UF 67/07) in NJW-RR 2009, 2 == Abzug des Kindergeldes
BGH am 2009-05-27 (XII ZR 78/08) in FamRZ 2009, 1300; NJW 2009, 2523 == Vorwegabzug des Zahlbetrags (statt Tabellenbetrags) verstößt nicht gegen Art. 3 Abs. 1 GG.
BGH am 2009-06-17 (XII ZR 102/08) in FamRZ 2009, 1391; NJW 2009, 2592 == Vorwegabzug des Zahlbetrags (statt Tabellenbetrags) bei Bemessung nachehelichen Unterhalts.
BGH am 2009-06-24 (XII ZR 161/08) in FamRZ 2009, 1477; NJW 2009, 2744 == Vorwegabzug des Zahlbetrags (statt Tabellenbetrags) auch bei Beurteilung der Leistungsfähigkeit für Ehegattenunterhalt.
BGH am 2010-04-14 (XII ZR 89/08) in FamRZ 2010, 869, NJW 2010, 2056 Tz. 27 == Vorwegabzug des Zahlbetrags.
BVerfG am 2011-07-14 (1 BvR 932/10) in FamRZ 2011, 1490; NJW 2011, 3215 == Art.3 I GG, §§ 1578, 1612b BGB: Keine Ungleichbehandlung durch Vorwegabzug des Zahlbetrags.
BGH am 2014-05-07 (XII ZB 258/13) in FamRZ 2014, 1183; NJW 2014, 2109, Tz. 37, 38 == Ehegattenunterhalt nach Vorwegabzug (nur) hälftigen Kindergeldes auch bei Zusammenleben mit Kind in neuer Beziehung.
BGH am 2015-11-11 (XII ZB 7/15) in FamRZ 2016, 199; NJW 2016, 322, Rn. 16 == Aufstockungsunterhaltsanspruch entsteht erst durch Vorwegabzug d. Kindesunterhalts.
15.3 Konkrete Bedarfsbemessung
Ein eheangemessener Unterhaltsbedarf (Elementarunterhalt) kann bis zu einem Gesamtbedarf von 4.000 € als Quotenunterhalt geltend gemacht werden. Ein darüber hinausgehender Bedarf auf Elementarunterhalt muss konkret dargelegt werden. Eigenes Einkommen des bedürftigen Ehegatten ist hierauf ohne Abzug eines Erwerbstätigenbonus (BGH vom 10.11.2010, XII ZR 197/08 = FamRZ 2011, 192, Tz. 24) anzurechnen. Obergrenze ist jedoch auch insoweit die unter Beachtung des Halbteilungsgrundsatzes zu errechnende Unterhaltsquote unter Berücksichtigung eines Erwerbstätigenbonus, wenn der Pflichtige sich unter Offenlegung seiner Einkommensverhältnisse darauf beruft. Die konkrete Darlegung des Bedarfs kann vom Berechtigten und Verpflichteten dadurch geschehen, dass die Höhe des zur Verfügung stehenden Gesamteinkommens sowie die hiervon betriebenen Aufwendungen zur Vermögensbildung dargelegt werden.
OLG Hamm am 2006-02-10 (5 UF 104/05) in NJW-RR 2006, 794 == Beispiel einer konkreten Bedarfsberechnung
BGH am 2010-08-11 (XII ZR 102/09) in FamRZ 2010, 1637; NJW 2010, 3372 == Zur Notwendigkeit, höheren Bedarf bei besonders günstigen Einkommensverhältnissen konkret zu begründen
BGH am 2010-11-10 (XII ZR 197/08) in FamRZ 2011, 192; NJW 2011, 303 == Kein Erwerbsbonus auf anzurechnendes eigenes Erwerbseinkommen des Berechtigten bei konkreter Bedarfsermittlung (Abweichung v. BGH FamRZ 2010, 1637, Tz. 31, und OLG Ffm. Nr. 15.3 i.d.F. bis 31.12.2012).
BGH am 2011-11-30 (XII ZR 35/09) in FamRZ 2012, 945; NJW 2012, 1581 == Konkrete Bedarfsberechnung des Elementarunterhalts bei Überschreiten des Tabellenhöchsteinkommens als Ermittlungsgrundlage. - Berechnungsbeispiele: Gutdeutsch, NJW 2012, 561 - 566
BGH am 2012-01-18 (XII ZR 178/09) in FamRZ 2012, 517; NJW 2012, 1144 == Regelmäßig geringerer Wohnbedarf im Rahmen konkreter Bedarfsermittlung nach Scheidung als tatsächl. Wohnvorteil bei alleiniger Nutzung des Einfamilienhauses.
BGH am 2017-11-15 (XII ZB 503/16) in NZFam 2018, 130 mAnm Schwamb; NJW 2018, 468 == Quotenunterhalt bei Vermutung des Verbrauchs bis zur zweifachen Höhe des Einkommenshöchstbetrags der DT
15.4 Vorsorgebedarf / Zusatz- und Sonderbedarf
Werden Altersvorsorge-, Kranken- und Pflegeversicherungskosten vom Berechtigten gesondert geltend gemacht oder vom Verpflichteten bezahlt, sind diese von dem Einkommen des Pflichtigen vorweg abzuziehen. Der Vorwegabzug unterbleibt, soweit nicht verteilte Mittel zur Verfügung stehen, z.B. durch Anrechnung nicht prägenden Einkommens des Berechtigten auf seinen Bedarf.
Bei der Bemessung des Altersvorsorgebedarfs kann nach den Grundsätzen der Bremer Tabelle verfahren werden. Altersvorsorgeunterhalt kann in der Regel nur dann verlangt werden, wenn der Bedarf in Höhe des Mindestselbstbehaltes für Erwerbstätige gemäß Ziffer 21.4 gedeckt ist. Der Altersvorsorgeunterhalt ist nicht auf den Höchstbetrag nach Maßgabe der Beitragsbemessungsgrenze beschränkt und soll gegebenenfalls aus nicht prägendem Einkommen gedeckt werden, so dass dann die zweite Berechnungsstufe entfallen kann, vgl. BGH FamRZ 1999, 372, FamRZ 2007, 117 ff., XII ZR 35/09 = FamRZ 2012, 945.
Altersvorsorgeunterhalt kann für die Vergangenheit nicht erst von dem Zeitpunkt an verlangt werden, in dem er ausdrücklich geltend gemacht worden ist. Es reicht für die Inanspruchnahme des Unterhaltspflichtigen vielmehr aus, dass von diesem Auskunft mit dem Ziel der Geltendmachung eines Unterhaltsanspruchs begehrt worden ist (BGH FamRZ 2007, 193 ff.), anders bei bereits erfolgter Bezifferung, BGH v. 7.11.2012, XII ZB 229/11 = FamRZ 2013, 109.
Der Beitrag für Krankenversicherung und Pflegeversicherung ist in jeweils nachzuweisender konkreter Höhe zu berücksichtigen.
Schwamb == AVU-Rechner
BGH am 2006-10-25 (XII ZR 141/04) in FamRZ 2007, 117; NJW 2007, 144 == Zur Höhe des Altersvorsorgeunterhalts bei guten Einkommensverhältnissen
BGH am 2010-08-11 (XII ZR 102/09) in FamRZ 2010, 1637; NJW 2010, 3372 == Altersvorsorgeunterhalt bei konkret bemessenem Barunterhalt
BGH am 2011-11-30 (XII ZR 35/09) in FamRZ 2012, 945; NJW 2012, 1581 == Keine zweistufige AVU-Berechnung bei konkret bemessenem Barunterhalt u. a.
BGH am 2011-11-30 (XII ZR 34/09) in FamRZ 2012, 947; NJW 2012, 1578 == AVU auf Basis des Elementarunterhalts, wenn dieser noch mit Quote berechnet wird.
BGH am 2012-11-07 (XII ZB 229/11) in FamRZ 2013, 109; NJW 2013, 161 == Kein zusätzlicher AVU für Vergangenheit bei bereits erfolgter Unterhaltsbezifferung.
BGH am 2014-11-19 (XII ZB 478/13) in FamRZ 2015, 309; NJW 2015, 334 == Keine Nachforderung vergessenen Altersvorsorgeunterhalts.
BGH am 2015-07-15 (XII ZB 369/14) in FamRZ 2015, 1694; NJW 2015, 2963, Rn. 28 == Berücksichtigung bereits früher möglicher Tarifänderung beim Krankenvorsorgeunterhalt.
15.5 Bedarf bei mehreren Ehegatten und Berechtigten nach § 1615 l BGB
Der Bedarf der Ehegatten berechnet sich nach dem Prioritätsgrundsatz. Danach sind die Unterhaltspflichten für einen späteren Ehegatten oder gegenüber dem betreuenden Elternteil eines nach der Scheidung der Eheleute geborenen Kindes (§ 1615l BGB) bei der Bemessung des Unterhaltsbedarfs des ersten Ehegatten nach § 1578 Abs. 1 S.1 BGB nicht zu berücksichtigen. Zur Anwendung der so genannten Dreiteilungsmethode kann es aber noch im Rahmen der Leistungsfähigkeit und der Mangelverteilung kommen (vgl. Nr. 24.3.2), wenn der erste Ehegatte nicht vorrangig ist. Der Bedarf eines späteren Ehegatten wird zwar durch die Unterhaltslast des Pflichtigen aus einer früheren Ehe geprägt. Der endgültige Unterhaltsbedarf des späteren Ehegatten lässt sich aber erst im Zusammenspiel mit der Leistungsfähigkeit des Unterhaltspflichtigen gegenüber einem früheren Ehegatten bemessen. Verbleibt dem Unterhaltspflichtigen danach gegenüber einem früheren Ehegatten wieder ein höherer Betrag, wirkt sich dies zugleich auf den im Wege der Halbteilung zu ermittelnden Bedarf seines späteren Ehegatten aus (BGH FamRZ 2012, 281, Tz. 45).
Zum dabei zu berücksichtigenden Einkommen vgl. Nr. 1.1 und 15.1.
Held am 2008-05-19 == Rechenbeispiel
Schwamb am 2008-05-19 == Rechenbeispiel, integrierte Berechnung zur Herleitung und Erläuterung des Grundsatzes
BGH am 2008-07-30 (XII ZR 177/06) in FamRZ 2008, 1911 ff.,1915 f.; NJW 2008, 3213 == Dreiteilungsmethode / Verteilung des Splittingvorteils
BGH am 2008-10-01 (XII ZR 62/07) in FamRZ 2009, 23; NJW 2009, 145 == Dreiteilungsmethode / Verteilung des Splittingvorteils - inzwischen für die Bedarfsberechnung überholt.
BGH am 2008-12-17 (XII ZR 9/07) in FamRZ 2009, 411; NJW 2009, 588 == Berücksichtigung eines Karrieresprungs bei der Dreiteilungsmethode
BGH am 2009-01-28 (XII ZR 119/07) in FamRZ 2009, 579; NJW 2009, 1271 == Berücksichtigung eines Karrieresprungs bei neu hinzutretendem Unterhaltsbedarf (u. a. Dreiteilungsmethode)
BGH am 2009-11-18 (XII ZR 65/09) in FamRZ 2010, 111; NJW 2010, 365 == Unterhaltsbemessung nach der Drittelmethode (für die Zeit ab 1.1.2008) bei Wiederverheiratung des Unterhaltspflichtigen.
BGH am 2010-01-27 (XII ZR 100/08) in FamRZ 2010, 538.Tz. 31; NJW 2010, 1595 == Unterhaltsbemessung nach der Drittelmethode erst für die Zeit ab 1.1.2008.
BGH am 2010-04-14 (XII ZR 89/08) in FamRZ 2010, 869; NJW 2010, 2056 == Beweislast des Pflichtigen für Einkommen der neuen Ehefrau bei Bemessung nach der Drittelmethode.
BVerfG am 2011-01-25 (1 BvR 918/10) in FamRZ 2011, 437; NJW 2011, 836 == Art.2 I, 20 III GG: Dreiteilung überschreitet Grenzen richterl. Rechtsfortbildung.
Schwamb am 2011-02-15 == Anm. zu BVerfG, Beschl. v. 25.1.2011 (1 BvR 918/10); ausführl. Anm. FamRB 2011, 120; Rechenbeispiele MDR 2012, 557
BGH am 2011-12-07 (XII ZR 151/09) in FamRZ 2012, 281; NJW 2012, 384, Tz. 45 == Bedarf ehel. Lebensverh.; Gleichrang neuer Ehefrau: Lstgsfähigk nach Drittelmethode; Anm. Schwamb, FamRB 2012, 71; MDR 2012, 557
BGH am 2011-12-07 (XII ZR 159/09) in FamRZ 2012, 288; FamRB 2012, 71 == Beweislast d. Pflichtigen für Einkommen der neuen Ehefrau bei Bemessung nach Drittelmethode
BGH am 2012-01-25 (XII ZR 139/09) in FamRZ 2012, 525; NJW 2012, 1209 == Keine Berücksichtigung der neuen Ehefrau bei Nachrang ggü. erster Ehefrau
BGH am 2013-03-20 (XII ZR 72/11) in NJW 2013, 1530 == Keine Unwirksamkeit, sondern nur Anpassung von Vereinbarungen mit Dreiteilung zur Bedarfsbemessung
BGH am 2013-06-26 (XII ZR 133/11) in NJW 2013, 2662, Tz. 87 == Keine Berücksichtigung eines Erwerbstätigkeitsbonus bei der Leistungsfähigkeit des Unterhaltspflichtigen
BGH am 2014-03-19 (XII ZB 19/13) in FamRZ 2014, 912; NJW 2014, 1590, Tz. 38, 39 == Dreiteilung ohne Erwerbstätigenbonus, Berücks. von Synergieeffekten
BGH am 2014-05-07 (XII ZB 258/13) in FamRZ 2014, 1183; NJW 2014, 2109, Tz. 21, 29 == Bedarf des ersten Ehegatten setzt sich bei Vorrang durch. Bei Gleichrang neuer Ehefrau Lstgsfähigk nach Drittelmethode.
15.6 Trennungsbedingter Mehrbedarf
Trennungsbedingter Mehrbedarf kann zusätzlich berücksichtigt werden, wenn ausnahmsweise noch die Anrechnungsmethode Anwendung findet. Obergrenze ist das Ergebnis der Differenzmethode.
BGH am 2012-01-18 (XII ZR 177/09) in FamRZ 2012, 514 == Zum nicht pauschalisierbaren, sondern im Rahmen konkreter Bedarfsermittlung vorzutragenden Mehrbedarf.
15.7 Begrenzung nach § 1578 b BGB
Nach Scheidung der Ehe ist in der Regel zunächst der eheangemessene Unterhalt weiterzuzahlen, eine sofortige Begrenzung wird bis auf Ausnahmefälle nicht in Betracht kommen. Dem berechtigten Ehegatten ist in der Regel eine auch unter Berücksichtigung der Ehedauer angemessene Übergangsfrist einzuräumen, binnen derer er sich auf die nicht an den ehelichen Lebensverhältnissen ausgerichteten neuen Verhältnisse einstellen kann. Für die Frage der Begrenzung des nachehelichen Unterhalts kommt es nach § 1578 b BGB maßgeblich darauf an, ob ehebedingte Nachteile eingetreten sind oder eine Begrenzung des Unterhaltsanspruchs unter Berücksichtigung der Dauer der Ehe unbillig wäre.
Der Ehegattenunterhalt ist nicht auf den Ausgleich ehebedingter Nachteile beschränkt. Wenn und soweit solche fehlen, ist über eine Herabsetzung auf den angemessenen Lebensbedarf im Wege einer umfassenden Billigkeitsabwägung zu entscheiden, die auch das jeweilige Maß an fortwirkender nachehelicher Solidarität einzubeziehen hat. Diesem Gedanken ist besonders Rechnung zu tragen, wenn Unterhalt wegen Krankheit geschuldet wird. Im Rahmen der umfassenden Billigkeitsabwägung sind sämtliche Umstände (wie z.B. beiderseitige Einkommens- und Vermögensverhältnisse, Vermögenserwerb während der Ehe, die vom Berechtigten in der Ehe erbrachte Lebensleistung, Umfang und Dauer des vom Pflichtigen bis zur Scheidung gezahlten Trennungsunterhalts bzw. des nach der Scheidung gezahlten Unterhalts) zu berücksichtigen. Die Ehedauer, bei der auf die Zeit von der Eheschließung bis zur Zustellung des Scheidungsantrags abzustellen ist, gewinnt bei der Bestimmung des Maßes der nachehelichen Solidarität ihr besonderes Gewicht aus der Wechselwirkung zwischen der Rollenverteilung in der Ehe und der darauf beruhenden Verflechtung der wirtschaftlichen Verhältnisse. Die Möglichkeit der Herabsetzung und/oder Befristung des Ehegattenunterhalts nach § 1578b BGB ist als rechtsvernichtende bzw. rechtsbeschränkende Einwendung bei entsprechendem Vortrag zu berücksichtigen. Im Rahmen der Herabsetzung und zeitlichen Begrenzung des Unterhalts ist der Unterhaltspflichtige für die Tatsachen darlegungs- und beweisbelastet, die für eine Begrenzung sprechen.
Hinsichtlich der Tatsache, dass ehebedingte Nachteile nicht entstanden sind, trifft den Unterhaltsberechtigten jedoch eine sekundäre Darlegungslast. Er muss die Behauptung, es seien keine ehebedingten Nachteile entstanden, substantiiert bestreiten und seinerseits darlegen, welche konkreten ehebedingten Nachteile entstanden sein sollen. Im Einzelfall kann der Vortrag genügen, dass in dem vor der Ehe ausgeübten Beruf Gehaltssteigerungen in einer bestimmten Höhe mit zunehmender Berufserfahrung bzw. Betriebszugehörigkeit üblich sind. Anders verhält es sich bei einem behaupteten beruflichen Aufstieg. Hier muss der Unterhaltsberechtigte darlegen, aufgrund welcher Umstände (wie etwa Fortbildungsbereitschaft, bestimmte Befähigungen, Neigungen, Talente etc.) er eine entsprechende Karriere gemacht hätte.
Der Betreuungsunterhalt nach § 1570 BGB ist nicht nach § 1578b BGB zu befristen.
BGH am 2006-04-12 (XII ZR 240/03) in FamRZ 2006, 1006; NJW 2006, 2401 == Befristung trotz langer Ehedauer (vorgehend OLG Ffm. 1 UF 317/02)
BGH am 2007-02-28 (XII ZR 37/05) in FamRZ 2007, 793; NJW 2007, 1961 == Zur Befristung des Anspruchs auf Aufstockungsunterhalt.
BGH am 2007-05-23 (XII ZR 245/04) in FamRZ 2007, 1232; NJW 2007, 2628 == Zur Befristung und zur Begrenzung nach den ehelichen Lebensverhältnissen
BGH am 2008-04-16 (XII ZR 107/06) in FamRZ 2008, 1325; NJW 2008, 2581 == Keine ehebedingten Nachteile i.S. v. § 1578b BGB wegen durch die Unterbrechung der Erwerbstätigkeit während der Ehe bedingten geringeren Rentenanwartschaften, wenn für diese Zeit ein Versorgungsausgleich stattgefunden hat.
OLG Ffm am 2008-08-13 (5 UF 185/07) == Zur Befristung
OLG Ffm am 2008-08-19 (3 UF 347/06) == Befristung bei Krankheit (aufgeh. durch BGH FamRZ 2010, 629)
OLG Ffm am 2008-11-13 (3 UF 10/08) == Zur Begrenzung von Aufstockungsunterhalt und der Bedeutung der Dauer der Ehe.
BGH am 2008-11-26 (XII ZR 131/07) in FamRZ 2009, 406; NJW 2009, 989 == Abgrenzung von Krankheitsunterhalt nach § 1572 BGB und Aufstockungsunterhalt nach § 1573 Abs. 2 BGB. Zur Befristung von Krankheitsunterhalt gem. § 1578b Abs. 2 BGB.
OLG Ffm am 2009-03-03 (3 UF 275/08) == Zur Begrenzung von Aufstockungsunterhalt und Bedeutung der Ehedauer (aufgeh. durch BGH, XII ZR 53/09, v. 20.10.10).
BGH am 2009-05-27 (XII ZR 111/08) in FamRZ 2009, 1207; NJW 2009, 2450 == § 1578 b BGB nicht auf die Kompensation ehebedingter Nachteile beschränkt, sondern auch eine darüber hinausgehende nacheheliche Solidarität zu berücksichtigen.
BGH am 2009-05-27 (XII ZR 78/08) in FamRZ 2009, 1300 ; NJW 2009, 2523 == Darlegungs- und Beweislast für ehebedingte Nachteile i. S. v. § 1578 b BGB
BGH am 2009-10-14 (XII ZR 146/08) in FamRZ 2009, 1990; NJW 2009, 3783 == Abwägung aller Gesichtspunkte für die Billigkeitsentscheidung des § 1578 b BGB ist Aufgabe des Tatrichters.
BGH am 2010-02-17 (XII ZR 140/08) in FamRZ 2010, 629; NJW 2010, 1598 == Herabsetzung oder zeitliche Begrenzung des nachehelichen Unterhalts beim Krankheitsunterhalt
BGH am 2010-03-24 (XII ZR 175/08) in FamRZ 2010, 875; NJW 2010, 1813 == Darlegungs- und Beweislast für ehebedingte Nachteile im Rahmen der Unterhaltsherabsetzung oder -befristung
BGH am 2010-04-14 (XII ZR 89/08) in FamRZ 2010, 869; NJW 2010, 2056 == Bei § 1572 BGB ist im Rahmen von § 1578 b BGB nacheheliche Solidarität besonders zu berücksichtigen.
BGH am 2010-04-28 (XII ZR 141/08) in FamRZ 2010, 1057; NJW-RR 2010, 1009 == Zur Befristung nachehelichen Krankheitsunterhalts im Fall der Klage des Sozialhilfeträgers auf rückständigen und laufenden Unterhalt aus übergegangenem Recht.
BGH am 2010-05-26 (XII ZR 143/08) in FamRZ 2010, 1238; NJW 2010, 2349 == Zur Befristung bei Abänderung von Prozessvergleichen.
BGH am 2010-06-02 (XII ZR 138/08) in FamRZ 2010, 1311; NJW 2010, 2582 == Zur Befristung von Aufstockungsunterhalt.
BGH am 2010-06-30 (XII ZR 9/09) in FamRZ 2010, 1414; NJW 2010, 2953 == Zur Befristung nachehelichen Krankheitsunterhalts bei Vertrauensschutz aus Alttitel (§ 36 Nr. 1 EGZPO).
BGH am 2010-08-04 (XII ZR 7/09) in FamRZ 2010, 1633; NJW 2010, 3097 == Zur Befristung/Begrenzung des Altersunterhalts (§ 1571 BGB)
BGH am 2010-08-11 (XII ZR 102/09) in FamRZ 2010, 1637; NJW 2010, 3372 == Befristung: Besonderes Gewicht längerer Ehedauer bei wirtschaftlicher Verflechtung
BGH am 2010-09-29 (XII ZR 205/08) in FamRZ 2010, 1884; NJW 2010, 3582 == Keine Abänderung zwecks Befristung von Aufstockungsunterhalt aus einem Urteil, das nach Veröffentlichung von BGH, XII ZR 240/03 v. 12.4.2006 = FamRZ 2006, 1006, ergangen ist.
BGH am 2010-10-06 (XII ZR 202/08) in FamRZ 2010, 1971; NJW 2011, 147 == Nach umfassender Billigkeitsabwägung keine Befristung bei langer Ehedauer und wirtschaftlicher Verflechtung.
BGH am 2010-10-20 (XII ZR 53/09) in FamRZ 2010, 2059; NJW 2010, 3653 == Zu den notw. Feststellungen, den ehebedingten Nachteil der Höhe nach zu bemessen.
BGH am 2010-11-10 (XII ZR 197/08) in FamRZ 2011, 192; NJW 2010, 303 == Zur Befristung des Unterhalts nach § 1573 I, II BGB bei ehebedingten Nachteilen des Berechtigten.
BGH am 2011-01-12 (XII ZR 83/08) in FamRZ 2011, 454; NJW 2011, 670 == Zur Befristung von Ehegattenunterhalt bei noch nicht abgeschlossener Entwicklung (hinsichtlich wirtschaftlicher Entflechtung).
BGH am 2011-02-16 (XII ZR 108/09) in FamRZ 2011, 628; NJW 2011, 1067 == Ehebedingte Nachteile wegen Kinderbetreuung und Haushaltsführung bzw. Arbeitplatzaufgabe.
BGH am 2011-03-02 (XII ZR 44/09) in FamRZ 2011, 713; NJW 2011, 1285 == .Ehebedingter Nachteil im Rahmen des Krankheitsunterhalts mangels Rentenanspruchs wegen Erwerbsminderung auf Grund Kindererziehung.
BGH am 2011-03-30 (XII ZR 63/09) in FamRZ 2011, 875; NJW 2011, 1807 == Zur Herabsetzung und Befristung nachehelichen Krankheitsunterhalts.
BGH am 2011-06-08 (XII ZR 17/09) in FamRZ 2011, 1381; NJW 2011, 2512 == Zur Anwendung von § 36 Nr. 1 EGZPO und ehebed. Nachteil, wenn VA die Ehezeit nur teilweise erfasst.
BGH am 2011-06-29 (XII ZR 157/09) in FamRZ 2011, 1721; NJW 2011, 3645 == Nachträgliche Begrenzung u. Befristung eines Titels über Altersunterhalt im Rentenalter möglich, wenn kein Vertrauensschutz des Berechtigten entgegen steht.
BGH am 2011-09-21 (XII ZR 121/09) in FamRZ 2011, 1851; NJW 2011, 3577 == Zur.Befristung von Aufstockungsunterhalt
BGH am 2011-10-26 (XII ZR 162/09) in FamRZ 2012, 93; NJW 2011, 74 == Zur sekundären Beweislast hins. ehebed. Nachteile bei Unterhaltsbegrenzung/-befristung.
BGH am 2011-11-23 (XII ZR 47/10) in FamRZ 2012, 197; NJW 2012, 309 == Kein ehebed. Nachteil wegen durch Eheschließung bedingten Wegfalls eines aus früherer Ehe herrührenden Unterhaltsanspruchs.
BGH am 2012-01-18 (XII ZR 178/09) in FamRZ 2012, 517; NJW 2012, 1144 == Zum Verhältnis von Vermögensverwertung und Herabsetzung/Befristung.
BGH am 2012-01-25 (XII ZR 139/09) in FamRZ 2012, 525; NJW 2012, 1209 == Zur Möglichkeit der Befristung trotz Ehevertrags mit lebenslanger Unterhaltsverpfl.
BGH am 2012-03-07 (XII ZR 25/10) in FamRZ 2012, 776; NJW 2012, 1506 == Voreheliche Kinderbetreuung zählt nicht zur Ehedauer. Zum ehebed. Nachteil
BGH am 2012-03-07 (XII ZR 145/09) in FamRZ 2012, 951; NJW 2012, 2028 == Zu (nicht b. VA berücks.) Rentennachteilen und Karriereverzicht als ehebedingte Nachteile
BGH am 2012-03-07 (XII ZR 179/09) in FamRZ 2012, 772; NJW 2012, 1807 == Zur Unterhaltsherabsetzung bei voller Erwerbsminderung des Berechtigten.
BGH am 2012-05-23 (XII ZR 147/10) in FamRZ 2012, 1284; NJW 2012, 2514 == Keine Abänderung zwecks Befristung von nach Veröff. von BGH FamRZ 2006, 1006 ergangenem Urteil.
BGH am 2012-12-05 (XII ZB 670/10) in FamRZ 2013, 274; NJW 2013, 528 == Kein nachträglicher Vorhalt mangelnder Erwerbsbemühungen zur Kompensation ehebedingten Nachteils
BGH am 2013-01-16 (XII ZR 39/10) in FamRZ 2013, 534; NJW 2013, 866 == Angemessener Lebensbedarf nach den Verdienstmöglichkeiten im Heimatland, angepasst an deutsches Preisniveau
BGH am 2013-02-20 (XII ZR 148/10) in FamRZ 2013, 860; NJW 2013, 1444 == Arbeitsplatzaufgabe zunächst wegen vor- und dann nachehelicher Kinderbetreuung als ehebedingter Nachteil
BGH am 2013-03-13 (XII ZB 650/11) in FamRZ 2013, 935 == Ehebedingter Arbeitsplatzwechsel als ehebedingter Nachteil
BGH am 2013-03-20 (XII ZR 120/11) in FamRZ 2013, 864; NJW 2013, 1447 == Sekundäre Beweislast einer aus Tschechien übergesiedelten Dipl.-Ing. für ehebedingten Nachteil
BGH am 2013-03-20 (XII ZR 72/11) in FamRZ 2013, 853; NJW 2013, 1530 == Keine Änderung durch § 1578b Abs. 1 BGB n.F. für Bedeutung der Ehedauer zur Bestimmung des Maßes nachehel. Solidarität.
BGH am 2013-06-19 (XII ZB 309/11) in NJW 2013, 1530 == Zur Begrenzung von Krankheitsunterhalt
BGH am 2014-02-26 (XII ZB 235/12) in FamRZ 2014, 823; NJW 2014, 1302, Tz. 18 == Kein ehebed. Nachteil durch geringere Versorgung bei Möglichkeit, Altersvors-Unterhalt zu erlangen
BGH am 2014-03-26 (XII ZB 214/13) in FamRZ 2014, 1007; NJW 2014, 1807, Tz. 21 == Mittelbarer ehebed. Nachteil durch Arbeitsplatzverlust und ehebed. begrenzte Bewerbungsmöglichkeiten
BGH am 2014-05-14 (XII ZB 301/12) in FamRZ 2014, 1276; NJW 2014, 2192, Tz. 47 == Kein ehebed. Nachteil durch geringere Versorgung bei Möglichkeit, Altersvors-Unterhalt zu erlangen
BGH am 2015-02-18 (XII ZR 80/13) in FamRZ 2015, 824; NJW 2015, 1380 == Begrenzung einer ehevertraglich lebenslangen Unterhaltsverpfl..
BGH am 2015-07-15 (XII ZB 369/14) in FamRZ 2015, 1694; NJW 2015, 2963 Rn. 23-26 == Zur Nichtberücksichtigung präkludierter Umstände für Befristung/Begrenzung.
BGH am 2016-06-08 (XII ZB 84/15) in FamRZ 2016, 1345; NJW 2016, 2256 == Berücksichtigung des vollen ehebed. Nachteils zugunsten Unterhaltsber.
BGH am 2018-07-04 (XII ZB 122/17) in FamRZ 2018, 1421; NJW 2018, 2636 == Kein ehebedingter Nachteil für Versorgungslücken bei Ausgleich durch VA und AVU.
BGH am 2018-07-04 (XII ZB 448/17) in FamRZ 2018, 1506; NJW 2018, 2638 == Zeitpunkt der Entscheidung über voraussehbare Umstände iSd § 1578b BGB.
16. Bedürftigkeit
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
Eigene (erzielte oder zurechenbare) Einkünfte des Berechtigten sind auf den Bedarf anzurechnen, wobei bei einer Berechnung nach Quoten das bereinigte Nettoerwerbseinkommen um den Erwerbstätigenbonus zu vermindern ist.
BGH am 2010-11-10 (XII ZR 197/08) in FamRZ 2011, 192; NJW 2011, 303 == Kein Erwerbsbonus auf anzurechnendes eigenes Erwerbseinkommen des Berechtigten bei konkreter Bedarfsermittlung (Abweichung v. BGH FamRZ 2010, 1637, Tz. 31).
17. Erwerbsobliegenheit
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
17.1 bei Kindesbetreuung
Die nach Vollendung des 3. Lebensjahres des Kindes grundsätzlich einsetzende Erwerbsobliegenheit des betreuenden Elternteils ist hinsichtlich Art und Umfang an den Belangen des Kindes auszurichten.
Stehen solche Belange einer Fremdbetreuung generell entgegen oder besteht eine kindgerechte Betreuungsmöglichkeit nicht, hat das Prinzip der Eigenverantwortung des betreuenden Elternteils für seinen Unterhalt zurückzustehen.
Dieser Maßstab bestimmt auch die Verpflichtung zur Aufnahme einer Teilzeit- oder Vollzeittätigkeit.
Vgl. hierzu die Gesetzesbegründung, FamRZ 2007, 1947, 2. Spalte:
" . . . Die Neuregelung verlangt (also) keineswegs einen abrupten, übergangslosen Wechsel von der elterlichen Betreuung zu Vollzeiterwerbstätigkeit. Im Interesse des Kindeswohls wird vielmehr auch künftig ein gestufter, an den Kriterien von § 1570 Abs. 1 BGB-Entwurf orientierter Übergang möglich sein."
Folgende Kriterien sind insbesondere zu prüfen:
Kindbezogene Gründe:
1. Generelle Betreuungsbedürftigkeit aufgrund des Alters
2. Fehlende kindgerechte Betreuungsmöglichkeiten, wobei die staatlichen Betreuungsmöglichkeiten nach der Rechtsprechung des BGH als kindgerecht anzusehen sind.
3. Krankheiten, die durch die Betreuung in einer Einrichtung nicht aufgefangen werden können und damit die Betreuung durch einen Elternteil erfordern.
Elternbezogene Gründe:
1. Vertrauen in die vereinbarte oder praktizierte Rollenverteilung und Ausgestaltung der Kinderbetreuung. Zu berücksichtigen ist dabei auch die Aufgabe einer Erwerbstätigkeit wegen Kindererziehung und die Dauer der Ehe.
2. Umfang der Betreuungsbedürftigkeit des Kindes im Anschluss an die Betreuung in einer Betreuungseinrichtung, wobei der Betreuungsbedarf in der Regel bei jüngeren Kindern größer ist als bei älteren Kindern.
Darlegungs- und beweispflichtig für diese Umstände ist der Unterhaltsbedürftige. Bei entsprechend konkretem Vortrag dürfte eine vollschichtige Erwerbsobliegenheit neben der Betreuung eines Kindes bis zum Ende der Grundschulzeit eher selten in Betracht kommen. An die für eine Verlängerung des Betreuungsunterhalts, insbesondere aus kindbezogenen Gründen, erforderlichen Darlegungen sind keine überzogenen Anforderungen zu stellen (BGH FamRZ 2012, 1040).
Eine überobligationsmäßige Belastung des betreuenden Elternteils (Berufstätigkeit, Kinderbetreuung, Haushaltsführung) ist zu vermeiden.
Bei Inanspruchnahme von privater Betreuung, z. B. durch Angehörige, kann es sich um eine freiwillige Leistung Dritter handeln, die den Unterhaltspflichtigen nicht entlasten soll. Die Kinderbetreuung während des Umgangs durch den Unterhaltspflichtigen kann allenfalls dann, wenn der Umgang geregelt ist oder unproblematisch funktioniert, zu einer Erwerbsobliegenheit des Unterhaltsberechtigten in den feststehenden Zeiten führen.
Die Änderung einer bestehenden Umgangsregelung zum Zweck der Ausweitung der Erwerbstätigkeit des betreuenden Unterhaltsberechtigten kann in der Regel nicht verlangt werden.
Der Betreuungsunterhalt ist nicht zu befristen.
BGH am 2009-03-18 (XII ZR 74/08) in FamRZ 2009, 770; NJW 2009, 1876 == Zur Dauer des Betreuungsunterhalts gem. § 1570 BGB. Kein Gebot zur Befristung des einheitlichen Anspruchs nach § 1570 BGB.
BGH am 2009-05-06 (XII ZR 114/08) in FamRZ 2009, 1124; NJW 2009, 1956 == Zur Dauer des Betreuungsunterhalts gem. § 1570 BGB. Keine Befristung des Betreuungsunterhalts nach § 1578 b BGB.
BGH am 2009-06-17 (XII ZR 102/08) in FamRZ 2009, 1391; NJW 2009, 2592 == Zur Dauer des Betreuungsunterhalts gem. § 1570 BGB (Anschluss an Entsch. vom 18.03.und 06.05.2009). Damit verlangt die Neuregelung regelmäßig keinen abrupten Wechsel von elterlicher Betreuung zu Vollzeiterwerbstätigkeit.
BGH am 2009-06-24 (XII ZR 161/08) in FamRZ 2009, 1477; NJW 2009, 2744 == Zur Dauer des Betreuungsunterhalts gem. § 1570 BGB (Anschluss an Entsch. vom 18.03., 06.05.und 17.06.2009).
BGH am 2009-12-16 (XII ZR 50/08) in FamRZ 2010, 357; NJW 2010, 937 == Kind- oder elternbezogene Gründe für eine Verlängerung des Betreuungsunterhalts über die Vollendung des dritten Lebensjahres des Kindes hinaus nur, wenn sie vorgetragen werden oder auf Grund des sonst festgestellten Sachverhalts auf der Hand liegen.
OLG Ffm am 2010-02-17 (5 UF 45/09) in FamRZ 2010, 1449 == Enge Auslegung von § 1570 BGB durch den BGH droht Kinder zu benachteiligen, die als Folge der Trennung der Eltern besonderer Zuwendung bedürfen.
BGH am 2010-03-17 (XII ZR 204/08) in FamRZ 2010, 802; NJW 2010, 1665 == Kind- oder elternbezogene Gründe für Unterhalt bei Betreuung eines vollj. behinderten Kindes.
BGH am 2010-04-21 (XII ZR 134/08) in FamRZ 2010, 1050; NJW 2010, 2277 == Elternbezogene Gründe nur bei tatsächlicher Betreuung des Kindes.
BGH am 2010-09-15 (XII ZR 20/09) in FamRZ 2010, 1880; NJW 2010, 3369 == Zu (nach BGH) fehlenden (Anm.: vom KG, FPR 2009, 254 = FF 2009, 165 jedoch dargelegten) kind- o. elternbezogenen Gründen für weiteren Betreuungsunterhalt und zum grundsätzlich beachtlichen Betreuungsangebot des barunterhaltspfl. Elternteils, wenn es ernsthaft und verlässlich ist.
Schwamb am 2010-12-01 == abl. Besprechung in FamRB 2010, 358 ff. zum Urt. d. BGH, XII ZR 20/09, v. 15.09.2010
BGH am 2011-03-30 (XII ZR 3/09) in FamRZ 2011, 791; NJW 2011, 1582; FamRB 2011, 165 == Zu (nach BGH) nicht ausreichenden kindbezogenen Gründen für verlängerten Betreuungsunterhalt (abl. Besprechung Schwamb, FamRB 2011, 165; Norpoth, FamRZ 2011, 874).
BGH am 2011-03-30 (XII ZR 3/09) in FamRZ 2011, 791; NJW 2011, 1582 == Zur Verwirkung des nachehelichen Betreuungsunterhalts nach § 1579 BGB.
BGH am 2011-06-01 (XII ZR 45/09) in FamRZ 2011, 1209; NJW 2011, 2430 == Zu (nach BGH) nicht ausreichenden kindbezogenen Gründen für verlängerten Betreuungsunterhalt und geforderten Prüfung der Umgestaltung einer Umgangsregelung mit dem Barunterhaltspflichtigen im Unterhaltsverfahren.
BGH am 2011-06-15 (XII ZR 94/09) in FamRZ 2011, 1375; NJW 2011, 2646 == Zu (nach BGH) nicht ausreichend begründeten individuellen Einzelumständen.
BGH am 2012-04-18 (XII ZR 65/10) in FamRZ 2012, 1040; NJW 2012, 1868 == Zur Darlegung kindbezogener Gründe: Keine überzogenen Anforderungen (mehr!). Zu gerechter Lastenverteilung.
BGH am 2012-08-08 (XII ZR 97/10) in FamRZ 2012, 1624; NJW 2012, 3037 == Zur Darlegung kindbezogener Gründe: Keine überzogenen Anforderungen (mehr!). Zu gerechter Lastenverteilung.
OLG Ffm am 2013-04-19 (6 WF 55/13) in FamRB 2013, 384; FamFR 2013, 441 == Zum notwendigen Vortrag kind- oder elternbezogener Gründe für verlängerten Betreuungsunterhalt (hier: für VKH)
BGH am 2014-10-01 (XII ZB 185/13) in FamRZ 2014, 1987; NJW 2014, 3649 == Vorrang des Berechtigten auch beii nur teilweisem Betreuungsunterhalt. Betreuungsunterhalt bei überobligatorischer Erwerbstätigkeit des Berechtigten.
17.2 bei Trennungsunterhalt
In der Regel besteht für den Berechtigten im ersten Jahr nach der Trennung keine Obliegenheit zur Aufnahme oder Ausweitung einer Erwerbstätigkeit.
Für den Trennungsunterhalt gelten zunächst großzügigere Anforderungen hinsichtlich einer Erwerbsobliegenheit als sie in § 1574 BGB für den nachehelichen Unterhalt bestimmt sind. Die bestehenden Verhältnisse sollen geschützt werden, damit die Wiederherstellung der ehelichen Lebensgemeinschaft nicht erschwert wird. Mit zunehmender Verfestigung der Trennung wird allerdings eine allmähliche Annäherung der unterschiedlichen Maßstäbe der Erwerbsobliegenheit bewirkt (BGH FamRZ 2012, 1201, Tz. 18).
BGH am 2012-04-18 (XII ZR 73/10) in FamRZ 2012, 1201; NJW 2012, 2190 == Trennungsunterhalt wegen Betreuung eines Kindes: Zunächst großzügigere Anforderungen hinsichtlich einer Erwerbsobliegenheit als nach § 1570 BGB.
BGH am 2014-10-22 (XII ZB 385/13) in FamRZ 2015, 127; NJW 2014, 3647 == Mehrheit von Teilauskünften im Stufenverfahren auf Trennungsunterhalt.
BGH am 2015-09-30 (XII ZB 1/15) in FamRZ 2015, 2131; NJW 2015, 3715 == Zum unwirksamen Verzicht auf künftigen Trennungsunterhalt.
Weitere Unterhaltsansprüche
18. Ansprüche aus § 1615l BGB
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
Der Bedarf nach § 1615 l BGB bemisst sich nach der Lebensstellung des betreuenden Elternteils. Erleidet dieser einen konkreten Verdienstausfall, ist er auch für den Unterhalt zu Grunde zu legen.
Der Mindestbedarf entspricht in der Regel dem notwendigen Selbstbehalt für nicht Erwerbstätige (880,- €).
Der Anspruch nach § 1615l BGB ist begrenzt auf den Betrag, der einem Ehegatten in gleicher Lage zustünde. Dies hat der Verpflichtete darzulegen.
Bezüglich der Erwerbsobliegenheit und Dauer des Anspruchs gilt Nr. 17.1 entsprechend.
BGH am 2008-07-16 (XII ZR 109/05) in FamRZ 2008, 1739, NJW 2008, 3125 == Zur Höhe des Bedarfs und Dauer des Anspruchs (siehe auch Nr. 17).
BGH am 2009-12-16 (XII ZR 50/08) in FamRZ 2010, 357; NJW 2010, 937 == Zum pauschalisierbaren Mindestbedarf in Höhe des Existenzminimums (notwendiger Selbstbehalt eines Nichterwerbstätigen) bei Betreuung eines nichtehelich geborenen Kindes. - Verlängerung des Betreuungsunterhalts über die Vollendung des dritten Lebensjahres des Kindes hinaus.
BGH am 2010-01-13 (XII ZR 123/08) in FamRZ 2010, 444; NJW 2010, 1138 == Zum Mindestbedarf in Höhe des Existenzminimums und den Voraussetzungen des Betreuungsunterhalts über die Vollendung des dritten Lebensjahres des Kindes hinaus.
BGH am 2013-10-02 (XII ZB 249/12) in FamRZ 2013, 1958; NJW 2013, 3578 == Notwendige Inverzugsetzung, keine Befristung des Unterhalts gem. § 1615l BGB
BGH am 2015-06-10 (XII ZB 251/14) in FamRZ 2015, 1369 Rn. 12 ff., 34 == Verlängerung des Unterhalts bei Betreuung eines behinderten Kindes; Lebensstellung d. Berechtigten.
BGH am 2016-03-09 (XII ZB 693/14) in FamRZ 2016, 887; NJW 2016, 1511 == Elternbezogener Grund für pers. Betreuung bei fortdauerndem Einvernehmen mit anderem Elternteil.
BGH am 2016-03-16 (XII ZR 148/14) in FamRZ 2016, 892; NJW 2016, 1961 == Wegfall des Anspruchs bei Eheschließung mit neuem Partner.
19. Elternunterhalt
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
Der Bedarf bemisst sich nach der eigenen Lebensstellung des unterhaltsberechtigten Elternteils, wobei nachteilige Veränderungen der Lebensverhältnisse, wie sie regelmäßig mit dem Eintritt in den Ruhestand einhergehen, zu berücksichtigen sind. Auch bei bescheidenen wirtschaftlichen Verhältnissen ist die Untergrenze des Bedarfs so zu bemessen, dass das Existenzminimum sichergestellt wird. Dieser Mindestbedarf kann in Höhe des notwendigen Selbstbehalts eines nicht Erwerbstätigen pauschaliert werden.
Bei einem Heimaufenthalt wird der Bedarf durch die dadurch anfallenden notwendigen Kosten zuzüglich eines Barbetrags für die persönlichen Bedürfnisse entsprechend § 27 b Abs.2 SGB XII bestimmt. Das unterhaltspflichtige Kind, das nur geringe oder keine eigenen Einkünfte erzielt und einen Anspruch auf Familienunterhalt hat, ist nur dann zur Zahlung von Elternunterhalt leistungsfähig, wenn es im Rahmen des Familienunterhalts selbst vollständig abgesichert ist und aus eigenen Erwerbseinkünften oder aus Taschengeld Elternunterhalt leisten kann. Zur Höhe des Taschengeldeinsatzes vgl. BGH FamRZ 2013, 363 mit der Maßgabe der Klarstellungen BGH FamRZ 2014, 1990, Rn. 12 ff. Zur Berechnung des sogenannten individuellen Familienselbstbehalts vgl. BGH FamRZ 2010, 1535 und FamRZ 2014, 538, Rn. 22 ff.
Der Wohnwert ist bei der Inanspruchnahme auf Elternunterhalt in der Regel nicht mit der bei einer Fremdvermietung erzielbaren objektiven Marktmiete, sondern auf der Grundlage der unter den gegebenen Verhältnissen ersparten Miete zu bemessen. Altersvorsorgevermögen, das der Anlage von 5 % des Jahresbruttoeinkommens des Pflichtigen bezogen auf seine gesamte Erwerbstätigkeit bis zur Inanspruchnahme auf Elternunterhalt entspricht, ist nicht für Unterhaltszwecke einzusetzen. Der Wert einer selbstgenutzten Immobilie bleibt bei der Bemessung des Altersvorsorgevermögens eines auf Elternunterhalt in Anspruch genommenen Unterhaltspflichtigen grundsätzlich unberücksichtigt, BGH, XII ZB 269/12 vom 7.8.2013 = FamRZ 2013, 1554.
Angemessene Aufwendungen, die dem Unterhaltspflichtigen für Besuche bei dem Elternteil entstehen, mindern grundsätzlich seine Leistungsfähigkeit, weil ihr Zweck auf einer unterhaltsrechtlich anzuerkennenden sittlichen Verpflichtung beruht.
BGH am 2004-07-07 (XII ZR 272/02) in FamRZ 2004, 1370; NJW-RR 2004, 1300 == Bedarf orientiert sich ggf. an den Heimkosten.
BGH am 2010-07-28 (XII ZR 140/07) in FamRZ 2010, 1535; NJW 2010, 3161 == Zur Berechnung des Elternunterhalts
BGH am 2010-09-15 (XII ZR 148/09) in FamRZ 2010, 1888; NJW 2010, 3714 == Verwirkung von Elternunterhalt nur bei Verschulden
BGH am 2012-11-21 (XII ZR 150/10) in FamRZ 2013, 203; NJW 2013, 301 == Unterhaltsbedarf eines im Pflegeheim wohnenden Elternteils
BGH am 2012-12-12 (XII ZR 43/11) in FamRZ 2013, 363; NJW 2013, 686 == Taschengeld ist einsatzpflichtig, jedoch nicht i. H. v. 5 - 7% des Mindestselbstbehalts des Pflichtigen u. a.
BGH am 2013-08-07 (XII ZB 269/12) in FamRZ 2013, 1554; NJW 2013, 3024, Tz. 18, 36 f. == Kein Einsatz selbst bewohnten Eigenheims für Elternunterhalt; Behalt eines Notgroschens
BGH am 2014-02-05 (XII ZB 25/13) in FamRZ 2014, 538; NJW 2014, 1173, Tz. 22, 26 == Zur Berechnung des Elternunterhalts, den ein in seiner Ehe geringer verdienendes Kind leisten muss
BGH am 2014-02-12 (XII ZB 607/12) in FamRZ 2014, 541; NJW 2014, 1177 == Zur Verwirkung von Elternunterhalt wegen schwerwiegenden Fehlverhaltens des Berechtigten
BGH am 2014-07-23 (XII ZB 489/13) in FamRZ 2014, 1540; NJW 2014, 2570 == Einsatz des Taschengeldes (Klarstellung zu FamRZ 2013, 363).
BGH am 2014-10-01 (XII ZB 133/13) in FamRZ 2014, 1990; NJW 2014, 3514 == Einsatz des Taschengeldes (weitere Klarstellung zu FamRZ 2013, 363).
BGH am 2015-04-29 (XII ZB 236/14) in FamRZ 2015, 1172; NJW 2015, 1877, Rn. 35 ff == Grds. kein Altersvorsorgeverm. für. zum Elternunterhalt verpfl. nicht erwerbstätigen verheirateten Ehegatten.
BGH am 2015-06-17 (XII ZB 458/14) in FamRZ 2015, 1594; NJW 2015, 2577, Rn. 31, 50 == Fiktives Pflegegeld bei fehlender Pflegeversicherung; fiktive Steuerlast eines Ehegatten bei Verpfl. zum Elternunterhalt.
BGH am 2015-07-08 (XII ZB 56/14) in FamRZ 2015, 1473; NJW 2015, 2493, Rn. 12 == Obliegenheit zur Inanspruchnahme von Leistungen der Grundsicherung im Alter ggü. Kindern.
BGH am 2015-10-07 (XII ZB 26/15) in FamRZ 2015, 2138; NJW 2015, 3569 == Unterhaltsbedarf eines im Heim lebenden Elternteils.
BGH am 2016-03-09 (XII ZB 693/14) in FamRZ 2016, 887; NJW 2016, 1511 == Anspruch aus § 1615l BGB vorrangig abziehbar, aber dann kein Familienselbstbehalt.
BGH am 2017-01-18 (XII ZB 118/16) in FamRZ 2017, 519, NJW 2017, 1169, Rn. 33, 34 == Abzugsfähigkeit von Tilgungsleistungen bis zu Wohnwert und Altersvorsorgequote.
BGH am 2017-02-15 (XII ZB 201/16) in FamRZ 2017, 711, NJW 2017, 1881, Rn. 14 == Abzugsfähigkeit von Barunterhaltsleistungen für mdj. Kinder, aber keine Monetarisierung der Betreuung.
BGH am 2018-09-12 (XII ZB 384/17) in FamRZ 2018, 1903 == Bedarf auf Mehrkosten für Gehörlose; zur unbilligen Härte iSd § 94 III Nr. 2 SGB XII.
20. Lebenspartnerschaft
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
Bei Getrenntleben oder Aufhebung der Lebenspartnerschaft gelten §§ 12, 16 LPartG.
Leistungsfähigkeit und Mangelfall
21. Selbstbehalt
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
21.1 Grundsatz
Es ist zu unterscheiden zwischen dem notwendigen (§ 1603 Abs. 2 BGB), dem angemessenen (§ 1603 Abs. 1 BGB) und dem eheangemessenen (§§ 1361 Abs. 1, 1578 Abs. 1 BGB; BGH FamRZ 2006, 683) Selbstbehalt.
BGH am 2006-03-15 (XII ZR 30/04) in FamRZ 2006, 683 == Selbstbehalt gegenüber Trennungs-/Ehegattenunterhalt liegt zwischen notwendigem und angemessenem Selbstbehalt. Einer zusätzlichen Grenze der Leistungsfähigkeit nach ehel. Lebensverhältnissen bedarf es nicht.
BVerfG am 2008-03-18 (1 BvR 125/06) in FamRZ 2008, 1145 == Art. 3 I GG: Verfassungswidrige Zurechnung fiktiver Einkünfte
BGH am 2008-12-03 (XII ZR 182/06) in FamRZ 2009, 314; NJW 2009, 1410 == Voraussetzungen für Zurechnung fiktiver Einkünfte, besondere Prüfung der Zumutbarkeit und des erzielbaren Einkommens einer etwaigen Nebentätigkeit
BGH am 2011-05-04 (XII ZR 70/09) in FamRZ 2011, 1041; NJW 2011, 1874 == Auch der betreuende Elternteil (§ 1606 III 2 BGB) kann anderer leistungsfähiger Verwandter i. S. v, § 1603 II 3 BGB sein. Dem barunterhaltspfl. Elternteil bleibt ggf.angem, Selbstbehalt, wenn sonst erhebl. finanzielles Ungleichgewicht zwischen den Eltern entstünde.
BGH am 2016-11-09 (XII ZB 227/15) in FamRZ 2017, 109; NZFam 2017, 61 == Zur Erwerbsobliegenheit des Rentenbeziehers wegen Erwerbsunfähigkeit ggü. mdj. Kind.
21.2 Notwendiger Selbstbehalt
Für Eltern gegenüber minderjährigen Kindern und diesen nach § 1603 Abs. 2 Satz 2 BGB gleichgestellten Kindern gilt im Allgemeinen der notwendige Selbstbehalt als unterste Grenze der Inanspruchnahme. Er beträgt 1.080 €. Davon entfallen 380 € auf den Wohnbedarf (290 € Kaltmiete, 90 € Nebenkosten und Heizung).
Für nicht Erwerbstätige beträgt er 880 €; bei Anhaltspunkten für unterhaltsrechtlich bedeutsame zusätzliche Kosten kann der Selbstbehalt angemessen erhöht werden. Bei geringfügiger Erwerbstätigkeit wird wegen des notwendigen Selbstbehalts auf BGH FamRZ 2008, 594 ff., 597, Tz. 29, verwiesen.
Verursacht der Umgang des Unterhaltspflichtigen mit den minderjährigen Kindern besondere Kosten, die er nur unter Gefährdung seines Selbstbehalts aufbringen könnte, kommt eine maßvolle Erhöhung in Betracht.
OLG Ffm am 2002-03-14 (1 UF 127/01) == Unterschreitung des Selbstbehalts durch Vereinbarung
OLG Ffm am 2005-02-02 (4 WF 136/04) == Erweiterter Umgang kann Unterhaltsanspruch reduzieren
BGH am 2005-02-23 (XII ZR 56/02) in FamRZ 2005, 706; NJW 2005, 1493 == Erhöhung des Selbstbehaltes oder Verringerung des Einkommens wegen Umgangskosten
OLG Ffm am 2006-09-29 (5 UF 171/06) in NJW 2007,382f. == Zur notwendigen Berücksichtigung der realen Beschäftigungschancen ungelernter Arbeitskräfte.
BGH am 2008-01-09 (XII ZR 170/05) in FamRZ 2008, 594; NJW 2008, 1373 Tz. 26 ff. == Herabsetzung des Selbstbehalts eines nicht erwerbstätigen Unterhaltspflichtigen bis auf sein Existenzminimum nach sozialhilferechtlichen Grundsätzen.
Schwamb am 2008-04-16 == Anmerkung in forum familienrecht 2008, 160, 161 zur BGH-Entscheidung XII ZR 170/05
BGH am 2013-01-30 (XII ZR 158/10) in FamRZ 2013, 616; NJW 2013, 1005 == Keine Berücksichtigung zusätzlicher AV/KV, wenn Mindestunterhalt f. mdj. Kind nicht aufgebracht wird
BGH am 2015-07-01 (XII ZB 240/14) in FamRZ 2015, 1473; NJW 2015, 2493, Rn. 26 == Hausgeld des Strafgefangenen als Selbstbehalt..
21.3 Angemessener Selbstbehalt
21.3.1 gegenüber volljährigen Kindern
Er beträgt gegenüber volljährigen Kindern 1.300 €. Davon entfallen 480 € auf den Wohnbedarf (370 € Kaltmiete, 110 € Nebenkosten und Heizung). Gegenüber volljährigen Kindern, die ihre bereits einmal erreichte wirtschaftliche Selbständigkeit wieder verloren haben, gilt Nr. 21.3.3. und ggf. Nr. 22.3.
BGH am 2012-01-18 (XII ZR 15/10) in FamRZ 2012, 530; NJW 2012, 926 == Erhöhter Selbstbehalt (wie ggü. Eltern) ggü. erw. Kind nach dessen Verlust wirtschaftl. Selbstst.
21.3.2 bei Ansprüchen aus § 1615l BGB
Gegenüber Anspruchsberechtigten nach § 1615 l BGB entspricht der Selbstbehalt dem eheangemessenen Selbstbehalt (Nr. 21.4).
21.3.3 beim Elternunterhalt
Gegenüber Eltern beträgt er mindestens 1.800 €, wobei die Hälfte des diesen Mindestbetrag übersteigenden Einkommens zusätzlich anrechnungsfrei bleibt. In diesem Mindestbetrag sind Kosten für Unterkunft und Heizung in Höhe von 480 € (370 € Kaltmiete, 110 € Nebenkosten und Heizung) enthalten.
BGH am 2006-08-30 (XII ZR 98/04) in FamRZ 2006, 1511 == Einschränkung bei Vermögensstamm; angemessene Altersvorsorge
BGH am 2010-07-28 (XII ZR 140/07) in FamRZ 2010, 1535; NJW 2010, 3161 == Leistungsfähigkeit für Elternunterhalt
21.3.4. von Großeltern gegenüber Enkeln (und umgekehrt)
Dies gilt entsprechend für sonstige Unterhaltsansprüche von Verwandten der auf- und absteigenden Linie (Großeltern/Enkel, vgl. BGH FamRZ 2006, 26, 28, FamRZ 2007, 375 f.).
21.4 Mindestselbstbehalt gegenüber Ehegatten
Der Mindestselbstbehalt gegenüber getrennt lebenden und geschiedenen Unterhaltsberechtigten ist bei Erwerbstätigen in der Regel mit 1.200 € zu bemessen, bei nicht Erwerbstätigen mit regelmäßig 1.090 € (Mittelbetrag zwischen unterschiedlichem notwendigem und dem angemessenen Selbstbehalt), davon 430 € für den Wohnbedarf (330 € Kaltmiete, 100 € Nebenkosten und Heizung).
Bei der Prüfung der Leistungsfähigkeit des Unterhaltspflichtigen ist ein Erwerbstätigkeitsbonus nicht zu berücksichtigen.
BGH am 2008-11-19 (XII ZR 129/06) in FamRZ 2009, 307.; NJW-RR 2009, 289 == Ehegattenselbstbehalt bei Bezug von Krankengeld zwischen notwendigem Selbstbehalt für Nichterwerbstätige und angemessenem Selbstbehalt (damals im Regelfall 935 EUR)
BGH am 2008-11-19 (XII ZR 51/08) in FamRZ 2009, 311 ff., 313 == Ehegattenselbstbehalt bei Bezug von Krankengeld zwischen notwendigem Selbstbehalt für Nichterwerbstätige und angemessenem Selbstbehalt, bei fiktivem Erwerbseinkommen zwischen notwendigem Selbstbehalt für Erwerbstätige und angemessenem Selbstbehalt (zwar regelmäßig, aber nicht zwingend genau hälftig dazwischen)
BGH am 2008-12-17 (XII ZR 63/07) in FamRZ 2009, 404; NJW-RR 2009, 649 f. == Zum Ehegattenselbstbehalt im Rahmen des Trennungsunterhalts bei Betreuung eines mdj. Kindes.
BGH am 2010-03-17 (XII ZR 204/08) in FamRZ 2010, 802; NJW 2010, 1665 == Eheangemessener Selbtbehalt für nicht Erwerbstätige.
BGH am 2013-06-26 (XII ZR 133/11) in NJW 2013, 2662, Tz. 87 == Keine Berücksichtigung eines Erwerbstätigkeitsbonus bei der Leistungsfähigkeit des Unterhaltspflichtigen
BGH am 2014-03-19 (XII ZB 19/13) in FamRZ 2014, 912; NJW 2014, 1590, Tz. 39 == Kein Erwerbstätigenbonus bei Prüfung der Leistungsfähigkeit.
BGH am 2016-04-27 (XII ZB 485/14) in FamRZ 2016, 1142; NJW 2016, 2122 == Eheangemessener Selbstbehalt auch beim Familienunterhalt (§§ 1360, 1360a BGB).
21.5 Anpassung des Selbstbehalts
21.5.1.
Beim Verwandtenunterhalt kann der jeweilige Selbstbehalt unterschritten werden, wenn der eigene Unterhalt des Pflichtigen ganz oder teilweise durch seinen Ehegatten gedeckt ist.
BGH am 2009-06-17 (XII ZR 102/08) in FamRZ 2009, 1391; NJW 2009, 2592 == Erhöhung des Selbstbehalts oder (teilw.) Abzug vom Einkommen bei Kosten der Ausübung des Umgangsrechts, die deutlich über den verbleibenden Anteil der Entlastung der Barunterhaltspflicht durch das hälftige Kindergeld hinausgehen.
21.5.2.
Der Selbstbehalt soll erhöht werden, wenn die Wohnkosten (Warmmiete) den ausgewiesenen Betrag überschreiten und nicht unangemessen sind.
BGH am 2006-08-23 (XII ZR 26/04) in FamRZ 2006, 1664 == Bemessung des notwendigen Selbstbehalts bei geringen Wohnkosten
BGH am 2008-12-03 (XII ZR 182/06) in FamRZ 2009, 314; NJW 2009, 1410 == Selbstbehalt bei geringen Wohnkosten, Bestätigung von BGH FamRZ 2006, 1664
21.5.3.
Eine Herabsetzung des Selbstbehalts mit Rücksicht auf geringere Wohnkosten des Unterhaltspflichtigen kommt nicht in Betracht, BGH FamRZ 2006, 1664, 1666.
Lebt der Unterhaltspflichtige mit einem leistungsfähigen Partner in Haushaltsgemeinschaft, kommt eine Haushaltsersparnis in Betracht, in der Regel 10% des jeweils maßgeblichen Selbstbehalts. Untergrenze ist der Sozialhilfesatz (vgl. BGH FamRZ 2008, 594 ff.).
BGH am 2008-01-09 (XII ZR 170/05) in FamRZ 2008, 594; NJW 2008, 1373 Tz. 31 ff. == Herabsetzung des Selbstbehalts eines Unterhaltspflichtigen um eine durch gemeinsame Haushaltsführung eintretende Ersparnis, höchstens jedoch bis auf sein Existenzminimum nach sozialhilferechtlichen Grundsätzen.
Schwamb am 2008-04-16 == Anmerkung in forum familienrecht 2008, 160, 161 zur BGH-Entscheidung XII ZR 170/05
BGH am 2008-12-03 (XII ZR 182/06) in FamRZ 2009, 314.; NJW 2009, 1410 == Notwendiger Selbstbehalt bei Ersparnis durch gemeinsame Haushaltsführung, Bestätigung von BGH FamRZ 2008, 594 ff.
BGH am 2010-03-17 (XII ZR 204/08) in FamRZ 2010, 802; NJW 2010, 1665 == Herabsetzung des eheangemessenen Selbtbehalts wegen gemeinsamer Haushaltsführung mit neuer Lebensgefährtin.
22. Bedarf des mit dem Pflichtigen zusammen lebenden Ehegatten
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
22.1 Mindestbedarf bei Ansprüchen des nachrangigen geschiedenen Ehegatten
Ist bei Unterhaltsansprüchen des nachrangigen geschiedenen Ehegatten der Unterhaltspflichtige wieder verheiratet, beträgt der Bedarf für den mit ihm zusammen lebenden Ehegatten mindestens 880 €. Vgl. zur Bedarfsberechnung im Übrigen BGH FamRZ 2012, 281, Tz. 45, 48.
22.2 Mindestbedarf bei Ansprüchen volljähriger Kinder
Ist bei Unterhaltsansprüchen nicht privilegierter volljähriger Kinder der Unterhaltspflichtige verheiratet, werden für den mit ihm zusammen lebenden Ehegatten mindestens 880 € angesetzt.
22.3. Mindestbedarf bei Ansprüchen von Eltern oder Enkeln des anderen Ehegatten und von gemeinsamen Enkeln
Ist bei Unterhaltsansprüchen der Eltern das unterhaltspflichtige Kind verheiratet, werden für den mit ihm zusammen lebenden Ehegatten mindestens 1.440 € angesetzt. Im Familienbedarf von 3.240 € (1.800 € + 1.440 €) sind Kosten für Unterkunft und Heizung von 860 € (660 € kalt + 200 € Nebenkosten und Heizung) enthalten. Dies gilt auch für Unterhaltsansprüche von und gegen Großeltern und Enkel(n).
BGH am 2010-07-28 (XII ZR 140/07) in FamRZ 2010, 1535; NJW 2010, 3161 == Familienselbstbehalt bei Berechnung des Elternunterhalts
23. Bedarf des vom Pflichtigen getrennt lebenden oder geschiedenen Ehegatten
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
bei Ansprüchen wie in Nr. 22: bleibt unbesetzt.
24. Mangelfall
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
24.1. Grundsatz
Ein absoluter Mangelfall liegt vor, wenn das Einkommen des Verpflichteten zur Deckung seines jeweils maßgeblichen Selbstbehalts und der gleichrangigen Unterhaltsansprüche nicht ausreicht. Zur Feststellung des Mangelfalls entspricht der einzusetzende Bedarf für minderjährige und diesen nach § 1603 Abs. 2 Satz 2 BGB gleichgestellten Kindern dem Zahlbetrag (Differenz zwischen dem Tabellenbetrag und dem anzurechnenden Kindergeld).
Reicht die Leistungsfähigkeit des Unterhaltspflichtigen für den Unterhalt sämtlicher (auch nachrangiger) Berechtigter nicht aus, so führt die Angemessenheitsbetrachtung beim Unterhaltsbedarf gemäß § 1610 BGB regelmäßig dazu, dass der Kindesunterhalt nur in Höhe des Existenzminimums zu veranschlagen ist (BGH FamRZ 2008, 2189, Tz. 22).
OLG Ffm am 2005-05-30 (5 WF 85/05) == Zu hohe Zahlungen an Unterhaltsvorschusskasse für eines der Kinder.
BGH am 2008-09-17 (XII ZR 72/06) in FamRZ 2008, 2198; NJW 2008,3562 == Kindesunterhalt nur in Höhe des Existenzminimums beim Mangelfall (auch im Verhältnis zu nur nachrangig Berechtigten)
BGH am 2010-06-02 (XII ZR 160/08) in FamRZ 2010, 1318; NJW 2010, 2515 == Kindesunterhalt nur in Höhe der Zahlbeträge des Mindestunterhalts im Mangelfall.
24.2. Einsatzbeträge
Zu den Einsatzbeträgen im Mangelfall beim Kindesunterhalt siehe Rechenbeispiel im Anhang III. Zwischen gleichrangigen Ehegatten bzw. bei Ansprüchen nach § 1615l BGB ist der Mindestbedarf von 880 €, ggf. herabgesetzt um Synergieeffekte und eigenes Einkommen, maßgebend. (Für die Altfälle, d.h. für die bis zum 31.12.2007 fällig gewordenen Unterhaltsansprüche, wird auf die Nr. 23.2 der Unterhaltsgrundsätze, Stand 01.07.2005, verwiesen, vgl. dazu auch BGH FamRZ 2003, 363).
BGH am 2010-03-17 (XII ZR 204/08) in FamRZ 2010, 802; NJW 2010, 1665, Tz. 18 == Mindestbedarf für Ehegattenunterhalt in Höhe des notwendigen Selbstbehalts für nicht Erwerbstätige.
24.3. Berechnung
Gielau am 2010-08-01 == Berechnungsformular ab 2008
24.3.1
Im absoluten Mangelfall ist die nach Abzug des maßgeblichen Selbstbehalts des Unterhaltspflichtigen verbleibende Verteilungsmasse anteilig auf alle gleichrangigen Unterhaltsberechtigten im Verhältnis ihrer Unterhaltsansprüche zu verteilen.
24.3.2
Stehen mehrere nach § 1609 Nr. 2 oder 3 BGB Berechtigte im gleichen Rang, schränkt die Unterhaltspflicht gegenüber dem jeweils anderen Berechtigten die Leistungsfähigkeit des Pflichtigen nach § 1581 S.1 BGB ein (sog. relativer Mangelfall). Dem kann zur Wahrung des Halbteilungsgrundsatzes dadurch Rechnung getragen werden, dass die Unterhaltsansprüche im Regelfall nach den Grundsätzen der so genannten Dreiteilung bemessen werden (BGH FamRZ 2012, 281), wobei kein Erwerbstätigenbonus zu berücksichtigen ist (BGH v. 19.3.2014 – XII ZB 19/13 = FamRZ 2014, 912 Rn. 39). Das schließt eine abweichende Verteilung aufgrund der Berücksichtigung weiterer individueller Billigkeitsabwägungen nicht aus.
BGH am 2011-12-07 (XII ZR 151/09) in FamRZ 2012, 281; NJW 2012, 384 == Lstgsfähigk. nach Drittelmethode bei Gleichrang; Anm. Schwamb, FamRB 2012, 71; MDR 2012, 557
BGH am 2013-06-26 (XII ZR 133/11) in NJW 2013, 2662, Tz. 87 == Keine Berücksichtigung eines Erwerbstätigkeitsbonus bei der Leistungsfähigkeit des Unterhaltspflichtigen, Anm. Niepmann/Schwamb. NJW 2013, 2720 unter III. 2.
BGH am 2014-03-19 (XII ZB 19/13) in FamRZ 2014, 912; NJW 2014, 1590, Tz. 38, 39 == Dreiteilung ohne Erwerbstätigenbonus, Berücks. von Synergieeffekten
BGH am 2014-05-07 (XII ZB 258/13) in FamRZ 2014, 1183; NJW 2014, 2109, Tz. 29 == Leistgsfähigkeit nach Drittelmethode bei Gleichrang.
24.3.3
Steht ein Berechtigter im Rang des § 1609 Nr. 2 BGB und ein anderer im dritten Rang, gilt folgendes: Ist der spätere Ehegatte nachrangig, berührt eine ihm gegenüber bestehende Unterhaltsverpflichtung den Unterhaltsanspruch des vorrangigen Ehegatten grundsätzlich nicht. Ist der Unterhaltsanspruch des späteren Ehegatten oder des nach § 1615l BGB Berechtigten vorrangig, bleibt zwar die Bedarfsberechnung für den zeitlich früheren Ehegatten von der neuen Unterhaltsverpflichtung unberührt. Jedoch darf der vorrangig Unterhaltsberechtigte nicht schlechter stehen als nach einer Berechnung gemäß Nr. 24.3.2 (BGH FamRZ 2012, 281, Tz. 42 u. 48)
BGH am 2011-12-07 (XII ZR 151/09) in FamRZ 2012, 281; NJW 2012, 384, Tz. 42, 48 == Verteilung bei Vorrang zweiter Ehefrau wie in 24.3.2; Anm. Schwamb, FamRB 2012, 71; MDR 2012, 557
24.4 Angemessenheitskontrolle
Das gewonnene Ergebnis ist jeweils noch auf seine Angemessenheit zu überprüfen.
Sonstiges
25. Rundung
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
Der Unterhaltsbetrag ist auf volle Euro aufzurunden.
26. Übergangsregelung
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
Für bis zum 31.12.2007 fällig gewordene Unterhaltsansprüche gilt das bis dahin geltende Recht.
Die an § 32 Abs. 6 S. 1 EStG i. d. F. des Gesetzes zur Anhebung des Grundfreibetrags, des Kinderfreibetrags, des Kindergelds und des Kinderzuschlags vom 16.7.2015 (BGBl. I 2015, 1202) ausgerichteten Mindestunterhaltsbeträge i. S. d. § 1612a BGB gelten in sinngemäßer Anwendung von § 1613 Abs. 1 S. 1 BGB erst ab 01.08.2015, ungeachtet der steuerrechtlich rückwirkend ab Januar 2015 in Kraft tretenden Kinderfreibeträge.
Anhang
INHBSBrdbgCEDDDüHBHHHRoHammJeKGKOKöNMBOldSHLSüdReiTOP
Anhang I - Düsseldorfer Tabelle
Stufe Nettoeinkommen (1) Altersstufen (2) v.H.
von bis 0-5 6-11 12-17 ab 18
1 1900 354 406 476 527 100
2 1901 2300 372 427 500 554 105
3 2301 2700 390 447 524 580 110
4 2701 3100 408 467 548 607 115
5 3101 3500 425 488 572 633 120
6 3501 3900 454 520 610 675 128
7 3901 4300 482 553 648 717 136
8 4301 4700 510 585 686 759 144
9 4701 5100 539 618 724 802 152
10 5101 5500 567 650 762 844 160
über 5.500 € nach den Umständen des Falles.
(1) des Barunterhaltspflichtigen in Euro
(2) in Jahren (vgl. § 1612a Abs. 1 u. 3 BGB)
oldies == hier die früheren Tabellen:
Schwamb am 2009-01-05 == Anmerkung zur Düsseldorfer Tabelle 2009
OLG Ffm am 2017-01-01 == Düsseldorfer Tabelle 2017_01 / Zahlbeträge
OLG Ffm am 2018-01-01 == Düsseldorfer Tabelle 2018_01 / Zahlbeträge
Schwamb am 2018-02-01 in FamRB 2018, 67 == Die DT 2018 - eine bittere Pille für Kinder Alleinerziehender
OLG Ffm am 2019-01-01 == Düsseldorfer Tabelle 2019_01 / Zahlbeträge
OLG Ffm am 2019-07-01 == Düsseldorfer Tabelle 2019_07 / Zahlbeträge
Anhang II - Umrechnung dynamischer Titel über Kindesunterhalt in Mindestunterhalt gem. § 36 Nr. 3 EGZPO
Siehe Düsseldorfer Tabelle unter E.
Während die dort errechneten Prozentsätze unverändert bleiben, auch wenn das Kind in eine höhere Altersstufe wechselt (BGH FamRZ 2012, 1048), müssen die ausgewiesenen Zahlbeträge für 2009 erstmals geändert werden, vgl. Diehl, FamExpress (Deubner-Verlag), Heft 2/2009, aufrufbar bei www.hefam.de unter Unterhaltsgrundsätze/Arbeitspapier, Anhang II, oder in der „Chronik“ 2009-01-06.
Für 1.1.2010 bis 31.7.2015 bzw. für 1.8.2015 bis 31.12.2015, 1.1.2016 bis 31.12.2016, 1.1.2017 bis 31.12.2017 und 1.1.2018 bis 31.12.2018 gelten die Beträge im jeweiligen Anhang II der Unterhaltsgrundsätze vom 1.1.2015 bzw. 1.8.2015 , 1.1.2016, 1.1.2017 und 1.1.2018..
Aufgrund der Erhöhung des Mindestunterhalts zum 1. 1. 2019 ergeben sich seither folgende Zahlbeträge:
Bsp. 1 seit 1.1.2019:
354 x 97,8% = aufgerundet 347 EUR, abzüglich hälftiges Kindergeld 97 EUR = 250 EUR.
Bsp. 2 seit 1.1.2019:
354 x 70,2% = aufgerundet 249 EUR zuzüglich hälftiges Kindergeld 97 EUR = 346 EUR.
Bsp. 3 seit 1.1.2019:
406 x 102,7% = aufgerundet 417 EUR abzüglich volles Kindergeld 194 EUR = 223 EUR.
Bsp. 4 seit 1.1.2019:
476 x 111,2% = aufgerundet 530 EUR abzügl. hälftiges Kindergeld 97 EUR = 433 EUR.
Aufgrund der Erhöhung des Kindergelds ab 1. 7. 2019 ergeben sich seither folgende Zahlbeträge:
Bsp. 1 seit 1.7.2019:
354 x 97,8% = aufgerundet 347 EUR, abzüglich hälftiges Kindergeld 102 EUR = 245 EUR.
Bsp. 2 seit 1.7.2019:
354 x 70,2% = aufgerundet 249 EUR zuzüglich hälftiges Kindergeld 102 EUR = 351 EUR.
Bsp. 3 seit 1.7.2019:
406 x 102,7% = aufgerundet 417 EUR abzüglich volles Kindergeld 204 EUR = 213 EUR.
Bsp. 4 seit 1.7.2019:
476 x 111,2% = aufgerundet 530 EUR abzügl. hälftiges Kindergeld 102 EUR = 428 EUR.
OLG Dü am 2015-08-01 == Düsseldorfer Tabelle 8/2015 mit Beispiel E.
Diehl am 2009-01-06 == Zur Umrechnung von Alttiteln gem. § 36 Nr. 3 EGZPO in FamExpress 2/2009 (Deubner-Verlag)
BGH am 2012-04-18 (XII ZR 66/10) in FamRZ 2012, 1048; NJW 2012, 1873 == Keine Änderung des Prozentsatzes bei Wechsel in höhere Altersstufe.
Anhang III - Rechenbeispiele
Absoluter Mangelfall (für 1.1.2019 gerechnet)
Der Verpflichtete M hat ein bereinigtes Nettoeinkommen von 1910 €. Unterhaltsberechtigt sind ein 18-jähriges Kind K1, das bei der Mutter lebt und auf's Gymnasium geht, und die beiden minderjährigen Kinder K2 (14 Jahre) und K3 (10 Jahre), die von der Mutter betreut werden. Das Kindergeld von 588 € (194 € + 194 € + 200 €) wird an die Mutter ausbezahlt, deren sonstiges Einkommen unter 880 € liegt.
Unterhaltsberechnung gemäß Nr. 24.1: Mangels Leistungsfähigkeit der Mutter alleinige Barunterhaltspflicht von M für alle Kinder. M erzielt zwar ein Einkommen nach der 2. Einkommensgruppe, ist aber bei drei Berechtigten in die 1. Einkommensgruppe einzustufen. Da ersichtlich ein Mangelfall vorliegt, ist das außerdem auch bereits deshalb der Fall.
Mindestbedarf K1: 527 € (Düsseldorfer Tabelle Gruppe 1, 4. Altersstufe) - 194 € Kindergeld => offener Bedarf = Einsatzbetrag 333 €
Mindestunterhalt K2: 476 € - 97 € hälftiges Kindergeld => offener Bedarf = Einsatzbetrag 379 €
Mindestunterhalt K3: 406 € - 100 € hälftiges Kindergeld => offener Bedarf = Einsatzbetrag 306 €
Summe der Einsatzbeträge: 333 + 379 + 306 = 1018 €
Verteilungsmasse: 1910 € - 1080 € = 830 €
Prozentuale Kürzung: 830/1018 * 100 = 81,5 %
Berechnung der gekürzten Unterhaltsansprüche:
K1: 333 € * 81,5 % = 272 €; zum Leben verfügbar also 272 + 194 = 466 €
K2: 379 € * 81,5 % = 309 €; zum Leben verfügbar also 309 + 97 = 406 €
K3: 306 € * 81,5 % = 250 €; zum Leben verfügbar also 250 + 100 = 350 €
hjg == Einstufige Mangelberechnung ab 2008
Absoluter Mangelfall (für 1.7.2019 gerechnet)
Der Verpflichtete M hat ein bereinigtes Nettoeinkommen von 1910 €. Unterhaltsberechtigt sind ein 18-jähriges Kind K1, das bei der Mutter lebt und auf's Gymnasium geht, und die beiden minderjährigen Kinder K2 (14 Jahre) und K3 (10 Jahre), die von der Mutter betreut werden. Das Kindergeld von 618 € (204 € + 204 € + 210 €) wird an die Mutter ausbezahlt, deren sonstiges Einkommen unter 880 € liegt.
Unterhaltsberechnung gemäß Nr. 24.1: Mangels Leistungsfähigkeit der Mutter alleinige Barunterhaltspflicht von M für alle Kinder. M erzielt zwar ein Einkommen nach der 2. Einkommensgruppe, ist aber bei drei Berechtigten in die 1. Einkommensgruppe einzustufen. Da ersichtlich ein Mangelfall vorliegt, ist das außerdem auch bereits deshalb der Fall.
Mindestbedarf K1: 527 € (Düsseldorfer Tabelle Gruppe 1, 4. Altersstufe) - 204 € Kindergeld => offener Bedarf = Einsatzbetrag 323 €
Mindestunterhalt K2: 476 € - 102 € hälftiges Kindergeld => offener Bedarf = Einsatzbetrag 374 €
Mindestunterhalt K3: 406 € - 105 € hälftiges Kindergeld => offener Bedarf = Einsatzbetrag 301 €
Summe der Einsatzbeträge: 323 + 374 + 301 = 998 €
Verteilungsmasse: 1910 € - 1080 € = 830 €
Prozentuale Kürzung: 830/998 * 100 = 83 %
Berechnung der gekürzten Unterhaltsansprüche:
K1: 323 € * 83 % = 269 €; zum Leben verfügbar also 269 + 204 = 473 €
K2: 374 € * 83 % = 311 €; zum Leben verfügbar also 311 + 102 = 413 €
K3: 301 € * 83 % = 250 €; zum Leben verfügbar also 250 + 105 = 355 €
frühere Grundsätze / Tabellen / Zahlbeträge: 2019-07 Düsseldorfer Tabelle 2019_07 / Zahlbeträge
2019-01 Düsseldorfer Tabelle 2019_01 / Zahlbeträge
2019-01 Roos: DTab ab 1.1.2019 - Große Übersicht (PDF)
2018-01 Düsseldorfer Tabelle 2018_01 / Zahlbeträge
2018-01 Roos: DTab ab 1.1.2018 - Große Übersicht (PDF)
2017-01 Unterhaltsgrundsätze des OLG Ffm 01.01.2017 (PDF)
2017-01 Düsseldorfer Tabelle 2017_01 / Zahlbeträge
2017-01 Roos: DTab ab 1.1.2017 - Große Übersicht (PDF)
2016-01 Unterhaltsgrundsätze des OLG Ffm 01.01.2016 (PDF)
2016-01 Düsseldorfer Tabelle 2016_01 / Zahlbeträge
2016-01 Roos: DTab ab 1.1.2016 - Große Übersicht (PDF)
2016-01 Roos: Regelsätze/MindestUnterhalt seit 2008/1982 bis 2016 (PDF)
2015-08 Unterhaltsgrundsätze des OLG Ffm 01.08.2015 (PDF)
2015-08 Düsseldorfer Tabelle 2015_08 / Zahlbeträge
2015-01 Unterhaltsgrundsätze des OLG Ffm 01.01.2015 (PDF)
2014-01 Unterhaltsgrundsätze des OLG Ffm 01.01.2014 (PDF)
2013-01 Unterhaltsgrundsätze des OLG Ffm 01.01.2013 (PDF)
2011-01 Unterhaltsgrundsätze des OLG Ffm 01.01.2011 (PDF)
2010-07 Unterhaltsgrundsätze des OLG Ffm 01.07.2010 (PDF)
2010-01 Unterhaltsgrundsätze des OLG Ffm 01.01.2010 (PDF)
2010-01 Düsseldorfer Tabelle 2010 / Zahlbeträge
2009-01 Unterhaltsgrundsätze des OLG Ffm 01.01.2009 (PDF)
2009-01 Düsseldorfer Tabelle 2009 / Zahlbeträge
2009-01 Roos: DTab ab 1.1.2009 - Große Übersicht (PDF)
2008-01 Unterhaltsgrundsätze des OLG Ffm 01.01.2008 (PDF)
2008-01 Düsseldorfer Tabelle 2008 / Zahlbeträge
2007-07 Beschlüsse des OLG Ffm zur Düsseldorfer Tabelle ab 01.07.2007 (PDF)
2005-07 Unterhaltsgrundsätze des OLG Ffm ab 01.07.2005 (PDF)
2003-11 Juncker zu den neuen Leitlinien (2003) - Erfahrungsaustausch 10. - 12.11.2003
2003-07 Unterhaltsgrundsätze des OLG Ffm ab 01.07.2003
2001-07 Düsseldorfer Tabelle ab 01.07.2001 / Zahlbetäge
2001-07 Düsseldorfer Tabelle ab 01.07.2001 (Anm.)
EuGH zur Zuständigkeit deutscher Gerichte zur Erteilung eines Erbscheins nach § 343 Abs. 3 FamFG
Share Share Share Tweet Send
Inhaltsverzeichnis:
In der Rechtssache C‑20/17 hat der Europäische Gerichtshof (EuGH) mit Urteil vom 21. Juni 2018 entschieden, dass die Europäische Erbrechtsverordnung (EuErbVO) der Zuständigkeit deutscher Gerichte zur Erteilung eines Erbscheins entgegensteht, wenn Erblasser seinen gewöhnlichen Aufenthalt in einem anderen Staat hatte.
\define pluginInfoTiddlerName()
twCard - Plugin - $(pluginName)$
\end
\define thisAddWidgetsThing()
<$fieldmangler tiddler={{$:/state/UpdatePlugintwCard}}>
<$button>Add Widget
<$action-sendmessage $message='tm-add-tag' $param="""widget-$(widgetTag)$"""/>
<$action-setfield $tiddler='$:/temp/UpdatePlugintwCard/temp' $field=add_widget $value=''/>
</$button>
</$fieldmangler>
\end
\define thisAddTiddlersThing()
<$fieldmangler tiddler={{$:/state/UpdatePlugintwCard}}>
<$button>Add Other Tiddler
<$action-sendmessage $message='tm-add-tag' $param="""tiddler-$(tiddlerTag)$"""/>
<$action-setfield $tiddler='$:/temp/UpdatePlugintwCard/temp' $field=add_tiddler $value=''/>
</$button>
</$fieldmangler>
\end
\define thisRemoveWidgetThing()
<$fieldmangler tiddler="""$(currentPlugintwCard)$""">
<$button>Remove Widget
<$action-sendmessage $message='tm-remove-tag' $param="""widget-$(widgetTag)$"""/>
</$button>
</$fieldmangler>
\end
\define thisRemoveTiddlerThing()
<$fieldmangler tiddler="""$(currentPlugintwCard)$""">
<$button>Remove Tiddler
<$action-sendmessage $message='tm-remove-tag' $param="""tiddler-$(tiddlerTag)$"""/>
</$button>
</$fieldmangler>
\end
\define currentPlugintwCardName() """$(currentPlugintwCard)$"""
Enter Plugin Information Here:
Plugin Name: <$select tiddler='$:/state/UpdatePlugintwCard'>
<$list filter='[tag[Plugin twCard]sort[title]]'>
<$set name=thisTid value=<<currentTiddler>>>
<$list filter='[<currentTiddler>get[title]]+[removeprefix[twCard - Plugin - ]]'>
<option value=<<thisTid>>><$view field='title'/></option>
</$list>
</$set>
</$list>
</$select>
<$list filter='[[$:/state/UpdatePlugintwCard]get[text]]' variable=currentPlugintwCard>
<$fieldmangler tiddler=<<currentPlugintwCardName>>>
Long Description:
<$edit-text tiddler={{$:/state/UpdatePlugintwCard}} field=text class='tc-edit-texteditor'/>
<$set name=widgetTag value={{$:/temp/UpdatePlugintwCard/temp!!add_widget}}>
<<thisAddWidgetsThing>></$set> : <$edit-text tiddler='$:/temp/UpdatePlugintwCard/temp' field='add_widget'/><br>
<$set name=tiddlerTag value={{$:/temp/UpdatePlugintwCard/temp!!add_tiddler}}>
<<thisAddTiddlersThing>></$set> : <$edit-text tiddler='$:/temp/UpdatePlugintwCard/temp' field='add_tiddler'/>
<table>
<tr><th>Widget List</th></tr>
<$list filter='[<currentPlugintwCard>tags[]]+[removeprefix[widget-]]'>
<$set name=widgetTag value=<<currentTiddler>>>
<tr><td><<currentTiddler>></td><td><<thisRemoveWidgetThing>></td></tr>
</$set>
</$list>
<tr><th>Other Tiddler List</th></tr>
<$list filter='[<currentPlugintwCard>tags[]]+[removeprefix[tiddler-]]'>
<$set name=tiddlerTag value=<<currentTiddler>>>
<tr><td><<currentTiddler>></td><td><<thisRemoveTiddlerThing>></td></tr>
</$set>
</$list>
</table>
<table>
<$list filter='[[Plugin Info Template]fields[]sort[title]]-[[text]]-[[modified]]-[[created]]-[[tags]]-[[title]]'>
<tr><td><<currentTiddler>></td><td><$edit-text tiddler=<<currentPlugintwCard>> field=<<currentTiddler>> class='tc-edit-texteditor' size=70/></td></tr>
</$list>
</table>
</$fieldmangler>
</$list>
By default, you can list this tiddler's tags by
```
<$list filter="[all[current]tags[]]">
</$list>
```
You can reproduce the same list using `currentTiddler` in this way:
```
<$list filter="[<currentTiddler>tags[]]">
</$list>
```
The `currentTiddler` means the tiddler which contains the code if the tiddler is `{{transcluded}}` in to another. If you want to refer to the tiddler which is shown in the storylist, use `storyTiddler` instead:
```
<$list filter="[<storyTiddler>tags[]]">
</$list>
```
If you want to extend the apperance of the tiddlers by adding new elements, or you like to add new buttons, widgets, decorators, then have a look at $:/tags: these are the "hooks" (like in Git) where you can place the new widgets.
For example look at $:/core/ui/MoreSideBar/Explorer:
- It has the $:/tags/MoreSideBar tag thus it appears in the More tab on the sidebar
- The `caption` field sets up the name to display (instead of the real name of the tiddler which is its path)
- Additionally you can add other fields like `list-before` for example to set up the position in the list (`list-before = $:/core/ui/MoreSideBar/System`)
So if you want to add a new entry to the More tab, then create a tiddler like `$:/yourname/moresidebar/MyNewButton` and set up the same settings as above.
These are the currently used system tags:
<ul>
<$list filter="[all[shadows+tiddlers]tags[]prefix[$:/]sort[title]]">
<li>{{||$:/core/ui/TagTemplate}}</li>
</$list>
</ul>
For the whole list see the [[tags reference|https://tiddlywiki.com/#SystemTags]].
One of the most enamoring things about TiddlyWiki is the emphasis on information re-usability.
<<<
The fundamental idea is that information is more useful and reusable if we cut it up into the smallest semantically meaningful chunks – tiddlers – and give them titles so that they can be structured with links, tags, lists and macros.
-- [[Source|https://tiddlywiki.com/#TiddlyWiki]]
<<<
Tiddlers are the most fundamental objects in the TiddlyWiki universe. Everything in this notebook is built on tiddlers.
Given their immense utility, surely they can be used to build other things other than TiddlyWiki-centric components? What about, say, HTTP APIs? It turns out, the answer is ''yes''.
Suppose we want to create a service that returns some JSON data as a response. We could write create tiddlers that describe what we want to do and what data it should send back when called upon (these tiddlers can be considered as arguments taken in by a supporting remote procedure that evaluates it in a RPC-like API).
Consider the following JSON:
```json
{
"mydatabase": {
"created": "20190109184902310",
"creator": "A.B. Samma",
"text": "https://maarfapad.cloudno.de/wiki/home",
"title": "Test",
"tags": "[[public wiki]]",
"type": "@pub_data",
"data": [{
"created": "20190109184902310",
"creator": "A.B. Samma",
"text": "https://maarfapad.cloudno.de/wiki/home",
"title": "Test link",
"tags": "[[public wiki]]",
"modified": "20190109185002027",
"modifier": "A.B. Samma"
}],
"modified": "20190109185002027",
"modifier": "A.B. Samma"
}
}
```
Here we have a tiddler object titled "Test" with all the usual fields such as tags, text, et cetera. There is also a field for type which can describe the type of operation this tiddler should effect. In this case, the type is `@pub_data` which means that, when called by a client via the tiddler's key (`/pub/mydatabase`), this tiddler should send this `data` from the remote server to the client.
```
[{
"created": "20190109184902310",
"creator": "A.B. Samma",
"text": "https://maarfapad.cloudno.de/wiki/home",
"title": "Test link",
"tags": "[[public wiki]]",
"modified": "20190109185002027",
"modifier": "A.B. Samma"
}]
```
A number of other operations can be implemented as well. We could for example define an API that would send us something else, say an entire TiddlyWiki notebook.
Assuming the wiki is stored in the same server and there is a supporting procedure, we'd define the tiddler as:
```json
{
"mywebsite": {
"created": "20190109184902310",
"creator": "A.B. Samma",
"text": "https://maarfapad.cloudno.de/wiki/home",
"title": "Test link",
"tags": "[[public wiki]]",
"type": "@pub_web",
"data": "home",
"modified": "20190109185002027",
"modifier": "A.B. Samma"
}
}
```
The server will notice the type `@pub_web` and interpret the `data` as the name of the wiki it has to send back, with appropriate `content-type` headers. This API route can be invoked by sending a GET request to `/pub/mywebsite`.
__''In summary''__
We have just described a means of creating/remixing/modifying useful web services using nothing but tiddlers that can created from any TiddlyWiki client and stored in a supporting backend to be invoked later.
This was all originally conceived to solve the problem of making wiki notebooks hosted at [[Maarfapad|http://maarfapad.com]] public on request. But clearly we can do more with this. Heck, we could even create a Function as a Service API using this! The possibilities are endless.
__''Future work''__
I'll be working hard to create a standard dictionary of supported key value fields and documenting what they allow users to do before releasing the first working service. These fields that you see here are by no means fixed. If you like what you have seen here today, tweet to me at [[@ABSamma|https://twitter.com/ABSamma]]!
* Third Condition modified
See also the [[introduction to the concept of variables|Variables]].
To transclude the value of a variable, use the [[macro call syntax|Macro Calls in WikiText]] with no parameters. You can also use a <<.wlink MacroCallWidget>> widget.
A [[macro|Macros]] snippet can contain `$(name)$` as a [[placeholder|Macro Definitions in WikiText]] for which the value of the variable of that name will be substituted.
A variable's value can be used as a [[filter parameter|Filter Parameter]], or as a [[widget attribute|Widgets in WikiText]]. The latter supports macro parameters.
!! Example: defining a variable
<$macrocall $name=".example" n="1"
eg="""<$set name=animal value=zebra>
<<animal>>
</$set>"""/>
!! Example: defining a macro
The `\define` pragma below [[defines a macro|Macros in WikiText]] called <<.var tags-of-current-tiddler>>. The macro returns the value of the tiddler's <<.field tags>> field, and can be accessed from anywhere else in the same tiddler (or in any tiddler that [[imports|ImportVariablesWidget]] it).
<$importvariables filter="$:/editions/tw5.com/macro-examples/tags-of-current-tiddler">
<$codeblock code={{$:/editions/tw5.com/macro-examples/tags-of-current-tiddler}}/>
<$macrocall $name=".example" n="2" eg="""The tags are: <<tags-of-current-tiddler>>"""/>
</$importvariables>
!! Example: using a variable as a filter parameter
This example uses the <<.olink backlinks>> [[operator|Filter Operators]] to list all tiddlers that link to this one.
<$macrocall $name=".example" n="3" eg="""<<list-links filter:"[<currentTiddler>backlinks[]]">>"""/>
\define linkFolder()
[[related folder|file:///D:/Project-Foo/$(currentTiddler)$]]
\end
As [[Jed Carty]] explains in [[this port|https://groups.google.com/d/msg/tiddlywiki/UWtxdIMTf9w/tHt7V-olXJ0J]], here's an answer to an often asked question: How to you insert variable text in wiki markup? The answer is: with a macro.
The below creates a link to a local folder depending on a folder name stored at a tiddler field called ''folder''.
```
\define linkFolder()
[[related folder|file:///D:/Project-Foo/$(folder)$]]
\end
<$set name=folder value={{!!folder}}>
<<linkFolder>>
</$set>
```
''Note:'' The above only works in TiddlyWiki loaded from your local filesystem.
The next example simply takes the tiddler title as the folder name...
```
\define linkFolder()
[[related folder|file:///D:/Project-Foo/$(currentTiddler)$]]
\end
<<linkFolder>>
```
> <<linkFolder>>
A <<.def variable>> is a snippet of text that can be accessed by name within a particular branch of the [[widget tree|Widgets]]. The snippet is known as the variable's <<.def value>>.
A new variable is defined using a <<.wlink SetWidget>> widget, and is then available to any of the children of that widget, including transcluded content. A <<.wid set>> widget can reuse an existing name, thus binding a different snippet to that name for the duration of the widget's children.
The <<.wlink ListWidget>> widget also sets a particular variable (<<.var currentTiddler>> by default) to each listed title in turn.
For an overview of how to use variables, see [[Variables in WikiText]].
Despite the term <<.word variable>>, each snippet is a constant string. The apparent variability is actually the result of the presence of multiple variables with the same name in different parts of the widget tree.
[[Macros]] are a special form of variable whose value can contain placeholders that get filled in with parameters whenever the macro is used.
By themselves, the snippets are <<.em not>> parsed as WikiText. However, a variable reference will transclude a snippet into a context where ~WikiText parsing <<.em may>> be occurring. Within a snippet, the only markup detected is `$name$` for a macro parameter transclusion and `$(name)$` for a variable transclusion.
The <<.mlink dumpvariables>> macro lists all variables (including macros) that are available at that position in the widget tree.
~TiddlyWiki's core has [[several variables|Core Variables]] built in.
<hr><small>see also: <$list filter="[tag[Variables]sort[title]]">
<$link><$view field="title"/></$link>, </$list></small>
Variables
<hr/><$list filter="[field:title[Variables]]">
<$list filter="[all[current]tags[]sort[title]]" template="$:/core/ui/TagTemplate" storyview="pop"/><h2><$link><$view field="title"/></$link></h2>
<$transclude tiddler=<<currentTiddler>> mode="block"/>
</$list>
<hr/>
<$radio field="show" value="$:/no"> Do not expand.</$radio>
<br><$radio field="show" value="$:/showall"> Expand, show all alphabetic.</$radio>
<br><$radio field="show" value="$:/showmostrecent"> Expand, show all most recent first.</$radio>
<hr/>
<$list filter="[all[current]field:show[$:/showall]]">
''EXPAND, SHOW ALL ALPHABETIC (without examples)''
<$list filter="[tag[Variables]!field:title[Variables]!has[draft.of]]">
<hr/> <$list filter="[all[current]tags[]sort[title]]" template="$:/core/ui/TagTemplate" storyview="pop"/><h2><$link><$view field="title"/></$link></h2>
<small>
<$transclude tiddler=<<currentTiddler>> mode="block"/></small>
</$list>
</$list>
<$list filter="[all[current]field:show[$:/showmostrecent]]">
''EXPAND, SHOW ALL, MOST RECENT FIRST''
<$list filter="[tag[Variables]!field:title[Variables]!has[draft.of]!sort[modified]]">
<hr/> <$list filter="[all[current]tags[]sort[title]]" template="$:/core/ui/TagTemplate" storyview="pop"/><h2><$link><$view field="title"/></$link></h2>
<small>
<br>modified: <$view field="modified" /> modifier: <$view field="modifier" />
<br>created: <$view field="created" />
<$transclude tiddler=<<currentTiddler>> mode="block"/></small>
</$list>
</$list>
<$list filter="[{!!draft.title}!is[missing]]" variable="listItem">
<$button>
Open Existing Tiddler
<$action-navigate $to={{!!draft.title}}/>
<$action-sendmessage $message='tm-close-tiddler'/>
</$button>
</$list>
in der Regel (-), es sei denn Prägung der
ehelichen Lebensverhältnisse bei guten Einkommensverhältnissen
(-), vgl. aber oben Arbeitnehmersparzulage und Arbeitgeberzuschuss zur Vermögensbildung
Für einen möglichen Schadensersatzanspruch muss der vorliegende Mangel vom Reiseveranstalter verschuldet sein.
Dabei gilt es zu prüfen, ob dieser die Beeinträchtigungen hatte verhindern oder ihnen entgegenwirken können. Liegt demnach höhere Gewalt (Vulkanausbruch) oder ein allgemeines Lebensrisiko (Lebensmittelvergiftung) vor, ist dies meist nicht der Fall. Ähnlich sieht es in Bezug auf den Schadensersatz für entgangene Urlaubsfreuden nach einem Verkehrsunfall aus.
notwendige Versicherungsaufwendungen wie Krankenversicherung, Rentenversicherung, Arbeitslosenversicherung (+), sonst in der Regel (-).(siehe einz
elne Versicherungen)
{{||$:/core/ui/TiddlerFields}}
rendered via <<source "$:/core/ui/TiddlerFields">>
Bei der Scheidung teilt das Familiengericht automatisch die Rentenanwartschaften zwischen den Ex-Partnern im Rahmen des Versorgungsausgleichs auf.
Folgesache zur Scheidung oder als isoliertes Verfahren. Auch bei Scheidung im Ausland wenn Anrechte in Deutschland erworben worden sind [[EGBGB Art 17]]
---
<<footnotes "Gesetz" "[[EGBGB Art 17]]">>
Anders als beim Zugewinnausgleich ist dazu kein gesonderter Antrag im Scheidungsverfahren erforderlich.
Nach dem Versorgungsausgleich fließt zunächst kein Geld. Erst mit Renteneintritt profitieren die ehemaligen Eheleute eventuell von der Altersvorsorge des Ex-Partners.
In einem Ehevertrag können Eheleute auf den Versorgungsausgleich ''verzichten''. Auch ohne Vertrag können Ehemann und -frau auf die Verteilung der Anrechte noch im Scheidungsprozess verzichten.
Hat die Ehe ''keine drei Jahre'' gehalten, entfällt der Versorgungsausgleich.[[]]
''Wann Sie auf den Versorgungsausgleich verzichten sollten''
In einigen Fällen kann es sinnvoll sein, den Versorgungsausgleich nicht in die Hände des Gerichts zu legen, sondern diesen einvernehmlich zu regeln. Das kann sein, wenn die Teilungskosten zu hoch sind, der Ausgleich zu einem unfairen Ergebnis käme oder von beiden Partnern einfach nicht gewollt ist. Sie können dann statt der Übertragung der Anwartschaften einen Ausgleichsbetrag oder eine andere Gegenleistung vereinbaren.
Wer ohnehin einen Ehevertrag abgeschlossen hat, hat meist auch den Versorgungsausgleich geregelt. In einer Doppelverdiener-Ehe oder bei später Heirat haben beide Eheleute eventuell schon ausreichende Versorgungsanwartschaften erworben. Solche Paare können in einem Ehevertrag den Versorgungsausgleich ausschließen (§ 6 Abs. 1 Nr. 2 VersAusglG). Dann entscheidet im Fall der Scheidung das Gericht nicht über den Versorgungsausgleich. Es ist auch möglich, bestimmte Anwartschaften ganz oder teilweise auszuschließen.
Notarielle Beurkundung oder gerichtlicher Vergleich - Eine solche Vereinbarung muss allerdings von einem Notar beurkundet werden (§ 7 VersAusglG). Die Parteien können aber auch noch im Scheidungstermin im Rahmen eines gerichtlichen Vergleichs auf den Versorgungsausgleich verzichten. Das geht aber nur, wenn beide Eheleute jeweils einen eigenen Anwalt zum Termin mitbringen. Dies ist zum Schutz der schwächeren Partei so vorgeschrieben. Da bei einer einvernehmlichen Scheidung allerdings oft nur die Antragstellerseite anwaltlich vertreten ist, muss zumindest für die Protokollierung ein zweiter Anwalt beauftragt werden.
''
Gerichtliche Kontrolle'' - Verzichten die Parteien auf den Versorgungsausgleich, muss das Gericht prüfen, ob der Verzicht nicht ausnahmsweise unfair ist (§ 8 VersAusglG). Das kann sein, wenn einer der Eheleute durch den Verzicht in unzumutbarer Weise benachteiligt wird, etwa weil einer der Eheleute nicht berufstätig war, um Kinder großzuziehen und er jetzt auf den Ausgleich verzichtet.
Wer sich scheiden lässt, hat vieles zu regeln: Da geht es vielleicht um das Sorgerecht für die Kinder und meistens um finanzielle Fragen. Nicht nur das vorhandene Vermögen ist im Zugewinnausgleich aufzuteilen, sondern auch das, worauf man Ansprüche erworben hat: vor allem die Rente. Meist haben beide Eheleute für ihre Altersvorsorge entweder Beiträge in die gesetzliche Rentenversicherung oder in eine betriebliche Altersversorgung gezahlt oder mit einer Riester- oder Rürup-Versicherung privat vorgesorgt. Damit bei der Trennung alles gerecht aufgeteilt wird, gibt es den sogenannten Versorgungsausgleich. Die rechtliche Grundlage bildet das Versorgungsausgleichsgesetz. Danach gilt, dass grundsätzlich alle während der Ehe erworbenen Ansprüche auf Altersversorgung je zur Hälfte geteilt werden. Es fließt, anders als beim Zugewinnausgleich, zwar erst einmal kein Geld – der Versorgungsausgleich ist aber dennoch wichtig, da es um Ihre Altersvorsorge geht!
Diese Versicherungen sind vom Versorgungsausgleich erfasst
Die Grundidee ist einfach: Jede Rentenanwartschaft, die während der Ehe entstanden ist, wird halbiert und beiden Partnern jeweils zu 50 Prozent gutgeschrieben. Das gilt auch für Ansprüche wegen Invalidität.
In den Versorgungsausgleich fallen alle Versicherungen, die später eine Rente zahlen. Aber nicht alle Verträge zur Altersvorsorge werden ausgeglichen. Manche privaten Rentenversicherungen oder Betriebsrenten sehen vor, dass man später zwischen einer Einmalzahlung und einer monatlichen Rente wählen kann. Sieht das Vertragsmodell grundsätzlich eine Rentenzahlung vor, kann man aber später stattdessen eine Einmalzahlung wählen, so fällt der Vertrag in den Versorgungsausgleich, solange noch nicht die Einmalzahlung gewählt wurde. Sieht der Vertrag umgekehrt grundsätzlich eine Einmalzahlung vor, so fällt der Vertrag nicht in den Versorgungsausgleich, sondern in den Zugewinnausgleich, solange der Versicherte keine Rentenzahlung gewählt hat.
Verträge mit und ohne Versorgungsausgleich
Versorgungen mit Ausgleich Versorgungen ohne Ausgleich
gesetzliche Rentenversicherung (Entgeltpunkte) Kapitallebensversicherung
Anwartschaften von berufsständischen Versorgungswerken (Ärzte, Anwälte, Architekten, Apotheker) Risikolebensversicherung
Private Rentenversicherung, die zwingend in eine Rente mündet oder bei denen das Rentenwahlrecht bereits unwiderruflich ausgeübt wurde Renten, die nichts mit dem Alter oder einer Erwerbsunfähigkeit zu tun haben (Opferrente, Rente der Berufsgenossenschaft, private Unfallrente)
Betriebsrente (betriebliche Altersversorgung)
Zusatzversorgung öffentlicher Dienst (Versorgungspunkte)
Riester-Rente, Rürup-Rente (§ 2 Abs. 2 Nr. 3 VersAusGlG)
Erwerbsunfähigkeitsrente
Quelle: Finanztip-Recherche (Stand: 15. September 2016)
Das Prinzip des Versorgungsausgleichs
Die Rentenanwartschaften sind bei den Ehegatten in der Regel unterschiedlich hoch. Oft hat derjenige eine geringere Anwartschaft, der wegen der Kindererziehung eine gewisse Zeit nicht gearbeitet hat. Unterschiedlich hohe Anwartschaften entstehen auch, wenn einer von beiden längere Zeit arbeitslos war oder wenn einer im öffentlichen Dienst beschäftigt ist.
Durch den Versorgungsausgleich werden diese Unterschiede ausgeglichen. Jeder Ehegatte bekommt die Hälfte derjenigen Rente oder Pension des anderen Ehegatten, die dieser während der Ehezeit erworben hat. Im Ergebnis haben nach dem Versorgungsausgleich beide Ehegatten eine gleich hohe Altersversorgung.
Beispiel: Partner A besitzt zum Zeitpunkt der Heirat eine gesetzliche Rentenanwartschaft in Höhe von monatlich 150 Euro. Zum Zeitpunkt der Scheidung ist der Anspruch auf künftige Rente auf 650 Euro pro Monat gestiegen. Zusätzlich hat er während der Ehe eine Zusatzversorgung, die einen Stand von 60 Euro hat. Partnerin B hat zum Zeitpunkt der Hochzeit einen Anspruch auf Beamtenversorgung in Höhe von monatlich 200 Euro, zum Zeitpunkt der Scheidung beläuft sich der Anspruch auf 900 Euro. Sie hat zusätzlich noch eine Riester-Versicherung während der Ehe abgeschlossen, die bei der Scheidung einen Anspruch von monatlich 160 Euro hat.
Partner A bekommt diese Anwartschaften: 350 Euro (Beamtenversorgung) + 80 Euro (Riester-Vertrag).
Partnerin B bekommt diese Anwartschaften: 250 Euro (gesetzliche Rente) + 30 Euro (Zusatzversorgung).
Quelle: Finanztip-Grafik (Stand: 7. September 2016)
Es kommt auf die Ehezeit an
Als Ehezeit gilt die Zeit vom Beginn des Monats, in dem die Ehe geschlossen wurde, bis zum Ende des Monats, der der Zustellung des Scheidungsantrags vorausgeht (§ 3 Abs. 1 VersAusglG).
Trennungszeit - In den Versorgungsausgleich fallen auch die Rentenanwartschaften, die die Eheleute während der Trennungszeit erworben haben. Bei ungewöhnlich langer Trennungszeit kann es jedoch gerechtfertigt sein, den Versorgungsausgleich auf den Zeitraum von der Eheschließung bis zur Trennung der Parteien zu beschränken. In derartigen Fällen kann es ungerechtfertigt sein, wenn der Ausgleichspflichtige trotz der jahrelangen Trennung einen nicht unerheblichen Teil seiner Rentenanwartschaften an den Ehegatten verlieren würde (BGH, Beschluss vom 29. März 2006, Az. XII ZB 2/02; OLG Celle, Beschluss vom 25. Juli 2000, Az. 17 U F 88/00).
Kein Versorgungsausgleich bei krassem Fehlverhalten - Das Gericht teilt Rentenansprüche ausnahmsweise dann nicht, sofern eine solche Teilung grob unbillig wäre (§ 27 VersAusglG). Das gilt etwa, wenn der eine Ehepartner den anderen massiv bedroht und verletzt hat (OLG Oldenburg, Beschluss vom 17. November 2016, Az. 3 UF 146/16).
Kein Versorgungsausgleich bei kurzer Ehe - Hat die Ehe höchstens drei Jahre gedauert, wird kein Versorgungsausgleich durchgeführt – es sei denn, einer der beiden Ex-Partner besteht darauf (§ 3 Abs. 3 VersAusglG). Maßgeblich ist die Ehezeit, die mit dem ersten Tag des Monats beginnt, in dem das Paar geheiratet hat; sie endet am letzten Tag des Monats vor Zustellung des Scheidungsantrags. Wann die Trennung erfolgte, spielt keine Rolle.
Beispiel 1: Das Ehepaar hat am 20. August 2013 geheiratet. Der Scheidungsantrag wird am 1. Juli 2016 zugestellt. Die Ehezeit beginnt am 1. August 2013 und endet am 30. Juni 2016. Da die Ehe weniger als drei Jahre dauerte, führt das Gericht nicht automatisch einen Versorgungsausgleich durch.
Beispiel 2: Die Eheleute haben am 12. April 2008 geheiratet. Seit dem 31. August 2010 leben sie getrennt. Erst im August 2016 wird die Scheidung eingereicht. In diesem Fall ist die Drei-Jahres-Grenze nicht eingehalten. Zwar haben die Eheleute weniger als drei Jahre zusammengelebt. Es kommt aber auf die Zeit bis zum Scheidungsantrag an, und der wurde in diesem Beispiel erst nach rund acht Jahren Ehe gestellt.
TIPP
Ansprüche auch bei kurzer Ehe prüfen
Auch wenn Ihre Ehe keine drei Jahre gehalten hat, sollten Sie selbst prüfen oder von einem Experten prüfen lassen, ob sich für Sie nicht doch ein Antrag auf Versorgungsausgleich lohnt. Das kann sein, falls der Ex-Partner in der Ehezeit viel verdient und dadurch Versorgungsanwartschaften von Wert gebildet hat.
So läuft der Versorgungsausgleich in der Praxis
Der Versorgungsausgleich wird bei einer Scheidung immer automatisch mitgeregelt. Anders als beim Zugewinnausgleich brauchen Sie also nicht extra einen Antrag zu stellen.
Fragebogen an Eheleute - Das Gericht schickt beiden Eheleuten Fragebögen zu, in denen sie angeben müssen, welche Versicherungen und Anwartschaften bestehen, welche Versicherungsnummer vergeben wurde und ob sie eine Vereinbarung über den Versorgungsausgleich geschlossen haben.
Diese Formulare müssen die Eheleute dem Gericht zurückschicken. Reicht einer der Ehegatten die Formulare nicht ein und verzögert dadurch den Scheidungsprozess, kann das Gericht ein Zwangsgeld verhängen.
Auskünfte der Versorgungsträger - Mit den Angaben der Eheleute geht das Familiengericht auf alle Versorgungsträger zu und lässt sich die Höhe der jeweiligen Rentenanwartschaften mitteilen. Auch das kann dauern, etwa weil Versicherungszeiten fehlen.
Prüfung durch Eheleute - Das Gericht leitet die Mitteilungen der Versorgungsträger den Eheleuten weiter, damit diese sie prüfen und Stellung nehmen können. Das sollten Sie ernst nehmen, es kann nämlich bei den Versorgungsträgern zu Fehlern kommen, die Sie bares Geld kosten. Deshalb sollten Sie die Angaben am besten von einem Rentenberater oder einem Versicherungsmathematiker überprüfen lassen. Die Anwaltskanzlei Hauß & Nießalla bietet einen kostenlosen Rechner an, mit dem Sie die Berechnung überprüfen können.
Verzögert sich die Scheidung wegen fehlender Auskünfte und läuft das Verfahren bereits seit drei Monaten, kann das Gericht den Versorgungsausgleich abtrennen und die Scheidung vorab durchführen (§ 140 FamFG). Der Versorgungsausgleich wird dann nach der Scheidung nachgeholt, sobald alle Rentenberechnungen vorliegen.
Ausgleich - Im Scheidungstermin wird dann der Versorgungsausgleich zugesprochen.
Grundsatz: Teilen der Anwartschaften beim jeweiligen Träger – interne Teilung
Bei den Ausgleichsbeträgen handelt es sich nicht um Beträge, die die Ehegatten selbst an den anderen Ehegatten auszahlen müssten. Das Familiengericht überträgt vielmehr der ausgleichsberechtigten Person ein eigenständiges, wertgleiches Anrecht mit vergleichbarer Wertentwicklung und Sicherung sowie mit vergleichbarem Risikoschutz – und zwar jeweils die Hälfte der Anwartschaft des Ex-Partners (§§ 10-13 VersAusglG). Das macht sich allerdings erst im Rentenalter bemerkbar. Intern bedeutet dabei, dass die geteilten Anwartschaften bei demselben Versorgungsträger weitergeführt werden. Wer also selbst schon eine Rentenanwartschaft etwa bei der gesetzlichen Rentenversicherung hat, der bekommt eine Aufstockung seiner Anwartschaft um die Hälfte der erworbenen Ansprüche des Ex-Partners. Anderenfalls wird für ihn ein neues Konto beispielsweise bei der gesetzlichen Rentenversicherung eingerichtet, auch wenn er dort selbst bisher überhaupt keine Anwartschaft hatte. Da das Anrecht wertgleich sein muss, muss etwa der Versicherer den für den alten Vertrag geltenden Garantiezins zugrunde legen.
Kosten bei interner Teilung - Die Teilung der Anwartschaften kostet Geld. Es muss meist ein neues Versicherungskonto eingerichtet und dann auch geführt werden. Das darf der Versorgungsträger in Rechnung stellen (§ 13 VersAusglG). Dabei trägt jeder Ehegatte auch die Hälfte der Kosten. Meist zieht der Versorgungsträger die eine Hälfte direkt vom Ausgleichswert ab, die andere Hälfte verrechnet er mit dem verbliebenen Anrecht.
In der Praxis berechnen die Versorgungsträger meist 2 bis 3 Prozent vom Wert des zu teilenden Anrechts. Bei besonders werthaltigen Anrechten können sich die Kosten auf mehrere Tausend Euro belaufen.
TIPP
Auf Teilungskosten achten
Fallen für die Teilung eines Anrechts hohe Kosten an, sollten die betroffenen Ehegatten prüfen, ob sie nicht besser die einzelnen Anrechte durch eine gesonderte Vereinbarung verrechnen wollen, um sich die Teilungskosten zu sparen.
Ermessen bei Bagatellgrenze - Geringe Anwartschaften muss das Familinegericht nicht ausgleichen. Die Mindestgrenze für den Ausgleich liegt 2016 bei einem Kapitalwert von 3.486 Euro in den westlichen und bei 3.024 Euro in den östlichen Bundesländern. Das entspricht einer monatlichen Rente von 29,05 Euro/West und 25,20 Euro/Ost (§ 18 Abs. 3 VersAusglG in Verbindung mit § 18 SGB IV). Es liegt allerdings im Ermessen der Gerichte, die die Belange der Mehrarbeit auf Seiten der Versorgungsträger gegen das Interesse des ausgleichsberechtigten Ehegatten an der Erlangung auch geringfügiger Anrechte abwägen müssen. Oft führte die Abwägung dazu, dass die Gerichte auch geringe Anwartschaften ausgeglichen haben.
Der Bundesgerichtshof hat sich mit der Bagatellgrenze deshalb in verschiedenen Beschlüssen beschäftigt (BGH, Beschluss vom 12. Oktober 2016, Az. XII ZB 372/16; Beschluss vom 28. September 2016, Az. XII ZB 325/16). Danach kann ein Ausgleich unterbleiben, wenn
der Wert des Anrechts bedeutungslos ist,
er erkennbar unter den entstehenden Verwaltungskosten liegt,
der Ausgleichsberechtigte nicht auf den Bagatellbetrag angewiesen ist und
die Teilung sich als insgesamt unwirtschaftlich darstellt.
Ausnahme: Die Versorger überweisen den Ausgleich – externe Teilung
Es gibt auch Anwartschaften, die das Familiengericht ausnahmsweise extern teilt. Das bedeutet, dass der ausgleichsberechtigte Partner keine eigene Anwartschaft bei demselben Versorgungsträger bekommt. Stattdessen überweist der bisherige Versorgungsträger den Ausgleichsbetrag an einen anderen Versorgungsträger (§§ 14 ff. VersAusglG). Das ist nur möglich, sofern eine besondere Vereinbarung vorliegt oder der Versorgungsträger das wünscht und eine Mindesthöhe nicht überschritten wird. Im Versorgungsausgleich liegt die Obergrenze für dieses einseitige Abfindungsrecht bei 58,10 Euro monatliche Rente und bei 6.972 Euro Kapitalwert (Stand: 2016).
Bei Betriebsrenten aus Direktzusagen oder Unterstützungskassen betragen die Obergrenze für den Ausgleichswert 74.400 Euro im Westen und 64.800 Euro im Osten (Stand: 2016). Werden diese Grenzen überschritten, muss intern geteilt werden.
Kommt es zur externen Teilung, kann der Ausgleichsberechtigte wählen, wohin das Geld fließen soll, zum Beispiel in die gesetzliche Rentenversicherung, eine Pensionskasse oder eine Direktversicherung.
Ohne Wahl wird die gesetzliche Rentenversicherung automatisch zum Zielversorgungsträger oder bei externer Teilung betrieblicher Anrechte die Versorgungsausgleichskasse (§ 15 Abs. 5 S. 2 VersAusglG). Dabei handelt es sich um eine Pensionskasse, die zur Erfüllung des gesetzlichen Auftrags von 38 Lebensversicherern gegründet wurde.
Beamtenversorgungen werden in aller Regel ebenfalls extern geteilt. Die Anwartschaft wird in Entgeltpunkten umgerechnet und auf die gesetzliche Rentenversicherung übertragen (§ 16 VersAusglG).
Tidgraph also supports a vertical layout through the `layout` parameter. The value can be `S` for south or `E` for east. The following
`<$tidgraph start="Virtues" layout="`<code><$text text={{!!layout}}/></code>`"/>`
produces this graph:
<$tidgraph start="Beispiele" layout={{!!layout}} maxdepth="1"/>
<$button set=!!layout setTo="S">South</$button>
<$button set=!!layout setTo="E">East</$button>
Die Prüfungsreihenfolge der Anspruchsgrundlagen beginnt mit der Prüfung der vertraglichen Ansprüche. Dies sind Ansprüche, die anlässlich eines Vertragsschluss in Betracht kommen. Hier ist zu unterscheiden zwischen Primär-, Sekundär- und Tertiäransprüchen.
''I. Primäransprüche''
Primäransprüche sind auf Erfüllung gerichtet. Beispiel: Wenn A dem B ein Auto verkauft, hat B einen Anspruch auf Übereignung des Fahrzeugs nach § 433 I BGB und A hat einen Anspruch auf Zahlung des Kaufpreises gemäß § 433 II BGB.
''
II. Sekundäransprüche''
Sekundäransprüche kommen bei Leistungsstörungen in Betracht, etwa Unmöglichkeit oder Verzug. Beispiel1: A verkauft dem B ein gebrauchtes Fahrzeug und nach Vertragsschluss, aber noch vor der Übereignung, erleidet das Fahrzeug aufgrund eines Unfalls einen Totalschaden. Die Übereignung des Fahrzeugs ist damit unmöglich geworden, der Primäranspruch erlischt. Es besteht jedoch ein Anspruch auf Schadensersatz statt der Leistung gemäß §§ 280, I, III, 283 BGB, wenn beispielsweise das Auto für einen höheren Preis hätte weiterverkauft werden können. Beispiel2: Wie oben, nur dass als Lieferzeitpunkt der 01.07. bestimmt worden ist und das Fahrzeug an diesem Tag nicht geliefert wird, sodass ein Ersatzfahrzeug angemietet werden muss. Hier entsteht neben dem Primäranspruch auf Übereignung des Wagen aufgrund des Verzuges ein Sekundäranspruch gemäß §§ 280 I, II, 286 BGB.
''
II. Tertiäransprüche''
Tertiäransprüche sind Ansprüche, die auf Surrogate gerichtet sind, vgl. beispielsweise § 285 BGB. Beispiel3: Wie oben. Aufgrund des Totalschadens ist der Primäranspruch untergegangen. Jedoch hat A möglicherweise einen Anspruch auf Schadensersatz gegen den Unfallverursacher. Nun kann B unter bestimmten Voraussetzungen verlangen, dass A ihm diesen Anspruch als Surrogat für die unmöglich gewordene Leistung abtritt. Dies ist insbesondere dann interessant, wenn der Unfallverursacher gut versichert war und B den niedrigeren Verkaufspreis zahlt, um den höheren Schadensersatzanspruch gegen die Versicherung zu erhalten.
<$list filter="[is[current]tag[person]]">
|!Street |{{!!street}} |
|!Town |{{!!town}} |
|!Phone |{{!!phone}} |
</$list>
<$list filter="[is[current]tag[right]]">
|!GESETZ |<$view field="gesetz"/> |
|!AGL |<$view field="agl"/> |
|!ART |<$view field="anspruchsart"/> |
|!Abgrenzung |<$view field="abgrenzung"/> |
|!§ |<$view field="artikel"/> |
|!Rechtsgebiet |<$view field="rechtsgebiet"/> |
|!LINK |<$view field="list"/> |
</$list>
<$list filter="[all[current]tag[Field]backlinks[]limit[1]]" variable="dummy">
!!! Backlinks
<<list-links "[all[current]backlinks[]]">>
</$list>
Neues vom BGH: fiktive Abrechnung bei Vollkaskoversicherung
Datum
22.12.2015
Autor
Frank Brüne
Art des Beitrags
Rechtstipp
teilen
Trägt ein KFZ einen Schaden davon, für den kein anderer Verkehrsteilnehmer haftbar gemacht werden kann, tritt – sofern vorhanden – die Teil- oder Vollkaskoversicherung ein. Diese ersetzt in der Regel die Kosten einer durchgeführten Reparatur. Es besteht allerdings auch die Möglichkeit, den Schaden fiktiv abzurechnen. Hierzu ist eine aktuelle Entscheidung des Bundesgerichtshofes (BGH) in Karlsruhe ergangen.
In dieser Entscheidung hat der BGH festgelegt, dass der Versicherungsnehmer bei einer Vollkaskoversicherung im Falle eines Schadens am eigenen Fahrzeug im Einzelfall die Preise einer markengebundenen Werkstatt bei fiktiver Abrechnung ansetzen kann (BGH Urteil vom 11.11.2015, Az.: IV ZR 426/14).
Was ist die „fiktive Abrechnung“?
Grundsätzlich darf ein Fahrzeughalter Schäden von seiner Kaskoversicherung (Vollkasko- und Teilkaskoversicherung, und damit nicht nur selbstverschuldete Unfälle, sondern beispielsweise auch Wildunfälle, u. a.) auch dann regulieren lassen, wenn er diese tatsächlich nicht reparieren lässt ("fiktive Abrechnung"). Hierbei erhält er von der Versicherung dann den Geldbetrag, den er für die Reparatur des Fahrzeuges hätte aufwenden müssen. Abgezogen wird lediglich die vereinbarte Selbstbeteiligung.
Unklar war allerdings bisher, auf Basis welcher Kosten die Versicherung den Schaden regulieren muss. Der Geschädigte hat bei der Ermittlung der Reparaturkosten nämlich die Möglichkeit, die Preise einer „teureren“ Markenwerkstatt oder aber die einer preiswerteren nicht markengebundenen Werkstatt zu Grunde zu legen. Die Interessen von Halter und Versicherer gehen hierbei natürlich weit auseinander: Während Fahrzeughalter im Falle eines Unfalls gerne das Geld für die fiktive Reparatur einer teuren Markenwerkstatt hätten, wollen Versicherer regelmäßig nur den Preis für die günstige Variante zahlen.
Neue Rechtsprechung für die Vollkaskoversicherung!
War bisher nur für den Bereich der Haftpflichtversicherung bei fiktiver Abrechnung geregelt, dass der Fahrzeughalter sich für die Abrechnung einer Markenwerkstatt entscheiden kann, wenn sein Fahrzeug nicht älter als drei Jahre ist oder das KFZ bis dahin ausschließlich in einer Markenwerkstatt repariert und gewartet wurde, so gab es keine Entscheidungen, wie bei einer Regulierung durch die Kaskoversicherung zu verfahren ist.
Dies hat sich nun geändert: Nach der aktuellen Entscheidung braucht der Geschädigte sich unter den gleichen Voraussetzungen wie bei der Haftpflichtversicherung auch im Falle einer Regulierung durch die Kaskoversicherung nicht immer auf eine günstigere Referenzwerkstatt verweisen zu lassen. Die Richter des BGH entschieden zudem, dass eine Abrechnung auf Basis der Kosten einer Markenwerkstatt auch dann zulässig sei, wenn der Schaden nur in einer Markenwerkstatt vollständig und fachgerecht repariert werden kann!
Was Fahrzeughalter bei einem Fahrzeugschaden beachten sollten
Aus der Entscheidung ergibt sich für Fahrzeughalter, dass es bei einer Kaskoversicherung im Falle eines Unfalls darauf ankommt, zu beweisen, dass das Fahrzeug entweder jünger als drei Jahre ist oder auch bisher nur markengebunden gewartet und repariert wurde. Hierzu sollten natürlich sämtliche Belege der Markenwerkstätte sorgfältig aufbewahrt werden.
Rechtordnung als Informationssystem = syntaktische (und andere) Zeichen von bestimmten Autoren und über bestimmte Kommunikationskanäle (BGBl, RIS, CELEX, jurix) [Schweighofer 1995/1999]
Formale Sprachen zur Beschreibung des Wissensinhalts bzw der Beziehungen (Links) zwischen Normen und Sachverhalten existieren seit langem: Verweisungen, Thesauri, Klassifikationen
Beispiele des österreichischen und europäischen Rechts
Dominanz der Verweisungen: Höchstgerichte (Normenliste des VwGH (Paschinger)), Hohenecker Index (nunmehr: Jahnel & Team), Neuner-Zechmeister-Index, CELEX Verweisungen, Verweisungen in jurix
Thesauri: Rida, Karlsruher Bibliographie, Bibliotheksthesaurus, Eurovoc, Schlagwortliste des EuGH, Schlagwortlisten der Höchstgerichte, juris Thesauri
Klassifikationen: Index des Bundesrechts, Fundstellennachweis des Gemeinschaftsrechts
Bewertung dieser Vorarbeiten
Breite: sehr umfassend
Tiefe: außer Verweisungen oft unzureichend
Zusammenhänge: hierarchische Beziehungen, wenig ausgebaut
Attribute: sehr gering
Menschengerecht, unterstützen Juristen
Nicht besonders computergerecht, aber IT unterstützt wesentlich Nutzung für den Menschen
zB kombinierte Verweisungssuche (mehrere Rechtsvorschriften mit Suchbegriff)
<$checkbox tag=<<actual>> > <$link><<currentTiddler>> </$link>
</$checkbox>
<span style="border:1px solid silver; padding-right:2em; display:block;">
*This demos ''three different methods'' for displaying the paragraph tiddlers (see [[Use|Use + Install]] for info)
*{{ToggleTiddlerTitles}}
</span>
...so, this is tiddler [[VorausSetzungen]].
[[VorausSetzungen]] has a field ''paragraphs: {{!!paragraphs}}''
<$set name="listfilter"
value="""[tag[Voraussetzungen]!is[system]sort[title]]""">
<ul class="te-list">
<$list filter=<<listfilter>>>
<$set name="tidTitle" value={{!!title}}>
<li class="todo-item te-flex-item">
<span class="te-flex-item te-flex-half-full">
<span class="te-flex-item te-flex-content te-flex-left">
<$link to={{!!title}}><$view field="title"/></$link>
</span>
</span>
<span class="te-flex-item te-flex-half-full">
<span class="te-flex-item te-flex-content te-flex-right">
<<teBtnEditShowModified>>
<$wikify name="cl" text=<<telang close>> >
<$wikify name="tt" text=<<telang Details>> >
<$macrocall $name="listrevealButton" title=<<tidTitle>> tooltip=<<tt>> close=<<cl>>/>
</$wikify>
</$wikify>
</span>
</span>
<$wikify name="tpl" text=<<telang date-created-tmpl>> >
<$macrocall $name="listrevealContent" title=<<tidTitle>> datetime=<<tpl>>/>
</$wikify>
</li>
</$set>
</$list>
</ul>
</$set>
<<tabs "[[V-1]] [[V-2]] [[V-3]]" "[[V1]]" "$:/state/tab3" "tc-vertical">>
{{||$:/plugins/btheado/ftlist/main}}
Bundesgerichtshof
Urt. v. 05.10.1988, Az.: IVb ZR 52/87
Anspruch auf hälftige Beteiligung an bei Zustellung des Scheidungsantrags vorhandenen Bausparguthaben; Voraussetzungen eines gesellschaftsrechtlichen Auseinandersetzungsanspruchs; Ausdrückliches oder stillschweigendes Zustandekommen eines Gesellschaftsvertrags hinsichtlich des Abschlusses von Bausparverträgen; Begründung einer Ehegatteninnengesellschaft durch schlüssiges Verhalten; Unentgeltliche Zuwendungen in Abgrenzung zu unbenannten, ehebedingten Zuwendungen unter Ehegatten ; Verdrängung des Gesamtschuldnerausgleichs zwischen Ehegatten durch die Vorschriften über den Zugewinnausgleich; Gesamtschuldnerische Haftung auf Rückzahlung eines Darlehens
Bibliografie
Gericht: BGH
Entscheidungsform: Urteil
Datum: 05.10.1988
Referenz: JurionRS 1988, 13150
Aktenzeichen: IVb ZR 52/87
ECLI: [keine Angabe]
Verfahrensgang:
vorgehend:
OLG Düsseldorf - 19.03.1987
Rechtsgrundlagen:
§ 242 BGB
§ 421 BGB
§ 426 Abs. 1 S. 1 BGB
§ 427 BGB
§ 667 BGB
§ 1372 BGB
Fundstellen:
FamRZ 1989, 147
FamRZ 1989, 174
NJW-RR 1989, 66-68 (Volltext mit red. LS)
BGH, 05.10.1988 - IVb ZR 52/87
Der IVb - Zivilsenat des Bundesgerichtshofs hat
auf die mündliche Verhandlung vom 5. Oktober 1988
durch
den Vorsitzenden Richter Lohmann und
die Richter Portmann, Dr. Krohn, Dr. Zysk und Nonnenkamp
für Recht erkannt:
Tenor:
Auf die Revision des Klägers wird das Urteil des 6. Zivilsenats des Oberlandesgerichts Düsseldorf vom 19. März 1987 im Kostenpunkt und insoweit aufgehoben, als die Klage auf Zahlung von 25.504,95 DM nebst Zinsen abgewiesen worden ist.
Die weitergehende Revision wird zurückgewiesen.
Im Umfang der Aufhebung wird der Rechtsstreit zur neuen Verhandlung und Entscheidung, auch über die Kosten des Revisionsverfahrens, an das Berufungsgericht zurückverwiesen.
Tatbestand
1
Der Kläger ist Schreinermeister. Die Beklagte ist seit September 1980 Lehrerin; zuvor stand sie bis April 1980 als Referendarin im Vorbereitungsdienst. Die Parteien schlossen im November 1976 miteinander die Ehe. Sie lebten im gesetzlichen Güterstand der Zugewinngemeinschaft. Am 12. Juli 1980 kam es zur Trennung. Auf den am 20. August 1981 zugestellten Scheidungsantrag wurde die Ehe geschieden; das Scheidungsurteil ist seit dem 29. September 1982 rechtskräftig.
2
Mit der vorliegenden, im Jahre 1983 bei dem Landgericht erhobenen Klage hat der Kläger schuldrechtliche Ansprüche gegen die Beklagte gerichtet, die er aus vier wirtschaftlichen Vorgängen - im folgenden a) bis d) - abgeleitet hat:
a)
Beide Parteien leisteten während der Ehe Einzahlungen auf drei Bausparverträge der Beklagten. Zur Zeit der Zustellung des Scheidungsantrags betrugen die Bausparguthaben insgesamt 34.612,36 DM.
b)
Zur Auffüllung eines dieser Bausparverträge nahmen beide Parteien im Jahre 1977 bei dem Vater der Beklagten ein Darlehen von 19.000 DM auf. Darauf zahlten sie bis zur Trennung gemeinsam 4.000 DM zurück und erbrachten Zinsleistungen. Das Restdarlehen, das einschließlich Zinsen noch 15.689,79 DM betrug, tilgte der Kläger durch zwei Zahlungen am 31. Oktober und 16. Dezember 1980.
c)
Im Mai 1980 überwies der Kläger auf das Konto der Beklagten 16.000 DM. Der Grund für diese Zahlung ist zwischen den Parteien streitig.
d)
Für das Jahr 1979 erstattete das Finanzamt Steuern in Höhe von 3.214,80 DM auf das Konto der Beklagten, nachdem diese in der gemeinsamen Steuererklärung der Parteien die zunächst angegebene Kontonummer des Klägers durchgestrichen und ihre eigene darübergesetzt hatte.
3
Der Kläger hat geltend gemacht: Von den auf den Namen der Beklagten lautenden Bausparguthaben stehe ihm im Innenverhältnis die Hälfte (17.306,18 DM) zu. Die Bausparverträge seien einverständlich dazu bestimmt gewesen, Kapital zu schaffen, um damit nach Möglichkeit gemeinsam Grundvermögen zu erwerben. Die Darlehensrückzahlung von 15.689,79 DM habe die Beklagte nach § 426 Abs. 1 Satz 1 BGB zur Hälfte mit 7.844,90 DM auszugleichen. Die ihr überwiesenen 16.000 DM müsse sie zurückerstatten, denn diesen Betrag habe er mit ihrem Einverständnis auf einen ihr vermeintlich zustehenden Ausgleichsanspruch nach Scheitern der Ehe in der unerfüllt gebliebenen Erwartung gezahlt, die Beklagte werde ihm die Bausparguthaben insgesamt überlassen. Von der an die Beklagte ausgezahlten Steuerrückerstattung von 3.214,80 DM stehe ihm ein Anteil von 1.660,05 DM zu. Das Finanzamt habe die Erstattung nur deshalb dem Girokonto der Beklagten gutgebracht, weil diese ohne sein Wissen anstelle seines in der gemeinsamen Steuererklärung angegebenen Kontos ihr eigenes eingesetzt habe.
4
Am 22. Oktober 1985 hat der Kläger einen Mahnbescheid über eine Zugewinnausgleichsforderung von 16.500 DM gegen die Beklagte erwirkt (16 B 4551/85 AG Velbert). Dagegen hat die Beklagte Widerspruch erhoben. Weiter ist jenes Verfahren noch nicht gediehen.
5
Im ersten Rechtszug des vorliegenden Rechtsstreits hat der Kläger erklärt, angesichts zu erwartender Zahlungsschwierigkeiten der Beklagten sei er damit einverstanden, daß sie ihm zur Deckung seiner über die Hälfte der Bausparguthaben hinausgehenden Auseinandersetzungsansprüche die gesamten Auszahlungsansprüche gegen die Bausparkasse abtrete; dann verbleibe ihm ein restlicher Zahlungsanspruch von 8.198,77 DM. Demgemäß hat er in erster Linie beantragt, die Beklagte zur Abtretung der ihr gegen die Bausparkasse zustehenden Ansprüche auf Auszahlung der Bausparguthaben von insgesamt 34.612,36 DM und zur Zahlung restlicher 8.198,77 DM zu verurteilen. Hilfsweise hat er ihre Verurteilung zur Abtretung der Hälfte der Auszahlungsansprüche (17.306,18 DM) und zur Zahlung von 25.504,95 DM begehrt.
6
Die Beklagte ist dem Klagebegehren entgegengetreten. Sie hat vorgetragen, zwischen den Parteien habe stets Einigkeit darüber bestanden, daß ihre Bausparverträge ihr allein zustehen sollten. Einen Anspruch auf hälftigen Ausgleich wegen der Tilgung des Restdarlehens habe der Kläger nicht; die Tilgung habe nicht in ihrem Interesse gelegen, weil ihr Vater wegen ihrer schlechten Vermögenslage die Rückzahlung des Darlehens nicht verlangt habe. Die an sie gezahlten 16.000 DM könne der Kläger nicht zurückfordern, weil die Zahlung - entgegen seiner Behauptung - dem Ausgleich ihres überzogenen Girokontos gedient habe, von dem Anschaffungen und Renovierungskosten für die eheliche Wohnung sowie auch Kosten der gemeinsamen Lebensführung bestritten worden seien. Die Steuererstattung sei ihr im Einvernehmen mit dem Kläger zugeflossen; die Angabe des Girokontos in der Steuererklärung habe sie mit seiner Zustimmung geändert.
7
Das Landgericht hat nach Beweisaufnahme dem Hilfsantrag des Klägers entsprochen und die Klage im übrigen abgewiesen. Mit der Berufung hat die Beklagte weiterhin die vollständige Abweisung der Klage erstrebt. Sie hat vorgetragen, sie habe sich die Bausparguthaben bereits auszahlen lassen. Daraufhin hat der Kläger beantragt, ihre Berufung mit der Maßgabe zurückzuweisen, daß die Beklagte nunmehr in Höhe der im Urteilsausspruch des Landgerichts bezeichneten Bausparguthaben zur Zahlung verurteilt werde. Nachdem er zuvor im ersten und auch noch im zweiten Rechtszug wiederholt erklärt hatte, er mache in diesem Rechtsstreit nicht den Anspruch auf Zugewinnausgleich geltend, hat der Kläger in der Berufungsverhandlung erklärt, er stütze die Klageforderung zugleich auf die Vorschriften über den Zugewinnausgleich. Die Klageforderung bleibe in ihrem bisherigen Umfang insoweit als Teilanspruch des Zugewinnausgleichs aufrechterhalten. Er hat hilfsweise die Verweisung an das Familiengericht beantragt. Die Beklagte hat der Klageänderung widersprochen und die funktionelle Zuständigkeit des Senats für die geänderte Klage einschließlich des Verweisungsantrages gerügt. Außerdem hat sie die Einreden der doppelten Rechtshängigkeit und der Verjährung erhoben.
8
Das Berufungsgericht hat das Urteil des Landgerichts abgeändert und die Klage abgewiesen. Dagegen richtet sich die Revision des Klägers, die der Senat angenommen hat.
Entscheidungsgründe
9
Die Revision hat einen Teilerfolg.
10
I.
1.
Zu dem Anspruch des Klägers auf hälftige Beteiligung an den bei Zustellung des Scheidungsantrags vorhandenen Bausparguthaben der Beklagten hat das Berufungsgericht ausgeführt, ein gesellschaftsrechtlicher Auseinandersetzungsanspruch bestehe nicht, weil die Parteien hinsichtlich der Bausparverträge weder ausdrücklich noch stillschweigend einen Gesellschaftsvertrag abgeschlossen hätten.
11
Diese Beurteilung läßt einen Rechtsfehler nicht erkennen. Mangels eines ausdrücklich geschlossenen Gesellschaftsvertrages käme nur die Begründung einer Ehegatteninnengesellschaft durch schlüssiges Verhalten (vgl.Senatsurteil vom 8. April 1987 - IVb ZR 43/86 - FamRZ 1987, 907) in Betracht. Die insoweit zu stellenden Anforderungen sind jedoch, wie das Berufungsgericht zutreffend ausgeführt hat, nicht erfüllt. Nach der ständigen Rechtsprechung des Bundesgerichtshofs schließen es zwar weder die Natur der Ehegemeinschaft noch die Vorschriften über den gesetzlichen Güterstand aus, daß Ehegatten zwischen sich ein Gesellschaftsverhältnis begründen. Ein solches ist angenommen worden, wenn Eheleute abredegemäß durch beiderseitige Leistungen einen über den typischen Rahmen der ehelichen Lebensgemeinschaft hinausgehenden Zweck verfolgten, indem sie etwa durch Einsatz von Vermögenswerten und Arbeitsleistungen gemeinsam ein Unternehmen aufbauten oder gemeinsam eine berufliche oder gewerbliche Tätigkeit ausübten. Das Bestreben, die eheliche Lebensgemeinschaft zu verwirklichen und Voraussetzungen dafür zu schaffen, ist als solches jedoch kein eigenständiger Zweck, der die Grundlage einer zwischen den Ehegatten bestehenden Gesellschaft bilden könnte (BGH Urteil vom 5. Juli 1974 - IV ZR 203/72 - NJW 1974, 2045). So liegt es regelmäßig, wenn die Ehegatten durch beiderseitige Leistungen zum Erwerb oder Ausbau eines Familienheims beitragen (s. BGHZ 84, 361, 366 f.) [BGH 08.07.1982 - IX ZR 99/80]. Sie handeln dann in dem Bestreben, die eheliche Lebensgemeinschaft in der von ihnen gewünschten Weise zu verwirklichen (BGH Urteil vom 29. Mai 1974 - IV ZR 210/72 - NJW 1974, 1554, 1555). Diesem Zweck diente nach der Feststellung des Berufungsgerichts das Bausparen der Parteien. Diese Feststellung wird nicht angegriffen. Sie entspricht auch dem Vorbringen des Klägers, die Parteien hätten zwar noch nicht zu Beginn ihrer Ehe, wohl aber in deren späterem Verlauf die Vorstellung gehabt, mit den Bausparmitteln nach Möglichkeit gemeinsam Grundvermögen zu erwerben. Davon, daß die Einzahlungen erfolgten, um ein Familienwohnheim zu schaffen, geht daher auch die Revision zu Recht aus. Ein darüber hinausgehender gemeinschaftlicher Zweck des Bausparens, der die Annahme einer Ehegatteninnengesellschaft zu tragen vermöchte, ist dem Vorbringen des Klägers nicht zu entnehmen.
12
2.
Das Berufungsgericht hat - nach rechtlich unbedenklicher und auch von der Revision nicht angegriffener Ablehnung von Ansprüchen auf Aufteilung der Bausparguthaben nach Gemeinschaftsregeln - die Frage geprüft, ob zwischen den Parteien ein Auftragsverhältnis anzunehmen sei, das die Beklagte verpflichte, den Kläger so zu stellen, als sei er die Bausparverträge gemeinschaftlich mit ihr eingegangen. Es hat das letztlich mit der Begründung verneint, diese vom Kläger ins Spiel gebrachte rechtliche Konstruktion laufe wiederum auf eine Innengesellschaft hinaus, die nicht vorliege.
13
Auch das hält der rechtlichen Überprüfung stand. Weder die Feststellungen des Berufungsgerichts noch der Vortrag des Klägers ergeben ein Auftragsverhältnis. Die Revision meint demgegenüber, mit seinen Einzahlungen auf die Bausparkonten habe der Kläger der Beklagten die Verwaltungsbefugnis über einen Teil seines Vermögens übertragen. Sie will den Anspruch auf Herausgabe dieses Vermögensteils auf § 667 BGB stützen. Dazu beruft sie sich auf ein Urteil des Bundesgerichtshofs vom 13. November 1985 (IVa ZR 42/84- NJW 1986, 1492) . Damit kann die Revision nicht durchdringen. Der genannten Entscheidung lag ein Fall zugrunde, in dem ein Ehegatte den anderen ausdrücklich mit der Verwaltung seines Vermögens beauftragt und entsprechend bevollmächtigt hatte. Ein vergleichbarer Sachverhalt ist hier weder festgestellt noch vorgetragen.
14
3.
Das Berufungsgericht hat es abgelehnt, den mit der Klage verfolgten Anspruch auf hälftige Beteiligung an den Bausparguthaben aus dem Rechtsinstitut des Wegfalls der Geschäftsgrundlage (§ 242 BGB) herzuleiten. Auch das ist - jedenfalls im Ergebnis - aus Rechtsgründen nicht zu beanstanden.
15
Allerdings bestehen gegen den Ausgangspunkt der Erwägungen des Berufungsgerichts insoweit Bedenken, als es annimmt, der Kläger habe der Beklagten mit seinen Einzahlungen auf ihre Bausparverträge "unentgeltliche" Zuwendungen gemacht. Im Gegensatz dazu stellt das Berufungsgericht selbst fest, die Einzahlungen, die dem möglichen Erwerb von Grundeigentum hätten dienen sollen, seien mit Rücksicht auf die eheliche Gemeinschaft erfolgt. Damit handelt es sich nicht um unentgeltliche Zuwendungen, also Schenkungen, sondern um sogenannte unbenannte (ehebedingte) Zuwendungen unter Ehegatten (vgl. BGHZ 82, 227, 230 [BGH 26.11.1981 - IX ZR 91/80]; 84, 361, 364 f. [BGH 08.07.1982 - IX ZR 99/80];Senatsurteil vom 27. Januar 1988 - IVb ZR 82/86 - BGHR BGB § 242 Geschäftsgrundlage 9 = FamRZ 1988, 482, 485). Derartige unbenannte Zuwendungen können bei Scheitern der Ehe nach den Regeln über den Wegfall der Geschäftsgrundlage zu Ausgleichsansprüchen führen, wenn die Beibehaltung der Vermögensverhältnisse, die durch die Zuwendung eines Ehegatten an den anderen herbeigeführt worden sind, dem benachteiligten Ehegatten nicht zuzumuten ist (BGHZ 84, 361, 365) [BGH 08.07.1982 - IX ZR 99/80]. Das gilt indessen in erster Linie für Fälle der Gütertrennung. Zwar ist ein solcher Ausgleichsanspruch auch beim Güterstand der Zugewinngemeinschaft nicht schlechthin ausgeschlossen. Seine Annahme ist dort aber nur unter besonderen Umständen gerechtfertigt (vgl. dazu BGHZ 65, 320, 324 [BGH 03.12.1975 - IV ZR 110/74]; 68, 299, 302 f. [BGH 27.04.1977 - IV ZR 143/76]; 84, 361, 365) [BGH 08.07.1982 - IX ZR 99/80]. Für die Anwendung der Regeln über den Wegfall der Geschäftsgrundlage ist nach Scheidung der Ehe insoweit kein Raum, als sie durch die Vorschriften über den Ausgleich des Zugewinns verdrängt werden. Die gesetzliche Regelung des Zugewinnausgleichs, die insbesondere eine gleichmäßige Beteiligung der Frau an dem in der Ehe erzielten Vermögenserwerb sicherstellen und bei der Vermögensauseinandersetzung den Streit darüber ausschließen soll, ob und in welchem Maße der eine Ehegatte an dem Vermögenserwerb des anderen wirtschaftlich beteiligt war (BGHZ 65, 320, 323) [BGH 03.12.1975 - IV ZR 110/74], läßt die ungeschriebenen, aus § 242 BGB abgeleiteten Grundsätze über den Wegfall der Geschäftsgrundlage nur dort eingreifen, wo ausnahmsweise der güterrechtliche Ausgleich zu keiner angemessenen Lösung führt (BGHZ 82, 227, 233, 235 f. [BGH 26.11.1981 - IX ZR 91/80]; s. dazu auch Johannsen/Henrich/Jaeger Eherecht BGB § 1372 Rdn. 8 und 9). Derartiges ist nach Art und Umfang des in Rede stehenden Vermögenserwerbs hier nicht ersichtlich.
16
4.
Die Entscheidung hält schließlich den Angriffen der Revision auch insoweit stand, als das Berufungsgericht einen Anspruch aus ungerechtfertigter Bereicherung verneint hat. Haben Ehegatten im gesetzlichen Güterstand der Zugewinngemeinschaft gelebt, so sind Bereicherungsansprüche auf Herausgabe der in der Ehe untereinander gemachten Zuwendungen wegen der Beendigung der Ehe durch Scheidung grundsätzlich nicht gegeben. Der Ausgleich vollzieht sich vielmehr gemäß den güterrechtlichen Vorschriften über den Zugewinnausgleich pauschal nach Maßgabe des beiderseitigen Vermögenszuwachses während der Ehe (BGHZ 65, 320, 323 f. [BGH 03.12.1975 - IV ZR 110/74]; 82, 227, 231 [BGH 26.11.1981 - IX ZR 91/80]; Johannsen/Henrich/Jaeger a.a.O. § 1372 Rdn. 7 m.w.N.).
17
II.
1.
Das angefochtene Urteil hält der rechtlichen Nachprüfung hingegen nicht stand, soweit das Berufungsgericht einen Ausgleichsanspruch nach § 426 Abs. 1 Satz 1 BGB in hälftiger Höhe der Tilgung des Restdarlehens durch den Kläger verneint hat. Weil die Parteien das Darlehen bei dem Vater der Beklagten gemeinschaftlich aufgenommen hatten, schuldeten sie Rückzahlung und Zinsen als Gesamtschuldner (§§ 421, 427 BGB). Im Verhältnis zueinander sind sie daher nach der Regel des § 426 Abs. 1 Satz 1 BGB im Grundsatz zu gleichen Anteilen verpflichtet. Entgegen der Ansicht des Berufungsgerichts wird der Gesamtschuldnerausgleich zwischen Ehegatten durch die Vorschriften über den Zugewinnausgleich nicht verdrängt. Das hat der Senat - nach dem Erlaß des Berufungsurteils - mit Urteil vom 30. September 1987 entschieden (IVb ZR 94/86- BGHR BGB § 426 Ehegatten 1 = FamRZ 1987, 1239, 1240) . Danach hindern die Vorschriften über den Zugewinnausgleich den Ausgleich zwischen gesamtschuldnerisch haftenden Ehegatten ebensowenig, wie sie der Auseinandersetzung einer zwischen ihnen bestehenden Bruchteilsgemeinschaft entgegenstehen. Bei richtiger Handhabung der güterrechtlichen Vorschriften wird das Ergebnis des Zugewinnausgleichs nicht verfälscht.
18
2.
Allerdings gilt der Grundsatz, daß Gesamtschuldner im Verhältnis zueinander zu gleichen Anteilen verpflichtet sind, nach § 426 Abs. 1 Satz 1 BGB nicht, soweit ein anderes bestimmt ist. Eine andere Bestimmung im Sinne dieser Vorschrift kann sich - außer aus dem Gesetz - aus einer ausdrücklich oder stillschweigend geschlossenen Vereinbarung, aus Inhalt und Zweck eines zwischen den Gesamtschuldnern bestehenden Rechtsverhältnisses oder aus der Natur der Sache, mithin aus der besonderen Gestaltung des tatsächlichen Geschehens ergeben (Senatsurteilevom 2. Juli 1986 - IVb ZR 58/85 - BGHR BGB § 426 Abs. 1 Satz 1 Bestimmung, anderweitige 1 und vom 30. September 1987 - FamRZ a.a.O. S. 1240 m.w.N.).
19
Das Berufungsgericht nimmt an, aus der Natur der Sache und der Gestaltung des tatsächlichen Geschehens folge hier eine Bestimmung des Inhalts, daß der Kläger im Verhältnis zur Beklagten die Kreditablösung in Höhe von 15.689,79 DM durch seine Zahlungen vom 31. Oktober und 16. Dezember 1980 allein zu tragen habe "und insoweit allenfalls einen Ausgleich im Rahmen der vom Familiengericht vorzunehmenden Zugewinnausgleichsregelung beanspruchen" könne. Damit und durch die in diesem Zusammenhang weiter angestellte Erwägung, Mehraufwendungen des besser verdienenden Ehegatten bei der Kreditrückzahlung während des Bestehens der ehelichen Gemeinschaft seien Beiträge zur ehelichen Lebensgemeinschaft, die nicht auszugleichen seien, wird jedoch eine von der intern anteiligen Haftung der Parteien abweichende Bestimmung nicht ausreichend begründet. Während des ehelichen Zusammenlebens hat nicht nur der Kläger als Schreinermeister, sondern auch die Beklagte als Referendarin Einkünfte erzielt. Nach der Feststellung des Berufungsgerichts haben auch beide gemeinsam bis zu ihrer Trennung 4.000 DM sowie Zinsen auf das Darlehen gezahlt. Bereits das kann gegen eine intern allein den Kläger treffende Zahlungspflicht sprechen (vgl. insoweitSenatsurteil vom 27. April 1988 - IVb ZR 55/87 - FamRZ 1988, 920, 921). Zudem ist das Darlehen zur Auffüllung eines der Bausparverträge verwendet worden, also zu einer Vermögensanlage, die im Falle der Verwirklichung der seinerzeitigen Vorstellungen von der Schaffung eines Familienwohnheims beiden Parteien zugute kommen sollten, an der aber der Kläger im Falle eines Scheiterns der Ehe vor dem Bau oder Kauf eines Hauses nur mittelbar - im Wege des Zugewinnausgleichs - teilhaben konnte (vgl. oben I.). Schließlich erfolgten die Rückzahlungen, derentwegen der Kläger den Ausgleichsanspruch geltend macht, erst nach der Trennung der Parteien (vgl. zu diesem Gesichtspunkt BGHZ 87, 265, 268) [BGH 17.05.1983 - IX ZR 14/82] und zu einer Zeit, als die Beklagte - seit September 1980 - als Lehrerin verdiente.
20
Daß die von ihm genannten Erwägungen die Annahme einer von der Regelung in § 426 Abs. 1 Satz 1 abweichenden Bestimmung nicht tragen, ist möglicherweise dem Berufungsgericht selbst nicht verborgen geblieben. Denn es lehnt den Ausgleichsanspruch letztlich mit der - rechtsirrigen - Erwägung ab, der Gesamtschuldnerausgleich werde durch die güterrechtlichen Vorschriften verdrängt.
21
Daher kann das angefochtene Urteil, soweit es den geltend gemachten Anspruch auf Gesamtschuldnerausgleich in Höhe von 7.844,90 DM abweist, nicht bestehen bleiben. Der Rechtsstreit muß insoweit zu neuer tatrichterlicher Prüfung an das Berufungsgericht zurückverwiesen werden.
22
III.
Zu Recht bekämpft die Revision das angefochtene Urteil auch insoweit, als ein Anspruch des Klägers auf Rückzahlung der im Mai 1980 an die Beklagte geleisteten 16.000 DM verneint wird. Das Berufungsgericht hat dazu ausgeführt, bei der Überweisung der 16.000 DM auf das Bankkonto der Beklagten handele es sich - wie bei den Einzahlungen auf ihre Bausparverträge - um eine "unentgeltliche" Zuwendung des Klägers an die Beklagte, die vor der Trennung der Parteien erfolgt und nicht rechtsgrundlos gewesen sei, weil sie ihren Rechtsgrund in der noch bestehenden ehelichen Lebensgemeinschaft gehabt habe. Diese Leistung sei ebenfalls im Rahmen des Zugewinnausgleichs zu berücksichtigen.
23
Diese Beurteilung ist nicht richtig, wenn die von der Revision als übergangen gerügte Behauptung des Klägers zutrifft, er habe den Betrag kurz vor der Trennung der Parteien mit dem Einverständnis der Beklagten zur Erfüllung eines ihr vermeintlich zustehenden Ausgleichsanspruchs nach dem Scheitern der Ehe in der Erwartung überwiesen, sie werde ihm die Bausparguthaben insgesamt überlassen. Dann handelt es sich nämlich nicht um eine ehebedingte Zuwendung, sondern um eine Leistung, die absprachegemäß im Rahmen einer außergerichtlichen vermögensrechtlichen Auseinandersetzung erbracht worden und über deren rechtliches Schicksal nach Vertragsrecht zu entscheiden ist. Daß die Darstellung des Klägers, der das Landgericht Glauben geschenkt hatte, nicht zutreffe oder unbewiesen sei, so daß der Kläger die Rückzahlung der 16.000 DM nicht verlangen könne, ist dem Berufungsurteil, wie die Revision zu Recht rügt, nicht zu entnehmen. Es enthält keine dahingehende Feststellung und erst recht keine Begründung für eine solche tatrichterliche Beurteilung. Daher hat das angefochtene Urteil auch zu diesem Anspruch keinen Bestand und ist die Sache auch insoweit zur Nachholung der erforderlichen Feststellungen an das Berufungsgericht zurückzuverweisen.
24
IV.
Die Ablehnung eines Bereicherungsanspruchs in Höhe eines Anteils von 1.660,05 DM an der Steuererstattung hält der rechtlichen Überprüfung ebenfalls nicht stand. Das Berufungsgericht hat gemeint, falls die Steuererstattung vor der Trennung der Parteien erfolgt sei, habe die darin liegende "unentgeltliche Zuwendung" des Klägers an die Beklagte ihren Rechtsgrund in der noch bestehenden ehelichen Lebensgemeinschaft. Wenn der Erstattungsbetrag erst nach der Trennung ausgezahlt worden sei, sei ein Bereicherungsanspruch durch die Vorschriften über den Zugewinnausgleich ausgeschlossen. Wie die Revision zu Recht rügt (§ 286 ZPO), berücksichtigt beides nicht hinreichend den Vortrag des Klägers. Wenn die Beklagte, wie er behauptet hat, in der gemeinsamen Steuererklärung für 1979 ohne sein Wissen seine dort angegebene Kontonummer gestrichen und durch die ihre ersetzt hat, kann von einer Zuwendung nicht die Rede sein. Dann kommt auch insoweit eine Haftung der Beklagten für die Verletzung einer Absprache in Betracht. Auch insoweit ist der Rechtsstreit daher zur weiteren tatrichterlichen Prüfung an das Berufungsgericht zurückzuverweisen.
25
V.
1.
Damit führt die Revision zur Aufhebung und Zurückverweisung hinsichtlich folgender Ansprüche: 7.844,90 DM (Gesamtschuldnerausgleich) + 16.000 DM (Rückforderung Überweisung) + 1.660,05 DM (anteilige Steuererstattung) = 25.504,95 DM nebst geforderter Zinsen. Im übrigen ist das Rechtsmittel unbegründet.
26
2.
Die in der mündlichen Verhandlung vor dem Berufungsgericht für den Kläger abgegebene Erklärung, die Klageforderung werde zugleich auf die Vorschriften über den Zugewinnausgleich gestützt und bleibe in ihrem bisherigen Umfang insoweit als Teilanspruch des Zugewinnausgleichs aufrechterhalten, enthält eine Klageänderung (§ 263 ZPO), der der Kläger widersprochen hat. Das Berufungsgericht hat ihre Sachdienlichkeit nicht geprüft; es hat dem hilfsweise gestellten Antrag auf Verweisung der Sache an das Familiengericht aus anderen Gründen nicht stattgegeben. Die Prüfung der Sachdienlichkeit kann der Senat nachholen (BGH Urteil vom 14. März 1979 - IV ZR 80/78 - MDR 1979, 829; vgl. auch Wieczorek ZPO 2. Aufl. § 264 Anm. CIVa; Zöller/Stephan ZPO 15. Aufl. § 263 Rdn. 15). Die Klageänderung ist nicht sachdienlich, weil für die erst in der mündlichen Verhandlung vor dem Berufungsgericht beantragte Entscheidung über den Ausgleich des Zugewinns noch jede sachliche Vorbereitung fehlt. Von einer Verweisung des Rechtsstreits (vgl.Senatsbeschluß vom 8. Juli 1981 - IVb ARZ 532/81 - FamRZ 1981, 1047 f.) ist daher zu Recht abgesehen worden.
<div>
!! Activity
<$select field="id">
<option value={{!!title}}>{{!!name}}</option>
</$select>
!!Date
<$edit-text field="date" type="date" />
! Description
<$edit-text class="tc-edit-texteditor" field="description" size="40" />
</div>
<$list filter="[has[website]sort[title]]">
Wechselmodell bei der Kinderbetreuung nach Trennung und Scheidung wird immer häufiger gelebte Realität. Und so stellen sich ganz neue Fragen – wie beispielsweise zum Kindergeld.
Wenn beide Elternteile in gleichem Umfang das Kind betreuen, wird der auf die Betreuung entfallende Anteil des Kindergelds bekanntlich halbiert. Was ist aber mit dem Barunterhalts-Anteil des Kindergelds?
Hierzu hat der BGH kürzlich entschieden: Die Teilung des Barunterhalts-Anteils im echten Wechselmodell orientiert sich an den Einkommensverhältnissen. Wenn also ein Elternteil mehr verdient und auch mehr zahlt – z.B. für Musikunterricht oder einen Sportverein –, dann soll er auch in höherem Maße vom Kindergeld profitieren (BGH, Beschl. v. 20.04.2016 – XII ZB 45/15, DRsp Nr. 2016/8924
Materielle Regeln: Personen, Sachen, Handlungen und Unterlassungen
Formelle Regeln: Rechtsanwendung, -durchsetzung, Normenschaffung, Normenpublikation
Prinzipien (Ideen) der Rechtsordnung
Regeln
Typ der Norm
Typologie der Normen nach Hohfeld oder besser nach Herrestad
Links zur Ontologie der realen Welt
Personen, Sachen, Prozesse (Zeit, Abfolge), Sanktion
Beschreibung in Form von Frames (zB van Kralingen)
Art des Anspruchs
Vertragliche Ansprüche
Primäransprüche
z.B. Erfüllung, Nacherfüllung
Sekundäransprüche
z.B. Minderung, Schadensersatz, Rückgabe, Rückzahlung
Vertragsähnliche Ansprüche
z.B. § 122 BGB, § 179 BGB, § 311 II BGB
Dingliche Ansprüche
Primäransprüche
z.B. Herausgabe, Grundbuchberichtigung, Unterlassung
Sekundäransprüche
z.B. Schadensersatz, Nutzungsersatz, Verwendungsersatz
Deliktische Ansprüche
z.B. §§ 823 ff. BGB, § 831 BGB, § 1 ProdHaftG
Bereicherungsrechtliche Ansprüche
§§ 812 ff. BGB
Rechtshindernde Einwendungen
z.B. § 105 BGB, §§ 116 ff. BGB, § 125 BGB, § 138 BGB
Rechtsvernichtende Einwendungen
z.B. § 362 BGB, § 346 BGB, §§ 119 ff. BGB, § 275 BGB
Einreden
peremptorische (dauernde)
z.B. Verjährung, § 214 BGB
dilatorische (aufschiebende)
z.B. nichterfüllter Vertrag, § 320 BGB
Update release v1.2.2,
no more annoying 403 popup of '$:/StoryList' before login.
And here are some must to be known: https://github.com/cs8425/widdly#important-to-know
--------
This fork provide a minimal self-hosted TiddlyWiki5 server written in Go,
original form opennota/widdly, and bring proof of concept flat-file & sqlite backends support from xarnze/widdly with much improvements.
features:
support bolt/bbolt, flat-file and sqlite backends
multi-arch/platform pre-compile executable [1]
multi-user login & edit (currently edit same wiki)
support TLS and http/2 !!
modify plugins without manually update base TW5 html file, all can be done in browser.
[1] sqlite backend only linux amd64 version support, if need other platform please compile your self. (cross-compile needs cgo support)
Github link: https://github.com/cs8425/widdly/tree/master
Download v1.2.2: https://github.com/cs8425/widdly/releases/tag/v1.2.2
PS. Any bugs/questions welcome to create issue.
PS. PRs are also welcome.
{{$:/plugins/telmiger/WMR/reference}}
---
{{$:/plugins/telmiger/WMR/about}}
Die Willenserklärung i.S.d. §§ 145 ff. BGB ist wiederum die Äußerung eines Willens, die auf Setzung einer privatrechtlichen Rechtsfolge gerichtet ist. Beispiel: Das Angebot, einen Kaufvertrag abzuschließen.
Wirksamkeit der Willenserklärung eines Minderjährigen, §§ 106 ff. BGB
Die Wirksamkeit der Willenserklärung eines Minderjährigen, der in seiner Geschäftsfähigkeit beschränkt ist, wird in den §§ 106 ff. BGB geregelt. Es gibt vier Möglichkeiten, die Wirksamkeit der Willenserklärung eines Minderjährigen zu erreichen.
I. Lediglich rechtlich vorteilhaft, § 107 BGB
Zunächst liegt die Wirksamkeit der Willenserklärung eines Minderjährigen vor, wenn das Rechtsgeschäft des Minderjährigen lediglich rechtlich vorteilhaft ist. Ein Rechtsgeschäft ist nach § 107 BGB lediglich rechtlich vorteilhaft, wenn es nicht unmittelbar rechtlich nachteilig ist. Es fallen auch rechtlich neutrale Geschäfte in die Definition. Nicht entscheidend ist also, ob das Rechtsgeschäft gut ist, entscheidend ist, dass es nicht schlecht ist. Dies ist auch dem Rechtsgedanken des § 165 BGB zu entnehmen. Dort ist die Wirksamkeit der Willenserklärung eines Minderjährigen, der als Stellvertreter handelt, geregelt. Wenn ein Minderjähriger als Stellvertreter handelt, so verpflichtet er nicht sich selbst, sondern einen Dritten. Derartige neutrale Rechtsgeschäfte sind folglich unschädlich. Unmittelbar rechtlich nachteilig ist ein Rechtsgeschäft immer dann, wenn der Minderjährige persönlich verpflichtet oder ein Recht des Minderjährigen aufgehoben oder beschränkt wird. Eine Verpflichtung liegt beispielsweise bei einem Kaufvertrag vor: Wenn der Minderjährige einen Kaufvertrag abschließt, dann verpflichtet ihn dieser entweder zur Übereignung der Sache oder zur Zahlung des Kaufpreises, vgl. § 433 I, II BGB. Ebenso ist der Fall gelagert, in welchem der Minderjährige sein Rad verkauft und dann anschließend das Rad übereignet. Durch die Übereignung verlöre er sein Eigentum an dem Rad und dies wäre nicht lediglich rechtlich vorteilhaft.
II. Einwilligung des gesetzlichen Vertreters, § 107 BGB
Die Wirksamkeit der Willenserklärung eines Minderjährigen kann des weiteren auch durch die Einwilligung des gesetzlichen Vertreters vor dem Abschluss des Rechtsgeschäfts eintreten. Eine solche Wirksamkeit der Willenserklärung des Minderjährigen ergibt sich aus § 107 BGB.
Die Einwilligung ist in § 183 BGB legaldefiniert und meint die vorherige Zustimmung. Gesetzliche Vertreter sind üblicherweise die Eltern des Minderjährigen, vgl. §§ 1626, 1629 BGB. Wenn die Eltern also vorher dem Rechtsgeschäft zugestimmt haben, so ist dieses wirksam. Zu beachten ist jedoch, dass in bestimmten Fällen eine Beteiligung des Vormundschaftsgerichts vorgesehen ist, vgl. §§ 1821, 1822 BGB (Grundstücksgeschäfte oder solche, die die Gründung einer Gesellschaft betreffen).
III. Genehmigung des gesetzlichen Vertreters, § 108 BGB
Weiterhin kann die Wirksamkeit der Willenserklärung eines Minderjährigen gemäß § 108 BGB durch Genehmigung des gesetzlichen Vertreters erreicht werden. Die Genehmigung ist in § 184 BGB legaldefiniert und meint die nachträgliche Zustimmung. Wenn ein Minderjähriger also ein Rechtsgeschäft abschließt, das nicht lediglich rechtlich vorteilhaft ist, und die Eltern haben nicht bereits im Vorhinein zugestimmt, dann kann das Rechtsgeschäft durch eine nachträgliche Zustimmung geheilt und damit die Wirksamkeit der Willenserklärung des Minderjährigen erzielt werden.
IV. Sonderfälle
Zuletzt kann die Wirksamkeit der Willenserklärung eines Minderjährigen in den Sonderfällen der § 110, 112 und 113 BGB eintreten. § 110 BGB ist der sogenannte Taschengeldparagraph. Die Wirksamkeit der Willenserklärung eines Minderjährigen hängt danach davon ab, dass der Minderjährige das Rechtsgeschäft mit seinem Taschengeld tätigt, wobei es nicht darauf ankommt, ob der Minderjährige das Geld zuvor von seinen Eltern oder mit deren Zustimmung von einem Dritten erhalten hat. Ausgenommen davon sind allerdings Ratenzahlungsgeschäfte. Beispiel: A bist 8 Jahre alt, bekommt einen Euro Taschengeld pro Woche und geht in einen Spielzeugladen. Dort sieht A ein wunderschönes Spielzeug, das allerdings 20 Euro kostet. Der Verkäufer kommt dem A jedoch entgegen und schlägt vor, dass A die gesparten 5 Euro anzahlen und den Rest abstottern könne, immer einen Euro pro Woche. Der Verkäufer und A werden sich handelseinig. Hier ist die Willenserklärung des Minderjährigen nicht wirksam. Dies folgt aus dem Wortlaut des § 110 BGB. Dort steht „bewirkt“ und nicht „bewirken wird“, sodass ein zukünftiges Bewirken nicht von der Norm erfasst ist. Im Übrigen sind für die Wirksamkeit der Willenserklärung eines Minderjährigen das selbständige Erwerbsgeschäft gemäß § 112 BGB und das Arbeits- oder Dienstverhältnis eines Minderjährigen nach § 113 BGB zu berücksichtigen.
Abgabe, Zugang, Vollmacht §§ 104 ff, 130, 164 ff. BGB
Weiterhin muss diese Willenserklärung bei der Einigung auch wirksam werden. Hierbei ist zu beachten, dass das Angebot eine empfangsbedürftige Willenserklärung darstellt. Wird diese Willenserklärung nur schriftlich verfasst und dann in die Schublade gelegt, wird sie folglich nicht wirksam. Es kommt hierbei auf den Zugang an, welcher zusammen mit dem Wirksamwerden in einem gesonderten Exkurs erörtert wird.
WordNet: Englischsprachige lexikalische Datenbank, Linguist George Miller/Princetone University (
EuroWordNet EWN
Ziel: mono- und crosslinguales Information Retrieval
WordNet-Lexika für verschiedene europäische Sprachen, verbunden durch einen interlingualen Index (ILI), Basisstruktur amerikanisches WordNet, erweiterte semantisch-lexikalische Relationen (insb Synonymie, Antonymie oder Hyponymie). Drei Top-Level-Kategorien ("top-ontology" mit 63 semantischen Auszeichnungen/Merkmalen – 1st, 2nd, 3rdOrderEntity) bilden den gemeinsamen semantischen Rahmen für alle Sprachen (
Deutsche Variante: GermaNet (
Aufbauend auf WordNet und EWN: Global WordNet
<$list filter="[prefix[El Libro]sort[title]]-[[El Libro]]" variable="sub">
<$list filter="[<sub>removeprefix[El Libro / ]]" variable="truncated">
<$link to=<<sub>>><<truncated>></$link><br>
</$list>
</$list>
Risikoreduktion (juristische und soziologische Bewertung)
Leben ist lebensgefährlich; Recht als Ordnung dient zur Reduktion dieser Risiken
Effizienz und Zweckmäßigkeit als wesentliche Kriterien
Vorüberlegungen zu Bewertungskriterien (benchmarking)
Verständlichkeit der Norm
Anerkennungswahrscheinlichkeit
Praktische Anwendbarkeit
Erforderliche Kontrolldichte (Überwachung + Sanktionierung)
Einhaltungswahrscheinlichkeit
Normverletzungsrisiko
Verhaltensstabilisierung (Luhmann)
//So wenig wie nötig, so genau wie möglich…//
MATRIX zwischen VORAUSSETZUNGEN und KEYS um BEGEHREN des Users zu ordnen und zu finden
UMSETZUNG über visuelle HAPTIK um TIDDLER
* [[BGB Allgemeiner Teil]]
* [[Schuldrecht Allgemeiner Teil]]
* [[Schuldrecht Besonderer Teil]]
* [[Sachenrecht]]
Handelsrecht
Zivilprozessrecht 1 (Erkenntnisverfahren)
Zivilprozessrecht 2 (Zwangsvolltreckungsrecht)
Mobiliarsachenrecht
BGH, 01.07.2010 - I ZR 61/09
Der I. Zivilsenat des Bundesgerichtshofs hat
am 1. Juli 2010
durch
den Vorsitzenden Richter Prof. Dr. Bornkamm und
die Richter Pokrant, Prof. Dr. Büscher, Dr. Schaffert und Dr. Koch
beschlossen:
Tenor:
Die Beschwerde der Beklagten gegen die Nichtzulassung der Revision in dem Urteil des 18. Zivilsenats des Oberlandesgerichts Düsseldorf vom 1. April 2009 wird zurückgewiesen, weil die Rechtssache keine grundsätzliche Bedeutung hat, die auf die Verletzung von Verfahrensgrundrechten gestützten Rügen nicht durchgreifen und die Fortbildung des Rechts oder die Sicherung einer einheitlichen Rechtsprechung eine Entscheidung des Revisionsgerichts auch im Übrigen nicht erfordern (§ 543 Abs. 2 Satz 1 ZPO).
Das Berufungsgericht hat nicht von Amts wegen eine den Richtern aus einem anderen Verfahren bekannte Tatsache zur Grundlage des angegriffenen Urteils gemacht. Der Vorsitzende des Berufungssenats hat die Parteien mit Verfügung vom 29. Oktober 2008 darauf hingewiesen, dass es mittlerweile "gerichtsbekannt" sei, dass die Beklagte bei einem Hinweis auf die Gefahr eines ungewöhnlich hohen Schadens weder die Beförderung ablehne noch besondere Sicherheitsvorkehrungen treffe, wenn die Grenze zum Verbotsgut nicht erreicht werde, was bei allen noch in Rede stehenden Schadensfällen zutreffe. Die Klägerin hat hierzu mit Schriftsatz vom 3. November 2008 Stellung genommen und mitgeteilt, dass dem gerichtlichen Hinweis aus ihrer Sicht nur zugestimmt werden könne. Damit hat sie hinreichend deutlich zum Ausdruck gebracht, dass sie sich dem Standpunkt des Gerichts anschließt und sich die vom Berufungssenat angeführte Tatsache im Rahmen ihres Vortrags zu eigen macht. Dem Beibringungsgrundsatz ist damit genügt (vgl. Musielak/Huber, ZPO, 7. Aufl., § 291 Rdn. 4; Laumen in Prütting/Gehrlein, ZPO, 2. Aufl., § 291 Rdn. 6 a.E.). Die von der Nichtzulassungsbeschwerde für grundsätzlich erachtete Rechtsfrage stellt sich danach im Streitfall nicht.
Von einer näheren Begründung wird gemäß § 544 Abs. 4 Satz 2, 2. Halbs. ZPO abgesehen.
Die Beklagte trägt die Kosten des Beschwerdeverfahrens (§ 97 Abs. 1 ZPO).
m Rahmen der Einigung ist bei der Annahme zu beachten, dass als Ausnahme zur Empfangsbedürftigkeit § 151 BGB gilt. Danach kann auf den Zugang der Annahme verzichtet werden, wenn dies der Verkehrssitte entspricht. Beispiel: Bei einer klassischen Katalogbestellung entspricht es der Verkehrssitte, dass die Annahmeerklärung als solche nicht zugehen muss, es reicht vielmehr aus, dass der Sache nach Annahmehandlungen, das heißt das Verpacken der Ware, vorgenommen werden. Es ist ausgeschlossen, dass eine Annahme in solchen Fällen erst mit Zustellung des Pakets erfolgt, da die Ware sonst ohne Vertrag auf Reisen gehen würde.
Das Wichtigste in Kürze
Wer sich scheiden lässt und vorher in einer Zugewinngemeinschaft gelebt hat, kann von seinem Ehegatten die Hälfte des während der Ehe erwirtschafteten Vermögens verlangen. Wer keinen notariellen Ehevertrag abgeschlossen hat, lebt automatisch in einer Zugewinngemeinschaft.
Nicht das gesamte Vermögen wird ausgeglichen, sondern nur der Vermögenszuwachs nach der Heirat.
Dazu gehören zum Beispiel auch Lottogewinne, Abfindungen und Leistungen aus einer privaten Unfallversicherung. Bei einer Erbschaft oder Schenkung wird nur der Wertzuwachs ausgeglichen, die Erbschaft selbst aber nicht.
Es ist den Eheleuten freigestellt, ob sie ein formelles Zugewinnausgleichsverfahren im Rahmen der Scheidung durchführen wollen. Eheleute sollten das wegen der Kosten besser außerhalb des Scheidungsverfahrens regeln.
Wenn beide Eheleute während der Ehe gleich viel hinzugewonnen haben, zum Beispiel gemeinsam ein Haus gebaut haben und beide als Eigentümer im Grundbuch stehen, gibt es nichts auszugleichen.
Unser Tipp: Bleiben Sie zu Familien- und Erbrecht immer auf dem Laufenden - mit unserem kostenlosen Newsletter!
Ihre E-Mail Adresse
Ja, bitte!
Wer sich scheiden lässt und während der Ehe in einer Zugewinngemeinschaft gelebt hat, kann einen sogenannten Zugewinnausgleich beantragen. Das gilt für alle Ehen, in denen das Ehepaar keinen Ehevertrag vor dem Notar gemacht hat. Ehegatten leben nämlich automatisch in einer Zugewinngemeinschaft, wenn sie nicht vertraglich etwas anderes vereinbaren (§ 1363 Abs. 1 BGB). Das gilt auch für eingetragene Lebenspartnerschaften.
Der Zugewinn, den die Ehegatten in der Ehe erzielen, ist bei der Scheidung auf Antrag auszugleichen. Anders als beim Versorgungsausgleich passiert nichts, solange Sie keinen Antrag beim Familiengericht stellen. Unser Tipp ist deswegen: Versuchen Sie den Zugewinnausgleich erst einmal untereinander zu regeln. Denn anderenfalls können die Anwalts- und Gerichtskosten ganz beträchtlich steigen. Doch was ist, wenn es Streit gibt? Und fällt der Lottogewinn oder das geerbte Haus in den Zugewinn?
Was ist der Zugewinnausgleich?
Während der Ehe haben in der Regel beide Eheleute oder zumindest einer von ihnen Vermögen hinzugewonnen. Dabei kann es sich zum Beispiel um Bankguthaben, Grundstücke, Wertpapiere, Versicherungen, Luxusgüter oder auch eine eigene Firma handeln. Der Vermögenszuwachs kann auch darauf beruhen, dass während der Ehe Schulden abgezahlt wurden. Der Zugewinn ist die Differenz zwischen dem Endvermögen eines Partners bei Scheidung und seinem Anfangsvermögen bei Heirat.
Das Gesetz geht davon aus, dass grundsätzlich beide Eheleute je zur Hälfte an dem Vermögenszuwachs während der Ehe teilhaben sollen. Wenn zum Beispiel Frau und Mann beide zusammengerechnet während der Ehe um 200.000 Euro reicher geworden sind, so steht jedem von ihnen die Hälfte davon zu, also 100.000 Euro.
Der Ausgleichsanspruch ist ein Anspruch auf eine bestimmte Geldsumme. Es kann nicht verlangt werden, dass bestimmte Vermögensgegenstände übertragen werden. Hat also zum Beispiel die Ehefrau während der Ehe weniger Vermögen hinzuerworben als ihr Mann, so kann sie von ihm nur verlangen, dass er ihr einen Ausgleich zahlt. Sie kann nicht verlangen, dass ihr ein Teil des Aktienpakets oder das Haus überlassen wird. Natürlich können die Eheleute untereinander etwas anderes vereinbaren.
Für die Berechnung des Zugewinnausgleichs ist eine Vermögensaufstellung erforderlich. Alles vorhandene Vermögen muss in die Berechnung einbezogen werden. Darum ist es nicht möglich, isoliert nur einzelne Vermögensgegenstände auszugleichen.
In welchen Fällen wird kein Zugewinnausgleich durchgeführt?
Der Zugewinnausgleich muss nicht zwingend bei einer Scheidung durchgeführt werden. Niemand zwingt die Eheleute dazu.
Kein Antrag - Es bleibt dem Ehegatten, dem der Zugewinnausgleich zusteht, überlassen, ob und wie er diesen Anspruch geltend macht. Sofern die Vermögensunterschiede sehr groß sind oder Sie überhaupt keinen Überblick haben, sollten Sie einen Fachanwalt für Familienrecht zurate ziehen. Nur so kann ein Anspruch erst berechnet werden.
Gleicher Zugewinn - In vielen Fällen erübrigt sich ein Zugewinnausgleich. Nämlich dann, wenn von vornherein klar ist, dass Mann und Frau während der Ehe gleich viel hinzugewonnen haben. Typisches Beispiel: Bei der Heirat hatten beide kein Vermögen, während der Ehe ist ein gemeinsames Haus angeschafft worden, weiteres nennenswertes Vermögen gibt es nicht. Hier ist der Zugewinn auf beiden Seiten gleich groß, nämlich das halbe Miteigentum am Haus, sodass ein Zugewinnausgleich gar nicht in Betracht kommt.
Vertragliche Regelung - Eheleute können in einem Ehevertrag vereinbaren, dass der Zugewinnausgleich anders berechnet werden soll, als es das Gesetz vorsieht. Sie können zum Beispiel festlegen, dass bestimmte Vermögensgegenstände nicht berücksichtigt werden sollen. Oder sie können beschließen, dass der Berechtigte mit einer pauschalen Summe abgefunden wird. Sie können auch im Vertrag regeln, dass der Berechtigte statt eines Geldbetrags einen Vermögensgegenstand übertragen bekommt. Diese und andere denkbare Vereinbarungen bedürfen aber immer der notariellen Beurkundung. Dann kommt es nicht zu einem Ausgleichsverfahren nach den gesetzlichen Regelungen.
Gütertrennung - Wenn Sie ohnehin vor einem Notar per Ehevertrag Gütertrennung vereinbart haben, kann bei der Scheidung auch kein Zugewinnausgleich verlangt werden. Eine solche Vereinbarung kann bereits bei der Heirat in einem Ehevertrag, aber auch noch während des laufenden Scheidungsverfahrens getroffen werden.
Unser Tipp: Bleiben Sie zu Familien- und Erbrecht immer auf dem Laufenden - mit unserem kostenlosen Newsletter!
Ihre E-Mail Adresse
Ja, bitte!
Wie wird der Zugewinnausgleich berechnet?
Der Zugewinnausgleich setzt voraus, dass man die beiden Gesamtvermögen der Ehegatten miteinander vergleicht. Bei jeder Person ist dabei der Vermögenszuwachs während der Ehe zu bestimmen. Dazu berechnet man die Differenz zwischen seinem End- und seinem Anfangsvermögen. Anfangsvermögen ist das Vermögen, das er bei Eheschließung hatte. Endvermögen ist das Vermögen, das der Ehegatte bei Beendigung der Ehe hat.
Stichtag ist seit dem 1. September 2009 dabei nicht die Scheidung, sondern der Tag der Zustellung des Scheidungsantrags an den anderen Ehegatten (§ 1384 BGB). Wenn die Ehe bereits vor dem 1. September 2009 rechtskräftig geschieden wurde, gilt als Stichtag für die Ausgleichsforderung noch die Beendigung der Ehe (BGH, Urteil vom 16. Juli 2014, Az. XII ZR 108/12)
Nur auf den jeweiligen Vermögensstand der Ehegatten zu diesen Zeitpunkten kommt es an. Nicht von Bedeutung ist, wer während der Ehe was gezahlt hat. Ebenso uninteressant ist, wer mehr verdient hat als der andere.
Der Zugewinn der beiden Ehegatten wird verglichen. Derjenige, der mehr erwirtschaftet hat, muss die Hälfte des saldierten Zugewinns an den anderen Ehegatten zahlen.
Beispiel: Partner A besitzt zum Zeitpunkt der Heirat 10.000 Euro. Zum Zeitpunkt der Scheidung hat er aus seiner Berufstätigkeit ein Vermögen von 25.000 Euro angesammelt. Partner B besaß zu Beginn der Ehe 5.000 Euro und zum Zeitpunkt der Scheidung 6.000 Euro.
Quelle: Finanztip-Grafik (Stand: 20. April 2017)
Der Zugewinn des Partners A beträgt somit: 25.000 Euro - 10.000 Euro = 15.000 Euro.
Der Zugewinn des Partners B beträgt: 6.000 Euro - 5.000 Euro = 1.000 Euro.
Der Überschuss an Zugewinn beträgt: 15.000 Euro – 1.000 Euro = 14.000 Euro.
Partner B kann von Partner A die Hälfte dieses Überschusses verlangen, also 7.000 Euro.
Für jeden einzelnen Ehegatten ist es im Hinblick auf den Ausgleichsanspruch von Vorteil, wenn sein Anfangsvermögen möglichst groß, sein Endvermögen dagegen möglichst klein ist. Je größer das Anfangs- und je kleiner das Endvermögen, desto geringer der eigene Zugewinn.
Besonderheiten bei der Ermittlung des Anfangsvermögens
Bei der Ermittlung des Anfangsvermögens können folgende Besonderheiten auftreten:
Keine genaue Kenntnis des Vermögens bei der Heirat - Wenn Sie nicht mehr genau nachweisen können, welches Vermögen bei Eheschließung vorhanden war, wird Ihr Anfangsvermögen mit 0 Euro angesetzt (§ 1377 Abs. 3 BGB). Alles muss bewiesen werden: Wer von damals keine Aufzeichnungen mehr hat (Sparbuch, Bankunterlagen etc.), steht mit leeren Händen da. Vor der Heirat sollten Sie sich also ganz genau aufschreiben, welches Vermögen und welche Schulden vorhanden sind.
Schulden bei der Heirat - Hatte ein Ehegatte bei Eheschließung nur Schulden oder waren seine Schulden höher als sein Vermögen, so werden diese berücksichtigt. Es wird ein sogenanntes negatives Anfangsvermögen angesetzt (§ 1374 Abs. 3 BGB).
Erbschaften und Schenkungen - Erbschaften und Schenkungen sollen beim Zugewinnausgleich außen vor bleiben. Deshalb werden sie zum Anfangsvermögen hinzugerechnet, auch wenn sie erst nach der Hochzeit erworben wurden (1374 Abs. 2 BGB). Dadurch soll erreicht werden, dass sich der Zugewinnausgleich wirklich nur auf das gemeinsam Erwirtschaftete beschränkt. Von der Erbschaft oder Schenkung profitiert der andere Ehegatte deshalb grundsätzlich nicht, weil so getan wird, als ob die Erbschaft schon bei der Hochzeit vorhanden war.
Beispiel: Partner B besitzt zum Zeitpunkt der Heirat 30.000 Euro. Während der Ehe stirbt die Mutter, er erbt 150.000 Euro. Diese 150.000 Euro werden dem Anfangsvermögen hinzugerechnet, das Anfangsvermögen beträgt also 180.000 Euro.
Das gehört zum Endvermögen
Zum Endvermögen gehört alles Vermögen, das bei Zustellung des Scheidungsantrags an den anderen Ehepartner vorhanden ist. Schulden sind abzuziehen. Woher das Vermögen stammt, ist unerheblich. Zum Endvermögen zählen also auch:
Vermögen, das bereits bei Eheschließung vorhanden war,
Erbschaften und Schenkungen,
Vermögen, das mit ererbtem oder geschenktem Geld erworben wurde,
Lottogewinn, selbst wenn dieser lange nach der Trennung dem einen Ehegatten zufällt (BGH, Urteil vom 9. Oktober 2013, Az. XII ZR 125/12),
Schmerzensgeld (BGH, Urteil vom 27. Mai 1981, Az. IVb ZR 577/80) und
Lebensversicherungen, die nicht der Altersvorsorge, sondern der Vermögensbildung dienen und deshalb nicht unter den Versorgungsausgleich fallen. Als Wert wird der Rückkaufswert oder der Zeitwert angesetzt, wenn sie fortgeführt werden sollen. Eine solche Bestätigung hat der Versicherer auszustellen.
Auch gemeinsames Vermögen der Eheleute wird berücksichtigt, allerdings nur der eigene Anteil. Haben die Parteien also ein gemeinsames Haus mit einem Wert von 300.000 Euro während der Ehe gekauft, so fließt dieses Haus jeweils mit einem Betrag von 150.000 Euro in das Endvermögen beider Personen.
Negatives Endvermögen - Das Endvermögen kann genau wie das Anfangsvermögen auch negativ sein, wenn ein Partner bei Zustellung des Scheidungsantrags Schulden hat (§ 1375 Abs. 1 Satz 2 BGB).
Zurechnung zum Endvermögen - Falls der Partner Vermögen verschwendet hat, wird der Betrag, der nicht mehr vorhanden ist, dennoch dem Endvermögen zugerechnet (§ 1375 Abs. 2 BGB). Das muss allerdings bewiesen werden, was nicht leicht ist. Allein ein großzügiger Lebensstil oder ein Leben über die Verhältnisse reicht dazu nicht aus. Die Teilnahme an Glücksspielen ist dann verschwenderisch, wenn das Verspielen des Vermögens leichtfertig ist.
Unser Tipp: Bleiben Sie zu Familien- und Erbrecht immer auf dem Laufenden - mit unserem kostenlosen Newsletter!
Ihre E-Mail Adresse
Ja, bitte!
Berechnung des Zugewinns bei Erbschaft während der Ehe
Eine Erbschaft wird zum Anfangsvermögen hinzugerechnet. Solange die Erbschaft noch vorhanden ist, gehört sie auch zum Endvermögen. Wenn zum Beispiel der Ehemann zu Beginn der Ehe kein Vermögen hatte, aber während der Ehe ein Haus erbt, wird das Haus dem Anfangsvermögen zu seinem damaligen Wert hinzugerechnet. Besitzt er das Haus auch noch am Ende der Ehe, wird es auch zum Endvermögen mit dem Wert bei der Zustellung des Scheidungsantrags hinzugerechnet. Das macht man deshalb, um zwischenzeitliche Wertsteigerungen durch den Zugewinn zu erfassen.
Es ist dabei unerheblich, woher der Wertzuwachs kommt. Er kann daher kommen, dass der Eigentümer das Haus renoviert hat. Er kann auch einfach daher kommen, dass die Grundstückspreise gestiegen sind. Entscheidend ist immer der sogenannte Verkehrswert des Vermögensgegenstands. Also der Wert, der als Erlös bei einer Veräußerung unter Ausnutzung aller Marktchancen erzielt werden könnte.
Beispiel: Partner C hat bei der Heirat Schulden in Höhe von 10.000 Euro. Im Jahr 1995 erbt er ein Haus, das damals einen Wert von 150.000 Euro hat. Am Ende der Ehe im Jahr 2016 hat es aber einen Wert von 220.000 Euro. Für Renovierungskosten hat er ein Darlehen aufgenommen, das bei Zustellung des Scheidungsantrags noch mit 40.000 Euro zu Buche schlägt. Partnerin D besaß zu Beginn der Ehe 20.000 Euro. Am Ende der Ehe beläuft sich ihr Vermögen auf 30.000 Euro.
Quelle: Finanztip-Grafik (Stand: 20. April 2017)
Wie Sie in dem Schaubild sehen, beläuft sich der Anspruch von Partnerin D also auf 15.000 Euro.
Kaufkraftausgleich beim Zugewinn
Bei der Berechnung des Zugewinnausgleichs ist der Wert des Anfangsvermögens vom Endvermögen abzuziehen. Damit diese Werte auch wirklich vergleichbar sind, muss das Anfangsvermögen auf den Geldwert zum Stichtag des Endvermögens umgerechnet werden. Dabei wird der inflationsbedingte Kaufkraftverlust mithilfe der sogenannten Indexierung aus dem Zugewinnausgleich herausgerechnet. Entscheidend sind dabei die Verbrauchpreisindizes des Statistischen Bundesamts. Es wird dabei in aller Regel der Jahresindex verwendet und keine Differenzierung nach Monaten vorgenommen.
Das geschieht mit folgender Formel:
Anfangsvermögen x Index bei Stellung des Scheidungsantrages / Index bei Heirat =
indexiertes Anfangsvermögen.
Verbraucherpreisindizes ab 1991
1991 70,2 2004 91,0
1992 73,8 2005 92,5
1993 77,1 2006 93,9
1994 79,1 2007 96,1
1995 80,5 2008 98,1
1996 81,6 2009 98,9
1997 83,2 2010 100
1998 84,0 2011 102,1
1999 84,5 2012 104,1
2000 85,7 2013 105,7
2001 87,4 2014 106,6
2002 88,6 2015 106,9
2003 89,6 2016 107,4
Quelle: Statistisches Bundesamt (Stand: 20. April 2017)
Wenn Sie online Ihren Zugewinn berechnen wollen, wird meist der Kaufkraftausgleich automatisch berücksichtigt. Sie können zum Beispiel dieses Formular von der Kanzlei Dr. Annegret Wiese aus München verwenden.
Beispiel: Partner E hat bei der Heirat im Jahr 1992 Vermögen in Höhe von 20.000 Euro. Am Ende der Ehe im Jahre 2016 verfügt er über ein Vermögen von 220.000 Euro, ein Nettozugewinn damit von 200.000 Euro.
Berechnung indexiertes Anfangsvermögen:
20.000 Euro × 107,4 / 73,8 = 29.106 Euro.
Der Zugewinn beläuft sich damit nur noch auf 190.894 Euro.
Ausgleichsanspruch ist auf vorhandenes Vermögen beschränkt
Es gibt eine Grenze für den Zugewinnausgleich. Derjenige, der ausgleichspflichtig ist, muss nur bis zur Höhe seines tatsächlich vorhandenen Vermögens zahlen. Wieviel Vermögen tatsächlich vorhanden ist, muss er als Endvermögen belegen. Diese Summe muss er gegebenenfalls leisten, aber darüber hinaus muss er keine Schulden machen, um den Zugewinn auszugleichen.
Besteht der Zugewinn also vor allem darin, dass Schulden zurückgeführt wurden, kann der Ausgleichsanspruch sogar ganz entfallen, wenn kein Vermögen vorhanden ist (§§ 1378 Abs. 2 Satz 1, 1384 BGB).
Beispiel: Geht Partner X mit 100.000 Euro Schulden in die Ehe, hat er bei einem Endvermögen von 20.000 Euro einen Zugewinn von 120.000 Euro. Hat Partner Y keinen Zugewinn erwirtschaftet, beträgt der Ausgleichsanspruch 60.000 Euro. Der Anspruch wird aber auf das vorhandene Vermögen beschränkt, sodass der Partner Y nur 20.000 Euro als Ausgleich verlangen kann.
Auskunftsanspruch
Um den Zugewinnausgleich berechnen zu können, müssen Sie von Ihrem Partner Auskunft zu seinem Vermögen verlangen. Sie brauchen eine Übersicht über sein Anfangsvermögen und sein Vermögen bei der Trennung (§ 1379 Abs. 2 BGB). Dadurch soll verhindert werden, dass zwischen Trennung und Scheidung Vermögen auf die Seite geschafft wird.
Was aber, wenn der Ehegatte bereits vor der Trennung sein Vermögen verschenkt hat? Oder Werte an einen Dritten übertragen hat, damit Sie dadurch benachteiligt werden? Wenn der Verdacht besteht, dass ein Ehepartner bereits vor der Trennung Vermögensbestandteile oder Vermögen verschwinden ließ, so muss er auch darüber Auskunft geben (BGH, Urteil vom 15. August 2012, Az. XII ZR 80/11). Allerdings müssen Sie dazu nicht nur einen Verdacht haben, sondern konkrete Tatsachen vortragen und diese auch belegen können. Sonst wird es mit der Auskunft über die Zeit der Trennung schwierig.
Wann verjährt der Anspruch auf Zugewinnausgleich?
Der Anspruch auf Zugewinnausgleich verjährt drei Jahre nach Rechtskraft der Scheidung (§ 195 BGB). Das bedeutet, dass derjenige Ehegatte, der meint, vom anderen etwas zu bekommen, nicht ewig mit seinen Forderungen warten kann.
Anwendungsbereich der Zuständigkeitsregelungen der Europäischen Erbrechtsverordnung
↑
Die Europäische Erbrechtsverordnung (EuErbVO) enthält in den Art. 4 ff. EuErbVO Regelungen zur internationalen Zuständigkeit in "Erbsachen". Hierunter fallen insbesondere das Verfahren zur Erteilung eines Europäischen Nachlasszeugnisses; aber auch andere Nicht-Streitverfahren und Streitverfahren (Klage auf Pflichtteil oder Erteilung). Nicht hierunter fallen Verfahren betreffend die Voraussetzungen der Eintragung in ein Register, z.B. Handelregister oder Grundbuch.
Erblasser hatte seinen letzten gewöhnlichen Aufenthalt in einem Mitgliedsstaat
↑
Hatte der Erblasser im Zeitpunkt seines Todes seinen gewöhnlichen Aufenthalt in einem Mitgliedsstaat i.S.d. EuErbVO, ist zwischen der Allgemeinen Zuständigkeit und der Zuständigkeit bei Rechtswahl zu unterscheiden.
↑
Allgemeine Zuständigkeit
Für den gesamten Nachlass sind die Gerichte des Mitgliedstaats zuständig, in dessen Hoheitsgebiet der Erblasser im Zeitpunkt seines Todes seinen gewöhnlichen Aufenthalt hatte (Art. 4 EuErbVO).
Beispiel: Erblasser E, deutscher Staatsangehöriger, ist am 20.08.2017 verstorben. Zum Zeitpunkt seines Todes war sein gewöhnlicher Aufenthalt in Marbella, Spanien. Somit sind die Gerichte Spaniens international zuständig.
↑
Unzuständigkeit bei Rechtswahl
Hat der Erblasser von der Möglichkeit zur Rechtswahl nach Art. 22 EuErbVO Gebrauch gemacht,
kann sich das Gericht nach Art. 4 zuständige Gericht auf Antrag einer Partei des Verfahrens gemäß Art. 6 Abs. 1 EuErbVO für unzuständig erklären, wenn seines Erachtens die Gerichte des Mitgliedstaats des gewählten Rechts besser entscheiden können; dabei soll es die konkreten Umstände des Falls berücksichtigt, z.B. den gewöhnlichen Aufenthalt der Parteien und den Ort, an dem die Vermögenswerte belegen sind.
so können die Parteien des Verfahrens gemäß Art. 5 EuErbVO vereinbaren, dass für Entscheidungen in Erbsachen ausschließlich ein Gericht oder die Gerichte dieses Mitgliedstaats zuständig sein sollen; in diesem Fall ist das Gericht am letzten gewöhnlichen Aufenthalt unzuständig, § 6 Abs. 2 EuErbVO.
Beispiel: Erblasser E hat in vorgehendem Beispiel in seinem Testament deutsches Erbrecht gewählt. Die testamentarischen Erben und die gesetzlichen Erben streiten über die Wirksamkeit des Testaments. Nachdem man sich über eine Gerichtsstandsvereinbarung nicht einigen konnte, beantragt der Kläger, F, damit, dass sich Gericht für unzuständig erklärt. Den Antrag begründet damit, dass die testamentarischen Erben und gesetzlichen Erben in Deutschland leben, der Nachlass überwiegend in Deutschland belegen ist und alle Dokumente in deutscher Sprache verfasst sind.
↑
Zuständigkeit bei Rechtswahl
Die Gerichte eines Mitgliedstaats, dessen Recht der Erblasser nach Artikel 22 gewählt hat, sind für die Entscheidungen in einer Erbsache zuständig, wenn
sich ein zuvor angerufenes Gericht nach Artikel 6 in derselben Sache für unzuständig erklärt hat,
die Verfahrensparteien nach Artikel 5 die Zuständigkeit eines Gerichts oder der Gerichte dieses Mitgliedstaats vereinbart haben oder
die Verfahrensparteien die Zuständigkeit des angerufenen Gerichts ausdrücklich anerkannt haben.
Beispiel: Nachdem das spanische Gericht sich für unzuständig erklärt hat, erhebt F Klage in einem deutschen Gericht. Dieses ist nun international zuständig.
Erblasser hatte keinen gewöhnlichen Aufenthalt in einem Mitgliedsstaat (Subsidiäre Zuständigkeit)
↑
Hatte der Erblasser seinen letzten gewöhnlichen Aufenthalt nicht in einem Mitgliedstaat, so sind die Gerichte des Mitgliedstaats, in dem sich die Nachlassmasse befindet, zuständig, wenn der Erblasser die Staatsangehörigkeit dieses Mitgliedstaats im Zeitpunkt seines Todes besaß (Art. 10 Abs. 1 a) EuErbVO).
Beispiel: Erblasser E, deutscher Staatsangehöriger, lebte bei seinem Tod bereits 20 Jahre in Miami, Florida. Zum Zeitpunkt seines Todes hatte er in Deutschland noch ein Konto und Depot. Wegen seiner Staatsangehörigkeit sind deutsche Gerichte zuständig.
Ergibt sich aus dem vorstehenden keine Zuständigkeit, sind die Gerichte eines Mitgliedstaats, in dem sich Nachlassvermögen befindet, zuständig, sofern
der Erblasser seinen vorhergehenden gewöhnlichen Aufenthalt in dem Mitgliedstaat hatte und
die Änderung dieses gewöhnlichen Aufenthalts zum Zeitpunkt der Anrufung des Gerichts nicht länger als 5 Jahre zurückliegt.
Beispiel: Erblasser E hatte seine Staatsangehörigkeit durch Annahme der US-Staatsangehörigkeit verloren. War sein letzter gewöhnlicher Aufenthalt in den letzten 5 Jahren vor dem Tod in Deutschland, sind deutsche Gerichte zuständig.
Ist kein Gericht in einem Mitgliedstaat nach vorstehenden Regeln zuständig, so sind dennoch die Gerichte des Mitgliedstaats, in dem sich Nachlassvermögen befindet, für Entscheidungen über dieses Nachlassvermögen zuständig.
Vermögen in einem Drittstaat: Beschränkung des Verfahrens
↑
Umfasst der Nachlass des Erblassers Vermögenswerte, die in einem Drittstaat, z.B. USA oder dem Vereinigten Königreich, belegen sind, so kann das Gericht auf Antrag beschließen, über einen oder mehrere dieser Vermögenswerte nicht zu befinden, wenn
zu erwarten ist, dass seine Entscheidung in Bezug auf diese Vermögenswerte in dem betreffenden Drittstaat nicht anerkannt oder
gegebenenfalls nicht für vollstreckbar erklärt wird (Art. 12 EuErbVO).
Tabellarische Übersicht
↑
Anwendbares Erbrecht
Zuständigkeit
Letzter gewöhnlichen Aufenthalt des Erblassers war in ...
Ohne Rechtswahl nach Art. 22 EuErbVO ist das Recht anzuwenden von
Bei wirksamer Rechtswahl nach Art. 22 EuErbVO:
Ohne Rechtswahl nach Art. 22 EuErbVO ist das Recht anzuwenden von
Bei wirksamer Rechtswahl nach Art. 22 EuErbVO:
Spanien
Spanisches Erbrecht bzw. forales Erbrecht
Deutsches Erbrecht
Spanien
Deutschland, in den Fällen der Art. 4 ff. EuErbVO
Deutschland
Deutsches Erbrecht
Spanisches Recht bzw. forales Erbrecht
Deutschland
Spanien, in den Fällen der Art. 4 EuErbVO